feat(client): v2 REPL over SDK with categorized help and tab-completion
925-line REPL replacing the 3317-line monolith — delegates all crypto, MLS, and RPC to quicproquo-sdk. 20 commands across 6 categories (messaging, groups, account, keys, utility, debug), rustyline tab completion, background event listener, auto-server-launch. Also adds SDK accessor methods (server_addr_string, config_state_path), WS bridge register handler, and README table formatting cleanup.
This commit is contained in:
168
README.md
168
README.md
@@ -24,18 +24,18 @@ agreement across any number of participants. Messages are framed with
|
||||
└─────────────────────────────────────────────┘
|
||||
```
|
||||
|
||||
| Property | Mechanism |
|
||||
|---|---|
|
||||
| Transport confidentiality | TLS 1.3 over QUIC (rustls) |
|
||||
| Transport authentication | TLS 1.3 server cert (self-signed or CA) |
|
||||
| Group key agreement | MLS `MLS_128_DHKEMX25519_AES128GCM_SHA256_Ed25519` |
|
||||
| Post-compromise security | MLS epoch ratchet |
|
||||
| Forward secrecy | Per-epoch key schedule |
|
||||
| Identity | Ed25519 (MLS credential + leaf node signature) |
|
||||
| Password auth | OPAQUE (password never sent to server) |
|
||||
| Post-quantum readiness | X25519 + ML-KEM-768 hybrid KEM envelope |
|
||||
| Local storage encryption | SQLCipher + Argon2id + ChaCha20-Poly1305 |
|
||||
| Message framing | Cap'n Proto (unpacked wire format) |
|
||||
| Property | Mechanism |
|
||||
| ------------------------- | -------------------------------------------------- |
|
||||
| Transport confidentiality | TLS 1.3 over QUIC (rustls) |
|
||||
| Transport authentication | TLS 1.3 server cert (self-signed or CA) |
|
||||
| Group key agreement | MLS `MLS_128_DHKEMX25519_AES128GCM_SHA256_Ed25519` |
|
||||
| Post-compromise security | MLS epoch ratchet |
|
||||
| Forward secrecy | Per-epoch key schedule |
|
||||
| Identity | Ed25519 (MLS credential + leaf node signature) |
|
||||
| Password auth | OPAQUE (password never sent to server) |
|
||||
| Post-quantum readiness | X25519 + ML-KEM-768 hybrid KEM envelope |
|
||||
| Local storage encryption | SQLCipher + Argon2id + ChaCha20-Poly1305 |
|
||||
| Message framing | Cap'n Proto (unpacked wire format) |
|
||||
|
||||
---
|
||||
|
||||
@@ -73,47 +73,47 @@ agreement across any number of participants. Messages are framed with
|
||||
|
||||
### REPL slash commands
|
||||
|
||||
| Command | Description |
|
||||
|---|---|
|
||||
| `/dm <username>` | Start a 1:1 DM with a peer |
|
||||
| `/create-group <name>` (or `/cg`) | Create a new group |
|
||||
| `/invite <username>` | Add a member to the current group |
|
||||
| `/remove <username>` | Remove a member from the current group |
|
||||
| `/join` | Join a pending group invitation |
|
||||
| `/leave` | Leave the current group |
|
||||
| `/switch @user` or `/switch #group` | Switch active conversation |
|
||||
| `/list` or `/ls` | List all conversations |
|
||||
| `/members` | Show group members with resolved usernames |
|
||||
| `/group-info` (or `/gi`) | Show group type, members, MLS epoch |
|
||||
| `/rename <name>` | Rename the current conversation |
|
||||
| `/history [count]` (or `/hist`) | Show message history (default 20) |
|
||||
| `/react <emoji> [index]` | React to a message with an emoji |
|
||||
| `/typing` | Send a typing indicator |
|
||||
| `/typing-notify on\|off` | Toggle typing indicator display |
|
||||
| `/edit <index> <text>` | Edit one of your messages |
|
||||
| `/delete <index>` | Delete one of your messages |
|
||||
| `/send-file <path>` (or `/sf`) | Upload and send a file (chunked, SHA-256 verified) |
|
||||
| `/download <index>` (or `/dl`) | Download a received file |
|
||||
| `/disappear <duration>` | Set message TTL (`30m`, `1h`, `1d`, `7d`) |
|
||||
| `/verify <username>` | Compare safety numbers with a peer |
|
||||
| `/update-key` (or `/rotate-key`) | Rotate your MLS key material |
|
||||
| `/delete-account` | Permanently delete your account (with confirmation) |
|
||||
| `/whoami` | Show identity and group status |
|
||||
| `/help` | Command reference |
|
||||
| `/quit` | Exit |
|
||||
| Command | Description |
|
||||
| ----------------------------------- | --------------------------------------------------- |
|
||||
| `/dm <username>` | Start a 1:1 DM with a peer |
|
||||
| `/create-group <name>` (or `/cg`) | Create a new group |
|
||||
| `/invite <username>` | Add a member to the current group |
|
||||
| `/remove <username>` | Remove a member from the current group |
|
||||
| `/join` | Join a pending group invitation |
|
||||
| `/leave` | Leave the current group |
|
||||
| `/switch @user` or `/switch #group` | Switch active conversation |
|
||||
| `/list` or `/ls` | List all conversations |
|
||||
| `/members` | Show group members with resolved usernames |
|
||||
| `/group-info` (or `/gi`) | Show group type, members, MLS epoch |
|
||||
| `/rename <name>` | Rename the current conversation |
|
||||
| `/history [count]` (or `/hist`) | Show message history (default 20) |
|
||||
| `/react <emoji> [index]` | React to a message with an emoji |
|
||||
| `/typing` | Send a typing indicator |
|
||||
| `/typing-notify on\|off` | Toggle typing indicator display |
|
||||
| `/edit <index> <text>` | Edit one of your messages |
|
||||
| `/delete <index>` | Delete one of your messages |
|
||||
| `/send-file <path>` (or `/sf`) | Upload and send a file (chunked, SHA-256 verified) |
|
||||
| `/download <index>` (or `/dl`) | Download a received file |
|
||||
| `/disappear <duration>` | Set message TTL (`30m`, `1h`, `1d`, `7d`) |
|
||||
| `/verify <username>` | Compare safety numbers with a peer |
|
||||
| `/update-key` (or `/rotate-key`) | Rotate your MLS key material |
|
||||
| `/delete-account` | Permanently delete your account (with confirmation) |
|
||||
| `/whoami` | Show identity and group status |
|
||||
| `/help` | Command reference |
|
||||
| `/quit` | Exit |
|
||||
|
||||
**Mesh commands** (requires `--features mesh`):
|
||||
|
||||
| Command | Description |
|
||||
|---|---|
|
||||
| `/mesh peers` | Scan for nearby qpq nodes via mDNS |
|
||||
| `/mesh server <host:port>` | Note a discovered server address |
|
||||
| `/mesh send <peer_id> <msg>` | Direct P2P message via iroh |
|
||||
| `/mesh broadcast <topic> <msg>` | Publish to a broadcast channel |
|
||||
| `/mesh subscribe <topic>` | Join a broadcast channel |
|
||||
| `/mesh route` | Show routing table |
|
||||
| `/mesh identity` | Show mesh identity info |
|
||||
| `/mesh store` | Show store-and-forward stats |
|
||||
| Command | Description |
|
||||
| ------------------------------- | ---------------------------------- |
|
||||
| `/mesh peers` | Scan for nearby qpq nodes via mDNS |
|
||||
| `/mesh server <host:port>` | Note a discovered server address |
|
||||
| `/mesh send <peer_id> <msg>` | Direct P2P message via iroh |
|
||||
| `/mesh broadcast <topic> <msg>` | Publish to a broadcast channel |
|
||||
| `/mesh subscribe <topic>` | Join a broadcast channel |
|
||||
| `/mesh route` | Show routing table |
|
||||
| `/mesh identity` | Show mesh identity info |
|
||||
| `/mesh store` | Show store-and-forward stats |
|
||||
|
||||
### Mesh networking (feature-gated: `--features mesh`)
|
||||
|
||||
@@ -200,20 +200,20 @@ See the [full demo walkthrough](docs/src/getting-started/demo-walkthrough.md) fo
|
||||
|
||||
## Crate layout
|
||||
|
||||
| Crate | Purpose |
|
||||
|---|---|
|
||||
| `quicproquo-core` | MLS group operations, hybrid KEM, OPAQUE auth, crypto primitives, WASM-compatible modules |
|
||||
| `quicproquo-proto` | Cap'n Proto schemas and generated RPC code |
|
||||
| `quicproquo-server` | QUIC server, NodeService RPC (24 methods), storage backends, federation, plugins, blob storage |
|
||||
| `quicproquo-client` | CLI + REPL (40+ commands), session management, conversation store, file transfer |
|
||||
| `quicproquo-ffi` | C FFI bindings (`libquicproquo_ffi.so`) for cross-language integration |
|
||||
| `quicproquo-plugin-api` | C-compatible plugin hook API (`HookVTable`, 6 hooks) |
|
||||
| `quicproquo-kt` | Key transparency / Merkle-log identity bindings |
|
||||
| `quicproquo-bot` | Programmable bot client framework |
|
||||
| `quicproquo-gen` | Code generation utilities |
|
||||
| `quicproquo-gui` | Tauri 2 desktop app (experimental, requires GTK) |
|
||||
| `quicproquo-mobile` | C FFI for mobile connection migration (experimental) |
|
||||
| `quicproquo-p2p` | iroh-based P2P transport, mesh identity, store-and-forward, broadcast channels |
|
||||
| Crate | Purpose |
|
||||
| ----------------------- | ---------------------------------------------------------------------------------------------- |
|
||||
| `quicproquo-core` | MLS group operations, hybrid KEM, OPAQUE auth, crypto primitives, WASM-compatible modules |
|
||||
| `quicproquo-proto` | Cap'n Proto schemas and generated RPC code |
|
||||
| `quicproquo-server` | QUIC server, NodeService RPC (24 methods), storage backends, federation, plugins, blob storage |
|
||||
| `quicproquo-client` | CLI + REPL (40+ commands), session management, conversation store, file transfer |
|
||||
| `quicproquo-ffi` | C FFI bindings (`libquicproquo_ffi.so`) for cross-language integration |
|
||||
| `quicproquo-plugin-api` | C-compatible plugin hook API (`HookVTable`, 6 hooks) |
|
||||
| `quicproquo-kt` | Key transparency / Merkle-log identity bindings |
|
||||
| `quicproquo-bot` | Programmable bot client framework |
|
||||
| `quicproquo-gen` | Code generation utilities |
|
||||
| `quicproquo-gui` | Tauri 2 desktop app (experimental, requires GTK) |
|
||||
| `quicproquo-mobile` | C FFI for mobile connection migration (experimental) |
|
||||
| `quicproquo-p2p` | iroh-based P2P transport, mesh identity, store-and-forward, broadcast channels |
|
||||
|
||||
---
|
||||
|
||||
@@ -234,15 +234,15 @@ GitHub Actions runs on every push and PR:
|
||||
|
||||
## Milestones
|
||||
|
||||
| # | Name | Status | What it adds |
|
||||
|---|------|--------|--------------|
|
||||
| M1 | QUIC/TLS transport | **Done** | QUIC + TLS 1.3 endpoint, length-prefixed framing, Ping/Pong |
|
||||
| M2 | Authentication Service | **Done** | Ed25519 identity, KeyPackage generation, AS upload/fetch |
|
||||
| M3 | Delivery Service + MLS groups | **Done** | DS relay, `GroupMember` create/join/add/send/recv |
|
||||
| M4 | Group CLI subcommands | **Done** | Persistent CLI, OPAQUE login, 20 subcommands |
|
||||
| M5 | Multi-party groups | **Done** | N > 2 members, Commit fan-out, `send --all`, epoch sync |
|
||||
| M6 | Persistence + REPL | **Done** | SQLite/SQLCipher, interactive REPL, DM channels, encrypted local storage |
|
||||
| M7 | Post-quantum MLS | **Planned** | Hybrid X25519 + ML-KEM-768 integrated into MLS ciphersuite |
|
||||
| # | Name | Status | What it adds |
|
||||
| --- | ----------------------------- | ----------- | ------------------------------------------------------------------------ |
|
||||
| M1 | QUIC/TLS transport | **Done** | QUIC + TLS 1.3 endpoint, length-prefixed framing, Ping/Pong |
|
||||
| M2 | Authentication Service | **Done** | Ed25519 identity, KeyPackage generation, AS upload/fetch |
|
||||
| M3 | Delivery Service + MLS groups | **Done** | DS relay, `GroupMember` create/join/add/send/recv |
|
||||
| M4 | Group CLI subcommands | **Done** | Persistent CLI, OPAQUE login, 20 subcommands |
|
||||
| M5 | Multi-party groups | **Done** | N > 2 members, Commit fan-out, `send --all`, epoch sync |
|
||||
| M6 | Persistence + REPL | **Done** | SQLite/SQLCipher, interactive REPL, DM channels, encrypted local storage |
|
||||
| M7 | Post-quantum MLS | **Planned** | Hybrid X25519 + ML-KEM-768 integrated into MLS ciphersuite |
|
||||
|
||||
M7 note: the hybrid KEM envelope is already implemented and tested (10 tests passing). What remains is integrating it into the OpenMLS CryptoProvider so all MLS key material gets post-quantum confidentiality.
|
||||
|
||||
@@ -252,17 +252,17 @@ M7 note: the hybrid KEM envelope is already implemented and tested (10 tests pas
|
||||
|
||||
See [ROADMAP.md](ROADMAP.md) for the full phased plan. Summary:
|
||||
|
||||
| Phase | Focus | Status |
|
||||
|-------|-------|--------|
|
||||
| 1 | Production hardening (unwrap removal, secure defaults, Docker) | In progress |
|
||||
| 2 | Test and CI maturity | Partially done |
|
||||
| 3 | Client SDKs (Go, TypeScript/WASM, Python FFI, C FFI) | **Go, TS, FFI, WASM done** |
|
||||
| 4 | Trust and security (audit, key transparency, PQ MLS) | DS auth + enumeration mitigation done |
|
||||
| 5 | Features and UX (rich messaging, file transfer, disappearing) | **Edit/delete, files, TTL done** |
|
||||
| 6 | Scale and operations (horizontal scaling, observability) | Planned |
|
||||
| 7 | Platform expansion (mobile, web, federation, sealed sender) | **Sealed sender done** |
|
||||
| 8 | Freifunk / community mesh networking | **F0-F6 done** |
|
||||
| 9 | Developer experience and community growth | Safety numbers + plugins done |
|
||||
| Phase | Focus | Status |
|
||||
| ----- | -------------------------------------------------------------- | ------------------------------------- |
|
||||
| 1 | Production hardening (unwrap removal, secure defaults, Docker) | In progress |
|
||||
| 2 | Test and CI maturity | Partially done |
|
||||
| 3 | Client SDKs (Go, TypeScript/WASM, Python FFI, C FFI) | **Go, TS, FFI, WASM done** |
|
||||
| 4 | Trust and security (audit, key transparency, PQ MLS) | DS auth + enumeration mitigation done |
|
||||
| 5 | Features and UX (rich messaging, file transfer, disappearing) | **Edit/delete, files, TTL done** |
|
||||
| 6 | Scale and operations (horizontal scaling, observability) | Planned |
|
||||
| 7 | Platform expansion (mobile, web, federation, sealed sender) | **Sealed sender done** |
|
||||
| 8 | Freifunk / community mesh networking | **F0-F6 done** |
|
||||
| 9 | Developer experience and community growth | Safety numbers + plugins done |
|
||||
|
||||
### Recently completed (Sprints 1-9)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user