mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-11-04 09:46:51 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			179 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			179 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Pterodactyl\Http\Controllers\Api\Application\Users;
 | 
						|
 | 
						|
use Pterodactyl\Models\User;
 | 
						|
use Illuminate\Http\Response;
 | 
						|
use Illuminate\Http\JsonResponse;
 | 
						|
use Pterodactyl\Services\Users\UserUpdateService;
 | 
						|
use Pterodactyl\Services\Users\UserCreationService;
 | 
						|
use Pterodactyl\Services\Users\UserDeletionService;
 | 
						|
use Pterodactyl\Contracts\Repository\UserRepositoryInterface;
 | 
						|
use Pterodactyl\Transformers\Api\Application\UserTransformer;
 | 
						|
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
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Services\Users\UserCreationService
 | 
						|
     */
 | 
						|
    private $creationService;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Services\Users\UserDeletionService
 | 
						|
     */
 | 
						|
    private $deletionService;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Contracts\Repository\UserRepositoryInterface
 | 
						|
     */
 | 
						|
    private $repository;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Services\Users\UserUpdateService
 | 
						|
     */
 | 
						|
    private $updateService;
 | 
						|
 | 
						|
    /**
 | 
						|
     * UserController constructor.
 | 
						|
     *
 | 
						|
     * @param \Pterodactyl\Contracts\Repository\UserRepositoryInterface $repository
 | 
						|
     * @param \Pterodactyl\Services\Users\UserCreationService           $creationService
 | 
						|
     * @param \Pterodactyl\Services\Users\UserDeletionService           $deletionService
 | 
						|
     * @param \Pterodactyl\Services\Users\UserUpdateService             $updateService
 | 
						|
     */
 | 
						|
    public function __construct(
 | 
						|
        UserRepositoryInterface $repository,
 | 
						|
        UserCreationService $creationService,
 | 
						|
        UserDeletionService $deletionService,
 | 
						|
        UserUpdateService $updateService
 | 
						|
    ) {
 | 
						|
        parent::__construct();
 | 
						|
 | 
						|
        $this->creationService = $creationService;
 | 
						|
        $this->deletionService = $deletionService;
 | 
						|
        $this->repository = $repository;
 | 
						|
        $this->updateService = $updateService;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 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.
 | 
						|
     *
 | 
						|
     * @param \Pterodactyl\Http\Requests\Api\Application\Users\GetUsersRequest $request
 | 
						|
     * @return array
 | 
						|
     */
 | 
						|
    public function index(GetUsersRequest $request): array
 | 
						|
    {
 | 
						|
        $users = $this->repository->setSearchTerm($request->input('search'))->paginated(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.
 | 
						|
     *
 | 
						|
     * @param \Pterodactyl\Http\Requests\Api\Application\Users\GetUsersRequest $request
 | 
						|
     * @return array
 | 
						|
     */
 | 
						|
    public function view(GetUsersRequest $request): array
 | 
						|
    {
 | 
						|
        return $this->fractal->item($request->getModel(User::class))
 | 
						|
            ->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.
 | 
						|
     *
 | 
						|
     * @param \Pterodactyl\Http\Requests\Api\Application\Users\UpdateUserRequest $request
 | 
						|
     * @return array
 | 
						|
     *
 | 
						|
     * @throws \Pterodactyl\Exceptions\Model\DataValidationException
 | 
						|
     * @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
 | 
						|
     */
 | 
						|
    public function update(UpdateUserRequest $request): array
 | 
						|
    {
 | 
						|
        $this->updateService->setUserLevel(User::USER_LEVEL_ADMIN);
 | 
						|
        $collection = $this->updateService->handle($request->getModel(User::class), $request->validated());
 | 
						|
 | 
						|
        $errors = [];
 | 
						|
        if (! empty($collection->get('exceptions'))) {
 | 
						|
            foreach ($collection->get('exceptions') as $node => $exception) {
 | 
						|
                /** @var \GuzzleHttp\Exception\RequestException $exception */
 | 
						|
                /** @var \GuzzleHttp\Psr7\Response|null $response */
 | 
						|
                $response = method_exists($exception, 'getResponse') ? $exception->getResponse() : null;
 | 
						|
                $message = trans('admin/server.exceptions.daemon_exception', [
 | 
						|
                    'code' => is_null($response) ? 'E_CONN_REFUSED' : $response->getStatusCode(),
 | 
						|
                ]);
 | 
						|
 | 
						|
                $errors[] = ['message' => $message, 'node' => $node];
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        $response = $this->fractal->item($collection->get('model'))
 | 
						|
            ->transformWith($this->getTransformer(UserTransformer::class));
 | 
						|
 | 
						|
        if (count($errors) > 0) {
 | 
						|
            $response->addMeta([
 | 
						|
                'revocation_errors' => $errors,
 | 
						|
            ]);
 | 
						|
        }
 | 
						|
 | 
						|
        return $response->toArray();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Store a new user on the system. Returns the created user and a HTTP/201
 | 
						|
     * header on successful creation.
 | 
						|
     *
 | 
						|
     * @param \Pterodactyl\Http\Requests\Api\Application\Users\StoreUserRequest $request
 | 
						|
     * @return \Illuminate\Http\JsonResponse
 | 
						|
     *
 | 
						|
     * @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.
 | 
						|
     *
 | 
						|
     * @param \Pterodactyl\Http\Requests\Api\Application\Users\DeleteUserRequest $request
 | 
						|
     * @return \Illuminate\Http\Response
 | 
						|
     *
 | 
						|
     * @throws \Pterodactyl\Exceptions\DisplayException
 | 
						|
     */
 | 
						|
    public function delete(DeleteUserRequest $request): Response
 | 
						|
    {
 | 
						|
        $this->deletionService->handle($request->getModel(User::class));
 | 
						|
 | 
						|
        return response('', 204);
 | 
						|
    }
 | 
						|
}
 |