[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> |
| 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" |
hajimehoshi | 8156e7c | 2016-09-29 06:17:52 | [diff] [blame] | 15 | #include "base/memory/memory_coordinator_client_registry.h" |
avi | fceb32f6 | 2016-10-07 16:30:52 | [diff] [blame] | 16 | #include "base/memory/ptr_util.h" |
michaeln | 3e5bced | 2015-02-09 22:58:23 | [diff] [blame] | 17 | #include "base/profiler/scoped_tracker.h" |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 18 | #include "base/strings/string_number_conversions.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 19 | #include "base/strings/string_util.h" |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 20 | #include "base/strings/stringprintf.h" |
| 21 | #include "base/trace_event/memory_allocator_dump.h" |
xunjieli | f5267de | 2017-01-20 21:18:57 | [diff] [blame] | 22 | #include "base/trace_event/memory_dump_request_args.h" |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 23 | #include "base/trace_event/process_memory_dump.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 24 | #include "base/values.h" |
rdsmith | bf8c3c1 | 2016-11-18 18:16:24 | [diff] [blame] | 25 | #include "net/base/network_throttle_manager_impl.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 26 | #include "net/http/http_auth_handler_factory.h" |
| 27 | #include "net/http/http_response_body_drainer.h" |
| 28 | #include "net/http/http_stream_factory_impl.h" |
| 29 | #include "net/http/url_security_manager.h" |
| 30 | #include "net/proxy/proxy_service.h" |
rch | 223465c | 2016-12-08 21:17:29 | [diff] [blame] | 31 | #include "net/quic/chromium/quic_crypto_client_stream_factory.h" |
rch | 675757b | 2016-07-29 16:40:11 | [diff] [blame] | 32 | #include "net/quic/chromium/quic_stream_factory.h" |
rch | d4db7c15 | 2016-07-29 21:58:12 | [diff] [blame] | 33 | #include "net/quic/core/crypto/quic_random.h" |
vasilvv | 28270e8f | 2016-12-01 21:38:09 | [diff] [blame] | 34 | #include "net/quic/core/quic_packets.h" |
mpw | 94250b8 | 2016-11-19 18:13:30 | [diff] [blame] | 35 | #include "net/quic/core/quic_tag.h" |
rch | d4db7c15 | 2016-07-29 21:58:12 | [diff] [blame] | 36 | #include "net/quic/core/quic_utils.h" |
rch | 799bbe8 | 2016-12-06 15:30:09 | [diff] [blame] | 37 | #include "net/quic/platform/impl/quic_chromium_clock.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 38 | #include "net/socket/client_socket_factory.h" |
| 39 | #include "net/socket/client_socket_pool_manager_impl.h" |
| 40 | #include "net/socket/next_proto.h" |
bnc | 1e75750 | 2014-12-13 02:20:16 | [diff] [blame] | 41 | #include "net/socket/ssl_client_socket.h" |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 42 | #include "net/spdy/spdy_session_pool.h" |
| 43 | |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 44 | namespace net { |
| 45 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 46 | namespace { |
| 47 | |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 48 | base::StaticAtomicSequenceNumber g_next_shard_id; |
| 49 | |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 50 | ClientSocketPoolManager* CreateSocketPoolManager( |
| 51 | HttpNetworkSession::SocketPoolType pool_type, |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 52 | const HttpNetworkSession::Params& params, |
| 53 | const std::string& ssl_session_cache_shard) { |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 54 | // TODO(yutak): Differentiate WebSocket pool manager and allow more |
| 55 | // simultaneous connections for WebSockets. |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 56 | return new ClientSocketPoolManagerImpl( |
| 57 | params.net_log, |
| 58 | params.client_socket_factory ? params.client_socket_factory |
| 59 | : ClientSocketFactory::GetDefaultFactory(), |
tbansal | 7b403bcc | 2016-04-13 22:33:21 | [diff] [blame] | 60 | params.socket_performance_watcher_factory, params.host_resolver, |
| 61 | params.cert_verifier, params.channel_id_service, |
eranm | 6571b2b | 2014-12-03 15:53:23 | [diff] [blame] | 62 | params.transport_security_state, params.cert_transparency_verifier, |
estark | 6f9b3d8 | 2016-01-12 21:37:05 | [diff] [blame] | 63 | params.ct_policy_enforcer, ssl_session_cache_shard, |
rsleevi | f020edc | 2015-03-16 19:31:24 | [diff] [blame] | 64 | params.ssl_config_service, pool_type); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 65 | } |
| 66 | |
| 67 | } // unnamed namespace |
| 68 | |
bnc | 8f0f3b6 | 2015-04-08 04:37:23 | [diff] [blame] | 69 | // The maximum receive window sizes for HTTP/2 sessions and streams. |
Avi Drissman | 13fc893 | 2015-12-20 04:40:46 | [diff] [blame] | 70 | const int32_t kSpdySessionMaxRecvWindowSize = 15 * 1024 * 1024; // 15 MB |
| 71 | const int32_t kSpdyStreamMaxRecvWindowSize = 6 * 1024 * 1024; // 6 MB |
rch | e713c179 | 2015-05-07 01:39:18 | [diff] [blame] | 72 | // QUIC's socket receive buffer size. |
| 73 | // We should adaptively set this buffer size, but for now, we'll use a size |
| 74 | // that seems large enough to receive data at line rate for most connections, |
| 75 | // and does not consume "too much" memory. |
Avi Drissman | 13fc893 | 2015-12-20 04:40:46 | [diff] [blame] | 76 | const int32_t kQuicSocketReceiveBufferSize = 1024 * 1024; // 1MB |
bnc | 8f0f3b6 | 2015-04-08 04:37:23 | [diff] [blame] | 77 | |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 78 | namespace { |
| 79 | |
| 80 | // Keep all HTTP2 parameters in |http2_settings|, even the ones that are not |
| 81 | // implemented, to be sent to the server. |
| 82 | // Set default values for settings that |http2_settings| does not specify. |
| 83 | SettingsMap AddDefaultHttp2Settings(SettingsMap http2_settings) { |
| 84 | // Set default values only if |http2_settings| does not have |
| 85 | // a value set for given setting. |
| 86 | SettingsMap::iterator it = http2_settings.find(SETTINGS_HEADER_TABLE_SIZE); |
| 87 | if (it == http2_settings.end()) |
| 88 | http2_settings[SETTINGS_HEADER_TABLE_SIZE] = kSpdyMaxHeaderTableSize; |
| 89 | |
| 90 | it = http2_settings.find(SETTINGS_MAX_CONCURRENT_STREAMS); |
| 91 | if (it == http2_settings.end()) |
| 92 | http2_settings[SETTINGS_MAX_CONCURRENT_STREAMS] = |
| 93 | kSpdyMaxConcurrentPushedStreams; |
| 94 | |
| 95 | it = http2_settings.find(SETTINGS_INITIAL_WINDOW_SIZE); |
| 96 | if (it == http2_settings.end()) |
| 97 | http2_settings[SETTINGS_INITIAL_WINDOW_SIZE] = kSpdyStreamMaxRecvWindowSize; |
| 98 | |
| 99 | return http2_settings; |
| 100 | } |
| 101 | |
| 102 | } // unnamed namespace |
| 103 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 104 | HttpNetworkSession::Params::Params() |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 105 | : client_socket_factory(nullptr), |
| 106 | host_resolver(nullptr), |
| 107 | cert_verifier(nullptr), |
| 108 | channel_id_service(nullptr), |
| 109 | transport_security_state(nullptr), |
| 110 | cert_transparency_verifier(nullptr), |
| 111 | ct_policy_enforcer(nullptr), |
| 112 | proxy_service(nullptr), |
| 113 | ssl_config_service(nullptr), |
| 114 | http_auth_handler_factory(nullptr), |
| 115 | net_log(nullptr), |
| 116 | host_mapping_rules(nullptr), |
| 117 | socket_performance_watcher_factory(nullptr), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 118 | ignore_certificate_errors(false), |
| 119 | testing_fixed_http_port(0), |
| 120 | testing_fixed_https_port(0), |
jri | f9b4bec | 2014-09-15 15:46:54 | [diff] [blame] | 121 | enable_tcp_fast_open_for_ssl(false), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 122 | enable_spdy_ping_based_connection_checking(true), |
bnc | efcd965 | 2016-02-03 18:00:32 | [diff] [blame] | 123 | enable_http2(true), |
bnc | 8f0f3b6 | 2015-04-08 04:37:23 | [diff] [blame] | 124 | spdy_session_max_recv_window_size(kSpdySessionMaxRecvWindowSize), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 125 | time_func(&base::TimeTicks::Now), |
bnc | a8681534 | 2016-06-27 12:27:48 | [diff] [blame] | 126 | enable_http2_alternative_service_with_different_host(false), |
| 127 | enable_quic_alternative_service_with_different_host(true), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 128 | enable_quic(false), |
zhongyi | 75527dd | 2016-01-21 22:26:43 | [diff] [blame] | 129 | disable_quic_on_timeout_with_open_streams(false), |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 130 | quic_always_require_handshake_confirmation(false), |
jri | 584002d1 | 2014-09-09 00:51:28 | [diff] [blame] | 131 | quic_disable_connection_pooling(false), |
rtenneti | ca75eb1b | 2015-03-03 23:09:50 | [diff] [blame] | 132 | quic_load_server_info_timeout_srtt_multiplier(0.25f), |
rtenneti | 4f80997 | 2015-02-11 19:38:34 | [diff] [blame] | 133 | quic_enable_connection_racing(false), |
qyearsley | 3257b7de | 2015-02-28 06:59:03 | [diff] [blame] | 134 | quic_enable_non_blocking_io(false), |
rtenneti | 34dffe75 | 2015-02-24 23:27:32 | [diff] [blame] | 135 | quic_disable_disk_cache(false), |
rch | 9976b0c | 2015-06-10 21:27:23 | [diff] [blame] | 136 | quic_prefer_aes(false), |
rch | e713c179 | 2015-05-07 01:39:18 | [diff] [blame] | 137 | quic_socket_receive_buffer_size(kQuicSocketReceiveBufferSize), |
rtenneti | afccbc06 | 2016-05-16 18:21:14 | [diff] [blame] | 138 | quic_delay_tcp_race(true), |
rtenneti | 6971c17 | 2016-01-15 20:12:10 | [diff] [blame] | 139 | quic_max_server_configs_stored_in_properties(0u), |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 140 | quic_clock(nullptr), |
| 141 | quic_random(nullptr), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 142 | quic_max_packet_length(kDefaultMaxPacketSize), |
| 143 | enable_user_alternate_protocol_ports(false), |
rch | 1f83eaf3 | 2016-01-06 00:27:11 | [diff] [blame] | 144 | quic_crypto_client_stream_factory( |
| 145 | QuicCryptoClientStreamFactory::GetDefaultFactory()), |
jri | 8c44d69 | 2015-10-23 23:53:41 | [diff] [blame] | 146 | quic_close_sessions_on_ip_change(false), |
rtenneti | 41c0999 | 2015-11-30 18:24:01 | [diff] [blame] | 147 | quic_idle_connection_timeout_seconds(kIdleConnectionTimeoutSeconds), |
zhongyi | dd1439f6 | 2016-09-02 02:02:26 | [diff] [blame] | 148 | quic_reduced_ping_timeout_seconds(kPingTimeoutSecs), |
zhongyi | 6ba0f425 | 2016-08-23 05:20:04 | [diff] [blame] | 149 | quic_packet_reader_yield_after_duration_milliseconds( |
| 150 | kQuicYieldAfterDurationMilliseconds), |
rtenneti | d2e74caa | 2015-12-09 00:51:57 | [diff] [blame] | 151 | quic_disable_preconnect_if_0rtt(false), |
jri | 7e63664 | 2016-01-14 06:57:08 | [diff] [blame] | 152 | quic_migrate_sessions_on_network_change(false), |
jri | d36ada6 | 2016-02-06 02:42:08 | [diff] [blame] | 153 | quic_migrate_sessions_early(false), |
jri | 217455a1 | 2016-07-13 20:15:09 | [diff] [blame] | 154 | quic_allow_server_migration(false), |
xunjieli | 888c2992 | 2016-03-18 21:05:09 | [diff] [blame] | 155 | quic_disable_bidirectional_streams(false), |
ckrasic | da193a8 | 2016-07-09 00:39:36 | [diff] [blame] | 156 | quic_force_hol_blocking(false), |
rtenneti | d073dd2 | 2016-08-04 01:58:33 | [diff] [blame] | 157 | quic_race_cert_verification(false), |
rch | bedd5745 | 2016-08-30 19:11:48 | [diff] [blame] | 158 | quic_do_not_fragment(false), |
tbansal | 6b52748 | 2017-01-27 19:10:49 | [diff] [blame] | 159 | quic_do_not_mark_as_broken_on_network_change(false), |
rch | d6163f3 | 2017-01-30 23:50:38 | [diff] [blame] | 160 | quic_estimate_initial_rtt(false), |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 161 | proxy_delegate(nullptr), |
mmenke | a7da6da | 2016-09-01 21:56:52 | [diff] [blame] | 162 | enable_token_binding(false), |
mmenke | 82d19a58 | 2017-01-27 23:26:32 | [diff] [blame] | 163 | http_09_on_non_default_ports_enabled(false), |
tbansal | 7450edf | 2016-12-28 21:12:53 | [diff] [blame] | 164 | restrict_to_one_preconnect_for_proxies(false) { |
rch | 02ebae8 | 2016-08-16 18:25:25 | [diff] [blame] | 165 | quic_supported_versions.push_back(QUIC_VERSION_35); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 166 | } |
| 167 | |
vmpstr | acd23b7 | 2016-02-26 21:08:55 | [diff] [blame] | 168 | HttpNetworkSession::Params::Params(const Params& other) = default; |
| 169 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 170 | HttpNetworkSession::Params::~Params() {} |
| 171 | |
| 172 | // TODO(mbelshe): Move the socket factories into HttpStreamFactory. |
| 173 | HttpNetworkSession::HttpNetworkSession(const Params& params) |
| 174 | : net_log_(params.net_log), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 175 | http_server_properties_(params.http_server_properties), |
| 176 | cert_verifier_(params.cert_verifier), |
| 177 | http_auth_handler_factory_(params.http_auth_handler_factory), |
| 178 | proxy_service_(params.proxy_service), |
| 179 | ssl_config_service_(params.ssl_config_service), |
zhongyi | af25754 | 2016-12-19 03:36:01 | [diff] [blame] | 180 | push_delegate_(nullptr), |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 181 | quic_stream_factory_( |
jri | df673d2 | 2016-06-02 22:06:33 | [diff] [blame] | 182 | params.net_log, |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 183 | params.host_resolver, |
nharper | 642ae4b | 2016-06-30 00:40:36 | [diff] [blame] | 184 | params.ssl_config_service, |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 185 | params.client_socket_factory |
| 186 | ? params.client_socket_factory |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 187 | : ClientSocketFactory::GetDefaultFactory(), |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 188 | params.http_server_properties, |
tbansal | 3b96695 | 2016-10-25 23:25:14 | [diff] [blame] | 189 | params.proxy_delegate, |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 190 | params.cert_verifier, |
estark | 6f9b3d8 | 2016-01-12 21:37:05 | [diff] [blame] | 191 | params.ct_policy_enforcer, |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 192 | params.channel_id_service, |
| 193 | params.transport_security_state, |
rtenneti | 052774e | 2015-11-24 21:00:12 | [diff] [blame] | 194 | params.cert_transparency_verifier, |
tbansal | fdf5665b | 2015-09-21 22:46:40 | [diff] [blame] | 195 | params.socket_performance_watcher_factory, |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 196 | params.quic_crypto_client_stream_factory, |
| 197 | params.quic_random ? params.quic_random : QuicRandom::GetInstance(), |
rch | 799bbe8 | 2016-12-06 15:30:09 | [diff] [blame] | 198 | params.quic_clock ? params.quic_clock : new QuicChromiumClock(), |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 199 | params.quic_max_packet_length, |
| 200 | params.quic_user_agent_id, |
| 201 | params.quic_supported_versions, |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 202 | params.quic_always_require_handshake_confirmation, |
jri | 584002d1 | 2014-09-09 00:51:28 | [diff] [blame] | 203 | params.quic_disable_connection_pooling, |
rtenneti | 2912825c | 2015-01-06 01:19:46 | [diff] [blame] | 204 | params.quic_load_server_info_timeout_srtt_multiplier, |
rtenneti | 4f80997 | 2015-02-11 19:38:34 | [diff] [blame] | 205 | params.quic_enable_connection_racing, |
qyearsley | 3257b7de | 2015-02-28 06:59:03 | [diff] [blame] | 206 | params.quic_enable_non_blocking_io, |
rtenneti | 34dffe75 | 2015-02-24 23:27:32 | [diff] [blame] | 207 | params.quic_disable_disk_cache, |
rch | 9976b0c | 2015-06-10 21:27:23 | [diff] [blame] | 208 | params.quic_prefer_aes, |
rch | 185ebee | 2015-07-14 23:56:22 | [diff] [blame] | 209 | params.quic_socket_receive_buffer_size, |
rtenneti | b8e80fb | 2016-05-16 00:12:09 | [diff] [blame] | 210 | params.quic_delay_tcp_race, |
rtenneti | 6971c17 | 2016-01-15 20:12:10 | [diff] [blame] | 211 | params.quic_max_server_configs_stored_in_properties, |
jri | 8c44d69 | 2015-10-23 23:53:41 | [diff] [blame] | 212 | params.quic_close_sessions_on_ip_change, |
zhongyi | 89649c3 | 2016-01-22 00:14:01 | [diff] [blame] | 213 | params.disable_quic_on_timeout_with_open_streams, |
rtenneti | 41c0999 | 2015-11-30 18:24:01 | [diff] [blame] | 214 | params.quic_idle_connection_timeout_seconds, |
zhongyi | dd1439f6 | 2016-09-02 02:02:26 | [diff] [blame] | 215 | params.quic_reduced_ping_timeout_seconds, |
zhongyi | 6ba0f425 | 2016-08-23 05:20:04 | [diff] [blame] | 216 | params.quic_packet_reader_yield_after_duration_milliseconds, |
jri | 7e63664 | 2016-01-14 06:57:08 | [diff] [blame] | 217 | params.quic_migrate_sessions_on_network_change, |
jri | d36ada6 | 2016-02-06 02:42:08 | [diff] [blame] | 218 | params.quic_migrate_sessions_early, |
jri | 217455a1 | 2016-07-13 20:15:09 | [diff] [blame] | 219 | params.quic_allow_server_migration, |
ckrasic | da193a8 | 2016-07-09 00:39:36 | [diff] [blame] | 220 | params.quic_force_hol_blocking, |
rtenneti | d073dd2 | 2016-08-04 01:58:33 | [diff] [blame] | 221 | params.quic_race_cert_verification, |
rch | bedd5745 | 2016-08-30 19:11:48 | [diff] [blame] | 222 | params.quic_do_not_fragment, |
rch | d6163f3 | 2017-01-30 23:50:38 | [diff] [blame] | 223 | params.quic_estimate_initial_rtt, |
nharper | d5cddca | 2016-02-27 03:37:52 | [diff] [blame] | 224 | params.quic_connection_options, |
| 225 | params.enable_token_binding), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 226 | spdy_session_pool_(params.host_resolver, |
| 227 | params.ssl_config_service, |
| 228 | params.http_server_properties, |
[email protected] | 5db45220 | 2014-08-19 05:22:15 | [diff] [blame] | 229 | params.transport_security_state, |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 230 | params.enable_spdy_ping_based_connection_checking, |
bnc | 8f0f3b6 | 2015-04-08 04:37:23 | [diff] [blame] | 231 | params.spdy_session_max_recv_window_size, |
bnc | 3171a243 | 2016-12-28 18:40:26 | [diff] [blame] | 232 | AddDefaultHttp2Settings(params.http2_settings), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 233 | params.time_func, |
tbansal | 28e68f8 | 2016-02-04 02:56:15 | [diff] [blame] | 234 | params.proxy_delegate), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 235 | http_stream_factory_(new HttpStreamFactoryImpl(this, false)), |
jri | 2b966f2 | 2014-09-02 22:25:36 | [diff] [blame] | 236 | http_stream_factory_for_websocket_(new HttpStreamFactoryImpl(this, true)), |
rdsmith | bf8c3c1 | 2016-11-18 18:16:24 | [diff] [blame] | 237 | network_stream_throttler_(new NetworkThrottleManagerImpl()), |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 238 | params_(params) { |
| 239 | DCHECK(proxy_service_); |
| 240 | DCHECK(ssl_config_service_.get()); |
| 241 | CHECK(http_server_properties_); |
| 242 | |
vitalybuka | bfe0e427 | 2015-12-03 01:51:42 | [diff] [blame] | 243 | const std::string ssl_session_cache_shard = |
| 244 | "http_network_session/" + base::IntToString(g_next_shard_id.GetNext()); |
| 245 | normal_socket_pool_manager_.reset(CreateSocketPoolManager( |
| 246 | NORMAL_SOCKET_POOL, params, ssl_session_cache_shard)); |
| 247 | websocket_socket_pool_manager_.reset(CreateSocketPoolManager( |
| 248 | WEBSOCKET_SOCKET_POOL, params, ssl_session_cache_shard)); |
| 249 | |
bnc | 3f0118e | 2016-02-02 15:42:22 | [diff] [blame] | 250 | if (params_.enable_http2) { |
| 251 | next_protos_.push_back(kProtoHTTP2); |
bnc | 3f0118e | 2016-02-02 15:42:22 | [diff] [blame] | 252 | } |
| 253 | |
| 254 | next_protos_.push_back(kProtoHTTP11); |
| 255 | |
rtenneti | 6971c17 | 2016-01-15 20:12:10 | [diff] [blame] | 256 | http_server_properties_->SetMaxServerConfigsStoredInProperties( |
| 257 | params.quic_max_server_configs_stored_in_properties); |
maksim.sisov | 0adf859 | 2016-07-15 06:25:56 | [diff] [blame] | 258 | |
| 259 | memory_pressure_listener_.reset(new base::MemoryPressureListener(base::Bind( |
| 260 | &HttpNetworkSession::OnMemoryPressure, base::Unretained(this)))); |
hajimehoshi | 8156e7c | 2016-09-29 06:17:52 | [diff] [blame] | 261 | base::MemoryCoordinatorClientRegistry::GetInstance()->Register(this); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 262 | } |
| 263 | |
| 264 | HttpNetworkSession::~HttpNetworkSession() { |
avi | fceb32f6 | 2016-10-07 16:30:52 | [diff] [blame] | 265 | response_drainers_.clear(); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 266 | spdy_session_pool_.CloseAllSessions(); |
hajimehoshi | 8156e7c | 2016-09-29 06:17:52 | [diff] [blame] | 267 | base::MemoryCoordinatorClientRegistry::GetInstance()->Unregister(this); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 268 | } |
| 269 | |
avi | fceb32f6 | 2016-10-07 16:30:52 | [diff] [blame] | 270 | void HttpNetworkSession::AddResponseDrainer( |
| 271 | std::unique_ptr<HttpResponseBodyDrainer> drainer) { |
| 272 | DCHECK(!base::ContainsKey(response_drainers_, drainer.get())); |
| 273 | HttpResponseBodyDrainer* drainer_ptr = drainer.get(); |
| 274 | response_drainers_[drainer_ptr] = std::move(drainer); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 275 | } |
| 276 | |
| 277 | void HttpNetworkSession::RemoveResponseDrainer( |
| 278 | HttpResponseBodyDrainer* drainer) { |
skyostil | b8f60ca | 2016-08-12 12:34:43 | [diff] [blame] | 279 | DCHECK(base::ContainsKey(response_drainers_, drainer)); |
avi | fceb32f6 | 2016-10-07 16:30:52 | [diff] [blame] | 280 | response_drainers_[drainer].release(); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 281 | response_drainers_.erase(drainer); |
| 282 | } |
| 283 | |
| 284 | TransportClientSocketPool* HttpNetworkSession::GetTransportSocketPool( |
| 285 | SocketPoolType pool_type) { |
| 286 | return GetSocketPoolManager(pool_type)->GetTransportSocketPool(); |
| 287 | } |
| 288 | |
| 289 | SSLClientSocketPool* HttpNetworkSession::GetSSLSocketPool( |
| 290 | SocketPoolType pool_type) { |
| 291 | return GetSocketPoolManager(pool_type)->GetSSLSocketPool(); |
| 292 | } |
| 293 | |
| 294 | SOCKSClientSocketPool* HttpNetworkSession::GetSocketPoolForSOCKSProxy( |
| 295 | SocketPoolType pool_type, |
| 296 | const HostPortPair& socks_proxy) { |
| 297 | return GetSocketPoolManager(pool_type)->GetSocketPoolForSOCKSProxy( |
| 298 | socks_proxy); |
| 299 | } |
| 300 | |
| 301 | HttpProxyClientSocketPool* HttpNetworkSession::GetSocketPoolForHTTPProxy( |
| 302 | SocketPoolType pool_type, |
| 303 | const HostPortPair& http_proxy) { |
| 304 | return GetSocketPoolManager(pool_type)->GetSocketPoolForHTTPProxy(http_proxy); |
| 305 | } |
| 306 | |
| 307 | SSLClientSocketPool* HttpNetworkSession::GetSocketPoolForSSLWithProxy( |
| 308 | SocketPoolType pool_type, |
| 309 | const HostPortPair& proxy_server) { |
| 310 | return GetSocketPoolManager(pool_type)->GetSocketPoolForSSLWithProxy( |
| 311 | proxy_server); |
| 312 | } |
| 313 | |
danakj | 1fd259a0 | 2016-04-16 03:17:09 | [diff] [blame] | 314 | std::unique_ptr<base::Value> HttpNetworkSession::SocketPoolInfoToValue() const { |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 315 | // TODO(yutak): Should merge values from normal pools and WebSocket pools. |
| 316 | return normal_socket_pool_manager_->SocketPoolInfoToValue(); |
| 317 | } |
| 318 | |
danakj | 1fd259a0 | 2016-04-16 03:17:09 | [diff] [blame] | 319 | std::unique_ptr<base::Value> HttpNetworkSession::SpdySessionPoolInfoToValue() |
| 320 | const { |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 321 | return spdy_session_pool_.SpdySessionPoolInfoToValue(); |
| 322 | } |
| 323 | |
danakj | 1fd259a0 | 2016-04-16 03:17:09 | [diff] [blame] | 324 | std::unique_ptr<base::Value> HttpNetworkSession::QuicInfoToValue() const { |
| 325 | std::unique_ptr<base::DictionaryValue> dict(new base::DictionaryValue()); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 326 | dict->Set("sessions", quic_stream_factory_.QuicStreamFactoryInfoToValue()); |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 327 | dict->SetBoolean("quic_enabled", IsQuicEnabled()); |
danakj | 1fd259a0 | 2016-04-16 03:17:09 | [diff] [blame] | 328 | std::unique_ptr<base::ListValue> connection_options(new base::ListValue); |
[email protected] | ecb4dc3 | 2014-08-16 05:49:25 | [diff] [blame] | 329 | for (QuicTagVector::const_iterator it = |
| 330 | params_.quic_connection_options.begin(); |
| 331 | it != params_.quic_connection_options.end(); ++it) { |
mpw | 94250b8 | 2016-11-19 18:13:30 | [diff] [blame] | 332 | connection_options->AppendString("'" + QuicTagToString(*it) + "'"); |
[email protected] | ecb4dc3 | 2014-08-16 05:49:25 | [diff] [blame] | 333 | } |
dcheng | c7eeda42 | 2015-12-26 03:56:48 | [diff] [blame] | 334 | dict->Set("connection_options", std::move(connection_options)); |
rtenneti | 8a2f463 | 2016-03-21 20:26:57 | [diff] [blame] | 335 | |
danakj | 1fd259a0 | 2016-04-16 03:17:09 | [diff] [blame] | 336 | std::unique_ptr<base::ListValue> origins_to_force_quic_on( |
| 337 | new base::ListValue); |
rtenneti | 8a2f463 | 2016-03-21 20:26:57 | [diff] [blame] | 338 | for (const auto& origin : params_.origins_to_force_quic_on) { |
| 339 | origins_to_force_quic_on->AppendString("'" + origin.ToString() + "'"); |
| 340 | } |
| 341 | dict->Set("origins_to_force_quic_on", std::move(origins_to_force_quic_on)); |
| 342 | |
rtenneti | f4b29d7 | 2016-01-11 19:29:39 | [diff] [blame] | 343 | dict->SetDouble("load_server_info_timeout_srtt_multiplier", |
| 344 | params_.quic_load_server_info_timeout_srtt_multiplier); |
| 345 | dict->SetBoolean("enable_connection_racing", |
| 346 | params_.quic_enable_connection_racing); |
| 347 | dict->SetBoolean("disable_disk_cache", params_.quic_disable_disk_cache); |
| 348 | dict->SetBoolean("prefer_aes", params_.quic_prefer_aes); |
rtenneti | b8e80fb | 2016-05-16 00:12:09 | [diff] [blame] | 349 | dict->SetBoolean("delay_tcp_race", params_.quic_delay_tcp_race); |
rtenneti | 6971c17 | 2016-01-15 20:12:10 | [diff] [blame] | 350 | dict->SetInteger("max_server_configs_stored_in_properties", |
| 351 | params_.quic_max_server_configs_stored_in_properties); |
rtenneti | f4b29d7 | 2016-01-11 19:29:39 | [diff] [blame] | 352 | dict->SetInteger("idle_connection_timeout_seconds", |
| 353 | params_.quic_idle_connection_timeout_seconds); |
zhongyi | dd1439f6 | 2016-09-02 02:02:26 | [diff] [blame] | 354 | dict->SetInteger("reduced_ping_timeout_seconds", |
| 355 | params_.quic_reduced_ping_timeout_seconds); |
zhongyi | 6ba0f425 | 2016-08-23 05:20:04 | [diff] [blame] | 356 | dict->SetInteger( |
| 357 | "packet_reader_yield_after_duration_milliseconds", |
| 358 | params_.quic_packet_reader_yield_after_duration_milliseconds); |
rtenneti | f4b29d7 | 2016-01-11 19:29:39 | [diff] [blame] | 359 | dict->SetBoolean("disable_preconnect_if_0rtt", |
| 360 | params_.quic_disable_preconnect_if_0rtt); |
rtenneti | b60e77a | 2016-03-29 17:34:37 | [diff] [blame] | 361 | dict->SetBoolean("disable_quic_on_timeout_with_open_streams", |
| 362 | params_.disable_quic_on_timeout_with_open_streams); |
rch | 703d0e0 | 2016-09-13 18:35:36 | [diff] [blame] | 363 | dict->SetBoolean("is_quic_disabled", quic_stream_factory_.IsQuicDisabled()); |
ckrasic | da193a8 | 2016-07-09 00:39:36 | [diff] [blame] | 364 | dict->SetBoolean("force_hol_blocking", params_.quic_force_hol_blocking); |
rtenneti | d073dd2 | 2016-08-04 01:58:33 | [diff] [blame] | 365 | dict->SetBoolean("race_cert_verification", |
| 366 | params_.quic_race_cert_verification); |
dcheng | c7eeda42 | 2015-12-26 03:56:48 | [diff] [blame] | 367 | return std::move(dict); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 368 | } |
| 369 | |
| 370 | void HttpNetworkSession::CloseAllConnections() { |
| 371 | normal_socket_pool_manager_->FlushSocketPoolsWithError(ERR_ABORTED); |
| 372 | websocket_socket_pool_manager_->FlushSocketPoolsWithError(ERR_ABORTED); |
| 373 | spdy_session_pool_.CloseCurrentSessions(ERR_ABORTED); |
jri | 7e63664 | 2016-01-14 06:57:08 | [diff] [blame] | 374 | quic_stream_factory_.CloseAllSessions(ERR_ABORTED, QUIC_INTERNAL_ERROR); |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 375 | } |
| 376 | |
| 377 | void HttpNetworkSession::CloseIdleConnections() { |
| 378 | normal_socket_pool_manager_->CloseIdleSockets(); |
| 379 | websocket_socket_pool_manager_->CloseIdleSockets(); |
| 380 | spdy_session_pool_.CloseCurrentIdleSessions(); |
| 381 | } |
| 382 | |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 383 | bool HttpNetworkSession::IsProtocolEnabled(NextProto protocol) const { |
bnc | 8f8225c | 2016-09-23 21:19:46 | [diff] [blame] | 384 | switch (protocol) { |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 385 | case kProtoUnknown: |
bnc | 8f8225c | 2016-09-23 21:19:46 | [diff] [blame] | 386 | NOTREACHED(); |
| 387 | return false; |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 388 | case kProtoHTTP11: |
| 389 | return true; |
| 390 | case kProtoHTTP2: |
| 391 | return params_.enable_http2; |
| 392 | case kProtoQUIC: |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 393 | return IsQuicEnabled(); |
bnc | 8f8225c | 2016-09-23 21:19:46 | [diff] [blame] | 394 | } |
| 395 | NOTREACHED(); |
| 396 | return false; |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 397 | } |
| 398 | |
zhongyi | af25754 | 2016-12-19 03:36:01 | [diff] [blame] | 399 | void HttpNetworkSession::SetServerPushDelegate( |
| 400 | std::unique_ptr<ServerPushDelegate> push_delegate) { |
| 401 | DCHECK(!push_delegate_ && push_delegate); |
| 402 | |
| 403 | push_delegate_ = std::move(push_delegate); |
| 404 | spdy_session_pool_.set_server_push_delegate(push_delegate_.get()); |
| 405 | quic_stream_factory_.set_server_push_delegate(push_delegate_.get()); |
| 406 | } |
| 407 | |
bnc | 1f29537 | 2015-10-21 23:24:22 | [diff] [blame] | 408 | void HttpNetworkSession::GetAlpnProtos(NextProtoVector* alpn_protos) const { |
bnc | 927c496 | 2016-07-21 14:45:59 | [diff] [blame] | 409 | *alpn_protos = next_protos_; |
bnc | 1f29537 | 2015-10-21 23:24:22 | [diff] [blame] | 410 | } |
| 411 | |
nharper | 8cdb0fb | 2016-04-22 21:34:59 | [diff] [blame] | 412 | void HttpNetworkSession::GetSSLConfig(const HttpRequestInfo& request, |
| 413 | SSLConfig* server_config, |
| 414 | SSLConfig* proxy_config) const { |
| 415 | ssl_config_service_->GetSSLConfig(server_config); |
| 416 | GetAlpnProtos(&server_config->alpn_protos); |
nharper | 8cdb0fb | 2016-04-22 21:34:59 | [diff] [blame] | 417 | *proxy_config = *server_config; |
| 418 | if (request.privacy_mode == PRIVACY_MODE_ENABLED) { |
| 419 | server_config->channel_id_enabled = false; |
| 420 | } else if (params_.enable_token_binding && params_.channel_id_service) { |
| 421 | server_config->token_binding_params.push_back(TB_PARAM_ECDSAP256); |
| 422 | } |
| 423 | } |
| 424 | |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 425 | void HttpNetworkSession::DumpMemoryStats( |
| 426 | base::trace_event::ProcessMemoryDump* pmd, |
| 427 | const std::string& parent_absolute_name) const { |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame^] | 428 | std::string name = base::StringPrintf("net/http_network_session_0x%" PRIxPTR, |
| 429 | reinterpret_cast<uintptr_t>(this)); |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 430 | base::trace_event::MemoryAllocatorDump* http_network_session_dump = |
| 431 | pmd->GetAllocatorDump(name); |
xunjieli | 2a2468bd | 2017-01-04 21:17:33 | [diff] [blame] | 432 | if (http_network_session_dump == nullptr) { |
| 433 | http_network_session_dump = pmd->CreateAllocatorDump(name); |
| 434 | normal_socket_pool_manager_->DumpMemoryStats( |
| 435 | pmd, http_network_session_dump->absolute_name()); |
| 436 | spdy_session_pool_.DumpMemoryStats( |
| 437 | pmd, http_network_session_dump->absolute_name()); |
xunjieli | f5267de | 2017-01-20 21:18:57 | [diff] [blame] | 438 | if (http_stream_factory_) { |
| 439 | http_stream_factory_->DumpMemoryStats( |
| 440 | pmd, http_network_session_dump->absolute_name()); |
| 441 | } |
xunjieli | 69720dd | 2017-01-30 15:36:29 | [diff] [blame] | 442 | quic_stream_factory_.DumpMemoryStats( |
| 443 | pmd, http_network_session_dump->absolute_name()); |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 444 | } |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame^] | 445 | |
xunjieli | 2a2468bd | 2017-01-04 21:17:33 | [diff] [blame] | 446 | // Create an empty row under parent's dump so size can be attributed correctly |
| 447 | // if |this| is shared between URLRequestContexts. |
| 448 | base::trace_event::MemoryAllocatorDump* empty_row_dump = |
| 449 | pmd->CreateAllocatorDump(base::StringPrintf( |
| 450 | "%s/http_network_session", parent_absolute_name.c_str())); |
| 451 | pmd->AddOwnershipEdge(empty_row_dump->guid(), |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 452 | http_network_session_dump->guid()); |
| 453 | } |
| 454 | |
pmarko | 6ab8be24 | 2017-01-11 11:02:55 | [diff] [blame] | 455 | bool HttpNetworkSession::IsQuicEnabled() const { |
| 456 | return params_.enable_quic; |
| 457 | } |
| 458 | |
| 459 | void HttpNetworkSession::DisableQuic() { |
| 460 | params_.enable_quic = false; |
| 461 | } |
| 462 | |
[email protected] | cf4cae3 | 2014-05-27 00:39:10 | [diff] [blame] | 463 | ClientSocketPoolManager* HttpNetworkSession::GetSocketPoolManager( |
| 464 | SocketPoolType pool_type) { |
| 465 | switch (pool_type) { |
| 466 | case NORMAL_SOCKET_POOL: |
| 467 | return normal_socket_pool_manager_.get(); |
| 468 | case WEBSOCKET_SOCKET_POOL: |
| 469 | return websocket_socket_pool_manager_.get(); |
| 470 | default: |
| 471 | NOTREACHED(); |
| 472 | break; |
| 473 | } |
| 474 | return NULL; |
| 475 | } |
| 476 | |
maksim.sisov | 0adf859 | 2016-07-15 06:25:56 | [diff] [blame] | 477 | void HttpNetworkSession::OnMemoryPressure( |
| 478 | base::MemoryPressureListener::MemoryPressureLevel memory_pressure_level) { |
| 479 | switch (memory_pressure_level) { |
| 480 | case base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE: |
| 481 | break; |
| 482 | case base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_MODERATE: |
| 483 | case base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_CRITICAL: |
| 484 | CloseIdleConnections(); |
| 485 | break; |
| 486 | } |
| 487 | } |
| 488 | |
bashi | 56b23f30 | 2017-02-09 01:24:57 | [diff] [blame] | 489 | void HttpNetworkSession::OnPurgeMemory() { |
| 490 | CloseIdleConnections(); |
hajimehoshi | 8156e7c | 2016-09-29 06:17:52 | [diff] [blame] | 491 | } |
| 492 | |
ttuttle | 859dc7a | 2015-04-23 19:42:29 | [diff] [blame] | 493 | } // namespace net |