Skip to content

Commit 32f2517

Browse files
committed
Pass at removing extraneous permissions table and using native MySQL JSON
1 parent 23d594f commit 32f2517

File tree

7 files changed

+132
-32
lines changed

7 files changed

+132
-32
lines changed

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

Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3,12 +3,31 @@
33
namespace Pterodactyl\Http\Controllers\Api\Client\Servers;
44

55
use Pterodactyl\Models\Server;
6+
use Pterodactyl\Repositories\Eloquent\SubuserRepository;
67
use Pterodactyl\Transformers\Api\Client\ServerTransformer;
8+
use Pterodactyl\Exceptions\Repository\RecordNotFoundException;
79
use Pterodactyl\Http\Controllers\Api\Client\ClientApiController;
810
use Pterodactyl\Http\Requests\Api\Client\Servers\GetServerRequest;
911

1012
class ServerController extends ClientApiController
1113
{
14+
/**
15+
* @var \Pterodactyl\Repositories\Eloquent\SubuserRepository
16+
*/
17+
private $repository;
18+
19+
/**
20+
* ServerController constructor.
21+
*
22+
* @param \Pterodactyl\Repositories\Eloquent\SubuserRepository $repository
23+
*/
24+
public function __construct(SubuserRepository $repository)
25+
{
26+
parent::__construct();
27+
28+
$this->repository = $repository;
29+
}
30+
1231
/**
1332
* Transform an individual server into a response that can be consumed by a
1433
* client using the API.
@@ -19,8 +38,21 @@ class ServerController extends ClientApiController
1938
*/
2039
public function index(GetServerRequest $request, Server $server): array
2140
{
41+
try {
42+
$permissions = $this->repository->findFirstWhere([
43+
'server_id' => $server->id,
44+
'user_id' => $request->user()->id,
45+
])->permissions;
46+
} catch (RecordNotFoundException $exception) {
47+
$permissions = [];
48+
}
49+
2250
return $this->fractal->item($server)
2351
->transformWith($this->getTransformer(ServerTransformer::class))
52+
->addMeta([
53+
'is_server_owner' => $request->user()->id === $server->owner_id,
54+
'user_permissions' => $permissions,
55+
])
2456
->toArray();
2557
}
2658
}

app/Models/Permission.php

Lines changed: 0 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -286,28 +286,4 @@ public static function getPermissions($array = false)
286286

287287
return collect(self::$deprecatedPermissions);
288288
}
289-
290-
/**
291-
* Find permission by permission node.
292-
*
293-
* @param \Illuminate\Database\Query\Builder $query
294-
* @param string $permission
295-
* @return \Illuminate\Database\Query\Builder
296-
*/
297-
public function scopePermission($query, $permission)
298-
{
299-
return $query->where('permission', $permission);
300-
}
301-
302-
/**
303-
* Filter permission by server.
304-
*
305-
* @param \Illuminate\Database\Query\Builder $query
306-
* @param \Pterodactyl\Models\Server $server
307-
* @return \Illuminate\Database\Query\Builder
308-
*/
309-
public function scopeServer($query, Server $server)
310-
{
311-
return $query->where('server_id', $server->id);
312-
}
313289
}

app/Models/Subuser.php

