@gajae-code/ai 0.1.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 (349) hide show
  1. package/CHANGELOG.md +2644 -0
  2. package/README.md +1181 -0
  3. package/dist/types/api-registry.d.ts +30 -0
  4. package/dist/types/auth-broker/client.d.ts +66 -0
  5. package/dist/types/auth-broker/index.d.ts +5 -0
  6. package/dist/types/auth-broker/refresher.d.ts +25 -0
  7. package/dist/types/auth-broker/remote-store.d.ts +96 -0
  8. package/dist/types/auth-broker/server.d.ts +32 -0
  9. package/dist/types/auth-broker/types.d.ts +105 -0
  10. package/dist/types/auth-broker/wire-schemas.d.ts +412 -0
  11. package/dist/types/auth-gateway/http.d.ts +39 -0
  12. package/dist/types/auth-gateway/index.d.ts +3 -0
  13. package/dist/types/auth-gateway/server.d.ts +17 -0
  14. package/dist/types/auth-gateway/types.d.ts +115 -0
  15. package/dist/types/auth-storage.d.ts +641 -0
  16. package/dist/types/cli.d.ts +2 -0
  17. package/dist/types/index.d.ts +49 -0
  18. package/dist/types/model-cache.d.ts +17 -0
  19. package/dist/types/model-manager.d.ts +62 -0
  20. package/dist/types/model-thinking.d.ts +71 -0
  21. package/dist/types/models.d.ts +12 -0
  22. package/dist/types/provider-details.d.ts +24 -0
  23. package/dist/types/provider-models/bundled-references.d.ts +4 -0
  24. package/dist/types/provider-models/descriptors.d.ts +48 -0
  25. package/dist/types/provider-models/google.d.ts +20 -0
  26. package/dist/types/provider-models/index.d.ts +5 -0
  27. package/dist/types/provider-models/ollama.d.ts +7 -0
  28. package/dist/types/provider-models/openai-compat.d.ts +237 -0
  29. package/dist/types/provider-models/special.d.ts +16 -0
  30. package/dist/types/providers/amazon-bedrock.d.ts +36 -0
  31. package/dist/types/providers/anthropic-messages-server-schema.d.ts +450 -0
  32. package/dist/types/providers/anthropic-messages-server.d.ts +17 -0
  33. package/dist/types/providers/anthropic.d.ts +188 -0
  34. package/dist/types/providers/aws-credentials.d.ts +43 -0
  35. package/dist/types/providers/aws-eventstream.d.ts +38 -0
  36. package/dist/types/providers/aws-sigv4.d.ts +55 -0
  37. package/dist/types/providers/azure-openai-responses.d.ts +15 -0
  38. package/dist/types/providers/cursor/gen/agent_pb.d.ts +13022 -0
  39. package/dist/types/providers/cursor.d.ts +42 -0
  40. package/dist/types/providers/error-message.d.ts +27 -0
  41. package/dist/types/providers/github-copilot-headers.d.ts +40 -0
  42. package/dist/types/providers/gitlab-duo.d.ts +27 -0
  43. package/dist/types/providers/google-auth.d.ts +24 -0
  44. package/dist/types/providers/google-gemini-cli.d.ts +72 -0
  45. package/dist/types/providers/google-gemini-headers.d.ts +18 -0
  46. package/dist/types/providers/google-shared.d.ts +163 -0
  47. package/dist/types/providers/google-types.d.ts +138 -0
  48. package/dist/types/providers/google-vertex.d.ts +7 -0
  49. package/dist/types/providers/google.d.ts +4 -0
  50. package/dist/types/providers/grammar.d.ts +1 -0
  51. package/dist/types/providers/kimi.d.ts +27 -0
  52. package/dist/types/providers/mock.d.ts +175 -0
  53. package/dist/types/providers/ollama.d.ts +6 -0
  54. package/dist/types/providers/openai-anthropic-shim.d.ts +31 -0
  55. package/dist/types/providers/openai-chat-server-schema.d.ts +814 -0
  56. package/dist/types/providers/openai-chat-server.d.ts +16 -0
  57. package/dist/types/providers/openai-codex/constants.d.ts +26 -0
  58. package/dist/types/providers/openai-codex/request-transformer.d.ts +49 -0
  59. package/dist/types/providers/openai-codex/response-handler.d.ts +17 -0
  60. package/dist/types/providers/openai-codex-responses.d.ts +67 -0
  61. package/dist/types/providers/openai-completions-compat.d.ts +25 -0
  62. package/dist/types/providers/openai-completions.d.ts +33 -0
  63. package/dist/types/providers/openai-responses-server-schema.d.ts +392 -0
  64. package/dist/types/providers/openai-responses-server.d.ts +17 -0
  65. package/dist/types/providers/openai-responses-shared.d.ts +89 -0
  66. package/dist/types/providers/openai-responses.d.ts +32 -0
  67. package/dist/types/providers/pi-native-client.d.ts +13 -0
  68. package/dist/types/providers/pi-native-server.d.ts +68 -0
  69. package/dist/types/providers/register-builtins.d.ts +31 -0
  70. package/dist/types/providers/synthetic.d.ts +26 -0
  71. package/dist/types/providers/transform-messages.d.ts +12 -0
  72. package/dist/types/providers/vision-guard.d.ts +8 -0
  73. package/dist/types/rate-limit-utils.d.ts +19 -0
  74. package/dist/types/stream.d.ts +24 -0
  75. package/dist/types/types.d.ts +746 -0
  76. package/dist/types/usage/claude.d.ts +3 -0
  77. package/dist/types/usage/gemini.d.ts +2 -0
  78. package/dist/types/usage/github-copilot.d.ts +7 -0
  79. package/dist/types/usage/google-antigravity.d.ts +2 -0
  80. package/dist/types/usage/kimi.d.ts +2 -0
  81. package/dist/types/usage/minimax-code.d.ts +2 -0
  82. package/dist/types/usage/openai-codex.d.ts +3 -0
  83. package/dist/types/usage/shared.d.ts +1 -0
  84. package/dist/types/usage/zai.d.ts +2 -0
  85. package/dist/types/usage.d.ts +258 -0
  86. package/dist/types/utils/abort.d.ts +19 -0
  87. package/dist/types/utils/anthropic-auth.d.ts +31 -0
  88. package/dist/types/utils/discovery/antigravity.d.ts +61 -0
  89. package/dist/types/utils/discovery/codex.d.ts +38 -0
  90. package/dist/types/utils/discovery/cursor.d.ts +23 -0
  91. package/dist/types/utils/discovery/gemini.d.ts +25 -0
  92. package/dist/types/utils/discovery/index.d.ts +4 -0
  93. package/dist/types/utils/discovery/openai-compatible.d.ts +72 -0
  94. package/dist/types/utils/event-stream.d.ts +28 -0
  95. package/dist/types/utils/fireworks-model-id.d.ts +10 -0
  96. package/dist/types/utils/foundry.d.ts +1 -0
  97. package/dist/types/utils/h2-fetch.d.ts +22 -0
  98. package/dist/types/utils/http-inspector.d.ts +31 -0
  99. package/dist/types/utils/idle-iterator.d.ts +67 -0
  100. package/dist/types/utils/json-parse.d.ts +10 -0
  101. package/dist/types/utils/oauth/alibaba-coding-plan.d.ts +18 -0
  102. package/dist/types/utils/oauth/anthropic.d.ts +22 -0
  103. package/dist/types/utils/oauth/api-key-login.d.ts +35 -0
  104. package/dist/types/utils/oauth/api-key-validation.d.ts +27 -0
  105. package/dist/types/utils/oauth/callback-server.d.ts +57 -0
  106. package/dist/types/utils/oauth/cerebras.d.ts +1 -0
  107. package/dist/types/utils/oauth/cloudflare-ai-gateway.d.ts +18 -0
  108. package/dist/types/utils/oauth/cursor.d.ts +15 -0
  109. package/dist/types/utils/oauth/deepseek.d.ts +10 -0
  110. package/dist/types/utils/oauth/firepass.d.ts +1 -0
  111. package/dist/types/utils/oauth/fireworks.d.ts +1 -0
  112. package/dist/types/utils/oauth/github-copilot.d.ts +38 -0
  113. package/dist/types/utils/oauth/gitlab-duo.d.ts +3 -0
  114. package/dist/types/utils/oauth/google-antigravity.d.ts +11 -0
  115. package/dist/types/utils/oauth/google-gemini-cli.d.ts +10 -0
  116. package/dist/types/utils/oauth/google-oauth-shared.d.ts +28 -0
  117. package/dist/types/utils/oauth/huggingface.d.ts +19 -0
  118. package/dist/types/utils/oauth/index.d.ts +38 -0
  119. package/dist/types/utils/oauth/kagi.d.ts +17 -0
  120. package/dist/types/utils/oauth/kilo.d.ts +5 -0
  121. package/dist/types/utils/oauth/kimi.d.ts +21 -0
  122. package/dist/types/utils/oauth/litellm.d.ts +18 -0
  123. package/dist/types/utils/oauth/lm-studio.d.ts +17 -0
  124. package/dist/types/utils/oauth/minimax-code.d.ts +28 -0
  125. package/dist/types/utils/oauth/moonshot.d.ts +1 -0
  126. package/dist/types/utils/oauth/nanogpt.d.ts +1 -0
  127. package/dist/types/utils/oauth/nvidia.d.ts +18 -0
  128. package/dist/types/utils/oauth/ollama-cloud.d.ts +2 -0
  129. package/dist/types/utils/oauth/ollama.d.ts +18 -0
  130. package/dist/types/utils/oauth/openai-codex.d.ts +21 -0
  131. package/dist/types/utils/oauth/opencode.d.ts +18 -0
  132. package/dist/types/utils/oauth/parallel.d.ts +17 -0
  133. package/dist/types/utils/oauth/perplexity.d.ts +9 -0
  134. package/dist/types/utils/oauth/pkce.d.ts +8 -0
  135. package/dist/types/utils/oauth/qianfan.d.ts +17 -0
  136. package/dist/types/utils/oauth/qwen-portal.d.ts +19 -0
  137. package/dist/types/utils/oauth/synthetic.d.ts +1 -0
  138. package/dist/types/utils/oauth/tavily.d.ts +17 -0
  139. package/dist/types/utils/oauth/together.d.ts +1 -0
  140. package/dist/types/utils/oauth/types.d.ts +44 -0
  141. package/dist/types/utils/oauth/venice.d.ts +18 -0
  142. package/dist/types/utils/oauth/vercel-ai-gateway.d.ts +18 -0
  143. package/dist/types/utils/oauth/vllm.d.ts +16 -0
  144. package/dist/types/utils/oauth/xiaomi.d.ts +19 -0
  145. package/dist/types/utils/oauth/zai.d.ts +18 -0
  146. package/dist/types/utils/oauth/zenmux.d.ts +1 -0
  147. package/dist/types/utils/overflow.d.ts +54 -0
  148. package/dist/types/utils/parse-bind.d.ts +23 -0
  149. package/dist/types/utils/provider-response.d.ts +3 -0
  150. package/dist/types/utils/retry-after.d.ts +3 -0
  151. package/dist/types/utils/retry.d.ts +26 -0
  152. package/dist/types/utils/schema/adapt.d.ts +24 -0
  153. package/dist/types/utils/schema/compatibility.d.ts +30 -0
  154. package/dist/types/utils/schema/dereference.d.ts +11 -0
  155. package/dist/types/utils/schema/draft.d.ts +10 -0
  156. package/dist/types/utils/schema/equality.d.ts +4 -0
  157. package/dist/types/utils/schema/fields.d.ts +49 -0
  158. package/dist/types/utils/schema/index.d.ts +13 -0
  159. package/dist/types/utils/schema/json-schema-validator.d.ts +12 -0
  160. package/dist/types/utils/schema/meta-validator.d.ts +2 -0
  161. package/dist/types/utils/schema/normalize.d.ts +93 -0
  162. package/dist/types/utils/schema/spill.d.ts +8 -0
  163. package/dist/types/utils/schema/stamps.d.ts +25 -0
  164. package/dist/types/utils/schema/types.d.ts +4 -0
  165. package/dist/types/utils/schema/wire.d.ts +54 -0
  166. package/dist/types/utils/schema/zod-decontaminate.d.ts +31 -0
  167. package/dist/types/utils/sse-debug.d.ts +10 -0
  168. package/dist/types/utils/tool-call-healing.d.ts +71 -0
  169. package/dist/types/utils/tool-choice.d.ts +50 -0
  170. package/dist/types/utils/validation.d.ts +17 -0
  171. package/dist/types/utils.d.ts +28 -0
  172. package/package.json +146 -0
  173. package/src/api-registry.ts +96 -0
  174. package/src/auth-broker/client.ts +358 -0
  175. package/src/auth-broker/index.ts +5 -0
  176. package/src/auth-broker/refresher.ts +127 -0
  177. package/src/auth-broker/remote-store.ts +623 -0
  178. package/src/auth-broker/server.ts +644 -0
  179. package/src/auth-broker/types.ts +127 -0
  180. package/src/auth-broker/wire-schemas.ts +200 -0
  181. package/src/auth-gateway/http.ts +194 -0
  182. package/src/auth-gateway/index.ts +3 -0
  183. package/src/auth-gateway/server.ts +717 -0
  184. package/src/auth-gateway/types.ts +134 -0
  185. package/src/auth-storage.ts +4104 -0
  186. package/src/cli.ts +262 -0
  187. package/src/index.ts +54 -0
  188. package/src/model-cache.ts +129 -0
  189. package/src/model-manager.ts +450 -0
  190. package/src/model-thinking.ts +691 -0
  191. package/src/models.json +73853 -0
  192. package/src/models.json.d.ts +9 -0
  193. package/src/models.ts +56 -0
  194. package/src/prompts/turn-aborted-guidance.md +4 -0
  195. package/src/provider-details.ts +90 -0
  196. package/src/provider-models/bundled-references.ts +38 -0
  197. package/src/provider-models/descriptors.ts +308 -0
  198. package/src/provider-models/google.ts +91 -0
  199. package/src/provider-models/index.ts +5 -0
  200. package/src/provider-models/ollama.ts +153 -0
  201. package/src/provider-models/openai-compat.ts +2275 -0
  202. package/src/provider-models/special.ts +67 -0
  203. package/src/providers/amazon-bedrock.ts +849 -0
  204. package/src/providers/anthropic-messages-server-schema.ts +229 -0
  205. package/src/providers/anthropic-messages-server.ts +677 -0
  206. package/src/providers/anthropic.ts +2696 -0
  207. package/src/providers/aws-credentials.ts +501 -0
  208. package/src/providers/aws-eventstream.ts +185 -0
  209. package/src/providers/aws-sigv4.ts +218 -0
  210. package/src/providers/azure-openai-responses.ts +337 -0
  211. package/src/providers/cursor/gen/agent_pb.ts +15274 -0
  212. package/src/providers/cursor/proto/agent.proto +3526 -0
  213. package/src/providers/cursor/proto/buf.gen.yaml +6 -0
  214. package/src/providers/cursor/proto/buf.yaml +17 -0
  215. package/src/providers/cursor.ts +2561 -0
  216. package/src/providers/error-message.ts +21 -0
  217. package/src/providers/github-copilot-headers.ts +140 -0
  218. package/src/providers/gitlab-duo.ts +372 -0
  219. package/src/providers/google-auth.ts +252 -0
  220. package/src/providers/google-gemini-cli.ts +795 -0
  221. package/src/providers/google-gemini-headers.ts +41 -0
  222. package/src/providers/google-shared.ts +902 -0
  223. package/src/providers/google-types.ts +167 -0
  224. package/src/providers/google-vertex.ts +88 -0
  225. package/src/providers/google.ts +41 -0
  226. package/src/providers/grammar.ts +70 -0
  227. package/src/providers/kimi.ts +52 -0
  228. package/src/providers/mock.ts +500 -0
  229. package/src/providers/ollama.ts +544 -0
  230. package/src/providers/openai-anthropic-shim.ts +138 -0
  231. package/src/providers/openai-chat-server-schema.ts +243 -0
  232. package/src/providers/openai-chat-server.ts +628 -0
  233. package/src/providers/openai-codex/constants.ts +43 -0
  234. package/src/providers/openai-codex/request-transformer.ts +161 -0
  235. package/src/providers/openai-codex/response-handler.ts +81 -0
  236. package/src/providers/openai-codex-responses.ts +2598 -0
  237. package/src/providers/openai-completions-compat.ts +279 -0
  238. package/src/providers/openai-completions.ts +1853 -0
  239. package/src/providers/openai-responses-server-schema.ts +290 -0
  240. package/src/providers/openai-responses-server.ts +1183 -0
  241. package/src/providers/openai-responses-shared.ts +800 -0
  242. package/src/providers/openai-responses.ts +621 -0
  243. package/src/providers/pi-native-client.ts +228 -0
  244. package/src/providers/pi-native-server.ts +210 -0
  245. package/src/providers/register-builtins.ts +412 -0
  246. package/src/providers/synthetic.ts +50 -0
  247. package/src/providers/transform-messages.ts +309 -0
  248. package/src/providers/vision-guard.ts +31 -0
  249. package/src/rate-limit-utils.ts +84 -0
  250. package/src/stream.ts +895 -0
  251. package/src/types.ts +884 -0
  252. package/src/usage/claude.ts +431 -0
  253. package/src/usage/gemini.ts +250 -0
  254. package/src/usage/github-copilot.ts +421 -0
  255. package/src/usage/google-antigravity.ts +201 -0
  256. package/src/usage/kimi.ts +271 -0
  257. package/src/usage/minimax-code.ts +31 -0
  258. package/src/usage/openai-codex.ts +503 -0
  259. package/src/usage/shared.ts +10 -0
  260. package/src/usage/zai.ts +247 -0
  261. package/src/usage.ts +183 -0
  262. package/src/utils/abort.ts +51 -0
  263. package/src/utils/anthropic-auth.ts +87 -0
  264. package/src/utils/discovery/antigravity.ts +261 -0
  265. package/src/utils/discovery/codex.ts +371 -0
  266. package/src/utils/discovery/cursor.ts +306 -0
  267. package/src/utils/discovery/gemini.ts +248 -0
  268. package/src/utils/discovery/index.ts +4 -0
  269. package/src/utils/discovery/openai-compatible.ts +224 -0
  270. package/src/utils/event-stream.ts +142 -0
  271. package/src/utils/fireworks-model-id.ts +30 -0
  272. package/src/utils/foundry.ts +8 -0
  273. package/src/utils/h2-fetch.ts +60 -0
  274. package/src/utils/http-inspector.ts +176 -0
  275. package/src/utils/idle-iterator.ts +250 -0
  276. package/src/utils/json-parse.ts +148 -0
  277. package/src/utils/oauth/alibaba-coding-plan.ts +59 -0
  278. package/src/utils/oauth/anthropic.ts +200 -0
  279. package/src/utils/oauth/api-key-login.ts +87 -0
  280. package/src/utils/oauth/api-key-validation.ts +92 -0
  281. package/src/utils/oauth/callback-server.ts +276 -0
  282. package/src/utils/oauth/cerebras.ts +16 -0
  283. package/src/utils/oauth/cloudflare-ai-gateway.ts +48 -0
  284. package/src/utils/oauth/cursor.ts +157 -0
  285. package/src/utils/oauth/deepseek.ts +53 -0
  286. package/src/utils/oauth/firepass.ts +24 -0
  287. package/src/utils/oauth/fireworks.ts +15 -0
  288. package/src/utils/oauth/github-copilot.ts +362 -0
  289. package/src/utils/oauth/gitlab-duo.ts +123 -0
  290. package/src/utils/oauth/google-antigravity.ts +200 -0
  291. package/src/utils/oauth/google-gemini-cli.ts +256 -0
  292. package/src/utils/oauth/google-oauth-shared.ts +110 -0
  293. package/src/utils/oauth/huggingface.ts +62 -0
  294. package/src/utils/oauth/index.ts +444 -0
  295. package/src/utils/oauth/kagi.ts +47 -0
  296. package/src/utils/oauth/kilo.ts +87 -0
  297. package/src/utils/oauth/kimi.ts +254 -0
  298. package/src/utils/oauth/litellm.ts +47 -0
  299. package/src/utils/oauth/lm-studio.ts +38 -0
  300. package/src/utils/oauth/minimax-code.ts +78 -0
  301. package/src/utils/oauth/moonshot.ts +16 -0
  302. package/src/utils/oauth/nanogpt.ts +15 -0
  303. package/src/utils/oauth/nvidia.ts +70 -0
  304. package/src/utils/oauth/oauth.html +199 -0
  305. package/src/utils/oauth/ollama-cloud.ts +28 -0
  306. package/src/utils/oauth/ollama.ts +47 -0
  307. package/src/utils/oauth/openai-codex.ts +299 -0
  308. package/src/utils/oauth/opencode.ts +49 -0
  309. package/src/utils/oauth/parallel.ts +46 -0
  310. package/src/utils/oauth/perplexity.ts +206 -0
  311. package/src/utils/oauth/pkce.ts +18 -0
  312. package/src/utils/oauth/qianfan.ts +58 -0
  313. package/src/utils/oauth/qwen-portal.ts +60 -0
  314. package/src/utils/oauth/synthetic.ts +16 -0
  315. package/src/utils/oauth/tavily.ts +46 -0
  316. package/src/utils/oauth/together.ts +16 -0
  317. package/src/utils/oauth/types.ts +94 -0
  318. package/src/utils/oauth/venice.ts +59 -0
  319. package/src/utils/oauth/vercel-ai-gateway.ts +47 -0
  320. package/src/utils/oauth/vllm.ts +40 -0
  321. package/src/utils/oauth/xiaomi.ts +137 -0
  322. package/src/utils/oauth/zai.ts +60 -0
  323. package/src/utils/oauth/zenmux.ts +15 -0
  324. package/src/utils/overflow.ts +137 -0
  325. package/src/utils/parse-bind.ts +54 -0
  326. package/src/utils/provider-response.ts +30 -0
  327. package/src/utils/retry-after.ts +110 -0
  328. package/src/utils/retry.ts +54 -0
  329. package/src/utils/schema/CONSTRAINTS.md +164 -0
  330. package/src/utils/schema/adapt.ts +36 -0
  331. package/src/utils/schema/compatibility.ts +435 -0
  332. package/src/utils/schema/dereference.ts +98 -0
  333. package/src/utils/schema/draft.ts +341 -0
  334. package/src/utils/schema/equality.ts +97 -0
  335. package/src/utils/schema/fields.ts +190 -0
  336. package/src/utils/schema/index.ts +13 -0
  337. package/src/utils/schema/json-schema-validator.ts +577 -0
  338. package/src/utils/schema/meta-validator.ts +167 -0
  339. package/src/utils/schema/normalize.ts +1588 -0
  340. package/src/utils/schema/spill.ts +43 -0
  341. package/src/utils/schema/stamps.ts +97 -0
  342. package/src/utils/schema/types.ts +11 -0
  343. package/src/utils/schema/wire.ts +213 -0
  344. package/src/utils/schema/zod-decontaminate.ts +331 -0
  345. package/src/utils/sse-debug.ts +289 -0
  346. package/src/utils/tool-call-healing.ts +271 -0
  347. package/src/utils/tool-choice.ts +99 -0
  348. package/src/utils/validation.ts +1019 -0
  349. package/src/utils.ts +166 -0
