2018-01-26 04:34:53 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Http\Requests\Api\Application\Servers\Databases;
|
|
|
|
|
2020-10-11 19:59:46 +01:00
|
|
|
use Webmozart\Assert\Assert;
|
|
|
|
use Pterodactyl\Models\Server;
|
2019-03-02 23:31:25 +00:00
|
|
|
use Illuminate\Validation\Rule;
|
|
|
|
use Illuminate\Database\Query\Builder;
|
2018-01-26 04:34:53 +00:00
|
|
|
use Pterodactyl\Services\Acl\Api\AdminAcl;
|
2020-10-11 19:59:46 +01:00
|
|
|
use Pterodactyl\Services\Databases\DatabaseManagementService;
|
2018-01-26 04:34:53 +00:00
|
|
|
use Pterodactyl\Http\Requests\Api\Application\ApplicationApiRequest;
|
|
|
|
|
|
|
|
class StoreServerDatabaseRequest extends ApplicationApiRequest
|
|
|
|
{
|
2022-10-14 17:59:20 +01:00
|
|
|
protected ?string $resource = AdminAcl::RESOURCE_SERVER_DATABASES;
|
2018-01-26 04:34:53 +00:00
|
|
|
|
2022-10-14 17:59:20 +01:00
|
|
|
protected int $permission = AdminAcl::WRITE;
|
2018-01-26 04:34:53 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Validation rules for database creation.
|
|
|
|
*/
|
|
|
|
public function rules(): array
|
|
|
|
{
|
2020-10-11 19:59:46 +01:00
|
|
|
$server = $this->route()->parameter('server');
|
|
|
|
|
2018-01-26 04:34:53 +00:00
|
|
|
return [
|
2019-03-02 23:31:25 +00:00
|
|
|
'database' => [
|
|
|
|
'required',
|
2020-10-11 19:59:46 +01:00
|
|
|
'alpha_dash',
|
2019-03-02 23:31:25 +00:00
|
|
|
'min:1',
|
2020-10-11 19:59:46 +01:00
|
|
|
'max:48',
|
|
|
|
Rule::unique('databases')->where(function (Builder $query) use ($server) {
|
|
|
|
$query->where('server_id', $server->id)->where('database', $this->databaseName());
|
2019-03-02 23:31:25 +00:00
|
|
|
}),
|
|
|
|
],
|
2018-05-21 01:11:52 +01:00
|
|
|
'remote' => 'required|string|regex:/^[0-9%.]{1,15}$/',
|
2018-01-26 04:34:53 +00:00
|
|
|
'host' => 'required|integer|exists:database_hosts,id',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return data formatted in the correct format for the service to consume.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function validated($key = null, $default = null): array
|
2018-01-26 04:34:53 +00:00
|
|
|
{
|
|
|
|
return [
|
|
|
|
'database' => $this->input('database'),
|
|
|
|
'remote' => $this->input('remote'),
|
|
|
|
'database_host_id' => $this->input('host'),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format error messages in a more understandable format for API output.
|
|
|
|
*/
|
2022-10-14 17:59:20 +01:00
|
|
|
public function attributes(): array
|
2018-01-26 04:34:53 +00:00
|
|
|
{
|
|
|
|
return [
|
|
|
|
'host' => 'Database Host Server ID',
|
|
|
|
'remote' => 'Remote Connection String',
|
|
|
|
'database' => 'Database Name',
|
|
|
|
];
|
|
|
|
}
|
2020-10-11 19:59:46 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the database name in the expected format.
|
|
|
|
*/
|
|
|
|
public function databaseName(): string
|
|
|
|
{
|
|
|
|
$server = $this->route()->parameter('server');
|
|
|
|
|
|
|
|
Assert::isInstanceOf($server, Server::class);
|
|
|
|
|
|
|
|
return DatabaseManagementService::generateUniqueDatabaseName($this->input('database'), $server->id);
|
|
|
|
}
|
2018-01-26 04:34:53 +00:00
|
|
|
}
|