diff options
author | Jimmy Hu <jimmy.hu@dexon.org> | 2018-10-09 10:04:28 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-10-09 10:04:28 +0800 |
commit | 9267d50de25ddf0f280eee797e2030ea989294e4 (patch) | |
tree | e6345f8b2f04d360a12d7272bf17b137a13eec93 /core/test/governance.go | |
parent | 8944f1ea16c531cbccc3f01d91854e942e040871 (diff) | |
download | dexon-consensus-9267d50de25ddf0f280eee797e2030ea989294e4.tar dexon-consensus-9267d50de25ddf0f280eee797e2030ea989294e4.tar.gz dexon-consensus-9267d50de25ddf0f280eee797e2030ea989294e4.tar.bz2 dexon-consensus-9267d50de25ddf0f280eee797e2030ea989294e4.tar.lz dexon-consensus-9267d50de25ddf0f280eee797e2030ea989294e4.tar.xz dexon-consensus-9267d50de25ddf0f280eee797e2030ea989294e4.tar.zst dexon-consensus-9267d50de25ddf0f280eee797e2030ea989294e4.zip |
core: Add DKG final message. (#181)
Diffstat (limited to 'core/test/governance.go')
-rw-r--r-- | core/test/governance.go | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/core/test/governance.go b/core/test/governance.go index 24fd2de..de3f34b 100644 --- a/core/test/governance.go +++ b/core/test/governance.go @@ -44,6 +44,7 @@ type Governance struct { tsig map[uint64]crypto.Signature DKGComplaint map[uint64][]*types.DKGComplaint DKGMasterPublicKey map[uint64][]*types.DKGMasterPublicKey + DKGFinal map[uint64]map[types.NodeID]struct{} RoundInterval time.Duration MinBlockInterval time.Duration MaxBlockInterval time.Duration @@ -62,6 +63,7 @@ func NewGovernance(nodeCount int, lambda time.Duration) ( tsig: make(map[uint64]crypto.Signature), DKGComplaint: make(map[uint64][]*types.DKGComplaint), DKGMasterPublicKey: make(map[uint64][]*types.DKGMasterPublicKey), + DKGFinal: make(map[uint64]map[types.NodeID]struct{}), RoundInterval: 365 * 86400 * time.Second, MinBlockInterval: 1 * time.Millisecond, MaxBlockInterval: lambda * 8, @@ -135,8 +137,14 @@ func (g *Governance) PrivateKeys() (keys []crypto.PrivateKey) { // AddDKGComplaint add a DKGComplaint. func (g *Governance) AddDKGComplaint(complaint *types.DKGComplaint) { + if g.IsDKGFinal(complaint.Round) { + return + } g.lock.Lock() defer g.lock.Unlock() + if _, exist := g.DKGFinal[complaint.Round][complaint.ProposerID]; exist { + return + } for _, comp := range g.DKGComplaint[complaint.Round] { if comp == complaint { return @@ -184,3 +192,20 @@ func (g *Governance) DKGMasterPublicKeys( } return mpks } + +// AddDKGFinalize adds a DKG finalize message. +func (g *Governance) AddDKGFinalize(final *types.DKGFinalize) { + g.lock.Lock() + defer g.lock.Unlock() + if _, exist := g.DKGFinal[final.Round]; !exist { + g.DKGFinal[final.Round] = make(map[types.NodeID]struct{}) + } + g.DKGFinal[final.Round][final.ProposerID] = struct{}{} +} + +// IsDKGFinal checks if DKG is final. +func (g *Governance) IsDKGFinal(round uint64) bool { + g.lock.RLock() + defer g.lock.RUnlock() + return len(g.DKGFinal[round]) > int(g.Configuration(round).DKGSetSize)/3*2 +} |