<?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.7.30 (Ruby 3.4.8) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-webtrans-http2-14" category="std" consensus="true" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.31.0 -->
  <front>
    <title abbrev="WebTransport-H2">WebTransport over HTTP/2</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-webtrans-http2-14"/>
    <author initials="A." surname="Frindell" fullname="Alan Frindell">
      <organization>Facebook Inc.</organization>
      <address>
        <email>afrind@fb.com</email>
      </address>
    </author>
    <author initials="E." surname="Kinnear" fullname="Eric Kinnear">
      <organization>Apple Inc.</organization>
      <address>
        <postal>
          <street>One Apple Park Way</street>
          <city>Cupertino, California 95014</city>
          <country>United States of America</country>
        </postal>
        <email>ekinnear@apple.com</email>
      </address>
    </author>
    <author initials="T." surname="Pauly" fullname="Tommy Pauly">
      <organization>Apple Inc.</organization>
      <address>
        <postal>
          <street>One Apple Park Way</street>
          <city>Cupertino, California 95014</city>
          <country>United States of America</country>
        </postal>
        <email>tpauly@apple.com</email>
      </address>
    </author>
    <author initials="M." surname="Thomson" fullname="Martin Thomson">
      <organization>Mozilla</organization>
      <address>
        <email>mt@lowentropy.net</email>
      </address>
    </author>
    <author initials="V." surname="Vasiliev" fullname="Victor Vasiliev">
      <organization>Google</organization>
      <address>
        <email>vasilvv@google.com</email>
      </address>
    </author>
    <author initials="G." surname="Xie" fullname="Guowu Xie">
      <organization>Facebook Inc.</organization>
      <address>
        <email>woo@fb.com</email>
      </address>
    </author>
    <date year="2026" month="March" day="02"/>
    <area>Web and Internet Transport</area>
    <workgroup>WEBTRANS</workgroup>
    <keyword>webtransport</keyword>
    <abstract>
      <?line 75?>

<t>WebTransport defines a set of low-level communications features designed for
client-server interactions that are initiated by Web clients.  This document
describes a protocol that can provide many of the capabilities of WebTransport
over HTTP/2.  This protocol enables the use of WebTransport when a UDP-based
protocol is not available.</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-webtrans.github.io/draft-ietf-webtrans-http2/#go.draft-ietf-webtrans-http2.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-webtrans-http2/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        WebTransport Working Group mailing list (<eref target="mailto:webtransport@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/webtransport/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/webtransport/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/ietf-wg-webtrans/draft-ietf-webtrans-http2"/>.</t>
    </note>
  </front>
  <middle>
    <?line 83?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>WebTransport <xref target="OVERVIEW"/> is designed to provide generic communication
capabilities to Web clients that use HTTP/3 <xref target="HTTP3"/>.  The HTTP/3 WebTransport
protocol <xref target="WEBTRANSPORT-H3"/> allows Web clients to use QUIC <xref target="QUIC"/> features
such as streams or datagrams <xref target="DATAGRAM"/>.  However, there are some
environments where QUIC cannot be deployed.</t>
      <t>This document defines a protocol that provides all of the core functions of
WebTransport using HTTP semantics. This includes unidirectional streams,
bidirectional streams, and datagrams.</t>
      <t>By relying only on generic HTTP semantics, this protocol might allow deployment
using any HTTP version.  However, this document only defines negotiation for
HTTP/2 <xref target="HTTP2"/> as the current most common TCP-based fallback to HTTP/3.</t>
      <section anchor="terminology">
        <name>Terminology</name>
        <t>The keywords "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD",
"SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" 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 follows terminology defined in <xref section="1.2" sectionFormat="of" target="OVERVIEW"/>. Note
that this document distinguishes between a WebTransport server and an HTTP/2
server. An HTTP/2 server is the server that terminates HTTP/2 connections; a
WebTransport server is an application that accepts WebTransport sessions, which
can be accessed using HTTP/2 and this protocol.</t>
      </section>
    </section>
    <section anchor="protocol-overview">
      <name>Protocol Overview</name>
      <t>WebTransport servers are identified by an HTTPS URI as defined in
<xref section="4.2.2" sectionFormat="of" target="HTTP"/>.</t>
      <t>When an HTTP/2 connection is established, the server sends a
SETTINGS_WT_MAX_SESSIONS setting with a value greater than "0" to indicate that
it supports WebTransport over HTTP/2. The value of the setting is the number of
concurrent sessions the server is willing to receive. Note that the client does
not need to send any value to indicate support for WebTransport; clients
indicate support for WebTransport by using the "webtransport" upgrade token in
CONNECT requests establishing WebTransport sessions (see <xref target="upgrade-token"/>).</t>
      <t>A client initiates a WebTransport session by sending an extended CONNECT request
<xref target="RFC8441"/>. If the server accepts the request, a WebTransport session is
established. The stream that carries the CONNECT request is used to exchange
bidirectional data for the session. This stream will be referred to as a
<em>CONNECT stream</em>.  The stream ID of a CONNECT stream, which will be referred to
as a <em>Session ID</em>, is used to uniquely identify a given WebTransport session
within the connection.  WebTransport using HTTP/2 uses extended CONNECT with the
<tt>webtransport</tt> HTTP Upgrade Token (<xref target="upgrade-token"/>).  This Upgrade Token uses
the Capsule Protocol as defined in <xref target="HTTP-DATAGRAM"/>.</t>
      <t>After the session is established, endpoints exchange WebTransport messages using
the Capsule Protocol on the bidirectional CONNECT stream, the "data stream" as
defined in <xref section="3.1" sectionFormat="of" target="HTTP-DATAGRAM"/>.</t>
      <t>Within this stream, <em>WebTransport streams</em> and <em>WebTransport datagrams</em> are
multiplexed.  In HTTP/2, WebTransport capsules are carried in HTTP/2 DATA
frames. Multiple independent WebTransport sessions can share a connection if the
HTTP version supports that, as HTTP/2 does.</t>
      <t>WebTransport capsules closely mirror a subset of QUIC frames and provide the
essential WebTransport features.  Within a WebTransport session, endpoints can
create and use bidirectional or unidirectional streams with no additional round
trips using the <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule.</t>
      <t>Stream creation and data flow on streams uses flow control mechanisms modeled on
those in QUIC. Flow control is managed using the WebTransport capsules:
<iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref>, <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref>, <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref>, <iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref>,
<iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref>, and <iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref>. Flow control for the CONNECT
stream as a whole, as provided by the HTTP version in use, applies in addition
to any WebTransport-session-level flow control.</t>
      <t>WebTransport streams can be aborted using a <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule and a
receiver can request that a sender stop sending with a <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref> capsule.</t>
      <t>A WebTransport session is terminated when the CONNECT stream that created it is
closed. This implicitly closes all WebTransport streams that were multiplexed
over that CONNECT stream.</t>
    </section>
    <section anchor="session-establishment-and-termination">
      <name>Session Establishment and Termination</name>
      <t>A WebTransport session is a communication context between a client and server
<xref target="OVERVIEW"/>. This section describes how sessions begin and end.</t>
      <section anchor="establishing-a-webtransport-capable-http2-connection">
        <name>Establishing a WebTransport-Capable HTTP/2 Connection</name>
        <t>In order to indicate potential support for WebTransport, the server MUST send
the SETTINGS_ENABLE_CONNECT_PROTOCOL setting with a value of "1" in its SETTINGS
frame.  The client MUST NOT send a WebTransport request until it has received
the setting indicating extended CONNECT support from the server.</t>
      </section>
      <section anchor="creating-a-new-session">
        <name>Creating a New Session</name>
        <t>As WebTransport sessions are established over HTTP, they are identified
using the <tt>https</tt> URI scheme (<xref section="4.2.2" sectionFormat="of" target="HTTP"/>).</t>
        <t>In order to create a new WebTransport session, a client can send an HTTP CONNECT
request. The <tt>:protocol</tt> pseudo-header field (<xref target="RFC8441"/>) MUST be set to
<tt>webtransport</tt> (<xref target="upgrade-token"/>). The <tt>:scheme</tt> field MUST be <tt>https</tt>. Both
the <tt>:authority</tt> and the <tt>:path</tt> value MUST be set; those fields indicate the
desired WebTransport server. In a Web context, the request MUST include an
<tt>Origin</tt> header field <xref target="ORIGIN"/> that includes the origin of the site that
requested the creation of the session.</t>
        <t>Upon receiving an extended CONNECT request with a <tt>:protocol</tt> field set to
<tt>webtransport</tt>, the HTTP server checks if the identified resource supports
WebTransport sessions. If the resource does not, the server SHOULD reply with
status code 406 (<xref section="15.5.7" sectionFormat="of" target="HTTP"/>). If it does, it MAY accept the
session by replying with a 2xx series status code, as defined in
<xref section="15.3" sectionFormat="of" target="HTTP"/>. The WebTransport server MUST verify the <tt>Origin</tt>
header to ensure that the specified origin is allowed to access the server
in question.</t>
        <t>A WebTransport session is established when the server sends a 2xx response. A
server generates that response from the request header, not from the contents of
the request. To enable clients to resend data when attempting to re-establish a
session that was rejected by a server, a server MUST NOT process any capsules on
the request stream unless it accepts the WebTransport session.</t>
        <t>A client MAY optimistically send any WebTransport capsules associated with a
CONNECT request, without waiting for a response, to the extent allowed by flow
control. This can reduce latency for data sent by a client at the start of a
WebTransport session. For example, a client might choose to send datagrams or
flow control updates before receiving any response from the server.</t>
      </section>
      <section anchor="application-protocol-negotiation">
        <name>Application Protocol Negotiation</name>
        <t>WebTransport over HTTP/2 offers a subprotocol negotiation mechanism, similar to
TLS Application-Layer Protocol Negotiation Extension (ALPN) <xref target="RFC7301"/>; the
intent is to simplify porting pre-existing protocols that rely on this type of
functionality.</t>
        <t>The user agent MAY include a <tt>WT-Available-Protocols</tt> header field in the
CONNECT request. The <tt>WT-Available-Protocols</tt> enumerates the possible protocols
in preference order. If the server receives such a header, it MAY include a
<tt>WT-Protocol</tt> field in a successful (2xx) response. If it does, the server MUST
include a single choice from the client's list in that field. Servers MAY reject
the request if the client did not include a suitable protocol.</t>
        <t>Both <tt>WT-Available-Protocols</tt> and <tt>WT-Protocol</tt> are defined in
<xref section="3.4" sectionFormat="of" target="WEBTRANSPORT-H3"/>.</t>
      </section>
      <section anchor="errors">
        <name>Session Termination and Error Handling</name>
        <t>A WebTransport session over HTTP/2 is terminated when either endpoint closes the
stream associated with the CONNECT request that initiated the session.</t>
        <t>Prior to closing the stream associated with the CONNECT request, either endpoint
can send a WT_CLOSE_SESSION capsule with an application error code and message
to convey additional information about the reasons for the closure of the
session.</t>
        <t>Session errors result in the termination of a session.  Errors can be reported
using the WT_CLOSE_SESSION capsule, which includes an error code and an optional
explanatory message.</t>
        <t>An endpoint can terminate a session without sending a WT_CLOSE_SESSION capsule
by closing the HTTP/2 stream.</t>
        <t>An HTTP/2 stream that is reset terminates the session without providing an
