| // Copyright 2024 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_HTTP_HTTP_STREAM_KEY_H_ |
| #define NET_HTTP_HTTP_STREAM_KEY_H_ |
| |
| #include <optional> |
| #include <string> |
| |
| #include "base/types/optional_ref.h" |
| #include "base/values.h" |
| #include "net/base/net_export.h" |
| #include "net/base/network_anonymization_key.h" |
| #include "net/base/privacy_mode.h" |
| #include "net/dns/host_resolver.h" |
| #include "net/dns/public/secure_dns_policy.h" |
| #include "net/http/alternative_service.h" |
| #include "net/quic/quic_session_alias_key.h" |
| #include "net/quic/quic_session_key.h" |
| #include "net/socket/socket_tag.h" |
| #include "net/spdy/spdy_session_key.h" |
| #include "url/scheme_host_port.h" |
| |
| namespace net { |
| |
| // The key used to group HttpStreams that don't require proxies. |
| // Currently SocketTag is not supported. |
| // TODO(crbug.com/346835898): Support SocketTag. |
| class NET_EXPORT_PRIVATE HttpStreamKey { |
| public: |
| HttpStreamKey(); |
| // `alt_service` is only used for HttpStreamKeys generated for alt-service |
| // requests. Note that these keys for alt-service connection attempts will |
| // never match the key for a non-alt-service attempt. For destinations with an |
| // alt service entry, two different HttpStreamKeys will be used: One with a |
| // null alt service, and one with a populate alt service value. All other |
| // fields will be the same. |
| HttpStreamKey( |
| url::SchemeHostPort destination, |
| PrivacyMode privacy_mode, |
| SocketTag socket_tag, |
| NetworkAnonymizationKey network_anonymization_key, |
| SecureDnsPolicy secure_dns_policy, |
| bool disable_cert_network_fetches, |
| base::optional_ref<const AlternativeService> alt_service = std::nullopt); |
| |
| ~HttpStreamKey(); |
| |
| HttpStreamKey(const HttpStreamKey& other); |
| HttpStreamKey& operator=(const HttpStreamKey& other); |
| |
| bool operator==(const HttpStreamKey& other) const; |
| bool operator<(const HttpStreamKey& other) const; |
| |
| const url::SchemeHostPort& destination() const { return destination_; } |
| |
| PrivacyMode privacy_mode() const { return privacy_mode_; } |
| |
| const SocketTag& socket_tag() const { return socket_tag_; } |
| |
| const NetworkAnonymizationKey& network_anonymization_key() const { |
| return network_anonymization_key_; |
| } |
| |
| SecureDnsPolicy secure_dns_policy() const { return secure_dns_policy_; } |
| |
| bool disable_cert_network_fetches() const { |
| return disable_cert_network_fetches_; |
| } |
| |
| std::string ToString() const; |
| |
| base::DictValue ToValue() const; |
| |
| // Calculate a SpdySessionKey from `this`. Unlike |
| // CalculateQuicSessionAliasKey(), this method doesn't take an optional |
| // destination because we don't use a different destination for |
| // SpdySessionKey. |
| // TODO(crbug.com/346835898): We may need to create SpdySessionAliasKey and |
| // use a different destination to support H2 alternative endpoints that have |
| // different destinations. Returns a key with an empty host when the scheme is |
| // not cryptographic. |
| SpdySessionKey CalculateSpdySessionKey() const; |
| |
| const std::optional<AlternativeService>& alt_service() const { |
| return alt_service_; |
| } |
| |
| // Returns the host that needs to be resolved to establish a connection to. |
| // This is typically `destination_`, except in the case `alt_service_` is |
| // non-null, in which case it's the alt service destination. |
| HostResolver::Host GetHostToResolve() const; |
| |
| // Calculates a QuicSessionAliasKey from `this`. Takes `alt_service_` into |
| // consideration, when populated and for the QUIC protocol. See the comment of |
| // QuicSessionAliasKey about the difference between the server id and the |
| // destination. Returns a key with empty server_id/destination when the scheme |
| // is not cryptographic. |
| QuicSessionAliasKey CalculateQuicSessionAliasKey() const; |
| |
| private: |
| url::SchemeHostPort destination_; |
| PrivacyMode privacy_mode_ = PrivacyMode::PRIVACY_MODE_DISABLED; |
| SocketTag socket_tag_; |
| NetworkAnonymizationKey network_anonymization_key_; |
| SecureDnsPolicy secure_dns_policy_ = SecureDnsPolicy::kAllow; |
| bool disable_cert_network_fetches_ = false; |
| std::optional<AlternativeService> alt_service_; |
| }; |
| |
| } // namespace net |
| |
| #endif // NET_HTTP_HTTP_STREAM_KEY_H_ |