moonspot / value-objects
Base classes for creating value objects which are easy to work with in JSON apis
Installs: 2 688
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 1
Requires
- php: ^8.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.15
- phan/phan: ^5.4
- php-parallel-lint/php-parallel-lint: ^1.3
- phpunit/phpunit: ^9.6
This package is auto-updated.
Last update: 2024-12-30 21:57:23 UTC
README
This library provides a base for creating value objects that can be easily created from and converted into YAML and JSON for use in creating API endpoints.
\Moonspot\ValueObjects\ValueObject
This class provides methods for converting arrays, JSON, and YAML into objects and exporting them back to those forms.
<?php namespace Example; use Moonspot\ValueObjects\ValueObject; class Car extends ValueObject { public int $id = 0; public string $model = ''; public string $make = ''; } $car = new Car(); $car->fromArray( [ 'id' => 1, 'model' => 'Kia', 'make' => 'Sportage' ] ); echo $car->toJSON();
{ "id": 1, "model": "Kia", "make": "Sportage" }
\Moonspot\ValueObjects\TypedArray
This class is a base class for creating an ArrayObject that requires a specific type or types added to the ArrayObject. And, the class will provide the Export interface. Also, any objects within the internal array will be deeply exported.
<?php namespace Example; use Moonspot\ValueObjects\TypedArray; use Moonspot\ValueObjects\ValueObject; class CarSet extends TypedArray { public const REQUIRED_TYPE = [Car::class]; } class Fleet extends ValueObject { public int $id = 0; public string $name = ''; public CarSet $cars; public function __construct() { // Any properties which are ValueObjects or TypedArrays should be // initialized in the ValueObject's constructor $this->cars = new CarSet(); } } $car = new Car(); $car->fromArray( [ 'id' => 1, 'model' => 'Kia', 'make' => 'Sportage' ] ); $fleet = new Fleet(); $fleet->id = 1; $fleet->name = "New Fleet"; $fleet->cars[] = $car; echo $fleet->toJSON();
{ "id": 1, "name": "New Fleet", "cars": [ { "id": 1, "model": "Kia", "make": "Sportage" } ] }
\Moonspot\ValueObjects\ArrayObject
This is the base class for TypedArray and extends the native ArrayObject classes adding the methods for the Export interface. This is useful by itself when there is unstructured array data that needs to be a part of a value object.
<?php namespace Example; use Moonspot\ValueObjects\ValueObject; use Moonspot\ValueObjects\ArrayObject; class Car extends ValueObject { public int $id = 0; public string $model = ''; public string $make = ''; public ArrayObject $attributes; public function __construct() { // Any properties which are ValueObjects or TypedArrays should be // initialized in the ValueObject's constructor $this->attributes = new ArrayObject(); } } $car = new Car(); $car->id = 1; $car->model = 'Kia'; $car->make = 'Sportage'; $car->attributes['color'] = 'Blue'; $car->attributes['passengers'] = 5; echo $car->toJSON();
{ "id": 1, "model": "Kia", "make": "Sportage", "attributes": { "color": "Blue", "passengers": 5 } }