src/Security/AdminLoginFormAuthenticator.php line 19

  1. <?php
  2. namespace App\Security;
  3. use Doctrine\ORM\EntityManagerInterface;
  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\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\Util\TargetPathTrait;
  16. class AdminLoginFormAuthenticator extends AbstractLoginFormAuthenticator
  17. {
  18.     use TargetPathTrait;
  19.     public function __construct(
  20.         private readonly EntityManagerInterface $entityManager,
  21.         private readonly UrlGeneratorInterface $urlGenerator,
  22.     ) {
  23.     }
  24.     public function onAuthenticationSuccess(Request $requestTokenInterface $token$firewallName): ?Response
  25.     {
  26.         if ($targetPath $this->getTargetPath($request->getSession(), $firewallName)) {
  27.             return new RedirectResponse($targetPath);
  28.         }
  29.         return new RedirectResponse($this->urlGenerator->generate('admin_dashboard_index'));
  30.     }
  31.     protected function getLoginUrl(Request $request): string
  32.     {
  33.         return $this->urlGenerator->generate('app_login');
  34.     }
  35.     public function authenticate(Request $request): Passport
  36.     {
  37.         $email $request->request->get('email');
  38.         $password $request->request->get('password');
  39.         $csrfToken $request->request->get('_csrf_token');
  40.         return new Passport(
  41.             new UserBadge($email),
  42.             new PasswordCredentials($password),
  43.             [
  44.                 new CsrfTokenBadge('authenticate'$csrfToken),
  45.                 (new RememberMeBadge())->enable()
  46.             ]
  47.         );
  48.     }
  49. }