src/EventSubscriber/LoginSubscriber.php line 37

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use Doctrine\ORM\EntityManagerInterface;
  4. use Psr\Log\LoggerInterface;
  5. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  6. use Symfony\Component\HttpFoundation\RedirectResponse;
  7. use Symfony\Component\HttpFoundation\RequestStack;
  8. use Symfony\Component\Routing\RouterInterface;
  9. use Symfony\Component\Security\Core\Event\AuthenticationSuccessEvent;
  10. use Symfony\Component\Security\Core\Exception\CustomUserMessageAuthenticationException;
  11. use Symfony\Component\Security\Core\Security;
  12. use Symfony\Component\Security\Csrf\TokenStorage\TokenStorageInterface;
  13. use Symfony\Component\Security\Http\Event\InteractiveLoginEvent;
  14. use Symfony\Component\HttpKernel\Event\RequestEvent;
  15. use Symfony\Component\HttpKernel\Event\ResponseEvent;
  16. class LoginSubscriber implements EventSubscriberInterface
  17. {
  18.     private $em;
  19.     private $log;
  20.     private $storage;
  21.     private $router;
  22.     private $event;
  23.     public function __construct(EntityManagerInterface $emLoggerInterface $logTokenStorageInterface $storageRouterInterface $routerRequestStack  $event)
  24.     {
  25.         $this->em $em;
  26.         $this->log $log;
  27.         $this->storage $storage;
  28.         $this->router $router;
  29.         $this->event $event;
  30.     }
  31.     public function onSecurityInteractiveLogin(AuthenticationSuccessEvent  $event)
  32.     {
  33. //        $request = $event->getRequest();
  34.         $session =  $this->event->getSession();
  35. //        $captcha =  $session->get('_captcha_captcha');
  36. //        $frase = $captcha['phrase'];
  37. ////        dump($frase);
  38. ////        dump($captcha);
  39. ////        dump($session);
  40. //        dump($request);
  41. //        $req = $event->getRequest()->get('login');
  42. ////        dd($req['captcha']);
  43. //        $this->storage->setToken('','');
  44. //        $event->getRequest()->getSession()->invalidate(1);
  45. //        return new RedirectResponse($this->router->generate('app_logout'));
  46. //        $this->storage->setToken('','');
  47. //        $session->invalidate(1);
  48.         //$mes = new CustomUserMessageAuthenticationException('Ingrese el CAPTCHA correcto.');
  49.         //$session->set(Security::AUTHENTICATION_ERROR, $mes);
  50.         //return new RedirectResponse($this->router->generate('app_logout'));
  51.     }
  52.     public static function getSubscribedEvents()
  53.     {
  54.         return [
  55.             'security.authentication.success' => 'onSecurityInteractiveLogin',
  56.         ];
  57.     }
  58. }