mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-31 08:36:52 +01:00 
			
		
		
		
	 e1308cb04d
			
		
	
	
		e1308cb04d
		
			
		
	
	
	
	
		
			
			* update scramble * cleanup application api endpoints * cleanup client api endpoints * fix security schema and make docs homepage nicer * remove duplicate myclabs/deep-copy * style(api-docs): use Blade template and Tailwind for styling * Publish scramble view * Use localStorage theme instead of config * Update routes/docs.php Co-authored-by: Lance Pioch <git@lance.sh> --------- Co-authored-by: Quinten <67589015+QuintenQVD0@users.noreply.github.com> Co-authored-by: RMartinOscar <40749467+RMartinOscar@users.noreply.github.com> Co-authored-by: Lance Pioch <git@lance.sh>
		
			
				
	
	
		
			49 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Http\Controllers\Api\Client\Servers;
 | |
| 
 | |
| use Illuminate\Http\Response;
 | |
| use App\Models\Server;
 | |
| use App\Facades\Activity;
 | |
| use GuzzleHttp\Exception\BadResponseException;
 | |
| use Symfony\Component\HttpKernel\Exception\HttpException;
 | |
| use App\Http\Controllers\Api\Client\ClientApiController;
 | |
| use App\Http\Requests\Api\Client\Servers\SendCommandRequest;
 | |
| use Dedoc\Scramble\Attributes\Group;
 | |
| use Exception;
 | |
| use Illuminate\Http\Client\ConnectionException;
 | |
| 
 | |
| #[Group('Server', weight: 1)]
 | |
| class CommandController extends ClientApiController
 | |
| {
 | |
|     /**
 | |
|      * Send command
 | |
|      *
 | |
|      * Send a command to a running server.
 | |
|      *
 | |
|      * @throws ConnectionException
 | |
|      */
 | |
|     public function index(SendCommandRequest $request, Server $server): Response
 | |
|     {
 | |
|         try {
 | |
|             $server->send($request->input('command'));
 | |
|         } catch (Exception $exception) {
 | |
|             $previous = $exception->getPrevious();
 | |
| 
 | |
|             if ($previous instanceof BadResponseException) {
 | |
|                 if ($previous->getResponse()->getStatusCode() === Response::HTTP_BAD_GATEWAY) {
 | |
|                     throw new HttpException(Response::HTTP_BAD_GATEWAY, 'Server must be online in order to send commands.', $exception);
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             throw $exception;
 | |
|         }
 | |
| 
 | |
|         Activity::event('server:console.command')
 | |
|             ->property('command', $request->input('command'))
 | |
|             ->log();
 | |
| 
 | |
|         return $this->returnNoContent();
 | |
|     }
 | |
| }
 |