add more default variables, closes #427
This commit is contained in:
parent
a52d9eb0fb
commit
9343ac7b7d
|
@ -297,14 +297,7 @@ class ServerRepository
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add Variables
|
|
||||||
$environmentVariables = [
|
|
||||||
'STARTUP' => $data['startup'],
|
|
||||||
];
|
|
||||||
|
|
||||||
foreach ($variableList as $item) {
|
foreach ($variableList as $item) {
|
||||||
$environmentVariables[$item['env']] = $item['val'];
|
|
||||||
|
|
||||||
ServerVariable::create([
|
ServerVariable::create([
|
||||||
'server_id' => $server->id,
|
'server_id' => $server->id,
|
||||||
'variable_id' => $item['id'],
|
'variable_id' => $item['id'],
|
||||||
|
@ -312,7 +305,9 @@ class ServerRepository
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$environment = $this->parseVariables($server);
|
||||||
$server->load('allocation', 'allocations');
|
$server->load('allocation', 'allocations');
|
||||||
|
|
||||||
$node->guzzleClient(['X-Access-Token' => $node->daemonSecret])->request('POST', '/servers', [
|
$node->guzzleClient(['X-Access-Token' => $node->daemonSecret])->request('POST', '/servers', [
|
||||||
'json' => [
|
'json' => [
|
||||||
'uuid' => (string) $server->uuid,
|
'uuid' => (string) $server->uuid,
|
||||||
|
@ -325,7 +320,7 @@ class ServerRepository
|
||||||
'ports' => $server->allocations->groupBy('ip')->map(function ($item) {
|
'ports' => $server->allocations->groupBy('ip')->map(function ($item) {
|
||||||
return $item->pluck('port');
|
return $item->pluck('port');
|
||||||
})->toArray(),
|
})->toArray(),
|
||||||
'env' => $environmentVariables,
|
'env' => $environment->pluck('value', 'variable')->toArray(),
|
||||||
'memory' => (int) $server->memory,
|
'memory' => (int) $server->memory,
|
||||||
'swap' => (int) $server->swap,
|
'swap' => (int) $server->swap,
|
||||||
'io' => (int) $server->io,
|
'io' => (int) $server->io,
|
||||||
|
@ -576,6 +571,8 @@ class ServerRepository
|
||||||
$newBuild['ports|overwrite'] = $server->allocations->groupBy('ip')->map(function ($item) {
|
$newBuild['ports|overwrite'] = $server->allocations->groupBy('ip')->map(function ($item) {
|
||||||
return $item->pluck('port');
|
return $item->pluck('port');
|
||||||
})->toArray();
|
})->toArray();
|
||||||
|
|
||||||
|
$newBuild['env|overwrite'] = $this->parseVariables($server)->pluck('value', 'variable')->toArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
// @TODO: verify that server can be set to this much memory without
|
// @TODO: verify that server can be set to this much memory without
|
||||||
|
@ -632,20 +629,15 @@ class ServerRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the service configuration for a server.
|
* Process the variables for a server, and save to the database.
|
||||||
*
|
*
|
||||||
* @param int $id
|
* @param \Pterodactyl\Models\Server $server
|
||||||
* @param array $data
|
* @param array $data
|
||||||
* @return void
|
* @param bool $admin
|
||||||
|
* @return \Illuminate\Support\Collection
|
||||||
*
|
*
|
||||||
* @throws \GuzzleHttp\Exception\RequestException
|
|
||||||
* @throws \Pterodactyl\Exceptions\DisplayException
|
|
||||||
* @throws \Pterodactyl\Exceptions\DisplayValidationException
|
* @throws \Pterodactyl\Exceptions\DisplayValidationException
|
||||||
*/
|
*/
|
||||||
protected function changeService($id, array $data)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function processVariables(Server $server, $data, $admin = false)
|
protected function processVariables(Server $server, $data, $admin = false)
|
||||||
{
|
{
|
||||||
$server->load('option.variables');
|
$server->load('option.variables');
|
||||||
|
@ -698,10 +690,21 @@ class ServerRepository
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $this->parseVariables($server);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse the variables and return in a standardized format.
|
||||||
|
*
|
||||||
|
* @param \Pterodactyl\Models\Server $server
|
||||||
|
* @return \Illuminate\Support\Collection
|
||||||
|
*/
|
||||||
|
protected function parseVariables(Server $server)
|
||||||
|
{
|
||||||
// Reload Variables
|
// Reload Variables
|
||||||
$server->load('variables');
|
$server->load('variables');
|
||||||
|
|
||||||
return $server->option->variables->map(function ($item, $key) use ($server) {
|
$parsed = $server->option->variables->map(function ($item, $key) use ($server) {
|
||||||
$display = $server->variables->where('variable_id', $item->id)->pluck('variable_value')->first();
|
$display = $server->variables->where('variable_id', $item->id)->pluck('variable_value')->first();
|
||||||
|
|
||||||
return [
|
return [
|
||||||
|
@ -709,6 +712,28 @@ class ServerRepository
|
||||||
'value' => (! is_null($display)) ? $display : $item->default_value,
|
'value' => (! is_null($display)) ? $display : $item->default_value,
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$merge = [[
|
||||||
|
'variable' => 'STARTUP',
|
||||||
|
'value' => $server->startup,
|
||||||
|
], [
|
||||||
|
'variable' => 'P_VARIABLE__LOCATION',
|
||||||
|
'value' => $server->location->short,
|
||||||
|
]];
|
||||||
|
|
||||||
|
$allocations = $server->allocations->where('id', '!=', $server->allocation_id);
|
||||||
|
$i = 0;
|
||||||
|
|
||||||
|
foreach($allocations as $allocation) {
|
||||||
|
$merge[] = [
|
||||||
|
'variable' => 'ALLOC_' . $i . '__PORT',
|
||||||
|
'value' => $allocation->port,
|
||||||
|
];
|
||||||
|
|
||||||
|
$i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $parsed->merge($merge);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -767,7 +792,7 @@ class ServerRepository
|
||||||
])->request('PATCH', '/server', [
|
])->request('PATCH', '/server', [
|
||||||
'json' => [
|
'json' => [
|
||||||
'build' => [
|
'build' => [
|
||||||
'env|overwrite' => $environment->pluck('value', 'variable')->merge(['STARTUP' => $server->startup])->toArray(),
|
'env|overwrite' => $environment->pluck('value', 'variable')->toArray(),
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
|
@ -816,7 +841,7 @@ class ServerRepository
|
||||||
])->request('POST', '/server/reinstall', [
|
])->request('POST', '/server/reinstall', [
|
||||||
'json' => [
|
'json' => [
|
||||||
'build' => [
|
'build' => [
|
||||||
'env|overwrite' => $environment->pluck('value', 'variable')->merge(['STARTUP' => $server->startup])->toArray(),
|
'env|overwrite' => $environment->pluck('value', 'variable')->toArray(),
|
||||||
],
|
],
|
||||||
'service' => [
|
'service' => [
|
||||||
'type' => $server->option->service->folder,
|
'type' => $server->option->service->folder,
|
||||||
|
|
Loading…
Reference in New Issue