src/Security/LoginAuthenticator.php line 22

  1. <?php
  2. namespace App\Security;
  3. use App\Entity\Referentiel\RefUser;
  4. use Symfony\Component\HttpFoundation\RedirectResponse;
  5. use Symfony\Component\HttpFoundation\Request;
  6. use Symfony\Component\HttpFoundation\Response;
  7. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  8. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  9. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\RememberMeBadge;
  10. use Symfony\Component\Security\Core\Exception\AuthenticationException;
  11. use Symfony\Component\Security\Core\Security;
  12. // use Symfony\Bundle\SecurityBundle\Security;
  13. use Symfony\Component\Security\Http\Authenticator\AbstractLoginFormAuthenticator;
  14. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\CsrfTokenBadge;
  15. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
  16. use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\PasswordCredentials;
  17. use Symfony\Component\Security\Http\Authenticator\Passport\Passport;
  18. use Symfony\Component\Security\Http\Util\TargetPathTrait;
  19. class LoginAuthenticator extends AbstractLoginFormAuthenticator
  20. {
  21.     use TargetPathTrait;
  22.     public const LOGIN_ROUTE 'app_login';
  23.     public function __construct(private UrlGeneratorInterface $urlGenerator)
  24.     {
  25.     }
  26.     public function authenticate(Request $request): Passport
  27.     {
  28.         $email $request->request->get('email''');
  29.         $security = [];
  30.         if ($request->get('_remember_me')) {
  31.             $security =  [ new CsrfTokenBadge('authenticate'$request->get('_csrf_token')), new RememberMeBadge() ];
  32.         } else {
  33.             $security =  [ new CsrfTokenBadge('authenticate'$request->get('_csrf_token'))];
  34.         }
  35.         return new Passport(
  36.             new UserBadge($email),
  37.             new PasswordCredentials($request->request->get('password''')), $security
  38.         );
  39.     }
  40.     public function onAuthenticationFailure(Request $requestAuthenticationException $exception): Response
  41.     {
  42.         $url $this->getLoginUrl($request);
  43.         return new RedirectResponse($url);
  44.     }
  45.     public function onAuthenticationSuccess(Request $requestTokenInterface $tokenstring $firewallName): ?Response
  46.     {
  47.         if ($targetPath $this->getTargetPath($request->getSession(), $firewallName)) {
  48.             return new RedirectResponse($targetPath);
  49.         }
  50.         return new RedirectResponse($this->urlGenerator->generate('app_main'));
  51.     }
  52.     protected function getLoginUrl(Request $request): string
  53.     {
  54.         return $this->urlGenerator->generate(self::LOGIN_ROUTE);
  55.     }
  56. }