package dht_pb import ( "errors" "github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/goprotobuf/proto" ma "github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr" peer "github.com/jbenet/go-ipfs/peer" ) func NewMessage(typ Message_MessageType, key string, level int) *Message { m := &Message{ Type: &typ, Key: &key, } m.SetClusterLevel(level) return m } func peerToPBPeer(p peer.Peer) *Message_Peer { pbp := new(Message_Peer) addrs := p.Addresses() if len(addrs) == 0 || addrs[0] == nil { pbp.Addr = proto.String("") } else { addr := addrs[0].String() pbp.Addr = &addr } pid := string(p.ID()) pbp.Id = &pid return pbp } func PeersToPBPeers(peers []peer.Peer) []*Message_Peer { pbpeers := make([]*Message_Peer, len(peers)) for i, p := range peers { pbpeers[i] = peerToPBPeer(p) } return pbpeers } // Address returns a multiaddr associated with the Message_Peer entry func (m *Message_Peer) Address() (ma.Multiaddr, error) { if m == nil { return nil, errors.New("MessagePeer is nil") } return ma.NewMultiaddr(*m.Addr) } // 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) func (m *Message) GetClusterLevel() int { level := m.GetClusterLevelRaw() - 1 if level < 0 { return 0 } return int(level) } // 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) func (m *Message) SetClusterLevel(level int) { lvl := int32(level) m.ClusterLevelRaw = &lvl }