Sha256: 0f71e57f2589cd37466d158b4e2019873442d703de2bdf26ed39b23b6ee7614a
Contents?: true
Size: 1.69 KB
Versions: 1
Compression:
Stored size: 1.69 KB
Contents
module Propono class QueueListener include Sqs def self.listen(topic_id, &message_processor) new(topic_id, &message_processor).listen end def initialize(topic_id, &message_processor) @topic_id = topic_id @message_processor = message_processor end def listen loop do unless read_messages sleep 10 end end end private def read_messages response = sqs.receive_message( queue_url, {'MaxNumberOfMessages' => 10} ) messages = response.body['Message'] if messages.empty? false else messages.each { |msg| process_sqs_message(msg) } end rescue Propono.config.logger.error "Unexpected error reading from queue #{queue_url}" Propono.config.logger.error $! end def process_sqs_message(sqs_message) body = JSON.parse(sqs_message["Body"])["Message"] # Legacy syntax is covered in the rescue statement # This begin/rescue dance and the rescue block will be removed in v1. begin body = JSON.parse(body) context = body.symbolize_keys message = context.delete(:message) Propono.config.logger.info "Propono [#{context[:id]}]: Received from sqs." @message_processor.call(message, context) rescue JSON::ParserError, TypeError Propono.config.logger.info("Sending and recieving messages without ids is deprecated") @message_processor.call(body) end sqs.delete_message(queue_url, sqs_message['ReceiptHandle']) end def queue_url @queue_url ||= subscription.queue.url end def subscription @subscription ||= QueueSubscription.create(@topic_id) end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
propono-0.9.1 | lib/propono/services/queue_listener.rb |