everything-dev 1.14.1 → 1.14.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/dist/cli/upgrade.cjs +2 -1
  2. package/dist/cli/upgrade.cjs.map +1 -1
  3. package/dist/cli/upgrade.mjs +2 -1
  4. package/dist/cli/upgrade.mjs.map +1 -1
  5. package/dist/contract.d.cts +33 -33
  6. package/dist/contract.d.mts +33 -33
  7. package/dist/orchestrator.cjs +0 -1
  8. package/dist/orchestrator.cjs.map +1 -1
  9. package/dist/plugin.d.cts +33 -33
  10. package/dist/plugin.d.mts +33 -33
  11. package/dist/shared.cjs +0 -10
  12. package/dist/shared.cjs.map +1 -1
  13. package/dist/shared.mjs +1 -9
  14. package/dist/shared.mjs.map +1 -1
  15. package/dist/types.d.cts +2 -2
  16. package/dist/types.d.mts +2 -2
  17. package/package.json +4 -30
  18. package/src/cli/upgrade.ts +1 -0
  19. package/dist/api.cjs +0 -124
  20. package/dist/api.cjs.map +0 -1
  21. package/dist/api.d.cts +0 -36
  22. package/dist/api.d.cts.map +0 -1
  23. package/dist/api.d.mts +0 -36
  24. package/dist/api.d.mts.map +0 -1
  25. package/dist/api.mjs +0 -119
  26. package/dist/api.mjs.map +0 -1
  27. package/dist/federation.server.cjs +0 -27
  28. package/dist/federation.server.cjs.map +0 -1
  29. package/dist/federation.server.mjs +0 -27
  30. package/dist/federation.server.mjs.map +0 -1
  31. package/dist/host.cjs +0 -402
  32. package/dist/host.cjs.map +0 -1
  33. package/dist/host.d.cts +0 -22
  34. package/dist/host.d.cts.map +0 -1
  35. package/dist/host.d.mts +0 -22
  36. package/dist/host.d.mts.map +0 -1
  37. package/dist/host.mjs +0 -399
  38. package/dist/host.mjs.map +0 -1
  39. package/dist/orchestrator.d.cts +0 -44
  40. package/dist/orchestrator.d.cts.map +0 -1
  41. package/dist/orchestrator.d.mts +0 -44
  42. package/dist/orchestrator.d.mts.map +0 -1
  43. package/dist/service-descriptor.d.cts +0 -137
  44. package/dist/service-descriptor.d.cts.map +0 -1
  45. package/dist/service-descriptor.d.mts +0 -137
  46. package/dist/service-descriptor.d.mts.map +0 -1
  47. package/dist/shared.d.cts +0 -36
  48. package/dist/shared.d.cts.map +0 -1
  49. package/dist/shared.d.mts +0 -36
  50. package/dist/shared.d.mts.map +0 -1
  51. package/src/api.ts +0 -181
  52. package/src/federation.server.ts +0 -43
  53. package/src/host.ts +0 -573
package/dist/host.mjs DELETED
@@ -1,399 +0,0 @@
1
- import { createStitchedRouter, loadApiPluginsFromRuntimeConfig } from "./api.mjs";
2
- import { loadRouterModule } from "./federation.server.mjs";
3
- import { serve } from "@hono/node-server";
4
- import { OpenAPIHandler } from "@orpc/openapi/fetch";
5
- import { OpenAPIReferencePlugin } from "@orpc/openapi/plugins";
6
- import { RPCHandler } from "@orpc/server/fetch";
7
- import { BatchHandlerPlugin } from "@orpc/server/plugins";
8
- import { ZodToJsonSchemaConverter } from "@orpc/zod/zod4";
9
- import { Hono } from "hono";
10
- import { cors } from "hono/cors";
11
- import { secureHeaders } from "hono/secure-headers";
12
-
13
- //#region src/host.ts
14
- function buildClientRuntimeConfig(runtimeConfig) {
15
- return {
16
- env: runtimeConfig.env,
17
- account: runtimeConfig.account,
18
- networkId: runtimeConfig.networkId,
19
- hostUrl: runtimeConfig.host.url,
20
- assetsUrl: runtimeConfig.ui.url,
21
- apiBase: "/api",
22
- rpcBase: "/api/rpc",
23
- authAvailable: !!runtimeConfig.auth,
24
- repository: runtimeConfig.repository,
25
- ui: runtimeConfig.ui ? {
26
- name: runtimeConfig.ui.name,
27
- url: runtimeConfig.ui.url,
28
- entry: runtimeConfig.ui.entry,
29
- integrity: runtimeConfig.ui.integrity
30
- } : void 0,
31
- api: runtimeConfig.api ? {
32
- name: runtimeConfig.api.name,
33
- url: runtimeConfig.api.url,
34
- entry: runtimeConfig.api.entry,
35
- integrity: runtimeConfig.api.integrity
36
- } : void 0,
37
- auth: runtimeConfig.auth ? {
38
- name: runtimeConfig.auth.name,
39
- url: runtimeConfig.auth.url,
40
- entry: runtimeConfig.auth.entry,
41
- integrity: runtimeConfig.auth.integrity,
42
- sidebar: runtimeConfig.auth.sidebar
43
- } : void 0,
44
- plugins: runtimeConfig.plugins ? Object.fromEntries(Object.entries(runtimeConfig.plugins).map(([key, plugin]) => [key, {
45
- name: plugin.name,
46
- url: plugin.url,
47
- entry: plugin.entry,
48
- integrity: plugin.integrity,
49
- ...plugin.ui ? { ui: {
50
- name: plugin.ui.name,
51
- url: plugin.ui.url,
52
- entry: plugin.ui.entry,
53
- source: plugin.ui.source,
54
- integrity: plugin.ui.integrity
55
- } } : {},
56
- ...plugin.sidebar ? { sidebar: plugin.sidebar } : {}
57
- }])) : void 0
58
- };
59
- }
60
- function renderLoadingShell(runtimeConfig, error) {
61
- const bootstrap = `window.__RUNTIME_CONFIG__ = ${JSON.stringify(runtimeConfig)};window.addEventListener('load', function handleEverythingDevHydrate() { window.__hydrate?.(); }, { once: true });`;
62
- const errorMarkup = error ? `<p style="color: #fca5a5;">Error loading UI: ${escapeHtml(error)}</p>` : "<p>Loading UI...</p>";
63
- const uiIntegrity = runtimeConfig.ui?.integrity;
64
- const sriAttr = uiIntegrity ? ` integrity="${uiIntegrity}" crossorigin="anonymous"` : "";
65
- const pluginUiScripts = Object.values(runtimeConfig.plugins ?? {}).filter((plugin) => plugin.ui?.url && plugin.ui.source === "remote").map((plugin) => {
66
- const uiIntegrity = plugin.ui.integrity;
67
- const sri = uiIntegrity ? ` integrity="${uiIntegrity}" crossorigin="anonymous"` : "";
68
- return `<script src="${plugin.ui.url}/remoteEntry.js"${sri}><\/script>`;
69
- }).join("\n");
70
- return `
71
- <!DOCTYPE html>
72
- <html lang="en">
73
- <head>
74
- <meta charset="utf-8" />
75
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
76
- <title>Loading...</title>
77
- <style>
78
- body { background: #171717; color: #fafafa; display: flex; align-items: center; justify-content: center; height: 100vh; font-family: system-ui; }
79
- .fade { animation: fadeIn 0.3s ease-in; text-align: center; padding: 2rem; }
80
- @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
81
- </style>
82
- ${runtimeConfig.assetsUrl ? `<script src="${runtimeConfig.assetsUrl}/remoteEntry.js"${sriAttr}><\/script>` : ""}
83
- ${pluginUiScripts}
84
- <script>${bootstrap}<\/script>
85
- </head>
86
- <body>
87
- <div id="root" class="fade">${errorMarkup}</div>
88
- </body>
89
- </html>
90
- `;
91
- }
92
- function escapeHtml(value) {
93
- return value.replaceAll("&", "&amp;").replaceAll("<", "&lt;").replaceAll(">", "&gt;").replaceAll("\"", "&quot;").replaceAll("'", "&#39;");
94
- }
95
- function createHostServer(config) {
96
- const port = config.port ?? 3e3;
97
- const { runtimeConfig } = config;
98
- let shutdownImpl = null;
99
- const ready = (async () => {
100
- shutdownImpl = (await runHostServer({
101
- runtimeConfig,
102
- port
103
- })).shutdown;
104
- })();
105
- const shutdown = async () => {
106
- console.log("[Host] Shutting down...");
107
- const timeout = setTimeout(() => {
108
- console.log("[Host] Force exit");
109
- process.exit(0);
110
- }, 5e3);
111
- await ready.catch(() => {});
112
- if (shutdownImpl) await shutdownImpl().catch(() => {});
113
- clearTimeout(timeout);
114
- console.log("[Host] Shutdown complete");
115
- };
116
- return {
117
- ready,
118
- shutdown
119
- };
120
- }
121
- async function runHostServer(opts) {
122
- const { runtimeConfig, port } = opts;
123
- let apiPlugins = [];
124
- let baseApiPlugin = null;
125
- let apiPluginError = null;
126
- let apiPluginLoading = null;
127
- let ssrRouterModule = null;
128
- let ssrRouterError = null;
129
- let ssrRouterLoading = null;
130
- let rpcHandler = null;
131
- let openApiHandler = null;
132
- const clientRuntimeConfig = buildClientRuntimeConfig(runtimeConfig);
133
- const initApiHandlers = () => {
134
- const stitchedRouter = createStitchedRouter(baseApiPlugin?.router ?? {}, apiPlugins.filter((plugin) => plugin.key !== "api"));
135
- if (!baseApiPlugin) {
136
- rpcHandler = null;
137
- openApiHandler = null;
138
- return;
139
- }
140
- rpcHandler = new RPCHandler(stitchedRouter, { plugins: [new BatchHandlerPlugin()] });
141
- openApiHandler = new OpenAPIHandler(stitchedRouter, { plugins: [new OpenAPIReferencePlugin({ schemaConverters: [new ZodToJsonSchemaConverter()] })] });
142
- };
143
- const ensureApiPluginLoaded = async () => {
144
- if (apiPlugins.length > 0) return {
145
- base: baseApiPlugin,
146
- plugins: apiPlugins,
147
- errors: []
148
- };
149
- if (!runtimeConfig.api) return null;
150
- if (apiPluginLoading) return apiPluginLoading;
151
- apiPluginLoading = loadApiPluginsFromRuntimeConfig(runtimeConfig, process.env).then((loaded) => {
152
- if (loaded) {
153
- apiPlugins = loaded.plugins;
154
- baseApiPlugin = loaded.base;
155
- apiPluginError = loaded.errors.length > 0 ? loaded.errors.map((item) => item.error).join("; ") : null;
156
- initApiHandlers();
157
- }
158
- return loaded;
159
- }).catch((e) => {
160
- apiPluginError = e instanceof Error ? e.message : String(e);
161
- return null;
162
- }).finally(() => {
163
- apiPluginLoading = null;
164
- });
165
- return apiPluginLoading;
166
- };
167
- const ensureRouterModuleLoaded = async () => {
168
- if (ssrRouterModule) return ssrRouterModule;
169
- if (ssrRouterLoading) return ssrRouterLoading;
170
- ssrRouterLoading = loadRouterModule(runtimeConfig).then((routerModule) => {
171
- ssrRouterModule = routerModule;
172
- ssrRouterError = null;
173
- return routerModule;
174
- }).catch((error) => {
175
- ssrRouterError = error instanceof Error ? error.message : String(error);
176
- return null;
177
- }).finally(() => {
178
- ssrRouterLoading = null;
179
- });
180
- return ssrRouterLoading;
181
- };
182
- ensureApiPluginLoaded();
183
- ensureRouterModuleLoaded();
184
- const app = new Hono();
185
- const corsOrigins = process.env.CORS_ORIGIN?.split(",").map((o) => o.trim()) ?? [runtimeConfig.host.url, ...runtimeConfig.ui?.url ? [runtimeConfig.ui.url] : []];
186
- if (!process.env.CORS_ORIGIN && runtimeConfig.env === "production") console.warn("[Security] CORS_ORIGIN is not set in production. Using host and UI URLs as allowed origins.");
187
- app.use("/*", cors({
188
- origin: corsOrigins,
189
- credentials: true
190
- }));
191
- app.use("*", secureHeaders({ crossOriginOpenerPolicy: "same-origin-allow-popups" }));
192
- app.get("/health", (c) => c.text("OK"));
193
- app.get("/ready", async (c) => {
194
- const probe = async (url, timeoutMs = 400) => {
195
- const started = Date.now();
196
- const controller = new AbortController();
197
- const timer = setTimeout(() => controller.abort(), timeoutMs);
198
- try {
199
- const res = await fetch(url, { signal: controller.signal });
200
- return {
201
- name: "",
202
- url,
203
- required: true,
204
- ok: res.ok,
205
- status: res.status,
206
- latencyMs: Date.now() - started
207
- };
208
- } catch (e) {
209
- return {
210
- name: "",
211
- url,
212
- required: true,
213
- ok: false,
214
- latencyMs: Date.now() - started,
215
- error: e instanceof Error ? e.message : String(e)
216
- };
217
- } finally {
218
- clearTimeout(timer);
219
- }
220
- };
221
- const checks = [];
222
- if (runtimeConfig.ui?.url) {
223
- const base = runtimeConfig.ui.url.replace(/\/$/, "");
224
- const manifest = await probe(`${base}/mf-manifest.json`);
225
- manifest.name = "ui";
226
- manifest.required = false;
227
- checks.push(manifest);
228
- if (!manifest.ok) {
229
- const remoteEntry = await probe(`${base}/remoteEntry.js`);
230
- remoteEntry.name = "ui";
231
- remoteEntry.required = true;
232
- checks.push(remoteEntry);
233
- } else manifest.required = true;
234
- }
235
- if (runtimeConfig.ui?.ssrUrl) {
236
- const ssr = await probe(`${runtimeConfig.ui.ssrUrl.replace(/\/$/, "")}/`);
237
- ssr.name = "ui-ssr";
238
- ssr.required = false;
239
- checks.push(ssr);
240
- }
241
- if (runtimeConfig.api?.url) {
242
- const api = await probe(`${runtimeConfig.api.url.replace(/\/$/, "")}/`);
243
- api.name = "api";
244
- api.required = true;
245
- checks.push(api);
246
- }
247
- if (runtimeConfig.api) {
248
- checks.push({
249
- name: "api-plugin",
250
- url: runtimeConfig.api.entry,
251
- required: true,
252
- ok: baseApiPlugin !== null,
253
- status: baseApiPlugin !== null ? 200 : 503,
254
- error: baseApiPlugin !== null ? void 0 : apiPluginLoading ? "loading" : apiPluginError ?? "not loaded"
255
- });
256
- if (!baseApiPlugin && !apiPluginLoading) ensureApiPluginLoaded();
257
- }
258
- for (const [key, plugin] of Object.entries(runtimeConfig.plugins ?? {})) {
259
- const loaded = apiPlugins.find((item) => item.key === key);
260
- checks.push({
261
- name: key,
262
- url: plugin.entry,
263
- required: true,
264
- ok: Boolean(loaded),
265
- status: loaded ? 200 : 503,
266
- error: loaded ? void 0 : apiPluginError ?? "not loaded"
267
- });
268
- }
269
- const allRequiredOk = checks.filter((x) => x.required).every((x) => x.ok);
270
- return c.json({
271
- status: allRequiredOk ? "ready" : "not_ready",
272
- host: {
273
- url: runtimeConfig.host.url,
274
- env: runtimeConfig.env
275
- },
276
- checks,
277
- timestamp: (/* @__PURE__ */ new Date()).toISOString()
278
- }, allRequiredOk ? 200 : 503);
279
- });
280
- app.get("/api/_health", (c) => c.json({
281
- status: "ready",
282
- mode: runtimeConfig.env,
283
- ui: runtimeConfig.ui?.url ?? null,
284
- uiSsr: runtimeConfig.ui?.ssrUrl ?? null,
285
- ssrRouterLoaded: ssrRouterModule !== null,
286
- ssrRouterLoading: ssrRouterLoading !== null,
287
- ssrRouterError,
288
- api: runtimeConfig.api?.url ?? null,
289
- apiPluginLoaded: baseApiPlugin !== null,
290
- apiPluginLoading: apiPluginLoading !== null,
291
- apiPluginError
292
- }));
293
- app.all("/api/rpc/*", async (c) => {
294
- if (!rpcHandler) await ensureApiPluginLoaded();
295
- if (!rpcHandler) return c.json({
296
- error: "API plugin not loaded",
297
- detail: apiPluginError
298
- }, 503);
299
- const result = await rpcHandler.handle(c.req.raw, {
300
- prefix: "/api/rpc",
301
- context: {}
302
- });
303
- return result.response ? c.newResponse(result.response.body, result.response) : c.text("Not Found", 404);
304
- });
305
- app.all("/api/*", async (c) => {
306
- if (!openApiHandler) await ensureApiPluginLoaded();
307
- if (!openApiHandler) return c.json({
308
- error: "API plugin not loaded",
309
- detail: apiPluginError
310
- }, 503);
311
- const result = await openApiHandler.handle(c.req.raw, {
312
- prefix: "/api",
313
- context: {}
314
- });
315
- return result.response ? c.newResponse(result.response.body, result.response) : c.text("Not Found", 404);
316
- });
317
- if (runtimeConfig.ui) {
318
- app.all("/__mf/ui/*", async (c) => {
319
- const targetUrl = `${runtimeConfig.ui.url}${c.req.path.replace("/__mf/ui", "")}`;
320
- return await fetch(targetUrl, {
321
- method: c.req.method,
322
- headers: c.req.header()
323
- });
324
- });
325
- if (runtimeConfig.ui.ssrUrl) app.all("/__mf/ui/ssr/*", async (c) => {
326
- const targetUrl = `${runtimeConfig.ui.ssrUrl}${c.req.path.replace("/__mf/ui/ssr", "")}`;
327
- return await fetch(targetUrl, {
328
- method: c.req.method,
329
- headers: c.req.header()
330
- });
331
- });
332
- }
333
- for (const [pluginKey, pluginConfig] of Object.entries(runtimeConfig.plugins ?? {})) {
334
- if (!pluginConfig.ui?.url) continue;
335
- const pluginUiUrl = pluginConfig.ui.url;
336
- const proxyPrefix = `/__mf/plugin-ui/${pluginKey}`;
337
- app.all(`${proxyPrefix}/*`, async (c) => {
338
- const targetUrl = `${pluginUiUrl}${c.req.path.replace(proxyPrefix, "")}`;
339
- return await fetch(targetUrl, {
340
- method: c.req.method,
341
- headers: c.req.header()
342
- });
343
- });
344
- }
345
- app.get("*", async (c) => {
346
- const routerModule = await ensureRouterModuleLoaded();
347
- if (!routerModule) return c.html(renderLoadingShell(clientRuntimeConfig, ssrRouterError), 503);
348
- try {
349
- const apiClient = baseApiPlugin?.createClient();
350
- const result = await routerModule.renderToStream(c.req.raw, {
351
- assetsUrl: runtimeConfig.ui.url,
352
- runtimeConfig: clientRuntimeConfig,
353
- apiClient
354
- });
355
- return new Response(result.stream, {
356
- status: result.statusCode,
357
- headers: result.headers
358
- });
359
- } catch (error) {
360
- const message = error instanceof Error ? error.message : String(error);
361
- return c.html(renderLoadingShell(clientRuntimeConfig, message), 500);
362
- }
363
- });
364
- const hostname = process.env.HOST ?? "0.0.0.0";
365
- let resolveReady = null;
366
- const ready = new Promise((resolve) => {
367
- resolveReady = resolve;
368
- });
369
- const proxiedFetch = (req) => {
370
- const url = new URL(req.url);
371
- const forwardedProto = req.headers.get("x-forwarded-proto");
372
- const forwardedHost = req.headers.get("x-forwarded-host");
373
- if (forwardedProto) url.protocol = forwardedProto;
374
- if (forwardedHost) url.host = forwardedHost;
375
- if (forwardedProto || forwardedHost) req = new Request(url, req);
376
- return app.fetch(req);
377
- };
378
- const server = serve({
379
- fetch: proxiedFetch,
380
- port,
381
- hostname
382
- }, (info) => {
383
- console.log(`[Host] Server running at http://${hostname}:${info.port}`);
384
- console.log(`[Host] API: http://${hostname}:${info.port}/api/rpc`);
385
- resolveReady?.();
386
- });
387
- await ready;
388
- return { shutdown: () => new Promise((resolve) => {
389
- try {
390
- server.close(() => resolve());
391
- } catch {
392
- resolve();
393
- }
394
- }) };
395
- }
396
-
397
- //#endregion
398
- export { createHostServer, runHostServer };
399
- //# sourceMappingURL=host.mjs.map
package/dist/host.mjs.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"host.mjs","names":[],"sources":["../src/host.ts"],"sourcesContent":["import { serve } from \"@hono/node-server\";\nimport { OpenAPIHandler } from \"@orpc/openapi/fetch\";\nimport { OpenAPIReferencePlugin } from \"@orpc/openapi/plugins\";\nimport { RPCHandler } from \"@orpc/server/fetch\";\nimport { BatchHandlerPlugin } from \"@orpc/server/plugins\";\nimport { ZodToJsonSchemaConverter } from \"@orpc/zod/zod4\";\nimport { Hono } from \"hono\";\nimport { cors } from \"hono/cors\";\nimport { secureHeaders } from \"hono/secure-headers\";\nimport {\n createStitchedRouter,\n type LoadedPluginResult,\n type LoadedPluginsResult,\n loadApiPluginsFromRuntimeConfig,\n} from \"./api\";\nimport { loadRouterModule, type RouterModule } from \"./federation.server\";\nimport type { ClientRuntimeConfig, RuntimeConfig } from \"./types\";\n\nexport interface HostServerConfig {\n runtimeConfig: RuntimeConfig;\n configDir: string;\n port?: number;\n}\n\nexport interface HostServerHandle {\n ready: Promise<void>;\n shutdown: () => Promise<void>;\n}\n\nfunction buildClientRuntimeConfig(runtimeConfig: RuntimeConfig): ClientRuntimeConfig {\n return {\n env: runtimeConfig.env,\n account: runtimeConfig.account,\n networkId: runtimeConfig.networkId,\n hostUrl: runtimeConfig.host.url,\n assetsUrl: runtimeConfig.ui.url,\n apiBase: \"/api\",\n rpcBase: \"/api/rpc\",\n authAvailable: !!runtimeConfig.auth,\n repository: runtimeConfig.repository,\n ui: runtimeConfig.ui\n ? {\n name: runtimeConfig.ui.name,\n url: runtimeConfig.ui.url,\n entry: runtimeConfig.ui.entry,\n integrity: runtimeConfig.ui.integrity,\n }\n : undefined,\n api: runtimeConfig.api\n ? {\n name: runtimeConfig.api.name,\n url: runtimeConfig.api.url,\n entry: runtimeConfig.api.entry,\n integrity: runtimeConfig.api.integrity,\n }\n : undefined,\n auth: runtimeConfig.auth\n ? {\n name: runtimeConfig.auth.name,\n url: runtimeConfig.auth.url,\n entry: runtimeConfig.auth.entry,\n integrity: runtimeConfig.auth.integrity,\n sidebar: runtimeConfig.auth.sidebar,\n }\n : undefined,\n plugins: runtimeConfig.plugins\n ? Object.fromEntries(\n Object.entries(runtimeConfig.plugins).map(([key, plugin]) => [\n key,\n {\n name: plugin.name,\n url: plugin.url,\n entry: plugin.entry,\n integrity: plugin.integrity,\n ...(plugin.ui\n ? {\n ui: {\n name: plugin.ui.name,\n url: plugin.ui.url,\n entry: plugin.ui.entry,\n source: plugin.ui.source,\n integrity: plugin.ui.integrity,\n },\n }\n : {}),\n ...(plugin.sidebar ? { sidebar: plugin.sidebar } : {}),\n },\n ]),\n )\n : undefined,\n };\n}\n\nfunction renderLoadingShell(runtimeConfig: ClientRuntimeConfig, error?: string | null) {\n const bootstrap = `window.__RUNTIME_CONFIG__ = ${JSON.stringify(runtimeConfig)};window.addEventListener('load', function handleEverythingDevHydrate() { window.__hydrate?.(); }, { once: true });`;\n const errorMarkup = error\n ? `<p style=\"color: #fca5a5;\">Error loading UI: ${escapeHtml(error)}</p>`\n : \"<p>Loading UI...</p>\";\n\n const uiIntegrity = runtimeConfig.ui?.integrity;\n const sriAttr = uiIntegrity ? ` integrity=\"${uiIntegrity}\" crossorigin=\"anonymous\"` : \"\";\n\n const pluginUiScripts = Object.values(runtimeConfig.plugins ?? {})\n .filter((plugin) => plugin.ui?.url && plugin.ui.source === \"remote\")\n .map((plugin) => {\n const uiIntegrity = plugin.ui!.integrity;\n const sri = uiIntegrity ? ` integrity=\"${uiIntegrity}\" crossorigin=\"anonymous\"` : \"\";\n return `<script src=\"${plugin.ui!.url}/remoteEntry.js\"${sri}></script>`;\n })\n .join(\"\\n\");\n\n return `\n\t\t<!DOCTYPE html>\n\t\t<html lang=\"en\">\n\t\t\t<head>\n\t\t\t\t<meta charset=\"utf-8\" />\n\t\t\t\t<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n\t\t\t\t<title>Loading...</title>\n\t\t\t\t<style>\n\t\t\t\t\tbody { background: #171717; color: #fafafa; display: flex; align-items: center; justify-content: center; height: 100vh; font-family: system-ui; }\n\t\t\t\t\t.fade { animation: fadeIn 0.3s ease-in; text-align: center; padding: 2rem; }\n\t\t\t\t\t@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }\n\t\t\t\t</style>\n\t\t\t\t${runtimeConfig.assetsUrl ? `<script src=\"${runtimeConfig.assetsUrl}/remoteEntry.js\"${sriAttr}></script>` : \"\"}\n\t\t\t\t${pluginUiScripts}\n\t\t\t\t<script>${bootstrap}</script>\n\t\t\t</head>\n\t\t\t<body>\n\t\t\t\t<div id=\"root\" class=\"fade\">${errorMarkup}</div>\n\t\t\t</body>\n\t\t</html>\n\t`;\n}\n\nfunction escapeHtml(value: string) {\n return value\n .replaceAll(\"&\", \"&amp;\")\n .replaceAll(\"<\", \"&lt;\")\n .replaceAll(\">\", \"&gt;\")\n .replaceAll('\"', \"&quot;\")\n .replaceAll(\"'\", \"&#39;\");\n}\n\nexport function createHostServer(config: HostServerConfig): HostServerHandle {\n const port = config.port ?? 3000;\n const { runtimeConfig } = config;\n\n let shutdownImpl: (() => Promise<void>) | null = null;\n\n const ready = (async () => {\n const started = await runHostServer({ runtimeConfig, port });\n shutdownImpl = started.shutdown;\n })();\n\n const shutdown = async () => {\n console.log(\"[Host] Shutting down...\");\n const timeout = setTimeout(() => {\n console.log(\"[Host] Force exit\");\n process.exit(0);\n }, 5000);\n await ready.catch(() => {});\n if (shutdownImpl) {\n await shutdownImpl().catch(() => {});\n }\n clearTimeout(timeout);\n console.log(\"[Host] Shutdown complete\");\n };\n\n return { ready, shutdown };\n}\n\nasync function runHostServer(opts: {\n runtimeConfig: RuntimeConfig;\n port: number;\n}): Promise<{ shutdown: () => Promise<void> }> {\n const { runtimeConfig, port } = opts;\n\n let apiPlugins: LoadedPluginResult[] = [];\n let baseApiPlugin: LoadedPluginResult | null = null;\n let apiPluginError: string | null = null;\n let apiPluginLoading: Promise<LoadedPluginsResult | null> | null = null;\n let ssrRouterModule: RouterModule | null = null;\n let ssrRouterError: string | null = null;\n let ssrRouterLoading: Promise<RouterModule | null> | null = null;\n let rpcHandler: RPCHandler<any> | null = null;\n let openApiHandler: OpenAPIHandler<any> | null = null;\n\n const clientRuntimeConfig = buildClientRuntimeConfig(runtimeConfig);\n\n const initApiHandlers = () => {\n const baseRouter = baseApiPlugin?.router ?? {};\n const stitchedRouter = createStitchedRouter(\n baseRouter,\n apiPlugins.filter((plugin) => plugin.key !== \"api\"),\n );\n\n if (!baseApiPlugin) {\n rpcHandler = null;\n openApiHandler = null;\n return;\n }\n\n rpcHandler = new RPCHandler(stitchedRouter as any, {\n plugins: [new BatchHandlerPlugin()],\n });\n openApiHandler = new OpenAPIHandler(stitchedRouter as any, {\n plugins: [\n new OpenAPIReferencePlugin({\n schemaConverters: [new ZodToJsonSchemaConverter()],\n }),\n ],\n });\n };\n\n const ensureApiPluginLoaded = async (): Promise<LoadedPluginsResult | null> => {\n if (apiPlugins.length > 0) return { base: baseApiPlugin, plugins: apiPlugins, errors: [] };\n if (!runtimeConfig.api) return null;\n if (apiPluginLoading) return apiPluginLoading;\n\n apiPluginLoading = loadApiPluginsFromRuntimeConfig(runtimeConfig, process.env as any)\n .then((loaded) => {\n if (loaded) {\n apiPlugins = loaded.plugins;\n baseApiPlugin = loaded.base;\n apiPluginError =\n loaded.errors.length > 0 ? loaded.errors.map((item) => item.error).join(\"; \") : null;\n initApiHandlers();\n }\n return loaded;\n })\n .catch((e) => {\n apiPluginError = e instanceof Error ? e.message : String(e);\n return null;\n })\n .finally(() => {\n apiPluginLoading = null;\n });\n\n return apiPluginLoading;\n };\n\n const ensureRouterModuleLoaded = async (): Promise<RouterModule | null> => {\n if (ssrRouterModule) {\n return ssrRouterModule;\n }\n\n if (ssrRouterLoading) {\n return ssrRouterLoading;\n }\n\n ssrRouterLoading = loadRouterModule(runtimeConfig)\n .then((routerModule) => {\n ssrRouterModule = routerModule;\n ssrRouterError = null;\n return routerModule;\n })\n .catch((error) => {\n ssrRouterError = error instanceof Error ? error.message : String(error);\n return null;\n })\n .finally(() => {\n ssrRouterLoading = null;\n });\n\n return ssrRouterLoading;\n };\n\n // Kick off API plugin load in the background; host should still start even if\n // the remote isn't ready yet.\n void ensureApiPluginLoaded();\n void ensureRouterModuleLoaded();\n\n const app = new Hono();\n\n const corsOrigins = process.env.CORS_ORIGIN?.split(\",\").map((o) => o.trim()) ?? [\n runtimeConfig.host.url,\n ...(runtimeConfig.ui?.url ? [runtimeConfig.ui.url] : []),\n ];\n\n if (!process.env.CORS_ORIGIN && runtimeConfig.env === \"production\") {\n console.warn(\n \"[Security] CORS_ORIGIN is not set in production. Using host and UI URLs as allowed origins.\",\n );\n }\n\n app.use(\n \"/*\",\n cors({\n origin: corsOrigins,\n credentials: true,\n }),\n );\n\n app.use(\"*\", secureHeaders({ crossOriginOpenerPolicy: \"same-origin-allow-popups\" }));\n\n app.get(\"/health\", (c) => c.text(\"OK\"));\n app.get(\"/ready\", async (c) => {\n type Check = {\n name: string;\n url: string;\n required: boolean;\n ok: boolean;\n status?: number;\n latencyMs?: number;\n error?: string;\n };\n\n const probe = async (url: string, timeoutMs = 400): Promise<Check> => {\n const started = Date.now();\n const controller = new AbortController();\n const timer = setTimeout(() => controller.abort(), timeoutMs);\n try {\n const res = await fetch(url, { signal: controller.signal });\n return {\n name: \"\",\n url,\n required: true,\n ok: res.ok,\n status: res.status,\n latencyMs: Date.now() - started,\n };\n } catch (e) {\n return {\n name: \"\",\n url,\n required: true,\n ok: false,\n latencyMs: Date.now() - started,\n error: e instanceof Error ? e.message : String(e),\n };\n } finally {\n clearTimeout(timer);\n }\n };\n\n const checks: Check[] = [];\n\n if (runtimeConfig.ui?.url) {\n const base = runtimeConfig.ui.url.replace(/\\/$/, \"\");\n const manifest = await probe(`${base}/mf-manifest.json`);\n manifest.name = \"ui\";\n // mf-manifest.json is preferred but not always present; fall back to\n // remoteEntry.js for readiness.\n manifest.required = false;\n checks.push(manifest);\n if (!manifest.ok) {\n const remoteEntry = await probe(`${base}/remoteEntry.js`);\n remoteEntry.name = \"ui\";\n remoteEntry.required = true;\n checks.push(remoteEntry);\n } else {\n manifest.required = true;\n }\n }\n\n if (runtimeConfig.ui?.ssrUrl) {\n const base = runtimeConfig.ui.ssrUrl.replace(/\\/$/, \"\");\n const ssr = await probe(`${base}/`);\n ssr.name = \"ui-ssr\";\n ssr.required = false;\n checks.push(ssr);\n }\n\n if (runtimeConfig.api?.url) {\n const base = runtimeConfig.api.url.replace(/\\/$/, \"\");\n const api = await probe(`${base}/`);\n api.name = \"api\";\n api.required = true;\n checks.push(api);\n }\n\n if (runtimeConfig.api) {\n checks.push({\n name: \"api-plugin\",\n url: runtimeConfig.api.entry,\n required: true,\n ok: baseApiPlugin !== null,\n status: baseApiPlugin !== null ? 200 : 503,\n error:\n baseApiPlugin !== null\n ? undefined\n : apiPluginLoading\n ? \"loading\"\n : (apiPluginError ?? \"not loaded\"),\n });\n if (!baseApiPlugin && !apiPluginLoading) {\n void ensureApiPluginLoaded();\n }\n }\n\n for (const [key, plugin] of Object.entries(runtimeConfig.plugins ?? {})) {\n const loaded = apiPlugins.find((item) => item.key === key);\n checks.push({\n name: key,\n url: plugin.entry,\n required: true,\n ok: Boolean(loaded),\n status: loaded ? 200 : 503,\n error: loaded ? undefined : (apiPluginError ?? \"not loaded\"),\n });\n }\n\n const allRequiredOk = checks.filter((x) => x.required).every((x) => x.ok);\n\n return c.json(\n {\n status: allRequiredOk ? \"ready\" : \"not_ready\",\n host: {\n url: runtimeConfig.host.url,\n env: runtimeConfig.env,\n },\n checks,\n timestamp: new Date().toISOString(),\n },\n allRequiredOk ? 200 : 503,\n );\n });\n app.get(\"/api/_health\", (c) =>\n c.json({\n status: \"ready\",\n mode: runtimeConfig.env,\n ui: runtimeConfig.ui?.url ?? null,\n uiSsr: runtimeConfig.ui?.ssrUrl ?? null,\n ssrRouterLoaded: ssrRouterModule !== null,\n ssrRouterLoading: ssrRouterLoading !== null,\n ssrRouterError,\n api: runtimeConfig.api?.url ?? null,\n apiPluginLoaded: baseApiPlugin !== null,\n apiPluginLoading: apiPluginLoading !== null,\n apiPluginError,\n }),\n );\n\n app.all(\"/api/rpc/*\", async (c) => {\n if (!rpcHandler) {\n await ensureApiPluginLoaded();\n }\n if (!rpcHandler) {\n return c.json({ error: \"API plugin not loaded\", detail: apiPluginError }, 503);\n }\n const result = await rpcHandler.handle(c.req.raw, {\n prefix: \"/api/rpc\",\n context: {},\n });\n return result.response\n ? c.newResponse(result.response.body, result.response)\n : c.text(\"Not Found\", 404);\n });\n\n app.all(\"/api/*\", async (c) => {\n if (!openApiHandler) {\n await ensureApiPluginLoaded();\n }\n if (!openApiHandler) {\n return c.json({ error: \"API plugin not loaded\", detail: apiPluginError }, 503);\n }\n const result = await openApiHandler.handle(c.req.raw, {\n prefix: \"/api\",\n context: {},\n });\n return result.response\n ? c.newResponse(result.response.body, result.response)\n : c.text(\"Not Found\", 404);\n });\n\n if (runtimeConfig.ui) {\n app.all(\"/__mf/ui/*\", async (c) => {\n const targetUrl = `${runtimeConfig.ui!.url}${c.req.path.replace(\"/__mf/ui\", \"\")}`;\n const response = await fetch(targetUrl, {\n method: c.req.method,\n headers: c.req.header(),\n });\n return response;\n });\n\n if (runtimeConfig.ui.ssrUrl) {\n app.all(\"/__mf/ui/ssr/*\", async (c) => {\n const targetUrl = `${runtimeConfig.ui!.ssrUrl}${c.req.path.replace(\"/__mf/ui/ssr\", \"\")}`;\n const response = await fetch(targetUrl, {\n method: c.req.method,\n headers: c.req.header(),\n });\n return response;\n });\n }\n }\n\n for (const [pluginKey, pluginConfig] of Object.entries(runtimeConfig.plugins ?? {})) {\n if (!pluginConfig.ui?.url) continue;\n const pluginUiUrl = pluginConfig.ui.url;\n const proxyPrefix = `/__mf/plugin-ui/${pluginKey}`;\n app.all(`${proxyPrefix}/*`, async (c) => {\n const targetUrl = `${pluginUiUrl}${c.req.path.replace(proxyPrefix, \"\")}`;\n const response = await fetch(targetUrl, {\n method: c.req.method,\n headers: c.req.header(),\n });\n return response;\n });\n }\n\n app.get(\"*\", async (c) => {\n const routerModule = await ensureRouterModuleLoaded();\n\n if (!routerModule) {\n return c.html(renderLoadingShell(clientRuntimeConfig, ssrRouterError), 503);\n }\n\n try {\n const apiClient = baseApiPlugin?.createClient();\n\n const result = await routerModule.renderToStream(c.req.raw, {\n assetsUrl: runtimeConfig.ui.url,\n runtimeConfig: clientRuntimeConfig,\n apiClient,\n });\n\n return new Response(result.stream, {\n status: result.statusCode,\n headers: result.headers,\n });\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n return c.html(renderLoadingShell(clientRuntimeConfig, message), 500);\n }\n });\n\n const hostname = process.env.HOST ?? \"0.0.0.0\";\n let resolveReady: (() => void) | null = null;\n const ready = new Promise<void>((resolve) => {\n resolveReady = resolve;\n });\n\n const proxiedFetch = (req: Request): Response | Promise<Response> => {\n const url = new URL(req.url);\n const forwardedProto = req.headers.get(\"x-forwarded-proto\");\n const forwardedHost = req.headers.get(\"x-forwarded-host\");\n\n if (forwardedProto) {\n url.protocol = forwardedProto;\n }\n if (forwardedHost) {\n url.host = forwardedHost;\n }\n\n if (forwardedProto || forwardedHost) {\n req = new Request(url, req);\n }\n\n return app.fetch(req);\n };\n\n const server = serve({ fetch: proxiedFetch, port, hostname }, (info) => {\n console.log(`[Host] Server running at http://${hostname}:${info.port}`);\n console.log(`[Host] API: http://${hostname}:${info.port}/api/rpc`);\n resolveReady?.();\n });\n\n await ready;\n\n return {\n shutdown: () =>\n new Promise<void>((resolve) => {\n try {\n server.close(() => resolve());\n } catch {\n resolve();\n }\n }),\n };\n}\n\nexport { runHostServer };\n"],"mappings":";;;;;;;;;;;;;AA6BA,SAAS,yBAAyB,eAAmD;AACnF,QAAO;EACL,KAAK,cAAc;EACnB,SAAS,cAAc;EACvB,WAAW,cAAc;EACzB,SAAS,cAAc,KAAK;EAC5B,WAAW,cAAc,GAAG;EAC5B,SAAS;EACT,SAAS;EACT,eAAe,CAAC,CAAC,cAAc;EAC/B,YAAY,cAAc;EAC1B,IAAI,cAAc,KACd;GACE,MAAM,cAAc,GAAG;GACvB,KAAK,cAAc,GAAG;GACtB,OAAO,cAAc,GAAG;GACxB,WAAW,cAAc,GAAG;GAC7B,GACD;EACJ,KAAK,cAAc,MACf;GACE,MAAM,cAAc,IAAI;GACxB,KAAK,cAAc,IAAI;GACvB,OAAO,cAAc,IAAI;GACzB,WAAW,cAAc,IAAI;GAC9B,GACD;EACJ,MAAM,cAAc,OAChB;GACE,MAAM,cAAc,KAAK;GACzB,KAAK,cAAc,KAAK;GACxB,OAAO,cAAc,KAAK;GAC1B,WAAW,cAAc,KAAK;GAC9B,SAAS,cAAc,KAAK;GAC7B,GACD;EACJ,SAAS,cAAc,UACnB,OAAO,YACL,OAAO,QAAQ,cAAc,QAAQ,CAAC,KAAK,CAAC,KAAK,YAAY,CAC3D,KACA;GACE,MAAM,OAAO;GACb,KAAK,OAAO;GACZ,OAAO,OAAO;GACd,WAAW,OAAO;GAClB,GAAI,OAAO,KACP,EACE,IAAI;IACF,MAAM,OAAO,GAAG;IAChB,KAAK,OAAO,GAAG;IACf,OAAO,OAAO,GAAG;IACjB,QAAQ,OAAO,GAAG;IAClB,WAAW,OAAO,GAAG;IACtB,EACF,GACD,EAAE;GACN,GAAI,OAAO,UAAU,EAAE,SAAS,OAAO,SAAS,GAAG,EAAE;GACtD,CACF,CAAC,CACH,GACD;EACL;;AAGH,SAAS,mBAAmB,eAAoC,OAAuB;CACrF,MAAM,YAAY,+BAA+B,KAAK,UAAU,cAAc,CAAC;CAC/E,MAAM,cAAc,QAChB,gDAAgD,WAAW,MAAM,CAAC,QAClE;CAEJ,MAAM,cAAc,cAAc,IAAI;CACtC,MAAM,UAAU,cAAc,eAAe,YAAY,6BAA6B;CAEtF,MAAM,kBAAkB,OAAO,OAAO,cAAc,WAAW,EAAE,CAAC,CAC/D,QAAQ,WAAW,OAAO,IAAI,OAAO,OAAO,GAAG,WAAW,SAAS,CACnE,KAAK,WAAW;EACf,MAAM,cAAc,OAAO,GAAI;EAC/B,MAAM,MAAM,cAAc,eAAe,YAAY,6BAA6B;AAClF,SAAO,gBAAgB,OAAO,GAAI,IAAI,kBAAkB,IAAI;GAC5D,CACD,KAAK,KAAK;AAEb,QAAO;;;;;;;;;;;;MAYH,cAAc,YAAY,gBAAgB,cAAc,UAAU,kBAAkB,QAAQ,eAAc,GAAG;MAC7G,gBAAgB;cACR,UAAU;;;kCAGU,YAAY;;;;;AAM9C,SAAS,WAAW,OAAe;AACjC,QAAO,MACJ,WAAW,KAAK,QAAQ,CACxB,WAAW,KAAK,OAAO,CACvB,WAAW,KAAK,OAAO,CACvB,WAAW,MAAK,SAAS,CACzB,WAAW,KAAK,QAAQ;;AAG7B,SAAgB,iBAAiB,QAA4C;CAC3E,MAAM,OAAO,OAAO,QAAQ;CAC5B,MAAM,EAAE,kBAAkB;CAE1B,IAAI,eAA6C;CAEjD,MAAM,SAAS,YAAY;AAEzB,kBADgB,MAAM,cAAc;GAAE;GAAe;GAAM,CAAC,EACrC;KACrB;CAEJ,MAAM,WAAW,YAAY;AAC3B,UAAQ,IAAI,0BAA0B;EACtC,MAAM,UAAU,iBAAiB;AAC/B,WAAQ,IAAI,oBAAoB;AAChC,WAAQ,KAAK,EAAE;KACd,IAAK;AACR,QAAM,MAAM,YAAY,GAAG;AAC3B,MAAI,aACF,OAAM,cAAc,CAAC,YAAY,GAAG;AAEtC,eAAa,QAAQ;AACrB,UAAQ,IAAI,2BAA2B;;AAGzC,QAAO;EAAE;EAAO;EAAU;;AAG5B,eAAe,cAAc,MAGkB;CAC7C,MAAM,EAAE,eAAe,SAAS;CAEhC,IAAI,aAAmC,EAAE;CACzC,IAAI,gBAA2C;CAC/C,IAAI,iBAAgC;CACpC,IAAI,mBAA+D;CACnE,IAAI,kBAAuC;CAC3C,IAAI,iBAAgC;CACpC,IAAI,mBAAwD;CAC5D,IAAI,aAAqC;CACzC,IAAI,iBAA6C;CAEjD,MAAM,sBAAsB,yBAAyB,cAAc;CAEnE,MAAM,wBAAwB;EAE5B,MAAM,iBAAiB,qBADJ,eAAe,UAAU,EAAE,EAG5C,WAAW,QAAQ,WAAW,OAAO,QAAQ,MAAM,CACpD;AAED,MAAI,CAAC,eAAe;AAClB,gBAAa;AACb,oBAAiB;AACjB;;AAGF,eAAa,IAAI,WAAW,gBAAuB,EACjD,SAAS,CAAC,IAAI,oBAAoB,CAAC,EACpC,CAAC;AACF,mBAAiB,IAAI,eAAe,gBAAuB,EACzD,SAAS,CACP,IAAI,uBAAuB,EACzB,kBAAkB,CAAC,IAAI,0BAA0B,CAAC,EACnD,CAAC,CACH,EACF,CAAC;;CAGJ,MAAM,wBAAwB,YAAiD;AAC7E,MAAI,WAAW,SAAS,EAAG,QAAO;GAAE,MAAM;GAAe,SAAS;GAAY,QAAQ,EAAE;GAAE;AAC1F,MAAI,CAAC,cAAc,IAAK,QAAO;AAC/B,MAAI,iBAAkB,QAAO;AAE7B,qBAAmB,gCAAgC,eAAe,QAAQ,IAAW,CAClF,MAAM,WAAW;AAChB,OAAI,QAAQ;AACV,iBAAa,OAAO;AACpB,oBAAgB,OAAO;AACvB,qBACE,OAAO,OAAO,SAAS,IAAI,OAAO,OAAO,KAAK,SAAS,KAAK,MAAM,CAAC,KAAK,KAAK,GAAG;AAClF,qBAAiB;;AAEnB,UAAO;IACP,CACD,OAAO,MAAM;AACZ,oBAAiB,aAAa,QAAQ,EAAE,UAAU,OAAO,EAAE;AAC3D,UAAO;IACP,CACD,cAAc;AACb,sBAAmB;IACnB;AAEJ,SAAO;;CAGT,MAAM,2BAA2B,YAA0C;AACzE,MAAI,gBACF,QAAO;AAGT,MAAI,iBACF,QAAO;AAGT,qBAAmB,iBAAiB,cAAc,CAC/C,MAAM,iBAAiB;AACtB,qBAAkB;AAClB,oBAAiB;AACjB,UAAO;IACP,CACD,OAAO,UAAU;AAChB,oBAAiB,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;AACvE,UAAO;IACP,CACD,cAAc;AACb,sBAAmB;IACnB;AAEJ,SAAO;;AAKT,CAAK,uBAAuB;AAC5B,CAAK,0BAA0B;CAE/B,MAAM,MAAM,IAAI,MAAM;CAEtB,MAAM,cAAc,QAAQ,IAAI,aAAa,MAAM,IAAI,CAAC,KAAK,MAAM,EAAE,MAAM,CAAC,IAAI,CAC9E,cAAc,KAAK,KACnB,GAAI,cAAc,IAAI,MAAM,CAAC,cAAc,GAAG,IAAI,GAAG,EAAE,CACxD;AAED,KAAI,CAAC,QAAQ,IAAI,eAAe,cAAc,QAAQ,aACpD,SAAQ,KACN,8FACD;AAGH,KAAI,IACF,MACA,KAAK;EACH,QAAQ;EACR,aAAa;EACd,CAAC,CACH;AAED,KAAI,IAAI,KAAK,cAAc,EAAE,yBAAyB,4BAA4B,CAAC,CAAC;AAEpF,KAAI,IAAI,YAAY,MAAM,EAAE,KAAK,KAAK,CAAC;AACvC,KAAI,IAAI,UAAU,OAAO,MAAM;EAW7B,MAAM,QAAQ,OAAO,KAAa,YAAY,QAAwB;GACpE,MAAM,UAAU,KAAK,KAAK;GAC1B,MAAM,aAAa,IAAI,iBAAiB;GACxC,MAAM,QAAQ,iBAAiB,WAAW,OAAO,EAAE,UAAU;AAC7D,OAAI;IACF,MAAM,MAAM,MAAM,MAAM,KAAK,EAAE,QAAQ,WAAW,QAAQ,CAAC;AAC3D,WAAO;KACL,MAAM;KACN;KACA,UAAU;KACV,IAAI,IAAI;KACR,QAAQ,IAAI;KACZ,WAAW,KAAK,KAAK,GAAG;KACzB;YACM,GAAG;AACV,WAAO;KACL,MAAM;KACN;KACA,UAAU;KACV,IAAI;KACJ,WAAW,KAAK,KAAK,GAAG;KACxB,OAAO,aAAa,QAAQ,EAAE,UAAU,OAAO,EAAE;KAClD;aACO;AACR,iBAAa,MAAM;;;EAIvB,MAAM,SAAkB,EAAE;AAE1B,MAAI,cAAc,IAAI,KAAK;GACzB,MAAM,OAAO,cAAc,GAAG,IAAI,QAAQ,OAAO,GAAG;GACpD,MAAM,WAAW,MAAM,MAAM,GAAG,KAAK,mBAAmB;AACxD,YAAS,OAAO;AAGhB,YAAS,WAAW;AACpB,UAAO,KAAK,SAAS;AACrB,OAAI,CAAC,SAAS,IAAI;IAChB,MAAM,cAAc,MAAM,MAAM,GAAG,KAAK,iBAAiB;AACzD,gBAAY,OAAO;AACnB,gBAAY,WAAW;AACvB,WAAO,KAAK,YAAY;SAExB,UAAS,WAAW;;AAIxB,MAAI,cAAc,IAAI,QAAQ;GAE5B,MAAM,MAAM,MAAM,MAAM,GADX,cAAc,GAAG,OAAO,QAAQ,OAAO,GAAG,CACvB,GAAG;AACnC,OAAI,OAAO;AACX,OAAI,WAAW;AACf,UAAO,KAAK,IAAI;;AAGlB,MAAI,cAAc,KAAK,KAAK;GAE1B,MAAM,MAAM,MAAM,MAAM,GADX,cAAc,IAAI,IAAI,QAAQ,OAAO,GAAG,CACrB,GAAG;AACnC,OAAI,OAAO;AACX,OAAI,WAAW;AACf,UAAO,KAAK,IAAI;;AAGlB,MAAI,cAAc,KAAK;AACrB,UAAO,KAAK;IACV,MAAM;IACN,KAAK,cAAc,IAAI;IACvB,UAAU;IACV,IAAI,kBAAkB;IACtB,QAAQ,kBAAkB,OAAO,MAAM;IACvC,OACE,kBAAkB,OACd,SACA,mBACE,YACC,kBAAkB;IAC5B,CAAC;AACF,OAAI,CAAC,iBAAiB,CAAC,iBACrB,CAAK,uBAAuB;;AAIhC,OAAK,MAAM,CAAC,KAAK,WAAW,OAAO,QAAQ,cAAc,WAAW,EAAE,CAAC,EAAE;GACvE,MAAM,SAAS,WAAW,MAAM,SAAS,KAAK,QAAQ,IAAI;AAC1D,UAAO,KAAK;IACV,MAAM;IACN,KAAK,OAAO;IACZ,UAAU;IACV,IAAI,QAAQ,OAAO;IACnB,QAAQ,SAAS,MAAM;IACvB,OAAO,SAAS,SAAa,kBAAkB;IAChD,CAAC;;EAGJ,MAAM,gBAAgB,OAAO,QAAQ,MAAM,EAAE,SAAS,CAAC,OAAO,MAAM,EAAE,GAAG;AAEzE,SAAO,EAAE,KACP;GACE,QAAQ,gBAAgB,UAAU;GAClC,MAAM;IACJ,KAAK,cAAc,KAAK;IACxB,KAAK,cAAc;IACpB;GACD;GACA,4BAAW,IAAI,MAAM,EAAC,aAAa;GACpC,EACD,gBAAgB,MAAM,IACvB;GACD;AACF,KAAI,IAAI,iBAAiB,MACvB,EAAE,KAAK;EACL,QAAQ;EACR,MAAM,cAAc;EACpB,IAAI,cAAc,IAAI,OAAO;EAC7B,OAAO,cAAc,IAAI,UAAU;EACnC,iBAAiB,oBAAoB;EACrC,kBAAkB,qBAAqB;EACvC;EACA,KAAK,cAAc,KAAK,OAAO;EAC/B,iBAAiB,kBAAkB;EACnC,kBAAkB,qBAAqB;EACvC;EACD,CAAC,CACH;AAED,KAAI,IAAI,cAAc,OAAO,MAAM;AACjC,MAAI,CAAC,WACH,OAAM,uBAAuB;AAE/B,MAAI,CAAC,WACH,QAAO,EAAE,KAAK;GAAE,OAAO;GAAyB,QAAQ;GAAgB,EAAE,IAAI;EAEhF,MAAM,SAAS,MAAM,WAAW,OAAO,EAAE,IAAI,KAAK;GAChD,QAAQ;GACR,SAAS,EAAE;GACZ,CAAC;AACF,SAAO,OAAO,WACV,EAAE,YAAY,OAAO,SAAS,MAAM,OAAO,SAAS,GACpD,EAAE,KAAK,aAAa,IAAI;GAC5B;AAEF,KAAI,IAAI,UAAU,OAAO,MAAM;AAC7B,MAAI,CAAC,eACH,OAAM,uBAAuB;AAE/B,MAAI,CAAC,eACH,QAAO,EAAE,KAAK;GAAE,OAAO;GAAyB,QAAQ;GAAgB,EAAE,IAAI;EAEhF,MAAM,SAAS,MAAM,eAAe,OAAO,EAAE,IAAI,KAAK;GACpD,QAAQ;GACR,SAAS,EAAE;GACZ,CAAC;AACF,SAAO,OAAO,WACV,EAAE,YAAY,OAAO,SAAS,MAAM,OAAO,SAAS,GACpD,EAAE,KAAK,aAAa,IAAI;GAC5B;AAEF,KAAI,cAAc,IAAI;AACpB,MAAI,IAAI,cAAc,OAAO,MAAM;GACjC,MAAM,YAAY,GAAG,cAAc,GAAI,MAAM,EAAE,IAAI,KAAK,QAAQ,YAAY,GAAG;AAK/E,UAJiB,MAAM,MAAM,WAAW;IACtC,QAAQ,EAAE,IAAI;IACd,SAAS,EAAE,IAAI,QAAQ;IACxB,CAAC;IAEF;AAEF,MAAI,cAAc,GAAG,OACnB,KAAI,IAAI,kBAAkB,OAAO,MAAM;GACrC,MAAM,YAAY,GAAG,cAAc,GAAI,SAAS,EAAE,IAAI,KAAK,QAAQ,gBAAgB,GAAG;AAKtF,UAJiB,MAAM,MAAM,WAAW;IACtC,QAAQ,EAAE,IAAI;IACd,SAAS,EAAE,IAAI,QAAQ;IACxB,CAAC;IAEF;;AAIN,MAAK,MAAM,CAAC,WAAW,iBAAiB,OAAO,QAAQ,cAAc,WAAW,EAAE,CAAC,EAAE;AACnF,MAAI,CAAC,aAAa,IAAI,IAAK;EAC3B,MAAM,cAAc,aAAa,GAAG;EACpC,MAAM,cAAc,mBAAmB;AACvC,MAAI,IAAI,GAAG,YAAY,KAAK,OAAO,MAAM;GACvC,MAAM,YAAY,GAAG,cAAc,EAAE,IAAI,KAAK,QAAQ,aAAa,GAAG;AAKtE,UAJiB,MAAM,MAAM,WAAW;IACtC,QAAQ,EAAE,IAAI;IACd,SAAS,EAAE,IAAI,QAAQ;IACxB,CAAC;IAEF;;AAGJ,KAAI,IAAI,KAAK,OAAO,MAAM;EACxB,MAAM,eAAe,MAAM,0BAA0B;AAErD,MAAI,CAAC,aACH,QAAO,EAAE,KAAK,mBAAmB,qBAAqB,eAAe,EAAE,IAAI;AAG7E,MAAI;GACF,MAAM,YAAY,eAAe,cAAc;GAE/C,MAAM,SAAS,MAAM,aAAa,eAAe,EAAE,IAAI,KAAK;IAC1D,WAAW,cAAc,GAAG;IAC5B,eAAe;IACf;IACD,CAAC;AAEF,UAAO,IAAI,SAAS,OAAO,QAAQ;IACjC,QAAQ,OAAO;IACf,SAAS,OAAO;IACjB,CAAC;WACK,OAAO;GACd,MAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;AACtE,UAAO,EAAE,KAAK,mBAAmB,qBAAqB,QAAQ,EAAE,IAAI;;GAEtE;CAEF,MAAM,WAAW,QAAQ,IAAI,QAAQ;CACrC,IAAI,eAAoC;CACxC,MAAM,QAAQ,IAAI,SAAe,YAAY;AAC3C,iBAAe;GACf;CAEF,MAAM,gBAAgB,QAA+C;EACnE,MAAM,MAAM,IAAI,IAAI,IAAI,IAAI;EAC5B,MAAM,iBAAiB,IAAI,QAAQ,IAAI,oBAAoB;EAC3D,MAAM,gBAAgB,IAAI,QAAQ,IAAI,mBAAmB;AAEzD,MAAI,eACF,KAAI,WAAW;AAEjB,MAAI,cACF,KAAI,OAAO;AAGb,MAAI,kBAAkB,cACpB,OAAM,IAAI,QAAQ,KAAK,IAAI;AAG7B,SAAO,IAAI,MAAM,IAAI;;CAGvB,MAAM,SAAS,MAAM;EAAE,OAAO;EAAc;EAAM;EAAU,GAAG,SAAS;AACtE,UAAQ,IAAI,mCAAmC,SAAS,GAAG,KAAK,OAAO;AACvE,UAAQ,IAAI,sBAAsB,SAAS,GAAG,KAAK,KAAK,UAAU;AAClE,kBAAgB;GAChB;AAEF,OAAM;AAEN,QAAO,EACL,gBACE,IAAI,SAAe,YAAY;AAC7B,MAAI;AACF,UAAO,YAAY,SAAS,CAAC;UACvB;AACN,YAAS;;GAEX,EACL"}
@@ -1,44 +0,0 @@
1
- import { DevRuntimeConfig, ServiceDescriptor, ServiceDescriptorMap } from "./service-descriptor.cjs";
2
- import * as _$_effect_platform_Error0 from "@effect/platform/Error";
3
- import * as _$effect_Scope0 from "effect/Scope";
4
- import * as _$_effect_platform_CommandExecutor0 from "@effect/platform/CommandExecutor";
5
- import { ExitCode } from "@effect/platform/CommandExecutor";
6
- import { Effect } from "effect";
7
-
8
- //#region src/orchestrator.d.ts
9
- interface ProcessCallbacks {
10
- onStatus: (name: string, status: ProcessStatus, message?: string) => void;
11
- onLog: (name: string, line: string, isError?: boolean) => void;
12
- }
13
- interface ProcessHandle {
14
- name: string;
15
- pid: number | undefined;
16
- kill: Effect.Effect<void, unknown>;
17
- waitForReady: Effect.Effect<void, Error>;
18
- waitForExit: Effect.Effect<ExitCode, unknown>;
19
- }
20
- type ProcessStatus = "pending" | "starting" | "ready" | "error";
21
- interface ProcessState {
22
- name: string;
23
- status: ProcessStatus;
24
- port: number;
25
- message?: string;
26
- source?: "local" | "remote";
27
- }
28
- declare const makeDevProcess: (pkg: string, callbacks: ProcessCallbacks, portOverride?: number) => Effect.Effect<{
29
- name: string;
30
- pid: undefined;
31
- kill: Effect.Effect<void, never, never>;
32
- waitForReady: Effect.Effect<void, Error, never>;
33
- waitForExit: Effect.Effect<never, never, never>;
34
- } | {
35
- name: string;
36
- pid: number;
37
- kill: Effect.Effect<void, never, never>;
38
- waitForReady: Effect.Effect<void, Error, never>;
39
- waitForExit: Effect.Effect<ExitCode, _$_effect_platform_Error0.PlatformError, never>;
40
- }, string | Error | _$_effect_platform_Error0.PlatformError, _$effect_Scope0.Scope | ServiceDescriptorMap | DevRuntimeConfig | _$_effect_platform_CommandExecutor0.CommandExecutor>;
41
- declare function getProcessStates(packages: string[], services: Map<string, ServiceDescriptor>, portOverride?: number): ProcessState[];
42
- //#endregion
43
- export { ProcessCallbacks, ProcessHandle, ProcessState, ProcessStatus, getProcessStates, makeDevProcess };
44
- //# sourceMappingURL=orchestrator.d.cts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"orchestrator.d.cts","names":[],"sources":["../src/orchestrator.ts"],"mappings":";;;;;;;;UAmBiB,gBAAA;EACf,QAAA,GAAW,IAAA,UAAc,MAAA,EAAQ,aAAA,EAAe,OAAA;EAChD,KAAA,GAAQ,IAAA,UAAc,IAAA,UAAc,OAAA;AAAA;AAAA,UAGrB,aAAA;EACf,IAAA;EACA,GAAA;EACA,IAAA,EAAM,MAAA,CAAO,MAAA;EACb,YAAA,EAAc,MAAA,CAAO,MAAA,OAAa,KAAA;EAClC,WAAA,EAAa,MAAA,CAAO,MAAA,CAAO,QAAA;AAAA;AAAA,KAGjB,aAAA;AAAA,UAEK,YAAA;EACf,IAAA;EACA,MAAA,EAAQ,aAAA;EACR,IAAA;EACA,OAAA;EACA,MAAA;AAAA;AAAA,cAuZW,cAAA,GAAkB,GAAA,UAAa,SAAA,EAAW,gBAAA,EAAkB,YAAA,cAAqB,MAAA,CAAA,MAAA;;;;;;;;;;;;;iBA6B9E,gBAAA,CACd,QAAA,YACA,QAAA,EAAU,GAAA,SAAY,iBAAA,GACtB,YAAA,YACC,YAAA"}
@@ -1,44 +0,0 @@
1
- import { DevRuntimeConfig, ServiceDescriptor, ServiceDescriptorMap } from "./service-descriptor.mjs";
2
- import { Effect } from "effect";
3
- import * as _$_effect_platform_Error0 from "@effect/platform/Error";
4
- import * as _$effect_Scope0 from "effect/Scope";
5
- import * as _$_effect_platform_CommandExecutor0 from "@effect/platform/CommandExecutor";
6
- import { ExitCode } from "@effect/platform/CommandExecutor";
7
-
8
- //#region src/orchestrator.d.ts
9
- interface ProcessCallbacks {
10
- onStatus: (name: string, status: ProcessStatus, message?: string) => void;
11
- onLog: (name: string, line: string, isError?: boolean) => void;
12
- }
13
- interface ProcessHandle {
14
- name: string;
15
- pid: number | undefined;
16
- kill: Effect.Effect<void, unknown>;
17
- waitForReady: Effect.Effect<void, Error>;
18
- waitForExit: Effect.Effect<ExitCode, unknown>;
19
- }
20
- type ProcessStatus = "pending" | "starting" | "ready" | "error";
21
- interface ProcessState {
22
- name: string;
23
- status: ProcessStatus;
24
- port: number;
25
- message?: string;
26
- source?: "local" | "remote";
27
- }
28
- declare const makeDevProcess: (pkg: string, callbacks: ProcessCallbacks, portOverride?: number) => Effect.Effect<{
29
- name: string;
30
- pid: undefined;
31
- kill: Effect.Effect<void, never, never>;
32
- waitForReady: Effect.Effect<void, Error, never>;
33
- waitForExit: Effect.Effect<never, never, never>;
34
- } | {
35
- name: string;
36
- pid: number;
37
- kill: Effect.Effect<void, never, never>;
38
- waitForReady: Effect.Effect<void, Error, never>;
39
- waitForExit: Effect.Effect<ExitCode, _$_effect_platform_Error0.PlatformError, never>;
40
- }, string | Error | _$_effect_platform_Error0.PlatformError, _$effect_Scope0.Scope | ServiceDescriptorMap | DevRuntimeConfig | _$_effect_platform_CommandExecutor0.CommandExecutor>;
41
- declare function getProcessStates(packages: string[], services: Map<string, ServiceDescriptor>, portOverride?: number): ProcessState[];
42
- //#endregion
43
- export { ProcessCallbacks, ProcessHandle, ProcessState, ProcessStatus, getProcessStates, makeDevProcess };
44
- //# sourceMappingURL=orchestrator.d.mts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"orchestrator.d.mts","names":[],"sources":["../src/orchestrator.ts"],"mappings":";;;;;;;;UAmBiB,gBAAA;EACf,QAAA,GAAW,IAAA,UAAc,MAAA,EAAQ,aAAA,EAAe,OAAA;EAChD,KAAA,GAAQ,IAAA,UAAc,IAAA,UAAc,OAAA;AAAA;AAAA,UAGrB,aAAA;EACf,IAAA;EACA,GAAA;EACA,IAAA,EAAM,MAAA,CAAO,MAAA;EACb,YAAA,EAAc,MAAA,CAAO,MAAA,OAAa,KAAA;EAClC,WAAA,EAAa,MAAA,CAAO,MAAA,CAAO,QAAA;AAAA;AAAA,KAGjB,aAAA;AAAA,UAEK,YAAA;EACf,IAAA;EACA,MAAA,EAAQ,aAAA;EACR,IAAA;EACA,OAAA;EACA,MAAA;AAAA;AAAA,cAuZW,cAAA,GAAkB,GAAA,UAAa,SAAA,EAAW,gBAAA,EAAkB,YAAA,cAAqB,MAAA,CAAA,MAAA;;;;;;;;;;;;;iBA6B9E,gBAAA,CACd,QAAA,YACA,QAAA,EAAU,GAAA,SAAY,iBAAA,GACtB,YAAA,YACC,YAAA"}