mirror of
https://github.com/moltbot/moltbot.git
synced 2026-04-27 00:17:29 +00:00
refactor(scripts): dedupe installer CLI verification
This commit is contained in:
@@ -4,6 +4,10 @@ set -euo pipefail
|
||||
INSTALL_URL="${OPENCLAW_INSTALL_URL:-https://openclaw.bot/install.sh}"
|
||||
DEFAULT_PACKAGE="openclaw"
|
||||
PACKAGE_NAME="${OPENCLAW_INSTALL_PACKAGE:-$DEFAULT_PACKAGE}"
|
||||
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
||||
|
||||
# shellcheck source=../install-sh-common/cli-verify.sh
|
||||
source "$SCRIPT_DIR/../install-sh-common/cli-verify.sh"
|
||||
|
||||
echo "==> Pre-flight: ensure git absent"
|
||||
if command -v git >/dev/null; then
|
||||
@@ -26,41 +30,7 @@ if [[ -n "$EXPECTED_VERSION" ]]; then
|
||||
else
|
||||
LATEST_VERSION="$(npm view "$PACKAGE_NAME" version)"
|
||||
fi
|
||||
CLI_NAME="$PACKAGE_NAME"
|
||||
CMD_PATH="$(command -v "$CLI_NAME" || true)"
|
||||
if [[ -z "$CMD_PATH" && -x "$HOME/.npm-global/bin/$PACKAGE_NAME" ]]; then
|
||||
CLI_NAME="$PACKAGE_NAME"
|
||||
CMD_PATH="$HOME/.npm-global/bin/$PACKAGE_NAME"
|
||||
fi
|
||||
ENTRY_PATH=""
|
||||
if [[ -z "$CMD_PATH" ]]; then
|
||||
NPM_ROOT="$(npm root -g 2>/dev/null || true)"
|
||||
if [[ -n "$NPM_ROOT" && -f "$NPM_ROOT/$PACKAGE_NAME/dist/entry.js" ]]; then
|
||||
ENTRY_PATH="$NPM_ROOT/$PACKAGE_NAME/dist/entry.js"
|
||||
fi
|
||||
fi
|
||||
if [[ -z "$CMD_PATH" && -z "$ENTRY_PATH" ]]; then
|
||||
echo "$PACKAGE_NAME is not on PATH" >&2
|
||||
exit 1
|
||||
fi
|
||||
echo "==> Verify CLI installed: $CLI_NAME"
|
||||
if [[ -n "$CMD_PATH" ]]; then
|
||||
INSTALLED_VERSION="$("$CMD_PATH" --version 2>/dev/null | head -n 1 | tr -d '\r')"
|
||||
else
|
||||
INSTALLED_VERSION="$(node "$ENTRY_PATH" --version 2>/dev/null | head -n 1 | tr -d '\r')"
|
||||
fi
|
||||
|
||||
echo "cli=$CLI_NAME installed=$INSTALLED_VERSION expected=$LATEST_VERSION"
|
||||
if [[ "$INSTALLED_VERSION" != "$LATEST_VERSION" ]]; then
|
||||
echo "ERROR: expected ${CLI_NAME}@${LATEST_VERSION}, got ${CLI_NAME}@${INSTALLED_VERSION}" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "==> Sanity: CLI runs"
|
||||
if [[ -n "$CMD_PATH" ]]; then
|
||||
"$CMD_PATH" --help >/dev/null
|
||||
else
|
||||
node "$ENTRY_PATH" --help >/dev/null
|
||||
fi
|
||||
echo "==> Verify CLI installed"
|
||||
verify_installed_cli "$PACKAGE_NAME" "$LATEST_VERSION"
|
||||
|
||||
echo "OK"
|
||||
|
||||
Reference in New Issue
Block a user