diff options
Diffstat (limited to 'libtests/aes.cc')
-rw-r--r-- | libtests/aes.cc | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/libtests/aes.cc b/libtests/aes.cc new file mode 100644 index 0000000..ad2f0dd --- /dev/null +++ b/libtests/aes.cc @@ -0,0 +1,112 @@ +#include <qpdf/Pl_AES_PDF.hh> +#include <qpdf/Pl_StdioFile.hh> + +#include <stdio.h> +#include <string.h> +#include <iostream> +#include <stdlib.h> + +static void usage() +{ + std::cerr << "Usage: aes [+-]cbc { -encrypt | -decrypt }" + << " hex-key infile outfile" << std::endl; + exit(2); +} + +int main(int argc, char* argv[]) +{ + if (argc != 6) + { + usage(); + } + + char* cbc = argv[1]; + char* action = argv[2]; + char* hexkey = argv[3]; + char* infilename = argv[4]; + char* outfilename = argv[5]; + + bool cbc_mode = true; + if (strcmp(cbc, "-cbc") == 0) + { + cbc_mode = false; + } + else if (strcmp(cbc, "+cbc") != 0) + { + usage(); + } + + bool encrypt = true; + if (strcmp(action, "-decrypt") == 0) + { + encrypt = false; + } + else if (strcmp(action, "-encrypt") != 0) + { + usage(); + } + + unsigned int hexkeylen = (unsigned int)strlen(hexkey); + unsigned int keylen = hexkeylen / 2; + if (keylen != Pl_AES_PDF::key_size) + { + std::cerr << "key length must be " << Pl_AES_PDF::key_size + << " bytes" << std::endl; + exit(2); + } + + FILE* infile = fopen(infilename, "rb"); + if (infile == 0) + { + std::cerr << "can't open " << infilename << std::endl; + exit(2); + } + + FILE* outfile = fopen(outfilename, "wb"); + if (outfile == 0) + { + std::cerr << "can't open " << outfilename << std::endl; + exit(2); + } + + unsigned char key[Pl_AES_PDF::key_size]; + for (unsigned int i = 0; i < strlen(hexkey); i += 2) + { + char t[3]; + t[0] = hexkey[i]; + t[1] = hexkey[i + 1]; + t[2] = '\0'; + + long val = strtol(t, 0, 16); + key[i/2] = (unsigned char) val; + } + + Pl_StdioFile* out = new Pl_StdioFile("stdout", outfile); + Pl_AES_PDF* aes = new Pl_AES_PDF("aes_128_cbc", out, encrypt, key); + if (! cbc_mode) + { + aes->disableCBC(); + } + + // 16 < buffer size, buffer_size is not a multiple of 8 for testing + unsigned char buf[83]; + bool done = false; + while (! done) + { + size_t len = fread(buf, 1, sizeof(buf), infile); + if (len <= 0) + { + done = true; + } + else + { + aes->write(buf, len); + } + } + aes->finish(); + delete aes; + delete out; + fclose(infile); + fclose(outfile); + return 0; +} |