105 строки
3.0 KiB
PHP
105 строки
3.0 KiB
PHP
<?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 Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface;
|
|
|
|
/**
|
|
* @Route("/admin/user")
|
|
*/
|
|
class UserController extends AbstractController
|
|
{
|
|
/**
|
|
* @Route("/", name="user_index", methods={"GET"})
|
|
*/
|
|
public function index(UserRepository $userRepository): Response
|
|
{
|
|
return $this->render('user/index.html.twig', [
|
|
'users' => $userRepository->findAll(),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @Route("/new", name="user_new", methods={"GET","POST"})
|
|
*/
|
|
public function new(Request $request, UserPasswordEncoderInterface $passwordEncoder): Response
|
|
{
|
|
$user = new User();
|
|
$form = $this->createForm(UserType::class, $user);
|
|
$form->handleRequest($request);
|
|
|
|
if ($form->isSubmitted() && $form->isValid()) {
|
|
$entityManager = $this->getDoctrine()->getManager();
|
|
$user->setPassword(
|
|
$passwordEncoder->encodePassword($user, $user->getPassword())
|
|
);
|
|
|
|
$user->setActive((bool) $form->get('active')->getData())
|
|
->setRoles($form->get('roles')->getData());
|
|
|
|
$entityManager->persist($user);
|
|
$entityManager->flush();
|
|
|
|
return $this->redirectToRoute('user_index');
|
|
}
|
|
|
|
return $this->render('user/new.html.twig', [
|
|
'user' => $user,
|
|
'form' => $form->createView(),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @Route("/{id}", name="user_show", methods={"GET"})
|
|
*/
|
|
public function show(User $user): Response
|
|
{
|
|
return $this->render('user/show.html.twig', [
|
|
'user' => $user,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @Route("/{id}/edit", name="user_edit", methods={"GET","POST"})
|
|
*/
|
|
public function edit(Request $request, User $user): Response
|
|
{
|
|
$form = $this->createForm(UserType::class, $user);
|
|
$form->handleRequest($request);
|
|
|
|
if ($form->isSubmitted() && $form->isValid()) {
|
|
$this->getDoctrine()->getManager()->flush();
|
|
|
|
return $this->redirectToRoute('user_index', [
|
|
'id' => $user->getId(),
|
|
]);
|
|
}
|
|
|
|
return $this->render('user/edit.html.twig', [
|
|
'user' => $user,
|
|
'form' => $form->createView(),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @Route("/{id}", name="user_delete", methods={"DELETE"})
|
|
*/
|
|
public function delete(Request $request, User $user): Response
|
|
{
|
|
if ($this->isCsrfTokenValid('delete'.$user->getId(), $request->request->get('_token'))) {
|
|
$entityManager = $this->getDoctrine()->getManager();
|
|
$entityManager->remove($user);
|
|
$entityManager->flush();
|
|
}
|
|
|
|
return $this->redirectToRoute('user_index');
|
|
}
|
|
}
|