Local network secure P2P communications
Go to file
Matéo Duparc 335e786f79
Show file name on saving
2021-06-20 16:12:01 +02:00
app Show file name on saving 2021-06-20 16:12:01 +02:00
gradle/wrapper Refresh name feature 2021-05-11 16:18:01 +02:00
.gitignore Genesis 2021-05-03 13:26:07 +02:00
LICENSE Genesis 2021-05-03 13:26:07 +02:00
README.md Display local IP addresses & Safe messages parsing 2021-05-04 20:42:53 +02:00
build.gradle Avatars 2021-05-27 20:15:03 +02:00
gradle.properties Genesis 2021-05-03 13:26:07 +02:00
gradlew Genesis 2021-05-03 13:26:07 +02:00
gradlew.bat Genesis 2021-05-03 13:26:07 +02:00
settings.gradle Genesis 2021-05-03 13:26:07 +02:00

README.md

AIRA Android

AIRA is peer-to-peer encrypted communication tool for local networks built on the PSEC protocol. It allows to securely send text messages and files without any server or Internet access. AIRA automatically discovers and connects to other peers on your network, so you don't need any prior configuration to start communicating.

Here is the Android version. You can find the original AIRA desktop version here.

Disclaimer

AIRA is still under developement and is not ready for production usage yet. Not all features have been implemented and bugs are expected. Neither the code or the PSEC protocol received any security audit and therefore shouldn't be considered fully secure. AIRA is provided "as is", without any warranty of any kind.

Features

  • End-to-End encryption using the PSEC protocol
  • Automatic peer discovery using mDNS
  • Manual peer connection
  • File transferts
  • Notifications
  • Encrypted database
  • Contact verification
  • IPv4/v6 compatibility
  • Free/Libre and Open Source

Build

Install Rust

AIRA android uses some code from the desktop version which is written in Rust. Therefore, you need to compile this Rust code first.

curl --proto '=https' --tlsv1.3 -sSf https://sh.rustup.rs | sh
rustup target add aarch64-linux-android armv7-linux-androideabi

Install NDK

The Rust code uses a crate called "rusqlite" to store data in SQLite databases. This crates uses the original SQLite3 library written in C. Therefore, to compile it you need the Android NDK. You can find instructions to install the NDK here: https://developer.android.com/ndk/guides

Once installed, you need to define the $ANDROID_NDK_HOME environment variable (if not already set):

export ANDROID_NDK_HOME=/home/<user>/Android/SDK/ndk/<NDK version>"

Download AIRA

git clone --depth=1 https://forge.chapril.org/hardcoresushi/AIRA-android.git && cd AIRA-android

Verify commit

git verify-commit HEAD

Build AIRA Rust code

cd app/src/main/native
./build.sh

Build final APK

If you have AndroidStudio installed, you can just open the project directory and then start the build process. Otherwise, you can use Gradle from the command line:

Generate a signed APK with your keystore:

# From the project root directory:
./gradlew assembleRelease -Pandroid.injected.signing.store.file=<KEYFILE> -Pandroid.injected.signing.store.password=<STORE_PASSWORD> -Pandroid.injected.signing.key.alias=<KEY_ALIAS> -Pandroid.injected.signing.key.password=<KEY_PASSWORD>

Generate an unsigned APK:

./gradlew assembleRelease

Once completed, the APKs will be located under app/build/outputs/apk/release/.

If you generate an unsigned APK you won't be able to install it as-is on your device. You will need to force install it with ADB:

adb install app-release-unsigned.apk