<?php
namespace App\Controller;
use App\Entity\User;
use App\Form\RegistrationFormType;
use App\Repository\UserRepository;
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\Mailer\MailerInterface;
use Symfony\Component\Mime\Address;
use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
use Symfony\Component\Routing\Annotation\Route;
use SymfonyCasts\Bundle\VerifyEmail\Exception\VerifyEmailExceptionInterface;
use SymfonyCasts\Bundle\VerifyEmail\VerifyEmailHelperInterface;
class RegistrationController extends AbstractController
{
#[Route('/register', name: 'app_register')]
public function register(
Request $request,
UserPasswordHasherInterface $userPasswordHasher,
EntityManagerInterface $entityManager,
VerifyEmailHelperInterface $verifyEmailHelper,
MailerInterface $mailerInterface
): Response
{
$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()
)
);
// $user->setRoles(['ROLE_USER_REGISTERED']);
$entityManager->persist($user);
$entityManager->flush();
$signatureComponents = $verifyEmailHelper->generateSignature(
'app_verify_email',
$user->getId(),
$user->getEmail(),
['id' => $user->getId()]
);
$email = (new TemplatedEmail())
->from(new Address('fermedejette@ferme.be', 'Ferme de Jette'))
->to(new Address($user->getEmail(), $user->getFirstName()))
->context([
'urlSigned' => $signatureComponents->getSignedUrl()
])
->subject('New registration')
->htmlTemplate('emails/register.html.twig');
$mailerInterface->send($email);
$this->addFlash(
'success',
'Un email de confirmation a été envoyé à: ' .$user->getEmail()
);
return $this->redirectToRoute('app_login');
}
return $this->render('registration/register.html.twig', [
'registrationForm' => $form->createView(),
]);
}
#[Route('/verify', name: 'app_verify_email')]
public function verifyUserEmail(
Request $request,
VerifyEmailHelperInterface $verifyEmailHelper,
UserRepository $userRepository,
EntityManagerInterface $entityManager
): Response {
$user = $userRepository->find($request->query->get('id'));
if (!$user) {
throw $this->createNotFoundException();
}
try {
$verifyEmailHelper->validateEmailConfirmation(
$request->getUri(),
$user->getId(),
$user->getEmail(),
);
} catch (VerifyEmailExceptionInterface $exception) {
$this->addFlash('error', $exception->getReason());
return $this->redirectToRoute('app_register');
}
$user->setIsVerified(true);
$entityManager->flush();
$this->addFlash(
'success',
'Compte vérifié ! Vous pouvez maintenant vous connecter'
);
return $this->redirectToRoute('app_login');
}
#[Route('/verify/resend', name: 'app_verify_resend_email')]
public function resendVerifyEmail()
{
return $this->render('registration/resend_verify_email.html.twig');
}
}