Lines changed: 6 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -8,12 +8,12 @@
88
* @property int $id
99
* @property int $user_id
1010
* @property int $server_id
11+
* @property array $permissions
1112
* @property \Carbon\Carbon $created_at
1213
* @property \Carbon\Carbon $updated_at
1314
*
1415
* @property \Pterodactyl\Models\User $user
1516
* @property \Pterodactyl\Models\Server $server
16-
* @property \Pterodactyl\Models\Permission[]|\Illuminate\Database\Eloquent\Collection $permissions
1717
*/
1818
class Subuser extends Validable
1919
{
@@ -45,8 +45,9 @@ class Subuser extends Validable
4545
* @var array
4646
*/
4747
protected $casts = [
48-
'user_id' => 'integer',
49-
'server_id' => 'integer',
48+
'user_id' => 'int',
49+
'server_id' => 'int',
50+
'permissions' => 'array',
5051
];
5152

5253
/**
@@ -55,6 +56,8 @@ class Subuser extends Validable
5556
public static $validationRules = [
5657
'user_id' => 'required|numeric|exists:users,id',
5758
'server_id' => 'required|numeric|exists:servers,id',
59+
'permissions' => 'nullable|array',
60+
'permissions.*' => 'string',
5861
];
5962

6063
/**

app/Providers/RepositoryServiceProvider.php

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,6 @@
2121
use Pterodactyl\Repositories\Wings\DaemonPowerRepository;
2222
use Pterodactyl\Repositories\Eloquent\DaemonKeyRepository;
2323
use Pterodactyl\Repositories\Eloquent\AllocationRepository;
24-
use Pterodactyl\Repositories\Eloquent\PermissionRepository;
2524
use Pterodactyl\Repositories\Wings\DaemonCommandRepository;
2625
use Pterodactyl\Contracts\Repository\EggRepositoryInterface;
2726
use Pterodactyl\Repositories\Eloquent\EggVariableRepository;
@@ -43,7 +42,6 @@
4342
use Pterodactyl\Repositories\Wings\DaemonConfigurationRepository;
4443
use Pterodactyl\Contracts\Repository\DaemonKeyRepositoryInterface;
4544
use Pterodactyl\Contracts\Repository\AllocationRepositoryInterface;
46-
use Pterodactyl\Contracts\Repository\PermissionRepositoryInterface;
4745
use Pterodactyl\Contracts\Repository\Daemon\FileRepositoryInterface;
4846
use Pterodactyl\Contracts\Repository\EggVariableRepositoryInterface;
4947
use Pterodactyl\Contracts\Repository\Daemon\PowerRepositoryInterface;
@@ -73,7 +71,6 @@ public function register()
7371
$this->app->bind(NestRepositoryInterface::class, NestRepository::class);
7472
$this->app->bind(NodeRepositoryInterface::class, NodeRepository::class);
7573
$this->app->bind(PackRepositoryInterface::class, PackRepository::class);
76-
$this->app->bind(PermissionRepositoryInterface::class, PermissionRepository::class);
7774
$this->app->bind(ScheduleRepositoryInterface::class, ScheduleRepository::class);
7875
$this->app->bind(ServerRepositoryInterface::class, ServerRepository::class);
7976
$this->app->bind(ServerVariableRepositoryInterface::class, ServerVariableRepository::class);

app/Repositories/Eloquent/PermissionRepository.php

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22

33
namespace Pterodactyl\Repositories\Eloquent;
44

5-
use Pterodactyl\Models\Permission;
5+
use Exception;
66
use Pterodactyl\Contracts\Repository\PermissionRepositoryInterface;
77

88
class PermissionRepository extends EloquentRepository implements PermissionRepositoryInterface
@@ -11,9 +11,10 @@ class PermissionRepository extends EloquentRepository implements PermissionRepos
1111
* Return the model backing this repository.
1212
*
1313
* @return string
14+
* @throws \Exception
1415
*/
1516
public function model()
1617
{
17-
return Permission::class;
18+
throw new Exception('This functionality is not implemented.');
1819
}
1920
}
Lines changed: 57 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,57 @@
1+
<?php
2+
3+
use Illuminate\Support\Facades\DB;
4+
use Illuminate\Support\Facades\Schema;
5+
use Illuminate\Database\Schema\Blueprint;
6+
use Illuminate\Database\Migrations\Migration;
7+
8+
class MergePermissionsTableIntoSubusers extends Migration
9+
{
10+
/**
11+
* Run the migrations.
12+
*
13+
* @return void
14+
*/
15+
public function up()
16+
{
17+
Schema::table('subusers', function (Blueprint $table) {
18+
$table->json('permissions')->nullable()->after('server_id');
19+
});
20+
21+
DB::statement('
22+
UPDATE subusers as s
23+
LEFT JOIN (
24+
SELECT subuser_id, JSON_ARRAYAGG(permission) as permissions
25+
FROM permissions
26+
GROUP BY subuser_id
27+
) as p ON p.subuser_id = s.id
28+
SET s.permissions = p.permissions
29+
');
30+
}
31+
32+
/**
33+
* Reverse the migrations.
34+
*
35+
* @return void
36+
*/
37+
public function down()
38+
{
39+
foreach (DB::select('SELECT id, permissions FROM subusers') as $datum) {
40+
$values = [];
41+
foreach(json_decode($datum->permissions, true) as $permission) {
42+
$values[] = $datum->id;
43+
$values[] = $permission;
44+
}
45+
46+
if (!empty($values)) {
47+
$string = 'VALUES ' . implode(', ', array_fill(0, count($values) / 2, '(?, ?)'));
48+
49+
DB::insert('INSERT INTO permissions(`subuser_id`, `permission`) ' . $string, $values);
50+
}
51+
}
52+
53+
Schema::table('subusers', function (Blueprint $table) {
54+
$table->dropColumn('permissions');
55+
});
56+
}
57+
}
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
<?php
2+
3+
use Illuminate\Support\Facades\Schema;
4+
use Illuminate\Database\Schema\Blueprint;
5+
use Illuminate\Database\Migrations\Migration;
6+
7+
class DropPermissionsTable extends Migration
8+
{
9+
/**
10+
* Run the migrations.
11+
*
12+
* @return void
13+
*/
14+
public function up()
15+
{
16+
Schema::dropIfExists('permissions');
17+
}
18+
19+
/**
20+
* Reverse the migrations.
21+
*
22+
* @return void
23+
*/
24+
public function down()
25+
{
26+
Schema::create('permissions', function (Blueprint $table) {
27+
$table->increments('id');
28+
$table->unsignedInteger('subuser_id');
29+
$table->string('permission');
30+
31+
$table->foreign('subuser_id')->references('id')->on('subusers')->onDelete('cascade');
32+
});
33+
}
34+
}

0 commit comments

Comments
 (0)