// Copyright 2012 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef NET_SPDY_SPDY_HTTP_UTILS_H_ #define NET_SPDY_SPDY_HTTP_UTILS_H_ #include #include "base/memory/ref_counted.h" #include "base/types/expected.h" #include "net/base/net_export.h" #include "net/base/request_priority.h" #include "net/third_party/quiche/src/quiche/spdy/core/http2_header_block.h" #include "net/third_party/quiche/src/quiche/spdy/core/spdy_framer.h" #include "net/third_party/quiche/src/quiche/spdy/core/spdy_protocol.h" #include "url/gurl.h" namespace net { class HttpResponseInfo; struct HttpRequestInfo; class HttpRequestHeaders; class HttpResponseHeaders; // HTTP Extensible Priorities header (in lowercase HTTP2/3). // RFC 9218. NET_EXPORT extern const char* const kHttp2PriorityHeader; // Convert a spdy::Http2HeaderBlock into an HttpResponseInfo with some checks. // `headers` input parameter with the spdy::Http2HeaderBlock. // `response` output parameter for the HttpResponseInfo. // Returns OK if successfully converted. An error is returned if the // spdy::Http2HeaderBlock is incomplete (e.g. missing 'status' or 'version') or // checks fail. NET_EXPORT int SpdyHeadersToHttpResponse(const spdy::Http2HeaderBlock& headers, HttpResponseInfo* response); // Converts a spdy::Http2HeaderBlock object into an HttpResponseHeaders object // by creating a string with embedded nul bytes instead of newlines and then // parsing it to the HttpResponseHeaders constructor to be parsed. Exposed for // testing. // TODO(https://crbug.com/1485670): Remove this once it is no longer needed. NET_EXPORT_PRIVATE base::expected, int> SpdyHeadersToHttpResponseHeadersUsingRawString( const spdy::Http2HeaderBlock& headers); // Converts a spdy::Http2HeaderBlock object into an HttpResponseHeaders object // by using the HttpResponseHeaders::Builder API. Exposed for testing. // TODO(https://crbug.com/1485670): Merge this back into // SpdyHeadersToHttpResponse() when // SpdyHeadersToHttpResponseHeadersUsingRawString() is removed. NET_EXPORT_PRIVATE base::expected, int> SpdyHeadersToHttpResponseHeadersUsingBuilder( const spdy::Http2HeaderBlock& headers); // Create a spdy::Http2HeaderBlock from HttpRequestInfo and // HttpRequestHeaders. NET_EXPORT void CreateSpdyHeadersFromHttpRequest( const HttpRequestInfo& info, std::optional priority, const HttpRequestHeaders& request_headers, spdy::Http2HeaderBlock* headers); // Create a spdy::Http2HeaderBlock from HttpRequestInfo and // HttpRequestHeaders, with the given protocol for extended CONNECT. // The request's method must be `CONNECT`. NET_EXPORT void CreateSpdyHeadersFromHttpRequestForExtendedConnect( const HttpRequestInfo& info, std::optional priority, const std::string& ext_connect_protocol, const HttpRequestHeaders& request_headers, spdy::Http2HeaderBlock* headers); // Create a spdy::Http2HeaderBlock from HttpRequestInfo and HttpRequestHeaders // for a WebSockets over HTTP/2 request. NET_EXPORT void CreateSpdyHeadersFromHttpRequestForWebSocket( const GURL& url, const HttpRequestHeaders& request_headers, spdy::Http2HeaderBlock* headers); // Create HttpRequestHeaders from spdy::Http2HeaderBlock. NET_EXPORT void ConvertHeaderBlockToHttpRequestHeaders( const spdy::Http2HeaderBlock& spdy_headers, HttpRequestHeaders* http_headers); NET_EXPORT spdy::SpdyPriority ConvertRequestPriorityToSpdyPriority( RequestPriority priority); NET_EXPORT RequestPriority ConvertSpdyPriorityToRequestPriority(spdy::SpdyPriority priority); } // namespace net #endif // NET_SPDY_SPDY_HTTP_UTILS_H_