159 Commits

Author SHA1 Message Date
tbeu
1529686f37 Apply Clang format 2025-03-23 14:09:01 -07:00
Gabriel Landau
888d4713f6 Add gtest validating mz_os_get_file_date works on ADS 2025-01-07 21:58:03 -08:00
Cœur
6d45beb98d ignore number_entry_cd when recover 2024-11-18 12:38:38 -05:00
Mikhail Khachayants
d7f5fdd19a fix and improve fuzzers 2024-11-14 18:07:14 -05:00
Nathan Moinvaziri
7df56f7cc8 Split compat layer into different source files #806 2024-10-30 18:11:27 -04:00
Nathan Moinvaziri
2f380cbbbf Upgrade to GoogleTest Framework v1.13.0. 2024-06-07 19:26:12 -07:00
Tulio Magno Quites Machado Filho
fbd8443122 Fix unzLocateFile 3rd parameter
Replace the previous type with one that is compatible with an int in
order to be identical to the interface used in madler's zlib.

Fixes #745.
2023-12-11 13:47:31 -08:00
Nathan Moinvaziri
933cedf2bb Added poc zip file for unzip fuzzer from GH issue #739. 2023-11-13 09:40:13 -08:00
Nathan Moinvaziri
42b6b8997c Added poc zip file for unzip fuzzer from GH issue #740. 2023-11-13 09:37:41 -08:00
Thomas Gamper
83301fc2a1 mz_os.h - fix indentation; mz_os_win32.c - adjust for utf8 strings to be represented by char*; test_encoding.cc - remove useless cast 2023-06-08 11:25:14 -07:00
Thomas Gamper
0fa804504c Adjust mz_os_utf8_string_create to return char*, and mz_os_utf8_string_delete to take a char** 2023-06-08 11:25:14 -07:00
Sergey Markelov
1e2d77345a Fix test crypt.rand: random_bytes[0] can be 0, std::string(random_bytes)
gets empty C string.
2023-05-17 15:50:06 -07:00
Sergey Markelov
1fdcfef544 Support AAD in AES-GCM 2023-05-05 13:53:16 -04:00
Nathan Moinvaziri
780459d80c Change to use encrypt/decrypt final functions in mz_aes. 2023-04-26 19:58:41 -07:00
Nathan Moinvaziri
c958ac8f7c Add unit test for any length in AES-GCM. 2023-04-26 19:58:29 -07:00
Nathan Moinvaziri
99efb55637 Clean up and rename mz_crypt_aes interface. 2023-04-26 10:45:44 -07:00
Nathan Moinvaziri
faf14369d9 Rename crypto unit tests. 2023-04-26 09:47:27 -07:00
Nathan Moinvaziri
1c24464e50 Implement verification of AES-GCM tag with OpenSSL. 2023-04-25 23:28:37 -07:00
Nathan Moinvaziri
8964058d0c Added AES-GCM unit test and fixed BCrypt code. 2023-04-25 23:27:50 -07:00
Nathan Moinvaziri
b366e5cc6f Improve hmac unit test with multiple calls to update. 2023-04-25 18:17:40 -07:00
Nathan Moinvaziri
c74bb95701 Skip unsupported SHA hash algorithms in unit tests. 2023-04-24 10:28:54 -07:00
Nathan Moinvaziri
ce42d1e81c Added support for OpenSSL version 3. 2023-04-18 13:49:06 -07:00
Nathan Moinvaziri
fcde5c5ba7 Added optional support for AES CBC mode to mz_crypt_aes. 2023-04-17 14:32:06 -07:00
Nathan Moinvaziri
3394c29b52 Fixed wrong usage of create function for sha224 test. 2023-04-09 11:14:26 -07:00
Nathan Moinvaziri
f9203e7a55 Remove SHA224 support for Windows. 2023-04-09 11:14:26 -07:00
Nathan Moinvaziri
217adc9363 Remove first param from create functions.
Better handle low memory situations.
2023-04-09 11:14:26 -07:00
Nathan Moinvaziri
5f5d899164 Added PBKDF2 test vectors. 2023-04-07 18:22:07 -07:00
Mircea Baja
2eb6305346 Fixed incorrect handling of long odd length passwords 2023-03-14 09:40:49 -07:00
Nathan Moinvaziri
261041dabc Remove useless MZ_CUSTOM_ALLOC and MZ_CUSTOM_FREE.
It would have required an include to make it useful.
2023-02-24 14:23:04 -08:00
Nathan Moinvaziri
ffe32766e0 Fixed formatting in fuzzers. 2023-02-19 16:04:32 -08:00
Nathan Moinvaziri
f07faecdde Remove all comparisons to NULL. 2023-02-19 16:04:13 -08:00
Nathan Moinvaziri
03e4d2213d Remove copyright years. 2023-02-16 13:14:21 -08:00
Sergey Markelov
63f927345b Encryption support on UWP 2023-02-16 11:27:07 -08:00
Sergey Markelov
de9e622832 Test case for crypt random number generator 2023-02-13 17:32:25 -08:00
Sergey Markelov
d87de80493 Fix passed AES crypt test if native encrypt/decrypt functions fail 2023-02-13 17:32:25 -08:00
Sergey
dd6f10fe8c Remove unused computed_hash buffer in AES crypt test 2023-02-13 17:32:25 -08:00
Nathan Moinvaziri
1ede6f9b5e Fixed compare of narrow type with wide type in loop in mz_crypt_pbkdf2. 2023-02-12 16:03:25 -08:00
Nicolas Benes
0273af4bde Rewrite test certificates using more modern algorithms
The test.p12 file use the RC2-CBC and 3DES-CBC algorithms, which
are quite dated and require the `-legacy` option in openssl to read
them.