application-level signal, though there will be an HTTP/2 error code.</t>
        <t>This document reserves the following HTTP/2 error codes for use with reporting
WebTransport errors:</t>
        <dl>
          <dt>WEBTRANSPORT_ERROR (0xTBD):</dt>
          <dd>
            <t>This generic error can be used for errors that do not have more specific error
codes.</t>
          </dd>
          <dt>WEBTRANSPORT_STREAM_STATE_ERROR (0xTBD):</dt>
          <dd>
            <t>A stream-related capsule identified a stream that was in an invalid state.</t>
          </dd>
        </dl>
        <t>Prior to terminating a stream with an error, a WT_CLOSE_SESSION capsule with an
application-specified error code MAY be sent.</t>
        <t>Session errors do not necessarily result in any change of HTTP/2 connection
state, except that an endpoint might choose to terminate a connection in
response to stream errors; see <xref section="5.4" sectionFormat="of" target="HTTP2"/>.</t>
      </section>
    </section>
    <section anchor="flow-control">
      <name>Flow Control</name>
      <t>Flow control governs the amount of resources that can be consumed or data that
can be sent.  WebTransport over HTTP/2 allows a server to limit the number of
sessions that a client can create on a single connection; see
<xref target="flow-control-limit-sessions"/>.</t>
      <t>For data, there are five applicable levels of flow control for data that is sent
or received using WebTransport over HTTP/2:</t>
      <ol spacing="normal" type="1"><li>
          <t>TCP flow control.</t>
        </li>
        <li>
          <t>HTTP/2 connection flow control, which governs the total amount of data in
DATA frames for all HTTP/2 streams.</t>
        </li>
        <li>
          <t>HTTP/2 stream flow control, which limits the data on a single HTTP/2 stream.
For a WebTransport session, this includes all capsules, including those that are
exempt from WebTransport session-level flow control.</t>
        </li>
        <li>
          <t>WebTransport session-level flow control, which limits the total amount of
stream data that can be sent or received on streams within the WebTransport
session. Note that this does not limit other types of capsules within a
WebTransport session, such as control messages or datagrams.</t>
        </li>
        <li>
          <t>WebTransport stream flow control, which limits data on individual streams
within a session.</t>
        </li>
      </ol>
      <t>TCP and HTTP/2 define the first three levels of flow control. This document
defines the final two.</t>
      <section anchor="flow-control-limit-sessions">
        <name>Limiting the Number of Simultaneous Sessions</name>
        <t>HTTP/2 defines a SETTINGS_MAX_CONCURRENT_STREAMS parameter
<xref section="6.5.2" sectionFormat="of" target="HTTP2"/> that allows the server to limit the maximum number of
concurrent streams on a single HTTP/2 session, which also limits the number of
WebTransport sessions on that connection.  Servers that wish to limit the rate
of incoming WebTransport sessions on any particular HTTP/2 session have multiple
mechanisms:</t>
        <ul spacing="normal">
          <li>
            <t>The <tt>REFUSED_STREAM</tt> error code defined in <xref section="8.7" sectionFormat="of" target="HTTP2"/> indicates
to the receiving HTTP/2 stack that the request was not processed in any way.</t>
          </li>
          <li>
            <t>HTTP status code 429 indicates that the request was rejected due to rate
limiting <xref target="RFC6585"/>.  Unlike the previous method, this signal is directly
propagated to the application.</t>
          </li>
        </ul>
      </section>
      <section anchor="flow-control-limit-streams">
        <name>Limiting the Number of Streams Within a Session</name>
        <t>The <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsule (<xref section="5.6.1" sectionFormat="of" target="WEBTRANSPORT-H3"/>) allows each
endpoint to limit the number of streams its peer is permitted to open as part of
a WebTransport session.  There is a separate limit for bidirectional streams and
for unidirectional streams.  Note that, unlike WebTransport over HTTP/3
<xref target="WEBTRANSPORT-H3"/>, because the entire WebTransport session is contained within
HTTP/2 DATA frames on a single HTTP/2 stream, this limit is the only mechanism
for an endpoint to limit the number of WebTransport streams that its peer can
open on a session.</t>
      </section>
      <section anchor="flow-control-initial">
        <name>Initial Flow Control Limits</name>
        <t>To allow stream data to be exchanged in the same flight as the extended CONNECT
request that establishes a WebTransport session, initial flow control limits can
be exchanged via HTTP/2 SETTINGS (<xref target="flow-control-settings"/>).  Initial values
for the flow control limits can also be exchanged via the <tt>WebTransport-Init</tt>
header field on the extended CONNECT request (<xref target="flow-control-header"/>).</t>
        <t>The limits communicated via HTTP/2 SETTINGS apply to all WebTransport sessions
opened on that HTTP/2 connection.  Limits communicated via the
<tt>WebTransport-Init</tt> header field apply only to the WebTransport session
established by the extended CONNECT request carrying that field.</t>
        <t>If both the SETTINGS and the header field are present when a WebTransport
session is established, the endpoint MUST use the greater of the two values for
each corresponding initial flow control value.  Endpoints sending the SETTINGS
and also including the header field SHOULD ensure that the header field values
are greater than or equal to the values provided in the SETTINGS.</t>
        <section anchor="flow-control-settings">
          <name>Flow Control SETTINGS</name>
          <t>Initial flow control limits can be exchanged via HTTP/2 SETTINGS
(<xref target="h2-settings"/>) by providing non-zero values for</t>
          <ul spacing="normal">
            <li>
              <t><iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref> via <iref item="SETTINGS_WT_INITIAL_MAX_DATA"/><xref target="SETTINGS_WT_INITIAL_MAX_DATA" format="none">SETTINGS_WT_INITIAL_MAX_DATA</xref></t>
            </li>
            <li>
              <t><iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> via <iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI</xref>,
<iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL</xref>, and
<iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE</xref></t>
            </li>
            <li>
              <t><iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> via <iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_UNI</xref> and
<iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI</xref></t>
            </li>
          </ul>
          <t>WebTransport SETTINGS can be updated during the lifetime of the HTTP/2
connection.  Updated values take effect for new sessions once they have been
acknowledged by the peer, as described in <xref section="6.5.3" sectionFormat="of" target="HTTP2"/>.  The
initial flow control limits for a new session are determined by the most
recently acknowledged SETTINGS values at the time the session is created.
Sessions that are already established are not affected by changes to these
SETTINGS, and their limits can only be updated using the corresponding flow
control capsules.</t>
        </section>
        <section anchor="flow-control-header">
          <name>Flow Control Header Field</name>
          <t>The <tt>WebTransport-Init</tt> HTTP header field can be used to communicate the initial
values of the flow control windows, similar to how QUIC uses transport
parameters.  The <tt>WebTransport-Init</tt> is a Dictionary Structured Field
(<xref section="3.2" sectionFormat="of" target="RFC8941"/>).  If the <tt>WebTransport-Init</tt> field cannot be
parsed correctly or does not have the correct type, the endpoint MUST reject the
CONNECT request with a 4xx status code.  The following keys are defined for the
<tt>WebTransport-Init</tt> header field:</t>
          <dl>
            <dt><tt>u</tt>:</dt>
            <dd>
              <t>The initial flow control limit for unidirectional streams opened by the
recipient of this header field.  MUST be an Integer.</t>
            </dd>
            <dt><tt>bl</tt>:</dt>
            <dd>
              <t>The initial flow control limit for the bidirectional streams opened by the
sender of this header field.  MUST be an Integer.</t>
            </dd>
            <dt><tt>br</tt>:</dt>
            <dd>
              <t>The initial flow control limit for the bidirectional streams opened by the
recipient of this header field.  MUST be an Integer.</t>
            </dd>
          </dl>
          <t>If any of these keys are present but contain invalid values, the endpoint MUST
reject the CONNECT request with a 4xx status code.  Unknown keys and parameters
in the dictionary MUST be ignored.</t>
        </section>
      </section>
      <section anchor="flow-control-intermediaries">
        <name>Flow Control and Intermediaries</name>
        <t>WebTransport over HTTP/2 uses several capsules for flow control, and all of
these capsules define special intermediary handling as described in
<xref section="3.2" sectionFormat="of" target="HTTP-DATAGRAM"/>.  These capsules, referred to as the "flow
control capsules" are <iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref>, <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref>, <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref>,
<iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref>, <iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref>, and <iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref>.</t>
        <t>An endpoint MUST NOT wait for a <iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref>, <iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref>, or
<iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsule before sending a <iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref>, <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref>,
or <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsule; doing so could result in the sender being blocked
for at least an entire round trip.  Endpoints SHOULD send flow control credit
as they consume data or close streams (similar to the mechanism used in QUIC,
see <xref section="4.2" sectionFormat="of" target="RFC9000"/>).</t>
        <t>Because flow control in WebTransport is hop-by-hop and does not provide an
end-to-end signal, intermediaries MUST consume flow control signals and express
their own flow control limits to the next hop. The intermediary can send these
signals via HTTP/3 flow control messages, HTTP/2 flow control messages, or as
WebTransport flow control capsules, where appropriate. Intermediaries are
responsible for storing any data for which they advertise flow control credit if
that data cannot be immediately forwarded to the next hop.</t>
        <t>In practice, an intermediary that translates flow control signals between
similar WebTransport protocols, such as between two HTTP/2 connections, can
often simply reexpress the same limits received on one connection directly on
the other connection.</t>
        <t>An intermediary that does not want to be responsible for storing data that
cannot be immediately sent on its translated connection would ensure that it
does not advertise a higher flow control limit on one connection than the
corresponding limit on the translated connection.</t>
      </section>
    </section>
    <section anchor="features">
      <name>WebTransport Features</name>
      <t>WebTransport over TCP-based HTTP semantics provides the following features
described in <xref target="OVERVIEW"/>: unidirectional streams, bidirectional streams, and
datagrams, initiated by either endpoint.</t>
      <t>WebTransport streams and datagrams that belong to different WebTransport
sessions are identified by the CONNECT stream on which they are transmitted,
with one WebTransport session consuming one CONNECT stream.</t>
      <section anchor="transport-properties">
        <name>Transport Properties</name>
        <t>The WebTransport framework <xref target="OVERVIEW"/> defines a set of optional transport
properties that clients can use to determine the presence of features which
might allow additional optimizations beyond the common set of properties
available via all WebTransport protocols.</t>
        <t>Because WebTransport over TCP-based HTTP semantics relies on the underlying
protocols to provide in order and reliable delivery, there are some notable
differences from the way in which QUIC handles application data. For example,
endpoints send stream data in order. As there is no ordering mechanism available
for the receiver to reassemble incoming data, receivers assume that all data
arriving in <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules is contiguous and in order.</t>
        <t>Below are details about support in WebTransport over HTTP/2 for the properties
defined by the WebTransport framework.</t>
        <dl>
          <dt>Unreliable Delivery:</dt>
          <dd>
            <t>WebTransport over HTTP/2 does not support unreliable delivery, as HTTP/2
retransmits any lost data. This means that any datagrams sent via WebTransport
over HTTP/2 will be retransmitted regardless of the preference of the
application. The receiver is permitted to drop them, however, if it is unable
to buffer them.</t>
          </dd>
          <dt>Pooling:</dt>
          <dd>
            <t>WebTransport over HTTP/2 provides support for pooling.  Every WebTransport
