indusagi 0.12.19 → 0.12.21

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 (518) hide show
  1. package/README.md +16 -36
  2. package/dist/agent/agent-loop.d.ts +3 -9
  3. package/dist/agent/agent-loop.d.ts.map +1 -1
  4. package/dist/agent/agent-loop.js +19 -58
  5. package/dist/agent/agent-loop.js.map +1 -1
  6. package/dist/agent/agent.d.ts +9 -10
  7. package/dist/agent/agent.d.ts.map +1 -1
  8. package/dist/agent/agent.js +182 -129
  9. package/dist/agent/agent.js.map +1 -1
  10. package/dist/agent/error-handler.d.ts.map +1 -1
  11. package/dist/agent/error-handler.js.map +1 -1
  12. package/dist/agent/event-bus.d.ts.map +1 -1
  13. package/dist/agent/event-bus.js +1 -3
  14. package/dist/agent/event-bus.js.map +1 -1
  15. package/dist/agent/index.d.ts.map +1 -1
  16. package/dist/agent/index.js +0 -6
  17. package/dist/agent/index.js.map +1 -1
  18. package/dist/agent/messages.d.ts +1 -1
  19. package/dist/agent/messages.d.ts.map +1 -1
  20. package/dist/agent/proxy.d.ts +1 -14
  21. package/dist/agent/proxy.d.ts.map +1 -1
  22. package/dist/agent/proxy.js +67 -148
  23. package/dist/agent/proxy.js.map +1 -1
  24. package/dist/agent/session-manager.d.ts +10 -10
  25. package/dist/agent/session-manager.d.ts.map +1 -1
  26. package/dist/agent/session-manager.js +20 -16
  27. package/dist/agent/session-manager.js.map +1 -1
  28. package/dist/agent/state-manager.d.ts +1 -1
  29. package/dist/agent/state-manager.d.ts.map +1 -1
  30. package/dist/agent/state-manager.js +1 -0
  31. package/dist/agent/state-manager.js.map +1 -1
  32. package/dist/agent/telemetry.d.ts.map +1 -1
  33. package/dist/agent/telemetry.js +1 -3
  34. package/dist/agent/telemetry.js.map +1 -1
  35. package/dist/agent/tools/bash.d.ts.map +1 -1
  36. package/dist/agent/tools/bash.js +143 -118
  37. package/dist/agent/tools/bash.js.map +1 -1
  38. package/dist/agent/tools/edit-diff.d.ts +1 -1
  39. package/dist/agent/tools/edit-diff.d.ts.map +1 -1
  40. package/dist/agent/tools/edit-diff.js +189 -175
  41. package/dist/agent/tools/edit-diff.js.map +1 -1
  42. package/dist/agent/tools/edit.d.ts.map +1 -1
  43. package/dist/agent/tools/edit.js +137 -121
  44. package/dist/agent/tools/edit.js.map +1 -1
  45. package/dist/agent/tools/find.d.ts.map +1 -1
  46. package/dist/agent/tools/find.js +100 -65
  47. package/dist/agent/tools/find.js.map +1 -1
  48. package/dist/agent/tools/grep.d.ts.map +1 -1
  49. package/dist/agent/tools/grep.js +126 -97
  50. package/dist/agent/tools/grep.js.map +1 -1
  51. package/dist/agent/tools/index.d.ts +53 -40
  52. package/dist/agent/tools/index.d.ts.map +1 -1
  53. package/dist/agent/tools/index.js +19 -12
  54. package/dist/agent/tools/index.js.map +1 -1
  55. package/dist/agent/tools/ls.d.ts +2 -1
  56. package/dist/agent/tools/ls.d.ts.map +1 -1
  57. package/dist/agent/tools/ls.js +145 -94
  58. package/dist/agent/tools/ls.js.map +1 -1
  59. package/dist/agent/tools/path-utils.d.ts.map +1 -1
  60. package/dist/agent/tools/path-utils.js +48 -29
  61. package/dist/agent/tools/path-utils.js.map +1 -1
  62. package/dist/agent/tools/process-controller.d.ts +15 -0
  63. package/dist/agent/tools/process-controller.d.ts.map +1 -0
  64. package/dist/agent/tools/process-controller.js +39 -0
  65. package/dist/agent/tools/process-controller.js.map +1 -0
  66. package/dist/agent/tools/process-manager.d.ts +60 -0
  67. package/dist/agent/tools/process-manager.d.ts.map +1 -0
  68. package/dist/agent/tools/process-manager.js +485 -0
  69. package/dist/agent/tools/process-manager.js.map +1 -0
  70. package/dist/agent/tools/process-types.d.ts +74 -0
  71. package/dist/agent/tools/process-types.d.ts.map +1 -0
  72. package/dist/agent/tools/process-types.js +7 -0
  73. package/dist/agent/tools/process-types.js.map +1 -0
  74. package/dist/agent/tools/process.d.ts +38 -0
  75. package/dist/agent/tools/process.d.ts.map +1 -0
  76. package/dist/agent/tools/process.js +360 -0
  77. package/dist/agent/tools/process.js.map +1 -0
  78. package/dist/agent/tools/read.d.ts.map +1 -1
  79. package/dist/agent/tools/read.js +157 -135
  80. package/dist/agent/tools/read.js.map +1 -1
  81. package/dist/agent/tools/registry.js +2 -4
  82. package/dist/agent/tools/registry.js.map +1 -1
  83. package/dist/agent/tools/teams/activity-tracker.d.ts +66 -0
  84. package/dist/agent/tools/teams/activity-tracker.d.ts.map +1 -0
  85. package/dist/agent/tools/teams/activity-tracker.js +480 -0
  86. package/dist/agent/tools/teams/activity-tracker.js.map +1 -0
  87. package/dist/agent/tools/teams/cleanup.d.ts +51 -0
  88. package/dist/agent/tools/teams/cleanup.d.ts.map +1 -0
  89. package/dist/agent/tools/teams/cleanup.js +219 -0
  90. package/dist/agent/tools/teams/cleanup.js.map +1 -0
  91. package/dist/agent/tools/teams/fs-lock.d.ts +12 -0
  92. package/dist/agent/tools/teams/fs-lock.d.ts.map +1 -0
  93. package/dist/agent/tools/teams/fs-lock.js +74 -0
  94. package/dist/agent/tools/teams/fs-lock.js.map +1 -0
  95. package/dist/agent/tools/teams/index.d.ts +12 -0
  96. package/dist/agent/tools/teams/index.d.ts.map +1 -0
  97. package/dist/agent/tools/teams/index.js +12 -0
  98. package/dist/agent/tools/teams/index.js.map +1 -0
  99. package/dist/agent/tools/teams/mailbox.d.ts +21 -0
  100. package/dist/agent/tools/teams/mailbox.d.ts.map +1 -0
  101. package/dist/agent/tools/teams/mailbox.js +106 -0
  102. package/dist/agent/tools/teams/mailbox.js.map +1 -0
  103. package/dist/agent/tools/teams/model-policy.d.ts +23 -0
  104. package/dist/agent/tools/teams/model-policy.d.ts.map +1 -0
  105. package/dist/agent/tools/teams/model-policy.js +113 -0
  106. package/dist/agent/tools/teams/model-policy.js.map +1 -0
  107. package/dist/agent/tools/teams/names.d.ts +28 -0
  108. package/dist/agent/tools/teams/names.d.ts.map +1 -0
  109. package/dist/agent/tools/teams/names.js +109 -0
  110. package/dist/agent/tools/teams/names.js.map +1 -0
  111. package/dist/agent/tools/teams/protocol.d.ts +75 -0
  112. package/dist/agent/tools/teams/protocol.d.ts.map +1 -0
  113. package/dist/agent/tools/teams/protocol.js +205 -0
  114. package/dist/agent/tools/teams/protocol.js.map +1 -0
  115. package/dist/agent/tools/teams/task-store.d.ts +89 -0
  116. package/dist/agent/tools/teams/task-store.d.ts.map +1 -0
  117. package/dist/agent/tools/teams/task-store.js +445 -0
  118. package/dist/agent/tools/teams/task-store.js.map +1 -0
  119. package/dist/agent/tools/teams/team-attach-claim.d.ts +36 -0
  120. package/dist/agent/tools/teams/team-attach-claim.d.ts.map +1 -0
  121. package/dist/agent/tools/teams/team-attach-claim.js +144 -0
  122. package/dist/agent/tools/teams/team-attach-claim.js.map +1 -0
  123. package/dist/agent/tools/teams/team-config.d.ts +55 -0
  124. package/dist/agent/tools/teams/team-config.d.ts.map +1 -0
  125. package/dist/agent/tools/teams/team-config.js +252 -0
  126. package/dist/agent/tools/teams/team-config.js.map +1 -0
  127. package/dist/agent/tools/teams/worktree.d.ts +40 -0
  128. package/dist/agent/tools/teams/worktree.d.ts.map +1 -0
  129. package/dist/agent/tools/teams/worktree.js +213 -0
  130. package/dist/agent/tools/teams/worktree.js.map +1 -0
  131. package/dist/agent/tools/todo-store.js +2 -1
  132. package/dist/agent/tools/todo-store.js.map +1 -1
  133. package/dist/agent/tools/todo.d.ts +2 -2
  134. package/dist/agent/tools/todo.js +2 -2
  135. package/dist/agent/tools/truncate.d.ts.map +1 -1
  136. package/dist/agent/tools/truncate.js +150 -134
  137. package/dist/agent/tools/truncate.js.map +1 -1
  138. package/dist/agent/tools/utils/hook-runner.d.ts +9 -10
  139. package/dist/agent/tools/utils/hook-runner.d.ts.map +1 -1
  140. package/dist/agent/tools/utils/hook-runner.js +18 -16
  141. package/dist/agent/tools/utils/hook-runner.js.map +1 -1
  142. package/dist/agent/tools/utils/image-resize.d.ts +1 -14
  143. package/dist/agent/tools/utils/image-resize.d.ts.map +1 -1
  144. package/dist/agent/tools/utils/image-resize.js +80 -34
  145. package/dist/agent/tools/utils/image-resize.js.map +1 -1
  146. package/dist/agent/tools/utils/mime.d.ts +0 -8
  147. package/dist/agent/tools/utils/mime.d.ts.map +1 -1
  148. package/dist/agent/tools/utils/mime.js +43 -32
  149. package/dist/agent/tools/utils/mime.js.map +1 -1
  150. package/dist/agent/tools/utils/shell.d.ts +1 -23
  151. package/dist/agent/tools/utils/shell.d.ts.map +1 -1
  152. package/dist/agent/tools/utils/shell.js +43 -86
  153. package/dist/agent/tools/utils/shell.js.map +1 -1
  154. package/dist/agent/tools/write.d.ts.map +1 -1
  155. package/dist/agent/tools/write.js +105 -62
  156. package/dist/agent/tools/write.js.map +1 -1
  157. package/dist/agent/types.d.ts +69 -64
  158. package/dist/agent/types.d.ts.map +1 -1
  159. package/dist/agent/types.js +38 -23
  160. package/dist/agent/types.js.map +1 -1
  161. package/dist/agent.d.ts +4 -0
  162. package/dist/agent.d.ts.map +1 -1
  163. package/dist/agent.js +4 -0
  164. package/dist/agent.js.map +1 -1
  165. package/dist/ai/api-registry.d.ts.map +1 -1
  166. package/dist/ai/api-registry.js +3 -4
  167. package/dist/ai/api-registry.js.map +1 -1
  168. package/dist/ai/cli.js +62 -82
  169. package/dist/ai/cli.js.map +1 -1
  170. package/dist/ai/env-api-keys.d.ts.map +1 -1
  171. package/dist/ai/env-api-keys.js +78 -81
  172. package/dist/ai/env-api-keys.js.map +1 -1
  173. package/dist/ai/index.d.ts +6 -0
  174. package/dist/ai/index.d.ts.map +1 -1
  175. package/dist/ai/index.js +6 -0
  176. package/dist/ai/index.js.map +1 -1
  177. package/dist/ai/models.d.ts +7 -17
  178. package/dist/ai/models.d.ts.map +1 -1
  179. package/dist/ai/models.generated.d.ts +19 -0
  180. package/dist/ai/models.generated.d.ts.map +1 -1
  181. package/dist/ai/models.generated.js +14 -2
  182. package/dist/ai/models.generated.js.map +1 -1
  183. package/dist/ai/models.js +17 -11
  184. package/dist/ai/models.js.map +1 -1
  185. package/dist/ai/providers/amazon-bedrock.d.ts.map +1 -1
  186. package/dist/ai/providers/amazon-bedrock.js +319 -248
  187. package/dist/ai/providers/amazon-bedrock.js.map +1 -1
  188. package/dist/ai/providers/anthropic.d.ts.map +1 -1
  189. package/dist/ai/providers/anthropic.js +378 -324
  190. package/dist/ai/providers/anthropic.js.map +1 -1
  191. package/dist/ai/providers/azure-openai-responses.d.ts.map +1 -1
  192. package/dist/ai/providers/azure-openai-responses.js +164 -123
  193. package/dist/ai/providers/azure-openai-responses.js.map +1 -1
  194. package/dist/ai/providers/google-shared.d.ts +0 -18
  195. package/dist/ai/providers/google-shared.d.ts.map +1 -1
  196. package/dist/ai/providers/google-shared.js +224 -225
  197. package/dist/ai/providers/google-shared.js.map +1 -1
  198. package/dist/ai/providers/google-vertex.d.ts.map +1 -1
  199. package/dist/ai/providers/google-vertex.js +244 -226
  200. package/dist/ai/providers/google-vertex.js.map +1 -1
  201. package/dist/ai/providers/google.d.ts +3 -0
  202. package/dist/ai/providers/google.d.ts.map +1 -1
  203. package/dist/ai/providers/google.js +232 -210
  204. package/dist/ai/providers/google.js.map +1 -1
  205. package/dist/ai/providers/kimi.js +1 -0
  206. package/dist/ai/providers/kimi.js.map +1 -1
  207. package/dist/ai/providers/mock.d.ts +10 -0
  208. package/dist/ai/providers/mock.d.ts.map +1 -0
  209. package/dist/ai/providers/mock.js +64 -0
  210. package/dist/ai/providers/mock.js.map +1 -0
  211. package/dist/ai/providers/openai-codex-responses.d.ts.map +1 -1
  212. package/dist/ai/providers/openai-codex-responses.js +178 -133
  213. package/dist/ai/providers/openai-codex-responses.js.map +1 -1
  214. package/dist/ai/providers/openai-completions.d.ts.map +1 -1
  215. package/dist/ai/providers/openai-completions.js +468 -387
  216. package/dist/ai/providers/openai-completions.js.map +1 -1
  217. package/dist/ai/providers/openai-responses-shared.d.ts.map +1 -1
  218. package/dist/ai/providers/openai-responses-shared.js +187 -166
  219. package/dist/ai/providers/openai-responses-shared.js.map +1 -1
  220. package/dist/ai/providers/openai-responses.d.ts.map +1 -1
  221. package/dist/ai/providers/openai-responses.js +108 -85
  222. package/dist/ai/providers/openai-responses.js.map +1 -1
  223. package/dist/ai/providers/openai-scaffold.d.ts +4 -0
  224. package/dist/ai/providers/openai-scaffold.d.ts.map +1 -0
  225. package/dist/ai/providers/openai-scaffold.js +33 -0
  226. package/dist/ai/providers/openai-scaffold.js.map +1 -0
  227. package/dist/ai/providers/register-builtins.d.ts.map +1 -1
  228. package/dist/ai/providers/register-builtins.js +109 -42
  229. package/dist/ai/providers/register-builtins.js.map +1 -1
  230. package/dist/ai/providers/simple-options.js +2 -0
  231. package/dist/ai/providers/simple-options.js.map +1 -1
  232. package/dist/ai/providers/transform-messages.js +3 -9
  233. package/dist/ai/providers/transform-messages.js.map +1 -1
  234. package/dist/ai/stream.d.ts +4 -14
  235. package/dist/ai/stream.d.ts.map +1 -1
  236. package/dist/ai/stream.js +0 -36
  237. package/dist/ai/stream.js.map +1 -1
  238. package/dist/ai/types.d.ts +22 -3
  239. package/dist/ai/types.d.ts.map +1 -1
  240. package/dist/ai/types.js +154 -77
  241. package/dist/ai/types.js.map +1 -1
  242. package/dist/ai/utils/base-stream-handler.js +1 -0
  243. package/dist/ai/utils/base-stream-handler.js.map +1 -1
  244. package/dist/ai/utils/event-stream.d.ts +2 -0
  245. package/dist/ai/utils/event-stream.d.ts.map +1 -1
  246. package/dist/ai/utils/event-stream.js +22 -5
  247. package/dist/ai/utils/event-stream.js.map +1 -1
  248. package/dist/ai/utils/json-parse.d.ts +3 -0
  249. package/dist/ai/utils/json-parse.d.ts.map +1 -1
  250. package/dist/ai/utils/json-parse.js +8 -5
  251. package/dist/ai/utils/json-parse.js.map +1 -1
  252. package/dist/ai/utils/oauth/anthropic.d.ts.map +1 -1
  253. package/dist/ai/utils/oauth/anthropic.js +110 -65
  254. package/dist/ai/utils/oauth/anthropic.js.map +1 -1
  255. package/dist/ai/utils/oauth/github-copilot.d.ts +8 -16
  256. package/dist/ai/utils/oauth/github-copilot.d.ts.map +1 -1
  257. package/dist/ai/utils/oauth/github-copilot.js +218 -227
  258. package/dist/ai/utils/oauth/github-copilot.js.map +1 -1
  259. package/dist/ai/utils/oauth/openai-codex.d.ts +4 -2
  260. package/dist/ai/utils/oauth/openai-codex.d.ts.map +1 -1
  261. package/dist/ai/utils/oauth/openai-codex.js +221 -236
  262. package/dist/ai/utils/oauth/openai-codex.js.map +1 -1
  263. package/dist/ai/utils/oauth/pkce.d.ts +6 -5
  264. package/dist/ai/utils/oauth/pkce.d.ts.map +1 -1
  265. package/dist/ai/utils/oauth/pkce.js +24 -21
  266. package/dist/ai/utils/oauth/pkce.js.map +1 -1
  267. package/dist/ai/utils/oauth/types.d.ts +31 -12
  268. package/dist/ai/utils/oauth/types.d.ts.map +1 -1
  269. package/dist/ai/utils/oauth/types.js +10 -1
  270. package/dist/ai/utils/oauth/types.js.map +1 -1
  271. package/dist/ai/utils/overflow.d.ts.map +1 -1
  272. package/dist/ai/utils/overflow.js +49 -21
  273. package/dist/ai/utils/overflow.js.map +1 -1
  274. package/dist/ai/utils/provider-adapter.js +9 -0
  275. package/dist/ai/utils/provider-adapter.js.map +1 -1
  276. package/dist/ai/utils/provider-client-builder.js +1 -1
  277. package/dist/ai/utils/provider-client-builder.js.map +1 -1
  278. package/dist/ai/utils/provider-errors.js +2 -0
  279. package/dist/ai/utils/provider-errors.js.map +1 -1
  280. package/dist/ai/utils/sanitize-unicode.d.ts +0 -20
  281. package/dist/ai/utils/sanitize-unicode.d.ts.map +1 -1
  282. package/dist/ai/utils/sanitize-unicode.js +35 -17
  283. package/dist/ai/utils/sanitize-unicode.js.map +1 -1
  284. package/dist/ai/utils/stream-event-helper.js +3 -0
  285. package/dist/ai/utils/stream-event-helper.js.map +1 -1
  286. package/dist/ai/utils/stream-handler-types.js +5 -0
  287. package/dist/ai/utils/stream-handler-types.js.map +1 -1
  288. package/dist/ai/utils/streaming-state-manager.js +4 -2
  289. package/dist/ai/utils/streaming-state-manager.js.map +1 -1
  290. package/dist/ai/utils/typebox-helpers.d.ts +6 -4
  291. package/dist/ai/utils/typebox-helpers.d.ts.map +1 -1
  292. package/dist/ai/utils/typebox-helpers.js +25 -7
  293. package/dist/ai/utils/typebox-helpers.js.map +1 -1
  294. package/dist/ai/utils/validation.d.ts.map +1 -1
  295. package/dist/ai/utils/validation.js +67 -34
  296. package/dist/ai/utils/validation.js.map +1 -1
  297. package/dist/ai.d.ts +4 -0
  298. package/dist/ai.d.ts.map +1 -1
  299. package/dist/ai.js +4 -0
  300. package/dist/ai.js.map +1 -1
  301. package/dist/cli.d.ts +3 -0
  302. package/dist/cli.d.ts.map +1 -0
  303. package/dist/cli.js +3 -0
  304. package/dist/cli.js.map +1 -0
  305. package/dist/index.d.ts +1 -0
  306. package/dist/index.d.ts.map +1 -1
  307. package/dist/index.js +1 -0
  308. package/dist/index.js.map +1 -1
  309. package/dist/mcp/client-pool.js +3 -2
  310. package/dist/mcp/client-pool.js.map +1 -1
  311. package/dist/mcp/client.js +19 -6
  312. package/dist/mcp/client.js.map +1 -1
  313. package/dist/mcp/config.d.ts +6 -6
  314. package/dist/mcp/config.js +17 -17
  315. package/dist/mcp/config.js.map +1 -1
  316. package/dist/mcp/errors.js +8 -0
  317. package/dist/mcp/errors.js.map +1 -1
  318. package/dist/mcp/index.d.ts +5 -5
  319. package/dist/mcp/index.js +5 -5
  320. package/dist/mcp/schema-converter.d.ts +1 -1
  321. package/dist/mcp/schema-converter.js +1 -1
  322. package/dist/mcp/server.d.ts +4 -4
  323. package/dist/mcp/server.js +12 -7
  324. package/dist/mcp/server.js.map +1 -1
  325. package/dist/mcp/tool-factory.d.ts +2 -2
  326. package/dist/mcp/tool-factory.js +2 -2
  327. package/dist/mcp.d.ts +0 -4
  328. package/dist/mcp.d.ts.map +1 -1
  329. package/dist/mcp.js +0 -4
  330. package/dist/mcp.js.map +1 -1
  331. package/dist/observability.d.ts +2 -0
  332. package/dist/observability.d.ts.map +1 -0
  333. package/dist/observability.js +2 -0
  334. package/dist/observability.js.map +1 -0
  335. package/dist/tui/autocomplete.d.ts +14 -18
  336. package/dist/tui/autocomplete.d.ts.map +1 -1
  337. package/dist/tui/autocomplete.js +290 -402
  338. package/dist/tui/autocomplete.js.map +1 -1
  339. package/dist/tui/components/box.d.ts +1 -6
  340. package/dist/tui/components/box.d.ts.map +1 -1
  341. package/dist/tui/components/box.js +98 -67
  342. package/dist/tui/components/box.js.map +1 -1
  343. package/dist/tui/components/cancellable-loader.d.ts +6 -3
  344. package/dist/tui/components/cancellable-loader.d.ts.map +1 -1
  345. package/dist/tui/components/cancellable-loader.js +8 -9
  346. package/dist/tui/components/cancellable-loader.js.map +1 -1
  347. package/dist/tui/components/editor.d.ts +18 -0
  348. package/dist/tui/components/editor.d.ts.map +1 -1
  349. package/dist/tui/components/editor.js +356 -354
  350. package/dist/tui/components/editor.js.map +1 -1
  351. package/dist/tui/components/image.d.ts +2 -0
  352. package/dist/tui/components/image.d.ts.map +1 -1
  353. package/dist/tui/components/image.js +79 -37
  354. package/dist/tui/components/image.js.map +1 -1
  355. package/dist/tui/components/input.d.ts +4 -8
  356. package/dist/tui/components/input.d.ts.map +1 -1
  357. package/dist/tui/components/input.js +236 -232
  358. package/dist/tui/components/input.js.map +1 -1
  359. package/dist/tui/components/loader.d.ts +5 -5
  360. package/dist/tui/components/loader.d.ts.map +1 -1
  361. package/dist/tui/components/loader.js +22 -19
  362. package/dist/tui/components/loader.js.map +1 -1
  363. package/dist/tui/components/markdown.d.ts +2 -32
  364. package/dist/tui/components/markdown.d.ts.map +1 -1
  365. package/dist/tui/components/markdown.js +338 -357
  366. package/dist/tui/components/markdown.js.map +1 -1
  367. package/dist/tui/components/select-list.d.ts +1 -0
  368. package/dist/tui/components/select-list.d.ts.map +1 -1
  369. package/dist/tui/components/select-list.js +83 -82
  370. package/dist/tui/components/select-list.js.map +1 -1
  371. package/dist/tui/components/settings-list.d.ts +10 -10
  372. package/dist/tui/components/settings-list.d.ts.map +1 -1
  373. package/dist/tui/components/settings-list.js +48 -40
  374. package/dist/tui/components/settings-list.js.map +1 -1
  375. package/dist/tui/components/spacer.d.ts +1 -0
  376. package/dist/tui/components/spacer.d.ts.map +1 -1
  377. package/dist/tui/components/spacer.js +20 -5
  378. package/dist/tui/components/spacer.js.map +1 -1
  379. package/dist/tui/components/text.d.ts.map +1 -1
  380. package/dist/tui/components/text.js +47 -20
  381. package/dist/tui/components/text.js.map +1 -1
  382. package/dist/tui/components/truncated-text.d.ts +8 -4
  383. package/dist/tui/components/truncated-text.d.ts.map +1 -1
  384. package/dist/tui/components/truncated-text.js +15 -12
  385. package/dist/tui/components/truncated-text.js.map +1 -1
  386. package/dist/tui/editor-component.d.ts +87 -23
  387. package/dist/tui/editor-component.d.ts.map +1 -1
  388. package/dist/tui/fuzzy.d.ts.map +1 -1
  389. package/dist/tui/fuzzy.js +101 -50
  390. package/dist/tui/fuzzy.js.map +1 -1
  391. package/dist/tui/keybindings.d.ts +3 -3
  392. package/dist/tui/keybindings.d.ts.map +1 -1
  393. package/dist/tui/keybindings.js +137 -111
  394. package/dist/tui/keybindings.js.map +1 -1
  395. package/dist/tui/keys.d.ts +46 -43
  396. package/dist/tui/keys.d.ts.map +1 -1
  397. package/dist/tui/keys.js +493 -411
  398. package/dist/tui/keys.js.map +1 -1
  399. package/dist/tui/stdin-buffer.d.ts.map +1 -1
  400. package/dist/tui/stdin-buffer.js +162 -159
  401. package/dist/tui/stdin-buffer.js.map +1 -1
  402. package/dist/tui/terminal-image.d.ts +10 -5
  403. package/dist/tui/terminal-image.d.ts.map +1 -1
  404. package/dist/tui/terminal-image.js +53 -51
  405. package/dist/tui/terminal-image.js.map +1 -1
  406. package/dist/tui/terminal.d.ts +4 -27
  407. package/dist/tui/terminal.d.ts.map +1 -1
  408. package/dist/tui/terminal.js +123 -121
  409. package/dist/tui/terminal.js.map +1 -1
  410. package/dist/tui/tui.d.ts +14 -1
  411. package/dist/tui/tui.d.ts.map +1 -1
  412. package/dist/tui/tui.js +185 -145
  413. package/dist/tui/tui.js.map +1 -1
  414. package/dist/tui/utils.d.ts.map +1 -1
  415. package/dist/tui/utils.js +235 -216
  416. package/dist/tui/utils.js.map +1 -1
  417. package/dist/tui.d.ts +4 -0
  418. package/dist/tui.d.ts.map +1 -1
  419. package/dist/tui.js +4 -0
  420. package/dist/tui.js.map +1 -1
  421. package/package.json +23 -43
  422. package/LICENSE.md +0 -22
  423. package/dist/agent/tools/task-types.d.ts +0 -74
  424. package/dist/agent/tools/task-types.d.ts.map +0 -1
  425. package/dist/agent/tools/task-types.js +0 -8
  426. package/dist/agent/tools/task-types.js.map +0 -1
  427. package/dist/agent/tools/task.d.ts +0 -84
  428. package/dist/agent/tools/task.d.ts.map +0 -1
  429. package/dist/agent/tools/task.js +0 -184
  430. package/dist/agent/tools/task.js.map +0 -1
  431. package/dist/memory/embedder/base.d.ts +0 -41
  432. package/dist/memory/embedder/base.d.ts.map +0 -1
  433. package/dist/memory/embedder/base.js +0 -10
  434. package/dist/memory/embedder/base.js.map +0 -1
  435. package/dist/memory/embedder/index.d.ts +0 -8
  436. package/dist/memory/embedder/index.d.ts.map +0 -1
  437. package/dist/memory/embedder/index.js +0 -6
  438. package/dist/memory/embedder/index.js.map +0 -1
  439. package/dist/memory/embedder/openai.d.ts +0 -35
  440. package/dist/memory/embedder/openai.d.ts.map +0 -1
  441. package/dist/memory/embedder/openai.js +0 -103
  442. package/dist/memory/embedder/openai.js.map +0 -1
  443. package/dist/memory/index.d.ts +0 -33
  444. package/dist/memory/index.d.ts.map +0 -1
  445. package/dist/memory/index.js +0 -31
  446. package/dist/memory/index.js.map +0 -1
  447. package/dist/memory/memory.d.ts +0 -126
  448. package/dist/memory/memory.d.ts.map +0 -1
  449. package/dist/memory/memory.js +0 -280
  450. package/dist/memory/memory.js.map +0 -1
  451. package/dist/memory/processors/base.d.ts +0 -42
  452. package/dist/memory/processors/base.d.ts.map +0 -1
  453. package/dist/memory/processors/base.js +0 -6
  454. package/dist/memory/processors/base.js.map +0 -1
  455. package/dist/memory/processors/index.d.ts +0 -16
  456. package/dist/memory/processors/index.d.ts.map +0 -1
  457. package/dist/memory/processors/index.js +0 -18
  458. package/dist/memory/processors/index.js.map +0 -1
  459. package/dist/memory/processors/message-history.d.ts +0 -35
  460. package/dist/memory/processors/message-history.d.ts.map +0 -1
  461. package/dist/memory/processors/message-history.js +0 -51
  462. package/dist/memory/processors/message-history.js.map +0 -1
  463. package/dist/memory/processors/observational-memory/index.d.ts +0 -82
  464. package/dist/memory/processors/observational-memory/index.d.ts.map +0 -1
  465. package/dist/memory/processors/observational-memory/index.js +0 -234
  466. package/dist/memory/processors/observational-memory/index.js.map +0 -1
  467. package/dist/memory/processors/observational-memory/observer-agent.d.ts +0 -64
  468. package/dist/memory/processors/observational-memory/observer-agent.d.ts.map +0 -1
  469. package/dist/memory/processors/observational-memory/observer-agent.js +0 -362
  470. package/dist/memory/processors/observational-memory/observer-agent.js.map +0 -1
  471. package/dist/memory/processors/observational-memory/reflector-agent.d.ts +0 -38
  472. package/dist/memory/processors/observational-memory/reflector-agent.d.ts.map +0 -1
  473. package/dist/memory/processors/observational-memory/reflector-agent.js +0 -213
  474. package/dist/memory/processors/observational-memory/reflector-agent.js.map +0 -1
  475. package/dist/memory/processors/observational-memory/token-counter.d.ts +0 -35
  476. package/dist/memory/processors/observational-memory/token-counter.d.ts.map +0 -1
  477. package/dist/memory/processors/observational-memory/token-counter.js +0 -90
  478. package/dist/memory/processors/observational-memory/token-counter.js.map +0 -1
  479. package/dist/memory/processors/semantic-recall.d.ts +0 -55
  480. package/dist/memory/processors/semantic-recall.d.ts.map +0 -1
  481. package/dist/memory/processors/semantic-recall.js +0 -143
  482. package/dist/memory/processors/semantic-recall.js.map +0 -1
  483. package/dist/memory/processors/working-memory.d.ts +0 -41
  484. package/dist/memory/processors/working-memory.d.ts.map +0 -1
  485. package/dist/memory/processors/working-memory.js +0 -82
  486. package/dist/memory/processors/working-memory.js.map +0 -1
  487. package/dist/memory/storage/base.d.ts +0 -288
  488. package/dist/memory/storage/base.d.ts.map +0 -1
  489. package/dist/memory/storage/base.js +0 -211
  490. package/dist/memory/storage/base.js.map +0 -1
  491. package/dist/memory/storage/index.d.ts +0 -9
  492. package/dist/memory/storage/index.d.ts.map +0 -1
  493. package/dist/memory/storage/index.js +0 -7
  494. package/dist/memory/storage/index.js.map +0 -1
  495. package/dist/memory/storage/inmemory.d.ts +0 -93
  496. package/dist/memory/storage/inmemory.d.ts.map +0 -1
  497. package/dist/memory/storage/inmemory.js +0 -646
  498. package/dist/memory/storage/inmemory.js.map +0 -1
  499. package/dist/memory/tools/working-memory.d.ts +0 -100
  500. package/dist/memory/tools/working-memory.d.ts.map +0 -1
  501. package/dist/memory/tools/working-memory.js +0 -237
  502. package/dist/memory/tools/working-memory.js.map +0 -1
  503. package/dist/memory/types.d.ts +0 -386
  504. package/dist/memory/types.d.ts.map +0 -1
  505. package/dist/memory/types.js +0 -58
  506. package/dist/memory/types.js.map +0 -1
  507. package/dist/memory/vector/base.d.ts +0 -145
  508. package/dist/memory/vector/base.d.ts.map +0 -1
  509. package/dist/memory/vector/base.js +0 -83
  510. package/dist/memory/vector/base.js.map +0 -1
  511. package/dist/memory/vector/index.d.ts +0 -8
  512. package/dist/memory/vector/index.d.ts.map +0 -1
  513. package/dist/memory/vector/index.js +0 -7
  514. package/dist/memory/vector/index.js.map +0 -1
  515. package/dist/memory/vector/inmemory.d.ts +0 -47
  516. package/dist/memory/vector/inmemory.d.ts.map +0 -1
  517. package/dist/memory/vector/inmemory.js +0 -234
  518. package/dist/memory/vector/inmemory.js.map +0 -1
