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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#![deny(warnings, missing_debug_implementations, missing_copy_implementations, missing_docs)]
extern crate time;
#[macro_use]
extern crate serde_json;
extern crate libc;
mod backend;
mod macros;
pub mod logger;
use std::fmt::{self, Display};
use std::env;
use backend::{Fused, CeeSyslog, Stdout};
#[derive(Clone, Copy, Debug, PartialEq, PartialOrd)]
pub enum Level {
Panic,
Fatal,
Error,
Warn,
Info,
Debug,
}
impl Display for Level {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self {
&Level::Debug => write!(f, "debug"),
&Level::Info => write!(f, "info"),
&Level::Warn => write!(f, "warning"),
&Level::Error => write!(f, "error"),
&Level::Fatal => write!(f, "fatal"),
&Level::Panic => write!(f, "panic"),
}
}
}
pub fn default(level: Level) -> logger::KvsLogger<Fused<CeeSyslog, Stdout>> {
let app_name = match env::var("SYSLOG_PROGRAM") {
Ok(name) => name,
Err(_) => env::args().next().unwrap().split("/").last().unwrap().into(),
};
let target = match env::var("SYSLOG_SOCKET") {
Ok(val) => val,
Err(_) => default_syslog_socket(),
};
let cee = CeeSyslog::new(target);
let stdout = Stdout::new();
let backend = backend::Fused::new(cee, stdout);
logger::KvsLogger::new(
app_name,
level,
backend
)
}
#[cfg(target_os = "macos")]
fn default_syslog_socket() -> String {
"/var/run/syslog".into()
}
#[cfg(target_os = "linux")]
fn default_syslog_socket() -> String {
"/dev/log".into()
}