package beaconchain import ( "github.com/harmony-one/harmony/api/proto" proto_identity "github.com/harmony-one/harmony/api/proto/identity" "github.com/harmony-one/harmony/p2p" ) // BeaconChainHandler handles registration of new Identities func (bc *BeaconChain) BeaconChainHandler(s p2p.Stream) { content, err := p2p.ReadMessageContent(s) if err != nil { bc.log.Error("Read p2p data failed") return } msgCategory, err := proto.GetMessageCategory(content) if err != nil { bc.log.Error("Read message category failed", "err", err) return } msgType, err := proto.GetMessageType(content) if err != nil { bc.log.Error("Read action type failed") return } msgPayload, err := proto.GetMessagePayload(content) if err != nil { bc.log.Error("Read message payload failed") return } identityMsgPayload, err := proto_identity.GetIdentityMessagePayload(msgPayload) if err != nil { bc.log.Error("Read message payload failed") return } switch msgCategory { case proto.Identity: actionType := proto_identity.IDMessageType(msgType) switch actionType { case proto_identity.Identity: bc.log.Info("Message category is of the type identity protocol, which is correct!") idMsgType, err := proto_identity.GetIdentityMessageType(msgPayload) if err != nil { bc.log.Error("Error finding the identity message type") } switch idMsgType { case proto_identity.Register: bc.log.Info("Identity Message Type is of the type Register") bc.AcceptConnections(identityMsgPayload) default: bc.log.Error("Unrecognized identity message type", "type", idMsgType) } default: bc.log.Error("Unrecognized message category", "actionType", actionType) } } }