diff --git a/Cargo.lock b/Cargo.lock index ed598a4..c427963 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -558,7 +558,6 @@ dependencies = [ "futures", "indexmap", "rand", - "serde", "thiserror", "tokio", "tokio-util", @@ -850,7 +849,6 @@ dependencies = [ "rand", "rand_distr", "rayon", - "serde", "thiserror", "tokio", "tokio-stream", diff --git a/binaries/cuprated/src/config/Cuprated.toml b/Cuprated.toml similarity index 85% rename from binaries/cuprated/src/config/Cuprated.toml rename to Cuprated.toml index 7a62683..a044625 100644 --- a/binaries/cuprated/src/config/Cuprated.toml +++ b/Cuprated.toml @@ -27,7 +27,7 @@ gray_peers_percent = 0.7 ## The port to accept connections on, if left `0` no connections will be accepted. p2p_port = 0 ## The IP address to listen to connections on. -server.ip = "0.0.0.0" +listen_on = "0.0.0.0" ## The Clear-net addressbook config. [p2p.clear_net.address_book_config] @@ -35,10 +35,8 @@ server.ip = "0.0.0.0" max_white_list_length = 1_000 ## The size of the gray peer list, which contains peers we have not made a connection to before. max_gray_list_length = 5_000 -## The folder to store the address book. -peer_store_directory = {cache} ## The amount of time between address book saves. -peer_save_period = {{ secs = 90, nanos = 0 }} +peer_save_period = { secs = 90, nanos = 0 } ## The block downloader config. [p2p.block_downloader] @@ -48,10 +46,8 @@ buffer_size = 50_000_000 in_progress_queue_size = 50_000_000 ## The target size of a batch of blocks (bytes), must not exceed 100MB. target_batch_size = 5_000_000 -## The number of blocks in the first batch (you probably shouldn't change this). -initial_batch_len = 1 ## 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 } ## Storage config [storage] @@ -60,8 +56,6 @@ reader_threads = "OnePerThread" ## Txpool storage config. [storage.txpool] -## The txpool storage location. -path = {txpool} ## The database sync mode for the txpool. sync_mode = "Async" ## The maximum size of all the txs in the pool (bytes). @@ -69,7 +63,5 @@ max_txpool_byte_size = 100_000_000 ## Blockchain storage config. [storage.blockchain] -## The blockchain storage location. -path = {blockchain} ## The database sync mode for the blockchain. sync_mode = "Async" diff --git a/binaries/cuprated/Cargo.toml b/binaries/cuprated/Cargo.toml index cc288b4..af50acc 100644 --- a/binaries/cuprated/Cargo.toml +++ b/binaries/cuprated/Cargo.toml @@ -19,11 +19,11 @@ cuprate-epee-encoding = { workspace = true } cuprate-fixed-bytes = { workspace = true } cuprate-levin = { workspace = true } cuprate-wire = { workspace = true } -cuprate-p2p = { workspace = true, features = ["serde"] } +cuprate-p2p = { workspace = true } cuprate-p2p-core = { workspace = true, features = ["serde"] } cuprate-dandelion-tower = { workspace = true, features = ["txpool"] } cuprate-async-buffer = { workspace = true } -cuprate-address-book = { workspace = true, features = ["serde_config"] } +cuprate-address-book = { workspace = true } cuprate-blockchain = { workspace = true } cuprate-database-service = { workspace = true, features = ["serde"] } cuprate-txpool = { workspace = true } diff --git a/binaries/cuprated/src/config.rs b/binaries/cuprated/src/config.rs index 794b10b..6b1229f 100644 --- a/binaries/cuprated/src/config.rs +++ b/binaries/cuprated/src/config.rs @@ -15,14 +15,16 @@ use cuprate_helper::{ network::Network, }; use cuprate_p2p::block_downloader::BlockDownloaderConfig; -use cuprate_p2p_core::ClearNet; +use cuprate_p2p_core::{ClearNet, ClearNetServerCfg}; mod args; mod default; +mod fs; mod p2p; mod storage; mod tracing_config; +use crate::config::fs::FileSystemConfig; use p2p::P2PConfig; use storage::StorageConfig; use tracing_config::TracingConfig; @@ -43,6 +45,7 @@ pub fn read_config_and_args() -> Config { } else { // First attempt to read the config file from the current directory. std::env::current_dir() + .map(|path| path.join(DEFAULT_CONFIG_FILE_NAME)) .map_err(Into::into) .and_then(Config::read_from_path) .inspect_err(|e| tracing::debug!("Failed to read config from current dir: {e}")) @@ -53,7 +56,7 @@ pub fn read_config_and_args() -> Config { }) .inspect_err(|e| { tracing::debug!("Failed to read config from config dir: {e}"); - tracing::warn!("Failed to find/read config file, using default config."); + println!("Failed to find/read config file, using default config."); }) .unwrap_or_default() }; @@ -76,6 +79,8 @@ pub struct Config { /// The storage config. storage: StorageConfig, + + fs: FileSystemConfig, } impl Config { @@ -87,14 +92,15 @@ impl Config { fn read_from_path(file: impl AsRef) -> Result { let file_text = read_to_string(file.as_ref())?; - Ok(toml::from_str(&file_text).inspect_err(|e| { - tracing::warn!("Error: {e}"); - - tracing::warn!( - "Failed to parse config file at: {}", - file.as_ref().to_string_lossy() - ); - })?) + Ok(toml::from_str(&file_text) + .inspect(|_| println!("Using config at: {}", file.as_ref().to_string_lossy())) + .inspect_err(|e| { + println!("{e}"); + println!( + "Failed to parse config file at: {}", + file.as_ref().to_string_lossy() + ); + })?) } /// Returns the current [`Network`] we are running on. @@ -111,11 +117,17 @@ impl Config { extra_outbound_connections: self.p2p.clear_net.general.extra_outbound_connections, max_inbound_connections: self.p2p.clear_net.general.max_inbound_connections, gray_peers_percent: self.p2p.clear_net.general.gray_peers_percent, - server_config: Some(self.p2p.clear_net.server.clone()), + server_config: Some(ClearNetServerCfg { + ip: self.p2p.clear_net.listen_on, + }), p2p_port: self.p2p.clear_net.general.p2p_port, // TODO: set this if a public RPC server is set. rpc_port: 0, - address_book_config: self.p2p.clear_net.general.address_book_config(self.network), + address_book_config: self + .p2p + .clear_net + .general + .address_book_config(&self.fs.cache_directory, self.network), } } @@ -135,13 +147,13 @@ impl Config { // We don't set reader threads as we manually make the reader threadpool. cuprate_blockchain::config::ConfigBuilder::default() .network(self.network) - .db_directory(blockchain.shared.path.clone()) + .data_directory(self.fs.data_directory.clone()) .sync_mode(blockchain.shared.sync_mode) .build() } /// The [`BlockDownloaderConfig`]. - pub const fn block_downloader_config(&self) -> BlockDownloaderConfig { - self.p2p.block_downloader + pub fn block_downloader_config(&self) -> BlockDownloaderConfig { + self.p2p.block_downloader.clone().into() } } diff --git a/binaries/cuprated/src/config/default.rs b/binaries/cuprated/src/config/default.rs index 6b8bb57..8c9642b 100644 --- a/binaries/cuprated/src/config/default.rs +++ b/binaries/cuprated/src/config/default.rs @@ -4,9 +4,9 @@ use std::{ str::from_utf8, }; -use cuprate_helper::fs::{ - CUPRATE_BLOCKCHAIN_DIR, CUPRATE_CACHE_DIR, CUPRATE_TXPOOL_DIR, DEFAULT_CONFIG_FILE_NAME, -}; +use cuprate_helper::fs::{CUPRATE_CACHE_DIR, DEFAULT_CONFIG_FILE_NAME}; + +use crate::constants::EXAMPLE_CONFIG; /// Creates a config file which will be named [`DEFAULT_CONFIG_FILE_NAME`] in the directory given in [`Path`]. /// @@ -28,50 +28,17 @@ pub fn create_default_config_file(path: &Path) -> ! { } }; - let config = generate_config_text(); + let config = EXAMPLE_CONFIG; file.write_all(config.as_bytes()).unwrap(); std::process::exit(0); } -/// Generates the text of the default config file. -fn generate_config_text() -> String { - let toml_value_str = |t: &PathBuf| { - let mut value = String::new(); - - serde::Serialize::serialize(t, toml::ser::ValueSerializer::new(&mut value)).unwrap(); - - value - }; - - format!( - include_str!("Cuprated.toml"), - cache = toml_value_str(&CUPRATE_CACHE_DIR), - txpool = toml_value_str(&CUPRATE_TXPOOL_DIR), - blockchain = toml_value_str(&CUPRATE_BLOCKCHAIN_DIR) - ) -} - #[cfg(test)] mod tests { - use crate::config::{default::generate_config_text, Config}; - - #[test] - fn generate_config_text_covers_all_values() { - let text = generate_config_text(); - let table: toml::Table = toml::from_str(&text).unwrap(); - - let full_config = Config::default(); - let full_config_table: toml::Table = - toml::from_str(&toml::to_string(&full_config).unwrap()).unwrap(); - - assert_eq!(full_config_table, table); - } - + use crate::{config::Config, constants::EXAMPLE_CONFIG}; #[test] fn generate_config_text_is_valid() { - let text = generate_config_text(); - - let config: Config = toml::from_str(&text).unwrap(); + let config: Config = toml::from_str(EXAMPLE_CONFIG).unwrap(); } } diff --git a/binaries/cuprated/src/config/fs.rs b/binaries/cuprated/src/config/fs.rs new file mode 100644 index 0000000..f8f6130 --- /dev/null +++ b/binaries/cuprated/src/config/fs.rs @@ -0,0 +1,21 @@ +use std::path::PathBuf; + +use serde::{Deserialize, Serialize}; + +use cuprate_helper::fs::{CUPRATE_CACHE_DIR, CUPRATE_DATA_DIR}; + +#[derive(Deserialize, Serialize)] +#[serde(deny_unknown_fields, default)] +pub struct FileSystemConfig { + pub data_directory: PathBuf, + pub cache_directory: PathBuf, +} + +impl Default for FileSystemConfig { + fn default() -> Self { + Self { + data_directory: CUPRATE_DATA_DIR.to_path_buf(), + cache_directory: CUPRATE_CACHE_DIR.to_path_buf(), + } + } +} diff --git a/binaries/cuprated/src/config/p2p.rs b/binaries/cuprated/src/config/p2p.rs index abd667d..749355b 100644 --- a/binaries/cuprated/src/config/p2p.rs +++ b/binaries/cuprated/src/config/p2p.rs @@ -1,11 +1,9 @@ -use std::net::SocketAddr; - -use serde::{Deserialize, Serialize}; - -use cuprate_address_book::AddressBookConfig; +use cuprate_helper::fs::addressbook_path; use cuprate_helper::network::Network; -use cuprate_p2p::block_downloader::BlockDownloaderConfig; -use cuprate_p2p_core::ClearNetServerCfg; +use serde::{Deserialize, Serialize}; +use std::net::{IpAddr, Ipv4Addr, Ipv6Addr, SocketAddr}; +use std::path::Path; +use std::time::Duration; /// P2P config. #[derive(Default, Deserialize, Serialize)] @@ -17,16 +15,62 @@ pub struct P2PConfig { pub block_downloader: BlockDownloaderConfig, } +#[derive(Clone, Deserialize, Serialize)] +#[serde(deny_unknown_fields, default)] +pub struct BlockDownloaderConfig { + /// The size in bytes of the buffer between the block downloader and the place which + /// is consuming the downloaded blocks. + pub buffer_size: usize, + /// The size of the in progress queue (in bytes) at which we stop requesting more blocks. + pub in_progress_queue_size: usize, + /// The [`Duration`] between checking the client pool for free peers. + pub check_client_pool_interval: Duration, + /// The target size of a single batch of blocks (in bytes). + pub target_batch_size: usize, +} + +impl From for cuprate_p2p::block_downloader::BlockDownloaderConfig { + fn from(value: BlockDownloaderConfig) -> Self { + Self { + buffer_size: value.buffer_size, + in_progress_queue_size: value.in_progress_queue_size, + check_client_pool_interval: value.check_client_pool_interval, + target_batch_size: value.target_batch_size, + initial_batch_len: 1, + } + } +} + +impl Default for BlockDownloaderConfig { + fn default() -> Self { + Self { + buffer_size: 50_000_000, + in_progress_queue_size: 50_000_000, + check_client_pool_interval: Duration::from_secs(30), + target_batch_size: 5_000_000, + } + } +} + /// The config values for P2P clear-net. -#[derive(Default, Deserialize, Serialize)] +#[derive(Deserialize, Serialize)] #[serde(deny_unknown_fields, default)] pub struct ClearNetConfig { /// The server config. - pub server: ClearNetServerCfg, + pub listen_on: IpAddr, #[serde(flatten)] pub general: SharedNetConfig, } +impl Default for ClearNetConfig { + fn default() -> Self { + Self { + listen_on: IpAddr::V4(Ipv4Addr::UNSPECIFIED), + general: Default::default(), + } + } +} + /// Network config values shared between all network zones. #[derive(Deserialize, Serialize)] #[serde(deny_unknown_fields, default)] @@ -47,14 +91,17 @@ pub struct SharedNetConfig { impl SharedNetConfig { /// Returns the [`AddressBookConfig`]. - pub fn address_book_config(&self, network: Network) -> AddressBookConfig { - // 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(); - address_book_config - .peer_store_directory - .push(network.to_string()); - - address_book_config + pub fn address_book_config( + &self, + cache_dir: &Path, + network: Network, + ) -> cuprate_address_book::AddressBookConfig { + cuprate_address_book::AddressBookConfig { + max_white_list_length: self.address_book_config.max_white_list_length, + max_gray_list_length: self.address_book_config.max_gray_list_length, + peer_store_directory: addressbook_path(cache_dir, network), + peer_save_period: self.address_book_config.peer_save_period, + } } } @@ -71,6 +118,24 @@ impl Default for SharedNetConfig { } } +#[derive(Deserialize, Serialize)] +#[serde(deny_unknown_fields, default)] +pub struct AddressBookConfig { + max_white_list_length: usize, + max_gray_list_length: usize, + peer_save_period: Duration, +} + +impl Default for AddressBookConfig { + fn default() -> Self { + Self { + max_white_list_length: 1_000, + max_gray_list_length: 5_000, + peer_save_period: Duration::from_secs(30), + } + } +} + /// Seed nodes for [`ClearNet`](cuprate_p2p_core::ClearNet). pub fn clear_net_seed_nodes(network: Network) -> Vec { let seeds = match network { diff --git a/binaries/cuprated/src/config/storage.rs b/binaries/cuprated/src/config/storage.rs index 2023139..99b8e20 100644 --- a/binaries/cuprated/src/config/storage.rs +++ b/binaries/cuprated/src/config/storage.rs @@ -1,8 +1,9 @@ use serde::{Deserialize, Serialize}; +use std::path::PathBuf; use cuprate_database::config::SyncMode; use cuprate_database_service::ReaderThreads; -use cuprate_helper::fs::{CUPRATE_BLOCKCHAIN_DIR, CUPRATE_TXPOOL_DIR}; +use cuprate_helper::fs::CUPRATE_DATA_DIR; /// The storage config. #[derive(Default, Deserialize, Serialize)] @@ -28,7 +29,6 @@ impl Default for BlockchainConfig { fn default() -> Self { Self { shared: SharedStorageConfig { - path: CUPRATE_BLOCKCHAIN_DIR.to_path_buf(), sync_mode: SyncMode::Async, }, } @@ -50,7 +50,6 @@ impl Default for TxpoolConfig { fn default() -> Self { Self { shared: SharedStorageConfig { - path: CUPRATE_TXPOOL_DIR.to_path_buf(), sync_mode: SyncMode::Async, }, max_txpool_byte_size: 100_000_000, @@ -59,12 +58,9 @@ impl Default for TxpoolConfig { } /// Config values shared between the tx-pool and blockchain. -#[derive(Deserialize, Serialize)] -#[serde(deny_unknown_fields)] +#[derive(Default, Deserialize, Serialize)] +#[serde(deny_unknown_fields, default)] pub struct SharedStorageConfig { - /// The path to the database storage. - pub path: std::path::PathBuf, /// The [`SyncMode`] of the database. - #[serde(default)] pub sync_mode: SyncMode, } diff --git a/binaries/cuprated/src/constants.rs b/binaries/cuprated/src/constants.rs index 2f3c7bb..a42248b 100644 --- a/binaries/cuprated/src/constants.rs +++ b/binaries/cuprated/src/constants.rs @@ -18,6 +18,8 @@ pub const VERSION_BUILD: &str = if cfg!(debug_assertions) { pub const PANIC_CRITICAL_SERVICE_ERROR: &str = "A service critical to Cuprate's function returned an unexpected error."; +pub const EXAMPLE_CONFIG: &str = include_str!("../../../Cuprated.toml"); + #[cfg(test)] mod test { use super::*; diff --git a/helper/src/fs.rs b/helper/src/fs.rs index cebd0cc..60d61a3 100644 --- a/helper/src/fs.rs +++ b/helper/src/fs.rs @@ -158,37 +158,61 @@ impl_path_lazylock! { CUPRATE_DATA_DIR, data_dir, "", - - /// Cuprate's blockchain directory. - /// - /// This is the PATH used for any Cuprate blockchain files. - /// - /// | OS | PATH | - /// |---------|----------------------------------------------------------------| - /// | Windows | `C:\Users\Alice\AppData\Roaming\Cuprate\blockchain\` | - /// | macOS | `/Users/Alice/Library/Application Support/Cuprate/blockchain/` | - /// | Linux | `/home/alice/.local/share/cuprate/blockchain/` | - CUPRATE_BLOCKCHAIN_DIR, - data_dir, - "blockchain", - - /// Cuprate's transaction pool directory. - /// - /// This is the PATH used for any Cuprate txpool files. - /// - /// | OS | PATH | - /// |---------|------------------------------------------------------------| - /// | Windows | `C:\Users\Alice\AppData\Roaming\Cuprate\txpool\` | - /// | macOS | `/Users/Alice/Library/Application Support/Cuprate/txpool/` | - /// | Linux | `/home/alice/.local/share/cuprate/txpool/` | - CUPRATE_TXPOOL_DIR, - data_dir, - "txpool", } -/// Joins the [`Path`] with a folder for the given [`Network`]. -pub fn path_with_network(path: &Path, network: Network) -> PathBuf { - path.join(network.to_string()) +/// Joins the [`Network`] to the [`Path`]. +/// +/// This will keep the path the same for [`Network::Mainnet`]. +fn path_with_network(path: &Path, network: Network) -> PathBuf { + match network { + Network::Mainnet => path.to_path_buf(), + network => path.join(network.to_string()), + } +} + +/// Cuprate's blockchain directory. +/// +/// This is the PATH used for any Cuprate blockchain files. +/// +/// ```rust +/// use cuprate_helper::{network::Network, fs::{CUPRATE_DATA_DIR, blockchain_path}}; +/// +/// assert_eq!(blockchain_path(&**CUPRATE_DATA_DIR, Network::Mainnet).as_path(), CUPRATE_DATA_DIR.join("blockchain")); +/// assert_eq!(blockchain_path(&**CUPRATE_DATA_DIR, Network::Stagenet).as_path(), CUPRATE_DATA_DIR.join(Network::Stagenet.to_string()).join("blockchain")); +/// assert_eq!(blockchain_path(&**CUPRATE_DATA_DIR, Network::Testnet).as_path(), CUPRATE_DATA_DIR.join(Network::Testnet.to_string()).join("blockchain")); +/// ``` +pub fn blockchain_path(data_dir: &Path, network: Network) -> PathBuf { + path_with_network(data_dir, network).join("blockchain") +} + +/// Cuprate's txpool directory. +/// +/// This is the PATH used for any Cuprate txpool files. +/// +/// ```rust +/// use cuprate_helper::{network::Network, fs::{CUPRATE_DATA_DIR, txpool_path}}; +/// +/// assert_eq!(txpool_path(&**CUPRATE_DATA_DIR, Network::Mainnet).as_path(), CUPRATE_DATA_DIR.join("txpool")); +/// assert_eq!(txpool_path(&**CUPRATE_DATA_DIR, Network::Stagenet).as_path(), CUPRATE_DATA_DIR.join(Network::Stagenet.to_string()).join("txpool")); +/// assert_eq!(txpool_path(&**CUPRATE_DATA_DIR, Network::Testnet).as_path(), CUPRATE_DATA_DIR.join(Network::Testnet.to_string()).join("txpool")); +/// ``` +pub fn txpool_path(data_dir: &Path, network: Network) -> PathBuf { + path_with_network(data_dir, network).join("txpool") +} + +/// Cuprate's address-book directory. +/// +/// This is the PATH used for any Cuprate address-book files. +/// +/// ```rust +/// use cuprate_helper::{network::Network, fs::{CUPRATE_CACHE_DIR, addressbook_path}}; +/// +/// assert_eq!(addressbook_path(&**CUPRATE_CACHE_DIR, Network::Mainnet).as_path(), CUPRATE_CACHE_DIR.join("addressbook")); +/// assert_eq!(addressbook_path(&**CUPRATE_CACHE_DIR, Network::Stagenet).as_path(), CUPRATE_CACHE_DIR.join(Network::Stagenet.to_string()).join("addressbook")); +/// assert_eq!(addressbook_path(&**CUPRATE_CACHE_DIR, Network::Testnet).as_path(), CUPRATE_CACHE_DIR.join(Network::Testnet.to_string()).join("addressbook")); +/// ``` +pub fn addressbook_path(cache_dir: &Path, network: Network) -> PathBuf { + path_with_network(cache_dir, network).join("addressbook") } //---------------------------------------------------------------------------------------------------- Tests @@ -210,29 +234,21 @@ mod test { (&*CUPRATE_CACHE_DIR, ""), (&*CUPRATE_CONFIG_DIR, ""), (&*CUPRATE_DATA_DIR, ""), - (&*CUPRATE_BLOCKCHAIN_DIR, ""), - (&*CUPRATE_TXPOOL_DIR, ""), ]; if cfg!(target_os = "windows") { array[0].1 = r"AppData\Local\Cuprate"; array[1].1 = r"AppData\Roaming\Cuprate"; array[2].1 = r"AppData\Roaming\Cuprate"; - array[3].1 = r"AppData\Roaming\Cuprate\blockchain"; - array[4].1 = r"AppData\Roaming\Cuprate\txpool"; } else if cfg!(target_os = "macos") { array[0].1 = "Library/Caches/Cuprate"; array[1].1 = "Library/Application Support/Cuprate"; array[2].1 = "Library/Application Support/Cuprate"; - array[3].1 = "Library/Application Support/Cuprate/blockchain"; - array[4].1 = "Library/Application Support/Cuprate/txpool"; } else { // Assumes Linux. array[0].1 = ".cache/cuprate"; array[1].1 = ".config/cuprate"; array[2].1 = ".local/share/cuprate"; - array[3].1 = ".local/share/cuprate/blockchain"; - array[4].1 = ".local/share/cuprate/txpool"; }; for (path, expected) in array { diff --git a/p2p/address-book/Cargo.toml b/p2p/address-book/Cargo.toml index 18416e2..aa7e3c5 100644 --- a/p2p/address-book/Cargo.toml +++ b/p2p/address-book/Cargo.toml @@ -5,13 +5,10 @@ edition = "2021" license = "MIT" authors = ["Boog900"] -[features] -defualt = [] -serde_config = ["dep:serde", "dep:cuprate-helper"] [dependencies] cuprate-constants = { workspace = true } -cuprate-helper = { workspace = true, features = ["std", "fs"], optional = true } +cuprate-helper = { workspace = true, features = ["std"], optional = true } cuprate-pruning = { workspace = true } cuprate-p2p-core = { workspace = true, features = ["borsh"] } @@ -28,7 +25,6 @@ indexmap = { workspace = true, features = ["std"] } rand = { workspace = true, features = ["std", "std_rng"] } borsh = { workspace = true, features = ["derive", "std"] } -serde = { workspace = true, features = ["derive", "std"], optional = true } [dev-dependencies] cuprate-test-utils = { workspace = true } diff --git a/p2p/address-book/src/lib.rs b/p2p/address-book/src/lib.rs index 0422967..054be46 100644 --- a/p2p/address-book/src/lib.rs +++ b/p2p/address-book/src/lib.rs @@ -20,8 +20,6 @@ mod store; /// The address book config. #[derive(Debug, Clone)] -#[cfg_attr(feature = "serde_config", derive(serde::Deserialize, serde::Serialize))] -#[cfg_attr(feature = "serde_config", serde(deny_unknown_fields, default))] pub struct AddressBookConfig { /// The maximum number of white peers in the peer list. /// @@ -37,18 +35,6 @@ pub struct AddressBookConfig { pub peer_save_period: Duration, } -#[cfg(feature = "serde_config")] -impl Default for AddressBookConfig { - fn default() -> Self { - Self { - max_white_list_length: 1000, - max_gray_list_length: 5000, - peer_store_directory: cuprate_helper::fs::CUPRATE_CACHE_DIR.clone(), - peer_save_period: Duration::from_secs(90), - } - } -} - /// Possible errors when dealing with the address book. /// This is boxed when returning an error in the [`tower::Service`]. #[derive(Debug, thiserror::Error, Eq, PartialEq)] diff --git a/p2p/p2p/Cargo.toml b/p2p/p2p/Cargo.toml index feb4b3f..866fb91 100644 --- a/p2p/p2p/Cargo.toml +++ b/p2p/p2p/Cargo.toml @@ -34,8 +34,6 @@ rand_distr = { workspace = true, features = ["std"] } tracing = { workspace = true, features = ["std", "attributes"] } borsh = { workspace = true, features = ["derive", "std"] } -serde = { workspace = true, features = ["std", "derive"], optional = true } - [dev-dependencies] cuprate-test-utils = { workspace = true } indexmap = { workspace = true } diff --git a/p2p/p2p/src/block_downloader.rs b/p2p/p2p/src/block_downloader.rs index d5d7fcc..5ebcedc 100644 --- a/p2p/p2p/src/block_downloader.rs +++ b/p2p/p2p/src/block_downloader.rs @@ -59,8 +59,6 @@ pub struct BlockBatch { /// The block downloader config. #[derive(Debug, Copy, Clone, PartialOrd, PartialEq, Ord, Eq)] -#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))] -#[cfg_attr(feature = "serde", serde(deny_unknown_fields, default))] pub struct BlockDownloaderConfig { /// The size in bytes of the buffer between the block downloader and the place which /// is consuming the downloaded blocks. @@ -75,18 +73,6 @@ pub struct BlockDownloaderConfig { pub initial_batch_len: usize, } -impl Default for BlockDownloaderConfig { - fn default() -> Self { - Self { - buffer_size: 50_000_000, - in_progress_queue_size: 50_000_000, - check_client_pool_interval: Duration::from_secs(30), - target_batch_size: 5_000_000, - initial_batch_len: 1, - } - } -} - /// An error that occurred in the [`BlockDownloader`]. #[derive(Debug, thiserror::Error)] pub(crate) enum BlockDownloadError { diff --git a/storage/blockchain/README.md b/storage/blockchain/README.md index 3f97a3d..8ab8b43 100644 --- a/storage/blockchain/README.md +++ b/storage/blockchain/README.md @@ -76,7 +76,7 @@ use cuprate_blockchain::{ let tmp_dir = tempfile::tempdir()?; let db_dir = tmp_dir.path().to_owned(); let config = ConfigBuilder::new() - .db_directory(db_dir.into()) + .data_directory(db_dir.into()) .build(); // Initialize the database environment. diff --git a/storage/blockchain/src/config.rs b/storage/blockchain/src/config.rs index 2ae94c7..5578db8 100644 --- a/storage/blockchain/src/config.rs +++ b/storage/blockchain/src/config.rs @@ -25,7 +25,7 @@ //! //! let config = ConfigBuilder::new() //! // Use a custom database directory. -//! .db_directory(db_dir.into()) +//! .data_directory(db_dir.into()) //! // Use as many reader threads as possible (when using `service`). //! .reader_threads(ReaderThreads::OnePerThread) //! // Use the fastest sync mode. @@ -48,7 +48,7 @@ use serde::{Deserialize, Serialize}; use cuprate_database::{config::SyncMode, resize::ResizeAlgorithm}; use cuprate_helper::{ - fs::{path_with_network, CUPRATE_BLOCKCHAIN_DIR}, + fs::{blockchain_path, CUPRATE_DATA_DIR}, network::Network, }; @@ -64,8 +64,7 @@ pub use cuprate_database_service::ReaderThreads; pub struct ConfigBuilder { network: Network, - /// [`Config::db_directory`]. - db_directory: Option, + data_dir: Option, /// [`Config::cuprate_database_config`]. db_config: cuprate_database::config::ConfigBuilder, @@ -82,10 +81,10 @@ impl ConfigBuilder { pub fn new() -> Self { Self { network: Network::default(), - db_directory: None, - db_config: cuprate_database::config::ConfigBuilder::new(Cow::Owned(path_with_network( - &CUPRATE_BLOCKCHAIN_DIR, - Network::default(), + data_dir: None, + db_config: cuprate_database::config::ConfigBuilder::new(Cow::Owned(blockchain_path( + &CUPRATE_DATA_DIR, + Network::Mainnet, ))), reader_threads: None, } @@ -101,14 +100,14 @@ impl ConfigBuilder { pub fn build(self) -> Config { // INVARIANT: all PATH safety checks are done // in `helper::fs`. No need to do them here. - let db_directory = self - .db_directory - .unwrap_or_else(|| CUPRATE_BLOCKCHAIN_DIR.to_path_buf()); + let data_dir = self + .data_dir + .unwrap_or_else(|| CUPRATE_DATA_DIR.to_path_buf()); let reader_threads = self.reader_threads.unwrap_or_default(); let db_config = self .db_config - .db_directory(Cow::Owned(path_with_network(&db_directory, self.network))) + .db_directory(Cow::Owned(blockchain_path(&data_dir, self.network))) .reader_threads(reader_threads.as_threads()) .build(); @@ -127,8 +126,8 @@ impl ConfigBuilder { /// Set a custom database directory (and file) [`PathBuf`]. #[must_use] - pub fn db_directory(mut self, db_directory: PathBuf) -> Self { - self.db_directory = Some(db_directory); + pub fn data_directory(mut self, db_directory: PathBuf) -> Self { + self.data_dir = Some(db_directory); self } @@ -159,10 +158,7 @@ impl ConfigBuilder { /// Good default for testing, and resource-available machines. #[must_use] pub fn fast(mut self) -> Self { - self.db_config = cuprate_database::config::ConfigBuilder::new(Cow::Owned( - path_with_network(&CUPRATE_BLOCKCHAIN_DIR, self.network), - )) - .fast(); + self.db_config = self.db_config.fast(); self.reader_threads = Some(ReaderThreads::OnePerThread); self @@ -174,10 +170,7 @@ impl ConfigBuilder { /// Good default for resource-limited machines, e.g. a cheap VPS. #[must_use] pub fn low_power(mut self) -> Self { - self.db_config = cuprate_database::config::ConfigBuilder::new(Cow::Owned( - path_with_network(&CUPRATE_BLOCKCHAIN_DIR, self.network), - )) - .low_power(); + self.db_config = self.db_config.low_power(); self.reader_threads = Some(ReaderThreads::One); self @@ -188,9 +181,9 @@ impl Default for ConfigBuilder { fn default() -> Self { Self { network: Network::default(), - db_directory: Some(CUPRATE_BLOCKCHAIN_DIR.to_path_buf()), - db_config: cuprate_database::config::ConfigBuilder::new(Cow::Owned(path_with_network( - &CUPRATE_BLOCKCHAIN_DIR, + data_dir: Some(CUPRATE_DATA_DIR.to_path_buf()), + db_config: cuprate_database::config::ConfigBuilder::new(Cow::Owned(blockchain_path( + &CUPRATE_DATA_DIR, Network::default(), ))), reader_threads: Some(ReaderThreads::default()), @@ -238,8 +231,8 @@ impl Config { /// /// let config = Config::new(); /// - /// assert_eq!(config.db_config.db_directory().as_ref(), path_with_network(&CUPRATE_BLOCKCHAIN_DIR, Network::Mainnet).as_path()); - /// assert!(config.db_config.db_file().starts_with(&*CUPRATE_BLOCKCHAIN_DIR)); + /// assert_eq!(config.db_config.db_directory().as_ref(), blockchain_path(&CUPRATE_DATA_DIR, Network::Mainnet).as_path()); + /// assert!(config.db_config.db_file().starts_with(&*CUPRATE_DATA_DIR)); /// assert!(config.db_config.db_file().ends_with(DATABASE_DATA_FILENAME)); /// assert_eq!(config.db_config.sync_mode, SyncMode::default()); /// assert_eq!(config.db_config.resize_algorithm, ResizeAlgorithm::default()); diff --git a/storage/blockchain/src/ops/mod.rs b/storage/blockchain/src/ops/mod.rs index 285aa24..96b25af 100644 --- a/storage/blockchain/src/ops/mod.rs +++ b/storage/blockchain/src/ops/mod.rs @@ -71,7 +71,7 @@ //! let tmp_dir = tempfile::tempdir()?; //! let db_dir = tmp_dir.path().to_owned(); //! let config = ConfigBuilder::new() -//! .db_directory(db_dir.into()) +//! .data_directory(db_dir.into()) //! .build(); //! //! // Initialize the database environment. diff --git a/storage/blockchain/src/service/mod.rs b/storage/blockchain/src/service/mod.rs index c5eb80c..d6a811b 100644 --- a/storage/blockchain/src/service/mod.rs +++ b/storage/blockchain/src/service/mod.rs @@ -77,7 +77,7 @@ //! let tmp_dir = tempfile::tempdir()?; //! let db_dir = tmp_dir.path().to_owned(); //! let config = ConfigBuilder::new() -//! .db_directory(db_dir.into()) +//! .data_directory(db_dir.into()) //! .build(); //! //! // Initialize the database thread-pool. diff --git a/storage/blockchain/src/service/tests.rs b/storage/blockchain/src/service/tests.rs index e8a1842..38db665 100644 --- a/storage/blockchain/src/service/tests.rs +++ b/storage/blockchain/src/service/tests.rs @@ -45,7 +45,7 @@ fn init_service() -> ( ) { let tempdir = tempfile::tempdir().unwrap(); let config = ConfigBuilder::new() - .db_directory(tempdir.path().into()) + .data_directory(tempdir.path().into()) .low_power() .build(); let (reader, writer, env) = init(config).unwrap(); diff --git a/storage/blockchain/src/tests.rs b/storage/blockchain/src/tests.rs index 271a82c..4192f81 100644 --- a/storage/blockchain/src/tests.rs +++ b/storage/blockchain/src/tests.rs @@ -74,7 +74,7 @@ impl AssertTableLen { pub(crate) fn tmp_concrete_env() -> (impl Env, tempfile::TempDir) { let tempdir = tempfile::tempdir().unwrap(); let config = ConfigBuilder::new() - .db_directory(tempdir.path().into()) + .data_directory(tempdir.path().into()) .low_power() .build(); let env = crate::open(config).unwrap(); diff --git a/storage/txpool/src/config.rs b/storage/txpool/src/config.rs index 69b73aa..66864b1 100644 --- a/storage/txpool/src/config.rs +++ b/storage/txpool/src/config.rs @@ -10,7 +10,7 @@ use cuprate_database::{ }; use cuprate_database_service::ReaderThreads; use cuprate_helper::{ - fs::{path_with_network, CUPRATE_TXPOOL_DIR}, + fs::{txpool_path, CUPRATE_DATA_DIR}, network::Network, }; @@ -26,8 +26,7 @@ const DEFAULT_TXPOOL_WEIGHT_LIMIT: usize = 600 * 1024 * 1024; pub struct ConfigBuilder { network: Network, - /// [`Config::db_directory`]. - db_directory: Option, + data_dir: Option, /// [`Config::cuprate_database_config`]. db_config: cuprate_database::config::ConfigBuilder, @@ -47,10 +46,10 @@ impl ConfigBuilder { pub fn new() -> Self { Self { network: Network::default(), - db_directory: None, - db_config: cuprate_database::config::ConfigBuilder::new(Cow::Owned(path_with_network( - &CUPRATE_TXPOOL_DIR, - Network::default(), + data_dir: None, + db_config: cuprate_database::config::ConfigBuilder::new(Cow::Owned(txpool_path( + &CUPRATE_DATA_DIR, + Network::Mainnet, ))), reader_threads: None, max_txpool_weight: None, @@ -67,9 +66,9 @@ impl ConfigBuilder { pub fn build(self) -> Config { // INVARIANT: all PATH safety checks are done // in `helper::fs`. No need to do them here. - let db_directory = self - .db_directory - .unwrap_or_else(|| CUPRATE_TXPOOL_DIR.to_path_buf()); + let data_dir = self + .data_dir + .unwrap_or_else(|| CUPRATE_DATA_DIR.to_path_buf()); let reader_threads = self.reader_threads.unwrap_or_default(); @@ -79,7 +78,7 @@ impl ConfigBuilder { let db_config = self .db_config - .db_directory(Cow::Owned(path_with_network(&db_directory, self.network))) + .db_directory(Cow::Owned(txpool_path(&data_dir, self.network))) .reader_threads(reader_threads.as_threads()) .build(); @@ -104,10 +103,10 @@ impl ConfigBuilder { self } - /// Set a custom database directory (and file) [`PathBuf`]. + /// Set a custom data directory [`PathBuf`]. #[must_use] - pub fn db_directory(mut self, db_directory: PathBuf) -> Self { - self.db_directory = Some(db_directory); + pub fn data_directory(mut self, db_directory: PathBuf) -> Self { + self.data_dir = Some(db_directory); self } @@ -138,9 +137,7 @@ impl ConfigBuilder { /// Good default for testing, and resource-available machines. #[must_use] pub fn fast(mut self) -> Self { - self.db_config = - cuprate_database::config::ConfigBuilder::new(Cow::Borrowed(&*CUPRATE_TXPOOL_DIR)) - .fast(); + self.db_config = self.db_config.fast(); self.reader_threads = Some(ReaderThreads::OnePerThread); self @@ -152,9 +149,7 @@ impl ConfigBuilder { /// Good default for resource-limited machines, e.g. a cheap VPS. #[must_use] pub fn low_power(mut self) -> Self { - self.db_config = - cuprate_database::config::ConfigBuilder::new(Cow::Borrowed(&*CUPRATE_TXPOOL_DIR)) - .low_power(); + self.db_config = self.db_config.low_power(); self.reader_threads = Some(ReaderThreads::One); self @@ -165,10 +160,10 @@ impl Default for ConfigBuilder { fn default() -> Self { Self { network: Network::default(), - db_directory: Some(CUPRATE_TXPOOL_DIR.to_path_buf()), - db_config: cuprate_database::config::ConfigBuilder::new(Cow::Owned(path_with_network( - &CUPRATE_TXPOOL_DIR, - Network::default(), + data_dir: Some(CUPRATE_DATA_DIR.to_path_buf()), + db_config: cuprate_database::config::ConfigBuilder::new(Cow::Owned(txpool_path( + &CUPRATE_DATA_DIR, + Network::Mainnet, ))), reader_threads: Some(ReaderThreads::default()), max_txpool_weight: Some(DEFAULT_TXPOOL_WEIGHT_LIMIT), @@ -220,8 +215,8 @@ impl Config { /// /// let config = Config::new(); /// - /// assert_eq!(config.db_config.db_directory(), path_with_network(&CUPRATE_TXPOOL_DIR, Network::Mainnet).as_path()); - /// assert!(config.db_config.db_file().starts_with(&*CUPRATE_TXPOOL_DIR)); + /// assert_eq!(config.db_config.db_directory(), txpool_path(&CUPRATE_DATA_DIR, Network::Mainnet).as_path()); + /// assert!(config.db_config.db_file().starts_with(&*CUPRATE_DATA_DIR)); /// assert!(config.db_config.db_file().ends_with(DATABASE_DATA_FILENAME)); /// assert_eq!(config.db_config.sync_mode, SyncMode::default()); /// assert_eq!(config.db_config.resize_algorithm, ResizeAlgorithm::default());