class Rack::ShowStatus
Rack::ShowStatus
catches all empty responses and replaces them with a site explaining the error.
Additional details can be put into rack.showstatus.detail
and will be shown as HTML. If such details exist, the error page is always rendered, even if the reply was not empty.
Public Class Methods
Source
# File lib/rack/show_status.rb, line 19 def initialize(app) @app = app @template = ERB.new(TEMPLATE) end
Public Instance Methods
Source
# File lib/rack/show_status.rb, line 24 def call(env) status, headers, body = response = @app.call(env) empty = headers[CONTENT_LENGTH].to_i <= 0 # client or server error, or explicit message if (status.to_i >= 400 && empty) || env[RACK_SHOWSTATUS_DETAIL] # This double assignment is to prevent an "unused variable" warning. # Yes, it is dumb, but I don't like Ruby yelling at me. req = req = Rack::Request.new(env) message = Rack::Utils::HTTP_STATUS_CODES[status.to_i] || status.to_s # This double assignment is to prevent an "unused variable" warning. # Yes, it is dumb, but I don't like Ruby yelling at me. detail = detail = env[RACK_SHOWSTATUS_DETAIL] || message html = @template.result(binding) size = html.bytesize response[2] = Rack::BodyProxy.new([html]) do body.close if body.respond_to?(:close) end headers[CONTENT_TYPE] = "text/html" headers[CONTENT_LENGTH] = size.to_s end response end