Follow all 5 steps in this tutorial to set up Google Consent Mode V2 for your website.
Why do you need to implement consent mode for your website?
To keep using Google Ads measurement, ads personalization and remarketing features, you must collect consent from end users based in the EEA to share consent signals with Google.
data:image/s3,"s3://crabby-images/03bd7/03bd7bd4c256fd63838280d05e5c73827058cc32" alt=""
Disclaimer: Before getting started, consult with your legal department/expert regarding data and privacy. This tutorial only shows how to technically implement Google Consent Mode V2 using a CMP, it does not guarantee data and privacy compliance for your specific business.
*This guide is not sponsored, affiliated, endorsed or administered by Google or Cookiebot in any way. This guide was created to provide the ppc community with a technical tutorial on implementing consent mode V2. Check official sources for up-to-date information.
Now let’s get started!
Step 1: Choose a Google CMP (Consent Management Platform)
In this tutorial, I’m using Cookiebot as a CMP. But you can choose your own favorite partner. Here’s a link where you can find all official Google CMP Partners: cmppartnerprogram.withgoogle.com
I’m using Google Tag Manager to implement Consent Mode. Be sure to first set up your accounts. Accounts ready? Then navigate to ‘Container Settings’ in GTM.
data:image/s3,"s3://crabby-images/ecdd5/ecdd5bef0539abe3650933d37f330a0ae16d2053" alt=""
Step 2: Set up Google Tag Manager for Consent Mode
Enable consent overview in the Container Settings of your Google Tag Manager account. This option enables new consent functionality in GTM.
data:image/s3,"s3://crabby-images/f4400/f4400bae097db128f4586b5820673ea618a79455" alt=""
Now continue by navigating to your Tags overview and select to create a New tag.
Hit the ‘New’ button.
data:image/s3,"s3://crabby-images/0d0a5/0d0a5e9f1211ad3bacb93ed41a895a0c188f24e3" alt=""
Step 3: Configure the Cookiebot CPM tag
Search the gallery for ‘Cookiebot CMP’ and add it to your workspace. Provide required permissions. (If you are already working with Cookiebot, then update to the latest version.)
data:image/s3,"s3://crabby-images/a9934/a99345cda612932048e2db126eb2492d9f6dc9b3" alt=""
data:image/s3,"s3://crabby-images/e5abe/e5abeb4d4e6492e70406d0bd008e4e070da284fa" alt=""
Now enter your Cookiebot ID. You can get this ID from your Cookiebot.com user account. Copy/paste the Domain Group ID attached to your website(s).
data:image/s3,"s3://crabby-images/9af69/9af695b94f10ae9e2a81229d6b73ead99b2227e8" alt=""
Enable Google Consent Mode. Cookiebot will then automatically signal the user’s consent to tags that rely on the Google’s consent API.
Set the default consent state for users in different geographical regions if needed. Or leave blank to apply globally.
data:image/s3,"s3://crabby-images/0ac38/0ac38817431b9b743c0974913b8a336af8a934cb" alt=""
data:image/s3,"s3://crabby-images/7c7d0/7c7d0373b162c9ea9b8145a1690152ba91edb1bf" alt=""
Click ‘Add’ at the top right to save your changes.
Create a trigger to fire the Cookiebot tag. It should fire on all pages using the ‘Consent initialization – All pages’ trigger.
data:image/s3,"s3://crabby-images/bfc05/bfc05760aa55b61c982d991fc70a0e339745e753" alt=""
This is how your final tag should look like (except for the example value of the Cookiebot ID). Now hit ‘Save’ to create your tag.
data:image/s3,"s3://crabby-images/c1861/c1861eadcc0b57018401576aade3bebb4e452ec1" alt=""
Step 4: Debug and publish your setup
When you debug and publish your tag, the Cookiebot consent banner should appear on your website from the moment a user visits your website.
data:image/s3,"s3://crabby-images/f44ea/f44ea5d32237fdd759b3d00582affce692d8743e" alt=""
Cookiebot uses 4 consent types categories: necessary, preferences, statistics and marketing. Users can choose to enable or disable each of these categories.
The Consent Mode V2 introduces 2 new consent types: ‘ad_personalization’ and ‘ad_user_data’. Both are mapped to the ‘marketing’ Cookiebot type.
data:image/s3,"s3://crabby-images/bdf4f/bdf4ff2c7ad60d1225a969f574937caa6d9eac5e" alt=""
When people choose to enable ‘Marketing’ cookies, it will grant consent for ‘ad_storage’, ‘ad_personalization’ and ‘ad_user_data’.
data:image/s3,"s3://crabby-images/c3635/c3635f6ae0bbfe969d020e34a24f21a6f6bc4f94" alt=""
Step 5: Verify built-in consent checks
When a tag supports ‘Built-in Consent Checks’, you can use a default trigger like ‘All Pages’ for it to fire. It will first check consent before firing the tag.
data:image/s3,"s3://crabby-images/6b3b8/6b3b8a2bf33f3b2ab11d707729b219c353454ca9" alt=""
Tags such as the Google Tag, Google Ads, Floodlight and Conversion Linker all have built-in consent checks. No additional consent configuration is needed for these tags.
However, if you add new Tags that don’t have built-in consent checks (e.g. a Meta Pixel tag), then you need to ‘Require additional consent for the tag to fire’.
data:image/s3,"s3://crabby-images/f320a/f320a4786e194efec6acae234dfc9ad24d8ae9ba" alt=""
For Tags that require additional consent, you need to use a custom event Trigger that first checks the latest user consent state before firing the tag.
data:image/s3,"s3://crabby-images/f7d18/f7d184a52e9a3447dd746f45752e756fd9804571" alt=""
Create a new Trigger and select ‘Custom Event’ as the Trigger Type. Use ‘cookie_consent_update’ as the Event name. Fire on ‘All Custom Events’.
data:image/s3,"s3://crabby-images/d9a45/d9a45fc04c9a649facd186d6a358f66035e7bed4" alt=""
When you’re done configuring consent for all your tags. You can then debug and preview the consent configuration. All consent types are denied when no consent is given.
data:image/s3,"s3://crabby-images/56783/5678393c505c14159206b7e254b0a69bc8d35305" alt=""
When people choose to enable ‘Marketing’ cookies, it will grant consent for ‘ad_storage’, ‘ad_personalization’ and ‘ad_user_data’.
data:image/s3,"s3://crabby-images/dbba1/dbba1241179fddfdb6f8f578001b44e8ffac68a0" alt=""
Congratulations! You have now successfully implemented Google Consent Mode V2. Allow some time for Google to detect your changes.