Documentation ¶
Index ¶
- type Config
- type PeerNotifier
- type SyncManager
- func (sm *SyncManager) DonePeer(peer *peerpkg.Peer)
- func (sm *SyncManager) GetCurrent() bool
- func (sm *SyncManager) IsCurrent() bool
- func (sm *SyncManager) IsCurrentAndCheckAccepted() bool
- func (sm *SyncManager) ListPeerStates() []string
- func (sm *SyncManager) NewPeer(peer *peerpkg.Peer)
- func (sm *SyncManager) Pause() chan<- struct{}
- func (sm *SyncManager) ProcessBlock(template *mining.BlockTemplate, flags common.BehaviorFlags) (bool, error)
- func (sm *SyncManager) QueueBlock(block *asiutil.Block, peer *peerpkg.Peer, done chan struct{})
- func (sm *SyncManager) QueueHeaders(headers *protos.MsgHeaders, peer *peerpkg.Peer)
- func (sm *SyncManager) QueueInv(inv *protos.MsgInv, peer *peerpkg.Peer)
- func (sm *SyncManager) QueueSig(sig *asiutil.BlockSign, peer *peerpkg.Peer, done chan struct{})
- func (sm *SyncManager) QueueTx(tx *asiutil.Tx, peer *peerpkg.Peer, done chan struct{})
- func (sm *SyncManager) Start()
- func (sm *SyncManager) Stop() error
- func (sm *SyncManager) SyncPeerID() int32
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Config ¶
type Config struct { PeerNotifier PeerNotifier Chain *blockchain.BlockChain TxMemPool *mempool.TxPool SigMemPool *mempool.SigPool ChainParams *chaincfg.Params DisableCheckpoints bool MaxPeers int Account *crypto.Account BroadcastMessage func(msg protos.Message, exclPeers ...interface{}) }
Config is a configuration struct used to initialize a new SyncManager.
type PeerNotifier ¶
type PeerNotifier interface { AnnounceNewTransactions(newTxs []*mining.TxDesc) UpdatePeerHeights(latestBlkHash *common.Hash, latestHeight int32, updateSource *peer.Peer) RelayInventory(invVect *protos.InvVect, data interface{}) TransactionConfirmed(tx *asiutil.Tx) AnnounceNewSignature(sig *asiutil.BlockSign) }
PeerNotifier exposes methods to notify peers of status changes to transactions, blocks, etc. Currently server (in the main package) implements this interface.
type SyncManager ¶
type SyncManager struct { BroadcastMessage func(msg protos.Message, exclPeers ...interface{}) // contains filtered or unexported fields }
SyncManager is used to communicate block related messages with peers. The SyncManager is started as by executing Start() in a goroutine. Once started, it selects peers to sync from and starts the initial block download. Once the chain is in sync, the SyncManager handles incoming block and header notifications and relays announcements of new blocks to peers.
func New ¶
func New(config *Config) (*SyncManager, error)
New constructs a new SyncManager. Use Start to begin processing asynchronous block, tx, and inv updates.
func (*SyncManager) DonePeer ¶
func (sm *SyncManager) DonePeer(peer *peerpkg.Peer)
DonePeer informs the blockmanager that a peer has disconnected.
func (*SyncManager) GetCurrent ¶
func (sm *SyncManager) GetCurrent() bool
func (*SyncManager) IsCurrent ¶
func (sm *SyncManager) IsCurrent() bool
IsCurrent returns whether or not the sync manager believes it is synced with the connected peers.
func (*SyncManager) IsCurrentAndCheckAccepted ¶
func (sm *SyncManager) IsCurrentAndCheckAccepted() bool
IsCurrent returns whether or not the sync manager believes it is synced with the connected peers or it not accepted blocks.
func (*SyncManager) ListPeerStates ¶
func (sm *SyncManager) ListPeerStates() []string
func (*SyncManager) NewPeer ¶
func (sm *SyncManager) NewPeer(peer *peerpkg.Peer)
NewPeer informs the sync manager of a newly active peer.
func (*SyncManager) Pause ¶
func (sm *SyncManager) Pause() chan<- struct{}
Pause pauses the sync manager until the returned channel is closed.
Note that while paused, all peer and block processing is halted. The message sender should avoid pausing the sync manager for long durations.
func (*SyncManager) ProcessBlock ¶
func (sm *SyncManager) ProcessBlock(template *mining.BlockTemplate, flags common.BehaviorFlags) (bool, error)
ProcessBlock makes use of ProcessBlock on an internal instance of a block chain.
func (*SyncManager) QueueBlock ¶
func (sm *SyncManager) QueueBlock(block *asiutil.Block, peer *peerpkg.Peer, done chan struct{})
QueueBlock adds the passed block message and peer to the block handling queue. Responds to the done channel argument after the block message is processed.
func (*SyncManager) QueueHeaders ¶
func (sm *SyncManager) QueueHeaders(headers *protos.MsgHeaders, peer *peerpkg.Peer)
QueueHeaders adds the passed headers message and peer to the block handling queue.
func (*SyncManager) QueueInv ¶
func (sm *SyncManager) QueueInv(inv *protos.MsgInv, peer *peerpkg.Peer)
QueueInv adds the passed inv message and peer to the block handling queue.
func (*SyncManager) QueueSig ¶
func (sm *SyncManager) QueueSig(sig *asiutil.BlockSign, peer *peerpkg.Peer, done chan struct{})
func (*SyncManager) QueueTx ¶
func (sm *SyncManager) QueueTx(tx *asiutil.Tx, peer *peerpkg.Peer, done chan struct{})
QueueTx adds the passed transaction message and peer to the block handling queue. Responds to the done channel argument after the tx message is processed.
func (*SyncManager) Start ¶
func (sm *SyncManager) Start()
Start begins the core block handler which processes block and inv messages.
func (*SyncManager) Stop ¶
func (sm *SyncManager) Stop() error
Stop gracefully shuts down the sync manager by stopping all asynchronous handlers and waiting for them to finish.
func (*SyncManager) SyncPeerID ¶
func (sm *SyncManager) SyncPeerID() int32
SyncPeerID returns the ID of the current sync peer, or 0 if there is none.