diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /dom/webidl/Sanitizer.webidl | |
parent | Initial commit. (diff) | |
download | thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/webidl/Sanitizer.webidl')
-rw-r--r-- | dom/webidl/Sanitizer.webidl | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/dom/webidl/Sanitizer.webidl b/dom/webidl/Sanitizer.webidl new file mode 100644 index 0000000000..894896a46f --- /dev/null +++ b/dom/webidl/Sanitizer.webidl @@ -0,0 +1,54 @@ +/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this file, + * You can obtain one at http://mozilla.org/MPL/2.0/. + * + * The origin of this IDL file is + * https://wicg.github.io/sanitizer-api/#sanitizer + * https://wicg.github.io/sanitizer-api/#config + * + * * Copyright © 2020 the Contributors to the HTML Sanitizer API Specification, + * published by the Web Platform Incubator Community Group under the W3C Community Contributor License Agreement (CLA). + */ + +// NOTE: This IDL is still under development: +// https://github.com/WICG/sanitizer-api/issues/181 + +typedef (DocumentFragment or Document) SanitizerInput; + +[GenerateConversionToJS] +dictionary SanitizerElementNamespace { + required DOMString name; + required DOMString _namespace; +}; + +typedef (DOMString or SanitizerElementNamespace) SanitizerElement; + +enum Star { + "*" +}; + +dictionary SanitizerAttribute { + required DOMString name; + DOMString? _namespace = null; + required (Star or sequence<SanitizerElement>) elements; +}; + +[Exposed=Window, SecureContext, Pref="dom.security.sanitizer.enabled"] +interface Sanitizer { + [Throws, UseCounter] + constructor(optional SanitizerConfig sanitizerConfig = {}); + [UseCounter, Throws] + DocumentFragment sanitize(SanitizerInput input); +}; + +dictionary SanitizerConfig { + sequence<SanitizerElement> allowElements; + sequence<SanitizerElement> blockElements; + sequence<SanitizerElement> dropElements; + sequence<SanitizerAttribute> allowAttributes; + sequence<SanitizerAttribute> dropAttributes; + boolean allowCustomElements; + boolean allowUnknownMarkup; + boolean allowComments; +}; |