<?php
namespace App\Controller;
use App\Entity\User;
use App\Form\UserType;
use App\Repository\UserRepository;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use App\Repository\DemandeRepository;
use App\Repository\OrderRepository;
use Symfony\Component\Security\Http\Authentication\AuthenticationUtils;
use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken;
/**
* @Route("/user")
*/
class UserController extends AbstractController
{
/**
* @Route("/index", name="app_user_index", methods={"GET"})
*
*/
public function index(UserRepository $userRepository): Response
{
return $this->render('user/index.html.twig', [
'users' => $userRepository->findAll(),
]);
}
/**
* @Route("/new", name="app_user_new", methods={"GET", "POST"})
*/
public function new(Request $request, UserRepository $userRepository, UserPasswordEncoderInterface $encoder): Response
{
if ($this->isGranted('ROLE_USER')) {
return $this->redirectToRoute('app_home_index');
}
$user = new User();
$form = $this->createForm(UserType::class, $user);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$hash = $encoder->encodePassword($user, $user->getPassword());
$user->setPassword($hash);
$userRepository->add($user, true);
// Authentification de l'utilisateur après son enregistrement
// $token = new UsernamePasswordToken($user, null, 'main', $user->getRoles());
// $this->get('security.token_storage')->setToken($token);
// // Redirection de l'utilisateur vers une page de succès ou autre page souhaitée
// return $guardHandler->authenticateUserAndHandleSuccess(
// $user,
// $request,
// $authenticator,
// 'main'
// );
return $this->redirectToRoute('app_home_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('user/new.html.twig', [
'user' => $user,
'form' => $form,
]);
}
/**
* @Route("/profile", name="profile", methods={"GET"})
*/
public function profile(OrderRepository $orderRepository): Response
{
$user = $this->get('security.token_storage')->getToken()->getUser();
return $this->render('user/profile.html.twig', [
'orders' => $orderRepository->findBy(['user' => $user->getId()])
]);
}
/**
* @Route("/login", name="login")
*/
public function login(Request $request, AuthenticationUtils $authenticationUtils)
{
if ($this->isGranted('ROLE_USER')) {
return $this->redirectToRoute('app_home_index');
}
// get the login error if there is one
$error = $authenticationUtils->getLastAuthenticationError();
// last username entered by the user
$lastUsername = $authenticationUtils->getLastUsername();
$session = $request->getSession();
return $this->render('user/login.html.twig', [
'last_username' => $lastUsername,
'error' => $error,
]);
}
/**
* @Route("/logout", name="logout")
*/
public function logout()
{
}
// /**
// * @Route("/{id}", name="app_user_show", methods={"GET"})
// */
// public function show(User $user): Response
// {
// $livres = $user->getLivres();
// return $this->render('user/show.html.twig', [
// 'user' => $user,
// 'livres' => $livres,
// ]);
// }
/**
* @Route("/{id}/edit", name="app_user_edit", methods={"GET", "POST"})
*/
public function edit(Request $request, User $user, UserRepository $userRepository): Response
{
$form = $this->createForm(UserType::class, $user);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$userRepository->add($user, true);
return $this->redirectToRoute('app_user_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('user/edit.html.twig', [
'user' => $user,
'form' => $form,
]);
}
/**
* @Route("/{id}", name="app_user_delete", methods={"POST"})
*/
public function delete(Request $request, User $user, UserRepository $userRepository): Response
{
if ($this->isCsrfTokenValid('delete'.$user->getId(), $request->request->get('_token'))) {
$userRepository->remove($user, true);
}
return $this->redirectToRoute('app_user_index', [], Response::HTTP_SEE_OTHER);
}
}