Crate tower_reqwest
source ·Expand description
§Overview
This library provides adapters to use reqwest client with the tower_http layers.
§Example
use http::{header::USER_AGENT, HeaderValue};
use http_body_util::BodyExt;
use serde_json::Value;
use tower::{ServiceBuilder, Service};
use tower_http::ServiceBuilderExt;
use tower_reqwest::HttpClientLayer;
#[tokio::main]
async fn main() -> anyhow::Result<()> {
let mut client = ServiceBuilder::new()
// Add some layers.
.override_request_header(USER_AGENT, HeaderValue::from_static("tower-reqwest"))
// Make client compatible with the `tower-http` layers.
.layer(HttpClientLayer)
.service(reqwest::Client::new());
// Execute request by using this service.
let response = client
.call(
http::request::Builder::new()
.method(http::Method::GET)
.uri("http://ip.jsontest.com")
.body(reqwest::Body::default())?,
)
.await?;
let bytes = response.into_body().collect().await?.to_bytes();
let value: Value = serde_json::from_slice(&bytes)?;
println!("{value:#?}");
Ok(())
}
Modules§
- When something went wrong.
Structs§
- Layer that creates
HttpClientService
from the inner service. - Adapter type to creating Tower HTTP services from the various clients.
Enums§
- This type represent all possible errors that can occurs during the request processing.
Functions§
- Converts an arbitrary body type into the
reqwest::Body
one.
Type Aliases§
- Alias for a Result with the error type
crate::Error
.