Enum Value

Source
pub enum Value {
    Public(Option<String>),
    Private(Option<String>),
}
Expand description

Wraps the data for an extension as a string with access restrictions.

This is a generic way for extensions to store their data in a universal, encoded form. It is also able to indicate the intended readers for such an extension so that backends can ensure that private extension data is properly encrypted even when present in a self-encoded access token.

Some extensions have semantics where the presence alone is the stored data, so storing data is optional and storing no data is distinct from not attaching any extension instance at all.

Variants§

§

Public(Option<String>)

An extension that the token owner is allowed to read and interpret.

§

Private(Option<String>)

Identifies an extenion whose content and/or existance MUST be kept secret.

Implementations§

Source§

impl Value

Source

pub fn public(content: Option<String>) -> Self

Creates an extension whose presence and content can be unveiled by the token holder.

Anyone in possession of the token corresponding to such a grant is potentially able to read the content of a public extension.

Source

pub fn private(content: Option<String>) -> Value

Creates an extension with secret content only visible for the server.

Token issuers should take special care to protect the content and the identifier of such an extension from being interpreted or correlated by the token holder.

Source

pub fn public_value(&self) -> Result<Option<&str>, ()>

Inspect the public value.

Returns an Err if this is not a public extension, None if the extension has no value but consists only of the key, and Some(_) otherwise.

Source

pub fn into_public_value(self) -> Result<Option<String>, ()>

Convert into the public value.

Returns an Err if this is not a public extension, None if the extension has no value but consists only of the key, and Some(_) otherwise.

Source

pub fn private_value(&self) -> Result<Option<&str>, ()>

Inspect the private value.

Returns an Err if this is not a private extension, None if the extension has no value but consists only of the key, and Some(_) otherwise.

Source

pub fn into_private_value(self) -> Result<Option<String>, ()>

Inspect the private value.

Returns an Err if this is not a private extension, None if the extension has no value but consists only of the key, and Some(_) otherwise.

Trait Implementations§

Source§

impl Clone for Value

Source§

fn clone(&self) -> Value

Returns a duplicate 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 Value

Source§

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

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

impl PartialEq for Value

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for Value

Source§

impl StructuralPartialEq for Value

Auto Trait Implementations§

§

impl Freeze for Value

§

impl RefUnwindSafe for Value

§

impl Send for Value

§

impl Sync for Value

§

impl Unpin for Value

§

impl UnwindSafe for Value

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where 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> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

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 T
where U: Into<T>,

Source§

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 T
where U: TryFrom<T>,

Source§

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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> ErasedDestructor for T
where T: 'static,