Skip to content

Commit f55a1c7

Browse files
authoredJan 3, 2023
Editorial: add <div algorithm> to HTTP extensions
Related to #1526.
1 parent 98b3a58 commit f55a1c7

File tree

1 file changed

+18
-0
lines changed

1 file changed

+18
-0
lines changed
 

‎fetch.bs

+18
Original file line numberDiff line numberDiff line change
@@ -3214,6 +3214,7 @@ request <a for=/>header</a> indicates where a
32143214

32153215
<hr>
32163216

3217+
<div algorithm>
32173218
<p>To <dfn id=append-a-request-origin-header>append a request `<code>Origin</code>` header</dfn>,
32183219
given a <a for=/>request</a> <var>request</var>, run these steps:
32193220

@@ -3264,6 +3265,7 @@ given a <a for=/>request</a> <var>request</var>, run these steps:
32643265
<p class=note>A <a for=/>request</a>'s <a for=request>referrer policy</a> is taken into account for
32653266
all fetches where the fetcher did not explicitly opt into sharing their <a for=/>origin</a> with the
32663267
server, e.g., via using the <a>CORS protocol</a>.
3268+
</div>
32673269

32683270

32693271
<h3 id=http-cors-protocol>CORS protocol</h3>
@@ -3657,6 +3659,7 @@ consideration for the security consequences. New exceptions can be proposed by
36573659
<p>The `<code>Content-Length</code>` header is largely defined in HTTP. Its processing model is
36583660
defined here as the model defined in HTTP is not compatible with web content. [[HTTP]]
36593661

3662+
<div algorithm>
36603663
<p>To <dfn export for="header list" lt="extract a length|extracting a length">extract a length</dfn>
36613664
from a <a for=/>header list</a> <var>headers</var>, run these steps:
36623665

@@ -3684,13 +3687,15 @@ from a <a for=/>header list</a> <var>headers</var>, run these steps:
36843687

36853688
<li><p>Return <var>candidateValue</var>, interpreted as decimal number.
36863689
</ol>
3690+
</div>
36873691

36883692

36893693
<h3 id=content-type-header>`<code>Content-Type</code>` header</h3>
36903694

36913695
<p>The `<code>Content-Type</code>` header is largely defined in HTTP. Its processing model is
36923696
defined here as the model defined in HTTP is not compatible with web content. [[HTTP]]
36933697

3698+
<div algorithm>
36943699
<p>To
36953700
<dfn export for="header list" lt="extract a MIME type|extracting a MIME type" id=concept-header-extract-mime-type>extract a MIME type</dfn>
36963701
from a <a for=/>header list</a> <var>headers</var>, run these steps:
@@ -3743,6 +3748,7 @@ from a <a for=/>header list</a> <var>headers</var>, run these steps:
37433748

37443749
<li><p>Return <var>mimeType</var>.
37453750
</ol>
3751+
</div>
37463752

37473753
<p class=warning>When <a>extract a MIME type</a> returns failure or a <a for=/>MIME type</a> whose
37483754
<a for="MIME type">essence</a> is incorrect for a given format, treat this as a fatal error.
@@ -3805,6 +3811,7 @@ Content-Type:
38053811
</table>
38063812
</div>
38073813

3814+
<div algorithm>
38083815
<p>To <dfn export>legacy extract an encoding</dfn> given failure or a <a for=/>MIME type</a>
38093816
<var>mimeType</var> and an <a for=/>encoding</a> <var>fallbackEncoding</var>, run these steps:
38103817

@@ -3828,6 +3835,7 @@ Content-Type:
38283835

38293836
<p>It is denoted as legacy as modern formats are to exclusively use <a for=/>UTF-8</a>.
38303837
</div>
3838+
</div>
38313839

38323840

38333841
<h3 id=x-content-type-options-header>`<code>X-Content-Type-Options</code>` header</h3>
@@ -3838,6 +3846,7 @@ response <a for=/>header</a> can be used to require checking of a <a for=/>respo
38383846
`<code>Content-Type</code>` <a for=/>header</a> against the <a for=request>destination</a> of a
38393847
<a for=/>request</a>.
38403848

