From eb2ec01d28525a5b40149b3a2075b94d74857209 Mon Sep 17 00:00:00 2001 From: Abdulbari Date: Thu, 23 Oct 2025 12:06:40 +0300 Subject: [PATCH] Update sgeupdated pipeline v22 new script for gitea --- .gitea/workflows/sgeupdated.yml | 133 ++++++++++++++++++-------------- 1 file changed, 75 insertions(+), 58 deletions(-) diff --git a/.gitea/workflows/sgeupdated.yml b/.gitea/workflows/sgeupdated.yml index dae3b2d..20252f0 100644 --- a/.gitea/workflows/sgeupdated.yml +++ b/.gitea/workflows/sgeupdated.yml @@ -4,86 +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 - + + echo "✅ Connected to server. Navigating to project..." cd /home/ubuntu/Bgreen/sgeUpdated + + # 1. Fetch the latest code git fetch origin main - - # Detect which files changed in the last commit - CHANGED_FILES=$(git diff --name-only HEAD HEAD~1) - - echo "🪶 Changed files:" - echo "$CHANGED_FILES" - + + # 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 - + # Backend section - #if [ "$BACKEND_CHANGED" = true ]; then - #echo "⚡ Backend changes detected." - #cd sgeUpdated/sge-backend - #echo "Running Maven build..." - #/opt/apache-maven-3.9.11/bin/mvn clean install -DskipTests - # cd ../.. - #echo "Rebuilding backend Docker container..." - #docker compose up -d --build bgreen-backend - #else - #echo "✅ No backend changes." - #fi - + if [ "$BACKEND_CHANGED" = true ]; then + 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 .. + 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 sgeUpdated/sge-frontend - echo "Running npm build..." - # npm install - # npm run build - cd ../.. + echo "⚡ Frontend changes detected. Rebuilding frontend..." + cd sge-frontend + echo "Running npm install and build..." + npm install + npm run build + cd .. echo "Rebuilding frontend Docker container..." - docker compose up -d --build bgreen-frontend else echo "✅ No frontend changes." fi - - # If no changes at all, just restart containers (commented out for now) - #if [ "$BACKEND_CHANGED" = false ] && [ "$FRONTEND_CHANGED" = false ]; then - #echo "♻️ No source changes detected. (Would restart containers here...)" - #docker compose up -d - #fi - - echo "✅ Check complete. (No rebuild or restart performed.)" + + # 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