@skaile/workspaces 0.22.0 → 0.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (124) hide show
  1. package/CHANGELOG.md +92 -0
  2. package/dist/{asset-feeds-Y2CDCM3W.js → asset-feeds-WKIKSZ6Z.js} +9 -9
  3. package/dist/{asset-feeds-Y2CDCM3W.js.map → asset-feeds-WKIKSZ6Z.js.map} +1 -1
  4. package/dist/asset-manager/index.js +7 -7
  5. package/dist/asset-manager/installer.js +6 -6
  6. package/dist/asset-manager/src/index.d.ts +15 -0
  7. package/dist/asset-manager/src/index.d.ts.map +1 -1
  8. package/dist/base-assets/connectors/deploy.js +8 -8
  9. package/dist/base-assets/connectors/devserver.js +8 -8
  10. package/dist/base-assets/connectors/flow/adapter.js +8 -8
  11. package/dist/base-assets/connectors/flow/run-flow.js +9 -9
  12. package/dist/base-assets/connectors/flow.js +8 -8
  13. package/dist/base-assets/connectors/git.js +8 -8
  14. package/dist/base-assets/connectors/gmail.js +8 -8
  15. package/dist/base-assets/connectors/googledrive/driver.d.ts.map +1 -1
  16. package/dist/base-assets/connectors/googledrive.js +8 -8
  17. package/dist/base-assets/connectors/local.js +8 -8
  18. package/dist/base-assets/connectors/mattermost.js +8 -8
  19. package/dist/base-assets/connectors/memory.js +8 -8
  20. package/dist/base-assets/connectors/minio.js +8 -8
  21. package/dist/base-assets/connectors/postgres.js +8 -8
  22. package/dist/base-assets/connectors/s3.js +8 -8
  23. package/dist/base-assets/connectors/sharepoint/driver.d.ts.map +1 -1
  24. package/dist/base-assets/connectors/sharepoint.js +8 -8
  25. package/dist/base-assets/connectors/sqlite.js +8 -8
  26. package/dist/base-assets/connectors/static-server.js +8 -8
  27. package/dist/base-assets/connectors/tunnel.js +8 -8
  28. package/dist/base-assets/connectors/webdav/driver.d.ts.map +1 -1
  29. package/dist/base-assets/connectors/webdav.js +8 -8
  30. package/dist/base-assets/connectors/xstate-store.js +8 -8
  31. package/dist/base-assets/connectors/xstate.js +8 -8
  32. package/dist/{chunk-MNAHNDUI.js → chunk-2F3RUZXC.js} +3 -3
  33. package/dist/{chunk-MNAHNDUI.js.map → chunk-2F3RUZXC.js.map} +1 -1
  34. package/dist/{chunk-2RYQERIT.js → chunk-2RFOFHSM.js} +4 -4
  35. package/dist/{chunk-2RYQERIT.js.map → chunk-2RFOFHSM.js.map} +1 -1
  36. package/dist/{chunk-K2HDYSAM.js → chunk-46COM7M5.js} +5 -5
  37. package/dist/{chunk-K2HDYSAM.js.map → chunk-46COM7M5.js.map} +1 -1
  38. package/dist/{chunk-V5TBKO5Q.js → chunk-542K7SR6.js} +59 -35
  39. package/dist/chunk-542K7SR6.js.map +1 -0
  40. package/dist/{chunk-PFOXL4SH.js → chunk-5ESCS2OS.js} +4 -4
  41. package/dist/{chunk-PFOXL4SH.js.map → chunk-5ESCS2OS.js.map} +1 -1
  42. package/dist/{chunk-WH2EB2SF.js → chunk-AFLH7B64.js} +3 -3
  43. package/dist/{chunk-WH2EB2SF.js.map → chunk-AFLH7B64.js.map} +1 -1
  44. package/dist/{chunk-7HSXUKNB.js → chunk-BTAC2VYT.js} +19 -18
  45. package/dist/chunk-BTAC2VYT.js.map +1 -0
  46. package/dist/{chunk-K7WPR77X.js → chunk-DH4N5AW4.js} +14 -8
  47. package/dist/chunk-DH4N5AW4.js.map +1 -0
  48. package/dist/{chunk-SKXCTV55.js → chunk-DZCFFTAX.js} +9 -9
  49. package/dist/{chunk-SKXCTV55.js.map → chunk-DZCFFTAX.js.map} +1 -1
  50. package/dist/{chunk-OJN25VJO.js → chunk-E4UJ7CVK.js} +31 -126
  51. package/dist/chunk-E4UJ7CVK.js.map +1 -0
  52. package/dist/{chunk-JN2CUVSU.js → chunk-LJ52ZKIU.js} +3 -3
  53. package/dist/{chunk-JN2CUVSU.js.map → chunk-LJ52ZKIU.js.map} +1 -1
  54. package/dist/{chunk-NBJ5TOEC.js → chunk-ODPII24X.js} +3 -3
  55. package/dist/{chunk-NBJ5TOEC.js.map → chunk-ODPII24X.js.map} +1 -1
  56. package/dist/{chunk-NDD5VMN5.js → chunk-OVQZ5OKL.js} +2 -2
  57. package/dist/{chunk-NDD5VMN5.js.map → chunk-OVQZ5OKL.js.map} +1 -1
  58. package/dist/{chunk-6MB7CRME.js → chunk-QMONOHXT.js} +268 -37
  59. package/dist/chunk-QMONOHXT.js.map +1 -0
  60. package/dist/{chunk-53UNDY6K.js → chunk-QTWA6BZK.js} +5 -5
  61. package/dist/{chunk-53UNDY6K.js.map → chunk-QTWA6BZK.js.map} +1 -1
  62. package/dist/{chunk-4NDWKA64.js → chunk-WSZAFRQL.js} +8 -3
  63. package/dist/chunk-WSZAFRQL.js.map +1 -0
  64. package/dist/{chunk-VUCPJBAG.js → chunk-YX3UWPJ5.js} +53 -28
  65. package/dist/chunk-YX3UWPJ5.js.map +1 -0
  66. package/dist/{chunk-ETMUGBHF.js → chunk-Z3M5K67G.js} +8 -8
  67. package/dist/chunk-Z3M5K67G.js.map +1 -0
  68. package/dist/cli/index.js +38 -38
  69. package/dist/cli/index.js.map +1 -1
  70. package/dist/cli/src/commands/manage.d.ts.map +1 -1
  71. package/dist/cli/src/helpers.d.ts +7 -0
  72. package/dist/cli/src/helpers.d.ts.map +1 -1
  73. package/dist/connectors/config.js +6 -6
  74. package/dist/connectors/index.js +8 -8
  75. package/dist/connectors/rclone.js +2 -1
  76. package/dist/connectors/src/rclone-process-manager.d.ts +91 -3
  77. package/dist/connectors/src/rclone-process-manager.d.ts.map +1 -1
  78. package/dist/connectors/src/watcher.d.ts +6 -0
  79. package/dist/connectors/src/watcher.d.ts.map +1 -1
  80. package/dist/core/index.js +5 -5
  81. package/dist/core/manifest.js +2 -2
  82. package/dist/core/models.js +1 -1
  83. package/dist/core/runtime-assets.js +4 -4
  84. package/dist/core/src/lock.d.ts +6 -6
  85. package/dist/core/src/manifest.d.ts.map +1 -1
  86. package/dist/core/src/models.d.ts +25 -18
  87. package/dist/core/src/models.d.ts.map +1 -1
  88. package/dist/core/src/repo-manager.d.ts +8 -2
  89. package/dist/core/src/repo-manager.d.ts.map +1 -1
  90. package/dist/core/workspace-config.js +3 -3
  91. package/dist/deploy/index.js +5 -5
  92. package/dist/discovery/index.js +3 -3
  93. package/dist/{ensure-sources-REWWBH2K.js → ensure-sources-OJUBGX6Z.js} +10 -10
  94. package/dist/{ensure-sources-REWWBH2K.js.map → ensure-sources-OJUBGX6Z.js.map} +1 -1
  95. package/dist/helpers-LTN3HMD3.js +4 -0
  96. package/dist/{helpers-I3SREIC3.js.map → helpers-LTN3HMD3.js.map} +1 -1
  97. package/dist/library/index.js +4 -4
  98. package/dist/open-library-67FSSQWE.js +13 -0
  99. package/dist/{open-library-CT4VVESU.js.map → open-library-67FSSQWE.js.map} +1 -1
  100. package/dist/{plugin-store-QS7TC5HY.js → plugin-store-IZ5SCRAV.js} +7 -7
  101. package/dist/{plugin-store-QS7TC5HY.js.map → plugin-store-IZ5SCRAV.js.map} +1 -1
  102. package/dist/runner/index.js +10 -10
  103. package/dist/sdk/asset-manager.js +7 -7
  104. package/dist/sdk/core.js +5 -5
  105. package/dist/sdk/index.js +10 -10
  106. package/dist/sdk/runner.js +10 -10
  107. package/dist/{setup-F6DGKL7J.js → setup-J7CYEQOF.js} +7 -7
  108. package/dist/{setup-F6DGKL7J.js.map → setup-J7CYEQOF.js.map} +1 -1
  109. package/dist/store-client-AEI6Y3KD.js +14 -0
  110. package/dist/{store-client-JP642EEI.js.map → store-client-AEI6Y3KD.js.map} +1 -1
  111. package/dist/tui/index.js +10 -10
  112. package/dist/workspace-plugin/index.js +1 -1
  113. package/package.json +1 -1
  114. package/dist/chunk-4NDWKA64.js.map +0 -1
  115. package/dist/chunk-6MB7CRME.js.map +0 -1
  116. package/dist/chunk-7HSXUKNB.js.map +0 -1
  117. package/dist/chunk-ETMUGBHF.js.map +0 -1
  118. package/dist/chunk-K7WPR77X.js.map +0 -1
  119. package/dist/chunk-OJN25VJO.js.map +0 -1
  120. package/dist/chunk-V5TBKO5Q.js.map +0 -1
  121. package/dist/chunk-VUCPJBAG.js.map +0 -1
  122. package/dist/helpers-I3SREIC3.js +0 -4
  123. package/dist/open-library-CT4VVESU.js +0 -13
  124. package/dist/store-client-JP642EEI.js +0 -14
@@ -0,0 +1,4 @@
1
+ export { S, colorRef, fitWidth, formatRelativeTime, kindColor, kindColorPad, logErr, logInfo, logOk, logWarn } from './chunk-WSZAFRQL.js';
2
+ import './chunk-NSBPE2FW.js';
3
+ //# sourceMappingURL=helpers-LTN3HMD3.js.map
4
+ //# sourceMappingURL=helpers-LTN3HMD3.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"helpers-I3SREIC3.js"}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"helpers-LTN3HMD3.js"}
@@ -1,9 +1,9 @@
1
- export { CatalogCache, CatalogConfigSchema, CatalogHttpError, DuplicateLibraryNameError, DuplicateSubscriptionError, GitSyncDriver, InstanceHasConsumersError, InstanceNotFoundError, InterpolationError, KNOWN_ASSET_KINDS, KnowledgeManifestSchema, LIBRARY_BACKENDS, LIBRARY_OWNERSHIPS, LIBRARY_STRUCTURES, LOCAL_CATALOG_URL, LibraryConfigSchema, LibraryError, LibraryInstanceRefSchema, LibraryManager, LibrarySectionSchema, LibrarySyncError, LocalCatalogSource, LocalIndex, LocalSyncDriver, LockFileSchema, LockSubscriptionSchema, OfflineError, OperationNotPermittedError, PIN_POLICIES, PinPolicySchema, PresetAppliedSchema, PresetExpandedSchema, RemoteCatalogSource, RequiresEdgeSchema, RestCatalogSource, SidecarGit, SkaileConfigSchema, SourceNotFoundError, SubscriptionNotFoundError, TarballHashMismatchError, UserLibraryNotFoundError, WorkspaceConfigV2Schema, applyNonStructuralUpgrade, applyPreset, applyPresetFromData, classifyRef, createEmptyLockFile, deriveSlug, detectChanges, detectNestedPresetRefs, detectWorkspaceVersion, evaluateUpgrade, extractLibraryInstanceId, extractReferencedKeys, filterKey, getConfigDefaults, getDefaultValue, getSidecarRoot, getStoreManifestsDir, getStoreRoot, hasInterpolationTokens, installFromManifest, interpolate, isLocalCatalogUrl, isSecretPlaceholder, knowledgeKindProvider, listSidecarSlugsOnDisk, loadLockFile, loadWorkspaceV2, migrateSidecarsToStoreIfNeeded, migrateWorkspaceConfig, parsePreset, parsePresetYaml, parseWorkspaceV2, projectConfigPath, queryInstancePickerChoices, resolveAllItems, resolveConfig, resolveIndexPath, resolveItem, resolveLibraryDir, resolvePin, resolveSidecarPaths, saveConfig, saveLockFile, saveWorkspaceV2, sha256Hex, skaileHomeDir, storeSecrets, trpcGetUrl, userConfigPath, validateAllPlaceholders, validateKnowledge, validateNestingDepth, validatePlaceholder, writeManifestIfMissing } from '../chunk-MNAHNDUI.js';
1
+ export { CatalogCache, CatalogConfigSchema, CatalogHttpError, DuplicateLibraryNameError, DuplicateSubscriptionError, GitSyncDriver, InstanceHasConsumersError, InstanceNotFoundError, InterpolationError, KNOWN_ASSET_KINDS, KnowledgeManifestSchema, LIBRARY_BACKENDS, LIBRARY_OWNERSHIPS, LIBRARY_STRUCTURES, LOCAL_CATALOG_URL, LibraryConfigSchema, LibraryError, LibraryInstanceRefSchema, LibraryManager, LibrarySectionSchema, LibrarySyncError, LocalCatalogSource, LocalIndex, LocalSyncDriver, LockFileSchema, LockSubscriptionSchema, OfflineError, OperationNotPermittedError, PIN_POLICIES, PinPolicySchema, PresetAppliedSchema, PresetExpandedSchema, RemoteCatalogSource, RequiresEdgeSchema, RestCatalogSource, SidecarGit, SkaileConfigSchema, SourceNotFoundError, SubscriptionNotFoundError, TarballHashMismatchError, UserLibraryNotFoundError, WorkspaceConfigV2Schema, applyNonStructuralUpgrade, applyPreset, applyPresetFromData, classifyRef, createEmptyLockFile, deriveSlug, detectChanges, detectNestedPresetRefs, detectWorkspaceVersion, evaluateUpgrade, extractLibraryInstanceId, extractReferencedKeys, filterKey, getConfigDefaults, getDefaultValue, getSidecarRoot, getStoreManifestsDir, getStoreRoot, hasInterpolationTokens, installFromManifest, interpolate, isLocalCatalogUrl, isSecretPlaceholder, knowledgeKindProvider, listSidecarSlugsOnDisk, loadLockFile, loadWorkspaceV2, migrateSidecarsToStoreIfNeeded, migrateWorkspaceConfig, parsePreset, parsePresetYaml, parseWorkspaceV2, projectConfigPath, queryInstancePickerChoices, resolveAllItems, resolveConfig, resolveIndexPath, resolveItem, resolveLibraryDir, resolvePin, resolveSidecarPaths, saveConfig, saveLockFile, saveWorkspaceV2, sha256Hex, skaileHomeDir, storeSecrets, trpcGetUrl, userConfigPath, validateAllPlaceholders, validateKnowledge, validateNestingDepth, validatePlaceholder, writeManifestIfMissing } from '../chunk-2F3RUZXC.js';
2
2
  export { GITHUB_PAT_ENV, fetchAssetFilesFromGitHub } from '../chunk-R7FOF242.js';
3
- import '../chunk-JN2CUVSU.js';
3
+ import '../chunk-LJ52ZKIU.js';
4
4
  import '../chunk-OKRUTSG7.js';
5
- import '../chunk-K7WPR77X.js';
6
- import '../chunk-VUCPJBAG.js';
5
+ import '../chunk-DH4N5AW4.js';
6
+ import '../chunk-YX3UWPJ5.js';
7
7
  import '../chunk-NELZIQ2E.js';
8
8
  import '../chunk-NSBPE2FW.js';
9
9
  //# sourceMappingURL=index.js.map
@@ -0,0 +1,13 @@
1
+ export { openCatalogSource, openLibrary, openLibraryManager, resolveCatalogSource } from './chunk-46COM7M5.js';
2
+ import './chunk-WSZAFRQL.js';
3
+ import './chunk-2F3RUZXC.js';
4
+ import './chunk-R7FOF242.js';
5
+ import './chunk-LJ52ZKIU.js';
6
+ import './chunk-OKRUTSG7.js';
7
+ import './chunk-ICS76R4T.js';
8
+ import './chunk-DH4N5AW4.js';
9
+ import './chunk-YX3UWPJ5.js';
10
+ import './chunk-NELZIQ2E.js';
11
+ import './chunk-NSBPE2FW.js';
12
+ //# sourceMappingURL=open-library-67FSSQWE.js.map
13
+ //# sourceMappingURL=open-library-67FSSQWE.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"open-library-CT4VVESU.js"}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"open-library-67FSSQWE.js"}
@@ -1,11 +1,11 @@
1
1
  import { pluginRegistry } from './chunk-6E6PKKAD.js';
2
- import { readPluginsLockSlice } from './chunk-ETMUGBHF.js';
2
+ import { readPluginsLockSlice } from './chunk-Z3M5K67G.js';
3
3
  import './chunk-K5GBV4SA.js';
4
4
  import './chunk-KLNL7QHN.js';
5
- import './chunk-PFOXL4SH.js';
6
- import './chunk-V5TBKO5Q.js';
7
- import './chunk-K7WPR77X.js';
8
- import './chunk-VUCPJBAG.js';
5
+ import './chunk-5ESCS2OS.js';
6
+ import './chunk-542K7SR6.js';
7
+ import './chunk-DH4N5AW4.js';
8
+ import './chunk-YX3UWPJ5.js';
9
9
  import './chunk-JKNWJ64A.js';
10
10
  import './chunk-O4JH3KUE.js';
11
11
  import './chunk-24UIWON4.js';
@@ -140,5 +140,5 @@ async function ensurePluginsLoaded(projectDir, plugins, registry = pluginRegistr
140
140
  }
141
141
 
142
142
  export { defaultInstall, ensurePluginsLoaded, loadPlugins, lockPath, nodeModulesDir, parseSpec, pluginsDir, pluginsPkgJson, reconcileHashFile, reconcilePlugins, resolvePluginEntry, specName };
