src/Controller/SecurityController.php line 47

  1. <?php
  2. namespace Cms\Controller;
  3. use Cms\Entity\User;
  4. use Cms\Form\RegistrationFormType;
  5. use Cms\Repository\UserRepository;
  6. use Cms\Security\EmailVerifier\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\Component\Security\Http\Authentication\AuthenticationUtils;
  16. use SymfonyCasts\Bundle\VerifyEmail\Exception\VerifyEmailExceptionInterface;
  17. class SecurityController extends AbstractController
  18. {
  19.     private EmailVerifier $emailVerifier;
  20.     public function __construct(EmailVerifier $emailVerifier)
  21.     {
  22.         $this->emailVerifier $emailVerifier;
  23.     }
  24.     #[Route('/login'name'cms_security_login'methods: ['GET''POST'])]
  25.     public function login(AuthenticationUtils $authenticationUtils): Response
  26.     {
  27.         $lastUsername $authenticationUtils->getLastUsername();
  28.         $lastError $authenticationUtils->getLastAuthenticationError();
  29.         return $this->render('security/login.html.twig', [
  30.             'last_username' => $lastUsername,
  31.             'error' => $lastError,
  32.         ]);
  33.     }
  34.     #[Route('/logout'name'cms_security_logout')]
  35.     public function logout(): void
  36.     {
  37.     }
  38.     #[Route('/register'name'cms_security_register')]
  39.     public function register(Request $requestUserPasswordHasherInterface $userPasswordHasherEntityManagerInterface $entityManager): Response
  40.     {
  41.         $user = new User();
  42.         $form $this->createForm(RegistrationFormType::class, $user);
  43.         $form->handleRequest($request);
  44.         if ($form->isSubmitted() && $form->isValid()) {
  45.             // encode the plain password
  46.             $user->setPassword(
  47.                 $userPasswordHasher->hashPassword(
  48.                     $user,
  49.                     $form->get('plainPassword')->getData()
  50.                 )
  51.             );
  52.             $entityManager->persist($user);
  53.             $entityManager->flush();
  54.             // generate a signed url and email it to the user
  55.             $this->emailVerifier->sendEmailConfirmation('cms_verify_email'$user,
  56.                 (new TemplatedEmail())
  57.                     ->from(new Address('admin@admin.com''Test CMS'))
  58.                     ->to($user->getEmail())
  59.                     ->subject('Please Confirm your Email')
  60.                     ->htmlTemplate('security/confirmation_email.html.twig')
  61.             );
  62.             // do anything else you need here, like send an email
  63.             return $this->redirectToRoute('cms_main_index');
  64.         }
  65.         return $this->render('security/register.html.twig', [
  66.             'registrationForm' => $form->createView(),
  67.         ]);
  68.     }
  69.     #[Route('/verify/email'name'cms_security_verify_email')]
  70.     public function verifyUserEmail(Request $requestUserRepository $userRepository): Response
  71.     {
  72.         $id $request->get('id');
  73.         if (null === $id) {
  74.             return $this->redirectToRoute('cms_security_register');
  75.         }
  76.         $user $userRepository->find($id);
  77.         if (null === $user) {
  78.             return $this->redirectToRoute('cms_security_register');
  79.         }
  80.         // validate email confirmation link, sets User::isVerified=true and persists
  81.         try {
  82.             $this->emailVerifier->handleEmailConfirmation($request$user);
  83.         } catch (VerifyEmailExceptionInterface $exception) {
  84.             $this->addFlash('verify_email_error'$exception->getReason());
  85.             return $this->redirectToRoute('cms_security_register');
  86.         }
  87.         $this->addFlash('success''Your email address has been verified.');
  88.         return $this->redirectToRoute('cms_main_index');
  89.     }
  90. }