mirror of
https://github.com/pyrohost/pyrodactyl.git
synced 2026-04-06 04:01:58 +02:00
179 lines
10 KiB
PHP
179 lines
10 KiB
PHP
<?php
|
|
|
|
use Illuminate\Support\Facades\Route;
|
|
use Pterodactyl\Http\Controllers\Api\Client;
|
|
use Pterodactyl\Http\Middleware\Activity\ServerSubject;
|
|
use Pterodactyl\Http\Middleware\Activity\AccountSubject;
|
|
use Pterodactyl\Http\Middleware\RequireTwoFactorAuthentication;
|
|
use Pterodactyl\Http\Middleware\Api\Client\Server\ResourceBelongsToServer;
|
|
use Pterodactyl\Http\Middleware\Api\Client\Server\AuthenticateServerAccess;
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Client Control API
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Endpoint: /api/client
|
|
|
|
|
*/
|
|
Route::get('/', [Client\ClientController::class, 'index'])->name('api:client.index');
|
|
Route::get('/permissions', [Client\ClientController::class, 'permissions']);
|
|
Route::get('/version', function () {
|
|
return response()->json(['version' => config('app.version')]);
|
|
});
|
|
|
|
Route::prefix('/nests')->group(function () {
|
|
Route::get('/', [Client\Nests\NestController::class, 'index'])->name('api:client.nests');
|
|
Route::get('/{nest}', [Client\Nests\NestController::class, 'view'])->name('api:client.nests.view');
|
|
});
|
|
|
|
Route::prefix('/account')->middleware(AccountSubject::class)->group(function () {
|
|
Route::prefix('/')->withoutMiddleware(RequireTwoFactorAuthentication::class)->group(function () {
|
|
Route::get('/', [Client\AccountController::class, 'index'])->name('api:client.account');
|
|
Route::get('/two-factor', [Client\TwoFactorController::class, 'index']);
|
|
Route::post('/two-factor', [Client\TwoFactorController::class, 'store']);
|
|
Route::post('/two-factor/disable', [Client\TwoFactorController::class, 'delete']);
|
|
});
|
|
|
|
Route::put('/email', [Client\AccountController::class, 'updateEmail'])->name('api:client.account.update-email');
|
|
Route::put('/password', [Client\AccountController::class, 'updatePassword'])->name('api:client.account.update-password');
|
|
|
|
Route::get('/activity', Client\ActivityLogController::class)->name('api:client.account.activity');
|
|
|
|
Route::get('/api-keys', [Client\ApiKeyController::class, 'index']);
|
|
Route::post('/api-keys', [Client\ApiKeyController::class, 'store']);
|
|
Route::delete('/api-keys/{identifier}', [Client\ApiKeyController::class, 'delete']);
|
|
|
|
Route::prefix('/ssh-keys')->group(function () {
|
|
Route::get('/', [Client\SSHKeyController::class, 'index']);
|
|
Route::post('/', [Client\SSHKeyController::class, 'store']);
|
|
Route::post('/remove', [Client\SSHKeyController::class, 'delete']);
|
|
});
|
|
});
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Client Control API
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Endpoint: /api/client/servers/{server}
|
|
|
|
|
*/
|
|
Route::group([
|
|
'prefix' => '/servers/{server}',
|
|
'middleware' => [
|
|
ServerSubject::class,
|
|
AuthenticateServerAccess::class,
|
|
ResourceBelongsToServer::class,
|
|
],
|
|
], function () {
|
|
Route::get('/', [Client\Servers\ServerController::class, 'index'])->name('api:client:server.view');
|
|
Route::get('/websocket', Client\Servers\WebsocketController::class)->name('api:client:server.ws');
|
|
Route::get('/resources', Client\Servers\ResourceUtilizationController::class)->name('api:client:server.resources');
|
|
Route::get('/activity', Client\Servers\ActivityLogController::class)->name('api:client:server.activity');
|
|
|
|
Route::post('/command', [Client\Servers\CommandController::class, 'index']);
|
|
Route::post('/power', [Client\Servers\PowerController::class, 'index']);
|
|
|
|
Route::group(['prefix' => '/databases'], function () {
|
|
Route::get('/', [Client\Servers\DatabaseController::class, 'index']);
|
|
Route::post('/', [Client\Servers\DatabaseController::class, 'store']);
|
|
Route::post('/{database}/rotate-password', [Client\Servers\DatabaseController::class, 'rotatePassword']);
|
|
Route::delete('/{database}', [Client\Servers\DatabaseController::class, 'delete']);
|
|
});
|
|
|
|
Route::group(['prefix' => '/files'], function () {
|
|
Route::get('/list', [Client\Servers\FileController::class, 'directory']);
|
|
Route::get('/contents', [Client\Servers\FileController::class, 'contents']);
|
|
Route::get('/download', [Client\Servers\FileController::class, 'download']);
|
|
Route::put('/rename', [Client\Servers\FileController::class, 'rename']);
|
|
Route::post('/copy', [Client\Servers\FileController::class, 'copy']);
|
|
Route::post('/write', [Client\Servers\FileController::class, 'write']);
|
|
Route::post('/compress', [Client\Servers\FileController::class, 'compress']);
|
|
Route::post('/decompress', [Client\Servers\FileController::class, 'decompress']);
|
|
Route::post('/delete', [Client\Servers\FileController::class, 'delete']);
|
|
Route::post('/create-folder', [Client\Servers\FileController::class, 'create']);
|
|
Route::post('/chmod', [Client\Servers\FileController::class, 'chmod']);
|
|
Route::post('/pull', [Client\Servers\FileController::class, 'pull'])->middleware(['throttle:10,5']);
|
|
Route::get('/upload', Client\Servers\FileUploadController::class);
|
|
});
|
|
|
|
Route::group(['prefix' => '/schedules'], function () {
|
|
Route::get('/', [Client\Servers\ScheduleController::class, 'index']);
|
|
Route::post('/', [Client\Servers\ScheduleController::class, 'store']);
|
|
Route::get('/{schedule}', [Client\Servers\ScheduleController::class, 'view']);
|
|
Route::post('/{schedule}', [Client\Servers\ScheduleController::class, 'update']);
|
|
Route::post('/{schedule}/execute', [Client\Servers\ScheduleController::class, 'execute']);
|
|
Route::delete('/{schedule}', [Client\Servers\ScheduleController::class, 'delete']);
|
|
|
|
Route::post('/{schedule}/tasks', [Client\Servers\ScheduleTaskController::class, 'store']);
|
|
Route::post('/{schedule}/tasks/{task}', [Client\Servers\ScheduleTaskController::class, 'update']);
|
|
Route::delete('/{schedule}/tasks/{task}', [Client\Servers\ScheduleTaskController::class, 'delete']);
|
|
});
|
|
|
|
Route::group(['prefix' => '/network'], function () {
|
|
Route::get('/allocations', [Client\Servers\NetworkAllocationController::class, 'index']);
|
|
Route::post('/allocations', [Client\Servers\NetworkAllocationController::class, 'store']);
|
|
Route::post('/allocations/{allocation}', [Client\Servers\NetworkAllocationController::class, 'update']);
|
|
Route::post('/allocations/{allocation}/primary', [Client\Servers\NetworkAllocationController::class, 'setPrimary']);
|
|
Route::delete('/allocations/{allocation}', [Client\Servers\NetworkAllocationController::class, 'delete']);
|
|
});
|
|
|
|
Route::group(['prefix' => '/subdomain'], function () {
|
|
Route::get('/', [Client\Servers\SubdomainController::class, 'index']);
|
|
Route::post('/', [Client\Servers\SubdomainController::class, 'store'])
|
|
->middleware('throttle:5,1'); // Max 5 creates/replaces per minute
|
|
Route::delete('/', [Client\Servers\SubdomainController::class, 'destroy'])
|
|
->middleware('throttle:5,1'); // Max 5 deletes per minute
|
|
Route::post('/check-availability', [Client\Servers\SubdomainController::class, 'checkAvailability'])
|
|
->middleware('throttle:20,1'); // Max 20 availability checks per minute
|
|
});
|
|
|
|
Route::group(['prefix' => '/users'], function () {
|
|
Route::get('/', [Client\Servers\SubuserController::class, 'index']);
|
|
Route::post('/', [Client\Servers\SubuserController::class, 'store']);
|
|
Route::get('/{user}', [Client\Servers\SubuserController::class, 'view']);
|
|
Route::post('/{user}', [Client\Servers\SubuserController::class, 'update']);
|
|
Route::delete('/{user}', [Client\Servers\SubuserController::class, 'delete']);
|
|
});
|
|
|
|
Route::group(['prefix' => '/backups'], function () {
|
|
Route::get('/', [Client\Servers\BackupController::class, 'index']);
|
|
Route::post('/', [Client\Servers\BackupController::class, 'store'])
|
|
->middleware('server.operation.rate-limit');
|
|
Route::get('/{backup}', [Client\Servers\BackupController::class, 'view']);
|
|
Route::get('/{backup}/download', [Client\Servers\BackupController::class, 'download']);
|
|
Route::post('/{backup}/lock', [Client\Servers\BackupController::class, 'toggleLock']);
|
|
Route::post('/{backup}/rename', [Client\Servers\BackupController::class, 'rename']);
|
|
Route::post('/{backup}/restore', [Client\Servers\BackupController::class, 'restore'])
|
|
->middleware('server.operation.rate-limit');
|
|
Route::delete('/{backup}', [Client\Servers\BackupController::class, 'delete']);
|
|
});
|
|
|
|
Route::group(['prefix' => '/startup'], function () {
|
|
Route::get('/', [Client\Servers\StartupController::class, 'index']);
|
|
Route::put('/variable', [Client\Servers\StartupController::class, 'update']);
|
|
Route::put('/command', [Client\Servers\StartupController::class, 'updateCommand']);
|
|
Route::get('/command/default', [Client\Servers\StartupController::class, 'getDefaultCommand']);
|
|
Route::post('/command/process', [Client\Servers\StartupController::class, 'processCommand']);
|
|
});
|
|
|
|
Route::group(['prefix' => '/settings'], function () {
|
|
Route::post('/rename', [Client\Servers\SettingsController::class, 'rename']);
|
|
Route::post('/reinstall', [Client\Servers\SettingsController::class, 'reinstall'])
|
|
->middleware('server.operation.rate-limit');
|
|
Route::put('/docker-image', [Client\Servers\SettingsController::class, 'dockerImage']);
|
|
Route::post('/docker-image/revert', [Client\Servers\SettingsController::class, 'revertDockerImage']);
|
|
Route::put('/egg', [Client\Servers\SettingsController::class, 'changeEgg']);
|
|
Route::post('/egg/preview', [Client\Servers\SettingsController::class, 'previewEggChange'])
|
|
->middleware('server.operation.rate-limit');
|
|
Route::post('/egg/apply', [Client\Servers\SettingsController::class, 'applyEggChange'])
|
|
->middleware('server.operation.rate-limit');
|
|
});
|
|
|
|
Route::group(['prefix' => '/operations'], function () {
|
|
Route::get('/', [Client\Servers\SettingsController::class, 'getServerOperations']);
|
|
Route::get('/{operationId}', [Client\Servers\SettingsController::class, 'getOperationStatus']);
|
|
});
|
|
});
|