newcraw 1.0.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 (188) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +692 -0
  3. package/README.zh-CN.md +338 -0
  4. package/cli-acp.js +82 -0
  5. package/cli.js +105 -0
  6. package/dist/REPL-74GZVSMY.js +42 -0
  7. package/dist/REPL-74GZVSMY.js.map +7 -0
  8. package/dist/acp-A55ZRIPP.js +1357 -0
  9. package/dist/acp-A55ZRIPP.js.map +7 -0
  10. package/dist/agentsValidate-XWFIEHJ2.js +373 -0
  11. package/dist/agentsValidate-XWFIEHJ2.js.map +7 -0
  12. package/dist/ask-4ACYU23S.js +126 -0
  13. package/dist/ask-4ACYU23S.js.map +7 -0
  14. package/dist/autoUpdater-O2WHHSGP.js +17 -0
  15. package/dist/autoUpdater-O2WHHSGP.js.map +7 -0
  16. package/dist/chunk-2UO3BFZH.js +16 -0
  17. package/dist/chunk-2UO3BFZH.js.map +7 -0
  18. package/dist/chunk-3C73U2IU.js +2970 -0
  19. package/dist/chunk-3C73U2IU.js.map +7 -0
  20. package/dist/chunk-3U5X4VWP.js +2613 -0
  21. package/dist/chunk-3U5X4VWP.js.map +7 -0
  22. package/dist/chunk-755HIAI3.js +95 -0
  23. package/dist/chunk-755HIAI3.js.map +7 -0
  24. package/dist/chunk-7ZFLZNOW.js +21 -0
  25. package/dist/chunk-7ZFLZNOW.js.map +7 -0
  26. package/dist/chunk-A44DGORI.js +49 -0
  27. package/dist/chunk-A44DGORI.js.map +7 -0
  28. package/dist/chunk-AXWJI6N5.js +11 -0
  29. package/dist/chunk-AXWJI6N5.js.map +7 -0
  30. package/dist/chunk-B26ZUMJI.js +515 -0
  31. package/dist/chunk-B26ZUMJI.js.map +7 -0
  32. package/dist/chunk-BHNQGSLO.js +96 -0
  33. package/dist/chunk-BHNQGSLO.js.map +7 -0
  34. package/dist/chunk-BUI6KGVA.js +164 -0
  35. package/dist/chunk-BUI6KGVA.js.map +7 -0
  36. package/dist/chunk-DY5D4SS7.js +936 -0
  37. package/dist/chunk-DY5D4SS7.js.map +7 -0
  38. package/dist/chunk-EENI5HG7.js +498 -0
  39. package/dist/chunk-EENI5HG7.js.map +7 -0
  40. package/dist/chunk-EXPWPWA4.js +654 -0
  41. package/dist/chunk-EXPWPWA4.js.map +7 -0
  42. package/dist/chunk-FHOCKJOW.js +766 -0
  43. package/dist/chunk-FHOCKJOW.js.map +7 -0
  44. package/dist/chunk-GPKVTIYJ.js +191 -0
  45. package/dist/chunk-GPKVTIYJ.js.map +7 -0
  46. package/dist/chunk-H5BCUDEN.js +794 -0
  47. package/dist/chunk-H5BCUDEN.js.map +7 -0
  48. package/dist/chunk-INJSFEKL.js +47 -0
  49. package/dist/chunk-INJSFEKL.js.map +7 -0
  50. package/dist/chunk-JX5ZQYTQ.js +12 -0
  51. package/dist/chunk-JX5ZQYTQ.js.map +7 -0
  52. package/dist/chunk-KQSHIOZK.js +24 -0
  53. package/dist/chunk-KQSHIOZK.js.map +7 -0
  54. package/dist/chunk-L6WKZEK4.js +1609 -0
  55. package/dist/chunk-L6WKZEK4.js.map +7 -0
  56. package/dist/chunk-LC4CL3YJ.js +124 -0
  57. package/dist/chunk-LC4CL3YJ.js.map +7 -0
  58. package/dist/chunk-MXSB7IOZ.js +1097 -0
  59. package/dist/chunk-MXSB7IOZ.js.map +7 -0
  60. package/dist/chunk-N5OHRWG2.js +249 -0
  61. package/dist/chunk-N5OHRWG2.js.map +7 -0
  62. package/dist/chunk-NQE3GGE3.js +19 -0
  63. package/dist/chunk-NQE3GGE3.js.map +7 -0
  64. package/dist/chunk-QF6YDTME.js +139 -0
  65. package/dist/chunk-QF6YDTME.js.map +7 -0
  66. package/dist/chunk-QTX7AJFQ.js +240 -0
  67. package/dist/chunk-QTX7AJFQ.js.map +7 -0
  68. package/dist/chunk-S3ZAJPYZ.js +515 -0
  69. package/dist/chunk-S3ZAJPYZ.js.map +7 -0
  70. package/dist/chunk-S5Y5IF2H.js +735 -0
  71. package/dist/chunk-S5Y5IF2H.js.map +7 -0
  72. package/dist/chunk-SBE6Y327.js +836 -0
  73. package/dist/chunk-SBE6Y327.js.map +7 -0
  74. package/dist/chunk-T25Z3JMG.js +17 -0
  75. package/dist/chunk-T25Z3JMG.js.map +7 -0
  76. package/dist/chunk-T6VKT5FR.js +196 -0
  77. package/dist/chunk-T6VKT5FR.js.map +7 -0
  78. package/dist/chunk-TSGGSPYD.js +151 -0
  79. package/dist/chunk-TSGGSPYD.js.map +7 -0
  80. package/dist/chunk-TY3CCSAT.js +24 -0
  81. package/dist/chunk-TY3CCSAT.js.map +7 -0
  82. package/dist/chunk-U224EQOS.js +34 -0
  83. package/dist/chunk-U224EQOS.js.map +7 -0
  84. package/dist/chunk-U7S4MEYP.js +95 -0
  85. package/dist/chunk-U7S4MEYP.js.map +7 -0
  86. package/dist/chunk-ULVAAZ2U.js +30517 -0
  87. package/dist/chunk-ULVAAZ2U.js.map +7 -0
  88. package/dist/chunk-WWLFALT7.js +128 -0
  89. package/dist/chunk-WWLFALT7.js.map +7 -0
  90. package/dist/chunk-XJQATPV7.js +23 -0
  91. package/dist/chunk-XJQATPV7.js.map +7 -0
  92. package/dist/chunk-XMGUQHMF.js +72 -0
  93. package/dist/chunk-XMGUQHMF.js.map +7 -0
  94. package/dist/chunk-XOMW5QTV.js +472 -0
  95. package/dist/chunk-XOMW5QTV.js.map +7 -0
  96. package/dist/chunk-Y7VZUSIM.js +1256 -0
  97. package/dist/chunk-Y7VZUSIM.js.map +7 -0
  98. package/dist/chunk-YVNBXMIP.js +511 -0
  99. package/dist/chunk-YVNBXMIP.js.map +7 -0
  100. package/dist/chunk-YYPJWXSA.js +145 -0
  101. package/dist/chunk-YYPJWXSA.js.map +7 -0
  102. package/dist/cli-BW34VKCN.js +3917 -0
  103. package/dist/cli-BW34VKCN.js.map +7 -0
  104. package/dist/commands-4CNZZBTE.js +46 -0
  105. package/dist/commands-4CNZZBTE.js.map +7 -0
  106. package/dist/config-XKRCXCSS.js +81 -0
  107. package/dist/config-XKRCXCSS.js.map +7 -0
  108. package/dist/context-T5CR3RP6.js +30 -0
  109. package/dist/context-T5CR3RP6.js.map +7 -0
  110. package/dist/costTracker-2G3ZI2JF.js +19 -0
  111. package/dist/costTracker-2G3ZI2JF.js.map +7 -0
  112. package/dist/customCommands-OCUMXZDN.js +25 -0
  113. package/dist/customCommands-OCUMXZDN.js.map +7 -0
  114. package/dist/env-DYDNFB4D.js +22 -0
  115. package/dist/env-DYDNFB4D.js.map +7 -0
  116. package/dist/index.js +34 -0
  117. package/dist/index.js.map +7 -0
  118. package/dist/kodeAgentSessionId-KTGFX2BE.js +13 -0
  119. package/dist/kodeAgentSessionId-KTGFX2BE.js.map +7 -0
  120. package/dist/kodeAgentSessionLoad-ZKR2VGHO.js +18 -0
  121. package/dist/kodeAgentSessionLoad-ZKR2VGHO.js.map +7 -0
  122. package/dist/kodeAgentSessionResume-NFZCTIBZ.js +16 -0
  123. package/dist/kodeAgentSessionResume-NFZCTIBZ.js.map +7 -0
  124. package/dist/kodeAgentStreamJson-VIXFTYL5.js +13 -0
  125. package/dist/kodeAgentStreamJson-VIXFTYL5.js.map +7 -0
  126. package/dist/kodeAgentStreamJsonSession-6CKTK6AF.js +131 -0
  127. package/dist/kodeAgentStreamJsonSession-6CKTK6AF.js.map +7 -0
  128. package/dist/kodeAgentStructuredStdio-SI5C7AAD.js +10 -0
  129. package/dist/kodeAgentStructuredStdio-SI5C7AAD.js.map +7 -0
  130. package/dist/kodeHooks-5RXJRDCY.js +36 -0
  131. package/dist/kodeHooks-5RXJRDCY.js.map +7 -0
  132. package/dist/llm-QJA3QMXR.js +3118 -0
  133. package/dist/llm-QJA3QMXR.js.map +7 -0
  134. package/dist/llmLazy-VCEV22DK.js +15 -0
  135. package/dist/llmLazy-VCEV22DK.js.map +7 -0
  136. package/dist/loader-CKNYMPCZ.js +28 -0
  137. package/dist/loader-CKNYMPCZ.js.map +7 -0
  138. package/dist/mcp-2SZTOKZX.js +49 -0
  139. package/dist/mcp-2SZTOKZX.js.map +7 -0
  140. package/dist/mentionProcessor-O7NWOH6S.js +211 -0
  141. package/dist/mentionProcessor-O7NWOH6S.js.map +7 -0
  142. package/dist/messages-PRKIHXMK.js +65 -0
  143. package/dist/messages-PRKIHXMK.js.map +7 -0
  144. package/dist/model-WG6RA25G.js +30 -0
  145. package/dist/model-WG6RA25G.js.map +7 -0
  146. package/dist/openai-VQLYFQ6B.js +29 -0
  147. package/dist/openai-VQLYFQ6B.js.map +7 -0
  148. package/dist/outputStyles-VQ57E3B6.js +28 -0
  149. package/dist/outputStyles-VQ57E3B6.js.map +7 -0
  150. package/dist/package.json +4 -0
  151. package/dist/pluginRuntime-NWOLU73K.js +218 -0
  152. package/dist/pluginRuntime-NWOLU73K.js.map +7 -0
  153. package/dist/pluginValidation-R7B6QQ6T.js +17 -0
  154. package/dist/pluginValidation-R7B6QQ6T.js.map +7 -0
  155. package/dist/prompts-W4V4Y67M.js +48 -0
  156. package/dist/prompts-W4V4Y67M.js.map +7 -0
  157. package/dist/query-GFFKKURO.js +50 -0
  158. package/dist/query-GFFKKURO.js.map +7 -0
  159. package/dist/responsesStreaming-2AIT6GHG.js +10 -0
  160. package/dist/responsesStreaming-2AIT6GHG.js.map +7 -0
  161. package/dist/ripgrep-SVBVC46X.js +17 -0
  162. package/dist/ripgrep-SVBVC46X.js.map +7 -0
  163. package/dist/skillMarketplace-5Z7Y6FTD.js +37 -0
  164. package/dist/skillMarketplace-5Z7Y6FTD.js.map +7 -0
  165. package/dist/state-X3R7BV7A.js +16 -0
  166. package/dist/state-X3R7BV7A.js.map +7 -0
  167. package/dist/theme-4VA64EWF.js +14 -0
  168. package/dist/theme-4VA64EWF.js.map +7 -0
  169. package/dist/toolPermissionContext-I3IXPVED.js +17 -0
  170. package/dist/toolPermissionContext-I3IXPVED.js.map +7 -0
  171. package/dist/toolPermissionSettings-35DJQEKG.js +18 -0
  172. package/dist/toolPermissionSettings-35DJQEKG.js.map +7 -0
  173. package/dist/tools-USOBTPOI.js +47 -0
  174. package/dist/tools-USOBTPOI.js.map +7 -0
  175. package/dist/userInput-NID2UYXG.js +312 -0
  176. package/dist/userInput-NID2UYXG.js.map +7 -0
  177. package/dist/uuid-VA3KVASX.js +9 -0
  178. package/dist/uuid-VA3KVASX.js.map +7 -0
  179. package/dist/yoga.wasm +0 -0
  180. package/package.json +135 -0
  181. package/scripts/binary-utils.cjs +61 -0
  182. package/scripts/cli-acp-wrapper.cjs +82 -0
  183. package/scripts/cli-wrapper.cjs +105 -0
  184. package/scripts/postinstall.js +144 -0
  185. package/web/dist/assets/index-COAJqX1Z.css +1 -0
  186. package/web/dist/assets/index-CzS_4LmC.js +179 -0
  187. package/web/dist/index.html +14 -0
  188. package/yoga.wasm +0 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/services/plugins/skillMarketplace.ts"],
