Consent Management in JavaScript SDK
Configure the various consent management options in JavaScript SDK.
RudderStack’s consent management functionality lets you manage the data sent to your downstream destinations based on user consent.
With this functionality, you can:
- Seamlessly integrate with popular consent management providers like OneTrust, Ketch, and iubenda. You can also set up a custom consent management provider.
- Configure consent settings for multiple providers for your web source.
- Unlock advanced use cases like pre-consent user tracking where you can track user activity and control the SDK’s behavior before and after the user provides their consent.
You can set up your website to implement consent management depending on the following use cases:
Post-consent user tracking
- This is the most common implementation where you load the JavaScript SDK only after the user has provided consent, which is typically after the consent manager’s SDK has loaded.
- With this approach, you cannot control the SDK behavior before and after the user provides their consent.
- See the OneTrust post-consent user tracking setup for a sample implementation.
Pre-consent user tracking
- This approach is helpful in cases where you need to track some user activity and control the SDK behavior before and after the user provides their consent.
- You can choose to track users as fully anonymous, track only their sessions, or track only with
anonymousId
as the user identifier. This minimizes any data loss related to attribution, acquisition, and the overall user journey. - There is no particular restriction on the loading order of the SDKs.
- See the OneTrust pre-consent user tracking setup for a sample implementation.
The presence of consent management object in the event’s context (context.consentManagement
) helps you differentiate between the pre- and post-consent events.
RudderStack does not add any other extra property to differentiate these events.
The preConsent
object
You can use the preConsent
object while loading the JavaScript SDK to define the SDK’s cookie storage and events delivery behavior in pre-consent mode.
- Pass the consent management platform’s information in the
consentManagement
object as a load
API option. - Add the
preConsent
object, as shown:
rudderanalytics.load(WRITE_KEY, DATA_PLANE_URL, {
consentManagement: {
enabled: true,
provider: "oneTrust" / "ketch" / "custom"
},
preConsent: {
enabled: true // false by default"
storage: { // Optional
strategy: "none" / "session" / "anonymousId", // Default is "none"
},
events: { // Optional
delivery: "immediate" / "buffer", // Default is "immediate"
},
},
...
// Other load options
});
If you set preConsent.enabled
to true
, the JavaScript SDK does not load the device mode integrations.
Cookie storage strategy
The SDK stores information in the pre-consent mode based on the following cookie storage strategies:
Value | Description |
---|
none | Fully anonymous tracking where RudderStack does not store any cookies.
For this value, note that:
- Each event contains a new
anonymousId . - If automatic session tracking is enabled, each event will contain a new
sessionId . - The SDK does not persist any data from the previous API calls, that is,
userId , groupId , traits , etc. are not included in the future events.
|
session | Fully anonymous tracking where RudderStack stores only the session tracking cookie (manual or automatic), if it is active.
For this value, note that:
- Each event contains a new
anonymousId . - The SDK does not persist any data from the previous API calls, that is,
userId , groupId , traits , etc. are not included in the future events.
|
anonymousId | RudderStack persists only the anonymous ID (anonymousId ).
For this value, note that:
- If automatic session tracking is enabled, each event will contain a new
sessionId . - The SDK does not persist any data from the previous API calls, that is,
userId , groupId , traits , etc. are not included in the future events.
|
Events delivery strategy
As the SDK does not load any device mode destinations in pre-consent mode, you can control the events delivery strategy for the cloud mode destinations only.
The SDK delivers events in the pre-consent mode based on the following values:
Value | Description |
---|
immediate | RudderStack sends the events to the RudderStack backend (data plane) immediately as they occur. |
buffer | This option is applicable only if the cookie storage strategy is set to none or session . The SDK buffers the events in the local storage. You can use the consent API to decide what to do with these buffered events. |
The SDK decides the delivery for preload events (events instrumented to the SDK before it is loaded), ad-blocked page view events, and Query string API events, based on the above options (immediate
/buffer
) set in the pre-consent mode.
The consent
API
You can invoke the JavaScript SDK’s consent
API once the user consent is available. The SDK then comes out of the pre-consent mode and resumes normal functioning.
A sample implementation for a custom provider is shown below:
<script type = "text/javascript">
// consent provider callback
function ConsentManagerWrapper() { /// Pseudo name
if (window.isConsented()) { // Pseudo name
// Pass the allowed and denied category IDs for custom setup
rudderanalytics.consent({
options: {
trackConsent: true / false, // Optional; default is false
consentManagement: {
allowedConsentIds: ['<category_id_1>','<category_id_2>',.....], // Required for Custom provider
deniedConsentIds: ['<category_id_3>','<category_id_4>',.....]
}, // Required for Custom provider
storage: {
type: "cookieStorage", // Other supported values are "localStorage","sessionStorage", "memoryStorage", and "none"
entries: {
userId: {
type: "localStorage" // Other supported values are "cookieStorage","sessionStorage", "memoryStorage", and "none"
},
userTraits: {
type: "cookieStorage" // Other supported values are "localStorage","sessionStorage", "memoryStorage", and "none"
},
sessionInfo: {
type: "cookieStorage" // Other supported values are "localStorage","sessionStorage", "memoryStorage", and "none"
}
}
}, // Optional
integrations: IntegrationOpts, // Optional
discardPreConsentEvents: true / false, // Optional; default is false
sendPageEvent: true / false // Optional, default is false
}
});
}
}
</script>
The consent
API options are listed below:
Parameter | Type | Description |
---|
trackConsent | Boolean | Determines if the SDK should send a track event with the name Consent Management Interaction .
Default value: false |
consentManagement | Object | Lets you pass the user consent data in case of a custom consent management provider. The SDK requires the allowedConsentIds and deniedConsentIds fields in case of a Custom consent provider. |
storage | Object | Lets you configure the different storage-specific options like:
storage.type : Specify where the persisted data should be stored.storage.entries : Lets you define storage for specific type of persisted user data.
|
integrations | Object | Instructs the SDK to filter the integrations before the consent filtering takes effect. |
discardPreConsentEvents | Boolean | Determines if the SDK should discard all the pre-consent events buffered previously.
Default value: false |
sendPageEvent | Boolean | Determines if the SDK should send a page event.
Default value: false |
The SDK does the following once you invoke the consent
API:
- Loads the device mode integrations based on consent.
- Fetches the consent information from the consent manager.
- Stores persistent user information like
userId
, anonymousId
, traits
, etc. according to the specified storage
option. - Discards or replays the buffered pre-consent events to the destinations based on the
discardPreconsentEvents
parameter.
The SDK also sends any events received after the user gives consent to the destinations immediately.
Integrate consent managers with JavaScript SDK
Questions? Contact us by email or on
Slack