@earendil-works/pi-ai 0.79.10 → 0.80.2

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 (531) hide show
  1. package/README.md +646 -521
  2. package/dist/api/anthropic-messages.d.ts +71 -0
  3. package/dist/api/anthropic-messages.d.ts.map +1 -0
  4. package/dist/api/anthropic-messages.js +963 -0
  5. package/dist/api/anthropic-messages.js.map +1 -0
  6. package/dist/api/anthropic-messages.lazy.d.ts +3 -0
  7. package/dist/api/anthropic-messages.lazy.d.ts.map +1 -0
  8. package/dist/api/anthropic-messages.lazy.js +3 -0
  9. package/dist/api/anthropic-messages.lazy.js.map +1 -0
  10. package/dist/api/azure-openai-responses.d.ts +15 -0
  11. package/dist/api/azure-openai-responses.d.ts.map +1 -0
  12. package/dist/api/azure-openai-responses.js +225 -0
  13. package/dist/api/azure-openai-responses.js.map +1 -0
  14. package/dist/api/azure-openai-responses.lazy.d.ts +3 -0
  15. package/dist/api/azure-openai-responses.lazy.d.ts.map +1 -0
  16. package/dist/api/azure-openai-responses.lazy.js +3 -0
  17. package/dist/api/azure-openai-responses.lazy.js.map +1 -0
  18. package/dist/api/bedrock-converse-stream.d.ts +38 -0
  19. package/dist/api/bedrock-converse-stream.d.ts.map +1 -0
  20. package/dist/api/bedrock-converse-stream.js +863 -0
  21. package/dist/api/bedrock-converse-stream.js.map +1 -0
  22. package/dist/api/bedrock-converse-stream.lazy.d.ts +9 -0
  23. package/dist/api/bedrock-converse-stream.lazy.d.ts.map +1 -0
  24. package/dist/api/bedrock-converse-stream.lazy.js +30 -0
  25. package/dist/api/bedrock-converse-stream.lazy.js.map +1 -0
  26. package/dist/{providers → api}/cloudflare.d.ts +0 -4
  27. package/dist/api/cloudflare.d.ts.map +1 -0
  28. package/dist/{providers → api}/cloudflare.js +0 -18
  29. package/dist/api/cloudflare.js.map +1 -0
  30. package/dist/api/github-copilot-headers.d.ts.map +1 -0
  31. package/dist/api/github-copilot-headers.js.map +1 -0
  32. package/dist/api/google-generative-ai.d.ts +13 -0
  33. package/dist/api/google-generative-ai.d.ts.map +1 -0
  34. package/dist/api/google-generative-ai.js +405 -0
  35. package/dist/api/google-generative-ai.js.map +1 -0
  36. package/dist/api/google-generative-ai.lazy.d.ts +3 -0
  37. package/dist/api/google-generative-ai.lazy.d.ts.map +1 -0
  38. package/dist/api/google-generative-ai.lazy.js +3 -0
  39. package/dist/api/google-generative-ai.lazy.js.map +1 -0
  40. package/dist/api/google-shared.d.ts.map +1 -0
  41. package/dist/api/google-shared.js.map +1 -0
  42. package/dist/api/google-vertex.d.ts +15 -0
  43. package/dist/api/google-vertex.d.ts.map +1 -0
  44. package/dist/api/google-vertex.js +454 -0
  45. package/dist/api/google-vertex.js.map +1 -0
  46. package/dist/api/google-vertex.lazy.d.ts +3 -0
  47. package/dist/api/google-vertex.lazy.d.ts.map +1 -0
  48. package/dist/api/google-vertex.lazy.js +3 -0
  49. package/dist/api/google-vertex.lazy.js.map +1 -0
  50. package/dist/api/lazy.d.ts +15 -0
  51. package/dist/api/lazy.d.ts.map +1 -0
  52. package/dist/api/lazy.js +59 -0
  53. package/dist/api/lazy.js.map +1 -0
  54. package/dist/api/mistral-conversations.d.ts +25 -0
  55. package/dist/api/mistral-conversations.d.ts.map +1 -0
  56. package/dist/api/mistral-conversations.js +555 -0
  57. package/dist/api/mistral-conversations.js.map +1 -0
  58. package/dist/api/mistral-conversations.lazy.d.ts +3 -0
  59. package/dist/api/mistral-conversations.lazy.d.ts.map +1 -0
  60. package/dist/api/mistral-conversations.lazy.js +3 -0
  61. package/dist/api/mistral-conversations.lazy.js.map +1 -0
  62. package/dist/{providers → api}/openai-codex-responses.d.ts +2 -3
  63. package/dist/api/openai-codex-responses.d.ts.map +1 -0
  64. package/dist/{providers → api}/openai-codex-responses.js +66 -45
  65. package/dist/api/openai-codex-responses.js.map +1 -0
  66. package/dist/api/openai-codex-responses.lazy.d.ts +3 -0
  67. package/dist/api/openai-codex-responses.lazy.d.ts.map +1 -0
  68. package/dist/api/openai-codex-responses.lazy.js +3 -0
  69. package/dist/api/openai-codex-responses.lazy.js.map +1 -0
  70. package/dist/{providers → api}/openai-completions.d.ts +2 -3
  71. package/dist/api/openai-completions.d.ts.map +1 -0
  72. package/dist/{providers → api}/openai-completions.js +32 -37
  73. package/dist/api/openai-completions.js.map +1 -0
  74. package/dist/api/openai-completions.lazy.d.ts +3 -0
  75. package/dist/api/openai-completions.lazy.d.ts.map +1 -0
  76. package/dist/api/openai-completions.lazy.js +3 -0
  77. package/dist/api/openai-completions.lazy.js.map +1 -0
  78. package/dist/api/openai-prompt-cache.d.ts.map +1 -0
  79. package/dist/api/openai-prompt-cache.js.map +1 -0
  80. package/dist/api/openai-responses-shared.d.ts.map +1 -0
  81. package/dist/{providers → api}/openai-responses-shared.js +37 -29
  82. package/dist/api/openai-responses-shared.js.map +1 -0
  83. package/dist/{providers → api}/openai-responses.d.ts +2 -3
  84. package/dist/api/openai-responses.d.ts.map +1 -0
  85. package/dist/{providers → api}/openai-responses.js +27 -32
  86. package/dist/api/openai-responses.js.map +1 -0
  87. package/dist/api/openai-responses.lazy.d.ts +3 -0
  88. package/dist/api/openai-responses.lazy.d.ts.map +1 -0
  89. package/dist/api/openai-responses.lazy.js +3 -0
  90. package/dist/api/openai-responses.lazy.js.map +1 -0
  91. package/dist/api/openrouter-images.d.ts +3 -0
  92. package/dist/api/openrouter-images.d.ts.map +1 -0
  93. package/dist/{providers/images/openrouter.js → api/openrouter-images.js} +5 -15
  94. package/dist/api/openrouter-images.js.map +1 -0
  95. package/dist/api/openrouter-images.lazy.d.ts +3 -0
  96. package/dist/api/openrouter-images.lazy.d.ts.map +1 -0
  97. package/dist/api/openrouter-images.lazy.js +4 -0
  98. package/dist/api/openrouter-images.lazy.js.map +1 -0
  99. package/dist/api/simple-options.d.ts.map +1 -0
  100. package/dist/api/simple-options.js.map +1 -0
  101. package/dist/api/transform-messages.d.ts.map +1 -0
  102. package/dist/api/transform-messages.js.map +1 -0
  103. package/dist/auth/context.d.ts +7 -0
  104. package/dist/auth/context.d.ts.map +1 -0
  105. package/dist/auth/context.js +42 -0
  106. package/dist/auth/context.js.map +1 -0
  107. package/dist/auth/credential-store.d.ts +16 -0
  108. package/dist/auth/credential-store.d.ts.map +1 -0
  109. package/dist/auth/credential-store.js +37 -0
  110. package/dist/auth/credential-store.js.map +1 -0
  111. package/dist/auth/helpers.d.ts +20 -0
  112. package/dist/auth/helpers.d.ts.map +1 -0
  113. package/dist/auth/helpers.js +46 -0
  114. package/dist/auth/helpers.js.map +1 -0
  115. package/dist/auth/resolve.d.ts +26 -0
  116. package/dist/auth/resolve.d.ts.map +1 -0
  117. package/dist/auth/resolve.js +101 -0
  118. package/dist/auth/resolve.js.map +1 -0
  119. package/dist/auth/types.d.ts +180 -0
  120. package/dist/auth/types.d.ts.map +1 -0
  121. package/dist/auth/types.js +2 -0
  122. package/dist/auth/types.js.map +1 -0
  123. package/dist/bedrock-provider.d.ts +2 -4
  124. package/dist/bedrock-provider.d.ts.map +1 -1
  125. package/dist/bedrock-provider.js +3 -4
  126. package/dist/bedrock-provider.js.map +1 -1
  127. package/dist/compat.d.ts +65 -0
  128. package/dist/compat.d.ts.map +1 -0
  129. package/dist/compat.js +182 -0
  130. package/dist/compat.js.map +1 -0
  131. package/dist/images-api-registry.d.ts +0 -1
  132. package/dist/images-api-registry.d.ts.map +1 -1
  133. package/dist/images-api-registry.js +0 -3
  134. package/dist/images-api-registry.js.map +1 -1
  135. package/dist/images-models.d.ts +93 -0
  136. package/dist/images-models.d.ts.map +1 -0
  137. package/dist/images-models.js +141 -0
  138. package/dist/images-models.js.map +1 -0
  139. package/dist/images.d.ts +1 -0
  140. package/dist/images.d.ts.map +1 -1
  141. package/dist/images.js +1 -0
  142. package/dist/images.js.map +1 -1
  143. package/dist/index.d.ts +29 -2
  144. package/dist/index.d.ts.map +1 -1
  145. package/dist/index.js +17 -4
  146. package/dist/index.js.map +1 -1
  147. package/dist/legacy-api-aliases.d.ts +42 -0
  148. package/dist/legacy-api-aliases.d.ts.map +1 -0
  149. package/dist/legacy-api-aliases.js +49 -0
  150. package/dist/legacy-api-aliases.js.map +1 -0
  151. package/dist/models.d.ts +133 -9
  152. package/dist/models.d.ts.map +1 -1
  153. package/dist/models.generated.d.ts +1766 -156
  154. package/dist/models.generated.d.ts.map +1 -1
  155. package/dist/models.generated.js +70 -17172
  156. package/dist/models.generated.js.map +1 -1
  157. package/dist/models.js +181 -17
  158. package/dist/models.js.map +1 -1
  159. package/dist/providers/all.d.ts +21 -0
  160. package/dist/providers/all.d.ts.map +1 -0
  161. package/dist/providers/all.js +114 -0
  162. package/dist/providers/all.js.map +1 -0
  163. package/dist/providers/amazon-bedrock.d.ts +2 -38
  164. package/dist/providers/amazon-bedrock.d.ts.map +1 -1
  165. package/dist/providers/amazon-bedrock.js +35 -865
  166. package/dist/providers/amazon-bedrock.js.map +1 -1
  167. package/dist/providers/amazon-bedrock.models.d.ts +1718 -0
  168. package/dist/providers/amazon-bedrock.models.d.ts.map +1 -0
  169. package/dist/providers/amazon-bedrock.models.js +1675 -0
  170. package/dist/providers/amazon-bedrock.models.js.map +1 -0
  171. package/dist/providers/ant-ling.d.ts +3 -0
  172. package/dist/providers/ant-ling.d.ts.map +1 -0
  173. package/dist/providers/ant-ling.js +15 -0
  174. package/dist/providers/ant-ling.js.map +1 -0
  175. package/dist/providers/ant-ling.models.d.ts +86 -0
  176. package/dist/providers/ant-ling.models.d.ts.map +1 -0
  177. package/dist/providers/ant-ling.models.js +60 -0
  178. package/dist/providers/ant-ling.models.js.map +1 -0
  179. package/dist/providers/anthropic.d.ts +2 -71
  180. package/dist/providers/anthropic.d.ts.map +1 -1
  181. package/dist/providers/anthropic.js +17 -973
  182. package/dist/providers/anthropic.js.map +1 -1
  183. package/dist/providers/anthropic.models.d.ts +458 -0
  184. package/dist/providers/anthropic.models.d.ts.map +1 -0
  185. package/dist/providers/anthropic.models.js +439 -0
  186. package/dist/providers/anthropic.models.js.map +1 -0
  187. package/dist/providers/azure-openai-responses.d.ts +2 -15
  188. package/dist/providers/azure-openai-responses.d.ts.map +1 -1
  189. package/dist/providers/azure-openai-responses.js +11 -230
  190. package/dist/providers/azure-openai-responses.js.map +1 -1
  191. package/dist/providers/azure-openai-responses.models.d.ts +804 -0
  192. package/dist/providers/azure-openai-responses.models.d.ts.map +1 -0
  193. package/dist/providers/azure-openai-responses.models.js +743 -0
  194. package/dist/providers/azure-openai-responses.models.js.map +1 -0
  195. package/dist/providers/cerebras.d.ts +3 -0
  196. package/dist/providers/cerebras.d.ts.map +1 -0
  197. package/dist/providers/cerebras.js +15 -0
  198. package/dist/providers/cerebras.js.map +1 -0
  199. package/dist/providers/cerebras.models.d.ts +45 -0
  200. package/dist/providers/cerebras.models.d.ts.map +1 -0
  201. package/dist/providers/cerebras.models.js +41 -0
  202. package/dist/providers/cerebras.models.js.map +1 -0
  203. package/dist/providers/cloudflare-ai-gateway.d.ts +3 -0
  204. package/dist/providers/cloudflare-ai-gateway.d.ts.map +1 -0
  205. package/dist/providers/cloudflare-ai-gateway.js +20 -0
  206. package/dist/providers/cloudflare-ai-gateway.js.map +1 -0
  207. package/dist/providers/cloudflare-ai-gateway.models.d.ts +765 -0
  208. package/dist/providers/cloudflare-ai-gateway.models.d.ts.map +1 -0
  209. package/dist/providers/cloudflare-ai-gateway.models.js +666 -0
  210. package/dist/providers/cloudflare-ai-gateway.models.js.map +1 -0
  211. package/dist/providers/cloudflare-auth.d.ts +4 -0
  212. package/dist/providers/cloudflare-auth.d.ts.map +1 -0
  213. package/dist/providers/cloudflare-auth.js +85 -0
  214. package/dist/providers/cloudflare-auth.js.map +1 -0
  215. package/dist/providers/cloudflare-workers-ai.d.ts +3 -0
  216. package/dist/providers/cloudflare-workers-ai.d.ts.map +1 -0
  217. package/dist/providers/cloudflare-workers-ai.js +14 -0
  218. package/dist/providers/cloudflare-workers-ai.js.map +1 -0
  219. package/dist/providers/cloudflare-workers-ai.models.d.ts +302 -0
  220. package/dist/providers/cloudflare-workers-ai.models.d.ts.map +1 -0
  221. package/dist/providers/cloudflare-workers-ai.models.js +239 -0
  222. package/dist/providers/cloudflare-workers-ai.models.js.map +1 -0
  223. package/dist/providers/deepseek.d.ts +3 -0
  224. package/dist/providers/deepseek.d.ts.map +1 -0
  225. package/dist/providers/deepseek.js +15 -0
  226. package/dist/providers/deepseek.js.map +1 -0
  227. package/dist/providers/deepseek.models.d.ts +63 -0
  228. package/dist/providers/deepseek.models.d.ts.map +1 -0
  229. package/dist/providers/deepseek.models.js +43 -0
  230. package/dist/providers/deepseek.models.js.map +1 -0
  231. package/dist/providers/faux.d.ts +43 -2
  232. package/dist/providers/faux.d.ts.map +1 -1
  233. package/dist/providers/faux.js +34 -7
  234. package/dist/providers/faux.js.map +1 -1
  235. package/dist/providers/fireworks.d.ts +3 -0
  236. package/dist/providers/fireworks.d.ts.map +1 -0
  237. package/dist/providers/fireworks.js +19 -0
  238. package/dist/providers/fireworks.js.map +1 -0
  239. package/dist/providers/fireworks.models.d.ts +353 -0
  240. package/dist/providers/fireworks.models.d.ts.map +1 -0
  241. package/dist/providers/fireworks.models.js +276 -0
  242. package/dist/providers/fireworks.models.js.map +1 -0
  243. package/dist/providers/github-copilot.d.ts +3 -0
  244. package/dist/providers/github-copilot.d.ts.map +1 -0
  245. package/dist/providers/github-copilot.js +25 -0
  246. package/dist/providers/github-copilot.js.map +1 -0
  247. package/dist/providers/github-copilot.models.d.ts +616 -0
  248. package/dist/providers/github-copilot.models.d.ts.map +1 -0
  249. package/dist/providers/github-copilot.models.js +426 -0
  250. package/dist/providers/github-copilot.models.js.map +1 -0
  251. package/dist/providers/google-vertex.d.ts +2 -15
  252. package/dist/providers/google-vertex.d.ts.map +1 -1
  253. package/dist/providers/google-vertex.js +30 -455
  254. package/dist/providers/google-vertex.js.map +1 -1
  255. package/dist/providers/google-vertex.models.d.ts +202 -0
  256. package/dist/providers/google-vertex.models.d.ts.map +1 -0
  257. package/dist/providers/google-vertex.models.js +182 -0
  258. package/dist/providers/google-vertex.models.js.map +1 -0
  259. package/dist/providers/google.d.ts +2 -13
  260. package/dist/providers/google.d.ts.map +1 -1
  261. package/dist/providers/google.js +12 -408
  262. package/dist/providers/google.js.map +1 -1
  263. package/dist/providers/google.models.d.ts +328 -0
  264. package/dist/providers/google.models.d.ts.map +1 -0
  265. package/dist/providers/google.models.js +288 -0
  266. package/dist/providers/google.models.js.map +1 -0
  267. package/dist/providers/groq.d.ts +3 -0
  268. package/dist/providers/groq.d.ts.map +1 -0
  269. package/dist/providers/groq.js +15 -0
  270. package/dist/providers/groq.js.map +1 -0
  271. package/dist/providers/groq.models.d.ts +128 -0
  272. package/dist/providers/groq.models.d.ts.map +1 -0
  273. package/dist/providers/groq.models.js +125 -0
  274. package/dist/providers/groq.models.js.map +1 -0
  275. package/dist/providers/huggingface.d.ts +3 -0
  276. package/dist/providers/huggingface.d.ts.map +1 -0
  277. package/dist/providers/huggingface.js +15 -0
  278. package/dist/providers/huggingface.js.map +1 -0
  279. package/dist/providers/huggingface.models.d.ts +883 -0
  280. package/dist/providers/huggingface.models.d.ts.map +1 -0
  281. package/dist/providers/huggingface.models.js +797 -0
  282. package/dist/providers/huggingface.models.js.map +1 -0
  283. package/dist/providers/images/{openrouter.d.ts → register-builtins.d.ts} +2 -2
  284. package/dist/providers/images/register-builtins.d.ts.map +1 -0
  285. package/dist/providers/images/register-builtins.js +34 -0
  286. package/dist/providers/images/register-builtins.js.map +1 -0
  287. package/dist/providers/kimi-coding.d.ts +3 -0
  288. package/dist/providers/kimi-coding.d.ts.map +1 -0
  289. package/dist/providers/kimi-coding.js +15 -0
  290. package/dist/providers/kimi-coding.js.map +1 -0
  291. package/dist/providers/kimi-coding.models.d.ts +63 -0
  292. package/dist/providers/kimi-coding.models.d.ts.map +1 -0
  293. package/dist/providers/kimi-coding.models.js +59 -0
  294. package/dist/providers/kimi-coding.models.js.map +1 -0
  295. package/dist/providers/minimax-cn.d.ts +3 -0
  296. package/dist/providers/minimax-cn.d.ts.map +1 -0
  297. package/dist/providers/minimax-cn.js +15 -0
  298. package/dist/providers/minimax-cn.js.map +1 -0
  299. package/dist/providers/minimax-cn.models.d.ts +54 -0
  300. package/dist/providers/minimax-cn.models.d.ts.map +1 -0
  301. package/dist/providers/minimax-cn.models.js +56 -0
  302. package/dist/providers/minimax-cn.models.js.map +1 -0
  303. package/dist/providers/minimax.d.ts +3 -0
  304. package/dist/providers/minimax.d.ts.map +1 -0
  305. package/dist/providers/minimax.js +15 -0
  306. package/dist/providers/minimax.js.map +1 -0
  307. package/dist/providers/minimax.models.d.ts +54 -0
  308. package/dist/providers/minimax.models.d.ts.map +1 -0
  309. package/dist/providers/minimax.models.js +56 -0
  310. package/dist/providers/minimax.models.js.map +1 -0
  311. package/dist/providers/mistral.d.ts +2 -25
  312. package/dist/providers/mistral.d.ts.map +1 -1
  313. package/dist/providers/mistral.js +12 -560
  314. package/dist/providers/mistral.js.map +1 -1
  315. package/dist/providers/mistral.models.d.ts +513 -0
  316. package/dist/providers/mistral.models.d.ts.map +1 -0
  317. package/dist/providers/mistral.models.js +515 -0
  318. package/dist/providers/mistral.models.js.map +1 -0
  319. package/dist/providers/moonshotai-cn.d.ts +3 -0
  320. package/dist/providers/moonshotai-cn.d.ts.map +1 -0
  321. package/dist/providers/moonshotai-cn.js +15 -0
  322. package/dist/providers/moonshotai-cn.js.map +1 -0
  323. package/dist/providers/moonshotai-cn.models.d.ts +234 -0
  324. package/dist/providers/moonshotai-cn.models.d.ts.map +1 -0
  325. package/dist/providers/moonshotai-cn.models.js +169 -0
  326. package/dist/providers/moonshotai-cn.models.js.map +1 -0
  327. package/dist/providers/moonshotai.d.ts +3 -0
  328. package/dist/providers/moonshotai.d.ts.map +1 -0
  329. package/dist/providers/moonshotai.js +15 -0
  330. package/dist/providers/moonshotai.js.map +1 -0
  331. package/dist/providers/moonshotai.models.d.ts +234 -0
  332. package/dist/providers/moonshotai.models.d.ts.map +1 -0
  333. package/dist/providers/moonshotai.models.js +169 -0
  334. package/dist/providers/moonshotai.models.js.map +1 -0
  335. package/dist/providers/nvidia.d.ts +3 -0
  336. package/dist/providers/nvidia.d.ts.map +1 -0
  337. package/dist/providers/nvidia.js +15 -0
  338. package/dist/providers/nvidia.js.map +1 -0
  339. package/dist/providers/nvidia.models.d.ts +535 -0
  340. package/dist/providers/nvidia.models.d.ts.map +1 -0
  341. package/dist/providers/nvidia.models.js +366 -0
  342. package/dist/providers/nvidia.models.js.map +1 -0
  343. package/dist/providers/openai-codex.d.ts +3 -0
  344. package/dist/providers/openai-codex.d.ts.map +1 -0
  345. package/dist/providers/openai-codex.js +18 -0
  346. package/dist/providers/openai-codex.js.map +1 -0
  347. package/dist/providers/openai-codex.models.d.ts +87 -0
  348. package/dist/providers/openai-codex.models.d.ts.map +1 -0
  349. package/dist/providers/openai-codex.models.js +77 -0
  350. package/dist/providers/openai-codex.models.js.map +1 -0
  351. package/dist/providers/openai.d.ts +3 -0
  352. package/dist/providers/openai.d.ts.map +1 -0
  353. package/dist/providers/openai.js +15 -0
  354. package/dist/providers/openai.js.map +1 -0
  355. package/dist/providers/openai.models.d.ts +805 -0
  356. package/dist/providers/openai.models.d.ts.map +1 -0
  357. package/dist/providers/openai.models.js +743 -0
  358. package/dist/providers/openai.models.js.map +1 -0
  359. package/dist/providers/opencode-go.d.ts +3 -0
  360. package/dist/providers/opencode-go.d.ts.map +1 -0
  361. package/dist/providers/opencode-go.js +18 -0
  362. package/dist/providers/opencode-go.js.map +1 -0
  363. package/dist/providers/opencode-go.models.d.ts +309 -0
  364. package/dist/providers/opencode-go.models.d.ts.map +1 -0
  365. package/dist/providers/opencode-go.models.js +240 -0
  366. package/dist/providers/opencode-go.models.js.map +1 -0
  367. package/dist/providers/opencode.d.ts +3 -0
  368. package/dist/providers/opencode.d.ts.map +1 -0
  369. package/dist/providers/opencode.js +22 -0
  370. package/dist/providers/opencode.js.map +1 -0
  371. package/dist/providers/opencode.models.d.ts +976 -0
  372. package/dist/providers/opencode.models.d.ts.map +1 -0
  373. package/dist/providers/opencode.models.js +815 -0
  374. package/dist/providers/opencode.models.js.map +1 -0
  375. package/dist/providers/openrouter-images.d.ts +3 -0
  376. package/dist/providers/openrouter-images.d.ts.map +1 -0
  377. package/dist/providers/openrouter-images.js +14 -0
  378. package/dist/providers/openrouter-images.js.map +1 -0
  379. package/dist/providers/openrouter.d.ts +3 -0
  380. package/dist/providers/openrouter.d.ts.map +1 -0
  381. package/dist/providers/openrouter.js +15 -0
  382. package/dist/providers/openrouter.js.map +1 -0
  383. package/dist/providers/openrouter.models.d.ts +5405 -0
  384. package/dist/providers/openrouter.models.d.ts.map +1 -0
  385. package/dist/providers/openrouter.models.js +4635 -0
  386. package/dist/providers/openrouter.models.js.map +1 -0
  387. package/dist/providers/together.d.ts +3 -0
  388. package/dist/providers/together.d.ts.map +1 -0
  389. package/dist/providers/together.js +15 -0
  390. package/dist/providers/together.js.map +1 -0
  391. package/dist/providers/together.models.d.ts +567 -0
  392. package/dist/providers/together.models.d.ts.map +1 -0
  393. package/dist/providers/together.models.js +361 -0
  394. package/dist/providers/together.models.js.map +1 -0
  395. package/dist/providers/vercel-ai-gateway.d.ts +3 -0
  396. package/dist/providers/vercel-ai-gateway.d.ts.map +1 -0
  397. package/dist/providers/vercel-ai-gateway.js +15 -0
  398. package/dist/providers/vercel-ai-gateway.js.map +1 -0
  399. package/dist/providers/vercel-ai-gateway.models.d.ts +2938 -0
  400. package/dist/providers/vercel-ai-gateway.models.d.ts.map +1 -0
  401. package/dist/providers/vercel-ai-gateway.models.js +2897 -0
  402. package/dist/providers/vercel-ai-gateway.models.js.map +1 -0
  403. package/dist/providers/xai.d.ts +3 -0
  404. package/dist/providers/xai.d.ts.map +1 -0
  405. package/dist/providers/xai.js +15 -0
  406. package/dist/providers/xai.js.map +1 -0
  407. package/dist/providers/xai.models.d.ts +157 -0
  408. package/dist/providers/xai.models.d.ts.map +1 -0
  409. package/dist/providers/xai.models.js +131 -0
  410. package/dist/providers/xai.models.js.map +1 -0
  411. package/dist/providers/xiaomi-token-plan-ams.d.ts +3 -0
  412. package/dist/providers/xiaomi-token-plan-ams.d.ts.map +1 -0
  413. package/dist/providers/xiaomi-token-plan-ams.js +15 -0
  414. package/dist/providers/xiaomi-token-plan-ams.js.map +1 -0
  415. package/dist/providers/xiaomi-token-plan-ams.models.d.ts +108 -0
  416. package/dist/providers/xiaomi-token-plan-ams.models.d.ts.map +1 -0
  417. package/dist/providers/xiaomi-token-plan-ams.models.js +95 -0
  418. package/dist/providers/xiaomi-token-plan-ams.models.js.map +1 -0
  419. package/dist/providers/xiaomi-token-plan-cn.d.ts +3 -0
  420. package/dist/providers/xiaomi-token-plan-cn.d.ts.map +1 -0
  421. package/dist/providers/xiaomi-token-plan-cn.js +15 -0
  422. package/dist/providers/xiaomi-token-plan-cn.js.map +1 -0
  423. package/dist/providers/xiaomi-token-plan-cn.models.d.ts +108 -0
  424. package/dist/providers/xiaomi-token-plan-cn.models.d.ts.map +1 -0
  425. package/dist/providers/xiaomi-token-plan-cn.models.js +95 -0
  426. package/dist/providers/xiaomi-token-plan-cn.models.js.map +1 -0
  427. package/dist/providers/xiaomi-token-plan-sgp.d.ts +3 -0
  428. package/dist/providers/xiaomi-token-plan-sgp.d.ts.map +1 -0
  429. package/dist/providers/xiaomi-token-plan-sgp.js +15 -0
  430. package/dist/providers/xiaomi-token-plan-sgp.js.map +1 -0
  431. package/dist/providers/xiaomi-token-plan-sgp.models.d.ts +108 -0
  432. package/dist/providers/xiaomi-token-plan-sgp.models.d.ts.map +1 -0
  433. package/dist/providers/xiaomi-token-plan-sgp.models.js +95 -0
  434. package/dist/providers/xiaomi-token-plan-sgp.models.js.map +1 -0
  435. package/dist/providers/xiaomi.d.ts +3 -0
  436. package/dist/providers/xiaomi.d.ts.map +1 -0
  437. package/dist/providers/xiaomi.js +15 -0
  438. package/dist/providers/xiaomi.js.map +1 -0
  439. package/dist/providers/xiaomi.models.d.ts +129 -0
  440. package/dist/providers/xiaomi.models.d.ts.map +1 -0
  441. package/dist/providers/xiaomi.models.js +113 -0
  442. package/dist/providers/xiaomi.models.js.map +1 -0
  443. package/dist/providers/zai-coding-cn.d.ts +3 -0
  444. package/dist/providers/zai-coding-cn.d.ts.map +1 -0
  445. package/dist/providers/zai-coding-cn.js +15 -0
  446. package/dist/providers/zai-coding-cn.js.map +1 -0
  447. package/dist/providers/zai-coding-cn.models.d.ts +153 -0
  448. package/dist/providers/zai-coding-cn.models.d.ts.map +1 -0
  449. package/dist/providers/zai-coding-cn.models.js +114 -0
  450. package/dist/providers/zai-coding-cn.models.js.map +1 -0
  451. package/dist/providers/zai.d.ts +3 -0
  452. package/dist/providers/zai.d.ts.map +1 -0
  453. package/dist/providers/zai.js +15 -0
  454. package/dist/providers/zai.js.map +1 -0
  455. package/dist/providers/zai.models.d.ts +153 -0
  456. package/dist/providers/zai.models.d.ts.map +1 -0
  457. package/dist/providers/zai.models.js +114 -0
  458. package/dist/providers/zai.models.js.map +1 -0
  459. package/dist/types.d.ts +67 -8
  460. package/dist/types.d.ts.map +1 -1
  461. package/dist/types.js.map +1 -1
  462. package/dist/utils/headers.d.ts +2 -0
  463. package/dist/utils/headers.d.ts.map +1 -1
  464. package/dist/utils/headers.js +10 -0
  465. package/dist/utils/headers.js.map +1 -1
  466. package/dist/utils/oauth/anthropic.d.ts +2 -0
  467. package/dist/utils/oauth/anthropic.d.ts.map +1 -1
  468. package/dist/utils/oauth/anthropic.js +31 -0
  469. package/dist/utils/oauth/anthropic.js.map +1 -1
  470. package/dist/utils/oauth/github-copilot.d.ts +2 -0
  471. package/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  472. package/dist/utils/oauth/github-copilot.js +33 -2
  473. package/dist/utils/oauth/github-copilot.js.map +1 -1
  474. package/dist/utils/oauth/load.d.ts +5 -0
  475. package/dist/utils/oauth/load.d.ts.map +1 -0
  476. package/dist/utils/oauth/load.js +22 -0
  477. package/dist/utils/oauth/load.js.map +1 -0
  478. package/dist/utils/oauth/openai-codex.d.ts +2 -0
  479. package/dist/utils/oauth/openai-codex.d.ts.map +1 -1
  480. package/dist/utils/oauth/openai-codex.js +49 -0
  481. package/dist/utils/oauth/openai-codex.js.map +1 -1
  482. package/package.json +15 -42
  483. package/dist/api-registry.d.ts +0 -20
  484. package/dist/api-registry.d.ts.map +0 -1
  485. package/dist/api-registry.js +0 -44
  486. package/dist/api-registry.js.map +0 -1
  487. package/dist/base.d.ts +0 -30
  488. package/dist/base.d.ts.map +0 -1
  489. package/dist/base.js +0 -18
  490. package/dist/base.js.map +0 -1
  491. package/dist/providers/cloudflare.d.ts.map +0 -1
  492. package/dist/providers/cloudflare.js.map +0 -1
  493. package/dist/providers/github-copilot-headers.d.ts.map +0 -1
  494. package/dist/providers/github-copilot-headers.js.map +0 -1
  495. package/dist/providers/google-shared.d.ts.map +0 -1
  496. package/dist/providers/google-shared.js.map +0 -1
  497. package/dist/providers/images/openrouter.d.ts.map +0 -1
  498. package/dist/providers/images/openrouter.js.map +0 -1
  499. package/dist/providers/openai-codex-responses.d.ts.map +0 -1
  500. package/dist/providers/openai-codex-responses.js.map +0 -1
  501. package/dist/providers/openai-completions.d.ts.map +0 -1
  502. package/dist/providers/openai-completions.js.map +0 -1
  503. package/dist/providers/openai-prompt-cache.d.ts.map +0 -1
  504. package/dist/providers/openai-prompt-cache.js.map +0 -1
  505. package/dist/providers/openai-responses-shared.d.ts.map +0 -1
  506. package/dist/providers/openai-responses-shared.js.map +0 -1
  507. package/dist/providers/openai-responses.d.ts.map +0 -1
  508. package/dist/providers/openai-responses.js.map +0 -1
  509. package/dist/providers/register-builtins.d.ts +0 -37
  510. package/dist/providers/register-builtins.d.ts.map +0 -1
  511. package/dist/providers/register-builtins.js +0 -191
  512. package/dist/providers/register-builtins.js.map +0 -1
  513. package/dist/providers/simple-options.d.ts.map +0 -1
  514. package/dist/providers/simple-options.js.map +0 -1
  515. package/dist/providers/transform-messages.d.ts.map +0 -1
  516. package/dist/providers/transform-messages.js.map +0 -1
  517. package/dist/stream.d.ts +0 -6
  518. package/dist/stream.d.ts.map +0 -1
  519. package/dist/stream.js +0 -37
  520. package/dist/stream.js.map +0 -1
  521. /package/dist/{providers → api}/github-copilot-headers.d.ts +0 -0
  522. /package/dist/{providers → api}/github-copilot-headers.js +0 -0
  523. /package/dist/{providers → api}/google-shared.d.ts +0 -0
  524. /package/dist/{providers → api}/google-shared.js +0 -0
  525. /package/dist/{providers → api}/openai-prompt-cache.d.ts +0 -0
  526. /package/dist/{providers → api}/openai-prompt-cache.js +0 -0
  527. /package/dist/{providers → api}/openai-responses-shared.d.ts +0 -0
  528. /package/dist/{providers → api}/simple-options.d.ts +0 -0
  529. /package/dist/{providers → api}/simple-options.js +0 -0
  530. /package/dist/{providers → api}/transform-messages.d.ts +0 -0
  531. /package/dist/{providers → api}/transform-messages.js +0 -0
