src/EventSubscriber/RequestSubscriber.php line 37

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  4. use Symfony\Component\HttpKernel\Event\RequestEvent;
  5. use Symfony\Component\HttpKernel\KernelEvents;
  6. use Symfony\Component\HttpFoundation\RequestStack;
  7. use Symfony\Component\Security\Core\Security;
  8. use Psr\Log\LoggerInterface;
  9. use Symfony\Component\Serializer\SerializerInterface;
  10. class RequestSubscriber implements EventSubscriberInterface {
  11.     private $requestStack;
  12.     private $logger;
  13.     private $security;
  14.     private $serializer;
  15.     public function __construct(RequestStack $requestStackLoggerInterface $loggerSecurity $securitySerializerInterface $serializer) {
  16.         $this->requestStack $requestStack;
  17.         $this->logger $logger;
  18.         $this->security $security;
  19.         $this->serializer $serializer;
  20.     }
  21.     /**
  22.      * 
  23.      * @return type
  24.      */
  25.     public static function getSubscribedEvents(): array {
  26.         return [
  27.             KernelEvents::REQUEST => 'onKernelRequest',
  28.         ];
  29.     }
  30.     public function onKernelRequest(RequestEvent $event) {
  31.         $request $event->getRequest();
  32.         $this->logger->info(sprintf('Request GET parameters: %s'json_encode($request->query->all())));
  33.         $this->logger->info(sprintf('Request POST parameters: %s'json_encode($request->request->all())));
  34.         $this->logger->info(sprintf('Request ATTRIBUTES parameters: %s'json_encode($request->attributes->all())));
  35.         $this->logger->info(sprintf('Request COOKIES parameters: %s'json_encode($request->cookies->all())));
  36.         $this->logger->info(sprintf('Request HEADERS parameters: %s'json_encode($request->headers->all())));
  37.         // Retrieve the logged-in user (if any)
  38.         $user $this->security->getUser();
  39.         // Access the user details
  40.         if ($user !== null) {
  41.             $serializedUser $this->serializer->serialize($user'json', ['groups' => 'user']);
  42.             $this->logger->info('User logged in: ' $serializedUser);
  43.         }
  44.         $this->requestStack->push($request);
  45.     }
  46. }