atwinta / data-transfer-object
Data transfer objects for Laravel
Installs: 2 893
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
pkg:composer/atwinta/data-transfer-object
Requires
- php: ^8.0
- laravel/framework: ^9.0|^10.0
Requires (Dev)
- laravel/pint: ^1.1
- nunomaduro/larastan: ^2.1
- orchestra/testbench: ^7.7
- phpstan/phpstan-strict-rules: ^1.4
This package is auto-updated.
Last update: 2025-10-23 11:09:56 UTC
README
Установка
Установка через Composer:
composer require atwinta/data-transfer-object
Использование
Создание DTO
php artisan make:dto <name> - создаст класс в папке app/DTO
После создания, в DTO нужно будет указать поля. Рекомендуется указывать их в конструкторе,
потому что поля, указанные в конструкторе можно заполнить используя метод DTO::create() и
сделать обязательными для создания DTO.
Для уменьшения количества кода рекомендуется определять поля в конструкторе:
class User extends \Atwinta\DTO\DTO { public function __construct( public int $id ) {} }
Использование DTO
Для создания DTO можно напрямую использовать конструктор или использовать метод
DTO::create(). Этот метод принимает массив вида [название поля => значение]
и самостоятельно вызывает конструктор, передавая значения в нужном порядке.
Если передать в него объект, он будет приведён к массиву следующим образом:
- Если объект наследуется от \Illuminate\Foundation\Http\FormRequest, на нём будет вызван методvalidated()
- Если объект имплементирует интерфейс \Illuminate\Contracts\Support\Arrayable, на нём будет вызван методtoArray()
- Все остальные объекты будут приведены к массиву используя cast (array) $object
Так как базовый класс DTO имплементирует интерфейс \Illuminate\Contracts\Support\Arrayable,
DTO можно заполнить из других DTO никак не изменяя их перед передачей в DTO::create().
Для массового заполнения уже созданного DTO можно использовать метод DTO::fill().
Он принимает те же параметры, что и DTO::create(), и обрабатывает их тем же образом.
По умолчанию, DTO::create() и DTO::fill() клонируют объекты перед записью в
поля заполняемого DTO. Чтобы отключить клонирование, нужно передать false во
второй параметр этих методов.