aboutsummaryrefslogtreecommitdiffstats
path: root/p2p/discover/udp.go
diff options
context:
space:
mode:
authorFelix Lange <fjl@twurst.com>2015-12-23 08:52:40 +0800
committerFelix Lange <fjl@twurst.com>2016-02-19 18:14:42 +0800
commitee1debda538857747536e8baf260630183f36869 (patch)
treeed98b3c983011f78fe01266fe7d974fac4b3eb84 /p2p/discover/udp.go
parentbb07ce3eedabb2133227ba1d7569d171d8e5b25c (diff)
downloadgo-tangerine-ee1debda538857747536e8baf260630183f36869.tar
go-tangerine-ee1debda538857747536e8baf260630183f36869.tar.gz
go-tangerine-ee1debda538857747536e8baf260630183f36869.tar.bz2
go-tangerine-ee1debda538857747536e8baf260630183f36869.tar.lz
go-tangerine-ee1debda538857747536e8baf260630183f36869.tar.xz
go-tangerine-ee1debda538857747536e8baf260630183f36869.tar.zst
go-tangerine-ee1debda538857747536e8baf260630183f36869.zip
p2p/discover: EIP-8 changes
Diffstat (limited to 'p2p/discover/udp.go')
-rw-r--r--p2p/discover/udp.go11
1 files changed, 10 insertions, 1 deletions
diff --git a/p2p/discover/udp.go b/p2p/discover/udp.go
index cec9046a3..81674f552 100644
--- a/p2p/discover/udp.go
+++ b/p2p/discover/udp.go
@@ -67,6 +67,8 @@ type (
Version uint
From, To rpcEndpoint
Expiration uint64
+ // Ignore additional fields (for forward compatibility).
+ Rest []rlp.RawValue `rlp:"tail"`
}
// pong is the reply to ping.
@@ -78,18 +80,24 @@ type (
ReplyTok []byte // This contains the hash of the ping packet.
Expiration uint64 // Absolute timestamp at which the packet becomes invalid.
+ // Ignore additional fields (for forward compatibility).
+ Rest []rlp.RawValue `rlp:"tail"`
}
// findnode is a query for nodes close to the given target.
findnode struct {
Target NodeID // doesn't need to be an actual public key
Expiration uint64
+ // Ignore additional fields (for forward compatibility).
+ Rest []rlp.RawValue `rlp:"tail"`
}
// reply to findnode
neighbors struct {
Nodes []rpcNode
Expiration uint64
+ // Ignore additional fields (for forward compatibility).
+ Rest []rlp.RawValue `rlp:"tail"`
}
rpcNode struct {
@@ -522,7 +530,8 @@ func decodePacket(buf []byte) (packet, NodeID, []byte, error) {
default:
return nil, fromID, hash, fmt.Errorf("unknown type: %d", ptype)
}
- err = rlp.DecodeBytes(sigdata[1:], req)
+ s := rlp.NewStream(bytes.NewReader(sigdata[1:]), 0)
+ err = s.Decode(req)
return req, fromID, hash, err
}