[−][src]Struct kuznechik::Kuznechik
Алгоритм синхронного шифрования "Кузнечик" (ГОСТ Р 34.12-2015, ГОСТ Р 34.13-2015)
Synchronous encryption algorithm "Kuznechik" (GOST R 34.12-2015, GOST R 34.13-2015)
Режимы шифрования / Encryption modes:
- AlgEcb - режим простой замены / Electronic Codebook (ЕСВ)
- AlgCtr - режим гаммирования / Counter (CTR)
- AlgOfb - режим гаммирования с обратной связью по выходу / Output Feedback (OFB)
- AlgCbc - режим простой замены с зацеплением / Cipher Block Chaining (СВС)
- AlgCfb - режим гаммирования с обратной связью по шифртексту / Cipher Feedback, (CFB)
- AlgMac - режим выработки имитовставки / Message Authentication Code (MAC)
Использование / Usage (AlgOfb):
use self::kuznechik::{Kuznechik, Algorithm, AlgOfb}; // Инициализация / Initialization let gamma = vec![0x12, 0x34, 0x56, 0x78, 0x90, 0xab, 0xce, 0xf0, 0xa1, 0xb2, 0xc3, 0xd4, 0xe5, 0xf0, 0x01, 0x12, 0x23, 0x34, 0x45, 0x56, 0x67, 0x78, 0x89, 0x90, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19]; let master_key = [0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff, 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0xfe, 0xdc, 0xba, 0x98, 0x76, 0x54, 0x32, 0x10, 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef]; let kuz = Kuznechik::new_with_master_key(master_key); let mut alg = AlgOfb::new(&kuz); alg.gamma = gamma.clone(); let data = vec![0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x00, 0xff, 0xee, 0xdd, 0xcc, 0xbb, 0xaa, 0x99, 0x88, 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xee, 0xff, 0x0a, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xee, 0xff, 0x0a, 0x00, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xee, 0xff, 0x0a, 0x00, 0x11]; // Шифрование / Encryption let enc_data = alg.encrypt(data.clone()); assert_eq!(enc_data, vec![0x81, 0x80, 0x0a, 0x59, 0xb1, 0x84, 0x2b, 0x24, 0xff, 0x1f, 0x79, 0x5e, 0x89, 0x7a, 0xbd, 0x95, 0xed, 0x5b, 0x47, 0xa7, 0x04, 0x8c, 0xfa, 0xb4, 0x8f, 0xb5, 0x21, 0x36, 0x9d, 0x93, 0x26, 0xbf, 0x66, 0xa2, 0x57, 0xac, 0x3c, 0xa0, 0xb8, 0xb1, 0xc8, 0x0f, 0xe7, 0xfc, 0x10, 0x28, 0x8a, 0x13, 0x20, 0x3e, 0xbb, 0xc0, 0x66, 0x13, 0x86, 0x60, 0xa0, 0x29, 0x22, 0x43, 0xf6, 0x90, 0x31, 0x50]); // Расшифрование / Decryption alg.gamma = gamma; let dec_data = alg.decrypt(enc_data); assert_eq!(dec_data, data);
Implementations
impl Kuznechik
[src]
pub fn new(password: &str) -> Result<Kuznechik, &'static str>
[src]
pub fn new_with_master_key(master_key: [u8; 32]) -> Kuznechik
[src]
pub fn set_password(&mut self, password: &str)
[src]
Auto Trait Implementations
impl RefUnwindSafe for Kuznechik
[src]
impl Send for Kuznechik
[src]
impl Sync for Kuznechik
[src]
impl Unpin for Kuznechik
[src]
impl UnwindSafe for Kuznechik
[src]
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,