A hydrator for doctrine 2 that converts an array to the entity of your choice.
The recommended way to install is through Composer.
composer require pmill/doctrine-array-hydrator
Given this doctrine entity:
<?php
namespace App\Entity;
use Doctrine\ORM\Mapping as ORM;
use Railroad\DoctrineArrayHydrator\Tests\Fixtures\Company;
use Railroad\DoctrineArrayHydrator\Tests\Fixtures\Permission;
/**
* @ORM\Entity
* @ORM\Table(name="users")
*/
class User
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue
*
* @var int
*/
protected $id;
/**
* @ORM\Column(type="string")
*
* @var string
*/
protected $name;
/**
* @ORM\Column(type="string")
*
* @var string
*/
protected $email;
/**
* @ManyToOne(targetEntity="Company")
*
* @var Company
*/
protected $company;
/**
* @OneToMany(targetEntity="Permission", mappedBy="product")
*
* @var Permission[]
*/
protected $permissions;
}
We can populate this object with an array, for example:
$data = [
'name' => 'Fred Jones',
'email' => 'fred@example.com',
'company' => 2,
'permissions' => [1, 2, 3, 4]
];
$hydrator = new \pmill\Doctrine\Hydrator\ArrayHydrator($entityManager);
$entity = $hydrator->hydrate('App\Entity\User', $data);
We can populate user with JSON API resource data Documentation
$data = [
'attributes' => [
'name' => 'Fred Jones',
'email' => 'fred@example.com',
],
'relationships' => [
'company' => [
'data' => ['id' => 1, 'type' => 'company'],
],
'permissions' => [
'data' => [
['id' => 1, 'type' => 'permission'],
['id' => 2, 'type' => 'permission'],
['id' => 3, 'type' => 'permission'],
['id' => 4, 'type' => 'permission'],
['name' => 'New permission']
]
]
]
];
$hydrator = new \pmill\Doctrine\Hydrator\JsonApiHydrator($entityManager);
$entity = $hydrator->hydrate('App\Entity\User', $data);
Doctrine Array to Entity Hydrator Copyright (c) 2015 pmill (dev.pmill@gmail.com) All rights reserved.