Trigger virus if size mismatch
This commit is contained in:
parent
c06790d5e0
commit
321daf3ac8
2 changed files with 2 additions and 18 deletions
|
|
@ -54,23 +54,11 @@ bool scan_decoded_files(zip zip)
|
|||
LFH* lfh = (LFH*) (zip.start + zip.lfh_off[i]);
|
||||
|
||||
// Verify CDH/LFH parsed sizes to avoid undefined behavior
|
||||
// Trigger virus alert if mismatching sizes
|
||||
if (lfh->filename_length != zip.cdh_filename_length[i])
|
||||
{
|
||||
fprintf(
|
||||
stderr,
|
||||
"[ERROR] Mismatch in CDH/LFH filename lengths. Local file might be "
|
||||
"malformed.\nSkipping file...\n");
|
||||
continue;
|
||||
}
|
||||
|
||||
for (int k = 0; k < blocklist_size; k++)
|
||||
{
|
||||
char* filename = zip.start + zip.lfh_off[i] + sizeof(LFH);
|
||||
if (strcmp(blocklist[k], filename) == 0)
|
||||
{
|
||||
fprintf(stderr, "[ERROR] Forbidden filename found in zip archive.\n");
|
||||
fprintf(stderr, "[ERROR] Mismatch in CDH/LFH filename lengths.\n");
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
data* decoded = malloc(sizeof(data));
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue