2018-09-05 01:07:44 +08:00
|
|
|
package pstoremem
|
2018-08-29 22:12:41 +08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"sync"
|
|
|
|
|
2018-09-02 19:10:55 +08:00
|
|
|
ic "github.com/libp2p/go-libp2p-crypto"
|
2018-09-08 01:46:23 +08:00
|
|
|
peer "github.com/libp2p/go-libp2p-peer"
|
2018-08-30 23:24:09 +08:00
|
|
|
|
|
|
|
pstore "github.com/libp2p/go-libp2p-peerstore"
|
2018-08-29 22:12:41 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type memoryKeyBook struct {
|
|
|
|
sync.RWMutex // same lock. wont happen a ton.
|
|
|
|
pks map[peer.ID]ic.PubKey
|
|
|
|
sks map[peer.ID]ic.PrivKey
|
|
|
|
}
|
|
|
|
|
2018-08-30 21:13:27 +08:00
|
|
|
var _ pstore.KeyBook = (*memoryKeyBook)(nil)
|
2018-08-29 22:12:41 +08:00
|
|
|
|
|
|
|
// noop new, but in the future we may want to do some init work.
|
2018-08-30 23:43:40 +08:00
|
|
|
func NewKeyBook() pstore.KeyBook {
|
2018-08-29 22:12:41 +08:00
|
|
|
return &memoryKeyBook{
|
|
|
|
pks: map[peer.ID]ic.PubKey{},
|
|
|
|
sks: map[peer.ID]ic.PrivKey{},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-31 19:59:46 +08:00
|
|
|
func (mkb *memoryKeyBook) PeersWithKeys() peer.IDSlice {
|
2018-08-29 22:12:41 +08:00
|
|
|
mkb.RLock()
|
2018-08-31 19:59:46 +08:00
|
|
|
ps := make(peer.IDSlice, 0, len(mkb.pks)+len(mkb.sks))
|
2018-08-29 22:12:41 +08:00
|
|
|
for p := range mkb.pks {
|
|
|
|
ps = append(ps, p)
|
|
|
|
}
|
|
|
|
for p := range mkb.sks {
|
|
|
|
if _, found := mkb.pks[p]; !found {
|
|
|
|
ps = append(ps, p)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
mkb.RUnlock()
|
|
|
|
return ps
|
|
|
|
}
|
|
|
|
|
|
|
|
func (mkb *memoryKeyBook) PubKey(p peer.ID) ic.PubKey {
|
|
|
|
mkb.RLock()
|
|
|
|
pk := mkb.pks[p]
|
|
|
|
mkb.RUnlock()
|
|
|
|
if pk != nil {
|
|
|
|
return pk
|
|
|
|
}
|
|
|
|
pk, err := p.ExtractPublicKey()
|
2018-10-16 18:25:41 +08:00
|
|
|
if err == nil {
|
2018-08-29 22:12:41 +08:00
|
|
|
mkb.Lock()
|
|
|
|
mkb.pks[p] = pk
|
|
|
|
mkb.Unlock()
|
|
|
|
}
|
|
|
|
return pk
|
|
|
|
}
|
|
|
|
|
|
|
|
func (mkb *memoryKeyBook) AddPubKey(p peer.ID, pk ic.PubKey) error {
|
|
|
|
// check it's correct first
|
|
|
|
if !p.MatchesPublicKey(pk) {
|
|
|
|
return errors.New("ID does not match PublicKey")
|
|
|
|
}
|
|
|
|
|
|
|
|
mkb.Lock()
|
|
|
|
mkb.pks[p] = pk
|
|
|
|
mkb.Unlock()
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (mkb *memoryKeyBook) PrivKey(p peer.ID) ic.PrivKey {
|
|
|
|
mkb.RLock()
|
|
|
|
sk := mkb.sks[p]
|
|
|
|
mkb.RUnlock()
|
|
|
|
return sk
|
|
|
|
}
|
|
|
|
|
|
|
|
func (mkb *memoryKeyBook) AddPrivKey(p peer.ID, sk ic.PrivKey) error {
|
|
|
|
if sk == nil {
|
|
|
|
return errors.New("sk is nil (PrivKey)")
|
|
|
|
}
|
|
|
|
|
|
|
|
// check it's correct first
|
|
|
|
if !p.MatchesPrivateKey(sk) {
|
|
|
|
return errors.New("ID does not match PrivateKey")
|
|
|
|
}
|
|
|
|
|
|
|
|
mkb.Lock()
|
|
|
|
mkb.sks[p] = sk
|
|
|
|
mkb.Unlock()
|
|
|
|
return nil
|
|
|
|
}
|