* chore(MP-21): snapshot pre-refactor state (Epic 1) * chore(MP-22): scaffold new repo structure, relocate Docker Compose, move frontend/backend modules, update Makefile; add docs mapping and env template * MP-22 Epic 2: Erfolgreich umgesetzt und verifiziert * MP-23 Epic 3: Gradle/Build Governance zentralisieren
3.6 KiB
Repository-Architektur (MP-22)
Dieses Dokument beschreibt die Zielstruktur und das Mapping vom bisherigen Stand (Ist) zur neuen Struktur (Soll). Es begleitet Epic 2 (MP-22).
Zielstruktur (Top-Level)
backend/ Gateway, Discovery (optional), Services gateway discovery services frontend/ KMP Frontend shells Ausführbare Apps (Assembler) features Vertical Slices (kein Feature→Feature) core Shared Foundation (Design-System, Network, Local-DB, Auth, Domain) docker/ Docker Compose, .env.example, Monitoring-/Core-Konfiguration docs/ Architektur, ADRs, C4-Modelle, Guides
Ist → Soll Mapping (erste Tranche)
-
Frontend
- clients/app → frontend/shells/meldestelle-portal (verschieben in Folge-Commit)
- clients/shared/common-ui → frontend/core/design-system (verschieben in Folge-Commit)
- clients/shared/navigation → frontend/core/navigation (verschieben in Folge-Commit)
-
Backend
- infrastructure/gateway → backend/gateway (verschieben in Folge-Commit)
- services/* → backend/services/* (verschieben in Folge-Commit)
- Discovery (falls genutzt) → backend/discovery
-
Docker
- compose.yaml → docker/docker-compose.yml (neu angelegt, Makefile angepasst)
- .env Handling → docker/.env.example (neu, als Template)
Build/Gradle
- settings.gradle.kts bleibt vorerst unverändert. Modul-Verschiebungen folgen in einem separaten Schritt mit angepassten include-Pfaden.
- Version Catalog (gradle/libs.versions.toml) bleibt die einzige Quelle der Versionswahrheit.
Richtlinien (Kurzfassung)
- Features kommunizieren ausschließlich über Routen (Navigation) und Shared-Modelle in frontend/core/domain.
- Kein manueller Authorization-Header – nur der DI-verwaltete apiClient aus frontend/core/network (Koin Named Binding).
- SQLDelight als Offline-SSoT: Schema/Migrationen zentral versionieren, UI liest stets lokal und synchronisiert im Hintergrund.
DI-Policy & Architecture Guards (MP-23)
-
DI-Policy (Frontend)
- Http‑Requests erfolgen ausschließlich über den via Koin bereitgestellten
apiClient(named Binding) aus:frontend:core:network. - Manuelles Setzen des
Authorization‑Headers ist verboten. Token‑Handling wird zentral imapiClientkonfiguriert (Auth‑Plugin/Interceptor). - Basis‑URL wird plattformspezifisch aufgelöst:
- JVM/Desktop: Env
API_BASE_URL(Fallbackhttp://localhost:8081). - Web/JS:
globalThis.API_BASE_URL(z. B. perindex.htmloder Proxy), sonstwindow.location.origin, Fallbackhttp://localhost:8081.
- JVM/Desktop: Env
- Http‑Requests erfolgen ausschließlich über den via Koin bereitgestellten
-
Architecture Guards (Frontend‑Scope)
- Root‑Task
archGuardsbricht den Build ab, wenn verbotene Muster gefunden werden (manuelleAuthorization‑Header). Tests sind ausgenommen; Backend ist ausgenommen. - Statische Analyse verfügbar über
detektundktlintCheck; AggregatorstaticAnalysisführt alles zusammen.
- Root‑Task
-
Hinweise für Features
- Features importieren keine anderen Features (Kommunikation über Navigation + Shared‑Domain‑Modelle). Eine explizite Detekt‑Regel folgt.
- Netzwerkzugriffe in Features nutzen Koin über die App‑Shell (DI‑Bootstrap). Für schrittweise Migration kann eine Factory den
apiClientoptional beziehen.
Nächste Schritte (MP-22 Folgetasks)
- Physisches Verschieben der Frontend-Module gemäß Mapping und Anpassung von settings.gradle.kts.
- Physisches Verschieben der Backend-Komponenten in backend/* inkl. evtl. Package-Pfade, sofern notwendig.
- Ergänzung von docker-compose.services.yml und docker-compose.clients.yml mit echten Overlays.
- Erstellen der ersten ADRs unter docs/adr (Koin, SQLDelight, Optimistic Locking, Freshness UI, Core Domain).