pub struct Ecb<C: BlockCipher + BlockEncrypt + BlockDecrypt, P: Padding> { /* private fields */ }
Expand description
Electronic Codebook (ECB) block cipher mode instance.
Note that new
method ignores IV, so during initialization you can
just pass Default::default()
instead.
Trait Implementations§
Source§impl<C, P> BlockMode<C, P> for Ecb<C, P>
impl<C, P> BlockMode<C, P> for Ecb<C, P>
Source§fn new(cipher: C, _iv: &GenericArray<u8, U0>) -> Self
fn new(cipher: C, _iv: &GenericArray<u8, U0>) -> Self
Create a new block mode instance from initialized block cipher and IV.
Source§fn new_from_slices(key: &[u8], _iv: &[u8]) -> Result<Self, InvalidKeyIvLength>where
C: NewBlockCipher,
fn new_from_slices(key: &[u8], _iv: &[u8]) -> Result<Self, InvalidKeyIvLength>where
C: NewBlockCipher,
Create a new block mode instance from variable size key and IV. Read more
Source§fn encrypt_blocks(
&mut self,
blocks: &mut [GenericArray<u8, <C as BlockCipher>::BlockSize>],
)
fn encrypt_blocks( &mut self, blocks: &mut [GenericArray<u8, <C as BlockCipher>::BlockSize>], )
Encrypt blocks of data
Source§fn decrypt_blocks(
&mut self,
blocks: &mut [GenericArray<u8, <C as BlockCipher>::BlockSize>],
)
fn decrypt_blocks( &mut self, blocks: &mut [GenericArray<u8, <C as BlockCipher>::BlockSize>], )
Decrypt blocks of data
Source§fn new_fix(
key: &GenericArray<u8, <C as NewBlockCipher>::KeySize>,
iv: &GenericArray<u8, Self::IvSize>,
) -> Selfwhere
C: NewBlockCipher,
fn new_fix(
key: &GenericArray<u8, <C as NewBlockCipher>::KeySize>,
iv: &GenericArray<u8, Self::IvSize>,
) -> Selfwhere
C: NewBlockCipher,
Create a new block mode instance from fixed sized key and IV.
Source§fn encrypt(self, buffer: &mut [u8], pos: usize) -> Result<&[u8], BlockModeError>
fn encrypt(self, buffer: &mut [u8], pos: usize) -> Result<&[u8], BlockModeError>
Encrypt message in-place. Read more
Source§fn decrypt(self, buffer: &mut [u8]) -> Result<&[u8], BlockModeError>
fn decrypt(self, buffer: &mut [u8]) -> Result<&[u8], BlockModeError>
Decrypt message in-place. Read more
Source§fn encrypt_vec(self, plaintext: &[u8]) -> Vec<u8> ⓘ
fn encrypt_vec(self, plaintext: &[u8]) -> Vec<u8> ⓘ
Encrypt message and store result in vector.
Source§fn decrypt_vec(self, ciphertext: &[u8]) -> Result<Vec<u8>, BlockModeError>
fn decrypt_vec(self, ciphertext: &[u8]) -> Result<Vec<u8>, BlockModeError>
Encrypt message and store result in vector.
Source§impl<C: Clone + BlockCipher + BlockEncrypt + BlockDecrypt, P: Clone + Padding> Clone for Ecb<C, P>
impl<C: Clone + BlockCipher + BlockEncrypt + BlockDecrypt, P: Clone + Padding> Clone for Ecb<C, P>
Auto Trait Implementations§
impl<C, P> Freeze for Ecb<C, P>where
C: Freeze,
impl<C, P> RefUnwindSafe for Ecb<C, P>where
C: RefUnwindSafe,
P: RefUnwindSafe,
impl<C, P> Send for Ecb<C, P>
impl<C, P> Sync for Ecb<C, P>
impl<C, P> Unpin for Ecb<C, P>
impl<C, P> UnwindSafe for Ecb<C, P>where
C: UnwindSafe,
P: UnwindSafe,
Blanket Implementations§
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