wali/smart-seeder 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

wali/smart-seeder

最新稳定版本:1.0.0

Composer 安装命令:

composer require wali/smart-seeder

包简介

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

README 文档

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 ❤️

统计信息

  • 总下载量: 16
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 5
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 5
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-10-01

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固