@@ -10,41 +10,48 @@ import { parseStreamingJson } from "../utils/json-parse.js";
10
10
  import { sanitizeSurrogates } from "../utils/sanitize-unicode.js";
11
11
  import { adjustMaxTokensForThinking, buildBaseOptions, executeWithRetry, } from "./simple-options.js";
12
12
  import { transformMessages } from "./transform-messages.js";
13
- // Stealth mode: Mimic Claude Code's tool naming exactly
14
- const claudeCodeVersion = "2.1.2";
15
- // Claude Code 2.x tool names (canonical casing)
16
- // Source: https://cchistory.mariozechner.at/data/prompts-2.1.11.md
17
- // To update: https://github.com/badlogic/cchistory
18
- const claudeCodeTools = [
19
- "Read",
20
- "Write",
21
- "Edit",
22
- "Bash",
23
- "Grep",
24
- "Glob",
25
- "AskUserQuestion",
26
- "EnterPlanMode",
27
- "ExitPlanMode",
28
- "KillShell",
29
- "NotebookEdit",
30
- "Skill",
31
- "Task",
32
- "TaskOutput",
33
- "TodoWrite",
34
- "WebFetch",
35
- "WebSearch",
36
- ];
37
- const ccToolLookup = new Map(claudeCodeTools.map((t) => [t.toLowerCase(), t]));
38
- // Convert tool name to CC canonical casing if it matches (case-insensitive)
39
- const toClaudeCodeName = (name) => ccToolLookup.get(name.toLowerCase()) ?? name;
40
- const fromClaudeCodeName = (name, tools) => {
41
- if (tools && tools.length > 0) {
42
- const lowerName = name.toLowerCase();
43
- const matchedTool = tools.find((tool) => tool.name.toLowerCase() === lowerName);
44
- if (matchedTool)
45
- return matchedTool.name;
46
- }
47
- return name;
13
+ const ClaudeCodeNameCodec = {
14
+ version: "2.1.2",
15
+ canonicalToolNames: [
16
+ "Read",
17
+ "Write",
18
+ "Edit",
19
+ "Bash",
20
+ "Grep",
21
+ "Glob",
22
+ "AskUserQuestion",
23
+ "EnterPlanMode",
24
+ "ExitPlanMode",
25
+ "KillShell",
26
+ "NotebookEdit",
27
+ "Skill",
28
+ "Task",
29
+ "TaskOutput",
30
+ "TodoWrite",
31
+ "WebFetch",
32
+ "WebSearch",
33
+ ],
34
+ lookup: undefined,
35
+ ensureLookup() {
36
+ if (!this.lookup) {
37
+ this.lookup = new Map(this.canonicalToolNames.map((toolName) => [toolName.toLowerCase(), toolName]));
38
+ }
39
+ return this.lookup;
40
+ },
41
+ encode(name) {
42
+ const lookup = this.ensureLookup();
43
+ return lookup.get(name.toLowerCase()) ?? name;
44
+ },
45
+ decode(name, tools) {
46
+ if (tools && tools.length > 0) {
47
+ const lowerName = name.toLowerCase();
48
+ const matchedTool = tools.find((tool) => tool.name.toLowerCase() === lowerName);
49
+ if (matchedTool) {
50
+ return matchedTool.name;
51
+ }
52
+ }
53
+ return name;
54
+ },
48
55
  };
49
56
  /**
50
57
  * Convert content blocks to Anthropic API format
@@ -89,6 +96,10 @@ function convertContentBlocks(content) {
89
96
  * Anthropic-specific `MessageCreateParamsStreaming`.
90
97
  */
91
98
  export class AnthropicRequestBuilder {
99
+ model;
100
+ context;
101
+ isOAuthToken;
102
+ options;
92
103
  constructor(model, context, isOAuthToken, options) {
93
104
  this.model = model;
94
105
  this.context = context;
@@ -119,6 +130,7 @@ function mergeHeaders(...headerSources) {
119
130
  * Wraps the Anthropic SDK streaming API and emits standardized assistant events.
120
131
  */
121
132
  export class AnthropicStreamHandler extends BaseStreamHandler {
133
+ executeFn;
122
134
  constructor(executeFn) {
123
135
  super();
124
136
  this.executeFn = executeFn;
@@ -141,6 +153,173 @@ export class AnthropicStreamHandler extends BaseStreamHandler {
141
153
  onEvent(event);
142
154
  }
143
155
  }
156
+ class AnthropicEventReducer {
157
+ blocks;
158
+ output;
159
+ stream;
160
+ model;
161
+ contextTools;
162
+ oauthMode;
163
+ handlers;
164
+ constructor(blocks, output, stream, model, contextTools, oauthMode) {
165
+ this.blocks = blocks;
166
+ this.output = output;
167
+ this.stream = stream;
168
+ this.model = model;
169
+ this.contextTools = contextTools;
170
+ this.oauthMode = oauthMode;
171
+ this.handlers = {
172
+ message_start: (event) => this.onMessageStart(event),
173
+ content_block_start: (event) => this.onContentBlockStart(event),
174
+ content_block_delta: (event) => this.onContentBlockDelta(event),
175
+ content_block_stop: (event) => this.onContentBlockStop(event),
176
+ message_delta: (event) => this.onMessageDelta(event),
177
+ };
178
+ }
179
+ reduce(event) {
180
+ const handler = this.handlers[event.type];
181
+ if (handler) {
182
+ handler(event);
183
+ }
184
+ }
185
+ onMessageStart(event) {
186
+ this.updateUsage(event?.message?.usage);
187
+ }
188
+ onContentBlockStart(event) {
189
+ if (event.content_block.type === "text") {
190
+ const block = {
191
+ type: "text",
192
+ text: "",
193
+ index: event.index,
194
+ };
195
+ this.output.content.push(block);
196
+ this.stream.push({ type: "text_start", contentIndex: this.output.content.length - 1, partial: this.output });
197
+ return;
198
+ }
199
+ if (event.content_block.type === "thinking") {
200
+ const block = {
201
+ type: "thinking",
202
+ thinking: "",
203
+ thinkingSignature: "",
204
+ index: event.index,
205
+ };
206
+ this.output.content.push(block);
207
+ this.stream.push({ type: "thinking_start", contentIndex: this.output.content.length - 1, partial: this.output });
208
+ return;
209
+ }
210
+ if (event.content_block.type === "tool_use") {
211
+ const decodedName = this.oauthMode
212
+ ? ClaudeCodeNameCodec.decode(event.content_block.name, this.contextTools)
213
+ : event.content_block.name;
214
+ const block = {
215
+ type: "toolCall",
216
+ id: event.content_block.id,
217
+ name: decodedName,
218
+ arguments: event.content_block.input,
219
+ partialJson: "",
220
+ index: event.index,
221
+ };
222
+ this.output.content.push(block);
223
+ this.stream.push({ type: "toolcall_start", contentIndex: this.output.content.length - 1, partial: this.output });
224
+ }
225
+ }
226
+ onContentBlockDelta(event) {
227
+ const blockIndex = this.blocks.findIndex((block) => block.index === event.index);
228
+ const block = this.blocks[blockIndex];
229
+ if (!block) {
230
+ return;
231
+ }
232
+ if (event.delta.type === "text_delta" && block.type === "text") {
233
+ block.text += event.delta.text;
234
+ this.stream.push({
235
+ type: "text_delta",
236
+ contentIndex: blockIndex,
237
+ delta: event.delta.text,
238
+ partial: this.output,
239
+ });
240
+ return;
241
+ }
242
+ if (event.delta.type === "thinking_delta" && block.type === "thinking") {
243
+ block.thinking += event.delta.thinking;
244
+ this.stream.push({
245
+ type: "thinking_delta",
246
+ contentIndex: blockIndex,
247
+ delta: event.delta.thinking,
248
+ partial: this.output,
249
+ });
250
+ return;
251
+ }
252
+ if (event.delta.type === "input_json_delta" && block.type === "toolCall") {
253
+ block.partialJson += event.delta.partial_json;
254
+ block.arguments = parseStreamingJson(block.partialJson);
255
+ this.stream.push({
256
+ type: "toolcall_delta",
257
+ contentIndex: blockIndex,
258
+ delta: event.delta.partial_json,
259
+ partial: this.output,
260
+ });
261
+ return;
262
+ }
263
+ if (event.delta.type === "signature_delta" && block.type === "thinking") {
264
+ block.thinkingSignature = block.thinkingSignature || "";
265
+ block.thinkingSignature += event.delta.signature;
266
+ }
267
+ }
268
+ onContentBlockStop(event) {
269
+ const blockIndex = this.blocks.findIndex((block) => block.index === event.index);
270
+ const block = this.blocks[blockIndex];
271
+ if (!block) {
272
+ return;
273
+ }
274
+ delete block.index;
275
+ if (block.type === "text") {
276
+ this.stream.push({
277
+ type: "text_end",
278
+ contentIndex: blockIndex,
279
+ content: block.text,
280
+ partial: this.output,
281
+ });
282
+ return;
283
+ }
284
+ if (block.type === "thinking") {
285
+ this.stream.push({
286
+ type: "thinking_end",
287
+ contentIndex: blockIndex,
288
+ content: block.thinking,
289
+ partial: this.output,
290
+ });
291
+ return;
292
+ }
293
+ if (block.type === "toolCall") {
294
+ block.arguments = parseStreamingJson(block.partialJson);
295
+ delete block.partialJson;
296
+ this.stream.push({
297
+ type: "toolcall_end",
298
+ contentIndex: blockIndex,
299
+ toolCall: block,
300
+ partial: this.output,
301
+ });
302
+ }
303
+ }
304
+ onMessageDelta(event) {
305
+ if (event.delta.stop_reason) {
306
+ this.output.stopReason = mapProviderStopReason(event.delta.stop_reason, "anthropic");
307
+ }
308
+ this.updateUsage(event.usage);
309
+ }
310
+ updateUsage(usage) {
311
+ if (!usage) {
312
+ return;
313
+ }
314
+ this.output.usage.input = usage.input_tokens || 0;
315
+ this.output.usage.output = usage.output_tokens || 0;
316
+ this.output.usage.cacheRead = usage.cache_read_input_tokens || 0;
317
+ this.output.usage.cacheWrite = usage.cache_creation_input_tokens || 0;
318
+ this.output.usage.totalTokens =
319
+ this.output.usage.input + this.output.usage.output + this.output.usage.cacheRead + this.output.usage.cacheWrite;
320
+ calculateCost(this.model, this.output.usage);
321
+ }
322
+ }
144
323
  export const streamAnthropic = (model, context, options) => {
145
324
  const stream = new AssistantMessageEventStream();
146
325
  const output = createAssistantMessageOutput(model);
@@ -154,152 +333,11 @@ export const streamAnthropic = (model, context, options) => {
154
333
  events.start();
155
334
  const blocks = output.content;
156
335
  const streamHandler = new AnthropicStreamHandler();
336
+ const reducer = new AnthropicEventReducer(blocks, output, stream, model, context.tools, isOAuthToken);
157
337
  await executeWithRetry(async () => {
158
338
  const anthropicStream = client.messages.stream({ ...params, stream: true }, { signal: options?.signal });
159
339
  await streamHandler.process(anthropicStream, (event) => {
160
- if (event.type === "message_start") {
161
- // Capture initial token usage from message_start event
162
- // This ensures we have input token counts even if the stream is aborted early
163
- output.usage.input = event.message.usage.input_tokens || 0;
164
- output.usage.output = event.message.usage.output_tokens || 0;
165
- output.usage.cacheRead = event.message.usage.cache_read_input_tokens || 0;
166
- output.usage.cacheWrite = event.message.usage.cache_creation_input_tokens || 0;
167
- // Anthropic doesn't provide total_tokens, compute from components
168
- output.usage.totalTokens =
169
- output.usage.input + output.usage.output + output.usage.cacheRead + output.usage.cacheWrite;
170
- calculateCost(model, output.usage);
171
- }
172
- else if (event.type === "content_block_start") {
173
- if (event.content_block.type === "text") {
174
- const block = {
175
- type: "text",
176
- text: "",
177
- index: event.index,
178
- };
179
- output.content.push(block);
180
- stream.push({ type: "text_start", contentIndex: output.content.length - 1, partial: output });
181
- }
182
- else if (event.content_block.type === "thinking") {
183
- const block = {
184
- type: "thinking",
185
- thinking: "",
186
- thinkingSignature: "",
187
- index: event.index,
188
- };
189
- output.content.push(block);
190
- stream.push({ type: "thinking_start", contentIndex: output.content.length - 1, partial: output });
191
- }
192
- else if (event.content_block.type === "tool_use") {
193
- const block = {
194
- type: "toolCall",
195
- id: event.content_block.id,
196
- name: isOAuthToken
197
- ? fromClaudeCodeName(event.content_block.name, context.tools)
198
- : event.content_block.name,
199
- arguments: event.content_block.input,
200
- partialJson: "",
201
- index: event.index,
202
- };
203
- output.content.push(block);
204
- stream.push({ type: "toolcall_start", contentIndex: output.content.length - 1, partial: output });
205
- }
206
- }
207
- else if (event.type === "content_block_delta") {
208
- if (event.delta.type === "text_delta") {
209
- const index = blocks.findIndex((b) => b.index === event.index);
210
- const block = blocks[index];
211
- if (block && block.type === "text") {
212
- block.text += event.delta.text;
213
- stream.push({
214
- type: "text_delta",
215
- contentIndex: index,
216
- delta: event.delta.text,
217
- partial: output,
218
- });
219
- }
220
- }
221
- else if (event.delta.type === "thinking_delta") {
222
- const index = blocks.findIndex((b) => b.index === event.index);
223
- const block = blocks[index];
224
- if (block && block.type === "thinking") {
225
- block.thinking += event.delta.thinking;
226
- stream.push({
227
- type: "thinking_delta",
228
- contentIndex: index,
229
- delta: event.delta.thinking,
230
- partial: output,
231
- });
232
- }
233
- }
234
- else if (event.delta.type === "input_json_delta") {
235
- const index = blocks.findIndex((b) => b.index === event.index);
236
- const block = blocks[index];
237
- if (block && block.type === "toolCall") {
238
- block.partialJson += event.delta.partial_json;
239
- block.arguments = parseStreamingJson(block.partialJson);
240
- stream.push({
241
- type: "toolcall_delta",
242
- contentIndex: index,
243
- delta: event.delta.partial_json,
244
- partial: output,
245
- });
246
- }
247
- }
248
- else if (event.delta.type === "signature_delta") {
249
- const index = blocks.findIndex((b) => b.index === event.index);
250
- const block = blocks[index];
251
- if (block && block.type === "thinking") {
252
- block.thinkingSignature = block.thinkingSignature || "";
253
- block.thinkingSignature += event.delta.signature;
254
- }
255
- }
256
- }
257
- else if (event.type === "content_block_stop") {
258
- const index = blocks.findIndex((b) => b.index === event.index);
259
- const block = blocks[index];
260
- if (block) {
261
- delete block.index;
262
- if (block.type === "text") {
263
- stream.push({
264
- type: "text_end",
265
- contentIndex: index,
266
- content: block.text,
267
- partial: output,
268
- });
269
- }
270
- else if (block.type === "thinking") {
271
- stream.push({
272
- type: "thinking_end",
273
- contentIndex: index,
274
- content: block.thinking,
275
- partial: output,
276
- });
277
- }
278
- else if (block.type === "toolCall") {
279
- block.arguments = parseStreamingJson(block.partialJson);
280
- delete block.partialJson;
281
- stream.push({
282
- type: "toolcall_end",
283
- contentIndex: index,
284
- toolCall: block,
285
- partial: output,
286
- });
287
- }
288
- }
289
- }
290
- else if (event.type === "message_delta") {
291
- if (event.delta.stop_reason) {
292
- output.stopReason = mapProviderStopReason(event.delta.stop_reason, "anthropic");
293
- }
294
- output.usage.input = event.usage.input_tokens || 0;
295
- output.usage.output = event.usage.output_tokens || 0;
296
- output.usage.cacheRead = event.usage.cache_read_input_tokens || 0;
297
- output.usage.cacheWrite = event.usage.cache_creation_input_tokens || 0;
298
- // Anthropic doesn't provide total_tokens, compute from components
299
- output.usage.totalTokens =
300
- output.usage.input + output.usage.output + output.usage.cacheRead + output.usage.cacheWrite;
301
- calculateCost(model, output.usage);
302
- }
340
+ reducer.reduce(event);
303
341
  });
304
342
  }, {
305
343
  maxAttempts: options?.signal ? 1 : 3,
@@ -358,7 +396,7 @@ function createClient(model, apiKey, interleavedThinking, optionsHeaders) {
358
396
  accept: "application/json",
359
397
  "anthropic-dangerous-direct-browser-access": "true",
360
398
  "anthropic-beta": `claude-code-20250219,oauth-2025-04-20,${betaFeatures.join(",")}`,
361
- "user-agent": `claude-cli/${claudeCodeVersion} (external, cli)`,
399
+ "user-agent": `claude-cli/${ClaudeCodeNameCodec.version} (external, cli)`,
362
400
  "x-app": "cli",
363
401
  }, model.headers, optionsHeaders);
364
402
  const client = new Anthropic({
@@ -446,164 +484,182 @@ function buildParams(model, context, isOAuthToken, options) {
446
484
  return params;
447
485
  }
448
486
  // Normalize tool call IDs to match Anthropic's required pattern and length
449
- function convertMessages(messages, model, isOAuthToken) {
450
- const params = [];
451
- // Transform messages for cross-provider compatibility
452
- const transformedMessages = transformMessages(messages, model, normalizeToolCallId);
453
- for (let i = 0; i < transformedMessages.length; i++) {
454
- const msg = transformedMessages[i];
455
- if (msg.role === "user") {
456
- if (typeof msg.content === "string") {
457
- if (msg.content.trim().length > 0) {
458
- params.push({
459
- role: "user",
460
- content: sanitizeSurrogates(msg.content),
461
- });
462
- }
487
+ class AnthropicMessageComposer {
488
+ model;
489
+ oauthMode;
490
+ constructor(model, oauthMode) {
491
+ this.model = model;
492
+ this.oauthMode = oauthMode;
493
+ }
494
+ compose(messages) {
495
+ const params = [];
496
+ const transformedMessages = transformMessages(messages, this.model, normalizeToolCallId);
497
+ for (let i = 0; i < transformedMessages.length; i++) {
498
+ const message = transformedMessages[i];
499
+ if (message.role === "user") {
500
+ const userParam = this.composeUserMessage(message);
501
+ if (userParam)
502
+ params.push(userParam);
503
+ continue;
463
504
  }
464
- else {
465
- const blocks = msg.content.map((item) => {
466
- if (item.type === "text") {
467
- return {
468
- type: "text",
469
- text: sanitizeSurrogates(item.text),
470
- };
471
- }
472
- else {
473
- return {
474
- type: "image",
475
- source: {
476
- type: "base64",
477
- media_type: item.mimeType,
478
- data: item.data,
479
- },
480
- };
481
- }
482
- });
483
- let filteredBlocks = !model?.input.includes("image") ? blocks.filter((b) => b.type !== "image") : blocks;
484
- filteredBlocks = filteredBlocks.filter((b) => {
485
- if (b.type === "text") {
486
- return b.text.trim().length > 0;
487
- }
488
- return true;
489
- });
490
- if (filteredBlocks.length === 0)
491
- continue;
492
- params.push({
493
- role: "user",
494
- content: filteredBlocks,
495
- });
505
+ if (message.role === "assistant") {
506
+ const assistantParam = this.composeAssistantMessage(message);
507
+ if (assistantParam)
508
+ params.push(assistantParam);
509
+ continue;
496
510
  }
511
+ const groupedToolResults = this.composeToolResultBatch(transformedMessages, i);
512
+ params.push(groupedToolResults.param);
513
+ i = groupedToolResults.nextIndex;
497
514
  }
498
- else if (msg.role === "assistant") {
499
- const blocks = [];
500
- for (const block of msg.content) {
501
- if (block.type === "text") {
502
- if (block.text.trim().length === 0)
503
- continue;
504
- blocks.push({
505
- type: "text",
506
- text: sanitizeSurrogates(block.text),
507
- });
508
- }
509
- else if (block.type === "thinking") {
510
- if (block.thinking.trim().length === 0)
511
- continue;
512
- // If thinking signature is missing/empty (e.g., from aborted stream),
513
- // convert to plain text block without <thinking> tags to avoid API rejection
514
- // and prevent Claude from mimicking the tags in responses
515
- if (!block.thinkingSignature || block.thinkingSignature.trim().length === 0) {
516
- blocks.push({
517
- type: "text",
518
- text: sanitizeSurrogates(block.thinking),
519
- });
520
- }
521
- else {
522
- blocks.push({
523
- type: "thinking",
524
- thinking: sanitizeSurrogates(block.thinking),
525
- signature: block.thinkingSignature,
526
- });
527
- }
515
+ applyCacheControlToLatestUserMessage(params);
516
+ return params;
517
+ }
518
+ composeUserMessage(message) {
519
+ if (typeof message.content === "string") {
520
+ if (message.content.trim().length === 0) {
521
+ return undefined;
522
+ }
523
+ return {
524
+ role: "user",
525
+ content: sanitizeSurrogates(message.content),
526
+ };
527
+ }
528
+ const blocks = message.content.map((item) => {
529
+ if (item.type === "text") {
530
+ return {
531
+ type: "text",
532
+ text: sanitizeSurrogates(item.text),
533
+ };
534
+ }
535
+ return {
536
+ type: "image",
537
+ source: {
538
+ type: "base64",
539
+ media_type: item.mimeType,
540
+ data: item.data,
541
+ },
542
+ };
543
+ });
544
+ let filteredBlocks = !this.model?.input.includes("image") ? blocks.filter((block) => block.type !== "image") : blocks;
545
+ filteredBlocks = filteredBlocks.filter((block) => (block.type === "text" ? block.text.trim().length > 0 : true));
546
+ if (filteredBlocks.length === 0) {
547
+ return undefined;
548
+ }
549
+ return {
550
+ role: "user",
551
+ content: filteredBlocks,
552
+ };
553
+ }
554
+ composeAssistantMessage(message) {
555
+ const blocks = [];
556
+ for (const block of message.content) {
557
+ if (block.type === "text") {
558
+ if (block.text.trim().length === 0)
559
+ continue;
560
+ blocks.push({ type: "text", text: sanitizeSurrogates(block.text) });
561
+ continue;
562
+ }
563
+ if (block.type === "thinking") {
564
+ if (block.thinking.trim().length === 0)
565
+ continue;
566
+ if (!block.thinkingSignature || block.thinkingSignature.trim().length === 0) {
567
+ blocks.push({ type: "text", text: sanitizeSurrogates(block.thinking) });
528
568
  }
529
- else if (block.type === "toolCall") {
569
+ else {
530
570
  blocks.push({
531
- type: "tool_use",
532
- id: block.id,
533
- name: isOAuthToken ? toClaudeCodeName(block.name) : block.name,
534
- input: block.arguments,
571
+ type: "thinking",
572
+ thinking: sanitizeSurrogates(block.thinking),
573
+ signature: block.thinkingSignature,
535
574
  });
536
575
  }
537
- }
538
- if (blocks.length === 0)
539
576
  continue;
540
- params.push({
541
- role: "assistant",
542
- content: blocks,
543
- });
577
+ }
578
+ if (block.type === "toolCall") {
579
+ blocks.push({
580
+ type: "tool_use",
581
+ id: block.id,
582
+ name: this.oauthMode ? ClaudeCodeNameCodec.encode(block.name) : block.name,
583
+ input: block.arguments,
584
+ });
585
+ }
586
+ }
587
+ if (blocks.length === 0) {
588
+ return undefined;
544
589
  }
545
- else if (msg.role === "toolResult") {
546
- // Collect all consecutive toolResult messages, needed for z.ai Anthropic endpoint
547
- const toolResults = [];
548
- // Add the current tool result
590
+ return {
591
+ role: "assistant",
592
+ content: blocks,
593
+ };
594
+ }
595
+ composeToolResultBatch(messages, startIndex) {
596
+ const toolResults = [];
597
+ const first = messages[startIndex];
598
+ toolResults.push({
599
+ type: "tool_result",
600
+ tool_use_id: first.toolCallId,
601
+ content: convertContentBlocks(first.content),
602
+ is_error: first.isError,
603
+ });
604
+ let cursor = startIndex + 1;
605
+ while (cursor < messages.length && messages[cursor].role === "toolResult") {
606
+ const next = messages[cursor];
549
607
  toolResults.push({
550
608
  type: "tool_result",
551
- tool_use_id: msg.toolCallId,
552
- content: convertContentBlocks(msg.content),
553
- is_error: msg.isError,
554
- });
555
- // Look ahead for consecutive toolResult messages
556
- let j = i + 1;
557
- while (j < transformedMessages.length && transformedMessages[j].role === "toolResult") {
558
- const nextMsg = transformedMessages[j]; // We know it's a toolResult
559
- toolResults.push({
560
- type: "tool_result",
561
- tool_use_id: nextMsg.toolCallId,
562
- content: convertContentBlocks(nextMsg.content),
563
- is_error: nextMsg.isError,
564
- });
565
- j++;
566
- }
567
- // Skip the messages we've already processed
568
- i = j - 1;
569
- // Add a single user message with all tool results
570
- params.push({
571
- role: "user",
572
- content: toolResults,
609
+ tool_use_id: next.toolCallId,
610
+ content: convertContentBlocks(next.content),
611
+ is_error: next.isError,
573
612
  });
613
+ cursor++;
574
614
  }
615
+ return {
616
+ param: { role: "user", content: toolResults },
617
+ nextIndex: cursor - 1,
618
+ };
575
619
  }
576
- // Add cache_control to the last user message to cache conversation history
577
- if (params.length > 0) {
578
- const lastMessage = params[params.length - 1];
579
- if (lastMessage.role === "user") {
580
- // Add cache control to the last content block
581
- if (Array.isArray(lastMessage.content)) {
582
- const lastBlock = lastMessage.content[lastMessage.content.length - 1];
583
- if (lastBlock &&
584
- (lastBlock.type === "text" || lastBlock.type === "image" || lastBlock.type === "tool_result")) {
585
- lastBlock.cache_control = { type: "ephemeral" };
586
- }
587
- }
588
- }
620
+ }
621
+ class AnthropicToolMapper {
622
+ oauthMode;
623
+ constructor(oauthMode) {
624
+ this.oauthMode = oauthMode;
589
625
  }
590
- return params;
626
+ map(tools) {
627
+ if (!tools)
628
+ return [];
629
+ return tools.map((tool) => {
630
+ const jsonSchema = tool.parameters;
631
+ return {
632
+ name: this.oauthMode ? ClaudeCodeNameCodec.encode(tool.name) : tool.name,
633
+ description: tool.description,
634
+ input_schema: {
635
+ type: "object",
636
+ properties: jsonSchema.properties || {},
637
+ required: jsonSchema.required || [],
638
+ },
639
+ };
640
+ });
641
+ }
642
+ }
643
+ function applyCacheControlToLatestUserMessage(params) {
644
+ if (params.length === 0)
645
+ return;
646
+ const lastMessage = params[params.length - 1];
647
+ if (lastMessage.role !== "user")
648
+ return;
649
+ if (!Array.isArray(lastMessage.content))
650
+ return;
651
+ const lastBlock = lastMessage.content[lastMessage.content.length - 1];
652
+ if (!lastBlock)
653
+ return;
654
+ if (lastBlock.type === "text" || lastBlock.type === "image" || lastBlock.type === "tool_result") {
655
+ lastBlock.cache_control = { type: "ephemeral" };
656
+ }
657
+ }
658
+ function convertMessages(messages, model, isOAuthToken) {
659
+ return new AnthropicMessageComposer(model, isOAuthToken).compose(messages);
591
660
  }
592
661
  function convertTools(tools, isOAuthToken) {
593
- if (!tools)
594
- return [];
595
- return tools.map((tool) => {
596
- const jsonSchema = tool.parameters; // TypeBox already generates JSON Schema
597
- return {
598
- name: isOAuthToken ? toClaudeCodeName(tool.name) : tool.name,
599
- description: tool.description,
600
- input_schema: {
601
- type: "object",
602
- properties: jsonSchema.properties || {},
603
- required: jsonSchema.required || [],
604
- },
605
- };
606
- });
662
+ return new AnthropicToolMapper(isOAuthToken).map(tools);
607
663
  }
608
664
  function mapStopReason(reason) {
609
665
  switch (reason) {
@@ -619,10 +675,8 @@ function mapStopReason(reason) {
619
675
  return "stop";
620
676
  case "stop_sequence":
621
677
  return "stop"; // We don't supply stop sequences, so this should never happen
622
- default: {
623
- const _exhaustive = reason;
624
- throw new Error(`Unhandled stop reason: ${_exhaustive}`);
625
- }
678
+ default:
679
+ return "stop";
626
680
  }
627
681
  }
628
682
  //# sourceMappingURL=anthropic.js.map