Internet DRAFT - draft-beky-httpbis-metadata
draft-beky-httpbis-metadata
HTTP B. Béky
Internet-Draft B. Roy
Intended status: Standards Track Google LLC
Expires: 2 February 2023 1 August 2022
METADATA frame for HTTP/2 and HTTP/3
draft-beky-httpbis-metadata-02
Abstract
This document describes a mechanism to send meta information over
HTTP/2 and HTTP/3 connections that refers to either the entire
connection or a specific stream without changing the semantics of the
HTTP messages. This mechanism can be used, for example, to gather
information for accounting or logging purposes.
About This Document
This note is to be removed before publishing as an RFC.
The latest revision of this draft can be found at
https://bencebeky.github.io/metadata/draft-beky-httpbis-
metadata.html. Status information for this document may be found at
https://datatracker.ietf.org/doc/draft-beky-httpbis-metadata/.
Discussion of this document takes place on the HTTP Working Group
mailing list (mailto:ietf-http-wg@w3.org), which is archived at
https://lists.w3.org/Archives/Public/ietf-http-wg/.
Source for this draft and an issue tracker can be found at
https://github.com/bencebeky/metadata.
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."
Béky & Roy Expires 2 February 2023 [Page 1]
Internet-Draft METADATA August 2022
This Internet-Draft will expire on 2 February 2023.
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
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
2. Conventions and Definitions . . . . . . . . . . . . . . . . . 3
3. METADATA frame . . . . . . . . . . . . . . . . . . . . . . . 3
3.1. METADATA HTTP/2 frame . . . . . . . . . . . . . . . . . . 3
3.2. METADATA HTTP/3 frame . . . . . . . . . . . . . . . . . . 4
4. Negotiating METADATA . . . . . . . . . . . . . . . . . . . . 5
5. Security Considerations . . . . . . . . . . . . . . . . . . . 5
5.1. Compression State Corruption . . . . . . . . . . . . . . 6
5.2. Denial-of-Service Considerations . . . . . . . . . . . . 6
6. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 6
6.1. HTTP/2 Frame . . . . . . . . . . . . . . . . . . . . . . 6
6.2. HTTP/2 Setting . . . . . . . . . . . . . . . . . . . . . 6
6.3. HTTP/3 Frame . . . . . . . . . . . . . . . . . . . . . . 7
6.4. HTTP/3 Setting . . . . . . . . . . . . . . . . . . . . . 7
7. Normative References . . . . . . . . . . . . . . . . . . . . 7
Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . . 8
Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . 8
1. Introduction
HTTP/2 [HTTP/2] and HTTP/3 [HTTP/3] connections are capable of
transporting multiple HTTP messages, which are composed of field
sections and bodies. This document describes a mechanism to convey
additional information about HTTP messages or the entire connection,
in a way that does not change HTTP semantics, over the same
connection. For instance, an endpoint may wish to convey the CPU
cost or other loadbalancing information for a particular HTTP
message, or perhaps certain statistics for a particular HTTP message
or for the connection as a whole. Applications may wish to provide
such information without affecting HTTP messages themselves. These
Béky & Roy Expires 2 February 2023 [Page 2]
Internet-Draft METADATA August 2022
are some non-exhaustive examples of use cases that may be well served
by the METADATA frame.
METADATA frames convey information to the next hop; they are
explicitly not designed as an end-to-end mechanism.
2. 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.
3. METADATA frame
Both HTTP/2 and HTTP/3 specifications allow the protocol to be
extended, see Section 5.5 of [HTTP/2] and Section 9 of [HTTP/3].
This document defines a new frame type: METADATA.
The METADATA frame can be used to transmit a metadata block, which is
an encoded list of key-value pairs. Each key and value is a sequence
of bytes with no restriction on the allowed values. The encoded
block is packaged as the payload of one or more frames.
An endpoint MAY transmit multiple metadata blocks on the same stream.
METADATA frames do not change HTTP semantics.
3.1. METADATA HTTP/2 frame
The type of the METADATA HTTP/2 frame is 0x4d.
METADATA HTTP/2 Frame {
Length (24),
Type (8) = 0x4d,
Flags (8),
Reserved(1),
Stream Identifier (31),
Encoded key-value pairs (..),
}
Figure 1: METADATA HTTP/2 frame
Béky & Roy Expires 2 February 2023 [Page 3]
Internet-Draft METADATA August 2022
The METADATA frame defines the following flag:
*END_METADATA (0x04)*: When set, the END_METADATA flag indicates
that this frame ends the logical metadata block.
A METADATA frame without the END_METADATA flag set MUST be
followed by a another METADATA frame on the same stream. However,
METADATA frames MAY be interleaved with non-METADATA frames on the
same stream, or frames of any type on different streams.
METADATA frames are allowed on any stream. METADATA frames on stream
0 carry information pertaining to the whole connection. METADATA
frames on any other stream are associated with the exchange carried
by that stream.
METADATA frames do not alter the state of a stream. METADATA frames
MUST NOT be sent on a stream in the "closed" or "half closed (local)"
state. An endpoint that receives METADATA for a stream in the "idle"
state MAY choose to retain the payload for a period of time, under
the assumption that the stream will soon transition to the "open"
state.
A metadata block is the concatenation of the payloads of a sequence
of one or more METADATA frames, only the last of which has the
END_METADATA flag set. If the transfer of the last metadata block
cannot be completed due to the stream or connection being closed
before a METADATA frame with the END_METADATA flag, then the
incomplete metadata block SHOULD be discarded. This SHOULD NOT
affect processing of previous metadata blocks on the same stream or
connection.
METADATA frames obey the maximum frame size set by
SETTINGS_MAX_FRAME_SIZE.
METADATA frames are not subject to flow control.
The metadata block of an HTTP/2 METADATA frame is encoded using HPACK
representations ([HPACK]). An endpoint MUST NOT use any HPACK
representations that change the dynamic table inside METADATA frames;
any METADATA frame with such representations SHOULD be treated as a
connection error.
3.2. METADATA HTTP/3 frame
The type of METADATA HTTP/3 frame is 0x4d.
Béky & Roy Expires 2 February 2023 [Page 4]
Internet-Draft METADATA August 2022
METADATA HTTP/3 Frame {
Type (i) = 0x4d,
Length (i),
Encoded key-value pairs (..),
}
Figure 2: METADATA HTTP/3 frame
METADATA frames are allowed on any stream that uses HTTP/3 frames.
METADATA frames on the control stream carry information pertaining to
the whole connection. METADATA frames on a request stream or a push
stream are associated with the exchange carried by that stream.
The metadata block of a HTTP/3 METADATA frame is encoded using QPACK
representations ([QPACK]). An endpoint MUST NOT use any QPACK
representations that reference the dynamic table inside METADATA
frames; any METADATA frame with such representations SHOULD be
treated as a connection error. Therefore the Required Insert Count
MUST be zero, and decoding METADATA frame payloads do not elicit
instructions on the QPACK decoder stream.
4. Negotiating METADATA
This document defines a new HTTP/2 setting identifier,
SETTINGS_ENABLE_METADATA, with value 0x4d44. It also defines a new
HTTP/3 setting identifier, SETTINGS_ENABLE_METADATA, with value
0x4d44.
An endpoint that supports METADATA frames SHOULD advertise that by
sending SETTINGS_ENABLE_METADATA with value 1 on each connection. A
value of 0 indicates that the endpoint does not support METADATA
frames. A value other than 0 or 1 MUST NOT be sent. In HTTP/2, the
initial value is 0; in HTTP/3, the default value is 0. For HTTP/2,
SETTINGS_ENABLE_METADATA MUST NOT be sent in any SETTINGS frame other
than the first one.
An endpoint SHOULD NOT send METADATA frames if it learns that the
peer does not support them.
5. Security Considerations
Béky & Roy Expires 2 February 2023 [Page 5]
Internet-Draft METADATA August 2022
5.1. Compression State Corruption
Since metadata blocks are encoded using HPACK or QPACK, they create
the possibility of changes to the compression state of a connection.
However, METADATA frames are extension frames, and might be dropped
by implementations or intermediaries. To avoid the problem of
compression state desynchronization between endpoints, HPACK or QPACK
representations that change compression state are disallowed.
5.2. Denial-of-Service Considerations
Depending on the application, metadata blocks sent over HTTP/2 might
be larger than the negotiated SETTINGS_MAX_FRAME_SIZE. To facilitate
interoperability, endpoints MUST respect the SETTINGS_MAX_FRAME_SIZE
expressed by the peer when encoding METADATA frames.
6. IANA Considerations
6.1. HTTP/2 Frame
This document adds an entry to the "HTTP/2 Frame Type" registry
maintained at <https://www.iana.org/assignments/http2-parameters/
http2-parameters.xhtml> with the following parameters:
*Code:* 0x4d
*Frame Type:* METADATA
*Reference:* This Document
6.2. HTTP/2 Setting
This document adds an entry to the "HTTP/2 Settings" registry
maintained at <https://www.iana.org/assignments/http2-parameters/
http2-parameters.xhtml> with the following parameters:
*Code:* 0x4d44
*Name:* SETTINGS_ENABLE_METADATA
*Initial Value:* 0
*Reference:* This Document
Béky & Roy Expires 2 February 2023 [Page 6]
Internet-Draft METADATA August 2022
6.3. HTTP/3 Frame
This document adds an entry to the "HTTP/3 Frame Types" registry
maintained at <https://www.iana.org/assignments/http3-parameters/
http3-parameters.xhtml> with the following parameters:
*Value:* 0x4d
*Frame Type:* METADATA
*Status*: provisional (permanent if this document is approved)
*Reference:* This Document
*Change Controller*: Bence Beky (IETF if this document is approved)
*Contact*: bnc@google.com (HTTP_WG; HTTP working group; ietf-http-
wg@w3.org if this document is approved)
*Notes*: None
6.4. HTTP/3 Setting
This document adds an entry to the "HTTP/3 Settings" registry
maintained at <https://www.iana.org/assignments/http3-parameters/
http3-parameters.xhtml> with the following parameters:
*Value:* 0x4d44
*Settings Name:* SETTINGS_ENABLE_METADATA
*Default:* 0
*Status*: provisional (permanent if this document is approved)
*Reference:* This Document
*Change Controller*: Bence Beky (IETF if this document is approved)
*Contact*: bnc@google.com (HTTP_WG; HTTP working group; ietf-http-
wg@w3.org if this document is approved)
*Notes*: None
7. Normative References
Béky & Roy Expires 2 February 2023 [Page 7]
Internet-Draft METADATA August 2022
[HPACK] Peon, R. and H. Ruellan, "HPACK: Header Compression for
HTTP/2", RFC 7541, DOI 10.17487/RFC7541, May 2015,
<https://www.rfc-editor.org/rfc/rfc7541>.
[HTTP/2] Thomson, M., Ed. and C. Benfield, Ed., "HTTP/2", RFC 9113,
DOI 10.17487/RFC9113, June 2022,
<https://www.rfc-editor.org/rfc/rfc9113>.
[HTTP/3] Bishop, M., Ed., "HTTP/3", RFC 9114, DOI 10.17487/RFC9114,
June 2022, <https://www.rfc-editor.org/rfc/rfc9114>.
[QPACK] Krasic, C., Bishop, M., and A. Frindell, Ed., "QPACK:
Field Compression for HTTP/3", RFC 9204,
DOI 10.17487/RFC9204, June 2022,
<https://www.rfc-editor.org/rfc/rfc9204>.
[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>.
Acknowledgments
The authors would like to acknowledge Dianna Hu and Ian Swett for
their contributions to this document.
Authors' Addresses
Bence Béky
Google LLC
Email: bnc@google.com
Biren Roy
Google LLC
Email: birenroy@google.com
Béky & Roy Expires 2 February 2023 [Page 8]