Merge pull request #371 from Pterodactyl/feature/fractal-api
Implement new API and Route Updates
This commit is contained in:
commit
db168e34bd
73 changed files with 3914 additions and 2671 deletions
|
@ -21,7 +21,6 @@
|
|||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
Route::get('/', 'BaseController@getIndex')->name('admin.index');
|
||||
|
||||
/*
|
||||
|
@ -79,15 +78,15 @@ Route::group(['prefix' => 'settings'], function () {
|
|||
|
|
||||
*/
|
||||
Route::group(['prefix' => 'users'], function () {
|
||||
Route::get('/', 'UserController@getIndex')->name('admin.users');
|
||||
Route::get('/accounts.json', 'UserController@getJson')->name('admin.users.json');
|
||||
Route::get('/new', 'UserController@getNew')->name('admin.users.new');
|
||||
Route::get('/view/{id}', 'UserController@getView')->name('admin.users.view');
|
||||
Route::get('/', 'UserController@index')->name('admin.users');
|
||||
Route::get('/accounts.json', 'UserController@json')->name('admin.users.json');
|
||||
Route::get('/new', 'UserController@create')->name('admin.users.new');
|
||||
Route::get('/view/{id}', 'UserController@view')->name('admin.users.view');
|
||||
|
||||
Route::post('/new', 'UserController@postNew');
|
||||
Route::post('/view/{id}', 'UserController@updateUser');
|
||||
Route::post('/new', 'UserController@store');
|
||||
Route::post('/view/{id}', 'UserController@update');
|
||||
|
||||
Route::delete('/view/{id}', 'UserController@deleteUser');
|
||||
Route::delete('/view/{id}', 'UserController@delete');
|
||||
});
|
||||
|
||||
/*
|
||||
|
@ -100,8 +99,8 @@ Route::group(['prefix' => 'users'], function () {
|
|||
*/
|
||||
Route::group(['prefix' => 'servers'], function () {
|
||||
Route::get('/', 'ServersController@index')->name('admin.servers');
|
||||
Route::get('/new', 'ServersController@new')->name('admin.servers.new');
|
||||
Route::get('/new/nodes', 'ServersController@newServerNodes')->name('admin.servers.new.nodes');
|
||||
Route::get('/new', 'ServersController@create')->name('admin.servers.new');
|
||||
Route::get('/new/nodes', 'ServersController@nodes')->name('admin.servers.new.nodes');
|
||||
Route::get('/view/{id}', 'ServersController@viewIndex')->name('admin.servers.view');
|
||||
Route::get('/view/{id}/details', 'ServersController@viewDetails')->name('admin.servers.view.details');
|
||||
Route::get('/view/{id}/build', 'ServersController@viewBuild')->name('admin.servers.view.build');
|
||||
|
@ -110,7 +109,7 @@ Route::group(['prefix' => 'servers'], function () {
|
|||
Route::get('/view/{id}/manage', 'ServersController@viewManage')->name('admin.servers.view.manage');
|
||||
Route::get('/view/{id}/delete', 'ServersController@viewDelete')->name('admin.servers.view.delete');
|
||||
|
||||
Route::post('/new', 'ServersController@create');
|
||||
Route::post('/new', 'ServersController@store');
|
||||
Route::post('/view/{id}/details', 'ServersController@setDetails');
|
||||
Route::post('/view/{id}/details/container', 'ServersController@setContainer')->name('admin.servers.view.details.container');
|
||||
Route::post('/view/{id}/build', 'ServersController@updateBuild');
|
||||
|
@ -136,7 +135,7 @@ Route::group(['prefix' => 'servers'], function () {
|
|||
*/
|
||||
Route::group(['prefix' => 'nodes'], function () {
|
||||
Route::get('/', 'NodesController@index')->name('admin.nodes');
|
||||
Route::get('/new', 'NodesController@new')->name('admin.nodes.new');
|
||||
Route::get('/new', 'NodesController@create')->name('admin.nodes.new');
|
||||
Route::get('/view/{id}', 'NodesController@viewIndex')->name('admin.nodes.view');
|
||||
Route::get('/view/{id}/settings', 'NodesController@viewSettings')->name('admin.nodes.view.settings');
|
||||
Route::get('/view/{id}/configuration', 'NodesController@viewConfiguration')->name('admin.nodes.view.configuration');
|
||||
|
@ -144,7 +143,7 @@ Route::group(['prefix' => 'nodes'], function () {
|
|||
Route::get('/view/{id}/servers', 'NodesController@viewServers')->name('admin.nodes.view.servers');
|
||||
Route::get('/view/{id}/settings/token', 'NodesController@setToken')->name('admin.nodes.view.configuration.token');
|
||||
|
||||
Route::post('/new', 'NodesController@create');
|
||||
Route::post('/new', 'NodesController@store');
|
||||
Route::post('/view/{id}/settings', 'NodesController@updateSettings');
|
||||
Route::post('/view/{id}/allocation', 'NodesController@createAllocation');
|
||||
Route::post('/view/{id}/allocation/remove', 'NodesController@allocationRemoveBlock')->name('admin.nodes.view.allocation.removeBlock');
|
||||
|
@ -164,16 +163,16 @@ Route::group(['prefix' => 'nodes'], function () {
|
|||
*/
|
||||
Route::group(['prefix' => 'services'], function () {
|
||||
Route::get('/', 'ServiceController@index')->name('admin.services');
|
||||
Route::get('/new', 'ServiceController@new')->name('admin.services.new');
|
||||
Route::get('/new', 'ServiceController@create')->name('admin.services.new');
|
||||
Route::get('/view/{id}', 'ServiceController@view')->name('admin.services.view');
|
||||
Route::get('/view/{id}/functions', 'ServiceController@viewFunctions')->name('admin.services.view.functions');
|
||||
Route::get('/option/new', 'OptionController@new')->name('admin.services.option.new');
|
||||
Route::get('/option/new', 'OptionController@create')->name('admin.services.option.new');
|
||||
Route::get('/option/{id}', 'OptionController@viewConfiguration')->name('admin.services.option.view');
|
||||
Route::get('/option/{id}/variables', 'OptionController@viewVariables')->name('admin.services.option.variables');
|
||||
|
||||
Route::post('/new', 'ServiceController@create');
|
||||
Route::post('/new', 'ServiceController@store');
|
||||
Route::post('/view/{id}', 'ServiceController@edit');
|
||||
Route::post('/option/new', 'OptionController@new');
|
||||
Route::post('/option/new', 'OptionController@store');
|
||||
Route::post('/option/{id}', 'OptionController@editConfiguration');
|
||||
Route::post('/option/{id}/variables', 'OptionController@createVariable');
|
||||
Route::post('/option/{id}/variables/{variable}', 'OptionController@editVariable')->name('admin.services.option.variables.edit');
|
||||
|
@ -191,11 +190,11 @@ Route::group(['prefix' => 'services'], function () {
|
|||
*/
|
||||
Route::group(['prefix' => 'packs'], function () {
|
||||
Route::get('/', 'PackController@index')->name('admin.packs');
|
||||
Route::get('/new', 'PackController@new')->name('admin.packs.new');
|
||||
Route::get('/new', 'PackController@create')->name('admin.packs.new');
|
||||
Route::get('/new/template', 'PackController@newTemplate')->name('admin.packs.new.template');
|
||||
Route::get('/view/{id}', 'PackController@view')->name('admin.packs.view');
|
||||
|
||||
Route::post('/new', 'PackController@create');
|
||||
Route::post('/new', 'PackController@store');
|
||||
Route::post('/view/{id}', 'PackController@update');
|
||||
Route::post('/view/{id}/export/{files?}', 'PackController@export')->name('admin.packs.view.export');
|
||||
});
|
||||
|
|
112
routes/api-admin.php
Normal file
112
routes/api-admin.php
Normal file
|
@ -0,0 +1,112 @@
|
|||
<?php
|
||||
/**
|
||||
* Pterodactyl - Panel
|
||||
* Copyright (c) 2015 - 2017 Dane Everitt <dane@daneeveritt.com>.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
Route::get('/', 'CoreController@index');
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Server Controller Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Endpoint: /api/admin/servers
|
||||
|
|
||||
*/
|
||||
Route::group(['prefix' => '/servers'], function () {
|
||||
Route::get('/', 'ServerController@index');
|
||||
Route::get('/{id}', 'ServerController@view');
|
||||
|
||||
Route::post('/', 'ServerController@store');
|
||||
|
||||
Route::put('/{id}/details', 'ServerController@details');
|
||||
Route::put('/{id}/container', 'ServerController@container');
|
||||
Route::put('/{id}/build', 'ServerController@build');
|
||||
Route::put('/{id}/startup', 'ServerController@startup');
|
||||
|
||||
Route::patch('/{id}/install', 'ServerController@install');
|
||||
Route::patch('/{id}/rebuild', 'ServerController@rebuild');
|
||||
Route::patch('/{id}/suspend', 'ServerController@suspend');
|
||||
|
||||
Route::delete('/{id}', 'ServerController@delete');
|
||||
});
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Location Controller Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Endpoint: /api/admin/locations
|
||||
|
|
||||
*/
|
||||
Route::group(['prefix' => '/locations'], function () {
|
||||
Route::get('/', 'LocationController@index');
|
||||
});
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Node Controller Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Endpoint: /api/admin/nodes
|
||||
|
|
||||
*/
|
||||
Route::group(['prefix' => '/nodes'], function () {
|
||||
Route::get('/', 'NodeController@index');
|
||||
Route::get('/{id}', 'NodeController@view');
|
||||
Route::get('/{id}/config', 'NodeController@viewConfig');
|
||||
|
||||
Route::post('/', 'NodeController@store');
|
||||
|
||||
Route::delete('/{id}', 'NodeController@delete');
|
||||
});
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| User Controller Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Endpoint: /api/admin/users
|
||||
|
|
||||
*/
|
||||
Route::group(['prefix' => '/users'], function () {
|
||||
Route::get('/', 'UserController@index');
|
||||
Route::get('/{id}', 'UserController@view');
|
||||
|
||||
Route::post('/', 'UserController@store');
|
||||
|
||||
Route::put('/{id}', 'UserController@update');
|
||||
|
||||
Route::delete('/{id}', 'UserController@delete');
|
||||
});
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Service Controller Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Endpoint: /api/admin/services
|
||||
|
|
||||
*/
|
||||
Route::group(['prefix' => '/services'], function () {
|
||||
Route::get('/', 'ServiceController@index');
|
||||
Route::get('/{id}', 'ServiceController@view');
|
||||
});
|
42
routes/api.php
Normal file
42
routes/api.php
Normal file
|
@ -0,0 +1,42 @@
|
|||
<?php
|
||||
/**
|
||||
* Pterodactyl - Panel
|
||||
* Copyright (c) 2015 - 2017 Dane Everitt <dane@daneeveritt.com>.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
Route::get('/', 'CoreController@index')->name('api.user');
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Server Controller Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Endpoint: /api/user/server/{server}
|
||||
|
|
||||
*/
|
||||
Route::group([
|
||||
'prefix' => '/server/{server}',
|
||||
'middleware' => 'server',
|
||||
], function () {
|
||||
Route::get('/', 'ServerController@index')->name('api.user.server');
|
||||
|
||||
Route::post('/power', 'ServerController@power')->name('api.user.server.power');
|
||||
Route::post('/command', 'ServerController@command')->name('api.user.server.command');
|
||||
});
|
|
@ -21,7 +21,6 @@
|
|||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
Route::get('/logout', 'LoginController@logout')->name('auth.logout')->middleware('auth');
|
||||
Route::get('/login', 'LoginController@showLoginForm')->name('auth.login');
|
||||
Route::get('/login/totp', 'LoginController@totp')->name('auth.totp');
|
||||
|
|
|
@ -21,7 +21,6 @@
|
|||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
Route::get('/', 'IndexController@getIndex')->name('index');
|
||||
Route::get('/index', function () {
|
||||
redirect()->route('index');
|
||||
|
@ -51,9 +50,9 @@ Route::group(['prefix' => 'account'], function () {
|
|||
*/
|
||||
Route::group(['prefix' => 'account/api'], function () {
|
||||
Route::get('/', 'APIController@index')->name('account.api');
|
||||
Route::get('/new', 'APIController@new')->name('account.api.new');
|
||||
Route::get('/new', 'APIController@create')->name('account.api.new');
|
||||
|
||||
Route::post('/new', 'APIController@save');
|
||||
Route::post('/new', 'APIController@store');
|
||||
|
||||
Route::delete('/revoke/{key}', 'APIController@revoke')->name('account.api.revoke');
|
||||
});
|
||||
|
|
|
@ -21,7 +21,6 @@
|
|||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
Route::get('/services', 'ServiceController@list')->name('daemon.services');
|
||||
Route::get('/services/pull/{service}/{file}', 'ServiceController@pull')->name('daemon.pull');
|
||||
Route::get('/packs/pull/{uuid}', 'PackController@pull')->name('daemon.pack.pull');
|
||||
|
|
|
@ -21,7 +21,6 @@
|
|||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
Route::get('/configuration/{token}', 'RemoteController@getConfiguration')->name('remote.configuration');
|
||||
|
||||
Route::post('/download', 'RemoteController@postDownload')->name('remote.download');
|
||||
|
|
|
@ -21,7 +21,6 @@
|
|||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
Route::get('/', 'ServerController@getIndex')->name('server.index');
|
||||
|
||||
/*
|
||||
|
@ -71,14 +70,14 @@ Route::group(['prefix' => 'files'], function () {
|
|||
|
|
||||
*/
|
||||
Route::group(['prefix' => 'users'], function () {
|
||||
Route::get('/', 'SubuserController@getIndex')->name('server.subusers');
|
||||
Route::get('/new', 'SubuserController@getNew')->name('server.subusers.new');
|
||||
Route::get('/view/{id}', 'SubuserController@getView')->name('server.subusers.view');
|
||||
Route::get('/', 'SubuserController@index')->name('server.subusers');
|
||||
Route::get('/new', 'SubuserController@create')->name('server.subusers.new');
|
||||
Route::get('/view/{id}', 'SubuserController@view')->name('server.subusers.view');
|
||||
|
||||
Route::post('/new', 'SubuserController@postNew');
|
||||
Route::post('/view/{id}', 'SubuserController@postView');
|
||||
Route::post('/new', 'SubuserController@store');
|
||||
Route::post('/view/{id}', 'SubuserController@update');
|
||||
|
||||
Route::delete('/delete/{id}', 'SubuserController@deleteSubuser')->name('server.subusers.delete');
|
||||
Route::delete('/delete/{id}', 'SubuserController@delete')->name('server.subusers.delete');
|
||||
});
|
||||
|
||||
/*
|
||||
|
@ -90,15 +89,13 @@ Route::group(['prefix' => 'users'], function () {
|
|||
|
|
||||
*/
|
||||
Route::group(['prefix' => 'tasks'], function () {
|
||||
Route::get('/', 'TaskController@getIndex')->name('server.tasks');
|
||||
Route::get('/new', 'TaskController@getNew')->name('server.tasks.new');
|
||||
Route::get('/view/{id}', 'TaskController@getView')->name('server.tasks.view');
|
||||
Route::get('/', 'TaskController@index')->name('server.tasks');
|
||||
Route::get('/new', 'TaskController@create')->name('server.tasks.new');
|
||||
|
||||
Route::post('/new', 'TaskController@postNew');
|
||||
Route::post('/view/{id}', 'SubuserController@postView');
|
||||
Route::post('/toggle/{id}', 'TaskController@toggleTask')->name('server.tasks.toggle');
|
||||
Route::post('/new', 'TaskController@store');
|
||||
Route::post('/toggle/{id}', 'TaskController@toggle')->name('server.tasks.toggle');
|
||||
|
||||
Route::delete('/delete/{id}', 'TaskController@deleteTask')->name('server.tasks.delete');
|
||||
Route::delete('/delete/{id}', 'TaskController@delete')->name('server.tasks.delete');
|
||||
});
|
||||
|
||||
/*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue