RevenueCat
Payments
Overview
RevenueCat is an In-App purchase and subscription platform for mobile apps. The RevenueCat model offers the following benefits:
- Build cross-platform In-App purchases easily.
- Manage your products and subscribers.
Integrating RevenueCat and CleverTap helps automatically send all customer subscription events from your app to CleverTap, allowing you to analyze events and monitor revenue seamlessly.
Support For Integration
This integration is managed and continuously improved by RevenueCat. The CleverTap and RevenueCat integration has undergone stringent testing to ensure seamless functionality. For any questions or issues, contact RevenueCat for support and resolution.
Prerequisites for Integration
The following are the prerequisites:
- Ensure you have access to your RevenueCat account.
- Ensure you have a CleverTap account with valid Account ID, Passcode, and Region.
Integrate RevenueCat with CleverTap
This process involves the following two major steps:
Sync CleverTap Identity to RevenueCat
To integrate CleverTap with RevenueCat, ensure both the CleverTap and RevenueCat SDKs are installed and user IDs are synchronized correctly. This ensures both platforms consistently recognize users and maintain a unified user profile.
You can synchronize the CleverTap ID with RevenueCat in the following two ways:
- Set CleverTap ID Manually: Manually set up the CleverTap ID as a RevenueCat customer attribute.
- Default Identifier: If you do not set a specific property, RevenueCat uses the App User ID as the default identifier sent to CleverTap.
Configuration for Different Platforms
To synchronize CleverTap and RevenueCat, configure the SDKs for your platform using the following code:
- Android
// Configure Purchases SDK
Purchases.configure(this, "public_sdk_key", "my_app_user_id"); //purchase SDK
// Configure CleverTap SDK
CleverTapAPI cleverTapInstance = CleverTapAPI.getInstance(getApplicationContext());
String cleverTapId = cleverTapInstance.getCleverTapId();
Map<String, String> attributes = new HashMap<>();
attributes.put("$cleverTapId", cleverTapId);
Purchases.getSharedInstance().setAttributes(attributes);
// Configure Purchases SDK
Purchases.configure(this, "public_sdk_key", "my_app_user_id")
// Configure CleverTap SDK
val cleverTapInstance = CleverTapAPI.getInstance(applicationContext)
val cleverTapId = cleverTapInstance?.cleverTapID
val attributes = mapOf("\$cleverTapId" to cleverTapId)
Purchases.getSharedInstance().setAttributes(attributes)
- iOS
// Configure Purchases SDK
[RCPurchases configureWithAPIKey:@"public_sdk_key" appUserID:@"my_app_user_id"];
// Configure CleverTap SDK
CleverTap *cleverTapInstance = [CleverTap sharedInstance];
NSString *cleverTapId = [cleverTapInstance profileGetCleverTapID];
NSDictionary *attributes = @{@"$cleverTapId": cleverTapId};
[[RCPurchases sharedPurchases] setAttributes:attributes];
// Configure Purchases SDK
Purchases.configure(withAPIKey: "public_sdk_key", appUserID: "my_app_user_id")
// Configure CleverTap SDK
if let cleverTapInstance = CleverTap.sharedInstance() {
if let cleverTapId = cleverTapInstance.profileGetCleverTapID() {
let attributes = ["$cleverTapId": cleverTapId]
Purchases.shared.setAttributes(attributes)
}
}
- Other Platforms
//Assumes using react-native-purchases and react-native-clevertap
import Purchases from 'react-native-purchases';
import CleverTap from 'clevertap-react-native';
// Configure Purchases SDK
Purchases.configure({ apiKey: "public_sdk_key", appUserID: "my_app_user_id" });
// Configure CleverTap SDK
CleverTap.profileGetCleverTapId((cleverTapId) => {
const attributes = { "$cleverTapId": cleverTapId };
Purchases.setAttributes(attributes);
});
//Assumes using purchases_flutter and clevertap_plugin
import 'package:purchases_flutter/purchases_flutter.dart';
import 'package:clevertap_plugin/clevertap_plugin.dart';
// Configure Purchases SDK
await Purchases.configure(PurchasesConfiguration("public_sdk_key")
..appUserID = "my_app_user_id");
// Configure CleverTap SDK
CleverTapPlugin.getCleverTapId().then((cleverTapId) {
final attributes = {"\$cleverTapId": cleverTapId};
Purchases.addAttributes(attributes);
});
// Configure Purchases SDK
purchases.setup("public_sdk_key", { appUserID: "my_app_user_id" });
// Configure CleverTap SDK
clevertap.profileGetCleverTapID((cleverTapId) => {
const attributes = { "$cleverTapId": cleverTapId };
purchases.setAttributes(attributes);
});
using RevenueCat;
using CleverTapSDK;
// Configure Purchases SDK
Purchases.Configure("public_sdk_key", appUserID: "my_app_user_id");
// Configure CleverTap SDK
CleverTapAPI cleverTapInstance = CleverTapAPI.GetInstance();
string cleverTapId = cleverTapInstance.GetCleverTapID();
var attributes = new Dictionary<string, string> { { "$cleverTapId", cleverTapId } };
Purchases.SharedInstance.SetAttributes(attributes);
For more information about configuring the CleverTap SDK, refer to the CleverTap SDK. For more information about configuring the RevenueCat SDK, refer to the RevenueCat SDK.
Send RevenueCat Events to CleverTap
Once the Purchases SDK and CleverTap SDK are synchronized with the same user identity, configure your mobile app or payment provider by selecting the app store and configuring the app in the RevenueCat dashboard.
- Select your project in the RevenueCat dashboard.
- Go to the Integrations section and click + New to integrate CleverTap.
- Choose CleverTap from the Marketing/Communications section.
data:image/s3,"s3://crabby-images/894f5/894f50d32892369b28a9bad3a9d034b9825657e8" alt="Integrations"
Integrations
- Enter the following CleverTap Account details:
Field | Description |
---|---|
Account ID | Locate the Project ID under Settings > Project from the CleverTap dashboard. |
Account Passcode | Locate the Passcode under Settings > Project from the CleverTap dashboard. For more information, refer to Account Passcode. |
Region | Locate Region for the API endpoint you want to select under Settings > Project. To find the API endpoint for your region, refer to API endpoints based on your data center region. |
Region Support
- By default, RevenueCat sends data through CleverTap EU data center. CleverTap customers with a regional data center configured can select their preferred region from the CleverTap Region dropdown.
- Currently, RevenueCat does not support the following regions: Indonesia (aps3) and Middle East (UAE - mec1).
- (Optional) Add your Sandbox Account ID and Sandbox Passcode from your test account.
- Enter the custom Event names for the events you want to send to CleverTap, or click Use default event names to send events with their default names. For more information about events tracked using this integration, refer to Events.
data:image/s3,"s3://crabby-images/1ed59/1ed59e8df165f0d7ad1218f4733d6e8e2a39e8ce" alt="CleverTap Integrations"
Send RevenueCat Events to CleverTap
- Select the required options from the Sales Reporting dropdown to specify how they want the revenue information to be calculated and displayed. For more information, refer to Taxes and Commissions.
data:image/s3,"s3://crabby-images/1c237/1c237d3ae96698bd2ed4bd89b54eda79e165ef8a" alt="Sales reporting"
Sales Reporting
- Click ADD INTEGRATION to complete the integration process.
FAQs
Which events are sent from RevenueCat to CleverTap?
The CleverTap integration tracks events such as Initial Purchase, Trial Started, and more. To learn about all the events that can be sent from RevenueCat to CleverTap, refer to Events.
Which JSON event types does RevenueCat deliver to CleverTap?
RevenueCat delivers JSONs to CleverTap for most event types, including Initial Purchase, Trial Started, Trial Converted, Trial Cancelled, Renewal, and more. To explore these sample events in detail, refer to Sample JSON Events.
Updated 24 days ago