<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc2629 version 1.6.5 (Ruby 3.0.3) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-quic-manageability-16" category="info" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.12.3 -->
  <front>
    <title abbrev="QUIC Manageability">Manageability of the QUIC Transport Protocol</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-quic-manageability-16"/>
    <author initials="M." surname="Kuehlewind" fullname="Mirja Kuehlewind">
      <organization>Ericsson</organization>
      <address>
        <email>mirja.kuehlewind@ericsson.com</email>
      </address>
    </author>
    <author initials="B." surname="Trammell" fullname="Brian Trammell">
      <organization>Google Switzerland GmbH</organization>
      <address>
        <postal>
          <street>Gustav-Gull-Platz 1</street>
          <city>8004 Zurich</city>
          <country>Switzerland</country>
        </postal>
        <email>ietf@trammell.ch</email>
      </address>
    </author>
    <date year="2022" month="April" day="06"/>
    <keyword>Internet-Draft</keyword>
    <abstract>
      <t>This document discusses manageability of the QUIC transport protocol, focusing
on the implications of QUIC's design and wire image on network operations
involving QUIC traffic. It is intended as a "user's manual" for the wire image,
providing guidance for network operators and equipment vendors who rely on the
use of transport-aware network functions.</t>
    </abstract>
  </front>
  <middle>
    <section anchor="introduction">
      <name>Introduction</name>
      <t>QUIC <xref target="QUIC-TRANSPORT"/> is a new transport protocol
that is encapsulated in UDP. QUIC integrates TLS
<xref target="QUIC-TLS"/> to encrypt all payload data and most control
information. QUIC version 1 was designed primarily as a transport for HTTP, with
the resulting protocol being known as HTTP/3 <xref target="QUIC-HTTP"/>.</t>
      <t>This document provides guidance for network operations that manage QUIC
traffic. This includes guidance on how to interpret and utilize information that
is exposed by QUIC to the network, requirements and assumptions of the QUIC
design with respect to network treatment, and a description of how common
network management practices will be impacted by QUIC.</t>
      <t>QUIC is an end-to-end transport protocol. No information in the protocol header,
even that which can be inspected, is mutable by the network. This is
enforced through integrity protection of the wire image <xref target="WIRE-IMAGE"/>.
Encryption of most transport-layer control signaling means that less information
is visible to the network than is the case with TCP.</t>
      <t>Integrity protection can also simplify troubleshooting at the end points as none
of the nodes on the network path can modify transport layer information.
However, it means in-network operations that depend on modification of data
(for examples, see <xref target="RFC9065"/>) are not possible without the cooperation of
a QUIC endpoint. Such cooperation might be possible with the introduction of
a proxy which authenticates as an endpoint. Proxy operations are not in scope
for this document.</t>
      <t>Network management is not a one-size-fits-all endeavour: practices considered
necessary or even mandatory within enterprise networks with certain compliance
requirements, for example, would be impermissible on other networks without
those requirements. The presence of a particular practice in this document
should therefore not be construed as a recommendation to apply it. For each
practice, this document describes what is and is not possible with the QUIC
transport protocol as defined.</t>
      <t>This document focuses solely on network management practices that observe
traffic on the wire. Replacement of troubleshooting based on observation
with active measurement techniques, for example, is therefore out of scope.
A more generalized treatment of network management operations on encrypted
transports is given in <xref target="RFC9065"/>.</t>
      <t>QUIC-specific terminology used in this document is defined
in <xref target="QUIC-TRANSPORT"/>.</t>
    </section>
    <section anchor="sec-wire-image">
      <name>Features of the QUIC Wire Image</name>
      <t>This section discusses those aspects of the QUIC transport protocol that
have an impact on the design and operation of devices that forward QUIC packets.
This section is therefore primarily considering the unencrypted part of QUIC's
wire image <xref target="WIRE-IMAGE"/>, which is defined as the information available in the
packet header in each QUIC packet, and the dynamics of that information. Since
QUIC is a versioned protocol, the wire image of the header format can also
change from version to version. However, the field that identifies the QUIC
version in some packets, and the format of the Version Negotiation Packet,
are both inspectable and invariant
<xref target="QUIC-INVARIANTS"/>.</t>
      <t>This document addresses version 1 of the QUIC protocol, whose wire image
is fully defined in <xref target="QUIC-TRANSPORT"/> and <xref target="QUIC-TLS"/>. Features of the wire
image described herein may change in future versions of the protocol, except
when specified as an invariant <xref target="QUIC-INVARIANTS"/>,
and cannot be used to identify QUIC as a protocol or
to infer the behavior of future versions of QUIC.</t>
      <section anchor="public-header">
        <name>QUIC Packet Header Structure</name>
        <t>QUIC packets may have either a long header or a short header. The first bit
of the QUIC header is the Header Form bit, and indicates which type of header
is present. The purpose of this bit is invariant across QUIC versions.</t>
        <t>The long header exposes more information. It contains a version number, as well
as source and destination connection IDs for associating packets with a QUIC
connection. The definition and location of these fields in the QUIC long header
are invariant for future versions of QUIC, although future versions of QUIC may
provide additional fields in the long header <xref target="QUIC-INVARIANTS"/>.</t>
        <t>In version 1 of QUIC, the long header is used during connection establishment
to transmit crypto handshake data, perform version negotiation, retry, and
send 0-RTT data.</t>
        <t>Short headers contain only an optional destination connection ID and the spin
bit for RTT measurement. In version 1 of QUIC, they are used after connection
establishment.</t>
        <t>The following information is exposed in QUIC packet headers in all versions of
QUIC:</t>
        <ul spacing="normal">
          <li>version number: the version number is present in the long header, and
identifies the version used for that packet. During Version
Negotiation (see <xref section="17.2.1" sectionFormat="of" target="QUIC-TRANSPORT"/> and <xref target="version"/>), the
version number field has a special value (0x00000000) that identifies the
packet as a Version Negotiation packet. QUIC
version 1 uses version 0x00000001. Operators should expect to observe
packets with other version numbers as a result of various Internet
experiments, future standards, and greasing (<xref target="RFC7801"/>). All deployed
versions are maintained in an IANA registry
(see <xref section="22.2" sectionFormat="of" target="QUIC-TRANSPORT"/>).</li>
          <li>source and destination connection ID: short and long headers carry a
destination connection ID, a variable-length field that can be used to
identify the connection associated with a QUIC packet, for load-balancing and
NAT rebinding purposes; see <xref target="sec-loadbalancing"/> and <xref target="rebinding"/>. Long
packet headers additionally carry a source connection ID. The source
connection ID corresponds to the destination connection ID the source would
like to have on packets sent to it, and is only present on long
headers. On long header packets, the length of the connection
IDs is also present; on short header packets, the length of the destination
connection ID is implicit.</li>
        </ul>
        <t>In version 1 of QUIC, the following additional information is exposed:</t>
        <ul spacing="normal">
          <li>"fixed bit": The second-most-significant bit of the first octet of most QUIC
packets of the current version is set to 1, enabling endpoints to demultiplex
with other UDP-encapsulated protocols. Even though this bit is fixed in the
version 1 specification, endpoints might use an extension that varies the bit.
Therefore, observers cannot reliably use it as an identifier for QUIC.</li>
          <li>latency spin bit: The third-most-significant bit of the first octet in the
short header for version 1. The spin bit is set by endpoints such that
tracking edge transitions can be used to passively observe end-to-end RTT. See
<xref target="spin-usage"/> for further details.</li>
          <li>header type: The long header has a 2 bit packet type field following the
Header Form and fixed bits. Header types correspond to stages of the
handshake; see <xref section="17.2" sectionFormat="of" target="QUIC-TRANSPORT"/> for details.</li>
          <li>length: The length of the remaining QUIC packet after the length field,
present on long headers. This field is used to implement coalesced packets
during the handshake (see <xref target="coalesced"/>).</li>
          <li>token: Initial packets may contain a token, a variable-length opaque value
optionally sent from client to server, used for validating the client's
address. Retry packets also contain a token, which can be used by the client
in an Initial packet on a subsequent connection attempt. The length of the
token is explicit in both cases.</li>
        </ul>
        <t>Retry (<xref section="17.2.5" sectionFormat="of" target="QUIC-TRANSPORT"/>) and Version Negotiation (<xref section="17.2.1" sectionFormat="of" target="QUIC-TRANSPORT"/>) packets are not encrypted or protected in any
way. For other kinds of packets, version 1 of QUIC cryptographically obfuscates
other information in the packet headers:</t>
        <ul spacing="normal">
          <li>packet number: All packets except Version Negotiation and
Retry packets have an associated packet number; however, this packet number
is encrypted, and therefore not of use to on-path observers. The offset of the
packet number can be decoded in long headers, while it
is implicit (depending on destination connection ID length) in short headers.
The length of the packet number is cryptographically protected.</li>
          <li>key phase: The Key Phase bit, present in short headers, specifies the keys
used to encrypt the packet to support key rotation. The Key Phase bit is
cryptographically protected.</li>
        </ul>
      </section>
      <section anchor="coalesced">
        <name>Coalesced Packets</name>
        <t>Multiple QUIC packets may be coalesced into a single UDP datagram,
with a datagram
carrying one or more long header packets followed by zero or one short header
packets. When packets are coalesced, the Length fields in the long headers are
used to separate QUIC packets; see <xref section="12.2" sectionFormat="of" target="QUIC-TRANSPORT"/>.
The Length field is variable length, and its position in the header is
also variable depending on the length of the source and destination connection
ID; see <xref section="17.2" sectionFormat="of" target="QUIC-TRANSPORT"/>.</t>
      </section>
      <section anchor="use-of-port-numbers">
        <name>Use of Port Numbers</name>
        <t>Applications that have a mapping for TCP as well as QUIC are expected to
use the same port number for both services. However, as for all other IETF
transports <xref target="RFC7605"/>, there is no guarantee that a specific application
will use a given registered port, or that a given port carries traffic belonging
to the respective registered service, especially when application layer
information is encrypted. For example, <xref target="QUIC-HTTP"/> specifies the use of the
HTTP Alternative Services mechanism <xref target="RFC7838"/> for discovery of HTTP/3
services on other ports.</t>
        <t>Further, as QUIC has a connection ID, it is also possible to maintain multiple
QUIC connections over one 5-tuple (protocol, source and destination IP address,
and source and destination port). However, if the connection ID is zero-length,
all packets of the 5-tuple likely belong to the same QUIC connection.</t>
      </section>
      <section anchor="handshake">
        <name>The QUIC Handshake</name>
        <t>New QUIC connections are established using a handshake, which is distinguishable
on the wire and contains some information that can be passively observed.</t>
        <t>To illustrate the information visible in the QUIC wire image during the
handshake, we first show the general communication pattern visible in the UDP
datagrams containing the QUIC handshake, then examine each of the datagrams in
detail.</t>
        <t>The QUIC handshake can normally be recognized on the wire through four flights
of datagrams labelled "Client Initial", "Server Initial", "Client Completion",
and "Server Completion", as illustrated in <xref target="fig-handshake"/>.</t>
        <t>A handshake starts with the client sending one or more datagrams containing
Initial packets, detailed in <xref target="fig-client-initial"/>, which elicits the
Server Initial response detailed in <xref target="fig-server-initial"/> typically containing
three types of packets: Initial packet(s) with the beginning of the server's
side of the TLS handshake, Handshake packet(s) with the rest of the server's
portion of the TLS handshake, and 1-RTT packet(s), if present.</t>
        <figure anchor="fig-handshake">
          <name>General communication pattern visible in the QUIC handshake</name>
          <artwork><![CDATA[
Client                                    Server
  |                                          |
  +----Client Initial----------------------->|
  +----(zero or more 0-RTT)----------------->|
  |                                          |
  |<-----------------------Server Initial----+
  |<--------(1-RTT encrypted data starts)----+
  |                                          |
  +----Client Completion-------------------->|
  +----(1-RTT encrypted data starts)-------->|
  |                                          |
  |<--------------------Server Completion----+
  |                                          |
]]></artwork>
        </figure>
        <t>As shown here, the client can send 0-RTT data as soon as it has sent its Client
