Integrate SDK
- Implementation
- Setup repositories
- Add Proxi.cloud SDK required dependencies
- Set Manifest Permissions
- Initiate Proxi.cloud SDK
- Pass the GDPR consent
- Report custom events
Implementation
The following manual describes how to implement Proxi.cloud SDK into your Android application.
If you would like to check an example app with Proxi.cloud SDK already implemented, check: Example App GIT repository
Setup repositories
Proxi.cloud SDK is distributed via maven central
repository.
So it is required to add mavenCentral()
to the list of repositories, jitpack
repository is also needed due to one of the dependencies used by Proxi.cloud SDK.
Depending on the way your project is setup it is done either in project’s root build.gradle
file in allProjects/repositories
section or using dependencyResolutionManagement
in project’s settings.gradle
file.
Option 1: Project level build.gradle allProjects/repositories
// project_directory/build.gradle
allprojects {
repositories {
mavenCentral()
maven { url "https://jitpack.io" }
// some other repos used in your project
}
}
Option 2: DependencyResolutionManagement
// settings.gradle file
dependencyResolutionManagement {
// Example flag set, may be different in your project setup
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven("https://jitpack.io")
// some other repositories used in your project
}
}
Add Proxi.cloud SDK required dependencies
Next step is to add Proxi.cloud SDK dependencies to your project’s application level build.gradle
file. Depending on your project’s setup you can define libraries’ packages and versions directly in build.gradle
file or in a separate libs.versions.toml
file and then just link to them.
As Proxi.cloud SDK relies heavly on play-services-location
and ads-identifier
libraries it is required to add them as well.
play-services-location
- used for geofencing and acquiring locationads-identifier
- required to access Advertising Identifier
How to implement:
Option 1: Direct way
// App level build.gradle, usually found in path: project_directory/app/build.gradle
dependencies {
// Proxi.cloude SDK
implementation("cloud.proxi.sdk:cloud.proxi.sdk:2.9.0")
// Required play services dependencies
implementation("com.google.android.gms:play-services-ads-identifier:18.1.0")
implementation("com.google.android.gms:play-services-location:21.3.0")
}
Option 2: Libs.versions.toml
Define Proxi.cloud SDK dependency in libs.versions.toml
file.
[versions]
# Proxi.cloud SDK version
proxiCloudSdkVersion = "2.9.0"
# play services ads identifier and location versions
adsIdentifierVersion = "18.1.0"
playServicesLocationVersion = "21.3.0"
[libraries]
# Proxi.cloud SDK
cloud-proxi-sdk = { group = "cloud.proxi.sdk", name = "cloud.proxi.sdk", version.ref = "proxiCloudSdkVersion" }
# play services ads identifier and location
ads-identifier = { group = "com.google.android.gms", name = "play-services-ads-identifier", version.ref = "adsIdentifierVersion" }
play-services-location = { group = "com.google.android.gms", name = "play-services-location", version.ref = "playServicesLocationVersion" }
Then add your dependency, similarly to the direct aproach. The difference is that we just link to the definition from libs.versions.toml
file.
// App level build.gradle, usually found in path: project_directory/app/build.gradle
dependencies {
// Proxi.cloude SDK
implementation(libs.cloud.proxi.sdk)
// Required play services dependencies
implementation(libs.ads.identifier)
implementation(libs.play.services.location)
}
Set Manifest Permissions
As Proxi.cloud SDK’s primary purpose is to gather location based data it is necessary for an app to add the following permissions:
ACCESS_FINE_LOCATION
is required in your manifest for location capabilities to work.
ACCESS_COARSE_LOCATION
Since Android 12 user must be provided with an option to opt in for non-precise location.
Important!
Starting from Android 6 (API level 23) the user needs to be asked explicitly for the location permission. More information on this page.
ACCESS_BACKGROUND_LOCATION
required to access location even if app is in background, needed for geofencing to work properly.
Important!
Starting from 29 March 2021 Google Play Store requires apps with
ACCESS_BACKGROUND_LOCATION
permission to fill aditional permission declaration form. You can read more about it on this page
ACCESS_WIFI_STATE
and CHANGE_WIFI_STATE
are neccessary to take advantage of WiFi scanning.
Example setup for permissions in AndroidManifest.xml
file.
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<!-- Required for Proxi.cloud SDK to enable location powered capabilities like geofencing and WiFi scanning -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION"/>
<!-- Required for Proxi.cloud SDK to scan WiFi networks -->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/>
<!-- Required for Proxi.cloud SDK jobs -->
<uses-permission android:name="android.permission.WAKE_LOCK"/>
<!-- Rest of the manifest file -->
Initiate Proxi.cloud SDK
Enable the SDK in your Application’s onCreate() method.
import cloud.proxi.ProxiCloudSdk;
class ExampleApp : Application() {
override fun onCreate() {
super.onCreate();
// Init Proxi.cloud SDK
// Replace "API_KEY" with a key provided to you by Proxi.cloud
ProxiCloudSdk.create(this, "API_KEY");
}
}
If you didn’t already extend Application
class, it is required to link it in AndroidManifest.xml
file. Inside application
tag set value of android:name
to the class that extends Application
. ExampleApp
in this case.
<!-- AndroidManifest.xml file -->
<application
android:name=".ExampleApp"
>
Pass the GDPR consent
Important!
Proxi.cloud SDK collects Advertising Identifier only if
setGdprConsent
is set to true.
If GDPR rules are applicable to your app, the user must consent to data collection. This includes information collected by the Proxi.cloud SDK. Please consult our privacy policy for more details on this topic.
Once the user provides appropriate consent to processing of their data, simply run:
ProxiCloudSdk.getInstance().setGdprConsent(true);
If for any reason the user withdraws their consent or you want to prevent SDK from collecting data including the user’s advertising identifier. Just run the same method with ‘false’ as its argument.
ProxiCloudSdk.getInstance().setGdprConsent(false);
Please make sure that the Proxi.cloud privacy policy is linked in your GDPR consent information screen and Proxi.cloud is listed among your trusted partners. Feel free to contact Proxi.cloud GDPR team in case of any questions.
Report custom events
Proxi.cloud SDK allows application developers to report custom events which then can be agreggated and analysed in the Proxi.cloud platform.
To use this functionality simply call the reportEvent
method when the event you wish to report occurs. The SDK will automatically add current timestamp and location (if it can be established) to the event and send it back to the Proxi.cloud platform for further aggregation where it can be used to create custom reports and analytics.
Below is an example showing how to report particular product view within the app.
ProxiCloudSdk.getInstance().reportEvent("product_viewed", "{'\"brand\":\"Awesome Brand\",\"name\":\"Awesome Product\",\"product_id\":1337}");