Sha256: 4bd4e79541a71311ceb5c4772fa0580db35c615e7c26e90223ae749437751e1c

Contents?: true

Size: 932 Bytes

Versions: 4

Compression:

Stored size: 932 Bytes

Contents

require "sentry/rails/tracing/abstract_subscriber"

module Sentry
  module Rails
    module Tracing
      class ActionControllerSubscriber < AbstractSubscriber
        EVENT_NAME = "process_action.action_controller".freeze

        def self.subscribe!
          subscribe_to_event(EVENT_NAME) do |event_name, duration, payload|
            controller = payload[:controller]
            action = payload[:action]

            record_on_current_span(
              op: event_name,
              start_timestamp: payload[:start_timestamp],
              description: "#{controller}##{action}",
              duration: duration
            ) do |span|
              payload = payload.dup
              payload.delete(:headers)
              payload.delete(:request)
              span.set_data(:payload, payload)
              span.set_http_status(payload[:status])
            end
          end
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
sentry-rails-4.5.0 lib/sentry/rails/tracing/action_controller_subscriber.rb
sentry-rails-4.5.0.pre.beta.1 lib/sentry/rails/tracing/action_controller_subscriber.rb
sentry-rails-4.4.0 lib/sentry/rails/tracing/action_controller_subscriber.rb
sentry-rails-4.4.0.pre.beta.0 lib/sentry/rails/tracing/action_controller_subscriber.rb