Admin : routes access control for /users + possibility to extend elsewhere

samuel
samuel 1 week ago
parent 7f602aec33
commit 6d563bd831

@ -41,6 +41,7 @@ security:
- { path: ^/login, roles: PUBLIC_ACCESS }
- { path: ^/register, roles: PUBLIC_ACCESS }
- { path: ^/, roles: ROLE_USER }
- { path: ^/admin, roles: ROLE_ADMIN }

@ -0,0 +1,74 @@
<?php
namespace App\Controller;
use App\Entity\User;
use App\Repository\UserRepository;
use Doctrine\ORM\EntityManagerInterface;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\IsGranted;
#[Route('/admin', name: 'admin_users_')]
#[IsGranted('ROLE_ADMIN')]
class AdminController extends AbstractController
{
private EntityManagerInterface $entityManager;
private UserPasswordHasherInterface $passwordHasher;
public function __construct(EntityManagerInterface $entityManager, UserPasswordHasherInterface $passwordHasher)
{
$this->entityManager = $entityManager;
$this->passwordHasher = $passwordHasher;
}
#[Route('/users', name: 'list', methods: ['GET'])]
public function getUserById(UserRepository $userRepository): JsonResponse
{
$users = $userRepository->findAll();
$data = array_map(function (User $user) {
return [
'id' => $user->getId(),
'username' => $user->getUsername(),
'roles' => $user->getRoles(),
];
}, $users);
return $this->json($data);
}
#[Route('/users/add', name: 'add_user', methods: ['POST'])]
public function addUser(Request $request, UserPasswordHasherInterface $passwordHasher): JsonResponse
{
$data = json_decode($request->getContent(), true);
$username = $data['username'] ?? null;
$password = $data['password'] ?? null;
$roles = $data['roles'] ?? ['ROLE_USER'];
if (!$username || !$password) {
return $this->json(['error' => 'Missing username or password'], Response::HTTP_BAD_REQUEST);
}
$existingUser = $this->entityManager->getRepository(User::class)->findOneBy(['username' => $username]);
if ($existingUser) {
return $this->json(['error' => 'User already exists'], Response::HTTP_CONFLICT);
}
$user = new User();
$user->setUsername($username);
$user->setRoles($roles);
$user->setPassword($passwordHasher->hashPassword($user, $password));
$this->entityManager->persist($user);
$this->entityManager->flush();
return $this->json(['message' => 'User created successfully', 'id' => $user->getId()], Response::HTTP_CREATED);
}
}

@ -19,22 +19,4 @@ class UserController extends AbstractController
$this->entityManager = $entityManager;
}
#[Route('/{userId}', name: 'get_by_id', methods: ['GET'])]
public function getUserById(int $userId): JsonResponse
{
$user = $this->entityManager->getRepository(User::class)->find($userId);
if (!$user) {
return $this->json(['error' => 'User not found'], Response::HTTP_NOT_FOUND);
}
$data = [
'id' => $user->getId(),
'username' => $user->getUsername(),
'roles' => $user->getRoles(),
];
return $this->json($data);
}
}

Loading…
Cancel
Save