Claude
|
a8d07ba2ab
|
Makefile: lokale Dev-/DB-Ziele (build, migrate, seed, setup) ergänzen
- docker-compose.dev.yml: veröffentlicht Postgres-Port 5432 für Host-läufige
Migrationen/Seeds (Produktiv-Postgres bleibt app-intern).
- Makefile: help-Default + Ziele install/dev/build-app/lint/typecheck/test,
db-up/db-wait/migrate/seed/seed-auth/seed-all/generate/db-check/studio/db-reset,
one-shot 'setup', E2E-Ziele; bestehende Deploy-Ziele (build/up/deploy/data) erhalten.
'make build-app migrate' bzw. 'make setup' decken den gewünschten Build+Migrate-Flow ab.
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
|
2026-06-09 15:18:13 +02:00 |
|
Matthias Hochmeister
|
d50ec765ab
|
Workstream 10: Deployment (Docker + externes Traefik) (Phase 7)
Liefert das reproduzierbare Compose-Setup hinter EXTERNEM Traefik:
- Dockerfile (multi-stage deps/builder/runner, Next.js standalone, non-root
UID/GID 1001, HEALTHCHECK gegen /api/health).
- docker/entrypoint.sh: wartet via pg_isready auf Postgres, wendet Migrationen
idempotent an (docker/migrate.mjs, plain ESM ohne tsx/drizzle-kit), optionaler
Seed (RUN_SEED), dann exec node server.js.
- docker-compose.yml: genau vier Services (app, postgres, osrm, nominatim),
KEIN Proxy-Service; externes traefik-Netz + internes Netz; Traefik-Labels
(Host, websecure, tls.certresolver, Security-Header-Middleware);
Postgres-/App-Healthchecks; AUTH_URL/AUTH_TRUST_HOST/Forwarded-Header.
- docker-compose.override.yml.example: lokal :3000 ohne TLS (http AUTH_URL).
- .dockerignore, Makefile (build/up/down/logs/deploy/data/config).
- .env.example: voller Vertrag inkl. APP_HOST, TRAEFIK_*, POSTGRES_*, RUN_SEED.
- docs/reference/deployment-traefik.md: externes Netz, Authentik-Redirect-URI
https://${APP_HOST}/api/auth/callback/authentik, Forwarded-Header/Cookies,
/api/health-Allowlist.
- tests/unit/deployment.test.ts (TDD): statische Offline-Verifikation der
Artefakte; vitest.config.ts nimmt tests/unit/** auf.
Offline verifiziert: tsc --noEmit sauber; vitest run grün (200 passed,
7 db-roundtrip skipped); next build erzeugt .next/standalone/server.js;
sh -n docker/entrypoint.sh ok; make -n deploy zeigt build->up.
Deferred (kein Docker/Postgres in der Sandbox): docker build/run id -u=1001,
docker compose config --services, /api/health anonym 200, End-to-End Traefik.
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
|
2026-06-09 12:35:45 +02:00 |
|