Project

nifval

0.01
No commit activity in last 3 years
No release in over 3 years
Validates a Spanish NIF/CIF/NIE by verifying that the digit control corresponds to the number.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 0
~> 2.5

Runtime

 Project Readme

NifVal

Description

NifVal is a simple gem which adds a Spanish NIF/NIE/CIF validator to ActiveModel. You simply have to validate ":nif" for "true" for a specific field.

Installation

Simply add this gem to your Gemfile:

gem "nifval"

and execute bundle.

Note: It appears that if we load NifVal after Devise, Nifval won't work. In order to make everything work, simply add Nifval before Devise in the Gemfile.

Then run the generator in order to install the I18n template:

rails generate nifval:install

If you want to validate a Nif via Javascript, you can also add:

rails generate nifval:javascript

And you are done!

Usage

On your model

Let's see an example:

class Person
  validates :nif, :nif => true
  attr_accessor :nif
end

Then if we create an instance and see if it is valid, the validation will be checked.

Let's see one example for each case. A successful validation (correct control digit T for 00000000):

p = Person.new("00000000T")
p.valid? # will return true

And an unsuccessful one (mistaken control digit C for A2345678):

p = Person.new("A2345678C")
p.valid? # will return false

### Via Javascript ###

Please refer to the Installation section on how to get Nifval's Javascript file.

You only have to add nifval.js to your application layout. Assuming the use of HAML:

= javascript_include_tag "nifval"

And then execute the nifval(nifToCheck) function, which returns a boolean.

nifval("00000000T") // returns true
nifval("A2345678C") // returns false

Example

You can see both situations via the test application included in this gem. This test app is also available at http://nifvalapp.heroku.com.

Changelog

  • v0.1.0 First version, basic Spanish NIF validation.
  • v0.1.1 Some fixes on regexps taht would allow invalid NIFs.
  • v0.1.2 Compatible with Ruby 1.8.7 and 1.9.2.
  • v0.1.3 Adding I18n support for error messages.
  • v0.1.4 Several fixes.
  • v0.2.0 Added test app, and providing a Javascript version too.
  • v0.2.1 Accepting strings with smaller than 9 chars.
  • v0.2.2 Core refactor, thanks to @ritxi.

Contributors

Thanks to @ritxi for the refactoring in v0.2.2.

Documentation

Adapted from here.

You can also find more information on Wikipedia.