session is an independent HTTP/2 stream and does not compete with other pooled
WebTransport sessions for per-stream resources.</t>
          </dd>
          <dt>Stream Independence:</dt>
          <dd>
            <t>WebTransport over HTTP/2 does not support stream independence, as HTTP/2
inherently has head-of-line blocking.</t>
          </dd>
          <dt>Connection Mobility:</dt>
          <dd>
            <t>WebTransport over HTTP/2 does not support connection mobility, unless an
underlying transport protocol that supports multipath or migration, such as
MPTCP <xref target="MPTCP"/>, is used underneath HTTP/2 and TLS. Without such
support, WebTransport over HTTP/2 connections cannot survive network
transitions.</t>
          </dd>
        </dl>
      </section>
      <section anchor="webtransport-streams">
        <name>WebTransport Streams</name>
        <t>WebTransport streams have identifiers and states that mirror the identifiers
((<xref section="2.1" sectionFormat="of" target="RFC9000"/>)) and states (<xref section="3" sectionFormat="of" target="RFC9000"/>) of QUIC
streams as closely as possible to aid in ease of implementation.</t>
        <t>WebTransport streams are identified by a numeric value, or stream ID. Stream IDs
are only meaningful within the WebTransport session in which they were created.
They share the same semantics as QUIC stream IDs, with client initiated streams
having even-numbered stream IDs and server-initiated streams having odd-numbered
stream IDs. Similarly, they can be bidirectional or unidirectional, indicated by
the second least significant bit of the stream ID.</t>
        <t>Because WebTransport does not provide an acknowledgement mechanism for
WebTransport capsules, it relies on the underlying transport's in order delivery
to inform stream state transitions. Wherever QUIC relies on receiving an ack for
a packet to transition between stream states, WebTransport performs that
transition immediately.</t>
      </section>
      <section anchor="use-of-keying-material-exporters">
        <name>Use of Keying Material Exporters</name>
        <t>WebTransport over HTTP/2 supports the use of TLS keying material exporters
<xref section="7.5" sectionFormat="of" target="TLS"/>. Since the underlying HTTP/2 connection could be
shared by multiple WebTransport sessions, WebTransport defines a mechanism for
deriving a TLS exporter that separates keying material for different sessions.
If the application requests an exporter for a given WebTransport session with a
specified label and context, the resulting exporter SHALL be a TLS exporter as
defined in <xref section="7.5" sectionFormat="of" target="TLS"/> with the label set to "EXPORTER-WebTransport"
and the context set to the serialization of the "WebTransport Exporter Context"
struct as defined below.</t>
        <figure anchor="fig-wt-exporter-context">
          <name>WebTransport Exporter Context struct</name>
          <artwork><![CDATA[
WebTransport Exporter Context {
  WebTransport Session ID (64),
  WebTransport Application-Supplied Exporter Label Length (8),
  WebTransport Application-Supplied Exporter Label (8..),
  WebTransport Application-Supplied Exporter Context Length (8),
  WebTransport Application-Supplied Exporter Context (..)
}
]]></artwork>
        </figure>
        <t>A TLS exporter API might permit the context field to be omitted.  In this case,
as with TLS 1.3, the WebTransport Application-Supplied Exporter Context becomes
zero-length if omitted.</t>
      </section>
    </section>
    <section anchor="webtransport-capsules">
      <name>WebTransport Capsules</name>
      <t>WebTransport capsules mirror their QUIC frame counterparts as closely as
possible to enable maximal reuse of any applicable QUIC infrastructure by
implementors.</t>
      <t>WebTransport capsules use the Capsule Protocol defined in
<xref section="3.2" sectionFormat="of" target="HTTP-DATAGRAM"/>.</t>
      <section anchor="PADDING">
        <name>PADDING Capsule</name>
        <t>A <iref item="PADDING"/><xref target="PADDING" format="none">PADDING</xref> capsule is an HTTP capsule <xref target="HTTP-DATAGRAM"/> of type=0x190B4D38 and
has no semantic value. <iref item="PADDING"/><xref target="PADDING" format="none">PADDING</xref> capsules can be used to introduce additional data
between other HTTP datagrams and can also be used to provide protection against
traffic analysis or for other reasons.</t>
        <t>Note that, when used with WebTransport over HTTP/2, the <iref item="PADDING"/><xref target="PADDING" format="none">PADDING</xref> capsule exists
alongside the ability to pad HTTP/2 frames (<xref section="10.7" sectionFormat="of" target="RFC9113"/>).
HTTP/2 padding is hop-by-hop and can be modified by intermediaries, while the
<iref item="PADDING"/><xref target="PADDING" format="none">PADDING</xref> capsule traverses intermediaries.  The <iref item="PADDING"/><xref target="PADDING" format="none">PADDING</xref> capsule cannot be smaller
than its own header, which means that the minimum size of the capsule is two
bytes: one byte for the Type and one byte to encode "0" for the Length.</t>
        <figure anchor="fig-padding">
          <name>PADDING Capsule Format</name>
          <artwork><![CDATA[
PADDING Capsule {
  Type (i) = 0x190B4D38,
  Length (i),
  Padding (..),
}
]]></artwork>
        </figure>
        <t>The Padding field MUST be set to an all-zero sequence of bytes of any length as
specified by the Length field.  A receiver is not obligated to verify padding
but MAY treat non-zero padding as a <xref target="errors">stream error</xref>.</t>
      </section>
      <section anchor="WT_RESET_STREAM">
        <name>WT_RESET_STREAM Capsule</name>
        <t>A <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule is an HTTP capsule <xref target="HTTP-DATAGRAM"/> of
type=0x190B4D39 and allows either endpoint to abruptly terminate the sending
part of a WebTransport stream.</t>
        <t>After sending a <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule, an endpoint ceases transmission of
<iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules on the identified stream. A receiver of a <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref>
capsule can discard any data in excess of the Reliable Size indicated, even if
that data was already received.</t>
        <t>The <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule follows the design of the QUIC RESET_STREAM_AT frame
<xref target="PARTIAL-RESET"/>.  Consequently, it includes a Reliable Size field.  A
<iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule MUST be sent after <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules that include an
amount of data equal to or in excess of the value in the Reliable Size field.  A
receiver MUST treat the receipt of a <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> with a Reliable Size
smaller than the number of bytes it has
received on the stream as a session error.</t>
        <figure anchor="fig-wt_reset_stream">
          <name>WT_RESET_STREAM Capsule Format</name>
          <artwork><![CDATA[
WT_RESET_STREAM Capsule {
  Type (i) = 0x190B4D39,
  Length (i),
  Stream ID (i),
  Application Protocol Error Code (i),
  Reliable Size (i),
}
]]></artwork>
        </figure>
        <t>The <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule defines the following fields:</t>
        <dl>
          <dt>Stream ID:</dt>
          <dd>
            <t>A variable-length integer encoding of the WebTransport stream ID of the
stream being terminated.</t>
          </dd>
          <dt>Application Protocol Error Code:</dt>
          <dd>
            <t>A variable-length integer containing the application protocol error code
that indicates why the stream is being closed.  WebTransport application
error codes are constrained to an unsigned 32-bit range defined in
<xref section="4.4" sectionFormat="of" target="WEBTRANSPORT-H3"/>.  This value MUST NOT exceed 0xffffffff,
values larger than this MUST be treated as a session error of type
WEBTRANSPORT_ERROR.</t>
          </dd>
          <dt>Reliable Size:</dt>
          <dd>
            <t>A variable-length integer indicating the amount of data that needs to be
delivered to the application even though the stream is reset.</t>
          </dd>
        </dl>
        <t>Unlike the equivalent QUIC frame, this capsule does not include a Final Size
field. In-order delivery of <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules ensures that the amount of
session-level flow control consumed by a stream is always known by both
endpoints.</t>
        <t>A <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule MUST NOT be sent after a stream is closed or reset.
While QUIC permits redundant RESET_STREAM frames, the ordering guarantee in
HTTP/2 makes this unnecessary.  A <xref target="errors">stream error</xref> of type
WEBTRANSPORT_STREAM_STATE_ERROR MUST be sent if a <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule is
received for a stream that is not in a valid state.</t>
      </section>
      <section anchor="WT_STOP_SENDING">
        <name>WT_STOP_SENDING Capsule</name>
        <t>An HTTP capsule <xref target="HTTP-DATAGRAM"/> called <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref> (type=0x190B4D3A) is
introduced to communicate that incoming data is being discarded on receipt per
application request. <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref> requests that a peer cease transmission on
a WebTransport stream.</t>
        <figure anchor="fig-wt_stop_sending">
          <name>WT_STOP_SENDING Capsule Format</name>
          <artwork><![CDATA[
WT_STOP_SENDING Capsule {
  Type (i) = 0x190B4D3A,
  Length (i),
  Stream ID (i),
  Application Protocol Error Code (i),
}
]]></artwork>
        </figure>
        <t>The <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref> capsule defines the following fields:</t>
        <dl>
          <dt>Stream ID:</dt>
          <dd>
            <t>A variable-length integer carrying the WebTransport stream ID of the stream
being ignored.</t>
          </dd>
          <dt>Application Protocol Error Code:</dt>
          <dd>
            <t>A variable-length integer containing the application-specified reason the
sender is ignoring the stream.  WebTransport application error codes are
constrained to an unsigned 32-bit range defined in
<xref section="4.4" sectionFormat="of" target="WEBTRANSPORT-H3"/>.  This value MUST NOT exceed 0xffffffff,
values larger than this MUST be treated as a session error of type
WEBTRANSPORT_ERROR.</t>
          </dd>
        </dl>
        <t>As defined in <xref section="3.5" sectionFormat="of" target="RFC9000"/>, the recipient of a <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref>
capsule sends a <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule in response, including the same error
code, if the stream is the "Ready" or "Send" state.</t>
        <t>A <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref> capsule MUST NOT be sent multiple times for the same stream.
While QUIC permits redundant STOP_SENDING frames, the ordering guarantee in
HTTP/2 makes this unnecessary.  A <xref target="errors">stream error</xref> of type
WEBTRANSPORT_STREAM_STATE_ERROR MUST be sent if a second <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref> capsule
is received.</t>
      </section>
      <section anchor="WT_STREAM">
        <name>WT_STREAM Capsule</name>
        <t><iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules implicitly create a WebTransport stream and carry stream
data.</t>
        <t>The Type field in the <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule is either 0x190B4D3B or 0x190B4D3C.  The
least significant bit in the capsule type is the FIN bit (0x01), indicating when
set that the capsule marks the end of the stream in one direction.  Stream data
consists of any number of 0x190B4D3B capsules followed by a terminal 0x190B4D3C
capsule.</t>
        <figure anchor="fig-wt_stream">
          <name>WT_STREAM Capsule Format</name>
          <artwork><![CDATA[
WT_STREAM Capsule {
  Type (i) = 0x190B4D3B..0x190B4D3C,
  Length (i),
  Stream ID (i),
  Stream Data (..),
}
]]></artwork>
        </figure>
        <t><iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules contain the following fields:</t>
        <dl>
          <dt>Stream ID:</dt>
          <dd>
            <t>The stream ID for the stream.  The second least significant bit of the Stream ID indicates whether