@@ -1,563 +1,15 @@
1
- import { Mistral } from "@mistralai/mistralai";
2
- import { registerApiProvider } from "../api-registry.js";
3
- import { calculateCost, clampThinkingLevel } from "../models.js";
4
- import { AssistantMessageEventStream } from "../utils/event-stream.js";
5
- import { shortHash } from "../utils/hash.js";
6
- import { parseStreamingJson } from "../utils/json-parse.js";
7
- import { sanitizeSurrogates } from "../utils/sanitize-unicode.js";
8
- import { buildBaseOptions } from "./simple-options.js";
9
- import { transformMessages } from "./transform-messages.js";
10
- const MISTRAL_TOOL_CALL_ID_LENGTH = 9;
11
- const MAX_MISTRAL_ERROR_BODY_CHARS = 4000;
12
- /**
13
- * Stream responses from Mistral using `chat.stream`.
14
- */
15
- export const streamMistral = (model, context, options) => {
16
- const stream = new AssistantMessageEventStream();
17
- (async () => {
18
- const output = createOutput(model);
19
- try {
20
- const apiKey = options?.apiKey;
21
- if (!apiKey) {
22
- throw new Error(`No API key for provider: ${model.provider}`);
23
- }
24
- // Intentionally per-request: avoids shared SDK mutable state across concurrent consumers.
25
- const mistral = new Mistral({
26
- apiKey,
27
- serverURL: model.baseUrl,
28
- });
29
- const normalizeMistralToolCallId = createMistralToolCallIdNormalizer();
30
- const transformedMessages = transformMessages(context.messages, model, (id) => normalizeMistralToolCallId(id));
31
- let payload = buildChatPayload(model, context, transformedMessages, options);
32
- const nextPayload = await options?.onPayload?.(payload, model);
33
- if (nextPayload !== undefined) {
34
- payload = nextPayload;
35
- }
36
- const mistralStream = await mistral.chat.stream(payload, buildRequestOptions(model, options));
37
- stream.push({ type: "start", partial: output });
38
- await consumeChatStream(model, output, stream, mistralStream);
39
- if (options?.signal?.aborted) {
40
- throw new Error("Request was aborted");
41
- }
42
- if (output.stopReason === "aborted" || output.stopReason === "error") {
43
- throw new Error("An unknown error occurred");
44
- }
45
- stream.push({ type: "done", reason: output.stopReason, message: output });
46
- stream.end();
47
- }
48
- catch (error) {
49
- for (const block of output.content) {
50
- // partialArgs is only a streaming scratch buffer; never persist it.
51
- delete block.partialArgs;
52
- }
53
- output.stopReason = options?.signal?.aborted ? "aborted" : "error";
54
- output.errorMessage = formatMistralError(error);
55
- stream.push({ type: "error", reason: output.stopReason, error: output });
56
- stream.end();
57
- }
58
- })();
59
- return stream;
60
- };
61
- /**
62
- * Maps provider-agnostic `SimpleStreamOptions` to Mistral options.
63
- */
64
- export const streamSimpleMistral = (model, context, options) => {
65
- const apiKey = options?.apiKey;
66
- if (!apiKey) {
67
- throw new Error(`No API key for provider: ${model.provider}`);
68
- }
69
- const base = buildBaseOptions(model, options, apiKey);
70
- const clampedReasoning = options?.reasoning ? clampThinkingLevel(model, options.reasoning) : undefined;
71
- const reasoning = clampedReasoning === "off" ? undefined : clampedReasoning;
72
- const shouldUseReasoning = model.reasoning && reasoning !== undefined;
73
- return streamMistral(model, context, {
74
- ...base,
75
- promptMode: shouldUseReasoning && usesPromptModeReasoning(model) ? "reasoning" : undefined,
76
- reasoningEffort: shouldUseReasoning && usesReasoningEffort(model) ? mapReasoningEffort(model, reasoning) : undefined,
1
+ import { mistralConversationsApi } from "../api/mistral-conversations.lazy.js";
2
+ import { envApiKeyAuth } from "../auth/helpers.js";
3
+ import { createProvider } from "../models.js";
4
+ import { MISTRAL_MODELS } from "./mistral.models.js";
5
+ export function mistralProvider() {
6
+ return createProvider({
7
+ id: "mistral",
8
+ name: "Mistral",
9
+ baseUrl: "https://api.mistral.ai",
10
+ auth: { apiKey: envApiKeyAuth("Mistral API key", ["MISTRAL_API_KEY"]) },
11
+ models: Object.values(MISTRAL_MODELS),
12
+ api: mistralConversationsApi(),
77
13
  });
78
- };
79
- export function register() {
80
- registerApiProvider({
81
- api: "mistral-conversations",
82
- stream: streamMistral,
83
- streamSimple: streamSimpleMistral,
84
- });
85
- }
86
- function createOutput(model) {
87
- return {
88
- role: "assistant",
89
- content: [],
90
- api: model.api,
91
- provider: model.provider,
92
- model: model.id,
93
- usage: {
94
- input: 0,
95
- output: 0,
96
- cacheRead: 0,
97
- cacheWrite: 0,
98
- totalTokens: 0,
99
- cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
100
- },
101
- stopReason: "stop",
102
- timestamp: Date.now(),
103
- };
104
- }
105
- function createMistralToolCallIdNormalizer() {
106
- const idMap = new Map();
107
- const reverseMap = new Map();
108
- return (id) => {
109
- const existing = idMap.get(id);
110
- if (existing)
111
- return existing;
112
- let attempt = 0;
113
- while (true) {
114
- const candidate = deriveMistralToolCallId(id, attempt);
115
- const owner = reverseMap.get(candidate);
116
- if (!owner || owner === id) {
117
- idMap.set(id, candidate);
118
- reverseMap.set(candidate, id);
119
- return candidate;
120
- }
121
- attempt++;
122
- }
123
- };
124
- }
125
- function deriveMistralToolCallId(id, attempt) {
126
- const normalized = id.replace(/[^a-zA-Z0-9]/g, "");
127
- if (attempt === 0 && normalized.length === MISTRAL_TOOL_CALL_ID_LENGTH)
128
- return normalized;
129
- const seedBase = normalized || id;
130
- const seed = attempt === 0 ? seedBase : `${seedBase}:${attempt}`;
131
- return shortHash(seed)
132
- .replace(/[^a-zA-Z0-9]/g, "")
133
- .slice(0, MISTRAL_TOOL_CALL_ID_LENGTH);
134
- }
135
- function formatMistralError(error) {
136
- if (error instanceof Error) {
137
- const sdkError = error;
138
- const statusCode = typeof sdkError.statusCode === "number" ? sdkError.statusCode : undefined;
139
- const bodyText = typeof sdkError.body === "string" ? sdkError.body.trim() : undefined;
140
- if (statusCode !== undefined && bodyText) {
141
- return `Mistral API error (${statusCode}): ${truncateErrorText(bodyText, MAX_MISTRAL_ERROR_BODY_CHARS)}`;
142
- }
143
- if (statusCode !== undefined)
144
- return `Mistral API error (${statusCode}): ${error.message}`;
145
- return error.message;
146
- }
147
- return safeJsonStringify(error);
148
- }
149
- function truncateErrorText(text, maxChars) {
150
- if (text.length <= maxChars)
151
- return text;
152
- return `${text.slice(0, maxChars)}... [truncated ${text.length - maxChars} chars]`;
153
- }
154
- function safeJsonStringify(value) {
155
- try {
156
- const serialized = JSON.stringify(value);
157
- return serialized === undefined ? String(value) : serialized;
158
- }
159
- catch {
160
- return String(value);
161
- }
162
- }
163
- function buildRequestOptions(model, options) {
164
- const requestOptions = {
165
- retries: { strategy: "none" },
166
- };
167
- if (options?.signal)
168
- requestOptions.signal = options.signal;
169
- const headers = {};
170
- if (model.headers)
171
- Object.assign(headers, model.headers);
172
- if (options?.headers)
173
- Object.assign(headers, options.headers);
174
- // Mistral infrastructure uses `x-affinity` for KV-cache reuse (prefix caching).
175
- // Respect explicit caller-provided header values.
176
- if (shouldUsePromptCaching(options) && !headers["x-affinity"]) {
177
- headers["x-affinity"] = options.sessionId;
178
- }
179
- if (Object.keys(headers).length > 0) {
180
- requestOptions.headers = headers;
181
- }
182
- return requestOptions;
183
- }
184
- function buildChatPayload(model, context, messages, options) {
185
- const payload = {
186
- model: model.id,
187
- stream: true,
188
- messages: toChatMessages(messages, model.input.includes("image")),
189
- };
190
- if (context.tools?.length)
191
- payload.tools = toFunctionTools(context.tools);
192
- if (options?.temperature !== undefined)
193
- payload.temperature = options.temperature;
194
- if (options?.maxTokens !== undefined)
195
- payload.maxTokens = options.maxTokens;
196
- if (options?.toolChoice)
197
- payload.toolChoice = mapToolChoice(options.toolChoice);
198
- if (options?.promptMode)
199
- payload.promptMode = options.promptMode;
200
- if (options?.reasoningEffort)
201
- payload.reasoningEffort = options.reasoningEffort;
202
- if (shouldUsePromptCaching(options))
203
- payload.promptCacheKey = options.sessionId;
204
- if (context.systemPrompt) {
205
- payload.messages.unshift({
206
- role: "system",
207
- content: sanitizeSurrogates(context.systemPrompt),
208
- });
209
- }
210
- return payload;
211
- }
212
- function shouldUsePromptCaching(options) {
213
- return options?.cacheRetention !== "none" && !!options?.sessionId;
214
- }
215
- function getMistralCachedPromptTokens(usage, promptTokens) {
216
- const rawUsage = usage;
217
- const rawCachedTokens = rawUsage.promptTokensDetails?.cachedTokens ??
218
- rawUsage.prompt_tokens_details?.cached_tokens ??
219
- rawUsage.promptTokenDetails?.cachedTokens ??
220
- rawUsage.prompt_token_details?.cached_tokens ??
221
- rawUsage.numCachedTokens ??
222
- rawUsage.num_cached_tokens ??
223
- 0;
224
- const cachedTokens = typeof rawCachedTokens === "number" && Number.isFinite(rawCachedTokens) ? rawCachedTokens : 0;
225
- return Math.min(promptTokens, Math.max(0, cachedTokens));
226
- }
227
- async function consumeChatStream(model, output, stream, mistralStream) {
228
- let currentBlock = null;
229
- const blocks = output.content;
230
- const blockIndex = () => blocks.length - 1;
231
- const toolBlocksByKey = new Map();
232
- const finishCurrentBlock = (block) => {
233
- if (!block)
234
- return;
235
- if (block.type === "text") {
236
- stream.push({
237
- type: "text_end",
238
- contentIndex: blockIndex(),
239
- content: block.text,
240
- partial: output,
241
- });
242
- return;
243
- }
244
- if (block.type === "thinking") {
245
- stream.push({
246
- type: "thinking_end",
247
- contentIndex: blockIndex(),
248
- content: block.thinking,
249
- partial: output,
250
- });
251
- }
252
- };
253
- for await (const event of mistralStream) {
254
- const chunk = event.data;
255
- // Mistral's streamed CompletionChunk carries an id field. Keep the first non-empty one,
256
- // mirroring how OpenAI-style streaming exposes a stable response identifier per stream.
257
- output.responseId ||= chunk.id;
258
- if (chunk.usage) {
259
- const promptTokens = chunk.usage.promptTokens || 0;
260
- const cachedPromptTokens = getMistralCachedPromptTokens(chunk.usage, promptTokens);
261
- output.usage.input = Math.max(0, promptTokens - cachedPromptTokens);
262
- output.usage.output = chunk.usage.completionTokens || 0;
263
- output.usage.cacheRead = cachedPromptTokens;
264
- output.usage.cacheWrite = 0;
265
- output.usage.totalTokens =
266
- chunk.usage.totalTokens ||
267
- output.usage.input + output.usage.output + output.usage.cacheRead + output.usage.cacheWrite;
268
- calculateCost(model, output.usage);
269
- }
270
- const choice = chunk.choices[0];
271
- if (!choice)
272
- continue;
273
- if (choice.finishReason) {
274
- output.stopReason = mapChatStopReason(choice.finishReason);
275
- }
276
- const delta = choice.delta;
277
- if (delta.content !== null && delta.content !== undefined) {
278
- const contentItems = typeof delta.content === "string" ? [delta.content] : delta.content;
279
- for (const item of contentItems) {
280
- if (typeof item === "string") {
281
- const textDelta = sanitizeSurrogates(item);
282
- if (!currentBlock || currentBlock.type !== "text") {
283
- finishCurrentBlock(currentBlock);
284
- currentBlock = { type: "text", text: "" };
285
- output.content.push(currentBlock);
286
- stream.push({ type: "text_start", contentIndex: blockIndex(), partial: output });
287
- }
288
- currentBlock.text += textDelta;
289
- stream.push({
290
- type: "text_delta",
291
- contentIndex: blockIndex(),
292
- delta: textDelta,
293
- partial: output,
294
- });
295
- continue;
296
- }
297
- if (item.type === "thinking") {
298
- const deltaText = item.thinking
299
- .map((part) => ("text" in part ? part.text : ""))
300
- .filter((text) => text.length > 0)
301
- .join("");
302
- const thinkingDelta = sanitizeSurrogates(deltaText);
303
- if (!thinkingDelta)
304
- continue;
305
- if (!currentBlock || currentBlock.type !== "thinking") {
306
- finishCurrentBlock(currentBlock);
307
- currentBlock = { type: "thinking", thinking: "" };
308
- output.content.push(currentBlock);
309
- stream.push({ type: "thinking_start", contentIndex: blockIndex(), partial: output });
310
- }
311
- currentBlock.thinking += thinkingDelta;
312
- stream.push({
313
- type: "thinking_delta",
314
- contentIndex: blockIndex(),
315
- delta: thinkingDelta,
316
- partial: output,
317
- });
318
- continue;
319
- }
320
- if (item.type === "text") {
321
- const textDelta = sanitizeSurrogates(item.text);
322
- if (!currentBlock || currentBlock.type !== "text") {
323
- finishCurrentBlock(currentBlock);
324
- currentBlock = { type: "text", text: "" };
325
- output.content.push(currentBlock);
326
- stream.push({ type: "text_start", contentIndex: blockIndex(), partial: output });
327
- }
328
- currentBlock.text += textDelta;
329
- stream.push({
330
- type: "text_delta",
331
- contentIndex: blockIndex(),
332
- delta: textDelta,
333
- partial: output,
334
- });
335
- }
336
- }
337
- }
338
- const toolCalls = delta.toolCalls || [];
339
- for (const toolCall of toolCalls) {
340
- if (currentBlock) {
341
- finishCurrentBlock(currentBlock);
342
- currentBlock = null;
343
- }
344
- const callId = toolCall.id && toolCall.id !== "null"
345
- ? toolCall.id
346
- : deriveMistralToolCallId(`toolcall:${toolCall.index ?? 0}`, 0);
347
- const key = `${callId}:${toolCall.index || 0}`;
348
- const existingIndex = toolBlocksByKey.get(key);
349
- let block;
350
- if (existingIndex !== undefined) {
351
- const existing = output.content[existingIndex];
352
- if (existing?.type === "toolCall") {
353
- block = existing;
354
- }
355
- }
356
- if (!block) {
357
- block = {
358
- type: "toolCall",
359
- id: callId,
360
- name: toolCall.function.name,
361
- arguments: {},
362
- partialArgs: "",
363
- };
364
- output.content.push(block);
365
- toolBlocksByKey.set(key, output.content.length - 1);
366
- stream.push({ type: "toolcall_start", contentIndex: output.content.length - 1, partial: output });
367
- }
368
- const argsDelta = typeof toolCall.function.arguments === "string"
369
- ? toolCall.function.arguments
370
- : JSON.stringify(toolCall.function.arguments || {});
371
- block.partialArgs = (block.partialArgs || "") + argsDelta;
372
- block.arguments = parseStreamingJson(block.partialArgs);
373
- stream.push({
374
- type: "toolcall_delta",
375
- contentIndex: toolBlocksByKey.get(key),
376
- delta: argsDelta,
377
- partial: output,
378
- });
379
- }
380
- }
381
- finishCurrentBlock(currentBlock);
382
- for (const index of toolBlocksByKey.values()) {
383
- const block = output.content[index];
384
- if (block.type !== "toolCall")
385
- continue;
386
- const toolBlock = block;
387
- toolBlock.arguments = parseStreamingJson(toolBlock.partialArgs);
388
- // Finalize in-place and strip the scratch buffer so replay only
389
- // carries parsed arguments.
390
- delete toolBlock.partialArgs;
391
- stream.push({
392
- type: "toolcall_end",
393
- contentIndex: index,
394
- toolCall: toolBlock,
395
- partial: output,
396
- });
397
- }
398
- }
399
- function toFunctionTools(tools) {
400
- return tools.map((tool) => ({
401
- type: "function",
402
- function: {
403
- name: tool.name,
404
- description: tool.description,
405
- parameters: stripSymbolKeys(tool.parameters),
406
- strict: false,
407
- },
408
- }));
409
- }
410
- function stripSymbolKeys(value) {
411
- if (Array.isArray(value)) {
412
- return value.map((item) => stripSymbolKeys(item));
413
- }
414
- if (value && typeof value === "object") {
415
- const result = {};
416
- for (const [key, entry] of Object.entries(value)) {
417
- result[key] = stripSymbolKeys(entry);
418
- }
419
- return result;
420
- }
421
- return value;
422
- }
423
- function toChatMessages(messages, supportsImages) {
424
- const result = [];
425
- for (const msg of messages) {
426
- if (msg.role === "user") {
427
- if (typeof msg.content === "string") {
428
- result.push({ role: "user", content: sanitizeSurrogates(msg.content) });
429
- continue;
430
- }
431
- const hadImages = msg.content.some((item) => item.type === "image");
432
- const content = msg.content
433
- .filter((item) => item.type === "text" || supportsImages)
434
- .map((item) => {
435
- if (item.type === "text")
436
- return { type: "text", text: sanitizeSurrogates(item.text) };
437
- return { type: "image_url", imageUrl: `data:${item.mimeType};base64,${item.data}` };
438
- });
439
- if (content.length > 0) {
440
- result.push({ role: "user", content });
441
- continue;
442
- }
443
- if (hadImages && !supportsImages) {
444
- result.push({ role: "user", content: "(image omitted: model does not support images)" });
445
- }
446
- continue;
447
- }
448
- if (msg.role === "assistant") {
449
- const contentParts = [];
450
- const toolCalls = [];
451
- for (const block of msg.content) {
452
- if (block.type === "text") {
453
- if (block.text.trim().length > 0) {
454
- contentParts.push({ type: "text", text: sanitizeSurrogates(block.text) });
455
- }
456
- continue;
457
- }
458
- if (block.type === "thinking") {
459
- if (block.thinking.trim().length > 0) {
460
- contentParts.push({
461
- type: "thinking",
462
- thinking: [{ type: "text", text: sanitizeSurrogates(block.thinking) }],
463
- });
464
- }
465
- continue;
466
- }
467
- toolCalls.push({
468
- id: block.id,
469
- type: "function",
470
- function: { name: block.name, arguments: JSON.stringify(block.arguments || {}) },
471
- });
472
- }
473
- const assistantMessage = { role: "assistant" };
474
- if (contentParts.length > 0)
475
- assistantMessage.content = contentParts;
476
- if (toolCalls.length > 0)
477
- assistantMessage.toolCalls = toolCalls;
478
- if (contentParts.length > 0 || toolCalls.length > 0)
479
- result.push(assistantMessage);
480
- continue;
481
- }
482
- const toolContent = [];
483
- const textResult = msg.content
484
- .filter((part) => part.type === "text")
485
- .map((part) => (part.type === "text" ? sanitizeSurrogates(part.text) : ""))
486
- .join("\n");
487
- const hasImages = msg.content.some((part) => part.type === "image");
488
- const toolText = buildToolResultText(textResult, hasImages, supportsImages, msg.isError);
489
- toolContent.push({ type: "text", text: toolText });
490
- for (const part of msg.content) {
491
- if (!supportsImages)
492
- continue;
493
- if (part.type !== "image")
494
- continue;
495
- toolContent.push({
496
- type: "image_url",
497
- imageUrl: `data:${part.mimeType};base64,${part.data}`,
498
- });
499
- }
500
- result.push({
501
- role: "tool",
502
- toolCallId: msg.toolCallId,
503
- name: msg.toolName,
504
- content: toolContent,
505
- });
506
- }
507
- return result;
508
- }
509
- function buildToolResultText(text, hasImages, supportsImages, isError) {
510
- const trimmed = text.trim();
511
- const errorPrefix = isError ? "[tool error] " : "";
512
- if (trimmed.length > 0) {
513
- const imageSuffix = hasImages && !supportsImages ? "\n[tool image omitted: model does not support images]" : "";
514
- return `${errorPrefix}${trimmed}${imageSuffix}`;
515
- }
516
- if (hasImages) {
517
- if (supportsImages) {
518
- return isError ? "[tool error] (see attached image)" : "(see attached image)";
519
- }
520
- return isError
521
- ? "[tool error] (image omitted: model does not support images)"
522
- : "(image omitted: model does not support images)";
523
- }
524
- return isError ? "[tool error] (no tool output)" : "(no tool output)";
525
- }
526
- function usesReasoningEffort(model) {
527
- return model.id === "mistral-small-2603" || model.id === "mistral-small-latest" || model.id === "mistral-medium-3.5";
528
- }
529
- function usesPromptModeReasoning(model) {
530
- return model.reasoning && !usesReasoningEffort(model);
531
- }
532
- function mapReasoningEffort(model, level) {
533
- return (model.thinkingLevelMap?.[level] ?? "high");
534
- }
535
- function mapToolChoice(choice) {
536
- if (!choice)
537
- return undefined;
538
- if (choice === "auto" || choice === "none" || choice === "any" || choice === "required") {
539
- return choice;
540
- }
541
- return {
542
- type: "function",
543
- function: { name: choice.function.name },
544
- };
545
- }
546
- function mapChatStopReason(reason) {
547
- if (reason === null)
548
- return "stop";
549
- switch (reason) {
550
- case "stop":
551
- return "stop";
552
- case "length":
553
- case "model_length":
554
- return "length";
555
- case "tool_calls":
556
- return "toolUse";
557
- case "error":
558
- return "error";
559
- default:
560
- return "stop";
561
- }
562
14
  }
563
15
  //# sourceMappingURL=mistral.js.map