React Native Indy SDK wrapper.
with npm:
$ npm install indy-sdk-react-native --save
with Yarn:
$ yarn add indy-sdk-react-native
Link (for React Native lower than 0.60)
$ react-native link indy-sdk-react-native
See https://github.com/TimoGlastra/ExampleRnIndySDK for an example android react native project that follows this tutorial.
Make sure there is a min. SDK version setup in android/build.gradle
:
buildscript {
ext {
...
minSdkVersion = 21
...
}
}
Add Sovrin Maven repository into android/build.gradle
:
allprojects {
repositories {
...
maven {
url 'https://repo.sovrin.org/repository/maven-public'
}
...
}
}
Add to android/app/build.gradle
:
dependencies {
// ...
implementation 'net.java.dev.jna:jna:5.2.0'
// ...
}
Download Android libindy binaries and copy them into android/app/src/main/jniLibs
.
- Create
android/app/src/main/jniLibs
directory in your project - Create subdirectories
arm64-v8a
,armeabi-v7a
,x86
andx86_64
insideandroid/app/src/main/jniLibs
. - Download the required libindy binaries for your release-channel and version
- with
stable
channel and version1.15.0
base url will be https://repo.sovrin.org/android/libindy/stable/1.15.0/ - download the binaries for
arm64
,armv7
,x86
andx86_64
, e.g.:libindy_android_arm64_1.15.0.zip
libindy_android_armv7_1.15.0.zip
libindy_android_x86_1.15.0.zip
libindy_android_x86_64_1.15.0.zip
- with
- Extract all downloaded ZIP files and copy
libindy.so
files to correspondingjniLibs
directorylibindy_arm64/lib/libindy.so
tojniLibs/arm64-v8a/libindy.so
libindy_armv7/lib/libindy.so
tojniLibs/armeabi-v7a/libindy.so
libindy_x86/lib/libindy.so
tojniLibs/x86/libindy.so
libindy_x86_64/lib/libindy.so
tojniLibs/x86_64/libindy.so
- Download the required JNA binaries from the JNA GitHub repo
- libindy version 1.15.0 works with version 5.5.0 of JNA. In this case the base url is: https://github.com/java-native-access/jna/tree/5.5.0/lib/native
- download the binaries for
aarch64
,armv7
,x86
,x86-64
, e.g.:android-aarch64.jar
android-armv7.jar
android-x86-64.jar
android-x86.jar
- Extract all downloaded JAR files and copy
libjnidispatch.so
to correspondingjniLibs
directory- You can extract the
.so
file from the jar using thejar
command. e.g.jar xf android-x86.jar
libjnidispatch.so
fromandroid-aarch64.jar
tojniLibs/arm64-v8a/libjnidispatch.so
libjnidispatch.so
fromandroid-armv7.jar
tojniLibs/armeabi-v7a/libjnidispatch.so
libjnidispatch.so
fromandroid-x86.jar
tojniLibs/x86/libjnidispatch.so
libjnidispatch.so
fromandroid-x86-64.jar
tojniLibs/x86_64/libjnidispatch.so
- You can extract the
Add the following to MainActivity.java
:
//...
import android.os.Bundle;
import android.system.ErrnoException;
import android.system.Os;
import java.io.File;
public class MainActivity extends ReactActivity {
//...
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
try {
Os.setenv("EXTERNAL_STORAGE", getExternalFilesDir(null).getAbsolutePath(), true);
System.loadLibrary("indy");
} catch (ErrnoException e) {
e.printStackTrace();
}
}
}
- Install CocoaPods dependencies:
pod install --project-directory=ios/
-
Create
Frameworks
folder in your project'sios/Pods
directory and copyIndy.framework
into that directory. The most recent version of theIndy.Framework
can be found here. -
[Optional] Most projects have
ios/Pods
ignored in their.gitignore
. This is good practice, however this means the framework would need to be added after every clone. To prevent this you can "unignore" the Frameworks directory:
ios/Pods/
!ios/Pods/Frameworks
- Add
Indy.framework
as dependency into your project. Open.xcworkspace
file in Xcode and in your project settings, tab General, section Frameworks, Libraries, and Embedded Content, click on plus. Then select Add Other -> Add files... and navigate toIndy.framework
file on your disk.
Beware that the Indy SDK repository does not have the "Build Libraries for Distribution" enabled by default. If that setting is disabled the version of Swift your project uses must be the same as the version of Swift used to compile
Indy.framework
. From Swift 5.0 onwards, building the library with that setting enabled will allow to use anIndy.framework
build that is compiled with a different version of Swift as your project. See https://stackoverflow.com/a/63305234/10552895 for more info.
import indy from 'indy-sdk-react-native'
await indy.createWallet({ id: 'wallet-123' }, { key: 'key' })
You can see example project here https://github.com/jakubkoci/UseReactNativeIndySdk/. It currently shows only usage on Android.
I found an error with permission while calling createWallet
when I was testing this package:
2020-01-27 16:25:02.300 9955-10044/com.usereactnativeindysdk E/log_panics: thread 'unnamed' panicked at 'called `Result::unwrap()` on an `Err` value: Os { code: 13, kind: PermissionDenied, message: "Permission denied" }': libcore/result.rs:945
Modify onCreate
method in MainActivity
of your project where you want to use this library in a following way:
public class MainActivity extends ReactActivity {
...
@Override
protected void onCreate(Bundle savedInstanceState) {
...
File externalFilesDir = getExternalFilesDir(null);
String path = externalFilesDir.getAbsolutePath();
System.out.println("externalFilesDir=" + path);
try {
Os.setenv("EXTERNAL_STORAGE", path, true);
} catch (ErrnoException e) {
e.printStackTrace();
}
...
}
...
}
This should resolve the issue with permissions.