Sha256: 355cf2c428f34cc5307110267207b38d54249caf982cfefa6320d6ee377afa09

Contents?: true

Size: 1.34 KB

Versions: 24

Compression:

Stored size: 1.34 KB

Contents

Brakeman.load_brakeman_dependency 'multi_json'
require 'brakeman/report/initializers/multi_json'

class Brakeman::Report::JSON < Brakeman::Report::Base
  def generate_report
    errors = tracker.errors.map{|e| { :error => e[:error], :location => e[:backtrace][0] }}

    warnings = convert_to_hashes all_warnings

    ignored = convert_to_hashes ignored_warnings

    scan_info = {
      :app_path => tracker.app_path,
      :rails_version => rails_version,
      :security_warnings => all_warnings.length,
      :start_time => tracker.start_time.to_s,
      :end_time => tracker.end_time.to_s,
      :duration => tracker.duration,
      :checks_performed => checks.checks_run.sort,
      :number_of_controllers => tracker.controllers.length,
      # ignore the "fake" model
      :number_of_models => tracker.models.length - 1,
      :number_of_templates => number_of_templates(@tracker),
      :ruby_version => RUBY_VERSION,
      :brakeman_version => Brakeman::Version
    }

    report_info = {
      :scan_info => scan_info,
      :warnings => warnings,
      :ignored_warnings => ignored,
      :errors => errors
    }

    MultiJson.dump(report_info, :pretty => true)
  end

  def convert_to_hashes warnings
    warnings.map do |w|
      hash = w.to_hash
      hash[:file] = warning_file w
      hash
    end.sort_by { |w| "#{w[:fingerprint]}#{w[:line]}" }
  end
end

Version data entries

24 entries across 24 versions & 2 rubygems

Version Path
brakeman-3.1.5 lib/brakeman/report/report_json.rb
brakeman-min-3.1.5 lib/brakeman/report/report_json.rb
brakeman-3.1.4 lib/brakeman/report/report_json.rb
brakeman-min-3.1.4 lib/brakeman/report/report_json.rb
brakeman-3.1.3 lib/brakeman/report/report_json.rb
brakeman-min-3.1.3 lib/brakeman/report/report_json.rb
brakeman-3.1.2 lib/brakeman/report/report_json.rb
brakeman-min-3.1.2 lib/brakeman/report/report_json.rb
brakeman-3.1.1 lib/brakeman/report/report_json.rb
brakeman-min-3.1.1 lib/brakeman/report/report_json.rb
brakeman-3.1.0 lib/brakeman/report/report_json.rb
brakeman-min-3.1.0 lib/brakeman/report/report_json.rb
brakeman-3.0.5 lib/brakeman/report/report_json.rb
brakeman-min-3.0.5 lib/brakeman/report/report_json.rb
brakeman-3.0.4 lib/brakeman/report/report_json.rb
brakeman-min-3.0.4 lib/brakeman/report/report_json.rb
brakeman-min-3.0.3 lib/brakeman/report/report_json.rb
brakeman-3.0.3 lib/brakeman/report/report_json.rb
brakeman-min-3.0.2 lib/brakeman/report/report_json.rb
brakeman-3.0.2 lib/brakeman/report/report_json.rb