Module: ActionCable::Server::Connections

Included in:
Base
Defined in:
actioncable/lib/action_cable/server/connections.rb

Overview

Action Cable Server Connections

Collection class for all the connections that have been established on this specific server. Remember, usually you’ll run many Action Cable servers, so you can’t use this collection as a full list of all of the connections established against your application. Instead, use RemoteConnections for that.

Constant Summary collapse

BEAT_INTERVAL =
3

Instance Method Summary collapse

Instance Method Details

#add_connection(connection) ⇒ Object



16
17
18
# File 'actioncable/lib/action_cable/server/connections.rb', line 16

def add_connection(connection)
  connections << connection
end

#connectionsObject



12
13
14
# File 'actioncable/lib/action_cable/server/connections.rb', line 12

def connections
  @connections ||= []
end

#open_connections_statisticsObject



33
34
35
# File 'actioncable/lib/action_cable/server/connections.rb', line 33

def open_connections_statistics
  connections.map(&:statistics)
end

#remove_connection(connection) ⇒ Object



20
21
22
# File 'actioncable/lib/action_cable/server/connections.rb', line 20

def remove_connection(connection)
  connections.delete connection
end

#setup_heartbeat_timerObject

WebSocket connection implementations differ on when they’ll mark a connection as stale. We basically never want a connection to go stale, as you then can’t rely on being able to communicate with the connection. To solve this, a 3 second heartbeat runs on all connections. If the beat fails, we automatically disconnect.



27
28
29
30
31
# File 'actioncable/lib/action_cable/server/connections.rb', line 27

def setup_heartbeat_timer
  @heartbeat_timer ||= event_loop.timer(BEAT_INTERVAL) do
    event_loop.post { connections.each(&:beat) }
  end
end