the stream is bidirectional or unidirectional, as described in <xref target="webtransport-streams"/>.</t>
          </dd>
          <dt>Stream Data:</dt>
          <dd>
            <t>Zero or more bytes of data for the stream.  Empty <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules MUST NOT
be used unless they open or close a stream; an endpoint MAY treat an empty
<iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule that neither starts nor ends a stream as a session error.</t>
          </dd>
        </dl>
        <t>A <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule MUST NOT be sent after a stream is closed or reset.  While
QUIC permits redundant STREAM frames, the ordering guarantee in HTTP/2 makes
this unnecessary.  A <xref target="errors">stream error</xref> of type
WEBTRANSPORT_STREAM_STATE_ERROR MUST be sent if a <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule is received
for a stream that is not in a valid state.</t>
      </section>
      <section anchor="WT_MAX_DATA">
        <name>WT_MAX_DATA Capsule</name>
        <t>An HTTP capsule <xref target="HTTP-DATAGRAM"/> called <iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref> (type=0x190B4D3D)
(<xref section="5.4.3" sectionFormat="of" target="WEBTRANSPORT-H3"/>) is used to inform the peer of the maximum
amount of data that can be sent on the WebTransport session as a whole.</t>
        <figure anchor="fig-wt_max_data">
          <name>WT_MAX_DATA Capsule Format</name>
          <artwork><![CDATA[
WT_MAX_DATA Capsule {
  Type (i) = 0x190B4D3D,
  Length (i),
  Maximum Data (i),
}
]]></artwork>
        </figure>
        <t><iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref> capsules contain the following field:</t>
        <dl>
          <dt>Maximum Data:</dt>
          <dd>
            <t>A variable-length integer indicating the maximum amount of data that can be
sent on the entire connection, in units of bytes.</t>
          </dd>
        </dl>
        <t>All data sent in <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules counts toward this limit.  The sum of the
lengths of Stream Data fields in <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules MUST NOT exceed the value
advertised by a receiver.  If an endpoint receives an incoming <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule
with Stream Data in excess of this limit, it MUST close the WebTransport session
with a WEBTRANSPORT_FLOW_CONTROL_ERROR session error.</t>
        <t>If an endpoint receives a <iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref> capsule with a Maximum Data value less
than a previously received value, it MUST close the WebTransport session with a
WEBTRANSPORT_FLOW_CONTROL_ERROR session error.</t>
        <t>The <iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref> capsule defines special intermediary handling, as described in
<xref section="3.2" sectionFormat="of" target="HTTP-DATAGRAM"/>.  Intermediaries MUST consume <iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref>
capsules for flow control purposes and MUST generate and send appropriate flow
control signals for their limits; see <xref target="flow-control-intermediaries"/>.</t>
        <t>The initial value for this limit MAY be communicated by sending a non-zero value
for <iref item="SETTINGS_WT_INITIAL_MAX_DATA"/><xref target="SETTINGS_WT_INITIAL_MAX_DATA" format="none">SETTINGS_WT_INITIAL_MAX_DATA</xref>.</t>
      </section>
      <section anchor="WT_MAX_STREAM_DATA">
        <name>WT_MAX_STREAM_DATA Capsule</name>
        <t>An HTTP capsule <xref target="HTTP-DATAGRAM"/> called <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> (type=0x190B4D3E) is
introduced to inform a peer of the maximum amount of data that can be sent on a
WebTransport stream.</t>
        <figure anchor="fig-wt_max_stream_data">
          <name>WT_MAX_STREAM_DATA Capsule Format</name>
          <artwork><![CDATA[
WT_MAX_STREAM_DATA Capsule {
  Type (i) = 0x190B4D3E,
  Length (i),
  Stream ID (i),
  Maximum Stream Data (i),
}
]]></artwork>
        </figure>
        <t><iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsules contain the following fields:</t>
        <dl>
          <dt>Stream ID:</dt>
          <dd>
            <t>The stream ID of the affected WebTransport stream, encoded as a
variable-length integer.</t>
          </dd>
          <dt>Maximum Stream Data:</dt>
          <dd>
            <t>A variable-length integer indicating the maximum amount of data that can be
sent on the identified stream, in units of bytes.</t>
          </dd>
        </dl>
        <t>All data sent in <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules for the identified stream counts toward this
limit.  The sum of the lengths of Stream Data fields in <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsules on
the identified stream MUST NOT exceed the value advertised by a receiver.  If an
endpoint receives an incoming <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule with Stream Data in excess of
this limit, it MUST close the WebTransport session with a
WEBTRANSPORT_FLOW_CONTROL_ERROR session error.</t>
        <t>If an endpoint receives a <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsule with a Maximum Stream Data
value less than a previously received value, it MUST close the WebTransport
session with a WEBTRANSPORT_FLOW_CONTROL_ERROR session error.</t>
        <t>The <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsule defines special intermediary handling, as
described in <xref section="3.2" sectionFormat="of" target="HTTP-DATAGRAM"/>.  Intermediaries MUST consume
<iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsules for flow control purposes and MUST generate and send
appropriate flow control signals for their limits; see
<xref target="flow-control-intermediaries"/>.</t>
        <t>Initial values for this limit for unidirectional and bidirectional streams MAY
be communicated by sending non-zero values for
<iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI</xref>,
<iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL</xref>, and
<iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE</xref> respectively.</t>
        <t>A <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsule MUST NOT be sent after a sender requests that a
stream be closed with <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref>.  While QUIC permits redundant
MAX_STREAM_DATA frames, the ordering guarantee in HTTP/2 makes this unnecessary.
A <xref target="errors">stream error</xref> of type WEBTRANSPORT_STREAM_STATE_ERROR MUST be sent
if a <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsule is received after a <iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref> capsule for
the same stream.</t>
      </section>
      <section anchor="WT_MAX_STREAMS">
        <name>WT_MAX_STREAMS Capsule</name>
        <t>An HTTP capsule <xref target="HTTP-DATAGRAM"/> called <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> is defined by
<xref section="5.6.1" sectionFormat="of" target="WEBTRANSPORT-H3"/> to inform the peer of the cumulative number of
streams of a given type it is permitted to open.  A <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsule with
a type of 0x190B4D3F applies to bidirectional streams, and a <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref>
capsule with a type of 0x190B4D40 applies to unidirectional streams.</t>
        <t>Note that, because Maximum Streams is a cumulative value representing the total
allowed number of streams, including previously closed streams, endpoints
repeatedly send new <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsules with increasing Maximum Streams
values as streams are opened.</t>
        <figure anchor="fig-wt_max_streams">
          <name>WT_MAX_STREAMS Capsule Format</name>
          <artwork><![CDATA[
WT_MAX_STREAMS Capsule {
  Type (i) = 0x190B4D3F..0x190B4D40,
  Length (i),
  Maximum Streams (i),
}
]]></artwork>
        </figure>
        <t><iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsules contain the following field:</t>
        <dl>
          <dt>Maximum Streams:</dt>
          <dd>
            <t>A count of the cumulative number of streams of the corresponding type that
can be opened over the lifetime of the connection. This value cannot
exceed 2<sup>60</sup>, as it is not possible to encode stream IDs larger
than 2<sup>62</sup>-1.</t>
          </dd>
        </dl>
        <t>An endpoint MUST NOT open more streams than permitted by the current stream
limit set by its peer.  For instance, a server that receives a unidirectional
stream limit of 3 is permitted to open streams 3, 7, and 11, but not stream 15.</t>
        <t>Note that this limit includes streams that have been closed as well as those
that are open.</t>
        <t>If an endpoint receives an incoming stream that would exceed the advertised
Maximum Streams value, it MUST close the WebTransport session with a
WEBTRANSPORT_FLOW_CONTROL_ERROR session error.</t>
        <t>Note that, like QUIC stream IDs, WebTransport stream IDs cannot be skipped.
Opening a stream with a given ID implicitly opens all streams of the same type
and direction with lower stream IDs.  Even though WebTransport over HTTP/2 uses
an ordered transport, an application can create a stream without immediately
sending data on it. A higher-numbered stream might have data written to it
first, causing it to appear at the peer before any data is sent on
lower-numbered streams.  For example, if the client's bidirectional stream limit
is 3 and the server opens stream ID 15 (the fourth server-initiated
bidirectional stream), this implicitly counts stream IDs 3, 7, 11, and 15
against the limit, which would violate the limit of 3.  An endpoint that
receives such a stream would close the WebTransport session with a
WEBTRANSPORT_FLOW_CONTROL_ERROR error.</t>
        <t>If an endpoint receives a <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsule with a Maximum Streams value
less than a previously received value, it MUST close the WebTransport session
with a WEBTRANSPORT_FLOW_CONTROL_ERROR session error.</t>
        <t>The <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsule defines special intermediary handling, as described
in <xref section="3.2" sectionFormat="of" target="HTTP-DATAGRAM"/>.  Intermediaries MUST consume <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref>
capsules for flow control purposes and MUST generate and send appropriate flow
control signals for their limits.</t>
        <t>Initial values for these limits MAY be communicated by sending non-zero values
for <iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_UNI</xref> and
<iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI</xref>.</t>
      </section>
      <section anchor="WT_DATA_BLOCKED">
        <name>WT_DATA_BLOCKED Capsule</name>
        <t>A sender SHOULD send a <iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref> capsule (type=0x190B4D41)
(<xref section="5.6.4" sectionFormat="of" target="WEBTRANSPORT-H3"/>) when it wishes to send data but is unable
to do so due to WebTransport session-level flow control.  A sender is not
required to send <iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref> capsules, however <iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref> capsules can
be used as input to tuning of flow control algorithms and for debugging
purposes.</t>
        <figure anchor="fig-wt_data_blocked">
          <name>WT_DATA_BLOCKED Capsule Format</name>
          <artwork><![CDATA[
WT_DATA_BLOCKED Capsule {
  Type (i) = 0x190B4D41,
  Length (i),
  Maximum Data (i),
}
]]></artwork>
        </figure>
        <t><iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref> capsules contain the following field:</t>
        <dl>
          <dt>Maximum Data:</dt>
          <dd>
            <t>A variable-length integer indicating the session-level limit at which
blocking occurred.</t>
          </dd>
        </dl>
        <t>The <iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref> capsule defines special intermediary handling, as described
in <xref section="3.2" sectionFormat="of" target="HTTP-DATAGRAM"/>.  Intermediaries MUST consume
<iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref> capsules for flow control purposes and MUST generate and send
appropriate flow control signals for their limits; see
<xref target="flow-control-intermediaries"/>.</t>
      </section>
      <section anchor="WT_STREAM_DATA_BLOCKED">
        <name>WT_STREAM_DATA_BLOCKED Capsule</name>
        <t>A sender SHOULD send a <iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref> capsule (type=0x190B4D42) when it
wishes to send data but is unable to do so due to stream-level flow control.  A
sender is not required to send <iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref> capsules, however
<iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref> capsules can be used as input to tuning of flow control
algorithms and for debugging purposes.</t>
        <t>This capsule is analogous to <iref item="WT_DATA_BLOCKED"/><xref target="WT_DATA_BLOCKED" format="none">WT_DATA_BLOCKED</xref> (<xref target="WT_DATA_BLOCKED"/>), but for
