mirror of
https://github.com/qpdf/qpdf.git
synced 2025-01-05 16:12:13 +00:00
2bc9121fa1
Lazily load MD5 and RC4 once in the life of the program. Only load the legacy provider if RC4 is actually being used.
68 lines
1.8 KiB
C++
68 lines
1.8 KiB
C++
#ifndef QPDFCRYPTO_OPENSSL_HH
|
|
#define QPDFCRYPTO_OPENSSL_HH
|
|
|
|
#include <qpdf/QPDFCryptoImpl.hh>
|
|
#include <string>
|
|
#if (defined(__GNUC__) || defined(__clang__))
|
|
# pragma GCC diagnostic push
|
|
# pragma GCC diagnostic ignored "-Wold-style-cast"
|
|
#endif
|
|
#include <openssl/opensslv.h>
|
|
#if !defined(OPENSSL_VERSION_MAJOR) || OPENSSL_VERSION_MAJOR < 3
|
|
# define QPDF_OPENSSL_1
|
|
#endif
|
|
#include <openssl/rand.h>
|
|
#ifdef OPENSSL_IS_BORINGSSL
|
|
# include <openssl/cipher.h>
|
|
# include <openssl/digest.h>
|
|
#else
|
|
# include <openssl/evp.h>
|
|
#endif
|
|
#if (defined(__GNUC__) || defined(__clang__))
|
|
# pragma GCC diagnostic pop
|
|
#endif
|
|
|
|
class QPDFCrypto_openssl: public QPDFCryptoImpl
|
|
{
|
|
public:
|
|
QPDFCrypto_openssl();
|
|
~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 const* 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
|