Internet DRAFT - draft-schinazi-masque-connect-udp-ecn
draft-schinazi-masque-connect-udp-ecn
MASQUE D. Schinazi
Internet-Draft Google LLC
Intended status: Standards Track 28 March 2022
Expires: 29 September 2022
An ECN Extension to CONNECT-UDP
draft-schinazi-masque-connect-udp-ecn-02
Abstract
CONNECT-UDP allows proxying UDP packets over HTTP. This document
describes an extension to CONNECT-UDP that allows conveying ECN
information on proxied UDP packets.
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/DavidSchinazi/draft-connect-udp-ecn.
Status of This Memo
This Internet-Draft is submitted in full conformance with the
provisions of BCP 78 and BCP 79.
Internet-Drafts are working documents of the Internet Engineering
Task Force (IETF). Note that other groups may also distribute
working documents as Internet-Drafts. The list of current Internet-
Drafts is at https://datatracker.ietf.org/drafts/current/.
Internet-Drafts are draft documents valid for a maximum of six months
and may be updated, replaced, or obsoleted by other documents at any
time. It is inappropriate to use Internet-Drafts as reference
material or to cite them other than as "work in progress."
This Internet-Draft will expire on 29 September 2022.
Copyright Notice
Copyright (c) 2022 IETF Trust and the persons identified as the
document authors. All rights reserved.
This document is subject to BCP 78 and the IETF Trust's Legal
Provisions Relating to IETF Documents (https://trustee.ietf.org/
license-info) in effect on the date of publication of this document.
Please review these documents carefully, as they describe your rights
Schinazi Expires 29 September 2022 [Page 1]
Internet-Draft CONNECT-UDP ECN Extension March 2022
and restrictions with respect to this document. Code Components
extracted from this document must include Revised BSD License text as
described in Section 4.e of the Trust Legal Provisions and are
provided without warranty as described in the Revised BSD License.
Table of Contents
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . 2
1.1. Conventions and Definitions . . . . . . . . . . . . . . . 2
2. Context Identifiers . . . . . . . . . . . . . . . . . . . . . 2
3. ECN Header Definition . . . . . . . . . . . . . . . . . . . . 3
4. Encoding of ECN bits . . . . . . . . . . . . . . . . . . . . 3
5. A Note about Future Extensions . . . . . . . . . . . . . . . 4
6. Security Considerations . . . . . . . . . . . . . . . . . . . 4
7. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 5
8. Normative References . . . . . . . . . . . . . . . . . . . . 5
Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . . 6
Author's Address . . . . . . . . . . . . . . . . . . . . . . . . 6
1. Introduction
CONNECT-UDP [CONNECT-UDP] allows proxying UDP packets over HTTP.
This document describes an extension to CONNECT-UDP that allows
conveying ECN [ECN] information on proxied UDP packets.
1.1. Conventions and Definitions
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and
"OPTIONAL" in this document are to be interpreted as described in
BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all
capitals, as shown here.
2. Context Identifiers
The "Context Identifiers" section of [CONNECT-UDP] defines the
concept of context IDs and how they can be used to extend CONNECT-
UDP. When a client wishes to use ECN with CONNECT-UDP, it generates
an unique client-allocated context ID. In this document, we'll refer
to that context ID as the "chosen context ID". Note that, by
definition of client-allocated context IDs, the chosen context ID
will always be a non-zero even number. We also add the restriction
that the chosen context ID MUST be strictly less than 10^15. If the
client has run out of available context ID values that match this
requirement for this CONNECT-UDP request, it MUST NOT use the ECN
extension with this CONNECT-UDP request.
Schinazi Expires 29 September 2022 [Page 2]
Internet-Draft CONNECT-UDP ECN Extension March 2022
3. ECN Header Definition
The "ECN" header field is an Item Structured Field, see Section 3.3
of [STRUCT-FIELD]; its value MUST be a Integer; any other value type
MUST be handled as if the field were not present by recipients (for
example, if this field is included multiple times, its type will
become a List and the field will therefore be ignored). This
document does not define any parameters for the "ECN" header field
value, but future documents might define parameters. Receivers MUST
ignore unknown parameters.
When present, the "ECN" header indicates that the sender supports
this extension, and communicates the chosen context ID as the "ECN"
field value.
For example, if the client chosen context ID is 42, it would send the
following:
ECN: 42; foo=bar
Figure 1: Example Client ECN Field
Clients MUST NOT indicate support for this extension unless they know
that the protocol running over UDP that is being proxied supports
ECN, and will react appropriately to Congestion Experienced (CE)
markings.
Proxies MUST NOT indicate support for this extension unless they know
they have the ability to read and write the IP ECN bits on its
target-bound UDP sockets.
This extension is said to have been negotiated when both client and
proxy indicated support for it in their CONNECT-UDP request and
response. When indicating support for this extension, the proxy send
the client's chosen context ID as the "ECN" field value.
For example, the proxy could reply with:
ECN: 42
Figure 2: Example Proxy ECN Field
4. Encoding of ECN bits
When an HTTP Datagram [HTTP-DGRAM] associated with a CONNECT-UDP
stream uses the chosen context ID as its context ID, its "Payload"
field contains the following format (using the notation from the
"Notational Conventions" section of [QUIC]):
Schinazi Expires 29 September 2022 [Page 3]
Internet-Draft CONNECT-UDP ECN Extension March 2022
CONNECT-UDP Payload with ECN {
Must be Zero (6),
ECN Bits (2),
UDP Payload (..),
}
Figure 3: CONNECT-UDP Payload with ECN
Must be Zero: 6 bits that MUST be sent as zero. Receivers MUST
validate that these bits are zero and MUST silently drop the HTTP
Datagram if they have any other value. Extensions to this
mechanism MAY relax this requirement.
ECN Bits: The ECN bits, sent in the same order as they appear in the
IP header.
UDP Payload: The UDP Payload, as defined in the "HTTP Datagram
Payload Format" section of [CONNECT-UDP].
When the proxy receives a datagram with the chosen context ID, it
sets the IP packet's ECN bits accordingly on the UDP packet it sends
to the target. Similarly, in the other direction the ECN Bits field
represents which ECN bits were seen on the UDP packets received from
the target.
5. A Note about Future Extensions
This CONNECT-UDP extension uses an HTTP field to register its chosen
context ID. Future extensions to CONNECT-UDP can use the same
strategy to register their chosen context ID(s) via another HTTP
field. This strategy is best for CONNECT-UDP extensions that only
need to register context IDs during the HTTP request and response.
Some extensions may need to register context IDs after the request
and response have been exchanged, for example an extension that
wishes to compress QUIC connection IDs [QUIC] is not aware of all
connection IDs at request time. In such cases, extensions can use
new Capsule Types (see [HTTP-DGRAM]) to perform context ID
registration.
6. Security Considerations
This document does not have additional security considerations beyond
those defined in [CONNECT-UDP].
Schinazi Expires 29 September 2022 [Page 4]
Internet-Draft CONNECT-UDP ECN Extension March 2022
7. IANA Considerations
This document will request IANA to register the following entry in
the "HTTP Field Name" registry:
Field Name: ECN
Template: None
Status: provisional (permanent if this document is approved)
Reference: This document
Comments: None
8. Normative References
[CONNECT-UDP]
Schinazi, D., "UDP Proxying Support for HTTP", Work in
Progress, Internet-Draft, draft-ietf-masque-connect-udp-
08, 21 March 2022, <https://datatracker.ietf.org/doc/html/
draft-ietf-masque-connect-udp-08>.
[ECN] Ramakrishnan, K., Floyd, S., and D. Black, "The Addition
of Explicit Congestion Notification (ECN) to IP",
RFC 3168, DOI 10.17487/RFC3168, September 2001,
<https://www.rfc-editor.org/rfc/rfc3168>.
[HTTP-DGRAM]
Schinazi, D. and L. Pardue, "HTTP Datagrams and the
Capsule Protocol", Work in Progress, Internet-Draft,
draft-ietf-masque-h3-datagram-08, 28 March 2022,
<https://datatracker.ietf.org/doc/html/draft-ietf-masque-
h3-datagram-08>.
[QUIC] Iyengar, J., Ed. and M. Thomson, Ed., "QUIC: A UDP-Based
Multiplexed and Secure Transport", RFC 9000,
DOI 10.17487/RFC9000, May 2021,
<https://www.rfc-editor.org/rfc/rfc9000>.
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
Requirement Levels", BCP 14, RFC 2119,
DOI 10.17487/RFC2119, March 1997,
<https://www.rfc-editor.org/rfc/rfc2119>.
[RFC8174] Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC
2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
May 2017, <https://www.rfc-editor.org/rfc/rfc8174>.
Schinazi Expires 29 September 2022 [Page 5]
Internet-Draft CONNECT-UDP ECN Extension March 2022
[STRUCT-FIELD]
Nottingham, M. and P-H. Kamp, "Structured Field Values for
HTTP", RFC 8941, DOI 10.17487/RFC8941, February 2021,
<https://www.rfc-editor.org/rfc/rfc8941>.
Acknowledgments
This proposal was inspired directly or indirectly by prior work from
many people. The author would like to thank contributors the MASQUE
working group.
Author's Address
David Schinazi
Google LLC
1600 Amphitheatre Parkway
Mountain View, California 94043,
United States of America
Email: dschinazi.ietf@gmail.com
Schinazi Expires 29 September 2022 [Page 6]