1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
use reqwest::{Request, Response};
use reqwest_middleware::{Middleware, Next};
use task_local_extensions::Extensions;

pub struct LoggingMiddleware;

#[async_trait::async_trait]
impl Middleware for LoggingMiddleware {
    async fn handle(
        &self,
        req: Request,
        extensions: &mut Extensions,
        next: Next<'_>,
    ) -> reqwest_middleware::Result<Response> {
        log::trace!("Request Started {:?}", req);
        let res = next.run(req, extensions).await;
        log::trace!("Result: {:?}", res);
        res
    }
}