stream-level data limits instead of session-level data limits.</t>
        <figure anchor="fig-wt_stream_data_blocked">
          <name>WT_STREAM_DATA_BLOCKED Capsule Format</name>
          <artwork><![CDATA[
WT_STREAM_DATA_BLOCKED Capsule {
  Type (i) = 0x190B4D42,
  Length (i),
  Stream ID (i),
  Maximum Stream Data (i),
}
]]></artwork>
        </figure>
        <t><iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref> capsules contain the following fields:</t>
        <dl>
          <dt>Stream ID:</dt>
          <dd>
            <t>A variable-length integer indicating the WebTransport stream that is
blocked due to flow control.</t>
          </dd>
          <dt>Maximum Stream Data:</dt>
          <dd>
            <t>A variable-length integer indicating the offset of the stream at which the
blocking occurred.</t>
          </dd>
        </dl>
        <t>The <iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref> capsule defines special intermediary handling, as
described in <xref section="3.2" sectionFormat="of" target="HTTP-DATAGRAM"/>.  Intermediaries MUST consume
<iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref> capsules for flow control purposes and MUST generate and
send appropriate flow control signals for their limits; see
<xref target="flow-control-intermediaries"/>.</t>
        <t>A <iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref> capsule MUST NOT be sent after a stream is closed or
reset.  While QUIC permits redundant STREAM_DATA_BLOCKED frames, the ordering
guarantee in HTTP/2 makes this unnecessary.  A <xref target="errors">stream error</xref> of type
WEBTRANSPORT_STREAM_STATE_ERROR MUST be sent if a <iref item="WT_STREAM_DATA_BLOCKED"/><xref target="WT_STREAM_DATA_BLOCKED" format="none">WT_STREAM_DATA_BLOCKED</xref> capsule
is received for a stream that is not in a valid state.</t>
      </section>
      <section anchor="WT_STREAMS_BLOCKED">
        <name>WT_STREAMS_BLOCKED Capsule</name>
        <t>A sender SHOULD send a <iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsule (type=0x190B4D43 or
0x190B4D44) (<xref section="5.4.2" sectionFormat="of" target="WEBTRANSPORT-H3"/>) when it wishes to open a
stream but is unable to do so due to the maximum stream limit set by its peer.
A <iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsule of type 0x190B4D43 is used to indicate reaching the
bidirectional stream limit, and a <iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsule of type 0x190B4D44
is used to indicate reaching the unidirectional stream limit.</t>
        <t>A <iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsule does not open the stream, but informs the peer that
a new stream was needed and the stream limit prevented the creation of the
stream.  A sender is not required to send <iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsules, however
<iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsules can be used as input to tuning of flow control
algorithms and for debugging purposes.</t>
        <figure anchor="fig-wt_streams_blocked">
          <name>WT_STREAMS_BLOCKED Capsule Format</name>
          <artwork><![CDATA[
WT_STREAMS_BLOCKED Capsule {
  Type (i) = 0x190B4D43..0x190B4D44,
  Length (i),
  Maximum Streams (i),
}
]]></artwork>
        </figure>
        <t><iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsules contain the following field:</t>
        <dl>
          <dt>Maximum Streams:</dt>
          <dd>
            <t>A variable-length integer indicating the maximum number of streams allowed
at the time the capsule was sent. This value cannot exceed 2<sup>60</sup>,
as it is not possible to encode stream IDs larger than 2<sup>62</sup>-1.</t>
          </dd>
        </dl>
        <t>The <iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsule defines special intermediary handling, as
described in <xref section="3.2" sectionFormat="of" target="HTTP-DATAGRAM"/>.  Intermediaries MUST consume
<iref item="WT_STREAMS_BLOCKED"/><xref target="WT_STREAMS_BLOCKED" format="none">WT_STREAMS_BLOCKED</xref> capsules for flow control purposes and MUST generate and send
appropriate flow control signals for their limits.</t>
      </section>
      <section anchor="DATAGRAM_CAPSULE">
        <name>DATAGRAM Capsule</name>
        <t>WebTransport over HTTP/2 uses the DATAGRAM capsule defined in
<xref section="3.5" sectionFormat="of" target="HTTP-DATAGRAM"/> to carry datagram traffic.</t>
        <figure anchor="fig-datagram">
          <name>DATAGRAM Capsule Format</name>
          <artwork><![CDATA[
DATAGRAM Capsule {
  Type (i) = 0x00,
  Length (i),
  HTTP Datagram Payload (..),
}
]]></artwork>
        </figure>
        <t>When used in WebTransport over HTTP/2, DATAGRAM capsules contain the following
fields:</t>
        <dl>
          <dt>HTTP Datagram Payload:</dt>
          <dd>
            <t>The content of the datagram to be delivered.</t>
          </dd>
        </dl>
        <t>The data in DATAGRAM capsules is not subject to flow control. The receiver MAY
discard this data if it does not have sufficient space to buffer it.</t>
        <t>An intermediary could forward the data in a DATAGRAM capsule over another
protocol, such as WebTransport over HTTP/3.  In QUIC, a datagram frame can span
at most one packet. Because of that, the applications have to know the maximum
size of the datagram they can send. However, when proxying the datagrams, the
hop-by-hop MTUs can vary.</t>
        <t><xref section="3.5" sectionFormat="of" target="HTTP-DATAGRAM"/> indicates that intermediaries that forward
DATAGRAM capsules where QUIC datagrams <xref target="DATAGRAM"/> are available forward the
contents of the capsule as native QUIC datagrams, rather than as HTTP datagrams
in a DATAGRAM capsule. Similarly, when forwarding DATAGRAM capsules used as part
of a WebTransport over HTTP/2 session on a WebTransport session that natively
supports QUIC datagrams, such as WebTransport over HTTP/3 <xref target="WEBTRANSPORT-H3"/>,
intermediaries follow the requirements in <xref target="WEBTRANSPORT-H3"/> to use native QUIC
datagrams.</t>
      </section>
      <section anchor="WT_CLOSE_SESSION_CAPSULE">
        <name>WT_CLOSE_SESSION Capsule</name>
        <t>WebTransport over HTTP/2 uses the WT_CLOSE_SESSION capsule defined in
<xref section="5" sectionFormat="of" target="WEBTRANSPORT-H3"/> to terminate a WebTransport session with an
application error code and message.</t>
        <t>WebTransport sessions can be terminated by optionally sending a WT_CLOSE_SESSION
capsule and then by closing the HTTP/2 stream associated with the session (see
<xref target="errors"/>).</t>
        <figure anchor="fig-wt_close_session">
          <name>WT_CLOSE_SESSION Capsule Format</name>
          <artwork><![CDATA[
WT_CLOSE_SESSION Capsule {
  Type (i) = WT_CLOSE_SESSION,
  Length (i),
  Application Error Code (32),
  Application Error Message (..8192),
}
]]></artwork>
        </figure>
        <t>When used in WebTransport over HTTP/2, WT_CLOSE_SESSION capsules contain the
following fields:</t>
        <dl>
          <dt>Application Error Code:</dt>
          <dd>
            <t>A 32-bit error code provided by the application closing the connection.</t>
          </dd>
          <dt>Application Error Message:</dt>
          <dd>
            <t>A UTF-8 encoded error message string provided by the application closing the
connection.  The message takes up the remainder of the capsule, and its
length MUST NOT exceed 1024 bytes.</t>
          </dd>
        </dl>
        <t>An endpoint that sends a WT_CLOSE_SESSION capsule MUST then half-close the
stream by sending an HTTP/2 frame with the END_STREAM flag set
(<xref section="5.1" sectionFormat="of" target="HTTP2"/>).  The recipient MUST close the stream upon receipt of
the capsule by replying with an HTTP/2 frame with the END_STREAM flag set; note
that it does not need to send a WT_CLOSE_SESSION capsule in response.</t>
        <t>Cleanly terminating a WebTransport session without a WT_CLOSE_SESSION capsule is
semantically equivalent to terminating it with a WT_CLOSE_SESSION capsule that
has an error code of 0 and an empty error string.</t>
      </section>
      <section anchor="WT_DRAIN_SESSION_CAPSULE">
        <name>WT_DRAIN_SESSION Capsule</name>
        <t>HTTP/2 uses GOAWAY frames (<xref section="6.8" sectionFormat="of" target="HTTP2"/>) to allow an endpoint to
gracefully stop accepting new streams while still finishing processing of
previously established streams.</t>
        <t>WebTransport over HTTP/2 uses the WT_DRAIN_SESSION capsule defined in
<xref section="4.6" sectionFormat="of" target="WEBTRANSPORT-H3"/> to gracefully shut down a WebTransport
session.</t>
        <figure anchor="fig-wt_drain_session">
          <name>WT_DRAIN_SESSION Capsule Format</name>
          <artwork><![CDATA[
WT_DRAIN_SESSION Capsule {
  Type (i) = WT_DRAIN_SESSION,
  Length (i) = 0
}
]]></artwork>
        </figure>
        <t>After sending or receiving either a WT_DRAIN_SESSION capsule or HTTP/2 GOAWAY
frame, an endpoint MAY continue using the session and MAY open new WebTransport
streams. The signal is intended for the application using WebTransport, which is
expected to attempt to gracefully terminate the session as soon as possible.</t>
      </section>
      <section anchor="capsule-ordering-and-reliability">
        <name>Capsule Ordering and Reliability</name>
        <t>The use of an ordered and reliable transport means that a receiver does not need
to tolerate capsules that arrive out of order. This differs from QUIC in that a
receiver is required to treat the arrival of out of order frames rather than
being tolerant.</t>
        <t>For an intermediary that forwards from an strongly-ordered transport (like
<xref target="WEBTRANSPORT-H3"/>) to a reliable transport (like this protocol), it is
necessary to maintain state for streams. A simple forwarding intermediary that
directly translates one type of protocol unit into another without understanding
the underlying state might cause a receiver to abort the session.</t>
        <t>For instance, after a RESET_STREAM frame is forwarded, an intermediary cannot
forward a RESET_STREAM frame as a <iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref> capsule or a STREAM frame as a
<iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule without error.</t>
      </section>
    </section>
    <section anchor="requirements-on-tls-usage">
      <name>Requirements on TLS Usage</name>
      <t>Because TLS keying material exporters are only secure for authentication when
they are uniquely bound to the TLS session <xref target="RFC7627"/>, WebTransport requires
either one of the following conditions:</t>
      <ul spacing="normal">
        <li>
          <t>The TLS version in use is greater than or equal to 1.3 <xref target="TLS"/>.</t>
        </li>
        <li>
          <t>The TLS version in use is 1.2, and the extended master secret extension
<xref target="RFC7627"/> has been negotiated.</t>
        </li>
      </ul>
      <t>Clients MUST NOT send WebTransport over HTTP/2 requests on connections that do
not meet one of the two conditions above. If a server receives a WebTransport
over HTTP/2 request on a connection that meets neither, the server MUST treat
the request as malformed, as specified in <xref section="8.1.1" sectionFormat="of" target="HTTP2"/>.</t>
    </section>
    <section anchor="examples">
      <name>Examples</name>
      <t>An example of negotiating a WebTransport Stream on an HTTP/2 connection follows.
