Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(237)

Side by Side Diff: chrome/browser/extensions/api/declarative_webrequest/webrequest_condition.h

Issue 11569007: Refactoring how conditions without URL attributes are handled. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Triggers back in ConditionSet Created 8 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITIO N_H_ 5 #ifndef CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITIO N_H_
6 #define CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITIO N_H_ 6 #define CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITIO N_H_
7 7
8 #include <set>
8 #include <string> 9 #include <string>
9 #include <vector> 10 #include <vector>
10 11
11 #include "base/basictypes.h" 12 #include "base/basictypes.h"
12 #include "base/memory/linked_ptr.h" 13 #include "base/memory/linked_ptr.h"
13 #include "chrome/browser/extensions/api/declarative_webrequest/webrequest_condit ion_attribute.h" 14 #include "chrome/browser/extensions/api/declarative_webrequest/webrequest_condit ion_attribute.h"
14 #include "chrome/browser/extensions/api/declarative_webrequest/webrequest_rule.h " 15 #include "chrome/browser/extensions/api/declarative_webrequest/webrequest_rule.h "
15 #include "chrome/common/extensions/matcher/url_matcher.h" 16 #include "chrome/common/extensions/matcher/url_matcher.h"
16 17
17 namespace extensions { 18 namespace extensions {
(...skipping 22 matching lines...) Expand all
40 const WebRequestConditionAttributes& condition_attributes); 41 const WebRequestConditionAttributes& condition_attributes);
41 ~WebRequestCondition(); 42 ~WebRequestCondition();
42 43
43 // Factory method that instantiates a WebRequestCondition according to 44 // Factory method that instantiates a WebRequestCondition according to
44 // the description |condition| passed by the extension API. 45 // the description |condition| passed by the extension API.
45 static scoped_ptr<WebRequestCondition> Create( 46 static scoped_ptr<WebRequestCondition> Create(
46 URLMatcherConditionFactory* url_matcher_condition_factory, 47 URLMatcherConditionFactory* url_matcher_condition_factory,
47 const base::Value& condition, 48 const base::Value& condition,
48 std::string* error); 49 std::string* error);
49 50
50 // Returns whether the request is a match, given that the URLMatcher found 51 // Returns whether the request matches this condition. |url_matches| lists
51 // a match for |url_matcher_conditions_|. 52 // the IDs that match the request's URL.
52 bool IsFulfilled(const WebRequestRule::RequestData& request_data) const; 53 bool IsFulfilled(const std::set<URLMatcherConditionSet::ID>& url_matches,
54 const WebRequestRule::RequestData& request_data) const;
53 55
54 // Returns a URLMatcherConditionSet::ID which is the canonical representation 56 // Returns a URLMatcherConditionSet::ID which is the canonical representation
55 // for all URL patterns that need to be matched by this WebRequestCondition. 57 // for all URL patterns that need to be matched by this WebRequestCondition.
56 // This ID is registered in a URLMatcher that can inform us in case of a 58 // This ID is registered in a URLMatcher that can inform us in case of a
57 // match. 59 // match.
58 URLMatcherConditionSet::ID url_matcher_condition_set_id() const { 60 URLMatcherConditionSet::ID url_matcher_condition_set_id() const {
61 DCHECK(url_matcher_conditions_.get());
59 return url_matcher_conditions_->id(); 62 return url_matcher_conditions_->id();
60 } 63 }
61 64
62 // Returns the set of conditions that are checked on the URL. This is the 65 // Returns the set of conditions that are checked on the URL. May be NULL.
63 // primary trigger for WebRequestCondition and therefore never empty.
64 // (If it was empty, the URLMatcher would never notify us about network
65 // requests which might fulfill the entire WebRequestCondition).
66 scoped_refptr<URLMatcherConditionSet> url_matcher_condition_set() const { 66 scoped_refptr<URLMatcherConditionSet> url_matcher_condition_set() const {
67 return url_matcher_conditions_; 67 return url_matcher_conditions_;
68 } 68 }
69 69
70 // Returns the condition attributes checked by this condition. 70 // Returns the condition attributes checked by this condition.
71 const WebRequestConditionAttributes condition_attributes() const { 71 const WebRequestConditionAttributes condition_attributes() const {
72 return condition_attributes_; 72 return condition_attributes_;
73 } 73 }
74 74
75 // Returns a bit vector representing extensions::RequestStage. The bit vector 75 // Returns a bit vector representing extensions::RequestStage. The bit vector
76 // contains a 1 for each request stage during which the condition can be 76 // contains a 1 for each request stage during which the condition can be
77 // tested. 77 // tested.
78 int stages() const { return applicable_request_stages_; } 78 int stages() const { return applicable_request_stages_; }
79 79
80 private: 80 private:
81 // Represents the 'url' attribute of this condition. If NULL, then there was
82 // no 'url' attribute in this condition.
81 scoped_refptr<URLMatcherConditionSet> url_matcher_conditions_; 83 scoped_refptr<URLMatcherConditionSet> url_matcher_conditions_;
84
85 // All non-UrlFilter attributes of this condition.
82 WebRequestConditionAttributes condition_attributes_; 86 WebRequestConditionAttributes condition_attributes_;
83 87
84 // Bit vector indicating all RequestStage during which all 88 // Bit vector indicating all RequestStage during which all
85 // |condition_attributes_| can be evaluated. 89 // |condition_attributes_| can be evaluated.
86 int applicable_request_stages_; 90 int applicable_request_stages_;
87 91
88 DISALLOW_COPY_AND_ASSIGN(WebRequestCondition); 92 DISALLOW_COPY_AND_ASSIGN(WebRequestCondition);
89 }; 93 };
90 94
91 // This class stores a set of conditions that may be part of a WebRequestRule. 95 // This class stores a set of conditions that may be part of a WebRequestRule.
92 // If any condition is fulfilled, the WebRequestActions of the WebRequestRule 96 // If any condition is fulfilled, the WebRequestActions of the WebRequestRule
93 // can be triggered. 97 // can be triggered.
94 class WebRequestConditionSet { 98 class WebRequestConditionSet {
95 public: 99 public:
96 typedef std::vector<linked_ptr<json_schema_compiler::any::Any> > AnyVector; 100 typedef std::vector<linked_ptr<json_schema_compiler::any::Any> > AnyVector;
97 typedef std::vector<linked_ptr<WebRequestCondition> > Conditions; 101 typedef std::vector<linked_ptr<WebRequestCondition> > Conditions;
98 102
99 explicit WebRequestConditionSet(const Conditions& conditions);
100 ~WebRequestConditionSet(); 103 ~WebRequestConditionSet();
101 104
102 // Factory method that creates an WebRequestConditionSet according to the JSON 105 // Factory method that creates an WebRequestConditionSet according to the JSON
103 // array |conditions| passed by the extension API. 106 // array |conditions| passed by the extension API.
104 // Sets |error| and returns NULL in case of an error. 107 // Sets |error| and returns NULL in case of an error.
105 static scoped_ptr<WebRequestConditionSet> Create( 108 static scoped_ptr<WebRequestConditionSet> Create(
106 URLMatcherConditionFactory* url_matcher_condition_factory, 109 URLMatcherConditionFactory* url_matcher_condition_factory,
107 const AnyVector& conditions, 110 const AnyVector& conditions,
108 std::string* error); 111 std::string* error);
109 112
110 const Conditions& conditions() const { 113 const Conditions& conditions() const {
111 return conditions_; 114 return conditions_;
112 } 115 }
113 116
114 // Returns whether any condition in the condition set is fulfilled 117 // Returns whether any condition in the condition set is fulfilled based on
115 // based on a match |url_match| and the value of |request_data.request|. 118 // matches in |url_matches| and the value of |request_data.request|. This
116 // This function should be called for each URLMatcherConditionSet::ID 119 // function should be called for a ConditionSet if any Condition in the
117 // that was found by the URLMatcher to ensure that the each trigger in 120 // ConditionSet was triggered by a url match or if the ConditionSet contains
118 // |match_triggers_| is found. 121 // a Condition without a UrlFilter.
119 bool IsFulfilled( 122 bool IsFulfilled(
120 URLMatcherConditionSet::ID url_match, 123 const std::set<URLMatcherConditionSet::ID>& url_matches,
121 const WebRequestRule::RequestData& request_data) const; 124 const WebRequestRule::RequestData& request_data) const;
122 125
123 // Appends the URLMatcherConditionSet from all conditions to |condition_sets|. 126 // Appends the URLMatcherConditionSet from all conditions to |condition_sets|.
124 void GetURLMatcherConditionSets( 127 void GetURLMatcherConditionSets(
125 URLMatcherConditionSet::Vector* condition_sets) const; 128 URLMatcherConditionSet::Vector* condition_sets) const;
126 129
130 // Returns whether there are some conditions without UrlFilter attributes.
131 bool HasConditionsWithoutUrls() const;
132
127 private: 133 private:
128 Conditions conditions_; 134 typedef std::map<URLMatcherConditionSet::ID, const WebRequestCondition*>
Jeffrey Yasskin 2012/12/19 19:10:52 For optimal memory use and performance, this ought
vabr (Chromium) 2012/12/20 08:57:13 I'm not sure I understand. If we iterate over a ma
Jeffrey Yasskin 2012/12/20 18:15:38 The vector's elements should be std::pair<URLMatch
135 MatchTriggers;
129 136
130 typedef std::map<URLMatcherConditionSet::ID, WebRequestCondition*> 137 WebRequestConditionSet(
131 MatchTriggers; 138 const Conditions& conditions,
132 MatchTriggers match_triggers_; 139 const MatchTriggers& match_triggers,
140 const std::vector<const WebRequestCondition*> conditions_without_urls);
Jeffrey Yasskin 2012/12/19 19:10:52 You forgot an & on conditions_without_urls. (Ther
vabr (Chromium) 2012/12/20 08:57:13 Done.
141
142 const MatchTriggers match_triggers_;
143 const Conditions conditions_;
144 const std::vector<const WebRequestCondition*> conditions_without_urls_;
133 145
134 DISALLOW_COPY_AND_ASSIGN(WebRequestConditionSet); 146 DISALLOW_COPY_AND_ASSIGN(WebRequestConditionSet);
135 }; 147 };
136 148
137 } // namespace extensions 149 } // namespace extensions
138 150
139 #endif // CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDI TION_H_ 151 #endif // CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDI TION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698