Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "ios/web_view/internal/web_view_url_request_context_getter.h" | 5 #include "ios/web_view/internal/web_view_url_request_context_getter.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/base_paths.h" | 9 #include "base/base_paths.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| 11 #include "base/memory/ptr_util.h" | 11 #include "base/memory/ptr_util.h" |
| 12 #include "base/memory/ref_counted.h" | 12 #include "base/memory/ref_counted.h" |
| 13 #include "base/path_service.h" | 13 #include "base/path_service.h" |
| 14 #include "base/threading/sequenced_worker_pool.h" | 14 #include "base/threading/sequenced_worker_pool.h" |
| 15 #import "ios/net/cookies/cookie_store_ios_persistent.h" | 15 #import "ios/net/cookies/cookie_store_ios_persistent.h" |
| 16 #import "ios/web/public/web_client.h" | 16 #import "ios/web/public/web_client.h" |
| 17 #include "ios/web/public/web_thread.h" | 17 #include "ios/web/public/web_thread.h" |
| 18 #include "ios/web_view/internal/web_view_network_delegate.h" | 18 #include "ios/web_view/internal/web_view_network_delegate.h" |
| 19 #include "net/base/cache_type.h" | 19 #include "net/base/cache_type.h" |
| 20 #include "net/cert/cert_verifier.h" | 20 #include "net/cert/cert_verifier.h" |
| 21 #include "net/cert/multi_log_ct_verifier.h" | |
| 21 #include "net/dns/host_resolver.h" | 22 #include "net/dns/host_resolver.h" |
| 22 #include "net/extras/sqlite/sqlite_persistent_cookie_store.h" | 23 #include "net/extras/sqlite/sqlite_persistent_cookie_store.h" |
| 23 #include "net/http/http_auth_handler_factory.h" | 24 #include "net/http/http_auth_handler_factory.h" |
| 24 #include "net/http/http_cache.h" | 25 #include "net/http/http_cache.h" |
| 25 #include "net/http/http_network_session.h" | 26 #include "net/http/http_network_session.h" |
| 26 #include "net/http/http_server_properties_impl.h" | 27 #include "net/http/http_server_properties_impl.h" |
| 27 #include "net/http/transport_security_persister.h" | 28 #include "net/http/transport_security_persister.h" |
| 28 #include "net/http/transport_security_state.h" | 29 #include "net/http/transport_security_state.h" |
| 29 #include "net/proxy/proxy_config_service_ios.h" | 30 #include "net/proxy/proxy_config_service_ios.h" |
| 30 #include "net/proxy/proxy_service.h" | 31 #include "net/proxy/proxy_service.h" |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 91 storage_->set_http_user_agent_settings( | 92 storage_->set_http_user_agent_settings( |
| 92 base::MakeUnique<net::StaticHttpUserAgentSettings>("en-us,en", | 93 base::MakeUnique<net::StaticHttpUserAgentSettings>("en-us,en", |
| 93 user_agent)); | 94 user_agent)); |
| 94 storage_->set_proxy_service( | 95 storage_->set_proxy_service( |
| 95 net::ProxyService::CreateUsingSystemProxyResolver( | 96 net::ProxyService::CreateUsingSystemProxyResolver( |
| 96 std::move(proxy_config_service_), 0, | 97 std::move(proxy_config_service_), 0, |
| 97 url_request_context_->net_log())); | 98 url_request_context_->net_log())); |
| 98 storage_->set_ssl_config_service(new net::SSLConfigServiceDefaults); | 99 storage_->set_ssl_config_service(new net::SSLConfigServiceDefaults); |
| 99 storage_->set_cert_verifier(net::CertVerifier::CreateDefault()); | 100 storage_->set_cert_verifier(net::CertVerifier::CreateDefault()); |
| 100 | 101 |
| 101 std::unique_ptr<net::TransportSecurityState> transport_security_state = | 102 storage_->set_transport_security_state( |
| 102 base::MakeUnique<net::TransportSecurityState>(); | 103 base::MakeUnique<net::TransportSecurityState>()); |
| 103 storage_->set_transport_security_state(std::move(transport_security_state)); | 104 storage_->set_cert_transparency_verifier( |
| 105 base::WrapUnique(new net::MultiLogCTVerifier)); | |
| 106 storage_->set_ct_policy_enforcer( | |
| 107 base::WrapUnique(new net::CTPolicyEnforcer)); | |
| 104 transport_security_persister_.reset(new net::TransportSecurityPersister( | 108 transport_security_persister_.reset(new net::TransportSecurityPersister( |
| 105 transport_security_state.get(), base_path_, file_task_runner_, false)); | 109 url_request_context_->transport_security_state(), base_path_, |
|
michaeldo
2017/03/27 05:37:42
Is there a reason to change this to use |url_reque
jzw
2017/03/27 09:04:40
storage's set_transport_security_state calls std::
michaeldo
2017/03/27 23:03:46
I see thank you for the explanation. Your implemen
| |
| 110 file_task_runner_, false)); | |
| 106 storage_->set_channel_id_service(base::MakeUnique<net::ChannelIDService>( | 111 storage_->set_channel_id_service(base::MakeUnique<net::ChannelIDService>( |
| 107 new net::DefaultChannelIDStore(nullptr))); | 112 new net::DefaultChannelIDStore(nullptr))); |
| 108 storage_->set_http_server_properties( | 113 storage_->set_http_server_properties( |
| 109 std::unique_ptr<net::HttpServerProperties>( | 114 std::unique_ptr<net::HttpServerProperties>( |
| 110 new net::HttpServerPropertiesImpl())); | 115 new net::HttpServerPropertiesImpl())); |
| 111 | 116 |
| 112 std::unique_ptr<net::HostResolver> host_resolver( | 117 std::unique_ptr<net::HostResolver> host_resolver( |
| 113 net::HostResolver::CreateDefaultResolver( | 118 net::HostResolver::CreateDefaultResolver( |
| 114 url_request_context_->net_log())); | 119 url_request_context_->net_log())); |
| 115 storage_->set_http_auth_handler_factory( | 120 storage_->set_http_auth_handler_factory( |
| 116 net::HttpAuthHandlerFactory::CreateDefault(host_resolver.get())); | 121 net::HttpAuthHandlerFactory::CreateDefault(host_resolver.get())); |
| 117 storage_->set_host_resolver(std::move(host_resolver)); | 122 storage_->set_host_resolver(std::move(host_resolver)); |
| 118 | 123 |
| 119 net::HttpNetworkSession::Params network_session_params; | 124 net::HttpNetworkSession::Params network_session_params; |
| 120 network_session_params.cert_verifier = | 125 network_session_params.cert_verifier = |
| 121 url_request_context_->cert_verifier(); | 126 url_request_context_->cert_verifier(); |
| 122 network_session_params.transport_security_state = | 127 network_session_params.transport_security_state = |
| 123 url_request_context_->transport_security_state(); | 128 url_request_context_->transport_security_state(); |
| 129 network_session_params.cert_transparency_verifier = | |
| 130 url_request_context_->cert_transparency_verifier(); | |
| 124 network_session_params.channel_id_service = | 131 network_session_params.channel_id_service = |
| 125 url_request_context_->channel_id_service(); | 132 url_request_context_->channel_id_service(); |
| 126 network_session_params.net_log = url_request_context_->net_log(); | 133 network_session_params.net_log = url_request_context_->net_log(); |
| 127 network_session_params.proxy_service = | 134 network_session_params.proxy_service = |
| 128 url_request_context_->proxy_service(); | 135 url_request_context_->proxy_service(); |
| 129 network_session_params.ssl_config_service = | 136 network_session_params.ssl_config_service = |
| 130 url_request_context_->ssl_config_service(); | 137 url_request_context_->ssl_config_service(); |
| 131 network_session_params.http_auth_handler_factory = | 138 network_session_params.http_auth_handler_factory = |
| 132 url_request_context_->http_auth_handler_factory(); | 139 url_request_context_->http_auth_handler_factory(); |
| 133 network_session_params.http_server_properties = | 140 network_session_params.http_server_properties = |
| 134 url_request_context_->http_server_properties(); | 141 url_request_context_->http_server_properties(); |
| 135 network_session_params.host_resolver = | 142 network_session_params.host_resolver = |
| 136 url_request_context_->host_resolver(); | 143 url_request_context_->host_resolver(); |
| 144 network_session_params.ct_policy_enforcer = | |
| 145 url_request_context_->ct_policy_enforcer(); | |
| 137 | 146 |
| 138 base::FilePath cache_path = base_path_.Append(FILE_PATH_LITERAL("Cache")); | 147 base::FilePath cache_path = base_path_.Append(FILE_PATH_LITERAL("Cache")); |
| 139 std::unique_ptr<net::HttpCache::DefaultBackend> main_backend( | 148 std::unique_ptr<net::HttpCache::DefaultBackend> main_backend( |
| 140 new net::HttpCache::DefaultBackend(net::DISK_CACHE, | 149 new net::HttpCache::DefaultBackend(net::DISK_CACHE, |
| 141 net::CACHE_BACKEND_DEFAULT, | 150 net::CACHE_BACKEND_DEFAULT, |
| 142 cache_path, 0, cache_task_runner_)); | 151 cache_path, 0, cache_task_runner_)); |
| 143 | 152 |
| 144 storage_->set_http_network_session( | 153 storage_->set_http_network_session( |
| 145 base::MakeUnique<net::HttpNetworkSession>(network_session_params)); | 154 base::MakeUnique<net::HttpNetworkSession>(network_session_params)); |
| 146 storage_->set_http_transaction_factory(base::MakeUnique<net::HttpCache>( | 155 storage_->set_http_transaction_factory(base::MakeUnique<net::HttpCache>( |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 158 | 167 |
| 159 return url_request_context_.get(); | 168 return url_request_context_.get(); |
| 160 } | 169 } |
| 161 | 170 |
| 162 scoped_refptr<base::SingleThreadTaskRunner> | 171 scoped_refptr<base::SingleThreadTaskRunner> |
| 163 WebViewURLRequestContextGetter::GetNetworkTaskRunner() const { | 172 WebViewURLRequestContextGetter::GetNetworkTaskRunner() const { |
| 164 return network_task_runner_; | 173 return network_task_runner_; |
| 165 } | 174 } |
| 166 | 175 |
| 167 } // namespace ios_web_view | 176 } // namespace ios_web_view |
| OLD | NEW |