@averyyy/pi-ai 0.80.3-piclient.1

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 (650) hide show
  1. package/README.md +1564 -0
  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 +972 -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 +219 -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 +872 -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/api/cloudflare.d.ts +9 -0
  27. package/dist/api/cloudflare.d.ts.map +1 -0
  28. package/dist/api/cloudflare.js +9 -0
  29. package/dist/api/cloudflare.js.map +1 -0
  30. package/dist/api/github-copilot-headers.d.ts +8 -0
  31. package/dist/api/github-copilot-headers.d.ts.map +1 -0
  32. package/dist/api/github-copilot-headers.js +29 -0
  33. package/dist/api/github-copilot-headers.js.map +1 -0
  34. package/dist/api/google-generative-ai.d.ts +13 -0
  35. package/dist/api/google-generative-ai.d.ts.map +1 -0
  36. package/dist/api/google-generative-ai.js +407 -0
  37. package/dist/api/google-generative-ai.js.map +1 -0
  38. package/dist/api/google-generative-ai.lazy.d.ts +3 -0
  39. package/dist/api/google-generative-ai.lazy.d.ts.map +1 -0
  40. package/dist/api/google-generative-ai.lazy.js +3 -0
  41. package/dist/api/google-generative-ai.lazy.js.map +1 -0
  42. package/dist/api/google-shared.d.ts +70 -0
  43. package/dist/api/google-shared.d.ts.map +1 -0
  44. package/dist/api/google-shared.js +329 -0
  45. package/dist/api/google-shared.js.map +1 -0
  46. package/dist/api/google-vertex.d.ts +15 -0
  47. package/dist/api/google-vertex.d.ts.map +1 -0
  48. package/dist/api/google-vertex.js +456 -0
  49. package/dist/api/google-vertex.js.map +1 -0
  50. package/dist/api/google-vertex.lazy.d.ts +3 -0
  51. package/dist/api/google-vertex.lazy.d.ts.map +1 -0
  52. package/dist/api/google-vertex.lazy.js +3 -0
  53. package/dist/api/google-vertex.lazy.js.map +1 -0
  54. package/dist/api/lazy.d.ts +15 -0
  55. package/dist/api/lazy.d.ts.map +1 -0
  56. package/dist/api/lazy.js +59 -0
  57. package/dist/api/lazy.js.map +1 -0
  58. package/dist/api/mistral-conversations.d.ts +25 -0
  59. package/dist/api/mistral-conversations.d.ts.map +1 -0
  60. package/dist/api/mistral-conversations.js +555 -0
  61. package/dist/api/mistral-conversations.js.map +1 -0
  62. package/dist/api/mistral-conversations.lazy.d.ts +3 -0
  63. package/dist/api/mistral-conversations.lazy.d.ts.map +1 -0
  64. package/dist/api/mistral-conversations.lazy.js +3 -0
  65. package/dist/api/mistral-conversations.lazy.js.map +1 -0
  66. package/dist/api/openai-codex-responses.d.ts +30 -0
  67. package/dist/api/openai-codex-responses.d.ts.map +1 -0
  68. package/dist/api/openai-codex-responses.js +1215 -0
  69. package/dist/api/openai-codex-responses.js.map +1 -0
  70. package/dist/api/openai-codex-responses.lazy.d.ts +3 -0
  71. package/dist/api/openai-codex-responses.lazy.d.ts.map +1 -0
  72. package/dist/api/openai-codex-responses.lazy.js +3 -0
  73. package/dist/api/openai-codex-responses.lazy.js.map +1 -0
  74. package/dist/api/openai-completions.d.ts +19 -0
  75. package/dist/api/openai-completions.d.ts.map +1 -0
  76. package/dist/api/openai-completions.js +1058 -0
  77. package/dist/api/openai-completions.js.map +1 -0
  78. package/dist/api/openai-completions.lazy.d.ts +3 -0
  79. package/dist/api/openai-completions.lazy.d.ts.map +1 -0
  80. package/dist/api/openai-completions.lazy.js +3 -0
  81. package/dist/api/openai-completions.lazy.js.map +1 -0
  82. package/dist/api/openai-prompt-cache.d.ts +3 -0
  83. package/dist/api/openai-prompt-cache.d.ts.map +1 -0
  84. package/dist/api/openai-prompt-cache.js +10 -0
  85. package/dist/api/openai-prompt-cache.js.map +1 -0
  86. package/dist/api/openai-responses-shared.d.ts +18 -0
  87. package/dist/api/openai-responses-shared.d.ts.map +1 -0
  88. package/dist/api/openai-responses-shared.js +482 -0
  89. package/dist/api/openai-responses-shared.js.map +1 -0
  90. package/dist/api/openai-responses.d.ts +13 -0
  91. package/dist/api/openai-responses.d.ts.map +1 -0
  92. package/dist/api/openai-responses.js +226 -0
  93. package/dist/api/openai-responses.js.map +1 -0
  94. package/dist/api/openai-responses.lazy.d.ts +3 -0
  95. package/dist/api/openai-responses.lazy.d.ts.map +1 -0
  96. package/dist/api/openai-responses.lazy.js +3 -0
  97. package/dist/api/openai-responses.lazy.js.map +1 -0
  98. package/dist/api/openrouter-images.d.ts +3 -0
  99. package/dist/api/openrouter-images.d.ts.map +1 -0
  100. package/dist/api/openrouter-images.js +126 -0
  101. package/dist/api/openrouter-images.js.map +1 -0
  102. package/dist/api/openrouter-images.lazy.d.ts +3 -0
  103. package/dist/api/openrouter-images.lazy.d.ts.map +1 -0
  104. package/dist/api/openrouter-images.lazy.js +4 -0
  105. package/dist/api/openrouter-images.lazy.js.map +1 -0
  106. package/dist/api/simple-options.d.ts +9 -0
  107. package/dist/api/simple-options.d.ts.map +1 -0
  108. package/dist/api/simple-options.js +52 -0
  109. package/dist/api/simple-options.js.map +1 -0
  110. package/dist/api/transform-messages.d.ts +8 -0
  111. package/dist/api/transform-messages.d.ts.map +1 -0
  112. package/dist/api/transform-messages.js +184 -0
  113. package/dist/api/transform-messages.js.map +1 -0
  114. package/dist/api-registry.d.ts +20 -0
  115. package/dist/api-registry.d.ts.map +1 -0
  116. package/dist/api-registry.js +44 -0
  117. package/dist/api-registry.js.map +1 -0
  118. package/dist/auth/context.d.ts +7 -0
  119. package/dist/auth/context.d.ts.map +1 -0
  120. package/dist/auth/context.js +42 -0
  121. package/dist/auth/context.js.map +1 -0
  122. package/dist/auth/credential-store.d.ts +16 -0
  123. package/dist/auth/credential-store.d.ts.map +1 -0
  124. package/dist/auth/credential-store.js +37 -0
  125. package/dist/auth/credential-store.js.map +1 -0
  126. package/dist/auth/helpers.d.ts +20 -0
  127. package/dist/auth/helpers.d.ts.map +1 -0
  128. package/dist/auth/helpers.js +46 -0
  129. package/dist/auth/helpers.js.map +1 -0
  130. package/dist/auth/resolve.d.ts +26 -0
  131. package/dist/auth/resolve.d.ts.map +1 -0
  132. package/dist/auth/resolve.js +101 -0
  133. package/dist/auth/resolve.js.map +1 -0
  134. package/dist/auth/types.d.ts +180 -0
  135. package/dist/auth/types.d.ts.map +1 -0
  136. package/dist/auth/types.js +2 -0
  137. package/dist/auth/types.js.map +1 -0
  138. package/dist/bedrock-provider.d.ts +5 -0
  139. package/dist/bedrock-provider.d.ts.map +1 -0
  140. package/dist/bedrock-provider.js +6 -0
  141. package/dist/bedrock-provider.js.map +1 -0
  142. package/dist/cli.d.ts +3 -0
  143. package/dist/cli.d.ts.map +1 -0
  144. package/dist/cli.js +130 -0
  145. package/dist/cli.js.map +1 -0
  146. package/dist/compat.d.ts +65 -0
  147. package/dist/compat.d.ts.map +1 -0
  148. package/dist/compat.js +182 -0
  149. package/dist/compat.js.map +1 -0
  150. package/dist/env-api-keys.d.ts +18 -0
  151. package/dist/env-api-keys.d.ts.map +1 -0
  152. package/dist/env-api-keys.js +145 -0
  153. package/dist/env-api-keys.js.map +1 -0
  154. package/dist/image-models.d.ts +10 -0
  155. package/dist/image-models.d.ts.map +1 -0
  156. package/dist/image-models.generated.d.ts +530 -0
  157. package/dist/image-models.generated.d.ts.map +1 -0
  158. package/dist/image-models.generated.js +532 -0
  159. package/dist/image-models.generated.js.map +1 -0
  160. package/dist/image-models.js +23 -0
  161. package/dist/image-models.js.map +1 -0
  162. package/dist/images-api-registry.d.ts +14 -0
  163. package/dist/images-api-registry.d.ts.map +1 -0
  164. package/dist/images-api-registry.js +22 -0
  165. package/dist/images-api-registry.js.map +1 -0
  166. package/dist/images-models.d.ts +93 -0
  167. package/dist/images-models.d.ts.map +1 -0
  168. package/dist/images-models.js +141 -0
  169. package/dist/images-models.js.map +1 -0
  170. package/dist/images.d.ts +4 -0
  171. package/dist/images.d.ts.map +1 -0
  172. package/dist/images.js +14 -0
  173. package/dist/images.js.map +1 -0
  174. package/dist/index.d.ts +31 -0
  175. package/dist/index.d.ts.map +1 -0
  176. package/dist/index.js +19 -0
  177. package/dist/index.js.map +1 -0
  178. package/dist/legacy-api-aliases.d.ts +42 -0
  179. package/dist/legacy-api-aliases.d.ts.map +1 -0
  180. package/dist/legacy-api-aliases.js +49 -0
  181. package/dist/legacy-api-aliases.js.map +1 -0
  182. package/dist/models.d.ts +142 -0
  183. package/dist/models.d.ts.map +1 -0
  184. package/dist/models.generated.d.ts +20965 -0
  185. package/dist/models.generated.d.ts.map +1 -0
  186. package/dist/models.generated.js +75 -0
  187. package/dist/models.generated.js.map +1 -0
  188. package/dist/models.js +238 -0
  189. package/dist/models.js.map +1 -0
  190. package/dist/oauth.d.ts +2 -0
  191. package/dist/oauth.d.ts.map +1 -0
  192. package/dist/oauth.js +2 -0
  193. package/dist/oauth.js.map +1 -0
  194. package/dist/providers/all.d.ts +21 -0
  195. package/dist/providers/all.d.ts.map +1 -0
  196. package/dist/providers/all.js +114 -0
  197. package/dist/providers/all.js.map +1 -0
  198. package/dist/providers/amazon-bedrock.d.ts +3 -0
  199. package/dist/providers/amazon-bedrock.d.ts.map +1 -0
  200. package/dist/providers/amazon-bedrock.js +39 -0
  201. package/dist/providers/amazon-bedrock.js.map +1 -0
  202. package/dist/providers/amazon-bedrock.models.d.ts +1837 -0
  203. package/dist/providers/amazon-bedrock.models.d.ts.map +1 -0
  204. package/dist/providers/amazon-bedrock.models.js +1794 -0
  205. package/dist/providers/amazon-bedrock.models.js.map +1 -0
  206. package/dist/providers/ant-ling.d.ts +3 -0
  207. package/dist/providers/ant-ling.d.ts.map +1 -0
  208. package/dist/providers/ant-ling.js +15 -0
  209. package/dist/providers/ant-ling.js.map +1 -0
  210. package/dist/providers/ant-ling.models.d.ts +86 -0
  211. package/dist/providers/ant-ling.models.d.ts.map +1 -0
  212. package/dist/providers/ant-ling.models.js +60 -0
  213. package/dist/providers/ant-ling.models.js.map +1 -0
  214. package/dist/providers/anthropic.d.ts +3 -0
  215. package/dist/providers/anthropic.d.ts.map +1 -0
  216. package/dist/providers/anthropic.js +20 -0
  217. package/dist/providers/anthropic.js.map +1 -0
  218. package/dist/providers/anthropic.models.d.ts +444 -0
  219. package/dist/providers/anthropic.models.d.ts.map +1 -0
  220. package/dist/providers/anthropic.models.js +423 -0
  221. package/dist/providers/anthropic.models.js.map +1 -0
  222. package/dist/providers/azure-openai-responses.d.ts +3 -0
  223. package/dist/providers/azure-openai-responses.d.ts.map +1 -0
  224. package/dist/providers/azure-openai-responses.js +14 -0
  225. package/dist/providers/azure-openai-responses.js.map +1 -0
  226. package/dist/providers/azure-openai-responses.models.d.ts +804 -0
  227. package/dist/providers/azure-openai-responses.models.d.ts.map +1 -0
  228. package/dist/providers/azure-openai-responses.models.js +743 -0
  229. package/dist/providers/azure-openai-responses.models.js.map +1 -0
  230. package/dist/providers/cerebras.d.ts +3 -0
  231. package/dist/providers/cerebras.d.ts.map +1 -0
  232. package/dist/providers/cerebras.js +15 -0
  233. package/dist/providers/cerebras.js.map +1 -0
  234. package/dist/providers/cerebras.models.d.ts +45 -0
  235. package/dist/providers/cerebras.models.d.ts.map +1 -0
  236. package/dist/providers/cerebras.models.js +41 -0
  237. package/dist/providers/cerebras.models.js.map +1 -0
  238. package/dist/providers/cloudflare-ai-gateway.d.ts +3 -0
  239. package/dist/providers/cloudflare-ai-gateway.d.ts.map +1 -0
  240. package/dist/providers/cloudflare-ai-gateway.js +20 -0
  241. package/dist/providers/cloudflare-ai-gateway.js.map +1 -0
  242. package/dist/providers/cloudflare-ai-gateway.models.d.ts +765 -0
  243. package/dist/providers/cloudflare-ai-gateway.models.d.ts.map +1 -0
  244. package/dist/providers/cloudflare-ai-gateway.models.js +666 -0
  245. package/dist/providers/cloudflare-ai-gateway.models.js.map +1 -0
  246. package/dist/providers/cloudflare-auth.d.ts +4 -0
  247. package/dist/providers/cloudflare-auth.d.ts.map +1 -0
  248. package/dist/providers/cloudflare-auth.js +85 -0
  249. package/dist/providers/cloudflare-auth.js.map +1 -0
  250. package/dist/providers/cloudflare-workers-ai.d.ts +3 -0
  251. package/dist/providers/cloudflare-workers-ai.d.ts.map +1 -0
  252. package/dist/providers/cloudflare-workers-ai.js +14 -0
  253. package/dist/providers/cloudflare-workers-ai.js.map +1 -0
  254. package/dist/providers/cloudflare-workers-ai.models.d.ts +302 -0
  255. package/dist/providers/cloudflare-workers-ai.models.d.ts.map +1 -0
  256. package/dist/providers/cloudflare-workers-ai.models.js +239 -0
  257. package/dist/providers/cloudflare-workers-ai.models.js.map +1 -0
  258. package/dist/providers/cloudflare.d.ts +13 -0
  259. package/dist/providers/cloudflare.d.ts.map +1 -0
  260. package/dist/providers/cloudflare.js +26 -0
  261. package/dist/providers/cloudflare.js.map +1 -0
  262. package/dist/providers/deepseek.d.ts +3 -0
  263. package/dist/providers/deepseek.d.ts.map +1 -0
  264. package/dist/providers/deepseek.js +15 -0
  265. package/dist/providers/deepseek.js.map +1 -0
  266. package/dist/providers/deepseek.models.d.ts +63 -0
  267. package/dist/providers/deepseek.models.d.ts.map +1 -0
  268. package/dist/providers/deepseek.models.js +43 -0
  269. package/dist/providers/deepseek.models.js.map +1 -0
  270. package/dist/providers/faux.d.ts +97 -0
  271. package/dist/providers/faux.d.ts.map +1 -0
  272. package/dist/providers/faux.js +395 -0
  273. package/dist/providers/faux.js.map +1 -0
  274. package/dist/providers/fireworks.d.ts +3 -0
  275. package/dist/providers/fireworks.d.ts.map +1 -0
  276. package/dist/providers/fireworks.js +19 -0
  277. package/dist/providers/fireworks.js.map +1 -0
  278. package/dist/providers/fireworks.models.d.ts +376 -0
  279. package/dist/providers/fireworks.models.d.ts.map +1 -0
  280. package/dist/providers/fireworks.models.js +294 -0
  281. package/dist/providers/fireworks.models.js.map +1 -0
  282. package/dist/providers/github-copilot-headers.d.ts +8 -0
  283. package/dist/providers/github-copilot-headers.d.ts.map +1 -0
  284. package/dist/providers/github-copilot-headers.js +29 -0
  285. package/dist/providers/github-copilot-headers.js.map +1 -0
  286. package/dist/providers/github-copilot.d.ts +3 -0
  287. package/dist/providers/github-copilot.d.ts.map +1 -0
  288. package/dist/providers/github-copilot.js +25 -0
  289. package/dist/providers/github-copilot.js.map +1 -0
  290. package/dist/providers/github-copilot.models.d.ts +616 -0
  291. package/dist/providers/github-copilot.models.d.ts.map +1 -0
  292. package/dist/providers/github-copilot.models.js +426 -0
  293. package/dist/providers/github-copilot.models.js.map +1 -0
  294. package/dist/providers/google-shared.d.ts +70 -0
  295. package/dist/providers/google-shared.d.ts.map +1 -0
  296. package/dist/providers/google-shared.js +329 -0
  297. package/dist/providers/google-shared.js.map +1 -0
  298. package/dist/providers/google-vertex.d.ts +3 -0
  299. package/dist/providers/google-vertex.d.ts.map +1 -0
  300. package/dist/providers/google-vertex.js +35 -0
  301. package/dist/providers/google-vertex.js.map +1 -0
  302. package/dist/providers/google-vertex.models.d.ts +202 -0
  303. package/dist/providers/google-vertex.models.d.ts.map +1 -0
  304. package/dist/providers/google-vertex.models.js +182 -0
  305. package/dist/providers/google-vertex.models.js.map +1 -0
  306. package/dist/providers/google.d.ts +3 -0
  307. package/dist/providers/google.d.ts.map +1 -0
  308. package/dist/providers/google.js +15 -0
  309. package/dist/providers/google.js.map +1 -0
  310. package/dist/providers/google.models.d.ts +328 -0
  311. package/dist/providers/google.models.d.ts.map +1 -0
  312. package/dist/providers/google.models.js +288 -0
  313. package/dist/providers/google.models.js.map +1 -0
  314. package/dist/providers/groq.d.ts +3 -0
  315. package/dist/providers/groq.d.ts.map +1 -0
  316. package/dist/providers/groq.js +15 -0
  317. package/dist/providers/groq.js.map +1 -0
  318. package/dist/providers/groq.models.d.ts +128 -0
  319. package/dist/providers/groq.models.d.ts.map +1 -0
  320. package/dist/providers/groq.models.js +125 -0
  321. package/dist/providers/groq.models.js.map +1 -0
  322. package/dist/providers/huggingface.d.ts +3 -0
  323. package/dist/providers/huggingface.d.ts.map +1 -0
  324. package/dist/providers/huggingface.js +15 -0
  325. package/dist/providers/huggingface.js.map +1 -0
  326. package/dist/providers/huggingface.models.d.ts +963 -0
  327. package/dist/providers/huggingface.models.d.ts.map +1 -0
  328. package/dist/providers/huggingface.models.js +869 -0
  329. package/dist/providers/huggingface.models.js.map +1 -0
  330. package/dist/providers/images/openrouter.d.ts +3 -0
  331. package/dist/providers/images/openrouter.d.ts.map +1 -0
  332. package/dist/providers/images/openrouter.js +128 -0
  333. package/dist/providers/images/openrouter.js.map +1 -0
  334. package/dist/providers/images/register-builtins.d.ts +4 -0
  335. package/dist/providers/images/register-builtins.d.ts.map +1 -0
  336. package/dist/providers/images/register-builtins.js +34 -0
  337. package/dist/providers/images/register-builtins.js.map +1 -0
  338. package/dist/providers/kimi-coding.d.ts +3 -0
  339. package/dist/providers/kimi-coding.d.ts.map +1 -0
  340. package/dist/providers/kimi-coding.js +15 -0
  341. package/dist/providers/kimi-coding.js.map +1 -0
  342. package/dist/providers/kimi-coding.models.d.ts +63 -0
  343. package/dist/providers/kimi-coding.models.d.ts.map +1 -0
  344. package/dist/providers/kimi-coding.models.js +59 -0
  345. package/dist/providers/kimi-coding.models.js.map +1 -0
  346. package/dist/providers/minimax-cn.d.ts +3 -0
  347. package/dist/providers/minimax-cn.d.ts.map +1 -0
  348. package/dist/providers/minimax-cn.js +15 -0
  349. package/dist/providers/minimax-cn.js.map +1 -0
  350. package/dist/providers/minimax-cn.models.d.ts +54 -0
  351. package/dist/providers/minimax-cn.models.d.ts.map +1 -0
  352. package/dist/providers/minimax-cn.models.js +56 -0
  353. package/dist/providers/minimax-cn.models.js.map +1 -0
  354. package/dist/providers/minimax.d.ts +3 -0
  355. package/dist/providers/minimax.d.ts.map +1 -0
  356. package/dist/providers/minimax.js +15 -0
  357. package/dist/providers/minimax.js.map +1 -0
  358. package/dist/providers/minimax.models.d.ts +54 -0
  359. package/dist/providers/minimax.models.d.ts.map +1 -0
  360. package/dist/providers/minimax.models.js +56 -0
  361. package/dist/providers/minimax.models.js.map +1 -0
  362. package/dist/providers/mistral.d.ts +3 -0
  363. package/dist/providers/mistral.d.ts.map +1 -0
  364. package/dist/providers/mistral.js +15 -0
  365. package/dist/providers/mistral.js.map +1 -0
  366. package/dist/providers/mistral.models.d.ts +513 -0
  367. package/dist/providers/mistral.models.d.ts.map +1 -0
  368. package/dist/providers/mistral.models.js +515 -0
  369. package/dist/providers/mistral.models.js.map +1 -0
  370. package/dist/providers/moonshotai-cn.d.ts +3 -0
  371. package/dist/providers/moonshotai-cn.d.ts.map +1 -0
  372. package/dist/providers/moonshotai-cn.js +15 -0
  373. package/dist/providers/moonshotai-cn.js.map +1 -0
  374. package/dist/providers/moonshotai-cn.models.d.ts +234 -0
  375. package/dist/providers/moonshotai-cn.models.d.ts.map +1 -0
  376. package/dist/providers/moonshotai-cn.models.js +169 -0
  377. package/dist/providers/moonshotai-cn.models.js.map +1 -0
  378. package/dist/providers/moonshotai.d.ts +3 -0
  379. package/dist/providers/moonshotai.d.ts.map +1 -0
  380. package/dist/providers/moonshotai.js +15 -0
  381. package/dist/providers/moonshotai.js.map +1 -0
  382. package/dist/providers/moonshotai.models.d.ts +234 -0
  383. package/dist/providers/moonshotai.models.d.ts.map +1 -0
  384. package/dist/providers/moonshotai.models.js +169 -0
  385. package/dist/providers/moonshotai.models.js.map +1 -0
  386. package/dist/providers/nvidia.d.ts +3 -0
  387. package/dist/providers/nvidia.d.ts.map +1 -0
  388. package/dist/providers/nvidia.js +15 -0
  389. package/dist/providers/nvidia.js.map +1 -0
  390. package/dist/providers/nvidia.models.d.ts +563 -0
  391. package/dist/providers/nvidia.models.d.ts.map +1 -0
  392. package/dist/providers/nvidia.models.js +385 -0
  393. package/dist/providers/nvidia.models.js.map +1 -0
  394. package/dist/providers/openai-codex-responses.d.ts +30 -0
  395. package/dist/providers/openai-codex-responses.d.ts.map +1 -0
  396. package/dist/providers/openai-codex-responses.js +1173 -0
  397. package/dist/providers/openai-codex-responses.js.map +1 -0
  398. package/dist/providers/openai-codex.d.ts +3 -0
  399. package/dist/providers/openai-codex.d.ts.map +1 -0
  400. package/dist/providers/openai-codex.js +18 -0
  401. package/dist/providers/openai-codex.js.map +1 -0
  402. package/dist/providers/openai-codex.models.d.ts +87 -0
  403. package/dist/providers/openai-codex.models.d.ts.map +1 -0
  404. package/dist/providers/openai-codex.models.js +77 -0
  405. package/dist/providers/openai-codex.models.js.map +1 -0
  406. package/dist/providers/openai-completions.d.ts +19 -0
  407. package/dist/providers/openai-completions.d.ts.map +1 -0
  408. package/dist/providers/openai-completions.js +977 -0
  409. package/dist/providers/openai-completions.js.map +1 -0
  410. package/dist/providers/openai-prompt-cache.d.ts +3 -0
  411. package/dist/providers/openai-prompt-cache.d.ts.map +1 -0
  412. package/dist/providers/openai-prompt-cache.js +10 -0
  413. package/dist/providers/openai-prompt-cache.js.map +1 -0
  414. package/dist/providers/openai-responses-shared.d.ts +18 -0
  415. package/dist/providers/openai-responses-shared.d.ts.map +1 -0
  416. package/dist/providers/openai-responses-shared.js +496 -0
  417. package/dist/providers/openai-responses-shared.js.map +1 -0
  418. package/dist/providers/openai-responses.d.ts +13 -0
  419. package/dist/providers/openai-responses.d.ts.map +1 -0
  420. package/dist/providers/openai-responses.js +234 -0
  421. package/dist/providers/openai-responses.js.map +1 -0
  422. package/dist/providers/openai.d.ts +3 -0
  423. package/dist/providers/openai.d.ts.map +1 -0
  424. package/dist/providers/openai.js +15 -0
  425. package/dist/providers/openai.js.map +1 -0
  426. package/dist/providers/openai.models.d.ts +805 -0
  427. package/dist/providers/openai.models.d.ts.map +1 -0
  428. package/dist/providers/openai.models.js +743 -0
  429. package/dist/providers/openai.models.js.map +1 -0
  430. package/dist/providers/opencode-go.d.ts +3 -0
  431. package/dist/providers/opencode-go.d.ts.map +1 -0
  432. package/dist/providers/opencode-go.js +18 -0
  433. package/dist/providers/opencode-go.js.map +1 -0
  434. package/dist/providers/opencode-go.models.d.ts +309 -0
  435. package/dist/providers/opencode-go.models.d.ts.map +1 -0
  436. package/dist/providers/opencode-go.models.js +240 -0
  437. package/dist/providers/opencode-go.models.js.map +1 -0
  438. package/dist/providers/opencode.d.ts +3 -0
  439. package/dist/providers/opencode.d.ts.map +1 -0
  440. package/dist/providers/opencode.js +22 -0
  441. package/dist/providers/opencode.js.map +1 -0
  442. package/dist/providers/opencode.models.d.ts +976 -0
  443. package/dist/providers/opencode.models.d.ts.map +1 -0
  444. package/dist/providers/opencode.models.js +815 -0
  445. package/dist/providers/opencode.models.js.map +1 -0
  446. package/dist/providers/openrouter-images.d.ts +3 -0
  447. package/dist/providers/openrouter-images.d.ts.map +1 -0
  448. package/dist/providers/openrouter-images.js +14 -0
  449. package/dist/providers/openrouter-images.js.map +1 -0
  450. package/dist/providers/openrouter.d.ts +3 -0
  451. package/dist/providers/openrouter.d.ts.map +1 -0
  452. package/dist/providers/openrouter.js +15 -0
  453. package/dist/providers/openrouter.js.map +1 -0
  454. package/dist/providers/openrouter.models.d.ts +5402 -0
  455. package/dist/providers/openrouter.models.d.ts.map +1 -0
  456. package/dist/providers/openrouter.models.js +4634 -0
  457. package/dist/providers/openrouter.models.js.map +1 -0
  458. package/dist/providers/register-builtins.d.ts +35 -0
  459. package/dist/providers/register-builtins.d.ts.map +1 -0
  460. package/dist/providers/register-builtins.js +254 -0
  461. package/dist/providers/register-builtins.js.map +1 -0
  462. package/dist/providers/simple-options.d.ts +8 -0
  463. package/dist/providers/simple-options.d.ts.map +1 -0
  464. package/dist/providers/simple-options.js +42 -0
  465. package/dist/providers/simple-options.js.map +1 -0
  466. package/dist/providers/together.d.ts +3 -0
  467. package/dist/providers/together.d.ts.map +1 -0
  468. package/dist/providers/together.js +15 -0
  469. package/dist/providers/together.js.map +1 -0
  470. package/dist/providers/together.models.d.ts +598 -0
  471. package/dist/providers/together.models.d.ts.map +1 -0
  472. package/dist/providers/together.models.js +380 -0
  473. package/dist/providers/together.models.js.map +1 -0
  474. package/dist/providers/transform-messages.d.ts +8 -0
  475. package/dist/providers/transform-messages.d.ts.map +1 -0
  476. package/dist/providers/transform-messages.js +184 -0
  477. package/dist/providers/transform-messages.js.map +1 -0
  478. package/dist/providers/vercel-ai-gateway.d.ts +3 -0
  479. package/dist/providers/vercel-ai-gateway.d.ts.map +1 -0
  480. package/dist/providers/vercel-ai-gateway.js +15 -0
  481. package/dist/providers/vercel-ai-gateway.js.map +1 -0
  482. package/dist/providers/vercel-ai-gateway.models.d.ts +3230 -0
  483. package/dist/providers/vercel-ai-gateway.models.d.ts.map +1 -0
  484. package/dist/providers/vercel-ai-gateway.models.js +3187 -0
  485. package/dist/providers/vercel-ai-gateway.models.js.map +1 -0
  486. package/dist/providers/xai.d.ts +3 -0
  487. package/dist/providers/xai.d.ts.map +1 -0
  488. package/dist/providers/xai.js +15 -0
  489. package/dist/providers/xai.js.map +1 -0
  490. package/dist/providers/xai.models.d.ts +157 -0
  491. package/dist/providers/xai.models.d.ts.map +1 -0
  492. package/dist/providers/xai.models.js +131 -0
  493. package/dist/providers/xai.models.js.map +1 -0
  494. package/dist/providers/xiaomi-token-plan-ams.d.ts +3 -0
  495. package/dist/providers/xiaomi-token-plan-ams.d.ts.map +1 -0
  496. package/dist/providers/xiaomi-token-plan-ams.js +15 -0
  497. package/dist/providers/xiaomi-token-plan-ams.js.map +1 -0
  498. package/dist/providers/xiaomi-token-plan-ams.models.d.ts +108 -0
  499. package/dist/providers/xiaomi-token-plan-ams.models.d.ts.map +1 -0
  500. package/dist/providers/xiaomi-token-plan-ams.models.js +95 -0
  501. package/dist/providers/xiaomi-token-plan-ams.models.js.map +1 -0
  502. package/dist/providers/xiaomi-token-plan-cn.d.ts +3 -0
  503. package/dist/providers/xiaomi-token-plan-cn.d.ts.map +1 -0
  504. package/dist/providers/xiaomi-token-plan-cn.js +15 -0
  505. package/dist/providers/xiaomi-token-plan-cn.js.map +1 -0
  506. package/dist/providers/xiaomi-token-plan-cn.models.d.ts +108 -0
  507. package/dist/providers/xiaomi-token-plan-cn.models.d.ts.map +1 -0
  508. package/dist/providers/xiaomi-token-plan-cn.models.js +95 -0
  509. package/dist/providers/xiaomi-token-plan-cn.models.js.map +1 -0
  510. package/dist/providers/xiaomi-token-plan-sgp.d.ts +3 -0
  511. package/dist/providers/xiaomi-token-plan-sgp.d.ts.map +1 -0
  512. package/dist/providers/xiaomi-token-plan-sgp.js +15 -0
  513. package/dist/providers/xiaomi-token-plan-sgp.js.map +1 -0
  514. package/dist/providers/xiaomi-token-plan-sgp.models.d.ts +108 -0
  515. package/dist/providers/xiaomi-token-plan-sgp.models.d.ts.map +1 -0
  516. package/dist/providers/xiaomi-token-plan-sgp.models.js +95 -0
  517. package/dist/providers/xiaomi-token-plan-sgp.models.js.map +1 -0
  518. package/dist/providers/xiaomi.d.ts +3 -0
  519. package/dist/providers/xiaomi.d.ts.map +1 -0
  520. package/dist/providers/xiaomi.js +15 -0
  521. package/dist/providers/xiaomi.js.map +1 -0
  522. package/dist/providers/xiaomi.models.d.ts +129 -0
  523. package/dist/providers/xiaomi.models.d.ts.map +1 -0
  524. package/dist/providers/xiaomi.models.js +113 -0
  525. package/dist/providers/xiaomi.models.js.map +1 -0
  526. package/dist/providers/zai-coding-cn.d.ts +3 -0
  527. package/dist/providers/zai-coding-cn.d.ts.map +1 -0
  528. package/dist/providers/zai-coding-cn.js +15 -0
  529. package/dist/providers/zai-coding-cn.js.map +1 -0
  530. package/dist/providers/zai-coding-cn.models.d.ts +153 -0
  531. package/dist/providers/zai-coding-cn.models.d.ts.map +1 -0
  532. package/dist/providers/zai-coding-cn.models.js +114 -0
  533. package/dist/providers/zai-coding-cn.models.js.map +1 -0
  534. package/dist/providers/zai.d.ts +3 -0
  535. package/dist/providers/zai.d.ts.map +1 -0
  536. package/dist/providers/zai.js +15 -0
  537. package/dist/providers/zai.js.map +1 -0
  538. package/dist/providers/zai.models.d.ts +153 -0
  539. package/dist/providers/zai.models.d.ts.map +1 -0
  540. package/dist/providers/zai.models.js +114 -0
  541. package/dist/providers/zai.models.js.map +1 -0
  542. package/dist/session-resources.d.ts +4 -0
  543. package/dist/session-resources.d.ts.map +1 -0
  544. package/dist/session-resources.js +22 -0
  545. package/dist/session-resources.js.map +1 -0
  546. package/dist/stream.d.ts +8 -0
  547. package/dist/stream.d.ts.map +1 -0
  548. package/dist/stream.js +39 -0
  549. package/dist/stream.js.map +1 -0
  550. package/dist/types.d.ts +597 -0
  551. package/dist/types.d.ts.map +1 -0
  552. package/dist/types.js +2 -0
  553. package/dist/types.js.map +1 -0
  554. package/dist/utils/abort-signals.d.ts +6 -0
  555. package/dist/utils/abort-signals.d.ts.map +1 -0
  556. package/dist/utils/abort-signals.js +34 -0
  557. package/dist/utils/abort-signals.js.map +1 -0
  558. package/dist/utils/diagnostics.d.ts +19 -0
  559. package/dist/utils/diagnostics.d.ts.map +1 -0
  560. package/dist/utils/diagnostics.js +25 -0
  561. package/dist/utils/diagnostics.js.map +1 -0
  562. package/dist/utils/error-body.d.ts +25 -0
  563. package/dist/utils/error-body.d.ts.map +1 -0
  564. package/dist/utils/error-body.js +109 -0
  565. package/dist/utils/error-body.js.map +1 -0
  566. package/dist/utils/estimate.d.ts +17 -0
  567. package/dist/utils/estimate.d.ts.map +1 -0
  568. package/dist/utils/estimate.js +95 -0
  569. package/dist/utils/estimate.js.map +1 -0
  570. package/dist/utils/event-stream.d.ts +21 -0
  571. package/dist/utils/event-stream.d.ts.map +1 -0
  572. package/dist/utils/event-stream.js +81 -0
  573. package/dist/utils/event-stream.js.map +1 -0
  574. package/dist/utils/hash.d.ts +3 -0
  575. package/dist/utils/hash.d.ts.map +1 -0
  576. package/dist/utils/hash.js +14 -0
  577. package/dist/utils/hash.js.map +1 -0
  578. package/dist/utils/headers.d.ts +4 -0
  579. package/dist/utils/headers.d.ts.map +1 -0
  580. package/dist/utils/headers.js +18 -0
  581. package/dist/utils/headers.js.map +1 -0
  582. package/dist/utils/json-parse.d.ts +16 -0
  583. package/dist/utils/json-parse.d.ts.map +1 -0
  584. package/dist/utils/json-parse.js +113 -0
  585. package/dist/utils/json-parse.js.map +1 -0
  586. package/dist/utils/node-http-proxy.d.ts +4 -0
  587. package/dist/utils/node-http-proxy.d.ts.map +1 -0
  588. package/dist/utils/node-http-proxy.js +92 -0
  589. package/dist/utils/node-http-proxy.js.map +1 -0
  590. package/dist/utils/oauth/anthropic.d.ts +27 -0
  591. package/dist/utils/oauth/anthropic.d.ts.map +1 -0
  592. package/dist/utils/oauth/anthropic.js +367 -0
  593. package/dist/utils/oauth/anthropic.js.map +1 -0
  594. package/dist/utils/oauth/device-code.d.ts +21 -0
  595. package/dist/utils/oauth/device-code.d.ts.map +1 -0
  596. package/dist/utils/oauth/device-code.js +56 -0
  597. package/dist/utils/oauth/device-code.js.map +1 -0
  598. package/dist/utils/oauth/github-copilot.d.ts +32 -0
  599. package/dist/utils/oauth/github-copilot.d.ts.map +1 -0
  600. package/dist/utils/oauth/github-copilot.js +370 -0
  601. package/dist/utils/oauth/github-copilot.js.map +1 -0
  602. package/dist/utils/oauth/index.d.ts +58 -0
  603. package/dist/utils/oauth/index.d.ts.map +1 -0
  604. package/dist/utils/oauth/index.js +122 -0
  605. package/dist/utils/oauth/index.js.map +1 -0
  606. package/dist/utils/oauth/load.d.ts +5 -0
  607. package/dist/utils/oauth/load.d.ts.map +1 -0
  608. package/dist/utils/oauth/load.js +22 -0
  609. package/dist/utils/oauth/load.js.map +1 -0
  610. package/dist/utils/oauth/oauth-page.d.ts +3 -0
  611. package/dist/utils/oauth/oauth-page.d.ts.map +1 -0
  612. package/dist/utils/oauth/oauth-page.js +105 -0
  613. package/dist/utils/oauth/oauth-page.js.map +1 -0
  614. package/dist/utils/oauth/openai-codex.d.ts +45 -0
  615. package/dist/utils/oauth/openai-codex.d.ts.map +1 -0
  616. package/dist/utils/oauth/openai-codex.js +537 -0
  617. package/dist/utils/oauth/openai-codex.js.map +1 -0
  618. package/dist/utils/oauth/pkce.d.ts +13 -0
  619. package/dist/utils/oauth/pkce.d.ts.map +1 -0
  620. package/dist/utils/oauth/pkce.js +31 -0
  621. package/dist/utils/oauth/pkce.js.map +1 -0
  622. package/dist/utils/oauth/types.d.ts +64 -0
  623. package/dist/utils/oauth/types.d.ts.map +1 -0
  624. package/dist/utils/oauth/types.js +2 -0
  625. package/dist/utils/oauth/types.js.map +1 -0
  626. package/dist/utils/overflow.d.ts +57 -0
  627. package/dist/utils/overflow.d.ts.map +1 -0
  628. package/dist/utils/overflow.js +155 -0
  629. package/dist/utils/overflow.js.map +1 -0
  630. package/dist/utils/provider-env.d.ts +7 -0
  631. package/dist/utils/provider-env.d.ts.map +1 -0
  632. package/dist/utils/provider-env.js +44 -0
  633. package/dist/utils/provider-env.js.map +1 -0
  634. package/dist/utils/retry.d.ts +12 -0
  635. package/dist/utils/retry.d.ts.map +1 -0
  636. package/dist/utils/retry.js +86 -0
  637. package/dist/utils/retry.js.map +1 -0
  638. package/dist/utils/sanitize-unicode.d.ts +22 -0
  639. package/dist/utils/sanitize-unicode.d.ts.map +1 -0
  640. package/dist/utils/sanitize-unicode.js +26 -0
  641. package/dist/utils/sanitize-unicode.js.map +1 -0
  642. package/dist/utils/typebox-helpers.d.ts +17 -0
  643. package/dist/utils/typebox-helpers.d.ts.map +1 -0
  644. package/dist/utils/typebox-helpers.js +21 -0
  645. package/dist/utils/typebox-helpers.js.map +1 -0
  646. package/dist/utils/validation.d.ts +18 -0
  647. package/dist/utils/validation.d.ts.map +1 -0
  648. package/dist/utils/validation.js +281 -0
  649. package/dist/utils/validation.js.map +1 -0
  650. package/package.json +92 -0
@@ -0,0 +1,872 @@
1
+ import { BedrockRuntimeClient, BedrockRuntimeServiceException, StopReason as BedrockStopReason, CachePointType, CacheTTL, ConversationRole, ConverseStreamCommand, ImageFormat, ToolResultStatus, } from "@aws-sdk/client-bedrock-runtime";
2
+ import { NodeHttpHandler } from "@smithy/node-http-handler";
3
+ import { HttpProxyAgent } from "http-proxy-agent";
4
+ import { HttpsProxyAgent } from "https-proxy-agent";
5
+ import { calculateCost } from "../models.js";
6
+ import { normalizeProviderError } from "../utils/error-body.js";
7
+ import { AssistantMessageEventStream } from "../utils/event-stream.js";
8
+ import { providerHeadersToRecord } from "../utils/headers.js";
9
+ import { parseStreamingJson } from "../utils/json-parse.js";
10
+ import { resolveHttpProxyUrlForTarget } from "../utils/node-http-proxy.js";
11
+ import { getProviderEnvValue } from "../utils/provider-env.js";
12
+ import { sanitizeSurrogates } from "../utils/sanitize-unicode.js";
13
+ import { adjustMaxTokensForThinking, buildBaseOptions, clampMaxTokensToContext, clampReasoning, } from "./simple-options.js";
14
+ import { transformMessages } from "./transform-messages.js";
15
+ const EMPTY_TEXT_PLACEHOLDER = "<empty>";
16
+ export const stream = (model, context, options = {}) => {
17
+ const stream = new AssistantMessageEventStream();
18
+ (async () => {
19
+ const output = {
20
+ role: "assistant",
21
+ content: [],
22
+ api: "bedrock-converse-stream",
23
+ provider: model.provider,
24
+ model: model.id,
25
+ usage: {
26
+ input: 0,
27
+ output: 0,
28
+ cacheRead: 0,
29
+ cacheWrite: 0,
30
+ totalTokens: 0,
31
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
32
+ },
33
+ stopReason: "stop",
34
+ timestamp: Date.now(),
35
+ };
36
+ const blocks = output.content;
37
+ const config = {
38
+ profile: options.profile || getProviderEnvValue("AWS_PROFILE", options.env),
39
+ };
40
+ const configuredRegion = getConfiguredBedrockRegion(options);
41
+ const hasAmbientConfiguredProfile = Boolean(getProviderEnvValue("AWS_PROFILE"));
42
+ const endpointRegion = getStandardBedrockEndpointRegion(model.baseUrl);
43
+ const useExplicitEndpoint = shouldUseExplicitBedrockEndpoint(model.baseUrl, configuredRegion, hasAmbientConfiguredProfile);
44
+ // Only pin standard AWS Bedrock runtime endpoints when no region or ambient AWS_PROFILE is configured.
45
+ // This preserves custom endpoints (VPC/proxy) from #3402 without forcing built-in
46
+ // catalog defaults such as us-east-1 to override AWS_REGION/AWS_PROFILE.
47
+ if (useExplicitEndpoint) {
48
+ config.endpoint = model.baseUrl;
49
+ }
50
+ // Resolve bearer token for Bedrock API key auth.
51
+ const skipAuth = getProviderEnvValue("AWS_BEDROCK_SKIP_AUTH", options.env) === "1";
52
+ const bearerToken = options.bearerToken || getProviderEnvValue("AWS_BEARER_TOKEN_BEDROCK", options.env) || undefined;
53
+ const useBearerToken = bearerToken !== undefined && !skipAuth;
54
+ // in Node.js/Bun environment only
55
+ if (typeof process !== "undefined" && (process.versions?.node || process.versions?.bun)) {
56
+ // Region resolution: ARN-embedded > explicit option > env vars > SDK default chain.
57
+ // When the model ID is an inference profile ARN, extract the region from it.
58
+ // This avoids conflicts with AWS_REGION set for other services.
59
+ const arnRegionMatch = model.id.match(/^arn:aws(?:-[a-z0-9-]+)?:bedrock:([a-z0-9-]+):/);
60
+ if (arnRegionMatch) {
61
+ config.region = arnRegionMatch[1];
62
+ }
63
+ else if (configuredRegion) {
64
+ config.region = configuredRegion;
65
+ }
66
+ else if (endpointRegion && useExplicitEndpoint) {
67
+ config.region = endpointRegion;
68
+ }
69
+ else if (!hasAmbientConfiguredProfile) {
70
+ config.region = "us-east-1";
71
+ }
72
+ // Support proxies that don't need authentication
73
+ if (skipAuth) {
74
+ config.credentials = {
75
+ accessKeyId: "dummy-access-key",
76
+ secretAccessKey: "dummy-secret-key",
77
+ };
78
+ }
79
+ const credentials = getConfiguredBedrockCredentials(options.env);
80
+ if (!skipAuth && credentials) {
81
+ config.credentials = credentials;
82
+ }
83
+ const proxyUrl = resolveHttpProxyUrlForTarget(model.baseUrl, options.env);
84
+ if (proxyUrl) {
85
+ // Bedrock runtime uses NodeHttp2Handler by default since v3.798.0, which is based
86
+ // on `http2` module and has no support for http agent.
87
+ // Use NodeHttpHandler to support HTTP(S) proxy agents.
88
+ config.requestHandler = new NodeHttpHandler({
89
+ httpAgent: new HttpProxyAgent(proxyUrl),
90
+ httpsAgent: new HttpsProxyAgent(proxyUrl),
91
+ });
92
+ }
93
+ else if (getProviderEnvValue("AWS_BEDROCK_FORCE_HTTP1", options.env) === "1") {
94
+ // Some custom endpoints require HTTP/1.1 instead of HTTP/2
95
+ config.requestHandler = new NodeHttpHandler();
96
+ }
97
+ }
98
+ else {
99
+ // Non-Node environment (browser): fall back to us-east-1 since
100
+ // there's no config file resolution available.
101
+ config.region =
102
+ configuredRegion || (endpointRegion && useExplicitEndpoint ? endpointRegion : undefined) || "us-east-1";
103
+ }
104
+ if (useBearerToken) {
105
+ config.token = { token: bearerToken };
106
+ config.authSchemePreference = ["httpBearerAuth"];
107
+ }
108
+ try {
109
+ const client = new BedrockRuntimeClient(config);
110
+ const customHeaders = providerHeadersToRecord(options.headers);
111
+ if (customHeaders) {
112
+ addCustomHeadersMiddleware(client, customHeaders);
113
+ }
114
+ const cacheRetention = resolveCacheRetention(options.cacheRetention, options.env);
115
+ const inferenceMaxTokens = options.maxTokens ?? (isAnthropicClaudeModel(model) ? model.maxTokens : undefined);
116
+ let commandInput = {
117
+ modelId: model.id,
118
+ messages: convertMessages(context, model, cacheRetention, options.env),
119
+ system: buildSystemPrompt(context.systemPrompt, model, cacheRetention, options.env),
120
+ inferenceConfig: {
121
+ ...(inferenceMaxTokens !== undefined && { maxTokens: inferenceMaxTokens }),
122
+ ...(options.temperature !== undefined && { temperature: options.temperature }),
123
+ },
124
+ toolConfig: convertToolConfig(context.tools, options.toolChoice),
125
+ additionalModelRequestFields: buildAdditionalModelRequestFields(model, options),
126
+ ...(options.requestMetadata !== undefined && { requestMetadata: options.requestMetadata }),
127
+ };
128
+ const nextCommandInput = await options?.onPayload?.(commandInput, model);
129
+ if (nextCommandInput !== undefined) {
130
+ commandInput = nextCommandInput;
131
+ }
132
+ const command = new ConverseStreamCommand(commandInput);
133
+ const response = await client.send(command, { abortSignal: options.signal });
134
+ if (response.$metadata.httpStatusCode !== undefined) {
135
+ const responseHeaders = {};
136
+ if (response.$metadata.requestId) {
137
+ responseHeaders["x-amzn-requestid"] = response.$metadata.requestId;
138
+ }
139
+ await options?.onResponse?.({ status: response.$metadata.httpStatusCode, headers: responseHeaders }, model);
140
+ }
141
+ for await (const item of response.stream) {
142
+ if (item.messageStart) {
143
+ if (item.messageStart.role !== ConversationRole.ASSISTANT) {
144
+ throw new Error("Unexpected assistant message start but got user message start instead");
145
+ }
146
+ stream.push({ type: "start", partial: output });
147
+ }
148
+ else if (item.contentBlockStart) {
149
+ handleContentBlockStart(item.contentBlockStart, blocks, output, stream);
150
+ }
151
+ else if (item.contentBlockDelta) {
152
+ handleContentBlockDelta(item.contentBlockDelta, blocks, output, stream);
153
+ }
154
+ else if (item.contentBlockStop) {
155
+ handleContentBlockStop(item.contentBlockStop, blocks, output, stream);
156
+ }
157
+ else if (item.messageStop) {
158
+ output.stopReason = mapStopReason(item.messageStop.stopReason);
159
+ }
160
+ else if (item.metadata) {
161
+ handleMetadata(item.metadata, model, output);
162
+ }
163
+ else if (item.internalServerException) {
164
+ throw item.internalServerException;
165
+ }
166
+ else if (item.modelStreamErrorException) {
167
+ throw item.modelStreamErrorException;
168
+ }
169
+ else if (item.validationException) {
170
+ throw item.validationException;
171
+ }
172
+ else if (item.throttlingException) {
173
+ throw item.throttlingException;
174
+ }
175
+ else if (item.serviceUnavailableException) {
176
+ throw item.serviceUnavailableException;
177
+ }
178
+ }
179
+ if (options.signal?.aborted) {
180
+ throw new Error("Request was aborted");
181
+ }
182
+ if (output.stopReason === "error" || output.stopReason === "aborted") {
183
+ throw new Error("An unknown error occurred");
184
+ }
185
+ stream.push({ type: "done", reason: output.stopReason, message: output });
186
+ stream.end();
187
+ }
188
+ catch (error) {
189
+ for (const block of output.content) {
190
+ delete block.index;
191
+ // partialJson is only a streaming scratch buffer; never persist it.
192
+ delete block.partialJson;
193
+ }
194
+ output.stopReason = options.signal?.aborted ? "aborted" : "error";
195
+ output.errorMessage = formatBedrockError(error);
196
+ stream.push({ type: "error", reason: output.stopReason, error: output });
197
+ stream.end();
198
+ }
199
+ })();
200
+ return stream;
201
+ };
202
+ /**
203
+ * Human-readable prefixes for Bedrock SDK exception names.
204
+ * The downstream retry logic in agent-session matches patterns like
205
+ * `server.?error` and `service.?unavailable`, so we preserve the legacy
206
+ * prefix format rather than using the raw SDK exception name.
207
+ */
208
+ const BEDROCK_ERROR_PREFIXES = {
209
+ InternalServerException: "Internal server error",
210
+ ModelStreamErrorException: "Model stream error",
211
+ ValidationException: "Validation error",
212
+ ThrottlingException: "Throttling error",
213
+ ServiceUnavailableException: "Service unavailable",
214
+ };
215
+ /**
216
+ * Some models reject the account/profile's configured Bedrock data retention mode
217
+ * (e.g. "data retention mode 'default' is not available for this model"). Point
218
+ * users at the AWS docs explaining how to configure a supported mode.
219
+ */
220
+ const BEDROCK_DATA_RETENTION_DOCS_URL = "https://docs.aws.amazon.com/bedrock/latest/userguide/data-retention.html";
221
+ /**
222
+ * Format a Bedrock error with a human-readable prefix.
223
+ * AWS SDK exceptions (both from `client.send()` and from stream event items)
224
+ * extend BedrockRuntimeServiceException. We map the `.name` to a stable
225
+ * human-readable prefix so downstream consumers (retry logic, context-overflow
226
+ * detection) can distinguish error categories via simple string matching.
227
+ */
228
+ function formatBedrockError(error) {
229
+ const norm = normalizeProviderError(error);
230
+ // Surface the raw HTTP body (with status) when the SDK did not fold it into
231
+ // the message; otherwise fall back to the message. This is what stops a
232
+ // gateway 403 from collapsing to `Unknown: UnknownError`.
233
+ const core = !norm.messageCarriesBody && norm.status !== undefined && norm.body !== undefined
234
+ ? `${norm.status}: ${norm.body}`
235
+ : norm.message;
236
+ const dataRetentionHint = /data retention mode/i.test(core)
237
+ ? ` See ${BEDROCK_DATA_RETENTION_DOCS_URL} for supported data retention modes.`
238
+ : "";
239
+ if (error instanceof BedrockRuntimeServiceException) {
240
+ const prefix = BEDROCK_ERROR_PREFIXES[error.name] ?? error.name;
241
+ return `${prefix}: ${core}${dataRetentionHint}`;
242
+ }
243
+ return `${core}${dataRetentionHint}`;
244
+ }
245
+ /**
246
+ * Header keys that must never be overwritten by caller-supplied headers.
247
+ * `host` and `x-amz-*` participate in the SigV4 canonical request; `authorization`
248
+ * is owned by SigV4 or the bearer-token path (config.token + authSchemePreference).
249
+ * Compared case-insensitively (caller key is lower-cased before lookup).
250
+ */
251
+ const RESERVED_HEADER_EXACT = new Set(["authorization", "host"]);
252
+ function isReservedHeader(key) {
253
+ const lower = key.toLowerCase();
254
+ return lower.startsWith("x-amz-") || RESERVED_HEADER_EXACT.has(lower);
255
+ }
256
+ /**
257
+ * Attach caller-supplied headers to the outgoing Bedrock request via a Smithy
258
+ * `build`-step middleware. The `build` step runs after request serialisation but
259
+ * before SigV4 signing, so injected headers are covered by the signature. Reserved
260
+ * SigV4 / auth headers (`x-amz-*`, `authorization`, `host`) are silently skipped;
261
+ * all other caller headers override any existing same-named header on the request.
262
+ */
263
+ function addCustomHeadersMiddleware(client, headers) {
264
+ const middleware = (next) => async (args) => {
265
+ const request = args.request;
266
+ if (request && typeof request === "object" && "headers" in request) {
267
+ const requestHeaders = request.headers;
268
+ for (const [key, value] of Object.entries(headers)) {
269
+ if (!isReservedHeader(key)) {
270
+ requestHeaders[key] = value;
271
+ }
272
+ }
273
+ }
274
+ return next(args);
275
+ };
276
+ client.middlewareStack.add(middleware, { step: "build", name: "pi-ai-custom-headers", priority: "low" });
277
+ }
278
+ export const streamSimple = (model, context, options) => {
279
+ const base = buildBaseOptions(model, context, options, undefined);
280
+ if (!options?.reasoning) {
281
+ return stream(model, context, { ...base, reasoning: undefined });
282
+ }
283
+ if (isAnthropicClaudeModel(model)) {
284
+ if (supportsAdaptiveThinking(model.id, model.name)) {
285
+ return stream(model, context, {
286
+ ...base,
287
+ reasoning: options.reasoning,
288
+ thinkingBudgets: options.thinkingBudgets,
289
+ });
290
+ }
291
+ // Undefined means the caller did not request an output cap; let the helper use the model cap.
292
+ // Do not coerce to 0 here, or the thinking budget would become the entire maxTokens value.
293
+ const adjusted = adjustMaxTokensForThinking(base.maxTokens, model.maxTokens, options.reasoning, options.thinkingBudgets);
294
+ const maxTokens = clampMaxTokensToContext(model, context, adjusted.maxTokens);
295
+ return stream(model, context, {
296
+ ...base,
297
+ maxTokens,
298
+ reasoning: options.reasoning,
299
+ thinkingBudgets: {
300
+ ...(options.thinkingBudgets || {}),
301
+ [clampReasoning(options.reasoning)]: Math.min(adjusted.thinkingBudget, Math.max(0, maxTokens - 1024)),
302
+ },
303
+ });
304
+ }
305
+ return stream(model, context, {
306
+ ...base,
307
+ reasoning: options.reasoning,
308
+ thinkingBudgets: options.thinkingBudgets,
309
+ });
310
+ };
311
+ function handleContentBlockStart(event, blocks, output, stream) {
312
+ const index = event.contentBlockIndex;
313
+ const start = event.start;
314
+ if (start?.toolUse) {
315
+ const block = {
316
+ type: "toolCall",
317
+ id: start.toolUse.toolUseId || "",
318
+ name: start.toolUse.name || "",
319
+ arguments: {},
320
+ partialJson: "",
321
+ index,
322
+ };
323
+ output.content.push(block);
324
+ stream.push({ type: "toolcall_start", contentIndex: blocks.length - 1, partial: output });
325
+ }
326
+ }
327
+ function handleContentBlockDelta(event, blocks, output, stream) {
328
+ const contentBlockIndex = event.contentBlockIndex;
329
+ const delta = event.delta;
330
+ let index = blocks.findIndex((b) => b.index === contentBlockIndex);
331
+ let block = blocks[index];
332
+ if (delta?.text !== undefined) {
333
+ // If no text block exists yet, create one, as `handleContentBlockStart` is not sent for text blocks
334
+ if (!block) {
335
+ const newBlock = { type: "text", text: "", index: contentBlockIndex };
336
+ output.content.push(newBlock);
337
+ index = blocks.length - 1;
338
+ block = blocks[index];
339
+ stream.push({ type: "text_start", contentIndex: index, partial: output });
340
+ }
341
+ if (block.type === "text") {
342
+ block.text += delta.text;
343
+ stream.push({ type: "text_delta", contentIndex: index, delta: delta.text, partial: output });
344
+ }
345
+ }
346
+ else if (delta?.toolUse && block?.type === "toolCall") {
347
+ block.partialJson = (block.partialJson || "") + (delta.toolUse.input || "");
348
+ block.arguments = parseStreamingJson(block.partialJson);
349
+ stream.push({ type: "toolcall_delta", contentIndex: index, delta: delta.toolUse.input || "", partial: output });
350
+ }
351
+ else if (delta?.reasoningContent) {
352
+ let thinkingBlock = block;
353
+ let thinkingIndex = index;
354
+ if (!thinkingBlock) {
355
+ const newBlock = { type: "thinking", thinking: "", thinkingSignature: "", index: contentBlockIndex };
356
+ output.content.push(newBlock);
357
+ thinkingIndex = blocks.length - 1;
358
+ thinkingBlock = blocks[thinkingIndex];
359
+ stream.push({ type: "thinking_start", contentIndex: thinkingIndex, partial: output });
360
+ }
361
+ if (thinkingBlock?.type === "thinking") {
362
+ if (delta.reasoningContent.text) {
363
+ thinkingBlock.thinking += delta.reasoningContent.text;
364
+ stream.push({
365
+ type: "thinking_delta",
366
+ contentIndex: thinkingIndex,
367
+ delta: delta.reasoningContent.text,
368
+ partial: output,
369
+ });
370
+ }
371
+ if (delta.reasoningContent.signature) {
372
+ thinkingBlock.thinkingSignature =
373
+ (thinkingBlock.thinkingSignature || "") + delta.reasoningContent.signature;
374
+ }
375
+ }
376
+ }
377
+ }
378
+ function handleMetadata(event, model, output) {
379
+ if (event.usage) {
380
+ output.usage.input = event.usage.inputTokens || 0;
381
+ output.usage.output = event.usage.outputTokens || 0;
382
+ output.usage.cacheRead = event.usage.cacheReadInputTokens || 0;
383
+ output.usage.cacheWrite = event.usage.cacheWriteInputTokens || 0;
384
+ output.usage.totalTokens = event.usage.totalTokens || output.usage.input + output.usage.output;
385
+ calculateCost(model, output.usage);
386
+ }
387
+ }
388
+ function handleContentBlockStop(event, blocks, output, stream) {
389
+ const index = blocks.findIndex((b) => b.index === event.contentBlockIndex);
390
+ const block = blocks[index];
391
+ if (!block)
392
+ return;
393
+ delete block.index;
394
+ switch (block.type) {
395
+ case "text":
396
+ stream.push({ type: "text_end", contentIndex: index, content: block.text, partial: output });
397
+ break;
398
+ case "thinking":
399
+ stream.push({ type: "thinking_end", contentIndex: index, content: block.thinking, partial: output });
400
+ break;
401
+ case "toolCall":
402
+ block.arguments = parseStreamingJson(block.partialJson);
403
+ // Finalize in-place and strip the scratch buffer so replay only
404
+ // carries parsed arguments.
405
+ delete block.partialJson;
406
+ stream.push({ type: "toolcall_end", contentIndex: index, toolCall: block, partial: output });
407
+ break;
408
+ }
409
+ }
410
+ /**
411
+ * Check if the model supports adaptive thinking (Opus 4.6+, Sonnet 4.6).
412
+ * Checks both model ID and model name to support application inference profiles
413
+ * whose ARNs don't contain the model name.
414
+ */
415
+ function getModelMatchCandidates(modelId, modelName) {
416
+ const values = modelName ? [modelId, modelName] : [modelId];
417
+ return values.flatMap((value) => {
418
+ const lower = value.toLowerCase();
419
+ return [lower, lower.replace(/[\s_.:]+/g, "-")];
420
+ });
421
+ }
422
+ function supportsAdaptiveThinking(modelId, modelName) {
423
+ const candidates = getModelMatchCandidates(modelId, modelName);
424
+ return candidates.some((s) => s.includes("opus-4-6") ||
425
+ s.includes("opus-4-7") ||
426
+ s.includes("opus-4-8") ||
427
+ s.includes("sonnet-4-6") ||
428
+ s.includes("sonnet-5") ||
429
+ s.includes("fable-5"));
430
+ }
431
+ function supportsNativeXhighEffort(model) {
432
+ const candidates = getModelMatchCandidates(model.id, model.name);
433
+ return candidates.some((s) => s.includes("opus-4-7") || s.includes("opus-4-8") || s.includes("fable-5"));
434
+ }
435
+ function mapThinkingLevelToEffort(model, level) {
436
+ if (level === "xhigh" && supportsNativeXhighEffort(model))
437
+ return "xhigh";
438
+ const mapped = level ? model.thinkingLevelMap?.[level] : undefined;
439
+ if (typeof mapped === "string")
440
+ return mapped;
441
+ switch (level) {
442
+ case "minimal":
443
+ case "low":
444
+ return "low";
445
+ case "medium":
446
+ return "medium";
447
+ case "high":
448
+ return "high";
449
+ default:
450
+ return "high";
451
+ }
452
+ }
453
+ /**
454
+ * Resolve cache retention preference.
455
+ * Defaults to "short" and uses PI_CACHE_RETENTION for backward compatibility.
456
+ */
457
+ function resolveCacheRetention(cacheRetention, env) {
458
+ if (cacheRetention) {
459
+ return cacheRetention;
460
+ }
461
+ if (getProviderEnvValue("PI_CACHE_RETENTION", env) === "long") {
462
+ return "long";
463
+ }
464
+ return "short";
465
+ }
466
+ /**
467
+ * Check if the model is an Anthropic Claude model on Bedrock.
468
+ * Checks both model ID and model name to support application inference profiles
469
+ * whose ARNs don't contain the model name.
470
+ */
471
+ function isAnthropicClaudeModel(model) {
472
+ const id = model.id.toLowerCase();
473
+ const name = model.name?.toLowerCase() ?? "";
474
+ return (id.includes("anthropic.claude") ||
475
+ id.includes("anthropic/claude") ||
476
+ name.includes("anthropic.claude") ||
477
+ name.includes("anthropic/claude") ||
478
+ name.includes("claude"));
479
+ }
480
+ /**
481
+ * Check if the model supports prompt caching.
482
+ * Supported: Claude 3.5 Haiku, Claude 3.7 Sonnet, Claude 4.x models
483
+ *
484
+ * For base models and system-defined inference profiles the model ID / ARN
485
+ * contains the model name, so we can decide locally.
486
+ *
487
+ * For application inference profiles (whose ARNs don't contain the model name),
488
+ * also checks model.name which is user-controlled via models.json or registerProvider.
489
+ * As a last resort, set AWS_BEDROCK_FORCE_CACHE=1 to enable cache points.
490
+ * Amazon Nova models have automatic caching and don't need explicit cache points.
491
+ */
492
+ function supportsPromptCaching(model, env) {
493
+ const candidates = getModelMatchCandidates(model.id, model.name);
494
+ const hasClaudeRef = candidates.some((s) => s.includes("claude"));
495
+ if (!hasClaudeRef) {
496
+ // Application inference profiles don't contain the model name in the ARN.
497
+ // Allow users to force cache points via environment variable.
498
+ if (getProviderEnvValue("AWS_BEDROCK_FORCE_CACHE", env) === "1")
499
+ return true;
500
+ return false;
501
+ }
502
+ // Claude 4.x models (opus-4, sonnet-4, haiku-4)
503
+ if (candidates.some((s) => s.includes("-4-")))
504
+ return true;
505
+ // Claude 3.7 Sonnet
506
+ if (candidates.some((s) => s.includes("claude-3-7-sonnet")))
507
+ return true;
508
+ // Claude 3.5 Haiku
509
+ if (candidates.some((s) => s.includes("claude-3-5-haiku")))
510
+ return true;
511
+ return false;
512
+ }
513
+ /**
514
+ * Check if the model supports thinking signatures in reasoningContent.
515
+ * Only Anthropic Claude models support the signature field.
516
+ * Other models (OpenAI, Qwen, Minimax, Moonshot, etc.) reject it with:
517
+ * "This model doesn't support the reasoningContent.reasoningText.signature field"
518
+ *
519
+ * Checks both model ID and model name to support application inference profiles.
520
+ */
521
+ function supportsThinkingSignature(model) {
522
+ return isAnthropicClaudeModel(model);
523
+ }
524
+ function buildSystemPrompt(systemPrompt, model, cacheRetention, env) {
525
+ if (!systemPrompt)
526
+ return undefined;
527
+ const blocks = [{ text: sanitizeSurrogates(systemPrompt) }];
528
+ // Add cache point for supported Claude models when caching is enabled
529
+ if (cacheRetention !== "none" && supportsPromptCaching(model, env)) {
530
+ blocks.push({
531
+ cachePoint: { type: CachePointType.DEFAULT, ...(cacheRetention === "long" ? { ttl: CacheTTL.ONE_HOUR } : {}) },
532
+ });
533
+ }
534
+ return blocks;
535
+ }
536
+ function normalizeToolCallId(id) {
537
+ const sanitized = id.replace(/[^a-zA-Z0-9_-]/g, "_");
538
+ return sanitized.length > 64 ? sanitized.slice(0, 64) : sanitized;
539
+ }
540
+ function createNonBlankTextBlock(text) {
541
+ const sanitized = sanitizeSurrogates(text);
542
+ return sanitized.trim().length === 0 ? undefined : { text: sanitized };
543
+ }
544
+ function createRequiredTextBlock(text) {
545
+ return createNonBlankTextBlock(text) ?? { text: EMPTY_TEXT_PLACEHOLDER };
546
+ }
547
+ function convertToolResultContent(content) {
548
+ const result = [];
549
+ for (const c of content) {
550
+ if (c.type === "image") {
551
+ result.push({ image: createImageBlock(c.mimeType, c.data) });
552
+ }
553
+ else {
554
+ const textBlock = createNonBlankTextBlock(c.text);
555
+ if (textBlock)
556
+ result.push(textBlock);
557
+ }
558
+ }
559
+ if (result.length === 0)
560
+ result.push({ text: EMPTY_TEXT_PLACEHOLDER });
561
+ return result;
562
+ }
563
+ function convertMessages(context, model, cacheRetention, env) {
564
+ const result = [];
565
+ const transformedMessages = transformMessages(context.messages, model, normalizeToolCallId);
566
+ for (let i = 0; i < transformedMessages.length; i++) {
567
+ const m = transformedMessages[i];
568
+ switch (m.role) {
569
+ case "user": {
570
+ const content = [];
571
+ if (typeof m.content === "string") {
572
+ content.push(createRequiredTextBlock(m.content));
573
+ }
574
+ else {
575
+ for (const c of m.content) {
576
+ switch (c.type) {
577
+ case "text": {
578
+ const textBlock = createNonBlankTextBlock(c.text);
579
+ if (textBlock)
580
+ content.push(textBlock);
581
+ break;
582
+ }
583
+ case "image":
584
+ content.push({ image: createImageBlock(c.mimeType, c.data) });
585
+ break;
586
+ default:
587
+ continue;
588
+ }
589
+ }
590
+ if (content.length === 0)
591
+ content.push({ text: EMPTY_TEXT_PLACEHOLDER });
592
+ }
593
+ result.push({
594
+ role: ConversationRole.USER,
595
+ content,
596
+ });
597
+ break;
598
+ }
599
+ case "assistant": {
600
+ // Skip assistant messages with empty content (e.g., from aborted requests)
601
+ // Bedrock rejects messages with empty content arrays
602
+ if (m.content.length === 0) {
603
+ continue;
604
+ }
605
+ const contentBlocks = [];
606
+ for (const c of m.content) {
607
+ switch (c.type) {
608
+ case "text": {
609
+ // Skip empty text blocks
610
+ const textBlock = createNonBlankTextBlock(c.text);
611
+ if (!textBlock)
612
+ continue;
613
+ contentBlocks.push(textBlock);
614
+ break;
615
+ }
616
+ case "toolCall":
617
+ contentBlocks.push({
618
+ toolUse: { toolUseId: c.id, name: c.name, input: c.arguments },
619
+ });
620
+ break;
621
+ case "thinking": {
622
+ // Skip empty thinking blocks
623
+ const thinking = sanitizeSurrogates(c.thinking);
624
+ if (thinking.trim().length === 0)
625
+ continue;
626
+ // Only Anthropic models support the signature field in reasoningText.
627
+ // For other models, we omit the signature to avoid errors like:
628
+ // "This model doesn't support the reasoningContent.reasoningText.signature field"
629
+ if (supportsThinkingSignature(model)) {
630
+ // Signatures arrive after thinking deltas. If a partial or externally
631
+ // persisted message lacks a signature, Bedrock rejects the replayed
632
+ // reasoning block. Fall back to plain text, matching Anthropic.
633
+ if (!c.thinkingSignature || c.thinkingSignature.trim().length === 0) {
634
+ contentBlocks.push({ text: thinking });
635
+ }
636
+ else {
637
+ contentBlocks.push({
638
+ reasoningContent: {
639
+ reasoningText: {
640
+ text: thinking,
641
+ signature: c.thinkingSignature,
642
+ },
643
+ },
644
+ });
645
+ }
646
+ }
647
+ else {
648
+ contentBlocks.push({
649
+ reasoningContent: {
650
+ reasoningText: { text: thinking },
651
+ },
652
+ });
653
+ }
654
+ break;
655
+ }
656
+ default:
657
+ continue;
658
+ }
659
+ }
660
+ // Skip if all content blocks were filtered out
661
+ if (contentBlocks.length === 0) {
662
+ continue;
663
+ }
664
+ result.push({
665
+ role: ConversationRole.ASSISTANT,
666
+ content: contentBlocks,
667
+ });
668
+ break;
669
+ }
670
+ case "toolResult": {
671
+ // Collect all consecutive toolResult messages into a single user message
672
+ // Bedrock requires all tool results to be in one message
673
+ const toolResults = [];
674
+ // Add current tool result with all content blocks combined
675
+ toolResults.push({
676
+ toolResult: {
677
+ toolUseId: m.toolCallId,
678
+ content: convertToolResultContent(m.content),
679
+ status: m.isError ? ToolResultStatus.ERROR : ToolResultStatus.SUCCESS,
680
+ },
681
+ });
682
+ // Look ahead for consecutive toolResult messages
683
+ let j = i + 1;
684
+ while (j < transformedMessages.length && transformedMessages[j].role === "toolResult") {
685
+ const nextMsg = transformedMessages[j];
686
+ toolResults.push({
687
+ toolResult: {
688
+ toolUseId: nextMsg.toolCallId,
689
+ content: convertToolResultContent(nextMsg.content),
690
+ status: nextMsg.isError ? ToolResultStatus.ERROR : ToolResultStatus.SUCCESS,
691
+ },
692
+ });
693
+ j++;
694
+ }
695
+ // Skip the messages we've already processed
696
+ i = j - 1;
697
+ result.push({
698
+ role: ConversationRole.USER,
699
+ content: toolResults,
700
+ });
701
+ break;
702
+ }
703
+ default:
704
+ continue;
705
+ }
706
+ }
707
+ // Add cache point to the last user message for supported Claude models when caching is enabled
708
+ if (cacheRetention !== "none" && supportsPromptCaching(model, env) && result.length > 0) {
709
+ const lastMessage = result[result.length - 1];
710
+ if (lastMessage.role === ConversationRole.USER && lastMessage.content) {
711
+ lastMessage.content.push({
712
+ cachePoint: {
713
+ type: CachePointType.DEFAULT,
714
+ ...(cacheRetention === "long" ? { ttl: CacheTTL.ONE_HOUR } : {}),
715
+ },
716
+ });
717
+ }
718
+ }
719
+ return result;
720
+ }
721
+ function convertToolConfig(tools, toolChoice) {
722
+ if (!tools?.length || toolChoice === "none")
723
+ return undefined;
724
+ const bedrockTools = tools.map((tool) => ({
725
+ toolSpec: {
726
+ name: tool.name,
727
+ description: tool.description,
728
+ inputSchema: { json: tool.parameters },
729
+ },
730
+ }));
731
+ let bedrockToolChoice;
732
+ switch (toolChoice) {
733
+ case "auto":
734
+ bedrockToolChoice = { auto: {} };
735
+ break;
736
+ case "any":
737
+ bedrockToolChoice = { any: {} };
738
+ break;
739
+ default:
740
+ if (toolChoice?.type === "tool") {
741
+ bedrockToolChoice = { tool: { name: toolChoice.name } };
742
+ }
743
+ }
744
+ return { tools: bedrockTools, toolChoice: bedrockToolChoice };
745
+ }
746
+ function mapStopReason(reason) {
747
+ switch (reason) {
748
+ case BedrockStopReason.END_TURN:
749
+ case BedrockStopReason.STOP_SEQUENCE:
750
+ return "stop";
751
+ case BedrockStopReason.MAX_TOKENS:
752
+ case BedrockStopReason.MODEL_CONTEXT_WINDOW_EXCEEDED:
753
+ return "length";
754
+ case BedrockStopReason.TOOL_USE:
755
+ return "toolUse";
756
+ default:
757
+ return "error";
758
+ }
759
+ }
760
+ function getConfiguredBedrockRegion(options) {
761
+ return (options.region ||
762
+ getProviderEnvValue("AWS_REGION", options.env) ||
763
+ getProviderEnvValue("AWS_DEFAULT_REGION", options.env) ||
764
+ undefined);
765
+ }
766
+ function getConfiguredBedrockCredentials(env) {
767
+ const accessKeyId = getProviderEnvValue("AWS_ACCESS_KEY_ID", env);
768
+ const secretAccessKey = getProviderEnvValue("AWS_SECRET_ACCESS_KEY", env);
769
+ if (!accessKeyId || !secretAccessKey) {
770
+ return undefined;
771
+ }
772
+ const sessionToken = getProviderEnvValue("AWS_SESSION_TOKEN", env);
773
+ return {
774
+ accessKeyId,
775
+ secretAccessKey,
776
+ ...(sessionToken ? { sessionToken } : {}),
777
+ };
778
+ }
779
+ function getStandardBedrockEndpointRegion(baseUrl) {
780
+ if (!baseUrl) {
781
+ return undefined;
782
+ }
783
+ try {
784
+ const { hostname } = new URL(baseUrl);
785
+ const match = hostname.toLowerCase().match(/^bedrock-runtime(?:-fips)?\.([a-z0-9-]+)\.amazonaws\.com(?:\.cn)?$/);
786
+ return match?.[1];
787
+ }
788
+ catch {
789
+ return undefined;
790
+ }
791
+ }
792
+ function shouldUseExplicitBedrockEndpoint(baseUrl, configuredRegion, hasAmbientConfiguredProfile) {
793
+ const endpointRegion = getStandardBedrockEndpointRegion(baseUrl);
794
+ if (!endpointRegion) {
795
+ return true;
796
+ }
797
+ return !configuredRegion && !hasAmbientConfiguredProfile;
798
+ }
799
+ function isGovCloudBedrockTarget(model, options) {
800
+ const region = getConfiguredBedrockRegion(options);
801
+ if (region?.toLowerCase().startsWith("us-gov-")) {
802
+ return true;
803
+ }
804
+ const modelId = model.id.toLowerCase();
805
+ return modelId.startsWith("us-gov.") || modelId.startsWith("arn:aws-us-gov:");
806
+ }
807
+ function buildAdditionalModelRequestFields(model, options) {
808
+ if (!options.reasoning || !model.reasoning) {
809
+ return undefined;
810
+ }
811
+ if (isAnthropicClaudeModel(model)) {
812
+ // GovCloud Bedrock currently rejects the Claude thinking.display field.
813
+ // Omit it there until the GovCloud Converse schema catches up.
814
+ const display = isGovCloudBedrockTarget(model, options) ? undefined : (options.thinkingDisplay ?? "summarized");
815
+ const result = supportsAdaptiveThinking(model.id, model.name)
816
+ ? {
817
+ thinking: { type: "adaptive", ...(display !== undefined ? { display } : {}) },
818
+ output_config: { effort: mapThinkingLevelToEffort(model, options.reasoning) },
819
+ }
820
+ : (() => {
821
+ const defaultBudgets = {
822
+ minimal: 1024,
823
+ low: 2048,
824
+ medium: 8192,
825
+ high: 16384,
826
+ xhigh: 16384, // Claude doesn't support xhigh, clamp to high
827
+ };
828
+ // Custom budgets override defaults (xhigh not in ThinkingBudgets, use high)
829
+ const level = options.reasoning === "xhigh" ? "high" : options.reasoning;
830
+ const budget = options.thinkingBudgets?.[level] ?? defaultBudgets[options.reasoning];
831
+ return {
832
+ thinking: {
833
+ type: "enabled",
834
+ budget_tokens: budget,
835
+ ...(display !== undefined ? { display } : {}),
836
+ },
837
+ };
838
+ })();
839
+ if (!supportsAdaptiveThinking(model.id, model.name) && (options.interleavedThinking ?? true)) {
840
+ result.anthropic_beta = ["interleaved-thinking-2025-05-14"];
841
+ }
842
+ return result;
843
+ }
844
+ return undefined;
845
+ }
846
+ function createImageBlock(mimeType, data) {
847
+ let format;
848
+ switch (mimeType) {
849
+ case "image/jpeg":
850
+ case "image/jpg":
851
+ format = ImageFormat.JPEG;
852
+ break;
853
+ case "image/png":
854
+ format = ImageFormat.PNG;
855
+ break;
856
+ case "image/gif":
857
+ format = ImageFormat.GIF;
858
+ break;
859
+ case "image/webp":
860
+ format = ImageFormat.WEBP;
861
+ break;
862
+ default:
863
+ throw new Error(`Unknown image type: ${mimeType}`);
864
+ }
865
+ const binaryString = atob(data);
866
+ const bytes = new Uint8Array(binaryString.length);
867
+ for (let i = 0; i < binaryString.length; i++) {
868
+ bytes[i] = binaryString.charCodeAt(i);
869
+ }
870
+ return { source: { bytes }, format };
871
+ }
872
+ //# sourceMappingURL=bedrock-converse-stream.js.map