src/Controller/RegistrationController.php line 32

  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\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  18. use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken;
  19. class RegistrationController extends AbstractController
  20. {
  21.     private EmailVerifier $emailVerifier;
  22.     public function __construct(EmailVerifier $emailVerifier)
  23.     {
  24.         $this->emailVerifier $emailVerifier;
  25.     }
  26.     #[Route('/customer/register'name'app_customer_register')]
  27.     public function customerRegister(Request $requestUserPasswordHasherInterface $userPasswordHasherEntityManagerInterface $entityManager): Response
  28.     {
  29.         $user = new User();
  30.         $form $this->createForm(RegistrationFormType::class, $user);
  31.         $form->handleRequest($request);
  32.         if ($form->isSubmitted() && $form->isValid()) {
  33.             // encode the plain password
  34.             $user->setPassword(
  35.                 $userPasswordHasher->hashPassword(
  36.                     $user,
  37.                     $form->get('plainPassword')->getData()
  38.                 )
  39.             );
  40.             $user->setRoles(["ROLE_USER""ROLE_CUSTOMER""ROLE_NO_PROFILE"]);
  41.             $user->setEnabled(true);
  42.             $user->setIsVerified(false);
  43.             $entityManager->persist($user);
  44.             $entityManager->flush();
  45.             // generate a signed url and email it to the user
  46.             $this->emailVerifier->sendEmailConfirmation('app_customer_verify_email'$user,
  47.                 (new TemplatedEmail())
  48.                     ->from(new Address('info@izipen.gr''iziPen Mailer'))
  49.                     ->to($user->getEmail())
  50.                     ->subject('Please Confirm your Email')
  51.                     ->htmlTemplate('email/customer/confirmation.html.twig')
  52.             );
  53.             // do anything else you need here, like send an email
  54.             return $this->redirectToRoute('app_default');
  55.         }
  56.         return $this->render('registration/register.customer.html.twig', [
  57.             'registrationForm' => $form->createView(),
  58.         ]);
  59.     }
  60.     #[Route('/writer/register'name'app_writer_register')]
  61.     public function writerRegister(Request $requestUserPasswordHasherInterface $userPasswordHasherEntityManagerInterface $entityManager): Response
  62.     {
  63.         $user = new User();
  64.         $form $this->createForm(RegistrationFormType::class, $user);
  65.         $form->handleRequest($request);
  66.         if ($form->isSubmitted() && $form->isValid()) {
  67.             // encode the plain password
  68.             $user->setPassword(
  69.                 $userPasswordHasher->hashPassword(
  70.                     $user,
  71.                     $form->get('plainPassword')->getData()
  72.                 )
  73.             );
  74.             $user->setRoles(["ROLE_USER""ROLE_WRITER""ROLE_NO_PROFILE"]);
  75.             $user->setEnabled(true);
  76.             $user->setIsVerified(false);
  77.             $entityManager->persist($user);
  78.             $entityManager->flush();
  79.             // generate a signed url and email it to the user
  80.             $this->emailVerifier->sendEmailConfirmation('app_writer_verify_email'$user,
  81.                 (new TemplatedEmail())
  82.                     ->from(new Address('info@izipen.gr''iziPen Mailer'))
  83.                     ->to($user->getEmail())
  84.                     ->subject('Please Confirm your Email')
  85.                     ->htmlTemplate('email/writer/confirmation.html.twig')
  86.             );
  87.             // do anything else you need here, like send an email
  88.             return $this->redirectToRoute('app_default');
  89.         }
  90.         return $this->render('registration/register.writer.html.twig', [
  91.             'registrationForm' => $form->createView(),
  92.         ]);
  93.     }
  94.     #[Route('/customer/verify/email'name'app_customer_verify_email')]
  95.     public function verifyCustomerUserEmail(Request $requestTranslatorInterface $translatorUserRepository $userRepositoryTokenStorageInterface $tokenStorage): Response
  96.     {
  97.         $id $request->get('id');
  98.         if (null === $id) {
  99.             return $this->redirectToRoute('app_default');
  100.         }
  101.         $user $userRepository->find($id);
  102.         if (null === $user || !(in_array('ROLE_CUSTOMER'$user->getRoles(), true))) {
  103.             return $this->redirectToRoute('app_default');
  104.         }
  105.         // validate email confirmation link, sets User::isVerified=true and persists
  106.         try {
  107.             $this->emailVerifier->handleEmailConfirmation($request$user);
  108.         } catch (VerifyEmailExceptionInterface $exception) {
  109.             $this->addFlash('verify_email_error'$translator->trans($exception->getReason(), [], 'VerifyEmailBundle'));
  110.             return $this->redirectToRoute('app_default');
  111.         }
  112.         // @TODO Change the redirect on success and handle or remove the flash message in your templates
  113.         $this->addFlash('success''Your email address has been verified.');
  114.         $tokenStorage->setToken(new UsernamePasswordToken($user'customer'$user->getRoles()));
  115.         return $this->redirectToRoute('customer_profile_register');
  116.     }
  117.     #[Route('/writer/verify/email'name'app_writer_verify_email')]
  118.     public function verifyWriterUserEmail(Request $requestTranslatorInterface $translatorUserRepository $userRepositoryTokenStorageInterface $tokenStorage): Response
  119.     {
  120.         $id $request->get('id');
  121.         if (null === $id) {
  122.             return $this->redirectToRoute('app_default');
  123.         }
  124.         $user $userRepository->find($id);
  125.         if (null === $user || !(in_array('ROLE_WRITER'$user->getRoles(), true))) {
  126.             return $this->redirectToRoute('app_default');
  127.         }
  128.         // validate email confirmation link, sets User::isVerified=true and persists
  129.         try {
  130.             $this->emailVerifier->handleEmailConfirmation($request$user);
  131.         } catch (VerifyEmailExceptionInterface $exception) {
  132.             $this->addFlash('verify_email_error'$translator->trans($exception->getReason(), [], 'VerifyEmailBundle'));
  133.             return $this->redirectToRoute('app_default');
  134.         }
  135.         // @TODO Change the redirect on success and handle or remove the flash message in your templates
  136.         $this->addFlash('success''Your email address has been verified.');
  137.         $tokenStorage->setToken(new UsernamePasswordToken($user'writer'$user->getRoles()));
  138.         return $this->redirectToRoute('writer_profile_register');
  139.     }
  140. }