find($serverId); // Delete from Hetzner even if server is already gone from Coolify if ($deleteFromHetzner && ($hetznerServerId || ($server && $server->hetzner_server_id))) { $this->deleteFromHetznerById( $hetznerServerId ?? $server->hetzner_server_id, $cloudProviderTokenId ?? $server->cloud_provider_token_id, $teamId ?? $server->team_id ); } ray($server ? 'Deleting server from Coolify' : 'Server already deleted from Coolify, skipping Coolify deletion'); // If server is already deleted from Coolify, skip this part if (! $server) { return; // Server already force deleted from Coolify } ray('force deleting server from Coolify', ['server_id' => $server->id]); try { $server->forceDelete(); } catch (\Throwable $e) { ray('Failed to force delete server from Coolify', [ 'error' => $e->getMessage(), 'server_id' => $server->id, ]); logger()->error('Failed to force delete server from Coolify', [ 'error' => $e->getMessage(), 'server_id' => $server->id, ]); } } private function deleteFromHetznerById(int $hetznerServerId, ?int $cloudProviderTokenId, int $teamId): void { try { // Use the provided token, or fallback to first available team token $token = null; if ($cloudProviderTokenId) { $token = CloudProviderToken::find($cloudProviderTokenId); } if (! $token) { $token = CloudProviderToken::where('team_id', $teamId) ->where('provider', 'hetzner') ->first(); } if (! $token) { ray('No Hetzner token found for team, skipping Hetzner deletion', [ 'team_id' => $teamId, 'hetzner_server_id' => $hetznerServerId, ]); return; } $hetznerService = new HetznerService($token->token); $hetznerService->deleteServer($hetznerServerId); ray('Deleted server from Hetzner', [ 'hetzner_server_id' => $hetznerServerId, 'team_id' => $teamId, ]); } catch (\Throwable $e) { ray('Failed to delete server from Hetzner', [ 'error' => $e->getMessage(), 'hetzner_server_id' => $hetznerServerId, 'team_id' => $teamId, ]); // Log the error but don't prevent the server from being deleted from Coolify logger()->error('Failed to delete server from Hetzner', [ 'error' => $e->getMessage(), 'hetzner_server_id' => $hetznerServerId, 'team_id' => $teamId, ]); // Notify the team about the failure $team = Team::find($teamId); $team?->notify(new HetznerDeletionFailed($hetznerServerId, $teamId, $e->getMessage())); } } }