blob: 15abf5d879c244562cef133c73b1026188845d43 [file] [log] [blame]
// Copyright 2020 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 COMPONENTS_PERMISSIONS_PERMISSION_ACTIONS_HISTORY_H_
#define COMPONENTS_PERMISSIONS_PERMISSION_ACTIONS_HISTORY_H_
#include "base/memory/raw_ptr.h"
#include "base/notreached.h"
#include "base/time/time.h"
#include "components/keyed_service/core/keyed_service.h"
#include "components/permissions/permission_request_enums.h"
#include "components/permissions/permission_uma_util.h"
#include "components/permissions/permission_util.h"
#include "components/permissions/prediction_service/prediction_request_features.h"
#include "components/pref_registry/pref_registry_syncable.h"
enum class PermissionAction;
enum class RequestType;
class PrefService;
namespace user_prefs {
class PrefRegistrySyncable;
}
namespace permissions {
// This class records and stores all actions taken on permission prompts. It
// also has utility functions to interact with the history.
class PermissionActionsHistory : public KeyedService {
public:
struct Entry {
PermissionAction action;
base::Time time;
bool operator==(const Entry that) const {
return std::tie(this->action, this->time) ==
std::tie(that.action, that.time);
}
bool operator!=(const Entry that) const { return !(*this == that); }
};
enum class EntryFilter {
WANT_ALL_PROMPTS,
WANT_LOUD_PROMPTS_ONLY,
WANT_QUIET_PROMPTS_ONLY,
};
explicit PermissionActionsHistory(PrefService* pref_service);
PermissionActionsHistory(const PermissionActionsHistory&) = delete;
PermissionActionsHistory& operator=(const PermissionActionsHistory&) = delete;
~PermissionActionsHistory() override = default;
// Get the history of recorded actions that happened after a particular time.
// Optionally a permission request type can be specified which will only
// return actions of that type.
std::vector<Entry> GetHistory(const base::Time& begin,
EntryFilter entry_filter);
std::vector<Entry> GetHistory(const base::Time& begin,
RequestType type,
EntryFilter entry_filter);
// Record that a particular action has occurred at this time.
// `base::Time::Now()` is used to retrieve the current time.
void RecordAction(PermissionAction action,
RequestType type,
PermissionPromptDisposition prompt_disposition);
// Delete logs of past user interactions. To be called when clearing
// browsing data.
void ClearHistory(const base::Time& delete_begin,
const base::Time& delete_end);
PrefService* GetPrefServiceForTesting();
static void FillInActionCounts(
PredictionRequestFeatures::ActionCounts* counts,
const std::vector<PermissionActionsHistory::Entry>& permission_actions);
// Registers the preferences related to blocklisting in the given PrefService.
static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry);
private:
std::vector<Entry> GetHistoryInternal(const base::Time& begin,
const std::string& key,
EntryFilter entry_filter);
raw_ptr<PrefService> pref_service_;
};
} // namespace permissions
#endif // COMPONENTS_PERMISSIONS_PERMISSION_ACTIONS_HISTORY_H_