atwinta / data-transfer-object
Data transfer objects for Laravel
Installs: 2 631
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
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-03-23 09:49:55 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
во
второй параметр этих методов.