Hello, and the server can send 1-RTT data as soon as it has sent its Server
Hello. The Client Completion flight contains at least one Handshake packet and
could also include an Initial packet. QUIC packets in separate contexts during
the handshake can be coalesced (see <xref target="coalesced"/>) in order to reduce the
number of UDP datagrams sent during the handshake.</t>
        <t>Handshake packets can arrive out-of-order without impacting the handshake as
long as the reordering was not accompanied by extensive delays that trigger a
spurious Probe Timeout ({Section 6.2 of RFC9002}).
If QUIC packets get lost or reordered, packets belonging
to the same flight might not be observed in close time succession, though
the sequence of the flights will not change, because one flight depends
upon the peer's previous flight.</t>
        <t>Datagrams that contain an Initial packet (Client Initial, Server
Initial, and some Client Completion) contain at least 1200 octets of UDP
payload. This protects against amplification attacks and verifies that the
network path meets the requirements for the minimum QUIC IP packet size;
see <xref section="14" sectionFormat="of" target="QUIC-TRANSPORT"/>. This is accomplished by either adding
PADDING frames within the Initial packet, coalescing other packets with the
Initial packet, or leaving unused payload in the UDP packet after the Initial
packet. A network path needs to be able to forward at least this size of
packet for QUIC to be used.</t>
        <t>The content of Initial packets is encrypted using Initial Secrets,
which are derived from a per-version constant and the client's
destination connection ID. That content is therefore observable by
any on-path device that knows the per-version constant and is
considered visible in this illustration.  The content of QUIC
Handshake packets is encrypted using keys established during the
initial handshake exchange, and is therefore not visible.</t>
        <t>Initial, Handshake, and 1-RTT packets belong to different cryptographic and
transport contexts. The Client Completion (<xref target="fig-init-complete"/>) and the
Server Completion (<xref target="fig-hs-complete"/>) flights conclude the Initial
and Handshake contexts, by sending final acknowledgments and
CRYPTO frames.</t>
        <figure anchor="fig-client-initial">
          <name>Example Client Initial datagram without 0-RTT</name>
          <artwork><![CDATA[
+----------------------------------------------------------+
| UDP header (source and destination UDP ports)            |
+----------------------------------------------------------+
| QUIC long header (type = Initial, Version, DCID, SCID) (Length)
+----------------------------------------------------------+  |
| QUIC CRYPTO frame header                                 |  |
+----------------------------------------------------------+  |
| | TLS Client Hello (incl. TLS SNI)                    |  |  |
+----------------------------------------------------------+  |
| QUIC PADDING frames                                      |  |
+----------------------------------------------------------+<-+
]]></artwork>
        </figure>
        <t>A Client Initial packet exposes the version, source and destination
connection IDs without encryption. The payload of the Initial
packet is protected using the Initial secret.  The complete TLS
Client Hello, including any TLS Server Name Indication (SNI)
present, is sent in one or more CRYPTO frames across one or more
QUIC Initial packets.</t>
        <figure anchor="fig-server-initial">
          <name>Coalesced Server Initial datagram pattern</name>
          <artwork><![CDATA[
+------------------------------------------------------------+
| UDP header (source and destination UDP ports)              |
+------------------------------------------------------------+
| QUIC long header (type = Initial, Version, DCID, SCID)   (Length)
+------------------------------------------------------------+  |
| QUIC CRYPTO frame header                                   |  |
+------------------------------------------------------------+  |
| TLS Server Hello                                           |  |
+------------------------------------------------------------+  |
| QUIC ACK frame (acknowledging client hello)                |  |
+------------------------------------------------------------+<-+
| QUIC long header (type = Handshake, Version, DCID, SCID) (Length)
+------------------------------------------------------------+  |
| encrypted payload (presumably CRYPTO frames)               |  |
+------------------------------------------------------------+<-+
| QUIC short header                                          |
+------------------------------------------------------------+
| 1-RTT encrypted payload                                    |
+------------------------------------------------------------+
]]></artwork>
        </figure>
        <t>The Server Initial datagram also exposes version number, source and destination
connection IDs in the clear; the payload of the Initial packet(s) is
protected using the Initial secret.</t>
        <figure anchor="fig-init-complete">
          <name>Coalesced Client Completion datagram pattern</name>
          <artwork><![CDATA[
+------------------------------------------------------------+
| UDP header (source and destination UDP ports)              |
+------------------------------------------------------------+
| QUIC long header (type = Initial, Version, DCID, SCID)   (Length)
+------------------------------------------------------------+  |
| QUIC ACK frame (acknowledging Server Initial)              |  |
+------------------------------------------------------------+<-+
| QUIC long header (type = Handshake, Version, DCID, SCID) (Length)
+------------------------------------------------------------+  |
| encrypted payload (presumably CRYPTO/ACK frames)           |  |
+------------------------------------------------------------+<-+
| QUIC short header                                          |
+------------------------------------------------------------+
| 1-RTT encrypted payload                                    |
+------------------------------------------------------------+
]]></artwork>
        </figure>
        <t>The Client Completion flight does not expose any additional information;
however, as the destination connection ID is server-selected, it usually
is not the same ID that is sent in the Client Initial. Client Completion
flights contain 1-RTT packets which indicate the handshake has completed
(see <xref target="sec-confirm"/>) on the client, and for three-way handshake RTT
estimation as in <xref target="sec-rtt"/>.</t>
        <figure anchor="fig-hs-complete">
          <name>Coalesced Server Completion datagram pattern</name>
          <artwork><![CDATA[
+------------------------------------------------------------+
| UDP header (source and destination UDP ports)              |
+------------------------------------------------------------+
| QUIC long header (type = Handshake, Version, DCID, SCID) (Length)
+------------------------------------------------------------+  |
| encrypted payload (presumably ACK frame)                   |  |
+------------------------------------------------------------+<-+
| QUIC short header                                          |
+------------------------------------------------------------+
| 1-RTT encrypted payload                                    |
+------------------------------------------------------------+
]]></artwork>
        </figure>
        <t>Similar to Client Completion, Server Completion also exposes no additional
information; observing it serves only to determine that the handshake has
completed.</t>
        <t>When the client uses 0-RTT data, the Client Initial
flight can also include one or more 0-RTT packets, as shown in
<xref target="fig-client-initial-0rtt"/>.</t>
        <figure anchor="fig-client-initial-0rtt">
          <name>Coalesced 0-RTT Client Initial datagram</name>
          <artwork><![CDATA[
+----------------------------------------------------------+
| UDP header (source and destination UDP ports)            |
+----------------------------------------------------------+
| QUIC long header (type = Initial, Version, DCID, SCID) (Length)
+----------------------------------------------------------+  |
| QUIC CRYPTO frame header                                 |  |
+----------------------------------------------------------+  |
| TLS Client Hello (incl. TLS SNI)                         |  |
+----------------------------------------------------------+<-+
| QUIC long header (type = 0-RTT, Version, DCID, SCID)   (Length)
+----------------------------------------------------------+  |
| 0-RTT encrypted payload                                  |  |
+----------------------------------------------------------+<-+
]]></artwork>
        </figure>
        <t>When a 0-RTT packet is coalesced with an Initial packet, the datagram
will be padded to 1200 byes. Additional datagrams containing only 0-RTT
packets with long headers can be sent after the client Initial packet(s),
containing more 0-RTT data. The amount of 0-RTT protected data that
can be sent in the first flight is limited by the initial congestion
window, typically to around 10 packets (see <xref section="7.2" sectionFormat="of" target="QUIC-RECOVERY"/>).</t>
      </section>
      <section anchor="wire-integrity">
        <name>Integrity Protection of the Wire Image</name>
        <t>As soon as the cryptographic context is established, all information in the QUIC
header, including exposed information, is integrity protected. Further,
information that was exposed in packets sent before the cryptographic context
was established is validated during the cryptographic handshake. Therefore,
devices on path cannot alter any information or bits in QUIC packets. Such
alterations would cause the integrity check to fail, which results in the
receiver discarding the packet. Some parts of Initial packets could be altered
by removing and re-applying the authenticated encryption without immediate
discard at the receiver. However, the cryptographic handshake validates most
fields and any modifications in those fields will result in connection
establishment failing later.</t>
      </section>
      <section anchor="rebinding">
        <name>Connection ID and Rebinding</name>
        <t>The connection ID in the QUIC packet headers allows association of QUIC
packets using information independent of the 5-tuple. This allows
rebinding of a connection after one of the endpoints - usually the
client - has experienced an address change. Further it can be used by
in-network devices to ensure that related 5-tuple flows are appropriately
balanced together.</t>
        <t>Client and server each choose a connection ID during the handshake; for
example, a server might request that a client use a connection ID, whereas the
client might choose a zero-length value. Connection IDs for either endpoint may
change during the lifetime of a connection, with the new connection ID being
supplied via encrypted frames (see <xref section="5.1" sectionFormat="of" target="QUIC-TRANSPORT"/>).
Therefore, observing a new connection ID does not necessarily indicate a new
connection.</t>
        <t><xref target="QUIC_LB"/> specifies algorithms for
encoding the server mapping in a connection ID in order to share this
information with selected on-path devices such as load balancers. Server
mappings should only be exposed to selected entities. Uncontrolled exposure
would allow linkage of multiple IP addresses to the same host if the server
also supports migration that opens an attack vector on specific servers or
pools. The best way to obscure an encoding is to appear random to any other
observers, which is most rigorously achieved with encryption. As a result,
any attempt to infer information from specific parts of a connection ID is
unlikely to be useful.</t>
      </section>
      <section anchor="packetnumber">
        <name>Packet Numbers</name>
        <t>The Packet Number field is always present in the QUIC packet header in version
1; however, it is always encrypted. The encryption key for packet number
protection on Initial packets -- which are sent before cryptographic context
establishment -- is specific to the QUIC version, while packet number protection
on subsequent packets uses secrets derived from the end-to-end cryptographic
context. Packet numbers are therefore not part of the wire image that is visible
to on-path observers.</t>
      </section>
      <section anchor="version">
        <name>Version Negotiation and Greasing</name>
        <t>Version Negotiation packets are used by the server to indicate that a requested
