mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 18:57:35 +00:00
LibArchive: Ensure tar extended header length is within expected range
This commit is contained in:
parent
006bf1905b
commit
9f7cfb1394
1 changed files with 7 additions and 0 deletions
|
@ -93,11 +93,18 @@ inline ErrorOr<void> TarInputStream::for_each_extended_header(F func)
|
||||||
Optional<unsigned int> length = file_contents.substring_view(0, length_end_index.value()).to_uint();
|
Optional<unsigned int> length = file_contents.substring_view(0, length_end_index.value()).to_uint();
|
||||||
if (!length.has_value())
|
if (!length.has_value())
|
||||||
return Error::from_string_literal("Malformed extended header: Could not parse length.");
|
return Error::from_string_literal("Malformed extended header: Could not parse length.");
|
||||||
|
|
||||||
|
if (length_end_index.value() >= length.value())
|
||||||
|
return Error::from_string_literal("Malformed extended header: Header length too short.");
|
||||||
|
|
||||||
unsigned int remaining_length = length.value();
|
unsigned int remaining_length = length.value();
|
||||||
|
|
||||||
remaining_length -= length_end_index.value() + 1;
|
remaining_length -= length_end_index.value() + 1;
|
||||||
file_contents = file_contents.substring_view(length_end_index.value() + 1);
|
file_contents = file_contents.substring_view(length_end_index.value() + 1);
|
||||||
|
|
||||||
|
if (file_contents.length() < remaining_length - 1)
|
||||||
|
return Error::from_string_literal("Malformed extended header: Header length too large.");
|
||||||
|
|
||||||
// Extract the header.
|
// Extract the header.
|
||||||
StringView header = file_contents.substring_view(0, remaining_length - 1);
|
StringView header = file_contents.substring_view(0, remaining_length - 1);
|
||||||
file_contents = file_contents.substring_view(remaining_length - 1);
|
file_contents = file_contents.substring_view(remaining_length - 1);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue