4 changed files with 119 additions and 0 deletions
@ -0,0 +1,67 @@
@@ -0,0 +1,67 @@
|
||||
<?php |
||||
|
||||
declare(strict_types=1); |
||||
|
||||
namespace App\Controller\Administration; |
||||
|
||||
use App\Form\RoleType; |
||||
use App\Repository\UserEntityRepository; |
||||
use Doctrine\ORM\EntityManagerInterface; |
||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; |
||||
use Symfony\Component\HttpFoundation\Request; |
||||
use Symfony\Component\HttpFoundation\Response; |
||||
use Symfony\Component\Routing\Attribute\Route; |
||||
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface; |
||||
|
||||
class RoleController extends AbstractController |
||||
{ |
||||
#[Route('/admin/role', name: 'admin_roles')] |
||||
public function index(): Response |
||||
{ |
||||
$form = $this->createForm(RoleType::class); |
||||
|
||||
return $this->render('admin/roles.html.twig', [ |
||||
'form' => $form->createView(), |
||||
]); |
||||
} |
||||
|
||||
/** |
||||
* Add a role to current user as submitted in a form |
||||
*/ |
||||
#[Route('/admin/role/add', name: 'admin_roles_add')] |
||||
public function addRole(Request $request, UserEntityRepository $userRepository, EntityManagerInterface $em, TokenStorageInterface $tokenStorage): Response |
||||
{ |
||||
// get role from request and add to current user's roles and save to db |
||||
$npub = $this->getUser()->getUserIdentifier(); |
||||
|
||||
$form = $this->createForm(RoleType::class); |
||||
$form->handleRequest($request); |
||||
|
||||
if (!$form->isSubmitted() || !$form->isValid()) { |
||||
return $this->render('admin/roles.html.twig', [ |
||||
'form' => $form->createView(), |
||||
]); |
||||
} |
||||
|
||||
$role = $form->get('role')->getData(); |
||||
$user = $userRepository->findOneBy(['npub' => $npub]); |
||||
$user->addRole($role); |
||||
$em->persist($user); |
||||
$em->flush(); |
||||
|
||||
// regenerate token with new roles |
||||
// Refresh the user token after update |
||||
$token = $tokenStorage->getToken(); |
||||
if ($token) { |
||||
$token->setUser($user); |
||||
$tokenStorage->setToken($token); |
||||
} |
||||
|
||||
// add a flash message |
||||
$this->addFlash('success', 'Role added to user'); |
||||
|
||||
return $this->render('admin/roles.html.twig', [ |
||||
'form' => $form->createView(), |
||||
]); |
||||
} |
||||
} |
||||
@ -0,0 +1,33 @@
@@ -0,0 +1,33 @@
|
||||
<?php |
||||
|
||||
declare(strict_types=1); |
||||
|
||||
namespace App\Form; |
||||
|
||||
use Symfony\Component\Form\AbstractType; |
||||
use Symfony\Component\Form\Extension\Core\Type\SubmitType; |
||||
use Symfony\Component\Form\Extension\Core\Type\TextType; |
||||
use Symfony\Component\Form\FormBuilderInterface; |
||||
use Symfony\Component\OptionsResolver\OptionsResolver; |
||||
|
||||
|
||||
class RoleType extends AbstractType |
||||
{ |
||||
|
||||
public function buildForm(FormBuilderInterface $builder, array $options) |
||||
{ |
||||
$builder |
||||
->setAction('/admin/role/add') |
||||
->add('role', TextType::class, [ |
||||
'required' => true, |
||||
]) |
||||
->add('submit', SubmitType::class, [ |
||||
'label' => 'Add Role', |
||||
]) |
||||
; |
||||
} |
||||
|
||||
public function configureOptions(OptionsResolver $resolver) |
||||
{ |
||||
} |
||||
} |
||||
@ -0,0 +1,17 @@
@@ -0,0 +1,17 @@
|
||||
{% extends 'base.html.twig' %} |
||||
|
||||
{% block body %} |
||||
<h1>{{ 'heading.roles'|trans }}</h1> |
||||
|
||||
{# Flash messages for feedback #} |
||||
{% for message in app.flashes('success') %} |
||||
<div class="alert alert-success"> |
||||
{{ message }} |
||||
</div> |
||||
{% endfor %} |
||||
|
||||
{# Form for adding a new role #} |
||||
{{ form_start(form) }} |
||||
{{ form_widget(form) }} |
||||
|
||||
{% endblock %} |
||||
Loading…
Reference in new issue