a-j-n/egyptian-national-id-laravel

Egyptian National ID validation, parsing, and generation package for PHP and Laravel.

Maintainers

Package info

github.com/a-j-n/EG-ID

pkg:composer/a-j-n/egyptian-national-id-laravel

Statistics

Installs: 2

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

v1.0.1 2026-03-03 17:50 UTC

This package is auto-updated.

Last update: 2026-03-03 17:53:06 UTC


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): string
  • validate(string|int|null $id): bool
  • parse(string|int|null $id): array
  • extractBirthDate(string|int|null $id): DateTimeImmutable
  • extractGender(string|int|null $id): string
  • extractGovernorate(string|int|null $id): ?array
  • calculateAge(DateTimeInterface $birthDate, ?DateTimeInterface $at = null): int
  • generate(array $options = []): string

Generate Options

  • birth_year (int)
  • birth_month (int)
  • birth_day (int)
  • governorate_code (int)
  • gender (Male or Female)

License

MIT