@cosmicdrift/kumiko-dev-server 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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,84 @@
1
1
  # @cosmicdrift/kumiko-dev-server
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-bundled-features@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-bundled-features@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-dev-server",
3
- "version": "0.5.2",
3
+ "version": "0.7.0",
4
4
  "description": "Development server bootstrap for Kumiko apps. Bundles the client, mints dev-JWTs, injects the resolved AppSchema, and seeds an admin. Not for production.",
5
5
  "license": "BUSL-1.1",
6
6
  "author": "Marc Frost <marc@cosmicdriftgamestudio.com>",
@@ -48,8 +48,8 @@
48
48
  "kumiko-dev": "./bin/kumiko-dev.ts"
49
49
  },
50
50
  "dependencies": {
51
- "@cosmicdrift/kumiko-bundled-features": "0.5.2",
52
- "@cosmicdrift/kumiko-framework": "0.5.2"
51
+ "@cosmicdrift/kumiko-bundled-features": "0.7.0",
52
+ "@cosmicdrift/kumiko-framework": "0.7.0"
53
53
  },
54
54
  "publishConfig": {
55
55
  "registry": "https://registry.npmjs.org",
@@ -633,6 +633,7 @@ export async function runProdApp(options: RunProdAppOptions): Promise<ProdAppHan
633
633
  db,
634
634
  seedsDir: options.seedsDir,
635
635
  appliedBy: "boot",
636
+ registry, // → dry-run-validator catched handler-QN-typos vor dem write
636
637
  createContext: (dbRunner: DbRunner) =>
637
638
  createSeedMigrationContext({ dispatcher: seedDispatcher, dbRunner }),
638
639
  });