Update build.yml
This commit is contained in:
38
.github/workflows/build.yml
vendored
38
.github/workflows/build.yml
vendored
@@ -119,8 +119,18 @@ jobs:
|
|||||||
source: "."
|
source: "."
|
||||||
target: "/var/www/projects/${{ env.APP_NAME }}/releases/${{ env.APP_VERSION }}"
|
target: "/var/www/projects/${{ env.APP_NAME }}/releases/${{ env.APP_VERSION }}"
|
||||||
|
|
||||||
# Ensure project directory exists
|
# Kirim file .env ke server
|
||||||
- name: reload server
|
- name: Upload .env to server
|
||||||
|
uses: appleboy/scp-action@master
|
||||||
|
with:
|
||||||
|
host: ${{ secrets.VPS_HOST }}
|
||||||
|
username: ${{ secrets.VPS_USERNAME }}
|
||||||
|
key: ${{ secrets.VPS_SSH_KEY }}
|
||||||
|
source: ".env"
|
||||||
|
target: "/var/www/projects/${{ env.APP_NAME }}/releases/${{ env.APP_VERSION }}/"
|
||||||
|
|
||||||
|
# manage deployment
|
||||||
|
- name: manage deployment
|
||||||
uses: appleboy/ssh-action@master
|
uses: appleboy/ssh-action@master
|
||||||
with:
|
with:
|
||||||
host: ${{ secrets.VPS_HOST }}
|
host: ${{ secrets.VPS_HOST }}
|
||||||
@@ -138,23 +148,33 @@ jobs:
|
|||||||
# Install PM2 if not already installed
|
# Install PM2 if not already installed
|
||||||
if ! command -v pm2 &> /dev/null; then
|
if ! command -v pm2 &> /dev/null; then
|
||||||
echo "PM2 is not installed. Installing now..."
|
echo "PM2 is not installed. Installing now..."
|
||||||
npm install -g pm2
|
bun install --global pm2
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Install dotenv-cli if not already installed
|
||||||
|
if ! command -v dotenv &> /dev/null; then
|
||||||
|
echo "dotenv-cli is not installed. Installing now..."
|
||||||
|
bun install --global dotenv-cli
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Find an available port
|
# Find an available port
|
||||||
PORT=$(curl -s -X GET https://wibu-bot.wibudev.com/api/find-port | jq -r '.[0]')
|
PORT=$(curl -s -X GET https://wibu-bot.wibudev.com/api/find-port | jq -r '.[0]')
|
||||||
|
if [ -z "$PORT" ] || ! [[ "$PORT" =~ ^[0-9]+$ ]]; then
|
||||||
|
echo "Invalid or missing port from API."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
# Deploy to VPS
|
# Deploy to VPS
|
||||||
cd /var/www/projects/${{ env.APP_NAME }}/releases/${{ env.APP_VERSION }}
|
cd /var/www/projects/${{ env.APP_NAME }}/releases/${{ env.APP_VERSION }}
|
||||||
|
|
||||||
# Set environment variables
|
# Set environment variables
|
||||||
echo "DATABASE_URL=postgresql://${{ secrets.POSTGRES_USER }}:${{ secrets.POSTGRES_PASSWORD }}@localhost:5433/${{ secrets.POSTGRES_DB }}?schema=public" >> .env
|
dotenv set DATABASE_URL="postgresql://${{ secrets.POSTGRES_USER }}:${{ secrets.POSTGRES_PASSWORD }}@localhost:5433/${{ secrets.POSTGRES_DB }}?schema=public"
|
||||||
echo "PORT=$PORT" >> .env
|
dotenv set PORT="$PORT"
|
||||||
echo "NEXT_PUBLIC_WIBU_URL=localhost:$PORT" >> .env
|
dotenv set NEXT_PUBLIC_WIBU_URL="localhost:$PORT"
|
||||||
echo "WIBU_UPLOAD_DIR=/uploads" >> .env
|
dotenv set WIBU_UPLOAD_DIR="/var/www/projects/${{ env.APP_NAME }}/uploads"
|
||||||
|
|
||||||
# Create uploads directory
|
# Create uploads directory
|
||||||
mkdir -p /uploads
|
mkdir -p /var/www/projects/${{ env.APP_NAME }}/uploads
|
||||||
|
|
||||||
# Install dependencies
|
# Install dependencies
|
||||||
bun install --production
|
bun install --production
|
||||||
@@ -169,7 +189,7 @@ jobs:
|
|||||||
bun prisma db seed || echo "tidak membutuhkan seed"
|
bun prisma db seed || echo "tidak membutuhkan seed"
|
||||||
|
|
||||||
# Restart the application
|
# Restart the application
|
||||||
pm2 reload ${{ env.APP_NAME }} || pm2 start "bun run start --port $PORT" --name "${{ env.APP_NAME }}" --namespace ${{ env.APP_NAME }}
|
pm2 reload ${{ env.APP_NAME }} || pm2 start "bun run start --port $PORT" --name "${{ env.APP_NAME }}-$PORT" --namespace "${{ env.APP_NAME }}"
|
||||||
|
|
||||||
# Step 4: Set BUILD_STATUS based on success or failure
|
# Step 4: Set BUILD_STATUS based on success or failure
|
||||||
- name: Set BUILD_STATUS
|
- name: Set BUILD_STATUS
|
||||||
|
|||||||
Reference in New Issue
Block a user