use anyhow::Result;
use config::{ConfigError, Environment};
use dotenv::dotenv;
use serde::Deserialize;
#[derive(Debug, Deserialize, Clone)]
pub struct Config {
    pub pg: deadpool_postgres::Config,
    #[serde(default)]
    pub use_tls: bool,
    pub db_ca_cert: String,
    pub db_client_cert: Option<String>,
    pub db_client_key: Option<String>,
    pub docker_port_grpc: u16,
    pub log_config: String,
}
impl Default for Config {
    fn default() -> Self {
        log::warn!("(default) Creating Config object with default values.");
        Self::new()
    }
}
impl Config {
    pub fn new() -> Self {
        Config {
            docker_port_grpc: 50051,
            log_config: String::from("log4rs.yaml"),
            pg: deadpool_postgres::Config::new(),
            use_tls: true,
            db_ca_cert: "".to_string(),
            db_client_cert: None,
            db_client_key: None,
        }
    }
    pub fn try_from_env() -> Result<Self, ConfigError> {
        dotenv().ok();
        let default_config = Config::default();
        config::Config::builder()
            .set_default("docker_port_grpc", default_config.docker_port_grpc)?
            .set_default("log_config", default_config.log_config)?
            .set_default("use_tls", default_config.use_tls)?
            .add_source(Environment::default().separator("__"))
            .build()?
            .try_deserialize()
    }
}
#[cfg(test)]
mod tests {
    use super::Config;
    #[tokio::test]
    async fn test_config_from_default() {
        crate::get_log_handle().await;
        ut_info!("(test_config_from_default) Start.");
        let config = Config::default();
        assert_eq!(config.docker_port_grpc, 50051);
        assert_eq!(config.log_config, String::from("log4rs.yaml"));
        assert_eq!(config.use_tls, true);
        ut_info!("(test_config_from_default) Success.");
    }
    #[tokio::test]
    async fn test_config_from_env() {
        crate::get_log_handle().await;
        ut_info!("(test_config_from_default) Start.");
        std::env::set_var("DOCKER_PORT_GRPC", "6789");
        std::env::set_var("LOG_CONFIG", "config_file.yaml");
        let config = Config::try_from_env();
        std::env::set_var("DOCKER_PORT_GRPC", "50051");
        std::env::set_var("LOG_CONFIG", "log4rs.yaml");
        assert!(config.is_ok());
        let config = config.unwrap();
        assert_eq!(config.docker_port_grpc, 6789);
        assert_eq!(config.log_config, String::from("config_file.yaml"));
        ut_info!("(test_config_from_env) Success.");
    }
}