<?xml version="1.0" encoding="UTF-8"?>
  <?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
  <!-- generated by https://github.com/cabo/kramdown-rfc2629 version 1.2.11 -->

<!DOCTYPE rfc SYSTEM "rfc2629.dtd" [
]>

<?rfc toc="yes"?>
<?rfc sortrefs="yes"?>
<?rfc symrefs="yes"?>
<?rfc docmapping="yes"?>

<rfc ipr="trust200902" docName="draft-ietf-quic-http-21" category="std">

  <front>
    <title abbrev="HTTP/3">Hypertext Transfer Protocol Version 3 (HTTP/3)</title>

    <author initials="M." surname="Bishop" fullname="Mike Bishop" role="editor">
      <organization>Akamai</organization>
      <address>
        <email>mbishop@evequefou.be</email>
      </address>
    </author>

    <date year="2019" month="July" day="08"/>

    <area>Transport</area>
    <workgroup>QUIC</workgroup>
    

    <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>


    <note title="Note to Readers">


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

<t>Working Group information can be found at <eref target="https://github.com/quicwg">https://github.com/quicwg</eref>; source
code and issues list for this draft can be found at
<eref target="https://github.com/quicwg/base-drafts/labels/-http">https://github.com/quicwg/base-drafts/labels/-http</eref>.</t>


    </note>


  </front>

  <middle>


<section anchor="introduction" title="Introduction">

<t>HTTP semantics are used for a broad range of services on the Internet. These
semantics have commonly been used with two different TCP mappings, HTTP/1.1 and
HTTP/2.  HTTP/3 supports the same semantics over a new transport protocol, QUIC.</t>

<section anchor="prior-versions-of-http" title="Prior versions of HTTP">

<t>HTTP/1.1 is a TCP mapping which uses whitespace-delimited text fields to convey
HTTP messages.  While these exchanges are human-readable, using whitespace for
message formatting leads to parsing difficulties and workarounds to be tolerant
of variant behavior. Because each connection can transfer only a single HTTP
request or response at a time in each direction, multiple parallel TCP
connections are often used, reducing the ability of the congestion controller to
accurately manage traffic between endpoints.</t>

<t>HTTP/2 introduced a binary framing and multiplexing layer to improve latency
without modifying the transport layer.  However, because the parallel nature of
HTTP/2’s multiplexing is not visible to TCP’s loss recovery mechanisms, a lost
or reordered packet causes all active transactions to experience a stall
regardless of whether that transaction was impacted by the lost packet.</t>

</section>
<section anchor="delegation-to-quic" title="Delegation to QUIC">

<t>The QUIC transport protocol incorporates stream multiplexing and per-stream flow
control, similar to that provided by the HTTP/2 framing layer. By providing
reliability at the stream level and congestion control across the entire
connection, it has the capability to improve the performance of HTTP compared to
a TCP mapping.  QUIC also incorporates TLS 1.3 at the transport layer, offering
comparable security to running TLS over TCP, with the improved connection setup
latency of TCP Fast Open <xref target="RFC7413"/>}.</t>

<t>This document defines a mapping of HTTP semantics over the QUIC transport
protocol, drawing heavily on the design of HTTP/2.  While delegating stream
lifetime and flow control issues to QUIC, a similar binary framing is used on
each stream. Some HTTP/2 features are subsumed by QUIC, while other features are
implemented atop QUIC.</t>

<t>QUIC is described in <xref target="QUIC-TRANSPORT"/>.  For a full description of HTTP/2, see
<xref target="HTTP2"/>.</t>

</section>
</section>
<section anchor="http3-protocol-overview" title="HTTP/3 Protocol Overview">

<t>HTTP/3 provides a transport for HTTP semantics using the QUIC transport protocol
and an internal framing layer similar to HTTP/2.</t>

<t>Once a client knows that an HTTP/3 server exists at a certain endpoint, it opens
a QUIC connection. QUIC provides protocol negotiation, stream-based
multiplexing, and flow control. An HTTP/3 endpoint can be discovered using HTTP
Alternative Services; this process is described in greater detail in
<xref target="discovery"/>.</t>

<t>Within each stream, the basic unit of HTTP/3 communication is a frame
(<xref target="frames"/>).  Each frame type serves a different purpose.  For example, HEADERS
and DATA frames form the basis of HTTP requests and responses
(<xref target="request-response"/>).  Other frame types like SETTINGS, PRIORITY, and GOAWAY
are used to manage the overall connection and relationships between streams.</t>

<t>Multiplexing of requests is performed using the QUIC stream abstraction,
described in Section 2 of <xref target="QUIC-TRANSPORT"/>.  Each request and response
consumes a single QUIC stream.  Streams are independent of each other, so one
stream that is blocked or suffers packet loss does not prevent progress on other
streams.</t>

<t>Server push is an interaction mode introduced in HTTP/2 <xref target="HTTP2"/> which permits
a server to push a request-response exchange to a client in anticipation of the
client making the indicated request.  This trades off network usage against a
potential latency gain.  Several HTTP/3 frames are used to manage server push,
such as PUSH_PROMISE, DUPLICATE_PUSH, MAX_PUSH_ID, and CANCEL_PUSH.</t>

<t>As in HTTP/2, request and response headers are compressed for transmission.
Because HPACK <xref target="HPACK"/> relies on in-order transmission of compressed
header blocks (a guarantee not provided by QUIC), HTTP/3 replaces HPACK with
QPACK <xref target="QPACK"></xref>.  QPACK uses separate unidirectional streams to modify and track
header table state, while header blocks refer to the state of the table without
modifying it.</t>

<section anchor="document-organization" title="Document Organization">

<t>The HTTP/3 specification is split into seven parts.  The document begins
with a detailed overview of the connection lifecycle and key concepts:</t>

<t><list style="symbols">
  <t>Connection Setup and Management (<xref target="connection-setup"/>) covers how an HTTP/3
endpoint is discovered and a connection is established.</t>
  <t>HTTP Request Lifecycle (<xref target="http-request-lifecycle"/>) describes how HTTP
semantics are expressed using frames.</t>
  <t>Connection Closure (<xref target="connection-closure"/>) describes how connections are
terminated, either gracefully or abruptly.</t>
</list></t>

<t>The details of the wire protocol and interactions with the transport are
described in subsequent sections:</t>

<t><list style="symbols">
  <t>Stream Mapping and Usage (<xref target="stream-mapping"/>) describes the way QUIC streams
are used.</t>
  <t>HTTP Framing Layer (<xref target="http-framing-layer"/>) describes the frames used on
most streams.</t>
  <t>Error Handling (<xref target="errors"/>) describes how error conditions are handled and
expressed, either on a particular stream or for the connection as a whole.</t>
</list></t>

<t>Additional resources are provided in the final sections:</t>

<t><list style="symbols">
  <t>Extensions to HTTP/3 (<xref target="extensions"/>) describes how new capabilities can be
added in future documents.</t>
  <t>A more detailed comparison between HTTP/2 and HTTP/3 can be found in
<xref target="h2-considerations"/>.</t>
</list></t>

</section>
<section anchor="conventions-and-terminology" title="Conventions and Terminology">

<t>The key words “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>Field definitions are given in Augmented Backus-Naur Form (ABNF), as defined in
<xref target="RFC5234"/>.</t>

<t>This document uses the variable-length integer encoding from
<xref target="QUIC-TRANSPORT"/>.</t>

<t>The following terms are used:</t>

<t><list style="hanging">
  <t hangText='abort:'>
  An abrupt termination of a connection or stream, possibly due to an error
condition.</t>
  <t hangText='client:'>
  The endpoint that initiates an HTTP/3 connection.  Clients send HTTP requests
and receive HTTP responses.</t>
  <t hangText='connection:'>
  A transport-layer connection between two endpoints, using QUIC as the
transport protocol.</t>
  <t hangText='connection error:'>
  An error that affects the entire HTTP/3 connection.</t>
  <t hangText='endpoint:'>
  Either the client or server of the connection.</t>
  <t hangText='frame:'>
  The smallest unit of communication on a stream in HTTP/3, consisting of a
header and a variable-length sequence of octets structured according to the
frame type.

Protocol elements called “frames” exist in both this document and
<xref target="QUIC-TRANSPORT"/>. Where frames from <xref target="QUIC-TRANSPORT"/> are referenced, the
frame name will be prefaced with “QUIC.”  For example, “QUIC CONNECTION_CLOSE
frames.”  References without this preface refer to frames defined in
<xref target="frames"/>.</t>
  <t hangText='peer:'>
  An endpoint.  When discussing a particular endpoint, “peer” refers to the
endpoint that is remote to the primary subject of discussion.</t>
  <t hangText='receiver:'>
  An endpoint that is receiving frames.</t>
  <t hangText='sender:'>
  An endpoint that is transmitting frames.</t>
  <t hangText='server:'>
  The endpoint that accepts an HTTP/3 connection.  Servers receive HTTP requests
and send HTTP responses.</t>
  <t hangText='stream:'>
  A bidirectional or unidirectional bytestream provided by the QUIC transport.</t>
  <t hangText='stream error:'>
  An error on the individual HTTP/3 stream.</t>
</list></t>

<t>The term “payload body” is defined in Section 3.3 of <xref target="RFC7230"/>.</t>

<t>Finally, the terms “gateway”, “intermediary”, “proxy”, and “tunnel” are defined
in Section 2.3 of <xref target="RFC7230"/>.  Intermediaries act as both client and server at
different times.</t>

</section>
</section>
<section anchor="connection-setup" title="Connection Setup and Management">

<section anchor="draft-version-identification" title="Draft Version Identification">

<t><list style='empty'>
  <t><spanx style="strong">RFC Editor’s Note:</spanx>  Please remove this section prior to publication of a
final version of this document.</t>
</list></t>

<t>HTTP/3 uses the token “h3” to identify itself in ALPN and Alt-Svc.  Only
implementations of the final, published RFC can identify themselves as “h3”.
Until such an RFC exists, implementations MUST NOT identify themselves using
this string.</t>

<t>Implementations of draft versions of the protocol MUST add the string “-“ and
the corresponding draft number to the identifier. For example,
draft-ietf-quic-http-01 is identified using the string “h3-01”.</t>

<t>Non-compatible experiments that are based on these draft versions MUST append
the string “-“ and an experiment name to the identifier. For example, an
experimental implementation based on draft-ietf-quic-http-09 which reserves an
extra stream for unsolicited transmission of 1980s pop music might identify
itself as “h3-09-rickroll”. Note that any label MUST conform to the “token”
syntax defined in Section 3.2.6 of <xref target="RFC7230"/>. Experimenters are encouraged to
coordinate their experiments on the quic@ietf.org mailing list.</t>

</section>
<section anchor="discovery" title="Discovering an HTTP/3 Endpoint">

<t>An HTTP origin advertises the availability of an equivalent HTTP/3 endpoint via
the Alt-Svc HTTP response header field or the HTTP/2 ALTSVC frame
(<xref target="ALTSVC"/>), using the ALPN token defined in
<xref target="connection-establishment"/>.</t>

<t>For example, an origin could indicate in an HTTP response that HTTP/3 was
available on UDP port 50781 at the same hostname by including the following
header field:</t>

<figure><artwork type="example"><![CDATA[
Alt-Svc: h3=":50781"
]]></artwork></figure>

<t>On receipt of an Alt-Svc record indicating HTTP/3 support, a client MAY attempt
to establish a QUIC connection to the indicated host and port and, if
successful, send HTTP requests using the mapping described in this document.</t>

<t>Connectivity problems (e.g. firewall blocking UDP) can result in QUIC connection
establishment failure, in which case the client SHOULD continue using the
existing connection or try another alternative endpoint offered by the origin.</t>

<t>Servers MAY serve HTTP/3 on any UDP port, since an alternative always includes
an explicit port.</t>

<section anchor="alt-svc-version-hint" title="QUIC Version Hints">

<t>This document defines the “quic” parameter for Alt-Svc, which MAY be used to
provide version-negotiation hints to HTTP/3 clients. QUIC versions are four-byte
sequences with no additional constraints on format. Leading zeros SHOULD be
omitted for brevity.</t>

<t>Syntax:</t>

<figure><artwork type="abnf"><![CDATA[
quic = DQUOTE version-number [ "," version-number ] * DQUOTE
version-number = 1*8HEXDIG; hex-encoded QUIC version
]]></artwork></figure>

<t>Where multiple versions are listed, the order of the values reflects the
server’s preference (with the first value being the most preferred version).
Reserved versions MAY be listed, but unreserved versions which are not supported
by the alternative SHOULD NOT be present in the list. Origins MAY omit supported
versions for any reason.</t>

<t>Clients MUST ignore any included versions which they do not support.  The “quic”
parameter MUST NOT occur more than once; clients SHOULD process only the first
occurrence.</t>

<t>For example, suppose a server supported both version 0x00000001 and the version
rendered in ASCII as “Q034”.  If it also opted to include the reserved version
(from Section 15 of <xref target="QUIC-TRANSPORT"/>) 0x1abadaba, it could specify the
following header field:</t>

<figure><artwork type="example"><![CDATA[
Alt-Svc: h3=":49288";quic="1,1abadaba,51303334"
]]></artwork></figure>

<t>A client acting on this header field would drop the reserved version (not
supported), then attempt to connect to the alternative using the first version
in the list which it does support, if any.</t>

</section>
</section>
<section anchor="connection-establishment" title="Connection Establishment">

<t>HTTP/3 relies on QUIC as the underlying transport.  The QUIC version being used
MUST use TLS version 1.3 or greater as its handshake protocol.  HTTP/3 clients
MUST indicate the target domain name during the TLS handshake. This may be done
using the Server Name Indication (SNI) <xref target="RFC6066"/> extension to TLS or using
some other mechanism.</t>

<t>QUIC connections are established as described in <xref target="QUIC-TRANSPORT"/>. During
connection establishment, HTTP/3 support is indicated by selecting the ALPN
token “h3” in the TLS handshake.  Support for other application-layer protocols
MAY be offered in the same handshake.</t>

<t>While connection-level options pertaining to the core QUIC protocol are set in
the initial crypto handshake, HTTP/3-specific settings are conveyed in the
SETTINGS frame. After the QUIC connection is established, a SETTINGS frame
(<xref target="frame-settings"/>) MUST be sent by each endpoint as the initial frame of their
respective HTTP control stream (see <xref target="control-streams"/>).</t>

</section>
<section anchor="connection-reuse" title="Connection Reuse">

<t>Once a connection exists to a server endpoint, this connection MAY be reused for
requests with multiple different URI authority components.  The client MAY send
any requests for which the client considers the server authoritative.</t>

<t>An authoritative HTTP/3 endpoint is typically discovered because the client has
received an Alt-Svc record from the request’s origin which nominates the
endpoint as a valid HTTP Alternative Service for that origin.  As required by
<xref target="RFC7838"/>, clients MUST check that the nominated server can present a valid
certificate for the origin before considering it authoritative. Clients MUST NOT
assume that an HTTP/3 endpoint is authoritative for other origins without an
explicit signal.</t>

<t>A server that does not wish clients to reuse connections for a particular origin
can indicate that it is not authoritative for a request by sending a 421
(Misdirected Request) status code in response to the request (see Section 9.1.2
of <xref target="HTTP2"/>).</t>

<t>The considerations discussed in Section 9.1 of <xref target="HTTP2"/> also apply to the
management of HTTP/3 connections.</t>

</section>
</section>
<section anchor="http-request-lifecycle" title="HTTP Request Lifecycle">

<section anchor="request-response" title="HTTP Message Exchanges">

<t>A client sends an HTTP request on a client-initiated bidirectional QUIC stream.
A client MUST send only a single request on a given stream. A server sends zero
or more non-final HTTP responses on the same stream as the request, followed by
a single final HTTP response, as detailed below.</t>

<t>An HTTP message (request or response) consists of:</t>

<t><list style="numbers">
  <t>the message header (see <xref target="RFC7230"/>, Section 3.2), sent as a single HEADERS
frame (see <xref target="frame-headers"/>),</t>
  <t>the payload body (see <xref target="RFC7230"/>, Section 3.3), sent as a series of DATA
frames (see <xref target="frame-data"/>),</t>
  <t>optionally, one HEADERS frame containing the trailer-part, if present (see
<xref target="RFC7230"/>, Section 4.1.2).</t>
</list></t>

<t>A server MAY send one or more PUSH_PROMISE frames (see <xref target="frame-push-promise"/>)
before, after, or interleaved with the frames of a response message. These
PUSH_PROMISE frames are not part of the response; see <xref target="server-push"/> for more
details.</t>

