2024-06-13 02:15:51 +00:00
|
|
|
use std::sync::Arc;
|
|
|
|
|
|
|
|
|
|
use super::EnvFilter;
|
|
|
|
|
use crate::Server;
|
|
|
|
|
|
|
|
|
|
pub struct Suppress {
|
|
|
|
|
server: Arc<Server>,
|
|
|
|
|
restore: EnvFilter,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl Suppress {
|
|
|
|
|
pub fn new(server: &Arc<Server>) -> Self {
|
|
|
|
|
let config = &server.config.log;
|
|
|
|
|
Self::from_filters(server, EnvFilter::try_new(config).unwrap_or_default(), &EnvFilter::default())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn from_filters(server: &Arc<Server>, restore: EnvFilter, suppress: &EnvFilter) -> Self {
|
|
|
|
|
server
|
|
|
|
|
.log
|
|
|
|
|
.reload
|
2024-07-11 00:42:49 +00:00
|
|
|
.reload(suppress, Some(&["console"]))
|
2024-06-13 02:15:51 +00:00
|
|
|
.expect("log filter reloaded");
|
|
|
|
|
Self {
|
|
|
|
|
server: server.clone(),
|
|
|
|
|
restore,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl Drop for Suppress {
|
|
|
|
|
fn drop(&mut self) {
|
|
|
|
|
self.server
|
|
|
|
|
.log
|
|
|
|
|
.reload
|
2024-07-11 00:42:49 +00:00
|
|
|
.reload(&self.restore, Some(&["console"]))
|
2024-06-13 02:15:51 +00:00
|
|
|
.expect("log filter reloaded");
|
|
|
|
|
}
|
|
|
|
|
}
|