[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 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 |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #include "net/http/http_network_session.h" |
| 6 | |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 7 | #include <inttypes.h> |
Bence Béky | 8cae04e | 2018-01-15 18:37:06 | [diff] [blame] | 8 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 9 | #include <utility> |
| 10 | |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 11 | #include "base/atomic_sequence_num.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 12 | #include "base/compiler_specific.h" |
| 13 | #include "base/debug/stack_trace.h" |
| 14 | #include "base/logging.h" |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 15 | #include "base/strings/string_number_conversions.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 16 | #include "base/strings/string_util.h" |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 17 | #include "base/strings/stringprintf.h" |
| 18 | #include "base/trace_event/memory_allocator_dump.h" |
xunjieli | f5267de | 2017-01-20 21:18:57 | [diff] [blame] | 19 | #include "base/trace_event/memory_dump_request_args.h" |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 20 | #include "base/trace_event/process_memory_dump.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 21 | #include "base/values.h" |
| 22 | #include "net/http/http_auth_handler_factory.h" |
| 23 | #include "net/http/http_response_body_drainer.h" |
Xida Chen | 9bfe0b6 | 2018-04-24 19:52:21 | [diff] [blame] | 24 | #include "net/http/http_stream_factory.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 25 | #include "net/http/url_security_manager.h" |
Lily Houghton | ffe89daa0 | 2018-03-09 18:30:03 | [diff] [blame] | 26 | #include "net/proxy_resolution/proxy_resolution_service.h" |
Ryan Hamilton | a3ee93a7 | 2018-08-01 22:03:08 | [diff] [blame] | 27 | #include "net/quic/quic_crypto_client_stream_factory.h" |
| 28 | #include "net/quic/quic_stream_factory.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 29 | #include "net/socket/client_socket_factory.h" |
| 30 | #include "net/socket/client_socket_pool_manager_impl.h" |
| 31 | #include "net/socket/next_proto.h" |
bnc | 1e75750 | 2014-12-13 02:20:16 | [diff] [blame] | 32 | #include "net/socket/ssl_client_socket.h" |
Bence Béky | 94658bf | 2018-05-11 19:22:58 | [diff] [blame] | 33 | #include "net/spdy/spdy_session_pool.h" |
Ryan Hamilton | 56b10c5d | 2018-05-11 13:40:16 | [diff] [blame] | 34 | #include "net/third_party/quic/core/crypto/quic_random.h" |
| 35 | #include "net/third_party/quic/core/quic_packets.h" |
| 36 | #include "net/third_party/quic/core/quic_tag.h" |
| 37 | #include "net/third_party/quic/core/quic_utils.h" |
| 38 | #include "net/third_party/quic/platform/impl/quic_chromium_clock.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 39 | |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 40 | namespace net { |
| 41 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 42 | namespace { |
| 43 | |
tzik | 74c2eb2c | 2017-07-25 15:26:15 | [diff] [blame] | 44 | base::AtomicSequenceNumber g_next_shard_id; |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 45 | |
Juan Jose Lopez Jaimez | 7fa1f00 | 2017-11-20 22:13:33 | [diff] [blame] | 46 | std::unique_ptr<ClientSocketPoolManager> CreateSocketPoolManager( |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 47 | HttpNetworkSession::SocketPoolType pool_type, |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 48 | const HttpNetworkSession::Context& context, |
Bence Béky | da280c6 | 2018-04-12 15:08:37 | [diff] [blame] | 49 | const std::string& ssl_session_cache_shard, |
| 50 | WebSocketEndpointLockManager* websocket_endpoint_lock_manager) { |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 51 | // TODO(yutak): Differentiate WebSocket pool manager and allow more |
| 52 | // simultaneous connections for WebSockets. |
Juan Jose Lopez Jaimez | 7fa1f00 | 2017-11-20 22:13:33 | [diff] [blame] | 53 | return std::make_unique<ClientSocketPoolManagerImpl>( |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 54 | context.net_log, |
| 55 | context.client_socket_factory ? context.client_socket_factory |
| 56 | : ClientSocketFactory::GetDefaultFactory(), |
tbansal | 16196a1e | 2017-06-09 01:50:09 | [diff] [blame] | 57 | context.socket_performance_watcher_factory, |
Tarun Bansal | ed2b20b64 | 2018-10-15 19:51:32 | [diff] [blame] | 58 | context.network_quality_estimator, context.host_resolver, |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 59 | context.cert_verifier, context.channel_id_service, |
| 60 | context.transport_security_state, context.cert_transparency_verifier, |
| 61 | context.ct_policy_enforcer, ssl_session_cache_shard, |
Bence Béky | da280c6 | 2018-04-12 15:08:37 | [diff] [blame] | 62 | context.ssl_config_service, websocket_endpoint_lock_manager, pool_type); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 63 | } |
| 64 | |
| 65 | } // unnamed namespace |
| 66 | |
bnc | 8f0f3b6 | 2015-04-08 04:37:23 | [diff] [blame] | 67 | // The maximum receive window sizes for HTTP/2 sessions and streams. |
Avi Drissman | 13fc893 | 2015-12-20 04:40:46 | [diff] [blame] | 68 | const int32_t kSpdySessionMaxRecvWindowSize = 15 * 1024 * 1024; // 15 MB |
| 69 | const int32_t kSpdyStreamMaxRecvWindowSize = 6 * 1024 * 1024; // 6 MB |
bnc | 8f0f3b6 | 2015-04-08 04:37:23 | [diff] [blame] | 70 | |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 71 | namespace { |
| 72 | |
| 73 | // Keep all HTTP2 parameters in |http2_settings|, even the ones that are not |
| 74 | // implemented, to be sent to the server. |
| 75 | // Set default values for settings that |http2_settings| does not specify. |
Ryan Hamilton | 0239aac | 2018-05-19 00:03:13 | [diff] [blame] | 76 | spdy::SettingsMap AddDefaultHttp2Settings(spdy::SettingsMap http2_settings) { |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 77 | // Set default values only if |http2_settings| does not have |
| 78 | // a value set for given setting. |
jdoerrie | 22a91d8b9 | 2018-10-05 08:43:26 | [diff] [blame] | 79 | auto it = http2_settings.find(spdy::SETTINGS_HEADER_TABLE_SIZE); |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 80 | if (it == http2_settings.end()) |
Ryan Hamilton | 0239aac | 2018-05-19 00:03:13 | [diff] [blame] | 81 | http2_settings[spdy::SETTINGS_HEADER_TABLE_SIZE] = kSpdyMaxHeaderTableSize; |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 82 | |
Ryan Hamilton | 0239aac | 2018-05-19 00:03:13 | [diff] [blame] | 83 | it = http2_settings.find(spdy::SETTINGS_MAX_CONCURRENT_STREAMS); |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 84 | if (it == http2_settings.end()) |
Ryan Hamilton | 0239aac | 2018-05-19 00:03:13 | [diff] [blame] | 85 | http2_settings[spdy::SETTINGS_MAX_CONCURRENT_STREAMS] = |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 86 | kSpdyMaxConcurrentPushedStreams; |
| 87 | |
Ryan Hamilton | 0239aac | 2018-05-19 00:03:13 | [diff] [blame] | 88 | it = http2_settings.find(spdy::SETTINGS_INITIAL_WINDOW_SIZE); |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 89 | if (it == http2_settings.end()) |
Ryan Hamilton | 0239aac | 2018-05-19 00:03:13 | [diff] [blame] | 90 | http2_settings[spdy::SETTINGS_INITIAL_WINDOW_SIZE] = |
| 91 | kSpdyStreamMaxRecvWindowSize; |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 92 | |
| 93 | return http2_settings; |
| 94 | } |
| 95 | |
| 96 | } // unnamed namespace |
| 97 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 98 | HttpNetworkSession::Params::Params() |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 99 | : enable_server_push_cancellation(false), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 100 | ignore_certificate_errors(false), |
| 101 | testing_fixed_http_port(0), |
| 102 | testing_fixed_https_port(0), |
rch | 1546ccd | 2017-04-20 02:14:23 | [diff] [blame] | 103 | enable_user_alternate_protocol_ports(false), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 104 | enable_spdy_ping_based_connection_checking(true), |
bnc | efcd965 | 2016-02-03 18:00:32 | [diff] [blame] | 105 | enable_http2(true), |
bnc | 8f0f3b6 | 2015-04-08 04:37:23 | [diff] [blame] | 106 | spdy_session_max_recv_window_size(kSpdySessionMaxRecvWindowSize), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 107 | time_func(&base::TimeTicks::Now), |
bnc | a86731e | 2017-04-17 12:31:28 | [diff] [blame] | 108 | enable_http2_alternative_service(false), |
Bence Béky | 8bfacd4 | 2018-02-23 13:05:13 | [diff] [blame] | 109 | enable_websocket_over_http2(false), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 110 | enable_quic(false), |
Ryan Hamilton | 4cbcbf1 | 2018-12-15 05:16:14 | [diff] [blame^] | 111 | enable_quic_proxies_for_https_urls(false), |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 112 | quic_max_packet_length(quic::kDefaultMaxPacketSize), |
rch | 1546ccd | 2017-04-20 02:14:23 | [diff] [blame] | 113 | quic_max_server_configs_stored_in_properties(0u), |
kapishnikov | 7f8dd1e | 2018-01-24 06:10:49 | [diff] [blame] | 114 | quic_enable_socket_recv_optimization(false), |
rch | 1546ccd | 2017-04-20 02:14:23 | [diff] [blame] | 115 | mark_quic_broken_when_network_blackholes(false), |
Ryan Hamilton | b3827e88 | 2018-03-27 03:07:48 | [diff] [blame] | 116 | retry_without_alt_svc_on_quic_errors(true), |
Yixin Wang | a9afead | 2017-10-19 20:23:10 | [diff] [blame] | 117 | support_ietf_format_quic_altsvc(false), |
Jana Iyengar | 903dec2 | 2017-11-28 00:44:23 | [diff] [blame] | 118 | quic_close_sessions_on_ip_change(false), |
Zhongyi Shi | 63574b7 | 2018-06-01 20:22:25 | [diff] [blame] | 119 | quic_goaway_sessions_on_ip_change(false), |
rtenneti | 41c0999 | 2015-11-30 18:24:01 | [diff] [blame] | 120 | quic_idle_connection_timeout_seconds(kIdleConnectionTimeoutSeconds), |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 121 | quic_reduced_ping_timeout_seconds(quic::kPingTimeoutSecs), |
Yixin Wang | 469da56 | 2017-11-15 21:34:58 | [diff] [blame] | 122 | quic_max_time_before_crypto_handshake_seconds( |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 123 | quic::kMaxTimeForCryptoHandshakeSecs), |
Yixin Wang | 469da56 | 2017-11-15 21:34:58 | [diff] [blame] | 124 | quic_max_idle_time_before_crypto_handshake_seconds( |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 125 | quic::kInitialIdleTimeoutSecs), |
Zhongyi Shi | f4683a3 | 2017-12-01 00:03:28 | [diff] [blame] | 126 | quic_migrate_sessions_on_network_change_v2(false), |
| 127 | quic_migrate_sessions_early_v2(false), |
Zhongyi Shi | 8de4383 | 2018-08-15 23:40:00 | [diff] [blame] | 128 | quic_retry_on_alternate_network_before_handshake(false), |
Renjie | a0cb4a2c | 2018-09-26 23:37:30 | [diff] [blame] | 129 | quic_race_stale_dns_on_connection(false), |
Renjie | a5722ccf | 2018-08-10 00:18:49 | [diff] [blame] | 130 | quic_go_away_on_path_degrading(false), |
Zhongyi Shi | 73f23ca87 | 2017-12-13 18:37:13 | [diff] [blame] | 131 | quic_max_time_on_non_default_network( |
| 132 | base::TimeDelta::FromSeconds(kMaxTimeOnNonDefaultNetworkSecs)), |
Zhongyi Shi | ee76076 | 2018-08-01 00:54:29 | [diff] [blame] | 133 | quic_max_migrations_to_non_default_network_on_write_error( |
| 134 | kMaxMigrationsToNonDefaultNetworkOnWriteError), |
Zhongyi Shi | 8b1e43f | 2017-12-13 20:46:30 | [diff] [blame] | 135 | quic_max_migrations_to_non_default_network_on_path_degrading( |
| 136 | kMaxMigrationsToNonDefaultNetworkOnPathDegrading), |
jri | 217455a1 | 2016-07-13 20:15:09 | [diff] [blame] | 137 | quic_allow_server_migration(false), |
Ryan Hamilton | 0d32636 | 2018-01-30 06:05:10 | [diff] [blame] | 138 | quic_allow_remote_alt_svc(true), |
xunjieli | 888c2992 | 2016-03-18 21:05:09 | [diff] [blame] | 139 | quic_disable_bidirectional_streams(false), |
ckrasic | da193a8 | 2016-07-09 00:39:36 | [diff] [blame] | 140 | quic_force_hol_blocking(false), |
rtenneti | d073dd2 | 2016-08-04 01:58:33 | [diff] [blame] | 141 | quic_race_cert_verification(false), |
rch | d6163f3 | 2017-01-30 23:50:38 | [diff] [blame] | 142 | quic_estimate_initial_rtt(false), |
Yixin Wang | 079ad54 | 2018-01-11 04:06:05 | [diff] [blame] | 143 | quic_headers_include_h2_stream_dependency(false), |
Nick Harper | 1e5757d4 | 2018-05-02 23:08:57 | [diff] [blame] | 144 | enable_channel_id(false), |
yucliu | 48f235d | 2018-01-11 00:59:55 | [diff] [blame] | 145 | http_09_on_non_default_ports_enabled(false), |
| 146 | disable_idle_sockets_close_on_memory_pressure(false) { |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 147 | quic_supported_versions.push_back(quic::QUIC_VERSION_43); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 148 | } |
| 149 | |
vmpstr | acd23b7 | 2016-02-26 21:08:55 | [diff] [blame] | 150 | HttpNetworkSession::Params::Params(const Params& other) = default; |
| 151 | |
Chris Watkins | 7a41d355 | 2017-12-01 02:13:27 | [diff] [blame] | 152 | HttpNetworkSession::Params::~Params() = default; |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 153 | |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 154 | HttpNetworkSession::Context::Context() |
| 155 | : client_socket_factory(nullptr), |
| 156 | host_resolver(nullptr), |
| 157 | cert_verifier(nullptr), |
| 158 | channel_id_service(nullptr), |
| 159 | transport_security_state(nullptr), |
| 160 | cert_transparency_verifier(nullptr), |
| 161 | ct_policy_enforcer(nullptr), |
Lily Houghton | 8c2f97d | 2018-01-22 05:06:59 | [diff] [blame] | 162 | proxy_resolution_service(nullptr), |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 163 | ssl_config_service(nullptr), |
| 164 | http_auth_handler_factory(nullptr), |
| 165 | net_log(nullptr), |
| 166 | socket_performance_watcher_factory(nullptr), |
Tarun Bansal | ed2b20b64 | 2018-10-15 19:51:32 | [diff] [blame] | 167 | network_quality_estimator(nullptr), |
Douglas Creager | 3cb04205 | 2018-11-06 23:08:52 | [diff] [blame] | 168 | #if BUILDFLAG(ENABLE_REPORTING) |
Douglas Creager | 134b52e | 2018-11-09 18:00:14 | [diff] [blame] | 169 | reporting_service(nullptr), |
Douglas Creager | 3cb04205 | 2018-11-06 23:08:52 | [diff] [blame] | 170 | network_error_logging_service(nullptr), |
| 171 | #endif |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 172 | quic_clock(nullptr), |
| 173 | quic_random(nullptr), |
| 174 | quic_crypto_client_stream_factory( |
Douglas Creager | 3cb04205 | 2018-11-06 23:08:52 | [diff] [blame] | 175 | QuicCryptoClientStreamFactory::GetDefaultFactory()) { |
| 176 | } |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 177 | |
| 178 | HttpNetworkSession::Context::Context(const Context& other) = default; |
| 179 | |
Chris Watkins | 7a41d355 | 2017-12-01 02:13:27 | [diff] [blame] | 180 | HttpNetworkSession::Context::~Context() = default; |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 181 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 182 | // TODO(mbelshe): Move the socket factories into HttpStreamFactory. |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 183 | HttpNetworkSession::HttpNetworkSession(const Params& params, |
| 184 | const Context& context) |
| 185 | : net_log_(context.net_log), |
| 186 | http_server_properties_(context.http_server_properties), |
| 187 | cert_verifier_(context.cert_verifier), |
| 188 | http_auth_handler_factory_(context.http_auth_handler_factory), |
Douglas Creager | 3cb04205 | 2018-11-06 23:08:52 | [diff] [blame] | 189 | #if BUILDFLAG(ENABLE_REPORTING) |
Douglas Creager | 134b52e | 2018-11-09 18:00:14 | [diff] [blame] | 190 | reporting_service_(context.reporting_service), |
Douglas Creager | 3cb04205 | 2018-11-06 23:08:52 | [diff] [blame] | 191 | network_error_logging_service_(context.network_error_logging_service), |
| 192 | #endif |
Lily Houghton | 8c2f97d | 2018-01-22 05:06:59 | [diff] [blame] | 193 | proxy_resolution_service_(context.proxy_resolution_service), |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 194 | ssl_config_service_(context.ssl_config_service), |
zhongyi | af25754 | 2016-12-19 03:36:01 | [diff] [blame] | 195 | push_delegate_(nullptr), |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 196 | quic_stream_factory_( |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 197 | context.net_log, |
| 198 | context.host_resolver, |
| 199 | context.ssl_config_service, |
| 200 | context.client_socket_factory |
| 201 | ? context.client_socket_factory |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 202 | : ClientSocketFactory::GetDefaultFactory(), |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 203 | context.http_server_properties, |
| 204 | context.cert_verifier, |
| 205 | context.ct_policy_enforcer, |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 206 | context.transport_security_state, |
| 207 | context.cert_transparency_verifier, |
| 208 | context.socket_performance_watcher_factory, |
| 209 | context.quic_crypto_client_stream_factory, |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 210 | context.quic_random ? context.quic_random |
| 211 | : quic::QuicRandom::GetInstance(), |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 212 | context.quic_clock ? context.quic_clock |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 213 | : quic::QuicChromiumClock::GetInstance(), |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 214 | params.quic_max_packet_length, |
| 215 | params.quic_user_agent_id, |
rch | 431dd445 | 2017-04-19 15:22:35 | [diff] [blame] | 216 | params.quic_max_server_configs_stored_in_properties > 0, |
Jana Iyengar | 903dec2 | 2017-11-28 00:44:23 | [diff] [blame] | 217 | params.quic_close_sessions_on_ip_change, |
Zhongyi Shi | 63574b7 | 2018-06-01 20:22:25 | [diff] [blame] | 218 | params.quic_goaway_sessions_on_ip_change, |
rch | 9ecde09b | 2017-04-08 00:18:23 | [diff] [blame] | 219 | params.mark_quic_broken_when_network_blackholes, |
rtenneti | 41c0999 | 2015-11-30 18:24:01 | [diff] [blame] | 220 | params.quic_idle_connection_timeout_seconds, |
zhongyi | dd1439f6 | 2016-09-02 02:02:26 | [diff] [blame] | 221 | params.quic_reduced_ping_timeout_seconds, |
Yixin Wang | 469da56 | 2017-11-15 21:34:58 | [diff] [blame] | 222 | params.quic_max_time_before_crypto_handshake_seconds, |
| 223 | params.quic_max_idle_time_before_crypto_handshake_seconds, |
Zhongyi Shi | f4683a3 | 2017-12-01 00:03:28 | [diff] [blame] | 224 | params.quic_migrate_sessions_on_network_change_v2, |
| 225 | params.quic_migrate_sessions_early_v2, |
Zhongyi Shi | 8de4383 | 2018-08-15 23:40:00 | [diff] [blame] | 226 | params.quic_retry_on_alternate_network_before_handshake, |
Renjie | a0cb4a2c | 2018-09-26 23:37:30 | [diff] [blame] | 227 | params.quic_race_stale_dns_on_connection, |
Renjie | a5722ccf | 2018-08-10 00:18:49 | [diff] [blame] | 228 | params.quic_go_away_on_path_degrading, |
Zhongyi Shi | 73f23ca87 | 2017-12-13 18:37:13 | [diff] [blame] | 229 | params.quic_max_time_on_non_default_network, |
Zhongyi Shi | ee76076 | 2018-08-01 00:54:29 | [diff] [blame] | 230 | params.quic_max_migrations_to_non_default_network_on_write_error, |
Zhongyi Shi | 8b1e43f | 2017-12-13 20:46:30 | [diff] [blame] | 231 | params.quic_max_migrations_to_non_default_network_on_path_degrading, |
jri | 217455a1 | 2016-07-13 20:15:09 | [diff] [blame] | 232 | params.quic_allow_server_migration, |
rtenneti | d073dd2 | 2016-08-04 01:58:33 | [diff] [blame] | 233 | params.quic_race_cert_verification, |
rch | d6163f3 | 2017-01-30 23:50:38 | [diff] [blame] | 234 | params.quic_estimate_initial_rtt, |
Yixin Wang | 079ad54 | 2018-01-11 04:06:05 | [diff] [blame] | 235 | params.quic_headers_include_h2_stream_dependency, |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 236 | params.quic_connection_options, |
Yixin Wang | 46a425f | 2017-08-10 23:02:20 | [diff] [blame] | 237 | params.quic_client_connection_options, |
kapishnikov | 7f8dd1e | 2018-01-24 06:10:49 | [diff] [blame] | 238 | params.quic_enable_socket_recv_optimization), |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 239 | spdy_session_pool_(context.host_resolver, |
| 240 | context.ssl_config_service, |
| 241 | context.http_server_properties, |
| 242 | context.transport_security_state, |
zhongyi | 8ac630d | 2017-06-26 19:46:33 | [diff] [blame] | 243 | params.quic_supported_versions, |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 244 | params.enable_spdy_ping_based_connection_checking, |
Yixin Wang | a9afead | 2017-10-19 20:23:10 | [diff] [blame] | 245 | params.support_ietf_format_quic_altsvc, |
bnc | 8f0f3b6 | 2015-04-08 04:37:23 | [diff] [blame] | 246 | params.spdy_session_max_recv_window_size, |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 247 | AddDefaultHttp2Settings(params.http2_settings), |
Bence Béky | 6a070bcd | 2018-09-06 15:02:43 | [diff] [blame] | 248 | params.greased_http2_frame, |
Tarun Bansal | 647b30d | 2018-10-19 21:21:47 | [diff] [blame] | 249 | params.time_func, |
| 250 | context.network_quality_estimator), |
Xida Chen | 9bfe0b6 | 2018-04-24 19:52:21 | [diff] [blame] | 251 | http_stream_factory_(std::make_unique<HttpStreamFactory>(this)), |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 252 | params_(params), |
| 253 | context_(context) { |
Lily Houghton | 8c2f97d | 2018-01-22 05:06:59 | [diff] [blame] | 254 | DCHECK(proxy_resolution_service_); |
Ryan Sleevi | b8449e0 | 2018-07-15 04:31:07 | [diff] [blame] | 255 | DCHECK(ssl_config_service_); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 256 | CHECK(http_server_properties_); |
| 257 | |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 258 | const std::string ssl_session_cache_shard = |
| 259 | "http_network_session/" + base::IntToString(g_next_shard_id.GetNext()); |
Juan Jose Lopez Jaimez | 7fa1f00 | 2017-11-20 22:13:33 | [diff] [blame] | 260 | normal_socket_pool_manager_ = CreateSocketPoolManager( |
Bence Béky | da280c6 | 2018-04-12 15:08:37 | [diff] [blame] | 261 | NORMAL_SOCKET_POOL, context, ssl_session_cache_shard, |
Bence Béky | 33a4e43 | 2018-12-03 16:17:23 | [diff] [blame] | 262 | &websocket_endpoint_lock_manager_); |
Juan Jose Lopez Jaimez | 7fa1f00 | 2017-11-20 22:13:33 | [diff] [blame] | 263 | websocket_socket_pool_manager_ = CreateSocketPoolManager( |
Bence Béky | da280c6 | 2018-04-12 15:08:37 | [diff] [blame] | 264 | WEBSOCKET_SOCKET_POOL, context, ssl_session_cache_shard, |
Bence Béky | 33a4e43 | 2018-12-03 16:17:23 | [diff] [blame] | 265 | &websocket_endpoint_lock_manager_); |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 266 | |
bnc | 3f0118e | 2016-02-02 15:42:22 | [diff] [blame] | 267 | if (params_.enable_http2) { |
| 268 | next_protos_.push_back(kProtoHTTP2); |
bnc | 3f0118e | 2016-02-02 15:42:22 | [diff] [blame] | 269 | } |
| 270 | |
| 271 | next_protos_.push_back(kProtoHTTP11); |
| 272 | |
rtenneti | 6971c17 | 2016-01-15 20:12:10 | [diff] [blame] | 273 | http_server_properties_->SetMaxServerConfigsStoredInProperties( |
| 274 | params.quic_max_server_configs_stored_in_properties); |
maksim.sisov | 0adf859 | 2016-07-15 06:25:56 | [diff] [blame] | 275 | |
yucliu | 48f235d | 2018-01-11 00:59:55 | [diff] [blame] | 276 | if (!params_.disable_idle_sockets_close_on_memory_pressure) { |
| 277 | memory_pressure_listener_.reset( |
| 278 | new base::MemoryPressureListener(base::BindRepeating( |
| 279 | &HttpNetworkSession::OnMemoryPressure, base::Unretained(this)))); |
| 280 | } |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 281 | } |
| 282 | |
| 283 | HttpNetworkSession::~HttpNetworkSession() { |
gab | 47aa7da | 2017-06-02 16:09:43 | [diff] [blame] | 284 | DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); |
avi | fceb32f6 | 2016-10-07 16:30:52 | [diff] [blame] | 285 | response_drainers_.clear(); |
Bence Béky | 3ba8c33 | 2017-12-11 20:19:24 | [diff] [blame] | 286 | // TODO(bnc): CloseAllSessions() is also called in SpdySessionPool destructor, |
| 287 | // one of the two calls should be removed. |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 288 | spdy_session_pool_.CloseAllSessions(); |
| 289 | } |
| 290 | |
avi | fceb32f6 | 2016-10-07 16:30:52 | [diff] [blame] | 291 | void HttpNetworkSession::AddResponseDrainer( |
| 292 | std::unique_ptr<HttpResponseBodyDrainer> drainer) { |
| 293 | DCHECK(!base::ContainsKey(response_drainers_, drainer.get())); |
| 294 | HttpResponseBodyDrainer* drainer_ptr = drainer.get(); |
| 295 | response_drainers_[drainer_ptr] = std::move(drainer); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 296 | } |
| 297 | |
| 298 | void HttpNetworkSession::RemoveResponseDrainer( |
| 299 | HttpResponseBodyDrainer* drainer) { |
skyostil | b8f60ca | 2016-08-12 12:34:43 | [diff] [blame] | 300 | DCHECK(base::ContainsKey(response_drainers_, drainer)); |
avi | fceb32f6 | 2016-10-07 16:30:52 | [diff] [blame] | 301 | response_drainers_[drainer].release(); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 302 | response_drainers_.erase(drainer); |
| 303 | } |
| 304 | |
| 305 | TransportClientSocketPool* HttpNetworkSession::GetTransportSocketPool( |
| 306 | SocketPoolType pool_type) { |
| 307 | return GetSocketPoolManager(pool_type)->GetTransportSocketPool(); |
| 308 | } |
| 309 | |
| 310 | SSLClientSocketPool* HttpNetworkSession::GetSSLSocketPool( |
| 311 | SocketPoolType pool_type) { |
| 312 | return GetSocketPoolManager(pool_type)->GetSSLSocketPool(); |
| 313 | } |
| 314 | |
| 315 | SOCKSClientSocketPool* HttpNetworkSession::GetSocketPoolForSOCKSProxy( |
| 316 | SocketPoolType pool_type, |
| 317 | const HostPortPair& socks_proxy) { |
| 318 | return GetSocketPoolManager(pool_type)->GetSocketPoolForSOCKSProxy( |
| 319 | socks_proxy); |
| 320 | } |
| 321 | |
| 322 | HttpProxyClientSocketPool* HttpNetworkSession::GetSocketPoolForHTTPProxy( |
| 323 | SocketPoolType pool_type, |
| 324 | const HostPortPair& http_proxy) { |
| 325 | return GetSocketPoolManager(pool_type)->GetSocketPoolForHTTPProxy(http_proxy); |
| 326 | } |
| 327 | |
| 328 | SSLClientSocketPool* HttpNetworkSession::GetSocketPoolForSSLWithProxy( |
| 329 | SocketPoolType pool_type, |
| 330 | const HostPortPair& proxy_server) { |
| 331 | return GetSocketPoolManager(pool_type)->GetSocketPoolForSSLWithProxy( |
| 332 | proxy_server); |
| 333 | } |
| 334 | |
danakj | 1fd259a0 | 2016-04-16 03:17:09 | [diff] [blame] | 335 | std::unique_ptr<base::Value> HttpNetworkSession::SocketPoolInfoToValue() const { |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 336 | // TODO(yutak): Should merge values from normal pools and WebSocket pools. |
| 337 | return normal_socket_pool_manager_->SocketPoolInfoToValue(); |
| 338 | } |
| 339 | |
danakj | 1fd259a0 | 2016-04-16 03:17:09 | [diff] [blame] | 340 | std::unique_ptr<base::Value> HttpNetworkSession::SpdySessionPoolInfoToValue() |
| 341 | const { |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 342 | return spdy_session_pool_.SpdySessionPoolInfoToValue(); |
| 343 | } |
| 344 | |
danakj | 1fd259a0 | 2016-04-16 03:17:09 | [diff] [blame] | 345 | std::unique_ptr<base::Value> HttpNetworkSession::QuicInfoToValue() const { |
| 346 | std::unique_ptr<base::DictionaryValue> dict(new base::DictionaryValue()); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 347 | dict->Set("sessions", quic_stream_factory_.QuicStreamFactoryInfoToValue()); |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 348 | dict->SetBoolean("quic_enabled", IsQuicEnabled()); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 349 | |
Jeremy Roman | 0579ed6 | 2017-08-29 15:56:19 | [diff] [blame] | 350 | auto connection_options(std::make_unique<base::ListValue>()); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 351 | for (const auto& option : params_.quic_connection_options) |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 352 | connection_options->AppendString(quic::QuicTagToString(option)); |
dcheng | c7eeda42 | 2015-12-26 03:56:48 | [diff] [blame] | 353 | dict->Set("connection_options", std::move(connection_options)); |
rtenneti | 8a2f463 | 2016-03-21 20:26:57 | [diff] [blame] | 354 | |
Jeremy Roman | 0579ed6 | 2017-08-29 15:56:19 | [diff] [blame] | 355 | auto supported_versions(std::make_unique<base::ListValue>()); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 356 | for (const auto& version : params_.quic_supported_versions) |
| 357 | supported_versions->AppendString(QuicVersionToString(version)); |
| 358 | dict->Set("supported_versions", std::move(supported_versions)); |
| 359 | |
Jeremy Roman | 0579ed6 | 2017-08-29 15:56:19 | [diff] [blame] | 360 | auto origins_to_force_quic_on(std::make_unique<base::ListValue>()); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 361 | for (const auto& origin : params_.origins_to_force_quic_on) |
| 362 | origins_to_force_quic_on->AppendString(origin.ToString()); |
rtenneti | 8a2f463 | 2016-03-21 20:26:57 | [diff] [blame] | 363 | dict->Set("origins_to_force_quic_on", std::move(origins_to_force_quic_on)); |
| 364 | |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 365 | dict->SetInteger("max_packet_length", params_.quic_max_packet_length); |
rtenneti | 6971c17 | 2016-01-15 20:12:10 | [diff] [blame] | 366 | dict->SetInteger("max_server_configs_stored_in_properties", |
| 367 | params_.quic_max_server_configs_stored_in_properties); |
rtenneti | f4b29d7 | 2016-01-11 19:29:39 | [diff] [blame] | 368 | dict->SetInteger("idle_connection_timeout_seconds", |
| 369 | params_.quic_idle_connection_timeout_seconds); |
zhongyi | dd1439f6 | 2016-09-02 02:02:26 | [diff] [blame] | 370 | dict->SetInteger("reduced_ping_timeout_seconds", |
| 371 | params_.quic_reduced_ping_timeout_seconds); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 372 | dict->SetBoolean("mark_quic_broken_when_network_blackholes", |
| 373 | params_.mark_quic_broken_when_network_blackholes); |
| 374 | dict->SetBoolean("retry_without_alt_svc_on_quic_errors", |
| 375 | params_.retry_without_alt_svc_on_quic_errors); |
rtenneti | d073dd2 | 2016-08-04 01:58:33 | [diff] [blame] | 376 | dict->SetBoolean("race_cert_verification", |
| 377 | params_.quic_race_cert_verification); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 378 | dict->SetBoolean("disable_bidirectional_streams", |
| 379 | params_.quic_disable_bidirectional_streams); |
Jana Iyengar | 903dec2 | 2017-11-28 00:44:23 | [diff] [blame] | 380 | dict->SetBoolean("close_sessions_on_ip_change", |
| 381 | params_.quic_close_sessions_on_ip_change); |
Zhongyi Shi | 63574b7 | 2018-06-01 20:22:25 | [diff] [blame] | 382 | dict->SetBoolean("goaway_sessions_on_ip_change", |
| 383 | params_.quic_goaway_sessions_on_ip_change); |
Zhongyi Shi | f4683a3 | 2017-12-01 00:03:28 | [diff] [blame] | 384 | dict->SetBoolean("migrate_sessions_on_network_change_v2", |
| 385 | params_.quic_migrate_sessions_on_network_change_v2); |
| 386 | dict->SetBoolean("migrate_sessions_early_v2", |
| 387 | params_.quic_migrate_sessions_early_v2); |
Zhongyi Shi | 8de4383 | 2018-08-15 23:40:00 | [diff] [blame] | 388 | dict->SetBoolean("retry_on_alternate_network_before_handshake", |
| 389 | params_.quic_retry_on_alternate_network_before_handshake); |
Renjie | a0cb4a2c | 2018-09-26 23:37:30 | [diff] [blame] | 390 | dict->SetBoolean("race_stale_dns_on_connection", |
| 391 | params_.quic_race_stale_dns_on_connection); |
Renjie | a5722ccf | 2018-08-10 00:18:49 | [diff] [blame] | 392 | dict->SetBoolean("go_away_on_path_degrading", |
| 393 | params_.quic_go_away_on_path_degrading); |
Zhongyi Shi | 73f23ca87 | 2017-12-13 18:37:13 | [diff] [blame] | 394 | dict->SetInteger("max_time_on_non_default_network_seconds", |
| 395 | params_.quic_max_time_on_non_default_network.InSeconds()); |
Zhongyi Shi | 8b1e43f | 2017-12-13 20:46:30 | [diff] [blame] | 396 | dict->SetInteger( |
Zhongyi Shi | ee76076 | 2018-08-01 00:54:29 | [diff] [blame] | 397 | "max_num_migrations_to_non_default_network_on_write_error", |
| 398 | params_.quic_max_migrations_to_non_default_network_on_write_error); |
| 399 | dict->SetInteger( |
Zhongyi Shi | 8b1e43f | 2017-12-13 20:46:30 | [diff] [blame] | 400 | "max_num_migrations_to_non_default_network_on_path_degrading", |
| 401 | params_.quic_max_migrations_to_non_default_network_on_path_degrading); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 402 | dict->SetBoolean("allow_server_migration", |
| 403 | params_.quic_allow_server_migration); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 404 | dict->SetBoolean("estimate_initial_rtt", params_.quic_estimate_initial_rtt); |
| 405 | dict->SetBoolean("force_hol_blocking", params_.quic_force_hol_blocking); |
zhongyi | f054cd0 | 2017-06-09 07:09:10 | [diff] [blame] | 406 | dict->SetBoolean("server_push_cancellation", |
| 407 | params_.enable_server_push_cancellation); |
rch | 5353574 | 2017-04-20 00:48:50 | [diff] [blame] | 408 | |
dcheng | c7eeda42 | 2015-12-26 03:56:48 | [diff] [blame] | 409 | return std::move(dict); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 410 | } |
| 411 | |
| 412 | void HttpNetworkSession::CloseAllConnections() { |
| 413 | normal_socket_pool_manager_->FlushSocketPoolsWithError(ERR_ABORTED); |
| 414 | websocket_socket_pool_manager_->FlushSocketPoolsWithError(ERR_ABORTED); |
| 415 | spdy_session_pool_.CloseCurrentSessions(ERR_ABORTED); |
Ryan Hamilton | 8d9ee76e | 2018-05-29 23:52:52 | [diff] [blame] | 416 | quic_stream_factory_.CloseAllSessions(ERR_ABORTED, quic::QUIC_INTERNAL_ERROR); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 417 | } |
| 418 | |
| 419 | void HttpNetworkSession::CloseIdleConnections() { |
| 420 | normal_socket_pool_manager_->CloseIdleSockets(); |
| 421 | websocket_socket_pool_manager_->CloseIdleSockets(); |
| 422 | spdy_session_pool_.CloseCurrentIdleSessions(); |
| 423 | } |
| 424 | |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 425 | bool HttpNetworkSession::IsProtocolEnabled(NextProto protocol) const { |
bnc | 8f8225c | 2016-09-23 21:19:46 | [diff] [blame] | 426 | switch (protocol) { |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 427 | case kProtoUnknown: |
bnc | 8f8225c | 2016-09-23 21:19:46 | [diff] [blame] | 428 | NOTREACHED(); |
| 429 | return false; |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 430 | case kProtoHTTP11: |
| 431 | return true; |
| 432 | case kProtoHTTP2: |
| 433 | return params_.enable_http2; |
| 434 | case kProtoQUIC: |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 435 | return IsQuicEnabled(); |
bnc | 8f8225c | 2016-09-23 21:19:46 | [diff] [blame] | 436 | } |
| 437 | NOTREACHED(); |
| 438 | return false; |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 439 | } |
| 440 | |
zhongyi | af25754 | 2016-12-19 03:36:01 | [diff] [blame] | 441 | void HttpNetworkSession::SetServerPushDelegate( |
| 442 | std::unique_ptr<ServerPushDelegate> push_delegate) { |
zhongyi | d7dd2db1 | 2017-04-14 17:01:25 | [diff] [blame] | 443 | DCHECK(push_delegate); |
| 444 | if (!params_.enable_server_push_cancellation || push_delegate_) |
| 445 | return; |
zhongyi | af25754 | 2016-12-19 03:36:01 | [diff] [blame] | 446 | |
| 447 | push_delegate_ = std::move(push_delegate); |
| 448 | spdy_session_pool_.set_server_push_delegate(push_delegate_.get()); |
| 449 | quic_stream_factory_.set_server_push_delegate(push_delegate_.get()); |
| 450 | } |
| 451 | |
bnc | 1f29537 | 2015-10-21 23:24:22 | [diff] [blame] | 452 | void HttpNetworkSession::GetAlpnProtos(NextProtoVector* alpn_protos) const { |
bnc | 927c496 | 2016-07-21 14:45:59 | [diff] [blame] | 453 | *alpn_protos = next_protos_; |
bnc | 1f29537 | 2015-10-21 23:24:22 | [diff] [blame] | 454 | } |
| 455 | |
nharper | 8cdb0fb | 2016-04-22 21:34:59 | [diff] [blame] | 456 | void HttpNetworkSession::GetSSLConfig(const HttpRequestInfo& request, |
| 457 | SSLConfig* server_config, |
| 458 | SSLConfig* proxy_config) const { |
| 459 | ssl_config_service_->GetSSLConfig(server_config); |
| 460 | GetAlpnProtos(&server_config->alpn_protos); |
Jesse Selover | daf8790 | 2018-12-03 20:44:30 | [diff] [blame] | 461 | server_config->ignore_certificate_errors = params_.ignore_certificate_errors; |
nharper | 8cdb0fb | 2016-04-22 21:34:59 | [diff] [blame] | 462 | *proxy_config = *server_config; |
| 463 | if (request.privacy_mode == PRIVACY_MODE_ENABLED) { |
| 464 | server_config->channel_id_enabled = false; |
Nick Harper | 1e5757d4 | 2018-05-02 23:08:57 | [diff] [blame] | 465 | } else { |
| 466 | server_config->channel_id_enabled = params_.enable_channel_id; |
Nick Harper | 25a0c4b | 2018-06-07 23:40:01 | [diff] [blame] | 467 | proxy_config->channel_id_enabled = params_.enable_channel_id; |
nharper | 8cdb0fb | 2016-04-22 21:34:59 | [diff] [blame] | 468 | } |
| 469 | } |
| 470 | |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 471 | void HttpNetworkSession::DumpMemoryStats( |
| 472 | base::trace_event::ProcessMemoryDump* pmd, |
| 473 | const std::string& parent_absolute_name) const { |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 474 | std::string name = base::StringPrintf("net/http_network_session_0x%" PRIxPTR, |
| 475 | reinterpret_cast<uintptr_t>(this)); |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 476 | base::trace_event::MemoryAllocatorDump* http_network_session_dump = |
| 477 | pmd->GetAllocatorDump(name); |
xunjieli | 2a2468bd | 2017-01-04 21:17:33 | [diff] [blame] | 478 | if (http_network_session_dump == nullptr) { |
| 479 | http_network_session_dump = pmd->CreateAllocatorDump(name); |
| 480 | normal_socket_pool_manager_->DumpMemoryStats( |
| 481 | pmd, http_network_session_dump->absolute_name()); |
| 482 | spdy_session_pool_.DumpMemoryStats( |
| 483 | pmd, http_network_session_dump->absolute_name()); |
xunjieli | f5267de | 2017-01-20 21:18:57 | [diff] [blame] | 484 | if (http_stream_factory_) { |
| 485 | http_stream_factory_->DumpMemoryStats( |
| 486 | pmd, http_network_session_dump->absolute_name()); |
| 487 | } |
xunjieli | 69720dd | 2017-01-30 15:36:29 | [diff] [blame] | 488 | quic_stream_factory_.DumpMemoryStats( |
| 489 | pmd, http_network_session_dump->absolute_name()); |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 490 | } |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 491 | |
xunjieli | 2a2468bd | 2017-01-04 21:17:33 | [diff] [blame] | 492 | // Create an empty row under parent's dump so size can be attributed correctly |
| 493 | // if |this| is shared between URLRequestContexts. |
| 494 | base::trace_event::MemoryAllocatorDump* empty_row_dump = |
| 495 | pmd->CreateAllocatorDump(base::StringPrintf( |
| 496 | "%s/http_network_session", parent_absolute_name.c_str())); |
| 497 | pmd->AddOwnershipEdge(empty_row_dump->guid(), |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 498 | http_network_session_dump->guid()); |
| 499 | } |
| 500 | |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 501 | bool HttpNetworkSession::IsQuicEnabled() const { |
| 502 | return params_.enable_quic; |
| 503 | } |
| 504 | |
| 505 | void HttpNetworkSession::DisableQuic() { |
| 506 | params_.enable_quic = false; |
| 507 | } |
| 508 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 509 | ClientSocketPoolManager* HttpNetworkSession::GetSocketPoolManager( |
| 510 | SocketPoolType pool_type) { |
| 511 | switch (pool_type) { |
| 512 | case NORMAL_SOCKET_POOL: |
| 513 | return normal_socket_pool_manager_.get(); |
| 514 | case WEBSOCKET_SOCKET_POOL: |
| 515 | return websocket_socket_pool_manager_.get(); |
| 516 | default: |
| 517 | NOTREACHED(); |
| 518 | break; |
| 519 | } |
| 520 | return NULL; |
| 521 | } |
| 522 | |
maksim.sisov | 0adf859 | 2016-07-15 06:25:56 | [diff] [blame] | 523 | void HttpNetworkSession::OnMemoryPressure( |
| 524 | base::MemoryPressureListener::MemoryPressureLevel memory_pressure_level) { |
yucliu | 48f235d | 2018-01-11 00:59:55 | [diff] [blame] | 525 | DCHECK(!params_.disable_idle_sockets_close_on_memory_pressure); |
| 526 | |
maksim.sisov | 0adf859 | 2016-07-15 06:25:56 | [diff] [blame] | 527 | switch (memory_pressure_level) { |
| 528 | case base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE: |
yucliu | 9462d91 | 2017-11-22 02:41:23 | [diff] [blame] | 529 | break; |
yucliu | 48f235d | 2018-01-11 00:59:55 | [diff] [blame] | 530 | |
| 531 | case base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_MODERATE: |
maksim.sisov | 0adf859 | 2016-07-15 06:25:56 | [diff] [blame] | 532 | case base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_CRITICAL: |
| 533 | CloseIdleConnections(); |
| 534 | break; |
| 535 | } |
| 536 | } |
| 537 | |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 538 | } // namespace net |