135 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Pterodactyl\Repositories\Daemon;
 | |
| 
 | |
| use Webmozart\Assert\Assert;
 | |
| use Psr\Http\Message\ResponseInterface;
 | |
| use Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface;
 | |
| 
 | |
| class ServerRepository extends BaseRepository implements ServerRepositoryInterface
 | |
| {
 | |
|     /**
 | |
|      * Create a new server on the daemon for the panel.
 | |
|      *
 | |
|      * @param array $structure
 | |
|      * @param array $overrides
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      *
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function create(array $structure, array $overrides = []): ResponseInterface
 | |
|     {
 | |
|         foreach ($overrides as $key => $value) {
 | |
|             $structure[$key] = value($value);
 | |
|         }
 | |
| 
 | |
|         return $this->getHttpClient()->request('POST', 'servers', [
 | |
|             'json' => $structure,
 | |
|         ]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Update server details on the daemon.
 | |
|      *
 | |
|      * @param array $data
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function update(array $data): ResponseInterface
 | |
|     {
 | |
|         return $this->getHttpClient()->request('PATCH', 'server', [
 | |
|             'json' => $data,
 | |
|         ]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Mark a server to be reinstalled on the system.
 | |
|      *
 | |
|      * @param array|null $data
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function reinstall(array $data = null): ResponseInterface
 | |
|     {
 | |
|         return $this->getHttpClient()->request('POST', 'server/reinstall', [
 | |
|             'json' => $data ?? [],
 | |
|         ]);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Mark a server as needing a container rebuild the next time the server is booted.
 | |
|      *
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function rebuild(): ResponseInterface
 | |
|     {
 | |
|         return $this->getHttpClient()->request('POST', 'server/rebuild');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Suspend a server on the daemon.
 | |
|      *
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function suspend(): ResponseInterface
 | |
|     {
 | |
|         return $this->getHttpClient()->request('POST', 'server/suspend');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Un-suspend a server on the daemon.
 | |
|      *
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function unsuspend(): ResponseInterface
 | |
|     {
 | |
|         return $this->getHttpClient()->request('POST', 'server/unsuspend');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Delete a server on the daemon.
 | |
|      *
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function delete(): ResponseInterface
 | |
|     {
 | |
|         return $this->getHttpClient()->request('DELETE', 'servers');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return details on a specific server.
 | |
|      *
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function details(): ResponseInterface
 | |
|     {
 | |
|         return $this->getHttpClient()->request('GET', 'server');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Revoke an access key on the daemon before the time is expired.
 | |
|      *
 | |
|      * @param string|array $key
 | |
|      * @return \Psr\Http\Message\ResponseInterface
 | |
|      *
 | |
|      * @throws \GuzzleHttp\Exception\GuzzleException
 | |
|      */
 | |
|     public function revokeAccessKey($key): ResponseInterface
 | |
|     {
 | |
|         if (is_array($key)) {
 | |
|             return $this->getHttpClient()->request('POST', 'keys/batch-delete', [
 | |
|                 'json' => ['keys' => $key],
 | |
|             ]);
 | |
|         }
 | |
| 
 | |
|         Assert::stringNotEmpty($key, 'First argument passed to revokeAccessKey must be a non-empty string or array, received %s.');
 | |
| 
 | |
|         return $this->getHttpClient()->request('DELETE', 'keys/' . $key);
 | |
|     }
 | |
| }
 | 
