Sha256: 0a8c7646676a9d6ce0075120ef96e138801c60720f0774eb6c4c14224d6c5fe7

Contents?: true

Size: 1.45 KB

Versions: 4

Compression:

Stored size: 1.45 KB

Contents

# frozen_string_literal: true

require "active_support/callbacks"

module ActionCable
  module Connection
    # = Action Cable \Connection \Callbacks
    #
    # There are <tt>before_command</tt>, <tt>after_command</tt>, and <tt>around_command</tt> callbacks
    # available to be invoked before, after or around every command received by a client respectively.
    # The term "command" here refers to any interaction received by a client (subscribing, unsubscribing or performing actions):
    #
    #    module ApplicationCable
    #      class Connection < ActionCable::Connection::Base
    #        identified_by :user
    #
    #        around_command :set_current_account
    #
    #        private
    #
    #        def set_current_account
    #          # Now all channels could use Current.account
    #          Current.set(account: user.account) { yield }
    #        end
    #      end
    #    end
    #
    module Callbacks
      extend  ActiveSupport::Concern
      include ActiveSupport::Callbacks

      included do
        define_callbacks :command
      end

      module ClassMethods
        def before_command(*methods, &block)
          set_callback(:command, :before, *methods, &block)
        end

        def after_command(*methods, &block)
          set_callback(:command, :after, *methods, &block)
        end

        def around_command(*methods, &block)
          set_callback(:command, :around, *methods, &block)
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
actioncable-7.1.0 lib/action_cable/connection/callbacks.rb
actioncable-7.1.0.rc2 lib/action_cable/connection/callbacks.rb
actioncable-7.1.0.rc1 lib/action_cable/connection/callbacks.rb
actioncable-7.1.0.beta1 lib/action_cable/connection/callbacks.rb