#[non_exhaustive]pub enum Config<'a> {
AES128 {
mode: Mode,
iv: Option<&'a [u8; 16]>,
key: &'a [u8; 16],
},
AES192 {
mode: Mode,
iv: Option<&'a [u8; 16]>,
key: &'a [u8; 24],
},
AES256 {
mode: Mode,
iv: Option<&'a [u8; 16]>,
key: &'a [u8; 32],
},
DES {
mode: Mode,
iv: Option<&'a [u8; 8]>,
key: &'a [u8; 8],
},
TDES {
mode: Mode,
iv: Option<&'a [u8; 8]>,
key: &'a [u8; 24],
},
CAST {
mode: Mode,
iv: Option<&'a [u8; 8]>,
key: &'a [u8],
padding: Padding,
},
RC4 {
key: &'a [u8],
},
RC2 {
mode: Mode,
iv: Option<&'a [u8; 8]>,
key: &'a [u8],
},
Blowfish {
mode: Mode,
iv: Option<&'a [u8; 8]>,
key: &'a [u8],
},
}Expand description
The configuration for a Cryptor.
let config = Config::AES256 {
mode: Mode::CTR,
iv: Some(b"use random iv :)"),
key: b"aes128 key must be 32 bytes long",
};Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Trait Implementations§
impl<'a> Copy for Config<'a>
impl<'a> StructuralPartialEq for Config<'a>
Auto Trait Implementations§
impl<'a> Freeze for Config<'a>
impl<'a> RefUnwindSafe for Config<'a>
impl<'a> Send for Config<'a>
impl<'a> Sync for Config<'a>
impl<'a> Unpin for Config<'a>
impl<'a> UnwindSafe for Config<'a>
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