setting up env vars + comaping with preboot values

pull/21/head
prplV 2025-01-15 16:25:53 +03:00
parent eed9fa881a
commit 0112066418
1 changed files with 31 additions and 11 deletions

View File

@ -3,6 +3,7 @@
use anyhow::{Result, Ok, Error}; use anyhow::{Result, Ok, Error};
use clap::Parser; use clap::Parser;
use std::path::PathBuf; use std::path::PathBuf;
use std::env::{var, vars};
const SOCKET_PATH: &str = "/var/run/enode/hostagent.sock"; const SOCKET_PATH: &str = "/var/run/enode/hostagent.sock";
@ -38,13 +39,7 @@ impl std::fmt::Display for EnvVars {
} }
} }
// impl<'a> Default for EnvVars { ///
// fn default() -> &'a str {
// todo!()
// // setting default env vars values if not exists
// }
// }
impl<'a> EnvVars { impl<'a> EnvVars {
// Default trait func is not satisfying this issue // Default trait func is not satisfying this issue
fn default(self) -> &'a str { fn default(self) -> &'a str {
@ -58,14 +53,38 @@ impl<'a> EnvVars {
EnvVars::NoxisLogTo => "./", EnvVars::NoxisLogTo => "./",
EnvVars::NoxisRemoteServerUrl => "localhost", EnvVars::NoxisRemoteServerUrl => "localhost",
EnvVars::NoxisConfig => "./settings.json", EnvVars::NoxisConfig => "./settings.json",
EnvVars::NoxisMetrics => "NOXIS_METRICS", EnvVars::NoxisMetrics => "full",
} }
} }
fn setup() { fn process_env_var(self, preboot_value: &str) {
// let default = self.default();
match var(self.to_string()) {
std::result::Result::Ok(val) => {
if val != preboot_value {
std::env::set_var(self.to_string(), self.default());
}
},
Err(_) => {
std::env::set_var(self.to_string(), preboot_value);
println!("{:?}", vars());
},
}
}
pub fn setup(preboot: &PrebootParams) {
// setup default if not exists // setup default if not exists
// check values and save preboot states in env vars if not equal // check values and save preboot states in env vars if not equal
todo!()
Self::NoxisNoHagent.process_env_var(&preboot.no_hostagent.to_string());
Self::NoxisNoLogs.process_env_var(&preboot.no_logs.to_string());
Self::NoxisRefreshLogs.process_env_var(&preboot.refresh_logs.to_string());
Self::NoxisNoRemoteConfig.process_env_var(&preboot.no_remote_config.to_string());
Self::NoxisNoConfigSub.process_env_var(&preboot.no_sub.to_string());
Self::NoxisSocketPath.process_env_var(preboot.socket_path.to_str().unwrap());
Self::NoxisLogTo.process_env_var(preboot.log_to.to_str().unwrap());
Self::NoxisRemoteServerUrl.process_env_var(&preboot.remote_server_url);
Self::NoxisConfig.process_env_var(preboot.config.to_str().unwrap());
Self::NoxisMetrics.process_env_var(&preboot.metrics.to_string());
} }
} }
@ -282,6 +301,7 @@ impl PrebootParams {
// return Err(Error::msg("Local Config Not Found or Noxis can't read it. Cannot start")); // return Err(Error::msg("Local Config Not Found or Noxis can't read it. Cannot start"));
} }
// redis server check // redis server check
EnvVars::setup(&self);
Ok(self) Ok(self)
} }
} }