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

Unified Diff: chrome/browser/extensions/api/declarative_webrequest/webrequest_condition.h

Issue 9820003: Implementation of beginning of Declarative Web Request API backend (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 9 months 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/api/declarative_webrequest/webrequest_condition.h
diff --git a/chrome/browser/extensions/api/declarative_webrequest/webrequest_condition.h b/chrome/browser/extensions/api/declarative_webrequest/webrequest_condition.h
new file mode 100644
index 0000000000000000000000000000000000000000..b2aa1a12c6336183ac97ad009488d59a3c3eccf2
--- /dev/null
+++ b/chrome/browser/extensions/api/declarative_webrequest/webrequest_condition.h
@@ -0,0 +1,132 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITION_H_
+#define CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITION_H_
+#pragma once
+
+#include <string>
+#include <vector>
+
+#include "base/basictypes.h"
+#include "base/gtest_prod_util.h"
+#include "base/memory/linked_ptr.h"
+#include "chrome/browser/extensions/api/declarative/url_matcher.h"
+#include "chrome/browser/extensions/api/declarative_webrequest/webrequest_condition_attribute.h"
+
+namespace extensions {
+namespace declarative_webrequest {
+
+// Representation of a condition in the Declarative WebRequest API. A condition
+// consists of several attributes. Each of these attributes needs to be
+// fulfilled in order for the condition to be fulfilled.
+//
+// We distinguish between two types of conditions:
+// - URL Matcher conditions are conditions that test the URL of a request.
+// These are treated separately because we use a URLMatcher to efficiently
+// test many of these conditions in parallel by using some advanced
+// data structures. The URLMatcher tells us if all URL Matcher conditions
+// are fulfilled for a WebRequestCondition.
+// - All other conditions are represented as WebRequestConditionAttributes.
+// These conditions are probed linearly (only if the URL Matcher found a hit).
+class WebRequestCondition {
+ public:
+ WebRequestCondition(
+ const URLMatcherConditionSet& url_matcher_conditions,
+ const WebRequestConditionAttributes& condition_attributes);
+ ~WebRequestCondition();
+
+ // Returns whether |request| is a match, given that the URLMatcher found
+ // |url_match|.
+ bool IsFulfilled(URLMatcherConditionSet::ID url_match,
+ net::URLRequest* request) const;
+
+ // Returns a URLMatcherConditionSet::ID which is the canonical representation
+ // for all URL patterns that need to be matched by this WebRequestCondition.
+ // This ID is registered in a URLMatcher that can inform us in case of a
+ // match.
+ URLMatcherConditionSet::ID url_matcher_condition_set_id() const {
+ return url_matcher_conditions_.id();
+ }
+
+ // Appends the url matcher condition set to |condition_sets|.
+ void AppendURLMatcherConditionSet(
+ std::vector<URLMatcherConditionSet>* condition_sets) const;
Matt Perry 2012/03/22 23:07:25 There's only one condition set - just provide an a
battre 2012/03/26 18:35:51 Done.
+
+ private:
+ URLMatcherConditionSet url_matcher_conditions_;
+ WebRequestConditionAttributes condition_attributes_;
+
+ DISALLOW_COPY_AND_ASSIGN(WebRequestCondition);
+};
+
+// This class stores a set of conditions that may be part of a WebRequestRule.
+// If any condition is fulfilled, the WebRequestActions of the WebRequestRule
+// can be triggered.
+class WebRequestConditionCollection {
Matt Perry 2012/03/22 23:07:25 nit: name WebRequestConditionSet to mirror URLMatc
battre 2012/03/26 18:35:51 In the case of URLMatcherConditionSet, you favored
Matt Perry 2012/03/26 19:11:06 Do you expect duplicate WebRequestConditions/Actio
battre 2012/03/26 20:38:10 No, there should not be any duplicates. If there a
+ public:
+ explicit WebRequestConditionCollection(
+ const std::vector<linked_ptr<WebRequestCondition> >& conditions);
+ ~WebRequestConditionCollection();
+
+ const std::vector<linked_ptr<WebRequestCondition> >& conditions() const {
+ return conditions_;
+ }
+
+ bool IsFulfilled(const std::set<URLMatcherConditionSet::ID>& url_matches,
+ net::URLRequest* request) const;
+
+ // Appends the URLMatcherConditionSet from all conditions to |condition_sets|.
+ void AppendURLMatcherConditionSets(
+ std::vector<URLMatcherConditionSet>* condition_sets) const;
Matt Perry 2012/03/22 23:07:25 I think this should collect a vector of const-refe
battre 2012/03/26 18:35:51 The URLMatcherConditionSet consists of an ID (int)
Matt Perry 2012/03/26 19:11:06 True, but both copies are still stored in memory f
+
+ private:
+ typedef std::vector<linked_ptr<WebRequestCondition> > Collection;
+ Collection conditions_;
+
+ typedef std::map<URLMatcherConditionSet::ID,
+ WebRequestCondition*> MatchTriggers;
+ MatchTriggers match_triggers_;
+
+ DISALLOW_COPY_AND_ASSIGN(WebRequestConditionCollection);
+};
+
+class WebRequestConditionFactory {
Matt Perry 2012/03/22 23:07:25 since this is just a class with all static methods
battre 2012/03/26 18:35:51 Done.
+ public:
+ typedef std::vector<linked_ptr<json_schema_compiler::any::Any> > AnyVector;
+
+ static scoped_ptr<WebRequestCondition> CreateCondition(
+ URLMatcherConditionFactory* url_matcher_condition_factory,
+ const base::Value& condition,
+ std::string* error);
+
+ static scoped_ptr<WebRequestConditionCollection> CreateConditionCollection(
+ URLMatcherConditionFactory* url_matcher_condition_factory,
+ const AnyVector& conditions,
+ std::string* error);
+
+ private:
+ FRIEND_TEST_ALL_PREFIXES(WebRequestConditionFactoryTest,
+ GetAllPathAttributesSorted);
+ // A method for testing that an internal array kAllPathAttributes remains
+ // sorted.
+ static std::vector<std::string> GetAllPathAttributes();
Matt Perry 2012/03/22 23:07:25 this and the test are unnecessary if you take my s
battre 2012/03/26 18:35:51 Done.
+
+ // Returns whether an element of name |name| of a Condition needs to be
+ // handled by the UrlMatcher.
+ static bool IsUrlMatcherConditionAttribute(const std::string& name);
+
+ static URLMatcherCondition CreateURLMatcherCondition(
+ URLMatcherConditionFactory* url_matcher_condition_factory,
+ const std::string& condition_attribute_name,
+ const base::Value* value,
+ std::string* error);
+
+ DISALLOW_IMPLICIT_CONSTRUCTORS(WebRequestConditionFactory);
+};
+
+} // namespace declarative_webrequest
+} // namespace extensions
+
+#endif // CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_CONDITION_H_

Powered by Google App Engine
This is Rietveld 408576698