Sha256: 374610ccd7a8079935026193badf2731440d0dea7a256dd6b4831bb4cd94129a

Contents?: true

Size: 1.84 KB

Versions: 18

Compression:

Stored size: 1.84 KB

Contents

module Instana
  class Rack
    def initialize(app)
      @app = app
    end

    def call(env)
      kvs = { :http => {} }
      kvs[:http][:method] = env['REQUEST_METHOD']
      kvs[:http][:url] = ::CGI.unescape(env['PATH_INFO'])

      if env.key?('HTTP_HOST')
        kvs[:http][:host] = env['HTTP_HOST']
      elsif env.key?('SERVER_NAME')
        kvs[:http][:host] = env['SERVER_NAME']
      end

      # Check incoming context
      incoming_context = {}
      if env.key?('HTTP_X_INSTANA_T')
        incoming_context[:trace_id]  = ::Instana::Util.header_to_id(env['HTTP_X_INSTANA_T'])
        incoming_context[:span_id]   = ::Instana::Util.header_to_id(env['HTTP_X_INSTANA_S']) if env.key?('HTTP_X_INSTANA_S')
        incoming_context[:level]     = env['HTTP_X_INSTANA_L'] if env.key?('HTTP_X_INSTANA_L')
      end

      ::Instana.tracer.log_start_or_continue(:rack, {}, incoming_context)

      status, headers, response = @app.call(env)

      if ::Instana.tracer.tracing?
        kvs[:http][:status] = status

        if status.between?(500, 511)
          # Because of the 5xx response, we flag this span as errored but
          # without a backtrace (no exception)
          ::Instana.tracer.log_error(nil)
        end

        # Save the IDs before the trace ends so we can place
        # them in the response headers in the ensure block
        trace_id = ::Instana.tracer.trace_id
        span_id = ::Instana.tracer.span_id
      end

      [status, headers, response]
    rescue Exception => e
      ::Instana.tracer.log_error(e)
      raise
    ensure
      if headers && ::Instana.tracer.tracing?
        # Set reponse headers; encode as hex string
        headers['X-Instana-T'] = ::Instana::Util.id_to_header(trace_id)
        headers['X-Instana-S'] = ::Instana::Util.id_to_header(span_id)
      end
      ::Instana.tracer.log_end(:rack, kvs)
    end
  end
end

Version data entries

18 entries across 18 versions & 1 rubygems

Version Path
instana-1.4.9 lib/instana/instrumentation/rack.rb
instana-1.4.8 lib/instana/instrumentation/rack.rb
instana-1.4.7 lib/instana/instrumentation/rack.rb
instana-1.4.6 lib/instana/instrumentation/rack.rb
instana-1.4.5 lib/instana/instrumentation/rack.rb
instana-1.4.4 lib/instana/instrumentation/rack.rb
instana-1.4.2 lib/instana/instrumentation/rack.rb
instana-1.4.1 lib/instana/instrumentation/rack.rb
instana-1.4.0 lib/instana/instrumentation/rack.rb
instana-1.3.3 lib/instana/instrumentation/rack.rb
instana-1.3.2 lib/instana/instrumentation/rack.rb
instana-1.3.1 lib/instana/instrumentation/rack.rb
instana-1.3.0 lib/instana/instrumentation/rack.rb
instana-1.2.0 lib/instana/instrumentation/rack.rb
instana-1.1.0 lib/instana/instrumentation/rack.rb
instana-1.0.3 lib/instana/instrumentation/rack.rb
instana-1.0.2 lib/instana/instrumentation/rack.rb
instana-1.0.1 lib/instana/instrumentation/rack.rb