Telemetry configuration
This guide uses the Navigation SDK for iOS, which is only available upon request. Contact us to get started.
The Navigation SDK can send telemetry data to TomTom. This helps us improve the SDK user experience. The Telemetry module allows the configuration of data collection.
In this guide, you will learn how to configure the Telemetry module and adjust the user consent level.
Project setup
Then add the following dependencies, depending on your preferred package manager:
Swift Package Manager
. To incorporate the Telemetry package into your project, follow the steps described in tomtom-sdk-spm-telemetry.
- Click File > Add Packages… / Add Package Dependencies… in XCode.
- In the Enter Package URL textbox, enter the URL for the package mentioned previously.
- Set the Dependency Rule to Exact Version.
- Ensure that you’ve selected the appropriate project where you want to add this dependency and click Add Package.
- Once the package is successfully resolved and added to your project, you can use this package by importing Telemetry modules into your Swift files:
import TomTomSDKTelemetryimport TomTomSDKTelemetryConfigProvider
CocoaPods
. Add the TomTomSDKTelemetry
and TomTomSDKTelemetryConfigProvider
modules to your project’s Podfile
:
+
1TOMTOM_SDK_VERSION = '0.61.0'23target 'YourAppTarget' do4 use_frameworks!5 pod 'TomTomSDKTelemetry', TOMTOM_SDK_VERSION6 pod 'TomTomSDKTelemetryConfigProvider', TOMTOM_SDK_VERSION7end
- Install the dependencies by executing the following commands in the project directory:
pod repo-art update tomtom-sdk-cocoapodspod install --repo-update
- Add the following imports to your project:
import TomTomSDKTelemetryimport TomTomSDKTelemetryConfigProvider
Basic configuration
You can use the Telemetry
object to configure what telemetry data the SDK sends. Initialize the Telemetry object before you start the TomTomNavigation
. To initialize the Telemetry object, you must provide an instance of DefaultTelemetryConfigProvider
, set with the API key.
let configProvider = DefaultTelemetryConfigProvider(apiKey: "YOUR_TOMTOM_API_KEY")try? Telemetry.initialize(configProvider: configProvider)
Telemetry initialization can only be done once. Every subsequent attempt to initialize the Telemetry is ignored.
User consent
You can enable or disable data collection for an end user by setting the Telemetry.userConsent
property.
Consent.none
results in the SDK sending no telemetry data. This is the default value.
Consent.anonymized
results in the SDK sending only anonymous telemetry data.
Consent.pseudonymized
causes the SDK to send the telemetry data with no personal or billing information. The data allows TomTom to identify the user. For example, given a user, TomTom can tell what routes they took. However, TomTom can’t link personal or billing data with the user.
Consent.personalized
results in the SDK sending the telemetry data, including any available personal or billing information.
Telemetry.userConsent = .personalized
Unless agreed differently in the contract, we ask our customers to only enable an end user to use the Traffic services if the user simultaneously consents to the telemetry data collection.
Next steps
Since you have learned how to configure Telemetry, here are recommendations for the next steps:
Starting navigation
Learn how to start turn-by-turn navigation.
Built-in location providers
Read what built-in location providers TomTom Navigation SDK for iOS offers.
Create your own provider
Learn how to create a custom location provider.