2024-02-16 20:56:38 +00:00
|
|
|
<?php
|
|
|
|
|
2024-06-28 13:05:37 +00:00
|
|
|
use App\Enums\BuildPackTypes;
|
|
|
|
use App\Enums\RedirectTypes;
|
|
|
|
use App\Models\Server;
|
2024-06-21 14:46:13 +00:00
|
|
|
use Illuminate\Database\Eloquent\Collection;
|
2024-06-28 13:05:37 +00:00
|
|
|
use Illuminate\Http\Request;
|
|
|
|
use Illuminate\Validation\Rule;
|
2024-06-21 14:46:13 +00:00
|
|
|
|
2024-02-16 20:56:38 +00:00
|
|
|
function get_team_id_from_token()
|
|
|
|
{
|
|
|
|
$token = auth()->user()->currentAccessToken();
|
2024-06-10 20:43:34 +00:00
|
|
|
|
2024-02-16 20:56:38 +00:00
|
|
|
return data_get($token, 'team_id');
|
|
|
|
}
|
2024-03-07 11:27:23 +00:00
|
|
|
function invalid_token()
|
|
|
|
{
|
2024-03-27 10:07:29 +00:00
|
|
|
return response()->json(['error' => 'Invalid token.', 'docs' => 'https://coolify.io/docs/api-reference/authorization'], 400);
|
2024-03-07 11:27:23 +00:00
|
|
|
}
|
2024-06-21 14:46:13 +00:00
|
|
|
|
|
|
|
function serialize_api_response($data)
|
|
|
|
{
|
|
|
|
if (! $data instanceof Collection) {
|
|
|
|
$data = collect($data);
|
|
|
|
}
|
|
|
|
$data = $data->sortKeys();
|
|
|
|
$created_at = data_get($data, 'created_at');
|
|
|
|
$updated_at = data_get($data, 'updated_at');
|
|
|
|
if ($created_at) {
|
|
|
|
unset($data['created_at']);
|
|
|
|
$data['created_at'] = $created_at;
|
|
|
|
|
|
|
|
}
|
|
|
|
if ($updated_at) {
|
|
|
|
unset($data['updated_at']);
|
|
|
|
$data['updated_at'] = $updated_at;
|
|
|
|
}
|
|
|
|
if (data_get($data, 'id')) {
|
|
|
|
$data = $data->prepend($data['id'], 'id');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
2024-06-28 13:05:37 +00:00
|
|
|
|
|
|
|
function sharedDataApplications()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'git_repository' => 'string',
|
|
|
|
'git_branch' => 'string',
|
|
|
|
'build_pack' => Rule::enum(BuildPackTypes::class),
|
|
|
|
'is_static' => 'boolean',
|
|
|
|
'domains' => 'string',
|
|
|
|
'redirect' => Rule::enum(RedirectTypes::class),
|
|
|
|
'git_commit_sha' => 'string',
|
|
|
|
'docker_registry_image_name' => 'string|nullable',
|
|
|
|
'docker_registry_image_tag' => 'string|nullable',
|
|
|
|
'install_command' => 'string|nullable',
|
|
|
|
'build_command' => 'string|nullable',
|
|
|
|
'start_command' => 'string|nullable',
|
|
|
|
'ports_exposes' => 'string|regex:/^(\d+)(,\d+)*$/',
|
|
|
|
'ports_mappings' => 'string|regex:/^(\d+:\d+)(,\d+:\d+)*$/|nullable',
|
|
|
|
'base_directory' => 'string|nullable',
|
|
|
|
'publish_directory' => 'string|nullable',
|
|
|
|
'health_check_enabled' => 'boolean',
|
|
|
|
'health_check_path' => 'string',
|
|
|
|
'health_check_port' => 'string|nullable',
|
|
|
|
'health_check_host' => 'string',
|
|
|
|
'health_check_method' => 'string',
|
|
|
|
'health_check_return_code' => 'numeric',
|
|
|
|
'health_check_scheme' => 'string',
|
|
|
|
'health_check_response_text' => 'string|nullable',
|
|
|
|
'health_check_interval' => 'numeric',
|
|
|
|
'health_check_timeout' => 'numeric',
|
|
|
|
'health_check_retries' => 'numeric',
|
|
|
|
'health_check_start_period' => 'numeric',
|
|
|
|
'limits_memory' => 'string',
|
|
|
|
'limits_memory_swap' => 'string',
|
|
|
|
'limits_memory_swappiness' => 'numeric',
|
|
|
|
'limits_memory_reservation' => 'string',
|
|
|
|
'limits_cpus' => 'string',
|
|
|
|
'limits_cpuset' => 'string|nullable',
|
|
|
|
'limits_cpu_shares' => 'numeric',
|
|
|
|
'custom_labels' => 'string|nullable',
|
|
|
|
'custom_docker_run_options' => 'string|nullable',
|
|
|
|
'post_deployment_command' => 'string|nullable',
|
|
|
|
'post_deployment_command_container' => 'string',
|
|
|
|
'pre_deployment_command' => 'string|nullable',
|
|
|
|
'pre_deployment_command_container' => 'string',
|
|
|
|
'manual_webhook_secret_github' => 'string|nullable',
|
|
|
|
'manual_webhook_secret_gitlab' => 'string|nullable',
|
|
|
|
'manual_webhook_secret_bitbucket' => 'string|nullable',
|
|
|
|
'manual_webhook_secret_gitea' => 'string|nullable',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
function validateDataApplications(Request $request, Server $server)
|
|
|
|
{
|
|
|
|
// Validate ports_mappings
|
|
|
|
if ($request->has('ports_mappings')) {
|
|
|
|
$ports = [];
|
|
|
|
foreach (explode(',', $request->ports_mappings) as $portMapping) {
|
|
|
|
$port = explode(':', $portMapping);
|
|
|
|
if (in_array($port[0], $ports)) {
|
|
|
|
return response()->json([
|
|
|
|
'message' => 'Validation failed.',
|
|
|
|
'errors' => [
|
|
|
|
'ports_mappings' => 'The first number before : should be unique between mappings.',
|
|
|
|
],
|
|
|
|
], 422);
|
|
|
|
}
|
|
|
|
$ports[] = $port[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Validate custom_labels
|
|
|
|
if ($request->has('custom_labels')) {
|
|
|
|
if (! isBase64Encoded($request->custom_labels)) {
|
|
|
|
return response()->json([
|
|
|
|
'message' => 'Validation failed.',
|
|
|
|
'errors' => [
|
|
|
|
'custom_labels' => 'The custom_labels should be base64 encoded.',
|
|
|
|
],
|
|
|
|
], 422);
|
|
|
|
}
|
|
|
|
$customLabels = base64_decode($request->custom_labels);
|
|
|
|
if (mb_detect_encoding($customLabels, 'ASCII', true) === false) {
|
|
|
|
return response()->json([
|
|
|
|
'message' => 'Validation failed.',
|
|
|
|
'errors' => [
|
|
|
|
'custom_labels' => 'The custom_labels should be base64 encoded.',
|
|
|
|
],
|
|
|
|
], 422);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($request->has('domains') && $server->isProxyShouldRun()) {
|
|
|
|
$fqdn = $request->domains;
|
|
|
|
$fqdn = str($fqdn)->replaceEnd(',', '')->trim();
|
|
|
|
$fqdn = str($fqdn)->replaceStart(',', '')->trim();
|
|
|
|
$errors = [];
|
|
|
|
$fqdn = str($fqdn)->trim()->explode(',')->map(function ($domain) use (&$errors) {
|
|
|
|
ray(filter_var($domain, FILTER_VALIDATE_URL));
|
|
|
|
if (filter_var($domain, FILTER_VALIDATE_URL) === false) {
|
|
|
|
$errors[] = 'Invalid domain: '.$domain;
|
|
|
|
}
|
|
|
|
|
|
|
|
return str($domain)->trim()->lower();
|
|
|
|
});
|
|
|
|
if (count($errors) > 0) {
|
|
|
|
return response()->json([
|
|
|
|
'message' => 'Validation failed.',
|
|
|
|
'errors' => $errors,
|
|
|
|
], 422);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|