Skip to content

Commit b395440

Browse files
committed
Check that the selected daemon is online for a transfer, delete the server from the old node when a transfer is successful
1 parent 7b51832 commit b395440

File tree

3 files changed

+41
-16
lines changed

3 files changed

+41
-16
lines changed

app/Http/Controllers/Admin/Servers/ServerTransferController.php

Lines changed: 14 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,7 @@
1212
use Pterodactyl\Repositories\Eloquent\NodeRepository;
1313
use Pterodactyl\Repositories\Eloquent\ServerRepository;
1414
use Pterodactyl\Repositories\Eloquent\LocationRepository;
15+
use Pterodactyl\Repositories\Wings\DaemonConfigurationRepository;
1516
use Pterodactyl\Contracts\Repository\AllocationRepositoryInterface;
1617

1718
class ServerTransferController extends Controller
@@ -51,6 +52,11 @@ class ServerTransferController extends Controller
5152
*/
5253
private $transferService;
5354

55+
/**
56+
* @var \Pterodactyl\Repositories\Wings\DaemonConfigurationRepository
57+
*/
58+
private $daemonConfigurationRepository;
59+
5460
/**
5561
* ServerTransferController constructor.
5662
*
@@ -61,6 +67,7 @@ class ServerTransferController extends Controller
6167
* @param \Pterodactyl\Repositories\Eloquent\NodeRepository $nodeRepository
6268
* @param \Pterodactyl\Services\Servers\SuspensionService $suspensionService
6369
* @param \Pterodactyl\Services\Servers\TransferService $transferService
70+
* @param \Pterodactyl\Repositories\Wings\DaemonConfigurationRepository $daemonConfigurationRepository
6471
*/
6572
public function __construct(
6673
AlertsMessageBag $alert,
@@ -69,7 +76,8 @@ public function __construct(
6976
LocationRepository $locationRepository,
7077
NodeRepository $nodeRepository,
7178
SuspensionService $suspensionService,
72-
TransferService $transferService
79+
TransferService $transferService,
80+
DaemonConfigurationRepository $daemonConfigurationRepository
7381
) {
7482
$this->alert = $alert;
7583
$this->allocationRepository = $allocationRepository;
@@ -78,6 +86,7 @@ public function __construct(
7886
$this->nodeRepository = $nodeRepository;
7987
$this->suspensionService = $suspensionService;
8088
$this->transferService = $transferService;
89+
$this->daemonConfigurationRepository = $daemonConfigurationRepository;
8190
}
8291

8392
/**
@@ -104,6 +113,9 @@ public function transfer(Request $request, Server $server)
104113
// Check if the node is viable for the transfer.
105114
$node = $this->nodeRepository->getNodeWithResourceUsage($node_id);
106115
if ($node->isViable($server->memory, $server->disk)) {
116+
// Check if the selected daemon is online.
117+
$this->daemonConfigurationRepository->setNode($node)->getSystemInformation();
118+
107119
// Suspend the server and request an archive to be created.
108120
$this->suspensionService->toggle($server, 'suspend');
109121

@@ -123,7 +135,7 @@ public function transfer(Request $request, Server $server)
123135
// Add the allocations to the server so they cannot be automatically assigned while the transfer is in progress.
124136
$this->assignAllocationsToServer($server, $node_id, $allocation_id, $additional_allocations);
125137

126-
// Request an archive from the server's current daemon.
138+
// Request an archive from the server's current daemon. (this also checks if the daemon is online)
127139
$this->transferService->requestArchive($server);
128140

129141
$this->alert->success(trans('admin/server.alerts.transfer_started'))->flash();

app/Http/Controllers/Api/Remote/Servers/ServerTransferController.php

Lines changed: 26 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -6,15 +6,16 @@
66
use Lcobucci\JWT\Builder;
77
use Illuminate\Http\Request;
88
use Lcobucci\JWT\Signer\Key;
9+
use Psr\Log\LoggerInterface;
910
use Illuminate\Http\Response;
1011
use Illuminate\Http\JsonResponse;
11-
use Illuminate\Support\Facades\Log;
1212
use Lcobucci\JWT\Signer\Hmac\Sha256;
1313
use Illuminate\Database\ConnectionInterface;
1414
use Pterodactyl\Http\Controllers\Controller;
1515
use Pterodactyl\Services\Servers\SuspensionService;
1616
use Pterodactyl\Repositories\Eloquent\NodeRepository;
1717
use Pterodactyl\Repositories\Eloquent\ServerRepository;
18+
use Pterodactyl\Repositories\Wings\DaemonServerRepository;
1819
use Pterodactyl\Repositories\Wings\DaemonTransferRepository;
1920
use Pterodactyl\Contracts\Repository\AllocationRepositoryInterface;
2021
use Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException;
@@ -42,6 +43,11 @@ class ServerTransferController extends Controller
4243
*/
4344
private $nodeRepository;
4445

46+
/**
47+
* @var \Pterodactyl\Repositories\Wings\DaemonServerRepository
48+
*/
49+
private $daemonServerRepository;
50+
4551
/**
4652
* @var \Pterodactyl\Repositories\Wings\DaemonTransferRepository
4753
*/
@@ -57,33 +63,44 @@ class ServerTransferController extends Controller
5763
*/
5864
private $suspensionService;
5965

66+
/**
67+
* @var \Psr\Log\LoggerInterface
68+
*/
69+
private $writer;
70+
6071
/**
6172
* ServerTransferController constructor.
6273
*
6374
* @param \Illuminate\Database\ConnectionInterface $connection
6475
* @param \Pterodactyl\Repositories\Eloquent\ServerRepository $repository
6576
* @param \Pterodactyl\Contracts\Repository\AllocationRepositoryInterface $allocationRepository
6677
* @param \Pterodactyl\Repositories\Eloquent\NodeRepository $nodeRepository
78+
* @param \Pterodactyl\Repositories\Wings\DaemonServerRepository $daemonServerRepository
6779
* @param \Pterodactyl\Repositories\Wings\DaemonTransferRepository $daemonTransferRepository
6880
* @param \Pterodactyl\Services\Servers\ServerConfigurationStructureService $configurationStructureService
6981
* @param \Pterodactyl\Services\Servers\SuspensionService $suspensionService
82+
* @param \Psr\Log\LoggerInterface $writer
7083
*/
7184
public function __construct(
7285
ConnectionInterface $connection,
7386
ServerRepository $repository,
7487
AllocationRepositoryInterface $allocationRepository,
7588
NodeRepository $nodeRepository,
89+
DaemonServerRepository $daemonServerRepository,
7690
DaemonTransferRepository $daemonTransferRepository,
7791
ServerConfigurationStructureService $configurationStructureService,
78-
SuspensionService $suspensionService
92+
SuspensionService $suspensionService,
93+
LoggerInterface $writer
7994
) {
8095
$this->connection = $connection;
8196
$this->repository = $repository;
8297
$this->allocationRepository = $allocationRepository;
8398
$this->nodeRepository = $nodeRepository;
99+
$this->daemonServerRepository = $daemonServerRepository;
84100
$this->daemonTransferRepository = $daemonTransferRepository;
85101
$this->configurationStructureService = $configurationStructureService;
86102
$this->suspensionService = $suspensionService;
103+
$this->writer = $writer;
87104
}
88105

89106
/**
@@ -162,15 +179,9 @@ public function failure(string $uuid)
162179
$allocationIds = json_decode($transfer->new_additional_allocations);
163180
array_push($allocationIds, $transfer->new_allocation);
164181

165-
// Begin a transaction.
166-
$this->connection->beginTransaction();
167-
168182
// Remove the new allocations.
169183
$this->allocationRepository->updateWhereIn('id', $allocationIds, ['server_id' => null]);
170184

171-
// Commit the transaction.
172-
$this->connection->commit();
173-
174185
// Unsuspend the server.
175186
$this->suspensionService->toggle($server, 'unsuspend');
176187

@@ -190,8 +201,6 @@ public function success(string $uuid)
190201
$server = $this->repository->getByUuid($uuid);
191202
$transfer = $server->transfer;
192203

193-
// TODO: Notify old daemon about transfer and get it to remove server files.
194-
195204
$allocationIds = json_decode($transfer->old_additional_allocations);
196205
array_push($allocationIds, $transfer->old_allocation);
197206

@@ -213,11 +222,15 @@ public function success(string $uuid)
213222
// Commit the transaction.
214223
$this->connection->commit();
215224

225+
// Delete the server from the old node
226+
try {
227+
$this->daemonServerRepository->setServer($server)->delete();
228+
} catch (DaemonConnectionException $exception) {
229+
$this->writer->warning($exception);
230+
}
231+
216232
// Unsuspend the server
217233
$server->load('node');
218-
Log::debug(json_encode($server));
219-
Log::debug(json_encode($server->node_id));
220-
Log::debug(json_encode($server->node));
221234
$this->suspensionService->toggle($server, $this->suspensionService::ACTION_UNSUSPEND);
222235

223236
return JsonResponse::create([], Response::HTTP_NO_CONTENT);

app/Repositories/Eloquent/NodeRepository.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -183,7 +183,7 @@ public function getNodesForServerCreation(): Collection
183183
public function getNodeWithResourceUsage(int $node_id): Node
184184
{
185185
$instance = $this->getBuilder()
186-
->select(['nodes.id', 'nodes.memory', 'nodes.disk', 'nodes.memory_overallocate', 'nodes.disk_overallocate'])
186+
->select(['nodes.id', 'nodes.fqdn', 'nodes.scheme', 'nodes.daemonSecret', 'nodes.daemonListen', 'nodes.memory', 'nodes.disk', 'nodes.memory_overallocate', 'nodes.disk_overallocate'])
187187
->selectRaw('IFNULL(SUM(servers.memory), 0) as sum_memory, IFNULL(SUM(servers.disk), 0) as sum_disk')
188188
->leftJoin('servers', 'servers.node_id', '=', 'nodes.id')
189189
->where('nodes.id', $node_id);

0 commit comments

Comments
 (0)