mirror of
https://github.com/logos-messaging/nim-chat-poc.git
synced 2026-01-02 14:13:10 +00:00
Nim Chat POC
This is the technical proof of a modular e2ee chat protocol using Waku. You can find discussion and details here
See EchoBot for a minimal client side usage example. See Client for the main entry point to the SDK
Quick Start
# Build Dependencies and link libraries
make update
# Build executables
make all
# Run tests
make tests
# Run an example of two clients communicating
./build/pingpong
Details
Features
Current state of the ChatSDK FURPS
| ID | Feature | Status | Notes |
|---|---|---|---|
| F1 | Permissionless Accounts | ✅ | |
| F2 | 1:1 Messaging | ✅ | |
| F3 | FS + PCS | 🟡 | PCS in place — needs noise implementation |
| F4 | Delivery Receipts | ✅ | |
| F5 | Basic Content Types | ✅ | Types need formal definition; plugin system prototyped |
| F6 | Default Message Store | 🚫 | Wont do - api changed, apps handle message storage |
| F7 | Default Secrets Store | ➡️ | Deferred - Not required for dev api preview |
| U1 | Non-interactive Initiation | ✅ | |
| U2 | Invite Links | ✅ | |
| U3 | 25 Lines of Code | ✅ | |
| R1 | Dropped Message Detection | 🚫 | Wont do - uses reliable channels |
| P1 | 10K Active Clients | ⚪ | |
| S1 | RLN Compatible | 🟡 | RLN supported, but not implemented yet |
| S2 | Future Proof | 🟡 | |
| S3 | Go Bindings | 🚫 | Wont do - Refocus on Logos-core |
| S4 | Rust Bindings | 🚫 | Wont do - Refocus on Logos-core |
| +1 | Sender Privacy | ✅ | Needs verification |
| +2 | Membership Privacy | 🟡 | Needs verification |
| +3 | User Activity Privacy | 🟡 | Needs verification |
| +4 | Nimble Compatible | ⛔ | Blocked — upstream dependency conflicts |
Message Flow
To establish a secure conversation, Saro and Raya need to:
- Find each others identityKeys
- Agree on a secret key, and location to communicate
For this technical proof, recipient identity keys are exchanged out of bound via an invite link. More complex identity systems will be explored in the future. ..
sequenceDiagram
participant S as Saro
participant R as Raya
Note over R,S: Discovery
R -->> S: Send Invite Link via established channel
Note over R,S: Initialization
S ->> R: PrivateV1 Invite
Note over R,S: Operation
loop
par
R->> S: Send Message
and
S->> R: Send Message
end
end
Limitations
.protofiles are included in this repo due to complications in importing nested packages using?subdir=. Once resolved there will be a single definition of protocol types.- Messages are sent using waku, however wakunode discovery has not been implemented. As a stopgap a manual discovery process based on staticpeers is used.
License
Description
Languages
Nim
94.5%
Makefile
4.2%
Shell
1.3%