As Chrome ships and experiments with various Protected Audience APIs, it can be useful for web developers to detect the presence of individual features in users’ browsers. This document seeks to list feature detection mechanisms for each shipped or experimented feature.
let pa = typeof navigator.joinAdInterestGroup !== 'undefined';
let dfss = false;
navigator.runAdAuction({get directFromSellerSignalsHeaderAdSlot(){dfss = true;}}).catch((e)=>{});
let nt = typeof navigator.createAuctionNonce !== 'undefined';
let nt = typeof navigator.clearOriginJoinedAdInterestGroups !== 'undefined';
These limits are intended to be guardrails against exceptional behavior, and not meant to be reached under normal conditions, so there should not be a need to find out what the guardrails are. In the best practices we previously published, we encourage buyers to use fewer interest groups.
reportWin(auctionSignals, perBuyerSignals, sellerSignals, browserSignals, directFromSellerSignals) {
...
let ka = typeof browserSignals.kAnonStatus !== 'undefined';
}
Intent to Experiment (note that this is an Origin Trial and as such requires Origin Trial tokens)
let ba = typeof navigator.getInterestGroupAdAuctionData !== 'undefined';
generateBid(interestGroup, auctionSignals, perBuyerSignals,
trustedBiddingSignals, browserSignals, directFromSellerSignals) {
...
let rg = typeof browserSignals.recency !== 'undefined';
}
This is a privacy protection that does not require different behavior from Protected Audience API callers and hence has no feature detection mechanism.
Whether automatic beacons will attach credentials cannot be detected from inside Protected Audience ads. From the perspective of the server, the request has either credentials mode “omit” (feature disabled) or “include” (feature enabled), which affects how headers are processed in the same way as the rest of the web platform.
This cannot be detected from the web platform. Instead, an ad auction can register both a reserved.top_navigation_commit
and a reserved.top_navigation
beacon, and then the ad frame can set the same automatic beacon data for both event types. The beacon destination server can then compare
top_navigation_commit
and top_navigation
beacons, and filter out duplicate beacons that have the same exact data.
Inside generateBid
one can determine the currently active limit on number of components ads as follows:
const maxAdComponents = browserSignals.adComponentsLimit ?
browserSignals.adComponentsLimit : 20;
From the context of a web page, the limit can also be queried as follows:
const maxAdComponents = navigator.protectedAudience ?
navigator.protectedAudience.queryFeatureSupport("adComponentsLimit") : 20;
Inside reportWin
one can determine its reporting timeout as follows:
const reportingTimeout = browserSignals.reportingTimeout ?
browserSignals.reportingTimeout : 50;
Inside reportResult
one can determine its reporting timeout as follows:
const reportingTimeout = auctionConfig.reportingTimeout ?
auctionConfig.reportingTimeout : 50;
From the context of a web page, whether custom reporting timeout is enabled can be queried as follows:
const reportingTimeoutEnabled = navigator.protectedAudience &&
navigator.protectedAudience.queryFeatureSupport("reportingTimeout");
Inside generateBid()
, if browserSignals.multiBidLimit
exists then returning
an array of bids is supported. The value of browserSignals.multiBidLimit
returns the maximum numbers of bids that can be returned, which may be as low as
1.
Inside generateBid()
, if browserSignals.multiBidLimit
exist then
the targetNumAdComponents
and numMandatoryAdComponents
bid fields will be
considered.
From context of a web page:
navigator.protectedAudience && navigator.protectedAudience.queryFeatureSupport(
"permitCrossOriginTrustedSignals")
From context of a web page:
navigator.protectedAudience && navigator.protectedAudience.queryFeatureSupport(
"realTimeReporting")
From context of a web page:
navigator.protectedAudience && navigator.protectedAudience.queryFeatureSupport(
"selectableReportingIds")
From context of a web page:
navigator.protectedAudience && navigator.protectedAudience.queryFeatureSupport(
"sellerNonce")
From context of a web page:
navigator.protectedAudience && navigator.protectedAudience.queryFeatureSupport(
"trustedSignalsKVv2")
Sometimes it's desirable to get status of all features detectable via queryFeatureSupport
in a
forward-compatible way. Sufficiently recent versions provide this functionality via
queryFeatureSupport('*')
, which returns a dictionary describing state of various features. Since
that functionality isn't available in older versions, backwards-compatibility polyfilling is
suggested:
let qfs = navigator.protectedAudience ?
navigator.protectedAudience.queryFeatureSupport.bind(navigator.protectedAudience) : null;
let allFeatureStatus = qfs ?
(qfs("*") || {
adComponentsLimit: qfs("adComponentsLimit"),
deprecatedRenderURLReplacements: qfs("deprecatedRenderURLReplacements"),
reportingTimeout: qfs("reportingTimeout")
}) : {}
An example return value would be:
{
"adComponentsLimit":40,
"deprecatedRenderURLReplacements":false,
"permitCrossOriginTrustedSignals":true,
"realTimeReporting":true,
"reportingTimeout":true
}