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
|
// Copyright 2021 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/attribution_reporting/store_source_result.h"
#include <optional>
#include <utility>
#include <variant>
#include "content/browser/attribution_reporting/storable_source.h"
#include "content/browser/attribution_reporting/store_source_result.mojom.h"
#include "third_party/abseil-cpp/absl/functional/overload.h"
namespace content {
namespace {
using Status = ::attribution_reporting::mojom::StoreSourceResult;
} // namespace
StoreSourceResult::StoreSourceResult(StorableSource source,
bool is_noised,
base::Time source_time,
std::optional<int> destination_limit,
Result result)
: source_(std::move(source)),
is_noised_(is_noised),
source_time_(source_time),
destination_limit_(destination_limit),
result_(std::move(result)) {
if (const auto* success = std::get_if<Success>(&result_)) {
CHECK(!success->min_fake_report_time.has_value() || is_noised_);
}
}
StoreSourceResult::~StoreSourceResult() = default;
StoreSourceResult::StoreSourceResult(const StoreSourceResult&) = default;
StoreSourceResult& StoreSourceResult::operator=(const StoreSourceResult&) =
default;
StoreSourceResult::StoreSourceResult(StoreSourceResult&&) = default;
StoreSourceResult& StoreSourceResult::operator=(StoreSourceResult&&) = default;
Status StoreSourceResult::status() const {
return std::visit(
absl::Overload{
[&](Success) {
return is_noised_ ? Status::kSuccessNoised : Status::kSuccess;
},
[](InternalError) { return Status::kInternalError; },
[](InsufficientSourceCapacity) {
return Status::kInsufficientSourceCapacity;
},
[](InsufficientUniqueDestinationCapacity) {
return Status::kInsufficientUniqueDestinationCapacity;
},
[](ExcessiveReportingOrigins) {
return Status::kExcessiveReportingOrigins;
},
[](ProhibitedByBrowserPolicy) {
return Status::kProhibitedByBrowserPolicy;
},
[](DestinationReportingLimitReached) {
return Status::kDestinationReportingLimitReached;
},
[](DestinationGlobalLimitReached) {
return Status::kDestinationGlobalLimitReached;
},
[](DestinationBothLimitsReached) {
return Status::kDestinationBothLimitsReached;
},
[](ReportingOriginsPerSiteLimitReached) {
return Status::kReportingOriginsPerSiteLimitReached;
},
[](ExceedsMaxChannelCapacity) {
return Status::kExceedsMaxChannelCapacity;
},
[](ExceedsMaxScopesChannelCapacity) {
return Status::kExceedsMaxScopesChannelCapacity;
},
[](ExceedsMaxTriggerStateCardinality) {
return Status::kExceedsMaxTriggerStateCardinality;
},
[](ExceedsMaxEventStatesLimit) {
return Status::kExceedsMaxEventStatesLimit;
},
[](DestinationPerDayReportingLimitReached) {
return Status::kDestinationPerDayReportingLimitReached;
},
},
result_);
}
} // namespace content
|