0
0
mirror of https://github.com/neon-mmd/websurfx.git synced 2024-11-26 07:58:20 -05:00

Compare commits

..

2 Commits

Author SHA1 Message Date
Ilan Joselevich
c73b7bea77
Merge 0a0508de80 into 280c7e2b5e 2024-02-07 01:26:08 +02:00
Ilan Joselevich
0a0508de80
config: restructure and add json support 2024-02-07 01:18:11 +02:00
3 changed files with 29 additions and 34 deletions

View File

@ -4,7 +4,7 @@
use std::fs::File;
use std::io::BufReader;
use crate::config::{process_settings, Config};
use crate::config::{process_settings, set_logging_level, Config};
use crate::handler::{file_path, FileType};
impl Config {
@ -20,11 +20,7 @@ impl Config {
Ok(f) => f,
Err(_) => {
log::error!("Config Error: No config file found, falling back to defaults");
let conf = Self::default();
if !logging_initialized {
conf.set_logging_level();
}
return Ok(conf);
return Ok(Self::default());
}
};
@ -33,7 +29,7 @@ impl Config {
let mut conf: Config = serde_json::from_reader(reader)?;
if !logging_initialized {
conf.set_logging_level();
set_logging_level(conf.server.debug, conf.server.logging)
}
conf = process_settings(conf)?;

View File

@ -4,7 +4,7 @@ use std::fs;
use mlua::{Lua, LuaSerdeExt};
use crate::config::{process_settings, Config};
use crate::config::{process_settings, set_logging_level, Config};
use crate::handler::{file_path, FileType};
impl Config {
@ -21,11 +21,7 @@ impl Config {
Ok(f) => f,
Err(_) => {
log::error!("Config Error: No config file found, falling back to defaults");
let conf = Self::default();
if !logging_initialized {
conf.set_logging_level();
}
return Ok(conf);
return Ok(Self::default());
}
};
let val = lua.load(fs::read_to_string(config_file)?).eval()?;
@ -33,7 +29,7 @@ impl Config {
let mut conf: Config = lua.from_value(val)?;
if !logging_initialized {
conf.set_logging_level();
set_logging_level(conf.server.debug, conf.server.logging)
}
conf = process_settings(conf)?;

View File

@ -20,9 +20,13 @@ pub struct Config {
pub search: Search,
}
impl Config {
/// a helper function that sets the proper logging level
fn set_logging_level(&self) {
/// a helper function that sets the proper logging level
///
/// # Arguments
///
/// * `debug` - It takes the option to whether enable or disable debug mode.
/// * `logging` - It takes the option to whether enable or disable logs.
fn set_logging_level(debug: bool, logging: bool) {
if let Ok(pkg_env_var) = std::env::var("PKG_ENV") {
if pkg_env_var.to_lowercase() == "dev" {
env_logger::Builder::new()
@ -33,7 +37,7 @@ impl Config {
}
// Initializing logging middleware with level set to default or info.
let log_level = match (self.server.debug, self.server.logging) {
let log_level = match (debug, logging) {
(true, true) => LevelFilter::Debug,
(true, false) => LevelFilter::Debug,
(false, true) => LevelFilter::Info,
@ -41,7 +45,6 @@ impl Config {
};
env_logger::Builder::new().filter(None, log_level).init();
}
}
fn process_settings(mut conf: Config) -> Result<Config, Box<dyn std::error::Error>> {