Class: ActionCable::RemoteConnections

Inherits:
Object
  • Object
show all
Defined in:
lib/action_cable/remote_connections.rb

Overview

If you need to disconnect a given connection, you can go through the RemoteConnections. You can find the connections you're looking for by searching for the identifier declared on the connection. For example:

module ApplicationCable
  class Connection < ActionCable::Connection::Base
    identified_by :current_user
    ....
  end
end

ActionCable.server.remote_connections.where(current_user: User.find(1)).disconnect

This will disconnect all the connections established for User.find(1), across all servers running on all machines, because it uses the internal channel that all of these servers are subscribed to.

Defined Under Namespace

Classes: RemoteConnection

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(server) ⇒ RemoteConnections

Returns a new instance of RemoteConnections.



25
26
27
# File 'lib/action_cable/remote_connections.rb', line 25

def initialize(server)
  @server = server
end

Instance Attribute Details

#serverObject (readonly)

Returns the value of attribute server.



23
24
25
# File 'lib/action_cable/remote_connections.rb', line 23

def server
  @server
end

Instance Method Details

#where(identifier) ⇒ Object



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

def where(identifier)
  RemoteConnection.new(server, identifier)
end