Chromium Code Reviews| Index: mojo/services/network/network_context.cc |
| diff --git a/mojo/services/network/network_context.cc b/mojo/services/network/network_context.cc |
| index 7c777aaddf3f372db45076e5b6a4dccd46128510..da57f5fdc20da42243db0fc1b37655d329cb9745 100644 |
| --- a/mojo/services/network/network_context.cc |
| +++ b/mojo/services/network/network_context.cc |
| @@ -6,109 +6,29 @@ |
| #include "base/base_paths.h" |
| #include "base/path_service.h" |
| -#include "net/cert/cert_verifier.h" |
| -#include "net/cookies/cookie_monster.h" |
| -#include "net/http/http_cache.h" |
| -#include "net/http/http_network_session.h" |
| -#include "net/http/http_server_properties_impl.h" |
| -#include "net/http/transport_security_persister.h" |
| -#include "net/http/transport_security_state.h" |
| #include "net/proxy/proxy_service.h" |
| -#include "net/ssl/default_server_bound_cert_store.h" |
| -#include "net/ssl/server_bound_cert_service.h" |
| -#include "net/ssl/ssl_config_service_defaults.h" |
| -#include "net/url_request/file_protocol_handler.h" |
| -#include "net/url_request/static_http_user_agent_settings.h" |
| #include "net/url_request/url_request_context.h" |
| -#include "net/url_request/url_request_context_storage.h" |
| -#include "net/url_request/url_request_job_factory_impl.h" |
| +#include "net/url_request/url_request_context_builder.h" |
| namespace mojo { |
| -NetworkContext::NetworkContext(const base::FilePath& base_path) |
| - : file_thread_("network_file_thread"), |
| - cache_thread_("network_cache_thread") { |
| - file_thread_.Start(); |
| - |
| - base::Thread::Options options; |
| - options.message_loop_type = base::MessageLoop::TYPE_IO; |
| - cache_thread_.StartWithOptions(options); |
| - |
| - url_request_context_.reset(new net::URLRequestContext()); |
| - url_request_context_->set_net_log(net_log_.get()); |
| - |
| - storage_.reset( |
| - new net::URLRequestContextStorage(url_request_context_.get())); |
| - |
| - storage_->set_cookie_store(new net::CookieMonster(NULL, NULL)); |
| - |
| +NetworkContext::NetworkContext(const base::FilePath& base_path) { |
| + net::URLRequestContextBuilder builder; |
| + builder.set_accept_language("en-us,en"); |
| // TODO(darin): This is surely the wrong UA string. |
| - storage_->set_http_user_agent_settings( |
| - new net::StaticHttpUserAgentSettings("en-us,en", "Mojo/0.1")); |
| - |
| - storage_->set_proxy_service(net::ProxyService::CreateDirect()); |
| - storage_->set_ssl_config_service(new net::SSLConfigServiceDefaults); |
| - storage_->set_cert_verifier(net::CertVerifier::CreateDefault()); |
| - |
| - net::TransportSecurityState* transport_security_state = |
| - new net::TransportSecurityState(); |
| - storage_->set_transport_security_state(transport_security_state); |
| - |
| - transport_security_persister_.reset( |
| - new net::TransportSecurityPersister( |
| - transport_security_state, |
| - base_path, |
| - file_thread_.message_loop_proxy(), |
| - false)); |
| - |
| - storage_->set_server_bound_cert_service( |
| - new net::ServerBoundCertService( |
|
mef
2014/06/30 21:42:58
do we need this?
mmenke
2014/06/30 21:55:25
We do, and I added this to the builder (See line 3
|
| - new net::DefaultServerBoundCertStore(NULL), |
| - file_thread_.message_loop_proxy())); |
| - storage_->set_http_server_properties( |
| - scoped_ptr<net::HttpServerProperties>( |
| - new net::HttpServerPropertiesImpl())); |
| - storage_->set_host_resolver(net::HostResolver::CreateDefaultResolver( |
| - url_request_context_->net_log())); |
| - |
| - net::HttpNetworkSession::Params network_session_params; |
| - network_session_params.cert_verifier = |
| - url_request_context_->cert_verifier(); |
| - network_session_params.transport_security_state = |
| - url_request_context_->transport_security_state(); |
| - network_session_params.server_bound_cert_service = |
| - url_request_context_->server_bound_cert_service(); |
| - network_session_params.net_log = |
| - url_request_context_->net_log(); |
| - network_session_params.proxy_service = |
| - url_request_context_->proxy_service(); |
| - network_session_params.ssl_config_service = |
| - url_request_context_->ssl_config_service(); |
| - network_session_params.http_server_properties = |
| - url_request_context_->http_server_properties(); |
| - network_session_params.host_resolver = |
| - url_request_context_->host_resolver(); |
| + builder.set_user_agent("Mojo/0.1"); |
| + builder.set_proxy_service(net::ProxyService::CreateDirect()); |
| + builder.set_transport_security_persister_path(base_path); |
| base::FilePath cache_path = base_path.Append(FILE_PATH_LITERAL("Cache")); |
| + net::URLRequestContextBuilder::HttpCacheParams cache_params; |
| + cache_params.path = base_path.Append(FILE_PATH_LITERAL("Cache")); |
|
mef
2014/06/30 21:42:58
shouldn't this be |cache_path|?
mmenke
2014/06/30 21:55:25
Actually, I meant to delete the cache_path line (W
|
| + cache_params.type = net::URLRequestContextBuilder::HttpCacheParams::IN_MEMORY; |
|
mef
2014/06/30 21:42:59
Why change from DISK_CACHE to IN_MEMORY?
mmenke
2014/06/30 21:55:25
Eee...That would have been bad! Thanks for catchi
|
| + builder.EnableHttpCache(cache_params); |
| - net::HttpCache::DefaultBackend* main_backend = |
| - new net::HttpCache::DefaultBackend( |
| - net::DISK_CACHE, |
| - net::CACHE_BACKEND_DEFAULT, |
| - cache_path, |
| - 0, |
| - cache_thread_.message_loop_proxy()); |
| - |
| - net::HttpCache* main_cache = new net::HttpCache( |
| - network_session_params, main_backend); |
| - storage_->set_http_transaction_factory(main_cache); |
| + builder.set_file_enabled(true); |
| - scoped_ptr<net::URLRequestJobFactoryImpl> job_factory( |
| - new net::URLRequestJobFactoryImpl()); |
| - job_factory->SetProtocolHandler( |
| - "file", |
| - new net::FileProtocolHandler(file_thread_.message_loop_proxy())); |
| - storage_->set_job_factory(job_factory.release()); |
| + url_request_context_.reset(builder.Build()); |
| } |
| NetworkContext::~NetworkContext() { |