vendor/stof/doctrine-extensions-bundle/src/EventListener/LoggerListener.php line 34

Open in your IDE?
  1. <?php
  2. namespace Stof\DoctrineExtensionsBundle\EventListener;
  3. use Gedmo\Loggable\LoggableListener;
  4. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  5. use Symfony\Component\HttpKernel\Event\RequestEvent;
  6. use Symfony\Component\HttpKernel\HttpKernelInterface;
  7. use Symfony\Component\HttpKernel\KernelEvents;
  8. use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  9. use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;
  10. /**
  11.  * Sets the username from the security context by listening on kernel.request
  12.  *
  13.  * @author Christophe Coevoet <stof@notk.org>
  14.  */
  15. class LoggerListener implements EventSubscriberInterface
  16. {
  17.     private $authorizationChecker;
  18.     private $tokenStorage;
  19.     private $loggableListener;
  20.     public function __construct(LoggableListener $loggableListenerTokenStorageInterface $tokenStorage nullAuthorizationCheckerInterface $authorizationChecker null)
  21.     {
  22.         $this->loggableListener $loggableListener;
  23.         $this->tokenStorage $tokenStorage;
  24.         $this->authorizationChecker $authorizationChecker;
  25.     }
  26.     /**
  27.      * @internal
  28.      */
  29.     public function onKernelRequest(RequestEvent $event)
  30.     {
  31.         if (HttpKernelInterface::MASTER_REQUEST !== $event->getRequestType()) {
  32.             return;
  33.         }
  34.         if (null === $this->tokenStorage || null === $this->authorizationChecker) {
  35.             return;
  36.         }
  37.         $token $this->tokenStorage->getToken();
  38.         if (null !== $token && $this->authorizationChecker->isGranted('IS_AUTHENTICATED_REMEMBERED')) {
  39.             $this->loggableListener->setUsername($token);
  40.         }
  41.     }
  42.     public static function getSubscribedEvents()
  43.     {
  44.         return array(
  45.             KernelEvents::REQUEST => 'onKernelRequest',
  46.         );
  47.     }
  48. }