# frozen_string_literal: true require "active_support/callbacks" module ActionCable module Channel # = Action Cable \Channel \Callbacks # # Action Cable Channel provides callback hooks that are invoked during the # life cycle of a channel: # # * {before_subscribe}[rdoc-ref:ClassMethods#before_subscribe] # * {after_subscribe}[rdoc-ref:ClassMethods#after_subscribe] (aliased as # {on_subscribe}[rdoc-ref:ClassMethods#on_subscribe]) # * {before_unsubscribe}[rdoc-ref:ClassMethods#before_unsubscribe] # * {after_unsubscribe}[rdoc-ref:ClassMethods#after_unsubscribe] (aliased as # {on_unsubscribe}[rdoc-ref:ClassMethods#on_unsubscribe]) # # ==== Example # # class ChatChannel < ApplicationCable::Channel # after_subscribe :send_welcome_message, unless: :subscription_rejected? # after_subscribe :track_subscription # # private # def send_welcome_message # broadcast_to(...) # end # # def track_subscription # # ... # end # end # module Callbacks extend ActiveSupport::Concern include ActiveSupport::Callbacks included do define_callbacks :subscribe define_callbacks :unsubscribe end module ClassMethods def before_subscribe(*methods, &block) set_callback(:subscribe, :before, *methods, &block) end # This callback will be triggered after the Base#subscribed method is # called, even if the subscription was rejected with the Base#reject # method. # # To trigger the callback only on successful subscriptions, use the # Base#subscription_rejected? method: # # after_subscribe :my_method, unless: :subscription_rejected? # def after_subscribe(*methods, &block) set_callback(:subscribe, :after, *methods, &block) end alias_method :on_subscribe, :after_subscribe def before_unsubscribe(*methods, &block) set_callback(:unsubscribe, :before, *methods, &block) end def after_unsubscribe(*methods, &block) set_callback(:unsubscribe, :after, *methods, &block) end alias_method :on_unsubscribe, :after_unsubscribe end end end end