Trait sp_core::crypto::Zeroize

source ·
pub trait Zeroize {
    // Required method
    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 Zeroize for str

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 EdwardsPoint

source§

fn zeroize(&mut self)

Reset this CompressedEdwardsPoint to 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 RistrettoPoint

source§

fn zeroize(&mut self)

source§

impl Zeroize for Scalar

source§

fn zeroize(&mut self)

source§

impl Zeroize for SigningKey

source§

fn zeroize(&mut self)

source§

impl Zeroize for Transcript

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 SecretKey

source§

fn zeroize(&mut self)

source§

impl Zeroize for Box<str>

source§

fn zeroize(&mut self)

source§

impl Zeroize for CString

source§

fn zeroize(&mut self)

source§

impl Zeroize for String

source§

fn zeroize(&mut self)

source§

impl Zeroize for __m128

source§

fn zeroize(&mut self)

source§

impl Zeroize for __m128d

source§

fn zeroize(&mut self)

source§

impl Zeroize for __m128i

source§

fn zeroize(&mut self)

source§

impl Zeroize for __m256

source§

fn zeroize(&mut self)

source§

impl Zeroize for __m256d

source§

fn zeroize(&mut self)

source§

impl Zeroize for __m256i

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<i8>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<i16>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<i32>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<i64>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<i128>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<isize>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<u8>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<u16>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<u32>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<u64>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<u128>

source§

fn zeroize(&mut self)

source§

impl Zeroize for NonZero<usize>

source§

fn zeroize(&mut self)

source§

impl<A> Zeroize for (A,)
where A: 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<A, B, C> Zeroize for (A, B, C)
where A: Zeroize, B: Zeroize, C: 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<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> 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<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<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, 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, 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<T, N> Zeroize for GenericArray<T, N>
where T: Zeroize, N: ArrayLength<T>,

source§

fn zeroize(&mut self)

source§

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

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<Z> Zeroize for Box<[Z]>
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<Z> Zeroize for Vec<Z>
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<Z> Zeroize for PhantomData<Z>

PhantomData is always zero sized so provide a Zeroize implementation.

source§

fn zeroize(&mut self)

source§

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

source§

fn zeroize(&mut self)

source§

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

source§

fn zeroize(&mut self)

source§

impl<Z> Zeroize for MaybeUninit<Z>

Impl Zeroize on MaybeUninit types.

This fills the memory with zeroes. Note that this ignore invariants that Z might have, because MaybeUninit removes all invariants.

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

Implementors§

source§

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

source§

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