Class: Idempotence::Reservation

Inherits:
Object
  • Object
show all
Includes:
Log::Dependency
Defined in:
lib/idempotence/reservation/reservation.rb

Defined Under Namespace

Modules: Substitute

Constant Summary collapse

METADATA_NAME =
:reserved

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.build(session: nil) ⇒ Object



16
17
18
19
20
# File 'lib/idempotence/reservation/reservation.rb', line 16

def self.build(session: nil)
  instance = new
  instance.configure(session: session)
  instance
end

.call(message, idempotence_key, session: nil) ⇒ Object



11
12
13
14
# File 'lib/idempotence/reservation/reservation.rb', line 11

def self.call(message, idempotence_key, session: nil)
  instance = build(session: session)
  instance.(message, idempotence_key)
end

Instance Method Details

#call(message, idempotence_key, &block) ⇒ Object



26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/idempotence/reservation/reservation.rb', line 26

def call(message, idempotence_key, &block)
  logger.trace(
    "Handling reservation idempotence for message #{message.class.name} #{message..global_position}",
    tag: :reservation
  )

  if reserved?(message)
    handle_reserved_message(message, &block)
  else
    reserve_message(message, idempotence_key)
  end

  logger.info(
    "Handled reservation idempotence for #{message.class.name} #{message..global_position}",
    tag: :reservation
  )
end

#configure(session: nil) ⇒ Object



22
23
24
# File 'lib/idempotence/reservation/reservation.rb', line 22

def configure(session: nil)
  Messaging::Postgres::Write.configure(self, session: session)
end

#handle_reserved_message(message) {|message| ... } ⇒ Object

Yields:

  • (message)


44
45
46
47
48
49
50
51
52
53
54
55
56
# File 'lib/idempotence/reservation/reservation.rb', line 44

def handle_reserved_message(message, &block)
  logger.trace(
    "Handling reserved message #{message.class.name} #{message..global_position}",
    tag: :reservation
  )

  yield message

  logger.info(
    "Handled reserved message #{message.class.name} #{message..global_position}",
    tag: :reservation
  )
end