respect-validation/library/Rules/Cnh.php
2015-06-08 12:09:25 -03:00

42 lines
1 KiB
PHP

<?php
/*
* This file is part of Respect/Validation.
*
* (c) Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
*
* For the full copyright and license information, please view the "LICENSE.md"
* file that was distributed with this source code.
*/
namespace Respect\Validation\Rules;
class Cnh extends AbstractRule
{
public function validate($input)
{
$ret = false;
if ((strlen($input = preg_replace('/[^\d]/', '', $input)) == 11)
&& (str_repeat($input[1], 11) != $input)) {
$dsc = 0;
for ($i = 0, $j = 9, $v = 0; $i < 9; ++$i, --$j) {
$v += (int) $input[$i] * $j;
}
if (($vl1 = $v % 11) >= 10) {
$vl1 = 0;
$dsc = 2;
}
for ($i = 0, $j = 1, $v = 0; $i < 9; ++$i, ++$j) {
$v += (int) $input[$i] * $j;
}
$vl2 = ($x = ($v % 11)) >= 10 ? 0 : $x - $dsc;
$ret = sprintf('%d%d', $vl1, $vl2) == substr($input, -2);
}
return $ret;
}
}