src/Controller/RegistrationController.php line 72

Open in your IDE?
  1. <?php
  2. namespace App\Controller;
  3. use App\Component\ResetPassword\ResetPasswordFactory;
  4. use App\Entity\ResetPasswordRequest;
  5. use App\Entity\User;
  6. use App\Form\RegistrationFormType;
  7. use App\Security\UserAuthenticator;
  8. use Doctrine\ORM\EntityManagerInterface;
  9. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  10. use Symfony\Component\EventDispatcher\EventDispatcherInterface;
  11. use Symfony\Component\Form\Extension\Core\Type\EmailType;
  12. use Symfony\Component\Form\Extension\Core\Type\PasswordType;
  13. use Symfony\Component\Form\Extension\Core\Type\RepeatedType;
  14. use Symfony\Component\Form\Extension\Core\Type\SubmitType;
  15. use Symfony\Component\HttpFoundation\Request;
  16. use Symfony\Component\HttpFoundation\Response;
  17. use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
  18. use Symfony\Component\Routing\Annotation\Route;
  19. use Symfony\Component\Security\Http\Authentication\UserAuthenticatorInterface;
  20. use Symfony\Component\Validator\Constraints\Length;
  21. use Symfony\Component\Validator\Constraints\NotBlank;
  22. use Symfony\Contracts\Translation\TranslatorInterface;
  23. class RegistrationController extends ABaseController
  24. {
  25.     public function __construct(
  26.         private ResetPasswordFactory $resetPasswordFactory,
  27.     )
  28.     {
  29.     }
  30.     #[Route('/register'name'route.register')]
  31.     public function register(Request $requestUserPasswordHasherInterface $userPasswordHasherUserAuthenticatorInterface $userAuthenticatorUserAuthenticator $authenticatorEntityManagerInterface $entityManager): Response
  32.     {
  33.         if (!empty($entityManager->getRepository(User::class)->findAll())) {
  34.             return $this->redirectToRoute('route.login');
  35.         }
  36.         $user = new User();
  37.         $form $this->createForm(RegistrationFormType::class, $user);
  38.         $form->handleRequest($request);
  39.         if ($form->isSubmitted() && $form->isValid()) {
  40.             // encode the plain password
  41.             $user->setPassword(
  42.             $userPasswordHasher->hashPassword(
  43.                     $user,
  44.                     $form->get('plainPassword')->getData()
  45.                 )
  46.             );
  47.             $user->setRoles(['ROLE_SUPER_ADMIN']);
  48.             $user->setFirstName('admin')
  49.                 ->setLastname('admin');
  50.             $entityManager->persist($user);
  51.             $entityManager->flush();
  52.             // do anything else you need here, like send an email
  53.             return $userAuthenticator->authenticateUser(
  54.                 $user,
  55.                 $authenticator,
  56.                 $request
  57.             );
  58.         }
  59.         return $this->render('registration/register.html.twig', [
  60.             'registrationForm' => $form->createView(),
  61.         ]);
  62.     }
  63.     #[Route('/reset_password'name'route.reset_password')]
  64.     public function requestResetPassword(Request $request): Response
  65.     {
  66.         $response $this->resolveDashboardRedirect();
  67.         if ($response instanceof Response) {
  68.             return $response;
  69.         }
  70.         $formBuilder $this->createFormBuilder();
  71.         $formBuilder->add('email'EmailType::class, [
  72.             'label' => 'E-mail',
  73.             'required' => true
  74.         ]);
  75.         $formBuilder->add('submit'SubmitType::class, [
  76.             'label' => 'Odeslat žádost o obnovení hesla'
  77.         ]);
  78.         $form $formBuilder->getForm();
  79.         $form->handleRequest($request);
  80.         if ($form->isSubmitted() && $form->isValid()) {
  81.             $this->resetPasswordFactory->resetPasswordPrepare($form->get('email')->getData());
  82.             return $this->redirectToRoute('route.login');
  83.         }
  84.         return $this->render('registration/reset_password_email.twig', [
  85.             'form' => $form->createView()
  86.         ]);
  87.     }
  88.     #[Route('/reset_password/{token}'name'route.reset_password_verify'requirements: ['token' => '.+'])]
  89.     public function resetPassword(
  90.         string $token,
  91.         Request $request,
  92.         UserPasswordHasherInterface $userPasswordHasher,
  93.         EntityManagerInterface $entityManager,
  94.     ): Response {
  95.         $response $this->resolveDashboardRedirect();
  96.         if ($response instanceof Response) {
  97.             return $response;
  98.         }
  99.         $resetPasswordRequest $this->getEntityManager()->getRepository(ResetPasswordRequest::class)->findOneBy(['token' => $token]);
  100.         if (!$resetPasswordRequest instanceof ResetPasswordRequest) {
  101.             return $this->redirectToRoute('route.login');
  102.         }
  103.         $isValid $this->resetPasswordFactory->resolveResetPassword($resetPasswordRequest);
  104.         if (!$isValid) {
  105.             return $this->redirectToRoute('route.login');
  106.         }
  107.         $formBuilder $this->createFormBuilder();
  108.         $formBuilder->add('plainPassword'RepeatedType::class, [
  109.             'type' => PasswordType::class,
  110.             'first_options' => ['label' => 'Heslo'],
  111.             'second_options' => ['label' => 'Heslo znovu'],
  112.             'required' => true,
  113.             'mapped' => false,
  114.             'attr' => ['autocomplete' => 'new-password'],
  115.             'constraints' => [
  116.                 new NotBlank([
  117.                     'message' => 'Prosím zadejte heslo',
  118.                 ]),
  119.                 new Length([
  120.                     'min' => 6,
  121.                     'minMessage' => 'Vaše heslo by mělo mít minimálně {{ limit }} znaků',
  122.                     'max' => 4096,
  123.                 ]),
  124.             ],
  125.         ]);
  126.         $formBuilder->add('submit'SubmitType::class, [
  127.             'label' => 'Nastavit heslo'
  128.         ]);
  129.         $form $formBuilder->getForm();
  130.         $form->handleRequest($request);
  131.         if ($form->isSubmitted() && $form->isValid()) {
  132.             $user $resetPasswordRequest->getUser();
  133.             $resetPasswordRequest->setVerifiedAt(new \DateTimeImmutable());
  134.             $user->setPassword(
  135.                 $userPasswordHasher->hashPassword(
  136.                     $user,
  137.                     $form->get('plainPassword')->getData()
  138.                 )
  139.             );
  140.             $entityManager->flush();
  141.             return $this->redirectToRoute('route.login');
  142.         }
  143.         return $this->render('registration/reset_password_email.twig', [
  144.             'form' => $form->createView()
  145.         ]);
  146.     }
  147. }