<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.6.10 (Ruby 3.1.2) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-masque-h3-datagram-10" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.12.10 -->
  <front>
    <title abbrev="HTTP Datagrams">HTTP Datagrams and the Capsule Protocol</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-masque-h3-datagram-10"/>
    <author initials="D." surname="Schinazi" fullname="David Schinazi">
      <organization>Google LLC</organization>
      <address>
        <postal>
          <street>1600 Amphitheatre Parkway</street>
          <city>Mountain View</city>
          <region>CA</region>
          <code>94043</code>
          <country>United States of America</country>
        </postal>
        <email>dschinazi.ietf@gmail.com</email>
      </address>
    </author>
    <author initials="L." surname="Pardue" fullname="Lucas Pardue">
      <organization>Cloudflare</organization>
      <address>
        <email>lucaspardue.24.7@gmail.com</email>
      </address>
    </author>
    <date year="2022" month="June" day="08"/>
    <area>Transport</area>
    <workgroup>MASQUE</workgroup>
    <keyword>quic</keyword>
    <keyword>http</keyword>
    <keyword>datagram</keyword>
    <keyword>fast</keyword>
    <keyword>tunnels</keyword>
    <keyword>turtles all the way down</keyword>
    <keyword>masque</keyword>
    <keyword>http-ng</keyword>
    <abstract>
      <t>This document describes HTTP Datagrams, a convention for conveying multiplexed,
potentially unreliable datagrams inside an HTTP connection.</t>
      <t>In HTTP/3, HTTP Datagrams can be conveyed natively using the QUIC DATAGRAM
extension. When the QUIC DATAGRAM frame is unavailable or undesirable, they can
be sent using the Capsule Protocol, a more general convention for conveying data
in HTTP connections.</t>
      <t>HTTP Datagrams and the Capsule Protocol are intended for use by HTTP extensions,
not applications.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://ietf-wg-masque.github.io/draft-ietf-masque-h3-datagram/draft-ietf-masque-h3-datagram.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-masque-h3-datagram/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        MASQUE Working Group mailing list (<eref target="mailto:masque@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/masque/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/ietf-wg-masque/draft-ietf-masque-h3-datagram"/>.</t>
    </note>
  </front>
  <middle>
    <section anchor="intro">
      <name>Introduction</name>
      <t>HTTP extensions (as defined in <xref section="16" sectionFormat="of" target="HTTP"/>) sometimes need
to access underlying transport protocol features such as unreliable delivery (as
offered by <xref target="DGRAM"/>) to enable desirable features. For example, this
could allow introducing an unreliable version of the CONNECT method, or adding
unreliable delivery to WebSockets <xref target="WEBSOCKET"/>.</t>
      <t>In <xref target="datagrams"/>, this document describes HTTP Datagrams, a convention that
supports the bidirectional and optionally multiplexed exchange of data inside an
HTTP connection. While HTTP datagrams are associated with HTTP requests, they
are not part of message content; instead, they are intended for use by HTTP
extensions (such as the CONNECT method), and are compatible with all versions of
HTTP.</t>
      <t>When HTTP is running over a transport protocol that supports unreliable
delivery (such as when the QUIC DATAGRAM extension is available to HTTP/3), HTTP
Datagrams can use that capability.</t>
      <t>This document also describes the HTTP Capsule Protocol in <xref target="capsule"/>, to allow
conveyance of HTTP Datagrams using reliable delivery. This addresses HTTP/3
cases where use of the QUIC DATAGRAM frame is unavailable or undesirable, or
where the transport protocol only provides reliable delivery, such as with
HTTP/1 or HTTP/2 over TCP.</t>
      <section anchor="defs">
        <name>Conventions and Definitions</name>
        <t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
        <t>This document uses terminology from <xref target="QUIC"/>.</t>
        <t>Where this document defines protocol types, the definition format uses the
notation from <xref section="1.3" sectionFormat="of" target="QUIC"/>. Where fields within types are integers,
they are encoded using the variable-length integer encoding from <xref section="16" sectionFormat="of" target="QUIC"/>. Integer values do not need to be encoded on the minimum number of bytes
necessary.</t>
      </section>
    </section>
    <section anchor="datagrams">
      <name>HTTP Datagrams</name>
      <t>HTTP Datagrams are a convention for conveying bidirectional and potentially
unreliable datagrams inside an HTTP connection, with multiplexing when
possible. All HTTP Datagrams are associated with an HTTP request.</t>
      <t>When HTTP Datagrams are conveyed on an HTTP/3 connection, the QUIC DATAGRAM
frame can be used to achieve these goals, including unreliable delivery; see
<xref target="format"/>. Negotiating the use of QUIC DATAGRAM frames for HTTP Datagrams is
achieved via the exchange of HTTP/3 settings; see <xref target="setting"/>.</t>
      <t>When running over HTTP/2, demultiplexing is provided by the HTTP/2 framing
layer, but unreliable delivery is unavailable. HTTP Datagrams are negotiated
and conveyed using the Capsule Protocol; see <xref target="datagram-capsule"/>.</t>
      <t>When running over HTTP/1, requests are strictly serialized in the connection,
and therefore demultiplexing is not available. Unreliable delivery is likewise
not available. HTTP Datagrams are negotiated and conveyed using the Capsule
Protocol; see <xref target="datagram-capsule"/>.</t>
      <t>HTTP Datagrams <bcp14>MUST</bcp14> only be sent with an association to an HTTP request that
