generated from CubeCraft-Creations/Tracehound
101 lines
3.0 KiB
YAML
101 lines
3.0 KiB
YAML
name: Deploy (Dev)
|
|
|
|
on:
|
|
repository_dispatch:
|
|
types:
|
|
- dev-build-success
|
|
workflow_dispatch:
|
|
|
|
env:
|
|
BINARY_NAME: openclaw
|
|
DEV_HOST: ${{ secrets.DEV_HOST }}
|
|
DEV_USER: ${{ secrets.DEV_USER }}
|
|
DEPLOY_PATH: /opt/openclaw/openclaw
|
|
|
|
jobs:
|
|
deploy:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Download build artifact
|
|
uses: actions/download-artifact@v4
|
|
with:
|
|
name: ${{ env.BINARY_NAME }}
|
|
|
|
- name: Ensure binary is executable
|
|
run: chmod +x ${{ env.BINARY_NAME }}
|
|
|
|
- name: Write deploy script
|
|
run: |
|
|
cat > deploy.sh <<'SCRIPT'
|
|
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
BINARY="${1:-openclaw}"
|
|
DEPLOY_PATH="${2:-/opt/openclaw/openclaw}"
|
|
SERVICE="${3:-openclaw}"
|
|
TIMESTAMP=$(date +%Y%m%d%H%M%S)
|
|
BACKUP="${DEPLOY_PATH}.${TIMESTAMP}.bak"
|
|
|
|
echo "::backup:: copying current binary"
|
|
if [ -f "$DEPLOY_PATH" ]; then
|
|
cp "$DEPLOY_PATH" "$BACKUP"
|
|
fi
|
|
|
|
echo "::deploy:: installing new binary"
|
|
cp "$BINARY" "$DEPLOY_PATH"
|
|
chmod +x "$DEPLOY_PATH"
|
|
|
|
echo "::restart:: reloading service"
|
|
systemctl reload-or-restart "$SERVICE" || systemctl restart "$SERVICE"
|
|
|
|
echo "::health:: waiting for service"
|
|
sleep 3
|
|
if systemctl is-active --quiet "$SERVICE"; then
|
|
echo "deploy ok — ${SERVICE} is active"
|
|
else
|
|
echo "::rollback:: service failed, restoring backup"
|
|
if [ -f "$BACKUP" ]; then
|
|
cp "$BACKUP" "$DEPLOY_PATH"
|
|
systemctl restart "$SERVICE"
|
|
fi
|
|
echo "rolled back to previous binary"
|
|
exit 1
|
|
fi
|
|
|
|
echo "::cleanup:: removing old backups (keeping last 3)"
|
|
ls -t "${DEPLOY_PATH}."*.bak 2>/dev/null | tail -n +4 | xargs -r rm -f
|
|
SCRIPT
|
|
chmod +x deploy.sh
|
|
|
|
- name: Deploy to dev server
|
|
uses: appleboy/scp-action@v0.1.7
|
|
with:
|
|
host: ${{ env.DEV_HOST }}
|
|
username: ${{ env.DEV_USER }}
|
|
key: ${{ secrets.DEV_SSH_KEY }}
|
|
source: "${{ env.BINARY_NAME }},deploy.sh"
|
|
target: "/tmp/openclaw-deploy"
|
|
|
|
- name: Execute deploy on dev server
|
|
uses: appleboy/ssh-action@v1
|
|
with:
|
|
host: ${{ env.DEV_HOST }}
|
|
username: ${{ env.DEV_USER }}
|
|
key: ${{ secrets.DEV_SSH_KEY }}
|
|
script: |
|
|
set -euo pipefail
|
|
cd /tmp/openclaw-deploy
|
|
sudo ./deploy.sh "${{ env.BINARY_NAME }}" "${{ env.DEPLOY_PATH }}" "openclaw"
|
|
rm -rf /tmp/openclaw-deploy
|
|
|
|
- name: Notify on failure
|
|
if: failure()
|
|
uses: appleboy/ssh-action@v1
|
|
with:
|
|
host: ${{ env.DEV_HOST }}
|
|
username: ${{ env.DEV_USER }}
|
|
key: ${{ secrets.DEV_SSH_KEY }}
|
|
script: |
|
|
echo "deploy failed for commit ${{ github.sha }} on ${{ github.repository }}" > /tmp/openclaw-deploy-failure.txt |