| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 |
- // Copyright (C) 2004-2025 Artifex Software, Inc.
- //
- // This file is part of MuPDF.
- //
- // MuPDF is free software: you can redistribute it and/or modify it under the
- // terms of the GNU Affero General Public License as published by the Free
- // Software Foundation, either version 3 of the License, or (at your option)
- // any later version.
- //
- // MuPDF is distributed in the hope that it will be useful, but WITHOUT ANY
- // WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
- // FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
- // details.
- //
- // You should have received a copy of the GNU Affero General Public License
- // along with MuPDF. If not, see <https://www.gnu.org/licenses/agpl-3.0.en.html>
- //
- // Alternative licensing terms are available from the licensor.
- // For commercial licensing, see <https://www.artifex.com/> or contact
- // Artifex Software, Inc., 39 Mesa Street, Suite 108A, San Francisco,
- // CA 94129, USA, for further information.
- #ifndef MUPDF_FITZ_CRYPT_H
- #define MUPDF_FITZ_CRYPT_H
- #include "mupdf/fitz/system.h"
- /* md5 digests */
- /**
- Structure definition is public to enable stack
- based allocation. Do not access the members directly.
- */
- typedef struct
- {
- uint32_t lo, hi;
- uint32_t a, b, c, d;
- unsigned char buffer[64];
- } fz_md5;
- /**
- MD5 initialization. Begins an MD5 operation, writing a new
- context.
- Never throws an exception.
- */
- void fz_md5_init(fz_md5 *state);
- /**
- MD5 block update operation. Continues an MD5 message-digest
- operation, processing another message block, and updating the
- context.
- Never throws an exception.
- */
- void fz_md5_update(fz_md5 *state, const unsigned char *input, size_t inlen);
- /**
- MD5 block update operation. Continues an MD5 message-digest
- operation, processing an int64, and updating the context.
- Never throws an exception.
- */
- void fz_md5_update_int64(fz_md5 *state, int64_t i);
- /**
- MD5 finalization. Ends an MD5 message-digest operation, writing
- the message digest and zeroizing the context.
- Never throws an exception.
- */
- void fz_md5_final(fz_md5 *state, unsigned char digest[16]);
- /* sha-256 digests */
- /**
- Structure definition is public to enable stack
- based allocation. Do not access the members directly.
- */
- typedef struct
- {
- unsigned int state[8];
- unsigned int count[2];
- union {
- unsigned char u8[64];
- unsigned int u32[16];
- } buffer;
- } fz_sha256;
- /**
- SHA256 initialization. Begins an SHA256 operation, initialising
- the supplied context.
- Never throws an exception.
- */
- void fz_sha256_init(fz_sha256 *state);
- /**
- SHA256 block update operation. Continues an SHA256 message-
- digest operation, processing another message block, and updating
- the context.
- Never throws an exception.
- */
- void fz_sha256_update(fz_sha256 *state, const unsigned char *input, size_t inlen);
- /**
- MD5 finalization. Ends an MD5 message-digest operation, writing
- the message digest and zeroizing the context.
- Never throws an exception.
- */
- void fz_sha256_final(fz_sha256 *state, unsigned char digest[32]);
- /* sha-512 digests */
- /**
- Structure definition is public to enable stack
- based allocation. Do not access the members directly.
- */
- typedef struct
- {
- uint64_t state[8];
- unsigned int count[2];
- union {
- unsigned char u8[128];
- uint64_t u64[16];
- } buffer;
- } fz_sha512;
- /**
- SHA512 initialization. Begins an SHA512 operation, initialising
- the supplied context.
- Never throws an exception.
- */
- void fz_sha512_init(fz_sha512 *state);
- /**
- SHA512 block update operation. Continues an SHA512 message-
- digest operation, processing another message block, and updating
- the context.
- Never throws an exception.
- */
- void fz_sha512_update(fz_sha512 *state, const unsigned char *input, size_t inlen);
- /**
- SHA512 finalization. Ends an SHA512 message-digest operation,
- writing the message digest and zeroizing the context.
- Never throws an exception.
- */
- void fz_sha512_final(fz_sha512 *state, unsigned char digest[64]);
- /* sha-384 digests */
- typedef fz_sha512 fz_sha384;
- /**
- SHA384 initialization. Begins an SHA384 operation, initialising
- the supplied context.
- Never throws an exception.
- */
- void fz_sha384_init(fz_sha384 *state);
- /**
- SHA384 block update operation. Continues an SHA384 message-
- digest operation, processing another message block, and updating
- the context.
- Never throws an exception.
- */
- void fz_sha384_update(fz_sha384 *state, const unsigned char *input, size_t inlen);
- /**
- SHA384 finalization. Ends an SHA384 message-digest operation,
- writing the message digest and zeroizing the context.
- Never throws an exception.
- */
- void fz_sha384_final(fz_sha384 *state, unsigned char digest[64]);
- /* arc4 crypto */
- /**
- Structure definition is public to enable stack
- based allocation. Do not access the members directly.
- */
- typedef struct
- {
- unsigned x;
- unsigned y;
- unsigned char state[256];
- } fz_arc4;
- /**
- RC4 initialization. Begins an RC4 operation, writing a new
- context.
- Never throws an exception.
- */
- void fz_arc4_init(fz_arc4 *state, const unsigned char *key, size_t len);
- /**
- RC4 block encrypt operation; encrypt src into dst (both of
- length len) updating the RC4 state as we go.
- Never throws an exception.
- */
- void fz_arc4_encrypt(fz_arc4 *state, unsigned char *dest, const unsigned char *src, size_t len);
- /**
- RC4 finalization. Zero the context.
- Never throws an exception.
- */
- void fz_arc4_final(fz_arc4 *state);
- /* AES block cipher implementation from XYSSL */
- /**
- Structure definitions are public to enable stack
- based allocation. Do not access the members directly.
- */
- typedef struct
- {
- int nr; /* number of rounds */
- uint32_t *rk; /* AES round keys */
- uint32_t buf[68]; /* unaligned data */
- } fz_aes;
- #define FZ_AES_DECRYPT 0
- #define FZ_AES_ENCRYPT 1
- /**
- AES encryption initialization. Fills in the supplied context
- and prepares for encryption using the given key.
- Returns non-zero for error (key size other than 128/192/256).
- Never throws an exception.
- */
- int fz_aes_setkey_enc(fz_aes *ctx, const unsigned char *key, int keysize);
- /**
- AES decryption initialization. Fills in the supplied context
- and prepares for decryption using the given key.
- Returns non-zero for error (key size other than 128/192/256).
- Never throws an exception.
- */
- int fz_aes_setkey_dec(fz_aes *ctx, const unsigned char *key, int keysize);
- /**
- AES block processing. Encrypts or Decrypts (according to mode,
- which must match what was initially set up) length bytes (which
- must be a multiple of 16), using (and modifying) the insertion
- vector iv, reading from input, and writing to output.
- Never throws an exception.
- */
- void fz_aes_crypt_cbc(fz_aes *ctx, int mode, size_t length,
- unsigned char iv[16],
- const unsigned char *input,
- unsigned char *output );
- #endif
|