Trait sp_core::crypto::Zeroize

source ·
pub trait Zeroize {
    fn zeroize(&mut self);
}
Expand description

Trait to zeroize a memory buffer. Trait for securely erasing values from memory.

Required Methods§

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.

Implementations on Foreign Types§

source§

impl<Z> Zeroize for Option<Z>where
    Z: Zeroize,

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroI32

source§

fn zeroize(&mut self)

source§

impl<Z> Zeroize for [MaybeUninit<Z>]

Impl Zeroize on slices of MaybeUninit types.

This impl can eventually be optimized using an memset intrinsic, such as core::intrinsics::volatile_set_memory.

This fills the slice with zeroes.

Note that this ignore invariants that Z might have, because MaybeUninit removes all invariants.

source§

fn zeroize(&mut self)

source§

impl Zeroize for String

source§

fn zeroize(&mut self)

source§

impl<Z, const N: usize> Zeroize for [Z; N]where
    Z: Zeroize,

Impl Zeroize on arrays of types that impl Zeroize.

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroU64

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroI8

source§

fn zeroize(&mut self)

source§

impl Zeroize for __m128

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroI128

source§

fn zeroize(&mut self)

source§

impl<Z> Zeroize for Box<[Z], Global>where
    Z: Zeroize,

source§

fn zeroize(&mut self)

Unlike Vec, Box<[Z]> cannot reallocate, so we can be sure that we are not leaving values on the heap.

source§

impl Zeroize for __m128d

source§

fn zeroize(&mut self)

source§

impl<A, B, C, D, E, F, G, H, I> Zeroize for (A, B, C, D, E, F, G, H, I)where
    A: Zeroize,
    B: Zeroize,
    C: Zeroize,
    D: Zeroize,
    E: Zeroize,
    F: Zeroize,
    G: Zeroize,
    H: Zeroize,
    I: Zeroize,

source§

fn zeroize(&mut self)

source§

impl<A, B, C, D> Zeroize for (A, B, C, D)where
    A: Zeroize,
    B: Zeroize,
    C: Zeroize,
    D: Zeroize,

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroU128

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroU16

source§

fn zeroize(&mut self)

source§

impl Zeroize for ()

() is zero sized so provide a Zeroize implementation.

source§

fn zeroize(&mut self)

source§

impl<A, B, C> Zeroize for (A, B, C)where
    A: Zeroize,
    B: Zeroize,
    C: Zeroize,

source§

fn zeroize(&mut self)

source§

impl<A> Zeroize for (A,)where
    A: Zeroize,

Generic implementation of Zeroize for tuples up to 10 parameters.

source§

fn zeroize(&mut self)

source§

impl<Z> Zeroize for [Z]where
    Z: DefaultIsZeroes,

Impl Zeroize on slices of types that can be zeroized with Default.

This impl can eventually be optimized using an memset intrinsic, such as core::intrinsics::volatile_set_memory. For that reason the blanket impl on slices is bounded by DefaultIsZeroes.

To zeroize a mut slice of Z: Zeroize which does not impl DefaultIsZeroes, call iter_mut().zeroize().

source§

fn zeroize(&mut self)

source§

impl<A, B, C, D, E, F, G, H> Zeroize for (A, B, C, D, E, F, G, H)where
    A: Zeroize,
    B: Zeroize,
    C: Zeroize,
    D: Zeroize,
    E: Zeroize,
    F: Zeroize,
    G: Zeroize,
    H: Zeroize,

source§

fn zeroize(&mut self)

source§

impl<A, B> Zeroize for (A, B)where
    A: Zeroize,
    B: Zeroize,

source§

fn zeroize(&mut self)

source§

impl<Z> Zeroize for Vec<Z, Global>where
    Z: Zeroize,

source§

fn zeroize(&mut self)

“Best effort” zeroization for Vec.

Ensures the entire capacity of the Vec is zeroed. Cannot ensure that previous reallocations did not leave values on the heap.

source§

impl<A, B, C, D, E, F, G, H, I, J> Zeroize for (A, B, C, D, E, F, G, H, I, J)where
    A: Zeroize,
    B: Zeroize,
    C: Zeroize,
    D: Zeroize,
    E: Zeroize,
    F: Zeroize,
    G: Zeroize,
    H: Zeroize,
    I: Zeroize,
    J: Zeroize,

source§

fn zeroize(&mut self)

source§

impl Zeroize for PhantomPinned

PhantomPinned is zero sized so provide a Zeroize implementation.

source§

fn zeroize(&mut self)

source§

impl Zeroize for __m128i

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroIsize

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroU32

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroI64

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroU8

source§

fn zeroize(&mut self)

source§

impl<A, B, C, D, E, F> Zeroize for (A, B, C, D, E, F)where
    A: Zeroize,
    B: Zeroize,
    C: Zeroize,
    D: Zeroize,
    E: Zeroize,
    F: Zeroize,

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroI16

source§

fn zeroize(&mut self)

source§

impl<A, B, C, D, E> Zeroize for (A, B, C, D, E)where
    A: Zeroize,
    B: Zeroize,
    C: Zeroize,
    D: Zeroize,
    E: Zeroize,

source§

fn zeroize(&mut self)

source§

impl<A, B, C, D, E, F, G> Zeroize for (A, B, C, D, E, F, G)where
    A: Zeroize,
    B: Zeroize,
    C: Zeroize,
    D: Zeroize,
    E: Zeroize,
    F: Zeroize,
    G: Zeroize,

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZeroUsize

source§

fn zeroize(&mut self)

source§

impl<Z> Zeroize for PhantomData<Z>

PhantomData is always zero sized so provide a Zeroize implementation.

source§

fn zeroize(&mut self)

source§

impl<'a, Z> Zeroize for IterMut<'a, Z>where
    Z: Zeroize,

source§

fn zeroize(&mut self)

source§

impl Zeroize for Seed

source§

fn zeroize(&mut self)

source§

impl Zeroize for SigningKey

source§

fn zeroize(&mut self)

source§

impl Zeroize for RistrettoPoint

source§

fn zeroize(&mut self)

source§

impl Zeroize for Scalar

source§

fn zeroize(&mut self)

source§

impl Zeroize for CompressedEdwardsY

source§

fn zeroize(&mut self)

Reset this CompressedEdwardsY to the compressed form of the identity element.

source§

impl Zeroize for MontgomeryPoint

source§

fn zeroize(&mut self)

source§

impl Zeroize for CompressedRistretto

source§

fn zeroize(&mut self)

source§

impl Zeroize for EdwardsPoint

source§

fn zeroize(&mut self)

Reset this CompressedEdwardsPoint to the identity element.

source§

impl Zeroize for SecretKey

source§

fn zeroize(&mut self)

source§

impl Zeroize for Keypair

source§

fn zeroize(&mut self)

source§

impl Zeroize for MiniSecretKey

source§

fn zeroize(&mut self)

source§

impl Zeroize for MontgomeryPoint

source§

fn zeroize(&mut self)

source§

impl Zeroize for Scalar

source§

fn zeroize(&mut self)

source§

impl Zeroize for Transcript

source§

fn zeroize(&mut self)

Implementors§

source§

impl<Z> Zeroize for Zeroizing<Z>where
    Z: Zeroize,

source§

impl<Z> Zeroize for Zwhere
    Z: DefaultIsZeroes,