go-libp2p-kad-dht/Message.go

57 lines
1.4 KiB
Go
Raw Normal View History

package dht
2014-08-09 22:28:46 -07:00
import (
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/goprotobuf/proto"
2014-08-09 22:28:46 -07:00
peer "github.com/jbenet/go-ipfs/peer"
)
2014-09-16 07:17:55 -07:00
func newMessage(typ Message_MessageType, key string, level int) *Message {
m := &Message{
Type: &typ,
Key: &key,
}
m.SetClusterLevel(level)
return m
}
2014-09-16 01:09:34 -07:00
func peerToPBPeer(p *peer.Peer) *Message_Peer {
2014-09-16 00:52:57 -07:00
pbp := new(Message_Peer)
2014-08-19 19:14:52 -07:00
if len(p.Addresses) == 0 || p.Addresses[0] == nil {
pbp.Addr = proto.String("")
} else {
2014-10-06 04:13:39 -07:00
addr := p.Addresses[0].String()
2014-08-19 19:14:52 -07:00
pbp.Addr = &addr
2014-08-09 22:28:46 -07:00
}
pid := string(p.ID)
pbp.Id = &pid
return pbp
}
2014-09-16 01:09:34 -07:00
func peersToPBPeers(peers []*peer.Peer) []*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] = peerToPBPeer(p)
}
return pbpeers
}
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 {
log.Error("GetClusterLevel: no routing level specified, assuming 0")
2014-09-16 01:09:34 -07:00
level = 0
}
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
}