indaxia / doctrine-orm-transformations
Provides JSON-ready Doctrine ORM Entity-Array transfomtaions
Installs: 72 437
Dependents: 1
Suggesters: 0
Security: 0
Stars: 12
Watchers: 5
Forks: 1
Open Issues: 5
Requires
- php: >=5.4.0
- doctrine/orm: ^2.5
Requires (Dev)
- phpunit/phpunit: 5.6.*
- dev-master
- 2.0.1-stable
- 2.0.0-stable
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.3.0
- 0.2.13-beta
- 0.2.12-beta
- 0.2.11-beta
- 0.2.10-beta
- 0.2.9-beta
- 0.2.8-beta
- 0.2.7-beta
- 0.2.6-beta
- 0.2.5-beta
- 0.2.4-beta
- 0.2.3-beta
- 0.2.2-beta
- 0.2.1-beta
- 0.2.0-beta
- 0.1.4-beta
- 0.1.3-beta
- 0.1.2-beta
- 0.1.1-beta
- 0.1.0-beta
- 0.0.7-alpha
- 0.0.6-alpha
- 0.0.5-alpha
- 0.0.4-alpha
- 0.0.3-alpha
- 0.0.2-beta
- 0.0.2-alpha
- 0.0.1-alpha
This package is not auto-updated.
Last update: 2025-01-05 03:11:24 UTC
README
Features
- JSON-ready toArray and fromArray Trait (no need to extend class);
- Manipulating fields and nested sub-fields using Policy for each one;
- Supports all Doctrine ORM Column types;
- Supports JavaScript ISO8601 format for "date", "time" and "datetime" types;
- Supports nested Entities and Collections for all the Association types (be careful with self-referencing);
- fromArray asks EntityManager to find by "referencedColumnName" or creates new sub-entities (depends on Identifier emptiness and Policy);
- Same for Collection members (OneToMany, ManyToMany);
- Static toArrays method transforms multiple entities at once;
- Has workarounds for CVE-2015-0231 and Doctrine issue #4673;
Step 1: Installation
in composer.json add:
"require": { "Indaxia/doctrine-orm-transformations": "2.*" }
then
> cd <your doc root> > composer update
Step 2: Reference common classes
use \Indaxia\OTR\ITransformable; use \Indaxia\OTR\Traits\Transformable; use \Indaxia\OTR\Annotations\Policy;
Documentation
How to transform entities to arrays and vice versa
Let's say we have the following entities:
class Car implements ITransformable { use Transformable; /** @ORM\Id * @ORM\Column(type="integer") */ protected $id; /** @Policy\To\Skip * @ORM\Column(type="string") */ protected $keys; /** @ORM\OneToMany(targetEntity="Wheel") ... */ protected $wheels; public function getId(); public function getKeys() ... public function setKeys($v) ... ... } class Engine implements ITransformable { use Transformable; /** @ORM\Id * @ORM\Column(type="integer") */ protected $id; /** @Policy\To\Skip * @ORM\Column(type="string") */ protected $serialNumber; public function getId(); public function getSerialNumber() ... public function setSerialNumber($v) ... ... } class Wheel implements ITransformable { use Transformable; /** @ORM\Id * @ORM\Column(type="integer") */ protected $id; /** @Policy\Skip * @ORM\Column(type="string") */ protected $brakes; /** @ORM\Column(type="string") */ protected $model; public function getId(); public function getBrakes() ... public function setBrakes($v) ... public function getModel() ... public function setModel($v) ... ... }
Here we have some $car. Let's transform it to array.
// Using global policy $result = $car->toArray(); // Using local policy $result = $car->toArray((new Policy\Auto)->inside([ 'wheels' => new Policy\To\FetchPaginate(['offset'=0, 'limit'=4, 'fromTail'=false]) ])); // Local policy overrides global policy $result = $car->toArray((new Policy\Auto)->inside([ 'keys' => new Policy\Auto ]));
$result will be something like:
[ '__meta' => ['class' => 'Car'], 'id' => 1, 'engine' => [ '__meta' => ['class' => 'Engine', 'association' => 'OneToOne'], 'id' => 83 ], 'wheels' => [ '__meta' => ['class' => 'Wheel', 'association' => 'OneToMany'], 'collection' => [ [ '_meta' => ['class' => 'Wheel'], 'id' => 1, 'model' => 'A' ], [ '_meta' => ['class' => 'Wheel'], 'id' => 2, 'model' => 'A' ], [ '_meta' => ['class' => 'Wheel'], 'id' => 3, 'model' => 'B' ], [ '_meta' => ['class' => 'Wheel'], 'id' => 4, 'model' => 'B' ] ] ] ]
It's ready for JSON transformation!
echo json_encode($result);
You can also use something like array2XML and more.
And we can transform it to Entity again. It will retrieve sub-entities by id using EntityManager. Don't forget to use try-catch block to avoid uncaught exceptions.
$carB = new Car(); // Simple way $carB->fromArray($result, $entityManager); // With Policy $carB->fromArray($result, $entityManager, (new Policy\Auto())->inside([ 'keys' => mew Policy\Skip, 'engine' => (new Policy\Auto())->inside([ 'serialNumber' => new Policy\From\DenyNewUnset ]), 'wheels' => (new Policy\Auto())->inside([ 'brakes' => new Policy\From\Auto ]) ]);
Documentation
Indaxia / 2016