blob: c7e44779ca906c5423145e2ffb66d82166427df3 [file] [log] [blame]
[email protected]aa84a7e2012-03-15 21:29:061// Copyright (c) 2012 The Chromium Authors. All rights reserved.
[email protected]f1d81922010-07-31 17:47:092// 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
xunjielid5debfc2017-02-24 15:55:497#include <inttypes.h>
8
[email protected]18590f22011-07-29 16:41:289#include "base/compiler_specific.h"
[email protected]7c52ed92012-04-06 15:42:4010#include "base/debug/alias.h"
danakj8522a25b2016-04-16 00:17:3611#include "base/memory/ptr_util.h"
xunjieli3fcbcc12017-04-26 15:51:1912#include "base/metrics/histogram_macros.h"
[email protected]4dc3ad4f2013-06-11 07:15:5013#include "base/strings/string_util.h"
xunjieli96ab36a72016-12-05 21:36:0514#include "base/strings/stringprintf.h"
fdoraya19b7702016-12-23 14:19:3115#include "base/threading/thread_task_runner_handle.h"
xunjieli96ab36a72016-12-05 21:36:0516#include "base/trace_event/memory_allocator_dump.h"
17#include "base/trace_event/memory_dump_manager.h"
xunjielid5debfc2017-02-24 15:55:4918#include "base/trace_event/memory_dump_request_args.h"
xunjieli96ab36a72016-12-05 21:36:0519#include "base/trace_event/process_memory_dump.h"
xunjielid701b6e52017-01-04 22:17:4220#include "net/base/sdch_manager.h"
[email protected]aa84a7e2012-03-15 21:29:0621#include "net/cookies/cookie_store.h"
[email protected]f2cb3cf2013-03-21 01:40:5322#include "net/dns/host_resolver.h"
xunjielia0166f42017-02-23 17:44:5723#include "net/http/http_cache.h"
[email protected]f6c21cb2011-02-16 19:45:4124#include "net/http/http_transaction_factory.h"
xunjieli9f8c5fb52016-12-07 22:59:3325#include "net/socket/ssl_client_socket_impl.h"
[email protected]ee4c30d2012-11-07 15:08:4326#include "net/url_request/http_user_agent_settings.h"
[email protected]7c52ed92012-04-06 15:42:4027#include "net/url_request/url_request.h"
[email protected]9349cfb2010-08-31 18:00:5328
[email protected]27a112c2011-01-06 04:19:3029namespace net {
30
[email protected]9349cfb2010-08-31 18:00:5331URLRequestContext::URLRequestContext()
tbansalea2fb8c2015-05-22 22:23:0032 : net_log_(nullptr),
33 host_resolver_(nullptr),
34 cert_verifier_(nullptr),
35 channel_id_service_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0036 http_auth_handler_factory_(nullptr),
37 proxy_service_(nullptr),
38 network_delegate_(nullptr),
bnc525e175a2016-06-20 12:36:4039 http_server_properties_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0040 http_user_agent_settings_(nullptr),
mmenke606c59c2016-03-07 18:20:5541 cookie_store_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0042 transport_security_state_(nullptr),
43 cert_transparency_verifier_(nullptr),
rsleevid6de8302016-06-21 01:33:2044 ct_policy_enforcer_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0045 http_transaction_factory_(nullptr),
46 job_factory_(nullptr),
47 throttler_manager_(nullptr),
xunjieli3bb781a2015-07-22 22:40:3448 backoff_manager_(nullptr),
rdsmithd6ee1642015-05-29 15:01:3049 sdch_manager_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0050 network_quality_estimator_(nullptr),
juliatuttle2b8dd2d12017-04-12 21:27:4151 reporting_service_(nullptr),
mgershd21d6d142016-12-14 23:06:3652 enable_brotli_(false),
xunjielic4da1de2017-03-28 16:19:5053 check_cleartext_permitted_(false),
xunjieli3fcbcc12017-04-26 15:51:1954 name_(nullptr),
55 largest_outstanding_requests_count_seen_(0) {
xunjieli96ab36a72016-12-05 21:36:0556 base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider(
57 this, "URLRequestContext", base::ThreadTaskRunnerHandle::Get());
58}
[email protected]f1d81922010-07-31 17:47:0959
[email protected]ef2bf422012-05-11 03:27:0960URLRequestContext::~URLRequestContext() {
61 AssertNoURLRequests();
xunjieli96ab36a72016-12-05 21:36:0562 base::trace_event::MemoryDumpManager::GetInstance()->UnregisterDumpProvider(
63 this);
[email protected]ef2bf422012-05-11 03:27:0964}
65
[email protected]fa22a6f12012-05-11 17:19:5966void URLRequestContext::CopyFrom(const URLRequestContext* other) {
[email protected]d9696672011-03-15 22:45:0967 // Copy URLRequestContext parameters.
[email protected]fa22a6f12012-05-11 17:19:5968 set_net_log(other->net_log_);
69 set_host_resolver(other->host_resolver_);
70 set_cert_verifier(other->cert_verifier_);
[email protected]6b8a3c742014-07-25 00:25:3571 set_channel_id_service(other->channel_id_service_);
[email protected]fa22a6f12012-05-11 17:19:5972 set_http_auth_handler_factory(other->http_auth_handler_factory_);
73 set_proxy_service(other->proxy_service_);
[email protected]90499482013-06-01 00:39:5074 set_ssl_config_service(other->ssl_config_service_.get());
[email protected]fa22a6f12012-05-11 17:19:5975 set_network_delegate(other->network_delegate_);
76 set_http_server_properties(other->http_server_properties_);
mmenke606c59c2016-03-07 18:20:5577 set_cookie_store(other->cookie_store_);
[email protected]fa22a6f12012-05-11 17:19:5978 set_transport_security_state(other->transport_security_state_);
[email protected]284303b62013-11-28 15:11:5479 set_cert_transparency_verifier(other->cert_transparency_verifier_);
rsleevid6de8302016-06-21 01:33:2080 set_ct_policy_enforcer(other->ct_policy_enforcer_);
[email protected]fa22a6f12012-05-11 17:19:5981 set_http_transaction_factory(other->http_transaction_factory_);
[email protected]fa22a6f12012-05-11 17:19:5982 set_job_factory(other->job_factory_);
83 set_throttler_manager(other->throttler_manager_);
xunjieli3bb781a2015-07-22 22:40:3484 set_backoff_manager(other->backoff_manager_);
rdsmithd6ee1642015-05-29 15:01:3085 set_sdch_manager(other->sdch_manager_);
[email protected]ee4c30d2012-11-07 15:08:4386 set_http_user_agent_settings(other->http_user_agent_settings_);
tbansalea2fb8c2015-05-22 22:23:0087 set_network_quality_estimator(other->network_quality_estimator_);
juliatuttle2b8dd2d12017-04-12 21:27:4188 set_reporting_service(other->reporting_service_);
maksim.sisov3d40c812016-05-02 13:27:1689 set_enable_brotli(other->enable_brotli_);
mgershd21d6d142016-12-14 23:06:3690 set_check_cleartext_permitted(other->check_cleartext_permitted_);
[email protected]d9696672011-03-15 22:45:0991}
92
[email protected]c2dad292012-09-07 21:27:3593const HttpNetworkSession::Params* URLRequestContext::GetNetworkSessionParams(
94 ) const {
95 HttpTransactionFactory* transaction_factory = http_transaction_factory();
96 if (!transaction_factory)
tbansalea2fb8c2015-05-22 22:23:0097 return nullptr;
[email protected]c2dad292012-09-07 21:27:3598 HttpNetworkSession* network_session = transaction_factory->GetSession();
99 if (!network_session)
tbansalea2fb8c2015-05-22 22:23:00100 return nullptr;
[email protected]c2dad292012-09-07 21:27:35101 return &network_session->params();
102}
103
danakj8522a25b2016-04-16 00:17:36104std::unique_ptr<URLRequest> URLRequestContext::CreateRequest(
[email protected]2ca01e52013-10-31 22:05:19105 const GURL& url,
106 RequestPriority priority,
davidben151423e2015-03-23 18:48:36107 URLRequest::Delegate* delegate) const {
danakj8522a25b2016-04-16 00:17:36108 return base::WrapUnique(
davidben151423e2015-03-23 18:48:36109 new URLRequest(url, priority, delegate, this, network_delegate_));
[email protected]8a26ff62012-08-24 21:49:20110}
111
rhalavatia9b551d2017-02-09 12:03:00112std::unique_ptr<URLRequest> URLRequestContext::CreateRequest(
113 const GURL& url,
114 RequestPriority priority,
115 URLRequest::Delegate* delegate,
116 NetworkTrafficAnnotationTag traffic_annotation) const {
117 // |traffic_annotation| is just a tag that is extracted during static
118 // code analysis and can be ignored here.
119 return CreateRequest(url, priority, delegate);
120}
121
[email protected]d100e44f2011-01-26 22:47:11122void URLRequestContext::set_cookie_store(CookieStore* cookie_store) {
123 cookie_store_ = cookie_store;
124}
125
xunjieli3fcbcc12017-04-26 15:51:19126void URLRequestContext::InsertURLRequest(const URLRequest* request) const {
127 url_requests_.insert(request);
128 if (url_requests_.size() > largest_outstanding_requests_count_seen_) {
129 largest_outstanding_requests_count_seen_ = url_requests_.size();
130 UMA_HISTOGRAM_COUNTS_1M("Net.URLRequestContext.OutstandingRequests",
131 largest_outstanding_requests_count_seen_);
132 }
133}
134
135void URLRequestContext::RemoveURLRequest(const URLRequest* request) const {
136 DCHECK_EQ(1u, url_requests_.count(request));
137 url_requests_.erase(request);
138}
139
[email protected]1e714bba2012-04-10 17:01:05140void URLRequestContext::AssertNoURLRequests() const {
xunjieli3fcbcc12017-04-26 15:51:19141 int num_requests = url_requests_.size();
[email protected]7c52ed92012-04-06 15:42:40142 if (num_requests != 0) {
143 // We're leaking URLRequests :( Dump the URL of the first one and record how
144 // many we leaked so we have an idea of how bad it is.
145 char url_buf[128];
xunjieli3fcbcc12017-04-26 15:51:19146 const URLRequest* request = *url_requests_.begin();
[email protected]7c52ed92012-04-06 15:42:40147 base::strlcpy(url_buf, request->url().spec().c_str(), arraysize(url_buf));
[email protected]eb4ecaca2012-05-04 01:05:03148 int load_flags = request->load_flags();
[email protected]7c52ed92012-04-06 15:42:40149 base::debug::Alias(url_buf);
150 base::debug::Alias(&num_requests);
[email protected]eb4ecaca2012-05-04 01:05:03151 base::debug::Alias(&load_flags);
[email protected]1f5f8e22012-09-06 23:40:54152 CHECK(false) << "Leaked " << num_requests << " URLRequest(s). First URL: "
153 << request->url().spec().c_str() << ".";
[email protected]7c52ed92012-04-06 15:42:40154 }
[email protected]9349cfb2010-08-31 18:00:53155}
[email protected]2fb629202010-12-23 23:52:57156
xunjieli96ab36a72016-12-05 21:36:05157bool URLRequestContext::OnMemoryDump(
158 const base::trace_event::MemoryDumpArgs& args,
159 base::trace_event::ProcessMemoryDump* pmd) {
xunjielic4da1de2017-03-28 16:19:50160 if (!name_)
xunjieli96ab36a72016-12-05 21:36:05161 name_ = "unknown";
xunjielid5debfc2017-02-24 15:55:49162
163 SSLClientSocketImpl::DumpSSLClientSessionMemoryStats(pmd);
164
xunjielic4da1de2017-03-28 16:19:50165 std::string dump_name =
166 base::StringPrintf("net/url_request_context/%s/0x%" PRIxPTR, name_,
167 reinterpret_cast<uintptr_t>(this));
xunjielid5debfc2017-02-24 15:55:49168 base::trace_event::MemoryAllocatorDump* dump =
169 pmd->CreateAllocatorDump(dump_name);
xunjieli96ab36a72016-12-05 21:36:05170 dump->AddScalar(base::trace_event::MemoryAllocatorDump::kNameObjectCount,
171 base::trace_event::MemoryAllocatorDump::kUnitsObjects,
xunjieli3fcbcc12017-04-26 15:51:19172 url_requests_.size());
xunjieli9f8c5fb52016-12-07 22:59:33173 HttpTransactionFactory* transaction_factory = http_transaction_factory();
174 if (transaction_factory) {
175 HttpNetworkSession* network_session = transaction_factory->GetSession();
176 if (network_session)
177 network_session->DumpMemoryStats(pmd, dump->absolute_name());
xunjielia0166f42017-02-23 17:44:57178 HttpCache* http_cache = transaction_factory->GetCache();
179 if (http_cache)
180 http_cache->DumpMemoryStats(pmd, dump->absolute_name());
xunjieli9f8c5fb52016-12-07 22:59:33181 }
xunjielid701b6e52017-01-04 22:17:42182 if (sdch_manager_)
xunjielid5debfc2017-02-24 15:55:49183 sdch_manager_->DumpMemoryStats(pmd, dump_name);
xunjieli96ab36a72016-12-05 21:36:05184 return true;
185}
186
[email protected]27a112c2011-01-06 04:19:30187} // namespace net