-
Notifications
You must be signed in to change notification settings - Fork 246
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
Comments
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 ProposalComponent sellers send data, such as publisher IDs, to top sellers via auction configurations. This data is then passed along to the When the For example, the render_url passed to runAdAuction is The SSP provided signals in auction config is If the SSP wins, the macro will be replaced by Chrome. The final render_url will be The above macro replacement can be done by the |
The solution to this problem may also solve #817 |
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 |
Just deleted my comment. :-) |
Thanks @ajvelasquezgoog and @keweigegoog , I am confirming that this proposal Noting the proposed solution does seem dependent on DSPs and SSPs coordinating on a standard for Given the current rollout schedule the above solution is only a temporary fix until 2026 when Fenced Frames come into play and |
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.
Macro Support for FLEDGE creatives #286
-- Is being deprecated in 2026 and does not provide a long term solution.
Supporting creative macros in FLEDGE #477
-- Helps with sending creative macro data post render for reporting purposes, which is really helpful, but again doesn’t help solve the current issue at hand.
The text was updated successfully, but these errors were encountered: