src/EventSubscriber/LogoutSubscriber.php line 34

Open in your IDE?
  1. <?php
  2. /*
  3.  * This file is part of the nellapp-core package.
  4.  *
  5.  * (c) Benjamin Georgeault
  6.  *
  7.  * For the full copyright and license information, please view the LICENSE
  8.  * file that was distributed with this source code.
  9.  */
  10. namespace App\EventSubscriber;
  11. use App\Entity\Account\User;
  12. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  13. use Symfony\Component\HttpFoundation\RedirectResponse;
  14. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  15. use Symfony\Component\Security\Http\Event\LogoutEvent;
  16. /**
  17.  * Class LogoutSubscriber
  18.  *
  19.  * @author Benjamin Georgeault
  20.  */
  21. class LogoutSubscriber implements EventSubscriberInterface
  22. {
  23.     public static function getSubscribedEvents(): array
  24.     {
  25.         return [
  26.             LogoutEvent::class => 'logout',
  27.         ];
  28.     }
  29.     public function logout(LogoutEvent $event): void
  30.     {
  31.         if (null === $this->getUser($event->getToken())) {
  32.             return;
  33.         }
  34.         $request $event->getRequest();
  35.         if (!$request->query->has('target')) {
  36.             return;
  37.         }
  38.         if (!filter_var($target $request->query->get('target'), FILTER_VALIDATE_URL)) {
  39.             return;
  40.         }
  41.         $event->setResponse(new RedirectResponse($target));
  42.     }
  43.     private function getUser(TokenInterface $token): ?User
  44.     {
  45.         if (($user $token->getUser()) instanceof User) {
  46.             return $user;
  47.         }
  48.         return null;
  49.     }
  50. }