// 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. #include "extensions/common/event_matcher.h" #include "extensions/common/event_filtering_info.h" namespace { const char kUrlFiltersKey[] = "url"; } namespace extensions { const char kEventFilterServiceTypeKey[] = "serviceType"; EventMatcher::EventMatcher(scoped_ptr filter, int routing_id) : filter_(filter.Pass()), routing_id_(routing_id) { } EventMatcher::~EventMatcher() { } bool EventMatcher::MatchNonURLCriteria( const EventFilteringInfo& event_info) const { if (event_info.has_instance_id()) { return event_info.instance_id() == GetInstanceID(); } const std::string& service_type_filter = GetServiceTypeFilter(); return service_type_filter.empty() || service_type_filter == event_info.service_type(); } int EventMatcher::GetURLFilterCount() const { base::ListValue* url_filters = NULL; if (filter_->GetList(kUrlFiltersKey, &url_filters)) return url_filters->GetSize(); return 0; } bool EventMatcher::GetURLFilter(int i, base::DictionaryValue** url_filter_out) { base::ListValue* url_filters = NULL; if (filter_->GetList(kUrlFiltersKey, &url_filters)) { return url_filters->GetDictionary(i, url_filter_out); } return false; } int EventMatcher::HasURLFilters() const { return GetURLFilterCount() != 0; } std::string EventMatcher::GetServiceTypeFilter() const { std::string service_type_filter; filter_->GetStringASCII(kEventFilterServiceTypeKey, &service_type_filter); return service_type_filter; } int EventMatcher::GetInstanceID() const { int instance_id = 0; filter_->GetInteger("instanceId", &instance_id); return instance_id; } int EventMatcher::GetRoutingID() const { return routing_id_; } } // namespace extensions