mirror of
https://github.com/kevinveenbirkenbach/infinito.git
synced 2025-01-09 22:17:26 +01:00
Optimized RequestedRight to load Source via RequestedEntity
This commit is contained in:
parent
edda341d59
commit
a96c1b396e
@ -102,4 +102,18 @@ class RequestedEntity extends AbstractEntity implements RequestedEntityInterface
|
|||||||
|
|
||||||
return $repository->find($this->id);
|
return $repository->find($this->id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Overriding is neccessary to declare the correct relation
|
||||||
|
* {@inheritdoc}
|
||||||
|
*
|
||||||
|
* @see \App\Attribut\RequestedRightAttributInterface::setRequestedRight()
|
||||||
|
*/
|
||||||
|
public function setRequestedRight($requestedRight): void
|
||||||
|
{
|
||||||
|
$this->requestedRight = $requestedRight;
|
||||||
|
if ($this->requestedRight !== $this) {
|
||||||
|
$this->requestedRight->setRequestedEntity($this);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,9 +8,10 @@ use App\Attribut\LayerAttribut;
|
|||||||
use App\Attribut\RecieverAttribut;
|
use App\Attribut\RecieverAttribut;
|
||||||
use App\Exception\PreconditionFailedException;
|
use App\Exception\PreconditionFailedException;
|
||||||
use App\Exception\NotSetException;
|
use App\Exception\NotSetException;
|
||||||
use App\Repository\Source\SourceRepositoryInterface;
|
|
||||||
use App\Domain\RequestManagement\Entity\RequestedEntityInterface;
|
use App\Domain\RequestManagement\Entity\RequestedEntityInterface;
|
||||||
use App\Attribut\RequestedEntityAttribut;
|
use App\Attribut\RequestedEntityAttribut;
|
||||||
|
use App\Entity\Meta\MetaInterface;
|
||||||
|
use App\Exception\NotCorrectInstanceException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author kevinfrantz
|
* @author kevinfrantz
|
||||||
@ -21,11 +22,6 @@ class RequestedRight implements RequestedRightInterface
|
|||||||
{
|
{
|
||||||
use CrudAttribut, LayerAttribut, RecieverAttribut, RequestedEntityAttribut;
|
use CrudAttribut, LayerAttribut, RecieverAttribut, RequestedEntityAttribut;
|
||||||
|
|
||||||
/**
|
|
||||||
* @var SourceRepositoryInterface
|
|
||||||
*/
|
|
||||||
private $sourceRepository;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var SourceInterface
|
* @var SourceInterface
|
||||||
*/
|
*/
|
||||||
@ -37,16 +33,18 @@ class RequestedRight implements RequestedRightInterface
|
|||||||
private $requestedEntity;
|
private $requestedEntity;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param SourceRepositoryInterface $sourceRepository
|
* @throws NotCorrectInstanceException
|
||||||
*/
|
*/
|
||||||
public function __construct(SourceRepositoryInterface $sourceRepository)
|
|
||||||
{
|
|
||||||
$this->sourceRepository = $sourceRepository;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function loadSource(): void
|
private function loadSource(): void
|
||||||
{
|
{
|
||||||
$this->source = $this->sourceRepository->findOneByIdOrSlug($this->requestedEntity);
|
$entity = $this->requestedEntity->getEntity();
|
||||||
|
if ($entity instanceof SourceInterface) {
|
||||||
|
$this->source = $entity;
|
||||||
|
}
|
||||||
|
if ($entity instanceof MetaInterface) {
|
||||||
|
$this->source = $entity->getSource();
|
||||||
|
}
|
||||||
|
throw new NotCorrectInstanceException('The entity instance can\'t be processed');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -85,12 +83,17 @@ class RequestedRight implements RequestedRightInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Overriding is neccessary to declare the correct relation.
|
||||||
|
*
|
||||||
* {@inheritdoc}
|
* {@inheritdoc}
|
||||||
*
|
*
|
||||||
* @see \App\Domain\RequestManagement\Right\RequestedRightInterface::setRequestedEntity()
|
* @see \App\Domain\RequestManagement\Right\RequestedRightInterface::setRequestedEntity()
|
||||||
*/
|
*/
|
||||||
final public function setRequestedEntity(RequestedEntityInterface $requestedSource): void
|
final public function setRequestedEntity(RequestedEntityInterface $requestedEntity): void
|
||||||
{
|
{
|
||||||
$this->requestedEntity = $requestedSource;
|
$this->requestedEntity = $requestedEntity;
|
||||||
|
if ($requestedEntity->getRequestedRight() !== $this) {
|
||||||
|
$this->requestedEntity->setRequestedRight($this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user