2018-08-23 06:29:20 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Http\Requests\Api\Client\Servers\Databases;
|
|
|
|
|
2020-10-11 02:17:04 +01:00
|
|
|
use Webmozart\Assert\Assert;
|
|
|
|
use Pterodactyl\Models\Server;
|
|
|
|
use Illuminate\Validation\Rule;
|
2022-05-07 19:17:10 +01:00
|
|
|
use Pterodactyl\Models\Database;
|
2020-03-22 22:31:25 +00:00
|
|
|
use Pterodactyl\Models\Permission;
|
2020-10-11 02:17:04 +01:00
|
|
|
use Illuminate\Database\Query\Builder;
|
2018-08-23 06:29:20 +01:00
|
|
|
use Pterodactyl\Contracts\Http\ClientPermissionsRequest;
|
|
|
|
use Pterodactyl\Http\Requests\Api\Client\ClientApiRequest;
|
2020-10-11 19:59:46 +01:00
|
|
|
use Pterodactyl\Services\Databases\DatabaseManagementService;
|
2018-08-23 06:29:20 +01:00
|
|
|
|
|
|
|
class StoreDatabaseRequest extends ClientApiRequest implements ClientPermissionsRequest
|
|
|
|
{
|
|
|
|
public function permission(): string
|
|
|
|
{
|
2020-03-22 22:31:25 +00:00
|
|
|
return Permission::ACTION_DATABASE_CREATE;
|
2018-08-23 06:29:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function rules(): array
|
|
|
|
{
|
2020-10-11 02:17:04 +01:00
|
|
|
$server = $this->route()->parameter('server');
|
|
|
|
|
|
|
|
Assert::isInstanceOf($server, Server::class);
|
|
|
|
|
2018-08-23 06:29:20 +01:00
|
|
|
return [
|
2020-10-11 02:17:04 +01:00
|
|
|
'database' => [
|
|
|
|
'required',
|
|
|
|
'alpha_dash',
|
2022-05-07 19:17:10 +01:00
|
|
|
'min:3',
|
2020-10-11 02:17:04 +01:00
|
|
|
'max:48',
|
|
|
|
// Yes, I am aware that you could have the same database name across two unique hosts. However,
|
|
|
|
// I don't really care about that for this validation. We just want to make sure it is unique to
|
|
|
|
// the server itself. No need for complexity.
|
2020-10-11 19:59:46 +01:00
|
|
|
Rule::unique('databases')->where(function (Builder $query) use ($server) {
|
|
|
|
$query->where('server_id', $server->id)
|
|
|
|
->where('database', DatabaseManagementService::generateUniqueDatabaseName($this->input('database'), $server->id));
|
2020-10-11 02:17:04 +01:00
|
|
|
}),
|
|
|
|
],
|
2022-05-07 19:17:10 +01:00
|
|
|
'remote' => Database::getRulesForField('remote'),
|
2018-08-23 06:29:20 +01:00
|
|
|
];
|
|
|
|
}
|
2020-10-11 02:17:04 +01:00
|
|
|
|
2020-10-11 19:59:46 +01:00
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
2020-10-11 02:17:04 +01:00
|
|
|
public function messages()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'database.unique' => 'The database name you have selected is already in use by this server.',
|
|
|
|
];
|
|
|
|
}
|
2018-08-23 06:29:20 +01:00
|
|
|
}
|