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

Unified Diff: chrome/browser/extensions/api/declarative_webrequest/webrequest_rules_registry.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_rules_registry.h
diff --git a/chrome/browser/extensions/api/declarative_webrequest/webrequest_rules_registry.h b/chrome/browser/extensions/api/declarative_webrequest/webrequest_rules_registry.h
new file mode 100644
index 0000000000000000000000000000000000000000..7682df2942b0064a7cb761d4ccc727591ec85b6c
--- /dev/null
+++ b/chrome/browser/extensions/api/declarative_webrequest/webrequest_rules_registry.h
@@ -0,0 +1,99 @@
+// 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_RULES_REGISTRY_H_
+#define CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_RULES_REGISTRY_H_
+#pragma once
+
+#include <vector>
+
+#include "base/memory/linked_ptr.h"
+#include "chrome/browser/extensions/api/declarative/rules_registry_with_cache.h"
+#include "chrome/browser/extensions/api/declarative/url_matcher.h"
+
+namespace net {
+class URLRequest;
+}
+
+namespace extensions {
+namespace declarative_webrequest{
+class WebRequestRule;
Matt Perry 2012/03/22 01:34:43 nit: just move this into the namespace block below
battre 2012/03/26 18:35:51 Done.
+}
+}
+
+namespace extensions {
+namespace declarative_webrequest{
Matt Perry 2012/03/22 01:34:43 We shouldn't go overboard with namespaces. I think
battre 2012/03/26 18:35:51 Done.
+
+// The WebRequestRulesRegistry is responsible for managing
+// the internal representation of rules for the Declarative Web Request API.
+//
+// Here is the high level overview of this functionality:
+//
+// RulesRegistry::Rule consists of Conditions and Actions, these are
+// represented as a WebRequestRule with WebRequestConditions and
+// WebRequestRuleActions.
+//
+// WebRequestConditions represent JSON dictionaries as the following:
+// {
+// 'instanceType': 'URLMatcher',
+// 'host_suffix': 'example.com',
+// 'path_prefix': '/query',
+// 'schema': 'http'
Matt Perry 2012/03/22 23:07:25 schema -> scheme
battre 2012/03/26 18:35:51 Done.
+// }
+//
+// The evaluation of URL related condition attributes (http_suffix, path_prefix)
Matt Perry 2012/03/22 01:34:43 host_suffix*
battre 2012/03/26 18:35:51 Done.
+// is delegated to a URLMatcher, because this is capable of evaluating many
+// of such URL related condition attributes in parallel.
+//
+// For this, the URLRequestCondition has a URLMatcherConditionSet, which
+// represents the {'host_suffix': 'example.com', 'path_prefix': '/query'} part.
+// We will then ask the URLMatcher, whether a given URL
+// "http://www.example.com/query/" has any matches, and the URLMatcher
+// will respond with the URLMatcherConditionSet::ID. We can map this
+// to the WebRequestRule and check whether also the other conditions (in this
+// example 'schema': 'http') are fulfilled.
Matt Perry 2012/03/22 01:34:43 I just started reviewing and don't have the full p
battre 2012/03/26 18:35:51 I have changed the example to 'has_cookie': {'name
+class WebRequestRulesRegistry : public RulesRegistryWithCache {
+ public:
+ typedef std::string ExtensionId;
+ typedef std::string RuleId;
+ typedef std::pair<ExtensionId, RuleId> GlobalRuleId;
+
+ WebRequestRulesRegistry();
+ ~WebRequestRulesRegistry();
+
+ // TODO(battre): This will become an implementation detail, because we need
+ // a way to also execute the actions of the rules.
+ std::set<GlobalRuleId> GetMatches(net::URLRequest* request);
+
+ // Implementation of RulesRegistryWithCache:
+ virtual std::string AddRulesImpl(
+ const std::string& extension_id,
+ const std::vector<linked_ptr<RulesRegistry::Rule> >& rules) OVERRIDE;
+ virtual std::string RemoveRulesImpl(
+ const std::string& extension_id,
+ const std::vector<std::string>& rule_identifiers) OVERRIDE;
+ virtual std::string RemoveAllRulesImpl(
+ const std::string& extension_id) OVERRIDE;
+ virtual content::BrowserThread::ID GetOwnerThread() const OVERRIDE;
+
+ private:
+ // Checking which rules match for a URLRequest is a two staged process.
+ // First we check all condition attributes regarding the URL. Each Rule is
+ // associated with URLMatcherConditionSets for these attributes. In case
+ // of a match, we also test the remaining condition attributes.
+ typedef std::map<URLMatcherConditionSet::ID, WebRequestRule*> RuleTriggers;
+ RuleTriggers rule_triggers_;
+
+ typedef std::map<GlobalRuleId, linked_ptr<WebRequestRule> > RulesMap;
+ RulesMap webrequest_rules_;
+
+ std::map<WebRequestRule*, GlobalRuleId> rule_ids_;
Matt Perry 2012/03/22 23:07:25 You could avoid needing this by having RuleTrigger
battre 2012/03/26 18:35:51 Done.
+
+ URLMatcher url_matcher_;
+};
+
+} // namespace declarative_webrequest
+} // namespace extensions
+
+#endif // CHROME_BROWSER_EXTENSIONS_API_DECLARATIVE_WEBREQUEST_WEBREQUEST_RULES_REGISTRY_H_

Powered by Google App Engine
This is Rietveld 408576698