pub struct CsprngArray<const N: usize>(/* private fields */);
Expand description

Generate Cryptographically secure random bytes of different sizes based on generic usize N

Structure
pub struct CsprngArray<const N: usize>([u8; N]);
Example
let bytes = CsprngArray::<32>::gen(); // Generates 32 random bytes
assert_eq!(bytes.len(), 32);

Implementations§

source§

impl<const N: usize> CsprngArray<N>

source

pub fn gen() -> Self

Method to generate random cryptographically secure random bytes

Example
let bytes = CsprngArray::<64>::gen(); // Generates 64 random bytes
assert_eq!(bytes.len(), 64);
source

pub fn take(self, buffer: &mut [u8; N]) -> MemSecurityResult<()>

Copies the contents of the buffer

source

pub fn take_zeroize_on_error( self, buffer: &mut [u8; N] ) -> MemSecurityResult<()>

Copies the contents of the buffer

source

pub fn expose(&self) -> [u8; N]

Clone the data. Be careful with this as it retains the secret in memory. It is recommended to call Csprng::zeroize() after consuming this in order to zeroize the memory

source

pub fn expose_borrowed(&self) -> &[u8]

Clone the data. Be careful with this as it retains the secret in memory. It is recommended to call Csprng::zeroize() after consuming this in order to zeroize the memory

source

pub fn dangerous_debug(&self) -> &[u8; N]

Get the inner value of the struct. This is only available in a debug build and is enforced by the flag #[cfg(debug_assertions)]

Trait Implementations§

source§

impl<const N: usize> AsRef<[u8]> for CsprngArray<N>

source§

fn as_ref(&self) -> &[u8]

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl<const N: usize> BorshDeserialize for CsprngArray<N>

source§

fn deserialize_reader<R: Read>(reader: &mut R) -> Result<Self, Error>

source§

fn deserialize(buf: &mut &[u8]) -> Result<Self, Error>

Deserializes this instance from a given slice of bytes. Updates the buffer to point at the remaining bytes.
source§

fn try_from_slice(v: &[u8]) -> Result<Self, Error>

Deserialize this instance from a slice of bytes.
source§

fn try_from_reader<R>(reader: &mut R) -> Result<Self, Error>
where R: Read,

source§

impl<const N: usize> BorshSerialize for CsprngArray<N>

source§

fn serialize<W: Write>(&self, writer: &mut W) -> Result<(), Error>

source§

impl<const N: usize> Debug for CsprngArray<N>

source§

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

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

impl<const N: usize> Display for CsprngArray<N>

source§

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

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

impl<const N: usize> Drop for CsprngArray<N>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<const N: usize> Zeroize for CsprngArray<N>

source§

fn zeroize(&mut self)

Zero out this object from memory using Rust intrinsics which ensure the zeroization operation is not “optimized away” by the compiler.

Auto Trait Implementations§

§

impl<const N: usize> RefUnwindSafe for CsprngArray<N>

§

impl<const N: usize> Send for CsprngArray<N>

§

impl<const N: usize> Sync for CsprngArray<N>

§

impl<const N: usize> Unpin for CsprngArray<N>

§

impl<const N: usize> UnwindSafe for CsprngArray<N>

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> 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

§

type Output = T

Should always be Self
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. 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.
§

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

§

fn vzip(self) -> V