<t>The HEADERS and PUSH_PROMISE frames might reference updates to the QPACK dynamic
table. While these updates are not directly part of the message exchange, they
must be received and processed before the message can be consumed.  See
<xref target="header-formatting"/> for more details.</t>

<t>The “chunked” transfer encoding defined in Section 4.1 of <xref target="RFC7230"/> MUST NOT
be used.</t>

<t>If a DATA frame is received before a HEADERS frame on a either a request or push
stream, the recipient MUST respond with a connection error of type
HTTP_UNEXPECTED_FRAME (<xref target="errors"/>).</t>

<t>Trailing header fields are carried in an additional HEADERS frame following the
body. Senders MUST send only one HEADERS frame in the trailers section;
receivers MUST discard any subsequent HEADERS frames.</t>

<t>A response MAY consist of multiple messages when and only when one or more
informational responses (1xx; see <xref target="RFC7231"/>, Section 6.2) precede a final
response to the same request.  Non-final responses do not contain a payload body
or trailers.</t>

<t>An HTTP request/response exchange fully consumes a bidirectional QUIC stream.
After sending a request, a client MUST close the stream for sending.  Unless
using the CONNECT method (see <xref target="the-connect-method"/>), clients MUST NOT make
stream closure dependent on receiving a response to their request. After sending
a final response, the server MUST close the stream for sending. At this point,
the QUIC stream is fully closed.</t>

<t>When a stream is closed, this indicates the end of an HTTP message. Because some
messages are large or unbounded, endpoints SHOULD begin processing partial HTTP
messages once enough of the message has been received to make progress.  If a
client stream terminates without enough of the HTTP message to provide a
complete response, the server SHOULD abort its response with the error code
HTTP_INCOMPLETE_REQUEST.</t>

<t>A server can send a complete response prior to the client sending an entire
request if the response does not depend on any portion of the request that has
not been sent and received. When this is true, a server MAY request that the
client abort transmission of a request without error by triggering a QUIC
STOP_SENDING frame with error code HTTP_EARLY_RESPONSE, sending a complete
response, and cleanly closing its stream. Clients MUST NOT discard complete
responses as a result of having their request terminated abruptly, though
clients can always discard responses at their discretion for other reasons.</t>

<section anchor="header-formatting" title="Header Formatting and Compression">

<t>HTTP message headers carry information as a series of key-value pairs, called
header fields. For a listing of registered HTTP header fields, see the “Message
Header Field” registry maintained at
<eref target="https://www.iana.org/assignments/message-headers">https://www.iana.org/assignments/message-headers</eref>.</t>

<t>Just as in previous versions of HTTP, header field names are strings of ASCII
characters that are compared in a case-insensitive fashion.  Properties of HTTP
header field names and values are discussed in more detail in Section 3.2 of
<xref target="RFC7230"/>, though the wire rendering in HTTP/3 differs.  As in HTTP/2, header
field names MUST be converted to lowercase prior to their encoding.  A request
or response containing uppercase header field names MUST be treated as
malformed (<xref target="malformed"/>).</t>

<t>As in HTTP/2, HTTP/3 uses special pseudo-header fields beginning with the ‘:’
character (ASCII 0x3a) to convey the target URI, the method of the request, and
the status code for the response.  These pseudo-header fields are defined in
Section 8.1.2.3 and 8.1.2.4 of <xref target="HTTP2"/>. Pseudo-header fields are not HTTP
header fields.  Endpoints MUST NOT generate pseudo-header fields other than
those defined in <xref target="HTTP2"/>.  The restrictions on the use of pseudo-header
fields in Section 8.1.2.1 of <xref target="HTTP2"/> also apply to HTTP/3.</t>

<t>HTTP/3 uses QPACK header compression as described in <xref target="QPACK"></xref>, a variation of
HPACK which allows the flexibility to avoid header-compression-induced
head-of-line blocking.  See that document for additional details.</t>

<t>An HTTP/3 implementation MAY impose a limit on the maximum size of the message
header it will accept on an individual HTTP message.  A server that receives a
larger header field list than it is willing to handle can send an HTTP 431
(Request Header Fields Too Large) status code <xref target="RFC6585"/>.  A client can
discard responses that it cannot process.  The size of a header field list is
calculated based on the uncompressed size of header fields, including the length
of the name and value in bytes plus an overhead of 32 bytes for each header
field.</t>

<t>If an implementation wishes to advise its peer of this limit, it can be conveyed
as a number of bytes in the <spanx style="verb">SETTINGS_MAX_HEADER_LIST_SIZE</spanx> parameter. An
implementation which has received this parameter SHOULD NOT send an HTTP message
header which exceeds the indicated size, as the peer will likely refuse to
process it.  However, because this limit is applied at each hop, messages below
this limit are not guaranteed to be accepted.</t>

</section>
<section anchor="request-cancellation" title="Request Cancellation and Rejection">

<t>Clients can cancel requests by aborting the stream (QUIC RESET_STREAM and/or
STOP_SENDING frames, as appropriate) with an error code of
HTTP_REQUEST_CANCELLED (<xref target="http-error-codes"/>).  When the client cancels a
response, it indicates that this response is no longer of interest.
Implementations SHOULD cancel requests by aborting both directions of a stream.</t>

<t>When the server rejects a request without performing any application processing,
it SHOULD abort its response stream with the error code HTTP_REQUEST_REJECTED.
In this context, “processed” means that some data from the stream was passed to
some higher layer of software that might have taken some action as a result. The
client can treat requests rejected by the server as though they had never been
sent at all, thereby allowing them to be retried later on a new connection.
Servers MUST NOT use the HTTP_REQUEST_REJECTED error code for requests which
were partially or fully processed.  When a server abandons a response after
partial processing, it SHOULD abort its response stream with the error code
HTTP_REQUEST_CANCELLED.</t>

<t>When a client sends a STOP_SENDING with HTTP_REQUEST_CANCELLED, a server MAY
send the error code HTTP_REQUEST_REJECTED in the corresponding RESET_STREAM
if no processing was performed.  Clients MUST NOT reset streams with the
HTTP_REQUEST_REJECTED error code except in response to a QUIC STOP_SENDING
frame that contains the same code.</t>

<t>If a stream is cancelled after receiving a complete response, the client MAY
ignore the cancellation and use the response.  However, if a stream is cancelled
after receiving a partial response, the response SHOULD NOT be used.
Automatically retrying such requests is not possible, unless this is otherwise
permitted (e.g., idempotent actions like GET, PUT, or DELETE).</t>

</section>
<section anchor="malformed" title="Malformed Requests and Responses">

<t>A malformed request or response is one that is an otherwise valid sequence of
frames but is invalid due to the presence of extraneous frames, prohibited
header fields, the absence of mandatory header fields, or the inclusion of
uppercase header field names.</t>

<t>A request or response that includes a payload body can include a
<spanx style="verb">content-length</spanx> header field.  A request or response is also malformed if the
value of a content-length header field does not equal the sum of the DATA frame
payload lengths that form the body.  A response that is defined to have no
payload, as described in Section 3.3.2 of <xref target="RFC7230"/> can have a non-zero
content-length header field, even though no content is included in DATA frames.</t>

<t>Intermediaries that process HTTP requests or responses (i.e., any intermediary
not acting as a tunnel) MUST NOT forward a malformed request or response.
Malformed requests or responses that are detected MUST be treated as a stream
error (<xref target="errors"/>) of type HTTP_GENERAL_PROTOCOL_ERROR.</t>

<t>For malformed requests, a server MAY send an HTTP response prior to closing or
resetting the stream.  Clients MUST NOT accept a malformed response.  Note that
these requirements are intended to protect against several types of common
attacks against HTTP; they are deliberately strict because being permissive can
expose implementations to these vulnerabilities.</t>

</section>
</section>
<section anchor="the-connect-method" title="The CONNECT Method">

<t>The pseudo-method CONNECT (<xref target="RFC7231"/>, Section 4.3.6) is primarily used with
HTTP proxies to establish a TLS session with an origin server for the purposes
of interacting with “https” resources. In HTTP/1.x, CONNECT is used to convert
an entire HTTP connection into a tunnel to a remote host. In HTTP/2, the CONNECT
method is used to establish a tunnel over a single HTTP/2 stream to a remote
host for similar purposes.</t>

<t>A CONNECT request in HTTP/3 functions in the same manner as in HTTP/2. The
request MUST be formatted as described in <xref target="HTTP2"/>, Section 8.3. A CONNECT
request that does not conform to these restrictions is malformed (see
<xref target="malformed"/>). The request stream MUST NOT be closed at the end of the request.</t>

<t>A proxy that supports CONNECT establishes a TCP connection (<xref target="RFC0793"/>) to the
server identified in the “:authority” pseudo-header field. Once this connection
is successfully established, the proxy sends a HEADERS frame containing a 2xx
series status code to the client, as defined in <xref target="RFC7231"/>, Section 4.3.6.</t>

<t>All DATA frames on the stream correspond to data sent or received on the TCP
connection. Any DATA frame sent by the client is transmitted by the proxy to the
TCP server; data received from the TCP server is packaged into DATA frames by
the proxy. Note that the size and number of TCP segments is not guaranteed to
map predictably to the size and number of HTTP DATA or QUIC STREAM frames.</t>

<t>Once the CONNECT method has completed, only DATA frames are permitted
to be sent on the stream.  Extension frames MAY be used if specifically
permitted by the definition of the extension.  Receipt of any other frame type
MUST be treated as a connection error of type HTTP_UNEXPECTED_FRAME.</t>

<t>The TCP connection can be closed by either peer. When the client ends the
request stream (that is, the receive stream at the proxy enters the “Data Recvd”
state), the proxy will set the FIN bit on its connection to the TCP server. When
the proxy receives a packet with the FIN bit set, it will terminate the send
stream that it sends to the client. TCP connections which remain half-closed in
a single direction are not invalid, but are often handled poorly by servers, so
clients SHOULD NOT close a stream for sending while they still expect to receive
data from the target of the CONNECT.</t>

<t>A TCP connection error is signaled with QUIC RESET_STREAM frame. A proxy treats
any error in the TCP connection, which includes receiving a TCP segment with the
RST bit set, as a stream error of type HTTP_CONNECT_ERROR
(<xref target="http-error-codes"/>).  Correspondingly, if a proxy detects an error with the
stream or the QUIC connection, it MUST close the TCP connection.  If the
underlying TCP implementation permits it, the proxy SHOULD send a TCP segment
with the RST bit set.</t>

</section>
<section anchor="priority" title="Prioritization">

<t>The purpose of prioritization is to allow a client to express how it would
prefer the server to allocate resources when managing concurrent streams.  Most
importantly, priority can be used to select streams for transmitting frames when
there is limited capacity for sending.</t>

<t>HTTP/3 uses a priority scheme similar to that described in <xref target="RFC7540"/>, Section
5.3. In this priority scheme, a given element can be designated as dependent
upon another element.  Each dependency is assigned a relative weight, a number
that is used to determine the relative proportion of available resources that
are assigned to streams dependent on the same stream. This information is
expressed in the PRIORITY frame <xref target="frame-priority"/> which identifies the element
and the dependency. The elements that can be prioritized are:</t>

<t><list style="symbols">
  <t>Requests, identified by the ID of the request stream</t>
  <t>Pushes, identified by the Push ID of the promised resource
(<xref target="frame-push-promise"/>)</t>
  <t>Placeholders, identified by a Placeholder ID</t>
</list></t>

<t>Taken together, the dependencies across all prioritized elements in a connection
form a dependency tree. An element can depend on another element or on the root
of the tree.  The tree also contains an orphan placeholder.  This placeholder
cannot be reprioritized, and no resources should be allocated to descendants of
the orphan placeholder if progress can be made on descendants of the root.  The
structure of the dependency tree changes as PRIORITY frames modify the
dependency links between other prioritized elements.</t>

<t>An exclusive flag allows for the insertion of a new level of dependencies.  The
exclusive flag causes the prioritized element to become the sole dependency of
its parent, causing other dependencies to become dependent on the exclusive
element.</t>

<t>All dependent streams are allocated an integer weight between 1 and 256
(inclusive), derived by adding one to the weight expressed in the PRIORITY
frame.</t>

<t>Streams with the same parent SHOULD be allocated resources proportionally based
on their weight.  Thus, if stream B depends on stream A with weight 4, stream C
depends on stream A with weight 12, and no progress can be made on stream A,
stream B ideally receives one-third of the resources allocated to stream C.</t>

<t>A reference to an element which is no longer in the tree is treated as a
reference to the orphan placeholder. Due to reordering between streams, an
element can also be prioritized which is not yet in the tree. Such elements are
added to the tree with the requested priority.  If a prioritized element depends
on another element which is not yet in the tree, the requested parent is first
added to the tree with the default priority.</t>

<t>When a prioritized element is first created, it has a default initial weight of
16 and a default dependency. Requests and placeholders are dependent on the
orphan placeholder; pushes are dependent on the client request on which the
PUSH_PROMISE frame was sent.</t>

<t>Priorities can be updated by sending a PRIORITY frame (see <xref target="frame-priority"/>)
on the control stream.</t>

<section anchor="placeholders" title="Placeholders">

<t>In HTTP/2, certain implementations used closed or unused streams as placeholders
in describing the relative priority of requests.  This created
confusion as servers could not reliably identify which elements of the priority
tree could be discarded safely. Clients could potentially reference closed
streams long after the server had discarded state, leading to disparate views of
the prioritization the client had attempted to express.</t>

<t>In HTTP/3, a number of placeholders are explicitly permitted by the server using
the <spanx style="verb">SETTINGS_NUM_PLACEHOLDERS</spanx> setting. Because the server commits to
maintaining these placeholders in the prioritization tree, clients can use them
with confidence that the server will not have discarded the state. Clients MUST
NOT send the <spanx style="verb">SETTINGS_NUM_PLACEHOLDERS</spanx> setting; receipt of this setting by a
server MUST be treated as a connection error of type
<spanx style="verb">HTTP_SETTINGS_ERROR</spanx>.</t>

<t>Client-controlled placeholders are identified by an ID between zero and one less
than the number of placeholders the server has permitted.  The orphan
placeholder cannot be prioritized or referenced by the client.</t>

<t>Like streams, client-controlled placeholders have priority information
associated with them.</t>

</section>
<section anchor="priority-tree-maintenance" title="Priority Tree Maintenance">

<t>Because placeholders will be used to “root” any persistent structure of the tree
which the client cares about retaining, servers can aggressively prune inactive
regions from the priority tree. For prioritization purposes, a node in the tree
is considered “inactive” when the corresponding stream has been closed for at
least two round-trip times (using any reasonable estimate available on the
server).  This delay helps mitigate race conditions where the server has pruned
a node the client believed was still active and used as a Stream Dependency.</t>

<t>Specifically, the server MAY at any time:</t>

<t><list style="symbols">
  <t>Identify and discard branches of the tree containing only inactive nodes
(i.e. a node with only other inactive nodes as descendants, along with those
descendants)</t>
  <t>Identify and condense interior regions of the tree containing only inactive
nodes, allocating weight appropriately</t>
</list></t>

<figure title="Example of Priority Tree Pruning" anchor="fig-pruning"><artwork type="drawing"><![CDATA[
    x                x                 x
    |                |                 |
    P                P                 P
   / \               |                 |
  I   I     ==>      I      ==>        A
     / \             |                 |
    A   I            A                 A
    |                |
    A                A
]]></artwork></figure>

<t>In the example in <xref target="fig-pruning"/>, <spanx style="verb">P</spanx> represents a Placeholder, <spanx style="verb">A</spanx> represents
an active node, and <spanx style="verb">I</spanx> represents an inactive node.  In the first step, the
server discards two inactive branches (each a single node).  In the second step,
the server condenses an interior inactive node.  Note that these transformations
will result in no change in the resources allocated to a particular active
stream.</t>

<t>Clients SHOULD assume the server is actively performing such pruning and SHOULD
NOT declare a dependency on a stream it knows to have been closed.</t>

</section>
</section>
<section anchor="server-push" title="Server Push">

<t>Server push is an interaction mode introduced in HTTP/2 <xref target="HTTP2"/> which permits
a server to push a request-response exchange to a client in anticipation of the
client making the indicated request.  This trades off network usage against a
potential latency gain.  HTTP/3 server push is similar to what is described in
HTTP/2 <xref target="HTTP2"/>, but uses different mechanisms.</t>

<t>Each server push is identified by a unique Push ID. This Push ID is used in a
single PUSH_PROMISE frame (see <xref target="frame-push-promise"/>) which carries the request
headers, possibly included in one or more DUPLICATE_PUSH frames (see
<xref target="frame-duplicate-push"/>), then included with the push stream which ultimately
fulfills those promises.</t>

