diff --git a/app/Jobs/ApplicationDeploymentJob.php b/app/Jobs/ApplicationDeploymentJob.php index 04011d9b1..b9c5b3953 100644 --- a/app/Jobs/ApplicationDeploymentJob.php +++ b/app/Jobs/ApplicationDeploymentJob.php @@ -280,6 +280,7 @@ class ApplicationDeploymentJob implements ShouldBeEncrypted, ShouldQueue $this->original_server = $this->server; } else { $this->build_server = $buildServers->random(); + $this->application_deployment_queue->build_server_id = $this->build_server->id; $this->application_deployment_queue->addLogEntry("Found a suitable build server ({$this->build_server->name})."); $this->original_server = $this->server; $this->use_build_server = true; diff --git a/app/Livewire/Project/Application/DeploymentNavbar.php b/app/Livewire/Project/Application/DeploymentNavbar.php index b3e39d23d..5fccce792 100644 --- a/app/Livewire/Project/Application/DeploymentNavbar.php +++ b/app/Livewire/Project/Application/DeploymentNavbar.php @@ -55,9 +55,14 @@ class DeploymentNavbar extends Component public function cancel() { $kill_command = "docker rm -f {$this->application_deployment_queue->deployment_uuid}"; + $build_server_id = $this->application_deployment_queue->build_server_id; $server_id = $this->application_deployment_queue->server_id ?? $this->application->destination->server_id; try { - $server = Server::find($server_id); + if ($this->application->settings->is_build_server_enabled) { + $server = Server::find($build_server_id); + } else { + $server = Server::find($server_id); + } if ($this->application_deployment_queue->logs) { $previous_logs = json_decode($this->application_deployment_queue->logs, associative: true, flags: JSON_THROW_ON_ERROR); diff --git a/database/migrations/2024_08_15_115907_add_build_server_id_to_deployment_queue.php b/database/migrations/2024_08_15_115907_add_build_server_id_to_deployment_queue.php new file mode 100644 index 000000000..da5f065a6 --- /dev/null +++ b/database/migrations/2024_08_15_115907_add_build_server_id_to_deployment_queue.php @@ -0,0 +1,28 @@ +integer('build_server_id')->nullable()->after('server_id'); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::table('application_deployment_queues', function (Blueprint $table) { + $table->dropColumn('build_server_id'); + }); + } +};