src/Security/AppAuthenticator.php line 20

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