Skip to content

Commit

Permalink
feat: [torrust#932] replace mode core config option with private
Browse files Browse the repository at this point in the history
…and `listed` flags

From:

```toml
[core]
mode = "public"
tracker_usage_statistics = true
inactive_peer_cleanup_interval = 600
```

To:

```toml
[core]
inactive_peer_cleanup_interval = 600
listed = false
private = false
tracker_usage_statistics = true
```
  • Loading branch information
josecelano committed Jul 1, 2024
1 parent f5d8dc6 commit 195d87e
Show file tree
Hide file tree
Showing 19 changed files with 108 additions and 185 deletions.
4 changes: 2 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -80,12 +80,12 @@ tower-http = { version = "0", features = ["compression-full", "cors", "propagate
trace = "0"
tracing = "0"
tracing-subscriber = { version = "0.3.18", features = ["json"] }
url = {version = "2", features = ["serde"] }
url = { version = "2", features = ["serde"] }
uuid = { version = "1", features = ["v4"] }
zerocopy = "0.7.33"

[package.metadata.cargo-machete]
ignored = ["crossbeam-skiplist", "dashmap", "figment", "parking_lot", "serde_bytes"]
ignored = ["crossbeam-skiplist", "dashmap", "figment", "parking_lot", "serde_bytes", "torrust-tracker-primitives"]

[dev-dependencies]
local-ip-address = "0"
Expand Down
14 changes: 2 additions & 12 deletions packages/configuration/src/v1/core.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
use serde::{Deserialize, Serialize};
use torrust_tracker_primitives::TrackerMode;

use super::network::Network;
use crate::v1::database::Database;
Expand All @@ -21,19 +20,15 @@ pub struct Core {
#[serde(default = "Core::default_inactive_peer_cleanup_interval")]
pub inactive_peer_cleanup_interval: u64,

// Whe `true` only approved torrents can be announced in the tracker.
// When `true` only approved torrents can be announced in the tracker.
#[serde(default = "Core::default_listed")]
pub listed: bool,

/// Tracker mode. See [`TrackerMode`] for more information.
#[serde(default = "Core::default_mode")]
pub mode: TrackerMode,

// Network configuration.
#[serde(default = "Core::default_network")]
pub net: Network,

// Whe `true` clients require a key to connect and use the tracker.
// When `true` clients require a key to connect and use the tracker.
#[serde(default = "Core::default_private")]
pub private: bool,

Expand All @@ -57,7 +52,6 @@ impl Default for Core {
database: Self::default_database(),
inactive_peer_cleanup_interval: Self::default_inactive_peer_cleanup_interval(),
listed: Self::default_listed(),
mode: Self::default_mode(),
net: Self::default_network(),
private: Self::default_private(),
tracker_policy: Self::default_tracker_policy(),
Expand All @@ -83,10 +77,6 @@ impl Core {
false
}

fn default_mode() -> TrackerMode {
TrackerMode::Public
}

fn default_network() -> Network {
Network::default()
}
Expand Down
26 changes: 13 additions & 13 deletions packages/configuration/src/v1/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -199,14 +199,10 @@
//! log_level = "info"
//!
//! [core]
//! mode = "public"
//! tracker_usage_statistics = true
//! inactive_peer_cleanup_interval = 600
//!
//! [core.tracker_policy]
//! max_peer_timeout = 900
//! persistent_torrent_completed_stat = false
//! remove_peerless_torrents = true
//! listed = false
//! private = false
//! tracker_usage_statistics = true
//!
//! [core.announce_policy]
//! interval = 120
Expand All @@ -220,6 +216,11 @@
//! external_ip = "0.0.0.0"
//! on_reverse_proxy = false
//!
//! [core.tracker_policy]
//! max_peer_timeout = 900
//! persistent_torrent_completed_stat = false
//! remove_peerless_torrents = true
//!
//! [http_api]
//! bind_address = "127.0.0.1:1212"
//!
Expand Down Expand Up @@ -365,17 +366,11 @@ mod tests {
log_level = "info"
[core]
mode = "public"
inactive_peer_cleanup_interval = 600
listed = false
private = false
tracker_usage_statistics = true
[core.tracker_policy]
max_peer_timeout = 900
persistent_torrent_completed_stat = false
remove_peerless_torrents = true
[core.announce_policy]
interval = 120
interval_min = 120
Expand All @@ -388,6 +383,11 @@ mod tests {
external_ip = "0.0.0.0"
on_reverse_proxy = false
[core.tracker_policy]
max_peer_timeout = 900
persistent_torrent_completed_stat = false
remove_peerless_torrents = true
[health_check_api]
bind_address = "127.0.0.1:1313"
"#
Expand Down
69 changes: 0 additions & 69 deletions packages/primitives/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,6 @@
//! by the tracker server crate, but also by other crates in the Torrust
//! ecosystem.
use std::collections::BTreeMap;
use std::fmt;
use std::str::FromStr;
use std::time::Duration;

use info_hash::InfoHash;
Expand Down Expand Up @@ -64,70 +62,3 @@ pub enum DatabaseDriver {
}

pub type PersistentTorrents = BTreeMap<InfoHash, u32>;

/// The mode the tracker will run in.
///
/// Refer to [Torrust Tracker Configuration](https://docs.rs/torrust-tracker-configuration)
/// to know how to configure the tracker to run in each mode.
#[derive(Serialize, Deserialize, Clone, PartialEq, Eq, Debug)]
pub enum TrackerMode {
/// Will track every new info hash and serve every peer.
#[serde(rename = "public")]
Public,

/// Will only track whitelisted info hashes.
#[serde(rename = "listed")]
Listed,

/// Will only serve authenticated peers
#[serde(rename = "private")]
Private,

/// Will only track whitelisted info hashes and serve authenticated peers
#[serde(rename = "private_listed")]
PrivateListed,
}

impl Default for TrackerMode {
fn default() -> Self {
Self::Public
}
}

impl fmt::Display for TrackerMode {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
let display_str = match self {
TrackerMode::Public => "public",
TrackerMode::Listed => "listed",
TrackerMode::Private => "private",
TrackerMode::PrivateListed => "private_listed",
};
write!(f, "{display_str}")
}
}

impl FromStr for TrackerMode {
type Err = String;

fn from_str(s: &str) -> Result<Self, Self::Err> {
match s.to_lowercase().as_str() {
"public" => Ok(TrackerMode::Public),
"listed" => Ok(TrackerMode::Listed),
"private" => Ok(TrackerMode::Private),
"private_listed" => Ok(TrackerMode::PrivateListed),
_ => Err(format!("Unknown tracker mode: {s}")),
}
}
}

impl TrackerMode {
#[must_use]
pub fn is_open(&self) -> bool {
matches!(self, TrackerMode::Public | TrackerMode::Listed)
}

#[must_use]
pub fn is_close(&self) -> bool {
!self.is_open()
}
}
18 changes: 9 additions & 9 deletions packages/test-helpers/src/configuration.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ use std::env;
use std::net::{IpAddr, Ipv4Addr, Ipv6Addr, SocketAddr};

use torrust_tracker_configuration::{Configuration, HttpApi, HttpTracker, LogLevel, UdpTracker};
use torrust_tracker_primitives::TrackerMode;

use crate::random;

Expand Down Expand Up @@ -86,40 +85,41 @@ pub fn ephemeral_without_reverse_proxy() -> Configuration {

/// Ephemeral configuration with `public` mode.
#[must_use]
pub fn ephemeral_mode_public() -> Configuration {
pub fn ephemeral_public() -> Configuration {
let mut cfg = ephemeral();

cfg.core.mode = TrackerMode::Public;
cfg.core.private = false;

cfg
}

/// Ephemeral configuration with `private` mode.
#[must_use]
pub fn ephemeral_mode_private() -> Configuration {
pub fn ephemeral_private() -> Configuration {
let mut cfg = ephemeral();

cfg.core.mode = TrackerMode::Private;
cfg.core.private = true;

cfg
}

/// Ephemeral configuration with `listed` mode.
#[must_use]
pub fn ephemeral_mode_whitelisted() -> Configuration {
pub fn ephemeral_listed() -> Configuration {
let mut cfg = ephemeral();

cfg.core.mode = TrackerMode::Listed;
cfg.core.listed = true;

cfg
}

/// Ephemeral configuration with `private_listed` mode.
#[must_use]
pub fn ephemeral_mode_private_whitelisted() -> Configuration {
pub fn ephemeral_private_and_listed() -> Configuration {
let mut cfg = ephemeral();

cfg.core.mode = TrackerMode::PrivateListed;
cfg.core.private = true;
cfg.core.listed = true;

cfg
}
Expand Down
6 changes: 3 additions & 3 deletions src/app.rs
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ pub async fn start(config: &Configuration, tracker: Arc<core::Tracker>) -> Vec<J
}

// Load whitelisted torrents
if tracker.is_whitelisted() {
if tracker.is_listed() {
tracker
.load_whitelist_from_database()
.await
Expand All @@ -64,8 +64,8 @@ pub async fn start(config: &Configuration, tracker: Arc<core::Tracker>) -> Vec<J
for udp_tracker_config in udp_trackers {
if tracker.is_private() {
warn!(
"Could not start UDP tracker on: {} while in {:?}. UDP is not safe for private trackers!",
udp_tracker_config.bind_address, config.core.mode
"Could not start UDP tracker on: {} while in private mode. UDP is not safe for private trackers!",
udp_tracker_config.bind_address
);
} else {
jobs.push(udp_tracker::start_job(udp_tracker_config, tracker.clone(), registar.give_form()).await);
Expand Down
4 changes: 2 additions & 2 deletions src/bootstrap/jobs/http_tracker.rs
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ async fn start_v1(
mod tests {
use std::sync::Arc;

use torrust_tracker_test_helpers::configuration::ephemeral_mode_public;
use torrust_tracker_test_helpers::configuration::ephemeral_public;

use crate::bootstrap::app::initialize_with_configuration;
use crate::bootstrap::jobs::http_tracker::start_job;
Expand All @@ -86,7 +86,7 @@ mod tests {

#[tokio::test]
async fn it_should_start_http_tracker() {
let cfg = Arc::new(ephemeral_mode_public());
let cfg = Arc::new(ephemeral_public());
let http_tracker = cfg.http_trackers.clone().expect("missing HTTP tracker configuration");
let config = &http_tracker[0];
let tracker = initialize_with_configuration(&cfg);
Expand Down
4 changes: 2 additions & 2 deletions src/bootstrap/jobs/tracker_apis.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ async fn start_v1(
mod tests {
use std::sync::Arc;

use torrust_tracker_test_helpers::configuration::ephemeral_mode_public;
use torrust_tracker_test_helpers::configuration::ephemeral_public;

use crate::bootstrap::app::initialize_with_configuration;
use crate::bootstrap::jobs::tracker_apis::start_job;
Expand All @@ -103,7 +103,7 @@ mod tests {

#[tokio::test]
async fn it_should_start_http_tracker() {
let cfg = Arc::new(ephemeral_mode_public());
let cfg = Arc::new(ephemeral_public());
let config = &cfg.http_api.clone().unwrap();
let tracker = initialize_with_configuration(&cfg);
let version = Version::V1;
Expand Down
Loading

0 comments on commit 195d87e

Please sign in to comment.