pub enum PwHashLimits {
    Minimum,
    Interactive,
    Moderate,
    Sensitive,
}
Expand description

Enum to specify limits (difficulty) for argon2id pwhashing algorithm.

Ops in this library don’t take explicit limit parameters. Instead, they check the current context, if not set using the default “Moderate” limits.

To set the context for the scope of the “with_exec” callback:

let _my_result = PwHashLimits::Sensitive.with_exec(|| {
  // execute my function that needs "Sensitive" limits
});

Variants§

§

Minimum

minimum limits (UNIT TESTING ONLY)

§

Interactive

low cpu/mem limits

§

Moderate

middle cpu/mem limits (default)

§

Sensitive

high cpu/mem limits

Implementations§

source§

impl PwHashLimits

source

pub fn current() -> Self

Get the current set limits or the default “Moderate” limits if none are set by with_exec().

source

pub fn with_exec<R, F>(self, f: F) -> R
where F: FnOnce() -> R,

Execute a closure with these pwhash limits set.

source

pub fn as_mem_limit(&self) -> u32

translate into mem limit

source

pub fn as_ops_limit(&self) -> u32

translate into cpu limit

Trait Implementations§

source§

impl Clone for PwHashLimits

source§

fn clone(&self) -> PwHashLimits

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 PwHashLimits

source§

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

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

impl PartialEq for PwHashLimits

source§

fn eq(&self, other: &PwHashLimits) -> 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 Copy for PwHashLimits

source§

impl Eq for PwHashLimits

source§

impl StructuralPartialEq for PwHashLimits

Auto Trait Implementations§

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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
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> ToOwned for T
where 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 T
where 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 T
where 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.