mirror of
https://github.com/pelican-dev/panel.git
synced 2025-05-20 00:34:44 +02:00

* remove `guard_name` from api and add id to transformer * disallow update/ delete for root admin role via api * disallow assigning root admin via api * add api to remove user roles * fix assignRoles & removeRoles
149 lines
4.8 KiB
PHP
149 lines
4.8 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\Application\Users;
|
|
|
|
use App\Models\User;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Spatie\QueryBuilder\QueryBuilder;
|
|
use App\Services\Users\UserUpdateService;
|
|
use App\Services\Users\UserCreationService;
|
|
use App\Transformers\Api\Application\UserTransformer;
|
|
use App\Http\Requests\Api\Application\Users\GetUsersRequest;
|
|
use App\Http\Requests\Api\Application\Users\StoreUserRequest;
|
|
use App\Http\Requests\Api\Application\Users\DeleteUserRequest;
|
|
use App\Http\Requests\Api\Application\Users\UpdateUserRequest;
|
|
use App\Http\Controllers\Api\Application\ApplicationApiController;
|
|
use App\Http\Requests\Api\Application\Users\AssignUserRolesRequest;
|
|
use App\Models\Role;
|
|
|
|
class UserController extends ApplicationApiController
|
|
{
|
|
/**
|
|
* UserController constructor.
|
|
*/
|
|
public function __construct(
|
|
private UserCreationService $creationService,
|
|
private UserUpdateService $updateService
|
|
) {
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* Handle request to list all users on the panel. Returns a JSON-API representation
|
|
* of a collection of users including any defined relations passed in
|
|
* the request.
|
|
*/
|
|
public function index(GetUsersRequest $request): array
|
|
{
|
|
$users = QueryBuilder::for(User::query())
|
|
->allowedFilters(['email', 'uuid', 'username', 'external_id'])
|
|
->allowedSorts(['id', 'uuid'])
|
|
->paginate($request->query('per_page') ?? 50);
|
|
|
|
return $this->fractal->collection($users)
|
|
->transformWith($this->getTransformer(UserTransformer::class))
|
|
->toArray();
|
|
}
|
|
|
|
/**
|
|
* Handle a request to view a single user. Includes any relations that
|
|
* were defined in the request.
|
|
*/
|
|
public function view(GetUsersRequest $request, User $user): array
|
|
{
|
|
return $this->fractal->item($user)
|
|
->transformWith($this->getTransformer(UserTransformer::class))
|
|
->toArray();
|
|
}
|
|
|
|
/**
|
|
* Update an existing user on the system and return the response. Returns the
|
|
* updated user model response on success. Supports handling of token revocation
|
|
* errors when switching a user from an admin to a normal user.
|
|
*
|
|
* Revocation errors are returned under the 'revocation_errors' key in the response
|
|
* meta. If there are no errors this is an empty array.
|
|
*
|
|
* @throws \App\Exceptions\Model\DataValidationException
|
|
*/
|
|
public function update(UpdateUserRequest $request, User $user): array
|
|
{
|
|
$this->updateService->setUserLevel(User::USER_LEVEL_ADMIN);
|
|
$user = $this->updateService->handle($user, $request->validated());
|
|
|
|
$response = $this->fractal->item($user)
|
|
->transformWith($this->getTransformer(UserTransformer::class));
|
|
|
|
return $response->toArray();
|
|
}
|
|
|
|
/**
|
|
* Assign roles to a user.
|
|
*/
|
|
public function assignRoles(AssignUserRolesRequest $request, User $user): array
|
|
{
|
|
foreach ($request->input('roles') as $role) {
|
|
if ($role === Role::getRootAdmin()->id) {
|
|
continue;
|
|
}
|
|
|
|
$user->assignRole($role);
|
|
}
|
|
|
|
$response = $this->fractal->item($user)
|
|
->transformWith($this->getTransformer(UserTransformer::class));
|
|
|
|
return $response->toArray();
|
|
}
|
|
|
|
/**
|
|
* Removes roles from a user.
|
|
*/
|
|
public function removeRoles(AssignUserRolesRequest $request, User $user): array
|
|
{
|
|
foreach ($request->input('roles') as $role) {
|
|
if ($role === Role::getRootAdmin()->id) {
|
|
continue;
|
|
}
|
|
|
|
$user->removeRole($role);
|
|
}
|
|
|
|
$response = $this->fractal->item($user)
|
|
->transformWith($this->getTransformer(UserTransformer::class));
|
|
|
|
return $response->toArray();
|
|
}
|
|
|
|
/**
|
|
* Store a new user on the system. Returns the created user and an HTTP/201
|
|
* header on successful creation.
|
|
*
|
|
* @throws \Exception
|
|
* @throws \App\Exceptions\Model\DataValidationException
|
|
*/
|
|
public function store(StoreUserRequest $request): JsonResponse
|
|
{
|
|
$user = $this->creationService->handle($request->validated());
|
|
|
|
return $this->fractal->item($user)
|
|
->transformWith($this->getTransformer(UserTransformer::class))
|
|
->addMeta([
|
|
'resource' => route('api.application.users.view', [
|
|
'user' => $user->id,
|
|
]),
|
|
])
|
|
->respond(201);
|
|
}
|
|
|
|
/**
|
|
* Handle a request to delete a user from the Panel. Returns a HTTP/204 response on successful deletion.
|
|
*/
|
|
public function delete(DeleteUserRequest $request, User $user): JsonResponse
|
|
{
|
|
$user->delete();
|
|
|
|
return new JsonResponse([], JsonResponse::HTTP_NO_CONTENT);
|
|
}
|
|
}
|