@aryee337/aery-ai 0.2.28 → 0.2.29

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 (417) hide show
  1. package/CHANGELOG.md +2914 -0
  2. package/README.md +614 -813
  3. package/package.json +140 -105
  4. package/src/api-registry.ts +96 -0
  5. package/src/auth-broker/client.ts +358 -0
  6. package/src/auth-broker/index.ts +5 -0
  7. package/src/auth-broker/refresher.ts +117 -0
  8. package/src/auth-broker/remote-store.ts +623 -0
  9. package/src/auth-broker/server.ts +644 -0
  10. package/src/auth-broker/types.ts +127 -0
  11. package/src/auth-broker/wire-schemas.ts +200 -0
  12. package/src/auth-gateway/http.ts +194 -0
  13. package/src/auth-gateway/index.ts +3 -0
  14. package/src/auth-gateway/server.ts +818 -0
  15. package/src/auth-gateway/types.ts +143 -0
  16. package/src/auth-storage.ts +4422 -0
  17. package/src/index.ts +54 -0
  18. package/src/model-cache.ts +129 -0
  19. package/src/model-manager.ts +469 -0
  20. package/src/model-thinking.ts +782 -0
  21. package/src/models.json +83530 -0
  22. package/src/models.json.d.ts +9 -0
  23. package/src/models.ts +56 -0
  24. package/src/prompts/turn-aborted-guidance.md +4 -0
  25. package/src/provider-details.ts +90 -0
  26. package/src/provider-models/bundled-references.ts +38 -0
  27. package/src/provider-models/descriptors.ts +355 -0
  28. package/src/provider-models/google.ts +88 -0
  29. package/src/provider-models/index.ts +5 -0
  30. package/src/provider-models/ollama.ts +153 -0
  31. package/src/provider-models/openai-compat.ts +2817 -0
  32. package/src/provider-models/special.ts +67 -0
  33. package/src/providers/aery-native-client.ts +228 -0
  34. package/src/providers/aery-native-server.ts +212 -0
  35. package/src/providers/amazon-bedrock.ts +873 -0
  36. package/src/providers/anthropic-client.ts +318 -0
  37. package/src/providers/anthropic-messages-server-schema.ts +243 -0
  38. package/src/providers/anthropic-messages-server.ts +683 -0
  39. package/src/providers/anthropic-wire.ts +268 -0
  40. package/src/providers/anthropic.ts +3094 -0
  41. package/src/providers/aws-credentials.ts +501 -0
  42. package/src/providers/aws-eventstream.ts +185 -0
  43. package/src/providers/aws-sigv4.ts +218 -0
  44. package/src/providers/azure-openai-responses.ts +361 -0
  45. package/src/providers/cursor/gen/agent_pb.ts +15274 -0
  46. package/src/providers/cursor/proto/agent.proto +3526 -0
  47. package/src/providers/cursor/proto/buf.gen.yaml +6 -0
  48. package/src/providers/cursor/proto/buf.yaml +17 -0
  49. package/src/providers/cursor.ts +2621 -0
  50. package/src/providers/error-message.ts +21 -0
  51. package/src/providers/github-copilot-headers.ts +140 -0
  52. package/src/providers/gitlab-duo.ts +372 -0
  53. package/src/providers/google-auth.ts +252 -0
  54. package/src/providers/google-gemini-cli.ts +809 -0
  55. package/src/providers/google-gemini-headers.ts +41 -0
  56. package/src/providers/google-shared.ts +917 -0
  57. package/src/providers/google-types.ts +167 -0
  58. package/src/providers/google-vertex.ts +91 -0
  59. package/src/providers/google.ts +41 -0
  60. package/src/providers/grammar.ts +70 -0
  61. package/src/providers/kimi.ts +52 -0
  62. package/src/providers/mock.ts +496 -0
  63. package/src/providers/ollama.ts +644 -0
  64. package/src/providers/openai-anthropic-shim.ts +138 -0
  65. package/src/providers/openai-chat-server-schema.ts +252 -0
  66. package/src/providers/openai-chat-server.ts +647 -0
  67. package/src/providers/openai-codex/constants.ts +43 -0
  68. package/src/providers/openai-codex/request-transformer.ts +161 -0
  69. package/src/providers/openai-codex/response-handler.ts +81 -0
  70. package/src/providers/openai-codex-responses.ts +3018 -0
  71. package/src/providers/openai-completions-compat.ts +300 -0
  72. package/src/providers/openai-completions.ts +1979 -0
  73. package/src/providers/openai-responses-server-schema.ts +290 -0
  74. package/src/providers/openai-responses-server.ts +1183 -0
  75. package/src/providers/openai-responses-shared.ts +873 -0
  76. package/src/providers/openai-responses.ts +679 -0
  77. package/src/providers/register-builtins.ts +436 -0
  78. package/src/providers/synthetic.ts +50 -0
  79. package/src/providers/transform-messages.ts +382 -0
  80. package/src/providers/vision-guard.ts +31 -0
  81. package/src/providers/xai-responses.ts +82 -0
  82. package/src/rate-limit-utils.ts +84 -0
  83. package/src/stream.ts +1065 -0
  84. package/src/types.ts +944 -0
  85. package/src/usage/claude.ts +482 -0
  86. package/src/usage/gemini.ts +250 -0
  87. package/src/usage/github-copilot.ts +421 -0
  88. package/src/usage/google-antigravity.ts +201 -0
  89. package/src/usage/kimi.ts +271 -0
  90. package/src/usage/minimax-code.ts +31 -0
  91. package/src/usage/openai-codex.ts +503 -0
  92. package/src/usage/shared.ts +10 -0
  93. package/src/usage/zai.ts +247 -0
  94. package/src/usage.ts +185 -0
  95. package/src/utils/abort.ts +51 -0
  96. package/src/utils/abortable-iterator.ts +69 -0
  97. package/src/utils/anthropic-auth.ts +93 -0
  98. package/src/utils/discovery/antigravity.ts +261 -0
  99. package/src/utils/discovery/codex.ts +371 -0
  100. package/src/utils/discovery/cursor.ts +306 -0
  101. package/src/utils/discovery/gemini.ts +248 -0
  102. package/src/utils/discovery/index.ts +4 -0
  103. package/src/utils/discovery/openai-compatible.ts +224 -0
  104. package/src/utils/event-stream.ts +142 -0
  105. package/src/utils/fireworks-model-id.ts +30 -0
  106. package/src/utils/foundry.ts +8 -0
  107. package/src/utils/http-inspector.ts +176 -0
  108. package/src/utils/idle-iterator.ts +267 -0
  109. package/src/utils/json-parse.ts +182 -0
  110. package/src/utils/oauth/__tests__/xai-oauth.test.ts +107 -0
  111. package/src/utils/oauth/alibaba-coding-plan.ts +59 -0
  112. package/src/utils/oauth/anthropic.ts +273 -0
  113. package/src/utils/oauth/api-key-login.ts +87 -0
  114. package/src/utils/oauth/api-key-validation.ts +92 -0
  115. package/src/utils/oauth/callback-server.ts +276 -0
  116. package/src/utils/oauth/cerebras.ts +16 -0
  117. package/src/utils/oauth/cloudflare-ai-gateway.ts +48 -0
  118. package/src/utils/oauth/cursor.ts +157 -0
  119. package/src/utils/oauth/deepseek.ts +53 -0
  120. package/src/utils/oauth/firepass.ts +24 -0
  121. package/src/utils/oauth/fireworks.ts +15 -0
  122. package/src/utils/oauth/github-copilot.ts +362 -0
  123. package/src/utils/oauth/gitlab-duo.ts +123 -0
  124. package/src/utils/oauth/google-antigravity.ts +200 -0
  125. package/src/utils/oauth/google-gemini-cli.ts +256 -0
  126. package/src/utils/oauth/google-oauth-shared.ts +110 -0
  127. package/src/utils/oauth/huggingface.ts +62 -0
  128. package/src/utils/oauth/index.ts +484 -0
  129. package/src/utils/oauth/kagi.ts +47 -0
  130. package/src/utils/oauth/kilo.ts +87 -0
  131. package/src/utils/oauth/kimi.ts +254 -0
  132. package/src/utils/oauth/litellm.ts +47 -0
  133. package/src/utils/oauth/lm-studio.ts +38 -0
  134. package/src/utils/oauth/minimax-code.ts +78 -0
  135. package/src/utils/oauth/moonshot.ts +23 -0
  136. package/src/utils/oauth/nanogpt.ts +15 -0
  137. package/src/utils/oauth/nvidia.ts +70 -0
  138. package/src/utils/oauth/oauth.html +203 -0
  139. package/src/utils/oauth/ollama-cloud.ts +28 -0
  140. package/src/utils/oauth/ollama.ts +47 -0
  141. package/src/utils/oauth/openai-codex.ts +299 -0
  142. package/src/utils/oauth/opencode.ts +49 -0
  143. package/src/utils/oauth/openrouter.ts +20 -0
  144. package/src/utils/oauth/parallel.ts +46 -0
  145. package/src/utils/oauth/perplexity.ts +206 -0
  146. package/src/utils/oauth/pkce.ts +18 -0
  147. package/src/utils/oauth/qianfan.ts +58 -0
  148. package/src/utils/oauth/qwen-portal.ts +60 -0
  149. package/src/utils/oauth/synthetic.ts +15 -0
  150. package/src/utils/oauth/tavily.ts +46 -0
  151. package/src/utils/oauth/together.ts +16 -0
  152. package/src/utils/oauth/types.ts +99 -0
  153. package/src/utils/oauth/venice.ts +59 -0
  154. package/src/utils/oauth/vercel-ai-gateway.ts +47 -0
  155. package/src/utils/oauth/vllm.ts +40 -0
  156. package/src/utils/oauth/wafer.ts +50 -0
  157. package/src/utils/oauth/xai-oauth.ts +342 -0
  158. package/src/utils/oauth/xiaomi.ts +139 -0
  159. package/src/utils/oauth/zai.ts +60 -0
  160. package/src/utils/oauth/zenmux.ts +15 -0
  161. package/src/utils/oauth/zhipu.ts +60 -0
  162. package/src/utils/overflow.ts +137 -0
  163. package/src/utils/parse-bind.ts +54 -0
  164. package/src/utils/provider-response.ts +30 -0
  165. package/src/utils/request-debug.ts +336 -0
  166. package/src/utils/retry-after.ts +110 -0
  167. package/src/utils/retry.ts +54 -0
  168. package/src/utils/schema/CONSTRAINTS.md +164 -0
  169. package/src/utils/schema/adapt.ts +36 -0
  170. package/src/utils/schema/compatibility.ts +435 -0
  171. package/src/utils/schema/dereference.ts +98 -0
  172. package/src/utils/schema/draft.ts +341 -0
  173. package/src/utils/schema/equality.ts +97 -0
  174. package/src/utils/schema/fields.ts +191 -0
  175. package/src/utils/schema/index.ts +13 -0
  176. package/src/utils/schema/json-schema-validator.ts +577 -0
  177. package/src/utils/schema/meta-validator.ts +167 -0
  178. package/src/utils/schema/normalize.ts +1588 -0
  179. package/src/utils/schema/spill.ts +43 -0
  180. package/src/utils/schema/stamps.ts +97 -0
  181. package/src/utils/schema/types.ts +10 -0
  182. package/src/utils/schema/wire.ts +293 -0
  183. package/src/utils/schema/zod-decontaminate.ts +331 -0
  184. package/src/utils/sdk-stream-timeout.ts +43 -0
  185. package/src/utils/sse-debug.ts +289 -0
  186. package/src/utils/stream-markup-healing.ts +612 -0
  187. package/src/utils/tool-choice.ts +99 -0
  188. package/src/utils/validation.ts +1024 -0
  189. package/src/utils.ts +166 -0
  190. package/dist/api-registry.d.ts +0 -20
  191. package/dist/api-registry.d.ts.map +0 -1
  192. package/dist/api-registry.js +0 -44
  193. package/dist/api-registry.js.map +0 -1
  194. package/dist/bedrock-provider.d.ts +0 -5
  195. package/dist/bedrock-provider.d.ts.map +0 -1
  196. package/dist/bedrock-provider.js +0 -6
  197. package/dist/bedrock-provider.js.map +0 -1
  198. package/dist/cli.d.ts +0 -3
  199. package/dist/cli.d.ts.map +0 -1
  200. package/dist/cli.js +0 -130
  201. package/dist/cli.js.map +0 -1
  202. package/dist/env-api-keys.d.ts +0 -18
  203. package/dist/env-api-keys.d.ts.map +0 -1
  204. package/dist/env-api-keys.js +0 -178
  205. package/dist/env-api-keys.js.map +0 -1
  206. package/dist/image-models.d.ts +0 -10
  207. package/dist/image-models.d.ts.map +0 -1
  208. package/dist/image-models.generated.d.ts +0 -440
  209. package/dist/image-models.generated.d.ts.map +0 -1
  210. package/dist/image-models.generated.js +0 -442
  211. package/dist/image-models.generated.js.map +0 -1
  212. package/dist/image-models.js +0 -23
  213. package/dist/image-models.js.map +0 -1
  214. package/dist/images-api-registry.d.ts +0 -14
  215. package/dist/images-api-registry.d.ts.map +0 -1
  216. package/dist/images-api-registry.js +0 -22
  217. package/dist/images-api-registry.js.map +0 -1
  218. package/dist/images.d.ts +0 -4
  219. package/dist/images.d.ts.map +0 -1
  220. package/dist/images.js +0 -14
  221. package/dist/images.js.map +0 -1
  222. package/dist/index.d.ts +0 -32
  223. package/dist/index.d.ts.map +0 -1
  224. package/dist/index.js +0 -20
  225. package/dist/index.js.map +0 -1
  226. package/dist/models.d.ts +0 -18
  227. package/dist/models.d.ts.map +0 -1
  228. package/dist/models.generated.d.ts +0 -17707
  229. package/dist/models.generated.d.ts.map +0 -1
  230. package/dist/models.generated.js +0 -16561
  231. package/dist/models.generated.js.map +0 -1
  232. package/dist/models.js +0 -71
  233. package/dist/models.js.map +0 -1
  234. package/dist/oauth.d.ts +0 -2
  235. package/dist/oauth.d.ts.map +0 -1
  236. package/dist/oauth.js +0 -2
  237. package/dist/oauth.js.map +0 -1
  238. package/dist/providers/aery-error-formatting.d.ts +0 -13
  239. package/dist/providers/aery-error-formatting.d.ts.map +0 -1
  240. package/dist/providers/aery-error-formatting.js +0 -112
  241. package/dist/providers/aery-error-formatting.js.map +0 -1
  242. package/dist/providers/amazon-bedrock.d.ts +0 -38
  243. package/dist/providers/amazon-bedrock.d.ts.map +0 -1
  244. package/dist/providers/amazon-bedrock.js +0 -763
  245. package/dist/providers/amazon-bedrock.js.map +0 -1
  246. package/dist/providers/anthropic.d.ts +0 -71
  247. package/dist/providers/anthropic.d.ts.map +0 -1
  248. package/dist/providers/anthropic.js +0 -949
  249. package/dist/providers/anthropic.js.map +0 -1
  250. package/dist/providers/azure-openai-responses.d.ts +0 -15
  251. package/dist/providers/azure-openai-responses.d.ts.map +0 -1
  252. package/dist/providers/azure-openai-responses.js +0 -225
  253. package/dist/providers/azure-openai-responses.js.map +0 -1
  254. package/dist/providers/cloudflare.d.ts +0 -13
  255. package/dist/providers/cloudflare.d.ts.map +0 -1
  256. package/dist/providers/cloudflare.js +0 -26
  257. package/dist/providers/cloudflare.js.map +0 -1
  258. package/dist/providers/faux.d.ts +0 -56
  259. package/dist/providers/faux.d.ts.map +0 -1
  260. package/dist/providers/faux.js +0 -368
  261. package/dist/providers/faux.js.map +0 -1
  262. package/dist/providers/github-copilot-headers.d.ts +0 -8
  263. package/dist/providers/github-copilot-headers.d.ts.map +0 -1
  264. package/dist/providers/github-copilot-headers.js +0 -29
  265. package/dist/providers/github-copilot-headers.js.map +0 -1
  266. package/dist/providers/google-gemini-cli.d.ts +0 -74
  267. package/dist/providers/google-gemini-cli.d.ts.map +0 -1
  268. package/dist/providers/google-gemini-cli.js +0 -779
  269. package/dist/providers/google-gemini-cli.js.map +0 -1
  270. package/dist/providers/google-shared.d.ts +0 -70
  271. package/dist/providers/google-shared.d.ts.map +0 -1
  272. package/dist/providers/google-shared.js +0 -329
  273. package/dist/providers/google-shared.js.map +0 -1
  274. package/dist/providers/google-vertex.d.ts +0 -15
  275. package/dist/providers/google-vertex.d.ts.map +0 -1
  276. package/dist/providers/google-vertex.js +0 -442
  277. package/dist/providers/google-vertex.js.map +0 -1
  278. package/dist/providers/google.d.ts +0 -13
  279. package/dist/providers/google.d.ts.map +0 -1
  280. package/dist/providers/google.js +0 -400
  281. package/dist/providers/google.js.map +0 -1
  282. package/dist/providers/images/openrouter.d.ts +0 -3
  283. package/dist/providers/images/openrouter.d.ts.map +0 -1
  284. package/dist/providers/images/openrouter.js +0 -129
  285. package/dist/providers/images/openrouter.js.map +0 -1
  286. package/dist/providers/images/register-builtins.d.ts +0 -4
  287. package/dist/providers/images/register-builtins.d.ts.map +0 -1
  288. package/dist/providers/images/register-builtins.js +0 -34
  289. package/dist/providers/images/register-builtins.js.map +0 -1
  290. package/dist/providers/mistral.d.ts +0 -25
  291. package/dist/providers/mistral.d.ts.map +0 -1
  292. package/dist/providers/mistral.js +0 -535
  293. package/dist/providers/mistral.js.map +0 -1
  294. package/dist/providers/openai-codex-responses.d.ts +0 -30
  295. package/dist/providers/openai-codex-responses.d.ts.map +0 -1
  296. package/dist/providers/openai-codex-responses.js +0 -1090
  297. package/dist/providers/openai-codex-responses.js.map +0 -1
  298. package/dist/providers/openai-completions.d.ts +0 -19
  299. package/dist/providers/openai-completions.d.ts.map +0 -1
  300. package/dist/providers/openai-completions.js +0 -950
  301. package/dist/providers/openai-completions.js.map +0 -1
  302. package/dist/providers/openai-prompt-cache.d.ts +0 -3
  303. package/dist/providers/openai-prompt-cache.d.ts.map +0 -1
  304. package/dist/providers/openai-prompt-cache.js +0 -10
  305. package/dist/providers/openai-prompt-cache.js.map +0 -1
  306. package/dist/providers/openai-responses-shared.d.ts +0 -18
  307. package/dist/providers/openai-responses-shared.d.ts.map +0 -1
  308. package/dist/providers/openai-responses-shared.js +0 -492
  309. package/dist/providers/openai-responses-shared.js.map +0 -1
  310. package/dist/providers/openai-responses.d.ts +0 -13
  311. package/dist/providers/openai-responses.d.ts.map +0 -1
  312. package/dist/providers/openai-responses.js +0 -237
  313. package/dist/providers/openai-responses.js.map +0 -1
  314. package/dist/providers/register-builtins.d.ts +0 -38
  315. package/dist/providers/register-builtins.d.ts.map +0 -1
  316. package/dist/providers/register-builtins.js +0 -278
  317. package/dist/providers/register-builtins.js.map +0 -1
  318. package/dist/providers/simple-options.d.ts +0 -8
  319. package/dist/providers/simple-options.d.ts.map +0 -1
  320. package/dist/providers/simple-options.js +0 -41
  321. package/dist/providers/simple-options.js.map +0 -1
  322. package/dist/providers/transform-messages.d.ts +0 -8
  323. package/dist/providers/transform-messages.d.ts.map +0 -1
  324. package/dist/providers/transform-messages.js +0 -184
  325. package/dist/providers/transform-messages.js.map +0 -1
  326. package/dist/session-resources.d.ts +0 -4
  327. package/dist/session-resources.d.ts.map +0 -1
  328. package/dist/session-resources.js +0 -22
  329. package/dist/session-resources.js.map +0 -1
  330. package/dist/stream.d.ts +0 -8
  331. package/dist/stream.d.ts.map +0 -1
  332. package/dist/stream.js +0 -27
  333. package/dist/stream.js.map +0 -1
  334. package/dist/types.d.ts +0 -498
  335. package/dist/types.d.ts.map +0 -1
  336. package/dist/types.js +0 -2
  337. package/dist/types.js.map +0 -1
  338. package/dist/utils/diagnostics.d.ts +0 -19
  339. package/dist/utils/diagnostics.d.ts.map +0 -1
  340. package/dist/utils/diagnostics.js +0 -25
  341. package/dist/utils/diagnostics.js.map +0 -1
  342. package/dist/utils/event-stream.d.ts +0 -21
  343. package/dist/utils/event-stream.d.ts.map +0 -1
  344. package/dist/utils/event-stream.js +0 -81
  345. package/dist/utils/event-stream.js.map +0 -1
  346. package/dist/utils/hash.d.ts +0 -3
  347. package/dist/utils/hash.d.ts.map +0 -1
  348. package/dist/utils/hash.js +0 -14
  349. package/dist/utils/hash.js.map +0 -1
  350. package/dist/utils/headers.d.ts +0 -2
  351. package/dist/utils/headers.d.ts.map +0 -1
  352. package/dist/utils/headers.js +0 -8
  353. package/dist/utils/headers.js.map +0 -1
  354. package/dist/utils/json-parse.d.ts +0 -16
  355. package/dist/utils/json-parse.d.ts.map +0 -1
  356. package/dist/utils/json-parse.js +0 -113
  357. package/dist/utils/json-parse.js.map +0 -1
  358. package/dist/utils/node-http-proxy.d.ts +0 -10
  359. package/dist/utils/node-http-proxy.d.ts.map +0 -1
  360. package/dist/utils/node-http-proxy.js +0 -97
  361. package/dist/utils/node-http-proxy.js.map +0 -1
  362. package/dist/utils/oauth/anthropic.d.ts +0 -25
  363. package/dist/utils/oauth/anthropic.d.ts.map +0 -1
  364. package/dist/utils/oauth/anthropic.js +0 -335
  365. package/dist/utils/oauth/anthropic.js.map +0 -1
  366. package/dist/utils/oauth/device-code.d.ts +0 -19
  367. package/dist/utils/oauth/device-code.d.ts.map +0 -1
  368. package/dist/utils/oauth/device-code.js +0 -55
  369. package/dist/utils/oauth/device-code.js.map +0 -1
  370. package/dist/utils/oauth/github-copilot.d.ts +0 -30
  371. package/dist/utils/oauth/github-copilot.d.ts.map +0 -1
  372. package/dist/utils/oauth/github-copilot.js +0 -268
  373. package/dist/utils/oauth/github-copilot.js.map +0 -1
  374. package/dist/utils/oauth/google-antigravity.d.ts +0 -26
  375. package/dist/utils/oauth/google-antigravity.d.ts.map +0 -1
  376. package/dist/utils/oauth/google-antigravity.js +0 -377
  377. package/dist/utils/oauth/google-antigravity.js.map +0 -1
  378. package/dist/utils/oauth/google-gemini-cli.d.ts +0 -26
  379. package/dist/utils/oauth/google-gemini-cli.d.ts.map +0 -1
  380. package/dist/utils/oauth/google-gemini-cli.js +0 -482
  381. package/dist/utils/oauth/google-gemini-cli.js.map +0 -1
  382. package/dist/utils/oauth/index.d.ts +0 -63
  383. package/dist/utils/oauth/index.d.ts.map +0 -1
  384. package/dist/utils/oauth/index.js +0 -131
  385. package/dist/utils/oauth/index.js.map +0 -1
  386. package/dist/utils/oauth/oauth-page.d.ts +0 -3
  387. package/dist/utils/oauth/oauth-page.d.ts.map +0 -1
  388. package/dist/utils/oauth/oauth-page.js +0 -105
  389. package/dist/utils/oauth/oauth-page.js.map +0 -1
  390. package/dist/utils/oauth/openai-codex.d.ts +0 -34
  391. package/dist/utils/oauth/openai-codex.d.ts.map +0 -1
  392. package/dist/utils/oauth/openai-codex.js +0 -385
  393. package/dist/utils/oauth/openai-codex.js.map +0 -1
  394. package/dist/utils/oauth/pkce.d.ts +0 -13
  395. package/dist/utils/oauth/pkce.d.ts.map +0 -1
  396. package/dist/utils/oauth/pkce.js +0 -31
  397. package/dist/utils/oauth/pkce.js.map +0 -1
  398. package/dist/utils/oauth/types.d.ts +0 -64
  399. package/dist/utils/oauth/types.d.ts.map +0 -1
  400. package/dist/utils/oauth/types.js +0 -2
  401. package/dist/utils/oauth/types.js.map +0 -1
  402. package/dist/utils/overflow.d.ts +0 -56
  403. package/dist/utils/overflow.d.ts.map +0 -1
  404. package/dist/utils/overflow.js +0 -151
  405. package/dist/utils/overflow.js.map +0 -1
  406. package/dist/utils/sanitize-unicode.d.ts +0 -22
  407. package/dist/utils/sanitize-unicode.d.ts.map +0 -1
  408. package/dist/utils/sanitize-unicode.js +0 -26
  409. package/dist/utils/sanitize-unicode.js.map +0 -1
  410. package/dist/utils/typebox-helpers.d.ts +0 -17
  411. package/dist/utils/typebox-helpers.d.ts.map +0 -1
  412. package/dist/utils/typebox-helpers.js +0 -21
  413. package/dist/utils/typebox-helpers.js.map +0 -1
  414. package/dist/utils/validation.d.ts +0 -18
  415. package/dist/utils/validation.d.ts.map +0 -1
  416. package/dist/utils/validation.js +0 -281
  417. package/dist/utils/validation.js.map +0 -1
