Class: Brakeman::Report::Table
  
  
  
  
  
    - Inherits:
 
    - 
      Base
      
        
          - Object
 
          
            - Base
 
          
            - Brakeman::Report::Table
 
          
        
        show all
      
     
  
  
  
  
  
  
  
  
  
  
    - Defined in:
 
    - lib/brakeman/report/report_table.rb
 
  
  
 
  Constant Summary
  
  Constants included
     from Util
  Util::ALL_COOKIES, Util::ALL_PARAMETERS, Util::COOKIES, Util::COOKIES_SEXP, Util::DIR_CONST, Util::LITERALS, Util::PARAMETERS, Util::PARAMS_SEXP, Util::PATH_PARAMETERS, Util::QUERY_PARAMETERS, Util::REQUEST_COOKIES, Util::REQUEST_ENV, Util::REQUEST_PARAMETERS, Util::REQUEST_PARAMS, Util::REQUEST_REQUEST_PARAMETERS, Util::SAFE_LITERAL, Util::SESSION, Util::SESSION_SEXP, Util::SIMPLE_LITERALS
  Instance Attribute Summary
  
  Attributes inherited from Base
  #checks, #tracker
  
    
      Instance Method Summary
      collapse
    
    
      
        - 
  
    
      #convert_ignored_warning(warning, original)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #convert_template_warning(warning, original)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #convert_to_rows(warnings, type = :warning)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #convert_warning(warning, original)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #generate_controller_warnings  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Generate table of controller warnings or nil if no warnings.
 
  
 
      
        - 
  
    
      #generate_controllers  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Generate table of controllers and routes found for those controllers.
 
  
 
      
        - 
  
    
      #generate_errors  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Generate table of errors or return nil if no errors.
 
  
 
      
        - 
  
    
      #generate_ignored_warnings  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #generate_model_warnings  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Generate table of model warnings or return nil if no warnings.
 
  
 
      
        - 
  
    
      #generate_obsolete  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #generate_overview  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #generate_report  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #generate_template_warnings  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Generate table of template warnings or return nil if no warnings.
 
  
 
      
        - 
  
    
      #generate_templates  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Generate listings of templates and their output.
 
  
 
      
        - 
  
    
      #generate_warning_overview  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Generate table of how many warnings of each warning type were reported.
 
  
 
      
        - 
  
    
      #generate_warnings  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #initialize(*args)  ⇒ Table 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #output_table(title, result, output)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #render_array(template, headings, value_array, locals)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #render_warnings(warnings, type, template, cols, sort_col)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #sort(rows, sort_col)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
        - 
  
    
      #text_header  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Generate header for text output.
 
  
 
      
        - 
  
    
      #text_message(warning, message)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
Escape warning message and highlight user input in text output.
 
  
 
      
        - 
  
    
      #truncate_table(str)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    
  
 
      
    
  
  
  
  
  
  
  
  
  
  Methods inherited from Base
  #absolute_paths?, #all_warnings, #context_for, #controller_information, #controller_warnings, #filter_warnings, #generic_warnings, #github_url, #ignored_warnings, #model_warnings, #number_of_templates, #rails_version, #template_warnings, #warning_file, #warnings_summary
  
  
  
  
  
  
  
  
  Methods included from Util
  #all_literals?, #array?, #block?, #call?, #camelize, #class_name, #constant?, #contains_class?, #cookies?, #dir_glob?, #false?, #hash?, #hash_access, #hash_insert, #hash_iterate, #hash_values, #integer?, #kwsplat?, #literal?, #make_call, #node_type?, #number?, #params?, #pluralize, #rails_version, #recurse_check?, #regexp?, #remove_kwsplat, #request_headers?, #request_value?, #result?, #safe_literal, #safe_literal?, #safe_literal_target?, #set_env_defaults, #sexp?, #simple_literal?, #string?, #string_interp?, #symbol?, #template_path_to_name, #true?, #underscore
  Constructor Details
  
    
  
  
    #initialize(*args)  ⇒ Table 
  
  
  
  
    
