diff --git a/beacon_node/lighthouse_network/src/config.rs b/beacon_node/lighthouse_network/src/config.rs index b1119f31966..ae8bd6072e8 100644 --- a/beacon_node/lighthouse_network/src/config.rs +++ b/beacon_node/lighthouse_network/src/config.rs @@ -63,14 +63,14 @@ pub struct Config { /// that no discovery address has been set in the CLI args. pub enr_address: (Option, Option), - /// The udp4 port to broadcast to peers in order to reach back for discovery. - pub enr_udp4_port: Option, + /// The disc4 port to broadcast to peers in order to reach back for discovery. + pub enr_disc4_port: Option, /// The tcp4 port to broadcast to peers in order to reach back for libp2p services. pub enr_tcp4_port: Option, - /// The udp6 port to broadcast to peers in order to reach back for discovery. - pub enr_udp6_port: Option, + /// The disc6 port to broadcast to peers in order to reach back for discovery. + pub enr_disc6_port: Option, /// The tcp6 port to broadcast to peers in order to reach back for libp2p services. pub enr_tcp6_port: Option, @@ -167,7 +167,7 @@ impl Config { self.listen_addresses = ListenAddress::V4(ListenAddr { addr, disc_port, - quic_port, + quic_port: Some(quic_port), tcp_port, }); self.discv5_config.listen_config = discv5::ListenConfig::from_ip(addr.into(), disc_port); @@ -177,17 +177,11 @@ impl Config { /// Sets the listening address to use an ipv6 address. The discv5 ip_mode and table filter is /// adjusted accordingly to ensure addresses that are present in the enr are globally /// reachable. - pub fn set_ipv6_listening_address( - &mut self, - addr: Ipv6Addr, - tcp_port: u16, - disc_port: u16, - quic_port: u16, - ) { + pub fn set_ipv6_listening_address(&mut self, addr: Ipv6Addr, tcp_port: u16, disc_port: u16) { self.listen_addresses = ListenAddress::V6(ListenAddr { addr, disc_port, - quic_port, + quic_port: None, tcp_port, }); @@ -198,6 +192,8 @@ impl Config { /// Sets the listening address to use both an ipv4 and ipv6 address. The discv5 ip_mode and /// table filter is adjusted accordingly to ensure addresses that are present in the enr are /// globally reachable. + /// TODO: add Quic support IPV6 port when https://github.com/libp2p/rust-libp2p/issues/4165 + /// gets addressed. pub fn set_ipv4_ipv6_listening_addresses( &mut self, v4_addr: Ipv4Addr, @@ -207,19 +203,18 @@ impl Config { v6_addr: Ipv6Addr, tcp6_port: u16, disc6_port: u16, - quic6_port: u16, ) { self.listen_addresses = ListenAddress::DualStack( ListenAddr { addr: v4_addr, disc_port: disc4_port, - quic_port: quic4_port, + quic_port: Some(quic4_port), tcp_port: tcp4_port, }, ListenAddr { addr: v6_addr, disc_port: disc6_port, - quic_port: quic6_port, + quic_port: None, tcp_port: tcp6_port, }, ); @@ -242,13 +237,18 @@ impl Config { disc_port, quic_port, tcp_port, - }) => self.set_ipv4_listening_address(addr, tcp_port, disc_port, quic_port), + }) => self.set_ipv4_listening_address( + addr, + tcp_port, + disc_port, + quic_port.expect("Quic port should exist on an IPV4 address"), + ), ListenAddress::V6(ListenAddr { addr, disc_port, - quic_port, + quic_port: _, tcp_port, - }) => self.set_ipv6_listening_address(addr, tcp_port, disc_port, quic_port), + }) => self.set_ipv6_listening_address(addr, tcp_port, disc_port), ListenAddress::DualStack( ListenAddr { addr: ip4addr, @@ -259,12 +259,17 @@ impl Config { ListenAddr { addr: ip6addr, disc_port: disc6_port, - quic_port: quic6_port, + quic_port: _quic6_port, tcp_port: tcp6_port, }, ) => self.set_ipv4_ipv6_listening_addresses( - ip4addr, tcp4_port, disc4_port, quic4_port, ip6addr, tcp6_port, disc6_port, - quic6_port, + ip4addr, + tcp4_port, + disc4_port, + quic4_port.expect("Quic port should exist on an IPV4 address"), + ip6addr, + tcp6_port, + disc6_port, ), } } @@ -304,7 +309,7 @@ impl Default for Config { let listen_addresses = ListenAddress::V4(ListenAddr { addr: Ipv4Addr::UNSPECIFIED, disc_port: 9000, - quic_port: 9001, + quic_port: Some(9001), tcp_port: 9000, }); @@ -338,9 +343,9 @@ impl Default for Config { listen_addresses, enr_address: (None, None), - enr_udp4_port: None, + enr_disc4_port: None, enr_tcp4_port: None, - enr_udp6_port: None, + enr_disc6_port: None, enr_tcp6_port: None, target_peers: 50, gs_config, diff --git a/beacon_node/lighthouse_network/src/discovery/enr.rs b/beacon_node/lighthouse_network/src/discovery/enr.rs index ef22f816a77..0ec061eac7a 100644 --- a/beacon_node/lighthouse_network/src/discovery/enr.rs +++ b/beacon_node/lighthouse_network/src/discovery/enr.rs @@ -155,11 +155,11 @@ pub fn create_enr_builder_from_config( builder.ip6(*ip); } - if let Some(udp4_port) = config.enr_udp4_port { + if let Some(udp4_port) = config.enr_disc4_port { builder.udp4(udp4_port); } - if let Some(udp6_port) = config.enr_udp6_port { + if let Some(udp6_port) = config.enr_disc6_port { builder.udp6(udp6_port); } diff --git a/beacon_node/lighthouse_network/src/listen_addr.rs b/beacon_node/lighthouse_network/src/listen_addr.rs index 646df708efd..777dd178e89 100644 --- a/beacon_node/lighthouse_network/src/listen_addr.rs +++ b/beacon_node/lighthouse_network/src/listen_addr.rs @@ -11,7 +11,9 @@ pub struct ListenAddr { /// The UDP port that discovery will listen on. pub disc_port: u16, /// The UDP port that QUIC will listen on. - pub quic_port: u16, + /// NB: Quic port is optional as it's not yet supported with IPV6 + /// See https://github.com/libp2p/rust-libp2p/issues/4165 + pub quic_port: Option, /// The TCP port that libp2p will listen on. pub tcp_port: u16, } @@ -21,8 +23,20 @@ impl + Clone> ListenAddr { (self.addr.clone().into(), self.disc_port).into() } - pub fn quic_socket_addr(&self) -> SocketAddr { - (self.addr.clone().into(), self.quic_port).into() + pub fn quic_socket_addr(&self) -> Option { + let addr: IpAddr = self.addr.clone().into(); + match addr { + IpAddr::V4(ip) => { + let addr = ( + ip, + self.quic_port + .expect("Quic port should exist on an IPV4 address"), + ) + .into(); + Some(addr) + } + IpAddr::V6(_) => None, + } } pub fn libp2p_socket_addr(&self) -> SocketAddr { @@ -55,15 +69,24 @@ impl ListenAddress { } } - /// Returns the TCP addresses. - pub fn tcp_addresses(&self) -> impl Iterator + '_ { - let v4_multiaddr = self + /// Returns the Listen addresses. + pub fn listen_addresses(&self) -> impl Iterator { + let v4_tcp_multiaddrs = self + .v4() + .map(|v4_addr| Multiaddr::from(v4_addr.addr).with(Protocol::Tcp(v4_addr.tcp_port))); + + let v4_quic_multiaddrs = self .v4() .map(|v4_addr| Multiaddr::from(v4_addr.addr).with(Protocol::Tcp(v4_addr.tcp_port))); - let v6_multiaddr = self + + let v6_tcp_multiaddrs = self .v6() .map(|v6_addr| Multiaddr::from(v6_addr.addr).with(Protocol::Tcp(v6_addr.tcp_port))); - v4_multiaddr.into_iter().chain(v6_multiaddr) + + v4_tcp_multiaddrs + .into_iter() + .chain(v4_quic_multiaddrs) + .chain(v6_tcp_multiaddrs) } #[cfg(test)] @@ -71,7 +94,7 @@ impl ListenAddress { ListenAddress::V4(ListenAddr { addr: Ipv4Addr::UNSPECIFIED, disc_port: unused_port::unused_udp4_port().unwrap(), - quic_port: unused_port::unused_udp4_port().unwrap(), + quic_port: unused_port::unused_udp4_port().transpose().unwrap(), tcp_port: unused_port::unused_tcp4_port().unwrap(), }) } @@ -81,7 +104,7 @@ impl ListenAddress { ListenAddress::V6(ListenAddr { addr: Ipv6Addr::UNSPECIFIED, disc_port: unused_port::unused_udp6_port().unwrap(), - quic_port: unused_port::unused_udp6_port().unwrap(), + quic_port: None, tcp_port: unused_port::unused_tcp6_port().unwrap(), }) } @@ -96,15 +119,20 @@ impl slog::KV for ListenAddress { if let Some(v4_addr) = self.v4() { serializer.emit_arguments("ip4_address", &format_args!("{}", v4_addr.addr))?; serializer.emit_u16("disc4_port", v4_addr.disc_port)?; - serializer.emit_u16("quic4_port", v4_addr.quic_port)?; + serializer.emit_u16( + "quic4_port", + v4_addr + .quic_port + .expect("Quic port should exist on an IPV4 address"), + )?; serializer.emit_u16("tcp4_port", v4_addr.tcp_port)?; } if let Some(v6_addr) = self.v6() { serializer.emit_arguments("ip6_address", &format_args!("{}", v6_addr.addr))?; serializer.emit_u16("disc6_port", v6_addr.disc_port)?; - serializer.emit_u16("quic6_port", v6_addr.quic_port)?; + serializer.emit_none("quic6_port")?; serializer.emit_u16("tcp6_port", v6_addr.tcp_port)?; } slog::Result::Ok(()) } -} \ No newline at end of file +} diff --git a/beacon_node/lighthouse_network/src/service/mod.rs b/beacon_node/lighthouse_network/src/service/mod.rs index 1a25beee0a7..04ed3a8b5b2 100644 --- a/beacon_node/lighthouse_network/src/service/mod.rs +++ b/beacon_node/lighthouse_network/src/service/mod.rs @@ -399,7 +399,7 @@ impl Network { info!(self.log, "Libp2p Starting"; "peer_id" => %enr.peer_id(), "bandwidth_config" => format!("{}-{}", config.network_load, NetworkLoad::from(config.network_load).name)); debug!(self.log, "Attempting to open listening ports"; config.listen_addrs(), "discovery_enabled" => !config.disable_discovery); - for listen_multiaddr in config.listen_addrs().tcp_addresses() { + for listen_multiaddr in config.listen_addrs().listen_addresses() { match self.swarm.listen_on(listen_multiaddr.clone()) { Ok(_) => { let mut log_address = listen_multiaddr; @@ -1569,4 +1569,4 @@ impl Network { pub async fn next_event(&mut self) -> NetworkEvent { futures::future::poll_fn(|cx| self.poll_network(cx)).await } -} +} \ No newline at end of file diff --git a/beacon_node/lighthouse_network/tests/common.rs b/beacon_node/lighthouse_network/tests/common.rs index b48891335cc..9fccf006ea1 100644 --- a/beacon_node/lighthouse_network/tests/common.rs +++ b/beacon_node/lighthouse_network/tests/common.rs @@ -75,8 +75,8 @@ pub fn build_config(port: u16, mut boot_nodes: Vec) -> NetworkConfig { .tempdir() .unwrap(); - config.set_ipv4_listening_address(std::net::Ipv4Addr::UNSPECIFIED, port, port); - config.enr_udp4_port = Some(port); + config.set_ipv4_listening_address(std::net::Ipv4Addr::UNSPECIFIED, port, port, port + 1); + config.enr_disc4_port = Some(port); config.enr_address = (Some(std::net::Ipv4Addr::LOCALHOST), None); config.boot_nodes_enr.append(&mut boot_nodes); config.network_dir = path.into_path(); diff --git a/beacon_node/network/src/nat.rs b/beacon_node/network/src/nat.rs index 99b43db0334..f20ad8c542a 100644 --- a/beacon_node/network/src/nat.rs +++ b/beacon_node/network/src/nat.rs @@ -29,7 +29,9 @@ impl UPnPConfig { config.listen_addrs().v4().map(|v4_addr| UPnPConfig { tcp_port: v4_addr.tcp_port, disc_port: v4_addr.disc_port, - quic_port: v4_addr.quic_port, + quic_port: v4_addr + .quic_port + .expect("Quic port should exist on an IPV4 address"), disable_discovery: config.disable_discovery, disable_quic_support: config.disable_quic_support, }) @@ -203,4 +205,4 @@ pub fn remove_mappings(tcp_port: Option, udp_ports: &[u16], log: &slog::Log Err(e) => debug!(log, "UPnP failed to remove mappings"; "error" => %e), } } -} \ No newline at end of file +} diff --git a/beacon_node/src/cli.rs b/beacon_node/src/cli.rs index a20e33c23f1..3c126bc727e 100644 --- a/beacon_node/src/cli.rs +++ b/beacon_node/src/cli.rs @@ -89,7 +89,8 @@ pub fn cli_app<'a, 'b>() -> App<'a, 'b> { Arg::with_name("port") .long("port") .value_name("PORT") - .help("The TCP/UDP ports to listen on. There are two UDP ports. The discovery UDP port will be set to this value and the Quic UDP port will be set to his value + 1. The discovery port can be modified by the \ + .help("The TCP/UDP ports to listen on. There are two UDP ports. \ + The discovery UDP port will be set to this value and the Quic UDP port will be set to this value + 1. The discovery port can be modified by the \ --discovery-port flag and the quic port can be modified by the --quic-port flag. If listening over both IPv4 and IPv6 the --port flag \ will apply to the IPv4 address and --port6 to the IPv6 address.") .default_value("9000") @@ -246,7 +247,7 @@ pub fn cli_app<'a, 'b>() -> App<'a, 'b> { Arg::with_name("disable-discovery") .long("disable-discovery") .help("Disables the discv5 discovery protocol. The node will not search for new peers or participate in the discovery protocol.") - .takes_value(false), + .takes_value(false) .hidden(true) ) .arg( @@ -1165,4 +1166,4 @@ pub fn cli_app<'a, 'b>() -> App<'a, 'b> { .takes_value(true) .possible_values(ProgressiveBalancesMode::VARIANTS) ) -} \ No newline at end of file +} diff --git a/beacon_node/src/config.rs b/beacon_node/src/config.rs index 4abf649bfbb..76633290e3a 100644 --- a/beacon_node/src/config.rs +++ b/beacon_node/src/config.rs @@ -869,15 +869,15 @@ pub fn parse_listening_addresses( .map_err(|parse_error| format!("Failed to parse --port6 as an integer: {parse_error}"))? .unwrap_or(9090); - // parse the possible udp ports - let maybe_udp_port = cli_args + // parse the possible discovery ports. + let maybe_disc_port = cli_args .value_of("discovery-port") .map(str::parse::) .transpose() .map_err(|parse_error| { format!("Failed to parse --discovery-port as an integer: {parse_error}") })?; - let maybe_udp6_port = cli_args + let maybe_disc6_port = cli_args .value_of("discovery-port6") .map(str::parse::) .transpose() @@ -885,6 +885,15 @@ pub fn parse_listening_addresses( format!("Failed to parse --discovery-port6 as an integer: {parse_error}") })?; + // parse the possible quic port. + let maybe_quic_port = cli_args + .value_of("quic-port") + .map(str::parse::) + .transpose() + .map_err(|parse_error| { + format!("Failed to parse --quic-port as an integer: {parse_error}") + })?; + // Now put everything together let listening_addresses = match (maybe_ipv4, maybe_ipv6) { (None, None) => { @@ -903,20 +912,21 @@ pub fn parse_listening_addresses( .transpose()? .unwrap_or(port); - if maybe_udp6_port.is_some() { + if maybe_disc6_port.is_some() { warn!(log, "When listening only over IpV6, use the --discovery-port flag. The value of --discovery-port6 will be ignored.") } // use zero ports if required. If not, use the specific udp port. If none given, use // the tcp port. - let udp_port = use_zero_ports + let disc_port = use_zero_ports .then(unused_port::unused_udp6_port) .transpose()? - .or(maybe_udp_port) + .or(maybe_disc_port) .unwrap_or(port); ListenAddress::V6(lighthouse_network::ListenAddr { addr: ipv6, - udp_port, + quic_port: None, + disc_port, tcp_port, }) } @@ -928,16 +938,25 @@ pub fn parse_listening_addresses( .then(unused_port::unused_tcp4_port) .transpose()? .unwrap_or(port); - // use zero ports if required. If not, use the specific udp port. If none given, use + // use zero ports if required. If not, use the specific discovery port. If none given, use // the tcp port. - let udp_port = use_zero_ports + let disc_port = use_zero_ports .then(unused_port::unused_udp4_port) .transpose()? - .or(maybe_udp_port) + .or(maybe_disc_port) .unwrap_or(port); + // use zero ports if required. If not, use the specific quic port. If none given, use + // the tcp port + 1. + let quic_port = use_zero_ports + .then(unused_port::unused_udp4_port) + .transpose()? + .or(maybe_quic_port) + .unwrap_or(port + 1); + ListenAddress::V4(lighthouse_network::ListenAddr { addr: ipv4, - udp_port, + disc_port, + quic_port: Some(quic_port), tcp_port, }) } @@ -946,31 +965,39 @@ pub fn parse_listening_addresses( .then(unused_port::unused_tcp4_port) .transpose()? .unwrap_or(port); - let ipv4_udp_port = use_zero_ports + let ipv4_disc_port = use_zero_ports .then(unused_port::unused_udp4_port) .transpose()? - .or(maybe_udp_port) + .or(maybe_disc_port) .unwrap_or(ipv4_tcp_port); + let ipv4_quic_port = use_zero_ports + .then(unused_port::unused_udp4_port) + .transpose()? + .or(maybe_quic_port) + .unwrap_or(port + 1); // Defaults to 9090 when required let ipv6_tcp_port = use_zero_ports .then(unused_port::unused_tcp6_port) .transpose()? .unwrap_or(port6); - let ipv6_udp_port = use_zero_ports + let ipv6_disc_port = use_zero_ports .then(unused_port::unused_udp6_port) .transpose()? - .or(maybe_udp6_port) + .or(maybe_disc6_port) .unwrap_or(ipv6_tcp_port); + ListenAddress::DualStack( lighthouse_network::ListenAddr { addr: ipv4, - udp_port: ipv4_udp_port, + disc_port: ipv4_disc_port, + quic_port: Some(ipv4_quic_port), tcp_port: ipv4_tcp_port, }, lighthouse_network::ListenAddr { addr: ipv6, - udp_port: ipv6_udp_port, + disc_port: ipv6_disc_port, + quic_port: None, tcp_port: ipv6_tcp_port, }, ) @@ -1079,7 +1106,7 @@ pub fn set_network_config( } if let Some(enr_udp_port_str) = cli_args.value_of("enr-udp-port") { - config.enr_udp4_port = Some( + config.enr_disc4_port = Some( enr_udp_port_str .parse::() .map_err(|_| format!("Invalid discovery port: {}", enr_udp_port_str))?, @@ -1095,7 +1122,7 @@ pub fn set_network_config( } if let Some(enr_udp_port_str) = cli_args.value_of("enr-udp6-port") { - config.enr_udp6_port = Some( + config.enr_disc6_port = Some( enr_udp_port_str .parse::() .map_err(|_| format!("Invalid discovery port: {}", enr_udp_port_str))?, @@ -1121,7 +1148,7 @@ pub fn set_network_config( ipv4_addr.addr }; config.enr_address.0 = Some(ipv4_enr_addr); - config.enr_udp4_port = Some(ipv4_addr.udp_port); + config.enr_disc4_port = Some(ipv4_addr.disc_port); } if let Some(ipv6_addr) = config.listen_addrs().v6().cloned() { @@ -1131,7 +1158,7 @@ pub fn set_network_config( ipv6_addr.addr }; config.enr_address.1 = Some(ipv6_enr_addr); - config.enr_udp6_port = Some(ipv6_addr.udp_port); + config.enr_disc6_port = Some(ipv6_addr.disc_port); } } @@ -1164,11 +1191,11 @@ pub fn set_network_config( // actually matters. Just use the udp port. let port = match config.listen_addrs() { - ListenAddress::V4(v4_addr) => v4_addr.udp_port, - ListenAddress::V6(v6_addr) => v6_addr.udp_port, + ListenAddress::V4(v4_addr) => v4_addr.disc_port, + ListenAddress::V6(v6_addr) => v6_addr.disc_port, ListenAddress::DualStack(v4_addr, _v6_addr) => { // NOTE: slight preference for ipv4 that I don't think is of importance. - v4_addr.udp_port + v4_addr.disc_port } }; diff --git a/boot_node/src/config.rs b/boot_node/src/config.rs index d006156bf9d..7c5f2dd0f52 100644 --- a/boot_node/src/config.rs +++ b/boot_node/src/config.rs @@ -57,20 +57,20 @@ impl BootNodeConfig { set_network_config(&mut network_config, matches, &data_dir, &logger)?; - // Set the Enr UDP ports to the listening ports if not present. + // Set the Enr Discovery ports to the listening ports if not present. if let Some(listening_addr_v4) = network_config.listen_addrs().v4() { - network_config.enr_udp4_port = Some( + network_config.enr_disc4_port = Some( network_config - .enr_udp4_port - .unwrap_or(listening_addr_v4.udp_port), + .enr_disc4_port + .unwrap_or(listening_addr_v4.disc_port), ) }; if let Some(listening_addr_v6) = network_config.listen_addrs().v6() { - network_config.enr_udp6_port = Some( + network_config.enr_disc6_port = Some( network_config - .enr_udp6_port - .unwrap_or(listening_addr_v6.udp_port), + .enr_disc6_port + .unwrap_or(listening_addr_v6.disc_port), ) }; diff --git a/lcli/src/generate_bootnode_enr.rs b/lcli/src/generate_bootnode_enr.rs index 0584cd65496..54294f2b42c 100644 --- a/lcli/src/generate_bootnode_enr.rs +++ b/lcli/src/generate_bootnode_enr.rs @@ -27,7 +27,7 @@ pub fn run(matches: &ArgMatches) -> Result<(), String> { let mut config = NetworkConfig::default(); config.enr_address = (Some(ip), None); - config.enr_udp4_port = Some(udp_port); + config.enr_disc4_port = Some(udp_port); config.enr_tcp6_port = Some(tcp_port); let secp256k1_keypair = secp256k1::Keypair::generate(); @@ -57,4 +57,4 @@ pub fn run(matches: &ArgMatches) -> Result<(), String> { .map_err(|e| format!("Unable to write key to {}: {:?}", NETWORK_KEY_FILENAME, e))?; Ok(()) -} +} \ No newline at end of file diff --git a/testing/node_test_rig/src/lib.rs b/testing/node_test_rig/src/lib.rs index 62db67b8c57..746992f3207 100644 --- a/testing/node_test_rig/src/lib.rs +++ b/testing/node_test_rig/src/lib.rs @@ -98,7 +98,7 @@ pub fn testing_client_config() -> ClientConfig { // Setting ports to `0` means that the OS will choose some available port. client_config .network - .set_ipv4_listening_address(std::net::Ipv4Addr::UNSPECIFIED, 0, 0); + .set_ipv4_listening_address(std::net::Ipv4Addr::UNSPECIFIED, 0, 0, 0); client_config.network.upnp_enabled = false; client_config.http_api.enabled = true; client_config.http_api.listen_port = 0; diff --git a/testing/simulator/src/local_network.rs b/testing/simulator/src/local_network.rs index e35870d126c..9d03de14716 100644 --- a/testing/simulator/src/local_network.rs +++ b/testing/simulator/src/local_network.rs @@ -14,6 +14,7 @@ use std::{sync::Arc, time::Duration}; use types::{Epoch, EthSpec}; const BOOTNODE_PORT: u16 = 42424; +const QUIC_PORT: u16 = BOOTNODE_PORT + 1; pub const INVALID_ADDRESS: &str = "http://127.0.0.1:42423"; pub const EXECUTION_PORT: u16 = 4000; @@ -63,8 +64,9 @@ impl LocalNetwork { std::net::Ipv4Addr::UNSPECIFIED, BOOTNODE_PORT, BOOTNODE_PORT, + QUIC_PORT, ); - beacon_config.network.enr_udp4_port = Some(BOOTNODE_PORT); + beacon_config.network.enr_disc4_port = Some(BOOTNODE_PORT); beacon_config.network.enr_tcp4_port = Some(BOOTNODE_PORT); beacon_config.network.discv5_config.table_filter = |_| true; @@ -154,8 +156,9 @@ impl LocalNetwork { std::net::Ipv4Addr::UNSPECIFIED, BOOTNODE_PORT + count, BOOTNODE_PORT + count, + BOOTNODE_PORT + count + 1, ); - beacon_config.network.enr_udp4_port = Some(BOOTNODE_PORT + count); + beacon_config.network.enr_disc4_port = Some(BOOTNODE_PORT + count); beacon_config.network.enr_tcp4_port = Some(BOOTNODE_PORT + count); beacon_config.network.discv5_config.table_filter = |_| true; beacon_config.network.proposer_only = is_proposer; @@ -312,4 +315,4 @@ impl LocalNetwork { ); genesis_time - now } -} +} \ No newline at end of file