React Native
Initialization
In order to create ease for partners, we have divided the SDK into multiple modules. Each module represents a specific
app niche that partners can use based on their app category. For this step, we will only focus on the core
sdk
In order to use the SDK, Core is mandatory to include as it contains the elements regarding the basic app navigation and workflow including nudges. Moreover, all the modules require the core to be integrated in order to successfully log the events.
The easiest way to integrate Causal Foundry React Native (Android) SDK in your project is using an NPM package. Add
dependencies of react-native SDK in the dependencies
section of your package.json
of your project and Android
Lifecycle Components in the app/build.gradle file.
for
version_number
please head to npm package.
After including the above, Open terminal/shell and go to your project directory, and run:
if you are using expo to build your react-native application, Please follow the instructions on the expo guidelines to integrate native modules. As Causal Foundry react native SDK uses android native modules to utilise OS level APIs to ensure optimal results.
As SDK requires app events to auto manage the logging of user sessions you also need to include android lifecycle dependency in your android app/build.gradle file.
If you are using expo for your React Native application then you need to move to bare workflow by expo to integrate the SDK as the Causal Foundry SDK uses android native modules to utilise OS level APIs to ensure optimal results. You DO NOT need to eject from expo just for the Causal Foundry SDK. If you are using React Native CLI, you can skip to here the following steps
Steps for Expo
To make use of Causal Foundry SDK and continue with the same developer experience of Expo Go, you can migrate to using development builds. Development builds are like your own personal version of Expo Go — they include the native runtime that powers your app, and you control what is included in that native runtime by adding or removing packages in your package.json. Development builds allow you to continue to build your app in JavaScript while taking advantage of the full ecosystem of native packages available for Expo and React Native projects.
Open terminal window, go to your apps directory, and run the prebuild command.
Using the run commands will initially prebuild your project to generate all of the native code within your project directory. If you manually modify the android or ios directory, you won't be able to safely re-run npx expo prebuild, this is known as the bare workflow.
Your app can still run in Expo Go, however, any custom native code won't be accessible if it's not already
present in the Expo Go app. After creating the prebuild, you need to update your scripts
for start
in
package.json
and remove --dev-client
if it is already added, update as:
In some cases you need to reconfigure your Expo modules after creating the prebuild which creates android and iOS folders in your project. To reconfigure expo modules run the following command in your project directory:
Once you have the setup ready, you can create development builds for your android and iOS applications as:
or you can create local development server as well:
This will generate the QR code for you that you can scan in Expo Go or by camera app in iOS to download builds.
SDK Initialization for Android
After following the above, you can open /android
folder in android studio and continue with SDK initialization as
below.
Lifecycle components are required, if you already have them in your project you may skip them. To add the dependency, open your android folder in Android Studio and open the app-level build.gradle file and in your dependencies add the following:
Create an Application class in your project and include LifecycleEventObserver Components. Initialize Android SDK with your SDK Token from onCreate callback of your Application class as shown below.
public class MainApplication extends Application implements ReactApplication, LifecycleEventObserver {
@Override
public void onCreate() {
super.onCreate();
// to observe Application lifecycle events
ProcessLifecycleOwner.get().getLifecycle().addObserver(this);
}
/*
In onStateChanged() function include the following function to auto-track events related to app and activity lifecycle.
*/
@Override
public void onStateChanged(@NonNull LifecycleOwner source, @NonNull Lifecycle.Event event) {
CfLogCore.CfSDKInit(this, event);
}
Causal Foundry Android SDK requires an SDK key in order to log events. To do so, you need to create an SDK key from the
Causal Foundry Platform and pass it to the SDK using the app's Manifest file as meta-data
like below:
<meta-data android:name="ai.causalfoundry.android.sdk.APPLICATION_KEY"
android:value="<SDK_KEY_HERE>"/>
Causal Foundry Android SDK also allows you to update track events after the user’s usage session is over. SDK sends the events whenever the app goes into the background. This helps in not overloading the user’s phone while in use. SDK handles the events even in offline mode and ensures that they get uploaded to the portal whenever the user connects to the internet. SDK also auto logs the App Open, close, and background events so, you don't have to implement those.
Don't forget to include android:name=".MyApplication"
in your manifest's application tag.
SDK Initialization for iOS
For ios initialization, you need to have a mac and Xcode installed and min deployment target as ios 13.0.
From your React Native project, head to /ios
folder and run
this will install all the necessary pods for your including the Causal Foundry SDk pods too.
once the Pods are successfully installed, head to your info.plist file and add the following keys for
the Permitted background task scheduler identifiers
ai.causalfoundry.ingestAppEvents
ai.causalfoundry.fetchNudges
OR
<key>BGTaskSchedulerPermittedIdentifiers</key>
<array>
<string>ai.causalfoundry.ingestAppEvents</string>
<string>ai.causalfoundry.fetchNudges</string>
</array>
After adding the values in info.plist, head to the app Target project > Signing & Capabilities
> Background Modes
and select the following 2:
- Background fetch
- Background processing
Once the background tasks are selected, create a new swift class named CFSDK
, when creating a new swift class you will
be prompted to also create a Bridging-Header file, allow that as well and inside you bridging header class, add the
following header:
In yourCFSDK
swift class, add the following init method:
import Foundation
import CausalFoundrySDKCore
@objc(CFSDK)
class CFSDK: NSObject {
@objc
func initCFSDK(){
CausalFoundry.shared.configure()
CFLogBuilder()
.setUsageForReactNative()
.allowAnonymousUsers()
.setSdkKey(sdkKey: "<SDK_KEY_FROM_CF_PLATFORM>")
.disableAutoPageTrack()
.build()
print("CF SDK init")
}
}
Once the above is added, head to your AppDelegate.mm
for initialization of the above function.
#import "<AppName>-Swift.h"
Other imports (Not required for all apps)
#import "AppDelegate.h"
#import <ReactNativeNavigation/ReactNativeNavigation.h>
#import <React/RCTBridge.h>
#import <React/RCTBundleURLProvider.h>
#import <React/RCTUtils.h>
// Call the below inside didFinishLaunchingWithOptions inside AppDelegate
CFSDK *cfSDK = [[CFSDK alloc] init];
[cfSDK initCFSDK];
Now try build your project, CF SDK should be initialized and ready to use.
Note that since we are using BGTaskScheduler for ios SDK, the events will not be sent exactly after the app the closed but will be sent at a later time on the availability of the resources by the OS.
Additional steps for Expo
Ejecting to bare workflow comes with a couple of additional steps dus to multiple architectural differences.
Node Modules in Dependencies | Native Event Emitter Error
After ejecting from Expo, head to your node_modules > @causalfoundry > [SDK directory]
and delete
the node_modules inside that directory. By default the node_modules of the project should be used to
overcome any dependency mismatch issues.
Failed resolution of: Lorg/koin/dsl/ModuleKt; | Koin Version Mismatch
As both Expo and CF Android ASK uses Koin, you might encounter koin version mismatch error on android
devices (depending on the version of the Expo you are using), to deal with such please downgrade the version
of koin in your expo gradle file implementation "io.insert-koin:koin***
to 3.1.2
, you might also need to
add koin core, depending on the other dependencies you use with expo, as bare workflow might not include the
core in some instances but for most cases it is not required as all.
Causal Foundry SDK automatically starts tracking user data (e.g., Upload/download speed, OS
version, device IDs) and engagement with the basic setup above. This data can be stored on the
device and uploaded in batches to reduce network and power usage, and to increase the likelihood of
successful uploads while you can also upload the events as soon as they happen. The upload is done
when the user device session ends. SDK also starts tracking user sessions with this basic setup.
Each event can further be understood in the context of its attributes which includes details like time, upload/download speed, device details, locale, online/offline usage, screen time, interactions, and so on. This enables you to gain in-depth insights into user interactions across your app. You can also leverage this data to segment users, personalize messages and configure campaign targeting.