Class: ActionDispatch::PublicExceptions
Relationships & Source Files | |
Inherits: | Object |
Defined in: | actionpack/lib/action_dispatch/middleware/public_exceptions.rb |
Overview
When called, this middleware renders an error page. By default if an HTML response is expected it will render static error pages from the /public
directory. For example when this middleware receives a 500 response it will render the template found in /public/500.html
. If an internationalized locale is set, this middleware will attempt to render the template in /public/500.<locale>.html
. If an internationalized template is not found it will fall back on /public/500.html
.
When a request with a content type other than HTML is made, this middleware will attempt to convert error information into the appropriate response type.
Class Method Summary
- .new(public_path) ⇒ PublicExceptions constructor
Instance Attribute Summary
- #public_path rw
Instance Method Summary
Constructor Details
.new(public_path) ⇒ PublicExceptions
# File 'actionpack/lib/action_dispatch/middleware/public_exceptions.rb', line 15
def initialize(public_path) @public_path = public_path end
Instance Attribute Details
#public_path (rw)
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/public_exceptions.rb', line 13
attr_accessor :public_path
Instance Method Details
#call(env)
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/public_exceptions.rb', line 19
def call(env) status = env["PATH_INFO"][1..-1] request = ActionDispatch::Request.new(env) content_type = request.formats.first body = { :status => status, :error => Rack::Utils::HTTP_STATUS_CODES.fetch(status.to_i, Rack::Utils::HTTP_STATUS_CODES[500]) } render(status, content_type, body) end