| #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 "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_PRIVATE Http2Setting { |
| Http2SettingsId id; |
| uint32_t value; |
| }; |
| |
| QUICHE_EXPORT_PRIVATE bool operator==(const Http2Setting& a, |
| const Http2Setting& b); |
| |
| // The maximum possible stream ID. |
| const Http2StreamId kMaxStreamId = 0x7FFFFFFF; |
| |
| // The stream ID that represents the connection (e.g., for connection-level flow |
| // control updates). |
| const 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). |
| const int kDefaultFramePayloadSizeLimit = 16 * 1024; |
| |
| // The default value for the initial stream and connection flow control window |
| // size, according to RFC 7540 Section 6.9.2. |
| const 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). |
| ABSL_CONST_INIT QUICHE_EXPORT_PRIVATE extern const char |
| kHttp2MethodPseudoHeader[]; |
| ABSL_CONST_INIT QUICHE_EXPORT_PRIVATE extern const char |
| kHttp2SchemePseudoHeader[]; |
| ABSL_CONST_INIT QUICHE_EXPORT_PRIVATE extern const char |
| kHttp2AuthorityPseudoHeader[]; |
| ABSL_CONST_INIT QUICHE_EXPORT_PRIVATE extern const char |
| kHttp2PathPseudoHeader[]; |
| ABSL_CONST_INIT QUICHE_EXPORT_PRIVATE extern const char |
| kHttp2StatusPseudoHeader[]; |
| |
| ABSL_CONST_INIT QUICHE_EXPORT_PRIVATE extern const uint8_t kMetadataFrameType; |
| ABSL_CONST_INIT QUICHE_EXPORT_PRIVATE extern const uint8_t kMetadataEndFlag; |
| ABSL_CONST_INIT QUICHE_EXPORT_PRIVATE extern const uint16_t |
| kMetadataExtensionId; |
| |
| enum class FrameType : uint8_t { |
| DATA = 0x0, |
| HEADERS, |
| PRIORITY, |
| RST_STREAM, |
| SETTINGS, |
| PUSH_PROMISE, |
| PING, |
| GOAWAY, |
| WINDOW_UPDATE, |
| CONTINUATION, |
| }; |
| |
| // 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. |
| 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. |
| absl::string_view Http2ErrorCodeToString(Http2ErrorCode error_code); |
| |
| enum class Perspective { |
| kClient, |
| kServer, |
| }; |
| |
| } // namespace adapter |
| } // namespace http2 |
| |
| #endif // QUICHE_HTTP2_ADAPTER_HTTP2_PROTOCOL_H_ |