src/Security/PmiAuthenticator.php line 19

  1. <?php
  2. namespace App\Security;
  3. use App\Entity\Pmi\User;
  4. use Doctrine\ORM\EntityManagerInterface;
  5. use Symfony\Component\HttpFoundation\RedirectResponse;
  6. use Symfony\Component\HttpFoundation\Request;
  7. use Symfony\Component\HttpFoundation\Response;
  8. use Symfony\Component\HttpFoundation\Session\Session;
  9. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  10. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  11. use Symfony\Component\Security\Core\Security;
  12. use Symfony\Component\Security\Http\Authenticator\AbstractLoginFormAuthenticator;
  13. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
  14. use Symfony\Component\Security\Http\Authenticator\Passport\SelfValidatingPassport;
  15. use Symfony\Component\Security\Http\Util\TargetPathTrait;
  16. class PmiAuthenticator extends AbstractLoginFormAuthenticator
  17. {
  18.     use TargetPathTrait;
  19.     public const LOGIN_ROUTE 'app_login';
  20.     private UrlGeneratorInterface $urlGenerator;
  21.     private EntityManagerInterface $entityManager;
  22.     public function __construct(UrlGeneratorInterface $urlGeneratorEntityManagerInterface $pmiEntityManager)
  23.     {
  24.         $this->urlGenerator $urlGenerator;
  25.         $this->entityManager $pmiEntityManager;
  26.     }
  27.     public function authenticate(Request $request): SelfValidatingPassport
  28.     {
  29.         $code $request->request->get('_code''');
  30.         $request->getSession()->set(Security::LAST_USERNAME$code);
  31.         return new SelfValidatingPassport(
  32.             new UserBadge($code)
  33.         );
  34.     }
  35.     public function onAuthenticationSuccess(Request $requestTokenInterface $tokenstring $firewallName): ?Response
  36.     {
  37.         $this->setUserLocale(
  38.             user$token->getUser(),
  39.             session$request->getSession()
  40.         );
  41.         if ($targetPath $this->getTargetPath($request->getSession(), $firewallName)) {
  42.             return new RedirectResponse($targetPath);
  43.         }
  44.         return new RedirectResponse($this->urlGenerator->generate('app_dashboard'));
  45.     }
  46.     protected function getLoginUrl(Request $request): string
  47.     {
  48.         return $this->urlGenerator->generate(self::LOGIN_ROUTE);
  49.     }
  50.     private function setUserLocale(User $userSession $session): void
  51.     {
  52.         $conn $this->entityManager->getConnection();
  53.         $stmt "
  54.             SELECT PACNUM02
  55.             FROM PARAM
  56.             WHERE PAKTSOC = 'UTI' AND PAKTNOPAR = '974' AND PAKTCODE = '" $user->getCode() . "'
  57.         ";
  58.         $locale $conn->fetchAllAssociative($stmt)[0]['PACNUM02'];
  59.         if ($locale == 1) {
  60.             $session->set('_locale''fr');
  61.         } else {
  62.             $session->set('_locale''en');
  63.         }
  64.     }
  65. }