<?php
namespace App\EventSubscriber;
use App\Entity\User;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpKernel\Event\RequestEvent;
use Symfony\Component\HttpKernel\KernelEvents;
use Symfony\Component\Security\Core\Security;
class RequestSubscriber implements EventSubscriberInterface
{
private $security;
public function __construct(Security $security)
{
$this->security = $security;
}
public function onKernelController(RequestEvent $event): void
{
if (!$event->isMainRequest()) {
return;
}
/** @var User $user */
if (!$user = $this->security->getUser()) {
return;
}
if ($user->getStatus() === User::STATUS_DISABLED) {
$event->setResponse(new RedirectResponse('/logout'));
}
}
public static function getSubscribedEvents(): array
{
return [
KernelEvents::REQUEST => 'onKernelController',
];
}
}