forked from TrueCloudLab/neoneo-go
network: implement CMDMempool command
CMDMempool returns hashes of transactions in mempool in chunks.
This commit is contained in:
parent
293e5c3f5d
commit
57bb2f73de
1 changed files with 22 additions and 0 deletions
|
@ -517,6 +517,25 @@ func (s *Server) handleInvCmd(p Peer, inv *payload.Inventory) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// handleMempoolCmd handles getmempool command.
|
||||||
|
func (s *Server) handleMempoolCmd(p Peer) error {
|
||||||
|
txs := s.chain.GetMemPool().GetVerifiedTransactions()
|
||||||
|
hs := make([]util.Uint256, 0, payload.MaxHashesCount)
|
||||||
|
for i := range txs {
|
||||||
|
hs = append(hs, txs[i].Hash())
|
||||||
|
if len(hs) < payload.MaxHashesCount && i != len(txs)-1 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
msg := NewMessage(CMDInv, payload.NewInventory(payload.TXType, hs))
|
||||||
|
err := p.EnqueueP2PMessage(msg)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
hs = hs[:0]
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// handleInvCmd processes the received inventory.
|
// handleInvCmd processes the received inventory.
|
||||||
func (s *Server) handleGetDataCmd(p Peer, inv *payload.Inventory) error {
|
func (s *Server) handleGetDataCmd(p Peer, inv *payload.Inventory) error {
|
||||||
for _, hash := range inv.Hashes {
|
for _, hash := range inv.Hashes {
|
||||||
|
@ -738,6 +757,9 @@ func (s *Server) handleMessage(peer Peer, msg *Message) error {
|
||||||
case CMDInv:
|
case CMDInv:
|
||||||
inventory := msg.Payload.(*payload.Inventory)
|
inventory := msg.Payload.(*payload.Inventory)
|
||||||
return s.handleInvCmd(peer, inventory)
|
return s.handleInvCmd(peer, inventory)
|
||||||
|
case CMDMempool:
|
||||||
|
// no payload
|
||||||
|
return s.handleMempoolCmd(peer)
|
||||||
case CMDBlock:
|
case CMDBlock:
|
||||||
block := msg.Payload.(*block.Block)
|
block := msg.Payload.(*block.Block)
|
||||||
return s.handleBlockCmd(peer, block)
|
return s.handleBlockCmd(peer, block)
|
||||||
|
|
Loading…
Reference in a new issue