go_study/fabric-main/gossip/util/msgs.go

73 lines
1.6 KiB
Go

/*
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
}