File: browsing_topics_site_data_manager_impl.cc

package info (click to toggle)
chromium 138.0.7204.183-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-proposed-updates
  • size: 6,080,960 kB
  • sloc: cpp: 34,937,079; ansic: 7,176,967; javascript: 4,110,704; python: 1,419,954; asm: 946,768; xml: 739,971; pascal: 187,324; sh: 89,623; perl: 88,663; objc: 79,944; sql: 50,304; cs: 41,786; fortran: 24,137; makefile: 21,811; php: 13,980; tcl: 13,166; yacc: 8,925; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (83 lines) | stat: -rw-r--r-- 3,362 bytes parent folder | download | duplicates (8)
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