[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" |
[email protected] | 4dc3ad4f | 2013-06-11 07:15:50 | [diff] [blame] | 12 | #include "base/strings/string_util.h" |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 13 | #include "base/strings/stringprintf.h" |
fdoray | a19b770 | 2016-12-23 14:19:31 | [diff] [blame] | 14 | #include "base/threading/thread_task_runner_handle.h" |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 15 | #include "base/trace_event/memory_allocator_dump.h" |
| 16 | #include "base/trace_event/memory_dump_manager.h" |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 17 | #include "base/trace_event/memory_dump_request_args.h" |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 18 | #include "base/trace_event/process_memory_dump.h" |
xunjieli | d701b6e5 | 2017-01-04 22:17:42 | [diff] [blame] | 19 | #include "net/base/sdch_manager.h" |
[email protected] | aa84a7e | 2012-03-15 21:29:06 | [diff] [blame] | 20 | #include "net/cookies/cookie_store.h" |
[email protected] | f2cb3cf | 2013-03-21 01:40:53 | [diff] [blame] | 21 | #include "net/dns/host_resolver.h" |
xunjieli | a0166f4 | 2017-02-23 17:44:57 | [diff] [blame] | 22 | #include "net/http/http_cache.h" |
[email protected] | f6c21cb | 2011-02-16 19:45:41 | [diff] [blame] | 23 | #include "net/http/http_transaction_factory.h" |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 24 | #include "net/socket/ssl_client_socket_impl.h" |
[email protected] | ee4c30d | 2012-11-07 15:08:43 | [diff] [blame] | 25 | #include "net/url_request/http_user_agent_settings.h" |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 26 | #include "net/url_request/url_request.h" |
[email protected] | 9349cfb | 2010-08-31 18:00:53 | [diff] [blame] | 27 | |
[email protected] | 27a112c | 2011-01-06 04:19:30 | [diff] [blame] | 28 | namespace net { |
| 29 | |
[email protected] | 9349cfb | 2010-08-31 18:00:53 | [diff] [blame] | 30 | URLRequestContext::URLRequestContext() |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 31 | : net_log_(nullptr), |
| 32 | host_resolver_(nullptr), |
| 33 | cert_verifier_(nullptr), |
| 34 | channel_id_service_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 35 | http_auth_handler_factory_(nullptr), |
| 36 | proxy_service_(nullptr), |
| 37 | network_delegate_(nullptr), |
bnc | 525e175a | 2016-06-20 12:36:40 | [diff] [blame] | 38 | http_server_properties_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 39 | http_user_agent_settings_(nullptr), |
mmenke | 606c59c | 2016-03-07 18:20:55 | [diff] [blame] | 40 | cookie_store_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 41 | transport_security_state_(nullptr), |
| 42 | cert_transparency_verifier_(nullptr), |
rsleevi | d6de830 | 2016-06-21 01:33:20 | [diff] [blame] | 43 | ct_policy_enforcer_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 44 | http_transaction_factory_(nullptr), |
| 45 | job_factory_(nullptr), |
| 46 | throttler_manager_(nullptr), |
xunjieli | 3bb781a | 2015-07-22 22:40:34 | [diff] [blame] | 47 | backoff_manager_(nullptr), |
rdsmith | d6ee164 | 2015-05-29 15:01:30 | [diff] [blame] | 48 | sdch_manager_(nullptr), |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 49 | network_quality_estimator_(nullptr), |
juliatuttle | 2b8dd2d1 | 2017-04-12 21:27:41 | [diff] [blame^] | 50 | reporting_service_(nullptr), |
nharper | 5babb5e6 | 2016-03-09 18:58:07 | [diff] [blame] | 51 | url_requests_(new std::set<const URLRequest*>), |
mgersh | d21d6d14 | 2016-12-14 23:06:36 | [diff] [blame] | 52 | enable_brotli_(false), |
xunjieli | c4da1de | 2017-03-28 16:19:50 | [diff] [blame] | 53 | check_cleartext_permitted_(false), |
| 54 | name_(nullptr) { |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 55 | base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider( |
| 56 | this, "URLRequestContext", base::ThreadTaskRunnerHandle::Get()); |
| 57 | } |
[email protected] | f1d8192 | 2010-07-31 17:47:09 | [diff] [blame] | 58 | |
[email protected] | ef2bf42 | 2012-05-11 03:27:09 | [diff] [blame] | 59 | URLRequestContext::~URLRequestContext() { |
| 60 | AssertNoURLRequests(); |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 61 | base::trace_event::MemoryDumpManager::GetInstance()->UnregisterDumpProvider( |
| 62 | this); |
[email protected] | ef2bf42 | 2012-05-11 03:27:09 | [diff] [blame] | 63 | } |
| 64 | |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 65 | void URLRequestContext::CopyFrom(const URLRequestContext* other) { |
[email protected] | d969667 | 2011-03-15 22:45:09 | [diff] [blame] | 66 | // Copy URLRequestContext parameters. |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 67 | set_net_log(other->net_log_); |
| 68 | set_host_resolver(other->host_resolver_); |
| 69 | set_cert_verifier(other->cert_verifier_); |
[email protected] | 6b8a3c74 | 2014-07-25 00:25:35 | [diff] [blame] | 70 | set_channel_id_service(other->channel_id_service_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 71 | set_http_auth_handler_factory(other->http_auth_handler_factory_); |
| 72 | set_proxy_service(other->proxy_service_); |
[email protected] | 9049948 | 2013-06-01 00:39:50 | [diff] [blame] | 73 | set_ssl_config_service(other->ssl_config_service_.get()); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 74 | set_network_delegate(other->network_delegate_); |
| 75 | set_http_server_properties(other->http_server_properties_); |
mmenke | 606c59c | 2016-03-07 18:20:55 | [diff] [blame] | 76 | set_cookie_store(other->cookie_store_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 77 | set_transport_security_state(other->transport_security_state_); |
[email protected] | 284303b6 | 2013-11-28 15:11:54 | [diff] [blame] | 78 | set_cert_transparency_verifier(other->cert_transparency_verifier_); |
rsleevi | d6de830 | 2016-06-21 01:33:20 | [diff] [blame] | 79 | set_ct_policy_enforcer(other->ct_policy_enforcer_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 80 | set_http_transaction_factory(other->http_transaction_factory_); |
[email protected] | fa22a6f1 | 2012-05-11 17:19:59 | [diff] [blame] | 81 | set_job_factory(other->job_factory_); |
| 82 | set_throttler_manager(other->throttler_manager_); |
xunjieli | 3bb781a | 2015-07-22 22:40:34 | [diff] [blame] | 83 | set_backoff_manager(other->backoff_manager_); |
rdsmith | d6ee164 | 2015-05-29 15:01:30 | [diff] [blame] | 84 | set_sdch_manager(other->sdch_manager_); |
[email protected] | ee4c30d | 2012-11-07 15:08:43 | [diff] [blame] | 85 | set_http_user_agent_settings(other->http_user_agent_settings_); |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 86 | set_network_quality_estimator(other->network_quality_estimator_); |
juliatuttle | 2b8dd2d1 | 2017-04-12 21:27:41 | [diff] [blame^] | 87 | set_reporting_service(other->reporting_service_); |
maksim.sisov | 3d40c81 | 2016-05-02 13:27:16 | [diff] [blame] | 88 | set_enable_brotli(other->enable_brotli_); |
mgersh | d21d6d14 | 2016-12-14 23:06:36 | [diff] [blame] | 89 | set_check_cleartext_permitted(other->check_cleartext_permitted_); |
[email protected] | d969667 | 2011-03-15 22:45:09 | [diff] [blame] | 90 | } |
| 91 | |
[email protected] | c2dad29 | 2012-09-07 21:27:35 | [diff] [blame] | 92 | const HttpNetworkSession::Params* URLRequestContext::GetNetworkSessionParams( |
| 93 | ) const { |
| 94 | HttpTransactionFactory* transaction_factory = http_transaction_factory(); |
| 95 | if (!transaction_factory) |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 96 | return nullptr; |
[email protected] | c2dad29 | 2012-09-07 21:27:35 | [diff] [blame] | 97 | HttpNetworkSession* network_session = transaction_factory->GetSession(); |
| 98 | if (!network_session) |
tbansal | ea2fb8c | 2015-05-22 22:23:00 | [diff] [blame] | 99 | return nullptr; |
[email protected] | c2dad29 | 2012-09-07 21:27:35 | [diff] [blame] | 100 | return &network_session->params(); |
| 101 | } |
| 102 | |
danakj | 8522a25b | 2016-04-16 00:17:36 | [diff] [blame] | 103 | std::unique_ptr<URLRequest> URLRequestContext::CreateRequest( |
[email protected] | 2ca01e5 | 2013-10-31 22:05:19 | [diff] [blame] | 104 | const GURL& url, |
| 105 | RequestPriority priority, |
davidben | 151423e | 2015-03-23 18:48:36 | [diff] [blame] | 106 | URLRequest::Delegate* delegate) const { |
danakj | 8522a25b | 2016-04-16 00:17:36 | [diff] [blame] | 107 | return base::WrapUnique( |
davidben | 151423e | 2015-03-23 18:48:36 | [diff] [blame] | 108 | new URLRequest(url, priority, delegate, this, network_delegate_)); |
[email protected] | 8a26ff6 | 2012-08-24 21:49:20 | [diff] [blame] | 109 | } |
| 110 | |
rhalavati | a9b551d | 2017-02-09 12:03:00 | [diff] [blame] | 111 | std::unique_ptr<URLRequest> URLRequestContext::CreateRequest( |
| 112 | const GURL& url, |
| 113 | RequestPriority priority, |
| 114 | URLRequest::Delegate* delegate, |
| 115 | NetworkTrafficAnnotationTag traffic_annotation) const { |
| 116 | // |traffic_annotation| is just a tag that is extracted during static |
| 117 | // code analysis and can be ignored here. |
| 118 | return CreateRequest(url, priority, delegate); |
| 119 | } |
| 120 | |
[email protected] | d100e44f | 2011-01-26 22:47:11 | [diff] [blame] | 121 | void URLRequestContext::set_cookie_store(CookieStore* cookie_store) { |
| 122 | cookie_store_ = cookie_store; |
| 123 | } |
| 124 | |
[email protected] | 1e714bba | 2012-04-10 17:01:05 | [diff] [blame] | 125 | void URLRequestContext::AssertNoURLRequests() const { |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 126 | int num_requests = url_requests_->size(); |
| 127 | if (num_requests != 0) { |
| 128 | // We're leaking URLRequests :( Dump the URL of the first one and record how |
| 129 | // many we leaked so we have an idea of how bad it is. |
| 130 | char url_buf[128]; |
| 131 | const URLRequest* request = *url_requests_->begin(); |
| 132 | base::strlcpy(url_buf, request->url().spec().c_str(), arraysize(url_buf)); |
[email protected] | eb4ecaca | 2012-05-04 01:05:03 | [diff] [blame] | 133 | int load_flags = request->load_flags(); |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 134 | base::debug::Alias(url_buf); |
| 135 | base::debug::Alias(&num_requests); |
[email protected] | eb4ecaca | 2012-05-04 01:05:03 | [diff] [blame] | 136 | base::debug::Alias(&load_flags); |
[email protected] | 1f5f8e2 | 2012-09-06 23:40:54 | [diff] [blame] | 137 | CHECK(false) << "Leaked " << num_requests << " URLRequest(s). First URL: " |
| 138 | << request->url().spec().c_str() << "."; |
[email protected] | 7c52ed9 | 2012-04-06 15:42:40 | [diff] [blame] | 139 | } |
[email protected] | 9349cfb | 2010-08-31 18:00:53 | [diff] [blame] | 140 | } |
[email protected] | 2fb62920 | 2010-12-23 23:52:57 | [diff] [blame] | 141 | |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 142 | bool URLRequestContext::OnMemoryDump( |
| 143 | const base::trace_event::MemoryDumpArgs& args, |
| 144 | base::trace_event::ProcessMemoryDump* pmd) { |
xunjieli | c4da1de | 2017-03-28 16:19:50 | [diff] [blame] | 145 | if (!name_) |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 146 | name_ = "unknown"; |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 147 | |
| 148 | SSLClientSocketImpl::DumpSSLClientSessionMemoryStats(pmd); |
| 149 | |
xunjieli | c4da1de | 2017-03-28 16:19:50 | [diff] [blame] | 150 | std::string dump_name = |
| 151 | base::StringPrintf("net/url_request_context/%s/0x%" PRIxPTR, name_, |
| 152 | reinterpret_cast<uintptr_t>(this)); |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 153 | base::trace_event::MemoryAllocatorDump* dump = |
| 154 | pmd->CreateAllocatorDump(dump_name); |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 155 | dump->AddScalar(base::trace_event::MemoryAllocatorDump::kNameObjectCount, |
| 156 | base::trace_event::MemoryAllocatorDump::kUnitsObjects, |
| 157 | url_requests_->size()); |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 158 | HttpTransactionFactory* transaction_factory = http_transaction_factory(); |
| 159 | if (transaction_factory) { |
| 160 | HttpNetworkSession* network_session = transaction_factory->GetSession(); |
| 161 | if (network_session) |
| 162 | network_session->DumpMemoryStats(pmd, dump->absolute_name()); |
xunjieli | a0166f4 | 2017-02-23 17:44:57 | [diff] [blame] | 163 | HttpCache* http_cache = transaction_factory->GetCache(); |
| 164 | if (http_cache) |
| 165 | http_cache->DumpMemoryStats(pmd, dump->absolute_name()); |
xunjieli | 9f8c5fb5 | 2016-12-07 22:59:33 | [diff] [blame] | 166 | } |
xunjieli | d701b6e5 | 2017-01-04 22:17:42 | [diff] [blame] | 167 | if (sdch_manager_) |
xunjieli | d5debfc | 2017-02-24 15:55:49 | [diff] [blame] | 168 | sdch_manager_->DumpMemoryStats(pmd, dump_name); |
xunjieli | 96ab36a7 | 2016-12-05 21:36:05 | [diff] [blame] | 169 | return true; |
| 170 | } |
| 171 | |
[email protected] | 27a112c | 2011-01-06 04:19:30 | [diff] [blame] | 172 | } // namespace net |