view src/win32/7zip/7z/CPP/7zip/Crypto/MyAes.cpp @ 1:f9f4f1b99eed

importing src directory
author Robert McIntyre <rlm@mit.edu>
date Sat, 03 Mar 2012 10:31:27 -0600
parents
children
line wrap: on
line source
1 // Crypto/MyAes.cpp
3 #include "StdAfx.h"
5 #include "MyAes.h"
7 namespace NCrypto {
9 struct CAesTabInit { CAesTabInit() { AesGenTables();} } g_AesTabInit;
11 STDMETHODIMP CAesCbcEncoder::Init() { return S_OK; }
13 STDMETHODIMP_(UInt32) CAesCbcEncoder::Filter(Byte *data, UInt32 size)
14 {
15 return (UInt32)AesCbc_Encode(&Aes, data, size);
16 }
18 STDMETHODIMP CAesCbcEncoder::SetKey(const Byte *data, UInt32 size)
19 {
20 if ((size & 0x7) != 0 || size < 16 || size > 32)
21 return E_INVALIDARG;
22 Aes_SetKeyEncode(&Aes.aes, data, size);
23 return S_OK;
24 }
26 STDMETHODIMP CAesCbcEncoder::SetInitVector(const Byte *data, UInt32 size)
27 {
28 if (size != AES_BLOCK_SIZE)
29 return E_INVALIDARG;
30 AesCbc_Init(&Aes, data);
31 return S_OK;
32 }
34 STDMETHODIMP CAesCbcDecoder::Init() { return S_OK; }
36 STDMETHODIMP_(UInt32) CAesCbcDecoder::Filter(Byte *data, UInt32 size)
37 {
38 return (UInt32)AesCbc_Decode(&Aes, data, size);
39 }
41 STDMETHODIMP CAesCbcDecoder::SetKey(const Byte *data, UInt32 size)
42 {
43 if ((size & 0x7) != 0 || size < 16 || size > 32)
44 return E_INVALIDARG;
45 Aes_SetKeyDecode(&Aes.aes, data, size);
46 return S_OK;
47 }
49 STDMETHODIMP CAesCbcDecoder::SetInitVector(const Byte *data, UInt32 size)
50 {
51 if (size != AES_BLOCK_SIZE)
52 return E_INVALIDARG;
53 AesCbc_Init(&Aes, data);
54 return S_OK;
55 }
57 }