pub struct OptionalAuthUser(pub Option<User>);Expand description
Axum extractor that optionally provides the authenticated user.
Same flow as AuthUser but wraps Option<User> and never rejects.
Returns None when not authenticated. Returns Some(user) when valid.
Internal errors (database failures) are logged and treated as None.
Usage: OptionalAuthUser(user): OptionalAuthUser in handler arguments.
Tuple Fields§
§0: Option<User>Trait Implementations§
Source§impl<S> FromRequestParts<S> for OptionalAuthUser
impl<S> FromRequestParts<S> for OptionalAuthUser
Auto Trait Implementations§
impl Freeze for OptionalAuthUser
impl RefUnwindSafe for OptionalAuthUser
impl Send for OptionalAuthUser
impl Sync for OptionalAuthUser
impl Unpin for OptionalAuthUser
impl UnsafeUnpin for OptionalAuthUser
impl UnwindSafe for OptionalAuthUser
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
Mutably borrows from an owned value. Read more
Source§impl<S, T> FromRequest<S, ViaParts> for T
impl<S, T> FromRequest<S, ViaParts> for T
Source§type Rejection = <T as FromRequestParts<S>>::Rejection
type Rejection = <T as FromRequestParts<S>>::Rejection
If the extractor fails it’ll use this “rejection” type. A rejection is
a kind of error that can be converted into a response.
Source§fn from_request(
req: Request<Body>,
state: &S,
) -> impl Future<Output = Result<T, <T as FromRequest<S, ViaParts>>::Rejection>>
fn from_request( req: Request<Body>, state: &S, ) -> impl Future<Output = Result<T, <T as FromRequest<S, ViaParts>>::Rejection>>
Perform the extraction.
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>
Converts
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>
Converts
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