@gencode/agents 0.0.9 → 0.0.10

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 (451) hide show
  1. package/dist/builtin-provider-C0d7-NZt.js +66 -0
  2. package/dist/config/index.d.ts +2 -9
  3. package/dist/config/index.js +1 -9
  4. package/dist/config-DG3Q1aJ6.js +1 -0
  5. package/dist/{index-JD6Ye-N5.d.ts → index-BdfpRxFA.d.ts} +7 -8
  6. package/dist/index.d.ts +1603 -40
  7. package/dist/index.js +504 -35
  8. package/dist/provider-registry-rVbsCDN2.js +1 -0
  9. package/dist/rolldown-runtime-CNxR59P3.js +1 -0
  10. package/package.json +2 -2
  11. package/dist/bootstrap/bootstrap-layout.d.ts +0 -23
  12. package/dist/bootstrap/bootstrap-layout.d.ts.map +0 -1
  13. package/dist/bootstrap/bootstrap-layout.js +0 -151
  14. package/dist/bootstrap/bootstrap-layout.js.map +0 -1
  15. package/dist/bootstrap/bootstrap.d.ts +0 -36
  16. package/dist/bootstrap/bootstrap.d.ts.map +0 -1
  17. package/dist/bootstrap/bootstrap.js +0 -136
  18. package/dist/bootstrap/bootstrap.js.map +0 -1
  19. package/dist/bootstrap/templates/AGENTS_MD.d.ts +0 -2
  20. package/dist/bootstrap/templates/AGENTS_MD.d.ts.map +0 -1
  21. package/dist/bootstrap/templates/AGENTS_MD.js +0 -223
  22. package/dist/bootstrap/templates/AGENTS_MD.js.map +0 -1
  23. package/dist/bootstrap/templates/BOOTSTRAP_MD.d.ts +0 -2
  24. package/dist/bootstrap/templates/BOOTSTRAP_MD.d.ts.map +0 -1
  25. package/dist/bootstrap/templates/BOOTSTRAP_MD.js +0 -66
  26. package/dist/bootstrap/templates/BOOTSTRAP_MD.js.map +0 -1
  27. package/dist/bootstrap/templates/HEARTBEAT_MD.d.ts +0 -2
  28. package/dist/bootstrap/templates/HEARTBEAT_MD.d.ts.map +0 -1
  29. package/dist/bootstrap/templates/HEARTBEAT_MD.js +0 -16
  30. package/dist/bootstrap/templates/HEARTBEAT_MD.js.map +0 -1
  31. package/dist/bootstrap/templates/IDENTITY_MD.d.ts +0 -2
  32. package/dist/bootstrap/templates/IDENTITY_MD.d.ts.map +0 -1
  33. package/dist/bootstrap/templates/IDENTITY_MD.js +0 -31
  34. package/dist/bootstrap/templates/IDENTITY_MD.js.map +0 -1
  35. package/dist/bootstrap/templates/SOUL_MD.d.ts +0 -2
  36. package/dist/bootstrap/templates/SOUL_MD.d.ts.map +0 -1
  37. package/dist/bootstrap/templates/SOUL_MD.js +0 -47
  38. package/dist/bootstrap/templates/SOUL_MD.js.map +0 -1
  39. package/dist/bootstrap/templates/TOOLS_MD.d.ts +0 -2
  40. package/dist/bootstrap/templates/TOOLS_MD.d.ts.map +0 -1
  41. package/dist/bootstrap/templates/TOOLS_MD.js +0 -51
  42. package/dist/bootstrap/templates/TOOLS_MD.js.map +0 -1
  43. package/dist/bootstrap/templates/USER_MD.d.ts +0 -2
  44. package/dist/bootstrap/templates/USER_MD.d.ts.map +0 -1
  45. package/dist/bootstrap/templates/USER_MD.js +0 -27
  46. package/dist/bootstrap/templates/USER_MD.js.map +0 -1
  47. package/dist/bootstrap/templates/index.d.ts +0 -3
  48. package/dist/bootstrap/templates/index.d.ts.map +0 -1
  49. package/dist/bootstrap/templates/index.js +0 -26
  50. package/dist/bootstrap/templates/index.js.map +0 -1
  51. package/dist/commands/compact.d.ts +0 -28
  52. package/dist/commands/compact.d.ts.map +0 -1
  53. package/dist/commands/compact.js +0 -57
  54. package/dist/commands/compact.js.map +0 -1
  55. package/dist/commands/help.d.ts +0 -3
  56. package/dist/commands/help.d.ts.map +0 -1
  57. package/dist/commands/help.js +0 -50
  58. package/dist/commands/help.js.map +0 -1
  59. package/dist/commands/index.d.ts +0 -6
  60. package/dist/commands/index.d.ts.map +0 -1
  61. package/dist/commands/index.js +0 -32
  62. package/dist/commands/index.js.map +0 -1
  63. package/dist/commands/new.d.ts +0 -3
  64. package/dist/commands/new.d.ts.map +0 -1
  65. package/dist/commands/new.js +0 -15
  66. package/dist/commands/new.js.map +0 -1
  67. package/dist/commands/registry.d.ts +0 -11
  68. package/dist/commands/registry.d.ts.map +0 -1
  69. package/dist/commands/registry.js +0 -122
  70. package/dist/commands/registry.js.map +0 -1
  71. package/dist/commands/reset.d.ts +0 -3
  72. package/dist/commands/reset.d.ts.map +0 -1
  73. package/dist/commands/reset.js +0 -4
  74. package/dist/commands/reset.js.map +0 -1
  75. package/dist/commands/skill.d.ts +0 -7
  76. package/dist/commands/skill.d.ts.map +0 -1
  77. package/dist/commands/skill.js +0 -23
  78. package/dist/commands/skill.js.map +0 -1
  79. package/dist/commands/types.d.ts +0 -57
  80. package/dist/commands/types.d.ts.map +0 -1
  81. package/dist/commands/types.js +0 -2
  82. package/dist/commands/types.js.map +0 -1
  83. package/dist/config/agents-config.d.ts +0 -85
  84. package/dist/config/agents-config.d.ts.map +0 -1
  85. package/dist/config/agents-config.js +0 -257
  86. package/dist/config/agents-config.js.map +0 -1
  87. package/dist/config/index.d.ts.map +0 -1
  88. package/dist/config/index.js.map +0 -1
  89. package/dist/config/types.d.ts +0 -87
  90. package/dist/config/types.d.ts.map +0 -1
  91. package/dist/config/types.js +0 -6
  92. package/dist/config/types.js.map +0 -1
  93. package/dist/config-DJX-VM7S.js +0 -198
  94. package/dist/config-DJX-VM7S.js.map +0 -1
  95. package/dist/history/compaction.d.ts +0 -42
  96. package/dist/history/compaction.d.ts.map +0 -1
  97. package/dist/history/compaction.js +0 -135
  98. package/dist/history/compaction.js.map +0 -1
  99. package/dist/history/index.d.ts +0 -57
  100. package/dist/history/index.d.ts.map +0 -1
  101. package/dist/history/index.js +0 -145
  102. package/dist/history/index.js.map +0 -1
  103. package/dist/history/limit.d.ts +0 -13
  104. package/dist/history/limit.d.ts.map +0 -1
  105. package/dist/history/limit.js +0 -32
  106. package/dist/history/limit.js.map +0 -1
  107. package/dist/history/repair.d.ts +0 -13
  108. package/dist/history/repair.d.ts.map +0 -1
  109. package/dist/history/repair.js +0 -25
  110. package/dist/history/repair.js.map +0 -1
  111. package/dist/history/token-estimate.d.ts +0 -22
  112. package/dist/history/token-estimate.d.ts.map +0 -1
  113. package/dist/history/token-estimate.js +0 -38
  114. package/dist/history/token-estimate.js.map +0 -1
  115. package/dist/index-JD6Ye-N5.d.ts.map +0 -1
  116. package/dist/index.d.ts.map +0 -1
  117. package/dist/index.js.map +0 -1
  118. package/dist/llm/client.d.ts +0 -53
  119. package/dist/llm/client.d.ts.map +0 -1
  120. package/dist/llm/client.js +0 -214
  121. package/dist/llm/client.js.map +0 -1
  122. package/dist/llm/openai-completions-compat.d.ts +0 -23
  123. package/dist/llm/openai-completions-compat.d.ts.map +0 -1
  124. package/dist/llm/openai-completions-compat.js +0 -602
  125. package/dist/llm/openai-completions-compat.js.map +0 -1
  126. package/dist/llm/openai-stream-error.d.ts +0 -11
  127. package/dist/llm/openai-stream-error.d.ts.map +0 -1
  128. package/dist/llm/openai-stream-error.js +0 -77
  129. package/dist/llm/openai-stream-error.js.map +0 -1
  130. package/dist/loop-detection/session-state.d.ts +0 -5
  131. package/dist/loop-detection/session-state.d.ts.map +0 -1
  132. package/dist/loop-detection/session-state.js +0 -16
  133. package/dist/loop-detection/session-state.js.map +0 -1
  134. package/dist/loop-detection/tool-loop-detection.d.ts +0 -122
  135. package/dist/loop-detection/tool-loop-detection.d.ts.map +0 -1
  136. package/dist/loop-detection/tool-loop-detection.js +0 -516
  137. package/dist/loop-detection/tool-loop-detection.js.map +0 -1
  138. package/dist/manager-qXa-NP0p.js +0 -1651
  139. package/dist/manager-qXa-NP0p.js.map +0 -1
  140. package/dist/memory/builtin-provider.d.ts +0 -5
  141. package/dist/memory/builtin-provider.d.ts.map +0 -1
  142. package/dist/memory/builtin-provider.js +0 -42
  143. package/dist/memory/builtin-provider.js.map +0 -1
  144. package/dist/memory/config.d.ts +0 -50
  145. package/dist/memory/config.d.ts.map +0 -1
  146. package/dist/memory/config.js +0 -46
  147. package/dist/memory/config.js.map +0 -1
  148. package/dist/memory/embedding-registry.d.ts +0 -37
  149. package/dist/memory/embedding-registry.d.ts.map +0 -1
  150. package/dist/memory/embedding-registry.js +0 -56
  151. package/dist/memory/embedding-registry.js.map +0 -1
  152. package/dist/memory/embeddings.d.ts +0 -11
  153. package/dist/memory/embeddings.d.ts.map +0 -1
  154. package/dist/memory/embeddings.js +0 -40
  155. package/dist/memory/embeddings.js.map +0 -1
  156. package/dist/memory/fs-utils.d.ts +0 -12
  157. package/dist/memory/fs-utils.d.ts.map +0 -1
  158. package/dist/memory/fs-utils.js +0 -24
  159. package/dist/memory/fs-utils.js.map +0 -1
  160. package/dist/memory/hybrid.d.ts +0 -43
  161. package/dist/memory/hybrid.d.ts.map +0 -1
  162. package/dist/memory/hybrid.js +0 -80
  163. package/dist/memory/hybrid.js.map +0 -1
  164. package/dist/memory/internal.d.ts +0 -28
  165. package/dist/memory/internal.d.ts.map +0 -1
  166. package/dist/memory/internal.js +0 -270
  167. package/dist/memory/internal.js.map +0 -1
  168. package/dist/memory/manager-search.d.ts +0 -61
  169. package/dist/memory/manager-search.d.ts.map +0 -1
  170. package/dist/memory/manager-search.js +0 -106
  171. package/dist/memory/manager-search.js.map +0 -1
  172. package/dist/memory/manager.d.ts +0 -126
  173. package/dist/memory/manager.d.ts.map +0 -1
  174. package/dist/memory/manager.js +0 -1006
  175. package/dist/memory/manager.js.map +0 -1
  176. package/dist/memory/memory-schema.d.ts +0 -11
  177. package/dist/memory/memory-schema.d.ts.map +0 -1
  178. package/dist/memory/memory-schema.js +0 -78
  179. package/dist/memory/memory-schema.js.map +0 -1
  180. package/dist/memory/memory.d.ts +0 -46
  181. package/dist/memory/memory.d.ts.map +0 -1
  182. package/dist/memory/memory.js +0 -127
  183. package/dist/memory/memory.js.map +0 -1
  184. package/dist/memory/mmr.d.ts +0 -22
  185. package/dist/memory/mmr.d.ts.map +0 -1
  186. package/dist/memory/mmr.js +0 -112
  187. package/dist/memory/mmr.js.map +0 -1
  188. package/dist/memory/provider-registry.d.ts +0 -29
  189. package/dist/memory/provider-registry.d.ts.map +0 -1
  190. package/dist/memory/provider-registry.js +0 -58
  191. package/dist/memory/provider-registry.js.map +0 -1
  192. package/dist/memory/provider.d.ts +0 -40
  193. package/dist/memory/provider.d.ts.map +0 -1
  194. package/dist/memory/provider.js +0 -2
  195. package/dist/memory/provider.js.map +0 -1
  196. package/dist/memory/session-files.d.ts +0 -13
  197. package/dist/memory/session-files.d.ts.map +0 -1
  198. package/dist/memory/session-files.js +0 -116
  199. package/dist/memory/session-files.js.map +0 -1
  200. package/dist/memory/sqlite-vec.d.ts +0 -10
  201. package/dist/memory/sqlite-vec.d.ts.map +0 -1
  202. package/dist/memory/sqlite-vec.js +0 -20
  203. package/dist/memory/sqlite-vec.js.map +0 -1
  204. package/dist/memory/sqlite.d.ts +0 -2
  205. package/dist/memory/sqlite.d.ts.map +0 -1
  206. package/dist/memory/sqlite.js +0 -12
  207. package/dist/memory/sqlite.js.map +0 -1
  208. package/dist/memory/temporal-decay.d.ts +0 -26
  209. package/dist/memory/temporal-decay.d.ts.map +0 -1
  210. package/dist/memory/temporal-decay.js +0 -119
  211. package/dist/memory/temporal-decay.js.map +0 -1
  212. package/dist/memory/watch-bridge.d.ts +0 -20
  213. package/dist/memory/watch-bridge.d.ts.map +0 -1
  214. package/dist/memory/watch-bridge.js +0 -128
  215. package/dist/memory/watch-bridge.js.map +0 -1
  216. package/dist/message.d.ts +0 -11
  217. package/dist/message.d.ts.map +0 -1
  218. package/dist/message.js +0 -46
  219. package/dist/message.js.map +0 -1
  220. package/dist/plugins/boundary-file-read.d.ts +0 -13
  221. package/dist/plugins/boundary-file-read.d.ts.map +0 -1
  222. package/dist/plugins/boundary-file-read.js +0 -31
  223. package/dist/plugins/boundary-file-read.js.map +0 -1
  224. package/dist/plugins/config-state.d.ts +0 -35
  225. package/dist/plugins/config-state.d.ts.map +0 -1
  226. package/dist/plugins/config-state.js +0 -97
  227. package/dist/plugins/config-state.js.map +0 -1
  228. package/dist/plugins/discovery.d.ts +0 -21
  229. package/dist/plugins/discovery.d.ts.map +0 -1
  230. package/dist/plugins/discovery.js +0 -425
  231. package/dist/plugins/discovery.js.map +0 -1
  232. package/dist/plugins/hooks.d.ts +0 -133
  233. package/dist/plugins/hooks.d.ts.map +0 -1
  234. package/dist/plugins/hooks.js +0 -19
  235. package/dist/plugins/hooks.js.map +0 -1
  236. package/dist/plugins/index.d.ts +0 -20
  237. package/dist/plugins/index.d.ts.map +0 -1
  238. package/dist/plugins/index.js +0 -11
  239. package/dist/plugins/index.js.map +0 -1
  240. package/dist/plugins/loader.d.ts +0 -60
  241. package/dist/plugins/loader.d.ts.map +0 -1
  242. package/dist/plugins/loader.js +0 -224
  243. package/dist/plugins/loader.js.map +0 -1
  244. package/dist/plugins/manager.d.ts +0 -20
  245. package/dist/plugins/manager.d.ts.map +0 -1
  246. package/dist/plugins/manager.js +0 -33
  247. package/dist/plugins/manager.js.map +0 -1
  248. package/dist/plugins/manifest-registry.d.ts +0 -15
  249. package/dist/plugins/manifest-registry.d.ts.map +0 -1
  250. package/dist/plugins/manifest-registry.js +0 -37
  251. package/dist/plugins/manifest-registry.js.map +0 -1
  252. package/dist/plugins/manifest.d.ts +0 -6
  253. package/dist/plugins/manifest.d.ts.map +0 -1
  254. package/dist/plugins/manifest.js +0 -80
  255. package/dist/plugins/manifest.js.map +0 -1
  256. package/dist/plugins/path-safety.d.ts +0 -6
  257. package/dist/plugins/path-safety.d.ts.map +0 -1
  258. package/dist/plugins/path-safety.js +0 -32
  259. package/dist/plugins/path-safety.js.map +0 -1
  260. package/dist/plugins/runtime-context.d.ts +0 -12
  261. package/dist/plugins/runtime-context.d.ts.map +0 -1
  262. package/dist/plugins/runtime-context.js +0 -2
  263. package/dist/plugins/runtime-context.js.map +0 -1
  264. package/dist/plugins/runtime.d.ts +0 -20
  265. package/dist/plugins/runtime.d.ts.map +0 -1
  266. package/dist/plugins/runtime.js +0 -33
  267. package/dist/plugins/runtime.js.map +0 -1
  268. package/dist/plugins/schema-validator.d.ts +0 -17
  269. package/dist/plugins/schema-validator.d.ts.map +0 -1
  270. package/dist/plugins/schema-validator.js +0 -26
  271. package/dist/plugins/schema-validator.js.map +0 -1
  272. package/dist/plugins/tool-hooks.d.ts +0 -4
  273. package/dist/plugins/tool-hooks.d.ts.map +0 -1
  274. package/dist/plugins/tool-hooks.js +0 -63
  275. package/dist/plugins/tool-hooks.js.map +0 -1
  276. package/dist/plugins/tools.d.ts +0 -20
  277. package/dist/plugins/tools.d.ts.map +0 -1
  278. package/dist/plugins/tools.js +0 -42
  279. package/dist/plugins/tools.js.map +0 -1
  280. package/dist/plugins/types.d.ts +0 -61
  281. package/dist/plugins/types.d.ts.map +0 -1
  282. package/dist/plugins/types.js +0 -2
  283. package/dist/plugins/types.js.map +0 -1
  284. package/dist/plugins/utils.d.ts +0 -4
  285. package/dist/plugins/utils.d.ts.map +0 -1
  286. package/dist/plugins/utils.js +0 -22
  287. package/dist/plugins/utils.js.map +0 -1
  288. package/dist/runner/agent-runtime.d.ts +0 -62
  289. package/dist/runner/agent-runtime.d.ts.map +0 -1
  290. package/dist/runner/agent-runtime.js +0 -186
  291. package/dist/runner/agent-runtime.js.map +0 -1
  292. package/dist/runner/announce-loop.d.ts +0 -41
  293. package/dist/runner/announce-loop.d.ts.map +0 -1
  294. package/dist/runner/announce-loop.js +0 -94
  295. package/dist/runner/announce-loop.js.map +0 -1
  296. package/dist/runner/event-dispatcher.d.ts +0 -12
  297. package/dist/runner/event-dispatcher.d.ts.map +0 -1
  298. package/dist/runner/event-dispatcher.js +0 -18
  299. package/dist/runner/event-dispatcher.js.map +0 -1
  300. package/dist/runner/finalizer.d.ts +0 -30
  301. package/dist/runner/finalizer.d.ts.map +0 -1
  302. package/dist/runner/finalizer.js +0 -75
  303. package/dist/runner/finalizer.js.map +0 -1
  304. package/dist/runner/invocation-resolver.d.ts +0 -67
  305. package/dist/runner/invocation-resolver.d.ts.map +0 -1
  306. package/dist/runner/invocation-resolver.js +0 -224
  307. package/dist/runner/invocation-resolver.js.map +0 -1
  308. package/dist/runner/plugin-context.d.ts +0 -18
  309. package/dist/runner/plugin-context.d.ts.map +0 -1
  310. package/dist/runner/plugin-context.js +0 -26
  311. package/dist/runner/plugin-context.js.map +0 -1
  312. package/dist/runner/run-context.d.ts +0 -38
  313. package/dist/runner/run-context.d.ts.map +0 -1
  314. package/dist/runner/run-context.js +0 -159
  315. package/dist/runner/run-context.js.map +0 -1
  316. package/dist/runner/runner-session.d.ts +0 -34
  317. package/dist/runner/runner-session.d.ts.map +0 -1
  318. package/dist/runner/runner-session.js +0 -61
  319. package/dist/runner/runner-session.js.map +0 -1
  320. package/dist/runner/runner.d.ts +0 -13
  321. package/dist/runner/runner.d.ts.map +0 -1
  322. package/dist/runner/runner.js +0 -234
  323. package/dist/runner/runner.js.map +0 -1
  324. package/dist/runner/runtime.d.ts +0 -7
  325. package/dist/runner/runtime.d.ts.map +0 -1
  326. package/dist/runner/runtime.js +0 -21
  327. package/dist/runner/runtime.js.map +0 -1
  328. package/dist/runner/session-lifecycle.d.ts +0 -31
  329. package/dist/runner/session-lifecycle.d.ts.map +0 -1
  330. package/dist/runner/session-lifecycle.js +0 -38
  331. package/dist/runner/session-lifecycle.js.map +0 -1
  332. package/dist/runner/skill-usage.d.ts +0 -29
  333. package/dist/runner/skill-usage.d.ts.map +0 -1
  334. package/dist/runner/skill-usage.js +0 -65
  335. package/dist/runner/skill-usage.js.map +0 -1
  336. package/dist/runner/title.d.ts +0 -3
  337. package/dist/runner/title.d.ts.map +0 -1
  338. package/dist/runner/title.js +0 -6
  339. package/dist/runner/title.js.map +0 -1
  340. package/dist/runner/turn-executor.d.ts +0 -51
  341. package/dist/runner/turn-executor.d.ts.map +0 -1
  342. package/dist/runner/turn-executor.js +0 -294
  343. package/dist/runner/turn-executor.js.map +0 -1
  344. package/dist/security/command-dangerous-rules.d.ts +0 -4
  345. package/dist/security/command-dangerous-rules.d.ts.map +0 -1
  346. package/dist/security/command-dangerous-rules.js +0 -26
  347. package/dist/security/command-dangerous-rules.js.map +0 -1
  348. package/dist/security/command-parser.d.ts +0 -3
  349. package/dist/security/command-parser.d.ts.map +0 -1
  350. package/dist/security/command-parser.js +0 -191
  351. package/dist/security/command-parser.js.map +0 -1
  352. package/dist/security/command-path-guard.d.ts +0 -10
  353. package/dist/security/command-path-guard.d.ts.map +0 -1
  354. package/dist/security/command-path-guard.js +0 -126
  355. package/dist/security/command-path-guard.js.map +0 -1
  356. package/dist/security/command-policy-config.d.ts +0 -5
  357. package/dist/security/command-policy-config.d.ts.map +0 -1
  358. package/dist/security/command-policy-config.js +0 -212
  359. package/dist/security/command-policy-config.js.map +0 -1
  360. package/dist/security/command-policy-engine.d.ts +0 -8
  361. package/dist/security/command-policy-engine.d.ts.map +0 -1
  362. package/dist/security/command-policy-engine.js +0 -122
  363. package/dist/security/command-policy-engine.js.map +0 -1
  364. package/dist/security/command-policy-types.d.ts +0 -67
  365. package/dist/security/command-policy-types.d.ts.map +0 -1
  366. package/dist/security/command-policy-types.js +0 -2
  367. package/dist/security/command-policy-types.js.map +0 -1
  368. package/dist/security/command-safe-bins.d.ts +0 -4
  369. package/dist/security/command-safe-bins.d.ts.map +0 -1
  370. package/dist/security/command-safe-bins.js +0 -84
  371. package/dist/security/command-safe-bins.js.map +0 -1
  372. package/dist/security/command-trusted-executables.d.ts +0 -6
  373. package/dist/security/command-trusted-executables.d.ts.map +0 -1
  374. package/dist/security/command-trusted-executables.js +0 -57
  375. package/dist/security/command-trusted-executables.js.map +0 -1
  376. package/dist/session/session.d.ts +0 -45
  377. package/dist/session/session.d.ts.map +0 -1
  378. package/dist/session/session.js +0 -167
  379. package/dist/session/session.js.map +0 -1
  380. package/dist/skills/skills.d.ts +0 -23
  381. package/dist/skills/skills.d.ts.map +0 -1
  382. package/dist/skills/skills.js +0 -109
  383. package/dist/skills/skills.js.map +0 -1
  384. package/dist/subagent/registry-persist.d.ts +0 -31
  385. package/dist/subagent/registry-persist.d.ts.map +0 -1
  386. package/dist/subagent/registry-persist.js +0 -115
  387. package/dist/subagent/registry-persist.js.map +0 -1
  388. package/dist/subagent/registry.d.ts +0 -52
  389. package/dist/subagent/registry.d.ts.map +0 -1
  390. package/dist/subagent/registry.js +0 -122
  391. package/dist/subagent/registry.js.map +0 -1
  392. package/dist/subagent/types.d.ts +0 -20
  393. package/dist/subagent/types.d.ts.map +0 -1
  394. package/dist/subagent/types.js +0 -2
  395. package/dist/subagent/types.js.map +0 -1
  396. package/dist/system-prompt/builder.d.ts +0 -50
  397. package/dist/system-prompt/builder.d.ts.map +0 -1
  398. package/dist/system-prompt/builder.js +0 -335
  399. package/dist/system-prompt/builder.js.map +0 -1
  400. package/dist/tools/apply-patch.d.ts +0 -15
  401. package/dist/tools/apply-patch.d.ts.map +0 -1
  402. package/dist/tools/apply-patch.js +0 -425
  403. package/dist/tools/apply-patch.js.map +0 -1
  404. package/dist/tools/bash.d.ts +0 -11
  405. package/dist/tools/bash.d.ts.map +0 -1
  406. package/dist/tools/bash.js +0 -13
  407. package/dist/tools/bash.js.map +0 -1
  408. package/dist/tools/cron.d.ts +0 -30
  409. package/dist/tools/cron.d.ts.map +0 -1
  410. package/dist/tools/cron.js +0 -57
  411. package/dist/tools/cron.js.map +0 -1
  412. package/dist/tools/exec.d.ts +0 -18
  413. package/dist/tools/exec.d.ts.map +0 -1
  414. package/dist/tools/exec.js +0 -144
  415. package/dist/tools/exec.js.map +0 -1
  416. package/dist/tools/files.d.ts +0 -37
  417. package/dist/tools/files.d.ts.map +0 -1
  418. package/dist/tools/files.js +0 -191
  419. package/dist/tools/files.js.map +0 -1
  420. package/dist/tools/image.d.ts +0 -14
  421. package/dist/tools/image.d.ts.map +0 -1
  422. package/dist/tools/image.js +0 -26
  423. package/dist/tools/image.js.map +0 -1
  424. package/dist/tools/index.d.ts +0 -36
  425. package/dist/tools/index.d.ts.map +0 -1
  426. package/dist/tools/index.js +0 -53
  427. package/dist/tools/index.js.map +0 -1
  428. package/dist/tools/memory.d.ts +0 -41
  429. package/dist/tools/memory.d.ts.map +0 -1
  430. package/dist/tools/memory.js +0 -114
  431. package/dist/tools/memory.js.map +0 -1
  432. package/dist/tools/process-registry.d.ts +0 -47
  433. package/dist/tools/process-registry.d.ts.map +0 -1
  434. package/dist/tools/process-registry.js +0 -262
  435. package/dist/tools/process-registry.js.map +0 -1
  436. package/dist/tools/process.d.ts +0 -17
  437. package/dist/tools/process.d.ts.map +0 -1
  438. package/dist/tools/process.js +0 -114
  439. package/dist/tools/process.js.map +0 -1
  440. package/dist/tools/subagent-spawn.d.ts +0 -44
  441. package/dist/tools/subagent-spawn.d.ts.map +0 -1
  442. package/dist/tools/subagent-spawn.js +0 -101
  443. package/dist/tools/subagent-spawn.js.map +0 -1
  444. package/dist/tools/subagents.d.ts +0 -30
  445. package/dist/tools/subagents.d.ts.map +0 -1
  446. package/dist/tools/subagents.js +0 -101
  447. package/dist/tools/subagents.js.map +0 -1
  448. package/dist/types.d.ts +0 -153
  449. package/dist/types.d.ts.map +0 -1
  450. package/dist/types.js +0 -6
  451. package/dist/types.js.map +0 -1
