ae8b64941e
OpenSMTPD plans to gather all logs from filters. Therefore, a default logger that implements the smtpd (future) log interface has to be available.
18 lines
435 B
Rust
18 lines
435 B
Rust
use log::{info, Level};
|
|
use opensmtpd::{event, handlers, Entry, SmtpIn, SmtpdLogger};
|
|
|
|
#[derive(Clone, Default)]
|
|
struct MyContext {
|
|
nb: usize,
|
|
}
|
|
|
|
#[event(Any)]
|
|
fn on_event(ctx: &mut MyContext, entry: &Entry) {
|
|
ctx.nb += 1;
|
|
info!("Event received: {}, {}", entry.session_id, ctx.nb);
|
|
}
|
|
|
|
fn main() {
|
|
let _ = SmtpdLogger::new().set_level(Level::Debug).init();
|
|
SmtpIn::new().event_handlers(handlers!(on_event)).run();
|
|
}
|