LibWeb: Limit HTMLTableCellElement colSpan to allowed values

This change ensures that `colSpan` is clamped to the maximum value of
1000 if the given value is larger than 2147483647.
This commit is contained in:
Tim Ledbetter 2024-11-30 22:29:22 +00:00 committed by Andreas Kling
parent d02b763cd6
commit 4630b1a44b
Notes: github-actions[bot] 2024-12-02 09:26:37 +00:00
4 changed files with 113 additions and 7 deletions

View file

@ -108,14 +108,25 @@ void HTMLTableCellElement::apply_presentational_hints(CSS::StyleProperties& styl
// This implements step 8 in the spec here:
// https://html.spec.whatwg.org/multipage/tables.html#algorithm-for-processing-rows
unsigned int HTMLTableCellElement::col_span() const
WebIDL::UnsignedLong HTMLTableCellElement::col_span() const
{
auto optional_value = Web::HTML::parse_non_negative_integer(get_attribute_value(HTML::AttributeNames::colspan));
auto col_span_attribute = get_attribute(HTML::AttributeNames::colspan);
if (!col_span_attribute.has_value())
return 1;
auto optional_value_digits = Web::HTML::parse_non_negative_integer_digits(*col_span_attribute);
// If parsing that value failed, or returned zero, or if the attribute is absent, then let colspan be 1, instead.
if (!optional_value.has_value() || optional_value.value() == 0) {
if (!optional_value_digits.has_value())
return 1;
}
auto optional_value = optional_value_digits->to_number<i64>(TrimWhitespace::No);
if (optional_value == 0)
return 1;
// NOTE: If there is no value at this point the value must be larger than NumericLimits<i64>::max(), so return the maximum value of 1000.
if (!optional_value.has_value())
return 1000;
auto value = optional_value.value();
@ -127,8 +138,10 @@ unsigned int HTMLTableCellElement::col_span() const
return value;
}
WebIDL::ExceptionOr<void> HTMLTableCellElement::set_col_span(unsigned int value)
WebIDL::ExceptionOr<void> HTMLTableCellElement::set_col_span(WebIDL::UnsignedLong value)
{
if (value > 2147483647)
value = 1;
return set_attribute(HTML::AttributeNames::colspan, String::number(value));
}

View file

@ -18,10 +18,10 @@ class HTMLTableCellElement final : public HTMLElement {
public:
virtual ~HTMLTableCellElement() override;
unsigned col_span() const;
WebIDL::UnsignedLong col_span() const;
unsigned row_span() const;
WebIDL::ExceptionOr<void> set_col_span(unsigned);
WebIDL::ExceptionOr<void> set_col_span(WebIDL::UnsignedLong);
WebIDL::ExceptionOr<void> set_row_span(unsigned);
WebIDL::Long cell_index() const;

View file

@ -18,6 +18,10 @@ canvas.getAttribute("width") after canvas.setAttribute("width", "4294967295"): 4
canvas.width after canvas.setAttribute("width", "4294967295"): 300
canvas.getAttribute("width") after canvas.width = 4294967295: 300
canvas.width after canvas.width = 4294967295: 300
canvas.getAttribute("width") after canvas.setAttribute("width", "4294967296"): 4294967296
canvas.width after canvas.setAttribute("width", "4294967296"): 300
canvas.getAttribute("width") after canvas.width = 4294967296: 0
canvas.width after canvas.width = 4294967296: 0
canvas.getAttribute("height") after canvas.setAttribute("height", "0"): 0
canvas.height after canvas.setAttribute("height", "0"): 0
canvas.getAttribute("height") after canvas.height = 0: 0
@ -38,6 +42,10 @@ canvas.getAttribute("height") after canvas.setAttribute("height", "4294967295"):
canvas.height after canvas.setAttribute("height", "4294967295"): 150
canvas.getAttribute("height") after canvas.height = 4294967295: 150
canvas.height after canvas.height = 4294967295: 150
canvas.getAttribute("height") after canvas.setAttribute("height", "4294967296"): 4294967296
canvas.height after canvas.setAttribute("height", "4294967296"): 150
canvas.getAttribute("height") after canvas.height = 4294967296: 0
canvas.height after canvas.height = 4294967296: 0
img.getAttribute("height") after img.setAttribute("height", "0"): 0
img.height after img.setAttribute("height", "0"): 0
img.getAttribute("height") after img.height = 0: 0
@ -58,6 +66,10 @@ img.getAttribute("height") after img.setAttribute("height", "4294967295"): 42949
img.height after img.setAttribute("height", "4294967295"): 0
img.getAttribute("height") after img.height = 4294967295: 0
img.height after img.height = 4294967295: 0
img.getAttribute("height") after img.setAttribute("height", "4294967296"): 4294967296
img.height after img.setAttribute("height", "4294967296"): 0
img.getAttribute("height") after img.height = 4294967296: 0
img.height after img.height = 4294967296: 0
img.getAttribute("hspace") after img.setAttribute("hspace", "0"): 0
img.hspace after img.setAttribute("hspace", "0"): 0
img.getAttribute("hspace") after img.hspace = 0: 0
@ -78,6 +90,10 @@ img.getAttribute("hspace") after img.setAttribute("hspace", "4294967295"): 42949
img.hspace after img.setAttribute("hspace", "4294967295"): 0
img.getAttribute("hspace") after img.hspace = 4294967295: 0
img.hspace after img.hspace = 4294967295: 0
img.getAttribute("hspace") after img.setAttribute("hspace", "4294967296"): 4294967296
img.hspace after img.setAttribute("hspace", "4294967296"): 0
img.getAttribute("hspace") after img.hspace = 4294967296: 0
img.hspace after img.hspace = 4294967296: 0
img.getAttribute("width") after img.setAttribute("width", "0"): 0
img.width after img.setAttribute("width", "0"): 0
img.getAttribute("width") after img.width = 0: 0
@ -98,6 +114,10 @@ img.getAttribute("width") after img.setAttribute("width", "4294967295"): 4294967
img.width after img.setAttribute("width", "4294967295"): 0
img.getAttribute("width") after img.width = 4294967295: 0
img.width after img.width = 4294967295: 0
img.getAttribute("width") after img.setAttribute("width", "4294967296"): 4294967296
img.width after img.setAttribute("width", "4294967296"): 0
img.getAttribute("width") after img.width = 4294967296: 0
img.width after img.width = 4294967296: 0
input.getAttribute("maxlength") after input.setAttribute("maxLength", "0"): 0
input.maxLength after input.setAttribute("maxlength", "0"): 0
input.getAttribute("maxlength") after input.maxLength = 0: 0
@ -116,6 +136,10 @@ input.maxLength = 2147483648 threw exception of type IndexSizeError
input.getAttribute("maxlength") after input.setAttribute("maxLength", "4294967295"): 4294967295
input.maxLength after input.setAttribute("maxlength", "4294967295"): -1
input.maxLength = 4294967295 threw exception of type IndexSizeError
input.getAttribute("maxlength") after input.setAttribute("maxLength", "4294967296"): 4294967296
input.maxLength after input.setAttribute("maxlength", "4294967296"): -1
input.getAttribute("maxlength") after input.maxLength = 4294967296: 0
input.maxLength after input.maxLength = 4294967296: 0
input.getAttribute("minlength") after input.setAttribute("minLength", "0"): 0
input.minLength after input.setAttribute("minlength", "0"): 0
input.getAttribute("minlength") after input.minLength = 0: 0
@ -134,6 +158,10 @@ input.minLength = 2147483648 threw exception of type IndexSizeError
input.getAttribute("minlength") after input.setAttribute("minLength", "4294967295"): 4294967295
input.minLength after input.setAttribute("minlength", "4294967295"): -1
input.minLength = 4294967295 threw exception of type IndexSizeError
input.getAttribute("minlength") after input.setAttribute("minLength", "4294967296"): 4294967296
input.minLength after input.setAttribute("minlength", "4294967296"): -1
input.getAttribute("minlength") after input.minLength = 4294967296: 0
input.minLength after input.minLength = 4294967296: 0
input.getAttribute("size") after input.setAttribute("size", "0"): 0
input.size after input.setAttribute("size", "0"): 20
input.size = 0 threw exception of type IndexSizeError
@ -153,6 +181,9 @@ input.getAttribute("size") after input.setAttribute("size", "4294967295"): 42949
input.size after input.setAttribute("size", "4294967295"): 20
input.getAttribute("size") after input.size = 4294967295: 20
input.size after input.size = 4294967295: 20
input.getAttribute("size") after input.setAttribute("size", "4294967296"): 4294967296
input.size after input.setAttribute("size", "4294967296"): 20
input.size = 4294967296 threw exception of type IndexSizeError
input.getAttribute("height") after input.setAttribute("height", "0"): 0
input.height after input.setAttribute("height", "0"): 0
input.getAttribute("height") after input.height = 0: 0
@ -173,6 +204,10 @@ input.getAttribute("height") after input.setAttribute("height", "4294967295"): 4
input.height after input.setAttribute("height", "4294967295"): 0
input.getAttribute("height") after input.height = 4294967295: 0
input.height after input.height = 4294967295: 0
input.getAttribute("height") after input.setAttribute("height", "4294967296"): 4294967296
input.height after input.setAttribute("height", "4294967296"): 0
input.getAttribute("height") after input.height = 4294967296: 0
input.height after input.height = 4294967296: 0
input.getAttribute("width") after input.setAttribute("width", "0"): 0
input.width after input.setAttribute("width", "0"): 0
input.getAttribute("width") after input.width = 0: 0
@ -193,6 +228,10 @@ input.getAttribute("width") after input.setAttribute("width", "4294967295"): 429
input.width after input.setAttribute("width", "4294967295"): 0
input.getAttribute("width") after input.width = 4294967295: 0
input.width after input.width = 4294967295: 0
input.getAttribute("width") after input.setAttribute("width", "4294967296"): 4294967296
input.width after input.setAttribute("width", "4294967296"): 0
input.getAttribute("width") after input.width = 4294967296: 0
input.width after input.width = 4294967296: 0
marquee.getAttribute("scrollamount") after marquee.setAttribute("scrollAmount", "0"): 0
marquee.scrollAmount after marquee.setAttribute("scrollamount", "0"): 0
marquee.getAttribute("scrollamount") after marquee.scrollAmount = 0: 0
@ -213,6 +252,10 @@ marquee.getAttribute("scrollamount") after marquee.setAttribute("scrollAmount",
marquee.scrollAmount after marquee.setAttribute("scrollamount", "4294967295"): 6
marquee.getAttribute("scrollamount") after marquee.scrollAmount = 4294967295: 6
marquee.scrollAmount after marquee.scrollAmount = 4294967295: 6
marquee.getAttribute("scrollamount") after marquee.setAttribute("scrollAmount", "4294967296"): 4294967296
marquee.scrollAmount after marquee.setAttribute("scrollamount", "4294967296"): 6
marquee.getAttribute("scrollamount") after marquee.scrollAmount = 4294967296: 0
marquee.scrollAmount after marquee.scrollAmount = 4294967296: 0
marquee.getAttribute("scrolldelay") after marquee.setAttribute("scrollDelay", "0"): 0
marquee.scrollDelay after marquee.setAttribute("scrolldelay", "0"): 0
marquee.getAttribute("scrolldelay") after marquee.scrollDelay = 0: 0
@ -233,6 +276,10 @@ marquee.getAttribute("scrolldelay") after marquee.setAttribute("scrollDelay", "4
marquee.scrollDelay after marquee.setAttribute("scrolldelay", "4294967295"): 85
marquee.getAttribute("scrolldelay") after marquee.scrollDelay = 4294967295: 85
marquee.scrollDelay after marquee.scrollDelay = 4294967295: 85
marquee.getAttribute("scrolldelay") after marquee.setAttribute("scrollDelay", "4294967296"): 4294967296
marquee.scrollDelay after marquee.setAttribute("scrolldelay", "4294967296"): 85
marquee.getAttribute("scrolldelay") after marquee.scrollDelay = 4294967296: 0
marquee.scrollDelay after marquee.scrollDelay = 4294967296: 0
select.getAttribute("size") after select.setAttribute("size", "0"): 0
select.size after select.setAttribute("size", "0"): 0
select.getAttribute("size") after select.size = 0: 0
@ -253,6 +300,34 @@ select.getAttribute("size") after select.setAttribute("size", "4294967295"): 429
select.size after select.setAttribute("size", "4294967295"): 0
select.getAttribute("size") after select.size = 4294967295: 0
select.size after select.size = 4294967295: 0
select.getAttribute("size") after select.setAttribute("size", "4294967296"): 4294967296
select.size after select.setAttribute("size", "4294967296"): 0
select.getAttribute("size") after select.size = 4294967296: 0
select.size after select.size = 4294967296: 0
td.getAttribute("colspan") after td.setAttribute("colSpan", "0"): 0
td.colSpan after td.setAttribute("colspan", "0"): 1
td.getAttribute("colspan") after td.colSpan = 0: 0
td.colSpan after td.colSpan = 0: 1
td.getAttribute("colspan") after td.setAttribute("colSpan", "1"): 1
td.colSpan after td.setAttribute("colspan", "1"): 1
td.getAttribute("colspan") after td.colSpan = 1: 1
td.colSpan after td.colSpan = 1: 1
td.getAttribute("colspan") after td.setAttribute("colSpan", "2147483647"): 2147483647
td.colSpan after td.setAttribute("colspan", "2147483647"): 1000
td.getAttribute("colspan") after td.colSpan = 2147483647: 2147483647
td.colSpan after td.colSpan = 2147483647: 1000
td.getAttribute("colspan") after td.setAttribute("colSpan", "2147483648"): 2147483648
td.colSpan after td.setAttribute("colspan", "2147483648"): 1000
td.getAttribute("colspan") after td.colSpan = 2147483648: 1
td.colSpan after td.colSpan = 2147483648: 1
td.getAttribute("colspan") after td.setAttribute("colSpan", "4294967295"): 4294967295
td.colSpan after td.setAttribute("colspan", "4294967295"): 1000
td.getAttribute("colspan") after td.colSpan = 4294967295: 1
td.colSpan after td.colSpan = 4294967295: 1
td.getAttribute("colspan") after td.setAttribute("colSpan", "4294967296"): 4294967296
td.colSpan after td.setAttribute("colspan", "4294967296"): 1000
td.getAttribute("colspan") after td.colSpan = 4294967296: 0
td.colSpan after td.colSpan = 4294967296: 1
textarea.getAttribute("maxlength") after textarea.setAttribute("maxLength", "0"): 0
textarea.maxLength after textarea.setAttribute("maxlength", "0"): 0
textarea.getAttribute("maxlength") after textarea.maxLength = 0: 0
@ -271,6 +346,10 @@ textarea.maxLength = 2147483648 threw exception of type IndexSizeError
textarea.getAttribute("maxlength") after textarea.setAttribute("maxLength", "4294967295"): 4294967295
textarea.maxLength after textarea.setAttribute("maxlength", "4294967295"): -1
textarea.maxLength = 4294967295 threw exception of type IndexSizeError
textarea.getAttribute("maxlength") after textarea.setAttribute("maxLength", "4294967296"): 4294967296
textarea.maxLength after textarea.setAttribute("maxlength", "4294967296"): -1
textarea.getAttribute("maxlength") after textarea.maxLength = 4294967296: 0
textarea.maxLength after textarea.maxLength = 4294967296: 0
textarea.getAttribute("minlength") after textarea.setAttribute("minLength", "0"): 0
textarea.minLength after textarea.setAttribute("minlength", "0"): 0
textarea.getAttribute("minlength") after textarea.minLength = 0: 0
@ -289,6 +368,10 @@ textarea.minLength = 2147483648 threw exception of type IndexSizeError
textarea.getAttribute("minlength") after textarea.setAttribute("minLength", "4294967295"): 4294967295
textarea.minLength after textarea.setAttribute("minlength", "4294967295"): -1
textarea.minLength = 4294967295 threw exception of type IndexSizeError
textarea.getAttribute("minlength") after textarea.setAttribute("minLength", "4294967296"): 4294967296
textarea.minLength after textarea.setAttribute("minlength", "4294967296"): -1
textarea.getAttribute("minlength") after textarea.minLength = 4294967296: 0
textarea.minLength after textarea.minLength = 4294967296: 0
textarea.getAttribute("rows") after textarea.setAttribute("rows", "0"): 0
textarea.rows after textarea.setAttribute("rows", "0"): 2
textarea.getAttribute("rows") after textarea.rows = 0: 2
@ -309,6 +392,10 @@ textarea.getAttribute("rows") after textarea.setAttribute("rows", "4294967295"):
textarea.rows after textarea.setAttribute("rows", "4294967295"): 2
textarea.getAttribute("rows") after textarea.rows = 4294967295: 2
textarea.rows after textarea.rows = 4294967295: 2
textarea.getAttribute("rows") after textarea.setAttribute("rows", "4294967296"): 4294967296
textarea.rows after textarea.setAttribute("rows", "4294967296"): 2
textarea.getAttribute("rows") after textarea.rows = 4294967296: 2
textarea.rows after textarea.rows = 4294967296: 2
textarea.getAttribute("cols") after textarea.setAttribute("cols", "0"): 0
textarea.cols after textarea.setAttribute("cols", "0"): 20
textarea.getAttribute("cols") after textarea.cols = 0: 20
@ -329,3 +416,7 @@ textarea.getAttribute("cols") after textarea.setAttribute("cols", "4294967295"):
textarea.cols after textarea.setAttribute("cols", "4294967295"): 20
textarea.getAttribute("cols") after textarea.cols = 4294967295: 20
textarea.cols after textarea.cols = 4294967295: 20
textarea.getAttribute("cols") after textarea.setAttribute("cols", "4294967296"): 4294967296
textarea.cols after textarea.setAttribute("cols", "4294967296"): 20
textarea.getAttribute("cols") after textarea.cols = 4294967296: 20
textarea.cols after textarea.cols = 4294967296: 20

View file

@ -34,6 +34,7 @@
setValue(2147483647);
setValue(2147483648);
setValue(4294967295);
setValue(4294967296);
}
const imageButtonInputFactory = () => {
@ -55,6 +56,7 @@
testProperty("marquee", "scrollAmount", (marquee) => marquee.scrollAmount, (marquee, value) => marquee.scrollAmount = value);
testProperty("marquee", "scrollDelay", (marquee) => marquee.scrollDelay, (marquee, value) => marquee.scrollDelay = value);
testProperty("select", "size", (select) => select.size, (select, value) => select.size = value);
testProperty("td", "colSpan", (tableCell) => tableCell.colSpan, (tableCell, value) => tableCell.colSpan = value);
testProperty("textarea", "maxLength", (textarea) => textarea.maxLength, (textarea, value) => textarea.maxLength = value);
testProperty("textarea", "minLength", (textarea) => textarea.minLength, (textarea, value) => textarea.minLength = value);
testProperty("textarea", "rows", (textarea) => textarea.rows, (textarea, value) => textarea.rows = value);