<?php
namespace App\Controller\Web;
use App\Entity\User;
use App\Enum\EnabledAcountTypeEnum;
use App\Form\Registration\RegistrationFormType;
use App\Security\UserCustomAuthenticator;
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\HttpKernel\KernelInterface;
use Symfony\Component\Mailer\Exception\TransportExceptionInterface;
use Symfony\Component\Mailer\MailerInterface;
use Symfony\Component\Mime\Address;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface;
use Symfony\Component\Security\Guard\GuardAuthenticatorHandler;
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
use Symfony\Contracts\Translation\TranslatorInterface;
class RegistrationController extends AbstractController
{
private $appKernel;
/**
* @Route("/register", name="app_register")
* @param Request $request
* @param UserPasswordEncoderInterface $passwordEncoder
* @param GuardAuthenticatorHandler $guardHandler
* @param UserCustomAuthenticator $authenticator
* @param MailerInterface $mailer
* @param TranslatorInterface $translator
* @param KernelInterface $appKernel
* @return Response
*/
public function register(Request $request, UserPasswordEncoderInterface $passwordEncoder, GuardAuthenticatorHandler $guardHandler, UserCustomAuthenticator $authenticator, MailerInterface $mailer, TranslatorInterface $translator, KernelInterface $appKernel): Response
{
$this->appKernel = $appKernel;
$user = new User();
$form = $this->createForm(RegistrationFormType::class, $user);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
// encode the plain password
$user->setPassword(
$passwordEncoder->encodePassword(
$user,
$form->get('plainPassword')->getData()
)
);
$entityManager = $this->getDoctrine()->getManager();
$entityManager->persist($user);
$entityManager->flush();
$this->sendMail($mailer, $translator, $user);
return $guardHandler->authenticateUserAndHandleSuccess(
$user,
$request,
$authenticator,
'main' // firewall name in security.yaml
);
}
return $this->render('registration/register.html.twig', [
'form' => $form->createView(),
]);
}
/**
* @Route("/register-validation", name="app_register_validation")
* @param Request $request
* @return Response
*/
public function registerConfirmation(Request $request) : Response {
$em = $this->getDoctrine()->getManager();
$user = $em->getRepository(User::class)->findOneBy(array('confirmationToken' => $request->get('token')));
if ($user) {
if ($user->getEnabled() != EnabledAcountTypeEnum::CLOSED) {
$user->setEnabled(EnabledAcountTypeEnum::ENABLED);
$em->flush();
return $this->render('registration/confirmation_account.html.twig', [
]);
} else {
return $this->redirectToRoute('app_login');
}
}
return $this->redirectToRoute('app_login');
}
private function sendMail(MailerInterface $mailer, TranslatorInterface $translator, User $data) : bool {
$message = (new TemplatedEmail())
->subject($translator->trans('email.accountConfirmation.title'))
->from(new Address($this->getParameter('NOREPLY_EMAIL'), 'No-Reply'))
->to(new Address($data->getEmail(), ($data->getFirstName() . " " . $data->getLastName())))
->htmlTemplate('Email/FosUserBundle/account_confirmation.html.twig')
->context([
'user' => $data,
'urlActivation' => $this->generateUrl("app_register_validation", [], UrlGeneratorInterface::ABSOLUTE_URL).'?token='.$data->getConfirmationToken()
])
;
try {
$mailer->send($message);
} catch (TransportExceptionInterface $e) {
return false;
}
return true;
}
}