Sha256: e21a1f07fea53d20d8b062423e1031da6fa1d328837a9201a1c1fc531b084c9d

Contents?: true

Size: 1.23 KB

Versions: 6

Compression:

Stored size: 1.23 KB

Contents

module Shoryuken
  module Util
    def logger
      Shoryuken.logger
    end

    def fire_event(event, reverse = false)
      logger.debug { "Firing '#{event}' lifecycle event" }
      arr = Shoryuken.options[:lifecycle_events][event]
      arr.reverse! if reverse
      arr.each do |block|
        begin
          block.call
        rescue => ex
          logger.warn(event: event)
          logger.warn "#{ex.class.name}: #{ex.message}"
        end
      end
    end

    def elapsed(started_at)
      # elapsed in ms
      (Time.now - started_at) * 1000
    end

    def unparse_queues(queues)
      queues.each_with_object({}) do |name, queue_and_weights|
        queue_and_weights[name] = queue_and_weights[name].to_i + 1
      end.to_a
    end

    def worker_name(worker_class, sqs_msg, body = nil)
      if Shoryuken.active_job? \
          && !sqs_msg.is_a?(Array) \
          && sqs_msg.message_attributes \
          && sqs_msg.message_attributes['shoryuken_class'] \
          && sqs_msg.message_attributes['shoryuken_class'][:string_value] \
          == ActiveJob::QueueAdapters::ShoryukenAdapter::JobWrapper.to_s \
          && body

        "ActiveJob/#{body['job_class']}"
      else
        worker_class.to_s
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
shoryuken-3.1.8 lib/shoryuken/util.rb
shoryuken-3.1.7 lib/shoryuken/util.rb
shoryuken-3.1.6 lib/shoryuken/util.rb
shoryuken-3.1.5 lib/shoryuken/util.rb
shoryuken-3.1.4 lib/shoryuken/util.rb
shoryuken-3.1.3 lib/shoryuken/util.rb