<?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-rfc2629 version 1.6.5 (Ruby 3.0.3) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-masque-h3-datagram-08" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.12.3 -->
  <front>
    <title abbrev="HTTP Datagrams">HTTP Datagrams and the Capsule Protocol</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-masque-h3-datagram-08"/>
    <author initials="D." surname="Schinazi" fullname="David Schinazi">
      <organization>Google LLC</organization>
      <address>
        <postal>
          <street>1600 Amphitheatre Parkway</street>
          <city>Mountain View, California 94043</city>
          <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="March" day="28"/>
    <workgroup>MASQUE</workgroup>
    <keyword>Internet-Draft</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>Both are intended for use by HTTP extensions, not applications.</t>
    </abstract>
    <note removeInRFC="true">
      <name>Discussion Venues</name>
      <t>Discussion of this document takes place on the MASQUE WG mailing list (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 sometimes need to access underlying transport protocol features
such as unreliable delivery (as offered by <xref target="DGRAM"/>)
to enable desirable features like an unreliable version of the CONNECT method,
and unreliable delivery in WebSockets <xref target="RFC6455"/> (or its successors).</t>
      <t>In <xref target="datagrams"/>, this document describes HTTP Datagrams, a convention that
supports the bidirectional and possibly 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. When the underlying transport protocol supports unreliable delivery (such
as when the QUIC DATAGRAM extension is available in HTTP/3), they can use that
capability.</t>
      <t>This document also describes the HTTP Capsule Protocol in <xref target="capsule"/>, to allow
conveyance of HTTP Datagrams when the QUIC DATAGRAM frame is unavailable or
undesirable, such as when earlier versions of HTTP are in use.</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>
      </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"/>. Negotiation is achieved using a setting; 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 a stream whose HTTP
semantics explicitly supports HTTP Datagrams. 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 associated with a method that has no known semantics for
HTTP Datagrams is received, the receiver <bcp14>MUST</bcp14> abort the corresponding stream; if
HTTP/3 is in use, the stream <bcp14>MUST</bcp14> be aborted with H3_DATAGRAM_ERROR. 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 (using the notation from the "Notational Conventions" section
of <xref target="QUIC"/>):</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.</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.</t>
        <t>HTTP/3 Datagrams <bcp14>MUST NOT</bcp14> be sent unless the corresponding stream's send side is
open. Once the receive side of a stream is closed, incoming datagrams for this
stream are no longer expected so related state can be released. State <bcp14>MAY</bcp14> be
kept for a short time to account for reordering. Once the state is released, the
received associated 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 H3_DATAGRAM HTTP/3 SETTINGS Parameter</name>
          <t>Implementations of HTTP/3 that support HTTP Datagrams can indicate that to
their peer by sending the H3_DATAGRAM SETTINGS parameter with a value of 1.</t>
          <t>The value of the H3_DATAGRAM SETTINGS parameter <bcp14>MUST</bcp14> be either 0 or 1. A value
of 0 indicates that HTTP Datagrams are not supported. If the H3_DATAGRAM
SETTINGS parameter 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 H3_DATAGRAM SETTINGS parameter
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 H3_DATAGRAM
SETTINGS parameter. 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
H3_DATAGRAM SETTINGS parameter 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 H3_DATAGRAM SETTINGS parameter with their
0-RTT state, they <bcp14>MUST</bcp14> validate that the new value of the H3_DATAGRAM SETTINGS
parameter 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 H3_DATAGRAM
SETTINGS parameter is 1.</t>
          <t>It is <bcp14>RECOMMENDED</bcp14> that implementations that support receiving HTTP Datagrams
using QUIC always send the H3_DATAGRAM SETTINGS parameter with a value of 1,
even if the application does not intend to use HTTP 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 H3_DATAGRAM Settings
Parameter. This allows new draft revisions to make incompatible changes.
Multiple draft versions <bcp14>MAY</bcp14> be supported by sending multiple values for
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.</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 a single HTTP request starting the capsule
protocol can be sent on HTTP/1.x connections.</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>
      </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
(using the notation from the "Notational Conventions" section of <xref target="QUIC"/>):</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 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, the Capsule Protocol is not in
use on responses unless the response includes a 2xx (Successful) status code.</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>
      </section>
      <section anchor="error-handling">
        <name>Error Handling</name>
        <t>When an error occurs in processing the Capsule Protocol, the receiver <bcp14>MUST</bcp14> treat
the message as malformed or incomplete, according to the underlying transport
protocol. 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 a malformed or incomplete message. In
particular, redundant length encodings <bcp14>MUST</bcp14> be verified to be self-consistent.</t>
        <t>When a stream carrying capsules terminates cleanly, if the last capsule on the
stream was truncated, this <bcp14>MUST</bcp14> be treated as 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 capsule type (see <xref target="iana-types"/> for the
value of the 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) = DATAGRAM,
  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 which
was received in a QUIC DATAGRAM frame, and vice versa.</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>Note that use of the Capsule Protocol is not required to use HTTP Datagrams. 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 unless they have a good reason not to.</t>
      </section>
    </section>
    <section anchor="security">
      <name>Security Considerations</name>
      <t>Since transmitting HTTP Datagrams using QUIC DATAGRAM frames requires sending an
HTTP/3 Settings parameter, 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 Settings parameter, 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 SETTINGS Parameter</name>
        <t>This document will request IANA to register the following entry in the
"HTTP/3 Settings" registry:</t>
        <dl>
          <dt>Value:</dt>
          <dd>
            <t>0xffd277 (note that this will switch to a lower value before publication)</t>
          </dd>
          <dt>Setting Name:</dt>
          <dd>
            <t>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>
          <dt>Value:</dt>
          <dd>
            <t>0x4A1268 (note that this will switch to a lower value before publication)</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>
          <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. Registrations in this registry
<bcp14>MUST</bcp14> include the following fields:</t>
        <dl>
          <dt>Type:</dt>
          <dd>
            <t>A name or label for the capsule type.</t>
          </dd>
          <dt>Value:</dt>
          <dd>
            <t>The value of the Capsule Type field (see <xref target="capsule-protocol"/>) is a 62-bit
integer.</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>An optional reference to a specification for the type. This field <bcp14>MAY</bcp14> be
empty.</t>
          </dd>
        </dl>
        <t>Registrations follow the "First Come First Served" policy (see Section 4.4 of
<xref target="IANA-POLICY"/>) where two registrations <bcp14>MUST NOT</bcp14> have the same Type.</t>
        <t>This registry initially contains the following entry:</t>
        <dl>
          <dt>Capsule Type:</dt>
          <dd>
            <t>DATAGRAM</t>
          </dd>
          <dt>Value:</dt>
          <dd>
            <t>0xff37a5 (note that this will switch to a lower value before publication)</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>This document</t>
          </dd>
        </dl>
        <t>Capsule types with a value of the form 41 * N + 23 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>
      </section>
    </section>
  </middle>
  <back>
    <references>
      <name>References</name>
      <references>
        <name>Normative References</name>
        <reference anchor="DGRAM">
          <front>
            <title>An Unreliable Datagram Extension to QUIC</title>
            <author fullname="Tommy Pauly">
              <organization>Apple Inc.</organization>
            </author>
            <author fullname="Eric Kinnear">
              <organization>Apple Inc.</organization>
            </author>
            <author fullname="David Schinazi">
              <organization>Google LLC</organization>
            </author>
            <date day="4" month="February" 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.

Discussion Venues

   This note is to be removed before publishing as an RFC.

   Discussion of this document takes place on the QUIC Working Group
   mailing list (mailto:quic@ietf.org), which is archived at
   https://mailarchive.ietf.org/arch/browse/quic/.

   Source for this draft and an issue tracker can be found at
   https://github.com/quicwg/datagram.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-quic-datagram-10"/>
        </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="HTTP">
          <front>
            <title>HTTP Semantics</title>
            <author fullname="Roy T. Fielding">
              <organization>Adobe</organization>
            </author>
            <author fullname="Mark Nottingham">
              <organization>Fastly</organization>
            </author>
            <author fullname="Julian Reschke">
              <organization>greenbytes GmbH</organization>
            </author>
            <date day="12" month="September" year="2021"/>
            <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.

   This document updates RFC 3864 and obsoletes RFC 2818, RFC 7231, RFC
   7232, RFC 7233, RFC 7235, RFC 7538, RFC 7615, RFC 7694, and portions
   of RFC 7230.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-httpbis-semantics-19"/>
        </reference>
        <reference anchor="H3">
          <front>
            <title>Hypertext Transfer Protocol Version 3 (HTTP/3)</title>
            <author fullname="Mike Bishop">
              <organization>Akamai</organization>
            </author>
            <date day="2" month="February" year="2021"/>
            <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.

DO NOT DEPLOY THIS VERSION OF HTTP

   DO NOT DEPLOY THIS VERSION OF HTTP/3 UNTIL IT IS IN AN RFC.  This
   version is still a work in progress.  For trial deployments, please
   use earlier versions.

Note to Readers

   Discussion of this draft takes place on the QUIC working group
   mailing list (quic@ietf.org), which is archived at
   https://mailarchive.ietf.org/arch/search/?email_list=quic.

   Working Group information can be found at https://github.com/quicwg;
   source code and issues list for this draft can be found at
   https://github.com/quicwg/base-drafts/labels/-http.
              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-quic-http-34"/>
        </reference>
        <reference anchor="H2">
          <front>
            <title>HTTP/2</title>
            <author fullname="Martin Thomson">
              <organization>Mozilla</organization>
            </author>
            <author fullname="Cory Benfield">
              <organization>Apple Inc.</organization>
            </author>
            <date day="24" month="January" 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.

   This document obsoletes RFC 7540 and RFC 8740.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-httpbis-http2bis-07"/>
        </reference>
        <reference anchor="H1">
          <front>
            <title>HTTP/1.1</title>
            <author fullname="Roy T. Fielding">
              <organization>Adobe</organization>
            </author>
            <author fullname="Mark Nottingham">
              <organization>Fastly</organization>
            </author>
            <author fullname="Julian Reschke">
              <organization>greenbytes GmbH</organization>
            </author>
            <date day="12" month="September" year="2021"/>
            <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.

   This document obsoletes portions of RFC 7230.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-httpbis-messaging-19"/>
        </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="RFC6455">
          <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="Kazuho Oku">
              <organization>Fastly</organization>
            </author>
            <author fullname="Lucas Pardue">
              <organization>Cloudflare</organization>
            </author>
            <date day="17" month="January" 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="Internet-Draft" value="draft-ietf-httpbis-priority-12"/>
        </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 SETTINGS parameter. 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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
uF7LqYETm0W6hBc9scyWOE8/Ef8NbxphlNZbAAA=

-->

</rfc>
