Trait axum::RequestExt 
source · pub trait RequestExt<B>: Sized + Sealed<B> {
    // Required methods
    fn extract<E, M>(
        self
    ) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequest<(), B, M>>::Rejection>> + Send>>
       where E: FromRequest<(), B, M> + 'static,
             M: 'static;
    fn extract_with_state<E, S, M>(
        self,
        state: &S
    ) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequest<S, B, M>>::Rejection>> + Send + '_>>
       where E: FromRequest<S, B, M> + 'static,
             S: Send + Sync;
    fn extract_parts<E>(
        &mut self
    ) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequestParts<()>>::Rejection>> + Send + '_>>
       where E: FromRequestParts<()> + 'static;
    fn extract_parts_with_state<'a, E, S>(
        &'a mut self,
        state: &'a S
    ) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequestParts<S>>::Rejection>> + Send + 'a>>
       where E: FromRequestParts<S> + 'static,
             S: Send + Sync;
    fn with_limited_body(self) -> Result<Request<Limited<B>>, Request<B>>;
    fn into_limited_body(self) -> Result<Limited<B>, B>;
}Expand description
Extension trait that adds additional methods to Request.
Required Methods§
sourcefn extract<E, M>(
    self
) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequest<(), B, M>>::Rejection>> + Send>>where
    E: FromRequest<(), B, M> + 'static,
    M: 'static,
 
fn extract<E, M>(
    self
) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequest<(), B, M>>::Rejection>> + Send>>where
    E: FromRequest<(), B, M> + 'static,
    M: 'static,
Apply an extractor to this Request.
This is just a convenience for E::from_request(req, &()).
Note this consumes the request. Use RequestExt::extract_parts if you’re not extracting
the body and don’t want to consume the request.
§Example
use axum::{
    async_trait,
    extract::FromRequest,
    http::{header::CONTENT_TYPE, Request, StatusCode},
    response::{IntoResponse, Response},
    Form, Json, RequestExt,
};
struct FormOrJson<T>(T);
#[async_trait]
impl<S, B, T> FromRequest<S, B> for FormOrJson<T>
where
    Json<T>: FromRequest<(), B>,
    Form<T>: FromRequest<(), B>,
    T: 'static,
    B: Send + 'static,
    S: Send + Sync,
{
    type Rejection = Response;
    async fn from_request(req: Request<B>, _state: &S) -> Result<Self, Self::Rejection> {
        let content_type = req
            .headers()
            .get(CONTENT_TYPE)
            .and_then(|value| value.to_str().ok())
            .ok_or_else(|| StatusCode::BAD_REQUEST.into_response())?;
        if content_type.starts_with("application/json") {
            let Json(payload) = req
                .extract::<Json<T>, _>()
                .await
                .map_err(|err| err.into_response())?;
            Ok(Self(payload))
        } else if content_type.starts_with("application/x-www-form-urlencoded") {
            let Form(payload) = req
                .extract::<Form<T>, _>()
                .await
                .map_err(|err| err.into_response())?;
            Ok(Self(payload))
        } else {
            Err(StatusCode::BAD_REQUEST.into_response())
        }
    }
}sourcefn extract_with_state<E, S, M>(
    self,
    state: &S
) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequest<S, B, M>>::Rejection>> + Send + '_>>
 
fn extract_with_state<E, S, M>( self, state: &S ) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequest<S, B, M>>::Rejection>> + Send + '_>>
Apply an extractor that requires some state to this Request.
This is just a convenience for E::from_request(req, state).
Note this consumes the request. Use RequestExt::extract_parts_with_state if you’re not
extracting the body and don’t want to consume the request.
§Example
use axum::{
    async_trait,
    extract::{FromRef, FromRequest},
    http::Request,
    RequestExt,
};
struct MyExtractor {
    requires_state: RequiresState,
}
#[async_trait]
impl<S, B> FromRequest<S, B> for MyExtractor
where
    String: FromRef<S>,
    S: Send + Sync,
    B: Send + 'static,
{
    type Rejection = std::convert::Infallible;
    async fn from_request(req: Request<B>, state: &S) -> Result<Self, Self::Rejection> {
        let requires_state = req.extract_with_state::<RequiresState, _, _>(state).await?;
        Ok(Self { requires_state })
    }
}
// some extractor that consumes the request body and requires state
struct RequiresState { /* ... */ }
#[async_trait]
impl<S, B> FromRequest<S, B> for RequiresState
where
    String: FromRef<S>,
    S: Send + Sync,
    B: Send + 'static,
{
    // ...
}sourcefn extract_parts<E>(
    &mut self
) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequestParts<()>>::Rejection>> + Send + '_>>where
    E: FromRequestParts<()> + 'static,
 
