Upgraded exception notifier plugin.
This commit is contained in:
parent
2d7d0d3b94
commit
d09d3922c1
18 changed files with 20 additions and 471 deletions
4
Gemfile
4
Gemfile
|
@ -13,4 +13,8 @@ gem 'haml', '>=2.0.6'
|
|||
group :development do
|
||||
gem 'annotate'
|
||||
gem 'hirb'
|
||||
end
|
||||
|
||||
group :production do
|
||||
gem 'exception_notification', :require => 'exception_notifier'
|
||||
end
|
|
@ -33,6 +33,7 @@ GEM
|
|||
builder (2.1.2)
|
||||
erubis (2.6.6)
|
||||
abstract (>= 1.0.0)
|
||||
exception_notification (2.4.0)
|
||||
fastercsv (1.5.4)
|
||||
haml (3.0.25)
|
||||
hirb (0.3.4)
|
||||
|
@ -84,6 +85,7 @@ PLATFORMS
|
|||
|
||||
DEPENDENCIES
|
||||
annotate
|
||||
exception_notification
|
||||
fastercsv
|
||||
haml (>= 2.0.6)
|
||||
hirb
|
||||
|
|
|
@ -46,4 +46,7 @@ Foodsoft::Application.configure do
|
|||
|
||||
# Send deprecation notices to registered listeners
|
||||
config.active_support.deprecation = :notify
|
||||
|
||||
# Use sendmail to avoid ssl cert problems
|
||||
config.action_mailer.delivery_method = :sendmail
|
||||
end
|
||||
|
|
|
@ -23,11 +23,16 @@ url_options = {
|
|||
:protocol => Foodsoft.config[:protocol]
|
||||
}
|
||||
url_options.merge!({:port => Foodsoft.config[:port]}) if Foodsoft.config[:port]
|
||||
ActionMailer::Base.default_url_options = url_options
|
||||
|
||||
# Configuration of the exception_notification plugin
|
||||
# Mailadresses are set in config/foodsoft.yaml
|
||||
ExceptionNotifier.exception_recipients = Foodsoft.config[:notification]['error_recipients']
|
||||
ExceptionNotifier.sender_address = Foodsoft.config[:notification]['sender_address']
|
||||
ExceptionNotifier.email_prefix = Foodsoft.config[:notification]['email_prefix']
|
||||
Foodsoft::Application.configure do
|
||||
config.action_mailer.default_url_options = url_options
|
||||
|
||||
# Configuration of the exception_notification plugin
|
||||
# Mailadresses are set in config/app_config.yml
|
||||
config.middleware.use ExceptionNotifier,
|
||||
:email_prefix => Foodsoft.config[:notification]['email_prefix'],
|
||||
:sender_address => Foodsoft.config[:notification]['sender_address'],
|
||||
:exception_recipients => Foodsoft.config[:notification]['error_recipients']
|
||||
|
||||
end
|
||||
|
||||
|
|
111
vendor/plugins/exception_notification/README
vendored
111
vendor/plugins/exception_notification/README
vendored
|
@ -1,111 +0,0 @@
|
|||
= Exception Notifier Plugin for Rails
|
||||
|
||||
The Exception Notifier plugin provides a mailer object and a default set of
|
||||
templates for sending email notifications when errors occur in a Rails
|
||||
application. The plugin is configurable, allowing programmers to specify:
|
||||
|
||||
* the sender address of the email
|
||||
* the recipient addresses
|
||||
* the text used to prefix the subject line
|
||||
|
||||
The email includes information about the current request, session, and
|
||||
environment, and also gives a backtrace of the exception.
|
||||
|
||||
== Usage
|
||||
|
||||
First, include the ExceptionNotifiable mixin in whichever controller you want
|
||||
to generate error emails (typically ApplicationController):
|
||||
|
||||
class ApplicationController < ActionController::Base
|
||||
include ExceptionNotifiable
|
||||
...
|
||||
end
|
||||
|
||||
Then, specify the email recipients in your environment:
|
||||
|
||||
ExceptionNotifier.exception_recipients = %w(joe@schmoe.com bill@schmoe.com)
|
||||
|
||||
And that's it! The defaults take care of the rest.
|
||||
|
||||
== Configuration
|
||||
|
||||
You can tweak other values to your liking, as well. In your environment file,
|
||||
just set any or all of the following values:
|
||||
|
||||
# defaults to exception.notifier@default.com
|
||||
ExceptionNotifier.sender_address =
|
||||
%("Application Error" <app.error@myapp.com>)
|
||||
|
||||
# defaults to "[ERROR] "
|
||||
ExceptionNotifier.email_prefix = "[APP] "
|
||||
|
||||
Email notifications will only occur when the IP address is determined not to
|
||||
be local. You can specify certain addresses to always be local so that you'll
|
||||
get a detailed error instead of the generic error page. You do this in your
|
||||
controller (or even per-controller):
|
||||
|
||||
consider_local "64.72.18.143", "14.17.21.25"
|
||||
|
||||
You can specify subnet masks as well, so that all matching addresses are
|
||||
considered local:
|
||||
|
||||
consider_local "64.72.18.143/24"
|
||||
|
||||
The address "127.0.0.1" is always considered local. If you want to completely
|
||||
reset the list of all addresses (for instance, if you wanted "127.0.0.1" to
|
||||
NOT be considered local), you can simply do, somewhere in your controller:
|
||||
|
||||
local_addresses.clear
|
||||
|
||||
== Customization
|
||||
|
||||
By default, the notification email includes four parts: request, session,
|
||||
environment, and backtrace (in that order). You can customize how each of those
|
||||
sections are rendered by placing a partial named for that part in your
|
||||
app/views/exception_notifier directory (e.g., _session.rhtml). Each partial has
|
||||
access to the following variables:
|
||||
|
||||
* @controller: the controller that caused the error
|
||||
* @request: the current request object
|
||||
* @exception: the exception that was raised
|
||||
* @host: the name of the host that made the request
|
||||
* @backtrace: a sanitized version of the exception's backtrace
|
||||
* @rails_root: a sanitized version of RAILS_ROOT
|
||||
* @data: a hash of optional data values that were passed to the notifier
|
||||
* @sections: the array of sections to include in the email
|
||||
|
||||
You can reorder the sections, or exclude sections completely, by altering the
|
||||
ExceptionNotifier.sections variable. You can even add new sections that
|
||||
describe application-specific data--just add the section's name to the list
|
||||
(whereever you'd like), and define the corresponding partial. Then, if your
|
||||
new section requires information that isn't available by default, make sure
|
||||
it is made available to the email using the exception_data macro:
|
||||
|
||||
class ApplicationController < ActionController::Base
|
||||
...
|
||||
protected
|
||||
exception_data :additional_data
|
||||
|
||||
def additional_data
|
||||
{ :document => @document,
|
||||
:person => @person }
|
||||
end
|
||||
...
|
||||
end
|
||||
|
||||
In the above case, @document and @person would be made available to the email
|
||||
renderer, allowing your new section(s) to access and display them. See the
|
||||
existing sections defined by the plugin for examples of how to write your own.
|
||||
|
||||
== Advanced Customization
|
||||
|
||||
By default, the email notifier will only notify on critical errors. For
|
||||
ActiveRecord::RecordNotFound and ActionController::UnknownAction, it will
|
||||
simply render the contents of your public/404.html file. Other exceptions
|
||||
will render public/500.html and will send the email notification. If you want
|
||||
to use different rules for the notification, you will need to implement your
|
||||
own rescue_action_in_public method. You can look at the default implementation
|
||||
in ExceptionNotifiable for an example of how to go about that.
|
||||
|
||||
|
||||
Copyright (c) 2005 Jamis Buck, released under the MIT license
|
|
@ -1,4 +0,0 @@
|
|||
require "action_mailer"
|
||||
require "exception_notifier"
|
||||
require "exception_notifiable"
|
||||
require "exception_notifier_helper"
|
|
@ -1,99 +0,0 @@
|
|||
require 'ipaddr'
|
||||
|
||||
# Copyright (c) 2005 Jamis Buck
|
||||
#
|
||||
# Permission is hereby granted, free of charge, to any person obtaining
|
||||
# a copy of this software and associated documentation files (the
|
||||
# "Software"), to deal in the Software without restriction, including
|
||||
# without limitation the rights to use, copy, modify, merge, publish,
|
||||
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||
# permit persons to whom the Software is furnished to do so, subject to
|
||||
# the following conditions:
|
||||
#
|
||||
# The above copyright notice and this permission notice shall be
|
||||
# included in all copies or substantial portions of the Software.
|
||||
#
|
||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
module ExceptionNotifiable
|
||||
def self.included(target)
|
||||
target.extend(ClassMethods)
|
||||
end
|
||||
|
||||
module ClassMethods
|
||||
def consider_local(*args)
|
||||
local_addresses.concat(args.flatten.map { |a| IPAddr.new(a) })
|
||||
end
|
||||
|
||||
def local_addresses
|
||||
addresses = read_inheritable_attribute(:local_addresses)
|
||||
unless addresses
|
||||
addresses = [IPAddr.new("127.0.0.1")]
|
||||
write_inheritable_attribute(:local_addresses, addresses)
|
||||
end
|
||||
addresses
|
||||
end
|
||||
|
||||
def exception_data(deliverer=self)
|
||||
if deliverer == self
|
||||
read_inheritable_attribute(:exception_data)
|
||||
else
|
||||
write_inheritable_attribute(:exception_data, deliverer)
|
||||
end
|
||||
end
|
||||
|
||||
def exceptions_to_treat_as_404
|
||||
exceptions = [ActiveRecord::RecordNotFound,
|
||||
ActionController::UnknownController,
|
||||
ActionController::UnknownAction]
|
||||
exceptions << ActionController::RoutingError if ActionController.const_defined?(:RoutingError)
|
||||
exceptions
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def local_request?
|
||||
remote = IPAddr.new(request.remote_ip)
|
||||
!self.class.local_addresses.detect { |addr| addr.include?(remote) }.nil?
|
||||
end
|
||||
|
||||
def render_404
|
||||
respond_to do |type|
|
||||
type.html { render :file => "#{RAILS_ROOT}/public/404.html", :status => "404 Not Found" }
|
||||
type.all { render :nothing => true, :status => "404 Not Found" }
|
||||
end
|
||||
end
|
||||
|
||||
def render_500
|
||||
respond_to do |type|
|
||||
type.html { render :file => "#{RAILS_ROOT}/public/500.html", :status => "500 Error" }
|
||||
type.all { render :nothing => true, :status => "500 Error" }
|
||||
end
|
||||
end
|
||||
|
||||
def rescue_action_in_public(exception)
|
||||
case exception
|
||||
when *self.class.exceptions_to_treat_as_404
|
||||
render_404
|
||||
|
||||
else
|
||||
render_500
|
||||
|
||||
deliverer = self.class.exception_data
|
||||
data = case deliverer
|
||||
when nil then {}
|
||||
when Symbol then send(deliverer)
|
||||
when Proc then deliverer.call(self)
|
||||
end
|
||||
|
||||
ExceptionNotifier.deliver_exception_notification(exception, self,
|
||||
request, data)
|
||||
end
|
||||
end
|
||||
end
|
|
@ -1,66 +0,0 @@
|
|||
require 'pathname'
|
||||
|
||||
# Copyright (c) 2005 Jamis Buck
|
||||
#
|
||||
# Permission is hereby granted, free of charge, to any person obtaining
|
||||
# a copy of this software and associated documentation files (the
|
||||
# "Software"), to deal in the Software without restriction, including
|
||||
# without limitation the rights to use, copy, modify, merge, publish,
|
||||
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||
# permit persons to whom the Software is furnished to do so, subject to
|
||||
# the following conditions:
|
||||
#
|
||||
# The above copyright notice and this permission notice shall be
|
||||
# included in all copies or substantial portions of the Software.
|
||||
#
|
||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
class ExceptionNotifier < ActionMailer::Base
|
||||
@@sender_address = %("Exception Notifier" <exception.notifier@default.com>)
|
||||
cattr_accessor :sender_address
|
||||
|
||||
@@exception_recipients = []
|
||||
cattr_accessor :exception_recipients
|
||||
|
||||
@@email_prefix = "[ERROR] "
|
||||
cattr_accessor :email_prefix
|
||||
|
||||
@@sections = %w(request session environment backtrace)
|
||||
cattr_accessor :sections
|
||||
|
||||
self.template_root = "#{File.dirname(__FILE__)}/../views"
|
||||
|
||||
def self.reloadable?() false end
|
||||
|
||||
def exception_notification(exception, controller, request, data={})
|
||||
content_type "text/plain"
|
||||
|
||||
subject "#{email_prefix}#{controller.controller_name}##{controller.action_name} (#{exception.class}) #{exception.message.inspect}"
|
||||
|
||||
recipients exception_recipients
|
||||
from sender_address
|
||||
|
||||
body data.merge({ :controller => controller, :request => request,
|
||||
:exception => exception, :host => (request.env["HTTP_X_FORWARDED_HOST"] || request.env["HTTP_HOST"]),
|
||||
:backtrace => sanitize_backtrace(exception.backtrace),
|
||||
:rails_root => rails_root, :data => data,
|
||||
:sections => sections })
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def sanitize_backtrace(trace)
|
||||
re = Regexp.new(/^#{Regexp.escape(rails_root)}/)
|
||||
trace.map { |line| Pathname.new(line.gsub(re, "[RAILS_ROOT]")).cleanpath.to_s }
|
||||
end
|
||||
|
||||
def rails_root
|
||||
@rails_root ||= Pathname.new(RAILS_ROOT).cleanpath.to_s
|
||||
end
|
||||
|
||||
end
|
|
@ -1,78 +0,0 @@
|
|||
require 'pp'
|
||||
|
||||
# Copyright (c) 2005 Jamis Buck
|
||||
#
|
||||
# Permission is hereby granted, free of charge, to any person obtaining
|
||||
# a copy of this software and associated documentation files (the
|
||||
# "Software"), to deal in the Software without restriction, including
|
||||
# without limitation the rights to use, copy, modify, merge, publish,
|
||||
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||
# permit persons to whom the Software is furnished to do so, subject to
|
||||
# the following conditions:
|
||||
#
|
||||
# The above copyright notice and this permission notice shall be
|
||||
# included in all copies or substantial portions of the Software.
|
||||
#
|
||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
module ExceptionNotifierHelper
|
||||
VIEW_PATH = "views/exception_notifier"
|
||||
APP_PATH = "#{RAILS_ROOT}/app/#{VIEW_PATH}"
|
||||
PARAM_FILTER_REPLACEMENT = "[FILTERED]"
|
||||
|
||||
def render_section(section)
|
||||
RAILS_DEFAULT_LOGGER.info("rendering section #{section.inspect}")
|
||||
summary = render_overridable(section).strip
|
||||
unless summary.blank?
|
||||
title = render_overridable(:title, :locals => { :title => section }).strip
|
||||
"#{title}\n\n#{summary.gsub(/^/, " ")}\n\n"
|
||||
end
|
||||
end
|
||||
|
||||
def render_overridable(partial, options={})
|
||||
if File.exist?(path = "#{APP_PATH}/_#{partial}.rhtml")
|
||||
render(options.merge(:file => path, :use_full_path => false))
|
||||
elsif File.exist?(path = "#{File.dirname(__FILE__)}/../#{VIEW_PATH}/_#{partial}.rhtml")
|
||||
render(options.merge(:file => path, :use_full_path => false))
|
||||
else
|
||||
""
|
||||
end
|
||||
end
|
||||
|
||||
def inspect_model_object(model, locals={})
|
||||
render_overridable(:inspect_model,
|
||||
:locals => { :inspect_model => model,
|
||||
:show_instance_variables => true,
|
||||
:show_attributes => true }.merge(locals))
|
||||
end
|
||||
|
||||
def inspect_value(value)
|
||||
len = 512
|
||||
result = object_to_yaml(value).gsub(/\n/, "\n ").strip
|
||||
result = result[0,len] + "... (#{result.length-len} bytes more)" if result.length > len+20
|
||||
result
|
||||
end
|
||||
|
||||
def object_to_yaml(object)
|
||||
object.to_yaml.sub(/^---\s*/m, "")
|
||||
end
|
||||
|
||||
def exclude_raw_post_parameters?
|
||||
@controller && @controller.respond_to?(:filter_parameters)
|
||||
end
|
||||
|
||||
def filter_sensitive_post_data_parameters(parameters)
|
||||
exclude_raw_post_parameters? ? @controller.__send__(:filter_parameters, parameters) : parameters
|
||||
end
|
||||
|
||||
def filter_sensitive_post_data_from_env(env_key, env_value)
|
||||
return env_value unless exclude_raw_post_parameters?
|
||||
return PARAM_FILTER_REPLACEMENT if (env_key =~ /RAW_POST_DATA/i)
|
||||
return @controller.__send__(:filter_parameters, {env_key => env_value}).values[0]
|
||||
end
|
||||
end
|
|
@ -1,61 +0,0 @@
|
|||
require 'test_helper'
|
||||
require 'exception_notifier_helper'
|
||||
|
||||
class ExceptionNotifierHelperTest < Test::Unit::TestCase
|
||||
|
||||
class ExceptionNotifierHelperIncludeTarget
|
||||
include ExceptionNotifierHelper
|
||||
end
|
||||
|
||||
def setup
|
||||
@helper = ExceptionNotifierHelperIncludeTarget.new
|
||||
end
|
||||
|
||||
# No controller
|
||||
|
||||
def test_should_not_exclude_raw_post_parameters_if_no_controller
|
||||
assert !@helper.exclude_raw_post_parameters?
|
||||
end
|
||||
|
||||
# Controller, no filtering
|
||||
|
||||
class ControllerWithoutFilterParameters; end
|
||||
|
||||
def test_should_not_filter_env_values_for_raw_post_data_keys_if_controller_can_not_filter_parameters
|
||||
stub_controller(ControllerWithoutFilterParameters.new)
|
||||
assert @helper.filter_sensitive_post_data_from_env("RAW_POST_DATA", "secret").include?("secret")
|
||||
end
|
||||
def test_should_not_exclude_raw_post_parameters_if_controller_can_not_filter_parameters
|
||||
stub_controller(ControllerWithoutFilterParameters.new)
|
||||
assert !@helper.exclude_raw_post_parameters?
|
||||
end
|
||||
def test_should_return_params_if_controller_can_not_filter_parameters
|
||||
stub_controller(ControllerWithoutFilterParameters.new)
|
||||
assert_equal :params, @helper.filter_sensitive_post_data_parameters(:params)
|
||||
end
|
||||
|
||||
# Controller with filtering
|
||||
|
||||
class ControllerWithFilterParameters
|
||||
def filter_parameters(params); :filtered end
|
||||
end
|
||||
|
||||
def test_should_filter_env_values_for_raw_post_data_keys_if_controller_can_filter_parameters
|
||||
stub_controller(ControllerWithFilterParameters.new)
|
||||
assert !@helper.filter_sensitive_post_data_from_env("RAW_POST_DATA", "secret").include?("secret")
|
||||
assert @helper.filter_sensitive_post_data_from_env("SOME_OTHER_KEY", "secret").include?("secret")
|
||||
end
|
||||
def test_should_exclude_raw_post_parameters_if_controller_can_filter_parameters
|
||||
stub_controller(ControllerWithFilterParameters.new)
|
||||
assert @helper.exclude_raw_post_parameters?
|
||||
end
|
||||
def test_should_delegate_param_filtering_to_controller_if_controller_can_filter_parameters
|
||||
stub_controller(ControllerWithFilterParameters.new)
|
||||
assert_equal :filtered, @helper.filter_sensitive_post_data_parameters(:params)
|
||||
end
|
||||
|
||||
private
|
||||
def stub_controller(controller)
|
||||
@helper.instance_variable_set(:@controller, controller)
|
||||
end
|
||||
end
|
|
@ -1,7 +0,0 @@
|
|||
require 'test/unit'
|
||||
require 'rubygems'
|
||||
require 'active_support'
|
||||
|
||||
$:.unshift File.join(File.dirname(__FILE__), '../lib')
|
||||
|
||||
RAILS_ROOT = '.' unless defined?(RAILS_ROOT)
|
|
@ -1 +0,0 @@
|
|||
<%= @backtrace.join "\n" %>
|
|
@ -1,7 +0,0 @@
|
|||
<% max = @request.env.keys.max { |a,b| a.length <=> b.length } -%>
|
||||
<% @request.env.keys.sort.each do |key| -%>
|
||||
* <%= "%-*s: %s" % [max.length, key, filter_sensitive_post_data_from_env(key, @request.env[key].to_s.strip)] %>
|
||||
<% end -%>
|
||||
|
||||
* Process: <%= $$ %>
|
||||
* Server : <%= `hostname -s`.chomp %>
|
|
@ -1,16 +0,0 @@
|
|||
<% if show_attributes -%>
|
||||
[attributes]
|
||||
<% attrs = inspect_model.attributes -%>
|
||||
<% max = attrs.keys.max { |a,b| a.length <=> b.length } -%>
|
||||
<% attrs.keys.sort.each do |attr| -%>
|
||||
* <%= "%*-s: %s" % [max.length, attr, object_to_yaml(attrs[attr]).gsub(/\n/, "\n ").strip] %>
|
||||
<% end -%>
|
||||
<% end -%>
|
||||
|
||||
<% if show_instance_variables -%>
|
||||
[instance variables]
|
||||
<% inspect_model.instance_variables.sort.each do |variable| -%>
|
||||
<%- next if variable == "@attributes" -%>
|
||||
* <%= variable %>: <%= inspect_value(inspect_model.instance_variable_get(variable)) %>
|
||||
<% end -%>
|
||||
<% end -%>
|
|
@ -1,4 +0,0 @@
|
|||
* URL : <%= @request.protocol %><%= @host %><%= @request.request_uri %>
|
||||
* IP address: <%= @request.env["HTTP_X_FORWARDED_FOR"] || @request.env["REMOTE_ADDR"] %>
|
||||
* Parameters: <%= filter_sensitive_post_data_parameters(@request.parameters).inspect %>
|
||||
* Rails root: <%= @rails_root %>
|
|
@ -1,2 +0,0 @@
|
|||
* session id: <%= @request.session.instance_variable_get(:@session_id).inspect %>
|
||||
* data: <%= PP.pp(@request.session.instance_variable_get(:@data),"").gsub(/\n/, "\n ").strip %>
|
|
@ -1,3 +0,0 @@
|
|||
-------------------------------
|
||||
<%= title.to_s.humanize %>:
|
||||
-------------------------------
|
|
@ -1,6 +0,0 @@
|
|||
A <%= @exception.class %> occurred in <%= @controller.controller_name %>#<%= @controller.action_name %>:
|
||||
|
||||
<%= @exception.message %>
|
||||
<%= @backtrace.first %>
|
||||
|
||||
<%= @sections.map { |section| render_section(section) }.join %>
|
Loading…
Reference in a new issue