prysm-pulse/shared/p2p/message.go
terence tsao 1b5b8a57e0 Remove unused proto schemas (#3005)
* Update io_kubernetes_build commit hash to 1246899

* Update dependency build_bazel_rules_nodejs to v0.33.1

* Update dependency com_github_hashicorp_golang_lru to v0.5.1

* Update libp2p

* Update io_bazel_rules_k8s commit hash to e68d5d7

* Starting to remove old protos

* Bazel build proto passes

* Fixing pb version

* Cleaned up core package

* Fixing tests

* 6 tests failing

* Update proto bugs

* Fixed incorrect validator ordering proto

* Sync with master

* Update go-ssz commit

* Removed bad copies from v1alpha1 folder

* add json spec json to pb handler

* add nested proto example

* proto/testing test works

* fix refactoring build failures

* use merged ssz

* push latest changes

* used forked json encoding

* used forked json encoding

* fix warning

* fix build issues

* fix test and lint

* fix build

* lint
2019-07-22 10:03:57 -04:00

28 lines
807 B
Go

package p2p
import (
"context"
"reflect"
"github.com/gogo/protobuf/proto"
peer "github.com/libp2p/go-libp2p-peer"
)
// Message represents a message received from an external peer.
type Message struct {
// Ctx message context.
Ctx context.Context
// Peer represents the sender of the message.
Peer peer.ID
// Data can be any type of message found in sharding/p2p/proto package.
Data proto.Message
}
// messageType returns the underlying struct type for a given proto.message.
func messageType(msg proto.Message) reflect.Type {
// proto.Message is a pointer and we need to dereference the pointer
// and take the type of the original struct. Otherwise reflect.TypeOf will
// create a new value of type **ethpb.BeaconBlockHashAnnounce for example.
return reflect.ValueOf(msg).Elem().Type()
}