80 lines
2.3 KiB
PHP
80 lines
2.3 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Symfony package.
|
|
*
|
|
* (c) Fabien Potencier <fabien@symfony.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace App\Controller;
|
|
|
|
use App\Form\Type\ChangePasswordType;
|
|
use App\Form\UserType;
|
|
use Sensio\Bundle\FrameworkExtraBundle\Configuration\IsGranted;
|
|
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;
|
|
|
|
/**
|
|
* Controller used to manage current user.
|
|
*
|
|
* @Route("/profile")
|
|
* @IsGranted("ROLE_USER")
|
|
*
|
|
* @author Romain Monteil <monteil.romain@gmail.com>
|
|
*/
|
|
class UserController extends AbstractController
|
|
{
|
|
/**
|
|
* @Route("/edit", methods="GET|POST", name="user_edit")
|
|
*/
|
|
public function edit(Request $request): Response
|
|
{
|
|
$user = $this->getUser();
|
|
|
|
$form = $this->createForm(UserType::class, $user);
|
|
$form->handleRequest($request);
|
|
|
|
if ($form->isSubmitted() && $form->isValid()) {
|
|
$this->getDoctrine()->getManager()->flush();
|
|
|
|
$this->addFlash('success', 'user.updated_successfully');
|
|
|
|
return $this->redirectToRoute('user_edit');
|
|
}
|
|
|
|
return $this->render('user/edit.html.twig', [
|
|
'user' => $user,
|
|
'form' => $form->createView(),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @Route("/change-password", methods="GET|POST", name="user_change_password")
|
|
*/
|
|
public function changePassword(Request $request, UserPasswordEncoderInterface $encoder): Response
|
|
{
|
|
$user = $this->getUser();
|
|
|
|
$form = $this->createForm(ChangePasswordType::class);
|
|
$form->handleRequest($request);
|
|
|
|
if ($form->isSubmitted() && $form->isValid()) {
|
|
$user->setPassword($encoder->encodePassword($user, $form->get('newPassword')->getData()));
|
|
|
|
$this->getDoctrine()->getManager()->flush();
|
|
|
|
return $this->redirectToRoute('security_logout');
|
|
}
|
|
|
|
return $this->render('user/change_password.html.twig', [
|
|
'form' => $form->createView(),
|
|
]);
|
|
}
|
|
}
|