PHPackages                             esponsor/dni-validator - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Validation &amp; Sanitization](/categories/validation)
4. /
5. esponsor/dni-validator

ActiveLibrary[Validation &amp; Sanitization](/categories/validation)

esponsor/dni-validator
======================

Validators for Latin American and related national ID documents with Laravel validation rules

v0.0.1(3w ago)02↓100%MITPHPPHP ^8.2

Since May 18Pushed 3w agoCompare

[ Source](https://github.com/esponsor/dni-validator)[ Packagist](https://packagist.org/packages/esponsor/dni-validator)[ RSS](/packages/esponsor-dni-validator/feed)WikiDiscussions main Synced 1w ago

READMEChangelogDependencies (2)Versions (2)Used By (0)

dni-validator
=============

[](#dni-validator)

Validators for Latin American and related national ID documents. Available as both a **PHP/Laravel** package and a **JavaScript/TypeScript** package.

Supported documents
-------------------

[](#supported-documents)

CountryTypeDescription🇨🇱 ChileRUTRol Único Tributario — modulo-11 check digit🇲🇽 MexicoCURPClave Única de Registro de Población — regex + weighted checksumMore countries coming in future releases.

---

PHP
---

[](#php)

### Install

[](#install)

```
composer require esponsor/dni-validator
```

Requires PHP `^8.2` and `illuminate/contracts` `^10|^11|^12`.

### Direct usage

[](#direct-usage)

```
use Esponsor\DniValidator\RutChile;
use Esponsor\DniValidator\CurpMexico;

$rut = new RutChile();
$rut->validate('11.111.111-1'); // true
$rut->validate('11.111.111-2'); // false
$rut->clean('11.111.111-1');   // '111111111'
$rut->format('111111111');     // '11.111.111-1'

$curp = new CurpMexico();
$curp->validate('GICJ020605HDGRHNA2'); // true
$curp->format('gicj020605hdgrhna2');   // 'GICJ020605HDGRHNA2'
```

### Laravel validation rules

[](#laravel-validation-rules)

```
use Esponsor\DniValidator\Rules\RutChileRule;
use Esponsor\DniValidator\Rules\CurpMexicoRule;

$request->validate([
    'rut'  => ['required', 'string', new RutChileRule()],
    'curp' => ['required', 'string', new CurpMexicoRule()],
]);
```

Error messages are in Spanish:

- `El RUT ingresado no es válido.`
- `El CURP ingresado no es válido.`

### Registry

[](#registry)

```
use Esponsor\DniValidator\DocumentValidatorRegistry;

$validator = DocumentValidatorRegistry::for('CL', 'RUT');
$validator->validate('11.111.111-1'); // true

DocumentValidatorRegistry::validate('MX', 'CURP', 'GICJ020605HDGRHNA2'); // true
DocumentValidatorRegistry::for('CL', 'UNKNOWN'); // null
```

### Running PHP tests

[](#running-php-tests)

```
cd packages/php
composer install
./vendor/bin/pest
```

---

JavaScript / TypeScript
-----------------------

[](#javascript--typescript)

### Install

[](#install-1)

```
npm install @esponsor/dni-validator
```

Requires Node 20+.

### Named imports

[](#named-imports)

```
import { rutValidate, rutFormat, rutClean } from '@esponsor/dni-validator/chile';
import { curpValidate, curpFormat, curpClean } from '@esponsor/dni-validator/mexico';

rutValidate('11.111.111-1'); // true
rutFormat('111111111');      // '11.111.111-1'

curpValidate('GICJ020605HDGRHNA2'); // true
curpFormat('gicj020605hdgrhna2');   // 'GICJ020605HDGRHNA2'
```

### Registry

[](#registry-1)

```
import { getValidator } from '@esponsor/dni-validator';

const validator = getValidator('CL', 'RUT');
validator?.validate('11.111.111-1'); // true
validator?.format?.('111111111');    // '11.111.111-1'

getValidator('CL', 'UNKNOWN'); // null
```

### Running JS tests

[](#running-js-tests)

```
cd packages/js
npm install
npm test
```

---

License
-------

[](#license)

MIT — Copyright (c) 2026 eSponsor

###  Health Score

36

—

LowBetter than 79% of packages

Maintenance95

Actively maintained with recent releases

Popularity3

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity36

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Unknown

Total

1

Last Release

22d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/4a62f4ade8f59f5bbd95bb768463e6741e4d53332d229674363288033cedcc57?d=identicon)[vpuentem](/maintainers/vpuentem)

---

Top Contributors

[![vpuentem](https://avatars.githubusercontent.com/u/26012735?v=4)](https://github.com/vpuentem "vpuentem (6 commits)")

---

Tags

laravelvalidatorrutcpfDNIcurplatam

###  Code Quality

TestsPest

### Embed Badge

![Health badge](/badges/esponsor-dni-validator/health.svg)

```
[![Health](https://phpackages.com/badges/esponsor-dni-validator/health.svg)](https://phpackages.com/packages/esponsor-dni-validator)
```

###  Alternatives

[proengsoft/laravel-jsvalidation

Validate forms transparently with Javascript reusing your Laravel Validation Rules, Messages, and FormRequest

1.1k2.3M50](/packages/proengsoft-laravel-jsvalidation)[propaganistas/laravel-disposable-email

Disposable email validator

6012.9M7](/packages/propaganistas-laravel-disposable-email)[psalm/plugin-laravel

Psalm plugin for Laravel

3325.1M337](/packages/psalm-plugin-laravel)[laravel-validation-rules/phone

Validate that a phone number is in the correct format

69365.2k](/packages/laravel-validation-rules-phone)[danielebarbaro/laravel-vat-eu-validator

A simple package that validates EU VAT numbers against the central ec.europa.eu database

41401.6k](/packages/danielebarbaro-laravel-vat-eu-validator)[laravel-validation-rules/us-state

Validate US States and Canada Provinces

16177.7k](/packages/laravel-validation-rules-us-state)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
