Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add GPP/TCF cmpapi integration to respect device access in EU/CA/US #152

Merged
merged 11 commits into from
Jan 7, 2025

Conversation

zapo
Copy link
Member

@zapo zapo commented Dec 12, 2024

In optable-web-sdk we currently defer the responsibility of detecting regulations and handling consent to the user which usually results in gating the load of the SDK which is not ideal.

In this PR we propose to detect regulation that should apply and integrate directly with CMP APIs (namely TCF and GPP) to gather visitor consent. Based on the detected regulation and consent, device access may be granted.

To do so, this PR introduces a new "consent" config property holding either a static consent object passed by the user, or automatically inferred:

 type Consent = { 
  // Whether localStorage read/writes are granted
  deviceAccess: boolean; 
  
  // Regulation that applies
  reg: "us" | "can" | "gdpr" | null;
  
  // GPP string when applicable
  gpp?: string;
  
  // TCF string when applicable
  tcf?: string;
  
  // GPP section IDs when applicable
  gppSectionIDs?: number[];
 }

This also updates the config object passed to instanciate the SDK to accept an optional consent retrieval configuration:

{
  // A "static" consent object already built by the publisher
  static?: Consent;
  // A "cmpapi" configuration indicating that consent should be gathered from CMP apis.
  cmpapi?: { 
    // An optional vendor ID from global vendor list when interpretting TCF/GPP EU consent,
    // when not passed, defaults to publisher consent.
    tcfeuVendorID?: string;
  }
}
  • Passing directly the static consent object allows the user to control device access and passing consent strings to the DCN based on their own integration with CMPs.
  • Passing "cmpapi" let the SDK automatically detect the regulation that should apply and infer device access based on the preferred CMP API for this regulation.

When absent, consent is granted for device access to preserve existing behavior. Eventually this may be changed to "cmpapi". Users should start passing consent: { static: { deviceAccess: true, reg: null } } if they want to preserve the existing behavior.

Regulation Detection & device access

Regulation detection is currently implemented by looking up the timezone of the device and the languages supported.
When no regulation is detected, device access is automatically granted.

regulation cmp api detection device access
TCF CA V1 ("can") gpp QC timezone and french browser language always granted
TCF EU V2 ("gdpr") tcfapi if available, otherwise gpp EU country timezone purpose 1 pub or vendor consent (when tcfeuVendorID is passed) when gdpr applies
US ("us") gpp (usnat + states) US time zone always granted

Signals passing to the DCN

Additionally to gating device access, the regulation and corresponding consent strings are passed to any DCN call as query strings as soon as they are available and set. This allows the DCN to degrade behavior based on applicable regulation, consent vs those APIs purpose

@zapo zapo changed the title Add initial draft for GPP/TCF cmpapi integration for consent handling in EU/CA/US Add initial draft for GPP/TCF cmpapi integration fordevice access consent handling in EU/CA/US Dec 12, 2024
@zapo zapo changed the title Add initial draft for GPP/TCF cmpapi integration fordevice access consent handling in EU/CA/US Add initial draft for GPP/TCF cmpapi integration for device access consent handling in EU/CA/US Dec 12, 2024
@zapo zapo changed the title Add initial draft for GPP/TCF cmpapi integration for device access consent handling in EU/CA/US Add GPP/TCF cmpapi integration to respect device access in EU/CA/US Dec 12, 2024
@zapo zapo force-pushed the cmp-integration branch 4 times, most recently from 4ca7f91 to d4e2bd6 Compare December 16, 2024 17:16
@zapo zapo marked this pull request as ready for review December 16, 2024 19:29
@zapo zapo force-pushed the cmp-integration branch from bed7dfe to 01ce346 Compare January 6, 2025 19:28
@zapo zapo requested a review from lemairejoel January 6, 2025 19:38
@zapo zapo force-pushed the cmp-integration branch from 01ce346 to d8b9e25 Compare January 6, 2025 21:39
@zapo zapo merged commit cfc8e08 into master Jan 7, 2025
7 checks passed
@zapo zapo deleted the cmp-integration branch January 7, 2025 19:09
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants