OLD | NEW |
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 <map> | 8 #include <map> |
9 #include <set> | 9 #include <set> |
10 #include <string> | 10 #include <string> |
11 #include <vector> | 11 #include <vector> |
12 | 12 |
13 #include "base/basictypes.h" | 13 #include "base/basictypes.h" |
14 #include "base/memory/linked_ptr.h" | 14 #include "base/memory/linked_ptr.h" |
| 15 #include "chrome/browser/extensions/api/declarative/declarative_rule.h" |
15 #include "chrome/browser/extensions/api/declarative_webrequest/webrequest_condit
ion_attribute.h" | 16 #include "chrome/browser/extensions/api/declarative_webrequest/webrequest_condit
ion_attribute.h" |
16 #include "chrome/browser/extensions/api/declarative_webrequest/webrequest_rule.h
" | |
17 #include "chrome/common/extensions/matcher/url_matcher.h" | 17 #include "chrome/common/extensions/matcher/url_matcher.h" |
| 18 #include "net/http/http_response_headers.h" |
18 | 19 |
19 namespace extensions { | 20 namespace extensions { |
20 | 21 |
| 22 // Container for information about a URLRequest to determine which |
| 23 // rules apply to the request. |
| 24 struct DeclarativeWebRequestData { |
| 25 DeclarativeWebRequestData(net::URLRequest* request, RequestStage stage) |
| 26 : request(request), stage(stage), |
| 27 original_response_headers(NULL) {} |
| 28 DeclarativeWebRequestData( |
| 29 net::URLRequest* request, RequestStage stage, |
| 30 const net::HttpResponseHeaders* original_response_headers) |
| 31 : request(request), stage(stage), |
| 32 original_response_headers(original_response_headers) {} |
| 33 net::URLRequest* request; |
| 34 RequestStage stage; |
| 35 // Additional information about requests that is not |
| 36 // available in all request stages. |
| 37 const net::HttpResponseHeaders* original_response_headers; |
| 38 }; |
| 39 |
21 // Representation of a condition in the Declarative WebRequest API. A condition | 40 // Representation of a condition in the Declarative WebRequest API. A condition |
22 // consists of several attributes. Each of these attributes needs to be | 41 // consists of several attributes. Each of these attributes needs to be |
23 // fulfilled in order for the condition to be fulfilled. | 42 // fulfilled in order for the condition to be fulfilled. |
24 // | 43 // |
25 // We distinguish between two types of conditions: | 44 // We distinguish between two types of conditions: |
26 // - URL Matcher conditions are conditions that test the URL of a request. | 45 // - URL Matcher conditions are conditions that test the URL of a request. |
27 // These are treated separately because we use a URLMatcher to efficiently | 46 // These are treated separately because we use a URLMatcher to efficiently |
28 // test many of these conditions in parallel by using some advanced | 47 // test many of these conditions in parallel by using some advanced |
29 // data structures. The URLMatcher tells us if all URL Matcher conditions | 48 // data structures. The URLMatcher tells us if all URL Matcher conditions |
30 // are fulfilled for a WebRequestCondition. | 49 // are fulfilled for a WebRequestCondition. |
31 // - All other conditions are represented as WebRequestConditionAttributes. | 50 // - All other conditions are represented as WebRequestConditionAttributes. |
32 // These conditions are probed linearly (only if the URL Matcher found a hit). | 51 // These conditions are probed linearly (only if the URL Matcher found a hit). |
33 // | 52 // |
34 // TODO(battre) Consider making the URLMatcher an owner of the | 53 // TODO(battre) Consider making the URLMatcher an owner of the |
35 // URLMatcherConditionSet and only pass a pointer to URLMatcherConditionSet | 54 // URLMatcherConditionSet and only pass a pointer to URLMatcherConditionSet |
36 // in url_matcher_condition_set(). This saves some copying in | 55 // in url_matcher_condition_set(). This saves some copying in |
37 // WebRequestConditionSet::GetURLMatcherConditionSets. | 56 // WebRequestConditionSet::GetURLMatcherConditionSets. |
38 class WebRequestCondition { | 57 class WebRequestCondition { |
39 public: | 58 public: |
| 59 typedef DeclarativeWebRequestData MatchData; |
| 60 |
40 WebRequestCondition( | 61 WebRequestCondition( |
41 scoped_refptr<URLMatcherConditionSet> url_matcher_conditions, | 62 scoped_refptr<URLMatcherConditionSet> url_matcher_conditions, |
42 const WebRequestConditionAttributes& condition_attributes); | 63 const WebRequestConditionAttributes& condition_attributes); |
43 ~WebRequestCondition(); | 64 ~WebRequestCondition(); |
44 | 65 |
45 // Factory method that instantiates a WebRequestCondition according to | 66 // Factory method that instantiates a WebRequestCondition according to |
46 // the description |condition| passed by the extension API. | 67 // the description |condition| passed by the extension API. |
47 static scoped_ptr<WebRequestCondition> Create( | 68 static scoped_ptr<WebRequestCondition> Create( |
48 URLMatcherConditionFactory* url_matcher_condition_factory, | 69 URLMatcherConditionFactory* url_matcher_condition_factory, |
49 const base::Value& condition, | 70 const base::Value& condition, |
50 std::string* error); | 71 std::string* error); |
51 | 72 |
52 // Returns whether the request matches this condition. |url_matches| lists | 73 // Returns whether the request matches this condition. |url_matches| lists |
53 // the IDs that match the request's URL. | 74 // the IDs that match the request's URL. |
54 bool IsFulfilled(const std::set<URLMatcherConditionSet::ID> &url_matches, | 75 bool IsFulfilled(const std::set<URLMatcherConditionSet::ID> &url_matches, |
55 const WebRequestRule::RequestData &request_data) const; | 76 const DeclarativeWebRequestData& request_data) const; |
56 | 77 |
57 // Returns a URLMatcherConditionSet::ID which is the canonical representation | 78 // True if this condition has a url filter. |
58 // for all URL patterns that need to be matched by this WebRequestCondition. | 79 bool has_url_matcher_condition_set() const { |
59 // This ID is registered in a URLMatcher that can inform us in case of a | 80 return url_matcher_conditions_ != NULL; |
60 // match. | |
61 URLMatcherConditionSet::ID url_matcher_condition_set_id() const { | |
62 DCHECK(url_matcher_conditions_.get()); | |
63 return url_matcher_conditions_->id(); | |
64 } | 81 } |
65 | 82 |
66 // Returns the set of conditions that are checked on the URL. May be NULL. | 83 // If this Condition has a url filter, appends it to |condition_sets|. |
67 scoped_refptr<URLMatcherConditionSet> url_matcher_condition_set() const { | 84 void GetURLMatcherConditionSets( |
68 return url_matcher_conditions_; | 85 URLMatcherConditionSet::Vector* condition_sets) const { |
| 86 if (url_matcher_conditions_) |
| 87 condition_sets->push_back(url_matcher_conditions_); |
69 } | 88 } |
70 | 89 |
71 // Returns the condition attributes checked by this condition. | 90 // Returns the condition attributes checked by this condition. |
72 const WebRequestConditionAttributes condition_attributes() const { | 91 const WebRequestConditionAttributes condition_attributes() const { |
73 return condition_attributes_; | 92 return condition_attributes_; |
74 } | 93 } |
75 | 94 |
76 // Returns a bit vector representing extensions::RequestStage. The bit vector | 95 // Returns a bit vector representing extensions::RequestStage. The bit vector |
77 // contains a 1 for each request stage during which the condition can be | 96 // contains a 1 for each request stage during which the condition can be |
78 // tested. | 97 // tested. |
79 int stages() const { return applicable_request_stages_; } | 98 int stages() const { return applicable_request_stages_; } |
80 | 99 |
81 private: | 100 private: |
82 // Represents the 'url' attribute of this condition. If NULL, then there was | 101 // Represents the 'url' attribute of this condition. If NULL, then there was |
83 // no 'url' attribute in this condition. | 102 // no 'url' attribute in this condition. |
84 scoped_refptr<URLMatcherConditionSet> url_matcher_conditions_; | 103 scoped_refptr<URLMatcherConditionSet> url_matcher_conditions_; |
85 | 104 |
86 // All non-UrlFilter attributes of this condition. | 105 // All non-UrlFilter attributes of this condition. |
87 WebRequestConditionAttributes condition_attributes_; | 106 WebRequestConditionAttributes condition_attributes_; |
88 | 107 |
89 // Bit vector indicating all RequestStage during which all | 108 // Bit vector indicating all RequestStage during which all |
90 // |condition_attributes_| can be evaluated. | 109 // |condition_attributes_| can be evaluated. |
91 int applicable_request_stages_; | 110 int applicable_request_stages_; |
92 | 111 |
93 DISALLOW_COPY_AND_ASSIGN(WebRequestCondition); | 112 DISALLOW_COPY_AND_ASSIGN(WebRequestCondition); |
94 }; | 113 }; |
95 | 114 |
96 // This class stores a set of conditions that may be part of a WebRequestRule. | 115 typedef DeclarativeConditionSet<WebRequestCondition> WebRequestConditionSet; |
97 // If any condition is fulfilled, the WebRequestActions of the WebRequestRule | |
98 // can be triggered. | |
99 class WebRequestConditionSet { | |
100 public: | |
101 typedef std::vector<linked_ptr<json_schema_compiler::any::Any> > AnyVector; | |
102 typedef std::vector<linked_ptr<WebRequestCondition> > Conditions; | |
103 | |
104 ~WebRequestConditionSet(); | |
105 | |
106 // Factory method that creates an WebRequestConditionSet according to the JSON | |
107 // array |conditions| passed by the extension API. | |
108 // Sets |error| and returns NULL in case of an error. | |
109 static scoped_ptr<WebRequestConditionSet> Create( | |
110 URLMatcherConditionFactory* url_matcher_condition_factory, | |
111 const AnyVector& conditions, | |
112 std::string* error); | |
113 | |
114 const Conditions& conditions() const { | |
115 return conditions_; | |
116 } | |
117 | |
118 // If |url_match_trigger| is a member of |url_matches|, then this returns | |
119 // whether the corresponding condition is fulfilled wrt. |request_data|. If | |
120 // |url_match_trigger| is -1, this function returns whether any of the | |
121 // conditions without URL attributes is satisfied. | |
122 bool IsFulfilled( | |
123 URLMatcherConditionSet::ID url_match_trigger, | |
124 const std::set<URLMatcherConditionSet::ID>& url_matches, | |
125 const WebRequestRule::RequestData& request_data) const; | |
126 | |
127 // Appends the URLMatcherConditionSet from all conditions to |condition_sets|. | |
128 void GetURLMatcherConditionSets( | |
129 URLMatcherConditionSet::Vector* condition_sets) const; | |
130 | |
131 // Returns whether there are some conditions without UrlFilter attributes. | |
132 bool HasConditionsWithoutUrls() const; | |
133 | |
134 private: | |
135 typedef std::map<URLMatcherConditionSet::ID, const WebRequestCondition*> | |
136 URLMatcherIdToCondition; | |
137 | |
138 WebRequestConditionSet( | |
139 const Conditions& conditions, | |
140 const URLMatcherIdToCondition& match_id_to_condition, | |
141 const std::vector<const WebRequestCondition*>& conditions_without_urls); | |
142 | |
143 const URLMatcherIdToCondition match_id_to_condition_; | |
144 const Conditions conditions_; | |
145 const std::vector<const WebRequestCondition*> conditions_without_urls_; | |
146 | |
147 DISALLOW_COPY_AND_ASSIGN(WebRequestConditionSet); | |
148 }; | |
149 | 116 |
150 } // namespace extensions | 117 } // namespace extensions |
151 | 118 |
152 #endif // CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDI
TION_H_ | 119 #endif // CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDI
TION_H_ |
OLD | NEW |