blob: 545679b3929c367abdc98f38f89dc247b4537f8b [file] [log] [blame]
// Copyright 2012 The Chromium Authors
// 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 <utility>
#include "base/functional/callback.h"
#include "extensions/common/mojom/event_dispatcher.mojom.h"
namespace {
const char kUrlFiltersKey[] = "url";
const char kWindowTypesKey[] = "windowTypes";
}
namespace extensions {
const char kEventFilterServiceTypeKey[] = "serviceType";
EventMatcher::EventMatcher(std::unique_ptr<base::Value::Dict> filter,
int routing_id)
: filter_(std::move(filter)), routing_id_(routing_id) {}
EventMatcher::~EventMatcher() {
}
bool EventMatcher::MatchNonURLCriteria(
const mojom::EventFilteringInfo& event_info) const {
if (event_info.has_instance_id) {
return event_info.instance_id == GetInstanceID();
}
if (event_info.window_type) {
int window_type_count = GetWindowTypeCount();
for (int i = 0; i < window_type_count; i++) {
std::string window_type;
if (GetWindowType(i, &window_type) &&
window_type == *event_info.window_type) {
return true;
}
}
return false;
}
if (event_info.has_window_exposed_by_default) {
// An event with a |window_exposed_by_default| set is only
// relevant to the listener if no window type filter is set.
if (HasWindowTypes())
return false;
return event_info.window_exposed_by_default;
}
const std::string& service_type_filter = GetServiceTypeFilter();
return service_type_filter.empty() ||
(event_info.service_type &&
service_type_filter == *event_info.service_type);
}
int EventMatcher::GetURLFilterCount() const {
base::Value::List* url_filters = filter_->FindList(kUrlFiltersKey);
if (url_filters)
return url_filters->size();
return 0;
}
const base::Value::Dict* EventMatcher::GetURLFilter(int i) {
base::Value::List* url_filters = filter_->FindList(kUrlFiltersKey);
if (url_filters)
return (*url_filters)[i].GetIfDict();
return nullptr;
}
bool EventMatcher::HasURLFilters() const {
return GetURLFilterCount() != 0;
}
std::string EventMatcher::GetServiceTypeFilter() const {
std::string service_type_filter;
if (const std::string* ptr =
filter_->FindString(kEventFilterServiceTypeKey)) {
if (base::IsStringASCII(*ptr))
service_type_filter = *ptr;
}
return service_type_filter;
}
int EventMatcher::GetInstanceID() const {
return filter_->FindInt("instanceId").value_or(0);
}
int EventMatcher::GetWindowTypeCount() const {
base::Value::List* window_type_filters = filter_->FindList(kWindowTypesKey);
if (window_type_filters)
return window_type_filters->size();
return 0;
}
bool EventMatcher::GetWindowType(int i, std::string* window_type_out) const {
base::Value::List* window_types = filter_->FindList(kWindowTypesKey);
if (window_types) {
if (i >= 0 && static_cast<size_t>(i) < window_types->size() &&
(*window_types)[i].is_string()) {
*window_type_out = (*window_types)[i].GetString();
return true;
}
}
return false;
}
bool EventMatcher::HasWindowTypes() const {
return GetWindowTypeCount() != 0;
}
int EventMatcher::GetRoutingID() const {
return routing_id_;
}
} // namespace extensions