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

Side by Side Diff: chrome/service/net/service_url_request_context_getter.cc

Issue 354693004: Switch to using URLRequestContextBuilder to create some URLRequestContexts. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix merge Created 6 years, 5 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/service/net/service_url_request_context.h" 5 #include "chrome/service/net/service_url_request_context_getter.h"
6 6
7 #if defined(OS_POSIX) && !defined(OS_MACOSX) 7 #if defined(OS_POSIX) && !defined(OS_MACOSX)
8 #include <sys/utsname.h> 8 #include <sys/utsname.h>
9 #endif 9 #endif
10 10
11 #include "base/compiler_specific.h" 11 #include "base/compiler_specific.h"
12 #include "base/message_loop/message_loop_proxy.h" 12 #include "base/message_loop/message_loop_proxy.h"
13 #include "base/strings/stringprintf.h" 13 #include "base/strings/stringprintf.h"
14 #include "base/sys_info.h" 14 #include "base/sys_info.h"
15 #include "chrome/common/chrome_version_info.h" 15 #include "chrome/common/chrome_version_info.h"
16 #include "chrome/service/service_process.h" 16 #include "chrome/service/service_process.h"
17 #include "net/cert/cert_verifier.h"
18 #include "net/cookies/cookie_monster.h"
19 #include "net/dns/host_resolver.h"
20 #include "net/http/http_auth_handler_factory.h"
21 #include "net/http/http_cache.h"
22 #include "net/http/http_network_session.h"
23 #include "net/http/http_server_properties_impl.h"
24 #include "net/proxy/proxy_config_service.h" 17 #include "net/proxy/proxy_config_service.h"
25 #include "net/proxy/proxy_service.h" 18 #include "net/proxy/proxy_service.h"
26 #include "net/ssl/ssl_config_service_defaults.h" 19 #include "net/url_request/url_request_context_builder.h"
27 #include "net/url_request/static_http_user_agent_settings.h"
28 #include "net/url_request/url_request_job_factory_impl.h"
29 #include "net/url_request/url_request_throttler_manager.h"
30 20
31 namespace { 21 namespace {
32 // Copied from webkit/glue/user_agent.cc. We don't want to pull in a dependency 22 // Copied from webkit/glue/user_agent.cc. We don't want to pull in a dependency
33 // on webkit/glue which also pulls in the renderer. Also our user-agent is 23 // on webkit/glue which also pulls in the renderer. Also our user-agent is
34 // totally different from the user-agent used by the browser, just the 24 // totally different from the user-agent used by the browser, just the
35 // OS-specific parts are common. 25 // OS-specific parts are common.
36 std::string BuildOSCpuInfo() { 26 std::string BuildOSCpuInfo() {
37 std::string os_cpu; 27 std::string os_cpu;
38 28
39 #if defined(OS_WIN) || defined(OS_MACOSX) || defined(OS_CHROMEOS) 29 #if defined(OS_WIN) || defined(OS_MACOSX) || defined(OS_CHROMEOS)
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
79 #else 69 #else
80 "%s %s", 70 "%s %s",
81 unixinfo.sysname, // e.g. Linux 71 unixinfo.sysname, // e.g. Linux
82 cputype.c_str() // e.g. i686 72 cputype.c_str() // e.g. i686
83 #endif 73 #endif
84 ); // NOLINT 74 ); // NOLINT
85 75
86 return os_cpu; 76 return os_cpu;
87 } 77 }
88 78
79 // Returns the default user agent.
89 std::string MakeUserAgentForServiceProcess() { 80 std::string MakeUserAgentForServiceProcess() {
90 std::string user_agent; 81 std::string user_agent;
91 chrome::VersionInfo version_info; 82 chrome::VersionInfo version_info;
92 if (!version_info.is_valid()) { 83 if (!version_info.is_valid()) {
93 DLOG(ERROR) << "Unable to create chrome::VersionInfo object"; 84 DLOG(ERROR) << "Unable to create chrome::VersionInfo object";
94 } 85 }
95 std::string extra_version_info; 86 std::string extra_version_info;
96 if (!version_info.IsOfficialBuild()) 87 if (!version_info.IsOfficialBuild())
97 extra_version_info = "-devel"; 88 extra_version_info = "-devel";
98 base::StringAppendF(&user_agent, 89 base::StringAppendF(&user_agent,
99 "Chrome Service %s(%s)%s %s ", 90 "Chrome Service %s(%s)%s %s ",
100 version_info.Version().c_str(), 91 version_info.Version().c_str(),
101 version_info.LastChange().c_str(), 92 version_info.LastChange().c_str(),
102 extra_version_info.c_str(), 93 extra_version_info.c_str(),
103 BuildOSCpuInfo().c_str()); 94 BuildOSCpuInfo().c_str());
104 return user_agent; 95 return user_agent;
105 } 96 }
106 97
107 } // namespace 98 } // namespace
108 99
109 ServiceURLRequestContext::ServiceURLRequestContext(
110 const std::string& user_agent,
111 net::ProxyConfigService* net_proxy_config_service)
112 : storage_(this) {
113 storage_.set_host_resolver(net::HostResolver::CreateDefaultResolver(NULL));
114 storage_.set_proxy_service(net::ProxyService::CreateUsingSystemProxyResolver(
115 net_proxy_config_service, 0u, NULL));
116 storage_.set_cert_verifier(net::CertVerifier::CreateDefault());
117 storage_.set_ssl_config_service(new net::SSLConfigServiceDefaults);
118 storage_.set_http_auth_handler_factory(
119 net::HttpAuthHandlerFactory::CreateDefault(host_resolver()));
120 storage_.set_http_server_properties(
121 scoped_ptr<net::HttpServerProperties>(
122 new net::HttpServerPropertiesImpl()));
123 storage_.set_transport_security_state(new net::TransportSecurityState);
124 storage_.set_throttler_manager(new net::URLRequestThrottlerManager);
125
126 net::HttpNetworkSession::Params session_params;
127 session_params.host_resolver = host_resolver();
128 session_params.cert_verifier = cert_verifier();
129 session_params.transport_security_state = transport_security_state();
130 session_params.proxy_service = proxy_service();
131 session_params.ssl_config_service = ssl_config_service();
132 session_params.http_auth_handler_factory = http_auth_handler_factory();
133 session_params.http_server_properties = http_server_properties();
134 scoped_refptr<net::HttpNetworkSession> network_session(
135 new net::HttpNetworkSession(session_params));
136 storage_.set_http_transaction_factory(new net::HttpCache(
137 network_session.get(), net::HttpCache::DefaultBackend::InMemory(0)));
138 // In-memory cookie store.
139 storage_.set_cookie_store(new net::CookieMonster(NULL, NULL));
140 storage_.set_job_factory(new net::URLRequestJobFactoryImpl());
141 storage_.set_http_user_agent_settings(new net::StaticHttpUserAgentSettings(
142 "en-us,fr", user_agent));
143 }
144
145 ServiceURLRequestContext::~ServiceURLRequestContext() {
146 }
147
148 ServiceURLRequestContextGetter::ServiceURLRequestContextGetter() 100 ServiceURLRequestContextGetter::ServiceURLRequestContextGetter()
149 : network_task_runner_( 101 : user_agent_(MakeUserAgentForServiceProcess()),
102 network_task_runner_(
150 g_service_process->io_thread()->message_loop_proxy()) { 103 g_service_process->io_thread()->message_loop_proxy()) {
151 // Build the default user agent.
152 user_agent_ = MakeUserAgentForServiceProcess();
153
154 // TODO(sanjeevr): Change CreateSystemProxyConfigService to accept a 104 // TODO(sanjeevr): Change CreateSystemProxyConfigService to accept a
155 // MessageLoopProxy* instead of MessageLoop*. 105 // MessageLoopProxy* instead of MessageLoop*.
156 DCHECK(g_service_process); 106 DCHECK(g_service_process);
157 proxy_config_service_.reset(net::ProxyService::CreateSystemProxyConfigService( 107 proxy_config_service_.reset(net::ProxyService::CreateSystemProxyConfigService(
158 g_service_process->io_thread()->message_loop_proxy().get(), 108 g_service_process->io_thread()->message_loop_proxy().get(),
159 g_service_process->file_thread()->message_loop())); 109 g_service_process->file_thread()->message_loop()));
160 } 110 }
161 111
162 net::URLRequestContext* 112 net::URLRequestContext*
163 ServiceURLRequestContextGetter::GetURLRequestContext() { 113 ServiceURLRequestContextGetter::GetURLRequestContext() {
164 if (!url_request_context_.get()) 114 if (!url_request_context_.get()) {
165 url_request_context_.reset( 115 net::URLRequestContextBuilder builder;
166 new ServiceURLRequestContext(user_agent_, 116 builder.set_user_agent(user_agent_);
167 proxy_config_service_.release())); 117 builder.set_accept_language("en-us,fr");
118 builder.set_proxy_config_service(proxy_config_service_.release());
119 builder.set_throttling_enabled(true);
120 url_request_context_.reset(builder.Build());
121 }
168 return url_request_context_.get(); 122 return url_request_context_.get();
169 } 123 }
170 124
171 scoped_refptr<base::SingleThreadTaskRunner> 125 scoped_refptr<base::SingleThreadTaskRunner>
172 ServiceURLRequestContextGetter::GetNetworkTaskRunner() const { 126 ServiceURLRequestContextGetter::GetNetworkTaskRunner() const {
173 return network_task_runner_; 127 return network_task_runner_;
174 } 128 }
175 129
176 ServiceURLRequestContextGetter::~ServiceURLRequestContextGetter() {} 130 ServiceURLRequestContextGetter::~ServiceURLRequestContextGetter() {}
OLDNEW
« no previous file with comments | « chrome/service/net/service_url_request_context_getter.h ('k') | chrome/service/service_process.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698