package p2p import ( "reflect" types "github.com/prysmaticlabs/eth2-types" ethpb "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1" pb "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1" "github.com/prysmaticlabs/prysm/shared/params" "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 && epoch >= params.BeaconConfig().AltairForkEpoch { return ðpb.SignedBeaconBlockAltair{} } return gossipTopicMappings[topic] } // AllTopics returns all topics stored in our // gossip mapping. func AllTopics() []string { 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 }