Methods
Class Public methods
new()
📝 Source code
# File actioncable/lib/action_cable/subscription_adapter/subscriber_map.rb, line 6
def initialize
@subscribers = Hash.new { |h, k| h[k] = [] }
@sync = Mutex.new
end
🔎 See on GitHub
Instance Public methods
add_channel(channel, on_success)
📝 Source code
# File actioncable/lib/action_cable/subscription_adapter/subscriber_map.rb, line 47
def add_channel(channel, on_success)
on_success.call if on_success
end
🔎 See on GitHub
add_subscriber(channel, subscriber, on_success)
📝 Source code
# File actioncable/lib/action_cable/subscription_adapter/subscriber_map.rb, line 11
def add_subscriber(channel, subscriber, on_success)
@sync.synchronize do
new_channel = !@subscribers.key?(channel)
@subscribers[channel] << subscriber
if new_channel
add_channel channel, on_success
elsif on_success
on_success.call
end
end
end
🔎 See on GitHub
broadcast(channel, message)
📝 Source code
# File actioncable/lib/action_cable/subscription_adapter/subscriber_map.rb, line 36
def broadcast(channel, message)
list = @sync.synchronize do
return if !@subscribers.key?(channel)
@subscribers[channel].dup
end
list.each do |subscriber|
invoke_callback(subscriber, message)
end
end
🔎 See on GitHub
invoke_callback(callback, message)
📝 Source code
# File actioncable/lib/action_cable/subscription_adapter/subscriber_map.rb, line 54
def invoke_callback(callback, message)
callback.call message
end
🔎 See on GitHub
remove_channel(channel)
📝 Source code
# File actioncable/lib/action_cable/subscription_adapter/subscriber_map.rb, line 51
def remove_channel(channel)
end
🔎 See on GitHub
remove_subscriber(channel, subscriber)
📝 Source code
# File actioncable/lib/action_cable/subscription_adapter/subscriber_map.rb, line 25
def remove_subscriber(channel, subscriber)
@sync.synchronize do
@subscribers[channel].delete(subscriber)
if @subscribers[channel].empty?
@subscribers.delete channel
remove_channel channel
end
end
end
🔎 See on GitHub