This package allows you to send signals to TelemetryDeck from your Android applications. Sign up for a free account at telemetrydeck.com
The Kotlin SDK for TelemetryDeck is available from Maven Central and can be used as a dependency directly in build.gradle
file:
dependencies {
implementation 'com.telemetrydeck:kotlin-sdk:4.0.2'
}
If needed, update your gradle.settings
to reference Kotlin version compatible with 2.0.20, e.g.:
id "org.jetbrains.kotlin.android" version "2.0.20" apply false
Sending signals requires access to the internet so the following permission should be added to the app's AndroidManifest.xml
<uses-permission android:name="android.permission.INTERNET" />
A quick way to start is by adding your App ID to the application
section of the app's AndroidManifest.xml
:
<application>
...
<meta-data android:name="com.telemetrydeck.appID" android:value="XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX" />
</application>
Replace XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
with your TelemetryDeck App ID.
In addition, the following optional properties are supported:
com.telemetrydeck.showDebugLogs
com.telemetrydeck.apiBaseURL
com.telemetrydeck.sendNewSessionBeganSignal
com.telemetrydeck.sessionID
com.telemetrydeck.testMode
com.telemetrydeck.defaultUser
For greater control you can set up and configure TelemetryDeck
using the provided builder:
val builder = TelemetryDeck.Builder()
.appID("XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX")
.showDebugLogs(true)
.defaultUser("Person")
TelemetryDeck.start(application, builder)
To send a signal immediately
TelemetryDeck.send("appLaunchedRegularly")
To enqueue a signal to be sent by TelemetryDeck at a later time
TelemetryDeck.signal("appLaunchedRegularly")
When TelemetryDeck
is started for the first time, it will create a user identifier for the user that is specific to the app installation.
-
The identity is stored within the application's file folder on the user's device.
-
The identifier will be removed when a user uninstalls an app. The KotlinSDK will not "bridge" the user's identity between installations.
-
Users can reset the identifier at any time by using the "Clear Data" action in Settings of their device.
If you have a better user identifier available, such as an email address or a username, you can use that instead, by setting defaultUser
(the identifier will be hashed before sending it) in configuration, or by passing the value when sending signals.
If you need a more robust mechanism for keep track of the user's identity, you can replace the default behaviour by providing your own implementation of TelemetryDeckIdentityProvider
:
val builder = TelemetryDeck.Builder()
.appID("XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX")
.showDebugLogs(true)
.defaultUser("Person")
.identityProvider(YourIdentityProvider())
TelemetryDeck.start(application, builder)
By default, Kotlin SDK for TelemetryDeck will include the following environment parameters for each outgoing signal
Parameter name | Provider |
---|---|
TelemetryDeck.Session.started |
SessionAppProvider |
TelemetryDeck.AppInfo.buildNumber |
EnvironmentParameterProvider |
TelemetryDeck.AppInfo.version |
EnvironmentParameterProvider |
TelemetryDeck.AppInfo.versionAndBuildNumber |
EnvironmentParameterProvider |
TelemetryDeck.Device.architecture |
EnvironmentParameterProvider |
TelemetryDeck.Device.modelName |
EnvironmentParameterProvider |
TelemetryDeck.Device.operatingSystem |
EnvironmentParameterProvider |
TelemetryDeck.Device.platform |
EnvironmentParameterProvider |
TelemetryDeck.Device.systemMajorMinorVersion |
EnvironmentParameterProvider |
TelemetryDeck.Device.systemMajorVersion |
EnvironmentParameterProvider |
TelemetryDeck.Device.systemVersion |
EnvironmentParameterProvider |
TelemetryDeck.Device.orientation |
PlatformContextProvider |
TelemetryDeck.Device.screenDensity |
PlatformContextProvider |
TelemetryDeck.Device.screenResolutionHeight |
PlatformContextProvider |
TelemetryDeck.Device.screenResolutionWidth |
PlatformContextProvider |
TelemetryDeck.Device.brand |
EnvironmentParameterProvider |
TelemetryDeck.Device.timeZone |
PlatformContextProvider |
TelemetryDeck.AppInfo.buildNumber |
EnvironmentParameterProvider |
TelemetryDeck.AppInfo.version |
EnvironmentParameterProvider |
TelemetryDeck.AppInfo.versionAndBuildNumber |
EnvironmentParameterProvider |
TelemetryDeck.SDK.name |
EnvironmentParameterProvider |
TelemetryDeck.SDK.version |
EnvironmentParameterProvider |
TelemetryDeck.SDK.nameAndVersion |
EnvironmentParameterProvider |
TelemetryDeck.SDK.buildType |
EnvironmentParameterProvider |
TelemetryDeck.RunContext.locale |
PlatformContextProvider |
TelemetryDeck.RunContext.targetEnvironment |
PlatformContextProvider |
TelemetryDeck.RunContext.isSideLoaded |
PlatformContextProvider |
TelemetryDeck.RunContext.sourceMarketplace |
PlatformContextProvider |
See Custom Telemetry on how to implement your own parameter enrichment.
Another way to send signals is to register a custom TelemetryDeckProvider
.
A provider uses the TelemetryDeck client in order to queue or send signals based on environment or other triggers.
To create a provider, implement the TelemetryDeckProvider
interface:
class CustomProvider: TelemetryDeckProvider {
override fun register(ctx: Application?, client: TelemetryDeckClient) {
// configure and start the provider
// you may retain a WeakReference to client
}
override fun stop() {
// deactivate the provider, perform cleanup work
}
}
Setup and start the provider during the register
method.
Tips:
- Do not retain a strong reference to the application context or TelemetryDeckClient instance.
- You can use
WeakReference<TelemetryDeckClient>
if you need to be able to call the TelemetryDeck at a later time.
To use your custom provider, register it by calling addProvider
using the TelemetryDeck.Builder
:
val builder = TelemetryDeck.Builder()
// ...
.addProvider(CustomProvider()) // <-- Your custom provider
Every time the SDK is about to send signals to our servers, the enrich
method of every provider will be invoked to give you the opportunity to append additional parameters.
In the implementation of your custom TelemetryDeckProvider
, you can override the enrich
method:
override fun enrich(
signalType: String,
clientUser: String?,
additionalPayload: Map<String, String>
): Map<String, String> {
// retrieve the payload of signal
val signalPayload = additionalPayload.toMutableMap()
// add additional attributes of your choice
val today = LocalDateTime.now().dayOfWeek
if (today == DayOfWeek.MONDAY) {
signalPayload["isMonday"] = "yes"
}
// return the enriched payload
return signalPayload
}
We use providers internally to provide lifecycle and environment integration out of the box. Feel free to examine how they work and inspire your own implementations.
You can also completely disable or override the default providers with your own.
SessionAppProvider
- Emits signals for application and activity lifecycle events. This provider is tasked with resetting the sessionID whensendNewSessionBeganSignal
is enabled.SessionActivityProvider
- Emits signals for application and activity lifecycle events. This provider is not enabled by default.EnvironmentParameterProvider
- Adds environment and device information to outgoing Signals. This provider overrides theenrich
method in order to append additional metadata for all signals before sending them.PlatformContextProvider
- Adds environment and device information which may change over time like the current timezone and screen metrics.
// Append a custom provider
val builder = TelemetryDeck.Builder()
// ...
.addProvider(CustomProvider())
// Replace all default providers
val builder = TelemetryDeck.Builder()
// ...
.providers(listOf(CustomProvider(), AnotherProvider()))
By default, TelemetryDeck SDK uses a simple println
to output internal diagnostic messages when showDebugLogs
is set to true
in configuration.
If your platform has custom logging needs, you can adopt the DebugLogger
interface and provide it to the TelemetryDeck
builder:
val builder = TelemetryDeck.Builder()
// ...
.logger(CustomLogger())
Please note that the logger implementation should be thread safe as it may be invoked in different queues and contexts.
- Android API 21 or later
- Kotlin 2.0.20
- Gradle 6.8.3–8.8*
- AGP 7.1.3–8.5
If you had Kotlin SDK for TelemetryDeck added to your app, you will notice that TelemetryManager
and related classes have been deprecated.
You can read more about the motivation behind these changes here.
To upgrade, please perform the following changes depending on how you use TelemetryDeck SDK.
- Adapt the manifest of your app and rename all keys from
com.telemetrydeck.sdk.*
tocom.telemetrydeck.*
for example:
Before:
<meta-data android:name="com.telemetrydeck.sdk.appID" android:value="XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX" />
After:
<meta-data android:name="com.telemetrydeck.appID" android:value="XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX" />
- In your app sourcecode, rename all uses of
TelemetryManager
toTelemetryDeck
. - If you were using
send()
to send signals, no further changes are needed! - If you were using
queue()
to send signals, you will need to rename the method toTelemetryDeck.signal()
.
- In your app sourcecode, rename all uses of
TelemetryManager
toTelemetryDeck
. - If you were using
send()
to send signals, no further changes are needed! - If you were using
queue()
to send signals, you will need to rename the method toTelemetryDeck.signal()
. - If you had a custom provider configuration, please replace the corresponding providers as follows:
Provider (old name) | Provider (new, 3.0+) |
---|---|
AppLifecycleTelemetryProvider |
SessionAppProvider , SessionActivityProvider |
SessionProvider |
SessionAppProvider |
EnvironmentMetadataProvider |
EnvironmentParameterProvider , PlatformContextProvider |
Tip
You can rename all deprecated classes in your project using the Code Cleanup function in IntelliJ/Android Studio.
Warning
Do not mix usage of TelemetryManager
and TelemetryDeck
. Once you're ready to migrate, adapt all uses at the same time.
Your custom providers must replace TelemetryProvider
with TelemetryDeckProvider
.
To adopt the new interface:
- Adapt the signature of the
register
method toregister(ctx: Application?, client: TelemetryDeckSignalProcessor)
The TelemetryDeckSignalProcessor
interface offers a subset of the TelemetryDeck
client API which gives you access to:
- To access the logger, use can use
client.debugLogger
- To access the signal cache, use
client.signalCache