blob: ee04f49622a031100f59a8cbd4cbdb2bc4e7afb6 [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"
Ilya Sherman0eb39802017-12-08 20:58:1812#include "base/metrics/histogram_functions.h"
xunjieli3fcbcc12017-04-26 15:51:1913#include "base/metrics/histogram_macros.h"
[email protected]4dc3ad4f2013-06-11 07:15:5014#include "base/strings/string_util.h"
xunjieli96ab36a72016-12-05 21:36:0515#include "base/strings/stringprintf.h"
fdoraya19b7702016-12-23 14:19:3116#include "base/threading/thread_task_runner_handle.h"
xunjieli96ab36a72016-12-05 21:36:0517#include "base/trace_event/memory_allocator_dump.h"
18#include "base/trace_event/memory_dump_manager.h"
xunjielid5debfc2017-02-24 15:55:4919#include "base/trace_event/memory_dump_request_args.h"
xunjieli96ab36a72016-12-05 21:36:0520#include "base/trace_event/process_memory_dump.h"
Yuta Hijikata101ed2a2020-11-18 07:50:3921#include "build/chromeos_buildflags.h"
Matt Menked732ea42019-03-08 12:05:0022#include "net/base/http_user_agent_settings.h"
[email protected]aa84a7e2012-03-15 21:29:0623#include "net/cookies/cookie_store.h"
[email protected]f2cb3cf2013-03-21 01:40:5324#include "net/dns/host_resolver.h"
xunjielia0166f42017-02-23 17:44:5725#include "net/http/http_cache.h"
[email protected]f6c21cb2011-02-16 19:45:4126#include "net/http/http_transaction_factory.h"
xunjieli9f8c5fb52016-12-07 22:59:3327#include "net/socket/ssl_client_socket_impl.h"
[email protected]7c52ed92012-04-06 15:42:4028#include "net/url_request/url_request.h"
[email protected]9349cfb2010-08-31 18:00:5329
[email protected]27a112c2011-01-06 04:19:3030namespace net {
31
Maks Orlovich9fdb7272019-12-13 01:28:2332URLRequestContext::URLRequestContext()
tbansalea2fb8c2015-05-22 22:23:0033 : net_log_(nullptr),
34 host_resolver_(nullptr),
35 cert_verifier_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0036 http_auth_handler_factory_(nullptr),
Lily Houghton8c2f97d2018-01-22 05:06:5937 proxy_resolution_service_(nullptr),
Wojciech Dzierżanowski1f823562019-01-18 11:26:0038 proxy_delegate_(nullptr),
Ryan Sleevib8449e02018-07-15 04:31:0739 ssl_config_service_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0040 network_delegate_(nullptr),
bnc525e175a2016-06-20 12:36:4041 http_server_properties_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0042 http_user_agent_settings_(nullptr),
mmenke606c59c2016-03-07 18:20:5543 cookie_store_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0044 transport_security_state_(nullptr),
45 cert_transparency_verifier_(nullptr),
rsleevid6de8302016-06-21 01:33:2046 ct_policy_enforcer_(nullptr),
Chris Thompsonf31b2492020-07-21 05:47:4247 sct_auditing_delegate_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0048 http_transaction_factory_(nullptr),
49 job_factory_(nullptr),
50 throttler_manager_(nullptr),
Victor Vasiliev7752898d2019-11-14 21:30:2251 quic_context_(nullptr),
tbansalea2fb8c2015-05-22 22:23:0052 network_quality_estimator_(nullptr),
Julia Tuttle3f9acac2017-11-20 22:06:3053#if BUILDFLAG(ENABLE_REPORTING)
juliatuttle2b8dd2d12017-04-12 21:27:4154 reporting_service_(nullptr),
Julia Tuttlecba7d222018-02-23 19:37:2755 network_error_logging_service_(nullptr),
Julia Tuttle3f9acac2017-11-20 22:06:3056#endif // BUILDFLAG(ENABLE_REPORTING)
Helen Lif5e4a752018-01-02 16:03:0257 url_requests_(std::make_unique<std::set<const URLRequest*>>()),
mgershd21d6d142016-12-14 23:06:3658 enable_brotli_(false),
xunjielic4da1de2017-03-28 16:19:5059 check_cleartext_permitted_(false),
Matt Menkeee10f0412020-05-14 14:16:0360 require_network_isolation_key_(false),
Maks Orlovich9fdb7272019-12-13 01:28:2361 name_("unknown") {
xunjieli96ab36a72016-12-05 21:36:0562 base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider(
63 this, "URLRequestContext", base::ThreadTaskRunnerHandle::Get());
64}
[email protected]f1d81922010-07-31 17:47:0965
[email protected]ef2bf422012-05-11 03:27:0966URLRequestContext::~URLRequestContext() {
gab47aa7da2017-06-02 16:09:4367 DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
[email protected]ef2bf422012-05-11 03:27:0968 AssertNoURLRequests();
xunjieli96ab36a72016-12-05 21:36:0569 base::trace_event::MemoryDumpManager::GetInstance()->UnregisterDumpProvider(
70 this);
[email protected]ef2bf422012-05-11 03:27:0971}
72
[email protected]c2dad292012-09-07 21:27:3573const HttpNetworkSession::Params* URLRequestContext::GetNetworkSessionParams(
74 ) const {
75 HttpTransactionFactory* transaction_factory = http_transaction_factory();
76 if (!transaction_factory)
tbansalea2fb8c2015-05-22 22:23:0077 return nullptr;
[email protected]c2dad292012-09-07 21:27:3578 HttpNetworkSession* network_session = transaction_factory->GetSession();
79 if (!network_session)
tbansalea2fb8c2015-05-22 22:23:0080 return nullptr;
[email protected]c2dad292012-09-07 21:27:3581 return &network_session->params();
82}
83
mmenke6ddfbea2017-05-31 21:48:4184const HttpNetworkSession::Context* URLRequestContext::GetNetworkSessionContext()
85 const {
86 HttpTransactionFactory* transaction_factory = http_transaction_factory();
87 if (!transaction_factory)
88 return nullptr;
89 HttpNetworkSession* network_session = transaction_factory->GetSession();
90 if (!network_session)
91 return nullptr;
92 return &network_session->context();
93}
94
Yuta Hijikata101ed2a2020-11-18 07:50:3995// TODO(crbug.com/1052397): Revisit once build flag switch of lacros-chrome is
96// complete.
97#if !defined(OS_WIN) && !(defined(OS_LINUX) || BUILDFLAG(IS_CHROMEOS_LACROS))
danakj8522a25b2016-04-16 00:17:3698std::unique_ptr<URLRequest> URLRequestContext::CreateRequest(
[email protected]2ca01e52013-10-31 22:05:1999 const GURL& url,
100 RequestPriority priority,
davidben151423e2015-03-23 18:48:36101 URLRequest::Delegate* delegate) const {
rhalavati0e2a2272017-05-23 13:10:32102 return CreateRequest(url, priority, delegate, MISSING_TRAFFIC_ANNOTATION);
[email protected]8a26ff62012-08-24 21:49:20103}
Nicolas Ouellet-Payeur6e833b52019-07-02 17:18:08104#endif
[email protected]8a26ff62012-08-24 21:49:20105
rhalavatia9b551d2017-02-09 12:03:00106std::unique_ptr<URLRequest> URLRequestContext::CreateRequest(
107 const GURL& url,
108 RequestPriority priority,
109 URLRequest::Delegate* delegate,
110 NetworkTrafficAnnotationTag traffic_annotation) const {
Matt Menkefd978852020-09-15 16:00:57111 return base::WrapUnique(
112 new URLRequest(url, priority, delegate, this, traffic_annotation));
rhalavatia9b551d2017-02-09 12:03:00113}
114
[email protected]d100e44f2011-01-26 22:47:11115void URLRequestContext::set_cookie_store(CookieStore* cookie_store) {
116 cookie_store_ = cookie_store;
117}
118
[email protected]1e714bba2012-04-10 17:01:05119void URLRequestContext::AssertNoURLRequests() const {
Helen Lif5e4a752018-01-02 16:03:02120 int num_requests = url_requests_->size();
[email protected]7c52ed92012-04-06 15:42:40121 if (num_requests != 0) {
122 // We're leaking URLRequests :( Dump the URL of the first one and record how
123 // many we leaked so we have an idea of how bad it is.
Helen Lif5e4a752018-01-02 16:03:02124 const URLRequest* request = *url_requests_->begin();
[email protected]eb4ecaca2012-05-04 01:05:03125 int load_flags = request->load_flags();
Lukasz Anforowicz68c21772018-01-13 03:42:44126 DEBUG_ALIAS_FOR_GURL(url_buf, request->url());
[email protected]7c52ed92012-04-06 15:42:40127 base::debug::Alias(&num_requests);
[email protected]eb4ecaca2012-05-04 01:05:03128 base::debug::Alias(&load_flags);
[email protected]1f5f8e22012-09-06 23:40:54129 CHECK(false) << "Leaked " << num_requests << " URLRequest(s). First URL: "
130 << request->url().spec().c_str() << ".";
[email protected]7c52ed92012-04-06 15:42:40131 }
[email protected]9349cfb2010-08-31 18:00:53132}
[email protected]2fb629202010-12-23 23:52:57133
xunjieli96ab36a72016-12-05 21:36:05134bool URLRequestContext::OnMemoryDump(
135 const base::trace_event::MemoryDumpArgs& args,
136 base::trace_event::ProcessMemoryDump* pmd) {
xunjielic4da1de2017-03-28 16:19:50137 std::string dump_name =
Matt Menke7d4b66f72017-09-26 04:09:55138 base::StringPrintf("net/url_request_context/%s/0x%" PRIxPTR,
139 name_.c_str(), reinterpret_cast<uintptr_t>(this));
xunjielid5debfc2017-02-24 15:55:49140 base::trace_event::MemoryAllocatorDump* dump =
141 pmd->CreateAllocatorDump(dump_name);
xunjieli96ab36a72016-12-05 21:36:05142 dump->AddScalar(base::trace_event::MemoryAllocatorDump::kNameObjectCount,
143 base::trace_event::MemoryAllocatorDump::kUnitsObjects,
Helen Lif5e4a752018-01-02 16:03:02144 url_requests_->size());
xunjieli9f8c5fb52016-12-07 22:59:33145 HttpTransactionFactory* transaction_factory = http_transaction_factory();
146 if (transaction_factory) {
147 HttpNetworkSession* network_session = transaction_factory->GetSession();
148 if (network_session)
149 network_session->DumpMemoryStats(pmd, dump->absolute_name());
xunjielia0166f42017-02-23 17:44:57150 HttpCache* http_cache = transaction_factory->GetCache();
151 if (http_cache)
152 http_cache->DumpMemoryStats(pmd, dump->absolute_name());
xunjieli9f8c5fb52016-12-07 22:59:33153 }
Maks Orlovich5cf437b02018-03-27 04:40:42154 if (cookie_store_) {
155 cookie_store_->DumpMemoryStats(pmd, dump->absolute_name());
156 }
xunjieli96ab36a72016-12-05 21:36:05157 return true;
158}
159
[email protected]27a112c2011-01-06 04:19:30160} // namespace net