Sha256: a5a9d29dcfad0c9d76b67b5619dfca51ffe4d2be09dc719620849c517f37d184

Contents?: true

Size: 1.29 KB

Versions: 49

Compression:

Stored size: 1.29 KB

Contents

require 'rack'

module Appsignal
  module Rack
    class RailsInstrumentation
      def initialize(app, options = {})
        Appsignal.logger.debug 'Initializing Appsignal::Rack::RailsInstrumentation'
        @app, @options = app, options
      end

      def call(env)
        if Appsignal.active?
          call_with_appsignal_monitoring(env)
        else
          @app.call(env)
        end
      end

      def call_with_appsignal_monitoring(env)
        request = ActionDispatch::Request.new(env)
        transaction = Appsignal::Transaction.create(
          env['action_dispatch.request_id'],
          Appsignal::Transaction::HTTP_REQUEST,
          request,
          :params_method => :filtered_parameters
        )
        begin
          @app.call(env)
        rescue => error
          transaction.set_error(error)
          raise error
        ensure
          controller = env['action_controller.instance']
          if controller
            transaction.set_action("#{controller.class.to_s}##{controller.action_name}")
          end
          transaction.set_http_or_background_queue_start
          transaction.set_metadata('path', request.path)
          transaction.set_metadata('method', request.request_method)
          Appsignal::Transaction.complete_current!
        end
      end
    end
  end
end

Version data entries

49 entries across 49 versions & 1 rubygems

Version Path
appsignal-1.1.2 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.1 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.1.beta.1 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.0.beta.13 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.0.beta.12 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.7 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.6 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.0.beta.11 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.6.beta.4 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.0.beta.10 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.6.beta.3 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.0.beta.9 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.6.beta.2 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.0.beta.8 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.6.beta.1 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.5 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.1.0.beta.7 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.5.beta.4 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.5.beta.3 lib/appsignal/rack/rails_instrumentation.rb
appsignal-1.0.5.beta.2 lib/appsignal/rack/rails_instrumentation.rb