mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-26 22:36:51 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Services\Servers;
 | |
| 
 | |
| use Illuminate\Support\Arr;
 | |
| use App\Models\Egg;
 | |
| use App\Models\User;
 | |
| use App\Models\Server;
 | |
| use App\Models\ServerVariable;
 | |
| use Illuminate\Database\ConnectionInterface;
 | |
| use App\Traits\Services\HasUserLevels;
 | |
| 
 | |
| class StartupModificationService
 | |
| {
 | |
|     use HasUserLevels;
 | |
| 
 | |
|     /**
 | |
|      * StartupModificationService constructor.
 | |
|      */
 | |
|     public function __construct(private ConnectionInterface $connection, private VariableValidatorService $validatorService)
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Process startup modification for a server.
 | |
|      *
 | |
|      * @throws \Throwable
 | |
|      */
 | |
|     public function handle(Server $server, array $data): Server
 | |
|     {
 | |
|         return $this->connection->transaction(function () use ($server, $data) {
 | |
|             if (!empty($data['environment'])) {
 | |
|                 $egg = $this->isUserLevel(User::USER_LEVEL_ADMIN) ? ($data['egg_id'] ?? $server->egg_id) : $server->egg_id;
 | |
| 
 | |
|                 $results = $this->validatorService
 | |
|                     ->setUserLevel($this->getUserLevel())
 | |
|                     ->handle($egg, $data['environment']);
 | |
| 
 | |
|                 foreach ($results as $result) {
 | |
|                     ServerVariable::query()->updateOrCreate(
 | |
|                         [
 | |
|                             'server_id' => $server->id,
 | |
|                             'variable_id' => $result->id,
 | |
|                         ],
 | |
|                         ['variable_value' => $result->value ?? '']
 | |
|                     );
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             if ($this->isUserLevel(User::USER_LEVEL_ADMIN)) {
 | |
|                 $this->updateAdministrativeSettings($data, $server);
 | |
|             }
 | |
| 
 | |
|             // Calling ->refresh() rather than ->fresh() here causes it to return the
 | |
|             // variables as triplicates for some reason? Not entirely sure, should dig
 | |
|             // in more to figure it out, but luckily we have a test case covering this
 | |
|             // specific call so we can be assured we're not breaking it _here_ at least.
 | |
|             //
 | |
|             // TODO: this seems like a red-flag for the code powering the relationship
 | |
|             //  that should be looked into more.
 | |
|             return $server->fresh();
 | |
|         });
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Update certain administrative settings for a server in the DB.
 | |
|      */
 | |
|     protected function updateAdministrativeSettings(array $data, Server &$server): void
 | |
|     {
 | |
|         $eggId = Arr::get($data, 'egg_id');
 | |
| 
 | |
|         if (is_digit($eggId) && $server->egg_id !== (int) $eggId) {
 | |
|             /** @var \App\Models\Egg $egg */
 | |
|             $egg = Egg::query()->findOrFail($data['egg_id']);
 | |
| 
 | |
|             $server = $server->forceFill([
 | |
|                 'egg_id' => $egg->id,
 | |
|             ]);
 | |
|         }
 | |
| 
 | |
|         $server->fill([
 | |
|             'startup' => $data['startup'] ?? $server->startup,
 | |
|             'skip_scripts' => $data['skip_scripts'] ?? isset($data['skip_scripts']),
 | |
|             'image' => $data['docker_image'] ?? $server->image,
 | |
|         ])->save();
 | |
|     }
 | |
| }
 | 
