File: attribution_scopes_data.cc

package info (click to toggle)
chromium 139.0.7258.127-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 6,122,068 kB
  • sloc: cpp: 35,100,771; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (138 lines) | stat: -rw-r--r-- 4,853 bytes parent folder | download | duplicates (9)
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "components/attribution_reporting/attribution_scopes_data.h"

#include <stdint.h>

#include <optional>
#include <utility>

#include "base/check.h"
#include "base/types/expected.h"
#include "base/types/expected_macros.h"
#include "base/values.h"
#include "components/attribution_reporting/attribution_scopes_set.h"
#include "components/attribution_reporting/constants.h"
#include "components/attribution_reporting/parsing_utils.h"
#include "components/attribution_reporting/privacy_math.h"
#include "components/attribution_reporting/source_registration_error.mojom.h"

namespace attribution_reporting {

namespace {

using ::attribution_reporting::mojom::SourceRegistrationError;

bool ScopesValid(const AttributionScopesSet& scopes, uint32_t scope_limit) {
  return !scopes.scopes().empty() && scopes.IsValidForSource(scope_limit);
}

bool EventStatesValid(uint32_t max_event_states) {
  return max_event_states > 0 &&
         max_event_states <= MaxTriggerStateCardinality();
}

bool DataValid(const AttributionScopesSet& scopes_set,
               uint32_t scope_limit,
               uint32_t max_event_states) {
  return scope_limit > 0 && ScopesValid(scopes_set, scope_limit) &&
         EventStatesValid(max_event_states);
}

}  // namespace

// static
std::optional<AttributionScopesData> AttributionScopesData::Create(
    AttributionScopesSet attribution_scopes_set,
    uint32_t attribution_scope_limit,
    uint32_t max_event_states) {
  if (!DataValid(attribution_scopes_set, attribution_scope_limit,
                 max_event_states)) {
    return std::nullopt;
  }

  return AttributionScopesData(std::move(attribution_scopes_set),
                               attribution_scope_limit, max_event_states);
}

// static
base::expected<AttributionScopesData, SourceRegistrationError>
AttributionScopesData::FromJSON(base::Value& v) {
  base::Value::Dict* scopes_dict = v.GetIfDict();
  if (!scopes_dict) {
    return base::unexpected(SourceRegistrationError::kAttributionScopesInvalid);
  }

  uint32_t attribution_scope_limit;
  if (const base::Value* attribution_scope_limit_value =
          scopes_dict->Find(kLimit)) {
    ASSIGN_OR_RETURN(
        attribution_scope_limit,
        ParsePositiveUint32(*attribution_scope_limit_value), [](ParseError) {
          return SourceRegistrationError::kAttributionScopeLimitInvalid;
        });
  } else {
    return base::unexpected(
        SourceRegistrationError::kAttributionScopeLimitRequired);
  }

  uint32_t max_event_states = kDefaultMaxEventStates;
  if (const base::Value* event_states_value =
          scopes_dict->Find(kMaxEventStates)) {
    ASSIGN_OR_RETURN(max_event_states, ParsePositiveUint32(*event_states_value),
                     [](ParseError) {
                       return SourceRegistrationError::kMaxEventStatesInvalid;
                     });
    if (max_event_states > MaxTriggerStateCardinality()) {
      return base::unexpected(SourceRegistrationError::kMaxEventStatesInvalid);
    }
  }

  ASSIGN_OR_RETURN(
      AttributionScopesSet attribution_scopes,
      AttributionScopesSet::FromJSON(*scopes_dict, attribution_scope_limit));
  return AttributionScopesData(std::move(attribution_scopes),
                               attribution_scope_limit, max_event_states);
}

AttributionScopesData::AttributionScopesData(AttributionScopesSet scopes,
                                             uint32_t attribution_scope_limit,
                                             uint32_t max_event_states)
    : attribution_scopes_set_(std::move(scopes)),
      attribution_scope_limit_(attribution_scope_limit),
      max_event_states_(max_event_states) {
  CHECK(DataValid(attribution_scopes_set_, attribution_scope_limit_,
                  max_event_states_));
}

AttributionScopesData::AttributionScopesData(mojo::DefaultConstruct::Tag) {
  CHECK(!DataValid(attribution_scopes_set_, attribution_scope_limit_,
                   max_event_states_));
}

AttributionScopesData::~AttributionScopesData() = default;

AttributionScopesData::AttributionScopesData(const AttributionScopesData&) =
    default;

AttributionScopesData::AttributionScopesData(AttributionScopesData&&) = default;

AttributionScopesData& AttributionScopesData::operator=(
    const AttributionScopesData&) = default;

AttributionScopesData& AttributionScopesData::operator=(
    AttributionScopesData&&) = default;

base::Value::Dict AttributionScopesData::ToJson() const {
  base::Value::Dict dict;

  dict.Set(kLimit, Uint32ToJson(attribution_scope_limit_));
  dict.Set(kMaxEventStates, Uint32ToJson(max_event_states_));
  attribution_scopes_set_.SerializeForSource(dict);

  return dict;
}

}  // namespace attribution_reporting