Skip to content

Latest commit

 

History

History
69 lines (56 loc) · 1.88 KB

get-notified-about-location-permissions-changes-or-get-current-location-permission-status.md

File metadata and controls

69 lines (56 loc) · 1.88 KB

Check the Location Permissions

To get current location permission status, use the sdkStatus property.

{% tabs %} {% tab title="iOS" %}

let sdkStatus = Sentiance.shared.sdkStatus

if (sdkStatus.locationPermission == .always) {
    // We are good!
} else {
    // Background location permission not granted.
}

if (sdkStatus.isPreciseLocationAuthorizationGranted) {
    // We are good!
} else {
    // Precise location permission not granted.
}

{% endtab %}

{% tab title="Android" %}

val sdkStatus = Sentiance.getInstance(context).sdkStatus

if (sdkStatus.locationPermission == SdkStatus.LocationPermission.ALWAYS) {
    // We are good!
} else {
    // Background location permission not granted.
}

if (sdkStatus.isPreciseLocationPermGranted) {
    // We are good!
} else {
    // Precise location permission not granted.
}

{% endtab %} {% endtabs %}

In the above example, sdkStatus returns an SDK status object (iOS / Android) which has properties for the location permission and precision.

{% hint style="info" %} The user must grant the background location access permission in order for SDK detections to work. This is presented as the "always" option on iOS, and the "allow all the time" option on Android 10+ devices.

The user must also enable precise location accuracy. {% endhint %}

To be notified of location permission changes, you can set up an SDK status listener on the SDK's config object as follows:

{% tabs %} {% tab title="iOS" %}

Sentiance.shared.setDidReceiveSdkStatusUpdateHandler { status in
    // Check the location permission and precision here.
}

{% endtab %}

{% tab title="Android" %}

Sentiance.getInstance(this).setSdkStatusUpdateListener { status -> 
    // Check the location permission and precision here.
}

{% endtab %} {% endtabs %}