{% hint style="warning" %}
The user linking concept described in this page has been deprecated in favor of a new User Creation flow introduced in v6.0.0 of the Sentiance SDK. {% endhint %}
User Linking can be used to connect your app’s user to a Sentiance user in a deeper way.
A user in the Sentiance Platform is identified by a unique user ID. An SDK instance (or an app install) on the other hand is identified by its install ID. By default, every new installation gets its own install and user IDs. However, it is possible to link the installation to an existing user.
To do so, we first link your app's user account (e.g. email, UUID, etc.) to the newly created Sentiance Platform user. Next time when the user re-installs your app, we'll use your app's user account to check for an existing link. If found, we will link this new installation to the existing user.
The biggest benefit here is the ability to get single continuous timelines for your users across app reinstalls and device migration.
During the first initialization, the SDK will provide your app an install ID associated with this particular instance of the app. In your app, you'll use this ID to link your user's account to a Sentiance user. This can only be done through server-to-server communication. Your app tells your server to contact the Sentiance Platform and request linking of your user account to this install-ID.
{% tabs %} {% tab title="iOS" %} Specify a SENTUserLinker in the SENTConfig.
{% code title="Swift" %}
let userLinker: SENTUserLinker = { installId, linkSuccess, linkFailed
// Use installId to initiate a link request here, and call
// linkSuccess() after linking succeeds.
}
let config = SENTConfig(appId: APPID,
secret: SECRET,
link: userLinker,
launchOptions: launchOptions)
Sentiance().initWith(config) {
// Success
} failure: { issue in
// Error Case with reason: issue
}
{% endcode %}
{% code title="Objective-C" %}
SENTUserLinker userLinker = ^(NSString *installId,
void (^linkSuccess)(void), void (^linkFailed)(void)) {
// Use installId to initiate a link request here, and call
// linkSuccess() after linking succeeds.
}
//SDK configuration
SENTConfig *config = [[SENTConfig alloc] initWithAppId:APPID
secret:SECRET
link:userLinker
launchOptions:launchOptions];
[sdk initWithConfig:config
success:^{
// Init success
}
failure:^(SENTInitIssue issue) {
// Init failed with reason <issue>
}];
{% endcode %}
During initialization, the SDK will pass the installID to the MetaUserLinker
. In this method, you must initiate a link request towards the Sentiance API (via your server), supplying the installID and your app’s userID.
After linking succeed, call linkSuccess()
. If it fails, you must call linkFailed()
. The SDK initialization will then fail with reason LINK_FAILED
. To reattempt linking, you can then initialize the SDK again, which in turn will invoke the MetaUserLinker
a second time.
{% endtab %}
{% tab title="Android" %}
Specify a UserLinker
in the SdkConfig
.
{% code title="Java" %}
class CustomUserLinker implements UserLinker {
boolean link(String installId) {
// Use installId to initiate a link request here, and return
// true after linking succeeds.
// This method will execute on a background thread.
}
}
SdkConfig config = new SdkConfig.Builder(APP_ID, SECRET, notification)
...
.setUserLinker(metaUserLinker)
.build();
Sentiance.getInstance(this).init(config, initCallback);
{% endcode %}
{% code title="Kotlin" %}
val linker = UserLinker { installId ->
// Use installId to initiate a link request here, and return
// true after linking succeeds.
// This method will execute on a background thread.
}
val config = SdkConfig.Builder(APP_ID, SECRET, notification)
...
.setUserLinker(linker)
.build()
Sentiance.getInstance(this).init(config, callback)
{% endcode %}
During initialization, the SDK will call the link(String)
method of your UserLinker
object from a background thread, passing to it the SDK install ID. In this method, you must initiate a link request towards the Sentiance API (via your server), supplying the install ID and your app’s User ID.
link(String)
must return true only after linking with the Sentiance API succeeds. If linking fails, you must return false. The SDK initialization will then fail with reason LINK_FAILED
.
{% endtab %}
{% endtabs %}
See our User Linking guide and the API documentation to learn more about the server-to-server linking.
Sentiance allows one active installation per user. This means that multiple instances of your app can be linked to the same user, but payloads generated by only one instance will be processed by the Sentiance Platform at any given time.
Generally, the active instance is the last installed instance of the SDK. However, priority is always given to phones over tablets. If the SDK is installed on a tablet while a phone instance is active, the tablet instance will not be activated.
{% hint style="info" %} On Android, we consider a phone to be a device having a screen size of less than 7 inches. {% endhint %}
To ensure the security of your app and data, make sure your app is compliant with the following security guidelines.
- Do not hardcode the Sentiance app secret in your app. Instead, securely retrieve and store it for future runs.
- Never send linking requests to the Sentiance API directly from your app. Instead, send them through your server.
- Use a secure connection and an authorization mechanism when sending link requests from your app to your server. This ensures that malicious requests do not get forwarded to the Sentiance API.
- Never store the Sentiance server token in your app. This token is used for authorized communication with the Sentiance API.
- Use certificate pinning if possible.
- Use Android's SafetyNet Attestation to verify that requests to your server are coming from a certified apk.
An example app for both iOS and Android can be found on our GitHub page.