Refiner Android SDK supports Android version 5.0+ (API level 21+)
Refiner Android SDK is published to Maven. Add dependency below in your app/build.gradle
file.
dependencies {
implementation 'io.refiner:refiner:latest.release'
}
You may also need to add the following to your project/build.gradle
file.
allprojects {
repositories {
mavenCentral()
}
}
Visit our documentation for more information about how to use the SDK methods.
Initialize Refiner Android SDK in your application class with the needed configuration parameters.
class MyApp : Application() {
override fun onCreate() {
super.onCreate()
try {
Refiner.initialize(
context = this,
projectId = "PROJECT_ID",
debugMode = false
)
} catch (e: Exception) {
Log.e("Refiner", e.printStackTrace().toString())
}
}
}
Call Identify User
to create or update a user record in Refiner.
The first parameter is the userId of your logged-in user and is the only mandatory parameter.
The second parameter is an object of user traits. You can omit or set this value to null
if you don't want to attach any traits to the user object in Refiner. User traits map accepts values with the following types: String, Int or Boolean.
try {
Refiner.identifyUser(
userId = "USER_ID",
userTraits = linkedMapOf(
Pair("email", "hello@hello.com"),
Pair("a_number", 123),
Pair("a_date", "2022-16-04 12:00:00")
)
)
} catch (e: Exception) {
Log.e("Refiner", e.printStackTrace().toString())
}
The third parameter is for setting the locale
of a user and is optional. The expected format is a two letter ISO 639-1 language code. When provided, the locale code is used for launching surveys for specific languages, as well as launching translated surveys. You can omit or set the value to null
if you are not using any language specific features.
The fourth parameter is an optional Identity Verification signature. We recommend to use a Identify Verification signature for increased security in a production environment. For development purposes, you can omit or set this value to null
.
try {
Refiner.identifyUser(
userId = "USER_ID",
userTraits = linkedMapOf(
Pair("email", "hello@hello.com"),
Pair("a_number", 123),
Pair("a_date", "2022-16-04 12:00:00")
),
locale = "en",
signature = "SIGNATURE"
)
} catch (e: Exception) {
Log.e("Refiner", e.printStackTrace().toString())
}
The Set User
method acts as an alternative to the Identify User
method described above.
In contrast to the Identify User
method, the Set User
method does not immediately create a user object in your Refiner account. The provided user Id and traits are kept locally in your app and no data is communicated to our servers at first. Only when the user performs a meaningful action in your app (e.g. Track Event
or Track Screen
is executed) will a user object be created in Refiner. Provided user traits will be attached to the user object when a survey is shown.
The purpose of this alternative method is provide a way to identify users locally when the SDK is initialised but keep the number of tracked users in your Refiner account to a minimum.
try {
Refiner.setUser(
userId = "USER_ID",
userTraits = linkedMapOf(
Pair("email", "hello@hello.com"),
Pair("a_number", 123),
Pair("a_date", "2022-16-04 12:00:00")
),
locale = "en",
signature = "SIGNATURE"
)
} catch (e: Exception) {
Log.e("Refiner", e.printStackTrace().toString())
}
Track Event
lets you track user events. Tracked events can be used to create user segments and target audiences in Refiner.
Refiner.trackEvent(eventName = "EVENT_NAME")
Track Screen
provides to track screen that user is currently on. Screen information can be used to launch surveys in specific areas of your app.
We recommend to track screens on which you might want to show a survey one day. There is no need to systematically track all screens of your app.
Refiner.trackScreen(screenName = "SCREEN_NAME")
Depending on your setup, you might want to initiate regular checks for surveys that are scheduled for the current user. For example when you are using time based trigger events, or when a target audience is based on user data received by our backend API.
The Ping
method provides an easy way to perform such checks. You can call the Ping
method at key moments in a user's journey, such as when the app is re-opened, or when the user performs a specific action.
Refiner.ping()
If you use the Manual Trigger Event for your survey, you need to call Show Form
whenever you want to launch the survey.
Refiner.showForm(formUuid = "FORM_UUID")
For testing purposes, you can also provide an additional force
parameter which will bypass all targeting rules and always display the survey.
Refiner.showForm(formUuid = "FORM_UUID", force = true)
Attach contextual data to the survey submissions with addToResponse
. Set null
to remove the contextual data.
Refiner.addToResponse(
contextualData = hashMapOf(
Pair("some_data", "hello"),
Pair("some_more_data", "hello again"),
)
)
A new user session is automatically detected when a user returns to your application after at least one hour of inactivity. You can choose to manually start a new user session with the method shown below. You can call this method for example right after a user opens your app.
Refiner.startSession()
Call Reset User
to reset the user identifier previously set through Identify User
. We recommend calling this method when the user logs out from your app.
Refiner.resetUser()
Change the environment UUID during runtime, after the SDK has been initialised.
Refiner.setProject(projectId ="PROJECT_ID")
Close a survey programmatically without sending any information to the backend API with the closeForm
method.
Refiner.closeForm(formUuid = "FORM_UUID")
Close a survey programmatically and send a "dismissed at" timestamp to the backend server with the dismissForm
method.
Refiner.dismissForm(formUuid = "FORM_UUID")
Registering callback functions allows you to execute any code at specific moments in the lifecycle of a survey. A popular use-case for callback functions is to redirect a user to a new screen once they completed a survey.
onBeforeShow
gets called right before a survey is supposed to be shown.
Refiner.onBeforeShow { formId, formConfig ->
Log.i(TAG, "onBeforeShow \nformId: $formId \nformConfig: $formConfig")
if (formId == "ABC") {
Log.i(TAG, "Abort mission")
} else {
Log.i(TAG, "Continue and show survey")
}
}
onNavigation
gets called when the user moves through the survey
Refiner.onNavigation { formId, formElement, progress ->
Log.i(
TAG,
"onNavigation \nformId: $formId \nformElement: $formElement \nprogress: $progress"
)
}
onShow
gets called when a survey widget becomes visible to your user.
Refiner.onShow { formId ->
Log.i(TAG, "onShow \nformId: $formId")
}
onClose
gets called when the survey widgets disappears from the screen.
Refiner.onClose { formId ->
Log.i(TAG, "onClose \nformId: $formId")
}
onDismiss
gets called when the user dismissed a survey by clicking on the “x” in the top right corner.
Refiner.onDismiss { formId ->
Log.i(TAG, "onDismiss \nformId: $formId")
}
onComplete
gets called when the user completed (submitted) a survey.
Refiner.onComplete { formId, formData ->
Log.i(TAG, "onComplete \nformId: $formId \nformData: $formData")
}