p2p/enode: add quic ENR entry (#30283)
Add `quic` entry to the ENR as proposed in https://github.com/ethereum/consensus-specs/pull/3644 --------- Co-authored-by: lightclient <lightclient@protonmail.com>
This commit is contained in:
parent
9be2e010c1
commit
f544fc3b46
@ -200,6 +200,20 @@ func (n *Node) TCPEndpoint() (netip.AddrPort, bool) {
|
||||
return netip.AddrPortFrom(n.ip, n.tcp), true
|
||||
}
|
||||
|
||||
// QUICEndpoint returns the announced QUIC endpoint.
|
||||
func (n *Node) QUICEndpoint() (netip.AddrPort, bool) {
|
||||
var quic uint16
|
||||
if n.ip.Is4() || n.ip.Is4In6() {
|
||||
n.Load((*enr.QUIC)(&quic))
|
||||
} else if n.ip.Is6() {
|
||||
n.Load((*enr.QUIC6)(&quic))
|
||||
}
|
||||
if !n.ip.IsValid() || n.ip.IsUnspecified() || quic == 0 {
|
||||
return netip.AddrPort{}, false
|
||||
}
|
||||
return netip.AddrPortFrom(n.ip, quic), true
|
||||
}
|
||||
|
||||
// Pubkey returns the secp256k1 public key of the node, if present.
|
||||
func (n *Node) Pubkey() *ecdsa.PublicKey {
|
||||
var key ecdsa.PublicKey
|
||||
|
@ -68,11 +68,12 @@ func TestPythonInterop(t *testing.T) {
|
||||
func TestNodeEndpoints(t *testing.T) {
|
||||
id := HexID("00000000000000806ad9b61fa5ae014307ebdc964253adcd9f2c0a392aa11abc")
|
||||
type endpointTest struct {
|
||||
name string
|
||||
node *Node
|
||||
wantIP netip.Addr
|
||||
wantUDP int
|
||||
wantTCP int
|
||||
name string
|
||||
node *Node
|
||||
wantIP netip.Addr
|
||||
wantUDP int
|
||||
wantTCP int
|
||||
wantQUIC int
|
||||
}
|
||||
tests := []endpointTest{
|
||||
{
|
||||
@ -98,6 +99,22 @@ func TestNodeEndpoints(t *testing.T) {
|
||||
return SignNull(&r, id)
|
||||
}(),
|
||||
},
|
||||
{
|
||||
name: "quic-only",
|
||||
node: func() *Node {
|
||||
var r enr.Record
|
||||
r.Set(enr.QUIC(9000))
|
||||
return SignNull(&r, id)
|
||||
}(),
|
||||
},
|
||||
{
|
||||
name: "quic6-only",
|
||||
node: func() *Node {
|
||||
var r enr.Record
|
||||
r.Set(enr.QUIC6(9000))
|
||||
return SignNull(&r, id)
|
||||
}(),
|
||||
},
|
||||
{
|
||||
name: "ipv4-only-loopback",
|
||||
node: func() *Node {
|
||||
@ -209,6 +226,48 @@ func TestNodeEndpoints(t *testing.T) {
|
||||
wantIP: netip.MustParseAddr("192.168.2.2"),
|
||||
wantUDP: 30304,
|
||||
},
|
||||
{
|
||||
name: "ipv4-quic",
|
||||
node: func() *Node {
|
||||
var r enr.Record
|
||||
r.Set(enr.IPv4Addr(netip.MustParseAddr("99.22.33.1")))
|
||||
r.Set(enr.QUIC(9001))
|
||||
return SignNull(&r, id)
|
||||
}(),
|
||||
wantIP: netip.MustParseAddr("99.22.33.1"),
|
||||
wantQUIC: 9001,
|
||||
},
|
||||
{ // Because the node is IPv4, the quic6 entry won't be loaded.
|
||||
name: "ipv4-quic6",
|
||||
node: func() *Node {
|
||||
var r enr.Record
|
||||
r.Set(enr.IPv4Addr(netip.MustParseAddr("99.22.33.1")))
|
||||
r.Set(enr.QUIC6(9001))
|
||||
return SignNull(&r, id)
|
||||
}(),
|
||||
wantIP: netip.MustParseAddr("99.22.33.1"),
|
||||
},
|
||||
{
|
||||
name: "ipv6-quic",
|
||||
node: func() *Node {
|
||||
var r enr.Record
|
||||
r.Set(enr.IPv6Addr(netip.MustParseAddr("2001::ff00:0042:8329")))
|
||||
r.Set(enr.QUIC(9001))
|
||||
return SignNull(&r, id)
|
||||
}(),
|
||||
wantIP: netip.MustParseAddr("2001::ff00:0042:8329"),
|
||||
},
|
||||
{
|
||||
name: "ipv6-quic6",
|
||||
node: func() *Node {
|
||||
var r enr.Record
|
||||
r.Set(enr.IPv6Addr(netip.MustParseAddr("2001::ff00:0042:8329")))
|
||||
r.Set(enr.QUIC6(9001))
|
||||
return SignNull(&r, id)
|
||||
}(),
|
||||
wantIP: netip.MustParseAddr("2001::ff00:0042:8329"),
|
||||
wantQUIC: 9001,
|
||||
},
|
||||
}
|
||||
|
||||
for _, test := range tests {
|
||||
@ -222,6 +281,9 @@ func TestNodeEndpoints(t *testing.T) {
|
||||
if test.wantTCP != test.node.TCP() {
|
||||
t.Errorf("node has wrong TCP port %d, want %d", test.node.TCP(), test.wantTCP)
|
||||
}
|
||||
if quic, _ := test.node.QUICEndpoint(); test.wantQUIC != int(quic.Port()) {
|
||||
t.Errorf("node has wrong QUIC port %d, want %d", quic.Port(), test.wantQUIC)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -77,6 +77,16 @@ type UDP6 uint16
|
||||
|
||||
func (v UDP6) ENRKey() string { return "udp6" }
|
||||
|
||||
// QUIC is the "quic" key, which holds the QUIC port of the node.
|
||||
type QUIC uint16
|
||||
|
||||
func (v QUIC) ENRKey() string { return "quic" }
|
||||
|
||||
// QUIC6 is the "quic6" key, which holds the IPv6-specific quic6 port of the node.
|
||||
type QUIC6 uint16
|
||||
|
||||
func (v QUIC6) ENRKey() string { return "quic6" }
|
||||
|
||||
// ID is the "id" key, which holds the name of the identity scheme.
|
||||
type ID string
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user