2023-09-29 12:15:07 +02:00
|
|
|
/*
|
|
|
|
env.rs - The environment loader. It loads all the .env config to a convenient `Env` struct.
|
|
|
|
This file provides the `loadenv` function that will do just that.
|
|
|
|
*/
|
|
|
|
|
2023-09-29 12:57:53 +02:00
|
|
|
use std::{env::var, net::SocketAddr};
|
2023-09-29 12:15:07 +02:00
|
|
|
|
2023-10-01 02:14:35 +02:00
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
pub struct Redis {
|
|
|
|
pub pass: String,
|
|
|
|
pub host: String,
|
|
|
|
pub port: u16,
|
|
|
|
pub prefix: String
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
2023-09-29 12:15:07 +02:00
|
|
|
pub struct Env {
|
2023-09-29 12:57:53 +02:00
|
|
|
pub logging: bool,
|
2023-10-01 02:14:35 +02:00
|
|
|
pub listen: SocketAddr,
|
|
|
|
pub redis: Redis,
|
2023-09-29 12:15:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn get_var<T: Into<String>, O: From<String>>(name: T) -> Result<O, String> {
|
|
|
|
let name: String = name.into();
|
|
|
|
let v = var(name.clone());
|
|
|
|
if v.is_err() {
|
|
|
|
return Err(format!("Variable {name} does not exist!"));
|
|
|
|
}
|
|
|
|
return Ok(v.unwrap().into())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn loadenv() -> Result<Env, Box<dyn std::error::Error>> {
|
|
|
|
Ok(
|
|
|
|
Env {
|
|
|
|
logging: get_var::<&str, String>("APP_LOGGING")?.to_lowercase() == "true",
|
2023-10-01 02:14:35 +02:00
|
|
|
listen: get_var::<&str, String>("APP_HOST")?.parse::<SocketAddr>().unwrap(),
|
|
|
|
redis: Redis {
|
|
|
|
pass: get_var("REDIS_PASS")?,
|
|
|
|
host: get_var("REDIS_HOST")?,
|
|
|
|
port: get_var::<&str, String>("REDIS_PORT")?.parse().unwrap(),
|
|
|
|
prefix: get_var("REDIS_PREFIX")?
|
|
|
|
}
|
2023-09-29 12:15:07 +02:00
|
|
|
}
|
|
|
|
)
|
|
|
|
}
|