Returns a new instance of Table.
   
 
  
  
    
      
4
5
6
7 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 4
def initialize *args
  super
  @table = Terminal::Table
end 
     | 
  
 
  
 
  
    Instance Method Details
    
      
  
  
    #convert_ignored_warning(warning, original)  ⇒ Object 
  
  
  
  
    
      
202
203
204 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 202
def convert_ignored_warning warning, original
  convert_warning warning, original
end 
     | 
  
 
    
      
  
  
    #convert_template_warning(warning, original)  ⇒ Object 
  
  
  
  
    
      
206
207
208 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 206
def convert_template_warning warning, original
  convert_warning warning, original
end 
     | 
  
 
    
      
  
  
    #convert_to_rows(warnings, type = :warning)  ⇒ Object 
  
  
  
  
    
      
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 185
def convert_to_rows warnings, type = :warning
  warnings.map do |warning|
    w = warning.to_row type
    case type
    when :warning
      convert_warning w, warning
    when :ignored
      convert_ignored_warning w, warning
    when :template
      convert_template_warning w, warning
    else
      convert_warning w, warning
    end
  end
end
     | 
  
 
    
      
  
  
    #convert_warning(warning, original)  ⇒ Object 
  
  
  
  
    
      
227
228
229
230
231 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 227
def convert_warning warning, original
  warning["Message"] = text_message original, warning["Message"]
  warning
end 
     | 
  
 
    
      
  
  
    #generate_controller_warnings  ⇒ Object 
  
  
  
  
    
Generate table of controller warnings or nil if no warnings
   
 
  
  
    
      
125
126
127
128
129
130
131 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 125
def generate_controller_warnings
  render_warnings controller_warnings,
                  :controller,
                  'controller_warnings',
                  ['Confidence', 'Controller', 'Warning Type', "CWE ID", 'Message'],
                  'Controller'
end
     | 
  
 
    
      
  
  
    #generate_controllers  ⇒ Object 
  
  
  
  
    
Generate table of controllers and routes found for those controllers
   
 
  
  
    
      
76
77
78
79
80
81
82
83
84 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 76
def generate_controllers
  controller_rows = controller_information
  cols = ['Name', 'Parent', 'Includes', 'Routes']
  locals = {:controller_rows => controller_rows}
  values = controller_rows.collect{|row| row.values_at(*cols) }
  render_array('controller_overview', cols, values, locals)
end
     | 
  
 
    
      
  
  
    #generate_errors  ⇒ Object 
  
  
  
  
    
Generate table of errors or return nil if no errors
   
 
  
  
    
      
87
88
89
90 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 87
def generate_errors
  values = tracker.errors.collect{|error| [error[:error], error[:backtrace][0]]}
  render_array('error_overview', ['Error', 'Location'], values, {:tracker => tracker})
end
     | 
  
 
    
      
  
  
    #generate_ignored_warnings  ⇒ Object 
  
  
  
  
    
      
133
134
135
136
137
138
139 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 133
def generate_ignored_warnings
  render_warnings ignored_warnings,
                  :ignored,
                  'ignored_warnings',
                  ['Confidence', 'Warning Type', "CWE ID", 'File', 'Message'],
                  'Warning Type'
end
     | 
  
 
    
      
  
  
    #generate_model_warnings  ⇒ Object 
  
  
  
  
    
Generate table of model warnings or return nil if no warnings
   
 
  
  
    
      
116
117
118
119
120
121
122 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 116
def generate_model_warnings
  render_warnings model_warnings,
                  :model,
                  'model_warnings',
                  ['Confidence', 'Model', 'Warning Type', "CWE ID", 'Message'],
                  'Model'
end
     | 
  
 
    
      
  
  
    #generate_obsolete  ⇒ Object 
  
  
  
  
    
      