@@ -0,0 +1,218 @@
1
+ /**
2
+ * AWS Signature V4 signing for HTTP requests. WebCrypto-only — no node:crypto.
3
+ *
4
+ * Matches `@smithy/signature-v4` for our usage: header-based signing with a
5
+ * full SHA-256 payload hash (Bedrock requires `applyChecksum: true`).
6
+ *
7
+ * Returns the set of headers to attach to the request:
8
+ * - `host`
9
+ * - `x-amz-date`
10
+ * - `x-amz-content-sha256`
11
+ * - `x-amz-security-token` (only when credentials carry a sessionToken)
12
+ * - `authorization`
13
+ */
14
+
15
+ export interface AwsCredentials {
16
+ accessKeyId: string;
17
+ secretAccessKey: string;
18
+ sessionToken?: string;
19
+ }
20
+
21
+ export interface SignParams {
22
+ method: string;
23
+ /** Hostname only — used to build the `host` header and the canonical request. */
24
+ host: string;
25
+ /** URI path component, e.g. `/model/anthropic.claude/converse-stream`. */
26
+ path: string;
27
+ /** Optional pre-built query string (without leading `?`). */
28
+ query?: string;
29
+ /** Extra headers to sign in addition to `host`/`x-amz-*`. Names are case-insensitive. */
30
+ headers?: Record<string, string>;
31
+ body: Uint8Array;
32
+ region: string;
33
+ service: string;
34
+ credentials: AwsCredentials;
35
+ /** Override clock for deterministic tests. */
36
+ date?: Date;
37
+ }
38
+
39
+ const ALGORITHM = "AWS4-HMAC-SHA256";
40
+ const KEY_TYPE = "aws4_request";
41
+ // Headers the SDK never includes in the signature. Lowercased.
42
+ const UNSIGNABLE: Record<string, true> = {
43
+ authorization: true,
44
+ "cache-control": true,
45
+ connection: true,
46
+ expect: true,
47
+ from: true,
48
+ "keep-alive": true,
49
+ "max-forwards": true,
50
+ pragma: true,
51
+ referer: true,
52
+ te: true,
53
+ trailer: true,
54
+ "transfer-encoding": true,
55
+ upgrade: true,
56
+ "user-agent": true,
57
+ "x-amzn-trace-id": true,
58
+ };
59
+
60
+ /** Coerce a possibly-ArrayBufferLike-backed `Uint8Array` into one over a fresh
61
+ * `ArrayBuffer`, which is what `crypto.subtle.{digest,sign,importKey}` requires
62
+ * under the strict TS DOM typings. No-op when already strict.
63
+ */
64
+ function asStrict(bytes: Uint8Array): Uint8Array<ArrayBuffer> {
65
+ if (bytes.buffer instanceof ArrayBuffer && bytes.byteOffset === 0 && bytes.byteLength === bytes.buffer.byteLength) {
66
+ return bytes as Uint8Array<ArrayBuffer>;
67
+ }
68
+ const copy = new Uint8Array(bytes.byteLength);
69
+ copy.set(bytes);
70
+ return copy;
71
+ }
72
+ const subtle = globalThis.crypto.subtle;
73
+
74
+ const HEX = "0123456789abcdef";
75
+ export function toHex(bytes: Uint8Array): string {
76
+ let out = "";
77
+ for (let i = 0; i < bytes.length; i++) {
78
+ const b = bytes[i];
79
+ out += HEX[b >> 4] + HEX[b & 15];
80
+ }
81
+ return out;
82
+ }
83
+
84
+ export async function sha256(data: Uint8Array | string): Promise<Uint8Array> {
85
+ const bytes = typeof data === "string" ? new TextEncoder().encode(data) : asStrict(data);
86
+ const digest = await subtle.digest("SHA-256", bytes);
87
+ return new Uint8Array(digest);
88
+ }
89
+
90
+ export async function sha256Hex(data: Uint8Array | string): Promise<string> {
91
+ return toHex(await sha256(data));
92
+ }
93
+
94
+ async function hmac(key: Uint8Array, data: string | Uint8Array): Promise<Uint8Array> {
95
+ const cryptoKey = await subtle.importKey("raw", asStrict(key), { name: "HMAC", hash: "SHA-256" }, false, ["sign"]);
96
+ const bytes = typeof data === "string" ? new TextEncoder().encode(data) : asStrict(data);
97
+ const sig = await subtle.sign("HMAC", cryptoKey, bytes);
98
+ return new Uint8Array(sig);
99
+ }
100
+
101
+ /**
102
+ * Derive a signing key: HMAC chain `kSecret → kDate → kRegion → kService → kSigning`.
103
+ */
104
+ export async function getSigningKey(
105
+ secretAccessKey: string,
106
+ shortDate: string,
107
+ region: string,
108
+ service: string,
109
+ ): Promise<Uint8Array> {
110
+ const kDate = await hmac(new TextEncoder().encode(`AWS4${secretAccessKey}`), shortDate);
111
+ const kRegion = await hmac(kDate, region);
112
+ const kService = await hmac(kRegion, service);
113
+ return hmac(kService, KEY_TYPE);
114
+ }
115
+
116
+ /** `YYYYMMDDTHHMMSSZ` + 8-char `YYYYMMDD`. */
117
+ export function formatAmzDate(d: Date): { longDate: string; shortDate: string } {
118
+ const iso = d.toISOString();
119
+ // `2025-05-17T12:34:56.789Z` -> `20250517T123456Z`
120
+ const longDate = `${iso.slice(0, 4)}${iso.slice(5, 7)}${iso.slice(8, 10)}T${iso.slice(11, 13)}${iso.slice(14, 16)}${iso.slice(17, 19)}Z`;
121
+ return { longDate, shortDate: longDate.slice(0, 8) };
122
+ }
123
+
124
+ /**
125
+ * Canonicalize a request path per RFC 3986: each segment is %-encoded but `/`
126
+ * stays literal. Matches the smithy default (`uriEscapePath: true`, then revert
127
+ * the double-encoding of `/`). Bedrock paths use no reserved characters in
128
+ * practice, but model IDs can include `:` and `.`.
129
+ */
130
+ function canonicalPath(path: string): string {
131
+ const segments = path.split("/");
132
+ const escaped = segments.map(seg => (seg.length === 0 ? "" : encodeRfc3986(seg)));
133
+ return escaped.join("/");
134
+ }
135
+
136
+ function encodeRfc3986(str: string): string {
137
+ return encodeURIComponent(str).replace(/[!'()*]/g, c => `%${c.charCodeAt(0).toString(16).toUpperCase()}`);
138
+ }
139
+
140
+ function canonicalQuery(query: string | undefined): string {
141
+ if (!query) return "";
142
+ const pairs: Array<[string, string]> = [];
143
+ for (const part of query.split("&")) {
144
+ if (!part) continue;
145
+ const eq = part.indexOf("=");
146
+ const k = eq === -1 ? part : part.slice(0, eq);
147
+ const v = eq === -1 ? "" : part.slice(eq + 1);
148
+ pairs.push([decodeURIComponent(k), decodeURIComponent(v)]);
149
+ }
150
+ pairs.sort((a, b) => (a[0] < b[0] ? -1 : a[0] > b[0] ? 1 : a[1] < b[1] ? -1 : a[1] > b[1] ? 1 : 0));
151
+ return pairs.map(([k, v]) => `${encodeRfc3986(k)}=${encodeRfc3986(v)}`).join("&");
152
+ }
153
+
154
+ export interface SignedHeaders {
155
+ host: string;
156
+ "x-amz-date": string;
157
+ "x-amz-content-sha256": string;
158
+ authorization: string;
159
+ "x-amz-security-token"?: string;
160
+ }
161
+
162
+ export async function signRequest(params: SignParams): Promise<SignedHeaders> {
163
+ const { method, host, path, query, body, region, service, credentials } = params;
164
+ const date = params.date ?? new Date();
165
+ const { longDate, shortDate } = formatAmzDate(date);
166
+ const payloadHash = await sha256Hex(body);
167
+
168
+ // Assemble the headers that will be signed. Always include host, x-amz-date,
169
+ // x-amz-content-sha256, plus x-amz-security-token when present, plus
170
+ // caller-provided signable headers (e.g. content-type, accept).
171
+ const signed: Record<string, string> = {
172
+ host,
173
+ "x-amz-date": longDate,
174
+ "x-amz-content-sha256": payloadHash,
175
+ };
176
+ if (credentials.sessionToken) signed["x-amz-security-token"] = credentials.sessionToken;
177
+ const extraHeaders = params.headers;
178
+ if (extraHeaders) {
179
+ for (const k in extraHeaders) {
180
+ const lk = k.toLowerCase();
181
+ if (UNSIGNABLE[lk]) continue;
182
+ if (lk.startsWith("proxy-") || lk.startsWith("sec-")) continue;
183
+ signed[lk] = extraHeaders[k].trim().replace(/\s+/g, " ");
184
+ }
185
+ }
186
+
187
+ const sortedNames = Object.keys(signed).sort();
188
+ const canonicalHeaders = `${sortedNames.map(n => `${n}:${signed[n]}`).join("\n")}\n`;
189
+ const signedHeadersStr = sortedNames.join(";");
190
+
191
+ const canonicalRequest = [
192
+ method.toUpperCase(),
193
+ canonicalPath(path),
194
+ canonicalQuery(query),
195
+ canonicalHeaders,
196
+ signedHeadersStr,
197
+ payloadHash,
198
+ ].join("\n");
199
+
200
+ const scope = `${shortDate}/${region}/${service}/${KEY_TYPE}`;
201
+ const stringToSign = [ALGORITHM, longDate, scope, await sha256Hex(canonicalRequest)].join("\n");
202
+
203
+ const signingKey = await getSigningKey(credentials.secretAccessKey, shortDate, region, service);
204
+ const signature = toHex(await hmac(signingKey, stringToSign));
205
+
206
+ const authorization =
207
+ `${ALGORITHM} Credential=${credentials.accessKeyId}/${scope}, ` +
208
+ `SignedHeaders=${signedHeadersStr}, Signature=${signature}`;
209
+
210
+ const out: SignedHeaders = {
211
+ host,
212
+ "x-amz-date": longDate,
213
+ "x-amz-content-sha256": payloadHash,
214
+ authorization,
215
+ };
216
+ if (credentials.sessionToken) out["x-amz-security-token"] = credentials.sessionToken;
217
+ return out;
218
+ }
@@ -0,0 +1,361 @@
1
+ import { $env, extractHttpStatusFromError } from "@aryee337/aery-utils";
2
+ import { AzureOpenAI, APIConnectionTimeoutError as OpenAIConnectionTimeoutError } from "openai";
3
+ import type {
4
+ Tool as OpenAITool,
5
+ ResponseCreateParamsStreaming,
6
+ ResponseInput,
7
+ ResponseStreamEvent,
8
+ } from "openai/resources/responses/responses";
9
+ import { getEnvApiKey } from "../stream";
10
+ import type {
11
+ AssistantMessage,
12
+ Context,
13
+ Model,
14
+ ServiceTier,
15
+ StreamFunction,
16
+ StreamOptions,
17
+ Tool,
18
+ ToolChoice,
19
+ } from "../types";
20
+ import { normalizeSystemPrompts } from "../utils";
21
+ import { createAbortSourceTracker } from "../utils/abort";
22
+ import { AssistantMessageEventStream } from "../utils/event-stream";
23
+ import { finalizeErrorMessage, type RawHttpRequestDump } from "../utils/http-inspector";
24
+ import {
25
+ getOpenAIStreamFirstEventTimeoutMs,
26
+ getOpenAIStreamIdleTimeoutMs,
27
+ iterateWithIdleTimeout,
28
+ } from "../utils/idle-iterator";
29
+ import { sanitizeSchemaForOpenAIResponses, toolWireSchema } from "../utils/schema";
30
+ import { wrapFetchForSseDebug } from "../utils/sse-debug";
31
+ import { mapToOpenAIResponsesToolChoice } from "../utils/tool-choice";
32
+ import { normalizeOpenAIResponsesPromptCacheKey, supportsDeveloperRole } from "./openai-responses";
33
+ import {
34
+ appendResponsesToolResultMessages,
35
+ applyCommonResponsesSamplingParams,
36
+ applyResponsesReasoningParams,
37
+ convertResponsesAssistantMessage,
38
+ convertResponsesInputContent,
39
+ createInitialResponsesAssistantMessage,
40
+ isOpenAIResponsesProgressEvent,
41
+ normalizeResponsesToolCallIdForTransform,
42
+ processResponsesStream,
43
+ } from "./openai-responses-shared";
44
+ import { transformMessages } from "./transform-messages";
45
+
46
+ const DEFAULT_AZURE_API_VERSION = "v1";
47
+ const AZURE_OPENAI_RESPONSES_FIRST_EVENT_TIMEOUT_MESSAGE =
48
+ "Azure OpenAI responses stream timed out while waiting for the first event";
49
+
50
+ function parseDeploymentNameMap(value: string | undefined): Map<string, string> {
51
+ const map = new Map<string, string>();
52
+ if (!value) return map;
53
+ for (const entry of value.split(",")) {
54
+ const trimmed = entry.trim();
55
+ if (!trimmed) continue;
56
+ const [modelId, deploymentName] = trimmed.split("=", 2);
57
+ if (!modelId || !deploymentName) continue;
58
+ map.set(modelId.trim(), deploymentName.trim());
59
+ }
60
+ return map;
61
+ }
62
+
63
+ function resolveDeploymentName(model: Model<"azure-openai-responses">, options?: AzureOpenAIResponsesOptions): string {
64
+ if (options?.azureDeploymentName) {
65
+ return options.azureDeploymentName;
66
+ }
67
+ const mappedDeployment = parseDeploymentNameMap($env.AZURE_OPENAI_DEPLOYMENT_NAME_MAP).get(model.id);
68
+ return mappedDeployment ?? model.id;
69
+ }
70
+
71
+ // Azure OpenAI Responses-specific options
72
+ export interface AzureOpenAIResponsesOptions extends StreamOptions {
73
+ reasoning?: "minimal" | "low" | "medium" | "high" | "xhigh";
74
+ reasoningSummary?: "auto" | "detailed" | "concise" | null;
75
+ azureApiVersion?: string;
76
+ azureResourceName?: string;
77
+ azureBaseUrl?: string;
78
+ azureDeploymentName?: string;
79
+ toolChoice?: ToolChoice;
80
+ serviceTier?: ServiceTier;
81
+ }
82
+
83
+ type AzureOpenAIResponsesSamplingParams = ResponseCreateParamsStreaming & {
84
+ top_p?: number;
85
+ top_k?: number;
86
+ min_p?: number;
87
+ presence_penalty?: number;
88
+ repetition_penalty?: number;
89
+ };
90
+
91
+ /**
92
+ * Generate function for Azure OpenAI Responses API
93
+ */
94
+ export const streamAzureOpenAIResponses: StreamFunction<"azure-openai-responses"> = (
95
+ model: Model<"azure-openai-responses">,
96
+ context: Context,
97
+ options?: AzureOpenAIResponsesOptions,
98
+ ): AssistantMessageEventStream => {
99
+ const stream = new AssistantMessageEventStream();
100
+
101
+ // Start async processing
102
+ (async () => {
103
+ const startTime = Date.now();
104
+ let firstTokenTime: number | undefined;
105
+ const deploymentName = resolveDeploymentName(model, options);
106
+
107
+ const output: AssistantMessage = createInitialResponsesAssistantMessage(
108
+ "azure-openai-responses",
109
+ model.provider,
110
+ model.id,
111
+ );
112
+ let rawRequestDump: RawHttpRequestDump | undefined;
113
+ const abortTracker = createAbortSourceTracker(options?.signal);
114
+ const firstEventTimeoutAbortError = new Error(AZURE_OPENAI_RESPONSES_FIRST_EVENT_TIMEOUT_MESSAGE);
115
+ const { requestAbortController, requestSignal } = abortTracker;
116
+
117
+ try {
118
+ // Create Azure OpenAI client
119
+ const apiKey = options?.apiKey || getEnvApiKey(model.provider) || "";
120
+ const client = createClient(model, apiKey, options);
121
+ const { baseUrl } = resolveAzureConfig(model, options);
122
+ const params = buildParams(model, context, options, deploymentName, baseUrl);
123
+ options?.onPayload?.(params);
124
+ const idleTimeoutMs = options?.streamIdleTimeoutMs ?? getOpenAIStreamIdleTimeoutMs();
125
+ const firstEventTimeoutMs =
126
+ options?.streamFirstEventTimeoutMs ?? getOpenAIStreamFirstEventTimeoutMs(idleTimeoutMs);
127
+ const requestTimeoutMs =
128
+ firstEventTimeoutMs !== undefined && firstEventTimeoutMs > 0 ? firstEventTimeoutMs : undefined;
129
+ rawRequestDump = {
130
+ provider: model.provider,
131
+ api: output.api,
132
+ model: model.id,
133
+ method: "POST",
134
+ url: `${baseUrl}/responses`,
135
+ body: params,
136
+ };
137
+ let requestTimeout: NodeJS.Timeout | undefined;
138
+ if (requestTimeoutMs !== undefined) {
139
+ requestTimeout = setTimeout(() => abortTracker.abortLocally(firstEventTimeoutAbortError), requestTimeoutMs);
140
+ }
141
+ let openaiStream: AsyncIterable<ResponseStreamEvent>;
142
+ try {
143
+ const requestOptions =
144
+ requestTimeoutMs === undefined
145
+ ? { signal: requestSignal }
146
+ : { signal: requestSignal, timeout: requestTimeoutMs };
147
+ openaiStream = await client.responses.create(params, requestOptions);
148
+ } catch (error) {
149
+ if (error instanceof OpenAIConnectionTimeoutError && !abortTracker.wasCallerAbort()) {
150
+ throw firstEventTimeoutAbortError;
151
+ }
152
+ throw error;
153
+ } finally {
154
+ if (requestTimeout !== undefined) clearTimeout(requestTimeout);
155
+ }
156
+ stream.push({ type: "start", partial: output });
157
+
158
+ await processResponsesStream(
159
+ iterateWithIdleTimeout(openaiStream, {
160
+ idleTimeoutMs,
161
+ firstItemTimeoutMs: firstEventTimeoutMs,
162
+ firstItemErrorMessage: AZURE_OPENAI_RESPONSES_FIRST_EVENT_TIMEOUT_MESSAGE,
163
+ errorMessage: "Azure OpenAI responses stream stalled while waiting for the next event",
164
+ onIdle: () => requestAbortController.abort(),
165
+ onFirstItemTimeout: () => abortTracker.abortLocally(firstEventTimeoutAbortError),
166
+ abortSignal: options?.signal,
167
+ isProgressItem: isOpenAIResponsesProgressEvent,
168
+ }),
169
+ output,
170
+ stream,
171
+ model,
172
+ {
173
+ onFirstToken: () => {
174
+ if (!firstTokenTime) firstTokenTime = Date.now();
175
+ },
176
+ },
177
+ );
178
+
179
+ const firstEventTimeoutError = abortTracker.getLocalAbortReason();
180
+ if (firstEventTimeoutError) {
181
+ throw firstEventTimeoutError;
182
+ }
183
+
184
+ if (abortTracker.wasCallerAbort()) {
185
+ throw new Error("Request was aborted");
186
+ }
187
+
188
+ if (output.stopReason === "aborted" || output.stopReason === "error") {
189
+ throw new Error(output.errorMessage ?? "An unknown error occurred");
190
+ }
191
+
192
+ output.duration = Date.now() - startTime;
193
+ if (firstTokenTime) output.ttft = firstTokenTime - startTime;
194
+ stream.push({ type: "done", reason: output.stopReason, message: output });
195
+ stream.end();
196
+ } catch (error) {
197
+ for (const block of output.content) delete (block as { index?: number }).index;
198
+ const firstEventTimeoutError = abortTracker.getLocalAbortReason();
199
+ output.stopReason = abortTracker.wasCallerAbort() ? "aborted" : "error";
200
+ output.errorStatus = extractHttpStatusFromError(error);
201
+ output.errorMessage = firstEventTimeoutError?.message ?? (await finalizeErrorMessage(error, rawRequestDump));
202
+ output.duration = Date.now() - startTime;
203
+ if (firstTokenTime) output.ttft = firstTokenTime - startTime;
204
+ stream.push({ type: "error", reason: output.stopReason, error: output });
205
+ stream.end();
206
+ }
207
+ })();
208
+
209
+ return stream;
210
+ };
211
+
212
+ function normalizeAzureBaseUrl(baseUrl: string): string {
213
+ return baseUrl.replace(/\/+$/, "");
214
+ }
215
+
216
+ function buildDefaultBaseUrl(resourceName: string): string {
217
+ return `https://${resourceName}.openai.azure.com/openai/v1`;
218
+ }
219
+
220
+ function resolveAzureConfig(
221
+ model: Model<"azure-openai-responses">,
222
+ options?: AzureOpenAIResponsesOptions,
223
+ ): { baseUrl: string; apiVersion: string } {
224
+ const apiVersion = options?.azureApiVersion || $env.AZURE_OPENAI_API_VERSION || DEFAULT_AZURE_API_VERSION;
225
+
226
+ const baseUrl = options?.azureBaseUrl?.trim() || $env.AZURE_OPENAI_BASE_URL?.trim() || undefined;
227
+ const resourceName = options?.azureResourceName || $env.AZURE_OPENAI_RESOURCE_NAME;
228
+
229
+ let resolvedBaseUrl = baseUrl;
230
+
231
+ if (!resolvedBaseUrl && resourceName) {
232
+ resolvedBaseUrl = buildDefaultBaseUrl(resourceName);
233
+ }
234
+
235
+ if (!resolvedBaseUrl && model.baseUrl) {
236
+ resolvedBaseUrl = model.baseUrl;
237
+ }
238
+
239
+ if (!resolvedBaseUrl) {
240
+ throw new Error(
241
+ "Azure OpenAI base URL is required. Set AZURE_OPENAI_BASE_URL or AZURE_OPENAI_RESOURCE_NAME, or pass azureBaseUrl, azureResourceName, or model.baseUrl.",
242
+ );
243
+ }
244
+
245
+ return {
246
+ baseUrl: normalizeAzureBaseUrl(resolvedBaseUrl),
247
+ apiVersion,
248
+ };
249
+ }
250
+
251
+ function createClient(model: Model<"azure-openai-responses">, apiKey: string, options?: AzureOpenAIResponsesOptions) {
252
+ if (!apiKey) {
253
+ const envKey = $env.AZURE_OPENAI_API_KEY;
254
+ if (!envKey) {
255
+ throw new Error(
256
+ "Azure OpenAI API key is required. Set AZURE_OPENAI_API_KEY environment variable or pass it as an argument.",
257
+ );
258
+ }
259
+ apiKey = envKey;
260
+ }
261
+
262
+ const headers = { ...(model.headers ?? {}) };
263
+
264
+ if (options?.headers) {
265
+ Object.assign(headers, options.headers);
266
+ }
267
+
268
+ const { baseUrl, apiVersion } = resolveAzureConfig(model, options);
269
+
270
+ const baseFetch = options?.fetch ?? fetch;
271
+ const onSseEvent = options?.onSseEvent;
272
+ return new AzureOpenAI({
273
+ apiKey,
274
+ apiVersion,
275
+ dangerouslyAllowBrowser: true,
276
+ maxRetries: 5,
277
+ defaultHeaders: headers,
278
+ baseURL: baseUrl,
279
+ fetch: onSseEvent ? wrapFetchForSseDebug(baseFetch, event => onSseEvent(event, model)) : baseFetch,
280
+ });
281
+ }
282
+
283
+ function buildParams(
284
+ model: Model<"azure-openai-responses">,
285
+ context: Context,
286
+ options: AzureOpenAIResponsesOptions | undefined,
287
+ deploymentName: string,
288
+ resolvedBaseUrl?: string,
289
+ ) {
290
+ const messages = convertMessages(model, context, true, resolvedBaseUrl);
291
+
292
+ const params: AzureOpenAIResponsesSamplingParams = {
293
+ model: deploymentName,
294
+ input: messages,
295
+ stream: true,
296
+ prompt_cache_key: normalizeOpenAIResponsesPromptCacheKey(options?.promptCacheKey ?? options?.sessionId),
297
+ };
298
+
299
+ applyCommonResponsesSamplingParams(params, options, model.provider);
300
+
301
+ if (context.tools) {
302
+ params.tools = convertTools(context.tools);
303
+ if (options?.toolChoice) {
304
+ params.tool_choice = mapToOpenAIResponsesToolChoice(options.toolChoice);
305
+ }
306
+ }
307
+
308
+ applyResponsesReasoningParams(params, model, options, messages);
309
+
310
+ return params;
311
+ }
312
+
313
+ function convertMessages(
314
+ model: Model<"azure-openai-responses">,
315
+ context: Context,
316
+ strictResponsesPairing: boolean,
317
+ resolvedBaseUrl?: string,
318
+ ): ResponseInput {
319
+ const messages: ResponseInput = [];
320
+ const transformedMessages = transformMessages(context.messages, model, normalizeResponsesToolCallIdForTransform);
321
+ const knownCallIds = new Set<string>();
322
+
323
+ const systemPrompts = normalizeSystemPrompts(context.systemPrompt);
324
+ if (systemPrompts.length > 0) {
325
+ const role = model.reasoning && supportsDeveloperRole(resolvedBaseUrl ?? model) ? "developer" : "system";
326
+ for (const systemPrompt of systemPrompts) {
327
+ messages.push({ role, content: systemPrompt });
328
+ }
329
+ }
330
+
331
+ let msgIndex = 0;
332
+ for (const msg of transformedMessages) {
333
+ if (msg.role === "user" || msg.role === "developer") {
334
+ const content = convertResponsesInputContent(msg.content, model.input.includes("image"));
335
+ if (!content) continue;
336
+ messages.push({
337
+ role: "user",
338
+ content: msg.role === "developer" && typeof msg.content === "string" ? msg.content.toWellFormed() : content,
339
+ });
340
+ } else if (msg.role === "assistant") {
341
+ const outputItems = convertResponsesAssistantMessage(msg as AssistantMessage, model, msgIndex, knownCallIds);
342
+ if (outputItems.length === 0) continue;
343
+ messages.push(...outputItems);
344
+ } else if (msg.role === "toolResult") {
345
+ appendResponsesToolResultMessages(messages, msg, model, strictResponsesPairing, knownCallIds);
346
+ }
347
+ msgIndex++;
348
+ }
349
+
350
+ return messages;
351
+ }
352
+
353
+ function convertTools(tools: Tool[]): OpenAITool[] {
354
+ return tools.map(tool => ({
355
+ type: "function",
356
+ name: tool.name,
357
+ description: tool.description || "",
358
+ parameters: sanitizeSchemaForOpenAIResponses(toolWireSchema(tool)),
359
+ strict: false,
360
+ }));
361
+ }