forked from hyperledger/fabric
-
Notifications
You must be signed in to change notification settings - Fork 0
/
msgs.go
72 lines (61 loc) · 1.63 KB
/
msgs.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/*
Copyright IBM Corp. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package util
import (
"sync"
"github.com/hyperledger/fabric/gossip/common"
"github.com/hyperledger/fabric/gossip/protoext"
)
// MembershipStore struct which encapsulates
// membership message store abstraction
type MembershipStore struct {
m map[string]*protoext.SignedGossipMessage
sync.RWMutex
}
// NewMembershipStore creates new membership store instance
func NewMembershipStore() *MembershipStore {
return &MembershipStore{m: make(map[string]*protoext.SignedGossipMessage)}
}
// MsgByID returns a message stored by a certain ID, or nil
// if such an ID isn't found
func (m *MembershipStore) MsgByID(pkiID common.PKIidType) *protoext.SignedGossipMessage {
m.RLock()
defer m.RUnlock()
if msg, exists := m.m[string(pkiID)]; exists {
return msg
}
return nil
}
// Size of the membership store
func (m *MembershipStore) Size() int {
m.RLock()
defer m.RUnlock()
return len(m.m)
}
// Put associates msg with the given pkiID
func (m *MembershipStore) Put(pkiID common.PKIidType, msg *protoext.SignedGossipMessage) {
m.Lock()
defer m.Unlock()
m.m[string(pkiID)] = msg
}
// Remove removes a message with a given pkiID
func (m *MembershipStore) Remove(pkiID common.PKIidType) {
m.Lock()
defer m.Unlock()
delete(m.m, string(pkiID))
}
// ToSlice returns a slice backed by the elements
// of the MembershipStore
func (m *MembershipStore) ToSlice() []*protoext.SignedGossipMessage {
m.RLock()
defer m.RUnlock()
members := make([]*protoext.SignedGossipMessage, len(m.m))
i := 0
for _, member := range m.m {
members[i] = member
i++
}
return members
}