zendrop / data
This package allows you to created DataTransferObjects without pain
Installs: 51 553
Dependents: 2
Suggesters: 0
Security: 0
Stars: 2
Watchers: 5
Forks: 0
Open Issues: 0
Requires
- php: ^8.1
- illuminate/support: ^9.0|^10.0|^11.0
Requires (Dev)
- laravel/pint: ^1.13
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^9.0
- symfony/var-dumper: ^6.0|^7.0
This package is not auto-updated.
Last update: 2025-01-10 14:15:27 UTC
README
Installation
To install the package via Composer, run the following command:
composer require zendrop/data
How To Use
Creating Data Models
- Implement Interfaces: Your models should implement
DataInterface
andToArrayInterface
. - Use Traits: Incorporate
DataTrait
andToArrayTrait
for functionality. - Handle Arrays: For validating arrays, use the
ArrayOf
attribute. Mark fields that can be skipped with Skippable. - Nested Structures: You can create models within models.
- Enums: Use BackedEnum for enum types.
Code Example
<?php use Zendrop\Data\DataInterface; use Zendrop\Data\DataTrait; use Zendrop\Data\Attributes\ArrayOf; use Zendrop\Data\Skippable; use Zendrop\Data\ToArrayInterface; use Zendrop\Data\ToArrayTrait; class Tag implements DataInterface, ToArrayInterface { use DataTrait; use ToArrayTrait; public function __construct( public readonly string $name ) { } } enum Occupation: string { case Manager: 'manager'; case Developer: 'developer'; } class User implements DataInterface, ToArrayInterface { use DataTrait; use ToArrayTrait; public function __construct( public readonly int $id, public readonly string $userName, /** @var Tag[] */ #[ArrayOf(Tag::class)] public readonly array $tags, public readonly Occupation $occupation, public readonly string|Skippable $bio = Skippable::Skipped ) { } }
Instantiation and Serialization
Create objects from arrays with automatic type conversion and key normalization. Serialize objects back to arrays with flexible key formatting.
// Create a User object from an array $user = User::from([ 'id' => '42', // will be converted to int 'user_name' => 'John Doe', 'tags' => [ ['name' => 'friend'], // will be converted to Tag class ['name' => 'zendrop'] ], 'occupation' => 'developer' // will be converted to Occupation enum // 'bio' is optional and skipped here ]); // Serialize the User object to an array $arraySnakeCase = $user->toArray(); // Default snake_case $arrayCamelCase = $user->toArray(ToArrayCase::Camel); $arrayKebabCase = $user->toArray(ToArrayCase::Kebab);