Class: Honeybadger::NotificationSubscriber

Inherits:
Object
  • Object
show all
Includes:
InstrumentationHelper
Defined in:
lib/honeybadger/notification_subscriber.rb

Instance Method Summary collapse

Methods included from InstrumentationHelper

#decrement_counter, #extract_attributes, #extract_callable, #gauge, #histogram, #increment_counter, #metric_agent, #metric_attributes, #metric_instrumentation, #metric_source, #monotonic_timer, #time

Instance Method Details

#finish(name, id, payload) ⇒ Object



12
13
14
15
16
17
18
19
20
21
22
23
# File 'lib/honeybadger/notification_subscriber.rb', line 12

def finish(name, id, payload)
  finish_time = ::Process.clock_gettime(::Process::CLOCK_MONOTONIC)
  return unless process?(name, payload)

  payload = {
    instrumenter_id: id,
    duration: ((finish_time - payload.delete(:_start_time)) * 1000).round(2)
  }.merge(format_payload(name, payload).compact)

  record(name, payload)
  record_metrics(name, payload)
end

#format_payload(name, payload) ⇒ Object



37
38
39
# File 'lib/honeybadger/notification_subscriber.rb', line 37

def format_payload(name, payload)
  payload
end

#process?(name, payload) ⇒ Boolean

Returns:

  • (Boolean)


33
34
35
# File 'lib/honeybadger/notification_subscriber.rb', line 33

def process?(name, payload)
  true
end

#record(name, payload) ⇒ Object



25
26
27
# File 'lib/honeybadger/notification_subscriber.rb', line 25

def record(name, payload)
  Honeybadger.event(name, payload)
end

#record_metrics(name, payload) ⇒ Object



29
30
31
# File 'lib/honeybadger/notification_subscriber.rb', line 29

def record_metrics(name, payload)
  # noop
end

#start(name, id, payload) ⇒ Object



8
9
10
# File 'lib/honeybadger/notification_subscriber.rb', line 8

def start(name, id, payload)
  payload[:_start_time] = ::Process.clock_gettime(::Process::CLOCK_MONOTONIC)
end