Class: ActionDispatch::ExceptionWrapper

Inherits:
Object
  • Object
show all
Defined in:
lib/action_dispatch/middleware/exception_wrapper.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(backtrace_cleaner, exception) ⇒ ExceptionWrapper

Returns a new instance of ExceptionWrapper.



34
35
36
37
38
39
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 34

def initialize(backtrace_cleaner, exception)
  @backtrace_cleaner = backtrace_cleaner
  @exception = original_exception(exception)

  expand_backtrace if exception.is_a?(SyntaxError) || exception.cause.is_a?(SyntaxError)
end

Instance Attribute Details

#backtrace_cleanerObject (readonly)

Returns the value of attribute backtrace_cleaner.



32
33
34
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 32

def backtrace_cleaner
  @backtrace_cleaner
end

#exceptionObject (readonly)

Returns the value of attribute exception.



32
33
34
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 32

def exception
  @exception
end

#fileObject (readonly)

Returns the value of attribute file.



32
33
34
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 32

def file
  @file
end

#line_numberObject (readonly)

Returns the value of attribute line_number.



32
33
34
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 32

def line_number
  @line_number
end

Class Method Details

.status_code_for_exception(class_name) ⇒ Object



85
86
87
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 85

def self.status_code_for_exception(class_name)
  Rack::Utils.status_code(@@rescue_responses[class_name])
end

Instance Method Details

#application_traceObject



49
50
51
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 49

def application_trace
  clean_backtrace(:silent)
end

#framework_traceObject



53
54
55
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 53

def framework_trace
  clean_backtrace(:noise)
end

#full_traceObject



57
58
59
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 57

def full_trace
  clean_backtrace(:all)
end

#rescue_templateObject



41
42
43
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 41

def rescue_template
  @@rescue_templates[@exception.class.name]
end

#source_extractsObject



89
90
91
92
93
94
95
96
97
98
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 89

def source_extracts
  backtrace.map do |trace|
    file, line_number = extract_file_and_line_number(trace)

    {
      code: source_fragment(file, line_number),
      line_number: line_number
    }
  end
end

#status_codeObject



45
46
47
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 45

def status_code
  self.class.status_code_for_exception(@exception.class.name)
end

#tracesObject



61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# File 'lib/action_dispatch/middleware/exception_wrapper.rb', line 61

def traces
  application_trace_with_ids = []
  framework_trace_with_ids = []
  full_trace_with_ids = []

  full_trace.each_with_index do |trace, idx|
    trace_with_id = { id: idx, trace: trace }

    if application_trace.include?(trace)
      application_trace_with_ids << trace_with_id
    else
      framework_trace_with_ids << trace_with_id
    end

    full_trace_with_ids << trace_with_id
  end

  {
    "Application Trace" => application_trace_with_ids,
    "Framework Trace" => framework_trace_with_ids,
    "Full Trace" => full_trace_with_ids
  }
end