1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-05-28 17:15:09 +00:00

LibWeb: Add <input> value sanitiztion algorithm

The value sanitiztion algorithm is defined for some states of the type
attribute, and sanitizes the value of the 'value' attribute
This commit is contained in:
Adam Hodgen 2022-02-17 23:05:46 +00:00 committed by Andreas Kling
parent 240068a48c
commit aa70422b4d
2 changed files with 90 additions and 27 deletions

View file

@ -13,29 +13,29 @@
namespace Web::HTML {
// https://html.spec.whatwg.org/multipage/input.html#attr-input-type
#define ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTES \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(hidden) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(text) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(search) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(tel) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(url) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(email) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(password) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(date) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(month) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(week) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(time) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE("datetime-local") \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(number) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(range) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(color) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(checkbox) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(radio) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(file) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(submit) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(image) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(reset) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(button)
#define ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTES \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(hidden, Hidden) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(text, Text) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(search, Search) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(tel, Telephone) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(url, URL) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(email, Email) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(password, Password) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(date, Date) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(month, Month) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(week, Week) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(time, Time) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE("datetime-local", LocalDateAndTime) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(number, Number) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(range, Range) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(color, Color) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(checkbox, Checkbox) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(radio, RadioButton) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(file, FileUpload) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(submit, SubmitButton) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(image, ImageButton) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(reset, ResetButton) \
__ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(button, Button)
class HTMLInputElement final : public FormAssociatedElement {
public:
@ -46,7 +46,14 @@ public:
virtual RefPtr<Layout::Node> create_layout_node(NonnullRefPtr<CSS::StyleProperties>) override;
enum TypeAttributeState {
#define __ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE(_, state) state,
ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTES
#undef __ENUMERATE_HTML_INPUT_TYPE_ATTRIBUTE
};
String type() const;
TypeAttributeState type_state() const;
void set_type(String const&);
String default_value() const { return attribute(HTML::AttributeNames::value); }
@ -90,6 +97,9 @@ private:
void create_shadow_tree_if_needed();
void run_input_activation_behavior();
// https://html.spec.whatwg.org/multipage/input.html#value-sanitization-algorithm
String value_sanitization_algorithm(String) const;
RefPtr<DOM::Text> m_text_node;
bool m_checked { false };