|
|
@ -14,6 +14,7 @@ import ( |
|
|
|
bls_cosi "github.com/harmony-one/harmony/crypto/bls" |
|
|
|
bls_cosi "github.com/harmony-one/harmony/crypto/bls" |
|
|
|
"github.com/harmony-one/harmony/internal/profiler" |
|
|
|
"github.com/harmony-one/harmony/internal/profiler" |
|
|
|
"github.com/harmony-one/harmony/internal/utils" |
|
|
|
"github.com/harmony-one/harmony/internal/utils" |
|
|
|
|
|
|
|
"github.com/harmony-one/harmony/p2p" |
|
|
|
"github.com/harmony-one/harmony/p2p/host" |
|
|
|
"github.com/harmony-one/harmony/p2p/host" |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
@ -107,8 +108,12 @@ func (consensus *Consensus) startConsensus(newBlock *types.Block) { |
|
|
|
// Leader sign the block hash itself
|
|
|
|
// Leader sign the block hash itself
|
|
|
|
consensus.prepareSigs[consensus.nodeID] = consensus.priKey.SignHash(consensus.blockHash[:]) |
|
|
|
consensus.prepareSigs[consensus.nodeID] = consensus.priKey.SignHash(consensus.blockHash[:]) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if utils.UseLibP2P { |
|
|
|
|
|
|
|
consensus.host.SendMessageToGroups([]p2p.GroupID{p2p.GroupIDBeacon}, msgToSend) |
|
|
|
|
|
|
|
} else { |
|
|
|
host.BroadcastMessageFromLeader(consensus.host, consensus.GetValidatorPeers(), msgToSend, consensus.OfflinePeers) |
|
|
|
host.BroadcastMessageFromLeader(consensus.host, consensus.GetValidatorPeers(), msgToSend, consensus.OfflinePeers) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// processPrepareMessage processes the prepare message sent from validators
|
|
|
|
// processPrepareMessage processes the prepare message sent from validators
|
|
|
|
func (consensus *Consensus) processPrepareMessage(message consensus_proto.Message) { |
|
|
|
func (consensus *Consensus) processPrepareMessage(message consensus_proto.Message) { |
|
|
@ -164,7 +169,12 @@ func (consensus *Consensus) processPrepareMessage(message consensus_proto.Messag |
|
|
|
// Construct and broadcast prepared message
|
|
|
|
// Construct and broadcast prepared message
|
|
|
|
msgToSend, aggSig := consensus.constructPreparedMessage() |
|
|
|
msgToSend, aggSig := consensus.constructPreparedMessage() |
|
|
|
consensus.aggregatedPrepareSig = aggSig |
|
|
|
consensus.aggregatedPrepareSig = aggSig |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if utils.UseLibP2P { |
|
|
|
|
|
|
|
consensus.host.SendMessageToGroups([]p2p.GroupID{p2p.GroupIDBeacon}, msgToSend) |
|
|
|
|
|
|
|
} else { |
|
|
|
host.BroadcastMessageFromLeader(consensus.host, consensus.GetValidatorPeers(), msgToSend, consensus.OfflinePeers) |
|
|
|
host.BroadcastMessageFromLeader(consensus.host, consensus.GetValidatorPeers(), msgToSend, consensus.OfflinePeers) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Set state to targetState
|
|
|
|
// Set state to targetState
|
|
|
|
consensus.state = targetState |
|
|
|
consensus.state = targetState |
|
|
@ -230,7 +240,12 @@ func (consensus *Consensus) processCommitMessage(message consensus_proto.Message |
|
|
|
// Construct and broadcast committed message
|
|
|
|
// Construct and broadcast committed message
|
|
|
|
msgToSend, aggSig := consensus.constructCommittedMessage() |
|
|
|
msgToSend, aggSig := consensus.constructCommittedMessage() |
|
|
|
consensus.aggregatedCommitSig = aggSig |
|
|
|
consensus.aggregatedCommitSig = aggSig |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if utils.UseLibP2P { |
|
|
|
|
|
|
|
consensus.host.SendMessageToGroups([]p2p.GroupID{p2p.GroupIDBeacon}, msgToSend) |
|
|
|
|
|
|
|
} else { |
|
|
|
host.BroadcastMessageFromLeader(consensus.host, consensus.GetValidatorPeers(), msgToSend, consensus.OfflinePeers) |
|
|
|
host.BroadcastMessageFromLeader(consensus.host, consensus.GetValidatorPeers(), msgToSend, consensus.OfflinePeers) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var blockObj types.Block |
|
|
|
var blockObj types.Block |
|
|
|
err := rlp.DecodeBytes(consensus.block, &blockObj) |
|
|
|
err := rlp.DecodeBytes(consensus.block, &blockObj) |
|
|
|