misc_pterodactyl-panel/app/Http/Controllers/Api/Application/Users/UserController.php

156 lines
5.3 KiB
PHP
Raw Normal View History

2017-11-19 22:30:00 +00:00
<?php
2018-01-20 01:58:57 +00:00
namespace Pterodactyl\Http\Controllers\Api\Application\Users;
2017-11-19 22:30:00 +00:00
use Pterodactyl\Models\User;
use Illuminate\Http\JsonResponse;
2020-09-13 18:55:39 +00:00
use Spatie\QueryBuilder\QueryBuilder;
use Pterodactyl\Services\Users\UserUpdateService;
use Pterodactyl\Services\Users\UserCreationService;
use Pterodactyl\Services\Users\UserDeletionService;
2017-11-19 22:30:00 +00:00
use Pterodactyl\Contracts\Repository\UserRepositoryInterface;
use Pterodactyl\Transformers\Api\Application\UserTransformer;
2021-01-04 18:50:43 +00:00
use Symfony\Component\HttpKernel\Exception\BadRequestHttpException;
use Pterodactyl\Http\Requests\Api\Application\Users\GetUserRequest;
2018-01-20 01:58:57 +00:00
use Pterodactyl\Http\Requests\Api\Application\Users\GetUsersRequest;
use Pterodactyl\Http\Requests\Api\Application\Users\StoreUserRequest;
use Pterodactyl\Http\Requests\Api\Application\Users\DeleteUserRequest;
use Pterodactyl\Http\Requests\Api\Application\Users\UpdateUserRequest;
use Pterodactyl\Http\Controllers\Api\Application\ApplicationApiController;
class UserController extends ApplicationApiController
2017-11-19 22:30:00 +00:00
{
2021-01-04 18:50:43 +00:00
/**
* @var \Pterodactyl\Contracts\Repository\UserRepositoryInterface
*/
private $repository;
/**
* @var \Pterodactyl\Services\Users\UserCreationService
*/
private $creationService;
/**
* @var \Pterodactyl\Services\Users\UserDeletionService
*/
private $deletionService;
2017-11-19 22:30:00 +00:00
/**
* @var \Pterodactyl\Services\Users\UserUpdateService
2017-11-19 22:30:00 +00:00
*/
private $updateService;
2017-11-19 22:30:00 +00:00
/**
* UserController constructor.
*/
public function __construct(
UserRepositoryInterface $repository,
UserCreationService $creationService,
UserDeletionService $deletionService,
UserUpdateService $updateService
2021-01-04 18:50:43 +00:00
) {
parent::__construct();
2021-01-04 18:50:43 +00:00
$this->repository = $repository;
$this->creationService = $creationService;
$this->deletionService = $deletionService;
$this->updateService = $updateService;
2017-11-19 22:30:00 +00:00
}
/**
* 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.
2017-11-19 22:30:00 +00:00
*
2018-01-20 01:58:57 +00:00
* @param \Pterodactyl\Http\Requests\Api\Application\Users\GetUsersRequest $request
*
2017-11-19 22:30:00 +00:00
* @return array
* @throws \Illuminate\Contracts\Container\BindingResolutionException
2017-11-19 22:30:00 +00:00
*/
public function index(GetUsersRequest $request): array
2017-11-19 22:30:00 +00:00
{
2021-01-04 18:50:43 +00:00
$perPage = $request->query('per_page', 10);
if ($perPage < 1) {
$perPage = 10;
} else if ($perPage > 100) {
throw new BadRequestHttpException('"per_page" query parameter must be below 100.');
}
2020-09-13 18:55:39 +00:00
$users = QueryBuilder::for(User::query())
->allowedFilters(['email', 'uuid', 'username', 'external_id'])
->allowedSorts(['id', 'uuid'])
2021-01-04 18:50:43 +00:00
->paginate($perPage);
2017-11-19 22:30:00 +00:00
2018-01-04 03:14:53 +00:00
return $this->fractal->collection($users)
->transformWith($this->getTransformer(UserTransformer::class))
2018-01-04 03:14:53 +00:00
->toArray();
}
/**
* Handle a request to view a single user. Includes any relations that
* were defined in the request.
*/
2021-01-04 18:50:43 +00:00
public function view(GetUserRequest $request, User $user): array
{
2020-09-13 18:55:39 +00:00
return $this->fractal->item($user)
->transformWith($this->getTransformer(UserTransformer::class))
2018-01-04 03:14:53 +00:00
->toArray();
2017-11-19 22:30:00 +00:00
}
/**
* 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 \Pterodactyl\Exceptions\Model\DataValidationException
* @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
* @throws \Illuminate\Contracts\Container\BindingResolutionException
*/
2020-06-26 04:42:21 +00:00
public function update(UpdateUserRequest $request, User $user): array
{
$this->updateService->setUserLevel(User::USER_LEVEL_ADMIN);
2020-06-26 04:42:21 +00:00
$user = $this->updateService->handle($user, $request->validated());
2021-01-04 18:50:43 +00:00
return $this->fractal->item($user)
->transformWith($this->getTransformer(UserTransformer::class))
->toArray();
}
/**
* Store a new user on the system. Returns the created user and a HTTP/201
* header on successful creation.
*
* @throws \Exception
* @throws \Pterodactyl\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.
*
* @throws \Pterodactyl\Exceptions\DisplayException
*/
2020-09-13 18:55:39 +00:00
public function delete(DeleteUserRequest $request, User $user): JsonResponse
{
2020-09-13 18:55:39 +00:00
$this->deletionService->handle($user);
2020-09-13 18:55:39 +00:00
return new JsonResponse([], JsonResponse::HTTP_NO_CONTENT);
}
2017-11-19 22:30:00 +00:00
}