Configuration
Full configuration reference for the React Native SDK
This page provides an overview of all configuration parameters for the SDK. In addition to the universal parameters, there are Android-specific and iOS-specific parameters.
Refer to Initialize the SDK for instructions.
Configuration parameters
The following parameters are specified in an Configuration
object. Refer to src/Configuration.ts for the complete interface definition.
-
projectToken
(required)- Your project token. You can find this in the Engagement web app under
Project settings
>Access management
>API
.
- Your project token. You can find this in the Engagement web app under
-
authorizationToken
(required)- Your Engagement API key.
- The token must be an Engagement public key. See Mobile SDKs API Access Management for details.
- For more information, refer to Engagement API documentation.
-
baseUrl
- Your API base URL which can be found in the Engagement web app under
Project settings
>Access management
>API
. - Default value
https://api.exponea.com
. - If you have custom base URL, you must set this property.
- Your API base URL which can be found in the Engagement web app under
-
projectMapping
- If you need to track some events to a different Engagement project, you can define a mapping between event types and Engagement projects.
- An event is always tracked to the default project and any projects it is mapped to.
- Example:
projectMapping: { [EventType.BANNER]: [ { projectToken: 'other-project-token', authorizationToken: 'other-auth-token', }, ], }
-
defaultProperties
- A list of properties to include in all tracking events.
- You can change these properties at runtime by calling
Exponea.setDefaultProperties()
.
-
allowDefaultCustomerProperties
- Flag to apply the
defaultProperties
list toidentifyCustomer
tracking events. - Default value:
true
- Flag to apply the
-
automaticSessionTracking
- Flag to control the automatic tracking of
session_start
andsession_end
events. - Default value:
true
- Flag to control the automatic tracking of
-
sessionTimeout
- The session is the actual time spent in the app. It starts when the app is launched and ends when the app goes into the background.
- When the application goes into the background, the SDK doesn't track the end of the session right away but waits a bit for the user to come back before doing so. You can configure the timeout by setting this property.
- Read more about tracking sessions.
-
pushTokenTrackingFrequency
- Indicates the frequency with which the SDK should track the push notification token to Engagement.
- Default value:
ON_TOKEN_CHANGE
- Possible values:
ON_TOKEN_CHANGE
- tracks push token if it differs from a previously tracked oneEVERY_LAUNCH
- always tracks push tokenDAILY
- tracks push token once per day
-
flushMaxRetries
- Controls how many times the SDK should attempt to flush an event before aborting. Useful for example in case the API is down or some other temporary error happens.
- The SDK will consider the data to be flushed if this number is exceeded and delete the data from the queue.
- Default value:
10
-
advancedAuthEnabled
- If set, advanced authorization is used for communication with the Engagement APIs listed in Customer token authorization.
- Refer to the authorization documentation for details.
-
inAppContentBlockPlaceholdersAutoLoad
- Automatically load the contents of in-app content blocks assigned to these Placeholder IDs.
-
android
AndroidConfiguration
object containing Android-specific configuration parameters.
-
ios
IOSConfiguration
object containing iOS-specific configuration parameters.
Android-specific configuration parameters
The following parameters are specified in an AndroidConfiguration
object. Refer to src/Configuration.ts for the complete interface definition.
-
automaticPushNotifications
- By default, the SDK will set up a Firebase service and try to process push notifications sent from the Engagement platform automatically. You can opt out by setting this to
false
. - Default value:
true
- By default, the SDK will set up a Firebase service and try to process push notifications sent from the Engagement platform automatically. You can opt out by setting this to
-
pushIcon
- Android resource ID of the icon to be used for push notifications.
-
pushIconResourceName
- Android resource name of the icon to be used for push notifications. For example, if file
push_icon.png
is placed in your drawable of mipmap resources folder, use the filename without extension as a value.
- Android resource name of the icon to be used for push notifications. For example, if file
-
pushAccentColor
- Accent color of push notification icon and buttons, specified as Color ARGB integer.
-
pushAccentColorRGBA
- Accent color of push notification icon and buttons, specified by RGBA channels separated by comma.
- For example, to use the color blue, the string
"0, 0, 255, 255"
should be entered.
-
pushAccentColorName
- Accent color of push notification icon and buttons, specified by resource name.
- Any color defined in R class can be used.
- For example, if you defined your color as a resource
<color name="push_accent_color">#0000ff</color>
, usepush_accent_color
as a value for this parameter.
-
pushChannelName
- Name of the channel to be created for the push notifications.
- Only available for API level 26+. Refer to https://developer.android.com/training/notify-user/channels for details.
-
pushChannelDescription
- Description of the channel to be created for the push notifications.
- Only available for API level 26+. Refer to https://developer.android.com/training/notify-user/channels for details.
-
pushChannelId
- Channel ID for push notifications.
- Only available for API level 26+. Refer to https://developer.android.com/training/notify-user/channels for details.
-
pushNotificationImportance
- Notification importance for the notification channel.
- Only available for API level 26+. Refer to https://developer.android.com/training/notify-user/channels for details.
-
httpLoggingLevel
- Level of HTTP request/response logging.
iOS-specific configuration parameters
The following parameters are specified in an IOSConfiguration
object. Refer to src/Configuration.ts for the complete interface definition.
-
requirePushAuthorization
- The SDK can check push notification authorization status (Apple documentation) and only track the push token if the user is authorized to receive push notifications.
- When disabled, the SDK will automatically register for push notifications on app start and track the token to Engagement so your app can receive silent push notifications.
- When enabled, the SDK will automatically register for push notifications if the app is authorized to show push notifications to the user.
- Unless you're only using silent notifications, keep the default value
true
.
-
appGroup
- App group used for communication between the main app and notification extensions. This is a required field for rich push notification setup.
Updated 26 days ago