Sha256: 2ed4f0ad06ecd33190d831db0c08170b49f02227e367b7ac7307176e5577521b

Contents?: true

Size: 1.91 KB

Versions: 8

Compression:

Stored size: 1.91 KB

Contents

# frozen_string_literal: true

require_relative '../../../metadata/ext'
require_relative '../../analytics'
require_relative '../ext'
require_relative '../event'
require_relative '../../../../core/telemetry/logger'

module Datadog
  module Tracing
    module Contrib
      module ActiveRecord
        module Events
          # Defines instrumentation for instantiation.active_record event
          module Instantiation
            include ActiveRecord::Event

            EVENT_NAME = 'instantiation.active_record'

            module_function

            def supported?
              Gem.loaded_specs['activerecord'] \
                && Gem.loaded_specs['activerecord'].version >= Gem::Version.new('4.2')
            end

            def event_name
              self::EVENT_NAME
            end

            def span_name
              Ext::SPAN_INSTANTIATION
            end

            def on_start(span, event, _id, payload)
              span.resource = payload.fetch(:class_name)
              span.type = Ext::SPAN_TYPE_INSTANTIATION
              span.set_tag(Tracing::Metadata::Ext::TAG_COMPONENT, Ext::TAG_COMPONENT)
              span.set_tag(Tracing::Metadata::Ext::TAG_OPERATION, Ext::TAG_OPERATION_INSTANTIATION)

              # Set analytics sample rate
              if Contrib::Analytics.enabled?(configuration[:analytics_enabled])
                Contrib::Analytics.set_sample_rate(span, configuration[:analytics_sample_rate])
              end

              # Measure service stats
              Contrib::Analytics.set_measured(span)

              span.set_tag(Ext::TAG_INSTANTIATION_CLASS_NAME, payload.fetch(:class_name))
              span.set_tag(Ext::TAG_INSTANTIATION_RECORD_COUNT, payload.fetch(:record_count))
            rescue StandardError => e
              Datadog.logger.error(e.message)
              Datadog::Core::Telemetry::Logger.report(e)
            end
          end
        end
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
datadog-2.10.0 lib/datadog/tracing/contrib/active_record/events/instantiation.rb
datadog-2.9.0 lib/datadog/tracing/contrib/active_record/events/instantiation.rb
datadog-2.8.0 lib/datadog/tracing/contrib/active_record/events/instantiation.rb
datadog-2.7.1 lib/datadog/tracing/contrib/active_record/events/instantiation.rb
datadog-2.7.0 lib/datadog/tracing/contrib/active_record/events/instantiation.rb
datadog-2.6.0 lib/datadog/tracing/contrib/active_record/events/instantiation.rb
datadog-2.5.0 lib/datadog/tracing/contrib/active_record/events/instantiation.rb
datadog-2.4.0 lib/datadog/tracing/contrib/active_record/events/instantiation.rb