forked from ph4r05/Whitebox-crypto-AES
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEncTools.h
50 lines (42 loc) · 1.38 KB
/
EncTools.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
//
// Created by Dusan Klinec on 30.12.17.
//
#ifndef WHITEBOX_CRYPTO_AES_ENCTOOLS_H
#define WHITEBOX_CRYPTO_AES_ENCTOOLS_H
#include "WBAESGenerator.h"
#include "InputObject.h"
class EncTools {
public:
/**
*
* @param decrypt true/false
* @param inf [in] input stream to process
* @param out [in, optional] output stream to return result to
* @param coding [in, optional] external coding
* @param cacc [in,out, optional] time_t time accumulator
* @param pacc [in,out, optional] clock_t time accumulator
*/
static void processData(bool decrypt, WBAES * wbaes, WBAESGenerator * generator,
InputObject<BYTE> * inf, InputObject<BYTE> * out,
ExtEncoding * coding = nullptr, bool padding = false, bool cbc = false, BYTE * iv = nullptr,
time_t *cacc = nullptr, clock_t * pacc = nullptr);
/**
* Simple IV xor
* @param buffer
* @param iv
*/
static void xorIv(BYTE * buffer, const BYTE * iv){
for(int ividx=0; ividx < N_BYTES; ++ividx){
buffer[ividx] ^= iv[ividx];
}
}
/**
* Simple AES block copy
* @param dstBlock
* @param srcBlock
*/
static void copyBlock(BYTE * dstBlock, const BYTE * srcBlock){
memcpy(dstBlock, srcBlock, N_BYTES);
}
};
#endif //WHITEBOX_CRYPTO_AES_ENCTOOLS_H