This example is intended to closely follow the example in
<xref section="5.1" sectionFormat="of" target="RFC8441"/> to help illustrate the differences defined in this
document.</t>
      <artwork><![CDATA[
[[ From Client ]]                   [[ From Server ]]

SETTINGS

                                    SETTINGS
                                    SETTINGS_ENABLE_CONNECT_PROTOCOL = 1

HEADERS + END_HEADERS
Stream ID = 3
:method = CONNECT
:protocol = webtransport
:scheme = https
:path = /
:authority = server.example.com
origin: server.example.com

                                    HEADERS + END_HEADERS
                                    Stream ID = 3
                                    :status = 200

WT_STREAM
Stream ID = 0
WebTransport Data

                                    WT_STREAM + FIN
                                    Stream ID = 0
                                    WebTransport Data

WT_STREAM + FIN
Stream ID = 0
WebTransport Data
]]></artwork>
      <t>An example of the server initiating a WebTransport Stream follows. The only
difference here is the endpoint that sends the first <iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref> capsule.</t>
      <artwork><![CDATA[
[[ From Client ]]                   [[ From Server ]]

SETTINGS

                                    SETTINGS
                                    SETTINGS_ENABLE_CONNECT_PROTOCOL = 1

HEADERS + END_HEADERS
Stream ID = 3
:method = CONNECT
:protocol = webtransport
:scheme = https
:path = /
:authority = server.example.com
origin: server.example.com
                                    HEADERS + END_HEADERS
                                    Stream ID = 3
                                    :status = 200

                                    WT_STREAM
                                    Stream ID = 1
                                    WebTransport Data

WT_STREAM + FIN
Stream ID = 1
WebTransport Data

                                    WT_STREAM + FIN
                                    Stream ID = 1
                                    WebTransport Data
]]></artwork>
    </section>
    <section anchor="considerations-for-future-versions">
      <name>Considerations for Future Versions</name>
      <t>Future versions of WebTransport that change the syntax of the CONNECT requests
used to establish WebTransport sessions will need to modify the upgrade token
used to identify WebTransport, allowing servers to offer multiple versions
simultaneously (<xref section="9.1" sectionFormat="of" target="WEBTRANSPORT-H3"/>).</t>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>WebTransport over HTTP/2 satisfies all of the security requirements imposed by
<xref target="OVERVIEW"/> on WebTransport protocols, thus providing a secure framework for
client-server communication in cases when the client is potentially untrusted.</t>
      <t>WebTransport over HTTP/2 requires explicit opt-in through the use of HTTP
SETTINGS; this avoids potential protocol confusion attacks by ensuring the
HTTP/2 server explicitly supports it. It also requires the use of the Origin
header, providing the server with the ability to deny access to Web-based
clients that do not originate from a trusted origin.</t>
      <t>Just like HTTP traffic going over HTTP/2, WebTransport pools traffic to
different origins within a single connection. Different origins imply different
trust domains, meaning that the implementations have to treat each transport as
potentially hostile towards others on the same connection. One potential attack
is a resource exhaustion attack: since all of the transports share both
congestion control and flow control context, a single client aggressively using
up those resources can cause other transports to stall. The user agent thus
SHOULD implement a fairness scheme that ensures that each transport within
connection gets a reasonable share of controlled resources; this applies both to
sending data and to opening new streams.</t>
      <t>An application could attempt to exhaust resources by opening too many
WebTransport sessions at once.  In cases when the application is untrusted, a
WebTransport client SHOULD limit the number of outgoing sessions it will open.</t>
      <t>Note that the security considerations of HTTP/2 <xref target="HTTP2"/> apply to WebTransport
over HTTP/2.  In particular, the denial-of-service considerations in
<xref section="10.5" sectionFormat="of" target="HTTP2"/> are relevant.  WebTransport extends HTTP/2 with
additional features that have legitimate uses but can become a burden when they
are used unnecessarily or to excess.</t>
      <t>Once a WebTransport session is established on an HTTP/2 stream, there are new
interaction modes that permit either endpoint to send WebTransport streams and
datagrams to its peer.  This is particularly novel for clients, which previously
had limited exposure to unsolicited server-initiated traffic beyond server push
(see <xref section="8.4" sectionFormat="of" target="HTTP2"/>).  An endpoint that does not monitor use of these
features exposes itself to a risk of denial-of-service attack.  Implementations
track the use of WebTransport features, such as the number of incoming streams
and datagrams, and set limits on their use as described in <xref target="flow-control"/>.  An
endpoint MAY treat activity that is suspicious as a stream error or choose to
close the connection.</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document registers an upgrade token (<xref target="upgrade-token"/>), new HTTP/2
settings (<xref target="h2-settings"/>), HTTP/2 error codes (<xref target="iana-h2-error"/>), new capsules
(<xref target="iana-capsules"/>), and the <tt>WebTransport-Init</tt> header field (<xref target="iana-header"/>).</t>
      <section anchor="upgrade-token">
        <name>Upgrade Token Registration</name>
        <t>The following entry is added to the "Hypertext Transfer Protocol (HTTP) Upgrade
Token Registry" registry established by Section 16.7 of <xref target="HTTP"/>.</t>
        <t>The "webtransport" label identifies HTTP/2 used as a protocol for WebTransport:</t>
        <dl>
          <dt>Value:</dt>
          <dd>
            <t>webtransport</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>WebTransport over HTTP/2</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>This document</t>
          </dd>
        </dl>
      </section>
      <section anchor="h2-settings">
        <name>HTTP/2 SETTINGS Parameter Registration</name>
        <t>The following entries are added to the "HTTP/2 Settings" registry established by
<xref target="HTTP2"/>:</t>
        <t anchor="SETTINGS_WT_INITIAL_MAX_DATA">The <iref item="SETTINGS_WT_INITIAL_MAX_DATA"/><xref target="SETTINGS_WT_INITIAL_MAX_DATA" format="none">SETTINGS_WT_INITIAL_MAX_DATA</xref> parameter indicates the initial value for the
session data limit, otherwise communicated by the <iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref> capsule
(<xref target="WT_MAX_DATA"/>).  The default value for the <iref item="SETTINGS_WT_INITIAL_MAX_DATA"/><xref target="SETTINGS_WT_INITIAL_MAX_DATA" format="none">SETTINGS_WT_INITIAL_MAX_DATA</xref>
parameter is "0", indicating that the endpoint needs to send a <iref item="WT_MAX_DATA"/><xref target="WT_MAX_DATA" format="none">WT_MAX_DATA</xref>
capsule within each session before its peer is allowed to send any stream data
within that session.</t>
        <t>Note that this limit applies to all WebTransport sessions that use the HTTP/2
connection on which this SETTING is sent.</t>
        <dl>
          <dt>Setting Name:</dt>
          <dd>
            <t><iref item="SETTINGS_WT_INITIAL_MAX_DATA"/><xref target="SETTINGS_WT_INITIAL_MAX_DATA" format="none">SETTINGS_WT_INITIAL_MAX_DATA</xref></t>
          </dd>
          <dt>Code:</dt>
          <dd>
            <t>0x2b61</t>
          </dd>
          <dt>Initial Value:</dt>
          <dd>
            <t>0</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This document</t>
          </dd>
        </dl>
        <t anchor="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI">The <iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI</xref> parameter indicates the initial
value for the stream data limit for incoming unidirectional streams, otherwise
communicated by the <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsule (<xref target="WT_MAX_STREAM_DATA"/>).  The
default value for the <iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI</xref> parameter is "0",
indicating that the endpoint needs to send <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsules for each
stream within each individual WebTransport session before its peer is allowed to
send any stream data on those streams.</t>
        <t>Note that this limit applies to all WebTransport streams on all sessions that
use the HTTP/2 connection on which this SETTING is sent.</t>
        <dl>
          <dt>Setting Name:</dt>
          <dd>
            <t><iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_UNI</xref></t>
          </dd>
          <dt>Code:</dt>
          <dd>
            <t>0x2b62</t>
          </dd>
          <dt>Initial Value:</dt>
          <dd>
            <t>0</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This document</t>
          </dd>
        </dl>
        <t anchor="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL">The <iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL</xref> parameter indicates the
initial value for the stream data limit for incoming data on bidirectional
streams initiated by the sender of this setting, otherwise communicated by the
<iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsule (<xref target="WT_MAX_STREAM_DATA"/>).  The default value for the
<iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL</xref> parameter is "0", indicating
that the endpoint needs to send <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsules for each stream
within each individual WebTransport session before its peer is allowed to send
any stream data on those streams.</t>
        <t>Note that this limit applies to all WebTransport streams on all sessions that
use the HTTP/2 connection on which this SETTING is sent.</t>
        <dl>
          <dt>Setting Name:</dt>
          <dd>
            <t><iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_LOCAL</xref></t>
          </dd>
          <dt>Code:</dt>
          <dd>
            <t>0x2b63</t>
          </dd>
          <dt>Initial Value:</dt>
          <dd>
            <t>0</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This document</t>
          </dd>
        </dl>
        <t anchor="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE">The <iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE</xref> parameter indicates the
initial value for the stream data limit for incoming data on bidirectional
streams initiated by the receiver of this setting, otherwise communicated by
the <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsule (<xref target="WT_MAX_STREAM_DATA"/>).  The default value for
the <iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE</xref> parameter is "0",
indicating that the endpoint needs to send <iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref> capsules for each
stream within each individual WebTransport session before its peer is allowed
to send any stream data on those streams.</t>
        <t>Note that this limit applies to all WebTransport streams on all sessions that
use the HTTP/2 connection on which this SETTING is sent.</t>
        <dl>
          <dt>Setting Name:</dt>
          <dd>
            <t><iref item="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE" format="none">SETTINGS_WT_INITIAL_MAX_STREAM_DATA_BIDI_REMOTE</xref></t>
          </dd>
          <dt>Code:</dt>
          <dd>
            <t>0x2b66</t>
          </dd>
          <dt>Initial Value:</dt>
          <dd>
            <t>0</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This document</t>
          </dd>
        </dl>
        <t anchor="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI">The <iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_UNI</xref> parameter indicates the initial value
for the unidirectional max stream limit, otherwise communicated by the
<iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsule (<xref target="WT_MAX_STREAMS"/>).  The default value for the
<iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_UNI</xref> parameter is "0", indicating that the
endpoint needs to send <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsules on each individual WebTransport
session before its peer is allowed to create any unidirectional streams within
that session.</t>
        <t>Note that this limit applies to all WebTransport sessions that use the HTTP/2
connection on which this SETTING is sent.</t>
        <dl>
          <dt>Setting Name:</dt>
          <dd>
            <t><iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_UNI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_UNI</xref></t>
          </dd>
          <dt>Code:</dt>
          <dd>
            <t>0x2b64</t>
          </dd>
          <dt>Initial Value:</dt>
          <dd>
            <t>0</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This document</t>
          </dd>
        </dl>
        <t anchor="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI">The <iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI</xref> parameter indicates the initial value
for the bidirectional max stream limit, otherwise communicated by the
<iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsule (<xref target="WT_MAX_STREAMS"/>).  The default value for the
<iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI</xref> parameter is "0", indicating that the
endpoint needs to send <iref item="WT_MAX_STREAMS"/><xref target="WT_MAX_STREAMS" format="none">WT_MAX_STREAMS</xref> capsules on each individual WebTransport
session before its peer is allowed to create any bidirectional streams within
that session.</t>
        <t>Note that this limit applies to all WebTransport sessions that use the HTTP/2
