aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorPratik Naik <pratiknaik@gmail.com>2015-04-06 13:17:02 -0500
committerPratik Naik <pratiknaik@gmail.com>2015-04-06 13:17:02 -0500
commit1c9d82dbf0e743534c5fa9be936eaa46c5b07523 (patch)
tree4fc5c31666fa033859150852cc5fd583420e32d8 /lib
parenteec92d0229a7bceb62d49d58c70b5629fe140d7f (diff)
downloadrails-1c9d82dbf0e743534c5fa9be936eaa46c5b07523.tar.gz
rails-1c9d82dbf0e743534c5fa9be936eaa46c5b07523.tar.bz2
rails-1c9d82dbf0e743534c5fa9be936eaa46c5b07523.zip
Add remote connection to talk over internal redis channel
Diffstat (limited to 'lib')
-rw-r--r--lib/action_cable.rb2
-rw-r--r--lib/action_cable/connection.rb3
-rw-r--r--lib/action_cable/connection/identifier.rb19
-rw-r--r--lib/action_cable/connection_proxy.rb14
-rw-r--r--lib/action_cable/remote_connection.rb38
-rw-r--r--lib/action_cable/server.rb12
6 files changed, 70 insertions, 18 deletions
diff --git a/lib/action_cable.rb b/lib/action_cable.rb
index fd42dc6cdd..159ee2bcc0 100644
--- a/lib/action_cable.rb
+++ b/lib/action_cable.rb
@@ -23,5 +23,5 @@ module ActionCable
autoload :Worker, 'action_cable/worker'
autoload :Server, 'action_cable/server'
autoload :Connection, 'action_cable/connection'
- autoload :ConnectionProxy, 'action_cable/connection_proxy'
+ autoload :RemoteConnection, 'action_cable/remote_connection'
end
diff --git a/lib/action_cable/connection.rb b/lib/action_cable/connection.rb
index 102903c6ef..91fc73713c 100644
--- a/lib/action_cable/connection.rb
+++ b/lib/action_cable/connection.rb
@@ -1,6 +1,7 @@
module ActionCable
module Connection
autoload :Base, 'action_cable/connection/base'
- autoload :Registry, 'action_cable/connection/Registry'
+ autoload :Registry, 'action_cable/connection/registry'
+ autoload :Identifier, 'action_cable/connection/identifier'
end
end
diff --git a/lib/action_cable/connection/identifier.rb b/lib/action_cable/connection/identifier.rb
new file mode 100644
index 0000000000..9bfd773ab1
--- /dev/null
+++ b/lib/action_cable/connection/identifier.rb
@@ -0,0 +1,19 @@
+module ActionCable
+ module Connection
+ module Identifier
+
+ def internal_redis_channel
+ "action_cable/#{connection_identifier}"
+ end
+
+ def connection_identifier
+ @connection_identifier ||= connection_gid identifiers.map { |id| instance_variable_get("@#{id}")}
+ end
+
+ def connection_gid(ids)
+ ids.map {|o| o.to_global_id.to_s }.sort.join(":")
+ end
+
+ end
+ end
+end
diff --git a/lib/action_cable/connection_proxy.rb b/lib/action_cable/connection_proxy.rb
deleted file mode 100644
index 980e037ff3..0000000000
--- a/lib/action_cable/connection_proxy.rb
+++ /dev/null
@@ -1,14 +0,0 @@
-module ActionCable
- module ConnectionProxy
- class << self
- def active
- end
-
- def where(identification)
- end
- end
-
- def disconnect
- end
- end
-end
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
diff --git a/lib/action_cable/server.rb b/lib/action_cable/server.rb
index 6e9265dc06..51e246c232 100644
--- a/lib/action_cable/server.rb
+++ b/lib/action_cable/server.rb
@@ -2,12 +2,12 @@ module ActionCable
class Server
cattr_accessor(:logger, instance_reader: true) { Rails.logger }
- attr_accessor :registered_channels, :worker_pool
+ attr_accessor :registered_channels, :redis_config
def initialize(redis_config:, channels:, worker_pool_size: 100, connection: Connection)
@redis_config = redis_config
@registered_channels = Set.new(channels)
- @worker_pool = ActionCable::Worker.pool(size: worker_pool_size)
+ @worker_pool_size = worker_pool_size
@connection_class = connection
end
@@ -15,9 +15,17 @@ module ActionCable
@connection_class.new(self, env).process
end
+ def worker_pool
+ @worker_pool ||= ActionCable::Worker.pool(size: @worker_pool_size)
+ end
+
def pubsub
@pubsub ||= EM::Hiredis.connect(@redis_config['url']).pubsub
end
+ def connection_identifiers
+ @connection_class.identifiers
+ end
+
end
end