1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
use crate::secret::Secret;
use crate::types::SecretAttributes;
use crate::SmallBuffer;
use ockam_core::Result;
use ockam_core::{async_trait, compat::boxed::Box};
/// A trait for hashing data into fixed length output
#[async_trait]
pub trait Hasher {
/// Compute the SHA-256 digest given input `data`
async fn sha256(&mut self, data: &[u8]) -> Result<[u8; 32]>;
/// Derive multiple output [`Secret`]s with given attributes using the HKDF-SHA256 using
/// specified salt, input key material and info.
async fn hkdf_sha256(
&mut self,
salt: &Secret,
info: &[u8],
ikm: Option<&Secret>,
output_attributes: SmallBuffer<SecretAttributes>,
) -> Result<SmallBuffer<Secret>>;
}