Sha256: 3fd0119e056e2154ae496557f38ff445e1d844ab01262e1b555eb86b6fbe3856

Contents?: true

Size: 1.17 KB

Versions: 2

Compression:

Stored size: 1.17 KB

Contents

if defined? Appsignal
  Appsignal.logger.info('Loading Dispatch Rider integration')

  module DispatchRider
    module Integrations
      module Appsignal

        def self.wrap_message(job, message)
          begin
            Appsignal::Transaction.create(SecureRandom.uuid, ENV.to_hash)

            ActiveSupport::Notifications.instrument(
              'perform_job.dispatch-rider',
              :class => message.subject,
              :method => 'handle',
              :attempts => message.receive_count,
              :queue => message.queue_name,
              :queue_time => (Time.now.to_f - message.sent_at.to_f) * 1000
            ) do
              job.call
            end
          rescue Exception => exception
            unless Appsignal.is_ignored_exception?(exception)
              Appsignal::Transaction.current.add_exception(exception)
            end
            raise exception
          ensure
            Appsignal::Transaction.current.complete!
          end
        end

      end
    end
  end

  DispatchRider.config do |config|

    config.around(:dispatch_message) do |job, message|
      DispatchRider::Appsignal.wrap_message(job, message)
    end

  end

end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
dispatch-rider-1.2.1 lib/dispatch-rider/integrations/appsignal.rb
dispatch-rider-1.2.0 lib/dispatch-rider/integrations/appsignal.rb