@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.
- package/dist/.makaio-build.json +2 -2
- package/dist/{account-identity-D5TUafYg.mjs → account-identity-C7Kx_ieU.mjs} +1 -1
- package/dist/{adapter-Deu9viD2.mjs → adapter-DaQqmKOJ.mjs} +1 -1
- package/dist/adapters/index.d.mts +1 -1
- package/dist/artifact-CGjnoyCC.mjs +1 -0
- package/dist/bus/index.d.mts +2 -2
- package/dist/bus/index.mjs +1 -1
- package/dist/{canonical-model-BM5WAnQW.mjs → canonical-model-DV-Z8gsb.mjs} +1 -1
- package/dist/{client-BO-0jTSV.mjs → client-BcfR-LJC.mjs} +1 -1
- package/dist/{compression-CXEHx0rS.mjs → compression-C5JAWdgZ.mjs} +1 -1
- package/dist/contracts/adapter/index.d.mts +2 -2
- package/dist/contracts/adapter/index.mjs +1 -1
- package/dist/contracts/adapter/schemas/session-lineage.d.mts +1 -1
- package/dist/contracts/artifact/index.d.mts +2 -2
- package/dist/contracts/artifact/index.mjs +1 -1
- package/dist/contracts/canonical-model/index.d.mts +1 -1
- package/dist/contracts/canonical-model/index.mjs +1 -1
- package/dist/contracts/client/index.d.mts +1 -1
- package/dist/contracts/client/index.mjs +1 -1
- package/dist/contracts/config/index.d.mts +6 -6
- package/dist/contracts/config/index.mjs +1 -1
- package/dist/contracts/extension/index.d.mts +2 -2
- package/dist/contracts/extension/index.mjs +1 -1
- package/dist/contracts/facet/index.d.mts +1 -1
- package/dist/contracts/harness/index.d.mts +1 -1
- package/dist/contracts/index.d.mts +95 -95
- package/dist/contracts/index.mjs +1 -1
- package/dist/contracts/materialization/index.d.mts +3 -3
- package/dist/contracts/materialization/index.mjs +1 -1
- package/dist/contracts/provider/index.d.mts +1 -1
- package/dist/contracts/provider/index.mjs +1 -1
- package/dist/contracts/session/index.d.mts +2 -2
- package/dist/contracts/session/index.mjs +1 -1
- package/dist/contracts/shared/index.mjs +1 -1
- package/dist/contracts/variant/index.d.mts +1 -1
- package/dist/contracts/workflow/index.d.mts +2 -2
- package/dist/contracts/workflow/index.mjs +1 -1
- package/dist/{definition-BJ_975aA.mjs → definition-C-GVz7uw.mjs} +1 -1
- package/dist/{definition-s9PIua2B.d.mts → definition-DePb3ke-.d.mts} +1 -1
- package/dist/{extension-CfL70C5n.mjs → extension-BS_4BOeO.mjs} +1 -1
- package/dist/{index-ekpUAYVC.d.mts → index-0WhPbKnH.d.mts} +806 -30
- package/dist/{index-BN95duxC.d.mts → index-4eP9DRL_.d.mts} +4 -4
- package/dist/{index-BwGfdbI0.d.mts → index-B1XsbrAr.d.mts} +6 -6
- package/dist/{index-CRmApyqn.d.mts → index-B5w-0Gg9.d.mts} +8 -8
- package/dist/{index-Chtgizhn.d.mts → index-BKZhnb2B.d.mts} +57 -57
- package/dist/{index-DTBQOCar.d.mts → index-BMbmoarE.d.mts} +16 -16
- package/dist/{index-B08YYzYZ.d.mts → index-BhOLtp0B.d.mts} +9 -9
- package/dist/{index-CWDJFJGa.d.mts → index-C6SLILCZ.d.mts} +200 -200
- package/dist/{index-DEzdNQum.d.mts → index-CYHWOXUm.d.mts} +1 -1
- package/dist/{index-DDrS0Axp.d.mts → index-Clqt7Nm3.d.mts} +16 -16
- package/dist/{index-JkIaFJoM.d.mts → index-Cvjnj7Zh.d.mts} +8 -8
- package/dist/{index-Qd1Qom8M.d.mts → index-Cyi7y_aG.d.mts} +16 -16
- package/dist/{index-C2jl1iE2.d.mts → index-D4gn93gL.d.mts} +28 -28
- package/dist/{index-DXYFNGT9.d.mts → index-D8ScOpus.d.mts} +61 -61
- package/dist/{index-DYw2AuNR.d.mts → index-DsLpP5ek.d.mts} +1 -1
- package/dist/{index-ByDySw3V.d.mts → index-WHUV7neB.d.mts} +10 -10
- package/dist/{index-CfIW5biI.d.mts → index-wfSedMR9.d.mts} +1 -1
- package/dist/kernel/extension/index.d.mts +1 -1
- package/dist/kernel/index.d.mts +2 -2
- package/dist/kernel/observability/index.d.mts +1 -1
- package/dist/{materialization-DBXjSiBn.mjs → materialization-CUYxZCfk.mjs} +1 -1
- package/dist/{namespace-KMxsPJwm.d.mts → namespace-BeMGmLrp.d.mts} +9 -9
- package/dist/{namespace-CxzW0mIH.d.mts → namespace-Bm77p82L.d.mts} +5 -5
- package/dist/{namespace-Bz0ORDns.d.mts → namespace-Bmi5bjm4.d.mts} +78 -78
- package/dist/{namespace-DuUCiVmK.d.mts → namespace-CGxFYDlK.d.mts} +26 -26
- package/dist/{namespace-DBGLCtoW.d.mts → namespace-CfvtDD_U.d.mts} +22 -22
- package/dist/{namespace-DXWpFdQH2.d.mts → namespace-D8P8Sxce2.d.mts} +2 -2
- package/dist/package.json +1 -1
- package/dist/{provider-context-DjSUpHSM.mjs → provider-context-CqMgPOWF.mjs} +1 -1
- package/dist/runtime-node/index.mjs +1 -1
- package/dist/runtime-node/workflow-worker/index.mjs +1 -1
- package/dist/{schema-Dky4zu9D.d.mts → schema-Bf_ZNjif.d.mts} +3 -3
- package/dist/{schemas-7ncImjsM.d.mts → schemas-BemsLc_V.d.mts} +1 -1
- package/dist/{schemas-Eq-lrXYz2.d.mts → schemas-C6TVJ80V2.d.mts} +5 -5
- package/dist/{schemas-CynXJXJu.d.mts → schemas-CoFCV42v.d.mts} +22 -22
- package/dist/{schemas-CE1gbhxu.mjs → schemas-CuG17U3L.mjs} +1 -1
- package/dist/{schemas-CJ2JvA7d.d.mts → schemas-D512XweP.d.mts} +3 -3
- package/dist/{schemas-bfhY9W6A.mjs → schemas-uID59wR8.mjs} +1 -1
- package/dist/services/adapter-subsystem/index.d.mts +2 -2
- package/dist/services/adapter-subsystem/namespace.d.mts +1 -1
- package/dist/services/agent-runtime/index.d.mts +2 -2
- package/dist/services/agent-runtime/namespace.d.mts +1 -1
- package/dist/services/agent-runtime/schemas.d.mts +1 -1
- package/dist/services/context-rules/index.d.mts +6 -6
- package/dist/services/filesystem/namespace.d.mts +6 -6
- package/dist/services/filesystem/schemas.d.mts +3 -3
- package/dist/services/harness/index.d.mts +6 -6
- package/dist/services/index.d.mts +94 -51
- package/dist/services/index.mjs +1 -1
- package/dist/services/log-import/browser.d.mts +2 -2
- package/dist/services/log-import/index.d.mts +2 -2
- package/dist/services/log-import/log-import.d.mts +1 -1
- package/dist/services/log-import/namespace.d.mts +2 -2
- package/dist/services/log-import/schemas.d.mts +1 -1
- package/dist/services/session/index.d.mts +5 -5
- package/dist/services/session/messages/namespace.d.mts +1 -1
- package/dist/services/session/session-events/namespace.d.mts +1 -1
- package/dist/services/session/storage/namespace.d.mts +1 -1
- package/dist/services/session/storage/schema.d.mts +1 -1
- package/dist/services/settings/namespace.d.mts +2 -2
- package/dist/services/subagent-template/index.d.mts +2 -2
- package/dist/services/subagent-template/namespace.d.mts +1 -1
- package/dist/services/subagent-template/schemas.d.mts +1 -1
- package/dist/{session-CpVSzgkZ.mjs → session-DH-ja8Ka.mjs} +1 -1
- package/dist/{session-lineage-DR-9DU-U.d.mts → session-lineage-5-wRBzuC.d.mts} +1 -1
- package/dist/{shared-DpOEfD8F.mjs → shared-BVW-3Dhy.mjs} +1 -1
- package/dist/{transition-Bf-K6QGz.d.mts → transition-CBjccCMw.d.mts} +1 -1
- package/dist/{types-BolHvLpf.d.mts → types-8rhArs_K.d.mts} +84 -84
- package/dist/{types-BslClRkH.d.mts → types-InWSdi-V.d.mts} +1 -1
- package/dist/ui-kernel/index.d.mts +1 -1
- package/dist/ui-kernel/pages/schemas.d.mts +1 -1
- package/dist/{workflow-BCKOJ4UC.mjs → workflow-BqH6ar-D.mjs} +1 -1
- package/dist/workflow-engine/index.d.mts +63 -63
- package/dist/workflow-worker-dH70EbjE.mjs +1 -0
- package/package.json +2 -2
- package/dist/artifact-B3npq1cy.mjs +0 -1
- package/dist/workflow-worker-BIpYi6o7.mjs +0 -1
- /package/dist/{json-value-CmhSGMLv.mjs → json-value-DmU8ibo_.mjs} +0 -0
- /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-
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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: "
|
|
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-
|
|
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>>;
|