aboutsummaryrefslogtreecommitdiffstats
path: root/lib/action_cable/channel
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2015-07-04 21:30:48 +0200
committerDavid Heinemeier Hansson <david@loudthinking.com>2015-07-04 21:30:48 +0200
commit0de65cf2d8860377d45020a83866073c5fec188c (patch)
treed39b559162936fd79049595d69098fd7712a8fe3 /lib/action_cable/channel
parent9886a995f5f0b32d0d400074c48221cb0f6b911e (diff)
parent5de01033150b70982f23a42670c55348a7371c4b (diff)
downloadrails-0de65cf2d8860377d45020a83866073c5fec188c.tar.gz
rails-0de65cf2d8860377d45020a83866073c5fec188c.tar.bz2
rails-0de65cf2d8860377d45020a83866073c5fec188c.zip
Merge branch 'master' of github.com:basecamp/action_cable
Diffstat (limited to 'lib/action_cable/channel')
-rw-r--r--lib/action_cable/channel/base.rb10
-rw-r--r--lib/action_cable/channel/redis.rb37
-rw-r--r--lib/action_cable/channel/streams.rb40
3 files changed, 42 insertions, 45 deletions
diff --git a/lib/action_cable/channel/base.rb b/lib/action_cable/channel/base.rb
index 12a5789bdc..335d2d9d7c 100644
--- a/lib/action_cable/channel/base.rb
+++ b/lib/action_cable/channel/base.rb
@@ -2,7 +2,7 @@ module ActionCable
module Channel
class Base
include Callbacks
- include Redis
+ include Streams
on_subscribe :start_periodic_timers
on_unsubscribe :stop_periodic_timers
@@ -10,16 +10,10 @@ module ActionCable
attr_reader :params, :connection
delegate :logger, to: :connection
- class_attribute :channel_name
-
class << self
def matches?(identifier)
raise "Please implement #{name}#matches? method"
end
-
- def find_name
- @name ||= channel_name || to_s.demodulize.underscore
- end
end
def initialize(connection, channel_identifier, params = {})
@@ -138,4 +132,4 @@ module ActionCable
end
end
end
-end \ No newline at end of file
+end
diff --git a/lib/action_cable/channel/redis.rb b/lib/action_cable/channel/redis.rb
deleted file mode 100644
index 0f77dc0418..0000000000
--- a/lib/action_cable/channel/redis.rb
+++ /dev/null
@@ -1,37 +0,0 @@
-module ActionCable
- module Channel
- module Redis
- extend ActiveSupport::Concern
-
- included do
- on_unsubscribe :unsubscribe_from_all_channels
- delegate :pubsub, to: :connection
- end
-
- def subscribe_to(redis_channel, callback = nil)
- callback ||= default_subscription_callback(redis_channel)
- @_redis_channels ||= []
- @_redis_channels << [ redis_channel, callback ]
-
- pubsub.subscribe(redis_channel, &callback)
- logger.info "#{channel_name} subscribed to broadcasts from #{redis_channel}"
- end
-
- def unsubscribe_from_all_channels
- if @_redis_channels
- @_redis_channels.each do |redis_channel, callback|
- pubsub.unsubscribe_proc(redis_channel, callback)
- logger.info "#{channel_name} unsubscribed to broadcasts from #{redis_channel}"
- end
- end
- end
-
- protected
- def default_subscription_callback(channel)
- -> (message) do
- transmit ActiveSupport::JSON.decode(message), via: "broadcast from #{channel}"
- end
- end
- end
- end
-end
diff --git a/lib/action_cable/channel/streams.rb b/lib/action_cable/channel/streams.rb
new file mode 100644
index 0000000000..3eac776e61
--- /dev/null
+++ b/lib/action_cable/channel/streams.rb
@@ -0,0 +1,40 @@
+module ActionCable
+ module Channel
+ module Streams
+ extend ActiveSupport::Concern
+
+ included do
+ on_unsubscribe :stop_all_streams
+ end
+
+ def stream_from(broadcasting, callback = nil)
+ callback ||= default_stream_callback(broadcasting)
+
+ streams << [ broadcasting, callback ]
+ pubsub.subscribe broadcasting, &callback
+
+ logger.info "#{channel_name} is streaming from #{broadcasting}"
+ end
+
+ def stop_all_streams
+ streams.each do |broadcasting, callback|
+ pubsub.unsubscribe_proc broadcasting, callback
+ logger.info "#{channel_name} stopped streaming from #{broadcasting}"
+ end
+ end
+
+ private
+ delegate :pubsub, to: :connection
+
+ def streams
+ @_streams ||= []
+ end
+
+ def default_stream_callback(broadcasting)
+ -> (message) do
+ transmit ActiveSupport::JSON.decode(message), via: "streamed from #{broadcasting}"
+ end
+ end
+ end
+ end
+end