@makaio/framework 1.0.0-dev-1782138936821 → 1.0.0-dev-1782480236258

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 (119) hide show
  1. package/dist/.makaio-build.json +2 -2
  2. package/dist/{account-identity-D5TUafYg.mjs → account-identity-C7Kx_ieU.mjs} +1 -1
  3. package/dist/{adapter-Deu9viD2.mjs → adapter-DaQqmKOJ.mjs} +1 -1
  4. package/dist/adapters/index.d.mts +1 -1
  5. package/dist/artifact-CGjnoyCC.mjs +1 -0
  6. package/dist/bus/index.d.mts +2 -2
  7. package/dist/bus/index.mjs +1 -1
  8. package/dist/{canonical-model-BM5WAnQW.mjs → canonical-model-DV-Z8gsb.mjs} +1 -1
  9. package/dist/{client-BO-0jTSV.mjs → client-BcfR-LJC.mjs} +1 -1
  10. package/dist/{compression-CXEHx0rS.mjs → compression-C5JAWdgZ.mjs} +1 -1
  11. package/dist/contracts/adapter/index.d.mts +2 -2
  12. package/dist/contracts/adapter/index.mjs +1 -1
  13. package/dist/contracts/adapter/schemas/session-lineage.d.mts +1 -1
  14. package/dist/contracts/artifact/index.d.mts +2 -2
  15. package/dist/contracts/artifact/index.mjs +1 -1
  16. package/dist/contracts/canonical-model/index.d.mts +1 -1
  17. package/dist/contracts/canonical-model/index.mjs +1 -1
  18. package/dist/contracts/client/index.d.mts +1 -1
  19. package/dist/contracts/client/index.mjs +1 -1
  20. package/dist/contracts/config/index.d.mts +6 -6
  21. package/dist/contracts/config/index.mjs +1 -1
  22. package/dist/contracts/extension/index.d.mts +2 -2
  23. package/dist/contracts/extension/index.mjs +1 -1
  24. package/dist/contracts/facet/index.d.mts +1 -1
  25. package/dist/contracts/harness/index.d.mts +1 -1
  26. package/dist/contracts/index.d.mts +95 -95
  27. package/dist/contracts/index.mjs +1 -1
  28. package/dist/contracts/materialization/index.d.mts +3 -3
  29. package/dist/contracts/materialization/index.mjs +1 -1
  30. package/dist/contracts/provider/index.d.mts +1 -1
  31. package/dist/contracts/provider/index.mjs +1 -1
  32. package/dist/contracts/session/index.d.mts +2 -2
  33. package/dist/contracts/session/index.mjs +1 -1
  34. package/dist/contracts/shared/index.mjs +1 -1
  35. package/dist/contracts/variant/index.d.mts +1 -1
  36. package/dist/contracts/workflow/index.d.mts +2 -2
  37. package/dist/contracts/workflow/index.mjs +1 -1
  38. package/dist/{definition-BJ_975aA.mjs → definition-C-GVz7uw.mjs} +1 -1
  39. package/dist/{definition-s9PIua2B.d.mts → definition-DePb3ke-.d.mts} +1 -1
  40. package/dist/{extension-CfL70C5n.mjs → extension-BS_4BOeO.mjs} +1 -1
  41. package/dist/{index-ekpUAYVC.d.mts → index-0WhPbKnH.d.mts} +806 -30
  42. package/dist/{index-BN95duxC.d.mts → index-4eP9DRL_.d.mts} +4 -4
  43. package/dist/{index-BwGfdbI0.d.mts → index-B1XsbrAr.d.mts} +6 -6
  44. package/dist/{index-CRmApyqn.d.mts → index-B5w-0Gg9.d.mts} +8 -8
  45. package/dist/{index-Chtgizhn.d.mts → index-BKZhnb2B.d.mts} +57 -57
  46. package/dist/{index-DTBQOCar.d.mts → index-BMbmoarE.d.mts} +16 -16
  47. package/dist/{index-B08YYzYZ.d.mts → index-BhOLtp0B.d.mts} +9 -9
  48. package/dist/{index-CWDJFJGa.d.mts → index-C6SLILCZ.d.mts} +200 -200
  49. package/dist/{index-DEzdNQum.d.mts → index-CYHWOXUm.d.mts} +1 -1
  50. package/dist/{index-DDrS0Axp.d.mts → index-Clqt7Nm3.d.mts} +16 -16
  51. package/dist/{index-JkIaFJoM.d.mts → index-Cvjnj7Zh.d.mts} +8 -8
  52. package/dist/{index-Qd1Qom8M.d.mts → index-Cyi7y_aG.d.mts} +16 -16
  53. package/dist/{index-C2jl1iE2.d.mts → index-D4gn93gL.d.mts} +28 -28
  54. package/dist/{index-DXYFNGT9.d.mts → index-D8ScOpus.d.mts} +61 -61
  55. package/dist/{index-DYw2AuNR.d.mts → index-DsLpP5ek.d.mts} +1 -1
  56. package/dist/{index-ByDySw3V.d.mts → index-WHUV7neB.d.mts} +10 -10
  57. package/dist/{index-CfIW5biI.d.mts → index-wfSedMR9.d.mts} +1 -1
  58. package/dist/kernel/extension/index.d.mts +1 -1
  59. package/dist/kernel/index.d.mts +2 -2
  60. package/dist/kernel/observability/index.d.mts +1 -1
  61. package/dist/{materialization-DBXjSiBn.mjs → materialization-CUYxZCfk.mjs} +1 -1
  62. package/dist/{namespace-KMxsPJwm.d.mts → namespace-BeMGmLrp.d.mts} +9 -9
  63. package/dist/{namespace-CxzW0mIH.d.mts → namespace-Bm77p82L.d.mts} +5 -5
  64. package/dist/{namespace-Bz0ORDns.d.mts → namespace-Bmi5bjm4.d.mts} +78 -78
  65. package/dist/{namespace-DuUCiVmK.d.mts → namespace-CGxFYDlK.d.mts} +26 -26
  66. package/dist/{namespace-DBGLCtoW.d.mts → namespace-CfvtDD_U.d.mts} +22 -22
  67. package/dist/{namespace-DXWpFdQH2.d.mts → namespace-D8P8Sxce2.d.mts} +2 -2
  68. package/dist/package.json +1 -1
  69. package/dist/{provider-context-DjSUpHSM.mjs → provider-context-CqMgPOWF.mjs} +1 -1
  70. package/dist/runtime-node/index.mjs +1 -1
  71. package/dist/runtime-node/workflow-worker/index.mjs +1 -1
  72. package/dist/{schema-Dky4zu9D.d.mts → schema-Bf_ZNjif.d.mts} +3 -3
  73. package/dist/{schemas-7ncImjsM.d.mts → schemas-BemsLc_V.d.mts} +1 -1
  74. package/dist/{schemas-Eq-lrXYz2.d.mts → schemas-C6TVJ80V2.d.mts} +5 -5
  75. package/dist/{schemas-CynXJXJu.d.mts → schemas-CoFCV42v.d.mts} +22 -22
  76. package/dist/{schemas-CE1gbhxu.mjs → schemas-CuG17U3L.mjs} +1 -1
  77. package/dist/{schemas-CJ2JvA7d.d.mts → schemas-D512XweP.d.mts} +3 -3
  78. package/dist/{schemas-bfhY9W6A.mjs → schemas-uID59wR8.mjs} +1 -1
  79. package/dist/services/adapter-subsystem/index.d.mts +2 -2
  80. package/dist/services/adapter-subsystem/namespace.d.mts +1 -1
  81. package/dist/services/agent-runtime/index.d.mts +2 -2
  82. package/dist/services/agent-runtime/namespace.d.mts +1 -1
  83. package/dist/services/agent-runtime/schemas.d.mts +1 -1
  84. package/dist/services/context-rules/index.d.mts +6 -6
  85. package/dist/services/filesystem/namespace.d.mts +6 -6
  86. package/dist/services/filesystem/schemas.d.mts +3 -3
  87. package/dist/services/harness/index.d.mts +6 -6
  88. package/dist/services/index.d.mts +94 -51
  89. package/dist/services/index.mjs +1 -1
  90. package/dist/services/log-import/browser.d.mts +2 -2
  91. package/dist/services/log-import/index.d.mts +2 -2
  92. package/dist/services/log-import/log-import.d.mts +1 -1
  93. package/dist/services/log-import/namespace.d.mts +2 -2
  94. package/dist/services/log-import/schemas.d.mts +1 -1
  95. package/dist/services/session/index.d.mts +5 -5
  96. package/dist/services/session/messages/namespace.d.mts +1 -1
  97. package/dist/services/session/session-events/namespace.d.mts +1 -1
  98. package/dist/services/session/storage/namespace.d.mts +1 -1
  99. package/dist/services/session/storage/schema.d.mts +1 -1
  100. package/dist/services/settings/namespace.d.mts +2 -2
  101. package/dist/services/subagent-template/index.d.mts +2 -2
  102. package/dist/services/subagent-template/namespace.d.mts +1 -1
  103. package/dist/services/subagent-template/schemas.d.mts +1 -1
  104. package/dist/{session-CpVSzgkZ.mjs → session-DH-ja8Ka.mjs} +1 -1
  105. package/dist/{session-lineage-DR-9DU-U.d.mts → session-lineage-5-wRBzuC.d.mts} +1 -1
  106. package/dist/{shared-DpOEfD8F.mjs → shared-BVW-3Dhy.mjs} +1 -1
  107. package/dist/{transition-Bf-K6QGz.d.mts → transition-CBjccCMw.d.mts} +1 -1
  108. package/dist/{types-BolHvLpf.d.mts → types-8rhArs_K.d.mts} +84 -84
  109. package/dist/{types-BslClRkH.d.mts → types-InWSdi-V.d.mts} +1 -1
  110. package/dist/ui-kernel/index.d.mts +1 -1
  111. package/dist/ui-kernel/pages/schemas.d.mts +1 -1
  112. package/dist/{workflow-BCKOJ4UC.mjs → workflow-BqH6ar-D.mjs} +1 -1
  113. package/dist/workflow-engine/index.d.mts +63 -63
  114. package/dist/workflow-worker-dH70EbjE.mjs +1 -0
  115. package/package.json +2 -2
  116. package/dist/artifact-B3npq1cy.mjs +0 -1
  117. package/dist/workflow-worker-BIpYi6o7.mjs +0 -1
  118. /package/dist/{json-value-CmhSGMLv.mjs → json-value-DmU8ibo_.mjs} +0 -0
  119. /package/dist/{schemas-CR1Rripy.mjs → schemas-DlrQ0227.mjs} +0 -0
