diff --git a/exoscale/opencode.sh b/exoscale/opencode.sh new file mode 100644 index 00000000..e6df4def --- /dev/null +++ b/exoscale/opencode.sh @@ -0,0 +1,46 @@ +#!/bin/bash +set -eo pipefail + +SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" 2>/dev/null && pwd)" +# shellcheck source=exoscale/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/exoscale/lib/common.sh)" +fi + +log_info "OpenCode on Exoscale" +echo "" + +ensure_exoscale_creds +ensure_ssh_key + +SERVER_NAME=$(get_server_name) +create_server "${SERVER_NAME}" +verify_server_connectivity "${EXOSCALE_SERVER_IP}" +wait_for_cloud_init "${EXOSCALE_SERVER_IP}" 60 + +log_warn "Installing OpenCode..." +run_server "${EXOSCALE_SERVER_IP}" "$(opencode_install_cmd)" +log_info "OpenCode installed" + +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_warn "Setting up environment variables..." +inject_env_vars_ssh "${EXOSCALE_SERVER_IP}" upload_file run_server \ + "OPENROUTER_API_KEY=${OPENROUTER_API_KEY}" + +echo "" +log_info "Exoscale server setup completed successfully!" +log_info "Server: ${SERVER_NAME} (ID: ${EXOSCALE_SERVER_ID}, IP: ${EXOSCALE_SERVER_IP})" +echo "" + +log_warn "Starting OpenCode..." +sleep 1 +clear +interactive_session "${EXOSCALE_SERVER_IP}" "source ~/.zshrc && opencode" diff --git a/manifest.json b/manifest.json index a037d4df..585d928f 100644 --- a/manifest.json +++ b/manifest.json @@ -1063,7 +1063,7 @@ "exoscale/amazonq": "missing", "exoscale/cline": "implemented", "exoscale/gptme": "implemented", - "exoscale/opencode": "missing", + "exoscale/opencode": "implemented", "exoscale/plandex": "implemented", "exoscale/kilocode": "implemented", "exoscale/continue": "missing"