Linux

To install the C++ SDK:

1

Fetch and extract the Ditto package. (Downloading and Unpacking Ditto)

2

Configure your app to link to the Ditto static library. (Linking to Ditto)

Downloading and Unpacking Ditto

Linux

Download Ditto.tar.gz and unpack an archive containing the libditto.a static library and Ditto header:

Linking to Ditto

Add -lditto as a compilation step in the main.cpp source file:

For instructions on adding cross-platform Bluetooth Low Energy (LE) capabilities, see Bluetooth on Linux.

BlueZ is the official Bluetooth protocol stack implementation for Linux systems to communicate with other Bluetooth-enabled platforms.

Android

The Ditto C++ SDK for Android is available in the Maven Central repository: https://central.sonatype.com/artifact/live.ditto/ditto-cpp

Integrating the C++ SDK into an Android app requires use of the Android Native Development Kit (NDK) and the Java Native Interface (JNI) mechanism. To learn more about the NDK and JNI, see https://developer.android.com/ndk/guides.

Setting Up Your Environment

Include the Maven Central repository in your Gradle file, and then synchronize it with your project.

1

From your project-level build.gradle file located in the app’s root directory, ensure the mavenCentral() repository is included in the repositories section:

Gradle
allprojects { repositories { mavenCentral() } }
2

Synchronize your project with the Gradle file by clicking File > Sync Project with Gradle Files.

Adding the Ditto SDK Dependency

Add the Ditto SDK to your app’s build.gradle file in the dependencies block with the appropriate version:

implementation "live.ditto:ditto-cpp:4.8.2"

To ensure that your app links properly with the shared objects in the SDK, and that your app has debugging symbols for the SDK, add these rules to your android packagingOptions block:


jniLibs { useLegacyPackaging = true keepDebugSymbols.add("\*\*/\*.so") } pickFirst 'lib/x86/libc++\_shared.so' pickFirst 'lib/x86\_64/libc++\_shared.so' pickFirst 'lib/armeabi-v7a/libc++\_shared.so' pickFirst 'lib/arm64-v8a/libc++\_shared.so' pickFirst 'lib/x86/libditto.so' pickFirst 'lib/x86\_64/libditto.so' pickFirst 'lib/armeabi-v7a/libditto.so' pickFirst 'lib/arm64-v8a/libditto.so'

Setting Android Context

The C++ SDK for Android requires that the app call Ditto::set_android_context(JNIEnv* env, jobject context) with an application context object after creating an instance of the C++ Ditto class. This context is required by the SDK on Android to access system resources such as network interfaces and files.

Configuring Permissions

The Android operating system limits access to some device functionality for end-user control and privacy. In order to use this functionality, configure your app to declare and request permissions from end users at runtime:

1

Review permissions used by Ditto. (Declaring Permissions)

2

Proactively check permission status to avoid unnecessary delay between granting access and Ditto being able to use the feature. (Requesting Permissions)

Declaring Permissions in the Android Manifest

Android requires certain permissions to be explicitly requested by the app to access features like Bluetooth Low Energy and Wi-Fi Aware. These permissions must be declared in the app’s manifest file and requested from the end user at runtime.

The Ditto SDK’s AndroidManifest.xml includes all of the necessary permissions for enabling its mesh network capabilities. These permissions will automatically be merged with your app’s permissions, so you should be aware of them.


<!-- Required for Bluetooth --> <uses-permission android:name="android.permission.BLUETOOTH" android:maxSdkVersion="30" /> <uses-permission android:name="android.permission.BLUETOOTH\_ADMIN" android:maxSdkVersion="30" /> <uses-permission android:name="android.permission.BLUETOOTH\_ADVERTISE" tools:targetApi="31" /> <uses-permission android:name="android.permission.BLUETOOTH\_CONNECT" tools:targetApi="31" /> <uses-permission android:name="android.permission.BLUETOOTH\_SCAN" android:usesPermissionFlags="neverForLocation" tools:targetApi="31" /> <uses-permission android:name="android.permission.ACCESS\_COARSE\_LOCATION" android:maxSdkVersion="28" /> <!-- Required for WiFi Aware --> <uses-permission android:name="android.permission.ACCESS\_WIFI\_STATE" /> <uses-permission android:name="android.permission.CHANGE\_WIFI\_STATE" /> <uses-permission android:name="android.permission.ACCESS\_NETWORK\_STATE" /> <uses-permission android:name="android.permission.CHANGE\_NETWORK\_STATE" /> <uses-permission android:name="android.permission.NEARBY\_WIFI\_DEVICES" android:usesPermissionFlags="neverForLocation" tools:targetApi="33" /> <uses-permission android:name="android.permission.ACCESS\_FINE\_LOCATION" android:maxSdkVersion="32" /> <!-- Required for WiFi Aware, TCP, UDP, and WebSockets --> <uses-permission android:name="android.permission.INTERNET" /> <!-- Required for mDNS discovery --> <uses-permission android:name="android.permission.CHANGE\_WIFI\_MULTICAST\_STATE" />

Some of these permissions have an android:maxSdkVersion attribute which means they are not used on devices running newer versions of Android. This is a best practice to respect users’ privacy when those permissions are not necessary.

However, some apps may still need to use one or more of the above permissions across more versions of Android. This can be accomplished by overriding the permission configuration in your app’s AndroidManifest.xml

To override any of these permission limitations in your app, do the following:

1

Open the AndroidManifest.xml located in the app/src/main directory of your project.

2

Within the same manifest tag, just before the application tag, add the relevant permissions you want to configure (location example):

<uses-permission android:name="android.permission.ACCESS\_FINE\_LOCATION" tools:remove="android:maxSdkVersion" /> <uses-permission android:name="android.permission.ACCESS\_COARSE\_LOCATION" tools:remove="android:maxSdkVersion" />

Note the additional tools:remove attribute. This tells the manifest merger to selectively remove the android:maxSdkVersion behavior from the associated permissions, changing them to apply to all Android versions.

For more information, see the official Permissions on Android and Merge manifest files documentation.

Requesting Permissions at Runtime

At runtime, your app can call the C++ Ditto::missing_permissions() function to get a list of permissions required by Ditto that are missing, and your app can request them.

Importing Ditto

From the source code of your app, using #include <Ditto.h>, import Ditto and provide your access credentials:

C++
auto identity =
    Identity::OnlinePlayground("YOUR_APP_ID", "PLAYGROUND_TOKEN", true);
try {
  Ditto ditto = Ditto(identity, dir);
  ditto.set_minimum_log_level(LogLevel::debug);
  ditto.start_sync();
} catch (const DittoError &err) {
}

Was this page helpful?