Android SDK Database Encryption
Overview
You can encrypt the Android SDK database. There are 2 options to add encryption to the SDK database.
Option #1: Using a custom sqlite build with database encryption extension
The following steps describe using the sqleet database encryption extension, but you can use any sqlite database encryption extension.
- Go to the sqleet releases page.
- From the latest release, download sqleet-v0.28.0-amalgamation.zip or sqleet-v0.28.0-amalgamation.tar.gz.
- Extract the sqleet-v0.28.0-amalgamation file content.
- Rename the following files:
- sqleet.h to sqlite3.h
- sqleet.c to sqlite3.c
- Download the latest sqlite build.
- Extract the content of the file.
- Replace the sqlite3.h & sqlite3.c files in SQLite_Android_Bindings/sqlite3/src/main/jni/sqlite with the files you renamed on step #4.
- Open the SQLite_Android_Bindings folder as a project in Android Studio.
- Run the gradle assembleRelease.
- Open your application's project (the application that uses the sdk) in Android Studio.
- Click File -> New -> New Module.
- Select import Jar / AAR package.
- Select sqlite3-release.aar from the SQLite_Android_Bindings project in SQLite_Android_Bindings/sqlite3/build/outputs/aar.
- After the module is created, add the following to your application's build.gradle file dependencies:
implementation project(path: ':sqlite3-release')
- In the "database" section of the MceConfig.json file, set the following:
"database":
{ "impl": "co.acoustic.mobile.push.sdk.db.custom.CustomSqliteDatabaseImpl", "encrypted": true }
- Your application will now run with an encrypted sdk database.
Optional settings:
You can add the following to the "database" section of the MceConfig.json file:
"keyRotationIntervalInDays": <number of days>
This will set the number of days that will pass between every database key rotation. The default is 30. The minimum is 1."encryptionProvider": "<encryption provider class name>"
The sdk defines a default encryption provider. This provider uses the keystore to store the key that encrypts the database secret key for Android 18 and above. For Android 17 and below, the sdk uses a code base encryption which is less secure. To have your own encryption you can start your own class that implements co.acoustic.mobile.push.sdk.api.encryption.SdkEncryptionProvider, and set this class' name as encryptionProvider. If you want to override our Android 17 and below encryption, you can extend the sdk encryption generator (package co.acoustic.mobile,push.sdk.encryption.DefaultSdkEncryptionProvider) and return your co.acoustic.mobile,push.sdk.api.encryption.EncryptionAlgorithm implementation only when OS level is 17 or below. Here is a sample code:
import android.os.Build;
import co.acoustic.mobile.push.sdk.api.encryption.EncryptionAlgorithm;
import co.acoustic.mobile.push.sdk.encryption.DefaultSdkEncryptionProvider;
public class SampeEncryptionProviderForAndroid17AndBelow extends DefaultSdkEncryptionProvider {
@Override
public EncryptionAlgorithm getEncryptionAlgorithm() {
if(Build.VERSION.SDK_INT>= Build.VERSION_CODES.JELLY_BEAN_MR2)
{ return super.getEncryptionAlgorithm(); }else
{ // return your provider }}
}
"keyGenerator": "<database secret key generator class name>"
The sdk defines a default database secret key generator that uses a random UUID. If you want to use you own key generator, you can have your own implementation that implements co.acoustic.mobile.push.sdk.api.db.SdkDatabaseSecretKeyGenerator and set your class name as "keyGenerator".
Upgrade, Downgrade an unencrypting options
- You can upgrade an older sdk version to an encrypted version.
- If you downgrade an encrypted version to an older sdk version that does not support encryption, the database will be erased and the sdk will start with a new database (all registration data will remain).
- If you want to replace an encrypted database with an unencrypted database using an encryption supporting sdk, keep the custom sqlite implementation and only change "encrypted" to false. After the application is updated and the database is unencrypted, your next update can be with the default sdk database ("impl":
"co.acoustic.mobile.push.sdk.db.android.AndroidDatabaseImpl" or no "impl" value at all) that is based on the Android OS sqlite version and you can remove the sqlite3-release package from your application project.
Option #2: Using a completely custom database
For your own custom database that is not based on the sdk code, you can create you own implementation based on the following API classes:
- co.acoustic.mobile.push.sdk.api.db.SdkDatabase
- co.acoustic.mobile.push.sdk.api.db.SdkDatabaseCursor
- co.acoustic.mobile.push.sdk.api.db.SdkDatabaseOpenHelper
- co.acoustic.mobile.push.sdk.api.db.SdkDatabaseQueryBuilder
- co.acoustic.mobile.push.sdk.api.db.SdkDatabaseImpl
- Set "impl" in the "database" section of the MceConfig.json file to be the name of your class that implements
co.acoustic.mobile.push.sdk.api.db.SdkDatabaseImpl
. - The rest of the parameters in the "database" section are not relevant to fully custom databases.
Updated 9 months ago