class Hallmonitor::Middleware

Public Class Methods

new(app) click to toggle source
# File lib/hallmonitor/middleware.rb, line 5
def initialize(app)
  @app = app
end

Public Instance Methods

call(env) click to toggle source
# File lib/hallmonitor/middleware.rb, line 9
def call(env)
  request = Rack::Request.new(env)
  @event_base_name = "http.#{request.path_info.gsub('/', '.')}.#{request.request_method}"
  if !request.path_info.match(/^\/?assets/)
    @event = Hallmonitor::TimedEvent.new("#{@event_base_name}.response_time")
    @event.start = Time.now
  else 
    @event = nil
  end

  response = @app.call(env)

  if @event
    @event.stop = Time.now
    Hallmonitor::Outputter.output(@event)
    Hallmonitor::Outputter.output(Hallmonitor::Event.new("#{@event_base_name}.count"))
  end
  response
end