From c157e39534232d1d8682cd3e281ce1a95feac02d Mon Sep 17 00:00:00 2001 From: Luke Warlow Date: Thu, 4 Apr 2024 14:18:18 +0100 Subject: [PATCH] Remove enforcement from embed and object elements (#486) See https://github.com/w3c/trusted-types/issues/305 --- spec/index.bs | 33 --------------------------------- 1 file changed, 33 deletions(-) diff --git a/spec/index.bs b/spec/index.bs index 751eef5..f5ee424 100644 --- a/spec/index.bs +++ b/spec/index.bs @@ -1093,10 +1093,7 @@ To get Trusted Types-compliant attribute value on ElementAttribute namespaceAttribute local nameTrustedTypeSink {{HTMLIFrameElement}}null"srcdoc"{{TrustedHTML}}"HTMLIFrameElement srcdoc" - {{HTMLEmbedElement}}null"src"{{TrustedScriptURL}}"HTMLEmbedElement src" {{HTMLScriptElement}}null"src"{{TrustedScriptURL}}"HTMLScriptElement src" - {{HTMLObjectElement}}null"data"{{TrustedScriptURL}}"HTMLObjectElement data" - {{HTMLObjectElement}}null"codebase"{{TrustedScriptURL}}"HTMLObjectElement codebase" {{SVGScriptElement}}null"href"{{TrustedScriptURL}}"SVGScriptElement href" {{SVGScriptElement}}XLink namespace"href"{{TrustedScriptURL}}"SVGScriptElement href" @@ -1205,21 +1202,6 @@ The first few steps of the [=prepare the script element=] algorithm are modified
  • ... -### Enforcement in element attributes ### {#enforcement-in-sinks} - -This document modifies following IDL attributes of various DOM elements: - -
    -partial interface HTMLEmbedElement {
    -  [CEReactions] attribute ScriptURLString src;
    -};
    -
    -partial interface HTMLObjectElement {
    -  [CEReactions] attribute ScriptURLString data;
    -  [CEReactions] attribute ScriptURLString codeBase; // obsolete
    -};
    -
    - ### Enforcement in timer functions ### {#enforcement-in-timer-functions} This document modifies the {{WindowOrWorkerGlobalScope}} interface mixin: @@ -1672,21 +1654,6 @@ restrictions: * HTML imports -## Plugin navigation ## {#plugins} - -Plugin content may have access to the document that embeds it (or; more broadly, -to the origin it was served from), often giving it the same capabilities -as DOM XSS. That's why Trusted Types limit {{HTMLEmbedElement}}'s <{embed/src}> to -{{TrustedScriptURL}}. - -However, it is also possible to navigate an existing object / embed to an -arbitrary location, bypassing the {{TrustedScriptURL}} restriction. - -Since plugin content in the web in general is being phased out for other -security reasons, and their navigation model is in flux, we recommend authors -to prevent that bypass vector by limiting the plugins altogether with -[=object-src=]. For example: `Content-Security-Policy: object-src: none`. - ## Script gadgets ## {#script-gadgets} While Trusted Types logic is called on many operations that results in creating