Skip to content

Commit fb9c106

Browse files
committed
Update server listing and associated logic to pull from the panel dynamiacally
1 parent 952dff8 commit fb9c106

26 files changed

+384
-239
lines changed

app/Http/Controllers/Api/Application/ApplicationApiController.php

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@
55
use Illuminate\Http\Request;
66
use Webmozart\Assert\Assert;
77
use Illuminate\Http\Response;
8+
use Illuminate\Support\Collection;
89
use Illuminate\Container\Container;
910
use Pterodactyl\Http\Controllers\Controller;
1011
use Pterodactyl\Extensions\Spatie\Fractalistic\Fractal;
@@ -30,7 +31,10 @@ public function __construct()
3031
Container::getInstance()->call([$this, 'loadDependencies']);
3132

3233
// Parse all of the includes to use on this request.
33-
$includes = collect(explode(',', $this->request->input('include', '')))->map(function ($value) {
34+
$input = $this->request->input('include', []);
35+
$input = is_array($input) ? $input : explode(',', $input);
36+
37+
$includes = (new Collection($input))->map(function ($value) {
3438
return trim($value);
3539
})->filter()->toArray();
3640

app/Http/Controllers/Api/Client/ClientController.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -52,7 +52,7 @@ public function index(GetServersRequest $request): array
5252
break;
5353
}
5454

55-
$servers = $this->repository->
55+
$servers = $this->repository
5656
->setSearchTerm($request->input('query'))
5757
->filterUserAccessServers(
5858
$request->user(), $filter, config('pterodactyl.paginate.frontend.servers')

app/Http/Controllers/Api/Client/Servers/ResourceUtilizationController.php

Lines changed: 26 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -3,21 +3,45 @@
33
namespace Pterodactyl\Http\Controllers\Api\Client\Servers;
44

55
use Pterodactyl\Models\Server;
6+
use Pterodactyl\Repositories\Wings\WingsServerRepository;
67
use Pterodactyl\Transformers\Api\Client\StatsTransformer;
78
use Pterodactyl\Http\Controllers\Api\Client\ClientApiController;
89
use Pterodactyl\Http\Requests\Api\Client\Servers\GetServerRequest;
910

1011
class ResourceUtilizationController extends ClientApiController
1112
{
13+
/**
14+
* @var \Pterodactyl\Repositories\Wings\WingsServerRepository
15+
*/
16+
private $repository;
17+
18+
/**
19+
* ResourceUtilizationController constructor.
20+
*
21+
* @param \Pterodactyl\Repositories\Wings\WingsServerRepository $repository
22+
*/
23+
public function __construct(WingsServerRepository $repository)
24+
{
25+
parent::__construct();
26+
27+
$this->repository = $repository;
28+
}
29+
1230
/**
1331
* Return the current resource utilization for a server.
1432
*
1533
* @param \Pterodactyl\Http\Requests\Api\Client\Servers\GetServerRequest $request
1634
* @return array
35+
*
36+
* @throws \Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException
1737
*/
18-
public function index(GetServerRequest $request): array
38+
public function __invoke(GetServerRequest $request): array
1939
{
20-
return $this->fractal->item($request->getModel(Server::class))
40+
$stats = $this->repository
41+
->setServer($request->getModel(Server::class))
42+
->getDetails();
43+
44+
return $this->fractal->item($stats)
2145
->transformWith($this->getTransformer(StatsTransformer::class))
2246
->toArray();
2347
}

app/Http/Controllers/Base/IndexController.php

Lines changed: 3 additions & 56 deletions
Original file line numberDiff line numberDiff line change
@@ -4,27 +4,11 @@
44

55
use Illuminate\Http\Request;
66
use Pterodactyl\Models\User;
7-
use Illuminate\Http\Response;
8-
use GuzzleHttp\Exception\ConnectException;
9-
use GuzzleHttp\Exception\RequestException;
107
use Pterodactyl\Http\Controllers\Controller;
11-
use Symfony\Component\HttpKernel\Exception\HttpException;
12-
use Pterodactyl\Services\DaemonKeys\DaemonKeyProviderService;
138
use Pterodactyl\Contracts\Repository\ServerRepositoryInterface;
14-
use Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface as DaemonServerRepositoryInterface;
159

1610
class IndexController extends Controller
1711
{
18-
/**
19-
* @var \Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface
20-
*/
21-
protected $daemonRepository;
22-
23-
/**
24-
* @var \Pterodactyl\Services\DaemonKeys\DaemonKeyProviderService
25-
*/
26-
protected $keyProviderService;
27-
2812
/**
2913
* @var \Pterodactyl\Contracts\Repository\ServerRepositoryInterface
3014
*/
@@ -33,17 +17,10 @@ class IndexController extends Controller
3317
/**
3418
* IndexController constructor.
3519
*
36-
* @param \Pterodactyl\Services\DaemonKeys\DaemonKeyProviderService $keyProviderService
37-
* @param \Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface $daemonRepository
38-
* @param \Pterodactyl\Contracts\Repository\ServerRepositoryInterface $repository
20+
* @param \Pterodactyl\Contracts\Repository\ServerRepositoryInterface $repository
3921
*/
40-
public function __construct(
41-
DaemonKeyProviderService $keyProviderService,
42-
DaemonServerRepositoryInterface $daemonRepository,
43-
ServerRepositoryInterface $repository
44-
) {
45-
$this->daemonRepository = $daemonRepository;
46-
$this->keyProviderService = $keyProviderService;
22+
public function __construct(ServerRepositoryInterface $repository)
23+
{
4724
$this->repository = $repository;
4825
}
4926

@@ -61,34 +38,4 @@ public function index(Request $request)
6138

6239
return view('templates/base.core', ['servers' => $servers]);
6340
}
64-
65-
/**
66-
* Returns status of the server in a JSON response used for populating active status list.
67-
*
68-
* @param \Illuminate\Http\Request $request
69-
* @param string $uuid
70-
* @return \Illuminate\Http\JsonResponse
71-
* @throws \Exception
72-
*/
73-
public function status(Request $request, $uuid)
74-
{
75-
$server = $this->repository->findFirstWhere([['uuidShort', '=', $uuid]]);
76-
$token = $this->keyProviderService->handle($server, $request->user());
77-
78-
if (! $server->installed) {
79-
return response()->json(['status' => 20]);
80-
} elseif ($server->suspended) {
81-
return response()->json(['status' => 30]);
82-
}
83-
84-
try {
85-
$response = $this->daemonRepository->setServer($server)->setToken($token)->details();
86-
} catch (ConnectException $exception) {
87-
throw new HttpException(Response::HTTP_GATEWAY_TIMEOUT, $exception->getMessage());
88-
} catch (RequestException $exception) {
89-
throw new HttpException(500, $exception->getMessage());
90-
}
91-
92-
return response()->json(json_decode($response->getBody()));
93-
}
9441
}

app/Models/Server.php

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,50 @@
1111
use Sofa\Eloquence\Contracts\CleansAttributes;
1212
use Sofa\Eloquence\Contracts\Validable as ValidableContract;
1313

14+
/**
15+
* @property int $id
16+
* @property string|null $external_id
17+
* @property string $uuid
18+
* @property string $uuidShort
19+
* @property int $node_id
20+
* @property string $name
21+
* @property string $description
22+
* @property bool $skip_scripts
23+
* @property bool $suspended
24+
* @property int $owner_id
25+
* @property int $memory
26+
* @property int $swap
27+
* @property int $disk
28+
* @property int $io
29+
* @property int $cpu
30+
* @property bool $oom_disabled
31+
* @property int $allocation_id
32+
* @property int $nest_id
33+
* @property int $egg_id
34+
* @property int|null $pack_id
35+
* @property string $startup
36+
* @property string $image
37+
* @property int $installed
38+
* @property int $allocation_limit
39+
* @property int $database_limit
40+
* @property \Carbon\Carbon $created_at
41+
* @property \Carbon\Carbon $updated_at
42+
*
43+
* @property \Pterodactyl\Models\User $user
44+
* @property \Pterodactyl\Models\User[]|\Illuminate\Support\Collection $subusers
45+
* @property \Pterodactyl\Models\Allocation $allocation
46+
* @property \Pterodactyl\Models\Allocation[]|\Illuminate\Support\Collection $allocations
47+
* @property \Pterodactyl\Models\Pack|null $pack
48+
* @property \Pterodactyl\Models\Node $node
49+
* @property \Pterodactyl\Models\Nest $nest
50+
* @property \Pterodactyl\Models\Egg $egg
51+
* @property \Pterodactyl\Models\EggVariable[]|\Illuminate\Support\Collection $variables
52+
* @property \Pterodactyl\Models\Schedule[]|\Illuminate\Support\Collection $schedule
53+
* @property \Pterodactyl\Models\Database[]|\Illuminate\Support\Collection $databases
54+
* @property \Pterodactyl\Models\Location $location
55+
* @property \Pterodactyl\Models\DaemonKey $key
56+
* @property \Pterodactyl\Models\DaemonKey[]|\Illuminate\Support\Collection $keys
57+
*/
1458
class Server extends Model implements CleansAttributes, ValidableContract
1559
{
1660
use BelongsToThrough, Eloquence, Notifiable, Validable;

app/Providers/RepositoryServiceProvider.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -51,7 +51,7 @@
5151
use Pterodactyl\Contracts\Repository\Daemon\CommandRepositoryInterface;
5252
use Pterodactyl\Contracts\Repository\ServerVariableRepositoryInterface;
5353
use Pterodactyl\Contracts\Repository\Daemon\ConfigurationRepositoryInterface;
54-
use Pterodactyl\Repositories\Daemon\ServerRepository as DaemonServerRepository;
54+
use Pterodactyl\Repositories\Wings\WingsServerRepository as DaemonServerRepository;
5555
use Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface as DaemonServerRepositoryInterface;
5656

5757
class RepositoryServiceProvider extends ServiceProvider
Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
<?php
2+
3+
namespace Pterodactyl\Repositories\Wings;
4+
5+
use GuzzleHttp\Exception\TransferException;
6+
use Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException;
7+
8+
class WingsServerRepository extends BaseWingsRepository
9+
{
10+
/**
11+
* Returns details about a server from the Daemon instance.
12+
*
13+
* @return array
14+
* @throws \Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException
15+
*/
16+
public function getDetails(): array
17+
{
18+
try {
19+
$response = $this->getHttpClient()->get(
20+
sprintf('/api/servers/%s', $this->getServer()->uuid)
21+
);
22+
} catch (TransferException $exception) {
23+
throw new DaemonConnectionException($exception);
24+
}
25+
26+
return json_decode($response->getBody()->__toString(), true);
27+
}
28+
}

app/Transformers/Api/Client/StatsTransformer.php

Lines changed: 11 additions & 68 deletions
Original file line numberDiff line numberDiff line change
@@ -2,28 +2,10 @@
22

33
namespace Pterodactyl\Transformers\Api\Client;
44

5-
use Pterodactyl\Models\Server;
6-
use GuzzleHttp\Exception\RequestException;
7-
use Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException;
8-
use Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface;
5+
use Illuminate\Support\Arr;
96

107
class StatsTransformer extends BaseClientTransformer
118
{
12-
/**
13-
* @var \Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface
14-
*/
15-
private $repository;
16-
17-
/**
18-
* Perform dependency injection.
19-
*
20-
* @param \Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface $repository
21-
*/
22-
public function handle(ServerRepositoryInterface $repository)
23-
{
24-
$this->repository = $repository;
25-
}
26-
279
/**
2810
* @return string
2911
*/
@@ -36,60 +18,21 @@ public function getResourceName(): string
3618
* Transform stats from the daemon into a result set that can be used in
3719
* the client API.
3820
*
39-
* @param \Pterodactyl\Models\Server $model
21+
* @param array $data
4022
* @return array
41-
*
42-
* @throws \Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException
4323
*/
44-
public function transform(Server $model)
24+
public function transform(array $data)
4525
{
46-
try {
47-
$stats = $this->repository->setServer($model)->details();
48-
} catch (RequestException $exception) {
49-
throw new DaemonConnectionException($exception);
50-
}
51-
52-
$object = json_decode($stats->getBody()->getContents());
53-
5426
return [
55-
'state' => $this->transformState(object_get($object, 'status', 0)),
56-
'memory' => [
57-
'current' => round(object_get($object, 'proc.memory.total', 0) / 1024 / 1024),
58-
'limit' => floatval($model->memory),
59-
],
60-
'cpu' => [
61-
'current' => object_get($object, 'proc.cpu.total', 0),
62-
'cores' => object_get($object, 'proc.cpu.cores', []),
63-
'limit' => floatval($model->cpu),
64-
],
65-
'disk' => [
66-
'current' => round(object_get($object, 'proc.disk.used', 0)),
67-
'limit' => floatval($model->disk),
68-
'io' => $model->io,
27+
'current_state' => Arr::get($data, 'state', 'stopped'),
28+
'is_suspended' => Arr::get($data, 'suspended', false),
29+
'resources' => [
30+
'memory_bytes' => Arr::get($data, 'resources.memory_bytes', 0),
31+
'cpu_absolute' => Arr::get($data, 'resources.cpu_absolute', 0),
32+
'disk_bytes' => Arr::get($data, 'resources.disk_bytes', 0),
33+
'network_rx_bytes' => Arr::get($data, 'resources.network.rx_bytes', 0),
34+
'network_tx_bytes' => Arr::get($data, 'resources.network.tx_bytes', 0),
6935
],
70-
'installed' => $model->installed === 1,
71-
'suspended' => (bool) $model->suspended,
7236
];
7337
}
74-
75-
/**
76-
* Transform the state returned by the daemon into a human readable string.
77-
*
78-
* @param int $state
79-
* @return string
80-
*/
81-
private function transformState(int $state): string
82-
{
83-
switch ($state) {
84-
case 1:
85-
return 'on';
86-
case 2:
87-
return 'starting';
88-
case 3:
89-
return 'stopping';
90-
case 0:
91-
default:
92-
return 'off';
93-
}
94-
}
9538
}
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
import { rawDataToServerObject, Server } from '@/api/server/getServer';
2+
import http, { getPaginationSet, PaginatedResult } from '@/api/http';
3+
4+
export default (): Promise<PaginatedResult<Server>> => {
5+
return new Promise((resolve, reject) => {
6+
http.get(`/api/client`, { params: { include: [ 'allocation' ] } })
7+
.then(({ data }) => resolve({
8+
items: (data.data || []).map((datum: any) => rawDataToServerObject(datum.attributes)),
9+
pagination: getPaginationSet(data.meta.pagination),
10+
}))
11+
.catch(reject);
12+
});
13+
};

0 commit comments

Comments
 (0)