kaspad/protocol/protocol.go
Svarog 8e624e057e
[NOD-1134] Integrate Protocol into main (#788)
* [NOD-1134] Integrate Protocol into main

* [NOD-1134] Fix typo

* [NOD-1134] Added comments

* [NOD-1134] A series of renames to protocol

* [NOD-1134] Fix comment

* [NOD-1134] protocol.ProtocolManager -> Manager

* [NOD-1134] Update comment

* [NOD-1134] protocol.New() -> protocol.NewManager()
2020-07-08 11:52:53 +03:00

59 lines
1.4 KiB
Go

package protocol
import (
"github.com/kaspanet/kaspad/blockdag"
"github.com/kaspanet/kaspad/netadapter"
"github.com/kaspanet/kaspad/wire"
)
// Manager manages the p2p protocol
type Manager struct {
netAdapter *netadapter.NetAdapter
}
// NewManager creates a new instance of the p2p protocol manager
func NewManager(listeningAddrs []string, dag *blockdag.BlockDAG) (*Manager, error) {
netAdapter, err := netadapter.NewNetAdapter(listeningAddrs)
if err != nil {
return nil, err
}
routerInitializer := newRouterInitializer(netAdapter, dag)
netAdapter.SetRouterInitializer(routerInitializer)
manager := Manager{
netAdapter: netAdapter,
}
return &manager, nil
}
// Start starts the p2p protocol
func (p *Manager) Start() error {
return p.netAdapter.Start()
}
// Stop stops the p2p protocol
func (p *Manager) Stop() error {
return p.netAdapter.Stop()
}
func newRouterInitializer(netAdapter *netadapter.NetAdapter, dag *blockdag.BlockDAG) netadapter.RouterInitializer {
return func(peer *netadapter.Peer) (*netadapter.Router, error) {
router := netadapter.Router{}
err := router.AddRoute([]string{wire.CmdTx}, startDummy(netAdapter, peer, dag))
if err != nil {
return nil, err
}
return &router, nil
}
}
func startDummy(netAdapter *netadapter.NetAdapter, peer *netadapter.Peer, dag *blockdag.BlockDAG) chan<- wire.Message {
ch := make(chan wire.Message)
spawn(func() {
for range ch {
}
})
return ch
}