Cordova Plugin Integration Guide
This page explains how to implement the Rokt Ecommerce Cordova SDK+. The SDK+ passes user and transaction data to Rokt on configured screens so Rokt can render relevant experiences, such as offers on confirmation screens. Your Rokt account manager will provide the key and secret required to initialize the SDK+.
Work with your Rokt account manager to first implement the SDK+ in a development environment so you can thoroughly test before going live.
1. Add the Rokt SDK+ to Your Cordova AppDirect link to 1. Add the Rokt SDK+ to Your Cordova App
Install the mParticle Cordova SDK+ and the Rokt kit plugin:
cordova plugin add @mparticle/cordova-sdk
cordova plugin add @mparticle/cordova-rokt-kit
2. Initialize the Rokt SDK+Direct link to 2. Initialize the Rokt SDK+
Insert the following initialization snippet in the relevant native entry point for each platform. The mParticle SDK+ must be initialized before any other SDK+ API calls. Replace your-key and your-secret with the key and secret provided by your Rokt team.
You can find a full example in the example app.
iOSDirect link to iOS
#import "AppDelegate.h"
#import "MainViewController.h"
#import "mParticle.h"
@implementation AppDelegate
- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions
{
MParticleOptions *mParticleOptions = [MParticleOptions optionsWithKey:@"your-key"
secret:@"your-secret"];
// Specify the data environment:
// Set it to MPEnvironmentDevelopment if you are still testing your integration.
// Set it to MPEnvironmentProduction if your integration is ready for production data.
// The default is MPEnvironmentAutoDetect which attempts to detect the environment automatically.
mParticleOptions.environment = MPEnvironmentDevelopment;
// Identify the current user:
// If you do not have the user's email address, you can pass in a null value
MPIdentityApiRequest *request = [MPIdentityApiRequest requestWithEmptyUser];
// Preferred: pass the customer's raw, unhashed email address in 'email'.
// If you can only provide a SHA-256-hashed email, set it in 'other' instead of email — do not pass both.
request.email = @"j.smith@example.com";
// [request setIdentity:@"sha256 hashed email goes here" identityType:MPIdentityOther]; // only if raw email unavailable
mParticleOptions.identifyRequest = request;
mParticleOptions.onIdentifyComplete = ^(MPIdentityApiResult * _Nullable apiResult, NSError * _Nullable error) {
if (apiResult) {
// If the user is identified, set additional user attributes
[apiResult.user setUserAttribute:@"example attribute key" value:@"example attribute value"];
}
};
[[MParticle sharedInstance] startWithOptions:mParticleOptions];
self.viewController = [[MainViewController alloc] init];
return [super application:application didFinishLaunchingWithOptions:launchOptions];
}
@end
AndroidDirect link to Android
import com.mparticle.MParticle;
import com.mparticle.MParticleOptions;
public class MainActivity extends CordovaActivity
{
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
// Enable Cordova apps to be started in the background
Bundle extras = getIntent().getExtras();
if (extras != null && extras.getBoolean("cdvStartInBackground", false)) {
moveTaskToBack(true);
}
// Set by <content src="index.html" /> in config.xml
loadUrl(launchUrl);
// Identify the current user:
// If you do not have the user's email address, you can pass in a null value
IdentityApiRequest identifyRequest = IdentityApiRequest.withEmptyUser()
// Preferred: pass the customer's raw, unhashed email via .email().
// If you can only provide a SHA-256-hashed email, remove .email() and use .userIdentity(Other) instead — do not pass both.
.email("j.smith@example.com")
// .userIdentity(MParticle.IdentityType.Other, "SHA-256 hashed email") // only if raw email unavailable
// If you can only provide a SHA-256-hashed mobile number, use 'other2' instead of MobileNumber — do not pass both.
// .userIdentity(MParticle.IdentityType.Other2, "SHA-256 hashed mobile number") // only if raw mobile unavailable
.userIdentity(MParticle.IdentityType.MobileNumber, "+13125551515")
.customerId("cust_10482")
.build();
MParticleOptions options = MParticleOptions.builder(this)
.credentials(
"your-key", // The key provided by your Rokt account manager
"your-secret" // The secret provided by your Rokt account manager
)
// Specify the data environment with environment:
// Set it to Development if you are still testing your integration.
// Set it to Production if your integration is ready for production data.
// The default is AutoDetect which attempts to detect the environment automatically.
.environment(MParticle.Environment.Development)
.identify(identifyRequest)
.build();
MParticle.start(options);
}
}
When inserting the initialization snippet, you will see customizable fields for:
-
Entering your Rokt key and secret.
Set
your-keyandyour-secretto the key and secret values provided by your Rokt account manager. -
Setting your data environment.
Set
environmenttoMPEnvironmentDevelopment(iOS) orMParticle.Environment.Development(Android) while testing to route data to the Development environment, andMPEnvironmentProduction/MParticle.Environment.Productionto send live customer activity to Production. -
Identifying your user and setting attributes.
In
identifyRequest, pass the user's raw, un-hashed email. For hashed emails and other identifiers, see Supported User Identifiers. Once identified, use the callback to set additional user attributes — see User Attributes for the recommended list.noteAlways include
identifyRequestin the initialization snippet. If you don't have the user's email at initialization, omit the email assignment — the SDK+ will still initialize, and you can identify the user later via 3. Identify the User. See Error Handling for how to handle identify failures — without error handling you may see data consistency issues at scale.
3. Identify the UserDirect link to 3. Identify the User
Call the identify method with a fresh identifyRequest any time the user provides their email address after the SDK+ has initialized (for example, when they log in, create an account, or make a purchase). This ensures event data is attributed to the correct user.
Supported User IdentifiersDirect link to Supported User Identifiers
Show supported user identifiers
| Field | Type | Description |
|---|---|---|
email | string | Pass the customer's raw, unhashed email address. |
mobile | string | Pass the customer's phone number in E.164 format. |
customerid | string | Pass your internal customer/account identifier. Send on every screen for logged-in users. |
other | string | Pass a SHA-256-hashed email. Only use when the raw email cannot be provided — do not pass both email and other. (Android path only.) |
other2 | string | Pass a SHA-256-hashed mobile number. Only use when the raw mobile number cannot be provided — do not pass both mobile and other2. (Android path only.) |
emailSha256 | string | Pass a SHA-256-hashed email. Only use when the raw email cannot be provided — do not pass both email and emailSha256. (iOS path only.) |
mobileSha256 | string | Pass a SHA-256-hashed mobile number. Only use when the raw mobile number cannot be provided — do not pass both mobile and mobileSha256. (iOS path only.) |
To identify the user:
-
Create an
identifyRequestobject to contain the user's identifiers. You should integrate the user's raw, unhashed email address into theemailfield. -
To set additional user attributes, create an
identifyTaskcallback. If theidentifyRequestsucceeds, then any user attributes you set inside the callback are assigned to the identified user. -
After creating the
identifyRequestand the callback, send them to Rokt using the identify method.For example, to identify a user named Jane Smith with the email address
j.smith@example.com, mobile number+13125551515, and customer IDcust_10482, you would use:
// 1. Create the identifyRequest object
var identifyRequest = new mparticle.IdentityRequest();
// Preferred: pass the customer's raw, unhashed email address.
// If you can only provide a SHA-256-hashed email, use setUserIdentity with 'other' instead — do not pass both.
identifyRequest.setEmail('j.smith@example.com');
identifyRequest.setUserIdentity(mparticle.UserIdentityType.Other, 'SHA-256 hashed email'); // only if raw email unavailable
// If you can only provide a SHA-256-hashed mobile number, use 'Other2' instead of 'MobileNumber' — do not pass both.
// (Called 'other2' on Android and 'mobileSha256' on iOS; both use this same field.)
identifyRequest.setUserIdentity(mparticle.UserIdentityType.Other2, 'SHA-256 hashed mobile number'); // only if raw mobile unavailable
identifyRequest.setUserIdentity(mparticle.UserIdentityType.MobileNumber, '+13125551515');
identifyRequest.setCustomerId('cust_10482');
// 2. User attributes are set using the identifyTask callback
var identifyTask = {
onSuccess: function(userID) {
var user = new mparticle.User(userID);
user.setUserAttribute('firstname', 'Jane');
user.setUserAttribute('lastname', 'Smith');
},
onError: function(errorResponse) {
console.error('Identify error: ' + JSON.stringify(errorResponse));
}
};
// 3. Call the identify method, including the identifyRequest object and identifyTask
var identity = new mparticle.Identity();
identity.identify(identifyRequest, identifyTask.onSuccess);
4. Set User AttributesDirect link to 4. Set User Attributes
Set user attributes progressively as the user navigates your app, not just at checkout. The more attributes you set, the better Rokt can resolve the customer and deliver relevant offers.
var identity = new mparticle.Identity();
identity.getCurrentUser(function(userID) {
var currentUser = new mparticle.User(userID);
// Once you have successfully set the current user, you can set user attributes with:
currentUser.setUserAttribute('custom-attribute-name', 'custom-attribute-value');
// Note: all user attributes (including list attributes and tags) must have distinct names.
// Rokt recommends setting as many of the following user attributes as possible:
currentUser.setUserAttribute('firstname', 'John');
currentUser.setUserAttribute('lastname', 'Doe');
// Phone numbers can be formatted either as '1234567890', or '+1 (234) 567-8901'
currentUser.setUserAttribute('mobile', '3125551515');
currentUser.setUserAttribute('age', '33');
currentUser.setUserAttribute('gender', 'M');
currentUser.setUserAttribute('billingcity', 'Brooklyn');
currentUser.setUserAttribute('billingstate', 'NY');
currentUser.setUserAttribute('billingzipcode', '123456');
currentUser.setUserAttribute('dob', 'yyyymmdd');
currentUser.setUserAttribute('title', 'Mr');
currentUser.setUserAttribute('language', 'en');
currentUser.setUserAttribute('predictedltv', '136.23');
// You can create a user attribute to contain a list of values
currentUser.setUserAttributeArray('favorite-genres', ['documentary', 'comedy', 'romance', 'drama']);
// To remove a user attribute, call removeUserAttribute and pass in the attribute name.
// All user attributes share the same key space.
currentUser.removeUserAttribute('attribute-to-remove');
});
User AttributesDirect link to User Attributes
Set as many of the following as you can collect:
Show all user attributes
| Field | Type | Description |
|---|---|---|
firstname | string | Customer's first name. Used for personalization. |
lastname | string | Customer's last name. Used for personalization. |
mobile | string | Phone number formatted as 1112345678 or +1 (222) 345-6789. Used for identity resolution and relevance. |
age | integer | Customer's age. Alternate to dob. Used for eligibility and relevance. |
dob | string | Date of birth, yyyymmdd. Alternate to age. Used for eligibility and relevance. |
gender | string | Customer's gender. For example, M, F, Male, or Female. Used for relevance. |
title | string | Honorific. For example, Mr, Mrs, Ms. Used for personalization. |
language | string | ISO 639-1 language code associated with the purchase. Used for relevance. |
billingcity | string | Billing city. Used for relevance. |
billingstate | string | Billing state / province / region. Used for relevance and eligibility. |
billingzipcode | string | Full ZIP or postcode (US preference is ZIP+4). Used for identity resolution and relevance. |
billingaddress1 | string | Billing street address line 1. Used for identity resolution and relevance. |
billingaddress2 | string | Billing street address line 2. Used for identity resolution. |
country | string | ISO 3166-1 alpha-2 country code (e.g. US, GB, AU). Used for eligibility and relevance. |
birthyear | integer | Customer's birth year (e.g. 1990). Used for eligibility and relevance. |
newcustomer | boolean | Whether this is a first-time buyer. Used for relevance. |
customertype | string | Whether the user is authenticated (guest / logged_in). Used for relevance. |
loyaltytier | string | Partner loyalty program tier. Used for relevance and eligibility. |
loyaltyid | string | Loyalty program member ID. Used for identity resolution. |
predictedltv | decimal | Predicted total lifetime value, typically from a partner ML model. Used for relevance. |
subscriptionstatus | string | Subscription state if applicable (active, trial, churned, paused, none). Used for relevance and eligibility. |
customersegment | string | Partner internal segmentation (e.g. vip, at_risk, new, reactivated). Used for relevance. |
acquisitionchannel | string | Channel through which the customer was acquired. Used for relevance. |
All user attributes (including list attributes) must have distinct names.
5. Track Funnel EventsDirect link to 5. Track Funnel Events
Track screen views, account lifecycle events, commerce events, and custom events so Rokt can maintain identity continuity and understand where each customer is in their journey.
Screen ViewsDirect link to Screen Views
Call mparticle.logScreenEvent with the name of the screen (e.g. 'homepage', 'product detail page'). Include any additional custom attributes in the info object.
mparticle.logScreenEvent('homepage', { 'custom-attribute': 'custom-value' });
Account Lifecycle EventsDirect link to Account Lifecycle Events
Log account lifecycle events when the user signs up, logs in, or logs out so Rokt can maintain identity continuity across sessions and devices. Signup and login events accept a method attribute describing how the user signed up or logged in.
Supported lifecycle event typesDirect link to Supported lifecycle event types
Show lifecycle event types
| Lifecycle Event Type | When to trigger | Supported method values |
|---|---|---|
sign_up | New account created | email, social, guest |
login | User logs in | email, social, sso |
logout | User logs out | Not applicable. |
Example lifecycle eventsDirect link to Example lifecycle events
// Signup event
mparticle.logEvent('sign_up', mparticle.EventType.Other, { method: 'email' });
// Login event
mparticle.logEvent('login', mparticle.EventType.Other, { method: 'email' });
// Logout event
mparticle.logEvent('logout', mparticle.EventType.Other);
Commerce EventsDirect link to Commerce Events
Commerce events carry product-level details for the user's journey. Trigger a separate commerce event for each product action the customer takes.
Investing in full commerce event coverage is one of the highest-leverage things you can do during your integration. Each event tells Rokt something different about where the customer is in their journey: a product view signals exploration, an add-to-cart signals consideration, a checkout start signals purchase intent, and a completed purchase confirms conversion. With a richer signal, Rokt can personalize offers more effectively, measure placement performance accurately, and attribute conversions to the right touchpoints. Doing this work during your initial integration also avoids a retrofit later. The signal compounds over time: each event Rokt receives adds context used to sharpen personalization, improve attribution accuracy, and better resolve and segment your customer base on future visits.
Commerce events are logged with mparticle.logCommerceEvent, using a product action type that identifies the customer action (viewing a product, adding to cart, starting checkout, completing a purchase, etc.). The sections below list the supported action types and walk through assembling the event.
Product action typesDirect link to Product action types
Show all product action types
| Customer action | Product action type |
|---|---|
| Product detail page viewed | mparticle.ProductActionType.ViewDetail |
| Product clicked | mparticle.ProductActionType.Click |
| Item added to cart | mparticle.ProductActionType.AddToCart |
| Item removed from cart | mparticle.ProductActionType.RemoveFromCart |
| Item added to wishlist | mparticle.ProductActionType.AddToWishlist |
| Item removed from wishlist | mparticle.ProductActionType.RemoveFromWishlist |
| Checkout flow initiated | mparticle.ProductActionType.Checkout |
| Checkout option selected | mparticle.ProductActionType.CheckoutOption |
| Order confirmed | mparticle.ProductActionType.Purchase |
| Order refunded | mparticle.ProductActionType.Refund |
Tracking a commerce event requires three steps:
1. Define the productDirect link to 1. Define the product
Create a product object with the product's name, SKU, and price. Set additional fields as needed.
var product = mparticle.eCommerce.createProduct(
'Double Room - Econ Rate', // Name
'econ-1', // SKU
100.00, // Price
4 // Quantity
);
product.Category = 'room';
product.Brand = 'lodge-o-rama';
product.Variant = 'standard';
product.Attributes = {
'ocean-view': 'true',
'balcony': 'false'
};
2. Summarize the transactionDirect link to 2. Summarize the transaction
Create a transactionAttributes object for Purchase, Checkout, and CheckoutOption events. Include shipping and coupon code when applicable — order-level coupons belong here, not on individual products.
var transactionAttributes = {
Id: 'ORDER-12345',
Revenue: 149.99,
Tax: 12.50,
Shipping: 5.99,
Coupon: 'SUMMER20'
};
3. Log the commerce eventDirect link to 3. Log the commerce event
Call mparticle.eCommerce.logProductAction with a product action type from the table above, the product array, optional custom attributes, and the transaction attributes.
mparticle.eCommerce.logProductAction(
mparticle.ProductActionType.Purchase,
[product],
{ 'sale': 'true' },
null,
transactionAttributes
);
The same structure applies to every product action type — swap Purchase for the action that matches the customer behavior you're logging. See the Product action types table for the full list.
Custom EventsDirect link to Custom Events
Track custom events using mparticle.logEvent, passing an event name, event type, and optional custom attributes.
Supported custom event typesDirect link to Supported custom event types
Show custom event types
| Type | Use for |
|---|---|
mparticle.EventType.Navigation | User navigation flows and screen transitions within your app. |
mparticle.EventType.Location | Location-based interactions and movements. |
mparticle.EventType.Search | Search queries and search-related actions. |
mparticle.EventType.Transaction | Financial transactions and purchase-related activity. |
mparticle.EventType.UserContent | User-generated content like reviews, comments, or posts. |
mparticle.EventType.UserPreference | User settings, preferences, and customization choices. |
mparticle.EventType.Social | Social media interactions and sharing activities. |
mparticle.EventType.Other | Anything that doesn't fit the categories above. |
Example custom eventDirect link to Example custom event
mparticle.logEvent(
'Video Watched',
mparticle.EventType.Navigation,
{ 'category': 'Destination Intro', 'title': 'Paris' }
);
6. Show a PlacementDirect link to 6. Show a Placement
Call mparticle.Rokt.selectPlacements on every payment and confirmation screen you want Rokt to render content on. Include one of the following page identifiers to specify the screen type and whether it's for testing or production:
stg.rokt.conf: A confirmation screen in a staging (or testing) environment.prod.rokt.conf: A confirmation screen in a production environment.stg.rokt.payments: A payments screen in a staging (or testing) environment.prod.rokt.payments: A payments screen in a production environment.
Placement AttributesDirect link to Placement Attributes
Pass these attributes in the attributes map of selectPlacements. Always supply the most recent value — attributes passed here override any earlier setUserAttribute calls.
Show all placement attributes
| Field | Type | Description |
|---|---|---|
email | string | Customer email (unhashed). Used for identity resolution. |
firstname | string | Customer first name. Used for personalization. |
lastname | string | Customer last name. Used for personalization. |
mobile | string | Customer mobile number in E.164 format. Used for identity resolution. |
confirmationref | string | Order / confirmation reference number. Used for relevance and deduplication. |
currency | string | Transaction currency (ISO 4217, e.g. USD, GBP, AUD). Used for relevance. |
country | string | ISO 3166-1 alpha-2 country code. Used for eligibility and relevance. |
language | string | Customer's preferred language (ISO 639-1). Used for relevance. |
totalprice | decimal | Total cart value including tax and shipping. Used for relevance. |
amount | string | Cart subtotal before tax and shipping. Distinct from totalprice. Used for relevance. |
couponCode | string | Promo code applied to the order, if any. Used for relevance. |
newcustomer | boolean | Whether this is a first-time buyer. Used for relevance. |
customertype | string | guest or logged_in. Used for relevance. |
value | decimal | Customer's cumulative purchase value (e.g. "2340.00"). Used for relevance. |
subscriptionstatus | string | Subscription state if applicable (active, trial, churned, paused, none). Used for relevance and eligibility. |
customersegment | string | Partner internal segmentation (e.g. vip, at_risk, new, reactivated). Used for relevance. |
paymenttype | string | Payment method selected (credit_card, paypal, apple_pay, etc.). Used for Pay+ eligibility. |
paymentServiceProvider | string | Payment services offered on the page (apple_pay, paypal, card). Used for Pay+ eligibility. |
ccbin | string | Credit card BIN (first 6 digits). Used for relevance. |
billingname | string | Billing name. Used for identity resolution. |
billingaddress1 | string | Billing street address. Used for identity resolution and relevance. |
billingaddress2 | string | Billing apartment / unit. Used for identity resolution. |
billingcity | string | Billing city. Used for relevance. |
billingstate | string | Billing state or province. Used for relevance. |
billingzipcode | string | Billing ZIP / postcode. Used for identity resolution and relevance. |
shippingmethod | string | Shipping method selected (standard, express, next_day). Used for relevance. |
shippingname | string | Shipping name. Used for relevance. |
shippingaddress1 | string | Shipping street address. Used for relevance. |
shippingcity | string | Shipping city. Used for relevance. |
shippingstate | string | Shipping state or province. Used for relevance. |
shippingzipcode | string | Shipping ZIP or postcode. Used for relevance. |
shippingcountry | string | Shipping country (ISO 3166-1 alpha-2). Used for relevance. |
cartItems | string | JSON-serialized array of cart items. Used for relevance. |
adsExperience | string | Pass "shoppable" when deliberately targeting a Shoppable Ads experience. Used on iOS only. |
Overlay PlacementsDirect link to Overlay Placements
Overlay placements render on top of your confirmation screen in a Rokt-managed container, requiring no changes to your app's existing layout.
To insert an overlay placement, call selectPlacements once the confirmation screen loads:
var attributes = {
// Identity
'email': 'j.smith@example.com',
'firstname': 'Jenny',
'lastname': 'Smith',
'mobile': '+13125551515',
// Transaction
'confirmationref': '54321',
'currency': 'USD',
'country': 'US',
'language': 'en',
'totalprice': '149.99',
'couponCode': 'SUMMER20',
// Customer context
'newcustomer': 'false',
'customertype': 'logged_in',
'value': '2340.00',
'subscriptionstatus': 'active',
'customersegment': 'vip',
// Payment (include paymenttype and paymentServiceProvider for Pay+)
'paymenttype': 'credit_card',
'paymentServiceProvider': 'card',
'ccbin': '411112',
// Billing address
'billingaddress1': '123 Main St',
'billingcity': 'Brooklyn',
'billingstate': 'NY',
'billingzipcode': '11201',
// Shipping
'shippingmethod': 'express',
'shippingaddress1': '175 Varick St',
'shippingcity': 'New York',
'shippingstate': 'NY',
'shippingzipcode': '10014',
'shippingcountry': 'US'
};
var config = {
colorMode: mparticle.Rokt.ColorMode.LIGHT
};
mparticle.Rokt.selectPlacements(
'RoktExperience',
attributes,
config
);
Embedded PlacementsDirect link to Embedded Placements
Embedded placements render inline at a fixed position in your app that you control (for example, above the payment options on a cart screen). Both Thanks and Pay+ use embedded placements, but Pay+ must use embedded placements.
To insert an embedded placement, pass the embedded view identifier in your selectPlacements call:
var attributes = {
'email': 'j.smith@example.com',
'firstname': 'Jenny',
'lastname': 'Smith',
'billingzipcode': '90210',
'confirmationref': '54321'
};
var config = {
colorMode: mparticle.Rokt.ColorMode.LIGHT
};
mparticle.Rokt.selectPlacements(
'RoktExperience',
attributes,
config,
'RoktEmbedded1' // The embedded view identifier
);
For Pay+ placements, include paymenttype and paymentServiceProvider in the selectPlacements call on each screen. paymentServiceProvider communicates what payment methods are available on the payment screen; paymenttype communicates what method the user paid with.
Interstitial PlacementsDirect link to Interstitial Placements
Interstitial placements are rendered between the payment and confirmation screens, allowing customers to purchase additional products. Interstitial placements are used by Shoppable Ads.
Interstitial placements are supported on iOS only in the Cordova SDK+. The Android path of this plugin does not support interstitial placements. Do not invoke interstitial placement logic on Android.
To enable Shoppable Ads with Apple Pay on iOS, your native iOS project must have RoktPaymentExtension registered in AppDelegate after MParticle.start and before selectPlacements. Follow the Apple Pay iOS setup guide to create a merchant ID, configure your Xcode project, and register the payment extension.
On iOS, interstitial placements use the selectShoppableAds method exposed through the Rokt kit. The iOS native layer handles the interstitial UI; your JavaScript code triggers it and listens for the resulting events.
To implement an interstitial placement on iOS, call selectShoppableAds from your confirmation screen logic. Pass the same comprehensive attributes you use for overlay placements:
// Guard: only invoke on iOS
if (cordova.platformId === 'ios') {
var attributes = {
// Identity
'email': 'j.smith@example.com',
'firstname': 'Jenny',
'lastname': 'Smith',
'mobile': '+13125551515',
// Transaction
'confirmationref': '54321',
'currency': 'USD',
'country': 'US',
'language': 'en',
'totalprice': '149.99',
'amount': '137.50',
'couponCode': 'SUMMER20',
// Customer context
'newcustomer': 'false',
'customertype': 'logged_in',
'value': '2340.00',
// Payment
'paymenttype': 'credit_card',
'paymentServiceProvider': 'card',
'ccbin': '411112',
// Billing address
'billingaddress1': '123 Main St',
'billingcity': 'Brooklyn',
'billingstate': 'NY',
'billingzipcode': '11201',
// Shipping (required for Shoppable Ads fulfillment)
'shippingaddress1': '175 Varick St',
'shippingcity': 'New York',
'shippingstate': 'NY',
'shippingzipcode': '10014',
'shippingcountry': 'US'
};
var config = {
colorMode: mparticle.Rokt.ColorMode.LIGHT
};
mparticle.Rokt.selectPlacements(
'RoktExperience',
attributes,
config
);
}
If your app does not have shipping address details (for example, for ticket or digital goods purchases), pass billing address details instead. Rokt will provide a UI for the customer to confirm or edit their shipping address before completing the purchase.
Optional FunctionsDirect link to Optional Functions
| Function | Purpose |
|---|---|
mparticle.Rokt.close() | Auto-close overlay placements. |
Additional ConfigurationDirect link to Additional Configuration
Pass optional parameters such as a config object to customize the placement UI (e.g. dark/light mode, caching).
var config = {
colorMode: mparticle.Rokt.ColorMode.LIGHT,
cacheConfig: {
cacheDurationInSeconds: 1200,
cacheAttributes: {
'email': 'j.smith@example.com',
'orderNumber': '123'
}
}
};
mparticle.Rokt.selectPlacements(
'RoktExperience',
attributes,
config
);
If you want to update the identifier RoktExperience or embedded identifier RoktEmbedded1 with a different value, contact your Rokt account manager to ensure Rokt placements are configured consistently.
Events APIDirect link to Events API
The SDK+ provides placement lifecycle events you can subscribe to. Use the onEvent callback in your selectPlacements call to respond to load state, engagement, and failures.
mparticle.Rokt.selectPlacements(
'RoktExperience',
attributes,
config,
null,
function(event) {
// Handle placement events
if (event && event.eventType) {
console.log('Rokt event: ' + event.eventType);
}
}
);
Standard eventsDirect link to Standard events
Show all standard events
| Event | Description | Params |
|---|---|---|
| ShowLoadingIndicator | Triggered before the SDK+ calls the Rokt backend. | |
| HideLoadingIndicator | Triggered when the SDK+ receives a success or failure from the Rokt backend. | |
| PlacementInteractive | Triggered when a placement has been rendered and is interactable. | placementId: String |
| PlacementReady | Triggered when a placement is ready to display but has not rendered content yet. | placementId: String |
| OfferEngagement | Triggered when the user engages with the offer. | placementId: String |
| PositiveEngagement | Triggered when the user positively engages with the offer. | placementId: String |
| FirstPositiveEngagement | Triggered when the user positively engages with the offer for the first time. | placementId: String, fulfillmentAttributes: Object |
| OpenUrl | Triggered when the user presses a URL that is configured to be sent to the partner app. | placementId: String, url: String |
| PlacementClosed | Triggered when a placement is closed by the user. | placementId: String |
| PlacementCompleted | Triggered when the offer progression reaches the end and no more offers are available to display. Also triggered when cache is hit but the retrieved placement will not be displayed as it has previously been dismissed. | placementId: String |
| PlacementFailure | Triggered when a placement could not be displayed due to some failure or when no placements are available to show. | placementId: String (optional) |
| CartItemInstantPurchase | Triggered when the catalog item purchase is initiated by the user (iOS only). | placementId: String, cartItemId: String, catalogItemId: String, currency: String, description: String, linkedProductId: String, totalPrice: Number, quantity: Number, unitPrice: Number |
7. AppendixDirect link to 7. Appendix
Appendix A: App ConfigurationDirect link to Appendix A: App Configuration
Applications can pass configuration settings through the config object so the SDK+ uses your app's custom configuration instead of system defaults.
ColorMode objectDirect link to ColorMode object
| Value | Description |
|---|---|
LIGHT | Application is in Light Mode |
DARK | Application is in Dark Mode |
SYSTEM | Application defaults to System Color Mode |
var config = {
colorMode: mparticle.Rokt.ColorMode.LIGHT
};
mparticle.Rokt.selectPlacements(
'RoktExperience',
attributes,
config
);
CacheConfig objectDirect link to CacheConfig object
| Parameter | Description |
|---|---|
cacheDurationInSeconds | Optional duration in seconds for which the Rokt SDK+ should cache the experience. Maximum allowed value is 90 minutes; default is 90 minutes if not provided or invalid. |
cacheAttributes | Optional attributes to be used as cache key. If null, all attributes sent in selectPlacements will be used as the cache key. |
// Cache the experience for 1200 seconds, using email and orderNumber as the cache key.
var config = {
cacheConfig: {
cacheDurationInSeconds: 1200,
cacheAttributes: {
'email': 'j.smith@example.com',
'orderNumber': '123'
}
}
};
mparticle.Rokt.selectPlacements(
'RoktExperience',
attributes,
config
);
EdgeToEdgeDisplay (Android only)Direct link to EdgeToEdgeDisplay (Android only)
Controls whether the Rokt overlay respects Android's edge-to-edge display mode. This configuration applies to the Android path only; iOS does not use this flag.
| Value | Description |
|---|---|
true (default) | Application supports edge-to-edge display mode |
false | Application does not support edge-to-edge display mode |
The Cordova SDK+ does not currently expose EdgeToEdgeDisplay as a JavaScript config option. If your Android app opts out of edge-to-edge display and the overlay renders incorrectly, configure it in your native Android code:
import com.mparticle.rokt.RoktConfig
val roktConfig = RoktConfig.Builder()
.edgeToEdgeDisplay(false) // set to false if your app does not use edge-to-edge
.build()
Pass roktConfig to selectPlacements in your native Android layer, or raise this with your Rokt account manager if you need Cordova-level support.
Appendix B: Native UI ComponentsDirect link to Appendix B: Native UI Components
The Cordova SDK+ uses native Rokt UI components rendered by the underlying iOS and Android SDK+s. There is no Cordova-specific declarative UI component (equivalent to Jetpack Compose or SwiftUI). The placement UI is managed entirely by the native layer and surfaced through the selectPlacements API.
Appendix C: Error HandlingDirect link to Appendix C: Error Handling
The IDSync API is intended to be central to your app's state and is designed to be fast and highly-available. Similar to how your app may prevent users from logging in, logging out, or modifying their state without an internet connection — treat these APIs as gating operations to maintain a consistent user state. The SDK+ will not retry API calls automatically, but provides callback APIs so you can do so according to your business logic.
If you do not implement error handling, you may see data consistency issues at scale.
The Cordova SDK+'s mparticle.Identity.identify() callback pattern surfaces errors through the onError handler. Inspect the errorResponse object to determine the appropriate action:
var identifyTask = {
onSuccess: function(userID) {
// IDSync succeeded — proceed with the identified user
console.log('Identify success, userID: ' + userID);
},
onError: function(errorResponse) {
if (errorResponse && errorResponse.httpCode !== undefined) {
if (errorResponse.httpCode === -1) {
// Device is likely offline (maps to UNKNOWN_ERROR on Android,
// MPIdentityErrorResponseCodeClientNoConnection on iOS) — retry the request
} else if (errorResponse.httpCode === 429) {
// Throttled — retry with exponential backoff
} else if (errorResponse.httpCode >= 500) {
// Server-side error — check the mParticle status page
} else {
// Inspect errorResponse for implementation issues (e.g. 400 invalid request, 401 auth error)
console.error('Identity error: ' + JSON.stringify(errorResponse));
}
}
}
};
var identity = new mparticle.Identity();
identity.identify(identifyRequest, identifyTask.onSuccess);
iOS error codesDirect link to iOS error codes
On iOS, the native SDK+ maps failures to MPIdentityErrorResponseCode values. The Cordova bridge surfaces these as the httpCode in the JavaScript error response. Key codes to handle:
| Code | Meaning | Action |
|---|---|---|
MPIdentityErrorResponseCodeClientNoConnection | Device offline or no network | Retry the request |
MPIdentityErrorResponseCodeClientSideTimeout | TCP connection timed out | Retry the request |
MPIdentityErrorResponseCodeRequestInProgress | Another IDSync request already in flight | Inspect implementation; retry if infrequent |
MPIdentityErrorResponseCodeRetry | SDK+-level retry signal | Retry the request |
429 (HTTP) | Rate-limited by mParticle servers | Retry with exponential backoff |
400 (HTTP) | Invalid request body | Inspect errorResponse — typically an implementation issue |
401 (HTTP) | Authentication error | Verify your API key |
Android error codesDirect link to Android error codes
On Android, the native SDK+ returns IdentityApi.UNKNOWN_ERROR for client-side failures (device offline, client-side timeout, invalid requests). A 429 response maps to IdentityApi.THROTTLE_ERROR. Both signal the appropriate retry strategy:
UNKNOWN_ERROR(device offline or client-side issue): retry the request once connectivity is restored.THROTTLE_ERROR/ 429: retry with exponential backoff. This can indicate a user "hotkey" or a higher-than-expected IDSync volume — inspect your implementation if it occurs frequently.
Appendix D: Passing Session ID from Web to NativeDirect link to Appendix D: Passing Session ID from Web to Native
When a user journey spans both web and native platforms, you can maintain a consistent Rokt session by passing the session ID from the Web SDK+ to the Cordova SDK+. This is useful for hybrid flows where users complete an action in a WebView (such as a payment page) and return to the native app for confirmation.
Getting the session ID from Web SDK+Direct link to Getting the session ID from Web SDK+
After calling selectPlacements, the session ID is available on the selection context:
const selection = await launcher.selectPlacements({
identifier: "checkout",
attributes: {
email: "user@example.com",
// ... other attributes
}
});
const sessionId = await selection.context.sessionId;
Passing to native app via deep linkDirect link to Passing to native app via deep link
Pass the session ID to your native app using a deep link:
const deepLink = `myapp://confirmation?sessionId=${encodeURIComponent(sessionId)}`;
window.location.href = deepLink;
Setting the session IDDirect link to Setting the session ID
Extract the session ID from the deep link and pass it to the mParticle SDK+ before calling selectPlacements.
// Extract the sessionId from your deep link handler and set it before selectPlacements
var sessionId = getSessionIdFromDeepLink(); // Your deep link parsing logic
if (sessionId) {
mparticle.Rokt.setSessionId(sessionId);
}
// Then proceed with selectPlacements
mparticle.Rokt.selectPlacements('RoktExperience', attributes, config);
NotesDirect link to Notes
- Call
setSessionIdbeforeselectPlacementsto ensure the session is used. - Empty strings are ignored and will not update the session.
- Always URL-encode the session ID when passing as a query parameter.
8. Test Your IntegrationDirect link to 8. Test Your Integration
To confirm the SDK+ initializes and events log correctly:
- Enable verbose SDK+ logging before initialization so you can see what's being sent.
- Build and run your app against a development key with the environment set to Development on both platforms.
- Trigger
selectPlacementson the screen where the placement should render and confirm the placement loads. - Verify events appear in your mParticle workspace's Live Stream, and confirm the
identifyRequestcall succeeds.
iOS verbose loggingDirect link to iOS verbose logging
[MParticle sharedInstance].logLevel = MPILogLevelVerbose;
Android verbose loggingDirect link to Android verbose logging
MParticleOptions options = MParticleOptions.builder(this)
.credentials("your-key", "your-secret")
.environment(MParticle.Environment.Development)
.logLevel(MParticle.LogLevel.VERBOSE)
.build();
TroubleshootingDirect link to Troubleshooting
If the placement doesn't render or events don't appear, check the native device logs (Xcode console for iOS, Android Logcat for Android) for Rokt SDK+ errors. Common issues:
Initialization errorsDirect link to Initialization errors
- Confirm the key and secret match the values from your Rokt account manager on both iOS (
your-key/your-secretinoptionsWithKey:secret:) and Android (.credentials("your-key", "your-secret")). - Confirm
MParticle.start(Android) and[[MParticle sharedInstance] startWithOptions:options](iOS) run before anyselectPlacementsorlogEventcall.
Identity errorsDirect link to Identity errors
If the identify callback fires with an error, see Error Handling for the error codes and retry guidance. Without error handling you may see data consistency issues at scale.
Placement not renderingDirect link to Placement not rendering
- Confirm the placement
identifier(e.g.RoktExperience) matches what your Rokt account manager configured. - For embedded placements, confirm the embedded view identifier (e.g.
RoktEmbedded1) matches the layout configuration. - Check that the attributes map contains at least
email,firstname,lastname,billingzipcode, andconfirmationref.