4
+ "sourcesContent": ["import {\r\n copyFileSync,\r\n existsSync,\r\n lstatSync,\r\n mkdirSync,\r\n readFileSync,\r\n readdirSync,\r\n renameSync,\r\n rmSync,\r\n writeFileSync,\r\n} from 'node:fs'\r\nimport { randomUUID } from 'node:crypto'\r\nimport { homedir } from 'node:os'\r\nimport { basename, dirname, join, resolve, sep } from 'node:path'\r\nimport { unzipSync } from 'fflate'\r\nimport { z } from 'zod'\r\nimport { CONFIG_BASE_DIR } from '@constants/product'\r\nimport { getCwd } from '@utils/state'\r\nimport { getKodeBaseDir } from '@utils/config/env'\r\n\r\nconst KNOWN_MARKETPLACES_FILE = 'known_marketplaces.json'\r\nconst MARKETPLACES_CACHE_DIR = 'marketplaces'\r\nconst INSTALLED_SKILL_PLUGINS_FILE = 'installed-skill-plugins.json'\r\n\r\nconst MarketplaceSourceSchema = z.discriminatedUnion('source', [\r\n z.strictObject({\r\n source: z.literal('github'),\r\n repo: z.string().min(3),\r\n ref: z.string().optional(),\r\n path: z.string().optional(),\r\n }),\r\n z.strictObject({\r\n source: z.literal('git'),\r\n url: z.string().min(3),\r\n ref: z.string().optional(),\r\n path: z.string().optional(),\r\n }),\r\n z.strictObject({\r\n source: z.literal('url'),\r\n url: z.string().url(),\r\n headers: z.record(z.string(), z.string()).optional(),\r\n }),\r\n z.strictObject({\r\n source: z.literal('npm'),\r\n package: z.string().min(1),\r\n }),\r\n z.strictObject({\r\n source: z.literal('file'),\r\n path: z.string().min(1),\r\n }),\r\n z.strictObject({\r\n source: z.literal('directory'),\r\n path: z.string().min(1),\r\n }),\r\n])\r\n\r\nexport type MarketplaceSource = z.infer<typeof MarketplaceSourceSchema>\r\n\r\nconst MarketplacePathListSchema = z.preprocess(value => {\r\n if (typeof value === 'string') return [value]\r\n return value\r\n}, z.array(z.string()))\r\n\r\nconst MarketplacePluginSchema = z\r\n .object({\r\n name: z.string().min(1),\r\n description: z.string().optional(),\r\n source: z.string().optional().default('./'),\r\n strict: z.boolean().optional(),\r\n skills: MarketplacePathListSchema.optional(),\r\n commands: MarketplacePathListSchema.optional(),\r\n })\r\n .passthrough()\r\n\r\nexport const MarketplaceManifestSchema = z\r\n .object({\r\n $schema: z.string().optional(),\r\n description: z.string().optional(),\r\n name: z.string().min(1),\r\n owner: z\r\n .object({\r\n name: z.string().optional(),\r\n email: z.string().optional(),\r\n })\r\n .passthrough()\r\n .optional(),\r\n metadata: z.record(z.string(), z.unknown()).optional().default({}),\r\n plugins: z.array(MarketplacePluginSchema).default([]),\r\n })\r\n .passthrough()\r\n\r\nexport type MarketplaceManifest = z.infer<typeof MarketplaceManifestSchema>\r\nexport type PluginEntry = MarketplaceManifest['plugins'][number]\r\n\r\nconst KnownMarketplacesSchema = z.record(\r\n z.string(),\r\n z.strictObject({\r\n source: MarketplaceSourceSchema,\r\n installLocation: z.string().min(1),\r\n lastUpdated: z.string().min(1),\r\n autoUpdate: z.boolean().optional(),\r\n }),\r\n)\r\n\r\nexport type KnownMarketplacesConfig = z.infer<typeof KnownMarketplacesSchema>\r\n\r\nexport type PluginScope = 'user' | 'project' | 'local'\r\n\r\ntype InstalledSkillPlugin = {\r\n plugin: string\r\n marketplace: string\r\n scope: PluginScope\r\n kind?: 'skill-pack' | 'plugin-pack'\r\n isEnabled?: boolean\r\n projectPath?: string\r\n installedAt: string\r\n pluginRoot?: string\r\n skills: string[]\r\n commands: string[]\r\n sourceMarketplacePath: string\r\n}\r\n\r\ntype InstalledSkillPluginsFile = Record<string, InstalledSkillPlugin>\r\n\r\nfunction userKodeDir(): string {\r\n return getKodeBaseDir()\r\n}\r\n\r\nfunction normalizePluginScope(options?: {\r\n scope?: PluginScope\r\n project?: boolean\r\n}): PluginScope {\r\n if (\r\n options?.scope === 'user' ||\r\n options?.scope === 'project' ||\r\n options?.scope === 'local'\r\n ) {\r\n return options.scope\r\n }\r\n if (options?.project === true) return 'project'\r\n return 'user'\r\n}\r\n\r\nfunction scopeBaseDir(scope: PluginScope): string {\r\n if (scope === 'user') return userKodeDir()\r\n return join(getCwd(), CONFIG_BASE_DIR)\r\n}\r\n\r\nfunction scopeSkillsDir(scope: PluginScope): string {\r\n return join(scopeBaseDir(scope), 'skills')\r\n}\r\n\r\nfunction scopeCommandsDir(scope: PluginScope): string {\r\n return join(scopeBaseDir(scope), 'commands')\r\n}\r\n\r\nfunction scopeDisabledSkillsDir(scope: PluginScope): string {\r\n return join(scopeBaseDir(scope), 'skills.disabled')\r\n}\r\n\r\nfunction scopeDisabledCommandsDir(scope: PluginScope): string {\r\n return join(scopeBaseDir(scope), 'commands.disabled')\r\n}\r\n\r\nfunction scopeInstalledPluginsDir(scope: PluginScope): string {\r\n return join(scopeBaseDir(scope), 'plugins', 'installed')\r\n}\r\n\r\nfunction scopeInstalledPluginRoot(\r\n scope: PluginScope,\r\n plugin: string,\r\n marketplace: string,\r\n): string {\r\n return join(scopeInstalledPluginsDir(scope), plugin, marketplace)\r\n}\r\n\r\nfunction pluginsDir(): string {\r\n return join(userKodeDir(), 'plugins')\r\n}\r\n\r\nfunction knownMarketplacesConfigPath(): string {\r\n return join(pluginsDir(), KNOWN_MARKETPLACES_FILE)\r\n}\r\n\r\nfunction marketplaceCacheBaseDir(): string {\r\n return join(pluginsDir(), MARKETPLACES_CACHE_DIR)\r\n}\r\n\r\nfunction installedSkillPluginsPath(): string {\r\n return join(userKodeDir(), INSTALLED_SKILL_PLUGINS_FILE)\r\n}\r\n\r\nfunction ensureDir(path: string): void {\r\n mkdirSync(path, { recursive: true })\r\n}\r\n\r\nfunction readJsonFile<T>(path: string, fallback: T): T {\r\n try {\r\n if (!existsSync(path)) return fallback\r\n const raw = readFileSync(path, 'utf8')\r\n return JSON.parse(raw) as T\r\n } catch {\r\n return fallback\r\n }\r\n}\r\n\r\nfunction writeJsonFile(path: string, value: unknown): void {\r\n ensureDir(dirname(path))\r\n writeFileSync(path, `${JSON.stringify(value, null, 2)}\\n`, 'utf8')\r\n}\r\n\r\nfunction normalizeMarketplaceSubPath(path: string | undefined): string | null {\r\n if (!path) return null\r\n const trimmed = path\r\n .trim()\r\n .replace(/^\\.?\\//, '')\r\n .replace(/^\\/+/, '')\r\n if (!trimmed) return null\r\n if (trimmed.includes('..')) {\r\n throw new Error(`Marketplace path contains '..': ${path}`)\r\n }\r\n return trimmed.replace(/\\\\/g, '/').replace(/\\/+$/, '')\r\n}\r\n\r\nfunction safeJoinWithin(baseDir: string, relativePath: string): string {\r\n const normalized = relativePath.replace(/\\\\/g, '/')\r\n if (!normalized || normalized.startsWith('/') || normalized.includes('..')) {\r\n throw new Error(`Unsafe path in archive: ${relativePath}`)\r\n }\r\n const joined = resolve(baseDir, normalized.split('/').join(sep))\r\n const resolvedBase = resolve(baseDir)\r\n if (!joined.startsWith(resolvedBase + sep) && joined !== resolvedBase) {\r\n throw new Error(`Path traversal detected: ${relativePath}`)\r\n }\r\n return joined\r\n}\r\n\r\nfunction ensureEmptyDir(path: string): void {\r\n if (existsSync(path)) rmSync(path, { recursive: true, force: true })\r\n ensureDir(path)\r\n}\r\n\r\nfunction safeCopyDirectory(srcDir: string, destDir: string): void {\r\n ensureDir(destDir)\r\n const entries = readdirSync(srcDir, { withFileTypes: true })\r\n for (const entry of entries) {\r\n const srcPath = join(srcDir, entry.name)\r\n const destPath = join(destDir, entry.name)\r\n\r\n if (entry.isDirectory()) {\r\n safeCopyDirectory(srcPath, destPath)\r\n continue\r\n }\r\n\r\n if (entry.isFile()) {\r\n ensureDir(dirname(destPath))\r\n copyFileSync(srcPath, destPath)\r\n continue\r\n }\r\n\r\n }\r\n}\r\n\r\nfunction readMarketplaceFromDirectory(rootDir: string): MarketplaceManifest {\r\n const primaryMarketplaceFile = resolve(\r\n rootDir,\r\n '.newcraw-plugin',\r\n 'marketplace.json',\r\n )\r\n const legacyMarketplaceFile = resolve(\r\n rootDir,\r\n '.claude-plugin',\r\n 'marketplace.json',\r\n )\r\n const marketplaceFile = existsSync(primaryMarketplaceFile)\r\n ? primaryMarketplaceFile\r\n : legacyMarketplaceFile\r\n if (!existsSync(marketplaceFile)) {\r\n throw new Error(\r\n `Marketplace file not found (expected .newcraw-plugin/marketplace.json or .claude-plugin/marketplace.json)`,\r\n )\r\n }\r\n const raw = readFileSync(marketplaceFile, 'utf8')\r\n const parsed = MarketplaceManifestSchema.safeParse(JSON.parse(raw))\r\n if (!parsed.success) {\r\n throw new Error(\r\n `Invalid marketplace.json: ${parsed.error.issues.map(i => i.message).join('; ')}`,\r\n )\r\n }\r\n return parsed.data\r\n}\r\n\r\nexport function parsePluginSpec(spec: string): {\r\n plugin: string\r\n marketplace: string\r\n} {\r\n const trimmed = spec.trim()\r\n const parts = trimmed.split('@')\r\n if (parts.length !== 2) {\r\n throw new Error(\r\n `Invalid plugin spec: ${spec}. Expected format: <plugin>@<marketplace>`,\r\n )\r\n }\r\n const plugin = parts[0]!.trim()\r\n const marketplace = parts[1]!.trim()\r\n if (!plugin || !marketplace) {\r\n throw new Error(\r\n `Invalid plugin spec: ${spec}. Expected format: <plugin>@<marketplace>`,\r\n )\r\n }\r\n return { plugin, marketplace }\r\n}\r\n\r\nfunction resolvePluginForInstall(pluginInput: string): {\r\n plugin: string\r\n marketplace: string\r\n pluginSpec: string\r\n} {\r\n const trimmed = pluginInput.trim()\r\n if (!trimmed) throw new Error('Plugin is required')\r\n\r\n if (trimmed.includes('@')) {\r\n const resolved = parsePluginSpec(trimmed)\r\n return {\r\n ...resolved,\r\n pluginSpec: `${resolved.plugin}@${resolved.marketplace}`,\r\n }\r\n }\r\n\r\n const config = loadKnownMarketplaces()\r\n const matches: { marketplace: string; entry: PluginEntry }[] = []\r\n for (const [marketplace, entry] of Object.entries(config)) {\r\n try {\r\n const manifest = readMarketplaceFromDirectory(entry.installLocation)\r\n const found = manifest.plugins.find(p => p.name === trimmed)\r\n if (found) matches.push({ marketplace, entry: found })\r\n } catch {\r\n }\r\n }\r\n\r\n if (matches.length === 0) {\r\n const availableMarketplaces = Object.keys(config).sort().join(', ')\r\n throw new Error(\r\n `Plugin '${trimmed}' not found in any marketplace. Available marketplaces: ${availableMarketplaces || '(none)'}`,\r\n )\r\n }\r\n\r\n if (matches.length > 1) {\r\n const options = matches\r\n .map(m => `${trimmed}@${m.marketplace}`)\r\n .sort()\r\n .join(', ')\r\n throw new Error(\r\n `Plugin '${trimmed}' is available in multiple marketplaces. Use an explicit spec: ${options}`,\r\n )\r\n }\r\n\r\n return {\r\n plugin: trimmed,\r\n marketplace: matches[0]!.marketplace,\r\n pluginSpec: `${trimmed}@${matches[0]!.marketplace}`,\r\n }\r\n}\r\n\r\nfunction resolveInstalledPluginSpec(\r\n pluginInput: string,\r\n state: InstalledSkillPluginsFile,\r\n): string {\r\n const trimmed = pluginInput.trim()\r\n if (!trimmed) throw new Error('Plugin is required')\r\n\r\n if (trimmed.includes('@')) {\r\n parsePluginSpec(trimmed)\r\n return trimmed\r\n }\r\n\r\n const matches = Object.entries(state).filter(\r\n ([, record]) => record?.plugin === trimmed,\r\n )\r\n if (matches.length === 0) {\r\n throw new Error(`Plugin '${trimmed}' is not installed`)\r\n }\r\n if (matches.length > 1) {\r\n const options = matches\r\n .map(([spec]) => spec)\r\n .sort()\r\n .join(', ')\r\n throw new Error(\r\n `Plugin '${trimmed}' is installed from multiple marketplaces. Use an explicit spec: ${options}`,\r\n )\r\n }\r\n return matches[0]![0]\r\n}\r\n\r\nfunction baseDirForInstallRecord(record: InstalledSkillPlugin): string {\r\n if (record.scope === 'user') return userKodeDir()\r\n const projectPath =\r\n typeof record.projectPath === 'string' ? record.projectPath.trim() : ''\r\n if (!projectPath) {\r\n throw new Error(\r\n `Installed plugin '${record.plugin}@${record.marketplace}' is missing projectPath for scope=${record.scope}`,\r\n )\r\n }\r\n return join(projectPath, CONFIG_BASE_DIR)\r\n}\r\n\r\nfunction githubRepoFromUrl(input: string): string | null {\r\n const ssh = input.match(/^git@github\\.com:([^/]+\\/[^/]+?)(?:\\.git)?$/)\r\n if (ssh?.[1]) return ssh[1]\r\n const https = input.match(\r\n /^https?:\\/\\/github\\.com\\/([^/]+\\/[^/]+?)(?:\\.git)?$/,\r\n )\r\n if (https?.[1]) return https[1]\r\n return null\r\n}\r\n\r\nfunction parseRefAndPath(input: string): {\r\n base: string\r\n ref?: string\r\n path?: string\r\n} {\r\n const [beforeHash, hashPart] = input.split('#', 2)\r\n const [base, refPart] = beforeHash.split('@', 2)\r\n return {\r\n base,\r\n ref: refPart?.trim() || undefined,\r\n path: hashPart?.trim() || undefined,\r\n }\r\n}\r\n\r\nfunction parseMarketplaceSourceInput(sourceInput: string): MarketplaceSource {\r\n const raw = sourceInput.trim()\r\n if (!raw) throw new Error('Marketplace source is required')\r\n\r\n for (const prefix of [\r\n 'github:',\r\n 'git:',\r\n 'url:',\r\n 'npm:',\r\n 'file:',\r\n 'dir:',\r\n ] as const) {\r\n if (raw.startsWith(prefix)) {\r\n const rest = raw.slice(prefix.length).trim()\r\n const parsed = parseRefAndPath(rest)\r\n if (prefix === 'github:') {\r\n return {\r\n source: 'github',\r\n repo: parsed.base.trim(),\r\n ...(parsed.ref ? { ref: parsed.ref } : {}),\r\n ...(parsed.path ? { path: parsed.path } : {}),\r\n }\r\n }\r\n if (prefix === 'git:') {\r\n const repo = githubRepoFromUrl(parsed.base.trim())\r\n if (repo) {\r\n return {\r\n source: 'github',\r\n repo,\r\n ...(parsed.ref ? { ref: parsed.ref } : {}),\r\n ...(parsed.path ? { path: parsed.path } : {}),\r\n }\r\n }\r\n return {\r\n source: 'git',\r\n url: parsed.base.trim(),\r\n ...(parsed.ref ? { ref: parsed.ref } : {}),\r\n ...(parsed.path ? { path: parsed.path } : {}),\r\n }\r\n }\r\n if (prefix === 'url:') {\r\n return { source: 'url', url: rest }\r\n }\r\n if (prefix === 'npm:') {\r\n return { source: 'npm', package: rest }\r\n }\r\n if (prefix === 'file:') {\r\n return { source: 'file', path: rest }\r\n }\r\n if (prefix === 'dir:') {\r\n return { source: 'directory', path: rest }\r\n }\r\n }\r\n }\r\n\r\n const resolved = resolve(raw)\r\n if (existsSync(resolved)) {\r\n const stat = lstatSync(resolved)\r\n if (stat.isDirectory()) return { source: 'directory', path: resolved }\r\n if (stat.isFile()) return { source: 'file', path: resolved }\r\n throw new Error(`Marketplace source must be a directory or file: ${raw}`)\r\n }\r\n\r\n const parsed = parseRefAndPath(raw)\r\n if (/^[^/\\s]+\\/[^/\\s]+$/.test(parsed.base)) {\r\n return {\r\n source: 'github',\r\n repo: parsed.base,\r\n ...(parsed.ref ? { ref: parsed.ref } : {}),\r\n ...(parsed.path ? { path: parsed.path } : {}),\r\n }\r\n }\r\n\r\n const repo = githubRepoFromUrl(parsed.base)\r\n if (repo) {\r\n return {\r\n source: 'github',\r\n repo,\r\n ...(parsed.ref ? { ref: parsed.ref } : {}),\r\n ...(parsed.path ? { path: parsed.path } : {}),\r\n }\r\n }\r\n\r\n if (/^https?:\\/\\//.test(raw)) {\r\n return { source: 'url', url: raw }\r\n }\r\n\r\n throw new Error(\r\n `Unsupported marketplace source: ${sourceInput}. Use a local path, \"owner/repo\", or prefixes like github:, git:, url:, file:, dir:.`,\r\n )\r\n}\r\n\r\nasync function fetchBinary(url: string): Promise<Uint8Array> {\r\n const resp = await fetch(url, { method: 'GET' })\r\n if (!resp.ok) {\r\n throw new Error(\r\n `Failed to download ${url}: ${resp.status} ${resp.statusText}`,\r\n )\r\n }\r\n const buf = await resp.arrayBuffer()\r\n return new Uint8Array(buf)\r\n}\r\n\r\nasync function tryDownloadGithubZip(\r\n repo: string,\r\n ref: string,\r\n): Promise<Uint8Array> {\r\n const [owner, name] = repo.split('/', 2)\r\n if (!owner || !name) throw new Error(`Invalid GitHub repo: ${repo}`)\r\n\r\n const candidates = ref.startsWith('refs/')\r\n ? [ref]\r\n : [`refs/heads/${ref}`, `refs/tags/${ref}`]\r\n\r\n\t let lastError: Error | null = null\r\n\t for (const candidate of candidates) {\r\n\t const url = `https://codeload.github.com/${owner}/${name}/zip/${candidate}`\r\n\t try {\r\n\t return await fetchBinary(url)\r\n\t } catch (err) {\r\n\t lastError = err instanceof Error ? err : Error(String(err))\r\n\t }\r\n }\r\n throw lastError ?? new Error(`Failed to download GitHub repo ${repo}@${ref}`)\r\n}\r\n\r\nasync function cacheMarketplaceToTempDir(\r\n source: MarketplaceSource,\r\n tempDir: string,\r\n): Promise<void> {\r\n ensureEmptyDir(tempDir)\r\n\r\n if (source.source === 'directory') {\r\n const root = resolve(source.path)\r\n if (!existsSync(root) || !lstatSync(root).isDirectory()) {\r\n throw new Error(`Directory not found: ${source.path}`)\r\n }\r\n safeCopyDirectory(root, tempDir)\r\n return\r\n }\r\n\r\n if (source.source === 'file') {\r\n const file = resolve(source.path)\r\n if (!existsSync(file) || !lstatSync(file).isFile()) {\r\n throw new Error(`File not found: ${source.path}`)\r\n }\r\n const out = join(tempDir, '.newcraw-plugin')\r\n ensureDir(out)\r\n copyFileSync(file, join(out, 'marketplace.json'))\r\n return\r\n }\r\n\r\n if (source.source === 'github') {\r\n const pathWithin = normalizeMarketplaceSubPath(source.path)\r\n\r\n const preferredRef = source.ref?.trim() || ''\r\n const refsToTry = preferredRef ? [preferredRef] : ['main', 'master']\r\n\r\n let zip: Uint8Array | null = null\r\n let usedRef = preferredRef || 'main'\r\n let lastError: Error | null = null\r\n for (const ref of refsToTry) {\r\n try {\r\n zip = await tryDownloadGithubZip(source.repo, ref)\r\n usedRef = ref\r\n break\r\n } catch (err) {\r\n lastError = err instanceof Error ? err : Error(String(err))\r\n }\r\n }\r\n if (!zip)\r\n throw (\r\n lastError ?? new Error(`Failed to download GitHub repo ${source.repo}`)\r\n )\r\n\r\n const files = unzipSync(zip)\r\n const names = Object.keys(files).filter(Boolean)\r\n const topDir = names.length > 0 ? names[0]!.split('/')[0]! : ''\r\n const includePrefix = pathWithin\r\n ? `${topDir}/${pathWithin.replace(/\\/+$/, '')}/`\r\n : `${topDir}/`\r\n\r\n let extractedCount = 0\r\n for (const [name, data] of Object.entries(files)) {\r\n if (!name.startsWith(includePrefix)) continue\r\n const rel = name.slice(includePrefix.length)\r\n if (!rel) continue\r\n if (rel.endsWith('/')) {\r\n ensureDir(safeJoinWithin(tempDir, rel))\r\n continue\r\n }\r\n const dest = safeJoinWithin(tempDir, rel)\r\n ensureDir(dirname(dest))\r\n writeFileSync(dest, data)\r\n extractedCount++\r\n }\r\n\r\n if (extractedCount === 0) {\r\n throw new Error(\r\n `No files extracted from ${source.repo}@${usedRef}${pathWithin ? `#${pathWithin}` : ''}`,\r\n )\r\n }\r\n return\r\n }\r\n\r\n if (source.source === 'url') {\r\n const url = source.url\r\n if (url.toLowerCase().endsWith('.json')) {\r\n const data = await fetchBinary(url)\r\n const out = join(tempDir, '.newcraw-plugin')\r\n ensureDir(out)\r\n writeFileSync(join(out, 'marketplace.json'), Buffer.from(data))\r\n return\r\n }\r\n if (url.toLowerCase().endsWith('.zip')) {\r\n const zip = await fetchBinary(url)\r\n const files = unzipSync(zip)\r\n for (const [name, data] of Object.entries(files)) {\r\n if (!name || name.endsWith('/')) continue\r\n const dest = safeJoinWithin(tempDir, name)\r\n ensureDir(dirname(dest))\r\n writeFileSync(dest, data)\r\n }\r\n return\r\n }\r\n throw new Error(\r\n `Unsupported url marketplace source. Provide a .json or .zip URL: ${url}`,\r\n )\r\n }\r\n\r\n if (source.source === 'git') {\r\n const repo = githubRepoFromUrl(source.url)\r\n if (repo) {\r\n await cacheMarketplaceToTempDir(\r\n {\r\n source: 'github',\r\n repo,\r\n ...(source.ref ? { ref: source.ref } : {}),\r\n ...(source.path ? { path: source.path } : {}),\r\n },\r\n tempDir,\r\n )\r\n return\r\n }\r\n throw new Error(\r\n `git sources are not supported without GitHub conversion (url=${source.url})`,\r\n )\r\n }\r\n\r\n if (source.source === 'npm') {\r\n throw new Error(\r\n `npm marketplace sources are not supported yet (package=${source.package}). Install the package and add it as a local dir instead.`,\r\n )\r\n }\r\n}\r\n\r\nfunction loadKnownMarketplaces(): KnownMarketplacesConfig {\r\n const raw = readJsonFile<unknown>(knownMarketplacesConfigPath(), {})\r\n const parsed = KnownMarketplacesSchema.safeParse(raw)\r\n if (!parsed.success) {\r\n throw new Error(\r\n `Marketplace configuration is corrupted: ${parsed.error.issues.map(i => i.message).join('; ')}`,\r\n )\r\n }\r\n return parsed.data\r\n}\r\n\r\nfunction saveKnownMarketplaces(config: KnownMarketplacesConfig): void {\r\n const parsed = KnownMarketplacesSchema.safeParse(config)\r\n if (!parsed.success) {\r\n throw new Error(`Invalid marketplace config: ${parsed.error.message}`)\r\n }\r\n writeJsonFile(knownMarketplacesConfigPath(), parsed.data)\r\n}\r\n\r\nexport function listMarketplaces(): KnownMarketplacesConfig {\r\n return loadKnownMarketplaces()\r\n}\r\n\r\nexport async function addMarketplace(\r\n sourceInput: string,\r\n): Promise<{ name: string }> {\r\n const source = parseMarketplaceSourceInput(sourceInput)\r\n const validatedSource = MarketplaceSourceSchema.safeParse(source)\r\n if (!validatedSource.success) {\r\n throw new Error(\r\n `Invalid marketplace source: ${validatedSource.error.issues.map(i => i.message).join('; ')}`,\r\n )\r\n }\r\n\r\n const config = loadKnownMarketplaces()\r\n const cacheBase = marketplaceCacheBaseDir()\r\n ensureDir(cacheBase)\r\n\r\n const tempDir = join(cacheBase, `tmp-${randomUUID()}`)\r\n try {\r\n await cacheMarketplaceToTempDir(validatedSource.data, tempDir)\r\n const manifest = readMarketplaceFromDirectory(tempDir)\r\n const marketplaceName = manifest.name\r\n\r\n if (config[marketplaceName]) {\r\n throw new Error(\r\n `Marketplace '${marketplaceName}' is already installed. Remove it first to re-add.`,\r\n )\r\n }\r\n\r\n const installLocation = join(cacheBase, marketplaceName)\r\n if (existsSync(installLocation)) {\r\n throw new Error(\r\n `Marketplace cache directory already exists: ${installLocation}`,\r\n )\r\n }\r\n\r\n renameSync(tempDir, installLocation)\r\n config[marketplaceName] = {\r\n source: validatedSource.data,\r\n installLocation,\r\n lastUpdated: new Date().toISOString(),\r\n }\r\n saveKnownMarketplaces(config)\r\n return { name: marketplaceName }\r\n } catch (error) {\r\n if (existsSync(tempDir)) rmSync(tempDir, { recursive: true, force: true })\r\n throw error\r\n }\r\n}\r\n\r\nexport function removeMarketplace(name: string): void {\r\n const trimmed = name.trim()\r\n if (!trimmed) throw new Error('Marketplace name is required')\r\n\r\n const config = loadKnownMarketplaces()\r\n const entry = config[trimmed]\r\n if (!entry) throw new Error(`Marketplace '${trimmed}' not found`)\r\n\r\n delete config[trimmed]\r\n saveKnownMarketplaces(config)\r\n\r\n try {\r\n if (existsSync(entry.installLocation)) {\r\n rmSync(entry.installLocation, { recursive: true, force: true })\r\n }\r\n } catch {\r\n }\r\n}\r\n\r\nexport async function refreshMarketplaceAsync(name: string): Promise<void> {\r\n const trimmed = name.trim()\r\n if (!trimmed) throw new Error('Marketplace name is required')\r\n\r\n const config = loadKnownMarketplaces()\r\n const entry = config[trimmed]\r\n if (!entry) throw new Error(`Marketplace '${trimmed}' not found`)\r\n\r\n const cacheBase = marketplaceCacheBaseDir()\r\n ensureDir(cacheBase)\r\n\r\n const tempDir = join(cacheBase, `tmp-${randomUUID()}`)\r\n try {\r\n await cacheMarketplaceToTempDir(entry.source, tempDir)\r\n const manifest = readMarketplaceFromDirectory(tempDir)\r\n if (manifest.name !== trimmed) {\r\n throw new Error(\r\n `Marketplace name mismatch on refresh: expected ${trimmed}, got ${manifest.name}`,\r\n )\r\n }\r\n\r\n if (existsSync(entry.installLocation)) {\r\n rmSync(entry.installLocation, { recursive: true, force: true })\r\n }\r\n renameSync(tempDir, entry.installLocation)\r\n config[trimmed] = {\r\n ...entry,\r\n lastUpdated: new Date().toISOString(),\r\n }\r\n saveKnownMarketplaces(config)\r\n } catch (error) {\r\n if (existsSync(tempDir)) rmSync(tempDir, { recursive: true, force: true })\r\n throw error\r\n }\r\n}\r\n\r\nexport async function refreshAllMarketplacesAsync(\r\n onProgress?: (message: string) => void,\r\n): Promise<{ refreshed: string[]; failed: { name: string; error: string }[] }> {\r\n const config = loadKnownMarketplaces()\r\n const names = Object.keys(config).sort()\r\n\r\n const refreshed: string[] = []\r\n const failed: { name: string; error: string }[] = []\r\n\r\n for (const name of names) {\r\n try {\r\n onProgress?.(`Updating marketplace: ${name}...`)\r\n await refreshMarketplaceAsync(name)\r\n refreshed.push(name)\r\n } catch (error) {\r\n const message = error instanceof Error ? error.message : String(error)\r\n failed.push({ name, error: message })\r\n onProgress?.(`Failed to refresh marketplace ${name}: ${message}`)\r\n }\r\n }\r\n\r\n return { refreshed, failed }\r\n}\r\n\r\nexport function getMarketplaceManifest(marketplaceName: string): {\r\n manifest: MarketplaceManifest\r\n rootDir: string\r\n source: MarketplaceSource\r\n} {\r\n const config = loadKnownMarketplaces()\r\n const entry = config[marketplaceName]\r\n if (!entry) {\r\n const available = Object.keys(config).sort().join(', ')\r\n throw new Error(\r\n `Marketplace '${marketplaceName}' not found. Available marketplaces: ${available || '(none)'}`,\r\n )\r\n }\r\n const manifest = readMarketplaceFromDirectory(entry.installLocation)\r\n return { manifest, rootDir: entry.installLocation, source: entry.source }\r\n}\r\n\r\nfunction ensurePluginInstallState(): InstalledSkillPluginsFile {\r\n ensureDir(userKodeDir())\r\n const state = readJsonFile<Record<string, any>>(\r\n installedSkillPluginsPath(),\r\n {},\r\n )\r\n for (const record of Object.values(state)) {\r\n if (!record || typeof record !== 'object') continue\r\n if (\r\n record.scope !== 'user' &&\r\n record.scope !== 'project' &&\r\n record.scope !== 'local'\r\n ) {\r\n record.scope = 'user'\r\n }\r\n if (record.kind !== 'skill-pack' && record.kind !== 'plugin-pack') {\r\n record.kind =\r\n typeof record.pluginRoot === 'string' ? 'plugin-pack' : 'skill-pack'\r\n }\r\n if (record.isEnabled === undefined) record.isEnabled = true\r\n }\r\n return state as InstalledSkillPluginsFile\r\n}\r\n\r\nfunction savePluginInstallState(state: InstalledSkillPluginsFile): void {\r\n writeJsonFile(installedSkillPluginsPath(), state)\r\n}\r\n\r\nexport function installSkillPlugin(\r\n pluginInput: string,\r\n options?: { scope?: PluginScope; project?: boolean; force?: boolean },\r\n): {\r\n pluginSpec: string\r\n installedSkills: string[]\r\n installedCommands: string[]\r\n} {\r\n const scope = normalizePluginScope(options)\r\n const { plugin, marketplace, pluginSpec } =\r\n resolvePluginForInstall(pluginInput)\r\n const { manifest, rootDir, source } = getMarketplaceManifest(marketplace)\r\n\r\n const entry = manifest.plugins.find(p => p.name === plugin)\r\n if (!entry) {\r\n const available = manifest.plugins\r\n .map(p => p.name)\r\n .sort()\r\n .join(', ')\r\n throw new Error(\r\n `Plugin '${plugin}' not found in marketplace '${marketplace}'. Available plugins: ${available || '(none)'}`,\r\n )\r\n }\r\n\r\n const installState = ensurePluginInstallState()\r\n const existing = installState[pluginSpec]\r\n if (existing && existing.scope !== scope && options?.force !== true) {\r\n throw new Error(\r\n `Plugin '${pluginSpec}' is already installed with scope=${existing.scope}. Uninstall it first to install with scope=${scope}.`,\r\n )\r\n }\r\n if (existing && options?.force !== true) {\r\n throw new Error(\r\n `Plugin '${pluginSpec}' is already installed. Re-run with --force to reinstall.`,\r\n )\r\n }\r\n\r\n const entrySourceBase = resolve(rootDir, entry.source ?? './')\r\n const primaryManifestPath = join(\r\n entrySourceBase,\r\n '.newcraw-plugin',\r\n 'plugin.json',\r\n )\r\n const legacyManifestPath = join(\r\n entrySourceBase,\r\n '.claude-plugin',\r\n 'plugin.json',\r\n )\r\n const pluginManifestPath = existsSync(primaryManifestPath)\r\n ? primaryManifestPath\r\n : legacyManifestPath\r\n\r\n if (\r\n existsSync(pluginManifestPath) &&\r\n lstatSync(pluginManifestPath).isFile()\r\n ) {\r\n const pluginRoot = scopeInstalledPluginRoot(scope, plugin, marketplace)\r\n if (existsSync(pluginRoot) && options?.force !== true) {\r\n throw new Error(`Destination already exists: ${pluginRoot}`)\r\n }\r\n ensureEmptyDir(pluginRoot)\r\n safeCopyDirectory(entrySourceBase, pluginRoot)\r\n\r\n installState[pluginSpec] = {\r\n plugin,\r\n marketplace,\r\n scope,\r\n kind: 'plugin-pack',\r\n pluginRoot,\r\n isEnabled: true,\r\n projectPath: scope === 'user' ? undefined : getCwd(),\r\n installedAt: new Date().toISOString(),\r\n skills: [],\r\n commands: [],\r\n sourceMarketplacePath:\r\n source.source === 'file' || source.source === 'directory'\r\n ? source.path\r\n : source.source === 'github'\r\n ? `github:${source.repo}`\r\n : source.source === 'url'\r\n ? source.url\r\n : source.source === 'git'\r\n ? source.url\r\n : `npm:${source.package}`,\r\n }\r\n savePluginInstallState(installState)\r\n\r\n return { pluginSpec, installedSkills: [], installedCommands: [] }\r\n }\r\n\r\n const skillsDestBase = scopeSkillsDir(scope)\r\n const commandsDestBase = join(scopeCommandsDir(scope), plugin, marketplace)\r\n\r\n ensureDir(skillsDestBase)\r\n ensureDir(commandsDestBase)\r\n\r\n const installedSkills: string[] = []\r\n const installedCommands: string[] = []\r\n\r\n const skillPaths = entry.skills ?? []\r\n for (const rel of skillPaths) {\r\n const src = safeJoinWithin(entrySourceBase, rel)\r\n if (!existsSync(src) || !lstatSync(src).isDirectory()) {\r\n throw new Error(`Skill path not found or not a directory: ${src}`)\r\n }\r\n const skillName = basename(src)\r\n const dest = join(skillsDestBase, skillName)\r\n\r\n if (existsSync(dest) && options?.force !== true) {\r\n throw new Error(`Destination already exists: ${dest}`)\r\n }\r\n ensureEmptyDir(dest)\r\n safeCopyDirectory(src, dest)\r\n installedSkills.push(skillName)\r\n }\r\n\r\n const commandPaths = entry.commands ?? []\r\n for (const rel of commandPaths) {\r\n const src = safeJoinWithin(entrySourceBase, rel)\r\n if (!existsSync(src)) {\r\n throw new Error(`Command path not found: ${src}`)\r\n }\r\n const stat = lstatSync(src)\r\n if (stat.isDirectory()) {\r\n const dest = join(commandsDestBase, basename(src))\r\n if (existsSync(dest) && options?.force !== true) {\r\n throw new Error(`Destination already exists: ${dest}`)\r\n }\r\n ensureEmptyDir(dest)\r\n safeCopyDirectory(src, dest)\r\n installedCommands.push(dest)\r\n continue\r\n }\r\n if (stat.isFile()) {\r\n const dest = join(commandsDestBase, basename(src))\r\n ensureDir(dirname(dest))\r\n if (existsSync(dest) && options?.force !== true) {\r\n throw new Error(`Destination already exists: ${dest}`)\r\n }\r\n copyFileSync(src, dest)\r\n installedCommands.push(dest)\r\n continue\r\n }\r\n }\r\n\r\n installState[pluginSpec] = {\r\n plugin,\r\n marketplace,\r\n scope,\r\n kind: 'skill-pack',\r\n isEnabled: true,\r\n projectPath: scope === 'user' ? undefined : getCwd(),\r\n installedAt: new Date().toISOString(),\r\n skills: installedSkills,\r\n commands: installedCommands,\r\n sourceMarketplacePath:\r\n source.source === 'file' || source.source === 'directory'\r\n ? source.path\r\n : source.source === 'github'\r\n ? `github:${source.repo}`\r\n : source.source === 'url'\r\n ? source.url\r\n : source.source === 'git'\r\n ? source.url\r\n : `npm:${source.package}`,\r\n }\r\n savePluginInstallState(installState)\r\n\r\n return { pluginSpec, installedSkills, installedCommands }\r\n}\r\n\r\nexport function uninstallSkillPlugin(\r\n pluginInput: string,\r\n options?: { scope?: PluginScope; project?: boolean },\r\n): { pluginSpec: string; removedSkills: string[]; removedCommands: string[] } {\r\n const requestedScope = normalizePluginScope(options)\r\n const state = ensurePluginInstallState()\r\n const pluginSpec = resolveInstalledPluginSpec(pluginInput, state)\r\n const record = state[pluginSpec]\r\n if (!record) {\r\n throw new Error(`Plugin '${pluginSpec}' is not installed`)\r\n }\r\n\r\n if (record.scope !== requestedScope) {\r\n throw new Error(\r\n `Plugin '${pluginSpec}' is installed with scope=${record.scope}. Re-run with --scope ${record.scope}.`,\r\n )\r\n }\r\n if (record.scope !== 'user') {\r\n const projectPath = record.projectPath?.trim() || ''\r\n const cwd = getCwd()\r\n if (!projectPath || projectPath !== cwd) {\r\n throw new Error(\r\n `Plugin '${pluginSpec}' is installed for a different directory. Expected cwd=${projectPath || '(missing)'}, got cwd=${cwd}`,\r\n )\r\n }\r\n }\r\n\r\n if (record.kind === 'plugin-pack') {\r\n const baseDir = baseDirForInstallRecord(record)\r\n const pluginRoot =\r\n typeof record.pluginRoot === 'string' && record.pluginRoot.trim()\r\n ? record.pluginRoot\r\n : join(\r\n baseDir,\r\n 'plugins',\r\n 'installed',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n\r\n const removedCommands: string[] = []\r\n if (existsSync(pluginRoot)) {\r\n rmSync(pluginRoot, { recursive: true, force: true })\r\n removedCommands.push(pluginRoot)\r\n }\r\n\r\n delete state[pluginSpec]\r\n savePluginInstallState(state)\r\n\r\n return { pluginSpec, removedSkills: [], removedCommands }\r\n }\r\n\r\n const baseDir = baseDirForInstallRecord(record)\r\n const skillsDestBase = join(baseDir, 'skills')\r\n const commandsDestBase = join(\r\n baseDir,\r\n 'commands',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n const disabledSkillsBase = join(\r\n baseDir,\r\n 'skills.disabled',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n const disabledCommandsBase = join(\r\n baseDir,\r\n 'commands.disabled',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n\r\n const removedSkills: string[] = []\r\n for (const skillName of record.skills) {\r\n const dest = join(skillsDestBase, skillName)\r\n if (existsSync(dest)) rmSync(dest, { recursive: true, force: true })\r\n const disabledDest = join(disabledSkillsBase, skillName)\r\n if (existsSync(disabledDest))\r\n rmSync(disabledDest, { recursive: true, force: true })\r\n removedSkills.push(skillName)\r\n }\r\n\r\n const removedCommands: string[] = []\r\n if (existsSync(commandsDestBase)) {\r\n rmSync(commandsDestBase, { recursive: true, force: true })\r\n removedCommands.push(commandsDestBase)\r\n }\r\n if (existsSync(disabledCommandsBase)) {\r\n rmSync(disabledCommandsBase, { recursive: true, force: true })\r\n removedCommands.push(disabledCommandsBase)\r\n }\r\n\r\n delete state[pluginSpec]\r\n savePluginInstallState(state)\r\n\r\n return { pluginSpec, removedSkills, removedCommands }\r\n}\r\n\r\nexport function disableSkillPlugin(\r\n pluginInput: string,\r\n options?: { scope?: PluginScope; project?: boolean },\r\n): {\r\n pluginSpec: string\r\n disabledSkills: string[]\r\n disabledCommands: string[]\r\n} {\r\n const requestedScope = normalizePluginScope(options)\r\n const state = ensurePluginInstallState()\r\n const pluginSpec = resolveInstalledPluginSpec(pluginInput, state)\r\n const record = state[pluginSpec]\r\n if (!record) throw new Error(`Plugin '${pluginSpec}' is not installed`)\r\n\r\n if (record.scope !== requestedScope) {\r\n throw new Error(\r\n `Plugin '${pluginSpec}' is installed with scope=${record.scope}. Re-run with --scope ${record.scope}.`,\r\n )\r\n }\r\n if (record.scope !== 'user') {\r\n const projectPath = record.projectPath?.trim() || ''\r\n const cwd = getCwd()\r\n if (!projectPath || projectPath !== cwd) {\r\n throw new Error(\r\n `Plugin '${pluginSpec}' is installed for a different directory. Expected cwd=${projectPath || '(missing)'}, got cwd=${cwd}`,\r\n )\r\n }\r\n }\r\n\r\n if (record.isEnabled === false) {\r\n return { pluginSpec, disabledSkills: [], disabledCommands: [] }\r\n }\r\n\r\n if (record.kind === 'plugin-pack') {\r\n record.isEnabled = false\r\n state[pluginSpec] = record\r\n savePluginInstallState(state)\r\n return { pluginSpec, disabledSkills: [], disabledCommands: [] }\r\n }\r\n\r\n const baseDir = baseDirForInstallRecord(record)\r\n const skillsDir = join(baseDir, 'skills')\r\n const commandsDir = join(\r\n baseDir,\r\n 'commands',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n const disabledSkillsBase = join(\r\n baseDir,\r\n 'skills.disabled',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n const disabledCommandsDir = join(\r\n baseDir,\r\n 'commands.disabled',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n\r\n const disabledSkills: string[] = []\r\n for (const skillName of record.skills) {\r\n const src = join(skillsDir, skillName)\r\n if (!existsSync(src)) continue\r\n const dest = join(disabledSkillsBase, skillName)\r\n ensureDir(dirname(dest))\r\n if (existsSync(dest)) rmSync(dest, { recursive: true, force: true })\r\n renameSync(src, dest)\r\n disabledSkills.push(skillName)\r\n }\r\n\r\n const disabledCommands: string[] = []\r\n if (existsSync(commandsDir)) {\r\n ensureDir(dirname(disabledCommandsDir))\r\n if (existsSync(disabledCommandsDir)) {\r\n rmSync(disabledCommandsDir, { recursive: true, force: true })\r\n }\r\n renameSync(commandsDir, disabledCommandsDir)\r\n disabledCommands.push(disabledCommandsDir)\r\n }\r\n\r\n record.isEnabled = false\r\n state[pluginSpec] = record\r\n savePluginInstallState(state)\r\n\r\n return { pluginSpec, disabledSkills, disabledCommands }\r\n}\r\n\r\nexport function enableSkillPlugin(\r\n pluginInput: string,\r\n options?: { scope?: PluginScope; project?: boolean },\r\n): { pluginSpec: string; enabledSkills: string[]; enabledCommands: string[] } {\r\n const requestedScope = normalizePluginScope(options)\r\n const state = ensurePluginInstallState()\r\n const pluginSpec = resolveInstalledPluginSpec(pluginInput, state)\r\n const record = state[pluginSpec]\r\n if (!record) throw new Error(`Plugin '${pluginSpec}' is not installed`)\r\n\r\n if (record.scope !== requestedScope) {\r\n throw new Error(\r\n `Plugin '${pluginSpec}' is installed with scope=${record.scope}. Re-run with --scope ${record.scope}.`,\r\n )\r\n }\r\n if (record.scope !== 'user') {\r\n const projectPath = record.projectPath?.trim() || ''\r\n const cwd = getCwd()\r\n if (!projectPath || projectPath !== cwd) {\r\n throw new Error(\r\n `Plugin '${pluginSpec}' is installed for a different directory. Expected cwd=${projectPath || '(missing)'}, got cwd=${cwd}`,\r\n )\r\n }\r\n }\r\n\r\n if (record.isEnabled !== false) {\r\n return { pluginSpec, enabledSkills: [], enabledCommands: [] }\r\n }\r\n\r\n if (record.kind === 'plugin-pack') {\r\n record.isEnabled = true\r\n state[pluginSpec] = record\r\n savePluginInstallState(state)\r\n return { pluginSpec, enabledSkills: [], enabledCommands: [] }\r\n }\r\n\r\n const baseDir = baseDirForInstallRecord(record)\r\n const skillsDir = join(baseDir, 'skills')\r\n const commandsDir = join(\r\n baseDir,\r\n 'commands',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n const disabledSkillsBase = join(\r\n baseDir,\r\n 'skills.disabled',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n const disabledCommandsDir = join(\r\n baseDir,\r\n 'commands.disabled',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n\r\n const enabledSkills: string[] = []\r\n for (const skillName of record.skills) {\r\n const src = join(disabledSkillsBase, skillName)\r\n if (!existsSync(src)) continue\r\n const dest = join(skillsDir, skillName)\r\n ensureDir(dirname(dest))\r\n if (existsSync(dest)) {\r\n throw new Error(`Destination already exists: ${dest}`)\r\n }\r\n renameSync(src, dest)\r\n enabledSkills.push(skillName)\r\n }\r\n\r\n const enabledCommands: string[] = []\r\n if (existsSync(disabledCommandsDir)) {\r\n ensureDir(dirname(commandsDir))\r\n if (existsSync(commandsDir)) {\r\n throw new Error(`Destination already exists: ${commandsDir}`)\r\n }\r\n renameSync(disabledCommandsDir, commandsDir)\r\n enabledCommands.push(commandsDir)\r\n }\r\n\r\n record.isEnabled = true\r\n state[pluginSpec] = record\r\n savePluginInstallState(state)\r\n\r\n return { pluginSpec, enabledSkills, enabledCommands }\r\n}\r\n\r\nexport function listInstalledSkillPlugins(): InstalledSkillPluginsFile {\r\n return ensurePluginInstallState()\r\n}\r\n\r\nexport function listEnabledInstalledPluginPackRoots(): string[] {\r\n const state = ensurePluginInstallState()\r\n const cwd = getCwd()\r\n const roots: string[] = []\r\n\r\n for (const spec of Object.keys(state).sort()) {\r\n const record = state[spec]\r\n if (!record || record.kind !== 'plugin-pack') continue\r\n if (record.isEnabled === false) continue\r\n\r\n if (record.scope !== 'user') {\r\n const projectPath = record.projectPath?.trim() || ''\r\n if (!projectPath || projectPath !== cwd) continue\r\n }\r\n\r\n const baseDir = baseDirForInstallRecord(record)\r\n const pluginRoot =\r\n typeof record.pluginRoot === 'string' && record.pluginRoot.trim()\r\n ? record.pluginRoot\r\n : join(\r\n baseDir,\r\n 'plugins',\r\n 'installed',\r\n record.plugin,\r\n record.marketplace,\r\n )\r\n\r\n try {\r\n if (!existsSync(pluginRoot) || !lstatSync(pluginRoot).isDirectory())\r\n continue\r\n roots.push(pluginRoot)\r\n } catch {\r\n continue\r\n }\r\n }\r\n\r\n return roots\r\n}\r\n"],
5
+ "mappings": "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",
6
+ "names": ["parsed", "repo", "baseDir", "removedCommands"]
7
+ }
@@ -0,0 +1,249 @@
1
+ import { createRequire as __newcrawCreateRequire } from "node:module";
2
+ const require = __newcrawCreateRequire(import.meta.url);
3
+ import {
4
+ AbortError
5
+ } from "./chunk-KQSHIOZK.js";
6
+
7
+ // src/utils/protocol/kodeAgentStructuredStdio.ts
8
+ import { createInterface } from "node:readline";
9
+ function isRecord(value) {
10
+ return Boolean(value) && typeof value === "object" && !Array.isArray(value);
11
+ }
12
+ function tryParseLine(line) {
13
+ if (!line.trim()) return null;
14
+ try {
15
+ const parsed = JSON.parse(line);
16
+ if (!isRecord(parsed)) return null;
17
+ if (typeof parsed.type !== "string") return null;
18
+ return parsed;
19
+ } catch {
20
+ return null;
21
+ }
22
+ }
23
+ function makeRequestId() {
24
+ return Math.random().toString(36).slice(2, 15);
25
+ }
26
+ var KodeAgentStructuredStdio = class {
27
+ constructor(input, output, opts = {}) {
28
+ this.input = input;
29
+ this.output = output;
30
+ this.opts = opts;
31
+ }
32
+ started = false;
33
+ inputClosed = false;
34
+ pendingRequests = /* @__PURE__ */ new Map();
35
+ queuedUserMessages = [];
36
+ awaitingUserWaiters = [];
37
+ start() {
38
+ if (this.started) return;
39
+ this.started = true;
40
+ const rl = createInterface({ input: this.input });
41
+ (async () => {
42
+ for await (const line of rl) {
43
+ this.handleLine(String(line));
44
+ }
45
+ })().catch(() => {
46
+ }).finally(() => {
47
+ this.inputClosed = true;
48
+ rl.close();
49
+ this.rejectAllPending(new Error("Stream closed"));
50
+ this.rejectAllUserWaiters(new Error("Stream closed"));
51
+ });
52
+ }
53
+ rejectAllPending(err) {
54
+ for (const pending of this.pendingRequests.values()) {
55
+ pending.cleanup();
56
+ pending.reject(err);
57
+ }
58
+ this.pendingRequests.clear();
59
+ }
60
+ rejectAllUserWaiters(err) {
61
+ for (const waiter of this.awaitingUserWaiters.splice(0)) {
62
+ waiter.reject(err);
63
+ }
64
+ }
65
+ write(obj) {
66
+ this.output.write(JSON.stringify(obj) + "\n");
67
+ }
68
+ sendControlResponseSuccess(requestId, response) {
69
+ this.write({
70
+ type: "control_response",
71
+ response: {
72
+ subtype: "success",
73
+ request_id: requestId,
74
+ ...response !== void 0 ? { response } : {}
75
+ }
76
+ });
77
+ }
78
+ sendControlResponseError(requestId, error) {
79
+ this.write({
80
+ type: "control_response",
81
+ response: {
82
+ subtype: "error",
83
+ request_id: requestId,
84
+ error
85
+ }
86
+ });
87
+ }
88
+ sendControlCancelRequest(requestId) {
89
+ this.write({
90
+ type: "control_cancel_request",
91
+ request_id: requestId
92
+ });
93
+ }
94
+ handleLine(line) {
95
+ const msg = tryParseLine(line);
96
+ if (!msg) return;
97
+ if (msg.type === "keep_alive") {
98
+ return;
99
+ }
100
+ if (msg.type === "user") {
101
+ const userMsg = msg;
102
+ const waiter = this.awaitingUserWaiters.shift();
103
+ if (waiter) waiter.resolve(userMsg);
104
+ else this.queuedUserMessages.push(userMsg);
105
+ return;
106
+ }
107
+ if (msg.type === "control_response") {
108
+ const responseMsg = msg;
109
+ const requestId = responseMsg.response?.request_id;
110
+ if (typeof requestId !== "string" || !requestId) return;
111
+ const pending = this.pendingRequests.get(requestId);
112
+ if (!pending) return;
113
+ pending.cleanup();
114
+ this.pendingRequests.delete(requestId);
115
+ pending.resolve(responseMsg.response);
116
+ return;
117
+ }
118
+ if (msg.type === "control_request") {
119
+ const requestMsg = msg;
120
+ const requestId = requestMsg.request_id;
121
+ const subtype = requestMsg.request?.subtype;
122
+ if (typeof requestId !== "string" || !requestId) return;
123
+ if (typeof subtype !== "string" || !subtype) {
124
+ this.sendControlResponseError(
125
+ requestId,
126
+ "Invalid control request (missing subtype)"
127
+ );
128
+ return;
129
+ }
130
+ if (subtype === "interrupt") {
131
+ this.opts.onInterrupt?.();
132
+ this.sendControlResponseSuccess(requestId);
133
+ return;
134
+ }
135
+ const handler = this.opts.onControlRequest;
136
+ if (handler) {
137
+ Promise.resolve().then(async () => await handler(requestMsg)).then(
138
+ (response) => this.sendControlResponseSuccess(requestId, response)
139
+ ).catch(
140
+ (err) => this.sendControlResponseError(
141
+ requestId,
142
+ err instanceof Error ? err.message : String(err)
143
+ )
144
+ );
145
+ return;
146
+ }
147
+ this.sendControlResponseError(
148
+ requestId,
149
+ `Unsupported control request subtype: ${subtype}`
150
+ );
151
+ }
152
+ }
153
+ async nextUserMessage(args) {
154
+ if (this.queuedUserMessages.length > 0) {
155
+ return this.queuedUserMessages.shift();
156
+ }
157
+ if (this.inputClosed) {
158
+ throw new Error("Stream closed");
159
+ }
160
+ const timeoutMs = typeof args?.timeoutMs === "number" && Number.isFinite(args.timeoutMs) ? Math.max(0, args.timeoutMs) : null;
161
+ return await new Promise((resolve, reject) => {
162
+ let settled = false;
163
+ let waiter = null;
164
+ const onAbort = () => {
165
+ cleanup();
166
+ reject(new AbortError("User input aborted."));
167
+ };
168
+ const onTimeout = () => {
169
+ cleanup();
170
+ reject(new Error("Timed out waiting for user input."));
171
+ };
172
+ const cleanup = () => {
173
+ if (settled) return;
174
+ settled = true;
175
+ if (args?.signal) args.signal.removeEventListener("abort", onAbort);
176
+ if (timeoutId) clearTimeout(timeoutId);
177
+ if (waiter) {
178
+ const idx = this.awaitingUserWaiters.indexOf(waiter);
179
+ if (idx >= 0) this.awaitingUserWaiters.splice(idx, 1);
180
+ }
181
+ };
182
+ let timeoutId = null;
183
+ if (timeoutMs !== null) timeoutId = setTimeout(onTimeout, timeoutMs);
184
+ if (args?.signal)
185
+ args.signal.addEventListener("abort", onAbort, { once: true });
186
+ waiter = {
187
+ resolve: (msg) => {
188
+ cleanup();
189
+ resolve(msg);
190
+ },
191
+ reject: (err) => {
192
+ cleanup();
193
+ reject(err);
194
+ }
195
+ };
196
+ this.awaitingUserWaiters.push(waiter);
197
+ });
198
+ }
199
+ async sendRequest(request, args) {
200
+ if (this.inputClosed) {
201
+ throw new Error("Stream closed");
202
+ }
203
+ if (args?.signal?.aborted) {
204
+ throw new AbortError("Request aborted.");
205
+ }
206
+ const requestId = makeRequestId();
207
+ this.write({ type: "control_request", request_id: requestId, request });
208
+ const timeoutMs = typeof args?.timeoutMs === "number" && Number.isFinite(args.timeoutMs) ? Math.max(0, args.timeoutMs) : null;
209
+ return await new Promise((resolve, reject) => {
210
+ const onAbort = () => {
211
+ this.sendControlCancelRequest(requestId);
212
+ this.pendingRequests.delete(requestId);
213
+ cleanup();
214
+ reject(new AbortError("Request aborted."));
215
+ };
216
+ const onTimeout = () => {
217
+ this.sendControlCancelRequest(requestId);
218
+ this.pendingRequests.delete(requestId);
219
+ cleanup();
220
+ reject(new Error("Timed out waiting for control response."));
221
+ };
222
+ const cleanup = () => {
223
+ if (args?.signal) args.signal.removeEventListener("abort", onAbort);
224
+ if (timeoutId) clearTimeout(timeoutId);
225
+ };
226
+ let timeoutId = null;
227
+ if (timeoutMs !== null) timeoutId = setTimeout(onTimeout, timeoutMs);
228
+ if (args?.signal)
229
+ args.signal.addEventListener("abort", onAbort, { once: true });
230
+ this.pendingRequests.set(requestId, {
231
+ cleanup,
232
+ resolve: (response) => {
233
+ if (response.subtype === "error") {
234
+ reject(
235
+ new Error(response.error || "Unknown control response error")
236
+ );
237
+ return;
238
+ }
239
+ resolve(response.response ?? null);
240
+ },
241
+ reject
242
+ });
243
+ });
244
+ }
245
+ };
246
+
247
+ export {
248
+ KodeAgentStructuredStdio
249
+ };
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/utils/protocol/kodeAgentStructuredStdio.ts"],
4
+ "sourcesContent": ["import { createInterface } from 'node:readline'\r\nimport { AbortError } from '@utils/text/errors'\r\n\r\ntype ControlRequestMessage = {\r\n type: 'control_request'\r\n request_id: string\r\n request: { subtype: string; [key: string]: unknown }\r\n}\r\n\r\ntype KeepAliveMessage = { type: 'keep_alive' }\r\n\r\ntype ControlResponseMessage = {\r\n type: 'control_response'\r\n response: {\r\n request_id: string\r\n subtype: 'success' | 'error'\r\n response?: unknown\r\n error?: string\r\n }\r\n}\r\n\r\ntype ControlCancelRequestMessage = {\r\n type: 'control_cancel_request'\r\n request_id: string\r\n}\r\n\r\ntype UserInputMessage = {\r\n type: 'user'\r\n uuid?: string\r\n parent_tool_use_id?: string | null\r\n message: { role: 'user'; content: unknown }\r\n}\r\n\r\ntype StructuredInputMessage =\r\n | ControlRequestMessage\r\n | ControlResponseMessage\r\n | ControlCancelRequestMessage\r\n | UserInputMessage\r\n | KeepAliveMessage\r\n | { type: string; [key: string]: unknown }\r\n\r\nfunction isRecord(value: unknown): value is Record<string, unknown> {\r\n return Boolean(value) && typeof value === 'object' && !Array.isArray(value)\r\n}\r\n\r\nfunction tryParseLine(line: string): StructuredInputMessage | null {\r\n if (!line.trim()) return null\r\n try {\r\n const parsed = JSON.parse(line) as unknown\r\n if (!isRecord(parsed)) return null\r\n if (typeof parsed.type !== 'string') return null\r\n return parsed as StructuredInputMessage\r\n } catch {\r\n return null\r\n }\r\n}\r\n\r\nfunction makeRequestId(): string {\r\n return Math.random().toString(36).slice(2, 15)\r\n}\r\n\r\nexport class KodeAgentStructuredStdio {\r\n private started = false\r\n private inputClosed = false\r\n private pendingRequests = new Map<\r\n string,\r\n {\r\n resolve: (msg: ControlResponseMessage['response']) => void\r\n reject: (err: Error) => void\r\n cleanup: () => void\r\n }\r\n >()\r\n private queuedUserMessages: UserInputMessage[] = []\r\n private awaitingUserWaiters: Array<{\r\n resolve: (msg: UserInputMessage) => void\r\n reject: (err: Error) => void\r\n }> = []\r\n\r\n constructor(\r\n private input: NodeJS.ReadableStream,\r\n private output: NodeJS.WritableStream,\r\n private opts: {\r\n onInterrupt?: () => void\r\n onControlRequest?: (msg: ControlRequestMessage) => Promise<unknown | void>\r\n } = {},\r\n ) {}\r\n\r\n start(): void {\r\n if (this.started) return\r\n this.started = true\r\n\r\n const rl = createInterface({ input: this.input })\r\n ;(async () => {\r\n for await (const line of rl) {\r\n this.handleLine(String(line))\r\n }\r\n })()\r\n .catch(() => {})\r\n .finally(() => {\r\n this.inputClosed = true\r\n rl.close()\r\n this.rejectAllPending(new Error('Stream closed'))\r\n this.rejectAllUserWaiters(new Error('Stream closed'))\r\n })\r\n }\r\n\r\n private rejectAllPending(err: Error): void {\r\n for (const pending of this.pendingRequests.values()) {\r\n pending.cleanup()\r\n pending.reject(err)\r\n }\r\n this.pendingRequests.clear()\r\n }\r\n\r\n private rejectAllUserWaiters(err: Error): void {\r\n for (const waiter of this.awaitingUserWaiters.splice(0)) {\r\n waiter.reject(err)\r\n }\r\n }\r\n\r\n private write(obj: unknown): void {\r\n this.output.write(JSON.stringify(obj) + '\\n')\r\n }\r\n\r\n private sendControlResponseSuccess(\r\n requestId: string,\r\n response?: unknown,\r\n ): void {\r\n this.write({\r\n type: 'control_response',\r\n response: {\r\n subtype: 'success',\r\n request_id: requestId,\r\n ...(response !== undefined ? { response } : {}),\r\n },\r\n })\r\n }\r\n\r\n private sendControlResponseError(requestId: string, error: string): void {\r\n this.write({\r\n type: 'control_response',\r\n response: {\r\n subtype: 'error',\r\n request_id: requestId,\r\n error,\r\n },\r\n })\r\n }\r\n\r\n private sendControlCancelRequest(requestId: string): void {\r\n this.write({\r\n type: 'control_cancel_request',\r\n request_id: requestId,\r\n })\r\n }\r\n\r\n private handleLine(line: string): void {\r\n const msg = tryParseLine(line)\r\n if (!msg) return\r\n\r\n if (msg.type === 'keep_alive') {\r\n return\r\n }\r\n\r\n if (msg.type === 'user') {\r\n const userMsg = msg as UserInputMessage\r\n const waiter = this.awaitingUserWaiters.shift()\r\n if (waiter) waiter.resolve(userMsg)\r\n else this.queuedUserMessages.push(userMsg)\r\n return\r\n }\r\n\r\n if (msg.type === 'control_response') {\r\n const responseMsg = msg as ControlResponseMessage\r\n const requestId = responseMsg.response?.request_id\r\n if (typeof requestId !== 'string' || !requestId) return\r\n const pending = this.pendingRequests.get(requestId)\r\n if (!pending) return\r\n pending.cleanup()\r\n this.pendingRequests.delete(requestId)\r\n pending.resolve(responseMsg.response)\r\n return\r\n }\r\n\r\n if (msg.type === 'control_request') {\r\n const requestMsg = msg as ControlRequestMessage\r\n const requestId = requestMsg.request_id\r\n const subtype = requestMsg.request?.subtype\r\n if (typeof requestId !== 'string' || !requestId) return\r\n if (typeof subtype !== 'string' || !subtype) {\r\n this.sendControlResponseError(\r\n requestId,\r\n 'Invalid control request (missing subtype)',\r\n )\r\n return\r\n }\r\n\r\n if (subtype === 'interrupt') {\r\n this.opts.onInterrupt?.()\r\n this.sendControlResponseSuccess(requestId)\r\n return\r\n }\r\n\r\n const handler = this.opts.onControlRequest\r\n if (handler) {\r\n Promise.resolve()\r\n .then(async () => await handler(requestMsg))\r\n .then(response =>\r\n this.sendControlResponseSuccess(requestId, response),\r\n )\r\n .catch(err =>\r\n this.sendControlResponseError(\r\n requestId,\r\n err instanceof Error ? err.message : String(err),\r\n ),\r\n )\r\n return\r\n }\r\n\r\n this.sendControlResponseError(\r\n requestId,\r\n `Unsupported control request subtype: ${subtype}`,\r\n )\r\n }\r\n }\r\n\r\n async nextUserMessage(args?: {\r\n signal?: AbortSignal\r\n timeoutMs?: number\r\n }): Promise<UserInputMessage> {\r\n if (this.queuedUserMessages.length > 0) {\r\n return this.queuedUserMessages.shift()!\r\n }\r\n if (this.inputClosed) {\r\n throw new Error('Stream closed')\r\n }\r\n\r\n const timeoutMs =\r\n typeof args?.timeoutMs === 'number' && Number.isFinite(args.timeoutMs)\r\n ? Math.max(0, args.timeoutMs)\r\n : null\r\n\r\n return await new Promise<UserInputMessage>((resolve, reject) => {\r\n let settled = false\r\n let waiter: {\r\n resolve: (msg: UserInputMessage) => void\r\n reject: (err: Error) => void\r\n } | null = null\r\n const onAbort = () => {\r\n cleanup()\r\n reject(new AbortError('User input aborted.'))\r\n }\r\n\r\n const onTimeout = () => {\r\n cleanup()\r\n reject(new Error('Timed out waiting for user input.'))\r\n }\r\n\r\n const cleanup = () => {\r\n if (settled) return\r\n settled = true\r\n if (args?.signal) args.signal.removeEventListener('abort', onAbort)\r\n if (timeoutId) clearTimeout(timeoutId)\r\n if (waiter) {\r\n const idx = this.awaitingUserWaiters.indexOf(waiter)\r\n if (idx >= 0) this.awaitingUserWaiters.splice(idx, 1)\r\n }\r\n }\r\n\r\n let timeoutId: NodeJS.Timeout | null = null\r\n if (timeoutMs !== null) timeoutId = setTimeout(onTimeout, timeoutMs)\r\n if (args?.signal)\r\n args.signal.addEventListener('abort', onAbort, { once: true })\r\n\r\n waiter = {\r\n resolve: msg => {\r\n cleanup()\r\n resolve(msg)\r\n },\r\n reject: err => {\r\n cleanup()\r\n reject(err)\r\n },\r\n }\r\n\r\n this.awaitingUserWaiters.push(waiter)\r\n })\r\n }\r\n\r\n async sendRequest<TResponse = unknown>(\r\n request: Record<string, unknown>,\r\n args?: { signal?: AbortSignal; timeoutMs?: number },\r\n ): Promise<TResponse> {\r\n if (this.inputClosed) {\r\n throw new Error('Stream closed')\r\n }\r\n if (args?.signal?.aborted) {\r\n throw new AbortError('Request aborted.')\r\n }\r\n\r\n const requestId = makeRequestId()\r\n this.write({ type: 'control_request', request_id: requestId, request })\r\n\r\n const timeoutMs =\r\n typeof args?.timeoutMs === 'number' && Number.isFinite(args.timeoutMs)\r\n ? Math.max(0, args.timeoutMs)\r\n : null\r\n\r\n return await new Promise<TResponse>((resolve, reject) => {\r\n const onAbort = () => {\r\n this.sendControlCancelRequest(requestId)\r\n this.pendingRequests.delete(requestId)\r\n cleanup()\r\n reject(new AbortError('Request aborted.'))\r\n }\r\n\r\n const onTimeout = () => {\r\n this.sendControlCancelRequest(requestId)\r\n this.pendingRequests.delete(requestId)\r\n cleanup()\r\n reject(new Error('Timed out waiting for control response.'))\r\n }\r\n\r\n const cleanup = () => {\r\n if (args?.signal) args.signal.removeEventListener('abort', onAbort)\r\n if (timeoutId) clearTimeout(timeoutId)\r\n }\r\n\r\n let timeoutId: NodeJS.Timeout | null = null\r\n if (timeoutMs !== null) timeoutId = setTimeout(onTimeout, timeoutMs)\r\n if (args?.signal)\r\n args.signal.addEventListener('abort', onAbort, { once: true })\r\n\r\n this.pendingRequests.set(requestId, {\r\n cleanup,\r\n resolve: response => {\r\n if (response.subtype === 'error') {\r\n reject(\r\n new Error(response.error || 'Unknown control response error'),\r\n )\r\n return\r\n }\r\n resolve((response.response ?? null) as TResponse)\r\n },\r\n reject,\r\n })\r\n })\r\n }\r\n}\r\n"],
5
+ "mappings": ";;;;;;;AAAA,SAAS,uBAAuB;AAyChC,SAAS,SAAS,OAAkD;AAClE,SAAO,QAAQ,KAAK,KAAK,OAAO,UAAU,YAAY,CAAC,MAAM,QAAQ,KAAK;AAC5E;AAEA,SAAS,aAAa,MAA6C;AACjE,MAAI,CAAC,KAAK,KAAK,EAAG,QAAO;AACzB,MAAI;AACF,UAAM,SAAS,KAAK,MAAM,IAAI;AAC9B,QAAI,CAAC,SAAS,MAAM,EAAG,QAAO;AAC9B,QAAI,OAAO,OAAO,SAAS,SAAU,QAAO;AAC5C,WAAO;AAAA,EACT,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEA,SAAS,gBAAwB;AAC/B,SAAO,KAAK,OAAO,EAAE,SAAS,EAAE,EAAE,MAAM,GAAG,EAAE;AAC/C;AAEO,IAAM,2BAAN,MAA+B;AAAA,EAiBpC,YACU,OACA,QACA,OAGJ,CAAC,GACL;AANQ;AACA;AACA;AAAA,EAIP;AAAA,EAvBK,UAAU;AAAA,EACV,cAAc;AAAA,EACd,kBAAkB,oBAAI,IAO5B;AAAA,EACM,qBAAyC,CAAC;AAAA,EAC1C,sBAGH,CAAC;AAAA,EAWN,QAAc;AACZ,QAAI,KAAK,QAAS;AAClB,SAAK,UAAU;AAEf,UAAM,KAAK,gBAAgB,EAAE,OAAO,KAAK,MAAM,CAAC;AAC/C,KAAC,YAAY;AACZ,uBAAiB,QAAQ,IAAI;AAC3B,aAAK,WAAW,OAAO,IAAI,CAAC;AAAA,MAC9B;AAAA,IACF,GAAG,EACA,MAAM,MAAM;AAAA,IAAC,CAAC,EACd,QAAQ,MAAM;AACb,WAAK,cAAc;AACnB,SAAG,MAAM;AACT,WAAK,iBAAiB,IAAI,MAAM,eAAe,CAAC;AAChD,WAAK,qBAAqB,IAAI,MAAM,eAAe,CAAC;AAAA,IACtD,CAAC;AAAA,EACL;AAAA,EAEQ,iBAAiB,KAAkB;AACzC,eAAW,WAAW,KAAK,gBAAgB,OAAO,GAAG;AACnD,cAAQ,QAAQ;AAChB,cAAQ,OAAO,GAAG;AAAA,IACpB;AACA,SAAK,gBAAgB,MAAM;AAAA,EAC7B;AAAA,EAEQ,qBAAqB,KAAkB;AAC7C,eAAW,UAAU,KAAK,oBAAoB,OAAO,CAAC,GAAG;AACvD,aAAO,OAAO,GAAG;AAAA,IACnB;AAAA,EACF;AAAA,EAEQ,MAAM,KAAoB;AAChC,SAAK,OAAO,MAAM,KAAK,UAAU,GAAG,IAAI,IAAI;AAAA,EAC9C;AAAA,EAEQ,2BACN,WACA,UACM;AACN,SAAK,MAAM;AAAA,MACT,MAAM;AAAA,MACN,UAAU;AAAA,QACR,SAAS;AAAA,QACT,YAAY;AAAA,QACZ,GAAI,aAAa,SAAY,EAAE,SAAS,IAAI,CAAC;AAAA,MAC/C;AAAA,IACF,CAAC;AAAA,EACH;AAAA,EAEQ,yBAAyB,WAAmB,OAAqB;AACvE,SAAK,MAAM;AAAA,MACT,MAAM;AAAA,MACN,UAAU;AAAA,QACR,SAAS;AAAA,QACT,YAAY;AAAA,QACZ;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH;AAAA,EAEQ,yBAAyB,WAAyB;AACxD,SAAK,MAAM;AAAA,MACT,MAAM;AAAA,MACN,YAAY;AAAA,IACd,CAAC;AAAA,EACH;AAAA,EAEQ,WAAW,MAAoB;AACrC,UAAM,MAAM,aAAa,IAAI;AAC7B,QAAI,CAAC,IAAK;AAEV,QAAI,IAAI,SAAS,cAAc;AAC7B;AAAA,IACF;AAEA,QAAI,IAAI,SAAS,QAAQ;AACvB,YAAM,UAAU;AAChB,YAAM,SAAS,KAAK,oBAAoB,MAAM;AAC9C,UAAI,OAAQ,QAAO,QAAQ,OAAO;AAAA,UAC7B,MAAK,mBAAmB,KAAK,OAAO;AACzC;AAAA,IACF;AAEA,QAAI,IAAI,SAAS,oBAAoB;AACnC,YAAM,cAAc;AACpB,YAAM,YAAY,YAAY,UAAU;AACxC,UAAI,OAAO,cAAc,YAAY,CAAC,UAAW;AACjD,YAAM,UAAU,KAAK,gBAAgB,IAAI,SAAS;AAClD,UAAI,CAAC,QAAS;AACd,cAAQ,QAAQ;AAChB,WAAK,gBAAgB,OAAO,SAAS;AACrC,cAAQ,QAAQ,YAAY,QAAQ;AACpC;AAAA,IACF;AAEA,QAAI,IAAI,SAAS,mBAAmB;AAClC,YAAM,aAAa;AACnB,YAAM,YAAY,WAAW;AAC7B,YAAM,UAAU,WAAW,SAAS;AACpC,UAAI,OAAO,cAAc,YAAY,CAAC,UAAW;AACjD,UAAI,OAAO,YAAY,YAAY,CAAC,SAAS;AAC3C,aAAK;AAAA,UACH;AAAA,UACA;AAAA,QACF;AACA;AAAA,MACF;AAEA,UAAI,YAAY,aAAa;AAC3B,aAAK,KAAK,cAAc;AACxB,aAAK,2BAA2B,SAAS;AACzC;AAAA,MACF;AAEA,YAAM,UAAU,KAAK,KAAK;AAC1B,UAAI,SAAS;AACX,gBAAQ,QAAQ,EACb,KAAK,YAAY,MAAM,QAAQ,UAAU,CAAC,EAC1C;AAAA,UAAK,cACJ,KAAK,2BAA2B,WAAW,QAAQ;AAAA,QACrD,EACC;AAAA,UAAM,SACL,KAAK;AAAA,YACH;AAAA,YACA,eAAe,QAAQ,IAAI,UAAU,OAAO,GAAG;AAAA,UACjD;AAAA,QACF;AACF;AAAA,MACF;AAEA,WAAK;AAAA,QACH;AAAA,QACA,wCAAwC,OAAO;AAAA,MACjD;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAM,gBAAgB,MAGQ;AAC5B,QAAI,KAAK,mBAAmB,SAAS,GAAG;AACtC,aAAO,KAAK,mBAAmB,MAAM;AAAA,IACvC;AACA,QAAI,KAAK,aAAa;AACpB,YAAM,IAAI,MAAM,eAAe;AAAA,IACjC;AAEA,UAAM,YACJ,OAAO,MAAM,cAAc,YAAY,OAAO,SAAS,KAAK,SAAS,IACjE,KAAK,IAAI,GAAG,KAAK,SAAS,IAC1B;AAEN,WAAO,MAAM,IAAI,QAA0B,CAAC,SAAS,WAAW;AAC9D,UAAI,UAAU;AACd,UAAI,SAGO;AACX,YAAM,UAAU,MAAM;AACpB,gBAAQ;AACR,eAAO,IAAI,WAAW,qBAAqB,CAAC;AAAA,MAC9C;AAEA,YAAM,YAAY,MAAM;AACtB,gBAAQ;AACR,eAAO,IAAI,MAAM,mCAAmC,CAAC;AAAA,MACvD;AAEA,YAAM,UAAU,MAAM;AACpB,YAAI,QAAS;AACb,kBAAU;AACV,YAAI,MAAM,OAAQ,MAAK,OAAO,oBAAoB,SAAS,OAAO;AAClE,YAAI,UAAW,cAAa,SAAS;AACrC,YAAI,QAAQ;AACV,gBAAM,MAAM,KAAK,oBAAoB,QAAQ,MAAM;AACnD,cAAI,OAAO,EAAG,MAAK,oBAAoB,OAAO,KAAK,CAAC;AAAA,QACtD;AAAA,MACF;AAEA,UAAI,YAAmC;AACvC,UAAI,cAAc,KAAM,aAAY,WAAW,WAAW,SAAS;AACnE,UAAI,MAAM;AACR,aAAK,OAAO,iBAAiB,SAAS,SAAS,EAAE,MAAM,KAAK,CAAC;AAE/D,eAAS;AAAA,QACP,SAAS,SAAO;AACd,kBAAQ;AACR,kBAAQ,GAAG;AAAA,QACb;AAAA,QACA,QAAQ,SAAO;AACb,kBAAQ;AACR,iBAAO,GAAG;AAAA,QACZ;AAAA,MACF;AAEA,WAAK,oBAAoB,KAAK,MAAM;AAAA,IACtC,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,YACJ,SACA,MACoB;AACpB,QAAI,KAAK,aAAa;AACpB,YAAM,IAAI,MAAM,eAAe;AAAA,IACjC;AACA,QAAI,MAAM,QAAQ,SAAS;AACzB,YAAM,IAAI,WAAW,kBAAkB;AAAA,IACzC;AAEA,UAAM,YAAY,cAAc;AAChC,SAAK,MAAM,EAAE,MAAM,mBAAmB,YAAY,WAAW,QAAQ,CAAC;AAEtE,UAAM,YACJ,OAAO,MAAM,cAAc,YAAY,OAAO,SAAS,KAAK,SAAS,IACjE,KAAK,IAAI,GAAG,KAAK,SAAS,IAC1B;AAEN,WAAO,MAAM,IAAI,QAAmB,CAAC,SAAS,WAAW;AACvD,YAAM,UAAU,MAAM;AACpB,aAAK,yBAAyB,SAAS;AACvC,aAAK,gBAAgB,OAAO,SAAS;AACrC,gBAAQ;AACR,eAAO,IAAI,WAAW,kBAAkB,CAAC;AAAA,MAC3C;AAEA,YAAM,YAAY,MAAM;AACtB,aAAK,yBAAyB,SAAS;AACvC,aAAK,gBAAgB,OAAO,SAAS;AACrC,gBAAQ;AACR,eAAO,IAAI,MAAM,yCAAyC,CAAC;AAAA,MAC7D;AAEA,YAAM,UAAU,MAAM;AACpB,YAAI,MAAM,OAAQ,MAAK,OAAO,oBAAoB,SAAS,OAAO;AAClE,YAAI,UAAW,cAAa,SAAS;AAAA,MACvC;AAEA,UAAI,YAAmC;AACvC,UAAI,cAAc,KAAM,aAAY,WAAW,WAAW,SAAS;AACnE,UAAI,MAAM;AACR,aAAK,OAAO,iBAAiB,SAAS,SAAS,EAAE,MAAM,KAAK,CAAC;AAE/D,WAAK,gBAAgB,IAAI,WAAW;AAAA,QAClC;AAAA,QACA,SAAS,cAAY;AACnB,cAAI,SAAS,YAAY,SAAS;AAChC;AAAA,cACE,IAAI,MAAM,SAAS,SAAS,gCAAgC;AAAA,YAC9D;AACA;AAAA,UACF;AACA,kBAAS,SAAS,YAAY,IAAkB;AAAA,QAClD;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AACF;",
6
+ "names": []
7
+ }
@@ -0,0 +1,19 @@
1
+ import { createRequire as __newcrawCreateRequire } from "node:module";
2
+ const require = __newcrawCreateRequire(import.meta.url);
3
+
4
+ // src/utils/text/generators.ts
5
+ var NO_VALUE = Symbol("NO_VALUE");
6
+ async function lastX(as) {
7
+ let lastValue = NO_VALUE;
8
+ for await (const a of as) {
9
+ lastValue = a;
10
+ }
11
+ if (lastValue === NO_VALUE) {
12
+ throw new Error("No items in generator");
13
+ }
14
+ return lastValue;
15
+ }
16
+
17
+ export {
18
+ lastX
19
+ };
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/utils/text/generators.ts"],
4
+ "sourcesContent": ["const NO_VALUE = Symbol('NO_VALUE')\r\n\r\nexport async function lastX<A>(as: AsyncGenerator<A>): Promise<A> {\r\n let lastValue: A | typeof NO_VALUE = NO_VALUE\r\n for await (const a of as) {\r\n lastValue = a\r\n }\r\n if (lastValue === NO_VALUE) {\r\n throw new Error('No items in generator')\r\n }\r\n return lastValue\r\n}\r\n\r\ntype QueuedGenerator<A> = {\r\n done: boolean | void\r\n value: A | void\r\n generator: AsyncGenerator<A, void>\r\n promise: Promise<QueuedGenerator<A>>\r\n}\r\n\r\nexport async function* all<A>(\r\n generators: AsyncGenerator<A, void>[],\r\n concurrencyCap = Infinity,\r\n): AsyncGenerator<A, void> {\r\n const next = (generator: AsyncGenerator<A, void>) => {\r\n const promise: Promise<QueuedGenerator<A>> = generator\r\n .next()\r\n .then(({ done, value }) => ({\r\n done,\r\n value,\r\n generator,\r\n promise,\r\n }))\r\n return promise\r\n }\r\n const waiting = [...generators]\r\n const promises = new Set<Promise<QueuedGenerator<A>>>()\r\n\r\n while (promises.size < concurrencyCap && waiting.length > 0) {\r\n const gen = waiting.shift()!\r\n promises.add(next(gen))\r\n }\r\n\r\n while (promises.size > 0) {\r\n const { done, value, generator, promise } = await Promise.race(promises)\r\n promises.delete(promise)\r\n\r\n if (!done) {\r\n promises.add(next(generator))\r\n if (value !== undefined) {\r\n yield value as A\r\n }\r\n } else if (waiting.length > 0) {\r\n const nextGen = waiting.shift()!\r\n promises.add(next(nextGen))\r\n }\r\n }\r\n}\r\n"],
5
+ "mappings": ";;;;AAAA,IAAM,WAAW,OAAO,UAAU;AAElC,eAAsB,MAAS,IAAmC;AAChE,MAAI,YAAiC;AACrC,mBAAiB,KAAK,IAAI;AACxB,gBAAY;AAAA,EACd;AACA,MAAI,cAAc,UAAU;AAC1B,UAAM,IAAI,MAAM,uBAAuB;AAAA,EACzC;AACA,SAAO;AACT;",
6
+ "names": []
7
+ }
@@ -0,0 +1,139 @@
1
+ import { createRequire as __newcrawCreateRequire } from "node:module";
2
+ const require = __newcrawCreateRequire(import.meta.url);
3
+ import {
4
+ getSessionProjectDir
5
+ } from "./chunk-QTX7AJFQ.js";
6
+ import {
7
+ isUuid
8
+ } from "./chunk-JX5ZQYTQ.js";
9
+
10
+ // src/utils/protocol/kodeAgentSessionLoad.ts
11
+ import { existsSync, readdirSync, readFileSync, statSync } from "fs";
12
+ import { basename, join } from "path";
13
+ function safeParseJson(line) {
14
+ try {
15
+ return JSON.parse(line);
16
+ } catch {
17
+ return null;
18
+ }
19
+ }
20
+ function isUserEntry(entry) {
21
+ return typeof entry?.type === "string" && entry.type === "user";
22
+ }
23
+ function isAssistantEntry(entry) {
24
+ return typeof entry?.type === "string" && entry.type === "assistant";
25
+ }
26
+ function isSummaryEntry(entry) {
27
+ return typeof entry?.type === "string" && entry.type === "summary";
28
+ }
29
+ function isCustomTitleEntry(entry) {
30
+ return typeof entry?.type === "string" && entry.type === "custom-title";
31
+ }
32
+ function isTagEntry(entry) {
33
+ return typeof entry?.type === "string" && entry.type === "tag";
34
+ }
35
+ function isFileHistorySnapshotEntry(entry) {
36
+ return typeof entry?.type === "string" && entry.type === "file-history-snapshot";
37
+ }
38
+ function normalizeLoadedUser(entry) {
39
+ if (!entry.uuid || !entry.message) return null;
40
+ return {
41
+ type: "user",
42
+ uuid: entry.uuid,
43
+ message: entry.message,
44
+ ...entry.toolUseResult !== void 0 ? { toolUseResult: { data: entry.toolUseResult, resultForAssistant: "" } } : {}
45
+ };
46
+ }
47
+ function normalizeLoadedAssistant(entry) {
48
+ if (!entry.uuid || !entry.message) return null;
49
+ return {
50
+ type: "assistant",
51
+ uuid: entry.uuid,
52
+ costUSD: 0,
53
+ durationMs: 0,
54
+ message: entry.message,
55
+ ...entry.isApiErrorMessage ? { isApiErrorMessage: true } : {},
56
+ ...typeof entry.requestId === "string" ? { requestId: entry.requestId } : {}
57
+ };
58
+ }
59
+ function loadKodeAgentSessionLogData(args) {
60
+ const { cwd, sessionId } = args;
61
+ const projectDir = getSessionProjectDir(cwd);
62
+ const filePath = join(projectDir, `${sessionId}.jsonl`);
63
+ if (!existsSync(filePath)) {
64
+ throw new Error(`No conversation found with session ID: ${sessionId}`);
65
+ }
66
+ const lines = readFileSync(filePath, "utf8").split("\n");
67
+ const messages = [];
68
+ const summaries = /* @__PURE__ */ new Map();
69
+ const customTitles = /* @__PURE__ */ new Map();
70
+ const tags = /* @__PURE__ */ new Map();
71
+ const fileHistorySnapshots = /* @__PURE__ */ new Map();
72
+ for (const line of lines) {
73
+ const raw = safeParseJson(line.trim());
74
+ if (!raw || typeof raw !== "object") continue;
75
+ const entry = raw;
76
+ if (isUserEntry(entry)) {
77
+ if (entry.sessionId && entry.sessionId !== sessionId) continue;
78
+ const msg = normalizeLoadedUser(entry);
79
+ if (msg) messages.push(msg);
80
+ continue;
81
+ }
82
+ if (isAssistantEntry(entry)) {
83
+ if (entry.sessionId && entry.sessionId !== sessionId) continue;
84
+ const msg = normalizeLoadedAssistant(entry);
85
+ if (msg) messages.push(msg);
86
+ continue;
87
+ }
88
+ if (isSummaryEntry(entry)) {
89
+ const leafUuid = typeof entry.leafUuid === "string" ? entry.leafUuid : "";
90
+ const summary = typeof entry.summary === "string" ? entry.summary : "";
91
+ if (leafUuid && summary) summaries.set(leafUuid, summary);
92
+ continue;
93
+ }
94
+ if (isCustomTitleEntry(entry)) {
95
+ const id = typeof entry.sessionId === "string" ? entry.sessionId : "";
96
+ const title = typeof entry.customTitle === "string" ? entry.customTitle : "";
97
+ if (id && title) customTitles.set(id, title);
98
+ continue;
99
+ }
100
+ if (isTagEntry(entry)) {
101
+ const id = typeof entry.sessionId === "string" ? entry.sessionId : "";
102
+ const tag = typeof entry.tag === "string" ? entry.tag : "";
103
+ if (id && tag) tags.set(id, tag);
104
+ continue;
105
+ }
106
+ if (isFileHistorySnapshotEntry(entry)) {
107
+ const messageId = typeof entry.messageId === "string" ? entry.messageId : "";
108
+ if (messageId) fileHistorySnapshots.set(messageId, entry);
109
+ continue;
110
+ }
111
+ }
112
+ return { messages, summaries, customTitles, tags, fileHistorySnapshots };
113
+ }
114
+ function loadKodeAgentSessionMessages(args) {
115
+ return loadKodeAgentSessionLogData(args).messages;
116
+ }
117
+ function findMostRecentKodeAgentSessionId(cwd) {
118
+ const projectDir = getSessionProjectDir(cwd);
119
+ if (!existsSync(projectDir)) return null;
120
+ const candidates = readdirSync(projectDir).filter((name) => name.endsWith(".jsonl")).filter((name) => !name.startsWith("agent-")).map((name) => ({
121
+ sessionId: basename(name, ".jsonl"),
122
+ path: join(projectDir, name)
123
+ })).filter((c) => isUuid(c.sessionId));
124
+ if (candidates.length === 0) return null;
125
+ candidates.sort((a, b) => {
126
+ try {
127
+ return statSync(b.path).mtimeMs - statSync(a.path).mtimeMs;
128
+ } catch {
129
+ return 0;
130
+ }
131
+ });
132
+ return candidates[0]?.sessionId ?? null;
133
+ }
134
+
135
+ export {
136
+ loadKodeAgentSessionLogData,
137
+ loadKodeAgentSessionMessages,
138
+ findMostRecentKodeAgentSessionId
139
+ };