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>
Source§impl<S, T> Layer<S> for ValidateRequestHeaderLayer<T>where
T: Clone,
impl<S, T> Layer<S> for ValidateRequestHeaderLayer<T>where
T: Clone,
Source§type Service = ValidateRequestHeader<S, T>
type Service = ValidateRequestHeader<S, T>
Source§fn layer(&self, inner: S) -> Self::Service
fn layer(&self, inner: S) -> Self::Service
Source§fn into_layer(self, inner: S) -> Self::Service
fn into_layer(self, inner: S) -> Self::Service
layer but consuming self after the service was created. Read moreAuto 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