mirror of
https://github.com/fluencelabs/go-libp2p-kad-dht
synced 2025-05-30 14:41:19 +00:00
56 lines
1.2 KiB
Go
56 lines
1.2 KiB
Go
package dht
|
|
|
|
import (
|
|
"code.google.com/p/goprotobuf/proto"
|
|
peer "github.com/jbenet/go-ipfs/peer"
|
|
)
|
|
|
|
// Message is a a helper struct which makes working with protbuf types easier
|
|
type Message struct {
|
|
Type PBDHTMessage_MessageType
|
|
Key string
|
|
Value []byte
|
|
Response bool
|
|
ID string
|
|
Success bool
|
|
Peers []*peer.Peer
|
|
}
|
|
|
|
func peerInfo(p *peer.Peer) *PBDHTMessage_PBPeer {
|
|
pbp := new(PBDHTMessage_PBPeer)
|
|
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
|
|
}
|
|
pid := string(p.ID)
|
|
pbp.Id = &pid
|
|
return pbp
|
|
}
|
|
|
|
// ToProtobuf takes a Message and produces a protobuf with it.
|
|
// TODO: building the protobuf message this way is a little wasteful
|
|
// Unused fields wont be omitted, find a better way to do this
|
|
func (m *Message) ToProtobuf() *PBDHTMessage {
|
|
pmes := new(PBDHTMessage)
|
|
if m.Value != nil {
|
|
pmes.Value = m.Value
|
|
}
|
|
|
|
pmes.Type = &m.Type
|
|
pmes.Key = &m.Key
|
|
pmes.Response = &m.Response
|
|
pmes.Id = &m.ID
|
|
pmes.Success = &m.Success
|
|
for _, p := range m.Peers {
|
|
pmes.Peers = append(pmes.Peers, peerInfo(p))
|
|
}
|
|
|
|
return pmes
|
|
}
|