Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Loss of runtime data for dynamic creatives #931

Open
dchristian-ias opened this issue Nov 27, 2023 · 5 comments
Open

Loss of runtime data for dynamic creatives #931

dchristian-ias opened this issue Nov 27, 2023 · 5 comments

Comments

@dchristian-ias
Copy link

AdTech companies that provide Advertisers products like Brand Safety and Fraud Protection depend on a number of runtime signals used to decide if they should display the Advertiser’s creative on a webpage, or block the ad from displaying. In PAAPI these signals are no longer available, essentially breaking these products.

Product Definitions
In this instance Brand Safety would entail blocking a creative from displaying on a Publisher page if the context (article/text) on that page is not content the Advertiser wants their ad appearing next to. Picture an airline ad being blocked from displaying on an article about 9/11.

Fraud Protection would entail blocking ads from running on a Publisher page when a bot is viewing the page vs a human.

Brand Safety Limitations
For Brand Safety, the biggest signal these companies depend on is the page url (full path, not just domain). This allows them to know (request made to backend server with page url) what type of content the ad is about to display on, and make a decision on if they should render the Advertiser’s creative on the page or not.

In direct and friendly frame placements, this data came from a top window prop like location.href, which is no longer accessible in FencedFrames.

In cross domain iframes where access to top level url is not available, this signal used to come from macro replacement in the creative url (DV360’s ${SOURCE_URL_ENC} for example), which is being phased out, and no longer available in PAAPI.

Fraud Protection Limitations
For Fraud Protection, helpful signals like page url, page domain, bid url, publisher Id, and exchange Id are also lost with the introduction of FencedFrames and deprecation of creative macro replacement.

In cross domain iframe scenarios the page domain used to be available via ancestorOrigins, but since Fenced Frames cut off any communication with the embedding context, this data is no longer available.

Comparing the page domain vs the bid url (available as a creative macro), as an example, is another type of signal these companies would look at to help detect fraudulent activity.

Noting: Fraud Protection usually consumes a number of different signals like IP, UserAgent, etc.. But just scoping this issue to runtime signals lost due to FencedFrame limitations, and creative macro replacement being phased out.

Question
How does Chrome look to provide these signals inside FencedFrames that were once available at runtime via window properties and creative macro replacement, but are no longer available given the new auction flow PAAPI provides?

These signals are important to Advertisers to ensure Brand Safety for their creatives, and are also helpful data points when calculating Fraud Protection for Advertisers as well.

Additional Notes
Also just noting, we are aware of GitHub Issues like the below that aim to help solve limitations due to lack of creative macro replacement in PAAPI, but neither help provide long term solutions for the lack of runtime data needed by creatives rendered inside FencedFrames.

@keweigegoog
Copy link

As a short-term solution when iFrames are still available until at least 2026, we’d like to propose Chrome allow SSP-provided macro values to be replaced in a winning render URL when processing the runAdAuction function.

Proposal

Component sellers send data, such as publisher IDs, to top sellers via auction configurations. This data is then passed along to the runAdAuction function.

When the runAdAuction function is executed, Chrome replaces macros in the winning render URL with actual values based on the key-value pairs provided by the winning SSP in the auction configuration.

For example, the render_url passed to runAdAuction is
https://cdn.com/adfetch?pub_id=${PUBLISHER_ID}

The SSP provided signals in auction config is
{[‘PUBLISHER_ID’: ‘123’]}

If the SSP wins, the macro will be replaced by Chrome. The final render_url will be
https://cdn.com/adfetch?pub_id=123

The above macro replacement can be done by the deprecatedReplaceInURN function introduced in Macro Support for FLEDGE creatives #286.

@sewoomg
Copy link
Contributor

sewoomg commented Dec 11, 2023

The solution to this problem may also solve #817

@ajvelasquezgoog
Copy link
Collaborator

ajvelasquezgoog commented Jan 25, 2024

Thanks David and Kewei. We wanted to highlight an update on our support of the Brand Safety use case mentioned here, while acknowledging that we continue to review and work on the feedback for the larger set of requests mentioned at the opening of the document.

We are indeed planning to provide an enhancement to deprecatedReplaceInURN JS API to make it available to more parties. We believe this covers the advertiser Brand Safety use case. Please see our detailed plan as a response to issue #286 (comment)

This has a target release for Chrome M123

@dmdabbs
Copy link
Contributor

dmdabbs commented Jan 25, 2024

Just deleted my comment. :-)

@dchristian-ias
Copy link
Author

Thanks @ajvelasquezgoog and @keweigegoog , I am confirming that this proposal
will support almost all of our creative macro needs for as long as deprecatedReplaceInURN is still available. We cannot resolve INVENTORY_SOURCE_EXTERNAL_ID or PMP/Deal ID until there is a resolution for supporting deals.

Noting the proposed solution does seem dependent on DSPs and SSPs coordinating on a standard for renderUrl macro replacement using deprecatedReplaceInURN.

Given the current rollout schedule the above solution is only a temporary fix until 2026 when Fenced Frames come into play and deprecatedReplaceInURN is deprecated. I'm curious how you and your team are thinking about solving this issue in the long term?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants