A Java JNI binding (to allow for Java and Android integration) to Networking and Cryptography library by Daniel J. Bernstein.
If you do use this project in your research project, please do cite this repo. Thanks!
Credits to:
- Libsodium: author Frank Denis and Contributors
- Kalium: author abstractj and Contributors
- Robosodium: author GerardSoleCa
- libstodium: author ArteMisc
- Java package is under org.libsodium.jni
- Maven coordinates are in the Sonatype OSS snapshot repository. View all artifacts here
<dependency>
<groupId>com.github.joshjdevl.libsodiumjni</groupId>
<artifactId>libsodium-jni-aar</artifactId>
<version>1.0.2-SNAPSHOT</version>
<type>aar</type>
</dependency>
<dependency>
<groupId>com.github.joshjdevl.libsodiumjni</groupId>
<artifactId>libsodium-jni</artifactId>
<version>1.0.2-SNAPSHOT</version>
<type>jar</type>
</dependency>
Install brew
Run ./build-mac.sh
Run ./build-linux.sh
Clone the repo and import project from folder example/Sodium in Android studio (Android studio 2.1). Android studio will handle the rest. Compile and run. Tested to emulators down to Android Version 16.
To use the AAR project as is (No .SO file imports needed).
It is also possible to build the AAR library yourself using the provided scripts linux or mac. After building the library open module settings and add the libsodium-jni-release.aar and/or libsodium-jni-debug.aar as a dependency.
To use the library with your own custom code, skip the aar file and add
- The native .SO libraries in your project (Create jnilibs folder and make the required changes to the gradle file)
- Add the source code from the src folder and add your own additional code.
###Docker Container
The docker container is available from libsodium-jni which is a Automated Build.
Please refer to the docker build for the commands used to build.
libsodium-jni is a work in progress, feedback, bug reports and patches are always welcome.
Everything has been tested and working on ubuntu 12.04 32bit and 64 bit, macos, and Android