pub struct RouteNonMatch { /* private fields */ }Expand description
The error type used for a non-matching route, as returned by RouteMatcher::is_match. Multiple
values of this type can be combined by matchers that are wrapping other matchers, using the
intersection / union methods. The data within is used by the Router to create a
Response when no routes were successfully matched.
#[derive(Clone)]
struct MyRouteMatcher;
impl RouteMatcher for MyRouteMatcher {
fn is_match(&self, state: &State) -> Result<(), RouteNonMatch> {
match state.borrow::<Method>() {
&Method::GET => Ok(()),
_ => Err(RouteNonMatch::new(StatusCode::METHOD_NOT_ALLOWED)
.with_allow_list(&[Method::GET])),
}
}
}Implementations§
Source§impl RouteNonMatch
impl RouteNonMatch
Sourcepub fn new(status: StatusCode) -> RouteNonMatch
pub fn new(status: StatusCode) -> RouteNonMatch
Creates a new RouteNonMatch value with the given HTTP status.
Sourcepub fn with_allow_list(self, allow: &[Method]) -> RouteNonMatch
pub fn with_allow_list(self, allow: &[Method]) -> RouteNonMatch
Adds an allow list to a RouteNonMatch. Typically this is used with a 405 Method Not Allowed status code, so the Router can accurately populate the Allow header in the
response. It must be populated by any RouteMatcher which restricts the HTTP method.
Sourcepub fn intersection(self, other: RouteNonMatch) -> RouteNonMatch
pub fn intersection(self, other: RouteNonMatch) -> RouteNonMatch
Takes the intersection of two RouteNonMatch values, producing a single result. This is
intended for use in cases where two RouteMatcher instances with a logical AND
connection have both indicated a non-match, and their results need to be aggregated.
This is typically for Gotham internal use, but may be useful for implementors of matchers
which wrap other RouteMatcher instances. See the AndRouteMatcher implementation (in
gotham::router::route::matcher::and) for an example.
Sourcepub fn union(self, other: RouteNonMatch) -> RouteNonMatch
pub fn union(self, other: RouteNonMatch) -> RouteNonMatch
Takes the union of two RouteNonMatch values, producing a single result. This is intended
for use in cases where two RouteMatcher instances with a logical OR connection have
both indicated a non-match, and their results need to be aggregated.
This is typically for Gotham internal use, but may be useful for implementors of matchers
which wrap other RouteMatcher instances. See the Node::select_route implementation (in
gotham::router::tree) for an example.
Trait Implementations§
Source§impl Clone for RouteNonMatch
impl Clone for RouteNonMatch
Source§fn clone(&self) -> RouteNonMatch
fn clone(&self) -> RouteNonMatch
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more