mirror of
https://github.com/vitodeploy/vito.git
synced 2025-04-19 09:51:37 +00:00
62 lines
1.6 KiB
PHP
Executable File
62 lines
1.6 KiB
PHP
Executable File
<?php
|
|
|
|
namespace App\Actions\Database;
|
|
|
|
use App\Models\Database;
|
|
use App\Models\DatabaseUser;
|
|
use App\Models\Server;
|
|
use Illuminate\Validation\Rule;
|
|
use Illuminate\Validation\ValidationException;
|
|
|
|
class LinkUser
|
|
{
|
|
/**
|
|
* @throws ValidationException
|
|
*/
|
|
public function link(DatabaseUser $databaseUser, array $input): DatabaseUser
|
|
{
|
|
if (! isset($input['databases']) || ! is_array($input['databases'])) {
|
|
$input['databases'] = [];
|
|
}
|
|
|
|
$dbs = Database::query()
|
|
->where('server_id', $databaseUser->server_id)
|
|
->whereIn('name', $input['databases'])
|
|
->count();
|
|
if (count($input['databases']) !== $dbs) {
|
|
throw ValidationException::withMessages(['databases' => __('Databases not found!')]);
|
|
}
|
|
|
|
$databaseUser->databases = $input['databases'];
|
|
|
|
// Unlink the user from all databases
|
|
$databaseUser->server->database()->handler()->unlink(
|
|
$databaseUser->username,
|
|
$databaseUser->host
|
|
);
|
|
|
|
// Link the user to the selected databases
|
|
$databaseUser->server->database()->handler()->link(
|
|
$databaseUser->username,
|
|
$databaseUser->host,
|
|
$databaseUser->databases
|
|
);
|
|
|
|
$databaseUser->save();
|
|
|
|
$databaseUser->refresh();
|
|
|
|
return $databaseUser;
|
|
}
|
|
|
|
public static function rules(Server $server, array $input): array
|
|
{
|
|
return [
|
|
'databases.*' => [
|
|
'nullable',
|
|
Rule::exists('databases', 'name')->where('server_id', $server->id),
|
|
],
|
|
];
|
|
}
|
|
}
|