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..a99652218c5af28be20b878c3aba7de92394823d 100644 |
--- a/mojo/services/network/network_context.cc |
+++ b/mojo/services/network/network_context.cc |
@@ -6,109 +6,28 @@ |
#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( |
- 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(); |
- |
- base::FilePath cache_path = base_path.Append(FILE_PATH_LITERAL("Cache")); |
+ builder.set_user_agent("Mojo/0.1"); |
+ builder.set_proxy_service(net::ProxyService::CreateDirect()); |
+ builder.set_transport_security_persister_path(base_path); |
- 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::URLRequestContextBuilder::HttpCacheParams cache_params; |
+ cache_params.path = base_path.Append(FILE_PATH_LITERAL("Cache")); |
+ cache_params.type = net::URLRequestContextBuilder::HttpCacheParams::DISK; |
+ builder.EnableHttpCache(cache_params); |
- 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() { |