From 4528c11ebf5565c5437c0b3494d30fcfb4b268c2 Mon Sep 17 00:00:00 2001 From: A <258483684+la14-1@users.noreply.github.com> Date: Tue, 10 Feb 2026 20:36:11 -0800 Subject: [PATCH] feat(exoscale): Add continue support (#349) Implements exoscale/continue matrix entry using Exoscale cloud primitives and Continue installation pattern from existing implementations. Agent: gap-filler-exoscale-4 Co-authored-by: B <6723574+louisgv@users.noreply.github.com> Co-authored-by: Claude Sonnet 4.5 --- exoscale/continue.sh | 65 ++++++++++++++++++++++++++++++++++++++++++++ manifest.json | 2 +- 2 files changed, 66 insertions(+), 1 deletion(-) create mode 100644 exoscale/continue.sh diff --git a/exoscale/continue.sh b/exoscale/continue.sh new file mode 100644 index 00000000..9cae88d5 --- /dev/null +++ b/exoscale/continue.sh @@ -0,0 +1,65 @@ +#!/bin/bash +# shellcheck disable=SC2154 +set -eo pipefail + +SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" 2>/dev/null && pwd)" +# shellcheck source=exoscale/lib/common.sh + +if [[ -f "${SCRIPT_DIR}/lib/common.sh" ]]; then + source "${SCRIPT_DIR}/lib/common.sh" +else + eval "$(curl -fsSL https://raw.githubusercontent.com/OpenRouterTeam/spawn/main/exoscale/lib/common.sh)" +fi + +log_info "Continue on Exoscale" +echo "" + +ensure_exoscale_creds +ensure_ssh_key + +SERVER_NAME=$(get_server_name) +create_server "${SERVER_NAME}" +verify_server_connectivity "${EXOSCALE_SERVER_IP}" +wait_for_cloud_init "${EXOSCALE_SERVER_IP}" 60 + +log_warn "Installing Continue CLI..." +run_server "${EXOSCALE_SERVER_IP}" "npm install -g @continuedev/cli" +log_info "Continue installed" + +echo "" +if [[ -n "${OPENROUTER_API_KEY:-}" ]]; then + log_info "Using OpenRouter API key from environment" +else + OPENROUTER_API_KEY=$(get_openrouter_api_key_oauth 5180) +fi + +log_warn "Setting up environment variables..." + +inject_env_vars_ssh "${EXOSCALE_SERVER_IP}" upload_file run_server \ + "OPENROUTER_API_KEY=${OPENROUTER_API_KEY}" + +log_warn "Creating Continue config file..." +run_server "${EXOSCALE_SERVER_IP}" "mkdir -p ~/.continue" +run_server "${EXOSCALE_SERVER_IP}" "cat > ~/.continue/config.json << 'EOF' +{ + \"models\": [ + { + \"title\": \"OpenRouter\", + \"provider\": \"openrouter\", + \"model\": \"openrouter/auto\", + \"apiBase\": \"https://openrouter.ai/api/v1\", + \"apiKey\": \"${OPENROUTER_API_KEY}\" + } + ] +} +EOF" + +echo "" +log_info "Exoscale server setup completed successfully!" +log_info "Server: ${SERVER_NAME} (ID: ${EXOSCALE_SERVER_ID}, IP: ${EXOSCALE_SERVER_IP})" +echo "" + +log_warn "Starting Continue CLI in TUI mode..." +sleep 1 +clear +interactive_session "${EXOSCALE_SERVER_IP}" "source ~/.zshrc && cn" diff --git a/manifest.json b/manifest.json index ea961370..b9a512f3 100644 --- a/manifest.json +++ b/manifest.json @@ -1066,6 +1066,6 @@ "exoscale/opencode": "implemented", "exoscale/plandex": "implemented", "exoscale/kilocode": "implemented", - "exoscale/continue": "missing" + "exoscale/continue": "implemented" } }