@arch-cadre/modules 0.0.27 → 0.0.29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_virtual/_rolldown/runtime.cjs +29 -0
- package/dist/client/widget-area.cjs +20 -0
- package/dist/client/widget-area.d.cts +19 -0
- package/dist/client/widget-area.d.cts.map +1 -0
- package/dist/client/widget-area.d.mts +19 -0
- package/dist/client/widget-area.d.mts.map +1 -0
- package/dist/client/widget-area.mjs +20 -0
- package/dist/client/widget-area.mjs.map +1 -0
- package/dist/index.cjs +5 -19
- package/dist/index.d.cts +4 -20
- package/dist/index.d.mts +4 -20
- package/dist/index.mjs +4 -19
- package/dist/server/lifecycle.cjs +193 -0
- package/dist/server/lifecycle.d.cts +9 -0
- package/dist/server/lifecycle.d.cts.map +1 -0
- package/dist/server/lifecycle.d.mts +9 -0
- package/dist/server/lifecycle.d.mts.map +1 -0
- package/dist/server/lifecycle.mjs +189 -0
- package/dist/server/lifecycle.mjs.map +1 -0
- package/dist/server/manage.cjs +126 -0
- package/dist/server/manage.d.cts +31 -0
- package/dist/server/manage.d.cts.map +1 -0
- package/dist/server/manage.d.mts +31 -0
- package/dist/server/manage.d.mts.map +1 -0
- package/dist/server/manage.mjs +118 -0
- package/dist/server/manage.mjs.map +1 -0
- package/dist/server/registry.cjs +86 -0
- package/dist/server/registry.d.cts +5 -0
- package/dist/server/registry.d.cts.map +1 -0
- package/dist/server/registry.d.mts +5 -0
- package/dist/server/registry.d.mts.map +1 -0
- package/dist/server/registry.mjs +86 -0
- package/dist/server/registry.mjs.map +1 -0
- package/dist/server/ui.cjs +180 -0
- package/dist/server/ui.d.cts +17 -0
- package/dist/server/ui.d.cts.map +1 -0
- package/dist/server/ui.d.mts +17 -0
- package/dist/server/ui.d.mts.map +1 -0
- package/dist/{ui-lsiPxu_C.mjs → server/ui.mjs} +5 -129
- package/dist/server/ui.mjs.map +1 -0
- package/dist/server.cjs +17 -291
- package/dist/server.d.cts +6 -59
- package/dist/server.d.mts +6 -59
- package/dist/server.mjs +6 -278
- package/dist/types.cjs +19 -0
- package/dist/{ui-CWGtK5lA.d.cts → types.d.cts} +2 -15
- package/dist/types.d.cts.map +1 -0
- package/dist/{ui-aeAUERbe.d.mts → types.d.mts} +2 -15
- package/dist/types.d.mts.map +1 -0
- package/dist/types.mjs +19 -0
- package/dist/types.mjs.map +1 -0
- package/package.json +1 -1
- package/dist/index.d.cts.map +0 -1
- package/dist/index.d.mts.map +0 -1
- package/dist/index.mjs.map +0 -1
- package/dist/server.d.cts.map +0 -1
- package/dist/server.d.mts.map +0 -1
- package/dist/server.mjs.map +0 -1
- package/dist/ui-CCBvXMXH.cjs +0 -441
- package/dist/ui-CWGtK5lA.d.cts.map +0 -1
- package/dist/ui-aeAUERbe.d.mts.map +0 -1
- package/dist/ui-lsiPxu_C.mjs.map +0 -1
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
//#region \0rolldown/runtime.js
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __copyProps = (to, from, except, desc) => {
|
|
9
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
+
for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
|
|
11
|
+
key = keys[i];
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except) {
|
|
13
|
+
__defProp(to, key, {
|
|
14
|
+
get: ((k) => from[k]).bind(null, key),
|
|
15
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return to;
|
|
21
|
+
};
|
|
22
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
|
|
23
|
+
value: mod,
|
|
24
|
+
enumerable: true
|
|
25
|
+
}) : target, mod));
|
|
26
|
+
|
|
27
|
+
//#endregion
|
|
28
|
+
|
|
29
|
+
exports.__toESM = __toESM;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
|
|
2
|
+
const require_ui = require('../server/ui.cjs');
|
|
3
|
+
require("react");
|
|
4
|
+
let react_jsx_runtime = require("react/jsx-runtime");
|
|
5
|
+
|
|
6
|
+
//#region src/client/widget-area.tsx
|
|
7
|
+
async function WidgetArea({ area, className, fallback, props }) {
|
|
8
|
+
const widgets = await require_ui.getModuleWidgets(area);
|
|
9
|
+
if (widgets.length === 0) return fallback || null;
|
|
10
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
11
|
+
className,
|
|
12
|
+
children: widgets.map((widget) => {
|
|
13
|
+
const Component = widget.component;
|
|
14
|
+
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(Component, { ...props }, widget.id);
|
|
15
|
+
})
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
//#endregion
|
|
20
|
+
exports.WidgetArea = WidgetArea;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as react_jsx_runtime0 from "react/jsx-runtime";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
|
|
4
|
+
//#region src/client/widget-area.d.ts
|
|
5
|
+
interface WidgetAreaProps {
|
|
6
|
+
area: string;
|
|
7
|
+
className?: string;
|
|
8
|
+
fallback?: React.ReactNode;
|
|
9
|
+
props?: any;
|
|
10
|
+
}
|
|
11
|
+
declare function WidgetArea({
|
|
12
|
+
area,
|
|
13
|
+
className,
|
|
14
|
+
fallback,
|
|
15
|
+
props
|
|
16
|
+
}: WidgetAreaProps): Promise<string | number | bigint | boolean | Iterable<React.ReactNode> | react_jsx_runtime0.JSX.Element | null | undefined>;
|
|
17
|
+
//#endregion
|
|
18
|
+
export { WidgetArea };
|
|
19
|
+
//# sourceMappingURL=widget-area.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"widget-area.d.cts","names":[],"sources":["../../src/client/widget-area.tsx"],"mappings":";;;;UAGU,eAAA;EACR,IAAA;EACA,SAAA;EACA,QAAA,GAAW,KAAA,CAAM,SAAA;EAEjB,KAAA;AAAA;AAAA,iBAGoB,UAAA,CAAA;EACpB,IAAA;EACA,SAAA;EACA,QAAA;EACA;AAAA,GACC,eAAA,GAAe,OAAA,sCAAA,QAAA,CAAA,KAAA,CAAA,SAAA,IAAA,kBAAA,CAAA,GAAA,CAAA,OAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import * as react_jsx_runtime0 from "react/jsx-runtime";
|
|
3
|
+
|
|
4
|
+
//#region src/client/widget-area.d.ts
|
|
5
|
+
interface WidgetAreaProps {
|
|
6
|
+
area: string;
|
|
7
|
+
className?: string;
|
|
8
|
+
fallback?: React.ReactNode;
|
|
9
|
+
props?: any;
|
|
10
|
+
}
|
|
11
|
+
declare function WidgetArea({
|
|
12
|
+
area,
|
|
13
|
+
className,
|
|
14
|
+
fallback,
|
|
15
|
+
props
|
|
16
|
+
}: WidgetAreaProps): Promise<string | number | bigint | boolean | Iterable<React.ReactNode> | react_jsx_runtime0.JSX.Element | null | undefined>;
|
|
17
|
+
//#endregion
|
|
18
|
+
export { WidgetArea };
|
|
19
|
+
//# sourceMappingURL=widget-area.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"widget-area.d.mts","names":[],"sources":["../../src/client/widget-area.tsx"],"mappings":";;;;UAGU,eAAA;EACR,IAAA;EACA,SAAA;EACA,QAAA,GAAW,KAAA,CAAM,SAAA;EAEjB,KAAA;AAAA;AAAA,iBAGoB,UAAA,CAAA;EACpB,IAAA;EACA,SAAA;EACA,QAAA;EACA;AAAA,GACC,eAAA,GAAe,OAAA,sCAAA,QAAA,CAAA,KAAA,CAAA,SAAA,IAAA,kBAAA,CAAA,GAAA,CAAA,OAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { getModuleWidgets } from "../server/ui.mjs";
|
|
2
|
+
import "react";
|
|
3
|
+
import { jsx } from "react/jsx-runtime";
|
|
4
|
+
|
|
5
|
+
//#region src/client/widget-area.tsx
|
|
6
|
+
async function WidgetArea({ area, className, fallback, props }) {
|
|
7
|
+
const widgets = await getModuleWidgets(area);
|
|
8
|
+
if (widgets.length === 0) return fallback || null;
|
|
9
|
+
return /* @__PURE__ */ jsx("div", {
|
|
10
|
+
className,
|
|
11
|
+
children: widgets.map((widget) => {
|
|
12
|
+
const Component = widget.component;
|
|
13
|
+
return /* @__PURE__ */ jsx(Component, { ...props }, widget.id);
|
|
14
|
+
})
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
//#endregion
|
|
19
|
+
export { WidgetArea };
|
|
20
|
+
//# sourceMappingURL=widget-area.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"widget-area.mjs","names":[],"sources":["../../src/client/widget-area.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { getModuleWidgets } from \"../server/ui\";\n\ninterface WidgetAreaProps {\n area: string;\n className?: string;\n fallback?: React.ReactNode;\n // Przekazywanie dowolnych propsów do widgetów (np. dane użytkownika)\n props?: any;\n}\n\nexport async function WidgetArea({\n area,\n className,\n fallback,\n props,\n}: WidgetAreaProps) {\n const widgets = await getModuleWidgets(area);\n\n if (widgets.length === 0) {\n return fallback || null;\n }\n\n return (\n <div className={className}>\n {widgets.map((widget) => {\n const Component = widget.component;\n return <Component key={widget.id} {...props} />;\n })}\n </div>\n );\n}\n"],"mappings":";;;;;AAWA,eAAsB,WAAW,EAC/B,MACA,WACA,UACA,SACkB;CAClB,MAAM,UAAU,MAAM,iBAAiB,KAAK;AAE5C,KAAI,QAAQ,WAAW,EACrB,QAAO,YAAY;AAGrB,QACE,oBAAC;EAAe;YACb,QAAQ,KAAK,WAAW;GACvB,MAAM,YAAY,OAAO;AACzB,UAAO,oBAAC,aAA0B,GAAI,SAAf,OAAO,GAAiB;IAC/C;GACE"}
|
package/dist/index.cjs
CHANGED
|
@@ -1,24 +1,10 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
2
|
-
const
|
|
3
|
-
require(
|
|
4
|
-
|
|
2
|
+
const require_types = require('./types.cjs');
|
|
3
|
+
const require_ui = require('./server/ui.cjs');
|
|
4
|
+
const require_widget_area = require('./client/widget-area.cjs');
|
|
5
5
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
const widgets = await require_ui.getModuleWidgets(area);
|
|
9
|
-
if (widgets.length === 0) return fallback || null;
|
|
10
|
-
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)("div", {
|
|
11
|
-
className,
|
|
12
|
-
children: widgets.map((widget) => {
|
|
13
|
-
const Component = widget.component;
|
|
14
|
-
return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(Component, { ...props }, widget.id);
|
|
15
|
-
})
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
//#endregion
|
|
20
|
-
exports.ModuleManifestSchema = require_ui.ModuleManifestSchema;
|
|
21
|
-
exports.WidgetArea = WidgetArea;
|
|
6
|
+
exports.ModuleManifestSchema = require_types.ModuleManifestSchema;
|
|
7
|
+
exports.WidgetArea = require_widget_area.WidgetArea;
|
|
22
8
|
exports.getApiModuleRoutes = require_ui.getApiModuleRoutes;
|
|
23
9
|
exports.getExtensions = require_ui.getExtensions;
|
|
24
10
|
exports.getKryoModuleNavigationGrouped = require_ui.getKryoModuleNavigationGrouped;
|
package/dist/index.d.cts
CHANGED
|
@@ -1,20 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
//#region src/client/widget-area.d.ts
|
|
6
|
-
interface WidgetAreaProps {
|
|
7
|
-
area: string;
|
|
8
|
-
className?: string;
|
|
9
|
-
fallback?: React.ReactNode;
|
|
10
|
-
props?: any;
|
|
11
|
-
}
|
|
12
|
-
declare function WidgetArea({
|
|
13
|
-
area,
|
|
14
|
-
className,
|
|
15
|
-
fallback,
|
|
16
|
-
props
|
|
17
|
-
}: WidgetAreaProps): Promise<string | number | bigint | boolean | Iterable<React.ReactNode> | react_jsx_runtime0.JSX.Element | null | undefined>;
|
|
18
|
-
//#endregion
|
|
19
|
-
export { ApiRouteDefinition, IModule, ModuleExtension, ModuleManifest, ModuleManifestSchema, ModuleNavElement, ModuleNavigation, ModuleNavigationGroupMap, ModulePageProps, ModuleRouteDefinition, ModuleWidget, PrivateRouteDefinition, PublicRouteDefinition, SidebarGroupType, SidebarMenuItemType, SidebarMenuType, SystemEvent, WidgetArea, getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension };
|
|
20
|
-
//# sourceMappingURL=index.d.cts.map
|
|
1
|
+
import { WidgetArea } from "./client/widget-area.cjs";
|
|
2
|
+
import { ApiRouteDefinition, IModule, ModuleExtension, ModuleManifest, ModuleManifestSchema, ModuleNavElement, ModuleNavigation, ModuleNavigationGroupMap, ModulePageProps, ModuleRouteDefinition, ModuleWidget, PrivateRouteDefinition, PublicRouteDefinition, SidebarGroupType, SidebarMenuItemType, SidebarMenuType, SystemEvent } from "./types.cjs";
|
|
3
|
+
import { getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension } from "./server/ui.cjs";
|
|
4
|
+
export { ApiRouteDefinition, IModule, ModuleExtension, ModuleManifest, ModuleManifestSchema, ModuleNavElement, ModuleNavigation, ModuleNavigationGroupMap, ModulePageProps, ModuleRouteDefinition, ModuleWidget, PrivateRouteDefinition, PublicRouteDefinition, SidebarGroupType, SidebarMenuItemType, SidebarMenuType, SystemEvent, WidgetArea, getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension };
|
package/dist/index.d.mts
CHANGED
|
@@ -1,20 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
//#region src/client/widget-area.d.ts
|
|
6
|
-
interface WidgetAreaProps {
|
|
7
|
-
area: string;
|
|
8
|
-
className?: string;
|
|
9
|
-
fallback?: React.ReactNode;
|
|
10
|
-
props?: any;
|
|
11
|
-
}
|
|
12
|
-
declare function WidgetArea({
|
|
13
|
-
area,
|
|
14
|
-
className,
|
|
15
|
-
fallback,
|
|
16
|
-
props
|
|
17
|
-
}: WidgetAreaProps): Promise<string | number | bigint | boolean | Iterable<React.ReactNode> | react_jsx_runtime0.JSX.Element | null | undefined>;
|
|
18
|
-
//#endregion
|
|
19
|
-
export { ApiRouteDefinition, IModule, ModuleExtension, ModuleManifest, ModuleManifestSchema, ModuleNavElement, ModuleNavigation, ModuleNavigationGroupMap, ModulePageProps, ModuleRouteDefinition, ModuleWidget, PrivateRouteDefinition, PublicRouteDefinition, SidebarGroupType, SidebarMenuItemType, SidebarMenuType, SystemEvent, WidgetArea, getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension };
|
|
20
|
-
//# sourceMappingURL=index.d.mts.map
|
|
1
|
+
import { WidgetArea } from "./client/widget-area.mjs";
|
|
2
|
+
import { ApiRouteDefinition, IModule, ModuleExtension, ModuleManifest, ModuleManifestSchema, ModuleNavElement, ModuleNavigation, ModuleNavigationGroupMap, ModulePageProps, ModuleRouteDefinition, ModuleWidget, PrivateRouteDefinition, PublicRouteDefinition, SidebarGroupType, SidebarMenuItemType, SidebarMenuType, SystemEvent } from "./types.mjs";
|
|
3
|
+
import { getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension } from "./server/ui.mjs";
|
|
4
|
+
export { ApiRouteDefinition, IModule, ModuleExtension, ModuleManifest, ModuleManifestSchema, ModuleNavElement, ModuleNavigation, ModuleNavigationGroupMap, ModulePageProps, ModuleRouteDefinition, ModuleWidget, PrivateRouteDefinition, PublicRouteDefinition, SidebarGroupType, SidebarMenuItemType, SidebarMenuType, SystemEvent, WidgetArea, getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension };
|
package/dist/index.mjs
CHANGED
|
@@ -1,20 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import "
|
|
3
|
-
import {
|
|
1
|
+
import { ModuleManifestSchema } from "./types.mjs";
|
|
2
|
+
import { getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension } from "./server/ui.mjs";
|
|
3
|
+
import { WidgetArea } from "./client/widget-area.mjs";
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
async function WidgetArea({ area, className, fallback, props }) {
|
|
7
|
-
const widgets = await getModuleWidgets(area);
|
|
8
|
-
if (widgets.length === 0) return fallback || null;
|
|
9
|
-
return /* @__PURE__ */ jsx("div", {
|
|
10
|
-
className,
|
|
11
|
-
children: widgets.map((widget) => {
|
|
12
|
-
const Component = widget.component;
|
|
13
|
-
return /* @__PURE__ */ jsx(Component, { ...props }, widget.id);
|
|
14
|
-
})
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
//#endregion
|
|
19
|
-
export { ModuleManifestSchema, WidgetArea, getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension };
|
|
20
|
-
//# sourceMappingURL=index.mjs.map
|
|
5
|
+
export { ModuleManifestSchema, WidgetArea, getApiModuleRoutes, getExtensions, getKryoModuleNavigationGrouped, getKryoModuleRoutes, getKryoPathPrefix, getModuleNavigation, getModuleNavigationGrouped, getModuleWidgets, getPrivateModuleRoutes, getPublicModuleRoutes, hasExtension };
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
"use server";
|
|
2
|
+
|
|
3
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
|
|
4
|
+
const require_manage = require('./manage.cjs');
|
|
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);
|
|
10
|
+
let _arch_cadre_core = require("@arch-cadre/core");
|
|
11
|
+
let drizzle_orm = require("drizzle-orm");
|
|
12
|
+
let node_child_process = require("node:child_process");
|
|
13
|
+
let node_util = require("node:util");
|
|
14
|
+
|
|
15
|
+
//#region src/server/lifecycle.ts
|
|
16
|
+
const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
17
|
+
async function updateStep(moduleId, step) {
|
|
18
|
+
console.log(`[Kernel] "${moduleId}" step: ${step}`);
|
|
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));
|
|
20
|
+
}
|
|
21
|
+
async function resolveSchemaPath(moduleId) {
|
|
22
|
+
const root = process.cwd();
|
|
23
|
+
if (moduleId === "@arch-cadre/core" || moduleId === "core") {
|
|
24
|
+
const p = node_path.default.join(root, "node_modules", "@kryo", "core", "dist", "server", "database", "schema.cjs");
|
|
25
|
+
try {
|
|
26
|
+
await node_fs_promises.default.access(p);
|
|
27
|
+
return p;
|
|
28
|
+
} catch {
|
|
29
|
+
const devP = node_path.default.resolve(root, "../../packages/kryo-core/src/server/database/schema.ts");
|
|
30
|
+
try {
|
|
31
|
+
await node_fs_promises.default.access(devP);
|
|
32
|
+
return devP;
|
|
33
|
+
} catch {}
|
|
34
|
+
}
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
const cleanId = moduleId.replace("@arch-cadre/", "");
|
|
38
|
+
const possible = [
|
|
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")
|
|
48
|
+
];
|
|
49
|
+
for (const p of possible) try {
|
|
50
|
+
await node_fs_promises.default.access(p);
|
|
51
|
+
console.log(`[Kernel:Lifecycle] Resolved schema for ${moduleId} at: ${p}`);
|
|
52
|
+
return p;
|
|
53
|
+
} catch {
|
|
54
|
+
console.warn(`[Kernel:Lifecycle] Unresolved schema for ${moduleId} at: ${p}`);
|
|
55
|
+
}
|
|
56
|
+
console.warn(`[Kernel:Lifecycle] Could not resolve schema path for: ${moduleId}`);
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
async function pushModuleSchema(moduleId) {
|
|
60
|
+
const execAsync = (0, node_util.promisify)(node_child_process.exec);
|
|
61
|
+
console.log(`[Kernel:Lifecycle] Targeted sync for module: ${moduleId}`);
|
|
62
|
+
const root = process.cwd();
|
|
63
|
+
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));
|
|
64
|
+
const activeModuleIds = new Set(enabledFromDb.map((m) => m.id));
|
|
65
|
+
activeModuleIds.add("@arch-cadre/core");
|
|
66
|
+
activeModuleIds.add(moduleId);
|
|
67
|
+
const schemaPaths = [];
|
|
68
|
+
for (const id of Array.from(activeModuleIds)) {
|
|
69
|
+
const p = await resolveSchemaPath(id);
|
|
70
|
+
if (p) schemaPaths.push(p);
|
|
71
|
+
}
|
|
72
|
+
if (schemaPaths.length === 0) {
|
|
73
|
+
console.warn(`[Kernel:Lifecycle] No schema paths resolved for ${moduleId}, skipping push.`);
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
const configPath = node_path.default.join(root, "drizzle.config.ts");
|
|
77
|
+
const cmd = `"${node_path.default.join(root, "node_modules", ".bin", "drizzle-kit")}" push --force --config=${configPath}`;
|
|
78
|
+
console.log(`[Kernel:Lifecycle] Executing isolated migration. Modules: ${Array.from(activeModuleIds).join(", ")}`);
|
|
79
|
+
try {
|
|
80
|
+
await execAsync(cmd, {
|
|
81
|
+
env: {
|
|
82
|
+
...process.env,
|
|
83
|
+
CI: "true",
|
|
84
|
+
DRIZZLE_SCHEMA_OVERRIDE: schemaPaths.join(",")
|
|
85
|
+
},
|
|
86
|
+
cwd: root
|
|
87
|
+
});
|
|
88
|
+
console.log(`[Kernel:Lifecycle] Isolated migration successful for ${moduleId}`);
|
|
89
|
+
} catch (e) {
|
|
90
|
+
console.error(`[Kernel:Lifecycle] Isolated migration failed for ${moduleId}:`);
|
|
91
|
+
console.error(e.stdout || e.message);
|
|
92
|
+
throw new Error(`Migration failed: ${moduleId}`);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
async function performToggle(moduleId, isEnabled) {
|
|
96
|
+
try {
|
|
97
|
+
const allModules = await require_manage.getModules();
|
|
98
|
+
const manifest = allModules.find((m) => m.id === moduleId);
|
|
99
|
+
await updateStep(moduleId, "Validate module...");
|
|
100
|
+
await sleep(500);
|
|
101
|
+
if (!manifest) return;
|
|
102
|
+
if (isEnabled) {
|
|
103
|
+
await updateStep(moduleId, "Queued...");
|
|
104
|
+
await sleep(500);
|
|
105
|
+
if (manifest.dependencies?.length) {
|
|
106
|
+
const pendingDeps = manifest.dependencies.filter((depId) => {
|
|
107
|
+
const dep = allModules.find((m) => m.id === depId);
|
|
108
|
+
return dep && !dep.enabled && !dep.system;
|
|
109
|
+
});
|
|
110
|
+
if (pendingDeps.length > 0) for (const depId of pendingDeps) {
|
|
111
|
+
await updateStep(moduleId, `Waiting for dependency "${depId}"...`);
|
|
112
|
+
await performToggle(depId, true);
|
|
113
|
+
await sleep(500);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
await updateStep(moduleId, "Initializing...");
|
|
117
|
+
await sleep(500);
|
|
118
|
+
await _arch_cadre_core_server.db.update(_arch_cadre_core.systemModulesTable).set({ enabled: true }).where((0, drizzle_orm.eq)(_arch_cadre_core.systemModulesTable.id, moduleId));
|
|
119
|
+
const instance = await require_manage.getModuleInstance(moduleId);
|
|
120
|
+
await updateStep(moduleId, "Migrate database...");
|
|
121
|
+
await sleep(500);
|
|
122
|
+
try {
|
|
123
|
+
if (instance?.onMigrate) await instance.onMigrate();
|
|
124
|
+
else await pushModuleSchema(moduleId);
|
|
125
|
+
await updateStep(moduleId, "Migration successful");
|
|
126
|
+
} catch (e) {
|
|
127
|
+
console.error(`[Kernel] Migration failed for ${moduleId}:`, e);
|
|
128
|
+
await updateStep(moduleId, `Migration failed: ${e.message}`);
|
|
129
|
+
await sleep(500);
|
|
130
|
+
}
|
|
131
|
+
if (instance?.onEnable) {
|
|
132
|
+
await updateStep(moduleId, "Running setup...");
|
|
133
|
+
await sleep(500);
|
|
134
|
+
await instance.onEnable();
|
|
135
|
+
}
|
|
136
|
+
await updateStep(moduleId, "Finishing...");
|
|
137
|
+
await sleep(500);
|
|
138
|
+
await _arch_cadre_core_server.db.update(_arch_cadre_core.systemModulesTable).set({
|
|
139
|
+
installed: true,
|
|
140
|
+
lastStep: null
|
|
141
|
+
}).where((0, drizzle_orm.eq)(_arch_cadre_core.systemModulesTable.id, moduleId));
|
|
142
|
+
} else {
|
|
143
|
+
const dependents = allModules.filter((m) => {
|
|
144
|
+
if (!m.enabled || m.id === moduleId) return false;
|
|
145
|
+
if (m.dependencies?.includes(moduleId)) return true;
|
|
146
|
+
if (m.extends?.includes(moduleId)) return m.extends.filter((targetId) => {
|
|
147
|
+
if (targetId === moduleId) return false;
|
|
148
|
+
return allModules.find((mod) => mod.id === targetId)?.enabled;
|
|
149
|
+
}).length === 0;
|
|
150
|
+
return false;
|
|
151
|
+
});
|
|
152
|
+
if (dependents.length > 0) {
|
|
153
|
+
await updateStep(moduleId, `Deactivating dependents...`);
|
|
154
|
+
for (const dep of dependents) {
|
|
155
|
+
await performToggle(dep.id, false);
|
|
156
|
+
await sleep(500);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
await updateStep(moduleId, "Deactivating...");
|
|
160
|
+
const instance = await require_manage.getModuleInstance(moduleId);
|
|
161
|
+
if (instance?.onDisable) await instance.onDisable();
|
|
162
|
+
await _arch_cadre_core_server.db.update(_arch_cadre_core.systemModulesTable).set({
|
|
163
|
+
enabled: false,
|
|
164
|
+
installed: false
|
|
165
|
+
}).where((0, drizzle_orm.eq)(_arch_cadre_core.systemModulesTable.id, moduleId));
|
|
166
|
+
await updateStep(moduleId, null);
|
|
167
|
+
}
|
|
168
|
+
} catch (e) {
|
|
169
|
+
console.error(`[Kernel] Fatal error for ${moduleId}:`, e);
|
|
170
|
+
await updateStep(moduleId, `Error: ${e.message}`);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
async function toggleModuleState(moduleId, isEnabled) {
|
|
174
|
+
const manifest = (await require_manage.getModules()).find((m) => m.id === moduleId);
|
|
175
|
+
if (!manifest) throw new Error(`Module "${moduleId}" not found`);
|
|
176
|
+
if (manifest.enabled === isEnabled) return { success: true };
|
|
177
|
+
performToggle(moduleId, isEnabled);
|
|
178
|
+
return { success: true };
|
|
179
|
+
}
|
|
180
|
+
async function initOperationalModules() {
|
|
181
|
+
const allModules = await require_manage.getModules();
|
|
182
|
+
for (const mod of allModules) if (mod.enabled) try {
|
|
183
|
+
const instance = await require_manage.getModuleInstance(mod.id);
|
|
184
|
+
if (instance?.init) await instance.init();
|
|
185
|
+
} catch (e) {
|
|
186
|
+
console.error(`[Kernel] Failed to init module ${mod.id}:`, e);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
//#endregion
|
|
191
|
+
exports.initOperationalModules = initOperationalModules;
|
|
192
|
+
exports.pushModuleSchema = pushModuleSchema;
|
|
193
|
+
exports.toggleModuleState = toggleModuleState;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
//#region src/server/lifecycle.d.ts
|
|
2
|
+
declare function pushModuleSchema(moduleId: string): Promise<void>;
|
|
3
|
+
declare function toggleModuleState(moduleId: string, isEnabled: boolean): Promise<{
|
|
4
|
+
success: boolean;
|
|
5
|
+
}>;
|
|
6
|
+
declare function initOperationalModules(): Promise<void>;
|
|
7
|
+
//#endregion
|
|
8
|
+
export { initOperationalModules, pushModuleSchema, toggleModuleState };
|
|
9
|
+
//# sourceMappingURL=lifecycle.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifecycle.d.cts","names":[],"sources":["../../src/server/lifecycle.ts"],"mappings":";iBA4GsB,gBAAA,CAAiB,QAAA,WAAgB,OAAA;AAAA,iBAwLjC,iBAAA,CAAkB,QAAA,UAAkB,SAAA,YAAkB,OAAA;;;iBAWtD,sBAAA,CAAA,GAAsB,OAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
//#region src/server/lifecycle.d.ts
|
|
2
|
+
declare function pushModuleSchema(moduleId: string): Promise<void>;
|
|
3
|
+
declare function toggleModuleState(moduleId: string, isEnabled: boolean): Promise<{
|
|
4
|
+
success: boolean;
|
|
5
|
+
}>;
|
|
6
|
+
declare function initOperationalModules(): Promise<void>;
|
|
7
|
+
//#endregion
|
|
8
|
+
export { initOperationalModules, pushModuleSchema, toggleModuleState };
|
|
9
|
+
//# sourceMappingURL=lifecycle.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifecycle.d.mts","names":[],"sources":["../../src/server/lifecycle.ts"],"mappings":";iBA4GsB,gBAAA,CAAiB,QAAA,WAAgB,OAAA;AAAA,iBAwLjC,iBAAA,CAAkB,QAAA,UAAkB,SAAA,YAAkB,OAAA;;;iBAWtD,sBAAA,CAAA,GAAsB,OAAA"}
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
"use server";
|
|
2
|
+
|
|
3
|
+
import { getModuleInstance, getModules } from "./manage.mjs";
|
|
4
|
+
import { db } from "@arch-cadre/core/server";
|
|
5
|
+
import fs from "node:fs/promises";
|
|
6
|
+
import path from "node:path";
|
|
7
|
+
import { systemModulesTable } from "@arch-cadre/core";
|
|
8
|
+
import { eq } from "drizzle-orm";
|
|
9
|
+
import { exec } from "node:child_process";
|
|
10
|
+
import { promisify } from "node:util";
|
|
11
|
+
|
|
12
|
+
//#region src/server/lifecycle.ts
|
|
13
|
+
const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
14
|
+
async function updateStep(moduleId, step) {
|
|
15
|
+
console.log(`[Kernel] "${moduleId}" step: ${step}`);
|
|
16
|
+
await db.update(systemModulesTable).set({ lastStep: step }).where(eq(systemModulesTable.id, moduleId));
|
|
17
|
+
}
|
|
18
|
+
async function resolveSchemaPath(moduleId) {
|
|
19
|
+
const root = process.cwd();
|
|
20
|
+
if (moduleId === "@arch-cadre/core" || moduleId === "core") {
|
|
21
|
+
const p = path.join(root, "node_modules", "@kryo", "core", "dist", "server", "database", "schema.cjs");
|
|
22
|
+
try {
|
|
23
|
+
await fs.access(p);
|
|
24
|
+
return p;
|
|
25
|
+
} catch {
|
|
26
|
+
const devP = path.resolve(root, "../../packages/kryo-core/src/server/database/schema.ts");
|
|
27
|
+
try {
|
|
28
|
+
await fs.access(devP);
|
|
29
|
+
return devP;
|
|
30
|
+
} catch {}
|
|
31
|
+
}
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
const cleanId = moduleId.replace("@arch-cadre/", "");
|
|
35
|
+
const possible = [
|
|
36
|
+
path.join(root, "modules", cleanId, "schema.ts"),
|
|
37
|
+
path.join(root, "modules", moduleId, "schema.ts"),
|
|
38
|
+
path.join(root, "node_modules", moduleId, "dist", "schema.cjs"),
|
|
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"),
|
|
42
|
+
path.resolve(root, "../../packages", cleanId, "src", "schema.ts"),
|
|
43
|
+
path.resolve(root, "../../packages", `kryo-${cleanId}`, "src", "schema.ts"),
|
|
44
|
+
path.resolve(root, "../../packages", cleanId, "schema.ts")
|
|
45
|
+
];
|
|
46
|
+
for (const p of possible) try {
|
|
47
|
+
await fs.access(p);
|
|
48
|
+
console.log(`[Kernel:Lifecycle] Resolved schema for ${moduleId} at: ${p}`);
|
|
49
|
+
return p;
|
|
50
|
+
} catch {
|
|
51
|
+
console.warn(`[Kernel:Lifecycle] Unresolved schema for ${moduleId} at: ${p}`);
|
|
52
|
+
}
|
|
53
|
+
console.warn(`[Kernel:Lifecycle] Could not resolve schema path for: ${moduleId}`);
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
async function pushModuleSchema(moduleId) {
|
|
57
|
+
const execAsync = promisify(exec);
|
|
58
|
+
console.log(`[Kernel:Lifecycle] Targeted sync for module: ${moduleId}`);
|
|
59
|
+
const root = process.cwd();
|
|
60
|
+
const enabledFromDb = await db.select({ id: systemModulesTable.id }).from(systemModulesTable).where(eq(systemModulesTable.enabled, true));
|
|
61
|
+
const activeModuleIds = new Set(enabledFromDb.map((m) => m.id));
|
|
62
|
+
activeModuleIds.add("@arch-cadre/core");
|
|
63
|
+
activeModuleIds.add(moduleId);
|
|
64
|
+
const schemaPaths = [];
|
|
65
|
+
for (const id of Array.from(activeModuleIds)) {
|
|
66
|
+
const p = await resolveSchemaPath(id);
|
|
67
|
+
if (p) schemaPaths.push(p);
|
|
68
|
+
}
|
|
69
|
+
if (schemaPaths.length === 0) {
|
|
70
|
+
console.warn(`[Kernel:Lifecycle] No schema paths resolved for ${moduleId}, skipping push.`);
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
const configPath = path.join(root, "drizzle.config.ts");
|
|
74
|
+
const cmd = `"${path.join(root, "node_modules", ".bin", "drizzle-kit")}" push --force --config=${configPath}`;
|
|
75
|
+
console.log(`[Kernel:Lifecycle] Executing isolated migration. Modules: ${Array.from(activeModuleIds).join(", ")}`);
|
|
76
|
+
try {
|
|
77
|
+
await execAsync(cmd, {
|
|
78
|
+
env: {
|
|
79
|
+
...process.env,
|
|
80
|
+
CI: "true",
|
|
81
|
+
DRIZZLE_SCHEMA_OVERRIDE: schemaPaths.join(",")
|
|
82
|
+
},
|
|
83
|
+
cwd: root
|
|
84
|
+
});
|
|
85
|
+
console.log(`[Kernel:Lifecycle] Isolated migration successful for ${moduleId}`);
|
|
86
|
+
} catch (e) {
|
|
87
|
+
console.error(`[Kernel:Lifecycle] Isolated migration failed for ${moduleId}:`);
|
|
88
|
+
console.error(e.stdout || e.message);
|
|
89
|
+
throw new Error(`Migration failed: ${moduleId}`);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
async function performToggle(moduleId, isEnabled) {
|
|
93
|
+
try {
|
|
94
|
+
const allModules = await getModules();
|
|
95
|
+
const manifest = allModules.find((m) => m.id === moduleId);
|
|
96
|
+
await updateStep(moduleId, "Validate module...");
|
|
97
|
+
await sleep(500);
|
|
98
|
+
if (!manifest) return;
|
|
99
|
+
if (isEnabled) {
|
|
100
|
+
await updateStep(moduleId, "Queued...");
|
|
101
|
+
await sleep(500);
|
|
102
|
+
if (manifest.dependencies?.length) {
|
|
103
|
+
const pendingDeps = manifest.dependencies.filter((depId) => {
|
|
104
|
+
const dep = allModules.find((m) => m.id === depId);
|
|
105
|
+
return dep && !dep.enabled && !dep.system;
|
|
106
|
+
});
|
|
107
|
+
if (pendingDeps.length > 0) for (const depId of pendingDeps) {
|
|
108
|
+
await updateStep(moduleId, `Waiting for dependency "${depId}"...`);
|
|
109
|
+
await performToggle(depId, true);
|
|
110
|
+
await sleep(500);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
await updateStep(moduleId, "Initializing...");
|
|
114
|
+
await sleep(500);
|
|
115
|
+
await db.update(systemModulesTable).set({ enabled: true }).where(eq(systemModulesTable.id, moduleId));
|
|
116
|
+
const instance = await getModuleInstance(moduleId);
|
|
117
|
+
await updateStep(moduleId, "Migrate database...");
|
|
118
|
+
await sleep(500);
|
|
119
|
+
try {
|
|
120
|
+
if (instance?.onMigrate) await instance.onMigrate();
|
|
121
|
+
else await pushModuleSchema(moduleId);
|
|
122
|
+
await updateStep(moduleId, "Migration successful");
|
|
123
|
+
} catch (e) {
|
|
124
|
+
console.error(`[Kernel] Migration failed for ${moduleId}:`, e);
|
|
125
|
+
await updateStep(moduleId, `Migration failed: ${e.message}`);
|
|
126
|
+
await sleep(500);
|
|
127
|
+
}
|
|
128
|
+
if (instance?.onEnable) {
|
|
129
|
+
await updateStep(moduleId, "Running setup...");
|
|
130
|
+
await sleep(500);
|
|
131
|
+
await instance.onEnable();
|
|
132
|
+
}
|
|
133
|
+
await updateStep(moduleId, "Finishing...");
|
|
134
|
+
await sleep(500);
|
|
135
|
+
await db.update(systemModulesTable).set({
|
|
136
|
+
installed: true,
|
|
137
|
+
lastStep: null
|
|
138
|
+
}).where(eq(systemModulesTable.id, moduleId));
|
|
139
|
+
} else {
|
|
140
|
+
const dependents = allModules.filter((m) => {
|
|
141
|
+
if (!m.enabled || m.id === moduleId) return false;
|
|
142
|
+
if (m.dependencies?.includes(moduleId)) return true;
|
|
143
|
+
if (m.extends?.includes(moduleId)) return m.extends.filter((targetId) => {
|
|
144
|
+
if (targetId === moduleId) return false;
|
|
145
|
+
return allModules.find((mod) => mod.id === targetId)?.enabled;
|
|
146
|
+
}).length === 0;
|
|
147
|
+
return false;
|
|
148
|
+
});
|
|
149
|
+
if (dependents.length > 0) {
|
|
150
|
+
await updateStep(moduleId, `Deactivating dependents...`);
|
|
151
|
+
for (const dep of dependents) {
|
|
152
|
+
await performToggle(dep.id, false);
|
|
153
|
+
await sleep(500);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
await updateStep(moduleId, "Deactivating...");
|
|
157
|
+
const instance = await getModuleInstance(moduleId);
|
|
158
|
+
if (instance?.onDisable) await instance.onDisable();
|
|
159
|
+
await db.update(systemModulesTable).set({
|
|
160
|
+
enabled: false,
|
|
161
|
+
installed: false
|
|
162
|
+
}).where(eq(systemModulesTable.id, moduleId));
|
|
163
|
+
await updateStep(moduleId, null);
|
|
164
|
+
}
|
|
165
|
+
} catch (e) {
|
|
166
|
+
console.error(`[Kernel] Fatal error for ${moduleId}:`, e);
|
|
167
|
+
await updateStep(moduleId, `Error: ${e.message}`);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
async function toggleModuleState(moduleId, isEnabled) {
|
|
171
|
+
const manifest = (await getModules()).find((m) => m.id === moduleId);
|
|
172
|
+
if (!manifest) throw new Error(`Module "${moduleId}" not found`);
|
|
173
|
+
if (manifest.enabled === isEnabled) return { success: true };
|
|
174
|
+
performToggle(moduleId, isEnabled);
|
|
175
|
+
return { success: true };
|
|
176
|
+
}
|
|
177
|
+
async function initOperationalModules() {
|
|
178
|
+
const allModules = await getModules();
|
|
179
|
+
for (const mod of allModules) if (mod.enabled) try {
|
|
180
|
+
const instance = await getModuleInstance(mod.id);
|
|
181
|
+
if (instance?.init) await instance.init();
|
|
182
|
+
} catch (e) {
|
|
183
|
+
console.error(`[Kernel] Failed to init module ${mod.id}:`, e);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
//#endregion
|
|
188
|
+
export { initOperationalModules, pushModuleSchema, toggleModuleState };
|
|
189
|
+
//# sourceMappingURL=lifecycle.mjs.map
|