spawn/upcloud
A 5ebe3e5a13
fix: add actionable guidance to destroy_server failures and service timeouts (#959)
When server destruction fails, users are left with a bare error message and
no indication that they may still be billed for a running server. This adds
dashboard URLs and clear warnings to destroy_server errors across 9 clouds
(Hetzner, UpCloud, Contabo, Netcup, RamNode, Hostinger, HOSTKEY, OVH,
Latitude). Also improves error messages for Koyeb (app creation, service
deployment, deployment timeout, instance ID), GitHub Codespaces (creation
failure, readiness timeout), and E2B (sandbox creation failure).

Agent: ux-engineer

Co-authored-by: A <6723574+louisgv@users.noreply.github.com>
Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-02-13 09:38:58 -08:00
..
lib fix: add actionable guidance to destroy_server failures and service timeouts (#959) 2026-02-13 09:38:58 -08:00
aider.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
amazonq.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
claude.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
cline.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
codex.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
continue.sh fix: replace unsafe inline API key injection with secure helpers (#676) 2026-02-12 15:03:12 -08:00
gemini.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
goose.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
gptme.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
interpreter.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
kilocode.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
nanoclaw.sh fix: replace log_warn with log_step/log_info for non-warning messages (#604) 2026-02-12 03:24:30 -08:00
openclaw.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
opencode.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
plandex.sh fix: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -08:00
README.md refactor: replace Python with jq in Hetzner lib, fix /lab → /labs URLs (#827) 2026-02-12 23:14:11 -08:00

UpCloud

UpCloud cloud servers via REST API. UpCloud

Agents

Claude Code

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/claude.sh)

OpenClaw

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/openclaw.sh)

NanoClaw

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/nanoclaw.sh)

Aider

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/aider.sh)

Goose

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/goose.sh)

Codex CLI

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/codex.sh)

Open Interpreter

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/interpreter.sh)

Gemini CLI

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/gemini.sh)

Amazon Q CLI

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/amazonq.sh)

Cline

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/cline.sh)

gptme

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/gptme.sh)

OpenCode

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/opencode.sh)

Plandex

bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/plandex.sh)

Non-Interactive Mode

UPCLOUD_SERVER_NAME=dev-mk1 \
UPCLOUD_USERNAME=your-api-username \
UPCLOUD_PASSWORD=your-api-password \
OPENROUTER_API_KEY=sk-or-v1-xxxxx \
  bash <(curl -fsSL https://openrouter.ai/labs/spawn/upcloud/claude.sh)

Environment Variables

Variable Description Default
UPCLOUD_USERNAME UpCloud API username (prompted)
UPCLOUD_PASSWORD UpCloud API password (prompted)
UPCLOUD_SERVER_NAME Server name (prompted)
UPCLOUD_ZONE Datacenter zone de-fra1
UPCLOUD_PLAN Server plan 1xCPU-2GB
OPENROUTER_API_KEY OpenRouter API key (OAuth or prompted)