forked from Abdulbari/sgeUpdated
Update sgeupdated pipeline v22
new script for gitea
This commit is contained in:
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user