Creating from Different Sources
You can use thefrom method to create a data object from nearly anything. For example, let’s say you have an Eloquent model like this:
Constructor Properties vs Regular Properties
Although the PHP 8.0 constructor properties look great in data objects, it is perfectly valid to use regular properties without a constructor like so:Magical Creation
It is possible to overwrite or extend the behaviour of thefrom method for specific types. So you can construct a data object in a specific manner for that type. This can be done by adding a static method starting with ‘from’ to the data object.
For example, we want to change how we create a data object from a model. We can add a fromModel static method that takes the model we want to use as a parameter:
fromModel method will be called to create a data object from the found model.
Multiple Magical Methods
You’re truly free to add as many from methods as you want. For example, you could add one to create a data object from a string:Multiple Arguments
It is also possible to use multiple arguments in a magical creation method:Requirements for Magical Methods
There are a few requirements to enable magical data object creation:- The method must be static and public
- The method must start with from
- The method cannot be called from
Default Creation Flow
When the package cannot find such a method for a type given to the data object’sfrom method. Then the data object will try to create itself from the following types:
- An Eloquent model by calling
toArrayon it - A Laravel request by calling
allon it - An Arrayable by calling
toArrayon it - An array
This list can be extended using extra normalizers, find more about it here.
CannotCreateData exception will be thrown.
Optional Creation
It is impossible to returnnull from a data object’s from method since we always expect a data object when calling from. To solve this, you can call the optional method:
from method when a value is given, so you can still magically create data objects. When a null value is given, it will return null.
Creation Without Magic Methods
You can ignore the magical creation methods when creating a data object as such:It is possible to configure how a data object is created, whether it will be validated, which casts to use and more. You can read more about it here.
DTO Classes
The defaultData class from which you extend your data objects is a multi versatile class, it packs a lot of functionality. But sometimes you just want a simple DTO class. You can use the Dto class for this:
Dto class is a data class in its most basic form. It can be created from anything using magical methods, can validate payloads before creating the data object and can be created using factories. But it doesn’t have any of the other functionality that the Data class has.