#![crate_name = "dlog_rs"]
use dlog_core::transforms::Transforms;
use log::Level;
use crate::logger::DlogLogger;
mod logger;
pub fn configure(api_key: impl Into<String>) {
Builder::new()
.with_str_api_key(api_key)
.with_email_sanitizer()
.with_credit_card_sanitizer()
.build();
}
pub struct Builder {
api_key: Option<String>,
level: Option<Level>,
transforms: Transforms,
}
impl Builder {
pub fn new() -> Self {
Self {
api_key: None,
level: None,
transforms: Transforms::new(),
}
}
pub fn with_str_api_key(mut self, api_key: impl Into<String>) -> Self {
self.api_key = Some(api_key.into());
self
}
pub fn with_env_api_key(mut self, env_var: impl Into<String>) -> Self {
self.api_key = Some(std::env::var(env_var.into()).unwrap_or_default());
self
}
pub fn with_level(mut self, level: Level) -> Self {
self.level = Some(level);
self
}
pub fn with_email_sanitizer(mut self) -> Self {
self.transforms.add_email_sanitizer(true);
self
}
pub fn with_credit_card_sanitizer(mut self) -> Self {
self.transforms.add_credit_card_sanitizer(true);
self
}
pub fn build(self) {
let native = match dlog_core::Logger::new(self.api_key.unwrap_or_default(), self.transforms) {
Err(err) => panic!("[dlog] Failed to configure dlog: {}", err),
Ok(val) => val,
};
let level = self.level.unwrap_or(Level::Debug);
log::set_max_level(level.to_level_filter());
let logger = DlogLogger::new(native, level);
if let Err(err) = log::set_boxed_logger(Box::new(logger)) {
panic!("{}", err)
}
}
}
impl Default for Builder {
fn default() -> Self {
Self::new()
}
}