Update sgeupdated pipeline v22

This commit is contained in:
2025-10-24 15:13:23 +03:00
parent 23a3d8252e
commit 385eda2132

View File

@@ -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
# 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)
# 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
echo "🔄 Resetting to your fork's main branch..."
git reset --hard myfork/main
# 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
# 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 check complete."
echo "✅ Deployment script finished."
EOF
# End of remote script