Class: E20::Ops::Middleware::TransactionIdMiddleware
- Inherits:
-
Object
- Object
- E20::Ops::Middleware::TransactionIdMiddleware
- Defined in:
- lib/e20/ops/middleware/transaction_id_middleware.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, options = {}) ⇒ TransactionIdMiddleware
constructor
A new instance of TransactionIdMiddleware.
Constructor Details
#initialize(app, options = {}) ⇒ TransactionIdMiddleware
Returns a new instance of TransactionIdMiddleware.
9 10 11 12 13 |
# File 'lib/e20/ops/middleware/transaction_id_middleware.rb', line 9 def initialize(app, = {}) @app = app @uuid_generator = [:uuid_generator] || UUID.new @logger = [:logger] || Logger.new(STDOUT) end |
Instance Method Details
#call(env) ⇒ Object
15 16 17 18 19 20 21 22 |
# File 'lib/e20/ops/middleware/transaction_id_middleware.rb', line 15 def call(env) uuid = @uuid_generator.generate @logger.info "[#{self.class.name}] Transaction ID: #{uuid}" status, headers, body = @app.call(env) headers["X-Transaction"] = uuid [status, headers, body] end |