turbo #4
|
@ -6,6 +6,8 @@ use App\Entity\User;
|
||||||
use App\Form\EditProfileFormType;
|
use App\Form\EditProfileFormType;
|
||||||
use App\Repository\UserRepository;
|
use App\Repository\UserRepository;
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
|
use Flasher\Prime\FlasherInterface;
|
||||||
|
use Flasher\SweetAlert\Prime\SweetAlertFactory;
|
||||||
use Sunrise\Slugger\Slugger;
|
use Sunrise\Slugger\Slugger;
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
use Symfony\Component\HttpFoundation\File\UploadedFile;
|
use Symfony\Component\HttpFoundation\File\UploadedFile;
|
||||||
|
@ -24,50 +26,6 @@ use Symfony\Component\Validator\Validator\ValidatorInterface;
|
||||||
*/
|
*/
|
||||||
class UserController extends BaseController
|
class UserController extends BaseController
|
||||||
{
|
{
|
||||||
|
|
||||||
#[Route(path: '/profile/edit/{username}', name: 'app_profile_edit')]
|
|
||||||
public function editProfile(Request $request, UserRepository $userRepository, UserPasswordHasherInterface $userPasswordHasher, EntityManagerInterface $entityManager, string $username = ''): Response
|
|
||||||
{
|
|
||||||
if ($username !== '') {
|
|
||||||
if ($this->isGranted(attribute: 'ROLE_ADMIN')) {
|
|
||||||
$user = $userRepository->findOneBy([
|
|
||||||
'username' => $username,
|
|
||||||
]);
|
|
||||||
} else {
|
|
||||||
throw new AccessDeniedException(message: 'Only admins are allowed to edit foreign profiles.');
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$user = $this->getUser();
|
|
||||||
}
|
|
||||||
|
|
||||||
$form = $this->createForm(type: EditProfileFormType::class, data: $user);
|
|
||||||
$form->handleRequest(request: $request);
|
|
||||||
|
|
||||||
if ($form->isSubmitted() && $form->isValid()) {
|
|
||||||
$user = $form->getData();
|
|
||||||
// if there's a new password, use it
|
|
||||||
|
|
||||||
if ($form->get(name: 'newPassword')->getData())
|
|
||||||
$user->setPassword(
|
|
||||||
password: $userPasswordHasher->hashPassword(
|
|
||||||
user: $user,
|
|
||||||
plainPassword: $form->get(name: 'newPassword')->getData()
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
$entityManager->persist(entity: $user);
|
|
||||||
$entityManager->flush();
|
|
||||||
|
|
||||||
return $this->redirectToRoute(route: 'app_main');
|
|
||||||
};
|
|
||||||
|
|
||||||
return $this->renderForm(view: '@default/user/edit_profile.html.twig', parameters: [
|
|
||||||
'user' => $user,
|
|
||||||
'userForm' => $form
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#[Route(path: '/profile/{username}', name: 'app_profile')]
|
#[Route(path: '/profile/{username}', name: 'app_profile')]
|
||||||
public function showProfile(UserRepository $userRepository, string $username = ''): Response
|
public function showProfile(UserRepository $userRepository, string $username = ''): Response
|
||||||
{
|
{
|
||||||
|
@ -85,6 +43,61 @@ class UserController extends BaseController
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[Route(path: '/profile/edit/{username}', name: 'app_profile_edit')]
|
||||||
|
public function editProfile(Request $request,
|
||||||
|
UserRepository $userRepository,
|
||||||
|
UserPasswordHasherInterface $userPasswordHasher,
|
||||||
|
EntityManagerInterface $entityManager,
|
||||||
|
string $username = ''): Response
|
||||||
|
{
|
||||||
|
$user = $this->getUser();
|
||||||
|
|
||||||
|
$editUser = $userRepository->findOneBy(['username' => $username]);
|
||||||
|
|
||||||
|
if ($username !== $editUser->getUsername()) {
|
||||||
|
if (!$this->isGranted(attribute: 'ROLE_ADMIN')) {
|
||||||
|
$this->addFlash(type: 'error', message: 'Only admins are allowed to edit foreign profiles.');
|
||||||
|
return $this->redirectToRoute(route: 'app_main');
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$form = $this->createForm(type: EditProfileFormType::class, data: $user);
|
||||||
|
$form->handleRequest(request: $request);
|
||||||
|
|
||||||
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
|
$user = $form->getData();
|
||||||
|
// if there's a new password, use it
|
||||||
|
|
||||||
|
if ($form->get(name: 'newPassword')->getData()) {
|
||||||
|
$user->setPassword(
|
||||||
|
password: $userPasswordHasher->hashPassword(
|
||||||
|
user: $user,
|
||||||
|
plainPassword: $form->get(name: 'newPassword')->getData()
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($user->getTmpAvatar()) {
|
||||||
|
$user->setAvatar($user->getTmpAvatar());
|
||||||
|
$user->setTmpAvatar('');
|
||||||
|
}
|
||||||
|
|
||||||
|
$entityManager->persist(entity: $user);
|
||||||
|
$entityManager->flush();
|
||||||
|
|
||||||
|
$this->addFlash(type: 'success', message: 'Profile successfully updated.');
|
||||||
|
|
||||||
|
return $this->redirectToRoute(route: 'app_main');
|
||||||
|
};
|
||||||
|
|
||||||
|
return $this->renderForm(view: '@default/user/edit_profile.html.twig', parameters: [
|
||||||
|
'user' => $editUser,
|
||||||
|
'userForm' => $form
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#[Route(path: '/list_users/', name: 'app_list_user')]
|
#[Route(path: '/list_users/', name: 'app_list_user')]
|
||||||
public function listUsers(UserRepository $userRepository): Response
|
public function listUsers(UserRepository $userRepository): Response
|
||||||
{
|
{
|
||||||
|
@ -96,7 +109,7 @@ class UserController extends BaseController
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO move to a helper class
|
// TODO move to a helper class
|
||||||
function humanFilesize($bytes, $decimals = 2)
|
function humanFilesize($bytes, $decimals = 2): string
|
||||||
{
|
{
|
||||||
$sz = 'BKMGTP';
|
$sz = 'BKMGTP';
|
||||||
$factor = floor((strlen($bytes) - 1) / 3);
|
$factor = floor((strlen($bytes) - 1) / 3);
|
||||||
|
@ -132,7 +145,8 @@ class UserController extends BaseController
|
||||||
$cleanFilename = $slugger->slugify($originalFilename);
|
$cleanFilename = $slugger->slugify($originalFilename);
|
||||||
$newFilename = $cleanFilename . '-' . uniqid() . '.' . $uploadedAvatar->guessExtension();
|
$newFilename = $cleanFilename . '-' . uniqid() . '.' . $uploadedAvatar->guessExtension();
|
||||||
$uploadedAvatar->move($destination, $newFilename);
|
$uploadedAvatar->move($destination, $newFilename);
|
||||||
$user->setAvatar($newFilename);
|
// Store the tmp name, use it on real form submit.
|
||||||
|
$user->setTmpAvatar($newFilename);
|
||||||
$entityManager->persist(entity: $user);
|
$entityManager->persist(entity: $user);
|
||||||
$entityManager->flush();
|
$entityManager->flush();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue