src/Controller/Public/RegistrationController.php line 31
<?phpnamespace App\Controller\Public;use App\Entity\User;use App\Form\RegistrationFormType;use App\Repository\UserRepository;use App\Security\EmailVerifier;use Doctrine\ORM\EntityManagerInterface;use Symfony\Bridge\Twig\Mime\TemplatedEmail;use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;use Symfony\Component\HttpFoundation\Request;use Symfony\Component\HttpFoundation\Response;use Symfony\Component\Mime\Address;use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;use Symfony\Component\Routing\Annotation\Route;use Symfony\Contracts\Translation\TranslatorInterface;use Symfony\UX\Turbo\TurboBundle;use SymfonyCasts\Bundle\VerifyEmail\Exception\VerifyEmailExceptionInterface;class RegistrationController extends AbstractController{private EmailVerifier $emailVerifier;public function __construct(EmailVerifier $emailVerifier){$this->emailVerifier = $emailVerifier;}#[Route('/inscription', name: 'register')]public function register(Request $request, UserPasswordHasherInterface $userPasswordHasher, EntityManagerInterface $entityManager): Response{if ($this->isGranted('ROLE_ADMIN')) {return $this->redirectToRoute('app_admin_dashboard_index');} elseif ($this->isGranted('ROLE_CLIENT')) {return $this->redirectToRoute('app_client_dashboard');} elseif ($this->isGranted('ROLE_USER') && $this->getUser()->isVerified() === false) {return $this->redirectToRoute('app_public_unverified_user');} elseif ($this->isGranted('ROLE_USER') && $this->getUser()->isVerified() === true) {return $this->redirectToRoute('app_public_awaiting_validation_user');}$user = new User();$form = $this->createForm(RegistrationFormType::class, $user);$form->handleRequest($request);if ($form->isSubmitted() && $form->isValid()) {// encode the plain password$user->setPassword($userPasswordHasher->hashPassword($user,$form->get('plainPassword')->getData()));$entityManager->persist($user);$entityManager->flush();// generate a signed url and email it to the user$this->emailVerifier->sendEmailConfirmation('app_public_verify_email', $user,(new TemplatedEmail())->from(new Address('eric@estorik.com', 'Diag'))->to($user->getEmail())->subject('Veuillez confirmer adresse e-mail')->htmlTemplate('registration/confirmation_email.html.twig'));// do anything else you need here, like send an emailif (TurboBundle::STREAM_FORMAT === $request->getPreferredFormat() && $request->getRealMethod() === Request::METHOD_POST) {$request->setRequestFormat(TurboBundle::STREAM_FORMAT);return $this->render('registration/message_check_email.stream.html.twig');}}if (TurboBundle::STREAM_FORMAT === $request->getPreferredFormat() && $request->getRealMethod() === Request::METHOD_POST) {$request->setRequestFormat(TurboBundle::STREAM_FORMAT);return $this->renderForm('registration/register.stream.html.twig', ['form' => $form,]);}return $this->renderForm('registration/register.html.twig', ['form' => $form,]);}#[Route('/verify/email', name: 'verify_email')]public function verifyUserEmail(Request $request, TranslatorInterface $translator, UserRepository $userRepository): Response{$id = $request->get('id');if (null === $id) {return $this->redirectToRoute('app_public_register');}$user = $userRepository->find($id);if (null === $user) {return $this->redirectToRoute('app_public_register');}// validate email confirmation link, sets User::isVerified=true and persiststry {$this->emailVerifier->handleEmailConfirmation($request, $user);} catch (VerifyEmailExceptionInterface $exception) {$this->addFlash('verify_email_error', $translator->trans($exception->getReason(), [], 'VerifyEmailBundle'));return $this->redirectToRoute('app_public_register');}// @TODO Change the redirect on success and handle or remove the flash message in your templates$this->addFlash('success', 'Your email address has been verified.');return $this->redirectToRoute('app_public_login');}}