src/Controller/BaseSite/Auth/RegistrationController.php line 35

Open in your IDE?
  1. <?php
  2. namespace App\Controller\BaseSite\Auth;
  3. use App\Entity\Generic\User;
  4. use App\Form\RegistrationFormType;
  5. use App\Repository\Generic\UserRepository;
  6. use App\Repository\LeadNumbersRepository;
  7. use App\Security\Authenticator\UserAuthenticator;
  8. use App\Security\EmailVerifier;
  9. use App\Service\SmsHandler;
  10. use Doctrine\ORM\EntityManagerInterface;
  11. use Symfony\Bridge\Twig\Mime\TemplatedEmail;
  12. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  13. use Symfony\Component\Form\FormError;
  14. use Symfony\Component\HttpFoundation\Request;
  15. use Symfony\Component\HttpFoundation\Response;
  16. use Symfony\Component\Mime\Address;
  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\Contracts\Translation\TranslatorInterface;
  21. use SymfonyCasts\Bundle\VerifyEmail\Exception\VerifyEmailExceptionInterface;
  22. class RegistrationController extends AbstractController
  23. {
  24.     private EmailVerifier $emailVerifier;
  25.     public function __construct(EmailVerifier $emailVerifier , private SmsHandler $smsHandler)
  26.     {
  27.         $this->emailVerifier $emailVerifier;
  28.     }
  29.     #[Route('/register'name'app_register')]
  30.     public function register(
  31.         LeadNumbersRepository $numbersRepository,
  32.         UserRepository $userRepository,
  33.         Request               $requestUserPasswordHasherInterface $userPasswordHasherUserAuthenticatorInterface $userAuthenticatorUserAuthenticator $authenticatorEntityManagerInterface $entityManager): Response
  34.     {
  35.         if ($this->getUser()) {
  36.             return $this->redirectToRoute('shop_owner_login');
  37.         }
  38. //        if ($request->get('mobile')) {
  39. //            if (!$numbersRepository->findOneBy(['number' => $request->get('mobile')])) {
  40. //                $number = new LeadNumbers();
  41. //                $number->setNumber($request->get('mobile'));
  42. //                $this->getDoctrine()->getManager()->persist($number);
  43. //                $this->getDoctrine()->getManager()->flush();
  44. //            }
  45. //        }
  46.         $user = new User();
  47.         if (
  48.             $request->get('mobile')
  49.         ) {
  50.             $user->setMobile($request->get('mobile'));
  51.             $user->setIdentifier($request->get('mobile'));
  52.         }
  53.         $form $this->createForm(RegistrationFormType::class, $user);
  54.         $form->handleRequest($request);
  55.         if ($form->isSubmitted() && $form->isValid()) {
  56.             $input $form->get('identifier')->getData();
  57.             if ($userRepository->findOneBy(['mobile' => $input])) {
  58.                 $this->addFlash('error' 'کاربری با این اطلاعات از قبل موجود می باشد');
  59.                 return $this->redirectToRoute('app_register');
  60.             }
  61.             if ($userRepository->findOneBy(['email' => $input])) {
  62.                 $this->addFlash('error' 'کاربری با این اطلاعات از قبل موجود می باشد');
  63.                 return $this->redirectToRoute('app_register');
  64.             }
  65.             if ($userRepository->findOneBy(['identifier' => $input])) {
  66.                 $this->addFlash('error' 'کاربری با این اطلاعات از قبل موجود می باشد');
  67.                 return $this->redirectToRoute('app_register');
  68.             }
  69.             $user->setRoles(['ROLE_SHOP_ADMIN''ROLE_SHOP_OWNER']);
  70.             $user->setPassword(
  71.                 $userPasswordHasher->hashPassword(
  72.                     $user,
  73.                     $form->get('plainPassword')->getData()
  74.                 )
  75.             );
  76.             if (filter_var($inputFILTER_VALIDATE_EMAIL)) {
  77.                 $user->setEmail($input);
  78.             } elseif (preg_match('/^09\d{9}$/'$input)) {
  79.                 $user->setMobile($input);
  80.             } else {
  81.                 $form->get('identifier')->addError(new FormError('ایمیل یا شماره موبایل معتبر نیست.'));
  82.                 return $this->redirectToRoute('app_register');
  83.             }
  84.             $user->setIdentifier($input);
  85.             $entityManager->persist($user);
  86.             $entityManager->flush();
  87.             $this->smsHandler->sendWelcome($user);
  88.             if ($user->getEmail()) {
  89.                 $this->emailVerifier->sendEmailConfirmation('app_verify_email'$user,
  90.                     (new TemplatedEmail())
  91.                         ->from(new Address('[email protected]''oops'))
  92.                         ->to($user->getEmail())
  93.                         ->subject('Please Confirm your Email')
  94.                         ->htmlTemplate('@baseAuth/registration/confirmation_email.html.twig')
  95.                 );
  96.             }
  97. //            return $this->redirectToRoute('shop_owner_login');
  98.             return $userAuthenticator->authenticateUser(
  99.                 $user,
  100.                 $authenticator,
  101.                 $request
  102.             );
  103.         }
  104.         return $this->render('@baseAuth/registration/register.html.twig', [
  105.             'registrationForm' => $form->createView(),
  106.         ]);
  107.     }
  108.     #[Route('/verify/email'name'app_verify_email')]
  109.     public function verifyUserEmail(Request $requestTranslatorInterface $translatorUserRepository $userRepository): Response
  110.     {
  111.         $id $request->query->get('id');
  112.         if (null === $id) {
  113.             return $this->redirectToRoute('app_register');
  114.         }
  115.         $user $userRepository->find($id);
  116.         if (null === $user) {
  117.             return $this->redirectToRoute('app_register');
  118.         }
  119.         // validate email confirmation link, sets User::isVerified=true and persists
  120.         try {
  121.             $this->emailVerifier->handleEmailConfirmation($request$user);
  122.         } catch (VerifyEmailExceptionInterface $exception) {
  123.             $this->addFlash('verify_email_error'$translator->trans($exception->getReason(), [], 'VerifyEmailBundle'));
  124.             return $this->redirectToRoute('app_register');
  125.         }
  126.         $this->addFlash('success''Your email address has been verified.');
  127.         return $this->redirectToRoute('app_register');
  128.     }
  129. }