2018-01-28 23:14:14 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Http\Requests\Api\Application\Servers;
|
|
|
|
|
|
|
|
use Pterodactyl\Models\Server;
|
|
|
|
use Illuminate\Validation\Rule;
|
|
|
|
use Pterodactyl\Services\Acl\Api\AdminAcl;
|
|
|
|
use Illuminate\Contracts\Validation\Validator;
|
|
|
|
use Pterodactyl\Models\Objects\DeploymentObject;
|
|
|
|
use Pterodactyl\Http\Requests\Api\Application\ApplicationApiRequest;
|
|
|
|
|
|
|
|
class StoreServerRequest extends ApplicationApiRequest
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $resource = AdminAcl::RESOURCE_SERVERS;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
protected $permission = AdminAcl::WRITE;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Rules to be applied to this request.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function rules(): array
|
|
|
|
{
|
2019-09-05 06:26:28 +01:00
|
|
|
$rules = Server::getRules();
|
2018-01-28 23:14:14 +00:00
|
|
|
|
|
|
|
return [
|
2018-02-24 17:57:12 +00:00
|
|
|
'external_id' => $rules['external_id'],
|
2018-01-28 23:14:14 +00:00
|
|
|
'name' => $rules['name'],
|
|
|
|
'description' => array_merge(['nullable'], $rules['description']),
|
|
|
|
'user' => $rules['owner_id'],
|
|
|
|
'egg' => $rules['egg_id'],
|
|
|
|
'docker_image' => $rules['image'],
|
|
|
|
'startup' => $rules['startup'],
|
2018-03-02 00:35:53 +00:00
|
|
|
'environment' => 'present|array',
|
2018-01-28 23:14:14 +00:00
|
|
|
'skip_scripts' => 'sometimes|boolean',
|
2019-08-03 21:41:24 +01:00
|
|
|
'oom_disabled' => 'sometimes|boolean',
|
2018-01-28 23:14:14 +00:00
|
|
|
|
|
|
|
// Resource limitations
|
|
|
|
'limits' => 'required|array',
|
|
|
|
'limits.memory' => $rules['memory'],
|
|
|
|
'limits.swap' => $rules['swap'],
|
|
|
|
'limits.disk' => $rules['disk'],
|
|
|
|
'limits.io' => $rules['io'],
|
2020-03-29 19:41:55 +01:00
|
|
|
'limits.threads' => $rules['threads'],
|
2018-01-28 23:14:14 +00:00
|
|
|
'limits.cpu' => $rules['cpu'],
|
|
|
|
|
2018-03-03 05:11:30 +00:00
|
|
|
// Application Resource Limits
|
|
|
|
'feature_limits' => 'required|array',
|
|
|
|
'feature_limits.databases' => $rules['database_limit'],
|
|
|
|
'feature_limits.allocations' => $rules['allocation_limit'],
|
|
|
|
|
2018-02-10 20:01:49 +00:00
|
|
|
// Placeholders for rules added in withValidator() function.
|
|
|
|
'allocation.default' => '',
|
|
|
|
'allocation.additional.*' => '',
|
|
|
|
|
2018-01-28 23:14:14 +00:00
|
|
|
// Automatic deployment rules
|
|
|
|
'deploy' => 'sometimes|required|array',
|
|
|
|
'deploy.locations' => 'array',
|
|
|
|
'deploy.locations.*' => 'integer|min:1',
|
|
|
|
'deploy.dedicated_ip' => 'required_with:deploy,boolean',
|
|
|
|
'deploy.port_range' => 'array',
|
|
|
|
'deploy.port_range.*' => 'string',
|
|
|
|
|
|
|
|
'start_on_completion' => 'sometimes|boolean',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Normalize the data into a format that can be consumed by the service.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function validated()
|
|
|
|
{
|
|
|
|
$data = parent::validated();
|
|
|
|
|
|
|
|
return [
|
2018-02-25 20:43:40 +00:00
|
|
|
'external_id' => array_get($data, 'external_id'),
|
2018-01-28 23:14:14 +00:00
|
|
|
'name' => array_get($data, 'name'),
|
|
|
|
'description' => array_get($data, 'description'),
|
|
|
|
'owner_id' => array_get($data, 'user'),
|
|
|
|
'egg_id' => array_get($data, 'egg'),
|
|
|
|
'image' => array_get($data, 'docker_image'),
|
|
|
|
'startup' => array_get($data, 'startup'),
|
|
|
|
'environment' => array_get($data, 'environment'),
|
|
|
|
'memory' => array_get($data, 'limits.memory'),
|
|
|
|
'swap' => array_get($data, 'limits.swap'),
|
|
|
|
'disk' => array_get($data, 'limits.disk'),
|
|
|
|
'io' => array_get($data, 'limits.io'),
|
|
|
|
'cpu' => array_get($data, 'limits.cpu'),
|
2020-03-29 19:41:55 +01:00
|
|
|
'threads' => array_get($data, 'limits.threads'),
|
2018-01-28 23:14:14 +00:00
|
|
|
'skip_scripts' => array_get($data, 'skip_scripts', false),
|
|
|
|
'allocation_id' => array_get($data, 'allocation.default'),
|
|
|
|
'allocation_additional' => array_get($data, 'allocation.additional'),
|
|
|
|
'start_on_completion' => array_get($data, 'start_on_completion', false),
|
2018-03-03 05:11:30 +00:00
|
|
|
'database_limit' => array_get($data, 'feature_limits.databases'),
|
|
|
|
'allocation_limit' => array_get($data, 'feature_limits.allocations'),
|
2018-01-28 23:14:14 +00:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Run validation after the rules above have been applied.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Contracts\Validation\Validator $validator
|
|
|
|
*/
|
|
|
|
public function withValidator(Validator $validator)
|
|
|
|
{
|
|
|
|
$validator->sometimes('allocation.default', [
|
|
|
|
'required', 'integer', 'bail',
|
|
|
|
Rule::exists('allocations', 'id')->where(function ($query) {
|
|
|
|
$query->whereNull('server_id');
|
|
|
|
}),
|
|
|
|
], function ($input) {
|
|
|
|
return ! ($input->deploy);
|
|
|
|
});
|
|
|
|
|
|
|
|
$validator->sometimes('allocation.additional.*', [
|
|
|
|
'integer',
|
|
|
|
Rule::exists('allocations', 'id')->where(function ($query) {
|
|
|
|
$query->whereNull('server_id');
|
|
|
|
}),
|
|
|
|
], function ($input) {
|
|
|
|
return ! ($input->deploy);
|
|
|
|
});
|
|
|
|
|
|
|
|
$validator->sometimes('deploy.locations', 'present', function ($input) {
|
|
|
|
return $input->deploy;
|
|
|
|
});
|
|
|
|
|
|
|
|
$validator->sometimes('deploy.port_range', 'present', function ($input) {
|
|
|
|
return $input->deploy;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a deployment object that can be passed to the server creation service.
|
|
|
|
*
|
|
|
|
* @return \Pterodactyl\Models\Objects\DeploymentObject|null
|
|
|
|
*/
|
|
|
|
public function getDeploymentObject()
|
|
|
|
{
|
|
|
|
if (is_null($this->input('deploy'))) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
$object = new DeploymentObject;
|
|
|
|
$object->setDedicated($this->input('deploy.dedicated_ip', false));
|
|
|
|
$object->setLocations($this->input('deploy.locations', []));
|
|
|
|
$object->setPorts($this->input('deploy.port_range', []));
|
|
|
|
|
|
|
|
return $object;
|
|
|
|
}
|
|
|
|
}
|