@@ -1,4 +1,4 @@
1
- import{i as e,o as t,t as n}from"../chunk-DTipWd-i.mjs";import{t as r}from"../semver-CIhHqMkw.mjs";import{RuntimeNamespace as i,RuntimeSubjects as a}from"./bus/runtime/namespace.mjs";import{ExplicitDescriptorDiscovery as o,FilesystemDescriptorDiscovery as s,MergedDescriptorDiscovery as c}from"./extension-discovery.mjs";import{MAKAIO_CONFIG_FILE_ENV as l,MAKAIO_HOME_ENV as u,buildConfiguredRuntimeOptions as d,createMakaioConfigDiscovery as f,defineMakaioConfig as p,loadMakaioConfig as m,parseMakaioConfig as h,resolveMakaioConfigPath as g,resolveMakaioHome as _,shouldIncludeExtension as v}from"./makaio-config.mjs";import{t as y}from"../descriptor-to-package-DdpjpT7n.mjs";import{a as b,c as x,i as S,n as C,o as w,r as T,s as E,t as ee}from"../load-extensions-Cze1RHcG.mjs";import{i as te,o as ne,r as re,s as ie,t as ae}from"../workflow-worker-BIpYi6o7.mjs";import{createRequire as oe}from"node:module";import{z as D}from"zod";import{execFile as se}from"node:child_process";import{promisify as ce}from"node:util";import{fileURLToPath as le,pathToFileURL as O}from"node:url";import*as k from"node:fs/promises";import*as A from"node:path";import j from"node:path";import*as M from"node:crypto";import{createHash as N}from"node:crypto";import*as P from"node:fs";import{existsSync as F,readFileSync as ue}from"node:fs";import{createBusNamespace as de}from"@makaio/framework/core";import{ChannelClosedError as fe,MakaioBus as pe,openChannel as me,projectSubjectTelemetryFacts as he}from"@makaio/framework/bus";import{AIModelSchema as ge,AdapterSubjects as _e,BUILT_IN_THIN_WORKFLOW_PROVIDER_ID as ve,ConfigSchema as I,ConfigSubjects as L,CredentialSubjects as ye,FrameworkContractNamespaces as be,FrameworkStorageNamespaces as xe,SubjectTelemetrySubjects as Se,isDetachedDescriptor as Ce,registerWorkerNodeProvider as we,safeParseExtensionDescriptor as Te,unregisterWorkerNodeProvider as Ee,versionSatisfies as De}from"@makaio/framework/contracts";import{DispatchingAuth as Oe,E2EAuth as ke,HmacAuth as Ae,WebSocketClientTransport as je}from"@makaio/framework/node/transports";import{BaseService as Me}from"@makaio/framework/service-base";import{uniqueIndex as Ne}from"drizzle-orm/sqlite-core";import{uniqueIndex as Pe}from"drizzle-orm/pg-core";import{STORAGE_ENGINE_URL_HINTS as Fe,defineDialectSchema as Ie,defineDualTable as Le,findStorageEngine as Re,getDatabaseDialect as ze,getRawSqlExecutor as Be,getStorageEngine as Ve,registerDrizzleHandlers as He,registerStorageEngine as Ue,resolveSchema as We,resolveStorageEngine as Ge,resolveStorageEngineForUrl as Ke}from"@makaio/framework/storage/drizzle";import{and as qe,eq as R,sql as z}from"drizzle-orm";import{parseStoredCredentialRef as Je}from"@makaio/framework/contracts/config";import{AdapterRuntimeSubjects as Ye,registerAdapterRuntimeIdentityHandlers as Xe}from"@makaio/framework/services/adapter-runtime";import{buildProviderContext as Ze}from"@makaio/framework/services/provider-context";import*as Qe from"node:os";import{ProviderStorageSubjects as $e}from"@makaio/framework/services/settings/storage";import{isRecord as et}from"@makaio/framework/utils";import{BootNamespace as tt,ExtensionCoordinator as nt,ExtensionNamespace as rt,KernelNamespace as it,coalesceExtensionOverrides as at,createShutdownSequence as ot,filterEligibleExtensions as st}from"@makaio/framework/kernel";import{AdapterSubsystemSubjects as ct}from"@makaio/framework/services/adapter-subsystem";import{CachedRegistryFetcher as lt,FallbackRegistryFetcher as ut,ModelRegistrySchema as dt,ProviderModelOverrideSchema as ft,mergeModelMetadata as pt}from"@makaio/framework/services/model-registry";import{createClientsCorePackage as mt}from"@makaio/framework/clients";import{Readable as ht,Transform as gt}from"node:stream";import{pipeline as _t}from"node:stream/promises";import{createDatabaseClient as vt}from"@makaio/framework/storage/drizzle/client";import{AdapterSubsystemToken as yt,FileAdapterConfigRepository as bt,createAdapterSubsystemContributionProcessor as xt,createAdapterSubsystemPackage as St}from"@makaio/framework/adapter-subsystem";import{loadOrCreateMachineIdentity as Ct,loadOrCreateMachineIdentity as wt,machineKeysExist as Tt,validateMachineKeys as Et}from"@makaio/framework/node/machine-identity";import{resolveWorkspaceRoot as Dt}from"@makaio/framework/utils/workspace-root";import{Hono as Ot}from"hono";import{CliNamespace as kt}from"@makaio/framework/kernel/cli";import{startBusServer as At}from"@makaio/framework/node/bus-server";import{WebSocketServer as jt}from"ws";import{ConfigProvider as Mt}from"@makaio/framework/providers";import{KernelSubjects as B}from"@makaio/framework/kernel/namespace";import{FrameworkServicesCoreNamespaces as Nt,SessionOrchestratorToken as Pt,createArtifactKindContributionProcessor as Ft,createArtifactLifecycleHookContributionProcessor as It,createFacetNamespaceContributionProcessor as Lt,createModelRegistryPackage as Rt,createSurfaceBindingContributionProcessor as zt,createToolContributionProcessor as Bt,createTransitionContributionProcessor as Vt,createWorkflowBlockContributionProcessor as Ht,frameworkCorePackages as Ut}from"@makaio/framework/services";import{createLogImportContributionProcessor as Wt,logImportRegistryPackage as Gt}from"@makaio/framework/services/log-import";import{createWorkflowEnginePackage as Kt}from"@makaio/framework/workflow-engine/package";import{PreferenceValueSchema as qt,PreferencesSubjects as Jt}from"@makaio/framework/services/preferences";import{resolveConnectorCredentials as Yt,resolveCredentialRef as Xt}from"@makaio/framework/adapters/config";import{DefinitionSubjects as Zt}from"@makaio/framework/services/definition";import{ProviderRuntimeSubjects as Qt}from"@makaio/framework/services/provider-runtime";import{SettingsSubjects as $t}from"@makaio/framework/services/settings/namespace";import{parseWorkspaceGlobs as en}from"@makaio/framework/utils/workspace-packages";import{serveStatic as tn}from"@hono/node-server/serve-static";function nn(e){return e.on(_e.getCapabilities,async t=>{let{adapterName:n,adapterId:r}=t.payload;if(r){await t.next();return}if(n){let r=await e.requestOptional(Ye.resolveId,{adapterName:n}),i=r.handled?r.data.adapterId:void 0;i&&(t.payload.adapterId=i)}await t.next()},{priority:20})}function rn(e){let{coordinator:t,configRepository:n,platformDefaults:r}=e,i=St({configRepository:n,coordinator:t,platformDefaults:r});return t.registerContributionProcessor(xt({getAdapterSubsystemService:()=>t.getExtensionService(yt)})),{adapterSubsystemPackage:i}}function an(e){let{bus:t,currentMachineId:n}=e,r=Xe(t,{currentMachineId:n,listKnownAdapterNames:e.listKnownAdapterNames??(async()=>{let{configs:e}=await t.request(ct.listAdapterConfigs,{});return e.map(e=>e.name)})}),i=nn(t);return{cleanup:()=>{r.cleanup(),i()}}}function on(e=`sqlite`){let{migrations:t}=Ve(e);return t.resolveSourceChainDir?.()??j.resolve(import.meta.dirname,`..`,t.chainDirName)}var sn=class extends Error{expectedDialect;journalDialect;constructor(e,t,n,r){super(`Migration journal at ${r} declares dialect '${n??`unknown`}', but the target database speaks '${e}'. Point the runner at a migrations directory generated for '${e}' (journal dialect '${t}').`),this.name=`MigrationDialectMismatchError`,this.expectedDialect=e,this.journalDialect=n}};function cn(e={}){let t=typeof e==`string`?void 0:e.expectedDialect,n=typeof e==`string`?e:e.migrationsDir??on(t),r=j.join(n,`meta`,`_journal.json`);if(!F(r))throw Error(`Cannot find migrations journal at ${r}`);let i=JSON.parse(ue(r,`utf-8`));if(t!==void 0){let e=Ve(t).migrations.journalDialect;if(i.dialect!==e)throw new sn(t,e,i.dialect,r)}return i.entries.map(e=>{let t=ue(j.join(n,`${e.tag}.sql`),`utf-8`);return{tag:e.tag,sql:t.split(`--> statement-breakpoint`),folderMillis:e.when,hash:N(`sha256`).update(t).digest(`hex`),bps:e.breakpoints}})}function ln(e){return e.replace(/--.*$/gm,``).trim()}async function un(e,t){try{await e.run(z.raw(`ROLLBACK`))}catch(e){console.error(`[storage-migrations] Failed to roll back migration transaction`,{...t,rollbackError:e})}}async function dn(e){let{migrations:t}=e.engine;if(await e.session.run(z.raw(t.beginTransactionStatement)),t.acquireTransactionLock)try{await t.acquireTransactionLock(e.session,e.tableName)}catch(t){throw await un(e.session,{migrationsTable:e.tableName}),t}}async function fn(e){let t=e.engine.migrations.acquireTransactionLock!==void 0;t&&await dn(e);try{await e.session.run(z.raw(e.engine.migrations.buildLedgerDdl(e.tableName)));let n=await e.session.all(z`SELECT hash FROM ${e.tableId}`);return t&&await e.session.run(z.raw(`COMMIT`)),new Set(n.map(e=>e.hash))}catch(n){throw t&&await un(e.session,{migrationsTable:e.tableName}),n}}async function pn(e,t){try{await e.session.run(z`INSERT INTO ${e.tableId} ("hash", "created_at") VALUES (${t.hash}, ${t.folderMillis})`),await e.session.run(z.raw(`COMMIT`))}catch(e){throw console.error(`[storage-migrations] Failed to finalize migration`,{hash:t.hash,folderMillis:t.folderMillis,error:e}),e}}async function mn(e,t){return e.engine.migrations.acquireTransactionLock===void 0||(await e.session.all(z`SELECT hash FROM ${e.tableId} WHERE hash = ${t.hash}`)).length===0?!1:(console.warn(`[storage-migrations] Migration already recorded by a concurrent runner, skipping`,{hash:t.hash,folderMillis:t.folderMillis}),await e.session.run(z.raw(`COMMIT`)),!0)}async function hn(e,t){await e.session.run(z.raw(`ROLLBACK`)),await dn(e),!await mn(e,t)&&await pn(e,t)}async function gn(e,t){await dn(e);try{if(await mn(e,t))return;for(let[n,r]of t.sql.entries())if(ln(r))try{await e.session.run(z.raw(r))}catch(i){if(n===0&&/^\s*CREATE\s/i.test(r)&&e.engine.errors.isDuplicateObjectError(i)){if(t.sql.length>1)throw Error(`Cannot adopt multi-statement migration '${t.tag}' because its first schema object already exists. Reset the database or provide an incremental migration.`,{cause:i});console.warn(`[storage-migrations] Schema object already exists, adopting into ledger`,{hash:t.hash,folderMillis:t.folderMillis,statementIndex:n}),await hn(e,t);return}throw console.error(`[storage-migrations] Failed to apply migration statement`,{hash:t.hash,folderMillis:t.folderMillis,statementIndex:n,statement:r,error:i}),i}await pn(e,t)}catch(n){throw await un(e.session,{hash:t.hash,folderMillis:t.folderMillis}),n}}async function _n(e,t,n){let r=Be(e),i=Ve(r.dialect),a=n??i.migrations.defaultLedgerTable;await r.withSession(async e=>{let n={session:e,engine:i,tableName:a,tableId:z.identifier(a)},r=await fn(n);for(let e of t)r.has(e.hash)||(await gn(n,e),r.add(e.hash))})}async function vn(e,t={}){await _n(e,cn({migrationsDir:t.migrationsDir,expectedDialect:ze(e)})),await Ge(e).fts.provisionSearchIndex(e)}var yn=class{configPath;constructor(e){this.configPath=A.join(e,`config.json`)}async getConfig(){try{let e=await k.readFile(this.configPath,`utf-8`);return I.parse(JSON.parse(e))}catch(e){if(e.code===`ENOENT`)return I.parse({});if(e instanceof SyntaxError||e instanceof Error&&e.name===`ZodError`)return console.warn(`[FileConfigStorage] Failed to parse config, falling back to defaults:`,e),I.parse({});throw e}}async saveConfig(e){let t=A.dirname(this.configPath);await k.mkdir(t,{recursive:!0}),await k.writeFile(this.configPath,JSON.stringify(e,null,2),{encoding:`utf-8`,mode:384}),await k.chmod(this.configPath,384)}};function bn(e){try{let t=A.resolve(Dt(e),`static/model-registry.yaml`);return F(t)?t:void 0}catch{return}}async function xn(e,t){await new Promise((n,r)=>{if(e.address()){n();return}let i=e=>{if(o(),e.code===`EADDRINUSE`){r(Error(`Port ${t} is already in use`));return}r(e)},a=()=>{o(),n()},o=()=>{e.off(`error`,i),e.off(`listening`,a)};e.once(`error`,i),e.once(`listening`,a)}),e.on(`error`,e=>{console.error(`[HttpServer] Post-bind error:`,e)})}function Sn(e){let t=e.address();if(typeof t==`object`&&t&&`port`in t)return t.port;throw Error(`HTTP server is not bound to a TCP address`)}function Cn(e,t){let n=e,r=!1;return{fetch:(e,i,a)=>{if(!r)return new Response(`Makaio runtime is booting`,{status:503,headers:{"Retry-After":`1`}});let{pathname:o}=new URL(e.url);return t?.health&&e.method===`GET`&&o===`/health`?Response.json(t.health()):e.method===`GET`&&o===`/bus`?new Response(`WebSocket endpoint`,{status:426,headers:{Upgrade:`websocket`}}):n.fetch(e,i,a)},markReady(){r=!0},replaceApp(e){n=e}}}const wn=[`extension`,`static-fallback`];function Tn(e){let t=[];function n(e){let t=new Ot,n=[...e].sort((e,t)=>wn.indexOf(e.phase)-wn.indexOf(t.phase));for(let e of n)e.mount(t);return t}function r(){return n(t)}function i(r){e&&e.replaceApp(n(r)),t=r}return{add(e){i([...t,e])},remove(e){let n=t.filter(t=>t.owner!==e);n.length!==t.length&&i(n)},build:r,get contributions(){return[...t]}}}function En(e,t){if(!(e instanceof Error))return!1;let{rootPackageName:n,subpath:r}=On(t),i=(r===void 0?[t]:[t,n]).flatMap(e=>[`Cannot find package '${e}'`,`Cannot find module '${e}'`,`Cannot find package "${e}"`,`Cannot find module "${e}"`]),a=e;return(a.code===`ERR_MODULE_NOT_FOUND`||a.code===`MODULE_NOT_FOUND`)&&i.some(t=>e.message.includes(t))||a.code===`ERR_PACKAGE_PATH_NOT_EXPORTED`&&r!==void 0&&e.message.includes(`Package subpath '${r}' is not defined by "exports"`)&&kn(e.message,n)?!0:i.some(t=>e.message.includes(t))}async function Dn(e){try{return await import(e)}catch(t){if(En(t,e))return null;throw t}}function On(e){let t=e.split(`/`);return e.startsWith(`@`)?{rootPackageName:t.slice(0,2).join(`/`),subpath:t.length>2?`./${t.slice(2).join(`/`)}`:void 0}:{rootPackageName:t[0]??e,subpath:t.length>1?`./${t.slice(1).join(`/`)}`:void 0}}function kn(e,t){let n=t,r=t.replaceAll(`/`,`\\`);return e.includes(`/${n}/package.json`)||e.includes(`\\${r}\\package.json`)}function An(e){let t=e.url?.split(`?`)[0]??``;return t===`/bus`?!0:(t===`/`||t===``)&&e.headers.origin===void 0}function jn(e,t){return(n,r,i)=>{if(!An(n))return;let a=e();if(!a||!t()){r.destroy();return}a.handleUpgrade(n,r,i,e=>{a.emit(`connection`,e,n)})}}var Mn=class{options;busServer=null;websocketServer=null;upgradeHandlerServer=null;upgradeHandler=null;busReady=!1;connecting=!1;constructor(e){this.options=e}get dispatchingAuth(){return this.options.auth instanceof Oe?this.options.auth:void 0}async connect(e,t){if(this.connecting||this.busServer||this.websocketServer)throw Error(`[BusServerTransport] connect() called while transport is already connected or connecting`);if(this.options.httpServer.address()===null)throw Error(`[BusServerTransport] httpServer must already be listening before connect() is called`);this.connecting=!0;try{let t=new jt({noServer:!0});this.websocketServer=t;let n=jn(()=>this.websocketServer,()=>this.busReady);this.options.httpServer.on(`upgrade`,n),this.upgradeHandlerServer=this.options.httpServer,this.upgradeHandler=n,this.busServer=await At({websocket:t,bus:e,auth:this.options.auth,loopbackName:this.options.loopbackName??`node`}),this.busReady=!0}catch(e){throw await this.stopBusServer(`startup error`),this.detachUpgradeHandler(),await this.stopWebSocketServer(`startup error`),e}finally{this.connecting=!1}}async disconnect(){await this.stopBusServer(`shutdown`),this.detachUpgradeHandler(),await this.stopWebSocketServer(`shutdown`)}async stopBusServer(e){this.busReady=!1,this.busServer&&=(await this.busServer.stop().catch(t=>{console.error(`[BusServerTransport] Failed to stop bus server during ${e}:`,t)}),null)}detachUpgradeHandler(){this.upgradeHandlerServer&&this.upgradeHandler&&this.upgradeHandlerServer.off(`upgrade`,this.upgradeHandler),this.upgradeHandlerServer=null,this.upgradeHandler=null}async stopWebSocketServer(e){this.websocketServer&&=(await new Promise((e,t)=>{this.websocketServer.close(n=>n?t(n):e())}).catch(t=>{t instanceof Error&&t.message===`The server is not running`||console.error(`[BusServerTransport] Failed to close WebSocket server during ${e}:`,t)}),null)}},Nn=class extends Mt{keysDir;constructor(e,t){super(e),this.keysDir=A.join(t,`keys`)}async getConfig(e){let t=await super.getConfig(e);return t.bus?.remote&&!t.bus.remote.secret&&(t.bus.remote.secret=this.generateSecret(),(await this.getStoredConfig()).bus?.remote?.url===t.bus.remote.url&&await this.saveConfig(await this.prepareConfigForPersistence(t))),t}generateSecret(){return M.randomBytes(32).toString(`base64`)}async getMachineId(){return(await wt(this.keysDir)).machineId}getEnv(e){return process.env[e]}};function Pn(e,t){return{extensions:e.discovery??new s(void 0,{extensionsDir:j.join(t,`extensions`),nodeModulesDir:j.join(t,`node_modules`)})}}function Fn(e){return F(j.join(e,`meta`,`_journal.json`))}function In(e,t={}){let{moduleDir:n=import.meta.dirname,getMigrationsFolder:r=on}=t,i=Ve(e).migrations.chainDirName,a=[],o=j.resolve(n,`..`,i);if(Fn(o))return o;a.push(o);try{let t=r(e);if(Fn(t))return t;a.push(t)}catch(t){a.push(`getMigrationsFolder('${e}') unavailable: ${t instanceof Error?t.message:String(t)}`)}throw Error(`resolveBundledMigrationsDir: no '${e}' migrations directory with meta/_journal.json found. Probed: ${a.join(`; `)}. Pass an explicit migrations directory (boot option 'centralMigrationsDir' or InitializeNodeDatabaseOptions.migrationsDir) when migrations are staged elsewhere.`)}function Ln(e){if(process.platform===`win32`)return!0;let t=e?.code;return t===`ENOSYS`||t===`EINVAL`}function Rn(e){return e===void 0||e.trim()===``?void 0:e}function zn(e){try{let t=new URL(e);if(t.host!==``)return`${t.protocol}//${t.host}${t.pathname}`}catch{}let t=e.indexOf(`:`);return t===-1?`<unparseable database URL>`:`${e.slice(0,t+1)}…`}async function Bn(e,t,n){let r;try{r=await import(O(oe(A.resolve(t,`package.json`)).resolve(e.packageName)).href)}catch(t){throw Error(`initializeNodeDatabase: the database URL from ${n} targets the '${e.dialect}' storage engine, but '${e.packageName}' could not be loaded. Install ${e.packageName} in the host application, or pass its already-loaded storageEngine via the 'database.engines' boot option.`,{cause:t})}let i=r.storageEngine;if(i===void 0||i.dialect!==e.dialect)throw Error(`initializeNodeDatabase: '${e.packageName}' does not provide a storage engine for dialect '${e.dialect}'. Auto-resolved engine packages must export 'storageEngine: StorageEngine' with a matching dialect.`);Re(e.dialect)===void 0&&Ue(i)}async function Vn(e){let t=Rn(e.database?.url),n=t??Rn(process.env.MAKAIO_DATABASE_URL);if(n!==void 0){let r=t===void 0?`the MAKAIO_DATABASE_URL environment variable`:`the 'database.url' boot option`,i=Ke(n);if(i.kind===`missing-engine`&&(await Bn(i,e.database?.enginePackageImportBasePath??process.cwd(),r),i=Ke(n)),i.kind!==`engine`){let e=Fe.map(e=>e.packageName).join(`, `);throw Error(`initializeNodeDatabase: unsupported database URL '${zn(n)}' from ${r}. URL targets require a storage engine that claims the URL (e.g. postgres:// / postgresql:// via ${e}); SQLite targets are configured via the dbPath option or MAKAIO_DATABASE_PATH.`)}return{kind:`url`,url:n,dialect:i.engine.dialect}}let r=A.resolve(Rn(e.dbPath)??Rn(process.env.MAKAIO_DATABASE_PATH)??A.join(e.makaioHome,`makaio.db`));return{kind:`file`,dbPath:r,url:O(r).href}}async function Hn(e){for(let t of e.database?.engines??[])Ue(t);let t=await Vn(e);if(t.kind===`url`){let n=await vt({url:t.url,postgres:{poolMax:e.database?.poolMax}});try{let r=e.migrationsDir??In(t.dialect);return await vn(n.db,{migrationsDir:r}),{databaseClient:n}}catch(e){throw await n.close(),e}}let{dbPath:n}=t,r=A.dirname(n);await P.promises.mkdir(r,{recursive:!0});let i=await vt({url:t.url});try{await vn(i.db,{migrationsDir:e.migrationsDir});try{await P.promises.chmod(n,384)}catch(e){if(!Ln(e))throw e;console.warn(`[initializeNodeDatabase] Failed to set SQLite file permissions (continuing; this may be unsupported on Windows):`,e)}return{databaseClient:i,dbPath:n}}catch(e){throw await i.close(),e}}const Un=D.object({npmName:D.string(),version:D.string(),source:D.enum([`new`,`upgraded`,`already-present`])}),Wn=D.object({npmName:D.string(),reason:D.string()}),Gn=D.object({success:D.boolean(),packageName:D.string(),version:D.string().optional(),restartRequired:D.boolean(),error:D.string().optional(),installed:D.array(Un).optional(),skipped:D.array(Wn).optional(),warnings:D.array(D.string()).optional()}),Kn=D.object({success:D.boolean(),packageName:D.string(),error:D.string().optional(),restartRequired:D.boolean()}),qn=D.object({name:D.string(),version:D.string(),description:D.string().optional(),hasDescriptor:D.boolean().default(!1),serverImportPath:D.string().min(1).optional()}),Jn=D.object({packageName:D.string(),latestVersion:D.string(),success:D.boolean(),error:D.string().optional()}),Yn=D.object({name:D.string(),displayName:D.string(),description:D.string(),icon:D.string().optional(),tags:D.array(D.string()).optional(),descriptorName:D.string().min(1).optional()}),Xn=D.object({$schema:D.string(),updatedAt:D.string(),adapters:D.array(Yn),extensions:D.array(Yn)}),Zn=D.object({name:D.string(),currentVersion:D.string(),latestVersion:D.string(),description:D.string().optional()}),Qn=de(`packages`,{list:{request:D.object({}),response:D.object({packages:D.array(qn)})},install:{request:D.object({packageName:D.string().optional(),packageNames:D.array(D.string()).min(1).optional(),source:D.enum([`npm`,`local`]).optional(),force:D.boolean().optional()}).refine(e=>e.packageName!==void 0||e.packageNames!==void 0,{message:`Expected packageName or packageNames`}),response:Gn},uninstall:{request:D.object({packageName:D.string()}),response:Kn},getLatestVersion:{request:D.object({packageName:D.string()}),response:Jn},getRegistry:{request:D.object({}),response:Xn},checkUpdates:{request:D.object({}),response:D.object({updates:D.array(Zn)})},installed:D.object({packageName:D.string(),version:D.string()}),uninstalled:D.object({packageName:D.string()})}),V=Qn.subjects;async function $n(e,t,n){if(!A.isAbsolute(e))return;let r;try{r=await k.realpath(e)}catch{return}let i=er(t,n),a=[A.resolve(r,`src`,`${i}.ts`),A.resolve(r,`dist`,`${i}.mjs`)];for(let e of a){let t=await tr(e);if(t!==void 0&&nr(t,r))return t}}function er(e,t){return t===!0?e:t}async function tr(e){try{return await k.realpath(e)}catch{return}}function nr(e,t){let n=A.relative(t,e);return n.length>0&&!n.startsWith(`..`)&&!A.isAbsolute(n)}var rr=class{extensionsDir;constructor(e){this.extensionsDir=A.resolve(e)}async install(e){try{let t=A.resolve(e.endsWith(`descriptor.json`)?A.dirname(e):e),n=await k.realpath(t),r=await this.readDescriptor(n);Ce(r)||await this.validateEntrypoints(n,r.entrypoints);let i=this.linkPathFor(r.name);await k.mkdir(A.dirname(i),{recursive:!0});try{if((await k.lstat(i)).isSymbolicLink())await k.unlink(i);else throw Error(`${i} already exists and is not a symlink`)}catch(e){if(e.code!==`ENOENT`)throw e}let a=process.platform===`win32`?`junction`:`dir`;return await k.symlink(n,i,a),{success:!0,packageName:r.name,version:r.version,restartRequired:!0}}catch(e){return{success:!1,packageName:``,error:e instanceof Error?e.message:String(e),restartRequired:!1}}}async uninstall(e){try{let t=this.linkPathFor(e);if(await k.unlink(t),e.startsWith(`@`)){let e=A.dirname(t);(await k.readdir(e).catch(()=>null))?.length===0&&await k.rmdir(e).catch(()=>{})}return{success:!0,packageName:e,restartRequired:!0}}catch(t){return{success:!1,packageName:e,error:t instanceof Error?t.message:String(t),restartRequired:!1}}}async list(){try{await k.access(this.extensionsDir)}catch{return[]}let e=await k.readdir(this.extensionsDir),t=[];for(let n of e){let e=A.join(this.extensionsDir,n);if(n.startsWith(`@`)){let n=await k.readdir(e).catch(()=>[]);for(let r of n){let n=A.join(e,r),i=await this.readLocalEntry(n);i!==null&&t.push(i)}}else{let n=await this.readLocalEntry(e);n!==null&&t.push(n)}}return t}async readLocalEntry(e){try{if(!(await k.lstat(e)).isSymbolicLink())return null;let t=await k.readlink(e),n=await k.realpath(A.resolve(A.dirname(e),t)),r=A.join(n,`descriptor.json`),i=await k.readFile(r,`utf-8`),a=Te(JSON.parse(i));if(!a.success)return null;let o=a.data.entrypoints?.server,s=o===void 0?void 0:await $n(n,`server`,o);return{name:a.data.name,version:a.data.version,sourcePath:n,source:`local`,...s!==void 0&&{serverImportPath:s}}}catch{return null}}async readDescriptor(e){let t=A.join(e,`descriptor.json`),n=await k.readFile(t,`utf-8`).catch(()=>{throw Error(`descriptor.json not found at ${t}`)}),r=Te(JSON.parse(n));if(!r.success)throw Error(`Invalid descriptor.json: ${r.error.message}`);return r.data}async validateEntrypoints(e,t){await Promise.all(Object.entries(t).map(async([t,n])=>{if(n!==void 0&&await $n(e,t,n)===void 0){let e=er(t,n);throw Error(`${t} entrypoint "${e}" has no resolvable candidate: neither src/${e}.ts nor dist/${e}.mjs exists within the extension root`)}}))}linkPathFor(e){let t=A.resolve(this.extensionsDir,...e.split(`/`)),n=A.relative(this.extensionsDir,t);if(n===``||n.startsWith(`..`)||A.isAbsolute(n))throw Error(`Invalid extension name: ${e}`);return t}};const ir=`nodeLinker: node-modules`,ar=/^[A-Za-z]:[\\/]/;let or=null;function H(){return or||(or=Promise.all([import(`../lib-Ba55od_d.mjs`).then(e=>t(e.t(),1)),import(`../lib-ZKtnbCqH.mjs`).then(e=>t(e.t(),1)),import(`../lib-CM_BUxN8.mjs`).then(e=>t(e.default,1))]).then(([e,t,n])=>({Configuration:e.Configuration,Project:e.Project,Cache:e.Cache,StreamReport:e.StreamReport,structUtils:e.structUtils,ppath:t.ppath,npath:t.npath,xfs:t.xfs,getPluginConfiguration:n.getPluginConfiguration})),or)}var sr=class{makaioHome;constructor(e){this.makaioHome=e}async initialize(){try{let{npath:e,ppath:t,xfs:n}=await H(),r=e.toPortablePath(this.makaioHome),i=t.join(r,`package.json`);if(await n.mkdirpPromise(r),await this.ensureYarnRc(r,n,t),await n.existsPromise(i))return;await n.writeJsonPromise(i,{name:`makaio-packages`,version:`1.0.0`,private:!0,description:`Makaio installed packages`,dependencies:{}}),console.info(`[YarnPackageManager] Created package.json at %s`,i)}catch(e){throw Error(`Failed to initialize package.json`,{cause:e})}}async ensureYarnRc(e,t,n){let r=n.join(e,`.yarnrc.yml`),i=await t.existsPromise(r)?await t.readFilePromise(r,`utf8`):``,a=fr(i);i!==a&&(await t.writeFilePromise(r,a),console.info(`[YarnPackageManager] Wrote .yarnrc.yml at %s`,r))}async loadYarnState(){let{Configuration:e,Project:t,Cache:n,npath:r,getPluginConfiguration:i}=await H(),a=r.toPortablePath(this.makaioHome),o=await e.find(a,i()),{project:s}=await t.find(o,a);return{configuration:o,project:s,cache:await n.find(o)}}async runProjectInstall(e,t,n){let{StreamReport:r}=await H();if((await r.start({configuration:e,stdout:process.stdout},async e=>{await t.install({cache:n,report:e})})).hasErrors())throw Error(`Yarn install failed with errors`)}async parsePackageDescriptor(e){let{structUtils:t}=await H(),n=t.parseDescriptor(e);return n.range===`unknown`?t.makeDescriptor(n,`latest`):n}async installPackage(e){try{let{structUtils:t}=await H(),{configuration:n,project:r,cache:i}=await this.loadYarnState(),a=await this.parsePackageDescriptor(e),o=t.stringifyIdent(a),s=r.topLevelWorkspace.manifest.dependencies.get(a.identHash);r.topLevelWorkspace.manifest.dependencies.set(a.identHash,a),await this.runProjectInstall(n,r,i);let c=r.storedResolutions.get(a.descriptorHash);if(!c)throw Error(`Package resolution not found after installation`);let l=r.storedPackages.get(c);if(!l)throw Error(`Package not found after installation`);let u=l.version??`unknown`;if(!(await this.readInstalledDescriptor(o)).hasDescriptor)throw s?r.topLevelWorkspace.manifest.dependencies.set(a.identHash,s):r.topLevelWorkspace.manifest.dependencies.delete(a.identHash),await this.runProjectInstall(n,r,i),Error(`Installed package ${o} does not contain a valid descriptor.json`);return console.info(`[YarnPackageManager] Installed %s@%s`,o,u),u}catch(t){throw Error(`Failed to install ${e}`,{cause:t})}}async uninstallPackage(e){try{let{structUtils:t}=await H(),{configuration:n,project:r,cache:i}=await this.loadYarnState(),a=t.parseIdent(e);if(!r.topLevelWorkspace.manifest.dependencies.delete(a.identHash))throw Error(`Package ${e} not found in dependencies`);await this.runProjectInstall(n,r,i),console.info(`[YarnPackageManager] Uninstalled %s`,e)}catch(t){throw Error(`Failed to uninstall ${e}`,{cause:t})}}async listPackages(){try{let{xfs:e,npath:t,ppath:n,structUtils:r}=await H(),i=t.toPortablePath(this.makaioHome),a=n.join(i,`package.json`);if(!await e.existsPromise(a))return[];let{project:o}=await this.loadYarnState(),s=[];for(let[,e]of o.topLevelWorkspace.manifest.dependencies){let t=r.stringifyIdent(e),n=o.storedResolutions.get(e.descriptorHash),i=(n?o.storedPackages.get(n):void 0)?.version??r.parseRange(e.range).selector,a=await this.readInstalledDescriptor(t);a.hasDescriptor&&s.push({name:t,version:i,hasDescriptor:!0,...a.serverImportPath!==void 0&&{serverImportPath:a.serverImportPath}})}return s}catch(e){throw Error(`Failed to list packages`,{cause:e})}}async ensureFrameworkDependency(e){let t=ur(e);try{let{structUtils:e}=await H(),{configuration:n,project:r,cache:i}=await this.loadYarnState(),a=e.makeDescriptor(e.parseIdent(`@makaio/framework`),t);if(r.topLevelWorkspace.manifest.dependencies.get(a.identHash)?.range===t)return;r.topLevelWorkspace.manifest.dependencies.set(a.identHash,a),await this.runProjectInstall(n,r,i),console.info(`[YarnPackageManager] Ensured @makaio/framework@%s`,t)}catch(e){throw Error(`Failed to ensure @makaio/framework@${t}`,{cause:e})}}async getLatestVersion(e){return this.resolvePackageVersion(e)}async readInstalledDescriptor(e){let t=await this.readInstalledExtensionDescriptor(e);if(t===null)return{hasDescriptor:!1};let n=await this.resolveInstalledServerEntrypoint(e,t);return{hasDescriptor:!0,...n!==void 0&&{serverImportPath:n}}}async resolveInstalledServerEntrypoint(e,t){let n=t.entrypoints?.server;if(n!==void 0)return $n(A.join(this.makaioHome,`node_modules`,...e.split(`/`)),`server`,n)}async readInstalledExtensionDescriptor(e){let t=A.join(this.makaioHome,`node_modules`,...e.split(`/`),`descriptor.json`),n;try{let e=await k.readFile(t,`utf-8`);n=JSON.parse(e)}catch(e){if(e instanceof SyntaxError||pr(e))return null;throw e}let r=Te(n);return r.success?r.data:null}async listInstalledExtensionDescriptors(){let e=A.join(this.makaioHome,`package.json`),t;try{let n=await k.readFile(e,`utf-8`);t=JSON.parse(n)}catch(e){if(pr(e))return[];throw e}let n=Object.keys(t.dependencies??{});return(await Promise.all(n.map(async e=>{let t=await this.readInstalledExtensionDescriptor(e);return t===null?null:{npmName:e,version:await this.readInstalledPackageVersion(e),descriptor:t}}))).filter(e=>e!==null)}async readInstalledPackageVersion(e){let t=A.join(this.makaioHome,`node_modules`,...e.split(`/`),`package.json`);try{let e=await k.readFile(t,`utf-8`),n=JSON.parse(e);return typeof n.version==`string`?n.version:`unknown`}catch{return`unknown`}}async readManifestSnapshot(){let e=A.join(this.makaioHome,`package.json`),t=await k.readFile(e,`utf-8`);return JSON.parse(t)}async writeManifestAndReinstall(e){let t=A.join(this.makaioHome,`package.json`);await k.writeFile(t,`${JSON.stringify(e,null,2)}\n`,`utf-8`);let{configuration:n,project:r,cache:i}=await this.loadYarnState();await this.runProjectInstall(n,r,i)}async resolvePackageVersion(e){try{let{StreamReport:t}=await H(),{configuration:n,project:r}=await this.loadYarnState(),i=await this.parsePackageDescriptor(e),a=`unknown`;return await t.start({configuration:n,stdout:process.stdout},async e=>{let t=n.makeResolver(),o=await t.getCandidates(i,{},{project:r,resolver:t,report:e});if(o.length>0){let e=o[0];a=e.reference.match(/^npm:(.+)$/)?.[1]??e.reference}}),a}catch(t){throw Error(`Failed to resolve version for ${e}`,{cause:t})}}};function cr(e,t){return!t||t===`latest`?e:`${e}@${t}`}function lr(e){if(e.startsWith(`@`)){let t=e.indexOf(`/`);if(t===-1)return e;let n=e.indexOf(`@`,t+1);return n===-1?e:e.slice(0,n)}let t=e.indexOf(`@`);return t===-1?e:e.slice(0,t)}function ur(e){return e.localPackagePath?`portal:${dr(e.localPackagePath)}`:e.versionRange}function dr(e){let t=(ar.test(e)?e:A.resolve(e)).replace(/\\/g,`/`);return ar.test(t)?`/${t}`:t}function fr(e){let t=e.split(/\r?\n/),n=!1,r=t.map(e=>/^\s*nodeLinker\s*:/.test(e)?(n=!0,ir):e);if(!n){let t=e.trimEnd();return`${t}${t.length>0?`
1
+ import{i as e,o as t,t as n}from"../chunk-DTipWd-i.mjs";import{t as r}from"../semver-CIhHqMkw.mjs";import{RuntimeNamespace as i,RuntimeSubjects as a}from"./bus/runtime/namespace.mjs";import{ExplicitDescriptorDiscovery as o,FilesystemDescriptorDiscovery as s,MergedDescriptorDiscovery as c}from"./extension-discovery.mjs";import{MAKAIO_CONFIG_FILE_ENV as l,MAKAIO_HOME_ENV as u,buildConfiguredRuntimeOptions as d,createMakaioConfigDiscovery as f,defineMakaioConfig as p,loadMakaioConfig as m,parseMakaioConfig as h,resolveMakaioConfigPath as g,resolveMakaioHome as _,shouldIncludeExtension as v}from"./makaio-config.mjs";import{t as y}from"../descriptor-to-package-DdpjpT7n.mjs";import{a as b,c as x,i as S,n as C,o as w,r as T,s as E,t as ee}from"../load-extensions-Cze1RHcG.mjs";import{i as te,o as ne,r as re,s as ie,t as ae}from"../workflow-worker-dH70EbjE.mjs";import{createRequire as oe}from"node:module";import{z as D}from"zod";import{execFile as se}from"node:child_process";import{promisify as ce}from"node:util";import{fileURLToPath as le,pathToFileURL as O}from"node:url";import*as k from"node:fs/promises";import*as A from"node:path";import j from"node:path";import*as M from"node:crypto";import{createHash as N}from"node:crypto";import*as P from"node:fs";import{existsSync as F,readFileSync as ue}from"node:fs";import{createBusNamespace as de}from"@makaio/framework/core";import{ChannelClosedError as fe,MakaioBus as pe,openChannel as me,projectSubjectTelemetryFacts as he}from"@makaio/framework/bus";import{AIModelSchema as ge,AdapterSubjects as _e,BUILT_IN_THIN_WORKFLOW_PROVIDER_ID as ve,ConfigSchema as I,ConfigSubjects as L,CredentialSubjects as ye,FrameworkContractNamespaces as be,FrameworkStorageNamespaces as xe,SubjectTelemetrySubjects as Se,isDetachedDescriptor as Ce,registerWorkerNodeProvider as we,safeParseExtensionDescriptor as Te,unregisterWorkerNodeProvider as Ee,versionSatisfies as De}from"@makaio/framework/contracts";import{DispatchingAuth as Oe,E2EAuth as ke,HmacAuth as Ae,WebSocketClientTransport as je}from"@makaio/framework/node/transports";import{BaseService as Me}from"@makaio/framework/service-base";import{uniqueIndex as Ne}from"drizzle-orm/sqlite-core";import{uniqueIndex as Pe}from"drizzle-orm/pg-core";import{STORAGE_ENGINE_URL_HINTS as Fe,defineDialectSchema as Ie,defineDualTable as Le,findStorageEngine as Re,getDatabaseDialect as ze,getRawSqlExecutor as Be,getStorageEngine as Ve,registerDrizzleHandlers as He,registerStorageEngine as Ue,resolveSchema as We,resolveStorageEngine as Ge,resolveStorageEngineForUrl as Ke}from"@makaio/framework/storage/drizzle";import{and as qe,eq as R,sql as z}from"drizzle-orm";import{parseStoredCredentialRef as Je}from"@makaio/framework/contracts/config";import{AdapterRuntimeSubjects as Ye,registerAdapterRuntimeIdentityHandlers as Xe}from"@makaio/framework/services/adapter-runtime";import{buildProviderContext as Ze}from"@makaio/framework/services/provider-context";import*as Qe from"node:os";import{ProviderStorageSubjects as $e}from"@makaio/framework/services/settings/storage";import{isRecord as et}from"@makaio/framework/utils";import{BootNamespace as tt,ExtensionCoordinator as nt,ExtensionNamespace as rt,KernelNamespace as it,coalesceExtensionOverrides as at,createShutdownSequence as ot,filterEligibleExtensions as st}from"@makaio/framework/kernel";import{AdapterSubsystemSubjects as ct}from"@makaio/framework/services/adapter-subsystem";import{CachedRegistryFetcher as lt,FallbackRegistryFetcher as ut,ModelRegistrySchema as dt,ProviderModelOverrideSchema as ft,mergeModelMetadata as pt}from"@makaio/framework/services/model-registry";import{createClientsCorePackage as mt}from"@makaio/framework/clients";import{Readable as ht,Transform as gt}from"node:stream";import{pipeline as _t}from"node:stream/promises";import{createDatabaseClient as vt}from"@makaio/framework/storage/drizzle/client";import{AdapterSubsystemToken as yt,FileAdapterConfigRepository as bt,createAdapterSubsystemContributionProcessor as xt,createAdapterSubsystemPackage as St}from"@makaio/framework/adapter-subsystem";import{loadOrCreateMachineIdentity as Ct,loadOrCreateMachineIdentity as wt,machineKeysExist as Tt,validateMachineKeys as Et}from"@makaio/framework/node/machine-identity";import{resolveWorkspaceRoot as Dt}from"@makaio/framework/utils/workspace-root";import{Hono as Ot}from"hono";import{CliNamespace as kt}from"@makaio/framework/kernel/cli";import{startBusServer as At}from"@makaio/framework/node/bus-server";import{WebSocketServer as jt}from"ws";import{ConfigProvider as Mt}from"@makaio/framework/providers";import{KernelSubjects as B}from"@makaio/framework/kernel/namespace";import{FrameworkServicesCoreNamespaces as Nt,SessionOrchestratorToken as Pt,createArtifactKindContributionProcessor as Ft,createArtifactLifecycleHookContributionProcessor as It,createFacetNamespaceContributionProcessor as Lt,createModelRegistryPackage as Rt,createSurfaceBindingContributionProcessor as zt,createToolContributionProcessor as Bt,createTransitionContributionProcessor as Vt,createWorkflowBlockContributionProcessor as Ht,frameworkCorePackages as Ut}from"@makaio/framework/services";import{createLogImportContributionProcessor as Wt,logImportRegistryPackage as Gt}from"@makaio/framework/services/log-import";import{createWorkflowEnginePackage as Kt}from"@makaio/framework/workflow-engine/package";import{PreferenceValueSchema as qt,PreferencesSubjects as Jt}from"@makaio/framework/services/preferences";import{resolveConnectorCredentials as Yt,resolveCredentialRef as Xt}from"@makaio/framework/adapters/config";import{DefinitionSubjects as Zt}from"@makaio/framework/services/definition";import{ProviderRuntimeSubjects as Qt}from"@makaio/framework/services/provider-runtime";import{SettingsSubjects as $t}from"@makaio/framework/services/settings/namespace";import{parseWorkspaceGlobs as en}from"@makaio/framework/utils/workspace-packages";import{serveStatic as tn}from"@hono/node-server/serve-static";function nn(e){return e.on(_e.getCapabilities,async t=>{let{adapterName:n,adapterId:r}=t.payload;if(r){await t.next();return}if(n){let r=await e.requestOptional(Ye.resolveId,{adapterName:n}),i=r.handled?r.data.adapterId:void 0;i&&(t.payload.adapterId=i)}await t.next()},{priority:20})}function rn(e){let{coordinator:t,configRepository:n,platformDefaults:r}=e,i=St({configRepository:n,coordinator:t,platformDefaults:r});return t.registerContributionProcessor(xt({getAdapterSubsystemService:()=>t.getExtensionService(yt)})),{adapterSubsystemPackage:i}}function an(e){let{bus:t,currentMachineId:n}=e,r=Xe(t,{currentMachineId:n,listKnownAdapterNames:e.listKnownAdapterNames??(async()=>{let{configs:e}=await t.request(ct.listAdapterConfigs,{});return e.map(e=>e.name)})}),i=nn(t);return{cleanup:()=>{r.cleanup(),i()}}}function on(e=`sqlite`){let{migrations:t}=Ve(e);return t.resolveSourceChainDir?.()??j.resolve(import.meta.dirname,`..`,t.chainDirName)}var sn=class extends Error{expectedDialect;journalDialect;constructor(e,t,n,r){super(`Migration journal at ${r} declares dialect '${n??`unknown`}', but the target database speaks '${e}'. Point the runner at a migrations directory generated for '${e}' (journal dialect '${t}').`),this.name=`MigrationDialectMismatchError`,this.expectedDialect=e,this.journalDialect=n}};function cn(e={}){let t=typeof e==`string`?void 0:e.expectedDialect,n=typeof e==`string`?e:e.migrationsDir??on(t),r=j.join(n,`meta`,`_journal.json`);if(!F(r))throw Error(`Cannot find migrations journal at ${r}`);let i=JSON.parse(ue(r,`utf-8`));if(t!==void 0){let e=Ve(t).migrations.journalDialect;if(i.dialect!==e)throw new sn(t,e,i.dialect,r)}return i.entries.map(e=>{let t=ue(j.join(n,`${e.tag}.sql`),`utf-8`);return{tag:e.tag,sql:t.split(`--> statement-breakpoint`),folderMillis:e.when,hash:N(`sha256`).update(t).digest(`hex`),bps:e.breakpoints}})}function ln(e){return e.replace(/--.*$/gm,``).trim()}async function un(e,t){try{await e.run(z.raw(`ROLLBACK`))}catch(e){console.error(`[storage-migrations] Failed to roll back migration transaction`,{...t,rollbackError:e})}}async function dn(e){let{migrations:t}=e.engine;if(await e.session.run(z.raw(t.beginTransactionStatement)),t.acquireTransactionLock)try{await t.acquireTransactionLock(e.session,e.tableName)}catch(t){throw await un(e.session,{migrationsTable:e.tableName}),t}}async function fn(e){let t=e.engine.migrations.acquireTransactionLock!==void 0;t&&await dn(e);try{await e.session.run(z.raw(e.engine.migrations.buildLedgerDdl(e.tableName)));let n=await e.session.all(z`SELECT hash FROM ${e.tableId}`);return t&&await e.session.run(z.raw(`COMMIT`)),new Set(n.map(e=>e.hash))}catch(n){throw t&&await un(e.session,{migrationsTable:e.tableName}),n}}async function pn(e,t){try{await e.session.run(z`INSERT INTO ${e.tableId} ("hash", "created_at") VALUES (${t.hash}, ${t.folderMillis})`),await e.session.run(z.raw(`COMMIT`))}catch(e){throw console.error(`[storage-migrations] Failed to finalize migration`,{hash:t.hash,folderMillis:t.folderMillis,error:e}),e}}async function mn(e,t){return e.engine.migrations.acquireTransactionLock===void 0||(await e.session.all(z`SELECT hash FROM ${e.tableId} WHERE hash = ${t.hash}`)).length===0?!1:(console.warn(`[storage-migrations] Migration already recorded by a concurrent runner, skipping`,{hash:t.hash,folderMillis:t.folderMillis}),await e.session.run(z.raw(`COMMIT`)),!0)}async function hn(e,t){await e.session.run(z.raw(`ROLLBACK`)),await dn(e),!await mn(e,t)&&await pn(e,t)}async function gn(e,t){await dn(e);try{if(await mn(e,t))return;for(let[n,r]of t.sql.entries())if(ln(r))try{await e.session.run(z.raw(r))}catch(i){if(n===0&&/^\s*CREATE\s/i.test(r)&&e.engine.errors.isDuplicateObjectError(i)){if(t.sql.length>1)throw Error(`Cannot adopt multi-statement migration '${t.tag}' because its first schema object already exists. Reset the database or provide an incremental migration.`,{cause:i});console.warn(`[storage-migrations] Schema object already exists, adopting into ledger`,{hash:t.hash,folderMillis:t.folderMillis,statementIndex:n}),await hn(e,t);return}throw console.error(`[storage-migrations] Failed to apply migration statement`,{hash:t.hash,folderMillis:t.folderMillis,statementIndex:n,statement:r,error:i}),i}await pn(e,t)}catch(n){throw await un(e.session,{hash:t.hash,folderMillis:t.folderMillis}),n}}async function _n(e,t,n){let r=Be(e),i=Ve(r.dialect),a=n??i.migrations.defaultLedgerTable;await r.withSession(async e=>{let n={session:e,engine:i,tableName:a,tableId:z.identifier(a)},r=await fn(n);for(let e of t)r.has(e.hash)||(await gn(n,e),r.add(e.hash))})}async function vn(e,t={}){await _n(e,cn({migrationsDir:t.migrationsDir,expectedDialect:ze(e)})),await Ge(e).fts.provisionSearchIndex(e)}var yn=class{configPath;constructor(e){this.configPath=A.join(e,`config.json`)}async getConfig(){try{let e=await k.readFile(this.configPath,`utf-8`);return I.parse(JSON.parse(e))}catch(e){if(e.code===`ENOENT`)return I.parse({});if(e instanceof SyntaxError||e instanceof Error&&e.name===`ZodError`)return console.warn(`[FileConfigStorage] Failed to parse config, falling back to defaults:`,e),I.parse({});throw e}}async saveConfig(e){let t=A.dirname(this.configPath);await k.mkdir(t,{recursive:!0}),await k.writeFile(this.configPath,JSON.stringify(e,null,2),{encoding:`utf-8`,mode:384}),await k.chmod(this.configPath,384)}};function bn(e){try{let t=A.resolve(Dt(e),`static/model-registry.yaml`);return F(t)?t:void 0}catch{return}}async function xn(e,t){await new Promise((n,r)=>{if(e.address()){n();return}let i=e=>{if(o(),e.code===`EADDRINUSE`){r(Error(`Port ${t} is already in use`));return}r(e)},a=()=>{o(),n()},o=()=>{e.off(`error`,i),e.off(`listening`,a)};e.once(`error`,i),e.once(`listening`,a)}),e.on(`error`,e=>{console.error(`[HttpServer] Post-bind error:`,e)})}function Sn(e){let t=e.address();if(typeof t==`object`&&t&&`port`in t)return t.port;throw Error(`HTTP server is not bound to a TCP address`)}function Cn(e,t){let n=e,r=!1;return{fetch:(e,i,a)=>{if(!r)return new Response(`Makaio runtime is booting`,{status:503,headers:{"Retry-After":`1`}});let{pathname:o}=new URL(e.url);return t?.health&&e.method===`GET`&&o===`/health`?Response.json(t.health()):e.method===`GET`&&o===`/bus`?new Response(`WebSocket endpoint`,{status:426,headers:{Upgrade:`websocket`}}):n.fetch(e,i,a)},markReady(){r=!0},replaceApp(e){n=e}}}const wn=[`extension`,`static-fallback`];function Tn(e){let t=[];function n(e){let t=new Ot,n=[...e].sort((e,t)=>wn.indexOf(e.phase)-wn.indexOf(t.phase));for(let e of n)e.mount(t);return t}function r(){return n(t)}function i(r){e&&e.replaceApp(n(r)),t=r}return{add(e){i([...t,e])},remove(e){let n=t.filter(t=>t.owner!==e);n.length!==t.length&&i(n)},build:r,get contributions(){return[...t]}}}function En(e,t){if(!(e instanceof Error))return!1;let{rootPackageName:n,subpath:r}=On(t),i=(r===void 0?[t]:[t,n]).flatMap(e=>[`Cannot find package '${e}'`,`Cannot find module '${e}'`,`Cannot find package "${e}"`,`Cannot find module "${e}"`]),a=e;return(a.code===`ERR_MODULE_NOT_FOUND`||a.code===`MODULE_NOT_FOUND`)&&i.some(t=>e.message.includes(t))||a.code===`ERR_PACKAGE_PATH_NOT_EXPORTED`&&r!==void 0&&e.message.includes(`Package subpath '${r}' is not defined by "exports"`)&&kn(e.message,n)?!0:i.some(t=>e.message.includes(t))}async function Dn(e){try{return await import(e)}catch(t){if(En(t,e))return null;throw t}}function On(e){let t=e.split(`/`);return e.startsWith(`@`)?{rootPackageName:t.slice(0,2).join(`/`),subpath:t.length>2?`./${t.slice(2).join(`/`)}`:void 0}:{rootPackageName:t[0]??e,subpath:t.length>1?`./${t.slice(1).join(`/`)}`:void 0}}function kn(e,t){let n=t,r=t.replaceAll(`/`,`\\`);return e.includes(`/${n}/package.json`)||e.includes(`\\${r}\\package.json`)}function An(e){let t=e.url?.split(`?`)[0]??``;return t===`/bus`?!0:(t===`/`||t===``)&&e.headers.origin===void 0}function jn(e,t){return(n,r,i)=>{if(!An(n))return;let a=e();if(!a||!t()){r.destroy();return}a.handleUpgrade(n,r,i,e=>{a.emit(`connection`,e,n)})}}var Mn=class{options;busServer=null;websocketServer=null;upgradeHandlerServer=null;upgradeHandler=null;busReady=!1;connecting=!1;constructor(e){this.options=e}get dispatchingAuth(){return this.options.auth instanceof Oe?this.options.auth:void 0}async connect(e,t){if(this.connecting||this.busServer||this.websocketServer)throw Error(`[BusServerTransport] connect() called while transport is already connected or connecting`);if(this.options.httpServer.address()===null)throw Error(`[BusServerTransport] httpServer must already be listening before connect() is called`);this.connecting=!0;try{let t=new jt({noServer:!0});this.websocketServer=t;let n=jn(()=>this.websocketServer,()=>this.busReady);this.options.httpServer.on(`upgrade`,n),this.upgradeHandlerServer=this.options.httpServer,this.upgradeHandler=n,this.busServer=await At({websocket:t,bus:e,auth:this.options.auth,loopbackName:this.options.loopbackName??`node`}),this.busReady=!0}catch(e){throw await this.stopBusServer(`startup error`),this.detachUpgradeHandler(),await this.stopWebSocketServer(`startup error`),e}finally{this.connecting=!1}}async disconnect(){await this.stopBusServer(`shutdown`),this.detachUpgradeHandler(),await this.stopWebSocketServer(`shutdown`)}async stopBusServer(e){this.busReady=!1,this.busServer&&=(await this.busServer.stop().catch(t=>{console.error(`[BusServerTransport] Failed to stop bus server during ${e}:`,t)}),null)}detachUpgradeHandler(){this.upgradeHandlerServer&&this.upgradeHandler&&this.upgradeHandlerServer.off(`upgrade`,this.upgradeHandler),this.upgradeHandlerServer=null,this.upgradeHandler=null}async stopWebSocketServer(e){this.websocketServer&&=(await new Promise((e,t)=>{this.websocketServer.close(n=>n?t(n):e())}).catch(t=>{t instanceof Error&&t.message===`The server is not running`||console.error(`[BusServerTransport] Failed to close WebSocket server during ${e}:`,t)}),null)}},Nn=class extends Mt{keysDir;constructor(e,t){super(e),this.keysDir=A.join(t,`keys`)}async getConfig(e){let t=await super.getConfig(e);return t.bus?.remote&&!t.bus.remote.secret&&(t.bus.remote.secret=this.generateSecret(),(await this.getStoredConfig()).bus?.remote?.url===t.bus.remote.url&&await this.saveConfig(await this.prepareConfigForPersistence(t))),t}generateSecret(){return M.randomBytes(32).toString(`base64`)}async getMachineId(){return(await wt(this.keysDir)).machineId}getEnv(e){return process.env[e]}};function Pn(e,t){return{extensions:e.discovery??new s(void 0,{extensionsDir:j.join(t,`extensions`),nodeModulesDir:j.join(t,`node_modules`)})}}function Fn(e){return F(j.join(e,`meta`,`_journal.json`))}function In(e,t={}){let{moduleDir:n=import.meta.dirname,getMigrationsFolder:r=on}=t,i=Ve(e).migrations.chainDirName,a=[],o=j.resolve(n,`..`,i);if(Fn(o))return o;a.push(o);try{let t=r(e);if(Fn(t))return t;a.push(t)}catch(t){a.push(`getMigrationsFolder('${e}') unavailable: ${t instanceof Error?t.message:String(t)}`)}throw Error(`resolveBundledMigrationsDir: no '${e}' migrations directory with meta/_journal.json found. Probed: ${a.join(`; `)}. Pass an explicit migrations directory (boot option 'centralMigrationsDir' or InitializeNodeDatabaseOptions.migrationsDir) when migrations are staged elsewhere.`)}function Ln(e){if(process.platform===`win32`)return!0;let t=e?.code;return t===`ENOSYS`||t===`EINVAL`}function Rn(e){return e===void 0||e.trim()===``?void 0:e}function zn(e){try{let t=new URL(e);if(t.host!==``)return`${t.protocol}//${t.host}${t.pathname}`}catch{}let t=e.indexOf(`:`);return t===-1?`<unparseable database URL>`:`${e.slice(0,t+1)}…`}async function Bn(e,t,n){let r;try{r=await import(O(oe(A.resolve(t,`package.json`)).resolve(e.packageName)).href)}catch(t){throw Error(`initializeNodeDatabase: the database URL from ${n} targets the '${e.dialect}' storage engine, but '${e.packageName}' could not be loaded. Install ${e.packageName} in the host application, or pass its already-loaded storageEngine via the 'database.engines' boot option.`,{cause:t})}let i=r.storageEngine;if(i===void 0||i.dialect!==e.dialect)throw Error(`initializeNodeDatabase: '${e.packageName}' does not provide a storage engine for dialect '${e.dialect}'. Auto-resolved engine packages must export 'storageEngine: StorageEngine' with a matching dialect.`);Re(e.dialect)===void 0&&Ue(i)}async function Vn(e){let t=Rn(e.database?.url),n=t??Rn(process.env.MAKAIO_DATABASE_URL);if(n!==void 0){let r=t===void 0?`the MAKAIO_DATABASE_URL environment variable`:`the 'database.url' boot option`,i=Ke(n);if(i.kind===`missing-engine`&&(await Bn(i,e.database?.enginePackageImportBasePath??process.cwd(),r),i=Ke(n)),i.kind!==`engine`){let e=Fe.map(e=>e.packageName).join(`, `);throw Error(`initializeNodeDatabase: unsupported database URL '${zn(n)}' from ${r}. URL targets require a storage engine that claims the URL (e.g. postgres:// / postgresql:// via ${e}); SQLite targets are configured via the dbPath option or MAKAIO_DATABASE_PATH.`)}return{kind:`url`,url:n,dialect:i.engine.dialect}}let r=A.resolve(Rn(e.dbPath)??Rn(process.env.MAKAIO_DATABASE_PATH)??A.join(e.makaioHome,`makaio.db`));return{kind:`file`,dbPath:r,url:O(r).href}}async function Hn(e){for(let t of e.database?.engines??[])Ue(t);let t=await Vn(e);if(t.kind===`url`){let n=await vt({url:t.url,postgres:{poolMax:e.database?.poolMax}});try{let r=e.migrationsDir??In(t.dialect);return await vn(n.db,{migrationsDir:r}),{databaseClient:n}}catch(e){throw await n.close(),e}}let{dbPath:n}=t,r=A.dirname(n);await P.promises.mkdir(r,{recursive:!0});let i=await vt({url:t.url});try{await vn(i.db,{migrationsDir:e.migrationsDir});try{await P.promises.chmod(n,384)}catch(e){if(!Ln(e))throw e;console.warn(`[initializeNodeDatabase] Failed to set SQLite file permissions (continuing; this may be unsupported on Windows):`,e)}return{databaseClient:i,dbPath:n}}catch(e){throw await i.close(),e}}const Un=D.object({npmName:D.string(),version:D.string(),source:D.enum([`new`,`upgraded`,`already-present`])}),Wn=D.object({npmName:D.string(),reason:D.string()}),Gn=D.object({success:D.boolean(),packageName:D.string(),version:D.string().optional(),restartRequired:D.boolean(),error:D.string().optional(),installed:D.array(Un).optional(),skipped:D.array(Wn).optional(),warnings:D.array(D.string()).optional()}),Kn=D.object({success:D.boolean(),packageName:D.string(),error:D.string().optional(),restartRequired:D.boolean()}),qn=D.object({name:D.string(),version:D.string(),description:D.string().optional(),hasDescriptor:D.boolean().default(!1),serverImportPath:D.string().min(1).optional()}),Jn=D.object({packageName:D.string(),latestVersion:D.string(),success:D.boolean(),error:D.string().optional()}),Yn=D.object({name:D.string(),displayName:D.string(),description:D.string(),icon:D.string().optional(),tags:D.array(D.string()).optional(),descriptorName:D.string().min(1).optional()}),Xn=D.object({$schema:D.string(),updatedAt:D.string(),adapters:D.array(Yn),extensions:D.array(Yn)}),Zn=D.object({name:D.string(),currentVersion:D.string(),latestVersion:D.string(),description:D.string().optional()}),Qn=de(`packages`,{list:{request:D.object({}),response:D.object({packages:D.array(qn)})},install:{request:D.object({packageName:D.string().optional(),packageNames:D.array(D.string()).min(1).optional(),source:D.enum([`npm`,`local`]).optional(),force:D.boolean().optional()}).refine(e=>e.packageName!==void 0||e.packageNames!==void 0,{message:`Expected packageName or packageNames`}),response:Gn},uninstall:{request:D.object({packageName:D.string()}),response:Kn},getLatestVersion:{request:D.object({packageName:D.string()}),response:Jn},getRegistry:{request:D.object({}),response:Xn},checkUpdates:{request:D.object({}),response:D.object({updates:D.array(Zn)})},installed:D.object({packageName:D.string(),version:D.string()}),uninstalled:D.object({packageName:D.string()})}),V=Qn.subjects;async function $n(e,t,n){if(!A.isAbsolute(e))return;let r;try{r=await k.realpath(e)}catch{return}let i=er(t,n),a=[A.resolve(r,`src`,`${i}.ts`),A.resolve(r,`dist`,`${i}.mjs`)];for(let e of a){let t=await tr(e);if(t!==void 0&&nr(t,r))return t}}function er(e,t){return t===!0?e:t}async function tr(e){try{return await k.realpath(e)}catch{return}}function nr(e,t){let n=A.relative(t,e);return n.length>0&&!n.startsWith(`..`)&&!A.isAbsolute(n)}var rr=class{extensionsDir;constructor(e){this.extensionsDir=A.resolve(e)}async install(e){try{let t=A.resolve(e.endsWith(`descriptor.json`)?A.dirname(e):e),n=await k.realpath(t),r=await this.readDescriptor(n);Ce(r)||await this.validateEntrypoints(n,r.entrypoints);let i=this.linkPathFor(r.name);await k.mkdir(A.dirname(i),{recursive:!0});try{if((await k.lstat(i)).isSymbolicLink())await k.unlink(i);else throw Error(`${i} already exists and is not a symlink`)}catch(e){if(e.code!==`ENOENT`)throw e}let a=process.platform===`win32`?`junction`:`dir`;return await k.symlink(n,i,a),{success:!0,packageName:r.name,version:r.version,restartRequired:!0}}catch(e){return{success:!1,packageName:``,error:e instanceof Error?e.message:String(e),restartRequired:!1}}}async uninstall(e){try{let t=this.linkPathFor(e);if(await k.unlink(t),e.startsWith(`@`)){let e=A.dirname(t);(await k.readdir(e).catch(()=>null))?.length===0&&await k.rmdir(e).catch(()=>{})}return{success:!0,packageName:e,restartRequired:!0}}catch(t){return{success:!1,packageName:e,error:t instanceof Error?t.message:String(t),restartRequired:!1}}}async list(){try{await k.access(this.extensionsDir)}catch{return[]}let e=await k.readdir(this.extensionsDir),t=[];for(let n of e){let e=A.join(this.extensionsDir,n);if(n.startsWith(`@`)){let n=await k.readdir(e).catch(()=>[]);for(let r of n){let n=A.join(e,r),i=await this.readLocalEntry(n);i!==null&&t.push(i)}}else{let n=await this.readLocalEntry(e);n!==null&&t.push(n)}}return t}async readLocalEntry(e){try{if(!(await k.lstat(e)).isSymbolicLink())return null;let t=await k.readlink(e),n=await k.realpath(A.resolve(A.dirname(e),t)),r=A.join(n,`descriptor.json`),i=await k.readFile(r,`utf-8`),a=Te(JSON.parse(i));if(!a.success)return null;let o=a.data.entrypoints?.server,s=o===void 0?void 0:await $n(n,`server`,o);return{name:a.data.name,version:a.data.version,sourcePath:n,source:`local`,...s!==void 0&&{serverImportPath:s}}}catch{return null}}async readDescriptor(e){let t=A.join(e,`descriptor.json`),n=await k.readFile(t,`utf-8`).catch(()=>{throw Error(`descriptor.json not found at ${t}`)}),r=Te(JSON.parse(n));if(!r.success)throw Error(`Invalid descriptor.json: ${r.error.message}`);return r.data}async validateEntrypoints(e,t){await Promise.all(Object.entries(t).map(async([t,n])=>{if(n!==void 0&&await $n(e,t,n)===void 0){let e=er(t,n);throw Error(`${t} entrypoint "${e}" has no resolvable candidate: neither src/${e}.ts nor dist/${e}.mjs exists within the extension root`)}}))}linkPathFor(e){let t=A.resolve(this.extensionsDir,...e.split(`/`)),n=A.relative(this.extensionsDir,t);if(n===``||n.startsWith(`..`)||A.isAbsolute(n))throw Error(`Invalid extension name: ${e}`);return t}};const ir=`nodeLinker: node-modules`,ar=/^[A-Za-z]:[\\/]/;let or=null;function H(){return or||(or=Promise.all([import(`../lib-Ba55od_d.mjs`).then(e=>t(e.t(),1)),import(`../lib-ZKtnbCqH.mjs`).then(e=>t(e.t(),1)),import(`../lib-CM_BUxN8.mjs`).then(e=>t(e.default,1))]).then(([e,t,n])=>({Configuration:e.Configuration,Project:e.Project,Cache:e.Cache,StreamReport:e.StreamReport,structUtils:e.structUtils,ppath:t.ppath,npath:t.npath,xfs:t.xfs,getPluginConfiguration:n.getPluginConfiguration})),or)}var sr=class{makaioHome;constructor(e){this.makaioHome=e}async initialize(){try{let{npath:e,ppath:t,xfs:n}=await H(),r=e.toPortablePath(this.makaioHome),i=t.join(r,`package.json`);if(await n.mkdirpPromise(r),await this.ensureYarnRc(r,n,t),await n.existsPromise(i))return;await n.writeJsonPromise(i,{name:`makaio-packages`,version:`1.0.0`,private:!0,description:`Makaio installed packages`,dependencies:{}}),console.info(`[YarnPackageManager] Created package.json at %s`,i)}catch(e){throw Error(`Failed to initialize package.json`,{cause:e})}}async ensureYarnRc(e,t,n){let r=n.join(e,`.yarnrc.yml`),i=await t.existsPromise(r)?await t.readFilePromise(r,`utf8`):``,a=fr(i);i!==a&&(await t.writeFilePromise(r,a),console.info(`[YarnPackageManager] Wrote .yarnrc.yml at %s`,r))}async loadYarnState(){let{Configuration:e,Project:t,Cache:n,npath:r,getPluginConfiguration:i}=await H(),a=r.toPortablePath(this.makaioHome),o=await e.find(a,i()),{project:s}=await t.find(o,a);return{configuration:o,project:s,cache:await n.find(o)}}async runProjectInstall(e,t,n){let{StreamReport:r}=await H();if((await r.start({configuration:e,stdout:process.stdout},async e=>{await t.install({cache:n,report:e})})).hasErrors())throw Error(`Yarn install failed with errors`)}async parsePackageDescriptor(e){let{structUtils:t}=await H(),n=t.parseDescriptor(e);return n.range===`unknown`?t.makeDescriptor(n,`latest`):n}async installPackage(e){try{let{structUtils:t}=await H(),{configuration:n,project:r,cache:i}=await this.loadYarnState(),a=await this.parsePackageDescriptor(e),o=t.stringifyIdent(a),s=r.topLevelWorkspace.manifest.dependencies.get(a.identHash);r.topLevelWorkspace.manifest.dependencies.set(a.identHash,a),await this.runProjectInstall(n,r,i);let c=r.storedResolutions.get(a.descriptorHash);if(!c)throw Error(`Package resolution not found after installation`);let l=r.storedPackages.get(c);if(!l)throw Error(`Package not found after installation`);let u=l.version??`unknown`;if(!(await this.readInstalledDescriptor(o)).hasDescriptor)throw s?r.topLevelWorkspace.manifest.dependencies.set(a.identHash,s):r.topLevelWorkspace.manifest.dependencies.delete(a.identHash),await this.runProjectInstall(n,r,i),Error(`Installed package ${o} does not contain a valid descriptor.json`);return console.info(`[YarnPackageManager] Installed %s@%s`,o,u),u}catch(t){throw Error(`Failed to install ${e}`,{cause:t})}}async uninstallPackage(e){try{let{structUtils:t}=await H(),{configuration:n,project:r,cache:i}=await this.loadYarnState(),a=t.parseIdent(e);if(!r.topLevelWorkspace.manifest.dependencies.delete(a.identHash))throw Error(`Package ${e} not found in dependencies`);await this.runProjectInstall(n,r,i),console.info(`[YarnPackageManager] Uninstalled %s`,e)}catch(t){throw Error(`Failed to uninstall ${e}`,{cause:t})}}async listPackages(){try{let{xfs:e,npath:t,ppath:n,structUtils:r}=await H(),i=t.toPortablePath(this.makaioHome),a=n.join(i,`package.json`);if(!await e.existsPromise(a))return[];let{project:o}=await this.loadYarnState(),s=[];for(let[,e]of o.topLevelWorkspace.manifest.dependencies){let t=r.stringifyIdent(e),n=o.storedResolutions.get(e.descriptorHash),i=(n?o.storedPackages.get(n):void 0)?.version??r.parseRange(e.range).selector,a=await this.readInstalledDescriptor(t);a.hasDescriptor&&s.push({name:t,version:i,hasDescriptor:!0,...a.serverImportPath!==void 0&&{serverImportPath:a.serverImportPath}})}return s}catch(e){throw Error(`Failed to list packages`,{cause:e})}}async ensureFrameworkDependency(e){let t=ur(e);try{let{structUtils:e}=await H(),{configuration:n,project:r,cache:i}=await this.loadYarnState(),a=e.makeDescriptor(e.parseIdent(`@makaio/framework`),t);if(r.topLevelWorkspace.manifest.dependencies.get(a.identHash)?.range===t)return;r.topLevelWorkspace.manifest.dependencies.set(a.identHash,a),await this.runProjectInstall(n,r,i),console.info(`[YarnPackageManager] Ensured @makaio/framework@%s`,t)}catch(e){throw Error(`Failed to ensure @makaio/framework@${t}`,{cause:e})}}async getLatestVersion(e){return this.resolvePackageVersion(e)}async readInstalledDescriptor(e){let t=await this.readInstalledExtensionDescriptor(e);if(t===null)return{hasDescriptor:!1};let n=await this.resolveInstalledServerEntrypoint(e,t);return{hasDescriptor:!0,...n!==void 0&&{serverImportPath:n}}}async resolveInstalledServerEntrypoint(e,t){let n=t.entrypoints?.server;if(n!==void 0)return $n(A.join(this.makaioHome,`node_modules`,...e.split(`/`)),`server`,n)}async readInstalledExtensionDescriptor(e){let t=A.join(this.makaioHome,`node_modules`,...e.split(`/`),`descriptor.json`),n;try{let e=await k.readFile(t,`utf-8`);n=JSON.parse(e)}catch(e){if(e instanceof SyntaxError||pr(e))return null;throw e}let r=Te(n);return r.success?r.data:null}async listInstalledExtensionDescriptors(){let e=A.join(this.makaioHome,`package.json`),t;try{let n=await k.readFile(e,`utf-8`);t=JSON.parse(n)}catch(e){if(pr(e))return[];throw e}let n=Object.keys(t.dependencies??{});return(await Promise.all(n.map(async e=>{let t=await this.readInstalledExtensionDescriptor(e);return t===null?null:{npmName:e,version:await this.readInstalledPackageVersion(e),descriptor:t}}))).filter(e=>e!==null)}async readInstalledPackageVersion(e){let t=A.join(this.makaioHome,`node_modules`,...e.split(`/`),`package.json`);try{let e=await k.readFile(t,`utf-8`),n=JSON.parse(e);return typeof n.version==`string`?n.version:`unknown`}catch{return`unknown`}}async readManifestSnapshot(){let e=A.join(this.makaioHome,`package.json`),t=await k.readFile(e,`utf-8`);return JSON.parse(t)}async writeManifestAndReinstall(e){let t=A.join(this.makaioHome,`package.json`);await k.writeFile(t,`${JSON.stringify(e,null,2)}\n`,`utf-8`);let{configuration:n,project:r,cache:i}=await this.loadYarnState();await this.runProjectInstall(n,r,i)}async resolvePackageVersion(e){try{let{StreamReport:t}=await H(),{configuration:n,project:r}=await this.loadYarnState(),i=await this.parsePackageDescriptor(e),a=`unknown`;return await t.start({configuration:n,stdout:process.stdout},async e=>{let t=n.makeResolver(),o=await t.getCandidates(i,{},{project:r,resolver:t,report:e});if(o.length>0){let e=o[0];a=e.reference.match(/^npm:(.+)$/)?.[1]??e.reference}}),a}catch(t){throw Error(`Failed to resolve version for ${e}`,{cause:t})}}};function cr(e,t){return!t||t===`latest`?e:`${e}@${t}`}function lr(e){if(e.startsWith(`@`)){let t=e.indexOf(`/`);if(t===-1)return e;let n=e.indexOf(`@`,t+1);return n===-1?e:e.slice(0,n)}let t=e.indexOf(`@`);return t===-1?e:e.slice(0,t)}function ur(e){return e.localPackagePath?`portal:${dr(e.localPackagePath)}`:e.versionRange}function dr(e){let t=(ar.test(e)?e:A.resolve(e)).replace(/\\/g,`/`);return ar.test(t)?`/${t}`:t}function fr(e){let t=e.split(/\r?\n/),n=!1,r=t.map(e=>/^\s*nodeLinker\s*:/.test(e)?(n=!0,ir):e);if(!n){let t=e.trimEnd();return`${t}${t.length>0?`
2
2
  `:``}${ir}\n`}return`${r.join(`
3
3
  `).trimEnd()}\n`}function pr(e){if(typeof e!=`object`||!e||!(`code`in e))return!1;let t=e.code;return t===`ENOENT`||t===`ENOTDIR`}function mr(e){if(e.startsWith(`git+`))return{kind:`git`,raw:e,resolved:e};let t=e===`~`||e.startsWith(`~/`)||e.startsWith(`~\\`);if(e.startsWith(`~`)&&!t)throw Error(`Unsupported home-relative path syntax: ${e}`);return e.startsWith(`.`)||A.isAbsolute(e)||A.win32.isAbsolute(e)||t?{kind:`local`,raw:e,resolved:t?A.resolve(Qe.homedir(),e===`~`?`.`:e.slice(2)):A.resolve(e)}:{kind:`npm`,raw:e,resolved:e}}var hr=class{packages;names;constructor(e,t){this.packages=e,this.names=t}async resolve(e,t={}){let n=t.snapshot!==null,r=n?t.snapshot===void 0?await this.packages.readManifestSnapshot():t.snapshot:null;try{return await this.runBfs(e,t.force===!0)}catch(e){if(n)try{await this.packages.writeManifestAndReinstall(r)}catch(t){throw AggregateError([e,t],`Dependency resolution failed and rollback failed: ${vr(e)}`)}throw e}}async runBfs(e,t){let n=await this.readInstalledIndex(),r=e.map(e=>{let t=_r(e),n=gr(t.npmName);return{npmName:t.npmName,...n?{expectedDescriptorName:n}:{},...t.requiredRange?{requiredRange:t.requiredRange}:{},optional:!1,path:[t.npmName],root:!0}}),i=new Set,a=[],o=[],s=[];for(;r.length>0;){let e=r.shift(),s=i.has(e.npmName),c=n.byNpmName.get(e.npmName);if(s){if(c&&this.assertDescriptorMatches(e,c.descriptor),c&&this.descriptorRangeSatisfied(c.descriptor,e.requiredRange))continue;if(!c)throw Error(`Package ${e.npmName} was resolved but is missing from the installed index`)}if(c&&this.assertDescriptorMatches(e,c.descriptor),c&&this.shouldUseCurrentDescriptor(c.descriptor,e)){a.push({npmName:e.npmName,version:c.version,source:`already-present`}),await this.enqueueDependencies(r,e,c.descriptor),i.add(e.npmName);continue}let l=cr(e.npmName,e.requiredRange),u,d;try{u=await this.packages.installPackage(l);let r=await this.packages.readInstalledExtensionDescriptor(e.npmName);if(!r)throw Error(`Installed package ${e.npmName} does not contain a valid descriptor.json`);this.assertDescriptorMatches(e,r),this.assertDescriptorVersionSatisfies(e,r),await this.assertDependentsCompatible(e.npmName,r.version,n,t),d=r}catch(t){if(e.optional){o.push({npmName:e.npmName,reason:t instanceof Error?t.message:String(t)});continue}throw t}a.push({npmName:e.npmName,version:u,source:c?`upgraded`:`new`}),c={npmName:e.npmName,version:u,descriptor:d},n.byNpmName.set(e.npmName,c),await this.enqueueDependencies(r,e,d),i.add(e.npmName)}return{installed:a,skipped:o,warnings:s}}async readInstalledIndex(){let e=await this.packages.listInstalledExtensionDescriptors();return{byNpmName:new Map(e.map(e=>[e.npmName,e]))}}descriptorRangeSatisfied(e,t){return t===void 0||De(e.version,t)}shouldUseCurrentDescriptor(e,t){return t.root&&t.requiredRange===void 0?!1:this.descriptorRangeSatisfied(e,t.requiredRange)}assertDescriptorMatches(e,t){if(!(e.expectedDescriptorName===void 0||t.name===e.expectedDescriptorName))throw Error(`Installed package ${e.npmName} declares descriptor name "${t.name}", expected "${e.expectedDescriptorName}"`)}assertDescriptorVersionSatisfies(e,t){if(!this.descriptorRangeSatisfied(t,e.requiredRange))throw Error(`Installed package ${e.npmName} descriptor version ${t.version} does not satisfy ${t.name} ${e.requiredRange}`)}async assertDependentsCompatible(e,t,n,r){if(r)return;let i=[];for(let r of n.byNpmName.values())for(let n of r.descriptor.dependencies??[])await this.names.resolveNpmPackageName(n.name)===e&&!De(t,n.version)&&i.push(`${r.npmName} requires ${n.name} ${n.version}`);if(i.length>0)throw Error(`Cannot install ${e}; existing dependencies would be violated:\n${i.join(`
4
4
  `)}`)}async enqueueDependencies(e,t,n){for(let r of n.dependencies??[]){let n=await this.names.resolveNpmPackageName(r.name);if(t.path.includes(n))throw Error(`Circular dependency detected: ${[...t.path,n].join(` -> `)}`);e.push({npmName:n,expectedDescriptorName:r.name,requiredRange:r.version,optional:r.optional===!0,path:[...t.path,n],root:!1})}}};function gr(e){return e.startsWith(`@`)?void 0:e}function _r(e){let t=lr(e);if(t.length===e.length)return{npmName:t};let n=e.slice(t.length+1);return n===`latest`?{npmName:t}:{npmName:t,requiredRange:n}}function vr(e){return e instanceof Error?e.message:String(e)}var yr=class{registryClient;lookupMapPromise=null;constructor(e){this.registryClient=e}async resolveNpmPackageName(e){if(e.startsWith(`@`))return e;let t;try{t=await this.getLookupMap()}catch(t){throw Error(`Cannot resolve descriptor name "${e}": package registry is unavailable`,{cause:t})}return t.get(e)||`@makaio/${e}`}getLookupMap(){if(this.lookupMapPromise)return this.lookupMapPromise;let e=this.registryClient.getRegistry().then(e=>{let t=new Map;for(let n of[...e.adapters,...e.extensions])n.descriptorName&&t.set(n.descriptorName,n.name);return t}).catch(t=>{throw this.lookupMapPromise===e&&(this.lookupMapPromise=null),t});return this.lookupMapPromise=e,this.lookupMapPromise}},br=class{inner;portalMap;constructor(e,t){this.inner=e,this.portalMap=t}async installPackage(e){let t=lr(e),n=this.portalMap.get(t);if(n!==void 0){let e=`${t}@portal:${dr(n)}`;return this.inner.installPackage(e)}return this.inner.installPackage(e)}readInstalledExtensionDescriptor(e){return this.inner.readInstalledExtensionDescriptor(e)}listInstalledExtensionDescriptors(){return this.inner.listInstalledExtensionDescriptors()}readManifestSnapshot(){return this.inner.readManifestSnapshot()}writeManifestAndReinstall(e){return this.inner.writeManifestAndReinstall(e)}},xr=class{cache=null;inFlightFetch=null;registryUrl;cacheTtlMs;fetchTimeoutMs;fetchImpl;constructor(e={}){this.registryUrl=e.registryUrl??`https://raw.githubusercontent.com/makaio-ai/makaio/develop/registry/packages.json`,this.cacheTtlMs=e.cacheTtlMs??36e5,this.fetchTimeoutMs=e.fetchTimeoutMs??1e4,this.fetchImpl=e.fetchImpl??fetch}async getRegistry(){if(this.cache&&Date.now()-this.cache.timestamp<this.cacheTtlMs)return this.cache.data;this.inFlightFetch??=this.fetchAndCacheRegistry();try{return await this.inFlightFetch}finally{this.inFlightFetch=null}}async fetchAndCacheRegistry(){let e=new AbortController,t=setTimeout(()=>e.abort(),this.fetchTimeoutMs);try{let t=await this.fetchImpl(this.registryUrl,{signal:e.signal});if(!t.ok)throw Error(`HTTP ${t.status}: ${t.statusText}`);let n=await t.json(),r=Xn.parse(n);return this.cache={data:r,timestamp:Date.now()},r}catch(e){let t=e instanceof Error?e:Error(String(e));throw Error(`Failed to fetch package registry`,{cause:t})}finally{clearTimeout(t)}}clearCache(){this.cache=null}},Sr=t(r(),1),Cr=`1.0.0`;function wr(){let e=Cr;if(typeof e!=`string`||e.length===0)throw Error(`Package manager package metadata must include a string version.`);return`^${e}`}const Tr=wr();var Er=class extends Me{yarnManager;registryService;localInstaller;dependencyResolver;frameworkPeerRange;frameworkPackagePath;constructor(e,t,n={}){super(e),this.yarnManager=n.yarnManager??new sr(t),this.registryService=n.registryService??new xr,this.localInstaller=n.localInstaller??new rr(A.join(t,`extensions`)),this.frameworkPeerRange=n.frameworkPeerRange??Tr,this.frameworkPackagePath=n.frameworkPackagePath;let r=n.devPortalPackages?.size?new br(this.yarnManager,n.devPortalPackages):this.yarnManager;this.dependencyResolver=n.dependencyResolver??new hr(r,new yr(this.registryService))}async onInit(){await this.yarnManager.initialize(),console.info(`[PackageManagerService] Initialized`),this.registerPackageHandlers(),this.registerRegistryHandlers()}normalizePackageName(e){if(typeof e!=`string`)return null;let t=e.trim();return t.length>0?t:null}validatePackageNamePayload(e,t){return this.normalizePackageName(e)||(t(),null)}createInvalidPackageNameResult(e){return e?{success:!1,packageName:``,latestVersion:e.latestVersion,error:`Invalid packageName`}:{success:!1,packageName:``,error:`Invalid packageName`,restartRequired:!1}}async emitInstalled(e,t){try{await this.bus.emit(V.installed,{packageName:e,version:t})}catch(e){console.error(`[PackageManagerService] installed emit failed:`,e)}}async emitUninstalled(e){try{await this.bus.emit(V.uninstalled,{packageName:e})}catch(e){console.error(`[PackageManagerService] uninstalled emit failed:`,e)}}registerPackageHandlers(){this.registerListHandler(),this.registerInstallHandler(),this.registerUninstallHandler()}registerListHandler(){this.registerHandler(V.list,async e=>{try{let[t,n]=await Promise.all([this.yarnManager.listPackages(),this.localInstaller.list()]),r=[...t,...n.map(e=>({name:e.name,version:e.version,hasDescriptor:!0,...e.serverImportPath!==void 0&&{serverImportPath:e.serverImportPath}}))];e.setResult({packages:r})}catch(t){let n=t instanceof Error?t.message:String(t);console.error(`[PackageManagerService] List failed:`,n),e.setResult({packages:[]})}})}async ensureFrameworkPeer(){try{await this.yarnManager.ensureFrameworkDependency({versionRange:this.frameworkPeerRange,...this.frameworkPackagePath?{localPackagePath:this.frameworkPackagePath}:{}})}catch(e){let t=e instanceof Error?e.message:String(e);throw Error(`Failed to ensure @makaio/framework dependency ${this.frameworkPeerRange}: ${t}`,{cause:e})}}async installNpmPackages(e,t){let n=await this.yarnManager.readManifestSnapshot(),r;try{await this.ensureFrameworkPeer(),r=await this.dependencyResolver.resolve(e,{force:t,snapshot:null})}catch(e){try{await this.yarnManager.writeManifestAndReinstall(n)}catch(t){let n=e instanceof Error?e.message:String(e);throw AggregateError([e,t],`Package install failed and rollback failed: ${n}`)}throw e}for(let e of r.installed)e.source!==`already-present`&&await this.emitInstalled(e.npmName,e.version);let i=r.installed[0];return{success:!0,packageName:i?.npmName??e[0]??``,version:i?.version,restartRequired:!0,installed:[...r.installed],skipped:[...r.skipped],warnings:[...r.warnings]}}registerInstallHandler(){this.registerHandler(V.install,async e=>{let t=e.payload.packageNames??(e.payload.packageName===void 0?[]:[e.payload.packageName]),n=t.map(e=>this.normalizePackageName(e)).filter(e=>e!==null);if(n.length!==t.length||n.length===0){e.setResult(this.createInvalidPackageNameResult());return}let r;if(e.payload.source!==void 0)r={kind:e.payload.source};else{let t=n.map(e=>mr(e));r=t[0];let i=t.find(e=>e.kind!==r.kind);if(i){e.setResult({success:!1,packageName:``,error:`Cannot mix install sources: ${r.kind} and ${i.kind}`,restartRequired:!1});return}}if(r.kind===`git`){e.setResult({success:!1,packageName:n[0],error:`Git URL installs are not yet supported`,restartRequired:!1});return}if(r.kind===`local`){if(n.length>1){e.setResult({success:!1,packageName:``,error:`Local installs only support a single path`,restartRequired:!1});return}let t=await this.localInstaller.install(n[0]);t.success&&await this.emitInstalled(t.packageName,t.version??`unknown`),e.setResult(t);return}try{e.setResult(await this.installNpmPackages(n,e.payload.force))}catch(t){let r=t instanceof Error?t.message:String(t);console.error(`[PackageManagerService] Install failed:`,r),e.setResult({success:!1,packageName:n[0]??``,error:r,restartRequired:!1})}})}registerUninstallHandler(){this.registerHandler(V.uninstall,async e=>{let t=this.validatePackageNamePayload(e.payload.packageName,()=>{e.setResult(this.createInvalidPackageNameResult())});if(t){if((await this.localInstaller.list()).find(e=>e.name===t)){let n=await this.localInstaller.uninstall(t);n.success&&await this.emitUninstalled(t),e.setResult(n);return}try{await this.yarnManager.uninstallPackage(t),await this.emitUninstalled(t),e.setResult({success:!0,packageName:t,restartRequired:!0})}catch(n){let r=n instanceof Error?n.message:String(n);console.error(`[PackageManagerService] Uninstall failed:`,r),e.setResult({success:!1,packageName:t,error:r,restartRequired:!1})}}})}registerRegistryHandlers(){this.registerHandler(V.getLatestVersion,async e=>{let t=this.validatePackageNamePayload(e.payload.packageName,()=>{e.setResult(this.createInvalidPackageNameResult({latestVersion:`unknown`}))});if(t)try{let n=await this.yarnManager.getLatestVersion(t);e.setResult({success:!0,packageName:t,latestVersion:n})}catch(n){let r=n instanceof Error?n.message:String(n);console.error(`[PackageManagerService] Version check failed:`,r),e.setResult({success:!1,packageName:t,latestVersion:`unknown`,error:r})}}),this.registerHandler(V.getRegistry,async e=>{try{let t=await this.registryService.getRegistry();e.setResult(t)}catch(t){let n=t instanceof Error?t.message:String(t);console.error(`[PackageManagerService] Registry fetch failed:`,n),e.setResult({$schema:`makaio/package-registry/v1`,updatedAt:new Date().toISOString(),adapters:[],extensions:[]})}}),this.registerHandler(V.checkUpdates,async e=>{try{let t=await this.checkForUpdates();e.setResult({updates:t})}catch(t){let n=t instanceof Error?t.message:String(t);console.error(`[PackageManagerService] Update check failed:`,n),e.setResult({updates:[]})}})}async checkForUpdates(){try{let e=await this.yarnManager.listPackages(),t=[];return await Promise.all(e.map(async e=>{try{let n=await this.yarnManager.getLatestVersion(e.name);Sr.valid(e.version)&&Sr.valid(n)&&Sr.gt(n,e.version)&&t.push({name:e.name,currentVersion:e.version,latestVersion:n,description:e.description})}catch(t){console.warn(`[PackageManagerService] Failed to check updates for %s:`,e.name,t)}})),console.info(`[PackageManagerService] Found %d package updates`,t.length),t}catch(e){throw Error(`Failed to check for updates`,{cause:e})}}};function Dr(e={}){return{name:`makaio.package-manager`,displayName:`Package Manager`,version:`0.1.0`,critical:!0,namespaces:[Qn],create:t=>new Er(t.bus,t.makaioHome,{registryService:e.registryService,dependencyResolver:e.dependencyResolver,frameworkPeerRange:e.frameworkPeerRange,frameworkPackagePath:e.frameworkPackagePath,devPortalPackages:e.devPortalPackages})}}function Or(e){return{filter:e=>!!e.http,async processActivated(t,n){e.add({owner:t,phase:`extension`,mount:e=>n.http.mount(e)})},async processStopped(t){e.remove(t)}}}const kr={resolve(e,t){return!e&&!t?null:e?t?e.updatedAt>t.updatedAt?e:t:e:t}};function Ar(e){return{scope:e.scope,surface:e.surface??`any`,context:e.context??`any`,viewport:e.viewport??`any`}}function jr(e){return{scope:e.scope,surface:e.surface===`any`?void 0:e.surface,context:e.context===`any`?void 0:e.context,viewport:e.viewport===`any`?void 0:e.viewport}}function Mr(e,t){return[`makaio:prefs`,e.scope,e.surface||`any`,e.context||`any`,e.viewport||`any`,t].join(`:`)}function Nr(e){return typeof e==`object`&&!!e&&`value`in e&&`updatedAt`in e&&typeof e.value==`string`&&typeof e.updatedAt==`number`}function Pr(e){try{let t=JSON.parse(e);return Nr(t)?t:{value:JSON.stringify(t),updatedAt:0}}catch{return null}}const Fr=Le(`preferences`,e=>({scope:e.text(`scope`).notNull(),surface:e.text(`surface`).notNull().default(`any`),context:e.text(`context`).notNull().default(`any`),viewport:e.text(`viewport`).notNull().default(`any`),category:e.text(`category`).notNull(),value:e.text(`value`).notNull(),updatedAt:e.epochMs(`updated_at`).notNull()}),{sqlite:e=>[Ne(`preferences_pk`).on(e.scope,e.surface,e.context,e.viewport,e.category)],postgres:e=>[Pe(`preferences_pk`).on(e.scope,e.surface,e.context,e.viewport,e.category)]}),Ir=Fr.sqlite,Lr=Fr.postgres,Rr=Ie({preferences:Ir},{preferences:Lr});function zr(e,t,n){let r=[];return n!==void 0&&r.push(R(e.category,n)),t&&(t.scope!==void 0&&r.push(R(e.scope,t.scope)),t.surface!==void 0&&r.push(R(e.surface,t.surface)),t.context!==void 0&&r.push(R(e.context,t.context)),t.viewport!==void 0&&r.push(R(e.viewport,t.viewport))),r}async function Br(e,t,n){let{preferences:r}=We(e,Rr),i=zr(r,t,n);return(i.length>0?await e.select().from(r).where(qe(...i)):await e.select().from(r)).map(e=>{let t;try{t=JSON.parse(e.value)}catch{t=null}let n=qt.safeParse(t);return{key:jr(e),category:e.category,value:n.success?n.data:null,updatedAt:e.updatedAt}})}async function Vr(e,t,n){let{preferences:r}=We(e,Rr),i=Ar(t),[a]=await e.select().from(r).where(qe(R(r.scope,i.scope),R(r.surface,i.surface),R(r.context,i.context),R(r.viewport,i.viewport),R(r.category,n))).limit(1);return a}var Hr=class{db;conflictResolver;constructor(e){this.db=e.db,this.conflictResolver=e.conflictResolver??kr}async get(e,t){let n=await this.readFromDb(e,t),r=this.readFromLocalStorage(e,t),i=r?.updatedAt===0?r:null;!n&&r&&!i&&this.removeFromLocalStorage(e,t);let a=this.conflictResolver.resolve(i,n);if(!a)return null;let o;try{o=JSON.parse(a.value)}catch{return null}let s=qt.safeParse(o);return s.success?(await this.syncResolvedPreference(e,t,a,r,n),s.data):null}async set(e,t,n){let r=Date.now(),i=JSON.stringify(n??null);this.writeToLocalStorage(e,t,{value:i,updatedAt:r}),await this.writeToDb(e,t,i,r)}async delete(e,t){this.removeFromLocalStorage(e,t),await this.deleteFromDb(e,t)}async list(e,t){return Br(this.db,e,t)}async writeToDb(e,t,n,r){let{preferences:i}=We(this.db,Rr),a=Ar(e);await this.db.insert(i).values({...a,category:t,value:n,updatedAt:r}).onConflictDoUpdate({target:[i.scope,i.surface,i.context,i.viewport,i.category],set:{value:n,updatedAt:r}})}readFromLocalStorage(e,t){let n=Mr(e,t),r=globalThis.localStorage?.getItem(n);return r?Pr(r):null}writeToLocalStorage(e,t,n){let r=Mr(e,t);try{globalThis.localStorage?.setItem(r,JSON.stringify(n))}catch(e){console.warn(`[StorageCoordinator] localStorage write failed:`,e)}}removeFromLocalStorage(e,t){let n=Mr(e,t);try{globalThis.localStorage?.removeItem(n)}catch(e){console.warn(`[StorageCoordinator] localStorage delete failed:`,e)}}async syncResolvedPreference(e,t,n,r,i){this.isSameStoredPreference(n,i)||await this.writeToDb(e,t,n.value,n.updatedAt),r&&!this.isSameStoredPreference(n,r)&&this.writeToLocalStorage(e,t,n)}isSameStoredPreference(e,t){return!e||!t?!1:e.value===t.value&&e.updatedAt===t.updatedAt}async readFromDb(e,t){let n=await Vr(this.db,e,t);return n?{value:n.value,updatedAt:n.updatedAt}:null}async deleteFromDb(e,t){let{preferences:n}=We(this.db,Rr),r=Ar(e);await this.db.delete(n).where(qe(R(n.scope,r.scope),R(n.surface,r.surface),R(n.context,r.context),R(n.viewport,r.viewport),R(n.category,t)))}};function Ur(e,t,n){let r=new Hr({db:t}),i=e.on(Jt.get,async e=>{let{key:t,category:n}=e.payload,i=await r.get(t,n);e.setResult({value:i})}),a=e.on(Jt.set,async e=>{let{key:t,category:n,value:i}=e.payload;await r.set(t,n,i),e.setResult({success:!0})}),o=e.on(Jt.delete,async e=>{let{key:t,category:n}=e.payload;await r.delete(t,n),e.setResult({success:!0})}),s=e.on(Jt.list,async e=>{let{key:t,category:n}=e.payload,i=await r.list(t,n);e.setResult({items:i})});return()=>{i(),a(),o(),s()}}const Wr={name:`preferences-storage`,displayName:`Preferences Storage`,version:`0.1.0`,critical:!0,storage:{registerHandlers:He(Ur)}},Gr=ce(se);function Kr(e,t){if(!e.ok)throw Error(`HTTP ${e.status} ${e.statusText} fetching ${t}`)}function qr(e){return{fetchTimeoutMs:e.fetchTimeoutMs??3e4,downloadTimeoutMs:e.downloadTimeoutMs??6e5,execTimeoutMs:e.execTimeoutMs??12e4,extractTimeoutMs:e.extractTimeoutMs??3e5}}async function Jr(e,t){try{return await fetch(e,{signal:AbortSignal.timeout(t)})}catch(n){let r=n instanceof Error?n.name:``;throw r===`AbortError`||r===`TimeoutError`?Error(`Timed out fetching ${e} after ${t}ms`,{cause:n}):n}}async function Yr(e,t,n,r){await k.mkdir(t,{recursive:!0}),n===`tar.gz`?await Gr(`tar`,[`-xzf`,e,`-C`,t],{timeout:r}).catch(n=>{throw n.code===`ENOENT`?Error(`tar extraction failed: host executable "tar" was not found on PATH`):Error(`tar extraction failed: ${e} → ${t}\nstderr: ${n.stderr??``}\n${String(n.message)}`)}):await Gr(`unzip`,[`-q`,e,`-d`,t],{timeout:r}).catch(n=>{throw n.code===`ENOENT`?Error(`zip extraction failed: host executable "unzip" was not found on PATH`):Error(`unzip extraction failed: ${e} → ${t}\nstderr: ${n.stderr??``}\n${String(n.message)}`)})}async function Xr(e,t,n,r){let{stdout:i}=await Gr(e,t,{cwd:n?.cwd,env:n?.env===void 0?process.env:{...process.env,...n.env},shell:!1,timeout:r}).catch(n=>{if(n.code===`ENOENT`)throw Error(`Command failed: host executable "${e}" was not found on PATH`);let r=n.stderr??``;throw Error(`Command failed: ${e} ${t.join(` `)}\nstderr: ${r}\n${String(n.message)}`)});return(i??``).trim()}function Zr(e={}){let{fetchTimeoutMs:t,downloadTimeoutMs:n,execTimeoutMs:r,extractTimeoutMs:i}=qr(e);return{async fetchText(e){let n=await Jr(e,t);return Kr(n,e),n.text()},async fetchJson(e){let n=await Jr(e,t);return Kr(n,e),n.json()},async downloadFile(e,t,r){let i=await Jr(e,n);if(Kr(i,e),i.body===null)throw Error(`Response body is null for URL: ${e}`);let a=i.headers.get(`content-length`),o=a===null?null:parseInt(a,10),s=o!==null&&!isNaN(o)?o:null;await k.mkdir(A.dirname(t),{recursive:!0});let c=P.createWriteStream(t),l=0,u=new gt({transform(e,t,n){l+=e.length,r?.(l,s),n(null,e)}});try{await _t(ht.from(i.body),u,c)}catch(e){throw await k.rm(t,{force:!0}),e}return t},exec(e,t,n){return Xr(e,t,n,r)},async extractArchive(e,t,n){await Yr(e,t,n,i)},async deleteFile(e){await k.rm(e,{force:!0})},async computeChecksum(e,t=`sha256`){return new Promise((n,r)=>{let i=N(t),a=P.createReadStream(e);a.on(`error`,r),a.on(`data`,e=>i.update(e)),a.on(`end`,()=>n(i.digest(`hex`)))})},async removeDirectory(e){await k.rm(e,{recursive:!0,force:!0})}}}function Qr(e){let t,n=!1;for(let r=e.length-1;r>=0;--r){let i=e[r];try{i()}catch(e){n||=(t=e,!0)}}if(e.length=0,n)throw t}function $r(e,t){try{return t()}catch(t){try{Qr(e)}catch{}throw t}}function ei(e,t){for(let n of e){let e=n.providers.find(e=>e.definition.id===t);if(e)return e}}function ti(e,t,n){for(let r of t){let t=e.find(e=>e.name===r.adapterName);if(t?.providers.some(e=>e.definition.id===n))return t}}function ni(e){let{$schema:t,...n}=e;return n}function ri(e,t){let n=e.definition,r=Date.now();return{id:n.id,packageName:t,name:n.name,description:n.description,endpoints:n.endpoints,defaultModel:n.defaultModel,fastModel:n.fastModel,availableModels:n.availableModels??[],defaultModelFilterMode:`show-all`,credentialEnvVars:n.credentialEnvVars,capabilities:n.capabilities,enabled:!0,createdAt:r,updatedAt:r}}function ii(e,t,n,r){let i=[];return $r(i,()=>(i.push(e.on($t.adapter.getConfigSchema,({payload:e,setResult:n})=>{let r=t().find(t=>t.name===e.adapterName);if(!r?.adapterConfigSchema){n({hasSchema:!1,schema:null});return}n({hasSchema:!0,schema:D.toJSONSchema(r.adapterConfigSchema)})})),i.push(e.on(Zt.getCredentialSchema,({payload:e,setResult:n})=>{let r=ei(t(),e.definitionId)?.credentialSchema;if(r){n({hasSchema:!0,schema:D.toJSONSchema(r)});return}n({hasSchema:!1,schema:null})})),i.push(e.on(Zt.getConfigSchema,({payload:e,setResult:n})=>{let r=ei(t(),e.definitionId)?.configSchema;if(r){n({hasSchema:!0,schema:D.toJSONSchema(r)});return}n({hasSchema:!1,schema:null})})),r&&i.push(e.on($t.extension.getConfigSchema,({payload:e,setResult:t})=>{let n=r(e.extensionName);if(!n?.configSchema){t({hasSchema:!1,schema:null,uiConfig:null});return}t({hasSchema:!0,schema:ni(D.toJSONSchema(n.configSchema)),uiConfig:n.uiConfig??null})})),i.push(e.on($e.get,({payload:e,setResult:n})=>{for(let r of t()){let t=r.providers.find(t=>t.definition.id===e.id);if(t){n({provider:ri(t,r.packageName)});return}}n({provider:null})},{priority:-1})),i.push(e.on($e.list,({setResult:e})=>{let n=[],r=new Set;for(let e of t())for(let t of e.providers)r.has(t.definition.id)||(r.add(t.definition.id),n.push(ri(t,e.packageName)));e({providers:n})},{priority:-1})),i.push(e.on(Qt.fetchModels,async({payload:r,setResult:i})=>{let{config:a}=await e.request(ct.getProviderConfig,{id:r.providerConfigId});if(!a)throw Error(`Provider config '${r.providerConfigId}' not found`);let{bindings:o}=await e.request(ct.listBindingsByConfig,{providerConfigId:r.providerConfigId}),s=ti(t(),o,a.definitionId);if(!s)throw Error(o.length===0?`Provider config '${r.providerConfigId}' is not bound to an adapter`:`No loaded adapter bound to provider config '${r.providerConfigId}' for definition '${a.definitionId}'`);let c=await Ze(e,r.providerConfigId),l=s.options.adapterId,u=l?n().get(l):void 0;if(!l||!u)throw Error(`Adapter instance for '${s.name}' not initialized`);if(!(`fetchModels`in u)||typeof u.fetchModels!=`function`)throw Error(`Adapter '${s.name}' does not support model fetching`);let d=await Yt(e,c.credentialRefs),f=c.endpointOverrides?Object.values(c.endpointOverrides).find(e=>e!==void 0):void 0;i({models:await u.fetchModels(f,d)})})),()=>{Qr(i)}))}function ai(e,t){let n=new Map;for(let[r,i]of e)t.has(r)&&n.set(r,i);return n}function oi(...e){let t=new Map;for(let n of e)for(let[e,r]of n)t.set(e,{...t.get(e)??{},...r});return t}function si(e,t){let n=[e.on(L.get,async e=>{let n=await t.getConfig();e.setResult({config:n})}),e.on(L.update,async e=>{let n=I.parse(e.payload.config),r=await t.prepareConfigForPersistence(n);await t.saveConfig(r),e.setResult({success:!0})})];return()=>{for(let e of n)e()}}var U=n((e=>{let t=Symbol.for(`yaml.alias`),n=Symbol.for(`yaml.document`),r=Symbol.for(`yaml.map`),i=Symbol.for(`yaml.pair`),a=Symbol.for(`yaml.scalar`),o=Symbol.for(`yaml.seq`),s=Symbol.for(`yaml.node.type`),c=e=>!!e&&typeof e==`object`&&e[s]===t,l=e=>!!e&&typeof e==`object`&&e[s]===n,u=e=>!!e&&typeof e==`object`&&e[s]===r,d=e=>!!e&&typeof e==`object`&&e[s]===i,f=e=>!!e&&typeof e==`object`&&e[s]===a,p=e=>!!e&&typeof e==`object`&&e[s]===o;function m(e){if(e&&typeof e==`object`)switch(e[s]){case r:case o:return!0}return!1}function h(e){if(e&&typeof e==`object`)switch(e[s]){case t:case r:case a:case o:return!0}return!1}e.ALIAS=t,e.DOC=n,e.MAP=r,e.NODE_TYPE=s,e.PAIR=i,e.SCALAR=a,e.SEQ=o,e.hasAnchor=e=>(f(e)||m(e))&&!!e.anchor,e.isAlias=c,e.isCollection=m,e.isDocument=l,e.isMap=u,e.isNode=h,e.isPair=d,e.isScalar=f,e.isSeq=p})),ci=n((e=>{var t=U();let n=Symbol(`break visit`),r=Symbol(`skip children`),i=Symbol(`remove node`);function a(e,n){let r=l(n);t.isDocument(e)?o(null,e.contents,r,Object.freeze([e]))===i&&(e.contents=null):o(null,e,r,Object.freeze([]))}a.BREAK=n,a.SKIP=r,a.REMOVE=i;function o(e,r,a,s){let c=u(e,r,a,s);if(t.isNode(c)||t.isPair(c))return d(e,s,c),o(e,c,a,s);if(typeof c!=`symbol`){if(t.isCollection(r)){s=Object.freeze(s.concat(r));for(let e=0;e<r.items.length;++e){let t=o(e,r.items[e],a,s);if(typeof t==`number`)e=t-1;else if(t===n)return n;else t===i&&(r.items.splice(e,1),--e)}}else if(t.isPair(r)){s=Object.freeze(s.concat(r));let e=o(`key`,r.key,a,s);if(e===n)return n;e===i&&(r.key=null);let t=o(`value`,r.value,a,s);if(t===n)return n;t===i&&(r.value=null)}}return c}async function s(e,n){let r=l(n);t.isDocument(e)?await c(null,e.contents,r,Object.freeze([e]))===i&&(e.contents=null):await c(null,e,r,Object.freeze([]))}s.BREAK=n,s.SKIP=r,s.REMOVE=i;async function c(e,r,a,o){let s=await u(e,r,a,o);if(t.isNode(s)||t.isPair(s))return d(e,o,s),c(e,s,a,o);if(typeof s!=`symbol`){if(t.isCollection(r)){o=Object.freeze(o.concat(r));for(let e=0;e<r.items.length;++e){let t=await c(e,r.items[e],a,o);if(typeof t==`number`)e=t-1;else if(t===n)return n;else t===i&&(r.items.splice(e,1),--e)}}else if(t.isPair(r)){o=Object.freeze(o.concat(r));let e=await c(`key`,r.key,a,o);if(e===n)return n;e===i&&(r.key=null);let t=await c(`value`,r.value,a,o);if(t===n)return n;t===i&&(r.value=null)}}return s}function l(e){return typeof e==`object`&&(e.Collection||e.Node||e.Value)?Object.assign({Alias:e.Node,Map:e.Node,Scalar:e.Node,Seq:e.Node},e.Value&&{Map:e.Value,Scalar:e.Value,Seq:e.Value},e.Collection&&{Map:e.Collection,Seq:e.Collection},e):e}function u(e,n,r,i){if(typeof r==`function`)return r(e,n,i);if(t.isMap(n))return r.Map?.(e,n,i);if(t.isSeq(n))return r.Seq?.(e,n,i);if(t.isPair(n))return r.Pair?.(e,n,i);if(t.isScalar(n))return r.Scalar?.(e,n,i);if(t.isAlias(n))return r.Alias?.(e,n,i)}function d(e,n,r){let i=n[n.length-1];if(t.isCollection(i))i.items[e]=r;else if(t.isPair(i))e===`key`?i.key=r:i.value=r;else if(t.isDocument(i))i.contents=r;else{let e=t.isAlias(i)?`alias`:`scalar`;throw Error(`Cannot replace node with ${e} parent`)}}e.visit=a,e.visitAsync=s})),li=n((e=>{var t=U(),n=ci();let r={"!":`%21`,",":`%2C`,"[":`%5B`,"]":`%5D`,"{":`%7B`,"}":`%7D`},i=e=>e.replace(/[!,[\]{}]/g,e=>r[e]);var a=class e{constructor(t,n){this.docStart=null,this.docEnd=!1,this.yaml=Object.assign({},e.defaultYaml,t),this.tags=Object.assign({},e.defaultTags,n)}clone(){let t=new e(this.yaml,this.tags);return t.docStart=this.docStart,t}atDocument(){let t=new e(this.yaml,this.tags);switch(this.yaml.version){case`1.1`:this.atNextDocument=!0;break;case`1.2`:this.atNextDocument=!1,this.yaml={explicit:e.defaultYaml.explicit,version:`1.2`},this.tags=Object.assign({},e.defaultTags);break}return t}add(t,n){this.atNextDocument&&=(this.yaml={explicit:e.defaultYaml.explicit,version:`1.1`},this.tags=Object.assign({},e.defaultTags),!1);let r=t.trim().split(/[ \t]+/),i=r.shift();switch(i){case`%TAG`:{if(r.length!==2&&(n(0,`%TAG directive should contain exactly two parts`),r.length<2))return!1;let[e,t]=r;return this.tags[e]=t,!0}case`%YAML`:{if(this.yaml.explicit=!0,r.length!==1)return n(0,`%YAML directive should contain exactly one part`),!1;let[e]=r;if(e===`1.1`||e===`1.2`)return this.yaml.version=e,!0;{let t=/^\d+\.\d+$/.test(e);return n(6,`Unsupported YAML version ${e}`,t),!1}}default:return n(0,`Unknown directive ${i}`,!0),!1}}tagName(e,t){if(e===`!`)return`!`;if(e[0]!==`!`)return t(`Not a valid tag: ${e}`),null;if(e[1]===`<`){let n=e.slice(2,-1);return n===`!`||n===`!!`?(t(`Verbatim tags aren't resolved, so ${e} is invalid.`),null):(e[e.length-1]!==`>`&&t(`Verbatim tags must end with a >`),n)}let[,n,r]=e.match(/^(.*!)([^!]*)$/s);r||t(`The ${e} tag has no suffix`);let i=this.tags[n];if(i)try{return i+decodeURIComponent(r)}catch(e){return t(String(e)),null}return n===`!`?e:(t(`Could not resolve tag: ${e}`),null)}tagString(e){for(let[t,n]of Object.entries(this.tags))if(e.startsWith(n))return t+i(e.substring(n.length));return e[0]===`!`?e:`!<${e}>`}toString(e){let r=this.yaml.explicit?[`%YAML ${this.yaml.version||`1.2`}`]:[],i=Object.entries(this.tags),a;if(e&&i.length>0&&t.isNode(e.contents)){let r={};n.visit(e.contents,(e,n)=>{t.isNode(n)&&n.tag&&(r[n.tag]=!0)}),a=Object.keys(r)}else a=[];for(let[t,n]of i)t===`!!`&&n===`tag:yaml.org,2002:`||(!e||a.some(e=>e.startsWith(n)))&&r.push(`%TAG ${t} ${n}`);return r.join(`
@@ -1 +1 @@
1
- import{i as e,n as t,r as n}from"../../await-trigger-DwVldnMt.mjs";import{a as r,i,n as a,o,r as s,s as c,t as l}from"../../workflow-worker-BIpYi6o7.mjs";export{i as InProcessWorkflowRunner,l as PiscinaThinWorkflowProvider,c as ThinWorkflowPiscinaRunner,r as WorkerNodeRunner,a as createNodeWorkflowRunner,s as createNodeWorkflowRunnerPackageOptions,t as loadWorkflowFromConfig,n as loadWorkflowModule,e as loadWorkflowModules,o as resolveWorkflowWorkerEntry};
1
+ import{i as e,n as t,r as n}from"../../await-trigger-DwVldnMt.mjs";import{a as r,i,n as a,o,r as s,s as c,t as l}from"../../workflow-worker-dH70EbjE.mjs";export{i as InProcessWorkflowRunner,l as PiscinaThinWorkflowProvider,c as ThinWorkflowPiscinaRunner,r as WorkerNodeRunner,a as createNodeWorkflowRunner,s as createNodeWorkflowRunnerPackageOptions,t as loadWorkflowFromConfig,n as loadWorkflowModule,e as loadWorkflowModules,o as resolveWorkflowWorkerEntry};
@@ -258,7 +258,7 @@ declare const sessions: _$drizzle_orm_sqlite_core0.SQLiteTableWithColumns<{
258
258
  tableName: "sessions";
259
259
  dataType: "string";
260
260
  columnType: "SQLiteText";
261
- data: "active" | "archived" | "closed" | "discovered";
261
+ data: "closed" | "discovered" | "active" | "archived";
262
262
  driverParam: string;
263
263
  notNull: true;
264
264
  hasDefault: false;
@@ -372,7 +372,7 @@ declare const sessions: _$drizzle_orm_sqlite_core0.SQLiteTableWithColumns<{
372
372
  tableName: "sessions";
373
373
  dataType: "string";
374
374
  columnType: "SQLiteText";
375
- data: "fork" | "subagent" | "compress" | "branch" | "rewrite" | "coordinator" | "aside";
375
+ data: "branch" | "fork" | "subagent" | "compress" | "rewrite" | "coordinator" | "aside";
376
376
  driverParam: string;
377
377
  notNull: false;
378
378
  hasDefault: false;
@@ -1130,7 +1130,7 @@ declare const agents: _$drizzle_orm_sqlite_core0.SQLiteTableWithColumns<{
1130
1130
  tableName: "agents";
1131
1131
  dataType: "string";
1132
1132
  columnType: "SQLiteText";
1133
- data: "active" | "idle" | "dead" | "disposed";
1133
+ data: "idle" | "active" | "dead" | "disposed";
1134
1134
  driverParam: string;
1135
1135
  notNull: true;
1136
1136
  hasDefault: false;
@@ -29,8 +29,8 @@ type SurfaceId = z.infer<typeof SurfaceIdSchema>;
29
29
  * A page is visible on a surface when the surface provides all required capabilities.
30
30
  */
31
31
  declare const SurfaceCapabilitySchema: z.ZodEnum<{
32
- filesystem: "filesystem";
33
32
  native: "native";
33
+ filesystem: "filesystem";
34
34
  dom: "dom";
35
35
  "multi-window": "multi-window";
36
36
  touch: "touch";
@@ -44,10 +44,10 @@ type SubagentTemplateSummary = z.infer<typeof SubagentTemplateSummarySchema>;
44
44
  */
45
45
  declare const SubagentTemplateCreateSchema: z.ZodObject<{
46
46
  name: z.ZodString;
47
- enabled: z.ZodDefault<z.ZodBoolean>;
48
47
  adapterName: z.ZodString;
49
48
  providerConfigId: z.ZodOptional<z.ZodString>;
50
49
  model: z.ZodOptional<z.ZodString>;
50
+ enabled: z.ZodDefault<z.ZodBoolean>;
51
51
  systemPrompt: z.ZodOptional<z.ZodString>;
52
52
  allowedTools: z.ZodOptional<z.ZodArray<z.ZodString>>;
53
53
  disallowedTools: z.ZodOptional<z.ZodArray<z.ZodString>>;
@@ -129,10 +129,10 @@ declare const SubagentTemplateSettingsSchemas: {
129
129
  create: {
130
130
  request: z.ZodObject<{
131
131
  name: z.ZodString;
132
- enabled: z.ZodDefault<z.ZodBoolean>;
133
132
  adapterName: z.ZodString;
134
133
  providerConfigId: z.ZodOptional<z.ZodString>;
135
134
  model: z.ZodOptional<z.ZodString>;
135
+ enabled: z.ZodDefault<z.ZodBoolean>;
136
136
  systemPrompt: z.ZodOptional<z.ZodString>;
137
137
  allowedTools: z.ZodOptional<z.ZodArray<z.ZodString>>;
138
138
  disallowedTools: z.ZodOptional<z.ZodArray<z.ZodString>>;
@@ -191,8 +191,8 @@ declare const SubagentTemplateInstanceSchema: z.ZodObject<{
191
191
  status: z.ZodEnum<{
192
192
  completed: "completed";
193
193
  cancelled: "cancelled";
194
- running: "running";
195
194
  failed: "failed";
195
+ running: "running";
196
196
  waiting_input: "waiting_input";
197
197
  }>;
198
198
  createdAt: z.ZodString;
@@ -222,8 +222,8 @@ declare const SubagentTemplateInstanceStatusSchema: z.ZodObject<{
222
222
  status: z.ZodEnum<{
223
223
  completed: "completed";
224
224
  cancelled: "cancelled";
225
- running: "running";
226
225
  failed: "failed";
226
+ running: "running";
227
227
  waiting_input: "waiting_input";
228
228
  }>;
229
229
  result: z.ZodOptional<z.ZodString>;
@@ -274,8 +274,8 @@ declare const SubagentTemplateKernelSchemas: {
274
274
  status: z.ZodEnum<{
275
275
  completed: "completed";
276
276
  cancelled: "cancelled";
277
- running: "running";
278
277
  failed: "failed";
278
+ running: "running";
279
279
  waiting_input: "waiting_input";
280
280
  }>;
281
281
  result: z.ZodOptional<z.ZodString>;
@@ -84,9 +84,9 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
84
84
  description: z.ZodOptional<z.ZodString>;
85
85
  inputSchema: z.ZodRecord<z.ZodString, z.ZodUnknown>;
86
86
  exposureMode: z.ZodEnum<{
87
- hidden: "hidden";
88
87
  direct: "direct";
89
88
  discovery: "discovery";
89
+ hidden: "hidden";
90
90
  }>;
91
91
  enabled: z.ZodBoolean;
92
92
  enabledBy: z.ZodOptional<z.ZodEnum<{
@@ -103,9 +103,9 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
103
103
  description: z.ZodOptional<z.ZodString>;
104
104
  inputSchema: z.ZodRecord<z.ZodString, z.ZodUnknown>;
105
105
  exposureMode: z.ZodEnum<{
106
- hidden: "hidden";
107
106
  direct: "direct";
108
107
  discovery: "discovery";
108
+ hidden: "hidden";
109
109
  }>;
110
110
  enabled: z.ZodBoolean;
111
111
  enabledBy: z.ZodOptional<z.ZodEnum<{
@@ -168,7 +168,7 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
168
168
  originalName: string;
169
169
  serverName: string;
170
170
  inputSchema: Record<string, unknown>;
171
- exposureMode: "hidden" | "direct" | "discovery";
171
+ exposureMode: "direct" | "discovery" | "hidden";
172
172
  enabled: boolean;
173
173
  exposed: boolean;
174
174
  description?: string | undefined;
@@ -180,7 +180,7 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
180
180
  originalName: string;
181
181
  serverName: string;
182
182
  inputSchema: Record<string, unknown>;
183
- exposureMode: "hidden" | "direct" | "discovery";
183
+ exposureMode: "direct" | "discovery" | "hidden";
184
184
  enabled: boolean;
185
185
  exposed: boolean;
186
186
  description?: string | undefined;
@@ -242,7 +242,7 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
242
242
  originalName: string;
243
243
  serverName: string;
244
244
  inputSchema: Record<string, unknown>;
245
- exposureMode: "hidden" | "direct" | "discovery";
245
+ exposureMode: "direct" | "discovery" | "hidden";
246
246
  enabled: boolean;
247
247
  exposed: boolean;
248
248
  description?: string | undefined;
@@ -254,7 +254,7 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
254
254
  originalName: string;
255
255
  serverName: string;
256
256
  inputSchema: Record<string, unknown>;
257
- exposureMode: "hidden" | "direct" | "discovery";
257
+ exposureMode: "direct" | "discovery" | "hidden";
258
258
  enabled: boolean;
259
259
  exposed: boolean;
260
260
  description?: string | undefined;
@@ -314,7 +314,7 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
314
314
  originalName: string;
315
315
  serverName: string;
316
316
  inputSchema: Record<string, unknown>;
317
- exposureMode: "hidden" | "direct" | "discovery";
317
+ exposureMode: "direct" | "discovery" | "hidden";
318
318
  enabled: boolean;
319
319
  exposed: boolean;
320
320
  description?: string | undefined;
@@ -326,7 +326,7 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
326
326
  originalName: string;
327
327
  serverName: string;
328
328
  inputSchema: Record<string, unknown>;
329
- exposureMode: "hidden" | "direct" | "discovery";
329
+ exposureMode: "direct" | "discovery" | "hidden";
330
330
  enabled: boolean;
331
331
  exposed: boolean;
332
332
  description?: string | undefined;
@@ -388,7 +388,7 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
388
388
  originalName: string;
389
389
  serverName: string;
390
390
  inputSchema: Record<string, unknown>;
391
- exposureMode: "hidden" | "direct" | "discovery";
391
+ exposureMode: "direct" | "discovery" | "hidden";
392
392
  enabled: boolean;
393
393
  exposed: boolean;
394
394
  description?: string | undefined;
@@ -400,7 +400,7 @@ declare const AgentRuntimeSelectionSchema: z.ZodObject<{
400
400
  originalName: string;
401
401
  serverName: string;
402
402
  inputSchema: Record<string, unknown>;
403
- exposureMode: "hidden" | "direct" | "discovery";
403
+ exposureMode: "direct" | "discovery" | "hidden";
404
404
  enabled: boolean;
405
405
  exposed: boolean;
406
406
  description?: string | undefined;
@@ -425,8 +425,8 @@ declare const AgentInstanceStatusSchema: z.ZodObject<{
425
425
  status: z.ZodEnum<{
426
426
  completed: "completed";
427
427
  cancelled: "cancelled";
428
- running: "running";
429
428
  failed: "failed";
429
+ running: "running";
430
430
  waiting_input: "waiting_input";
431
431
  }>;
432
432
  result: z.ZodOptional<z.ZodString>;
@@ -535,9 +535,9 @@ declare const AgentRuntimeSchemas: {
535
535
  description: z.ZodOptional<z.ZodString>;
536
536
  inputSchema: z.ZodRecord<z.ZodString, z.ZodUnknown>;
537
537
  exposureMode: z.ZodEnum<{
538
- hidden: "hidden";
539
538
  direct: "direct";
540
539
  discovery: "discovery";
540
+ hidden: "hidden";
541
541
  }>;
542
542
  enabled: z.ZodBoolean;
543
543
  enabledBy: z.ZodOptional<z.ZodEnum<{
@@ -554,9 +554,9 @@ declare const AgentRuntimeSchemas: {
554
554
  description: z.ZodOptional<z.ZodString>;
555
555
  inputSchema: z.ZodRecord<z.ZodString, z.ZodUnknown>;
556
556
  exposureMode: z.ZodEnum<{
557
- hidden: "hidden";
558
557
  direct: "direct";
559
558
  discovery: "discovery";
559
+ hidden: "hidden";
560
560
  }>;
561
561
  enabled: z.ZodBoolean;
562
562
  enabledBy: z.ZodOptional<z.ZodEnum<{
@@ -619,7 +619,7 @@ declare const AgentRuntimeSchemas: {
619
619
  originalName: string;
620
620
  serverName: string;
621
621
  inputSchema: Record<string, unknown>;
622
- exposureMode: "hidden" | "direct" | "discovery";
622
+ exposureMode: "direct" | "discovery" | "hidden";
623
623
  enabled: boolean;
624
624
  exposed: boolean;
625
625
  description?: string | undefined;
@@ -631,7 +631,7 @@ declare const AgentRuntimeSchemas: {
631
631
  originalName: string;
632
632
  serverName: string;
633
633
  inputSchema: Record<string, unknown>;
634
- exposureMode: "hidden" | "direct" | "discovery";
634
+ exposureMode: "direct" | "discovery" | "hidden";
635
635
  enabled: boolean;
636
636
  exposed: boolean;
637
637
  description?: string | undefined;
@@ -693,7 +693,7 @@ declare const AgentRuntimeSchemas: {
693
693
  originalName: string;
694
694
  serverName: string;
695
695
  inputSchema: Record<string, unknown>;
696
- exposureMode: "hidden" | "direct" | "discovery";
696
+ exposureMode: "direct" | "discovery" | "hidden";
697
697
  enabled: boolean;
698
698
  exposed: boolean;
699
699
  description?: string | undefined;
@@ -705,7 +705,7 @@ declare const AgentRuntimeSchemas: {
705
705
  originalName: string;
706
706
  serverName: string;
707
707
  inputSchema: Record<string, unknown>;
708
- exposureMode: "hidden" | "direct" | "discovery";
708
+ exposureMode: "direct" | "discovery" | "hidden";
709
709
  enabled: boolean;
710
710
  exposed: boolean;
711
711
  description?: string | undefined;
@@ -765,7 +765,7 @@ declare const AgentRuntimeSchemas: {
765
765
  originalName: string;
766
766
  serverName: string;
767
767
  inputSchema: Record<string, unknown>;
768
- exposureMode: "hidden" | "direct" | "discovery";
768
+ exposureMode: "direct" | "discovery" | "hidden";
769
769
  enabled: boolean;
770
770
  exposed: boolean;
771
771
  description?: string | undefined;
@@ -777,7 +777,7 @@ declare const AgentRuntimeSchemas: {
777
777
  originalName: string;
778
778
  serverName: string;
779
779
  inputSchema: Record<string, unknown>;
780
- exposureMode: "hidden" | "direct" | "discovery";
780
+ exposureMode: "direct" | "discovery" | "hidden";
781
781
  enabled: boolean;
782
782
  exposed: boolean;
783
783
  description?: string | undefined;
@@ -839,7 +839,7 @@ declare const AgentRuntimeSchemas: {
839
839
  originalName: string;
840
840
  serverName: string;
841
841
  inputSchema: Record<string, unknown>;
842
- exposureMode: "hidden" | "direct" | "discovery";
842
+ exposureMode: "direct" | "discovery" | "hidden";
843
843
  enabled: boolean;
844
844
  exposed: boolean;
845
845
  description?: string | undefined;
@@ -851,7 +851,7 @@ declare const AgentRuntimeSchemas: {
851
851
  originalName: string;
852
852
  serverName: string;
853
853
  inputSchema: Record<string, unknown>;
854
- exposureMode: "hidden" | "direct" | "discovery";
854
+ exposureMode: "direct" | "discovery" | "hidden";
855
855
  enabled: boolean;
856
856
  exposed: boolean;
857
857
  description?: string | undefined;
@@ -888,8 +888,8 @@ declare const AgentRuntimeSchemas: {
888
888
  status: z.ZodEnum<{
889
889
  completed: "completed";
890
890
  cancelled: "cancelled";
891
- running: "running";
892
891
  failed: "failed";
892
+ running: "running";
893
893
  waiting_input: "waiting_input";
894
894
  }>;
895
895
  result: z.ZodOptional<z.ZodString>;
@@ -1 +1 @@
1
- import{a as e}from"./visibility-Cb62p9bv.mjs";import"./credential-ref-YWQQENEo.mjs";import{p as t}from"./shared-DpOEfD8F.mjs";import{t as n}from"./provider-context-DjSUpHSM.mjs";import{z as r}from"zod";const i=r.enum([`fork`,`fresh`]),a=r.enum([`spawning`,`running`,`waiting_input`,`hung`,`completed`,`failed`,`cancelled`]),o=r.enum([`tool`,`turn`]),s=r.object({task:r.string(),adapterName:r.string().optional(),providerConfigId:r.string().optional(),providerContext:n.optional(),harnessId:r.string().optional(),model:r.string().optional(),reasoningEffort:e.optional(),contextMode:i.default(`fork`),tools:r.array(r.string()).optional(),disallowedTools:r.array(r.string()).optional(),allowedDirectories:r.array(r.string()).optional(),systemPrompt:r.string().optional(),maxDepth:r.number().optional(),responseSchema:t.optional(),executionTargetId:r.string().optional(),completion:o.optional()}),c=r.object({maxDepth:r.number().default(3),maxConcurrentPerSession:r.number().default(10),maxTotalActive:r.number().default(50),defaultRequestTimeoutMs:r.number().default(6e4),defaultAwaitTimeoutMs:r.number().default(3e5),stateRetentionMs:r.number().default(1800*1e3),inactivityTimeoutMs:r.number().int().nonnegative().default(0),sweepIntervalMs:r.number().int().nonnegative().default(6e4),allowedAdapters:r.array(r.string()).default([]),allowedModels:r.array(r.string()).default([])}).parse({}),l=r.object({inputTokens:r.number(),outputTokens:r.number(),totalTokens:r.number()}),u=r.object({messageId:r.string(),question:r.string(),context:r.string().optional()}),d=r.object({subagentId:r.string(),parentSessionId:r.string(),task:r.string(),config:s,depth:r.number()}),f=r.object({success:r.boolean(),agentId:r.string().optional(),error:r.string().optional()}),p=r.object({subagentId:r.string(),parentSessionId:r.string(),error:r.string(),phase:r.enum([`session_create`,`adapter_start`,`agent_start`])}),m=r.object({parentSessionId:r.string(),config:s,depth:r.number(),spawningToolCallId:r.string().optional()}),h=r.object({subagentId:r.string(),status:r.literal(`spawning`)}),g=r.object({subagentId:r.string(),timeoutMs:r.number().optional()}),_=r.object({status:r.enum([`completed`,`failed`,`waiting_input`,`timeout`,`cancelled`]),result:r.string().optional(),error:r.string().optional(),pendingRequest:u.optional(),completionSource:o.optional()}),v=r.object({subagentId:r.string(),content:r.string(),inResponseTo:r.string().optional()}),y=r.object({sent:r.boolean(),resolvedPending:r.boolean()}),b=r.object({subagentId:r.string(),reason:r.string().optional()}),x=r.object({killed:r.boolean()}),S=r.object({subagentId:r.string(),update:r.string(),percentComplete:r.number().optional()}),C=r.object({reported:r.boolean()}),w=r.object({subagentId:r.string(),question:r.string(),context:r.string().optional(),timeoutMs:r.number().optional()}),T=r.object({responded:r.boolean(),response:r.string().optional(),timedOut:r.boolean()}),E=r.object({subagentId:r.string(),result:r.string(),summary:r.string().optional()}),D=r.object({completed:r.boolean()}),O=r.object({subagentId:r.string(),task:r.string(),status:a}),k=r.object({parentSessionId:r.string()}),A=r.object({subagents:r.array(O)});export{s as C,l as E,h as S,a as T,w as _,o as a,y as b,d as c,x as d,k as f,C as g,S as h,D as i,f as l,u as m,_ as n,i as o,A as p,E as r,c as s,g as t,b as u,T as v,p as w,m as x,v as y};
1
+ import{a as e}from"./visibility-Cb62p9bv.mjs";import"./credential-ref-YWQQENEo.mjs";import{p as t}from"./shared-BVW-3Dhy.mjs";import{t as n}from"./provider-context-CqMgPOWF.mjs";import{z as r}from"zod";const i=r.enum([`fork`,`fresh`]),a=r.enum([`spawning`,`running`,`waiting_input`,`hung`,`completed`,`failed`,`cancelled`]),o=r.enum([`tool`,`turn`]),s=r.object({task:r.string(),adapterName:r.string().optional(),providerConfigId:r.string().optional(),providerContext:n.optional(),harnessId:r.string().optional(),model:r.string().optional(),reasoningEffort:e.optional(),contextMode:i.default(`fork`),tools:r.array(r.string()).optional(),disallowedTools:r.array(r.string()).optional(),allowedDirectories:r.array(r.string()).optional(),systemPrompt:r.string().optional(),maxDepth:r.number().optional(),responseSchema:t.optional(),executionTargetId:r.string().optional(),completion:o.optional()}),c=r.object({maxDepth:r.number().default(3),maxConcurrentPerSession:r.number().default(10),maxTotalActive:r.number().default(50),defaultRequestTimeoutMs:r.number().default(6e4),defaultAwaitTimeoutMs:r.number().default(3e5),stateRetentionMs:r.number().default(1800*1e3),inactivityTimeoutMs:r.number().int().nonnegative().default(0),sweepIntervalMs:r.number().int().nonnegative().default(6e4),allowedAdapters:r.array(r.string()).default([]),allowedModels:r.array(r.string()).default([])}).parse({}),l=r.object({inputTokens:r.number(),outputTokens:r.number(),totalTokens:r.number()}),u=r.object({messageId:r.string(),question:r.string(),context:r.string().optional()}),d=r.object({subagentId:r.string(),parentSessionId:r.string(),task:r.string(),config:s,depth:r.number()}),f=r.object({success:r.boolean(),agentId:r.string().optional(),error:r.string().optional()}),p=r.object({subagentId:r.string(),parentSessionId:r.string(),error:r.string(),phase:r.enum([`session_create`,`adapter_start`,`agent_start`])}),m=r.object({parentSessionId:r.string(),config:s,depth:r.number(),spawningToolCallId:r.string().optional()}),h=r.object({subagentId:r.string(),status:r.literal(`spawning`)}),g=r.object({subagentId:r.string(),timeoutMs:r.number().optional()}),_=r.object({status:r.enum([`completed`,`failed`,`waiting_input`,`timeout`,`cancelled`]),result:r.string().optional(),error:r.string().optional(),pendingRequest:u.optional(),completionSource:o.optional()}),v=r.object({subagentId:r.string(),content:r.string(),inResponseTo:r.string().optional()}),y=r.object({sent:r.boolean(),resolvedPending:r.boolean()}),b=r.object({subagentId:r.string(),reason:r.string().optional()}),x=r.object({killed:r.boolean()}),S=r.object({subagentId:r.string(),update:r.string(),percentComplete:r.number().optional()}),C=r.object({reported:r.boolean()}),w=r.object({subagentId:r.string(),question:r.string(),context:r.string().optional(),timeoutMs:r.number().optional()}),T=r.object({responded:r.boolean(),response:r.string().optional(),timedOut:r.boolean()}),E=r.object({subagentId:r.string(),result:r.string(),summary:r.string().optional()}),D=r.object({completed:r.boolean()}),O=r.object({subagentId:r.string(),task:r.string(),status:a}),k=r.object({parentSessionId:r.string()}),A=r.object({subagents:r.array(O)});export{s as C,l as E,h as S,a as T,w as _,o as a,y as b,d as c,x as d,k as f,C as g,S as h,D as i,f as l,u as m,_ as n,i as o,A as p,E as r,c as s,g as t,b as u,T as v,p as w,m as x,v as y};
@@ -64,8 +64,8 @@ declare const SurfaceBindingRegistrationSchema: z.ZodObject<{
64
64
  template: z.ZodString;
65
65
  }, z.core.$strip>], "kind">;
66
66
  appliesTo: z.ZodArray<z.ZodEnum<{
67
- workpiece: "workpiece";
68
67
  artifact: "artifact";
68
+ workpiece: "workpiece";
69
69
  surface: "surface";
70
70
  }>>;
71
71
  valueMapping: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
@@ -108,8 +108,8 @@ declare const ArtifactProjectionPolicySchema: z.ZodObject<{
108
108
  comment: "comment";
109
109
  }>;
110
110
  defaultRole: z.ZodOptional<z.ZodEnum<{
111
- workpiece: "workpiece";
112
111
  artifact: "artifact";
112
+ workpiece: "workpiece";
113
113
  }>>;
114
114
  semanticEvents: z.ZodOptional<z.ZodArray<z.ZodEnum<{
115
115
  created: "created";
@@ -141,8 +141,8 @@ declare const ArtifactMaterializationRefSchema: z.ZodObject<{
141
141
  externalId: z.ZodString;
142
142
  externalUrl: z.ZodOptional<z.ZodString>;
143
143
  surfaceRole: z.ZodEnum<{
144
- workpiece: "workpiece";
145
144
  artifact: "artifact";
145
+ workpiece: "workpiece";
146
146
  }>;
147
147
  lastSyncedRevision: z.ZodOptional<z.ZodString>;
148
148
  metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;