<?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\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Security;
/**
* @Route("/user")
* @Security("is_granted('ROLE_ADMIN')")
*/
class UserController extends AbstractController
{
/**
* @Route("/", name="app_user_index", methods={"GET"})
*/
public function index(UserRepository $userRepository): Response
{
return $this->render('user/index.html.twig', [
'users' => $userRepository->findBy(array('Archive'=>0)),
]);
}
/**
* @Route("/new", name="app_user_new", methods={"GET", "POST"})
*/
public function new(Request $request, UserRepository $userRepository): Response
{
$user = new User();
$form = $this->createForm(UserType::class, $user);
$form->handleRequest($request);
if ($form->isSubmitted() ) {
$userExist = $userRepository->findOneBy(array('email'=>$user->getEmail()));
if(!empty($userExist))
{
return $this->redirectToRoute('app_user_index', ['error'=>'userExist'], Response::HTTP_SEE_OTHER);
}
else
{
dd('ok');
$user->setRoles(array('ROLE_CLIENT'));
$pass = password_hash($_POST['password'], PASSWORD_DEFAULT);
$user->setPassword($pass);
$user->setArchive(0);
$user->setToken('ok');
$userRepository->add($user, true);
return $this->redirectToRoute('app_user_index', [], Response::HTTP_SEE_OTHER);
}
}
return $this->renderForm('user/new.html.twig', [
'user' => $user,
'form' => $form,
'type'=>'add'
]);
}
/**
* @Route("/{id}", name="app_user_show", methods={"GET"})
*/
public function show(User $user): Response
{
return $this->render('user/show.html.twig', [
'user' => $user,
]);
}
/**
* @Route("/{id}/edit", name="app_user_edit", methods={"GET", "POST"})
*/
public function edit(Request $request, User $user, UserRepository $userRepository): Response
{
$oldEmail = $user->getEmail();
$form = $this->createForm(UserType::class, $user);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
if($oldEmail != $user->getEmail())
{
$userExist = $userRepository->findOneBy(array('email'=>$user->getEmail()));
if(!empty($userExist))
{
return $this->redirectToRoute('app_user_index', ['error'=>'userExist'], Response::HTTP_SEE_OTHER);
}
}
if(!empty($_POST['password']))
{
$pass = password_hash($_POST['password'], PASSWORD_DEFAULT);
$user->setPassword($pass);
}
$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,
'type'=>'edit'
]);
}
/**
* @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'))) {
$user->setArchive(1);
$userRepository->add($user, true);
}
return $this->redirectToRoute('app_user_index', [], Response::HTTP_SEE_OTHER);
}
}