提交 d83374fd 作者: Steven Allen

fix: handle peerstore failure case in constructor

License: MIT
Signed-off-by: 's avatarSteven Allen <steven@stebalien.com>
上级 d2611d42
...@@ -84,15 +84,19 @@ var DHTOption RoutingOption = constructDHTRouting ...@@ -84,15 +84,19 @@ var DHTOption RoutingOption = constructDHTRouting
var DHTClientOption RoutingOption = constructClientDHTRouting var DHTClientOption RoutingOption = constructClientDHTRouting
var NilRouterOption RoutingOption = nilrouting.ConstructNilRouting var NilRouterOption RoutingOption = nilrouting.ConstructNilRouting
func Peerstore(id peer.ID, sk crypto.PrivKey) peerstore.Peerstore { func Peerstore(id peer.ID, sk crypto.PrivKey) (peerstore.Peerstore, error) {
ps := pstoremem.NewPeerstore() ps := pstoremem.NewPeerstore()
if sk != nil { if sk != nil {
ps.AddPrivKey(id, sk) if err := ps.AddPubKey(id, sk.GetPublic()); err != nil {
ps.AddPubKey(id, sk.GetPublic()) return nil, err
}
if err := ps.AddPrivKey(id, sk); err != nil {
return nil, err
}
} }
return ps return ps, nil
} }
func P2PAddrFilters(cfg *config.Config) (opts Libp2pOpts, err error) { func P2PAddrFilters(cfg *config.Config) (opts Libp2pOpts, err error) {
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论