webdevcave / dto
Provides a foundation for data transfer objects in PHP applications. Built with support for ArrayAccess, JsonSerializable interfaces and hydration provided by our dependency injection container.
Requires
- php: >=8.4.1
- webdevcave/yadic: ^1.2
Requires (Dev)
- phpunit/phpunit: ^13.1
- rregeer/phpunit-coverage-check: ^0.3.1
README
Provides a foundation for data transfer objects in PHP applications. Built with support for ArrayAccess, JsonSerializable interfaces and hydration provided by our dependency injection container (webdevcave/yadic).
Requirements
- PHP >= 8.4.1
- Composer
Installation
Using composer:
composer require webdevcave/dto
Usage example
Extend the DataTransferObject class and define your properties. You can use the from() method to hydrate the DTO from an array.
use Webdevcave\DTO\DataTransferObject; class UserDTO extends DataTransferObject { public string $name; public string $email; } // Hydrating from array $data = ['name' => 'John Doe', 'email' => 'john@example.com']; $user = UserDTO::from($data); echo $user->name; // John Doe // ArrayAccess echo $user['email']; // john@example.com // JSON Serialization echo json_encode($user);
Scripts
The following scripts are available via Composer:
composer test: Run the testscomposer test-coverage: Run the tests with coverage (requires Xdebug)composer check-coverage: Check the coverage
Tests
The project uses PHPUnit for testing. You can run the tests using:
composer test
Contributing
Contributions are welcome! If you find any issues or have suggestions for improvements, please open an issue or a pull request on GitHub.
License
This project is licensed under the MIT License - see the LICENSE file for details.