diff options
author | James Hill <jamie@jamie-laptop.local> | 2009-08-05 11:44:44 -0500 |
---|---|---|
committer | Joshua Peek <josh@joshpeek.com> | 2009-08-05 11:45:01 -0500 |
commit | cfd421daa2b04216e27d666361eb4053020e027d (patch) | |
tree | 878e4980a47433990e96c2edb8b28ee5b1ae22f1 /activemodel/lib/active_model/validations.rb | |
parent | 64268a0b06d32567c6e88b7293f332b79e10414b (diff) | |
download | rails-cfd421daa2b04216e27d666361eb4053020e027d.tar.gz rails-cfd421daa2b04216e27d666361eb4053020e027d.tar.bz2 rails-cfd421daa2b04216e27d666361eb4053020e027d.zip |
Allow validations to use values from custom readers [#2936 state:resolved]
Signed-off-by: Joshua Peek <josh@joshpeek.com>
Diffstat (limited to 'activemodel/lib/active_model/validations.rb')
-rw-r--r-- | activemodel/lib/active_model/validations.rb | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/activemodel/lib/active_model/validations.rb b/activemodel/lib/active_model/validations.rb index 54a869396d..0fca96e5cc 100644 --- a/activemodel/lib/active_model/validations.rb +++ b/activemodel/lib/active_model/validations.rb @@ -66,7 +66,7 @@ module ActiveModel # Declare the validation. send(validation_method(options[:on]), options) do |record| attrs.each do |attr| - value = record.send(attr) + value = record.instance_eval { read_attribute_for_validation(attr) } next if (value.nil? && options[:allow_nil]) || (value.blank? && options[:allow_blank]) yield record, attr, value end @@ -95,6 +95,28 @@ module ActiveModel def invalid? !valid? end + + protected + # Hook method defining how an attribute value should be retieved. By default this is assumed + # to be an instance named after the attribute. Override this method in subclasses should you + # need to retrieve the value for a given attribute differently e.g. + # class MyClass + # include ActiveModel::Validations + # + # def initialize(data = {}) + # @data = data + # end + # + # private + # + # def read_attribute_for_validation(key) + # @data[key] + # end + # end + # + def read_attribute_for_validation(key) + send(key) + end end end |