Class: Yabeda::Rack::Queue::Middleware
- Inherits:
-
Object
- Object
- Yabeda::Rack::Queue::Middleware
- Defined in:
- lib/yabeda/rack/queue/middleware.rb
Defined Under Namespace
Classes: StderrLogger, YabedaReporter
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, reporter: YabedaReporter.new, logger: nil, clock: nil) ⇒ Middleware
constructor
A new instance of Middleware.
Constructor Details
#initialize(app, reporter: YabedaReporter.new, logger: nil, clock: nil) ⇒ Middleware
Returns a new instance of Middleware.
15 16 17 18 19 20 21 |
# File 'lib/yabeda/rack/queue/middleware.rb', line 15 def initialize(app, reporter: YabedaReporter.new, logger: nil, clock: nil) @app = app @reporter = reporter @parser = HeaderTimestampParser.new @logger = logger || StderrLogger.new @clock = clock || -> { Process.clock_gettime(Process::CLOCK_REALTIME) } end |
Instance Method Details
#call(env) ⇒ Object
23 24 25 26 |
# File 'lib/yabeda/rack/queue/middleware.rb', line 23 def call(env) measure_queue_time(env) if env["HTTP_X_REQUEST_START"] || env["HTTP_X_QUEUE_START"] @app.call(env) end |