Sha256: 284db51913a2abba7708c7278105acfe0c1a66f73ac86d7a535c86986f3186dc

Contents?: true

Size: 1.27 KB

Versions: 5

Compression:

Stored size: 1.27 KB

Contents

require 'ddtrace/ext/app_types'
require 'ddtrace/contrib/sidekiq/ext'

require 'yaml'

module Datadog
  module Contrib
    module Sidekiq
      # Common functionality used by both client-side and server-side tracers.
      module Tracing
        def initialize(options = {})
          @tracer = options[:tracer] || Datadog.configuration[:sidekiq][:tracer]
        end

        protected

        # If class is wrapping something else, the interesting resource info
        # is the underlying, wrapped class, and not the wrapper. This is
        # primarily to support `ActiveJob`.
        def job_resource(job)
          if job['wrapped']
            job['wrapped'].to_s
          elsif job['class'] == 'Sidekiq::Extensions::DelayedClass'
            delay_extension_class(job).to_s
          else
            job['class'].to_s
          end
        rescue => e
          Datadog::Logger.log.debug { "Error retrieving Sidekiq job class name (jid:#{job['jid']}): #{e}" }

          job['class'].to_s
        end

        #
        def delay_extension_class(job)
          clazz, method = YAML.parse(job['args'].first).children.first.children

          method = method.value[1..-1] # Remove leading `:` from method symbol

          "#{clazz.value}.#{method}"
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
ddtrace-0.34.2 lib/ddtrace/contrib/sidekiq/tracing.rb
ddtrace-0.34.1 lib/ddtrace/contrib/sidekiq/tracing.rb
ddtrace-0.34.0 lib/ddtrace/contrib/sidekiq/tracing.rb
ddtrace-0.33.1 lib/ddtrace/contrib/sidekiq/tracing.rb
ddtrace-0.33.0 lib/ddtrace/contrib/sidekiq/tracing.rb