mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Merge pull request #5643 from rafaelfranca/remove-duplication
Remove code duplication in InclusionValidator and ExclusionValidator.
This commit is contained in:
commit
ddaeb4b6cf
3 changed files with 39 additions and 44 deletions
31
activemodel/lib/active_model/validations/clusivity.rb
Normal file
31
activemodel/lib/active_model/validations/clusivity.rb
Normal file
|
@ -0,0 +1,31 @@
|
|||
require 'active_support/core_ext/range.rb'
|
||||
|
||||
module ActiveModel
|
||||
module Validations
|
||||
module Clusivity
|
||||
ERROR_MESSAGE = "An object with the method #include? or a proc or lambda is required, " <<
|
||||
"and must be supplied as the :in option of the configuration hash"
|
||||
|
||||
def check_validity!
|
||||
unless [:include?, :call].any?{ |method| options[:in].respond_to?(method) }
|
||||
raise ArgumentError, ERROR_MESSAGE
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def include?(record, value)
|
||||
delimiter = options[:in]
|
||||
exclusions = delimiter.respond_to?(:call) ? delimiter.call(record) : delimiter
|
||||
exclusions.send(inclusion_method(exclusions), value)
|
||||
end
|
||||
|
||||
# In Ruby 1.9 <tt>Range#include?</tt> on non-numeric ranges checks all possible values in the
|
||||
# range for equality, so it may be slow for large ranges. The new <tt>Range#cover?</tt>
|
||||
# uses the previous logic of comparing a value with the range endpoints.
|
||||
def inclusion_method(enumerable)
|
||||
enumerable.is_a?(Range) ? :cover? : :include?
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
|
@ -1,35 +1,17 @@
|
|||
require 'active_support/core_ext/range'
|
||||
require "active_model/validations/clusivity"
|
||||
|
||||
module ActiveModel
|
||||
|
||||
# == Active Model Exclusion Validator
|
||||
module Validations
|
||||
class ExclusionValidator < EachValidator
|
||||
ERROR_MESSAGE = "An object with the method #include? or a proc or lambda is required, " <<
|
||||
"and must be supplied as the :in option of the configuration hash"
|
||||
|
||||
def check_validity!
|
||||
unless [:include?, :call].any? { |method| options[:in].respond_to?(method) }
|
||||
raise ArgumentError, ERROR_MESSAGE
|
||||
end
|
||||
end
|
||||
include Clusivity
|
||||
|
||||
def validate_each(record, attribute, value)
|
||||
delimiter = options[:in]
|
||||
exclusions = delimiter.respond_to?(:call) ? delimiter.call(record) : delimiter
|
||||
if exclusions.send(inclusion_method(exclusions), value)
|
||||
if include?(record, value)
|
||||
record.errors.add(attribute, :exclusion, options.except(:in).merge!(:value => value))
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
# In Ruby 1.9 <tt>Range#include?</tt> on non-numeric ranges checks all possible values in the
|
||||
# range for equality, so it may be slow for large ranges. The new <tt>Range#cover?</tt>
|
||||
# uses the previous logic of comparing a value with the range endpoints.
|
||||
def inclusion_method(enumerable)
|
||||
enumerable.is_a?(Range) ? :cover? : :include?
|
||||
end
|
||||
end
|
||||
|
||||
module HelperMethods
|
||||
|
@ -59,7 +41,7 @@ module ActiveModel
|
|||
# * <tt>:unless</tt> - Specifies a method, proc or string to call to determine if the validation should
|
||||
# not occur (e.g. <tt>:unless => :skip_validation</tt>, or <tt>:unless => Proc.new { |user| user.signup_step <= 2 }</tt>). The
|
||||
# method, proc or string should return or evaluate to a true or false value.
|
||||
# * <tt>:strict</tt> - Specifies whether validation should be strict.
|
||||
# * <tt>:strict</tt> - Specifies whether validation should be strict.
|
||||
# See <tt>ActiveModel::Validation#validates!</tt> for more information
|
||||
def validates_exclusion_of(*attr_names)
|
||||
validates_with ExclusionValidator, _merge_attributes(attr_names)
|
||||
|
|
|
@ -1,35 +1,17 @@
|
|||
require 'active_support/core_ext/range'
|
||||
require "active_model/validations/clusivity"
|
||||
|
||||
module ActiveModel
|
||||
|
||||
# == Active Model Inclusion Validator
|
||||
module Validations
|
||||
class InclusionValidator < EachValidator
|
||||
ERROR_MESSAGE = "An object with the method #include? or a proc or lambda is required, " <<
|
||||
"and must be supplied as the :in option of the configuration hash"
|
||||
|
||||
def check_validity!
|
||||
unless [:include?, :call].any?{ |method| options[:in].respond_to?(method) }
|
||||
raise ArgumentError, ERROR_MESSAGE
|
||||
end
|
||||
end
|
||||
include Clusivity
|
||||
|
||||
def validate_each(record, attribute, value)
|
||||
delimiter = options[:in]
|
||||
exclusions = delimiter.respond_to?(:call) ? delimiter.call(record) : delimiter
|
||||
unless exclusions.send(inclusion_method(exclusions), value)
|
||||
unless include?(record, value)
|
||||
record.errors.add(attribute, :inclusion, options.except(:in).merge!(:value => value))
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
# In Ruby 1.9 <tt>Range#include?</tt> on non-numeric ranges checks all possible values in the
|
||||
# range for equality, so it may be slow for large ranges. The new <tt>Range#cover?</tt>
|
||||
# uses the previous logic of comparing a value with the range endpoints.
|
||||
def inclusion_method(enumerable)
|
||||
enumerable.is_a?(Range) ? :cover? : :include?
|
||||
end
|
||||
end
|
||||
|
||||
module HelperMethods
|
||||
|
@ -59,7 +41,7 @@ module ActiveModel
|
|||
# * <tt>:unless</tt> - Specifies a method, proc or string to call to determine if the validation should
|
||||
# not occur (e.g. <tt>:unless => :skip_validation</tt>, or <tt>:unless => Proc.new { |user| user.signup_step <= 2 }</tt>). The
|
||||
# method, proc or string should return or evaluate to a true or false value.
|
||||
# * <tt>:strict</tt> - Specifies whether validation should be strict.
|
||||
# * <tt>:strict</tt> - Specifies whether validation should be strict.
|
||||
# See <tt>ActiveModel::Validation#validates!</tt> for more information
|
||||
def validates_inclusion_of(*attr_names)
|
||||
validates_with InclusionValidator, _merge_attributes(attr_names)
|
||||
|
|
Loading…
Reference in a new issue