explicitly supports them. For example, existing HTTP methods GET and POST do not
define semantics for associated HTTP Datagrams; therefore, HTTP Datagrams cannot
be sent associated with GET or POST request streams.</t>
      <t>If an HTTP Datagram is received and it is associated with a request that has no
known semantics for HTTP Datagrams, the receiver <bcp14>MUST</bcp14> terminate the request; if
HTTP/3 is in use, the request stream <bcp14>MUST</bcp14> be aborted with H3_DATAGRAM_ERROR
(0x33). HTTP extensions can override these requirements by defining a
negotiation mechanism and semantics for HTTP Datagrams.</t>
      <section anchor="format">
        <name>HTTP/3 Datagrams</name>
        <t>When used with HTTP/3, the Datagram Data field of QUIC DATAGRAM frames uses the
following format:</t>
        <figure anchor="h3-datagram-format">
          <name>HTTP/3 Datagram Format</name>
          <artwork><![CDATA[
HTTP/3 Datagram {
  Quarter Stream ID (i),
  HTTP Datagram Payload (..),
}
]]></artwork>
        </figure>
        <dl>
          <dt>Quarter Stream ID:</dt>
          <dd>
            <t>A variable-length integer that contains the value of the client-initiated
bidirectional stream that this datagram is associated with, divided by four (the
division by four stems from the fact that HTTP requests are sent on
client-initiated bidirectional streams, and those have stream IDs that are
divisible by four). The largest legal QUIC stream ID value is 2<sup>62</sup>-1,
so the largest legal value of Quarter Stream ID is 2<sup>60</sup>-1. Receipt of
an HTTP/3 Datagram that includes a larger value <bcp14>MUST</bcp14> be treated as an HTTP/3
connection error of type H3_DATAGRAM_ERROR (0x33).</t>
          </dd>
          <dt>HTTP Datagram Payload:</dt>
          <dd>
            <t>The payload of the datagram, whose semantics are defined by the extension that
is using HTTP Datagrams. Note that this field can be empty.</t>
          </dd>
        </dl>
        <t>Receipt of a QUIC DATAGRAM frame whose payload is too short to allow parsing the
Quarter Stream ID field <bcp14>MUST</bcp14> be treated as an HTTP/3 connection error of type
H3_DATAGRAM_ERROR (0x33).</t>
        <t>HTTP/3 Datagrams <bcp14>MUST NOT</bcp14> be sent unless the corresponding stream's send side is
open. If a datagram is received after the corresponding stream's receive side is
closed, the received datagrams <bcp14>MUST</bcp14> be silently dropped.</t>
        <t>If an HTTP/3 datagram is received and its Quarter Stream ID maps to a stream
that has not yet been created, the receiver <bcp14>SHALL</bcp14> either drop that datagram
silently or buffer it temporarily (on the order of a round trip) while awaiting
the creation of the corresponding stream.</t>
        <t>If an HTTP/3 datagram is received and its Quarter Stream ID maps to a stream
that cannot be created due to client-initiated bidirectional stream limits, it
<bcp14>SHOULD</bcp14> be treated as an HTTP/3 connection error of type H3_ID_ERROR. Generating
an error is not mandatory in this case because HTTP/3 implementations might have
practical barriers to determining the active stream concurrency limit that is
applied by the QUIC layer.</t>
        <t>Prioritization of HTTP/3 datagrams is not defined in this document. Future
extensions <bcp14>MAY</bcp14> define how to prioritize datagrams, and <bcp14>MAY</bcp14> define signaling to
allow communicating prioritization preferences.</t>
        <section anchor="setting">
          <name>The SETTINGS_H3_DATAGRAM HTTP/3 Setting</name>
          <t>Endpoints can indicate to their peer that they are willing to receive HTTP/3
Datagrams by sending the SETTINGS_H3_DATAGRAM (0x33) setting with a
value of 1.</t>
          <t>The value of the SETTINGS_H3_DATAGRAM setting <bcp14>MUST</bcp14> be either 0 or 1. A value
of 0 indicates that the implementation is not willing to receive HTTP Datagrams.
If the SETTINGS_H3_DATAGRAM setting is received with a value that is neither 0
or 1, the receiver <bcp14>MUST</bcp14> terminate the connection with error H3_SETTINGS_ERROR.</t>
          <t>QUIC DATAGRAM frames <bcp14>MUST NOT</bcp14> be sent until the SETTINGS_H3_DATAGRAM setting
has been both sent and received with a value of 1.</t>
          <t>When clients use 0-RTT, they <bcp14>MAY</bcp14> store the value of the server's
SETTINGS_H3_DATAGRAM setting. Doing so allows the client to send QUIC DATAGRAM
frames in 0-RTT packets. When servers decide to accept 0-RTT data, they <bcp14>MUST</bcp14>
send a SETTINGS_H3_DATAGRAM setting greater than or equal to the value they sent
to the client in the connection where they sent them the NewSessionTicket
message. If a client stores the value of the SETTINGS_H3_DATAGRAM setting with
their 0-RTT state, they <bcp14>MUST</bcp14> validate that the new value of the
SETTINGS_H3_DATAGRAM setting sent by the server in the handshake is greater than
or equal to the stored value; if not, the client <bcp14>MUST</bcp14> terminate the connection
with error H3_SETTINGS_ERROR. In all cases, the maximum permitted value of the
SETTINGS_H3_DATAGRAM setting parameter is 1.</t>
          <t>It is <bcp14>RECOMMENDED</bcp14> that implementations that support receiving HTTP/3 Datagrams
always send the SETTINGS_H3_DATAGRAM setting with a value of 1,
even if the application does not intend to use HTTP/3 Datagrams. This helps to
avoid "sticking out"; see <xref target="security"/>.</t>
          <section anchor="note-about-draft-versions">
            <name>Note About Draft Versions</name>
            <t>[[RFC editor: please remove this section before publication.]]</t>
            <t>Some revisions of this draft specification use a different value (the Identifier
field of a Setting in the HTTP/3 SETTINGS frame) for the SETTINGS_H3_DATAGRAM
setting. This allows new draft revisions to make incompatible changes. Multiple
draft versions <bcp14>MAY</bcp14> be supported by sending multiple values for
SETTINGS_H3_DATAGRAM. Once SETTINGS have been sent and received, an
implementation that supports multiple drafts <bcp14>MUST</bcp14> compute the intersection of
the values it has sent and received, and then it <bcp14>MUST</bcp14> select and use the most
recent draft version from the intersection set. This ensures that both peers
negotiate the same draft version.</t>
          </section>
        </section>
      </section>
      <section anchor="http-datagrams-using-capsules">
        <name>HTTP Datagrams using Capsules</name>
        <t>When HTTP/3 Datagrams are unavailable or undesirable, HTTP Datagrams can be sent
using the Capsule Protocol, see <xref target="datagram-capsule"/>.</t>
      </section>
    </section>
    <section anchor="capsule">
      <name>Capsules</name>
      <t>One mechanism to extend HTTP is to introduce new HTTP Upgrade Tokens (see
<xref section="16.7" sectionFormat="of" target="HTTP"/>). In HTTP/1.x, these tokens are used via the Upgrade
mechanism (see <xref section="7.8" sectionFormat="of" target="HTTP"/>). In HTTP/2 and HTTP/3, these tokens are
used via the Extended CONNECT mechanism (see <xref target="EXT-CONNECT2"/> and
<xref target="EXT-CONNECT3"/>).</t>
      <t>This specification introduces the Capsule Protocol. The Capsule Protocol is a
sequence of type-length-value tuples that definitions of new HTTP Upgrade Tokens
can choose to use. It allows endpoints to reliably communicate request-related
information end-to-end on HTTP request streams, even in the presence of HTTP
intermediaries. The Capsule Protocol can be used to exchange HTTP Datagrams,
which is necessary when HTTP is running over a transport that does not support
the QUIC DATAGRAM frame. The Capsule Protocol can also be used to communicate
reliable and bidirectional control messages associated with a datagram-based
protocol even when HTTP/3 Datagrams are in use.</t>
      <section anchor="data-stream">
        <name>HTTP Data Streams</name>
        <t>This specification defines the "data stream" of an HTTP request as the
bidirectional stream of bytes that follows the header section of the request
message and the final, successful (i.e., 2xx) response message.</t>
        <t>In HTTP/1.x, the data stream consists of all bytes on the connection that follow
the blank line that concludes either the request header section, or the response
header section. As a result, only the last HTTP request on an HTTP/1.x connection
can start the capsule protocol.</t>
        <t>In HTTP/2 and HTTP/3, the data stream of a given HTTP request consists of all
bytes sent in DATA frames with the corresponding stream ID.</t>
        <t>The concept of a data stream is particularly relevant for methods such as
CONNECT where there is no HTTP message content after the headers.</t>
        <t>Data streams can be prioritized using any means suited to stream or request
prioritization. For example, see <xref section="11" sectionFormat="of" target="PRIORITY"/>.</t>
        <t>Data streams are subject to the flow control mechanisms of the underlying layers
(for example, HTTP/2 stream flow control, HTTP/2 connection flow control, and
TCP flow control).</t>
      </section>
      <section anchor="capsule-protocol">
        <name>The Capsule Protocol</name>
        <t>Definitions of new HTTP Upgrade Tokens can state that their associated request's
data stream uses the Capsule Protocol. If they do so, that means that the
contents of the associated request's data stream uses the following format:</t>
        <figure anchor="capsule-stream-format">
          <name>Capsule Protocol Stream Format</name>
          <artwork><![CDATA[
Capsule Protocol {
  Capsule (..) ...,
}
]]></artwork>
        </figure>
        <figure anchor="capsule-format">
          <name>Capsule Format</name>
          <artwork><![CDATA[
Capsule {
  Capsule Type (i),
  Capsule Length (i),
  Capsule Value (..),
}
]]></artwork>
        </figure>
        <dl>
          <dt>Capsule Type:</dt>
          <dd>
            <t>A variable-length integer indicating the Type of the capsule.</t>
          </dd>
          <dt>Capsule Length:</dt>
          <dd>
            <t>The length in bytes of the Capsule Value field following this field, encoded
as a variable-length integer. Note that this field can have a value of zero.</t>
          </dd>
          <dt>Capsule Value:</dt>
          <dd>
            <t>The payload of this capsule. Its semantics are determined by the value of the
Capsule Type field.</t>
          </dd>
        </dl>
        <t>An intermediary can identify the use of the capsule protocol either through the
presence of the Capsule-Protocol header field (<xref target="hdr"/>) or by understanding the
chosen HTTP Upgrade token.</t>
        <t>Because new protocols or extensions might define new capsule types,
