mirror of
https://github.com/pelican-dev/panel.git
synced 2025-05-20 00:34:44 +02:00

* 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'],
|
|
]);
|
|
}
|
|
}
|