From 385eda21323a94bebe772eef59a8a07e12c14e45 Mon Sep 17 00:00:00 2001 From: Abdulbari Date: Fri, 24 Oct 2025 15:13:23 +0300 Subject: [PATCH] Update sgeupdated pipeline v22 --- .gitea/workflows/sgeupdated.yml | 152 +++++++++++++++----------------- 1 file changed, 73 insertions(+), 79 deletions(-) diff --git a/.gitea/workflows/sgeupdated.yml b/.gitea/workflows/sgeupdated.yml index a2c3752..20252f0 100644 --- a/.gitea/workflows/sgeupdated.yml +++ b/.gitea/workflows/sgeupdated.yml @@ -4,109 +4,103 @@ on: push: branches: - main - workflow_dispatch: - -concurrency: - group: sgeupdated-deploy-${{ github.ref }} - cancel-in-progress: true jobs: deploy: + # 'ubuntu-latest' is a common name for runners. + # Check with your Gitea admin if you have a different runner tag. runs-on: ubuntu-latest - + steps: - - name: Checkout repo - uses: actions/checkout@v3 + # Gitea automatically checks out your code, so we don't need 'actions/checkout' - - name: Deploy over SSH - uses: appleboy/ssh-action@v1.0.3 - with: - host: ${{ secrets.SERVER_HOST }} - username: ${{ secrets.SERVER_USER }} - key: ${{ secrets.SSH_PRIVATE_KEY }} - script_stop: true - script: | + - name: Setup SSH + run: | + # Create the .ssh directory + mkdir -p ~/.ssh/ + + # Add your private key (from Gitea secrets) + echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa + chmod 600 ~/.ssh/id_rsa + + # Add your server's host key to known_hosts to avoid the 'yes/no' prompt + # This is a critical step for automation + ssh-keyscan ${{ secrets.SERVER_HOST }} >> ~/.ssh/known_hosts + + - name: Deploy to Server + # This command runs the entire script on your remote server + run: | + ssh ${{ secrets.SERVER_USER }}@${{ secrets.SERVER_HOST }} << 'EOF' + # Start of remote script set -euo pipefail - - # Go to your repo + + echo "✅ Connected to server. Navigating to project..." cd /home/ubuntu/Bgreen/sgeUpdated - - echo "📦 Fetching latest code from your fork..." - git fetch myfork main - - # Detect which files changed in the last commit - CHANGED_FILES=$(git diff --name-only HEAD HEAD~1) - echo "🪶 Changed files:" - echo "$CHANGED_FILES" - - echo "🔄 Resetting to your fork's main branch..." - git reset --hard myfork/main - + + # 1. Fetch the latest code + git fetch origin main + + # 2. See what files changed between your current version (HEAD) and the new one (origin/main) + # We add '|| true' in case there are no diffs, which would stop 'set -e' + CHANGED_FILES=$(git diff --name-only HEAD origin/main) || true + + if [ -z "$CHANGED_FILES" ]; then + echo "No file changes detected between HEAD and origin/main." + else + echo "🪶 Changed files:" + echo "$CHANGED_FILES" + fi + + # 3. Update the local repository to the new version + git reset --hard origin/main + BACKEND_CHANGED=false FRONTEND_CHANGED=false - - # Check if backend folder changed - if echo "$CHANGED_FILES" | grep -q "^sgeUpdated/sge-backend/"; then + + # 4. Check for backend changes (Note the corrected path: no 'sgeUpdated/') + if echo "$CHANGED_FILES" | grep -q "^sge-backend/"; then BACKEND_CHANGED=true fi - - # Check if frontend folder changed - if echo "$CHANGED_FILES" | grep -q "^sgeUpdated/sge-frontend/"; then + + # 5. Check for frontend changes (Note the corrected path: no 'sgeUpdated/') + if echo "$CHANGED_FILES" | grep -q "^sge-frontend/"; then FRONTEND_CHANGED=true fi - - ############################ - # Docker readiness check - ############################ - echo "⏳ Checking Docker status before rebuild..." - sleep 5 - docker ps -a || true - - ############################ + + # Backend section - ############################ if [ "$BACKEND_CHANGED" = true ]; then - echo "⚡ Backend changes detected." - echo "Running Maven build for backend..." - cd /home/ubuntu/Bgreen/sgeUpdated/sge-backend + echo "⚡ Backend changes detected. Rebuilding backend..." + cd sge-backend + echo "Running Maven build..." /opt/apache-maven-3.9.11/bin/mvn clean install -DskipTests - cd /home/ubuntu/Bgreen - echo "🔁 Rebuilding backend container..." - docker compose -f docker-compose.yml up -d --build bgreen-backend || { - echo "⚠️ Docker rebuild failed once, retrying..." - sleep 5 - docker compose -f docker-compose.yml up -d --build bgreen-backend - } + cd .. + echo "Rebuilding backend Docker container..." + docker compose up -d --build bgreen-backend else echo "✅ No backend changes." fi - - ############################ + # Frontend section - ############################ if [ "$FRONTEND_CHANGED" = true ]; then - echo "⚡ Frontend changes detected." - cd /home/ubuntu/Bgreen/sgeUpdated/sge-frontend - echo "Installing npm dependencies and building..." + echo "⚡ Frontend changes detected. Rebuilding frontend..." + cd sge-frontend + echo "Running npm install and build..." npm install npm run build - cd /home/ubuntu/Bgreen - echo "🔁 Rebuilding frontend container..." - docker compose -f docker-compose.yml up -d --build bgreen-frontend || { - echo "⚠️ Docker rebuild failed once, retrying..." - sleep 5 - docker compose -f docker-compose.yml up -d --build bgreen-frontend - } + cd .. + echo "Rebuilding frontend Docker container..." + docker compose up -d --build bgreen-frontend else echo "✅ No frontend changes." fi - - ############################ - # If no changes at all - ############################ - if [ "$BACKEND_CHANGED" = false ] && [ "$FRONTEND_CHANGED" = false ]; then - echo "♻️ No source changes detected. Restarting containers..." - docker compose -f /home/ubuntu/Bgreen/docker-compose.yml up -d - fi - - echo "✅ Deployment check complete." + + # This is your final 'build all' condition + # if [ "$BACKEND_CHANGED" = false ] && [ "$FRONTEND_CHANGED" = false ]; then + # echo "♻️ No source changes detected. Ensuring all containers are up." + # docker compose up -d + # fi + + echo "✅ Deployment script finished." + EOF + # End of remote script