Я пытаюсь внедрить объект контейнера (который доступен в контроллерах) в сущности, используя postLoad
lifecycleCallbacks
, Аргумент к postLoad
метод LifecycleEventArgs
, Я мог видеть свойство контейнера (которое я хочу получить) в EventManager
из LifecycleEventArgs
согласно выводу дампа, но это, кажется, частная собственность, и нет getContainer()
метод в EventManager
, Ниже мой код.
service.yml
services:
ibw.jobeet.entity.job.container_aware:
class: Ibw\JobeetBundle\Entity\Job
tags:
- { name: doctrine.event_listener, event: postLoad }
ИВТ \ JobeetBundle \ Entity \ Job.php
<?php
namespace Ibw\JobeetBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\ORM\Event\LifecycleEventArgs;
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Component\HttpFoundation\File\UploadedFile;
use Symfony\Component\DependencyInjection\ContainerAware;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Ibw\JobeetBundle\Utils\Jobeet;
/**
* Job
*/
class Job
{
//....
/**
* @var Container
*/
protected $container;
public function postLoad(LifecycleEventArgs $eventArgs)
{
$entity = $eventArgs->getEntity();
$entityManager = $eventArgs->getEntityManager();
$eventManager = $entityManager->getEventManager();
echo '<pre>';
\Doctrine\Common\Util\Debug::dump($eventManager, 3);
// want to get $eventManager->container here
exit;
}
//....
}
Есть ли другой способ получить его?
Вы можете использовать сеттер-инъекцию, которая приводит к вызову предопределенного метода (setContainer()
в данном случае) с контейнером в качестве аргумента при создании службы слушателя:
services:
ibw.jobeet.entity.job.container_aware:
class: Your\Bundle\Doctrine\Event\Listener\JobListener
calls:
- [setContainer, ["@service_container"]]
tags:
- { name: doctrine.event_listener, event: postLoad }
Теперь контейнер внедряется в конструктор вашего класса слушателя:
namespace Your\Bundle\Doctrine\Event\Listener;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Doctrine\ORM\Event\LifecycleEventArgs;
class JobListener
{
/** @var ContainerInterface */
protected $container;
/**
* @param ContainerInterface @container
*/
public function setContainer(ContainerInterface $container)
{
$this->container = $container;
}
public function postLoad(LifecycleEventArgs $eventArgs)
{
$entity = $eventArgs->getEntity();
// do something with your entity here i.e.
$entity->setFoo($this->container->getParameter('foo'));
Это всего лишь пример. Пожалуйста, рассмотрите возможность внедрения только тех услуг, которые вам действительно нужны, вместо введения самого контейнера. Вы будете вознаграждены лучшей тестируемостью и производительностью.
Других решений пока нет …