Sha256: 831c17f0cd499285624aa812d6b2be384420e12f7da4f30befe6bb97103ee314
Contents?: true
Size: 1.63 KB
Versions: 4
Compression:
Stored size: 1.63 KB
Contents
require 'brakeman/checks/base_check' #Reports any calls to +validates_format_of+ which do not use +\A+ and +\z+ #as anchors in the given regular expression. # #For example: # # #Allows anything after new line # validates_format_of :user_name, :with => /^\w+$/ class Brakeman::CheckValidationRegex < Brakeman::BaseCheck Brakeman::Checks.add self @description = "Report uses of validates_format_of with improper anchors" WITH = Sexp.new(:lit, :with) def run_check tracker.models.each do |name, model| @current_model = name format_validations = model[:options][:validates_format_of] if format_validations format_validations.each do |v| process_validator v end end end end #Check validates_format_of def process_validator validator if value = hash_access(validator[-1], WITH) check_regex value, validator end end #Issue warning if the regular expression does not use #+\A+ and +\z+ def check_regex value, validator return unless regexp? value regex = value[1].inspect if regex =~ /^\/(.{2}).*(.{2})\/(m|i|x|n|e|u|s|o)*\z/ if $1 != "\\A" or ($2 != "\\Z" and $2 != "\\z") warn :model => @current_model, :warning_type => "Format Validation", :message => "Insufficient validation for '#{get_name validator}' using #{value[1].inspect}. Use \\A and \\z as anchors", :line => value.line, :confidence => CONFIDENCE[:high] end end end #Get the name of the attribute being validated. def get_name validator name = validator[1] if sexp? name name[1] else name end end end
Version data entries
4 entries across 4 versions & 1 rubygems