Skip to content

Kotlin SDK for TelemetryDeck, a privacy-conscious analytics service for apps and websites.

License

Notifications You must be signed in to change notification settings

TelemetryDeck/KotlinSDK

Repository files navigation

Kotlin SDK for TelemetryDeck

This package allows you to send signals to TelemetryDeck from your Android applications. Sign up for a free account at telemetrydeck.com

Installation

Dependencies

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

Permission for internet access

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" />

Getting Started

Using the application manifest

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

Programmatic Usage

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)

Sending Signals

To send a signal immediately

TelemetryDeck.send("appLaunchedRegularly")

To enqueue a signal to be sent by TelemetryDeck at a later time

TelemetryDeck.signal("appLaunchedRegularly")

User Identifiers

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.

Custom User Identifiers

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)

Environment Parameters

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.

Custom Telemetry

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 when sendNewSessionBeganSignal 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 the enrich 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()))

Custom Logging

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.

Requirements

  • Android API 21 or later
  • Kotlin 2.0.20
  • Gradle 6.8.3–8.8*
  • AGP 7.1.3–8.5

Migrating providers to 3.0+

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.

If you're using the application manifest

  • Adapt the manifest of your app and rename all keys from com.telemetrydeck.sdk.* to com.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 to TelemetryDeck.
  • 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 to TelemetryDeck.signal().

Programmatic Usage

  • In your app sourcecode, rename all uses of TelemetryManager to TelemetryDeck.
  • 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 to TelemetryDeck.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.

Custom Telemetry

Your custom providers must replace TelemetryProvider with TelemetryDeckProvider.

To adopt the new interface:

  • Adapt the signature of the register method to register(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

About

Kotlin SDK for TelemetryDeck, a privacy-conscious analytics service for apps and websites.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages