The core protocol of WoopChain
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
woop/node/service_setup.go

73 lines
2.1 KiB

package node
import (
"fmt"
"github.com/harmony-one/harmony/api/service"
"github.com/harmony-one/harmony/api/service/blockproposal"
"github.com/harmony-one/harmony/api/service/consensus"
"github.com/harmony-one/harmony/api/service/explorer"
"github.com/harmony-one/harmony/api/service/networkinfo"
)
// RegisterValidatorServices register the validator services.
func (node *Node) RegisterValidatorServices() {
_, chanPeer, _ := node.initNodeConfiguration()
// Register networkinfo service. "0" is the beacon shard ID
node.serviceManager.Register(
service.NetworkInfo,
networkinfo.MustNew(
node.host, node.NodeConfig.GetShardGroupID(), chanPeer, nil, node.networkInfoDHTPath(),
),
)
// Register consensus service.
node.serviceManager.Register(
service.Consensus,
consensus.New(node.BlockChannel, node.Consensus, node.startConsensus),
)
// Register new block service.
node.serviceManager.Register(
service.BlockProposal,
blockproposal.New(node.Consensus.ReadySignal, node.Consensus.CommitSigChannel, node.WaitForConsensusReadyV2),
)
}
// RegisterExplorerServices register the explorer services
func (node *Node) RegisterExplorerServices() {
_, chanPeer, _ := node.initNodeConfiguration()
// Register networkinfo service.
node.serviceManager.Register(
service.NetworkInfo,
networkinfo.MustNew(
node.host, node.NodeConfig.GetShardGroupID(), chanPeer, nil, node.networkInfoDHTPath()),
)
// Register explorer service.
node.serviceManager.Register(
service.SupportExplorer, explorer.New(&node.SelfPeer, node.stateSync, node.Blockchain()),
)
}
// RegisterService register a service to the node service manager
func (node *Node) RegisterService(st service.Type, s service.Service) {
node.serviceManager.Register(st, s)
}
// StartServices runs registered services.
func (node *Node) StartServices() error {
return node.serviceManager.StartServices()
}
// StopServices runs registered services.
func (node *Node) StopServices() error {
return node.serviceManager.StopServices()
}
func (node *Node) networkInfoDHTPath() string {
return fmt.Sprintf(".dht-%s-%s-c%s",
node.SelfPeer.IP,
node.SelfPeer.Port,
node.chainConfig.ChainID,
)
}