197 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			197 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Pterodactyl\Http\Controllers\Admin;
 | 
						|
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use Pterodactyl\Models\User;
 | 
						|
use Prologue\Alerts\AlertsMessageBag;
 | 
						|
use Spatie\QueryBuilder\QueryBuilder;
 | 
						|
use Pterodactyl\Exceptions\DisplayException;
 | 
						|
use Pterodactyl\Http\Controllers\Controller;
 | 
						|
use Illuminate\Contracts\Translation\Translator;
 | 
						|
use Pterodactyl\Services\Users\UserUpdateService;
 | 
						|
use Pterodactyl\Traits\Helpers\AvailableLanguages;
 | 
						|
use Pterodactyl\Services\Users\UserCreationService;
 | 
						|
use Pterodactyl\Services\Users\UserDeletionService;
 | 
						|
use Pterodactyl\Http\Requests\Admin\UserFormRequest;
 | 
						|
use Pterodactyl\Contracts\Repository\UserRepositoryInterface;
 | 
						|
 | 
						|
class UserController extends Controller
 | 
						|
{
 | 
						|
    use AvailableLanguages;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Prologue\Alerts\AlertsMessageBag
 | 
						|
     */
 | 
						|
    protected $alert;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Services\Users\UserCreationService
 | 
						|
     */
 | 
						|
    protected $creationService;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Services\Users\UserDeletionService
 | 
						|
     */
 | 
						|
    protected $deletionService;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Contracts\Repository\UserRepositoryInterface
 | 
						|
     */
 | 
						|
    protected $repository;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Illuminate\Contracts\Translation\Translator
 | 
						|
     */
 | 
						|
    protected $translator;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Services\Users\UserUpdateService
 | 
						|
     */
 | 
						|
    protected $updateService;
 | 
						|
 | 
						|
    /**
 | 
						|
     * UserController constructor.
 | 
						|
     */
 | 
						|
    public function __construct(
 | 
						|
        AlertsMessageBag $alert,
 | 
						|
        UserCreationService $creationService,
 | 
						|
        UserDeletionService $deletionService,
 | 
						|
        Translator $translator,
 | 
						|
        UserUpdateService $updateService,
 | 
						|
        UserRepositoryInterface $repository
 | 
						|
    ) {
 | 
						|
        $this->alert = $alert;
 | 
						|
        $this->creationService = $creationService;
 | 
						|
        $this->deletionService = $deletionService;
 | 
						|
        $this->repository = $repository;
 | 
						|
        $this->translator = $translator;
 | 
						|
        $this->updateService = $updateService;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Display user index page.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\View\View
 | 
						|
     */
 | 
						|
    public function index(Request $request)
 | 
						|
    {
 | 
						|
        $users = QueryBuilder::for(
 | 
						|
            User::query()->select('users.*')
 | 
						|
                ->selectRaw('COUNT(DISTINCT(subusers.id)) as subuser_of_count')
 | 
						|
                ->selectRaw('COUNT(DISTINCT(servers.id)) as servers_count')
 | 
						|
                ->leftJoin('subusers', 'subusers.user_id', '=', 'users.id')
 | 
						|
                ->leftJoin('servers', 'servers.owner_id', '=', 'users.id')
 | 
						|
                ->groupBy('users.id')
 | 
						|
        )
 | 
						|
            ->allowedFilters(['username', 'email', 'uuid'])
 | 
						|
            ->allowedSorts(['id', 'uuid'])
 | 
						|
            ->paginate(50);
 | 
						|
 | 
						|
        return view('admin.users.index', ['users' => $users]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Display new user page.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\View\View
 | 
						|
     */
 | 
						|
    public function create()
 | 
						|
    {
 | 
						|
        return view('admin.users.new', [
 | 
						|
            'languages' => $this->getAvailableLanguages(true),
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Display user view page.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\View\View
 | 
						|
     */
 | 
						|
    public function view(User $user)
 | 
						|
    {
 | 
						|
        return view('admin.users.view', [
 | 
						|
            'user' => $user,
 | 
						|
            'languages' => $this->getAvailableLanguages(true),
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Delete a user from the system.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Http\RedirectResponse
 | 
						|
     *
 | 
						|
     * @throws \Exception
 | 
						|
     * @throws \Pterodactyl\Exceptions\DisplayException
 | 
						|
     */
 | 
						|
    public function delete(Request $request, User $user)
 | 
						|
    {
 | 
						|
        if ($request->user()->id === $user->id) {
 | 
						|
            throw new DisplayException($this->translator->get('admin/user.exceptions.user_has_servers'));
 | 
						|
        }
 | 
						|
 | 
						|
        $this->deletionService->handle($user);
 | 
						|
 | 
						|
        return redirect()->route('admin.users');
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Create a user.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Http\RedirectResponse
 | 
						|
     *
 | 
						|
     * @throws \Exception
 | 
						|
     * @throws \Throwable
 | 
						|
     */
 | 
						|
    public function store(UserFormRequest $request)
 | 
						|
    {
 | 
						|
        $user = $this->creationService->handle($request->normalize());
 | 
						|
        $this->alert->success($this->translator->get('admin/user.notices.account_created'))->flash();
 | 
						|
 | 
						|
        return redirect()->route('admin.users.view', $user->id);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Update a user on the system.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Http\RedirectResponse
 | 
						|
     *
 | 
						|
     * @throws \Pterodactyl\Exceptions\Model\DataValidationException
 | 
						|
     * @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
 | 
						|
     */
 | 
						|
    public function update(UserFormRequest $request, User $user)
 | 
						|
    {
 | 
						|
        $this->updateService
 | 
						|
            ->setUserLevel(User::USER_LEVEL_ADMIN)
 | 
						|
            ->handle($user, $request->normalize());
 | 
						|
 | 
						|
        $this->alert->success(trans('admin/user.notices.account_updated'))->flash();
 | 
						|
 | 
						|
        return redirect()->route('admin.users.view', $user->id);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Get a JSON response of users on the system.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Support\Collection|\Pterodactyl\Models\Model
 | 
						|
     */
 | 
						|
    public function json(Request $request)
 | 
						|
    {
 | 
						|
        $users = QueryBuilder::for(User::query())->allowedFilters(['email'])->paginate(25);
 | 
						|
 | 
						|
        // Handle single user requests.
 | 
						|
        if ($request->query('user_id')) {
 | 
						|
            $user = User::query()->findOrFail($request->input('user_id'));
 | 
						|
            $user->md5 = md5(strtolower($user->email));
 | 
						|
 | 
						|
            return $user;
 | 
						|
        }
 | 
						|
 | 
						|
        return $users->map(function ($item) {
 | 
						|
            $item->md5 = md5(strtolower($item->email));
 | 
						|
 | 
						|
            return $item;
 | 
						|
        });
 | 
						|
    }
 | 
						|
}
 |