BareRTC/pkg
Noah Petherbridge 09da9fa23d Don't send WhoList within 15 seconds of server start
To help alleviate rocky chat server reboots, WhoList messages will be
withheld in the first 15 seconds from server start.

When a lot of chatters were online during a reboot (e.g. 50 or more),
they would all try and reconnect after 5 seconds and each login was
broadcasting Who List updates to everybody else logged in. With the
surge of logins in a short time, these WhoList messages would fill up
the buffers of each recipient, kicking them offline for being too slow
to keep up with messages; only for that recipient to reconnect again.
The average user may have experienced 2 or 3 disconnects when the chat
server reboots.

To help alleviate the spam of messages being sent out:

* Presence messages are withheld for the first 30 seconds ("has joined
  the room" notifications)
* Now, WhoList messages are withheld for the first 15 seconds.

After 16 seconds of uptime, the server will send a WhoList to everybody
currently online to catch them up.

To accommodate this, the front-end will show a spinner and say "Waiting
for Who List..." when the page is connected but no WhoList has been
received yet. Under normal operation, this spinner won't be visible
beyond a brief moment as a WhoList is normally sent upon joining the
chat.
2025-03-21 20:49:26 -07:00
..
config Echo Public Channel Messages 2025-02-17 22:08:25 -08:00
jwt Moderator rule: nodvd (exempt from dark video detector) 2025-01-03 23:15:05 -08:00
log Initial commit 2023-01-10 22:38:48 -08:00
messages Echo Public Channel Messages 2025-02-17 22:08:25 -08:00
models Switch to mattn/go-sqlite3 2025-03-17 17:58:03 -07:00
util A bit more logging to debug WebSocket issues 2023-02-08 20:01:06 -08:00
api.go History Modal + Dark Detector Fixes 2025-02-14 18:12:39 -08:00
banned_users.go Commands: /ban and /op 2023-08-04 20:31:21 -07:00
commands.go Send admin reports on /nsfw command + Fixes 2025-02-17 12:50:06 -08:00
config.go Re-sign JWT tokens for safer server deployments 2023-04-19 19:55:39 -07:00
echo_messages.go Echo: Skip messages sent by blocked usernames 2025-03-09 15:52:34 -07:00
expand_media.go YouTube link embeds 2023-03-24 22:47:58 -07:00
handlers.go Safety for the operator-only hidden status 2025-03-11 21:31:40 -07:00
images.go Photo sharing support 2023-03-21 21:29:24 -07:00
logging.go Fix webcam freezing issues with mutualOpen video connections 2023-11-18 15:38:02 -08:00
markdown.go JWT Token-based Authentication 2023-02-05 17:42:09 -08:00
message_filters.go Include DM context in reported messages 2024-01-20 15:17:02 -08:00
moderation_rules.go Moderator rule: nodvd (exempt from dark video detector) 2025-01-03 23:15:05 -08:00
pages.go Add webcam troubleshooting tips to the About page 2024-10-17 20:13:08 -07:00
polling_api.go Add DisconnectNow API endpoint 2024-03-15 15:59:42 -07:00
server.go Don't send WhoList within 15 seconds of server start 2025-03-21 20:49:26 -07:00
subscriber.go Don't send WhoList within 15 seconds of server start 2025-03-21 20:49:26 -07:00
webhook_messages.go Webhooks and Report Users 2023-08-12 21:35:41 -07:00
webhooks.go Send admin reports on /nsfw command + Fixes 2025-02-17 12:50:06 -08:00
websocket.go JWT Token Chat Moderation Rules 2024-09-19 17:29:08 -07:00