src/Security/LoginFormAuthenticator.php line 21

Open in your IDE?
  1. <?php
  2. namespace App\Security;
  3. use App\Repository\UserRepository;
  4. use Symfony\Component\HttpFoundation\RedirectResponse;
  5. use Symfony\Component\HttpFoundation\Request;
  6. use Symfony\Component\HttpFoundation\Response;
  7. use Symfony\Component\Routing\RouterInterface;
  8. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  9. use Symfony\Component\Security\Http\Authenticator\AbstractLoginFormAuthenticator;
  10. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\CsrfTokenBadge;
  11. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\RememberMeBadge;
  12. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
  13. use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\PasswordCredentials;
  14. use Symfony\Component\Security\Http\Authenticator\Passport\Passport;
  15. use Symfony\Component\Security\Http\Authenticator\Passport\PassportInterface;
  16. use Symfony\Component\Security\Http\Util\TargetPathTrait;
  17. class LoginFormAuthenticator extends AbstractLoginFormAuthenticator
  18. {
  19.     use TargetPathTrait;
  20.     public const LOGIN_ROUTE 'app_login';
  21.     private UserRepository $userRepository;
  22.     private RouterInterface $router;
  23.     public function __construct(UserRepository $userRepositoryRouterInterface $router)
  24.     {
  25.         $this->userRepository $userRepository;
  26.         $this->router $router;
  27.     }
  28.     public function authenticate(Request $request): PassportInterface
  29.     {
  30.         $email $request->request->get('email');
  31.         $password $request->request->get('password');
  32.         return new Passport(
  33.             new UserBadge($email),
  34.             new PasswordCredentials($password),
  35.             [
  36.                 new CsrfTokenBadge(
  37.                     'authenticate',
  38.                     $request->request->get('_csrf_token')
  39.                 ),
  40.                 new RememberMeBadge(),
  41.             ]
  42.         );
  43.     }
  44.     public function onAuthenticationSuccess(Request $requestTokenInterface $tokenstring $firewallName): ?Response
  45.     {
  46.         if ($target $this->getTargetPath($request->getSession(), $firewallName)) {
  47.             return new RedirectResponse($target);
  48.         }
  49.         return new RedirectResponse(
  50.             $this->router->generate('app_home')
  51.         );
  52.     }
  53.     protected function getLoginUrl(Request $request): string
  54.     {
  55.         return $this->router->generate(self::LOGIN_ROUTE);
  56.     }
  57. }