struct HmacStreamValidator {
hmac: Hmac<Sha256>,
}Expand description
A higher level interface over the HMAC validation of the attachment ciphertext
Fields§
§hmac: Hmac<Sha256>Implementations§
Source§impl HmacStreamValidator
impl HmacStreamValidator
fn new(mac_key: &[u8; 32], iv: &[u8; 16]) -> Self
Sourcefn read_block(&mut self, data: &[u8; 16])
fn read_block(&mut self, data: &[u8; 16])
Called on each CBC ciphertext block in order
Sourcefn end_stream(&self) -> [u8; 32]
fn end_stream(&self) -> [u8; 32]
Called after the final block has been ingested by read_block, during encryption.
Sourcefn validate_stream_end(&self, expected_mac: &[u8; 32]) -> bool
fn validate_stream_end(&self, expected_mac: &[u8; 32]) -> bool
Called after the final block has been ingested by read_block, during decryption. Returns
whether the calculated HMAC matches the expected HMAC from the header.
Auto Trait Implementations§
impl Freeze for HmacStreamValidator
impl RefUnwindSafe for HmacStreamValidator
impl Send for HmacStreamValidator
impl Sync for HmacStreamValidator
impl Unpin for HmacStreamValidator
impl UnsafeUnpin for HmacStreamValidator
impl UnwindSafe for HmacStreamValidator
Blanket Implementations§
§impl<T> AnySync for T
impl<T> AnySync for T
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> CompatExt for T
impl<T> CompatExt for T
§impl<T, UT> HandleAlloc<UT> for T
impl<T, UT> HandleAlloc<UT> for T
§fn new_handle(value: Arc<T>) -> Handle
fn new_handle(value: Arc<T>) -> Handle
Create a new handle for an Arc value Read more
§unsafe fn clone_handle(handle: Handle) -> Handle
unsafe fn clone_handle(handle: Handle) -> Handle
Clone a handle Read more
§unsafe fn consume_handle(handle: Handle) -> Arc<T>
unsafe fn consume_handle(handle: Handle) -> Arc<T>
Consume a handle, getting back the initial
Arc<> Read more§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more