openclaw / Dockerfile
YoBatM's picture
Update Dockerfile
c6f878c 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
# Expose the port
EXPOSE 7860
# Create a startup script
RUN echo '#!/bin/bash\n\
set -x\n\
\n\
if [ -z "$GEMINI_API_KEY_1" ]; then\n\
echo "ERROR: GEMINI_API_KEY_1 is not set."\n\
exit 1\n\
fi\n\
\n\
mkdir -p /root/.openclaw/agents/main/agent\n\
mkdir -p /root/.openclaw/agents/main/sessions\n\
mkdir -p /root/.openclaw/credentials\n\
\n\
rm -f /root/.openclaw/agents/main/agent/auth-profiles.json\n\
\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": [\n\
"10.16.4.123",\n\
"10.16.34.155",\n\
"10.20.1.9",\n\
"10.20.1.222",\n\
"10.20.26.157",\n\
"10.20.31.87"\n\
],\n\
"auth": {\n\
"mode": "token",\n\
"token": "hola"\n\
},\n\
"controlUi": {\n\
"enabled": true,\n\
"allowInsecureAuth": true,\n\
"dangerouslyDisableDeviceAuth": true,\n\
"allowedOrigins": ["*"],\n\
"dangerouslyAllowHostHeaderOriginFallback": true\n\
}\n\
},\n\
"agents": {\n\
"defaults": {\n\
"model": {\n\
"primary": "google/gemini-2.5-flash"\n\
}\n\
}\n\
}\n\
}\n\
EOF\n\
fi\n\
\n\
chmod 700 /root/.openclaw\n\
chmod 600 /root/.openclaw/openclaw.json\n\
\n\
openclaw doctor --fix\n\
\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"]