pub struct ValidateRequestHeaderLayer<T> { /* private fields */ }
Expand description
Layer that applies ValidateRequestHeader
which validates all requests.
See the module docs for an example.
Implementations§
Source§impl<C> ValidateRequestHeaderLayer<AuthorizeContext<C>>
impl<C> ValidateRequestHeaderLayer<AuthorizeContext<C>>
Sourcepub fn set_allow_anonymous(&mut self, allow_anonymous: bool) -> &mut Self
pub fn set_allow_anonymous(&mut self, allow_anonymous: bool) -> &mut Self
Allow anonymous requests.
Sourcepub fn with_allow_anonymous(self, allow_anonymous: bool) -> Self
pub fn with_allow_anonymous(self, allow_anonymous: bool) -> Self
Allow anonymous requests.
Source§impl<ResBody> ValidateRequestHeaderLayer<AuthorizeContext<Basic<ResBody>>>
impl<ResBody> ValidateRequestHeaderLayer<AuthorizeContext<Basic<ResBody>>>
Sourcepub fn basic(username: &str, password: &str) -> Selfwhere
ResBody: Default,
pub fn basic(username: &str, password: &str) -> Selfwhere
ResBody: Default,
Authorize requests using a username and password pair.
The Authorization
header is required to be Basic {credentials}
where credentials
is
base64_encode("{username}:{password}")
.
Since the username and password is sent in clear text it is recommended to use HTTPS/TLS with this method. However use of HTTPS/TLS is not enforced by this middleware.
Source§impl<ResBody> ValidateRequestHeaderLayer<AuthorizeContext<Bearer<ResBody>>>
impl<ResBody> ValidateRequestHeaderLayer<AuthorizeContext<Bearer<ResBody>>>
Source§impl<ResBody> ValidateRequestHeaderLayer<AcceptHeader<ResBody>>
impl<ResBody> ValidateRequestHeaderLayer<AcceptHeader<ResBody>>
Sourcepub fn accept(value: &str) -> Selfwhere
ResBody: Default,
pub fn accept(value: &str) -> Selfwhere
ResBody: Default,
Validate requests have the required Accept header.
The Accept
header is required to be */*
, type/*
or type/subtype
,
as configured.
§Panics
Panics if header_value
is not in the form: type/subtype
, such as application/json
See AcceptHeader::new
for when this method panics.
§Example
use rama_http::layer::validate_request::{AcceptHeader, ValidateRequestHeaderLayer};
let layer = ValidateRequestHeaderLayer::<AcceptHeader>::accept("application/json");
Source§impl<T> ValidateRequestHeaderLayer<T>
impl<T> ValidateRequestHeaderLayer<T>
Source§impl<F, A> ValidateRequestHeaderLayer<BoxValidateRequestFn<F, A>>
impl<F, A> ValidateRequestHeaderLayer<BoxValidateRequestFn<F, A>>
Trait Implementations§
Source§impl<T> Clone for ValidateRequestHeaderLayer<T>where
T: Clone,
impl<T> Clone for ValidateRequestHeaderLayer<T>where
T: Clone,
Source§impl<T: Debug> Debug for ValidateRequestHeaderLayer<T>
impl<T: Debug> Debug for ValidateRequestHeaderLayer<T>
Auto Trait Implementations§
impl<T> Freeze for ValidateRequestHeaderLayer<T>where
T: Freeze,
impl<T> RefUnwindSafe for ValidateRequestHeaderLayer<T>where
T: RefUnwindSafe,
impl<T> Send for ValidateRequestHeaderLayer<T>where
T: Send,
impl<T> Sync for ValidateRequestHeaderLayer<T>where
T: Sync,
impl<T> Unpin for ValidateRequestHeaderLayer<T>where
T: Unpin,
impl<T> UnwindSafe for ValidateRequestHeaderLayer<T>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more