@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,976 +1,20 @@
1
- import Anthropic from "@anthropic-ai/sdk";
2
- import { registerApiProvider } from "../api-registry.js";
3
- import { calculateCost } from "../models.js";
4
- import { AssistantMessageEventStream } from "../utils/event-stream.js";
5
- import { headersToRecord } from "../utils/headers.js";
6
- import { parseJsonWithRepair, parseStreamingJson } from "../utils/json-parse.js";
7
- import { getProviderEnvValue } from "../utils/provider-env.js";
8
- import { sanitizeSurrogates } from "../utils/sanitize-unicode.js";
9
- import { resolveCloudflareBaseUrl } from "./cloudflare.js";
10
- import { buildCopilotDynamicHeaders, hasCopilotVisionInput } from "./github-copilot-headers.js";
11
- import { adjustMaxTokensForThinking, buildBaseOptions } from "./simple-options.js";
12
- import { transformMessages } from "./transform-messages.js";
13
- /**
14
- * Resolve cache retention preference.
15
- * Defaults to "short" and uses PI_CACHE_RETENTION for backward compatibility.
16
- */
17
- function resolveCacheRetention(cacheRetention, env) {
18
- if (cacheRetention) {
19
- return cacheRetention;
20
- }
21
- if (getProviderEnvValue("PI_CACHE_RETENTION", env) === "long") {
22
- return "long";
23
- }
24
- return "short";
25
- }
26
- function getCacheControl(model, cacheRetention, env) {
27
- const retention = resolveCacheRetention(cacheRetention, env);
28
- if (retention === "none") {
29
- return { retention };
30
- }
31
- const ttl = retention === "long" && getAnthropicCompat(model).supportsLongCacheRetention ? "1h" : undefined;
32
- return {
33
- retention,
34
- cacheControl: { type: "ephemeral", ...(ttl && { ttl }) },
35
- };
36
- }
37
- // Stealth mode: Mimic Claude Code's tool naming exactly
38
- const claudeCodeVersion = "2.1.75";
39
- // Claude Code 2.x tool names (canonical casing)
40
- // Source: https://cchistory.mariozechner.at/data/prompts-2.1.11.md
41
- // To update: https://github.com/badlogic/cchistory
42
- const claudeCodeTools = [
43
- "Read",
44
- "Write",
45
- "Edit",
46
- "Bash",
47
- "Grep",
48
- "Glob",
49
- "AskUserQuestion",
50
- "EnterPlanMode",
51
- "ExitPlanMode",
52
- "KillShell",
53
- "NotebookEdit",
54
- "Skill",
55
- "Task",
56
- "TaskOutput",
57
- "TodoWrite",
58
- "WebFetch",
59
- "WebSearch",
60
- ];
61
- const ccToolLookup = new Map(claudeCodeTools.map((t) => [t.toLowerCase(), t]));
62
- // Convert tool name to CC canonical casing if it matches (case-insensitive)
63
- const toClaudeCodeName = (name) => ccToolLookup.get(name.toLowerCase()) ?? name;
64
- const fromClaudeCodeName = (name, tools) => {
65
- if (tools && tools.length > 0) {
66
- const lowerName = name.toLowerCase();
67
- const matchedTool = tools.find((tool) => tool.name.toLowerCase() === lowerName);
68
- if (matchedTool)
69
- return matchedTool.name;
70
- }
71
- return name;
72
- };
73
- /**
74
- * Convert content blocks to Anthropic API format
75
- */
76
- function convertContentBlocks(content) {
77
- // If only text blocks, return as concatenated string for simplicity
78
- const hasImages = content.some((c) => c.type === "image");
79
- if (!hasImages) {
80
- return sanitizeSurrogates(content.map((c) => c.text).join("\n"));
81
- }
82
- // If we have images, convert to content block array
83
- const blocks = content.map((block) => {
84
- if (block.type === "text") {
85
- return {
86
- type: "text",
87
- text: sanitizeSurrogates(block.text),
88
- };
89
- }
90
- return {
91
- type: "image",
92
- source: {
93
- type: "base64",
94
- media_type: block.mimeType,
95
- data: block.data,
96
- },
97
- };
98
- });
99
- // If only images (no text), add placeholder text block
100
- const hasText = blocks.some((b) => b.type === "text");
101
- if (!hasText) {
102
- blocks.unshift({
103
- type: "text",
104
- text: "(see attached image)",
105
- });
106
- }
107
- return blocks;
108
- }
109
- const FINE_GRAINED_TOOL_STREAMING_BETA = "fine-grained-tool-streaming-2025-05-14";
110
- const INTERLEAVED_THINKING_BETA = "interleaved-thinking-2025-05-14";
111
- function getAnthropicCompat(model) {
112
- // Auto-detect session affinity and cache control support from provider
113
- const isFireworks = model.provider === "fireworks";
114
- const isCloudflareAiGatewayAnthropic = model.provider === "cloudflare-ai-gateway" && model.baseUrl.includes("anthropic");
115
- return {
116
- supportsEagerToolInputStreaming: model.compat?.supportsEagerToolInputStreaming ?? !isFireworks,
117
- supportsLongCacheRetention: model.compat?.supportsLongCacheRetention ?? !isFireworks,
118
- sendSessionAffinityHeaders: model.compat?.sendSessionAffinityHeaders ?? !!(isFireworks || isCloudflareAiGatewayAnthropic),
119
- supportsCacheControlOnTools: model.compat?.supportsCacheControlOnTools ?? !isFireworks,
120
- supportsTemperature: model.compat?.supportsTemperature ?? true,
121
- allowEmptySignature: model.compat?.allowEmptySignature ?? false,
122
- };
123
- }
124
- function mergeHeaders(...headerSources) {
125
- const merged = {};
126
- for (const headers of headerSources) {
127
- if (headers) {
128
- Object.assign(merged, headers);
129
- }
130
- }
131
- return merged;
132
- }
133
- const ANTHROPIC_MESSAGE_EVENTS = new Set([
134
- "message_start",
135
- "message_delta",
136
- "message_stop",
137
- "content_block_start",
138
- "content_block_delta",
139
- "content_block_stop",
140
- ]);
141
- function flushSseEvent(state) {
142
- if (!state.event && state.data.length === 0) {
143
- return null;
144
- }
145
- const event = {
146
- event: state.event,
147
- data: state.data.join("\n"),
148
- raw: [...state.raw],
149
- };
150
- state.event = null;
151
- state.data = [];
152
- state.raw = [];
153
- return event;
154
- }
155
- function decodeSseLine(line, state) {
156
- if (line === "") {
157
- return flushSseEvent(state);
158
- }
159
- state.raw.push(line);
160
- if (line.startsWith(":")) {
161
- return null;
162
- }
163
- const delimiterIndex = line.indexOf(":");
164
- const fieldName = delimiterIndex === -1 ? line : line.slice(0, delimiterIndex);
165
- let value = delimiterIndex === -1 ? "" : line.slice(delimiterIndex + 1);
166
- if (value.startsWith(" ")) {
167
- value = value.slice(1);
168
- }
169
- if (fieldName === "event") {
170
- state.event = value;
171
- }
172
- else if (fieldName === "data") {
173
- state.data.push(value);
174
- }
175
- return null;
176
- }
177
- function nextLineBreakIndex(text) {
178
- const carriageReturnIndex = text.indexOf("\r");
179
- const newlineIndex = text.indexOf("\n");
180
- if (carriageReturnIndex === -1) {
181
- return newlineIndex;
182
- }
183
- if (newlineIndex === -1) {
184
- return carriageReturnIndex;
185
- }
186
- return Math.min(carriageReturnIndex, newlineIndex);
187
- }
188
- function consumeLine(text) {
189
- const lineBreakIndex = nextLineBreakIndex(text);
190
- if (lineBreakIndex === -1) {
191
- return null;
192
- }
193
- let nextIndex = lineBreakIndex + 1;
194
- if (text[lineBreakIndex] === "\r" && text[nextIndex] === "\n") {
195
- nextIndex += 1;
196
- }
197
- return {
198
- line: text.slice(0, lineBreakIndex),
199
- rest: text.slice(nextIndex),
200
- };
201
- }
202
- async function* iterateSseMessages(body, signal) {
203
- const reader = body.getReader();
204
- const decoder = new TextDecoder();
205
- const state = { event: null, data: [], raw: [] };
206
- let buffer = "";
207
- try {
208
- while (true) {
209
- if (signal?.aborted) {
210
- throw new Error("Request was aborted");
211
- }
212
- const { value, done } = await reader.read();
213
- if (done) {
214
- break;
215
- }
216
- buffer += decoder.decode(value, { stream: true });
217
- let consumed = consumeLine(buffer);
218
- while (consumed) {
219
- buffer = consumed.rest;
220
- const event = decodeSseLine(consumed.line, state);
221
- if (event) {
222
- yield event;
223
- }
224
- consumed = consumeLine(buffer);
225
- }
226
- }
227
- buffer += decoder.decode();
228
- let consumed = consumeLine(buffer);
229
- while (consumed) {
230
- buffer = consumed.rest;
231
- const event = decodeSseLine(consumed.line, state);
232
- if (event) {
233
- yield event;
234
- }
235
- consumed = consumeLine(buffer);
236
- }
237
- if (buffer.length > 0) {
238
- const event = decodeSseLine(buffer, state);
239
- if (event) {
240
- yield event;
241
- }
242
- }
243
- const trailingEvent = flushSseEvent(state);
244
- if (trailingEvent) {
245
- yield trailingEvent;
246
- }
247
- }
248
- finally {
249
- reader.releaseLock();
250
- }
251
- }
252
- async function* iterateAnthropicEvents(response, signal) {
253
- if (!response.body) {
254
- throw new Error("Attempted to iterate over an Anthropic response with no body");
255
- }
256
- let sawMessageStart = false;
257
- let sawMessageEnd = false;
258
- for await (const sse of iterateSseMessages(response.body, signal)) {
259
- if (sse.event === "error") {
260
- throw new Error(sse.data);
261
- }
262
- if (!ANTHROPIC_MESSAGE_EVENTS.has(sse.event ?? "")) {
263
- continue;
264
- }
265
- try {
266
- const event = parseJsonWithRepair(sse.data);
267
- if (event.type === "message_start") {
268
- sawMessageStart = true;
269
- }
270
- else if (event.type === "message_stop") {
271
- sawMessageEnd = true;
272
- }
273
- yield event;
274
- }
275
- catch (error) {
276
- const message = error instanceof Error ? error.message : String(error);
277
- throw new Error(`Could not parse Anthropic SSE event ${sse.event}: ${message}; data=${sse.data}; raw=${sse.raw.join("\\n")}`);
278
- }
279
- }
280
- if (sawMessageStart && !sawMessageEnd) {
281
- throw new Error("Anthropic stream ended before message_stop");
282
- }
283
- }
284
- export const streamAnthropic = (model, context, options) => {
285
- const stream = new AssistantMessageEventStream();
286
- (async () => {
287
- const output = {
288
- role: "assistant",
289
- content: [],
290
- api: model.api,
291
- provider: model.provider,
292
- model: model.id,
293
- usage: {
294
- input: 0,
295
- output: 0,
296
- cacheRead: 0,
297
- cacheWrite: 0,
298
- totalTokens: 0,
299
- cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
300
- },
301
- stopReason: "stop",
302
- timestamp: Date.now(),
303
- };
304
- try {
305
- let client;
306
- let isOAuth;
307
- if (options?.client) {
308
- client = options.client;
309
- isOAuth = false;
310
- }
311
- else {
312
- const apiKey = options?.apiKey;
313
- if (!apiKey) {
314
- throw new Error(`No API key for provider: ${model.provider}`);
315
- }
316
- let copilotDynamicHeaders;
317
- if (model.provider === "github-copilot") {
318
- const hasImages = hasCopilotVisionInput(context.messages);
319
- copilotDynamicHeaders = buildCopilotDynamicHeaders({
320
- messages: context.messages,
321
- hasImages,
322
- });
323
- }
324
- const cacheRetention = resolveCacheRetention(options?.cacheRetention, options?.env);
325
- const cacheSessionId = cacheRetention === "none" ? undefined : options?.sessionId;
326
- const created = createClient(model, apiKey, options?.interleavedThinking ?? true, shouldUseFineGrainedToolStreamingBeta(model, context), options?.headers, copilotDynamicHeaders, cacheSessionId, options?.env);
327
- client = created.client;
328
- isOAuth = created.isOAuthToken;
329
- }
330
- let params = buildParams(model, context, isOAuth, options);
331
- const nextParams = await options?.onPayload?.(params, model);
332
- if (nextParams !== undefined) {
333
- params = nextParams;
334
- }
335
- const requestOptions = {
336
- ...(options?.signal ? { signal: options.signal } : {}),
337
- ...(options?.timeoutMs !== undefined ? { timeout: options.timeoutMs } : {}),
338
- maxRetries: options?.maxRetries ?? 0,
339
- };
340
- const response = await client.messages.create({ ...params, stream: true }, requestOptions).asResponse();
341
- await options?.onResponse?.({ status: response.status, headers: headersToRecord(response.headers) }, model);
342
- stream.push({ type: "start", partial: output });
343
- const blocks = output.content;
344
- for await (const event of iterateAnthropicEvents(response, options?.signal)) {
345
- if (event.type === "message_start") {
346
- output.responseId = event.message.id;
347
- // Capture initial token usage from message_start event
348
- // This ensures we have input token counts even if the stream is aborted early
349
- output.usage.input = event.message.usage.input_tokens || 0;
350
- output.usage.output = event.message.usage.output_tokens || 0;
351
- output.usage.cacheRead = event.message.usage.cache_read_input_tokens || 0;
352
- output.usage.cacheWrite = event.message.usage.cache_creation_input_tokens || 0;
353
- output.usage.cacheWrite1h = event.message.usage.cache_creation?.ephemeral_1h_input_tokens || 0;
354
- // Anthropic doesn't provide total_tokens, compute from components
355
- output.usage.totalTokens =
356
- output.usage.input + output.usage.output + output.usage.cacheRead + output.usage.cacheWrite;
357
- calculateCost(model, output.usage);
358
- }
359
- else if (event.type === "content_block_start") {
360
- if (event.content_block.type === "text") {
361
- const block = {
362
- type: "text",
363
- text: "",
364
- index: event.index,
365
- };
366
- output.content.push(block);
367
- stream.push({ type: "text_start", contentIndex: output.content.length - 1, partial: output });
368
- }
369
- else if (event.content_block.type === "thinking") {
370
- const block = {
371
- type: "thinking",
372
- thinking: "",
373
- thinkingSignature: "",
374
- index: event.index,
375
- };
376
- output.content.push(block);
377
- stream.push({ type: "thinking_start", contentIndex: output.content.length - 1, partial: output });
378
- }
379
- else if (event.content_block.type === "redacted_thinking") {
380
- const block = {
381
- type: "thinking",
382
- thinking: "[Reasoning redacted]",
383
- thinkingSignature: event.content_block.data,
384
- redacted: true,
385
- index: event.index,
386
- };
387
- output.content.push(block);
388
- stream.push({ type: "thinking_start", contentIndex: output.content.length - 1, partial: output });
389
- }
390
- else if (event.content_block.type === "tool_use") {
391
- const block = {
392
- type: "toolCall",
393
- id: event.content_block.id,
394
- name: isOAuth
395
- ? fromClaudeCodeName(event.content_block.name, context.tools)
396
- : event.content_block.name,
397
- arguments: event.content_block.input ?? {},
398
- partialJson: "",
399
- index: event.index,
400
- };
401
- output.content.push(block);
402
- stream.push({ type: "toolcall_start", contentIndex: output.content.length - 1, partial: output });
403
- }
404
- }
405
- else if (event.type === "content_block_delta") {
406
- if (event.delta.type === "text_delta") {
407
- const index = blocks.findIndex((b) => b.index === event.index);
408
- const block = blocks[index];
409
- if (block && block.type === "text") {
410
- block.text += event.delta.text;
411
- stream.push({
412
- type: "text_delta",
413
- contentIndex: index,
414
- delta: event.delta.text,
415
- partial: output,
416
- });
417
- }
418
- }
419
- else if (event.delta.type === "thinking_delta") {
420
- const index = blocks.findIndex((b) => b.index === event.index);
421
- const block = blocks[index];
422
- if (block && block.type === "thinking") {
423
- block.thinking += event.delta.thinking;
424
- stream.push({
425
- type: "thinking_delta",
426
- contentIndex: index,
427
- delta: event.delta.thinking,
428
- partial: output,
429
- });
430
- }
431
- }
432
- else if (event.delta.type === "input_json_delta") {
433
- const index = blocks.findIndex((b) => b.index === event.index);
434
- const block = blocks[index];
435
- if (block && block.type === "toolCall") {
436
- block.partialJson += event.delta.partial_json;
437
- block.arguments = parseStreamingJson(block.partialJson);
438
- stream.push({
439
- type: "toolcall_delta",
440
- contentIndex: index,
441
- delta: event.delta.partial_json,
442
- partial: output,
443
- });
444
- }
445
- }
446
- else if (event.delta.type === "signature_delta") {
447
- const index = blocks.findIndex((b) => b.index === event.index);
448
- const block = blocks[index];
449
- if (block && block.type === "thinking") {
450
- block.thinkingSignature = block.thinkingSignature || "";
451
- block.thinkingSignature += event.delta.signature;
452
- }
453
- }
454
- }
455
- else if (event.type === "content_block_stop") {
456
- const index = blocks.findIndex((b) => b.index === event.index);
457
- const block = blocks[index];
458
- if (block) {
459
- delete block.index;
460
- if (block.type === "text") {
461
- stream.push({
462
- type: "text_end",
463
- contentIndex: index,
464
- content: block.text,
465
- partial: output,
466
- });
467
- }
468
- else if (block.type === "thinking") {
469
- stream.push({
470
- type: "thinking_end",
471
- contentIndex: index,
472
- content: block.thinking,
473
- partial: output,
474
- });
475
- }
476
- else if (block.type === "toolCall") {
477
- block.arguments = parseStreamingJson(block.partialJson);
478
- // Finalize in-place and strip the scratch buffer so replay only
479
- // carries parsed arguments.
480
- delete block.partialJson;
481
- stream.push({
482
- type: "toolcall_end",
483
- contentIndex: index,
484
- toolCall: block,
485
- partial: output,
486
- });
487
- }
488
- }
489
- }
490
- else if (event.type === "message_delta") {
491
- if (event.delta.stop_reason) {
492
- const stopReasonResult = mapStopReason(event.delta.stop_reason, event.delta.stop_details);
493
- output.stopReason = stopReasonResult.stopReason;
494
- if (stopReasonResult.errorMessage) {
495
- output.errorMessage = stopReasonResult.errorMessage;
496
- }
497
- }
498
- // Only update usage fields if present (not null).
499
- // Preserves input_tokens from message_start when proxies omit it in message_delta.
500
- if (event.usage.input_tokens != null) {
501
- output.usage.input = event.usage.input_tokens;
502
- }
503
- if (event.usage.output_tokens != null) {
504
- output.usage.output = event.usage.output_tokens;
505
- }
506
- if (event.usage.cache_read_input_tokens != null) {
507
- output.usage.cacheRead = event.usage.cache_read_input_tokens;
508
- }
509
- if (event.usage.cache_creation_input_tokens != null) {
510
- output.usage.cacheWrite = event.usage.cache_creation_input_tokens;
511
- }
512
- // Anthropic doesn't provide total_tokens, compute from components
513
- output.usage.totalTokens =
514
- output.usage.input + output.usage.output + output.usage.cacheRead + output.usage.cacheWrite;
515
- calculateCost(model, output.usage);
516
- }
517
- }
518
- if (options?.signal?.aborted) {
519
- throw new Error("Request was aborted");
520
- }
521
- if (output.stopReason === "aborted" || output.stopReason === "error") {
522
- throw new Error(output.errorMessage || "An unknown error occurred");
523
- }
524
- stream.push({ type: "done", reason: output.stopReason, message: output });
525
- stream.end();
526
- }
527
- catch (error) {
528
- for (const block of output.content) {
529
- delete block.index;
530
- // partialJson is only a streaming scratch buffer; never persist it.
531
- delete block.partialJson;
532
- }
533
- output.stopReason = options?.signal?.aborted ? "aborted" : "error";
534
- output.errorMessage = error instanceof Error ? error.message : JSON.stringify(error);
535
- stream.push({ type: "error", reason: output.stopReason, error: output });
536
- stream.end();
537
- }
538
- })();
539
- return stream;
540
- };
541
- /**
542
- * Map ThinkingLevel to Anthropic effort levels for adaptive thinking.
543
- * Note: effort "max" is only valid on Opus 4.6, while Opus 4.7+ and Fable 5 support "xhigh".
544
- */
545
- function mapThinkingLevelToEffort(model, level) {
546
- const mapped = level ? model.thinkingLevelMap?.[level] : undefined;
547
- if (typeof mapped === "string")
548
- return mapped;
549
- switch (level) {
550
- case "minimal":
551
- case "low":
552
- return "low";
553
- case "medium":
554
- return "medium";
555
- case "high":
556
- return "high";
557
- default:
558
- return "high";
559
- }
560
- }
561
- export const streamSimpleAnthropic = (model, context, options) => {
562
- const apiKey = options?.apiKey;
563
- if (!apiKey) {
564
- throw new Error(`No API key for provider: ${model.provider}`);
565
- }
566
- const base = buildBaseOptions(model, options, apiKey);
567
- if (!options?.reasoning) {
568
- return streamAnthropic(model, context, { ...base, thinkingEnabled: false });
569
- }
570
- // For models with adaptive thinking: use an effort level.
571
- // For older models: use budget-based thinking.
572
- if (model.compat?.forceAdaptiveThinking === true) {
573
- const effort = mapThinkingLevelToEffort(model, options.reasoning);
574
- return streamAnthropic(model, context, {
575
- ...base,
576
- thinkingEnabled: true,
577
- effort,
578
- });
579
- }
580
- // Undefined means the caller did not request an output cap; let the helper use the model cap.
581
- // Do not coerce to 0 here, or the thinking budget would become the entire max_tokens value.
582
- const adjusted = adjustMaxTokensForThinking(base.maxTokens, model.maxTokens, options.reasoning, options.thinkingBudgets);
583
- return streamAnthropic(model, context, {
584
- ...base,
585
- maxTokens: adjusted.maxTokens,
586
- thinkingEnabled: true,
587
- thinkingBudgetTokens: adjusted.thinkingBudget,
588
- });
589
- };
590
- export function register() {
591
- registerApiProvider({
592
- api: "anthropic-messages",
593
- stream: streamAnthropic,
594
- streamSimple: streamSimpleAnthropic,
595
- });
596
- }
597
- function isOAuthToken(apiKey) {
598
- return apiKey.includes("sk-ant-oat");
599
- }
600
- function createClient(model, apiKey, interleavedThinking, useFineGrainedToolStreamingBeta, optionsHeaders, dynamicHeaders, sessionId, env) {
601
- // Adaptive thinking models have interleaved thinking built in, so skip the beta header.
602
- const needsInterleavedBeta = interleavedThinking && model.compat?.forceAdaptiveThinking !== true;
603
- const betaFeatures = [];
604
- if (useFineGrainedToolStreamingBeta) {
605
- betaFeatures.push(FINE_GRAINED_TOOL_STREAMING_BETA);
606
- }
607
- if (needsInterleavedBeta) {
608
- betaFeatures.push(INTERLEAVED_THINKING_BETA);
609
- }
610
- if (model.provider === "cloudflare-ai-gateway") {
611
- const client = new Anthropic({
612
- apiKey: null,
613
- authToken: null,
614
- baseURL: resolveCloudflareBaseUrl(model, env),
615
- dangerouslyAllowBrowser: true,
616
- defaultHeaders: mergeHeaders({
617
- accept: "application/json",
618
- "anthropic-dangerous-direct-browser-access": "true",
619
- "cf-aig-authorization": `Bearer ${apiKey}`,
620
- "x-api-key": null,
621
- Authorization: null,
622
- ...(betaFeatures.length > 0 ? { "anthropic-beta": betaFeatures.join(",") } : {}),
623
- }, model.headers, optionsHeaders),
624
- });
625
- return { client, isOAuthToken: false };
626
- }
627
- // Copilot: Bearer auth, selective betas.
628
- if (model.provider === "github-copilot") {
629
- const client = new Anthropic({
630
- apiKey: null,
631
- authToken: apiKey,
632
- baseURL: model.baseUrl,
633
- dangerouslyAllowBrowser: true,
634
- defaultHeaders: mergeHeaders({
635
- accept: "application/json",
636
- "anthropic-dangerous-direct-browser-access": "true",
637
- ...(betaFeatures.length > 0 ? { "anthropic-beta": betaFeatures.join(",") } : {}),
638
- }, model.headers, dynamicHeaders, optionsHeaders),
639
- });
640
- return { client, isOAuthToken: false };
641
- }
642
- // OAuth: Bearer auth, Claude Code identity headers
643
- if (isOAuthToken(apiKey)) {
644
- const client = new Anthropic({
645
- apiKey: null,
646
- authToken: apiKey,
647
- baseURL: model.baseUrl,
648
- dangerouslyAllowBrowser: true,
649
- defaultHeaders: mergeHeaders({
650
- accept: "application/json",
651
- "anthropic-dangerous-direct-browser-access": "true",
652
- "anthropic-beta": ["claude-code-20250219", "oauth-2025-04-20", ...betaFeatures].join(","),
653
- "user-agent": `claude-cli/${claudeCodeVersion}`,
654
- "x-app": "cli",
655
- }, model.headers, optionsHeaders),
656
- });
657
- return { client, isOAuthToken: true };
658
- }
659
- // API key auth
660
- const sessionAffinityHeaders = sessionId && getAnthropicCompat(model).sendSessionAffinityHeaders ? { "x-session-affinity": sessionId } : {};
661
- const client = new Anthropic({
662
- apiKey,
663
- authToken: null,
664
- baseURL: model.baseUrl,
665
- dangerouslyAllowBrowser: true,
666
- defaultHeaders: mergeHeaders({
667
- accept: "application/json",
668
- "anthropic-dangerous-direct-browser-access": "true",
669
- ...(betaFeatures.length > 0 ? { "anthropic-beta": betaFeatures.join(",") } : {}),
670
- }, sessionAffinityHeaders, model.headers, optionsHeaders),
671
- });
672
- return { client, isOAuthToken: false };
673
- }
674
- function buildParams(model, context, isOAuthToken, options) {
675
- const { cacheControl } = getCacheControl(model, options?.cacheRetention, options?.env);
676
- const compat = getAnthropicCompat(model);
677
- const params = {
678
- model: model.id,
679
- messages: convertMessages(context.messages, model, isOAuthToken, cacheControl, compat.allowEmptySignature),
680
- max_tokens: options?.maxTokens ?? model.maxTokens,
681
- stream: true,
682
- };
683
- // For OAuth tokens, we MUST include Claude Code identity
684
- if (isOAuthToken) {
685
- params.system = [
686
- {
687
- type: "text",
688
- text: "You are Claude Code, Anthropic's official CLI for Claude.",
689
- ...(cacheControl ? { cache_control: cacheControl } : {}),
690
- },
691
- ];
692
- if (context.systemPrompt) {
693
- params.system.push({
694
- type: "text",
695
- text: sanitizeSurrogates(context.systemPrompt),
696
- ...(cacheControl ? { cache_control: cacheControl } : {}),
697
- });
698
- }
699
- }
700
- else if (context.systemPrompt) {
701
- // Add cache control to system prompt for non-OAuth tokens
702
- params.system = [
703
- {
704
- type: "text",
705
- text: sanitizeSurrogates(context.systemPrompt),
706
- ...(cacheControl ? { cache_control: cacheControl } : {}),
707
- },
708
- ];
709
- }
710
- // Temperature is incompatible with extended thinking and unsupported on Claude Opus 4.7+.
711
- if (options?.temperature !== undefined && !options?.thinkingEnabled && compat.supportsTemperature) {
712
- params.temperature = options.temperature;
713
- }
714
- if (context.tools && context.tools.length > 0) {
715
- params.tools = convertTools(context.tools, isOAuthToken, compat.supportsEagerToolInputStreaming, compat.supportsCacheControlOnTools ? cacheControl : undefined);
716
- }
717
- // Configure thinking mode: adaptive, budget-based, or explicitly disabled.
718
- if (model.reasoning) {
719
- if (options?.thinkingEnabled) {
720
- // Default to "summarized" so Opus 4.7 and Mythos Preview behave like
721
- // older Claude 4 models (whose API default is also "summarized").
722
- const display = options.thinkingDisplay ?? "summarized";
723
- if (model.compat?.forceAdaptiveThinking === true) {
724
- // Adaptive thinking: Claude decides when and how much to think.
725
- params.thinking = { type: "adaptive", display };
726
- if (options.effort) {
727
- // The Anthropic SDK types can lag newly supported effort values such as "xhigh".
728
- params.output_config =
729
- options.effort === "xhigh"
730
- ? { effort: options.effort }
731
- : { effort: options.effort };
732
- }
733
- }
734
- else {
735
- // Budget-based thinking for older models
736
- params.thinking = {
737
- type: "enabled",
738
- budget_tokens: options.thinkingBudgetTokens || 1024,
739
- display,
740
- };
741
- }
742
- }
743
- else if (options?.thinkingEnabled === false && model.thinkingLevelMap?.off !== null) {
744
- params.thinking = { type: "disabled" };
745
- }
746
- }
747
- if (options?.metadata) {
748
- const userId = options.metadata.user_id;
749
- if (typeof userId === "string") {
750
- params.metadata = { user_id: userId };
751
- }
752
- }
753
- if (options?.toolChoice) {
754
- if (typeof options.toolChoice === "string") {
755
- params.tool_choice = { type: options.toolChoice };
756
- }
757
- else {
758
- params.tool_choice = options.toolChoice;
759
- }
760
- }
761
- return params;
762
- }
763
- // Normalize tool call IDs to match Anthropic's required pattern and length
764
- function normalizeToolCallId(id) {
765
- return id.replace(/[^a-zA-Z0-9_-]/g, "_").slice(0, 64);
766
- }
767
- function convertMessages(messages, model, isOAuthToken, cacheControl, allowEmptySignature = false) {
768
- const params = [];
769
- // Transform messages for cross-provider compatibility
770
- const transformedMessages = transformMessages(messages, model, normalizeToolCallId);
771
- for (let i = 0; i < transformedMessages.length; i++) {
772
- const msg = transformedMessages[i];
773
- if (msg.role === "user") {
774
- if (typeof msg.content === "string") {
775
- if (msg.content.trim().length > 0) {
776
- params.push({
777
- role: "user",
778
- content: sanitizeSurrogates(msg.content),
779
- });
780
- }
781
- }
782
- else {
783
- const blocks = msg.content.map((item) => {
784
- if (item.type === "text") {
785
- return {
786
- type: "text",
787
- text: sanitizeSurrogates(item.text),
788
- };
789
- }
790
- else {
791
- return {
792
- type: "image",
793
- source: {
794
- type: "base64",
795
- media_type: item.mimeType,
796
- data: item.data,
797
- },
798
- };
799
- }
800
- });
801
- const filteredBlocks = blocks.filter((b) => {
802
- if (b.type === "text") {
803
- return b.text.trim().length > 0;
804
- }
805
- return true;
806
- });
807
- if (filteredBlocks.length === 0)
808
- continue;
809
- params.push({
810
- role: "user",
811
- content: filteredBlocks,
812
- });
813
- }
814
- }
815
- else if (msg.role === "assistant") {
816
- const blocks = [];
817
- for (const block of msg.content) {
818
- if (block.type === "text") {
819
- if (block.text.trim().length === 0)
820
- continue;
821
- blocks.push({
822
- type: "text",
823
- text: sanitizeSurrogates(block.text),
824
- });
825
- }
826
- else if (block.type === "thinking") {
827
- // Redacted thinking: pass the opaque payload back as redacted_thinking
828
- if (block.redacted) {
829
- blocks.push({
830
- type: "redacted_thinking",
831
- data: block.thinkingSignature,
832
- });
833
- continue;
834
- }
835
- if (block.thinking.trim().length === 0)
836
- continue;
837
- // If thinking signature is missing/empty (e.g., from aborted stream),
838
- // convert to plain text for Anthropic. Some compatible providers emit
839
- // and accept empty signatures, so let marked models preserve the block.
840
- if (!block.thinkingSignature || block.thinkingSignature.trim().length === 0) {
841
- blocks.push(allowEmptySignature
842
- ? {
843
- type: "thinking",
844
- thinking: sanitizeSurrogates(block.thinking),
845
- signature: "",
846
- }
847
- : {
848
- type: "text",
849
- text: sanitizeSurrogates(block.thinking),
850
- });
851
- }
852
- else {
853
- blocks.push({
854
- type: "thinking",
855
- thinking: sanitizeSurrogates(block.thinking),
856
- signature: block.thinkingSignature,
857
- });
858
- }
859
- }
860
- else if (block.type === "toolCall") {
861
- blocks.push({
862
- type: "tool_use",
863
- id: block.id,
864
- name: isOAuthToken ? toClaudeCodeName(block.name) : block.name,
865
- input: block.arguments ?? {},
866
- });
867
- }
868
- }
869
- if (blocks.length === 0)
870
- continue;
871
- params.push({
872
- role: "assistant",
873
- content: blocks,
874
- });
875
- }
876
- else if (msg.role === "toolResult") {
877
- // Collect all consecutive toolResult messages, needed for z.ai Anthropic endpoint
878
- const toolResults = [];
879
- // Add the current tool result
880
- toolResults.push({
881
- type: "tool_result",
882
- tool_use_id: msg.toolCallId,
883
- content: convertContentBlocks(msg.content),
884
- is_error: msg.isError,
885
- });
886
- // Look ahead for consecutive toolResult messages
887
- let j = i + 1;
888
- while (j < transformedMessages.length && transformedMessages[j].role === "toolResult") {
889
- const nextMsg = transformedMessages[j]; // We know it's a toolResult
890
- toolResults.push({
891
- type: "tool_result",
892
- tool_use_id: nextMsg.toolCallId,
893
- content: convertContentBlocks(nextMsg.content),
894
- is_error: nextMsg.isError,
895
- });
896
- j++;
897
- }
898
- // Skip the messages we've already processed
899
- i = j - 1;
900
- // Add a single user message with all tool results
901
- params.push({
902
- role: "user",
903
- content: toolResults,
904
- });
905
- }
906
- }
907
- // Add cache_control to the last user message to cache conversation history
908
- if (cacheControl && params.length > 0) {
909
- const lastMessage = params[params.length - 1];
910
- if (lastMessage.role === "user") {
911
- if (Array.isArray(lastMessage.content)) {
912
- const lastBlock = lastMessage.content[lastMessage.content.length - 1];
913
- if (lastBlock &&
914
- (lastBlock.type === "text" || lastBlock.type === "image" || lastBlock.type === "tool_result")) {
915
- lastBlock.cache_control = cacheControl;
916
- }
917
- }
918
- else if (typeof lastMessage.content === "string") {
919
- lastMessage.content = [
920
- {
921
- type: "text",
922
- text: lastMessage.content,
923
- cache_control: cacheControl,
924
- },
925
- ];
926
- }
927
- }
928
- }
929
- return params;
930
- }
931
- function shouldUseFineGrainedToolStreamingBeta(model, context) {
932
- return !!context.tools?.length && !getAnthropicCompat(model).supportsEagerToolInputStreaming;
933
- }
934
- function convertTools(tools, isOAuthToken, supportsEagerToolInputStreaming, cacheControl) {
935
- if (!tools)
936
- return [];
937
- return tools.map((tool, index) => {
938
- const schema = tool.parameters;
939
- return {
940
- name: isOAuthToken ? toClaudeCodeName(tool.name) : tool.name,
941
- description: tool.description,
942
- ...(supportsEagerToolInputStreaming ? { eager_input_streaming: true } : {}),
943
- input_schema: {
944
- type: "object",
945
- properties: schema.properties ?? {},
946
- required: schema.required ?? [],
947
- },
948
- ...(cacheControl && index === tools.length - 1 ? { cache_control: cacheControl } : {}),
949
- };
1
+ import { anthropicMessagesApi } from "../api/anthropic-messages.lazy.js";
2
+ import { envApiKeyAuth, lazyOAuth } from "../auth/helpers.js";
3
+ import { createProvider } from "../models.js";
4
+ import { loadAnthropicOAuth } from "../utils/oauth/load.js";
5
+ import { ANTHROPIC_MODELS } from "./anthropic.models.js";
6
+ export function anthropicProvider() {
7
+ return createProvider({
8
+ id: "anthropic",
9
+ name: "Anthropic",
10
+ baseUrl: "https://api.anthropic.com",
11
+ auth: {
12
+ // ANTHROPIC_OAUTH_TOKEN takes precedence over ANTHROPIC_API_KEY
13
+ apiKey: envApiKeyAuth("Anthropic API key", ["ANTHROPIC_OAUTH_TOKEN", "ANTHROPIC_API_KEY"]),
14
+ oauth: lazyOAuth({ name: "Anthropic (Claude Pro/Max)", load: loadAnthropicOAuth }),
15
+ },
16
+ models: Object.values(ANTHROPIC_MODELS),
17
+ api: anthropicMessagesApi(),
950
18
  });
951
19
  }
952
- function mapStopReason(reason, stopDetails) {
953
- switch (reason) {
954
- case "end_turn":
955
- return { stopReason: "stop" };
956
- case "max_tokens":
957
- return { stopReason: "length" };
958
- case "tool_use":
959
- return { stopReason: "toolUse" };
960
- case "refusal":
961
- return {
962
- stopReason: "error",
963
- errorMessage: stopDetails?.explanation || `The model refused to complete the request`,
964
- };
965
- case "pause_turn": // Stop is good enough -> resubmit
966
- return { stopReason: "stop" };
967
- case "stop_sequence":
968
- return { stopReason: "stop" }; // We don't supply stop sequences, so this should never happen
969
- case "sensitive": // Content flagged by safety filters (not yet in SDK types)
970
- return { stopReason: "error" };
971
- default:
972
- // Handle unknown stop reasons gracefully (API may add new values)
973
- throw new Error(`Unhandled stop reason: ${reason}`);
974
- }
975
- }
976
20
  //# sourceMappingURL=anthropic.js.map