mirror of
https://github.com/YGGverse/aquatic.git
synced 2026-03-31 17:55:36 +00:00
119 lines
3.5 KiB
Rust
119 lines
3.5 KiB
Rust
use std::{net::SocketAddr, path::PathBuf};
|
|
|
|
use aquatic_common::privileges::PrivilegeConfig;
|
|
use aquatic_toml_config::TomlConfig;
|
|
use serde::Deserialize;
|
|
|
|
use aquatic_common::cli::LogLevel;
|
|
|
|
/// aquatic_http_private configuration
|
|
#[derive(Clone, Debug, PartialEq, TomlConfig, Deserialize)]
|
|
#[serde(default, deny_unknown_fields)]
|
|
pub struct Config {
|
|
/// Socket workers receive requests from the socket, parse them and send
|
|
/// them on to the swarm workers. They then receive responses from the
|
|
/// swarm workers, encode them and send them back over the socket.
|
|
pub socket_workers: usize,
|
|
/// Swarm workers receive a number of requests from socket workers,
|
|
/// generate responses and send them back to the socket workers.
|
|
pub swarm_workers: usize,
|
|
pub worker_channel_size: usize,
|
|
/// Number of database connections to establish in each socket worker
|
|
pub db_connections_per_worker: u32,
|
|
pub log_level: LogLevel,
|
|
pub network: NetworkConfig,
|
|
pub protocol: ProtocolConfig,
|
|
pub cleaning: CleaningConfig,
|
|
pub privileges: PrivilegeConfig,
|
|
}
|
|
|
|
impl Default for Config {
|
|
fn default() -> Self {
|
|
Self {
|
|
socket_workers: 1,
|
|
swarm_workers: 1,
|
|
worker_channel_size: 128,
|
|
db_connections_per_worker: 4,
|
|
log_level: LogLevel::default(),
|
|
network: NetworkConfig::default(),
|
|
protocol: ProtocolConfig::default(),
|
|
cleaning: CleaningConfig::default(),
|
|
privileges: PrivilegeConfig::default(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl aquatic_common::cli::Config for Config {
|
|
fn get_log_level(&self) -> Option<LogLevel> {
|
|
Some(self.log_level)
|
|
}
|
|
}
|
|
|
|
#[derive(Clone, Debug, PartialEq, TomlConfig, Deserialize)]
|
|
#[serde(default, deny_unknown_fields)]
|
|
pub struct NetworkConfig {
|
|
/// Bind to this address
|
|
pub address: SocketAddr,
|
|
/// Path to TLS certificate (DER-encoded X.509)
|
|
pub tls_certificate_path: PathBuf,
|
|
/// Path to TLS private key (DER-encoded ASN.1 in PKCS#8 or PKCS#1 format)
|
|
pub tls_private_key_path: PathBuf,
|
|
pub keep_alive: bool,
|
|
}
|
|
|
|
impl Default for NetworkConfig {
|
|
fn default() -> Self {
|
|
Self {
|
|
address: SocketAddr::from(([0, 0, 0, 0], 3000)),
|
|
tls_certificate_path: "".into(),
|
|
tls_private_key_path: "".into(),
|
|
keep_alive: true,
|
|
}
|
|
}
|
|
}
|
|
|
|
#[derive(Clone, Debug, PartialEq, TomlConfig, Deserialize)]
|
|
#[serde(default, deny_unknown_fields)]
|
|
pub struct ProtocolConfig {
|
|
/// Maximum number of torrents to accept in scrape request
|
|
pub max_scrape_torrents: usize,
|
|
/// Maximum number of requested peers to accept in announce request
|
|
pub max_peers: usize,
|
|
/// Ask peers to announce this often (seconds)
|
|
pub peer_announce_interval: usize,
|
|
}
|
|
|
|
impl Default for ProtocolConfig {
|
|
fn default() -> Self {
|
|
Self {
|
|
max_scrape_torrents: 100,
|
|
max_peers: 50,
|
|
peer_announce_interval: 300,
|
|
}
|
|
}
|
|
}
|
|
|
|
#[derive(Clone, Debug, PartialEq, TomlConfig, Deserialize)]
|
|
#[serde(default, deny_unknown_fields)]
|
|
pub struct CleaningConfig {
|
|
/// Clean peers this often (seconds)
|
|
pub torrent_cleaning_interval: u64,
|
|
/// Remove peers that have not announced for this long (seconds)
|
|
pub max_peer_age: u32,
|
|
}
|
|
|
|
impl Default for CleaningConfig {
|
|
fn default() -> Self {
|
|
Self {
|
|
torrent_cleaning_interval: 30,
|
|
max_peer_age: 360,
|
|
}
|
|
}
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use super::Config;
|
|
|
|
::aquatic_toml_config::gen_serialize_deserialize_test!(Config);
|
|
}
|