370 lines
14 KiB
C++
370 lines
14 KiB
C++
// 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.
|
|
|
|
// This class represents contextual information (cookies, cache, etc.)
|
|
// that's necessary when processing resource requests.
|
|
|
|
#ifndef NET_URL_REQUEST_URL_REQUEST_CONTEXT_H_
|
|
#define NET_URL_REQUEST_URL_REQUEST_CONTEXT_H_
|
|
|
|
#include <stdint.h>
|
|
#include <memory>
|
|
#include <set>
|
|
#include <string>
|
|
|
|
#include "base/memory/raw_ptr.h"
|
|
#include "base/memory/weak_ptr.h"
|
|
#include "base/threading/thread_checker.h"
|
|
#include "base/types/pass_key.h"
|
|
#include "build/build_config.h"
|
|
#include "build/chromeos_buildflags.h"
|
|
#include "net/base/net_export.h"
|
|
#include "net/base/network_handle.h"
|
|
#include "net/base/request_priority.h"
|
|
#include "net/log/net_log_source.h"
|
|
#include "net/net_buildflags.h"
|
|
#include "net/traffic_annotation/network_traffic_annotation.h"
|
|
#include "net/url_request/url_request.h"
|
|
#include "third_party/abseil-cpp/absl/types/optional.h"
|
|
|
|
namespace net {
|
|
class CertVerifier;
|
|
class ClientSocketFactory;
|
|
class CookieStore;
|
|
class CTPolicyEnforcer;
|
|
class HostResolver;
|
|
class HttpAuthHandlerFactory;
|
|
class HttpNetworkSession;
|
|
struct HttpNetworkSessionContext;
|
|
struct HttpNetworkSessionParams;
|
|
class HttpServerProperties;
|
|
class HttpTransactionFactory;
|
|
class HttpUserAgentSettings;
|
|
class NetLog;
|
|
class NetworkDelegate;
|
|
class NetworkQualityEstimator;
|
|
class ProxyDelegate;
|
|
class ProxyResolutionService;
|
|
class QuicContext;
|
|
class SCTAuditingDelegate;
|
|
class SSLConfigService;
|
|
class TransportSecurityPersister;
|
|
class TransportSecurityState;
|
|
class URLRequest;
|
|
class URLRequestJobFactory;
|
|
class URLRequestThrottlerManager;
|
|
class URLRequestContextBuilder;
|
|
|
|
#if BUILDFLAG(ENABLE_REPORTING)
|
|
class NetworkErrorLoggingService;
|
|
class PersistentReportingAndNelStore;
|
|
class ReportingService;
|
|
#endif // BUILDFLAG(ENABLE_REPORTING)
|
|
|
|
// Class that provides application-specific context for URLRequest
|
|
// instances. May only be created by URLRequestContextBuilder.
|
|
// Owns most of its member variables, except a few that may be shared
|
|
// with other contexts.
|
|
class NET_EXPORT URLRequestContext final {
|
|
public:
|
|
// URLRequestContext must be created by URLRequestContextBuilder.
|
|
explicit URLRequestContext(base::PassKey<URLRequestContextBuilder> pass_key);
|
|
URLRequestContext(const URLRequestContext&) = delete;
|
|
URLRequestContext& operator=(const URLRequestContext&) = delete;
|
|
|
|
~URLRequestContext();
|
|
|
|
// May return nullptr if this context doesn't have an associated network
|
|
// session.
|
|
const HttpNetworkSessionParams* GetNetworkSessionParams() const;
|
|
|
|
// May return nullptr if this context doesn't have an associated network
|
|
// session.
|
|
const HttpNetworkSessionContext* GetNetworkSessionContext() const;
|
|
|
|
// TODO(crbug.com/1052397): Revisit once build flag switch of lacros-chrome is
|
|
// complete.
|
|
#if !BUILDFLAG(IS_WIN) && \
|
|
!(BUILDFLAG(IS_LINUX) || BUILDFLAG(IS_CHROMEOS_LACROS))
|
|
// This function should not be used in Chromium, please use the version with
|
|
// NetworkTrafficAnnotationTag in the future.
|
|
//
|
|
// The unannotated method is not available on desktop Linux + Windows. It's
|
|
// available on other platforms, since we only audit network annotations on
|
|
// Linux & Windows.
|
|
std::unique_ptr<URLRequest> CreateRequest(
|
|
const GURL& url,
|
|
RequestPriority priority,
|
|
URLRequest::Delegate* delegate) const;
|
|
#endif
|
|
|
|
// `traffic_annotation` is metadata about the network traffic send via this
|
|
// URLRequest, see net::DefineNetworkTrafficAnnotation. Note that:
|
|
// - net provides the API for tagging requests with an opaque identifier.
|
|
// - chrome/browser/privacy/traffic_annotation.proto contains the Chrome
|
|
// specific .proto describing the verbose annotation format that Chrome's
|
|
// callsites are expected to follow.
|
|
// - tools/traffic_annotation/ contains sample and template for annotation and
|
|
// tools will be added for verification following crbug.com/690323.
|
|
//
|
|
// `is_for_websockets` should be true iff this was created for use by a
|
|
// websocket. HTTP/HTTPS requests fail if it's true, and WS/WSS requests fail
|
|
// if it's false. This is to protect against broken consumers.
|
|
//
|
|
// `net_log_source_id` is used to construct NetLogWithSource using the
|
|
// specified Source ID. This method is expected to be used when URLRequest
|
|
// wants to take over existing NetLogSource.
|
|
std::unique_ptr<URLRequest> CreateRequest(
|
|
const GURL& url,
|
|
RequestPriority priority,
|
|
URLRequest::Delegate* delegate,
|
|
NetworkTrafficAnnotationTag traffic_annotation,
|
|
bool is_for_websockets = false,
|
|
const absl::optional<net::NetLogSource> net_log_source =
|
|
absl::nullopt) const;
|
|
|
|
NetLog* net_log() const { return net_log_; }
|
|
|
|
HostResolver* host_resolver() const { return host_resolver_.get(); }
|
|
|
|
CertVerifier* cert_verifier() const { return cert_verifier_.get(); }
|
|
|
|
// Get the proxy service for this context.
|
|
ProxyResolutionService* proxy_resolution_service() const {
|
|
return proxy_resolution_service_.get();
|
|
}
|
|
|
|
ProxyDelegate* proxy_delegate() const { return proxy_delegate_.get(); }
|
|
|
|
// Get the ssl config service for this context.
|
|
SSLConfigService* ssl_config_service() const {
|
|
return ssl_config_service_.get();
|
|
}
|
|
|
|
// Gets the HTTP Authentication Handler Factory for this context.
|
|
// The factory is only valid for the lifetime of this URLRequestContext
|
|
HttpAuthHandlerFactory* http_auth_handler_factory() const {
|
|
return http_auth_handler_factory_.get();
|
|
}
|
|
|
|
// Gets the http transaction factory for this context.
|
|
HttpTransactionFactory* http_transaction_factory() const {
|
|
return http_transaction_factory_.get();
|
|
}
|
|
|
|
NetworkDelegate* network_delegate() const { return network_delegate_.get(); }
|
|
|
|
HttpServerProperties* http_server_properties() const {
|
|
return http_server_properties_.get();
|
|
}
|
|
|
|
// Gets the cookie store for this context (may be null, in which case
|
|
// cookies are not stored).
|
|
CookieStore* cookie_store() const { return cookie_store_.get(); }
|
|
|
|
TransportSecurityState* transport_security_state() const {
|
|
return transport_security_state_.get();
|
|
}
|
|
|
|
CTPolicyEnforcer* ct_policy_enforcer() const {
|
|
return ct_policy_enforcer_.get();
|
|
}
|
|
|
|
SCTAuditingDelegate* sct_auditing_delegate() const {
|
|
return sct_auditing_delegate_.get();
|
|
}
|
|
|
|
const URLRequestJobFactory* job_factory() const { return job_factory_; }
|
|
|
|
// May return nullptr.
|
|
URLRequestThrottlerManager* throttler_manager() const {
|
|
return throttler_manager_.get();
|
|
}
|
|
|
|
QuicContext* quic_context() const { return quic_context_.get(); }
|
|
|
|
// Gets the URLRequest objects that hold a reference to this
|
|
// URLRequestContext.
|
|
std::set<const URLRequest*>* url_requests() const {
|
|
return url_requests_.get();
|
|
}
|
|
|
|
// CHECKs that no URLRequests using this context remain. Subclasses should
|
|
// additionally call AssertNoURLRequests() within their own destructor,
|
|
// prior to implicit destruction of subclass-owned state.
|
|
void AssertNoURLRequests() const;
|
|
|
|
// Get the underlying |HttpUserAgentSettings| implementation that provides
|
|
// the HTTP Accept-Language and User-Agent header values.
|
|
const HttpUserAgentSettings* http_user_agent_settings() const {
|
|
return http_user_agent_settings_.get();
|
|
}
|
|
|
|
// Gets the NetworkQualityEstimator associated with this context.
|
|
// May return nullptr.
|
|
NetworkQualityEstimator* network_quality_estimator() const {
|
|
return network_quality_estimator_.get();
|
|
}
|
|
|
|
#if BUILDFLAG(ENABLE_REPORTING)
|
|
ReportingService* reporting_service() const {
|
|
return reporting_service_.get();
|
|
}
|
|
|
|
NetworkErrorLoggingService* network_error_logging_service() const {
|
|
return network_error_logging_service_.get();
|
|
}
|
|
#endif // BUILDFLAG(ENABLE_REPORTING)
|
|
|
|
bool enable_brotli() const { return enable_brotli_; }
|
|
|
|
// Returns current value of the |check_cleartext_permitted| flag.
|
|
bool check_cleartext_permitted() const { return check_cleartext_permitted_; }
|
|
|
|
bool require_network_isolation_key() const {
|
|
return require_network_isolation_key_;
|
|
}
|
|
|
|
// If != handles::kInvalidNetworkHandle, the network which this
|
|
// context has been bound to.
|
|
handles::NetworkHandle bound_network() const { return bound_network_; }
|
|
|
|
void AssertCalledOnValidThread() {
|
|
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
|
|
}
|
|
|
|
// DEPRECATED: Do not use this even in tests. This is for a legacy use.
|
|
void SetJobFactoryForTesting(const URLRequestJobFactory* job_factory) {
|
|
job_factory_ = job_factory;
|
|
}
|
|
|
|
private:
|
|
friend class URLRequestContextBuilder;
|
|
|
|
HttpNetworkSession* http_network_session() const {
|
|
return http_network_session_.get();
|
|
}
|
|
|
|
void set_net_log(NetLog* net_log);
|
|
void set_host_resolver(std::unique_ptr<HostResolver> host_resolver);
|
|
void set_cert_verifier(std::unique_ptr<CertVerifier> cert_verifier);
|
|
void set_proxy_resolution_service(
|
|
std::unique_ptr<ProxyResolutionService> proxy_resolution_service);
|
|
void set_proxy_delegate(std::unique_ptr<ProxyDelegate> proxy_delegate);
|
|
void set_ssl_config_service(std::unique_ptr<SSLConfigService> service);
|
|
void set_http_auth_handler_factory(
|
|
std::unique_ptr<HttpAuthHandlerFactory> factory);
|
|
void set_http_network_session(
|
|
std::unique_ptr<HttpNetworkSession> http_network_session);
|
|
void set_http_transaction_factory(
|
|
std::unique_ptr<HttpTransactionFactory> factory);
|
|
void set_network_delegate(std::unique_ptr<NetworkDelegate> network_delegate);
|
|
void set_http_server_properties(
|
|
std::unique_ptr<HttpServerProperties> http_server_properties);
|
|
void set_cookie_store(std::unique_ptr<CookieStore> cookie_store);
|
|
void set_transport_security_state(
|
|
std::unique_ptr<TransportSecurityState> state);
|
|
void set_ct_policy_enforcer(std::unique_ptr<CTPolicyEnforcer> enforcer);
|
|
void set_sct_auditing_delegate(std::unique_ptr<SCTAuditingDelegate> delegate);
|
|
void set_job_factory(std::unique_ptr<const URLRequestJobFactory> job_factory);
|
|
void set_throttler_manager(
|
|
std::unique_ptr<URLRequestThrottlerManager> throttler_manager);
|
|
void set_quic_context(std::unique_ptr<QuicContext> quic_context);
|
|
void set_http_user_agent_settings(
|
|
std::unique_ptr<const HttpUserAgentSettings> http_user_agent_settings);
|
|
void set_network_quality_estimator(
|
|
NetworkQualityEstimator* network_quality_estimator);
|
|
void set_client_socket_factory(
|
|
std::unique_ptr<ClientSocketFactory> client_socket_factory);
|
|
#if BUILDFLAG(ENABLE_REPORTING)
|
|
void set_persistent_reporting_and_nel_store(
|
|
std::unique_ptr<PersistentReportingAndNelStore>
|
|
persistent_reporting_and_nel_store);
|
|
void set_reporting_service(
|
|
std::unique_ptr<ReportingService> reporting_service);
|
|
void set_network_error_logging_service(
|
|
std::unique_ptr<NetworkErrorLoggingService>
|
|
network_error_logging_service);
|
|
#endif // BUILDFLAG(ENABLE_REPORTING)
|
|
void set_enable_brotli(bool enable_brotli) { enable_brotli_ = enable_brotli; }
|
|
void set_check_cleartext_permitted(bool check_cleartext_permitted) {
|
|
check_cleartext_permitted_ = check_cleartext_permitted;
|
|
}
|
|
void set_require_network_isolation_key(bool require_network_isolation_key) {
|
|
require_network_isolation_key_ = require_network_isolation_key;
|
|
}
|
|
void set_bound_network(handles::NetworkHandle network) {
|
|
bound_network_ = network;
|
|
}
|
|
|
|
void set_transport_security_persister(
|
|
std::unique_ptr<TransportSecurityPersister> transport_security_persister);
|
|
|
|
raw_ptr<NetLog> net_log_ = nullptr;
|
|
|
|
std::unique_ptr<HostResolver> host_resolver_;
|
|
std::unique_ptr<CertVerifier> cert_verifier_;
|
|
std::unique_ptr<HttpAuthHandlerFactory> http_auth_handler_factory_;
|
|
std::unique_ptr<ProxyDelegate> proxy_delegate_;
|
|
std::unique_ptr<NetworkDelegate> network_delegate_;
|
|
std::unique_ptr<ProxyResolutionService> proxy_resolution_service_;
|
|
std::unique_ptr<SSLConfigService> ssl_config_service_;
|
|
std::unique_ptr<HttpServerProperties> http_server_properties_;
|
|
std::unique_ptr<const HttpUserAgentSettings> http_user_agent_settings_;
|
|
std::unique_ptr<CookieStore> cookie_store_;
|
|
std::unique_ptr<TransportSecurityState> transport_security_state_;
|
|
std::unique_ptr<CTPolicyEnforcer> ct_policy_enforcer_;
|
|
std::unique_ptr<SCTAuditingDelegate> sct_auditing_delegate_;
|
|
std::unique_ptr<QuicContext> quic_context_;
|
|
std::unique_ptr<ClientSocketFactory> client_socket_factory_;
|
|
|
|
// The storage duplication for URLRequestJobFactory is needed because of
|
|
// SetJobFactoryForTesting. Once this method is removable, we can only store a
|
|
// unique_ptr similarly to the other fields.
|
|
std::unique_ptr<const URLRequestJobFactory> job_factory_storage_;
|
|
raw_ptr<const URLRequestJobFactory> job_factory_ = nullptr;
|
|
|
|
std::unique_ptr<URLRequestThrottlerManager> throttler_manager_;
|
|
|
|
#if BUILDFLAG(ENABLE_REPORTING)
|
|
// Must precede |reporting_service_| and |network_error_logging_service_|
|
|
std::unique_ptr<PersistentReportingAndNelStore>
|
|
persistent_reporting_and_nel_store_;
|
|
|
|
std::unique_ptr<ReportingService> reporting_service_;
|
|
std::unique_ptr<NetworkErrorLoggingService> network_error_logging_service_;
|
|
#endif // BUILDFLAG(ENABLE_REPORTING)
|
|
|
|
// May be used (but not owned) by the HttpTransactionFactory.
|
|
std::unique_ptr<HttpNetworkSession> http_network_session_;
|
|
|
|
// `http_transaction_factory_` might hold a raw pointer on
|
|
// `http_network_session_` so it needs to be declared last.
|
|
std::unique_ptr<HttpTransactionFactory> http_transaction_factory_;
|
|
|
|
raw_ptr<NetworkQualityEstimator> network_quality_estimator_ = nullptr;
|
|
|
|
std::unique_ptr<TransportSecurityPersister> transport_security_persister_;
|
|
|
|
std::unique_ptr<std::set<const URLRequest*>> url_requests_;
|
|
|
|
// Enables Brotli Content-Encoding support.
|
|
bool enable_brotli_ = false;
|
|
// Enables checking system policy before allowing a cleartext http or ws
|
|
// request. Only used on Android.
|
|
bool check_cleartext_permitted_ = false;
|
|
|
|
// Triggers a DCHECK if a NetworkAnonymizationKey/IsolationInfo is not
|
|
// provided to a request when true.
|
|
bool require_network_isolation_key_ = false;
|
|
|
|
handles::NetworkHandle bound_network_;
|
|
|
|
THREAD_CHECKER(thread_checker_);
|
|
};
|
|
|
|
} // namespace net
|
|
|
|
#endif // NET_URL_REQUEST_URL_REQUEST_CONTEXT_H_
|