Struct ntex_service::dev::ServiceChain

source ·
pub struct ServiceChain<Svc, Req> { /* private fields */ }
Expand description

Chain builder - chain allows to compose multiple service into one service.

Implementations§

source§

impl<Svc: Service<Req>, Req> ServiceChain<Svc, Req>

source

pub fn and_then<Next, F>( self, service: F ) -> ServiceChain<AndThen<Svc, Next>, Req>
where Self: Sized, F: IntoService<Next, Svc::Response>, Next: Service<Svc::Response, Error = Svc::Error>,

Call another service after call to this one has resolved successfully.

This function can be used to chain two services together and ensure that the second service isn’t called until call to the fist service have finished. Result of the call to the first service is used as an input parameter for the second service’s call.

Note that this function consumes the receiving service and returns a wrapped version of it.

source

pub fn then<Next, F>(self, service: F) -> ServiceChain<Then<Svc, Next>, Req>
where Self: Sized, F: IntoService<Next, Result<Svc::Response, Svc::Error>>, Next: Service<Result<Svc::Response, Svc::Error>, Error = Svc::Error>,

Chain on a computation for when a call to the service finished, passing the result of the call to the next service U.

Note that this function consumes the receiving pipeline and returns a wrapped version of it.

source

pub fn map<F, Res>(self, f: F) -> ServiceChain<Map<Svc, F, Req, Res>, Req>
where Self: Sized, F: Fn(Svc::Response) -> Res,

Map this service’s output to a different type, returning a new service of the resulting type.

This function is similar to the Option::map or Iterator::map where it will change the type of the underlying service.

Note that this function consumes the receiving service and returns a wrapped version of it, similar to the existing map methods in the standard library.

source

pub fn map_err<F, Err>(self, f: F) -> ServiceChain<MapErr<Svc, F, Err>, Req>
where Self: Sized, F: Fn(Svc::Error) -> Err,

Map this service’s error to a different error, returning a new service.

This function is similar to the Result::map_err where it will change the error type of the underlying service. This is useful for example to ensure that services have the same error type.

Note that this function consumes the receiving service and returns a wrapped version of it.

source

pub fn apply_fn<F, R, In, Out, Err>( self, f: F ) -> ServiceChain<Apply<Svc, Req, F, R, In, Out, Err>, In>
where F: Fn(In, Pipeline<Svc>) -> R, R: Future<Output = Result<Out, Err>>, Svc: Service<Req>, Err: From<Svc::Error>,

Use function as middleware for current service.

Short version of apply_fn(chain(...), fn)

source

pub fn into_pipeline(self) -> Pipeline<Svc>

Create service pipeline

Trait Implementations§

source§

impl<Svc, Req> Clone for ServiceChain<Svc, Req>
where Svc: Clone,

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<Svc, Req> Debug for ServiceChain<Svc, Req>
where Svc: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Svc: Service<Req>, Req> Service<Req> for ServiceChain<Svc, Req>

§

type Response = <Svc as Service<Req>>::Response

Responses given by the service.
§

type Error = <Svc as Service<Req>>::Error

Errors produced by the service when polling readiness or executing call.
source§

async fn ready(&self, ctx: ServiceCtx<'_, Self>) -> Result<(), Self::Error>

Returns when the service is able to process requests. Read more
source§

async fn shutdown(&self)

Shutdown service. Read more
source§

async fn call( &self, req: Req, ctx: ServiceCtx<'_, Self> ) -> Result<Self::Response, Self::Error>

Process the request and return the response asynchronously. Read more
source§

fn map<F, Res>(self, f: F) -> ServiceChain<Map<Self, F, Req, Res>, Req>
where Self: Sized, F: Fn(Self::Response) -> Res,

Map this service’s output to a different type, returning a new service of the resulting type. Read more
source§

fn map_err<F, E>(self, f: F) -> ServiceChain<MapErr<Self, F, E>, Req>
where Self: Sized, F: Fn(Self::Error) -> E,

Map this service’s error to a different error, returning a new service. Read more

Auto Trait Implementations§

§

impl<Svc, Req> Freeze for ServiceChain<Svc, Req>
where Svc: Freeze,

§

impl<Svc, Req> RefUnwindSafe for ServiceChain<Svc, Req>
where Svc: RefUnwindSafe, Req: RefUnwindSafe,

§

impl<Svc, Req> Send for ServiceChain<Svc, Req>
where Svc: Send, Req: Send,

§

impl<Svc, Req> Sync for ServiceChain<Svc, Req>
where Svc: Sync, Req: Sync,

§

impl<Svc, Req> Unpin for ServiceChain<Svc, Req>
where Svc: Unpin, Req: Unpin,

§

impl<Svc, Req> UnwindSafe for ServiceChain<Svc, Req>
where Svc: UnwindSafe, Req: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<Svc, Req> IntoService<Svc, Req> for Svc
where Svc: Service<Req>,

source§

fn into_service(self) -> Svc

Convert to a Service
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.