Methods
- A
- I
- L
- N
- R
- S
Class Public methods
new(adapter, event_loop)
Link
# File actioncable/lib/action_cable/subscription_adapter/redis.rb, line 61 def initialize(adapter, event_loop) super() @adapter = adapter @event_loop = event_loop @subscribe_callbacks = Hash.new { |h, k| h[k] = [] } @subscription_lock = Mutex.new @raw_client = nil @when_connected = [] @thread = nil end
Instance Public methods
add_channel(channel, on_success)
Link
# File actioncable/lib/action_cable/subscription_adapter/redis.rb, line 128 def add_channel(channel, on_success) @subscription_lock.synchronize do ensure_listener_running @subscribe_callbacks[channel] << on_success when_connected { send_command("subscribe", channel) } end end
invoke_callback(*)
Link
listen(conn)
Link
# File actioncable/lib/action_cable/subscription_adapter/redis.rb, line 77 def listen(conn) conn.without_reconnect do original_client = conn.respond_to?(:_client) ? conn._client : conn.client conn.subscribe("_action_cable_internal") do |on| on.subscribe do |chan, count| @subscription_lock.synchronize do if count == 1 @raw_client = original_client until @when_connected.empty? @when_connected.shift.call end end if callbacks = @subscribe_callbacks[chan] next_callback = callbacks.shift @event_loop.post(&next_callback) if next_callback @subscribe_callbacks.delete(chan) if callbacks.empty? end end end on.message do |chan, message| broadcast(chan, message) end on.unsubscribe do |chan, count| if count == 0 @subscription_lock.synchronize do @raw_client = nil end end end end end end
remove_channel(channel)
Link