Skip to content

Migrate to V3

Introduction

V3 introduces breaking changes that will require manual updates if you have an existing codebase with a custom V2 implementation.

This guide covers what you should be changing in order to be able to use the V3 version.

For each step, this guide is designed to:

  • help you understand the differences between V2 and V3
  • help you resolve any breaking changes
  • provide you, whenever possible, with code examples and starting points in order to migrate to V3.

Info

For a broader understanding of V3, please read the following document.

Getting started

Script Tag

Let's start the migration by updating the Usercentrics <script> tag on your website.

The main difference will be the src URL. In order to start using V3, please update the src to: "https://web.cmp.usercentrics.eu/ui/loader.js.

bundle and bundle-legacy users

Only loader.js is available on V3

<script
  id="usercentrics-cmp"
  data-settings-id="XXXXXXXX"
  src="https://web.cmp.usercentrics.eu/ui/loader.js" 
  async
>
</script>
<script src="https://web.cmp.usercentrics.eu/tcf/stub.js">
<script
  id="usercentrics-cmp"
  data-settings-id="XXXXXXXX"
  src="https://web.cmp.usercentrics.eu/ui/loader.js" 
  async
>
</script>
<script
  id="usercentrics-cmp"
  data-settings-id="XXXXXXXX"
  src="https://app.usercentrics.eu/browser-ui/latest/loader.js" 
  async>
</script>
<script
  id="usercentrics-cmp"
  data-settings-id="XXXXXXXX"
  src="https://app.usercentrics.eu/browser-ui/latest/loader.js"
  data-tcf-enabled
>
</script>

Browser UI API

We recommend taking a look at our new Browser UI API after you resolve the breaking changes

Renamed methods

With the introduction of V3, the following Browser UI API methods were renamed:

Old name New name
enableScriptsForServicesWithConsent refreshScripts
clearStorage clearUserSession

Renamed methods with functional changes

The following methods, besides being renamed also got functional changes

Old name New name
acceptServices updateServicesConsents
rejectServices
updateChoicesForTcf updateTcfConsents

updateServicesConsents

In order to simplify the services consent updates, the acceptServices and rejectServices have been unified into one method updateServicesConsents which now accepts the following parameters:

Input Input Type Return Type
servicesConsents ServicesConsents Promise<void>
const serviceConsents = [
    {id: 'HkocEodjb7', consent: true}, // Google Analytics
    {id: 'S1_9Vsuj-Q', consent: false}, // Google Ads
]

await __ucCmp.updateServicesConsents(serviceConsents);
await __ucCmp.saveConsents();

updateTcfConsents

Input Input Type Return Type
decisions TCFDecisions Promise<void>
const vendorConsents = [
    {id: 6, consent: true}, // AdSpirit GmbH
    {id: 11, legitimateInterestConsent: false}, // Quantcast
];

const decision = {
    vendors: vendorConsents
};

await updateTcfVendorConsents({ decision });

Methods functional changes

All new V3 methods are now async. Apart from that, denyAllConsents, acceptAllConsents, updateServicesConsents and updateTcfConsents will only update the consent status. In order to save consents, you need to call saveConsents('EXPLICIT' | 'IMPLICIT') after updating consents.

Removed methods

With the introduction of V3, the following Browser UI API methods were removed:

Removed methods

acceptService

areAllConsentsAccepted

denyAndCloseCcpa

rejectService

getServicesBaseInfo

getServicesFullInfo

restartCMP

restartEmbeddings

getSettings

getSettingsCore

getSettingsUI

getSettingsLabels

getTCFVendors

Content Security Policy

For best security you should add a Content-Security-Policy meta tag. It's important to replace the nonce.

<meta http-equiv="Content-Security-Policy" content="script-src 'self' https://*.usercentrics.eu 'nonce-SomeRandomString'; connect-src 'self' https://*.usercentrics.eu; img-src 'self' data: https://*.usercentrics.eu;">
<script nonce="SomeRandomString" src="https://web.cmp.usercentrics.eu/ui/loader.js" id="usercentrics-cmp" data-settings-id="YOUR_SETTINGS_ID"></script>

Missing features (not implemented yet)

Whereas most of the features of v2 have been implemented, some are still on the todo list:

  • Consent injection via window variable

CustomCSS

Since the structure of the CMP changed, the custom css is not backwards compatible and needs updating.

Please read more about the new custom css entry points.

Embeddings

Starting with V3, in order to simplify their usage - embeddings will be a reflection of the CMP itself, meaning that all the information present in the CMP will also be present in the Embeddings.

Setup options

For the div possible class names remain the same: "uc-embed" and "uc-embed-tcf" for GDPR and TCF, respectively.

For more insights, please refer to the Embeddings documentation

Structure

Since embeddings are a reflection of the CMP in V3, the structure of these have been simplified. The previous way of configuring embeddings is no longer required because of this.

Deprecated attributes

uc-data

As mentioned above, all the information present in the CMP will be displayed in the embeddings with no option to filter out specific information.

uc-styling

All embeddings will have the same styling as the CMP, so no further styling is required.

This attribute has been deprecated in favor of using the uc-embed-type value service-specific with the uc-embed-service-id.

Example on how to migrate from V2 to V3

<div 
  class="uc-embed"
  uc-embed-type="service-specific"
  uc-embed-service-id="BJz7qNsdj-7">
</div>
<div 
  class="uc-embed"
  uc-consent-name="Youtube Video"
  uc-data="all">
</div>

uc-embedding-vendors

Since we now reflect the same labels and styling as the CMP, this option is no longer available.

uc-embedding-non-iab-vendors

Since we now reflect the same labels and styling as the CMP, this option is no longer available.

uc-embedding-atp-vendors

Since we now reflect the same labels and styling as the CMP, this option is no longer available.

Renamed attributes

uc-embedding-type

Was renamed to uc-embed-type.

The values for purpose and vendor were renamed to purposes and vendors, respectively.

uc-show-toggle

Was renamed to uc-embed-show-toggle.

Following the same phylosophy as uc-styling is no longer possible to change the toggle colors, they will keep the same color as selected for the CMP.

In that case, .uc-embed-toggle-button.toggle-on, .uc-embed-toggle-button.toggle-off, .uc-embed-toggle-button.toggle-disabled are no longer supported.

uc-embedding-show-hidden-categories

Was renamed to uc-embed-show-all-categories. All other functionality and properties remain the same.

uc-embedding-title

Was renamed to uc-embed-title.