discourse/plugins/chat/app/services/chat
Régis Hanol 6dfe2fbe16
PERF: auto join & leave chat channels (#29193)
Chat channels that are linked to a category can be set to automatically join users.

This is handled by subscribing to the following events

- group_destroyed
- user_seen
- user_confirmed_email
- user_added_to_group
- user_removed_from_group
- category_updated
- site_setting_changed (for `chat_allowed_groups`)

As well as a

- hourly background job (`AutoJoinUsers`)
- `CreateCategoryChannel` service
- `UpdateChannel` service

There was however two issues with the current implementation

1. We were triggering a lot of background jobs, mostly because it was decided to batch to auto join/leave into groups of 1000 users, adding a lot of stress to the system
2. We had one "class" (a service or a background job) per "event" and all of them had slightly different ways to select users to join/leave, making it hard to keep everything in sync

This PR "simply" adds two new servicesL `AutoJoinChannels` and `AutoLeaveChannels` that takes care, in an efficient way, of all the cases when users might automatically join a leave a chat channel.

Every other changes come from the fact that we're now always calling either one of those services, depending on the event that happened.

In the making of these classes, a few bugs were encountered and fixed, notably

- A user is only ever able to access chat channels if and only if they're part of a group listed in the `chat_allowed_group` site setting
- A category that has no associated "category groups" is only accessible to staff members (and not "Everyone")
- A silenced user should not be able to automatically join channels
- We should not attempt to automatically join users to deleted chat channels
- There is no need to automatically join users to chat channels that have already more than `max_chat_auto_joined_users` users

Internal - t/135259 & t/70607

* DEV: add specs for auto join/leave channels services

* DEV: less hacky specs

* DEV: no instance variables in specs
2024-11-12 15:00:59 +11:00
..
action PERF: auto join & leave chat channels (#29193) 2024-11-12 15:00:59 +11:00
channel/policy DEV: Introduce a Service::ActionBase class for service actions 2024-09-18 17:02:46 +02:00
direct_message_channel/policy DEV: Introduce a Service::ActionBase class for service actions 2024-09-18 17:02:46 +02:00
add_users_to_channel.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
auto_join_channels.rb PERF: auto join & leave chat channels (#29193) 2024-11-12 15:00:59 +11:00
auto_leave_channels.rb PERF: auto join & leave chat channels (#29193) 2024-11-12 15:00:59 +11:00
create_category_channel.rb PERF: auto join & leave chat channels (#29193) 2024-11-12 15:00:59 +11:00
create_direct_message_channel.rb DEV: sets an icon_upload_id on a channel (#29566) 2024-11-04 17:19:44 +09:00
create_message.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
create_thread.rb DEV: Refactor the Chat::CreateThread service a bit 2024-11-06 15:53:43 +01:00
flag_message.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
invite_users_to_channel.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
leave_channel.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
list_channel_messages.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
list_channel_thread_messages.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
list_user_channels.rb FIX: show chat thread notifications for direct message channels (#29414) 2024-10-31 10:50:11 +04:00
lookup_channel_threads.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
lookup_thread.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
lookup_user_threads.rb FIX: show chat thread notifications for direct message channels (#29414) 2024-10-31 10:50:11 +04:00
mark_all_user_channels_read.rb DEV: Provide user input to services using params key 2024-10-25 09:57:59 +02:00
mark_thread_title_prompt_seen.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
message_destroyer.rb DEV: Add last_message_id to channel and thread (#22488) 2023-07-13 10:28:11 +10:00
publisher.rb PERF: auto join & leave chat channels (#29193) 2024-11-12 15:00:59 +11:00
restore_message.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
search_chatable.rb DEV: Bump rubocop_discourse (#29608) 2024-11-06 06:27:49 +08:00
start_reply.rb DEV: start/stop reply implementation (#29542) 2024-11-04 08:14:35 +11:00
stop_message_streaming.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
stop_reply.rb DEV: start/stop reply implementation (#29542) 2024-11-04 08:14:35 +11:00
tracking_state.rb DEV: Replace params by the contract object in services 2024-10-25 14:48:34 +02:00
trash_channel.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
trash_message.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
trash_messages.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
unfollow_channel.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
update_channel_status.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
update_channel.rb PERF: auto join & leave chat channels (#29193) 2024-11-12 15:00:59 +11:00
update_message.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
update_thread_notification_settings.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
update_thread.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
update_user_channel_last_read.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
update_user_thread_last_read.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00
upsert_draft.rb DEV: Remove hash-like access from service contracts 2024-10-29 16:02:51 +01:00