lazysodium-android

Lazysodium (Android) makes it effortless for Android developers to get started with Libsodium's cryptography.

License

License

GroupId

GroupId

com.goterl
ArtifactId

ArtifactId

lazysodium-android
Last Version

Last Version

5.0.2
Release Date

Release Date

Type

Type

aar
Description

Description

lazysodium-android
Lazysodium (Android) makes it effortless for Android developers to get started with Libsodium's cryptography.
Project URL

Project URL

https://github.com/terl/lazysodium-android
Source Code Management

Source Code Management

http://github.com/terl/lazysodium-android

Download lazysodium-android

How to add to project

<!-- https://jarcasting.com/artifacts/com.goterl/lazysodium-android/ -->
<dependency>
    <groupId>com.goterl</groupId>
    <artifactId>lazysodium-android</artifactId>
    <version>5.0.2</version>
    <type>aar</type>
</dependency>
// https://jarcasting.com/artifacts/com.goterl/lazysodium-android/
implementation 'com.goterl:lazysodium-android:5.0.2'
// https://jarcasting.com/artifacts/com.goterl/lazysodium-android/
implementation ("com.goterl:lazysodium-android:5.0.2")
'com.goterl:lazysodium-android:aar:5.0.2'
<dependency org="com.goterl" name="lazysodium-android" rev="5.0.2">
  <artifact name="lazysodium-android" type="aar" />
</dependency>
@Grapes(
@Grab(group='com.goterl', module='lazysodium-android', version='5.0.2')
)
libraryDependencies += "com.goterl" % "lazysodium-android" % "5.0.2"
[com.goterl/lazysodium-android "5.0.2"]

Dependencies

compile (1)

Group / Artifact Type Version
net.java.dev.jna : jna jar 5.8.0

Project Modules

There are no modules declared in this project.

Lazysodium Android

Lazysodium is a complete Android implementation of the Libsodium library that provides developers with a smooth and effortless cryptography experience.

Checks Maven Central

Why Lazysodium

We created Lazysodium because we really wanted a solid Libsodium compatible Java/Android library that would just work without fuss. We were exasperated and annoyed with current Libsodium implementations as some of them were just poorly maintained and poorly architected.

You can find more info here.

Used by

Name Short description
WordPress WordPress, one of the largest website builders, has Lazysodium powering their encryption in their Android app.
Threema (SaltyRTC) Threema is a global end-to-end encrypted chatting app and SaltyRTC is their protocol for encryption.
OpenHAB OpenHAB allows you to automate and superpower your home.
PayPay CardPaymentSDK is a card payments library to make payments through several payment methods painless. It uses PayPay as an endpoint to establish a payment security channel.
UXBOX UXBox, the open-source solution for design and prototyping
E3DB An encrypted NoSQL database designed from the ground-up for user privacy and security.
ADAMANT The most private messenger possible. Your device does not store any info. It directly interacts with the blockchain, where every byte is fully-encrypted.
Kepler A small TCP server written in Java powered by Netty, an asynchronous networking library.
Regen Ledger A global marketplace & contracting platform for Earth's ecosystem assets, services, and data.
Tezos The TezosJ SDK library enables plain Java developers to create applications that communicates with Tezos blockchain.
Exonum Exonum Java Binding is a framework for building blockchain applications in Java, powered by Exonum.
Paseto Java Implementation of Platform-Agnostic Security Tokens.
Recordo A super secure diary/journal that provides end to end encryption.

Features

This library is fully compatible with Kotlin powered Android projects.

You can find an up-to-date feature list here.

Quick start

This is by no means a comprehensive introduction to Lazysodium. Please view the official documentation for a more comprehensive guide.

1. Install

Whatever build tool you're using the general gist is to add the mavenCentral() repository and then add the Lazysodium dependency. More detailed instructions here.

The following example is for users of the build tool Gradle:

// Top level build file
repositories {
    // Add this to the end of any existing repositories
    mavenCentral()
}

// Project level dependencies section
dependencies {
    implementation "com.goterl:lazysodium-android:VERSION_NUMBER@aar"
    implementation "net.java.dev.jna:jna:5.5.0@aar"
}

Substitute VERSION_NUMBER for the version in this box:

Maven Central

2. Let's go!

You can now initialise and start encrypting! Please note that this library follows the official libsodium docs closely. You need to use those docs to help you find the functions you need.

// Let's initialise LazySodium, perhaps in an Application class somewhere
LazySodiumAndroid lazySodium = new LazySodiumAndroid(new SodiumAndroid());

Let's encrypt! Again, most of them are available on the official libsodium documentation.

// Cast our lazySodium object so we're only using "lazy" methods, 
// i.e methods that do the heavy work of encryption.
SecretBox.Lazy secretBoxLazy = (SecretBox.Lazy) lazySodium;
String message = "This is a super secret message.";

// Generate a symmetric key to encrypt the message.
Key key = secretBoxLazy.cryptoSecretBoxKeygen();

// Generate a random nonce.
byte[] nonce = lazySodium.nonce(SecretBox.NONCEBYTES);

// Encrypt now! Now you have a super secure encrypted message
// available in the variable cipher.
String cipher = secretBoxLazy.cryptoSecretBoxEasy(message, nonce, key);

3. You decide

Every project is different, you may need to use lower-level APIs to achieve the control you need so you use the Native interface. Or alternatively you just don't want to deal with the details so you stick to the Lazy interface.

Every interface you can cast to is helpfully all in one directory so you can easily pick the functions you need. This isolates your code and prevents you from making mistakes.

Important: If possible, please stick to using either the Native or the Lazy interface. The reason for this is that the Lazy interface defaults to converting everything to hexadecimal whereas the Native interface assumes everything is non-hexadecimal. If you don't know what you're doing, you could end up making mistakes.

You can provide your own encoder as follows:

// Base64MessageEncoder has to implement our MessageEncoder interface
Base64MessageEncoder encoder = new Base64MessageEncoder(); 
// ... then from now on all Lazy methods will be encoded in Base64.
LazySodiumAndroid lazySodium = new LazySodiumAndroid(new SodiumAndroid(), encoder); 

Documentation

See our official documentation to get started.

Apps

You can preview some of the features in our free Lazysodium app available on Google Play:

Get it on Google Play

Lazysodium for Java

We also have a Java implementation available at Lazysodium for Java. It has the same API as this library so you can share code easily!


Created by Terl.

com.goterl

Terl

Providing wellbeing and relief through technology.

Versions

Version
5.0.2
5.0.1
5.0.0