92
93
94
95 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 92
def generate_obsolete
  values = tracker.unused_fingerprints.collect{|fingerprint| [fingerprint] }
  render_array('obsolete_ignore_entries', ['fingerprint'], values, {:tracker => tracker})
end
     | 
  
 
    
      
  
  
    #generate_overview  ⇒ Object 
  
  
  
  
    
      
52
53
54
55
56
57
58
59
60
61
62
63 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 52
def generate_overview
  num_warnings = all_warnings.length
  @table.new(:headings => ['Scanned/Reported', 'Total']) do |t|
    t.add_row ['Controllers', tracker.controllers.length]
    t.add_row ['Models', tracker.models.length - 1]
    t.add_row ['Templates', number_of_templates(@tracker)]
    t.add_row ['Errors', tracker.errors.length]
    t.add_row ['Security Warnings', "#{num_warnings} (#{warnings_summary[:high_confidence]})"]
    t.add_row ['Ignored Warnings', ignored_warnings.length] unless ignored_warnings.empty?
  end
end
     | 
  
 
    
      
  
  
    #generate_report  ⇒ Object 
  
  
  
  
    
      
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 9
def generate_report
  summary_option = tracker.options[:summary_only]
  out = +""
  unless summary_option == :no_summary
    out <<  <<
      "\n\n+SUMMARY+\n\n" <<
      truncate_table(generate_overview.to_s) << "\n\n" <<
      truncate_table(generate_warning_overview.to_s) << "\n"
  end
    if summary_option == :summary_only or summary_option == true
    return out
  end
  if tracker.options[:report_routes] or tracker.options[:debug]
    out << "\n+CONTROLLERS+\n" <<
    truncate_table(generate_controllers.to_s) << "\n"
  end
  if tracker.options[:debug]
    out << "\n+TEMPLATES+\n\n" <<
    truncate_table(generate_templates.to_s) << "\n"
  end
  output_table("+Obsolete Ignore Entries+", generate_obsolete, out)
  output_table("+Errors+", generate_errors, out)
  output_table("+SECURITY WARNINGS+", generate_warnings, out)
  output_table("Controller Warnings:", generate_controller_warnings, out)
  output_table("Model Warnings:", generate_model_warnings, out)
  output_table("View Warnings:", generate_template_warnings, out)
  out << "\n"
  out
end
     | 
  
 
    
      
  
  
    #generate_template_warnings  ⇒ Object 
  
  
  
  
    
Generate table of template warnings or return nil if no warnings
   
 
  
  
    
      
106
107
108
109
110
111
112
113 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 106
def generate_template_warnings
  render_warnings template_warnings,
                  :template,
                  'view_warnings',
                  ['Confidence', 'Template', 'Warning Type', "CWE ID", 'Message'],
                  'Template'
end
     | 
  
 
    
      
  
  
    #generate_templates  ⇒ Object 
  
  
  
  
    
Generate listings of templates and their output
   
 
  
  
    
      
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 156
def generate_templates
  out_processor = Brakeman::OutputProcessor.new
  template_rows = {}
  tracker.templates.each do |name, template|
    template.each_output do |out|
      out = out_processor.format out
      template_rows[name] ||= []
      template_rows[name] << out.gsub("\n", ";").gsub(/\s+/, " ")
    end
  end
  template_rows = template_rows.sort_by{|name, value| name.to_s}
  output = +''
  template_rows.each do |template|
    output << template.first.to_s << "\n\n"
    table = @table.new(:headings => ['Output']) do |t|
            template[1].each do |v|
        t.add_row [v]
      end
    end
    output << table.to_s << "\n\n"
  end
  output
end
     | 
  
 
    
      
  
  
    #generate_warning_overview  ⇒ Object 
  
  
  
  
    
Generate table of how many warnings of each warning type were reported
   
 
  
  
    
      
66
67
68
69
70
71
72
73 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 66
def generate_warning_overview
  types = warnings_summary.keys
  types.delete :high_confidence
  values = types.sort.collect{|warning_type| [warning_type, warnings_summary[warning_type]] }
  locals = {:types => types, :warnings_summary => warnings_summary}
  render_array('warning_overview', ['Warning Type', 'Total'], values, locals)