connection on which this SETTING is sent.</t>
        <dl>
          <dt>Setting Name:</dt>
          <dd>
            <t><iref item="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI"/><xref target="SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI" format="none">SETTINGS_WT_INITIAL_MAX_STREAMS_BIDI</xref></t>
          </dd>
          <dt>Code:</dt>
          <dd>
            <t>0x2b65</t>
          </dd>
          <dt>Initial Value:</dt>
          <dd>
            <t>0</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>This document</t>
          </dd>
        </dl>
      </section>
      <section anchor="iana-h2-error">
        <name>HTTP/2 Error Code Registration</name>
        <t>The following entries are added to the "HTTP/2 Error Code" registry established
by <xref target="HTTP2"/>:</t>
        <t>For WEBTRANSPORT_ERROR:</t>
        <dl>
          <dt>Code:</dt>
          <dd>
            <t>0xTBD</t>
          </dd>
          <dt>Name:</dt>
          <dd>
            <t>WEBTRANSPORT_ERROR</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>General WebTransport error detected</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t><xref target="errors"/></t>
          </dd>
        </dl>
        <t>For WEBTRANSPORT_STREAM_STATE_ERROR:</t>
        <dl>
          <dt>Code:</dt>
          <dd>
            <t>0xTBD</t>
          </dd>
          <dt>Name:</dt>
          <dd>
            <t>WEBTRANSPORT_STREAM_STATE_ERROR</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>Unexpected WebTransport stream-related capsule received</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t><xref target="errors"/></t>
          </dd>
        </dl>
        <t>For WEBTRANSPORT_FLOW_CONTROL_ERROR:</t>
        <dl>
          <dt>Code:</dt>
          <dd>
            <t>0xTBD</t>
          </dd>
          <dt>Name:</dt>
          <dd>
            <t>WEBTRANSPORT_FLOW_CONTROL_ERROR</t>
          </dd>
          <dt>Description:</dt>
          <dd>
            <t>A flow control error occurred</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t><xref target="errors"/></t>
          </dd>
        </dl>
      </section>
      <section anchor="iana-capsules">
        <name>Capsule Types</name>
        <t>The following entries are added to the "HTTP Capsule Types" registry established
by <xref target="HTTP-DATAGRAM"/>:</t>
        <t>The <tt>PADDING</tt> capsule.</t>
        <dl spacing="compact">
          <dt>Value:</dt>
          <dd>
            <t>0x190B4D38</t>
          </dd>
          <dt>Capsule Type:</dt>
          <dd>
            <t><iref item="PADDING"/><xref target="PADDING" format="none">PADDING</xref></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>WebTransport Working Group <eref target="mailto:webtransport@ietf.org">webtransport@ietf.org</eref></t>
          </dd>
          <dt>Notes:</dt>
          <dd>
            <t>None</t>
          </dd>
        </dl>
        <t>The <tt>WT_RESET_STREAM</tt> capsule.</t>
        <dl spacing="compact">
          <dt>Value:</dt>
          <dd>
            <t>0x190B4D39</t>
          </dd>
          <dt>Capsule Type:</dt>
          <dd>
            <t><iref item="WT_RESET_STREAM"/><xref target="WT_RESET_STREAM" format="none">WT_RESET_STREAM</xref></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>WebTransport Working Group <eref target="mailto:webtransport@ietf.org">webtransport@ietf.org</eref></t>
          </dd>
          <dt>Notes:</dt>
          <dd>
            <t>None</t>
          </dd>
        </dl>
        <t>The <tt>WT_STOP_SENDING</tt> capsule.</t>
        <dl spacing="compact">
          <dt>Value:</dt>
          <dd>
            <t>0x190B4D3A</t>
          </dd>
          <dt>Capsule Type:</dt>
          <dd>
            <t><iref item="WT_STOP_SENDING"/><xref target="WT_STOP_SENDING" format="none">WT_STOP_SENDING</xref></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>WebTransport Working Group <eref target="mailto:webtransport@ietf.org">webtransport@ietf.org</eref></t>
          </dd>
          <dt>Notes:</dt>
          <dd>
            <t>None</t>
          </dd>
        </dl>
        <t>The <tt>WT_STREAM</tt> capsule.</t>
        <dl spacing="compact">
          <dt>Value:</dt>
          <dd>
            <t>0x190B4D3B..0x190B4D3C</t>
          </dd>
          <dt>Capsule Type:</dt>
          <dd>
            <t><iref item="WT_STREAM"/><xref target="WT_STREAM" format="none">WT_STREAM</xref></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>WebTransport Working Group <eref target="mailto:webtransport@ietf.org">webtransport@ietf.org</eref></t>
          </dd>
          <dt>Notes:</dt>
          <dd>
            <t>None</t>
          </dd>
        </dl>
        <t>The <tt>WT_MAX_STREAM_DATA</tt> capsule.</t>
        <dl spacing="compact">
          <dt>Value:</dt>
          <dd>
            <t>0x190B4D3E</t>
          </dd>
          <dt>Capsule Type:</dt>
          <dd>
            <t><iref item="WT_MAX_STREAM_DATA"/><xref target="WT_MAX_STREAM_DATA" format="none">WT_MAX_STREAM_DATA</xref></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>WebTransport Working Group <eref target="mailto:webtransport@ietf.org">webtransport@ietf.org</eref></t>
          </dd>
          <dt>Notes:</dt>
          <dd>
            <t>None</t>
          </dd>
        </dl>
      </section>
      <section anchor="iana-header">
        <name>HTTP Header Field Name</name>
        <t>IANA will register the following entry in the "Hypertext Transfer Protocol
