blob: e6694f1e4a5f2c9e8600d7792900c97d70f34cda [file] [log] [blame]
xunjieli413a68782015-06-16 17:15:431// 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
Chris Mumford3f0eda92018-07-23 14:51:175#ifndef EXTENSIONS_RENDERER_EXTENSION_THROTTLE_MANAGER_H_
6#define EXTENSIONS_RENDERER_EXTENSION_THROTTLE_MANAGER_H_
xunjieli413a68782015-06-16 17:15:437
8#include <map>
dchengf5d241082016-04-21 03:43:119#include <memory>
xunjieli413a68782015-06-16 17:15:4310#include <string>
11
avic9cec102015-12-23 00:39:2612#include "base/macros.h"
xunjieli413a68782015-06-16 17:15:4313#include "base/memory/ref_counted.h"
Chris Mumford3f0eda92018-07-23 14:51:1714#include "base/synchronization/lock.h"
15#include "extensions/renderer/extension_throttle_entry.h"
Lucas Furukawa Gadani011886592019-10-23 17:12:2416#include "services/network/public/mojom/url_response_head.mojom-forward.h"
xunjieli413a68782015-06-16 17:15:4317#include "url/gurl.h"
18
Chris Mumford3f0eda92018-07-23 14:51:1719namespace blink {
Minggang Wangf6840ecf2019-07-29 05:15:0220class URLLoaderThrottle;
Chris Mumford3f0eda92018-07-23 14:51:1721class WebURLRequest;
22} // namespace blink
23
Chris Mumford3f0eda92018-07-23 14:51:1724namespace net {
25struct RedirectInfo;
26} // namespace net
27
xunjieli413a68782015-06-16 17:15:4328namespace extensions {
29
Chris Mumford3f0eda92018-07-23 14:51:1730// This is a thread safe class that registers URL request throttler entries for
31// URLs being accessed in order to supervise traffic. URL requests for HTTP
32// contents should register their URLs in this manager on each request.
xunjieli413a68782015-06-16 17:15:4333//
34// ExtensionThrottleManager maintains a map of URL IDs to URL request
35// throttler entries. It creates URL request throttler entries when new URLs
36// are registered, and does garbage collection from time to time in order to
37// clean out outdated entries. URL ID consists of lowercased scheme, host, port
38// and path. All URLs converted to the same ID will share the same entry.
Chris Mumford3f0eda92018-07-23 14:51:1739class ExtensionThrottleManager {
xunjieli413a68782015-06-16 17:15:4340 public:
41 ExtensionThrottleManager();
Chris Mumford3f0eda92018-07-23 14:51:1742 virtual ~ExtensionThrottleManager();
xunjieli413a68782015-06-16 17:15:4343
Chris Mumford3f0eda92018-07-23 14:51:1744 // Creates a throttle which uses this class to prevent extensions from
45 // requesting a URL too often, if such a throttle is needed.
Minggang Wangf6840ecf2019-07-29 05:15:0246 std::unique_ptr<blink::URLLoaderThrottle> MaybeCreateURLLoaderThrottle(
Chris Mumford3f0eda92018-07-23 14:51:1747 const blink::WebURLRequest& request);
48
Matt Menke21850502019-10-09 22:34:2449 // Determine if a request to |request_url| should be rejected.
50 bool ShouldRejectRequest(const GURL& request_url);
Chris Mumford3f0eda92018-07-23 14:51:1751
Matt Menke21850502019-10-09 22:34:2452 // Determine if a redirect from the original |request_url| should be allowed
53 // to be redirected as specified by |redirect_info|.
Chris Mumford3f0eda92018-07-23 14:51:1754 bool ShouldRejectRedirect(const GURL& request_url,
Chris Mumford3f0eda92018-07-23 14:51:1755 const net::RedirectInfo& redirect_info);
56
57 // Must be called when the |response_head| for a request has been received.
Lucas Furukawa Gadani011886592019-10-23 17:12:2458 void WillProcessResponse(
59 const GURL& response_url,
60 const network::mojom::URLResponseHead& response_head);
Chris Mumford3f0eda92018-07-23 14:51:1761
62 // Set the network status online state as specified in |is_online|.
63 void SetOnline(bool is_online);
64
65 void SetBackoffPolicyForTests(
66 std::unique_ptr<net::BackoffEntry::Policy> policy);
67
68 // Registers a new entry in this service and overrides the existing entry (if
69 // any) for the URL. The service will hold a reference to the entry.
70 // It is only used by unit tests.
Chris Mumfordc54b0c342018-07-23 21:29:4671 void OverrideEntryForTests(const GURL& url,
72 std::unique_ptr<ExtensionThrottleEntry> entry);
Chris Mumford3f0eda92018-07-23 14:51:1773
Chris Mumford3f0eda92018-07-23 14:51:1774 int GetNumberOfEntriesForTests() const { return url_entries_.size(); }
75
76 protected:
77 // Method that allows us to transform a URL into an ID that can be used in our
78 // map. Resulting IDs will be lowercase and consist of the scheme, host, port
79 // and path (without query string, fragment, etc.).
80 // If the URL is invalid, the invalid spec will be returned, without any
81 // transformation.
82 std::string GetIdFromUrl(const GURL& url) const;
xunjieli413a68782015-06-16 17:15:4383
xunjieli413a68782015-06-16 17:15:4384 // Must be called for every request, returns the URL request throttler entry
85 // associated with the URL. The caller must inform this entry of some events.
Chris Mumfordc54b0c342018-07-23 21:29:4686 // Please refer to extension_throttle_entry.h for further information.
87 ExtensionThrottleEntry* RegisterRequestUrl(const GURL& url);
xunjieli413a68782015-06-16 17:15:4388
Chris Mumford3f0eda92018-07-23 14:51:1789 // Method that does the actual work of garbage collecting.
90 void GarbageCollectEntries();
xunjielie484e2d62015-06-19 14:31:2191
Chris Mumford3f0eda92018-07-23 14:51:1792 private:
xunjieli413a68782015-06-16 17:15:4393 // Explicitly erases an entry.
94 // This is useful to remove those entries which have got infinite lifetime and
95 // thus won't be garbage collected.
96 // It is only used by unit tests.
97 void EraseEntryForTests(const GURL& url);
98
xunjieli413a68782015-06-16 17:15:4399 // Whether throttling is enabled or not.
100 void set_enforce_throttling(bool enforce);
101 bool enforce_throttling();
102
xunjieli413a68782015-06-16 17:15:43103 // Method that ensures the map gets cleaned from time to time. The period at
104 // which garbage collecting happens is adjustable with the
105 // kRequestBetweenCollecting constant.
106 void GarbageCollectEntriesIfNecessary();
107
xunjieli413a68782015-06-16 17:15:43108 // Maximum number of entries that we are willing to collect in our map.
109 static const unsigned int kMaximumNumberOfEntries;
110 // Number of requests that will be made between garbage collection.
111 static const unsigned int kRequestsBetweenCollecting;
112
Chris Mumfordc54b0c342018-07-23 21:29:46113 // Map that contains a list of URL ID (composed of the scheme, host, port and
114 // path) and their matching ExtensionThrottleEntry.
115 std::map<std::string, std::unique_ptr<ExtensionThrottleEntry>> url_entries_;
xunjieli413a68782015-06-16 17:15:43116
117 // This keeps track of how many requests have been made. Used with
118 // GarbageCollectEntries.
119 unsigned int requests_since_last_gc_;
120
121 // Valid after construction.
122 GURL::Replacements url_id_replacements_;
123
Chris Mumfordc54b0c342018-07-23 21:29:46124 // This is null when it is not set for tests.
dchengf5d241082016-04-21 03:43:11125 std::unique_ptr<net::BackoffEntry::Policy> backoff_policy_for_tests_;
xunjielie484e2d62015-06-19 14:31:21126
Chris Mumford3f0eda92018-07-23 14:51:17127 // Used to synchronize all public methods.
128 base::Lock lock_;
gab370841f22017-06-01 14:38:26129
xunjieli413a68782015-06-16 17:15:43130 DISALLOW_COPY_AND_ASSIGN(ExtensionThrottleManager);
131};
132
133} // namespace extensions
134
Chris Mumford3f0eda92018-07-23 14:51:17135#endif // EXTENSIONS_RENDERER_EXTENSION_THROTTLE_MANAGER_H_