@cosmicdrift/kumiko-renderer 0.5.2 → 0.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/CHANGELOG.md +79 -0
  2. package/package.json +3 -3
package/CHANGELOG.md CHANGED
@@ -1,5 +1,84 @@
1
1
  # @cosmicdrift/kumiko-renderer
2
2
 
3
+ ## 0.7.0
4
+
5
+ ### Minor Changes
6
+
7
+ - bcf43b6: es-ops: `SeedMembershipRow` exposes `streamTenantId` (stream-tenant aus `kumiko_events.v1`) neben dem payload-`tenantId`. Seed-Authors müssen den `kumiko_events`-JOIN nicht mehr selbst bauen — `m.streamTenantId` ist der korrekte Wert für `systemWriteAs`'s `tenantIdOverride` wenn das Aggregate von einem fremden Executor angelegt wurde (typisches `seedTenantMembership(by=systemAdmin)`-Pattern).
8
+
9
+ ### Patch Changes
10
+
11
+ - Updated dependencies [bcf43b6]
12
+ - @cosmicdrift/kumiko-framework@0.7.0
13
+ - @cosmicdrift/kumiko-headless@0.7.0
14
+
15
+ ## 0.6.0
16
+
17
+ ### Minor Changes
18
+
19
+ - 8489d18: feat(es-ops): Phase 1.5 — tenantIdOverride + dry-run-validator + E2E-Test + Doku
20
+
21
+ Phase 1.5 schließt die Lücken aus Phase 1 die den ersten Driver-Use-Case
22
+ (publicstatus admin-roles) blockten. Siehe Retro:
23
+ `kumiko-platform/docs/plans/features/es-ops-phase1-retro.md` (PR #9).
24
+
25
+ **A1 — tenantIdOverride:**
26
+ `SeedMigrationContext.systemWriteAs(qn, payload, tenantIdOverride?)`.
27
+ Default SYSTEM_TENANT_ID (unverändert für System-scope-Aggregates wie
28
+ config-values). Mit override: `createSystemUser(tenantIdOverride)` als
29
+ Executor, damit der Event-Store-Executor den Aggregate-Stream im
30
+ richtigen Tenant findet. Fix für die `version_conflict`-Klasse-Bug
31
+ (Memory `feedback_event_store_tenant_consistency.md`).
32
+
33
+ **A2 — dry-run-validator:**
34
+ Runner parsed seed-files vor `migration.run()` per regex
35
+ `systemWriteAs\(["']([^"']+)["']`, sammelt handler-QNs, validiert
36
+ gegen `registry.getWriteHandler(qn)`. Fail-fast mit klarer Message
37
+
38
+ - Datei + QN statt zur Runtime "handler not found". Catched camelCase-
39
+ typos (kebab-case-vs-camelCase Drift) + andere QN-Drift zur Boot-Zeit.
40
+ runProdApp reicht den richtigen Registry rein (`registry` neu in
41
+ RunPendingSeedMigrationsArgs).
42
+
43
+ **A3 — E2E-Test:**
44
+ `packages/bundled-features/src/__tests__/es-ops-e2e.integration.ts`
45
+ mit `setupTestStack`-Pattern: tenant+config Features echt geladen,
46
+ echtes Membership-Aggregate via TenantHandlers.addMember im Demo-Tenant,
47
+ seed-migration ruft update-member-roles mit tenantIdOverride → write
48
+ geht durch, Marker landed, Event in Store, Read-Model aktualisiert.
49
+ Plus typo-Test: seed mit camelCase fail-t Dry-Run mit
50
+ `/dry-run found.*unknown handler-QN/`. **TDD-First**: ohne A1+A2 wäre
51
+ der test rot.
52
+
53
+ **A4 — Doku:**
54
+ `framework/src/es-ops/README.md` erweitert um „Wann brauche ich
55
+ tenantIdOverride?" + „Deployment-Anforderungen" (Docker COPY, Idempotenz,
56
+ Multi-Replica) + „Lokaler Smoke vor Push". Recipe-README + seed-files
57
+ auf neue API aktualisiert.
58
+
59
+ **A5 — Smoke-Skript-Template:**
60
+ `samples/recipes/seed-migration/scripts/smoke.ts` als copy-paste-Template
61
+ für App-Authors: Bun-runnable, offline (read-only, kein DB-Write),
62
+ validiert Module-Load + QN-Resolution + System-User-Access. Recipe-
63
+ README dokumentiert Pflicht-Pattern.
64
+
65
+ **Bonus-Fix:**
66
+ `tenant:write:create`-access auf `["system", "SystemAdmin"]` erweitert
67
+ (symmetrisch zu update-member-roles). Aufgedeckt durch Recipe-Smoke +
68
+ initial-tenants-Seed. Pinning-Test in `tenant.integration.ts` updated.
69
+
70
+ **Test-State:** 45/45 grün (Pre-Push). Typecheck clean. Biome clean.
71
+ as-cast-Audit clean. Guard-silent-skip clean. Recipe-Smoke clean.
72
+
73
+ **Folge-Step (separater PR):** publicstatus driver-sample reaktivieren
74
+ mit lokalem Pre-Push-Smoke gegen publicstatus' echtes Feature-Set.
75
+
76
+ ### Patch Changes
77
+
78
+ - Updated dependencies [8489d18]
79
+ - @cosmicdrift/kumiko-framework@0.6.0
80
+ - @cosmicdrift/kumiko-headless@0.6.0
81
+
3
82
  ## 0.5.2
4
83
 
5
84
  ### Patch Changes
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cosmicdrift/kumiko-renderer",
3
- "version": "0.5.2",
3
+ "version": "0.7.0",
4
4
  "description": "Platform-agnostic React renderer for Kumiko screens. Contains the shared logic — primitives-contract, hooks, KumikoScreen, navigation & SSE abstractions — that any platform-specific renderer (web, native) composes. No DOM, no EventSource, no react-dom.",
5
5
  "license": "BUSL-1.1",
6
6
  "author": "Marc Frost <marc@cosmicdriftgamestudio.com>",
@@ -15,8 +15,8 @@
15
15
  }
16
16
  },
17
17
  "dependencies": {
18
- "@cosmicdrift/kumiko-framework": "0.5.2",
19
- "@cosmicdrift/kumiko-headless": "0.5.2",
18
+ "@cosmicdrift/kumiko-framework": "0.7.0",
19
+ "@cosmicdrift/kumiko-headless": "0.7.0",
20
20
  "react": "^19.2.6"
21
21
  },
22
22
  "devDependencies": {