SecurityController.php 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. <?php
  2. namespace App\Controller;
  3. use App\Entity\Profile;
  4. use App\Form\UserEditPasswordType;
  5. use App\Form\UserEditType;
  6. use App\Form\UserRegisterType;
  7. use App\Service\Mail;
  8. use App\Service\UserManager;
  9. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  10. use Symfony\Component\Form\Extension\Core\Type\EmailType;
  11. use Symfony\Component\Form\Extension\Core\Type\SubmitType;
  12. use Symfony\Component\HttpFoundation\Request;
  13. use Symfony\Component\Routing\Annotation\Route;
  14. use App\Form\UserType;
  15. use App\Entity\User;
  16. use App\Form\ProfileType;
  17. use App\Repository\UserRepository;
  18. use Doctrine\ORM\EntityManagerInterface;
  19. use Symfony\Component\Form\FormFactoryInterface;
  20. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  21. use Symfony\Component\Security\Http\Authentication\AuthenticationUtils;
  22. use Symfony\Component\HttpFoundation\Response;
  23. class SecurityController extends AbstractController
  24. {
  25. #[Route("/login", name: "app_login")]
  26. public function login(AuthenticationUtils $authenticationUtils): Response
  27. {
  28. // get the login error if there is one
  29. $error = $authenticationUtils->getLastAuthenticationError();
  30. // last username entered by the user
  31. $lastUsername = $authenticationUtils->getLastUsername();
  32. return $this->render('security/login.html.twig', ['last_username' => $lastUsername, 'error' => $error]);
  33. }
  34. #[Route("/logout", name: "app_logout")]
  35. public function logout()
  36. {
  37. throw new \Exception('Don\'t forget to activate logout in security.yaml');
  38. }
  39. #[Route("/admin/createuser", name: "admin_createuser")]
  40. public function createUserAction(Request $request, UserManager $userManager): Response
  41. {
  42. $user = new User;
  43. $form = $this->createForm(UserType::class, $user);
  44. $form->handleRequest($request);
  45. if ($form->isSubmitted() && $form->isValid())
  46. {
  47. $userManager->enregistrerUser($user);
  48. $this->addFlash('success', 'L\'utilisateur a été ajouté');
  49. return $this->redirectToRoute('admin_index');
  50. }
  51. return $this->renderForm('security/createuser.html.twig', array (
  52. 'form' => $form
  53. ));
  54. }
  55. #[Route("/admin/edituser/{id}", name: "admin_edituser")]
  56. public function editUserAction(Request $request, User $user, EntityManagerInterface $em): Response
  57. {
  58. $form = $this->createForm(UserEditType::class, $user);
  59. $form->handleRequest($request);
  60. if ($form->isSubmitted() && $form->isValid())
  61. {
  62. $em->flush();
  63. $this->addFlash('success', 'L\'utilisateur a été modifié');
  64. return $this->redirectToRoute('admin_index');
  65. }
  66. return $this->renderForm('security/createuser.html.twig', array (
  67. 'form' => $form
  68. ));
  69. }
  70. #[Route("/admin/edituseroptions/{id}", name: "admin_edituseroptions")]
  71. public function editUseroptions (Request $request, Profile $options, EntityManagerInterface $em): Response
  72. {
  73. $form = $this->createForm(ProfileType::class, $options);
  74. $form->handleRequest($request);
  75. if ($form->isSubmitted() && $form->isValid())
  76. {
  77. $em->flush();
  78. $this->addFlash('success', 'Les options de l\'utilisateur ont bien été modifiées.');
  79. return $this->redirectToRoute('admin_index');
  80. }
  81. return $this->renderForm('profil/preferences.html.twig', [
  82. 'user' => $options->getUser(),
  83. 'form' => $form
  84. ]);
  85. }
  86. #[Route("/admin", name: "admin_index")]
  87. public function indexAction(Request $request, UserRepository $repo): Response
  88. {
  89. $users = $repo->findAll();
  90. return $this->render('security/liste.html.twig', array(
  91. 'users' => $users
  92. ));
  93. }
  94. #[Route("/admin/deluser/{id}", name: "admin_deluser")]
  95. public function delUserAction (Request $request, User $user, UserManager $userManager, FormFactoryInterface $ffi): Response
  96. {
  97. $form = $ffi->create();
  98. $form->handleRequest($request);
  99. if ($form->isSubmitted() && $form->isValid()) {
  100. $userManager->removeUser($user);
  101. $this->addFlash("success", "L'utilisateur a bien été supprimé");
  102. return $this->redirectToRoute('admin_index');
  103. }
  104. return $this->renderForm('security/supprimeruser.html.twig', array (
  105. 'user' => $user,
  106. 'form' => $form
  107. ));
  108. }
  109. #[Route("/register", name: "security_register")]
  110. public function registerAction(Request $request, UserManager $userManager, Mail $mail): Response
  111. {
  112. $user = new User();
  113. $form = $this->createForm(UserRegisterType::class, $user);
  114. $form->handleRequest($request);
  115. if ($form->isSubmitted() && $form->isValid())
  116. {
  117. $userManager->register($user);
  118. //$adresse = $this->generateUrl('security_activate', array('token'=>$user->getToken()), UrlGeneratorInterface::ABSOLUTE_URL);
  119. //$mail->sendMailActivation($user, $adresse);
  120. $adresse = $this->generateUrl('admin_edituser', ['id' => $user->getId()], UrlGeneratorInterface::ABSOLUTE_URL);
  121. $mail->sendMailDemandeActivation($user, $adresse);
  122. $this->addFlash('success', 'Votre compte a été créé. Un mail a été envoyé à l\'administrateur pour l\'activation du compte');
  123. return $this->redirectToRoute('security_attente');
  124. }
  125. return $this->renderForm('security/register.html.twig', [
  126. 'form' => $form
  127. ]);
  128. }
  129. #[Route("/attente", name: "security_attente")]
  130. public function attenteActivation(): Response
  131. {
  132. return $this->render('security/attente.html.twig');
  133. }
  134. #[Route("/motdepasseoublie", name: "security_envoyertoken")]
  135. public function recupMdpAction(Request $request, UserManager $userManager, Mail $mail, EntityManagerInterface $em, UserRepository $userRepo): Response
  136. {
  137. $form = $this->createFormBuilder()
  138. ->add('email', EmailType::class)
  139. ->add('envoyer-mail', SubmitType::class)
  140. ->getForm();
  141. $form->handleRequest($request);
  142. if ($form->isSubmitted() && $form->isValid()) {
  143. $data = $form->getData();
  144. $user = $userRepo->findOneBy(array('mail'=>$data['email']));
  145. if ($user != null)
  146. {
  147. $userManager->generateToken($user);
  148. $em->flush();
  149. $adresse = $this->generateUrl('security_resetpassword', array('token'=>$user->getToken()), UrlGeneratorInterface::ABSOLUTE_URL);
  150. $mail->sendMailTokenMp($user, $adresse);
  151. $this->addFlash('success', "Un mail vous a été envoyé à ".$user->getUsername()." pour récupérer le mot de passe");
  152. return $this->redirectToRoute('app_login');
  153. } else {
  154. $this->addFlash('warning', "Cet email n'existe pas");
  155. }
  156. }
  157. return $this->renderForm('security/chercheruserpourpassword.html.twig', array (
  158. 'form' => $form
  159. ));
  160. }
  161. #[Route("/resetpassword/token={token}", name: "security_resetpassword")]
  162. public function resetPasswordAction(Request $request, UserManager $userManager, User $user = null): Response
  163. {
  164. if ($user != null) {
  165. if ($user->isValidToken()) {
  166. $form = $this->createForm(UserEditPasswordType::class, $user);
  167. $form->handleRequest($request);
  168. if ($form->isSubmitted() && $form->isValid()) {
  169. $userManager->resetPassword($user);
  170. $this->addFlash('success', 'Mot de passe changé, veuillez vous connecter');
  171. return $this->redirectToRoute('videotheque_liste');
  172. }
  173. return $this->renderForm('security/password.html.twig', array(
  174. 'form' => $form
  175. ));
  176. }
  177. }
  178. $this->addFlash('warning', "Ce token n'est plus valide");
  179. return $this->redirectToRoute('videotheque_liste');
  180. }
  181. #[Route("/admin/resettokens", name: "admin_resettokens")]
  182. public function resetTokensAction(UserManager $userManager, EntityManagerInterface $em, UserRepository $userRepo): Response
  183. {
  184. $users = $userRepo->findAll();
  185. foreach ($users as $user)
  186. {
  187. $userManager->generateToken($user);
  188. }
  189. $em->flush();
  190. return $this->redirectToRoute('admin_index');
  191. }
  192. #[Route("/activate/token={token}", name: "security_activate")]
  193. public function activateAction(Request $request, EntityManagerInterface $em, User $user = null): Response
  194. {
  195. if ($user != null)
  196. {
  197. if ($user->isValidToken())
  198. {
  199. $user->setActivated(true);
  200. $em->flush();
  201. $this->addFlash('success', "Votre compte est activé");
  202. return $this->redirectToRoute('app_login');
  203. }
  204. }
  205. $this->addFlash('warning', "Ce token n'est plus valide");
  206. return $this->redirectToRoute('videotheque_liste');
  207. }
  208. }