src/EventSubscriber/UserSystem/LogoutDisabledUserSubscriber.php line 69

Open in your IDE?
  1. <?php
  2. /**
  3.  * This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony).
  4.  *
  5.  * Copyright (C) 2019 - 2020 Jan Böhmer (https://github.com/jbtronics)
  6.  *
  7.  * This program is free software: you can redistribute it and/or modify
  8.  * it under the terms of the GNU Affero General Public License as published
  9.  * by the Free Software Foundation, either version 3 of the License, or
  10.  * (at your option) any later version.
  11.  *
  12.  * This program is distributed in the hope that it will be useful,
  13.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  15.  * GNU Affero General Public License for more details.
  16.  *
  17.  * You should have received a copy of the GNU Affero General Public License
  18.  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
  19.  */
  20. declare(strict_types=1);
  21. /**
  22.  * This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony).
  23.  *
  24.  * Copyright (C) 2019 Jan Böhmer (https://github.com/jbtronics)
  25.  *
  26.  * This program is free software; you can redistribute it and/or
  27.  * modify it under the terms of the GNU General Public License
  28.  * as published by the Free Software Foundation; either version 2
  29.  * of the License, or (at your option) any later version.
  30.  *
  31.  * This program is distributed in the hope that it will be useful,
  32.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  33.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  34.  * GNU General Public License for more details.
  35.  *
  36.  * You should have received a copy of the GNU General Public License
  37.  * along with this program; if not, write to the Free Software
  38.  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
  39.  */
  40. namespace App\EventSubscriber\UserSystem;
  41. use App\Entity\UserSystem\User;
  42. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  43. use Symfony\Component\HttpFoundation\RedirectResponse;
  44. use Symfony\Component\HttpKernel\Event\RequestEvent;
  45. use Symfony\Component\HttpKernel\KernelEvents;
  46. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  47. use Symfony\Component\Security\Core\Security;
  48. /**
  49.  * This subscriber is used to log out a disabled user, as soon as he to do an request.
  50.  * It is not possible for him to login again, afterwards.
  51.  */
  52. final class LogoutDisabledUserSubscriber implements EventSubscriberInterface
  53. {
  54.     private $security;
  55.     private $urlGenerator;
  56.     public function __construct(Security $securityUrlGeneratorInterface $urlGenerator)
  57.     {
  58.         $this->security $security;
  59.         $this->urlGenerator $urlGenerator;
  60.     }
  61.     public function onRequest(RequestEvent $event): void
  62.     {
  63.         $user $this->security->getUser();
  64.         if ($user instanceof User && $user->isDisabled()) {
  65.             //Redirect to login
  66.             $response = new RedirectResponse($this->urlGenerator->generate('logout'));
  67.             $event->setResponse($response);
  68.         }
  69.     }
  70.     /**
  71.      * Returns an array of event names this subscriber wants to listen to.
  72.      *
  73.      * The array keys are event names and the value can be:
  74.      *
  75.      *  * The method name to call (priority defaults to 0)
  76.      *  * An array composed of the method name to call and the priority
  77.      *  * An array of arrays composed of the method names to call and respective
  78.      *    priorities, or 0 if unset
  79.      *
  80.      * For instance:
  81.      *
  82.      *  * ['eventName' => 'methodName']
  83.      *  * ['eventName' => ['methodName', $priority]]
  84.      *  * ['eventName' => [['methodName1', $priority], ['methodName2']]]
  85.      *
  86.      * @return array The event names to listen to
  87.      */
  88.     public static function getSubscribedEvents(): array
  89.     {
  90.         return [KernelEvents::REQUEST => 'onRequest'];
  91.     }
  92. }