Class: ActionSubscriber::Middleware::Router

Inherits:
Object
  • Object
show all
Includes:
Logging
Defined in:
lib/action_subscriber/middleware/router.rb

Constant Summary collapse

INSTRUMENT_KEY =
"process_event.action_subscriber".freeze

Instance Method Summary collapse

Methods included from Logging

initialize_logger, logger, #logger, logger=

Constructor Details

#initialize(app) ⇒ Router

Returns a new instance of Router.



7
8
9
# File 'lib/action_subscriber/middleware/router.rb', line 7

def initialize(app)
  @app = app
end

Instance Method Details

#call(env) ⇒ Object



11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# File 'lib/action_subscriber/middleware/router.rb', line 11

def call(env)
  action = env.action
  message_id = env.message_id
  queue = env.queue
  routing_key = env.routing_key
  subscriber = env.subscriber

  logger.info { "START #{message_id} #{subscriber}##{action}" }

  instrument_call(subscriber, routing_key, queue) do
    subscriber.run_action_with_filters(env, action)
  end

  logger.info { "FINISHED #{message_id}" }
end