Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hpn4/hmessager
HMessager is a Android decentralized messaging app providing end-to-end encryption based on the Signal Protocol and built with Jetpack Compose
https://github.com/hpn4/hmessager
android double-ratchet-algorithm end-to-end-encryption jetpack-compose signal-protocol x3dh
Last synced: 3 months ago
JSON representation
HMessager is a Android decentralized messaging app providing end-to-end encryption based on the Signal Protocol and built with Jetpack Compose
- Host: GitHub
- URL: https://github.com/hpn4/hmessager
- Owner: Hpn4
- Created: 2023-08-11T17:34:52.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2024-04-22T21:18:29.000Z (9 months ago)
- Last Synced: 2024-09-26T14:01:37.242Z (3 months ago)
- Topics: android, double-ratchet-algorithm, end-to-end-encryption, jetpack-compose, signal-protocol, x3dh
- Language: Kotlin
- Homepage:
- Size: 561 KB
- Stars: 5
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# HMessager
HMessager is a decentralized messaging app for Android based on the [Signal Protocol](https://signal.org/docs/) and build with [Jetpack Compose](https://developer.android.com/jetpack/compose).
This project is under development and not ready for use.
## Server
To setup a server you just have to run the script `server.py` located in the `server` folder.
You can run it on a public IP or in a private network and then do port-forwarding.The code is pretty straightforward, it's just a simple Websocket server that listen for connections and then forward the messages to clients based on hashed identity if they are connected or store message locally if not.
Then in HMessager, go to the settings screen and enter the IP and port of your server.
---
## Create conversation
To create a conversation with someone, you have to scan his QR code and he must scan yours.
1. Click on the message icon in the bottom right corner of the home screen
2. Click on the scan button to scan the QR code of the person you want to chat with
3. Then click on the code button to show your QR code to the other person
4. The other person must scan your QR code
5. You can now create the conversation---
## Security
The [X3DH](https://signal.org/docs/specifications/x3dh/) and the [double ratchet algorithm](https://signal.org/docs/specifications/doubleratchet/) are used to provide end-to-end encryption.
### Data storage
All your conversations, settings, keys and messages (including medias) are stored in the files storage of the app inaccessible to other apps and you.
Their are also encrypted with different keys derived from a password that you have to enter when you open the app.The first time you open the app, you need to choose your password, this password will then be used to derive a master key.
If you forget your password, you will lose all your data and it's impossible to recover them so be aware of that.### Algorithms used
- SHA3-512 and SHA3-256 for hashing
- X3DH with Curve25519 for key agreement
- HKDF with SHA3-512 for key derivation
- AES-256 for encryption
- Ed25519 for signatures
- HMAC with SHA3-512 for message authentication---
## Features
- [x] End-to-end encryption with a double ratchet algorithm
- [x] Send and receive text messages
- [x] Send and receive emojis only messages (big emojis)
- [x] Send and receive images and videos
- [x] Send and receive audio messages (with waveform)
- [x] Send and receive files
- [x] Choose images/video from gallery
- [x] Choose files/audio from file explorer
- [x] Take pictures/video with camera
- [x] Record audio with microphoneCurrently group conversations are not supported, it's only possible to chat with one person at a time.
## Screenshots
Here an exemple of a conversation with the app.
---
## TODO
- [ ] Add support to reply to a message (quote)
- [ ] Add support for message reactions (emojis)
- [ ] Add support for message deletion
- [ ] Add support for text style in message (bold, italic, code, puce list, header...)
- [ ] Add support for link preview
- [ ] Group medias together (images and videos in a single message)
- [ ] Add multiple themes