<t>Server push is only enabled on a connection when a client sends a MAX_PUSH_ID
frame (see <xref target="frame-max-push-id"/>). A server cannot use server push until it
receives a MAX_PUSH_ID frame. A client sends additional MAX_PUSH_ID frames to
control the number of pushes that a server can promise. A server SHOULD use Push
IDs sequentially, starting at 0. A client MUST treat receipt of a push stream
with a Push ID that is greater than the maximum Push ID as a connection error of
type HTTP_ID_ERROR.</t>

<t>The header of the request message is carried by a PUSH_PROMISE frame (see
<xref target="frame-push-promise"/>) on the request stream which generated the push. This
allows the server push to be associated with a client request.  Promised
requests MUST conform to the requirements in Section 8.2 of <xref target="HTTP2"/>.</t>

<t>The same server push can be associated with additional client requests using a
DUPLICATE_PUSH frame (see <xref target="frame-duplicate-push"/>).</t>

<t>Ordering of a PUSH_PROMISE or DUPLICATE_PUSH in relation to certain parts of the
response is important. The server SHOULD send PUSH_PROMISE or DUPLICATE_PUSH
frames prior to sending HEADERS or DATA frames that reference the promised
responses.  This reduces the chance that a client requests a resource that will
be pushed by the server.</t>

<t>When a server later fulfills a promise, the server push response is conveyed on
a push stream (see <xref target="push-streams"/>). The push stream identifies the Push ID of
the promise that it fulfills, then contains a response to the promised request
using the same format described for responses in <xref target="request-response"/>.</t>

<t>Due to reordering, DUPLICATE_PUSH frames or push stream data can arrive before
the corresponding PUSH_PROMISE frame.  When a client receives a DUPLICATE_PUSH
frame for an as-yet-unknown Push ID, the request headers of the push are not
immediately available.  The client can either delay generating new requests for
content referenced following the DUPLICATE_PUSH frame until the request headers
become available, or can initiate requests for discovered resources and cancel
the requests if the requested resource is already being pushed. When a client
receives a new push stream with an as-yet-unknown Push ID, both the associated
client request and the pushed request headers are unknown.  The client can
buffer the stream data in expectation of the matching PUSH_PROMISE. The client
can use stream flow control (see section 4.1 of <xref target="QUIC-TRANSPORT"/>) to limit the
amount of data a server may commit to the pushed stream.</t>

<t>If a promised server push is not needed by the client, the client SHOULD send a
CANCEL_PUSH frame. If the push stream is already open or opens after sending the
CANCEL_PUSH frame, a QUIC STOP_SENDING frame with an error code of
HTTP_REQUEST_CANCELLED can be used. This asks the server not to transfer
additional data and indicates that it will be discarded upon receipt.</t>

</section>
</section>
<section anchor="connection-closure" title="Connection Closure">

<t>Once established, an HTTP/3 connection can be used for many requests and
responses over time until the connection is closed.  Connection closure can
happen in any of several different ways.</t>

<section anchor="idle-connections" title="Idle Connections">

<t>Each QUIC endpoint declares an idle timeout during the handshake.  If the
connection remains idle (no packets received) for longer than this duration, the
peer will assume that the connection has been closed.  HTTP/3 implementations
will need to open a new connection for new requests if the existing connection
has been idle for longer than the server’s advertised idle timeout, and SHOULD
do so if approaching the idle timeout.</t>

<t>HTTP clients are expected to request that the transport keep connections open
while there are responses outstanding for requests or server pushes, as
described in Section 19.2 of <xref target="QUIC-TRANSPORT"/>. If the client is not expecting
a response from the server, allowing an idle connection to time out is preferred
over expending effort maintaining a connection that might not be needed.  A
gateway MAY maintain connections in anticipation of need rather than incur the
latency cost of connection establishment to servers. Servers SHOULD NOT actively
keep connections open.</t>

</section>
<section anchor="connection-shutdown" title="Connection Shutdown">

<t>Even when a connection is not idle, either endpoint can decide to stop using the
connection and let the connection close gracefully.  Since clients drive request
generation, clients perform a connection shutdown by not sending additional
requests on the connection; responses and pushed responses associated to
previous requests will continue to completion.  Servers perform the same
function by communicating with clients.</t>

<t>Servers initiate the shutdown of a connection by sending a GOAWAY frame
(<xref target="frame-goaway"/>).  The GOAWAY frame indicates that client-initiated requests
on lower stream IDs were or might be processed in this connection, while
requests on the indicated stream ID and greater were rejected. This enables
client and server to agree on which requests were accepted prior to the
connection shutdown.  This identifier MAY be zero if no requests were
processed.  Servers SHOULD NOT increase the QUIC MAX_STREAMS limit after
sending a GOAWAY frame.</t>

<t>Clients MUST NOT send new requests on the connection after receiving GOAWAY;
a new connection MAY be established to send additional requests.</t>

<t>Some requests might already be in transit. If the client has already sent
requests on streams with a Stream ID greater than or equal to that indicated in
the GOAWAY frame, those requests will not be processed and MAY be retried by the
client on a different connection.  The client MAY cancel these requests.  It is
RECOMMENDED that the server explicitly reject such requests (see
<xref target="request-cancellation"/>) in order to clean up transport state for the affected
streams.</t>

<t>Requests on Stream IDs less than the Stream ID in the GOAWAY frame might have
been processed; their status cannot be known until a response is received, the
stream is reset individually, or the connection terminates.  Servers MAY reject
individual requests on streams below the indicated ID if these requests were not
processed.</t>

<t>Servers SHOULD send a GOAWAY frame when the closing of a connection is known
in advance, even if the advance notice is small, so that the remote peer can
know whether a request has been partially processed or not.  For example, if an
HTTP client sends a POST at the same time that a server closes a QUIC
connection, the client cannot know if the server started to process that POST
request if the server does not send a GOAWAY frame to indicate what streams it
might have acted on.</t>

<t>A client that is unable to retry requests loses all requests that are in flight
when the server closes the connection.  A server MAY send multiple GOAWAY frames
indicating different stream IDs, but MUST NOT increase the value they send in
the last Stream ID, since clients might already have retried unprocessed
requests on another connection.  A server that is attempting to gracefully shut
down a connection SHOULD send an initial GOAWAY frame with the last Stream ID
set to the maximum value allowed by QUIC’s MAX_STREAMS and SHOULD NOT increase
the MAX_STREAMS limit thereafter.  This signals to the client that a shutdown is
imminent and that initiating further requests is prohibited.  After allowing
time for any in-flight requests (at least one round-trip time), the server MAY
send another GOAWAY frame with an updated last Stream ID.  This ensures that a
connection can be cleanly shut down without losing requests.</t>

<t>Once all accepted requests have been processed, the server can permit the
connection to become idle, or MAY initiate an immediate closure of the
connection.  An endpoint that completes a graceful shutdown SHOULD use the
HTTP_NO_ERROR code when closing the connection.</t>

<t>If a client has consumed all available bidirectional stream IDs with requests,
the server need not send a GOAWAY frame, since the client is unable to make
further requests.</t>

</section>
<section anchor="immediate-application-closure" title="Immediate Application Closure">

<t>An HTTP/3 implementation can immediately close the QUIC connection at any time.
This results in sending a QUIC CONNECTION_CLOSE frame to the peer; the error
code in this frame indicates to the peer why the connection is being closed.
See <xref target="errors"/> for error codes which can be used when closing a connection.</t>

<t>Before closing the connection, a GOAWAY MAY be sent to allow the client to retry
some requests.  Including the GOAWAY frame in the same packet as the QUIC
CONNECTION_CLOSE frame improves the chances of the frame being received by
clients.</t>

</section>
<section anchor="transport-closure" title="Transport Closure">

<t>For various reasons, the QUIC transport could indicate to the application layer
that the connection has terminated.  This might be due to an explicit closure
by the peer, a transport-level error, or a change in network topology which
interrupts connectivity.</t>

<t>If a connection terminates without a GOAWAY frame, clients MUST assume that any
request which was sent, whether in whole or in part, might have been processed.</t>

</section>
</section>
<section anchor="stream-mapping" title="Stream Mapping and Usage">

<t>A QUIC stream provides reliable in-order delivery of bytes, but makes no
guarantees about order of delivery with regard to bytes on other streams. On the
wire, data is framed into QUIC STREAM frames, but this framing is invisible to
the HTTP framing layer. The transport layer buffers and orders received QUIC
STREAM frames, exposing the data contained within as a reliable byte stream to
the application. Although QUIC permits out-of-order delivery within a stream,
HTTP/3 does not make use of this feature.</t>

<t>QUIC streams can be either unidirectional, carrying data only from initiator to
receiver, or bidirectional.  Streams can be initiated by either the client or
the server.  For more detail on QUIC streams, see Section 2 of
<xref target="QUIC-TRANSPORT"/>.</t>

<t>When HTTP headers and data are sent over QUIC, the QUIC layer handles most of
the stream management.  HTTP does not need to do any separate multiplexing when
using QUIC - data sent over a QUIC stream always maps to a particular HTTP
transaction or connection context.</t>

<section anchor="bidirectional-streams" title="Bidirectional Streams">

<t>All client-initiated bidirectional streams are used for HTTP requests and
responses.  A bidirectional stream ensures that the response can be readily
correlated with the request. This means that the client’s first request occurs
on QUIC stream 0, with subsequent requests on stream 4, 8, and so on. In order
to permit these streams to open, an HTTP/3 client SHOULD send non-zero values
for the QUIC transport parameters <spanx style="verb">initial_max_stream_data_bidi_local</spanx>. An
HTTP/3 server SHOULD send non-zero values for the QUIC transport parameters
<spanx style="verb">initial_max_stream_data_bidi_remote</spanx> and <spanx style="verb">initial_max_bidi_streams</spanx>. It is
RECOMMENDED that <spanx style="verb">initial_max_bidi_streams</spanx> be no smaller than 100, so as to not
unnecessarily limit parallelism.</t>

<t>HTTP/3 does not use server-initiated bidirectional streams, though an extension
could define a use for these streams.  Clients MUST treat receipt of a
server-initiated bidirectional stream as a connection error of type
HTTP_STREAM_CREATION_ERROR unless such an extension has been negotiated.</t>

</section>
<section anchor="unidirectional-streams" title="Unidirectional Streams">

<t>Unidirectional streams, in either direction, are used for a range of purposes.
The purpose is indicated by a stream type, which is sent as a variable-length
integer at the start of the stream. The format and structure of data that
follows this integer is determined by the stream type.</t>

<figure title="Unidirectional Stream Header" anchor="fig-stream-header"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                        Stream Type (i)                      ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>Some stream types are reserved (<xref target="stream-grease"/>).  Two stream types are
defined in this document: control streams (<xref target="control-streams"/>) and push streams
(<xref target="push-streams"/>).  Other stream types can be defined by extensions to HTTP/3;
see <xref target="extensions"/> for more details.</t>

<t>The performance of HTTP/3 connections in the early phase of their lifetime is
sensitive to the creation and exchange of data on unidirectional streams.
Endpoints that set low values for the QUIC transport parameters
<spanx style="verb">initial_max_uni_streams</spanx> and <spanx style="verb">initial_max_stream_data_uni</spanx> will increase the
chance that the remote peer reaches the limit early and becomes blocked. In
particular, the value chosen for <spanx style="verb">initial_max_uni_streams</spanx> should consider that
remote peers may wish to exercise reserved stream behavior (<xref target="stream-grease"/>).
To avoid blocking, both clients and servers MUST allow the peer to create at
least one unidirectional stream for the HTTP control stream plus the number of
unidirectional streams required by mandatory extensions (such as QPACK) by
setting an appropriate value for the QUIC transport parameter
<spanx style="verb">initial_max_uni_streams</spanx> (three being the minimum value required for the base
HTTP/3 protocol and QPACK), and SHOULD use a value of 1,024 or greater for the
QUIC transport parameter <spanx style="verb">initial_max_stream_data_uni</spanx>.</t>

<t>Note that an endpoint is not required to grant additional credits to create more
unidirectional streams if its peer consumes all the initial credits before
creating the critical unidirectional streams. Endpoints SHOULD create the HTTP
control stream as well as the unidirectional streams required by mandatory
extensions (such as the QPACK encoder and decoder streams) first, and then
create additional streams as allowed by their peer.</t>

<t>If the stream header indicates a stream type which is not supported by the
recipient, the remainder of the stream cannot be consumed as the semantics are
unknown. Recipients of unknown stream types MAY trigger a QUIC STOP_SENDING
frame with an error code of HTTP_STREAM_CREATION_ERROR, but MUST NOT consider
such streams to be a connection error of any kind.</t>

<t>Implementations MAY send stream types before knowing whether the peer supports
them.  However, stream types which could modify the state or semantics of
existing protocol components, including QPACK or other extensions, MUST NOT be
sent until the peer is known to support them.</t>

<t>A sender can close or reset a unidirectional stream unless otherwise specified.
A receiver MUST tolerate unidirectional streams being closed or reset prior to
the reception of the unidirectional stream header.</t>

<section anchor="control-streams" title="Control Streams">

<t>A control stream is indicated by a stream type of <spanx style="verb">0x00</spanx>.  Data on this stream
consists of HTTP/3 frames, as defined in <xref target="frames"/>.</t>

<t>Each side MUST initiate a single control stream at the beginning of the
connection and send its SETTINGS frame as the first frame on this stream.  If
the first frame of the control stream is any other frame type, this MUST be
treated as a connection error of type HTTP_MISSING_SETTINGS. Only one control
stream per peer is permitted; receipt of a second stream which claims to be a
control stream MUST be treated as a connection error of type
HTTP_STREAM_CREATION_ERROR.  The sender MUST NOT close the control stream, and
the receiver MUST NOT request that the sender close the control stream.  If
either control stream is closed at any point, this MUST be treated as a
connection error of type HTTP_CLOSED_CRITICAL_STREAM.</t>

<t>A pair of unidirectional streams is used rather than a single bidirectional
stream.  This allows either peer to send data as soon as it is able.  Depending
on whether 0-RTT is enabled on the connection, either client or server might be
able to send stream data first after the cryptographic handshake completes.</t>

</section>
<section anchor="push-streams" title="Push Streams">

<t>Server push is an optional feature introduced in HTTP/2 that allows a server to
initiate a response before a request has been made.  See <xref target="server-push"/> for
more details.</t>

<t>A push stream is indicated by a stream type of <spanx style="verb">0x01</spanx>, followed by the Push ID
of the promise that it fulfills, encoded as a variable-length integer. The
remaining data on this stream consists of HTTP/3 frames, as defined in
<xref target="frames"/>, and fulfills a promised server push.  Server push and Push IDs are
described in <xref target="server-push"/>.</t>

<t>Only servers can push; if a server receives a client-initiated push stream, this
MUST be treated as a connection error of type HTTP_STREAM_CREATION_ERROR.</t>

<figure title="Push Stream Header" anchor="fig-push-stream-header"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                           0x01 (i)                          ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Push ID (i)                        ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>Each Push ID MUST only be used once in a push stream header. If a push stream
header includes a Push ID that was used in another push stream header, the
client MUST treat this as a connection error of type HTTP_ID_ERROR.</t>

</section>
<section anchor="stream-grease" title="Reserved Stream Types">

<t>Stream types of the format <spanx style="verb">0x1f * N + 0x21</spanx> for integer values of N are
reserved to exercise the requirement that unknown types be ignored. These
streams have no semantics, and can be sent when application-layer padding is
desired. They MAY also be sent on connections where no data is currently being
transferred. Endpoints MUST NOT consider these streams to have any meaning upon
receipt.</t>

<t>The payload and length of the stream are selected in any manner the
implementation chooses.</t>

</section>
</section>
</section>
<section anchor="http-framing-layer" title="HTTP Framing Layer">

<t>HTTP frames are carried on QUIC streams, as described in <xref target="stream-mapping"/>.
HTTP/3 defines three stream types: control stream, request stream, and push
stream. This section describes HTTP/3 frame formats and the streams types on
which they are permitted; see <xref target="stream-frame-mapping"/> for an overview.  A
comparison between HTTP/2 and HTTP/3 frames is provided in <xref target="h2-frames"/>.</t>

