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
|
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.
|
// Pubkey returns the secp256k1 public key of the node, if present.
|
||||||
func (n *Node) Pubkey() *ecdsa.PublicKey {
|
func (n *Node) Pubkey() *ecdsa.PublicKey {
|
||||||
var key ecdsa.PublicKey
|
var key ecdsa.PublicKey
|
||||||
|
@ -68,11 +68,12 @@ func TestPythonInterop(t *testing.T) {
|
|||||||
func TestNodeEndpoints(t *testing.T) {
|
func TestNodeEndpoints(t *testing.T) {
|
||||||
id := HexID("00000000000000806ad9b61fa5ae014307ebdc964253adcd9f2c0a392aa11abc")
|
id := HexID("00000000000000806ad9b61fa5ae014307ebdc964253adcd9f2c0a392aa11abc")
|
||||||
type endpointTest struct {
|
type endpointTest struct {
|
||||||
name string
|
name string
|
||||||
node *Node
|
node *Node
|
||||||
wantIP netip.Addr
|
wantIP netip.Addr
|
||||||
wantUDP int
|
wantUDP int
|
||||||
wantTCP int
|
wantTCP int
|
||||||
|
wantQUIC int
|
||||||
}
|
}
|
||||||
tests := []endpointTest{
|
tests := []endpointTest{
|
||||||
{
|
{
|
||||||
@ -98,6 +99,22 @@ func TestNodeEndpoints(t *testing.T) {
|
|||||||
return SignNull(&r, id)
|
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",
|
name: "ipv4-only-loopback",
|
||||||
node: func() *Node {
|
node: func() *Node {
|
||||||
@ -209,6 +226,48 @@ func TestNodeEndpoints(t *testing.T) {
|
|||||||
wantIP: netip.MustParseAddr("192.168.2.2"),
|
wantIP: netip.MustParseAddr("192.168.2.2"),
|
||||||
wantUDP: 30304,
|
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 {
|
for _, test := range tests {
|
||||||
@ -222,6 +281,9 @@ func TestNodeEndpoints(t *testing.T) {
|
|||||||
if test.wantTCP != test.node.TCP() {
|
if test.wantTCP != test.node.TCP() {
|
||||||
t.Errorf("node has wrong TCP port %d, want %d", test.node.TCP(), test.wantTCP)
|
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" }
|
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.
|
// ID is the "id" key, which holds the name of the identity scheme.
|
||||||
type ID string
|
type ID string
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user