version from the client is not supported (see <xref section="6" sectionFormat="of" target="QUIC-TRANSPORT"/>.
Version Negotiation packets are not intrinsically protected, but future QUIC
versions could use later encrypted messages to verify that they were authentic.
Therefore, any modification of this list will be detected and may cause the
endpoints to terminate the connection attempt.</t>
        <t>Also note that the list of versions in the Version Negotiation packet may
contain reserved versions. This mechanism is used to avoid ossification in the
implementation on the selection mechanism. Further, a client may send an Initial
packet with a reserved version number to trigger version negotiation. In
the Version Negotiation packet, the connection IDs of the client's
Initial packet
are reflected to provide a proof of return-routability. Therefore, changing this
information will also cause the connection to fail.</t>
        <t>QUIC is expected to evolve rapidly, so new versions, both experimental and IETF
standard versions, will be deployed on the Internet more often than with
other commonly deployed Internet- and transport-layer protocols. Use
of the version number field for traffic recognition will therefore behave
differently than with these protocols. Using a particular version number
to recognize valid QUIC traffic is likely to persistently miss a fraction of
QUIC flows,
and completely fail in the near future. Reliance on the version number field
for the purposes of admission control is similarly likely to rapidly lead to
unintended failure modes. Admission of QUIC traffic regardless of version
avoids these failure modes, avoids unnecessary deployment delays, and
supports continuous version-based evolution.</t>
      </section>
    </section>
    <section anchor="network-visible-information-about-quic-flows">
      <name>Network-Visible Information about QUIC Flows</name>
      <t>This section addresses the different kinds of observations and inferences that
can be made about QUIC flows by a passive observer in the network based on the
wire image in <xref target="sec-wire-image"/>. Here we assume a bidirectional observer (one
that can see packets in both directions in the sequence in which they are
carried on the wire) unless noted, but typically without access to any keying
information.</t>
      <section anchor="sec-identifying">
        <name>Identifying QUIC Traffic</name>
        <t>The QUIC wire image is not specifically designed to be distinguishable
from other UDP traffic by a passive observer in the network. While certain
QUIC applications may be heuristically identifiable on a per-application
basis, there is no general method for distinguishing QUIC traffic from
otherwise-unclassifiable UDP traffic on a given link. Any unrecognized UDP
traffic may therefore be QUIC traffic.</t>
        <t>At the time of writing, two application bindings for QUIC have been published
or adopted by the IETF: HTTP/3 <xref target="QUIC-HTTP"/> and DNS over Dedicated QUIC
Connections <xref target="I-D.ietf-dprive-dnsoquic"/>. These are both known at the time
of writing to have active Internet deployments, so an assumption that all
QUIC traffic is HTTP/3 is not valid. HTTP/3 uses UDP port 443 by
convention but various methods can be used to specify alternate port numbers.
Simple assumptions about whether a given flow is using QUIC based upon a UDP
port number may therefore not hold; see also <xref section="5" sectionFormat="of" target="RFC7605"/>.</t>
        <t>While the second-most-significant bit (0x40) of the first octet is set to 1 in
most QUIC packets of the current version (see <xref target="public-header"/> and <xref section="17" sectionFormat="of" target="QUIC-TRANSPORT"/>), this method of recognizing QUIC traffic is not reliable.
First, it only provides one bit of information and is prone to collision with
UDP-based protocols other than those considered in <xref target="RFC7983"/>. Second, this
feature of the wire image is not invariant <xref target="QUIC-INVARIANTS"/> and may change in
future versions of the protocol, or even be negotiated during the handshake via
the use of an extension <xref target="QUIC-GREASE"/>.</t>
        <t>Even though transport parameters transmitted in the client's Initial packet are
observable by the network, they cannot be modified by the network without
causing connection failure. Further, the reply from the server cannot be
observed, so observers on the network cannot know which parameters are actually
in use.</t>
        <section anchor="identifying-negotiated-version">
          <name>Identifying Negotiated Version</name>
          <t>An in-network observer assuming that a set of packets belongs to a QUIC flow
might infer the version number in use by observing the handshake: for QUIC
version 1, if the version number in the Initial packet from a client is the
same as the version number in the Initial packet of the server response, that
version has been accepted by both endpoints to be used for the rest of the
connection.</t>
          <t>The negotiated version cannot be identified for flows for which a handshake is
not observed, such as in the case of connection migration; however, it might be
possible to associate a flow with a flow for which a version has been
identified; see <xref target="sec-flow-association"/>.</t>
        </section>
        <section anchor="sec-garbage">
          <name>First Packet Identification for Garbage Rejection</name>
          <t>A related question is whether the first packet of a given flow on a port known
to be associated with QUIC is a valid QUIC packet.  This determination supports
in-network filtering of garbage UDP packets (reflection attacks, random
backscatter, etc.). While heuristics based on the first byte of the packet
(packet type) could be used to separate valid from invalid first packet types,
the deployment of such heuristics is not recommended, as bits in the first byte
may have different meanings in future versions of the protocol.</t>
        </section>
      </section>
      <section anchor="sec-confirm">
        <name>Connection Confirmation</name>
        <t>This document focuses on QUIC version 1, and this Connection Confirmation
section applies only to packets belonging to QUIC version 1 flows; for purposes
of on-path observation, it assumes that these packets have been identified as
such through the observation of a version number exchange as described above.</t>
        <t>Connection establishment uses Initial and Handshake packets containing a
TLS handshake, and Retry packets that do not contain parts of the handshake.
Connection establishment can therefore be detected using heuristics similar to
those used to detect TLS over TCP. A client initiating a connection may
also send data in 0-RTT packets directly after the Initial
packet containing the TLS Client Hello. Since packets may be reordered or lost
in the network, 0-RTT packets could be seen before the Initial
packet.</t>
        <t>Note that in this version of QUIC, clients send Initial packets before servers
do, servers send Handshake packets before clients do, and only clients send
Initial packets with tokens. Therefore, an endpoint can be identified as a
client or server by an on-path observer. An attempted connection after Retry can
be detected by correlating the contents of the Retry packet with the Token and
the Destination Connection ID fields of the new Initial packet.</t>
      </section>
      <section anchor="distinguishing-acknowledgment-traffic">
        <name>Distinguishing Acknowledgment Traffic</name>
        <t>Some deployed in-network functions distinguish packets that carry only
acknowledgment (ACK-only) information
from packets carrying upper-layer data in order to attempt to enhance
performance, for example by queueing ACKs differently or manipulating ACK
signaling <xref target="RFC3449"/>. Distinguishing ACK packets is possible in TCP,
but is not supported by
QUIC, since acknowledgment signaling is carried inside QUIC's encrypted payload,
and ACK manipulation is impossible. Specifically, heuristics attempting to
distinguish ACK-only packets from payload-carrying packets based on packet size
are likely to fail, and are not recommended to use as a way to construe
internals of QUIC's operation as those mechanisms can change, e.g., due to the
use of extensions.</t>
      </section>
      <section anchor="sec-server">
        <name>Server Name Indication (SNI)</name>
        <t>The client's TLS ClientHello may contain a Server Name Indication (SNI)
<xref target="RFC6066"/> extension, by which the client reveals the name of the server it
intends to connect to, in order to allow the server to present a certificate
based on that name. It may also contain an Application-Layer Protocol
Negotiation (ALPN) <xref target="RFC7301"/> extension, by which the client exposes the names
of application-layer protocols it supports; an observer can deduce that one of
those protocols will be used if the connection continues.</t>
        <t>Work is currently underway in the TLS working group to encrypt the contents of
the ClientHello in TLS 1.3 <xref target="TLS-ECH"/>. This would make
SNI-based application identification impossible by on-path observation for QUIC
and other protocols that use TLS.</t>
        <section anchor="extracting-server-name-indication-sni-information">
          <name>Extracting Server Name Indication (SNI) Information</name>
          <t>If the ClientHello is not encrypted, SNI can be derived from the client's
Initial packet(s) by calculating the Initial secret to decrypt the packet
payload and parsing the QUIC CRYPTO frame(s) containing the TLS ClientHello.</t>
          <t>As both the derivation of the Initial secret and the structure of the Initial
packet itself are version-specific, the first step is always to parse the
version number (the second through fifth bytes of the long header). Note that
only long header packets carry the version number, so it is necessary to also
check if the first bit of the QUIC packet is set to 1, indicating a long header.</t>
          <t>Note that proprietary QUIC versions, that have been deployed before
standardization, might not set the first bit in a QUIC long header packet to
1. However, it is expected that these versions will
gradually disappear over time and therefore do not require any special
consideration or treatment.</t>
          <t>When the version has been identified as QUIC version 1, the packet type needs to
be verified as an Initial packet by checking that the third and fourth bits of
the header are both set to 0. Then the Destination Connection ID needs to be
extracted from the packet. The Initial secret is calculated using the
version-specific Initial salt, as described in <xref section="5.2" sectionFormat="of" target="QUIC-TLS"/>.
The length of the connection ID is indicated in the 6th byte of the header
followed by the connection ID itself.</t>
          <t>Note that subsequent Initial packets might contain a Destination Connection ID
other than the one used to generate the Initial secret. Therefore, attempts to
decrypt these packets using the procedure above might fail unless the Initial
secret is retained by the observer.</t>
          <t>To determine the end of the packet header and find the start of the payload,
the packet number length, the source connection ID length, and the token length
need to be extracted. The packet number length is defined by the seventh and
eight bits of the header as described in <xref section="17.2" sectionFormat="of" target="QUIC-TRANSPORT"/>,
but is protected as described in <xref section="5.4" sectionFormat="of" target="QUIC-TLS"/>. The source
connection ID length is specified in the byte after the destination
connection ID. The token length, which follows the source connection ID, is
a variable-length integer as specified in <xref section="16" sectionFormat="of" target="QUIC-TRANSPORT"/>.</t>
          <t>After decryption, the client's Initial packet(s) can be parsed to detect the
CRYPTO frame(s) that contains the TLS ClientHello, which then can be parsed
similarly to TLS over TCP connections. Note that there can be multiple CRYPTO
frames spread out over one or more Initial packets, and they might not be in
order, so reassembling the CRYPTO stream by parsing offsets and lengths is
required. Further, the client's Initial packet(s) may contain other frames,
so the first bytes of each frame need to be checked to identify the frame
type and determine whether the frame can be skipped over. Note that the
length of the frames is dependent on the frame type; see
<xref section="18" sectionFormat="of" target="QUIC-TRANSPORT"/>.
E.g., PADDING frames, each consisting of a single zero byte, may occur before,
after, or between CRYPTO frames. However, extensions might define additional
frame types. If an unknown frame type is encountered, it is impossible to
know the length of that frame which prevents skipping over it, and therefore
parsing fails.</t>
        </section>
      </section>
      <section anchor="sec-flow-association">
        <name>Flow Association</name>
        <t>The QUIC connection ID (see <xref target="rebinding"/>) is designed to allow a coordinating
on-path device, such as a load-balancer, to associate two flows when one of the
endpoints changes address.  This change can be due to NAT rebinding or address
migration.</t>
        <t>The connection ID must change upon intentional address change by an endpoint,
and connection ID negotiation is encrypted, so it is not possible for a
passive observer to link intended changes of address using the connection ID.</t>
        <t>When one endpoint's address unintentionally changes, as is the case with NAT
rebinding, an on-path observer may be able to use the connection ID to
associate the flow on the new address with the flow on the old address.</t>
        <t>A network function that attempts to use the connection ID to associate flows
must be robust to the failure of this technique. Since the connection ID may
change multiple times during the lifetime of a connection, packets with the
same 5-tuple but different connection IDs might or might not belong to
the same connection. Likewise, packets with the same connection ID but
different 5-tuples might not belong to the same connection, either.</t>
        <t>Connection IDs should be treated as opaque; see <xref target="sec-loadbalancing"/>
for caveats regarding connection ID selection at servers.</t>
      </section>
      <section anchor="sec-teardown">
        <name>Flow Teardown</name>
        <t>QUIC does not expose the end of a connection; the only indication to on-path
devices that a flow has ended is that packets are no longer observed. Stateful
devices on path such as NATs and firewalls must therefore use idle timeouts to
determine when to drop state for QUIC flows; see <xref target="sec-stateful"/>.</t>
      </section>
      <section anchor="sec-symmetry">
        <name>Flow Symmetry Measurement</name>
        <t>QUIC explicitly exposes which side of a connection is a client and which side is
a server during the handshake. In addition, the symmetry of a flow (whether
primarily client-to-server, primarily server-to-client, or roughly
bidirectional, as input to basic traffic classification techniques) can be
inferred through the measurement of data rate in each direction.
Note that QUIC packets containing only control frames (such as
ACK-only packets) may be padded. Padding, though optional,
may conceal connection roles or flow symmetry information.</t>
      </section>
      <section anchor="sec-rtt">
        <name>Round-Trip Time (RTT) Measurement</name>
        <t>The round-trip time (RTT) of QUIC flows can be inferred
by observation once per flow,
during the handshake, as in passive TCP measurement; this requires parsing of
the QUIC packet header and recognition of the handshake, as illustrated in
<xref target="handshake"/>. It can also be inferred during the flow's lifetime, if the
endpoints use the spin bit facility described below and in <xref section="17.3.1" sectionFormat="of" target="QUIC-TRANSPORT"/>.</t>
        <section anchor="measuring-initial-rtt">
          <name>Measuring Initial RTT</name>
          <t>In the common case, the delay between the client's Initial packet (containing
the TLS ClientHello) and the server's Initial packet (containing the TLS
ServerHello) represents the RTT component on the path between the observer and
the server. The delay between the server's first Handshake packet and the
Handshake packet sent by the client represents the RTT component on the path
between the observer and the client. While the client may send 0-RTT packets
after the Initial packet during connection re-establishment, these can be
ignored for RTT measurement purposes.</t>
          <t>Handshake RTT can be measured by adding the client-to-observer and
