|
|
|
@ -427,10 +427,11 @@ func (rw *protoRW) ReadMsg() (Msg, error) { |
|
|
|
|
// peer. Sub-protocol independent fields are contained and initialized here, with
|
|
|
|
|
// protocol specifics delegated to all connected sub-protocols.
|
|
|
|
|
type PeerInfo struct { |
|
|
|
|
Enode string `json:"enode"` // Node URL
|
|
|
|
|
ID string `json:"id"` // Unique node identifier
|
|
|
|
|
Name string `json:"name"` // Name of the node, including client type, version, OS, custom data
|
|
|
|
|
Caps []string `json:"caps"` // Protocols advertised by this peer
|
|
|
|
|
ENR string `json:"enr,omitempty"` // Ethereum Node Record
|
|
|
|
|
Enode string `json:"enode"` // Node URL
|
|
|
|
|
ID string `json:"id"` // Unique node identifier
|
|
|
|
|
Name string `json:"name"` // Name of the node, including client type, version, OS, custom data
|
|
|
|
|
Caps []string `json:"caps"` // Protocols advertised by this peer
|
|
|
|
|
Network struct { |
|
|
|
|
LocalAddress string `json:"localAddress"` // Local endpoint of the TCP data connection
|
|
|
|
|
RemoteAddress string `json:"remoteAddress"` // Remote endpoint of the TCP data connection
|
|
|
|
@ -450,12 +451,15 @@ func (p *Peer) Info() *PeerInfo { |
|
|
|
|
} |
|
|
|
|
// Assemble the generic peer metadata
|
|
|
|
|
info := &PeerInfo{ |
|
|
|
|
Enode: p.Node().String(), |
|
|
|
|
Enode: p.Node().URLv4(), |
|
|
|
|
ID: p.ID().String(), |
|
|
|
|
Name: p.Name(), |
|
|
|
|
Caps: caps, |
|
|
|
|
Protocols: make(map[string]interface{}), |
|
|
|
|
} |
|
|
|
|
if p.Node().Seq() > 0 { |
|
|
|
|
info.ENR = p.Node().String() |
|
|
|
|
} |
|
|
|
|
info.Network.LocalAddress = p.LocalAddr().String() |
|
|
|
|
info.Network.RemoteAddress = p.RemoteAddr().String() |
|
|
|
|
info.Network.Inbound = p.rw.is(inboundConn) |
|
|
|
|