<texttable title="HTTP/3 frames and stream type overview" anchor="stream-frame-mapping">
      <ttcol align='left'>Frame</ttcol>
      <ttcol align='left'>Control Stream</ttcol>
      <ttcol align='left'>Request Stream</ttcol>
      <ttcol align='left'>Push Stream</ttcol>
      <ttcol align='left'>Section</ttcol>
      <c>DATA</c>
      <c>No</c>
      <c>Yes</c>
      <c>Yes</c>
      <c><xref target="frame-data"/></c>
      <c>HEADERS</c>
      <c>No</c>
      <c>Yes</c>
      <c>Yes</c>
      <c><xref target="frame-headers"/></c>
      <c>PRIORITY</c>
      <c>Yes</c>
      <c>No</c>
      <c>No</c>
      <c><xref target="frame-priority"/></c>
      <c>CANCEL_PUSH</c>
      <c>Yes</c>
      <c>No</c>
      <c>No</c>
      <c><xref target="frame-cancel-push"/></c>
      <c>SETTINGS</c>
      <c>Yes (1)</c>
      <c>No</c>
      <c>No</c>
      <c><xref target="frame-settings"/></c>
      <c>PUSH_PROMISE</c>
      <c>No</c>
      <c>Yes</c>
      <c>No</c>
      <c><xref target="frame-push-promise"/></c>
      <c>GOAWAY</c>
      <c>Yes</c>
      <c>No</c>
      <c>No</c>
      <c><xref target="frame-goaway"/></c>
      <c>MAX_PUSH_ID</c>
      <c>Yes</c>
      <c>No</c>
      <c>No</c>
      <c><xref target="frame-max-push-id"/></c>
      <c>DUPLICATE_PUSH</c>
      <c>No</c>
      <c>Yes</c>
      <c>No</c>
      <c><xref target="frame-duplicate-push"/></c>
</texttable>

<t>Certain frames can only occur as the first frame of a particular stream type;
these are indicated in <xref target="stream-frame-mapping"/> with a (1).  Specific guidance
is provided in the relevant section.</t>

<t>Note that, unlike QUIC frames, HTTP/3 frames can span multiple packets.</t>

<section anchor="frame-layout" title="Frame Layout">

<t>All frames have the following format:</t>

<figure title="HTTP/3 frame format" anchor="fig-frame"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                           Type (i)                          ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Length (i)                         ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                       Frame Payload (*)                     ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>A frame includes the following fields:</t>

<t><list style="hanging">
  <t hangText='Type:'>
  A variable-length integer that identifies the frame type.</t>
  <t hangText='Length:'>
  A variable-length integer that describes the length of the Frame Payload.</t>
  <t hangText='Frame Payload:'>
  A payload, the semantics of which are determined by the Type field.</t>
</list></t>

<t>Each frame’s payload MUST contain exactly the fields identified in its
description.  A frame payload that contains additional bytes after the
identified fields or a frame payload that terminates before the end of the
identified fields MUST be treated as a connection error of type
HTTP_MALFORMED_FRAME.</t>

<t>When a stream terminates cleanly, if the last frame on the stream was truncated,
this MUST be treated as a connection error (<xref target="errors"/>) of type
HTTP_MALFORMED_FRAME. Streams which terminate abruptly may be reset at any point
in a frame.</t>

</section>
<section anchor="frames" title="Frame Definitions">

<section anchor="frame-data" title="DATA">

<t>DATA frames (type=0x0) convey arbitrary, variable-length sequences of bytes
associated with an HTTP request or response payload.</t>

<t>DATA frames MUST be associated with an HTTP request or response.  If a DATA
frame is received on a control stream, the recipient MUST respond with a
connection error (<xref target="errors"/>) of type HTTP_WRONG_STREAM.</t>

<figure title="DATA frame payload" anchor="fig-data"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                         Payload (*)                         ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

</section>
<section anchor="frame-headers" title="HEADERS">

<t>The HEADERS frame (type=0x1) is used to carry a header block, compressed using
QPACK. See <xref target="QPACK"></xref> for more details.</t>

<figure title="HEADERS frame payload" anchor="fig-headers"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                       Header Block (*)                      ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>HEADERS frames can only be sent on request / push streams.  If a HEADERS frame
is received on a control stream, the recipient MUST respond with a connection
error (<xref target="errors"/>) of type HTTP_WRONG_STREAM.</t>

</section>
<section anchor="frame-priority" title="PRIORITY">

<t>The PRIORITY (type=0x2) frame specifies the client-advised priority of a
request, server push or placeholder.</t>

<t>A PRIORITY frame identifies an element to prioritize, and an element upon which
it depends.  A Prioritized ID or Dependency ID identifies a client-initiated
request using the corresponding stream ID, a server push using a Push ID (see
<xref target="frame-push-promise"/>), or a placeholder using a Placeholder ID (see
<xref target="placeholders"/>).</t>

<t>In order to ensure that prioritization is processed in a consistent order,
PRIORITY frames MUST be sent on the control stream.</t>

<figure title="PRIORITY frame payload" anchor="fig-priority"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|PT |DT |X|Empty|          Prioritized Element ID (i)         ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                [Element Dependency ID (i)]                  ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|   Weight (8)  |
+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>The PRIORITY frame payload has the following fields:</t>

<t><list style="hanging">
  <t hangText='PT (Prioritized Element Type):'>
  A two-bit field indicating the type of element being prioritized (see
<xref target="priority-element-types"/>).  This MUST NOT be set to <spanx style="verb">11</spanx>.</t>
  <t hangText='DT (Element Dependency Type):'>
  A two-bit field indicating the type of element being depended on (see
<xref target="priority-element-types"/>).</t>
  <t hangText='X (Exclusive Flag):'>
  A single-bit flag indicating that the dependency is exclusive (see
<xref target="priority"/>).</t>
  <t hangText='Empty:'>
  A three-bit field which MUST be zero when sent and has no semantic value on
receipt.</t>
  <t hangText='Prioritized Element ID:'>
  A variable-length integer that identifies the element being prioritized.
Depending on the value of Prioritized Type, this contains the Stream ID of a
request stream, the Push ID of a promised resource, or a Placeholder ID of a
placeholder.</t>
  <t hangText='Element Dependency ID:'>
  A variable-length integer that identifies the element on which a dependency
is being expressed. Depending on the value of Dependency Type, this contains
the Stream ID of a request stream, the Push ID of a promised resource, the
Placeholder ID of a placeholder, or is absent.  For details of
dependencies, see <xref target="priority"/> and <xref target="HTTP2"/>, Section 5.3.</t>
  <t hangText='Weight:'>
  An unsigned 8-bit integer representing a priority weight for the prioritized
element (see <xref target="HTTP2"/>, Section 5.3). Add one to the value to obtain a
weight between 1 and 256.</t>
</list></t>

<t>The values for the Prioritized Element Type and Element Dependency Type
(<xref target="priority-element-types"/>) imply the interpretation of the associated Element
ID fields.</t>

<texttable title="Element Types of a PRIORITY frame" anchor="priority-element-types">
      <ttcol align='left'>Type Bits</ttcol>
      <ttcol align='left'>Type Description</ttcol>
      <ttcol align='left'>Element ID Contents</ttcol>
      <c>00</c>
      <c>Request stream</c>
      <c>Stream ID</c>
      <c>01</c>
      <c>Push stream</c>
      <c>Push ID</c>
      <c>10</c>
      <c>Placeholder</c>
      <c>Placeholder ID</c>
      <c>11</c>
      <c>Root of the tree</c>
      <c>Absent</c>
</texttable>

<t>Note that unlike in <xref target="HTTP2"/>, the root of the tree cannot be referenced
using a Stream ID of 0, as in QUIC stream 0 carries a valid HTTP request.  The
root of the tree cannot be reprioritized.</t>

<t>The PRIORITY frame can express relationships which might not be permitted based
on the stream on which it is sent or its position in the stream. These
situations MUST be treated as a connection error of type HTTP_MALFORMED_FRAME.
The following situations are examples of invalid PRIORITY frames:</t>

<t><list style="symbols">
  <t>A PRIORITY frame with the Prioritized Element Type set to <spanx style="verb">11</spanx>.</t>
  <t>A PRIORITY frame which claims to reference a request, but the associated ID
does not identify a client-initiated bidirectional stream</t>
</list></t>

<t>A PRIORITY frame with Empty bits not set to zero MAY be treated as a connection
error of type HTTP_MALFORMED_FRAME.</t>

<t>A PRIORITY frame that references a non-existent Push ID, a Placeholder ID
greater than the server’s limit, or a Stream ID the client is not yet permitted
to open MUST be treated as a connection error of type HTTP_ID_ERROR.</t>

<t>A PRIORITY frame received on any stream other than the control stream MUST be
treated as a connection error of type HTTP_WRONG_STREAM.</t>

<t>PRIORITY frames received by a client MUST be treated as a connection error of
type HTTP_UNEXPECTED_FRAME.</t>

</section>
<section anchor="frame-cancel-push" title="CANCEL_PUSH">

<t>The CANCEL_PUSH frame (type=0x3) is used to request cancellation of a server
push prior to the push stream being received.  The CANCEL_PUSH frame identifies
a server push by Push ID (see <xref target="frame-push-promise"/>), encoded as a
variable-length integer.</t>

<t>When a server receives this frame, it aborts sending the response for the
identified server push.  If the server has not yet started to send the server
push, it can use the receipt of a CANCEL_PUSH frame to avoid opening a push
stream.  If the push stream has been opened by the server, the server SHOULD
send a QUIC RESET_STREAM frame on that stream and cease transmission of the
response.</t>

<t>A server can send the CANCEL_PUSH frame to indicate that it will not be
fulfilling a promise prior to creation of a push stream.  Once the push stream
has been created, sending CANCEL_PUSH has no effect on the state of the push
stream.  A QUIC RESET_STREAM frame SHOULD be used instead to abort transmission
of the server push response.</t>

<t>A CANCEL_PUSH frame is sent on the control stream.  Receiving a CANCEL_PUSH
frame on a stream other than the control stream MUST be treated as a connection
error of type HTTP_WRONG_STREAM.</t>

<figure title="CANCEL_PUSH frame payload" anchor="fig-cancel-push"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Push ID (i)                        ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>The CANCEL_PUSH frame carries a Push ID encoded as a variable-length integer.
The Push ID identifies the server push that is being cancelled (see
<xref target="frame-push-promise"/>).</t>

<t>If the client receives a CANCEL_PUSH frame, that frame might identify a Push ID
that has not yet been mentioned by a PUSH_PROMISE frame.</t>

</section>
<section anchor="frame-settings" title="SETTINGS">

<t>The SETTINGS frame (type=0x4) conveys configuration parameters that affect how
endpoints communicate, such as preferences and constraints on peer behavior.
Individually, a SETTINGS parameter can also be referred to as a “setting”; the
identifier and value of each setting parameter can be referred to as a “setting
identifier” and a “setting value”.</t>

<t>SETTINGS frames always apply to a connection, never a single stream.  A SETTINGS
frame MUST be sent as the first frame of each control stream (see
<xref target="control-streams"/>) by each peer, and MUST NOT be sent subsequently. If
an endpoint receives a second SETTINGS frame on the control stream, the endpoint
MUST respond with a connection error of type HTTP_UNEXPECTED_FRAME.</t>

<t>SETTINGS frames MUST NOT be sent on any stream other than the control stream.
If an endpoint receives a SETTINGS frame on a different stream, the endpoint
MUST respond with a connection error of type HTTP_WRONG_STREAM.</t>

<t>SETTINGS parameters are not negotiated; they describe characteristics of the
sending peer, which can be used by the receiving peer. However, a negotiation
can be implied by the use of SETTINGS - each peer uses SETTINGS to advertise a
set of supported values. The definition of the setting would describe how each
peer combines the two sets to conclude which choice will be used.  SETTINGS does
not provide a mechanism to identify when the choice takes effect.</t>

<t>Different values for the same parameter can be advertised by each peer. For
example, a client might be willing to consume a very large response header,
while servers are more cautious about request size.</t>

<t>Parameters MUST NOT occur more than once in the SETTINGS frame.  A receiver MAY
treat the presence of the same parameter more than once as a connection error of
type HTTP_SETTINGS_ERROR.</t>

<t>The payload of a SETTINGS frame consists of zero or more parameters.  Each
parameter consists of a setting identifier and a value, both encoded as QUIC
variable-length integers.</t>

<figure title="SETTINGS parameter format" anchor="fig-ext-settings"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                        Identifier (i)                       ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                           Value (i)                         ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>An implementation MUST ignore the contents for any SETTINGS identifier it does
not understand.</t>

<section anchor="settings-parameters" title="Defined SETTINGS Parameters">

<t>The following settings are defined in HTTP/3:</t>

<t><list style="hanging">
  <t hangText='SETTINGS_MAX_HEADER_LIST_SIZE (0x6):'>
  The default value is unlimited.  See <xref target="header-formatting"/> for usage.</t>
  <t hangText='SETTINGS_NUM_PLACEHOLDERS (0x9):'>
  The default value is 0.  However, this value SHOULD be set to a non-zero
value by servers.  See <xref target="placeholders"/> for usage.</t>
</list></t>

<t>Setting identifiers of the format <spanx style="verb">0x1f * N + 0x21</spanx> for integer values of N are
reserved to exercise the requirement that unknown identifiers be ignored.  Such
settings have no defined meaning. Endpoints SHOULD include at least one such
setting in their SETTINGS frame. Endpoints MUST NOT consider such settings to
have any meaning upon receipt.</t>

<t>Because the setting has no defined meaning, the value of the setting can be any
value the implementation selects.</t>

<t>Additional settings can be defined by extensions to HTTP/3; see <xref target="extensions"/>
for more details.</t>

</section>
<section anchor="initialization" title="Initialization">

<t>An HTTP implementation MUST NOT send frames or requests which would be invalid
based on its current understanding of the peer’s settings.  All settings begin
at an initial value, and are updated upon receipt of a SETTINGS frame.  For
servers, the initial value of each client setting is the default value.</t>

<t>For clients using a 1-RTT QUIC connection, the initial value of each server
setting is the default value. When a 0-RTT QUIC connection is being used, the
initial value of each server setting is the value used in the previous session.
Clients MUST store the settings the server provided in the session being resumed
and MUST comply with stored settings until the current server settings are
received.  A client can use these initial values to send requests before the
server’s SETTINGS frame has arrived.  This removes the need for a client to wait
for the SETTINGS frame before sending requests.</t>

<t>A server can remember the settings that it advertised, or store an
integrity-protected copy of the values in the ticket and recover the information
when accepting 0-RTT data. A server uses the HTTP/3 settings values in
determining whether to accept 0-RTT data.</t>

<t>A server MAY accept 0-RTT and subsequently provide different settings in its
SETTINGS frame. If 0-RTT data is accepted by the server, its SETTINGS frame MUST
NOT reduce any limits or alter any values that might be violated by the client
with its 0-RTT data.  The server MAY omit settings from its SETTINGS frame which
are unchanged from the initial value.</t>

</section>
</section>
<section anchor="frame-push-promise" title="PUSH_PROMISE">

<t>The PUSH_PROMISE frame (type=0x5) is used to carry a promised request header
set from server to client on a request stream, as in HTTP/2.</t>

<figure title="PUSH_PROMISE frame payload" anchor="fig-push-promise"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Push ID (i)                        ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                       Header Block (*)                      ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>The payload consists of:</t>

<t><list style="hanging">
  <t hangText='Push ID:'>
  A variable-length integer that identifies the server push operation.  A Push
ID is used in push stream headers (<xref target="server-push"/>), CANCEL_PUSH frames
(<xref target="frame-cancel-push"/>), DUPLICATE_PUSH frames (<xref target="frame-duplicate-push"/>), and
PRIORITY frames (<xref target="frame-priority"/>).</t>
  <t hangText='Header Block:'>
  QPACK-compressed request header fields for the promised response.  See <xref target="QPACK"></xref>
for more details.</t>
</list></t>

<t>A server MUST NOT use a Push ID that is larger than the client has provided in a
MAX_PUSH_ID frame (<xref target="frame-max-push-id"/>). A client MUST treat receipt of a
PUSH_PROMISE frame that contains a larger Push ID than the client has advertised
as a connection error of HTTP_ID_ERROR.</t>

<t>A server MUST NOT use the same Push ID in multiple PUSH_PROMISE frames. A client
MUST treat receipt of a Push ID which has already been promised as a connection
error of type HTTP_ID_ERROR.</t>

<t>If a PUSH_PROMISE frame is received on the control stream, the client MUST
respond with a connection error (<xref target="errors"/>) of type HTTP_WRONG_STREAM.</t>

<t>A client MUST NOT send a PUSH_PROMISE frame.  A server MUST treat the receipt
of a PUSH_PROMISE frame as a connection error of type HTTP_UNEXPECTED_FRAME.</t>

<t>See <xref target="server-push"/> for a description of the overall server push mechanism.</t>

</section>
<section anchor="frame-goaway" title="GOAWAY">

<t>The GOAWAY frame (type=0x7) is used to initiate graceful shutdown of a
connection by a server.  GOAWAY allows a server to stop accepting new requests
while still finishing processing of previously received requests.  This enables
administrative actions, like server maintenance.  GOAWAY by itself does not
close a connection.</t>

