Skip to content

class Athena::Validator::Constraints::Range
inherits Athena::Validator::Constraint #

Validates that a Number or Time value is between some minimum and maximum.

class House
  include AVD::Validatable

  def initialize(@area : Number); end

  @[Assert::Range(15..100)]
  property area : Number
end

Configuration#

Required Arguments#

range#

Type: ::Range

The ::Range that defines the minimum and maximum values, if any. An endless range can be used to only have a minimum or maximum.

Optional Arguments#

Note

This constraint does not support a message argument.

not_in_range_message#

Type: String Default: This value should be between {{ min }} and {{ max }}.

The message that will be shown if the value is less than the min or greater than the max.

Placeholders#

The following placeholders can be used in this message:

  • {{ value }} - The current (invalid) value.
  • {{ min }} - The lower limit.
  • {{ max }} - The upper limit.

min_message#

Type: String Default: This value should be {{ limit }} or more.

The message that will be shown if the value is less than the min, and no max has been provided.

Placeholders#

The following placeholders can be used in this message:

  • {{ value }} - The current (invalid) value.
  • {{ limit }} - The lower limit.

max_message#

Type: String Default: This value should be {{ limit }} or less.

The message that will be shown if the value is more than the max, and no min has been provided.

Placeholders#

The following placeholders can be used in this message:

  • {{ value }} - The current (invalid) value.
  • {{ limit }} - The upper limit.

groups#

Type: Array(String) | String | Nil Default: nil

The validation groups this constraint belongs to. AVD::Constraint::DEFAULT_GROUP is assumed if nil.

payload#

Type: Hash(String, String)? Default: nil

Any arbitrary domain-specific data that should be stored with this constraint. The payload is not used by Athena::Validator, but its processing is completely up to you.

Constants#

NOT_IN_RANGE_ERROR = "7e62386d-30ae-4e7c-918f-1b7e571c6d69"#

TOO_HIGH_ERROR = "5d9aed01-ac49-4d8e-9c16-e4aab74ea774"#

TOO_LOW_ERROR = "f0316644-882e-4779-a404-ee7ac97ddecc"#

Constructors#

.new(range : ::Range, not_in_range_message : String = "This value should be between {{ min }} and {{ max }}.", min_message : String = "This value should be {{ limit }} or more.", max_message : String = "This value should be {{ limit }} or less.", groups : Array(String) | String | Nil = nil, payload : Hash(String, String) | Nil = nil)#

Methods#

#max : Number::Primitive | Time | Nil#

#max_message : String#

#min : Number::Primitive | Time | Nil#

#min_message : String#

#not_in_range_message : String#

#validated_by : AVD::ConstraintValidator.class#

Returns the AVD::ConstraintValidator.class that should handle validating self.