intermediaries that wish to allow for future extensibility <bcp14>SHOULD</bcp14> forward
capsules without modification, unless the definition of the Capsule Type in use
specifies additional intermediary processing. One such Capsule Type is the
DATAGRAM capsule; see <xref target="datagram-capsule"/>. In particular, intermediaries <bcp14>SHOULD</bcp14>
forward Capsules with an unknown Capsule Type without modification.</t>
        <t>Endpoints which receive a Capsule with an unknown Capsule Type <bcp14>MUST</bcp14> silently
drop that Capsule and skip over it to parse the next Capsule.</t>
        <t>By virtue of the definition of the data stream:</t>
        <ul spacing="normal">
          <li>The Capsule Protocol is not in use unless the response includes a 2xx
(Successful) status code.</li>
          <li>When the Capsule Protocol is in use, the associated HTTP request and response
do not carry HTTP content. A future extension <bcp14>MAY</bcp14> define a new capsule type to
carry HTTP content.</li>
        </ul>
        <t>Since the Capsule Protocol only applies to definitions of new HTTP Upgrade
Tokens, in HTTP/2 and HTTP/3 it can only be used with the CONNECT method.
Therefore, once both endpoints agree to use the Capsule Protocol, the frame
usage requirements of the stream change as specified in <xref section="8.5" sectionFormat="of" target="H2"/>
and <xref section="4.2" sectionFormat="of" target="H3"/>.</t>
        <t>The Capsule Protocol <bcp14>MUST NOT</bcp14> be used with messages that contain Content-Length,
Content-Type, or Transfer-Encoding header fields. Additionally, HTTP status
codes 204 (No Content), 205 (Reset Content), and 206 (Partial Content) <bcp14>MUST NOT</bcp14>
be sent on responses that use the Capsule Protocol. A receiver that observes a
violation of these requirements <bcp14>MUST</bcp14> treat the HTTP message as malformed.</t>
        <t>When processing capsules, a receiver might be tempted to accumulate the full
length of the capsule value in the data stream before handling it. This approach
can consume flow control in underlying layers, which might lead to deadlocks if
the capsule data exhausts the flow control window.</t>
      </section>
      <section anchor="error-handling">
        <name>Error Handling</name>
        <t>When a receiver encounters an error processing the Capsule Protocol, the
receiver <bcp14>MUST</bcp14> treat it as if it had received a malformed or incomplete HTTP
message. For HTTP/3, the handling of malformed messages is described in
<xref section="4.1.3" sectionFormat="of" target="H3"/>. For HTTP/2, the handling of malformed messages is
described in <xref section="8.1.1" sectionFormat="of" target="H2"/>. For HTTP/1.1, the handling of incomplete
messages is described in <xref section="8" sectionFormat="of" target="H1"/>.</t>
        <t>Each capsule's payload <bcp14>MUST</bcp14> contain exactly the fields identified in its
description. A capsule payload that contains additional bytes after the
identified fields or a capsule payload that terminates before the end of the
identified fields <bcp14>MUST</bcp14> be treated as it if were a malformed or incomplete
message. In particular, redundant length encodings <bcp14>MUST</bcp14> be verified to be
self-consistent.</t>
        <t>If the receive side of a stream carrying capsules is terminated cleanly (for
example, in HTTP/3 this is defined as receiving a QUIC STREAM frame with the FIN
bit set) and the last capsule on the stream was truncated, this <bcp14>MUST</bcp14> be treated
as if it were a malformed or incomplete message.</t>
      </section>
      <section anchor="hdr">
        <name>The Capsule-Protocol Header Field</name>
        <t>The "Capsule-Protocol" header field is an Item Structured Field, see <xref section="3.3" sectionFormat="of" target="STRUCT-FIELD"/>; its value <bcp14>MUST</bcp14> be a Boolean; any other value
type <bcp14>MUST</bcp14> be handled as if the field were not present by recipients (for
example, if this field is included multiple times, its type will become a List
and the field will therefore be ignored). This document does not define any
parameters for the Capsule-Protocol header field value, but future documents
might define parameters. Receivers <bcp14>MUST</bcp14> ignore unknown parameters.</t>
        <t>Endpoints indicate that the Capsule Protocol is in use on a data stream by
sending a Capsule-Protocol header field with a true value. A Capsule-Protocol
header field with a false value has the same semantics as when the header is not
present.</t>
        <t>Intermediaries <bcp14>MAY</bcp14> use this header field to allow processing of HTTP Datagrams
for unknown HTTP Upgrade Tokens; note that this is only possible for HTTP
Upgrade or Extended CONNECT.</t>
        <t>The Capsule-Protocol header field <bcp14>MUST NOT</bcp14> be used on HTTP responses with a
status code outside the 2xx range.</t>
        <t>When using the Capsule Protocol, HTTP endpoints <bcp14>SHOULD</bcp14> send the Capsule-Protocol
header field to simplify intermediary processing. Definitions of new HTTP
Upgrade Tokens that use the Capsule Protocol <bcp14>MAY</bcp14> alter this recommendation.</t>
      </section>
      <section anchor="datagram-capsule">
        <name>The DATAGRAM Capsule</name>
        <t>This document defines the DATAGRAM (0x00) capsule type. This capsule allows HTTP
Datagrams to be sent on a stream using the Capsule Protocol. This is
particularly useful when HTTP is running over a transport that does not support
the QUIC DATAGRAM frame.</t>
        <figure anchor="datagram-capsule-format">
          <name>DATAGRAM Capsule Format</name>
          <artwork><![CDATA[
Datagram Capsule {
  Type (i) = 0x00,
  Length (i),
  HTTP Datagram Payload (..),
}
]]></artwork>
        </figure>
        <dl>
          <dt>HTTP Datagram Payload:</dt>
          <dd>
            <t>The payload of the datagram, whose semantics are defined by the extension that
