@aryee337/aery-ai 0.2.27 → 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,67 @@
1
+ import { once } from "@aryee337/aery-utils";
2
+ import type { ModelManagerOptions } from "../model-manager";
3
+ import { fetchCodexModels } from "../utils/discovery/codex";
4
+
5
+ // ---------------------------------------------------------------------------
6
+ // OpenAI Codex
7
+ // ---------------------------------------------------------------------------
8
+
9
+ export interface OpenAICodexModelManagerConfig {
10
+ accessToken?: string;
11
+ accountId?: string;
12
+ clientVersion?: string;
13
+ }
14
+
15
+ export function openaiCodexModelManagerOptions(
16
+ config: OpenAICodexModelManagerConfig = {},
17
+ ): ModelManagerOptions<"openai-codex-responses"> {
18
+ const { accessToken, accountId, clientVersion } = config;
19
+ return {
20
+ providerId: "openai-codex",
21
+ ...(accessToken
22
+ ? {
23
+ fetchDynamicModels: async () => {
24
+ const result = await fetchCodexModels({ accessToken, accountId, clientVersion });
25
+ return result?.models ?? null;
26
+ },
27
+ }
28
+ : undefined),
29
+ };
30
+ }
31
+
32
+ // ---------------------------------------------------------------------------
33
+ // Cursor
34
+ // ---------------------------------------------------------------------------
35
+
36
+ export interface CursorModelManagerConfig {
37
+ apiKey?: string;
38
+ baseUrl?: string;
39
+ clientVersion?: string;
40
+ }
41
+
42
+ export function cursorModelManagerOptions(config: CursorModelManagerConfig = {}): ModelManagerOptions<"cursor-agent"> {
43
+ const { apiKey, baseUrl, clientVersion } = config;
44
+ return {
45
+ providerId: "cursor",
46
+ ...(apiKey
47
+ ? {
48
+ fetchDynamicModels: async () => {
49
+ const { fetchCursorUsableModels } = await cursorDiscovery();
50
+ return fetchCursorUsableModels({ apiKey, baseUrl, clientVersion });
51
+ },
52
+ }
53
+ : undefined),
54
+ };
55
+ }
56
+
57
+ const cursorDiscovery = once(() => import("../utils/discovery/cursor"));
58
+
59
+ // ---------------------------------------------------------------------------
60
+ // Zai
61
+ // ---------------------------------------------------------------------------
62
+
63
+ export interface ZaiModelManagerConfig {}
64
+
65
+ export function zaiModelManagerOptions(_config: ZaiModelManagerConfig = {}): ModelManagerOptions<"anthropic-messages"> {
66
+ return { providerId: "zai" };
67
+ }
@@ -0,0 +1,228 @@
1
+ /**
2
+ * Client half of the aery-native auth-gateway protocol.
3
+ *
4
+ * Dispatches a {@link streamSimple}-shaped request to an `aery auth-gateway`
5
+ * via `POST /v1/aery/stream`, reads the SSE event stream back, and pushes the
6
+ * parsed events into a local {@link AssistantMessageEventStream} — the same
7
+ * stream type every other provider client produces. Callers downstream of
8
+ * `streamSimple` cannot tell whether the events came from a real provider
9
+ * SDK or from a gateway hop; they consume `AssistantMessageEvent`s either
10
+ * way.
11
+ *
12
+ * Activated when a {@link Model} has `transport: "aery-native"` set; the
13
+ * dispatch hook lives in `streamSimple()` (see `../stream.ts`). Used by
14
+ * containerized aery deployments (robaery slots, the swarm extension) that
15
+ * route every LLM call through a credential-holding sidecar so the slot
16
+ * itself stays credential-free.
17
+ */
18
+ import { readSseJson } from "@aryee337/aery-utils";
19
+ import type {
20
+ Api,
21
+ AssistantMessage,
22
+ AssistantMessageEvent,
23
+ AssistantMessageEventStream as AssistantMessageEventStreamType,
24
+ Context,
25
+ Model,
26
+ SimpleStreamOptions,
27
+ } from "../types";
28
+ import { AssistantMessageEventStream } from "../utils/event-stream";
29
+
30
+ /**
31
+ * Fields that must not cross the wire — either non-serializable (functions,
32
+ * `AbortSignal`, the provider-session `Map`) or server-controlled
33
+ * (`apiKey`, which the gateway injects from its own credential store; the
34
+ * client's `apiKey` is the gateway *bearer*, sent in the `Authorization`
35
+ * header rather than the request body).
36
+ */
37
+ const NON_WIRE_KEYS = new Set<keyof SimpleStreamOptions>([
38
+ "signal",
39
+ "apiKey",
40
+ "fetch",
41
+ "onPayload",
42
+ "onResponse",
43
+ "onSseEvent",
44
+ "execHandlers",
45
+ "cursorExecHandlers",
46
+ "cursorOnToolResult",
47
+ "providerSessionState",
48
+ ]);
49
+
50
+ function buildWireOptions(options: SimpleStreamOptions | undefined): Record<string, unknown> {
51
+ if (!options) return {};
52
+ const wire: Record<string, unknown> = {};
53
+ for (const [k, v] of Object.entries(options)) {
54
+ if (v === undefined) continue;
55
+ if (NON_WIRE_KEYS.has(k as keyof SimpleStreamOptions)) continue;
56
+ wire[k] = v;
57
+ }
58
+ return wire;
59
+ }
60
+
61
+ async function decodeGatewayError(response: Response): Promise<Error> {
62
+ const status = response.status;
63
+ let body: unknown;
64
+ try {
65
+ body = await response.json();
66
+ } catch {
67
+ body = await response.text().catch(() => "");
68
+ }
69
+ if (typeof body === "object" && body !== null && "error" in body) {
70
+ const err = (body as { error: unknown }).error;
71
+ if (typeof err === "object" && err !== null) {
72
+ const message = (err as { message?: unknown }).message;
73
+ const type = (err as { type?: unknown }).type;
74
+ const out = new Error(typeof message === "string" ? message : `auth-gateway ${status}`);
75
+ (out as { status?: number; type?: string }).status = status;
76
+ if (typeof type === "string") (out as { type?: string }).type = type;
77
+ return out;
78
+ }
79
+ }
80
+ const text = typeof body === "string" ? body : JSON.stringify(body);
81
+ const err = new Error(`auth-gateway ${status}: ${text || response.statusText}`);
82
+ (err as { status?: number }).status = status;
83
+ return err;
84
+ }
85
+
86
+ /**
87
+ * Resolve the `/v1/aery/stream` endpoint URL from the model's `baseUrl`.
88
+ * Trims a trailing slash so concatenation can't double-slash; throws when
89
+ * the baseUrl is missing (transport=aery-native without a gateway target is
90
+ * a configuration error, not a runtime recoverable one).
91
+ */
92
+ function resolveStreamUrl(model: Model<Api>): string {
93
+ if (!model.baseUrl) {
94
+ throw new Error(
95
+ `aery-native transport requires \`baseUrl\` on model ${model.id} (set it on the provider config in models.yml)`,
96
+ );
97
+ }
98
+ return `${model.baseUrl.replace(/\/+$/, "")}/v1/aery/stream`;
99
+ }
100
+
101
+ function buildHeaders(model: Model<Api>, apiKey: string | undefined): Record<string, string> {
102
+ const headers: Record<string, string> = {
103
+ "Content-Type": "application/json",
104
+ Accept: "text/event-stream",
105
+ ...(model.headers ?? {}),
106
+ };
107
+ if (apiKey && !headers.Authorization) {
108
+ headers.Authorization = `Bearer ${apiKey}`;
109
+ }
110
+ return headers;
111
+ }
112
+
113
+ /**
114
+ * Stream a turn through an `aery auth-gateway over the aery-native protocol.
115
+ *
116
+ * The returned {@link AssistantMessageEventStream} receives each parsed
117
+ * `AssistantMessageEvent` verbatim from the gateway; the terminal `done` /
118
+ * `error` event resolves `.result()` automatically via the base class's
119
+ * completion check. Non-streaming consumers just call `.result()` and pay
120
+ * for SSE framing they don't use — that overhead is dominated by provider
121
+ * latency, so we always stream rather than maintaining a parallel
122
+ * non-streaming path.
123
+ */
124
+ export function streamAeryNative<TApi extends Api>(
125
+ model: Model<TApi>,
126
+ context: Context,
127
+ options?: SimpleStreamOptions,
128
+ ): AssistantMessageEventStreamType {
129
+ const stream = new AssistantMessageEventStream();
130
+
131
+ void (async () => {
132
+ const signal = options?.signal;
133
+ // Abort propagation: cancel the response body when the caller's signal
134
+ // fires. Mirror `streamProxy`'s shape — explicit listener + finally
135
+ // cleanup — so we don't leak listeners on the long-running case.
136
+ let response: Response | null = null;
137
+ const onAbort = (): void => {
138
+ const body = response?.body;
139
+ if (body) body.cancel("Request aborted by caller").catch(() => {});
140
+ };
141
+ if (signal) {
142
+ if (signal.aborted) {
143
+ stream.fail(signal.reason instanceof Error ? signal.reason : new Error(String(signal.reason ?? "aborted")));
144
+ return;
145
+ }
146
+ signal.addEventListener("abort", onAbort, { once: true });
147
+ }
148
+
149
+ try {
150
+ const url = resolveStreamUrl(model as Model<Api>);
151
+ const fetchImpl = options?.fetch ?? globalThis.fetch;
152
+ const headers = buildHeaders(model as Model<Api>, options?.apiKey);
153
+ const body = JSON.stringify({
154
+ modelId: model.id,
155
+ context,
156
+ options: buildWireOptions(options),
157
+ stream: true,
158
+ });
159
+
160
+ response = await fetchImpl(url, { method: "POST", headers, body, signal });
161
+ if (!response.ok) {
162
+ stream.fail(await decodeGatewayError(response));
163
+ return;
164
+ }
165
+ if (!response.body) {
166
+ stream.fail(new Error("auth-gateway returned empty body"));
167
+ return;
168
+ }
169
+
170
+ let sawTerminal = false;
171
+ for await (const event of readSseJson<AssistantMessageEvent>(
172
+ response.body as ReadableStream<Uint8Array>,
173
+ signal,
174
+ )) {
175
+ if (event.type === "done" || event.type === "error") sawTerminal = true;
176
+ stream.push(event);
177
+ // `stream.push` resolves `.result()` on `done`/`error`; subsequent
178
+ // pushes are silently dropped by the base class. We still iterate
179
+ // to drain any trailing bytes from the wire so the underlying TCP
180
+ // stream closes cleanly.
181
+ }
182
+
183
+ if (!sawTerminal) {
184
+ // SSE closed before a terminal event reached us — synthesize one
185
+ // so awaiters of `.result()` resolve instead of hanging forever.
186
+ // Matches the gateway's own defensive fallback in
187
+ // `aery-native-server.encodeStream`.
188
+ const aborted = signal?.aborted === true;
189
+ const partial = makeSyntheticAssistant(model as Model<Api>);
190
+ if (aborted) {
191
+ partial.stopReason = "aborted";
192
+ partial.errorMessage = "stream closed without terminal event";
193
+ stream.push({ type: "error", reason: "aborted", error: partial });
194
+ } else {
195
+ partial.stopReason = "stop";
196
+ stream.push({ type: "done", reason: "stop", message: partial });
197
+ }
198
+ }
199
+ stream.end();
200
+ } catch (err) {
201
+ stream.fail(err);
202
+ } finally {
203
+ if (signal) signal.removeEventListener("abort", onAbort);
204
+ }
205
+ })();
206
+
207
+ return stream;
208
+ }
209
+
210
+ function makeSyntheticAssistant(model: Model<Api>): AssistantMessage {
211
+ return {
212
+ role: "assistant",
213
+ content: [],
214
+ api: model.api,
215
+ provider: model.provider,
216
+ model: model.id,
217
+ usage: {
218
+ input: 0,
219
+ output: 0,
220
+ cacheRead: 0,
221
+ cacheWrite: 0,
222
+ totalTokens: 0,
223
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
224
+ },
225
+ stopReason: "stop",
226
+ timestamp: Date.now(),
227
+ };
228
+ }
@@ -0,0 +1,212 @@
1
+ /**
2
+ * Aery-native wire format for the auth-gateway.
3
+ *
4
+ * Where the OpenAI / Anthropic / Responses route modules translate foreign
5
+ * wire shapes through aery-ai's canonical {@link Context}, this module accepts
6
+ * the canonical shape *directly* — for clients that already speak aery-ai
7
+ * (containerized aery, the swarm extension, robaery's sidecar auth-gateway).
8
+ * Skipping the wire-format → Context → wire-format round-trip cuts
9
+ * per-request CPU but, more importantly, avoids the quantization that those
10
+ * translations impose on first-class aery-ai fields (service tier, cache
11
+ * markers, thinking budgets, tool-choice variants, …).
12
+ *
13
+ * The streaming wire is {@link AssistantMessageEvent} serialized verbatim and
14
+ * SSE-framed. Same type aery-ai already produces internally; the client feeds
15
+ * each parsed event straight into `AssistantMessageEventStream.push()` with
16
+ * no translation. Including `partial: AssistantMessage` on every delta is
17
+ * O(N²) in turn length on the wire — acceptable for the loopback / sidecar
18
+ * topology this transport is designed for; provider latency dominates the
19
+ * actual cost.
20
+ *
21
+ * Endpoint contract:
22
+ * POST /v1/aery/stream
23
+ * body: { modelId, context, options?, stream? } // `stream` defaults to true
24
+ * 200 SSE: stream of `AssistantMessageEvent` (terminated by `data: [DONE]`)
25
+ * 200 JSON (stream=false): { message: AssistantMessage }
26
+ * 4xx/5xx: { error: { type, message } }
27
+ */
28
+ import type { AssistantMessageEventStream, Context, SimpleStreamOptions } from "../types";
29
+
30
+ export interface AeryNativeParsedRequest {
31
+ modelId: string;
32
+ context: Context;
33
+ options: SimpleStreamOptions;
34
+ stream: boolean;
35
+ }
36
+ /**
37
+ * Subset of {@link SimpleStreamOptions} accepted from the wire. Function-valued
38
+ * fields (`fetch`, `onPayload`, `onResponse`, `onSseEvent`, exec handlers, the
39
+ * provider-session map) and gateway-owned controls (`apiKey`, `signal`) are
40
+ * intentionally absent — those are server-side concerns. Anything outside this
41
+ * allow-list is dropped silently rather than 400ing, so clients can forward
42
+ * `SimpleStreamOptions` from older / newer aery builds without per-version
43
+ * conditionals.
44
+ */
45
+ const ALLOWED_OPTION_KEYS: ReadonlySet<keyof SimpleStreamOptions> = new Set([
46
+ "temperature",
47
+ "topP",
48
+ "topK",
49
+ "minP",
50
+ "presencePenalty",
51
+ "frequencyPenalty",
52
+ "repetitionPenalty",
53
+ "stopSequences",
54
+ "maxTokens",
55
+ "cacheRetention",
56
+ "headers",
57
+ "initiatorOverride",
58
+ "maxRetryDelayMs",
59
+ "metadata",
60
+ "sessionId",
61
+ "promptCacheKey",
62
+ "streamFirstEventTimeoutMs",
63
+ "streamIdleTimeoutMs",
64
+ "reasoning",
65
+ "disableReasoning",
66
+ "hideThinkingSummary",
67
+ "thinkingBudgets",
68
+ "toolChoice",
69
+ "serviceTier",
70
+ "kimiApiFormat",
71
+ "syntheticApiFormat",
72
+ "preferWebsockets",
73
+ "openrouterVariant",
74
+ ] as const satisfies readonly (keyof SimpleStreamOptions)[]);
75
+
76
+ // ---------------------------------------------------------------------------
77
+ // parseRequest
78
+ // ---------------------------------------------------------------------------
79
+
80
+ /**
81
+ * Parse an aery-native request body. Validation is intentionally minimal — only
82
+ * the shape the gateway itself reads is checked (`modelId`, `context.messages`
83
+ * array, options is an object). Everything downstream is the canonical aery-ai
84
+ * type surface; mis-shaped values surface as a `502 upstream_error` from
85
+ * `streamSimple` rather than being re-validated here.
86
+ *
87
+ * Accepts both `{ modelId: string }` and `{ model: { id: string } }` so the
88
+ * existing `streamProxy` client (which sends the full Model object) can target
89
+ * the gateway with only a URL swap.
90
+ */
91
+ export function parseRequest(body: unknown, _headers?: Headers): AeryNativeParsedRequest {
92
+ if (typeof body !== "object" || body === null || Array.isArray(body)) {
93
+ throw new Error("Request body must be a JSON object");
94
+ }
95
+ const obj = body as Record<string, unknown>;
96
+
97
+ let modelId: string | undefined;
98
+ if (typeof obj.modelId === "string" && obj.modelId.length > 0) {
99
+ modelId = obj.modelId;
100
+ } else if (typeof obj.model === "string" && obj.model.length > 0) {
101
+ modelId = obj.model;
102
+ } else if (typeof obj.model === "object" && obj.model !== null) {
103
+ const m = obj.model as Record<string, unknown>;
104
+ if (typeof m.id === "string" && m.id.length > 0) modelId = m.id;
105
+ }
106
+ if (!modelId) throw new Error("Missing `modelId` (or `model.id`) field");
107
+
108
+ const context = obj.context;
109
+ if (typeof context !== "object" || context === null || Array.isArray(context)) {
110
+ throw new Error("Missing `context` object");
111
+ }
112
+ const ctxObj = context as Record<string, unknown>;
113
+ if (!Array.isArray(ctxObj.messages)) {
114
+ throw new Error("`context.messages` must be an array");
115
+ }
116
+ if (ctxObj.systemPrompt !== undefined && !Array.isArray(ctxObj.systemPrompt)) {
117
+ throw new Error("`context.systemPrompt` must be an array of strings when present");
118
+ }
119
+ if (ctxObj.tools !== undefined && !Array.isArray(ctxObj.tools)) {
120
+ throw new Error("`context.tools` must be an array when present");
121
+ }
122
+
123
+ const options: SimpleStreamOptions = {};
124
+ const rawOpts = obj.options;
125
+ if (typeof rawOpts === "object" && rawOpts !== null && !Array.isArray(rawOpts)) {
126
+ const optsBag = options as Record<string, unknown>;
127
+ for (const [k, v] of Object.entries(rawOpts)) {
128
+ if (v === undefined || v === null) continue;
129
+ if (!ALLOWED_OPTION_KEYS.has(k as keyof SimpleStreamOptions)) continue;
130
+ optsBag[k] = v;
131
+ }
132
+ }
133
+
134
+ // `stream` defaults to true — aery-native clients overwhelmingly stream, and
135
+ // matching `streamProxy`'s implicit-stream behavior avoids a one-flag papercut.
136
+ const stream = typeof obj.stream === "boolean" ? obj.stream : true;
137
+
138
+ return {
139
+ modelId,
140
+ context: context as Context,
141
+ options,
142
+ stream,
143
+ };
144
+ }
145
+ // ---------------------------------------------------------------------------
146
+ // encodeStream (SSE)
147
+ // ---------------------------------------------------------------------------
148
+
149
+ const SSE_ENCODER = new TextEncoder();
150
+ const SSE_DONE = SSE_ENCODER.encode("data: [DONE]\n\n");
151
+
152
+ /**
153
+ * Ship every {@link AssistantMessageEvent} verbatim, SSE-framed.
154
+ *
155
+ * No per-event re-shaping: the aery-native client is aery-ai itself, so the
156
+ * canonical event type IS the wire type. Including the rolling
157
+ * `partial: AssistantMessage` on every delta is quadratic in turn length
158
+ * on the wire, but for the loopback / sidecar topology this transport
159
+ * targets (containerized aery → host gateway, robaery slot → aery-auth-gateway
160
+ * sidecar) the bandwidth cost is negligible compared to provider latency —
161
+ * and the client gets to feed the events straight into its existing
162
+ * `AssistantMessageEventStream.push()` plumbing with zero translation.
163
+ */
164
+ export function encodeStream(events: AssistantMessageEventStream): ReadableStream<Uint8Array> {
165
+ return new ReadableStream<Uint8Array>({
166
+ async start(controller) {
167
+ try {
168
+ for await (const event of events) {
169
+ controller.enqueue(SSE_ENCODER.encode(`data: ${JSON.stringify(event)}\n\n`));
170
+ if (event.type === "done" || event.type === "error") break;
171
+ }
172
+ controller.enqueue(SSE_DONE);
173
+ controller.close();
174
+ } catch (err) {
175
+ // Best-effort error envelope so the client iterator resolves
176
+ // instead of hanging on the dropped connection. Shape matches the
177
+ // canonical `error` event minus the unrecoverable `error:
178
+ // AssistantMessage` payload (we don't have a usable one here).
179
+ const message = err instanceof Error ? err.message : String(err);
180
+ controller.enqueue(
181
+ SSE_ENCODER.encode(
182
+ `data: ${JSON.stringify({ type: "error", reason: "error", errorMessage: message })}\n\n`,
183
+ ),
184
+ );
185
+ controller.enqueue(SSE_DONE);
186
+ controller.close();
187
+ }
188
+ },
189
+ });
190
+ }
191
+
192
+ // ---------------------------------------------------------------------------
193
+ // formatError
194
+ // ---------------------------------------------------------------------------
195
+
196
+ /**
197
+ * Aery-native error envelope:
198
+ * `{ error: { type, message } }`
199
+ *
200
+ * Mirrors OpenAI's outer shape (which clients/SDKs already parse) without the
201
+ * provider-specific status taxonomy — aery-native callers consume `type`
202
+ * directly.
203
+ */
204
+ export function formatError(status: number, type: string, message: string): Response {
205
+ return new Response(JSON.stringify({ error: { type, message } }), {
206
+ status,
207
+ headers: {
208
+ "Content-Type": "application/json; charset=utf-8",
209
+ "Cache-Control": "no-store",
210
+ },
211
+ });
212
+ }