Module: MessageStore::Read
Defined Under Namespace
Modules: Build, Call, Configure
Classes: Iterator
Constant Summary
collapse
- Error =
Class.new(RuntimeError)
Class Method Summary
collapse
Instance Method Summary
collapse
Class Method Details
.included(cls) ⇒ Object
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
# File 'lib/message_store/read.rb', line 3
def self.included(cls)
cls.class_exec do
include Dependency
include Initializer
include TemplateMethod
include Log::Dependency
extend Build
extend Call
extend Configure
dependency :iterator, Iterator
initializer :stream_name, :position, :batch_size
template_method! :configure
end
end
|
Instance Method Details
#call(&action) ⇒ Object
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
# File 'lib/message_store/read.rb', line 48
def call(&action)
logger.trace(tag: :read) { "Reading (Stream Name: #{stream_name})" }
if action.nil?
error_message = "Reader must be actuated with a block"
logger.error(tag: :read) { error_message }
raise Error, error_message
end
enumerate_message_data(&action)
logger.info(tag: :read) { "Reading completed (Stream Name: #{stream_name})" }
return AsyncInvocation::Incorrect
end
|
#enumerate_message_data(&action) ⇒ Object
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
# File 'lib/message_store/read.rb', line 64
def enumerate_message_data(&action)
logger.trace(tag: :read) { "Enumerating (Stream Name: #{stream_name})" }
message_data = nil
loop do
message_data = iterator.next
break if message_data.nil?
logger.debug(tags: [:data, :message_data]) { message_data.pretty_inspect }
action.(message_data)
end
logger.debug(tag: :read) { "Enumerated (Stream Name: #{stream_name})" }
end
|