143
- //# sourceMappingURL=plugin-store-QS7TC5HY.js.map
144
- //# sourceMappingURL=plugin-store-QS7TC5HY.js.map
143
+ //# sourceMappingURL=plugin-store-IZ5SCRAV.js.map
144
+ //# sourceMappingURL=plugin-store-IZ5SCRAV.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../cli/src/plugin-store/paths.ts","../cli/src/plugin-store/spec.ts","../cli/src/plugin-store/load.ts","../cli/src/plugin-store/reconcile.ts","../cli/src/plugin-store/index.ts"],"names":[],"mappings":"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","file":"plugin-store-QS7TC5HY.js","sourcesContent":["/**\n * Pure path helpers for the project-local plugin store.\n *\n * The store is a self-contained npm workspace owned by the CLI under\n * `<projectDir>/.skaile/plugins/`. Nothing here touches the filesystem.\n */\n\nimport { join } from \"node:path\";\n\n/** `<projectDir>/.skaile/plugins` — the store root. */\nexport function pluginsDir(projectDir: string): string {\n return join(projectDir, \".skaile\", \"plugins\");\n}\n\n/** `<store>/package.json` — generated, never user-edited. */\nexport function pluginsPkgJson(projectDir: string): string {\n return join(pluginsDir(projectDir), \"package.json\");\n}\n\n/** `<store>/node_modules` — where reconciled plugin packages land. */\nexport function nodeModulesDir(projectDir: string): string {\n return join(pluginsDir(projectDir), \"node_modules\");\n}\n\n/** `<store>/.reconcile-hash` — SHA of plugins-list + lock slice; skip reinstall when unchanged. */\nexport function reconcileHashFile(projectDir: string): string {\n return join(pluginsDir(projectDir), \".reconcile-hash\");\n}\n\n/** `<projectDir>/skaile.lock.yaml` — the project lock file. */\nexport function lockPath(projectDir: string): string {\n return join(projectDir, \"skaile.lock.yaml\");\n}\n\n/**\n * Absolute path to a plugin package's entry directory under the store's\n * `node_modules`. Dynamic `import()` against this absolute path works inside\n * compiled binaries via `pathToFileURL`.\n */\nexport function resolvePluginEntry(projectDir: string, pkgName: string): string {\n return join(nodeModulesDir(projectDir), pkgName);\n}\n","/**\n * Parse npm package specifiers from the `plugins:` list into name + range.\n *\n * The leading `@` of a scope is NOT a separator: only the last `@` at a\n * non-zero index splits the package name from its semver range.\n * \"@skaile/provider-fly@^0.1.0\" → { name: \"@skaile/provider-fly\", range: \"^0.1.0\" }\n * \"@skaile/connector-redis\" → { name: \"@skaile/connector-redis\", range: \"*\" }\n * \"lodash@^4\" → { name: \"lodash\", range: \"^4\" }\n */\n\n/** A parsed plugin specifier: package name plus a semver range (`\"*\"` when omitted). */\nexport interface PluginSpec {\n name: string;\n range: string;\n}\n\n/**\n * Parse a single plugin specifier into `{ name, range }`.\n *\n * @param spec - An npm specifier, e.g. `\"@skaile/provider-fly@^0.1.0\"` or `\"lodash\"`.\n * @returns The package name and semver range (range defaults to `\"*\"`).\n * @throws Error when the specifier is empty.\n */\nexport function parseSpec(spec: string): PluginSpec {\n const trimmed = spec.trim();\n if (!trimmed) throw new Error(\"parseSpec: empty specifier\");\n\n // Find the version-separating `@` — the last one that is not the scope `@`\n // at index 0. A bare `@scope/name` has its only `@` at index 0 (no range).\n const at = trimmed.lastIndexOf(\"@\");\n if (at <= 0) {\n return { name: trimmed, range: \"*\" };\n }\n const name = trimmed.slice(0, at);\n const range = trimmed.slice(at + 1);\n return { name, range: range.length > 0 ? range : \"*\" };\n}\n\n/** Convenience: just the package name of a specifier. */\nexport function specName(spec: string): string {\n return parseSpec(spec).name;\n}\n","/**\n * Runtime plugin loader: dynamic-import each reconciled plugin and let it\n * self-register into the `pluginRegistry`.\n *\n * Each plugin specifier resolves to an absolute path under the store's\n * `node_modules`; we import it via a `file://` URL so the import works inside\n * `bun --compile` binaries (which bundle only the literal-string switches, but\n * can still execute a `file://` import against the unpacked store on disk).\n * Failures are caught per-plugin so one broken plugin never aborts the rest.\n */\n\nimport { pathToFileURL } from \"node:url\";\nimport { type PluginRegistry, pluginRegistry } from \"@skaile/workspaces/plugin-registry\";\nimport type { Logger } from \"@skaile/workspaces/types\";\nimport { resolvePluginEntry } from \"./paths.js\";\nimport { parseSpec } from \"./spec.js\";\n\n/** Options for {@link loadPlugins}. */\nexport interface LoadOptions {\n log?: Logger;\n}\n\n/** Result of a load pass: which specs registered and which failed. */\nexport interface LoadResult {\n loaded: string[];\n failed: { spec: string; error: string }[];\n}\n\n/** The self-registration entrypoint a plugin module is expected to export. */\ntype PluginModule = { register?: (registry: PluginRegistry) => void };\n\n/**\n * Load and register each plugin in `plugins` into `registry`.\n *\n * @param projectDir - Project root holding `.skaile/plugins/node_modules`.\n * @param plugins - The `skaile.yaml` `plugins:` list (npm specifiers).\n * @param registry - Registry to register into. Defaults to the process-wide `pluginRegistry`.\n * @param opts - Optional logger.\n * @returns Loaded specs + per-plugin failures (never throws).\n */\nexport async function loadPlugins(\n projectDir: string,\n plugins: string[],\n registry: PluginRegistry = pluginRegistry,\n opts: LoadOptions = {},\n): Promise<LoadResult> {\n const loaded: string[] = [];\n const failed: { spec: string; error: string }[] = [];\n\n for (const spec of plugins) {\n try {\n const { name } = parseSpec(spec);\n const entry = resolvePluginEntry(projectDir, name);\n const mod = (await import(pathToFileURL(entry).href)) as PluginModule;\n if (typeof mod.register !== \"function\") {\n throw new Error(`plugin \"${name}\" does not export a register() function`);\n }\n mod.register(registry);\n loaded.push(spec);\n } catch (err) {\n const message = err instanceof Error ? err.message : String(err);\n failed.push({ spec, error: `failed to load plugin \"${spec}\": ${message}` });\n opts.log?.warn(`plugin load failed: ${spec}`, { error: message });\n }\n }\n\n return { loaded, failed };\n}\n","/**\n * Reconcile the project-local plugin store (`<projectDir>/.skaile/plugins/`).\n *\n * The reconciler is hash-skipped: it computes a SHA-256 over the sorted plugin\n * list plus the lock file's `plugins` slice and compares it to the stored\n * `.reconcile-hash`. On a match it returns with zero further I/O; otherwise it\n * regenerates the store's `package.json` and runs `bun install` against it.\n *\n * The install step is injectable (`InstallFn`) so tests stay hermetic — they\n * pass a fake installer that records calls and writes a stub `node_modules`.\n */\n\nimport { createHash } from \"node:crypto\";\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from \"node:fs\";\nimport { readPluginsLockSlice } from \"@skaile/workspaces/core\";\nimport { pluginsDir, pluginsPkgJson, reconcileHashFile } from \"./paths.js\";\nimport { parseSpec } from \"./spec.js\";\n\n/**\n * Installs the store's dependencies. Returns `ok: false` (never throws) on a\n * failed install so the reconciler can surface the captured `output`.\n */\nexport type InstallFn = (pluginsDir: string) => Promise<{ ok: boolean; output: string }>;\n\n/** Options for {@link reconcilePlugins}. */\nexport interface ReconcileOptions {\n /** Injectable installer. Defaults to a real `bun install` of the store. */\n runInstall?: InstallFn;\n /**\n * Lock slice to fold into the reconcile-hash. Defaults to\n * `readPluginsLockSlice(projectDir)` so a lock edit invalidates the hash.\n */\n lockSlice?: unknown;\n}\n\n/** Result of a reconcile pass. */\nexport interface ReconcileResult {\n changed: boolean;\n reason: \"no-plugins\" | \"up-to-date\" | \"reconciled\";\n}\n\n/**\n * The default real installer: `bun install` inside the store directory.\n * Frozen on subsequent runs (a `bun.lock`/`bun.lockb` already exists), and\n * non-frozen on the first run so a lock can be generated.\n */\nexport const defaultInstall: InstallFn = async (dir) => {\n const { portableSpawn } = await import(\"@skaile/workspaces/core\");\n const hasLock =\n existsSync(`${dir}/bun.lock`) ||\n existsSync(`${dir}/bun.lockb`) ||\n existsSync(`${dir}/package-lock.json`);\n const args = hasLock ? [\"bun\", \"install\", \"--frozen-lockfile\"] : [\"bun\", \"install\"];\n const proc = portableSpawn(args, { cwd: dir });\n const chunks: string[] = [];\n const decoder = new TextDecoder();\n const pump = async (stream: ReadableStream<Uint8Array>) => {\n const reader = stream.getReader();\n for (;;) {\n const { done, value } = await reader.read();\n if (done) break;\n if (value) chunks.push(decoder.decode(value, { stream: true }));\n }\n };\n await Promise.all([pump(proc.stdout), pump(proc.stderr)]);\n const code = await proc.exited;\n return { ok: code === 0, output: chunks.join(\"\") };\n};\n\n/** Generate the store's `package.json` from the plugin specs. */\nfunction writePackageJson(projectDir: string, plugins: string[]): void {\n const dependencies: Record<string, string> = {};\n for (const spec of plugins) {\n const { name, range } = parseSpec(spec);\n dependencies[name] = range;\n }\n const pkg = {\n name: \"skaile-project-plugins\",\n private: true,\n dependencies,\n };\n mkdirSync(pluginsDir(projectDir), { recursive: true });\n writeFileSync(pluginsPkgJson(projectDir), `${JSON.stringify(pkg, null, 2)}\\n`);\n}\n\n/**\n * Reconcile the plugin store for a project.\n *\n * @param projectDir - Project root containing `skaile.yaml` / `skaile.lock.yaml`.\n * @param plugins - The `skaile.yaml` `plugins:` list (npm specifiers).\n * @param opts - Optional injectable installer + lock slice override.\n * @returns Whether the store changed and why.\n */\nexport async function reconcilePlugins(\n projectDir: string,\n plugins: string[],\n opts: ReconcileOptions = {},\n): Promise<ReconcileResult> {\n if (plugins.length === 0) {\n return { changed: false, reason: \"no-plugins\" };\n }\n\n const lockSlice = opts.lockSlice ?? readPluginsLockSlice(projectDir);\n const wantHash = createHash(\"sha256\")\n .update(JSON.stringify({ plugins: [...plugins].sort(), lock: lockSlice }))\n .digest(\"hex\");\n\n const hashFile = reconcileHashFile(projectDir);\n if (existsSync(hashFile)) {\n const have = readFileSync(hashFile, \"utf8\").trim();\n if (have === wantHash) {\n return { changed: false, reason: \"up-to-date\" };\n }\n }\n\n writePackageJson(projectDir, plugins);\n\n const install = opts.runInstall ?? defaultInstall;\n const result = await install(pluginsDir(projectDir));\n if (!result.ok) {\n throw new Error(`plugin install failed:\\n${result.output}`);\n }\n\n writeFileSync(hashFile, wantHash);\n return { changed: true, reason: \"reconciled\" };\n}\n","/**\n * The project-local plugin store: reconcile (`<projectDir>/.skaile/plugins/`)\n * then load the reconciled plugins into the `pluginRegistry`.\n *\n * `ensurePluginsLoaded` is the single entrypoint commands wire in. It is a\n * guarded no-op when `plugins` is empty/undefined — zero overhead for the\n * common case where no project declares `plugins:` in `skaile.yaml`.\n */\n\nimport { type PluginRegistry, pluginRegistry } from \"@skaile/workspaces/plugin-registry\";\nimport type { Logger } from \"@skaile/workspaces/types\";\nimport { type LoadResult, loadPlugins } from \"./load.js\";\nimport { type ReconcileOptions, reconcilePlugins } from \"./reconcile.js\";\n\nexport type { LoadOptions, LoadResult } from \"./load.js\";\nexport { loadPlugins } from \"./load.js\";\nexport {\n lockPath,\n nodeModulesDir,\n pluginsDir,\n pluginsPkgJson,\n reconcileHashFile,\n resolvePluginEntry,\n} from \"./paths.js\";\nexport type { InstallFn, ReconcileOptions, ReconcileResult } from \"./reconcile.js\";\nexport { defaultInstall, reconcilePlugins } from \"./reconcile.js\";\nexport type { PluginSpec } from \"./spec.js\";\nexport { parseSpec, specName } from \"./spec.js\";\n\n/** Options for {@link ensurePluginsLoaded}. */\nexport interface EnsurePluginsOptions extends ReconcileOptions {\n log?: Logger;\n}\n\n/**\n * Reconcile the plugin store then load each plugin into `registry`.\n *\n * No-op (returns immediately) when `plugins` is empty/undefined, so the common\n * no-plugins path costs nothing.\n *\n * @param projectDir - Project root.\n * @param plugins - The `skaile.yaml` `plugins:` list (may be undefined).\n * @param registry - Registry to register into. Defaults to `pluginRegistry`.\n * @param opts - Injectable installer / lock slice + optional logger.\n * @returns The load result, or an empty result when there are no plugins.\n */\nexport async function ensurePluginsLoaded(\n projectDir: string,\n plugins: string[] | undefined,\n registry: PluginRegistry = pluginRegistry,\n opts: EnsurePluginsOptions = {},\n): Promise<LoadResult> {\n if (!plugins || plugins.length === 0) {\n return { loaded: [], failed: [] };\n }\n await reconcilePlugins(projectDir, plugins, opts);\n return loadPlugins(projectDir, plugins, registry, { log: opts.log });\n}\n"]}
1
+ {"version":3,"sources":["../cli/src/plugin-store/paths.ts","../cli/src/plugin-store/spec.ts","../cli/src/plugin-store/load.ts","../cli/src/plugin-store/reconcile.ts","../cli/src/plugin-store/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAUO,SAAS,WAAW,UAAA,EAA4B;AACrD,EAAA,OAAO,IAAA,CAAK,UAAA,EAAY,SAAA,EAAW,SAAS,CAAA;AAC9C;AAGO,SAAS,eAAe,UAAA,EAA4B;AACzD,EAAA,OAAO,IAAA,CAAK,UAAA,CAAW,UAAU,CAAA,EAAG,cAAc,CAAA;AACpD;AAGO,SAAS,eAAe,UAAA,EAA4B;AACzD,EAAA,OAAO,IAAA,CAAK,UAAA,CAAW,UAAU,CAAA,EAAG,cAAc,CAAA;AACpD;AAGO,SAAS,kBAAkB,UAAA,EAA4B;AAC5D,EAAA,OAAO,IAAA,CAAK,UAAA,CAAW,UAAU,CAAA,EAAG,iBAAiB,CAAA;AACvD;AAGO,SAAS,SAAS,UAAA,EAA4B;AACnD,EAAA,OAAO,IAAA,CAAK,YAAY,kBAAkB,CAAA;AAC5C;AAOO,SAAS,kBAAA,CAAmB,YAAoB,OAAA,EAAyB;AAC9E,EAAA,OAAO,IAAA,CAAK,cAAA,CAAe,UAAU,CAAA,EAAG,OAAO,CAAA;AACjD;;;AClBO,SAAS,UAAU,IAAA,EAA0B;AAClD,EAAA,MAAM,OAAA,GAAU,KAAK,IAAA,EAAK;AAC1B,EAAA,IAAI,CAAC,OAAA,EAAS,MAAM,IAAI,MAAM,4BAA4B,CAAA;AAI1D,EAAA,MAAM,EAAA,GAAK,OAAA,CAAQ,WAAA,CAAY,GAAG,CAAA;AAClC,EAAA,IAAI,MAAM,CAAA,EAAG;AACX,IAAA,OAAO,EAAE,IAAA,EAAM,OAAA,EAAS,KAAA,EAAO,GAAA,EAAI;AAAA,EACrC;AACA,EAAA,MAAM,IAAA,GAAO,OAAA,CAAQ,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA;AAChC,EAAA,MAAM,KAAA,GAAQ,OAAA,CAAQ,KAAA,CAAM,EAAA,GAAK,CAAC,CAAA;AAClC,EAAA,OAAO,EAAE,IAAA,EAAM,KAAA,EAAO,MAAM,MAAA,GAAS,CAAA,GAAI,QAAQ,GAAA,EAAI;AACvD;AAGO,SAAS,SAAS,IAAA,EAAsB;AAC7C,EAAA,OAAO,SAAA,CAAU,IAAI,CAAA,CAAE,IAAA;AACzB;;;ACDA,eAAsB,YACpB,UAAA,EACA,OAAA,EACA,WAA2B,cAAA,EAC3B,IAAA,GAAoB,EAAC,EACA;AACrB,EAAA,MAAM,SAAmB,EAAC;AAC1B,EAAA,MAAM,SAA4C,EAAC;AAEnD,EAAA,KAAA,MAAW,QAAQ,OAAA,EAAS;AAC1B,IAAA,IAAI;AACF,MAAA,MAAM,EAAE,IAAA,EAAK,GAAI,SAAA,CAAU,IAAI,CAAA;AAC/B,MAAA,MAAM,KAAA,GAAQ,kBAAA,CAAmB,UAAA,EAAY,IAAI,CAAA;AACjD,MAAA,MAAM,GAAA,GAAO,MAAM,OAAO,aAAA,CAAc,KAAK,CAAA,CAAE,IAAA,CAAA;AAC/C,MAAA,IAAI,OAAO,GAAA,CAAI,QAAA,KAAa,UAAA,EAAY;AACtC,QAAA,MAAM,IAAI,KAAA,CAAM,CAAA,QAAA,EAAW,IAAI,CAAA,uCAAA,CAAyC,CAAA;AAAA,MAC1E;AACA,MAAA,GAAA,CAAI,SAAS,QAAQ,CAAA;AACrB,MAAA,MAAA,CAAO,KAAK,IAAI,CAAA;AAAA,IAClB,SAAS,GAAA,EAAK;AACZ,MAAA,MAAM,UAAU,GAAA,YAAe,KAAA,GAAQ,GAAA,CAAI,OAAA,GAAU,OAAO,GAAG,CAAA;AAC/D,MAAA,MAAA,CAAO,IAAA,CAAK,EAAE,IAAA,EAAM,KAAA,EAAO,0BAA0B,IAAI,CAAA,GAAA,EAAM,OAAO,CAAA,CAAA,EAAI,CAAA;AAC1E,MAAA,IAAA,CAAK,GAAA,EAAK,KAAK,CAAA,oBAAA,EAAuB,IAAI,IAAI,EAAE,KAAA,EAAO,SAAS,CAAA;AAAA,IAClE;AAAA,EACF;AAEA,EAAA,OAAO,EAAE,QAAQ,MAAA,EAAO;AAC1B;ACrBO,IAAM,cAAA,GAA4B,OAAO,GAAA,KAAQ;AACtD,EAAA,MAAM,EAAE,aAAA,EAAc,GAAI,MAAM,OAAO,iBAAyB,CAAA;AAChE,EAAA,MAAM,OAAA,GACJ,UAAA,CAAW,CAAA,EAAG,GAAG,WAAW,CAAA,IAC5B,UAAA,CAAW,CAAA,EAAG,GAAG,CAAA,UAAA,CAAY,CAAA,IAC7B,UAAA,CAAW,CAAA,EAAG,GAAG,CAAA,kBAAA,CAAoB,CAAA;AACvC,EAAA,MAAM,IAAA,GAAO,UAAU,CAAC,KAAA,EAAO,WAAW,mBAAmB,CAAA,GAAI,CAAC,KAAA,EAAO,SAAS,CAAA;AAClF,EAAA,MAAM,OAAO,aAAA,CAAc,IAAA,EAAM,EAAE,GAAA,EAAK,KAAK,CAAA;AAC7C,EAAA,MAAM,SAAmB,EAAC;AAC1B,EAAA,MAAM,OAAA,GAAU,IAAI,WAAA,EAAY;AAChC,EAAA,MAAM,IAAA,GAAO,OAAO,MAAA,KAAuC;AACzD,IAAA,MAAM,MAAA,GAAS,OAAO,SAAA,EAAU;AAChC,IAAA,WAAS;AACP,MAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,MAAM,OAAO,IAAA,EAAK;AAC1C,MAAA,IAAI,IAAA,EAAM;AACV,MAAA,IAAI,KAAA,EAAO,MAAA,CAAO,IAAA,CAAK,OAAA,CAAQ,MAAA,CAAO,OAAO,EAAE,MAAA,EAAQ,IAAA,EAAM,CAAC,CAAA;AAAA,IAChE;AAAA,EACF,CAAA;AACA,EAAA,MAAM,OAAA,CAAQ,GAAA,CAAI,CAAC,IAAA,CAAK,IAAA,CAAK,MAAM,CAAA,EAAG,IAAA,CAAK,IAAA,CAAK,MAAM,CAAC,CAAC,CAAA;AACxD,EAAA,MAAM,IAAA,GAAO,MAAM,IAAA,CAAK,MAAA;AACxB,EAAA,OAAO,EAAE,IAAI,IAAA,KAAS,CAAA,EAAG,QAAQ,MAAA,CAAO,IAAA,CAAK,EAAE,CAAA,EAAE;AACnD;AAGA,SAAS,gBAAA,CAAiB,YAAoB,OAAA,EAAyB;AACrE,EAAA,MAAM,eAAuC,EAAC;AAC9C,EAAA,KAAA,MAAW,QAAQ,OAAA,EAAS;AAC1B,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,UAAU,IAAI,CAAA;AACtC,IAAA,YAAA,CAAa,IAAI,CAAA,GAAI,KAAA;AAAA,EACvB;AACA,EAAA,MAAM,GAAA,GAAM;AAAA,IACV,IAAA,EAAM,wBAAA;AAAA,IACN,OAAA,EAAS,IAAA;AAAA,IACT;AAAA,GACF;AACA,EAAA,SAAA,CAAU,WAAW,UAAU,CAAA,EAAG,EAAE,SAAA,EAAW,MAAM,CAAA;AACrD,EAAA,aAAA,CAAc,cAAA,CAAe,UAAU,CAAA,EAAG,CAAA,EAAG,KAAK,SAAA,CAAU,GAAA,EAAK,IAAA,EAAM,CAAC,CAAC;AAAA,CAAI,CAAA;AAC/E;AAUA,eAAsB,gBAAA,CACpB,UAAA,EACA,OAAA,EACA,IAAA,GAAyB,EAAC,EACA;AAC1B,EAAA,IAAI,OAAA,CAAQ,WAAW,CAAA,EAAG;AACxB,IAAA,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,MAAA,EAAQ,YAAA,EAAa;AAAA,EAChD;AAEA,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,SAAA,IAAa,oBAAA,CAAqB,UAAU,CAAA;AACnE,EAAA,MAAM,QAAA,GAAW,WAAW,QAAQ,CAAA,CACjC,OAAO,IAAA,CAAK,SAAA,CAAU,EAAE,OAAA,EAAS,CAAC,GAAG,OAAO,CAAA,CAAE,MAAK,EAAG,IAAA,EAAM,WAAW,CAAC,CAAA,CACxE,MAAA,CAAO,KAAK,CAAA;AAEf,EAAA,MAAM,QAAA,GAAW,kBAAkB,UAAU,CAAA;AAC7C,EAAA,IAAI,UAAA,CAAW,QAAQ,CAAA,EAAG;AACxB,IAAA,MAAM,IAAA,GAAO,YAAA,CAAa,QAAA,EAAU,MAAM,EAAE,IAAA,EAAK;AACjD,IAAA,IAAI,SAAS,QAAA,EAAU;AACrB,MAAA,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,MAAA,EAAQ,YAAA,EAAa;AAAA,IAChD;AAAA,EACF;AAEA,EAAA,gBAAA,CAAiB,YAAY,OAAO,CAAA;AAEpC,EAAA,MAAM,OAAA,GAAU,KAAK,UAAA,IAAc,cAAA;AACnC,EAAA,MAAM,MAAA,GAAS,MAAM,OAAA,CAAQ,UAAA,CAAW,UAAU,CAAC,CAAA;AACnD,EAAA,IAAI,CAAC,OAAO,EAAA,EAAI;AACd,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA;AAAA,EAA2B,MAAA,CAAO,MAAM,CAAA,CAAE,CAAA;AAAA,EAC5D;AAEA,EAAA,aAAA,CAAc,UAAU,QAAQ,CAAA;AAChC,EAAA,OAAO,EAAE,OAAA,EAAS,IAAA,EAAM,MAAA,EAAQ,YAAA,EAAa;AAC/C;;;AC/EA,eAAsB,oBACpB,UAAA,EACA,OAAA,EACA,WAA2B,cAAA,EAC3B,IAAA,GAA6B,EAAC,EACT;AACrB,EAAA,IAAI,CAAC,OAAA,IAAW,OAAA,CAAQ,MAAA,KAAW,CAAA,EAAG;AACpC,IAAA,OAAO,EAAE,MAAA,EAAQ,EAAC,EAAG,MAAA,EAAQ,EAAC,EAAE;AAAA,EAClC;AACA,EAAA,MAAM,gBAAA,CAAiB,UAAA,EAAY,OAAA,EAAS,IAAI,CAAA;AAChD,EAAA,OAAO,WAAA,CAAY,YAAY,OAAA,EAAS,QAAA,EAAU,EAAE,GAAA,EAAK,IAAA,CAAK,KAAK,CAAA;AACrE","file":"plugin-store-IZ5SCRAV.js","sourcesContent":["/**\n * Pure path helpers for the project-local plugin store.\n *\n * The store is a self-contained npm workspace owned by the CLI under\n * `<projectDir>/.skaile/plugins/`. Nothing here touches the filesystem.\n */\n\nimport { join } from \"node:path\";\n\n/** `<projectDir>/.skaile/plugins` — the store root. */\nexport function pluginsDir(projectDir: string): string {\n return join(projectDir, \".skaile\", \"plugins\");\n}\n\n/** `<store>/package.json` — generated, never user-edited. */\nexport function pluginsPkgJson(projectDir: string): string {\n return join(pluginsDir(projectDir), \"package.json\");\n}\n\n/** `<store>/node_modules` — where reconciled plugin packages land. */\nexport function nodeModulesDir(projectDir: string): string {\n return join(pluginsDir(projectDir), \"node_modules\");\n}\n\n/** `<store>/.reconcile-hash` — SHA of plugins-list + lock slice; skip reinstall when unchanged. */\nexport function reconcileHashFile(projectDir: string): string {\n return join(pluginsDir(projectDir), \".reconcile-hash\");\n}\n\n/** `<projectDir>/skaile.lock.yaml` — the project lock file. */\nexport function lockPath(projectDir: string): string {\n return join(projectDir, \"skaile.lock.yaml\");\n}\n\n/**\n * Absolute path to a plugin package's entry directory under the store's\n * `node_modules`. Dynamic `import()` against this absolute path works inside\n * compiled binaries via `pathToFileURL`.\n */\nexport function resolvePluginEntry(projectDir: string, pkgName: string): string {\n return join(nodeModulesDir(projectDir), pkgName);\n}\n","/**\n * Parse npm package specifiers from the `plugins:` list into name + range.\n *\n * The leading `@` of a scope is NOT a separator: only the last `@` at a\n * non-zero index splits the package name from its semver range.\n * \"@skaile/provider-fly@^0.1.0\" → { name: \"@skaile/provider-fly\", range: \"^0.1.0\" }\n * \"@skaile/connector-redis\" → { name: \"@skaile/connector-redis\", range: \"*\" }\n * \"lodash@^4\" → { name: \"lodash\", range: \"^4\" }\n */\n\n/** A parsed plugin specifier: package name plus a semver range (`\"*\"` when omitted). */\nexport interface PluginSpec {\n name: string;\n range: string;\n}\n\n/**\n * Parse a single plugin specifier into `{ name, range }`.\n *\n * @param spec - An npm specifier, e.g. `\"@skaile/provider-fly@^0.1.0\"` or `\"lodash\"`.\n * @returns The package name and semver range (range defaults to `\"*\"`).\n * @throws Error when the specifier is empty.\n */\nexport function parseSpec(spec: string): PluginSpec {\n const trimmed = spec.trim();\n if (!trimmed) throw new Error(\"parseSpec: empty specifier\");\n\n // Find the version-separating `@` — the last one that is not the scope `@`\n // at index 0. A bare `@scope/name` has its only `@` at index 0 (no range).\n const at = trimmed.lastIndexOf(\"@\");\n if (at <= 0) {\n return { name: trimmed, range: \"*\" };\n }\n const name = trimmed.slice(0, at);\n const range = trimmed.slice(at + 1);\n return { name, range: range.length > 0 ? range : \"*\" };\n}\n\n/** Convenience: just the package name of a specifier. */\nexport function specName(spec: string): string {\n return parseSpec(spec).name;\n}\n","/**\n * Runtime plugin loader: dynamic-import each reconciled plugin and let it\n * self-register into the `pluginRegistry`.\n *\n * Each plugin specifier resolves to an absolute path under the store's\n * `node_modules`; we import it via a `file://` URL so the import works inside\n * `bun --compile` binaries (which bundle only the literal-string switches, but\n * can still execute a `file://` import against the unpacked store on disk).\n * Failures are caught per-plugin so one broken plugin never aborts the rest.\n */\n\nimport { pathToFileURL } from \"node:url\";\nimport { type PluginRegistry, pluginRegistry } from \"@skaile/workspaces/plugin-registry\";\nimport type { Logger } from \"@skaile/workspaces/types\";\nimport { resolvePluginEntry } from \"./paths.js\";\nimport { parseSpec } from \"./spec.js\";\n\n/** Options for {@link loadPlugins}. */\nexport interface LoadOptions {\n log?: Logger;\n}\n\n/** Result of a load pass: which specs registered and which failed. */\nexport interface LoadResult {\n loaded: string[];\n failed: { spec: string; error: string }[];\n}\n\n/** The self-registration entrypoint a plugin module is expected to export. */\ntype PluginModule = { register?: (registry: PluginRegistry) => void };\n\n/**\n * Load and register each plugin in `plugins` into `registry`.\n *\n * @param projectDir - Project root holding `.skaile/plugins/node_modules`.\n * @param plugins - The `skaile.yaml` `plugins:` list (npm specifiers).\n * @param registry - Registry to register into. Defaults to the process-wide `pluginRegistry`.\n * @param opts - Optional logger.\n * @returns Loaded specs + per-plugin failures (never throws).\n */\nexport async function loadPlugins(\n projectDir: string,\n plugins: string[],\n registry: PluginRegistry = pluginRegistry,\n opts: LoadOptions = {},\n): Promise<LoadResult> {\n const loaded: string[] = [];\n const failed: { spec: string; error: string }[] = [];\n\n for (const spec of plugins) {\n try {\n const { name } = parseSpec(spec);\n const entry = resolvePluginEntry(projectDir, name);\n const mod = (await import(pathToFileURL(entry).href)) as PluginModule;\n if (typeof mod.register !== \"function\") {\n throw new Error(`plugin \"${name}\" does not export a register() function`);\n }\n mod.register(registry);\n loaded.push(spec);\n } catch (err) {\n const message = err instanceof Error ? err.message : String(err);\n failed.push({ spec, error: `failed to load plugin \"${spec}\": ${message}` });\n opts.log?.warn(`plugin load failed: ${spec}`, { error: message });\n }\n }\n\n return { loaded, failed };\n}\n","/**\n * Reconcile the project-local plugin store (`<projectDir>/.skaile/plugins/`).\n *\n * The reconciler is hash-skipped: it computes a SHA-256 over the sorted plugin\n * list plus the lock file's `plugins` slice and compares it to the stored\n * `.reconcile-hash`. On a match it returns with zero further I/O; otherwise it\n * regenerates the store's `package.json` and runs `bun install` against it.\n *\n * The install step is injectable (`InstallFn`) so tests stay hermetic — they\n * pass a fake installer that records calls and writes a stub `node_modules`.\n */\n\nimport { createHash } from \"node:crypto\";\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from \"node:fs\";\nimport { readPluginsLockSlice } from \"@skaile/workspaces/core\";\nimport { pluginsDir, pluginsPkgJson, reconcileHashFile } from \"./paths.js\";\nimport { parseSpec } from \"./spec.js\";\n\n/**\n * Installs the store's dependencies. Returns `ok: false` (never throws) on a\n * failed install so the reconciler can surface the captured `output`.\n */\nexport type InstallFn = (pluginsDir: string) => Promise<{ ok: boolean; output: string }>;\n\n/** Options for {@link reconcilePlugins}. */\nexport interface ReconcileOptions {\n /** Injectable installer. Defaults to a real `bun install` of the store. */\n runInstall?: InstallFn;\n /**\n * Lock slice to fold into the reconcile-hash. Defaults to\n * `readPluginsLockSlice(projectDir)` so a lock edit invalidates the hash.\n */\n lockSlice?: unknown;\n}\n\n/** Result of a reconcile pass. */\nexport interface ReconcileResult {\n changed: boolean;\n reason: \"no-plugins\" | \"up-to-date\" | \"reconciled\";\n}\n\n/**\n * The default real installer: `bun install` inside the store directory.\n * Frozen on subsequent runs (a `bun.lock`/`bun.lockb` already exists), and\n * non-frozen on the first run so a lock can be generated.\n */\nexport const defaultInstall: InstallFn = async (dir) => {\n const { portableSpawn } = await import(\"@skaile/workspaces/core\");\n const hasLock =\n existsSync(`${dir}/bun.lock`) ||\n existsSync(`${dir}/bun.lockb`) ||\n existsSync(`${dir}/package-lock.json`);\n const args = hasLock ? [\"bun\", \"install\", \"--frozen-lockfile\"] : [\"bun\", \"install\"];\n const proc = portableSpawn(args, { cwd: dir });\n const chunks: string[] = [];\n const decoder = new TextDecoder();\n const pump = async (stream: ReadableStream<Uint8Array>) => {\n const reader = stream.getReader();\n for (;;) {\n const { done, value } = await reader.read();\n if (done) break;\n if (value) chunks.push(decoder.decode(value, { stream: true }));\n }\n };\n await Promise.all([pump(proc.stdout), pump(proc.stderr)]);\n const code = await proc.exited;\n return { ok: code === 0, output: chunks.join(\"\") };\n};\n\n/** Generate the store's `package.json` from the plugin specs. */\nfunction writePackageJson(projectDir: string, plugins: string[]): void {\n const dependencies: Record<string, string> = {};\n for (const spec of plugins) {\n const { name, range } = parseSpec(spec);\n dependencies[name] = range;\n }\n const pkg = {\n name: \"skaile-project-plugins\",\n private: true,\n dependencies,\n };\n mkdirSync(pluginsDir(projectDir), { recursive: true });\n writeFileSync(pluginsPkgJson(projectDir), `${JSON.stringify(pkg, null, 2)}\\n`);\n}\n\n/**\n * Reconcile the plugin store for a project.\n *\n * @param projectDir - Project root containing `skaile.yaml` / `skaile.lock.yaml`.\n * @param plugins - The `skaile.yaml` `plugins:` list (npm specifiers).\n * @param opts - Optional injectable installer + lock slice override.\n * @returns Whether the store changed and why.\n */\nexport async function reconcilePlugins(\n projectDir: string,\n plugins: string[],\n opts: ReconcileOptions = {},\n): Promise<ReconcileResult> {\n if (plugins.length === 0) {\n return { changed: false, reason: \"no-plugins\" };\n }\n\n const lockSlice = opts.lockSlice ?? readPluginsLockSlice(projectDir);\n const wantHash = createHash(\"sha256\")\n .update(JSON.stringify({ plugins: [...plugins].sort(), lock: lockSlice }))\n .digest(\"hex\");\n\n const hashFile = reconcileHashFile(projectDir);\n if (existsSync(hashFile)) {\n const have = readFileSync(hashFile, \"utf8\").trim();\n if (have === wantHash) {\n return { changed: false, reason: \"up-to-date\" };\n }\n }\n\n writePackageJson(projectDir, plugins);\n\n const install = opts.runInstall ?? defaultInstall;\n const result = await install(pluginsDir(projectDir));\n if (!result.ok) {\n throw new Error(`plugin install failed:\\n${result.output}`);\n }\n\n writeFileSync(hashFile, wantHash);\n return { changed: true, reason: \"reconciled\" };\n}\n","/**\n * The project-local plugin store: reconcile (`<projectDir>/.skaile/plugins/`)\n * then load the reconciled plugins into the `pluginRegistry`.\n *\n * `ensurePluginsLoaded` is the single entrypoint commands wire in. It is a\n * guarded no-op when `plugins` is empty/undefined — zero overhead for the\n * common case where no project declares `plugins:` in `skaile.yaml`.\n */\n\nimport { type PluginRegistry, pluginRegistry } from \"@skaile/workspaces/plugin-registry\";\nimport type { Logger } from \"@skaile/workspaces/types\";\nimport { type LoadResult, loadPlugins } from \"./load.js\";\nimport { type ReconcileOptions, reconcilePlugins } from \"./reconcile.js\";\n\nexport type { LoadOptions, LoadResult } from \"./load.js\";\nexport { loadPlugins } from \"./load.js\";\nexport {\n lockPath,\n nodeModulesDir,\n pluginsDir,\n pluginsPkgJson,\n reconcileHashFile,\n resolvePluginEntry,\n} from \"./paths.js\";\nexport type { InstallFn, ReconcileOptions, ReconcileResult } from \"./reconcile.js\";\nexport { defaultInstall, reconcilePlugins } from \"./reconcile.js\";\nexport type { PluginSpec } from \"./spec.js\";\nexport { parseSpec, specName } from \"./spec.js\";\n\n/** Options for {@link ensurePluginsLoaded}. */\nexport interface EnsurePluginsOptions extends ReconcileOptions {\n log?: Logger;\n}\n\n/**\n * Reconcile the plugin store then load each plugin into `registry`.\n *\n * No-op (returns immediately) when `plugins` is empty/undefined, so the common\n * no-plugins path costs nothing.\n *\n * @param projectDir - Project root.\n * @param plugins - The `skaile.yaml` `plugins:` list (may be undefined).\n * @param registry - Registry to register into. Defaults to `pluginRegistry`.\n * @param opts - Injectable installer / lock slice + optional logger.\n * @returns The load result, or an empty result when there are no plugins.\n */\nexport async function ensurePluginsLoaded(\n projectDir: string,\n plugins: string[] | undefined,\n registry: PluginRegistry = pluginRegistry,\n opts: EnsurePluginsOptions = {},\n): Promise<LoadResult> {\n if (!plugins || plugins.length === 0) {\n return { loaded: [], failed: [] };\n }\n await reconcilePlugins(projectDir, plugins, opts);\n return loadPlugins(projectDir, plugins, registry, { log: opts.log });\n}\n"]}
@@ -1,5 +1,5 @@
1
- export { CLAUDE_CODE_CREDENTIALS_KEY, COMPILE_MANIFEST_FILENAME, CapabilityRegistry, DEFAULT_CAPABILITY_CALL_TIMEOUT_MS, DEFAULT_COALESCE_MS, MarkdownStreamer, PreInitRingSink, agentDefinitionExists, bootstrapCapabilityRegistry, bootstrapRunnerLogStore, buildAgentResources, buildClientCapabilityHandler, buildContextSection, buildEnvironmentSection, builtinCapabilities, clearPreInitRingSink, clearSession, compileComposition, computeCapabilitySignature, createAgentSession, createSessionStimulusBus, defineCapability, deleteSession, emitSystemPromptComposed, ensureGitConfigInclude, extractClaudeAiOauthExpiresAt, getPreInitRingSink, handleMountResourceRequest, handleResourceRequest, installPreInitRingSink, listSessions, loadAgentManifest, loadCompileManifest, loadCompileManifestFromDir, loadSession, loadSessionById, newSession, registerCompositionCapabilities, rejectCapabilityOnApprovalDeny, resetRunnerLogStore, resolveAgentComposition, resolveAgentMixins, resolveBinding, resolveCapabilityCallTimeoutMs, resolveCapabilityResult, resolveComposition, resolveMixin, runAgentChat, saveSession, setCurrentSession, startAgentServer, touchSession, writeClaudeCodeCredentialsFile } from '../chunk-SKXCTV55.js';
2
- import '../chunk-NDD5VMN5.js';
1
+ export { CLAUDE_CODE_CREDENTIALS_KEY, COMPILE_MANIFEST_FILENAME, CapabilityRegistry, DEFAULT_CAPABILITY_CALL_TIMEOUT_MS, DEFAULT_COALESCE_MS, MarkdownStreamer, PreInitRingSink, agentDefinitionExists, bootstrapCapabilityRegistry, bootstrapRunnerLogStore, buildAgentResources, buildClientCapabilityHandler, buildContextSection, buildEnvironmentSection, builtinCapabilities, clearPreInitRingSink, clearSession, compileComposition, computeCapabilitySignature, createAgentSession, createSessionStimulusBus, defineCapability, deleteSession, emitSystemPromptComposed, ensureGitConfigInclude, extractClaudeAiOauthExpiresAt, getPreInitRingSink, handleMountResourceRequest, handleResourceRequest, installPreInitRingSink, listSessions, loadAgentManifest, loadCompileManifest, loadCompileManifestFromDir, loadSession, loadSessionById, newSession, registerCompositionCapabilities, rejectCapabilityOnApprovalDeny, resetRunnerLogStore, resolveAgentComposition, resolveAgentMixins, resolveBinding, resolveCapabilityCallTimeoutMs, resolveCapabilityResult, resolveComposition, resolveMixin, runAgentChat, saveSession, setCurrentSession, startAgentServer, touchSession, writeClaudeCodeCredentialsFile } from '../chunk-DZCFFTAX.js';
2
+ import '../chunk-OVQZ5OKL.js';
3
3
  import '../chunk-X5YPJV4N.js';
4
4
  import '../chunk-O7SG5PC2.js';
5
5
  import '../chunk-7QBNJTTQ.js';
@@ -14,21 +14,21 @@ import '../chunk-KOVLSBXK.js';
14
14
  import '../chunk-RRVQAE5D.js';
15
15
  import '../chunk-6VTG73UY.js';
16
16
  import '../chunk-LV2HPH3C.js';
17
- import '../chunk-OJN25VJO.js';
18
- import '../chunk-NBJ5TOEC.js';
19
- import '../chunk-6MB7CRME.js';
17
+ import '../chunk-E4UJ7CVK.js';
18
+ import '../chunk-ODPII24X.js';
19
+ import '../chunk-QMONOHXT.js';
20
20
  import '../chunk-QAVZOJCV.js';
21
21
  import '../chunk-6E6PKKAD.js';
22
22
  import '../chunk-ICS76R4T.js';
23
23
  import '../chunk-GZWJGNNN.js';
24
24
  import '../chunk-FVTV7M76.js';
25
- export { globalSettingsPath, loadSettings, mapLegacyFields, projectSettingsPath, resolveSettings, saveSettings } from '../chunk-ETMUGBHF.js';
25
+ export { globalSettingsPath, loadSettings, mapLegacyFields, projectSettingsPath, resolveSettings, saveSettings } from '../chunk-Z3M5K67G.js';
26
26
  export { DRIVER_DEFAULTS, resolveDriverPaths } from '../chunk-K5GBV4SA.js';
27
27
  import '../chunk-KLNL7QHN.js';
28
- import '../chunk-PFOXL4SH.js';
29
- import '../chunk-V5TBKO5Q.js';
30
- import '../chunk-K7WPR77X.js';
31
- import '../chunk-VUCPJBAG.js';
28
+ import '../chunk-5ESCS2OS.js';
29
+ import '../chunk-542K7SR6.js';
30
+ import '../chunk-DH4N5AW4.js';
31
+ import '../chunk-YX3UWPJ5.js';
32
32
  import '../chunk-JKNWJ64A.js';
33
33
  export { DRIVER_TARGETS, SUPPORTED_DRIVER_TARGETS } from '../chunk-O4JH3KUE.js';
34
34
  import '../chunk-24UIWON4.js';
@@ -1,12 +1,12 @@
1
- export { AssetManager } from '../chunk-7HSXUKNB.js';
2
- export { createScaffold, deployAll, installAgent, removeAsset } from '../chunk-2RYQERIT.js';
3
- import '../chunk-ETMUGBHF.js';
1
+ export { AssetManager, parseCanonicalLockKey } from '../chunk-BTAC2VYT.js';
2
+ export { createScaffold, deployAll, installAgent, removeAsset } from '../chunk-2RFOFHSM.js';
3
+ import '../chunk-Z3M5K67G.js';
4
4
  import '../chunk-K5GBV4SA.js';
5
5
  import '../chunk-KLNL7QHN.js';
6
- import '../chunk-PFOXL4SH.js';
7
- import '../chunk-V5TBKO5Q.js';
8
- import '../chunk-K7WPR77X.js';
9
- import '../chunk-VUCPJBAG.js';
6
+ import '../chunk-5ESCS2OS.js';
7
+ import '../chunk-542K7SR6.js';
8
+ import '../chunk-DH4N5AW4.js';
9
+ import '../chunk-YX3UWPJ5.js';
10
10
  import '../chunk-JKNWJ64A.js';
11
11
  import '../chunk-O4JH3KUE.js';
12
12
  import '../chunk-24UIWON4.js';
package/dist/sdk/core.js CHANGED
@@ -1,10 +1,10 @@
1
- export { ALL_PROVIDERS, SETTINGS_DEFAULTS, WorkspaceYamlEditor, applyPatch, buildLockFile, computeHash, detectEnvApiKeys, extractForPatch, generatePatch, globalSettingsPath, listPatches, loadSettings, mapLegacyFields, maskApiKey, migrateSettings, portableSpawn, portableSpawnSync, projectSettingsPath, providerEnvKey, readLock, readPatch, readPluginsLockSlice, resolveAllKeys, resolveApiKey, resolveSettings, savePatch, saveSettings, verifyLock, walkForSettings, writeLock, writePluginsLockSlice } from '../chunk-ETMUGBHF.js';
1
+ export { ALL_PROVIDERS, SETTINGS_DEFAULTS, WorkspaceYamlEditor, applyPatch, buildLockFile, computeHash, detectEnvApiKeys, extractForPatch, generatePatch, globalSettingsPath, listPatches, loadSettings, mapLegacyFields, maskApiKey, migrateSettings, portableSpawn, portableSpawnSync, projectSettingsPath, providerEnvKey, readLock, readPatch, readPluginsLockSlice, resolveAllKeys, resolveApiKey, resolveSettings, savePatch, saveSettings, verifyLock, walkForSettings, writeLock, writePluginsLockSlice } from '../chunk-Z3M5K67G.js';
2
2
  export { DRIVER_DEFAULTS, resolveDriverPaths } from '../chunk-K5GBV4SA.js';
3
3
  export { detectAiResources, detectDomains, detectMonorepoRoot } from '../chunk-KLNL7QHN.js';
4
- export { BASE_ASSETS_REPO_NAME, resolveBaseAssetsRoot, resolveRuntimeAssets } from '../chunk-PFOXL4SH.js';
5
- export { COMPACTION_DEFAULTS, CanonicalRefConflictError, DEFAULT_RECIPE_ATTR, SK_WORKSPACE_DEFAULT_NAME, SK_WORKSPACE_SUFFIX, buildProvenanceIndex, checkRepoStatus, checkoutPin, cloneRepo, decodeSkaileYaml, encodeSkaileYaml, ensureRepo, findWorkspaceRoot, getGlobalCacheDir, getRepoCommit, linkRepo, listSkWorkspaceConfigs, loadMcpServerDeclarations, loadSkWorkspaceConfig, mergeSkWorkspaceConfigs, normalizeConfig, pullRepo, readLinks, resolveAgentDir, resolveAll, resolveAsset, resolveSkWorkspaceConfig, saveSkWorkspaceConfig, scanRepo, unlinkRepo, validateAssetRecipeAttr, validateAssetRecipeFlake, workspaceConfigFilename, writeLinks } from '../chunk-V5TBKO5Q.js';
6
- export { bundleDepRefs, fromAgentMd, fromAgentYaml, fromBundleYaml, fromConnectorMd, fromContractMd, fromFlowYaml, fromMcpServerMd, fromPromptMd, fromSkillMd, parseFrontmatter, parseRequires, scanDirectory, walkDir } from '../chunk-K7WPR77X.js';
7
- export { ASSET_KINDS, INDIVIDUAL_KINDS, assetRefToDep, assetRefToStr, depToStr, entryFromRaw, entryToRaw, parseAssetRef, parseDep, repositoryFromRaw, repositoryToRaw } from '../chunk-VUCPJBAG.js';
4
+ export { BASE_ASSETS_REPO_NAME, resolveBaseAssetsRoot, resolveRuntimeAssets } from '../chunk-5ESCS2OS.js';
5
+ export { COMPACTION_DEFAULTS, CanonicalRefConflictError, DEFAULT_RECIPE_ATTR, SK_WORKSPACE_DEFAULT_NAME, SK_WORKSPACE_SUFFIX, buildProvenanceIndex, checkRepoStatus, checkoutPin, cloneRepo, decodeSkaileYaml, encodeSkaileYaml, ensureRepo, findWorkspaceRoot, getGlobalCacheDir, getRepoCommit, linkRepo, listSkWorkspaceConfigs, loadMcpServerDeclarations, loadSkWorkspaceConfig, mergeSkWorkspaceConfigs, normalizeConfig, pullRepo, readLinks, resolveAgentDir, resolveAll, resolveAsset, resolveSkWorkspaceConfig, saveSkWorkspaceConfig, scanRepo, unlinkRepo, validateAssetRecipeAttr, validateAssetRecipeFlake, workspaceConfigFilename, writeLinks } from '../chunk-542K7SR6.js';
6
+ export { bundleDepRefs, fromAgentMd, fromAgentYaml, fromBundleYaml, fromConnectorMd, fromContractMd, fromFlowYaml, fromMcpServerMd, fromPromptMd, fromSkillMd, parseFrontmatter, parseRequires, scanDirectory, walkDir } from '../chunk-DH4N5AW4.js';
7
+ export { ASSET_KINDS, INDIVIDUAL_KINDS, assetRefToDep, assetRefToStr, depToStr, entryFromRaw, entryToRaw, parseAssetRef, parseDep, repositoryFromRaw, repositoryToRaw } from '../chunk-YX3UWPJ5.js';
8
8
  export { deployedBase, deployedDir, isDeployed } from '../chunk-JKNWJ64A.js';
9
9
  export { DRIVER_TARGETS, SUPPORTED_DRIVER_TARGETS } from '../chunk-O4JH3KUE.js';
10
10
  export { LogStore, LogStoreDisabledError, NoOpSink, OnLogBridgeSink, SqliteSink, StdoutSink, WsLogSink, createLogStoreFromConfig, createLogger, getLogStore, normalizeError, openSqlite, registerLogStore, resetLogStore, resolveLogStoreConfig, sanitizeData } from '../chunk-24UIWON4.js';
package/dist/sdk/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { AgentClient } from '../chunk-SZ3SIVZQ.js';
2
- import { startAgentServer } from '../chunk-SKXCTV55.js';
3
- import '../chunk-NDD5VMN5.js';
2
+ import { startAgentServer } from '../chunk-DZCFFTAX.js';
3
+ import '../chunk-OVQZ5OKL.js';
4
4
  import '../chunk-X5YPJV4N.js';
5
5
  import '../chunk-O7SG5PC2.js';
6
6
  import '../chunk-7QBNJTTQ.js';
@@ -15,21 +15,21 @@ import '../chunk-KOVLSBXK.js';
15
15
  import '../chunk-RRVQAE5D.js';
16
16
  import '../chunk-6VTG73UY.js';
17
17
  import '../chunk-LV2HPH3C.js';
18
- import '../chunk-OJN25VJO.js';
19
- import '../chunk-NBJ5TOEC.js';
20
- import '../chunk-6MB7CRME.js';
18
+ import '../chunk-E4UJ7CVK.js';
19
+ import '../chunk-ODPII24X.js';
20
+ import '../chunk-QMONOHXT.js';
21
21
  import '../chunk-QAVZOJCV.js';
22
22
  import '../chunk-6E6PKKAD.js';
23
23
  import '../chunk-ICS76R4T.js';
24
24
  import '../chunk-GZWJGNNN.js';
25
25
  import '../chunk-FVTV7M76.js';
26
- import '../chunk-ETMUGBHF.js';
26
+ import '../chunk-Z3M5K67G.js';
27
27
  import '../chunk-K5GBV4SA.js';
28
28
  import '../chunk-KLNL7QHN.js';
29
- import '../chunk-PFOXL4SH.js';
30
- import '../chunk-V5TBKO5Q.js';
31
- import '../chunk-K7WPR77X.js';
32
- import '../chunk-VUCPJBAG.js';
29
+ import '../chunk-5ESCS2OS.js';
30
+ import '../chunk-542K7SR6.js';
31
+ import '../chunk-DH4N5AW4.js';
32
+ import '../chunk-YX3UWPJ5.js';
33
33
  import '../chunk-JKNWJ64A.js';
34
34
  import '../chunk-O4JH3KUE.js';
35
35
  import '../chunk-24UIWON4.js';
@@ -1,5 +1,5 @@
1
- export { CLAUDE_CODE_CREDENTIALS_KEY, COMPILE_MANIFEST_FILENAME, CapabilityRegistry, DEFAULT_CAPABILITY_CALL_TIMEOUT_MS, DEFAULT_COALESCE_MS, MarkdownStreamer, PreInitRingSink, agentDefinitionExists, bootstrapCapabilityRegistry, bootstrapRunnerLogStore, buildAgentResources, buildClientCapabilityHandler, buildContextSection, buildEnvironmentSection, builtinCapabilities, clearPreInitRingSink, clearSession, compileComposition, computeCapabilitySignature, createAgentSession, createSessionStimulusBus, defineCapability, deleteSession, emitSystemPromptComposed, ensureGitConfigInclude, extractClaudeAiOauthExpiresAt, getPreInitRingSink, handleMountResourceRequest, handleResourceRequest, installPreInitRingSink, listSessions, loadAgentManifest, loadCompileManifest, loadCompileManifestFromDir, loadSession, loadSessionById, newSession, registerCompositionCapabilities, rejectCapabilityOnApprovalDeny, resetRunnerLogStore, resolveAgentComposition, resolveAgentMixins, resolveBinding, resolveCapabilityCallTimeoutMs, resolveCapabilityResult, resolveComposition, resolveMixin, runAgentChat, saveSession, setCurrentSession, startAgentServer, touchSession, writeClaudeCodeCredentialsFile } from '../chunk-SKXCTV55.js';
2
- import '../chunk-NDD5VMN5.js';
1
+ export { CLAUDE_CODE_CREDENTIALS_KEY, COMPILE_MANIFEST_FILENAME, CapabilityRegistry, DEFAULT_CAPABILITY_CALL_TIMEOUT_MS, DEFAULT_COALESCE_MS, MarkdownStreamer, PreInitRingSink, agentDefinitionExists, bootstrapCapabilityRegistry, bootstrapRunnerLogStore, buildAgentResources, buildClientCapabilityHandler, buildContextSection, buildEnvironmentSection, builtinCapabilities, clearPreInitRingSink, clearSession, compileComposition, computeCapabilitySignature, createAgentSession, createSessionStimulusBus, defineCapability, deleteSession, emitSystemPromptComposed, ensureGitConfigInclude, extractClaudeAiOauthExpiresAt, getPreInitRingSink, handleMountResourceRequest, handleResourceRequest, installPreInitRingSink, listSessions, loadAgentManifest, loadCompileManifest, loadCompileManifestFromDir, loadSession, loadSessionById, newSession, registerCompositionCapabilities, rejectCapabilityOnApprovalDeny, resetRunnerLogStore, resolveAgentComposition, resolveAgentMixins, resolveBinding, resolveCapabilityCallTimeoutMs, resolveCapabilityResult, resolveComposition, resolveMixin, runAgentChat, saveSession, setCurrentSession, startAgentServer, touchSession, writeClaudeCodeCredentialsFile } from '../chunk-DZCFFTAX.js';
2
+ import '../chunk-OVQZ5OKL.js';
3
3
  import '../chunk-X5YPJV4N.js';
4
4
  import '../chunk-O7SG5PC2.js';
5
5
  import '../chunk-7QBNJTTQ.js';
@@ -14,21 +14,21 @@ import '../chunk-KOVLSBXK.js';
14
14
  import '../chunk-RRVQAE5D.js';
15
15
  import '../chunk-6VTG73UY.js';
16
16
  import '../chunk-LV2HPH3C.js';
17
- import '../chunk-OJN25VJO.js';
18
- import '../chunk-NBJ5TOEC.js';
19
- import '../chunk-6MB7CRME.js';
17
+ import '../chunk-E4UJ7CVK.js';
18
+ import '../chunk-ODPII24X.js';
19
+ import '../chunk-QMONOHXT.js';
20
20
  import '../chunk-QAVZOJCV.js';
21
21
  import '../chunk-6E6PKKAD.js';
22
22
  import '../chunk-ICS76R4T.js';
23
23
  import '../chunk-GZWJGNNN.js';
24
24
  import '../chunk-FVTV7M76.js';
25
- export { globalSettingsPath, loadSettings, mapLegacyFields, projectSettingsPath, resolveSettings, saveSettings } from '../chunk-ETMUGBHF.js';
25
+ export { globalSettingsPath, loadSettings, mapLegacyFields, projectSettingsPath, resolveSettings, saveSettings } from '../chunk-Z3M5K67G.js';
26
26
  export { DRIVER_DEFAULTS, resolveDriverPaths } from '../chunk-K5GBV4SA.js';
27
27
  import '../chunk-KLNL7QHN.js';
28
- import '../chunk-PFOXL4SH.js';
29
- import '../chunk-V5TBKO5Q.js';
30
- import '../chunk-K7WPR77X.js';
31
- import '../chunk-VUCPJBAG.js';
28
+ import '../chunk-5ESCS2OS.js';
29
+ import '../chunk-542K7SR6.js';
30
+ import '../chunk-DH4N5AW4.js';
31
+ import '../chunk-YX3UWPJ5.js';
32
32
  import '../chunk-JKNWJ64A.js';
33
33
  export { DRIVER_TARGETS, SUPPORTED_DRIVER_TARGETS } from '../chunk-O4JH3KUE.js';
34
34
  import '../chunk-24UIWON4.js';
@@ -4,13 +4,13 @@ import { getModels } from './chunk-KOVLSBXK.js';
4
4
  import './chunk-RRVQAE5D.js';
5
5
  import './chunk-6VTG73UY.js';
6
6
  import './chunk-6E6PKKAD.js';
7
- import { ALL_PROVIDERS, detectEnvApiKeys, resolveSettings, maskApiKey, providerEnvKey, projectSettingsPath, loadSettings, WorkspaceYamlEditor, saveSettings } from './chunk-ETMUGBHF.js';
7
+ import { ALL_PROVIDERS, detectEnvApiKeys, resolveSettings, maskApiKey, providerEnvKey, projectSettingsPath, loadSettings, WorkspaceYamlEditor, saveSettings } from './chunk-Z3M5K67G.js';
8
8
  import './chunk-K5GBV4SA.js';
9
9
  import './chunk-KLNL7QHN.js';
10
- import './chunk-PFOXL4SH.js';
11
- import './chunk-V5TBKO5Q.js';
12
- import './chunk-K7WPR77X.js';
13
- import './chunk-VUCPJBAG.js';
10
+ import './chunk-5ESCS2OS.js';
11
+ import './chunk-542K7SR6.js';
12
+ import './chunk-DH4N5AW4.js';
13
+ import './chunk-YX3UWPJ5.js';
14
14
  import './chunk-JKNWJ64A.js';
15
15
  import './chunk-O4JH3KUE.js';
16
16
  import './chunk-24UIWON4.js';
@@ -485,5 +485,5 @@ async function cmdSetup(_args, opts) {
485
485
  }
486
486
 
487
487
  export { cmdSetup };
488
- //# sourceMappingURL=setup-F6DGKL7J.js.map
489
- //# sourceMappingURL=setup-F6DGKL7J.js.map
488
+ //# sourceMappingURL=setup-J7CYEQOF.js.map
489
+ //# sourceMappingURL=setup-J7CYEQOF.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../cli/src/setup.ts"],"names":["p","isCancel","result"],"mappings":"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","file":"setup-F6DGKL7J.js","sourcesContent":["/**\n * skaile setup — Interactive provider setup wizard\n *\n * Discovers existing config, lets the user pick providers, enter/validate API keys,\n * choose where to store them, and set defaults.\n */\n\nimport fs from \"node:fs\";\nimport os from \"node:os\";\nimport path from \"node:path\";\nimport * as p from \"@clack/prompts\";\nimport { getModels, validateApiKey } from \"@skaile/workspaces/bridge\";\nimport {\n ALL_PROVIDERS,\n detectEnvApiKeys,\n loadSettings,\n maskApiKey,\n projectSettingsPath,\n providerEnvKey,\n resolveSettings,\n type SkaileSettings,\n saveSettings,\n WorkspaceYamlEditor,\n} from \"@skaile/workspaces/core\";\n\n// ---------------------------------------------------------------------------\n// Provider metadata\n// ---------------------------------------------------------------------------\n\n/** LLM providers only (excludes voice providers) */\nconst LLM_PROVIDERS = ALL_PROVIDERS.filter((p) => p !== \"deepgram\" && p !== \"elevenlabs\");\n\nconst PROVIDER_LABELS: Record<string, string> = {\n anthropic: \"Anthropic (Claude)\",\n openai: \"OpenAI (GPT)\",\n google: \"Google (Gemini)\",\n mistral: \"Mistral AI\",\n groq: \"Groq (fast inference)\",\n openrouter: \"OpenRouter (multi-provider gateway)\",\n deepseek: \"DeepSeek\",\n xai: \"xAI (Grok)\",\n together: \"Together AI\",\n fireworks: \"Fireworks AI\",\n};\n\nconst PROVIDER_KEY_URLS: Record<string, string> = {\n anthropic: \"https://console.anthropic.com/settings/keys\",\n openai: \"https://platform.openai.com/api-keys\",\n google: \"https://aistudio.google.com/apikey\",\n mistral: \"https://console.mistral.ai/api-keys\",\n groq: \"https://console.groq.com/keys\",\n openrouter: \"https://openrouter.ai/settings/keys\",\n deepseek: \"https://platform.deepseek.com/api_keys\",\n xai: \"https://console.x.ai/\",\n together: \"https://api.together.ai/settings/api-keys\",\n fireworks: \"https://fireworks.ai/api-keys\",\n};\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\ntype StorageTarget = \"settings\" | \"env-project\" | \"env-global\" | \"skip\";\ntype DefaultsTarget = \"project\" | \"personal\";\n\ninterface SetupPlan {\n providers: string[];\n newKeys: Record<string, string>;\n storageTarget: StorageTarget;\n defaultsTarget: DefaultsTarget;\n defaultProvider: string;\n defaultModel: string;\n defaultDriver: string;\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction isCancel(value: unknown): value is symbol {\n return p.isCancel(value);\n}\n\nfunction exitOnCancel<T>(value: T): asserts value is Exclude<T, symbol> {\n if (isCancel(value)) {\n p.cancel(\"Setup cancelled.\");\n process.exit(0);\n }\n}\n\n/** Load .env files from common locations and parse key=value pairs */\nfunction loadDotenvKeys(): Record<string, string> {\n const locations = [path.join(process.cwd(), \".env\"), path.join(os.homedir(), \".env\")];\n const result: Record<string, string> = {};\n for (const loc of locations) {\n try {\n const content = fs.readFileSync(loc, \"utf-8\");\n for (const line of content.split(\"\\n\")) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(\"#\")) continue;\n const eq = trimmed.indexOf(\"=\");\n if (eq === -1) continue;\n const key = trimmed.slice(0, eq).trim();\n let val = trimmed.slice(eq + 1).trim();\n // Strip surrounding quotes\n if (\n (val.startsWith('\"') && val.endsWith('\"')) ||\n (val.startsWith(\"'\") && val.endsWith(\"'\"))\n ) {\n val = val.slice(1, -1);\n }\n result[key] = val;\n }\n } catch {\n // file doesn't exist, skip\n }\n }\n return result;\n}\n\n/** Append key=value entries to a .env file without overwriting existing keys */\nfunction appendEnvFile(filePath: string, entries: Record<string, string>): void {\n let existing = \"\";\n try {\n existing = fs.readFileSync(filePath, \"utf-8\");\n } catch {\n // file doesn't exist yet\n }\n\n const existingKeys = new Set<string>();\n for (const line of existing.split(\"\\n\")) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(\"#\")) continue;\n const eq = trimmed.indexOf(\"=\");\n if (eq !== -1) existingKeys.add(trimmed.slice(0, eq).trim());\n }\n\n const lines: string[] = [];\n for (const [key, value] of Object.entries(entries)) {\n if (existingKeys.has(key)) {\n p.log.warn(` ${key} already exists in ${filePath} — skipping`);\n continue;\n }\n lines.push(`${key}=${value}`);\n }\n\n if (lines.length === 0) return;\n\n const separator = existing.endsWith(\"\\n\") || existing === \"\" ? \"\" : \"\\n\";\n const content = `${separator + lines.join(\"\\n\")}\\n`;\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\n fs.appendFileSync(filePath, content, \"utf-8\");\n}\n\n// ---------------------------------------------------------------------------\n// Wizard steps\n// ---------------------------------------------------------------------------\n\nasync function showCurrentState(\n settings: SkaileSettings,\n envKeys: Record<string, string>,\n): Promise<void> {\n const apiKeys = settings.apiKeys ?? {};\n const lines: string[] = [\"Provider keys:\"];\n for (const provider of LLM_PROVIDERS) {\n const envVal = envKeys[provider];\n const storedVal = apiKeys[provider];\n if (envVal) {\n lines.push(` ${provider.padEnd(12)} [env] ${maskApiKey(envVal)}`);\n } else if (storedVal) {\n lines.push(` ${provider.padEnd(12)} [stored] ${maskApiKey(storedVal)}`);\n } else {\n lines.push(` ${provider.padEnd(12)} (not configured)`);\n }\n }\n lines.push(\"\");\n lines.push(\"Current defaults:\");\n lines.push(` Provider: ${settings.provider ?? \"(not set)\"}`);\n lines.push(` Model: ${settings.model ?? \"(not set)\"}`);\n lines.push(` Driver: ${settings.driver ?? \"(not set)\"}`);\n\n p.note(lines.join(\"\\n\"), \"Current configuration\");\n}\n\nasync function selectProviders(\n envKeys: Record<string, string>,\n storedKeys: Record<string, string>,\n): Promise<string[]> {\n const result = await p.multiselect({\n message: \"Which providers do you want to configure?\",\n options: LLM_PROVIDERS.map((id) => ({\n value: id,\n label: PROVIDER_LABELS[id] ?? id,\n hint: envKeys[id]\n ? `env: ${maskApiKey(envKeys[id])}`\n : storedKeys[id]\n ? `stored: ${maskApiKey(storedKeys[id])}`\n : undefined,\n })),\n initialValues: LLM_PROVIDERS.filter((id) => envKeys[id] || storedKeys[id]),\n required: true,\n });\n exitOnCancel(result);\n return result as string[];\n}\n\nasync function collectApiKeys(\n providers: string[],\n envKeys: Record<string, string>,\n storedKeys: Record<string, string>,\n): Promise<Record<string, string>> {\n const newKeys: Record<string, string> = {};\n\n for (const provider of providers) {\n const envVar = providerEnvKey(provider);\n\n if (envKeys[provider]) {\n p.log.info(`${PROVIDER_LABELS[provider] ?? provider}: already set via ${envVar}`);\n continue;\n }\n\n if (storedKeys[provider]) {\n const update = await p.confirm({\n message: `${PROVIDER_LABELS[provider] ?? provider}: key already stored (${maskApiKey(storedKeys[provider])}). Update it?`,\n initialValue: false,\n });\n exitOnCancel(update);\n if (!update) continue;\n }\n\n const keyUrl = PROVIDER_KEY_URLS[provider];\n const key = await p.password({\n message: `${PROVIDER_LABELS[provider] ?? provider} API key${keyUrl ? ` (get one at ${keyUrl})` : \"\"}:`,\n });\n exitOnCancel(key);\n\n if (!key) continue;\n\n // Optional validation\n const shouldValidate = await p.confirm({\n message: \"Validate this key?\",\n initialValue: true,\n });\n exitOnCancel(shouldValidate);\n\n if (shouldValidate) {\n const s = p.spinner();\n s.start(`Validating ${provider} key...`);\n const result = await validateApiKey(provider, key);\n if (result.ok) {\n s.stop(`${provider} key is valid`);\n } else {\n s.stop(`${provider} validation failed: ${result.error}`);\n const retry = await p.confirm({\n message: \"Use this key anyway?\",\n initialValue: false,\n });\n exitOnCancel(retry);\n if (!retry) continue;\n }\n }\n\n newKeys[provider] = key;\n }\n\n return newKeys;\n}\n\nasync function selectStorageTarget(): Promise<StorageTarget> {\n const result = await p.select({\n message: \"Where should API keys be stored?\",\n options: [\n { value: \"settings\" as const, label: \".skaile/settings.json (project-local, gitignored)\" },\n { value: \"env-project\" as const, label: `${process.cwd()}/.env (project-level)` },\n { value: \"env-global\" as const, label: `${os.homedir()}/.env (global)` },\n { value: \"skip\" as const, label: \"Skip — I'll set env vars myself\" },\n ],\n });\n exitOnCancel(result);\n return result as StorageTarget;\n}\n\nasync function selectDefaultProvider(providers: string[], current?: string): Promise<string> {\n const result = await p.select({\n message: \"Default LLM provider:\",\n options: providers.map((id) => ({\n value: id,\n label: PROVIDER_LABELS[id] ?? id,\n })),\n initialValue: current && providers.includes(current) ? current : providers[0],\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDefaultModel(\n provider: string,\n current?: string,\n apiKey?: string,\n): Promise<string> {\n // Try live model list from provider API, fall back to static catalog\n const s = apiKey ? p.spinner() : undefined;\n if (s) s.start(`Fetching models from ${provider}...`);\n\n const fetchResult = await getModels(provider, apiKey);\n\n if (s) {\n if (fetchResult.source === \"api\") {\n s.stop(`Loaded ${fetchResult.models.length} models from ${provider} API`);\n } else if (fetchResult.error) {\n s.stop(`Could not fetch live models (${fetchResult.error}) — using built-in catalog`);\n } else {\n s.stop(`Using built-in model catalog`);\n }\n }\n\n const models = fetchResult.models;\n if (models.length === 0) {\n p.log.warn(`No models found for ${provider} — enter a model ID manually`);\n const result = await p.text({\n message: \"Model ID:\",\n initialValue: current ?? \"\",\n });\n exitOnCancel(result);\n return result as string;\n }\n\n const result = await p.select({\n message: `Default model (${provider}):`,\n options: models.map((m) => ({\n value: m.id,\n label: `${m.name} (${m.id})`,\n })),\n initialValue: current && models.some((m) => m.id === current) ? current : models[0].id,\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDriver(current?: string): Promise<string> {\n const result = await p.select({\n message: \"Default agent driver:\",\n options: [\n { value: \"omp\", label: \"omp (oh-my-pi — multi-provider, recommended)\" },\n { value: \"claude-sdk\", label: \"claude-sdk (Anthropic Agent SDK, Claude only)\" },\n { value: \"codex\", label: \"codex (OpenAI Codex SDK, OpenAI only)\" },\n ],\n initialValue: current ?? \"omp\",\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDefaultsTarget(projectDir: string): Promise<DefaultsTarget> {\n const yamlPath = path.join(projectDir, \"skaile.yaml\");\n const hasYaml = fs.existsSync(yamlPath);\n\n if (!hasYaml) {\n // No skaile.yaml — can only save personally\n return \"personal\";\n }\n\n const result = await p.select({\n message: \"Where should driver, provider, and model defaults be saved?\",\n options: [\n {\n value: \"project\" as const,\n label: \"skaile.yaml (project-wide, shared with team)\",\n hint: \"recommended\",\n },\n {\n value: \"personal\" as const,\n label: \".skaile/settings.json (personal only, gitignored)\",\n },\n ],\n initialValue: \"project\" as const,\n });\n exitOnCancel(result);\n return result as DefaultsTarget;\n}\n\nasync function reviewAndSave(plan: SetupPlan, projectDir: string): Promise<void> {\n const settingsFile = projectSettingsPath(projectDir);\n\n // Build summary\n const lines: string[] = [];\n\n if (Object.keys(plan.newKeys).length > 0) {\n lines.push(\"New API keys:\");\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n lines.push(` ${provider.padEnd(12)} ${maskApiKey(key)}`);\n }\n const targetLabels: Record<StorageTarget, string> = {\n settings: `.skaile/settings.json (${settingsFile})`,\n \"env-project\": `${process.cwd()}/.env`,\n \"env-global\": `${os.homedir()}/.env`,\n skip: \"not saved (set env vars manually)\",\n };\n lines.push(` Storage: ${targetLabels[plan.storageTarget]}`);\n lines.push(\"\");\n }\n\n const defaultsLabel =\n plan.defaultsTarget === \"project\"\n ? \"skaile.yaml (project-wide)\"\n : \".skaile/settings.json (personal)\";\n lines.push(\"Defaults:\");\n lines.push(` Provider: ${plan.defaultProvider}`);\n lines.push(` Model: ${plan.defaultModel}`);\n lines.push(` Driver: ${plan.defaultDriver}`);\n lines.push(` Saved to: ${defaultsLabel}`);\n\n p.note(lines.join(\"\\n\"), \"Summary\");\n\n const confirmed = await p.confirm({\n message: \"Apply these settings?\",\n initialValue: true,\n });\n exitOnCancel(confirmed);\n\n if (!confirmed) {\n p.cancel(\"Setup cancelled — no changes were made.\");\n process.exit(0);\n }\n\n // Load existing project settings (or empty)\n const existing = await loadSettings(settingsFile);\n\n // Save defaults to skaile.yaml or settings.json depending on user choice\n if (plan.defaultsTarget === \"project\") {\n const yamlPath = path.join(projectDir, \"skaile.yaml\");\n const editor = WorkspaceYamlEditor.load(yamlPath);\n editor.setAgentConfig(\"default\", {\n provider: plan.defaultProvider,\n model: plan.defaultModel,\n driver: plan.defaultDriver,\n });\n editor.save();\n p.log.success(`Saved defaults to ${yamlPath}`);\n }\n\n // Personal settings: only include defaults if saving personally, always include API keys.\n // When saving to project (skaile.yaml), strip driver/provider/model from settings.json\n // so they don't shadow the project-wide values.\n const merged: SkaileSettings = { ...existing };\n if (plan.defaultsTarget === \"personal\") {\n merged.provider = plan.defaultProvider;\n merged.model = plan.defaultModel;\n merged.driver = plan.defaultDriver;\n } else {\n delete merged.provider;\n delete merged.model;\n delete merged.driver;\n }\n\n // Save keys\n const hasNewKeys = Object.keys(plan.newKeys).length > 0;\n\n if (hasNewKeys && plan.storageTarget === \"settings\") {\n const apiKeys = { ...(merged.apiKeys ?? {}) };\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n apiKeys[provider] = key;\n }\n merged.apiKeys = apiKeys;\n } else if (hasNewKeys && plan.storageTarget === \"env-project\") {\n const envEntries: Record<string, string> = {};\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n envEntries[providerEnvKey(provider)] = key;\n }\n appendEnvFile(path.join(process.cwd(), \".env\"), envEntries);\n p.log.success(`Appended keys to ${process.cwd()}/.env`);\n } else if (hasNewKeys && plan.storageTarget === \"env-global\") {\n const envEntries: Record<string, string> = {};\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n envEntries[providerEnvKey(provider)] = key;\n }\n appendEnvFile(path.join(os.homedir(), \".env\"), envEntries);\n p.log.success(`Appended keys to ${os.homedir()}/.env`);\n }\n\n // Write unified settings file\n await saveSettings(merged, settingsFile);\n p.log.success(`Saved settings to ${settingsFile}`);\n}\n\n// ---------------------------------------------------------------------------\n// Main entry\n// ---------------------------------------------------------------------------\n\n/** Check whether Claude Code OAuth credentials exist on disk */\nfunction hasClaudeCodeCredentials(): boolean {\n const credPath = path.join(os.homedir(), \".claude\", \".credentials.json\");\n try {\n const content = fs.readFileSync(credPath, \"utf-8\");\n const parsed = JSON.parse(content);\n // Check that it has at least one non-empty field\n return parsed && (parsed.accessToken || parsed.refreshToken || parsed.oauthToken);\n } catch {\n return false;\n }\n}\n\n/**\n * Interactive provider setup wizard: discovers existing config, prompts for\n * provider/model/driver preferences and API keys, then writes the results to\n * `skaile.yaml` or `.skaile/settings.json` depending on the user's choice.\n *\n * @param _args - Unused positional args (reserved for future use).\n * @param opts - Options including an optional `projectDir` override.\n * @docLink cli/dev-guide#setup\n */\nexport async function cmdSetup(_args: string[], opts: { projectDir?: string }): Promise<void> {\n p.intro(\"skaile setup\");\n\n const projectDir = opts.projectDir ?? process.cwd();\n\n // 1. Detect existing state via layered resolution\n const dotenvKeys = loadDotenvKeys();\n const envKeys = detectEnvApiKeys(dotenvKeys);\n const settings = await resolveSettings(projectDir);\n\n // 2. Show current state\n await showCurrentState(settings, envKeys);\n\n // 3. Select driver FIRST — it determines which providers/models are relevant\n const defaultDriver = await selectDriver(settings.driver);\n\n const apiKeys = settings.apiKeys ?? {};\n let providers: string[];\n let newKeys: Record<string, string>;\n let storageTarget: StorageTarget = \"skip\";\n let defaultProvider: string;\n let defaultModel: string;\n\n if (defaultDriver === \"claude-sdk\") {\n // -----------------------------------------------------------------------\n // Claude SDK path: Anthropic only\n // -----------------------------------------------------------------------\n defaultProvider = \"anthropic\";\n\n // Check for existing auth: API key or Claude Code OAuth credentials\n const hasEnvKey = !!envKeys.anthropic;\n const hasStoredKey = !!apiKeys.anthropic;\n const hasOAuth = hasClaudeCodeCredentials();\n\n if (hasEnvKey) {\n p.log.info(`Anthropic API key found in environment (${maskApiKey(envKeys.anthropic)})`);\n providers = [\"anthropic\"];\n newKeys = {};\n } else if (hasStoredKey) {\n p.log.info(`Anthropic API key found in settings (${maskApiKey(apiKeys.anthropic)})`);\n providers = [\"anthropic\"];\n newKeys = {};\n } else if (hasOAuth) {\n p.log.info(\"Claude Code subscription detected (OAuth credentials found)\");\n p.log.info(\"The Claude SDK will use your Claude Code login — no API key needed.\");\n providers = [\"anthropic\"];\n newKeys = {};\n } else {\n // No auth found — prompt for Anthropic API key\n p.log.warn(\"No Anthropic API key or Claude Code subscription found.\");\n p.log.info(\"You can either:\");\n p.log.info(\" 1. Enter an Anthropic API key now\");\n p.log.info(\" 2. Run `claude login` to authenticate with Claude Code\");\n\n const wantsKey = await p.confirm({\n message: \"Enter an Anthropic API key?\",\n initialValue: true,\n });\n exitOnCancel(wantsKey);\n\n providers = [\"anthropic\"];\n if (wantsKey) {\n newKeys = await collectApiKeys([\"anthropic\"], envKeys, apiKeys);\n } else {\n newKeys = {};\n }\n }\n\n // Storage target (only ask if there are new keys)\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n // Model selection — only Anthropic models (try live fetch with available key)\n const anthropicKey = newKeys.anthropic ?? envKeys.anthropic ?? apiKeys.anthropic;\n defaultModel = await selectDefaultModel(\"anthropic\", settings.model, anthropicKey);\n } else if (defaultDriver === \"codex\") {\n // -----------------------------------------------------------------------\n // Codex path: OpenAI only\n // -----------------------------------------------------------------------\n defaultProvider = \"openai\";\n\n const hasEnvKey = !!envKeys.openai;\n const hasStoredKey = !!apiKeys.openai;\n\n if (hasEnvKey) {\n p.log.info(`OpenAI API key found in environment (${maskApiKey(envKeys.openai)})`);\n providers = [\"openai\"];\n newKeys = {};\n } else if (hasStoredKey) {\n p.log.info(`OpenAI API key found in settings (${maskApiKey(apiKeys.openai)})`);\n providers = [\"openai\"];\n newKeys = {};\n } else {\n p.log.warn(\"No OpenAI API key found.\");\n newKeys = await collectApiKeys([\"openai\"], envKeys, apiKeys);\n providers = [\"openai\"];\n }\n\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n const openaiKey = newKeys.openai ?? envKeys.openai ?? apiKeys.openai;\n defaultModel = await selectDefaultModel(\"openai\", settings.model, openaiKey);\n } else {\n // -----------------------------------------------------------------------\n // omp / pi path: multi-provider flow (existing behavior)\n // -----------------------------------------------------------------------\n\n // 4. Select providers\n providers = await selectProviders(envKeys, apiKeys);\n\n // 5. Collect API keys\n newKeys = await collectApiKeys(providers, envKeys, apiKeys);\n\n // 6. Storage target (only ask if there are new keys)\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n // 7. Default provider (from selected providers + any already configured)\n const allConfigured = [\n ...new Set([\n ...providers,\n ...Object.keys(envKeys),\n ...Object.keys(apiKeys).filter((k) => apiKeys[k]),\n ]),\n ].filter((p) => LLM_PROVIDERS.includes(p as any));\n defaultProvider = await selectDefaultProvider(\n allConfigured.length > 0 ? allConfigured : providers,\n settings.provider,\n );\n\n // 8. Default model (try live fetch with available key)\n const providerKey =\n newKeys[defaultProvider] ?? envKeys[defaultProvider] ?? apiKeys[defaultProvider];\n defaultModel = await selectDefaultModel(defaultProvider, settings.model, providerKey);\n }\n\n // 9. Choose where to save defaults (project-wide vs personal)\n const defaultsTarget = await selectDefaultsTarget(projectDir);\n\n // 10. Review and save\n await reviewAndSave(\n {\n providers,\n newKeys,\n storageTarget,\n defaultsTarget,\n defaultProvider,\n defaultModel,\n defaultDriver,\n },\n projectDir,\n );\n\n p.outro(\"Setup complete!\");\n}\n"]}
1
+ {"version":3,"sources":["../cli/src/setup.ts"],"names":["p","isCancel","result"],"mappings":"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","file":"setup-J7CYEQOF.js","sourcesContent":["/**\n * skaile setup — Interactive provider setup wizard\n *\n * Discovers existing config, lets the user pick providers, enter/validate API keys,\n * choose where to store them, and set defaults.\n */\n\nimport fs from \"node:fs\";\nimport os from \"node:os\";\nimport path from \"node:path\";\nimport * as p from \"@clack/prompts\";\nimport { getModels, validateApiKey } from \"@skaile/workspaces/bridge\";\nimport {\n ALL_PROVIDERS,\n detectEnvApiKeys,\n loadSettings,\n maskApiKey,\n projectSettingsPath,\n providerEnvKey,\n resolveSettings,\n type SkaileSettings,\n saveSettings,\n WorkspaceYamlEditor,\n} from \"@skaile/workspaces/core\";\n\n// ---------------------------------------------------------------------------\n// Provider metadata\n// ---------------------------------------------------------------------------\n\n/** LLM providers only (excludes voice providers) */\nconst LLM_PROVIDERS = ALL_PROVIDERS.filter((p) => p !== \"deepgram\" && p !== \"elevenlabs\");\n\nconst PROVIDER_LABELS: Record<string, string> = {\n anthropic: \"Anthropic (Claude)\",\n openai: \"OpenAI (GPT)\",\n google: \"Google (Gemini)\",\n mistral: \"Mistral AI\",\n groq: \"Groq (fast inference)\",\n openrouter: \"OpenRouter (multi-provider gateway)\",\n deepseek: \"DeepSeek\",\n xai: \"xAI (Grok)\",\n together: \"Together AI\",\n fireworks: \"Fireworks AI\",\n};\n\nconst PROVIDER_KEY_URLS: Record<string, string> = {\n anthropic: \"https://console.anthropic.com/settings/keys\",\n openai: \"https://platform.openai.com/api-keys\",\n google: \"https://aistudio.google.com/apikey\",\n mistral: \"https://console.mistral.ai/api-keys\",\n groq: \"https://console.groq.com/keys\",\n openrouter: \"https://openrouter.ai/settings/keys\",\n deepseek: \"https://platform.deepseek.com/api_keys\",\n xai: \"https://console.x.ai/\",\n together: \"https://api.together.ai/settings/api-keys\",\n fireworks: \"https://fireworks.ai/api-keys\",\n};\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\ntype StorageTarget = \"settings\" | \"env-project\" | \"env-global\" | \"skip\";\ntype DefaultsTarget = \"project\" | \"personal\";\n\ninterface SetupPlan {\n providers: string[];\n newKeys: Record<string, string>;\n storageTarget: StorageTarget;\n defaultsTarget: DefaultsTarget;\n defaultProvider: string;\n defaultModel: string;\n defaultDriver: string;\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction isCancel(value: unknown): value is symbol {\n return p.isCancel(value);\n}\n\nfunction exitOnCancel<T>(value: T): asserts value is Exclude<T, symbol> {\n if (isCancel(value)) {\n p.cancel(\"Setup cancelled.\");\n process.exit(0);\n }\n}\n\n/** Load .env files from common locations and parse key=value pairs */\nfunction loadDotenvKeys(): Record<string, string> {\n const locations = [path.join(process.cwd(), \".env\"), path.join(os.homedir(), \".env\")];\n const result: Record<string, string> = {};\n for (const loc of locations) {\n try {\n const content = fs.readFileSync(loc, \"utf-8\");\n for (const line of content.split(\"\\n\")) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(\"#\")) continue;\n const eq = trimmed.indexOf(\"=\");\n if (eq === -1) continue;\n const key = trimmed.slice(0, eq).trim();\n let val = trimmed.slice(eq + 1).trim();\n // Strip surrounding quotes\n if (\n (val.startsWith('\"') && val.endsWith('\"')) ||\n (val.startsWith(\"'\") && val.endsWith(\"'\"))\n ) {\n val = val.slice(1, -1);\n }\n result[key] = val;\n }\n } catch {\n // file doesn't exist, skip\n }\n }\n return result;\n}\n\n/** Append key=value entries to a .env file without overwriting existing keys */\nfunction appendEnvFile(filePath: string, entries: Record<string, string>): void {\n let existing = \"\";\n try {\n existing = fs.readFileSync(filePath, \"utf-8\");\n } catch {\n // file doesn't exist yet\n }\n\n const existingKeys = new Set<string>();\n for (const line of existing.split(\"\\n\")) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(\"#\")) continue;\n const eq = trimmed.indexOf(\"=\");\n if (eq !== -1) existingKeys.add(trimmed.slice(0, eq).trim());\n }\n\n const lines: string[] = [];\n for (const [key, value] of Object.entries(entries)) {\n if (existingKeys.has(key)) {\n p.log.warn(` ${key} already exists in ${filePath} — skipping`);\n continue;\n }\n lines.push(`${key}=${value}`);\n }\n\n if (lines.length === 0) return;\n\n const separator = existing.endsWith(\"\\n\") || existing === \"\" ? \"\" : \"\\n\";\n const content = `${separator + lines.join(\"\\n\")}\\n`;\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\n fs.appendFileSync(filePath, content, \"utf-8\");\n}\n\n// ---------------------------------------------------------------------------\n// Wizard steps\n// ---------------------------------------------------------------------------\n\nasync function showCurrentState(\n settings: SkaileSettings,\n envKeys: Record<string, string>,\n): Promise<void> {\n const apiKeys = settings.apiKeys ?? {};\n const lines: string[] = [\"Provider keys:\"];\n for (const provider of LLM_PROVIDERS) {\n const envVal = envKeys[provider];\n const storedVal = apiKeys[provider];\n if (envVal) {\n lines.push(` ${provider.padEnd(12)} [env] ${maskApiKey(envVal)}`);\n } else if (storedVal) {\n lines.push(` ${provider.padEnd(12)} [stored] ${maskApiKey(storedVal)}`);\n } else {\n lines.push(` ${provider.padEnd(12)} (not configured)`);\n }\n }\n lines.push(\"\");\n lines.push(\"Current defaults:\");\n lines.push(` Provider: ${settings.provider ?? \"(not set)\"}`);\n lines.push(` Model: ${settings.model ?? \"(not set)\"}`);\n lines.push(` Driver: ${settings.driver ?? \"(not set)\"}`);\n\n p.note(lines.join(\"\\n\"), \"Current configuration\");\n}\n\nasync function selectProviders(\n envKeys: Record<string, string>,\n storedKeys: Record<string, string>,\n): Promise<string[]> {\n const result = await p.multiselect({\n message: \"Which providers do you want to configure?\",\n options: LLM_PROVIDERS.map((id) => ({\n value: id,\n label: PROVIDER_LABELS[id] ?? id,\n hint: envKeys[id]\n ? `env: ${maskApiKey(envKeys[id])}`\n : storedKeys[id]\n ? `stored: ${maskApiKey(storedKeys[id])}`\n : undefined,\n })),\n initialValues: LLM_PROVIDERS.filter((id) => envKeys[id] || storedKeys[id]),\n required: true,\n });\n exitOnCancel(result);\n return result as string[];\n}\n\nasync function collectApiKeys(\n providers: string[],\n envKeys: Record<string, string>,\n storedKeys: Record<string, string>,\n): Promise<Record<string, string>> {\n const newKeys: Record<string, string> = {};\n\n for (const provider of providers) {\n const envVar = providerEnvKey(provider);\n\n if (envKeys[provider]) {\n p.log.info(`${PROVIDER_LABELS[provider] ?? provider}: already set via ${envVar}`);\n continue;\n }\n\n if (storedKeys[provider]) {\n const update = await p.confirm({\n message: `${PROVIDER_LABELS[provider] ?? provider}: key already stored (${maskApiKey(storedKeys[provider])}). Update it?`,\n initialValue: false,\n });\n exitOnCancel(update);\n if (!update) continue;\n }\n\n const keyUrl = PROVIDER_KEY_URLS[provider];\n const key = await p.password({\n message: `${PROVIDER_LABELS[provider] ?? provider} API key${keyUrl ? ` (get one at ${keyUrl})` : \"\"}:`,\n });\n exitOnCancel(key);\n\n if (!key) continue;\n\n // Optional validation\n const shouldValidate = await p.confirm({\n message: \"Validate this key?\",\n initialValue: true,\n });\n exitOnCancel(shouldValidate);\n\n if (shouldValidate) {\n const s = p.spinner();\n s.start(`Validating ${provider} key...`);\n const result = await validateApiKey(provider, key);\n if (result.ok) {\n s.stop(`${provider} key is valid`);\n } else {\n s.stop(`${provider} validation failed: ${result.error}`);\n const retry = await p.confirm({\n message: \"Use this key anyway?\",\n initialValue: false,\n });\n exitOnCancel(retry);\n if (!retry) continue;\n }\n }\n\n newKeys[provider] = key;\n }\n\n return newKeys;\n}\n\nasync function selectStorageTarget(): Promise<StorageTarget> {\n const result = await p.select({\n message: \"Where should API keys be stored?\",\n options: [\n { value: \"settings\" as const, label: \".skaile/settings.json (project-local, gitignored)\" },\n { value: \"env-project\" as const, label: `${process.cwd()}/.env (project-level)` },\n { value: \"env-global\" as const, label: `${os.homedir()}/.env (global)` },\n { value: \"skip\" as const, label: \"Skip — I'll set env vars myself\" },\n ],\n });\n exitOnCancel(result);\n return result as StorageTarget;\n}\n\nasync function selectDefaultProvider(providers: string[], current?: string): Promise<string> {\n const result = await p.select({\n message: \"Default LLM provider:\",\n options: providers.map((id) => ({\n value: id,\n label: PROVIDER_LABELS[id] ?? id,\n })),\n initialValue: current && providers.includes(current) ? current : providers[0],\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDefaultModel(\n provider: string,\n current?: string,\n apiKey?: string,\n): Promise<string> {\n // Try live model list from provider API, fall back to static catalog\n const s = apiKey ? p.spinner() : undefined;\n if (s) s.start(`Fetching models from ${provider}...`);\n\n const fetchResult = await getModels(provider, apiKey);\n\n if (s) {\n if (fetchResult.source === \"api\") {\n s.stop(`Loaded ${fetchResult.models.length} models from ${provider} API`);\n } else if (fetchResult.error) {\n s.stop(`Could not fetch live models (${fetchResult.error}) — using built-in catalog`);\n } else {\n s.stop(`Using built-in model catalog`);\n }\n }\n\n const models = fetchResult.models;\n if (models.length === 0) {\n p.log.warn(`No models found for ${provider} — enter a model ID manually`);\n const result = await p.text({\n message: \"Model ID:\",\n initialValue: current ?? \"\",\n });\n exitOnCancel(result);\n return result as string;\n }\n\n const result = await p.select({\n message: `Default model (${provider}):`,\n options: models.map((m) => ({\n value: m.id,\n label: `${m.name} (${m.id})`,\n })),\n initialValue: current && models.some((m) => m.id === current) ? current : models[0].id,\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDriver(current?: string): Promise<string> {\n const result = await p.select({\n message: \"Default agent driver:\",\n options: [\n { value: \"omp\", label: \"omp (oh-my-pi — multi-provider, recommended)\" },\n { value: \"claude-sdk\", label: \"claude-sdk (Anthropic Agent SDK, Claude only)\" },\n { value: \"codex\", label: \"codex (OpenAI Codex SDK, OpenAI only)\" },\n ],\n initialValue: current ?? \"omp\",\n });\n exitOnCancel(result);\n return result as string;\n}\n\nasync function selectDefaultsTarget(projectDir: string): Promise<DefaultsTarget> {\n const yamlPath = path.join(projectDir, \"skaile.yaml\");\n const hasYaml = fs.existsSync(yamlPath);\n\n if (!hasYaml) {\n // No skaile.yaml — can only save personally\n return \"personal\";\n }\n\n const result = await p.select({\n message: \"Where should driver, provider, and model defaults be saved?\",\n options: [\n {\n value: \"project\" as const,\n label: \"skaile.yaml (project-wide, shared with team)\",\n hint: \"recommended\",\n },\n {\n value: \"personal\" as const,\n label: \".skaile/settings.json (personal only, gitignored)\",\n },\n ],\n initialValue: \"project\" as const,\n });\n exitOnCancel(result);\n return result as DefaultsTarget;\n}\n\nasync function reviewAndSave(plan: SetupPlan, projectDir: string): Promise<void> {\n const settingsFile = projectSettingsPath(projectDir);\n\n // Build summary\n const lines: string[] = [];\n\n if (Object.keys(plan.newKeys).length > 0) {\n lines.push(\"New API keys:\");\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n lines.push(` ${provider.padEnd(12)} ${maskApiKey(key)}`);\n }\n const targetLabels: Record<StorageTarget, string> = {\n settings: `.skaile/settings.json (${settingsFile})`,\n \"env-project\": `${process.cwd()}/.env`,\n \"env-global\": `${os.homedir()}/.env`,\n skip: \"not saved (set env vars manually)\",\n };\n lines.push(` Storage: ${targetLabels[plan.storageTarget]}`);\n lines.push(\"\");\n }\n\n const defaultsLabel =\n plan.defaultsTarget === \"project\"\n ? \"skaile.yaml (project-wide)\"\n : \".skaile/settings.json (personal)\";\n lines.push(\"Defaults:\");\n lines.push(` Provider: ${plan.defaultProvider}`);\n lines.push(` Model: ${plan.defaultModel}`);\n lines.push(` Driver: ${plan.defaultDriver}`);\n lines.push(` Saved to: ${defaultsLabel}`);\n\n p.note(lines.join(\"\\n\"), \"Summary\");\n\n const confirmed = await p.confirm({\n message: \"Apply these settings?\",\n initialValue: true,\n });\n exitOnCancel(confirmed);\n\n if (!confirmed) {\n p.cancel(\"Setup cancelled — no changes were made.\");\n process.exit(0);\n }\n\n // Load existing project settings (or empty)\n const existing = await loadSettings(settingsFile);\n\n // Save defaults to skaile.yaml or settings.json depending on user choice\n if (plan.defaultsTarget === \"project\") {\n const yamlPath = path.join(projectDir, \"skaile.yaml\");\n const editor = WorkspaceYamlEditor.load(yamlPath);\n editor.setAgentConfig(\"default\", {\n provider: plan.defaultProvider,\n model: plan.defaultModel,\n driver: plan.defaultDriver,\n });\n editor.save();\n p.log.success(`Saved defaults to ${yamlPath}`);\n }\n\n // Personal settings: only include defaults if saving personally, always include API keys.\n // When saving to project (skaile.yaml), strip driver/provider/model from settings.json\n // so they don't shadow the project-wide values.\n const merged: SkaileSettings = { ...existing };\n if (plan.defaultsTarget === \"personal\") {\n merged.provider = plan.defaultProvider;\n merged.model = plan.defaultModel;\n merged.driver = plan.defaultDriver;\n } else {\n delete merged.provider;\n delete merged.model;\n delete merged.driver;\n }\n\n // Save keys\n const hasNewKeys = Object.keys(plan.newKeys).length > 0;\n\n if (hasNewKeys && plan.storageTarget === \"settings\") {\n const apiKeys = { ...(merged.apiKeys ?? {}) };\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n apiKeys[provider] = key;\n }\n merged.apiKeys = apiKeys;\n } else if (hasNewKeys && plan.storageTarget === \"env-project\") {\n const envEntries: Record<string, string> = {};\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n envEntries[providerEnvKey(provider)] = key;\n }\n appendEnvFile(path.join(process.cwd(), \".env\"), envEntries);\n p.log.success(`Appended keys to ${process.cwd()}/.env`);\n } else if (hasNewKeys && plan.storageTarget === \"env-global\") {\n const envEntries: Record<string, string> = {};\n for (const [provider, key] of Object.entries(plan.newKeys)) {\n envEntries[providerEnvKey(provider)] = key;\n }\n appendEnvFile(path.join(os.homedir(), \".env\"), envEntries);\n p.log.success(`Appended keys to ${os.homedir()}/.env`);\n }\n\n // Write unified settings file\n await saveSettings(merged, settingsFile);\n p.log.success(`Saved settings to ${settingsFile}`);\n}\n\n// ---------------------------------------------------------------------------\n// Main entry\n// ---------------------------------------------------------------------------\n\n/** Check whether Claude Code OAuth credentials exist on disk */\nfunction hasClaudeCodeCredentials(): boolean {\n const credPath = path.join(os.homedir(), \".claude\", \".credentials.json\");\n try {\n const content = fs.readFileSync(credPath, \"utf-8\");\n const parsed = JSON.parse(content);\n // Check that it has at least one non-empty field\n return parsed && (parsed.accessToken || parsed.refreshToken || parsed.oauthToken);\n } catch {\n return false;\n }\n}\n\n/**\n * Interactive provider setup wizard: discovers existing config, prompts for\n * provider/model/driver preferences and API keys, then writes the results to\n * `skaile.yaml` or `.skaile/settings.json` depending on the user's choice.\n *\n * @param _args - Unused positional args (reserved for future use).\n * @param opts - Options including an optional `projectDir` override.\n * @docLink cli/dev-guide#setup\n */\nexport async function cmdSetup(_args: string[], opts: { projectDir?: string }): Promise<void> {\n p.intro(\"skaile setup\");\n\n const projectDir = opts.projectDir ?? process.cwd();\n\n // 1. Detect existing state via layered resolution\n const dotenvKeys = loadDotenvKeys();\n const envKeys = detectEnvApiKeys(dotenvKeys);\n const settings = await resolveSettings(projectDir);\n\n // 2. Show current state\n await showCurrentState(settings, envKeys);\n\n // 3. Select driver FIRST — it determines which providers/models are relevant\n const defaultDriver = await selectDriver(settings.driver);\n\n const apiKeys = settings.apiKeys ?? {};\n let providers: string[];\n let newKeys: Record<string, string>;\n let storageTarget: StorageTarget = \"skip\";\n let defaultProvider: string;\n let defaultModel: string;\n\n if (defaultDriver === \"claude-sdk\") {\n // -----------------------------------------------------------------------\n // Claude SDK path: Anthropic only\n // -----------------------------------------------------------------------\n defaultProvider = \"anthropic\";\n\n // Check for existing auth: API key or Claude Code OAuth credentials\n const hasEnvKey = !!envKeys.anthropic;\n const hasStoredKey = !!apiKeys.anthropic;\n const hasOAuth = hasClaudeCodeCredentials();\n\n if (hasEnvKey) {\n p.log.info(`Anthropic API key found in environment (${maskApiKey(envKeys.anthropic)})`);\n providers = [\"anthropic\"];\n newKeys = {};\n } else if (hasStoredKey) {\n p.log.info(`Anthropic API key found in settings (${maskApiKey(apiKeys.anthropic)})`);\n providers = [\"anthropic\"];\n newKeys = {};\n } else if (hasOAuth) {\n p.log.info(\"Claude Code subscription detected (OAuth credentials found)\");\n p.log.info(\"The Claude SDK will use your Claude Code login — no API key needed.\");\n providers = [\"anthropic\"];\n newKeys = {};\n } else {\n // No auth found — prompt for Anthropic API key\n p.log.warn(\"No Anthropic API key or Claude Code subscription found.\");\n p.log.info(\"You can either:\");\n p.log.info(\" 1. Enter an Anthropic API key now\");\n p.log.info(\" 2. Run `claude login` to authenticate with Claude Code\");\n\n const wantsKey = await p.confirm({\n message: \"Enter an Anthropic API key?\",\n initialValue: true,\n });\n exitOnCancel(wantsKey);\n\n providers = [\"anthropic\"];\n if (wantsKey) {\n newKeys = await collectApiKeys([\"anthropic\"], envKeys, apiKeys);\n } else {\n newKeys = {};\n }\n }\n\n // Storage target (only ask if there are new keys)\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n // Model selection — only Anthropic models (try live fetch with available key)\n const anthropicKey = newKeys.anthropic ?? envKeys.anthropic ?? apiKeys.anthropic;\n defaultModel = await selectDefaultModel(\"anthropic\", settings.model, anthropicKey);\n } else if (defaultDriver === \"codex\") {\n // -----------------------------------------------------------------------\n // Codex path: OpenAI only\n // -----------------------------------------------------------------------\n defaultProvider = \"openai\";\n\n const hasEnvKey = !!envKeys.openai;\n const hasStoredKey = !!apiKeys.openai;\n\n if (hasEnvKey) {\n p.log.info(`OpenAI API key found in environment (${maskApiKey(envKeys.openai)})`);\n providers = [\"openai\"];\n newKeys = {};\n } else if (hasStoredKey) {\n p.log.info(`OpenAI API key found in settings (${maskApiKey(apiKeys.openai)})`);\n providers = [\"openai\"];\n newKeys = {};\n } else {\n p.log.warn(\"No OpenAI API key found.\");\n newKeys = await collectApiKeys([\"openai\"], envKeys, apiKeys);\n providers = [\"openai\"];\n }\n\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n const openaiKey = newKeys.openai ?? envKeys.openai ?? apiKeys.openai;\n defaultModel = await selectDefaultModel(\"openai\", settings.model, openaiKey);\n } else {\n // -----------------------------------------------------------------------\n // omp / pi path: multi-provider flow (existing behavior)\n // -----------------------------------------------------------------------\n\n // 4. Select providers\n providers = await selectProviders(envKeys, apiKeys);\n\n // 5. Collect API keys\n newKeys = await collectApiKeys(providers, envKeys, apiKeys);\n\n // 6. Storage target (only ask if there are new keys)\n if (Object.keys(newKeys).length > 0) {\n storageTarget = await selectStorageTarget();\n }\n\n // 7. Default provider (from selected providers + any already configured)\n const allConfigured = [\n ...new Set([\n ...providers,\n ...Object.keys(envKeys),\n ...Object.keys(apiKeys).filter((k) => apiKeys[k]),\n ]),\n ].filter((p) => LLM_PROVIDERS.includes(p as any));\n defaultProvider = await selectDefaultProvider(\n allConfigured.length > 0 ? allConfigured : providers,\n settings.provider,\n );\n\n // 8. Default model (try live fetch with available key)\n const providerKey =\n newKeys[defaultProvider] ?? envKeys[defaultProvider] ?? apiKeys[defaultProvider];\n defaultModel = await selectDefaultModel(defaultProvider, settings.model, providerKey);\n }\n\n // 9. Choose where to save defaults (project-wide vs personal)\n const defaultsTarget = await selectDefaultsTarget(projectDir);\n\n // 10. Review and save\n await reviewAndSave(\n {\n providers,\n newKeys,\n storageTarget,\n defaultsTarget,\n defaultProvider,\n defaultModel,\n defaultDriver,\n },\n projectDir,\n );\n\n p.outro(\"Setup complete!\");\n}\n"]}
@@ -0,0 +1,14 @@
1
+ export { clearStoreTokens, getStoreConfig, isStoreAuthenticated, saveStoreTokens, storeFetch } from './chunk-AFLH7B64.js';
2
+ import './chunk-Z3M5K67G.js';
3
+ import './chunk-K5GBV4SA.js';
4
+ import './chunk-KLNL7QHN.js';
5
+ import './chunk-5ESCS2OS.js';
6
+ import './chunk-542K7SR6.js';
7
+ import './chunk-DH4N5AW4.js';
8
+ import './chunk-YX3UWPJ5.js';
9
+ import './chunk-JKNWJ64A.js';
10
+ import './chunk-O4JH3KUE.js';
11
+ import './chunk-24UIWON4.js';
12
+ import './chunk-NSBPE2FW.js';
13
+ //# sourceMappingURL=store-client-AEI6Y3KD.js.map
14
+ //# sourceMappingURL=store-client-AEI6Y3KD.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"store-client-JP642EEI.js"}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"store-client-AEI6Y3KD.js"}