wip
This commit is contained in:
parent
4df66ebf00
commit
593f1acf10
@ -19,11 +19,19 @@ class DemoDeployApplication extends Component
|
|||||||
|
|
||||||
public Application $application;
|
public Application $application;
|
||||||
public $destination;
|
public $destination;
|
||||||
|
public string $deployment_id;
|
||||||
|
public string $workdir;
|
||||||
|
|
||||||
|
|
||||||
public CoolifyInstanceSettings $coolify_instance_settings;
|
public CoolifyInstanceSettings $coolify_instance_settings;
|
||||||
public $wildcard_domain;
|
public $wildcard_domain;
|
||||||
|
|
||||||
|
protected $command;
|
||||||
|
|
||||||
|
private function dockerPreCommand($command)
|
||||||
|
{
|
||||||
|
return $this->command[] = "docker exec {$this->deployment_id} sh -c '{$command}'";
|
||||||
|
}
|
||||||
public function deploy()
|
public function deploy()
|
||||||
{
|
{
|
||||||
$this->isKeepAliveOn = true;
|
$this->isKeepAliveOn = true;
|
||||||
@ -36,22 +44,24 @@ public function deploy()
|
|||||||
$this->wildcard_domain = $project_wildcard_domain ?? $global_wildcard_domain ?? null;
|
$this->wildcard_domain = $project_wildcard_domain ?? $global_wildcard_domain ?? null;
|
||||||
|
|
||||||
$source = $this->application->source->getMorphClass()::where('id', $this->application->source->id)->first();
|
$source = $this->application->source->getMorphClass()::where('id', $this->application->source->id)->first();
|
||||||
$deployment_id = new Cuid2(10);
|
$this->deployment_id = new Cuid2(10);
|
||||||
|
|
||||||
$workdir = $this->get_workdir('application', $this->application->uuid, $deployment_id);
|
$this->workdir = "/tmp/{$this->deployment_id}";
|
||||||
|
|
||||||
$command[] = "echo 'Starting deployment of {$this->application->name} ({$this->application->uuid})'";
|
$this->command[] = "echo 'Starting deployment of {$this->application->name} ({$this->application->uuid})'";
|
||||||
$command[] = 'mkdirs -p ' . $workdir;
|
$this->command[] = "docker run -d --name {$this->deployment_id} --rm -v /var/run/docker.sock:/var/run/docker.sock coolify-builder >/dev/null";
|
||||||
$command[] = "git clone -b {$this->application->git_branch} {$source->html_url}/{$this->application->git_repository}.git {$workdir}";
|
|
||||||
|
|
||||||
if (!file_exists($workdir) && $workdir != "/") {
|
$this->dockerPreCommand('hostname');
|
||||||
$command[] = "echo 'Removing {$workdir}'";
|
$this->dockerPreCommand("mkdir -p {$this->workdir}");
|
||||||
$command[] = "rm -rf {$workdir}";
|
$this->dockerPreCommand("ls -ld {$this->workdir}");
|
||||||
}
|
$this->dockerPreCommand("git clone -b {$this->application->git_branch} {$source->html_url}/{$this->application->git_repository}.git {$this->workdir}");
|
||||||
$this->activity = remoteProcess(implode("\n", $command), $this->destination->server->name);
|
$this->dockerPreCommand("ls -l {$this->workdir}");
|
||||||
|
$this->command[] = "docker stop -t 0 {$this->deployment_id} >/dev/null";
|
||||||
|
|
||||||
|
$this->activity = remoteProcess(implode("\n", $this->command), $this->destination->server->name);
|
||||||
|
|
||||||
Deployment::create([
|
Deployment::create([
|
||||||
'uuid' => $deployment_id,
|
'uuid' => $this->deployment_id,
|
||||||
'type_id' => $this->application->id,
|
'type_id' => $this->application->id,
|
||||||
'type_type' => Application::class,
|
'type_type' => Application::class,
|
||||||
'activity_log_id' => $this->activity->id,
|
'activity_log_id' => $this->activity->id,
|
||||||
|
@ -22,7 +22,6 @@ function remoteProcess(
|
|||||||
$temp_file = 'id.rsa_' . 'root' . '@' . $found_server->ip;
|
$temp_file = 'id.rsa_' . 'root' . '@' . $found_server->ip;
|
||||||
Storage::disk('local')->put($temp_file, $found_server->privateKey->private_key, 'private');
|
Storage::disk('local')->put($temp_file, $found_server->privateKey->private_key, 'private');
|
||||||
$private_key_location = '/var/www/html/storage/app/' . $temp_file;
|
$private_key_location = '/var/www/html/storage/app/' . $temp_file;
|
||||||
|
|
||||||
return resolve(DispatchRemoteProcess::class, [
|
return resolve(DispatchRemoteProcess::class, [
|
||||||
'remoteProcessArgs' => new RemoteProcessArgs(
|
'remoteProcessArgs' => new RemoteProcessArgs(
|
||||||
destination: $found_server->ip,
|
destination: $found_server->ip,
|
||||||
|
@ -37,7 +37,7 @@ public function run(): void
|
|||||||
'id' => 3,
|
'id' => 3,
|
||||||
'name' => "localhost",
|
'name' => "localhost",
|
||||||
'description' => "This is the local machine",
|
'description' => "This is the local machine",
|
||||||
'user' => 'ab',
|
'user' => 'andrasbacsai',
|
||||||
'ip' => "172.17.0.1",
|
'ip' => "172.17.0.1",
|
||||||
'team_id' => $root_team->id,
|
'team_id' => $root_team->id,
|
||||||
'private_key_id' => $private_key_1->id,
|
'private_key_id' => $private_key_1->id,
|
||||||
|
25
docker/builder/Dockerfile
Normal file
25
docker/builder/Dockerfile
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
FROM alpine:3.17
|
||||||
|
|
||||||
|
ARG TARGETPLATFORM
|
||||||
|
# https://download.docker.com/linux/static/stable/
|
||||||
|
ARG DOCKER_VERSION=20.10.18
|
||||||
|
# https://github.com/docker/compose/releases
|
||||||
|
# Reverted to 2.6.1 because of this https://github.com/docker/compose/issues/9704. 2.9.0 still has a bug.
|
||||||
|
ARG DOCKER_COMPOSE_VERSION=2.6.1
|
||||||
|
# https://github.com/buildpacks/pack/releases
|
||||||
|
ARG PACK_VERSION=0.27.0
|
||||||
|
# https://github.com/railwayapp/nixpacks/releases
|
||||||
|
ARG NIXPACKS_VERSION=1.6.0
|
||||||
|
|
||||||
|
USER root
|
||||||
|
RUN apk add --no-cache bash curl git git-lfs openssh-client tar tini
|
||||||
|
RUN mkdir -p ~/.docker/cli-plugins
|
||||||
|
RUN curl -SL https://cdn.coollabs.io/bin/$TARGETPLATFORM/docker-$DOCKER_VERSION -o /usr/bin/docker
|
||||||
|
RUN curl -SL https://cdn.coollabs.io/bin/$TARGETPLATFORM/docker-compose-linux-$DOCKER_COMPOSE_VERSION -o ~/.docker/cli-plugins/docker-compose
|
||||||
|
RUN curl -SL https://cdn.coollabs.io/bin/$TARGETPLATFORM/pack-v$PACK_VERSION -o /usr/local/bin/pack
|
||||||
|
RUN curl -sSL https://nixpacks.com/install.sh | bash
|
||||||
|
RUN chmod +x ~/.docker/cli-plugins/docker-compose /usr/bin/docker /usr/local/bin/pack
|
||||||
|
|
||||||
|
ENTRYPOINT ["/sbin/tini", "--"]
|
||||||
|
CMD ["sh", "-c", "while true; do sleep 1000; done"]
|
||||||
|
|
@ -4,10 +4,6 @@
|
|||||||
Activity: <span>{{ $activity?->id ?? 'waiting' }}</span>
|
Activity: <span>{{ $activity?->id ?? 'waiting' }}</span>
|
||||||
</div>
|
</div>
|
||||||
<pre style="width: 100%;overflow-y: scroll;" @if ($isKeepAliveOn) wire:poll.750ms="polling" @endif>{{ data_get($activity, 'description') }}</pre>
|
<pre style="width: 100%;overflow-y: scroll;" @if ($isKeepAliveOn) wire:poll.750ms="polling" @endif>{{ data_get($activity, 'description') }}</pre>
|
||||||
{{-- <div>
|
|
||||||
<div>Details:</div>
|
|
||||||
<pre style="width: 100%;overflow-y: scroll;">{{ json_encode(data_get($activity, 'properties'), JSON_PRETTY_PRINT) }}</pre>
|
|
||||||
</div> --}}
|
|
||||||
@endisset
|
@endisset
|
||||||
<button wire:click='deploy'>Deploy</button>
|
<button wire:click='deploy'>Deploy</button>
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
Reference in New Issue
Block a user