element-android/rust-sdk
2021-11-24 14:11:32 +01:00
..
src crypto: Update to the latest rust-sdk version 2021-11-17 14:58:14 +01:00
build.rs matrix-sdk: Initial import of the rust-sdk crypto layer. 2021-02-17 16:21:57 +01:00
Cargo.toml rust: Bump the uniffi version 2021-11-24 14:11:32 +01:00
Makefile Wire compute room shields with rust 2021-11-19 13:29:42 +01:00
README.md rust: Add a README explaining how to build the bindings 2021-02-26 16:40:38 +01:00

Kotlin bindings for the Rust SDK crypto layer.

Prerequisites

Rust

To build the bindings Rust will be needed it can be either installed using an OS specific package manager or directly with the provided installer.

Android NDK

The Android NDK will be required as well, it can be installed either through Android Studio or directly using an installer.

Uniffi

The bindings are using uniffi to generate the C translation layer between Rust and Kotlin. Uniffi is a Rust project and can be installed with our freshly installed Rust setup using:

$ cargo install uniffi_bindgen

Configuring Rust for cross compilation

First we'll need to install the Rust target for our desired Android architecture, for example:

# rustup target add aarch64-linux-android

This will add support to cross-compile for the aarch64-linux-android target, Rust supports many different targets, you'll have to make sure to pick the right one for your device or emulator.

After this is done, we'll have to configure Cargo to use the correct linker for our target. Cargo is configured using a TOML file that will be found in %USERPROFILE%\.cargo\config.toml on Windows or $HOME/.cargo/config on Unix platforms. More details and configuration options for Cargo can be found in the official docs over here.

[target.aarch64-linux-android]
ar = "NDK_HOME/toolchains/llvm/prebuilt/linux-x86_64/bin/ar"
linker = "NDK_HOME/toolchains/llvm/prebuilt/linux-x86_64/bin/aarch64-linux-android30-clang"

Building

A Makefile is provided that builds and installs the dynamic library into the appropriate target specific jniLibs directory. But before we can get started we'll need to tweak our Rust setup to allow cross compilation.

To enable cross compilation fro olm-sys which builds our libolm C library we'll need to set the ANDROID_NDK environment variable to the location of our Android NDK installation.

$ export ANDROID_NDK=$HOME/Android/Sdk/ndk/22.0.7026061/

Makefile build

After the prerequisites have been installed and the environment variable has been set a build for the aarch64 target can be build using:

make aarch64

Manual build

If the Makefile doesn't work on your system, the bindings can built for the aarch64 target with:

$ cargo build --target aarch64-linux-android

After that, a dynamic library can be found in the target/aarch64-linux-android/debug directory. The library will be called libmatrix_crypto.so and needs to be renamed and copied into the jniLibs directory:

$ cp target/aarch64-linux-android/debug/libmatrix_crypto.so \
     ../matrix-sdk-android/src/main/jniLibs/aarch64/libuniffi_olm.so