openclaw / Dockerfile
oreo0725's picture
Update Dockerfile
f1e4c5e verified
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=7860
ENV OPENCLAW_GATEWAY_MODE=local
ENV OPENCLAW_GATEWAY_PASSWORD=${SETUP_PASSWORD}
# Expose the port (Hugging Face default)
EXPOSE 7860
# 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_API_KEY_1" ]; then\n\
echo "ERROR: GEMINI_API_KEY_1 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_API_KEY_1}",\n\
"GEMINI_API_KEY": "${GEMINI_API_KEY_1}",\n\
"GOOGLE_GENERATIVE_AI_API_KEY": "${GEMINI_API_KEY_1}",\n\
"PALM_API_KEY": "${GEMINI_API_KEY_1}"\n\
},\n\
"gateway": {\n\
"mode": "local",\n\
"bind": "lan",\n\
"port": 7860,\n\
"trustedProxies": ["0.0.0.0/0"],\n\
"auth": {\n\
"mode": "token",\n\
"token": "${SETUP_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 7860..."\n\
exec openclaw gateway run --port 7860\n\
' > /usr/local/bin/start-openclaw && chmod +x /usr/local/bin/start-openclaw
CMD ["/usr/local/bin/start-openclaw"]