Struct actix_web::middleware::Compat
source · pub struct Compat<T> { /* private fields */ }
Expand description
Middleware for enabling any middleware to be used in Resource::wrap
,
and Condition
.
Examples
use actix_web::middleware::{Logger, Compat};
use actix_web::{App, web};
let logger = Logger::default();
// this would not compile because of incompatible body types
// let app = App::new()
// .service(web::scope("scoped").wrap(logger));
// by using this middleware we can use the logger on a scope
let app = App::new()
.service(web::scope("scoped").wrap(Compat::new(logger)));
Implementations§
Trait Implementations§
source§impl<S, T, Req> Transform<S, Req> for Compat<T>where
S: Service<Req>,
T: Transform<S, Req>,
T::Future: 'static,
T::Response: MapServiceResponseBody,
T::Error: Into<Error>,
impl<S, T, Req> Transform<S, Req> for Compat<T>where
S: Service<Req>,
T: Transform<S, Req>,
T::Future: 'static,
T::Response: MapServiceResponseBody,
T::Error: Into<Error>,
§type Response = ServiceResponse<BoxBody>
type Response = ServiceResponse<BoxBody>
Responses produced by the service.
§type Transform = CompatMiddleware<<T as Transform<S, Req>>::Transform>
type Transform = CompatMiddleware<<T as Transform<S, Req>>::Transform>
The
TransformService
value created by this factory§type InitError = <T as Transform<S, Req>>::InitError
type InitError = <T as Transform<S, Req>>::InitError
Errors produced while building a transform service.
§type Future = Pin<Box<dyn Future<Output = Result<<Compat<T> as Transform<S, Req>>::Transform, <Compat<T> as Transform<S, Req>>::InitError>> + 'static, Global>>
type Future = Pin<Box<dyn Future<Output = Result<<Compat<T> as Transform<S, Req>>::Transform, <Compat<T> as Transform<S, Req>>::InitError>> + 'static, Global>>
The future response value.
source§fn new_transform(&self, service: S) -> Self::Future
fn new_transform(&self, service: S) -> Self::Future
Creates and returns a new Transform component, asynchronously