Sha256: 637e772dea1c643b4a5ebbe40636157e73591322a214bd3e4a15e856bcd25f58

Contents?: true

Size: 1.42 KB

Versions: 6

Compression:

Stored size: 1.42 KB

Contents

module Appsignal
  module Rack
    class SinatraInstrumentation
      def initialize(app, options = {})
        Appsignal.logger.debug 'Initializing Appsignal::Rack::SinatraInstrumentation'
        @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)
        ActiveSupport::Notifications.instrument(
          'process_action.sinatra',
          raw_payload(env)
        ) do |payload|
          begin
            @app.call(env)
          ensure
            # This information is available only after the
            # request has been processed by Sinatra.
            payload[:action] = env['sinatra.route']
          end
        end
      ensure
        # In production newer versions of Sinatra don't raise errors, but store
        # them in the sinatra.error env var.
        Appsignal::Transaction.current.add_exception(env['sinatra.error']) if env['sinatra.error']
      end

      def raw_payload(env)
        request = @options.fetch(:request_class, ::Sinatra::Request).new(env)
        params = request.public_send(@options.fetch(:params_method, :params))
        {
          :params  => params,
          :session => request.session,
          :method  => request.request_method,
          :path    => request.path
        }
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
appsignal-0.11.14 lib/appsignal/rack/sinatra_instrumentation.rb
appsignal-0.11.14.beta.1 lib/appsignal/rack/sinatra_instrumentation.rb
appsignal-0.11.13 lib/appsignal/rack/sinatra_instrumentation.rb
appsignal-0.11.13.beta.4 lib/appsignal/rack/sinatra_instrumentation.rb
appsignal-0.11.13.beta.3 lib/appsignal/rack/sinatra_instrumentation.rb
appsignal-0.11.13.beta.2 lib/appsignal/rack/sinatra_instrumentation.rb