cosmwasm-crypto 0.14.1

Crypto bindings for cosmwasm contracts
Documentation
//! Dummy 256-bits Digest impl.
//! This digest stores/accepts a value of the proper length.
//! To be used for / with already hashed values, just to comply with the Digest contract.
//!
//! Adapted from `sha2` [sha256.rs](https://github.com/RustCrypto/hashes/blob/master/sha2/src/sha256.rs)
use digest::consts::U32;
use digest::generic_array::GenericArray;
use digest::{FixedOutputDirty, Output, Reset, Update};

/// The 256-bits identity container
#[derive(Clone)]
pub struct Identity256 {
    array: GenericArray<u8, U32>,
}

impl Default for Identity256 {
    fn default() -> Self {
        Identity256 {
            array: GenericArray::default(),
        }
    }
}

impl Update for Identity256 {
    fn update(&mut self, hash: impl AsRef<[u8]>) {
        assert_eq!(hash.as_ref().len(), 32);
        self.array = *GenericArray::from_slice(hash.as_ref());
    }
}

impl FixedOutputDirty for Identity256 {
    type OutputSize = U32;

    fn finalize_into_dirty(&mut self, out: &mut Output<Self>) {
        *out = self.array;
    }
}

impl Reset for Identity256 {
    fn reset(&mut self) {
        *self = Self::default();
    }
}