parent
7f602aec33
commit
6d563bd831
@ -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);
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in new issue