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
|
// Copyright 2023 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_FENCED_FRAME_FENCED_DOCUMENT_DATA_H_
#define CONTENT_BROWSER_FENCED_FRAME_FENCED_DOCUMENT_DATA_H_
#include <map>
#include <string>
#include <vector>
#include "base/functional/callback_forward.h"
#include "content/browser/fenced_frame/automatic_beacon_info.h"
#include "content/common/content_export.h"
#include "content/public/browser/document_user_data.h"
#include "third_party/blink/public/common/fenced_frame/redacted_fenced_frame_config.h"
namespace content {
// Used on the browser-side to store information related to fenced frames and
// URN iframes created using an API like Protected Audience or Shared Storage.
class CONTENT_EXPORT FencedDocumentData
: public DocumentUserData<FencedDocumentData> {
public:
~FencedDocumentData() override;
// Attempts to retrieve the automatic beacon data for a given event type.
const std::optional<AutomaticBeaconInfo> GetAutomaticBeaconInfo(
blink::mojom::AutomaticBeaconType event_type) const;
// Writes the beacon data set in `setReportEventDataForAutomaticBeacons()`.
void UpdateAutomaticBeaconData(
blink::mojom::AutomaticBeaconType event_type,
const std::string& event_data,
const std::vector<blink::FencedFrame::ReportingDestination>& destinations,
bool once,
bool cross_origin_exposed);
// Automatic beacon data is cleared out after one automatic beacon if `once`
// was set to true when calling `setReportEventDataForAutomaticBeacons()`.
void MaybeResetAutomaticBeaconData(
blink::mojom::AutomaticBeaconType event_type);
void AddDisabledUntrustedNetworkCallback(base::OnceClosure callback) {
on_disabled_untrusted_network_callbacks_.push_back(std::move(callback));
}
void RunDisabledUntrustedNetworkCallbacks();
private:
// No public constructors to force going through static methods of
// DocumentUserData (e.g. CreateForCurrentDocument).
explicit FencedDocumentData(RenderFrameHost* rfh);
friend DocumentUserData;
DOCUMENT_USER_DATA_KEY_DECL();
// Stores data registered by the document in a fenced frame tree using
// the `fence.setReportEventDataForAutomaticBeacons` API. Maps an event type
// to an AutomaticBeaconInfo object.
std::map<blink::mojom::AutomaticBeaconType, AutomaticBeaconInfo>
automatic_beacon_info_;
// Should be invoked when network access is cut off. This is stored as a
// vector to account for the web platform supporting multiple calls to
// disableUntrustedNetwork().
// Note: The callbacks must be run before FencedDocumentData is destroyed.
// Otherwise a check failure will crash the program, see check's error
// message: "LocalFrameHost::DisableUntrustedNetworkInFencedFrameCallback was
// destroyed without first either being run or its corresponding binding being
// closed. It is an error to drop response callbacks which still correspond to
// an open interface pipe."
// TODO(crbug.com/340606646): Add guards against the scenario above.
std::vector<base::OnceClosure> on_disabled_untrusted_network_callbacks_;
};
} // namespace content
#endif // CONTENT_BROWSER_FENCED_FRAME_FENCED_DOCUMENT_DATA_H_
|