mirror of
https://github.com/pterodactyl/panel.git
synced 2024-11-23 01:22:30 +01:00
115 lines
3.7 KiB
PHP
115 lines
3.7 KiB
PHP
<?php
|
|
|
|
namespace Pterodactyl\Services\Servers;
|
|
|
|
use Exception;
|
|
use Illuminate\Http\Response;
|
|
use Pterodactyl\Models\Server;
|
|
use Illuminate\Support\Facades\Log;
|
|
use Illuminate\Database\ConnectionInterface;
|
|
use Pterodactyl\Repositories\Wings\DaemonServerRepository;
|
|
use Pterodactyl\Services\Databases\DatabaseManagementService;
|
|
use Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException;
|
|
|
|
class ServerDeletionService
|
|
{
|
|
/**
|
|
* @var bool
|
|
*/
|
|
protected $force = false;
|
|
|
|
/**
|
|
* @var \Illuminate\Database\ConnectionInterface
|
|
*/
|
|
private $connection;
|
|
|
|
/**
|
|
* @var \Pterodactyl\Repositories\Wings\DaemonServerRepository
|
|
*/
|
|
private $daemonServerRepository;
|
|
|
|
/**
|
|
* @var \Pterodactyl\Services\Databases\DatabaseManagementService
|
|
*/
|
|
private $databaseManagementService;
|
|
|
|
/**
|
|
* DeletionService constructor.
|
|
*
|
|
* @param \Illuminate\Database\ConnectionInterface $connection
|
|
* @param \Pterodactyl\Repositories\Wings\DaemonServerRepository $daemonServerRepository
|
|
* @param \Pterodactyl\Services\Databases\DatabaseManagementService $databaseManagementService
|
|
*/
|
|
public function __construct(
|
|
ConnectionInterface $connection,
|
|
DaemonServerRepository $daemonServerRepository,
|
|
DatabaseManagementService $databaseManagementService
|
|
) {
|
|
$this->connection = $connection;
|
|
$this->daemonServerRepository = $daemonServerRepository;
|
|
$this->databaseManagementService = $databaseManagementService;
|
|
}
|
|
|
|
/**
|
|
* Set if the server should be forcibly deleted from the panel (ignoring daemon errors) or not.
|
|
*
|
|
* @param bool $bool
|
|
* @return $this
|
|
*/
|
|
public function withForce($bool = true)
|
|
{
|
|
$this->force = $bool;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Delete a server from the panel and remove any associated databases from hosts.
|
|
*
|
|
* @param \Pterodactyl\Models\Server $server
|
|
*
|
|
* @throws \Throwable
|
|
* @throws \Pterodactyl\Exceptions\DisplayException
|
|
*/
|
|
public function handle(Server $server)
|
|
{
|
|
try {
|
|
$this->daemonServerRepository->setServer($server)->delete();
|
|
} catch (DaemonConnectionException $exception) {
|
|
// If there is an error not caused a 404 error and this isn't a forced delete,
|
|
// go ahead and bail out. We specifically ignore a 404 since that can be assumed
|
|
// to be a safe error, meaning the server doesn't exist at all on Wings so there
|
|
// is no reason we need to bail out from that.
|
|
if (! $this->force && $exception->getStatusCode() !== Response::HTTP_NOT_FOUND) {
|
|
throw $exception;
|
|
}
|
|
|
|
Log::warning($exception);
|
|
}
|
|
|
|
$this->connection->transaction(function () use ($server) {
|
|
foreach ($server->databases as $database) {
|
|
try {
|
|
$this->databaseManagementService->delete($database);
|
|
} catch (Exception $exception) {
|
|
if (!$this->force) {
|
|
throw $exception;
|
|
}
|
|
|
|
// Oh well, just try to delete the database entry we have from the database
|
|
// so that the server itself can be deleted. This will leave it dangling on
|
|
// the host instance, but we couldn't delete it anyways so not sure how we would
|
|
// handle this better anyways.
|
|
//
|
|
// @see https://github.com/pterodactyl/panel/issues/2085
|
|
$database->delete();
|
|
|
|
Log::warning($exception);
|
|
}
|
|
}
|
|
|
|
$server->delete();
|
|
});
|
|
}
|
|
}
|