src/Controller/RegistrationController.php line 21

  1. <?php
  2. namespace App\Controller;
  3. use App\Controller\Bootstrap\DefaultLayoutController;
  4. use App\Entity\User;
  5. use App\Form\RegistrationFormType;
  6. use Doctrine\ORM\EntityManagerInterface;
  7. use Symfony\Component\HttpFoundation\Request;
  8. use Symfony\Component\HttpFoundation\Response;
  9. use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
  10. use Symfony\Component\Routing\Annotation\Route;
  11. use Symfony\Component\Security\Http\Attribute\IsGranted;
  12. #[IsGranted("ROLE_ADMIN")]
  13. #[Route('/utilisateur')]
  14. class RegistrationController extends DefaultLayoutController
  15. {
  16.     #[Route('/creation-compte'name'app_register')]
  17.     public function register(Request $requestUserPasswordHasherInterface $userPasswordHasherEntityManagerInterface $entityManager): Response
  18.     {
  19.         $user = new User();
  20.         $form $this->createForm(RegistrationFormType::class, $user);
  21.         $form->handleRequest($request);
  22.         if ($form->isSubmitted() && $form->isValid()) {
  23.             // encode the plain password
  24.             $user->setPassword(
  25.                 $userPasswordHasher->hashPassword(
  26.                     $user,
  27.                     $form->get('plainPassword')->getData()
  28.                 )
  29.             );
  30.             $entityManager->persist($user);
  31.             $entityManager->flush();
  32.             // do anything else you need here, like send an email
  33.             return $this->redirectToRoute('dashboard');
  34.         }
  35.         $this->theme->addJavascriptFile('js/custom/authentication/sign-up/general.js');
  36.         return $this->render('pages/auth/signup.html.twig', [
  37.             'form' => $form->createView()
  38.         ]);
  39.     }
  40. }