mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-11 12:10:05 +00:00
d077483577
* v3 import renamings * tidy * fmt * rev * Update beacon-chain/core/epoch/precompute/reward_penalty_test.go * Update beacon-chain/core/helpers/validators_test.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/iface/BUILD.bazel * Update beacon-chain/db/kv/kv.go * Update beacon-chain/db/kv/state.go * Update beacon-chain/rpc/prysm/v1alpha1/validator/attester_test.go * Update beacon-chain/rpc/prysm/v1alpha1/validator/attester_test.go * Update beacon-chain/sync/initial-sync/service.go * fix deps * fix bad replacements * fix bad replacements * change back * gohashtree version * fix deps Co-authored-by: Nishant Das <nishdas93@gmail.com> Co-authored-by: Potuz <potuz@prysmaticlabs.com>
63 lines
2.3 KiB
Go
63 lines
2.3 KiB
Go
package p2p
|
|
|
|
import (
|
|
"reflect"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/config/params"
|
|
types "github.com/prysmaticlabs/prysm/v3/consensus-types/primitives"
|
|
ethpb "github.com/prysmaticlabs/prysm/v3/proto/prysm/v1alpha1"
|
|
"google.golang.org/protobuf/proto"
|
|
)
|
|
|
|
// gossipTopicMappings represent the protocol ID to protobuf message type map for easy
|
|
// lookup.
|
|
var gossipTopicMappings = map[string]proto.Message{
|
|
BlockSubnetTopicFormat: ðpb.SignedBeaconBlock{},
|
|
AttestationSubnetTopicFormat: ðpb.Attestation{},
|
|
ExitSubnetTopicFormat: ðpb.SignedVoluntaryExit{},
|
|
ProposerSlashingSubnetTopicFormat: ðpb.ProposerSlashing{},
|
|
AttesterSlashingSubnetTopicFormat: ðpb.AttesterSlashing{},
|
|
AggregateAndProofSubnetTopicFormat: ðpb.SignedAggregateAttestationAndProof{},
|
|
SyncContributionAndProofSubnetTopicFormat: ðpb.SignedContributionAndProof{},
|
|
SyncCommitteeSubnetTopicFormat: ðpb.SyncCommitteeMessage{},
|
|
}
|
|
|
|
// GossipTopicMappings is a function to return the assigned data type
|
|
// versioned by epoch.
|
|
func GossipTopicMappings(topic string, epoch types.Epoch) proto.Message {
|
|
if topic == BlockSubnetTopicFormat {
|
|
if epoch >= params.BeaconConfig().BellatrixForkEpoch {
|
|
return ðpb.SignedBeaconBlockBellatrix{}
|
|
}
|
|
if epoch >= params.BeaconConfig().AltairForkEpoch {
|
|
return ðpb.SignedBeaconBlockAltair{}
|
|
}
|
|
}
|
|
return gossipTopicMappings[topic]
|
|
}
|
|
|
|
// AllTopics returns all topics stored in our
|
|
// gossip mapping.
|
|
func AllTopics() []string {
|
|
var topics []string
|
|
for k := range gossipTopicMappings {
|
|
topics = append(topics, k)
|
|
}
|
|
return topics
|
|
}
|
|
|
|
// GossipTypeMapping is the inverse of GossipTopicMappings so that an arbitrary protobuf message
|
|
// can be mapped to a protocol ID string.
|
|
var GossipTypeMapping = make(map[reflect.Type]string, len(gossipTopicMappings))
|
|
|
|
func init() {
|
|
for k, v := range gossipTopicMappings {
|
|
GossipTypeMapping[reflect.TypeOf(v)] = k
|
|
}
|
|
// Specially handle Altair objects.
|
|
GossipTypeMapping[reflect.TypeOf(ðpb.SignedBeaconBlockAltair{})] = BlockSubnetTopicFormat
|
|
// Specially handle Bellatrix objects.
|
|
GossipTypeMapping[reflect.TypeOf(ðpb.SignedBeaconBlockBellatrix{})] = BlockSubnetTopicFormat
|
|
GossipTypeMapping[reflect.TypeOf(ðpb.SignedBlindedBeaconBlockBellatrix{})] = BlockSubnetTopicFormat
|
|
}
|