```console
$ openssl pkcs12 -in test.p12 -info -noout -legacy -passin pass:test
MAC: sha1, Iteration 1
MAC length: 20, salt length: 8
PKCS7 Encrypted data: pbeWithSHA1And40BitRC2-CBC, Iteration 2048
Certificate bag
PKCS7 Data
Shrouded Keybag: pbeWithSHA1And3-KeyTripleDES-CBC, Iteration 2048
```

Rewrite the test.p12 file with a current openssl (via p12 -> pem -> p12
conversion) to use more modern algorithms which do not require legacy
mode. Rewrite test.pem with a new export of test.p12.

```console
$ openssl pkcs12 -in test.p12 -info -noout -passin pass:test
MAC: sha256, Iteration 2048
MAC length: 32, salt length: 8
PKCS7 Encrypted data: PBES2, PBKDF2, AES-256-CBC, Iteration 2048, PRF hmacWithSHA256
Certificate bag
PKCS7 Data
Shrouded Keybag: PBES2, PBKDF2, AES-256-CBC, Iteration 2048, PRF hmacWithSHA256
```
2022-12-30 13:05:20 -08:00
Nathan Moinvaziri
4d13283bad Check to ensure GTest alias doesn't exist in parent project. 2022-11-29 16:51:25 -08:00
Nathan Moinvaziri
d7a10bb868 Silence warning about not being able to find GTest. 2022-11-29 16:02:05 -08:00
Sam James
be23c8d3b7 Search system for GTest before downloading. #654
Distributions often do builds with no network access available
for both security reasons and also to ensure reproducibility.

This change tells CMake to query the system for a copy of gtest,
but if it's not available, it'll fall back to downloading via
FetchContent.
2022-11-29 16:02:05 -08:00
Nathan Moinvaziri
9333ea834e Don't use pthreads on Windows for Google framework. 2022-10-15 15:55:40 -07:00
Nathan Moinvaziri
d03ca72a25 Implement Google test framework. 2022-10-13 09:51:47 -07:00
Nathan Moinvaziri
b89927c81d Fixed casing in test_get_file_date 2022-05-10 16:13:37 -07:00
Peter Harris
01af9bfb91 Add a test for mz_os_get_file_date 2022-05-10 16:13:37 -07:00
Sergey Markelov
9896383d2f Add SHA224, SHA384, SHA512 to crypt. 2022-01-18 10:31:11 -08:00
Nathan Moinvaziri
99dbed46c0 Fixed compiler warning in open_file_func assignment. 2021-05-08 12:21:42 -07:00
Nathan Moinvaziri
8847f22979 Add support for ioapi in compatibility layer. #566 2021-05-08 12:15:00 -07:00
Uilian Ries
9fb1dc29fe #475 Replace _WINDOWS by _WIN32
Signed-off-by: Uilian Ries <uilianries@gmail.com>
2021-04-13 15:56:13 -07:00
Nathan Moinvaziri
db95894646 Updated name of project to minizip-ng. 2021-01-23 16:19:05 -08:00