Documentation ¶
Index ¶
- Constants
- func BuildIsingPayload(msg IsingMessage, sender *crypto.PubKey) (*message.IsingPayload, error)
- func FilterNoderByIDs(nodes []protocol.Noder, nids []uint64) (ret []protocol.Noder)
- func HasAbilityToVerifyBlock(block *ledger.Block) bool
- func HeightHashToString(height uint32, blockHash Uint256) string
- func StringToHeightHash(str string) (uint32, Uint256)
- type BlockFlooding
- type BlockInfo
- type BuiltinMining
- type ForkCache
- func (fc *ForkCache) AnalyzePingResp() bool
- func (fc *ForkCache) AnalyzeProbeResp() bool
- func (fc *ForkCache) CachePingResp(hash Uint256, height uint32, sender uint64) error
- func (fc *ForkCache) CacheProbeResp(hash Uint256, height uint32, sender uint64) error
- func (fc *ForkCache) GetCurrentHeight() uint32
- func (fc *ForkCache) GetRollBackHeight() uint32
- func (fc *ForkCache) SetRollBackHeight(height uint32)
- type HashSustainer
- type HeightHash
- type IsingMessage
- type IsingMessageType
- type MindChanging
- type Mining
- type NodersPong
- type Ping
- type Pong
- type Proposal
- type ProposerCache
- type ProposerInfo
- type ProposerService
- func (ps *ProposerService) BlockPersistCompleted(v interface{})
- func (ps *ProposerService) BlockSyncingFinished(v interface{})
- func (ps *ProposerService) BroadcastConsensusMsg(msg IsingMessage) error
- func (ps *ProposerService) ChangeProposerRoutine()
- func (ps *ProposerService) ConsensusRoutine(vType voting.VotingContentType, isProposer bool)
- func (ps *ProposerService) CurrentVoting(vType voting.VotingContentType) voting.Voting
- func (ps *ProposerService) GetPersistedNode(nids []uint64) []protocol.Noder
- func (ps *ProposerService) GetReceiverNode(nids []uint64) []protocol.Noder
- func (ps *ProposerService) HandleBlockFloodingMsg(bfMsg *BlockFlooding, sender uint64)
- func (ps *ProposerService) HandleBlockForking()
- func (ps *ProposerService) HandleMindChangingMsg(mindChanging *MindChanging, sender uint64)
- func (ps *ProposerService) HandlePingMsg(msg *Ping, sender uint64)
- func (ps *ProposerService) HandlePongMsg(msg *Pong, sender uint64)
- func (ps *ProposerService) HandleProposalMsg(proposal *Proposal, sender uint64)
- func (ps *ProposerService) HandleRequestMsg(req *Request, sender uint64)
- func (ps *ProposerService) HandleResponseMsg(resp *Response, sender uint64)
- func (ps *ProposerService) Initialize(vType voting.VotingContentType)
- func (ps *ProposerService) IsBlockProposer() bool
- func (ps *ProposerService) PersistCachedBlock(height uint32) error
- func (ps *ProposerService) ProcessRollback()
- func (ps *ProposerService) ProduceNewBlock()
- func (ps *ProposerService) ProposerRoutine()
- func (ps *ProposerService) ReceiveConsensusMsg(v interface{})
- func (ps *ProposerService) SendConsensusMsg(msg IsingMessage, to []protocol.Noder) error
- func (ps *ProposerService) SendNewProposal(votingHeight uint32, vType voting.VotingContentType, isProposer bool) error
- func (ps *ProposerService) SetOrChangeMind(votingType voting.VotingContentType, votingHeight uint32, ...)
- func (ps *ProposerService) Start() error
- func (ps *ProposerService) SyncBlock(isProposer bool)
- func (ps *ProposerService) TimeoutRoutine()
- type Request
- type Response
- type SyncCache
- func (sc *SyncCache) AddBlockToSyncCache(block *ledger.Block, rtime int64) error
- func (sc *SyncCache) AddVoteForBlock(hash Uint256, height uint32, voter uint64) bool
- func (sc *SyncCache) BlockInSyncCache(hash Uint256, height uint32) (*BlockInfo, bool)
- func (sc *SyncCache) CachedBlockHeight() int
- func (sc *SyncCache) ChangeVoteForBlock(hash Uint256, height uint32, voter uint64) error
- func (sc *SyncCache) GetBlock(height uint32, hash *Uint256) (*ledger.Block, error)
- func (sc *SyncCache) RemoveBlockFromCache(height uint32) error
- func (sc *SyncCache) SetConsensusHeight(height uint32)
- func (sc *SyncCache) WaitBlockVotingFinished(height uint32) (*ledger.VBlock, error)
- type TimeLock
Constants ¶
const ( TxnAmountToBePackaged = 20480 WaitingForFloodingFinished = time.Second * 6 WaitingForVotingFinished = time.Second * 16 TimeoutTolerance = time.Second * 2 ForkingDetectTimer = time.Second * 5 WaitingForProbeFinished = time.Second * 3 BlockRollbackStep = 5 )
const (
InitialBlockHeight = 5
)
const (
MinPingRespNum = 3
)
const (
MinSyncVotesNum = 3
)
Variables ¶
This section is empty.
Functions ¶
func BuildIsingPayload ¶
func BuildIsingPayload(msg IsingMessage, sender *crypto.PubKey) (*message.IsingPayload, error)
func FilterNoderByIDs ¶
FilterNoderByIDs filter out a node slice who its ID was specified in 'nids'
func HasAbilityToVerifyBlock ¶
HasAbilityToVerifyBlock checks if local node can verify the block.
func HeightHashToString ¶
HeightHashToString uses block height and block hash to generate a uniq string
func StringToHeightHash ¶
StringToHeightHash recovers block height and block hash from string which generated by HeightHashToString
Types ¶
type BlockFlooding ¶
type BlockFlooding struct {
// contains filtered or unexported fields
}
func NewBlockFlooding ¶
func NewBlockFlooding(block *ledger.Block) *BlockFlooding
func (*BlockFlooding) Deserialize ¶
func (bf *BlockFlooding) Deserialize(r io.Reader) error
type BuiltinMining ¶
type BuiltinMining struct {
// contains filtered or unexported fields
}
func NewBuiltinMining ¶
func NewBuiltinMining(account *vault.Account, txnCollector *transaction.TxnCollector) *BuiltinMining
func (*BuiltinMining) BuildBlock ¶
func (bm *BuiltinMining) BuildBlock(height uint32, chordID []byte, winnerHash Uint256, winnerType ledger.WinnerType) (*ledger.Block, error)
func (*BuiltinMining) CreateCoinbaseTransaction ¶
func (bm *BuiltinMining) CreateCoinbaseTransaction() *transaction.Transaction
type ForkCache ¶
func NewForkCache ¶
func (*ForkCache) AnalyzePingResp ¶
AnalyzePingResp: return true when my hash different with majority of neighbors
func (*ForkCache) AnalyzeProbeResp ¶
func (*ForkCache) CachePingResp ¶
func (*ForkCache) CacheProbeResp ¶
func (*ForkCache) GetCurrentHeight ¶
func (*ForkCache) GetRollBackHeight ¶
func (*ForkCache) SetRollBackHeight ¶
type HashSustainer ¶
type HashSustainer struct {
// contains filtered or unexported fields
}
type HeightHash ¶
type HeightHash map[uint32]*Uint256
type IsingMessage ¶
type IsingMessage interface { serialization.SerializableData }
func RecoverFromIsingPayload ¶
func RecoverFromIsingPayload(payload *message.IsingPayload) (IsingMessage, error)
type IsingMessageType ¶
type IsingMessageType byte
const ( BlockFloodingMsg IsingMessageType = 0x00 BlockRequestMsg IsingMessageType = 0x01 BlockResponseMsg IsingMessageType = 0x02 BlockProposalMsg IsingMessageType = 0x03 MindChangingMsg IsingMessageType = 0x04 PingMsg IsingMessageType = 0x07 PongMsg IsingMessageType = 0x08 )
type MindChanging ¶
type MindChanging struct {
// contains filtered or unexported fields
}
func NewMindChanging ¶
func NewMindChanging(hash *Uint256, height uint32, ctype voting.VotingContentType) *MindChanging
func (*MindChanging) Deserialize ¶
func (mc *MindChanging) Deserialize(r io.Reader) error
type NodersPong ¶
type NodersPong map[uint64]HeightHash
type Proposal ¶
type Proposal struct {
// contains filtered or unexported fields
}
func NewProposal ¶
func NewProposal(hash *Uint256, height uint32, ctype voting.VotingContentType) *Proposal
type ProposerCache ¶
func NewProposerCache ¶
func NewProposerCache() *ProposerCache
func (*ProposerCache) Add ¶
func (pc *ProposerCache) Add(height uint32, votingContent voting.VotingContent)
func (*ProposerCache) Get ¶
func (pc *ProposerCache) Get(height uint32) *ProposerInfo
type ProposerInfo ¶
type ProposerInfo struct {
// contains filtered or unexported fields
}
type ProposerService ¶
func NewProposerService ¶
func NewProposerService(account *vault.Account, node protocol.Noder) *ProposerService
func (*ProposerService) BlockPersistCompleted ¶
func (ps *ProposerService) BlockPersistCompleted(v interface{})
func (*ProposerService) BlockSyncingFinished ¶
func (ps *ProposerService) BlockSyncingFinished(v interface{})
func (*ProposerService) BroadcastConsensusMsg ¶
func (ps *ProposerService) BroadcastConsensusMsg(msg IsingMessage) error
func (*ProposerService) ChangeProposerRoutine ¶
func (ps *ProposerService) ChangeProposerRoutine()
func (*ProposerService) ConsensusRoutine ¶
func (ps *ProposerService) ConsensusRoutine(vType voting.VotingContentType, isProposer bool)
func (*ProposerService) CurrentVoting ¶
func (ps *ProposerService) CurrentVoting(vType voting.VotingContentType) voting.Voting
func (*ProposerService) GetPersistedNode ¶
func (ps *ProposerService) GetPersistedNode(nids []uint64) []protocol.Noder
GetPersistedNode returns PersistFinished nodes from neighbors according to neighbor node ID passed in. If 'nids' passed in is nil then returns all.
func (*ProposerService) GetReceiverNode ¶
func (ps *ProposerService) GetReceiverNode(nids []uint64) []protocol.Noder
GetReceiverNode returns neighbors nodes according to neighbor node ID passed in. If 'nids' passed in is nil then returns all neighbor nodes.
func (*ProposerService) HandleBlockFloodingMsg ¶
func (ps *ProposerService) HandleBlockFloodingMsg(bfMsg *BlockFlooding, sender uint64)
func (*ProposerService) HandleBlockForking ¶
func (ps *ProposerService) HandleBlockForking()
func (*ProposerService) HandleMindChangingMsg ¶
func (ps *ProposerService) HandleMindChangingMsg(mindChanging *MindChanging, sender uint64)
func (*ProposerService) HandlePingMsg ¶
func (ps *ProposerService) HandlePingMsg(msg *Ping, sender uint64)
func (*ProposerService) HandlePongMsg ¶
func (ps *ProposerService) HandlePongMsg(msg *Pong, sender uint64)
func (*ProposerService) HandleProposalMsg ¶
func (ps *ProposerService) HandleProposalMsg(proposal *Proposal, sender uint64)
func (*ProposerService) HandleRequestMsg ¶
func (ps *ProposerService) HandleRequestMsg(req *Request, sender uint64)
func (*ProposerService) HandleResponseMsg ¶
func (ps *ProposerService) HandleResponseMsg(resp *Response, sender uint64)
func (*ProposerService) Initialize ¶
func (ps *ProposerService) Initialize(vType voting.VotingContentType)
func (*ProposerService) IsBlockProposer ¶
func (ps *ProposerService) IsBlockProposer() bool
func (*ProposerService) PersistCachedBlock ¶
func (ps *ProposerService) PersistCachedBlock(height uint32) error
func (*ProposerService) ProcessRollback ¶
func (ps *ProposerService) ProcessRollback()
func (*ProposerService) ProduceNewBlock ¶
func (ps *ProposerService) ProduceNewBlock()
func (*ProposerService) ProposerRoutine ¶
func (ps *ProposerService) ProposerRoutine()
func (*ProposerService) ReceiveConsensusMsg ¶
func (ps *ProposerService) ReceiveConsensusMsg(v interface{})
func (*ProposerService) SendConsensusMsg ¶
func (ps *ProposerService) SendConsensusMsg(msg IsingMessage, to []protocol.Noder) error
func (*ProposerService) SendNewProposal ¶
func (ps *ProposerService) SendNewProposal(votingHeight uint32, vType voting.VotingContentType, isProposer bool) error
func (*ProposerService) SetOrChangeMind ¶
func (ps *ProposerService) SetOrChangeMind(votingType voting.VotingContentType, votingHeight uint32, maybeFinalHash *Uint256)
func (*ProposerService) Start ¶
func (ps *ProposerService) Start() error
func (*ProposerService) SyncBlock ¶
func (ps *ProposerService) SyncBlock(isProposer bool)
func (*ProposerService) TimeoutRoutine ¶
func (ps *ProposerService) TimeoutRoutine()
type Request ¶
type Request struct {
// contains filtered or unexported fields
}
func NewRequest ¶
func NewRequest(hash *Uint256, height uint32, ctype voting.VotingContentType) *Request
type Response ¶
type Response struct {
// contains filtered or unexported fields
}
func NewResponse ¶
func NewResponse(hash *Uint256, height uint32, ctype voting.VotingContentType, content voting.VotingContent) *Response
type SyncCache ¶
SyncCache cached blocks sent by block proposer when wait for block syncing finished.
func NewSyncBlockCache ¶
func NewSyncBlockCache() *SyncCache
func (*SyncCache) AddBlockToSyncCache ¶
AddBlockToSyncCache caches received block and the voter count when receive block. Returns nil if block already existed.
func (*SyncCache) AddVoteForBlock ¶
AddVoteForBlock adds vote for block when receive valid proposal.
func (*SyncCache) BlockInSyncCache ¶
BlockInSyncCache returns block info and true is the block exists in cache.
func (*SyncCache) CachedBlockHeight ¶
CachedBlockHeight returns cached block height.
func (*SyncCache) ChangeVoteForBlock ¶
ChangeVoteForBlock change vote for block when receive valid mind changing.
func (*SyncCache) RemoveBlockFromCache ¶
RemoveBlockFromCache removes cached block which height is minimum.
func (*SyncCache) SetConsensusHeight ¶
type TimeLock ¶
func NewTimeLock ¶
func NewTimeLock() *TimeLock