src/Security/LoginAuthenticator.php line 20

  1. <?php
  2. namespace App\Security;
  3. use App\Service\PasswordService;
  4. use Symfony\Component\HttpFoundation\Request;
  5. use Symfony\Bundle\SecurityBundle\Security;
  6. use Symfony\Component\HttpFoundation\Response;
  7. use Symfony\Component\Routing\RouterInterface;
  8. use Symfony\Component\HttpFoundation\RedirectResponse;
  9. use Symfony\Component\Security\Http\Util\TargetPathTrait;
  10. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  11. use Symfony\Component\Security\Http\Authenticator\Passport\Passport;
  12. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  13. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
  14. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\CsrfTokenBadge;
  15. use Symfony\Component\Security\Http\Authenticator\AbstractLoginFormAuthenticator;
  16. use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\PasswordCredentials;
  17. class LoginAuthenticator extends AbstractLoginFormAuthenticator
  18. {
  19.     use TargetPathTrait;
  20.     public const LOGIN_ROUTE 'app_home';
  21.     private $router;
  22.     private PasswordService $passwordService;
  23.     public function __construct(private UrlGeneratorInterface $urlGeneratorRouterInterface $routerPasswordService $passwordService)
  24.     {
  25.         $this->router $router;
  26.         $this->passwordService $passwordService;
  27.     }
  28.     public function authenticate(Request $request): Passport
  29.     {
  30.         $email $request->request->get('email''');
  31.         $request->getSession()->set(Security::LAST_USERNAME$email);
  32.         return new Passport(
  33.             new UserBadge($email),
  34.             new PasswordCredentials($request->request->get('password''')),
  35.             [
  36.                 new CsrfTokenBadge('authenticate'$request->request->get('_csrf_token')),
  37.             ]
  38.         );
  39.     }
  40.     public function onAuthenticationSuccess(Request $requestTokenInterface $tokenstring $firewallName): ?Response
  41.     {
  42.         $case $this->passwordService->checkCasePassword($token->getUser());
  43.         if ($case != 'none') {
  44.             return new RedirectResponse($this->urlGenerator->generate('app_edit_password', ["case" => $case]));
  45.         } else {
  46.             $roles $token->getUser()->getRoles();
  47.             $user $token->getUser();
  48.             if (in_array('ROLE_COMPANY'$rolestrue)) {
  49.                 $company $user->getCompanyMember()->getCompany();
  50.                 if (count($company->getCompanyQuestionnaires()) > 0) {
  51.                     $redirection = new RedirectResponse($this->router->generate('app_roadmap_index'));
  52.                 } else if ($company->getCompanyLabelNR()) {
  53.                     $redirection = new RedirectResponse($this->router->generate('app_label_nr'));
  54.                 }
  55.             } elseif (in_array('ROLE_ADMIN'$rolestrue) || in_array('ROLE_BILBEA'$rolestrue)) {
  56.                 $redirection = new RedirectResponse($this->router->generate('app_backoffice'));
  57.             }
  58.             return $redirection;
  59.             // return new RedirectResponse($this->urlGenerator->generate('app_home'));
  60.         }
  61.     }
  62.     protected function getLoginUrl(Request $request): string
  63.     {
  64.         return $this->urlGenerator->generate(self::LOGIN_ROUTE);
  65.     }
  66. }