vendor/stof/doctrine-extensions-bundle/src/EventListener/LoggerListener.php line 41
<?php
namespace Stof\DoctrineExtensionsBundle\EventListener;
use Gedmo\Loggable\Loggable;
use Gedmo\Loggable\LoggableListener;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpKernel\Event\RequestEvent;
use Symfony\Component\HttpKernel\HttpKernelInterface;
use Symfony\Component\HttpKernel\KernelEvents;
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;
/**
* Sets the username from the security context by listening on kernel.request
*
* @author Christophe Coevoet <stof@notk.org>
*
* @phpstan-template T of Loggable|object
*/
class LoggerListener implements EventSubscriberInterface
{
private ?AuthorizationCheckerInterface $authorizationChecker;
private ?TokenStorageInterface $tokenStorage;
/** @var LoggableListener<T> */
private LoggableListener $loggableListener;
/**
* @param LoggableListener<T> $loggableListener
*/
public function __construct(LoggableListener $loggableListener, TokenStorageInterface $tokenStorage = null, AuthorizationCheckerInterface $authorizationChecker = null)
{
$this->loggableListener = $loggableListener;
$this->tokenStorage = $tokenStorage;
$this->authorizationChecker = $authorizationChecker;
}
/**
* @internal
*/
public function onKernelRequest(RequestEvent $event): void
{
if (!$event->isMainRequest()) {
return;
}
if (null === $this->tokenStorage || null === $this->authorizationChecker) {
return;
}
$token = $this->tokenStorage->getToken();
if (null !== $token && $this->authorizationChecker->isGranted('IS_AUTHENTICATED_REMEMBERED')) {
$this->loggableListener->setUsername($token);
}
}
public static function getSubscribedEvents()
{
return array(
KernelEvents::REQUEST => 'onKernelRequest',
);
}
}