(HTTP) Field Name Registry" maintained at
<eref target="https://www.iana.org/assignments/http-fields">https://www.iana.org/assignments/http-fields</eref>:</t>
        <dl>
          <dt>Field Name:</dt>
          <dd>
            <t>WebTransport-Init</t>
          </dd>
          <dt>Structured Type:</dt>
          <dd>
            <t>Dictionary</t>
          </dd>
          <dt>Status:</dt>
          <dd>
            <t>permanent</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>This document</t>
          </dd>
          <dt>Comments:</dt>
          <dd>
            <t>None</t>
          </dd>
        </dl>
      </section>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="OVERVIEW">
          <front>
            <title>The WebTransport Protocol Framework</title>
            <author fullname="Eric Kinnear" initials="E." surname="Kinnear">
              <organization>Apple Inc.</organization>
            </author>
            <author fullname="Victor Vasiliev" initials="V." surname="Vasiliev">
              <organization>Google</organization>
            </author>
            <date day="20" month="October" year="2025"/>
            <abstract>
              <t>   The WebTransport Protocol Framework enables clients constrained by
   the Web security model to communicate with a remote server using a
   secure multiplexed transport.  It consists of a set of individual
   protocols that are safe to expose to untrusted applications, combined
   with an abstract model that allows them to be used interchangeably.

   This document defines the overall requirements on the protocols used
   in WebTransport, as well as the common features of the protocols,
   support for some of which may be optional.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-webtrans-overview-11"/>
        </reference>
        <reference anchor="WEBTRANSPORT-H3">
          <front>
            <title>WebTransport over HTTP/3</title>
            <author fullname="Alan Frindell" initials="A." surname="Frindell">
              <organization>Facebook</organization>
            </author>
            <author fullname="Eric Kinnear" initials="E." surname="Kinnear">
              <organization>Apple Inc.</organization>
            </author>
            <author fullname="Victor Vasiliev" initials="V." surname="Vasiliev">
              <organization>Google</organization>
            </author>
            <date day="20" month="October" year="2025"/>
            <abstract>
              <t>   WebTransport [OVERVIEW] is a protocol framework that enables
   application clients constrained by the Web security model to
   communicate with a remote application server using a secure
   multiplexed transport.  This document describes a WebTransport
   protocol that is based on HTTP/3 [HTTP3] and provides support for
   unidirectional streams, bidirectional streams, and datagrams, all
   multiplexed within the same HTTP/3 connection.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-webtrans-http3-14"/>
        </reference>
        <reference anchor="HTTP">
          <front>
            <title>HTTP Semantics</title>
            <author fullname="R. Fielding" initials="R." role="editor" surname="Fielding"/>
            <author fullname="M. Nottingham" initials="M." role="editor" surname="Nottingham"/>
            <author fullname="J. Reschke" initials="J." role="editor" surname="Reschke"/>
            <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="HTTP-DATAGRAM">
          <front>
            <title>HTTP Datagrams and the Capsule Protocol</title>
            <author fullname="D. Schinazi" initials="D." surname="Schinazi"/>
            <author fullname="L. Pardue" initials="L." surname="Pardue"/>
            <date month="August" year="2022"/>
            <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 sent unreliably using the QUIC DATAGRAM extension. When the QUIC DATAGRAM frame is unavailable or undesirable, HTTP Datagrams can be sent using the Capsule Protocol, which is 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>
          </front>
          <seriesInfo name="RFC" value="9297"/>
          <seriesInfo name="DOI" value="10.17487/RFC9297"/>
        </reference>
        <reference anchor="HTTP2">
          <front>
            <title>HTTP/2</title>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson"/>
            <author fullname="C. Benfield" initials="C." role="editor" surname="Benfield"/>
            <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="ORIGIN">
          <front>
            <title>The Web Origin Concept</title>
            <author fullname="A. Barth" initials="A." surname="Barth"/>
            <date month="December" year="2011"/>
            <abstract>
              <t>This document defines the concept of an "origin", which is often used as the scope of authority or privilege by user agents. Typically, user agents isolate content retrieved from different origins to prevent malicious web site operators from interfering with the operation of benign web sites. In addition to outlining the principles that underlie the concept of origin, this document details how to determine the origin of a URI and how to serialize an origin into a string. It also defines an HTTP header field, named "Origin", that indicates which origins are associated with an HTTP request. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6454"/>
          <seriesInfo name="DOI" value="10.17487/RFC6454"/>
        </reference>
        <reference anchor="PARTIAL-RESET">
          <front>
            <title>QUIC Stream Resets with Partial Delivery</title>
            <author fullname="Marten Seemann" initials="M." surname="Seemann">
         </author>
            <author fullname="Kazuho Oku" initials="K." surname="Oku">
              <organization>Fastly</organization>
            </author>
            <date day="14" month="June" year="2025"/>
            <abstract>
              <t>   QUIC defines a RESET_STREAM frame to abort sending on a stream.  When
   a sender resets a stream, it also stops retransmitting STREAM frames
   for this stream in the event of packet loss.  On the receiving side,
   there is no guarantee that any data sent on that stream is delivered.

   This document defines a new QUIC frame, the RESET_STREAM_AT frame,
   that allows resetting a stream, while guaranteeing delivery of stream
   data up to a certain byte offset.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-quic-reliable-stream-reset-07"/>
        </reference>
        <reference anchor="TLS">
          <front>
            <title>The Transport Layer Security (TLS) Protocol Version 1.3</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <date month="August" year="2018"/>
            <abstract>
              <t>This document specifies version 1.3 of the Transport Layer Security (TLS) protocol. TLS allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
              <t>This document updates RFCs 5705 and 6066, and obsoletes RFCs 5077, 5246, and 6961. This document also specifies new requirements for TLS 1.2 implementations.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8446"/>
          <seriesInfo name="DOI" value="10.17487/RFC8446"/>
        </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"/>
            <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"/>
            <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="RFC8441">
          <front>
            <title>Bootstrapping WebSockets with HTTP/2</title>
            <author fullname="P. McManus" initials="P." surname="McManus"/>
            <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="RFC6585">
          <front>
            <title>Additional HTTP Status Codes</title>
            <author fullname="M. Nottingham" initials="M." surname="Nottingham"/>
            <author fullname="R. Fielding" initials="R." surname="Fielding"/>
            <date month="April" year="2012"/>
            <abstract>
              <t>This document specifies additional HyperText Transfer Protocol (HTTP) status codes for a variety of common situations. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6585"/>
          <seriesInfo name="DOI" value="10.17487/RFC6585"/>
        </reference>
        <reference anchor="RFC8941">
          <front>
            <title>Structured Field Values for HTTP</title>
            <author fullname="M. Nottingham" initials="M." surname="Nottingham"/>
            <author fullname="P-H. Kamp" surname="P-H. Kamp"/>
            <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="RFC9000">
          <front>
            <title>QUIC: A UDP-Based Multiplexed and Secure Transport</title>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar"/>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson"/>
            <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="RFC9113">
          <front>
            <title>HTTP/2</title>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson"/>
            <author fullname="C. Benfield" initials="C." role="editor" surname="Benfield"/>
            <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="RFC7627">
          <front>
            <title>Transport Layer Security (TLS) Session Hash and Extended Master Secret Extension</title>
            <author fullname="K. Bhargavan" initials="K." role="editor" surname="Bhargavan"/>
            <author fullname="A. Delignat-Lavaud" initials="A." surname="Delignat-Lavaud"/>
            <author fullname="A. Pironti" initials="A." surname="Pironti"/>
            <author fullname="A. Langley" initials="A." surname="Langley"/>
            <author fullname="M. Ray" initials="M." surname="Ray"/>
            <date month="September" year="2015"/>
            <abstract>
              <t>The Transport Layer Security (TLS) master secret is not cryptographically bound to important session parameters such as the server certificate. Consequently, it is possible for an active attacker to set up two sessions, one with a client and another with a server, such that the master secrets on the two sessions are the same. Thereafter, any mechanism that relies on the master secret for authentication, including session resumption, becomes vulnerable to a man-in-the-middle attack, where the attacker can simply forward messages back and forth between the client and server. This specification defines a TLS extension that contextually binds the master secret to a log of the full handshake that computes it, thus preventing such attacks.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7627"/>
          <seriesInfo name="DOI" value="10.17487/RFC7627"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="DATAGRAM">
          <front>
            <title>An Unreliable Datagram Extension to QUIC</title>
            <author fullname="T. Pauly" initials="T." surname="Pauly"/>
            <author fullname="E. Kinnear" initials="E." surname="Kinnear"/>
            <author fullname="D. Schinazi" initials="D." surname="Schinazi"/>
            <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="HTTP3">
          <front>
            <title>HTTP/3</title>
            <author fullname="M. Bishop" initials="M." role="editor" surname="Bishop"/>
            <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="QUIC">
          <front>
            <title>QUIC: A UDP-Based Multiplexed and Secure Transport</title>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar"/>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson"/>
            <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="MPTCP">
          <front>
            <title>TCP Extensions for Multipath Operation with Multiple Addresses</title>
            <author fullname="A. Ford" initials="A." surname="Ford"/>
            <author fullname="C. Raiciu" initials="C." surname="Raiciu"/>
            <author fullname="M. Handley" initials="M." surname="Handley"/>
            <author fullname="O. Bonaventure" initials="O." surname="Bonaventure"/>
            <date month="January" year="2013"/>
            <abstract>
              <t>TCP/IP communication is currently restricted to a single path per connection, yet multiple paths often exist between peers. The simultaneous use of these multiple paths for a TCP/IP session would improve resource usage within the network and, thus, improve user experience through higher throughput and improved resilience to network failure.</t>
              <t>Multipath TCP provides the ability to simultaneously use multiple paths between peers. This document presents a set of extensions to traditional TCP to support multipath operation. The protocol offers the same type of service to applications as TCP (i.e., reliable bytestream), and it provides the components necessary to establish and use multiple TCP flows across potentially disjoint paths. This document defines an Experimental Protocol for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6824"/>
          <seriesInfo name="DOI" value="10.17487/RFC6824"/>
        </reference>
        <reference anchor="RFC7301">
          <front>
            <title>Transport Layer Security (TLS) Application-Layer Protocol Negotiation Extension</title>
            <author fullname="S. Friedl" initials="S." surname="Friedl"/>
            <author fullname="A. Popov" initials="A." surname="Popov"/>
            <author fullname="A. Langley" initials="A." surname="Langley"/>
            <author fullname="E. Stephan" initials="E." surname="Stephan"/>
            <date month="July" year="2014"/>
            <abstract>
              <t>This document describes a Transport Layer Security (TLS) extension for application-layer protocol negotiation within the TLS handshake. For instances in which multiple application protocols are supported on the same TCP or UDP port, this extension allows the application layer to negotiate which protocol will be used within the TLS connection.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7301"/>
          <seriesInfo name="DOI" value="10.17487/RFC7301"/>
        </reference>
        <reference anchor="RFC9220">
          <front>
            <title>Bootstrapping WebSockets with HTTP/3</title>
            <author fullname="R. Hamilton" initials="R." surname="Hamilton"/>
            <date month="June" 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="RFC" value="9220"/>
          <seriesInfo name="DOI" value="10.17487/RFC9220"/>
        </reference>
        <reference anchor="RFC9729">
          <front>
            <title>The Concealed HTTP Authentication Scheme</title>
            <author fullname="D. Schinazi" initials="D." surname="Schinazi"/>
            <author fullname="D. Oliver" initials="D." surname="Oliver"/>
            <author fullname="J. Hoyland" initials="J." surname="Hoyland"/>
            <date month="February" year="2025"/>
            <abstract>
              <t>Most HTTP authentication schemes are probeable in the sense that it is possible for an unauthenticated client to probe whether an origin serves resources that require authentication. It is possible for an origin to hide the fact that it requires authentication by not generating Unauthorized status codes; however, that only works with non-cryptographic authentication schemes: cryptographic signatures require a fresh nonce to be signed. Prior to this document, there was no existing way for the origin to share such a nonce without exposing the fact that it serves resources that require authentication. This document defines a new non-probeable cryptographic authentication scheme.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9729"/>
          <seriesInfo name="DOI" value="10.17487/RFC9729"/>
        </reference>
      </references>
    </references>
    <?line 1664?>

<section anchor="use-with-other-http-versions">
      <name>Use with Other HTTP Versions</name>
      <t>While this document defines WebTransport negotiation and session establishment
in terms of HTTP/2, the capsule-based mechanisms described here rely on generic
HTTP semantics and the Capsule Protocol <xref target="HTTP-DATAGRAM"/>, and can generally be
used over any HTTP version that supports these features.</t>
      <t>The primary HTTP-version-specific aspects of this protocol are the use of
Extended CONNECT for session establishment and the use of HTTP SETTINGS for
exchanging initial flow control limits (<xref target="flow-control-settings"/>).</t>
      <t>Extended CONNECT is defined for HTTP/2 in <xref target="RFC8441"/> and for HTTP/3 in
<xref target="RFC9220"/>.  Other HTTP versions that support Extended CONNECT can use the
"webtransport" upgrade token (<xref target="upgrade-token"/>) to establish capsule-based
WebTransport sessions.</t>
      <t>The flow control SETTINGS defined in this document use the same codepoints
across HTTP versions, but their behavior differs.  HTTP/2 allows SETTINGS to be
updated during the lifetime of a connection with acknowledgment-based
synchronization, while HTTP/3 SETTINGS are sent only once and are fixed for the
connection lifetime.  The <tt>WebTransport-Init</tt> header field
(<xref target="flow-control-header"/>) can be used to provide per-session initial flow
control limits regardless of HTTP version.</t>
      <t>When a version-specific WebTransport protocol exists for a given HTTP version,
endpoints SHOULD prefer it over the capsule-based protocol defined here.  For
example, WebTransport over HTTP/3 <xref target="WEBTRANSPORT-H3"/> provides stream
independence and unreliable datagram delivery by using native QUIC streams and
datagrams, which are not available when using the capsule-based protocol over a
single HTTP/3 stream.</t>
    </section>
    <section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>Thanks to Anthony Chivetta, Eric Gorbaty, Ankshit Jain, Joshua Otto, and
Valentin Pistol for their contributions in the design and implementation of this
work. The requirements on TLS usage were inspired by <xref target="RFC9729"/>.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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
cQtZgc88Xrw8+xG7i12cn70U5tHknp2rTyK4ZdzeAR6zFbLgUi2Mntm2UgsX
nzCZf7fbjMnTuetmxM5tLdvYuFurMVvS9jblmKdbKtu8lShP92qU66zW5Yqv
rcklFmm66ks2YT71a8fCcnxTbTWzORVcA2W6dW4rf/0sAMv8rkAykm3hJC1L
g9Y4/gV8jaYbJGu2NdgIRIzfY6MlabwffYHjPf4yueNP2hA/JxE/lUiXNCZb
tjBBy/+a3RQbbqVOMHQIlZNbKNWGOgPlulPY8IpiMie2rpbo8V+6rdod8SmF
yreA2Xa3iICwJ5kG7LYwjo6oCBsEQi/Qk3992dcKHH+57DN6e2vIiFRUcamY
fIlUlFrJ9rSd4jK5SVyqO4rLZKu4VHcXl18qYW4UlxF6aEpNbxvKCc/k5wpP
FW7tzpqAJzxjm7i1DFUdPXi+RIZu5TJfIkpVU5S2CpejorTZ8jkiSsPmek05
GulxgkuKt/gAoau2CN1Yn6tbt6f6kuZUd2xNRa5Z3NQV58QPt6FVt6XOzvhG
BMcUTIy1MeA5HTB0TxpjvsPvqpqLuZtV33a9qhuN+uQuRr0yRn0X0Dzr3sKr
y2uN2NHySreUsFGXAjZqK1+jn6N4jaivrK2wVLfp5LrFyp+sl+tFWlNtluvu
blrlzGw1ADtn62hXV3LKdHSapcvGUnNvjtPDXthLOzH631l83jzGkWrIhObA
B7v+wB3tYIPEWNPZNZQuldw96cDDkqbU0uDH6DTUj1yZG6Fa/XD96IonmYT2
7Es2sq9gAoommWut6LbBKGwlQx3Gxzgc18oEWzCtvdLKckaqD6MGSDEVenSj
+vzC+acPdrv9MwaGN2nNVVRjHt2kLY++wFcjS7Iq68SooF1UkHhUwNUDftcH
wjsqZeJYJRstplfqldxx3Wzn5/fx8yKQnH8syUWsCu7/sVqv/uPJ7h8f4n/J
tM6s3zHM6Kd8Ya+GjuOUNvEpN2Pt81j9va6eQuSO5ptGXLvg3KN3ydANu5+z
pkzZv5ijLb2FgSe8oIzCqk65utZ2V+dLtazeF9KokU/SVWOWPIo3kjYrfNRL
vmZOsbfXo6ZbVG7Kg+w99kndVyds1mXQGNn2SDT0iVUgerHgxlDwRNmmgsT3
tqiznjLuO46lM4lT952ir5rE85t4fDxGSKlTrXrOeBaCLexFifshW62QoZwB
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
v95/hrWt/xc7iIZZJ/kAAA==

-->

</rfc>
