Skip to content

class Athena::Validator::Constraints::Positive
inherits Athena::Validator::Constraints::GreaterThan #

Validates that a value is a positive number. Use AVD::Constraints::PositiveOrZero if you wish to also allow 0.

class Account
  include AVD::Validatable

  def initialize(@balance : Number); end

  @[Assert::Positive]
  property balance : Number
end

Configuration#

Optional Arguments#

message#

Type: String Default: This value should be positive.

The message that will be shown if the value is not greater than 0.

Placeholders#

The following placeholders can be used in this message:

  • {{ value }} - The current (invalid) value.
  • {{ compared_value }} - The expected value.
  • {{ compared_value_type }} - The type of the expected value.

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.

Constructors#

.new(message : String = "This value should be positive.", groups : Array(String) | String | Nil = nil, payload : Hash(String, String) | Nil = nil)#

Methods#

#validated_by : AVD::ConstraintValidator.class#

:inherit: