428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
|
# File 'lib/active_record_safer_query/checker.rb', line 428
def self.run(argv = ARGV, out: $stdout, err: $stderr)
options = {
format: DEFAULT_FORMAT,
fail_level: DEFAULT_FAIL_LEVEL,
root: Dir.pwd,
whitelist_paths: []
}
parser = OptionParser.new do |opts|
opts.banner = 'Usage: activerecord-safer-query [options] [paths...]'
opts.separator ''
opts.separator 'Detect class-level ActiveRecord lookups that may bypass tenant/user scopes.'
opts.separator ''
opts.on('--root PATH', 'Target repository root. Default: current directory') { |value| options[:root] = value }
opts.on('--format FORMAT', 'text or json') { |value| options[:format] = value }
opts.on('--fail-level LEVEL', 'LOW, MEDIUM, or HIGH. Default: LOW') { |value| options[:fail_level] = value.upcase }
opts.on('--whitelist PATH', 'YAML whitelist file. Can be used multiple times') { |value| options[:whitelist_paths] << value }
opts.on('-h', '--help', 'Show this help') do
out.puts opts
return 0
end
end
paths = parser.parse(argv)
validate_options!(options)
findings = Checker.new(paths: paths, root: options[:root], whitelist_paths: options[:whitelist_paths]).findings
emit(findings, options, out)
findings.any? { |finding| finding.fail_at?(options[:fail_level]) } ? 1 : 0
rescue OptionParser::ParseError, ArgumentError => e
err.puts "[activerecord-safer-query] #{e.message}"
err.puts parser
2
end
|