1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/browser/browsing_topics/browsing_topics_site_data_manager_impl.h"
#include "base/task/lazy_thread_pool_task_runner.h"
namespace content {
namespace {
// The shared-task runner for all browsing topics site data storage operations.
// The backend is a sqlite database and we want to be sure to access it on a
// single thread (to prevent any potential races when a given context is
// destroyed and recreated for the same backing storage.). This uses
// BLOCK_SHUTDOWN as some data deletion operations may be running when the
// browser is closed, and we want to ensure all data is deleted correctly. This
// uses BEST_EFFORT as the database will be queried very infrequently (e.g.
// every week), so some amount of delay is acceptable.
base::LazyThreadPoolSequencedTaskRunner g_storage_task_runner =
LAZY_THREAD_POOL_SEQUENCED_TASK_RUNNER_INITIALIZER(
base::TaskTraits(base::TaskPriority::BEST_EFFORT,
base::MayBlock(),
base::TaskShutdownBehavior::BLOCK_SHUTDOWN));
const base::FilePath::CharType kDatabasePath[] =
FILE_PATH_LITERAL("BrowsingTopicsSiteData");
} // namespace
BrowsingTopicsSiteDataManagerImpl::BrowsingTopicsSiteDataManagerImpl(
const base::FilePath& user_data_directory)
: storage_(base::SequenceBound<BrowsingTopicsSiteDataStorage>(
g_storage_task_runner.Get(),
user_data_directory.Append(kDatabasePath))) {}
BrowsingTopicsSiteDataManagerImpl::~BrowsingTopicsSiteDataManagerImpl() =
default;
void BrowsingTopicsSiteDataManagerImpl::ExpireDataBefore(base::Time time) {
storage_.AsyncCall(&BrowsingTopicsSiteDataStorage::ExpireDataBefore)
.WithArgs(time);
}
void BrowsingTopicsSiteDataManagerImpl::ClearContextDomain(
const browsing_topics::HashedDomain& hashed_context_domain) {
storage_.AsyncCall(&BrowsingTopicsSiteDataStorage::ClearContextDomain)
.WithArgs(hashed_context_domain);
}
void BrowsingTopicsSiteDataManagerImpl::GetBrowsingTopicsApiUsage(
base::Time begin_time,
base::Time end_time,
GetBrowsingTopicsApiUsageCallback callback) {
storage_.AsyncCall(&BrowsingTopicsSiteDataStorage::GetBrowsingTopicsApiUsage)
.WithArgs(begin_time, end_time)
.Then(std::move(callback));
}
void BrowsingTopicsSiteDataManagerImpl::OnBrowsingTopicsApiUsed(
const browsing_topics::HashedHost& hashed_main_frame_host,
const browsing_topics::HashedDomain& hashed_context_domain,
const std::string& context_domain,
base::Time time) {
storage_.AsyncCall(&BrowsingTopicsSiteDataStorage::OnBrowsingTopicsApiUsed)
.WithArgs(hashed_main_frame_host, hashed_context_domain, context_domain,
time);
}
void BrowsingTopicsSiteDataManagerImpl::
GetContextDomainsFromHashedContextDomains(
const std::set<browsing_topics::HashedDomain>& hashed_context_domains,
BrowsingTopicsSiteDataManager::
GetContextDomainsFromHashedContextDomainsCallback callback) {
storage_
.AsyncCall(&BrowsingTopicsSiteDataStorage::
GetContextDomainsFromHashedContextDomains)
.WithArgs(hashed_context_domains)
.Then(std::move(callback));
}
} // namespace content
|