Working project name, not final.

Trey Del Bonis 9d70e23b09 test: reworked test entrypoint for new flexitest version hace 1 mes
client f04449ede6 db: reorganized massively, splitting our components like MQ and making names more consistent hace 2 meses
codec 1da1a7145e util: moved most modules into new codec crate and reorganized hace 2 meses
common 2794ed859e meta: add new ecksport deps in crate tomls, code still broken hace 3 meses
contrib 856f5f3682 sqldb, contrib: generate sqldb crate with `--lib` flag hace 8 meses
core 21cce0effd client, core, db, homeserver: remove "origin" concept from MQ system hace 2 meses
datamodel bd6e2c2d5f datamodel: added module hace 2 meses
db f04449ede6 db: reorganized massively, splitting our components like MQ and making names more consistent hace 2 meses
docs 9686fab82d docs: added planes.md hace 2 meses
homeserver f04449ede6 db: reorganized massively, splitting our components like MQ and making names more consistent hace 2 meses
ident 1da1a7145e util: moved most modules into new codec crate and reorganized hace 2 meses
proto 1da1a7145e util: moved most modules into new codec crate and reorganized hace 2 meses
rpc f04449ede6 db: reorganized massively, splitting our components like MQ and making names more consistent hace 2 meses
test 9d70e23b09 test: reworked test entrypoint for new flexitest version hace 1 mes
tools 1da1a7145e util: moved most modules into new codec crate and reorganized hace 2 meses
user f04449ede6 db: reorganized massively, splitting our components like MQ and making names more consistent hace 2 meses
util 1da1a7145e util: moved most modules into new codec crate and reorganized hace 2 meses
.gitignore 8237d39ff4 test: mostly finished test harness hace 7 meses
Cargo.lock f04449ede6 db: reorganized massively, splitting our components like MQ and making names more consistent hace 2 meses
Cargo.toml f04449ede6 db: reorganized massively, splitting our components like MQ and making names more consistent hace 2 meses
README.md acd6ec6c08 meta: updated README again hace 6 meses

README.md

aspect

A better messaging and chat protocol. Building it the right way.

rough design doc

Rough roadmap

These are handwavy milestones that I expect to change.

Phase 1

  • Prototype device identity system
  • Basic MLS group setup/teardown
  • Support adding/removing devices
  • ZMQ or AMQP channel message streams

Phase 2

  • Protocol cleanup
  • Properly authenticate user device identity graph
  • Proper device attestation for homeservers
  • Experiment with roaming identities?
  • Replace transport auth with better system
  • Homeserver push events to change group membership (use OpenMLS support for this)
  • More sophisticated message structure and local channel state
  • Prototype spaces?
  • More homeserver administrative actions

Phase 3

  • More thorough spaces impl
  • Invites
  • Persistent channel data store (for custom emotes, stickers, etc.)

Known issues

Keeping this list here so that I remember what I'm doing.

  • No transport encryption, homeserver user creds are in plaintext.
  • User authentication is shaky, should add some kind of session authentication to avoid resending creds and stuff.
  • No connection pooling or automatic reconnect to homeservers.
  • Password hashing round count is way too high for debug builds, takes 5+ seconds.
  • Lots of ORM queries have // TODOs on them because we query more columns than we need to, that could be reduced.
  • Lots of queries could be made into JOINs but I don't know how to express that to SeaORM correctly.
  • Lots of Codec serialization is "self-documenting" in the bad way (the source code is the only documentation), switch to using Stencil when it's mature enough.