| #ifndef QUICHE_HTTP2_ADAPTER_HTTP2_PROTOCOL_H_ |
| #define QUICHE_HTTP2_ADAPTER_HTTP2_PROTOCOL_H_ |
| |
| #include <cstdint> |
| #include <string> |
| #include <utility> |
| |
| #include "absl/base/attributes.h" |
| #include "absl/strings/string_view.h" |
| #include "absl/types/variant.h" |
| #include "quiche/common/platform/api/quiche_export.h" |
| |
| namespace http2 { |
| namespace adapter { |
| |
| // Represents an HTTP/2 stream ID, consistent with nghttp2. |
| using Http2StreamId = int32_t; |
| |
| // Represents an HTTP/2 SETTINGS parameter as specified in RFC 7540 Section 6.5. |
| using Http2SettingsId = uint16_t; |
| |
| // Represents the payload of an HTTP/2 PING frame. |
| using Http2PingId = uint64_t; |
| |
| // Represents a single header name or value. |
| using HeaderRep = absl::variant<absl::string_view, std::string>; |
| |
| // Boolean return value is true if |rep| holds a string_view, which is assumed |
| // to have an indefinite lifetime. |
| std::pair<absl::string_view, bool> GetStringView(const HeaderRep& rep); |
| |
| // Represents an HTTP/2 header field. A header field is a key-value pair with |
| // lowercase keys (as specified in RFC 7540 Section 8.1.2). |
| using Header = std::pair<HeaderRep, HeaderRep>; |
| |
| // Represents an HTTP/2 SETTINGS key-value parameter. |
| struct QUICHE_EXPORT Http2Setting { |
| Http2SettingsId id; |
| uint32_t value; |
| }; |
| |
| QUICHE_EXPORT bool operator==(const Http2Setting& a, const Http2Setting& b); |
| |
| // The maximum possible stream ID. |
| inline constexpr Http2StreamId kMaxStreamId = 0x7FFFFFFF; |
| |
| // The stream ID that represents the connection (e.g., for connection-level flow |
| // control updates). |
| inline constexpr Http2StreamId kConnectionStreamId = 0; |
| |
| // The default value for the size of the largest frame payload, according to RFC |
| // 7540 Section 6.5.2 (SETTINGS_MAX_FRAME_SIZE). |
| inline constexpr uint32_t kDefaultFramePayloadSizeLimit = 16u * 1024u; |
| |
| // The maximum value for the size of the largest frame payload, according to RFC |
| // 7540 Section 6.5.2 (SETTINGS_MAX_FRAME_SIZE). |
| inline constexpr uint32_t kMaximumFramePayloadSizeLimit = 16777215u; |
| |
| // The default value for the initial stream and connection flow control window |
| // size, according to RFC 7540 Section 6.9.2. |
| inline constexpr int kInitialFlowControlWindowSize = 64 * 1024 - 1; |
| |
| // The pseudo-header fields as specified in RFC 7540 Section 8.1.2.3 (request) |
| // and Section 8.1.2.4 (response). |
| inline constexpr absl::string_view kHttp2MethodPseudoHeader = ":method"; |
| inline constexpr absl::string_view kHttp2SchemePseudoHeader = ":scheme"; |
| inline constexpr absl::string_view kHttp2AuthorityPseudoHeader = ":authority"; |
| inline constexpr absl::string_view kHttp2PathPseudoHeader = ":path"; |
| inline constexpr absl::string_view kHttp2StatusPseudoHeader = ":status"; |
| |
| inline constexpr uint8_t kMetadataFrameType = 0x4d; |
| inline constexpr uint8_t kMetadataEndFlag = 0x04; |
| inline constexpr uint16_t kMetadataExtensionId = 0x4d44; |
| |
| enum class FrameType : uint8_t { |
| DATA = 0x0, |
| HEADERS, |
| PRIORITY, |
| RST_STREAM, |
| SETTINGS, |
| PUSH_PROMISE, |
| PING, |
| GOAWAY, |
| WINDOW_UPDATE, |
| CONTINUATION, |
| }; |
| |
| enum FrameFlags : uint8_t { |
| END_STREAM_FLAG = 0x1, |
| ACK_FLAG = END_STREAM_FLAG, |
| END_HEADERS_FLAG = 0x4, |
| PADDED_FLAG = 0x8, |
| PRIORITY_FLAG = 0x20, |
| }; |
| |
| // HTTP/2 error codes as specified in RFC 7540 Section 7. |
| enum class Http2ErrorCode { |
| HTTP2_NO_ERROR = 0x0, |
| PROTOCOL_ERROR = 0x1, |
| INTERNAL_ERROR = 0x2, |
| FLOW_CONTROL_ERROR = 0x3, |
| SETTINGS_TIMEOUT = 0x4, |
| STREAM_CLOSED = 0x5, |
| FRAME_SIZE_ERROR = 0x6, |
| REFUSED_STREAM = 0x7, |
| CANCEL = 0x8, |
| COMPRESSION_ERROR = 0x9, |
| CONNECT_ERROR = 0xA, |
| ENHANCE_YOUR_CALM = 0xB, |
| INADEQUATE_SECURITY = 0xC, |
| HTTP_1_1_REQUIRED = 0xD, |
| MAX_ERROR_CODE = HTTP_1_1_REQUIRED, |
| }; |
| |
| // The SETTINGS parameters defined in RFC 7540 Section 6.5.2. Endpoints may send |
| // SETTINGS parameters outside of these definitions as per RFC 7540 Section 5.5. |
| // This is explicitly an enum instead of an enum class for ease of implicit |
| // conversion to the underlying Http2SettingsId type and use with non-standard |
| // extension SETTINGS parameters. |
| enum Http2KnownSettingsId : Http2SettingsId { |
| HEADER_TABLE_SIZE = 0x1, |
| MIN_SETTING = HEADER_TABLE_SIZE, |
| ENABLE_PUSH = 0x2, |
| MAX_CONCURRENT_STREAMS = 0x3, |
| INITIAL_WINDOW_SIZE = 0x4, |
| MAX_FRAME_SIZE = 0x5, |
| MAX_HEADER_LIST_SIZE = 0x6, |
| ENABLE_CONNECT_PROTOCOL = 0x8, // See RFC 8441 |
| MAX_SETTING = ENABLE_CONNECT_PROTOCOL |
| }; |
| |
| // Returns a human-readable string representation of the given SETTINGS |id| for |
| // logging/debugging. Returns "SETTINGS_UNKNOWN" for IDs outside of the RFC 7540 |
| // Section 6.5.2 definitions. |
| QUICHE_EXPORT absl::string_view Http2SettingsIdToString(uint16_t id); |
| |
| // Returns a human-readable string representation of the given |error_code| for |
| // logging/debugging. Returns "UNKNOWN_ERROR" for errors outside of RFC 7540 |
| // Section 7 definitions. |
| QUICHE_EXPORT absl::string_view Http2ErrorCodeToString( |
| Http2ErrorCode error_code); |
| |
| enum class Perspective { |
| kClient, |
| kServer, |
| }; |
| |
| } // namespace adapter |
| } // namespace http2 |
| |
| #endif // QUICHE_HTTP2_ADAPTER_HTTP2_PROTOCOL_H_ |