Wip - not working
This commit is contained in:
@@ -31,8 +31,8 @@ class DeployApplicationJob implements ShouldQueue
|
|||||||
protected $destination;
|
protected $destination;
|
||||||
protected $source;
|
protected $source;
|
||||||
protected Activity $activity;
|
protected Activity $activity;
|
||||||
protected array $command = [];
|
|
||||||
protected string $git_commit;
|
protected string $git_commit;
|
||||||
|
protected string $workdir;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new job instance.
|
* Create a new job instance.
|
||||||
@@ -75,11 +75,6 @@ class DeployApplicationJob implements ShouldQueue
|
|||||||
$coolify_instance_settings = CoolifyInstanceSettings::find(1);
|
$coolify_instance_settings = CoolifyInstanceSettings::find(1);
|
||||||
$this->source = $this->application->source->getMorphClass()::where('id', $this->application->source->id)->first();
|
$this->source = $this->application->source->getMorphClass()::where('id', $this->application->source->id)->first();
|
||||||
|
|
||||||
$source_html_url = data_get($this->application, 'source.html_url');
|
|
||||||
$url = parse_url(filter_var($source_html_url, FILTER_SANITIZE_URL));
|
|
||||||
$source_html_url_host = $url['host'];
|
|
||||||
$source_html_url_scheme = $url['scheme'];
|
|
||||||
|
|
||||||
// Get Wildcard Domain
|
// Get Wildcard Domain
|
||||||
$project_wildcard_domain = data_get($this->application, 'environment.project.settings.wildcard_domain');
|
$project_wildcard_domain = data_get($this->application, 'environment.project.settings.wildcard_domain');
|
||||||
$global_wildcard_domain = data_get($coolify_instance_settings, 'wildcard_domain');
|
$global_wildcard_domain = data_get($coolify_instance_settings, 'wildcard_domain');
|
||||||
@@ -90,66 +85,49 @@ class DeployApplicationJob implements ShouldQueue
|
|||||||
$this->application->fqdn = $this->application->uuid . '.' . $wildcard_domain;
|
$this->application->fqdn = $this->application->uuid . '.' . $wildcard_domain;
|
||||||
$this->application->save();
|
$this->application->save();
|
||||||
}
|
}
|
||||||
$workdir = "/artifacts/{$this->deployment_uuid}";
|
$this->workdir = "/artifacts/{$this->deployment_uuid}";
|
||||||
|
|
||||||
// Start build process
|
// Pull builder image
|
||||||
$command_git_clone[] = "echo 'Starting deployment of {$this->application->git_repository}:{$this->application->git_branch}...'";
|
$this->executeNow([
|
||||||
$command_git_clone[] = "echo -n 'Pulling latest version of the builder image (ghcr.io/coollabsio/coolify-builder)... '";
|
"echo 'Starting deployment of {$this->application->git_repository}:{$this->application->git_branch}...",
|
||||||
$command_git_clone[] = "docker run --pull=always -d --name {$this->deployment_uuid} --rm -v /var/run/docker.sock:/var/run/docker.sock ghcr.io/coollabsio/coolify-builder >/dev/null 2>&1";
|
"echo -n 'Pulling latest version of the builder image (ghcr.io/coollabsio/coolify-builder)... '",
|
||||||
$command_git_clone[] = "echo 'Done.'";
|
"docker run --pull=always -d --name {$this->deployment_uuid} --rm -v /var/run/docker.sock:/var/run/docker.sock ghcr.io/coollabsio/coolify-builder >/dev/null 2>&1",
|
||||||
$command_git_clone[] = "echo -n 'Importing {$this->application->git_repository}:{$this->application->git_branch} to {$workdir}... '";
|
"echo 'Done.'",
|
||||||
if ($this->application->source->getMorphClass() == 'App\Models\GithubApp') {
|
], 'docker_pull_builder_image');
|
||||||
if ($this->source->is_public) {
|
|
||||||
$command_git_clone[] = $this->execute_in_builder("git clone -q -b {$this->application->git_branch} {$this->source->html_url}/{$this->application->git_repository}.git {$workdir}");
|
// Import git repository
|
||||||
} else {
|
$this->executeNow([
|
||||||
$github_access_token = $this->generate_jwt_token_for_github();
|
"echo -n 'Importing {$this->application->git_repository}:{$this->application->git_branch} to {$this->workdir}... '",
|
||||||
$command_git_clone[] = $this->execute_in_builder("git clone -q -b {$this->application->git_branch} $source_html_url_scheme://x-access-token:$github_access_token@$source_html_url_host/{$this->application->git_repository}.git {$workdir}");
|
$this->gitImport(),
|
||||||
}
|
"echo 'Done.'"
|
||||||
}
|
], 'importing_git_repository');
|
||||||
$command_git_clone[] = "echo 'Done.'";
|
|
||||||
$this->executeNow($command_git_clone, 'git_clone');
|
// Get git commit
|
||||||
// Export git commit to a file
|
$this->executeNow([$this->execute_in_builder("cd {$this->workdir} && git rev-parse HEAD")], 'commit_sha', hideFromOutput: true);
|
||||||
$this->executeNow([$this->execute_in_builder("cd {$workdir} && git rev-parse HEAD")], 'commit_sha', hideFromOutput: true);
|
|
||||||
$this->git_commit = $this->activity->properties->get('commit_sha');
|
$this->git_commit = $this->activity->properties->get('commit_sha');
|
||||||
|
|
||||||
$this->executeNow([$this->execute_in_builder("rm -fr {$workdir}/.git")], 'remote_git', hideFromOutput: true);
|
$this->executeNow([
|
||||||
|
$this->execute_in_builder("rm -fr {$this->workdir}/.git")
|
||||||
|
], hideFromOutput: true);
|
||||||
|
|
||||||
// Create docker-compose.yml && replace TAG with git commit
|
|
||||||
$docker_compose_base64 = base64_encode($this->generate_docker_compose());
|
$docker_compose_base64 = base64_encode($this->generate_docker_compose());
|
||||||
$this->executeNow([$this->execute_in_builder("echo '{$docker_compose_base64}' | base64 -d > {$workdir}/docker-compose.yml")], 'docker_compose');
|
$this->executeNow([
|
||||||
$this->executeNow([$this->execute_in_builder("cat {$workdir}/docker-compose.yml")], 'docker_compose_content');
|
$this->execute_in_builder("echo '{$docker_compose_base64}' | base64 -d > {$this->workdir}/docker-compose.yml")
|
||||||
$command_other_command[] = "echo -n 'Generating nixpacks configuration... '";
|
], hideFromOutput: true);
|
||||||
if (str_starts_with($this->application->base_image, 'apache') || str_starts_with($this->application->base_image, 'nginx')) {
|
|
||||||
// @TODO: Add static site builds
|
|
||||||
} else {
|
|
||||||
$nixpacks_command = "nixpacks build -o {$workdir} --no-error-without-start";
|
|
||||||
if ($this->application->install_command) {
|
|
||||||
$nixpacks_command .= " --install-cmd '{$this->application->install_command}'";
|
|
||||||
}
|
|
||||||
if ($this->application->build_command) {
|
|
||||||
$nixpacks_command .= " --build-cmd '{$this->application->build_command}'";
|
|
||||||
}
|
|
||||||
if ($this->application->start_command) {
|
|
||||||
$nixpacks_command .= " --start-cmd '{$this->application->start_command}'";
|
|
||||||
}
|
|
||||||
$nixpacks_command .= " {$workdir}";
|
|
||||||
$command_other_command[] = $this->execute_in_builder($nixpacks_command);
|
|
||||||
$command_other_command[] = $this->execute_in_builder("cp {$workdir}/.nixpacks/Dockerfile {$workdir}/Dockerfile");
|
|
||||||
$command_other_command[] = $this->execute_in_builder("rm -f {$workdir}/.nixpacks/Dockerfile");
|
|
||||||
}
|
|
||||||
$command_other_command[] = "echo 'Done.'";
|
|
||||||
$command_other_command[] = "echo -n 'Building image... '";
|
|
||||||
|
|
||||||
$command_other_command[] = $this->execute_in_builder("docker build -f {$workdir}/Dockerfile --build-arg SOURCE_COMMIT={$this->git_commit} --progress plain -t {$this->application->uuid}:{$this->git_commit} {$workdir}");
|
$this->executeNow([
|
||||||
$command_other_command[] = "echo 'Done.'";
|
"echo -n 'Generating nixpacks configuration... '",
|
||||||
$command_other_command[] = $this->execute_in_builder("docker rm -f {$this->application->uuid} >/dev/null 2>&1");
|
$this->getNixpacks(),
|
||||||
|
"echo 'Done.'",
|
||||||
$command_other_command[] = "echo -n 'Deploying... '";
|
"echo -n 'Building image... '",
|
||||||
|
$this->execute_in_builder("docker build -f {$this->workdir}/Dockerfile --build-arg SOURCE_COMMIT={$this->git_commit} --progress plain -t {$this->application->uuid}:{$this->git_commit} {$this->workdir}"),
|
||||||
$command_other_command[] = $this->execute_in_builder("docker compose --project-directory {$workdir} up -d");
|
"echo 'Done.'",
|
||||||
$command_other_command[] = "echo 'Done. 🎉'";
|
$this->execute_in_builder("docker rm -f {$this->application->uuid} >/dev/null 2>&1"),
|
||||||
$command_other_command[] = "docker stop -t 0 {$this->deployment_uuid} >/dev/null";
|
"echo -n 'Deploying... '",
|
||||||
$this->executeNow($command_other_command, 'other_command');
|
$this->execute_in_builder("docker compose --project-directory {$this->workdir} up -d"),
|
||||||
|
"echo 'Done. 🎉'",
|
||||||
|
"docker stop -t 0 {$this->deployment_uuid} >/dev/null"
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function execute_in_builder(string $command)
|
private function execute_in_builder(string $command)
|
||||||
@@ -264,9 +242,10 @@ class DeployApplicationJob implements ShouldQueue
|
|||||||
return $labels;
|
return $labels;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function executeNow(array $command, string $propertyName, bool $hideFromOutput = false)
|
private function executeNow(array $command, string $propertyName = null, bool $hideFromOutput = false)
|
||||||
{
|
{
|
||||||
$commandText = collect($command)->implode("\n");
|
$commandText = collect($command)->implode("\n");
|
||||||
|
dd($commandText);
|
||||||
|
|
||||||
$this->activity->properties = $this->activity->properties->merge([
|
$this->activity->properties = $this->activity->properties->merge([
|
||||||
'command' => $commandText,
|
'command' => $commandText,
|
||||||
@@ -278,11 +257,51 @@ class DeployApplicationJob implements ShouldQueue
|
|||||||
'hideFromOutput' => $hideFromOutput,
|
'hideFromOutput' => $hideFromOutput,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
if ($propertyName) {
|
||||||
$result = $remoteProcess();
|
$result = $remoteProcess();
|
||||||
|
|
||||||
$this->activity->properties = $this->activity->properties->merge([
|
$this->activity->properties = $this->activity->properties->merge([
|
||||||
$propertyName => trim($result->output()),
|
$propertyName => trim($result->output()),
|
||||||
]);
|
]);
|
||||||
$this->activity->save();
|
$this->activity->save();
|
||||||
|
} else {
|
||||||
|
$remoteProcess();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private function gitImport()
|
||||||
|
{
|
||||||
|
$source_html_url = data_get($this->application, 'source.html_url');
|
||||||
|
$url = parse_url(filter_var($source_html_url, FILTER_SANITIZE_URL));
|
||||||
|
$source_html_url_host = $url['host'];
|
||||||
|
$source_html_url_scheme = $url['scheme'];
|
||||||
|
if ($this->application->source->getMorphClass() == 'App\Models\GithubApp') {
|
||||||
|
if ($this->source->is_public) {
|
||||||
|
return $this->execute_in_builder("git clone -q -b {$this->application->git_branch} {$this->source->html_url}/{$this->application->git_repository}.git {$this->workdir}");
|
||||||
|
} else {
|
||||||
|
$github_access_token = $this->generate_jwt_token_for_github();
|
||||||
|
return $this->execute_in_builder("git clone -q -b {$this->application->git_branch} $source_html_url_scheme://x-access-token:$github_access_token@$source_html_url_host/{$this->application->git_repository}.git {$this->workdir}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private function getNixpacks()
|
||||||
|
{
|
||||||
|
if (str_starts_with($this->application->base_image, 'apache') || str_starts_with($this->application->base_image, 'nginx')) {
|
||||||
|
// @TODO: Add static site builds
|
||||||
|
} else {
|
||||||
|
$nixpacks_command = "nixpacks build -o {$this->workdir} --no-error-without-start";
|
||||||
|
if ($this->application->install_command) {
|
||||||
|
$nixpacks_command .= " --install-cmd '{$this->application->install_command}'";
|
||||||
|
}
|
||||||
|
if ($this->application->build_command) {
|
||||||
|
$nixpacks_command .= " --build-cmd '{$this->application->build_command}'";
|
||||||
|
}
|
||||||
|
if ($this->application->start_command) {
|
||||||
|
$nixpacks_command .= " --start-cmd '{$this->application->start_command}'";
|
||||||
|
}
|
||||||
|
$nixpacks_command .= " {$this->workdir}";
|
||||||
|
$command_other_command[] = $this->execute_in_builder($nixpacks_command);
|
||||||
|
$command_other_command[] = $this->execute_in_builder("cp {$this->workdir}/.nixpacks/Dockerfile {$this->workdir}/Dockerfile");
|
||||||
|
$command_other_command[] = $this->execute_in_builder("rm -f {$this->workdir}/.nixpacks/Dockerfile");
|
||||||
|
}
|
||||||
|
return $command_other_command;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user