mirror of
https://github.com/zlib-ng/minizip-ng
synced 2025-03-28 21:13:18 +00:00
Fixed pk_verify not being set when writing encrypted entries.
This commit is contained in:
parent
c76f28f217
commit
215a7a84dc
40
mz_zip.c
40
mz_zip.c
@ -187,6 +187,16 @@ static int32_t mz_zip_search_zip64_eocd(void *stream, const int64_t end_central_
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Get PKWARE traditional encryption verifier */
|
||||||
|
static uint16_t mz_zip_get_pk_verify(uint32_t dos_date, uint64_t crc, uint16_t flag)
|
||||||
|
{
|
||||||
|
/* Info-ZIP modification to ZipCrypto format: if bit 3 of the general
|
||||||
|
* purpose bit flag is set, it uses high byte of 16-bit File Time. */
|
||||||
|
if (flag & MZ_ZIP_FLAG_DATA_DESCRIPTOR)
|
||||||
|
return ((dos_date >> 16) & 0xff) << 8 | ((dos_date >> 8) & 0xff);
|
||||||
|
return ((crc >> 16) & 0xff) << 8 | ((crc >> 24) & 0xff);
|
||||||
|
}
|
||||||
|
|
||||||
/* Get info about the current file in the zip file */
|
/* Get info about the current file in the zip file */
|
||||||
static int32_t mz_zip_entry_read_header(void *stream, uint8_t local, mz_zip_file *file_info, void *file_extra_stream) {
|
static int32_t mz_zip_entry_read_header(void *stream, uint8_t local, mz_zip_file *file_info, void *file_extra_stream) {
|
||||||
uint64_t ntfs_time = 0;
|
uint64_t ntfs_time = 0;
|
||||||
@ -241,15 +251,8 @@ static int32_t mz_zip_entry_read_header(void *stream, uint8_t local, mz_zip_file
|
|||||||
err = mz_stream_read_uint32(stream, &file_info->crc);
|
err = mz_stream_read_uint32(stream, &file_info->crc);
|
||||||
#ifdef HAVE_PKCRYPT
|
#ifdef HAVE_PKCRYPT
|
||||||
if (err == MZ_OK && file_info->flag & MZ_ZIP_FLAG_ENCRYPTED) {
|
if (err == MZ_OK && file_info->flag & MZ_ZIP_FLAG_ENCRYPTED) {
|
||||||
/* Info-ZIP modification to ZipCrypto format: if bit 3 of the general
|
/* Use dos_date from header instead of derived from time in zip extensions */
|
||||||
* purpose bit flag is set, it uses high byte of 16-bit File Time. */
|
file_info->pk_verify = mz_zip_get_pk_verify(dos_date, file_info->crc, file_info->flag);
|
||||||
|
|
||||||
if (file_info->flag & MZ_ZIP_FLAG_DATA_DESCRIPTOR)
|
|
||||||
file_info->pk_verify = ((dos_date >> 16) & 0xff) << 8 |
|
|
||||||
((dos_date >> 8) & 0xff);
|
|
||||||
else
|
|
||||||
file_info->pk_verify = ((file_info->crc >> 16) & 0xff) << 8 |
|
|
||||||
((file_info->crc >> 24) & 0xff);
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (err == MZ_OK) {
|
if (err == MZ_OK) {
|
||||||
@ -1942,16 +1945,23 @@ int32_t mz_zip_entry_write_open(void *handle, const mz_zip_file *file_info, int1
|
|||||||
|
|
||||||
mz_stream_get_prop_int64(zip->stream, MZ_STREAM_PROP_DISK_NUMBER, &disk_number);
|
mz_stream_get_prop_int64(zip->stream, MZ_STREAM_PROP_DISK_NUMBER, &disk_number);
|
||||||
zip->file_info.disk_number = (uint32_t)disk_number;
|
zip->file_info.disk_number = (uint32_t)disk_number;
|
||||||
|
|
||||||
zip->file_info.disk_offset = mz_stream_tell(zip->stream);
|
zip->file_info.disk_offset = mz_stream_tell(zip->stream);
|
||||||
|
|
||||||
|
if (zip->file_info.flag & MZ_ZIP_FLAG_ENCRYPTED) {
|
||||||
|
#ifdef HAVE_PKCRYPT
|
||||||
|
/* Pre-calculated CRC value is required for PKWARE traditional encryption */
|
||||||
|
uint32_t dos_date = mz_zip_time_t_to_dos_date(zip->file_info.modified_date);
|
||||||
|
zip->file_info.pk_verify = mz_zip_get_pk_verify(dos_date, zip->file_info.crc, zip->file_info.flag);
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_WZAES
|
||||||
|
if (zip->file_info.aes_version && zip->file_info.aes_encryption_mode == 0)
|
||||||
|
zip->file_info.aes_encryption_mode = MZ_AES_ENCRYPTION_MODE_256;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
zip->file_info.crc = 0;
|
zip->file_info.crc = 0;
|
||||||
zip->file_info.compressed_size = 0;
|
zip->file_info.compressed_size = 0;
|
||||||
|
|
||||||
#ifdef HAVE_WZAES
|
|
||||||
if (zip->file_info.aes_version && zip->file_info.aes_encryption_mode == 0)
|
|
||||||
zip->file_info.aes_encryption_mode = MZ_AES_ENCRYPTION_MODE_256;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if ((compress_level == 0) || (is_dir))
|
if ((compress_level == 0) || (is_dir))
|
||||||
zip->file_info.compression_method = MZ_COMPRESS_METHOD_STORE;
|
zip->file_info.compression_method = MZ_COMPRESS_METHOD_STORE;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user