To create a DataTransferObject
create the class and use public properties.
use DataTransferObject\DataTransferObject;
class Employee extends DataTransferObject
{
public string $name;
public string $email;
public ?Employee $reportsTo;
public int $age;
public bool $active = true;
/**
* @var \App\DataTransferObject\Employee[] $subordinates
*/
public array $subordinates = [];
}
Then to set the data
$employee = new Employee();
$employee->name = 'sarah';
You can also mass set the properties using an array when constructing the argument. Note this only sets, does not convert or extract, see fromArray
$sarah = new Employee([
'name' => 'Sarah',
'email' => '[email protected]',
'reportsTo' => $claire
]);
When you use the DataTransferObject
constructor, it simply sets the values that you are providing, however when you need to convert data and cast types, you can use the fromArray
method.
The fromArray
extracts relevant data and it:
- casts built in types bool, int, string, float etc
- will create a
DataTransferObject
,DateTime
or any other object that has a__set_state
magic method.
It will only extract fields defined in the DataTransferObject
and will only throw an error, if after extracting data, a property on the DataTransferObject
was not initialized.
For example, related DataTransferObjects
such as belongsTo
and hasMany
will be marshalled. For hasMany
to work create an array and set the DocBlock definition like below:
class Employee extends DataTransferObject
{
public string $name;
public string $email;
public ?Employee $reportsTo;
/**
* @var \App\DataTransferObjects\Employee[] $subordinates
*/
public array $subordinates = [];
}
To use the fromArray
method
$employee = Employee::fromArray([
'name' => 'Sarah',
'email' => '[email protected]',
'reportsTo' => [
'name' => 'Claire',
'email' => '[email protected]',
],
'subordinates' => [
[
'name' => 'Jon',
'email' => '[email protected]'
]
]
]);
To convert the DataTransferObject
and any nested objects to an array if the object has an toArray
method or does not have a __toString
method.
$employee->toArray();
The default serialization method is JSON, for a different method, e.g. XML you can override the serialize
and deserialize
methods. Only public properties will be used in the serialization and therefore deserialization process.
To convert a DataTransferObject
to a string.
$employee->toString();
To convert a string to a DataTransferObject
$employee = Contact::fromString(
'{"name":"Jon","company":"Snow Enterprises","email":"[email protected]","age":33,"unsubscribed":false}'
);
When the DataTransferObject
is constructed it will call initialize
method if it is available, this is a hook incase
you need to override the constructor.
If you try to set or get a property that does not exist, a RuntimeException
will be thrown.