mirror of
https://github.com/sigp/lighthouse.git
synced 2026-03-06 02:01:40 +00:00
* upgrade clap to v4.5 * cli fixes * Merge branch 'unstable' of https://github.com/sigp/lighthouse into upgrade-clap-cli * value parser for mnemonic * Merge branch 'unstable' of https://github.com/sigp/lighthouse into upgrade-clap-cli * merge unstable * default --format val * fix eth sim * fix eth sim * merge conflicts * resolve beta compiler issue * add num args, version * add custom flag parser, make rate limiter flags clap friendly * remove unneeded check * fmt * update * alphabetic order * resolve merge conflict * fix test * resolve conflicts * fix test * revert removed if statement * fmt got me again * fix broken flag * make cli * make cli * update * remove -e files * update * cli help updates * Merge branch 'unstable' of https://github.com/sigp/lighthouse into upgrade-clap-cli * cli help updates * md files * merge conflict * merge conflicts * md * help text, text width, and a few flag fixes * fmt * merge * revert * revert * resolve merge conflicts * merge conflicts * revert simulator changes * require at least one arg * fix eth sim cli * resolve merge conflicts * book changes * md changes * cli check * cli check * retry cli check * retry cli check * Merge branch 'unstable' of https://github.com/sigp/lighthouse into upgrade-clap-cli * cli * Merge remote-tracking branch 'origin/unstable' into upgrade-clap-cli * Update CLI docs for Goerli removal * Fix cargo lock
227 lines
8.3 KiB
Rust
227 lines
8.3 KiB
Rust
use beacon_node::{get_data_dir, set_network_config};
|
|
use clap::ArgMatches;
|
|
use eth2_network_config::Eth2NetworkConfig;
|
|
use lighthouse_network::discv5::{self, enr::CombinedKey, Enr};
|
|
use lighthouse_network::{
|
|
discovery::{load_enr_from_disk, use_or_load_enr},
|
|
load_private_key, CombinedKeyExt, NetworkConfig,
|
|
};
|
|
use serde::{Deserialize, Serialize};
|
|
use ssz::Encode;
|
|
use std::net::{SocketAddrV4, SocketAddrV6};
|
|
use std::time::Duration;
|
|
use std::{marker::PhantomData, path::PathBuf};
|
|
use types::EthSpec;
|
|
|
|
/// A set of configuration parameters for the bootnode, established from CLI arguments.
|
|
pub struct BootNodeConfig<E: EthSpec> {
|
|
// TODO: Generalise to multiaddr
|
|
pub boot_nodes: Vec<Enr>,
|
|
pub local_enr: Enr,
|
|
pub local_key: CombinedKey,
|
|
pub discv5_config: discv5::Config,
|
|
phantom: PhantomData<E>,
|
|
}
|
|
|
|
impl<E: EthSpec> BootNodeConfig<E> {
|
|
pub async fn new(
|
|
matches: &ArgMatches,
|
|
eth2_network_config: &Eth2NetworkConfig,
|
|
) -> Result<Self, String> {
|
|
let data_dir = get_data_dir(matches);
|
|
// Try and obtain bootnodes
|
|
|
|
let boot_nodes = {
|
|
let mut boot_nodes = Vec::new();
|
|
|
|
if let Some(enr) = ð2_network_config.boot_enr {
|
|
boot_nodes.extend_from_slice(enr);
|
|
}
|
|
|
|
if let Some(nodes) = matches.get_one::<String>("boot-nodes") {
|
|
boot_nodes.extend_from_slice(
|
|
&nodes
|
|
.split(',')
|
|
.map(|enr| enr.parse().map_err(|_| format!("Invalid ENR: {}", enr)))
|
|
.collect::<Result<Vec<Enr>, _>>()?,
|
|
);
|
|
}
|
|
|
|
boot_nodes
|
|
};
|
|
|
|
let mut network_config = NetworkConfig::default();
|
|
|
|
let logger = slog_scope::logger();
|
|
|
|
set_network_config(&mut network_config, matches, &data_dir, &logger)?;
|
|
|
|
// Set the Enr Discovery ports to the listening ports if not present.
|
|
if let Some(listening_addr_v4) = network_config.listen_addrs().v4() {
|
|
if network_config.enr_udp4_port.is_none() {
|
|
network_config.enr_udp4_port =
|
|
Some(network_config.enr_udp4_port.unwrap_or(
|
|
listening_addr_v4.disc_port.try_into().map_err(|_| {
|
|
"boot node enr-udp-port not set and listening port is zero"
|
|
})?,
|
|
))
|
|
}
|
|
};
|
|
|
|
if let Some(listening_addr_v6) = network_config.listen_addrs().v6() {
|
|
if network_config.enr_udp6_port.is_none() {
|
|
network_config.enr_udp6_port =
|
|
Some(network_config.enr_udp6_port.unwrap_or(
|
|
listening_addr_v6.disc_port.try_into().map_err(|_| {
|
|
"boot node enr-udp-port not set and listening port is zero"
|
|
})?,
|
|
))
|
|
}
|
|
};
|
|
|
|
// By default this is enabled. If it is not set, revert to false.
|
|
if !matches.get_flag("enable-enr-auto-update") {
|
|
network_config.discv5_config.enr_update = false;
|
|
}
|
|
|
|
let private_key = load_private_key(&network_config, &logger);
|
|
let local_key = CombinedKey::from_libp2p(private_key)?;
|
|
|
|
let local_enr = if let Some(dir) = matches.get_one::<String>("network-dir") {
|
|
let network_dir: PathBuf = dir.into();
|
|
load_enr_from_disk(&network_dir)?
|
|
} else {
|
|
// build the enr_fork_id and add it to the local_enr if it exists
|
|
let enr_fork = {
|
|
let spec = eth2_network_config.chain_spec::<E>()?;
|
|
|
|
let genesis_state_url: Option<String> =
|
|
clap_utils::parse_optional(matches, "genesis-state-url")?;
|
|
let genesis_state_url_timeout =
|
|
clap_utils::parse_required(matches, "genesis-state-url-timeout")
|
|
.map(Duration::from_secs)?;
|
|
|
|
if eth2_network_config.genesis_state_is_known() {
|
|
let genesis_state = eth2_network_config
|
|
.genesis_state::<E>(genesis_state_url.as_deref(), genesis_state_url_timeout, &logger).await?
|
|
.ok_or_else(|| {
|
|
"The genesis state for this network is not known, this is an unsupported mode"
|
|
.to_string()
|
|
})?;
|
|
|
|
slog::info!(logger, "Genesis state found"; "root" => genesis_state.canonical_root().to_string());
|
|
let enr_fork = spec.enr_fork_id::<E>(
|
|
types::Slot::from(0u64),
|
|
genesis_state.genesis_validators_root(),
|
|
);
|
|
|
|
Some(enr_fork.as_ssz_bytes())
|
|
} else {
|
|
slog::warn!(
|
|
logger,
|
|
"No genesis state provided. No Eth2 field added to the ENR"
|
|
);
|
|
None
|
|
}
|
|
};
|
|
|
|
// Build the local ENR
|
|
|
|
let mut local_enr = {
|
|
let (maybe_ipv4_address, maybe_ipv6_address) = network_config.enr_address;
|
|
let mut builder = discv5::Enr::builder();
|
|
|
|
if let Some(ip) = maybe_ipv4_address {
|
|
builder.ip4(ip);
|
|
}
|
|
|
|
if let Some(ip) = maybe_ipv6_address {
|
|
builder.ip6(ip);
|
|
}
|
|
|
|
if let Some(udp4_port) = network_config.enr_udp4_port {
|
|
builder.udp4(udp4_port.get());
|
|
}
|
|
|
|
if let Some(udp6_port) = network_config.enr_udp6_port {
|
|
builder.udp6(udp6_port.get());
|
|
}
|
|
|
|
// If we know of the ENR field, add it to the initial construction
|
|
if let Some(enr_fork_bytes) = enr_fork {
|
|
builder.add_value("eth2", &enr_fork_bytes);
|
|
}
|
|
builder
|
|
.build(&local_key)
|
|
.map_err(|e| format!("Failed to build ENR: {:?}", e))?
|
|
};
|
|
|
|
use_or_load_enr(&local_key, &mut local_enr, &network_config, &logger)?;
|
|
local_enr
|
|
};
|
|
|
|
Ok(BootNodeConfig {
|
|
boot_nodes,
|
|
local_enr,
|
|
local_key,
|
|
discv5_config: network_config.discv5_config,
|
|
phantom: PhantomData,
|
|
})
|
|
}
|
|
}
|
|
|
|
/// The set of configuration parameters that can safely be (de)serialized.
|
|
///
|
|
/// Its fields are a subset of the fields of `BootNodeConfig`, some of them are copied from `discv5::Config`.
|
|
#[derive(Serialize, Deserialize)]
|
|
pub struct BootNodeConfigSerialization {
|
|
pub ipv4_listen_socket: Option<SocketAddrV4>,
|
|
pub ipv6_listen_socket: Option<SocketAddrV6>,
|
|
// TODO: Generalise to multiaddr
|
|
pub boot_nodes: Vec<Enr>,
|
|
pub local_enr: Enr,
|
|
pub disable_packet_filter: bool,
|
|
pub enable_enr_auto_update: bool,
|
|
}
|
|
|
|
impl BootNodeConfigSerialization {
|
|
/// Returns a `BootNodeConfigSerialization` obtained from copying resp. cloning the
|
|
/// relevant fields of `config`
|
|
pub fn from_config_ref<E: EthSpec>(config: &BootNodeConfig<E>) -> Self {
|
|
let BootNodeConfig {
|
|
boot_nodes,
|
|
local_enr,
|
|
local_key: _,
|
|
discv5_config,
|
|
phantom: _,
|
|
} = config;
|
|
|
|
let (ipv4_listen_socket, ipv6_listen_socket) = match discv5_config.listen_config {
|
|
lighthouse_network::discv5::ListenConfig::Ipv4 { ip, port } => {
|
|
(Some(SocketAddrV4::new(ip, port)), None)
|
|
}
|
|
lighthouse_network::discv5::ListenConfig::Ipv6 { ip, port } => {
|
|
(None, Some(SocketAddrV6::new(ip, port, 0, 0)))
|
|
}
|
|
lighthouse_network::discv5::ListenConfig::DualStack {
|
|
ipv4,
|
|
ipv4_port,
|
|
ipv6,
|
|
ipv6_port,
|
|
} => (
|
|
Some(SocketAddrV4::new(ipv4, ipv4_port)),
|
|
Some(SocketAddrV6::new(ipv6, ipv6_port, 0, 0)),
|
|
),
|
|
};
|
|
|
|
BootNodeConfigSerialization {
|
|
ipv4_listen_socket,
|
|
ipv6_listen_socket,
|
|
boot_nodes: boot_nodes.clone(),
|
|
local_enr: local_enr.clone(),
|
|
disable_packet_filter: !discv5_config.enable_packet_filter,
|
|
enable_enr_auto_update: discv5_config.enr_update,
|
|
}
|
|
}
|
|
}
|