From 600ba8c3f17a64f2c5de2835d10212deb2f460f4 Mon Sep 17 00:00:00 2001 From: Divma <26765164+divagant-martian@users.noreply.github.com> Date: Fri, 21 Jun 2024 10:05:03 -0500 Subject: [PATCH] feat(iroh): allow setting the logging directory via config file (#2391) ## Description Adds the options to set the directory where logs will be created in the config file. **Example:** ```toml [file_logs] rust_log = "iroh=info" rotation = "daily" max_files = 1 dir = "/home/me/my_logs" ``` It is recommended that the path is absolute, otherwise it will be interpreted as relative _to the execution dir_. If this option is not set, the default `/logs` will be used. ## Breaking Changes N/a ## Notes & open questions N/a ## Change checklist - [ ] Self-review. - [ ] Documentation updates if relevant. - [ ] Tests if relevant. - [ ] All breaking changes documented. --- iroh-cli/src/logging.rs | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/iroh-cli/src/logging.rs b/iroh-cli/src/logging.rs index 620c70a5d2..2f2539174c 100644 --- a/iroh-cli/src/logging.rs +++ b/iroh-cli/src/logging.rs @@ -20,7 +20,8 @@ pub(crate) const DEFAULT_FILE_RUST_LOG: &str = "rustyline=warn,debug"; /// - use the default [`fmt::format::Format`] save for: /// - including line numbers. /// - not using ansi colors. -/// - create log files in the `logs` dir inside the given `iroh_data_root`. +/// - create log files in the [`FileLogging::dir`] directory. If not provided, the `logs` dir +/// inside the given `iroh_data_root` is used. /// - rotate files every [`Self::rotation`]. /// - keep at most [`Self::max_files`] log files. /// - use the filtering defined by [`Self::rust_log`]. When not provided, the default @@ -38,6 +39,7 @@ pub(crate) fn init_terminal_and_file_logging( rust_log, max_files, rotation, + dir, } = file_log_config; let filter = rust_log.layer(); @@ -51,7 +53,9 @@ pub(crate) fn init_terminal_and_file_logging( Rotation::Daily => rolling::Rotation::DAILY, Rotation::Never => rolling::Rotation::NEVER, }; - let logs_path = logs_dir.join("logs"); + + // prefer the directory set in the config file over the default + let logs_path = dir.clone().unwrap_or_else(|| logs_dir.join("logs")); let file_appender = rolling::Builder::new() .rotation(rotation) @@ -102,6 +106,8 @@ pub(crate) struct FileLogging { pub(crate) max_files: usize, /// How often should a new log file be produced. pub(crate) rotation: Rotation, + /// Where to store log files. + pub(crate) dir: Option, } impl Default for FileLogging { @@ -110,6 +116,7 @@ impl Default for FileLogging { rust_log: EnvFilter::default(), max_files: 4, rotation: Rotation::default(), + dir: None, } } }