observer-to-server RTT components together. This measurement necessarily
includes all transport- and application-layer delay at both endpoints.</t>
        </section>
        <section anchor="spin-usage">
          <name>Using the Spin Bit for Passive RTT Measurement</name>
          <t>The spin bit provides a version-specific method to measure per-flow RTT from
observation points on the network path throughout the duration of a connection.
See <xref section="17.4" sectionFormat="of" target="QUIC-TRANSPORT"/> for the definition of the spin bit in
Version 1 of QUIC. Endpoint participation in spin bit signaling is optional.
That is, while its location is fixed in this version of QUIC, an endpoint can
unilaterally choose to not support "spinning" the bit.</t>
          <t>Use of the spin bit for RTT measurement by devices on path is only possible when
both endpoints enable it. Some endpoints may disable use of the spin bit by
default, others only in specific deployment scenarios, e.g., for servers and
clients where the RTT would reveal the presence of a VPN or proxy. To avoid
making these connections identifiable based on the usage of the spin bit, all
endpoints randomly disable "spinning" for at least one eighth of connections,
even if otherwise enabled by default. An endpoint not participating in spin bit
signaling for a given connection can use a fixed spin value for the duration of
the connection, or can set the bit randomly on each packet sent.</t>
          <t>When in use, the latency spin bit in each direction changes value once per
RTT any time that both endpoints are sending packets
continuously. An on-path observer can observe the time difference between edges
(changes from 1 to 0 or 0 to 1) in the spin bit signal in a single direction to
measure one sample of end-to-end RTT. This mechanism follows the principles of
protocol measurability laid out in <xref target="IPIM"/>.</t>
          <t>Note that this measurement, as with passive RTT measurement for TCP, includes
all transport protocol delay (e.g., delayed sending of acknowledgments) and/or
application layer delay (e.g., waiting for a response to be generated). It
therefore provides devices on path a good instantaneous estimate of the RTT as
experienced by the application.</t>
          <t>However, application-limited and flow-control-limited senders can have
application and transport layer delay, respectively, that are much greater than
network RTT. When the sender is application-limited and e.g., only sends small
amount of periodic application traffic, where that period is longer than the
RTT, measuring the spin bit provides information about the application period,
not the network RTT.</t>
          <t>Since the spin bit logic at each endpoint considers only samples from packets
that advance the largest packet number, signal generation itself is
resistant to reordering. However, reordering can cause problems at an observer
by causing spurious edge detection and therefore inaccurate (i.e., lower) RTT
estimates, if reordering occurs across a spin-bit flip in the stream.</t>
          <t>Simple heuristics based on the observed data rate per flow or changes in the RTT
series can be used to reject bad RTT samples due to lost or reordered edges in
the spin signal, as well as application or flow control limitation; for example,
QoF <xref target="TMA-QOF"/> rejects component RTTs significantly higher than RTTs over the
history of the flow. These heuristics may use the handshake RTT as an initial
RTT estimate for a given flow. Usually such heuristics would also detect if
the spin is either constant or randomly set for a connection.</t>
          <t>An on-path observer that can see traffic in both directions (from client to
server and from server to client) can also use the spin bit to measure
"upstream" and "downstream" component RTT; i.e, the component of the
end-to-end RTT attributable to the paths between the observer and the server
and the observer and the client, respectively. It does this by measuring the
delay between a spin edge observed in the upstream direction and that observed
in the downstream direction, and vice versa.</t>
          <t>Raw RTT samples generated using these techniques can be processed in various
ways to generate useful network performance metrics. A simple linear smoothing
or moving minimum filter can be applied to the stream of RTT samples to get a
more stable estimate of application-experienced RTT. RTT samples measured from
the spin bit can also be used to generate RTT distribution information,
including minimum RTT (which approximates network RTT over longer time windows)
and RTT variance (which approximates one-way packet delay variance as seen
by an application end-point).</t>
        </section>
      </section>
    </section>
    <section anchor="specific-network-management-tasks">
      <name>Specific Network Management Tasks</name>
      <t>In this section, we review specific network management and measurement
techniques and how QUIC's design impacts them.</t>
      <section anchor="passive-network-performance-measurement-and-troubleshooting">
        <name>Passive Network Performance Measurement and Troubleshooting</name>
        <t>Limited RTT measurement is possible by passive observation of QUIC traffic;
see <xref target="sec-rtt"/>. No passive measurement of loss is possible with the present
wire image. Limited observation of upstream congestion may be
possible via the observation of CE markings in the IP header <xref target="RFC3168"/>
on ECN-enabled QUIC traffic.</t>
        <t>On-path devices can also make measurements of RTT, loss and other
performance metrics when information is carried in an additional network-layer
packet header (Section 6 of
<xref target="I-D.ietf-tsvwg-transport-encrypt"/> describes use of operations,
administration and management (OAM) information).
Using network-layer approaches also has the advantage that common observation
and analysis tools can be consistently used for multiple transport protocols,
however, these techniques are often limited to measurements within one or
multiple cooperating domains.</t>
      </section>
      <section anchor="sec-stateful">
        <name>Stateful Treatment of QUIC Traffic</name>
        <t>Stateful treatment of QUIC traffic (e.g., at a firewall or NAT middlebox) is
possible through QUIC traffic and version identification (<xref target="sec-identifying"/>)
and observation of the handshake for connection confirmation (<xref target="sec-confirm"/>).
The lack of any visible end-of-flow signal (<xref target="sec-teardown"/>) means that this
state must be purged either through timers or through least-recently-used
eviction, depending on application requirements.</t>
        <t>While QUIC has no clear network-visible end-of-flow signal and therefore
does require timer-based state removal, the QUIC handshake indicates
confirmation by both ends of a valid bidirectional transmission. As soon
as the handshake completed, timers should be set long enough to also
allow for short idle time during a valid transmission.</t>
        <t><xref target="RFC4787"/> requires a network state timeout that is not less than 2 minutes
for most UDP traffic.  However, in practice, a QUIC endpoint can experience
lower timeouts, in the range of 30 to 60 seconds <xref target="QUIC-TIMEOUT"/>.</t>
        <t>In contrast, <xref target="RFC5382"/> recommends a state timeout of more than 2
hours for TCP, given that TCP is a connection-oriented protocol with
well-defined closure semantics.
Even though QUIC has explicitly been designed to tolerate NAT rebindings,
decreasing the NAT timeout is not recommended, as it may negatively impact
application performance or incentivize endpoints to send very frequent
keep-alive packets.</t>
        <t>The recommendation is therefore that, even when lower state timeouts are
used for other UDP traffic, a state timeout of at least two minutes
ought to be used for QUIC traffic.</t>
        <t>If state is removed too early, this could lead to black-holing of incoming
packets after a short idle period. To detect this situation, a timer at the
client needs to expire before a re-establishment can happen (if at all), which
would lead to unnecessarily long delays in an otherwise working connection.</t>
        <t>Furthermore, not all endpoints use routing architectures where connections
will survive a port or address change. So even when the client revives the
connection, a NAT rebinding can cause a routing mismatch where a packet
is not even delivered to the server that might support address migration.
For these reasons, the limits in <xref target="RFC4787"/> are important to avoid
black-holing of packets (and hence avoid interrupting the flow of data to the
client), especially where devices are able to distinguish QUIC traffic from
other UDP payloads.</t>
        <t>The QUIC header optionally contains a connection ID which could provide
additional entropy beyond the 5-tuple. The QUIC handshake needs
to be observed in order to understand whether the connection ID is present and
what length it has. However, connection IDs may be renegotiated
after the handshake, and this renegotiation is not visible to the path.
Therefore, using the connection ID as a flow key field for stateful treatment
of flows is not recommended as connection ID changes will cause undetectable
and unrecoverable loss of state in the middle of a connection. In particular,
the use of the connection ID for functions that require state to make a
forwarding decison is not viable as it will break connectivity, or at minimum
cause long timeout-based delays before this problem is detected by the
endpoints and the connection can potentially be re-established.</t>
        <t>Use of connection IDs is specifically discouraged for NAT applications.
If a NAT hits an operational limit, it is recommended to rather drop the
initial packets of a flow (see also <xref target="sec-filtering"/>),
which potentially triggers TCP fallback. Use of the connection ID to
multiplex multiple connections on the same IP address/port pair is not a
viable solution as it risks connectivity breakage, in case the connection
ID changes.</t>
      </section>
      <section anchor="address-rewriting-to-ensure-routing-stability">
        <name>Address Rewriting to Ensure Routing Stability</name>
        <t>While QUIC's migration capability makes it possible for a connection to survive
client address changes, this does not work if the routers or switches in the
server infrastructure route using the address-port 4-tuple. If infrastructure
routes on addresses only, NAT rebinding or address migration will cause packets
to be delivered to the wrong server. <xref target="QUIC_LB"/> describes a way to addresses
this problem by coordinating the selection and use of connection IDs between
load-balancers and servers.</t>
        <t>Applying address translation at a middlebox to maintain a stable
address-port mapping for flows based on connection ID might seem
like a solution to this problem. However, hiding information about the
change of the IP address or port conceals important and security-relevant
information from QUIC endpoints and as such would facilitate amplification
attacks (see <xref section="8" sectionFormat="of" target="QUIC-TRANSPORT"/>). A NAT function that hides
peer address changes prevents the other end from
detecting and mitigating attacks as the endpoint cannot verify connectivity
to the new address using QUIC PATH_CHALLENGE and PATH_RESPONSE frames.</t>
        <t>In addition, a change of IP address or port is also an input signal to other
internal mechanisms in QUIC. When a path change is detected, path-dependent
variables like congestion control parameters will be reset protecting
the new path from overload.</t>
      </section>
      <section anchor="sec-loadbalancing">
        <name>Server Cooperation with Load Balancers</name>
        <t>In the case of networking architectures that include load balancers,
the connection ID can be used as a way for the server to signal information
about the desired treatment of a flow to the load balancers. Guidance on
assigning connection IDs is given in
<xref target="QUIC-APPLICABILITY"/>. <xref target="QUIC_LB"/>
describes a system for coordinating selection and use of connection IDs between
load-balancers and servers.</t>
      </section>
      <section anchor="sec-filtering">
        <name>Filtering Behavior</name>
        <t><xref target="RFC4787"/> describes possible packet filtering behaviors that relate to NATs
but is often also used is other scenarios where packet filtering is desired.
Though the guidance there holds, a particularly unwise behavior admits a
handful of UDP packets and then makes a decision to whether or not filter
later packets in the same connection.
QUIC applications are encouraged to fall back to TCP if early packets do
not arrive at their destination <xref target="QUIC-APPLICABILITY"/>, as QUIC is
based on UDP and there are known blocks of UDP traffic (see <xref target="sec-udp-1312"/>).
Admitting a few packets allows the QUIC endpoint to determine that the path
accepts QUIC. Sudden drops afterwards will result in slow and costly timeouts
before abandoning the connection.</t>
      </section>
      <section anchor="sec-udp-1312">
        <name>UDP Blocking, Throttling, and NAT Binding</name>
        <t>Today, UDP is the most prevalent DDoS vector, since it is easy for compromised
non-admin applications to send a flood of large UDP packets (while with TCP the
attacker gets throttled by the congestion controller) or to craft reflection and
amplification attacks. Some networks therefore block UDP traffic.
With increased deployment of QUIC, there is also an increased need to allow
UDP traffic on ports used for QUIC. However, if UDP is generally enabled on
these ports, UDP flood attacks may also use the same ports. One possible
response to this threat is to throttle UDP traffic on the network, allocating a
fixed portion of the network capacity to UDP and blocking UDP datagrams over
that cap. As the portion of QUIC traffic compared to TCP is also expected to
increase over time, using such a limit is not recommended but if done,
limits might need to be adapted dynamically.</t>
        <t>Further, if UDP traffic is desired to be throttled, it is recommended to
