Encrypted overlay filesystems implementation for Android. Also available on GitHub: https://github.com/hardcore-sushi/DroidFS
Go to file
Atrate 85f5aac441 Make app movable to SD card
Signed-off-by: Atrate <Atrate@protonmail.com>
2020-09-21 19:32:29 +02:00
app Make app movable to SD card 2020-09-21 19:32:29 +02:00
gradle/wrapper Updating to gradle 6.6.1 2020-09-08 11:27:07 +02:00
Screenshots Updating README.md 2020-08-27 12:00:45 +02:00
.gitignore Inital commit 2020-07-17 22:12:20 +02:00
build.gradle Inital commit 2020-07-17 22:12:20 +02:00
gradle.properties Inital commit 2020-07-17 22:12:20 +02:00
gradlew Updating to gradle 6.6.1 2020-09-08 11:27:07 +02:00
gradlew.bat Updating to gradle 6.6.1 2020-09-08 11:27:07 +02:00
LICENSE.txt Inital commit 2020-07-17 22:12:20 +02:00
README.md Updating description 2020-09-07 20:22:40 +02:00
settings.gradle Inital commit 2020-07-17 22:12:20 +02:00

DroidFS

DroidFS is an alternative way to use encrypted overlay filesystems on Android that uses its own internal file explorer instead of mounting virtual volumes. It currently only works with gocryptfs but support for CryFS is expected to be added soon.

Disclamer

DroidFS is provided "as is", without any warranty of any kind. It shouldn't be considered as an absolute safe way to store files. DroidFS cannot protect you from screen recording apps, keyloggers, apk backdooring, compromised root accesses, memory dumps etc. Do not use this app with volumes containing sensitive data unless you know exactly what you are doing.

Permissions

DroidFS need some permissions to work properly. Here is why:

  • Read & write access to shared storage:

    Required for creating, opening and modifying volumes and for importing/exporting files to/from volumes.
  • Biometric/Fingerprint hardware:

    Required to encrypt/decrypt password hashes using a fingerprint protected key.
  • Camera:

    Needed to take photos directly from DroidFS to import them securely.

Unsafe features

DroidFS allows you to enable/disable unsafe features to fit your needs between security and comfort. It is strongly recommended to read the documentation of a feature before enabling it.

  • Allow screenshots:

    Disable the secure flag of DroidFS activities. This will allow you to take screenshots from the app, but will also allow other apps to record the screen while using DroidFS. Note: apps with root access don't care about this flag: they can take screenshots or record the screen of any app without any permissions.
  • Allow opening files with other applications:

    Decrypt and open file using external apps. This require writing the plain file to disk (DroidFS internal storage).
  • Allow exporting files:

    Decrypt and write file to disk (external storage). Any app with storage permissions can access exported files.
  • Allow sharing files via the android share menu:

    Decrypt and share file with other apps. This require writing the plain file to disk (DroidFS internal storage).
  • Allow saving password hash using fingerprint:

    Generate an AES-256 GCM key in the Android Keystore (protected by fingerprint authentication), then use it to encrypt the volume password hash and store it to the DroidFS internal storage. This require Android v6.0+.

Download

You can download the latest version here.

Build

Most of the original gocryptfs code was used as is (written in Go) and compiled to native code. That's why you need Go and the Android Native Development Kit (NDK) to build DroidFS from source.

Install Requirements

Download Sources

$ git clone https://github.com/hardcore-sushi/DroidFS.git

Gocryptfs need openssl to work:

$ cd DroidFS/app/libgocryptfs
$ wget -qO - https://www.openssl.org/source/openssl-1.1.1g.tar.gz | tar -xvzf -

Build

First, we need to build libgocryptfs.
Retrieve your Android NDK installation path, usually someting like "<Android SDK path>/ndk/<NDK version>".

$ cd DroidFS/app/libgocryptfs
$ env ANDROID_NDK_HOME="<your ndk path>" OPENSSL_PATH="./openssl-1.1.1g" ./build.sh

Then, open the DroidFS project with Android Studio.
If a device (virtual or physical) is connected, just click on "Run".
If you want to generate a signed APK, you can follow this post.

Third party code

Thanks to these open source projects that DroidFS uses:

Modified code:

Libraries: