@shareai-lab/kode 1.1.12 → 1.1.13

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 (593) hide show
  1. package/cli.js +44 -23
  2. package/dist/ProjectOnboarding.js +99 -0
  3. package/dist/ProjectOnboarding.js.map +7 -0
  4. package/dist/Tool.js +1 -0
  5. package/dist/Tool.js.map +7 -0
  6. package/dist/commands/agents.js +2087 -0
  7. package/dist/commands/agents.js.map +7 -0
  8. package/dist/commands/approvedTools.js +36 -0
  9. package/dist/commands/approvedTools.js.map +7 -0
  10. package/dist/commands/bug.js +21 -0
  11. package/dist/commands/bug.js.map +7 -0
  12. package/dist/commands/clear.js +37 -0
  13. package/dist/commands/clear.js.map +7 -0
  14. package/dist/commands/compact.js +104 -0
  15. package/dist/commands/compact.js.map +7 -0
  16. package/dist/commands/config.js +20 -0
  17. package/dist/commands/config.js.map +7 -0
  18. package/dist/commands/cost.js +19 -0
  19. package/dist/commands/cost.js.map +7 -0
  20. package/dist/commands/ctx_viz.js +152 -0
  21. package/dist/commands/ctx_viz.js.map +7 -0
  22. package/dist/commands/doctor.js +25 -0
  23. package/dist/commands/doctor.js.map +7 -0
  24. package/dist/commands/help.js +20 -0
  25. package/dist/commands/help.js.map +7 -0
  26. package/dist/commands/init.js +38 -0
  27. package/dist/commands/init.js.map +7 -0
  28. package/dist/commands/listen.js +37 -0
  29. package/dist/commands/listen.js.map +7 -0
  30. package/dist/commands/login.js +37 -0
  31. package/dist/commands/login.js.map +7 -0
  32. package/dist/commands/logout.js +33 -0
  33. package/dist/commands/logout.js.map +7 -0
  34. package/dist/commands/mcp.js +34 -0
  35. package/dist/commands/mcp.js.map +7 -0
  36. package/dist/commands/model.js +41 -0
  37. package/dist/commands/model.js.map +7 -0
  38. package/dist/commands/modelstatus.js +21 -0
  39. package/dist/commands/modelstatus.js.map +7 -0
  40. package/dist/commands/onboarding.js +36 -0
  41. package/dist/commands/onboarding.js.map +7 -0
  42. package/dist/commands/pr_comments.js +61 -0
  43. package/dist/commands/pr_comments.js.map +7 -0
  44. package/dist/commands/refreshCommands.js +37 -0
  45. package/dist/commands/refreshCommands.js.map +7 -0
  46. package/dist/commands/release-notes.js +30 -0
  47. package/dist/commands/release-notes.js.map +7 -0
  48. package/dist/commands/resume.js +35 -0
  49. package/dist/commands/resume.js.map +7 -0
  50. package/dist/commands/review.js +51 -0
  51. package/dist/commands/review.js.map +7 -0
  52. package/dist/commands/terminalSetup.js +163 -0
  53. package/dist/commands/terminalSetup.js.map +7 -0
  54. package/dist/commands.js +84 -0
  55. package/dist/commands.js.map +7 -0
  56. package/dist/components/ApproveApiKey.js +74 -0
  57. package/dist/components/ApproveApiKey.js.map +7 -0
  58. package/dist/components/AsciiLogo.js +12 -0
  59. package/dist/components/AsciiLogo.js.map +7 -0
  60. package/dist/components/AutoUpdater.js +74 -0
  61. package/dist/components/AutoUpdater.js.map +7 -0
  62. package/dist/components/Bug.js +147 -0
  63. package/dist/components/Bug.js.map +7 -0
  64. package/dist/components/Config.js +166 -0
  65. package/dist/components/Config.js.map +7 -0
  66. package/dist/components/ConsoleOAuthFlow.js +188 -0
  67. package/dist/components/ConsoleOAuthFlow.js.map +7 -0
  68. package/dist/components/Cost.js +13 -0
  69. package/dist/components/Cost.js.map +7 -0
  70. package/dist/components/CostThresholdDialog.js +38 -0
  71. package/dist/components/CostThresholdDialog.js.map +7 -0
  72. package/dist/components/CustomSelect/option-map.js +32 -0
  73. package/dist/components/CustomSelect/option-map.js.map +7 -0
  74. package/dist/components/CustomSelect/select-option.js +34 -0
  75. package/dist/components/CustomSelect/select-option.js.map +7 -0
  76. package/dist/components/CustomSelect/select.js +64 -0
  77. package/dist/components/CustomSelect/select.js.map +7 -0
  78. package/dist/components/CustomSelect/theme.js +1 -0
  79. package/dist/components/CustomSelect/theme.js.map +7 -0
  80. package/dist/components/CustomSelect/use-select-state.js +220 -0
  81. package/dist/components/CustomSelect/use-select-state.js.map +7 -0
  82. package/dist/components/CustomSelect/use-select.js +21 -0
  83. package/dist/components/CustomSelect/use-select.js.map +7 -0
  84. package/dist/components/FallbackToolUseRejectedMessage.js +11 -0
  85. package/dist/components/FallbackToolUseRejectedMessage.js.map +7 -0
  86. package/dist/components/FileEditToolUpdatedMessage.js +31 -0
  87. package/dist/components/FileEditToolUpdatedMessage.js.map +7 -0
  88. package/dist/components/Help.js +41 -0
  89. package/dist/components/Help.js.map +7 -0
  90. package/dist/components/HighlightedCode.js +30 -0
  91. package/dist/components/HighlightedCode.js.map +7 -0
  92. package/dist/components/InvalidConfigDialog.js +83 -0
  93. package/dist/components/InvalidConfigDialog.js.map +7 -0
  94. package/dist/components/Link.js +18 -0
  95. package/dist/components/Link.js.map +7 -0
  96. package/dist/components/LogSelector.js +50 -0
  97. package/dist/components/LogSelector.js.map +7 -0
  98. package/dist/components/Logo.js +89 -0
  99. package/dist/components/Logo.js.map +7 -0
  100. package/dist/components/MCPServerApprovalDialog.js +79 -0
  101. package/dist/components/MCPServerApprovalDialog.js.map +7 -0
  102. package/dist/components/MCPServerDialogCopy.js +11 -0
  103. package/dist/components/MCPServerDialogCopy.js.map +7 -0
  104. package/dist/components/MCPServerMultiselectDialog.js +80 -0
  105. package/dist/components/MCPServerMultiselectDialog.js.map +7 -0
  106. package/dist/components/Message.js +146 -0
  107. package/dist/components/Message.js.map +7 -0
  108. package/dist/components/MessageResponse.js +9 -0
  109. package/dist/components/MessageResponse.js.map +7 -0
  110. package/dist/components/MessageSelector.js +133 -0
  111. package/dist/components/MessageSelector.js.map +7 -0
  112. package/dist/components/ModeIndicator.js +38 -0
  113. package/dist/components/ModeIndicator.js.map +7 -0
  114. package/dist/components/ModelConfig.js +208 -0
  115. package/dist/components/ModelConfig.js.map +7 -0
  116. package/dist/components/ModelListManager.js +140 -0
  117. package/dist/components/ModelListManager.js.map +7 -0
  118. package/dist/components/ModelSelector.js +1985 -0
  119. package/dist/components/ModelSelector.js.map +7 -0
  120. package/dist/components/ModelStatusDisplay.js +87 -0
  121. package/dist/components/ModelStatusDisplay.js.map +7 -0
  122. package/dist/components/Onboarding.js +153 -0
  123. package/dist/components/Onboarding.js.map +7 -0
  124. package/dist/components/PressEnterToContinue.js +10 -0
  125. package/dist/components/PressEnterToContinue.js.map +7 -0
  126. package/dist/components/PromptInput.js +501 -0
  127. package/dist/components/PromptInput.js.map +7 -0
  128. package/dist/components/SentryErrorBoundary.js +27 -0
  129. package/dist/components/SentryErrorBoundary.js.map +7 -0
  130. package/dist/components/Spinner.js +101 -0
  131. package/dist/components/Spinner.js.map +7 -0
  132. package/dist/components/StickerRequestForm.js +7 -0
  133. package/dist/components/StickerRequestForm.js.map +7 -0
  134. package/dist/components/StructuredDiff.js +148 -0
  135. package/dist/components/StructuredDiff.js.map +7 -0
  136. package/dist/components/TextInput.js +100 -0
  137. package/dist/components/TextInput.js.map +7 -0
  138. package/dist/components/TodoItem.js +35 -0
  139. package/dist/components/TodoItem.js.map +7 -0
  140. package/dist/components/TokenWarning.js +19 -0
  141. package/dist/components/TokenWarning.js.map +7 -0
  142. package/dist/components/ToolUseLoader.js +24 -0
  143. package/dist/components/ToolUseLoader.js.map +7 -0
  144. package/dist/components/TrustDialog.js +76 -0
  145. package/dist/components/TrustDialog.js.map +7 -0
  146. package/dist/components/binary-feedback/BinaryFeedback.js +50 -0
  147. package/dist/components/binary-feedback/BinaryFeedback.js.map +7 -0
  148. package/dist/components/binary-feedback/BinaryFeedbackOption.js +94 -0
  149. package/dist/components/binary-feedback/BinaryFeedbackOption.js.map +7 -0
  150. package/dist/components/binary-feedback/BinaryFeedbackView.js +139 -0
  151. package/dist/components/binary-feedback/BinaryFeedbackView.js.map +7 -0
  152. package/dist/components/binary-feedback/utils.js +161 -0
  153. package/dist/components/binary-feedback/utils.js.map +7 -0
  154. package/dist/components/messages/AssistantBashOutputMessage.js +23 -0
  155. package/dist/components/messages/AssistantBashOutputMessage.js.map +7 -0
  156. package/dist/components/messages/AssistantLocalCommandOutputMessage.js +36 -0
  157. package/dist/components/messages/AssistantLocalCommandOutputMessage.js.map +7 -0
  158. package/dist/components/messages/AssistantRedactedThinkingMessage.js +12 -0
  159. package/dist/components/messages/AssistantRedactedThinkingMessage.js.map +7 -0
  160. package/dist/components/messages/AssistantTextMessage.js +78 -0
  161. package/dist/components/messages/AssistantTextMessage.js.map +7 -0
  162. package/dist/components/messages/AssistantThinkingMessage.js +27 -0
  163. package/dist/components/messages/AssistantThinkingMessage.js.map +7 -0
  164. package/dist/components/messages/AssistantToolUseMessage.js +91 -0
  165. package/dist/components/messages/AssistantToolUseMessage.js.map +7 -0
  166. package/dist/components/messages/TaskProgressMessage.js +11 -0
  167. package/dist/components/messages/TaskProgressMessage.js.map +7 -0
  168. package/dist/components/messages/TaskToolMessage.js +39 -0
  169. package/dist/components/messages/TaskToolMessage.js.map +7 -0
  170. package/dist/components/messages/UserBashInputMessage.js +18 -0
  171. package/dist/components/messages/UserBashInputMessage.js.map +7 -0
  172. package/dist/components/messages/UserCommandMessage.js +20 -0
  173. package/dist/components/messages/UserCommandMessage.js.map +7 -0
  174. package/dist/components/messages/UserKodingInputMessage.js +18 -0
  175. package/dist/components/messages/UserKodingInputMessage.js.map +7 -0
  176. package/dist/components/messages/UserPromptMessage.js +20 -0
  177. package/dist/components/messages/UserPromptMessage.js.map +7 -0
  178. package/dist/components/messages/UserTextMessage.js +25 -0
  179. package/dist/components/messages/UserTextMessage.js.map +7 -0
  180. package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +10 -0
  181. package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js.map +7 -0
  182. package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js +15 -0
  183. package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js.map +7 -0
  184. package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +25 -0
  185. package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +7 -0
  186. package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +47 -0
  187. package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +7 -0
  188. package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +23 -0
  189. package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +7 -0
  190. package/dist/components/messages/UserToolResultMessage/utils.js +42 -0
  191. package/dist/components/messages/UserToolResultMessage/utils.js.map +7 -0
  192. package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js +112 -0
  193. package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +7 -0
  194. package/dist/components/permissions/FallbackPermissionRequest.js +131 -0
  195. package/dist/components/permissions/FallbackPermissionRequest.js.map +7 -0
  196. package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +159 -0
  197. package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +7 -0
  198. package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +58 -0
  199. package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +7 -0
  200. package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +153 -0
  201. package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +7 -0
  202. package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +70 -0
  203. package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +7 -0
  204. package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +212 -0
  205. package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +7 -0
  206. package/dist/components/permissions/PermissionRequest.js +70 -0
  207. package/dist/components/permissions/PermissionRequest.js.map +7 -0
  208. package/dist/components/permissions/PermissionRequestTitle.js +52 -0
  209. package/dist/components/permissions/PermissionRequestTitle.js.map +7 -0
  210. package/dist/components/permissions/hooks.js +28 -0
  211. package/dist/components/permissions/hooks.js.map +7 -0
  212. package/dist/components/permissions/toolUseOptions.js +46 -0
  213. package/dist/components/permissions/toolUseOptions.js.map +7 -0
  214. package/dist/components/permissions/utils.js +21 -0
  215. package/dist/components/permissions/utils.js.map +7 -0
  216. package/dist/constants/betas.js +11 -0
  217. package/dist/constants/betas.js.map +7 -0
  218. package/dist/constants/claude-asterisk-ascii-art.js +242 -0
  219. package/dist/constants/claude-asterisk-ascii-art.js.map +7 -0
  220. package/dist/constants/figures.js +6 -0
  221. package/dist/constants/figures.js.map +7 -0
  222. package/dist/constants/keys.js +7 -0
  223. package/dist/constants/keys.js.map +7 -0
  224. package/dist/constants/macros.js +13 -0
  225. package/dist/constants/macros.js.map +7 -0
  226. package/dist/constants/modelCapabilities.js +154 -0
  227. package/dist/constants/modelCapabilities.js.map +7 -0
  228. package/dist/constants/models.js +1029 -0
  229. package/dist/constants/models.js.map +7 -0
  230. package/dist/constants/oauth.js +18 -0
  231. package/dist/constants/oauth.js.map +7 -0
  232. package/dist/constants/product.js +26 -0
  233. package/dist/constants/product.js.map +7 -0
  234. package/dist/constants/prompts.js +168 -0
  235. package/dist/constants/prompts.js.map +7 -0
  236. package/dist/constants/releaseNotes.js +9 -0
  237. package/dist/constants/releaseNotes.js.map +7 -0
  238. package/dist/context/PermissionContext.js +111 -0
  239. package/dist/context/PermissionContext.js.map +7 -0
  240. package/dist/context.js +259 -0
  241. package/dist/context.js.map +7 -0
  242. package/dist/cost-tracker.js +76 -0
  243. package/dist/cost-tracker.js.map +7 -0
  244. package/dist/entrypoints/cli.js +1101 -0
  245. package/dist/entrypoints/cli.js.map +7 -0
  246. package/dist/entrypoints/mcp.js +150 -0
  247. package/dist/entrypoints/mcp.js.map +7 -0
  248. package/dist/history.js +25 -0
  249. package/dist/history.js.map +7 -0
  250. package/dist/hooks/useApiKeyVerification.js +12 -0
  251. package/dist/hooks/useApiKeyVerification.js.map +7 -0
  252. package/dist/hooks/useArrowKeyHistory.js +50 -0
  253. package/dist/hooks/useArrowKeyHistory.js.map +7 -0
  254. package/dist/hooks/useCanUseTool.js +112 -0
  255. package/dist/hooks/useCanUseTool.js.map +7 -0
  256. package/dist/hooks/useCancelRequest.js +30 -0
  257. package/dist/hooks/useCancelRequest.js.map +7 -0
  258. package/dist/hooks/useDoublePress.js +31 -0
  259. package/dist/hooks/useDoublePress.js.map +7 -0
  260. package/dist/hooks/useExitOnCtrlCD.js +26 -0
  261. package/dist/hooks/useExitOnCtrlCD.js.map +7 -0
  262. package/dist/hooks/useInterval.js +18 -0
  263. package/dist/hooks/useInterval.js.map +7 -0
  264. package/dist/hooks/useLogMessages.js +14 -0
  265. package/dist/hooks/useLogMessages.js.map +7 -0
  266. package/dist/hooks/useLogStartupTime.js +15 -0
  267. package/dist/hooks/useLogStartupTime.js.map +7 -0
  268. package/dist/hooks/useNotifyAfterTimeout.js +42 -0
  269. package/dist/hooks/useNotifyAfterTimeout.js.map +7 -0
  270. package/dist/hooks/usePermissionRequestLogging.js +28 -0
  271. package/dist/hooks/usePermissionRequestLogging.js.map +7 -0
  272. package/dist/hooks/useTerminalSize.js +38 -0
  273. package/dist/hooks/useTerminalSize.js.map +7 -0
  274. package/dist/hooks/useTextInput.js +250 -0
  275. package/dist/hooks/useTextInput.js.map +7 -0
  276. package/dist/hooks/useUnifiedCompletion.js +929 -0
  277. package/dist/hooks/useUnifiedCompletion.js.map +7 -0
  278. package/dist/index.js +26 -0
  279. package/dist/index.js.map +7 -0
  280. package/dist/messages.js +33 -0
  281. package/dist/messages.js.map +7 -0
  282. package/dist/package.json +1 -0
  283. package/dist/permissions.js +194 -0
  284. package/dist/permissions.js.map +7 -0
  285. package/dist/query.js +492 -0
  286. package/dist/query.js.map +7 -0
  287. package/dist/screens/ConfigureNpmPrefix.js +128 -0
  288. package/dist/screens/ConfigureNpmPrefix.js.map +7 -0
  289. package/dist/screens/Doctor.js +143 -0
  290. package/dist/screens/Doctor.js.map +7 -0
  291. package/dist/screens/LogList.js +55 -0
  292. package/dist/screens/LogList.js.map +7 -0
  293. package/dist/screens/REPL.js +596 -0
  294. package/dist/screens/REPL.js.map +7 -0
  295. package/dist/screens/ResumeConversation.js +56 -0
  296. package/dist/screens/ResumeConversation.js.map +7 -0
  297. package/dist/services/adapters/base.js +29 -0
  298. package/dist/services/adapters/base.js.map +7 -0
  299. package/dist/services/adapters/chatCompletions.js +69 -0
  300. package/dist/services/adapters/chatCompletions.js.map +7 -0
  301. package/dist/services/adapters/responsesAPI.js +126 -0
  302. package/dist/services/adapters/responsesAPI.js.map +7 -0
  303. package/dist/services/browserMocks.js +48 -0
  304. package/dist/services/browserMocks.js.map +7 -0
  305. package/dist/services/claude.js +1605 -0
  306. package/dist/services/claude.js.map +7 -0
  307. package/dist/services/customCommands.js +359 -0
  308. package/dist/services/customCommands.js.map +7 -0
  309. package/dist/services/fileFreshness.js +280 -0
  310. package/dist/services/fileFreshness.js.map +7 -0
  311. package/dist/services/gpt5ConnectionTest.js +248 -0
  312. package/dist/services/gpt5ConnectionTest.js.map +7 -0
  313. package/dist/services/mcpClient.js +435 -0
  314. package/dist/services/mcpClient.js.map +7 -0
  315. package/dist/services/mcpServerApproval.js +55 -0
  316. package/dist/services/mcpServerApproval.js.map +7 -0
  317. package/dist/services/mentionProcessor.js +200 -0
  318. package/dist/services/mentionProcessor.js.map +7 -0
  319. package/dist/services/modelAdapterFactory.js +47 -0
  320. package/dist/services/modelAdapterFactory.js.map +7 -0
  321. package/dist/services/notifier.js +35 -0
  322. package/dist/services/notifier.js.map +7 -0
  323. package/dist/services/oauth.js +259 -0
  324. package/dist/services/oauth.js.map +7 -0
  325. package/dist/services/openai.js +998 -0
  326. package/dist/services/openai.js.map +7 -0
  327. package/dist/services/responseStateManager.js +68 -0
  328. package/dist/services/responseStateManager.js.map +7 -0
  329. package/dist/services/sentry.js +9 -0
  330. package/dist/services/sentry.js.map +7 -0
  331. package/dist/services/statsig.js +112 -0
  332. package/dist/services/statsig.js.map +7 -0
  333. package/dist/services/statsigStorage.js +75 -0
  334. package/dist/services/statsigStorage.js.map +7 -0
  335. package/dist/services/systemReminder.js +353 -0
  336. package/dist/services/systemReminder.js.map +7 -0
  337. package/dist/services/vcr.js +133 -0
  338. package/dist/services/vcr.js.map +7 -0
  339. package/dist/test/testAdapters.js +88 -0
  340. package/dist/test/testAdapters.js.map +1 -0
  341. package/dist/tools/ArchitectTool/ArchitectTool.js +119 -0
  342. package/dist/tools/ArchitectTool/ArchitectTool.js.map +7 -0
  343. package/dist/tools/ArchitectTool/prompt.js +18 -0
  344. package/dist/tools/ArchitectTool/prompt.js.map +7 -0
  345. package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +423 -0
  346. package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +7 -0
  347. package/dist/tools/BashTool/BashTool.js +188 -0
  348. package/dist/tools/BashTool/BashTool.js.map +7 -0
  349. package/dist/tools/BashTool/BashToolResultMessage.js +21 -0
  350. package/dist/tools/BashTool/BashToolResultMessage.js.map +7 -0
  351. package/dist/tools/BashTool/OutputLine.js +30 -0
  352. package/dist/tools/BashTool/OutputLine.js.map +7 -0
  353. package/dist/tools/BashTool/prompt.js +179 -0
  354. package/dist/tools/BashTool/prompt.js.map +7 -0
  355. package/dist/tools/BashTool/utils.js +51 -0
  356. package/dist/tools/BashTool/utils.js.map +7 -0
  357. package/dist/tools/FileEditTool/FileEditTool.js +228 -0
  358. package/dist/tools/FileEditTool/FileEditTool.js.map +7 -0
  359. package/dist/tools/FileEditTool/prompt.js +54 -0
  360. package/dist/tools/FileEditTool/prompt.js.map +7 -0
  361. package/dist/tools/FileEditTool/utils.js +42 -0
  362. package/dist/tools/FileEditTool/utils.js.map +7 -0
  363. package/dist/tools/FileReadTool/FileReadTool.js +272 -0
  364. package/dist/tools/FileReadTool/FileReadTool.js.map +7 -0
  365. package/dist/tools/FileReadTool/prompt.js +10 -0
  366. package/dist/tools/FileReadTool/prompt.js.map +7 -0
  367. package/dist/tools/FileWriteTool/FileWriteTool.js +204 -0
  368. package/dist/tools/FileWriteTool/FileWriteTool.js.map +7 -0
  369. package/dist/tools/FileWriteTool/prompt.js +14 -0
  370. package/dist/tools/FileWriteTool/prompt.js.map +7 -0
  371. package/dist/tools/GlobTool/GlobTool.js +88 -0
  372. package/dist/tools/GlobTool/GlobTool.js.map +7 -0
  373. package/dist/tools/GlobTool/prompt.js +12 -0
  374. package/dist/tools/GlobTool/prompt.js.map +7 -0
  375. package/dist/tools/GrepTool/GrepTool.js +107 -0
  376. package/dist/tools/GrepTool/GrepTool.js.map +7 -0
  377. package/dist/tools/GrepTool/prompt.js +15 -0
  378. package/dist/tools/GrepTool/prompt.js.map +7 -0
  379. package/dist/tools/MCPTool/MCPTool.js +90 -0
  380. package/dist/tools/MCPTool/MCPTool.js.map +7 -0
  381. package/dist/tools/MCPTool/prompt.js +7 -0
  382. package/dist/tools/MCPTool/prompt.js.map +7 -0
  383. package/dist/tools/MemoryReadTool/MemoryReadTool.js +103 -0
  384. package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +7 -0
  385. package/dist/tools/MemoryReadTool/prompt.js +7 -0
  386. package/dist/tools/MemoryReadTool/prompt.js.map +7 -0
  387. package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +77 -0
  388. package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +7 -0
  389. package/dist/tools/MemoryWriteTool/prompt.js +7 -0
  390. package/dist/tools/MemoryWriteTool/prompt.js.map +7 -0
  391. package/dist/tools/MultiEditTool/MultiEditTool.js +293 -0
  392. package/dist/tools/MultiEditTool/MultiEditTool.js.map +7 -0
  393. package/dist/tools/MultiEditTool/prompt.js +48 -0
  394. package/dist/tools/MultiEditTool/prompt.js.map +7 -0
  395. package/dist/tools/NotebookEditTool/NotebookEditTool.js +238 -0
  396. package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +7 -0
  397. package/dist/tools/NotebookEditTool/prompt.js +7 -0
  398. package/dist/tools/NotebookEditTool/prompt.js.map +7 -0
  399. package/dist/tools/NotebookReadTool/NotebookReadTool.js +212 -0
  400. package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +7 -0
  401. package/dist/tools/NotebookReadTool/prompt.js +7 -0
  402. package/dist/tools/NotebookReadTool/prompt.js.map +7 -0
  403. package/dist/tools/StickerRequestTool/StickerRequestTool.js +86 -0
  404. package/dist/tools/StickerRequestTool/StickerRequestTool.js.map +7 -0
  405. package/dist/tools/StickerRequestTool/prompt.js +23 -0
  406. package/dist/tools/StickerRequestTool/prompt.js.map +7 -0
  407. package/dist/tools/TaskTool/TaskTool.js +308 -0
  408. package/dist/tools/TaskTool/TaskTool.js.map +7 -0
  409. package/dist/tools/TaskTool/constants.js +5 -0
  410. package/dist/tools/TaskTool/constants.js.map +7 -0
  411. package/dist/tools/TaskTool/prompt.js +82 -0
  412. package/dist/tools/TaskTool/prompt.js.map +7 -0
  413. package/dist/tools/ThinkTool/ThinkTool.js +48 -0
  414. package/dist/tools/ThinkTool/ThinkTool.js.map +7 -0
  415. package/dist/tools/ThinkTool/prompt.js +16 -0
  416. package/dist/tools/ThinkTool/prompt.js.map +7 -0
  417. package/dist/tools/TodoWriteTool/TodoWriteTool.js +216 -0
  418. package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +7 -0
  419. package/dist/tools/TodoWriteTool/prompt.js +66 -0
  420. package/dist/tools/TodoWriteTool/prompt.js.map +7 -0
  421. package/dist/tools/URLFetcherTool/URLFetcherTool.js +137 -0
  422. package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +7 -0
  423. package/dist/tools/URLFetcherTool/cache.js +45 -0
  424. package/dist/tools/URLFetcherTool/cache.js.map +7 -0
  425. package/dist/tools/URLFetcherTool/htmlToMarkdown.js +42 -0
  426. package/dist/tools/URLFetcherTool/htmlToMarkdown.js.map +7 -0
  427. package/dist/tools/URLFetcherTool/prompt.js +22 -0
  428. package/dist/tools/URLFetcherTool/prompt.js.map +7 -0
  429. package/dist/tools/WebSearchTool/WebSearchTool.js +86 -0
  430. package/dist/tools/WebSearchTool/WebSearchTool.js.map +7 -0
  431. package/dist/tools/WebSearchTool/prompt.js +17 -0
  432. package/dist/tools/WebSearchTool/prompt.js.map +7 -0
  433. package/dist/tools/WebSearchTool/searchProviders.js +48 -0
  434. package/dist/tools/WebSearchTool/searchProviders.js.map +7 -0
  435. package/dist/tools/lsTool/lsTool.js +201 -0
  436. package/dist/tools/lsTool/lsTool.js.map +7 -0
  437. package/dist/tools/lsTool/prompt.js +5 -0
  438. package/dist/tools/lsTool/prompt.js.map +7 -0
  439. package/dist/tools.js +64 -0
  440. package/dist/tools.js.map +7 -0
  441. package/dist/types/PermissionMode.js +82 -0
  442. package/dist/types/PermissionMode.js.map +7 -0
  443. package/dist/types/RequestContext.js +47 -0
  444. package/dist/types/RequestContext.js.map +7 -0
  445. package/dist/types/common.d.js +1 -0
  446. package/dist/types/common.d.js.map +7 -0
  447. package/dist/types/conversation.js +1 -0
  448. package/dist/types/conversation.js.map +7 -0
  449. package/dist/types/logs.js +1 -0
  450. package/dist/types/logs.js.map +7 -0
  451. package/dist/types/modelCapabilities.js +1 -0
  452. package/dist/types/modelCapabilities.js.map +7 -0
  453. package/dist/types/notebook.js +1 -0
  454. package/dist/types/notebook.js.map +7 -0
  455. package/dist/utils/Cursor.js +313 -0
  456. package/dist/utils/Cursor.js.map +7 -0
  457. package/dist/utils/PersistentShell.js +382 -0
  458. package/dist/utils/PersistentShell.js.map +7 -0
  459. package/dist/utils/advancedFuzzyMatcher.js +206 -0
  460. package/dist/utils/advancedFuzzyMatcher.js.map +7 -0
  461. package/dist/utils/agentLoader.js +199 -0
  462. package/dist/utils/agentLoader.js.map +7 -0
  463. package/dist/utils/agentStorage.js +59 -0
  464. package/dist/utils/agentStorage.js.map +7 -0
  465. package/dist/utils/array.js +7 -0
  466. package/dist/utils/array.js.map +7 -0
  467. package/dist/utils/ask.js +77 -0
  468. package/dist/utils/ask.js.map +7 -0
  469. package/dist/utils/auth.js +11 -0
  470. package/dist/utils/auth.js.map +7 -0
  471. package/dist/utils/autoCompactCore.js +149 -0
  472. package/dist/utils/autoCompactCore.js.map +7 -0
  473. package/dist/utils/autoUpdater.js +362 -0
  474. package/dist/utils/autoUpdater.js.map +7 -0
  475. package/dist/utils/betas.js +21 -0
  476. package/dist/utils/betas.js.map +7 -0
  477. package/dist/utils/browser.js +15 -0
  478. package/dist/utils/browser.js.map +7 -0
  479. package/dist/utils/cleanup.js +54 -0
  480. package/dist/utils/cleanup.js.map +7 -0
  481. package/dist/utils/commands.js +207 -0
  482. package/dist/utils/commands.js.map +7 -0
  483. package/dist/utils/commonUnixCommands.js +687 -0
  484. package/dist/utils/commonUnixCommands.js.map +7 -0
  485. package/dist/utils/config.js +655 -0
  486. package/dist/utils/config.js.map +7 -0
  487. package/dist/utils/conversationRecovery.js +35 -0
  488. package/dist/utils/conversationRecovery.js.map +7 -0
  489. package/dist/utils/debugLogger.js +891 -0
  490. package/dist/utils/debugLogger.js.map +7 -0
  491. package/dist/utils/diff.js +32 -0
  492. package/dist/utils/diff.js.map +7 -0
  493. package/dist/utils/env.js +44 -0
  494. package/dist/utils/env.js.map +7 -0
  495. package/dist/utils/errors.js +23 -0
  496. package/dist/utils/errors.js.map +7 -0
  497. package/dist/utils/exampleCommands.js +80 -0
  498. package/dist/utils/exampleCommands.js.map +7 -0
  499. package/dist/utils/execFileNoThrow.js +44 -0
  500. package/dist/utils/execFileNoThrow.js.map +7 -0
  501. package/dist/utils/expertChatStorage.js +78 -0
  502. package/dist/utils/expertChatStorage.js.map +7 -0
  503. package/dist/utils/file.js +282 -0
  504. package/dist/utils/file.js.map +7 -0
  505. package/dist/utils/fileRecoveryCore.js +41 -0
  506. package/dist/utils/fileRecoveryCore.js.map +7 -0
  507. package/dist/utils/format.js +41 -0
  508. package/dist/utils/format.js.map +7 -0
  509. package/dist/utils/fuzzyMatcher.js +252 -0
  510. package/dist/utils/fuzzyMatcher.js.map +7 -0
  511. package/dist/utils/generators.js +46 -0
  512. package/dist/utils/generators.js.map +7 -0
  513. package/dist/utils/git.js +83 -0
  514. package/dist/utils/git.js.map +7 -0
  515. package/dist/utils/globalLogger.js +54 -0
  516. package/dist/utils/globalLogger.js.map +7 -0
  517. package/dist/utils/http.js +7 -0
  518. package/dist/utils/http.js.map +7 -0
  519. package/dist/utils/imagePaste.js +29 -0
  520. package/dist/utils/imagePaste.js.map +7 -0
  521. package/dist/utils/json.js +16 -0
  522. package/dist/utils/json.js.map +7 -0
  523. package/dist/utils/log.js +298 -0
  524. package/dist/utils/log.js.map +7 -0
  525. package/dist/utils/markdown.js +187 -0
  526. package/dist/utils/markdown.js.map +7 -0
  527. package/dist/utils/messageContextManager.js +195 -0
  528. package/dist/utils/messageContextManager.js.map +7 -0
  529. package/dist/utils/messages.js +633 -0
  530. package/dist/utils/messages.js.map +7 -0
  531. package/dist/utils/model.js +687 -0
  532. package/dist/utils/model.js.map +7 -0
  533. package/dist/utils/permissions/filesystem.js +80 -0
  534. package/dist/utils/permissions/filesystem.js.map +7 -0
  535. package/dist/utils/responseState.js +20 -0
  536. package/dist/utils/responseState.js.map +7 -0
  537. package/dist/utils/ripgrep.js +131 -0
  538. package/dist/utils/ripgrep.js.map +7 -0
  539. package/dist/utils/secureFile.js +483 -0
  540. package/dist/utils/secureFile.js.map +7 -0
  541. package/dist/utils/sessionState.js +31 -0
  542. package/dist/utils/sessionState.js.map +7 -0
  543. package/dist/utils/state.js +24 -0
  544. package/dist/utils/state.js.map +7 -0
  545. package/dist/utils/style.js +31 -0
  546. package/dist/utils/style.js.map +7 -0
  547. package/dist/utils/terminal.js +43 -0
  548. package/dist/utils/terminal.js.map +7 -0
  549. package/dist/utils/theme.js +102 -0
  550. package/dist/utils/theme.js.map +7 -0
  551. package/dist/utils/thinking.js +103 -0
  552. package/dist/utils/thinking.js.map +7 -0
  553. package/dist/utils/todoStorage.js +291 -0
  554. package/dist/utils/todoStorage.js.map +7 -0
  555. package/dist/utils/tokens.js +30 -0
  556. package/dist/utils/tokens.js.map +7 -0
  557. package/dist/utils/toolExecutionController.js +109 -0
  558. package/dist/utils/toolExecutionController.js.map +7 -0
  559. package/dist/utils/unaryLogging.js +14 -0
  560. package/dist/utils/unaryLogging.js.map +7 -0
  561. package/dist/utils/user.js +40 -0
  562. package/dist/utils/user.js.map +7 -0
  563. package/dist/utils/validate.js +132 -0
  564. package/dist/utils/validate.js.map +7 -0
  565. package/dist/yoga.wasm +0 -0
  566. package/package.json +28 -7
  567. package/src/Tool.ts +4 -3
  568. package/src/commands/agents.tsx +10 -4
  569. package/src/components/messages/AssistantToolUseMessage.tsx +5 -6
  570. package/src/constants/macros.ts +5 -2
  571. package/src/entrypoints/cli.tsx +38 -19
  572. package/src/entrypoints/mcp.ts +1 -2
  573. package/src/hooks/useDoublePress.ts +0 -1
  574. package/src/hooks/useTextInput.ts +4 -5
  575. package/src/hooks/useUnifiedCompletion.ts +2 -2
  576. package/src/index.ts +34 -0
  577. package/src/query.ts +13 -8
  578. package/src/screens/Doctor.tsx +1 -1
  579. package/src/screens/REPL.tsx +13 -9
  580. package/src/services/openai.ts +25 -4
  581. package/src/tools/ArchitectTool/ArchitectTool.tsx +18 -5
  582. package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +21 -14
  583. package/src/tools/FileEditTool/FileEditTool.tsx +6 -2
  584. package/src/tools/FileWriteTool/FileWriteTool.tsx +7 -3
  585. package/src/tools/MultiEditTool/MultiEditTool.tsx +26 -4
  586. package/src/tools/NotebookReadTool/NotebookReadTool.tsx +1 -1
  587. package/src/tools/StickerRequestTool/StickerRequestTool.tsx +28 -14
  588. package/src/tools/TaskTool/TaskTool.tsx +8 -36
  589. package/src/types/common.d.ts +2 -0
  590. package/src/utils/generators.ts +1 -1
  591. package/src/utils/messageContextManager.ts +5 -0
  592. package/src/utils/messages.tsx +8 -2
  593. package/src/utils/thinking.ts +1 -1
