| 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/socket/client_socket_pool_manager_impl.h" | 5 #include "net/socket/client_socket_pool_manager_impl.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/values.h" | 8 #include "base/values.h" |
| 9 #include "net/http/http_network_session.h" | 9 #include "net/http/http_network_session.h" |
| 10 #include "net/http/http_proxy_client_socket_pool.h" | 10 #include "net/http/http_proxy_client_socket_pool.h" |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 72 : new TransportClientSocketPool(max_sockets_per_pool(pool_type), | 72 : new TransportClientSocketPool(max_sockets_per_pool(pool_type), |
| 73 max_sockets_per_group(pool_type), | 73 max_sockets_per_group(pool_type), |
| 74 &transport_pool_histograms_, | 74 &transport_pool_histograms_, |
| 75 host_resolver, | 75 host_resolver, |
| 76 socket_factory_, | 76 socket_factory_, |
| 77 net_log)), | 77 net_log)), |
| 78 ssl_pool_histograms_("SSL2"), | 78 ssl_pool_histograms_("SSL2"), |
| 79 ssl_socket_pool_(new SSLClientSocketPool(max_sockets_per_pool(pool_type), | 79 ssl_socket_pool_(new SSLClientSocketPool(max_sockets_per_pool(pool_type), |
| 80 max_sockets_per_group(pool_type), | 80 max_sockets_per_group(pool_type), |
| 81 &ssl_pool_histograms_, | 81 &ssl_pool_histograms_, |
| 82 host_resolver, | |
| 83 cert_verifier, | 82 cert_verifier, |
| 84 channel_id_service, | 83 channel_id_service, |
| 85 transport_security_state, | 84 transport_security_state, |
| 86 cert_transparency_verifier, | 85 cert_transparency_verifier, |
| 87 cert_policy_enforcer, | 86 cert_policy_enforcer, |
| 88 ssl_session_cache_shard, | 87 ssl_session_cache_shard, |
| 89 socket_factory, | 88 socket_factory, |
| 90 transport_socket_pool_.get(), | 89 transport_socket_pool_.get(), |
| 91 NULL /* no socks proxy */, | 90 NULL /* no socks proxy */, |
| 92 NULL /* no http proxy */, | 91 NULL /* no http proxy */, |
| (...skipping 195 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 288 max_sockets_per_proxy_server(pool_type_), | 287 max_sockets_per_proxy_server(pool_type_), |
| 289 max_sockets_per_group(pool_type_), | 288 max_sockets_per_group(pool_type_), |
| 290 &transport_for_https_proxy_pool_histograms_, | 289 &transport_for_https_proxy_pool_histograms_, |
| 291 host_resolver_, | 290 host_resolver_, |
| 292 socket_factory_, | 291 socket_factory_, |
| 293 net_log_))); | 292 net_log_))); |
| 294 DCHECK(tcp_https_ret.second); | 293 DCHECK(tcp_https_ret.second); |
| 295 | 294 |
| 296 std::pair<SSLSocketPoolMap::iterator, bool> ssl_https_ret = | 295 std::pair<SSLSocketPoolMap::iterator, bool> ssl_https_ret = |
| 297 ssl_socket_pools_for_https_proxies_.insert(std::make_pair( | 296 ssl_socket_pools_for_https_proxies_.insert(std::make_pair( |
| 298 http_proxy, | 297 http_proxy, new SSLClientSocketPool( |
| 299 new SSLClientSocketPool( | 298 max_sockets_per_proxy_server(pool_type_), |
| 300 max_sockets_per_proxy_server(pool_type_), | 299 max_sockets_per_group(pool_type_), |
| 301 max_sockets_per_group(pool_type_), | 300 &ssl_for_https_proxy_pool_histograms_, cert_verifier_, |
| 302 &ssl_for_https_proxy_pool_histograms_, host_resolver_, | 301 channel_id_service_, transport_security_state_, |
| 303 cert_verifier_, channel_id_service_, transport_security_state_, | 302 cert_transparency_verifier_, cert_policy_enforcer_, |
| 304 cert_transparency_verifier_, cert_policy_enforcer_, | 303 ssl_session_cache_shard_, socket_factory_, |
| 305 ssl_session_cache_shard_, socket_factory_, | 304 tcp_https_ret.first->second /* https proxy */, |
| 306 tcp_https_ret.first->second /* https proxy */, | 305 NULL /* no socks proxy */, NULL /* no http proxy */, |
| 307 NULL /* no socks proxy */, NULL /* no http proxy */, | 306 ssl_config_service_.get(), |
| 308 ssl_config_service_.get(), enable_ssl_connect_job_waiting_, | 307 enable_ssl_connect_job_waiting_, net_log_))); |
| 309 net_log_))); | |
| 310 DCHECK(tcp_https_ret.second); | 308 DCHECK(tcp_https_ret.second); |
| 311 | 309 |
| 312 std::pair<HTTPProxySocketPoolMap::iterator, bool> ret = | 310 std::pair<HTTPProxySocketPoolMap::iterator, bool> ret = |
| 313 http_proxy_socket_pools_.insert( | 311 http_proxy_socket_pools_.insert( |
| 314 std::make_pair( | 312 std::make_pair( |
| 315 http_proxy, | 313 http_proxy, |
| 316 new HttpProxyClientSocketPool( | 314 new HttpProxyClientSocketPool( |
| 317 max_sockets_per_proxy_server(pool_type_), | 315 max_sockets_per_proxy_server(pool_type_), |
| 318 max_sockets_per_group(pool_type_), | 316 max_sockets_per_group(pool_type_), |
| 319 &http_proxy_pool_histograms_, | 317 &http_proxy_pool_histograms_, |
| 320 host_resolver_, | |
| 321 tcp_http_ret.first->second, | 318 tcp_http_ret.first->second, |
| 322 ssl_https_ret.first->second, | 319 ssl_https_ret.first->second, |
| 323 net_log_))); | 320 net_log_))); |
| 324 | 321 |
| 325 return ret.first->second; | 322 return ret.first->second; |
| 326 } | 323 } |
| 327 | 324 |
| 328 SSLClientSocketPool* ClientSocketPoolManagerImpl::GetSocketPoolForSSLWithProxy( | 325 SSLClientSocketPool* ClientSocketPoolManagerImpl::GetSocketPoolForSSLWithProxy( |
| 329 const HostPortPair& proxy_server) { | 326 const HostPortPair& proxy_server) { |
| 330 SSLSocketPoolMap::const_iterator it = | 327 SSLSocketPoolMap::const_iterator it = |
| 331 ssl_socket_pools_for_proxies_.find(proxy_server); | 328 ssl_socket_pools_for_proxies_.find(proxy_server); |
| 332 if (it != ssl_socket_pools_for_proxies_.end()) | 329 if (it != ssl_socket_pools_for_proxies_.end()) |
| 333 return it->second; | 330 return it->second; |
| 334 | 331 |
| 335 SSLClientSocketPool* new_pool = new SSLClientSocketPool( | 332 SSLClientSocketPool* new_pool = new SSLClientSocketPool( |
| 336 max_sockets_per_proxy_server(pool_type_), | 333 max_sockets_per_proxy_server(pool_type_), |
| 337 max_sockets_per_group(pool_type_), &ssl_pool_histograms_, host_resolver_, | 334 max_sockets_per_group(pool_type_), &ssl_pool_histograms_, cert_verifier_, |
| 338 cert_verifier_, channel_id_service_, transport_security_state_, | 335 channel_id_service_, transport_security_state_, |
| 339 cert_transparency_verifier_, cert_policy_enforcer_, | 336 cert_transparency_verifier_, cert_policy_enforcer_, |
| 340 ssl_session_cache_shard_, socket_factory_, | 337 ssl_session_cache_shard_, socket_factory_, |
| 341 NULL, /* no tcp pool, we always go through a proxy */ | 338 NULL, /* no tcp pool, we always go through a proxy */ |
| 342 GetSocketPoolForSOCKSProxy(proxy_server), | 339 GetSocketPoolForSOCKSProxy(proxy_server), |
| 343 GetSocketPoolForHTTPProxy(proxy_server), ssl_config_service_.get(), | 340 GetSocketPoolForHTTPProxy(proxy_server), ssl_config_service_.get(), |
| 344 enable_ssl_connect_job_waiting_, net_log_); | 341 enable_ssl_connect_job_waiting_, net_log_); |
| 345 | 342 |
| 346 std::pair<SSLSocketPoolMap::iterator, bool> ret = | 343 std::pair<SSLSocketPoolMap::iterator, bool> ret = |
| 347 ssl_socket_pools_for_proxies_.insert(std::make_pair(proxy_server, | 344 ssl_socket_pools_for_proxies_.insert(std::make_pair(proxy_server, |
| 348 new_pool)); | 345 new_pool)); |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 392 // We should not flush the socket pools if we added trust to a | 389 // We should not flush the socket pools if we added trust to a |
| 393 // cert. | 390 // cert. |
| 394 // | 391 // |
| 395 // Since the OnCACertChanged method doesn't tell us what | 392 // Since the OnCACertChanged method doesn't tell us what |
| 396 // kind of change it is, we have to flush the socket | 393 // kind of change it is, we have to flush the socket |
| 397 // pools to be safe. | 394 // pools to be safe. |
| 398 FlushSocketPoolsWithError(ERR_NETWORK_CHANGED); | 395 FlushSocketPoolsWithError(ERR_NETWORK_CHANGED); |
| 399 } | 396 } |
| 400 | 397 |
| 401 } // namespace net | 398 } // namespace net |
| OLD | NEW |