From 8e4def50a79826d34a5ec9dcb29ff27b4e79b2fa Mon Sep 17 00:00:00 2001 From: A <258483684+la14-1@users.noreply.github.com> Date: Fri, 13 Feb 2026 23:20:50 -0800 Subject: [PATCH] feat: Add Open Interpreter on HOSTKEY (#1072) Agent: gap-filler Co-authored-by: OpenRouter Bot Co-authored-by: Claude Sonnet 4.5 Co-authored-by: Security Reviewer --- hostkey/README.md | 6 ++++ hostkey/interpreter.sh | 64 ++++++++++++++++++++++++++++++++++++++++++ manifest.json | 2 +- 3 files changed, 71 insertions(+), 1 deletion(-) create mode 100644 hostkey/interpreter.sh diff --git a/hostkey/README.md b/hostkey/README.md index c17fe555..fd88c100 100644 --- a/hostkey/README.md +++ b/hostkey/README.md @@ -10,6 +10,12 @@ HOSTKEY VPS hosting via REST API. [HOSTKEY](https://hostkey.com/) bash <(curl -fsSL https://openrouter.ai/labs/spawn/hostkey/claude.sh) ``` +#### Open Interpreter + +```bash +bash <(curl -fsSL https://openrouter.ai/labs/spawn/hostkey/interpreter.sh) +``` + #### gptme ```bash diff --git a/hostkey/interpreter.sh b/hostkey/interpreter.sh new file mode 100644 index 00000000..3d2b4fec --- /dev/null +++ b/hostkey/interpreter.sh @@ -0,0 +1,64 @@ +#!/bin/bash +set -eo pipefail + +# Source common functions - try local file first, fall back to remote +SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" 2>/dev/null && pwd)" +# shellcheck source=hostkey/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/hostkey/lib/common.sh)" +fi + +log_info "Open Interpreter on HOSTKEY" +echo "" + +# 1. Resolve HOSTKEY API token +ensure_hostkey_token + +# 2. Generate + register SSH key +ensure_ssh_key + +# 3. Get server name and create server +SERVER_NAME=$(get_server_name) +create_server "${SERVER_NAME}" + +# 4. Wait for SSH and cloud-init +verify_server_connectivity "${HOSTKEY_INSTANCE_IP}" +wait_for_cloud_init "${HOSTKEY_INSTANCE_IP}" 60 + +# 5. Install Open Interpreter +log_step "Installing Open Interpreter..." +run_server "${HOSTKEY_INSTANCE_IP}" "pip install open-interpreter 2>/dev/null || pip3 install open-interpreter" + +# Verify installation succeeded +if ! run_server "${HOSTKEY_INSTANCE_IP}" "command -v interpreter &> /dev/null"; then + log_install_failed "Open Interpreter" "pip install open-interpreter" "${HOSTKEY_INSTANCE_IP}" + exit 1 +fi +log_info "Open Interpreter installation verified successfully" + +# 6. Get OpenRouter API key +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_step "Setting up environment variables..." +inject_env_vars_ssh "${HOSTKEY_INSTANCE_IP}" upload_file run_server \ + "OPENROUTER_API_KEY=${OPENROUTER_API_KEY}" \ + "OPENAI_API_KEY=${OPENROUTER_API_KEY}" \ + "OPENAI_BASE_URL=https://openrouter.ai/api/v1" + +echo "" +log_info "HOSTKEY server setup completed successfully!" +log_info "Server: ${SERVER_NAME} (ID: ${HOSTKEY_INSTANCE_ID}, IP: ${HOSTKEY_INSTANCE_IP})" +echo "" + +# 7. Start Open Interpreter interactively +log_step "Starting Open Interpreter..." +sleep 1 +clear +interactive_session "${HOSTKEY_INSTANCE_IP}" "source ~/.zshrc && interpreter" diff --git a/manifest.json b/manifest.json index b39bcfb5..ba55a403 100644 --- a/manifest.json +++ b/manifest.json @@ -1344,7 +1344,7 @@ "hostkey/aider": "implemented", "hostkey/goose": "implemented", "hostkey/codex-cli": "missing", - "hostkey/open-interpreter": "missing", + "hostkey/open-interpreter": "implemented", "hostkey/gemini-cli": "missing", "hostkey/amazonq": "missing", "hostkey/cline": "implemented",