Merge branch 'main' into fix/send-card-bridge
This commit is contained in:
39
nanoclaw.sh
39
nanoclaw.sh
@@ -138,16 +138,13 @@ write_header
|
|||||||
cat "$PROJECT_ROOT/assets/setup-splash.txt"
|
cat "$PROJECT_ROOT/assets/setup-splash.txt"
|
||||||
|
|
||||||
# ─── pre-flight: minimum hardware specs ────────────────────────────────
|
# ─── pre-flight: minimum hardware specs ────────────────────────────────
|
||||||
# NanoClaw runs an agent container per session. Below these thresholds the
|
# NanoClaw runs an agent container per session. Below this threshold the
|
||||||
# host + container + agent will struggle (OOM under load, image + session
|
# host + container + agent will struggle (OOM under load). Soft warn — the
|
||||||
# DBs filling the disk). Soft warn — `df` only sees the partition that
|
# user can override.
|
||||||
# $PROJECT_ROOT lives on, which can underreport on hosts with separate
|
|
||||||
# /home or /var mounts, so the user can override.
|
|
||||||
|
|
||||||
# RAM floor is set below 4 GB because "4 GB" VMs typically report 3700–3900 MB
|
# RAM floor is set below 4 GB because "4 GB" VMs typically report 3700–3900 MB
|
||||||
# after kernel reserves (e.g. Hetzner CX21 ≈ 3814, AWS t3.medium ≈ 3800).
|
# after kernel reserves (e.g. Hetzner CX21 ≈ 3814, AWS t3.medium ≈ 3800).
|
||||||
MIN_MEM_MB=3700
|
MIN_MEM_MB=3700
|
||||||
MIN_DISK_GB=20
|
|
||||||
|
|
||||||
detect_mem_mb() {
|
detect_mem_mb() {
|
||||||
case "$(uname -s)" in
|
case "$(uname -s)" in
|
||||||
@@ -162,39 +159,29 @@ detect_mem_mb() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
detect_disk_gb() {
|
|
||||||
# -P: POSIX format (no line-wrapping); -k: 1024-byte blocks. Avail is col 4.
|
|
||||||
df -Pk "$PROJECT_ROOT" 2>/dev/null \
|
|
||||||
| awk 'NR==2 { printf "%d", $4 / 1024 / 1024 }'
|
|
||||||
}
|
|
||||||
|
|
||||||
MEM_MB=$(detect_mem_mb)
|
MEM_MB=$(detect_mem_mb)
|
||||||
DISK_GB=$(detect_disk_gb)
|
|
||||||
: "${MEM_MB:=0}"
|
: "${MEM_MB:=0}"
|
||||||
: "${DISK_GB:=0}"
|
|
||||||
|
|
||||||
LOW_MEM=false; LOW_DISK=false
|
LOW_MEM=false
|
||||||
[ "$MEM_MB" -gt 0 ] && [ "$MEM_MB" -lt "$MIN_MEM_MB" ] && LOW_MEM=true
|
[ "$MEM_MB" -gt 0 ] && [ "$MEM_MB" -lt "$MIN_MEM_MB" ] && LOW_MEM=true
|
||||||
[ "$DISK_GB" -gt 0 ] && [ "$DISK_GB" -lt "$MIN_DISK_GB" ] && LOW_DISK=true
|
|
||||||
|
|
||||||
if [ "$LOW_MEM" = true ] || [ "$LOW_DISK" = true ]; then
|
if [ "$LOW_MEM" = true ]; then
|
||||||
printf ' %s\n' "$(red 'Warning: this machine likely cannot run NanoClaw.')"
|
printf ' %s\n' "$(red 'Warning: this machine likely cannot run NanoClaw.')"
|
||||||
printf ' %s\n' "$(dim 'NanoClaw recommends a 4 GB+ machine with 20 GB+ free disk. Below this,')"
|
printf ' %s\n' "$(dim 'NanoClaw recommends a 4 GB+ RAM machine. Below this, the host + agent')"
|
||||||
printf ' %s\n' "$(dim 'the host + agent container will run out of memory or disk under most')"
|
printf ' %s\n' "$(dim 'container will run out of memory under most workloads. A stronger')"
|
||||||
printf ' %s\n' "$(dim 'workloads. A stronger machine is strongly recommended.')"
|
printf ' %s\n' "$(dim 'machine is strongly recommended.')"
|
||||||
[ "$LOW_MEM" = true ] && printf ' %s\n' "$(dim " · Detected RAM: ${MEM_MB} MB")"
|
printf ' %s\n' "$(dim " · Detected RAM: ${MEM_MB} MB")"
|
||||||
[ "$LOW_DISK" = true ] && printf ' %s\n' "$(dim " · Free disk on $PROJECT_ROOT: ${DISK_GB} GB")"
|
|
||||||
printf '\n'
|
printf '\n'
|
||||||
read -r -p " $(bold 'Try anyway?') [y/N] " SPECS_ANS </dev/tty
|
read -r -p " $(bold 'Try anyway?') [y/N] " SPECS_ANS </dev/tty
|
||||||
|
|
||||||
case "${SPECS_ANS:-N}" in
|
case "${SPECS_ANS:-N}" in
|
||||||
[Yy]*)
|
[Yy]*)
|
||||||
ph_event setup_low_specs_continued mem_mb="$MEM_MB" disk_gb="$DISK_GB" low_mem="$LOW_MEM" low_disk="$LOW_DISK"
|
ph_event setup_low_specs_continued mem_mb="$MEM_MB" low_mem="$LOW_MEM"
|
||||||
printf '\n'
|
printf '\n'
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
ph_event setup_low_specs_aborted mem_mb="$MEM_MB" disk_gb="$DISK_GB" low_mem="$LOW_MEM" low_disk="$LOW_DISK"
|
ph_event setup_low_specs_aborted mem_mb="$MEM_MB" low_mem="$LOW_MEM"
|
||||||
printf '\n %s\n\n' "$(dim 'Aborted. Re-run after upgrading the host or freeing disk space.')"
|
printf '\n %s\n\n' "$(dim 'Aborted. Re-run after upgrading the host.')"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@@ -17,30 +17,40 @@ if command -v node >/dev/null 2>&1; then
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
case "$(uname -s)" in
|
if command -v uvx >/dev/null 2>&1; then
|
||||||
Darwin)
|
echo "STEP: uvx-nodeenv"
|
||||||
echo "STEP: brew-install-node"
|
uvx nodeenv -n lts ~/node
|
||||||
if ! command -v brew >/dev/null 2>&1; then
|
mkdir -p ~/.local/bin
|
||||||
|
ln -sf ~/node/bin/node ~/.local/bin/node
|
||||||
|
ln -sf ~/node/bin/npm ~/.local/bin/npm
|
||||||
|
ln -sf ~/node/bin/npx ~/.local/bin/npx
|
||||||
|
ln -sf ~/node/bin/pnpm ~/.local/bin/pnpm
|
||||||
|
else
|
||||||
|
case "$(uname -s)" in
|
||||||
|
Darwin)
|
||||||
|
echo "STEP: brew-install-node"
|
||||||
|
if ! command -v brew >/dev/null 2>&1; then
|
||||||
|
echo "STATUS: failed"
|
||||||
|
echo "ERROR: Homebrew not installed. Install brew first (https://brew.sh) then re-run."
|
||||||
|
echo "=== END ==="
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
brew install node@22
|
||||||
|
;;
|
||||||
|
Linux)
|
||||||
|
echo "STEP: nodesource-setup"
|
||||||
|
curl -fsSL https://deb.nodesource.com/setup_22.x | sudo -E bash -
|
||||||
|
echo "STEP: apt-install-nodejs"
|
||||||
|
sudo apt-get install -y nodejs
|
||||||
|
;;
|
||||||
|
*)
|
||||||
echo "STATUS: failed"
|
echo "STATUS: failed"
|
||||||
echo "ERROR: Homebrew not installed. Install brew first (https://brew.sh) then re-run."
|
echo "ERROR: Unsupported platform: $(uname -s)"
|
||||||
echo "=== END ==="
|
echo "=== END ==="
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
;;
|
||||||
brew install node@22
|
esac
|
||||||
;;
|
fi
|
||||||
Linux)
|
|
||||||
echo "STEP: nodesource-setup"
|
|
||||||
curl -fsSL https://deb.nodesource.com/setup_22.x | sudo -E bash -
|
|
||||||
echo "STEP: apt-install-nodejs"
|
|
||||||
sudo apt-get install -y nodejs
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "STATUS: failed"
|
|
||||||
echo "ERROR: Unsupported platform: $(uname -s)"
|
|
||||||
echo "=== END ==="
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if ! command -v node >/dev/null 2>&1; then
|
if ! command -v node >/dev/null 2>&1; then
|
||||||
echo "STATUS: failed"
|
echo "STATUS: failed"
|
||||||
|
|||||||
Reference in New Issue
Block a user