end
     | 
  
 
    
      
  
  
    #generate_warnings  ⇒ Object 
  
  
  
  
    
      
97
98
99
100
101
102
103 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 97
def generate_warnings
  render_warnings generic_warnings,
                  :warning,
                  'security_warnings',
                  ["Confidence", "Class", "Method", "Warning Type", "CWE ID", "Message"],
                  'Class'
end
     | 
  
 
    
      
  
  
    #output_table(title, result, output)  ⇒ Object 
  
  
  
  
    
      
46
47
48
49
50 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 46
def output_table title, result, output
  return unless result
  output << "\n\n#{title}\n\n#{truncate_table(result.to_s)}"
end
     | 
  
 
    
      
  
  
    #render_array(template, headings, value_array, locals)  ⇒ Object 
  
  
  
  
    
      
219
220
221
222
223
224
225 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 219
def render_array template, headings, value_array, locals
  return if value_array.empty?
  @table.new(:headings => headings) do |t|
    value_array.each { |value_row| t.add_row value_row }
  end
end
     | 
  
 
    
      
  
  
    #render_warnings(warnings, type, template, cols, sort_col)  ⇒ Object 
  
  
  
  
    
      
141
142
143
144
145
146
147
148
149
150
151
152
153 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 141
def render_warnings warnings, type, template, cols, sort_col
  unless warnings.empty?
    rows = sort(convert_to_rows(warnings, type), sort_col)
    values = rows.collect { |row| row.values_at(*cols) }
    locals = { :warnings => rows }
    render_array(template, cols, values, locals)
  else
    nil
  end
end
     | 
  
 
    
      
  
  
    #sort(rows, sort_col)  ⇒ Object 
  
  
  
  
    
      
210
211
212
213
214
215
216
217 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 210
def sort rows, sort_col
  stabilizer = 0
  rows.sort_by do |row|
    stabilizer += 1
    row.values_at("Confidence", "Warning Type", sort_col) << stabilizer
  end
end
     | 
  
 
    
      
  
  
    
Generate header for text output
   
 
  
  
    
      
257
258
259
260
261
262
263
264
265
266
267
268
269 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 257
def 
  <<-HEADER
+BRAKEMAN REPORT+
Application path: #{tracker.app_path}
Rails version: #{rails_version}
Brakeman version: #{Brakeman::Version}
Started at #{tracker.start_time}
Duration: #{tracker.duration} seconds
Checks run: #{checks.checks_run.sort.join(", ")}
HEADER
end
     | 
  
 
    
      
  
  
    #text_message(warning, message)  ⇒ Object 
  
  
  
  
    
Escape warning message and highlight user input in text output
   
 
  
  
    
      
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 234
def text_message warning, message
  message = message.to_s
  if warning.line
    message << " near line #{warning.line}"
  end
  if warning.code
    if @highlight_user_input and warning.user_input
      code = warning.format_with_user_input do |user_input, user_input_string|
        "+#{user_input_string}+"
      end
    else
      code = warning.format_code
    end
    message << ": #{code}"
  end
  message
end
     | 
  
 
    
      
  
  
    #truncate_table(str)  ⇒ Object 
  
  
  
  
    
      
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289 
     | 
    
      # File 'lib/brakeman/report/report_table.rb', line 271
def truncate_table str
  @terminal_width ||= if @tracker.options[:table_width]
                        @tracker.options[:table_width]
                      elsif $stdin && $stdin.tty?
                        Brakeman.load_brakeman_dependency 'highline'
                        ::HighLine.default_instance.terminal.terminal_size[0]
                      else
                        80
                      end
  lines = str.lines
  lines.map do |line|
    if line.chomp.length > @terminal_width
      line[0..(@terminal_width - 3)] + ">>\n"
    else
      line
    end
  end.join
end
     |