php-collective / laravel-dto
Laravel integration for php-collective/dto
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/php-collective/laravel-dto
Requires
- php: >=8.2
- laravel/framework: ^11.0|^12.0
- php-collective/dto: ^0.1|dev-master
Requires (Dev)
- orchestra/testbench: ^9.0|^10.0
- php-collective/code-sniffer: dev-master
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^10.0|^11.0|^12.0
This package is auto-updated.
Last update: 2025-12-16 13:50:48 UTC
README
Laravel integration for php-collective/dto.
Installation
composer require php-collective/laravel-dto
The service provider will be auto-discovered.
Configuration
Publish the config file:
php artisan vendor:publish --provider="PhpCollective\LaravelDto\DtoServiceProvider"
This creates config/dto.php with the following options:
return [ 'config_path' => config_path(), // Where DTO config files are located 'output_path' => app_path('Dto'), // Where to generate DTOs 'namespace' => 'App\\Dto', // Namespace for generated DTOs ];
Usage
1. Create your DTO configuration
Create config/dto.xml (or config/dtos.xml to avoid conflicts):
<?xml version="1.0" encoding="UTF-8"?> <dtos xmlns="php-collective-dto"> <dto name="User"> <field name="id" type="int"/> <field name="name" type="string"/> <field name="email" type="string"/> </dto> </dtos>
2. Generate DTOs
php artisan dto:generate
Options:
--dry-run- Preview changes without writing files-v- Verbose output
3. Use your DTOs
use App\Dto\UserDto; $user = new UserDto(); $user->setId(1); $user->setName('John Doe'); $user->setEmail('john@example.com'); return response()->json($user->toArray());
Or create from an array:
$user = UserDto::createFromArray([ 'id' => 1, 'name' => 'John Doe', 'email' => 'john@example.com', ]);
Supported Config Formats
The package supports multiple config file formats:
dto.xmlordtos.xml- XML formatdto.yml/dto.yamlordtos.yml/dtos.yaml- YAML formatdtos.php- PHP format (usedtos.phpto avoid conflict withconfig/dto.php)dto/subdirectory with multiple files
License
MIT