Module: Datadog::Contrib::Kafka::Event::ClassMethods

Defined in:
lib/ddtrace/contrib/kafka/event.rb

Overview

Class methods for Kafka events.

Instance Method Summary collapse

Instance Method Details

#configurationObject



30
31
32
# File 'lib/ddtrace/contrib/kafka/event.rb', line 30

def configuration
  Datadog.configuration[:kafka]
end

#event_nameObject



18
19
20
# File 'lib/ddtrace/contrib/kafka/event.rb', line 18

def event_name
  self::EVENT_NAME
end

#process(span, _event, _id, payload) ⇒ Object



34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/ddtrace/contrib/kafka/event.rb', line 34

def process(span, _event, _id, payload)
  span.service = configuration[:service_name]
  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

#span_optionsObject



22
23
24
# File 'lib/ddtrace/contrib/kafka/event.rb', line 22

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

#tracerObject



26
27
28
# File 'lib/ddtrace/contrib/kafka/event.rb', line 26

def tracer
  -> { configuration[:tracer] }
end