Module: ActionController::Rescue

Defined in:
lib/action_controller/rescue.rb

Overview

Actions that fail to perform as expected throw exceptions. These exceptions can either be rescued for the public view (with a nice user-friendly explanation) or for the developers view (with tons of debugging information). The developers view is already implemented by the Action Controller, but the public view should be tailored to your specific application.

The default behavior for public exceptions is to render a static html file with the name of the error code thrown. If no such file exists, an empty response is sent with the correct status code.

You can override what constitutes a local request by overriding the local_request? method in your own controller. Custom rescue behavior is achieved by overriding the rescue_action_in_public and rescue_action_locally methods.

Defined Under Namespace

Modules: ClassMethods

Constant Summary collapse

LOCALHOST =
'127.0.0.1'.freeze
DEFAULT_RESCUE_RESPONSE =
:internal_server_error
DEFAULT_RESCUE_RESPONSES =
{
  'ActionController::RoutingError'             => :not_found,
  'ActionController::UnknownAction'            => :not_found,
  'ActiveRecord::RecordNotFound'               => :not_found,
  'ActiveRecord::StaleObjectError'             => :conflict,
  'ActiveRecord::RecordInvalid'                => :unprocessable_entity,
  'ActiveRecord::RecordNotSaved'               => :unprocessable_entity,
  'ActionController::MethodNotAllowed'         => :method_not_allowed,
  'ActionController::NotImplemented'           => :not_implemented,
  'ActionController::InvalidAuthenticityToken' => :unprocessable_entity
}
DEFAULT_RESCUE_TEMPLATE =
'diagnostics'
DEFAULT_RESCUE_TEMPLATES =
{
  'ActionView::MissingTemplate'       => 'missing_template',
  'ActionController::RoutingError'    => 'routing_error',
  'ActionController::UnknownAction'   => 'unknown_action',
  'ActionView::TemplateError'         => 'template_error'
}
RESCUES_TEMPLATE_PATH =
ActionView::Template::EagerPath.new_and_loaded(
File.join(File.dirname(__FILE__), "templates"))

Class Method Summary collapse

Class Method Details

.included(base) ⇒ Object

:nodoc:



44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# File 'lib/action_controller/rescue.rb', line 44

def self.included(base) #:nodoc:
  base.cattr_accessor :rescue_responses
  base.rescue_responses = Hash.new(DEFAULT_RESCUE_RESPONSE)
  base.rescue_responses.update DEFAULT_RESCUE_RESPONSES

  base.cattr_accessor :rescue_templates
  base.rescue_templates = Hash.new(DEFAULT_RESCUE_TEMPLATE)
  base.rescue_templates.update DEFAULT_RESCUE_TEMPLATES

  base.extend(ClassMethods)
  base.send :include, ActiveSupport::Rescuable

  base.class_eval do
    alias_method_chain :perform_action, :rescue
  end
end