Add more API routes
Servers: list all, list single Nodes: list all, list single, list single allocations, add node Locations: list all
This commit is contained in:
		
							parent
							
								
									0ccaa16ea4
								
							
						
					
					
						commit
						63f377a038
					
				
							
								
								
									
										33
									
								
								app/Http/Controllers/API/LocationController.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								app/Http/Controllers/API/LocationController.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,33 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace Pterodactyl\Http\Controllers\API; | ||||
| 
 | ||||
| use Illuminate\Http\Request; | ||||
| use Pterodactyl\Models\Location; | ||||
| 
 | ||||
| /** | ||||
|  * @Resource("Servers") | ||||
|  */ | ||||
| class LocationController extends BaseController | ||||
| { | ||||
| 
 | ||||
|     public function __construct() | ||||
|     { | ||||
|         //
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * List All Locations | ||||
|      * | ||||
|      * Lists all locations currently on the system. | ||||
|      * | ||||
|      * @Get("/locations") | ||||
|      * @Versions({"v1"}) | ||||
|      * @Response(200) | ||||
|      */ | ||||
|     public function getLocations(Request $request) | ||||
|     { | ||||
|         return Location::all(); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										154
									
								
								app/Http/Controllers/API/NodeController.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								app/Http/Controllers/API/NodeController.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,154 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace Pterodactyl\Http\Controllers\API; | ||||
| 
 | ||||
| use Illuminate\Http\Request; | ||||
| 
 | ||||
| use Pterodactyl\Models; | ||||
| use Pterodactyl\Transformers\NodeTransformer; | ||||
| use Pterodactyl\Repositories\NodeRepository; | ||||
| 
 | ||||
| use Pterodactyl\Exceptions\DisplayValidationException; | ||||
| use Pterodactyl\Exceptions\DisplayException; | ||||
| use Dingo\Api\Exception\ResourceException; | ||||
| use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; | ||||
| use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; | ||||
| use Symfony\Component\HttpKernel\Exception\ServiceUnavailableHttpException; | ||||
| 
 | ||||
| /** | ||||
|  * @Resource("Servers") | ||||
|  */ | ||||
| class NodeController extends BaseController | ||||
| { | ||||
| 
 | ||||
|     public function __construct() | ||||
|     { | ||||
|         //
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * List All Nodes | ||||
|      * | ||||
|      * Lists all nodes currently on the system. | ||||
|      * | ||||
|      * @Get("/nodes/{?page}") | ||||
|      * @Versions({"v1"}) | ||||
|      * @Parameters({ | ||||
|      *      @Parameter("page", type="integer", description="The page of results to view.", default=1) | ||||
|      * }) | ||||
|      * @Response(200) | ||||
|      */ | ||||
|     public function getNodes(Request $request) | ||||
|     { | ||||
|         $nodes = Models\Node::paginate(15); | ||||
|         return $this->response->paginator($nodes, new NodeTransformer); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Create a New Node | ||||
|      * | ||||
|      * @Post("/nodes") | ||||
|      * @Versions({"v1"}) | ||||
|      * @Transaction({ | ||||
|      *      @Request({ | ||||
|      *      	'name' => 'My API Node', | ||||
|      *      	'location' => 1, | ||||
|      *      	'public' => 1, | ||||
|      *      	'fqdn' => 'daemon.wuzzle.woo', | ||||
|      *      	'scheme' => 'https', | ||||
|      *      	'memory' => 10240, | ||||
|      *      	'memory_overallocate' => 100, | ||||
|      *      	'disk' => 204800, | ||||
|      *      	'disk_overallocate' => -1, | ||||
|      *      	'daemonBase' => '/srv/daemon-data', | ||||
|      *      	'daemonSFTP' => 2022, | ||||
|      *      	'daemonListen' => 8080 | ||||
|      *      }, headers={"Authorization": "Bearer <jwt-token>"}), | ||||
|      *       @Response(201), | ||||
|      *       @Response(422, body={ | ||||
|      *          "message": "A validation error occured.", | ||||
|      *          "errors": {}, | ||||
|      *          "status_code": 422 | ||||
|      *       }), | ||||
|      *       @Response(503, body={ | ||||
|      *       	"message": "There was an error while attempting to add this node to the system.", | ||||
|      *       	"status_code": 503 | ||||
|      *       }) | ||||
|      * }) | ||||
|      */ | ||||
|     public function postNode(Request $request) | ||||
|     { | ||||
|         try { | ||||
|             $node = new NodeRepository; | ||||
|             $new = $node->create($request->all()); | ||||
|             return $this->response->created(route('api.nodes.view', [ | ||||
|                 'id' => $new | ||||
|             ])); | ||||
|         } catch (DisplayValidationException $ex) { | ||||
|             throw new ResourceException('A validation error occured.', json_decode($ex->getMessage(), true)); | ||||
|         } catch (DisplayException $ex) { | ||||
|             throw new ResourceException($ex->getMessage()); | ||||
|         } catch (\Exception $e) { | ||||
|             throw new BadRequestHttpException('There was an error while attempting to add this node to the system.'); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * List Specific Node | ||||
|      * | ||||
|      * Lists specific fields about a server or all fields pertaining to that node. | ||||
|      * | ||||
|      * @Get("/nodes/{id}/{?fields}") | ||||
|      * @Versions({"v1"}) | ||||
|      * @Parameters({ | ||||
|      *      @Parameter("id", type="integer", required=true, description="The ID of the node to get information on."), | ||||
|      *      @Parameter("fields", type="string", required=false, description="A comma delimidated list of fields to include.") | ||||
|      * }) | ||||
|      * @Response(200) | ||||
|      */ | ||||
|     public function getNode(Request $request, $id, $fields = null) | ||||
|     { | ||||
|         $query = Models\Node::where('id', $id); | ||||
| 
 | ||||
|         if (!is_null($request->input('fields'))) { | ||||
|             foreach(explode(',', $request->input('fields')) as $field) { | ||||
|                 if (!empty($field)) { | ||||
|                     $query->addSelect($field); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         try { | ||||
|             if (!$query->first()) { | ||||
|                 throw new NotFoundHttpException('No node by that ID was found.'); | ||||
|             } | ||||
|             return $query->first(); | ||||
|         } catch (NotFoundHttpException $ex) { | ||||
|             throw $ex; | ||||
|         } catch (\Exception $ex) { | ||||
|             throw new BadRequestHttpException('There was an issue with the fields passed in the request.'); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * List Node Allocations | ||||
|      * | ||||
|      * Returns a listing of all node allocations. | ||||
|      * | ||||
|      * @Get("/nodes/{id}/allocations") | ||||
|      * @Versions({"v1"}) | ||||
|      * @Parameters({ | ||||
|      *      @Parameter("id", type="integer", required=true, description="The ID of the node to get allocations for."), | ||||
|      * }) | ||||
|      * @Response(200) | ||||
|      */ | ||||
|     public function getNodeAllocations(Request $request, $id) | ||||
|     { | ||||
|         $allocations = Models\Allocation::select('ip', 'port', 'assigned_to')->where('node', $id)->orderBy('ip', 'asc')->orderBy('port', 'asc')->get(); | ||||
|         if ($allocations->count() < 1) { | ||||
|             throw new NotFoundHttpException('No allocations where found for the requested node.'); | ||||
|         } | ||||
|         return $allocations; | ||||
|     } | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										84
									
								
								app/Http/Controllers/API/ServerController.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										84
									
								
								app/Http/Controllers/API/ServerController.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,84 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace Pterodactyl\Http\Controllers\API; | ||||
| 
 | ||||
| use Illuminate\Http\Request; | ||||
| 
 | ||||
| use Pterodactyl\Models; | ||||
| use Pterodactyl\Transformers\ServerTransformer; | ||||
| use Pterodactyl\Repositories\ServerRepository; | ||||
| 
 | ||||
| use Pterodactyl\Exceptions\DisplayValidationException; | ||||
| use Pterodactyl\Exceptions\DisplayException; | ||||
| use Dingo\Api\Exception\ResourceException; | ||||
| use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; | ||||
| use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; | ||||
| use Symfony\Component\HttpKernel\Exception\ServiceUnavailableHttpException; | ||||
| 
 | ||||
| /** | ||||
|  * @Resource("Servers") | ||||
|  */ | ||||
| class ServerController extends BaseController | ||||
| { | ||||
| 
 | ||||
|     public function __construct() | ||||
|     { | ||||
|         //
 | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * List All Servers | ||||
|      * | ||||
|      * Lists all servers currently on the system. | ||||
|      * | ||||
|      * @Get("/servers/{?page}") | ||||
|      * @Versions({"v1"}) | ||||
|      * @Parameters({ | ||||
|      *      @Parameter("page", type="integer", description="The page of results to view.", default=1) | ||||
|      * }) | ||||
|      * @Response(200) | ||||
|      */ | ||||
|     public function getServers(Request $request) | ||||
|     { | ||||
|         $servers = Models\Server::paginate(15); | ||||
|         return $this->response->paginator($servers, new ServerTransformer); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * List Specific Server | ||||
|      * | ||||
|      * Lists specific fields about a server or all fields pertaining to that server. | ||||
|      * | ||||
|      * @Get("/servers/{id}/{fields}") | ||||
|      * @Versions({"v1"}) | ||||
|      * @Parameters({ | ||||
|      *      @Parameter("id", type="integer", required=true, description="The ID of the server to get information on."), | ||||
|      *      @Parameter("fields", type="string", required=false, description="A comma delimidated list of fields to include.") | ||||
|      * }) | ||||
|      * @Response(200) | ||||
|      */ | ||||
|     public function getServer(Request $request, $id) | ||||
|     { | ||||
|         $query = Models\Server::where('id', $id); | ||||
| 
 | ||||
|         if (!is_null($request->input('fields'))) { | ||||
|             foreach(explode(',', $request->input('fields')) as $field) { | ||||
|                 if (!empty($field)) { | ||||
|                     $query->addSelect($field); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         try { | ||||
|             if (!$query->first()) { | ||||
|                 throw new NotFoundHttpException('No server by that ID was found.'); | ||||
|             } | ||||
|             return $query->first(); | ||||
|         } catch (NotFoundHttpException $ex) { | ||||
|             throw $ex; | ||||
|         } catch (\Exception $ex) { | ||||
|             throw new BadRequestHttpException('There was an issue with the fields passed in the request.'); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| @ -53,12 +53,12 @@ class UserController extends BaseController | ||||
|      * }) | ||||
|      * @Response(200) | ||||
|      */ | ||||
|     public function getUser(Request $request, $id, $fields = null) | ||||
|     public function getUser(Request $request, $id) | ||||
|     { | ||||
|         $query = Models\User::where('id', $id); | ||||
| 
 | ||||
|         if (!is_null($fields)) { | ||||
|             foreach(explode(',', $fields) as $field) { | ||||
|         if (!is_null($request->input('fields'))) { | ||||
|             foreach(explode(',', $request->input('fields')) as $field) { | ||||
|                 if (!empty($field)) { | ||||
|                     $query->addSelect($field); | ||||
|                 } | ||||
|  | ||||
| @ -30,6 +30,10 @@ class APIRoutes | ||||
|         }); | ||||
| 
 | ||||
|         $api->version('v1', ['middleware' => 'api.auth'], function ($api) { | ||||
| 
 | ||||
|             /** | ||||
|              * User Routes | ||||
|              */ | ||||
|             $api->get('users', [ | ||||
|                 'as' => 'api.users', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@getUsers' | ||||
| @ -40,20 +44,65 @@ class APIRoutes | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@postUser' | ||||
|             ]); | ||||
| 
 | ||||
|             $api->get('users/{id}/{fields?}', [ | ||||
|             $api->get('users/{id}', [ | ||||
|                 'as' => 'api.users.view', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@getUser' | ||||
|             ]); | ||||
| 
 | ||||
|             $api->patch('users/{id}/', [ | ||||
|             $api->patch('users/{id}', [ | ||||
|                 'as' => 'api.users.patch', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@patchUser' | ||||
|             ]); | ||||
| 
 | ||||
|             $api->delete('users/{id}/', [ | ||||
|             $api->delete('users/{id}', [ | ||||
|                 'as' => 'api.users.delete', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\UserController@deleteUser' | ||||
|             ]); | ||||
| 
 | ||||
|             /** | ||||
|              * Server Routes | ||||
|              */ | ||||
|             $api->get('servers', [ | ||||
|                 'as' => 'api.servers', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@getServers' | ||||
|             ]); | ||||
| 
 | ||||
|             $api->get('servers/{id}', [ | ||||
|                 'as' => 'api.servers.view', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\ServerController@getServer' | ||||
|             ]); | ||||
| 
 | ||||
|             /** | ||||
|              * Node Routes | ||||
|              */ | ||||
|             $api->get('nodes', [ | ||||
|                 'as' => 'api.nodes', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@getNodes' | ||||
|             ]); | ||||
| 
 | ||||
|             $api->post('nodes', [ | ||||
|                 'as' => 'api.nodes.post', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@postNode' | ||||
|             ]); | ||||
| 
 | ||||
|             $api->get('nodes/{id}', [ | ||||
|                 'as' => 'api.nodes.view', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@getNode' | ||||
|             ]); | ||||
| 
 | ||||
|             $api->get('nodes/{id}/allocations', [ | ||||
|                 'as' => 'api.nodes.view', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\NodeController@getNodeAllocations' | ||||
|             ]); | ||||
| 
 | ||||
|             /** | ||||
|              * Location Routes | ||||
|              */ | ||||
|             $api->get('locations', [ | ||||
|                 'as' => 'api.locations', | ||||
|                 'uses' => 'Pterodactyl\Http\Controllers\API\LocationController@getLocations' | ||||
|             ]); | ||||
| 
 | ||||
|         }); | ||||
|     } | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										21
									
								
								app/Transformers/NodeTransformer.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								app/Transformers/NodeTransformer.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace Pterodactyl\Transformers; | ||||
| 
 | ||||
| use Pterodactyl\Models\Node; | ||||
| use League\Fractal\TransformerAbstract; | ||||
| 
 | ||||
| class NodeTransformer extends TransformerAbstract | ||||
| { | ||||
| 
 | ||||
|     /** | ||||
|      * Turn this item object into a generic array | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function transform(Node $node) | ||||
|     { | ||||
|         return $node; | ||||
|     } | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										21
									
								
								app/Transformers/ServerTransformer.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								app/Transformers/ServerTransformer.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace Pterodactyl\Transformers; | ||||
| 
 | ||||
| use Pterodactyl\Models\Server; | ||||
| use League\Fractal\TransformerAbstract; | ||||
| 
 | ||||
| class ServerTransformer extends TransformerAbstract | ||||
| { | ||||
| 
 | ||||
|     /** | ||||
|      * Turn this item object into a generic array | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function transform(Server $server) | ||||
|     { | ||||
|         return $server; | ||||
|     } | ||||
| 
 | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Dane Everitt
						Dane Everitt