delthas 2f6303ecc2 Add support for the wip soju.im/read capability and READ command
READ lets downstream clients share information between each other about
what messages have been read by other downstreams.

Each target/entity has an optional corresponding read receipt, which is
stored as a timestamp.

- When a downstream sends:
  READ #chan timestamp=2020-01-01T01:23:45.000Z
  the read receipt for that target is set to that date
- soju sends READ to downstreams:
  - on JOIN, if the client uses the soju.im/read capability
  - when the read receipt timestamp is set by any downstream

The read receipt date is clamped by the previous receipt date and the
current time.

git-svn-id: https://svn.yakumo.dev/yakumo.izuru/suika/trunk@781 f0ae65fe-ee39-954e-97ec-027ff2717ef4
2022-02-11 18:41:46 +00:00
2021-11-17 14:07:58 +00:00
2021-10-15 07:59:53 +00:00
2020-11-30 10:39:41 +00:00
2020-04-01 15:38:09 +00:00
2022-01-03 20:01:44 +00:00
2021-12-02 22:52:29 +00:00
2022-02-09 14:16:54 +00:00
2020-02-07 16:41:51 +00:00
2022-02-08 15:10:19 +00:00
2021-11-03 17:21:12 +00:00
2021-09-09 08:07:37 +00:00
2021-09-09 08:07:37 +00:00
2022-02-08 15:10:19 +00:00
2021-11-17 11:04:24 +00:00

soju

builds.sr.ht status

A user-friendly IRC bouncer.

  • Multi-user
  • Support multiple clients for a single user, with proper backlog synchronization
  • Support connecting to multiple upstream servers via a single IRC connection to the bouncer

Usage

Building and installing

Dependencies:

  • Go
  • BSD or GNU make
  • a C89 compiler (for SQLite)
  • scdoc (optional, for man pages)

For end users, a Makefile is provided:

make
sudo make install

For development, you can use go run ./cmd/soju as usual.

To link with the system libsqlite3, set GOFLAGS="-tags=libsqlite3".

Contributing

Send patches on the mailing list or on GitHub, report bugs on the issue tracker. Discuss in #soju on Libera Chat.

License

AGPLv3, see LICENSE.

Copyright (C) 2020 The soju Contributors

Description
Languages
Go 99.1%
Makefile 0.5%
Shell 0.4%