forked from lavina/lavina
1
0
Fork 0
lavina/crates
Nikita Vilunov cefd6f8df0 irc: basic implementation of PLAIN SASL auth ()
Reviewed-on: 
2023-12-08 02:47:09 +00:00
..
lavina-core add author id in messages schema 2023-10-04 18:32:08 +02:00
mgmt-api add management API endpoints 2023-09-24 22:59:34 +02:00
projection-irc irc: basic implementation of PLAIN SASL auth () 2023-12-08 02:47:09 +00:00
projection-xmpp move sasl into separate crate 2023-12-08 03:33:18 +01:00
proto-irc irc: basic implementation of PLAIN SASL auth () 2023-12-08 02:47:09 +00:00
proto-xmpp move sasl into separate crate 2023-12-08 03:33:18 +01:00
sasl move sasl into separate crate 2023-12-08 03:33:18 +01:00
readme.md update docs 2023-10-10 02:30:50 +02:00

readme.md

Dependency diagram of the project

A few rules:

  • Only projections should be direct deps of lavina, there is no need to depend on proto-* crates.
  • On the other hand, projections should not be dependencies of sim-* crates.
  • lavina-core does not depend on protocol-specific crates.

Lavina

lavina-core. This crate implements the core functionality of the server not specific to public interfaces. It includes handling general persistence, message casts, in future room authorization and cross-node communication.

lavina. The application crate. It's used to link other crates together and build the final binary with support for all protocols.

mgmt-api. Model definitions for management API to be used both in the server and client implementations.

IRC

proto-irc. Protocol definition for IRC, includes both server-side and client-side messages and both serialization and deserialization where needed.

projection-irc. Projection of lavina-core onto the IRC client-to-server protocol implementation.

sim-irc. Future implementation of IRC client simulator to be used in integration and load testing.