a-j-n / egyptian-national-id-laravel
Egyptian National ID validation, parsing, and generation package for PHP and Laravel.
v1.0.1
2026-03-03 17:50 UTC
Requires
- php: ^8.2
- illuminate/support: ^10.0|^11.0|^12.0
- illuminate/validation: ^10.0|^11.0|^12.0
Requires (Dev)
- phpunit/phpunit: ^10.5|^11.0|^12.0
README
PHP and Laravel package for Egyptian National ID:
- validation
- parsing
- generation
- sanitization (including Arabic numerals)
Credits
This package is a PHP/Laravel adaptation of the original project by Mahmoud Ebeid (mahmoudEbeid2):
https://github.com/mahmoudEbeid2/egyptian-national-id
Installation
composer require a-j-n/egyptian-national-id-laravel
Laravel package discovery is enabled automatically.
Laravel Setup
For Laravel 10/11/12, no manual setup is needed after install.
The package uses Laravel auto-discovery via composer.json (extra.laravel.providers and extra.laravel.aliases).
To verify discovery in Laravel 12:
php artisan package:discover
Then test quickly in Tinker:
php artisan tinker
app(EgyptianNationalId\NationalIdService::class)->validate('30001010123456');
If you need manual registration, add:
// config/app.php 'providers' => [ EgyptianNationalId\EgyptianNationalIdServiceProvider::class, ], 'aliases' => [ 'NationalId' => EgyptianNationalId\Facades\NationalId::class, ],
Quick Usage
use EgyptianNationalId\NationalIdService; $service = app(NationalIdService::class); $isValid = $service->validate('30001010123456'); $id = $service->generate(['gender' => 'Male']); $parsed = $service->parse($id);
Facade Usage
use EgyptianNationalId\Facades\NationalId; $isValid = NationalId::validate('30001010123456'); $parsed = NationalId::parse('30001010123456');
Validation Rule (String)
$request->validate([ 'national_id' => ['required', 'national_id'], ]);
Validation Rule (Class)
use EgyptianNationalId\Rules\NationalIdRule; $request->validate([ 'national_id' => ['required', new NationalIdRule()], ]);
Parse Result Shape
[ 'national_id' => '...', 'birth_date' => DateTimeImmutable, 'birth_year' => 1998, 'birth_month' => 7, 'birth_day' => 21, 'age' => 27, 'gender' => 'Male'|'Female', 'governorate' => ['code' => 1, 'name_en' => 'Cairo', 'name_ar' => 'Al Qahirah', 'region' => 'Cairo'], 'region' => 'Cairo', 'inside_egypt' => true, 'is_adult' => true ]
API
sanitize(string|int|null $id): stringvalidate(string|int|null $id): boolparse(string|int|null $id): arrayextractBirthDate(string|int|null $id): DateTimeImmutableextractGender(string|int|null $id): stringextractGovernorate(string|int|null $id): ?arraycalculateAge(DateTimeInterface $birthDate, ?DateTimeInterface $at = null): intgenerate(array $options = []): string
Generate Options
birth_year(int)birth_month(int)birth_day(int)governorate_code(int)gender(MaleorFemale)
License
MIT