mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-08 02:31:19 +00:00
16b04699d0
* polling interval * adding proto message * changing proto messages * changing naming * adding slot functionality * initial sync working * new changes * more sync fixes * its working now * finally working * add tests * fix tests * tests * adding tests * lint * log checks * making changes to simulator * update logs * fix tests * get sync to work with crystallized state * fixing race * making requested changes * unexport * documentation * gazelle and fix merge conflicts * adding repeated requests * fix lint * adding new clock , db methods, and util func * revert change to test * gazelle * add in test * gazelle * finally working * save slot * fix lint and constant
53 lines
1.9 KiB
Go
53 lines
1.9 KiB
Go
package node
|
|
|
|
import (
|
|
"github.com/golang/protobuf/proto"
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
"github.com/prysmaticlabs/prysm/shared/cmd"
|
|
"github.com/prysmaticlabs/prysm/shared/p2p"
|
|
"github.com/prysmaticlabs/prysm/shared/p2p/adapter/metric"
|
|
"github.com/prysmaticlabs/prysm/shared/p2p/adapter/tracer"
|
|
"github.com/urfave/cli"
|
|
)
|
|
|
|
var topicMappings = map[pb.Topic]proto.Message{
|
|
pb.Topic_BEACON_BLOCK_ANNOUNCE: &pb.BeaconBlockAnnounce{},
|
|
pb.Topic_BEACON_BLOCK_REQUEST: &pb.BeaconBlockRequest{},
|
|
pb.Topic_BEACON_BLOCK_REQUEST_BY_SLOT_NUMBER: &pb.BeaconBlockRequestBySlotNumber{},
|
|
pb.Topic_BEACON_BLOCK_RESPONSE: &pb.BeaconBlockResponse{},
|
|
pb.Topic_CHAIN_HEAD_REQUEST: &pb.ChainHeadRequest{},
|
|
pb.Topic_CHAIN_HEAD_RESPONSE: &pb.ChainHeadResponse{},
|
|
pb.Topic_CRYSTALLIZED_STATE_HASH_ANNOUNCE: &pb.CrystallizedStateHashAnnounce{},
|
|
pb.Topic_CRYSTALLIZED_STATE_REQUEST: &pb.CrystallizedStateRequest{},
|
|
pb.Topic_CRYSTALLIZED_STATE_RESPONSE: &pb.CrystallizedStateResponse{},
|
|
pb.Topic_ACTIVE_STATE_HASH_ANNOUNCE: &pb.ActiveStateHashAnnounce{},
|
|
pb.Topic_ACTIVE_STATE_REQUEST: &pb.ActiveStateRequest{},
|
|
pb.Topic_ACTIVE_STATE_RESPONSE: &pb.ActiveStateResponse{},
|
|
}
|
|
|
|
func configureP2P(ctx *cli.Context) (*p2p.Server, error) {
|
|
s, err := p2p.NewServer(ctx.GlobalString(cmd.BootstrapNode.Name))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
traceAdapter, err := tracer.New("beacon-chain",
|
|
ctx.GlobalString(cmd.TracingEndpointFlag.Name),
|
|
ctx.GlobalFloat64(cmd.TraceSampleFractionFlag.Name),
|
|
ctx.GlobalBool(cmd.EnableTracingFlag.Name))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
adapters := []p2p.Adapter{traceAdapter}
|
|
if !ctx.GlobalBool(cmd.DisableMonitoringFlag.Name) {
|
|
adapters = append(adapters, metric.New())
|
|
}
|
|
|
|
for k, v := range topicMappings {
|
|
s.RegisterTopic(k.String(), v, adapters...)
|
|
}
|
|
|
|
return s, nil
|
|
}
|