Files
codeocean/app/channels/synchronized_editor_channel.rb
Sebastian Serth cc90861bd5 Generate Session ID on server for synchronized editor
This change allows us to use the session ID immediately for the connection_change and connection_status methods. Hence, we can identify different browser sessions of the same user.
2023-09-12 18:47:06 +02:00

58 lines
1.8 KiB
Ruby

# frozen_string_literal: true
class SynchronizedEditorChannel < ApplicationCable::Channel
def subscribed
stream_from specific_channel
# We generate a session_id for the user and send it to the client
@session_id = SecureRandom.uuid
connection.transmit identifier: @identifier, message: {action: :session_id, session_id: @session_id}
message = create_message('connection_change', 'connected')
Event::SynchronizedEditor.create_for_connection_change(message, current_user, programming_group)
ActionCable.server.broadcast(specific_channel, message)
end
def unsubscribed
# Any cleanup needed when channel is unsubscribed
stop_all_streams
message = create_message('connection_change', 'disconnected')
Event::SynchronizedEditor.create_for_connection_change(message, current_user, programming_group)
ActionCable.server.broadcast(specific_channel, message)
end
def specific_channel
reject unless ProgrammingGroupPolicy.new(current_user, programming_group).stream_sync_editor?
"synchronized_editor_channel_group_#{programming_group.id}"
end
def programming_group
current_contributor if current_contributor.programming_group?
end
def editor_change(message)
change = message.deep_symbolize_keys
Event::SynchronizedEditor.create_for_editor_change(change, current_user, programming_group)
ActionCable.server.broadcast(specific_channel, change)
end
def connection_status
ActionCable.server.broadcast(specific_channel, create_message('connection_status', 'connected'))
end
def current_content(message)
ActionCable.server.broadcast(specific_channel, message)
end
def create_message(action, status)
{
action:,
status:,
user: current_user.to_page_context,
session_id: @session_id,
}
end
end