<figure title="GOAWAY frame payload" anchor="fig-goaway"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Stream ID (i)                      ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>The GOAWAY frame is always sent on the control stream. It carries a QUIC Stream
ID for a client-initiated bidirectional stream encoded as a variable-length
integer.  A client MUST treat receipt of a GOAWAY frame containing a Stream ID
of any other type as a connection error of type HTTP_MALFORMED_FRAME.</t>

<t>Clients do not need to send GOAWAY to initiate a graceful shutdown; they simply
stop making new requests.  A server MUST treat receipt of a GOAWAY frame on any
stream as a connection error (<xref target="errors"/>) of type HTTP_UNEXPECTED_FRAME.</t>

<t>The GOAWAY frame applies to the connection, not a specific stream.  A client
MUST treat a GOAWAY frame on a stream other than the control stream as a
connection error (<xref target="errors"/>) of type HTTP_WRONG_STREAM.</t>

<t>See <xref target="connection-shutdown"/> for more information on the use of the GOAWAY frame.</t>

</section>
<section anchor="frame-max-push-id" title="MAX_PUSH_ID">

<t>The MAX_PUSH_ID frame (type=0xD) is used by clients to control the number of
server pushes that the server can initiate.  This sets the maximum value for a
Push ID that the server can use in a PUSH_PROMISE frame.  Consequently, this
also limits the number of push streams that the server can initiate in addition
to the limit set by the QUIC MAX_STREAMS frame.</t>

<t>The MAX_PUSH_ID frame is always sent on the control stream.  Receipt of a
MAX_PUSH_ID frame on any other stream MUST be treated as a connection error of
type HTTP_WRONG_STREAM.</t>

<t>A server MUST NOT send a MAX_PUSH_ID frame.  A client MUST treat the receipt of
a MAX_PUSH_ID frame as a connection error of type HTTP_UNEXPECTED_FRAME.</t>

<t>The maximum Push ID is unset when a connection is created, meaning that a server
cannot push until it receives a MAX_PUSH_ID frame.  A client that wishes to
manage the number of promised server pushes can increase the maximum Push ID by
sending MAX_PUSH_ID frames as the server fulfills or cancels server pushes.</t>

<figure title="MAX_PUSH_ID frame payload" anchor="fig-max-push"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Push ID (i)                        ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>The MAX_PUSH_ID frame carries a single variable-length integer that identifies
the maximum value for a Push ID that the server can use (see
<xref target="frame-push-promise"/>).  A MAX_PUSH_ID frame cannot reduce the maximum Push ID;
receipt of a MAX_PUSH_ID that contains a smaller value than previously received
MUST be treated as a connection error of type HTTP_ID_ERROR.</t>

</section>
<section anchor="frame-duplicate-push" title="DUPLICATE_PUSH">

<t>The DUPLICATE_PUSH frame (type=0xE) is used by servers to indicate that an
existing pushed resource is related to multiple client requests.</t>

<t>The DUPLICATE_PUSH frame is always sent on a request stream.  Receipt of a
DUPLICATE_PUSH frame on any other stream MUST be treated as a connection error
of type HTTP_WRONG_STREAM.</t>

<t>A client MUST NOT send a DUPLICATE_PUSH frame.  A server MUST treat the receipt
of a DUPLICATE_PUSH frame as a connection error of type HTTP_UNEXPECTED_FRAME.</t>

<figure title="DUPLICATE_PUSH frame payload" anchor="fig-duplicate-push"><artwork type="drawing"><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|                          Push ID (i)                        ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>The DUPLICATE_PUSH frame carries a single variable-length integer that
identifies the Push ID of a resource that the server has previously promised
(see <xref target="frame-push-promise"/>), though that promise might not be received before
this frame.  A server MUST NOT use a Push ID that is larger than the client has
provided in a MAX_PUSH_ID frame (<xref target="frame-max-push-id"/>).  A client MUST treat
receipt of a DUPLICATE_PUSH that contains a larger Push ID than the client has
advertised as a connection error of type HTTP_ID_ERROR.</t>

<t>This frame allows the server to use the same server push in response to multiple
concurrent requests.  Referencing the same server push ensures that a promise
can be made in relation to every response in which server push might be needed
without duplicating request headers or pushed responses.</t>

<t>Allowing duplicate references to the same Push ID is primarily to reduce
duplication caused by concurrent requests.  A server SHOULD avoid reusing a Push
ID over a long period.  Clients are likely to consume server push responses and
not retain them for reuse over time.  Clients that see a DUPLICATE_PUSH that
uses a Push ID that they have since consumed and discarded are forced to ignore
the DUPLICATE_PUSH.</t>

</section>
<section anchor="frame-grease" title="Reserved Frame Types">

<t>Frame types of the format <spanx style="verb">0x1f * N + 0x21</spanx> for integer values of N are reserved
to exercise the requirement that unknown types be ignored (<xref target="extensions"/>).
These frames have no semantics, and can be sent when application-layer padding
is desired. They MAY also be sent on connections where no data is currently
being transferred. Endpoints MUST NOT consider these frames to have any meaning
upon receipt.</t>

<t>The payload and length of the frames are selected in any manner the
implementation chooses.</t>

</section>
</section>
</section>
<section anchor="errors" title="Error Handling">

<t>QUIC allows the application to abruptly terminate (reset) individual streams or
the entire connection when an error is encountered.  These are referred to as
“stream errors” or “connection errors” and are described in more detail in
<xref target="QUIC-TRANSPORT"/>.  An endpoint MAY choose to treat a stream error as a
connection error.</t>

<t>This section describes HTTP/3-specific error codes which can be used to express
the cause of a connection or stream error.</t>

<section anchor="http-error-codes" title="HTTP/3 Error Codes">

<t>The following error codes are defined for use in QUIC RESET_STREAM frames,
STOP_SENDING frames, and CONNECTION_CLOSE frames when using HTTP/3.</t>

<t><list style="hanging">
  <t hangText='HTTP_NO_ERROR (0x00):'>
  No error.  This is used when the connection or stream needs to be closed, but
there is no error to signal.</t>
  <t hangText='HTTP_GENERAL_PROTOCOL_ERROR (0x01):'>
  Peer violated protocol requirements in a way which doesn’t match a more
specific error code, or endpoint declines to use the more specific error code.</t>
  <t hangText='Reserved (0x02):'>
  This code is reserved and has no meaning.</t>
  <t hangText='HTTP_INTERNAL_ERROR (0x03):'>
  An internal error has occurred in the HTTP stack.</t>
  <t hangText='Reserved (0x04):'>
  This code is reserved and has no meaning.</t>
  <t hangText='HTTP_REQUEST_CANCELLED (0x05):'>
  The request or its response (including pushed response) is cancelled.</t>
  <t hangText='HTTP_INCOMPLETE_REQUEST (0x06):'>
  The client’s stream terminated without containing a fully-formed request.</t>
  <t hangText='HTTP_CONNECT_ERROR (0x07):'>
  The connection established in response to a CONNECT request was reset or
abnormally closed.</t>
  <t hangText='HTTP_EXCESSIVE_LOAD (0x08):'>
  The endpoint detected that its peer is exhibiting a behavior that might be
generating excessive load.</t>
  <t hangText='HTTP_VERSION_FALLBACK (0x09):'>
  The requested operation cannot be served over HTTP/3.  The
peer should retry over HTTP/1.1.</t>
  <t hangText='HTTP_WRONG_STREAM (0x0A):'>
  A frame was received on a stream where it is not permitted.</t>
  <t hangText='HTTP_ID_ERROR (0x0B):'>
  A Stream ID, Push ID, or Placeholder ID was used incorrectly, such as
exceeding a limit, reducing a limit, or being reused.</t>
  <t hangText='Reserved (0x0C):'>
  N/A</t>
  <t hangText='HTTP_STREAM_CREATION_ERROR (0x0D):'>
  The endpoint detected that its peer created a stream that it will not accept.</t>
  <t hangText='Reserved (0x0E):'>
  N/A</t>
  <t hangText='HTTP_CLOSED_CRITICAL_STREAM (0x0F):'>
  A stream required by the connection was closed or reset.</t>
  <t hangText='Reserved (0x0010):'>
  N/A</t>
  <t hangText='HTTP_EARLY_RESPONSE (0x0011):'>
  The remainder of the client’s request is not needed to produce a response.
For use in STOP_SENDING only.</t>
  <t hangText='HTTP_MISSING_SETTINGS (0x0012):'>
  No SETTINGS frame was received at the beginning of the control stream.</t>
  <t hangText='HTTP_UNEXPECTED_FRAME (0x0013):'>
  A frame was received which was not permitted in the current state.</t>
  <t hangText='HTTP_REQUEST_REJECTED (0x0014):'>
  A server rejected a request without performing any application processing.</t>
  <t hangText='HTTP_SETTINGS_ERROR (0x00FF):'>
  An endpoint detected an error in the payload of a SETTINGS frame: a duplicate
setting was detected, a client-only setting was sent by a server, or a
server-only setting by a client.</t>
  <t hangText='HTTP_MALFORMED_FRAME (0x01XX):'>
  An error in a specific frame type.  If the frame type is <spanx style="verb">0xfe</spanx> or less, the
type is included as the last byte of the error code.  For example, an error in
a MAX_PUSH_ID frame would be indicated with the code (0x10D).  The last byte
<spanx style="verb">0xff</spanx> is used to indicate any frame type greater than <spanx style="verb">0xfe</spanx>.</t>
</list></t>

</section>
</section>
<section anchor="extensions" title="Extensions to HTTP/3">

<t>HTTP/3 permits extension of the protocol.  Within the limitations described in
this section, protocol extensions can be used to provide additional services or
alter any aspect of the protocol.  Extensions are effective only within the
scope of a single HTTP/3 connection.</t>

<t>This applies to the protocol elements defined in this document.  This does not
affect the existing options for extending HTTP, such as defining new methods,
status codes, or header fields.</t>

<t>Extensions are permitted to use new frame types (<xref target="frames"/>), new settings
(<xref target="settings-parameters"/>), new error codes (<xref target="errors"/>), or new unidirectional
stream types (<xref target="unidirectional-streams"/>).  Registries are established for
managing these extension points: frame types (<xref target="iana-frames"/>), settings
(<xref target="iana-settings"/>), error codes (<xref target="iana-error-codes"/>), and stream types
(<xref target="iana-stream-types"/>).</t>

<t>Implementations MUST ignore unknown or unsupported values in all extensible
protocol elements.  Implementations MUST discard frames and unidirectional
streams that have unknown or unsupported types.  This means that any of these
extension points can be safely used by extensions without prior arrangement or
negotiation.</t>

<t>Extensions that could change the semantics of existing protocol components MUST
be negotiated before being used.  For example, an extension that changes the
layout of the HEADERS frame cannot be used until the peer has given a positive
signal that this is acceptable. In this case, it could also be necessary to
coordinate when the revised layout comes into effect.</t>

<t>This document doesn’t mandate a specific method for negotiating the use of an
extension but notes that a setting (<xref target="settings-parameters"/>) could be used for
that purpose.  If both peers set a value that indicates willingness to use the
extension, then the extension can be used.  If a setting is used for extension
negotiation, the default value MUST be defined in such a fashion that the
extension is disabled if the setting is omitted.</t>

</section>
<section anchor="security-considerations" title="Security Considerations">

<t>The security considerations of HTTP/3 should be comparable to those of HTTP/2
with TLS.  Note that where HTTP/2 employs PADDING frames and Padding fields in
other frames to make a connection more resistant to traffic analysis, HTTP/3 can
rely on QUIC PADDING frames or employ the reserved frame and stream types
discussed in <xref target="frame-grease"/> and <xref target="stream-grease"/>.</t>

<t>When HTTP Alternative Services is used for discovery for HTTP/3 endpoints, the
security considerations of <xref target="ALTSVC"/> also apply.</t>

<t>Several protocol elements contain nested length elements, typically in the form
of frames with an explicit length containing variable-length integers.  This
could pose a security risk to an incautious implementer.  An implementation MUST
ensure that the length of a frame exactly matches the length of the fields it
contains.</t>

<t>The use of 0-RTT with HTTP/3 creates an exposure to replay attack.  The
anti-replay mitigations in <xref target="HTTP-REPLAY"/> MUST be applied when using
HTTP/3 with 0-RTT.</t>

<t>Certain HTTP implementations use the client address for logging or
access-control purposes.  Since a QUIC client’s address might change during a
connection (and future versions might support simultaneous use of multiple
addresses), such implementations will need to either actively retrieve the
client’s current address or addresses when they are relevant or explicitly
accept that the original address might change.</t>

</section>
<section anchor="iana-considerations" title="IANA Considerations">

<section anchor="registration-of-http3-identification-string" title="Registration of HTTP/3 Identification String">

<t>This document creates a new registration for the identification of
HTTP/3 in the “Application Layer Protocol Negotiation (ALPN)
Protocol IDs” registry established in <xref target="RFC7301"/>.</t>

<t>The “h3” string identifies HTTP/3:</t>

<t><list style="hanging">
  <t hangText='Protocol:'>
  HTTP/3</t>
  <t hangText='Identification Sequence:'>
  0x68 0x33 (“h3”)</t>
  <t hangText='Specification:'>
  This document</t>
</list></t>

</section>
<section anchor="registration-of-quic-version-hint-alt-svc-parameter" title="Registration of QUIC Version Hint Alt-Svc Parameter">

<t>This document creates a new registration for version-negotiation hints in the
“Hypertext Transfer Protocol (HTTP) Alt-Svc Parameter” registry established in
<xref target="RFC7838"/>.</t>

<t><list style="hanging">
  <t hangText='Parameter:'>
  “quic”</t>
  <t hangText='Specification:'>
  This document, <xref target="alt-svc-version-hint"/></t>
</list></t>

</section>
<section anchor="iana-frames" title="Frame Types">

<t>This document establishes a registry for HTTP/3 frame type codes. The “HTTP/3
Frame Type” registry governs a 62-bit space. This space is split into three
spaces that are governed by different policies. Values between <spanx style="verb">0x00</spanx> and <spanx style="verb">0x3f</spanx>
(in hexadecimal) are assigned via the Standards Action or IESG Review policies
<xref target="RFC8126"/>. Values from <spanx style="verb">0x40</spanx> to <spanx style="verb">0x3fff</spanx> operate on the Specification
Required policy <xref target="RFC8126"/>. All other values are assigned to Private Use
<xref target="RFC8126"/>.</t>

<t>While this registry is separate from the “HTTP/2 Frame Type” registry defined in
<xref target="HTTP2"/>, it is preferable that the assignments parallel each other where the
code spaces overlap.  If an entry is present in only one registry, every effort
SHOULD be made to avoid assigning the corresponding value to an unrelated
operation.</t>

<t>New entries in this registry require the following information:</t>

<t><list style="hanging">
  <t hangText='Frame Type:'>
  A name or label for the frame type.</t>
  <t hangText='Code:'>
  The 62-bit code assigned to the frame type.</t>
  <t hangText='Specification:'>
  A reference to a specification that includes a description of the frame layout
and its semantics, including any parts of the frame that are conditionally
present.</t>
</list></t>

<t>The entries in the following table are registered by this document.</t>

<texttable>
      <ttcol align='left'>Frame Type</ttcol>
      <ttcol align='center'>Code</ttcol>
      <ttcol align='left'>Specification</ttcol>
      <c>DATA</c>
      <c>0x0</c>
      <c><xref target="frame-data"/></c>
      <c>HEADERS</c>
      <c>0x1</c>
      <c><xref target="frame-headers"/></c>
      <c>PRIORITY</c>
      <c>0x2</c>
      <c><xref target="frame-priority"/></c>
      <c>CANCEL_PUSH</c>
      <c>0x3</c>
      <c><xref target="frame-cancel-push"/></c>
      <c>SETTINGS</c>
      <c>0x4</c>
      <c><xref target="frame-settings"/></c>
      <c>PUSH_PROMISE</c>
      <c>0x5</c>
      <c><xref target="frame-push-promise"/></c>
      <c>Reserved</c>
      <c>0x6</c>
      <c>N/A</c>
      <c>GOAWAY</c>
      <c>0x7</c>
      <c><xref target="frame-goaway"/></c>
      <c>Reserved</c>
      <c>0x8</c>
      <c>N/A</c>
      <c>Reserved</c>
      <c>0x9</c>
      <c>N/A</c>
      <c>MAX_PUSH_ID</c>
      <c>0xD</c>
      <c><xref target="frame-max-push-id"/></c>
      <c>DUPLICATE_PUSH</c>
      <c>0xE</c>
      <c><xref target="frame-duplicate-push"/></c>
