mirror of
https://github.com/OpenRouterTeam/spawn.git
synced 2026-05-22 03:14:57 +00:00
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 <noreply@anthropic.com>
This commit is contained in:
parent
21343b836a
commit
4528c11ebf
2 changed files with 66 additions and 1 deletions
65
exoscale/continue.sh
Normal file
65
exoscale/continue.sh
Normal file
|
|
@ -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"
|
||||
|
|
@ -1066,6 +1066,6 @@
|
|||
"exoscale/opencode": "implemented",
|
||||
"exoscale/plandex": "implemented",
|
||||
"exoscale/kilocode": "implemented",
|
||||
"exoscale/continue": "missing"
|
||||
"exoscale/continue": "implemented"
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue