diff options
author | Kasper Timm Hansen <kaspth@gmail.com> | 2015-07-23 14:32:45 +0200 |
---|---|---|
committer | Kasper Timm Hansen <kaspth@gmail.com> | 2015-07-23 14:32:45 +0200 |
commit | 3fb1a84f538d47a3c691b245a8dd0f5b4f8184e4 (patch) | |
tree | d0e1952753f699ad19fbac5b2d0968824717555d /lib/action_cable/channel | |
parent | bdbc91ab5840faf1e1c5002eb9d0be442ec52504 (diff) | |
parent | a97a1fc7452088b875edb6b258c92d6eab1c19a4 (diff) | |
download | rails-3fb1a84f538d47a3c691b245a8dd0f5b4f8184e4.tar.gz rails-3fb1a84f538d47a3c691b245a8dd0f5b4f8184e4.tar.bz2 rails-3fb1a84f538d47a3c691b245a8dd0f5b4f8184e4.zip |
Merge pull request #36 from cristianbica/channel-action-dispatched
Improve channel actions dispatcher to allow inheritance/mixins
Diffstat (limited to 'lib/action_cable/channel')
-rw-r--r-- | lib/action_cable/channel/base.rb | 39 |
1 files changed, 37 insertions, 2 deletions
diff --git a/lib/action_cable/channel/base.rb b/lib/action_cable/channel/base.rb index 87ae3a1211..d6bd98d180 100644 --- a/lib/action_cable/channel/base.rb +++ b/lib/action_cable/channel/base.rb @@ -75,6 +75,42 @@ module ActionCable attr_reader :params, :connection delegate :logger, to: :connection + class << self + # A list of method names that should be considered actions. This + # includes all public instance methods on a channel, less + # any internal methods (defined on Base), adding back in + # any methods that are internal, but still exist on the class + # itself. + # + # ==== Returns + # * <tt>Set</tt> - A set of all methods that should be considered actions. + def action_methods + @action_methods ||= begin + # All public instance methods of this class, including ancestors + methods = (public_instance_methods(true) - + # Except for public instance methods of Base and its ancestors + ActionCable::Channel::Base.public_instance_methods(true) + + # Be sure to include shadowed public instance methods of this class + public_instance_methods(false)).uniq.map(&:to_s) + methods.to_set + end + end + + protected + # action_methods are cached and there is sometimes need to refresh + # them. ::clear_action_methods! allows you to do that, so next time + # you run action_methods, they will be recalculated + def clear_action_methods! + @action_methods = nil + end + + # Refresh the cached action_methods when a new action_method is added. + def method_added(name) + super + clear_action_methods! + end + end + def initialize(connection, identifier, params = {}) @connection = connection @identifier = identifier @@ -147,7 +183,7 @@ module ActionCable end def processable_action?(action) - self.class.instance_methods(false).include?(action) + self.class.action_methods.include?(action.to_s) end def dispatch_action(action, data) @@ -168,7 +204,6 @@ module ActionCable end end - def run_subscribe_callbacks self.class.on_subscribe_callbacks.each { |callback| send(callback) } end |