src/EventSubscriber/RequestSubscriber.php line 18

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use App\Util\FileUtils;
  4. use Monolog\Handler\StreamHandler;
  5. use Monolog\Logger;
  6. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  7. use Symfony\Component\HttpFoundation\JsonResponse;
  8. use Symfony\Component\HttpKernel\Event\ControllerEvent;
  9. use Symfony\Component\HttpKernel\Event\ResponseEvent;
  10. use Symfony\Component\HttpKernel\KernelEvents;
  11. class RequestSubscriber implements EventSubscriberInterface
  12. {
  13.     private $logger;
  14.     public function onKernelController(ControllerEvent $event)
  15.     {
  16.         $request $event->getRequest();
  17.         if(!str_contains($request->getRequestUri(), '.ico')) {
  18.             $this->getLogger()->info(sprintf("START %s: %s with %s"$request->getMethod(), $request->getRequestUri(), $request->getContent()));
  19.         }
  20.     }
  21.     public function onKernelResponse(ResponseEvent $event)
  22.     {
  23.         $request $event->getRequest();
  24.         $response $event->getResponse();
  25.         if ($response instanceof JsonResponse) {
  26.             $this->getLogger()->info(sprintf("FINISHED %s: %s with %s: Response - %s"$request->getMethod(), $request->getRequestUri(), $request->getContent(), $response->getContent()));
  27.         }
  28.     }
  29.     public static function getSubscribedEvents(): array
  30.     {
  31.         return [
  32.             KernelEvents::CONTROLLER => 'onKernelController',
  33.             KernelEvents::RESPONSE => 'onKernelResponse',
  34.         ];
  35.     }
  36.     private function getLogger()
  37.     {
  38.         if(empty($this->logger)) {
  39.             $this->logger = new Logger('request');
  40.             $logDir dirname(__DIR__2) . '/var/log/request/' date('Y/m');
  41.             FileUtils::validateDirectory($logDir);
  42.             if('prod' == $_ENV['APP_ENV']) {
  43.                 $level Logger::INFO;
  44.             } else {
  45.                 $level Logger::DEBUG;
  46.             }
  47.             $logFile $logDir DIRECTORY_SEPARATOR date('d') . '.log';
  48.             if (!is_file($logFile)) {
  49.                 touch($logFile);
  50.             }
  51.             $this->logger->pushHandler(new StreamHandler($logFile$level));
  52.         }
  53.         return $this->logger;
  54.     }
  55. }