Class: Eventboss::UnitOfWork

Inherits:
Object
  • Object
show all
Includes:
Logging, SafeThread
Defined in:
lib/eventboss/unit_of_work.rb

Overview

UnitOfWork handles calls a listener for each message and deletes on success

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from SafeThread

#handle_exception, #safe_thread

Methods included from Logging

#logger

Constructor Details

#initialize(queue, listener, message) ⇒ UnitOfWork

Returns a new instance of UnitOfWork.



9
10
11
12
13
# File 'lib/eventboss/unit_of_work.rb', line 9

def initialize(queue, listener, message)
  @queue = queue
  @listener = listener
  @message = message
end

Instance Attribute Details

#listenerObject

Returns the value of attribute listener.



7
8
9
# File 'lib/eventboss/unit_of_work.rb', line 7

def listener
  @listener
end

#messageObject

Returns the value of attribute message.



7
8
9
# File 'lib/eventboss/unit_of_work.rb', line 7

def message
  @message
end

#queueObject

Returns the value of attribute queue.



7
8
9
# File 'lib/eventboss/unit_of_work.rb', line 7

def queue
  @queue
end

Instance Method Details

#cleanup(client) ⇒ Object



26
27
28
29
30
31
# File 'lib/eventboss/unit_of_work.rb', line 26

def cleanup(client)
  client.delete_message(
    queue_url: @queue.url, receipt_handle: @message.receipt_handle
  )
  logger.debug('Deleting', @message.message_id)
end

#run(client) ⇒ Object



15
16
17
18
19
20
21
22
23
24
# File 'lib/eventboss/unit_of_work.rb', line 15

def run(client)
  logger.debug('Started', @message.message_id)
  processor = @listener.new
  processor.receive(JSON.parse(@message.body))
  logger.info('Finished', @message.message_id)
rescue StandardError => exception
  handle_exception(exception, processor: processor, message_id: @message.message_id)
else
  cleanup(client)
end