@anh3d0nic/qwen-code-termux-ice 21.0.1 → 21.2.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 (1281) hide show
  1. package/bin/qwen-ice +127 -331
  2. package/core/ice-core.js +101 -0
  3. package/core-dist/index.d.ts +6 -0
  4. package/core-dist/index.js +7 -0
  5. package/core-dist/index.js.map +1 -0
  6. package/core-dist/src/__mocks__/fs/promises.d.ts +11 -0
  7. package/core-dist/src/__mocks__/fs/promises.js +17 -0
  8. package/core-dist/src/__mocks__/fs/promises.js.map +1 -0
  9. package/core-dist/src/config/config.d.ts +648 -0
  10. package/core-dist/src/config/config.js +1374 -0
  11. package/core-dist/src/config/config.js.map +1 -0
  12. package/core-dist/src/config/config.test.d.ts +6 -0
  13. package/core-dist/src/config/config.test.js +1116 -0
  14. package/core-dist/src/config/config.test.js.map +1 -0
  15. package/core-dist/src/config/constants.d.ts +11 -0
  16. package/core-dist/src/config/constants.js +16 -0
  17. package/core-dist/src/config/constants.js.map +1 -0
  18. package/core-dist/src/config/models.d.ts +9 -0
  19. package/core-dist/src/config/models.js +10 -0
  20. package/core-dist/src/config/models.js.map +1 -0
  21. package/core-dist/src/config/storage.d.ts +38 -0
  22. package/core-dist/src/config/storage.js +114 -0
  23. package/core-dist/src/config/storage.js.map +1 -0
  24. package/core-dist/src/config/storage.test.d.ts +6 -0
  25. package/core-dist/src/config/storage.test.js +36 -0
  26. package/core-dist/src/config/storage.test.js.map +1 -0
  27. package/core-dist/src/confirmation-bus/message-bus.d.ts +22 -0
  28. package/core-dist/src/confirmation-bus/message-bus.js +98 -0
  29. package/core-dist/src/confirmation-bus/message-bus.js.map +1 -0
  30. package/core-dist/src/confirmation-bus/types.d.ts +104 -0
  31. package/core-dist/src/confirmation-bus/types.js +16 -0
  32. package/core-dist/src/confirmation-bus/types.js.map +1 -0
  33. package/core-dist/src/core/__tests__/openaiTimeoutHandling.test.d.ts +6 -0
  34. package/core-dist/src/core/__tests__/openaiTimeoutHandling.test.js +298 -0
  35. package/core-dist/src/core/__tests__/openaiTimeoutHandling.test.js.map +1 -0
  36. package/core-dist/src/core/__tests__/orphanedToolCallsTest.d.ts +64 -0
  37. package/core-dist/src/core/__tests__/orphanedToolCallsTest.js +122 -0
  38. package/core-dist/src/core/__tests__/orphanedToolCallsTest.js.map +1 -0
  39. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.d.ts +28 -0
  40. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.js +349 -0
  41. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.js.map +1 -0
  42. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.test.d.ts +6 -0
  43. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.test.js +396 -0
  44. package/core-dist/src/core/anthropicContentGenerator/anthropicContentGenerator.test.js.map +1 -0
  45. package/core-dist/src/core/anthropicContentGenerator/converter.d.ts +48 -0
  46. package/core-dist/src/core/anthropicContentGenerator/converter.js +449 -0
  47. package/core-dist/src/core/anthropicContentGenerator/converter.js.map +1 -0
  48. package/core-dist/src/core/anthropicContentGenerator/converter.test.d.ts +6 -0
  49. package/core-dist/src/core/anthropicContentGenerator/converter.test.js +843 -0
  50. package/core-dist/src/core/anthropicContentGenerator/converter.test.js.map +1 -0
  51. package/core-dist/src/core/anthropicContentGenerator/index.d.ts +9 -0
  52. package/core-dist/src/core/anthropicContentGenerator/index.js +11 -0
  53. package/core-dist/src/core/anthropicContentGenerator/index.js.map +1 -0
  54. package/core-dist/src/core/baseLlmClient.d.ts +48 -0
  55. package/core-dist/src/core/baseLlmClient.js +98 -0
  56. package/core-dist/src/core/baseLlmClient.js.map +1 -0
  57. package/core-dist/src/core/baseLlmClient.test.d.ts +6 -0
  58. package/core-dist/src/core/baseLlmClient.test.js +319 -0
  59. package/core-dist/src/core/baseLlmClient.test.js.map +1 -0
  60. package/core-dist/src/core/client.d.ts +48 -0
  61. package/core-dist/src/core/client.js +547 -0
  62. package/core-dist/src/core/client.js.map +1 -0
  63. package/core-dist/src/core/client.test.d.ts +6 -0
  64. package/core-dist/src/core/client.test.js +1885 -0
  65. package/core-dist/src/core/client.test.js.map +1 -0
  66. package/core-dist/src/core/contentGenerator.d.ts +100 -0
  67. package/core-dist/src/core/contentGenerator.js +162 -0
  68. package/core-dist/src/core/contentGenerator.js.map +1 -0
  69. package/core-dist/src/core/contentGenerator.test.d.ts +6 -0
  70. package/core-dist/src/core/contentGenerator.test.js +95 -0
  71. package/core-dist/src/core/contentGenerator.test.js.map +1 -0
  72. package/core-dist/src/core/coreToolScheduler.d.ts +142 -0
  73. package/core-dist/src/core/coreToolScheduler.js +872 -0
  74. package/core-dist/src/core/coreToolScheduler.js.map +1 -0
  75. package/core-dist/src/core/coreToolScheduler.test.d.ts +6 -0
  76. package/core-dist/src/core/coreToolScheduler.test.js +2221 -0
  77. package/core-dist/src/core/coreToolScheduler.test.js.map +1 -0
  78. package/core-dist/src/core/geminiChat.d.ts +122 -0
  79. package/core-dist/src/core/geminiChat.js +571 -0
  80. package/core-dist/src/core/geminiChat.js.map +1 -0
  81. package/core-dist/src/core/geminiChat.test.d.ts +6 -0
  82. package/core-dist/src/core/geminiChat.test.js +1276 -0
  83. package/core-dist/src/core/geminiChat.test.js.map +1 -0
  84. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.d.ts +38 -0
  85. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.js +193 -0
  86. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.js.map +1 -0
  87. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.test.d.ts +6 -0
  88. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.test.js +304 -0
  89. package/core-dist/src/core/geminiContentGenerator/geminiContentGenerator.test.js.map +1 -0
  90. package/core-dist/src/core/geminiContentGenerator/index.d.ts +12 -0
  91. package/core-dist/src/core/geminiContentGenerator/index.js +36 -0
  92. package/core-dist/src/core/geminiContentGenerator/index.js.map +1 -0
  93. package/core-dist/src/core/geminiContentGenerator/index.test.d.ts +6 -0
  94. package/core-dist/src/core/geminiContentGenerator/index.test.js +34 -0
  95. package/core-dist/src/core/geminiContentGenerator/index.test.js.map +1 -0
  96. package/core-dist/src/core/geminiRequest.d.ts +13 -0
  97. package/core-dist/src/core/geminiRequest.js +11 -0
  98. package/core-dist/src/core/geminiRequest.js.map +1 -0
  99. package/core-dist/src/core/geminiRequest.test.d.ts +6 -0
  100. package/core-dist/src/core/geminiRequest.test.js +73 -0
  101. package/core-dist/src/core/geminiRequest.test.js.map +1 -0
  102. package/core-dist/src/core/logger.d.ts +68 -0
  103. package/core-dist/src/core/logger.js +364 -0
  104. package/core-dist/src/core/logger.js.map +1 -0
  105. package/core-dist/src/core/logger.test.d.ts +6 -0
  106. package/core-dist/src/core/logger.test.js +520 -0
  107. package/core-dist/src/core/logger.test.js.map +1 -0
  108. package/core-dist/src/core/loggingContentGenerator/index.d.ts +6 -0
  109. package/core-dist/src/core/loggingContentGenerator/index.js +7 -0
  110. package/core-dist/src/core/loggingContentGenerator/index.js.map +1 -0
  111. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.d.ts +36 -0
  112. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.js +321 -0
  113. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.js.map +1 -0
  114. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.test.d.ts +6 -0
  115. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.test.js +287 -0
  116. package/core-dist/src/core/loggingContentGenerator/loggingContentGenerator.test.js.map +1 -0
  117. package/core-dist/src/core/modalityDefaults.d.ts +14 -0
  118. package/core-dist/src/core/modalityDefaults.js +81 -0
  119. package/core-dist/src/core/modalityDefaults.js.map +1 -0
  120. package/core-dist/src/core/modalityDefaults.test.d.ts +6 -0
  121. package/core-dist/src/core/modalityDefaults.test.js +181 -0
  122. package/core-dist/src/core/modalityDefaults.test.js.map +1 -0
  123. package/core-dist/src/core/nonInteractiveToolExecutor.d.ts +16 -0
  124. package/core-dist/src/core/nonInteractiveToolExecutor.js +30 -0
  125. package/core-dist/src/core/nonInteractiveToolExecutor.js.map +1 -0
  126. package/core-dist/src/core/nonInteractiveToolExecutor.test.d.ts +6 -0
  127. package/core-dist/src/core/nonInteractiveToolExecutor.test.js +296 -0
  128. package/core-dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -0
  129. package/core-dist/src/core/openaiContentGenerator/constants.d.ts +6 -0
  130. package/core-dist/src/core/openaiContentGenerator/constants.js +7 -0
  131. package/core-dist/src/core/openaiContentGenerator/constants.js.map +1 -0
  132. package/core-dist/src/core/openaiContentGenerator/converter.d.ts +133 -0
  133. package/core-dist/src/core/openaiContentGenerator/converter.js +1020 -0
  134. package/core-dist/src/core/openaiContentGenerator/converter.js.map +1 -0
  135. package/core-dist/src/core/openaiContentGenerator/converter.test.d.ts +6 -0
  136. package/core-dist/src/core/openaiContentGenerator/converter.test.js +1966 -0
  137. package/core-dist/src/core/openaiContentGenerator/converter.test.js.map +1 -0
  138. package/core-dist/src/core/openaiContentGenerator/errorHandler.d.ts +27 -0
  139. package/core-dist/src/core/openaiContentGenerator/errorHandler.js +84 -0
  140. package/core-dist/src/core/openaiContentGenerator/errorHandler.js.map +1 -0
  141. package/core-dist/src/core/openaiContentGenerator/errorHandler.test.d.ts +6 -0
  142. package/core-dist/src/core/openaiContentGenerator/errorHandler.test.js +267 -0
  143. package/core-dist/src/core/openaiContentGenerator/errorHandler.test.js.map +1 -0
  144. package/core-dist/src/core/openaiContentGenerator/index.d.ts +21 -0
  145. package/core-dist/src/core/openaiContentGenerator/index.js +43 -0
  146. package/core-dist/src/core/openaiContentGenerator/index.js.map +1 -0
  147. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.d.ts +22 -0
  148. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.js +117 -0
  149. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.js.map +1 -0
  150. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.test.d.ts +6 -0
  151. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js +298 -0
  152. package/core-dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js.map +1 -0
  153. package/core-dist/src/core/openaiContentGenerator/pipeline.d.ts +74 -0
  154. package/core-dist/src/core/openaiContentGenerator/pipeline.js +327 -0
  155. package/core-dist/src/core/openaiContentGenerator/pipeline.js.map +1 -0
  156. package/core-dist/src/core/openaiContentGenerator/pipeline.test.d.ts +6 -0
  157. package/core-dist/src/core/openaiContentGenerator/pipeline.test.js +1143 -0
  158. package/core-dist/src/core/openaiContentGenerator/pipeline.test.js.map +1 -0
  159. package/core-dist/src/core/openaiContentGenerator/provider/README.md +61 -0
  160. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.d.ts +70 -0
  161. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.js +258 -0
  162. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.js.map +1 -0
  163. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.test.d.ts +6 -0
  164. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.test.js +781 -0
  165. package/core-dist/src/core/openaiContentGenerator/provider/dashscope.test.js.map +1 -0
  166. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.d.ts +14 -0
  167. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.js +21 -0
  168. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.js.map +1 -0
  169. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.test.d.ts +6 -0
  170. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.test.js +51 -0
  171. package/core-dist/src/core/openaiContentGenerator/provider/deepseek.test.js.map +1 -0
  172. package/core-dist/src/core/openaiContentGenerator/provider/default.d.ts +17 -0
  173. package/core-dist/src/core/openaiContentGenerator/provider/default.js +52 -0
  174. package/core-dist/src/core/openaiContentGenerator/provider/default.js.map +1 -0
  175. package/core-dist/src/core/openaiContentGenerator/provider/default.test.d.ts +6 -0
  176. package/core-dist/src/core/openaiContentGenerator/provider/default.test.js +227 -0
  177. package/core-dist/src/core/openaiContentGenerator/provider/default.test.js.map +1 -0
  178. package/core-dist/src/core/openaiContentGenerator/provider/index.d.ts +6 -0
  179. package/core-dist/src/core/openaiContentGenerator/provider/index.js +6 -0
  180. package/core-dist/src/core/openaiContentGenerator/provider/index.js.map +1 -0
  181. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.d.ts +17 -0
  182. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.js +25 -0
  183. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.js.map +1 -0
  184. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.test.d.ts +6 -0
  185. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.test.js +66 -0
  186. package/core-dist/src/core/openaiContentGenerator/provider/modelscope.test.js.map +1 -0
  187. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.d.ts +8 -0
  188. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.js +21 -0
  189. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.js.map +1 -0
  190. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.test.d.ts +6 -0
  191. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.test.js +152 -0
  192. package/core-dist/src/core/openaiContentGenerator/provider/openrouter.test.js.map +1 -0
  193. package/core-dist/src/core/openaiContentGenerator/provider/types.d.ts +26 -0
  194. package/core-dist/src/core/openaiContentGenerator/provider/types.js +2 -0
  195. package/core-dist/src/core/openaiContentGenerator/provider/types.js.map +1 -0
  196. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.d.ts +157 -0
  197. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.js +390 -0
  198. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.js.map +1 -0
  199. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.test.d.ts +6 -0
  200. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js +585 -0
  201. package/core-dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js.map +1 -0
  202. package/core-dist/src/core/prompts.d.ts +81 -0
  203. package/core-dist/src/core/prompts.js +996 -0
  204. package/core-dist/src/core/prompts.js.map +1 -0
  205. package/core-dist/src/core/prompts.test.d.ts +6 -0
  206. package/core-dist/src/core/prompts.test.js +485 -0
  207. package/core-dist/src/core/prompts.test.js.map +1 -0
  208. package/core-dist/src/core/tokenLimits.d.ts +29 -0
  209. package/core-dist/src/core/tokenLimits.js +171 -0
  210. package/core-dist/src/core/tokenLimits.js.map +1 -0
  211. package/core-dist/src/core/tokenLimits.test.d.ts +1 -0
  212. package/core-dist/src/core/tokenLimits.test.js +270 -0
  213. package/core-dist/src/core/tokenLimits.test.js.map +1 -0
  214. package/core-dist/src/core/turn.d.ts +161 -0
  215. package/core-dist/src/core/turn.js +197 -0
  216. package/core-dist/src/core/turn.js.map +1 -0
  217. package/core-dist/src/core/turn.test.d.ts +6 -0
  218. package/core-dist/src/core/turn.test.js +817 -0
  219. package/core-dist/src/core/turn.test.js.map +1 -0
  220. package/core-dist/src/extension/claude-converter.d.ts +121 -0
  221. package/core-dist/src/extension/claude-converter.js +572 -0
  222. package/core-dist/src/extension/claude-converter.js.map +1 -0
  223. package/core-dist/src/extension/claude-converter.test.d.ts +6 -0
  224. package/core-dist/src/extension/claude-converter.test.js +305 -0
  225. package/core-dist/src/extension/claude-converter.test.js.map +1 -0
  226. package/core-dist/src/extension/extensionManager.d.ts +159 -0
  227. package/core-dist/src/extension/extensionManager.js +829 -0
  228. package/core-dist/src/extension/extensionManager.js.map +1 -0
  229. package/core-dist/src/extension/extensionManager.test.d.ts +6 -0
  230. package/core-dist/src/extension/extensionManager.test.js +598 -0
  231. package/core-dist/src/extension/extensionManager.test.js.map +1 -0
  232. package/core-dist/src/extension/extensionSettings.d.ts +33 -0
  233. package/core-dist/src/extension/extensionSettings.js +186 -0
  234. package/core-dist/src/extension/extensionSettings.js.map +1 -0
  235. package/core-dist/src/extension/extensionSettings.test.d.ts +1 -0
  236. package/core-dist/src/extension/extensionSettings.test.js +488 -0
  237. package/core-dist/src/extension/extensionSettings.test.js.map +1 -0
  238. package/core-dist/src/extension/gemini-converter.d.ts +47 -0
  239. package/core-dist/src/extension/gemini-converter.js +185 -0
  240. package/core-dist/src/extension/gemini-converter.js.map +1 -0
  241. package/core-dist/src/extension/gemini-converter.test.d.ts +6 -0
  242. package/core-dist/src/extension/gemini-converter.test.js +128 -0
  243. package/core-dist/src/extension/gemini-converter.test.js.map +1 -0
  244. package/core-dist/src/extension/github.d.ts +30 -0
  245. package/core-dist/src/extension/github.js +330 -0
  246. package/core-dist/src/extension/github.js.map +1 -0
  247. package/core-dist/src/extension/github.test.d.ts +6 -0
  248. package/core-dist/src/extension/github.test.js +376 -0
  249. package/core-dist/src/extension/github.test.js.map +1 -0
  250. package/core-dist/src/extension/index.d.ts +6 -0
  251. package/core-dist/src/extension/index.js +7 -0
  252. package/core-dist/src/extension/index.js.map +1 -0
  253. package/core-dist/src/extension/marketplace.d.ts +19 -0
  254. package/core-dist/src/extension/marketplace.js +222 -0
  255. package/core-dist/src/extension/marketplace.js.map +1 -0
  256. package/core-dist/src/extension/marketplace.test.d.ts +6 -0
  257. package/core-dist/src/extension/marketplace.test.js +215 -0
  258. package/core-dist/src/extension/marketplace.test.js.map +1 -0
  259. package/core-dist/src/extension/override.d.ts +25 -0
  260. package/core-dist/src/extension/override.js +82 -0
  261. package/core-dist/src/extension/override.js.map +1 -0
  262. package/core-dist/src/extension/override.test.d.ts +6 -0
  263. package/core-dist/src/extension/override.test.js +94 -0
  264. package/core-dist/src/extension/override.test.js.map +1 -0
  265. package/core-dist/src/extension/settings.d.ts +39 -0
  266. package/core-dist/src/extension/settings.js +116 -0
  267. package/core-dist/src/extension/settings.js.map +1 -0
  268. package/core-dist/src/extension/settings.test.d.ts +6 -0
  269. package/core-dist/src/extension/settings.test.js +125 -0
  270. package/core-dist/src/extension/settings.test.js.map +1 -0
  271. package/core-dist/src/extension/storage.d.ts +9 -0
  272. package/core-dist/src/extension/storage.js +38 -0
  273. package/core-dist/src/extension/storage.js.map +1 -0
  274. package/core-dist/src/extension/storage.test.d.ts +6 -0
  275. package/core-dist/src/extension/storage.test.js +64 -0
  276. package/core-dist/src/extension/storage.test.js.map +1 -0
  277. package/core-dist/src/extension/variableSchema.d.ts +40 -0
  278. package/core-dist/src/extension/variableSchema.js +26 -0
  279. package/core-dist/src/extension/variableSchema.js.map +1 -0
  280. package/core-dist/src/extension/variables.d.ts +21 -0
  281. package/core-dist/src/extension/variables.js +46 -0
  282. package/core-dist/src/extension/variables.js.map +1 -0
  283. package/core-dist/src/extension/variables.test.d.ts +6 -0
  284. package/core-dist/src/extension/variables.test.js +17 -0
  285. package/core-dist/src/extension/variables.test.js.map +1 -0
  286. package/core-dist/src/hooks/hookAggregator.d.ts +66 -0
  287. package/core-dist/src/hooks/hookAggregator.js +280 -0
  288. package/core-dist/src/hooks/hookAggregator.js.map +1 -0
  289. package/core-dist/src/hooks/hookAggregator.test.d.ts +6 -0
  290. package/core-dist/src/hooks/hookAggregator.test.js +449 -0
  291. package/core-dist/src/hooks/hookAggregator.test.js.map +1 -0
  292. package/core-dist/src/hooks/hookEventHandler.d.ts +42 -0
  293. package/core-dist/src/hooks/hookEventHandler.js +127 -0
  294. package/core-dist/src/hooks/hookEventHandler.js.map +1 -0
  295. package/core-dist/src/hooks/hookEventHandler.test.d.ts +6 -0
  296. package/core-dist/src/hooks/hookEventHandler.test.js +183 -0
  297. package/core-dist/src/hooks/hookEventHandler.test.js.map +1 -0
  298. package/core-dist/src/hooks/hookPlanner.d.ts +42 -0
  299. package/core-dist/src/hooks/hookPlanner.js +101 -0
  300. package/core-dist/src/hooks/hookPlanner.js.map +1 -0
  301. package/core-dist/src/hooks/hookPlanner.test.d.ts +6 -0
  302. package/core-dist/src/hooks/hookPlanner.test.js +303 -0
  303. package/core-dist/src/hooks/hookPlanner.test.js.map +1 -0
  304. package/core-dist/src/hooks/hookRegistry.d.ts +106 -0
  305. package/core-dist/src/hooks/hookRegistry.js +225 -0
  306. package/core-dist/src/hooks/hookRegistry.js.map +1 -0
  307. package/core-dist/src/hooks/hookRegistry.test.d.ts +6 -0
  308. package/core-dist/src/hooks/hookRegistry.test.js +539 -0
  309. package/core-dist/src/hooks/hookRegistry.test.js.map +1 -0
  310. package/core-dist/src/hooks/hookRunner.d.ts +40 -0
  311. package/core-dist/src/hooks/hookRunner.js +318 -0
  312. package/core-dist/src/hooks/hookRunner.js.map +1 -0
  313. package/core-dist/src/hooks/hookRunner.test.d.ts +6 -0
  314. package/core-dist/src/hooks/hookRunner.test.js +466 -0
  315. package/core-dist/src/hooks/hookRunner.test.js.map +1 -0
  316. package/core-dist/src/hooks/hookSystem.d.ts +43 -0
  317. package/core-dist/src/hooks/hookSystem.js +75 -0
  318. package/core-dist/src/hooks/hookSystem.js.map +1 -0
  319. package/core-dist/src/hooks/hookSystem.test.d.ts +6 -0
  320. package/core-dist/src/hooks/hookSystem.test.js +237 -0
  321. package/core-dist/src/hooks/hookSystem.test.js.map +1 -0
  322. package/core-dist/src/hooks/index.d.ts +16 -0
  323. package/core-dist/src/hooks/index.js +16 -0
  324. package/core-dist/src/hooks/index.js.map +1 -0
  325. package/core-dist/src/hooks/trustedHooks.d.ts +28 -0
  326. package/core-dist/src/hooks/trustedHooks.js +91 -0
  327. package/core-dist/src/hooks/trustedHooks.js.map +1 -0
  328. package/core-dist/src/hooks/types.d.ts +498 -0
  329. package/core-dist/src/hooks/types.js +292 -0
  330. package/core-dist/src/hooks/types.js.map +1 -0
  331. package/core-dist/src/ide/constants.d.ts +9 -0
  332. package/core-dist/src/ide/constants.js +10 -0
  333. package/core-dist/src/ide/constants.js.map +1 -0
  334. package/core-dist/src/ide/detect-ide.d.ts +56 -0
  335. package/core-dist/src/ide/detect-ide.js +68 -0
  336. package/core-dist/src/ide/detect-ide.js.map +1 -0
  337. package/core-dist/src/ide/detect-ide.test.d.ts +6 -0
  338. package/core-dist/src/ide/detect-ide.test.js +113 -0
  339. package/core-dist/src/ide/detect-ide.test.js.map +1 -0
  340. package/core-dist/src/ide/ide-client.d.ts +132 -0
  341. package/core-dist/src/ide/ide-client.js +750 -0
  342. package/core-dist/src/ide/ide-client.js.map +1 -0
  343. package/core-dist/src/ide/ide-client.test.d.ts +6 -0
  344. package/core-dist/src/ide/ide-client.test.js +463 -0
  345. package/core-dist/src/ide/ide-client.test.js.map +1 -0
  346. package/core-dist/src/ide/ide-installer.d.ts +14 -0
  347. package/core-dist/src/ide/ide-installer.js +112 -0
  348. package/core-dist/src/ide/ide-installer.js.map +1 -0
  349. package/core-dist/src/ide/ide-installer.test.d.ts +6 -0
  350. package/core-dist/src/ide/ide-installer.test.js +134 -0
  351. package/core-dist/src/ide/ide-installer.test.js.map +1 -0
  352. package/core-dist/src/ide/ideContext.d.ts +44 -0
  353. package/core-dist/src/ide/ideContext.js +101 -0
  354. package/core-dist/src/ide/ideContext.js.map +1 -0
  355. package/core-dist/src/ide/ideContext.test.d.ts +6 -0
  356. package/core-dist/src/ide/ideContext.test.js +393 -0
  357. package/core-dist/src/ide/ideContext.test.js.map +1 -0
  358. package/core-dist/src/ide/process-utils.d.ts +21 -0
  359. package/core-dist/src/ide/process-utils.js +170 -0
  360. package/core-dist/src/ide/process-utils.js.map +1 -0
  361. package/core-dist/src/ide/process-utils.test.d.ts +6 -0
  362. package/core-dist/src/ide/process-utils.test.js +130 -0
  363. package/core-dist/src/ide/process-utils.test.js.map +1 -0
  364. package/core-dist/src/ide/types.d.ts +486 -0
  365. package/core-dist/src/ide/types.js +138 -0
  366. package/core-dist/src/ide/types.js.map +1 -0
  367. package/core-dist/src/index.d.ts +179 -0
  368. package/core-dist/src/index.js +225 -0
  369. package/core-dist/src/index.js.map +1 -0
  370. package/core-dist/src/index.test.d.ts +6 -0
  371. package/core-dist/src/index.test.js +12 -0
  372. package/core-dist/src/index.test.js.map +1 -0
  373. package/core-dist/src/lsp/LspConfigLoader.d.ts +46 -0
  374. package/core-dist/src/lsp/LspConfigLoader.js +381 -0
  375. package/core-dist/src/lsp/LspConfigLoader.js.map +1 -0
  376. package/core-dist/src/lsp/LspConfigLoader.test.d.ts +6 -0
  377. package/core-dist/src/lsp/LspConfigLoader.test.js +80 -0
  378. package/core-dist/src/lsp/LspConfigLoader.test.js.map +1 -0
  379. package/core-dist/src/lsp/LspConnectionFactory.d.ts +62 -0
  380. package/core-dist/src/lsp/LspConnectionFactory.js +305 -0
  381. package/core-dist/src/lsp/LspConnectionFactory.js.map +1 -0
  382. package/core-dist/src/lsp/LspLanguageDetector.d.ts +39 -0
  383. package/core-dist/src/lsp/LspLanguageDetector.js +199 -0
  384. package/core-dist/src/lsp/LspLanguageDetector.js.map +1 -0
  385. package/core-dist/src/lsp/LspResponseNormalizer.d.ts +122 -0
  386. package/core-dist/src/lsp/LspResponseNormalizer.js +710 -0
  387. package/core-dist/src/lsp/LspResponseNormalizer.js.map +1 -0
  388. package/core-dist/src/lsp/LspServerManager.d.ts +87 -0
  389. package/core-dist/src/lsp/LspServerManager.js +563 -0
  390. package/core-dist/src/lsp/LspServerManager.js.map +1 -0
  391. package/core-dist/src/lsp/NativeLspClient.d.ts +149 -0
  392. package/core-dist/src/lsp/NativeLspClient.js +169 -0
  393. package/core-dist/src/lsp/NativeLspClient.js.map +1 -0
  394. package/core-dist/src/lsp/NativeLspService.d.ts +106 -0
  395. package/core-dist/src/lsp/NativeLspService.integration.test.d.ts +6 -0
  396. package/core-dist/src/lsp/NativeLspService.integration.test.js +663 -0
  397. package/core-dist/src/lsp/NativeLspService.integration.test.js.map +1 -0
  398. package/core-dist/src/lsp/NativeLspService.js +623 -0
  399. package/core-dist/src/lsp/NativeLspService.js.map +1 -0
  400. package/core-dist/src/lsp/NativeLspService.test.d.ts +6 -0
  401. package/core-dist/src/lsp/NativeLspService.test.js +99 -0
  402. package/core-dist/src/lsp/NativeLspService.test.js.map +1 -0
  403. package/core-dist/src/lsp/constants.d.ts +35 -0
  404. package/core-dist/src/lsp/constants.js +86 -0
  405. package/core-dist/src/lsp/constants.js.map +1 -0
  406. package/core-dist/src/lsp/types.d.ts +409 -0
  407. package/core-dist/src/lsp/types.js +7 -0
  408. package/core-dist/src/lsp/types.js.map +1 -0
  409. package/core-dist/src/mcp/constants.d.ts +22 -0
  410. package/core-dist/src/mcp/constants.js +23 -0
  411. package/core-dist/src/mcp/constants.js.map +1 -0
  412. package/core-dist/src/mcp/google-auth-provider.d.ts +23 -0
  413. package/core-dist/src/mcp/google-auth-provider.js +75 -0
  414. package/core-dist/src/mcp/google-auth-provider.js.map +1 -0
  415. package/core-dist/src/mcp/google-auth-provider.test.d.ts +6 -0
  416. package/core-dist/src/mcp/google-auth-provider.test.js +89 -0
  417. package/core-dist/src/mcp/google-auth-provider.test.js.map +1 -0
  418. package/core-dist/src/mcp/oauth-provider.d.ts +150 -0
  419. package/core-dist/src/mcp/oauth-provider.js +617 -0
  420. package/core-dist/src/mcp/oauth-provider.js.map +1 -0
  421. package/core-dist/src/mcp/oauth-provider.test.d.ts +6 -0
  422. package/core-dist/src/mcp/oauth-provider.test.js +917 -0
  423. package/core-dist/src/mcp/oauth-provider.test.js.map +1 -0
  424. package/core-dist/src/mcp/oauth-token-storage.d.ts +65 -0
  425. package/core-dist/src/mcp/oauth-token-storage.js +182 -0
  426. package/core-dist/src/mcp/oauth-token-storage.js.map +1 -0
  427. package/core-dist/src/mcp/oauth-token-storage.test.d.ts +6 -0
  428. package/core-dist/src/mcp/oauth-token-storage.test.js +307 -0
  429. package/core-dist/src/mcp/oauth-token-storage.test.js.map +1 -0
  430. package/core-dist/src/mcp/oauth-utils.d.ts +124 -0
  431. package/core-dist/src/mcp/oauth-utils.js +252 -0
  432. package/core-dist/src/mcp/oauth-utils.js.map +1 -0
  433. package/core-dist/src/mcp/oauth-utils.test.d.ts +6 -0
  434. package/core-dist/src/mcp/oauth-utils.test.js +220 -0
  435. package/core-dist/src/mcp/oauth-utils.test.js.map +1 -0
  436. package/core-dist/src/mcp/sa-impersonation-provider.d.ts +33 -0
  437. package/core-dist/src/mcp/sa-impersonation-provider.js +133 -0
  438. package/core-dist/src/mcp/sa-impersonation-provider.js.map +1 -0
  439. package/core-dist/src/mcp/sa-impersonation-provider.test.d.ts +6 -0
  440. package/core-dist/src/mcp/sa-impersonation-provider.test.js +117 -0
  441. package/core-dist/src/mcp/sa-impersonation-provider.test.js.map +1 -0
  442. package/core-dist/src/mcp/token-storage/base-token-storage.d.ts +19 -0
  443. package/core-dist/src/mcp/token-storage/base-token-storage.js +36 -0
  444. package/core-dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
  445. package/core-dist/src/mcp/token-storage/base-token-storage.test.d.ts +6 -0
  446. package/core-dist/src/mcp/token-storage/base-token-storage.test.js +160 -0
  447. package/core-dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
  448. package/core-dist/src/mcp/token-storage/file-token-storage.d.ts +24 -0
  449. package/core-dist/src/mcp/token-storage/file-token-storage.js +144 -0
  450. package/core-dist/src/mcp/token-storage/file-token-storage.js.map +1 -0
  451. package/core-dist/src/mcp/token-storage/file-token-storage.test.d.ts +6 -0
  452. package/core-dist/src/mcp/token-storage/file-token-storage.test.js +235 -0
  453. package/core-dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -0
  454. package/core-dist/src/mcp/token-storage/hybrid-token-storage.d.ts +23 -0
  455. package/core-dist/src/mcp/token-storage/hybrid-token-storage.js +78 -0
  456. package/core-dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -0
  457. package/core-dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +6 -0
  458. package/core-dist/src/mcp/token-storage/hybrid-token-storage.test.js +193 -0
  459. package/core-dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +1 -0
  460. package/core-dist/src/mcp/token-storage/index.d.ts +11 -0
  461. package/core-dist/src/mcp/token-storage/index.js +12 -0
  462. package/core-dist/src/mcp/token-storage/index.js.map +1 -0
  463. package/core-dist/src/mcp/token-storage/keychain-token-storage.d.ts +35 -0
  464. package/core-dist/src/mcp/token-storage/keychain-token-storage.js +248 -0
  465. package/core-dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -0
  466. package/core-dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +6 -0
  467. package/core-dist/src/mcp/token-storage/keychain-token-storage.test.js +254 -0
  468. package/core-dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -0
  469. package/core-dist/src/mcp/token-storage/types.d.ts +38 -0
  470. package/core-dist/src/mcp/token-storage/types.js +11 -0
  471. package/core-dist/src/mcp/token-storage/types.js.map +1 -0
  472. package/core-dist/src/mocks/msw.d.ts +6 -0
  473. package/core-dist/src/mocks/msw.js +8 -0
  474. package/core-dist/src/mocks/msw.js.map +1 -0
  475. package/core-dist/src/models/constants.d.ts +71 -0
  476. package/core-dist/src/models/constants.js +92 -0
  477. package/core-dist/src/models/constants.js.map +1 -0
  478. package/core-dist/src/models/index.d.ts +10 -0
  479. package/core-dist/src/models/index.js +12 -0
  480. package/core-dist/src/models/index.js.map +1 -0
  481. package/core-dist/src/models/modelConfigErrors.d.ts +46 -0
  482. package/core-dist/src/models/modelConfigErrors.js +87 -0
  483. package/core-dist/src/models/modelConfigErrors.js.map +1 -0
  484. package/core-dist/src/models/modelConfigResolver.d.ts +84 -0
  485. package/core-dist/src/models/modelConfigResolver.js +204 -0
  486. package/core-dist/src/models/modelConfigResolver.js.map +1 -0
  487. package/core-dist/src/models/modelConfigResolver.test.d.ts +6 -0
  488. package/core-dist/src/models/modelConfigResolver.test.js +302 -0
  489. package/core-dist/src/models/modelConfigResolver.test.js.map +1 -0
  490. package/core-dist/src/models/modelRegistry.d.ts +55 -0
  491. package/core-dist/src/models/modelRegistry.js +182 -0
  492. package/core-dist/src/models/modelRegistry.js.map +1 -0
  493. package/core-dist/src/models/modelRegistry.test.d.ts +6 -0
  494. package/core-dist/src/models/modelRegistry.test.js +408 -0
  495. package/core-dist/src/models/modelRegistry.test.js.map +1 -0
  496. package/core-dist/src/models/modelsConfig.d.ts +343 -0
  497. package/core-dist/src/models/modelsConfig.js +957 -0
  498. package/core-dist/src/models/modelsConfig.js.map +1 -0
  499. package/core-dist/src/models/modelsConfig.test.d.ts +6 -0
  500. package/core-dist/src/models/modelsConfig.test.js +1242 -0
  501. package/core-dist/src/models/modelsConfig.test.js.map +1 -0
  502. package/core-dist/src/models/types.d.ts +114 -0
  503. package/core-dist/src/models/types.js +7 -0
  504. package/core-dist/src/models/types.js.map +1 -0
  505. package/core-dist/src/output/json-formatter.d.ts +11 -0
  506. package/core-dist/src/output/json-formatter.js +30 -0
  507. package/core-dist/src/output/json-formatter.js.map +1 -0
  508. package/core-dist/src/output/json-formatter.test.d.ts +6 -0
  509. package/core-dist/src/output/json-formatter.test.js +266 -0
  510. package/core-dist/src/output/json-formatter.test.js.map +1 -0
  511. package/core-dist/src/output/types.d.ts +25 -0
  512. package/core-dist/src/output/types.js +17 -0
  513. package/core-dist/src/output/types.js.map +1 -0
  514. package/core-dist/src/prompts/mcp-prompts.d.ts +8 -0
  515. package/core-dist/src/prompts/mcp-prompts.js +13 -0
  516. package/core-dist/src/prompts/mcp-prompts.js.map +1 -0
  517. package/core-dist/src/prompts/prompt-registry.d.ts +34 -0
  518. package/core-dist/src/prompts/prompt-registry.js +65 -0
  519. package/core-dist/src/prompts/prompt-registry.js.map +1 -0
  520. package/core-dist/src/qwen/qwenContentGenerator.d.ts +71 -0
  521. package/core-dist/src/qwen/qwenContentGenerator.js +182 -0
  522. package/core-dist/src/qwen/qwenContentGenerator.js.map +1 -0
  523. package/core-dist/src/qwen/qwenContentGenerator.test.d.ts +6 -0
  524. package/core-dist/src/qwen/qwenContentGenerator.test.js +1175 -0
  525. package/core-dist/src/qwen/qwenContentGenerator.test.js.map +1 -0
  526. package/core-dist/src/qwen/qwenOAuth2.d.ts +195 -0
  527. package/core-dist/src/qwen/qwenOAuth2.js +677 -0
  528. package/core-dist/src/qwen/qwenOAuth2.js.map +1 -0
  529. package/core-dist/src/qwen/qwenOAuth2.test.d.ts +6 -0
  530. package/core-dist/src/qwen/qwenOAuth2.test.js +1621 -0
  531. package/core-dist/src/qwen/qwenOAuth2.test.js.map +1 -0
  532. package/core-dist/src/qwen/sharedTokenManager.d.ts +196 -0
  533. package/core-dist/src/qwen/sharedTokenManager.js +649 -0
  534. package/core-dist/src/qwen/sharedTokenManager.js.map +1 -0
  535. package/core-dist/src/qwen/sharedTokenManager.test.d.ts +7 -0
  536. package/core-dist/src/qwen/sharedTokenManager.test.js +662 -0
  537. package/core-dist/src/qwen/sharedTokenManager.test.js.map +1 -0
  538. package/core-dist/src/services/chatCompressionService.d.ts +32 -0
  539. package/core-dist/src/services/chatCompressionService.js +213 -0
  540. package/core-dist/src/services/chatCompressionService.js.map +1 -0
  541. package/core-dist/src/services/chatCompressionService.test.d.ts +6 -0
  542. package/core-dist/src/services/chatCompressionService.test.js +343 -0
  543. package/core-dist/src/services/chatCompressionService.test.js.map +1 -0
  544. package/core-dist/src/services/chatRecordingService.d.ts +215 -0
  545. package/core-dist/src/services/chatRecordingService.js +285 -0
  546. package/core-dist/src/services/chatRecordingService.js.map +1 -0
  547. package/core-dist/src/services/chatRecordingService.test.d.ts +6 -0
  548. package/core-dist/src/services/chatRecordingService.test.js +299 -0
  549. package/core-dist/src/services/chatRecordingService.test.js.map +1 -0
  550. package/core-dist/src/services/fileDiscoveryService.d.ts +45 -0
  551. package/core-dist/src/services/fileDiscoveryService.js +104 -0
  552. package/core-dist/src/services/fileDiscoveryService.js.map +1 -0
  553. package/core-dist/src/services/fileDiscoveryService.test.d.ts +6 -0
  554. package/core-dist/src/services/fileDiscoveryService.test.js +143 -0
  555. package/core-dist/src/services/fileDiscoveryService.test.js.map +1 -0
  556. package/core-dist/src/services/fileSystemService.d.ts +88 -0
  557. package/core-dist/src/services/fileSystemService.js +131 -0
  558. package/core-dist/src/services/fileSystemService.js.map +1 -0
  559. package/core-dist/src/services/fileSystemService.test.d.ts +6 -0
  560. package/core-dist/src/services/fileSystemService.test.js +216 -0
  561. package/core-dist/src/services/fileSystemService.test.js.map +1 -0
  562. package/core-dist/src/services/gitService.d.ts +22 -0
  563. package/core-dist/src/services/gitService.js +98 -0
  564. package/core-dist/src/services/gitService.js.map +1 -0
  565. package/core-dist/src/services/gitService.test.d.ts +6 -0
  566. package/core-dist/src/services/gitService.test.js +187 -0
  567. package/core-dist/src/services/gitService.test.js.map +1 -0
  568. package/core-dist/src/services/loopDetectionService.d.ts +86 -0
  569. package/core-dist/src/services/loopDetectionService.js +239 -0
  570. package/core-dist/src/services/loopDetectionService.js.map +1 -0
  571. package/core-dist/src/services/loopDetectionService.test.d.ts +6 -0
  572. package/core-dist/src/services/loopDetectionService.test.js +478 -0
  573. package/core-dist/src/services/loopDetectionService.test.js.map +1 -0
  574. package/core-dist/src/services/sessionService.d.ts +200 -0
  575. package/core-dist/src/services/sessionService.js +527 -0
  576. package/core-dist/src/services/sessionService.js.map +1 -0
  577. package/core-dist/src/services/sessionService.test.d.ts +6 -0
  578. package/core-dist/src/services/sessionService.test.js +576 -0
  579. package/core-dist/src/services/sessionService.test.js.map +1 -0
  580. package/core-dist/src/services/shellExecutionService.d.ts +104 -0
  581. package/core-dist/src/services/shellExecutionService.js +626 -0
  582. package/core-dist/src/services/shellExecutionService.js.map +1 -0
  583. package/core-dist/src/services/shellExecutionService.test.d.ts +6 -0
  584. package/core-dist/src/services/shellExecutionService.test.js +684 -0
  585. package/core-dist/src/services/shellExecutionService.test.js.map +1 -0
  586. package/core-dist/src/skills/index.d.ts +19 -0
  587. package/core-dist/src/skills/index.js +9 -0
  588. package/core-dist/src/skills/index.js.map +1 -0
  589. package/core-dist/src/skills/skill-load.d.ts +4 -0
  590. package/core-dist/src/skills/skill-load.js +137 -0
  591. package/core-dist/src/skills/skill-load.js.map +1 -0
  592. package/core-dist/src/skills/skill-load.test.d.ts +6 -0
  593. package/core-dist/src/skills/skill-load.test.js +237 -0
  594. package/core-dist/src/skills/skill-load.test.js.map +1 -0
  595. package/core-dist/src/skills/skill-manager.d.ts +134 -0
  596. package/core-dist/src/skills/skill-manager.js +505 -0
  597. package/core-dist/src/skills/skill-manager.js.map +1 -0
  598. package/core-dist/src/skills/skill-manager.test.d.ts +6 -0
  599. package/core-dist/src/skills/skill-manager.test.js +527 -0
  600. package/core-dist/src/skills/skill-manager.test.js.map +1 -0
  601. package/core-dist/src/skills/types.d.ts +88 -0
  602. package/core-dist/src/skills/types.js +29 -0
  603. package/core-dist/src/skills/types.js.map +1 -0
  604. package/core-dist/src/subagents/builtin-agents.d.ts +35 -0
  605. package/core-dist/src/subagents/builtin-agents.js +85 -0
  606. package/core-dist/src/subagents/builtin-agents.js.map +1 -0
  607. package/core-dist/src/subagents/builtin-agents.test.d.ts +6 -0
  608. package/core-dist/src/subagents/builtin-agents.test.js +78 -0
  609. package/core-dist/src/subagents/builtin-agents.test.js.map +1 -0
  610. package/core-dist/src/subagents/index.d.ts +29 -0
  611. package/core-dist/src/subagents/index.js +15 -0
  612. package/core-dist/src/subagents/index.js.map +1 -0
  613. package/core-dist/src/subagents/subagent-events.d.ts +105 -0
  614. package/core-dist/src/subagents/subagent-events.js +32 -0
  615. package/core-dist/src/subagents/subagent-events.js.map +1 -0
  616. package/core-dist/src/subagents/subagent-hooks.d.ts +29 -0
  617. package/core-dist/src/subagents/subagent-hooks.js +7 -0
  618. package/core-dist/src/subagents/subagent-hooks.js.map +1 -0
  619. package/core-dist/src/subagents/subagent-manager.d.ts +178 -0
  620. package/core-dist/src/subagents/subagent-manager.js +711 -0
  621. package/core-dist/src/subagents/subagent-manager.js.map +1 -0
  622. package/core-dist/src/subagents/subagent-manager.test.d.ts +6 -0
  623. package/core-dist/src/subagents/subagent-manager.test.js +829 -0
  624. package/core-dist/src/subagents/subagent-manager.test.js.map +1 -0
  625. package/core-dist/src/subagents/subagent-statistics.d.ts +50 -0
  626. package/core-dist/src/subagents/subagent-statistics.js +210 -0
  627. package/core-dist/src/subagents/subagent-statistics.js.map +1 -0
  628. package/core-dist/src/subagents/subagent-statistics.test.d.ts +6 -0
  629. package/core-dist/src/subagents/subagent-statistics.test.js +238 -0
  630. package/core-dist/src/subagents/subagent-statistics.test.js.map +1 -0
  631. package/core-dist/src/subagents/subagent.d.ts +167 -0
  632. package/core-dist/src/subagents/subagent.js +758 -0
  633. package/core-dist/src/subagents/subagent.js.map +1 -0
  634. package/core-dist/src/subagents/subagent.test.d.ts +6 -0
  635. package/core-dist/src/subagents/subagent.test.js +819 -0
  636. package/core-dist/src/subagents/subagent.test.js.map +1 -0
  637. package/core-dist/src/subagents/types.d.ts +224 -0
  638. package/core-dist/src/subagents/types.js +58 -0
  639. package/core-dist/src/subagents/types.js.map +1 -0
  640. package/core-dist/src/subagents/types.test.d.ts +6 -0
  641. package/core-dist/src/subagents/types.test.js +31 -0
  642. package/core-dist/src/subagents/types.test.js.map +1 -0
  643. package/core-dist/src/subagents/validation.d.ts +63 -0
  644. package/core-dist/src/subagents/validation.js +293 -0
  645. package/core-dist/src/subagents/validation.js.map +1 -0
  646. package/core-dist/src/subagents/validation.test.d.ts +6 -0
  647. package/core-dist/src/subagents/validation.test.js +330 -0
  648. package/core-dist/src/subagents/validation.test.js.map +1 -0
  649. package/core-dist/src/telemetry/config.d.ts +31 -0
  650. package/core-dist/src/telemetry/config.js +74 -0
  651. package/core-dist/src/telemetry/config.js.map +1 -0
  652. package/core-dist/src/telemetry/config.test.d.ts +6 -0
  653. package/core-dist/src/telemetry/config.test.js +124 -0
  654. package/core-dist/src/telemetry/config.test.js.map +1 -0
  655. package/core-dist/src/telemetry/constants.d.ts +39 -0
  656. package/core-dist/src/telemetry/constants.js +41 -0
  657. package/core-dist/src/telemetry/constants.js.map +1 -0
  658. package/core-dist/src/telemetry/file-exporters.d.ts +29 -0
  659. package/core-dist/src/telemetry/file-exporters.js +62 -0
  660. package/core-dist/src/telemetry/file-exporters.js.map +1 -0
  661. package/core-dist/src/telemetry/index.d.ts +25 -0
  662. package/core-dist/src/telemetry/index.js +31 -0
  663. package/core-dist/src/telemetry/index.js.map +1 -0
  664. package/core-dist/src/telemetry/integration.test.circular.d.ts +6 -0
  665. package/core-dist/src/telemetry/integration.test.circular.js +95 -0
  666. package/core-dist/src/telemetry/integration.test.circular.js.map +1 -0
  667. package/core-dist/src/telemetry/loggers.d.ts +40 -0
  668. package/core-dist/src/telemetry/loggers.js +712 -0
  669. package/core-dist/src/telemetry/loggers.js.map +1 -0
  670. package/core-dist/src/telemetry/loggers.test.circular.d.ts +6 -0
  671. package/core-dist/src/telemetry/loggers.test.circular.js +107 -0
  672. package/core-dist/src/telemetry/loggers.test.circular.js.map +1 -0
  673. package/core-dist/src/telemetry/loggers.test.d.ts +6 -0
  674. package/core-dist/src/telemetry/loggers.test.js +961 -0
  675. package/core-dist/src/telemetry/loggers.test.js.map +1 -0
  676. package/core-dist/src/telemetry/metrics.d.ts +320 -0
  677. package/core-dist/src/telemetry/metrics.js +532 -0
  678. package/core-dist/src/telemetry/metrics.js.map +1 -0
  679. package/core-dist/src/telemetry/metrics.test.d.ts +6 -0
  680. package/core-dist/src/telemetry/metrics.test.js +746 -0
  681. package/core-dist/src/telemetry/metrics.test.js.map +1 -0
  682. package/core-dist/src/telemetry/qwen-logger/event-types.d.ts +89 -0
  683. package/core-dist/src/telemetry/qwen-logger/event-types.js +2 -0
  684. package/core-dist/src/telemetry/qwen-logger/event-types.js.map +1 -0
  685. package/core-dist/src/telemetry/qwen-logger/qwen-logger.d.ts +102 -0
  686. package/core-dist/src/telemetry/qwen-logger/qwen-logger.js +739 -0
  687. package/core-dist/src/telemetry/qwen-logger/qwen-logger.js.map +1 -0
  688. package/core-dist/src/telemetry/qwen-logger/qwen-logger.test.d.ts +6 -0
  689. package/core-dist/src/telemetry/qwen-logger/qwen-logger.test.js +380 -0
  690. package/core-dist/src/telemetry/qwen-logger/qwen-logger.test.js.map +1 -0
  691. package/core-dist/src/telemetry/sdk.d.ts +9 -0
  692. package/core-dist/src/telemetry/sdk.js +163 -0
  693. package/core-dist/src/telemetry/sdk.js.map +1 -0
  694. package/core-dist/src/telemetry/sdk.test.d.ts +6 -0
  695. package/core-dist/src/telemetry/sdk.test.js +116 -0
  696. package/core-dist/src/telemetry/sdk.test.js.map +1 -0
  697. package/core-dist/src/telemetry/telemetry-utils.d.ts +6 -0
  698. package/core-dist/src/telemetry/telemetry-utils.js +14 -0
  699. package/core-dist/src/telemetry/telemetry-utils.js.map +1 -0
  700. package/core-dist/src/telemetry/telemetry-utils.test.d.ts +6 -0
  701. package/core-dist/src/telemetry/telemetry-utils.test.js +40 -0
  702. package/core-dist/src/telemetry/telemetry-utils.test.js.map +1 -0
  703. package/core-dist/src/telemetry/telemetry.test.d.ts +6 -0
  704. package/core-dist/src/telemetry/telemetry.test.js +49 -0
  705. package/core-dist/src/telemetry/telemetry.test.js.map +1 -0
  706. package/core-dist/src/telemetry/tool-call-decision.d.ts +13 -0
  707. package/core-dist/src/telemetry/tool-call-decision.js +29 -0
  708. package/core-dist/src/telemetry/tool-call-decision.js.map +1 -0
  709. package/core-dist/src/telemetry/types.d.ts +363 -0
  710. package/core-dist/src/telemetry/types.js +635 -0
  711. package/core-dist/src/telemetry/types.js.map +1 -0
  712. package/core-dist/src/telemetry/uiTelemetry.d.ts +80 -0
  713. package/core-dist/src/telemetry/uiTelemetry.js +164 -0
  714. package/core-dist/src/telemetry/uiTelemetry.js.map +1 -0
  715. package/core-dist/src/telemetry/uiTelemetry.test.d.ts +6 -0
  716. package/core-dist/src/telemetry/uiTelemetry.test.js +625 -0
  717. package/core-dist/src/telemetry/uiTelemetry.test.js.map +1 -0
  718. package/core-dist/src/test-utils/config.d.ts +17 -0
  719. package/core-dist/src/test-utils/config.js +31 -0
  720. package/core-dist/src/test-utils/config.js.map +1 -0
  721. package/core-dist/src/test-utils/index.d.ts +6 -0
  722. package/core-dist/src/test-utils/index.js +7 -0
  723. package/core-dist/src/test-utils/index.js.map +1 -0
  724. package/core-dist/src/test-utils/mock-tool.d.ts +66 -0
  725. package/core-dist/src/test-utils/mock-tool.js +121 -0
  726. package/core-dist/src/test-utils/mock-tool.js.map +1 -0
  727. package/core-dist/src/test-utils/mockWorkspaceContext.d.ts +13 -0
  728. package/core-dist/src/test-utils/mockWorkspaceContext.js +24 -0
  729. package/core-dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
  730. package/core-dist/src/tools/askUserQuestion.d.ts +41 -0
  731. package/core-dist/src/tools/askUserQuestion.js +247 -0
  732. package/core-dist/src/tools/askUserQuestion.js.map +1 -0
  733. package/core-dist/src/tools/askUserQuestion.test.d.ts +6 -0
  734. package/core-dist/src/tools/askUserQuestion.test.js +218 -0
  735. package/core-dist/src/tools/askUserQuestion.test.js.map +1 -0
  736. package/core-dist/src/tools/diffOptions.d.ts +9 -0
  737. package/core-dist/src/tools/diffOptions.js +46 -0
  738. package/core-dist/src/tools/diffOptions.js.map +1 -0
  739. package/core-dist/src/tools/diffOptions.test.d.ts +6 -0
  740. package/core-dist/src/tools/diffOptions.test.js +155 -0
  741. package/core-dist/src/tools/diffOptions.test.js.map +1 -0
  742. package/core-dist/src/tools/edit.d.ts +55 -0
  743. package/core-dist/src/tools/edit.js +446 -0
  744. package/core-dist/src/tools/edit.js.map +1 -0
  745. package/core-dist/src/tools/edit.test.d.ts +6 -0
  746. package/core-dist/src/tools/edit.test.js +742 -0
  747. package/core-dist/src/tools/edit.test.js.map +1 -0
  748. package/core-dist/src/tools/exitPlanMode.d.ts +28 -0
  749. package/core-dist/src/tools/exitPlanMode.js +144 -0
  750. package/core-dist/src/tools/exitPlanMode.js.map +1 -0
  751. package/core-dist/src/tools/exitPlanMode.test.d.ts +6 -0
  752. package/core-dist/src/tools/exitPlanMode.test.js +178 -0
  753. package/core-dist/src/tools/exitPlanMode.test.js.map +1 -0
  754. package/core-dist/src/tools/glob.d.ts +44 -0
  755. package/core-dist/src/tools/glob.js +195 -0
  756. package/core-dist/src/tools/glob.js.map +1 -0
  757. package/core-dist/src/tools/glob.test.d.ts +6 -0
  758. package/core-dist/src/tools/glob.test.js +481 -0
  759. package/core-dist/src/tools/glob.test.js.map +1 -0
  760. package/core-dist/src/tools/grep.d.ts +44 -0
  761. package/core-dist/src/tools/grep.js +427 -0
  762. package/core-dist/src/tools/grep.js.map +1 -0
  763. package/core-dist/src/tools/grep.test.d.ts +6 -0
  764. package/core-dist/src/tools/grep.test.js +360 -0
  765. package/core-dist/src/tools/grep.test.js.map +1 -0
  766. package/core-dist/src/tools/ls.d.ts +68 -0
  767. package/core-dist/src/tools/ls.js +221 -0
  768. package/core-dist/src/tools/ls.js.map +1 -0
  769. package/core-dist/src/tools/ls.test.d.ts +6 -0
  770. package/core-dist/src/tools/ls.test.js +246 -0
  771. package/core-dist/src/tools/ls.test.js.map +1 -0
  772. package/core-dist/src/tools/lsp.d.ts +66 -0
  773. package/core-dist/src/tools/lsp.js +894 -0
  774. package/core-dist/src/tools/lsp.js.map +1 -0
  775. package/core-dist/src/tools/lsp.test.d.ts +6 -0
  776. package/core-dist/src/tools/lsp.test.js +960 -0
  777. package/core-dist/src/tools/lsp.test.js.map +1 -0
  778. package/core-dist/src/tools/mcp-client-manager.d.ts +110 -0
  779. package/core-dist/src/tools/mcp-client-manager.js +381 -0
  780. package/core-dist/src/tools/mcp-client-manager.js.map +1 -0
  781. package/core-dist/src/tools/mcp-client-manager.test.d.ts +6 -0
  782. package/core-dist/src/tools/mcp-client-manager.test.js +207 -0
  783. package/core-dist/src/tools/mcp-client-manager.test.js.map +1 -0
  784. package/core-dist/src/tools/mcp-client.d.ts +199 -0
  785. package/core-dist/src/tools/mcp-client.js +1001 -0
  786. package/core-dist/src/tools/mcp-client.js.map +1 -0
  787. package/core-dist/src/tools/mcp-client.test.d.ts +6 -0
  788. package/core-dist/src/tools/mcp-client.test.js +307 -0
  789. package/core-dist/src/tools/mcp-client.test.js.map +1 -0
  790. package/core-dist/src/tools/mcp-tool.d.ts +69 -0
  791. package/core-dist/src/tools/mcp-tool.js +365 -0
  792. package/core-dist/src/tools/mcp-tool.js.map +1 -0
  793. package/core-dist/src/tools/mcp-tool.test.d.ts +6 -0
  794. package/core-dist/src/tools/mcp-tool.test.js +827 -0
  795. package/core-dist/src/tools/mcp-tool.test.js.map +1 -0
  796. package/core-dist/src/tools/memoryTool.d.ts +42 -0
  797. package/core-dist/src/tools/memoryTool.js +403 -0
  798. package/core-dist/src/tools/memoryTool.js.map +1 -0
  799. package/core-dist/src/tools/memoryTool.test.d.ts +6 -0
  800. package/core-dist/src/tools/memoryTool.test.js +416 -0
  801. package/core-dist/src/tools/memoryTool.test.js.map +1 -0
  802. package/core-dist/src/tools/modifiable-tool.d.ts +32 -0
  803. package/core-dist/src/tools/modifiable-tool.js +90 -0
  804. package/core-dist/src/tools/modifiable-tool.js.map +1 -0
  805. package/core-dist/src/tools/modifiable-tool.test.d.ts +6 -0
  806. package/core-dist/src/tools/modifiable-tool.test.js +188 -0
  807. package/core-dist/src/tools/modifiable-tool.test.js.map +1 -0
  808. package/core-dist/src/tools/read-file.d.ts +35 -0
  809. package/core-dist/src/tools/read-file.js +141 -0
  810. package/core-dist/src/tools/read-file.js.map +1 -0
  811. package/core-dist/src/tools/read-file.test.d.ts +6 -0
  812. package/core-dist/src/tools/read-file.test.js +333 -0
  813. package/core-dist/src/tools/read-file.test.js.map +1 -0
  814. package/core-dist/src/tools/ripGrep.d.ts +44 -0
  815. package/core-dist/src/tools/ripGrep.js +235 -0
  816. package/core-dist/src/tools/ripGrep.js.map +1 -0
  817. package/core-dist/src/tools/ripGrep.test.d.ts +6 -0
  818. package/core-dist/src/tools/ripGrep.test.js +529 -0
  819. package/core-dist/src/tools/ripGrep.test.js.map +1 -0
  820. package/core-dist/src/tools/sdk-control-client-transport.d.ts +67 -0
  821. package/core-dist/src/tools/sdk-control-client-transport.js +93 -0
  822. package/core-dist/src/tools/sdk-control-client-transport.js.map +1 -0
  823. package/core-dist/src/tools/shell.d.ts +34 -0
  824. package/core-dist/src/tools/shell.js +509 -0
  825. package/core-dist/src/tools/shell.js.map +1 -0
  826. package/core-dist/src/tools/shell.test.d.ts +6 -0
  827. package/core-dist/src/tools/shell.test.js +880 -0
  828. package/core-dist/src/tools/shell.test.js.map +1 -0
  829. package/core-dist/src/tools/skill.d.ts +45 -0
  830. package/core-dist/src/tools/skill.js +214 -0
  831. package/core-dist/src/tools/skill.js.map +1 -0
  832. package/core-dist/src/tools/skill.test.d.ts +6 -0
  833. package/core-dist/src/tools/skill.test.js +280 -0
  834. package/core-dist/src/tools/skill.test.js.map +1 -0
  835. package/core-dist/src/tools/task.d.ts +60 -0
  836. package/core-dist/src/tools/task.js +417 -0
  837. package/core-dist/src/tools/task.js.map +1 -0
  838. package/core-dist/src/tools/task.test.d.ts +6 -0
  839. package/core-dist/src/tools/task.test.js +367 -0
  840. package/core-dist/src/tools/task.test.js.map +1 -0
  841. package/core-dist/src/tools/todoWrite.d.ts +42 -0
  842. package/core-dist/src/tools/todoWrite.js +409 -0
  843. package/core-dist/src/tools/todoWrite.js.map +1 -0
  844. package/core-dist/src/tools/todoWrite.test.d.ts +6 -0
  845. package/core-dist/src/tools/todoWrite.test.js +234 -0
  846. package/core-dist/src/tools/todoWrite.test.js.map +1 -0
  847. package/core-dist/src/tools/tool-error.d.ts +45 -0
  848. package/core-dist/src/tools/tool-error.js +61 -0
  849. package/core-dist/src/tools/tool-error.js.map +1 -0
  850. package/core-dist/src/tools/tool-names.d.ts +60 -0
  851. package/core-dist/src/tools/tool-names.js +66 -0
  852. package/core-dist/src/tools/tool-names.js.map +1 -0
  853. package/core-dist/src/tools/tool-registry.d.ts +103 -0
  854. package/core-dist/src/tools/tool-registry.js +404 -0
  855. package/core-dist/src/tools/tool-registry.js.map +1 -0
  856. package/core-dist/src/tools/tool-registry.test.d.ts +6 -0
  857. package/core-dist/src/tools/tool-registry.test.js +331 -0
  858. package/core-dist/src/tools/tool-registry.test.js.map +1 -0
  859. package/core-dist/src/tools/tools.d.ts +364 -0
  860. package/core-dist/src/tools/tools.js +263 -0
  861. package/core-dist/src/tools/tools.js.map +1 -0
  862. package/core-dist/src/tools/tools.test.d.ts +6 -0
  863. package/core-dist/src/tools/tools.test.js +205 -0
  864. package/core-dist/src/tools/tools.test.js.map +1 -0
  865. package/core-dist/src/tools/web-fetch.d.ts +31 -0
  866. package/core-dist/src/tools/web-fetch.js +168 -0
  867. package/core-dist/src/tools/web-fetch.js.map +1 -0
  868. package/core-dist/src/tools/web-fetch.test.d.ts +6 -0
  869. package/core-dist/src/tools/web-fetch.test.js +134 -0
  870. package/core-dist/src/tools/web-fetch.test.js.map +1 -0
  871. package/core-dist/src/tools/web-search/base-provider.d.ts +31 -0
  872. package/core-dist/src/tools/web-search/base-provider.js +34 -0
  873. package/core-dist/src/tools/web-search/base-provider.js.map +1 -0
  874. package/core-dist/src/tools/web-search/index.d.ts +24 -0
  875. package/core-dist/src/tools/web-search/index.js +249 -0
  876. package/core-dist/src/tools/web-search/index.js.map +1 -0
  877. package/core-dist/src/tools/web-search/index.test.d.ts +6 -0
  878. package/core-dist/src/tools/web-search/index.test.js +237 -0
  879. package/core-dist/src/tools/web-search/index.test.js.map +1 -0
  880. package/core-dist/src/tools/web-search/providers/dashscope-provider.d.ts +23 -0
  881. package/core-dist/src/tools/web-search/providers/dashscope-provider.js +120 -0
  882. package/core-dist/src/tools/web-search/providers/dashscope-provider.js.map +1 -0
  883. package/core-dist/src/tools/web-search/providers/google-provider.d.ts +17 -0
  884. package/core-dist/src/tools/web-search/providers/google-provider.js +55 -0
  885. package/core-dist/src/tools/web-search/providers/google-provider.js.map +1 -0
  886. package/core-dist/src/tools/web-search/providers/tavily-provider.d.ts +17 -0
  887. package/core-dist/src/tools/web-search/providers/tavily-provider.js +54 -0
  888. package/core-dist/src/tools/web-search/providers/tavily-provider.js.map +1 -0
  889. package/core-dist/src/tools/web-search/types.d.ts +138 -0
  890. package/core-dist/src/tools/web-search/types.js +7 -0
  891. package/core-dist/src/tools/web-search/types.js.map +1 -0
  892. package/core-dist/src/tools/web-search/utils.d.ts +28 -0
  893. package/core-dist/src/tools/web-search/utils.js +35 -0
  894. package/core-dist/src/tools/web-search/utils.js.map +1 -0
  895. package/core-dist/src/tools/write-file.d.ts +52 -0
  896. package/core-dist/src/tools/write-file.js +316 -0
  897. package/core-dist/src/tools/write-file.js.map +1 -0
  898. package/core-dist/src/tools/write-file.test.d.ts +6 -0
  899. package/core-dist/src/tools/write-file.test.js +613 -0
  900. package/core-dist/src/tools/write-file.test.js.map +1 -0
  901. package/core-dist/src/utils/LruCache.d.ts +13 -0
  902. package/core-dist/src/utils/LruCache.js +38 -0
  903. package/core-dist/src/utils/LruCache.js.map +1 -0
  904. package/core-dist/src/utils/browser.d.ts +13 -0
  905. package/core-dist/src/utils/browser.js +50 -0
  906. package/core-dist/src/utils/browser.js.map +1 -0
  907. package/core-dist/src/utils/configResolver.d.ts +120 -0
  908. package/core-dist/src/utils/configResolver.js +125 -0
  909. package/core-dist/src/utils/configResolver.js.map +1 -0
  910. package/core-dist/src/utils/configResolver.test.d.ts +6 -0
  911. package/core-dist/src/utils/configResolver.test.js +99 -0
  912. package/core-dist/src/utils/configResolver.test.js.map +1 -0
  913. package/core-dist/src/utils/debugLogger.d.ts +46 -0
  914. package/core-dist/src/utils/debugLogger.js +159 -0
  915. package/core-dist/src/utils/debugLogger.js.map +1 -0
  916. package/core-dist/src/utils/debugLogger.test.d.ts +6 -0
  917. package/core-dist/src/utils/debugLogger.test.js +188 -0
  918. package/core-dist/src/utils/debugLogger.test.js.map +1 -0
  919. package/core-dist/src/utils/editHelper.d.ts +58 -0
  920. package/core-dist/src/utils/editHelper.js +342 -0
  921. package/core-dist/src/utils/editHelper.js.map +1 -0
  922. package/core-dist/src/utils/editHelper.test.d.ts +6 -0
  923. package/core-dist/src/utils/editHelper.test.js +127 -0
  924. package/core-dist/src/utils/editHelper.test.js.map +1 -0
  925. package/core-dist/src/utils/editor.d.ts +37 -0
  926. package/core-dist/src/utils/editor.js +179 -0
  927. package/core-dist/src/utils/editor.js.map +1 -0
  928. package/core-dist/src/utils/editor.test.d.ts +6 -0
  929. package/core-dist/src/utils/editor.test.js +434 -0
  930. package/core-dist/src/utils/editor.test.js.map +1 -0
  931. package/core-dist/src/utils/envVarResolver.d.ts +39 -0
  932. package/core-dist/src/utils/envVarResolver.js +100 -0
  933. package/core-dist/src/utils/envVarResolver.js.map +1 -0
  934. package/core-dist/src/utils/envVarResolver.test.d.ts +6 -0
  935. package/core-dist/src/utils/envVarResolver.test.js +221 -0
  936. package/core-dist/src/utils/envVarResolver.test.js.map +1 -0
  937. package/core-dist/src/utils/environmentContext.d.ts +21 -0
  938. package/core-dist/src/utils/environmentContext.js +73 -0
  939. package/core-dist/src/utils/environmentContext.js.map +1 -0
  940. package/core-dist/src/utils/environmentContext.test.d.ts +6 -0
  941. package/core-dist/src/utils/environmentContext.test.js +151 -0
  942. package/core-dist/src/utils/environmentContext.test.js.map +1 -0
  943. package/core-dist/src/utils/errorParsing.d.ts +7 -0
  944. package/core-dist/src/utils/errorParsing.js +72 -0
  945. package/core-dist/src/utils/errorParsing.js.map +1 -0
  946. package/core-dist/src/utils/errorParsing.test.d.ts +6 -0
  947. package/core-dist/src/utils/errorParsing.test.js +87 -0
  948. package/core-dist/src/utils/errorParsing.test.js.map +1 -0
  949. package/core-dist/src/utils/errorReporting.d.ts +14 -0
  950. package/core-dist/src/utils/errorReporting.js +56 -0
  951. package/core-dist/src/utils/errorReporting.js.map +1 -0
  952. package/core-dist/src/utils/errorReporting.test.d.ts +6 -0
  953. package/core-dist/src/utils/errorReporting.test.js +84 -0
  954. package/core-dist/src/utils/errorReporting.test.js.map +1 -0
  955. package/core-dist/src/utils/errors.d.ts +44 -0
  956. package/core-dist/src/utils/errors.js +114 -0
  957. package/core-dist/src/utils/errors.js.map +1 -0
  958. package/core-dist/src/utils/errors.test.d.ts +6 -0
  959. package/core-dist/src/utils/errors.test.js +70 -0
  960. package/core-dist/src/utils/errors.test.js.map +1 -0
  961. package/core-dist/src/utils/fetch.d.ts +14 -0
  962. package/core-dist/src/utils/fetch.js +152 -0
  963. package/core-dist/src/utils/fetch.js.map +1 -0
  964. package/core-dist/src/utils/fetch.test.d.ts +6 -0
  965. package/core-dist/src/utils/fetch.test.js +40 -0
  966. package/core-dist/src/utils/fetch.test.js.map +1 -0
  967. package/core-dist/src/utils/fileUtils.d.ts +102 -0
  968. package/core-dist/src/utils/fileUtils.js +584 -0
  969. package/core-dist/src/utils/fileUtils.js.map +1 -0
  970. package/core-dist/src/utils/fileUtils.test.d.ts +6 -0
  971. package/core-dist/src/utils/fileUtils.test.js +808 -0
  972. package/core-dist/src/utils/fileUtils.test.js.map +1 -0
  973. package/core-dist/src/utils/filesearch/crawlCache.d.ts +25 -0
  974. package/core-dist/src/utils/filesearch/crawlCache.js +57 -0
  975. package/core-dist/src/utils/filesearch/crawlCache.js.map +1 -0
  976. package/core-dist/src/utils/filesearch/crawlCache.test.d.ts +6 -0
  977. package/core-dist/src/utils/filesearch/crawlCache.test.js +103 -0
  978. package/core-dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
  979. package/core-dist/src/utils/filesearch/crawler.d.ts +15 -0
  980. package/core-dist/src/utils/filesearch/crawler.js +50 -0
  981. package/core-dist/src/utils/filesearch/crawler.js.map +1 -0
  982. package/core-dist/src/utils/filesearch/crawler.test.d.ts +6 -0
  983. package/core-dist/src/utils/filesearch/crawler.test.js +468 -0
  984. package/core-dist/src/utils/filesearch/crawler.test.js.map +1 -0
  985. package/core-dist/src/utils/filesearch/fileSearch.d.ts +38 -0
  986. package/core-dist/src/utils/filesearch/fileSearch.js +194 -0
  987. package/core-dist/src/utils/filesearch/fileSearch.js.map +1 -0
  988. package/core-dist/src/utils/filesearch/fileSearch.test.d.ts +6 -0
  989. package/core-dist/src/utils/filesearch/fileSearch.test.js +642 -0
  990. package/core-dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
  991. package/core-dist/src/utils/filesearch/ignore.d.ts +42 -0
  992. package/core-dist/src/utils/filesearch/ignore.js +106 -0
  993. package/core-dist/src/utils/filesearch/ignore.js.map +1 -0
  994. package/core-dist/src/utils/filesearch/ignore.test.d.ts +6 -0
  995. package/core-dist/src/utils/filesearch/ignore.test.js +144 -0
  996. package/core-dist/src/utils/filesearch/ignore.test.js.map +1 -0
  997. package/core-dist/src/utils/filesearch/result-cache.d.ts +33 -0
  998. package/core-dist/src/utils/filesearch/result-cache.js +59 -0
  999. package/core-dist/src/utils/filesearch/result-cache.js.map +1 -0
  1000. package/core-dist/src/utils/filesearch/result-cache.test.d.ts +6 -0
  1001. package/core-dist/src/utils/filesearch/result-cache.test.js +46 -0
  1002. package/core-dist/src/utils/filesearch/result-cache.test.js.map +1 -0
  1003. package/core-dist/src/utils/formatters.d.ts +6 -0
  1004. package/core-dist/src/utils/formatters.js +16 -0
  1005. package/core-dist/src/utils/formatters.js.map +1 -0
  1006. package/core-dist/src/utils/generateContentResponseUtilities.d.ts +13 -0
  1007. package/core-dist/src/utils/generateContentResponseUtilities.js +95 -0
  1008. package/core-dist/src/utils/generateContentResponseUtilities.js.map +1 -0
  1009. package/core-dist/src/utils/generateContentResponseUtilities.test.d.ts +6 -0
  1010. package/core-dist/src/utils/generateContentResponseUtilities.test.js +235 -0
  1011. package/core-dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
  1012. package/core-dist/src/utils/getFolderStructure.d.ts +31 -0
  1013. package/core-dist/src/utils/getFolderStructure.js +233 -0
  1014. package/core-dist/src/utils/getFolderStructure.js.map +1 -0
  1015. package/core-dist/src/utils/getFolderStructure.test.d.ts +6 -0
  1016. package/core-dist/src/utils/getFolderStructure.test.js +282 -0
  1017. package/core-dist/src/utils/getFolderStructure.test.js.map +1 -0
  1018. package/core-dist/src/utils/getPty.d.ts +7 -0
  1019. package/core-dist/src/utils/getPty.js +7 -0
  1020. package/core-dist/src/utils/getPty.js.map +1 -0
  1021. package/core-dist/src/utils/gitIgnoreParser.d.ts +16 -0
  1022. package/core-dist/src/utils/gitIgnoreParser.js +152 -0
  1023. package/core-dist/src/utils/gitIgnoreParser.js.map +1 -0
  1024. package/core-dist/src/utils/gitIgnoreParser.test.d.ts +6 -0
  1025. package/core-dist/src/utils/gitIgnoreParser.test.js +185 -0
  1026. package/core-dist/src/utils/gitIgnoreParser.test.js.map +1 -0
  1027. package/core-dist/src/utils/gitUtils.d.ts +21 -0
  1028. package/core-dist/src/utils/gitUtils.js +78 -0
  1029. package/core-dist/src/utils/gitUtils.js.map +1 -0
  1030. package/core-dist/src/utils/iconvHelper.d.ts +33 -0
  1031. package/core-dist/src/utils/iconvHelper.js +48 -0
  1032. package/core-dist/src/utils/iconvHelper.js.map +1 -0
  1033. package/core-dist/src/utils/ignorePatterns.d.ts +103 -0
  1034. package/core-dist/src/utils/ignorePatterns.js +222 -0
  1035. package/core-dist/src/utils/ignorePatterns.js.map +1 -0
  1036. package/core-dist/src/utils/ignorePatterns.test.d.ts +6 -0
  1037. package/core-dist/src/utils/ignorePatterns.test.js +255 -0
  1038. package/core-dist/src/utils/ignorePatterns.test.js.map +1 -0
  1039. package/core-dist/src/utils/installationManager.d.ts +16 -0
  1040. package/core-dist/src/utils/installationManager.js +52 -0
  1041. package/core-dist/src/utils/installationManager.js.map +1 -0
  1042. package/core-dist/src/utils/installationManager.test.d.ts +6 -0
  1043. package/core-dist/src/utils/installationManager.test.js +79 -0
  1044. package/core-dist/src/utils/installationManager.test.js.map +1 -0
  1045. package/core-dist/src/utils/jsonl-utils.d.ts +38 -0
  1046. package/core-dist/src/utils/jsonl-utils.js +176 -0
  1047. package/core-dist/src/utils/jsonl-utils.js.map +1 -0
  1048. package/core-dist/src/utils/language-detection.d.ts +6 -0
  1049. package/core-dist/src/utils/language-detection.js +101 -0
  1050. package/core-dist/src/utils/language-detection.js.map +1 -0
  1051. package/core-dist/src/utils/memoryDiscovery.d.ts +15 -0
  1052. package/core-dist/src/utils/memoryDiscovery.js +238 -0
  1053. package/core-dist/src/utils/memoryDiscovery.js.map +1 -0
  1054. package/core-dist/src/utils/memoryDiscovery.test.d.ts +6 -0
  1055. package/core-dist/src/utils/memoryDiscovery.test.js +212 -0
  1056. package/core-dist/src/utils/memoryDiscovery.test.js.map +1 -0
  1057. package/core-dist/src/utils/memoryImportProcessor.d.ts +41 -0
  1058. package/core-dist/src/utils/memoryImportProcessor.js +296 -0
  1059. package/core-dist/src/utils/memoryImportProcessor.js.map +1 -0
  1060. package/core-dist/src/utils/memoryImportProcessor.test.d.ts +6 -0
  1061. package/core-dist/src/utils/memoryImportProcessor.test.js +631 -0
  1062. package/core-dist/src/utils/memoryImportProcessor.test.js.map +1 -0
  1063. package/core-dist/src/utils/messageInspectors.d.ts +8 -0
  1064. package/core-dist/src/utils/messageInspectors.js +16 -0
  1065. package/core-dist/src/utils/messageInspectors.js.map +1 -0
  1066. package/core-dist/src/utils/nextSpeakerChecker.d.ts +12 -0
  1067. package/core-dist/src/utils/nextSpeakerChecker.js +99 -0
  1068. package/core-dist/src/utils/nextSpeakerChecker.js.map +1 -0
  1069. package/core-dist/src/utils/nextSpeakerChecker.test.d.ts +6 -0
  1070. package/core-dist/src/utils/nextSpeakerChecker.test.js +183 -0
  1071. package/core-dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
  1072. package/core-dist/src/utils/openaiLogger.d.ts +42 -0
  1073. package/core-dist/src/utils/openaiLogger.js +140 -0
  1074. package/core-dist/src/utils/openaiLogger.js.map +1 -0
  1075. package/core-dist/src/utils/openaiLogger.test.d.ts +6 -0
  1076. package/core-dist/src/utils/openaiLogger.test.js +314 -0
  1077. package/core-dist/src/utils/openaiLogger.test.js.map +1 -0
  1078. package/core-dist/src/utils/partUtils.d.ts +35 -0
  1079. package/core-dist/src/utils/partUtils.js +133 -0
  1080. package/core-dist/src/utils/partUtils.js.map +1 -0
  1081. package/core-dist/src/utils/partUtils.test.d.ts +6 -0
  1082. package/core-dist/src/utils/partUtils.test.js +241 -0
  1083. package/core-dist/src/utils/partUtils.test.js.map +1 -0
  1084. package/core-dist/src/utils/pathReader.d.ts +17 -0
  1085. package/core-dist/src/utils/pathReader.js +92 -0
  1086. package/core-dist/src/utils/pathReader.js.map +1 -0
  1087. package/core-dist/src/utils/pathReader.test.d.ts +6 -0
  1088. package/core-dist/src/utils/pathReader.test.js +367 -0
  1089. package/core-dist/src/utils/pathReader.test.js.map +1 -0
  1090. package/core-dist/src/utils/paths.d.ts +110 -0
  1091. package/core-dist/src/utils/paths.js +269 -0
  1092. package/core-dist/src/utils/paths.js.map +1 -0
  1093. package/core-dist/src/utils/paths.test.d.ts +6 -0
  1094. package/core-dist/src/utils/paths.test.js +633 -0
  1095. package/core-dist/src/utils/paths.test.js.map +1 -0
  1096. package/core-dist/src/utils/projectSummary.d.ts +22 -0
  1097. package/core-dist/src/utils/projectSummary.js +86 -0
  1098. package/core-dist/src/utils/projectSummary.js.map +1 -0
  1099. package/core-dist/src/utils/promptIdContext.d.ts +7 -0
  1100. package/core-dist/src/utils/promptIdContext.js +8 -0
  1101. package/core-dist/src/utils/promptIdContext.js.map +1 -0
  1102. package/core-dist/src/utils/quotaErrorDetection.d.ts +19 -0
  1103. package/core-dist/src/utils/quotaErrorDetection.js +84 -0
  1104. package/core-dist/src/utils/quotaErrorDetection.js.map +1 -0
  1105. package/core-dist/src/utils/quotaErrorDetection.test.d.ts +6 -0
  1106. package/core-dist/src/utils/quotaErrorDetection.test.js +104 -0
  1107. package/core-dist/src/utils/quotaErrorDetection.test.js.map +1 -0
  1108. package/core-dist/src/utils/qwenIgnoreParser.d.ts +18 -0
  1109. package/core-dist/src/utils/qwenIgnoreParser.js +61 -0
  1110. package/core-dist/src/utils/qwenIgnoreParser.js.map +1 -0
  1111. package/core-dist/src/utils/qwenIgnoreParser.test.d.ts +6 -0
  1112. package/core-dist/src/utils/qwenIgnoreParser.test.js +50 -0
  1113. package/core-dist/src/utils/qwenIgnoreParser.test.js.map +1 -0
  1114. package/core-dist/src/utils/rateLimit.d.ts +23 -0
  1115. package/core-dist/src/utils/rateLimit.js +69 -0
  1116. package/core-dist/src/utils/rateLimit.js.map +1 -0
  1117. package/core-dist/src/utils/rateLimit.test.d.ts +6 -0
  1118. package/core-dist/src/utils/rateLimit.test.js +72 -0
  1119. package/core-dist/src/utils/rateLimit.test.js.map +1 -0
  1120. package/core-dist/src/utils/readManyFiles.d.ts +67 -0
  1121. package/core-dist/src/utils/readManyFiles.js +133 -0
  1122. package/core-dist/src/utils/readManyFiles.js.map +1 -0
  1123. package/core-dist/src/utils/readManyFiles.test.d.ts +6 -0
  1124. package/core-dist/src/utils/readManyFiles.test.js +230 -0
  1125. package/core-dist/src/utils/readManyFiles.test.js.map +1 -0
  1126. package/core-dist/src/utils/request-tokenizer/imageTokenizer.d.ts +112 -0
  1127. package/core-dist/src/utils/request-tokenizer/imageTokenizer.js +403 -0
  1128. package/core-dist/src/utils/request-tokenizer/imageTokenizer.js.map +1 -0
  1129. package/core-dist/src/utils/request-tokenizer/imageTokenizer.test.d.ts +6 -0
  1130. package/core-dist/src/utils/request-tokenizer/imageTokenizer.test.js +114 -0
  1131. package/core-dist/src/utils/request-tokenizer/imageTokenizer.test.js.map +1 -0
  1132. package/core-dist/src/utils/request-tokenizer/index.d.ts +9 -0
  1133. package/core-dist/src/utils/request-tokenizer/index.js +9 -0
  1134. package/core-dist/src/utils/request-tokenizer/index.js.map +1 -0
  1135. package/core-dist/src/utils/request-tokenizer/requestTokenizer.d.ts +52 -0
  1136. package/core-dist/src/utils/request-tokenizer/requestTokenizer.js +252 -0
  1137. package/core-dist/src/utils/request-tokenizer/requestTokenizer.js.map +1 -0
  1138. package/core-dist/src/utils/request-tokenizer/requestTokenizer.test.d.ts +6 -0
  1139. package/core-dist/src/utils/request-tokenizer/requestTokenizer.test.js +227 -0
  1140. package/core-dist/src/utils/request-tokenizer/requestTokenizer.test.js.map +1 -0
  1141. package/core-dist/src/utils/request-tokenizer/supportedImageFormats.d.ts +30 -0
  1142. package/core-dist/src/utils/request-tokenizer/supportedImageFormats.js +41 -0
  1143. package/core-dist/src/utils/request-tokenizer/supportedImageFormats.js.map +1 -0
  1144. package/core-dist/src/utils/request-tokenizer/textTokenizer.d.ts +32 -0
  1145. package/core-dist/src/utils/request-tokenizer/textTokenizer.js +54 -0
  1146. package/core-dist/src/utils/request-tokenizer/textTokenizer.js.map +1 -0
  1147. package/core-dist/src/utils/request-tokenizer/textTokenizer.test.d.ts +6 -0
  1148. package/core-dist/src/utils/request-tokenizer/textTokenizer.test.js +237 -0
  1149. package/core-dist/src/utils/request-tokenizer/textTokenizer.test.js.map +1 -0
  1150. package/core-dist/src/utils/request-tokenizer/types.d.ts +34 -0
  1151. package/core-dist/src/utils/request-tokenizer/types.js +7 -0
  1152. package/core-dist/src/utils/request-tokenizer/types.js.map +1 -0
  1153. package/core-dist/src/utils/retry.d.ts +38 -0
  1154. package/core-dist/src/utils/retry.js +180 -0
  1155. package/core-dist/src/utils/retry.js.map +1 -0
  1156. package/core-dist/src/utils/retry.test.d.ts +6 -0
  1157. package/core-dist/src/utils/retry.test.js +402 -0
  1158. package/core-dist/src/utils/retry.test.js.map +1 -0
  1159. package/core-dist/src/utils/ripgrepUtils.d.ts +61 -0
  1160. package/core-dist/src/utils/ripgrepUtils.js +227 -0
  1161. package/core-dist/src/utils/ripgrepUtils.js.map +1 -0
  1162. package/core-dist/src/utils/ripgrepUtils.test.d.ts +6 -0
  1163. package/core-dist/src/utils/ripgrepUtils.test.js +101 -0
  1164. package/core-dist/src/utils/ripgrepUtils.test.js.map +1 -0
  1165. package/core-dist/src/utils/runtimeFetchOptions.d.ts +44 -0
  1166. package/core-dist/src/utils/runtimeFetchOptions.js +92 -0
  1167. package/core-dist/src/utils/runtimeFetchOptions.js.map +1 -0
  1168. package/core-dist/src/utils/runtimeFetchOptions.test.d.ts +6 -0
  1169. package/core-dist/src/utils/runtimeFetchOptions.test.js +70 -0
  1170. package/core-dist/src/utils/runtimeFetchOptions.test.js.map +1 -0
  1171. package/core-dist/src/utils/safeJsonParse.d.ts +15 -0
  1172. package/core-dist/src/utils/safeJsonParse.js +43 -0
  1173. package/core-dist/src/utils/safeJsonParse.js.map +1 -0
  1174. package/core-dist/src/utils/safeJsonParse.test.d.ts +6 -0
  1175. package/core-dist/src/utils/safeJsonParse.test.js +112 -0
  1176. package/core-dist/src/utils/safeJsonParse.test.js.map +1 -0
  1177. package/core-dist/src/utils/safeJsonStringify.d.ts +13 -0
  1178. package/core-dist/src/utils/safeJsonStringify.js +25 -0
  1179. package/core-dist/src/utils/safeJsonStringify.js.map +1 -0
  1180. package/core-dist/src/utils/safeJsonStringify.test.d.ts +6 -0
  1181. package/core-dist/src/utils/safeJsonStringify.test.js +61 -0
  1182. package/core-dist/src/utils/safeJsonStringify.test.js.map +1 -0
  1183. package/core-dist/src/utils/schemaConverter.d.ts +15 -0
  1184. package/core-dist/src/utils/schemaConverter.js +109 -0
  1185. package/core-dist/src/utils/schemaConverter.js.map +1 -0
  1186. package/core-dist/src/utils/schemaConverter.test.d.ts +6 -0
  1187. package/core-dist/src/utils/schemaConverter.test.js +106 -0
  1188. package/core-dist/src/utils/schemaConverter.test.js.map +1 -0
  1189. package/core-dist/src/utils/schemaValidator.d.ts +16 -0
  1190. package/core-dist/src/utils/schemaValidator.js +123 -0
  1191. package/core-dist/src/utils/schemaValidator.js.map +1 -0
  1192. package/core-dist/src/utils/schemaValidator.test.d.ts +6 -0
  1193. package/core-dist/src/utils/schemaValidator.test.js +266 -0
  1194. package/core-dist/src/utils/schemaValidator.test.js.map +1 -0
  1195. package/core-dist/src/utils/secure-browser-launcher.d.ts +23 -0
  1196. package/core-dist/src/utils/secure-browser-launcher.js +165 -0
  1197. package/core-dist/src/utils/secure-browser-launcher.js.map +1 -0
  1198. package/core-dist/src/utils/secure-browser-launcher.test.d.ts +6 -0
  1199. package/core-dist/src/utils/secure-browser-launcher.test.js +149 -0
  1200. package/core-dist/src/utils/secure-browser-launcher.test.js.map +1 -0
  1201. package/core-dist/src/utils/shell-utils.d.ts +158 -0
  1202. package/core-dist/src/utils/shell-utils.js +739 -0
  1203. package/core-dist/src/utils/shell-utils.js.map +1 -0
  1204. package/core-dist/src/utils/shell-utils.test.d.ts +6 -0
  1205. package/core-dist/src/utils/shell-utils.test.js +466 -0
  1206. package/core-dist/src/utils/shell-utils.test.js.map +1 -0
  1207. package/core-dist/src/utils/shellReadOnlyChecker.d.ts +6 -0
  1208. package/core-dist/src/utils/shellReadOnlyChecker.js +290 -0
  1209. package/core-dist/src/utils/shellReadOnlyChecker.js.map +1 -0
  1210. package/core-dist/src/utils/shellReadOnlyChecker.test.d.ts +6 -0
  1211. package/core-dist/src/utils/shellReadOnlyChecker.test.js +157 -0
  1212. package/core-dist/src/utils/shellReadOnlyChecker.test.js.map +1 -0
  1213. package/core-dist/src/utils/subagentGenerator.d.ts +20 -0
  1214. package/core-dist/src/utils/subagentGenerator.js +120 -0
  1215. package/core-dist/src/utils/subagentGenerator.js.map +1 -0
  1216. package/core-dist/src/utils/subagentGenerator.test.d.ts +6 -0
  1217. package/core-dist/src/utils/subagentGenerator.test.js +135 -0
  1218. package/core-dist/src/utils/subagentGenerator.test.js.map +1 -0
  1219. package/core-dist/src/utils/summarizer.d.ts +25 -0
  1220. package/core-dist/src/utils/summarizer.js +53 -0
  1221. package/core-dist/src/utils/summarizer.js.map +1 -0
  1222. package/core-dist/src/utils/summarizer.test.d.ts +6 -0
  1223. package/core-dist/src/utils/summarizer.test.js +128 -0
  1224. package/core-dist/src/utils/summarizer.test.js.map +1 -0
  1225. package/core-dist/src/utils/symlink.d.ts +26 -0
  1226. package/core-dist/src/utils/symlink.js +43 -0
  1227. package/core-dist/src/utils/symlink.js.map +1 -0
  1228. package/core-dist/src/utils/systemEncoding.d.ts +40 -0
  1229. package/core-dist/src/utils/systemEncoding.js +160 -0
  1230. package/core-dist/src/utils/systemEncoding.js.map +1 -0
  1231. package/core-dist/src/utils/systemEncoding.test.d.ts +6 -0
  1232. package/core-dist/src/utils/systemEncoding.test.js +367 -0
  1233. package/core-dist/src/utils/systemEncoding.test.js.map +1 -0
  1234. package/core-dist/src/utils/terminalSerializer.d.ts +25 -0
  1235. package/core-dist/src/utils/terminalSerializer.js +432 -0
  1236. package/core-dist/src/utils/terminalSerializer.js.map +1 -0
  1237. package/core-dist/src/utils/terminalSerializer.test.d.ts +6 -0
  1238. package/core-dist/src/utils/terminalSerializer.test.js +176 -0
  1239. package/core-dist/src/utils/terminalSerializer.test.js.map +1 -0
  1240. package/core-dist/src/utils/testUtils.d.ts +29 -0
  1241. package/core-dist/src/utils/testUtils.js +70 -0
  1242. package/core-dist/src/utils/testUtils.js.map +1 -0
  1243. package/core-dist/src/utils/textUtils.d.ts +29 -0
  1244. package/core-dist/src/utils/textUtils.js +59 -0
  1245. package/core-dist/src/utils/textUtils.js.map +1 -0
  1246. package/core-dist/src/utils/textUtils.test.d.ts +6 -0
  1247. package/core-dist/src/utils/textUtils.test.js +91 -0
  1248. package/core-dist/src/utils/textUtils.test.js.map +1 -0
  1249. package/core-dist/src/utils/thoughtUtils.d.ts +23 -0
  1250. package/core-dist/src/utils/thoughtUtils.js +53 -0
  1251. package/core-dist/src/utils/thoughtUtils.js.map +1 -0
  1252. package/core-dist/src/utils/thoughtUtils.test.d.ts +6 -0
  1253. package/core-dist/src/utils/thoughtUtils.test.js +78 -0
  1254. package/core-dist/src/utils/thoughtUtils.test.js.map +1 -0
  1255. package/core-dist/src/utils/toml-to-markdown-converter.d.ts +22 -0
  1256. package/core-dist/src/utils/toml-to-markdown-converter.js +61 -0
  1257. package/core-dist/src/utils/toml-to-markdown-converter.js.map +1 -0
  1258. package/core-dist/src/utils/toml-to-markdown-converter.test.d.ts +6 -0
  1259. package/core-dist/src/utils/toml-to-markdown-converter.test.js +73 -0
  1260. package/core-dist/src/utils/toml-to-markdown-converter.test.js.map +1 -0
  1261. package/core-dist/src/utils/tool-utils.d.ts +22 -0
  1262. package/core-dist/src/utils/tool-utils.js +121 -0
  1263. package/core-dist/src/utils/tool-utils.js.map +1 -0
  1264. package/core-dist/src/utils/tool-utils.test.d.ts +6 -0
  1265. package/core-dist/src/utils/tool-utils.test.js +100 -0
  1266. package/core-dist/src/utils/tool-utils.test.js.map +1 -0
  1267. package/core-dist/src/utils/workspaceContext.d.ts +66 -0
  1268. package/core-dist/src/utils/workspaceContext.js +173 -0
  1269. package/core-dist/src/utils/workspaceContext.js.map +1 -0
  1270. package/core-dist/src/utils/workspaceContext.test.d.ts +6 -0
  1271. package/core-dist/src/utils/workspaceContext.test.js +313 -0
  1272. package/core-dist/src/utils/workspaceContext.test.js.map +1 -0
  1273. package/core-dist/src/utils/yaml-parser.d.ts +29 -0
  1274. package/core-dist/src/utils/yaml-parser.js +172 -0
  1275. package/core-dist/src/utils/yaml-parser.js.map +1 -0
  1276. package/core-dist/src/utils/yaml-parser.test.d.ts +6 -0
  1277. package/core-dist/src/utils/yaml-parser.test.js +170 -0
  1278. package/core-dist/src/utils/yaml-parser.test.js.map +1 -0
  1279. package/core-dist/tsconfig.tsbuildinfo +1 -0
  1280. package/package.json +3 -1
  1281. package/scripts/postinstall.cjs +102 -203
