foxy-dev-team/backend/start-container.sh

79 lines
4.0 KiB
Bash

#!/bin/bash
set -e
echo "🦊 Starting Foxy Dev Team API Container..."
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
# ─── Environment ──────────────────────────────────────────────────────────────
export HOME="/home/foxy"
export FOXY_HOME="/home/foxy/.openclaw"
export OPENCLAW_TYPE="${OPENCLAW_TYPE:-standalone}"
# Force gateway bind to LAN (all interfaces) — required for Docker
export OPENCLAW_GATEWAY_BIND="lan"
echo "📌 OPENCLAW_TYPE = $OPENCLAW_TYPE"
echo "📌 FOXY_HOME = $FOXY_HOME"
echo "📌 OPENCLAW_GATEWAY_BIND = $OPENCLAW_GATEWAY_BIND"
# ─── Ensure directories ──────────────────────────────────────────────────────
mkdir -p "$FOXY_HOME/logs" "$FOXY_HOME/workspace" "$FOXY_HOME/agents"
# ─── Config patching ─────────────────────────────────────────────────────────
# Fix host paths (/home/openclaw → /home/foxy) in all config & agent files
echo "🔧 Patching host paths for container environment..."
find "$FOXY_HOME" -type f \( -name "*.json" -o -name "*.yaml" -o -name "*.yml" \) \
-not -path "*/logs/*" \
-not -path "*/node_modules/*" \
-exec sed -i 's/\/home\/openclaw/\/home\/foxy/g' {} + 2>/dev/null || true
echo "✅ Path patching complete."
# ─── Gateway startup ─────────────────────────────────────────────────────────
if [ "$OPENCLAW_TYPE" = "standalone" ]; then
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo "🚀 Starting OpenClaw Gateway (standalone, foreground mode)..."
echo ""
echo " Command: openclaw gateway run --bind lan --allow-unconfigured"
echo ""
# 'gateway run' = foreground mode (no systemd needed)
# '--bind lan' = listen on all interfaces (0.0.0.0) for Docker port mapping
# '--allow-unconfigured' = start even if gateway.mode!=local in config
nohup openclaw gateway run \
--bind lan \
--allow-unconfigured \
> "$FOXY_HOME/logs/gateway.log" 2>&1 &
GATEWAY_PID=$!
echo "⏱ Waiting for Gateway (PID $GATEWAY_PID) to initialize..."
# Wait up to 15 seconds for port 18789 to open
for i in $(seq 1 15); do
if netstat -tulpn 2>/dev/null | grep -q ":18789"; then
echo "✅ OpenClaw Gateway is UP — port 18789 is listening!"
break
fi
if ! kill -0 $GATEWAY_PID 2>/dev/null; then
echo "❌ Gateway process died!"
echo "──── Gateway Log ────"
tail -n 30 "$FOXY_HOME/logs/gateway.log" 2>/dev/null || echo "(no log)"
echo "─────────────────────"
break
fi
sleep 1
done
# Final check
if ! netstat -tulpn 2>/dev/null | grep -q ":18789"; then
echo "⚠️ Gateway may not be fully ready. Tail of log:"
tail -n 10 "$FOXY_HOME/logs/gateway.log" 2>/dev/null || true
echo "⚠️ Continuing anyway — API will still start."
fi
else
echo "🔗 OPENCLAW_TYPE is shared — expecting host-managed Gateway."
fi
# ─── Start API ────────────────────────────────────────────────────────────────
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo "🚀 Starting Uvicorn API Server on port 7000..."
exec python -m uvicorn app.main:app --host 0.0.0.0 --port 7000