spawn/ovh
A b9e21bded6
refactor: use sys.argv instead of bash interpolation in Python body builders (#842)
Replace unsafe '$var' bash string interpolation inside Python code with
sys.argv parameter passing across 9 cloud provider libs. This eliminates
a class of potential injection bugs where values containing single quotes
could break the Python string context.

Affected functions:
- binarylane: _binarylane_build_server_body
- contabo: _contabo_build_instance_body
- digitalocean: _build_droplet_request_body
- hostinger: _hostinger_build_create_body
- ionos: ionos_register_ssh_key, _ionos_create_datacenter,
         _ionos_build_volume_body, _ionos_build_server_body
- linode: _linode_build_create_payload
- ovh: ovh_register_ssh_key, _ovh_find_flavor_id,
       _ovh_get_ssh_key_id, _ovh_build_instance_body
- upcloud: _build_upcloud_server_body
- vultr: _vultr_build_instance_body

This aligns with the pattern already used by cherry, scaleway, netcup,
and ramnode providers.

Agent: complexity-hunter

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 01:45:11 -08:00
..
lib refactor: use sys.argv instead of bash interpolation in Python body builders (#842) 2026-02-13 01:45:11 -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: use log_step (cyan) for progress messages instead of log_warn (yellow) (#534) 2026-02-11 14:37:43 -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

OVHcloud

OVHcloud Public Cloud instances via REST API. OVHcloud

Setup

OVHcloud uses signature-based API authentication. You need:

  1. Application Key and Application Secret - Create at https://api.ovh.com/createToken/
  2. Consumer Key - Generated during token creation
  3. Project ID - Find at OVH Manager (select project -> Project ID)

Required API permissions:

  • GET /cloud/project/*
  • POST /cloud/project/*
  • DELETE /cloud/project/*
  • GET /me

Environment Variables

Variable Description
OVH_APPLICATION_KEY OVH Application Key
OVH_APPLICATION_SECRET OVH Application Secret
OVH_CONSUMER_KEY OVH Consumer Key
OVH_PROJECT_ID OVH Public Cloud Project ID
OVH_SERVER_NAME Instance name (optional, prompted if not set)
OVH_FLAVOR Instance flavor (default: d2-2)
OVH_REGION Region (default: GRA7)
OVH_SSH_USER SSH user (default: ubuntu)

Agents

Claude Code

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

Aider

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

OpenClaw

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

NanoClaw

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

Cline

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

Codex CLI

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

Goose

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

Open Interpreter

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

Gemini CLI

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

Amazon Q CLI

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

OpenCode

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

Plandex

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

gptme

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

Non-Interactive Mode

OVH_SERVER_NAME=dev-mk1 \
OVH_APPLICATION_KEY=your-app-key \
OVH_APPLICATION_SECRET=your-app-secret \
OVH_CONSUMER_KEY=your-consumer-key \
OVH_PROJECT_ID=your-project-id \
OPENROUTER_API_KEY=sk-or-v1-xxxxx \
  bash <(curl -fsSL https://openrouter.ai/labs/spawn/ovh/claude.sh)