</texttable>

<t>Additionally, each code of the format <spanx style="verb">0x1f * N + 0x21</spanx> for integer values of N
(that is, <spanx style="verb">0x21</spanx>, <spanx style="verb">0x40</spanx>, …, through <spanx style="verb">0x3FFFFFFFFFFFFFFE</spanx>) MUST NOT be
assigned by IANA.</t>

</section>
<section anchor="iana-settings" title="Settings Parameters">

<t>This document establishes a registry for HTTP/3 settings.  The “HTTP/3 Settings”
registry governs a 62-bit space. This space is split into three spaces that are
governed by different policies. Values between <spanx style="verb">0x00</spanx> and <spanx style="verb">0x3f</spanx> (in
hexadecimal) are assigned via the Standards Action or IESG Review policies
<xref target="RFC8126"/>. Values from <spanx style="verb">0x40</spanx> to <spanx style="verb">0x3fff</spanx> operate on the Specification
Required policy <xref target="RFC8126"/>. All other values are assigned to Private Use
<xref target="RFC8126"/>.  The designated experts are the same as those for the “HTTP/2
Settings” registry defined in <xref target="HTTP2"/>.</t>

<t>While this registry is separate from the “HTTP/2 Settings” registry defined in
<xref target="HTTP2"/>, it is preferable that the assignments parallel each other.  If an
entry is present in only one registry, every effort SHOULD be made to avoid
assigning the corresponding value to an unrelated operation.</t>

<t>New registrations are advised to provide the following information:</t>

<t><list style="hanging">
  <t hangText='Name:'>
  A symbolic name for the setting.  Specifying a setting name is optional.</t>
  <t hangText='Code:'>
  The 62-bit code assigned to the setting.</t>
  <t hangText='Specification:'>
  An optional reference to a specification that describes the use of the
setting.</t>
</list></t>

<t>The entries in the following table are registered by this document.</t>

<texttable>
      <ttcol align='left'>Setting Name</ttcol>
      <ttcol align='center'>Code</ttcol>
      <ttcol align='left'>Specification</ttcol>
      <c>Reserved</c>
      <c>0x2</c>
      <c>N/A</c>
      <c>Reserved</c>
      <c>0x3</c>
      <c>N/A</c>
      <c>Reserved</c>
      <c>0x4</c>
      <c>N/A</c>
      <c>Reserved</c>
      <c>0x5</c>
      <c>N/A</c>
      <c>MAX_HEADER_LIST_SIZE</c>
      <c>0x6</c>
      <c><xref target="settings-parameters"/></c>
      <c>NUM_PLACEHOLDERS</c>
      <c>0x9</c>
      <c><xref target="settings-parameters"/></c>
</texttable>

<t>Additionally, each code of the format <spanx style="verb">0x1f * N + 0x21</spanx> for integer values of N
(that is, <spanx style="verb">0x21</spanx>, <spanx style="verb">0x40</spanx>, …, through <spanx style="verb">0x3FFFFFFFFFFFFFFE</spanx>) MUST NOT be
assigned by IANA.</t>

</section>
<section anchor="iana-error-codes" title="Error Codes">

<t>This document establishes a registry for HTTP/3 error codes. The “HTTP/3 Error
Code” registry manages a 62-bit space.  The “HTTP/3 Error Code” registry
operates under the “Expert Review” policy <xref target="RFC8126"/>.</t>

<t>Registrations for error codes are required to include a description
of the error code.  An expert reviewer is advised to examine new
registrations for possible duplication with existing error codes.
Use of existing registrations is to be encouraged, but not mandated.</t>

<t>New registrations are advised to provide the following information:</t>

<t><list style="hanging">
  <t hangText='Name:'>
  A name for the error code.  Specifying an error code name is optional.</t>
  <t hangText='Code:'>
  The 62-bit error code value.</t>
  <t hangText='Description:'>
  A brief description of the error code semantics, longer if no detailed
specification is provided.</t>
  <t hangText='Specification:'>
  An optional reference for a specification that defines the error code.</t>
</list></t>

<t>The entries in the following table are registered by this document.</t>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Code</ttcol>
      <ttcol align='left'>Description</ttcol>
      <ttcol align='left'>Specification</ttcol>
      <c>HTTP_NO_ERROR</c>
      <c>0x0000</c>
      <c>No error</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_GENERAL_PROTOCOL_ERROR</c>
      <c>0x0001</c>
      <c>General protocol error</c>
      <c><xref target="http-error-codes"/></c>
      <c>Reserved</c>
      <c>0x0002</c>
      <c>N/A</c>
      <c>N/A</c>
      <c>HTTP_INTERNAL_ERROR</c>
      <c>0x0003</c>
      <c>Internal error</c>
      <c><xref target="http-error-codes"/></c>
      <c>Reserved</c>
      <c>0x0004</c>
      <c>N/A</c>
      <c>N/A</c>
      <c>HTTP_REQUEST_CANCELLED</c>
      <c>0x0005</c>
      <c>Data no longer needed</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_INCOMPLETE_REQUEST</c>
      <c>0x0006</c>
      <c>Stream terminated early</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_CONNECT_ERROR</c>
      <c>0x0007</c>
      <c>TCP reset or error on CONNECT request</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_EXCESSIVE_LOAD</c>
      <c>0x0008</c>
      <c>Peer generating excessive load</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_VERSION_FALLBACK</c>
      <c>0x0009</c>
      <c>Retry over HTTP/1.1</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_WRONG_STREAM</c>
      <c>0x000A</c>
      <c>A frame was sent on the wrong stream</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_ID_ERROR</c>
      <c>0x000B</c>
      <c>An identifier was used incorrectly</c>
      <c><xref target="http-error-codes"/></c>
      <c>Reserved</c>
      <c>0x000C</c>
      <c>N/A</c>
      <c>N/A</c>
      <c>HTTP_STREAM_CREATION_ERROR</c>
      <c>0x000D</c>
      <c>Stream creation error</c>
      <c><xref target="http-error-codes"/></c>
      <c>Reserved</c>
      <c>0x000E</c>
      <c>N/A</c>
      <c>N/A</c>
      <c>HTTP_CLOSED_CRITICAL_STREAM</c>
      <c>0x000F</c>
      <c>Critical stream was closed</c>
      <c><xref target="http-error-codes"/></c>
      <c>Reserved</c>
      <c>0x000E</c>
      <c>N/A</c>
      <c>N/A</c>
      <c>HTTP_EARLY_RESPONSE</c>
      <c>0x0011</c>
      <c>Remainder of request not needed</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_MISSING_SETTINGS</c>
      <c>0x0012</c>
      <c>No SETTINGS frame received</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_UNEXPECTED_FRAME</c>
      <c>0x0013</c>
      <c>Frame not permitted in the current state</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_REQUEST_REJECTED</c>
      <c>0x0014</c>
      <c>Request not processed</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_MALFORMED_FRAME</c>
      <c>0x01XX</c>
      <c>Error in frame formatting</c>
      <c><xref target="http-error-codes"/></c>
      <c>HTTP_SETTINGS_ERROR</c>
      <c>0x00FF</c>
      <c>SETTINGS frame contained invalid values</c>
      <c><xref target="http-error-codes"/></c>
</texttable>

</section>
<section anchor="iana-stream-types" title="Stream Types">

<t>This document establishes a registry for HTTP/3 unidirectional stream types. The
“HTTP/3 Stream Type” registry governs a 62-bit space. This space is split into
three spaces that are governed by different policies. Values between <spanx style="verb">0x00</spanx> and
0x3f (in hexadecimal) are assigned via the Standards Action or IESG Review
policies <xref target="RFC8126"/>. Values from <spanx style="verb">0x40</spanx> to <spanx style="verb">0x3fff</spanx> operate on the
Specification Required policy <xref target="RFC8126"/>. All other values are assigned to
Private Use <xref target="RFC8126"/>.</t>

<t>New entries in this registry require the following information:</t>

<t><list style="hanging">
  <t hangText='Stream Type:'>
  A name or label for the stream type.</t>
  <t hangText='Code:'>
  The 62-bit code assigned to the stream type.</t>
  <t hangText='Specification:'>
  A reference to a specification that includes a description of the stream type,
including the layout semantics of its payload.</t>
  <t hangText='Sender:'>
  Which endpoint on a connection may initiate a stream of this type. Values are
“Client”, “Server”, or “Both”.</t>
</list></t>

<t>The entries in the following table are registered by this document.</t>

<texttable>
      <ttcol align='left'>Stream Type</ttcol>
      <ttcol align='center'>Code</ttcol>
      <ttcol align='left'>Specification</ttcol>
      <ttcol align='left'>Sender</ttcol>
      <c>Control Stream</c>
      <c>0x00</c>
      <c><xref target="control-streams"/></c>
      <c>Both</c>
      <c>Push Stream</c>
      <c>0x01</c>
      <c><xref target="server-push"/></c>
      <c>Server</c>
</texttable>

<t>Additionally, each code of the format <spanx style="verb">0x1f * N + 0x21</spanx> for integer values of N
(that is, <spanx style="verb">0x21</spanx>, <spanx style="verb">0x40</spanx>, …, through <spanx style="verb">0x3FFFFFFFFFFFFFFE</spanx>) MUST NOT be
assigned by IANA.</t>

</section>
</section>


  </middle>

  <back>

    <references title='Normative References'>

<reference anchor="QUIC-TRANSPORT" >
  <front>
    <title>QUIC: A UDP-Based Multiplexed and Secure Transport</title>
    <author initials="J." surname="Iyengar" fullname="Jana Iyengar" role="editor">
      <organization>Fastly</organization>
    </author>
    <author initials="M." surname="Thomson" fullname="Martin Thomson" role="editor">
      <organization>Mozilla</organization>
    </author>
    <date year="2019" month="July" day="08"/>
  </front>
  <seriesInfo name="Internet-Draft" value="draft-ietf-quic-transport-20"/>
</reference>
<reference anchor="QPACK" >
  <front>
    <title>QPACK: Header Compression for HTTP over QUIC</title>
    <author initials="C." surname="Krasic" fullname="Charles 'Buck' Krasic">
      <organization>Google, Inc</organization>
    </author>
    <author initials="M." surname="Bishop" fullname="Mike Bishop">
      <organization>Akamai Technologies</organization>
    </author>
    <author initials="A." surname="Frindell" fullname="Alan Frindell" role="editor">
      <organization>Facebook</organization>
    </author>
    <date year="2019" month="July" day="08"/>
  </front>
  <seriesInfo name="Internet-Draft" value="draft-ietf-quic-qpack-09"/>
</reference>




<reference  anchor="HTTP2" target='https://www.rfc-editor.org/info/rfc7540'>
<front>
<title>Hypertext Transfer Protocol Version 2 (HTTP/2)</title>
<author initials='M.' surname='Belshe' fullname='M. Belshe'><organization /></author>
<author initials='R.' surname='Peon' fullname='R. Peon'><organization /></author>
<author initials='M.' surname='Thomson' fullname='M. Thomson' role='editor'><organization /></author>
<date year='2015' month='May' />
<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 perception of latency by introducing header field compression and allowing multiple concurrent exchanges on the same connection.  It also introduces unsolicited push of representations from servers to clients.</t><t>This specification is an alternative to, but does not obsolete, the HTTP/1.1 message syntax.  HTTP's existing semantics remain unchanged.</t></abstract>
</front>
<seriesInfo name='RFC' value='7540'/>
<seriesInfo name='DOI' value='10.17487/RFC7540'/>
</reference>



<reference  anchor="RFC2119" target='https://www.rfc-editor.org/info/rfc2119'>
<front>
<title>Key words for use in RFCs to Indicate Requirement Levels</title>
<author initials='S.' surname='Bradner' fullname='S. Bradner'><organization /></author>
<date year='1997' month='March' />
<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" target='https://www.rfc-editor.org/info/rfc8174'>
<front>
<title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
<author initials='B.' surname='Leiba' fullname='B. Leiba'><organization /></author>
<date year='2017' month='May' />
<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="RFC5234" target='https://www.rfc-editor.org/info/rfc5234'>
<front>
<title>Augmented BNF for Syntax Specifications: ABNF</title>
<author initials='D.' surname='Crocker' fullname='D. Crocker' role='editor'><organization /></author>
<author initials='P.' surname='Overell' fullname='P. Overell'><organization /></author>
<date year='2008' month='January' />
<abstract><t>Internet technical specifications often need to define a formal syntax.  Over the years, a modified version of Backus-Naur Form (BNF), called Augmented BNF (ABNF), has been popular among many Internet specifications.  The current specification documents ABNF. It balances compactness and simplicity with reasonable representational power.  The differences between standard BNF and ABNF involve naming rules, repetition, alternatives, order-independence, and value ranges.  This specification also supplies additional rule definitions and encoding for a core lexical analyzer of the type common to several Internet specifications.  [STANDARDS-TRACK]</t></abstract>
</front>
<seriesInfo name='STD' value='68'/>
<seriesInfo name='RFC' value='5234'/>
<seriesInfo name='DOI' value='10.17487/RFC5234'/>
</reference>



<reference  anchor="RFC7230" target='https://www.rfc-editor.org/info/rfc7230'>
<front>
<title>Hypertext Transfer Protocol (HTTP/1.1): Message Syntax and Routing</title>
<author initials='R.' surname='Fielding' fullname='R. Fielding' role='editor'><organization /></author>
<author initials='J.' surname='Reschke' fullname='J. Reschke' role='editor'><organization /></author>
<date year='2014' month='June' />
<abstract><t>The Hypertext Transfer Protocol (HTTP) is a stateless application-level protocol for distributed, collaborative, hypertext information systems.  This document provides an overview of HTTP architecture and its associated terminology, defines the &quot;http&quot; and &quot;https&quot; Uniform Resource Identifier (URI) schemes, defines the HTTP/1.1 message syntax and parsing requirements, and describes related security concerns for implementations.</t></abstract>
</front>
<seriesInfo name='RFC' value='7230'/>
<seriesInfo name='DOI' value='10.17487/RFC7230'/>
</reference>



<reference  anchor="ALTSVC" target='https://www.rfc-editor.org/info/rfc7838'>
<front>
<title>HTTP Alternative Services</title>
<author initials='M.' surname='Nottingham' fullname='M. Nottingham'><organization /></author>
<author initials='P.' surname='McManus' fullname='P. McManus'><organization /></author>
<author initials='J.' surname='Reschke' fullname='J. Reschke'><organization /></author>
<date year='2016' month='April' />
<abstract><t>This document specifies &quot;Alternative Services&quot; for HTTP, which allow an origin's resources to be authoritatively available at a separate network location, possibly accessed with a different protocol configuration.</t></abstract>
</front>
<seriesInfo name='RFC' value='7838'/>
<seriesInfo name='DOI' value='10.17487/RFC7838'/>
</reference>



<reference  anchor="RFC6066" target='https://www.rfc-editor.org/info/rfc6066'>
<front>
<title>Transport Layer Security (TLS) Extensions: Extension Definitions</title>
<author initials='D.' surname='Eastlake 3rd' fullname='D. Eastlake 3rd'><organization /></author>
<date year='2011' month='January' />
<abstract><t>This document provides specifications for existing TLS extensions.  It is a companion document for RFC 5246, &quot;The Transport Layer Security (TLS) Protocol Version 1.2&quot;.  The extensions specified are server_name, max_fragment_length, client_certificate_url, trusted_ca_keys, truncated_hmac, and status_request.  [STANDARDS-TRACK]</t></abstract>
</front>
<seriesInfo name='RFC' value='6066'/>
<seriesInfo name='DOI' value='10.17487/RFC6066'/>
</reference>



<reference  anchor="RFC7231" target='https://www.rfc-editor.org/info/rfc7231'>
<front>
<title>Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content</title>
<author initials='R.' surname='Fielding' fullname='R. Fielding' role='editor'><organization /></author>
<author initials='J.' surname='Reschke' fullname='J. Reschke' role='editor'><organization /></author>
<date year='2014' month='June' />
<abstract><t>The Hypertext Transfer Protocol (HTTP) is a stateless \%application- level protocol for distributed, collaborative, hypertext information systems.  This document defines the semantics of HTTP/1.1 messages, as expressed by request methods, request header fields, response status codes, and response header fields, along with the payload of messages (metadata and body content) and mechanisms for content negotiation.</t></abstract>
</front>
<seriesInfo name='RFC' value='7231'/>
<seriesInfo name='DOI' value='10.17487/RFC7231'/>
</reference>



