To install the package via Composer, run the following command:
composer require zendrop/data
- 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.
<?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
) {
}
}
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);