Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1185)

Unified Diff: chrome/browser/io_thread.cc

Issue 2929153002: Use URLRequestContextBuilderMojo to create the SystemURLRequestContext. (Closed)
Patch Set: Merge Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/io_thread.cc
diff --git a/chrome/browser/io_thread.cc b/chrome/browser/io_thread.cc
index 39a8b1b3c4c1e3a3b3db046b897a4e4c6346c276..40602f82c0edc0a115d30f624ecd8d4f8552b234 100644
--- a/chrome/browser/io_thread.cc
+++ b/chrome/browser/io_thread.cc
@@ -36,6 +36,7 @@
#include "chrome/browser/data_usage/tab_id_annotator.h"
#include "chrome/browser/data_use_measurement/chrome_data_use_ascriber.h"
#include "chrome/browser/net/async_dns_field_trial.h"
+#include "chrome/browser/net/chrome_mojo_proxy_resolver_factory.h"
#include "chrome/browser/net/chrome_network_delegate.h"
#include "chrome/browser/net/dns_probe_service.h"
#include "chrome/browser/net/proxy_service_factory.h"
@@ -62,7 +63,6 @@
#include "components/variations/variations_associated_data.h"
#include "components/version_info/version_info.h"
#include "content/public/browser/browser_thread.h"
-#include "content/public/browser/cookie_store_factory.h"
#include "content/public/browser/network_quality_observer_factory.h"
#include "content/public/common/content_features.h"
#include "content/public/common/content_switches.h"
@@ -82,15 +82,15 @@
#include "net/cert/multi_threaded_cert_verifier.h"
#include "net/cert/sth_distributor.h"
#include "net/cert/sth_observer.h"
-#include "net/cookies/cookie_store.h"
#include "net/dns/host_cache.h"
#include "net/dns/host_resolver.h"
#include "net/dns/mapped_host_resolver.h"
#include "net/http/http_auth_filter.h"
#include "net/http/http_auth_handler_factory.h"
#include "net/http/http_auth_preferences.h"
-#include "net/http/http_network_layer.h"
+#include "net/http/http_network_session.h"
#include "net/http/http_server_properties_impl.h"
+#include "net/http/http_transaction_factory.h"
#include "net/net_features.h"
#include "net/nqe/external_estimate_provider.h"
#include "net/nqe/network_quality_estimator_params.h"
@@ -100,18 +100,11 @@
#include "net/quic/chromium/quic_utils_chromium.h"
#include "net/socket/ssl_client_socket.h"
#include "net/socket/tcp_client_socket.h"
-#include "net/ssl/channel_id_service.h"
-#include "net/ssl/default_channel_id_store.h"
-#include "net/url_request/data_protocol_handler.h"
-#include "net/url_request/file_protocol_handler.h"
-#include "net/url_request/ftp_protocol_handler.h"
-#include "net/url_request/static_http_user_agent_settings.h"
#include "net/url_request/url_fetcher.h"
#include "net/url_request/url_request_context.h"
#include "net/url_request/url_request_context_builder.h"
+#include "net/url_request/url_request_context_builder_mojo.h"
#include "net/url_request/url_request_context_getter.h"
-#include "net/url_request/url_request_context_storage.h"
-#include "net/url_request/url_request_job_factory_impl.h"
#include "url/url_constants.h"
#if BUILDFLAG(ENABLE_EXTENSIONS)
@@ -135,6 +128,7 @@
#if defined(OS_CHROMEOS)
#include "chrome/browser/chromeos/net/cert_verify_proc_chromeos.h"
#include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h"
+#include "chromeos/network/dhcp_proxy_script_fetcher_factory_chromeos.h"
#include "chromeos/network/host_resolver_impl_chromeos.h"
#endif
@@ -762,8 +756,9 @@ const net::HttpNetworkSession::Params& IOThread::NetworkSessionParams() const {
void IOThread::DisableQuic() {
session_params_.enable_quic = false;
- if (globals_->system_request_context_storage)
- globals_->system_request_context_storage->http_network_session()
+ if (globals_->system_request_context)
+ globals_->system_request_context->http_transaction_factory()
+ ->GetSession()
->DisableQuic();
}
@@ -807,23 +802,14 @@ bool IOThread::PacHttpsUrlStrippingEnabled() const {
void IOThread::ConstructSystemRequestContext() {
const base::CommandLine& command_line =
*base::CommandLine::ForCurrentProcess();
+ net::URLRequestContextBuilderMojo builder;
- globals_->system_request_context =
- base::MakeUnique<SystemURLRequestContext>();
- net::URLRequestContext* context = globals_->system_request_context.get();
- globals_->system_request_context_storage =
- base::MakeUnique<net::URLRequestContextStorage>(context);
- net::URLRequestContextStorage* context_storage =
- globals_->system_request_context_storage.get();
-
- context->set_network_quality_estimator(
+ builder.set_network_quality_estimator(
globals_->network_quality_estimator.get());
- context->set_enable_brotli(globals_->enable_brotli);
- context->set_name("system");
+ builder.set_enable_brotli(globals_->enable_brotli);
+ builder.set_name("system");
- context_storage->set_http_user_agent_settings(
- base::MakeUnique<net::StaticHttpUserAgentSettings>(std::string(),
- GetUserAgent()));
+ builder.set_user_agent(GetUserAgent());
std::unique_ptr<ChromeNetworkDelegate> chrome_network_delegate(
new ChromeNetworkDelegate(extension_event_router_forwarder(),
&system_enable_referrers_));
@@ -831,41 +817,27 @@ void IOThread::ConstructSystemRequestContext() {
chrome_network_delegate->set_data_use_aggregator(
globals_->data_use_aggregator.get(),
true /* is_data_usage_off_the_record */);
- context_storage->set_network_delegate(
+ builder.set_network_delegate(
globals_->data_use_ascriber->CreateNetworkDelegate(
std::move(chrome_network_delegate), GetMetricsDataUseForwarder()));
- context->set_net_log(net_log_);
- context_storage->set_host_resolver(CreateGlobalHostResolver(net_log_));
-
- context_storage->set_ssl_config_service(GetSSLConfigService());
- context_storage->set_http_auth_handler_factory(
- CreateDefaultAuthHandlerFactory(context->host_resolver()));
+ builder.set_net_log(net_log_);
+ std::unique_ptr<net::HostResolver> host_resolver(
+ CreateGlobalHostResolver(net_log_));
- // In-memory cookie store.
- context_storage->set_cookie_store(
- content::CreateCookieStore(content::CookieStoreConfig()));
- // In-memory channel ID store.
- context_storage->set_channel_id_service(
- base::MakeUnique<net::ChannelIDService>(
- new net::DefaultChannelIDStore(nullptr)));
- context->cookie_store()->SetChannelIDServiceID(
- context->channel_id_service()->GetUniqueID());
+ builder.set_ssl_config_service(GetSSLConfigService());
+ builder.SetHttpAuthHandlerFactory(
+ CreateDefaultAuthHandlerFactory(host_resolver.get()));
Randy Smith (Not in Mondays) 2017/06/13 16:42:14 nit, random thought, not necessary for this CL: Wo
mmenke 2017/06/13 17:02:22 This is an IOThread method, not a net one, and dep
- context_storage->set_transport_security_state(
- base::MakeUnique<net::TransportSecurityState>());
-
- context_storage->set_http_server_properties(
- base::MakeUnique<net::HttpServerPropertiesImpl>());
+ builder.set_host_resolver(std::move(host_resolver));
#if defined(OS_CHROMEOS)
// Creates a CertVerifyProc that doesn't allow any profile-provided certs.
- context_storage->set_cert_verifier(base::MakeUnique<net::CachingCertVerifier>(
+ builder.SetCertVerifier(base::MakeUnique<net::CachingCertVerifier>(
base::MakeUnique<net::MultiThreadedCertVerifier>(
new chromeos::CertVerifyProcChromeOS())));
#else
- context_storage->set_cert_verifier(
- IgnoreErrorsCertVerifier::MaybeWrapCertVerifier(
- command_line, net::CertVerifier::CreateDefault()));
+ builder.SetCertVerifier(IgnoreErrorsCertVerifier::MaybeWrapCertVerifier(
+ command_line, net::CertVerifier::CreateDefault()));
UMA_HISTOGRAM_BOOLEAN(
"Net.Certificate.IgnoreCertificateErrorsSPKIListPresent",
command_line.HasSwitch(switches::kIgnoreCertificateErrorsSPKIList));
@@ -879,45 +851,40 @@ void IOThread::ConstructSystemRequestContext() {
// Register the ct_tree_tracker_ as observer for verified SCTs.
ct_verifier->SetObserver(ct_tree_tracker_.get());
- context_storage->set_cert_transparency_verifier(std::move(ct_verifier));
-
- context_storage->set_ct_policy_enforcer(
- base::MakeUnique<net::CTPolicyEnforcer>());
-
- context_storage->set_proxy_service(ProxyServiceFactory::CreateProxyService(
- net_log_, context, context->network_delegate(),
- std::move(system_proxy_config_service_), command_line,
- WpadQuickCheckEnabled(), PacHttpsUrlStrippingEnabled()));
-
- net::HttpNetworkSession::Context session_context;
- net::URLRequestContextBuilder::SetHttpNetworkSessionComponents(
- context, &session_context);
-
- context_storage->set_http_network_session(
- base::MakeUnique<net::HttpNetworkSession>(session_params_,
- session_context));
- context_storage->set_http_transaction_factory(
- base::MakeUnique<net::HttpNetworkLayer>(
- context_storage->http_network_session()));
-
- std::unique_ptr<net::URLRequestJobFactoryImpl> job_factory(
- new net::URLRequestJobFactoryImpl());
-
- job_factory->SetProtocolHandler(url::kDataScheme,
- base::MakeUnique<net::DataProtocolHandler>());
Randy Smith (Not in Mondays) 2017/06/13 16:42:15 nit, not sure if it should be in this CL: The code
mmenke 2017/06/13 17:02:21 Sure, I'll update it in another CL. net can certa
- job_factory->SetProtocolHandler(
- url::kFileScheme,
- base::MakeUnique<net::FileProtocolHandler>(
- base::CreateTaskRunnerWithTraits(
- {base::MayBlock(), base::TaskPriority::USER_VISIBLE,
- base::TaskShutdownBehavior::SKIP_ON_SHUTDOWN})));
Randy Smith (Not in Mondays) 2017/06/13 16:42:15 So the conversion to using URLRequestContextBuilde
mmenke 2017/06/13 17:02:22 Good point, completely forgot about that. I'll up
mmenke 2017/06/13 17:34:41 Actually, I'm going to set the task runner via the
+ builder.set_ct_verifier(std::move(ct_verifier));
+
+ // TODO(eroman): Figure out why this doesn't work in single-process mode.
+ // Should be possible now that a private isolate is used.
+ // http://crbug.com/474654
Randy Smith (Not in Mondays) 2017/06/13 16:42:15 Sorry, I poked around a bit but eventually decided
mmenke 2017/06/13 17:02:21 There was a comment about that in the previous pat
+ if (!command_line.HasSwitch(switches::kWinHttpProxyResolver)) {
+ if (command_line.HasSwitch(switches::kSingleProcess)) {
+ LOG(ERROR) << "Cannot use V8 Proxy resolver in single process mode.";
+ } else {
+ builder.set_mojo_proxy_resolver_factory(
+ ChromeMojoProxyResolverFactory::GetInstance());
+ }
+ }
+
+ builder.set_pac_quick_check_enabled(WpadQuickCheckEnabled());
+ builder.set_pac_sanitize_url_policy(
+ PacHttpsUrlStrippingEnabled()
+ ? net::ProxyService::SanitizeUrlPolicy::SAFE
+ : net::ProxyService::SanitizeUrlPolicy::UNSAFE);
+#if defined(OS_CHROMEOS)
+ builder.set_dhcp_fetcher_factory(
+ base::MakeUnique<chromeos::DhcpProxyScriptFetcherFactoryChromeos>());
+#endif
+ builder.set_proxy_config_service(std::move(system_proxy_config_service_));
+
+ builder.set_http_network_session_params(session_params_);
+
+ builder.set_data_enabled(true);
+ builder.set_file_enabled(true);
#if !BUILDFLAG(DISABLE_FTP_SUPPORT)
- job_factory->SetProtocolHandler(
- url::kFtpScheme,
- net::FtpProtocolHandler::Create(context->host_resolver()));
+ builder.set_ftp_enabled(true);
#endif
- context_storage->set_job_factory(std::move(job_factory));
+ globals_->system_request_context = builder.Build();
}
// static

Powered by Google App Engine
This is Rietveld 408576698