| // 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. |
| |
| #ifndef CONTENT_BROWSER_PRIVATE_AGGREGATION_PRIVATE_AGGREGATION_MANAGER_H_ |
| #define CONTENT_BROWSER_PRIVATE_AGGREGATION_PRIVATE_AGGREGATION_MANAGER_H_ |
| |
| #include <stddef.h> |
| |
| #include <optional> |
| #include <string> |
| |
| #include "base/functional/callback_forward.h" |
| #include "base/time/time.h" |
| #include "content/browser/private_aggregation/private_aggregation_budget_key.h" |
| #include "content/common/content_export.h" |
| #include "content/public/browser/storage_partition.h" |
| #include "mojo/public/cpp/bindings/pending_receiver.h" |
| #include "third_party/blink/public/mojom/private_aggregation/private_aggregation_host.mojom-forward.h" |
| |
| namespace url { |
| class Origin; |
| } |
| |
| namespace content { |
| |
| class BrowserContext; |
| |
| // Interface that mediates data flow between the Private Aggregation API |
| // component and other APIs using it. |
| class CONTENT_EXPORT PrivateAggregationManager { |
| public: |
| virtual ~PrivateAggregationManager() = default; |
| |
| static PrivateAggregationManager* GetManager(BrowserContext& browser_context); |
| |
| // Binds a new pending receiver for a worklet, allowing messages to be sent |
| // and processed. However, the receiver is not bound if the `worklet_origin` |
| // is not potentially trustworthy or if `context_id` is too long. The return |
| // value indicates whether the receiver was accepted. If `context_id` is set, |
| // and no `ContributeToHistogram()` calls are made by disconnection, a null |
| // report will still be sent. If `timeout` is set, the report will be sent as |
| // if the pipe closed after the timeout, regardless of when the disconnection |
| // actually happens. `timeout` must be positive if set. If |
| // `aggregation_coordinator_origin` is set, the origin must be on the |
| // allowlist. `filtering_id_max_bytes` must be positive and no greater than |
| // `AggregationServicePayloadContents::kMaximumFilteringIdMaxBytes`. |
| [[nodiscard]] virtual bool BindNewReceiver( |
| url::Origin worklet_origin, |
| url::Origin top_frame_origin, |
| PrivateAggregationBudgetKey::Api api_for_budgeting, |
| std::optional<std::string> context_id, |
| std::optional<base::TimeDelta> timeout, |
| std::optional<url::Origin> aggregation_coordinator_origin, |
| size_t filtering_id_max_bytes, |
| mojo::PendingReceiver<blink::mojom::PrivateAggregationHost> |
| pending_receiver) = 0; |
| |
| // Deletes all data in storage for any budgets that could have been set |
| // between `delete_begin` and `delete_end` time (inclusive). Note that the |
| // discrete time windows used in the budgeter may lead to more data being |
| // deleted than strictly necessary. Null times are treated as unbounded lower |
| // or upper range. If `!filter.is_null()`, budget keys with an origin that |
| // does *not* match the `filter` are retained (i.e. not cleared). |
| virtual void ClearBudgetData( |
| base::Time delete_begin, |
| base::Time delete_end, |
| StoragePartition::StorageKeyMatcherFunction filter, |
| base::OnceClosure done) = 0; |
| |
| // Returns whether debug mode is allowed for a context with the given |
| // parameters. If disallowed, any debug mode details specified over the |
| // PrivateAggregationHost mojo pipe will be ignored. |
| virtual bool IsDebugModeAllowed(const url::Origin& top_frame_origin, |
| const url::Origin& reporting_origin) = 0; |
| }; |
| |
| } // namespace content |
| |
| #endif // CONTENT_BROWSER_PRIVATE_AGGREGATION_PRIVATE_AGGREGATION_MANAGER_H_ |