src/Controller/RegistrationController.php line 37

Open in your IDE?
  1. <?php
  2. namespace App\Controller;
  3. use App\Entity\User;
  4. use App\Form\RegistrationFormType;
  5. use App\Repository\UserRepository;
  6. use App\Security\EmailVerifier;
  7. use Doctrine\ORM\EntityManagerInterface;
  8. use Symfony\Bridge\Twig\Mime\TemplatedEmail;
  9. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  10. use Symfony\Component\HttpFoundation\Request;
  11. use Symfony\Component\HttpFoundation\Response;
  12. use Symfony\Component\Mime\Address;
  13. use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
  14. use Symfony\Component\Routing\Annotation\Route;
  15. use Symfony\Contracts\Translation\TranslatorInterface;
  16. use SymfonyCasts\Bundle\VerifyEmail\Exception\VerifyEmailExceptionInterface;
  17. use Symfony\Component\Mime\Email;
  18. use Symfony\Component\Mailer\MailerInterface;
  19. use SymfonyCasts\Bundle\VerifyEmail\VerifyEmailHelperInterface;
  20. class RegistrationController extends AbstractController
  21. {
  22.     private EmailVerifier $emailVerifier;
  23.     public function __construct(EmailVerifier $emailVerifierVerifyEmailHelperInterface $helper)
  24.     {
  25.         $this->emailVerifier $emailVerifier;
  26.         $this->verifyEmailHelper $helper;
  27.     }
  28.     /**
  29.      * @Route("/creer-un-compte", name="app_register")
  30.      */
  31.     public function register(Request $requestUserPasswordHasherInterface $userPasswordHasherEntityManagerInterface $entityManagerMailerInterface $mailer): Response {
  32.         // Si l'utilisateur est déjà connecté, le rediriger vers l'accueil
  33.         if ($this->getUser()) {
  34.             return $this->redirectToRoute('app_home');
  35.         }
  36.         $user = new User();
  37.         $form $this->createForm(RegistrationFormType::class, $user);
  38.         $form->handleRequest($request);
  39.         if ($form->isSubmitted() && $form->isValid()) {
  40.             // Hachage du mot de passe
  41.             $user->setPassword(
  42.                 $userPasswordHasher->hashPassword(
  43.                     $user,
  44.                     $form->get('plainPassword')->getData()
  45.                 )
  46.             );
  47.             $user->setRoles(['ROLE_USER']);
  48.             $entityManager->persist($user);
  49.             $entityManager->flush();
  50.             // Envoi du mail de confirmation à l'utilisateur
  51.             $this->emailVerifier->sendEmailConfirmation(
  52.                 'app_verify_email',
  53.                 $user,
  54.                 (new TemplatedEmail())
  55.                     ->from(new Address('moussa@halogari.yt''HaloGari'))
  56.                     ->to($user->getEmail())
  57.                     ->subject('Veuillez confirmer votre adresse e-mail')
  58.                     ->htmlTemplate('emails/confirmation_register.html.twig')
  59.                     ->embedFromPath($this->getParameter('kernel.project_dir') . '/public/images/logo.png''logo_halogari')
  60.             );
  61.             // Envoi d’un mail d’alerte à l’admin (HTML)
  62.             $signatureComponents $this->verifyEmailHelper->generateSignature(
  63.                 'app_verify_email',
  64.                 $user->getId(),
  65.                 $user->getEmail(),
  66.                 ['id' => $user->getId()]
  67.             );
  68.             $signedUrl $signatureComponents->getSignedUrl();
  69.             $mailer->send(
  70.                 (new TemplatedEmail())
  71.                     ->from(new Address('moussa@halogari.yt''HaloGari - Notifications'))
  72.                     ->to('moussa@halogari.yt')
  73.                     ->subject('Nouvelle inscription sur HaloGari')
  74.                     ->htmlTemplate('emails/new_user.html.twig')
  75.                     ->context([
  76.                         'user' => $user,
  77.                         'signedUrl' => $signedUrl
  78.                     ])
  79.             );
  80.             return $this->redirectToRoute('registration_confirmation');
  81.         }
  82.         return $this->render('registration/register.html.twig', [
  83.             'registrationForm' => $form->createView(),
  84.         ]);
  85.     }
  86.     /**
  87.      * @Route("/verify/email", name="app_verify_email")
  88.      */
  89.     public function verifyUserEmail(Request $requestTranslatorInterface $translatorUserRepository $userRepository): Response
  90.     {
  91.         $id $request->get('id');
  92.         if (null === $id) {
  93.             return $this->redirectToRoute('app_register');
  94.         }
  95.         $user $userRepository->find($id);
  96.         if (null === $user) {
  97.             return $this->redirectToRoute('app_register');
  98.         }
  99.         // validate email confirmation link, sets User::isVerified=true and persists
  100.         try {
  101.             $this->emailVerifier->handleEmailConfirmation($request$user);
  102.         } catch (VerifyEmailExceptionInterface $exception) {
  103.             $this->addFlash('verify_email_error'$translator->trans($exception->getReason(), [], 'VerifyEmailBundle'));
  104.             return $this->redirectToRoute('app_register');
  105.         }
  106.         // @TODO Change the redirect on success and handle or remove the flash message in your templates
  107.         $this->addFlash('success''Votre adresse e-mail a été vérifiée.');
  108.         return $this->redirectToRoute('app_home');
  109.     }
  110.     /**
  111.      * @Route("/creer-un-compte/confirmation", name="registration_confirmation")
  112.      */
  113.     public function confirmation(): Response
  114.     {
  115.         return $this->render('registration/confirmation.html.twig');
  116.     }
  117. }