96 lines
2.0 KiB
PHP
96 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace App\Service\Person;
|
|
|
|
use App\Entity\Person;
|
|
use App\Hydrator\DoctrineObject;
|
|
use App\Service\EntityServiceInterface;
|
|
use Doctrine\ORM\EntityManager;
|
|
use Doctrine\ORM\Query;
|
|
use Exception;
|
|
|
|
class PersonService implements EntityServiceInterface
|
|
{
|
|
|
|
/**
|
|
* @var EntityManager
|
|
*/
|
|
private $em;
|
|
|
|
/**
|
|
* @var DoctrineObject
|
|
*/
|
|
private $hydrator;
|
|
|
|
public function __construct(EntityManager $em, DoctrineObject $hydrator)
|
|
{
|
|
$this->em = $em;
|
|
$this->hydrator = $hydrator;
|
|
}
|
|
|
|
public function getList()
|
|
{
|
|
$qb = $this->em->createQueryBuilder();
|
|
$entities = $qb->select('p')
|
|
->from(Person::class, 'p')
|
|
->getQuery()
|
|
->getArrayResult();
|
|
return $entities;
|
|
}
|
|
|
|
public function get($id)
|
|
{
|
|
$qb = $this->em->createQueryBuilder();
|
|
|
|
$entity = $qb->select('p')
|
|
->from(Person::class, 'p')
|
|
->where('p.id = :id')
|
|
->setParameter('id', $id)
|
|
->getQuery()
|
|
->getOneOrNullResult(Query::HYDRATE_ARRAY);
|
|
|
|
return $entity;
|
|
}
|
|
|
|
public function create($data)
|
|
{
|
|
$entity = $this->hydrator->hydrate($data, new Person());
|
|
try {
|
|
$this->em->persist($entity);
|
|
$this->em->flush();
|
|
} catch (Exception $ex) {
|
|
return false;
|
|
}
|
|
return $entity;
|
|
}
|
|
|
|
public function modify($id, $data)
|
|
{
|
|
if (null === ($entity = $this->em->find(Person::class, $id))) {
|
|
return false;
|
|
}
|
|
|
|
$entity = $this->hydrator->hydrate($data, $entity);
|
|
$this->em->persist($entity);
|
|
$this->em->flush();
|
|
|
|
return $entity;
|
|
}
|
|
|
|
public function delete($id)
|
|
{
|
|
if (null === ($entity = $this->em->find(Person::class, $id))) {
|
|
return false;
|
|
}
|
|
|
|
try {
|
|
$this->em->remove($entity);
|
|
$this->em->flush();
|
|
} catch (Exception $ex) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|