Class: Pallets::Middleware::AppsignalInstrumenter

Inherits:
Object
  • Object
show all
Extended by:
Appsignal::Hooks::Helpers
Defined in:
lib/pallets/middleware/appsignal_instrumenter.rb

Class Method Summary collapse

Class Method Details

.call(worker, job, context) ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'lib/pallets/middleware/appsignal_instrumenter.rb', line 8

def self.call(worker, job, context)
  job_status = nil
  transaction = Appsignal::Transaction.create(
    SecureRandom.uuid,
    Appsignal::Transaction::BACKGROUND_JOB,
    Appsignal::Transaction::GenericRequest.new(queue_start: job['created_at'])
  )

  Appsignal.instrument('perform_job.pallets') do
    begin
      yield
    rescue Exception => ex
      job_status = :failed
      transaction.set_error(ex)
      raise
    ensure
      transaction.set_action_if_nil("#{job['task_class']}#run (#{job['workflow_class']})")
      transaction.params = filtered_context(context)
      (job).each { |kv| transaction.(*kv) }
      transaction.set_http_or_background_queue_start
      Appsignal.increment_counter('pallets_job_count', 1, status: job_status || :successful)
    end
  end
ensure
  Appsignal::Transaction.complete_current!
end

.filtered_context(context) ⇒ Object



35
36
37
38
39
40
# File 'lib/pallets/middleware/appsignal_instrumenter.rb', line 35

def self.filtered_context(context)
  Appsignal::Utils::HashSanitizer.sanitize(
    context,
    Appsignal.config[:filter_parameters]
  )
end

.formatted_metadata(job) ⇒ Object



42
43
44
# File 'lib/pallets/middleware/appsignal_instrumenter.rb', line 42

def self.(job)
  job.map { |k, v| [k, truncate(string_or_inspect(v))] }
end