use std::sync::Arc;
use torrust_tracker_clock::static_time;
use torrust_tracker_configuration::validator::Validator;
use torrust_tracker_configuration::Configuration;
use tracing::instrument;
use super::config::initialize_configuration;
use crate::bootstrap;
use crate::core::services::tracker_factory;
use crate::core::Tracker;
use crate::shared::crypto::ephemeral_instance_keys;
#[must_use]
#[instrument(skip())]
pub fn setup() -> (Configuration, Arc<Tracker>) {
let configuration = initialize_configuration();
if let Err(e) = configuration.validate() {
panic!("Configuration error: {e}");
}
let tracker = initialize_with_configuration(&configuration);
tracing::info!("Configuration:\n{}", configuration.clone().mask_secrets().to_json());
(configuration, tracker)
}
#[must_use]
#[instrument(skip())]
pub fn initialize_with_configuration(configuration: &Configuration) -> Arc<Tracker> {
initialize_static();
initialize_logging(configuration);
Arc::new(initialize_tracker(configuration))
}
#[instrument(skip())]
pub fn initialize_static() {
lazy_static::initialize(&static_time::TIME_AT_APP_START);
lazy_static::initialize(&ephemeral_instance_keys::RANDOM_SEED);
}
#[must_use]
#[instrument(skip(config))]
pub fn initialize_tracker(config: &Configuration) -> Tracker {
tracker_factory(config)
}
#[instrument(skip(config))]
pub fn initialize_logging(config: &Configuration) {
bootstrap::logging::setup(config);
}