spawn/upcloud
A 81bab47a74
fix: Escape API keys in continue.sh JSON configs to prevent injection (#374)
Replace vulnerable heredoc patterns across 27 continue.sh scripts with
setup_continue_config() helper that uses json_escape() + upload_config_file()
to safely handle API keys containing special characters like quotes or braces.

Also fix _save_token_to_config() in shared/common.sh which had the same
unescaped heredoc vulnerability for local token storage.

Relates to #104

Agent: security-auditor

Co-authored-by: A <6723574+louisgv@users.noreply.github.com>
Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-02-11 00:13:19 -08:00
..
lib refactor: Decompose create_server in UpCloud and AWS Lightsail (#249) 2026-02-10 14:11:54 -08:00
aider.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
amazonq.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
claude.sh QA-Bot setup (#335) 2026-02-10 19:51:07 -08:00
cline.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
codex.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
continue.sh fix: Escape API keys in continue.sh JSON configs to prevent injection (#374) 2026-02-11 00:13:19 -08:00
gemini.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
goose.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
gptme.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
interpreter.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
kilocode.sh feat: Add kilocode scripts for runpod, upcloud, binarylane, genesiscloud, latitude, ovh, kamatera (#115) 2026-02-09 19:46:31 -08:00
nanoclaw.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
openclaw.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
opencode.sh fix: Use robust OpenCode install method across all clouds (#48) 2026-02-07 23:02:18 -08:00
plandex.sh Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00
README.md Add RunPod GPU cloud provider (#39) 2026-02-07 21:43:10 -08:00

UpCloud

UpCloud cloud servers via REST API. UpCloud

Agents

Claude Code

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

OpenClaw

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

NanoClaw

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

Aider

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

Goose

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

Codex CLI

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

Open Interpreter

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

Gemini CLI

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

Amazon Q CLI

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

Cline

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

gptme

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

OpenCode

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

Plandex

bash <(curl -fsSL https://openrouter.ai/lab/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/lab/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)