From c00fc2fbd6ec8483ab13cd1c2a509fc1c80caed3 Mon Sep 17 00:00:00 2001 From: Gianpierre Mio <88248836+DarkCodex29@users.noreply.github.com> Date: Wed, 8 Apr 2026 13:42:40 -0500 Subject: [PATCH] ci: unify deploy pipeline - sync to Gitea + self-hosted deploy - GitHub: CI on ubuntu-latest (no more self-hosted) - GitHub: add sync-gitea.yml for auto-deploy trigger - Gitea: add deploy.yml with robust health check - Remove disabled deploy.yml.disabled --- .gitea/workflows/deploy.yml | 48 +++++++++++++++++++ .github/workflows/ci.yml | 13 +++--- .github/workflows/deploy.yml.disabled | 66 --------------------------- .github/workflows/sync-gitea.yml | 17 +++++++ 4 files changed, 71 insertions(+), 73 deletions(-) create mode 100644 .gitea/workflows/deploy.yml delete mode 100644 .github/workflows/deploy.yml.disabled create mode 100644 .github/workflows/sync-gitea.yml diff --git a/.gitea/workflows/deploy.yml b/.gitea/workflows/deploy.yml new file mode 100644 index 0000000..b8304fa --- /dev/null +++ b/.gitea/workflows/deploy.yml @@ -0,0 +1,48 @@ +name: Deploy API-Ubigeo + +on: + push: + branches: [main] + +jobs: + deploy: + runs-on: self-hosted + steps: + - name: Checkout + uses: actions/checkout@v4 + + - name: Sync source + run: | + rsync -a --delete \ + --exclude='.git' \ + --exclude='node_modules' \ + --exclude='dist' \ + --exclude='.env' \ + ./ /home/deployer/api-ubigeo/ + + - name: Build image + run: | + cd /home/deployer/api-ubigeo + docker build -t ubigeo-api:latest . + + - name: Deploy containers + run: | + cd /home/deployer/api-ubigeo + docker compose -f docker-compose.production.yml down --remove-orphans + docker compose -f docker-compose.production.yml up -d + + - name: Health check + run: | + echo "Waiting for API-Ubigeo to start..." + for i in $(seq 1 15); do + sleep 3 + HTTP_CODE=$(curl -s -o /dev/null -w '%{http_code}' http://localhost:3200/api/v1/health 2>/dev/null || echo "000") + if [ "$HTTP_CODE" != "000" ] && [ "$HTTP_CODE" != "502" ] && [ "$HTTP_CODE" != "503" ]; then + echo "✅ Health check passed after $((i*3))s (HTTP $HTTP_CODE)" + exit 0 + fi + echo "Attempt $i/15 - not ready yet (HTTP $HTTP_CODE)..." + done + echo "❌ Health check failed after 45s" + docker logs ubigeo-api --tail 50 + exit 1 \ No newline at end of file diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index b840875..6ec4608 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -6,16 +6,15 @@ on: jobs: build: - runs-on: self-hosted + runs-on: ubuntu-latest steps: - - name: Checkout - uses: actions/checkout@v4 - + - uses: actions/checkout@v4 + - uses: actions/setup-node@v4 + with: + node-version: '22' - name: Install dependencies run: npm ci - - name: Generate Prisma client run: npx prisma generate - - name: Build - run: npm run build + run: npm run build \ No newline at end of file diff --git a/.github/workflows/deploy.yml.disabled b/.github/workflows/deploy.yml.disabled deleted file mode 100644 index b510b49..0000000 --- a/.github/workflows/deploy.yml.disabled +++ /dev/null @@ -1,66 +0,0 @@ -name: Deploy - -on: - push: - branches: [main] - -jobs: - deploy: - runs-on: self-hosted - steps: - - name: Checkout - run: | - if [ ! -d /workspace/darkcodex/api-ubigeo/.git ]; then - git clone https://948ee86882f8d9ca46eb94750addfccdace443a6@git.darkcodex.dev/darkcodex/api-ubigeo.git \ - /workspace/darkcodex/api-ubigeo - fi - cd /workspace/darkcodex/api-ubigeo - git fetch origin main - git reset --hard origin/main - - - name: Sync source - run: | - rsync -a --delete \ - --exclude='.git' \ - --exclude='node_modules' \ - --exclude='dist' \ - --exclude='.env' \ - /workspace/darkcodex/api-ubigeo/ /home/deployer/api-ubigeo/ - - - name: Build image - run: | - cd /home/deployer/api-ubigeo - docker build -t ubigeo-api:latest . - - - name: Deploy containers - run: | - cd /home/deployer/api-ubigeo - docker compose -f docker-compose.production.yml down --remove-orphans - docker compose -f docker-compose.production.yml up -d - - - name: Register Traefik route - run: | - docker run --rm \ - -v /etc/easypanel/traefik/config:/traefik-config \ - alpine sh -c ' - apk add jq -q --no-progress 2>/dev/null - FILE=/traefik-config/main.yaml - - if jq -e ".http.routers[\"https-ubigeo-0\"]" "$FILE" > /dev/null 2>&1; then - echo "ubigeo route already exists in main.yaml" - exit 0 - fi - - jq ".http.routers[\"http-ubigeo-0\"] = {\"rule\": \"Host(\\\"api-ubigeo.darkcodex.dev\\\") && PathPrefix(\\\"/\\\")\", \"entryPoints\": [\"http\"], \"middlewares\": [\"redirect-to-https\", \"bad-gateway-error-page\"], \"service\": \"ubigeo_api-0\"} | - .http.routers[\"https-ubigeo-0\"] = {\"rule\": \"Host(\\\"api-ubigeo.darkcodex.dev\\\") && PathPrefix(\\\"/\\\")\", \"entryPoints\": [\"https\"], \"middlewares\": [\"bad-gateway-error-page\"], \"service\": \"ubigeo_api-0\", \"tls\": {\"certResolver\": \"letsencrypt\"}} | - .http.services[\"ubigeo_api-0\"] = {\"loadBalancer\": {\"passHostHeader\": true, \"servers\": [{\"url\": \"http://ubigeo-api:3200/\"}]}}" \ - "$FILE" > /tmp/main-new.json && mv /tmp/main-new.json "$FILE" - echo "Traefik route injected into main.yaml" - ' - - - name: Health check - run: | - sleep 15 - STATUS=$(wget -qO- http://ubigeo-api:3200/api/v1/health 2>/dev/null || echo "fail") - echo "Health: $STATUS" - echo "$STATUS" | grep -q "ok" && echo "Deploy OK" || echo "Warning: health check unreachable from runner" diff --git a/.github/workflows/sync-gitea.yml b/.github/workflows/sync-gitea.yml new file mode 100644 index 0000000..189ba51 --- /dev/null +++ b/.github/workflows/sync-gitea.yml @@ -0,0 +1,17 @@ +name: Sync to Gitea + +on: + push: + branches: [main] + +jobs: + sync: + name: Push to Gitea + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Push to Gitea + run: | + git push https://${{ secrets.GITEA_TOKEN }}@git.darkcodex.dev/darkcodex/api-ubigeo.git main --force \ No newline at end of file