@@ -0,0 +1,998 @@
1
+ import { getGlobalConfig } from "../utils/config.js";
2
+ import { ProxyAgent, fetch } from "undici";
3
+ import { setSessionState, getSessionState } from "../utils/sessionState.js";
4
+ import { logEvent } from "../services/statsig.js";
5
+ import { debug as debugLogger, getCurrentRequest, logAPIError } from "../utils/debugLogger.js";
6
+ function getRetryDelay(attempt, retryAfter) {
7
+ if (retryAfter) {
8
+ const retryAfterMs = parseInt(retryAfter) * 1e3;
9
+ if (!isNaN(retryAfterMs) && retryAfterMs > 0) {
10
+ return Math.min(retryAfterMs, 6e4);
11
+ }
12
+ }
13
+ const baseDelay = 1e3;
14
+ const maxDelay = 32e3;
15
+ const delay = baseDelay * Math.pow(2, attempt - 1);
16
+ const jitter = Math.random() * 0.1 * delay;
17
+ return Math.min(delay + jitter, maxDelay);
18
+ }
19
+ function abortableDelay(delayMs, signal) {
20
+ return new Promise((resolve, reject) => {
21
+ if (signal?.aborted) {
22
+ reject(new Error("Request was aborted"));
23
+ return;
24
+ }
25
+ const timeoutId = setTimeout(() => {
26
+ resolve();
27
+ }, delayMs);
28
+ if (signal) {
29
+ const abortHandler = () => {
30
+ clearTimeout(timeoutId);
31
+ reject(new Error("Request was aborted"));
32
+ };
33
+ signal.addEventListener("abort", abortHandler, { once: true });
34
+ }
35
+ });
36
+ }
37
+ var ModelErrorType = /* @__PURE__ */ ((ModelErrorType2) => {
38
+ ModelErrorType2["MaxLength"] = "1024";
39
+ ModelErrorType2["MaxCompletionTokens"] = "max_completion_tokens";
40
+ ModelErrorType2["TemperatureRestriction"] = "temperature_restriction";
41
+ ModelErrorType2["StreamOptions"] = "stream_options";
42
+ ModelErrorType2["Citations"] = "citations";
43
+ ModelErrorType2["RateLimit"] = "rate_limit";
44
+ return ModelErrorType2;
45
+ })(ModelErrorType || {});
46
+ function getModelErrorKey(baseURL, model, type) {
47
+ return `${baseURL}:${model}:${type}`;
48
+ }
49
+ function hasModelError(baseURL, model, type) {
50
+ return !!getSessionState("modelErrors")[getModelErrorKey(baseURL, model, type)];
51
+ }
52
+ function setModelError(baseURL, model, type, error) {
53
+ setSessionState("modelErrors", {
54
+ [getModelErrorKey(baseURL, model, type)]: error
55
+ });
56
+ }
57
+ const GPT5_ERROR_HANDLERS = [
58
+ {
59
+ type: "max_completion_tokens" /* MaxCompletionTokens */,
60
+ detect: (errMsg) => {
61
+ const lowerMsg = errMsg.toLowerCase();
62
+ return (
63
+ // Exact OpenAI GPT-5 error message
64
+ lowerMsg.includes("unsupported parameter: 'max_tokens'") && lowerMsg.includes("'max_completion_tokens'") || // Generic max_tokens error patterns
65
+ lowerMsg.includes("max_tokens") && lowerMsg.includes("max_completion_tokens") || lowerMsg.includes("max_tokens") && lowerMsg.includes("not supported") || lowerMsg.includes("max_tokens") && lowerMsg.includes("use max_completion_tokens") || // Additional patterns for various providers
66
+ lowerMsg.includes("invalid parameter") && lowerMsg.includes("max_tokens") || lowerMsg.includes("parameter error") && lowerMsg.includes("max_tokens")
67
+ );
68
+ },
69
+ fix: async (opts) => {
70
+ console.log(`\u{1F527} GPT-5 Fix: Converting max_tokens (${opts.max_tokens}) to max_completion_tokens`);
71
+ if ("max_tokens" in opts) {
72
+ opts.max_completion_tokens = opts.max_tokens;
73
+ delete opts.max_tokens;
74
+ }
75
+ }
76
+ },
77
+ {
78
+ type: "temperature_restriction" /* TemperatureRestriction */,
79
+ detect: (errMsg) => {
80
+ const lowerMsg = errMsg.toLowerCase();
81
+ return lowerMsg.includes("temperature") && (lowerMsg.includes("only supports") || lowerMsg.includes("must be 1") || lowerMsg.includes("invalid temperature"));
82
+ },
83
+ fix: async (opts) => {
84
+ console.log(`\u{1F527} GPT-5 Fix: Adjusting temperature from ${opts.temperature} to 1`);
85
+ opts.temperature = 1;
86
+ }
87
+ }
88
+ // Add more GPT-5 specific handlers as needed
89
+ ];
90
+ const ERROR_HANDLERS = [
91
+ {
92
+ type: "1024" /* MaxLength */,
93
+ detect: (errMsg) => errMsg.includes("Expected a string with maximum length 1024"),
94
+ fix: async (opts) => {
95
+ const toolDescriptions = {};
96
+ for (const tool of opts.tools || []) {
97
+ if (tool.function.description.length <= 1024) continue;
98
+ let str = "";
99
+ let remainder = "";
100
+ for (let line of tool.function.description.split("\n")) {
101
+ if (str.length + line.length < 1024) {
102
+ str += line + "\n";
103
+ } else {
104
+ remainder += line + "\n";
105
+ }
106
+ }
107
+ logEvent("truncated_tool_description", {
108
+ name: tool.function.name,
109
+ original_length: String(tool.function.description.length),
110
+ truncated_length: String(str.length),
111
+ remainder_length: String(remainder.length)
112
+ });
113
+ tool.function.description = str;
114
+ toolDescriptions[tool.function.name] = remainder;
115
+ }
116
+ if (Object.keys(toolDescriptions).length > 0) {
117
+ let content = "<additional-tool-usage-instructions>\n\n";
118
+ for (const [name, description] of Object.entries(toolDescriptions)) {
119
+ content += `<${name}>
120
+ ${description}
121
+ </${name}>
122
+
123
+ `;
124
+ }
125
+ content += "</additional-tool-usage-instructions>";
126
+ for (let i = opts.messages.length - 1; i >= 0; i--) {
127
+ if (opts.messages[i].role === "system") {
128
+ opts.messages.splice(i + 1, 0, {
129
+ role: "system",
130
+ content
131
+ });
132
+ break;
133
+ }
134
+ }
135
+ }
136
+ }
137
+ },
138
+ {
139
+ type: "max_completion_tokens" /* MaxCompletionTokens */,
140
+ detect: (errMsg) => errMsg.includes("Use 'max_completion_tokens'"),
141
+ fix: async (opts) => {
142
+ opts.max_completion_tokens = opts.max_tokens;
143
+ delete opts.max_tokens;
144
+ }
145
+ },
146
+ {
147
+ type: "stream_options" /* StreamOptions */,
148
+ detect: (errMsg) => errMsg.includes("stream_options"),
149
+ fix: async (opts) => {
150
+ delete opts.stream_options;
151
+ }
152
+ },
153
+ {
154
+ type: "citations" /* Citations */,
155
+ detect: (errMsg) => errMsg.includes("Extra inputs are not permitted") && errMsg.includes("citations"),
156
+ fix: async (opts) => {
157
+ if (!opts.messages) return;
158
+ for (const message of opts.messages) {
159
+ if (!message) continue;
160
+ if (Array.isArray(message.content)) {
161
+ for (const item of message.content) {
162
+ if (item && typeof item === "object") {
163
+ const itemObj = item;
164
+ if ("citations" in itemObj) {
165
+ delete itemObj.citations;
166
+ }
167
+ }
168
+ }
169
+ } else if (message.content && typeof message.content === "object") {
170
+ const contentObj = message.content;
171
+ if ("citations" in contentObj) {
172
+ delete contentObj.citations;
173
+ }
174
+ }
175
+ }
176
+ }
177
+ }
178
+ ];
179
+ function isRateLimitError(errMsg) {
180
+ if (!errMsg) return false;
181
+ const lowerMsg = errMsg.toLowerCase();
182
+ return lowerMsg.includes("rate limit") || lowerMsg.includes("too many requests") || lowerMsg.includes("429");
183
+ }
184
+ const MODEL_FEATURES = {
185
+ // OpenAI thinking models
186
+ o1: { usesMaxCompletionTokens: true },
187
+ "o1-preview": { usesMaxCompletionTokens: true },
188
+ "o1-mini": { usesMaxCompletionTokens: true },
189
+ "o1-pro": { usesMaxCompletionTokens: true },
190
+ "o3-mini": { usesMaxCompletionTokens: true },
191
+ // GPT-5 models
192
+ "gpt-5": {
193
+ usesMaxCompletionTokens: true,
194
+ supportsResponsesAPI: true,
195
+ requiresTemperatureOne: true,
196
+ supportsVerbosityControl: true,
197
+ supportsCustomTools: true,
198
+ supportsAllowedTools: true
199
+ },
200
+ "gpt-5-mini": {
201
+ usesMaxCompletionTokens: true,
202
+ supportsResponsesAPI: true,
203
+ requiresTemperatureOne: true,
204
+ supportsVerbosityControl: true,
205
+ supportsCustomTools: true,
206
+ supportsAllowedTools: true
207
+ },
208
+ "gpt-5-nano": {
209
+ usesMaxCompletionTokens: true,
210
+ supportsResponsesAPI: true,
211
+ requiresTemperatureOne: true,
212
+ supportsVerbosityControl: true,
213
+ supportsCustomTools: true,
214
+ supportsAllowedTools: true
215
+ },
216
+ "gpt-5-chat-latest": {
217
+ usesMaxCompletionTokens: true,
218
+ supportsResponsesAPI: false,
219
+ // Uses Chat Completions only
220
+ requiresTemperatureOne: true,
221
+ supportsVerbosityControl: true
222
+ }
223
+ };
224
+ function getModelFeatures(modelName) {
225
+ if (!modelName || typeof modelName !== "string") {
226
+ return { usesMaxCompletionTokens: false };
227
+ }
228
+ if (MODEL_FEATURES[modelName]) {
229
+ return MODEL_FEATURES[modelName];
230
+ }
231
+ if (modelName.toLowerCase().includes("gpt-5")) {
232
+ return {
233
+ usesMaxCompletionTokens: true,
234
+ supportsResponsesAPI: true,
235
+ requiresTemperatureOne: true,
236
+ supportsVerbosityControl: true,
237
+ supportsCustomTools: true,
238
+ supportsAllowedTools: true
239
+ };
240
+ }
241
+ for (const [key, features] of Object.entries(MODEL_FEATURES)) {
242
+ if (modelName.includes(key)) {
243
+ return features;
244
+ }
245
+ }
246
+ return { usesMaxCompletionTokens: false };
247
+ }
248
+ function applyModelSpecificTransformations(opts) {
249
+ if (!opts.model || typeof opts.model !== "string") {
250
+ return;
251
+ }
252
+ const features = getModelFeatures(opts.model);
253
+ const isGPT5 = opts.model.toLowerCase().includes("gpt-5");
254
+ if (isGPT5 || features.usesMaxCompletionTokens) {
255
+ if ("max_tokens" in opts && !("max_completion_tokens" in opts)) {
256
+ console.log(`\u{1F527} Transforming max_tokens (${opts.max_tokens}) to max_completion_tokens for ${opts.model}`);
257
+ opts.max_completion_tokens = opts.max_tokens;
258
+ delete opts.max_tokens;
259
+ }
260
+ if (features.requiresTemperatureOne && "temperature" in opts) {
261
+ if (opts.temperature !== 1 && opts.temperature !== void 0) {
262
+ console.log(
263
+ `\u{1F527} GPT-5 temperature constraint: Adjusting temperature from ${opts.temperature} to 1 for ${opts.model}`
264
+ );
265
+ opts.temperature = 1;
266
+ }
267
+ }
268
+ if (isGPT5) {
269
+ delete opts.frequency_penalty;
270
+ delete opts.presence_penalty;
271
+ delete opts.logit_bias;
272
+ delete opts.user;
273
+ if (!opts.reasoning_effort && features.supportsVerbosityControl) {
274
+ opts.reasoning_effort = "medium";
275
+ }
276
+ }
277
+ } else {
278
+ if (features.usesMaxCompletionTokens && "max_tokens" in opts && !("max_completion_tokens" in opts)) {
279
+ opts.max_completion_tokens = opts.max_tokens;
280
+ delete opts.max_tokens;
281
+ }
282
+ }
283
+ }
284
+ async function applyModelErrorFixes(opts, baseURL) {
285
+ const isGPT5 = opts.model.startsWith("gpt-5");
286
+ const handlers = isGPT5 ? [...GPT5_ERROR_HANDLERS, ...ERROR_HANDLERS] : ERROR_HANDLERS;
287
+ for (const handler of handlers) {
288
+ if (hasModelError(baseURL, opts.model, handler.type)) {
289
+ await handler.fix(opts);
290
+ return;
291
+ }
292
+ }
293
+ }
294
+ async function tryWithEndpointFallback(baseURL, opts, headers, provider, proxy, signal) {
295
+ const endpointsToTry = [];
296
+ if (provider === "minimax") {
297
+ endpointsToTry.push("/text/chatcompletion_v2", "/chat/completions");
298
+ } else {
299
+ endpointsToTry.push("/chat/completions");
300
+ }
301
+ let lastError = null;
302
+ for (const endpoint of endpointsToTry) {
303
+ try {
304
+ const response = await fetch(`${baseURL}${endpoint}`, {
305
+ method: "POST",
306
+ headers,
307
+ body: JSON.stringify(opts.stream ? { ...opts, stream: true } : opts),
308
+ dispatcher: proxy,
309
+ signal
310
+ // 🔧 Connect AbortSignal to fetch call
311
+ });
312
+ if (response.ok) {
313
+ return { response, endpoint };
314
+ }
315
+ if (response.status === 404 && endpointsToTry.length > 1) {
316
+ console.log(
317
+ `Endpoint ${endpoint} returned 404, trying next endpoint...`
318
+ );
319
+ continue;
320
+ }
321
+ return { response, endpoint };
322
+ } catch (error) {
323
+ lastError = error;
324
+ if (endpointsToTry.indexOf(endpoint) < endpointsToTry.length - 1) {
325
+ console.log(`Network error on ${endpoint}, trying next endpoint...`);
326
+ continue;
327
+ }
328
+ }
329
+ }
330
+ throw lastError || new Error("All endpoints failed");
331
+ }
332
+ async function getCompletionWithProfile(modelProfile, opts, attempt = 0, maxAttempts = 10, signal) {
333
+ if (attempt >= maxAttempts) {
334
+ throw new Error("Max attempts reached");
335
+ }
336
+ const provider = modelProfile?.provider || "anthropic";
337
+ const baseURL = modelProfile?.baseURL;
338
+ const apiKey = modelProfile?.apiKey;
339
+ const proxy = getGlobalConfig().proxy ? new ProxyAgent(getGlobalConfig().proxy) : void 0;
340
+ const headers = {
341
+ "Content-Type": "application/json"
342
+ };
343
+ if (apiKey) {
344
+ if (provider === "azure") {
345
+ headers["api-key"] = apiKey;
346
+ } else {
347
+ headers["Authorization"] = `Bearer ${apiKey}`;
348
+ }
349
+ }
350
+ applyModelSpecificTransformations(opts);
351
+ await applyModelErrorFixes(opts, baseURL || "");
352
+ debugLogger.api("OPENAI_API_CALL_START", {
353
+ endpoint: baseURL || "DEFAULT_OPENAI",
354
+ model: opts.model,
355
+ provider,
356
+ apiKeyConfigured: !!apiKey,
357
+ apiKeyPrefix: apiKey ? apiKey.substring(0, 8) : null,
358
+ maxTokens: opts.max_tokens,
359
+ temperature: opts.temperature,
360
+ messageCount: opts.messages?.length || 0,
361
+ streamMode: opts.stream,
362
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
363
+ modelProfileModelName: modelProfile?.modelName,
364
+ modelProfileName: modelProfile?.name
365
+ });
366
+ opts.messages = opts.messages.map((msg) => {
367
+ if (msg.role === "tool") {
368
+ if (Array.isArray(msg.content)) {
369
+ return {
370
+ ...msg,
371
+ content: msg.content.map((c) => c.text || "").filter(Boolean).join("\n\n") || "(empty content)"
372
+ };
373
+ } else if (typeof msg.content !== "string") {
374
+ return {
375
+ ...msg,
376
+ content: typeof msg.content === "undefined" ? "(empty content)" : JSON.stringify(msg.content)
377
+ };
378
+ }
379
+ }
380
+ return msg;
381
+ });
382
+ const azureApiVersion = "2024-06-01";
383
+ let endpoint = "/chat/completions";
384
+ if (provider === "azure") {
385
+ endpoint = `/chat/completions?api-version=${azureApiVersion}`;
386
+ } else if (provider === "minimax") {
387
+ endpoint = "/text/chatcompletion_v2";
388
+ }
389
+ try {
390
+ if (opts.stream) {
391
+ const isOpenAICompatible2 = [
392
+ "minimax",
393
+ "kimi",
394
+ "deepseek",
395
+ "siliconflow",
396
+ "qwen",
397
+ "glm",
398
+ "baidu-qianfan",
399
+ "openai",
400
+ "mistral",
401
+ "xai",
402
+ "groq",
403
+ "custom-openai"
404
+ ].includes(provider);
405
+ let response2;
406
+ let usedEndpoint2;
407
+ if (isOpenAICompatible2 && provider !== "azure") {
408
+ const result = await tryWithEndpointFallback(
409
+ baseURL,
410
+ opts,
411
+ headers,
412
+ provider,
413
+ proxy,
414
+ signal
415
+ // 🔧 Pass AbortSignal to endpoint fallback
416
+ );
417
+ response2 = result.response;
418
+ usedEndpoint2 = result.endpoint;
419
+ } else {
420
+ response2 = await fetch(`${baseURL}${endpoint}`, {
421
+ method: "POST",
422
+ headers,
423
+ body: JSON.stringify({ ...opts, stream: true }),
424
+ dispatcher: proxy,
425
+ signal
426
+ // 🔧 CRITICAL FIX: Connect AbortSignal to fetch call
427
+ });
428
+ usedEndpoint2 = endpoint;
429
+ }
430
+ if (!response2.ok) {
431
+ if (signal?.aborted) {
432
+ throw new Error("Request cancelled by user");
433
+ }
434
+ try {
435
+ const errorData = await response2.json();
436
+ const hasError = (data) => {
437
+ return typeof data === "object" && data !== null;
438
+ };
439
+ const errorMessage = hasError(errorData) ? errorData.error?.message || errorData.message || `HTTP ${response2.status}` : `HTTP ${response2.status}`;
440
+ const isGPT5 = opts.model.startsWith("gpt-5");
441
+ const handlers = isGPT5 ? [...GPT5_ERROR_HANDLERS, ...ERROR_HANDLERS] : ERROR_HANDLERS;
442
+ for (const handler of handlers) {
443
+ if (handler.detect(errorMessage)) {
444
+ console.log(`\u{1F527} Detected ${handler.type} error for ${opts.model}: ${errorMessage}`);
445
+ setModelError(baseURL || "", opts.model, handler.type, errorMessage);
446
+ await handler.fix(opts);
447
+ console.log(`\u{1F527} Applied fix for ${handler.type}, retrying...`);
448
+ return getCompletionWithProfile(
449
+ modelProfile,
450
+ opts,
451
+ attempt + 1,
452
+ maxAttempts,
453
+ signal
454
+ );
455
+ }
456
+ }
457
+ console.log(`\u26A0\uFE0F Unhandled API error (${response2.status}): ${errorMessage}`);
458
+ logAPIError({
459
+ model: opts.model,
460
+ endpoint: `${baseURL}${endpoint}`,
461
+ status: response2.status,
462
+ error: errorMessage,
463
+ request: opts,
464
+ response: errorData,
465
+ provider
466
+ });
467
+ } catch (parseError) {
468
+ console.log(`\u26A0\uFE0F Could not parse error response (${response2.status})`);
469
+ logAPIError({
470
+ model: opts.model,
471
+ endpoint: `${baseURL}${endpoint}`,
472
+ status: response2.status,
473
+ error: `Could not parse error response: ${parseError.message}`,
474
+ request: opts,
475
+ response: { parseError: parseError.message },
476
+ provider
477
+ });
478
+ }
479
+ const delayMs = getRetryDelay(attempt);
480
+ console.log(
481
+ ` \u23BF API error (${response2.status}), retrying in ${Math.round(delayMs / 1e3)}s... (attempt ${attempt + 1}/${maxAttempts})`
482
+ );
483
+ try {
484
+ await abortableDelay(delayMs, signal);
485
+ } catch (error) {
486
+ if (error.message === "Request was aborted") {
487
+ throw new Error("Request cancelled by user");
488
+ }
489
+ throw error;
490
+ }
491
+ return getCompletionWithProfile(
492
+ modelProfile,
493
+ opts,
494
+ attempt + 1,
495
+ maxAttempts,
496
+ signal
497
+ // 🔧 Pass AbortSignal to recursive call
498
+ );
499
+ }
500
+ const stream = createStreamProcessor(response2.body, signal);
501
+ return stream;
502
+ }
503
+ const isOpenAICompatible = [
504
+ "minimax",
505
+ "kimi",
506
+ "deepseek",
507
+ "siliconflow",
508
+ "qwen",
509
+ "glm",
510
+ "baidu-qianfan",
511
+ "openai",
512
+ "mistral",
513
+ "xai",
514
+ "groq",
515
+ "custom-openai"
516
+ ].includes(provider);
517
+ let response;
518
+ let usedEndpoint;
519
+ if (isOpenAICompatible && provider !== "azure") {
520
+ const result = await tryWithEndpointFallback(
521
+ baseURL,
522
+ opts,
523
+ headers,
524
+ provider,
525
+ proxy,
526
+ signal
527
+ // 🔧 Pass AbortSignal to endpoint fallback
528
+ );
529
+ response = result.response;
530
+ usedEndpoint = result.endpoint;
531
+ } else {
532
+ response = await fetch(`${baseURL}${endpoint}`, {
533
+ method: "POST",
534
+ headers,
535
+ body: JSON.stringify(opts),
536
+ dispatcher: proxy,
537
+ signal
538
+ // 🔧 CRITICAL FIX: Connect AbortSignal to non-streaming fetch call
539
+ });
540
+ usedEndpoint = endpoint;
541
+ }
542
+ if (!response.ok) {
543
+ if (signal?.aborted) {
544
+ throw new Error("Request cancelled by user");
545
+ }
546
+ try {
547
+ const errorData = await response.json();
548
+ const hasError = (data) => {
549
+ return typeof data === "object" && data !== null;
550
+ };
551
+ const errorMessage = hasError(errorData) ? errorData.error?.message || errorData.message || `HTTP ${response.status}` : `HTTP ${response.status}`;
552
+ const isGPT5 = opts.model.startsWith("gpt-5");
553
+ const handlers = isGPT5 ? [...GPT5_ERROR_HANDLERS, ...ERROR_HANDLERS] : ERROR_HANDLERS;
554
+ for (const handler of handlers) {
555
+ if (handler.detect(errorMessage)) {
556
+ console.log(`\u{1F527} Detected ${handler.type} error for ${opts.model}: ${errorMessage}`);
557
+ setModelError(baseURL || "", opts.model, handler.type, errorMessage);
558
+ await handler.fix(opts);
559
+ console.log(`\u{1F527} Applied fix for ${handler.type}, retrying...`);
560
+ return getCompletionWithProfile(
561
+ modelProfile,
562
+ opts,
563
+ attempt + 1,
564
+ maxAttempts,
565
+ signal
566
+ );
567
+ }
568
+ }
569
+ console.log(`\u26A0\uFE0F Unhandled API error (${response.status}): ${errorMessage}`);
570
+ } catch (parseError) {
571
+ console.log(`\u26A0\uFE0F Could not parse error response (${response.status})`);
572
+ }
573
+ const delayMs = getRetryDelay(attempt);
574
+ console.log(
575
+ ` \u23BF API error (${response.status}), retrying in ${Math.round(delayMs / 1e3)}s... (attempt ${attempt + 1}/${maxAttempts})`
576
+ );
577
+ try {
578
+ await abortableDelay(delayMs, signal);
579
+ } catch (error) {
580
+ if (error.message === "Request was aborted") {
581
+ throw new Error("Request cancelled by user");
582
+ }
583
+ throw error;
584
+ }
585
+ return getCompletionWithProfile(
586
+ modelProfile,
587
+ opts,
588
+ attempt + 1,
589
+ maxAttempts,
590
+ signal
591
+ // 🔧 Pass AbortSignal to recursive call
592
+ );
593
+ }
594
+ const responseData = await response.json();
595
+ return responseData;
596
+ } catch (error) {
597
+ if (signal?.aborted) {
598
+ throw new Error("Request cancelled by user");
599
+ }
600
+ if (attempt < maxAttempts) {
601
+ if (signal?.aborted) {
602
+ throw new Error("Request cancelled by user");
603
+ }
604
+ const delayMs = getRetryDelay(attempt);
605
+ console.log(
606
+ ` \u23BF Network error, retrying in ${Math.round(delayMs / 1e3)}s... (attempt ${attempt + 1}/${maxAttempts})`
607
+ );
608
+ try {
609
+ await abortableDelay(delayMs, signal);
610
+ } catch (error2) {
611
+ if (error2.message === "Request was aborted") {
612
+ throw new Error("Request cancelled by user");
613
+ }
614
+ throw error2;
615
+ }
616
+ return getCompletionWithProfile(
617
+ modelProfile,
618
+ opts,
619
+ attempt + 1,
620
+ maxAttempts,
621
+ signal
622
+ // 🔧 Pass AbortSignal to recursive call
623
+ );
624
+ }
625
+ throw error;
626
+ }
627
+ }
628
+ function createStreamProcessor(stream, signal) {
629
+ if (!stream) {
630
+ throw new Error("Stream is null or undefined");
631
+ }
632
+ return (async function* () {
633
+ const reader = stream.getReader();
634
+ const decoder = new TextDecoder("utf-8");
635
+ let buffer = "";
636
+ try {
637
+ while (true) {
638
+ if (signal?.aborted) {
639
+ break;
640
+ }
641
+ let readResult;
642
+ try {
643
+ readResult = await reader.read();
644
+ } catch (e) {
645
+ if (signal?.aborted) {
646
+ break;
647
+ }
648
+ console.error("Error reading from stream:", e);
649
+ break;
650
+ }
651
+ const { done, value } = readResult;
652
+ if (done) {
653
+ break;
654
+ }
655
+ const chunk = decoder.decode(value, { stream: true });
656
+ buffer += chunk;
657
+ let lineEnd = buffer.indexOf("\n");
658
+ while (lineEnd !== -1) {
659
+ const line = buffer.substring(0, lineEnd).trim();
660
+ buffer = buffer.substring(lineEnd + 1);
661
+ if (line === "data: [DONE]") {
662
+ continue;
663
+ }
664
+ if (line.startsWith("data: ")) {
665
+ const data = line.slice(6).trim();
666
+ if (!data) continue;
667
+ try {
668
+ const parsed = JSON.parse(data);
669
+ yield parsed;
670
+ } catch (e) {
671
+ console.error("Error parsing JSON:", data, e);
672
+ }
673
+ }
674
+ lineEnd = buffer.indexOf("\n");
675
+ }
676
+ }
677
+ if (buffer.trim()) {
678
+ const lines = buffer.trim().split("\n");
679
+ for (const line of lines) {
680
+ if (line.startsWith("data: ") && line !== "data: [DONE]") {
681
+ const data = line.slice(6).trim();
682
+ if (!data) continue;
683
+ try {
684
+ const parsed = JSON.parse(data);
685
+ yield parsed;
686
+ } catch (e) {
687
+ console.error("Error parsing final JSON:", data, e);
688
+ }
689
+ }
690
+ }
691
+ }
692
+ } catch (e) {
693
+ console.error("Unexpected error in stream processing:", e);
694
+ } finally {
695
+ try {
696
+ reader.releaseLock();
697
+ } catch (e) {
698
+ console.error("Error releasing reader lock:", e);
699
+ }
700
+ }
701
+ })();
702
+ }
703
+ function streamCompletion(stream, signal) {
704
+ return createStreamProcessor(stream, signal);
705
+ }
706
+ async function callGPT5ResponsesAPI(modelProfile, opts, signal) {
707
+ const baseURL = modelProfile?.baseURL || "https://api.openai.com/v1";
708
+ const apiKey = modelProfile?.apiKey;
709
+ const proxy = getGlobalConfig().proxy ? new ProxyAgent(getGlobalConfig().proxy) : void 0;
710
+ const headers = {
711
+ "Content-Type": "application/json",
712
+ Authorization: `Bearer ${apiKey}`
713
+ };
714
+ const responsesParams = {
715
+ model: opts.model,
716
+ input: opts.messages
717
+ // Responses API uses 'input' instead of 'messages'
718
+ };
719
+ if (opts.max_completion_tokens) {
720
+ responsesParams.max_completion_tokens = opts.max_completion_tokens;
721
+ } else if (opts.max_tokens) {
722
+ responsesParams.max_completion_tokens = opts.max_tokens;
723
+ }
724
+ if (opts.temperature === 1) {
725
+ responsesParams.temperature = 1;
726
+ }
727
+ const reasoningEffort = opts.reasoning_effort || "medium";
728
+ responsesParams.reasoning = {
729
+ effort: reasoningEffort,
730
+ // 🚀 Enable reasoning summaries for transparency in coding tasks
731
+ generate_summary: true
732
+ };
733
+ if (opts.tools && opts.tools.length > 0) {
734
+ responsesParams.tools = opts.tools;
735
+ if (opts.tool_choice) {
736
+ responsesParams.tool_choice = opts.tool_choice;
737
+ }
738
+ }
739
+ const systemMessages = opts.messages.filter((msg) => msg.role === "system");
740
+ const nonSystemMessages = opts.messages.filter((msg) => msg.role !== "system");
741
+ if (systemMessages.length > 0) {
742
+ responsesParams.instructions = systemMessages.map((msg) => msg.content).join("\n\n");
743
+ responsesParams.input = nonSystemMessages;
744
+ }
745
+ const features = getModelFeatures(opts.model);
746
+ if (features.supportsVerbosityControl) {
747
+ responsesParams.text = {
748
+ verbosity: "high"
749
+ };
750
+ }
751
+ if (opts.model.startsWith("gpt-5")) {
752
+ if (!responsesParams.reasoning) {
753
+ responsesParams.reasoning = {
754
+ effort: "medium"
755
+ // Balanced for most coding tasks
756
+ };
757
+ }
758
+ if (!responsesParams.instructions) {
759
+ responsesParams.instructions = `You are an expert programmer working in a terminal-based coding environment. Follow these guidelines:
760
+ - Provide clear, concise code solutions
761
+ - Use proper error handling and validation
762
+ - Follow coding best practices and patterns
763
+ - Explain complex logic when necessary
764
+ - Focus on maintainable, readable code`;
765
+ }
766
+ }
767
+ try {
768
+ const response = await fetch(`${baseURL}/responses`, {
769
+ method: "POST",
770
+ headers,
771
+ body: JSON.stringify(responsesParams),
772
+ dispatcher: proxy,
773
+ signal
774
+ });
775
+ if (!response.ok) {
776
+ throw new Error(`GPT-5 Responses API error: ${response.status} ${response.statusText}`);
777
+ }
778
+ const responseData = await response.json();
779
+ return convertResponsesAPIToChatCompletion(responseData);
780
+ } catch (error) {
781
+ if (signal?.aborted) {
782
+ throw new Error("Request cancelled by user");
783
+ }
784
+ throw error;
785
+ }
786
+ }
787
+ function convertResponsesAPIToChatCompletion(responsesData) {
788
+ let outputText = responsesData.output_text || "";
789
+ const usage = responsesData.usage || {};
790
+ if (responsesData.output && Array.isArray(responsesData.output)) {
791
+ const reasoningItems = responsesData.output.filter((item) => item.type === "reasoning" && item.summary);
792
+ const messageItems = responsesData.output.filter((item) => item.type === "message");
793
+ if (reasoningItems.length > 0 && messageItems.length > 0) {
794
+ const reasoningSummary = reasoningItems.map((item) => item.summary?.map((s) => s.text).join("\n")).filter(Boolean).join("\n\n");
795
+ const mainContent = messageItems.map((item) => item.content?.map((c) => c.text).join("\n")).filter(Boolean).join("\n\n");
796
+ if (reasoningSummary) {
797
+ outputText = `**\u{1F9E0} Reasoning Process:**
798
+ ${reasoningSummary}
799
+
800
+ **\u{1F4DD} Response:**
801
+ ${mainContent}`;
802
+ } else {
803
+ outputText = mainContent;
804
+ }
805
+ }
806
+ }
807
+ return {
808
+ id: responsesData.id || `chatcmpl-${Date.now()}`,
809
+ object: "chat.completion",
810
+ created: Math.floor(Date.now() / 1e3),
811
+ model: responsesData.model || "",
812
+ choices: [
813
+ {
814
+ index: 0,
815
+ message: {
816
+ role: "assistant",
817
+ content: outputText,
818
+ // 🚀 Include reasoning metadata if available
819
+ ...responsesData.reasoning && {
820
+ reasoning: {
821
+ effort: responsesData.reasoning.effort,
822
+ summary: responsesData.reasoning.summary
823
+ }
824
+ }
825
+ },
826
+ finish_reason: responsesData.status === "completed" ? "stop" : "length"
827
+ }
828
+ ],
829
+ usage: {
830
+ prompt_tokens: usage.input_tokens || 0,
831
+ completion_tokens: usage.output_tokens || 0,
832
+ total_tokens: (usage.input_tokens || 0) + (usage.output_tokens || 0),
833
+ // 🔧 GPT-5 Enhanced Usage Details
834
+ prompt_tokens_details: {
835
+ cached_tokens: usage.input_tokens_details?.cached_tokens || 0
836
+ },
837
+ completion_tokens_details: {
838
+ reasoning_tokens: usage.output_tokens_details?.reasoning_tokens || 0
839
+ }
840
+ }
841
+ };
842
+ }
843
+ async function getGPT5CompletionWithProfile(modelProfile, opts, attempt = 0, maxAttempts = 10, signal) {
844
+ const features = getModelFeatures(opts.model);
845
+ const isOfficialOpenAI = !modelProfile.baseURL || modelProfile.baseURL.includes("api.openai.com");
846
+ if (features.supportsResponsesAPI && !opts.stream && isOfficialOpenAI) {
847
+ try {
848
+ debugLogger.api("ATTEMPTING_GPT5_RESPONSES_API", {
849
+ model: opts.model,
850
+ baseURL: modelProfile.baseURL || "official",
851
+ provider: modelProfile.provider,
852
+ stream: opts.stream,
853
+ requestId: getCurrentRequest()?.id
854
+ });
855
+ const result = await callGPT5ResponsesAPI(modelProfile, opts, signal);
856
+ debugLogger.api("GPT5_RESPONSES_API_SUCCESS", {
857
+ model: opts.model,
858
+ baseURL: modelProfile.baseURL || "official",
859
+ requestId: getCurrentRequest()?.id
860
+ });
861
+ return result;
862
+ } catch (error) {
863
+ debugLogger.api("GPT5_RESPONSES_API_FALLBACK", {
864
+ model: opts.model,
865
+ error: error.message,
866
+ baseURL: modelProfile.baseURL || "official",
867
+ requestId: getCurrentRequest()?.id
868
+ });
869
+ console.warn(
870
+ `\u{1F504} GPT-5 Responses API failed, falling back to Chat Completions: ${error.message}`
871
+ );
872
+ }
873
+ } else if (!isOfficialOpenAI) {
874
+ debugLogger.api("GPT5_THIRD_PARTY_PROVIDER", {
875
+ model: opts.model,
876
+ baseURL: modelProfile.baseURL,
877
+ provider: modelProfile.provider,
878
+ supportsResponsesAPI: features.supportsResponsesAPI,
879
+ requestId: getCurrentRequest()?.id
880
+ });
881
+ console.log(`\u{1F310} Using GPT-5 via third-party provider: ${modelProfile.provider} (${modelProfile.baseURL})`);
882
+ if (modelProfile.provider === "azure") {
883
+ delete opts.reasoning_effort;
884
+ } else if (modelProfile.provider === "custom-openai") {
885
+ console.log(`\u{1F527} Applying OpenAI-compatible optimizations for custom provider`);
886
+ }
887
+ } else if (opts.stream) {
888
+ debugLogger.api("GPT5_STREAMING_MODE", {
889
+ model: opts.model,
890
+ baseURL: modelProfile.baseURL || "official",
891
+ reason: "responses_api_no_streaming",
892
+ requestId: getCurrentRequest()?.id
893
+ });
894
+ console.log(`\u{1F504} Using Chat Completions for streaming (Responses API streaming not available)`);
895
+ }
896
+ debugLogger.api("USING_CHAT_COMPLETIONS_FOR_GPT5", {
897
+ model: opts.model,
898
+ baseURL: modelProfile.baseURL || "official",
899
+ provider: modelProfile.provider,
900
+ reason: isOfficialOpenAI ? "streaming_or_fallback" : "third_party_provider",
901
+ requestId: getCurrentRequest()?.id
902
+ });
903
+ return await getCompletionWithProfile(
904
+ modelProfile,
905
+ opts,
906
+ attempt,
907
+ maxAttempts,
908
+ signal
909
+ );
910
+ }
911
+ async function fetchCustomModels(baseURL, apiKey) {
912
+ try {
913
+ const hasVersionNumber = /\/v\d+/.test(baseURL);
914
+ const cleanBaseURL = baseURL.replace(/\/+$/, "");
915
+ const modelsURL = hasVersionNumber ? `${cleanBaseURL}/models` : `${cleanBaseURL}/v1/models`;
916
+ const response = await fetch(modelsURL, {
917
+ method: "GET",
918
+ headers: {
919
+ Authorization: `Bearer ${apiKey}`,
920
+ "Content-Type": "application/json"
921
+ }
922
+ });
923
+ if (!response.ok) {
924
+ if (response.status === 401) {
925
+ throw new Error(
926
+ "Invalid API key. Please check your API key and try again."
927
+ );
928
+ } else if (response.status === 403) {
929
+ throw new Error(
930
+ "API key does not have permission to access models. Please check your API key permissions."
931
+ );
932
+ } else if (response.status === 404) {
933
+ throw new Error(
934
+ "API endpoint not found. Please check if the base URL is correct and supports the /models endpoint."
935
+ );
936
+ } else if (response.status === 429) {
937
+ throw new Error(
938
+ "Too many requests. Please wait a moment and try again."
939
+ );
940
+ } else if (response.status >= 500) {
941
+ throw new Error(
942
+ "API service is temporarily unavailable. Please try again later."
943
+ );
944
+ } else {
945
+ throw new Error(
946
+ `Unable to connect to API (${response.status}). Please check your base URL, API key, and internet connection.`
947
+ );
948
+ }
949
+ }
950
+ const data = await response.json();
951
+ const hasDataArray = (obj) => {
952
+ return typeof obj === "object" && obj !== null && "data" in obj && Array.isArray(obj.data);
953
+ };
954
+ const hasModelsArray = (obj) => {
955
+ return typeof obj === "object" && obj !== null && "models" in obj && Array.isArray(obj.models);
956
+ };
957
+ let models = [];
958
+ if (hasDataArray(data)) {
959
+ models = data.data;
960
+ } else if (Array.isArray(data)) {
961
+ models = data;
962
+ } else if (hasModelsArray(data)) {
963
+ models = data.models;
964
+ } else {
965
+ throw new Error(
966
+ 'API returned unexpected response format. Expected an array of models or an object with a "data" or "models" array.'
967
+ );
968
+ }
969
+ if (!Array.isArray(models)) {
970
+ throw new Error("API response format error: models data is not an array.");
971
+ }
972
+ return models;
973
+ } catch (error) {
974
+ if (error instanceof Error && (error.message.includes("API key") || error.message.includes("API endpoint") || error.message.includes("API service") || error.message.includes("response format"))) {
975
+ throw error;
976
+ }
977
+ console.error("Failed to fetch custom API models:", error);
978
+ if (error instanceof Error && error.message.includes("fetch")) {
979
+ throw new Error(
980
+ "Unable to connect to the API. Please check the base URL and your internet connection."
981
+ );
982
+ }
983
+ throw new Error(
984
+ "Failed to fetch models from custom API. Please check your configuration and try again."
985
+ );
986
+ }
987
+ }
988
+ export {
989
+ applyModelSpecificTransformations,
990
+ callGPT5ResponsesAPI,
991
+ createStreamProcessor,
992
+ fetchCustomModels,
993
+ getCompletionWithProfile,
994
+ getGPT5CompletionWithProfile,
995
+ getModelFeatures,
996
+ streamCompletion
997
+ };
998
+ //# sourceMappingURL=openai.js.map