class Attribool::ValidatorService
A simple interface to run validators, which should implement a valid? method which returns true if conditions are valid, and an error method which returns an exception class and message to be raised when validations fail.
Public Class Methods
Source
# File lib/attribool/validator_service.rb, line 16 def self.call(validator_name, *args) new(::Attribool::Validators.fetch(validator_name), *args).validate end
Run the validator.
@param [Symbol] validator_name
@param [Object] *args to be forwarded to validator
Source
# File lib/attribool/validator_service.rb, line 26 def initialize(validator, *args) @validator = validator.new(*args) end
Construct the service and inject the validator.
@param [Class] Validator
@param [Object] *args
Public Instance Methods
Source
# File lib/attribool/validator_service.rb, line 36 def validate @validator.valid? || raise(@validator.error) end
Raises the validator’s exception unless its conditions are met.
@return [Boolean]
@raise [Exception] if validation fails