src/Controller/v1/User/DeleteUserController.php
<?php
declare(strict_types = 1);
/**
* /src/Controller/v1/User/DeleteUserController.php
*
* @author TLe, Tarmo Leppänen <tarmo.leppanen@pinja.com>
*/
namespace App\Controller\v1\User;
use App\Entity\User;
use App\Enum\Role;
use App\Resource\UserResource;
use App\Rest\Controller;
use App\Rest\Traits\Methods;
use OpenApi\Attributes as OA;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpKernel\Attribute\AsController;
use Symfony\Component\HttpKernel\Exception\HttpException;
use Symfony\Component\Routing\Attribute\Route;
use Symfony\Component\Routing\Requirement\Requirement;
use Symfony\Component\Security\Http\Attribute\IsGranted;
use Throwable;
/**
* @package App\Controller\v1\User
* @author TLe, Tarmo Leppänen <tarmo.leppanen@pinja.com>
*/
#[AsController]
#[OA\Tag(name: 'User Management')]
class DeleteUserController extends Controller
{
use Methods\DeleteMethod;
public function __construct(
UserResource $resource,
) {
parent::__construct($resource);
}
/**
* @throws Throwable
*/
#[Route(
path: '/v1/user/{user}',
requirements: [
'requestUser' => Requirement::UUID_V1,
],
methods: [Request::METHOD_DELETE],
)]
#[IsGranted(Role::ROOT->value)]
public function __invoke(Request $request, User $user, User $loggedInUser): Response
{
if ($loggedInUser === $user) {
throw new HttpException(Response::HTTP_BAD_REQUEST, 'You cannot remove yourself...');
}
return $this->deleteMethod($request, $user->getId());
}
}