Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merge the HTTP guidance into the "consult other specs" section. #546

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
33 changes: 7 additions & 26 deletions index.bs
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ Markup Shorthands: markdown on
Boilerplate: feedback-header off
!By: <a href="https://www.w3.org/2001/tag/">Members of the TAG</a>, past and present
!Participate: <a href="https://github.com/w3ctag/design-principles">GitHub w3ctag/design-principles</a> (<a href="https://github.com/w3ctag/design-principles/issues/new">file an issue</a>; <a href="https://github.com/w3ctag/design-principles/issues?state=open">open issues</a>)
Required IDs: using-http

Link Defaults: html (dfn) queue a task/in parallel/reflect
</pre>
Expand Down Expand Up @@ -78,6 +79,8 @@ urlPrefix: https://w3c.github.io/geolocation-api/; spec: geolocation
urlPrefix: https://html.spec.whatwg.org/multipage/; spec: HTML
url: system-state.html#dom-navigator-online; type: attribute; for: NavigatorOnline; text: onLine;
url: media.html#dom-media-play; type:method; for:HTMLMediaElement; text:play()
urlPrefix: https://www.rfc-editor.org/rfc/rfc9110.html; spec: rfc9110
url: #name-accept; type: http-header; text: Accept
urlPrefix: https://w3c.github.io/remote-playback/; spec: REMOTE-PLAYBACK
url: #remoteplayback-interface; type:interface; text: RemotePlayback
url: #dfn-remote-playback-devices; type:dfn; text: remote playback device
Expand Down Expand Up @@ -561,9 +564,11 @@ An incomplete list of such guidance follows:

* [[encoding#specification-hooks|Encoding]]
* [[fetch#fetch-elsewhere|Fetch]]
* <span id="using-http">[[RFC9205 inline]]</span>,
especially on [[RFC9205#section-4.7|defining header fields]], and
[other HTTP RFCs](https://datatracker.ietf.org/doc/search?name=HTTP&amp;sort=&amp;rfcs=on&amp;by=group&amp;group=httpbis)
* [[hr-time#sec-tools|Time]]
* [[url#url-apis-elsewhere|URLs]]
* [[#using-http]]

Consult with the relevant community
when using their specification.
Expand Down Expand Up @@ -1107,7 +1112,7 @@ even if this means using another character to separate values.
<div class=example>

The <{input/accept}> attribute is a comma-separated list of values,
because it needs to match the syntax of the `Accept` HTTP header. (See [[#using-http|guidance on HTTP headers]])
because it needs to match the syntax of the [:Accept:] HTTP header.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
because it needs to match the syntax of the [:Accept:] HTTP header.
because it needs to match the syntax of the [:Accept:] HTTP header field value.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This suggestion is more technically correct, but it's also wordier, and I suspect that nobody's confused by the shorter formulation. I'm inclined not to make the change, but I will if anyone feels strongly.


</div>

Expand Down Expand Up @@ -3136,30 +3141,6 @@ due to security implications, and instead recommend enforcing strict MIME types

New MIME types should have a specification and should be registered with the Internet Assigned Numbers Authority (IANA).

<h3 id="using-http">Consult documentation on best practices when using HTTP</h3>

When using [[RFC9110|HTTP]],
consult [[RFC9205 inline]]
for advice on correct usage of the protocol.

[Fetch](https://fetch.spec.whatwg.org/) is the way that
user agents most often interact with servers.
Fetch defines the CORS protocol and necessary security checks.
Outside of those constraints necessary for security,
Fetch does not provide guidelines on how to best use HTTP.
Appropriate use of methods, header fields, content types, caching, and other HTTP features
might need to be defined.

Recommendations on best practices for HTTP
can be found in [[RFC9205 inline]] and
[other HTTP RFCs](https://datatracker.ietf.org/doc/search?name=HTTP&amp;sort=&amp;rfcs=on&amp;by=group&amp;group=httpbis).
RFC 9205 includes advice on
[[RFC9205#section-4.3|specifying client behavior]],
[[RFC9205#section-4.7|defining header fields]],
[[RFC9205#section-4.8|use of media types]],
[[RFC9205#section-4.16|evolving specifications]], and
other advice on how to get the most out of HTTP.

<h3 id="extend-manifests">Extend existing manifest files rather than creating new ones</h3>

If your feature requires a manifest,
Expand Down
Loading