3849+
<div algorithm>
38413850
<p>To <dfn export>determine nosniff</dfn>, given a <a for=/>header list</a> <var>list</var>, run
38423851
these steps:
38433852

@@ -3853,6 +3862,7 @@ these steps:
38533862

38543863
<li><p>Return false.
38553864
</ol>
3865+
</div>
38563866

38573867
<p>Web developers and conformance checkers must use the following <a for=header>value</a>
38583868
<a>ABNF</a> for `<a http-header><code>X-Content-Type-Options</code></a>`:
@@ -3862,6 +3872,7 @@ X-Content-Type-Options = "nosniff" ; case-insensitive
38623872
</code></pre>
38633873

38643874

3875+
<div algorithm="should response to request be blocked due to nosniff">
38653876
<h4 lt="should response to request be blocked due to nosniff" dfn id=should-response-to-request-be-blocked-due-to-nosniff?>Should
38663877
<var>response</var> to <var>request</var> be blocked due to nosniff?</h4>
38673878

@@ -3888,6 +3899,7 @@ X-Content-Type-Options = "nosniff" ; case-insensitive
38883899
<p class="note no-backref">Only <a for=/>request</a> <a for=request>destinations</a> that are
38893900
<a for=request/destination>script-like</a> or "<code>style</code>" are considered as any exploits
38903901
pertain to them. Also, considering "<code>image</code>" was not compatible with deployed content.
3902+
</div>
38913903

38923904

38933905
<h3 id=cross-origin-resource-policy-header>`<code>Cross-Origin-Resource-Policy</code>` header</h3>
@@ -3905,6 +3917,7 @@ response <a for=/>header</a> can be used to require checking a <a for=/>request<
39053917
Cross-Origin-Resource-Policy = %s"same-origin" / %s"same-site" / %s"cross-origin" ; case-sensitive
39063918
</code></pre>
39073919

3920+
<div algorithm>
39083921
<p>To perform a <dfn export>cross-origin resource policy check</dfn>, given an <a for=url>origin</a>
39093922
<var>origin</var>, an <a for=/>environment settings object</a> <var>settingsObject</var>, a string
39103923
<var>destination</var>, a <a for=/>response</a> <var>response</var>, and an optional boolean
@@ -3946,7 +3959,9 @@ Cross-Origin-Resource-Policy = %s"same-origin" / %s"same-site" / %s"cross-or
39463959
<var>response</var> is either the <a for="filtered response">internal response</a> of an
39473960
<a>opaque filtered response</a> or a <a for=/>response</a> which will be the
39483961
<a for="filtered response">internal response</a> of an <a>opaque filtered response</a>. [[HTML]]
3962+
</div>
39493963

3964+
<div algorithm>
39503965
<p>To perform a <dfn>cross-origin resource policy internal check</dfn>, given an
39513966
<a for=url>origin</a> <var>origin</var>, an <a for=/>embedder policy value</a>
39523967
<var>embedderPolicyValue</var>, a <a for=/>response</a> <var>response</var>, and a boolean
@@ -4029,7 +4044,9 @@ Cross-Origin-Resource-Policy = %s"same-origin" / %s"same-site" / %s"cross-or
40294044
match a securely-transported initiator.
40304045
</dl>
40314046
</ol>
4047+
</div>
40324048

4049+
<div algorithm>
40334050
<p>To <dfn>queue a cross-origin embedder policy CORP violation report</dfn>, given a
40344051
<a for=/>response</a> <var>response</var>, an <a for=/>environment settings object</a>
40354052
<var>settingsObject</var>, a string <var>destination</var>, and a boolean <var>reportOnly</var>,
@@ -4083,6 +4100,7 @@ run these steps:
40834100
<a for="environment settings object">global object</a> given the
40844101
<a>"<code>coep</code>" report type</a>, <var>endpoint</var>, and <var>body</var>. [[!REPORTING]]
40854102
</ol>
4103+
</div>
40864104

40874105

40884106

0 commit comments

Comments
 (0)