Home | History | Annotate | Download | only in common
      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
      3 // found in the LICENSE file.
      4 
      5 #ifndef EXTENSIONS_COMMON_EVENT_FILTER_H_
      6 #define EXTENSIONS_COMMON_EVENT_FILTER_H_
      7 
      8 #include <map>
      9 #include <set>
     10 
     11 #include "base/memory/linked_ptr.h"
     12 #include "components/url_matcher/url_matcher.h"
     13 #include "extensions/common/event_filtering_info.h"
     14 #include "extensions/common/event_matcher.h"
     15 
     16 namespace extensions {
     17 
     18 // Matches incoming events against a collection of EventMatchers. Each added
     19 // EventMatcher is given an id which is returned by MatchEvent() when it is
     20 // passed a matching event.
     21 class EventFilter {
     22  public:
     23   typedef int MatcherID;
     24   EventFilter();
     25   ~EventFilter();
     26 
     27   // Adds an event matcher that will be used in calls to MatchEvent(). Returns
     28   // the id of the matcher, or -1 if there was an error.
     29   MatcherID AddEventMatcher(const std::string& event_name,
     30                             scoped_ptr<EventMatcher> matcher);
     31 
     32   // Retrieve the EventMatcher with the given id.
     33   EventMatcher* GetEventMatcher(MatcherID id);
     34 
     35   // Retrieve the name of the event that the EventMatcher specified by |id| is
     36   // referring to.
     37   const std::string& GetEventName(MatcherID id);
     38 
     39   // Removes an event matcher, returning the name of the event that it was for.
     40   std::string RemoveEventMatcher(MatcherID id);
     41 
     42   // Match an event named |event_name| with filtering info |event_info| against
     43   // our set of event matchers. Returns a set of ids that correspond to the
     44   // event matchers that matched the event.
     45   // TODO(koz): Add a std::string* parameter for retrieving error messages.
     46   std::set<MatcherID> MatchEvent(const std::string& event_name,
     47                                  const EventFilteringInfo& event_info,
     48                                  int routing_id);
     49 
     50   int GetMatcherCountForEvent(const std::string& event_name);
     51 
     52   // For testing.
     53   bool IsURLMatcherEmpty() const {
     54     return url_matcher_.IsEmpty();
     55   }
     56 
     57  private:
     58   class EventMatcherEntry {
     59    public:
     60     // Adds |condition_sets| to |url_matcher| on construction and removes them
     61     // again on destruction. |condition_sets| should be the
     62     // URLMatcherConditionSets that match the URL constraints specified by
     63     // |event_matcher|.
     64     EventMatcherEntry(
     65         scoped_ptr<EventMatcher> event_matcher,
     66         url_matcher::URLMatcher* url_matcher,
     67         const url_matcher::URLMatcherConditionSet::Vector& condition_sets);
     68     ~EventMatcherEntry();
     69 
     70     // Prevents the removal of condition sets when this class is destroyed. We
     71     // call this in EventFilter's destructor so that we don't do the costly
     72     // removal of condition sets when the URLMatcher is going to be destroyed
     73     // and clean them up anyway.
     74     void DontRemoveConditionSetsInDestructor();
     75 
     76     EventMatcher* event_matcher() {
     77       return event_matcher_.get();
     78     }
     79 
     80    private:
     81     scoped_ptr<EventMatcher> event_matcher_;
     82     // The id sets in url_matcher_ that this EventMatcher owns.
     83     std::vector<url_matcher::URLMatcherConditionSet::ID> condition_set_ids_;
     84     url_matcher::URLMatcher* url_matcher_;
     85 
     86     DISALLOW_COPY_AND_ASSIGN(EventMatcherEntry);
     87   };
     88 
     89   // Maps from a matcher id to an event matcher entry.
     90   typedef std::map<MatcherID, linked_ptr<EventMatcherEntry> > EventMatcherMap;
     91 
     92   // Maps from event name to the map of matchers that are registered for it.
     93   typedef std::map<std::string, EventMatcherMap> EventMatcherMultiMap;
     94 
     95   // Adds the list of URL filters in |matcher| to the URL matcher, having
     96   // matches for those URLs map to |id|.
     97   bool CreateConditionSets(
     98       MatcherID id,
     99       EventMatcher* matcher,
    100       url_matcher::URLMatcherConditionSet::Vector* condition_sets);
    101 
    102   bool AddDictionaryAsConditionSet(
    103       base::DictionaryValue* url_filter,
    104       url_matcher::URLMatcherConditionSet::Vector* condition_sets);
    105 
    106   url_matcher::URLMatcher url_matcher_;
    107   EventMatcherMultiMap event_matchers_;
    108 
    109   // The next id to assign to an EventMatcher.
    110   MatcherID next_id_;
    111 
    112   // The next id to assign to a condition set passed to URLMatcher.
    113   url_matcher::URLMatcherConditionSet::ID next_condition_set_id_;
    114 
    115   // Maps condition set ids, which URLMatcher operates in, to event matcher
    116   // ids, which the interface to this class operates in. As each EventFilter
    117   // can specify many condition sets this is a many to one relationship.
    118   std::map<url_matcher::URLMatcherConditionSet::ID, MatcherID>
    119       condition_set_id_to_event_matcher_id_;
    120 
    121   // Maps from event matcher ids to the name of the event they match on.
    122   std::map<MatcherID, std::string> id_to_event_name_;
    123 
    124   DISALLOW_COPY_AND_ASSIGN(EventFilter);
    125 };
    126 
    127 }  // namespace extensions
    128 
    129 #endif  // EXTENSIONS_COMMON_EVENT_FILTER_H_
    130