block individual
QUIC flows entirely rather than dropping packets indiscriminately.
When the handshake is blocked, QUIC-capable applications may fall back
to TCP. However, blocking a random fraction of QUIC packets across
4-tuples will allow many QUIC handshakes to complete, preventing TCP fallback,
but these connections will suffer from
severe packet loss (see also <xref target="sec-filtering"/>). Therefore, UDP throttling
should be realized by per-flow policing, as opposed to per-packet
policing. Note that this per-flow policing should be stateless to avoid
problems with stateful treatment of QUIC flows (see <xref target="sec-stateful"/>),
for example blocking a portion of the space of values of a hash function
over the addresses and ports in the UDP datagram.
While QUIC endpoints are often able to survive address changes, e.g., by NAT
rebindings, blocking a portion of the traffic based on 5-tuple hashing increases
the risk of black-holing an active connection when the address changes.</t>
        <t>Note that some source ports are assumed to be reflection attack vectors by some
servers; see <xref section="8.1" sectionFormat="of" target="QUIC-APPLICABILITY"/>. As a result, NAT
binding to these source ports can result in that traffic being blocked.</t>
      </section>
      <section anchor="sec-ddos-dec">
        <name>DDoS Detection and Mitigation</name>
        <t>On-path observation of the transport headers of packets can be used for various
security functions. For example, Denial of Service (DOS) and Distributed DOS
(DDOS) attacks against the infrastructure or against an endpoint can be
detected and mitigated by characterising anomalous traffic.
Other uses include support for security audits (e.g., verifying the
compliance with ciphersuites); client and application fingerprinting for
inventory; and to provide alerts for network intrusion detection and other
next generation firewall functions.</t>
        <t>Current practices in detection and mitigation of DDoS
attacks generally involve classification of incoming traffic (as
packets, flows, or some other aggregate) into "good" (productive) and "bad"
(DDoS) traffic, and then differential treatment of this traffic to forward only
good traffic. This operation is often done in a separate specialized mitigation
environment through which all traffic is filtered; a generalized architecture
for separation of concerns in mitigation is given in
<xref target="DOTS-ARCH"/>.</t>
        <t>Efficient classification of this DDoS traffic in the mitigation environment
is key to the success of this approach. Limited first-packet garbage detection
as in <xref target="sec-garbage"/> and stateful tracking of QUIC traffic as in
<xref target="sec-stateful"/> above may be useful during classification.</t>
        <t>Note that the use of a connection ID to support connection migration renders
5-tuple based filtering insufficient to detect active flows and requires more
state to be maintained by DDoS defense systems if support of migration of QUIC
flows is desired. For the common case of NAT rebinding, where the client's
address changes without the client's intent or knowledge, DDoS defense systems
can detect a change in the client's endpoint address by linking flows based on
the server's connection IDs. However, QUIC's linkability resistance ensures that
a deliberate connection migration is accompanied by a change in the connection
ID. In this case, the connection ID can not be used to distinguish valid, active
traffic from new attack traffic.</t>
        <t>It is also possible for
endpoints to directly support security functions such as DoS
classification and mitigation.
Endpoints can cooperate with an in-network device directly by e.g.,
sharing information about connection IDs.</t>
        <t>Another potential method could use an
on-path network device that relies on pattern inferences in the traffic and
heuristics or machine learning instead of processing observed header
information.</t>
        <t>However, it is questionable whether connection migrations must be supported
during a DDoS attack. While unintended migration without a connection ID
change can be more easily supported, it might be acceptable to not
support migrations of active QUIC connections that are not visible to
the network functions performing the DDoS detection.
As soon as the connection blocking is detected by the client,
the client may be able to rely on the 0-RTT data mechanism
provided by QUIC. When clients migrate to a new path, they should be prepared
for the migration to fail and attempt to reconnect quickly.</t>
        <t>Beyond in-network DDoS protection mechanisms, TCP syncookies <xref target="RFC4937"/>
are a well-established method of mitigating some
kinds of TCP DDoS attacks. QUIC Retry packets are the functional analogue to
syncookies, forcing clients to prove possession of their IP address before
committing server state.  However, there are safeguards in QUIC against
unsolicited injection of these packets by intermediaries who do not have consent
of the end server. See <xref target="QUIC_LB"/> for standard ways for intermediaries to send
Retry packets on behalf of consenting servers.</t>
      </section>
      <section anchor="quality-of-service-handling-and-ecmp-routing">
        <name>Quality of Service Handling and ECMP Routing</name>
        <t>It is expected that any QoS handling in the network, e.g., based on use of
DiffServ Code Points (DSCPs) <xref target="RFC2475"/> as well as Equal-Cost
Multi-Path (ECMP) routing, is applied on a per flow-basis (and not per-packet)
and as such that all packets belonging to the same active QUIC connection
get uniform treatment.</t>
        <t>Using ECMP to distribute packets from a single flow across multiple
network paths or any other non-uniform treatment of packets belong to the same
connection could result in variations in order, delivery rate, and drop rate.
As feedback about loss or delay of each packet is used as input to
the congestion controller, these variations could adversely affect performance.
Depending on the loss recovery mechanism implemented, QUIC may be
more tolerant of packet re-ordering than traditional TCP traffic (see
<xref target="packetnumber"/>). However, the recovery mechanism used by a flow cannot be
known by the network and therefore reordering tolerance should be
considered as unknown.</t>
        <t>Note that the 5-tuple of a QUIC connnection can change due to migration.
In this case different flows are observed by the path and maybe be treated
differently, as congestion control is usualy reset on migration (see also
<xref target="sec-flow-association"/>).</t>
      </section>
      <section anchor="handling-icmp-messages">
        <name>Handling ICMP Messages</name>
        <t>Datagram Packetization Layer PMTU Discovery (PLPMTUD) can be used by QUIC to
probe for the supported PMTU. PLPMTUD optionally uses ICMP messages (e.g.,
IPv6 Packet Too Big messages). Given known attacks with the use of ICMP
messages, the use of PLPMTUD in QUIC has been designed to safely use but
not rely on receiving ICMP feedback (see
<xref section="14.2.1." sectionFormat="of" target="QUIC-TRANSPORT"/>).</t>
        <t>Networks are recommended to forward these ICMP messages and retain as much of
the original packet as possible without exceeding the minimum MTU for the IP
version when generating ICMP messages as recommended in <xref target="RFC1812"/>
and <xref target="RFC4443"/>.</t>
      </section>
      <section anchor="guiding-path-mtu">
        <name>Guiding Path MTU</name>
        <t>Some network segments support 1500-byte packets,
but can only do so by fragmenting at a
lower layer before traversing a network segment with a smaller MTU,
and then reassembling within the network segment.
This is permissible even when the IP layer is IPv6 or IPv4 with the DF bit set,
because fragmention occurs below the IP layer.
However, this process can add to compute
and memory costs, leading to a bottleneck that limits network capacity. In such
networks this generates a desire to influence a majority of senders to use
smaller packets, to avoid exceeding limited reassembly capacity.</t>
        <t>For TCP, MSS clamping (<xref section="3.2" sectionFormat="of" target="RFC4459"/>) is often used to change
the sender's TCP maximum segment size, but QUIC requires a different approach.
<xref section="14" sectionFormat="of" target="QUIC-TRANSPORT"/> advises senders to probe larger sizes using
Datagram Packetization Layer PMTU Discovery (<xref target="DPLPMTUD"/>) or Path
Maximum Transmission Unit Discovery (PMTUD: <xref target="RFC1191"/> and <xref target="RFC8201"/>).
This mechanism encourages senders to approach the maximum packet size, which
could then cause fragmentation within a network segment of which
they may not be aware.</t>
        <t>If path performance is limited when forwarding larger packets, an on-path
device should support a maximum packet size for a specific transport flow
and then consistently drop all packets that exceed the configured size
when the inner IPv4 packet has DF set, or IPv6 is used.</t>
        <t>Networks with configurations that would lead to fragmentation of large
packets within a network segment should drop such packets rather than
fragmenting them. Network operators who plan to implement a more
selective policy may start by focusing on QUIC.</t>
        <t>QUIC flows cannot always be easily distinguished from other UDP traffic, but
we assume at least some portion of QUIC traffic can be identified
(see <xref target="sec-identifying"/>). For networks supporting QUIC, it is recommended
that a path drops any packet larger than the fragmentation size.
When a QUIC endpoint uses DPLPMTUD, it will use a QUIC probe packet to
discover the PMTU. If this probe is lost, it will not impact the flow of
QUIC data.</t>
        <t>IPv4 routers generate an ICMP message when a packet is dropped because the
link MTU was exceeded. <xref target="RFC8504"/> specifies how an IPv6 node generates an
ICMPv6 Packet Too Big message (PTB) in this case. PMTUD relies upon an
endpoint receiving such PTB messages <xref target="RFC8201"/>, whereas DPLPMTUD does not
reply upon these messages, but still can optionally use these to improve
performance <xref section="4.6" sectionFormat="of" target="DPLPMTUD"/>.</t>
        <t>A network cannot know in advance which discovery method is used by a QUIC
endpoint, so it should send a PTB message in addition to dropping an
oversized packet. A generated PTB message should be compliant with the
validation requirements of <xref section="14.2.1" sectionFormat="of" target="QUIC-TRANSPORT"/>, otherwise
it will be ignored for PMTU discovery. This provides a signal to the
endpoint to prevent the packet size from growing too large, which can
entirely avoid network segment fragmentation for that flow.</t>
        <t>Endpoints can cache PMTU information, in the IP-layer cache. This short-term
consistency between the PMTU for flows can help avoid an endpoint using a
PMTU that is inefficient. The IP cache can also influence the PMTU value of
other IP flows that use the same path <xref target="RFC8201"/><xref target="DPLPMTUD"/>,
including IP packets carrying
protocols other than QUIC. The representation of an IP path is
implementation-specific <xref target="RFC8201"/>.</t>
      </section>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document has no actions for IANA.</t>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>QUIC is an encrypted and authenticated transport. That means, once the
cryptographic handshake is complete, QUIC endpoints discard most packets that
are not authenticated, greatly limiting the ability of an attacker to interfere
with existing connections.</t>
      <t>However, some information is still observerable, as supporting manageability of
QUIC traffic inherently involves tradeoffs with the confidentiality of QUIC's
control information; this entire document is therefore security-relevant.</t>
      <t>More security considerations for QUIC are discussed in <xref target="QUIC-TRANSPORT"/>
and <xref target="QUIC-TLS"/>, generally considering active or passive attackers in the
network as well as attacks on specific QUIC mechanism.</t>
      <t>Version Negotiation packets do not contain any mechanism to prevent version
downgrade attacks. However, future versions of QUIC that use Version Negotiation
packets are required to define a mechanism that is robust against version
downgrade attacks. Therefore, a network node should not attempt to impact
version selection, as version downgrade may result in connection failure.</t>
    </section>
    <section anchor="contributors">
      <name>Contributors</name>
      <t>The following people have contributed significant text to and/or
feedback on this document:</t>
      <ul spacing="normal">
        <li>Chris Box</li>
        <li>Dan Druta</li>
        <li>David Schinazi</li>
        <li>Gorry Fairhurst</li>
        <li>Ian Swett</li>
        <li>Igor Lubashev</li>
        <li>Jana Iyengar</li>
        <li>Jared Mauch</li>
        <li>Lars Eggert</li>
        <li>Lucas Purdue</li>
        <li>Marcus Ihlar</li>
        <li>Mark Nottingham</li>
        <li>Martin Duke</li>
        <li>Martin Thomson</li>
        <li>Matt Joras</li>
        <li>Mike Bishop</li>
        <li>Nick Banks</li>
        <li>Thomas Fossati</li>
        <li>Sean Turner</li>
      </ul>
    </section>
    <section anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>Special thanks to last call reviewers Elwyn Davies, Barry Lieba,
