blob: cb09e73ffc05a9b83d4b5cd919f3d355b62f1311 [file] [log] [blame]
// 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.
#ifndef CONTENT_BROWSER_ATTRIBUTION_REPORTING_ATTRIBUTION_SUITABLE_CONTEXT_H_
#define CONTENT_BROWSER_ATTRIBUTION_REPORTING_ATTRIBUTION_SUITABLE_CONTEXT_H_
#include <stdint.h>
#include <optional>
#include "base/memory/weak_ptr.h"
#include "components/attribution_reporting/suitable_origin.h"
#include "content/browser/attribution_reporting/attribution_input_event.h"
#include "content/common/content_export.h"
#include "content/public/browser/content_browser_client.h"
#include "services/metrics/public/cpp/ukm_source_id.h"
namespace content {
class AttributionDataHostManager;
class NavigationHandle;
class RenderFrameHostImpl;
// The `AttributionSuitableContext` encapsulates the context necessary from a
// `RenderFrameHost` for a `KeepAliveAttributionRequestHelper` to be created.
class CONTENT_EXPORT AttributionSuitableContext {
public:
// Returns `AttributionSuitableContext` if the context is suitable to register
// attribution. The following two variants differ in the ways to get UKM
// source IDs.
//
// Called for a context associated with an ongoing navigation. Note that
// `AttributionHost::GetPageUkmSourceId()` returns the UKM source ID for the
// most recently navigated primary page, therefore we get UKM source ID from
// the associated ongoing navigation handle.
static std::optional<AttributionSuitableContext> Create(NavigationHandle*);
// Called for a context associated with a complete navigation.
static std::optional<AttributionSuitableContext> Create(RenderFrameHostImpl*);
// Allows to create a context with arbitrary properties for testing purposes.
static AttributionSuitableContext CreateForTesting(
attribution_reporting::SuitableOrigin context_origin,
bool is_nested_within_fenced_frame,
GlobalRenderFrameHostId root_render_frame_id,
int64_t last_navigation_id,
AttributionInputEvent last_input_event = AttributionInputEvent(),
ContentBrowserClient::AttributionReportingOsRegistrars os_registrars =
{ContentBrowserClient::AttributionReportingOsRegistrar::kWeb,
ContentBrowserClient::AttributionReportingOsRegistrar::kWeb},
AttributionDataHostManager* attribution_data_host_manager = nullptr,
bool is_context_google_amp_viewer = false,
ukm::SourceId ukm_source_id = ukm::kInvalidSourceId);
bool operator==(const AttributionSuitableContext& other) const;
AttributionSuitableContext(const AttributionSuitableContext&);
AttributionSuitableContext& operator=(const AttributionSuitableContext&);
AttributionSuitableContext(AttributionSuitableContext&&);
AttributionSuitableContext& operator=(AttributionSuitableContext&&);
~AttributionSuitableContext();
const attribution_reporting::SuitableOrigin& context_origin() const {
return context_origin_;
}
bool is_nested_within_fenced_frame() const {
return is_nested_within_fenced_frame_;
}
GlobalRenderFrameHostId root_render_frame_id() const {
return root_render_frame_id_;
}
int64_t last_navigation_id() const { return last_navigation_id_; }
const AttributionInputEvent& last_input_event() const {
return last_input_event_;
}
ContentBrowserClient::AttributionReportingOsRegistrars os_registrars() const {
return os_registrars_;
}
bool is_context_google_amp_viewer() const {
return is_context_google_amp_viewer_;
}
ukm::SourceId ukm_source_id() const { return ukm_source_id_; }
AttributionDataHostManager* data_host_manager() const {
return attribution_data_host_manager_.get();
}
private:
AttributionSuitableContext(
attribution_reporting::SuitableOrigin context_origin,
bool is_nested_within_fenced_frame,
GlobalRenderFrameHostId root_render_frame_id,
int64_t last_navigation_id,
AttributionInputEvent last_input_event,
ContentBrowserClient::AttributionReportingOsRegistrars,
bool is_context_google_amp_viewer,
ukm::SourceId,
base::WeakPtr<AttributionDataHostManager>);
attribution_reporting::SuitableOrigin context_origin_;
bool is_nested_within_fenced_frame_;
GlobalRenderFrameHostId root_render_frame_id_;
int64_t last_navigation_id_;
AttributionInputEvent last_input_event_;
ContentBrowserClient::AttributionReportingOsRegistrars os_registrars_;
bool is_context_google_amp_viewer_ = false;
ukm::SourceId ukm_source_id_;
base::WeakPtr<AttributionDataHostManager> attribution_data_host_manager_;
};
} // namespace content
#endif // CONTENT_BROWSER_ATTRIBUTION_REPORTING_ATTRIBUTION_SUITABLE_CONTEXT_H_