Spatie's Data Transfer Object library is awesome, but typing out DTOs can quickly become a chore. Inspired by Json2Typescript style tools, we built one for PHP DTOs.
Try it out at https://json2dto.atymic.dev
The web version has all of the same tools as the cli version in an easy to use React-based GUI. Features include:
- Interactive JSON Editor: Real-time JSON validation and formatting
- Live DTO Generation: Instant preview of generated PHP DTOs
- Multiple PHP Versions: Support for PHP 7.4+ typed properties and PHP 8.0+ attributes
- Nested DTO Support: Automatic generation of complex nested structures
- Usage Examples: Comprehensive examples showing real-world DTO usage patterns
- CLI Documentation: Complete guide for local development usage
When generating nested DTOs, the tool will create a zip file containing all related DTO classes.
This repository provides a complete solution for working with DTOs:
- Modern React + TypeScript application
- Real-time JSON validation and DTO generation
- Interactive examples and documentation
- Responsive design with Tailwind CSS
- Robust DTO generation engine
- Support for multiple PHP versions
- Flexible and strict DTO modes
- Comprehensive validation
- Real-world usage patterns
- Service layer implementations
- API controller examples
- Best practices and guidelines
- CLI tool for local development
- Docker support for easy deployment
- Comprehensive test suite
- CI/CD pipeline
Prefer to use the tool locally? You can install json2dto
via composer and generate files directly from json files.
composer global require atymic/json2dto # Install Globally
composer require atymic/json2dto --dev # Install locally in a project
The tool accepts json input either as a filename (second argument) or via stdin
.
You should run the tool in the root of your project (where your composer.json
is located) as it will resolve namespaces
based on your PSR4 autoloading config. If you aren't using PSR4, your generated folder structure might not match.
# Generate PHP 7.4 typed DTO
./vendor/bin/json2dto generate "App\DTO" test.json -name "Test" --typed
# Generate PHP 8.0 typed DTO (DTO V3)
./vendor/bin/json2dto generate "App\DTO" test.json -name "Test" --v3
# Generate a flexible DTO (with nested DTOs)
./vendor/bin/json2dto generate "App\DTO" test.json -name "Test" --nested --flexible
# Generate a DTO from stdin
wget http://example.com/cat.json | ./vendor/bin/json2dto generate "App\DTO" -name Cat
json2dto generate [options] [--] <namespace> [<json>]
Arguments:
namespace Namespace to generate the class(es) in
json File containing the json string
Options:
--nested Generate nested DTOs
--typed Generate PHP >= 7.4 strict typing
--flexible Generate a flexible DTO
--dry Dry run, print generated files
--v3 Generate V3 DTO
-h, --help Display this help message