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

content / browser / browsing_topics / browsing_topics_site_data_manager_impl.cc [blame]

// 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