Sha256: 578489f91645f97c045f163d7cc7a2a21cc7d4710d6744cb25a4c225f82ae3d1

Contents?: true

Size: 1.13 KB

Versions: 3

Compression:

Stored size: 1.13 KB

Contents

# frozen_string_literal: true

# Copyright The OpenTelemetry Authors
#
# SPDX-License-Identifier: Apache-2.0
require 'opentelemetry-instrumentation-rack'

module OpenTelemetry
  module Instrumentation
    module Sinatra
      module Middlewares
        # Middleware to trace Sinatra requests
        class TracerMiddleware
          def initialize(app)
            @app = app
          end

          def call(env)
            response = @app.call(env)
          ensure
            trace_response(env, response)
          end

          def trace_response(env, response)
            span = OpenTelemetry::Instrumentation::Rack.current_span
            return unless span.recording?

            span.set_attribute('http.route', env['sinatra.route'].split.last) if env['sinatra.route']
            span.name = env['sinatra.route'] if env['sinatra.route']

            sinatra_response = ::Sinatra::Response.new([], response.first)
            return unless sinatra_response.server_error?

            span.record_exception(env['sinatra.error'])
            span.status = OpenTelemetry::Trace::Status.error
          end
        end
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
opentelemetry-instrumentation-sinatra-0.21.2 lib/opentelemetry/instrumentation/sinatra/middlewares/tracer_middleware.rb
opentelemetry-instrumentation-sinatra-0.21.1 lib/opentelemetry/instrumentation/sinatra/middlewares/tracer_middleware.rb
opentelemetry-instrumentation-sinatra-0.21.0 lib/opentelemetry/instrumentation/sinatra/middlewares/tracer_middleware.rb