Как получить объект-контейнер из LifecycleEventArgs postLoad в Entity?

Я пытаюсь внедрить объект контейнера (который доступен в контроллерах) в сущности, используя 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;
}
//....
}

Есть ли другой способ получить его?

1

Решение

Вы можете использовать сеттер-инъекцию, которая приводит к вызову предопределенного метода (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'));

Это всего лишь пример. Пожалуйста, рассмотрите возможность внедрения только тех услуг, которые вам действительно нужны, вместо введения самого контейнера. Вы будете вознаграждены лучшей тестируемостью и производительностью.

2

Другие решения

Других решений пока нет …