2018-01-27 18:38:56 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Pterodactyl\Transformers\Api\Application;
|
|
|
|
|
2022-05-07 22:45:22 +01:00
|
|
|
use Illuminate\Support\Arr;
|
2022-05-14 21:03:50 +01:00
|
|
|
use Pterodactyl\Models\Egg;
|
2018-01-27 18:38:56 +00:00
|
|
|
use Pterodactyl\Models\Nest;
|
|
|
|
use Pterodactyl\Models\Server;
|
2018-02-24 17:17:21 +00:00
|
|
|
use Pterodactyl\Models\EggVariable;
|
2018-01-27 18:38:56 +00:00
|
|
|
use Pterodactyl\Services\Acl\Api\AdminAcl;
|
|
|
|
|
|
|
|
class EggTransformer extends BaseTransformer
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Relationships that can be loaded onto this transformation.
|
|
|
|
*/
|
2022-05-05 00:11:42 +01:00
|
|
|
protected array $availableIncludes = [
|
2021-01-27 05:08:53 +00:00
|
|
|
'nest',
|
|
|
|
'servers',
|
|
|
|
'config',
|
|
|
|
'script',
|
|
|
|
'variables',
|
2018-01-27 18:38:56 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the resource name for the JSONAPI output.
|
|
|
|
*/
|
|
|
|
public function getResourceName(): string
|
|
|
|
{
|
|
|
|
return Egg::RESOURCE_NAME;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Transform an Egg model into a representation that can be consumed by
|
|
|
|
* the application api.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function transform(Egg $model)
|
|
|
|
{
|
2022-09-17 19:36:41 +01:00
|
|
|
$files = json_decode($model->config_files, true, 512, JSON_THROW_ON_ERROR);
|
|
|
|
if (empty($files)) {
|
|
|
|
$files = new \stdClass();
|
|
|
|
}
|
|
|
|
|
2018-01-27 18:38:56 +00:00
|
|
|
return [
|
|
|
|
'id' => $model->id,
|
|
|
|
'uuid' => $model->uuid,
|
2019-12-28 19:12:01 +00:00
|
|
|
'name' => $model->name,
|
2018-01-27 18:38:56 +00:00
|
|
|
'nest' => $model->nest_id,
|
|
|
|
'author' => $model->author,
|
|
|
|
'description' => $model->description,
|
2020-12-13 17:53:17 +00:00
|
|
|
// "docker_image" is deprecated, but left here to avoid breaking too many things at once
|
|
|
|
// in external software. We'll remove it down the road once things have gotten the chance
|
|
|
|
// to upgrade to using "docker_images".
|
2022-05-07 22:45:22 +01:00
|
|
|
'docker_image' => count($model->docker_images) > 0 ? Arr::first($model->docker_images) : '',
|
2020-12-13 17:53:17 +00:00
|
|
|
'docker_images' => $model->docker_images,
|
2018-01-27 18:38:56 +00:00
|
|
|
'config' => [
|
2022-09-17 19:36:41 +01:00
|
|
|
'files' => $files,
|
2018-03-25 23:41:36 +01:00
|
|
|
'startup' => json_decode($model->config_startup, true),
|
2018-01-27 18:38:56 +00:00
|
|
|
'stop' => $model->config_stop,
|
2018-03-25 23:41:36 +01:00
|
|
|
'logs' => json_decode($model->config_logs, true),
|
2021-01-27 05:08:53 +00:00
|
|
|
'file_denylist' => $model->file_denylist,
|
2018-01-27 18:38:56 +00:00
|
|
|
'extends' => $model->config_from,
|
|
|
|
],
|
|
|
|
'startup' => $model->startup,
|
|
|
|
'script' => [
|
|
|
|
'privileged' => $model->script_is_privileged,
|
|
|
|
'install' => $model->script_install,
|
|
|
|
'entry' => $model->script_entry,
|
|
|
|
'container' => $model->script_container,
|
|
|
|
'extends' => $model->copy_script_from,
|
|
|
|
],
|
|
|
|
$model->getCreatedAtColumn() => $this->formatTimestamp($model->created_at),
|
|
|
|
$model->getUpdatedAtColumn() => $this->formatTimestamp($model->updated_at),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Include the Nest relationship for the given Egg in the transformation.
|
|
|
|
*
|
|
|
|
* @return \League\Fractal\Resource\Item|\League\Fractal\Resource\NullResource
|
2021-01-23 20:33:34 +00:00
|
|
|
*
|
2018-05-13 17:19:35 +01:00
|
|
|
* @throws \Pterodactyl\Exceptions\Transformer\InvalidTransformerLevelException
|
2018-01-27 18:38:56 +00:00
|
|
|
*/
|
|
|
|
public function includeNest(Egg $model)
|
|
|
|
{
|
2021-01-23 20:33:34 +00:00
|
|
|
if (!$this->authorize(AdminAcl::RESOURCE_NESTS)) {
|
2018-01-27 18:38:56 +00:00
|
|
|
return $this->null();
|
|
|
|
}
|
|
|
|
|
|
|
|
$model->loadMissing('nest');
|
|
|
|
|
|
|
|
return $this->item($model->getRelation('nest'), $this->makeTransformer(NestTransformer::class), Nest::RESOURCE_NAME);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Include the Servers relationship for the given Egg in the transformation.
|
|
|
|
*
|
|
|
|
* @return \League\Fractal\Resource\Collection|\League\Fractal\Resource\NullResource
|
2021-01-23 20:33:34 +00:00
|
|
|
*
|
2018-05-13 17:19:35 +01:00
|
|
|
* @throws \Pterodactyl\Exceptions\Transformer\InvalidTransformerLevelException
|
2018-01-27 18:38:56 +00:00
|
|
|
*/
|
|
|
|
public function includeServers(Egg $model)
|
|
|
|
{
|
2021-01-23 20:33:34 +00:00
|
|
|
if (!$this->authorize(AdminAcl::RESOURCE_SERVERS)) {
|
2018-01-27 18:38:56 +00:00
|
|
|
return $this->null();
|
|
|
|
}
|
|
|
|
|
|
|
|
$model->loadMissing('servers');
|
|
|
|
|
|
|
|
return $this->collection($model->getRelation('servers'), $this->makeTransformer(ServerTransformer::class), Server::RESOURCE_NAME);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Include more detailed information about the configuration if this Egg is
|
|
|
|
* extending another.
|
|
|
|
*
|
|
|
|
* @return \League\Fractal\Resource\Item|\League\Fractal\Resource\NullResource
|
|
|
|
*/
|
|
|
|
public function includeConfig(Egg $model)
|
|
|
|
{
|
|
|
|
if (is_null($model->config_from)) {
|
|
|
|
return $this->null();
|
|
|
|
}
|
|
|
|
|
|
|
|
$model->loadMissing('configFrom');
|
|
|
|
|
|
|
|
return $this->item($model, function (Egg $model) {
|
|
|
|
return [
|
|
|
|
'files' => json_decode($model->inherit_config_files),
|
|
|
|
'startup' => json_decode($model->inherit_config_startup),
|
|
|
|
'stop' => $model->inherit_config_stop,
|
|
|
|
'logs' => json_decode($model->inherit_config_logs),
|
|
|
|
];
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Include more detailed information about the script configuration if the
|
|
|
|
* Egg is extending another.
|
|
|
|
*
|
|
|
|
* @return \League\Fractal\Resource\Item|\League\Fractal\Resource\NullResource
|
|
|
|
*/
|
|
|
|
public function includeScript(Egg $model)
|
|
|
|
{
|
|
|
|
if (is_null($model->copy_script_from)) {
|
|
|
|
return $this->null();
|
|
|
|
}
|
|
|
|
|
|
|
|
$model->loadMissing('scriptFrom');
|
|
|
|
|
|
|
|
return $this->item($model, function (Egg $model) {
|
|
|
|
return [
|
|
|
|
'privileged' => $model->script_is_privileged,
|
|
|
|
'install' => $model->copy_script_install,
|
|
|
|
'entry' => $model->copy_script_entry,
|
|
|
|
'container' => $model->copy_script_container,
|
|
|
|
];
|
|
|
|
});
|
|
|
|
}
|
2018-02-24 17:17:21 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Include the variables that are defined for this Egg.
|
|
|
|
*
|
|
|
|
* @return \League\Fractal\Resource\Collection|\League\Fractal\Resource\NullResource
|
2021-01-23 20:33:34 +00:00
|
|
|
*
|
2018-05-13 17:19:35 +01:00
|
|
|
* @throws \Pterodactyl\Exceptions\Transformer\InvalidTransformerLevelException
|
2018-02-24 17:17:21 +00:00
|
|
|
*/
|
|
|
|
public function includeVariables(Egg $model)
|
|
|
|
{
|
2021-01-23 20:33:34 +00:00
|
|
|
if (!$this->authorize(AdminAcl::RESOURCE_EGGS)) {
|
2018-02-24 17:17:21 +00:00
|
|
|
return $this->null();
|
|
|
|
}
|
|
|
|
|
|
|
|
$model->loadMissing('variables');
|
|
|
|
|
|
|
|
return $this->collection(
|
|
|
|
$model->getRelation('variables'),
|
|
|
|
$this->makeTransformer(EggVariableTransformer::class),
|
|
|
|
EggVariable::RESOURCE_NAME
|
|
|
|
);
|
|
|
|
}
|
2018-01-27 18:38:56 +00:00
|
|
|
}
|