warp::filter

Trait FilterBase

source
pub trait FilterBase {
    type Extract: Tuple;
    type Error: IsReject;
    type Future: Future<Output = Result<Self::Extract, Self::Error>> + Send;

    // Required method
    fn filter(&self, internal: Internal) -> Self::Future;

    // Provided method
    fn map_err<F, E>(self, _internal: Internal, fun: F) -> MapErr<Self, F>
       where Self: Sized,
             F: Fn(Self::Error) -> E + Clone,
             E: Debug + Send { ... }
}

Required Associated Types§

Required Methods§

source

fn filter(&self, internal: Internal) -> Self::Future

Provided Methods§

source

fn map_err<F, E>(self, _internal: Internal, fun: F) -> MapErr<Self, F>
where Self: Sized, F: Fn(Self::Error) -> E + Clone, E: Debug + Send,

Implementors§

source§

impl FilterBase for Any

source§

impl<F> FilterBase for CorsFilter<F>

source§

impl<F> FilterBase for BoxingFilter<F>
where F: Filter, F::Future: Send + 'static,

source§

impl<F, T> FilterBase for Unify<F>
where F: Filter<Extract = (Either<T, T>,)>, T: Tuple,

source§

impl<F, T> FilterBase for UntupleOne<F>
where F: Filter<Extract = (T,)>, T: Tuple,

source§

impl<F, U> FilterBase for FilterFn<F>
where F: Fn(&mut Route) -> U, U: TryFuture + Send + 'static, U::Ok: Tuple + Send, U::Error: IsReject,

source§

impl<FN, F> FilterBase for WithLog<FN, F>
where FN: Fn(Info<'_>) + Clone + Send, F: Filter + Clone + Send, F::Extract: Reply, F::Error: IsReject,

source§

impl<FN, F> FilterBase for WithTrace<FN, F>
where FN: Fn(Info<'_>) -> Span + Clone + Send, F: Filter + Clone + Send, F::Extract: Reply, F::Error: IsReject,

source§

impl<P> FilterBase for Exact<P>
where P: AsRef<str>,

source§

impl<T, F> FilterBase for AndThen<T, F>

source§

impl<T, F> FilterBase for Map<T, F>
where T: Filter, F: Func<T::Extract> + Clone + Send,

source§

type Extract = (<F as Func<<T as FilterBase>::Extract>>::Output,)

source§

type Error = <T as FilterBase>::Error

source§

type Future = MapFuture<T, F>

source§

impl<T, F> FilterBase for OrElse<T, F>
where T: Filter, F: Func<T::Error> + Clone + Send, F::Output: TryFuture<Ok = T::Extract> + Send, <F::Output as TryFuture>::Error: IsReject,

source§

type Extract = <<F as Func<<T as FilterBase>::Error>>::Output as TryFuture>::Ok

source§

type Error = <<F as Func<<T as FilterBase>::Error>>::Output as TryFuture>::Error

source§

type Future = OrElseFuture<T, F>

source§

impl<T, F> FilterBase for Recover<T, F>
where T: Filter, F: Func<T::Error> + Clone + Send, F::Output: TryFuture + Send, <F::Output as TryFuture>::Error: IsReject,

source§

type Extract = (Either<<T as FilterBase>::Extract, (<<F as Func<<T as FilterBase>::Error>>::Output as TryFuture>::Ok,)>,)

source§

type Error = <<F as Func<<T as FilterBase>::Error>>::Output as TryFuture>::Error

source§

type Future = RecoverFuture<T, F>

source§

impl<T, F> FilterBase for Then<T, F>
where T: Filter, F: Func<T::Extract> + Clone + Send, F::Output: Future + Send,

source§

impl<T, F, E> FilterBase for MapErr<T, F>
where T: Filter, F: Fn(T::Error) -> E + Clone + Send, E: IsReject,

source§

impl<T, U> FilterBase for And<T, U>
where T: Filter, T::Extract: Send, U: Filter + Clone + Send, <T::Extract as Tuple>::HList: Combine<<U::Extract as Tuple>::HList> + Send, <<<T::Extract as Tuple>::HList as Combine<<U::Extract as Tuple>::HList>>::Output as HList>::Tuple: Send, U::Error: CombineRejection<T::Error>,

source§

impl<T, U> FilterBase for Or<T, U>
where T: Filter, U: Filter + Clone + Send, U::Error: CombineRejection<T::Error>,

source§

impl<T: Tuple + Send> FilterBase for BoxedFilter<T>