66 lines
2.1 KiB
YAML
66 lines
2.1 KiB
YAML
name: Frontend Build and Deploy
|
|
|
|
on:
|
|
workflow_dispatch: {}
|
|
|
|
env:
|
|
REGISTRY_HOST: git.ivanch.me
|
|
IMAGE_FRONTEND: ${{ env.REGISTRY_HOST }}/ivanch/opencand.ui
|
|
# ───────────────────────────────────────────────────────────────────────────
|
|
DEPLOY_USER: ${{ secrets.LIVE_HOST }}
|
|
DEPLOY_HOST: ${{ secrets.LIVE_USERNAME }}
|
|
DEPLOY_PATH: ${{ secrets.LIVE_PROJECT_DIR }}
|
|
|
|
jobs:
|
|
build_and_deploy:
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
- name: Check out repository
|
|
uses: actions/checkout@v2
|
|
|
|
- name: Log in to Container Registry
|
|
run: |
|
|
echo "${{ secrets.REGISTRY_PASSWORD }}" \
|
|
| docker login "${{ env.REGISTRY_HOST }}" \
|
|
-u "${{ secrets.REGISTRY_USERNAME }}" \
|
|
--password-stdin
|
|
|
|
- name: Build and Push Frontend Image
|
|
run: |
|
|
TAG=latest
|
|
|
|
docker build \
|
|
--build-arg VITE_API_BASE_URL="http://api.opencand.ivanch.me" \
|
|
--file OpenCand.UI.dockerfile \
|
|
-t "${{ env.IMAGE_FRONTEND }}:${TAG}" \
|
|
.
|
|
|
|
docker push "${{ env.IMAGE_FRONTEND }}:${TAG}"
|
|
|
|
- name: Set up SSH
|
|
run: |
|
|
mkdir -p ~/.ssh
|
|
echo "${{ secrets.LIVE_KEY }}" > ~/.ssh/id_rsa
|
|
chmod 600 ~/.ssh/id_rsa
|
|
|
|
# Add the host to known_hosts so SSH does not prompt
|
|
ssh-keyscan -H "${{ env.DEPLOY_HOST }}" >> ~/.ssh/known_hosts
|
|
|
|
- name: Deploy to Production Server
|
|
run: |
|
|
TAG=latest
|
|
|
|
ssh "${{ env.DEPLOY_USER }}@${{ env.DEPLOY_HOST }}" << 'EOF'
|
|
cd "${{ env.DEPLOY_PATH }}"
|
|
|
|
# Replace the “image:” line for the frontend service
|
|
# sed -i \
|
|
# "s|image: .*/frontend:.*|image: ${{ env.IMAGE_FRONTEND }}:${TAG}|g" \
|
|
# docker-compose.yml
|
|
|
|
# Pull only the new frontend image, then restart that service
|
|
docker-compose pull frontend
|
|
docker-compose up -d frontend
|
|
EOF
|