mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
8f97e9d19a
Signed-off-by: José Valim <jose.valim@gmail.com>
79 lines
No EOL
2.7 KiB
Ruby
79 lines
No EOL
2.7 KiB
Ruby
module ActiveModel
|
|
module Validations
|
|
module ClassMethods
|
|
|
|
# Passes the record off to the class or classes specified and allows them
|
|
# to add errors based on more complex conditions.
|
|
#
|
|
# class Person
|
|
# include ActiveModel::Validations
|
|
# validates_with MyValidator
|
|
# end
|
|
#
|
|
# class MyValidator < ActiveModel::Validator
|
|
# def validate(record)
|
|
# if some_complex_logic
|
|
# record.errors[:base] << "This record is invalid"
|
|
# end
|
|
# end
|
|
#
|
|
# private
|
|
# def some_complex_logic
|
|
# # ...
|
|
# end
|
|
# end
|
|
#
|
|
# You may also pass it multiple classes, like so:
|
|
#
|
|
# class Person
|
|
# include ActiveModel::Validations
|
|
# validates_with MyValidator, MyOtherValidator, :on => :create
|
|
# end
|
|
#
|
|
# Configuration options:
|
|
# * <tt>on</tt> - Specifies when this validation is active
|
|
# (<tt>:create</tt> or <tt>:update</tt>
|
|
# * <tt>if</tt> - Specifies a method, proc or string to call to determine
|
|
# if the validation should occur (e.g. <tt>:if => :allow_validation</tt>,
|
|
# or <tt>:if => Proc.new { |user| user.signup_step > 2 }</tt>).
|
|
# The method, proc or string should return or evaluate to a true or false value.
|
|
# * <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.
|
|
#
|
|
# If you pass any additional configuration options, they will be passed
|
|
# to the class and available as <tt>options</tt>:
|
|
#
|
|
# class Person
|
|
# include ActiveModel::Validations
|
|
# validates_with MyValidator, :my_custom_key => "my custom value"
|
|
# end
|
|
#
|
|
# class MyValidator < ActiveModel::Validator
|
|
# def validate(record)
|
|
# options[:my_custom_key] # => "my custom value"
|
|
# end
|
|
# end
|
|
#
|
|
def validates_with(*args, &block)
|
|
options = args.extract_options!
|
|
args.each do |klass|
|
|
validator = klass.new(options, &block)
|
|
validator.setup(self) if validator.respond_to?(:setup)
|
|
|
|
if validator.respond_to?(:attributes) && !validator.attributes.empty?
|
|
validator.attributes.each do |attribute|
|
|
_validators[attribute.to_sym] << validator
|
|
end
|
|
else
|
|
_validators[nil] << validator
|
|
end
|
|
|
|
validate(validator, options)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end |