This commit is contained in:
Andras Bacsai 2023-04-19 14:28:39 +02:00
parent 2e8b1134b9
commit ab588d37c0
4 changed files with 53 additions and 22 deletions

View File

@ -27,19 +27,39 @@ class DeployApplication extends Component
$this->application = Application::find($this->applicationId)->first(); $this->application = Application::find($this->applicationId)->first();
$this->destination = $this->application->destination->getMorphClass()::where('id', $this->application->destination->id)->first(); $this->destination = $this->application->destination->getMorphClass()::where('id', $this->application->destination->id)->first();
} }
protected function setDeploymentUuid()
public function start()
{ {
// Create Deployment ID // Create Deployment ID
$this->deployment_uuid = new Cuid2(7); $this->deployment_uuid = new Cuid2(7);
$this->parameters['deployment_uuid'] = $this->deployment_uuid; $this->parameters['deployment_uuid'] = $this->deployment_uuid;
}
protected function redirectToDeployment()
{
return redirect()->route('project.applications.deployment', $this->parameters);
}
public function start()
{
$this->setDeploymentUuid();
dispatch(new DeployApplicationJob( dispatch(new DeployApplicationJob(
deployment_uuid: $this->deployment_uuid, deployment_uuid: $this->deployment_uuid,
application_uuid: $this->application->uuid, application_uuid: $this->application->uuid,
force_rebuild: false,
)); ));
return redirect()->route('project.applications.deployment', $this->parameters); return $this->redirectToDeployment();
}
public function forceRebuild()
{
$this->setDeploymentUuid();
dispatch(new DeployApplicationJob(
deployment_uuid: $this->deployment_uuid,
application_uuid: $this->application->uuid,
force_rebuild: true,
));
return $this->redirectToDeployment();
} }
public function stop() public function stop()

View File

@ -43,6 +43,7 @@ class DeployApplicationJob implements ShouldQueue
public function __construct( public function __construct(
public string $deployment_uuid, public string $deployment_uuid,
public string $application_uuid, public string $application_uuid,
public bool $force_rebuild = false,
) { ) {
$this->application = Application::query() $this->application = Application::query()
->where('uuid', $this->application_uuid) ->where('uuid', $this->application_uuid)
@ -86,7 +87,7 @@ class DeployApplicationJob implements ShouldQueue
// Set wildcard domain // Set wildcard domain
if (!$this->application->settings->is_bot && !$this->application->fqdn && $wildcard_domain) { if (!$this->application->settings->is_bot && !$this->application->fqdn && $wildcard_domain) {
$this->application->fqdn = $this->application->uuid . '.' . $wildcard_domain; $this->application->fqdn = 'http://' . $this->application->uuid . '.' . $wildcard_domain;
$this->application->save(); $this->application->save();
} }
$this->workdir = "/artifacts/{$this->deployment_uuid}"; $this->workdir = "/artifacts/{$this->deployment_uuid}";
@ -116,6 +117,9 @@ class DeployApplicationJob implements ShouldQueue
$this->executeNow([$this->execute_in_builder("cd {$this->workdir} && git rev-parse HEAD")], 'commit_sha', hideFromOutput: true); $this->executeNow([$this->execute_in_builder("cd {$this->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');
if (!$this->force_rebuild) {
$this->executeNow([ $this->executeNow([
"docker inspect {$this->application->uuid} --format '{{json .Config.Image}}' 2>&1", "docker inspect {$this->application->uuid} --format '{{json .Config.Image}}' 2>&1",
], 'stopped_container_image', hideFromOutput: true, ignoreErrors: true); ], 'stopped_container_image', hideFromOutput: true, ignoreErrors: true);
@ -136,6 +140,7 @@ class DeployApplicationJob implements ShouldQueue
return; return;
} }
} }
}
$this->executeNow([ $this->executeNow([
$this->execute_in_builder("rm -fr {$this->workdir}/.git") $this->execute_in_builder("rm -fr {$this->workdir}/.git")
], hideFromOutput: true); ], hideFromOutput: true);

View File

@ -1,13 +1,19 @@
<div> <div>
@if ($application->status === 'running') @if ($application->status === 'running')
<button wire:click='start'>Restart</button>
<button wire:click='forceRebuild'>Force Rebuild</button>
<button wire:click='stop'>Stop</button> <button wire:click='stop'>Stop</button>
@else @else
<button wire:click='start'>Start</button> <button wire:click='start'>Start</button>
<button wire:click='forceRebuild'>Start (no cache)</button>
@endif @endif
<button wire:click='kill'>Kill</button> <button wire:click='kill'>Kill</button>
<span wire:poll='pollingStatus'> <span wire:poll='pollingStatus'>
@if ($application->status === 'running') @if ($application->status === 'running')
<span class="text-green-500">{{ $application->status }}</span> <span class="text-green-500">{{ $application->status }}</span>
@if (!data_get($application, 'settings.is_bot') && data_get($application, 'fqdn'))
<a target="_blank" href="{{ data_get($application, 'fqdn') }}">Open</a>
@endif
@else @else
<span class="text-red-500">{{ $application->status }}</span> <span class="text-red-500">{{ $application->status }}</span>
@endif @endif