pub struct SharedClassifier<C> { /* private fields */ }
Expand description

A MakeClassifier that produces new classifiers by cloning an inner classifier.

When a type implementing ClassifyResponse doesn’t depend on information from the request, SharedClassifier can be used to turn an instance of that type into a MakeClassifier.

Example

use std::fmt;
use tower_http::classify::{
    ClassifyResponse, ClassifiedResponse, NeverClassifyEos,
    SharedClassifier, MakeClassifier,
};
use http::Response;

// A response classifier that only considers errors to be failures.
#[derive(Clone, Copy)]
struct MyClassifier;

impl ClassifyResponse for MyClassifier {
    type FailureClass = String;
    type ClassifyEos = NeverClassifyEos<Self::FailureClass>;

    fn classify_response<B>(
        self,
        _res: &Response<B>,
    ) -> ClassifiedResponse<Self::FailureClass, Self::ClassifyEos> {
        ClassifiedResponse::Ready(Ok(()))
    }

    fn classify_error<E>(self, error: &E) -> Self::FailureClass
    where
        E: fmt::Display + 'static,
    {
        error.to_string()
    }
}

// Some function that requires a `MakeClassifier`
fn use_make_classifier<M: MakeClassifier>(make: M) {
    // ...
}

// `MyClassifier` doesn't implement `MakeClassifier` but since it doesn't
// care about the incoming request we can make `MyClassifier`s by cloning.
// That is what `SharedClassifier` does.
let make_classifier = SharedClassifier::new(MyClassifier);

// We now have a `MakeClassifier`!
use_make_classifier(make_classifier);

Implementations§

source§

impl<C> SharedClassifier<C>

source

pub fn new(classifier: C) -> Selfwhere C: ClassifyResponse + Clone,

Create a new SharedClassifier from the given classifier.

Trait Implementations§

source§

impl<C: Clone> Clone for SharedClassifier<C>

source§

fn clone(&self) -> SharedClassifier<C>

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<C: Debug> Debug for SharedClassifier<C>

source§

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

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

impl<C> MakeClassifier for SharedClassifier<C>where C: ClassifyResponse + Clone,

§

type FailureClass = <C as ClassifyResponse>::FailureClass

The type of failure classifications. Read more
§

type ClassifyEos = <C as ClassifyResponse>::ClassifyEos

The type used to classify the response end of stream (EOS).
§

type Classifier = C

The response classifier produced.
source§

fn make_classifier<B>(&self, _req: &Request<B>) -> Self::Classifier

Returns a response classifier for this request

Auto Trait Implementations§

§

impl<C> RefUnwindSafe for SharedClassifier<C>where C: RefUnwindSafe,

§

impl<C> Send for SharedClassifier<C>where C: Send,

§

impl<C> Sync for SharedClassifier<C>where C: Sync,

§

impl<C> Unpin for SharedClassifier<C>where C: Unpin,

§

impl<C> UnwindSafe for SharedClassifier<C>where C: UnwindSafe,

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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<T> ToOwned for Twhere 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 Twhere 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 Twhere 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.