Initial: OpenClaw + Claude Pro Proxy with CI/CD
Some checks failed
Build and Deploy / build-and-deploy (push) Has been cancelled

This commit is contained in:
Joshua Adkisson
2026-04-02 10:24:02 -05:00
commit a6a7f82109
3 changed files with 133 additions and 0 deletions

View File

@@ -0,0 +1,49 @@
name: Build and Deploy
on:
push:
branches: [main]
env:
REGISTRY: gitea.pitthappens.dyndns.org
IMAGE_NAME: ragincajunbanjo/openclaw-proxy
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Login to Gitea Container Registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ gitea.actor }}
password: ${{ secrets.REGISTRY_TOKEN }}
- name: Build and push image
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: |
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ gitea.sha }}
- name: Deploy to local Docker
run: |
docker pull ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest
cd ${{ gitea.workspace }}
docker compose -f docker-compose.yml down --remove-orphans || true
docker compose -f docker-compose.yml up -d openclaw
echo "Waiting for health check..."
for i in $(seq 1 60); do
if curl -sf http://127.0.0.1:3456/health > /dev/null 2>&1; then
echo "Deployment successful!"
exit 0
fi
sleep 2
done
echo "WARNING: Health check didn't pass within 120s"
docker compose logs openclaw

35
Dockerfile Normal file
View File

@@ -0,0 +1,35 @@
FROM node:20-bookworm-slim
RUN apt-get update && apt-get install -y \
git curl ca-certificates tini \
&& rm -rf /var/lib/apt/lists/*
RUN npm install -g @anthropic-ai/claude-code
RUN git clone https://github.com/wende/claude-max-api-proxy.git /opt/claude-max-api-proxy \
&& cd /opt/claude-max-api-proxy \
&& npm install \
&& npm run build
RUN git clone --depth 1 https://github.com/openclaw/openclaw.git /opt/openclaw \
&& cd /opt/openclaw \
&& corepack enable \
&& pnpm install --frozen-lockfile \
&& pnpm build
RUN useradd -m -u 1000 -s /bin/bash openclaw || true
RUN mkdir -p /home/openclaw/.claude \
/home/openclaw/.openclaw \
/home/openclaw/.openclaw/workspace \
&& chown -R 1000:1000 /home/openclaw
COPY entrypoint.sh /usr/local/bin/entrypoint.sh
RUN chmod +x /usr/local/bin/entrypoint.sh
USER openclaw
WORKDIR /home/openclaw
EXPOSE 3456 18789 18790
ENTRYPOINT ["tini", "--"]
CMD ["/usr/local/bin/entrypoint.sh"]

49
entrypoint.sh Normal file
View File

@@ -0,0 +1,49 @@
#!/bin/bash
set -e
MODE="${1:-run}"
if [ "$MODE" = "auth" ]; then
echo "=== Claude Code Authentication ==="
echo "Run 'claude login' to authenticate with your Max subscription."
echo "Credentials are saved to the mounted volume at ~/.claude"
echo ""
exec claude login
fi
if [ "$MODE" = "shell" ]; then
exec /bin/bash
fi
echo "Checking Claude Code authentication..."
if ! claude --version > /dev/null 2>&1; then
echo "ERROR: Claude Code CLI not working."
echo "Run: docker compose run --rm openclaw auth"
exit 1
fi
if [ ! -f "$HOME/.claude/.credentials.json" ] && [ -z "$ANTHROPIC_API_KEY" ]; then
echo "ERROR: No Claude credentials found."
echo "Run: docker compose run --rm openclaw auth"
exit 1
fi
echo "Claude Code CLI authenticated."
echo "Starting claude-max-api-proxy on :3456..."
node /opt/claude-max-api-proxy/dist/server/standalone.js &
PROXY_PID=$!
for i in $(seq 1 30); do
if curl -sf http://127.0.0.1:3456/health > /dev/null 2>&1; then
echo "Proxy ready."
break
fi
[ $i -eq 30 ] && echo "ERROR: Proxy timeout." && exit 1
sleep 1
done
echo "Starting OpenClaw gateway on :18789..."
cd /opt/openclaw
exec node dist/index.js gateway \
--bind "${OPENCLAW_GATEWAY_BIND:-lan}" \
--port 18789