https://github.com/nutgram/hydrator
A turbocharged json object hydrator for your DTOs
https://github.com/nutgram/hydrator
data-transfer-object dto enum hacktoberfest hydrator json jsonmapper mapper php php8
Last synced: 7 months ago
JSON representation
A turbocharged json object hydrator for your DTOs
- Host: GitHub
- URL: https://github.com/nutgram/hydrator
- Owner: nutgram
- License: mit
- Created: 2022-04-21T19:57:55.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2025-03-31T23:08:00.000Z (about 1 year ago)
- Last Synced: 2025-04-01T00:22:04.889Z (about 1 year ago)
- Topics: data-transfer-object, dto, enum, hacktoberfest, hydrator, json, jsonmapper, mapper, php, php8
- Language: PHP
- Homepage:
- Size: 162 KB
- Stars: 11
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Strongly typed hydrator for PHP 8.0+
---
Fork of the original project https://github.com/sunrise-php/hydrator.
## Installation
```bash
composer require nutgram/hydrator
```
## How to use?
```php
use SergiX44\Hydrator\Hydrator;
$hydrator = new Hydrator();
// create and hydrate an object with an array
$data = [/* the class props here */];
$object = $hydrator->hydrate(SomeDto::class, $data);
// hydrate an object with an array
$data = [/* the class props here */];
$hydrator->hydrate($object, $data);
// creates and hydrate an object with JSON
$json = '{...}';
$object = $hydrator->hydrateWithJson(SomeDto::class, $json);
// hydrate an object with JSON
$json = '{...}';
$hydrator->hydrateWithJson($object, $json);
// pass JSON decoding flags
$options = JSON_OBJECT_AS_ARRAY|JSON_BIGINT_AS_STRING;
$hydrator->hydrateWithJson($object, $json, $options);
```
## Allowed property types
### Required
If a property has no a default value, then the property is required.
```php
public string $value;
```
### Optional
If a property has a default value, then the property is optional.
```php
public string $value = 'foo';
```
### Null
If a property is nullable, then the property can accept null.
```php
public ?string $value;
```
If the property should be optional, then it must has a default value.
```php
public ?string $value = null;
```
### Boolean
Accepts the following values: true, false, 1, 0, "1", "0", "yes", "no", "on" and "no".
```php
public bool $value;
```
```php
['value' => true];
['value' => 'yes'];
```
## Integer
Accepts only integers (also as a string).
```php
public int $value;
```
```php
['value' => 42];
['value' => '42'];
```
## Number
Accepts only numbers (also as a string).
```php
public float $value;
```
```php
['value' => 42.0];
['value' => '42.0'];
```
## String
Accepts only strings.
```php
public string $value;
```
```php
['value' => 'foo'];
```
## Array
Accepts only arrays.
```php
public array $value;
```
```php
['value' => [1, 2, 'foo']];
```
## Array
Accept a list of objects.
```php
final class SomeDto {
public readonly string $value;
}
```
```php
use SergiX44\Hydrator\Annotation\ArrayType;
#[ArrayType(SomeDto::class)]
public array $value;
```
```php
[
'value' => [
[
'value' => 'foo',
],
[
'value' => 'bar',
],
],
],
```
## Object
Accepts only objects.
```php
public object $value;
```
```php
['value' => new stdClass];
```
## DateTime/DateTimeImmutable
Integers (also as a string) will be handled as a timestamp, otherwise accepts only valid date-time strings.
```php
public DateTimeImmutable $value;
```
```php
// 2010-01-01
['value' => 1262304000];
// 2010-01-01
['value' => '1262304000'];
// normal date
['value' => '2010-01-01'];
```
## DateInterval
Accepts only valid date-interval strings based on ISO 8601.
```php
public DateInterval $value;
```
```php
['value' => 'P1Y']
```
## Enum
Accepts only values that exist in an enum.
```php
enum SomeEnum: int {
case foo = 0;
case bar = 1;
}
```
```php
public SomeEnum $value;
```
```php
['value' => 0]
['value' => '1']
```
## Association
Accepts a valid structure for an association
```php
final class SomeDto {
public string $value;
}
```
```php
public SomeDto $value;
```
```php
[
'value' => [
'value' => 'foo',
],
]
```
## Property alias
If you need to get a non-normalized key, use aliases.
For example, the Google Recaptcha API returns the following response:
```json
{
"success": false,
"error-codes": []
}
```
To correctly map the response, use the following model:
```php
use SergiX44\Hydrator\Annotation\Alias;
final class RecaptchaVerificationResult {
public bool $success;
#[Alias('error-codes')]
public array $errorCodes = [];
}
```
## Examples
```php
final class Product {
public string $name;
public Category $category;
#[ArrayType(Tag::class)]
public array $tags;
public Status $status;
}
final class Category {
public string $name;
}
final class Tag {
public string $name;
}
enum Status: int {
case ENABLED = 1;
case DISABLED = 0;
}
```
```php
$product = $hydrator->hydrate(Product::class, [
'name' => 'Stool',
'category' => [
'name' => 'Furniture',
],
'tags' => [
[
'name' => 'Wood',
],
[
'name' => 'Lacquered',
],
],
'status' => 0,
]);
```
---
## Test run
```bash
composer test
```