P6.6: legacy:grandfather-subscriptions — aktive Legacy-Abos aus dem Rechnungsarchiv migrieren
Kriterien vom Auftraggeber (12.06.2026): Quelle der Aktiv-Erkennung ist
ausschliesslich das read-only Rechnungsarchiv legacy_invoices (D-12).
Legacy-Rechnungen bleiben Archiv; neue manuelle Rechnungen entstehen im
MAN-Rechnungskreis.
- Aktiv-Regel: juengste Rechnung pro (Portal, Legacy-Vereinbarung) mit
payment_option.type=recurring und user_payment_option.status=active;
next_due_date max. --grace-months (Default 12) ueberfaellig, sonst
stale -> bleibt reines Archiv. Einmal-Kaeufe werden nie uebernommen.
- Uebernahme als grandfathered in user_payment_options:
current_period_end = next_due_date, Betraege/Intervall der letzten
Legacy-Rechnung in legacy_conditions -> der taegliche MAN-Lauf
(billing:generate-manual-invoices) fakturiert zum gewohnten
jaehrlichen Rhythmus weiter. Versteckte Katalog-Platzhalter
LEGACY-{PE|BP}-{Artikel} in payment_options.
- Replay-faehig (D-18): Re-Runs aktualisieren anhand der Legacy-IDs in
legacy_conditions statt zu duplizieren — die Kern-Migration laeuft
kurz vor dem Relaunch erneut.
- Optionen: --dry-run, --as-of, --grace-months, --no-report; JSON-Report
nach storage/app/migration/. Dry-Run gegen Test-Snapshot: 22 aktive
jaehrliche Vereinbarungen, davon 4 sofort faellig, 0 stale.
- Doku: MIGRATION-STEPS.md (Runbook-Reihenfolge nach archive-invoices),
05-DATABASE-MERGE §5.6, 12-NAECHSTE-SCHRITTE 6.6, 08-PROGRESS,
PHASE-9-Plan + Checkliste.
Tests: GrandfatherLegacySubscriptionsTest (7, inkl. End-to-End
Migration -> MAN-Rechnung mit Legacy-Betraegen). Suite: 475 passed,
4 skipped. Pint clean.
Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
This commit is contained in:
parent
d548f4b235
commit
1cd4d8e33a
8 changed files with 526 additions and 12 deletions
|
|
@ -164,11 +164,15 @@ ist hybrid mit zwei getrennten Rechnungskreisen (plus Altbestand):
|
|||
- **`User::hasActiveBooking()`** prüft jetzt echt (hinter
|
||||
`billing.enforce_booking`): Cashier-Abo ∨ bezahlter Einzel-/Extra-PM-Kauf
|
||||
∨ aktive/grandfathered Legacy-Vereinbarung (MAN-Kreis).
|
||||
- **Legacy-Migration (12.06.)**: `legacy:grandfather-subscriptions` leitet
|
||||
die aktiven, jährlich wiederkehrenden Vereinbarungen aus dem
|
||||
Rechnungsarchiv ab und schreibt sie als `grandfathered` in
|
||||
`user_payment_options` (Replay-fähig — die Kern-Migration läuft kurz
|
||||
vor dem Relaunch erneut). Details:
|
||||
`dev/migration 2026/05-DATABASE-MERGE.md` §5.6 + `MIGRATION-STEPS.md`.
|
||||
- **Noch offen in 9D** (folgt mit 9E, braucht Checkout/Webhooks):
|
||||
Slot-Logik von `users.press_release_quota`-Stub auf Plan-Kontingent +
|
||||
Periodenzähler umstellen und Stub-Spalten entfernen. Voraussetzung:
|
||||
Die aktiven Legacy-Zahlungen müssen noch in `user_payment_options`
|
||||
migriert werden (Tabelle ist aktuell leer — eigener Migrations-Schritt).
|
||||
Periodenzähler umstellen und Stub-Spalten entfernen.
|
||||
|
||||
### 9E · Stripe (Laravel Cashier)
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue