centralized_client.go 3.49 KB
Newer Older
Brian Tiger Chow's avatar
Brian Tiger Chow committed
1 2 3
package mockrouting

import (
4
	"context"
Brian Tiger Chow's avatar
Brian Tiger Chow committed
5
	"errors"
6
	"time"
Brian Tiger Chow's avatar
Brian Tiger Chow committed
7

Steven Allen's avatar
Steven Allen committed
8 9
	u "gx/ipfs/QmNiJuT8Ja3hMVpBHXv3Q6dwmperaQ6JjLtpMQgMCD7xvx/go-ipfs-util"
	ds "gx/ipfs/QmPpegoMqhAEqjncrzArm7KVWAkCm78rqL2DPuNjhPrshg/go-datastore"
Steven Allen's avatar
Steven Allen committed
10 11 12
	logging "gx/ipfs/QmRb5jh8z2E8hMGN2tkvs1yHynUanqnZ3UeKwgN1i9P1F8/go-log"
	routing "gx/ipfs/QmTiWLZ6Fo5j4KcTVutZJ5KWRRJrbxzmxA4td8NfEdrPh7/go-libp2p-routing"
	dhtpb "gx/ipfs/QmUpttFinNDmNPgFwKN8sZK6BUtBmA68Y4KdSBDXa8t9sJ/go-libp2p-record/pb"
13
	"gx/ipfs/QmVvkK7s5imCiq3JVbL3pGfnhcCnf3LrFJPF4GE2sAoGZf/go-testutil"
Steven Allen's avatar
Steven Allen committed
14
	ma "gx/ipfs/QmWWQ2Txc2c6tqjsBpzg5Ar652cHPGNsQQp2SejkNmkUMb/go-multiaddr"
Steven Allen's avatar
Steven Allen committed
15
	pstore "gx/ipfs/QmXauCuJzmzapetmC6W4TuDJLL1yFFrVzSHoWv8YdbmnxH/go-libp2p-peerstore"
16
	proto "gx/ipfs/QmZ4Qi3GaRbjcx28Sme5eMH7RQjGkt8wHxt2a65oLaeFEV/gogo-protobuf/proto"
Steven Allen's avatar
Steven Allen committed
17
	peer "gx/ipfs/QmZoWKhxUmZ2seW4BzX6fJkNR8hh9PsGModr7q171yq2SS/go-libp2p-peer"
Steven Allen's avatar
Steven Allen committed
18
	cid "gx/ipfs/QmcZfnkapfECQGcLZaf9B79NRg7cRa9EnZh4LSbkCzwNvY/go-cid"
19
	dshelp "gx/ipfs/QmdQTPWduSeyveSxeCAte33M592isSW5Z979g81aJphrgn/go-ipfs-ds-help"
Brian Tiger Chow's avatar
Brian Tiger Chow committed
20 21
)

Jeromy's avatar
Jeromy committed
22
var log = logging.Logger("mockrouter")
Brian Tiger Chow's avatar
Brian Tiger Chow committed
23 24 25 26

type client struct {
	datastore ds.Datastore
	server    server
27
	peer      testutil.Identity
Brian Tiger Chow's avatar
Brian Tiger Chow committed
28 29 30
}

// FIXME(brian): is this method meant to simulate putting a value into the network?
31
func (c *client) PutValue(ctx context.Context, key string, val []byte) error {
Brian Tiger Chow's avatar
Brian Tiger Chow committed
32
	log.Debugf("PutValue: %s", key)
33 34 35 36 37 38 39 40 41
	rec := new(dhtpb.Record)
	rec.Value = val
	rec.Key = proto.String(string(key))
	rec.TimeReceived = proto.String(u.FormatRFC3339(time.Now()))
	data, err := proto.Marshal(rec)
	if err != nil {
		return err
	}

42
	return c.datastore.Put(dshelp.NewKeyFromBinary([]byte(key)), data)
Brian Tiger Chow's avatar
Brian Tiger Chow committed
43 44 45
}

// FIXME(brian): is this method meant to simulate getting a value from the network?
46
func (c *client) GetValue(ctx context.Context, key string) ([]byte, error) {
Brian Tiger Chow's avatar
Brian Tiger Chow committed
47
	log.Debugf("GetValue: %s", key)
48
	v, err := c.datastore.Get(dshelp.NewKeyFromBinary([]byte(key)))
Brian Tiger Chow's avatar
Brian Tiger Chow committed
49 50 51 52 53 54 55 56 57
	if err != nil {
		return nil, err
	}

	data, ok := v.([]byte)
	if !ok {
		return nil, errors.New("could not cast value from datastore")
	}

58 59 60 61 62 63 64
	rec := new(dhtpb.Record)
	err = proto.Unmarshal(data, rec)
	if err != nil {
		return nil, err
	}

	return rec.GetValue(), nil
Brian Tiger Chow's avatar
Brian Tiger Chow committed
65 66
}

67
func (c *client) GetValues(ctx context.Context, key string, count int) ([]routing.RecvdVal, error) {
68 69
	log.Debugf("GetValues: %s", key)
	data, err := c.GetValue(ctx, key)
70 71 72 73 74 75 76
	if err != nil {
		return nil, err
	}

	return []routing.RecvdVal{{Val: data, From: c.peer.ID()}}, nil
}

77
func (c *client) FindProviders(ctx context.Context, key *cid.Cid) ([]pstore.PeerInfo, error) {
Brian Tiger Chow's avatar
Brian Tiger Chow committed
78 79 80
	return c.server.Providers(key), nil
}

Jeromy's avatar
Jeromy committed
81
func (c *client) FindPeer(ctx context.Context, pid peer.ID) (pstore.PeerInfo, error) {
Brian Tiger Chow's avatar
Brian Tiger Chow committed
82
	log.Debugf("FindPeer: %s", pid)
Jeromy's avatar
Jeromy committed
83
	return pstore.PeerInfo{}, nil
Brian Tiger Chow's avatar
Brian Tiger Chow committed
84 85
}

86
func (c *client) FindProvidersAsync(ctx context.Context, k *cid.Cid, max int) <-chan pstore.PeerInfo {
Jeromy's avatar
Jeromy committed
87
	out := make(chan pstore.PeerInfo)
Brian Tiger Chow's avatar
Brian Tiger Chow committed
88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
	go func() {
		defer close(out)
		for i, p := range c.server.Providers(k) {
			if max <= i {
				return
			}
			select {
			case out <- p:
			case <-ctx.Done():
				return
			}
		}
	}()
	return out
}

Brian Tiger Chow's avatar
Brian Tiger Chow committed
104 105
// Provide returns once the message is on the network. Value is not necessarily
// visible yet.
106 107 108 109
func (c *client) Provide(_ context.Context, key *cid.Cid, brd bool) error {
	if !brd {
		return nil
	}
Jeromy's avatar
Jeromy committed
110
	info := pstore.PeerInfo{
Brian Tiger Chow's avatar
Brian Tiger Chow committed
111 112 113 114
		ID:    c.peer.ID(),
		Addrs: []ma.Multiaddr{c.peer.Address()},
	}
	return c.server.Announce(info, key)
Brian Tiger Chow's avatar
Brian Tiger Chow committed
115 116
}

117 118
func (c *client) Ping(ctx context.Context, p peer.ID) (time.Duration, error) {
	return 0, nil
Brian Tiger Chow's avatar
Brian Tiger Chow committed
119 120
}

121 122 123 124
func (c *client) Bootstrap(context.Context) error {
	return nil
}

Brian Tiger Chow's avatar
Brian Tiger Chow committed
125
var _ routing.IpfsRouting = &client{}