This repository has been archived by the owner. It is now read-only.

kemalyst-validators v0.1.0

Mix-in that provides validation methods to model objects

Kemalyst Validators

Kemalyst Validators provides a standard way of creating validation for models. The library is built for Kemalyst but can be leveraged by any plain old object.

Installation

Add this to your application's shard.yml:

dependencies:
  kemalyst-validators:
    github: drujensen/kemalyst-validators

Usage

Kemalyst::Validators is a mix-in that you include in your class:

require "kemalyst-validators"

class Person
  include Kemalyst::Validators
  property name : String?
  
  validate :name, "is required", -> (this : Person) { this.name != nil }
  
  validate :name, "must be 3 characters long", -> (this : Person) do 
    if name = this.name
      return name.size > 2
    end
    return true
  end
  
  def initialize(@name = nil)
  end
end

The validate macro takes three parameters. The symbol of the field and the message that will display when the validation fails. The third is a Proc that is provided an instance of self and returns either true or false.

To check to see if your instance is valid, call valid?. Each Proc will be called and if any of them fails, an errors Array with the messages is returned.

If no Symbol is provided as a first parameter, the errors will be added to the :base field.

person = Person.new(name: "JD")
person.valid?.should eq false
person.errors[0].to_s.should eq "Name must be 3 characters long"

Development

RoadMap:

  • [] Provide standard validators that can be used per field

Contributing

  1. Fork it ( https://github.com/drujensen/kemalyst-validators/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors

Repository

kemalyst-validators

Owner
Statistic
  • 2
  • 0
  • 1
  • 1
  • 0
  • almost 8 years ago
  • June 26, 2016
License

MIT License

Links
Synced at

Tue, 21 Jan 2025 12:49:36 GMT

Languages