Message.go 1.53 KB
Newer Older
1 2
package dht

Jeromy's avatar
Jeromy committed
3
import (
4
	"github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/goprotobuf/proto"
Jeromy's avatar
Jeromy committed
5
	peer "github.com/jbenet/go-ipfs/peer"
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
6
	u "github.com/jbenet/go-ipfs/util"
Jeromy's avatar
Jeromy committed
7 8
)

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
9 10 11 12 13 14 15 16 17
func newMessage(typ Message_MessageType, key string, level int) *Message {
	m := &Message{
		Type: &typ,
		Key:  &key,
	}
	m.SetClusterLevel(level)
	return m
}

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
18
func peerToPBPeer(p *peer.Peer) *Message_Peer {
19
	pbp := new(Message_Peer)
Jeromy's avatar
Jeromy committed
20 21 22 23 24 25 26 27 28
	if len(p.Addresses) == 0 || p.Addresses[0] == nil {
		pbp.Addr = proto.String("")
	} else {
		addr, err := p.Addresses[0].String()
		if err != nil {
			//Temp: what situations could cause this?
			panic(err)
		}
		pbp.Addr = &addr
Jeromy's avatar
Jeromy committed
29 30 31 32
	}
	pid := string(p.ID)
	pbp.Id = &pid
	return pbp
33 34
}

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
35
func peersToPBPeers(peers []*peer.Peer) []*Message_Peer {
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
36
	pbpeers := make([]*Message_Peer, len(peers))
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
37 38 39 40 41 42
	for i, p := range peers {
		pbpeers[i] = peerToPBPeer(p)
	}
	return pbpeers
}

43 44 45
// 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)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
46
func (m *Message) GetClusterLevel() int {
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
47 48 49 50 51
	level := m.GetClusterLevelRaw() - 1
	if level < 0 {
		u.PErr("handleGetValue: no routing level specified, assuming 0\n")
		level = 0
	}
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
52
	return int(level)
53
}
54

55 56 57
// 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)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
58 59 60
func (m *Message) SetClusterLevel(level int) {
	lvl := int32(level)
	m.ClusterLevelRaw = &lvl
61
}