123456789_123456789_123456789_123456789_123456789_

Class: ActionDispatch::ServerTiming

Relationships & Source Files
Namespace Children
Classes:
Inherits: Object
Defined in: actionpack/lib/action_dispatch/middleware/server_timing.rb

Class Method Summary

Instance Method Summary

Constructor Details

.new(app) ⇒ ServerTiming

[ GitHub ]

  
# File 'actionpack/lib/action_dispatch/middleware/server_timing.rb', line 50

def initialize(app)
  @app = app
  @subscriber = Subscriber.instance
  @subscriber.ensure_subscribed
end

Class Method Details

.unsubscribe

This method is for internal use only.
[ GitHub ]

  
# File 'actionpack/lib/action_dispatch/middleware/server_timing.rb', line 46

def self.unsubscribe # :nodoc:
  Subscriber.instance.unsubscribe
end

Instance Method Details

#call(env)

[ GitHub ]

  
# File 'actionpack/lib/action_dispatch/middleware/server_timing.rb', line 56

def call(env)
  response = nil
  events = @subscriber.collect_events do
    response = @app.call(env)
  end

  headers = response[1]

  header_info = events.group_by(&:name).map do |event_name, events_collection|
    "%s;dur=%.2f" % [event_name, events_collection.sum(&:duration)]
  end

  if headers[ActionDispatch::Constants::SERVER_TIMING].present?
    header_info.prepend(headers[ActionDispatch::Constants::SERVER_TIMING])
  end
  headers[ActionDispatch::Constants::SERVER_TIMING] = header_info.join(", ")

  response
end