EUID Client-Side Integration Guide for Prebid.js
This guide is for publishers who have access to personal data (email address or phone number) on the client side and want to integrate with EUID and generate EUID tokens (advertising tokens) to be passed by Prebid.js in the RTB bidstream.
To integrate with EUID using Prebid.js, you'll need to make changes to the HTML and JavaScript on your site. No server-side work is required if you follow this guide.
Prebid.js Version
This implementation requires Prebid.js version 8.42.0 or later. For version information, see https://github.com/prebid/Prebid.js/releases.
If you need to use an earlier version of Prebid.js, use the implementation solution presented in the EUID Client-Server Integration Guide for Prebid.js instead.
Integration Example
An example of the EUID Prebid.js client-side integration is available at the following links:
- Code: Example Prebid.js EUID Integration
- Running site: EUID Prebid.js Client-Side Integration Example
Integration Overview: High-Level Steps
You'll need to complete the following steps:
Integrating with Single Sign-On (SSO)
If you integrate with one or more SSO providers to offer SSO login, you might be able to retrieve the logged-in user's email address from the SSO provider to generate EUID tokens.
For details, see Publisher Integration with SSO Providers.
Complete EUID Account Setup
Complete the EUID account setup by following the steps described in the Account Setup page. As part of the account setup process for a client-side implementation, you'll need to provide a list of domain names for the sites that you'll be using with Prebid.js.
Only root-level domains are required for account setup. For example, if you're going to use EUID with Prebid.js on example.com, shop.example.com, and example.org, you only need to provide the domain names example.com and example.org.
When account setup is complete, you'll receive a client keypair consisting of two values that identify you to the EUID servers: Subscription ID and public key. These values are unique to you, and you'll use them to configure the EUID module. For details, see Subscription ID and Public Key.
Add Prebid.js to Your Site
To add Prebid.js to your site, follow the instructions in Getting Started for Developers in the Prebid.js documentation.
When you download the Prebid.js package, add the EUID module by checking the box next to the module named European Unified ID, listed under the section User ID Modules.
When you've added Prebid.js to your site and confirmed that it's working properly, you're ready to configure the EUID module.
To make sure that the EUID module is installed, find the string euidIdSystem
in the pbjs.installedModules
array.
Configure the EUID Module
To configure the EUID module, call pbjs.setConfig
with an object containing the public key and Subscription ID that you received during account setup, as well as the user's hashed or unhashed email address.
Once it's configured, the EUID module generates an EUID token for the user and stores it in the user's browser. The module automatically refreshes the token as needed as long as your site is open in the user's browser.
You can configure the EUID module using any one of these accepted personal data formats, for any specific user:
- Normalized or un-normalized email address
- Normalized, hashed, and Base64-encoded email address
- Normalized phone number
- Normalized, hashed, and Base64-encoded phone number
Notes:
- The personal data format might vary per user, but you can only send one value per user.
- If you want to pass the personal data to the module already hashed, follow this sequence:
- First normalize.
- Then hash the result using the SHA-256 hashing algorithm.
- Then encode the resulting bytes of the hash value using Base64 encoding.
- The EUID module encrypts the hashed personal data before sending it to the EUID service.
- If the module is configured multiple times, it uses the most recent configuration values.
Configuring the EUID Module: Code Example
The following code snippet demonstrates the different ways that you can configure the EUID module.
const baseConfig = {
userSync: {
userIds: [{
name: 'euid',
params: {
serverPublicKey: publicKey,
subscriptionId: subscriptionId,
// Choose only one of the following: email, emailHash, phone, or phoneHash
email: 'user@example.com', // Normalized or non-normalized, unhashed email address
// emailHash: 'tMmiiTI7IaAcPpQPFQ65uMVCWH8av9jw4cwf/F5HVRQ=', // Normalized, hashed, and encoded email address
// phone: '+12345678901', // Normalized phone number
// phoneHash: 'EObwtHBUqDNZR33LNSMdtt5cafsYFuGmuY4ZLenlue4=', // Normalized, hashed, and encoded phone number
}
}]
}
};
This example assumes that you're using the EUID production environment. During integration testing, use the EUID integration environment by setting params.euidApiBase
to 'https://integ.euid.eu/'
. Tokens from the EUID integration environment are not valid for passing to the bidstream. For the integration environment, you will have different Subscription ID and public key values.
Storing the EUID Token in the Browser
By default, the EUID module stores data using local storage. To use a cookie instead, set params.storage
to cookie
, as shown in the following example.
For details, see European Unified ID Configuration in the Prebid documentation.
pbjs.setConfig({
userSync: {
userIds: [{
name: 'euid',
params: {
// default value is 'localStorage'
storage: 'cookie'
}
}]
}
});
The cookie size can be significant, which could be a problem. However, if local storage is not an option, this is one possible approach.
When to Pass Personal Data to the EUID Module
When the EUID module is configured, it checks for an existing EUID token in the user's browser. If there is a token that was generated from the same personal data, and either it's still valid or it can be refreshed, the module uses it, and refreshes if needed.
If there is no existing token, or the token has expired and cannot be refreshed, the EUID module cannot generate a new token without personal data.
Configure the EUID module with the user's personal data on each page load. This is the recommended approach.
In some cases, the user's personal data is not available on page load, and getting the personal data has some associated cost. For example, an API call might be required to fetch the personal data, or the user has to be prompted to provide the personal data.
If the EUID token has expired and cannot be refreshed, you must configure the EUID module with personal data to generate a new token. To do this, check the value returned by pbjs.getUserIds().euid
, as shown in the following example:
const params = {};
if (!pbjs.getUserIds().euid) {
// There is no token that can be used or refreshed.
// The EUID module must be configured with personal data to generate a new token.
params.email = getUserEmail();
params.serverPublicKey = publicKey;
params.subscriptionId = subscriptionId;
}
pbjs.setConfig({
userSync: {
userIds: [{
name: 'euid',
params: params
}]
}
});
It is possible that the user has opted out of EUID previously. In this case, the EUID module respects the user's optout and no EUID token is generated and collected by Prebid.js.
Checking the Integration
To check that the EUID module has successfully generated an EUID token, call pbjs.getUserIds().euid
. If a value is returned, a valid EUID token exists in the EUID module.
If there are problems with the integration, here are some steps you can take:
- Check the browser console logs.
- Check the values for Subscription ID (subscriptionId value) and public key (serverPublicKey value):
- Make sure they are exactly the same values that you received from the EUID team.
- Check that you have the correct values for the environment you're using. You'll have different Subscription ID and public key values for each environment.
- Check that you provided the domain name of the site to the EUID team during account setup. If needed, to confirm, ask your EUID contact.
- Use the browser developer tools to inspect the API calls to the EUID service.
For additional help, refer to Prebid's documentation on Troubleshooting Prebid.js and Debugging Prebid.js.
An example of a tool for validating and debugging Prebid.js configuration is Professor Prebid, an open-source Chrome extension:
- Chrome web store download location: Professor Prebid
- Documentation on prebid.org: Professor Prebid User Guide
Optional: Prebid.js Integration with Google Secure Signals
if you're using Prebid.js, and you're planning to pass EUID tokens to Google using Google Secure Signals, there are a couple of additional configuration steps:
- In your Google Ad Manager account, make sure that encrypted signals are properly shared with third-party bidders: see Allow Secure Signals Sharing.
- Update your Prebid.js configuration: see Optional: Enable Secure Signals in Prebid.js.