<?php
namespace App\Controller\Admin;
use App\Entity\User;
use App\Form\UserEditType;
use App\Form\UserType;
use App\Repository\UserRepository;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\Validator\Validator\ValidatorInterface;
#[Route('admin/user')]
class UserController extends AbstractController
{
#[Route('/', name: 'user_index', methods: ['GET'])]
public function index(
UserRepository $userRepository
): Response
{
return $this->render('admin/user/index.html.twig', [
'users' => $userRepository->findAll(),
]);
}
#[Route('/new', name: 'user_new', methods: ['GET', 'POST'])]
public function new(
Request $request,
UserRepository $userRepository,
UserPasswordHasherInterface $passwordHasher,
ValidatorInterface $validator
): Response
{
$user = new User();
$form = $this->createForm(UserType::class, $user);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$userPassword = $user->getPassword();
$hashedPassword = $passwordHasher->hashPassword(
$user,
$userPassword
);
$user->setPassword($hashedPassword);
$userRepository->add($user, true);
return $this->redirectToRoute('user_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('admin/user/new.html.twig', [
'user' => $user,
'form' => $form,
]);
}
#[Route('/{id}', name: 'user_show', methods: ['GET'])]
public function show(
User $user
): Response
{
return $this->render('admin/user/show.html.twig', [
'user' => $user,
]);
}
#[Route('/{id}/edit', name: 'user_edit', methods: ['GET', 'POST'])]
public function edit(
Request $request,
User $user, UserRepository $userRepository,
UserPasswordHasherInterface $passwordHasher
): Response
{
$oldPassword = $user->getPassword();
$user->setPassword('');
$form = $this->createForm(UserEditType::class, $user);
if ($request->isMethod('POST')) {
$requestArray = $request->request->all();
if($requestArray['user_edit']['password']['first'] == "" || $requestArray['user_edit']['password']['first'] == null) {
$requestArray['user_edit']['password']['first'] = $oldPassword;
$requestArray['user_edit']['password']['second'] = $oldPassword;
$request->request->replace($requestArray);
}
}
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$userPassword = $user->getPassword();
if ($user->getPassword() != $oldPassword) {
$hashedPassword = $passwordHasher->hashPassword(
$user,
$userPassword
);
$user->setPassword($hashedPassword);
}
$userRepository->add($user, true);
return $this->redirectToRoute('user_index', [], Response::HTTP_SEE_OTHER);
}
return $this->renderForm('admin/user/edit.html.twig', [
'user' => $user,
'form' => $form,
]);
}
#[Route('/{id}', name: '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('user_index', [], Response::HTTP_SEE_OTHER);
}
}