Sha256: 3de1f8fcab2c1598503d6d015878a8dfb5a2b377c0bddfabf04eb15f1ed2ad73

Contents?: true

Size: 1.4 KB

Versions: 12

Compression:

Stored size: 1.4 KB

Contents

# typed: false

require_relative '../analytics'
require_relative '../active_support/notifications/event'
require_relative 'ext'

module Datadog
  module Tracing
    module Contrib
      module Kafka
        # Defines basic behaviors for an ActiveSupport event.
        module Event
          def self.included(base)
            base.include(ActiveSupport::Notifications::Event)
            base.extend(ClassMethods)
          end

          # Class methods for Kafka events.
          module ClassMethods
            def event_name
              self::EVENT_NAME
            end

            def span_options
              { service: configuration[:service_name] }
            end

            def configuration
              Datadog.configuration.tracing[:kafka]
            end

            def process(span, _event, _id, payload)
              span.set_tag(Tracing::Metadata::Ext::TAG_COMPONENT, Ext::TAG_COMPONENT)

              span.set_tag(Ext::TAG_CLIENT, payload[:client_id])

              # 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)

              report_if_exception(span, payload)
            end
          end
        end
      end
    end
  end
end

Version data entries

12 entries across 12 versions & 1 rubygems

Version Path
ddtrace-1.9.0 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.8.0 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.7.0 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.6.1 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.6.0 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.5.2 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.5.1 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.5.0 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.4.2 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.4.1 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.4.0 lib/datadog/tracing/contrib/kafka/event.rb
ddtrace-1.3.0 lib/datadog/tracing/contrib/kafka/event.rb