A lightweight CLI tool for generating PHP entity and data class files from your database schema.
Drago Generator is built on Nette, Dibi, and Symfony Console, and allows you to create ready-to-use PHP classes for your tables with configurable constants, references, suffixes, and namespaces.
- PHP >= 8.3
- Nette Framework
- Symfony Console
- Dibi
- Composer
composer require drago-ex/generator --dev
extensions:
generator: Drago\Generator\DI\GeneratorExtension(%consoleMode%)
console: Contributte\Console\DI\ConsoleExtension(%consoleMode%)
# generator
generator:
# base (typical of Oracle)
lower: false
# generator entity
path: %appDir%/Entity
tableName: 'Table'
primaryKey: 'PrimaryKey'
columnInfo: false
constant: true
constantSize: false
constantPrefix: 'Column'
references: false
suffix: Entity
extendsOn: true
extends: Drago\Database\Entity
final: false
namespace: App\Entity
# generator data class
pathDataClass: %appDir%/DataClass
constantDataClass: true
constantSizeDataClass: true
constantDataPrefix: 'Form'
referencesDataClass: false
suffixDataClass: Data
extendsDataClass: Drago\Utils\ExtraArrayHash
finalDataClass: false
namespaceDataClass: App\DataClass
# symfony console
console:
name: Symfony Console
version: '1.0'Run generation commands using the Composer-installed binary:
# Generate entity classes
php vendor/bin/generator app:entity <table>
# Generate data classes
php vendor/bin/generator app:dataClass <table># Generate all entities
php vendor/bin/generator app:entity
# Generate entity for a specific table
php vendor/bin/generator app:entity users
# Generate all data classes
php vendor/bin/generator app:dataClass
# Generate data class for a specific table
php vendor/bin/generator app:dataClass orders- Generate entity and data classes from database tables
- Configurable constants and column size constants
- Support for foreign key references
- Set custom suffixes, namespaces, and final classes
- Symfony Console integration for a clean CLI
All settings of entities and data form can be found in Options.php
- Designed for Nette Framework projects.
- CLI binary expects a project with app/Bootstrap.php.
- For non-Nette projects, a custom bootstrap is required.