mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-10-05 15:49:15 +00:00
LibWeb: Implement type attribute validation for image loading
This change fixes image loading where unsupported image types are included in the list of source elements.
This commit is contained in:
parent
a9604ece2b
commit
a0561ea9b2
Notes:
sideshowbarker
2024-07-17 05:05:51 +09:00
Author: https://github.com/lukewarlow
Commit: a0561ea9b2
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/234
Reviewed-by: https://github.com/AtkinsSJ ✅
Reviewed-by: https://github.com/tcl3 ✅
1 changed files with 35 additions and 1 deletions
|
@ -932,6 +932,33 @@ void HTMLImageElement::restart_the_animation()
|
|||
}
|
||||
}
|
||||
|
||||
static bool is_supported_image_type(String const& type)
|
||||
{
|
||||
if (type.is_empty())
|
||||
return true;
|
||||
if (!type.starts_with_bytes("image/"sv, CaseSensitivity::CaseInsensitive))
|
||||
return false;
|
||||
// FIXME: These should be derived from ImageDecoder
|
||||
if (type.equals_ignoring_ascii_case("image/bmp"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/gif"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/vnd.microsoft.icon"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/x-icon"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/jpeg"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/jpg"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/pjpeg"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/jxl"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/png"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/apng"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/x-png"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/tiff"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/tinyvg"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/webp"sv)
|
||||
|| type.equals_ignoring_ascii_case("image/svg+xml"sv))
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/images.html#update-the-source-set
|
||||
static void update_the_source_set(DOM::Element& element)
|
||||
{
|
||||
|
@ -1041,8 +1068,15 @@ static void update_the_source_set(DOM::Element& element)
|
|||
// 7. Parse child's sizes attribute, and let source set's source size be the returned value.
|
||||
source_set.m_source_size = parse_a_sizes_attribute(element.document(), child->get_attribute_value(HTML::AttributeNames::sizes));
|
||||
|
||||
// FIXME: 8. If child has a type attribute, and its value is an unknown or unsupported MIME type, continue to the next child.
|
||||
// 8. If child has a type attribute, and its value is an unknown or unsupported MIME type, continue to the next child.
|
||||
if (child->has_attribute(HTML::AttributeNames::type)) {
|
||||
auto mime_type = child->get_attribute_value(HTML::AttributeNames::type);
|
||||
if (is<HTMLImageElement>(element)) {
|
||||
if (!is_supported_image_type(mime_type))
|
||||
continue;
|
||||
}
|
||||
|
||||
// FIXME: Implement this step for link elements
|
||||
}
|
||||
|
||||
// FIXME: 9. If child has width or height attributes, set el's dimension attribute source to child.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue