aboutsummaryrefslogtreecommitdiffstats
path: root/lib/action_cable/remote_connection.rb
diff options
context:
space:
mode:
authorPratik Naik <pratiknaik@gmail.com>2015-04-07 10:11:46 -0500
committerPratik Naik <pratiknaik@gmail.com>2015-04-07 10:11:46 -0500
commit6127d0cda4d60c7b30ee1fb40006da11e04512d0 (patch)
treec6905ea6b5414a64a687dea12cb0ea4631d2e0a1 /lib/action_cable/remote_connection.rb
parentbdbbe18f3cc527b121bbb2f402898caf4c2fbb15 (diff)
parentfb797ad1f1c3b0d96968c5feef783a2b8fe07eed (diff)
downloadrails-6127d0cda4d60c7b30ee1fb40006da11e04512d0.tar.gz
rails-6127d0cda4d60c7b30ee1fb40006da11e04512d0.tar.bz2
rails-6127d0cda4d60c7b30ee1fb40006da11e04512d0.zip
Merge branch 'connection-management'
Diffstat (limited to 'lib/action_cable/remote_connection.rb')
-rw-r--r--lib/action_cable/remote_connection.rb38
1 files changed, 38 insertions, 0 deletions
diff --git a/lib/action_cable/remote_connection.rb b/lib/action_cable/remote_connection.rb
new file mode 100644
index 0000000000..e2cb2d932c
--- /dev/null
+++ b/lib/action_cable/remote_connection.rb
@@ -0,0 +1,38 @@
+module ActionCable
+ class RemoteConnection
+ class InvalidIdentifiersError < StandardError; end
+
+ include Connection::Identifier
+
+ delegate :redis, to: :server
+
+ def initialize(server, ids)
+ @server = server
+ set_identifier_instance_vars(ids)
+ end
+
+ def disconnect
+ message = { type: 'disconnect' }.to_json
+ redis.publish(internal_redis_channel, message)
+ end
+
+ def identifiers
+ @server.connection_identifiers
+ end
+
+ def redis
+ @redis ||= Redis.new(@server.redis_config)
+ end
+
+ private
+ def set_identifier_instance_vars(ids)
+ raise InvalidIdentifiersError unless valid_identifiers?(ids)
+ ids.each { |k,v| instance_variable_set("@#{k}", v) }
+ end
+
+ def valid_identifiers?(ids)
+ keys = ids.keys
+ identifiers.all? { |id| keys.include?(id) }
+ end
+ end
+end