Class: Shoryuken::Processor
- Inherits:
-
Object
- Object
- Shoryuken::Processor
- Includes:
- Util
- Defined in:
- lib/shoryuken/processor.rb
Instance Attribute Summary collapse
-
#queue ⇒ Object
readonly
Returns the value of attribute queue.
-
#sqs_msg ⇒ Object
readonly
Returns the value of attribute sqs_msg.
Class Method Summary collapse
Instance Method Summary collapse
-
#initialize(queue, sqs_msg) ⇒ Processor
constructor
A new instance of Processor.
- #process ⇒ Object
Methods included from Util
#elapsed, #fire_event, #logger, #unparse_queues, #worker_name
Constructor Details
#initialize(queue, sqs_msg) ⇒ Processor
Returns a new instance of Processor.
11 12 13 14 |
# File 'lib/shoryuken/processor.rb', line 11 def initialize(queue, sqs_msg) @queue = queue @sqs_msg = sqs_msg end |
Instance Attribute Details
#queue ⇒ Object (readonly)
Returns the value of attribute queue.
5 6 7 |
# File 'lib/shoryuken/processor.rb', line 5 def queue @queue end |
#sqs_msg ⇒ Object (readonly)
Returns the value of attribute sqs_msg.
5 6 7 |
# File 'lib/shoryuken/processor.rb', line 5 def sqs_msg @sqs_msg end |
Class Method Details
.process(queue, sqs_msg) ⇒ Object
7 8 9 |
# File 'lib/shoryuken/processor.rb', line 7 def self.process(queue, sqs_msg) new(queue, sqs_msg).process end |
Instance Method Details
#process ⇒ Object
16 17 18 19 20 21 22 23 24 25 26 27 28 |
# File 'lib/shoryuken/processor.rb', line 16 def process return logger.error { "No worker found for #{queue}" } unless worker Shoryuken::Logging.with_context("#{worker_name(worker.class, sqs_msg, body)}/#{queue}/#{sqs_msg.}") do worker.class.server_middleware.invoke(worker, queue, sqs_msg, body) do worker.perform(sqs_msg, body) end end rescue Exception => ex Array(Shoryuken.exception_handlers).each { |handler| handler.call(ex, queue, sqs_msg) } raise end |