@arch-cadre/modules 0.0.11 → 0.0.15

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.
@@ -1 +1 @@
1
- {"version":3,"file":"extension-point.mjs","names":[],"sources":["../../src/client/extension-point.tsx"],"sourcesContent":["import { getExtensions } from \"../server/ui\";\nimport * as React from \"react\";\n\ninterface ExtensionPointProps {\n module: string;\n point: string;\n className?: string;\n props?: any;\n fallback?: React.ReactNode;\n}\n\nexport async function ExtensionPoint({\n module,\n point,\n className,\n props,\n fallback,\n}: ExtensionPointProps) {\n const extensions = await getExtensions(module, point);\n\n if (extensions.length === 0) return fallback || null;\n\n return (\n <div className={className}>\n {extensions.map((ext) => {\n const Component = ext.component;\n return <Component key={ext.id} {...props} />;\n })}\n </div>\n );\n}\n"],"mappings":";;;;;AAWA,eAAsB,eAAe,EACnC,QACA,OACA,WACA,OACA,YACsB;CACtB,MAAM,aAAa,MAAM,cAAc,QAAQ,MAAM;AAErD,KAAI,WAAW,WAAW,EAAG,QAAO,YAAY;AAEhD,QACE,oBAAC;EAAe;YACb,WAAW,KAAK,QAAQ;GACvB,MAAM,YAAY,IAAI;AACtB,UAAO,oBAAC,aAAuB,GAAI,SAAZ,IAAI,GAAiB;IAC5C;GACE"}
1
+ {"version":3,"file":"extension-point.mjs","names":[],"sources":["../../src/client/extension-point.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { getExtensions } from \"../server/ui\";\n\ninterface ExtensionPointProps {\n module: string;\n point: string;\n className?: string;\n props?: any;\n fallback?: React.ReactNode;\n}\n\nexport async function ExtensionPoint({\n module,\n point,\n className,\n props,\n fallback,\n}: ExtensionPointProps) {\n const extensions = await getExtensions(module, point);\n\n if (extensions.length === 0) return fallback || null;\n\n return (\n <div className={className}>\n {extensions.map((ext) => {\n const Component = ext.component;\n return <Component key={ext.id} {...props} />;\n })}\n </div>\n );\n}\n"],"mappings":";;;;;AAWA,eAAsB,eAAe,EACnC,QACA,OACA,WACA,OACA,YACsB;CACtB,MAAM,aAAa,MAAM,cAAc,QAAQ,MAAM;AAErD,KAAI,WAAW,WAAW,EAAG,QAAO,YAAY;AAEhD,QACE,oBAAC;EAAe;YACb,WAAW,KAAK,QAAQ;GACvB,MAAM,YAAY,IAAI;AACtB,UAAO,oBAAC,aAAuB,GAAI,SAAZ,IAAI,GAAiB;IAC5C;GACE"}
@@ -3,8 +3,14 @@
3
3
  const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
4
4
  const require_manage = require('./manage.cjs');
5
5
  let _arch_cadre_core_server = require("@arch-cadre/core/server");
6
+ let node_fs_promises = require("node:fs/promises");
7
+ node_fs_promises = require_runtime.__toESM(node_fs_promises);
8
+ let node_path = require("node:path");
9
+ node_path = require_runtime.__toESM(node_path);
6
10
  let _arch_cadre_core = require("@arch-cadre/core");
7
11
  let drizzle_orm = require("drizzle-orm");
12
+ let node_child_process = require("node:child_process");
13
+ let node_util = require("node:util");
8
14
 
9
15
  //#region src/server/lifecycle.ts
10
16
  const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
@@ -13,18 +19,16 @@ async function updateStep(moduleId, step) {
13
19
  await _arch_cadre_core_server.db.update(_arch_cadre_core.systemModulesTable).set({ lastStep: step }).where((0, drizzle_orm.eq)(_arch_cadre_core.systemModulesTable.id, moduleId));
14
20
  }
15
21
  async function resolveSchemaPath(moduleId) {
16
- const path = await import("node:path");
17
- const fs = await import("node:fs/promises");
18
22
  const root = process.cwd();
19
23
  if (moduleId === "@arch-cadre/core" || moduleId === "core") {
20
- const p = path.join(root, "node_modules", "@kryo", "core", "dist", "server", "database", "schema.cjs");
24
+ const p = node_path.default.join(root, "node_modules", "@kryo", "core", "dist", "server", "database", "schema.cjs");
21
25
  try {
22
- await fs.access(p);
26
+ await node_fs_promises.default.access(p);
23
27
  return p;
24
28
  } catch {
25
- const devP = path.resolve(root, "../../packages/kryo-core/src/server/database/schema.ts");
29
+ const devP = node_path.default.resolve(root, "../../packages/kryo-core/src/server/database/schema.ts");
26
30
  try {
27
- await fs.access(devP);
31
+ await node_fs_promises.default.access(devP);
28
32
  return devP;
29
33
  } catch {}
30
34
  }
@@ -32,16 +36,18 @@ async function resolveSchemaPath(moduleId) {
32
36
  }
33
37
  const cleanId = moduleId.replace("@arch-cadre/", "");
34
38
  const possible = [
35
- path.join(root, "modules", cleanId, "schema.ts"),
36
- path.join(root, "modules", moduleId, "schema.ts"),
37
- path.join(root, "node_modules", moduleId, "dist", "schema.cjs"),
38
- path.join(root, "node_modules", `@arch-cadre/${cleanId}`, "dist", "schema.cjs"),
39
- path.resolve(root, "../../packages", cleanId, "src", "schema.ts"),
40
- path.resolve(root, "../../packages", `kryo-${cleanId}`, "src", "schema.ts"),
41
- path.resolve(root, "../../packages", cleanId, "schema.ts")
39
+ node_path.default.join(root, "modules", cleanId, "schema.ts"),
40
+ node_path.default.join(root, "modules", moduleId, "schema.ts"),
41
+ node_path.default.join(root, "node_modules", moduleId, "dist", "schema.cjs"),
42
+ node_path.default.join(root, "node_modules", `@arch-cadre/${cleanId}`, "dist", "schema.cjs"),
43
+ node_path.default.join(root, "node_modules", moduleId, "src", "schema.ts"),
44
+ node_path.default.join(root, "node_modules", `@arch-cadre/${cleanId}`, "src", "schema.ts"),
45
+ node_path.default.resolve(root, "../../packages", cleanId, "src", "schema.ts"),
46
+ node_path.default.resolve(root, "../../packages", `kryo-${cleanId}`, "src", "schema.ts"),
47
+ node_path.default.resolve(root, "../../packages", cleanId, "schema.ts")
42
48
  ];
43
49
  for (const p of possible) try {
44
- await fs.access(p);
50
+ await node_fs_promises.default.access(p);
45
51
  console.log(`[Kernel:Lifecycle] Resolved schema for ${moduleId} at: ${p}`);
46
52
  return p;
47
53
  } catch {}
@@ -49,10 +55,7 @@ async function resolveSchemaPath(moduleId) {
49
55
  return null;
50
56
  }
51
57
  async function pushModuleSchema(moduleId) {
52
- const { exec } = await import("node:child_process");
53
- const { promisify } = await import("node:util");
54
- const execAsync = promisify(exec);
55
- const path = await import("node:path");
58
+ const execAsync = (0, node_util.promisify)(node_child_process.exec);
56
59
  console.log(`[Kernel:Lifecycle] Targeted sync for module: ${moduleId}`);
57
60
  const root = process.cwd();
58
61
  const enabledFromDb = await _arch_cadre_core_server.db.select({ id: _arch_cadre_core.systemModulesTable.id }).from(_arch_cadre_core.systemModulesTable).where((0, drizzle_orm.eq)(_arch_cadre_core.systemModulesTable.enabled, true));
@@ -68,8 +71,8 @@ async function pushModuleSchema(moduleId) {
68
71
  console.warn(`[Kernel:Lifecycle] No schema paths resolved for ${moduleId}, skipping push.`);
69
72
  return;
70
73
  }
71
- const configPath = path.join(root, "drizzle.config.ts");
72
- const cmd = `"${path.join(root, "node_modules", ".bin", "drizzle-kit")}" push --force --config=${configPath}`;
74
+ const configPath = node_path.default.join(root, "drizzle.config.ts");
75
+ const cmd = `"${node_path.default.join(root, "node_modules", ".bin", "drizzle-kit")}" push --force --config=${configPath}`;
73
76
  console.log(`[Kernel:Lifecycle] Executing isolated migration. Modules: ${Array.from(activeModuleIds).join(", ")}`);
74
77
  try {
75
78
  await execAsync(cmd, {
@@ -89,9 +92,6 @@ async function pushModuleSchema(moduleId) {
89
92
  }
90
93
  async function performToggle(moduleId, isEnabled) {
91
94
  try {
92
- const { exec } = await import("node:child_process");
93
- const { promisify } = await import("node:util");
94
- promisify(exec);
95
95
  const allModules = await require_manage.getModules();
96
96
  const manifest = allModules.find((m) => m.id === moduleId);
97
97
  await updateStep(moduleId, "Validate module...");
@@ -124,6 +124,7 @@ async function performToggle(moduleId, isEnabled) {
124
124
  else await pushModuleSchema(moduleId);
125
125
  await updateStep(moduleId, "Migration successful");
126
126
  } catch (e) {
127
+ console.error(`[Kernel] Migration failed for ${moduleId}:`, e);
127
128
  await updateStep(moduleId, `Migration failed: ${e.message}`);
128
129
  await sleep(500);
129
130
  }
@@ -1 +1 @@
1
- {"version":3,"file":"lifecycle.d.cts","names":[],"sources":["../../src/server/lifecycle.ts"],"mappings":";iBAqFsB,gBAAA,CAAiB,QAAA,WAAgB,OAAA;AAAA,iBAsLjC,iBAAA,CAAkB,QAAA,UAAkB,SAAA,YAAkB,OAAA;;;iBAWtD,sBAAA,CAAA,GAAsB,OAAA"}
1
+ {"version":3,"file":"lifecycle.d.cts","names":[],"sources":["../../src/server/lifecycle.ts"],"mappings":";iBAuGsB,gBAAA,CAAiB,QAAA,WAAgB,OAAA;AAAA,iBAgLjC,iBAAA,CAAkB,QAAA,UAAkB,SAAA,YAAkB,OAAA;;;iBAWtD,sBAAA,CAAA,GAAsB,OAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"lifecycle.d.mts","names":[],"sources":["../../src/server/lifecycle.ts"],"mappings":";iBAqFsB,gBAAA,CAAiB,QAAA,WAAgB,OAAA;AAAA,iBAsLjC,iBAAA,CAAkB,QAAA,UAAkB,SAAA,YAAkB,OAAA;;;iBAWtD,sBAAA,CAAA,GAAsB,OAAA"}
1
+ {"version":3,"file":"lifecycle.d.mts","names":[],"sources":["../../src/server/lifecycle.ts"],"mappings":";iBAuGsB,gBAAA,CAAiB,QAAA,WAAgB,OAAA;AAAA,iBAgLjC,iBAAA,CAAkB,QAAA,UAAkB,SAAA,YAAkB,OAAA;;;iBAWtD,sBAAA,CAAA,GAAsB,OAAA"}
@@ -2,8 +2,12 @@
2
2
 
3
3
  import { getModuleInstance, getModules } from "./manage.mjs";
4
4
  import { db } from "@arch-cadre/core/server";
5
+ import fs from "node:fs/promises";
6
+ import path from "node:path";
5
7
  import { systemModulesTable } from "@arch-cadre/core";
6
8
  import { eq } from "drizzle-orm";
9
+ import { exec } from "node:child_process";
10
+ import { promisify } from "node:util";
7
11
 
8
12
  //#region src/server/lifecycle.ts
9
13
  const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
@@ -12,8 +16,6 @@ async function updateStep(moduleId, step) {
12
16
  await db.update(systemModulesTable).set({ lastStep: step }).where(eq(systemModulesTable.id, moduleId));
13
17
  }
14
18
  async function resolveSchemaPath(moduleId) {
15
- const path = await import("node:path");
16
- const fs = await import("node:fs/promises");
17
19
  const root = process.cwd();
18
20
  if (moduleId === "@arch-cadre/core" || moduleId === "core") {
19
21
  const p = path.join(root, "node_modules", "@kryo", "core", "dist", "server", "database", "schema.cjs");
@@ -35,6 +37,8 @@ async function resolveSchemaPath(moduleId) {
35
37
  path.join(root, "modules", moduleId, "schema.ts"),
36
38
  path.join(root, "node_modules", moduleId, "dist", "schema.cjs"),
37
39
  path.join(root, "node_modules", `@arch-cadre/${cleanId}`, "dist", "schema.cjs"),
40
+ path.join(root, "node_modules", moduleId, "src", "schema.ts"),
41
+ path.join(root, "node_modules", `@arch-cadre/${cleanId}`, "src", "schema.ts"),
38
42
  path.resolve(root, "../../packages", cleanId, "src", "schema.ts"),
39
43
  path.resolve(root, "../../packages", `kryo-${cleanId}`, "src", "schema.ts"),
40
44
  path.resolve(root, "../../packages", cleanId, "schema.ts")
@@ -48,10 +52,7 @@ async function resolveSchemaPath(moduleId) {
48
52
  return null;
49
53
  }
50
54
  async function pushModuleSchema(moduleId) {
51
- const { exec } = await import("node:child_process");
52
- const { promisify } = await import("node:util");
53
55
  const execAsync = promisify(exec);
54
- const path = await import("node:path");
55
56
  console.log(`[Kernel:Lifecycle] Targeted sync for module: ${moduleId}`);
56
57
  const root = process.cwd();
57
58
  const enabledFromDb = await db.select({ id: systemModulesTable.id }).from(systemModulesTable).where(eq(systemModulesTable.enabled, true));
@@ -88,9 +89,6 @@ async function pushModuleSchema(moduleId) {
88
89
  }
89
90
  async function performToggle(moduleId, isEnabled) {
90
91
  try {
91
- const { exec } = await import("node:child_process");
92
- const { promisify } = await import("node:util");
93
- promisify(exec);
94
92
  const allModules = await getModules();
95
93
  const manifest = allModules.find((m) => m.id === moduleId);
96
94
  await updateStep(moduleId, "Validate module...");
@@ -123,6 +121,7 @@ async function performToggle(moduleId, isEnabled) {
123
121
  else await pushModuleSchema(moduleId);
124
122
  await updateStep(moduleId, "Migration successful");
125
123
  } catch (e) {
124
+ console.error(`[Kernel] Migration failed for ${moduleId}:`, e);
126
125
  await updateStep(moduleId, `Migration failed: ${e.message}`);
127
126
  await sleep(500);
128
127
  }
@@ -1 +1 @@
1
- {"version":3,"file":"lifecycle.mjs","names":[],"sources":["../../src/server/lifecycle.ts"],"sourcesContent":["\"use server\";\n\nimport { systemModulesTable } from \"@arch-cadre/core\";\nimport { db } from \"@arch-cadre/core/server\";\nimport { eq } from \"drizzle-orm\";\nimport { getModuleInstance, getModules } from \"./manage\";\n\nconst sleep = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms));\n\nasync function updateStep(moduleId: string, step: string | null) {\n console.log(`[Kernel] \"${moduleId}\" step: ${step}`);\n await db\n .update(systemModulesTable)\n .set({ lastStep: step })\n .where(eq(systemModulesTable.id, moduleId));\n}\n\nasync function resolveSchemaPath(moduleId: string): Promise<string | null> {\n const path = await import(\"node:path\");\n const fs = await import(\"node:fs/promises\");\n const root = process.cwd();\n\n // 1. Special case for core\n if (moduleId === \"@arch-cadre/core\" || moduleId === \"core\") {\n const p = path.join(\n root,\n \"node_modules\",\n \"@kryo\",\n \"core\",\n \"dist\",\n \"server\",\n \"database\",\n \"schema.cjs\",\n );\n try {\n await fs.access(p);\n return p;\n } catch {\n // Monorepo dev fallback\n const devP = path.resolve(\n root,\n \"../../packages/kryo-core/src/server/database/schema.ts\",\n );\n try {\n await fs.access(devP);\n return devP;\n } catch {}\n }\n return null;\n }\n\n // Normalize moduleId (remove @arch-cadre/ prefix if present for directory searching)\n const cleanId = moduleId.replace(\"@arch-cadre/\", \"\");\n\n const possible = [\n // Local module\n path.join(root, \"modules\", cleanId, \"schema.ts\"),\n path.join(root, \"modules\", moduleId, \"schema.ts\"),\n\n // node_modules (installed or symlinked)\n path.join(root, \"node_modules\", moduleId, \"dist\", \"schema.cjs\"),\n path.join(root, \"node_modules\", `@arch-cadre/${cleanId}`, \"dist\", \"schema.cjs\"),\n\n // Monorepo packages (searching by various naming conventions)\n path.resolve(root, \"../../packages\", cleanId, \"src\", \"schema.ts\"),\n path.resolve(root, \"../../packages\", `kryo-${cleanId}`, \"src\", \"schema.ts\"),\n path.resolve(root, \"../../packages\", cleanId, \"schema.ts\"),\n ];\n\n for (const p of possible) {\n try {\n await fs.access(p);\n console.log(\n `[Kernel:Lifecycle] Resolved schema for ${moduleId} at: ${p}`,\n );\n return p;\n } catch {}\n }\n\n console.warn(\n `[Kernel:Lifecycle] Could not resolve schema path for: ${moduleId}`,\n );\n return null;\n}\n\nexport async function pushModuleSchema(moduleId: string) {\n const { exec } = await import(\"node:child_process\");\n const { promisify } = await import(\"node:util\");\n const execAsync = promisify(exec);\n const path = await import(\"node:path\");\n\n console.log(`[Kernel:Lifecycle] Targeted sync for module: ${moduleId}`);\n\n const root = process.cwd();\n\n // 1. Get all currently enabled modules to avoid dropping their tables\n const enabledFromDb = await db\n .select({ id: systemModulesTable.id })\n .from(systemModulesTable)\n .where(eq(systemModulesTable.enabled, true));\n\n const activeModuleIds = new Set(enabledFromDb.map((m) => m.id));\n activeModuleIds.add(\"@arch-cadre/core\");\n activeModuleIds.add(moduleId);\n\n // 2. Resolve physical paths for all active schemas\n const schemaPaths: string[] = [];\n for (const id of Array.from(activeModuleIds)) {\n const p = await resolveSchemaPath(id);\n if (p) schemaPaths.push(p);\n }\n\n if (schemaPaths.length === 0) {\n console.warn(\n `[Kernel:Lifecycle] No schema paths resolved for ${moduleId}, skipping push.`,\n );\n return;\n }\n\n // 3. Prepare command\n const configPath = path.join(root, \"drizzle.config.ts\");\n const drizzleKitBin = path.join(root, \"node_modules\", \".bin\", \"drizzle-kit\");\n\n const cmd = `\"${drizzleKitBin}\" push --force --config=${configPath}`;\n\n console.log(\n `[Kernel:Lifecycle] Executing isolated migration. Modules: ${Array.from(activeModuleIds).join(\", \")}`,\n );\n\n try {\n await execAsync(cmd, {\n env: {\n ...process.env,\n CI: \"true\",\n // Pass the calculated schemas to our dynamic drizzle.config.ts\n DRIZZLE_SCHEMA_OVERRIDE: schemaPaths.join(\",\"),\n },\n cwd: root,\n });\n console.log(\n `[Kernel:Lifecycle] Isolated migration successful for ${moduleId}`,\n );\n } catch (e: any) {\n console.error(\n `[Kernel:Lifecycle] Isolated migration failed for ${moduleId}:`,\n );\n console.error(e.stdout || e.message);\n throw new Error(`Migration failed: ${moduleId}`);\n }\n}\n\nasync function performToggle(moduleId: string, isEnabled: boolean) {\n try {\n const { exec } = await import(\"node:child_process\");\n const { promisify } = await import(\"node:util\");\n const execAsync = promisify(exec);\n\n const allModules = await getModules();\n const manifest = allModules.find((m) => m.id === moduleId);\n\n await updateStep(moduleId, \"Validate module...\");\n await sleep(500);\n\n if (!manifest) return;\n\n if (isEnabled) {\n await updateStep(moduleId, \"Queued...\");\n await sleep(500);\n\n if (manifest.dependencies?.length) {\n const pendingDeps = manifest.dependencies.filter((depId) => {\n const dep = allModules.find((m) => m.id === depId);\n return dep && !dep.enabled && !dep.system;\n });\n\n if (pendingDeps.length > 0) {\n await updateStep(moduleId, \"Waiting for dependencies...\");\n\n for (const depId of pendingDeps) {\n await performToggle(depId, true);\n await sleep(500);\n }\n }\n }\n\n await updateStep(moduleId, \"Initializing...\");\n await sleep(500);\n await db\n .update(systemModulesTable)\n .set({ enabled: true })\n .where(eq(systemModulesTable.id, moduleId));\n\n const instance = await getModuleInstance(moduleId);\n\n await updateStep(moduleId, \"Migrate database...\");\n await sleep(500);\n\n try {\n if (instance?.onMigrate) {\n await instance.onMigrate();\n } else {\n // Fallback to default push if no hook provided but schema might exist\n await pushModuleSchema(moduleId);\n }\n await updateStep(moduleId, \"Migration successful\");\n } catch (e: any) {\n await updateStep(moduleId, `Migration failed: ${e.message}`);\n await sleep(500);\n }\n\n if (instance?.onEnable) {\n await updateStep(moduleId, \"Running setup...\");\n await sleep(500);\n await instance.onEnable();\n }\n\n await updateStep(moduleId, \"Finishing...\");\n await sleep(500);\n await db\n .update(systemModulesTable)\n .set({ installed: true, lastStep: null })\n .where(eq(systemModulesTable.id, moduleId));\n } else {\n const dependents = allModules.filter((m) => {\n if (!m.enabled || m.id === moduleId) return false;\n\n if (m.dependencies?.includes(moduleId)) return true;\n\n if (m.extends?.includes(moduleId)) {\n const otherActiveTargets = m.extends.filter((targetId) => {\n if (targetId === moduleId) return false;\n const target = allModules.find((mod) => mod.id === targetId);\n return target?.enabled;\n });\n\n return otherActiveTargets.length === 0;\n }\n\n return false;\n });\n\n if (dependents.length > 0) {\n await updateStep(moduleId, `Deactivating dependents...`);\n for (const dep of dependents) {\n await performToggle(dep.id, false);\n await sleep(1000);\n }\n }\n\n await updateStep(moduleId, \"Deactivating...\");\n\n const instance = await getModuleInstance(moduleId);\n if (instance?.onDisable) await instance.onDisable();\n\n await db\n .update(systemModulesTable)\n .set({ enabled: false, installed: false })\n .where(eq(systemModulesTable.id, moduleId));\n\n await updateStep(moduleId, null);\n }\n } catch (e) {\n console.error(`[Kernel] Fatal error for ${moduleId}:`, e);\n await updateStep(moduleId, `Error: ${(e as Error).message}`);\n }\n}\n\nexport async function toggleModuleState(moduleId: string, isEnabled: boolean) {\n const allModules = await getModules();\n const manifest = allModules.find((m) => m.id === moduleId);\n if (!manifest) throw new Error(`Module \"${moduleId}\" not found`);\n\n if (manifest.enabled === isEnabled) return { success: true };\n\n void performToggle(moduleId, isEnabled);\n return { success: true };\n}\n\nexport async function initOperationalModules() {\n const allModules = await getModules();\n for (const mod of allModules) {\n if (mod.enabled) {\n try {\n const instance = await getModuleInstance(mod.id);\n if (instance?.init) {\n await instance.init();\n }\n } catch (e) {\n console.error(`[Kernel] Failed to init module ${mod.id}:`, e);\n }\n }\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"lifecycle.mjs","names":[],"sources":["../../src/server/lifecycle.ts"],"sourcesContent":["\"use server\";\n\nimport { exec } from \"node:child_process\";\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { promisify } from \"node:util\";\nimport { systemModulesTable } from \"@arch-cadre/core\";\nimport { db } from \"@arch-cadre/core/server\";\nimport { eq } from \"drizzle-orm\";\nimport { getModuleInstance, getModules } from \"./manage\";\n\nconst sleep = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms));\n\nasync function updateStep(moduleId: string, step: string | null) {\n console.log(`[Kernel] \"${moduleId}\" step: ${step}`);\n await db\n .update(systemModulesTable)\n .set({ lastStep: step })\n .where(eq(systemModulesTable.id, moduleId));\n}\n\nasync function resolveSchemaPath(moduleId: string): Promise<string | null> {\n // const path = await import(\"node:path\");\n // const fs = await import(\"node:fs/promises\");\n const root = process.cwd();\n\n // 1. Special case for core\n if (moduleId === \"@arch-cadre/core\" || moduleId === \"core\") {\n const p = path.join(\n root,\n \"node_modules\",\n \"@kryo\",\n \"core\",\n \"dist\",\n \"server\",\n \"database\",\n \"schema.cjs\",\n );\n try {\n await fs.access(p);\n return p;\n } catch {\n // Monorepo dev fallback\n const devP = path.resolve(\n root,\n \"../../packages/kryo-core/src/server/database/schema.ts\",\n );\n try {\n await fs.access(devP);\n return devP;\n } catch {}\n }\n return null;\n }\n\n // Normalize moduleId (remove @arch-cadre/ prefix if present for directory searching)\n const cleanId = moduleId.replace(\"@arch-cadre/\", \"\");\n\n const possible = [\n // Local module\n path.join(root, \"modules\", cleanId, \"schema.ts\"),\n path.join(root, \"modules\", moduleId, \"schema.ts\"),\n\n // node_modules (installed or symlinked)\n path.join(root, \"node_modules\", moduleId, \"dist\", \"schema.cjs\"),\n path.join(\n root,\n \"node_modules\",\n `@arch-cadre/${cleanId}`,\n \"dist\",\n \"schema.cjs\",\n ),\n path.join(root, \"node_modules\", moduleId, \"src\", \"schema.ts\"),\n path.join(\n root,\n \"node_modules\",\n `@arch-cadre/${cleanId}`,\n \"src\",\n \"schema.ts\",\n ),\n\n // Monorepo packages (searching by various naming conventions)\n path.resolve(root, \"../../packages\", cleanId, \"src\", \"schema.ts\"),\n path.resolve(root, \"../../packages\", `kryo-${cleanId}`, \"src\", \"schema.ts\"),\n path.resolve(root, \"../../packages\", cleanId, \"schema.ts\"),\n ];\n\n for (const p of possible) {\n try {\n await fs.access(p);\n console.log(\n `[Kernel:Lifecycle] Resolved schema for ${moduleId} at: ${p}`,\n );\n return p;\n } catch {}\n }\n\n console.warn(\n `[Kernel:Lifecycle] Could not resolve schema path for: ${moduleId}`,\n );\n return null;\n}\n\nexport async function pushModuleSchema(moduleId: string) {\n const execAsync = promisify(exec);\n\n console.log(`[Kernel:Lifecycle] Targeted sync for module: ${moduleId}`);\n\n const root = process.cwd();\n\n // 1. Get all currently enabled modules to avoid dropping their tables\n const enabledFromDb = await db\n .select({ id: systemModulesTable.id })\n .from(systemModulesTable)\n .where(eq(systemModulesTable.enabled, true));\n\n const activeModuleIds = new Set(enabledFromDb.map((m) => m.id));\n activeModuleIds.add(\"@arch-cadre/core\");\n activeModuleIds.add(moduleId);\n\n // 2. Resolve physical paths for all active schemas\n const schemaPaths: string[] = [];\n for (const id of Array.from(activeModuleIds)) {\n const p = await resolveSchemaPath(id);\n if (p) schemaPaths.push(p);\n }\n\n if (schemaPaths.length === 0) {\n console.warn(\n `[Kernel:Lifecycle] No schema paths resolved for ${moduleId}, skipping push.`,\n );\n return;\n }\n\n // 3. Prepare command\n const configPath = path.join(root, \"drizzle.config.ts\");\n const drizzleKitBin = path.join(root, \"node_modules\", \".bin\", \"drizzle-kit\");\n\n const cmd = `\"${drizzleKitBin}\" push --force --config=${configPath}`;\n\n console.log(\n `[Kernel:Lifecycle] Executing isolated migration. Modules: ${Array.from(activeModuleIds).join(\", \")}`,\n );\n\n try {\n await execAsync(cmd, {\n env: {\n ...process.env,\n CI: \"true\",\n // Pass the calculated schemas to our dynamic drizzle.config.ts\n DRIZZLE_SCHEMA_OVERRIDE: schemaPaths.join(\",\"),\n },\n cwd: root,\n });\n console.log(\n `[Kernel:Lifecycle] Isolated migration successful for ${moduleId}`,\n );\n } catch (e: any) {\n console.error(\n `[Kernel:Lifecycle] Isolated migration failed for ${moduleId}:`,\n );\n console.error(e.stdout || e.message);\n throw new Error(`Migration failed: ${moduleId}`);\n }\n}\n\nasync function performToggle(moduleId: string, isEnabled: boolean) {\n try {\n const allModules = await getModules();\n const manifest = allModules.find((m) => m.id === moduleId);\n\n await updateStep(moduleId, \"Validate module...\");\n await sleep(500);\n\n if (!manifest) return;\n\n if (isEnabled) {\n await updateStep(moduleId, \"Queued...\");\n await sleep(500);\n\n if (manifest.dependencies?.length) {\n const pendingDeps = manifest.dependencies.filter((depId) => {\n const dep = allModules.find((m) => m.id === depId);\n return dep && !dep.enabled && !dep.system;\n });\n\n if (pendingDeps.length > 0) {\n await updateStep(moduleId, \"Waiting for dependencies...\");\n\n for (const depId of pendingDeps) {\n await performToggle(depId, true);\n await sleep(500);\n }\n }\n }\n\n await updateStep(moduleId, \"Initializing...\");\n await sleep(500);\n await db\n .update(systemModulesTable)\n .set({ enabled: true })\n .where(eq(systemModulesTable.id, moduleId));\n\n const instance = await getModuleInstance(moduleId);\n\n await updateStep(moduleId, \"Migrate database...\");\n await sleep(500);\n\n try {\n if (instance?.onMigrate) {\n await instance.onMigrate();\n } else {\n // Fallback to default push if no hook provided but schema might exist\n await pushModuleSchema(moduleId);\n }\n await updateStep(moduleId, \"Migration successful\");\n } catch (e: any) {\n console.error(`[Kernel] Migration failed for ${moduleId}:`, e);\n await updateStep(moduleId, `Migration failed: ${e.message}`);\n await sleep(500);\n }\n\n if (instance?.onEnable) {\n await updateStep(moduleId, \"Running setup...\");\n await sleep(500);\n await instance.onEnable();\n }\n\n await updateStep(moduleId, \"Finishing...\");\n await sleep(500);\n await db\n .update(systemModulesTable)\n .set({ installed: true, lastStep: null })\n .where(eq(systemModulesTable.id, moduleId));\n } else {\n const dependents = allModules.filter((m) => {\n if (!m.enabled || m.id === moduleId) return false;\n\n if (m.dependencies?.includes(moduleId)) return true;\n\n if (m.extends?.includes(moduleId)) {\n const otherActiveTargets = m.extends.filter((targetId) => {\n if (targetId === moduleId) return false;\n const target = allModules.find((mod) => mod.id === targetId);\n return target?.enabled;\n });\n\n return otherActiveTargets.length === 0;\n }\n\n return false;\n });\n\n if (dependents.length > 0) {\n await updateStep(moduleId, `Deactivating dependents...`);\n for (const dep of dependents) {\n await performToggle(dep.id, false);\n await sleep(1000);\n }\n }\n\n await updateStep(moduleId, \"Deactivating...\");\n\n const instance = await getModuleInstance(moduleId);\n if (instance?.onDisable) await instance.onDisable();\n\n await db\n .update(systemModulesTable)\n .set({ enabled: false, installed: false })\n .where(eq(systemModulesTable.id, moduleId));\n\n await updateStep(moduleId, null);\n }\n } catch (e) {\n console.error(`[Kernel] Fatal error for ${moduleId}:`, e);\n await updateStep(moduleId, `Error: ${(e as Error).message}`);\n }\n}\n\nexport async function toggleModuleState(moduleId: string, isEnabled: boolean) {\n const allModules = await getModules();\n const manifest = allModules.find((m) => m.id === moduleId);\n if (!manifest) throw new Error(`Module \"${moduleId}\" not found`);\n\n if (manifest.enabled === isEnabled) return { success: true };\n\n void performToggle(moduleId, isEnabled);\n return { success: true };\n}\n\nexport async function initOperationalModules() {\n const allModules = await getModules();\n for (const mod of allModules) {\n if (mod.enabled) {\n try {\n const instance = await getModuleInstance(mod.id);\n if (instance?.init) {\n await instance.init();\n }\n } catch (e) {\n console.error(`[Kernel] Failed to init module ${mod.id}:`, e);\n }\n }\n }\n}\n"],"mappings":"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"}
@@ -3,6 +3,10 @@
3
3
  const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
4
4
  const require_types = require('../types.cjs');
5
5
  let _arch_cadre_core_server = require("@arch-cadre/core/server");
6
+ let node_fs_promises = require("node:fs/promises");
7
+ node_fs_promises = require_runtime.__toESM(node_fs_promises);
8
+ let node_path = require("node:path");
9
+ node_path = require_runtime.__toESM(node_path);
6
10
  let _arch_cadre_core = require("@arch-cadre/core");
7
11
  let drizzle_orm = require("drizzle-orm");
8
12
 
@@ -15,15 +19,13 @@ async function registerModules(modules) {
15
19
  }
16
20
  async function getModules() {
17
21
  try {
18
- const fs = await import("node:fs/promises");
19
- const path = await import("node:path");
20
22
  const modulesDir = await (0, _arch_cadre_core_server.getModulesDir)();
21
23
  const manifests = [];
22
- const entries = await fs.readdir(modulesDir).catch(() => []);
24
+ const entries = await node_fs_promises.default.readdir(modulesDir).catch(() => []);
23
25
  for (const dir of entries) {
24
26
  if (dir.startsWith(".")) continue;
25
27
  try {
26
- const content = await fs.readFile(path.join(modulesDir, dir, "manifest.json"), "utf-8");
28
+ const content = await node_fs_promises.default.readFile(node_path.default.join(modulesDir, dir, "manifest.json"), "utf-8");
27
29
  const manifest = require_types.ModuleManifestSchema.parse(JSON.parse(content));
28
30
  manifests.push({
29
31
  ...manifest,
@@ -63,7 +65,8 @@ async function getModuleStatus(moduleId) {
63
65
  } catch {
64
66
  return {
65
67
  enabled: false,
66
- installed: false
68
+ installed: false,
69
+ lastStep: null
67
70
  };
68
71
  }
69
72
  }
@@ -84,11 +87,11 @@ async function getModuleInstance(moduleId) {
84
87
  }
85
88
  console.log(`[Kernel:Manage] Module "${moduleId}" not in registry. Registry size: ${store.size}. Keys: ${Array.from(store.keys()).join(", ")}`);
86
89
  if (!moduleId.startsWith(".") && !moduleId.startsWith("/")) try {
87
- const mod = await import(moduleId);
90
+ const mod = await import(`@arch-cadre/${moduleId}`);
88
91
  console.log(`[Kernel:Manage] Module "${moduleId}" loaded via import().`);
89
92
  return mod.default || mod || null;
90
93
  } catch (e) {
91
- console.warn(`[Kernel:Manage] Failed to import module "${moduleId}": ${e.message}`);
94
+ console.warn(`[Kernel:Manage] Failed to import module "${moduleId} via import().": ${e.message}`);
92
95
  }
93
96
  return null;
94
97
  } catch (error) {
@@ -3,9 +3,9 @@ import { IModule } from "../types.cjs";
3
3
  //#region src/server/manage.d.ts
4
4
  declare function registerModules(modules: IModule[]): Promise<void>;
5
5
  declare function getModules(): Promise<{
6
- enabled: any;
7
- installed: any;
8
- lastStep: any;
6
+ enabled: boolean;
7
+ installed: boolean;
8
+ lastStep: string | null | undefined;
9
9
  hasDocs: boolean;
10
10
  id: string;
11
11
  name: string;
@@ -18,13 +18,9 @@ declare function getModules(): Promise<{
18
18
  npmDevDependencies?: string[] | undefined;
19
19
  }[]>;
20
20
  declare function getModuleStatus(moduleId: string): Promise<{
21
- enabled: any;
22
- installed: any;
23
- lastStep: any;
24
- } | {
25
21
  enabled: boolean;
26
22
  installed: boolean;
27
- lastStep?: undefined;
23
+ lastStep: string | null;
28
24
  }>;
29
25
  declare function isModuleEnabled(moduleId: string): Promise<boolean>;
30
26
  declare function getModuleInstance(moduleId: string): Promise<IModule | null>;
@@ -1 +1 @@
1
- {"version":3,"file":"manage.d.cts","names":[],"sources":["../../src/server/manage.ts"],"mappings":";;;iBAasB,eAAA,CAAgB,OAAA,EAAS,OAAA,KAAS,OAAA;AAAA,iBASlC,UAAA,CAAA,GAAU,OAAA;;;;;;;;;;;;;;;iBAgDV,eAAA,CAAgB,QAAA,WAAgB,OAAA;;;;;;;;;iBAgBhC,eAAA,CAAgB,QAAA,WAAmB,OAAA;AAAA,iBAuBnC,iBAAA,CACpB,QAAA,WACC,OAAA,CAAQ,OAAA;AAAA,iBA2CW,eAAA,GAAA,CAAmB,QAAA,WAAmB,OAAA,CAAQ,CAAA;AAAA,iBAa9C,kBAAA,CAAmB,QAAA,UAAkB,MAAA,QAAW,OAAA"}
1
+ {"version":3,"file":"manage.d.cts","names":[],"sources":["../../src/server/manage.ts"],"mappings":";;;iBAesB,eAAA,CAAgB,OAAA,EAAS,OAAA,KAAS,OAAA;AAAA,iBASlC,UAAA,CAAA,GAAU,OAAA;;;;;;;;;;;;;;;iBAmDV,eAAA,CAAgB,QAAA,WAAgB,OAAA;;;;;iBAiBhC,eAAA,CAAgB,QAAA,WAAmB,OAAA;AAAA,iBAYnC,iBAAA,CACpB,QAAA,WACC,OAAA,CAAQ,OAAA;AAAA,iBA6CW,eAAA,GAAA,CAAmB,QAAA,WAAmB,OAAA,CAAQ,CAAA;AAAA,iBAa9C,kBAAA,CAAmB,QAAA,UAAkB,MAAA,QAAW,OAAA"}
@@ -3,9 +3,9 @@ import { IModule } from "../types.mjs";
3
3
  //#region src/server/manage.d.ts
4
4
  declare function registerModules(modules: IModule[]): Promise<void>;
5
5
  declare function getModules(): Promise<{
6
- enabled: any;
7
- installed: any;
8
- lastStep: any;
6
+ enabled: boolean;
7
+ installed: boolean;
8
+ lastStep: string | null | undefined;
9
9
  hasDocs: boolean;
10
10
  id: string;
11
11
  name: string;
@@ -18,13 +18,9 @@ declare function getModules(): Promise<{
18
18
  npmDevDependencies?: string[] | undefined;
19
19
  }[]>;
20
20
  declare function getModuleStatus(moduleId: string): Promise<{
21
- enabled: any;
22
- installed: any;
23
- lastStep: any;
24
- } | {
25
21
  enabled: boolean;
26
22
  installed: boolean;
27
- lastStep?: undefined;
23
+ lastStep: string | null;
28
24
  }>;
29
25
  declare function isModuleEnabled(moduleId: string): Promise<boolean>;
30
26
  declare function getModuleInstance(moduleId: string): Promise<IModule | null>;
@@ -1 +1 @@
1
- {"version":3,"file":"manage.d.mts","names":[],"sources":["../../src/server/manage.ts"],"mappings":";;;iBAasB,eAAA,CAAgB,OAAA,EAAS,OAAA,KAAS,OAAA;AAAA,iBASlC,UAAA,CAAA,GAAU,OAAA;;;;;;;;;;;;;;;iBAgDV,eAAA,CAAgB,QAAA,WAAgB,OAAA;;;;;;;;;iBAgBhC,eAAA,CAAgB,QAAA,WAAmB,OAAA;AAAA,iBAuBnC,iBAAA,CACpB,QAAA,WACC,OAAA,CAAQ,OAAA;AAAA,iBA2CW,eAAA,GAAA,CAAmB,QAAA,WAAmB,OAAA,CAAQ,CAAA;AAAA,iBAa9C,kBAAA,CAAmB,QAAA,UAAkB,MAAA,QAAW,OAAA"}
1
+ {"version":3,"file":"manage.d.mts","names":[],"sources":["../../src/server/manage.ts"],"mappings":";;;iBAesB,eAAA,CAAgB,OAAA,EAAS,OAAA,KAAS,OAAA;AAAA,iBASlC,UAAA,CAAA,GAAU,OAAA;;;;;;;;;;;;;;;iBAmDV,eAAA,CAAgB,QAAA,WAAgB,OAAA;;;;;iBAiBhC,eAAA,CAAgB,QAAA,WAAmB,OAAA;AAAA,iBAYnC,iBAAA,CACpB,QAAA,WACC,OAAA,CAAQ,OAAA;AAAA,iBA6CW,eAAA,GAAA,CAAmB,QAAA,WAAmB,OAAA,CAAQ,CAAA;AAAA,iBAa9C,kBAAA,CAAmB,QAAA,UAAkB,MAAA,QAAW,OAAA"}
@@ -2,6 +2,8 @@
2
2
 
3
3
  import { ModuleManifestSchema } from "../types.mjs";
4
4
  import { db, getModulesDir } from "@arch-cadre/core/server";
5
+ import fs from "node:fs/promises";
6
+ import path from "node:path";
5
7
  import { systemModulesTable } from "@arch-cadre/core";
6
8
  import { eq } from "drizzle-orm";
7
9
 
@@ -14,8 +16,6 @@ async function registerModules(modules) {
14
16
  }
15
17
  async function getModules() {
16
18
  try {
17
- const fs = await import("node:fs/promises");
18
- const path = await import("node:path");
19
19
  const modulesDir = await getModulesDir();
20
20
  const manifests = [];
21
21
  const entries = await fs.readdir(modulesDir).catch(() => []);
@@ -62,7 +62,8 @@ async function getModuleStatus(moduleId) {
62
62
  } catch {
63
63
  return {
64
64
  enabled: false,
65
- installed: false
65
+ installed: false,
66
+ lastStep: null
66
67
  };
67
68
  }
68
69
  }
@@ -83,11 +84,11 @@ async function getModuleInstance(moduleId) {
83
84
  }
84
85
  console.log(`[Kernel:Manage] Module "${moduleId}" not in registry. Registry size: ${store.size}. Keys: ${Array.from(store.keys()).join(", ")}`);
85
86
  if (!moduleId.startsWith(".") && !moduleId.startsWith("/")) try {
86
- const mod = await import(moduleId);
87
+ const mod = await import(`@arch-cadre/${moduleId}`);
87
88
  console.log(`[Kernel:Manage] Module "${moduleId}" loaded via import().`);
88
89
  return mod.default || mod || null;
89
90
  } catch (e) {
90
- console.warn(`[Kernel:Manage] Failed to import module "${moduleId}": ${e.message}`);
91
+ console.warn(`[Kernel:Manage] Failed to import module "${moduleId} via import().": ${e.message}`);
91
92
  }
92
93
  return null;
93
94
  } catch (error) {
@@ -1 +1 @@
1
- {"version":3,"file":"manage.mjs","names":[],"sources":["../../src/server/manage.ts"],"sourcesContent":["\"use server\";\n\nimport { systemModulesTable } from \"@arch-cadre/core\";\nimport { db, getModulesDir } from \"@arch-cadre/core/server\";\nimport { eq } from \"drizzle-orm\";\nimport { type IModule, ModuleManifestSchema } from \"../types\";\n\nconst globalForModules = globalThis as any;\n\nif (!globalForModules.__KRYO_REGISTERED_MODULES__) {\n globalForModules.__KRYO_REGISTERED_MODULES__ = new Map<string, IModule>();\n}\n\nexport async function registerModules(modules: IModule[]) {\n const store = globalForModules.__KRYO_REGISTERED_MODULES__;\n for (const mod of modules) {\n if (mod.manifest?.id) {\n store.set(mod.manifest.id, mod);\n }\n }\n}\n\nexport async function getModules() {\n try {\n const fs = await import(\"node:fs/promises\");\n const path = await import(\"node:path\");\n const modulesDir = await getModulesDir();\n const manifests = [];\n const entries = await fs.readdir(modulesDir).catch(() => []);\n\n for (const dir of entries) {\n if (dir.startsWith(\".\")) continue;\n try {\n const content = await fs.readFile(\n path.join(modulesDir, dir, \"manifest.json\"),\n \"utf-8\",\n );\n const manifest = ModuleManifestSchema.parse(JSON.parse(content));\n manifests.push({ ...manifest, hasDocs: false });\n } catch {}\n }\n const store = globalForModules.__KRYO_REGISTERED_MODULES__ as Map<\n string,\n IModule\n >;\n for (const mod of store.values()) {\n if (!manifests.some((m) => m.id === mod.manifest.id)) {\n manifests.push({ ...mod.manifest, hasDocs: false });\n }\n }\n const dbModules = await db\n .select()\n .from(systemModulesTable)\n .catch(() => []);\n const dbMap = new Map(dbModules.map((m) => [m.id, m]));\n return manifests.map((mod) => {\n const dbEntry = dbMap.get(mod.id);\n return {\n ...mod,\n enabled: mod.system ? true : (dbEntry?.enabled ?? false),\n installed: mod.system ? true : (dbEntry?.installed ?? false),\n lastStep: dbEntry?.lastStep,\n hasDocs: mod.hasDocs,\n };\n });\n } catch {\n return [];\n }\n}\n\nexport async function getModuleStatus(moduleId: string) {\n try {\n const [mod] = await db\n .select()\n .from(systemModulesTable)\n .where(eq(systemModulesTable.id, moduleId));\n return {\n enabled: mod?.enabled,\n installed: mod?.installed,\n lastStep: mod?.lastStep,\n };\n } catch {\n return { enabled: false, installed: false };\n }\n}\n\nexport async function isModuleEnabled(moduleId: string): Promise<boolean> {\n try {\n const [mod] = await db\n .select()\n .from(systemModulesTable)\n .where(eq(systemModulesTable.id, moduleId));\n return !!mod?.enabled || !!mod?.system;\n } catch {\n return false;\n }\n}\n\n// export async function getModuleUrl(\n// moduleId: string,\n// path: string,\n// type: \"public\" | \"admin\" = \"public\",\n// ) {\n// const cleanPath = path === \"index\" || path === \"\" ? \"\" : `/${path}`;\n// return type === \"public\"\n// ? `/m/${moduleId}${cleanPath}`\n// : `/module/${moduleId}${cleanPath}`;\n// }\n\nexport async function getModuleInstance(\n moduleId: string,\n): Promise<IModule | null> {\n try {\n const store = globalForModules.__KRYO_REGISTERED_MODULES__ as Map<\n string,\n IModule\n >;\n\n // 1. Check if module is already registered in the global store\n if (store.has(moduleId)) {\n console.log(`[Kernel:Manage] Module \"${moduleId}\" found in registry.`);\n return store.get(moduleId) || null;\n }\n\n console.log(\n `[Kernel:Manage] Module \"${moduleId}\" not in registry. Registry size: ${store.size}. Keys: ${Array.from(store.keys()).join(\", \")}`,\n );\n\n // 2. Try to load as an NPM package (for modules installed via npm/pnpm)\n // We only try this if it doesn't look like a local module path\n if (!moduleId.startsWith(\".\") && !moduleId.startsWith(\"/\")) {\n try {\n const mod = await import(moduleId);\n console.log(\n `[Kernel:Manage] Module \"${moduleId}\" loaded via import().`,\n );\n return mod.default || mod || null;\n } catch (e: any) {\n console.warn(\n `[Kernel:Manage] Failed to import module \"${moduleId}\": ${e.message}`,\n );\n }\n }\n\n return null;\n } catch (error: any) {\n console.error(\n `[Kernel:Manage] Error in getModuleInstance for \"${moduleId}\":`,\n error,\n );\n return null;\n }\n}\n\nexport async function getModuleConfig<T>(moduleId: string): Promise<T | null> {\n try {\n const [mod] = await db\n .select({ config: systemModulesTable.config })\n .from(systemModulesTable)\n .where(eq(systemModulesTable.id, moduleId));\n if (!mod?.config) return null;\n return JSON.parse(mod.config) as T;\n } catch {\n return null;\n }\n}\n\nexport async function updateModuleConfig(moduleId: string, config: any) {\n try {\n await db\n .update(systemModulesTable)\n .set({ config: JSON.stringify(config) })\n .where(eq(systemModulesTable.id, moduleId));\n } catch (e) {\n console.warn(`[Kernel:Manage] Failed to update config for ${moduleId}:`, e);\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"manage.mjs","names":[],"sources":["../../src/server/manage.ts"],"sourcesContent":["\"use server\";\n\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { systemModulesTable } from \"@arch-cadre/core\";\nimport { db, getModulesDir } from \"@arch-cadre/core/server\";\nimport { eq } from \"drizzle-orm\";\nimport { type IModule, ModuleManifestSchema } from \"../types\";\n\nconst globalForModules = globalThis as any;\n\nif (!globalForModules.__KRYO_REGISTERED_MODULES__) {\n globalForModules.__KRYO_REGISTERED_MODULES__ = new Map<string, IModule>();\n}\n\nexport async function registerModules(modules: IModule[]) {\n const store = globalForModules.__KRYO_REGISTERED_MODULES__;\n for (const mod of modules) {\n if (mod.manifest?.id) {\n store.set(mod.manifest.id, mod);\n }\n }\n}\n\nexport async function getModules() {\n try {\n const modulesDir = await getModulesDir();\n const manifests = [];\n const entries = await fs.readdir(modulesDir).catch(() => []);\n\n for (const dir of entries) {\n if (dir.startsWith(\".\")) continue;\n try {\n const content = await fs.readFile(\n path.join(modulesDir, dir, \"manifest.json\"),\n \"utf-8\",\n );\n const manifest = ModuleManifestSchema.parse(JSON.parse(content));\n manifests.push({ ...manifest, hasDocs: false });\n } catch {}\n }\n\n const store = globalForModules.__KRYO_REGISTERED_MODULES__ as Map<\n string,\n IModule\n >;\n\n for (const mod of store.values()) {\n if (!manifests.some((m) => m.id === mod.manifest.id)) {\n manifests.push({ ...mod.manifest, hasDocs: false });\n }\n }\n\n const dbModules = await db\n .select()\n .from(systemModulesTable)\n .catch(() => []);\n\n const dbMap = new Map(dbModules.map((m) => [m.id, m]));\n\n return manifests.map((mod) => {\n const dbEntry = dbMap.get(mod.id);\n return {\n ...mod,\n enabled: mod.system ? true : (dbEntry?.enabled ?? false),\n installed: mod.system ? true : (dbEntry?.installed ?? false),\n lastStep: dbEntry?.lastStep,\n hasDocs: mod.hasDocs,\n };\n });\n } catch {\n return [];\n }\n}\n\nexport async function getModuleStatus(moduleId: string) {\n try {\n const [mod] = await db\n .select()\n .from(systemModulesTable)\n .where(eq(systemModulesTable.id, moduleId));\n\n return {\n enabled: mod?.enabled,\n installed: mod?.installed,\n lastStep: mod?.lastStep,\n };\n } catch {\n return { enabled: false, installed: false, lastStep: null };\n }\n}\n\nexport async function isModuleEnabled(moduleId: string): Promise<boolean> {\n try {\n const [mod] = await db\n .select()\n .from(systemModulesTable)\n .where(eq(systemModulesTable.id, moduleId));\n return !!mod?.enabled || !!mod?.system;\n } catch {\n return false;\n }\n}\n\nexport async function getModuleInstance(\n moduleId: string,\n): Promise<IModule | null> {\n try {\n const store = globalForModules.__KRYO_REGISTERED_MODULES__ as Map<\n string,\n IModule\n >;\n\n // 1. Check if module is already registered in the global store\n if (store.has(moduleId)) {\n console.log(`[Kernel:Manage] Module \"${moduleId}\" found in registry.`);\n return store.get(moduleId) || null;\n }\n\n console.log(\n `[Kernel:Manage] Module \"${moduleId}\" not in registry. Registry size: ${store.size}. Keys: ${Array.from(store.keys()).join(\", \")}`,\n );\n\n // 2. Try to load as an NPM package (for modules installed via npm/pnpm)\n // We only try this if it doesn't look like a local module path\n if (!moduleId.startsWith(\".\") && !moduleId.startsWith(\"/\")) {\n try {\n const mod = await import(`@arch-cadre/${moduleId}`);\n\n console.log(\n `[Kernel:Manage] Module \"${moduleId}\" loaded via import().`,\n );\n\n return mod.default || mod || null;\n } catch (e: any) {\n console.warn(\n `[Kernel:Manage] Failed to import module \"${moduleId} via import().\": ${e.message}`,\n );\n }\n }\n\n return null;\n } catch (error: any) {\n console.error(\n `[Kernel:Manage] Error in getModuleInstance for \"${moduleId}\":`,\n error,\n );\n return null;\n }\n}\n\nexport async function getModuleConfig<T>(moduleId: string): Promise<T | null> {\n try {\n const [mod] = await db\n .select({ config: systemModulesTable.config })\n .from(systemModulesTable)\n .where(eq(systemModulesTable.id, moduleId));\n if (!mod?.config) return null;\n return JSON.parse(mod.config) as T;\n } catch {\n return null;\n }\n}\n\nexport async function updateModuleConfig(moduleId: string, config: any) {\n try {\n await db\n .update(systemModulesTable)\n .set({ config: JSON.stringify(config) })\n .where(eq(systemModulesTable.id, moduleId));\n } catch (e) {\n console.warn(`[Kernel:Manage] Failed to update config for ${moduleId}:`, e);\n }\n}\n"],"mappings":"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"}
@@ -9,13 +9,13 @@ let drizzle_orm = require("drizzle-orm");
9
9
  //#region src/server/registry.ts
10
10
  const globalForRegistry = globalThis;
11
11
  async function initModules(force = false) {
12
- if (globalForRegistry.__WINKLY_MODULES_INITIALIZED__ && !force) return;
12
+ if (globalForRegistry.__KRYO_MODULES_INITIALIZED__ && !force) return;
13
13
  if (force) {
14
14
  console.log("[Kernel:Registry] Forcing re-initialization...");
15
15
  _arch_cadre_core.eventBus.clearAll();
16
16
  }
17
17
  console.log("[Kernel:Registry] Synchronizing module listeners...");
18
- globalForRegistry.__WINKLY_MODULES_INITIALIZED__ = true;
18
+ globalForRegistry.__KRYO_MODULES_INITIALIZED__ = true;
19
19
  await _arch_cadre_core.eventBus.publish("system:modules:init:start", { timestamp: Date.now() });
20
20
  const processedModuleIds = /* @__PURE__ */ new Set();
21
21
  let hasNewModules = true;
@@ -33,7 +33,7 @@ async function initModules(force = false) {
33
33
  installed: mod.system ?? false,
34
34
  system: mod.system ?? false
35
35
  }).onConflictDoNothing();
36
- } catch (e) {}
36
+ } catch (_e) {}
37
37
  const sortedPending = [...pendingModules].sort((a, b) => a.system === b.system ? 0 : a.system ? -1 : 1);
38
38
  for (const mod of sortedPending) {
39
39
  processedModuleIds.add(mod.id);
@@ -49,7 +49,7 @@ async function initModules(force = false) {
49
49
  let dbMod = null;
50
50
  try {
51
51
  [dbMod] = await _arch_cadre_core_server.db.select().from(_arch_cadre_core.systemModulesTable).where((0, drizzle_orm.eq)(_arch_cadre_core.systemModulesTable.id, mod.id));
52
- } catch (e) {}
52
+ } catch (_e) {}
53
53
  if (enabled && (!dbMod || !dbMod.installed)) {
54
54
  console.log(`[Kernel:Registry] Installing module ${mod.id}...`);
55
55
  if (instance.onMigrate) {
@@ -63,7 +63,7 @@ async function initModules(force = false) {
63
63
  installed: true,
64
64
  lastStep: null
65
65
  }).where((0, drizzle_orm.eq)(_arch_cadre_core.systemModulesTable.id, mod.id));
66
- } catch (e) {}
66
+ } catch (_e) {}
67
67
  }
68
68
  if (instance.init) {
69
69
  console.log(`[Kernel:Registry] Initializing ${mod.id}...`);
@@ -8,13 +8,13 @@ import { eq } from "drizzle-orm";
8
8
  //#region src/server/registry.ts
9
9
  const globalForRegistry = globalThis;
10
10
  async function initModules(force = false) {
11
- if (globalForRegistry.__WINKLY_MODULES_INITIALIZED__ && !force) return;
11
+ if (globalForRegistry.__KRYO_MODULES_INITIALIZED__ && !force) return;
12
12
  if (force) {
13
13
  console.log("[Kernel:Registry] Forcing re-initialization...");
14
14
  eventBus.clearAll();
15
15
  }
16
16
  console.log("[Kernel:Registry] Synchronizing module listeners...");
17
- globalForRegistry.__WINKLY_MODULES_INITIALIZED__ = true;
17
+ globalForRegistry.__KRYO_MODULES_INITIALIZED__ = true;
18
18
  await eventBus.publish("system:modules:init:start", { timestamp: Date.now() });
19
19
  const processedModuleIds = /* @__PURE__ */ new Set();
20
20
  let hasNewModules = true;
@@ -32,7 +32,7 @@ async function initModules(force = false) {
32
32
  installed: mod.system ?? false,
33
33
  system: mod.system ?? false
34
34
  }).onConflictDoNothing();
35
- } catch (e) {}
35
+ } catch (_e) {}
36
36
  const sortedPending = [...pendingModules].sort((a, b) => a.system === b.system ? 0 : a.system ? -1 : 1);
37
37
  for (const mod of sortedPending) {
38
38
  processedModuleIds.add(mod.id);
@@ -48,7 +48,7 @@ async function initModules(force = false) {
48
48
  let dbMod = null;
49
49
  try {
50
50
  [dbMod] = await db.select().from(systemModulesTable).where(eq(systemModulesTable.id, mod.id));
51
- } catch (e) {}
51
+ } catch (_e) {}
52
52
  if (enabled && (!dbMod || !dbMod.installed)) {
53
53
  console.log(`[Kernel:Registry] Installing module ${mod.id}...`);
54
54
  if (instance.onMigrate) {
@@ -62,7 +62,7 @@ async function initModules(force = false) {
62
62
  installed: true,
63
63
  lastStep: null
64
64
  }).where(eq(systemModulesTable.id, mod.id));
65
- } catch (e) {}
65
+ } catch (_e) {}
66
66
  }
67
67
  if (instance.init) {
68
68
  console.log(`[Kernel:Registry] Initializing ${mod.id}...`);
@@ -1 +1 @@
1
- {"version":3,"file":"registry.mjs","names":[],"sources":["../../src/server/registry.ts"],"sourcesContent":["\"use server\";\n\nimport { eventBus, systemModulesTable } from \"@arch-cadre/core\";\nimport { db } from \"@arch-cadre/core/server\";\nimport { eq } from \"drizzle-orm\";\nimport { getModuleInstance, getModules, isModuleEnabled } from \"./manage\";\n\nconst globalForRegistry = globalThis as unknown as {\n __WINKLY_MODULES_INITIALIZED__: boolean | undefined;\n};\n\nexport async function initModules(force = false) {\n if (globalForRegistry.__WINKLY_MODULES_INITIALIZED__ && !force) return;\n\n if (force) {\n console.log(\"[Kernel:Registry] Forcing re-initialization...\");\n eventBus.clearAll();\n }\n\n console.log(\"[Kernel:Registry] Synchronizing module listeners...\");\n globalForRegistry.__WINKLY_MODULES_INITIALIZED__ = true;\n\n await eventBus.publish(\"system:modules:init:start\", {\n timestamp: Date.now(),\n });\n\n const processedModuleIds = new Set<string>();\n let hasNewModules = true;\n let iterations = 0;\n const MAX_ITERATIONS = 10; // Bezpiecznik przed nieskończoną pętlą\n\n while (hasNewModules && iterations < MAX_ITERATIONS) {\n hasNewModules = false;\n iterations++;\n\n // 1. Get ALL currently registered modules (including newly added ones)\n const currentModules = await getModules();\n\n // 2. Filter out modules that are already processed\n const pendingModules = currentModules.filter(\n (mod) => !processedModuleIds.has(mod.id),\n );\n\n if (pendingModules.length === 0) {\n break;\n }\n\n // 3. Synchronize new modules with database\n for (const mod of pendingModules) {\n try {\n await db\n .insert(systemModulesTable)\n .values({\n id: mod.id,\n enabled: mod.system ?? false,\n installed: mod.system ?? false,\n system: mod.system ?? false,\n })\n .onConflictDoNothing();\n } catch (e) {\n // Table might not exist yet\n }\n }\n\n // 4. Sort pending modules: system modules first\n const sortedPending = [...pendingModules].sort((a, b) =>\n a.system === b.system ? 0 : a.system ? -1 : 1,\n );\n\n // 5. Initialize modules\n for (const mod of sortedPending) {\n // Mark as processed immediately to avoid cycles\n processedModuleIds.add(mod.id);\n hasNewModules = true; // We processed something, so we should check again in case it added more\n\n try {\n const enabled = await isModuleEnabled(mod.id);\n if (!enabled) continue;\n\n const instance = await getModuleInstance(mod.id);\n\n if (!instance) {\n console.warn(\n `[Kernel:Registry] No instance found for module ${mod.id}. Ensure it is registered correctly.`,\n );\n continue;\n }\n\n let dbMod: any = null;\n try {\n [dbMod] = await db\n .select()\n .from(systemModulesTable)\n .where(eq(systemModulesTable.id, mod.id));\n } catch (e) {\n // Ignore missing table\n }\n\n // onEnable lifecycle\n if (enabled && (!dbMod || !dbMod.installed)) {\n console.log(`[Kernel:Registry] Installing module ${mod.id}...`);\n\n // 1. Run migrations first\n if (instance.onMigrate) {\n console.log(`[Kernel:Registry] Running onMigrate for ${mod.id}...`);\n await instance.onMigrate();\n }\n\n // 2. Run enable hook\n console.log(`[Kernel:Registry] Running onEnable for ${mod.id}...`);\n if (instance.onEnable) await instance.onEnable();\n\n try {\n await db\n .update(systemModulesTable)\n .set({ installed: true, lastStep: null })\n .where(eq(systemModulesTable.id, mod.id));\n } catch (e) {\n // Ignore missing table\n }\n }\n\n // Operational init\n if (instance.init) {\n console.log(`[Kernel:Registry] Initializing ${mod.id}...`);\n await instance.init();\n console.log(`[Kernel:Registry] Module ${mod.id} is active.`);\n }\n } catch (error) {\n console.error(\n `[Kernel:Registry] Critical failure for ${mod.id}:`,\n error,\n );\n }\n }\n }\n\n if (iterations >= MAX_ITERATIONS) {\n console.warn(\n \"[Kernel:Registry] Max init iterations reached. Check for circular module registrations.\",\n );\n }\n\n await eventBus.publish(\"system:modules:init:end\", {\n timestamp: Date.now(),\n moduleCount: processedModuleIds.size,\n });\n}\n"],"mappings":";;;;;;;;AAOA,MAAM,oBAAoB;AAI1B,eAAsB,YAAY,QAAQ,OAAO;AAC/C,KAAI,kBAAkB,kCAAkC,CAAC,MAAO;AAEhE,KAAI,OAAO;AACT,UAAQ,IAAI,iDAAiD;AAC7D,WAAS,UAAU;;AAGrB,SAAQ,IAAI,sDAAsD;AAClE,mBAAkB,iCAAiC;AAEnD,OAAM,SAAS,QAAQ,6BAA6B,EAClD,WAAW,KAAK,KAAK,EACtB,CAAC;CAEF,MAAM,qCAAqB,IAAI,KAAa;CAC5C,IAAI,gBAAgB;CACpB,IAAI,aAAa;CACjB,MAAM,iBAAiB;AAEvB,QAAO,iBAAiB,aAAa,gBAAgB;AACnD,kBAAgB;AAChB;EAMA,MAAM,kBAHiB,MAAM,YAAY,EAGH,QACnC,QAAQ,CAAC,mBAAmB,IAAI,IAAI,GAAG,CACzC;AAED,MAAI,eAAe,WAAW,EAC5B;AAIF,OAAK,MAAM,OAAO,eAChB,KAAI;AACF,SAAM,GACH,OAAO,mBAAmB,CAC1B,OAAO;IACN,IAAI,IAAI;IACR,SAAS,IAAI,UAAU;IACvB,WAAW,IAAI,UAAU;IACzB,QAAQ,IAAI,UAAU;IACvB,CAAC,CACD,qBAAqB;WACjB,GAAG;EAMd,MAAM,gBAAgB,CAAC,GAAG,eAAe,CAAC,MAAM,GAAG,MACjD,EAAE,WAAW,EAAE,SAAS,IAAI,EAAE,SAAS,KAAK,EAC7C;AAGD,OAAK,MAAM,OAAO,eAAe;AAE/B,sBAAmB,IAAI,IAAI,GAAG;AAC9B,mBAAgB;AAEhB,OAAI;IACF,MAAM,UAAU,MAAM,gBAAgB,IAAI,GAAG;AAC7C,QAAI,CAAC,QAAS;IAEd,MAAM,WAAW,MAAM,kBAAkB,IAAI,GAAG;AAEhD,QAAI,CAAC,UAAU;AACb,aAAQ,KACN,kDAAkD,IAAI,GAAG,sCAC1D;AACD;;IAGF,IAAI,QAAa;AACjB,QAAI;AACF,MAAC,SAAS,MAAM,GACb,QAAQ,CACR,KAAK,mBAAmB,CACxB,MAAM,GAAG,mBAAmB,IAAI,IAAI,GAAG,CAAC;aACpC,GAAG;AAKZ,QAAI,YAAY,CAAC,SAAS,CAAC,MAAM,YAAY;AAC3C,aAAQ,IAAI,uCAAuC,IAAI,GAAG,KAAK;AAG/D,SAAI,SAAS,WAAW;AACtB,cAAQ,IAAI,2CAA2C,IAAI,GAAG,KAAK;AACnE,YAAM,SAAS,WAAW;;AAI5B,aAAQ,IAAI,0CAA0C,IAAI,GAAG,KAAK;AAClE,SAAI,SAAS,SAAU,OAAM,SAAS,UAAU;AAEhD,SAAI;AACF,YAAM,GACH,OAAO,mBAAmB,CAC1B,IAAI;OAAE,WAAW;OAAM,UAAU;OAAM,CAAC,CACxC,MAAM,GAAG,mBAAmB,IAAI,IAAI,GAAG,CAAC;cACpC,GAAG;;AAMd,QAAI,SAAS,MAAM;AACjB,aAAQ,IAAI,kCAAkC,IAAI,GAAG,KAAK;AAC1D,WAAM,SAAS,MAAM;AACrB,aAAQ,IAAI,4BAA4B,IAAI,GAAG,aAAa;;YAEvD,OAAO;AACd,YAAQ,MACN,0CAA0C,IAAI,GAAG,IACjD,MACD;;;;AAKP,KAAI,cAAc,eAChB,SAAQ,KACN,0FACD;AAGH,OAAM,SAAS,QAAQ,2BAA2B;EAChD,WAAW,KAAK,KAAK;EACrB,aAAa,mBAAmB;EACjC,CAAC"}
1
+ {"version":3,"file":"registry.mjs","names":[],"sources":["../../src/server/registry.ts"],"sourcesContent":["\"use server\";\n\nimport { eventBus, systemModulesTable } from \"@arch-cadre/core\";\nimport { db } from \"@arch-cadre/core/server\";\nimport { eq } from \"drizzle-orm\";\nimport { getModuleInstance, getModules, isModuleEnabled } from \"./manage\";\n\nconst globalForRegistry = globalThis as unknown as {\n __KRYO_MODULES_INITIALIZED__: boolean | undefined;\n};\n\nexport async function initModules(force = false) {\n if (globalForRegistry.__KRYO_MODULES_INITIALIZED__ && !force) return;\n\n if (force) {\n console.log(\"[Kernel:Registry] Forcing re-initialization...\");\n eventBus.clearAll();\n }\n\n console.log(\"[Kernel:Registry] Synchronizing module listeners...\");\n globalForRegistry.__KRYO_MODULES_INITIALIZED__ = true;\n\n await eventBus.publish(\"system:modules:init:start\", {\n timestamp: Date.now(),\n });\n\n const processedModuleIds = new Set<string>();\n let hasNewModules = true;\n let iterations = 0;\n const MAX_ITERATIONS = 10; // Bezpiecznik przed nieskończoną pętlą\n\n while (hasNewModules && iterations < MAX_ITERATIONS) {\n hasNewModules = false;\n iterations++;\n\n // 1. Get ALL currently registered modules (including newly added ones)\n const currentModules = await getModules();\n\n // 2. Filter out modules that are already processed\n const pendingModules = currentModules.filter(\n (mod) => !processedModuleIds.has(mod.id),\n );\n\n if (pendingModules.length === 0) {\n break;\n }\n\n // 3. Synchronize new modules with database\n for (const mod of pendingModules) {\n try {\n await db\n .insert(systemModulesTable)\n .values({\n id: mod.id,\n enabled: mod.system ?? false,\n installed: mod.system ?? false,\n system: mod.system ?? false,\n })\n .onConflictDoNothing();\n } catch (_e) {\n // Table might not exist yet\n }\n }\n\n // 4. Sort pending modules: system modules first\n const sortedPending = [...pendingModules].sort((a, b) =>\n a.system === b.system ? 0 : a.system ? -1 : 1,\n );\n\n // 5. Initialize modules\n for (const mod of sortedPending) {\n // Mark as processed immediately to avoid cycles\n processedModuleIds.add(mod.id);\n hasNewModules = true; // We processed something, so we should check again in case it added more\n\n try {\n const enabled = await isModuleEnabled(mod.id);\n if (!enabled) continue;\n\n const instance = await getModuleInstance(mod.id);\n\n if (!instance) {\n console.warn(\n `[Kernel:Registry] No instance found for module ${mod.id}. Ensure it is registered correctly.`,\n );\n continue;\n }\n\n let dbMod: any = null;\n try {\n [dbMod] = await db\n .select()\n .from(systemModulesTable)\n .where(eq(systemModulesTable.id, mod.id));\n } catch (_e) {\n // Ignore missing table\n }\n\n // onEnable lifecycle\n if (enabled && (!dbMod || !dbMod.installed)) {\n console.log(`[Kernel:Registry] Installing module ${mod.id}...`);\n\n // 1. Run migrations first\n if (instance.onMigrate) {\n console.log(`[Kernel:Registry] Running onMigrate for ${mod.id}...`);\n await instance.onMigrate();\n }\n\n // 2. Run enable hook\n console.log(`[Kernel:Registry] Running onEnable for ${mod.id}...`);\n if (instance.onEnable) await instance.onEnable();\n\n try {\n await db\n .update(systemModulesTable)\n .set({ installed: true, lastStep: null })\n .where(eq(systemModulesTable.id, mod.id));\n } catch (_e) {\n // Ignore missing table\n }\n }\n\n // Operational init\n if (instance.init) {\n console.log(`[Kernel:Registry] Initializing ${mod.id}...`);\n await instance.init();\n console.log(`[Kernel:Registry] Module ${mod.id} is active.`);\n }\n } catch (error) {\n console.error(\n `[Kernel:Registry] Critical failure for ${mod.id}:`,\n error,\n );\n }\n }\n }\n\n if (iterations >= MAX_ITERATIONS) {\n console.warn(\n \"[Kernel:Registry] Max init iterations reached. Check for circular module registrations.\",\n );\n }\n\n await eventBus.publish(\"system:modules:init:end\", {\n timestamp: Date.now(),\n moduleCount: processedModuleIds.size,\n });\n}\n"],"mappings":";;;;;;;;AAOA,MAAM,oBAAoB;AAI1B,eAAsB,YAAY,QAAQ,OAAO;AAC/C,KAAI,kBAAkB,gCAAgC,CAAC,MAAO;AAE9D,KAAI,OAAO;AACT,UAAQ,IAAI,iDAAiD;AAC7D,WAAS,UAAU;;AAGrB,SAAQ,IAAI,sDAAsD;AAClE,mBAAkB,+BAA+B;AAEjD,OAAM,SAAS,QAAQ,6BAA6B,EAClD,WAAW,KAAK,KAAK,EACtB,CAAC;CAEF,MAAM,qCAAqB,IAAI,KAAa;CAC5C,IAAI,gBAAgB;CACpB,IAAI,aAAa;CACjB,MAAM,iBAAiB;AAEvB,QAAO,iBAAiB,aAAa,gBAAgB;AACnD,kBAAgB;AAChB;EAMA,MAAM,kBAHiB,MAAM,YAAY,EAGH,QACnC,QAAQ,CAAC,mBAAmB,IAAI,IAAI,GAAG,CACzC;AAED,MAAI,eAAe,WAAW,EAC5B;AAIF,OAAK,MAAM,OAAO,eAChB,KAAI;AACF,SAAM,GACH,OAAO,mBAAmB,CAC1B,OAAO;IACN,IAAI,IAAI;IACR,SAAS,IAAI,UAAU;IACvB,WAAW,IAAI,UAAU;IACzB,QAAQ,IAAI,UAAU;IACvB,CAAC,CACD,qBAAqB;WACjB,IAAI;EAMf,MAAM,gBAAgB,CAAC,GAAG,eAAe,CAAC,MAAM,GAAG,MACjD,EAAE,WAAW,EAAE,SAAS,IAAI,EAAE,SAAS,KAAK,EAC7C;AAGD,OAAK,MAAM,OAAO,eAAe;AAE/B,sBAAmB,IAAI,IAAI,GAAG;AAC9B,mBAAgB;AAEhB,OAAI;IACF,MAAM,UAAU,MAAM,gBAAgB,IAAI,GAAG;AAC7C,QAAI,CAAC,QAAS;IAEd,MAAM,WAAW,MAAM,kBAAkB,IAAI,GAAG;AAEhD,QAAI,CAAC,UAAU;AACb,aAAQ,KACN,kDAAkD,IAAI,GAAG,sCAC1D;AACD;;IAGF,IAAI,QAAa;AACjB,QAAI;AACF,MAAC,SAAS,MAAM,GACb,QAAQ,CACR,KAAK,mBAAmB,CACxB,MAAM,GAAG,mBAAmB,IAAI,IAAI,GAAG,CAAC;aACpC,IAAI;AAKb,QAAI,YAAY,CAAC,SAAS,CAAC,MAAM,YAAY;AAC3C,aAAQ,IAAI,uCAAuC,IAAI,GAAG,KAAK;AAG/D,SAAI,SAAS,WAAW;AACtB,cAAQ,IAAI,2CAA2C,IAAI,GAAG,KAAK;AACnE,YAAM,SAAS,WAAW;;AAI5B,aAAQ,IAAI,0CAA0C,IAAI,GAAG,KAAK;AAClE,SAAI,SAAS,SAAU,OAAM,SAAS,UAAU;AAEhD,SAAI;AACF,YAAM,GACH,OAAO,mBAAmB,CAC1B,IAAI;OAAE,WAAW;OAAM,UAAU;OAAM,CAAC,CACxC,MAAM,GAAG,mBAAmB,IAAI,IAAI,GAAG,CAAC;cACpC,IAAI;;AAMf,QAAI,SAAS,MAAM;AACjB,aAAQ,IAAI,kCAAkC,IAAI,GAAG,KAAK;AAC1D,WAAM,SAAS,MAAM;AACrB,aAAQ,IAAI,4BAA4B,IAAI,GAAG,aAAa;;YAEvD,OAAO;AACd,YAAQ,MACN,0CAA0C,IAAI,GAAG,IACjD,MACD;;;;AAKP,KAAI,cAAc,eAChB,SAAQ,KACN,0FACD;AAGH,OAAM,SAAS,QAAQ,2BAA2B;EAChD,WAAW,KAAK,KAAK;EACrB,aAAa,mBAAmB;EACjC,CAAC"}
@@ -47,9 +47,8 @@ async function getModuleNavigationGrouped(type) {
47
47
  }
48
48
  async function getKryoPathPrefix() {
49
49
  try {
50
- await (0, _arch_cadre_core_server.ensureSystemInitialized)();
51
50
  return (await require_manage.getModuleConfig("kryo-panel"))?.pathPrefix ?? "/kryo";
52
- } catch (e) {
51
+ } catch (_e) {
53
52
  return "/kryo";
54
53
  }
55
54
  }
@@ -72,7 +71,6 @@ async function getKryoModuleNavigationGrouped(type) {
72
71
  return transformedGroups;
73
72
  }
74
73
  async function getModuleNavigation(type) {
75
- await (0, _arch_cadre_core_server.ensureSystemInitialized)();
76
74
  const { user } = await (0, _arch_cadre_core_server.getCurrentSession)();
77
75
  const userRoles = user?.roles || [];
78
76
  const userPermissions = user?.permissions || [];
@@ -91,7 +89,6 @@ async function getModuleNavigation(type) {
91
89
  return all;
92
90
  }
93
91
  async function getPublicModuleRoutes() {
94
- await (0, _arch_cadre_core_server.ensureSystemInitialized)();
95
92
  const active = (await require_manage.getModules()).filter((m) => m.enabled);
96
93
  const allRoutes = [];
97
94
  for (const mod of active) try {
@@ -101,7 +98,6 @@ async function getPublicModuleRoutes() {
101
98
  return allRoutes;
102
99
  }
103
100
  async function getPrivateModuleRoutes() {
104
- await (0, _arch_cadre_core_server.ensureSystemInitialized)();
105
101
  const active = (await require_manage.getModules()).filter((m) => m.enabled);
106
102
  const allRoutes = [];
107
103
  for (const mod of active) try {
@@ -119,7 +115,6 @@ async function getKryoModuleRoutes() {
119
115
  }));
120
116
  }
121
117
  async function getApiModuleRoutes() {
122
- await (0, _arch_cadre_core_server.ensureSystemInitialized)();
123
118
  const active = (await require_manage.getModules()).filter((m) => m.enabled);
124
119
  const allRoutes = [];
125
120
  for (const mod of active) try {
@@ -129,7 +124,6 @@ async function getApiModuleRoutes() {
129
124
  return allRoutes;
130
125
  }
131
126
  async function getModuleWidgets(area) {
132
- await (0, _arch_cadre_core_server.ensureSystemInitialized)();
133
127
  const active = (await require_manage.getModules()).filter((m) => m.enabled);
134
128
  const widgets = [];
135
129
  for (const mod of active) try {
@@ -142,7 +136,6 @@ async function getModuleWidgets(area) {
142
136
  return widgets.sort((a, b) => (a.priority || 0) - (b.priority || 0));
143
137
  }
144
138
  async function getExtensions(targetModule, point) {
145
- await (0, _arch_cadre_core_server.ensureSystemInitialized)();
146
139
  const active = (await require_manage.getModules()).filter((m) => m.enabled);
147
140
  const extensions = [];
148
141
  for (const mod of active) try {
@@ -159,7 +152,6 @@ async function getExtensions(targetModule, point) {
159
152
  return extensions.sort((a, b) => (a.priority || 0) - (b.priority || 0));
160
153
  }
161
154
  async function hasExtension(targetModule, point) {
162
- await (0, _arch_cadre_core_server.ensureSystemInitialized)();
163
155
  const active = (await require_manage.getModules()).filter((m) => m.enabled);
164
156
  for (const mod of active) try {
165
157
  const instance = await require_manage.getModuleInstance(mod.id);
@@ -1 +1 @@
1
- {"version":3,"file":"ui.d.cts","names":[],"sources":["../../src/server/ui.ts"],"mappings":";;;iBAqDsB,0BAAA,CAA2B,IAAA,yBAA0B,OAAA,CAAA,MAAA,SAAA,gBAAA;AAAA,iBA6CrD,iBAAA,CAAA,GAAqB,OAAA;AAAA,iBAUrB,8BAAA,CACpB,IAAA,yBAA0B,OAAA,CAAA,MAAA,SAAA,gBAAA;AAAA,iBA4BN,mBAAA,CACpB,IAAA,aACC,OAAA,CAAQ,gBAAA;AAAA,iBA2CW,qBAAA,CAAA,GAAyB,OAAA,CAC7C,qBAAA;AAAA,iBA6BoB,sBAAA,CAAA,GAA0B,OAAA,CAC9C,sBAAA;AAAA,iBA6BoB,mBAAA,CAAA,GAAuB,OAAA,CAAQ,sBAAA;AAAA,iBAU/B,kBAAA,CAAA,GAAsB,OAAA,CAAQ,kBAAA;AAAA,iBAkB9B,gBAAA,CAAiB,IAAA,WAAY,OAAA,CAAA,YAAA;AAAA,iBAuB7B,aAAA,CAAc,YAAA,UAAsB,KAAA,YAAc,OAAA,CAAA,eAAA;AAAA,iBAyBlD,YAAA,CAAa,YAAA,UAAsB,KAAA,YAAc,OAAA"}
1
+ {"version":3,"file":"ui.d.cts","names":[],"sources":["../../src/server/ui.ts"],"mappings":";;;iBAqDsB,0BAAA,CAA2B,IAAA,yBAA0B,OAAA,CAAA,MAAA,SAAA,gBAAA;AAAA,iBA6CrD,iBAAA,CAAA,GAAqB,OAAA;AAAA,iBASrB,8BAAA,CACpB,IAAA,yBAA0B,OAAA,CAAA,MAAA,SAAA,gBAAA;AAAA,iBA4BN,mBAAA,CACpB,IAAA,aACC,OAAA,CAAQ,gBAAA;AAAA,iBAuCW,qBAAA,CAAA,GAAyB,OAAA,CAC7C,qBAAA;AAAA,iBA2BoB,sBAAA,CAAA,GAA0B,OAAA,CAC9C,sBAAA;AAAA,iBA6BoB,mBAAA,CAAA,GAAuB,OAAA,CAAQ,sBAAA;AAAA,iBAU/B,kBAAA,CAAA,GAAsB,OAAA,CAAQ,kBAAA;AAAA,iBAkB9B,gBAAA,CAAiB,IAAA,WAAY,OAAA,CAAA,YAAA;AAAA,iBAuB7B,aAAA,CAAc,YAAA,UAAsB,KAAA,YAAc,OAAA,CAAA,eAAA;AAAA,iBAyBlD,YAAA,CAAa,YAAA,UAAsB,KAAA,YAAc,OAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"ui.d.mts","names":[],"sources":["../../src/server/ui.ts"],"mappings":";;;iBAqDsB,0BAAA,CAA2B,IAAA,yBAA0B,OAAA,CAAA,MAAA,SAAA,gBAAA;AAAA,iBA6CrD,iBAAA,CAAA,GAAqB,OAAA;AAAA,iBAUrB,8BAAA,CACpB,IAAA,yBAA0B,OAAA,CAAA,MAAA,SAAA,gBAAA;AAAA,iBA4BN,mBAAA,CACpB,IAAA,aACC,OAAA,CAAQ,gBAAA;AAAA,iBA2CW,qBAAA,CAAA,GAAyB,OAAA,CAC7C,qBAAA;AAAA,iBA6BoB,sBAAA,CAAA,GAA0B,OAAA,CAC9C,sBAAA;AAAA,iBA6BoB,mBAAA,CAAA,GAAuB,OAAA,CAAQ,sBAAA;AAAA,iBAU/B,kBAAA,CAAA,GAAsB,OAAA,CAAQ,kBAAA;AAAA,iBAkB9B,gBAAA,CAAiB,IAAA,WAAY,OAAA,CAAA,YAAA;AAAA,iBAuB7B,aAAA,CAAc,YAAA,UAAsB,KAAA,YAAc,OAAA,CAAA,eAAA;AAAA,iBAyBlD,YAAA,CAAa,YAAA,UAAsB,KAAA,YAAc,OAAA"}
1
+ {"version":3,"file":"ui.d.mts","names":[],"sources":["../../src/server/ui.ts"],"mappings":";;;iBAqDsB,0BAAA,CAA2B,IAAA,yBAA0B,OAAA,CAAA,MAAA,SAAA,gBAAA;AAAA,iBA6CrD,iBAAA,CAAA,GAAqB,OAAA;AAAA,iBASrB,8BAAA,CACpB,IAAA,yBAA0B,OAAA,CAAA,MAAA,SAAA,gBAAA;AAAA,iBA4BN,mBAAA,CACpB,IAAA,aACC,OAAA,CAAQ,gBAAA;AAAA,iBAuCW,qBAAA,CAAA,GAAyB,OAAA,CAC7C,qBAAA;AAAA,iBA2BoB,sBAAA,CAAA,GAA0B,OAAA,CAC9C,sBAAA;AAAA,iBA6BoB,mBAAA,CAAA,GAAuB,OAAA,CAAQ,sBAAA;AAAA,iBAU/B,kBAAA,CAAA,GAAsB,OAAA,CAAQ,kBAAA;AAAA,iBAkB9B,gBAAA,CAAiB,IAAA,WAAY,OAAA,CAAA,YAAA;AAAA,iBAuB7B,aAAA,CAAc,YAAA,UAAsB,KAAA,YAAc,OAAA,CAAA,eAAA;AAAA,iBAyBlD,YAAA,CAAa,YAAA,UAAsB,KAAA,YAAc,OAAA"}
@@ -1,7 +1,7 @@
1
1
  "use server";
2
2
 
3
3
  import { getModuleConfig, getModuleInstance, getModules } from "./manage.mjs";
4
- import { ensureSystemInitialized, getCurrentSession } from "@arch-cadre/core/server";
4
+ import { getCurrentSession } from "@arch-cadre/core/server";
5
5
 
6
6
  //#region src/server/ui.ts
7
7
  /**
@@ -46,9 +46,8 @@ async function getModuleNavigationGrouped(type) {
46
46
  }
47
47
  async function getKryoPathPrefix() {
48
48
  try {
49
- await ensureSystemInitialized();
50
49
  return (await getModuleConfig("kryo-panel"))?.pathPrefix ?? "/kryo";
51
- } catch (e) {
50
+ } catch (_e) {
52
51
  return "/kryo";
53
52
  }
54
53
  }
@@ -71,7 +70,6 @@ async function getKryoModuleNavigationGrouped(type) {
71
70
  return transformedGroups;
72
71
  }
73
72
  async function getModuleNavigation(type) {
74
- await ensureSystemInitialized();
75
73
  const { user } = await getCurrentSession();
76
74
  const userRoles = user?.roles || [];
77
75
  const userPermissions = user?.permissions || [];
@@ -90,7 +88,6 @@ async function getModuleNavigation(type) {
90
88
  return all;
91
89
  }
92
90
  async function getPublicModuleRoutes() {
93
- await ensureSystemInitialized();
94
91
  const active = (await getModules()).filter((m) => m.enabled);
95
92
  const allRoutes = [];
96
93
  for (const mod of active) try {
@@ -100,7 +97,6 @@ async function getPublicModuleRoutes() {
100
97
  return allRoutes;
101
98
  }
102
99
  async function getPrivateModuleRoutes() {
103
- await ensureSystemInitialized();
104
100
  const active = (await getModules()).filter((m) => m.enabled);
105
101
  const allRoutes = [];
106
102
  for (const mod of active) try {
@@ -118,7 +114,6 @@ async function getKryoModuleRoutes() {
118
114
  }));
119
115
  }
120
116
  async function getApiModuleRoutes() {
121
- await ensureSystemInitialized();
122
117
  const active = (await getModules()).filter((m) => m.enabled);
123
118
  const allRoutes = [];
124
119
  for (const mod of active) try {
@@ -128,7 +123,6 @@ async function getApiModuleRoutes() {
128
123
  return allRoutes;
129
124
  }
130
125
  async function getModuleWidgets(area) {
131
- await ensureSystemInitialized();
132
126
  const active = (await getModules()).filter((m) => m.enabled);
133
127
  const widgets = [];
134
128
  for (const mod of active) try {
@@ -141,7 +135,6 @@ async function getModuleWidgets(area) {
141
135
  return widgets.sort((a, b) => (a.priority || 0) - (b.priority || 0));
142
136
  }
143
137
  async function getExtensions(targetModule, point) {
144
- await ensureSystemInitialized();
145
138
  const active = (await getModules()).filter((m) => m.enabled);
146
139
  const extensions = [];
147
140
  for (const mod of active) try {
@@ -158,7 +151,6 @@ async function getExtensions(targetModule, point) {
158
151
  return extensions.sort((a, b) => (a.priority || 0) - (b.priority || 0));
159
152
  }
160
153
  async function hasExtension(targetModule, point) {
161
- await ensureSystemInitialized();
162
154
  const active = (await getModules()).filter((m) => m.enabled);
163
155
  for (const mod of active) try {
164
156
  const instance = await getModuleInstance(mod.id);
@@ -1 +1 @@
1
- {"version":3,"file":"ui.mjs","names":[],"sources":["../../src/server/ui.ts"],"sourcesContent":["\"use server\";\n\nimport { ensureSystemInitialized, getCurrentSession } from \"@arch-cadre/core/server\";\nimport type {\n ApiRouteDefinition,\n ModuleExtension,\n ModuleNavElement,\n ModuleNavigationGroupMap,\n ModuleWidget,\n PrivateRouteDefinition,\n PublicRouteDefinition,\n} from \"../types\";\nimport { getModuleConfig, getModuleInstance, getModules } from \"./manage\";\n\n/**\n * Helper to check and filter a navigation item based on roles and permissions.\n * Returns the item (potentially with filtered sub-items) or null if access is denied.\n */\nfunction filterNavItem(\n item: ModuleNavElement,\n userRoles: string[],\n userPermissions: string[],\n): ModuleNavElement | null {\n // 1. Check access for the item itself\n if (item.roles && item.roles.length > 0) {\n if (!item.roles.some((role) => userRoles.includes(role))) {\n return null;\n }\n }\n\n if (item.permissions && item.permissions.length > 0) {\n if (!item.permissions.every((perm) => userPermissions.includes(perm))) {\n return null;\n }\n }\n\n // 2. Recursively filter sub-items if they exist\n if (item.items && item.items.length > 0) {\n const filteredSubItems = item.items\n .map((subItem) =>\n filterNavItem(subItem as any, userRoles, userPermissions),\n )\n .filter((subItem): subItem is ModuleNavElement => subItem !== null);\n\n return {\n ...item,\n items: filteredSubItems as any,\n };\n }\n\n return item;\n}\n\nexport async function getModuleNavigationGrouped(type: \"admin\" | \"settings\") {\n // await ensureSystemInitialized();\n // const { getCurrentSession } = await import(\"../auth/session\");\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n\n const { user } = await getCurrentSession();\n const userRoles = user?.roles || [];\n const userPermissions = user?.permissions || [];\n\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const groups: Record<string, ModuleNavElement[]> = {};\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n // 1. From instance\n const instanceNav = instance?.navigation?.[type];\n if (instanceNav) {\n for (const [groupName, items] of Object.entries(\n instanceNav as ModuleNavigationGroupMap,\n )) {\n if (!groups[groupName]) groups[groupName] = [];\n for (const rawItem of items) {\n const item = filterNavItem(rawItem, userRoles, userPermissions);\n if (\n item &&\n !groups[groupName].some((existing) => existing.url === item.url)\n ) {\n groups[groupName].push(item);\n }\n }\n }\n }\n } catch (_e) {\n console.warn(\n `[Kernel:UI] Failed to load navigation for module ${mod.id}:`,\n _e,\n );\n }\n }\n return groups;\n}\n\nexport async function getKryoPathPrefix(): Promise<string> {\n try {\n await ensureSystemInitialized();\n const config = await getModuleConfig<{ pathPrefix: string }>(\"kryo-panel\");\n return config?.pathPrefix ?? \"/kryo\";\n } catch (e) {\n return \"/kryo\";\n }\n}\n\nexport async function getKryoModuleNavigationGrouped(\n type: \"admin\" | \"settings\",\n) {\n const groups = await getModuleNavigationGrouped(type);\n const prefix = await getKryoPathPrefix();\n\n const prefixUrl = (url: string) => {\n if (url.startsWith(prefix)) return url;\n return url === \"/\" ? prefix : `${prefix}${url}`;\n };\n\n const processItems = (items: ModuleNavElement[]): ModuleNavElement[] => {\n return items.map((item) => ({\n ...item,\n url: prefixUrl(item.url),\n items: item.items\n ? processItems(item.items as ModuleNavElement[])\n : undefined,\n })) as ModuleNavElement[];\n };\n\n const transformedGroups: Record<string, ModuleNavElement[]> = {};\n for (const [group, items] of Object.entries(groups)) {\n transformedGroups[group] = processItems(items);\n }\n\n return transformedGroups;\n}\n\nexport async function getModuleNavigation(\n type: \"public\",\n): Promise<ModuleNavElement[]> {\n await ensureSystemInitialized();\n // const { getCurrentSession } = await import(\"../auth/session\");\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n\n const { user } = await getCurrentSession();\n const userRoles = user?.roles || [];\n const userPermissions = user?.permissions || [];\n\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const all: ModuleNavElement[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n if (instance?.navigation?.[type]) {\n const items = instance.navigation[type] as ModuleNavElement[];\n for (const rawItem of items) {\n const item = filterNavItem(rawItem, userRoles, userPermissions);\n if (item) all.push(item);\n }\n }\n\n // if (!instance?.navigation?.[type]) {\n // const navModule = await import(`@/modules/${mod.id}/navigation`).catch(\n // () => null,\n // );\n // if (navModule?.navigation?.[type]) {\n // const items = navModule.navigation[type] as ModuleNavElement[];\n // for (const rawItem of items) {\n // const item = filterNavItem(rawItem, userRoles, userPermissions);\n // if (item) {\n // all.push(item);\n // }\n // }\n // }\n // }\n } catch {}\n }\n return all;\n}\n\nexport async function getPublicModuleRoutes(): Promise<\n PublicRouteDefinition[]\n> {\n await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const allRoutes: PublicRouteDefinition[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n // 1. Try from instance (if pre-defined)\n if (instance?.routes?.public) {\n allRoutes.push(...instance.routes.public);\n } else {\n // 2. Try loading from a dedicated routes file (better for bundling)\n // const routesModule = await import(`@/modules/${mod.id}/routes`).catch(\n // () => null,\n // );\n // if (routesModule?.publicRoutes) {\n // allRoutes.push(...routesModule.publicRoutes);\n // }\n }\n } catch {}\n }\n return allRoutes;\n}\n\nexport async function getPrivateModuleRoutes(): Promise<\n PrivateRouteDefinition[]\n> {\n await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const allRoutes: PrivateRouteDefinition[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n // 1. Try from instance\n if (instance?.routes?.private) {\n allRoutes.push(...instance.routes.private);\n } else {\n // 2. Try from routes file\n // const routesModule = await import(`@/modules/${mod.id}/routes`).catch(\n // () => null,\n // );\n // if (routesModule?.privateRoutes) {\n // allRoutes.push(...routesModule.privateRoutes);\n // }\n }\n } catch {}\n }\n return allRoutes;\n}\n\nexport async function getKryoModuleRoutes(): Promise<PrivateRouteDefinition[]> {\n const routes = await getPrivateModuleRoutes();\n const prefix = await getKryoPathPrefix();\n\n return routes.map((route) => ({\n ...route,\n path: route.path === \"/\" ? prefix : `${prefix}${route.path}`,\n }));\n}\n\nexport async function getApiModuleRoutes(): Promise<ApiRouteDefinition[]> {\n await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const allRoutes: ApiRouteDefinition[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n if (instance?.routes?.api) {\n allRoutes.push(...instance.routes.api);\n }\n } catch {}\n }\n return allRoutes;\n}\n\nexport async function getModuleWidgets(area: string) {\n await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const widgets: ModuleWidget[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n if (instance?.widgets) {\n const matching = instance.widgets.filter(\n (w: ModuleWidget) => w.area === area,\n );\n widgets.push(...matching);\n }\n } catch (_e) {}\n }\n\n return widgets.sort((a, b) => (a.priority || 0) - (b.priority || 0));\n}\n\nexport async function getExtensions(targetModule: string, point?: string) {\n await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const extensions: ModuleExtension[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n if (instance?.extensions) {\n const matching = instance.extensions.filter((ext: ModuleExtension) => {\n const isTarget = ext.targetModule === targetModule;\n const isPoint = point ? ext.point === point : true;\n return isTarget && isPoint;\n });\n extensions.push(...matching);\n }\n } catch (_e) {}\n }\n\n return extensions.sort((a, b) => (a.priority || 0) - (b.priority || 0));\n}\n\nexport async function hasExtension(targetModule: string, point?: string) {\n await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n if (instance?.extensions) {\n const matching = instance.extensions.filter((ext: ModuleExtension) => {\n const isTarget = ext.targetModule === targetModule;\n const isPoint = point ? ext.point === point : true;\n return isTarget && isPoint;\n });\n if (matching.length > 0) return true;\n }\n } catch (_e) {}\n }\n\n return false;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"ui.mjs","names":[],"sources":["../../src/server/ui.ts"],"sourcesContent":["\"use server\";\n\nimport { getCurrentSession } from \"@arch-cadre/core/server\";\nimport type {\n ApiRouteDefinition,\n ModuleExtension,\n ModuleNavElement,\n ModuleNavigationGroupMap,\n ModuleWidget,\n PrivateRouteDefinition,\n PublicRouteDefinition,\n} from \"../types\";\nimport { getModuleConfig, getModuleInstance, getModules } from \"./manage\";\n\n/**\n * Helper to check and filter a navigation item based on roles and permissions.\n * Returns the item (potentially with filtered sub-items) or null if access is denied.\n */\nfunction filterNavItem(\n item: ModuleNavElement,\n userRoles: string[],\n userPermissions: string[],\n): ModuleNavElement | null {\n // 1. Check access for the item itself\n if (item.roles && item.roles.length > 0) {\n if (!item.roles.some((role) => userRoles.includes(role))) {\n return null;\n }\n }\n\n if (item.permissions && item.permissions.length > 0) {\n if (!item.permissions.every((perm) => userPermissions.includes(perm))) {\n return null;\n }\n }\n\n // 2. Recursively filter sub-items if they exist\n if (item.items && item.items.length > 0) {\n const filteredSubItems = item.items\n .map((subItem) =>\n filterNavItem(subItem as any, userRoles, userPermissions),\n )\n .filter((subItem): subItem is ModuleNavElement => subItem !== null);\n\n return {\n ...item,\n items: filteredSubItems as any,\n };\n }\n\n return item;\n}\n\nexport async function getModuleNavigationGrouped(type: \"admin\" | \"settings\") {\n // await ensureSystemInitialized();\n // const { getCurrentSession } = await import(\"../auth/session\");\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n\n const { user } = await getCurrentSession();\n const userRoles = user?.roles || [];\n const userPermissions = user?.permissions || [];\n\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const groups: Record<string, ModuleNavElement[]> = {};\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n // 1. From instance\n const instanceNav = instance?.navigation?.[type];\n if (instanceNav) {\n for (const [groupName, items] of Object.entries(\n instanceNav as ModuleNavigationGroupMap,\n )) {\n if (!groups[groupName]) groups[groupName] = [];\n for (const rawItem of items) {\n const item = filterNavItem(rawItem, userRoles, userPermissions);\n if (\n item &&\n !groups[groupName].some((existing) => existing.url === item.url)\n ) {\n groups[groupName].push(item);\n }\n }\n }\n }\n } catch (_e) {\n console.warn(\n `[Kernel:UI] Failed to load navigation for module ${mod.id}:`,\n _e,\n );\n }\n }\n return groups;\n}\n\nexport async function getKryoPathPrefix(): Promise<string> {\n try {\n const config = await getModuleConfig<{ pathPrefix: string }>(\"kryo-panel\");\n return config?.pathPrefix ?? \"/kryo\";\n } catch (_e) {\n return \"/kryo\";\n }\n}\n\nexport async function getKryoModuleNavigationGrouped(\n type: \"admin\" | \"settings\",\n) {\n const groups = await getModuleNavigationGrouped(type);\n const prefix = await getKryoPathPrefix();\n\n const prefixUrl = (url: string) => {\n if (url.startsWith(prefix)) return url;\n return url === \"/\" ? prefix : `${prefix}${url}`;\n };\n\n const processItems = (items: ModuleNavElement[]): ModuleNavElement[] => {\n return items.map((item) => ({\n ...item,\n url: prefixUrl(item.url),\n items: item.items\n ? processItems(item.items as ModuleNavElement[])\n : undefined,\n })) as ModuleNavElement[];\n };\n\n const transformedGroups: Record<string, ModuleNavElement[]> = {};\n for (const [group, items] of Object.entries(groups)) {\n transformedGroups[group] = processItems(items);\n }\n\n return transformedGroups;\n}\n\nexport async function getModuleNavigation(\n type: \"public\",\n): Promise<ModuleNavElement[]> {\n const { user } = await getCurrentSession();\n const userRoles = user?.roles || [];\n const userPermissions = user?.permissions || [];\n\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const all: ModuleNavElement[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n if (instance?.navigation?.[type]) {\n const items = instance.navigation[type] as ModuleNavElement[];\n for (const rawItem of items) {\n const item = filterNavItem(rawItem, userRoles, userPermissions);\n if (item) all.push(item);\n }\n }\n\n // if (!instance?.navigation?.[type]) {\n // const navModule = await import(`@/modules/${mod.id}/navigation`).catch(\n // () => null,\n // );\n // if (navModule?.navigation?.[type]) {\n // const items = navModule.navigation[type] as ModuleNavElement[];\n // for (const rawItem of items) {\n // const item = filterNavItem(rawItem, userRoles, userPermissions);\n // if (item) {\n // all.push(item);\n // }\n // }\n // }\n // }\n } catch {}\n }\n return all;\n}\n\nexport async function getPublicModuleRoutes(): Promise<\n PublicRouteDefinition[]\n> {\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const allRoutes: PublicRouteDefinition[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n // 1. Try from instance (if pre-defined)\n if (instance?.routes?.public) {\n allRoutes.push(...instance.routes.public);\n } else {\n // 2. Try loading from a dedicated routes file (better for bundling)\n // const routesModule = await import(`@/modules/${mod.id}/routes`).catch(\n // () => null,\n // );\n // if (routesModule?.publicRoutes) {\n // allRoutes.push(...routesModule.publicRoutes);\n // }\n }\n } catch {}\n }\n return allRoutes;\n}\n\nexport async function getPrivateModuleRoutes(): Promise<\n PrivateRouteDefinition[]\n> {\n // await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const allRoutes: PrivateRouteDefinition[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n // 1. Try from instance\n if (instance?.routes?.private) {\n allRoutes.push(...instance.routes.private);\n } else {\n // 2. Try from routes file\n // const routesModule = await import(`@/modules/${mod.id}/routes`).catch(\n // () => null,\n // );\n // if (routesModule?.privateRoutes) {\n // allRoutes.push(...routesModule.privateRoutes);\n // }\n }\n } catch {}\n }\n return allRoutes;\n}\n\nexport async function getKryoModuleRoutes(): Promise<PrivateRouteDefinition[]> {\n const routes = await getPrivateModuleRoutes();\n const prefix = await getKryoPathPrefix();\n\n return routes.map((route) => ({\n ...route,\n path: route.path === \"/\" ? prefix : `${prefix}${route.path}`,\n }));\n}\n\nexport async function getApiModuleRoutes(): Promise<ApiRouteDefinition[]> {\n // await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const allRoutes: ApiRouteDefinition[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n if (instance?.routes?.api) {\n allRoutes.push(...instance.routes.api);\n }\n } catch {}\n }\n return allRoutes;\n}\n\nexport async function getModuleWidgets(area: string) {\n // await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const widgets: ModuleWidget[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n if (instance?.widgets) {\n const matching = instance.widgets.filter(\n (w: ModuleWidget) => w.area === area,\n );\n widgets.push(...matching);\n }\n } catch (_e) {}\n }\n\n return widgets.sort((a, b) => (a.priority || 0) - (b.priority || 0));\n}\n\nexport async function getExtensions(targetModule: string, point?: string) {\n // await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n const extensions: ModuleExtension[] = [];\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n if (instance?.extensions) {\n const matching = instance.extensions.filter((ext: ModuleExtension) => {\n const isTarget = ext.targetModule === targetModule;\n const isPoint = point ? ext.point === point : true;\n return isTarget && isPoint;\n });\n extensions.push(...matching);\n }\n } catch (_e) {}\n }\n\n return extensions.sort((a, b) => (a.priority || 0) - (b.priority || 0));\n}\n\nexport async function hasExtension(targetModule: string, point?: string) {\n // await ensureSystemInitialized();\n // const { getModules, getModuleInstance } = await import(\"./manage\");\n const modules = await getModules();\n const active = modules.filter((m) => m.enabled);\n\n for (const mod of active) {\n try {\n const instance = await getModuleInstance(mod.id);\n\n if (instance?.extensions) {\n const matching = instance.extensions.filter((ext: ModuleExtension) => {\n const isTarget = ext.targetModule === targetModule;\n const isPoint = point ? ext.point === point : true;\n return isTarget && isPoint;\n });\n if (matching.length > 0) return true;\n }\n } catch (_e) {}\n }\n\n return false;\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,11 +1,9 @@
1
1
  {
2
2
  "name": "@arch-cadre/modules",
3
- "version": "0.0.11",
3
+ "version": "0.0.15",
4
4
  "description": "Core Modules for Kryo framework",
5
5
  "type": "module",
6
- "types": "./dist/index.d.cts",
7
6
  "main": "./dist/index.cjs",
8
- "module": "./dist/index.mjs",
9
7
  "exports": {
10
8
  ".": {
11
9
  "import": "./dist/index.mjs",
@@ -21,28 +19,32 @@
21
19
  "dist"
22
20
  ],
23
21
  "scripts": {
22
+ "clean": "rm -rf ./dist",
23
+ "switch:dev": "node scripts/switchToSrc.js",
24
+ "switch:prod": "node scripts/switchToDist.js",
24
25
  "release": "npm publish --access public --no-git-checks",
25
26
  "dev": "tsdown --watch",
26
27
  "build": "tsdown"
27
28
  },
28
29
  "dependencies": {
29
- "@arch-cadre/core": "^0.0.11",
30
+ "@arch-cadre/core": "^0.0.15",
30
31
  "server-only": "^0.0.1",
31
32
  "zod": "^4.1.12"
32
33
  },
33
34
  "peerDependencies": {
34
- "@arch-cadre/core": "^0.0.11",
35
- "drizzle-orm": "1.0.0-beta.6-4414a19",
35
+ "@arch-cadre/core": "^0.0.15",
36
+ "drizzle-orm": "1.0.0-beta.15-859cf75",
36
37
  "next": ">=15.0.0",
37
38
  "react": "^19.0.0",
38
39
  "react-dom": "^19.0.0"
39
40
  },
40
41
  "devDependencies": {
41
- "@arch-cadre/core": "^0.0.11",
42
- "@biomejs/biome": "2.3.8",
42
+ "@arch-cadre/core": "^0.0.15",
43
43
  "@types/react": "^19",
44
44
  "@types/react-dom": "^19",
45
45
  "tsdown": "^0.20.3",
46
46
  "typescript": "^5"
47
- }
47
+ },
48
+ "module": "./dist/index.mjs",
49
+ "types": "./dist/index.d.cts"
48
50
  }