diff options
Diffstat (limited to 'src/config.rs')
| -rw-r--r-- | src/config.rs | 30 |
1 files changed, 19 insertions, 11 deletions
diff --git a/src/config.rs b/src/config.rs index b86d018..2898c81 100644 --- a/src/config.rs +++ b/src/config.rs @@ -12,30 +12,38 @@ pub struct Configuration { pub database_url: String, pub jwt_secret: String, pub allowed_host: String, - pub sentry_dsn: Option<String>, } +pub struct Sentry(pub ClientInitGuard); + impl Configuration { pub fn new() -> Result<Self, ConfigError> { let mut cfg = config::Config::new(); cfg.merge(config::Environment::default())?; cfg.try_into() } +} + +impl Sentry { + pub fn new() -> Result<Self, std::env::VarError> { + match std::env::var("SENTRY_DSN") { + Ok(dsn) => { + let guard = sentry::init(( + dsn.clone(), + sentry::ClientOptions { + release: sentry::release_name!(), + ..Default::default() + }, + )); - pub fn set_sentry_guard(&self) -> Option<ClientInitGuard> { - match &self.sentry_dsn { - Some(dsn) => Some(sentry::init(( - dsn.clone(), - sentry::ClientOptions { - release: sentry::release_name!(), - ..Default::default() - }, - ))), - None => None, + Ok(Self(guard)) + } + Err(e) => Err(e), } } } lazy_static! { pub static ref CONFIG: Configuration = Configuration::new().expect("Config can be loaded"); + pub static ref SENTRY: Sentry = Sentry::new().expect("Sentry not configured."); } |
