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
//! This crate provides [`ClientWithMiddleware`], a wrapper around [`reqwest::Client`] with the //! ability to attach middleware which runs on every request. //! //! You'll want to instantiate [`ClientWithMiddleware`] using [`ClientBuilder`], then you can //! attach your middleware using [`with`], finalize it with [`build`] and from then on sending //! requests is the same as with reqwest: //! //! ``` //! use reqwest::{Client, Request, Response}; //! use reqwest_middleware::{ClientBuilder, Middleware, Next, Result}; //! use truelayer_extensions::Extensions; //! //! struct LoggingMiddleware; //! //! #[async_trait::async_trait] //! impl Middleware for LoggingMiddleware { //! async fn handle( //! &self, //! req: Request, //! extensions: &mut Extensions, //! next: Next<'_>, //! ) -> Result<Response> { //! println!("Request started {:?}", req); //! let res = next.run(req, extensions).await; //! println!("Result: {:?}", res); //! res //! } //! } //! //! async fn run() { //! let reqwest_client = Client::builder().build().unwrap(); //! let client = ClientBuilder::new(reqwest_client) //! .with(LoggingMiddleware) //! .build(); //! let resp = client.get("https://truelayer.com").send().await.unwrap(); //! println!("TrueLayer page HTML: {}", resp.text().await.unwrap()); //! } //! ``` //! //! [`build`]: struct.ClientBuilder.html#method.build //! [`ClientBuilder`]: struct.ClientBuilder.html //! [`ClientWithMiddleware`]: struct.ClientWithMiddleware.html //! [`reqwest::Client`]: https://docs.rs/reqwest/0.10.8/reqwest/struct.Client.html //! [`with`]: struct.ClientBuilder.html#method.with mod client; mod error; mod middleware; pub use client::{ClientBuilder, ClientWithMiddleware, RequestBuilder}; pub use error::{Error, Result}; pub use middleware::{Middleware, Next};