{% hint style="warning" %} In version 4 of the iOS SDK, this implementation was completed automatically.
The Experience Platform SDK will not automatically collect Lifecycle metrics. To continue collecting Lifecycle metrics, you must add code to your app. For more information, see Manual Lifecycle Implementation. {% endhint %}
Sessions contain information about the app's current lifecycle, such as the device information, the application install or upgrade information, the session start and pause times, the number of application launches, and additional context data that is provided by the developer through the LifecycleStart
API. Session data is persisted, so it is available across application launches.
{% tabs %} {% tab title="Android" %}
- Import the library:
import com.adobe.marketing.mobile.*;
{% endtab %}
{% tab title="iOS" %}
- Import the library:
#import "ACPLifecycle.h"
#import "ACPCore.h"
- In Swift, importing
ACPCore
also imports the necessary Lifecycle APIs:
import ACPCore
{% endtab %}
{% tab title="React Native" %}
Import the Lifecycle extension
import {ACPLifecycle} from '@adobe/react-native-acpcore';
{% endtab %}
{% tab title="Flutter" %}
Import the Lifecycle extension
import 'package:flutter_acpcore/flutter_acplifecycle.dart';
{% endtab %}
{% tab title="Cordova" %}
After creating your Cordova app and adding the Android and iOS platforms, the Lifecycle extension for Cordova can be added with this command:
cordova plugin add https://github.com/adobe/cordova-acpcore.git
{% endtab %}
{% tab title="Unity" %}
After importing the ACPCore.unitypackage, the Lifecycle extension for Unity can be added with following code in the MainScript
using com.adobe.marketing.mobile;
{% endtab %} {% endtabs %}
{% tabs %} {% tab title="Android" %}
-
Register the Lifecycle extension:
public class TargetApp extends Application { @Override public void onCreate() { super.onCreate(); MobileCore.setApplication(this); try { Lifecycle.registerExtension(); } catch (Exception e) { //Log the exception } } }
-
In the
onResume
function, start the lifecycle data collection:@Override public void onResume() { MobileCore.setApplication(getApplication()); MobileCore.lifecycleStart(null); }
Setting the application is only necessary on activities that are entry points for your application. However, setting the application on each Activity has no negative impact and ensures that the SDK always has the necessary reference to your application. We recommend that you call
setApplication
in each of your activities. -
In the
onPause
function, pause the lifecycle data collection:@Override public void onPause() { MobileCore.lifecyclePause(); }
To ensure accurate session and crash reporting, this call must be added to every activity. {% endtab %}
{% tab title="iOS" %}
-
Register the Lifecycle extension with the SDK Core by adding the following to your app's
application:didFinishLaunchingWithOptions:
delegate method:- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // register the lifecycle extension [ACPLifecycle registerExtension]; return YES; }
-
Start Lifecycle data collection by calling
lifecycleStart:
from within the callback of theACPCore::start:
method in your app'sapplication:didFinishLaunchingWithOptions:
delegate method.If your iOS application supports background capabilities, your
application:didFinishLaunchingWithOptions:
method might be called when iOS launches your app in the background. If you do not want background launches to count towards your lifecycle metrics, thenlifecycleStart:
should only be called when the application state is not equal toUIApplicationStateBackground
.- (BOOL) application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // register the lifecycle extension [ACPLifecycle registerExtension]; const UIApplicationState appState = application.applicationState; [ACPCore start:^{ // only start lifecycle if the application is not in the background if (appState != UIApplicationStateBackground) { [ACPCore lifecycleStart:nil]; } }]; }
-
When launched, if your app is resuming from a backgrounded state, iOS might call your
applicationWillEnterForeground:
delegate method. You also need to calllifecycleStart:
, but this time you do not need all of the supporting code that you used inapplication:didFinishLaunchingWithOptions:
:- (void) applicationWillEnterForeground:(UIApplication *)application { [ACPCore lifecycleStart:nil]; }
In iOS 13 and later, for a scene-based application, use the
UISceneDelegate
'ssceneWillEnterForeground
method as follows:- (void) sceneWillEnterForeground:(UIScene *)scene { [ACPCore lifecycleStart:nil]; }
For more information on handling foregrounding applications with Scenes, refer to Apple's documentation here
-
When the app enters the background, pause Lifecycle data collection from your app's
applicationDidEnterBackground:
delegate method:- (void) applicationDidEnterBackground:(UIApplication *)application { [ACPCore lifecyclePause]; }
In iOS 13 and later, for a scene-based application, use the
UISceneDelegate
'ssceneDidEnterBackground
method as follows:- (void) sceneDidEnterBackground:(UIScene *)scene { [ACPCore lifecyclePause]; }
For more information on handling backgrounding applications with Scenes, refer to Apple's documentation here
-
Register the Lifecycle extension with the SDK Core by adding the following to your app's
application:didFinishLaunchingWithOptions:
delegate method:func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool { // register the lifecycle extension ACPLifecycle.registerExtension(); }
-
Start Lifecycle data collection by calling
lifecycleStart:
from within the callback of theACPCore::start:
method in your app'sapplication:didFinishLaunchingWithOptions:
delegate method.If your iOS application supports background capabilities, your
application:didFinishLaunchingWithOptions:
method might be called when iOS launches your app in the background. If you do not want background launches to count towards your lifecycle metrics, thenlifecycleStart:
should only be called when the application state is not equal toUIApplicationStateBackground
.func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool { // register the lifecycle extension ACPLifecycle.registerExtension(); let appState = application.applicationState; ACPCore.start { // only start lifecycle if the application is not in the background if appState != .background { ACPCore.lifecycleStart(nil) } } }
-
When launched, if your app is resuming from a backgrounded state, iOS might call your
applicationWillEnterForeground:
delegate method. You also need to calllifecycleStart:
, but this time you do not need all of the supporting code that you used inapplication:didFinishLaunchingWithOptions:
:func applicationWillEnterForeground(_ application: UIApplication) { ACPCore.lifecycleStart(nil) }
In iOS 13 and later, for a scene-based application, use the
UISceneDelegate
'ssceneWillEnterForeground
method as follows:func sceneWillEnterForeground(_ scene: UIScene) { ACPCore.lifecycleStart(nil) }
For more information on handling foregrounding applications with Scenes, refer to Apple's documentation here
-
When the app enters the background, pause Lifecycle data collection from your app's
applicationDidEnterBackground:
delegate method:func applicationDidEnterBackground(_ application: UIApplication) { ACPCore.lifecyclePause() }
In iOS 13 and later, for a scene-based application, use the
UISceneDelegate
'ssceneDidEnterBackground
method as follows:func sceneDidEnterBackground(_ scene: UIScene) { ACPCore.lifecyclePause() }
For more information on handling backgrounding applications with Scenes, refer to Apple's documentation here {% endtab %}
{% tab title="React Native" %} Registering the extension with Core:
When using React Native, registering Lifecycle with Mobile Core should be done in native code which is shown under the Android and iOS tabs.
Note: Implementing Lifecycle via JavaScript may lead to inaccurate Lifecycle metrics, therefore we recommend implementing Lifecycle in native Android and iOS code. However, these APIs are still provided in JavaScript to support flexible Lifecycle implementations.
Starting a lifecycle event:
ACPCore.lifecycleStart({"lifecycleStart": "myData"});
Pausing a lifecycle event:
ACPCore.lifecyclePause();
{% endtab %}
{% tab title="Cordova" %} When using Cordova, registering Lifecycle with Mobile Core must be done in native code which is shown under the Android and iOS tabs. {% endtab %}
{% tab title="Unity" %} Starting and Pausing a lifecycle event: Add the OnApplicationPause in the MainScript with the following code:
private void OnApplicationPause(bool pauseStatus)
{
if (pauseStatus)
{
ACPCore.LifecyclePause();
}
else
{
var cdata = new Dictionary<string, string>();
cdata.Add("launch.data", "added");
ACPCore.LifecycleStart(cdata);
}
}
{% endtab %}
{% endtabs %}
The following is a complete list of all of the metrics provided on your user's app lifecycle.
Metric | Key | Description |
---|---|---|
App ID | a.AppID | Stores the application name and version in the following format: AppName BundleVersion (app version code) .
An example of this format is MyAppName 1.1(1) . |
Device Name | a.DeviceName | Stores the device name. |
Operating System Version | a.OSVersion | Operating system name and version. |
Carrier Name | a.CarrierName |
Stores the name of the mobile service provider as provided by the device.
Important: This metric is not automatically stored in an Analytics variable. You must create a processing rule to copy this value to an Analytics variable for reporting. |
Resolution | a.Resolution | Width x Height in pixels. |
Locale | a.locale | Locale set for this device, for example, en-US. |
Metric | Key | Description |
---|---|---|
AppID | a.AppID
|
Stores the application name and version in the AppName BundleVersion (app version code) format.
An example of this format is MyAppName 1.1(1) . |
Device name | a.DeviceName
|
Stores the device name. |
Operating system version | a.OSVersion
|
Operating system name and version. |
Carrier name | a.CarrierName
|
Stores the name of the mobile service provider as provided by the devices. Important: This metric is not automatically stored in an Analytics variable. For reporting, you must create a processing rule to copy this value to an Analytics variable. |
Resolution | a.Resolution
|
Width x height, in pixels. |
Locale | a.Locale
|
Locale set for this device, for example, en-US. |
Key | Description |
---|---|
lifecycle.sessionTimeout
|
Time, in seconds, that must elapse between the time the app is launched and before the launch is considered to be a new session. This timeout also applies when your application is sent to the background and reactivated. Default value is 300 seconds (5 minutes). |