@sentiance/react-native-sentiancedeprecated

React Native library for the Sentiance SDK

Usage no npm install needed!

<script type="module">
  import sentianceReactNativeSentiance from 'https://cdn.skypack.dev/@sentiance/react-native-sentiance';
</script>

README

react-native-sentiance

Getting started

$ npm install react-native-sentiance --save

Mostly automatic installation

$ react-native link react-native-sentiance

Manual installation

iOS

  1. In XCode, in the project navigator, right click LibrariesAdd Files to [your project's name]
  2. Go to node_modulesreact-native-sentiance-library and add RNSentianceLibrary.xcodeproj
  3. In XCode, in the project navigator, select RNSentianceLibrary.xcodeproj. Add the folder where SENTTransportDetectionSDK.framework is located to Search PathsFramework Search Paths
  4. In XCode, in the project navigator, select your project. Add libRNSentianceLibrary.a to your project's Build PhasesLink Binary With Libraries
  5. Run your project (Cmd+R)<

Android

  1. Open up android/app/src/main/java/[...]/MainActivity.java
  • Add import com.reactlibrary.RNSentiancePackage; to the imports at the top of the file
  • Add new RNSentiancePackage() to the list returned by the getPackages() method
  1. Append the following lines to android/settings.gradle:
    include ':react-native-sentiance'
    project(':react-native-sentiance').projectDir = new File(rootProject.projectDir, 	'../node_modules/react-native-sentiance/android')
    
  2. Insert the following lines inside the dependencies block in android/app/build.gradle:
      compile project(':react-native-sentiance')
    

Usage

import RNSentiance from 'react-native-sentiance';

Initializing the Sentiance SDK

Initialization is a very important step; before initialization, almost none of the methods on the Sentiance SDK interface are allowed to be called (with the exception of init, isInitialized and getVersion).

try {
    const initResponse = await RNSentiance.init('APPID', 'SECRET');
    // SDK init has successfully initialized
} catch (err) {
    // SDK init has failed initializing
}

Starting the Sentiance SDK

Starting is only allowed after successful initialization.

try {
    const startResponse = await RNSentiance.start();
    if (startResponse === 'STARTED') {
        // SDK started properly.
    } else if (startResponse === 'PENDING') {
        // Something prevented the SDK to start properly. Once fixed, the SDK will start automatically.
    }
} catch (err) {
    // SDK did not start.
}

Stopping the Sentiance SDK

Stopping is only allowed after successful initialization. While it's possible to "pause" the detections modules of the Sentiance SDK's, it's not recommended.

try {
    const stopResponse = await RNSentiance.stop();
    // SDK stopped properly.
} catch(err) {
    // An error prevented the SDK from stopping correctly
}

Cooldown period

It's best practice to implement a cooldown period to protect against flip-flops or state race conditions. To cancel a scheduled stop-with-cooldown, simply call start again.

await RNSentiance.stopAfter(300);

Init status

Checking if SDK is initialized

const isInitialized = await RNSentiance.isInitialized();

SDK status

The status of the Sentiance SDK

const sdkStatus = await RNSentiance.getSdkStatus();

The SDK can signal SDK status updates to JavaScript without being invoked directly. You can subscribe to these status updates by creating a new NativeEventEmitter instance around your module, and adding a listener for SDKStatusUpdate.

import { NativeEventEmitter } from 'react-native'

const sentianceEmitter = new NativeEventEmitter(RNSentiance);
const subscription = sentianceEmitter.addListener(
    'SDKStatusUpdate',
    res => {
        // Returns SDK status
    }
);

// Don't forget to unsubscribe, typically in componentWillUnmount
subscription.remove();

Get SDK version

const version = await RNSentiance.getVersion();

Get user id

If the SDK is initialized, you can get the user id as follows. This user id will allow you to interact with the API's from Sentiance. You need a token and user to authorize requests and query the right data.

const userId = await RNSentiance.getUserId();

Get user access token

If the SDK is initialized, you can get a user access token as follows. This token will allow you to interact with the API's from Sentiance. You need a token and user to authorize requests and query the right data. If the token has expired, or will expire soon, the SDK will get a new bearer token before passing it to the callback. Generally, this operation will complete instantly by returning a cached bearer token, but if a new token has to be obtained from the Sentiance API, there is a possibility it will fail.

const { tokenId, expiryDate } = await RNSentiance.getUserAccessToken();

Adding custom metadata

Custom metadata allows you to store text-based key-value user properties into the Sentiance platform. Examples are custom user id's, application related properties you need after the processing, ...

const label = 'correlation_id'
const value = '3a5276ec-b2b2-4636-b893-eb9a9f014938'

await RNSentiance.addUserMetadataField(label, value);

Remove custom metadata

You can remove previously added metadata fields by passing the metadata label to the removeUserMetadataField function.

const label = 'correlation_id'

await RNSentiance.removeUserMetadataField(label);

Adding multiple custom metadata fields

You can add multiple custom metadata fields by passing an object to the addUserMetadataFields function.

const metadata = { corrolation_id: '3a5276ec-b2b2-4636-b893-eb9a9f014938' }

await RNSentiance.addUserMetadataFields(metadata);

Starting trip

Whenever you call startTrip on the SDK, you override moving state detection and the SDK will track the trip until you call stopTrip or until the timeout (2 hours) is reached. startTrip accepts a metadata object and a transport mode hint (number) as parameters.

Transport mode hint:

SENTTransportModeUnknown = 1,
SENTTransportModeCar = 2,
SENTTransportModeBicycle = 3,
SENTTransportModeOnFoot = 4,
SENTTransportModeTrain = 5,
SENTTransportModeTram = 6,
SENTTransportModeBus = 7,
SENTTransportModePlane = 8,
SENTTransportModeBoat = 9,
SENTTransportModeMetro = 10,
SENTTransportModeRunning = 11

Example:

const metadata = { corrolation_id: '3a5276ec-b2b2-4636-b893-eb9a9f014938' }
const transportModeHint = 1
try {
    await RNSentiance.startTrip(metadata, transportModeHint);
    // trip is started
} catch (err) {
    // Unable to start trip
}

Stopping trip

try {
    const trip = await RNSentiance.stopTrip();
    // Stopped trip
} catch (err) {
    // Unable to stop trip
}

The SDK can also signal trip timeouts to JavaScript. You can subscribe to these trip timeouts by creating a new NativeEventEmitter instance around your module, and adding a listener for TripTimeout.

import { NativeEventEmitter } from 'react-native'

const sentianceEmitter = new NativeEventEmitter(RNSentianceLibrary)
const subscription = sentianceEmitter.addListener(
    'TripTimeout',
    res => {
        // Returns a trip object
    }
)

Trip status

Checking trip status

const isTripOngoing = await RNSentiance.isTripOngoing();

Adding external events

When the external event state becomes active.

Event types:

SENTExternalEventTypeOther = 1,
SENTExternalEventTypeBeacon = 2,
SENTExternalEventTypeCustomRegion = 3

Example:

const externalEventType = 1
const timestamp = Date.now() // timestamp should be in UNIX Epoch time
const id = 'a247ee7b-6438-477b-ab23-b8f039db2106'
const label = 'iBeacon is within 10 meter'

try {
    await RNSentiance.registerExternalEvent(externalEventType, timestamp, id, label);
} catch (err) {
    // Unable to register external event
)

Deregistering external events

When the external event state becomes inactive.

Event types:

SENTExternalEventTypeOther = 1,
SENTExternalEventTypeBeacon = 2,
SENTExternalEventTypeCustomRegion = 3

Example:

const externalEventType = 1
const timestamp = Date.now() // timestamp should be in UNIX Epoch time
const id = 'a247ee7b-6438-477b-ab23-b8f039db2106'
const label = 'iBeacon is out of range'

try {
    await RNSentiance.deregisterExternalEvent(externalEventType, timestamp, id, label);
    // Registered external event
} catch (err) {
    // Unable to register external event
}

Control sending data

If you want to override the default behavior, you can initiate a force submission of detections. Ideally, you use this method only after explaining to the user that your app will consume more bandwidth in case the device is not connected to Wi-Fi.

try {
    await RNSentiance.submitDetections();
} catch (err) {
    // Something went wrong with submitting data, for more information, see the error variable
}

Disk, mobile network and Wi-Fi quotas

The actual usages and limits in bytes can be obtained using the getWiFiQuotaUsage, getWiFiQuotaLimit and similar methods on the Sentiance SDK interface.

const limit = await RNSentiance.getWiFiQuotaLimit();

All quota functions:

  • getWiFiQuotaLimit
  • getWiFiQuotaUsage
  • getMobileQuotaLimit
  • getMobileQuotaUsage
  • getDiskQuotaLimit
  • getDiskQuotaUsage
  • getWiFiLastSeenTimestamp

Last time seen Wi-Fi

const timestamp = await RNSentiance.getWiFiLastSeenTimestamp();