cable8mm / xeed
The Xeed is to generate new model, seed, Nova resource, database seed, factory and migration files for Laravel & Nova based on data from the existing database table.
Installs: 2 211
Dependents: 0
Suggesters: 0
Security: 0
Stars: 87
Watchers: 1
Forks: 8
Open Issues: 0
Type:project
pkg:composer/cable8mm/xeed
Requires
- php: ^8.1.0
- cable8mm/array-flatten: ^1.0
- doctrine/inflector: ^2.0
- league/flysystem: ^3.0
- symfony/console: ^6.0|^7.0
- vlucas/phpdotenv: ^5.0
Requires (Dev)
- fakerphp/faker: ^1.23
- laravel/pint: ^1.0
- nunomaduro/collision: ^6.0|^7.0|^8.0
- orchestra/testbench: ^6.0|^7.0|^8.0|^9.0|^10.0
- phpunit/phpunit: ^9.0|^10.0|^11.0|^12.0
Suggests
- php: `symfony/console` need `^8.0.2` over.
- cable8mm/array-flatten: To enable more efficient database schema mapping.
- doctrine/inflector: To get a Laravel Model name from a table name.
- symfony/console: Console framework to be used.
- vlucas/phpdotenv: To read `.env` configuration.
- dev-main
- v2.0.1
- v2.0.0
- v1.6.12
- v1.6.11
- v1.6.10
- v1.6.9
- v1.6.8
- v1.6.7
- v1.6.6
- v1.6.5
- v1.6.4
- v1.6.3
- v1.6.2
- v1.6.1
- v1.6.0
- v1.5.1
- v1.5.0
- v1.4.0
- v1.3.1
- v1.3.0
- v1.2.1
- v1.2.0
- v1.1.0
- v1.0.1
- v1.0.0
- v0.7.5
- v0.7.4
- v0.7.3
- v0.7.2
- v0.7.1
- v0.7.0
- v0.6.2
- v0.6.1
- v0.6.0
- v0.5.3
- v0.5.2
- v0.5.1
- v0.5.0
- dev-fix-deploy-action-icon-in-readme
- dev-update-php-min-version
- dev-fix-readme-for-ussage
- dev-change-laravel-commands
This package is auto-updated.
Last update: 2026-02-13 05:20:06 UTC
README
The Xeed is to generate new model, seed, Nova resources, database seed, factory and migration files for Laravel & Nova based on data from the existing database table.
Tip
It can function as both php artisan xeed:* commands for Laravel & Nova providing 100% identical functionality. Therefore, you can use it within your own Laravel & Nova project.
We have provided the API Documentation on the web. For more information, please visit https://www.palgle.com/xeed/ ❤️
Features
- Database testing is supported
- Generate models for Laravel
- Generate seed files for Laravel
- Generate Nova resources files for Laravel Nova
- Generate database seed files for Laravel
- Generate factories for Laravel
- Generate migrations for Laravel
- Generate belongsTo and hasMany relationships functions for Laravel
- Laravel multi & reserved columns supported
- Laravel integration
- MySQL, SQLite and PostgreSQL supported
Support & Tested
Preview
Installation
composer require cable8mm/xeed --dev
Usage
-f option make it forced, and xeeds is the table make.
# Generate all models from database in `app/Models` folder
php artisan xeed:model
# Force to generate a model from `xeeds` table in `app/Models` folder
php artisan xeed:model xeeds -f
# Generate all factories from database in `database/factories' folder
php artisan xeed:factory
# Force to generate a factory from `xeeds` table in `database/factories' folder
php artisan xeed:factory xeeds -f
# Generate all seeds from database in `database/seeders` folder
php artisan xeed:seeder
# Force to generate a seeder from `xeeds` table in `database/seeders` folder
php artisan xeed:seeder xeeds -f
# Generate all seeds from database in `database/seeders` folder
php artisan xeed:faker-seeder
# Force to generate a seeder from `xeeds` table in `database/seeders` folder
php artisan xeed:faker-seeder xeeds -f
# Generate a database seed from database in `database/seeders` folder
php artisan xeed:database
# Generate all migrations from database in `database/migrations' folder
php artisan xeed:migration
# Force to generate a migration from `xeeds` table in `database/migrations' folder
php artisan xeed:migration xeeds -f
# Add the relation function to all models from database in `app/Models` folder
php artisan xeed:relation
# Runs xeed:models before running xeed:relations. Add -f to force to generate
php artisan xeed:relation -f
# Add the Laravel Nova resources to all tables in `app/Nova` folder
php artisan xeed:nova
# Clean generated files, seeders, models, factories and migration files.
php artisan xeed:wipe
Formatting
# Modify all files to comply with the PSR-12.
composer lint
# Inspect all files to ensure compliance with PSR-12.
composer inspect
Testing
It uses the built-in SQLite database, not your own database. It will never cause harm to your data. You don't need to worry about that.
# Run `vendor/bin/testbench package:test tests`
composer testpack
# Run `vendor/bin/phpunit tests`
composer test
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
The below can help you contribute.
The Xeed has a built-in SQLite database, allowing you to contribute easily without needing your own database. Simply create a new file for testing purposes and utilize it.
# Create a new empty file for SQLite database
touch database/database.sqlite
And then,
# Run tests
composer test
Database seeds
For migrations and factories, when you need to execute tests for all database field types, utilize the following command.
# Import an 'xeeds' Table into the Database
php artisan xeed
# Drop the 'xeeds' Table from the Database
php artisan xeed drop
Utilize migration files for all database field types by referring to the following location database/*.sql these files are saved in the specified folder.
Use testorchestral/testbench
You can utilize testorchestral/testbench to execute tests. When running Laravel commands, the generated files are saved in the vendor/orchestra/testbench-core/laravel/database folder.
Resources
Laravel columns description for mysql:
| Available Column Types | Field | Type | Null | Key | Default | Extra |
|---|---|---|---|---|---|---|
| id() | id | bigint unsigned | NO | PRI | auto_increment | |
| bigInteger('big_integer') | big_integer | bigint | NO | |||
| binary('binary') | binary | blob | NO | |||
| boolean('boolean') | boolean | tinyint(1) | NO | |||
| char('char', length: 100) | char | char(100) | NO | |||
| dateTimeTz('date_time_tz', precision: 0) | date_time_tz | datetime | NO | |||
| dateTime('date_time', precision: 0) | date_time | datetime | NO | |||
| date('date') | date | date | NO | |||
| decimal('decimal', total: 8, places: 2) | decimal | decimal(8,2) | NO | |||
| double('double') | double | double | NO | |||
| enum('enum', ['easy', 'hard']) | enum | enum('easy','hard') | NO | |||
| float('float', precision: 53) | float | double | NO | |||
| foreignId('foreign_id') | foreign_id | bigint unsigned | NO | |||
| foreignUlid('foreign_ulid') | foreign_ulid | char(26) | NO | |||
| foreignUuid('foreign_uuid') | foreign_uuid | char(36) | NO | |||
| geometry('geometry', subtype: 'point', srid: 0) | geometry | point | NO | |||
| integer('integer') | integer | int | NO | |||
| ipAddress('ip_address') | ip_address | varchar(45) | NO | |||
| json('json') | json | json | NO | |||
| jsonb('jsonb') | jsonb | json | NO | |||
| longText('long_text') | long_text | longtext | NO | |||
| macAddress('mac_address') | mac_address | varchar(17) | NO | |||
| mediumInteger('medium_integer') | medium_integer | mediumint | NO | |||
| mediumText('medium_text') | medium_text | mediumtext | NO | |||
| morphs('morph') | morph_type | varchar(255) | NO | MUL | ||
| Ditto make 2 fields | morph_id | bigint unsigned | NO | |||
| nullableTimestamps(precision: 0) | created_at | timestamp | YES | |||
| Ditto make 2 fields | updated_at | timestamp | YES | |||
| nullableMorphs('nullable_morph') | nullable_morph_type | varchar(255) | YES | MUL | ||
| Ditto make 2 fields | nullable_morph_id | bigint unsigned | YES | |||
| nullableUlidMorphs('nullable_ulid_morph') | nullable_ulid_morph_type | varchar(255) | YES | MUL | ||
| Ditto make 2 fields | nullable_ulid_morph_id | char(26) | YES | |||
| nullableUuidMorphs('nullable_uuid_morph') | nullable_uuid_morph_type | varchar(255) | YES | MUL | ||
| Ditto make 2 fields | nullable_uuid_morph_id | char(36) | YES | |||
| rememberToken() | remember_token | varchar(100) | YES | |||
| set('set', ['strawberry', 'vanilla']) | set | set('strawberry','vanilla') | NO | |||
| smallInteger('small_integer') | small_integer | smallint | NO | |||
| softDeletesTz('soft_delete_tz', precision: 0) | soft_delete_tz | timestamp | YES | |||
| softDeletes('soft_delete', precision: 0) | soft_delete | timestamp | YES | |||
| string('string', length: 100) | string | varchar(100) | NO | |||
| text('text') | text | text | NO | |||
| time('time_tz', 0) | time_tz | time | NO | |||
| time('time', 0) | time | time | NO | |||
| timestampTz('timestamp_tz', precision: 0) | timestamp_tz | timestamp | NO | |||
| timestamp('timestamp', precision: 0) | timestamp | timestamp | NO | |||
| tinyInteger('tiny_integer') | tiny_integer | tinyint | NO | |||
| tinyText('tiny_text') | tiny_text | tinytext | NO | |||
| unsignedBigInteger('unsigned_big_integer') | unsigned_big_integer | bigint unsigned | NO | |||
| unsignedInteger('unsigned_integer') | unsigned_integer | int unsigned | NO | |||
| unsignedMediumInteger('unsigned_medium_integer') | unsigned_medium_integer | mediumint unsigned | NO | |||
| unsignedSmallInteger('unsigned_small_integer') | unsigned_small_integer | smallint unsigned | NO | |||
| unsignedTinyInteger('unsigned_tiny_integer') | unsigned_tiny_integer | tinyint unsigned | NO | |||
| ulidMorphs('ulid_morph') | ulid_morph_type | varchar(255) | NO | MUL | ||
| Ditto make 2 fields | ulid_morph_id | char(26) | NO | |||
| uuidMorphs('uuid_morph') | uuid_morph_type | varchar(255) | NO | MUL | ||
| Ditto make 2 fields | uuid_morph_id | char(36) | NO | |||
| ulid('ulid') | ulid | char(26) | NO | |||
| uuid('uuid') | uuid | char(36) | NO | |||
| year('year') | year | year | NO |
Code of Conduct
In order to ensure that the community is welcoming to all, please review and abide by the CODE OF CONDUCT.
Credits
License
The Xeed project is open-sourced software licensed under the MIT license.
