mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-31 20:06:52 +01:00 
			
		
		
		
	 da195fd2fe
			
		
	
	
		da195fd2fe
		
			
		
	
	
	
	
		
			
			* Not found property rule * Make these “better” * Day 1 * Day 2 * Day 3 * Dat 4 * Remove disabled check * Day 4 continued * Run pint * Final changes hopefully * Pint fixes * Fix again * Reset these * Update app/Filament/Admin/Pages/Health.php Co-authored-by: MartinOscar <40749467+rmartinoscar@users.noreply.github.com> * Update app/Traits/CheckMigrationsTrait.php Co-authored-by: MartinOscar <40749467+rmartinoscar@users.noreply.github.com> --------- Co-authored-by: MartinOscar <40749467+rmartinoscar@users.noreply.github.com>
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Services\Databases;
 | |
| 
 | |
| use Webmozart\Assert\Assert;
 | |
| use App\Models\Server;
 | |
| use App\Models\Database;
 | |
| use App\Models\DatabaseHost;
 | |
| use App\Exceptions\Service\Database\NoSuitableDatabaseHostException;
 | |
| 
 | |
| readonly class DeployServerDatabaseService
 | |
| {
 | |
|     public function __construct(private DatabaseManagementService $managementService) {}
 | |
| 
 | |
|     /**
 | |
|      * @param  array{database?: string, remote?: string}  $data
 | |
|      */
 | |
|     public function handle(Server $server, array $data): Database
 | |
|     {
 | |
|         Assert::notEmpty($data['database'] ?? null);
 | |
|         Assert::notEmpty($data['remote'] ?? null);
 | |
| 
 | |
|         $hosts = DatabaseHost::query()->get();
 | |
|         if ($hosts->isEmpty()) {
 | |
|             throw new NoSuitableDatabaseHostException();
 | |
|         }
 | |
| 
 | |
|         $nodeHosts = $server->node->databaseHosts()->get();
 | |
|         // TODO: @areyouscared remove allow random feature for database hosts
 | |
|         if ($nodeHosts->isEmpty() && !config('panel.client_features.databases.allow_random')) {
 | |
|             throw new NoSuitableDatabaseHostException();
 | |
|         }
 | |
| 
 | |
|         return $this->managementService->create($server, [
 | |
|             'database_host_id' => $nodeHosts->isEmpty()
 | |
|                 ? $hosts->random()->id
 | |
|                 : $nodeHosts->random()->id,
 | |
|             'database' => DatabaseManagementService::generateUniqueDatabaseName($data['database'], $server->id),
 | |
|             'remote' => $data['remote'],
 | |
|         ]);
 | |
|     }
 | |
| }
 |