fn extract_parts<E>(
    &mut self
) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequestParts<()>>::Rejection>> + Send + '_>>where
    E: FromRequestParts<()> + 'static,
Apply a parts extractor to this Request.
This is just a convenience for E::from_request_parts(parts, state).
§Example
use axum::{
    async_trait,
    extract::FromRequest,
    headers::{authorization::Bearer, Authorization},
    http::Request,
    response::{IntoResponse, Response},
    Json, RequestExt, TypedHeader,
};
struct MyExtractor<T> {
    bearer_token: String,
    payload: T,
}
#[async_trait]
impl<S, B, T> FromRequest<S, B> for MyExtractor<T>
where
    B: Send + 'static,
    S: Send + Sync,
    Json<T>: FromRequest<(), B>,
    T: 'static,
{
    type Rejection = Response;
    async fn from_request(mut req: Request<B>, _state: &S) -> Result<Self, Self::Rejection> {
        let TypedHeader(auth_header) = req
            .extract_parts::<TypedHeader<Authorization<Bearer>>>()
            .await
            .map_err(|err| err.into_response())?;
        let Json(payload) = req
            .extract::<Json<T>, _>()
            .await
            .map_err(|err| err.into_response())?;
        Ok(Self {
            bearer_token: auth_header.token().to_owned(),
            payload,
        })
    }
}sourcefn extract_parts_with_state<'a, E, S>(
    &'a mut self,
    state: &'a S
) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequestParts<S>>::Rejection>> + Send + 'a>>
 
fn extract_parts_with_state<'a, E, S>( &'a mut self, state: &'a S ) -> Pin<Box<dyn Future<Output = Result<E, <E as FromRequestParts<S>>::Rejection>> + Send + 'a>>
Apply a parts extractor that requires some state to this Request.
This is just a convenience for E::from_request_parts(parts, state).
§Example
use axum::{
    async_trait,
    extract::{FromRef, FromRequest, FromRequestParts},
    http::{request::Parts, Request},
    response::{IntoResponse, Response},
    Json, RequestExt,
};
struct MyExtractor<T> {
    requires_state: RequiresState,
    payload: T,
}
#[async_trait]
impl<S, B, T> FromRequest<S, B> for MyExtractor<T>
where
    String: FromRef<S>,
    Json<T>: FromRequest<(), B>,
    T: 'static,
    S: Send + Sync,
    B: Send + 'static,
{
    type Rejection = Response;
    async fn from_request(mut req: Request<B>, state: &S) -> Result<Self, Self::Rejection> {
        let requires_state = req
            .extract_parts_with_state::<RequiresState, _>(state)
            .await
            .map_err(|err| err.into_response())?;
        let Json(payload) = req
            .extract::<Json<T>, _>()
            .await
            .map_err(|err| err.into_response())?;
        Ok(Self {
            requires_state,
            payload,
        })
    }
}
struct RequiresState {}
#[async_trait]
impl<S> FromRequestParts<S> for RequiresState
where
    String: FromRef<S>,
    S: Send + Sync,
{
    // ...
}sourcefn with_limited_body(self) -> Result<Request<Limited<B>>, Request<B>>
 
fn with_limited_body(self) -> Result<Request<Limited<B>>, Request<B>>
Apply the default body limit.
If it is disabled, return the request as-is in Err.
sourcefn into_limited_body(self) -> Result<Limited<B>, B>
 
fn into_limited_body(self) -> Result<Limited<B>, B>
Consumes the request, returning the body wrapped in Limited if a
default limit is in place, or not wrapped if the
default limit is disabled.