blob: a56e490fe81c5d3d34f9a5ed7f7d6683e179a378 (
plain) (
blame)
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
51
52
53
|
#ifndef QPDFCRYPTO_openssl_HH
#define QPDFCRYPTO_openssl_HH
#include <qpdf/QPDFCryptoImpl.hh>
#include <string>
#ifdef OPENSSL_IS_BORINGSSL
#include <openssl/cipher.h>
#include <openssl/digest.h>
#else
#include <openssl/evp.h>
#endif
#include <openssl/rand.h>
class QPDFCrypto_openssl: public QPDFCryptoImpl
{
public:
QPDFCrypto_openssl();
QPDF_DLL
~QPDFCrypto_openssl() override;
void provideRandomData(unsigned char* data, size_t len) override;
void MD5_init() override;
void MD5_update(unsigned char const* data, size_t len) override;
void MD5_finalize() override;
void MD5_digest(MD5_Digest) override;
void RC4_init(unsigned char const* key_data, int key_len = -1) override;
void RC4_process(unsigned char* in_data, size_t len,
unsigned char* out_data = 0) override;
void RC4_finalize() override;
void SHA2_init(int bits) override;
void SHA2_update(unsigned char const* data, size_t len) override;
void SHA2_finalize() override;
std::string SHA2_digest() override;
void rijndael_init(
bool encrypt, unsigned char const* key_data, size_t key_len,
bool cbc_mode, unsigned char* cbc_block) override;
void rijndael_process(
unsigned char* in_data, unsigned char* out_data) override;
void rijndael_finalize() override;
private:
EVP_MD_CTX* const md_ctx;
EVP_CIPHER_CTX* const cipher_ctx;
uint8_t md_out[EVP_MAX_MD_SIZE];
size_t sha2_bits;
};
#endif // QPDFCRYPTO_openssl_HH
|