40 lines
1.1 KiB
YAML
40 lines
1.1 KiB
YAML
name: Deploy to NAS
|
|
|
|
on:
|
|
push:
|
|
branches: [main]
|
|
|
|
jobs:
|
|
deploy:
|
|
runs-on: self-hosted
|
|
container:
|
|
image: docker:latest
|
|
options: -v /volume2/docker:/volume2/docker
|
|
|
|
steps:
|
|
- name: Pull code
|
|
run: |
|
|
if [ -d "${{ vars.DEPLOY_DIR }}/.git" ]; then
|
|
git -C ${{ vars.DEPLOY_DIR }} fetch origin main
|
|
git -C ${{ vars.DEPLOY_DIR }} reset --hard origin/main
|
|
git -C ${{ vars.DEPLOY_DIR }} clean -fd
|
|
else
|
|
git clone http://192.168.1.4:3000/christoph/pamietnik.git ${{ vars.DEPLOY_DIR }}
|
|
fi
|
|
|
|
- name: Write .env
|
|
run: |
|
|
printf 'DB_PASSWORD=%s\nADMIN_USER=%s\nADMIN_PASSWORD=%s\n' \
|
|
'${{ secrets.DB_PASSWORD }}' \
|
|
'${{ vars.ADMIN_USER }}' \
|
|
'${{ secrets.ADMIN_PASSWORD }}' \
|
|
> ${{ vars.DEPLOY_DIR }}/.env
|
|
|
|
- name: Build & Deploy
|
|
run: docker compose -f ${{ vars.DEPLOY_DIR }}/docker-compose.yml up --build -d
|
|
|
|
- name: Health check
|
|
run: |
|
|
sleep 15
|
|
wget -qO- http://192.168.1.4:9050/healthz || exit 1
|