src/Controller/Security/ResetPasswordController.php line 35

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Controller\Security;
  4. use App\Entity\Security\User;
  5. use App\Form\Security\ChangePasswordFormType;
  6. use App\Form\Security\ResetPasswordRequestFormType;
  7. use App\Service\Mailer\Mailer;
  8. use Doctrine\ORM\EntityManagerInterface;
  9. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  10. use Symfony\Component\HttpFoundation\RedirectResponse;
  11. use Symfony\Component\HttpFoundation\Request;
  12. use Symfony\Component\HttpFoundation\Response;
  13. use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
  14. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  15. use Symfony\Contracts\Translation\TranslatorInterface;
  16. use SymfonyCasts\Bundle\ResetPassword\Controller\ResetPasswordControllerTrait;
  17. use SymfonyCasts\Bundle\ResetPassword\Exception\ResetPasswordExceptionInterface;
  18. use SymfonyCasts\Bundle\ResetPassword\ResetPasswordHelperInterface;
  19. class ResetPasswordController extends AbstractController
  20. {
  21.     use ResetPasswordControllerTrait;
  22.     public function __construct(
  23.         private ResetPasswordHelperInterface $resetPasswordHelper,
  24.         private EntityManagerInterface $entityManager,
  25.         private Mailer $mailer,
  26.         private UrlGeneratorInterface $urlGenerator,
  27.     ) {
  28.     }
  29.     public function request(Request $request): Response
  30.     {
  31.         $form $this->createForm(ResetPasswordRequestFormType::class);
  32.         $form->handleRequest($request);
  33.         if ($form->isSubmitted() && $form->isValid()) {
  34.             return $this->processSendingPasswordResetEmail(
  35.                 $form->get('email')->getData(),
  36.             );
  37.         }
  38.         return $this->render('Security/Emails/request.html.twig', [
  39.             'requestForm' => $form->createView(),
  40.         ]);
  41.     }
  42.     public function checkEmail(): Response
  43.     {
  44.         if (null === ($resetToken $this->getTokenObjectFromSession())) {
  45.             $resetToken $this->resetPasswordHelper->generateFakeResetToken();
  46.         }
  47.         return $this->render('Security/ResetPassword/check_email.html.twig', [
  48.             'resetToken' => $resetToken,
  49.         ]);
  50.     }
  51.     public function reset(Request $requestUserPasswordHasherInterface $userPasswordHasherTranslatorInterface $translatorstring $token null): Response
  52.     {
  53.         if (null !== $token) {
  54.             $this->storeTokenInSession($token);
  55.             return $this->redirectToRoute('foxorders_security_reset_password_reset');
  56.         }
  57.         $token $this->getTokenFromSession();
  58.         if (null === $token) {
  59.             throw $this->createNotFoundException($translator->trans('app.app.global.user.password.reset.messages.token_not_found'));
  60.         }
  61.         try {
  62.             $user $this->resetPasswordHelper->validateTokenAndFetchUser($token);
  63.         } catch (ResetPasswordExceptionInterface $e) {
  64.             $this->addFlash('reset_password_error'sprintf(
  65.                 '%s - %s',
  66.                 $translator->trans(ResetPasswordExceptionInterface::MESSAGE_PROBLEM_VALIDATE, [], 'ResetPasswordBundle'),
  67.                 $translator->trans($e->getReason(), [], 'ResetPasswordBundle')
  68.             ));
  69.             return $this->redirectToRoute('foxorders_security_reset_password_request');
  70.         }
  71.         $form $this->createForm(ChangePasswordFormType::class);
  72.         $form->handleRequest($request);
  73.         if ($form->isSubmitted()) {
  74.             $this->resetPasswordHelper->removeResetRequest($token);
  75.             $encodedPassword $userPasswordHasher->hashPassword(
  76.                 $user,
  77.                 $form->get('plainPassword')->getData()
  78.             );
  79.             $user->setPassword($encodedPassword);
  80.             $this->entityManager->flush();
  81.             $this->cleanSessionAfterReset();
  82.             return $this->redirectToRoute('foxorders_dashboard');
  83.         }
  84.         return $this->render('Security/ResetPassword/reset.html.twig', [
  85.             'resetForm' => $form->createView(),
  86.         ]);
  87.     }
  88.     private function processSendingPasswordResetEmail(string $emailFormData): RedirectResponse
  89.     {
  90.         $user $this->entityManager->getRepository(User::class)->findOneBy([
  91.             'email' => $emailFormData,
  92.         ]);
  93.         if (!$user) {
  94.             return $this->redirectToRoute('foxorders_security_reset_password_check_email');
  95.         }
  96.         try {
  97.             $resetToken $this->resetPasswordHelper->generateResetToken($user);
  98.             $url $this->urlGenerator->generate('foxorders_security_reset_password_reset', ['token' => $resetToken->getToken()], UrlGeneratorInterface::ABSOLUTE_URL);
  99.             $this->mailer->sendResetPasswordMail($usercompact('url'));
  100.             $this->setTokenObjectInSession($resetToken);
  101.         } catch (ResetPasswordExceptionInterface $e) {
  102.             return $this->redirectToRoute('foxorders_security_reset_password_check_email');
  103.         }
  104.         return $this->redirectToRoute('foxorders_security_reset_password_check_email');
  105.     }
  106. }