diff options
author | Sonic <sonic@cobinhood.com> | 2018-09-25 17:17:59 +0800 |
---|---|---|
committer | Wei-Ning Huang <w@dexon.org> | 2019-04-09 21:32:48 +0800 |
commit | cccee95ab66e9e4d6e6a3897b2e543221a27e44c (patch) | |
tree | c1c903f0333e7f5fa588efe5e62c0e6269cf1ae3 | |
parent | 41433314bbb6db749db36ad1f479b103cea0539c (diff) | |
download | dexon-cccee95ab66e9e4d6e6a3897b2e543221a27e44c.tar dexon-cccee95ab66e9e4d6e6a3897b2e543221a27e44c.tar.gz dexon-cccee95ab66e9e4d6e6a3897b2e543221a27e44c.tar.bz2 dexon-cccee95ab66e9e4d6e6a3897b2e543221a27e44c.tar.lz dexon-cccee95ab66e9e4d6e6a3897b2e543221a27e44c.tar.xz dexon-cccee95ab66e9e4d6e6a3897b2e543221a27e44c.tar.zst dexon-cccee95ab66e9e4d6e6a3897b2e543221a27e44c.zip |
dex: let peerSet able to manage notary peers
-rw-r--r-- | dex/peer.go | 65 |
1 files changed, 64 insertions, 1 deletions
diff --git a/dex/peer.go b/dex/peer.go index f955b531d..887cc200d 100644 --- a/dex/peer.go +++ b/dex/peer.go @@ -34,6 +34,7 @@ var ( errClosed = errors.New("peer set is closed") errAlreadyRegistered = errors.New("peer is already registered") errNotRegistered = errors.New("peer is not registered") + errInvalidRound = errors.New("invalid round") ) const ( @@ -402,12 +403,18 @@ type peerSet struct { peers map[string]*peer lock sync.RWMutex closed bool + + // TODO(sonic): revist this map after dexon core SDK is finalized. + // use types.ValidatorID? or implement Stringer for types.ValidatorID + notaryPeers map[uint64]map[string]*peer + round uint64 } // newPeerSet creates a new peer set to track the active participants. func newPeerSet() *peerSet { return &peerSet{ - peers: make(map[string]*peer), + peers: make(map[string]*peer), + notaryPeers: make(map[uint64]map[string]*peer), } } @@ -492,6 +499,20 @@ func (ps *peerSet) PeersWithoutTx(hash common.Hash) []*peer { return list } +// PeersWithoutNotaryNodeInfo retrieves a list of peers that do not have a +// given info in their set of known hashes. +func (ps *peerSet) PeersWithoutNotaryNodeInfo(hash common.Hash) []*peer { + ps.lock.RLock() + defer ps.lock.RUnlock() + list := make([]*peer, 0, len(ps.peers)) + for _, p := range ps.peers { + if p.knownInfos.Contains(hash) { + list = append(list, p) + } + } + return list +} + // BestPeer retrieves the known peer with the currently highest total difficulty. func (ps *peerSet) BestPeer() *peer { ps.lock.RLock() @@ -520,3 +541,45 @@ func (ps *peerSet) Close() { } ps.closed = true } + +// AddNotaryPeer adds a peer into notary peer of the given round. +// Caller of this function need to make sure that the peer is acutally in +// notary set. +func (ps *peerSet) AddNotaryPeer(round uint64, p *peer) error { + ps.lock.Lock() + defer ps.lock.Unlock() + + // TODO(sonic): revisit this round check after dexon core SDK is finalized. + if round < ps.round || round > ps.round+2 { + return errInvalidRound + } + + if _, ok := ps.peers[p.id]; !ok { + return errNotRegistered + } + + ps.notaryPeers[round][p.id] = p + return nil +} + +// NotaryPeers return peers in notary set of the given round. +func (ps *peerSet) NotaryPeers(round uint64) []*peer { + ps.lock.RLock() + defer ps.lock.RUnlock() + + list := make([]*peer, 0, len(ps.notaryPeers[round])) + for _, p := range ps.notaryPeers[round] { + if _, ok := ps.peers[p.id]; ok { + list = append(list, p) + } + } + return list +} + +// NextRound moves notary peer set to next round. +func (ps *peerSet) NextRound() { + ps.lock.Lock() + defer ps.lock.Unlock() + delete(ps.notaryPeers, ps.round) + ps.round = ps.round + 1 +} |