wali/smart-seeder

A PHP/Laravel package for generating fake localized data (Arabic names, Hijri dates, Saudi IBAN, etc.).

Installs: 11

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/wali/smart-seeder

1.0.0 2025-10-01 08:22 UTC

This package is auto-updated.

Last update: 2025-10-01 09:10:52 UTC


README

CI Software License PHP Version

SmartSeeder is a lightweight PHP package designed to generate realistic, localized fake data for your applications. Perfect for testing, database seeding, or generating sample datasets with Arabic/Saudi-specific data.

โœจ Features

  • ๐ŸŽญ Arabic Names: Generate random first names and full names (male/female)
  • ๐Ÿ“… Hijri Dates: Generate Islamic calendar dates
  • ๐Ÿฆ Saudi IBANs: Generate valid-looking Saudi Arabian bank account numbers
  • ๐Ÿ“ฑ Saudi Mobile Numbers: Generate realistic Saudi mobile phone numbers
  • ๐Ÿ†” Saudi National IDs: Generate valid-format Saudi national identification numbers
  • ๐Ÿ  Saudi Iqama Numbers: Generate valid-format Saudi resident ID numbers (starting with 2)
  • โšก Lightweight: Minimal dependencies, fast performance
  • ๐Ÿ”ง Easy Integration: Works seamlessly with PHP and Laravel projects

๐Ÿ“ฆ Installation

Install via Composer:

composer require wali/smart-seeder

๐Ÿš€ Quick Start

<?php

require_once 'vendor/autoload.php';

use Wali\SmartSeeder\SmartSeeder;

// Generate a random Arabic first name
echo SmartSeeder::name(); // e.g., "ุฃุญู…ุฏ"

// Generate a random Arabic full name
echo SmartSeeder::fullName(); // e.g., "ูุงุทู…ุฉ ุงู„ุฃู†ุตุงุฑูŠ"

// Generate a Hijri date
echo SmartSeeder::hijriDate(); // e.g., "1445/03/15"

// Generate a Saudi IBAN
echo SmartSeeder::iban(); // e.g., "SA0380000000608010167519"

// Generate a Saudi mobile number
echo SmartSeeder::phone(); // e.g., "+966501234567"

// Generate a Saudi National ID
echo SmartSeeder::nationalId(); // e.g., "1023456789"

// Generate a Saudi Iqama (resident ID)
echo SmartSeeder::iqama(); // e.g., "2087654321"

๐Ÿ“– Detailed Usage

Names

Generate Arabic names with optional gender specification:

// Random name (male or female)
$name = SmartSeeder::name();

// Specific gender
$maleName = SmartSeeder::name('male');     // ูˆู„ูŠุฏ, ุฃุญู…ุฏ, ุฎุงู„ุฏ, ู…ุญู…ุฏ
$femaleName = SmartSeeder::name('female'); // ูุงุทู…ุฉ, ู…ุฑูŠู…, ุณุงุฑุฉ, ู†ูˆุฑุฉ

// Full names with family names
$fullName = SmartSeeder::fullName();
$maleFullName = SmartSeeder::fullName('male');
$femaleFullName = SmartSeeder::fullName('female');

Dates

Generate Hijri (Islamic) calendar dates:

$hijriDate = SmartSeeder::hijriDate();
// Returns format: YYYY/MM/DD (e.g., "1445/03/15")

Financial Data

Generate Saudi-specific financial identifiers:

// Saudi IBAN (International Bank Account Number)
$iban = SmartSeeder::iban();
// Returns: "SA" + 22 digits (e.g., "SA0380000000608010167519")

Contact Information

Generate Saudi contact details:

// Saudi mobile phone number
$phone = SmartSeeder::phone();
// Returns: "+966" + 9 digits (e.g., "+966501234567")

// Saudi National ID (citizens and residents)
$nationalId = SmartSeeder::nationalId();
// Returns: 10-digit number starting with 1 or 2 (e.g., "1023456789")

// Saudi Iqama (resident ID) - specifically for non-citizens
$iqama = SmartSeeder::iqama();
// Returns: 10-digit number starting with 2 (e.g., "2087654321")

๐Ÿงช Laravel Integration

SmartSeeder works perfectly with Laravel factories and seeders:

// In a Laravel Factory
use Wali\SmartSeeder\SmartSeeder;

$factory->define(User::class, function (Faker $faker) {
    return [
        'name' => SmartSeeder::fullName(),
        'phone' => SmartSeeder::phone(),
        'national_id' => SmartSeeder::nationalId(),
        'iqama' => SmartSeeder::iqama(),
        'iban' => SmartSeeder::iban(),
        // ... other attributes
    ];
});

// In a Laravel Seeder
class UserSeeder extends Seeder
{
    public function run()
    {
        for ($i = 0; $i < 100; $i++) {
            User::create([
                'name' => SmartSeeder::fullName(),
                'phone' => SmartSeeder::phone(),
                'national_id' => SmartSeeder::nationalId(),
            ]);
        }
    }
}

๐Ÿงช Testing

Run the test suite:

# Run all tests
composer test

# Run tests with coverage
composer test-coverage

# Or using PHPUnit directly
./vendor/bin/phpunit

๐Ÿ“‹ Requirements

  • PHP 8.2 or higher
  • Composer

๐Ÿค Contributing

Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

๐Ÿ“ Code Quality

This package uses several tools to maintain code quality:

# Code formatting with Laravel Pint
composer format

# Check code style (without fixing)
composer format-test

# Code refactoring with Rector (dry-run)
composer refactor-dry

# Apply refactoring suggestions
composer refactor

# Run all CI checks locally
composer ci

๐Ÿ”’ Security

If you discover any security-related issues, please email creaspo6@gmail.com instead of using the issue tracker.

๐Ÿ“„ License

The MIT License (MIT). Please see License File for more information.

๐Ÿ‘จโ€๐Ÿ’ป Author

Wali-Eldin Hassan

๐Ÿ™ Acknowledgments

  • Inspired by the need for localized Arabic/Saudi fake data generation

Made with โค๏ธ