FROM node:22-slim # Install system dependencies RUN apt-get update && apt-get install -y git && rm -rf /var/lib/apt/lists/* # Install OpenClaw globally RUN npm install -g openclaw@latest # Create config directory RUN mkdir -p /root/.openclaw # Set up environment for Hugging Face Spaces ENV PORT=18789 ENV OPENCLAW_GATEWAY_MODE=local ENV OPENCLAW_GATEWAY_PASSWORD=${OPENCLAW_GATEWAY_PASSWORD} # Expose the port (Hugging Face default) EXPOSE 18789 # Create a startup script that generates config and starts OpenClaw RUN echo '#!/bin/bash\n\ set -x\n\ \n\ # Check for required environment variables\n\ if [ -z "$GEMINI_APIKEY" ]; then\n\ echo "ERROR: GEMINI_APIKEY is not set. Agent will fail. Exiting."\n\ exit 1\n\ fi\n\ \n\ # Create critical missing directories\n\ mkdir -p /root/.openclaw/agents/main/agent\n\ mkdir -p /root/.openclaw/agents/main/sessions\n\ mkdir -p /root/.openclaw/credentials\n\ \n\ # Remove auth-profiles.json if it exists to force env var usage\n\ rm -f /root/.openclaw/agents/main/agent/auth-profiles.json\n\ \n\ # Generate minimal config if not exists\n\ if [ ! -f /root/.openclaw/openclaw.json ]; then\n\ cat > /root/.openclaw/openclaw.json << EOF\n\ {\n\ "env": {\n\ "GOOGLE_API_KEY": "${GEMINI_APIKEY}",\n\ "GEMINI_API_KEY": "${GEMINI_APIKEY}",\n\ "GOOGLE_GENERATIVE_AI_API_KEY": "${GEMINI_APIKEY}",\n\ "PALM_API_KEY": "${GEMINI_APIKEY}"\n\ },\n\ "gateway": {\n\ "mode": "local",\n\ "bind": "lan",\n\ "port": 18789,\n\ "trustedProxies": ["0.0.0.0/0"],\n\ "auth": {\n\ "mode": "token",\n\ "token": "${OPENCLAW_GATEWAY_PASSWORD}"\n\ },\n\ "controlUi": {\n\ "allowInsecureAuth": true\n\ }\n\ },\n\ "agents": {\n\ "defaults": {\n\ "model": {\n\ "primary": "google/gemini-1.5-pro"\n\ }\n\ }\n\ }\n\ }\n\ EOF\n\ fi\n\ \n\ # Fix permissions\n\ chmod 700 /root/.openclaw\n\ chmod 600 /root/.openclaw/openclaw.json\n\ chmod 600 /root/.openclaw/agents/main/agent/auth-profiles.json\n\ \n\ # Fix config if needed\n\ openclaw doctor --fix\n\ \n\ # Start OpenClaw gateway\n\ echo "Starting OpenClaw gateway on port 18789..."\n\ exec openclaw gateway run --port 18789\n\ ' > /usr/local/bin/start-openclaw && chmod +x /usr/local/bin/start-openclaw CMD ["/usr/local/bin/start-openclaw"]