From 85b7e1bcb0e38bc968e2791da2596182fca223e9 Mon Sep 17 00:00:00 2001 From: A <258483684+la14-1@users.noreply.github.com> Date: Wed, 11 Feb 2026 13:48:30 -0800 Subject: [PATCH] feat: Add netcup/gptme script (#522) Implements gptme agent on Netcup VPS using netcup lib primitives. Agent: gap-filler-netcup Co-authored-by: B <6723574+louisgv@users.noreply.github.com> Co-authored-by: Claude Sonnet 4.5 --- manifest.json | 2 +- netcup/gptme.sh | 66 +++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 67 insertions(+), 1 deletion(-) create mode 100644 netcup/gptme.sh diff --git a/manifest.json b/manifest.json index 98809474..710a36e3 100644 --- a/manifest.json +++ b/manifest.json @@ -1181,7 +1181,7 @@ "netcup/gemini": "implemented", "netcup/amazonq": "implemented", "netcup/cline": "implemented", - "netcup/gptme": "missing", + "netcup/gptme": "implemented", "netcup/opencode": "missing", "netcup/plandex": "missing", "netcup/kilocode": "missing", diff --git a/netcup/gptme.sh b/netcup/gptme.sh new file mode 100644 index 00000000..57e69b71 --- /dev/null +++ b/netcup/gptme.sh @@ -0,0 +1,66 @@ +#!/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=netcup/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/netcup/lib/common.sh)" +fi + +log_info "gptme on Netcup Cloud" +echo "" + +# 1. Resolve Netcup credentials +ensure_netcup_credentials + +# 2. Generate 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 "${NETCUP_SERVER_IP}" +wait_for_cloud_init "${NETCUP_SERVER_IP}" 60 + +# 5. Install gptme +log_step "Installing gptme..." +run_server "${NETCUP_SERVER_IP}" "pip install gptme 2>/dev/null || pip3 install gptme" + +# Verify installation succeeded +if ! run_server "${NETCUP_SERVER_IP}" "command -v gptme &> /dev/null && gptme --version &> /dev/null"; then + log_error "gptme installation verification failed" + log_error "The 'gptme' command is not available or not working properly on server ${NETCUP_SERVER_IP}" + exit 1 +fi +log_info "gptme 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 + +# Get model preference +MODEL_ID=$(get_model_id_interactive "openrouter/auto" "gptme") || exit 1 + +log_step "Setting up environment variables..." +inject_env_vars_ssh "${NETCUP_SERVER_IP}" upload_file run_server \ + "OPENROUTER_API_KEY=${OPENROUTER_API_KEY}" + +echo "" +log_info "Netcup VPS setup completed successfully!" +log_info "Server: ${SERVER_NAME} (ID: ${NETCUP_SERVER_ID}, IP: ${NETCUP_SERVER_IP})" +echo "" + +# 7. Start gptme interactively +log_step "Starting gptme..." +sleep 1 +clear +interactive_session "${NETCUP_SERVER_IP}" "source ~/.zshrc && gptme -m openrouter/${MODEL_ID}"