MOTIONTAG SDK Flutter Plugin
The MOTIONTAG Mobility & Location Analytics SDK enables to collect raw sensor data of the telephone in a battery efficient way. This data is then transmitted to the MOTIONTAG back-end system (ISO 27001 certified). In the backend, the sensor events are processed and a partial journey is constructed. Journeys consist either solely of tracks or tracks plus stays. Tracks describe a movement from a origin to a destination with a certain mode of transport. Stays symbolize a stationary behaviour with a particular purpose for the visit.
The use cases for the SDK are manifold. In the mobility sector it can be used to get detailed mobility data for planning purposes. The collected data enables to compare how the transport network is being used. This way the effectiveness of the current infrastructure and the passenger flow management is measured and the design of new mobility services. By implementing and using the SDK you can make use of these findings to improve timetables and routes, expand transport supply and attract more passengers.
If you integrate the MOTIONTAG SDK inside your own application, you can either download user journeys via a provided dump interface on the internet or we tailor a customized solution to your needs.
This plugin wraps the iOS and the Android SDK on the two platforms respectively.
The general principle was to expose the intersection of the features of the two implementation, meaning that some Android-only and iOS-only features are intentionally left out. Minimum supported OS versions:
Android | iOS |
---|---|
API 23+ | iOS 12.3+ |
1. Installation
First, add motiontag_sdk
as a dependency in your pubspec.yaml file.
iOS
The SDK must be initialized before the plugin registration in the didFinishLaunchingWithOptions
application's delegate function.
The handleEventsForBackgroundURLSession
calls must be forwarded by overriding the appropriate delegate.
Check out AppDelegate.swift as an example.
Android
Create an Application
, which you register in the AndroidManifest.xml
.
You have to call MotionTagWrapper.initialize()
from the Application
's onCreate
callback and provide the required arguments.
Check out MainApplication.kt
as an example.
Auto Backup for Apps is a platform feature that automatically backs up a user's data from apps that target and run on Android 6.0 (API level 23) or later. To limit unexpected behavior from our SDK, you should either disable automated backups entirely or exclude the appropriate SDK files from full backup. Please check this section of the native Android MOTIONTAG SDK for more information.
2. Permission management
Since the permission management is not part of the MOTIONTAG SDK, it is the app's responsibility to acquire the permissions/authorizations from the user before starting the SDK.
The example project demonstrates an implementation using the
permission_handler
package.
iOS
The SDK requires access to location updates in the background, for that please add following capability in Xcode:
- Capabilities -> Background Modes:
- Location Updates
Additionally, The SDK requires two authorizations before being started: Location (Always)
and Motion
.
Therefore, add the following items to your app's Info.plist
:
- "Privacy - Motion Usage Description" string
- "Privacy - Location Always & When in Use Description" string
- "Privacy - When in Use Description" string
If you use permission_handler
make sure to add the
requested snippets to the Podfile for each of them.
Android
The following runtime permissions are required before starting the SDK:
android.permission.ACTIVITY_RECOGNITION
android.permission.ACCESS_FINE_LOCATION
android.permission.ACCESS_COARSE_LOCATION
android.permission.ACCESS_BACKGROUND_LOCATION
Some of these permissions may not be required when targeting older Android versions. Please check the native Android MOTIONTAG SDK documentation for more info.
3. Usage
The MotionTag class is the main entry point of the SDK. It has the following public functions:
Function | Description |
---|---|
Future<void> start() async |
Starts tracking. It's not necessary to call this method again after a device reboot. |
Future<void> stop() async |
Stops tracking. |
Future<void> setUserToken(String userToken) async |
Sets the user token (JWT). The SDK expects a valid user token prior to executing the start() function. The provided token will be persisted internally. |
Future<String?> getUserToken() async |
Retrieved the persisted user token or null if it was not previously set. |
void setObserver(void Function(MotionTagEvent event)? observer) |
Set a function to be called by the SDK to inform abour relevant changes (e.g.: data transmission error, tracking started, etc). |
Future<void> clearData() async |
Deletes all unstransmitted stored user data from the SDK. This function is useful when signing out the user from your app. |
Future<bool> isTrackingActive() async |
Returns true if the SDK is currently active, false otherwise. |
The MotionTagEvent class is the base class for all notifiable SDK events.
The SDK currently supports the following concrete implementations of the MotionTagEvent
class:
Event | Description |
---|---|
StartedEvent |
Informs the application that tracking has been started. |
StoppedEvent |
Informs the application that tracking has been stopped. |
LocationEvent |
Hands the latest captured device location to the application. |
TransmissionSuccessEvent |
Informs when a package of events has been successfully sent to the server. |
TransmissionErrorEvent |
Informs when a package of events failed to be transmitted to the server. |
4. User authentication
The SDK must be configured at runtime with a user-specific token using JWT. For more information, please check the native Android and/or iOS SDK documentations.
5. Non-standard background process limitations on Android
Some Android OEMs, like Huawei and OnePlus, decided to implement non-standard background process limitations on 3rd party apps as an attempt to reduce battery consumption. The MOTIONTAG SDK must be running all times in the background, otherwise it won't function properly.
Therefore we recommend developers integrating our SDK to read the https://dontkillmyapp.com website, it describes this problem in detail and it provides some workaround options for both developers and users. There's also this StackOverflow post which describes how developers can forward users to the correct OEM settings.
When battery optimization is turned on for your app, the MOTIONTAG SDK may not be able to track and generate data continuously. If 24/7 tracking on all supported phone models is crucial to your use case, we strongly recommend you to include a prompt for the user, and facilitate the deactivation of battery optimization settings for your app on the affected phones.
6. License
The SDK is licensed under the MOTIONTAG SDK Test License.