定制 floriandomgjoni/laravel-ai-factory 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

floriandomgjoni/laravel-ai-factory

Composer 安装命令:

composer require floriandomgjoni/laravel-ai-factory

包简介

Laravel package for generating realistic factory data using AI (OpenAI, Gemini, DeepSeek) with support for manual and hardcoded fields, model events, and bulk inserts.

README 文档

README

Laravel AI Factory is a developer-friendly package for generating realistic test data using AI models. It integrates seamlessly with Laravel factories and supports both AI-generated and manually defined fields, with the option to use bulk or individual inserts.

🚀 Features

  • ✅ Generate factory data using AI prompts
  • ✅ Supports OpenAI - Gemini and DeepSeek support coming soon...
  • ✅ Mix AI-generated fields with hardcoded or Faker-generated fields
  • ✅ Optional bulk insert for performance (without triggering model events)
  • ✅ Easy to extend and override

📦 Installation

composer require floriandomgjoni/laravel-ai-factory

⚙️ Configuration

Publish the config:

php artisan vendor:publish --tag=ai-factory-config

Update your .env with the appropriate API keys:

AI_FACTORY_DRIVER=openai
AI_FACTORY_OPENAI_API_KEY=your-api-key
AI_FACTORY_OPENAI_MODEL=gpt-4o-mini

or, for a local LLM:

AI_FACTORY_DRIVER=local
AI_FACTORY_LOCAL_URL=http://localhost:8080/v1/chat/completions
AI_FACTORY_LOCAL_API_KEY=""
AI_FACTORY_LOCAL_MODEL=Default

🧠 Defining AI Fields

In your factory, use the HasAIFactory trait and define the aiFields() method:

<?php
use FlorianDomgjoni\AIFactory\Concerns\HasAIFactory;

class UserFactory extends Factory
{
    use HasAIFactory;

    protected $model = \App\Models\User::class;

    public function aiFields(): array
    {
        return [
            'name' => 'Generate a realistic full name',
            'email' => fn () => fake()->unique()->safeEmail(),
            'password' => fn () => bcrypt('password'),
            'api_token' => fn () => Str::random(60),
        ];
    }
}
  • Use a string for AI-generated fields (prompt).
  • Use a callable for manual or faker-based fields.

You also need to fill the $model property with the model class inside the factory. It is required in order to function properly.

🛠 Usage

Basic Usage

User::factory()->count(5)->createWithAI();

Override Fields

User::factory()->count(3)->createWithAI([
    'email' => fn () => fake()->unique()->safeEmail(),
    'role' => fn () => 'admin'
]);

Bulk Insert (faster, skips model events)

User::factory()->count(100)->createWithAI([], true);

🧪 Example Prompt

[
    'title' => 'Generate a blog post title related to technology',
    'content' => 'Generate a paragraph of blog content about AI',
    'published_at' => fn () => now()->subDays(rand(1, 30)),
]

📂 Config File

return [
    'driver' => env('AI_FACTORY_DRIVER', 'openai'),

    'openai' => [
        'api_key' => env('AI_FACTORY_OPENAI_API_KEY'),
        'model' => env('AI_FACTORY_OPENAI_MODEL', 'gpt-4o-mini'),
    ],

    'local' => [
        'url' => env('AI_FACTORY_LOCAL_URL', 'http://localhost:8080'),
        'api_key' => env('AI_FACTORY_LOCAL_API_KEY', null),
        'model' => env('AI_FACTORY_LOCAL_MODEL', null),
    ],
];

🛡 Error Handling

  • AI data generation is wrapped in try/catch.
  • Model creation errors are logged individually.
  • Invalid JSON or failed API calls will throw descriptive exceptions.

📄 License

This package is open-sourced software licensed under the MIT license.

统计信息

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

GitHub 信息

  • Stars: 19
  • Watchers: 0
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-05-27