src/Security/SecurityAuthenticator.php line 23

  1. <?php
  2. namespace App\Security;
  3. use App\Entity\Main\Administrator;
  4. use App\Repository\AdministratorRepository;
  5. use Doctrine\ORM\EntityManagerInterface;
  6. use Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface;
  7. use Symfony\Component\HttpFoundation\RedirectResponse;
  8. use Symfony\Component\HttpFoundation\Request;
  9. use Symfony\Component\HttpFoundation\Response;
  10. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  11. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  12. use Symfony\Component\Security\Core\Exception\AuthenticationException;
  13. use Symfony\Component\Security\Core\Security;
  14. use Symfony\Component\Security\Http\Authenticator\AbstractLoginFormAuthenticator;
  15. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\CsrfTokenBadge;
  16. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
  17. use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\PasswordCredentials;
  18. use Symfony\Component\Security\Http\Authenticator\Passport\Passport;
  19. use Symfony\Component\Security\Http\Util\TargetPathTrait;
  20. final class SecurityAuthenticator extends AbstractLoginFormAuthenticator
  21. {
  22.     use TargetPathTrait;
  23.     public const LOGIN_ROUTE 'login';
  24.     public function __construct(
  25.         private UrlGeneratorInterface $urlGenerator,
  26.         private ParameterBagInterface $parameterBag,
  27.         private AdministratorRepository $userRepository,
  28.         private EntityManagerInterface $manager
  29.     ) {
  30.     }
  31.     public function authenticate(Request $request): Passport
  32.     {
  33.         $username $request->request->get('email''');
  34.         $password $request->request->get('password''');
  35.         assert(is_string($username) && is_string($password));
  36.         $request->getSession()->set(Security::LAST_USERNAME$username);
  37.         /** @var string $token */
  38.         $token $request->get('_csrf_token');
  39.         return new Passport(
  40.             new UserBadge($username),
  41.             new PasswordCredentials($password),
  42.             [
  43.                 new CsrfTokenBadge('authenticate'$token),
  44.             ]
  45.         );
  46.     }
  47.     public function onAuthenticationSuccess(Request $requestTokenInterface $tokenstring $firewallName): ?Response
  48.     {
  49.         $user $token->getUser();
  50.         if (!$user instanceof Administrator) {
  51.             throw new \RuntimeException('Invalid user class '.($user $user::class : 'null'));
  52.         }
  53.         if ('ROLE_CONTENT_MANAGER' === $user->getRole()) {
  54.             return new RedirectResponse($this->urlGenerator->generate('admin_app_market_content_news_list'));
  55.         }
  56.         if ($targetPath $this->getTargetPath($request->getSession(), $firewallName)) {
  57.             return new RedirectResponse($targetPath);
  58.         }
  59.         return new RedirectResponse($this->urlGenerator->generate('sonata_admin_dashboard'));
  60.     }
  61.     /**
  62.      * Override to change what happens after a bad username/password is submitted.
  63.      */
  64.     public function onAuthenticationFailure(Request $requestAuthenticationException $exception): Response
  65.     {
  66.         if ($request->hasSession()) {
  67.             $request->getSession()->set(Security::AUTHENTICATION_ERROR$exception);
  68.         }
  69.         $url $this->getLoginUrl($request);
  70.         return new RedirectResponse($url);
  71.     }
  72.     protected function getLoginUrl(Request $request): string
  73.     {
  74.         return $this->urlGenerator->generate(self::LOGIN_ROUTE);
  75.     }
  76. }