lib/brakeman/report.rb
require 'brakeman/report/report_base'
#Generates a report based on the Tracker and the results of
#Tracker#run_checks. Be sure to +run_checks+ before generating
#a report.
class Brakeman::Report
attr_reader :tracker
VALID_FORMATS = [:to_html, :to_pdf, :to_csv, :to_json, :to_tabs, :to_hash, :to_s, :to_markdown, :to_codeclimate, :to_plain, :to_text, :to_junit, :to_github]
def initialize tracker
@app_tree = tracker.app_tree
@tracker = tracker
end
def format format
reporter = case format
when :to_codeclimate
require_report 'codeclimate'
Brakeman::Report::CodeClimate
when :to_csv
require_report 'csv'
Brakeman::Report::CSV
when :to_html
require_report 'html'
Brakeman::Report::HTML
when :to_json
return self.to_json
when :to_tabs
require_report 'tabs'
Brakeman::Report::Tabs
when :to_hash
require_report 'hash'
Brakeman::Report::Hash
when :to_markdown
return self.to_markdown
when :to_plain, :to_text, :to_s
return self.to_plain
when :to_table
return self.to_table
when :to_pdf
raise "PDF output is not yet supported."
when :to_junit
require_report 'junit'
Brakeman::Report::JUnit
when :to_sarif
return self.to_sarif
when :to_sonar
require_report 'sonar'
Brakeman::Report::Sonar
when :to_github
require_report 'github'
Brakeman::Report::Github
else
raise "Invalid format: #{format}. Should be one of #{VALID_FORMATS.inspect}"
end
generate(reporter)
end
def method_missing method, *args
if VALID_FORMATS.include? method
format method
else
super
end
end
def require_report type
require "brakeman/report/report_#{type}"
end
def to_json
require_report 'json'
generate Brakeman::Report::JSON
end
def to_sonar
require_report 'sonar'
generate Brakeman::Report::Sonar
end
def to_table
require_report 'table'
generate Brakeman::Report::Table
end
def to_markdown
require_report 'markdown'
generate Brakeman::Report::Markdown
end
def to_text
require_report 'text'
generate Brakeman::Report::Text
end
alias to_plain to_text
alias to_s to_text
def to_sarif
require_report 'sarif'
generate Brakeman::Report::SARIF
end
def generate reporter
reporter.new(@tracker).generate_report
end
end