Commit 4287fcc002488327ddea203365410a2361ae1e0b
1 parent
0cdcd102
RC4: switch to pluggable crypto
Showing
8 changed files
with
84 additions
and
9 deletions
include/qpdf/QPDFCryptoImpl.hh
| ... | ... | @@ -50,6 +50,16 @@ class QPDF_DLL_CLASS QPDFCryptoImpl |
| 50 | 50 | virtual void MD5_finalize() = 0; |
| 51 | 51 | QPDF_DLL |
| 52 | 52 | virtual void MD5_digest(MD5_Digest) = 0; |
| 53 | + | |
| 54 | + // key_len of -1 means treat key_data as a null-terminated string | |
| 55 | + QPDF_DLL | |
| 56 | + virtual void RC4_init(unsigned char const* key_data, int key_len = -1) = 0; | |
| 57 | + // out_data = 0 means to encrypt/decrypt in place | |
| 58 | + QPDF_DLL | |
| 59 | + virtual void RC4_process(unsigned char* in_data, size_t len, | |
| 60 | + unsigned char* out_data = 0) = 0; | |
| 61 | + QPDF_DLL | |
| 62 | + virtual void RC4_finalize() = 0; | |
| 53 | 63 | }; |
| 54 | 64 | |
| 55 | 65 | #endif // QPDFCRYPTOIMPL_HH | ... | ... |
libqpdf/QPDFCrypto_native.cc
| ... | ... | @@ -25,3 +25,20 @@ QPDFCrypto_native::MD5_digest(MD5_Digest d) |
| 25 | 25 | this->md5->digest(d); |
| 26 | 26 | } |
| 27 | 27 | |
| 28 | +void | |
| 29 | +QPDFCrypto_native::RC4_init(unsigned char const* key_data, int key_len) | |
| 30 | +{ | |
| 31 | + this->rc4 = std::make_shared<RC4_native>(key_data, key_len); | |
| 32 | +} | |
| 33 | + | |
| 34 | +void | |
| 35 | +QPDFCrypto_native::RC4_process(unsigned char* in_data, size_t len, | |
| 36 | + unsigned char* out_data) | |
| 37 | +{ | |
| 38 | + this->rc4->process(in_data, len, out_data); | |
| 39 | +} | |
| 40 | + | |
| 41 | +void | |
| 42 | +QPDFCrypto_native::RC4_finalize() | |
| 43 | +{ | |
| 44 | +} | ... | ... |
libqpdf/RC4.cc
0 → 100644
| 1 | +#include <qpdf/RC4.hh> | |
| 2 | +#include <qpdf/QPDFCryptoProvider.hh> | |
| 3 | + | |
| 4 | +#include <string.h> | |
| 5 | + | |
| 6 | +RC4::RC4(unsigned char const* key_data, int key_len) : | |
| 7 | + crypto(QPDFCryptoProvider::getImpl()) | |
| 8 | +{ | |
| 9 | + this->crypto->RC4_init(key_data, key_len); | |
| 10 | +} | |
| 11 | + | |
| 12 | +void | |
| 13 | +RC4::process(unsigned char *in_data, size_t len, unsigned char* out_data) | |
| 14 | +{ | |
| 15 | + this->crypto->RC4_process(in_data, len, out_data); | |
| 16 | +} | ... | ... |
libqpdf/RC4_native.cc
| 1 | -#include <qpdf/RC4.hh> | |
| 1 | +#include <qpdf/RC4_native.hh> | |
| 2 | 2 | #include <qpdf/QIntC.hh> |
| 3 | 3 | |
| 4 | 4 | #include <string.h> |
| ... | ... | @@ -12,7 +12,7 @@ static void swap_byte(unsigned char &a, unsigned char &b) |
| 12 | 12 | b = t; |
| 13 | 13 | } |
| 14 | 14 | |
| 15 | -RC4::RC4(unsigned char const* key_data, int key_len) | |
| 15 | +RC4_native::RC4_native(unsigned char const* key_data, int key_len) | |
| 16 | 16 | { |
| 17 | 17 | if (key_len == -1) |
| 18 | 18 | { |
| ... | ... | @@ -38,7 +38,7 @@ RC4::RC4(unsigned char const* key_data, int key_len) |
| 38 | 38 | } |
| 39 | 39 | |
| 40 | 40 | void |
| 41 | -RC4::process(unsigned char *in_data, size_t len, unsigned char* out_data) | |
| 41 | +RC4_native::process(unsigned char *in_data, size_t len, unsigned char* out_data) | |
| 42 | 42 | { |
| 43 | 43 | if (out_data == 0) |
| 44 | 44 | { | ... | ... |
libqpdf/build.mk
libqpdf/qpdf/QPDFCrypto_native.hh
| ... | ... | @@ -4,6 +4,7 @@ |
| 4 | 4 | #include <qpdf/DLL.h> |
| 5 | 5 | #include <qpdf/QPDFCryptoImpl.hh> |
| 6 | 6 | #include <qpdf/MD5_native.hh> |
| 7 | +#include <qpdf/RC4_native.hh> | |
| 7 | 8 | #include <memory> |
| 8 | 9 | |
| 9 | 10 | class QPDFCrypto_native: public QPDFCryptoImpl |
| ... | ... | @@ -19,8 +20,14 @@ class QPDFCrypto_native: public QPDFCryptoImpl |
| 19 | 20 | virtual void MD5_finalize(); |
| 20 | 21 | virtual void MD5_digest(MD5_Digest); |
| 21 | 22 | |
| 23 | + virtual void RC4_init(unsigned char const* key_data, int key_len = -1); | |
| 24 | + virtual void RC4_process(unsigned char* in_data, size_t len, | |
| 25 | + unsigned char* out_data = 0); | |
| 26 | + virtual void RC4_finalize(); | |
| 27 | + | |
| 22 | 28 | private: |
| 23 | 29 | std::shared_ptr<MD5_native> md5; |
| 30 | + std::shared_ptr<RC4_native> rc4; | |
| 24 | 31 | }; |
| 25 | 32 | |
| 26 | 33 | #endif // QPDFCRYPTO_NATIVE_HH | ... | ... |
libqpdf/qpdf/RC4.hh
0 → 100644
| 1 | +#ifndef RC4_HH | |
| 2 | +#define RC4_HH | |
| 3 | + | |
| 4 | +#include <qpdf/QPDFCryptoImpl.hh> | |
| 5 | +#include <memory> | |
| 6 | +#include <cstring> | |
| 7 | + | |
| 8 | +class RC4 | |
| 9 | +{ | |
| 10 | + public: | |
| 11 | + // key_len of -1 means treat key_data as a null-terminated string | |
| 12 | + QPDF_DLL | |
| 13 | + RC4(unsigned char const* key_data, int key_len = -1); | |
| 14 | + | |
| 15 | + // out_data = 0 means to encrypt/decrypt in place | |
| 16 | + QPDF_DLL | |
| 17 | + void process(unsigned char* in_data, size_t len, | |
| 18 | + unsigned char* out_data = 0); | |
| 19 | + | |
| 20 | + private: | |
| 21 | + std::shared_ptr<QPDFCryptoImpl> crypto; | |
| 22 | +}; | |
| 23 | + | |
| 24 | +#endif // RC4_HH | ... | ... |
libqpdf/qpdf/RC4_native.hh
| 1 | -#ifndef RC4_HH | |
| 2 | -#define RC4_HH | |
| 1 | +#ifndef RC4_NATIVE_HH | |
| 2 | +#define RC4_NATIVE_HH | |
| 3 | 3 | |
| 4 | -#include <stddef.h> | |
| 4 | +#include <cstring> | |
| 5 | 5 | |
| 6 | -class RC4 | |
| 6 | +class RC4_native | |
| 7 | 7 | { |
| 8 | 8 | public: |
| 9 | 9 | // key_len of -1 means treat key_data as a null-terminated string |
| 10 | - RC4(unsigned char const* key_data, int key_len = -1); | |
| 10 | + RC4_native(unsigned char const* key_data, int key_len = -1); | |
| 11 | 11 | |
| 12 | 12 | // out_data = 0 means to encrypt/decrypt in place |
| 13 | 13 | void process(unsigned char* in_data, size_t len, |
| ... | ... | @@ -25,4 +25,4 @@ class RC4 |
| 25 | 25 | RC4Key key; |
| 26 | 26 | }; |
| 27 | 27 | |
| 28 | -#endif // RC4_HH | |
| 28 | +#endif // RC4_NATIVE_HH | ... | ... |