cbc 0.1.2

Cipher Block Chaining (CBC) block cipher mode of operation
Documentation
use aes::*;
use cbc::{Decryptor, Encryptor};
use cipher::{block_mode_dec_test, block_mode_enc_test, iv_state_test};

iv_state_test!(aes128_cbc_enc_iv_state, Encryptor<Aes128>, encrypt);
iv_state_test!(aes128_cbc_dec_iv_state, Decryptor<Aes128>, decrypt);
iv_state_test!(aes192_cbc_enc_iv_state, Encryptor<Aes192>, encrypt);
iv_state_test!(aes192_cbc_dec_iv_state, Decryptor<Aes192>, decrypt);
iv_state_test!(aes256_cbc_enc_iv_state, Encryptor<Aes256>, encrypt);
iv_state_test!(aes256_cbc_dec_iv_state, Decryptor<Aes256>, decrypt);

// Test vectors from CVAP "AES Multiblock Message Test (MMT) Sample Vectors":
// <https://csrc.nist.gov/Projects/Cryptographic-Algorithm-Validation-Program/Block-Ciphers>
block_mode_enc_test!(aes128_cbc_enc_test, "aes128", Encryptor<Aes128>);
block_mode_dec_test!(aes128_cbc_dec_test, "aes128", Decryptor<Aes128>);
block_mode_enc_test!(aes128enc_cbc_enc_test, "aes128", Encryptor<Aes128Enc>);
block_mode_dec_test!(aes128dec_cbc_dec_test, "aes128", Decryptor<Aes128Dec>);
block_mode_enc_test!(aes192_cbc_enc_test, "aes192", Encryptor<Aes192>);
block_mode_dec_test!(aes192_cbc_dec_test, "aes192", Decryptor<Aes192>);
block_mode_enc_test!(aes192enc_cbc_enc_test, "aes192", Encryptor<Aes192Enc>);
block_mode_dec_test!(aes192dec_cbc_dec_test, "aes192", Decryptor<Aes192Dec>);
block_mode_enc_test!(aes256_cbc_enc_test, "aes256", Encryptor<Aes256>);
block_mode_dec_test!(aes256_cbc_dec_test, "aes256", Decryptor<Aes256>);
block_mode_enc_test!(aes256enc_cbc_enc_test, "aes256", Encryptor<Aes256Enc>);
block_mode_dec_test!(aes256dec_cbc_dec_test, "aes256", Decryptor<Aes256Dec>);