is using HTTP Datagrams. Note that this field can be empty.</t>
          </dd>
        </dl>
        <t>HTTP Datagrams sent using the DATAGRAM capsule have the same semantics as
those sent in QUIC DATAGRAM frames. In particular, the restrictions on when
it is allowed to send an HTTP Datagram and how to process them from <xref target="format"/>
also apply to HTTP Datagrams sent and received using the DATAGRAM capsule.</t>
        <t>An intermediary can reencode HTTP Datagrams as it forwards them. In other words,
an intermediary <bcp14>MAY</bcp14> send a DATAGRAM capsule to forward an HTTP Datagram that
was received in a QUIC DATAGRAM frame, and vice versa. Intermediaries <bcp14>MUST NOT</bcp14>
perform this reencoding unless they have identified the use of the Capsule
Protocol on the corresponding request stream; see <xref target="capsule-protocol"/>.</t>
        <t>Note that while DATAGRAM capsules that are sent on a stream are reliably
delivered in order, intermediaries can reencode DATAGRAM capsules into QUIC
DATAGRAM frames when forwarding messages, which could result in loss or
reordering.</t>
        <t>If an intermediary receives an HTTP Datagram in a QUIC DATAGRAM frame and is
forwarding it on a connection that supports QUIC DATAGRAM frames, the
intermediary <bcp14>SHOULD NOT</bcp14> convert that HTTP Datagram to a DATAGRAM capsule. If the
HTTP Datagram is too large to fit in a DATAGRAM frame (for example because the
path MTU of that QUIC connection is too low or if the maximum UDP payload size
advertised on that connection is too low), the intermediary <bcp14>SHOULD</bcp14> drop the HTTP
Datagram instead of converting it to a DATAGRAM capsule. This preserves the
end-to-end unreliability characteristic that methods such as Datagram
Packetization Layer Path MTU Discovery (DPLPMTUD) depend on
<xref target="DPLPMTUD"/>. An intermediary that converts QUIC DATAGRAM frames to
DATAGRAM capsules allows HTTP Datagrams to be arbitrarily large without
suffering any loss; this can misrepresent the true path properties, defeating
methods such as DPLPMTUD.</t>
        <t>While DATAGRAM capsules can theoretically carry a payload of length
2<sup>62</sup>-1, most HTTP extensions that use HTTP Datagrams will have their
own limits on what datagram payload sizes are practical. Implementations <bcp14>SHOULD</bcp14>
take those limits into account when parsing DATAGRAM capsules: if an incoming
DATAGRAM capsule has a length that is known to be so large as to not be usable,
the implementation <bcp14>SHOULD</bcp14> discard the capsule without buffering its contents
into memory.</t>
        <t>Since QUIC DATAGRAM frames are required to fit within a QUIC packet,
implementations that reencode DATAGRAM capsules into QUIC DATAGRAM frames might
be tempted to accumulate the entire capsule before reencoding it. This can cause
flow control problems; see <xref target="capsule-protocol"/>.</t>
        <t>Note that it is possible for an HTTP extension to use HTTP Datagrams without
using the Capsule Protocol. For example, if an HTTP extension that uses HTTP
Datagrams is only defined over transports that support QUIC DATAGRAM frames, it
might not need a stream encoding. Additionally, HTTP extensions can use HTTP
Datagrams with their own data stream protocol. However, new HTTP extensions that
wish to use HTTP Datagrams <bcp14>SHOULD</bcp14> use the Capsule Protocol as failing to do so
will make it harder for the HTTP extension to support versions of HTTP other
than HTTP/3 and will prevent interoperability with intermediaries that only
support the Capsule Protocol.</t>
      </section>
    </section>
    <section anchor="security">
      <name>Security Considerations</name>
      <t>Since transmitting HTTP Datagrams using QUIC DATAGRAM frames requires sending
the HTTP/3 SETTINGS_H3_DATAGRAM setting, it "sticks out". In other words,
probing clients can learn whether a server supports HTTP Datagrams over QUIC
DATAGRAM frames. As some servers might wish to obfuscate the fact that they
offer application services that use HTTP datagrams, it's best for all
implementations that support this feature to always send this setting, see
<xref target="setting"/>.</t>
      <t>Since use of the Capsule Protocol is restricted to new HTTP Upgrade Tokens, it
is not accessible from Web Platform APIs (such as those commonly accessed via
JavaScript in web browsers).</t>
    </section>
    <section anchor="iana">
      <name>IANA Considerations</name>
      <section anchor="iana-setting">
        <name>HTTP/3 Setting</name>
        <t>This document will request IANA to register the following entry in the
"HTTP/3 Settings" registry:</t>
        <dl spacing="compact">
          <dt>Value:</dt>
          <dd>
            <t>0x33</t>
          </dd>
          <dt>Setting Name:</dt>
          <dd>
            <t>SETTINGS_H3_DATAGRAM</t>
          </dd>
          <dt>Default:</dt>
          <dd>
            <t>0</t>
          </dd>
          <dt>Status:</dt>
          <dd>
            <t>provisional (permanent if this document is approved)</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This Document</t>
          </dd>
          <dt>Change Controller:</dt>
          <dd>
            <t>IETF</t>
          </dd>
          <dt>Contact:</dt>
          <dd>
            <t>HTTP_WG; HTTP working group; ietf-http-wg@w3.org</t>
          </dd>
        </dl>
      </section>
      <section anchor="iana-error">
        <name>HTTP/3 Error Code</name>
        <t>This document will request IANA to register the following entry in the
