src/EventSubscriber/KernelRequestSubscriber.php line 37

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\EventSubscriber;
  4. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  5. use Symfony\Component\HttpFoundation\RequestStack;
  6. use Symfony\Component\HttpFoundation\Response;
  7. use Symfony\Component\HttpKernel\Event\RequestEvent;
  8. use Symfony\Component\HttpKernel\KernelEvents;
  9. use Twig\Environment as TwigEnvironment;
  10. class KernelRequestSubscriber implements EventSubscriberInterface
  11. {
  12.     private TwigEnvironment $twig;
  13.     protected $requestStack;
  14.     public function __construct(TwigEnvironment $twigRequestStack $requestStack)
  15.     {
  16.         $this->twig $twig;
  17.         $this->requestStack $requestStack;
  18.     }
  19.     /**
  20.      * {@inheritdoc}
  21.      */
  22.     public static function getSubscribedEvents(): array
  23.     {
  24.         return [
  25.             KernelEvents::REQUEST => [
  26.                 ['onMaintenance'\PHP_INT_MAX 1000],
  27.             ],
  28.         ];
  29.     }
  30.     public function onMaintenance(RequestEvent $event): void
  31.     {
  32.         /** @var bool $isMaintenance */
  33.         $isMaintenance \filter_var($_ENV['MAINTENANCE_MODE'] ?? '0'\FILTER_VALIDATE_BOOLEAN);
  34.         $isCli \PHP_SAPI === 'cli';
  35.         $ip $this->requestStack->getCurrentRequest()->getClientIp();
  36.         if ($ip !== $_ENV['MAINTENANCE_AUTHORIZED_IP']) {
  37.             if ($isMaintenance && !$isCli) {
  38.                 $event->setResponse(new Response(
  39.                     $this->twig->render('maintenance/maintenance.html.twig'),
  40.                     Response::HTTP_SERVICE_UNAVAILABLE,
  41.                 ));
  42.                 $event->stopPropagation();
  43.             }
  44.         }
  45.     }
  46. }