// 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_SSL_SSL_CONFIG_SERVICE_H_ #define NET_SSL_SSL_CONFIG_SERVICE_H_ #include #include #include #include "base/observer_list.h" #include "net/base/net_export.h" #include "net/ssl/ssl_config.h" namespace net { struct NET_EXPORT SSLContextConfig { SSLContextConfig(); SSLContextConfig(const SSLContextConfig&); SSLContextConfig(SSLContextConfig&&); ~SSLContextConfig(); SSLContextConfig& operator=(const SSLContextConfig&); SSLContextConfig& operator=(SSLContextConfig&&); bool operator==(const SSLContextConfig&) const; // Returns whether post-quantum key agreement is enabled in TLS handshakes. bool PostQuantumKeyAgreementEnabled() const; // The minimum and maximum protocol versions that are enabled. // (Use the SSL_PROTOCOL_VERSION_xxx enumerators defined in ssl_config.h.) // SSL 2.0/3.0 and TLS 1.0/1.1 are not supported. If version_max < // version_min, it means no protocol versions are enabled. uint16_t version_min = kDefaultSSLVersionMin; uint16_t version_max = kDefaultSSLVersionMax; // A list of cipher suites which should be explicitly prevented from being // used in addition to those disabled by the net built-in policy. // // Though cipher suites are sent in TLS as "uint8_t CipherSuite[2]", in // big-endian form, they should be declared in host byte order, with the // first uint8_t occupying the most significant byte. // Ex: To disable TLS_RSA_WITH_RC4_128_MD5, specify 0x0004, while to // disable TLS_ECDH_ECDSA_WITH_RC4_128_SHA, specify 0xC002. std::vector disabled_cipher_suites; // If specified, controls whether post-quantum key agreement in TLS // connections is allowed. If `std::nullopt`, this is determined by feature // flags. std::optional post_quantum_override; // Controls whether ECH is enabled. bool ech_enabled = true; }; // The interface for retrieving global SSL configuration. This interface // does not cover setting the SSL configuration, as on some systems, the // SSLConfigService objects may not have direct access to the configuration, or // live longer than the configuration preferences. class NET_EXPORT SSLConfigService { public: // Observer is notified when SSL config settings have changed. class NET_EXPORT Observer { public: // Notify observers if SSL settings have changed. virtual void OnSSLContextConfigChanged() = 0; protected: virtual ~Observer() = default; }; SSLConfigService(); virtual ~SSLConfigService(); // May not be thread-safe, should only be called on the IO thread. virtual SSLContextConfig GetSSLContextConfig() = 0; // Returns true if connections to |hostname| can reuse, or are permitted to // reuse, connections on which a client cert has been negotiated. Note that // this must return true for both hostnames being pooled - that is to say this // function must return true for both the hostname of the existing connection // and the potential hostname to pool before allowing the connection to be // reused. // // NOTE: Pooling connections with ambient authority can create security issues // with that ambient authority and privacy issues in that embedders (and // users) may not have been consulted to send a client cert to |hostname|. // Implementations of this method should only return true if they have // received affirmative consent (e.g. through preferences or Enterprise // policy). // // NOTE: For Web Platform clients, this violates the Fetch Standard's policies // around connection pools: https://fetch.spec.whatwg.org/#connections. // Implementations that return true should take steps to limit the Web // Platform visibility of this, such as only allowing it to be used for // Enterprise or internal configurations. // // DEPRECATED: For the reasons above, this method is temporary and will be // removed in a future release. Please leave a comment on // https://crbug.com/855690 if you believe this is needed. virtual bool CanShareConnectionWithClientCerts( std::string_view hostname) const = 0; // Add an observer of this service. void AddObserver(Observer* observer); // Remove an observer of this service. void RemoveObserver(Observer* observer); // Calls the OnSSLContextConfigChanged method of registered observers. Should // only be called on the IO thread. void NotifySSLContextConfigChange(); protected: // Process before/after config update. If |force_notification| is true, // NotifySSLContextConfigChange will be called regardless of whether // |orig_config| and |new_config| are equal. void ProcessConfigUpdate(const SSLContextConfig& orig_config, const SSLContextConfig& new_config, bool force_notification); private: base::ObserverList::Unchecked observer_list_; }; } // namespace net #endif // NET_SSL_SSL_CONFIG_SERVICE_H_