"HTTP/3 Error Codes" registry:</t>
        <dl spacing="compact">
          <dt>Value:</dt>
          <dd>
            <t>0x33</t>
          </dd>
          <dt>Name:</dt>
          <dd>
            <t>H3_DATAGRAM_ERROR</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>Datagram or capsule protocol parse error</t>
          </dd>
          <dt>Status:</dt>
          <dd>
            <t>provisional (permanent if this document is approved)</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This Document</t>
          </dd>
          <dt>Change Controller:</dt>
          <dd>
            <t>IETF</t>
          </dd>
          <dt>Contact:</dt>
          <dd>
            <t>HTTP_WG; HTTP working group; ietf-http-wg@w3.org</t>
          </dd>
        </dl>
      </section>
      <section anchor="iana-hdr">
        <name>HTTP Header Field Name</name>
        <t>This document will request IANA to register the following entry in the "HTTP
Field Name" registry:</t>
        <dl spacing="compact">
          <dt>Field Name:</dt>
          <dd>
            <t>Capsule-Protocol</t>
          </dd>
          <dt>Template:</dt>
          <dd>
            <t>None</t>
          </dd>
          <dt>Status:</dt>
          <dd>
            <t>provisional (permanent if this document is approved)</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>This document</t>
          </dd>
          <dt>Comments:</dt>
          <dd>
            <t>None</t>
          </dd>
        </dl>
      </section>
      <section anchor="iana-types">
        <name>Capsule Types</name>
        <t>This document establishes a registry for HTTP capsule type codes. The "HTTP
Capsule Types" registry governs a 62-bit space, and operates under the QUIC
registration policy documented in <xref section="22.1" sectionFormat="of" target="QUIC"/>. This new registry
includes the common set of fields listed in <xref section="22.1.1" sectionFormat="of" target="QUIC"/>. In
addition to those common fields, all registrations in this registry <bcp14>MUST</bcp14> include
a "Capsule Type" field which contains a short name or label for the capsule type.</t>
        <t>Permanent registrations in this registry are assigned using the Specification
Required policy (<xref section="4.6" sectionFormat="of" target="IANA-POLICY"/>), except for values
between 0x00 and 0x3f (in hexadecimal; inclusive), which are assigned using
Standards Action or IESG Approval as defined in Sections <xref target="IANA-POLICY" section="4.9" sectionFormat="bare"/> and <xref target="IANA-POLICY" section="4.10" sectionFormat="bare"/> of <xref target="IANA-POLICY"/>.</t>
        <t>Capsule types with a value of the form 0x29 * N + 0x17 for integer values of N
