@@ -3214,6 +3214,7 @@ request <a for=/>header</a> indicates where a
3214
3214
3215
3215
<hr>
3216
3216
3217
+ <div algorithm>
3217
3218
<p> To <dfn id=append-a-request-origin-header>append a request `<code>Origin</code>` header</dfn> ,
3218
3219
given a <a for=/>request</a> <var> request</var> , run these steps:
3219
3220
@@ -3264,6 +3265,7 @@ given a <a for=/>request</a> <var>request</var>, run these steps:
3264
3265
<p class=note> A <a for=/>request</a> 's <a for=request>referrer policy</a> is taken into account for
3265
3266
all fetches where the fetcher did not explicitly opt into sharing their <a for=/>origin</a> with the
3266
3267
server, e.g., via using the <a>CORS protocol</a> .
3268
+ </div>
3267
3269
3268
3270
3269
3271
<h3 id=http-cors-protocol>CORS protocol</h3>
@@ -3657,6 +3659,7 @@ consideration for the security consequences. New exceptions can be proposed by
3657
3659
<p> The `<code> Content-Length</code> ` header is largely defined in HTTP. Its processing model is
3658
3660
defined here as the model defined in HTTP is not compatible with web content. [[HTTP]]
3659
3661
3662
+ <div algorithm>
3660
3663
<p> To <dfn export for="header list" lt="extract a length|extracting a length">extract a length</dfn>
3661
3664
from a <a for=/>header list</a> <var> headers</var> , run these steps:
3662
3665
@@ -3684,13 +3687,15 @@ from a <a for=/>header list</a> <var>headers</var>, run these steps:
3684
3687
3685
3688
<li><p> Return <var> candidateValue</var> , interpreted as decimal number.
3686
3689
</ol>
3690
+ </div>
3687
3691
3688
3692
3689
3693
<h3 id=content-type-header>`<code>Content-Type</code>` header</h3>
3690
3694
3691
3695
<p> The `<code> Content-Type</code> ` header is largely defined in HTTP. Its processing model is
3692
3696
defined here as the model defined in HTTP is not compatible with web content. [[HTTP]]
3693
3697
3698
+ <div algorithm>
3694
3699
<p> To
3695
3700
<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>
3696
3701
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:
3743
3748
3744
3749
<li><p> Return <var> mimeType</var> .
3745
3750
</ol>
3751
+ </div>
3746
3752
3747
3753
<p class=warning> When <a>extract a MIME type</a> returns failure or a <a for=/>MIME type</a> whose
3748
3754
<a for="MIME type">essence</a> is incorrect for a given format, treat this as a fatal error.
@@ -3805,6 +3811,7 @@ Content-Type:
3805
3811
</table>
3806
3812
</div>
3807
3813
3814
+ <div algorithm>
3808
3815
<p> To <dfn export>legacy extract an encoding</dfn> given failure or a <a for=/>MIME type</a>
3809
3816
<var> mimeType</var> and an <a for=/>encoding</a> <var> fallbackEncoding</var> , run these steps:
3810
3817
@@ -3828,6 +3835,7 @@ Content-Type:
3828
3835
3829
3836
<p> It is denoted as legacy as modern formats are to exclusively use <a for=/>UTF-8</a> .
3830
3837
</div>
3838
+ </div>
3831
3839
3832
3840
3833
3841
<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
3838
3846
`<code> Content-Type</code> ` <a for=/>header</a> against the <a for=request>destination</a> of a
3839
3847
<a for=/>request</a> .
3840
3848
3849
+ <div algorithm>
3841
3850
<p> To <dfn export>determine nosniff</dfn> , given a <a for=/>header list</a> <var> list</var> , run
3842
3851
these steps:
3843
3852
@@ -3853,6 +3862,7 @@ these steps:
3853
3862
3854
3863
<li><p> Return false.
3855
3864
</ol>
3865
+ </div>
3856
3866
3857
3867
<p> Web developers and conformance checkers must use the following <a for=header>value</a>
3858
3868
<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
3862
3872
</code></pre>
3863
3873
3864
3874
3875
+ <div algorithm="should response to request be blocked due to nosniff">
3865
3876
<h4 lt="should response to request be blocked due to nosniff" dfn id=should-response-to-request-be-blocked-due-to-nosniff?>Should
3866
3877
<var>response</var> to <var>request</var> be blocked due to nosniff?</h4>
3867
3878
@@ -3888,6 +3899,7 @@ X-Content-Type-Options = "nosniff" ; case-insensitive
3888
3899
<p class="note no-backref"> Only <a for=/>request</a> <a for=request>destinations</a> that are
3889
3900
<a for=request/destination>script-like</a> or "<code> style</code> " are considered as any exploits
3890
3901
pertain to them. Also, considering "<code> image</code> " was not compatible with deployed content.
3902
+ </div>
3891
3903
3892
3904
3893
3905
<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<
3905
3917
Cross-Origin-Resource-Policy = %s"same-origin" / %s"same-site" / %s"cross-origin" ; case-sensitive
3906
3918
</code></pre>
3907
3919
3920
+ <div algorithm>
3908
3921
<p> To perform a <dfn export>cross-origin resource policy check</dfn> , given an <a for=url>origin</a>
3909
3922
<var> origin</var> , an <a for=/>environment settings object</a> <var> settingsObject</var> , a string
3910
3923
<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
3946
3959
<var> response</var> is either the <a for="filtered response">internal response</a> of an
3947
3960
<a>opaque filtered response</a> or a <a for=/>response</a> which will be the
3948
3961
<a for="filtered response">internal response</a> of an <a>opaque filtered response</a> . [[HTML]]
3962
+ </div>
3949
3963
3964
+ <div algorithm>
3950
3965
<p> To perform a <dfn>cross-origin resource policy internal check</dfn> , given an
3951
3966
<a for=url>origin</a> <var> origin</var> , an <a for=/>embedder policy value</a>
3952
3967
<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
4029
4044
match a securely-transported initiator.
4030
4045
</dl>
4031
4046
</ol>
4047
+ </div>
4032
4048
4049
+ <div algorithm>
4033
4050
<p> To <dfn>queue a cross-origin embedder policy CORP violation report</dfn> , given a
4034
4051
<a for=/>response</a> <var> response</var> , an <a for=/>environment settings object</a>
4035
4052
<var> settingsObject</var> , a string <var> destination</var> , and a boolean <var> reportOnly</var> ,
@@ -4083,6 +4100,7 @@ run these steps:
4083
4100
<a for="environment settings object">global object</a> given the
4084
4101
<a>"<code>coep</code>" report type</a> , <var> endpoint</var> , and <var> body</var> . [[!REPORTING]]
4085
4102
</ol>
4103
+ </div>
4086
4104
4087
4105
4088
4106
0 commit comments