<reference  anchor="RFC0793" target='https://www.rfc-editor.org/info/rfc793'>
<front>
<title>Transmission Control Protocol</title>
<author initials='J.' surname='Postel' fullname='J. Postel'><organization /></author>
<date year='1981' month='September' />
</front>
<seriesInfo name='STD' value='7'/>
<seriesInfo name='RFC' value='793'/>
<seriesInfo name='DOI' value='10.17487/RFC0793'/>
</reference>



<reference  anchor="RFC7540" target='https://www.rfc-editor.org/info/rfc7540'>
<front>
<title>Hypertext Transfer Protocol Version 2 (HTTP/2)</title>
<author initials='M.' surname='Belshe' fullname='M. Belshe'><organization /></author>
<author initials='R.' surname='Peon' fullname='R. Peon'><organization /></author>
<author initials='M.' surname='Thomson' fullname='M. Thomson' role='editor'><organization /></author>
<date year='2015' month='May' />
<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 perception of latency by introducing header field compression and allowing multiple concurrent exchanges on the same connection.  It also introduces unsolicited push of representations from servers to clients.</t><t>This specification is an alternative to, but does not obsolete, the HTTP/1.1 message syntax.  HTTP's existing semantics remain unchanged.</t></abstract>
</front>
<seriesInfo name='RFC' value='7540'/>
<seriesInfo name='DOI' value='10.17487/RFC7540'/>
</reference>



<reference  anchor="HTTP-REPLAY" target='https://www.rfc-editor.org/info/rfc8470'>
<front>
<title>Using Early Data in HTTP</title>
<author initials='M.' surname='Thomson' fullname='M. Thomson'><organization /></author>
<author initials='M.' surname='Nottingham' fullname='M. Nottingham'><organization /></author>
<author initials='W.' surname='Tarreau' fullname='W. Tarreau'><organization /></author>
<date year='2018' month='September' />
<abstract><t>Using TLS early data creates an exposure to the possibility of a replay attack.  This document defines mechanisms that allow clients to communicate with servers about HTTP requests that are sent in early data.  Techniques are described that use these mechanisms to mitigate the risk of replay.</t></abstract>
</front>
<seriesInfo name='RFC' value='8470'/>
<seriesInfo name='DOI' value='10.17487/RFC8470'/>
</reference>



<reference  anchor="RFC7838" target='https://www.rfc-editor.org/info/rfc7838'>
<front>
<title>HTTP Alternative Services</title>
<author initials='M.' surname='Nottingham' fullname='M. Nottingham'><organization /></author>
<author initials='P.' surname='McManus' fullname='P. McManus'><organization /></author>
<author initials='J.' surname='Reschke' fullname='J. Reschke'><organization /></author>
<date year='2016' month='April' />
<abstract><t>This document specifies &quot;Alternative Services&quot; for HTTP, which allow an origin's resources to be authoritatively available at a separate network location, possibly accessed with a different protocol configuration.</t></abstract>
</front>
<seriesInfo name='RFC' value='7838'/>
<seriesInfo name='DOI' value='10.17487/RFC7838'/>
</reference>



<reference  anchor="RFC8126" target='https://www.rfc-editor.org/info/rfc8126'>
<front>
<title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
<author initials='M.' surname='Cotton' fullname='M. Cotton'><organization /></author>
<author initials='B.' surname='Leiba' fullname='B. Leiba'><organization /></author>
<author initials='T.' surname='Narten' fullname='T. Narten'><organization /></author>
<date year='2017' month='June' />
<abstract><t>Many protocols make use of points of extensibility that use constants to identify various protocol parameters.  To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper.  For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t><t>To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed.  This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t><t>This is the third edition of this document; it obsoletes RFC 5226.</t></abstract>
</front>
<seriesInfo name='BCP' value='26'/>
<seriesInfo name='RFC' value='8126'/>
<seriesInfo name='DOI' value='10.17487/RFC8126'/>
</reference>




    </references>

    <references title='Informative References'>





<reference  anchor="RFC7413" target='https://www.rfc-editor.org/info/rfc7413'>
<front>
<title>TCP Fast Open</title>
<author initials='Y.' surname='Cheng' fullname='Y. Cheng'><organization /></author>
<author initials='J.' surname='Chu' fullname='J. Chu'><organization /></author>
<author initials='S.' surname='Radhakrishnan' fullname='S. Radhakrishnan'><organization /></author>
<author initials='A.' surname='Jain' fullname='A. Jain'><organization /></author>
<date year='2014' month='December' />
<abstract><t>This document describes an experimental TCP mechanism called TCP Fast Open (TFO).  TFO allows data to be carried in the SYN and SYN-ACK packets and consumed by the receiving end during the initial connection handshake, and saves up to one full round-trip time (RTT) compared to the standard TCP, which requires a three-way handshake (3WHS) to complete before data can be exchanged.  However, TFO deviates from the standard TCP semantics, since the data in the SYN could be replayed to an application in some rare circumstances.  Applications should not use TFO unless they can tolerate this issue, as detailed in the Applicability section.</t></abstract>
</front>
<seriesInfo name='RFC' value='7413'/>
<seriesInfo name='DOI' value='10.17487/RFC7413'/>
</reference>



<reference  anchor="HPACK" target='https://www.rfc-editor.org/info/rfc7231'>
<front>
<title>Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content</title>
<author initials='R.' surname='Fielding' fullname='R. Fielding' role='editor'><organization /></author>
<author initials='J.' surname='Reschke' fullname='J. Reschke' role='editor'><organization /></author>
<date year='2014' month='June' />
<abstract><t>The Hypertext Transfer Protocol (HTTP) is a stateless \%application- level protocol for distributed, collaborative, hypertext information systems.  This document defines the semantics of HTTP/1.1 messages, as expressed by request methods, request header fields, response status codes, and response header fields, along with the payload of messages (metadata and body content) and mechanisms for content negotiation.</t></abstract>
</front>
<seriesInfo name='RFC' value='7231'/>
<seriesInfo name='DOI' value='10.17487/RFC7231'/>
</reference>



<reference  anchor="RFC6585" target='https://www.rfc-editor.org/info/rfc6585'>
<front>
<title>Additional HTTP Status Codes</title>
<author initials='M.' surname='Nottingham' fullname='M. Nottingham'><organization /></author>
<author initials='R.' surname='Fielding' fullname='R. Fielding'><organization /></author>
<date year='2012' month='April' />
<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="RFC7301" target='https://www.rfc-editor.org/info/rfc7301'>
<front>
<title>Transport Layer Security (TLS) Application-Layer Protocol Negotiation Extension</title>
<author initials='S.' surname='Friedl' fullname='S. Friedl'><organization /></author>
<author initials='A.' surname='Popov' fullname='A. Popov'><organization /></author>
<author initials='A.' surname='Langley' fullname='A. Langley'><organization /></author>
<author initials='E.' surname='Stephan' fullname='E. Stephan'><organization /></author>
<date year='2014' month='July' />
<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>




    </references>


<section anchor="h2-considerations" title="Considerations for Transitioning from HTTP/2">

<t>HTTP/3 is strongly informed by HTTP/2, and bears many similarities.  This
section describes the approach taken to design HTTP/3, points out important
differences from HTTP/2, and describes how to map HTTP/2 extensions into HTTP/3.</t>

<t>HTTP/3 begins from the premise that similarity to HTTP/2 is preferable, but not
a hard requirement.  HTTP/3 departs from HTTP/2 where QUIC differs from TCP,
either to take advantage of QUIC features (like streams) or to accommodate
important shortcomings (such as a lack of total ordering). These differences
make HTTP/3 similar to HTTP/2 in key aspects, such as the relationship of
requests and responses to streams. However, the details of the HTTP/3 design are
substantially different than HTTP/2.</t>

<t>These departures are noted in this section.</t>

<section anchor="h2-streams" title="Streams">

<t>HTTP/3 permits use of a larger number of streams (2^62-1) than HTTP/2.  The
considerations about exhaustion of stream identifier space apply, though the
space is significantly larger such that it is likely that other limits in QUIC
are reached first, such as the limit on the connection flow control window.</t>

</section>
<section anchor="h2-frames" title="HTTP Frame Types">

<t>Many framing concepts from HTTP/2 can be elided on QUIC, because the transport
deals with them. Because frames are already on a stream, they can omit the
stream number. Because frames do not block multiplexing (QUIC’s multiplexing
occurs below this layer), the support for variable-maximum-length packets can be
removed. Because stream termination is handled by QUIC, an END_STREAM flag is
not required.  This permits the removal of the Flags field from the generic
frame layout.</t>

<t>Frame payloads are largely drawn from <xref target="HTTP2"/>. However, QUIC includes many
features (e.g., flow control) which are also present in HTTP/2. In these cases,
the HTTP mapping does not re-implement them. As a result, several HTTP/2 frame
types are not required in HTTP/3. Where an HTTP/2-defined frame is no longer
used, the frame ID has been reserved in order to maximize portability between
HTTP/2 and HTTP/3 implementations. However, even equivalent frames between the
two mappings are not identical.</t>

<t>Many of the differences arise from the fact that HTTP/2 provides an absolute
ordering between frames across all streams, while QUIC provides this guarantee
on each stream only.  As a result, if a frame type makes assumptions that frames
from different streams will still be received in the order sent, HTTP/3 will
break them.</t>

<t>Some examples of feature adaptations are described below, as well as general
guidance to extension frame implementors converting an HTTP/2 extension to
HTTP/3.</t>

<section anchor="prioritization-differences" title="Prioritization Differences">

<t>HTTP/2 specifies priority assignments in PRIORITY frames and (optionally) in
HEADERS frames. Implicit in the HTTP/2 prioritization scheme is the notion of
in-order delivery of priority changes (i.e., dependency tree mutations). Since
operations on the dependency tree such as reparenting a subtree are not
commutative, both sender and receiver must apply them in the same order to
ensure that both sides have a consistent view of the stream dependency tree.</t>

<t>To achieve in-order delivery of priority changes in HTTP/3, PRIORITY frames are
sent on the control stream.  HTTP/3 permits the prioritization of requests,
pushes and placeholders that each exist in separate identifier spaces. The
HTTP/3 PRIORITY frame replaces the stream dependency field with fields that can
identify the element of interest and its dependency.</t>

</section>
<section anchor="header-compression-differences" title="Header Compression Differences">

<t>HPACK was designed with the assumption of in-order delivery. A sequence of
encoded header blocks must arrive (and be decoded) at an endpoint in the same
order in which they were encoded. This ensures that the dynamic state at the two
endpoints remains in sync.</t>

<t>Because this total ordering is not provided by QUIC, HTTP/3 uses a modified
version of HPACK, called QPACK.  QPACK uses a single unidirectional stream to
make all modifications to the dynamic table, ensuring a total order of updates.
All frames which contain encoded headers merely reference the table state at a
given time without modifying it.</t>

<t><xref target="QPACK"></xref> provides additional details.</t>

</section>
<section anchor="guidance-for-new-frame-type-definitions" title="Guidance for New Frame Type Definitions">

<t>Frame type definitions in HTTP/3 often use the QUIC variable-length integer
encoding.  In particular, Stream IDs use this encoding, which allows for a
larger range of possible values than the encoding used in HTTP/2.  Some frames
in HTTP/3 use an identifier rather than a Stream ID (e.g. Push IDs in PRIORITY
frames). Redefinition of the encoding of extension frame types might be
necessary if the encoding includes a Stream ID.</t>

<t>Because the Flags field is not present in generic HTTP/3 frames, those frames
which depend on the presence of flags need to allocate space for flags as part
of their frame payload.</t>

<t>Other than this issue, frame type HTTP/2 extensions are typically portable to
QUIC simply by replacing Stream 0 in HTTP/2 with a control stream in HTTP/3.
HTTP/3 extensions will not assume ordering, but would not be harmed by ordering,
and would be portable to HTTP/2 in the same manner.</t>

</section>
<section anchor="mapping-between-http2-and-http3-frame-types" title="Mapping Between HTTP/2 and HTTP/3 Frame Types">

<t><list style="hanging">
  <t hangText='DATA (0x0):'>
  Padding is not defined in HTTP/3 frames.  See <xref target="frame-data"/>.</t>
  <t hangText='HEADERS (0x1):'>
  The PRIORITY region of HEADERS is not defined in HTTP/3 frames. A separate
PRIORITY frame is used in all cases. Padding is not defined in HTTP/3 frames.
See <xref target="frame-headers"/>.</t>
  <t hangText='PRIORITY (0x2):'>
  As described above, the PRIORITY frame references a variety of identifiers. It
is sent as the first frame on a request streams or on the control stream. See
<xref target="frame-priority"/>.</t>
  <t hangText='RST_STREAM (0x3):'>
  RST_STREAM frames do not exist, since QUIC provides stream lifecycle
management.  The same code point is used for the CANCEL_PUSH frame
(<xref target="frame-cancel-push"/>).</t>
  <t hangText='SETTINGS (0x4):'>
  SETTINGS frames are sent only at the beginning of the connection.  See
<xref target="frame-settings"/> and <xref target="h2-settings"/>.</t>
  <t hangText='PUSH_PROMISE (0x5):'>
  The PUSH_PROMISE does not reference a stream; instead the push stream
references the PUSH_PROMISE frame using a Push ID.  See
<xref target="frame-push-promise"/>.</t>
  <t hangText='PING (0x6):'>
  PING frames do not exist, since QUIC provides equivalent functionality.</t>
  <t hangText='GOAWAY (0x7):'>
  GOAWAY is sent only from server to client and does not contain an error code.
See <xref target="frame-goaway"/>.</t>
  <t hangText='WINDOW_UPDATE (0x8):'>
  WINDOW_UPDATE frames do not exist, since QUIC provides flow control.</t>
  <t hangText='CONTINUATION (0x9):'>
  CONTINUATION frames do not exist; instead, larger HEADERS/PUSH_PROMISE
frames than HTTP/2 are permitted.</t>
</list></t>

<t>Frame types defined by extensions to HTTP/2 need to be separately registered for
HTTP/3 if still applicable.  The IDs of frames defined in <xref target="HTTP2"/> have been
reserved for simplicity.  Note that the frame type space in HTTP/3 is
substantially larger (62 bits versus 8 bits), so many HTTP/3 frame types have no
equivalent HTTP/2 code points.  See <xref target="iana-frames"/>.</t>

</section>
</section>
<section anchor="h2-settings" title="HTTP/2 SETTINGS Parameters">

<t>An important difference from HTTP/2 is that settings are sent once, at the
beginning of the connection, and thereafter cannot change.  This eliminates
many corner cases around synchronization of changes.</t>

<t>Some transport-level options that HTTP/2 specifies via the SETTINGS frame are
superseded by QUIC transport parameters in HTTP/3. The HTTP-level options that
are retained in HTTP/3 have the same value as in HTTP/2.</t>

<t>Below is a listing of how each HTTP/2 SETTINGS parameter is mapped:</t>

<t><list style="hanging">
  <t hangText='SETTINGS_HEADER_TABLE_SIZE:'>
  See <xref target="QPACK"></xref>.</t>
  <t hangText='SETTINGS_ENABLE_PUSH:'>
  This is removed in favor of the MAX_PUSH_ID which provides a more granular
control over server push.</t>
  <t hangText='SETTINGS_MAX_CONCURRENT_STREAMS:'>
  QUIC controls the largest open Stream ID as part of its flow control logic.
Specifying SETTINGS_MAX_CONCURRENT_STREAMS in the SETTINGS frame is an error.</t>
  <t hangText='SETTINGS_INITIAL_WINDOW_SIZE:'>
  QUIC requires both stream and connection flow control window sizes to be
specified in the initial transport handshake.  Specifying
SETTINGS_INITIAL_WINDOW_SIZE in the SETTINGS frame is an error.</t>
  <t hangText='SETTINGS_MAX_FRAME_SIZE:'>
  This setting has no equivalent in HTTP/3.  Specifying it in the SETTINGS frame
is an error.</t>
  <t hangText='SETTINGS_MAX_HEADER_LIST_SIZE:'>
  See <xref target="settings-parameters"/>.</t>
</list></t>

<t>In HTTP/3, setting values are variable-length integers (6, 14, 30, or 62 bits
long) rather than fixed-length 32-bit fields as in HTTP/2.  This will often
produce a shorter encoding, but can produce a longer encoding for settings which
use the full 32-bit space.  Settings ported from HTTP/2 might choose to redefine
the format of their settings to avoid using the 62-bit encoding.</t>

<t>Settings need to be defined separately for HTTP/2 and HTTP/3. The IDs of
settings defined in <xref target="HTTP2"/> have been reserved for simplicity.  Note that
the settings identifier space in HTTP/3 is substantially larger (62 bits versus
16 bits), so many HTTP/3 settings have no equivalent HTTP/2 code point. See
<xref target="iana-settings"/>.</t>

