Sha256: 9a544bfafefa90a5530fdf9291e204c8f5dee4e85260e86002242e82fb9644d2

Contents?: true

Size: 1.25 KB

Versions: 4

Compression:

Stored size: 1.25 KB

Contents

# frozen_string_literal: true

module PlainApm
  module Hooks
    class ActionPack < ActiveSupportSubscriber
      NOTIFICATION_PATTERN = /\A[^!]\w+\.action_controller\Z/.freeze

      private

      def notification_pattern
        NOTIFICATION_PATTERN
      end

      def payload(event)
        name, source = *event.name.split(".")
        payload = event.payload

        base = {
          "source" => source,
          "name" => name,
          "backtrace" => filtered_backtrace,
          "allocations" => event.allocations,
          "started_at" => event.time,
          "finished_at" => event.end
        }

        case name
        when "process_action"
          base.merge({
            "controller" => payload[:controller],
            "action" => payload[:action],
            "params" => payload[:params],
            "format" => payload[:format],
            "method" => payload[:method],
            "path" => payload[:path],
            "status" => payload[:status]
          })
        when "redirect_to", "start_processing", "halted_callback", "send_file", "send_data"
          nil
        when "read_fragment", "write_fragment", "exist_fragment?", "expire_fragment"
          # controller, action, key
          nil
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
plain_apm-0.4.0 lib/plain_apm/hooks/action_pack.rb
plain_apm-0.3.0 lib/plain_apm/hooks/action_pack.rb
plain_apm-0.2.9 lib/plain_apm/hooks/action_pack.rb
plain_apm-0.2.8 lib/plain_apm/hooks/action_pack.rb