Module: ActiveModel::Validations::HelperMethods
- Defined in:
- lib/common_lib/active_model/validations/absence.rb,
lib/common_lib/active_model/validations/past_date.rb,
lib/common_lib/active_model/validations/complete_date.rb
Instance Method Summary collapse
-
#validates_absence_of(*attr_names) ⇒ Object
Validates that the specified attributes are blank (as defined by Object#blank?).
-
#validates_complete_date_for(*attr_names) ⇒ Object
Validates that the specified attributes contain a complete date.
-
#validates_past_date_for(*attr_names) ⇒ Object
Validates that the specified attributes contain a date in the past.
Instance Method Details
#validates_absence_of(*attr_names) ⇒ Object
Validates that the specified attributes are blank (as defined by Object#blank?). Happens by default on save. Example:
class Person < ActiveRecord::Base
validates_absence_of :first_name
end
The first_name attribute must be in the object and it cannot be blank.
If you want to validate the absence of a boolean field (where the real values are true and false), you will want to use validates_inclusion_of :field_name, :in => [true, false]
.
This is due to the way Object#blank? handles boolean values: false.blank? # => true
.
Configuration options:
-
:message
- A custom error message (default is: “can’t be blank”). -
:on
- Specifies when this validation is active. Runs in all
validation contexts by default (+nil+), other options are <tt>:create</tt>
and <tt>:update</tt>.
-
:if
- 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.
-
:unless
- 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.
-
:strict
- Specifies whether validation should be strict.
See <tt>ActiveModel::Validation#validates!</tt> for more information
73 74 75 |
# File 'lib/common_lib/active_model/validations/absence.rb', line 73 def validates_absence_of(*attr_names) validates_with AbsenceValidator, _merge_attributes(attr_names) end |
#validates_complete_date_for(*attr_names) ⇒ Object
Validates that the specified attributes contain a complete date. Happens by default on save. Example:
class Person < ActiveRecord::Base
validates_complete_date_for :dob
end
The first_name attribute must be in the object and it cannot be blank.
If you want to validate the absence of a boolean field (where the real values are true and false), you will want to use validates_inclusion_of :field_name, :in => [true, false]
.
This is due to the way Object#blank? handles boolean values: false.blank? # => true
.
Configuration options:
-
:message
- A custom error message (default is: “can’t be blank”). -
:on
- Specifies when this validation is active. Runs in all
validation contexts by default (+nil+), other options are <tt>:create</tt>
and <tt>:update</tt>.
-
:if
- 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.
-
:unless
- 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.
-
:strict
- Specifies whether validation should be strict.
See <tt>ActiveModel::Validation#validates!</tt> for more information
133 134 135 |
# File 'lib/common_lib/active_model/validations/complete_date.rb', line 133 def validates_complete_date_for(*attr_names) validates_with CompleteDateValidator, _merge_attributes(attr_names) end |
#validates_past_date_for(*attr_names) ⇒ Object
Validates that the specified attributes contain a date in the past. Happens by default on save. Example:
class Person < ActiveRecord::Base
validates_past_date_for :dob
end
The first_name attribute must be in the object and it cannot be blank.
If you want to validate the absence of a boolean field (where the real values are true and false), you will want to use validates_inclusion_of :field_name, :in => [true, false]
.
This is due to the way Object#blank? handles boolean values: false.blank? # => true
.
Configuration options:
-
:message
- A custom error message (default is: “can’t be blank”). -
:on
- Specifies when this validation is active. Runs in all
validation contexts by default (+nil+), other options are <tt>:create</tt>
and <tt>:update</tt>.
-
:if
- 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.
-
:unless
- 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.
-
:strict
- Specifies whether validation should be strict.
See <tt>ActiveModel::Validation#validates!</tt> for more information
116 117 118 |
# File 'lib/common_lib/active_model/validations/past_date.rb', line 116 def validates_past_date_for(*attr_names) validates_with PastDateValidator, _merge_attributes(attr_names) end |