Struct pavex::blueprint::router::RegisteredFallback

source ·
pub struct RegisteredFallback<'a> { /* private fields */ }
Expand description

The type returned by Blueprint::fallback.

It allows you to further configure the behaviour of the registered handler.

Implementations§

source§

impl<'a> RegisteredFallback<'a>

source

pub fn error_handler(self, error_handler: RawIdentifiers) -> Self

Register an error handler.

Error handlers convert the error type returned by your request handler into an HTTP response.

Error handlers CANNOT consume the error type, they must take a reference to the error as input.
Error handlers can have additional input parameters alongside the error, as long as there are constructors registered for those parameter types.

use pavex::f;
use pavex::blueprint::Blueprint;
use pavex::response::Response;

fn fallback() -> Result<Response, RuntimeError> {
    // [...]
}

fn error_to_response(error: &ConfigurationError, log_level: LogLevel) -> Response {
    // [...]
}

let mut bp = Blueprint::new();
bp.fallback(f!(crate::fallback))
    .error_handler(f!(crate::error_to_response));

If an error handler has already been registered for the same error type, it will be overwritten.

§Common Errors

Pavex will fail to generate the runtime code for your application if you register an error handler for an infallible request handler (i.e. a request handler that doesn’t return a Result).

Auto Trait Implementations§

§

impl<'a> Freeze for RegisteredFallback<'a>

§

impl<'a> RefUnwindSafe for RegisteredFallback<'a>

§

impl<'a> Send for RegisteredFallback<'a>

§

impl<'a> Sync for RegisteredFallback<'a>

§

impl<'a> Unpin for RegisteredFallback<'a>

§

impl<'a> !UnwindSafe for RegisteredFallback<'a>

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.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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<T> Same for T

§

type Output = T

Should always be Self
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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more