</section>
<section anchor="http2-error-codes" title="HTTP/2 Error Codes">

<t>QUIC has the same concepts of “stream” and “connection” errors that HTTP/2
provides. However, there is no direct portability of HTTP/2 error codes.</t>

<t>The HTTP/2 error codes defined in Section 7 of <xref target="HTTP2"/> map to the HTTP/3
error codes as follows:</t>

<t><list style="hanging">
  <t hangText='NO_ERROR (0x0):'>
  HTTP_NO_ERROR in <xref target="http-error-codes"/>.</t>
  <t hangText='PROTOCOL_ERROR (0x1):'>
  This is mapped to HTTP_GENERAL_PROTOCOL_ERROR except in cases where more
specific error codes have been defined. This includes HTTP_MALFORMED_FRAME,
HTTP_WRONG_STREAM, HTTP_UNEXPECTED_FRAME and HTTP_CLOSED_CRITICAL_STREAM
defined in <xref target="http-error-codes"/>.</t>
  <t hangText='INTERNAL_ERROR (0x2):'>
  HTTP_INTERNAL_ERROR in <xref target="http-error-codes"/>.</t>
  <t hangText='FLOW_CONTROL_ERROR (0x3):'>
  Not applicable, since QUIC handles flow control.  Would provoke a
QUIC_FLOW_CONTROL_RECEIVED_TOO_MUCH_DATA from the QUIC layer.</t>
  <t hangText='SETTINGS_TIMEOUT (0x4):'>
  Not applicable, since no acknowledgement of SETTINGS is defined.</t>
  <t hangText='STREAM_CLOSED (0x5):'>
  Not applicable, since QUIC handles stream management.  Would provoke a
QUIC_STREAM_DATA_AFTER_TERMINATION from the QUIC layer.</t>
  <t hangText='FRAME_SIZE_ERROR (0x6):'>
  HTTP_MALFORMED_FRAME error codes defined in <xref target="http-error-codes"/>.</t>
  <t hangText='REFUSED_STREAM (0x7):'>
  HTTP_REQUEST_REJECTED (in <xref target="http-error-codes"/>) is used to indicate that a
request was not processed. Otherwise, not applicable because QUIC handles
stream management.  A STREAM_ID_ERROR at the QUIC layer is used for streams
that are improperly opened.</t>
  <t hangText='CANCEL (0x8):'>
  HTTP_REQUEST_CANCELLED in <xref target="http-error-codes"/>.</t>
  <t hangText='COMPRESSION_ERROR (0x9):'>
  Multiple error codes are defined in <xref target="QPACK"></xref>.</t>
  <t hangText='CONNECT_ERROR (0xa):'>
  HTTP_CONNECT_ERROR in <xref target="http-error-codes"/>.</t>
  <t hangText='ENHANCE_YOUR_CALM (0xb):'>
  HTTP_EXCESSIVE_LOAD in <xref target="http-error-codes"/>.</t>
  <t hangText='INADEQUATE_SECURITY (0xc):'>
  Not applicable, since QUIC is assumed to provide sufficient security on all
connections.</t>
  <t hangText='HTTP_1_1_REQUIRED (0xd):'>
  HTTP_VERSION_FALLBACK in <xref target="http-error-codes"/>.</t>
</list></t>

<t>Error codes need to be defined for HTTP/2 and HTTP/3 separately.  See
<xref target="iana-error-codes"/>.</t>

</section>
</section>
<section anchor="change-log" title="Change Log">

<t><list style='empty'>
  <t><spanx style="strong">RFC Editor’s Note:</spanx>  Please remove this section prior to publication of a
final version of this document.</t>
</list></t>

<section anchor="since-draft-ietf-quic-http-20" title="Since draft-ietf-quic-http-20">

<t><list style="symbols">
  <t>Prohibit closing the control stream (#2509, #2666)</t>
  <t>Change default priority to use an orphan node (#2502, #2690)</t>
  <t>Exclusive priorities are restored (#2754, #2781)</t>
  <t>Restrict use of frames when using CONNECT (#2229, #2702)</t>
  <t>Close and maybe reset streams if a connection error occurs for CONNECT (#2228,
#2703)</t>
  <t>Encourage provision of sufficient unidirectional streams for QPACK (#2100,
#2529, #2762)</t>
  <t>Allow extensions to use server-initiated bidirectional streams (#2711, #2773)</t>
  <t>Clarify use of maximum header list size setting (#2516, #2774)</t>
  <t>Extensive changes to error codes and conditions of their sending
  <list style="symbols">
      <t>Require connection errors for more error conditions (#2511, #2510)</t>
      <t>Updated the error codes for illegal GOAWAY frames (#2714, #2707)</t>
      <t>Specified error code for HEADERS on control stream (#2708)</t>
      <t>Specified error code for servers receiving PUSH_PROMISE (#2709)</t>
      <t>Specified error code for receiving DATA before HEADERS (#2715)</t>
      <t>Describe malformed messages and their handling (#2410, #2764)</t>
      <t>Remove HTTP_PUSH_ALREADY_IN_CACHE error (#2812, #2813)</t>
      <t>Refactor Push ID related errors (#2818, #2820)</t>
      <t>Rationalize HTTP/3 stream creation errors (#2821, #2822)</t>
    </list></t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-19" title="Since draft-ietf-quic-http-19">

<t><list style="symbols">
  <t>SETTINGS_NUM_PLACEHOLDERS is 0x9 (#2443,#2530)</t>
  <t>Non-zero bits in the Empty field of the PRIORITY frame MAY be treated as an
error (#2501)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-18" title="Since draft-ietf-quic-http-18">

<t><list style="symbols">
  <t>Resetting streams following a GOAWAY is recommended, but not required
(#2256,#2457)</t>
  <t>Use variable-length integers throughout (#2437,#2233,#2253,#2275)
  <list style="symbols">
      <t>Variable-length frame types, stream types, and settings identifiers</t>
      <t>Renumbered stream type assignments</t>
      <t>Modified associated reserved values</t>
    </list></t>
  <t>Frame layout switched from Length-Type-Value to Type-Length-Value
(#2395,#2235)</t>
  <t>Specified error code for servers receiving DUPLICATE_PUSH (#2497)</t>
  <t>Use connection error for invalid PRIORITY (#2507, #2508)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-17" title="Since draft-ietf-quic-http-17">

<t><list style="symbols">
  <t>HTTP_REQUEST_REJECTED is used to indicate a request can be retried (#2106,
#2325)</t>
  <t>Changed error code for GOAWAY on the wrong stream (#2231, #2343)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-16" title="Since draft-ietf-quic-http-16">

<t><list style="symbols">
  <t>Rename “HTTP/QUIC” to “HTTP/3” (#1973)</t>
  <t>Changes to PRIORITY frame (#1865, #2075)
  <list style="symbols">
      <t>Permitted as first frame of request streams</t>
      <t>Remove exclusive reprioritization</t>
      <t>Changes to Prioritized Element Type bits</t>
    </list></t>
  <t>Define DUPLICATE_PUSH frame to refer to another PUSH_PROMISE (#2072)</t>
  <t>Set defaults for settings, allow request before receiving SETTINGS (#1809,
#1846, #2038)</t>
  <t>Clarify message processing rules for streams that aren’t closed (#1972, #2003)</t>
  <t>Removed reservation of error code 0 and moved HTTP_NO_ERROR to this value
(#1922)</t>
  <t>Removed prohibition of zero-length DATA frames (#2098)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-15" title="Since draft-ietf-quic-http-15">

<t>Substantial editorial reorganization; no technical changes.</t>

</section>
<section anchor="since-draft-ietf-quic-http-14" title="Since draft-ietf-quic-http-14">

<t><list style="symbols">
  <t>Recommend sensible values for QUIC transport parameters (#1720,#1806)</t>
  <t>Define error for missing SETTINGS frame (#1697,#1808)</t>
  <t>Setting values are variable-length integers (#1556,#1807) and do not have
separate maximum values (#1820)</t>
  <t>Expanded discussion of connection closure (#1599,#1717,#1712)</t>
  <t>HTTP_VERSION_FALLBACK falls back to HTTP/1.1 (#1677,#1685)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-13" title="Since draft-ietf-quic-http-13">

<t><list style="symbols">
  <t>Reserved some frame types for grease (#1333, #1446)</t>
  <t>Unknown unidirectional stream types are tolerated, not errors; some reserved
for grease (#1490, #1525)</t>
  <t>Require settings to be remembered for 0-RTT, prohibit reductions (#1541,
#1641)</t>
  <t>Specify behavior for truncated requests (#1596, #1643)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-12" title="Since draft-ietf-quic-http-12">

<t><list style="symbols">
  <t>TLS SNI extension isn’t mandatory if an alternative method is used (#1459,
#1462, #1466)</t>
  <t>Removed flags from HTTP/3 frames (#1388, #1398)</t>
  <t>Reserved frame types and settings for use in preserving extensibility (#1333,
#1446)</t>
  <t>Added general error code (#1391, #1397)</t>
  <t>Unidirectional streams carry a type byte and are extensible (#910,#1359)</t>
  <t>Priority mechanism now uses explicit placeholders to enable persistent
structure in the tree (#441,#1421,#1422)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-11" title="Since draft-ietf-quic-http-11">

<t><list style="symbols">
  <t>Moved QPACK table updates and acknowledgments to dedicated streams (#1121,
#1122, #1238)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-10" title="Since draft-ietf-quic-http-10">

<t><list style="symbols">
  <t>Settings need to be remembered when attempting and accepting 0-RTT (#1157,
#1207)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-09" title="Since draft-ietf-quic-http-09">

<t><list style="symbols">
  <t>Selected QCRAM for header compression (#228, #1117)</t>
  <t>The server_name TLS extension is now mandatory (#296, #495)</t>
  <t>Specified handling of unsupported versions in Alt-Svc (#1093, #1097)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-08" title="Since draft-ietf-quic-http-08">

<t><list style="symbols">
  <t>Clarified connection coalescing rules (#940, #1024)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-07" title="Since draft-ietf-quic-http-07">

<t><list style="symbols">
  <t>Changes for integer encodings in QUIC (#595,#905)</t>
  <t>Use unidirectional streams as appropriate (#515, #240, #281, #886)</t>
  <t>Improvement to the description of GOAWAY (#604, #898)</t>
  <t>Improve description of server push usage (#947, #950, #957)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-06" title="Since draft-ietf-quic-http-06">

<t><list style="symbols">
  <t>Track changes in QUIC error code usage (#485)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-05" title="Since draft-ietf-quic-http-05">

<t><list style="symbols">
  <t>Made push ID sequential, add MAX_PUSH_ID, remove SETTINGS_ENABLE_PUSH (#709)</t>
  <t>Guidance about keep-alive and QUIC PINGs (#729)</t>
  <t>Expanded text on GOAWAY and cancellation (#757)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-04" title="Since draft-ietf-quic-http-04">

<t><list style="symbols">
  <t>Cite RFC 5234 (#404)</t>
  <t>Return to a single stream per request (#245,#557)</t>
  <t>Use separate frame type and settings registries from HTTP/2 (#81)</t>
  <t>SETTINGS_ENABLE_PUSH instead of SETTINGS_DISABLE_PUSH (#477)</t>
  <t>Restored GOAWAY (#696)</t>
  <t>Identify server push using Push ID rather than a stream ID (#702,#281)</t>
  <t>DATA frames cannot be empty (#700)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-03" title="Since draft-ietf-quic-http-03">

<t>None.</t>

</section>
<section anchor="since-draft-ietf-quic-http-02" title="Since draft-ietf-quic-http-02">

<t><list style="symbols">
  <t>Track changes in transport draft</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-01" title="Since draft-ietf-quic-http-01">

<t><list style="symbols">
  <t>SETTINGS changes (#181):
  <list style="symbols">
      <t>SETTINGS can be sent only once at the start of a connection;
no changes thereafter</t>
      <t>SETTINGS_ACK removed</t>
      <t>Settings can only occur in the SETTINGS frame a single time</t>
      <t>Boolean format updated</t>
    </list></t>
  <t>Alt-Svc parameter changed from “v” to “quic”; format updated (#229)</t>
  <t>Closing the connection control stream or any message control stream is a
fatal error (#176)</t>
  <t>HPACK Sequence counter can wrap (#173)</t>
  <t>0-RTT guidance added</t>
  <t>Guide to differences from HTTP/2 and porting HTTP/2 extensions added
(#127,#242)</t>
</list></t>

</section>
<section anchor="since-draft-ietf-quic-http-00" title="Since draft-ietf-quic-http-00">

<t><list style="symbols">
  <t>Changed “HTTP/2-over-QUIC” to “HTTP/QUIC” throughout (#11,#29)</t>
  <t>Changed from using HTTP/2 framing within Stream 3 to new framing format and
two-stream-per-request model (#71,#72,#73)</t>
  <t>Adopted SETTINGS format from draft-bishop-httpbis-extended-settings-01</t>
  <t>Reworked SETTINGS_ACK to account for indeterminate inter-stream order (#75)</t>
  <t>Described CONNECT pseudo-method (#95)</t>
  <t>Updated ALPN token and Alt-Svc guidance (#13,#87)</t>
  <t>Application-layer-defined error codes (#19,#74)</t>
</list></t>

</section>
<section anchor="since-draft-shade-quic-http2-mapping-00" title="Since draft-shade-quic-http2-mapping-00">

<t><list style="symbols">
  <t>Adopted as base for draft-ietf-quic-http</t>
  <t>Updated authors/editors list</t>
</list></t>

</section>
</section>
<section numbered="false" anchor="acknowledgements" title="Acknowledgements">

<t>The original authors of this specification were Robbie Shade and Mike Warres.</t>

<t>A substantial portion of Mike’s contribution was supported by Microsoft during
his employment there.</t>

</section>


  </back>

<!-- ##markdown-source:
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
EqgzyNG0JDKoYEy/8Od2KizvW0HJ1EPEnBjxNQq8WFIU2kj6WoPVjr5PDym5
aSkYUUc/r5aM4G5PnZ0tL/BYiqqWuq7GC6tNlsTBWGXhVJn1PXUaR6GyE+JT
NkfWUHozJhz2KkVGa3K/9easyfyHoZK7M7g7/d47D+Ludr5cP8qzQxAtaHWc
+H1+KA0kWqfDJ1YNB/87Rk2W/cyIpECgFbqn4T3w16+SSU72/09l19bbtrGE
3/0rBOshcSD28CqKDU4BH0dBDNhOK9s56JMhW7QjVBIFUY6bHpz/3vlmZi+k
qMhFACGyuMvd2dm5X87G519o0zefP99d3p59umP7j3Xb8vwcwuBzlJvzy/Hn
2xunjXcvbgU/EspvL8rZk3WHWLY1t8iNuTXPhI/Aqdev2LWKBQ0LxJ6t60uw
xbvTjzcQ8caTy/Mro+F1bdrxbHciQ3e27bj6PVd3z4FPxh9vgXLOKpO7qXf7
b+yZyLUa3u0vzKYF12eokUnwU48NqC9zVN1eNSBtw258UOOKdgD7tKdwtdlR
qgs6ODbMP2rD4pZeGlxO7GYDtypKpJBsyhghFiKn6e9JK9wPXOQBTpAZ53fH
Ec3+0jRT3tc+jWZ1sv5O06epW1Dzt/2LGV99wpLvfv98O6HVX/Bh37t5Wkl8
P6I0JMn9dosCVNdjkrzVLvlw6LrMNaqhmRlfP6PiNFtnbM3iiu2non6Yroqm
lUlE/3AG5xO5pTO3g51swB8Aw4N6h4DTKdV4Yo+avrq6GPzEobJStPeiejo6
+qX37t3k41lvPJtvq82bmqWZn9+96/V+XaC2tSpqjfhALd8PMD3f23IG3B/7
F5JR4RTz/IftyG+EFjLYZxtS5IN5uX0MUKA0YFDE4dFRgGKo3IuLU8VcbZ+G
M+FtP87CYtDrx8Ph8IQG6bZM9XXrhdfK74hp26whWq+4BwuGxzy8CDF8/Ccx
TE70NP51WzGi3kovz36cZymG5KMIQyYl6tqS/KJRkLtdAE3CKg2NY15sHsa8
2AVXwqbjW06/35ea62rM1/NWQ0RNgJXgORx/Y94R2DlmTngfpiiEILE5Bg+T
O/20Mq+4dWnWKAxl1kyXPeRlc4PcltWNo+4kPN3kGcxIbu16BSAYRTxfnggY
SFF6/G6LP0usn/G+w1TByqrrGkALioYyQSqnxkuhU7P9Gaom1RJ1eDa39dON
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
uAEA

-->

</rfc>

