Initial commit: Lageplan v1.0 - Next.js 15.5, React 19

This commit is contained in:
Pepe Ziberi
2026-02-21 11:57:44 +01:00
commit adf3dc8c1d
167 changed files with 34265 additions and 0 deletions

111
deploy/README.md Normal file
View File

@@ -0,0 +1,111 @@
# Lageplan — Portainer Deployment
## Architektur
```
Browser → :3000 (Web App) → intern: db:5432, minio:9000
```
Nur **ein Port (3000)** muss exponiert werden. DB und MinIO laufen rein intern im Docker-Netzwerk. Icons werden über die Web-App gestreamt — kein direkter MinIO-Zugriff nötig.
---
## Dateien
| Datei | Beschreibung |
|-------|-------------|
| `lageplan-web-v1.0.0.tar` | Docker Image (~92 MB) |
| `portainer-stack.yml` | Stack YAML für Portainer |
| `.env.example` | Environment Variables Vorlage |
---
## Schritt 1: Image auf Server laden
```bash
# Kopieren
scp lageplan-web-v1.0.0.tar user@server:/tmp/
# Auf dem Server laden
docker load -i /tmp/lageplan-web-v1.0.0.tar
# Prüfen
docker images | grep lageplan
```
---
## Schritt 2: Stack in Portainer erstellen
1. **Portainer**`Stacks``+ Add stack`
2. **Name**: `lageplan`
3. **Web editor**: Inhalt von `portainer-stack.yml` einfügen
4. **Environment variables** setzen:
| Variable | Wert |
|----------|------|
| `POSTGRES_USER` | `lageplan` |
| `POSTGRES_PASSWORD` | *(sicheres Passwort)* |
| `POSTGRES_DB` | `lageplan` |
| `MINIO_ROOT_USER` | `minioadmin` |
| `MINIO_ROOT_PASSWORD` | *(sicheres Passwort)* |
| `MINIO_BUCKET` | `lageplan-icons` |
| `WEB_PORT` | `3000` |
| `NEXTAUTH_URL` | `http://SERVER_IP:3000` |
| `NEXTAUTH_SECRET` | *(langer zufälliger String)* |
> **Tipp**: Secret generieren: `openssl rand -base64 32`
5. **Deploy the stack**
---
## Schritt 3: Datenbank initialisieren (einmalig)
In Portainer: Container `web` → Console → `/bin/sh`:
```bash
npx prisma db push
npx prisma db seed
```
Oder per SSH:
```bash
docker exec -it lageplan-web-1 npx prisma db push
docker exec -it lageplan-web-1 npx prisma db seed
```
---
## Schritt 4: Zugriff
- **Web App**: `http://SERVER_IP:3000`
- **Login**: `admin@lageplan.local` / `admin123`
---
## Update
```bash
# Lokal: neues Image bauen + exportieren
docker compose build web
docker tag lageplan-web:latest lageplan-web:v1.1.0
docker save lageplan-web:v1.1.0 -o deploy/lageplan-web-v1.1.0.tar
# Server: laden
docker load -i lageplan-web-v1.1.0.tar
# Portainer: Stack → Editor → Image-Tag ändern → Update the stack
```
---
## Ports
| Service | Port | Extern? |
|---------|------|---------|
| Web App | 3000 | ✅ Ja (`WEB_PORT`) |
| PostgreSQL | 5432 | ❌ Nur intern |
| MinIO API | 9000 | ❌ Nur intern |
| MinIO Console | 9001 | ❌ Nur intern |

View File

@@ -0,0 +1,97 @@
# =============================================================
# Lageplan - Portainer Stack
# =============================================================
# Deployment:
# 1. Image auf Server laden: docker load -i lageplan-web-v1.0.0.tar
# 2. In Portainer: Stacks → Add Stack → Web editor
# 3. Diese YAML einfügen + Environment Variables setzen
# =============================================================
services:
# --- PostgreSQL Database ---
db:
image: postgres:16-alpine
restart: unless-stopped
environment:
POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
POSTGRES_DB: ${POSTGRES_DB}
volumes:
- postgres_data:/var/lib/postgresql/data
networks:
- lageplan-net
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER}"]
interval: 10s
timeout: 5s
retries: 5
# --- MinIO Object Storage (S3-kompatibel, für Symbole/Icons) ---
# Kein externer Port nötig — Icons werden über die Web-App gestreamt
minio:
image: minio/minio:latest
restart: unless-stopped
command: server /data --console-address ":9001"
environment:
MINIO_ROOT_USER: ${MINIO_ROOT_USER}
MINIO_ROOT_PASSWORD: ${MINIO_ROOT_PASSWORD}
volumes:
- minio_data:/data
networks:
- lageplan-net
healthcheck:
test: ["CMD", "mc", "ready", "local"]
interval: 10s
timeout: 5s
retries: 5
# --- MinIO Bucket Initialisierung (einmalig) ---
minio-init:
image: minio/mc:latest
depends_on:
minio:
condition: service_healthy
networks:
- lageplan-net
entrypoint: >
/bin/sh -c "
mc alias set myminio http://minio:9000 ${MINIO_ROOT_USER} ${MINIO_ROOT_PASSWORD};
mc mb myminio/${MINIO_BUCKET} --ignore-existing;
mc anonymous set download myminio/${MINIO_BUCKET};
echo 'Bucket ready';
exit 0;
"
# --- Lageplan Web App (Next.js) ---
web:
image: lageplan-web:v1.0.0
restart: unless-stopped
environment:
DATABASE_URL: postgresql://${POSTGRES_USER}:${POSTGRES_PASSWORD}@db:5432/${POSTGRES_DB}
NEXTAUTH_URL: ${NEXTAUTH_URL}
NEXTAUTH_SECRET: ${NEXTAUTH_SECRET}
MINIO_ENDPOINT: minio
MINIO_PORT: "9000"
MINIO_ACCESS_KEY: ${MINIO_ROOT_USER}
MINIO_SECRET_KEY: ${MINIO_ROOT_PASSWORD}
MINIO_BUCKET: ${MINIO_BUCKET}
MINIO_USE_SSL: "false"
ports:
- "${WEB_PORT:-3000}:3000"
depends_on:
db:
condition: service_healthy
minio:
condition: service_healthy
networks:
- lageplan-net
volumes:
postgres_data:
driver: local
minio_data:
driver: local
networks:
lageplan-net:
driver: bridge

9
deploy/portainer.env Normal file
View File

@@ -0,0 +1,9 @@
POSTGRES_USER=lageplan
POSTGRES_PASSWORD=HIER_SICHERES_PASSWORT_SETZEN
POSTGRES_DB=lageplan
MINIO_ROOT_USER=minioadmin
MINIO_ROOT_PASSWORD=HIER_SICHERES_PASSWORT_SETZEN
MINIO_BUCKET=lageplan-icons
WEB_PORT=3000
NEXTAUTH_URL=http://SERVER_IP:3000
NEXTAUTH_SECRET=HIER_LANGEN_ZUFAELLIGEN_STRING_GENERIEREN