Sha256: d5a5c364454307081a6024ad6bab64413f99f19e7126f001215eb4c4dd50e571

Contents?: true

Size: 1.5 KB

Versions: 9

Compression:

Stored size: 1.5 KB

Contents

# frozen_string_literal: true

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 on_start(span, _event, _id, payload)
              span.set_tag(Tracing::Metadata::Ext::TAG_COMPONENT, Ext::TAG_COMPONENT)
              span.set_tag(Contrib::Ext::Messaging::TAG_SYSTEM, Ext::TAG_MESSAGING_SYSTEM)

              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

9 entries across 9 versions & 1 rubygems

Version Path
datadog-2.9.0 lib/datadog/tracing/contrib/kafka/event.rb
datadog-2.8.0 lib/datadog/tracing/contrib/kafka/event.rb
datadog-2.7.1 lib/datadog/tracing/contrib/kafka/event.rb
datadog-2.7.0 lib/datadog/tracing/contrib/kafka/event.rb
datadog-2.6.0 lib/datadog/tracing/contrib/kafka/event.rb
datadog-2.5.0 lib/datadog/tracing/contrib/kafka/event.rb
datadog-2.4.0 lib/datadog/tracing/contrib/kafka/event.rb
datadog-2.3.0 lib/datadog/tracing/contrib/kafka/event.rb
datadog-2.2.0 lib/datadog/tracing/contrib/kafka/event.rb