@@ -0,0 +1,1242 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Qwen Team
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect } from 'vitest';
7
+ import { ModelsConfig } from './modelsConfig.js';
8
+ import { AuthType } from '../core/contentGenerator.js';
9
+ describe('ModelsConfig', () => {
10
+ function deepClone(value) {
11
+ if (value === null || typeof value !== 'object')
12
+ return value;
13
+ if (Array.isArray(value))
14
+ return value.map((v) => deepClone(v));
15
+ const out = {};
16
+ for (const key of Object.keys(value)) {
17
+ out[key] = deepClone(value[key]);
18
+ }
19
+ return out;
20
+ }
21
+ function snapshotGenerationConfig(modelsConfig) {
22
+ return deepClone(modelsConfig.getGenerationConfig());
23
+ }
24
+ function currentGenerationConfig(modelsConfig) {
25
+ return modelsConfig.getGenerationConfig();
26
+ }
27
+ it('should fully rollback state when switchModel fails after applying defaults (authType change)', async () => {
28
+ const modelProvidersConfig = {
29
+ openai: [
30
+ {
31
+ id: 'openai-a',
32
+ name: 'OpenAI A',
33
+ baseUrl: 'https://api.openai.example.com/v1',
34
+ envKey: 'OPENAI_API_KEY',
35
+ generationConfig: {
36
+ samplingParams: { temperature: 0.2, max_tokens: 123 },
37
+ timeout: 111,
38
+ maxRetries: 1,
39
+ },
40
+ },
41
+ ],
42
+ anthropic: [
43
+ {
44
+ id: 'anthropic-b',
45
+ name: 'Anthropic B',
46
+ baseUrl: 'https://api.anthropic.example.com/v1',
47
+ envKey: 'ANTHROPIC_API_KEY',
48
+ generationConfig: {
49
+ samplingParams: { temperature: 0.7, max_tokens: 456 },
50
+ timeout: 222,
51
+ maxRetries: 2,
52
+ },
53
+ },
54
+ ],
55
+ };
56
+ const modelsConfig = new ModelsConfig({
57
+ initialAuthType: AuthType.USE_OPENAI,
58
+ modelProvidersConfig,
59
+ });
60
+ // Establish a known baseline state via a successful switch.
61
+ await modelsConfig.switchModel(AuthType.USE_OPENAI, 'openai-a');
62
+ const baselineAuthType = modelsConfig.getCurrentAuthType();
63
+ const baselineModel = modelsConfig.getModel();
64
+ const baselineStrict = modelsConfig.isStrictModelProviderSelection();
65
+ const baselineGc = snapshotGenerationConfig(modelsConfig);
66
+ const baselineSources = deepClone(modelsConfig.getGenerationConfigSources());
67
+ modelsConfig.setOnModelChange(async () => {
68
+ throw new Error('refresh failed');
69
+ });
70
+ await expect(modelsConfig.switchModel(AuthType.USE_ANTHROPIC, 'anthropic-b')).rejects.toThrow('refresh failed');
71
+ // Ensure state is fully rolled back (selection + generation config + flags).
72
+ expect(modelsConfig.getCurrentAuthType()).toBe(baselineAuthType);
73
+ expect(modelsConfig.getModel()).toBe(baselineModel);
74
+ expect(modelsConfig.isStrictModelProviderSelection()).toBe(baselineStrict);
75
+ const gc = currentGenerationConfig(modelsConfig);
76
+ expect(gc).toMatchObject({
77
+ model: baselineGc.model,
78
+ baseUrl: baselineGc.baseUrl,
79
+ apiKeyEnvKey: baselineGc.apiKeyEnvKey,
80
+ samplingParams: baselineGc.samplingParams,
81
+ timeout: baselineGc.timeout,
82
+ maxRetries: baselineGc.maxRetries,
83
+ });
84
+ const sources = modelsConfig.getGenerationConfigSources();
85
+ expect(sources).toEqual(baselineSources);
86
+ });
87
+ it('should fully rollback state when switchModel fails after applying defaults', async () => {
88
+ const modelProvidersConfig = {
89
+ openai: [
90
+ {
91
+ id: 'model-a',
92
+ name: 'Model A',
93
+ baseUrl: 'https://api.example.com/v1',
94
+ envKey: 'API_KEY_A',
95
+ },
96
+ {
97
+ id: 'model-b',
98
+ name: 'Model B',
99
+ baseUrl: 'https://api.example.com/v1',
100
+ envKey: 'API_KEY_B',
101
+ },
102
+ ],
103
+ };
104
+ const modelsConfig = new ModelsConfig({
105
+ initialAuthType: AuthType.USE_OPENAI,
106
+ modelProvidersConfig,
107
+ });
108
+ await modelsConfig.switchModel(AuthType.USE_OPENAI, 'model-a');
109
+ const baselineModel = modelsConfig.getModel();
110
+ const baselineGc = snapshotGenerationConfig(modelsConfig);
111
+ const baselineSources = deepClone(modelsConfig.getGenerationConfigSources());
112
+ modelsConfig.setOnModelChange(async () => {
113
+ throw new Error('hot-update failed');
114
+ });
115
+ await expect(modelsConfig.switchModel(AuthType.USE_OPENAI, 'model-b')).rejects.toThrow('hot-update failed');
116
+ expect(modelsConfig.getModel()).toBe(baselineModel);
117
+ expect(modelsConfig.getGenerationConfig()).toMatchObject({
118
+ model: baselineGc.model,
119
+ baseUrl: baselineGc.baseUrl,
120
+ apiKeyEnvKey: baselineGc.apiKeyEnvKey,
121
+ });
122
+ expect(modelsConfig.getGenerationConfigSources()).toEqual(baselineSources);
123
+ });
124
+ it('should require provider-sourced apiKey when switching models even if envKey is missing', async () => {
125
+ const modelProvidersConfig = {
126
+ openai: [
127
+ {
128
+ id: 'model-a',
129
+ name: 'Model A',
130
+ baseUrl: 'https://api.example.com/v1',
131
+ envKey: 'API_KEY_SHARED',
132
+ },
133
+ {
134
+ id: 'model-b',
135
+ name: 'Model B',
136
+ baseUrl: 'https://api.example.com/v1',
137
+ envKey: 'API_KEY_SHARED',
138
+ },
139
+ ],
140
+ };
141
+ const modelsConfig = new ModelsConfig({
142
+ initialAuthType: AuthType.USE_OPENAI,
143
+ modelProvidersConfig,
144
+ generationConfig: {
145
+ model: 'model-a',
146
+ },
147
+ });
148
+ // Simulate key prompt flow / explicit key provided via CLI/settings.
149
+ modelsConfig.updateCredentials({ apiKey: 'manual-key', model: 'model-a' });
150
+ await modelsConfig.switchModel(AuthType.USE_OPENAI, 'model-b');
151
+ const gc = currentGenerationConfig(modelsConfig);
152
+ expect(gc.model).toBe('model-b');
153
+ expect(gc.apiKey).toBeUndefined();
154
+ expect(gc.apiKeyEnvKey).toBe('API_KEY_SHARED');
155
+ });
156
+ it('should use provider config when modelId exists in registry even after updateCredentials', () => {
157
+ const modelProvidersConfig = {
158
+ openai: [
159
+ {
160
+ id: 'model-a',
161
+ name: 'Model A',
162
+ baseUrl: 'https://api.example.com/v1',
163
+ envKey: 'API_KEY_A',
164
+ generationConfig: {
165
+ samplingParams: { temperature: 0.1, max_tokens: 123 },
166
+ timeout: 111,
167
+ maxRetries: 1,
168
+ },
169
+ },
170
+ ],
171
+ };
172
+ // Simulate settings.model.generationConfig being resolved into ModelsConfig.generationConfig
173
+ const modelsConfig = new ModelsConfig({
174
+ initialAuthType: AuthType.USE_OPENAI,
175
+ modelProvidersConfig,
176
+ generationConfig: {
177
+ model: 'custom-model',
178
+ samplingParams: { temperature: 0.9, max_tokens: 999 },
179
+ timeout: 9999,
180
+ maxRetries: 9,
181
+ },
182
+ generationConfigSources: {
183
+ model: { kind: 'settings', detail: 'settings.model.name' },
184
+ samplingParams: {
185
+ kind: 'settings',
186
+ detail: 'settings.model.generationConfig.samplingParams',
187
+ },
188
+ timeout: {
189
+ kind: 'settings',
190
+ detail: 'settings.model.generationConfig.timeout',
191
+ },
192
+ maxRetries: {
193
+ kind: 'settings',
194
+ detail: 'settings.model.generationConfig.maxRetries',
195
+ },
196
+ },
197
+ });
198
+ // User manually updates credentials via updateCredentials.
199
+ // Note: In practice, handleAuthSelect prevents using a modelId that matches a provider model,
200
+ // but if syncAfterAuthRefresh is called with a modelId that exists in registry,
201
+ // we should use provider config.
202
+ modelsConfig.updateCredentials({ apiKey: 'manual-key' });
203
+ // syncAfterAuthRefresh with a modelId that exists in registry should use provider config
204
+ modelsConfig.syncAfterAuthRefresh(AuthType.USE_OPENAI, 'model-a');
205
+ const gc = currentGenerationConfig(modelsConfig);
206
+ expect(gc.model).toBe('model-a');
207
+ // Provider config should be applied
208
+ expect(gc.samplingParams?.temperature).toBe(0.1);
209
+ expect(gc.samplingParams?.max_tokens).toBe(123);
210
+ expect(gc.timeout).toBe(111);
211
+ expect(gc.maxRetries).toBe(1);
212
+ });
213
+ it('should preserve settings generationConfig when modelId does not exist in registry', () => {
214
+ const modelProvidersConfig = {
215
+ openai: [
216
+ {
217
+ id: 'provider-model',
218
+ name: 'Provider Model',
219
+ baseUrl: 'https://api.example.com/v1',
220
+ envKey: 'API_KEY_A',
221
+ generationConfig: {
222
+ samplingParams: { temperature: 0.1, max_tokens: 123 },
223
+ timeout: 111,
224
+ maxRetries: 1,
225
+ },
226
+ },
227
+ ],
228
+ };
229
+ // Simulate settings with a custom model (not in registry)
230
+ const modelsConfig = new ModelsConfig({
231
+ initialAuthType: AuthType.USE_OPENAI,
232
+ modelProvidersConfig,
233
+ generationConfig: {
234
+ model: 'custom-model',
235
+ samplingParams: { temperature: 0.9, max_tokens: 999 },
236
+ timeout: 9999,
237
+ maxRetries: 9,
238
+ },
239
+ generationConfigSources: {
240
+ model: { kind: 'settings', detail: 'settings.model.name' },
241
+ samplingParams: {
242
+ kind: 'settings',
243
+ detail: 'settings.model.generationConfig.samplingParams',
244
+ },
245
+ timeout: {
246
+ kind: 'settings',
247
+ detail: 'settings.model.generationConfig.timeout',
248
+ },
249
+ maxRetries: {
250
+ kind: 'settings',
251
+ detail: 'settings.model.generationConfig.maxRetries',
252
+ },
253
+ },
254
+ });
255
+ // User manually sets credentials for a custom model (not in registry)
256
+ modelsConfig.updateCredentials({
257
+ apiKey: 'manual-key',
258
+ baseUrl: 'https://manual.example.com/v1',
259
+ model: 'custom-model',
260
+ });
261
+ // First auth refresh - modelId doesn't exist in registry, so credentials should be preserved
262
+ modelsConfig.syncAfterAuthRefresh(AuthType.USE_OPENAI, 'custom-model');
263
+ // Second auth refresh should still preserve settings generationConfig
264
+ modelsConfig.syncAfterAuthRefresh(AuthType.USE_OPENAI, 'custom-model');
265
+ const gc = currentGenerationConfig(modelsConfig);
266
+ expect(gc.model).toBe('custom-model');
267
+ // Settings-sourced generation config should be preserved since modelId doesn't exist in registry
268
+ expect(gc.samplingParams?.temperature).toBe(0.9);
269
+ expect(gc.samplingParams?.max_tokens).toBe(999);
270
+ expect(gc.timeout).toBe(9999);
271
+ expect(gc.maxRetries).toBe(9);
272
+ });
273
+ it('should clear provider-sourced config when updateCredentials is called after switchModel', async () => {
274
+ const modelProvidersConfig = {
275
+ openai: [
276
+ {
277
+ id: 'provider-model',
278
+ name: 'Provider Model',
279
+ baseUrl: 'https://provider.example.com/v1',
280
+ envKey: 'PROVIDER_API_KEY',
281
+ generationConfig: {
282
+ samplingParams: { temperature: 0.1, max_tokens: 100 },
283
+ timeout: 1000,
284
+ maxRetries: 2,
285
+ },
286
+ },
287
+ ],
288
+ };
289
+ const modelsConfig = new ModelsConfig({
290
+ initialAuthType: AuthType.USE_OPENAI,
291
+ modelProvidersConfig,
292
+ });
293
+ // Step 1: Switch to a provider model - this applies provider config
294
+ await modelsConfig.switchModel(AuthType.USE_OPENAI, 'provider-model');
295
+ // Verify provider config is applied
296
+ let gc = currentGenerationConfig(modelsConfig);
297
+ expect(gc.model).toBe('provider-model');
298
+ expect(gc.baseUrl).toBe('https://provider.example.com/v1');
299
+ expect(gc.samplingParams?.temperature).toBe(0.1);
300
+ expect(gc.samplingParams?.max_tokens).toBe(100);
301
+ expect(gc.timeout).toBe(1000);
302
+ expect(gc.maxRetries).toBe(2);
303
+ // Verify sources are from modelProviders
304
+ let sources = modelsConfig.getGenerationConfigSources();
305
+ expect(sources['model']?.kind).toBe('modelProviders');
306
+ expect(sources['baseUrl']?.kind).toBe('modelProviders');
307
+ expect(sources['samplingParams']?.kind).toBe('modelProviders');
308
+ expect(sources['timeout']?.kind).toBe('modelProviders');
309
+ expect(sources['maxRetries']?.kind).toBe('modelProviders');
310
+ // Step 2: User manually sets credentials via updateCredentials
311
+ // This should clear all provider-sourced config
312
+ modelsConfig.updateCredentials({
313
+ apiKey: 'manual-api-key',
314
+ model: 'custom-model',
315
+ });
316
+ // Verify provider-sourced config is cleared
317
+ gc = currentGenerationConfig(modelsConfig);
318
+ expect(gc.model).toBe('custom-model'); // Set by updateCredentials
319
+ expect(gc.apiKey).toBe('manual-api-key'); // Set by updateCredentials
320
+ expect(gc.baseUrl).toBeUndefined(); // Cleared (was from provider)
321
+ expect(gc.samplingParams).toBeUndefined(); // Cleared (was from provider)
322
+ expect(gc.timeout).toBeUndefined(); // Cleared (was from provider)
323
+ expect(gc.maxRetries).toBeUndefined(); // Cleared (was from provider)
324
+ // Verify sources are updated
325
+ sources = modelsConfig.getGenerationConfigSources();
326
+ expect(sources['model']?.kind).toBe('programmatic');
327
+ expect(sources['apiKey']?.kind).toBe('programmatic');
328
+ expect(sources['baseUrl']).toBeUndefined(); // Source cleared
329
+ expect(sources['samplingParams']).toBeUndefined(); // Source cleared
330
+ expect(sources['timeout']).toBeUndefined(); // Source cleared
331
+ expect(sources['maxRetries']).toBeUndefined(); // Source cleared
332
+ });
333
+ it('should preserve non-provider config when updateCredentials clears provider config', async () => {
334
+ const modelProvidersConfig = {
335
+ openai: [
336
+ {
337
+ id: 'provider-model',
338
+ name: 'Provider Model',
339
+ baseUrl: 'https://provider.example.com/v1',
340
+ envKey: 'PROVIDER_API_KEY',
341
+ generationConfig: {
342
+ samplingParams: { temperature: 0.1, max_tokens: 100 },
343
+ timeout: 1000,
344
+ maxRetries: 2,
345
+ },
346
+ },
347
+ ],
348
+ };
349
+ // Initialize with settings-sourced config
350
+ const modelsConfig = new ModelsConfig({
351
+ initialAuthType: AuthType.USE_OPENAI,
352
+ modelProvidersConfig,
353
+ generationConfig: {
354
+ samplingParams: { temperature: 0.8, max_tokens: 500 },
355
+ timeout: 5000,
356
+ },
357
+ generationConfigSources: {
358
+ samplingParams: {
359
+ kind: 'settings',
360
+ detail: 'settings.model.generationConfig.samplingParams',
361
+ },
362
+ timeout: {
363
+ kind: 'settings',
364
+ detail: 'settings.model.generationConfig.timeout',
365
+ },
366
+ },
367
+ });
368
+ // Switch to provider model - this overwrites with provider config
369
+ await modelsConfig.switchModel(AuthType.USE_OPENAI, 'provider-model');
370
+ // Verify provider config is applied (overwriting settings)
371
+ let gc = currentGenerationConfig(modelsConfig);
372
+ expect(gc.samplingParams?.temperature).toBe(0.1);
373
+ expect(gc.timeout).toBe(1000);
374
+ // User manually sets credentials - clears provider-sourced config
375
+ modelsConfig.updateCredentials({
376
+ apiKey: 'manual-key',
377
+ });
378
+ // Provider-sourced config should be cleared
379
+ gc = currentGenerationConfig(modelsConfig);
380
+ expect(gc.samplingParams).toBeUndefined();
381
+ expect(gc.timeout).toBeUndefined();
382
+ // The original settings-sourced config is NOT restored automatically;
383
+ // it should be re-resolved by other layers in refreshAuth
384
+ });
385
+ it('should always force Qwen OAuth apiKey placeholder when applying model defaults', async () => {
386
+ // Simulate a stale/explicit apiKey existing before switching models.
387
+ const modelsConfig = new ModelsConfig({
388
+ initialAuthType: AuthType.QWEN_OAUTH,
389
+ generationConfig: {
390
+ apiKey: 'manual-key-should-not-leak',
391
+ },
392
+ });
393
+ // Switching within qwen-oauth triggers applyResolvedModelDefaults().
394
+ await modelsConfig.switchModel(AuthType.QWEN_OAUTH, 'coder-model');
395
+ const gc = currentGenerationConfig(modelsConfig);
396
+ expect(gc.apiKey).toBe('QWEN_OAUTH_DYNAMIC_TOKEN');
397
+ expect(gc.apiKeyEnvKey).toBeUndefined();
398
+ });
399
+ it('should apply extra_body and customHeaders from model provider config', async () => {
400
+ const modelProvidersConfig = {
401
+ openai: [
402
+ {
403
+ id: 'model-with-extras',
404
+ name: 'Model With Extras',
405
+ baseUrl: 'https://api.example.com/v1',
406
+ envKey: 'API_KEY',
407
+ generationConfig: {
408
+ extra_body: { custom_param: 'value', enable_thinking: true },
409
+ customHeaders: { 'X-Custom-Header': 'header-value' },
410
+ },
411
+ },
412
+ ],
413
+ };
414
+ const modelsConfig = new ModelsConfig({
415
+ initialAuthType: AuthType.USE_OPENAI,
416
+ modelProvidersConfig,
417
+ });
418
+ await modelsConfig.switchModel(AuthType.USE_OPENAI, 'model-with-extras');
419
+ const gc = currentGenerationConfig(modelsConfig);
420
+ expect(gc.extra_body).toEqual({
421
+ custom_param: 'value',
422
+ enable_thinking: true,
423
+ });
424
+ expect(gc.customHeaders).toEqual({ 'X-Custom-Header': 'header-value' });
425
+ const sources = modelsConfig.getGenerationConfigSources();
426
+ expect(sources['extra_body']?.kind).toBe('modelProviders');
427
+ expect(sources['customHeaders']?.kind).toBe('modelProviders');
428
+ });
429
+ it('should apply Qwen OAuth apiKey placeholder during syncAfterAuthRefresh for fresh users', () => {
430
+ // Fresh user: authType not selected yet (currentAuthType undefined).
431
+ const modelsConfig = new ModelsConfig();
432
+ // Config.refreshAuth passes modelId from modelsConfig.getModel(), which falls back to DEFAULT_QWEN_MODEL.
433
+ modelsConfig.syncAfterAuthRefresh(AuthType.QWEN_OAUTH, modelsConfig.getModel());
434
+ const gc = currentGenerationConfig(modelsConfig);
435
+ expect(gc.model).toBe('coder-model');
436
+ expect(gc.apiKey).toBe('QWEN_OAUTH_DYNAMIC_TOKEN');
437
+ expect(gc.apiKeyEnvKey).toBeUndefined();
438
+ });
439
+ it('should use default model for new authType when switching from different authType with env vars', () => {
440
+ // Simulate cold start with OPENAI env vars (OPENAI_MODEL and OPENAI_API_KEY)
441
+ // This sets the model in generationConfig but no authType is selected yet
442
+ const modelsConfig = new ModelsConfig({
443
+ generationConfig: {
444
+ model: 'gpt-4o', // From OPENAI_MODEL env var
445
+ apiKey: 'openai-key-from-env',
446
+ },
447
+ });
448
+ // User switches to qwen-oauth via AuthDialog
449
+ // refreshAuth calls syncAfterAuthRefresh with the current model (gpt-4o)
450
+ // which doesn't exist in qwen-oauth registry, so it should use default
451
+ modelsConfig.syncAfterAuthRefresh(AuthType.QWEN_OAUTH, 'gpt-4o');
452
+ const gc = currentGenerationConfig(modelsConfig);
453
+ // Should use default qwen-oauth model (coder-model), not the OPENAI model
454
+ expect(gc.model).toBe('coder-model');
455
+ expect(gc.apiKey).toBe('QWEN_OAUTH_DYNAMIC_TOKEN');
456
+ expect(gc.apiKeyEnvKey).toBeUndefined();
457
+ });
458
+ it('should clear manual credentials when switching from USE_OPENAI to QWEN_OAUTH', () => {
459
+ // User manually set credentials for OpenAI
460
+ const modelsConfig = new ModelsConfig({
461
+ initialAuthType: AuthType.USE_OPENAI,
462
+ generationConfig: {
463
+ model: 'gpt-4o',
464
+ apiKey: 'manual-openai-key',
465
+ baseUrl: 'https://manual.example.com/v1',
466
+ },
467
+ });
468
+ // Manually set credentials via updateCredentials
469
+ modelsConfig.updateCredentials({
470
+ apiKey: 'manual-openai-key',
471
+ baseUrl: 'https://manual.example.com/v1',
472
+ model: 'gpt-4o',
473
+ });
474
+ // User switches to qwen-oauth
475
+ // Since authType is not USE_OPENAI, manual credentials should be cleared
476
+ // and default qwen-oauth model should be applied
477
+ modelsConfig.syncAfterAuthRefresh(AuthType.QWEN_OAUTH, 'gpt-4o');
478
+ const gc = currentGenerationConfig(modelsConfig);
479
+ // Should use default qwen-oauth model, not preserve manual OpenAI credentials
480
+ expect(gc.model).toBe('coder-model');
481
+ expect(gc.apiKey).toBe('QWEN_OAUTH_DYNAMIC_TOKEN');
482
+ // baseUrl should be set to qwen-oauth default, not preserved from manual OpenAI config
483
+ expect(gc.baseUrl).toBe('DYNAMIC_QWEN_OAUTH_BASE_URL');
484
+ expect(gc.apiKeyEnvKey).toBeUndefined();
485
+ });
486
+ it('should preserve manual credentials when switching to USE_OPENAI', () => {
487
+ // User manually set credentials
488
+ const modelsConfig = new ModelsConfig({
489
+ initialAuthType: AuthType.USE_OPENAI,
490
+ generationConfig: {
491
+ model: 'gpt-4o',
492
+ apiKey: 'manual-openai-key',
493
+ baseUrl: 'https://manual.example.com/v1',
494
+ samplingParams: { temperature: 0.9 },
495
+ },
496
+ });
497
+ // Manually set credentials via updateCredentials
498
+ modelsConfig.updateCredentials({
499
+ apiKey: 'manual-openai-key',
500
+ baseUrl: 'https://manual.example.com/v1',
501
+ model: 'gpt-4o',
502
+ });
503
+ // User switches to USE_OPENAI (same or different model)
504
+ // Since authType is USE_OPENAI, manual credentials should be preserved
505
+ modelsConfig.syncAfterAuthRefresh(AuthType.USE_OPENAI, 'gpt-4o');
506
+ const gc = currentGenerationConfig(modelsConfig);
507
+ // Should preserve manual credentials
508
+ expect(gc.model).toBe('gpt-4o');
509
+ expect(gc.apiKey).toBe('manual-openai-key');
510
+ expect(gc.baseUrl).toBe('https://manual.example.com/v1');
511
+ expect(gc.samplingParams?.temperature).toBe(0.9); // Preserved from initial config
512
+ });
513
+ it('should maintain consistency between currentModelId and _generationConfig.model after initialization', () => {
514
+ const modelProvidersConfig = {
515
+ openai: [
516
+ {
517
+ id: 'test-model',
518
+ name: 'Test Model',
519
+ baseUrl: 'https://api.example.com/v1',
520
+ envKey: 'TEST_API_KEY',
521
+ },
522
+ ],
523
+ };
524
+ // Test case 1: generationConfig.model provided with other config
525
+ const config1 = new ModelsConfig({
526
+ initialAuthType: AuthType.USE_OPENAI,
527
+ modelProvidersConfig,
528
+ generationConfig: {
529
+ model: 'test-model',
530
+ samplingParams: { temperature: 0.5 },
531
+ },
532
+ });
533
+ expect(config1.getModel()).toBe('test-model');
534
+ expect(config1.getGenerationConfig().model).toBe('test-model');
535
+ // Test case 2: generationConfig.model provided
536
+ const config2 = new ModelsConfig({
537
+ initialAuthType: AuthType.USE_OPENAI,
538
+ modelProvidersConfig,
539
+ generationConfig: {
540
+ model: 'test-model',
541
+ },
542
+ });
543
+ expect(config2.getModel()).toBe('test-model');
544
+ expect(config2.getGenerationConfig().model).toBe('test-model');
545
+ // Test case 3: no model provided (empty string fallback)
546
+ const config3 = new ModelsConfig({
547
+ initialAuthType: AuthType.USE_OPENAI,
548
+ modelProvidersConfig,
549
+ generationConfig: {},
550
+ });
551
+ expect(config3.getModel()).toBe('coder-model'); // Falls back to DEFAULT_QWEN_MODEL
552
+ expect(config3.getGenerationConfig().model).toBeUndefined();
553
+ });
554
+ it('should maintain consistency between currentModelId and _generationConfig.model during syncAfterAuthRefresh', () => {
555
+ const modelProvidersConfig = {
556
+ openai: [
557
+ {
558
+ id: 'model-a',
559
+ name: 'Model A',
560
+ baseUrl: 'https://api.example.com/v1',
561
+ envKey: 'API_KEY_A',
562
+ },
563
+ ],
564
+ };
565
+ const modelsConfig = new ModelsConfig({
566
+ initialAuthType: AuthType.USE_OPENAI,
567
+ modelProvidersConfig,
568
+ generationConfig: {
569
+ model: 'model-a',
570
+ },
571
+ });
572
+ // Manually set credentials to trigger preserveManualCredentials path
573
+ modelsConfig.updateCredentials({ apiKey: 'manual-key' });
574
+ // syncAfterAuthRefresh with a different modelId
575
+ modelsConfig.syncAfterAuthRefresh(AuthType.USE_OPENAI, 'model-a');
576
+ // Both should be consistent
577
+ expect(modelsConfig.getModel()).toBe('model-a');
578
+ expect(modelsConfig.getGenerationConfig().model).toBe('model-a');
579
+ });
580
+ it('should maintain consistency between currentModelId and _generationConfig.model during setModel', async () => {
581
+ const modelProvidersConfig = {
582
+ openai: [
583
+ {
584
+ id: 'model-a',
585
+ name: 'Model A',
586
+ baseUrl: 'https://api.example.com/v1',
587
+ envKey: 'API_KEY_A',
588
+ },
589
+ ],
590
+ };
591
+ const modelsConfig = new ModelsConfig({
592
+ initialAuthType: AuthType.USE_OPENAI,
593
+ modelProvidersConfig,
594
+ });
595
+ // setModel with a raw model ID
596
+ await modelsConfig.setModel('custom-model');
597
+ // Both should be consistent
598
+ expect(modelsConfig.getModel()).toBe('custom-model');
599
+ expect(modelsConfig.getGenerationConfig().model).toBe('custom-model');
600
+ });
601
+ it('should maintain consistency between currentModelId and _generationConfig.model during updateCredentials', () => {
602
+ const modelsConfig = new ModelsConfig({
603
+ initialAuthType: AuthType.USE_OPENAI,
604
+ });
605
+ // updateCredentials with model
606
+ modelsConfig.updateCredentials({
607
+ apiKey: 'test-key',
608
+ model: 'updated-model',
609
+ });
610
+ // Both should be consistent
611
+ expect(modelsConfig.getModel()).toBe('updated-model');
612
+ expect(modelsConfig.getGenerationConfig().model).toBe('updated-model');
613
+ });
614
+ describe('getAllConfiguredModels', () => {
615
+ it('should return all models across all authTypes and put qwen-oauth first', () => {
616
+ const modelProvidersConfig = {
617
+ openai: [
618
+ {
619
+ id: 'openai-model-1',
620
+ name: 'OpenAI Model 1',
621
+ baseUrl: 'https://api.openai.com/v1',
622
+ envKey: 'OPENAI_API_KEY',
623
+ },
624
+ {
625
+ id: 'openai-model-2',
626
+ name: 'OpenAI Model 2',
627
+ baseUrl: 'https://api.openai.com/v1',
628
+ envKey: 'OPENAI_API_KEY',
629
+ },
630
+ ],
631
+ anthropic: [
632
+ {
633
+ id: 'anthropic-model-1',
634
+ name: 'Anthropic Model 1',
635
+ baseUrl: 'https://api.anthropic.com/v1',
636
+ envKey: 'ANTHROPIC_API_KEY',
637
+ },
638
+ ],
639
+ gemini: [
640
+ {
641
+ id: 'gemini-model-1',
642
+ name: 'Gemini Model 1',
643
+ baseUrl: 'https://generativelanguage.googleapis.com/v1',
644
+ envKey: 'GEMINI_API_KEY',
645
+ },
646
+ ],
647
+ };
648
+ const modelsConfig = new ModelsConfig({
649
+ modelProvidersConfig,
650
+ });
651
+ const allModels = modelsConfig.getAllConfiguredModels();
652
+ // qwen-oauth models should be ordered first
653
+ const firstNonQwenIndex = allModels.findIndex((m) => m.authType !== AuthType.QWEN_OAUTH);
654
+ expect(firstNonQwenIndex).toBeGreaterThan(0);
655
+ expect(allModels
656
+ .slice(0, firstNonQwenIndex)
657
+ .every((m) => m.authType === AuthType.QWEN_OAUTH)).toBe(true);
658
+ expect(allModels
659
+ .slice(firstNonQwenIndex)
660
+ .every((m) => m.authType !== AuthType.QWEN_OAUTH)).toBe(true);
661
+ // Should include qwen-oauth models (hard-coded)
662
+ const qwenModels = allModels.filter((m) => m.authType === AuthType.QWEN_OAUTH);
663
+ expect(qwenModels.length).toBeGreaterThan(0);
664
+ // Should include openai models
665
+ const openaiModels = allModels.filter((m) => m.authType === AuthType.USE_OPENAI);
666
+ expect(openaiModels.length).toBe(2);
667
+ expect(openaiModels.map((m) => m.id)).toContain('openai-model-1');
668
+ expect(openaiModels.map((m) => m.id)).toContain('openai-model-2');
669
+ // Should include anthropic models
670
+ const anthropicModels = allModels.filter((m) => m.authType === AuthType.USE_ANTHROPIC);
671
+ expect(anthropicModels.length).toBe(1);
672
+ expect(anthropicModels[0].id).toBe('anthropic-model-1');
673
+ // Should include gemini models
674
+ const geminiModels = allModels.filter((m) => m.authType === AuthType.USE_GEMINI);
675
+ expect(geminiModels.length).toBe(1);
676
+ expect(geminiModels[0].id).toBe('gemini-model-1');
677
+ });
678
+ it('should return empty array when no models are registered', () => {
679
+ const modelsConfig = new ModelsConfig();
680
+ const allModels = modelsConfig.getAllConfiguredModels();
681
+ // Should still include qwen-oauth models (hard-coded)
682
+ expect(allModels.length).toBeGreaterThan(0);
683
+ const qwenModels = allModels.filter((m) => m.authType === AuthType.QWEN_OAUTH);
684
+ expect(qwenModels.length).toBeGreaterThan(0);
685
+ });
686
+ it('should return models with correct structure', () => {
687
+ const modelProvidersConfig = {
688
+ openai: [
689
+ {
690
+ id: 'test-model',
691
+ name: 'Test Model',
692
+ description: 'A test model',
693
+ baseUrl: 'https://api.example.com/v1',
694
+ envKey: 'TEST_API_KEY',
695
+ capabilities: {
696
+ vision: true,
697
+ },
698
+ },
699
+ ],
700
+ };
701
+ const modelsConfig = new ModelsConfig({
702
+ modelProvidersConfig,
703
+ });
704
+ const allModels = modelsConfig.getAllConfiguredModels();
705
+ const testModel = allModels.find((m) => m.id === 'test-model');
706
+ expect(testModel).toBeDefined();
707
+ expect(testModel?.id).toBe('test-model');
708
+ expect(testModel?.label).toBe('Test Model');
709
+ expect(testModel?.description).toBe('A test model');
710
+ expect(testModel?.authType).toBe(AuthType.USE_OPENAI);
711
+ expect(testModel?.isVision).toBe(true);
712
+ expect(testModel?.capabilities?.vision).toBe(true);
713
+ });
714
+ it('should support filtering by authTypes and still put qwen-oauth first when included', () => {
715
+ const modelProvidersConfig = {
716
+ openai: [
717
+ {
718
+ id: 'openai-model-1',
719
+ name: 'OpenAI Model 1',
720
+ baseUrl: 'https://api.openai.com/v1',
721
+ envKey: 'OPENAI_API_KEY',
722
+ },
723
+ ],
724
+ anthropic: [
725
+ {
726
+ id: 'anthropic-model-1',
727
+ name: 'Anthropic Model 1',
728
+ baseUrl: 'https://api.anthropic.com/v1',
729
+ envKey: 'ANTHROPIC_API_KEY',
730
+ },
731
+ ],
732
+ };
733
+ const modelsConfig = new ModelsConfig({
734
+ modelProvidersConfig,
735
+ });
736
+ // Filter: OpenAI only (should not include qwen-oauth)
737
+ const openaiOnly = modelsConfig.getAllConfiguredModels([
738
+ AuthType.USE_OPENAI,
739
+ ]);
740
+ expect(openaiOnly.every((m) => m.authType === AuthType.USE_OPENAI)).toBe(true);
741
+ expect(openaiOnly.map((m) => m.id)).toContain('openai-model-1');
742
+ // Filter: include qwen-oauth but request it later -> still ordered first
743
+ const withQwen = modelsConfig.getAllConfiguredModels([
744
+ AuthType.USE_OPENAI,
745
+ AuthType.QWEN_OAUTH,
746
+ AuthType.USE_ANTHROPIC,
747
+ ]);
748
+ expect(withQwen.length).toBeGreaterThan(0);
749
+ const firstNonQwenIndex = withQwen.findIndex((m) => m.authType !== AuthType.QWEN_OAUTH);
750
+ expect(firstNonQwenIndex).toBeGreaterThan(0);
751
+ expect(withQwen
752
+ .slice(0, firstNonQwenIndex)
753
+ .every((m) => m.authType === AuthType.QWEN_OAUTH)).toBe(true);
754
+ });
755
+ });
756
+ describe('Runtime Model Snapshot', () => {
757
+ it('should detect and capture runtime model from CLI source', () => {
758
+ const modelsConfig = new ModelsConfig({
759
+ initialAuthType: AuthType.USE_OPENAI,
760
+ generationConfig: {
761
+ model: 'gpt-4-turbo',
762
+ apiKey: 'sk-test-key',
763
+ baseUrl: 'https://api.openai.com/v1',
764
+ },
765
+ generationConfigSources: {
766
+ model: { kind: 'cli', detail: '--model' },
767
+ apiKey: { kind: 'cli', detail: '--openaiApiKey' },
768
+ baseUrl: { kind: 'cli', detail: '--openaiBaseUrl' },
769
+ },
770
+ });
771
+ const snapshotId = modelsConfig.detectAndCaptureRuntimeModel();
772
+ expect(snapshotId).toBe('$runtime|openai|gpt-4-turbo');
773
+ const snapshot = modelsConfig.getActiveRuntimeModelSnapshot();
774
+ expect(snapshot).toBeDefined();
775
+ expect(snapshot?.id).toBe('$runtime|openai|gpt-4-turbo');
776
+ expect(snapshot?.authType).toBe(AuthType.USE_OPENAI);
777
+ expect(snapshot?.modelId).toBe('gpt-4-turbo');
778
+ expect(snapshot?.apiKey).toBe('sk-test-key');
779
+ expect(snapshot?.baseUrl).toBe('https://api.openai.com/v1');
780
+ });
781
+ it('should detect and capture runtime model from ENV source', () => {
782
+ const modelsConfig = new ModelsConfig({
783
+ initialAuthType: AuthType.USE_OPENAI,
784
+ generationConfig: {
785
+ model: 'gpt-4o',
786
+ apiKey: 'sk-env-key',
787
+ baseUrl: 'https://api.openai.com/v1',
788
+ },
789
+ generationConfigSources: {
790
+ model: { kind: 'settings', detail: 'settings.model.name' },
791
+ apiKey: { kind: 'env', envKey: 'OPENAI_API_KEY' },
792
+ baseUrl: { kind: 'settings', detail: 'settings.openaiBaseUrl' },
793
+ },
794
+ });
795
+ const snapshotId = modelsConfig.detectAndCaptureRuntimeModel();
796
+ expect(snapshotId).toBe('$runtime|openai|gpt-4o');
797
+ const snapshot = modelsConfig.getActiveRuntimeModelSnapshot();
798
+ expect(snapshot).toBeDefined();
799
+ expect(snapshot?.modelId).toBe('gpt-4o');
800
+ expect(snapshot?.apiKey).toBe('sk-env-key');
801
+ });
802
+ it('should not capture registry models as runtime', () => {
803
+ const modelProvidersConfig = {
804
+ openai: [
805
+ {
806
+ id: 'gpt-4-turbo',
807
+ name: 'GPT-4 Turbo',
808
+ baseUrl: 'https://api.openai.com/v1',
809
+ envKey: 'OPENAI_API_KEY',
810
+ },
811
+ ],
812
+ };
813
+ const modelsConfig = new ModelsConfig({
814
+ initialAuthType: AuthType.USE_OPENAI,
815
+ modelProvidersConfig,
816
+ generationConfig: {
817
+ model: 'gpt-4-turbo',
818
+ apiKey: 'sk-test-key',
819
+ baseUrl: 'https://api.openai.com/v1',
820
+ },
821
+ generationConfigSources: {
822
+ model: { kind: 'cli', detail: '--model' },
823
+ apiKey: { kind: 'cli', detail: '--openaiApiKey' },
824
+ baseUrl: { kind: 'cli', detail: '--openaiBaseUrl' },
825
+ },
826
+ });
827
+ const snapshotId = modelsConfig.detectAndCaptureRuntimeModel();
828
+ // Should not create snapshot since model exists in registry
829
+ expect(snapshotId).toBeUndefined();
830
+ expect(modelsConfig.getActiveRuntimeModelSnapshot()).toBeUndefined();
831
+ });
832
+ it('should not capture runtime model without valid credentials', () => {
833
+ const modelsConfig = new ModelsConfig({
834
+ initialAuthType: AuthType.USE_OPENAI,
835
+ generationConfig: {
836
+ model: 'custom-model',
837
+ // Missing apiKey and baseUrl
838
+ },
839
+ generationConfigSources: {
840
+ model: { kind: 'cli', detail: '--model' },
841
+ },
842
+ });
843
+ const snapshotId = modelsConfig.detectAndCaptureRuntimeModel();
844
+ expect(snapshotId).toBeUndefined();
845
+ });
846
+ it('should switch to runtime model and apply snapshot configuration', async () => {
847
+ const modelsConfig = new ModelsConfig({
848
+ initialAuthType: AuthType.USE_OPENAI,
849
+ generationConfig: {
850
+ model: 'runtime-model',
851
+ apiKey: 'sk-runtime-key',
852
+ baseUrl: 'https://runtime.example.com/v1',
853
+ samplingParams: { temperature: 0.7, max_tokens: 2000 },
854
+ },
855
+ generationConfigSources: {
856
+ model: { kind: 'programmatic', detail: 'test' },
857
+ apiKey: { kind: 'programmatic', detail: 'test' },
858
+ baseUrl: { kind: 'programmatic', detail: 'test' },
859
+ },
860
+ });
861
+ // Create initial snapshot
862
+ const initialSnapshotId = modelsConfig.detectAndCaptureRuntimeModel();
863
+ expect(initialSnapshotId).toBeDefined();
864
+ // Change to a different state
865
+ // Note: this updates the existing snapshot, changing its ID
866
+ modelsConfig.updateCredentials({
867
+ model: 'different-model',
868
+ apiKey: 'different-key',
869
+ baseUrl: 'https://different.example.com/v1',
870
+ });
871
+ // The snapshot ID has changed because we updated the model
872
+ const updatedSnapshotId = modelsConfig.getActiveRuntimeModelSnapshotId();
873
+ expect(updatedSnapshotId).toBe('$runtime|openai|different-model');
874
+ // Create a separate snapshot for the original runtime model
875
+ // (simulate having multiple runtime models available)
876
+ modelsConfig['runtimeModelSnapshots'].set('$runtime|openai|runtime-model', {
877
+ id: '$runtime|openai|runtime-model',
878
+ authType: AuthType.USE_OPENAI,
879
+ modelId: 'runtime-model',
880
+ apiKey: 'sk-runtime-key',
881
+ baseUrl: 'https://runtime.example.com/v1',
882
+ generationConfig: {
883
+ samplingParams: { temperature: 0.7, max_tokens: 2000 },
884
+ },
885
+ sources: {
886
+ model: { kind: 'programmatic', detail: 'test' },
887
+ apiKey: { kind: 'programmatic', detail: 'test' },
888
+ baseUrl: { kind: 'programmatic', detail: 'test' },
889
+ },
890
+ createdAt: Date.now(),
891
+ });
892
+ // Switch back to original runtime model
893
+ await modelsConfig.switchToRuntimeModel('$runtime|openai|runtime-model');
894
+ const gc = currentGenerationConfig(modelsConfig);
895
+ expect(gc.model).toBe('runtime-model');
896
+ expect(gc.apiKey).toBe('sk-runtime-key');
897
+ expect(gc.baseUrl).toBe('https://runtime.example.com/v1');
898
+ expect(gc.samplingParams?.temperature).toBe(0.7);
899
+ expect(gc.samplingParams?.max_tokens).toBe(2000);
900
+ });
901
+ it('should throw error when switching to non-existent runtime snapshot', async () => {
902
+ const modelsConfig = new ModelsConfig({
903
+ initialAuthType: AuthType.USE_OPENAI,
904
+ });
905
+ await expect(modelsConfig.switchToRuntimeModel('$runtime|openai|nonexistent')).rejects.toThrow("Runtime model snapshot '$runtime|openai|nonexistent' not found");
906
+ });
907
+ it('should return runtime option first in getAllConfiguredModels', () => {
908
+ const modelProvidersConfig = {
909
+ openai: [
910
+ {
911
+ id: 'registry-model',
912
+ name: 'Registry Model',
913
+ baseUrl: 'https://api.openai.com/v1',
914
+ envKey: 'OPENAI_API_KEY',
915
+ },
916
+ ],
917
+ };
918
+ const modelsConfig = new ModelsConfig({
919
+ initialAuthType: AuthType.USE_OPENAI,
920
+ modelProvidersConfig,
921
+ generationConfig: {
922
+ model: 'runtime-model',
923
+ apiKey: 'sk-test-key',
924
+ baseUrl: 'https://runtime.example.com/v1',
925
+ },
926
+ generationConfigSources: {
927
+ model: { kind: 'programmatic', detail: 'test' },
928
+ apiKey: { kind: 'programmatic', detail: 'test' },
929
+ baseUrl: { kind: 'programmatic', detail: 'test' },
930
+ },
931
+ });
932
+ modelsConfig.detectAndCaptureRuntimeModel();
933
+ const allModels = modelsConfig.getAllConfiguredModels();
934
+ // Runtime model should be first for USE_OPENAI
935
+ const openaiModels = allModels.filter((m) => m.authType === AuthType.USE_OPENAI);
936
+ expect(openaiModels.length).toBe(2);
937
+ expect(openaiModels[0].isRuntimeModel).toBe(true);
938
+ // AvailableModel.id should be modelId, runtimeSnapshotId should be snapshot.id
939
+ expect(openaiModels[0].id).toBe('runtime-model');
940
+ expect(openaiModels[0].runtimeSnapshotId).toBe('$runtime|openai|runtime-model');
941
+ expect(openaiModels[0].label).toBe('runtime-model');
942
+ expect(openaiModels[1].isRuntimeModel).toBeUndefined();
943
+ expect(openaiModels[1].id).toBe('registry-model');
944
+ });
945
+ it('should create/update runtime snapshot via updateCredentials', () => {
946
+ const modelsConfig = new ModelsConfig({
947
+ initialAuthType: AuthType.USE_OPENAI,
948
+ });
949
+ // Update with complete credentials
950
+ modelsConfig.updateCredentials({
951
+ model: 'custom-model',
952
+ apiKey: 'sk-custom-key',
953
+ baseUrl: 'https://custom.example.com/v1',
954
+ });
955
+ const snapshot = modelsConfig.getActiveRuntimeModelSnapshot();
956
+ expect(snapshot).toBeDefined();
957
+ expect(snapshot?.modelId).toBe('custom-model');
958
+ expect(snapshot?.apiKey).toBe('sk-custom-key');
959
+ expect(snapshot?.baseUrl).toBe('https://custom.example.com/v1');
960
+ });
961
+ it('should update existing runtime snapshot when credentials change', () => {
962
+ const modelsConfig = new ModelsConfig({
963
+ initialAuthType: AuthType.USE_OPENAI,
964
+ generationConfig: {
965
+ model: 'initial-model',
966
+ apiKey: 'sk-initial-key',
967
+ baseUrl: 'https://initial.example.com/v1',
968
+ },
969
+ generationConfigSources: {
970
+ model: { kind: 'programmatic', detail: 'test' },
971
+ apiKey: { kind: 'programmatic', detail: 'test' },
972
+ baseUrl: { kind: 'programmatic', detail: 'test' },
973
+ },
974
+ });
975
+ // Create initial snapshot
976
+ modelsConfig.detectAndCaptureRuntimeModel();
977
+ // Update credentials with different model
978
+ modelsConfig.updateCredentials({
979
+ model: 'updated-model',
980
+ apiKey: 'sk-updated-key',
981
+ });
982
+ const snapshot = modelsConfig.getActiveRuntimeModelSnapshot();
983
+ expect(snapshot).toBeDefined();
984
+ expect(snapshot?.modelId).toBe('updated-model');
985
+ expect(snapshot?.apiKey).toBe('sk-updated-key');
986
+ // baseUrl should be preserved from initial
987
+ expect(snapshot?.baseUrl).toBe('https://initial.example.com/v1');
988
+ });
989
+ it('should enforce per-authType snapshot limit', () => {
990
+ const modelsConfig = new ModelsConfig({
991
+ initialAuthType: AuthType.USE_OPENAI,
992
+ });
993
+ // Create first snapshot for USE_OPENAI
994
+ modelsConfig.updateCredentials({
995
+ model: 'model-a',
996
+ apiKey: 'sk-key-a',
997
+ baseUrl: 'https://a.example.com/v1',
998
+ });
999
+ const firstSnapshotId = modelsConfig.getActiveRuntimeModelSnapshotId();
1000
+ expect(firstSnapshotId).toBe('$runtime|openai|model-a');
1001
+ // Create second snapshot for USE_OPENAI (different model)
1002
+ modelsConfig.updateCredentials({
1003
+ model: 'model-b',
1004
+ apiKey: 'sk-key-b',
1005
+ baseUrl: 'https://b.example.com/v1',
1006
+ });
1007
+ const secondSnapshotId = modelsConfig.getActiveRuntimeModelSnapshotId();
1008
+ expect(secondSnapshotId).toBe('$runtime|openai|model-b');
1009
+ // First snapshot should be cleaned up
1010
+ expect(modelsConfig.getActiveRuntimeModelSnapshot()?.id).toBe(secondSnapshotId);
1011
+ });
1012
+ it('should support multiple authTypes with separate snapshots', async () => {
1013
+ const modelsConfig = new ModelsConfig({
1014
+ initialAuthType: AuthType.USE_OPENAI,
1015
+ });
1016
+ // Create OpenAI snapshot
1017
+ modelsConfig.updateCredentials({
1018
+ model: 'openai-model',
1019
+ apiKey: 'sk-openai-key',
1020
+ baseUrl: 'https://openai.example.com/v1',
1021
+ });
1022
+ // Verify OpenAI snapshot exists
1023
+ const openaiSnapshot = modelsConfig.getActiveRuntimeModelSnapshot();
1024
+ expect(openaiSnapshot?.authType).toBe(AuthType.USE_OPENAI);
1025
+ expect(openaiSnapshot?.modelId).toBe('openai-model');
1026
+ // Switch to Anthropic via switchToRuntimeModel
1027
+ // First create an Anthropic snapshot manually
1028
+ modelsConfig['runtimeModelSnapshots'].set('$runtime|anthropic|anthropic-model', {
1029
+ id: '$runtime|anthropic|anthropic-model',
1030
+ authType: AuthType.USE_ANTHROPIC,
1031
+ modelId: 'anthropic-model',
1032
+ apiKey: 'sk-anthropic-key',
1033
+ baseUrl: 'https://anthropic.example.com/v1',
1034
+ sources: {
1035
+ model: { kind: 'programmatic', detail: 'test' },
1036
+ apiKey: { kind: 'programmatic', detail: 'test' },
1037
+ baseUrl: { kind: 'programmatic', detail: 'test' },
1038
+ },
1039
+ createdAt: Date.now(),
1040
+ });
1041
+ // Switch to the Anthropic runtime model
1042
+ await modelsConfig.switchToRuntimeModel('$runtime|anthropic|anthropic-model');
1043
+ // Should now have Anthropic snapshot active
1044
+ const anthropicSnapshot = modelsConfig.getActiveRuntimeModelSnapshot();
1045
+ expect(anthropicSnapshot?.authType).toBe(AuthType.USE_ANTHROPIC);
1046
+ expect(anthropicSnapshot?.modelId).toBe('anthropic-model');
1047
+ });
1048
+ it('should rollback state when switchToRuntimeModel fails', async () => {
1049
+ const modelsConfig = new ModelsConfig({
1050
+ initialAuthType: AuthType.USE_OPENAI,
1051
+ generationConfig: {
1052
+ model: 'runtime-model',
1053
+ apiKey: 'sk-runtime-key',
1054
+ baseUrl: 'https://runtime.example.com/v1',
1055
+ },
1056
+ generationConfigSources: {
1057
+ model: { kind: 'programmatic', detail: 'test' },
1058
+ apiKey: { kind: 'programmatic', detail: 'test' },
1059
+ baseUrl: { kind: 'programmatic', detail: 'test' },
1060
+ },
1061
+ });
1062
+ // Create snapshot
1063
+ const snapshotId = modelsConfig.detectAndCaptureRuntimeModel();
1064
+ expect(snapshotId).toBeDefined();
1065
+ // Set up onModelChange to fail
1066
+ modelsConfig.setOnModelChange(async () => {
1067
+ throw new Error('refresh failed');
1068
+ });
1069
+ // Store baseline state
1070
+ const baselineModel = modelsConfig.getModel();
1071
+ const baselineGc = snapshotGenerationConfig(modelsConfig);
1072
+ // Try to switch - should fail
1073
+ await expect(modelsConfig.switchToRuntimeModel(snapshotId)).rejects.toThrow('refresh failed');
1074
+ // State should be rolled back
1075
+ expect(modelsConfig.getModel()).toBe(baselineModel);
1076
+ expect(modelsConfig.getGenerationConfig()).toMatchObject({
1077
+ model: baselineGc.model,
1078
+ apiKey: baselineGc.apiKey,
1079
+ baseUrl: baselineGc.baseUrl,
1080
+ });
1081
+ });
1082
+ });
1083
+ describe('reloadModelProvidersConfig', () => {
1084
+ it('should reload model providers configuration', async () => {
1085
+ const modelsConfig = new ModelsConfig({
1086
+ initialAuthType: AuthType.USE_OPENAI,
1087
+ modelProvidersConfig: {
1088
+ openai: [{ id: 'gpt-4', name: 'GPT-4' }],
1089
+ },
1090
+ });
1091
+ // Verify initial model
1092
+ await modelsConfig.switchModel(AuthType.USE_OPENAI, 'gpt-4');
1093
+ expect(modelsConfig.getModel()).toBe('gpt-4');
1094
+ // Reload with new config
1095
+ modelsConfig.reloadModelProvidersConfig({
1096
+ openai: [{ id: 'gpt-3.5', name: 'GPT-3.5' }],
1097
+ });
1098
+ // After reload, old model should not exist
1099
+ expect(modelsConfig.getAllConfiguredModels().find((m) => m.id === 'gpt-4')).toBeUndefined();
1100
+ expect(modelsConfig.getAllConfiguredModels().find((m) => m.id === 'gpt-3.5')).toBeDefined();
1101
+ });
1102
+ it('should preserve current model selection if still available after reload', async () => {
1103
+ const modelsConfig = new ModelsConfig({
1104
+ initialAuthType: AuthType.USE_OPENAI,
1105
+ modelProvidersConfig: {
1106
+ openai: [
1107
+ { id: 'gpt-4', name: 'GPT-4' },
1108
+ { id: 'gpt-3.5', name: 'GPT-3.5' },
1109
+ ],
1110
+ },
1111
+ });
1112
+ await modelsConfig.switchModel(AuthType.USE_OPENAI, 'gpt-4');
1113
+ expect(modelsConfig.getModel()).toBe('gpt-4');
1114
+ // Reload with config that still includes gpt-4
1115
+ modelsConfig.reloadModelProvidersConfig({
1116
+ openai: [
1117
+ { id: 'gpt-4', name: 'GPT-4 Updated' },
1118
+ { id: 'new-model', name: 'New Model' },
1119
+ ],
1120
+ });
1121
+ // Current model should still be available
1122
+ const availableModels = modelsConfig.getAllConfiguredModels();
1123
+ expect(availableModels.find((m) => m.id === 'gpt-4')).toBeDefined();
1124
+ expect(availableModels.find((m) => m.id === 'new-model')).toBeDefined();
1125
+ });
1126
+ it('should update available models after reload', async () => {
1127
+ const modelsConfig = new ModelsConfig({
1128
+ initialAuthType: AuthType.USE_OPENAI,
1129
+ modelProvidersConfig: {
1130
+ openai: [{ id: 'gpt-4', name: 'GPT-4' }],
1131
+ },
1132
+ });
1133
+ const initialModels = modelsConfig.getAllConfiguredModels();
1134
+ expect(initialModels.some((m) => m.id === 'gpt-4')).toBe(true);
1135
+ expect(initialModels.some((m) => m.id === 'gemini-pro')).toBe(false);
1136
+ // Reload with different config
1137
+ modelsConfig.reloadModelProvidersConfig({
1138
+ openai: [{ id: 'gpt-3.5', name: 'GPT-3.5' }],
1139
+ gemini: [{ id: 'gemini-pro', name: 'Gemini Pro' }],
1140
+ });
1141
+ const updatedModels = modelsConfig.getAllConfiguredModels();
1142
+ expect(updatedModels.some((m) => m.id === 'gpt-4')).toBe(false);
1143
+ expect(updatedModels.some((m) => m.id === 'gpt-3.5')).toBe(true);
1144
+ expect(updatedModels.some((m) => m.id === 'gemini-pro')).toBe(true);
1145
+ });
1146
+ it('should handle reload with empty config', async () => {
1147
+ const modelsConfig = new ModelsConfig({
1148
+ initialAuthType: AuthType.USE_OPENAI,
1149
+ modelProvidersConfig: {
1150
+ openai: [{ id: 'gpt-4', name: 'GPT-4' }],
1151
+ gemini: [{ id: 'gemini-pro', name: 'Gemini Pro' }],
1152
+ },
1153
+ });
1154
+ expect(modelsConfig
1155
+ .getAllConfiguredModels()
1156
+ .filter((m) => m.authType !== 'qwen-oauth').length).toBeGreaterThan(0);
1157
+ // Reload with empty config
1158
+ modelsConfig.reloadModelProvidersConfig({});
1159
+ // Only qwen-oauth models should remain
1160
+ const models = modelsConfig.getAllConfiguredModels();
1161
+ expect(models.every((m) => m.authType === 'qwen-oauth')).toBe(true);
1162
+ });
1163
+ it('should preserve qwen-oauth models after reload', () => {
1164
+ const modelsConfig = new ModelsConfig({
1165
+ modelProvidersConfig: {
1166
+ openai: [{ id: 'gpt-4', name: 'GPT-4' }],
1167
+ },
1168
+ });
1169
+ const initialQwenModels = modelsConfig
1170
+ .getAllConfiguredModels()
1171
+ .filter((m) => m.authType === 'qwen-oauth');
1172
+ modelsConfig.reloadModelProvidersConfig({
1173
+ gemini: [{ id: 'gemini-pro', name: 'Gemini Pro' }],
1174
+ });
1175
+ // qwen-oauth models should still exist
1176
+ const qwenModelsAfterReload = modelsConfig
1177
+ .getAllConfiguredModels()
1178
+ .filter((m) => m.authType === 'qwen-oauth');
1179
+ expect(qwenModelsAfterReload.length).toBe(initialQwenModels.length);
1180
+ });
1181
+ it('should handle reload with undefined config', () => {
1182
+ const modelsConfig = new ModelsConfig({
1183
+ modelProvidersConfig: {
1184
+ openai: [{ id: 'gpt-4', name: 'GPT-4' }],
1185
+ },
1186
+ });
1187
+ expect(modelsConfig
1188
+ .getAllConfiguredModels()
1189
+ .filter((m) => m.authType === 'openai').length).toBeGreaterThan(0);
1190
+ modelsConfig.reloadModelProvidersConfig(undefined);
1191
+ // User-configured models should be cleared
1192
+ expect(modelsConfig
1193
+ .getAllConfiguredModels()
1194
+ .filter((m) => m.authType === 'openai').length).toBe(0);
1195
+ });
1196
+ it('should support multiple reloads', () => {
1197
+ const modelsConfig = new ModelsConfig();
1198
+ // First reload
1199
+ modelsConfig.reloadModelProvidersConfig({
1200
+ openai: [{ id: 'model-v1', name: 'Model V1' }],
1201
+ });
1202
+ expect(modelsConfig.getAllConfiguredModels().some((m) => m.id === 'model-v1')).toBe(true);
1203
+ // Second reload
1204
+ modelsConfig.reloadModelProvidersConfig({
1205
+ openai: [{ id: 'model-v2', name: 'Model V2' }],
1206
+ });
1207
+ expect(modelsConfig.getAllConfiguredModels().some((m) => m.id === 'model-v1')).toBe(false);
1208
+ expect(modelsConfig.getAllConfiguredModels().some((m) => m.id === 'model-v2')).toBe(true);
1209
+ // Third reload with empty config
1210
+ modelsConfig.reloadModelProvidersConfig({});
1211
+ expect(modelsConfig.getAllConfiguredModels().some((m) => m.id === 'model-v2')).toBe(false);
1212
+ });
1213
+ it('should handle complex multi-authType reload', async () => {
1214
+ const modelsConfig = new ModelsConfig({
1215
+ initialAuthType: AuthType.USE_OPENAI,
1216
+ modelProvidersConfig: {
1217
+ openai: [
1218
+ { id: 'gpt-4', name: 'GPT-4' },
1219
+ { id: 'gpt-3.5', name: 'GPT-3.5' },
1220
+ ],
1221
+ gemini: [{ id: 'gemini-pro', name: 'Gemini Pro' }],
1222
+ },
1223
+ });
1224
+ // Reload with completely different config
1225
+ modelsConfig.reloadModelProvidersConfig({
1226
+ openai: [{ id: 'new-openai', name: 'New OpenAI' }],
1227
+ anthropic: [{ id: 'claude', name: 'Claude' }],
1228
+ gemini: [{ id: 'gemini-ultra', name: 'Gemini Ultra' }],
1229
+ });
1230
+ const allModels = modelsConfig.getAllConfiguredModels();
1231
+ // Old models should be gone
1232
+ expect(allModels.some((m) => m.id === 'gpt-4')).toBe(false);
1233
+ expect(allModels.some((m) => m.id === 'gpt-3.5')).toBe(false);
1234
+ expect(allModels.some((m) => m.id === 'gemini-pro')).toBe(false);
1235
+ // New models should exist
1236
+ expect(allModels.some((m) => m.id === 'new-openai')).toBe(true);
1237
+ expect(allModels.some((m) => m.id === 'claude')).toBe(true);
1238
+ expect(allModels.some((m) => m.id === 'gemini-ultra')).toBe(true);
1239
+ });
1240
+ });
1241
+ });
1242
+ //# sourceMappingURL=modelsConfig.test.js.map