2016-02-21 06:15:37 +00:00
|
|
|
<?php
|
2016-12-07 22:46:38 +00:00
|
|
|
|
2016-02-21 06:15:37 +00:00
|
|
|
namespace Pterodactyl\Http\Controllers\Admin;
|
|
|
|
|
2022-10-14 17:59:20 +01:00
|
|
|
use Illuminate\View\View;
|
2016-12-07 22:46:38 +00:00
|
|
|
use Illuminate\Http\Request;
|
2017-06-17 23:36:39 +01:00
|
|
|
use Pterodactyl\Models\User;
|
2022-10-14 17:59:20 +01:00
|
|
|
use Pterodactyl\Models\Model;
|
|
|
|
use Illuminate\Support\Collection;
|
|
|
|
use Illuminate\Http\RedirectResponse;
|
2017-06-14 05:25:37 +01:00
|
|
|
use Prologue\Alerts\AlertsMessageBag;
|
2020-09-13 20:21:44 +01:00
|
|
|
use Spatie\QueryBuilder\QueryBuilder;
|
2022-10-14 17:59:20 +01:00
|
|
|
use Illuminate\View\Factory as ViewFactory;
|
2016-02-21 06:15:37 +00:00
|
|
|
use Pterodactyl\Exceptions\DisplayException;
|
|
|
|
use Pterodactyl\Http\Controllers\Controller;
|
2017-08-31 03:14:20 +01:00
|
|
|
use Illuminate\Contracts\Translation\Translator;
|
2017-08-27 21:10:51 +01:00
|
|
|
use Pterodactyl\Services\Users\UserUpdateService;
|
2017-12-31 02:25:04 +00:00
|
|
|
use Pterodactyl\Traits\Helpers\AvailableLanguages;
|
2017-08-27 21:10:51 +01:00
|
|
|
use Pterodactyl\Services\Users\UserCreationService;
|
|
|
|
use Pterodactyl\Services\Users\UserDeletionService;
|
2017-06-17 23:36:39 +01:00
|
|
|
use Pterodactyl\Http\Requests\Admin\UserFormRequest;
|
2022-10-24 01:51:20 +01:00
|
|
|
use Pterodactyl\Http\Requests\Admin\NewUserFormRequest;
|
2017-08-05 01:11:41 +01:00
|
|
|
use Pterodactyl\Contracts\Repository\UserRepositoryInterface;
|
2016-02-21 06:15:37 +00:00
|
|
|
|
|
|
|
class UserController extends Controller
|
|
|
|
{
|
2017-12-31 02:25:04 +00:00
|
|
|
use AvailableLanguages;
|
|
|
|
|
2017-06-11 04:28:44 +01:00
|
|
|
/**
|
|
|
|
* UserController constructor.
|
|
|
|
*/
|
2017-07-01 21:29:49 +01:00
|
|
|
public function __construct(
|
2022-10-14 17:59:20 +01:00
|
|
|
protected AlertsMessageBag $alert,
|
|
|
|
protected UserCreationService $creationService,
|
|
|
|
protected UserDeletionService $deletionService,
|
|
|
|
protected Translator $translator,
|
|
|
|
protected UserUpdateService $updateService,
|
|
|
|
protected UserRepositoryInterface $repository,
|
|
|
|
protected ViewFactory $view
|
2017-07-01 21:29:49 +01:00
|
|
|
) {
|
2017-06-11 04:28:44 +01:00
|
|
|
}
|
|
|
|
|
2016-02-21 06:15:37 +00:00
|
|
|
/**
|
2017-03-19 23:36:50 +00:00
|
|
|
* Display user index page.
|
2016-02-21 06:15:37 +00:00
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function index(Request $request): View
|
2016-02-21 06:15:37 +00:00
|
|
|
{
|
2020-09-23 04:13:54 +01:00
|
|
|
$users = QueryBuilder::for(
|
|
|
|
User::query()->select('users.*')
|
2020-10-11 02:06:42 +01:00
|
|
|
->selectRaw('COUNT(DISTINCT(subusers.id)) as subuser_of_count')
|
|
|
|
->selectRaw('COUNT(DISTINCT(servers.id)) as servers_count')
|
2020-09-23 04:13:54 +01:00
|
|
|
->leftJoin('subusers', 'subusers.user_id', '=', 'users.id')
|
|
|
|
->leftJoin('servers', 'servers.owner_id', '=', 'users.id')
|
|
|
|
->groupBy('users.id')
|
|
|
|
)
|
2020-09-13 20:26:15 +01:00
|
|
|
->allowedFilters(['username', 'email', 'uuid'])
|
2020-09-13 20:21:44 +01:00
|
|
|
->allowedSorts(['id', 'uuid'])
|
|
|
|
->paginate(50);
|
2017-03-03 23:14:21 +00:00
|
|
|
|
2022-10-14 17:59:20 +01:00
|
|
|
return $this->view->make('admin.users.index', ['users' => $users]);
|
2016-02-21 06:15:37 +00:00
|
|
|
}
|
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Display new user page.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function create(): View
|
2016-02-21 06:15:37 +00:00
|
|
|
{
|
2022-10-14 17:59:20 +01:00
|
|
|
return $this->view->make('admin.users.new', [
|
2017-12-31 02:25:04 +00:00
|
|
|
'languages' => $this->getAvailableLanguages(true),
|
|
|
|
]);
|
2016-02-21 06:15:37 +00:00
|
|
|
}
|
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Display user view page.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function view(User $user): View
|
2016-02-21 06:15:37 +00:00
|
|
|
{
|
2022-10-14 17:59:20 +01:00
|
|
|
return $this->view->make('admin.users.view', [
|
2017-12-31 02:25:04 +00:00
|
|
|
'user' => $user,
|
|
|
|
'languages' => $this->getAvailableLanguages(true),
|
|
|
|
]);
|
2016-02-21 06:15:37 +00:00
|
|
|
}
|
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
2017-06-11 04:28:44 +01:00
|
|
|
* Delete a user from the system.
|
2017-03-19 23:36:50 +00:00
|
|
|
*
|
2017-06-14 05:25:37 +01:00
|
|
|
* @throws \Exception
|
2017-06-25 01:49:09 +01:00
|
|
|
* @throws \Pterodactyl\Exceptions\DisplayException
|
2017-03-19 23:36:50 +00:00
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function delete(Request $request, User $user): RedirectResponse
|
2016-02-21 06:15:37 +00:00
|
|
|
{
|
2017-06-25 01:49:09 +01:00
|
|
|
if ($request->user()->id === $user->id) {
|
2022-01-15 16:10:37 +00:00
|
|
|
throw new DisplayException($this->translator->get('admin/user.exceptions.user_has_servers'));
|
2017-06-25 01:49:09 +01:00
|
|
|
}
|
|
|
|
|
2017-08-05 01:11:41 +01:00
|
|
|
$this->deletionService->handle($user);
|
2016-12-07 22:46:38 +00:00
|
|
|
|
2017-10-09 21:13:52 +01:00
|
|
|
return redirect()->route('admin.users');
|
2016-02-21 06:15:37 +00:00
|
|
|
}
|
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Create a user.
|
|
|
|
*
|
2017-06-14 05:25:37 +01:00
|
|
|
* @throws \Exception
|
|
|
|
* @throws \Throwable
|
2017-03-19 23:36:50 +00:00
|
|
|
*/
|
2022-10-24 01:51:20 +01:00
|
|
|
public function store(NewUserFormRequest $request): RedirectResponse
|
2016-02-21 06:15:37 +00:00
|
|
|
{
|
2017-08-05 01:11:41 +01:00
|
|
|
$user = $this->creationService->handle($request->normalize());
|
2019-12-17 05:25:48 +00:00
|
|
|
$this->alert->success($this->translator->get('admin/user.notices.account_created'))->flash();
|
2017-06-11 04:28:44 +01:00
|
|
|
|
|
|
|
return redirect()->route('admin.users.view', $user->id);
|
2016-02-21 06:15:37 +00:00
|
|
|
}
|
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
2017-06-11 04:28:44 +01:00
|
|
|
* Update a user on the system.
|
2017-03-19 23:36:50 +00:00
|
|
|
*
|
2017-06-25 01:49:09 +01:00
|
|
|
* @throws \Pterodactyl\Exceptions\Model\DataValidationException
|
2017-10-07 23:21:41 +01:00
|
|
|
* @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
|
2017-03-19 23:36:50 +00:00
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function update(UserFormRequest $request, User $user): RedirectResponse
|
2016-02-21 06:15:37 +00:00
|
|
|
{
|
2019-12-08 19:02:59 +00:00
|
|
|
$this->updateService
|
|
|
|
->setUserLevel(User::USER_LEVEL_ADMIN)
|
|
|
|
->handle($user, $request->normalize());
|
2017-12-03 20:00:47 +00:00
|
|
|
|
2019-12-08 19:02:59 +00:00
|
|
|
$this->alert->success(trans('admin/user.notices.account_updated'))->flash();
|
2016-12-07 22:46:38 +00:00
|
|
|
|
2017-06-11 04:28:44 +01:00
|
|
|
return redirect()->route('admin.users.view', $user->id);
|
2016-02-21 06:15:37 +00:00
|
|
|
}
|
|
|
|
|
2017-03-19 23:36:50 +00:00
|
|
|
/**
|
|
|
|
* Get a JSON response of users on the system.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function json(Request $request): Model|Collection
|
2016-10-21 20:22:47 +01:00
|
|
|
{
|
2020-09-13 20:35:48 +01:00
|
|
|
$users = QueryBuilder::for(User::query())->allowedFilters(['email'])->paginate(25);
|
|
|
|
|
2020-04-11 20:56:03 +01:00
|
|
|
// Handle single user requests.
|
|
|
|
if ($request->query('user_id')) {
|
2020-09-13 20:35:48 +01:00
|
|
|
$user = User::query()->findOrFail($request->input('user_id'));
|
|
|
|
$user->md5 = md5(strtolower($user->email));
|
|
|
|
|
|
|
|
return $user;
|
2020-04-11 20:56:03 +01:00
|
|
|
}
|
|
|
|
|
2020-09-13 20:35:48 +01:00
|
|
|
return $users->map(function ($item) {
|
|
|
|
$item->md5 = md5(strtolower($item->email));
|
|
|
|
|
|
|
|
return $item;
|
|
|
|
});
|
2016-10-21 20:22:47 +01:00
|
|
|
}
|
2016-02-21 06:15:37 +00:00
|
|
|
}
|