reflector.go/dht/store.go
2018-03-07 19:49:33 -05:00

42 lines
704 B
Go

package dht
import "sync"
type peer struct {
nodeID bitmap
}
type peerStore struct {
data map[string][]peer
lock sync.RWMutex
}
func newPeerStore() *peerStore {
return &peerStore{
data: map[string][]peer{},
}
}
func (s *peerStore) Insert(key string, nodeId bitmap) {
s.lock.Lock()
defer s.lock.Unlock()
newPeer := peer{nodeID: nodeId}
_, ok := s.data[key]
if !ok {
s.data[key] = []peer{newPeer}
} else {
s.data[key] = append(s.data[key], newPeer)
}
}
func (s *peerStore) Get(key string) []bitmap {
s.lock.RLock()
defer s.lock.RUnlock()
nodes := []bitmap{}
if peers, ok := s.data[key]; ok {
for _, p := range peers {
nodes = append(nodes, p.nodeID)
}
}
return nodes
}