@@ -0,0 +1,89 @@
1
+ import type OpenAI from "openai";
2
+ import type { ResponseInput, ResponseInputContent, ResponseOutputItem } from "openai/resources/responses/responses";
3
+ import { type Api, type AssistantMessage, type ImageContent, type Model, type ServiceTier, type StopReason, type StreamOptions, type TextContent, type TextSignatureV1, type ToolResultMessage } from "../types";
4
+ import type { AssistantMessageEventStream } from "../utils/event-stream";
5
+ export declare function encodeTextSignatureV1(id: string, phase?: TextSignatureV1["phase"]): string;
6
+ export declare function parseTextSignature(signature: string | undefined): {
7
+ id: string;
8
+ phase?: TextSignatureV1["phase"];
9
+ } | undefined;
10
+ export declare function encodeResponsesToolCallId(callId: string, itemId: string | null | undefined): string;
11
+ export declare function normalizeResponsesToolCallIdForTransform(id: string, model?: Model<Api>, source?: AssistantMessage): string;
12
+ export declare function collectKnownCallIds(messages: ResponseInput): Set<string>;
13
+ /** Scan replay items for call_ids that were originally custom tool calls. */
14
+ export declare function collectCustomCallIds(messages: ResponseInput): Set<string>;
15
+ /**
16
+ * Convert orphan `function_call_output` / `custom_tool_call_output` items —
17
+ * those whose `call_id` has no matching preceding `function_call` /
18
+ * `custom_tool_call` in the same input — into assistant text notes.
19
+ *
20
+ * The Responses API rejects unpaired outputs with
21
+ * `400 No tool call found for function call output with call_id …`. Orphans
22
+ * sneak in through two paths today:
23
+ *
24
+ * - A previous turn's `providerPayload` snapshot replaces the input array via
25
+ * the `dt: false` splice (see {@link convertConversationMessages}), wiping
26
+ * the matching `function_call` while leaving the matching
27
+ * `function_call_output` queued in a later `toolResult`.
28
+ * - A locally-rejected tool call (argument-validation failure, hook reject,
29
+ * aborted turn before the call streamed) produces a tool result without a
30
+ * `function_call` ever landing in any persisted provider payload.
31
+ *
32
+ * Dropping the result loses information the model needs to recover; sending
33
+ * it as-is 400s the request. Folding it into an assistant `message` preserves
34
+ * the payload (call_id + truncated output) while staying within the Responses
35
+ * input grammar. Matches the behavior of {@link transformRequestBody} in the
36
+ * OpenAI code backend provider — issue #1351 / regression of #472.
37
+ */
38
+ export declare function repairOrphanResponsesToolOutputs(input: ResponseInput): ResponseInput;
39
+ export declare function convertResponsesInputContent(content: string | Array<TextContent | ImageContent>, supportsImages: boolean): ResponseInputContent[] | undefined;
40
+ export declare function convertResponsesAssistantMessage<TApi extends Api>(assistantMsg: AssistantMessage, model: Model<TApi>, msgIndex: number, knownCallIds: Set<string>, includeThinkingSignatures?: boolean, customCallIds?: Set<string>): ResponseInput;
41
+ export declare function appendResponsesToolResultMessages<TApi extends Api>(messages: ResponseInput, toolResult: ToolResultMessage, model: Model<TApi>, strictResponsesPairing: boolean, knownCallIds: ReadonlySet<string>, customCallIds?: ReadonlySet<string>): void;
42
+ export interface ProcessResponsesStreamOptions {
43
+ onFirstToken?: () => void;
44
+ onOutputItemDone?: (item: ResponseOutputItem) => void;
45
+ }
46
+ export declare function processResponsesStream<TApi extends Api>(openaiStream: AsyncIterable<OpenAI.Responses.ResponseStreamEvent>, output: AssistantMessage, stream: AssistantMessageEventStream, model: Model<TApi>, options?: ProcessResponsesStreamOptions): Promise<void>;
47
+ export declare function mapOpenAIResponsesStopReason(status: OpenAI.Responses.ResponseStatus | undefined): StopReason;
48
+ /** Initial empty `AssistantMessage` that streaming providers accumulate into. */
49
+ export declare function createInitialResponsesAssistantMessage(api: Api, provider: string, modelId: string): AssistantMessage;
50
+ /** Extension fields we add on top of `ResponseCreateParamsStreaming` across the Responses-family providers. */
51
+ export type ResponsesSamplingParamsExtras = {
52
+ top_p?: number;
53
+ top_k?: number;
54
+ min_p?: number;
55
+ presence_penalty?: number;
56
+ repetition_penalty?: number;
57
+ };
58
+ type CommonResponsesParams = OpenAI.Responses.ResponseCreateParamsStreaming & ResponsesSamplingParamsExtras;
59
+ type CommonSamplingOptions = Pick<StreamOptions, "temperature" | "topP" | "topK" | "minP" | "presencePenalty" | "repetitionPenalty" | "maxTokens"> & {
60
+ serviceTier?: ServiceTier;
61
+ };
62
+ /**
63
+ * Apply the common `StreamOptions` → Responses sampling-parameter mapping (max output tokens,
64
+ * temperature, top-p/k, min-p, presence/repetition penalties, service tier). Mutates `params`.
65
+ */
66
+ export declare function applyCommonResponsesSamplingParams<P extends CommonResponsesParams>(params: P, options: CommonSamplingOptions | undefined, provider: string): void;
67
+ type ReasoningOptions = {
68
+ reasoning?: string;
69
+ reasoningSummary?: "auto" | "detailed" | "concise" | null;
70
+ };
71
+ /**
72
+ * Apply reasoning-related Responses parameters: enable encrypted reasoning content for replay,
73
+ * set effort/summary when requested, and otherwise inject the GPT-5 "Juice: 0" no-reasoning hack.
74
+ * Mutates `params` and may push a developer message into `messages`.
75
+ */
76
+ export declare function applyResponsesReasoningParams<P extends OpenAI.Responses.ResponseCreateParamsStreaming>(params: P, model: Model<Api>, options: ReasoningOptions | undefined, messages: ResponseInput, mapEffort?: (effort: string) => string): void;
77
+ /** Populate `output.usage` from a Responses-API `response.usage` payload. Does not invoke `calculateCost`. */
78
+ export declare function populateResponsesUsageFromResponse(output: AssistantMessage, usage: {
79
+ input_tokens?: number | null;
80
+ output_tokens?: number | null;
81
+ total_tokens?: number | null;
82
+ input_tokens_details?: {
83
+ cached_tokens?: number | null;
84
+ } | null;
85
+ output_tokens_details?: {
86
+ reasoning_tokens?: number | null;
87
+ } | null;
88
+ } | null | undefined): void;
89
+ export {};
@@ -0,0 +1,32 @@
1
+ import type { Tool as OpenAITool } from "openai/resources/responses/responses";
2
+ import type { Model, ServiceTier, StreamFunction, StreamOptions, Tool, ToolChoice } from "../types";
3
+ import { type OpenAIResponsesToolChoice } from "../utils/tool-choice";
4
+ export declare function normalizeOpenAIResponsesPromptCacheKey(sessionId: string | undefined): string | undefined;
5
+ export interface OpenAIResponsesOptions extends StreamOptions {
6
+ reasoning?: "minimal" | "low" | "medium" | "high" | "xhigh";
7
+ reasoningSummary?: "auto" | "detailed" | "concise" | null;
8
+ serviceTier?: ServiceTier;
9
+ toolChoice?: ToolChoice;
10
+ /**
11
+ * Enforce strict tool call/result pairing when building Responses API inputs.
12
+ * Azure OpenAI and GitHub Copilot Responses paths require tool results to match prior tool calls.
13
+ */
14
+ strictResponsesPairing?: boolean;
15
+ }
16
+ /**
17
+ * Generate function for OpenAI Responses API
18
+ */
19
+ export declare const streamOpenAIResponses: StreamFunction<"openai-responses">;
20
+ export declare function supportsDeveloperRole(modelOrBaseUrl: Pick<Model, "provider" | "baseUrl"> | string): boolean;
21
+ /**
22
+ * Whether this model should get the OpenAI custom-tool grammar variant
23
+ * for `apply_patch`. The generated model catalog sets
24
+ * `model.applyPatchToolType` for first-party GPT-5 Responses models; this
25
+ * runtime path only consumes that metadata.
26
+ * @internal Exported for tests.
27
+ */
28
+ export declare function supportsFreeformApplyPatch(model: Model<"openai-responses">): boolean;
29
+ /** @internal Exported for tests. */
30
+ export declare function mapOpenAIResponsesToolChoiceForTools(choice: ToolChoice | undefined, tools: Tool[], model: Model<"openai-responses">): OpenAIResponsesToolChoice;
31
+ /** @internal Exported for tests. */
32
+ export declare function convertTools(tools: Tool[], strictMode: boolean, model: Model<"openai-responses">): OpenAITool[];
@@ -0,0 +1,13 @@
1
+ import type { Api, AssistantMessageEventStream as AssistantMessageEventStreamType, Context, Model, SimpleStreamOptions } from "../types";
2
+ /**
3
+ * Stream a turn through an `gjc auth-gateway` over the pi-native protocol.
4
+ *
5
+ * The returned {@link AssistantMessageEventStream} receives each parsed
6
+ * `AssistantMessageEvent` verbatim from the gateway; the terminal `done` /
7
+ * `error` event resolves `.result()` automatically via the base class's
8
+ * completion check. Non-streaming consumers just call `.result()` and pay
9
+ * for SSE framing they don't use — that overhead is dominated by provider
10
+ * latency, so we always stream rather than maintaining a parallel
11
+ * non-streaming path.
12
+ */
13
+ export declare function streamPiNative<TApi extends Api>(model: Model<TApi>, context: Context, options?: SimpleStreamOptions): AssistantMessageEventStreamType;
@@ -0,0 +1,68 @@
1
+ /**
2
+ * Pi-native wire format for the auth-gateway.
3
+ *
4
+ * Where the OpenAI / Anthropic / Responses route modules translate foreign
5
+ * wire shapes through pi-ai's canonical {@link Context}, this module accepts
6
+ * the canonical shape *directly* — for clients that already speak pi-ai
7
+ * (containerized gjc, the swarm extension, robogjc'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 pi-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 pi-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/pi/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
+ export interface PiNativeParsedRequest {
30
+ modelId: string;
31
+ context: Context;
32
+ options: SimpleStreamOptions;
33
+ stream: boolean;
34
+ }
35
+ /**
36
+ * Parse a pi-native request body. Validation is intentionally minimal — only
37
+ * the shape the gateway itself reads is checked (`modelId`, `context.messages`
38
+ * array, options is an object). Everything downstream is the canonical pi-ai
39
+ * type surface; mis-shaped values surface as a `502 upstream_error` from
40
+ * `streamSimple` rather than being re-validated here.
41
+ *
42
+ * Accepts both `{ modelId: string }` and `{ model: { id: string } }` so the
43
+ * existing `streamProxy` client (which sends the full Model object) can target
44
+ * the gateway with only a URL swap.
45
+ */
46
+ export declare function parseRequest(body: unknown, _headers?: Headers): PiNativeParsedRequest;
47
+ /**
48
+ * Ship every {@link AssistantMessageEvent} verbatim, SSE-framed.
49
+ *
50
+ * No per-event re-shaping: the pi-native client is pi-ai itself, so the
51
+ * canonical event type IS the wire type. Including the rolling
52
+ * `partial: AssistantMessage` on every delta is quadratic in turn length
53
+ * on the wire, but for the loopback / sidecar topology this transport
54
+ * targets (containerized gjc → host gateway, robogjc slot → gjc-auth-gateway
55
+ * sidecar) the bandwidth cost is negligible compared to provider latency —
56
+ * and the client gets to feed the events straight into its existing
57
+ * `AssistantMessageEventStream.push()` plumbing with zero translation.
58
+ */
59
+ export declare function encodeStream(events: AssistantMessageEventStream): ReadableStream<Uint8Array>;
60
+ /**
61
+ * Pi-native error envelope:
62
+ * `{ error: { type, message } }`
63
+ *
64
+ * Mirrors OpenAI's outer shape (which clients/SDKs already parse) without the
65
+ * provider-specific status taxonomy — pi-native callers consume `type`
66
+ * directly.
67
+ */
68
+ export declare function formatError(status: number, type: string, message: string): Response;
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Lazy provider module loading.
3
+ *
4
+ * Each provider module is loaded only when its stream function is first called.
5
+ * This avoids eagerly importing heavy SDK dependencies (e.g., @anthropic-ai/sdk,
6
+ * openai) at startup. The loaded module promise is cached so subsequent calls
7
+ * reuse the same import.
8
+ *
9
+ * NOTE: stream.ts currently imports providers directly, so this file is not yet
10
+ * wired into the main streaming path. It provides the infrastructure for lazy
11
+ * loading that can be integrated when stream.ts is refactored.
12
+ */
13
+ import type { AssistantMessageEventStream, Context, Model, OptionsForApi } from "../types";
14
+ import { AssistantMessageEventStream as EventStreamImpl } from "../utils/event-stream";
15
+ import type { BedrockOptions } from "./amazon-bedrock";
16
+ interface BedrockProviderModule {
17
+ streamBedrock: (model: Model<"bedrock-converse-stream">, context: Context, options: BedrockOptions) => AssistantMessageEventStream;
18
+ }
19
+ export declare function setBedrockProviderModule(module: BedrockProviderModule): void;
20
+ export declare const streamAnthropic: (model: Model<"anthropic-messages">, context: Context, options: OptionsForApi<"anthropic-messages">) => EventStreamImpl;
21
+ export declare const streamAzureOpenAIResponses: (model: Model<"azure-openai-responses">, context: Context, options: OptionsForApi<"azure-openai-responses">) => EventStreamImpl;
22
+ export declare const streamGoogle: (model: Model<"google-generative-ai">, context: Context, options: OptionsForApi<"google-generative-ai">) => EventStreamImpl;
23
+ export declare const streamGoogleGeminiCli: (model: Model<"google-gemini-cli">, context: Context, options: OptionsForApi<"google-gemini-cli">) => EventStreamImpl;
24
+ export declare const streamGoogleVertex: (model: Model<"google-vertex">, context: Context, options: OptionsForApi<"google-vertex">) => EventStreamImpl;
25
+ export declare const streamOpenAICodexResponses: (model: Model<"openai-codex-responses">, context: Context, options: OptionsForApi<"openai-codex-responses">) => EventStreamImpl;
26
+ export declare const streamOpenAICompletions: (model: Model<"openai-completions">, context: Context, options: OptionsForApi<"openai-completions">) => EventStreamImpl;
27
+ export declare const streamOpenAIResponses: (model: Model<"openai-responses">, context: Context, options: OptionsForApi<"openai-responses">) => EventStreamImpl;
28
+ export declare const streamCursor: (model: Model<"cursor-agent">, context: Context, options: OptionsForApi<"cursor-agent">) => EventStreamImpl;
29
+ export declare const streamOllama: (model: Model<"ollama-chat">, context: Context, options: OptionsForApi<"ollama-chat">) => EventStreamImpl;
30
+ export declare const streamBedrock: (model: Model<"bedrock-converse-stream">, context: Context, options: OptionsForApi<"bedrock-converse-stream">) => EventStreamImpl;
31
+ export {};
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Synthetic provider - wraps OpenAI or Anthropic API based on format setting.
3
+ *
4
+ * Synthetic offers both OpenAI-compatible and Anthropic-compatible APIs:
5
+ * - OpenAI: https://api.synthetic.new/openai/v1/chat/completions
6
+ * - Anthropic: https://api.synthetic.new/anthropic/v1/messages
7
+ *
8
+ * @see https://dev.synthetic.new/docs/api/overview
9
+ */
10
+ import type { Api, Context, Model } from "../types";
11
+ import type { AssistantMessageEventStream } from "../utils/event-stream";
12
+ import { type OpenAIAnthropicApiFormat, type OpenAIAnthropicShimOptions } from "./openai-anthropic-shim";
13
+ export type SyntheticApiFormat = OpenAIAnthropicApiFormat;
14
+ export interface SyntheticOptions extends OpenAIAnthropicShimOptions {
15
+ /** API format: "openai" or "anthropic". Default: "openai" */
16
+ format?: SyntheticApiFormat;
17
+ }
18
+ /**
19
+ * Stream from Synthetic, routing to either OpenAI or Anthropic API based on format.
20
+ * Returns synchronously like other providers - async processing happens internally.
21
+ */
22
+ export declare function streamSynthetic(model: Model<"openai-completions">, context: Context, options?: SyntheticOptions): AssistantMessageEventStream;
23
+ /**
24
+ * Check if a model is a Synthetic model.
25
+ */
26
+ export declare function isSyntheticModel(model: Model<Api>): boolean;
@@ -0,0 +1,12 @@
1
+ import type { Api, AssistantMessage, Message, Model } from "../types";
2
+ /**
3
+ * Normalize tool call ID for cross-provider compatibility.
4
+ * OpenAI Responses API generates IDs that are 450+ chars with special characters like `|`.
5
+ * Anthropic APIs require IDs matching ^[a-zA-Z0-9_-]+$ (max 64 chars).
6
+ *
7
+ * For aborted/errored turns, this function:
8
+ * - Preserves tool call structure (unlike converting to text summaries)
9
+ * - Injects synthetic "aborted" tool results
10
+ * - Adds a <turn-aborted> guidance marker for the model
11
+ */
12
+ export declare function transformMessages<TApi extends Api>(messages: Message[], model: Model<TApi>, normalizeToolCallId?: (id: string, model: Model<TApi>, source: AssistantMessage) => string): Message[];
@@ -0,0 +1,8 @@
1
+ import type { ImageContent, TextContent } from "../types";
2
+ export declare const NON_VISION_IMAGE_PLACEHOLDER = "[image omitted: model does not support vision]";
3
+ export declare function partitionVisionContent(content: ReadonlyArray<TextContent | ImageContent>, supportsImages: boolean): {
4
+ textBlocks: TextContent[];
5
+ imageBlocks: ImageContent[];
6
+ omittedImages: boolean;
7
+ };
8
+ export declare function joinTextWithImagePlaceholder(text: string, omittedImages: boolean): string;
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Rate limit reason classification and backoff calculation utilities.
3
+ * Ported from opencode-antigravity-auth plugin for consistency.
4
+ */
5
+ export type RateLimitReason = "QUOTA_EXHAUSTED" | "RATE_LIMIT_EXCEEDED" | "MODEL_CAPACITY_EXHAUSTED" | "SERVER_ERROR" | "UNKNOWN";
6
+ /**
7
+ * Classify a rate-limit error message into a reason category.
8
+ * Priority order: MODEL_CAPACITY > RATE_LIMIT > QUOTA > SERVER_ERROR > UNKNOWN.
9
+ *
10
+ * "resource exhausted" maps to MODEL_CAPACITY (transient, short wait)
11
+ * "quota exceeded" maps to QUOTA_EXHAUSTED (long wait, switch account)
12
+ */
13
+ export declare function parseRateLimitReason(errorMessage: string): RateLimitReason;
14
+ /**
15
+ * Calculate backoff delay in ms for a given rate limit reason.
16
+ * MODEL_CAPACITY gets jitter to prevent thundering herd.
17
+ */
18
+ export declare function calculateRateLimitBackoffMs(reason: RateLimitReason): number;
19
+ export declare function isUsageLimitError(errorMessage: string): boolean;
@@ -0,0 +1,24 @@
1
+ import type { Effort } from "./model-thinking";
2
+ import type { AnthropicOptions } from "./providers/anthropic";
3
+ import type { Api, AssistantMessage, Context, Model, OptionsForApi, SimpleStreamOptions, ToolChoice } from "./types";
4
+ import { AssistantMessageEventStream } from "./utils/event-stream";
5
+ /**
6
+ * Get API key for provider from known environment variables, e.g. OPENAI_API_KEY.
7
+ *
8
+ * Will not return API keys for providers that require OAuth tokens.
9
+ * Checks Bun.env, then cwd/.env, then ~/.env.
10
+ */
11
+ export declare function getEnvApiKey(provider: string): string | undefined;
12
+ /**
13
+ * Enumerate every provider that has an env-var fallback for `getEnvApiKey`.
14
+ * Used by `gjc auth-broker migrate --include-env` to discover env-sourced keys
15
+ * that should be uploaded to the broker.
16
+ */
17
+ export declare function listProvidersWithEnvKey(): string[];
18
+ export declare function stream<TApi extends Api>(model: Model<TApi>, context: Context, options?: OptionsForApi<TApi>): AssistantMessageEventStream;
19
+ export declare function complete<TApi extends Api>(model: Model<TApi>, context: Context, options?: OptionsForApi<TApi>): Promise<AssistantMessage>;
20
+ export declare function streamSimple<TApi extends Api>(model: Model<TApi>, context: Context, options?: SimpleStreamOptions): AssistantMessageEventStream;
21
+ export declare function completeSimple<TApi extends Api>(model: Model<TApi>, context: Context, options?: SimpleStreamOptions): Promise<AssistantMessage>;
22
+ export declare const OUTPUT_FALLBACK_BUFFER = 4000;
23
+ export declare const ANTHROPIC_THINKING: Record<Effort, number>;
24
+ export declare function mapAnthropicToolChoice(choice?: ToolChoice): AnthropicOptions["toolChoice"];