Send your event data from RudderStack to CleverTap.
CleverTap is a popular customer engagement and retention platform. Its in-app analytics and marketing capabilities allow you to get real-time insights into your customers and build valuable, long-term relationships with them. With CleverTap, you can easily gain insights into your users’ actions and how they are using your product. You can also segment users based on their behavior and run targeted campaigns to boost user engagement and retention metrics.
Find the open source transformer code for this destination in the GitHub repository.
Getting started
RudderStack supports sending event data to CleverTap via the following connection modes:
Connection Mode
Web
Mobile
Server
Device mode
Supported
Supported
-
Cloud mode
Supported
Supported
Supported
In a web device mode integration, that is, using our JavaScript SDK as a source, the CleverTap native SDK is loaded from thehttps://d2r1yp2w7bby2u.cloudfront.net domain. Based on your website’s content security policy, you may need to allowlist this domain to load the CleverTap SDK.
Once you have confirmed that the platform supports sending events to CleverTap, perform the steps below:
To configure CleverTap as a destination, you will need to configure the following settings:
Account ID: Your account ID is a unique ID generated for your account. It can be found in your account Settings as your Project ID.
Passcode: Your account passcode is a unique code generated for your account. It can be found in the Settings as Passcode.
Enable track for anonymous user: Enable this option to track anonymous users in CleverTap.
Use CleverTap ObjectId for Mapping: Enable this option to use both CleverTap objectId along with identity for mapping events from RudderStack to CleverTap.
Region: Server Only: This is your dedicated CleverTap region.
Use Native SDK to send Events: Enable this option if you want to send events using device mode.
All server-side destination requests require either an anonymousId or a userId in the payload.
Adding device mode integration
To add CleverTap to your Android project and enable functionalities like push notifications, follow these steps:
Open your project level build.gradle file, and add the following:
Ensure that android.useAndroidX is set to true in your gradle.properties file.
Add the following under the dependencies section:
// ruddder core sdk
implementation'com.rudderstack.android.sdk:core:1.+'// rudder-clevertap integration
implementation'com.rudderstack.android.integration:clevertap:1.+'// clevertap native sdk
implementation'com.clevertap.android:clevertap-android-sdk:4.+'// if you don't have Gson included already
implementation'com.google.code.gson:gson:2.8.6'
Initialize the RudderStack SDK in the Application class’s onCreate() method as shown:
Configuring push notifications and in-app messages
Follow these steps to configure CleverTap push notifications for your desired platform.
Register push notifications for Android devices on your CleverTap dashboard either by uploading your FCM credentials or any other supported credentials by navigating to Settings - Channels - Mobile Push - Android.
Add the following dependency in your project level build.gradle file inside the buildscript:
Add the following dependencies and plugin to your app level build.gradle file:
dependencies{// for push notifications
implementation'com.clevertap.android:clevertap-android-sdk:4.0.0'implementation'com.google.firebase:firebase-messaging:20.2.4'}applyplugin:'com.google.gms.google-services'
Place the google-services.json downloaded from the Firebase console into the root folder of your app.
Add your CLEVERTAP_ACCOUNT_ID , CLEVERTAP_TOKEN & FcmMessageListenerService to the application tag of your app’s AndroidManifest.xml:
Create a notification channel anywhere in your application using the following block of code. You can then use this channel Id while creating any campaign on your CleverTap Dashboard.
For push notifications and In-app messages to function correctly, CleverTap needs to know the Application status as early as possible. You can either set the android:name in your AndroidManifest.xml tag to com.clevertap.android.sdk.Application. Or, if you have a custom Application class, call ActivityLifecycleCallback.register(this); before super.onCreate() in your Application class.
Open the android folder of your React Native app and complete the steps in the Android tab of this section.
Open the ios folder of your React Native app and complete the steps in the iOS tab of this section.
Using CleverTap objectId and identity for mapping (cloud mode only)
CleverTap uniquely identifies each user with two main identifiers, namely objectId and identity. When the Use CleverTap ObjectId for Mapping option is enabled in the dashboard, both objectId and identity are used for mapping.
When the Use CleverTap ObjectId for Mapping setting is disabled in the dashboard, RudderStack expects the the following mapping for identifying users and tracking events (track/page/screen):
RudderStack
CleverTap
userId or anonymousId
identity
When the Use CleverTap ObjectId for Mapping setting is enabled in the dashboard, the following mapping is expected:
For identify events:
RudderStack
RudderStack
CleverTap
CleverTap
anonymousId present?
userId present?
objectId
identity
Yes
Yes
anonymousId
userId
Yes
No
anonymousId
-
No
Yes
CleverTap-generated UUID
userId
For track events:
RudderStack
RudderStack
CleverTap
CleverTap
anonymousId present?
userId present?
Tracking with
Value
Yes
Yes
objectId
anonymousId
Yes
No
objectId
anonymousId
No
Yes
identity
userId
Why use CleverTap objectId for mapping?
When you track an unidentified user in CleverTap, a user profile is created with minimal details, along with the details of the user’s activity. When the same user is then identified with a userId without the Use CleverTap ObjectId for Mapping option enabled, RudderStack creates another profile for the user with the identifier userId (in case of RudderStack) which maps to identity (in case of CleverTap).
One way to solve this problem is to track users only in cases where a userId is present. To do so, you can disable the Enable tracking for anonymous users option in the RudderStack dashboard. Alternatively, you can enable the Use CleverTap ObjectId for Mapping option in the dashboard which allows you to track the anonymous users and when they are later identified, merge their anonymousId with their userId.
Device token upload using cloud mode
This section is applicable for the Android and iOS sources when sending events via cloud mode.
When the device token is present in context.device.token in identify calls, RudderStack will use the CleverTap Device Token Upload API to upload the device token for the identified user. For Android, RudderStack sets the token type as fcm. For iOS, it is set as apns.
To use this feature you should have enabled the Use CleverTap ObjectId for Mapping option in the dashboard, as RudderStack needs the objectId to upload the device token.
Page
The page call allows you to record information whenever a user sees a web page, along with its associated properties.
When you send a page event , RudderStack sends that event to CleverTap as a “Web Page Viewed Page Name event.
CleverTap does not support nested objects or arrays for custom attributes in the page events. Hence, RudderStack converts the nested objects or arrays into strings before sending them to CleverTap.
Screen
The screen method allows you to record whenever a user sees the mobile screen, along with any associated optional properties. This call is similar to the page call, but is exclusive to your mobile device.
A sample screen call looks like the following code snippet:
In the above snippet, RudderStack captures all information related to the screen being viewed, along with any additional info associated with that screen view event. In CleverTap, the above screen call will be shown as - “Screen Viewed: Sample Screen Name “ along with the properties.
CleverTap does not support nested objects or arrays for custom attributes in the screen events. Hence, RudderStack converts the nested objects or arrays into strings before sending them to CleverTap.
Track
The track call allows you to capture any action that the user might perform, along with the properties associated with that action. Each action is considered to be an event. It is similar to screen event, and the user is by default associated with userId or anonymousId.
In the above snippet, RudderStack captures the information related to the Checked Out event, along with any additional info about that event - in this case the details of the Checked out event.
To set a specific value to the screen or track type event, you need to pass the event related property in the properties field.
CleverTap does not support nested objects or arrays for custom attributes in the track events. Hence, RudderStack converts the nested objects or arrays into strings before sending them to CleverTap.
Order Completed
When you track an event with the name Order Completed using the using the RudderStack Ecommerce Events tracking, RudderStack maps that event to CleverTap’s Charged event.
A number of RudderStack’s specific fields map to CleverTap’s standard Charged event fields
RudderStack
CleverTap
checkout_id
Charged ID
revenue
Amount
products
Items
A sample Order Completed event looks like the following:
The Order Completed ecommerce event is a free-flowing event. If you are setting extra fields, for example: discount, coupon, currency, etc., these will be automatically set to Charged event properties.
Identify
The identify call lets you associate a user with their actions and capture relevant traits about them. This information includes unique userid as well as any optional information such as name, email, etc.
Passing one of userId or email is required for identify calls to CleverTap.
A number of RudderStack’s special traits map to CleverTap’s standard user profile fields, as shown in the table below. You will be required to pass the key on the left into RudderStack and RudderStack will transform it to the key on the right before sending to CleverTap.
RudderStack
CleverTap
name
Name
birthday
DOB
avatar
Photo
gender
Gender
phone
Phone
email
Email
employed
Employed
education
Education
married
Married
customerType
Customer Type
All other traits will be sent to CleverTap as custom attributes.
A sample identify call looks like the following:
rudderanalytics.identify("userid",{name:"Name Surname",email:"name@website.com",phone:"phone",birthday:"birthday",gender:"M",avatar:"link to image",title:"Owner",organization:"Company",city:"Tokyo",region:"ABC",country:"JP",zip:"100-0001",Flagged:false,Residence:"Shibuya",MSG-email:false});
In the above snippet, RudderStack captures relevant information about the user such as the email and phone, as well as the associated traits of that user.
If a user already exists, the new values will be updated for that user. RudderStack automatically maps the userId (or anoymousId) to CleverTap user’s identity.
CleverTap does not support nested objects or arrays for custom attributes in the identify events. Hence, RudderStack converts the nested objects or arrays into strings before sending them to CleverTap.
Profile properties MSG-email, MSG-push, MSG-sms and MSG-whatsapp are used to set the Do-Not-Disturb status for the user. Unless these are explicitly set to false, they are always true.
Example: To disable push notifications for a user, set MSG-push to false
Privacy options
When loading the RudderStack SDK, you can set the following options in the CLEVERTAP integrations object:
optOut
optional
boolean
Set to true if the user opts out of sharing their data. Default is false.
useIP
optional
boolean
Set to true if the user agrees to share their IP data. Default is false.
CleverTap does a reverse lookup on the IP of the incoming request on the back end to map the location of the user. Under GDPR laws, user consent is required to initiate this lookup. Use the useIP flag in the web SDK to provide that consent.
If useIP is set to true, the city/country information will populate on the Profile page of the CleverTap dashboard. If set to false, then this data won’t be populated, and the city/country information will be shown as Unknown, Unknown.
This site uses cookies to improve your experience while you navigate through the website. Out of
these
cookies, the cookies that are categorized as necessary are stored on your browser as they are as
essential
for the working of basic functionalities of the website. We also use third-party cookies that
help
us
analyze and understand how you use this website. These cookies will be stored in your browser
only
with
your
consent. You also have the option to opt-out of these cookies. But opting out of some of these
cookies
may
have an effect on your browsing experience.
Necessary
Always Enabled
Necessary cookies are absolutely essential for the website to function properly. This
category only includes cookies that ensures basic functionalities and security
features of the website. These cookies do not store any personal information.
This site uses cookies to improve your experience. If you want to
learn more about cookies and why we use them, visit our cookie
policy. We'll assume you're ok with this, but you can opt-out if you wish Cookie Settings.