go-libp2p-kad-dht/pb/message.go

184 lines
4.9 KiB
Go
Raw Normal View History

package dht_pb
2014-08-09 22:28:46 -07:00
import (
logging "github.com/ipfs/go-log"
inet "github.com/libp2p/go-libp2p-net"
peer "github.com/libp2p/go-libp2p-peer"
pstore "github.com/libp2p/go-libp2p-peerstore"
b58 "github.com/mr-tron/base58/base58"
ma "github.com/multiformats/go-multiaddr"
2014-08-09 22:28:46 -07:00
)
var log = logging.Logger("dht.pb")
2015-01-27 22:57:39 -08:00
type PeerRoutingInfo struct {
pstore.PeerInfo
2015-01-27 22:57:39 -08:00
inet.Connectedness
}
// NewMessage constructs a new dht message with given type, key, and level
func NewMessage(typ Message_MessageType, key []byte, level int) *Message {
2014-09-16 07:17:55 -07:00
m := &Message{
Type: typ,
Key: key,
2014-09-16 07:17:55 -07:00
}
m.SetClusterLevel(level)
return m
}
2015-01-27 22:57:39 -08:00
func peerRoutingInfoToPBPeer(p PeerRoutingInfo) *Message_Peer {
pbp := new(Message_Peer)
pbp.Addrs = make([][]byte, len(p.Addrs))
for i, maddr := range p.Addrs {
pbp.Addrs[i] = maddr.Bytes() // Bytes, not String. Compressed.
}
s := string(p.ID)
pbp.Id = []byte(s)
2015-01-27 22:57:39 -08:00
c := ConnectionType(p.Connectedness)
pbp.Connection = c
2015-01-27 22:57:39 -08:00
return pbp
}
func peerInfoToPBPeer(p pstore.PeerInfo) *Message_Peer {
2014-09-16 00:52:57 -07:00
pbp := new(Message_Peer)
pbp.Addrs = make([][]byte, len(p.Addrs))
for i, maddr := range p.Addrs {
pbp.Addrs[i] = maddr.Bytes() // Bytes, not String. Compressed.
2014-08-09 22:28:46 -07:00
}
pbp.Id = []byte(p.ID)
2014-08-09 22:28:46 -07:00
return pbp
}
// PBPeerToPeer turns a *Message_Peer into its pstore.PeerInfo counterpart
func PBPeerToPeerInfo(pbp *Message_Peer) *pstore.PeerInfo {
return &pstore.PeerInfo{
ID: peer.ID(pbp.GetId()),
Addrs: pbp.Addresses(),
2014-11-21 08:03:11 -08:00
}
}
// RawPeerInfosToPBPeers converts a slice of Peers into a slice of *Message_Peers,
2014-11-20 10:46:19 -08:00
// ready to go out on the wire.
func RawPeerInfosToPBPeers(peers []pstore.PeerInfo) []*Message_Peer {
2014-09-16 07:17:55 -07:00
pbpeers := make([]*Message_Peer, len(peers))
2014-09-16 01:09:34 -07:00
for i, p := range peers {
pbpeers[i] = peerInfoToPBPeer(p)
2014-09-16 01:09:34 -07:00
}
return pbpeers
}
// PeersToPBPeers converts given []peer.Peer into a set of []*Message_Peer,
// which can be written to a message and sent out. the key thing this function
// does (in addition to PeersToPBPeers) is set the ConnectionType with
// information from the given inet.Network.
func PeerInfosToPBPeers(n inet.Network, peers []pstore.PeerInfo) []*Message_Peer {
pbps := RawPeerInfosToPBPeers(peers)
for i, pbp := range pbps {
c := ConnectionType(n.Connectedness(peers[i].ID))
pbp.Connection = c
}
return pbps
}
2015-01-27 22:57:39 -08:00
func PeerRoutingInfosToPBPeers(peers []PeerRoutingInfo) []*Message_Peer {
pbpeers := make([]*Message_Peer, len(peers))
for i, p := range peers {
pbpeers[i] = peerRoutingInfoToPBPeer(p)
}
return pbpeers
}
// PBPeersToPeerInfos converts given []*Message_Peer into []pstore.PeerInfo
// Invalid addresses will be silently omitted.
func PBPeersToPeerInfos(pbps []*Message_Peer) []*pstore.PeerInfo {
peers := make([]*pstore.PeerInfo, 0, len(pbps))
for _, pbp := range pbps {
peers = append(peers, PBPeerToPeerInfo(pbp))
2014-11-21 08:03:11 -08:00
}
return peers
2014-11-21 08:03:11 -08:00
}
// Addresses returns a multiaddr associated with the Message_Peer entry
func (m *Message_Peer) Addresses() []ma.Multiaddr {
if m == nil {
return nil
}
maddrs := make([]ma.Multiaddr, 0, len(m.Addrs))
for _, addr := range m.Addrs {
maddr, err := ma.NewMultiaddrBytes(addr)
if err != nil {
log.Warningf("error decoding Multiaddr for peer: %s", m.GetId())
continue
}
maddrs = append(maddrs, maddr)
}
return maddrs
}
2014-09-16 00:52:57 -07:00
// GetClusterLevel gets and adjusts the cluster level on the message.
// a +/- 1 adjustment is needed to distinguish a valid first level (1) and
// default "no value" protobuf behavior (0)
2014-09-16 07:17:55 -07:00
func (m *Message) GetClusterLevel() int {
2014-09-16 01:09:34 -07:00
level := m.GetClusterLevelRaw() - 1
if level < 0 {
return 0
2014-09-16 01:09:34 -07:00
}
2014-09-16 07:17:55 -07:00
return int(level)
2014-09-16 00:52:57 -07:00
}
2014-09-16 00:52:57 -07:00
// SetClusterLevel adjusts and sets the cluster level on the message.
// a +/- 1 adjustment is needed to distinguish a valid first level (1) and
// default "no value" protobuf behavior (0)
2014-09-16 07:17:55 -07:00
func (m *Message) SetClusterLevel(level int) {
lvl := int32(level)
m.ClusterLevelRaw = lvl
}
// Loggable turns a Message into machine-readable log output
func (m *Message) Loggable() map[string]interface{} {
return map[string]interface{}{
"message": map[string]string{
"type": m.Type.String(),
2016-09-30 10:24:03 -07:00
"key": b58.Encode([]byte(m.GetKey())),
},
}
}
// ConnectionType returns a Message_ConnectionType associated with the
// inet.Connectedness.
func ConnectionType(c inet.Connectedness) Message_ConnectionType {
switch c {
default:
return Message_NOT_CONNECTED
case inet.NotConnected:
return Message_NOT_CONNECTED
case inet.Connected:
return Message_CONNECTED
case inet.CanConnect:
return Message_CAN_CONNECT
case inet.CannotConnect:
return Message_CANNOT_CONNECT
}
}
// Connectedness returns an inet.Connectedness associated with the
// Message_ConnectionType.
func Connectedness(c Message_ConnectionType) inet.Connectedness {
switch c {
default:
return inet.NotConnected
case Message_NOT_CONNECTED:
return inet.NotConnected
case Message_CONNECTED:
return inet.Connected
case Message_CAN_CONNECT:
return inet.CanConnect
case Message_CANNOT_CONNECT:
return inet.CannotConnect
}
}