Update to use new repository and standard laravel notation for controllers
This commit is contained in:
parent
62cd03d684
commit
26e4ff1f62
2 changed files with 28 additions and 24 deletions
|
@ -36,14 +36,13 @@ class CommandController extends ClientApiController
|
||||||
* Send a command to a running server.
|
* Send a command to a running server.
|
||||||
*
|
*
|
||||||
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\SendCommandRequest $request
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\SendCommandRequest $request
|
||||||
|
* @param \Pterodactyl\Models\Server $server
|
||||||
* @return \Illuminate\Http\Response
|
* @return \Illuminate\Http\Response
|
||||||
*
|
*
|
||||||
* @throws \Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException
|
* @throws \Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException
|
||||||
*/
|
*/
|
||||||
public function index(SendCommandRequest $request): Response
|
public function index(SendCommandRequest $request, Server $server): Response
|
||||||
{
|
{
|
||||||
$server = $request->getModel(Server::class);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$this->repository->setServer($server)->send($request->input('command'));
|
$this->repository->setServer($server)->send($request->input('command'));
|
||||||
} catch (RequestException $exception) {
|
} catch (RequestException $exception) {
|
||||||
|
|
|
@ -2,16 +2,15 @@
|
||||||
|
|
||||||
namespace Pterodactyl\Http\Controllers\Api\Client\Servers;
|
namespace Pterodactyl\Http\Controllers\Api\Client\Servers;
|
||||||
|
|
||||||
use Illuminate\Support\Str;
|
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
use Pterodactyl\Models\Server;
|
use Pterodactyl\Models\Server;
|
||||||
use Pterodactyl\Models\Database;
|
use Pterodactyl\Models\Database;
|
||||||
|
use Pterodactyl\Repositories\Eloquent\DatabaseRepository;
|
||||||
use Pterodactyl\Services\Databases\DatabasePasswordService;
|
use Pterodactyl\Services\Databases\DatabasePasswordService;
|
||||||
use Pterodactyl\Transformers\Api\Client\DatabaseTransformer;
|
use Pterodactyl\Transformers\Api\Client\DatabaseTransformer;
|
||||||
use Pterodactyl\Services\Databases\DatabaseManagementService;
|
use Pterodactyl\Services\Databases\DatabaseManagementService;
|
||||||
use Pterodactyl\Services\Databases\DeployServerDatabaseService;
|
use Pterodactyl\Services\Databases\DeployServerDatabaseService;
|
||||||
use Pterodactyl\Http\Controllers\Api\Client\ClientApiController;
|
use Pterodactyl\Http\Controllers\Api\Client\ClientApiController;
|
||||||
use Pterodactyl\Contracts\Repository\DatabaseRepositoryInterface;
|
|
||||||
use Pterodactyl\Http\Requests\Api\Client\Servers\Databases\GetDatabasesRequest;
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Databases\GetDatabasesRequest;
|
||||||
use Pterodactyl\Http\Requests\Api\Client\Servers\Databases\StoreDatabaseRequest;
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Databases\StoreDatabaseRequest;
|
||||||
use Pterodactyl\Http\Requests\Api\Client\Servers\Databases\DeleteDatabaseRequest;
|
use Pterodactyl\Http\Requests\Api\Client\Servers\Databases\DeleteDatabaseRequest;
|
||||||
|
@ -25,7 +24,7 @@ class DatabaseController extends ClientApiController
|
||||||
private $deployDatabaseService;
|
private $deployDatabaseService;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var \Pterodactyl\Contracts\Repository\DatabaseRepositoryInterface
|
* @var \Pterodactyl\Repositories\Eloquent\DatabaseRepository
|
||||||
*/
|
*/
|
||||||
private $repository;
|
private $repository;
|
||||||
|
|
||||||
|
@ -44,13 +43,13 @@ class DatabaseController extends ClientApiController
|
||||||
*
|
*
|
||||||
* @param \Pterodactyl\Services\Databases\DatabaseManagementService $managementService
|
* @param \Pterodactyl\Services\Databases\DatabaseManagementService $managementService
|
||||||
* @param \Pterodactyl\Services\Databases\DatabasePasswordService $passwordService
|
* @param \Pterodactyl\Services\Databases\DatabasePasswordService $passwordService
|
||||||
* @param \Pterodactyl\Contracts\Repository\DatabaseRepositoryInterface $repository
|
* @param \Pterodactyl\Repositories\Eloquent\DatabaseRepository $repository
|
||||||
* @param \Pterodactyl\Services\Databases\DeployServerDatabaseService $deployDatabaseService
|
* @param \Pterodactyl\Services\Databases\DeployServerDatabaseService $deployDatabaseService
|
||||||
*/
|
*/
|
||||||
public function __construct(
|
public function __construct(
|
||||||
DatabaseManagementService $managementService,
|
DatabaseManagementService $managementService,
|
||||||
DatabasePasswordService $passwordService,
|
DatabasePasswordService $passwordService,
|
||||||
DatabaseRepositoryInterface $repository,
|
DatabaseRepository $repository,
|
||||||
DeployServerDatabaseService $deployDatabaseService
|
DeployServerDatabaseService $deployDatabaseService
|
||||||
) {
|
) {
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
|
@ -62,12 +61,15 @@ class DatabaseController extends ClientApiController
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Return all of the databases that belong to the given server.
|
||||||
|
*
|
||||||
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Databases\GetDatabasesRequest $request
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Databases\GetDatabasesRequest $request
|
||||||
|
* @param \Pterodactyl\Models\Server $server
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
public function index(GetDatabasesRequest $request): array
|
public function index(GetDatabasesRequest $request, Server $server): array
|
||||||
{
|
{
|
||||||
$databases = $this->repository->getDatabasesForServer($request->getModel(Server::class)->id);
|
$databases = $this->repository->getDatabasesForServer($server->id);
|
||||||
|
|
||||||
return $this->fractal->collection($databases)
|
return $this->fractal->collection($databases)
|
||||||
->transformWith($this->getTransformer(DatabaseTransformer::class))
|
->transformWith($this->getTransformer(DatabaseTransformer::class))
|
||||||
|
@ -78,13 +80,14 @@ class DatabaseController extends ClientApiController
|
||||||
* Create a new database for the given server and return it.
|
* Create a new database for the given server and return it.
|
||||||
*
|
*
|
||||||
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Databases\StoreDatabaseRequest $request
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Databases\StoreDatabaseRequest $request
|
||||||
|
* @param \Pterodactyl\Models\Server $server
|
||||||
* @return array
|
* @return array
|
||||||
*
|
*
|
||||||
* @throws \Pterodactyl\Exceptions\Service\Database\DatabaseClientFeatureNotEnabledException
|
* @throws \Pterodactyl\Exceptions\Service\Database\DatabaseClientFeatureNotEnabledException
|
||||||
*/
|
*/
|
||||||
public function store(StoreDatabaseRequest $request): array
|
public function store(StoreDatabaseRequest $request, Server $server): array
|
||||||
{
|
{
|
||||||
$database = $this->deployDatabaseService->handle($request->getModel(Server::class), $request->validated());
|
$database = $this->deployDatabaseService->handle($server, $request->validated());
|
||||||
|
|
||||||
return $this->fractal->item($database)
|
return $this->fractal->item($database)
|
||||||
->parseIncludes(['password'])
|
->parseIncludes(['password'])
|
||||||
|
@ -97,17 +100,15 @@ class DatabaseController extends ClientApiController
|
||||||
* the caller.
|
* the caller.
|
||||||
*
|
*
|
||||||
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Databases\RotatePasswordRequest $request
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Databases\RotatePasswordRequest $request
|
||||||
|
* @param \Pterodactyl\Models\Server $server
|
||||||
|
* @param \Pterodactyl\Models\Database $database
|
||||||
* @return array
|
* @return array
|
||||||
*
|
*
|
||||||
* @throws \Pterodactyl\Exceptions\Model\DataValidationException
|
* @throws \Throwable
|
||||||
* @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
|
|
||||||
*/
|
*/
|
||||||
public function rotatePassword(RotatePasswordRequest $request)
|
public function rotatePassword(RotatePasswordRequest $request, Server $server, Database $database)
|
||||||
{
|
{
|
||||||
$database = $request->getModel(Database::class);
|
$this->passwordService->handle($database);
|
||||||
|
|
||||||
$this->passwordService->handle($database, Str::random(24));
|
|
||||||
|
|
||||||
$database->refresh();
|
$database->refresh();
|
||||||
|
|
||||||
return $this->fractal->item($database)
|
return $this->fractal->item($database)
|
||||||
|
@ -117,14 +118,18 @@ class DatabaseController extends ClientApiController
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Removes a database from the server.
|
||||||
|
*
|
||||||
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Databases\DeleteDatabaseRequest $request
|
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\Databases\DeleteDatabaseRequest $request
|
||||||
|
* @param \Pterodactyl\Models\Server $server
|
||||||
|
* @param \Pterodactyl\Models\Database $database
|
||||||
* @return \Illuminate\Http\Response
|
* @return \Illuminate\Http\Response
|
||||||
*
|
*
|
||||||
* @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
|
* @throws \Pterodactyl\Exceptions\Repository\RecordNotFoundException
|
||||||
*/
|
*/
|
||||||
public function delete(DeleteDatabaseRequest $request): Response
|
public function delete(DeleteDatabaseRequest $request, Server $server, Database $database): Response
|
||||||
{
|
{
|
||||||
$this->managementService->delete($request->getModel(Database::class)->id);
|
$this->managementService->delete($database->id);
|
||||||
|
|
||||||
return Response::create('', Response::HTTP_NO_CONTENT);
|
return Response::create('', Response::HTTP_NO_CONTENT);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue