39 lines
932 B
Ruby
Raw Normal View History

2020-10-10 14:16:11 +02:00
# typed: true
# frozen_string_literal: true
require "rubocops/extend/formula"
module RuboCop
module Cop
module FormulaAudit
2020-08-26 02:21:58 +02:00
# This cop makes sure that caveats don't recommend unsupported or unsafe operations.
#
# @example
# # bad
# def caveats
# <<~EOS
# Use `setuid` to allow running the exeutable by non-root users.
# EOS
# end
#
# # good
# def caveats
# <<~EOS
# Use `sudo` to run the executable.
# EOS
# end
#
# @api private
class Caveats < FormulaCop
def audit_formula(_node, _class_node, _parent_class_node, _body_node)
caveats_strings.each do |n|
next unless regex_match_group(n, /\bsetuid\b/i)
2018-09-17 02:45:00 +02:00
problem "Don't recommend setuid in the caveats, suggest sudo instead."
end
end
end
end
end
end