Module: ActionCable::Server::Connections

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

Overview

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 =

:nodoc:

3

Instance Method Summary collapse

Instance Method Details

#add_connection(connection) ⇒ Object



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

def add_connection(connection)
  connections << connection
end

#connectionsObject



8
9
10
# File 'lib/action_cable/server/connections.rb', line 8

def connections
  @connections ||= []
end

#open_connections_statisticsObject



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

def open_connections_statistics
  connections.map(&:statistics)
end

#remove_connection(connection) ⇒ Object



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

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.



23
24
25
26
27
# File 'lib/action_cable/server/connections.rb', line 23

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