提交 01451c21 作者: Jeromy 提交者: Juan Batiz-Benet

fix routing resolver

上级 1cf7a182
...@@ -33,34 +33,40 @@ func (p *ipnsPublisher) Publish(k ci.PrivKey, value string) error { ...@@ -33,34 +33,40 @@ func (p *ipnsPublisher) Publish(k ci.PrivKey, value string) error {
// validate `value` is a ref (multihash) // validate `value` is a ref (multihash)
_, err := mh.FromB58String(value) _, err := mh.FromB58String(value)
if err != nil { if err != nil {
log.Errorf("hash cast failed: %s", value)
return fmt.Errorf("publish value must be str multihash. %v", err) return fmt.Errorf("publish value must be str multihash. %v", err)
} }
ctx := context.TODO() ctx := context.TODO()
data, err := createRoutingEntryData(k, value) data, err := createRoutingEntryData(k, value)
if err != nil { if err != nil {
log.Error("entry creation failed.")
return err return err
} }
pubkey := k.GetPublic() pubkey := k.GetPublic()
pkbytes, err := pubkey.Bytes() pkbytes, err := pubkey.Bytes()
if err != nil { if err != nil {
return nil log.Error("pubkey getbytes failed.")
return err
} }
nameb := u.Hash(pkbytes) nameb := u.Hash(pkbytes)
namekey := u.Key(nameb).Pretty() namekey := u.Key("/pk/" + string(nameb))
ipnskey := []byte("/ipns/" + namekey)
log.Debugf("Storing pubkey at: %s", namekey)
// Store associated public key // Store associated public key
timectx, _ := context.WithDeadline(ctx, time.Now().Add(time.Second*4)) timectx, _ := context.WithDeadline(ctx, time.Now().Add(time.Second*4))
err = p.routing.PutValue(timectx, u.Key("/pk/"+string(nameb)), pkbytes) err = p.routing.PutValue(timectx, namekey, pkbytes)
if err != nil { if err != nil {
return err return err
} }
ipnskey := u.Key("/ipns/" + string(nameb))
log.Debugf("Storing ipns entry at: %s", ipnskey)
// Store ipns entry at "/ipns/"+b58(h(pubkey)) // Store ipns entry at "/ipns/"+b58(h(pubkey))
timectx, _ = context.WithDeadline(ctx, time.Now().Add(time.Second*4)) timectx, _ = context.WithDeadline(ctx, time.Now().Add(time.Second*4))
err = p.routing.PutValue(timectx, u.Key(ipnskey), data) err = p.routing.PutValue(timectx, ipnskey, data)
if err != nil { if err != nil {
return err return err
} }
......
...@@ -46,7 +46,7 @@ func (r *routingResolver) Resolve(name string) (string, error) { ...@@ -46,7 +46,7 @@ func (r *routingResolver) Resolve(name string) (string, error) {
// use the routing system to get the name. // use the routing system to get the name.
// /ipns/<name> // /ipns/<name>
h := []byte("/ipns/" + name) h := []byte("/ipns/" + string(hash))
ipnsKey := u.Key(h) ipnsKey := u.Key(h)
val, err := r.routing.GetValue(ctx, ipnsKey) val, err := r.routing.GetValue(ctx, ipnsKey)
......
...@@ -355,10 +355,12 @@ func (dht *IpfsDHT) getFromPeerList(ctx context.Context, key u.Key, ...@@ -355,10 +355,12 @@ func (dht *IpfsDHT) getFromPeerList(ctx context.Context, key u.Key,
func (dht *IpfsDHT) getLocal(key u.Key) ([]byte, error) { func (dht *IpfsDHT) getLocal(key u.Key) ([]byte, error) {
dht.dslock.Lock() dht.dslock.Lock()
defer dht.dslock.Unlock() defer dht.dslock.Unlock()
log.Debug("getLocal %s", key)
v, err := dht.datastore.Get(key.DsKey()) v, err := dht.datastore.Get(key.DsKey())
if err != nil { if err != nil {
return nil, err return nil, err
} }
log.Debug("found in db")
byt, ok := v.([]byte) byt, ok := v.([]byte)
if !ok { if !ok {
...@@ -374,6 +376,7 @@ func (dht *IpfsDHT) getLocal(key u.Key) ([]byte, error) { ...@@ -374,6 +376,7 @@ func (dht *IpfsDHT) getLocal(key u.Key) ([]byte, error) {
if u.Debug { if u.Debug {
err = dht.verifyRecord(rec) err = dht.verifyRecord(rec)
if err != nil { if err != nil {
log.Errorf("local record verify failed: %s", err)
return nil, err return nil, err
} }
} }
......
...@@ -4,8 +4,11 @@ import ( ...@@ -4,8 +4,11 @@ import (
"bytes" "bytes"
"errors" "errors"
"strings" "strings"
"time"
"code.google.com/p/go.net/context"
"code.google.com/p/goprotobuf/proto" "code.google.com/p/goprotobuf/proto"
ci "github.com/jbenet/go-ipfs/crypto"
"github.com/jbenet/go-ipfs/peer" "github.com/jbenet/go-ipfs/peer"
pb "github.com/jbenet/go-ipfs/routing/dht/pb" pb "github.com/jbenet/go-ipfs/routing/dht/pb"
u "github.com/jbenet/go-ipfs/util" u "github.com/jbenet/go-ipfs/util"
...@@ -32,6 +35,29 @@ func (dht *IpfsDHT) makePutRecord(key u.Key, value []byte) (*pb.Record, error) { ...@@ -32,6 +35,29 @@ func (dht *IpfsDHT) makePutRecord(key u.Key, value []byte) (*pb.Record, error) {
return record, nil return record, nil
} }
func (dht *IpfsDHT) getPublicKey(pid peer.ID) (ci.PubKey, error) {
log.Debug("getPublicKey for: %s", pid)
p, err := dht.peerstore.Get(pid)
if err == nil {
return p.PubKey(), nil
}
log.Debug("not in peerstore, searching dht.")
ctxT, _ := context.WithTimeout(dht.ContextCloser.Context(), time.Second*5)
val, err := dht.GetValue(ctxT, u.Key("/pk/"+string(pid)))
if err != nil {
log.Warning("Failed to find requested public key.")
return nil, err
}
pubkey, err := ci.UnmarshalPublicKey(val)
if err != nil {
log.Errorf("Failed to unmarshal public key: %s", err)
return nil, err
}
return pubkey, nil
}
func (dht *IpfsDHT) verifyRecord(r *pb.Record) error { func (dht *IpfsDHT) verifyRecord(r *pb.Record) error {
// First, validate the signature // First, validate the signature
p, err := dht.peerstore.Get(peer.ID(r.GetAuthor())) p, err := dht.peerstore.Get(peer.ID(r.GetAuthor()))
...@@ -76,6 +102,14 @@ func ValidateIpnsRecord(k u.Key, val []byte) error { ...@@ -76,6 +102,14 @@ func ValidateIpnsRecord(k u.Key, val []byte) error {
} }
func ValidatePublicKeyRecord(k u.Key, val []byte) error { func ValidatePublicKeyRecord(k u.Key, val []byte) error {
// TODO: keyparts := bytes.Split([]byte(k), []byte("/"))
if len(keyparts) < 3 {
return errors.New("invalid key")
}
pkh := u.Hash(val)
if !bytes.Equal(keyparts[2], pkh) {
return errors.New("public key does not match storage key")
}
return nil return nil
} }
...@@ -12,6 +12,8 @@ import ( ...@@ -12,6 +12,8 @@ import (
u "github.com/jbenet/go-ipfs/util" u "github.com/jbenet/go-ipfs/util"
) )
var log = u.Logger("mockrouter")
var _ routing.IpfsRouting = &MockRouter{} var _ routing.IpfsRouting = &MockRouter{}
type MockRouter struct { type MockRouter struct {
...@@ -33,10 +35,12 @@ func (mr *MockRouter) SetRoutingServer(rs RoutingServer) { ...@@ -33,10 +35,12 @@ func (mr *MockRouter) SetRoutingServer(rs RoutingServer) {
} }
func (mr *MockRouter) PutValue(ctx context.Context, key u.Key, val []byte) error { func (mr *MockRouter) PutValue(ctx context.Context, key u.Key, val []byte) error {
log.Debugf("PutValue: %s", key)
return mr.datastore.Put(key.DsKey(), val) return mr.datastore.Put(key.DsKey(), val)
} }
func (mr *MockRouter) GetValue(ctx context.Context, key u.Key) ([]byte, error) { func (mr *MockRouter) GetValue(ctx context.Context, key u.Key) ([]byte, error) {
log.Debugf("GetValue: %s", key)
v, err := mr.datastore.Get(key.DsKey()) v, err := mr.datastore.Get(key.DsKey())
if err != nil { if err != nil {
return nil, err return nil, err
...@@ -55,6 +59,7 @@ func (mr *MockRouter) FindProviders(ctx context.Context, key u.Key) ([]peer.Peer ...@@ -55,6 +59,7 @@ func (mr *MockRouter) FindProviders(ctx context.Context, key u.Key) ([]peer.Peer
} }
func (mr *MockRouter) FindPeer(ctx context.Context, pid peer.ID) (peer.Peer, error) { func (mr *MockRouter) FindPeer(ctx context.Context, pid peer.ID) (peer.Peer, error) {
log.Debug("FindPeer: %s", pid)
return nil, nil return nil, nil
} }
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论