1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
use log::{LogLevelFilter, LogRecord};
use std::error::Error;
use serde_value::Value;
use file::{Deserialize, Deserializers};
use filter::{Filter, Response};
use filter::threshold::serde::ThresholdFilterConfig;
mod serde;
#[derive(Debug)]
pub struct ThresholdFilter {
level: LogLevelFilter,
}
impl ThresholdFilter {
pub fn new(level: LogLevelFilter) -> ThresholdFilter {
ThresholdFilter { level: level }
}
}
impl Filter for ThresholdFilter {
fn filter(&self, record: &LogRecord) -> Response {
if record.level() > self.level {
Response::Reject
} else {
Response::Neutral
}
}
}
pub struct ThresholdFilterDeserializer;
impl Deserialize for ThresholdFilterDeserializer {
type Trait = Filter;
fn deserialize(&self, config: Value, _: &Deserializers) -> Result<Box<Filter>, Box<Error>> {
let config = try!(config.deserialize_into::<ThresholdFilterConfig>());
Ok(Box::new(ThresholdFilter::new(config.level.0)))
}
}