Skip to content

Commit

Permalink
Move origin into policy container. (#8302)
Browse files Browse the repository at this point in the history
This change also depends on whatwg/dom#1142.
  • Loading branch information
wanderview committed Jan 10, 2023
1 parent 67994b2 commit 17f8486
Showing 1 changed file with 61 additions and 57 deletions.
118 changes: 61 additions & 57 deletions source
Original file line number Diff line number Diff line change
Expand Up @@ -10016,9 +10016,10 @@ o.myself = o;</code></pre>

<p>The <code>Document</code> object's <dfn data-x="concept-document-origin"
data-x-href="https://dom.spec.whatwg.org/#concept-document-origin"
data-x-for="Document">origin</dfn> is defined in <cite>DOM</cite>. It is initially set when the
<code>Document</code> object is created, and can change during the lifetime of the
<code>Document</code> only upon setting <code
data-x-for="Document">origin</dfn> is defined in <cite>DOM</cite>. It currently aliases to
value of its <span data-x=document-concept-policy-container>policy container</span>'s
<span data-x=policy-container-origin>origin</span>. This origin can change during the lifetime
of the <code>Document</code> upon setting <code
data-x="dom-document-domain">document.domain</code>. A <code>Document</code>'s <span
data-x="concept-document-origin">origin</span> can differ from the <span
data-x="concept-url-origin">origin</span> of its <span data-x="concept-document-url">URL</span>;
Expand Down Expand Up @@ -83441,6 +83442,10 @@ dictionary <dfn dictionary>DragEventInit</dfn> : <span>MouseEventInit</span> {
<!-- Note: each item has to define a default value for creating a new policy container. -->

<ul>
<li><p>An <dfn export for="policy container" data-dfn-for="Policy Container"
data-x="policy-container-origin">origin</dfn>, which is an <span>origin</span>. It is initially
an opaque origin.</p></li>

<li><p>A <dfn export for="policy container" data-x="policy-container-csp-list">CSP list</dfn>,
which is a <span data-x="concept-csp-list">CSP list</span>. It is initially empty.</p></li>

Expand All @@ -83461,6 +83466,9 @@ dictionary <dfn dictionary>DragEventInit</dfn> : <span>MouseEventInit</span> {
<ol>
<li><p>Let <var>clone</var> be a new <span>policy container</span>.</p></li>

<li><p>Set <var>clone</var>'s <span data-x="policy-container-origin">origin</span> to
<var>policyContainer</var>'s <span data-x="policy-container-origin">origin</span>.</p></li>

<li><p><span data-x="list iterate">For each</span> <var>policy</var> in
<var>policyContainer</var>'s <span data-x="policy-container-csp-list">CSP list</span>, <span
data-x="list append">append</span> a copy of <var>policy</var> into <var>clone</var>'s <span
Expand Down Expand Up @@ -83512,6 +83520,10 @@ dictionary <dfn dictionary>DragEventInit</dfn> : <span>MouseEventInit</span> {

<li><p>Let <var>result</var> be a new <span>policy container</span>.</p></li>

<li><p>Set <var>result</var>'s <span data-x="policy-container-origin">origin</span> to
<var>response</var>'s <span data-x="concept-response-url">URL</span>'s
<span data-x="concept-url-origin">origin</span>.</p></li>

<li><p>Set <var>result</var>'s <span data-x="policy-container-csp-list">CSP list</span> to the
result of <span data-x="parse-response-csp">parsing a response's Content Security Policies</span>
given <var>response</var>.</p></li>
Expand Down Expand Up @@ -83567,7 +83579,9 @@ dictionary <dfn dictionary>DragEventInit</dfn> : <span>MouseEventInit</span> {
<li><p>If <var>responsePolicyContainer</var> is not null, then return
<var>responsePolicyContainer</var>.</p></li>

<li><p>Return a new <span>policy container</span>.</p></li>
<li><p>Return a new <span>policy container</span> with its
<span data-x="policy-container-origin">origin</span> set to <var>responseURL</var>'s
<span data-x="concept-url-origin">origin</span>.</p></li>
</ol>

<p>To <dfn data-x="initialize worker policy container">initialize a worker global scope's policy
Expand Down Expand Up @@ -85021,12 +85035,6 @@ interface <dfn interface>BarProp</dfn> {
<span data-x="concept-document-window">associated <code>Document</code></span>.</p>
</dd>

<dt>The <span data-x="concept-settings-object-origin">origin</span></dt>
<dd>
<p>Return the <span data-x="concept-document-origin">origin</span> of <var>window</var>'s
<span data-x="concept-document-window">associated <code>Document</code></span>.</p>
</dd>

<dt>The <span data-x="concept-settings-object-policy-container">policy container</span></dt>
<dd>
<p>Return the <span data-x="concept-document-policy-container">policy container</span> of
Expand Down Expand Up @@ -88151,9 +88159,6 @@ interface <dfn interface>BeforeUnloadEvent</dfn> : <span>Event</span> {
<dt><span data-x="concept-document-mode">mode</span></dt>
<dd>"<code data-x="">quirks</code>"</dd>

<dt><span data-x="concept-document-origin">origin</span></dt>
<dd><var>origin</var></dd>

<dt><span data-x="concept-document-bc">browsing context</span></dt>
<dd><var>browsingContext</var>

Expand Down Expand Up @@ -89463,9 +89468,6 @@ location.href = '#foo';</code></pre>
<dd>a <span data-x="concept-response">response</span> that ultimately was navigated to
(potentially a <span>network error</span>)</dd>

<dt><dfn data-x="navigation-params-origin">origin</dfn></dt>
<dd>an <span>origin</span> to use for the new <code>Document</code></dd>

<dt><dfn data-x="navigation-params-policy-container">policy container</dfn></dt>
<dd>a <span>policy container</span> to use for the new <code>Document</code></dd>

Expand Down Expand Up @@ -89811,6 +89813,9 @@ location.href = '#foo';</code></pre>
<var>finalSandboxFlags</var>, <var>documentState</var>'s <span
data-x="document-state-initiator-origin">initiator origin</span>, and null.</p></li>

<li><p>Set <var>policyContainer</var>'s <span data-x="policy-container-origin">origin</span>
to <var>responseOrigin</var>.</p></li>

<li><p>Let <var>coop</var> be a new <span>cross-origin opener policy</span>.</p></li>

<li>
Expand Down Expand Up @@ -89843,11 +89848,8 @@ location.href = '#foo';</code></pre>
<dt><span data-x="navigation-params-response">response</span></dt>
<dd><var>response</var></dd>

<dt><span data-x="navigation-params-origin">origin</span></dt>
<dd><var>responseOrigin</var></dd>

<dt><span data-x="navigation-params-policy-container">policy container</span></dt>
<dd><var>policyContainer</var></dd>
<dd><var>policyContainer</var>

<dt><span data-x="navigation-params-sandboxing">final sandboxing flag set</span></dt>
<dd><var>finalSandboxFlags</var></dd>
Expand Down Expand Up @@ -90215,11 +90217,10 @@ location.href = '#foo';</code></pre>
<dt><span data-x="navigation-params-response">response</span></dt>
<dd><var>response</var></dd>

<dt><span data-x="navigation-params-origin">origin</span></dt>
<dd><var>initiatorOrigin</var></dd>

<dt><span data-x="navigation-params-policy-container">policy container</span></dt>
<dd><var>policyContainer</var></dd>
<dd>a <span data-x="clone a policy container">clone</span> of <var>policyContainer</var>
with its <span data-x="policy-container-origin">origin</span> set to
<var>initiatorOrigin</var></dd>

<dt><span data-x="navigation-params-sandboxing">final sandboxing flag set</span></dt>
<dd><var>finalSandboxFlags</var></dd>
Expand Down Expand Up @@ -91018,7 +91019,8 @@ location.href = '#foo';</code></pre>
data-x="navigation-params-response">response</span>, <var>navigable</var>,
<var>navigationParams</var>'s <span data-x="navigation-params-policy-container">policy
container</span>'s <span data-x="policy-container-csp-list">CSP list</span>, and
<var>navigationParams</var>'s <span data-x="navigation-params-origin">origin</span> is false,
<var>navigationParams</var>'s <span data-x="navigation-params-policy-container">policy
container</span>'s <span data-x="policy-container-origin">origin</span> is false,
then set <var>failure</var> to true.</p></li>

<li>
Expand Down Expand Up @@ -91207,6 +91209,9 @@ location.href = '#foo';</code></pre>
<var>navigable</var>'s <span data-x="nav-container-document">container document</span>'s <span
data-x="concept-document-policy-container">policy container</span>, and null.</p></li>

<li><p>Set <var>policyContainer</var>'s <span data-x="policy-container-origin">origin</span>
to <var>responseOrigin</var>.</p></li>

<li>
<p>Return a new <span>navigation params</span>, with</p>

Expand All @@ -91220,9 +91225,6 @@ location.href = '#foo';</code></pre>
<dt><span data-x="navigation-params-response">response</span></dt>
<dd><var>response</var></dd>

<dt><span data-x="navigation-params-origin">origin</span></dt>
<dd><var>responseOrigin</var></dd>

<dt><span data-x="navigation-params-policy-container">policy container</span></dt>
<dd><var>policyContainer</var></dd>

Expand Down Expand Up @@ -91795,6 +91797,9 @@ location.href = '#foo';</code></pre>
<var>sourceSnapshotParams</var>'s <span data-x="source-snapshot-params-policy-container">source
policy container</span>, null, and <var>responsePolicyContainer</var>.</p></li>

<li><p>Set <var>resultPolicyContainer</var>'s <span
data-x="policy-container-origin">origin</span> to <var>responseOrigin</var></p></li>.

<li>
<p>Return a new <span>navigation params</span>, with</p>

Expand All @@ -91808,9 +91813,6 @@ location.href = '#foo';</code></pre>
<dt><span data-x="navigation-params-response">response</span></dt>
<dd><var>response</var></dd>

<dt><span data-x="navigation-params-origin">origin</span></dt>
<dd><var>responseOrigin</var></dd>

<dt><span data-x="navigation-params-policy-container">policy container</span></dt>
<dd><var>resultPolicyContainer</var></dd>

Expand Down Expand Up @@ -93158,7 +93160,8 @@ location.href = '#foo';</code></pre>
<li>
<p>Let <var>permissionsPolicy</var> be the result of <span>creating a permissions policy from a
response</span> given <var>browsingContext</var>, <var>navigationParams</var>'s <span
data-x="navigation-params-origin">origin</span>, and <var>navigationParams</var>'s <span
data-x="navigation-params-policy-container">policy container</span>'s <span
data-x="policy-container-origin">origin</span>, and <var>navigationParams</var>'s <span
data-x="navigation-params-response">response</span>. <ref spec="PERMISSIONSPOLICY"></p>

<div class="note">
Expand Down Expand Up @@ -93193,7 +93196,8 @@ location.href = '#foo';</code></pre>
<code>about:blank</code></span> is true, and <var>browsingContext</var>'s <span>active
document</span>'s <span data-x="concept-document-origin">origin</span> is <span>same
origin-domain</span> with <var>navigationParams</var>'s <span
data-x="navigation-params-origin">origin</span>, then set <var>window</var> to
data-x="navigation-params-policy-container">policy container</span>'s <span
data-x="policy-container-origin">origin</span>, then set <var>window</var> to
<var>browsingContext</var>'s <span>active window</span>.</p>

<p class="note">This means that both the <span data-x="is initial about:blank">initial
Expand All @@ -93220,7 +93224,8 @@ location.href = '#foo';</code></pre>

<li><p>Let <var>agent</var> be the result of <span
data-x="obtain-similar-origin-window-agent">obtaining a similar-origin window agent</span>
given <var>navigationParams</var>'s <span data-x="navigation-params-origin">origin</span>,
given <var>navigationParams</var>'s <span data-x="navigation-params-policy-container">policy
container</span>'s <span data-x="policy-container-origin">origin</span>,
<var>browsingContext</var>'s <span data-x="tlbc group">group</span>, and
<var>requestsOAC</var>.</p></li>

Expand All @@ -93242,7 +93247,8 @@ location.href = '#foo';</code></pre>
<li><p>Let <var>topLevelCreationURL</var> be <var>creationURL</var>.</p></li>

<li><p>Let <var>topLevelOrigin</var> be <var>navigationParams</var>'s <span
data-x="navigation-params-origin">origin</span>.</p></li>
data-x="navigation-params-policy-container">policy container</span>'s <span
data-x="policy-container-origin">origin</span>.</p></li>

<li>
<p>If <var>navigable</var>'s <span data-x="nav-container">container</span> is not null,
Expand Down Expand Up @@ -93286,9 +93292,6 @@ location.href = '#foo';</code></pre>
<dt><span data-x="concept-document-content-type">content type</span></dt>
<dd><var>contentType</var></dd>

<dt><span data-x="concept-document-origin">origin</span></dt>
<dd><var>navigationParams</var>'s <span data-x="navigation-params-origin">origin</span></dd>

<dt><span data-x="concept-document-bc">browsing context</span></dt>
<dd><var>browsingContext</var>

Expand Down Expand Up @@ -93767,9 +93770,6 @@ new PaymentRequest(&hellip;); // Allowed to use
<dt><span data-x="navigation-params-response">response</span></dt>
<dd>a new <span data-x="concept-response">response</span></dd>

<dt><span data-x="navigation-params-origin">origin</span></dt>
<dd><var>origin</var></dd>

<dt><span data-x="navigation-params-policy-container">policy container</span></dt>
<dd>a new <span>policy container</span></dd>

Expand Down Expand Up @@ -94940,7 +94940,8 @@ new PaymentRequest(&hellip;); // Allowed to use
settings object">origin</dfn></dt>

<dd>
<p>An <span>origin</span> used in security checks.</p>
<p>This objects <span data-x="concept-settings-object-policy-container">policy
container</span>'s <span data-x="policy-container-origin">origin</span>.</p>
</dd>

<dt>A <dfn data-x="concept-settings-object-policy-container" export
Expand Down Expand Up @@ -107246,6 +107247,12 @@ interface <dfn interface>SharedWorkerGlobalScope</dfn> : <span>WorkerGlobalScope
<code>SharedWorkerGlobalScope</code> object created in the previous step.</p>
</li>

<li><p>Set <var>worker global scope</var>'s
<span data-x="concept-WorkerGlobalScope-policy-container">policy container</span>'s
<span data-x="policy-container-origin">origin</span> to <var>outside settings</var>'s
<span data-x="concept-settings-object-policy-container">policy container</span>'s
<span data-x="policy-container-origin">origin</span>.</p></li>

<li><p><span>Set up a worker environment settings object</span> with <var>realm execution
context</var>, <var>outside settings</var>, and <var>unsafeWorkerCreationTime</var>, and let
<var>inside settings</var> be the result.</p></li>
Expand Down Expand Up @@ -107649,14 +107656,6 @@ interface <dfn interface>SharedWorkerGlobalScope</dfn> : <span>WorkerGlobalScope
data-x="concept-WorkerGlobalScope-url">url</span>.</p>
</dd>

<dt>The <span data-x="concept-settings-object-origin">origin</span></dt>
<dd>
<p>Return a unique <span data-x="concept-origin-opaque">opaque origin</span> if <var>worker
global scope</var>'s <span data-x="concept-WorkerGlobalScope-url">url</span>'s <span
data-x="concept-url-scheme">scheme</span> is "<code data-x="">data</code>", and <var>inherited
origin</var> otherwise.</p>
</dd>

<dt>The <span data-x="concept-settings-object-policy-container">policy container</span></dt>
<dd>
<p>Return <var>worker global scope</var>'s <span
Expand All @@ -107677,6 +107676,18 @@ interface <dfn interface>SharedWorkerGlobalScope</dfn> : <span>WorkerGlobalScope
</dl>
</li>

<li><p><span>Assert</span> that <var>settings object</var>'s <span
data-x="concept-settings-object-policy-container">policy container</span>'s <span
data-x="policy-container-origin">origin</span> is an <span data-x="concept-origin-opaque">opaque
origin</span>.</p></li>

<li><p>If <var>worker global scope</var>'s <span
data-x="concept-WorkerGlobalScope-url">url</span>'s <span
data-x="concept-url-scheme">scheme</span> is not "<code data-x="">data</code>", then set
<var>settings object</var>'s <span data-x="concept-settings-object-policy-container">policy
container</span>'s <span data-x="policy-container-origin">origin</span> to <var>inherited
origin</var>.</p></li>

<li><p>Set <var>settings object</var>'s <span data-x="concept-environment-id">id</span> to a new
unique opaque string, <span data-x="concept-environment-creation-url">creation URL</span> to
<var>worker global scope</var>'s <span>url</span>, <span>top-level creation URL</span> to null,
Expand Down Expand Up @@ -108812,8 +108823,6 @@ interface <dfn interface>WorkletGlobalScope</dfn> {};</code></pre>
object</span> <var>outsideSettings</var>:</p>

<ol>
<li><p>Let <var>origin</var> be a unique <span data-x="concept-origin-opaque">opaque
origin</span>.</p></li>

<li><p>Let <var>inheritedAPIBaseURL</var> be <var>outsideSettings</var>'s <span>API base
URL</span>.</p></li>
Expand Down Expand Up @@ -108861,11 +108870,6 @@ interface <dfn interface>WorkletGlobalScope</dfn> {};</code></pre>
available to worklet code make use of the <span>API base URL</span>.</p>
</dd>

<dt>The <span data-x="concept-settings-object-origin">origin</span></dt>
<dd>
<p>Return <var>origin</var>.</p>
</dd>

<dt>The <span data-x="concept-settings-object-policy-container">policy container</span></dt>
<dd>
<p>Return <var>inheritedPolicyContainer</var>.</p>
Expand Down

0 comments on commit 17f8486

Please sign in to comment.