mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 18:32:28 -05:00
LibWeb/MimeSniff: Add match an audio or video type pattern algorithm
This commit is contained in:
parent
62ca3b518b
commit
d5e5a1138f
2 changed files with 54 additions and 1 deletions
|
@ -70,6 +70,12 @@ TEST_CASE(compute_unknown_mime_type)
|
|||
mime_type_to_headers_map.set("image/webp"sv, { "RIFF\x00\x00\x00\x00WEBPVP"sv });
|
||||
mime_type_to_headers_map.set("image/png"sv, { "\x89PNG\x0D\x0A\x1A\x0A"sv });
|
||||
mime_type_to_headers_map.set("image/jpeg"sv, { "\xFF\xD8\xFF"sv });
|
||||
mime_type_to_headers_map.set("audio/aiff"sv, { "FORM\x00\x00\x00\x00\x41IFF"sv });
|
||||
mime_type_to_headers_map.set("audio/mpeg"sv, { "ID3"sv });
|
||||
mime_type_to_headers_map.set("application/ogg"sv, { "OggS\x00"sv });
|
||||
mime_type_to_headers_map.set("audio/midi"sv, { "MThd\x00\x00\x00\x06"sv });
|
||||
mime_type_to_headers_map.set("video/avi"sv, { "RIFF\x00\x00\x00\x00\x41\x56\x49\x20"sv });
|
||||
mime_type_to_headers_map.set("audio/wave"sv, { "RIFF\x00\x00\x00\x00WAVE"sv });
|
||||
|
||||
for (auto const& mime_type_to_headers : mime_type_to_headers_map) {
|
||||
auto mime_type = mime_type_to_headers.key;
|
||||
|
|
|
@ -136,6 +136,52 @@ ErrorOr<Optional<MimeType>> match_an_image_type_pattern(ReadonlyBytes input)
|
|||
return OptionalNone {};
|
||||
}
|
||||
|
||||
// https://mimesniff.spec.whatwg.org/#matching-an-audio-or-video-type-pattern
|
||||
ErrorOr<Optional<MimeType>> match_an_audio_or_video_type_pattern(ReadonlyBytes input)
|
||||
{
|
||||
// 1. Execute the following steps for each row row in the following table:
|
||||
static Array<BytePatternTableRow, 6> constexpr pattern_table {
|
||||
// The string "FORM" followed by four bytes followed by the string "AIFF", the AIFF signature.
|
||||
BytePatternTableRow { "\x46\x4F\x52\x4D\x00\x00\x00\x00\x41\x49\x46\x46"sv,
|
||||
"\xFF\xFF\xFF\xFF\x00\x00\x00\x00\xFF\xFF\xFF\xFF"sv, no_ignored_bytes, "audio/aiff"sv },
|
||||
|
||||
// The string "ID3", the ID3v2-tagged MP3 signature.
|
||||
BytePatternTableRow { "\x49\x44\x33"sv, "\xFF\xFF\xFF"sv, no_ignored_bytes, "audio/mpeg"sv },
|
||||
|
||||
// The string "OggS" followed by NUL, the Ogg container signature.
|
||||
BytePatternTableRow { "\x4F\x67\x67\x53\x00"sv, "\xFF\xFF\xFF\xFF\xFF"sv, no_ignored_bytes, "application/ogg"sv },
|
||||
|
||||
// The string "MThd" followed by four bytes representing the number 6 in 32 bits (big-endian), the MIDI signature.
|
||||
BytePatternTableRow { "\x4D\x54\x68\x64\x00\x00\x00\x06"sv, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF"sv, no_ignored_bytes, "audio/midi"sv },
|
||||
|
||||
// The string "RIFF" followed by four bytes followed by the string "AVI ", the AVI signature.
|
||||
BytePatternTableRow { "\x52\x49\x46\x46\x00\x00\x00\x00\x41\x56\x49\x20"sv,
|
||||
"\xFF\xFF\xFF\xFF\x00\x00\x00\x00\xFF\xFF\xFF\xFF"sv, no_ignored_bytes, "video/avi"sv },
|
||||
|
||||
// The string "RIFF" followed by four bytes followed by the string "WAVE", the WAVE signature.
|
||||
BytePatternTableRow { "\x52\x49\x46\x46\x00\x00\x00\x00\x57\x41\x56\x45"sv,
|
||||
"\xFF\xFF\xFF\xFF\x00\x00\x00\x00\xFF\xFF\xFF\xFF"sv, no_ignored_bytes, "audio/wave"sv }
|
||||
};
|
||||
|
||||
for (auto const& row : pattern_table) {
|
||||
// 1. Let patternMatched be the result of the pattern matching algorithm given input, the
|
||||
// value in the first column of row, the value in the second column of row, and the
|
||||
// value in the third column of row.
|
||||
auto pattern_matched = pattern_matching_algorithm(input, row.byte_pattern.bytes(), row.pattern_mask.bytes(), row.ignored_leading_bytes);
|
||||
|
||||
// 2. If patternMatched is true, return the value in the fourth column of row.
|
||||
if (pattern_matched)
|
||||
return MimeType::parse(row.mime_type);
|
||||
}
|
||||
|
||||
// FIXME: 2. If input matches the signature for MP4, return "video/mp4".
|
||||
// FIXME: 3. If input matches the signature for WebM, return "video/webm".
|
||||
// FIXME: 4. If input matches the signature for MP3 without ID3, return "audio/mpeg".
|
||||
|
||||
// 5. Return undefined.
|
||||
return OptionalNone {};
|
||||
}
|
||||
|
||||
// https://mimesniff.spec.whatwg.org/#rules-for-identifying-an-unknown-mime-type
|
||||
ErrorOr<MimeType> rules_for_identifying_an_unknown_mime_type(Resource const& resource, bool sniff_scriptable = false)
|
||||
{
|
||||
|
@ -261,7 +307,8 @@ ErrorOr<MimeType> rules_for_identifying_an_unknown_mime_type(Resource const& res
|
|||
if (matched_type.has_value())
|
||||
return matched_type.release_value();
|
||||
|
||||
// FIXME: 5. Set matchedType to the result of executing the audio or video type pattern matching algorithm given resource’s resource header.
|
||||
// 5. Set matchedType to the result of executing the audio or video type pattern matching algorithm given resource’s resource header.
|
||||
matched_type = TRY(match_an_audio_or_video_type_pattern(resource.resource_header()));
|
||||
|
||||
// 6. If matchedType is not undefined, return matchedType.
|
||||
if (matched_type.has_value())
|
||||
|
|
Loading…
Add table
Reference in a new issue