Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "net/url_request/url_request_context_builder.h" | 5 #include "net/url_request/url_request_context_builder.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
| 10 #include "base/compiler_specific.h" | 10 #include "base/compiler_specific.h" |
| 11 #include "base/logging.h" | 11 #include "base/logging.h" |
| 12 #include "base/single_thread_task_runner.h" | 12 #include "base/single_thread_task_runner.h" |
| 13 #include "base/strings/string_util.h" | 13 #include "base/strings/string_util.h" |
| 14 #include "base/thread_task_runner_handle.h" | 14 #include "base/thread_task_runner_handle.h" |
| 15 #include "base/threading/thread.h" | 15 #include "base/threading/thread.h" |
| 16 #include "net/base/cache_type.h" | 16 #include "net/base/cache_type.h" |
| 17 #include "net/base/net_errors.h" | 17 #include "net/base/net_errors.h" |
| 18 #include "net/base/network_delegate_impl.h" | 18 #include "net/base/network_delegate_impl.h" |
| 19 #include "net/base/sdch_manager.h" | 19 #include "net/base/sdch_manager.h" |
| 20 #include "net/cert/cert_verifier.h" | 20 #include "net/cert/cert_verifier.h" |
| 21 #include "net/cookies/cookie_monster.h" | 21 #include "net/cookies/cookie_monster.h" |
| 22 #include "net/dns/host_resolver.h" | 22 #include "net/dns/host_resolver.h" |
| 23 #include "net/ftp/ftp_network_layer.h" | 23 #include "net/ftp/ftp_network_layer.h" |
| 24 #include "net/http/http_auth_handler_factory.h" | 24 #include "net/http/http_auth_handler_factory.h" |
| 25 #include "net/http/http_cache.h" | 25 #include "net/http/http_cache.h" |
| 26 #include "net/http/http_network_layer.h" | 26 #include "net/http/http_network_layer.h" |
| 27 #include "net/http/http_network_session.h" | 27 #include "net/http/http_network_session.h" |
| 28 #include "net/http/http_server_properties_impl.h" | 28 #include "net/http/http_server_properties_impl.h" |
| 29 #include "net/http/http_server_properties_manager.h" | |
| 29 #include "net/http/transport_security_persister.h" | 30 #include "net/http/transport_security_persister.h" |
| 30 #include "net/http/transport_security_state.h" | 31 #include "net/http/transport_security_state.h" |
| 31 #include "net/ssl/channel_id_service.h" | 32 #include "net/ssl/channel_id_service.h" |
| 32 #include "net/ssl/default_channel_id_store.h" | 33 #include "net/ssl/default_channel_id_store.h" |
| 33 #include "net/ssl/ssl_config_service_defaults.h" | 34 #include "net/ssl/ssl_config_service_defaults.h" |
| 34 #include "net/url_request/data_protocol_handler.h" | 35 #include "net/url_request/data_protocol_handler.h" |
| 35 #include "net/url_request/static_http_user_agent_settings.h" | 36 #include "net/url_request/static_http_user_agent_settings.h" |
| 36 #include "net/url_request/url_request_context.h" | 37 #include "net/url_request/url_request_context.h" |
| 37 #include "net/url_request/url_request_context_storage.h" | 38 #include "net/url_request/url_request_context_storage.h" |
| 38 #include "net/url_request/url_request_intercepting_job_factory.h" | 39 #include "net/url_request/url_request_intercepting_job_factory.h" |
| (...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 143 file_task_runner_ = file_thread_->task_runner(); | 144 file_task_runner_ = file_thread_->task_runner(); |
| 144 } | 145 } |
| 145 return file_task_runner_; | 146 return file_task_runner_; |
| 146 } | 147 } |
| 147 | 148 |
| 148 void set_transport_security_persister( | 149 void set_transport_security_persister( |
| 149 scoped_ptr<TransportSecurityPersister> transport_security_persister) { | 150 scoped_ptr<TransportSecurityPersister> transport_security_persister) { |
| 150 transport_security_persister = transport_security_persister.Pass(); | 151 transport_security_persister = transport_security_persister.Pass(); |
| 151 } | 152 } |
| 152 | 153 |
| 154 // Sets a HttpServerPropertiesManager. Note that the manager must be | |
| 155 // initialized prior to this call. | |
| 156 void set_http_server_properties_manager( | |
| 157 scoped_ptr<HttpServerPropertiesManager> http_server_properties_manager) { | |
| 158 http_server_properties_manager_ = http_server_properties_manager.Pass(); | |
| 159 set_http_server_properties(http_server_properties_manager_->GetWeakPtr()); | |
| 160 } | |
| 161 | |
| 153 protected: | 162 protected: |
| 154 ~BasicURLRequestContext() override { AssertNoURLRequests(); } | 163 ~BasicURLRequestContext() override { |
| 164 AssertNoURLRequests(); | |
| 165 // Shut down the |http_server_properties_manager_| if there is one, since | |
| 166 // this is the only place in BasicURLRequestContext to do so. | |
| 167 // Note that the shutdown is performed on the network thread. | |
| 168 if (http_server_properties_manager_) | |
| 169 http_server_properties_manager_->ShutdownOnPrefThread(); | |
|
mmenke
2015/07/07 20:28:12
Isn't the pref thread actually the file thread? I
xunjieli
2015/07/08 20:07:22
Why does the pref thread need to be the file threa
mmenke
2015/07/08 20:21:48
I'm not sure. The pref code doesn't say much abou
xunjieli
2015/07/09 15:51:02
Done. I made the builder take in a weak ptr of the
| |
| 170 } | |
| 155 | 171 |
| 156 private: | 172 private: |
| 157 // The thread should be torn down last. | 173 // The thread should be torn down last. |
| 158 scoped_ptr<base::Thread> file_thread_; | 174 scoped_ptr<base::Thread> file_thread_; |
| 159 scoped_refptr<base::SingleThreadTaskRunner> file_task_runner_; | 175 scoped_refptr<base::SingleThreadTaskRunner> file_task_runner_; |
| 160 | 176 |
| 161 URLRequestContextStorage storage_; | 177 URLRequestContextStorage storage_; |
| 162 scoped_ptr<TransportSecurityPersister> transport_security_persister_; | 178 scoped_ptr<TransportSecurityPersister> transport_security_persister_; |
| 179 scoped_ptr<HttpServerPropertiesManager> http_server_properties_manager_; | |
| 163 | 180 |
| 164 DISALLOW_COPY_AND_ASSIGN(BasicURLRequestContext); | 181 DISALLOW_COPY_AND_ASSIGN(BasicURLRequestContext); |
| 165 }; | 182 }; |
| 166 | 183 |
| 167 } // namespace | 184 } // namespace |
| 168 | 185 |
| 169 URLRequestContextBuilder::HttpCacheParams::HttpCacheParams() | 186 URLRequestContextBuilder::HttpCacheParams::HttpCacheParams() |
| 170 : type(IN_MEMORY), | 187 : type(IN_MEMORY), |
| 171 max_size(0) {} | 188 max_size(0) {} |
| 172 URLRequestContextBuilder::HttpCacheParams::~HttpCacheParams() {} | 189 URLRequestContextBuilder::HttpCacheParams::~HttpCacheParams() {} |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 236 DCHECK(cookie_store); | 253 DCHECK(cookie_store); |
| 237 cookie_store_ = cookie_store; | 254 cookie_store_ = cookie_store; |
| 238 channel_id_service_ = channel_id_service.Pass(); | 255 channel_id_service_ = channel_id_service.Pass(); |
| 239 } | 256 } |
| 240 | 257 |
| 241 void URLRequestContextBuilder::SetFileTaskRunner( | 258 void URLRequestContextBuilder::SetFileTaskRunner( |
| 242 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner) { | 259 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner) { |
| 243 file_task_runner_ = task_runner; | 260 file_task_runner_ = task_runner; |
| 244 } | 261 } |
| 245 | 262 |
| 263 void URLRequestContextBuilder::SetHttpServerPropertiesManager( | |
| 264 scoped_ptr<HttpServerPropertiesManager> http_server_properties_manager) { | |
| 265 http_server_properties_manager_ = http_server_properties_manager.Pass(); | |
| 266 } | |
| 267 | |
| 246 URLRequestContext* URLRequestContextBuilder::Build() { | 268 URLRequestContext* URLRequestContextBuilder::Build() { |
| 247 BasicURLRequestContext* context = | 269 BasicURLRequestContext* context = |
| 248 new BasicURLRequestContext(file_task_runner_); | 270 new BasicURLRequestContext(file_task_runner_); |
| 249 URLRequestContextStorage* storage = context->storage(); | 271 URLRequestContextStorage* storage = context->storage(); |
| 250 | 272 |
| 251 storage->set_http_user_agent_settings(new StaticHttpUserAgentSettings( | 273 storage->set_http_user_agent_settings(new StaticHttpUserAgentSettings( |
| 252 accept_language_, user_agent_)); | 274 accept_language_, user_agent_)); |
| 253 | 275 |
| 254 if (!network_delegate_) | 276 if (!network_delegate_) |
| 255 network_delegate_.reset(new BasicNetworkDelegate); | 277 network_delegate_.reset(new BasicNetworkDelegate); |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 319 storage->set_transport_security_state(new TransportSecurityState()); | 341 storage->set_transport_security_state(new TransportSecurityState()); |
| 320 if (!transport_security_persister_path_.empty()) { | 342 if (!transport_security_persister_path_.empty()) { |
| 321 context->set_transport_security_persister( | 343 context->set_transport_security_persister( |
| 322 make_scoped_ptr<TransportSecurityPersister>( | 344 make_scoped_ptr<TransportSecurityPersister>( |
| 323 new TransportSecurityPersister(context->transport_security_state(), | 345 new TransportSecurityPersister(context->transport_security_state(), |
| 324 transport_security_persister_path_, | 346 transport_security_persister_path_, |
| 325 context->GetFileTaskRunner(), | 347 context->GetFileTaskRunner(), |
| 326 false))); | 348 false))); |
| 327 } | 349 } |
| 328 | 350 |
| 329 storage->set_http_server_properties( | 351 if (http_server_properties_manager_) { |
| 330 scoped_ptr<HttpServerProperties>(new HttpServerPropertiesImpl())); | 352 context->set_http_server_properties_manager( |
| 353 http_server_properties_manager_.Pass()); | |
| 354 } else { | |
| 355 storage->set_http_server_properties( | |
| 356 scoped_ptr<HttpServerProperties>(new HttpServerPropertiesImpl())); | |
| 357 } | |
| 358 | |
| 331 storage->set_cert_verifier(CertVerifier::CreateDefault()); | 359 storage->set_cert_verifier(CertVerifier::CreateDefault()); |
| 332 | 360 |
| 333 if (throttling_enabled_) | 361 if (throttling_enabled_) |
| 334 storage->set_throttler_manager(new URLRequestThrottlerManager()); | 362 storage->set_throttler_manager(new URLRequestThrottlerManager()); |
| 335 | 363 |
| 336 HttpNetworkSession::Params network_session_params; | 364 HttpNetworkSession::Params network_session_params; |
| 337 network_session_params.host_resolver = context->host_resolver(); | 365 network_session_params.host_resolver = context->host_resolver(); |
| 338 network_session_params.cert_verifier = context->cert_verifier(); | 366 network_session_params.cert_verifier = context->cert_verifier(); |
| 339 network_session_params.transport_security_state = | 367 network_session_params.transport_security_state = |
| 340 context->transport_security_state(); | 368 context->transport_security_state(); |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 421 } | 449 } |
| 422 url_request_interceptors_.weak_clear(); | 450 url_request_interceptors_.weak_clear(); |
| 423 } | 451 } |
| 424 storage->set_job_factory(top_job_factory.release()); | 452 storage->set_job_factory(top_job_factory.release()); |
| 425 // TODO(willchan): Support sdch. | 453 // TODO(willchan): Support sdch. |
| 426 | 454 |
| 427 return context; | 455 return context; |
| 428 } | 456 } |
| 429 | 457 |
| 430 } // namespace net | 458 } // namespace net |
| OLD | NEW |