are reserved to exercise the requirement that unknown capsule types be ignored.
These capsules have no semantics and can carry arbitrary values. These values
<bcp14>MUST NOT</bcp14> be assigned by IANA and <bcp14>MUST NOT</bcp14> appear in the listing of assigned
values.</t>
        <t>This registry initially contains the following entry:</t>
        <dl spacing="compact">
          <dt>Value:</dt>
          <dd>
            <t>0x00</t>
          </dd>
          <dt>Capsule Type:</dt>
          <dd>
            <t>DATAGRAM</t>
          </dd>
          <dt>Status:</dt>
          <dd>
            <t>permanent</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This document</t>
          </dd>
          <dt>Change Controller:</dt>
          <dd>
            <t>IETF</t>
          </dd>
          <dt>Contact:</dt>
          <dd>
            <t>MASQUE Working Group <eref target="mailto:masque@ietf.org">masque@ietf.org</eref></t>
          </dd>
          <dt>Notes:</dt>
          <dd>
            <t>None</t>
          </dd>
        </dl>
      </section>
    </section>
  </middle>
  <back>
    <displayreference target="H1" to="HTTP/1.1"/>
    <displayreference target="H2" to="HTTP/2"/>
    <displayreference target="H3" to="HTTP/3"/>
    <references>
      <name>References</name>
      <references>
        <name>Normative References</name>
        <reference anchor="H1">
          <front>
            <title>HTTP/1.1</title>
            <author fullname="R. Fielding" initials="R." role="editor" surname="Fielding">
              <organization/>
            </author>
            <author fullname="M. Nottingham" initials="M." role="editor" surname="Nottingham">
              <organization/>
            </author>
            <author fullname="J. Reschke" initials="J." role="editor" surname="Reschke">
              <organization/>
            </author>
            <date month="June" year="2022"/>
            <abstract>
              <t>The Hypertext Transfer Protocol (HTTP) is a stateless application-level protocol for distributed, collaborative, hypertext information systems. This document specifies the HTTP/1.1 message syntax, message parsing, connection management, and related security concerns. </t>
              <t>This document obsoletes portions of RFC 7230.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="99"/>
          <seriesInfo name="RFC" value="9112"/>
          <seriesInfo name="DOI" value="10.17487/RFC9112"/>
        </reference>
        <reference anchor="H2">
          <front>
            <title>HTTP/2</title>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson">
              <organization/>
            </author>
            <author fullname="C. Benfield" initials="C." role="editor" surname="Benfield">
              <organization/>
            </author>
            <date month="June" year="2022"/>
            <abstract>
              <t>This specification describes an optimized expression of the semantics of the Hypertext Transfer Protocol (HTTP), referred to as HTTP version 2 (HTTP/2). HTTP/2 enables a more efficient use of network resources and a reduced latency by introducing field compression and allowing multiple concurrent exchanges on the same connection.</t>
              <t>This document obsoletes RFCs 7540 and 8740.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9113"/>
          <seriesInfo name="DOI" value="10.17487/RFC9113"/>
        </reference>
        <reference anchor="H3">
          <front>
            <title>HTTP/3</title>
            <author fullname="M. Bishop" initials="M." role="editor" surname="Bishop">
              <organization/>
            </author>
            <date month="June" year="2022"/>
            <abstract>
              <t>The QUIC transport protocol has several features that are desirable in a transport for HTTP, such as stream multiplexing, per-stream flow control, and low-latency connection establishment.  This document describes a mapping of HTTP semantics over QUIC.  This document also identifies HTTP/2 features that are subsumed by QUIC and describes how HTTP/2 extensions can be ported to HTTP/3.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9114"/>
          <seriesInfo name="DOI" value="10.17487/RFC9114"/>
        </reference>
        <reference anchor="HTTP">
          <front>
            <title>HTTP Semantics</title>
            <author fullname="R. Fielding" initials="R." role="editor" surname="Fielding">
              <organization/>
            </author>
            <author fullname="M. Nottingham" initials="M." role="editor" surname="Nottingham">
              <organization/>
            </author>
            <author fullname="J. Reschke" initials="J." role="editor" surname="Reschke">
              <organization/>
            </author>
            <date month="June" year="2022"/>
            <abstract>
              <t>The Hypertext Transfer Protocol (HTTP) is a stateless application-level protocol for distributed, collaborative, hypertext information systems. This document describes the overall architecture of HTTP, establishes common terminology, and defines aspects of the protocol that are shared by all versions. In this definition are core protocol elements, extensibility mechanisms, and the "http" and "https" Uniform Resource Identifier (URI) schemes. </t>
              <t>This document updates RFC 3864 and obsoletes RFCs 2818, 7231, 7232, 7233, 7235, 7538, 7615, 7694, and portions of 7230.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="97"/>
          <seriesInfo name="RFC" value="9110"/>
          <seriesInfo name="DOI" value="10.17487/RFC9110"/>
        </reference>
        <reference anchor="DGRAM">
          <front>
            <title>An Unreliable Datagram Extension to QUIC</title>
            <author fullname="T. Pauly" initials="T." surname="Pauly">
              <organization/>
            </author>
            <author fullname="E. Kinnear" initials="E." surname="Kinnear">
              <organization/>
            </author>
            <author fullname="D. Schinazi" initials="D." surname="Schinazi">
              <organization/>
            </author>
            <date month="March" year="2022"/>
            <abstract>
              <t>This document defines an extension to the QUIC transport protocol to add support for sending and receiving unreliable datagrams over a QUIC connection.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9221"/>
          <seriesInfo name="DOI" value="10.17487/RFC9221"/>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner">
              <organization/>
            </author>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification.  These words are often capitalized. This document defines these words as they should be interpreted in IETF documents.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba">
              <organization/>
            </author>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol  specifications.  This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the  defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="QUIC">
          <front>
            <title>QUIC: A UDP-Based Multiplexed and Secure Transport</title>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar">
              <organization/>
            </author>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson">
              <organization/>
            </author>
            <date month="May" year="2021"/>
            <abstract>
              <t>This document defines the core of the QUIC transport protocol.  QUIC provides applications with flow-controlled streams for structured communication, low-latency connection establishment, and network path migration. QUIC includes security measures that ensure confidentiality, integrity, and availability in a range of deployment circumstances.  Accompanying documents describe the integration of TLS for key negotiation, loss detection, and an exemplary congestion control algorithm.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9000"/>
          <seriesInfo name="DOI" value="10.17487/RFC9000"/>
        </reference>
        <reference anchor="STRUCT-FIELD">
          <front>
            <title>Structured Field Values for HTTP</title>
            <author fullname="M. Nottingham" initials="M." surname="Nottingham">
              <organization/>
            </author>
            <author fullname="P-H. Kamp" initials="P-H." surname="Kamp">
              <organization/>
            </author>
            <date month="February" year="2021"/>
            <abstract>
              <t>This document describes a set of data types and associated algorithms that are intended to make it easier and safer to define and handle HTTP header and trailer fields, known as "Structured Fields", "Structured Headers", or "Structured Trailers". It is intended for use by specifications of new HTTP fields that wish to use a common syntax that is more restrictive than traditional HTTP field values.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8941"/>
          <seriesInfo name="DOI" value="10.17487/RFC8941"/>
        </reference>
        <reference anchor="IANA-POLICY">
          <front>
            <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
            <author fullname="M. Cotton" initials="M." surname="Cotton">
              <organization/>
            </author>
            <author fullname="B. Leiba" initials="B." surname="Leiba">
              <organization/>
            </author>
            <author fullname="T. Narten" initials="T." surname="Narten">
              <organization/>
            </author>
            <date month="June" year="2017"/>
            <abstract>
              <t>Many protocols make use of points of extensibility that use constants to identify various protocol parameters.  To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper.  For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
              <t>To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed.  This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
              <t>This is the third edition of this document; it obsoletes RFC 5226.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="26"/>
          <seriesInfo name="RFC" value="8126"/>
          <seriesInfo name="DOI" value="10.17487/RFC8126"/>
        </reference>
      </references>
      <references>
        <name>Informative References</name>
        <reference anchor="WEBSOCKET">
          <front>
            <title>The WebSocket Protocol</title>
            <author fullname="I. Fette" initials="I." surname="Fette">
              <organization/>
            </author>
            <author fullname="A. Melnikov" initials="A." surname="Melnikov">
              <organization/>
            </author>
            <date month="December" year="2011"/>
            <abstract>
              <t>The WebSocket Protocol enables two-way communication between a client running untrusted code in a controlled environment to a remote host that has opted-in to communications from that code.  The security model used for this is the origin-based security model commonly used by web browsers.  The protocol consists of an opening handshake followed by basic message framing, layered over TCP.  The goal of this technology is to provide a mechanism for browser-based applications that need two-way communication with servers that does not rely on opening multiple HTTP connections (e.g., using XMLHttpRequest or &lt;iframe&gt;s and long polling).  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6455"/>
          <seriesInfo name="DOI" value="10.17487/RFC6455"/>
        </reference>
        <reference anchor="EXT-CONNECT2">
          <front>
            <title>Bootstrapping WebSockets with HTTP/2</title>
            <author fullname="P. McManus" initials="P." surname="McManus">
              <organization/>
            </author>
            <date month="September" year="2018"/>
            <abstract>
              <t>This document defines a mechanism for running the WebSocket Protocol (RFC 6455) over a single stream of an HTTP/2 connection.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8441"/>
          <seriesInfo name="DOI" value="10.17487/RFC8441"/>
        </reference>
        <reference anchor="EXT-CONNECT3">
          <front>
            <title>Bootstrapping WebSockets with HTTP/3</title>
            <author fullname="Ryan Hamilton">
              <organization>Google</organization>
            </author>
            <date day="8" month="February" year="2022"/>
            <abstract>
              <t>   The mechanism for running the WebSocket Protocol over a single stream
   of an HTTP/2 connection is equally applicable to HTTP/3, but the HTTP
   version-specific details need to be specified.  This document
   describes how the mechanism is adapted for HTTP/3.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-httpbis-h3-websockets-04"/>
        </reference>
        <reference anchor="PRIORITY">
          <front>
            <title>Extensible Prioritization Scheme for HTTP</title>
            <author fullname="K. Oku" initials="K." surname="Oku">
              <organization/>
            </author>
            <author fullname="L. Pardue" initials="L." surname="Pardue">
              <organization/>
            </author>
            <date month="June" year="2022"/>
            <abstract>
              <t>This document describes a scheme that allows an HTTP client to communicate its preferences for how the upstream server prioritizes responses to its requests, and also allows a server to hint to a downstream intermediary how its responses should be prioritized when they are forwarded.  This document defines the Priority header field for communicating the initial priority in an HTTP version-independent manner, as well as HTTP/2 and HTTP/3 frames for reprioritizing responses. These share a common format structure that is designed to provide future extensibility.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9218"/>
          <seriesInfo name="DOI" value="10.17487/RFC9218"/>
        </reference>
        <reference anchor="DPLPMTUD">
          <front>
            <title>Packetization Layer Path MTU Discovery for Datagram Transports</title>
            <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
              <organization/>
            </author>
            <author fullname="T. Jones" initials="T." surname="Jones">
              <organization/>
            </author>
            <author fullname="M. Tüxen" initials="M." surname="Tüxen">
              <organization/>
            </author>
            <author fullname="I. Rüngeler" initials="I." surname="Rüngeler">
              <organization/>
            </author>
            <author fullname="T. Völker" initials="T." surname="Völker">
              <organization/>
            </author>
            <date month="September" year="2020"/>
            <abstract>
              <t>This document specifies Datagram Packetization Layer Path MTU Discovery (DPLPMTUD). This is a robust method for Path MTU Discovery (PMTUD) for datagram Packetization Layers (PLs). It allows a PL, or a datagram application that uses a PL, to discover whether a network path can support the current size of datagram.  This can be used to detect and reduce the message size when a sender encounters a packet black hole. It can also probe a network path to discover whether the maximum packet size can be increased.  This provides functionality for datagram transports that is equivalent to the PLPMTUD specification for TCP, specified in RFC 4821, which it updates. It also updates the UDP Usage Guidelines to refer to this method for use with UDP datagrams and updates SCTP.</t>
              <t>The document provides implementation notes for incorporating Datagram PMTUD into IETF datagram transports or applications that use datagram transports.</t>
              <t>This specification updates RFC 4960, RFC 4821, RFC 6951, RFC 8085, and RFC 8261.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8899"/>
          <seriesInfo name="DOI" value="10.17487/RFC8899"/>
        </reference>
      </references>
    </references>
    <section numbered="false" anchor="acks">
      <name>Acknowledgments</name>
      <t>Portions of this document were previously part of the QUIC DATAGRAM frame
definition itself, the authors would like to acknowledge the authors of that
document and the members of the IETF MASQUE working group for their suggestions.
Additionally, the authors would like to thank Martin Thomson for suggesting the
use of an HTTP/3 setting. Furthermore, the authors would like to
thank Ben Schwartz for writing the first proposal that used two layers of
indirection. The final design in this document came out of the HTTP Datagrams
Design Team, whose members were Alan Frindell, Alex Chernyakhovsky, Ben
Schwartz, Eric Rescorla, Marcus Ihlar, Martin Thomson, Mike Bishop, Tommy Pauly,
Victor Vasiliev, and the authors of this document. The authors thank Mark
Nottingham and Philipp Tiesel for their helpful comments.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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

-->

</rfc>
