src/Controller/RegistrationController.php line 92

Open in your IDE?
  1. <?php
  2. namespace App\Controller;
  3. use App\Entity\Contador;
  4. use App\Entity\User;
  5. use App\Entity\DatosSindicato;
  6. use App\Form\RegistrationFormType;
  7. use App\Repository\UserRepository;
  8. use App\Security\EmailVerifier;
  9. use Doctrine\ORM\EntityManagerInterface;
  10. use Symfony\Bridge\Twig\Mime\TemplatedEmail;
  11. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  12. use Symfony\Component\HttpFoundation\Request;
  13. use Symfony\Component\HttpFoundation\Response;
  14. use Symfony\Component\Mime\Address;
  15. use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
  16. use Symfony\Component\Routing\Annotation\Route;
  17. use SymfonyCasts\Bundle\VerifyEmail\Exception\VerifyEmailExceptionInterface;
  18. class RegistrationController extends AbstractController
  19. {
  20.     private EmailVerifier $emailVerifier;
  21.     public function __construct(EmailVerifier $emailVerifier)
  22.     {
  23.         $this->emailVerifier $emailVerifier;
  24.     }
  25.     #[Route('/register'name'app_register')]
  26.     public function register(Request $requestUserPasswordHasherInterface $userPasswordHasherEntityManagerInterface $entityManager): Response
  27.     {
  28.         $user = new Contador();
  29.         $form $this->createForm(RegistrationFormType::class, $user);
  30.         $form->handleRequest($request);
  31.         if ($form->isSubmitted() && $form->isValid()) {
  32.             $user->setRoles(["ROLE_CONTADOR"]);
  33.             $user->setRegisterDate(new \DateTime("now"));
  34.             $user->setEnabled(false);
  35.             //evaluo la contrasena
  36.             $error_encontrado="";
  37.             $clave $entityManager->getRepository(User::class)->validar_clave($form->get('plainPassword')->getData(), $error_encontrado);
  38.             if ($clave == true){
  39.                 // encode the plain password
  40.                 $user->setPassword(
  41.                 $userPasswordHasher->hashPassword(
  42.                         $user,
  43.                         $form->get('plainPassword')->getData()
  44.                     )
  45.                 );
  46.                 $entityManager->persist($user);
  47.                 $entityManager->flush();
  48.                 $datos $entityManager->getRepository(DatosSindicato::class)->find(1);
  49.                 // generate a signed url and email it to the user
  50.                 $this->emailVerifier->sendEmailConfirmation('app_verify_email'$user,
  51.                     (new TemplatedEmail())
  52.                         ->from(new Address($datos->getEmail(), 'Sindicato'))
  53.                         ->to($user->getEmail())
  54.                         ->subject('Por favor confirme su Email')
  55.                         ->htmlTemplate('web/registracion/confirmation_email.html.twig')
  56.                         ->context([
  57.                             'nombre' => $user->getNombre(),
  58.                         ])
  59.                 );
  60.                 //mensaje Flash
  61.                 $this->addFlash('notice', array(
  62.                     'type' => 'success'
  63.                     'title' => 'CORREO ENVIADO!'
  64.                     'message' => 'Hemos enviado un email a su casilla de correo para que confirme su dirección de email.'
  65.                 ));
  66.                 return $this->redirectToRoute('web');
  67.                 // return $this->render('web/registracion/confirmarRegistracion.html.twig');
  68.             }else{
  69.                 //mensaje Flash
  70.                 $this->addFlash('notice', array(
  71.                     'type' => 'danger'
  72.                     'title' => 'ERROR!'
  73.                     'message' => 'La contraseña no cumple con los requisito. Verifique su clave.'
  74.                 ));
  75.                 //return $this->redirectToRoute('web');
  76.             }
  77.         }
  78.         return $this->render('web/registracion/registrarme.html.twig', [
  79.             'form' => $form->createView(),
  80.         ]);
  81.     }
  82.     #[Route('/verify/email'name'app_verify_email')]
  83.     public function verifyUserEmail(Request $requestUserRepository $userRepository): Response
  84.     {
  85.         $id $request->get('id');
  86.         if (null === $id) {
  87.             return $this->redirectToRoute('app_register');
  88.         }
  89.         $user $userRepository->find($id);
  90.         if (null === $user) {
  91.             return $this->redirectToRoute('app_register');
  92.         }
  93.         // validate email confirmation link, sets User::isVerified=true and persists
  94.         try {
  95.             $this->emailVerifier->handleEmailConfirmation($request$user);
  96.         } catch (VerifyEmailExceptionInterface $exception) {
  97.             $this->addFlash('verify_email_error'$exception->getReason());
  98.             return $this->redirectToRoute('web');
  99.         }
  100.         //mensaje Flash
  101.         $this->addFlash('notice', array(
  102.             'type' => 'success'
  103.             'title' => 'FELICITACIONES!'
  104.             'message' => 'Su registración se ha completado exitosamente. Ya puede ingresar al sistema con sus datos.'
  105.         ));
  106.         return $this->redirectToRoute('panel_contador_home');
  107.     }
  108. }