mi/backend/src/rocket_trace.rs

35 lines
976 B
Rust
Raw Normal View History

2020-11-05 17:14:23 +00:00
use rocket::fairing::{Fairing, Info, Kind};
2020-11-05 22:52:32 +00:00
use rocket::http::Header;
2020-11-05 17:14:23 +00:00
use rocket::{Data, Request, Response};
use rusty_ulid::generate_ulid_string;
2020-11-05 22:52:32 +00:00
pub struct RequestId;
2020-11-05 17:14:23 +00:00
2020-11-05 22:52:32 +00:00
impl Fairing for RequestId {
2020-11-05 17:14:23 +00:00
fn info(&self) -> Info {
Info {
2020-11-05 22:52:32 +00:00
name: "Request ID",
2020-11-05 17:14:23 +00:00
kind: Kind::Request | Kind::Response,
}
}
fn on_request(&self, request: &mut Request, _: &Data) {
2020-11-05 22:52:32 +00:00
match request.headers().get_one("X-Request-Id") {
Some(_) => {}
2020-11-05 17:14:23 +00:00
None => {
let reqid = generate_ulid_string();
request.add_header(Header::new("X-Request-Id", reqid.clone()));
}
};
}
fn on_response(&self, request: &Request, response: &mut Response) {
match request.headers().get_one("X-Request-Id") {
Some(reqid) => {
response.set_header(Header::new("X-Request-Id", format!("{}", reqid)));
}
None => {}
};
}
}