Struct axum_auth::AuthBearer

source ·
pub struct AuthBearer(pub String);
Expand description

Bearer token extractor which contains the innards of a bearer header as a string

This is enabled via the auth-bearer feature

Example

This structure can be used like any other axum extractor:

use axum_auth::AuthBearer;

/// Handler for a typical [axum] route, takes a `token` and returns it
async fn handler(AuthBearer(token): AuthBearer) -> String {
    format!("Found a bearer token: {}", token)
}

Errors

There are a few errors which this extractor can make. By default, all invalid responses are 400 BAD REQUEST with one of these messages:

  • `Authorization` header must be a bearer token – Somebody tried to but basic auth here instead of bearer
  • `Authorization` header is missing – The header was required but it wasn’t found
  • `Authorization` header contains invalid characters – The header couldn’t be processed because of invalid characters

Tuple Fields§

§0: String

Trait Implementations§

source§

impl AuthBearerCustom for AuthBearer

source§

const ERROR_CODE: StatusCode = ERR_DEFAULT

Error code to use instead of the typical 400 BAD REQUEST error
source§

const ERROR_OVERWRITE: Option<&'static str> = None

Message to overwrite all default ones with if required, leave as None ideally
source§

fn from_header(contents: &str) -> Self

Converts provided header contents to new instance of self; you need to implement this Read more
source§

fn decode_request_parts(req: &mut Parts) -> Result<Self, Rejection>

Decodes bearer token content into new instance of self from axum body parts; this is automatically implemented
source§

impl Clone for AuthBearer

source§

fn clone(&self) -> AuthBearer

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for AuthBearer

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<B> FromRequestParts<B> for AuthBearerwhere B: Send + Sync,

§

type Rejection = (StatusCode, &'static str)

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_parts<'life0, 'life1, 'async_trait>( req: &'life0 mut Parts, _: &'life1 B ) -> Pin<Box<dyn Future<Output = Result<Self, Self::Rejection>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Perform the extraction.
source§

impl PartialEq for AuthBearer

source§

fn eq(&self, other: &AuthBearer) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for AuthBearer

source§

impl StructuralEq for AuthBearer

source§

impl StructuralPartialEq for AuthBearer

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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.

source§

impl<T> FromRef<T> for Twhere T: Clone,

source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
source§

impl<S, T> FromRequest<S, ViaParts> for Twhere S: Send + Sync, T: FromRequestParts<S>,

§

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<'life0, 'async_trait>( req: Request<Body>, state: &'life0 S ) -> Pin<Box<dyn Future<Output = Result<T, <T as FromRequest<S, ViaParts>>::Rejection>> + Send + 'async_trait>>where 'life0: 'async_trait, T: 'async_trait,

Perform the extraction.
source§

impl<T, U> Into<U> for Twhere 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> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere 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 Twhere 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.