summaryrefslogtreecommitdiff
path: root/lib/killjoy/rmq/message.rb
diff options
context:
space:
mode:
authormo khan <mokhan@users.noreply.github.com>2019-04-20 09:32:24 -0600
committerGitHub <noreply@github.com>2019-04-20 09:32:24 -0600
commitbc2274ce4183bee7523665bf8a905a584f20081a (patch)
treeb336f1e4c305a3d22a2177b5b8e14f2b68989348 /lib/killjoy/rmq/message.rb
parenta7cd8453ab61f3a7b6ab59cda9d051dc725cdead (diff)
parent85bd0e5d520109f29011f6eff69e9d2f2e20af26 (diff)
Merge pull request #2 from mokhan/kafkamain
Kafka
Diffstat (limited to 'lib/killjoy/rmq/message.rb')
-rw-r--r--lib/killjoy/rmq/message.rb47
1 files changed, 47 insertions, 0 deletions
diff --git a/lib/killjoy/rmq/message.rb b/lib/killjoy/rmq/message.rb
new file mode 100644
index 0000000..2aa9c7d
--- /dev/null
+++ b/lib/killjoy/rmq/message.rb
@@ -0,0 +1,47 @@
+module Killjoy
+ class Message
+ attr_reader :to_hash, :info, :channel
+
+ def initialize(raw_message, info, channel)
+ @to_hash = JSON.parse(raw_message, symbolize_names: true)
+ @info = info
+ @channel = channel
+ @interceptors = { ack: [], reject: [] }
+ end
+
+ def intercept(response_type, &block)
+ @interceptors[response_type] << block
+ end
+
+ def process(future)
+ future.on_success do |rows|
+ ack!
+ end
+ future.on_failure do |error|
+ reject!
+ end
+ end
+
+ def ack!
+ run_interceptors_for(:ack)
+ channel.acknowledge(info.delivery_tag, false)
+ end
+
+ def reject!(requeue = false)
+ run_interceptors_for(:reject)
+ channel.reject(info.delivery_tag, requeue)
+ end
+
+ def to_s
+ to_hash
+ end
+
+ private
+
+ def run_interceptors_for(response_type)
+ @interceptors[response_type].each do |interceptor|
+ interceptor.call
+ end
+ end
+ end
+end