vendor/appaydin/pd-activity/Listener/RequestListener.php line 35

Open in your IDE?
  1. <?php
  2. /**
  3.  * This file is part of the pd-admin pd-activity package.
  4.  *
  5.  * @package     pd-activity
  6.  * @license     LICENSE
  7.  * @author      Ramazan APAYDIN <apaydin541@gmail.com>
  8.  * @link        https://github.com/appaydin/pd-activity
  9.  */
  10. namespace Pd\ActivityBundle\Listener;
  11. use Pd\ActivityBundle\Message\HttpLog;
  12. use Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface;
  13. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  14. use Symfony\Component\HttpKernel\Event\ResponseEvent;
  15. use Symfony\Component\HttpKernel\KernelEvents;
  16. use Symfony\Component\Messenger\MessageBusInterface;
  17. use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  18. class RequestListener implements EventSubscriberInterface
  19. {
  20.     public function __construct(
  21.         private ParameterBagInterface $bag,
  22.         private TokenStorageInterface $tokenStorage,
  23.         private MessageBusInterface $bus
  24.     )
  25.     {
  26.     }
  27.     /**
  28.      * Listen Request.
  29.      */
  30.     public function onKernelResponse(ResponseEvent $event): void
  31.     {
  32.         $request $event->getRequest();
  33.         if ($event->isMainRequest()) {
  34.             if (!$this->bag->get('pd_activity.log_request') ||
  35.                 \in_array($request->getMethod(), $this->bag->get('pd_activity.request_exclude_methods'), true)) {
  36.                 return;
  37.             }
  38.             // Check Uri Match
  39.             if ($this->bag->get('pd_activity.request_match_uri') &&
  40.                 !preg_match("{{$this->bag->get('pd_activity.request_match_uri')}}"$request->getRequestUri())) {
  41.                 return;
  42.             }
  43.             // Check Ajax Request
  44.             if (!$this->bag->get('pd_activity.log_ajax_request') && $request->isXmlHttpRequest()) {
  45.                 return;
  46.             }
  47.             // Check Content Disposion
  48.             if ($event->getResponse()->headers->has('Content-Disposition')){
  49.                 return;
  50.             }
  51.             // Send JOB
  52.             $this->bus->dispatch(new HttpLog(
  53.                 $request->getMethod(),
  54.                 $request->getRequestUri(),
  55.                 $request->request->all(),
  56.                 $request->getClientIp(),
  57.                 $request->getLocale(),
  58.                 $this->tokenStorage->getToken()?->getUser()->getId()
  59.             ));
  60.         }
  61.     }
  62.     public static function getSubscribedEvents(): array
  63.     {
  64.         return [
  65.             KernelEvents::RESPONSE => [['onKernelResponse']],
  66.         ];
  67.     }
  68. }