mirror of
https://github.com/Cuprate/cuprate.git
synced 2025-01-10 21:05:01 +00:00
review comments
This commit is contained in:
parent
06b7429f9e
commit
26653d428d
10 changed files with 34 additions and 25 deletions
|
@ -10,7 +10,10 @@ use clap::Parser;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
use cuprate_consensus::ContextConfig;
|
use cuprate_consensus::ContextConfig;
|
||||||
use cuprate_helper::{fs::CUPRATE_CONFIG_DIR, network::Network};
|
use cuprate_helper::{
|
||||||
|
fs::{CUPRATE_CONFIG_DIR, DEFAULT_CONFIG_FILE_NAME},
|
||||||
|
network::Network,
|
||||||
|
};
|
||||||
use cuprate_p2p::block_downloader::BlockDownloaderConfig;
|
use cuprate_p2p::block_downloader::BlockDownloaderConfig;
|
||||||
use cuprate_p2p_core::ClearNet;
|
use cuprate_p2p_core::ClearNet;
|
||||||
|
|
||||||
|
@ -24,19 +27,16 @@ use p2p::P2PConfig;
|
||||||
use storage::StorageConfig;
|
use storage::StorageConfig;
|
||||||
use tracing_config::TracingConfig;
|
use tracing_config::TracingConfig;
|
||||||
|
|
||||||
/// The default name of Cuprate's config file.
|
|
||||||
const DEFAULT_CONFIG_FILE_NAME: &str = "Cuprate.toml";
|
|
||||||
|
|
||||||
/// Reads the args & config file, returning a [`Config`].
|
/// Reads the args & config file, returning a [`Config`].
|
||||||
pub fn read_config_and_args() -> Config {
|
pub fn read_config_and_args() -> Config {
|
||||||
let args = args::Args::parse();
|
let args = args::Args::parse();
|
||||||
|
|
||||||
let config: Config = if let Some(config_file) = &args.config_file {
|
let config: Config = if let Some(config_file) = &args.config_file {
|
||||||
// If a config file was set in the args try read it and exit if we can't.
|
// If a config file was set in the args try to read it and exit if we can't.
|
||||||
match Config::read_from_file(config_file) {
|
match Config::read_from_file(config_file) {
|
||||||
Ok(config) => config,
|
Ok(config) => config,
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
tracing::error!("Failed to read config from file: {}", e);
|
tracing::error!("Failed to read config from file: {e}");
|
||||||
std::process::exit(1);
|
std::process::exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -74,20 +74,22 @@ pub struct Config {
|
||||||
/// The P2P network config.
|
/// The P2P network config.
|
||||||
p2p: P2PConfig,
|
p2p: P2PConfig,
|
||||||
|
|
||||||
/// The Storage config
|
/// The storage config.
|
||||||
storage: StorageConfig,
|
storage: StorageConfig,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Config {
|
impl Config {
|
||||||
/// Attempts to read a config file in [`toml`] format from the given [`Path`.
|
/// Attempts to read a config file in [`toml`] format from the given [`Path`].
|
||||||
///
|
///
|
||||||
/// # Errors
|
/// # Errors
|
||||||
///
|
///
|
||||||
/// Will return an [`Err`] if the file cannot be read or if the file is not a valid [`toml`] config.
|
/// Will return an [`Err`] if the file cannot be read or if the file is not a valid [`toml`] config.
|
||||||
fn read_from_file(file: impl AsRef<Path>) -> Result<Self, anyhow::Error> {
|
fn read_from_path(file: impl AsRef<Path>) -> Result<Self, anyhow::Error> {
|
||||||
let file_text = read_to_string(file.as_ref())?;
|
let file_text = read_to_string(file.as_ref())?;
|
||||||
|
|
||||||
Ok(toml::from_str(&file_text).inspect_err(|_| {
|
Ok(toml::from_str(&file_text).inspect_err(|e| {
|
||||||
|
tracing::warn!("Error: {e}");
|
||||||
|
|
||||||
tracing::warn!(
|
tracing::warn!(
|
||||||
"Failed to parse config file at: {}",
|
"Failed to parse config file at: {}",
|
||||||
file.as_ref().to_string_lossy()
|
file.as_ref().to_string_lossy()
|
||||||
|
|
|
@ -48,7 +48,7 @@ buffer_size = 50_000_000
|
||||||
in_progress_queue_size = 50_000_000
|
in_progress_queue_size = 50_000_000
|
||||||
## The target size of a batch of blocks (bytes), must not exceed 100MB.
|
## The target size of a batch of blocks (bytes), must not exceed 100MB.
|
||||||
target_batch_size = 5_000_000
|
target_batch_size = 5_000_000
|
||||||
## The number of blocks in the first bacth (you probably shouldn't change this).
|
## The number of blocks in the first batch (you probably shouldn't change this).
|
||||||
initial_batch_len = 1
|
initial_batch_len = 1
|
||||||
## The amount of time between checking the pool of connected peers for free peers to download blocks.
|
## The amount of time between checking the pool of connected peers for free peers to download blocks.
|
||||||
check_client_pool_interval = {{ secs = 30, nanos = 0 }}
|
check_client_pool_interval = {{ secs = 30, nanos = 0 }}
|
||||||
|
|
|
@ -10,7 +10,7 @@ use crate::config::{default::create_default_config_file, Config, DEFAULT_CONFIG_
|
||||||
#[derive(clap::Parser, Debug)]
|
#[derive(clap::Parser, Debug)]
|
||||||
#[command(version, about)]
|
#[command(version, about)]
|
||||||
pub struct Args {
|
pub struct Args {
|
||||||
/// The network we should run on.
|
/// The network to run on.
|
||||||
#[arg(
|
#[arg(
|
||||||
long,
|
long,
|
||||||
default_value_t = Network::Mainnet,
|
default_value_t = Network::Mainnet,
|
||||||
|
@ -21,10 +21,10 @@ pub struct Args {
|
||||||
/// The amount of outbound clear-net connections to maintain.
|
/// The amount of outbound clear-net connections to maintain.
|
||||||
#[arg(long)]
|
#[arg(long)]
|
||||||
pub outbound_connections: Option<usize>,
|
pub outbound_connections: Option<usize>,
|
||||||
/// The location of the Cuprate config file.
|
/// The PATH of the `cuprated` config file.
|
||||||
#[arg(long)]
|
#[arg(long)]
|
||||||
pub config_file: Option<PathBuf>,
|
pub config_file: Option<PathBuf>,
|
||||||
/// Generate a config file and place it in the given folder.
|
/// Generate a config file and place it in the given PATH.
|
||||||
#[arg(long)]
|
#[arg(long)]
|
||||||
pub generate_config: Option<PathBuf>,
|
pub generate_config: Option<PathBuf>,
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,7 +51,7 @@ impl SharedNetConfig {
|
||||||
// HACK: we add the network here so we don't need to define another address book config.
|
// HACK: we add the network here so we don't need to define another address book config.
|
||||||
let mut address_book_config = self.address_book_config.clone();
|
let mut address_book_config = self.address_book_config.clone();
|
||||||
address_book_config
|
address_book_config
|
||||||
.peer_store_folder
|
.peer_store_directory
|
||||||
.push(network.to_string());
|
.push(network.to_string());
|
||||||
|
|
||||||
address_book_config
|
address_book_config
|
||||||
|
@ -104,7 +104,7 @@ pub fn clear_net_seed_nodes(network: Network) -> Vec<SocketAddr> {
|
||||||
|
|
||||||
seeds
|
seeds
|
||||||
.iter()
|
.iter()
|
||||||
.map(|&s| str::parse(s))
|
.map(|s| s.parse())
|
||||||
.collect::<Result<_, _>>()
|
.collect::<Result<_, _>>()
|
||||||
.unwrap()
|
.unwrap()
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,8 +42,8 @@ pub struct TxpoolConfig {
|
||||||
#[serde(flatten)]
|
#[serde(flatten)]
|
||||||
pub shared: SharedStorageConfig,
|
pub shared: SharedStorageConfig,
|
||||||
|
|
||||||
/// The maximum size of the tx-pool (bytes).
|
/// The maximum size of the tx-pool.
|
||||||
pub max_txpool_size: usize,
|
pub max_txpool_byte_size: usize,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for TxpoolConfig {
|
impl Default for TxpoolConfig {
|
||||||
|
|
|
@ -63,6 +63,9 @@ pub const CUPRATE_DIR: &str = {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// The default name of Cuprate's config file.
|
||||||
|
pub const DEFAULT_CONFIG_FILE_NAME: &str = "Cuprated.toml";
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------- Directories
|
//---------------------------------------------------------------------------------------------------- Directories
|
||||||
/// Create a `LazyLock` for common PATHs used by Cuprate.
|
/// Create a `LazyLock` for common PATHs used by Cuprate.
|
||||||
///
|
///
|
||||||
|
|
|
@ -15,7 +15,7 @@ fn test_cfg() -> AddressBookConfig {
|
||||||
AddressBookConfig {
|
AddressBookConfig {
|
||||||
max_white_list_length: 100,
|
max_white_list_length: 100,
|
||||||
max_gray_list_length: 500,
|
max_gray_list_length: 500,
|
||||||
peer_store_folder: PathBuf::new(),
|
peer_store_directory: PathBuf::new(),
|
||||||
peer_save_period: Duration::from_secs(60),
|
peer_save_period: Duration::from_secs(60),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,8 +31,8 @@ pub struct AddressBookConfig {
|
||||||
///
|
///
|
||||||
/// Gray peers are peers we are yet to make a connection to.
|
/// Gray peers are peers we are yet to make a connection to.
|
||||||
pub max_gray_list_length: usize,
|
pub max_gray_list_length: usize,
|
||||||
/// The location to store the peer store file.
|
/// The location to store the peer store files.
|
||||||
pub peer_store_folder: PathBuf,
|
pub peer_store_directory: PathBuf,
|
||||||
/// The amount of time between saving the address book to disk.
|
/// The amount of time between saving the address book to disk.
|
||||||
pub peer_save_period: Duration,
|
pub peer_save_period: Duration,
|
||||||
}
|
}
|
||||||
|
@ -43,7 +43,7 @@ impl Default for AddressBookConfig {
|
||||||
Self {
|
Self {
|
||||||
max_white_list_length: 1000,
|
max_white_list_length: 1000,
|
||||||
max_gray_list_length: 5000,
|
max_gray_list_length: 5000,
|
||||||
peer_store_folder: cuprate_helper::fs::CUPRATE_CACHE_DIR.clone(),
|
peer_store_directory: cuprate_helper::fs::CUPRATE_CACHE_DIR.clone(),
|
||||||
peer_save_period: Duration::from_secs(90),
|
peer_save_period: Duration::from_secs(90),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,7 +39,9 @@ pub(crate) fn save_peers_to_disk<Z: BorshNetworkZone>(
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
let file = cfg.peer_store_folder.join(format!("{}_p2p_state", Z::NAME));
|
let file = cfg
|
||||||
|
.peer_store_directory
|
||||||
|
.join(format!("{}_p2p_state", Z::NAME));
|
||||||
spawn_blocking(move || fs::write(&file, &data))
|
spawn_blocking(move || fs::write(&file, &data))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,7 +54,9 @@ pub(crate) async fn read_peers_from_disk<Z: BorshNetworkZone>(
|
||||||
),
|
),
|
||||||
std::io::Error,
|
std::io::Error,
|
||||||
> {
|
> {
|
||||||
let file = cfg.peer_store_folder.join(format!("{}_p2p_state", Z::NAME));
|
let file = cfg
|
||||||
|
.peer_store_directory
|
||||||
|
.join(format!("{}_p2p_state", Z::NAME));
|
||||||
|
|
||||||
tracing::info!("Loading peers from file: {} ", file.display());
|
tracing::info!("Loading peers from file: {} ", file.display());
|
||||||
|
|
||||||
|
|
|
@ -90,7 +90,7 @@ impl ConfigBuilder {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Change the network this blockchain database is for.
|
/// Change the network this database is for.
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub const fn network(mut self, network: Network) -> Self {
|
pub const fn network(mut self, network: Network) -> Self {
|
||||||
self.network = network;
|
self.network = network;
|
||||||
|
|
Loading…
Reference in a new issue