Class: Rabbit::Receiving::Receive

Inherits:
Object
  • Object
show all
Defined in:
lib/rabbit/receiving/receive.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(message: nil, delivery_info: nil, arguments: nil) ⇒ Receive

Returns a new instance of Receive.



11
12
13
14
15
# File 'lib/rabbit/receiving/receive.rb', line 11

def initialize(message: nil, delivery_info: nil, arguments: nil)
  self.message = message
  self.delivery_info = delivery_info
  self.arguments = arguments
end

Instance Attribute Details

#argumentsObject

Returns the value of attribute arguments.



9
10
11
# File 'lib/rabbit/receiving/receive.rb', line 9

def arguments
  @arguments
end

#delivery_infoObject

Returns the value of attribute delivery_info.



9
10
11
# File 'lib/rabbit/receiving/receive.rb', line 9

def delivery_info
  @delivery_info
end

#messageObject

Returns the value of attribute message.



9
10
11
# File 'lib/rabbit/receiving/receive.rb', line 9

def message
  @message
end

Instance Method Details

#after_hooksObject



52
53
54
# File 'lib/rabbit/receiving/receive.rb', line 52

def after_hooks
  Rabbit.config.after_receiving_hooks || []
end

#before_hooksObject



48
49
50
# File 'lib/rabbit/receiving/receive.rb', line 48

def before_hooks
  Rabbit.config.before_receiving_hooks || []
end

#callObject



17
18
19
20
21
22
# File 'lib/rabbit/receiving/receive.rb', line 17

def call
  log!
  call_hooks(before_hooks)
  process_message
  call_hooks(after_hooks)
end

#call_hooks(hooks) ⇒ Object



42
43
44
45
46
# File 'lib/rabbit/receiving/receive.rb', line 42

def call_hooks(hooks)
  hooks.each do |hook_proc|
    hook_proc.call(message, message_info)
  end
end

#job_classObject



74
75
76
77
78
79
80
# File 'lib/rabbit/receiving/receive.rb', line 74

def job_class
  Rabbit.config.receiving_job_class_callable&.call(
    message: message,
    delivery_info: delivery_info,
    arguments: arguments,
  ) || Rabbit::Receiving::Job
end

#job_configsObject



66
67
68
# File 'lib/rabbit/receiving/receive.rb', line 66

def job_configs
  queue.handler.additional_job_configs
end

#log!Object



24
25
26
27
28
29
30
31
32
33
34
# File 'lib/rabbit/receiving/receive.rb', line 24

def log!
  message_parts = message.scan(/.{1,#{Rabbit.config.logger_message_size_limit}}/)

  message_parts.each_with_index do |message_part, index|
    message = Rabbit::Helper.generate_message(message_part, message_parts.size, index)

    Rabbit.config.receive_logger.debug(
      [message, delivery_info, arguments].join(" / "),
    )
  end
end

#message_infoObject



56
57
58
59
60
# File 'lib/rabbit/receiving/receive.rb', line 56

def message_info
  arguments.merge(
    delivery_info.slice(:exchange, :routing_key),
  )
end

#process_messageObject



36
37
38
39
40
# File 'lib/rabbit/receiving/receive.rb', line 36

def process_message
  job_class
    .set(queue: queue_name, **job_configs)
    .perform_later(message, message_info)
end

#queueObject



62
63
64
# File 'lib/rabbit/receiving/receive.rb', line 62

def queue
  @queue ||= Rabbit::Receiving::Queue.new(message, arguments)
end

#queue_nameObject



70
71
72
# File 'lib/rabbit/receiving/receive.rb', line 70

def queue_name
  queue.name
end