updates
This commit is contained in:
@@ -3,6 +3,7 @@
|
|||||||
namespace App\Actions\RemoteProcess;
|
namespace App\Actions\RemoteProcess;
|
||||||
|
|
||||||
use App\Data\RemoteProcessArgs;
|
use App\Data\RemoteProcessArgs;
|
||||||
|
use App\Jobs\DeployRemoteProcess;
|
||||||
use App\Jobs\ExecuteRemoteProcess;
|
use App\Jobs\ExecuteRemoteProcess;
|
||||||
use Spatie\Activitylog\Models\Activity;
|
use Spatie\Activitylog\Models\Activity;
|
||||||
|
|
||||||
@@ -30,11 +31,8 @@ class DispatchRemoteProcess
|
|||||||
public function __invoke(): Activity
|
public function __invoke(): Activity
|
||||||
{
|
{
|
||||||
$job = new ExecuteRemoteProcess($this->activity);
|
$job = new ExecuteRemoteProcess($this->activity);
|
||||||
|
|
||||||
dispatch($job);
|
dispatch($job);
|
||||||
|
|
||||||
$this->activity->refresh();
|
$this->activity->refresh();
|
||||||
|
|
||||||
return $this->activity;
|
return $this->activity;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,8 +4,8 @@ namespace App\Http\Livewire;
|
|||||||
|
|
||||||
use App\Models\Application;
|
use App\Models\Application;
|
||||||
use App\Models\CoolifyInstanceSettings;
|
use App\Models\CoolifyInstanceSettings;
|
||||||
use App\Models\Deployment;
|
|
||||||
use Livewire\Component;
|
use Livewire\Component;
|
||||||
|
use Symfony\Component\Yaml\Yaml;
|
||||||
use Visus\Cuid2\Cuid2;
|
use Visus\Cuid2\Cuid2;
|
||||||
|
|
||||||
class DeployApplication extends Component
|
class DeployApplication extends Component
|
||||||
@@ -17,12 +17,25 @@ class DeployApplication extends Component
|
|||||||
|
|
||||||
private function execute_in_builder(string $command)
|
private function execute_in_builder(string $command)
|
||||||
{
|
{
|
||||||
return $this->command[] = "docker exec {$this->deployment_uuid} sh -c '{$command}'";
|
return $this->command[] = "docker exec {$this->deployment_uuid} bash -c '{$command}'";
|
||||||
}
|
}
|
||||||
private function start_builder_container()
|
private function start_builder_container()
|
||||||
{
|
{
|
||||||
$this->command[] = "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";
|
$this->command[] = "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";
|
||||||
}
|
}
|
||||||
|
private function generate_docker_compose(mixed $application)
|
||||||
|
{
|
||||||
|
return Yaml::dump([
|
||||||
|
'version' => '3.8',
|
||||||
|
'services' => [
|
||||||
|
$application->uuid => [
|
||||||
|
'image' => "{$application->uuid}:TAG",
|
||||||
|
'container_name' => $application->uuid,
|
||||||
|
'restart' => 'always',
|
||||||
|
]
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
}
|
||||||
public function deploy()
|
public function deploy()
|
||||||
{
|
{
|
||||||
$coolify_instance_settings = CoolifyInstanceSettings::find(1);
|
$coolify_instance_settings = CoolifyInstanceSettings::find(1);
|
||||||
@@ -37,14 +50,48 @@ class DeployApplication extends Component
|
|||||||
|
|
||||||
// Create Deployment ID
|
// Create Deployment ID
|
||||||
$this->deployment_uuid = new Cuid2(7);
|
$this->deployment_uuid = new Cuid2(7);
|
||||||
|
|
||||||
|
// Set wildcard domain
|
||||||
|
if (!$application->settings->is_bot && !$application->fqdn && $wildcard_domain) {
|
||||||
|
$application->fqdn = $application->uuid . '.' . $wildcard_domain;
|
||||||
|
$application->save();
|
||||||
|
}
|
||||||
$workdir = "/artifacts/{$this->deployment_uuid}";
|
$workdir = "/artifacts/{$this->deployment_uuid}";
|
||||||
|
|
||||||
// Start build process
|
// Start build process
|
||||||
|
$docker_compose = $this->generate_docker_compose($application);
|
||||||
$this->command[] = "echo 'Starting deployment of {$application->name} ({$application->uuid})'";
|
$this->command[] = "echo 'Starting deployment of {$application->name} ({$application->uuid})'";
|
||||||
$this->start_builder_container();
|
$this->start_builder_container();
|
||||||
// $this->execute_in_builder('hostname');
|
|
||||||
$this->execute_in_builder("git clone -b {$application->git_branch} {$source->html_url}/{$application->git_repository}.git {$workdir}");
|
$this->execute_in_builder("git clone -b {$application->git_branch} {$source->html_url}/{$application->git_repository}.git {$workdir}");
|
||||||
$this->execute_in_builder("ls -l {$workdir}");
|
|
||||||
|
// Export git commit to a file
|
||||||
|
$this->execute_in_builder("cd {$workdir} && git rev-parse HEAD > {$workdir}/.git-commit");
|
||||||
|
|
||||||
|
// Set TAG in docker-compose.yml
|
||||||
|
$this->execute_in_builder("echo -e '{$docker_compose}' > {$workdir}/docker-compose.yml");
|
||||||
|
$this->execute_in_builder("sed -i \"s/TAG/$(cat {$workdir}/.git-commit)/g\" {$workdir}/docker-compose.yml");
|
||||||
|
$this->execute_in_builder("cat {$workdir}/docker-compose.yml");
|
||||||
|
|
||||||
|
if (str_starts_with($application->base_image, 'apache') || str_starts_with($application->base_image, 'nginx')) {
|
||||||
|
// @TODO: Add static site builds
|
||||||
|
} else {
|
||||||
|
$nixpacks_command = "nixpacks build -o {$workdir} --no-error-without-start";
|
||||||
|
if ($application->install_command) {
|
||||||
|
$nixpacks_command .= " --install-cmd '{$application->install_command}'";
|
||||||
|
}
|
||||||
|
if ($application->build_command) {
|
||||||
|
$nixpacks_command .= " --build-cmd '{$application->build_command}'";
|
||||||
|
}
|
||||||
|
if ($application->start_command) {
|
||||||
|
$nixpacks_command .= " --start-cmd '{$application->start_command}'";
|
||||||
|
}
|
||||||
|
$nixpacks_command .= " {$workdir}";
|
||||||
|
$this->execute_in_builder($nixpacks_command);
|
||||||
|
$this->execute_in_builder("cp {$workdir}/.nixpacks/Dockerfile {$workdir}/Dockerfile");
|
||||||
|
$this->execute_in_builder("rm -f {$workdir}/.nixpacks/Dockerfile");
|
||||||
|
}
|
||||||
|
$this->execute_in_builder("docker build -f {$workdir}/Dockerfile --build-arg SOURCE_COMMIT=$(cat {$workdir}/.git-commit) --progress plain -t {$application->uuid}:$(cat {$workdir}/.git-commit) {$workdir}");
|
||||||
|
$this->execute_in_builder("docker compose --project-directory {$workdir} up -d");
|
||||||
$this->command[] = "docker stop -t 0 {$this->deployment_uuid} >/dev/null";
|
$this->command[] = "docker stop -t 0 {$this->deployment_uuid} >/dev/null";
|
||||||
$this->activity = remoteProcess($this->command, $destination->server, $this->deployment_uuid, $application);
|
$this->activity = remoteProcess($this->command, $destination->server, $this->deployment_uuid, $application);
|
||||||
|
|
||||||
@@ -52,6 +99,18 @@ class DeployApplication extends Component
|
|||||||
$deploymentUrl = "$currentUrl/deployment/$this->deployment_uuid";
|
$deploymentUrl = "$currentUrl/deployment/$this->deployment_uuid";
|
||||||
return redirect($deploymentUrl);
|
return redirect($deploymentUrl);
|
||||||
}
|
}
|
||||||
|
public function cancel()
|
||||||
|
{
|
||||||
|
// dd($this->deployment_uuid);
|
||||||
|
// $jobs = DB::table('jobs')->get();
|
||||||
|
// foreach ($jobs as $job) {
|
||||||
|
// // Decode the job payload
|
||||||
|
// $jobPayload = json_decode($job->payload, true);
|
||||||
|
// if (str_contains($jobPayload['data']['command'], $this->deployment_uuid)) {
|
||||||
|
// dd($jobPayload['data']['command']);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
}
|
||||||
public function render()
|
public function render()
|
||||||
{
|
{
|
||||||
return view('livewire.deploy-application');
|
return view('livewire.deploy-application');
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
<div>
|
<div>
|
||||||
<button wire:click='deploy'>Deploy</button>
|
<button wire:click='deploy'>Deploy</button>
|
||||||
|
<button wire:click='cancel'>Cancel</button>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user