Al Morton, and Peter Saint-Andre.</t>
      <t>This work was partially supported by the European Commission under Horizon 2020
grant agreement no. 688421 Measurement and Architecture for a Middleboxed
Internet (MAMI), and by the Swiss State Secretariat for Education, Research, and
Innovation under contract no. 15.0268. This support does not imply endorsement.</t>
    </section>
  </middle>
  <back>
    <references>
      <name>References</name>
      <references>
        <name>Normative References</name>
        <reference anchor="QUIC-TRANSPORT">
          <front>
            <title>QUIC: A UDP-Based Multiplexed and Secure Transport</title>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar">
              <organization/>
            </author>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson">
              <organization/>
            </author>
            <date month="May" year="2021"/>
            <abstract>
              <t>This document defines the core of the QUIC transport protocol.  QUIC provides applications with flow-controlled streams for structured communication, low-latency connection establishment, and network path migration. QUIC includes security measures that ensure confidentiality, integrity, and availability in a range of deployment circumstances.  Accompanying documents describe the integration of TLS for key negotiation, loss detection, and an exemplary congestion control algorithm.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9000"/>
          <seriesInfo name="DOI" value="10.17487/RFC9000"/>
        </reference>
        <reference anchor="QUIC-TLS">
          <front>
            <title>Using TLS to Secure QUIC</title>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson">
              <organization/>
            </author>
            <author fullname="S. Turner" initials="S." role="editor" surname="Turner">
              <organization/>
            </author>
            <date month="May" year="2021"/>
            <abstract>
              <t>This document describes how Transport Layer Security (TLS) is used to secure QUIC.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9001"/>
          <seriesInfo name="DOI" value="10.17487/RFC9001"/>
        </reference>
      </references>
      <references>
        <name>Informative References</name>
        <reference anchor="TMA-QOF">
          <front>
            <title>Inline Data Integrity Signals for Passive Measurement (in Proc. TMA 2014)</title>
            <author initials="B." surname="Trammell">
              <organization/>
            </author>
            <author initials="D." surname="Gugelmann">
              <organization/>
            </author>
            <author initials="N." surname="Brownlee">
              <organization/>
            </author>
            <date year="2014" month="April"/>
          </front>
        </reference>
        <reference anchor="IPIM" target="https://arxiv.org/abs/1612.02902">
          <front>
            <title>In-Protocol Internet Measurement (arXiv preprint 1612.02902)</title>
            <author initials="M." surname="Allman">
              <organization/>
            </author>
            <author initials="R." surname="Beverly">
              <organization/>
            </author>
            <author initials="B." surname="Trammell">
              <organization/>
            </author>
            <date year="2016" month="December" day="09"/>
          </front>
        </reference>
        <reference anchor="QUIC-TIMEOUT" target="https://www.ietf.org/proceedings/88/slides/slides-88-tsvarea-10.pdf">
          <front>
            <title>QUIC (IETF-88 TSV Area Presentation)</title>
            <author initials="J." surname="Roskind">
              <organization/>
            </author>
            <date year="2013" month="November" day="07"/>
          </front>
        </reference>
        <reference anchor="RFC7605">
          <front>
            <title>Recommendations on Using Assigned Transport Port Numbers</title>
            <author fullname="J. Touch" initials="J." surname="Touch">
              <organization/>
            </author>
            <date month="August" year="2015"/>
            <abstract>
              <t>This document provides recommendations to designers of application and service protocols on how to use the transport protocol port number space and when to request a port assignment from IANA.  It provides designer guidance to requesters or users of port numbers on how to interact with IANA using the processes defined in RFC 6335; thus, this document complements (but does not update) that document.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="165"/>
          <seriesInfo name="RFC" value="7605"/>
          <seriesInfo name="DOI" value="10.17487/RFC7605"/>
        </reference>
        <reference anchor="QUIC-RECOVERY">
          <front>
            <title>QUIC Loss Detection and Congestion Control</title>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar">
              <organization/>
            </author>
            <author fullname="I. Swett" initials="I." role="editor" surname="Swett">
              <organization/>
            </author>
            <date month="May" year="2021"/>
            <abstract>
              <t>This document describes loss detection and congestion control mechanisms for QUIC.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9002"/>
          <seriesInfo name="DOI" value="10.17487/RFC9002"/>
        </reference>
        <reference anchor="QUIC-GREASE">
          <front>
            <title>Greasing the QUIC Bit</title>
            <author fullname="Martin Thomson">
              <organization>Mozilla</organization>
            </author>
            <date day="10" month="November" year="2021"/>
            <abstract>
              <t>   This document describes a method for negotiating the ability to send
   an arbitrary value for the second-to-most significant bit in QUIC
   packets.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-quic-bit-grease-02"/>
        </reference>
        <reference anchor="RFC4459">
          <front>
            <title>MTU and Fragmentation Issues with In-the-Network Tunneling</title>
            <author fullname="P. Savola" initials="P." surname="Savola">
              <organization/>
            </author>
            <date month="April" year="2006"/>
            <abstract>
              <t>Tunneling techniques such as IP-in-IP when deployed in the middle of the network, typically between routers, have certain issues regarding how large packets can be handled: whether such packets would be fragmented and reassembled (and how), whether Path MTU Discovery would be used, or how this scenario could be operationally avoided. This memo justifies why this is a common, non-trivial problem, and goes on to describe the different solutions and their characteristics at some length.  This memo provides information for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4459"/>
          <seriesInfo name="DOI" value="10.17487/RFC4459"/>
        </reference>
        <reference anchor="QUIC-HTTP">
          <front>
            <title>Hypertext Transfer Protocol Version 3 (HTTP/3)</title>
            <author fullname="Mike Bishop">
              <organization>Akamai</organization>
            </author>
            <date day="2" month="February" year="2021"/>
            <abstract>
              <t>The QUIC transport protocol has several features that are desirable
   in a transport for HTTP, such as stream multiplexing, per-stream flow
   control, and low-latency connection establishment.  This document
   describes a mapping of HTTP semantics over QUIC.  This document also
   identifies HTTP/2 features that are subsumed by QUIC, and describes
   how HTTP/2 extensions can be ported to HTTP/3.

DO NOT DEPLOY THIS VERSION OF HTTP

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

Note to Readers

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

   Working Group information can be found at https://github.com/quicwg;
   source code and issues list for this draft can be found at
   https://github.com/quicwg/base-drafts/labels/-http.
              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-quic-http-34"/>
        </reference>
        <reference anchor="WIRE-IMAGE">
          <front>
            <title>The Wire Image of a Network Protocol</title>
            <author fullname="B. Trammell" initials="B." surname="Trammell">
              <organization/>
            </author>
            <author fullname="M. Kuehlewind" initials="M." surname="Kuehlewind">
              <organization/>
            </author>
            <date month="April" year="2019"/>
            <abstract>
              <t>This document defines the wire image, an abstraction of the information available to an on-path non-participant in a networking protocol.  This abstraction is intended to shed light on the implications that increased encryption has for network functions that use the wire image.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8546"/>
          <seriesInfo name="DOI" value="10.17487/RFC8546"/>
        </reference>
        <reference anchor="RFC9065">
          <front>
            <title>Considerations around Transport Header Confidentiality, Network Operations, and the Evolution of Internet Transport Protocols</title>
            <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
              <organization/>
            </author>
            <author fullname="C. Perkins" initials="C." surname="Perkins">
              <organization/>
            </author>
            <date month="July" year="2021"/>
            <abstract>
              <t>To protect user data and privacy, Internet transport protocols have supported payload encryption and authentication for some time. Such encryption and authentication are now also starting to be applied to the transport protocol headers. This helps avoid transport protocol ossification by middleboxes, mitigate attacks against the transport protocol, and protect metadata about the communication. Current operational practice in some networks inspect transport header information within the network, but this is no longer possible when those transport headers are encrypted.</t>
              <t>This document discusses the possible impact when network traffic uses a protocol with an encrypted transport header. It suggests issues to consider when designing new transport protocols or features.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9065"/>
          <seriesInfo name="DOI" value="10.17487/RFC9065"/>
        </reference>
        <reference anchor="QUIC-INVARIANTS">
          <front>
            <title>Version-Independent Properties of QUIC</title>
            <author fullname="M. Thomson" initials="M." surname="Thomson">
              <organization/>
            </author>
            <date month="May" year="2021"/>
            <abstract>
              <t>This document defines the properties of the QUIC transport protocol that are common to all versions of the protocol.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8999"/>
          <seriesInfo name="DOI" value="10.17487/RFC8999"/>
        </reference>
        <reference anchor="RFC7801">
          <front>
            <title>GOST R 34.12-2015: Block Cipher "Kuznyechik"</title>
            <author fullname="V. Dolmatov" initials="V." role="editor" surname="Dolmatov">
              <organization/>
            </author>
            <date month="March" year="2016"/>
            <abstract>
              <t>This document is intended to be a source of information about the Russian Federal standard GOST R 34.12-2015 describing the block cipher with a block length of n=128 bits and a key length of k=256 bits, which is also referred to as "Kuznyechik".  This algorithm is one of the set of Russian cryptographic standard algorithms (called GOST algorithms).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7801"/>
          <seriesInfo name="DOI" value="10.17487/RFC7801"/>
        </reference>
        <reference anchor="RFC7838">
          <front>
            <title>HTTP Alternative Services</title>
            <author fullname="M. Nottingham" initials="M." surname="Nottingham">
              <organization/>
            </author>
            <author fullname="P. McManus" initials="P." surname="McManus">
              <organization/>
            </author>
            <author fullname="J. Reschke" initials="J." surname="Reschke">
              <organization/>
            </author>
            <date month="April" year="2016"/>
            <abstract>
              <t>This document specifies "Alternative Services" 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="QUIC_LB">
          <front>
            <title>QUIC-LB: Generating Routable QUIC Connection IDs</title>
            <author fullname="Martin Duke">
              <organization>Google</organization>
            </author>
            <author fullname="Nick Banks">
              <organization>Microsoft</organization>
            </author>
            <author fullname="Christian Huitema">
              <organization>Private Octopus Inc.</organization>
            </author>
            <date day="28" month="March" year="2022"/>
            <abstract>
              <t>   QUIC address migration allows clients to change their IP address
   while maintaining connection state.  To reduce the ability of an
   observer to link two IP addresses, clients and servers use new
   connection IDs when they communicate via different client addresses.
   This poses a problem for traditional "layer-4" load balancers that
   route packets via the IP address and port 4-tuple.  This
   specification provides a standardized means of securely encoding
   routing information in the server's connection IDs so that a properly
   configured load balancer can route packets with migrated addresses
   correctly.  As it proposes a structured connection ID format, it also
   provides a means of connection IDs self-encoding their length to aid
   some hardware offloads.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-quic-load-balancers-13"/>
        </reference>
        <reference anchor="I-D.ietf-dprive-dnsoquic">
          <front>
            <title>DNS over Dedicated QUIC Connections</title>
            <author fullname="Christian Huitema">
              <organization>Private Octopus Inc.</organization>
            </author>
            <author fullname="Sara Dickinson">
              <organization>Sinodun IT</organization>
            </author>
            <author fullname="Allison Mankin">
              <organization>Salesforce</organization>
            </author>
            <date day="21" month="March" year="2022"/>
            <abstract>
              <t>   This document describes the use of QUIC to provide transport
   confidentiality for DNS.  The encryption provided by QUIC has similar
   properties to those provided by TLS, while QUIC transport eliminates
   the head-of-line blocking issues inherent with TCP and provides more
   efficient packet loss recovery than UDP.  DNS over QUIC (DoQ) has
   privacy properties similar to DNS over TLS (DoT) specified in
   RFC7858, and latency characteristics similar to classic DNS over UDP.
   This specification describes the use of DNS over QUIC as a general-
   purpose transport for DNS and includes the use of DNS over QUIC for
   stub to recursive, recursive to authoritative, and zone transfer
   scenarios.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-dprive-dnsoquic-11"/>
        </reference>
        <reference anchor="RFC7983">
          <front>
            <title>Multiplexing Scheme Updates for Secure Real-time Transport Protocol (SRTP) Extension for Datagram Transport Layer Security (DTLS)</title>
            <author fullname="M. Petit-Huguenin" initials="M." surname="Petit-Huguenin">
              <organization/>
            </author>
            <author fullname="G. Salgueiro" initials="G." surname="Salgueiro">
              <organization/>
            </author>
            <date month="September" year="2016"/>
            <abstract>
              <t>This document defines how Datagram Transport Layer Security (DTLS), Real-time Transport Protocol (RTP), RTP Control Protocol (RTCP), Session Traversal Utilities for NAT (STUN), Traversal Using Relays around NAT (TURN), and ZRTP packets are multiplexed on a single receiving socket.  It overrides the guidance from RFC 5764 ("SRTP                Extension for DTLS"), which suffered from four issues described and fixed in this document.</t>
              <t>This document updates RFC 5764.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7983"/>
          <seriesInfo name="DOI" value="10.17487/RFC7983"/>
        </reference>
        <reference anchor="RFC3449">
          <front>
            <title>TCP Performance Implications of Network Path Asymmetry</title>
            <author fullname="H. Balakrishnan" initials="H." surname="Balakrishnan">
              <organization/>
            </author>
            <author fullname="V. Padmanabhan" initials="V." surname="Padmanabhan">
              <organization/>
            </author>
            <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
              <organization/>
            </author>
            <author fullname="M. Sooriyabandara" initials="M." surname="Sooriyabandara">
              <organization/>
            </author>
            <date month="December" year="2002"/>
            <abstract>
              <t>This document describes TCP performance problems that arise because of asymmetric effects.  These problems arise in several access networks, including bandwidth-asymmetric networks and packet radio subnetworks, for different underlying reasons.  However, the end result on TCP performance is the same in both cases: performance often degrades significantly because of imperfection and variability in the ACK feedback from the receiver to the sender. The document details several mitigations to these effects, which have either been proposed or evaluated in the literature, or are currently deployed in networks.  These solutions use a combination of local link- layer techniques, subnetwork, and end-to-end mechanisms, consisting of: (i) techniques to manage the channel used for the upstream bottleneck link carrying the ACKs, typically using header compression or reducing the frequency of TCP ACKs, (ii) techniques to handle this reduced ACK frequency to retain the TCP sender's acknowledgment-triggered self- clocking and (iii) techniques to schedule the data and ACK packets in the reverse direction to improve performance in the presence of two-way traffic.  Each technique is described, together with known issues, and recommendations for use.  A summary of the recommendations is provided at the end of the document.  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="69"/>
          <seriesInfo name="RFC" value="3449"/>
          <seriesInfo name="DOI" value="10.17487/RFC3449"/>
        </reference>
        <reference anchor="RFC6066">
          <front>
            <title>Transport Layer Security (TLS) Extensions: Extension Definitions</title>
            <author fullname="D. Eastlake 3rd" initials="D." surname="Eastlake 3rd">
              <organization/>
            </author>
            <date month="January" year="2011"/>
            <abstract>
              <t>This document provides specifications for existing TLS extensions.  It is a companion document for RFC 5246, "The Transport Layer Security (TLS) Protocol Version 1.2".  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="RFC7301">
          <front>
            <title>Transport Layer Security (TLS) Application-Layer Protocol Negotiation Extension</title>
            <author fullname="S. Friedl" initials="S." surname="Friedl">
              <organization/>
            </author>
            <author fullname="A. Popov" initials="A." surname="Popov">
              <organization/>
            </author>
            <author fullname="A. Langley" initials="A." surname="Langley">
              <organization/>
            </author>
            <author fullname="E. Stephan" initials="E." surname="Stephan">
              <organization/>
            </author>
            <date month="July" year="2014"/>
            <abstract>
              <t>This document describes a Transport Layer Security (TLS) extension for application-layer protocol negotiation within the TLS handshake. For instances in which multiple application protocols are supported on the same TCP or UDP port, this extension allows the application layer to negotiate which protocol will be used within the TLS connection.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7301"/>
          <seriesInfo name="DOI" value="10.17487/RFC7301"/>
        </reference>
        <reference anchor="TLS-ECH">
          <front>
            <title>TLS Encrypted Client Hello</title>
            <author fullname="Eric Rescorla">
              <organization>RTFM, Inc.</organization>
            </author>
            <author fullname="Kazuho Oku">
              <organization>Fastly</organization>
            </author>
            <author fullname="Nick Sullivan">
              <organization>Cloudflare</organization>
            </author>
            <author fullname="Christopher A. Wood">
              <organization>Cloudflare</organization>
            </author>
            <date day="13" month="February" year="2022"/>
            <abstract>
              <t>   This document describes a mechanism in Transport Layer Security (TLS)
   for encrypting a ClientHello message under a server public key.