@@ -1,23 +0,0 @@
1
- import { type SimpleStreamOptions, type StreamFunction } from "@mariozechner/pi-ai";
2
- export interface OpenAICompletionsOptions {
3
- temperature?: number;
4
- maxTokens?: number;
5
- signal?: AbortSignal;
6
- apiKey?: string;
7
- sessionId?: string;
8
- onPayload?: (payload: unknown) => void;
9
- headers?: Record<string, string>;
10
- maxRetryDelayMs?: number;
11
- metadata?: Record<string, unknown>;
12
- cacheRetention?: "none" | "short" | "long";
13
- toolChoice?: "auto" | "none" | "required" | {
14
- type: "function";
15
- function: {
16
- name: string;
17
- };
18
- };
19
- reasoningEffort?: "minimal" | "low" | "medium" | "high" | "xhigh";
20
- }
21
- export declare const streamOpenAICompletionsCompat: StreamFunction<"openai-completions", OpenAICompletionsOptions>;
22
- export declare const streamSimpleOpenAICompletionsCompat: StreamFunction<"openai-completions", SimpleStreamOptions>;
23
- //# sourceMappingURL=openai-completions-compat.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"openai-completions-compat.d.ts","sourceRoot":"","sources":["../../src/llm/openai-completions-compat.ts"],"names":[],"mappings":"AAKA,OAAO,EAML,KAAK,mBAAmB,EACxB,KAAK,cAAc,EAEpB,MAAM,qBAAqB,CAAC;AAU7B,MAAM,WAAW,wBAAwB;IACvC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;IACvC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,cAAc,CAAC,EAAE,MAAM,GAAG,OAAO,GAAG,MAAM,CAAC;IAC3C,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,UAAU,GAAG;QAAE,IAAI,EAAE,UAAU,CAAC;QAAC,QAAQ,EAAE;YAAE,IAAI,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC;IAC7F,eAAe,CAAC,EAAE,SAAS,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAC;CACnE;AAED,eAAO,MAAM,6BAA6B,EAAE,cAAc,CACxD,oBAAoB,EACpB,wBAAwB,CA+OzB,CAAC;AAEF,eAAO,MAAM,mCAAmC,EAAE,cAAc,CAC9D,oBAAoB,EACpB,mBAAmB,CAepB,CAAC"}
@@ -1,602 +0,0 @@
1
- import OpenAI from "openai";
2
- import { calculateCost, getEnvApiKey, supportsXhigh, } from "@mariozechner/pi-ai";
3
- import { parseStreamingJson } from "@mariozechner/pi-ai";
4
- import { AssistantMessageEventStream } from "@mariozechner/pi-ai/dist/utils/event-stream.js";
5
- import { sanitizeSurrogates } from "@mariozechner/pi-ai/dist/utils/sanitize-unicode.js";
6
- import { buildCopilotDynamicHeaders, hasCopilotVisionInput } from "@mariozechner/pi-ai/dist/providers/github-copilot-headers.js";
7
- import { buildBaseOptions, clampReasoning } from "@mariozechner/pi-ai/dist/providers/simple-options.js";
8
- import { transformMessages } from "@mariozechner/pi-ai/dist/providers/transform-messages.js";
9
- import { LlmRequestError } from "./client.js";
10
- import { parseOpenAIStreamPayloadError } from "./openai-stream-error.js";
11
- export const streamOpenAICompletionsCompat = (model, context, options) => {
12
- const stream = new AssistantMessageEventStream();
13
- void (async () => {
14
- const output = {
15
- role: "assistant",
16
- content: [],
17
- api: model.api,
18
- provider: model.provider,
19
- model: model.id,
20
- usage: {
21
- input: 0,
22
- output: 0,
23
- cacheRead: 0,
24
- cacheWrite: 0,
25
- totalTokens: 0,
26
- cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
27
- },
28
- stopReason: "stop",
29
- timestamp: Date.now(),
30
- errorMessage: undefined,
31
- };
32
- try {
33
- const apiKey = options?.apiKey || getEnvApiKey(model.provider) || "";
34
- const client = createClient(model, context, apiKey, options?.headers);
35
- const params = buildParams(model, context, options);
36
- options?.onPayload?.(params);
37
- const openaiStream = await client.chat.completions.create(params, { signal: options?.signal });
38
- stream.push({ type: "start", partial: output });
39
- let currentBlock = null;
40
- const blocks = output.content;
41
- const blockIndex = () => blocks.length - 1;
42
- const finishCurrentBlock = (block) => {
43
- if (!block) {
44
- return;
45
- }
46
- if (block.type === "text") {
47
- stream.push({
48
- type: "text_end",
49
- contentIndex: blockIndex(),
50
- content: block.text,
51
- partial: output,
52
- });
53
- return;
54
- }
55
- if (block.type === "thinking") {
56
- stream.push({
57
- type: "thinking_end",
58
- contentIndex: blockIndex(),
59
- content: block.thinking,
60
- partial: output,
61
- });
62
- return;
63
- }
64
- if (block.type === "toolCall") {
65
- block.arguments = parseStreamingJson(block.partialArgs);
66
- delete block.partialArgs;
67
- stream.push({
68
- type: "toolcall_end",
69
- contentIndex: blockIndex(),
70
- toolCall: block,
71
- partial: output,
72
- });
73
- }
74
- };
75
- for await (const chunk of openaiStream) {
76
- const payloadError = parseOpenAIStreamPayloadError(chunk);
77
- if (payloadError) {
78
- throw new LlmRequestError({
79
- message: `LLM upstream returned an error payload in a 200 stream: ${payloadError.message}`,
80
- code: "stream_payload_error",
81
- providerMessage: payloadError.providerMessage,
82
- retryable: payloadError.retryable,
83
- cause: payloadError.raw,
84
- });
85
- }
86
- if (chunk.usage) {
87
- const cachedTokens = chunk.usage.prompt_tokens_details?.cached_tokens || 0;
88
- const reasoningTokens = chunk.usage.completion_tokens_details?.reasoning_tokens || 0;
89
- const input = (chunk.usage.prompt_tokens || 0) - cachedTokens;
90
- const outputTokens = (chunk.usage.completion_tokens || 0) + reasoningTokens;
91
- output.usage = {
92
- input,
93
- output: outputTokens,
94
- cacheRead: cachedTokens,
95
- cacheWrite: 0,
96
- totalTokens: input + outputTokens + cachedTokens,
97
- cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
98
- };
99
- calculateCost(model, output.usage);
100
- }
101
- const choice = chunk.choices?.[0];
102
- if (!choice) {
103
- continue;
104
- }
105
- if (choice.finish_reason) {
106
- output.stopReason = mapStopReason(choice.finish_reason);
107
- }
108
- if (!choice.delta) {
109
- continue;
110
- }
111
- if (choice.delta.content !== null && choice.delta.content !== undefined && choice.delta.content.length > 0) {
112
- if (!currentBlock || currentBlock.type !== "text") {
113
- finishCurrentBlock(currentBlock);
114
- currentBlock = { type: "text", text: "" };
115
- output.content.push(currentBlock);
116
- stream.push({ type: "text_start", contentIndex: blockIndex(), partial: output });
117
- }
118
- currentBlock.text += choice.delta.content;
119
- stream.push({
120
- type: "text_delta",
121
- contentIndex: blockIndex(),
122
- delta: choice.delta.content,
123
- partial: output,
124
- });
125
- }
126
- const reasoningFields = ["reasoning_content", "reasoning", "reasoning_text"];
127
- const foundReasoningField = reasoningFields.find((field) => {
128
- const value = choice.delta[field];
129
- return value !== null && value !== undefined && value.length > 0;
130
- });
131
- if (foundReasoningField) {
132
- if (!currentBlock || currentBlock.type !== "thinking") {
133
- finishCurrentBlock(currentBlock);
134
- currentBlock = {
135
- type: "thinking",
136
- thinking: "",
137
- thinkingSignature: foundReasoningField,
138
- };
139
- output.content.push(currentBlock);
140
- stream.push({ type: "thinking_start", contentIndex: blockIndex(), partial: output });
141
- }
142
- const delta = choice.delta[foundReasoningField];
143
- currentBlock.thinking += delta;
144
- stream.push({
145
- type: "thinking_delta",
146
- contentIndex: blockIndex(),
147
- delta,
148
- partial: output,
149
- });
150
- }
151
- if (choice.delta.tool_calls) {
152
- for (const toolCall of choice.delta.tool_calls) {
153
- if (!currentBlock ||
154
- currentBlock.type !== "toolCall" ||
155
- (toolCall.id && currentBlock.id !== toolCall.id)) {
156
- finishCurrentBlock(currentBlock);
157
- currentBlock = {
158
- type: "toolCall",
159
- id: toolCall.id || "",
160
- name: toolCall.function?.name || "",
161
- arguments: {},
162
- partialArgs: "",
163
- };
164
- output.content.push(currentBlock);
165
- stream.push({ type: "toolcall_start", contentIndex: blockIndex(), partial: output });
166
- }
167
- if (toolCall.id)
168
- currentBlock.id = toolCall.id;
169
- if (toolCall.function?.name)
170
- currentBlock.name = toolCall.function.name;
171
- let delta = "";
172
- if (toolCall.function?.arguments) {
173
- delta = toolCall.function.arguments;
174
- currentBlock.partialArgs += toolCall.function.arguments;
175
- currentBlock.arguments = parseStreamingJson(currentBlock.partialArgs);
176
- }
177
- stream.push({
178
- type: "toolcall_delta",
179
- contentIndex: blockIndex(),
180
- delta,
181
- partial: output,
182
- });
183
- }
184
- }
185
- const reasoningDetails = choice.delta.reasoning_details;
186
- if (reasoningDetails && Array.isArray(reasoningDetails)) {
187
- for (const detail of reasoningDetails) {
188
- if (detail.type === "reasoning.encrypted" && detail.id && detail.data) {
189
- const matchingToolCall = output.content.find((block) => block.type === "toolCall" && block.id === detail.id);
190
- if (matchingToolCall) {
191
- matchingToolCall.thoughtSignature = JSON.stringify(detail);
192
- }
193
- }
194
- }
195
- }
196
- }
197
- finishCurrentBlock(currentBlock);
198
- if (options?.signal?.aborted) {
199
- throw new Error("Request was aborted");
200
- }
201
- if (output.stopReason === "aborted" || output.stopReason === "error") {
202
- throw new Error(output.errorMessage
203
- ?? (output.stopReason === "aborted"
204
- ? "Request was aborted"
205
- : `LLM stream ended with stopReason=${output.stopReason}`));
206
- }
207
- stream.push({ type: "done", reason: output.stopReason, message: output });
208
- stream.end();
209
- }
210
- catch (error) {
211
- for (const block of output.content) {
212
- delete block.index;
213
- }
214
- output.stopReason = options?.signal?.aborted ? "aborted" : "error";
215
- output.errorMessage = error instanceof Error ? error.message : JSON.stringify(error);
216
- const rawMetadata = error?.error?.metadata?.raw;
217
- if (rawMetadata) {
218
- output.errorMessage += `\n${rawMetadata}`;
219
- }
220
- stream.push({ type: "error", reason: output.stopReason, error: output });
221
- stream.end();
222
- }
223
- })();
224
- return stream;
225
- };
226
- export const streamSimpleOpenAICompletionsCompat = (model, context, options) => {
227
- const apiKey = options?.apiKey || getEnvApiKey(model.provider);
228
- if (!apiKey) {
229
- throw new Error(`No API key for provider: ${model.provider}`);
230
- }
231
- const base = buildBaseOptions(model, options, apiKey);
232
- const reasoningEffort = supportsXhigh(model) ? options?.reasoning : clampReasoning(options?.reasoning);
233
- return streamOpenAICompletionsCompat(model, context, {
234
- ...base,
235
- reasoningEffort,
236
- toolChoice: undefined,
237
- });
238
- };
239
- function createClient(model, context, apiKey, optionsHeaders) {
240
- if (!apiKey) {
241
- if (!process.env.OPENAI_API_KEY) {
242
- throw new Error("OpenAI API key is required. Set OPENAI_API_KEY environment variable or pass it as an argument.");
243
- }
244
- apiKey = process.env.OPENAI_API_KEY;
245
- }
246
- const headers = { ...model.headers };
247
- if (model.provider === "github-copilot") {
248
- const hasImages = hasCopilotVisionInput(context.messages);
249
- Object.assign(headers, buildCopilotDynamicHeaders({ messages: context.messages, hasImages }));
250
- }
251
- if (optionsHeaders) {
252
- Object.assign(headers, optionsHeaders);
253
- }
254
- return new OpenAI({
255
- apiKey,
256
- baseURL: model.baseUrl,
257
- dangerouslyAllowBrowser: true,
258
- defaultHeaders: headers,
259
- });
260
- }
261
- function buildParams(model, context, options) {
262
- const compat = getCompat(model);
263
- const messages = convertMessages(model, context, compat);
264
- maybeAddOpenRouterAnthropicCacheControl(model, messages);
265
- const params = {
266
- model: model.id,
267
- messages,
268
- stream: true,
269
- };
270
- if (compat.supportsUsageInStreaming !== false) {
271
- params.stream_options = { include_usage: true };
272
- }
273
- if (compat.supportsStore) {
274
- params.store = false;
275
- }
276
- if (options?.maxTokens) {
277
- if (compat.maxTokensField === "max_tokens") {
278
- params.max_tokens = options.maxTokens;
279
- }
280
- else {
281
- params.max_completion_tokens = options.maxTokens;
282
- }
283
- }
284
- if (options?.temperature !== undefined) {
285
- params.temperature = options.temperature;
286
- }
287
- if (context.tools) {
288
- params.tools = convertTools(context.tools, compat);
289
- }
290
- else if (hasToolHistory(context.messages)) {
291
- params.tools = [];
292
- }
293
- if (options?.toolChoice) {
294
- params.tool_choice = options.toolChoice;
295
- }
296
- if ((compat.thinkingFormat === "zai" || compat.thinkingFormat === "qwen") && model.reasoning) {
297
- params.enable_thinking = !!options?.reasoningEffort;
298
- }
299
- else if (options?.reasoningEffort && model.reasoning && compat.supportsReasoningEffort) {
300
- params.reasoning_effort = options.reasoningEffort;
301
- }
302
- if (model.baseUrl.includes("openrouter.ai") && model.compat?.openRouterRouting) {
303
- params.provider = model.compat.openRouterRouting;
304
- }
305
- if (model.baseUrl.includes("ai-gateway.vercel.sh") && model.compat?.vercelGatewayRouting) {
306
- const routing = model.compat.vercelGatewayRouting;
307
- if (routing.only || routing.order) {
308
- const gatewayOptions = {};
309
- if (routing.only)
310
- gatewayOptions.only = routing.only;
311
- if (routing.order)
312
- gatewayOptions.order = routing.order;
313
- params.providerOptions = { gateway: gatewayOptions };
314
- }
315
- }
316
- return params;
317
- }
318
- function hasToolHistory(messages) {
319
- for (const msg of messages) {
320
- if (msg.role === "toolResult") {
321
- return true;
322
- }
323
- if (msg.role === "assistant" && msg.content.some((block) => block.type === "toolCall")) {
324
- return true;
325
- }
326
- }
327
- return false;
328
- }
329
- function normalizeMistralToolId(id) {
330
- let normalized = id.replace(/[^a-zA-Z0-9]/g, "");
331
- if (normalized.length < 9) {
332
- normalized += "ABCDEFGHI".slice(0, 9 - normalized.length);
333
- }
334
- else if (normalized.length > 9) {
335
- normalized = normalized.slice(0, 9);
336
- }
337
- return normalized;
338
- }
339
- function maybeAddOpenRouterAnthropicCacheControl(model, messages) {
340
- if (model.provider !== "openrouter" || !model.id.startsWith("anthropic/")) {
341
- return;
342
- }
343
- for (let i = messages.length - 1; i >= 0; i -= 1) {
344
- const msg = messages[i];
345
- if (msg.role !== "user" && msg.role !== "assistant") {
346
- continue;
347
- }
348
- const content = msg.content;
349
- if (typeof content === "string") {
350
- msg.content = [{ type: "text", text: content, cache_control: { type: "ephemeral" } }];
351
- return;
352
- }
353
- if (!Array.isArray(content)) {
354
- continue;
355
- }
356
- for (let j = content.length - 1; j >= 0; j -= 1) {
357
- const part = content[j];
358
- if (part?.type === "text") {
359
- Object.assign(part, { cache_control: { type: "ephemeral" } });
360
- return;
361
- }
362
- }
363
- }
364
- }
365
- function convertMessages(model, context, compat) {
366
- const params = [];
367
- const normalizeToolCallId = (id) => {
368
- if (compat.requiresMistralToolIds)
369
- return normalizeMistralToolId(id);
370
- if (id.includes("|")) {
371
- const [callId] = id.split("|");
372
- return callId.replace(/[^a-zA-Z0-9_-]/g, "_").slice(0, 40);
373
- }
374
- if (model.provider === "openai")
375
- return id.length > 40 ? id.slice(0, 40) : id;
376
- return id;
377
- };
378
- const transformedMessages = transformMessages(context.messages, model, (id) => normalizeToolCallId(id));
379
- if (context.systemPrompt) {
380
- const role = model.reasoning && compat.supportsDeveloperRole ? "developer" : "system";
381
- params.push({ role, content: sanitizeSurrogates(context.systemPrompt) });
382
- }
383
- let lastRole = null;
384
- for (let i = 0; i < transformedMessages.length; i += 1) {
385
- const msg = transformedMessages[i];
386
- if (compat.requiresAssistantAfterToolResult && lastRole === "toolResult" && msg.role === "user") {
387
- params.push({ role: "assistant", content: "I have processed the tool results." });
388
- }
389
- if (msg.role === "user") {
390
- if (typeof msg.content === "string") {
391
- params.push({ role: "user", content: sanitizeSurrogates(msg.content) });
392
- }
393
- else {
394
- const content = msg.content.map((item) => {
395
- if (item.type === "text") {
396
- return { type: "text", text: sanitizeSurrogates(item.text) };
397
- }
398
- return {
399
- type: "image_url",
400
- image_url: { url: `data:${item.mimeType};base64,${item.data}` },
401
- };
402
- });
403
- const filteredContent = !model.input.includes("image")
404
- ? content.filter((item) => item.type !== "image_url")
405
- : content;
406
- if (filteredContent.length === 0)
407
- continue;
408
- params.push({ role: "user", content: filteredContent });
409
- }
410
- lastRole = msg.role;
411
- continue;
412
- }
413
- if (msg.role === "assistant") {
414
- const assistantMsg = {
415
- role: "assistant",
416
- content: compat.requiresAssistantAfterToolResult ? "" : null,
417
- };
418
- const textBlocks = msg.content.filter((block) => block.type === "text" && block.text?.trim().length > 0);
419
- if (textBlocks.length > 0) {
420
- assistantMsg.content = model.provider === "github-copilot"
421
- ? textBlocks.map((block) => sanitizeSurrogates(block.text)).join("")
422
- : textBlocks.map((block) => ({ type: "text", text: sanitizeSurrogates(block.text) }));
423
- }
424
- const thinkingBlocks = msg.content.filter((block) => block.type === "thinking" && block.thinking?.trim().length > 0);
425
- if (thinkingBlocks.length > 0) {
426
- if (compat.requiresThinkingAsText) {
427
- const thinkingText = thinkingBlocks.map((block) => block.thinking).join("\n\n");
428
- if (assistantMsg.content) {
429
- assistantMsg.content.unshift({ type: "text", text: thinkingText });
430
- }
431
- else {
432
- assistantMsg.content = [{ type: "text", text: thinkingText }];
433
- }
434
- }
435
- else {
436
- const signature = thinkingBlocks[0].thinkingSignature;
437
- if (signature && signature.length > 0) {
438
- assistantMsg[signature] = thinkingBlocks.map((block) => block.thinking).join("\n");
439
- }
440
- }
441
- }
442
- const toolCalls = msg.content.filter((block) => block.type === "toolCall");
443
- if (toolCalls.length > 0) {
444
- assistantMsg.tool_calls = toolCalls.map((toolCall) => ({
445
- id: toolCall.id,
446
- type: "function",
447
- function: { name: toolCall.name, arguments: JSON.stringify(toolCall.arguments) },
448
- }));
449
- const reasoningDetails = toolCalls
450
- .filter((toolCall) => toolCall.thoughtSignature)
451
- .map((toolCall) => {
452
- try {
453
- return JSON.parse(toolCall.thoughtSignature);
454
- }
455
- catch {
456
- return null;
457
- }
458
- })
459
- .filter(Boolean);
460
- if (reasoningDetails.length > 0) {
461
- assistantMsg.reasoning_details = reasoningDetails;
462
- }
463
- }
464
- const content = assistantMsg.content;
465
- const hasContent = content !== null && content !== undefined && (typeof content === "string" ? content.length > 0 : content.length > 0);
466
- if (!hasContent && !assistantMsg.tool_calls) {
467
- continue;
468
- }
469
- params.push(assistantMsg);
470
- lastRole = msg.role;
471
- continue;
472
- }
473
- if (msg.role === "toolResult") {
474
- const imageBlocks = [];
475
- let j = i;
476
- for (; j < transformedMessages.length && transformedMessages[j].role === "toolResult"; j += 1) {
477
- const toolMsg = transformedMessages[j];
478
- const textResult = toolMsg.content.filter((c) => c.type === "text").map((c) => c.text).join("\n");
479
- const hasImages = toolMsg.content.some((c) => c.type === "image");
480
- const toolResultMsg = {
481
- role: "tool",
482
- content: sanitizeSurrogates(textResult.length > 0 ? textResult : "(see attached image)"),
483
- tool_call_id: toolMsg.toolCallId,
484
- };
485
- if (compat.requiresToolResultName && toolMsg.toolName) {
486
- toolResultMsg.name = toolMsg.toolName;
487
- }
488
- params.push(toolResultMsg);
489
- if (hasImages && model.input.includes("image")) {
490
- for (const block of toolMsg.content) {
491
- if (block.type === "image") {
492
- imageBlocks.push({
493
- type: "image_url",
494
- image_url: { url: `data:${block.mimeType};base64,${block.data}` },
495
- });
496
- }
497
- }
498
- }
499
- }
500
- i = j - 1;
501
- if (imageBlocks.length > 0) {
502
- if (compat.requiresAssistantAfterToolResult) {
503
- params.push({ role: "assistant", content: "I have processed the tool results." });
504
- }
505
- params.push({
506
- role: "user",
507
- content: [{ type: "text", text: "Attached image(s) from tool result:" }, ...imageBlocks],
508
- });
509
- lastRole = "user";
510
- }
511
- else {
512
- lastRole = "toolResult";
513
- }
514
- }
515
- }
516
- return params;
517
- }
518
- function convertTools(tools, compat) {
519
- return tools.map((tool) => ({
520
- type: "function",
521
- function: {
522
- name: tool.name,
523
- description: tool.description,
524
- parameters: tool.parameters,
525
- ...(compat.supportsStrictMode !== false && { strict: false }),
526
- },
527
- }));
528
- }
529
- function mapStopReason(reason) {
530
- if (reason === null)
531
- return "stop";
532
- switch (reason) {
533
- case "stop":
534
- return "stop";
535
- case "length":
536
- return "length";
537
- case "function_call":
538
- case "tool_calls":
539
- return "toolUse";
540
- case "error":
541
- case "content_filter":
542
- return "error";
543
- default:
544
- throw new Error(`Unhandled stop reason: ${reason}`);
545
- }
546
- }
547
- function detectCompat(model) {
548
- const provider = model.provider;
549
- const baseUrl = model.baseUrl;
550
- const isZai = provider === "zai" || baseUrl.includes("api.z.ai");
551
- const isNonStandard = provider === "cerebras" ||
552
- baseUrl.includes("cerebras.ai") ||
553
- provider === "xai" ||
554
- baseUrl.includes("api.x.ai") ||
555
- provider === "mistral" ||
556
- baseUrl.includes("mistral.ai") ||
557
- baseUrl.includes("chutes.ai") ||
558
- baseUrl.includes("deepseek.com") ||
559
- isZai ||
560
- provider === "opencode" ||
561
- baseUrl.includes("opencode.ai");
562
- const useMaxTokens = provider === "mistral" || baseUrl.includes("mistral.ai") || baseUrl.includes("chutes.ai");
563
- const isGrok = provider === "xai" || baseUrl.includes("api.x.ai");
564
- const isMistral = provider === "mistral" || baseUrl.includes("mistral.ai");
565
- return {
566
- supportsStore: !isNonStandard,
567
- supportsDeveloperRole: !isNonStandard,
568
- supportsReasoningEffort: !isGrok && !isZai,
569
- supportsUsageInStreaming: true,
570
- maxTokensField: useMaxTokens ? "max_tokens" : "max_completion_tokens",
571
- requiresToolResultName: isMistral,
572
- requiresAssistantAfterToolResult: false,
573
- requiresThinkingAsText: isMistral,
574
- requiresMistralToolIds: isMistral,
575
- thinkingFormat: isZai ? "zai" : "openai",
576
- openRouterRouting: {},
577
- vercelGatewayRouting: {},
578
- supportsStrictMode: true,
579
- };
580
- }
581
- function getCompat(model) {
582
- const detected = detectCompat(model);
583
- if (!model.compat) {
584
- return detected;
585
- }
586
- return {
587
- supportsStore: model.compat.supportsStore ?? detected.supportsStore,
588
- supportsDeveloperRole: model.compat.supportsDeveloperRole ?? detected.supportsDeveloperRole,
589
- supportsReasoningEffort: model.compat.supportsReasoningEffort ?? detected.supportsReasoningEffort,
590
- supportsUsageInStreaming: model.compat.supportsUsageInStreaming ?? detected.supportsUsageInStreaming,
591
- maxTokensField: model.compat.maxTokensField ?? detected.maxTokensField,
592
- requiresToolResultName: model.compat.requiresToolResultName ?? detected.requiresToolResultName,
593
- requiresAssistantAfterToolResult: model.compat.requiresAssistantAfterToolResult ?? detected.requiresAssistantAfterToolResult,
594
- requiresThinkingAsText: model.compat.requiresThinkingAsText ?? detected.requiresThinkingAsText,
595
- requiresMistralToolIds: model.compat.requiresMistralToolIds ?? detected.requiresMistralToolIds,
596
- thinkingFormat: model.compat.thinkingFormat ?? detected.thinkingFormat,
597
- openRouterRouting: model.compat.openRouterRouting ?? {},
598
- vercelGatewayRouting: model.compat.vercelGatewayRouting ?? detected.vercelGatewayRouting,
599
- supportsStrictMode: model.compat.supportsStrictMode ?? detected.supportsStrictMode,
600
- };
601
- }
602
- //# sourceMappingURL=openai-completions-compat.js.map