Class: ActionCable::RemoteConnections
- Inherits:
-
Object
- Object
- ActionCable::RemoteConnections
- 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
-
#server ⇒ Object
readonly
Returns the value of attribute server.
Instance Method Summary collapse
-
#initialize(server) ⇒ RemoteConnections
constructor
A new instance of RemoteConnections.
- #where(identifier) ⇒ Object
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
#server ⇒ Object (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 |