From bd8c0b8a7ad680aae909c6453758d86b9fc66559 Mon Sep 17 00:00:00 2001 From: Santiago Pastorino Date: Mon, 11 Jun 2012 16:58:24 -0300 Subject: Return proper format on exceptions --- .../middleware/public_exceptions.rb | 50 ++++++++++++++++------ 1 file changed, 36 insertions(+), 14 deletions(-) (limited to 'actionpack/lib/action_dispatch') diff --git a/actionpack/lib/action_dispatch/middleware/public_exceptions.rb b/actionpack/lib/action_dispatch/middleware/public_exceptions.rb index 85b8d178bf..bf9149ebf2 100644 --- a/actionpack/lib/action_dispatch/middleware/public_exceptions.rb +++ b/actionpack/lib/action_dispatch/middleware/public_exceptions.rb @@ -3,28 +3,50 @@ module ActionDispatch class PublicExceptions attr_accessor :public_path - def initialize(public_path) + def initialize(public_path, consider_all_requests_local = false) @public_path = public_path + @consider_all_requests_local = consider_all_requests_local end def call(env) - status = env["PATH_INFO"][1..-1] - locale_path = "#{public_path}/#{status}.#{I18n.locale}.html" if I18n.locale - path = "#{public_path}/#{status}.html" - - if locale_path && File.exist?(locale_path) - render(status, File.read(locale_path)) - elsif File.exist?(path) - render(status, File.read(path)) + exception = env["action_dispatch.exception"] + status = env["PATH_INFO"][1..-1] + request = ActionDispatch::Request.new(env) + content_type = request.formats.first + format = (mime = Mime[content_type]) && "to_#{mime.to_sym}" + body = { :status => status, :error => exception.message } + + render(status, body, :format => format, :content_type => content_type) + end + + private + + def render(status, body, options) + format = options[:format] + + if !@consider_all_requests_local && format && body.respond_to?(format) + render_format(status, body.public_send(format), options) else - [404, { "X-Cascade" => "pass" }, []] + render_html(status) end end - private + def render_format(status, body, options) + [status, {'Content-Type' => "#{options[:content_type]}; charset=#{ActionDispatch::Response.default_charset}", + 'Content-Length' => body.bytesize.to_s}, [body]] + end + + def render_html(status) + found = false + path = "#{public_path}/#{status}.#{I18n.locale}.html" if I18n.locale + path = "#{public_path}/#{status}.html" unless path && (found = File.exist?(path)) - def render(status, body) - [status, {'Content-Type' => "text/html; charset=#{Response.default_charset}", 'Content-Length' => body.bytesize.to_s}, [body]] + if found || File.exist?(path) + body = File.read(path) + [status, {'Content-Type' => "text/html; charset=#{Response.default_charset}", 'Content-Length' => body.bytesize.to_s}, [body]] + else + [404, { "X-Cascade" => "pass" }, []] + end end end -end \ No newline at end of file +end -- cgit v1.2.3