Discussion Venues

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

   Source for this draft and an issue tracker can be found at
   https://github.com/tlswg/draft-ietf-tls-esni
   (https://github.com/tlswg/draft-ietf-tls-esni).

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-tls-esni-14"/>
        </reference>
        <reference anchor="RFC3168">
          <front>
            <title>The Addition of Explicit Congestion Notification (ECN) to IP</title>
            <author fullname="K. Ramakrishnan" initials="K." surname="Ramakrishnan">
              <organization/>
            </author>
            <author fullname="S. Floyd" initials="S." surname="Floyd">
              <organization/>
            </author>
            <author fullname="D. Black" initials="D." surname="Black">
              <organization/>
            </author>
            <date month="September" year="2001"/>
            <abstract>
              <t>This memo specifies the incorporation of ECN (Explicit Congestion Notification) to TCP and IP, including ECN's use of two bits in the IP header.  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3168"/>
          <seriesInfo name="DOI" value="10.17487/RFC3168"/>
        </reference>
        <reference anchor="I-D.ietf-tsvwg-transport-encrypt">
          <front>
            <title>Considerations around Transport Header Confidentiality, Network Operations, and the Evolution of Internet Transport Protocols</title>
            <author fullname="Godred Fairhurst">
              <organization>University of Aberdeen</organization>
            </author>
            <author fullname="Colin Perkins">
              <organization>University of Glasgow</organization>
            </author>
            <date day="20" month="April" year="2021"/>
            <abstract>
              <t>To protect user data and privacy, Internet transport protocols have supported payload encryption and authentication for some time. Such encryption and authentication are now also starting to be applied to the transport protocol headers. This helps avoid transport protocol ossification by middleboxes, mitigate attacks against the transport protocol, and protect metadata about the communication. Current operational practice in some networks inspect transport header information within the network, but this is no longer possible when those transport headers are encrypted.

 This document discusses the possible impact when network traffic uses a protocol with an encrypted transport header. It suggests issues to consider when designing new transport protocols or features.
              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-tsvwg-transport-encrypt-21"/>
        </reference>
        <reference anchor="RFC4787">
          <front>
            <title>Network Address Translation (NAT) Behavioral Requirements for Unicast UDP</title>
            <author fullname="F. Audet" initials="F." role="editor" surname="Audet">
              <organization/>
            </author>
            <author fullname="C. Jennings" initials="C." surname="Jennings">
              <organization/>
            </author>
            <date month="January" year="2007"/>
            <abstract>
              <t>This document defines basic terminology for describing different types of Network Address Translation (NAT) behavior when handling Unicast UDP and also defines a set of requirements that would allow many applications, such as multimedia communications or online gaming, to work consistently.  Developing NATs that meet this set of requirements will greatly increase the likelihood that these applications will function properly.  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="127"/>
          <seriesInfo name="RFC" value="4787"/>
          <seriesInfo name="DOI" value="10.17487/RFC4787"/>
        </reference>
        <reference anchor="RFC5382">
          <front>
            <title>NAT Behavioral Requirements for TCP</title>
            <author fullname="S. Guha" initials="S." role="editor" surname="Guha">
              <organization/>
            </author>
            <author fullname="K. Biswas" initials="K." surname="Biswas">
              <organization/>
            </author>
            <author fullname="B. Ford" initials="B." surname="Ford">
              <organization/>
            </author>
            <author fullname="S. Sivakumar" initials="S." surname="Sivakumar">
              <organization/>
            </author>
            <author fullname="P. Srisuresh" initials="P." surname="Srisuresh">
              <organization/>
            </author>
            <date month="October" year="2008"/>
            <abstract>
              <t>This document defines a set of requirements for NATs that handle TCP that would allow many applications, such as peer-to-peer applications and online games to work consistently.  Developing NATs that meet this set of requirements will greatly increase the likelihood that these applications will function properly.  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="142"/>
          <seriesInfo name="RFC" value="5382"/>
          <seriesInfo name="DOI" value="10.17487/RFC5382"/>
        </reference>
        <reference anchor="QUIC-APPLICABILITY">
          <front>
            <title>Applicability of the QUIC Transport Protocol</title>
            <author fullname="Mirja Kuehlewind">
              <organization>Ericsson</organization>
            </author>
            <author fullname="Brian Trammell">
              <organization>Google</organization>
            </author>
            <date day="7" month="March" year="2022"/>
            <abstract>
              <t>   This document discusses the applicability of the QUIC transport
   protocol, focusing on caveats impacting application protocol
   development and deployment over QUIC.  Its intended audience is
   designers of application protocol mappings to QUIC, and implementors
   of these application protocols.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-quic-applicability-15"/>
        </reference>
        <reference anchor="DOTS-ARCH">
          <front>
            <title>DDoS Open Threat Signaling (DOTS) Architecture</title>
            <author fullname="A. Mortensen" initials="A." role="editor" surname="Mortensen">
              <organization/>
            </author>
            <author fullname="T. Reddy.K" initials="T." role="editor" surname="Reddy.K">
              <organization/>
            </author>
            <author fullname="F. Andreasen" initials="F." surname="Andreasen">
              <organization/>
            </author>
            <author fullname="N. Teague" initials="N." surname="Teague">
              <organization/>
            </author>
            <author fullname="R. Compton" initials="R." surname="Compton">
              <organization/>
            </author>
            <date month="August" year="2020"/>
            <abstract>
              <t>This document describes an architecture for establishing and maintaining Distributed Denial-of-Service (DDoS) Open Threat Signaling (DOTS) within and between domains. The document does not specify protocols or protocol extensions, instead focusing on defining architectural relationships, components, and concepts used in a DOTS deployment.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8811"/>
          <seriesInfo name="DOI" value="10.17487/RFC8811"/>
        </reference>
        <reference anchor="RFC4937">
          <front>
            <title>IANA Considerations for PPP over Ethernet (PPPoE)</title>
            <author fullname="P. Arberg" initials="P." surname="Arberg">
              <organization/>
            </author>
            <author fullname="V. Mammoliti" initials="V." surname="Mammoliti">
              <organization/>
            </author>
            <date month="June" year="2007"/>
            <abstract>
              <t>This document describes the IANA considerations for the PPP over Ethernet (PPPoE) protocol.  This memo provides information for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4937"/>
          <seriesInfo name="DOI" value="10.17487/RFC4937"/>
        </reference>
        <reference anchor="RFC2475">
          <front>
            <title>An Architecture for Differentiated Services</title>
            <author fullname="S. Blake" initials="S." surname="Blake">
              <organization/>
            </author>
            <author fullname="D. Black" initials="D." surname="Black">
              <organization/>
            </author>
            <author fullname="M. Carlson" initials="M." surname="Carlson">
              <organization/>
            </author>
            <author fullname="E. Davies" initials="E." surname="Davies">
              <organization/>
            </author>
            <author fullname="Z. Wang" initials="Z." surname="Wang">
              <organization/>
            </author>
            <author fullname="W. Weiss" initials="W." surname="Weiss">
              <organization/>
            </author>
            <date month="December" year="1998"/>
            <abstract>
              <t>This document defines an architecture for implementing scalable service differentiation in the Internet.  This memo provides information for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2475"/>
          <seriesInfo name="DOI" value="10.17487/RFC2475"/>
        </reference>
        <reference anchor="RFC1812">
          <front>
            <title>Requirements for IP Version 4 Routers</title>
            <author fullname="F. Baker" initials="F." role="editor" surname="Baker">
              <organization/>
            </author>
            <date month="June" year="1995"/>
            <abstract>
              <t>This memo defines and discusses requirements for devices that perform the network layer forwarding function of the Internet protocol suite. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="1812"/>
          <seriesInfo name="DOI" value="10.17487/RFC1812"/>
        </reference>
        <reference anchor="RFC4443">
          <front>
            <title>Internet Control Message Protocol (ICMPv6) for the Internet Protocol Version 6 (IPv6) Specification</title>
            <author fullname="A. Conta" initials="A." surname="Conta">
              <organization/>
            </author>
            <author fullname="S. Deering" initials="S." surname="Deering">
              <organization/>
            </author>
            <author fullname="M. Gupta" initials="M." role="editor" surname="Gupta">
              <organization/>
            </author>
            <date month="March" year="2006"/>
            <abstract>
              <t>This document describes the format of a set of control messages used in ICMPv6 (Internet Control Message Protocol).  ICMPv6 is the Internet Control Message Protocol for Internet Protocol version 6 (IPv6).  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="89"/>
          <seriesInfo name="RFC" value="4443"/>
          <seriesInfo name="DOI" value="10.17487/RFC4443"/>
        </reference>
        <reference anchor="DPLPMTUD">
          <front>
            <title>Packetization Layer Path MTU Discovery for Datagram Transports</title>
            <author fullname="G. Fairhurst" initials="G." surname="Fairhurst">
              <organization/>
            </author>
            <author fullname="T. Jones" initials="T." surname="Jones">
              <organization/>
            </author>
            <author fullname="M. Tüxen" initials="M." surname="Tüxen">
              <organization/>
            </author>
            <author fullname="I. Rüngeler" initials="I." surname="Rüngeler">
              <organization/>
            </author>
            <author fullname="T. Völker" initials="T." surname="Völker">
              <organization/>
            </author>
            <date month="September" year="2020"/>
            <abstract>
              <t>This document specifies Datagram Packetization Layer Path MTU Discovery (DPLPMTUD). This is a robust method for Path MTU Discovery (PMTUD) for datagram Packetization Layers (PLs). It allows a PL, or a datagram application that uses a PL, to discover whether a network path can support the current size of datagram.  This can be used to detect and reduce the message size when a sender encounters a packet black hole. It can also probe a network path to discover whether the maximum packet size can be increased.  This provides functionality for datagram transports that is equivalent to the PLPMTUD specification for TCP, specified in RFC 4821, which it updates. It also updates the UDP Usage Guidelines to refer to this method for use with UDP datagrams and updates SCTP.</t>
              <t>The document provides implementation notes for incorporating Datagram PMTUD into IETF datagram transports or applications that use datagram transports.</t>
              <t>This specification updates RFC 4960, RFC 4821, RFC 6951, RFC 8085, and RFC 8261.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8899"/>
          <seriesInfo name="DOI" value="10.17487/RFC8899"/>
        </reference>
        <reference anchor="RFC1191">
          <front>
            <title>Path MTU discovery</title>
            <author fullname="J.C. Mogul" initials="J.C." surname="Mogul">
              <organization/>
            </author>
            <author fullname="S.E. Deering" initials="S.E." surname="Deering">
              <organization/>
            </author>
            <date month="November" year="1990"/>
            <abstract>
              <t>This memo describes a technique for dynamically discovering the maximum transmission unit (MTU) of an arbitrary internet path.  It specifies a small change to the way routers generate one type of ICMP message.  For a path that passes through a router that has not been so changed, this technique might not discover the correct Path MTU, but it will always choose a Path MTU as accurate as, and in many cases more accurate than, the Path MTU that would be chosen by current practice.  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="1191"/>
          <seriesInfo name="DOI" value="10.17487/RFC1191"/>
        </reference>
        <reference anchor="RFC8201">
          <front>
            <title>Path MTU Discovery for IP version 6</title>
            <author fullname="J. McCann" initials="J." surname="McCann">
              <organization/>
            </author>
            <author fullname="S. Deering" initials="S." surname="Deering">
              <organization/>
            </author>
            <author fullname="J. Mogul" initials="J." surname="Mogul">
              <organization/>
            </author>
            <author fullname="R. Hinden" initials="R." role="editor" surname="Hinden">
              <organization/>
            </author>
            <date month="July" year="2017"/>
            <abstract>
              <t>This document describes Path MTU Discovery (PMTUD) for IP version 6. It is largely derived from RFC 1191, which describes Path MTU Discovery for IP version 4.  It obsoletes RFC 1981.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="87"/>
          <seriesInfo name="RFC" value="8201"/>
          <seriesInfo name="DOI" value="10.17487/RFC8201"/>
        </reference>
        <reference anchor="RFC8504">
          <front>
            <title>IPv6 Node Requirements</title>
            <author fullname="T. Chown" initials="T." surname="Chown">
              <organization/>
            </author>
            <author fullname="J. Loughney" initials="J." surname="Loughney">
              <organization/>
            </author>
            <author fullname="T. Winters" initials="T." surname="Winters">
              <organization/>
            </author>
            <date month="January" year="2019"/>
            <abstract>
              <t>This document defines requirements for IPv6 nodes.  It is expected that IPv6 will be deployed in a wide range of devices and situations. Specifying the requirements for IPv6 nodes allows IPv6 to function well and interoperate in a large number of situations and deployments.</t>
              <t>This document obsoletes RFC 6434, and in turn RFC 4294.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="220"/>
          <seriesInfo name="RFC" value="8504"/>
          <seriesInfo name="DOI" value="10.17487/RFC8504"/>
        </reference>
      </references>
    </references>
  </back>
  <!-- ##markdown-source:
H4sIAN4FTmIAA+19bXcbV5Le9/srOtKHIbMATcqyLMs7SagX29yRZI5Iz2ST
k7OnCTTIXgHdmO4GKY5H+e2peqrq3roNQNauvUlOsj7Jjgigb9+XuvVeT02n
0zDUw7J6Vrwpm/K6Kq/qZT3cF+2iGG6q4o8/nb0oLruy6ddtNxTnXTu0s3YZ
yqurrrp9Jt9nT4Z5O2vKFQ0478rFMK2rYTH9y6aeTVf+Z9OTJ2FeDtWzMKP/
e91298+Kulm0IdTr7lkxdJt+eHR8/M3xo/C+ur9ru/mz4qwZqq6phulLHjmE
fiib+T+Vy7aht91XfVjXz4r/ThOcFD3NtqsWPf3rfsX/+B8hhHIz3LTds1AU
U/r/Bb2vp2UfFX/YVDfL6q5u5vhYZv+m7v65HH/VdtfPilddPev7tsEn1aqs
l8+KFf/66H389X+p9EdHs3aVv/D5EW/oalUtl+51z7u6bPIv8LLv2/Z6WRUX
d/Xw16pb0oKL71dXP/h38w7/l0GfPJrd4Luell8N9DztY3k7/X6zXE7Pl+Xw
1+IE38/oDJ4VT4+PHxf/bUNzladm7aYZ+Cjc+0Jo2m5VDvUtHVbgM4p/FcXl
m9PpH3/87hmeVkI6a5Z1UxUvy6HEkV13TFAX9XVTLvuCHi/Oy76nAYo3Vdlv
umpVNUNxUDdMXrMjHrN4dHzy+BCDpkPj/6b6v3v2cusHL49oB66rJdFes/sX
b49o79u7ZllV+AJEifdPjx/TJ2fnZ29Gy5vaNYgUma+k7P5rfVusu2rd1fT3
yZOTR0fHj4iUP2NFRI6nS57u7q/f0WyrWzqY+8/bkKHsrpkMboZh3T/74ouy
+1DfHhFlfVFe9V+kmeVLfzI9eTQ9/oY+5Ps9vTx78+rHny6zXcDFPzh7dfnd
9OnT4vLiT8VpV5V0glVPe0D00Tafsdp/OCretf17u17j2d7d3R0xdWPCayKO
qprXzXX/xdOnX/TLel71+j80h+nQ35Y0henJ8dF6vsgX9OX05GR6/DV9+O67
F18/Of7qma3t3asXP/7p1bt/fMbffHOMncAX3797dXrxio57+vIo8bCrephe
01v6SsZ6/Pirb+hWTKfTgjaULuGM+NLlTd0XxAY3IId53c82fV/1xWovhx0i
h10raU3ootBjtNrQNvhhvVov6xl2tueH+cHf0Xuqnm5WwYzhru74Z/SOgp4h
siS2+b5o11UnT9HlvW2XtzRmfOtiUdONOxsKmjHRatXMq3lR9kVZPNj0Vfc7
THpTLh/g3vI00ksmgSZ7W/OJFNebel42swo/y9/cdj1mV9EGrrEjt/Qa/vTu
pi26anlfyAoDvRG7YpsxLe/oRONwi00zwzqOZMNX9Xy+rEJ4yNewa+cbfBsC
1vbzz/9ZaPfd6duL8x/fXf5ezvf440dea0mj3u3Y9jDclNiMqpmV635DHJM2
hFjTTy/Pj2TXarA0+rwvLl9fhPii1xf6ihN6xdDyCN39eijK5bJYl/fLtpwz
QZbYjFXbD8Rted7LxFNJXMg76Ib39FdxUtyVdsQ0D+Inq7KracdwRGn6vOs/
XF6eT+h4hpvA50QXcbMc+GxsbcVVxX++b4jb8QD8wBdfxp3iP3+fUzvfw48f
j8YULcdO6//EqYNKsZlC9VhXiBSHAetmttxk49CSb9o73j3e5Y5Y6IDt2gx0
Z/5aFW6nMHjgk/qwbnvanKt7peoWdKrTmdBG0FqENQshkvDZrNbxHtklDHqT
eAd599bVbODBbF0kUMuBR5nIKHwss67GQDwOT5yE/YpI0B6RpeueEWuoZ7TY
u3rJR8H3mT5KEz9SymXqbIh65tOhndL/7KDSo+Jtm+1FLSwinvRNVc6rbhJI
VMhG0V0jGV/MaGR+dYPVVfMJv221Gcor0jFoHm7j7Iz6UPGLZjTR4aZrN9c3
egOYh/ELq5ntQM4emLD+fPbu1fTszen3r/huPP3q8RMmp1dyM/QpXIV055fl
fdXZ1Sh6aA1MtquqNIpaVn3vl89UcFv3NS8iP33+fcNr5M9mxLXldC9fnNNu
n+1aBu8QqSktvZn57YL2hBZNI/c3bYvrRBPg0fhk1m0NouqLhnTQoFvQtEzT
yrVtIutykO1ftXMZ1Q5VFux5QPihvWMhT6cz6LrrZrrvfs2rNc+l1aFVRPDO
MrcJB3w3qw8lraZidbjCwYBTPfnq48fDAiy2JeJqe9lC3qJ2I6uctfF1NGIo
5YrR+7D0o+Jiw1TlfrSqr28GprFsOBFgjkvLYLTvH+6VNFlPoIvC06+wpXIJ
9D3n+KVbus2aKL+f0edB5JNjU3TCb7fvYd3jsZL2q5r2xFOmi3rop8ykWfiV
t+2GzI90W4kQe+J1XTWnW00f9GVH86Ad5ZtF485ZwN1jkTVPGFyr7uPB97L+
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
Ek/j/wKiXtQqmwABAA==

-->

</rfc>
