use crate::log_safe_channel::*; use crate::settings::*; use simplelog::*; use std::fs::OpenOptions; use std::path::Path; pub struct VeilidLogs { pub client_log_channel: Option, pub client_log_channel_closer: Option, } impl VeilidLogs { pub fn setup_normal_logs(settings: Settings) -> Result { let settingsr = settings.read(); // Set up loggers let mut logs: Vec> = Vec::new(); let mut client_log_channel: Option = None; let mut client_log_channel_closer: Option = None; let mut cb = ConfigBuilder::new(); for ig in veilid_core::DEFAULT_LOG_IGNORE_LIST { cb.add_filter_ignore_str(ig); } if settingsr.logging.terminal.enabled { logs.push(TermLogger::new( convert_loglevel(settingsr.logging.terminal.level), cb.build(), TerminalMode::Mixed, ColorChoice::Auto, )) } if settingsr.logging.file.enabled { let log_path = Path::new(&settingsr.logging.file.path); let logfile = if settingsr.logging.file.append { OpenOptions::new() .create(true) .append(true) .open(log_path) .map_err(|e| format!("failed to open log file: {}", e))? } else { OpenOptions::new() .create(true) .truncate(true) .write(true) .open(log_path) .map_err(|e| format!("failed to open log file: {}", e))? }; logs.push(WriteLogger::new( convert_loglevel(settingsr.logging.file.level), cb.build(), logfile, )) } if settingsr.logging.client.enabled { let (clog, clogwriter, clogcloser) = LogSafeChannel::new(); client_log_channel = Some(clog); client_log_channel_closer = Some(clogcloser); logs.push(WriteLogger::new( convert_loglevel(settingsr.logging.client.level), cb.build(), clogwriter, )) } CombinedLogger::init(logs).map_err(|e| format!("failed to init logs: {}", e))?; Ok(VeilidLogs { client_log_channel, client_log_channel_closer, }) } }