mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-04 08:44:28 +00:00
2e7b08f97e
* don't broadcast to yourself * todo * Also listen for incoming streams * send to a specific peer * add godoc comment * handle EOF as a normal thing * gazelle * add test for subscribing via direct comm
28 lines
804 B
Go
28 lines
804 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 **pb.BeaconBlockHashAnnounce for example.
|
|
return reflect.ValueOf(msg).Elem().Type()
|
|
}
|