Please do have a look at ActiveRecord::Validations::ClassMethods for a higher level of validations.
Active Records implement validation by overwriting Base#validate (or the variations, validate_on_create and validate_on_update). Each of these methods can inspect the state of the object, which usually means ensuring that a number of attributes have a certain value (such as not empty, within a given range, matching a certain regular expression).
Example:
class Person < ActiveRecord::Base
protected
def validate
errors.add_on_empty %w( first_name last_name )
errors.add("phone_number", "has invalid format") unless phone_number =~ /[0-9]*/
end
def validate_on_create # is only run the first time a new object is saved
unless valid_discount?(membership_discount)
errors.add("membership_discount", "has expired")
end
end
def validate_on_update
errors.add_to_base("No changes have occurred") if unchanged_attributes?
end
end
person = Person.new("first_name" => "David", "phone_number" => "what?")
person.save # => false (and doesn't do the save)
person.errors.empty? # => false
person.errors.count # => 2
person.errors.on "last_name" # => "can't be empty"
person.errors.on "phone_number" # => "has invalid format"
person.errors.each_full { |msg| puts msg }
# => "Last name can't be empty\n" +
# "Phone number has invalid format"
person.attributes = { "last_name" => "Heinemeier", "phone_number" => "555-555" }
person.save # => true (and person is now saved in the database)
An Errors object is automatically created for every Active Record.
- E
- I
- S
- V
| VALIDATIONS | = | %w( validate validate_on_create validate_on_update ) |
Returns the Errors object that holds all information about attribute error messages.
Performs the opposite of valid?. Returns true if errors were added, false otherwise.
The validation process on save can be skipped by passing false. The regular Base#save method is replaced with this when the validations module is mixed in, which it is by default.
Attempts to save the record just like Base#save but will raise a RecordInvalid exception instead of returning false if the record is not valid.
Runs validate and validate_on_create or validate_on_update and returns true if no errors were added otherwise false.
# File activerecord/lib/active_record/validations.rb, line 1107 1107: def valid? 1108: errors.clear 1109: 1110: run_callbacks(:validate) 1111: validate 1112: 1113: if new_record? 1114: run_callbacks(:validate_on_create) 1115: validate_on_create 1116: else 1117: run_callbacks(:validate_on_update) 1118: validate_on_update 1119: end 1120: 1121: errors.empty? 1122: end
Overwrite this method for validation checks on all saves and use Errors.add(field, msg) for invalid attributes.
Overwrite this method for validation checks used only on creation.