mirror of
https://github.com/OpenRouterTeam/spawn.git
synced 2026-05-09 19:49:58 +00:00
Improve error messages in shared utilities and cloud providers that previously showed bare "Failed to..." messages without telling users how to fix the problem. Shared (shared/common.sh): - generate_ssh_key_if_missing: handle ssh-keygen/mkdir failures with disk space and permission guidance - get_ssh_fingerprint: detect missing/corrupt public key files with regeneration instructions - generic_ssh_wait: structured "How to fix" with manual SSH test command and firewall check - _report_api_failure: add DNS/firewall/proxy guidance for network errors - ensure_jq: platform-specific install commands for unknown package managers, hash rehash hint after install - get_openrouter_api_key_manual: structured guidance after 3 failed attempts Cloud providers: - Contabo: actionable guidance for OAuth token failures - Exoscale: guidance for credential validation and CLI download failures - Netcup: network connectivity hint for API connection failure - Scaleway: structured guidance for project ID lookup failure Agent: ux-engineer Co-authored-by: A <6723574+louisgv@users.noreply.github.com> Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com> |
||
|---|---|---|
| .. | ||
| lib | ||
| aider.sh | ||
| amazonq.sh | ||
| claude.sh | ||
| cline.sh | ||
| codex.sh | ||
| continue.sh | ||
| gemini.sh | ||
| goose.sh | ||
| gptme.sh | ||
| interpreter.sh | ||
| kilocode.sh | ||
| nanoclaw.sh | ||
| openclaw.sh | ||
| opencode.sh | ||
| plandex.sh | ||
| README.md | ||
Exoscale
Exoscale European cloud compute via CLI with per-second billing. Exoscale
Agents
Claude Code
bash <(curl -fsSL https://openrouter.ai/labs/spawn/exoscale/claude.sh)
Aider
bash <(curl -fsSL https://openrouter.ai/labs/spawn/exoscale/aider.sh)
Goose
bash <(curl -fsSL https://openrouter.ai/labs/spawn/exoscale/goose.sh)
Non-Interactive Mode
EXOSCALE_SERVER_NAME=dev-mk1 \
EXOSCALE_API_KEY=your-key \
EXOSCALE_API_SECRET=your-secret \
OPENROUTER_API_KEY=sk-or-v1-xxxxx \
bash <(curl -fsSL https://openrouter.ai/labs/spawn/exoscale/claude.sh)
Environment Variables
EXOSCALE_SERVER_NAME- Name for the instance (optional, will prompt if not provided)EXOSCALE_API_KEY- Exoscale API key (required)EXOSCALE_API_SECRET- Exoscale API secret (required)EXOSCALE_INSTANCE_TYPE- Instance type (default:standard.small)EXOSCALE_ZONE- Zone (default:ch-gva-2)EXOSCALE_TEMPLATE- OS template (default:Linux Ubuntu 24.04 LTS 64-bit)OPENROUTER_API_KEY- OpenRouter API key (optional, will use OAuth if not provided)
Getting Started
- Create API credentials at https://portal.exoscale.com/iam/api-keys
- Run one of the agent scripts above
- The script will auto-install the exo CLI if needed
- Configure your API credentials when prompted
- The instance will be provisioned and the agent will start
Available Zones
ch-gva-2- Geneva, Switzerland (default)ch-dk-2- Zurich, Switzerlandde-fra-1- Frankfurt, Germanyde-muc-1- Munich, Germanyat-vie-1- Vienna, Austriaat-vie-2- Vienna, Austriabg-sof-1- Sofia, Bulgaria
Pricing
Exoscale uses per-second billing with no upfront costs or long-term commitments. Resources are billed by the second at a flat rate across all zones.