[email protected] | aa84a7e | 2012-03-15 21:29:06 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
[email protected] | f1d8192 | 2010-07-31 17:47:09 | [diff] [blame] | 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/url_request/url_request_context.h" |
| 6 | |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 7 | #include <inttypes.h> |
| 8 | |
[email protected] | 18590f2 | 2011-07-29 16:41:28 | [diff] [blame] | 9 | #include "base/compiler_specific.h" |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 10 | #include "base/debug/alias.h" |
danakj | 8522a25b | 2016-04-16 00:17:36 | [diff] [blame] | 11 | #include "base/memory/ptr_util.h" |
Ilya Sherman | 0eb3980 | 2017-12-08 20:58:18 | [diff] [blame] | 12 | #include "base/metrics/histogram_functions.h" |
xunjieli | 3fcbcc1 | 2017-04-26 15:51:19 | [diff] [blame] | 13 | #include "base/metrics/histogram_macros.h" |
[email protected] | 4dc3ad4f | 2013-06-11 07:15:50 | [diff] [blame] | 14 | #include "base/strings/string_util.h" |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 15 | #include "base/strings/stringprintf.h" |
fdoray | a19b770 | 2016-12-23 14:19:31 | [diff] [blame] | 16 | #include "base/threading/thread_task_runner_handle.h" |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 17 | #include "base/trace_event/memory_allocator_dump.h" |
| 18 | #include "base/trace_event/memory_dump_manager.h" |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 19 | #include "base/trace_event/memory_dump_request_args.h" |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 20 | #include "base/trace_event/process_memory_dump.h" |
[email protected] | aa84a7e | 2012-03-15 21:29:06 | [diff] [blame] | 21 | #include "net/cookies/cookie_store.h" |
[email protected] | f2cb3cf | 2013-03-21 01:40:53 | [diff] [blame] | 22 | #include "net/dns/host_resolver.h" |
xunjieli | a0166f4 | 2017-02-23 17:44:57 | [diff] [blame] | 23 | #include "net/http/http_cache.h" |
[email protected] | f6c21cb | 2011-02-16 19:45:41 | [diff] [blame] | 24 | #include "net/http/http_transaction_factory.h" |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 25 | #include "net/socket/ssl_client_socket_impl.h" |
[email protected] | ee4c30d | 2012-11-07 15:08:43 | [diff] [blame] | 26 | #include "net/url_request/http_user_agent_settings.h" |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 27 | #include "net/url_request/url_request.h" |
[email protected] | 9349cfb | 2010-08-31 18:00:53 | [diff] [blame] | 28 | |
[email protected] | 27a112c | 2011-01-06 04:19:30 | [diff] [blame] | 29 | namespace net { |
| 30 | |
[email protected] | 9349cfb | 2010-08-31 18:00:53 | [diff] [blame] | 31 | URLRequestContext::URLRequestContext() |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 32 | : net_log_(nullptr), |
| 33 | host_resolver_(nullptr), |
| 34 | cert_verifier_(nullptr), |
| 35 | channel_id_service_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 36 | http_auth_handler_factory_(nullptr), |
Lily Houghton | 8c2f97d | 2018-01-22 05:06:59 | [diff] [blame] | 37 | proxy_resolution_service_(nullptr), |
Wojciech Dzierżanowski | 1f82356 | 2019-01-18 11:26:00 | [diff] [blame^] | 38 | proxy_delegate_(nullptr), |
Ryan Sleevi | b8449e0 | 2018-07-15 04:31:07 | [diff] [blame] | 39 | ssl_config_service_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 40 | network_delegate_(nullptr), |
bnc | 525e175a | 2016-06-20 12:36:40 | [diff] [blame] | 41 | http_server_properties_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 42 | http_user_agent_settings_(nullptr), |
mmenke | 606c59c | 2016-03-07 18:20:55 | [diff] [blame] | 43 | cookie_store_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 44 | transport_security_state_(nullptr), |
| 45 | cert_transparency_verifier_(nullptr), |
rsleevi | d6de830 | 2016-06-21 01:33:20 | [diff] [blame] | 46 | ct_policy_enforcer_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 47 | http_transaction_factory_(nullptr), |
| 48 | job_factory_(nullptr), |
| 49 | throttler_manager_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 50 | network_quality_estimator_(nullptr), |
Julia Tuttle | 3f9acac | 2017-11-20 22:06:30 | [diff] [blame] | 51 | #if BUILDFLAG(ENABLE_REPORTING) |
juliatuttle | 2b8dd2d1 | 2017-04-12 21:27:41 | [diff] [blame] | 52 | reporting_service_(nullptr), |
Julia Tuttle | cba7d22 | 2018-02-23 19:37:27 | [diff] [blame] | 53 | network_error_logging_service_(nullptr), |
Julia Tuttle | 3f9acac | 2017-11-20 22:06:30 | [diff] [blame] | 54 | #endif // BUILDFLAG(ENABLE_REPORTING) |
Helen Li | f5e4a75 | 2018-01-02 16:03:02 | [diff] [blame] | 55 | url_requests_(std::make_unique<std::set<const URLRequest*>>()), |
mgersh | d21d6d14 | 2016-12-14 23:06:36 | [diff] [blame] | 56 | enable_brotli_(false), |
xunjieli | c4da1de | 2017-03-28 16:19:50 | [diff] [blame] | 57 | check_cleartext_permitted_(false), |
Helen Li | f5e4a75 | 2018-01-02 16:03:02 | [diff] [blame] | 58 | name_("unknown") { |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 59 | base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider( |
| 60 | this, "URLRequestContext", base::ThreadTaskRunnerHandle::Get()); |
| 61 | } |
[email protected] | f1d8192 | 2010-07-31 17:47:09 | [diff] [blame] | 62 | |
[email protected] | ef2bf42 | 2012-05-11 03:27:09 | [diff] [blame] | 63 | URLRequestContext::~URLRequestContext() { |
gab | 47aa7da | 2017-06-02 16:09:43 | [diff] [blame] | 64 | DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); |
[email protected] | ef2bf42 | 2012-05-11 03:27:09 | [diff] [blame] | 65 | AssertNoURLRequests(); |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 66 | base::trace_event::MemoryDumpManager::GetInstance()->UnregisterDumpProvider( |
| 67 | this); |
[email protected] | ef2bf42 | 2012-05-11 03:27:09 | [diff] [blame] | 68 | } |
| 69 | |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 70 | void URLRequestContext::CopyFrom(const URLRequestContext* other) { |
[email protected] | d969667 | 2011-03-15 22:45:09 | [diff] [blame] | 71 | // Copy URLRequestContext parameters. |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 72 | set_net_log(other->net_log_); |
| 73 | set_host_resolver(other->host_resolver_); |
| 74 | set_cert_verifier(other->cert_verifier_); |
[email protected] | 6b8a3c74 | 2014-07-25 00:25:35 | [diff] [blame] | 75 | set_channel_id_service(other->channel_id_service_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 76 | set_http_auth_handler_factory(other->http_auth_handler_factory_); |
Lily Houghton | 8c2f97d | 2018-01-22 05:06:59 | [diff] [blame] | 77 | set_proxy_resolution_service(other->proxy_resolution_service_); |
Wojciech Dzierżanowski | 1f82356 | 2019-01-18 11:26:00 | [diff] [blame^] | 78 | set_proxy_delegate(other->proxy_delegate_); |
Ryan Sleevi | b8449e0 | 2018-07-15 04:31:07 | [diff] [blame] | 79 | set_ssl_config_service(other->ssl_config_service_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 80 | set_network_delegate(other->network_delegate_); |
| 81 | set_http_server_properties(other->http_server_properties_); |
mmenke | 606c59c | 2016-03-07 18:20:55 | [diff] [blame] | 82 | set_cookie_store(other->cookie_store_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 83 | set_transport_security_state(other->transport_security_state_); |
[email protected] | 284303b6 | 2013-11-28 15:11:54 | [diff] [blame] | 84 | set_cert_transparency_verifier(other->cert_transparency_verifier_); |
rsleevi | d6de830 | 2016-06-21 01:33:20 | [diff] [blame] | 85 | set_ct_policy_enforcer(other->ct_policy_enforcer_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 86 | set_http_transaction_factory(other->http_transaction_factory_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 87 | set_job_factory(other->job_factory_); |
| 88 | set_throttler_manager(other->throttler_manager_); |
[email protected] | ee4c30d | 2012-11-07 15:08:43 | [diff] [blame] | 89 | set_http_user_agent_settings(other->http_user_agent_settings_); |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 90 | set_network_quality_estimator(other->network_quality_estimator_); |
Julia Tuttle | 3f9acac | 2017-11-20 22:06:30 | [diff] [blame] | 91 | #if BUILDFLAG(ENABLE_REPORTING) |
juliatuttle | 2b8dd2d1 | 2017-04-12 21:27:41 | [diff] [blame] | 92 | set_reporting_service(other->reporting_service_); |
Julia Tuttle | cba7d22 | 2018-02-23 19:37:27 | [diff] [blame] | 93 | set_network_error_logging_service(other->network_error_logging_service_); |
Julia Tuttle | 3f9acac | 2017-11-20 22:06:30 | [diff] [blame] | 94 | #endif // BUILDFLAG(ENABLE_REPORTING) |
maksim.sisov | 3d40c81 | 2016-05-02 13:27:16 | [diff] [blame] | 95 | set_enable_brotli(other->enable_brotli_); |
mgersh | d21d6d14 | 2016-12-14 23:06:36 | [diff] [blame] | 96 | set_check_cleartext_permitted(other->check_cleartext_permitted_); |
[email protected] | d969667 | 2011-03-15 22:45:09 | [diff] [blame] | 97 | } |
| 98 | |
[email protected] | c2dad29 | 2012-09-07 21:27:35 | [diff] [blame] | 99 | const HttpNetworkSession::Params* URLRequestContext::GetNetworkSessionParams( |
| 100 | ) const { |
| 101 | HttpTransactionFactory* transaction_factory = http_transaction_factory(); |
| 102 | if (!transaction_factory) |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 103 | return nullptr; |
[email protected] | c2dad29 | 2012-09-07 21:27:35 | [diff] [blame] | 104 | HttpNetworkSession* network_session = transaction_factory->GetSession(); |
| 105 | if (!network_session) |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 106 | return nullptr; |
[email protected] | c2dad29 | 2012-09-07 21:27:35 | [diff] [blame] | 107 | return &network_session->params(); |
| 108 | } |
| 109 | |
mmenke | 6ddfbea | 2017-05-31 21:48:41 | [diff] [blame] | 110 | const HttpNetworkSession::Context* URLRequestContext::GetNetworkSessionContext() |
| 111 | const { |
| 112 | HttpTransactionFactory* transaction_factory = http_transaction_factory(); |
| 113 | if (!transaction_factory) |
| 114 | return nullptr; |
| 115 | HttpNetworkSession* network_session = transaction_factory->GetSession(); |
| 116 | if (!network_session) |
| 117 | return nullptr; |
| 118 | return &network_session->context(); |
| 119 | } |
| 120 | |
danakj | 8522a25b | 2016-04-16 00:17:36 | [diff] [blame] | 121 | std::unique_ptr<URLRequest> URLRequestContext::CreateRequest( |
[email protected] | 2ca01e5 | 2013-10-31 22:05:19 | [diff] [blame] | 122 | const GURL& url, |
| 123 | RequestPriority priority, |
davidben | 151423e | 2015-03-23 18:48:36 | [diff] [blame] | 124 | URLRequest::Delegate* delegate) const { |
rhalavati | 0e2a227 | 2017-05-23 13:10:32 | [diff] [blame] | 125 | return CreateRequest(url, priority, delegate, MISSING_TRAFFIC_ANNOTATION); |
[email protected] | 8a26ff6 | 2012-08-24 21:49:20 | [diff] [blame] | 126 | } |
| 127 | |
rhalavati | a9b551d | 2017-02-09 12:03:00 | [diff] [blame] | 128 | std::unique_ptr<URLRequest> URLRequestContext::CreateRequest( |
| 129 | const GURL& url, |
| 130 | RequestPriority priority, |
| 131 | URLRequest::Delegate* delegate, |
| 132 | NetworkTrafficAnnotationTag traffic_annotation) const { |
rhalavati | 0e2a227 | 2017-05-23 13:10:32 | [diff] [blame] | 133 | return base::WrapUnique(new URLRequest( |
| 134 | url, priority, delegate, this, network_delegate_, traffic_annotation)); |
rhalavati | a9b551d | 2017-02-09 12:03:00 | [diff] [blame] | 135 | } |
| 136 | |
[email protected] | d100e44f | 2011-01-26 22:47:11 | [diff] [blame] | 137 | void URLRequestContext::set_cookie_store(CookieStore* cookie_store) { |
| 138 | cookie_store_ = cookie_store; |
| 139 | } |
| 140 | |
[email protected] | 1e714bba | 2012-04-10 17:01:05 | [diff] [blame] | 141 | void URLRequestContext::AssertNoURLRequests() const { |
Helen Li | f5e4a75 | 2018-01-02 16:03:02 | [diff] [blame] | 142 | int num_requests = url_requests_->size(); |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 143 | if (num_requests != 0) { |
| 144 | // We're leaking URLRequests :( Dump the URL of the first one and record how |
| 145 | // many we leaked so we have an idea of how bad it is. |
Helen Li | f5e4a75 | 2018-01-02 16:03:02 | [diff] [blame] | 146 | const URLRequest* request = *url_requests_->begin(); |
[email protected] | eb4ecaca | 2012-05-04 01:05:03 | [diff] [blame] | 147 | int load_flags = request->load_flags(); |
Lukasz Anforowicz | 68c2177 | 2018-01-13 03:42:44 | [diff] [blame] | 148 | DEBUG_ALIAS_FOR_GURL(url_buf, request->url()); |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 149 | base::debug::Alias(&num_requests); |
[email protected] | eb4ecaca | 2012-05-04 01:05:03 | [diff] [blame] | 150 | base::debug::Alias(&load_flags); |
[email protected] | 1f5f8e2 | 2012-09-06 23:40:54 | [diff] [blame] | 151 | CHECK(false) << "Leaked " << num_requests << " URLRequest(s). First URL: " |
| 152 | << request->url().spec().c_str() << "."; |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 153 | } |
[email protected] | 9349cfb | 2010-08-31 18:00:53 | [diff] [blame] | 154 | } |
[email protected] | 2fb62920 | 2010-12-23 23:52:57 | [diff] [blame] | 155 | |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 156 | bool URLRequestContext::OnMemoryDump( |
| 157 | const base::trace_event::MemoryDumpArgs& args, |
| 158 | base::trace_event::ProcessMemoryDump* pmd) { |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 159 | SSLClientSocketImpl::DumpSSLClientSessionMemoryStats(pmd); |
| 160 | |
xunjieli | c4da1de | 2017-03-28 16:19:50 | [diff] [blame] | 161 | std::string dump_name = |
Matt Menke | 7d4b66f7 | 2017-09-26 04:09:55 | [diff] [blame] | 162 | base::StringPrintf("net/url_request_context/%s/0x%" PRIxPTR, |
| 163 | name_.c_str(), reinterpret_cast<uintptr_t>(this)); |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 164 | base::trace_event::MemoryAllocatorDump* dump = |
| 165 | pmd->CreateAllocatorDump(dump_name); |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 166 | dump->AddScalar(base::trace_event::MemoryAllocatorDump::kNameObjectCount, |
| 167 | base::trace_event::MemoryAllocatorDump::kUnitsObjects, |
Helen Li | f5e4a75 | 2018-01-02 16:03:02 | [diff] [blame] | 168 | url_requests_->size()); |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 169 | HttpTransactionFactory* transaction_factory = http_transaction_factory(); |
| 170 | if (transaction_factory) { |
| 171 | HttpNetworkSession* network_session = transaction_factory->GetSession(); |
| 172 | if (network_session) |
| 173 | network_session->DumpMemoryStats(pmd, dump->absolute_name()); |
xunjieli | a0166f4 | 2017-02-23 17:44:57 | [diff] [blame] | 174 | HttpCache* http_cache = transaction_factory->GetCache(); |
| 175 | if (http_cache) |
| 176 | http_cache->DumpMemoryStats(pmd, dump->absolute_name()); |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 177 | } |
Maks Orlovich | 5cf437b0 | 2018-03-27 04:40:42 | [diff] [blame] | 178 | if (cookie_store_) { |
| 179 | cookie_store_->DumpMemoryStats(pmd, dump->absolute_name()); |
| 180 | } |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 181 | return true; |
| 182 | } |
| 183 | |
[email protected] | 27a112c | 2011-01-06 04:19:30 | [diff] [blame] | 184 | } // namespace net |