Files
oma-memorial/.gitea/workflows/deploy.yml
T
denshooter 034ba854b5 feat: admin categorized display, improved CI/CD pipeline
- Admin: User timeline contributions shown in Timeline section
- Admin: User memory contributions shown in Erinnerungen section
- Admin: User photo uploads shown in Familien-Uploads section
- All contributions still appear in unified Beiträge section
- Dockerfile: fix data dir path (/data -> /app/data)
- CI/CD: use checkout@v4, retry health check, auto-create proxy network
- CI/CD: support SITE_PASSWORD/ADMIN_PASSWORD secrets
- CI/CD: use wget instead of curl (alpine compat)

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
2026-02-18 13:04:20 +01:00

62 lines
1.7 KiB
YAML

name: Build and Deploy
on:
push:
branches:
- main
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Create proxy network if needed
run: docker network create proxy || true
- name: Build Docker image
run: docker build -t oma-memorial:latest .
- name: Stop and remove old container
run: |
docker stop oma-memorial 2>/dev/null || true
docker rm oma-memorial 2>/dev/null || true
- name: Ensure data directory exists
run: mkdir -p ${{ gitea.workspace }}/data
- name: Run container in proxy network
run: |
docker run -d \
--name oma-memorial \
--network proxy \
--restart unless-stopped \
-e NODE_ENV=production \
-e SITE_PASSWORD="${{ secrets.SITE_PASSWORD }}" \
-e ADMIN_PASSWORD="${{ secrets.ADMIN_PASSWORD }}" \
-v ${{ gitea.workspace }}/data:/app/data \
oma-memorial:latest
- name: Health check
run: |
echo "Waiting for container to start..."
for i in $(seq 1 15); do
if docker exec oma-memorial wget -q --spider http://localhost:3000 2>/dev/null; then
echo "Container is healthy!"
exit 0
fi
echo "Attempt $i/15..."
sleep 2
done
echo "Health check failed"
docker logs oma-memorial --tail 30
exit 1
- name: Show container status
if: always()
run: |
docker ps --filter name=oma-memorial
docker logs oma-memorial --tail 20