Sha256: 239c6be605ed167d4b16531886d5341e5e0916b2b9d9b32b64c6122124543f5a

Contents?: true

Size: 1.83 KB

Versions: 19

Compression:

Stored size: 1.83 KB

Contents

# encoding: utf-8
# This file is distributed under New Relic's license terms.
# See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.

module NewRelic
  module Agent
    module Instrumentation
      module Sinatra
        module TransactionNamer
          extend self

          def transaction_name_for_route(env, request)
            name = route_for_sinatra(env)
            name = route_name_for_padrino(request) if name.nil?

            transaction_name(name, request) unless name.nil?
          end

          def initial_transaction_name(request)
            transaction_name(::NewRelic::Agent::UNKNOWN_METRIC, request)
          end

          def transaction_name(route_text, request)
            verb = http_verb(request)

            route_text = route_text.source if route_text.is_a?(Regexp)
            name = route_text.gsub(%r{^[/^\\A]*(.*?)[/\$\?\\z]*$}, '\1')
            name = "#{verb} #{name}" unless verb.nil?
            name
          rescue => e
            ::NewRelic::Agent.logger.debug("#{e.class} : #{e.message} - Error encountered trying to identify Sinatra transaction name")
            ::NewRelic::Agent::UNKNOWN_METRIC
          end

          def http_verb(request)
            request.request_method if request.respond_to?(:request_method)
          end

          # For bare Sinatra, our override on process_route captures the last
          # route into the environment for us to use later on
          def route_for_sinatra(env)
            env["newrelic.last_route"]
          end

          # For Padrino, the request object has a copy of the matched route
          # on it when we go to evaluating, so we can just retrieve that
          def route_name_for_padrino(request)
            request.route_obj.original_path
          rescue
            nil
          end
        end
      end
    end
  end
end

Version data entries

19 entries across 19 versions & 1 rubygems

Version Path
newrelic_rpm-3.14.1.311 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.14.0.305 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.13.2.302 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.13.1.300 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.13.0.299 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.12.1.298 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.12.0.288 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.11.2.286 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.11.1.284 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.11.0.283 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.10.0.279 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.9.9.275 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.9.8.273 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.9.7.266 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.9.6.257 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.9.5.251 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.9.4.245 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.9.3.241 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb
newrelic_rpm-3.9.2.239 lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb