Sto provando a inserire l'utente attualmente connesso in un listener. Il mio obiettivo è scrivere un \ DateTime() corrente nella colonna 'last_active' della mia tabella 'demo_user' ogni volta che l'utente esegue un'azione (entrambi i metodi this non funzionano per me).Symfony2 - Inietta l'utente attualmente connesso a un listener
app/config/config.yml
# ...
services:
demo.listener:
class: Demo\UserBundle\EventListener\ActivityWatcher.php
arguments: ['@service_container']
tags:
- { name: doctrine.event_listener, event: postLoad }
src/Demo/UserBundle/EventListener/ActivityWatcher.php
namespace Demo\UserBundle\EventListener;
use Doctrine\ORM\Event\LifecycleEventArgs;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Demo\UserBundle\Entity\DemoUser;
class ActivityWatcher
{
protected $container;
public function __construct(ContainerInterface $container)
{
$this->container = $container;
}
public function postLoad(LifecycleEventArgs $args)
{
$entity = $args->getEntity();
$entityManager = $args->getEntityManager();
if ($entity instanceof DemoUser) {
$token = $this->container->get('security.context')->getToken();
$user = $token->getUser();
if($entity->getId() == $user->getId()) {
$entity->setLastActivity(new \DateTime());
$entityManager->persist($entity);
$entityManager->flush();
}
}
}
}
Ma il $ token è sempre vuoto ... UPDATE: non ha menzionato, che ho effettuato l'accesso autenticato e quando questo accade
FatalErrorException: Error: Call to a member function getUser()
on a non-object ...
Qualche idea? Arrgh, grazie, Jan
UPDATE:
Ho provato anche solo per iniettare il security.context:
arguments: ["@security.context"]
ma ottenuto un
ServiceCircularReferenceException: Circular reference detected for "doctrine.orm.default_entity_manager", path: "doctrine.orm.default_entity_manager -> doctrine.dbal.default_connection -> wwk.listener -> security.context -> security.authentication.manager -> security.user.provider.concrete.administrators".
Non una soluzione ellegant ma: http://stackoverflow.com/questions/7561013/injecting- securitycontext-services-in-a-listener-class-in-symfony2-cause-circ –
Penso che sto esattamente cercando di farlo al momento, ma senza alcun successo – jxp315
Il link fornito da @JovanPerovic va bene. La risposta corretta è questa: http://stackoverflow.com/questions/7561013/injecting-securitycontext-into-a-listener-prepersist-or-preupdate-in-symfony2-to#26011863 – webDEVILopers