Any per-request restricted data processing settings that you configure will apply globally. For example, if you add per-request restricted data processing parameters to a request for a user from an applicable US state, restricted data processing mode will be activated and only non-personalised ads will serve.
- Restricted data processing settings for pages using GPT and AdSense tags
- Restricted data processing settings for other tags
Restricted data processing settings for pages using GPT and AdSense tags
Requesting ads
By default, ad requests to Google do not limit how data is processed and personalised ads are served, with ad selection based on both the content of the web page and the history of the individual user visiting the page. Google already supports sending signals via ad tags for multiple regulatory compliance and privacy reasons including:
- Non-personalised ads settings in Google’s publisher ad tags
(Ad Manager, AdMob, Android & iOS, AdSense) - Tagging an ad request for EEA users under the age of consent (TFUA)
(Ad Manager, AdMob, AdSense) - Tagging an ad request for child-directed treatment (TFCD)
(Ad Manager, AdMob, AdSense)Publishers may choose to use the TFCD parameter to tag requests for under-age users. Restricted data processing also will be activated when the TFCD parameter is set
This article outlines how to request restricted data processing mode via ad tags. When you activate restricted data processing, Google will limit how it uses data and only serve non-personalised ads. If you want to activate restricted data processing for all users located in applicable US states who visit your property, no changes to your ad tagging are needed. You can read more about restricted data processing, including how to activate it in the UI in the Google Ad Manager, AdMob or AdSense Help Centres.
If you wish to activate restricted data processing for only some users, GPT and AdSense/Ad Exchange asynchronous ad tags offer publishers a way to trigger the serving of restricted data processing on a per-page basis. This may be useful if you choose to display a 'Do Not Sell My Personal Information' opt-out link. For those users that opt out, you may decide that passing this signal satisfies your regulatory obligations. See 'Helping publishers comply with the US states privacy laws' (Google Ad Manager, AdMob, AdSense) for more information about restricted data processing mode.
- For the GPT tag, use the following code snippet:
googletag.pubads().setPrivacySettings({
'restrictDataProcessing': true
}); - For the AdSense and Ad Exchange asynchronous ad tag, use the following code snippet:
<ins class="adsbygoogle"
style="display:inline-block;width:728px;height:90px"
data-ad-client="ca-pub-0123456789abcdef"
data-ad-slot="0123456789"
data-restrict-data-processing="1"></ins>
These methods will trigger restricted data processing for subsequent Google ad requests from the page issued by the following supported ad tags: GPT, AdSense or Ad Exchange asynchronous ad tags (adsbygoogle.js
), and the IMA SDK. Verify that an ad tag is restricting data processing by finding the ad request in your browser developer tools and looking for the parameter &rdp=1
.
These same APIs allow disabling restricted data processing (and reactivation of personalisation) by passing in false
and 0
, depending on the type that the API expects. If a page contains multiple types of Google ad tags (for example, both a GPT tag and an AdSense/Ad Exchange asynchronous tag), you must use the RDP control for each type of tag.
Restricted data processing settings for other tags
GPT passback tags
If you're using GPT passback tags, you can mark an ad request as restricted data processing by using the same googletag.pubads().setPrivacySettings
API that traditional GPT uses.
Code example:
<script async src="https://securepubads.g.doubleclick.net/tag/js/gpt.js"></script> <div id='gpt-passback'> <script> window.googletag = window.googletag || {cmd: []}; googletag.cmd.push(function() { googletag .defineSlot('/123/sports', [300, 250], 'gpt-passback') .addService(googletag.pubads()); googletag.pubads().setPrivacySettings({ 'restrictDataProcessing': true }); googletag.enableServices(); googletag.display('gpt-passback'); }); </script> </div>
Tagless Request
If you're using Tagless Request, you can mark an ad request as restricted data processing by adding the rdp=[int]
parameter directly to the tag request URL. We recommend that you specify the parameter early in the tag to avoid any risk of truncation. Specify rdp=1
to mark the ad request as restricted data processing. Omission of the parameter defaults to disabling restricted data processing and allowing personalised ads.
Code example:
https://securepubads.g.doubleclick.net/gampad/ad?iu=/12345/adunit&sz=728x90&rdp=1&c=12345
Google Mobile Ads SDK
Please see the app developer site for more information on the Google Mobile Ads SDK.
- AdMob: iOS GMA SDK, Android GMA SDK
- Ad Manager: iOS GMA SDK, Android GMA SDK
Google Interactive Media Ads SDK (for Video)
On video requests, you can indicate that you want Google to treat your video content as restricted data processing. You can do this with a manually constructed master video tag (Ad Manager only) or using any of the platform-specific IMA SDKs (HTML 5 IMA SDK, iOS IMA SDK, Android IMA SDK, Google Cast IMA SDK).
If your video player uses Ad Manager's Dynamic Ad Insertion feature, it can also include the rdp=1 parameter with a video on demand (VOD) or live stream request to pass the parameter to any included ad requests (DAI HTML5 SDK, DAI Cast SDK, DAI iOS SDK, DAI Android SDK, DAI Roku SDK, DAI tvOS SDK).
Legacy Google publisher ad tags
Other types of Google ad tags (e.g. the legacy GAM tag, GUT tag and AdSense or Ad Exchange synchronous tag (show_ads.js
)) do not support restricted data processing ad requests. We recommend migrating to one of the tags that has full-feature support for both personalised ads and restricted data processing mode.
AdSense for Search
By default, ad requests to Google do not limit how data is processed and personalised ads are served, with ad selection based on both the user’s search query and the history of the individual user doing the search. When you activate restricted data processing, Google will limit how it uses data and only serve non-personalised ads.
You can either activate restricted data processing on a request basis as described below or by asking your account manager to deactivate personalisation for specific properties.
- For the Custom Search Ads – web ad tag, add the following text to the
pageOptions
in the Custom Search Ads tag:personalizedAds: false,
- For the AdMob tag:
builder.setAdvancedOptionValue("csa_personalizedAds", "false");
- For the iOS tag:
[request setAdvancedOptionValue:@"false" forKey:@"personalizedAds"];
These methods will trigger restricted data processing and serve non-personalised ads for that particular request. This is a stateless parameter. If the parameter isn't set in subsequent requests for that user, the behaviour will revert to the default behaviour, which is to request personalised ads.
Accelerated Mobile Pages (AMP)
<amp-ad type=”doubleclick”>
or <amp-ad type=”adsense”>
.For ad requests from AMP pages, publishers may choose to restrict data processing for all users located in applicable US states, or they may choose to restrict data processing selectively by following the instructions below to deactivate personalisation. Publishers will use the existing deactivate personalisation settings when they want to activate restricted data processing. These terms will be used interchangeably throughout this article.
Requesting non-personalised ads for users in applicable US states
If you use AMP AdSense tags, or AMP Doubleclick without Real Time Config (RTC), you may simply activate restricted data processing in the Google Ad Manager or AdSense UIs, and no further changes to your AMP pages are needed.
If your AMP ad tags do use Real Time Config (RTC), RTC requests are only sent if consent is given or not required. (Note: You can allow specific RTC callouts to be sent regardless of consent state.) To avoid sending RTC requests for users who will receive non-personalised ads (i.e. those in applicable US states) you can use the following components and configurations (amp-geo
and amp-consent
):
<!-- Set up the amp-geo component to detect end users from the US amp-geo only supports country-level geo detection now, but US states detection is coming soon. Please make sure that you handle the case 'unknown' when the country cannot be determined by amp-geo, and have at least one group contain the 'unknown' -->
<amp-geo layout=nodisplay>
<script type="application/json">
{
"ISOCountryGroups": {
"us": ["us"],
"eea": ["preset-eea", “unknown”]
}
}
</script>
</amp-geo>
<!-- Set up the amp-consent component to block requests and collect user consents. We'll later configure it to be auto-rejected, so it doesn't actually prompt for consent. This prevents RTC callouts and signals Ad Manager/AdSense to serve non-personalised ads. -->
<amp-consent layout="nodisplay" id="consent-element">
<script type="application/json">
{
“consentInstanceId”: “my_consent”,
“consentRequire”: false,
“geoOverride”: {
“us”: {
“consentRequired”: “remote”,
“checkConsentHref”: “https://your-endpoint”
}
}
</script>
</amp-consent>
Because amp-geo
does not currently support detecting applicable US states, you need to provide an endpoint to tell AMP whether consent is required for the current user via the checkConsentHref
setting. AMP expects a JSON object back from the endpoint, please find more information about the endpoint response from the AMP site document.
If setting an endpoint doesn't work for you, the AMP team is working on an upcoming feature to help you detect applicable US states users. Before that feature launch, you can choose to apply the consent setting to all US users as a temporary solution. The amp-consent
config looks like:
<!-- Set up the amp-consent component to block requests and collect user consents for all US users -->
<amp-consent layout="nodisplay" id="consent-element">
<script type="application/json">
{
“consentInstanceId”: “my_consent”,
“consentRequire”: false,
“geoOverride”: {
“us”: {
“consentRequired”: “true”
}
}
</script>
</amp-consent>
You must add the attribute data-block-on-consent
to any existing amp-ad
components on the page as indicated below. _auto_reject
instructs the ads to not wait for prompt, but fallback to serve non-personalised ads directly.
<!-- Finally we set up the ad tag, directing it to automatically reject consent -->
<amp-ad data-block-on-consent="_auto_reject"
width=320 height=50
type="doubleclick"
data-slot="/4119129/mobile_ad_banner">
</amp-ad>
Serving personalised/non-personalised ads based on consent
Since AMP doesn't allow custom JavaScript, the requesting of personalised or non-personalised ads is based on the configuration of an amp-consent
component, and the attributes data-block-on-consent
and data-npa-on-unknown-consent
. Assuming that you've configured an amp-consent
component and linked it to all <amp-ad>
tags on the page using data-block-on-consent
:
- If the user has responded affirmatively to the
amp-consent
component (user accepts the consent prompt), ads will be requested normally. - If the user has responded negatively to the
amp-consent
component (user rejects the consent prompt), non-personalised ads will be requested. - If the user’s response to the amp-consent is unknown (user dismisses the consent prompt)
- By default, no ad requests are sent at all.
- If
data-npa-on-unknown-consent
is set totrue
, non-personalised ads will be requested.
- If you configure an
amp-geo
component such that consent isn't applicable based on the user’s geographical location, requests are sent normally.
If your <amp-ad>
tags don't use data-block-on-consent
, or the amp-consent
component hasn't been correctly configured, requests are sent normally.
The following is an example of a configuration that prompts all users in the applicable US states for consent, with resulting behaviour as described above:
<!-- Set up the amp-geo component to detect end users from the US amp-geo only supports country-level geo detection now, but US states detection is coming soon. Please make sure that you handle the case 'unknown' when the country cannot be determined by amp-geo, and have at least one group contain the 'unknown' -->
<amp-geo layout=nodisplay>
<script type="application/json">
{
"ISOCountryGroups": {
"us": ["us"],
"unknown": ["unknown"]
}
}
</script>
</amp-geo>
<!--Set up the consent for users in the US -->
<amp-consent layout="nodisplay" id="consent-element">
<script type="application/json">
{
“consentInstanceId” : “my_consent”,
“consentRequired”: false,
“geoOverride”: {
“us”: {
“consentRequired”: “true”,
“promptUI”: “myConsentFlow”
}
}
}
</script>
<div id=”myConsentFlow”>...</div>
</amp-consent>
<!-- Finally we set up the ad tag, directing it to wait for consent when necessary, and request non-personalised ads if resolved consent is unknown -->
<amp-ad data-block-on-consent
data-npa-on-unknown-consent=true
width=320 height=50
type="doubleclick"
data-slot="/4119129/mobile_ad_banner">
</amp-ad>
You can set up your own endpoint to selectively prompt users for consent by configuring the page to send a CORS POST request to an endpoint via checkConsentHref
. You can learn more by reading the amp-consent documentation.