@earendil-works/pi-ai 0.79.9 → 0.80.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 (527) hide show
  1. package/README.md +633 -521
  2. package/dist/api/anthropic-messages.d.ts +71 -0
  3. package/dist/api/anthropic-messages.d.ts.map +1 -0
  4. package/dist/api/anthropic-messages.js +965 -0
  5. package/dist/api/anthropic-messages.js.map +1 -0
  6. package/dist/api/anthropic-messages.lazy.d.ts +3 -0
  7. package/dist/api/anthropic-messages.lazy.d.ts.map +1 -0
  8. package/dist/api/anthropic-messages.lazy.js +3 -0
  9. package/dist/api/anthropic-messages.lazy.js.map +1 -0
  10. package/dist/api/azure-openai-responses.d.ts +15 -0
  11. package/dist/api/azure-openai-responses.d.ts.map +1 -0
  12. package/dist/api/azure-openai-responses.js +225 -0
  13. package/dist/api/azure-openai-responses.js.map +1 -0
  14. package/dist/api/azure-openai-responses.lazy.d.ts +3 -0
  15. package/dist/api/azure-openai-responses.lazy.d.ts.map +1 -0
  16. package/dist/api/azure-openai-responses.lazy.js +3 -0
  17. package/dist/api/azure-openai-responses.lazy.js.map +1 -0
  18. package/dist/api/bedrock-converse-stream.d.ts +38 -0
  19. package/dist/api/bedrock-converse-stream.d.ts.map +1 -0
  20. package/dist/api/bedrock-converse-stream.js +863 -0
  21. package/dist/api/bedrock-converse-stream.js.map +1 -0
  22. package/dist/api/bedrock-converse-stream.lazy.d.ts +9 -0
  23. package/dist/api/bedrock-converse-stream.lazy.d.ts.map +1 -0
  24. package/dist/api/bedrock-converse-stream.lazy.js +30 -0
  25. package/dist/api/bedrock-converse-stream.lazy.js.map +1 -0
  26. package/dist/{providers → api}/cloudflare.d.ts +0 -4
  27. package/dist/api/cloudflare.d.ts.map +1 -0
  28. package/dist/{providers → api}/cloudflare.js +0 -18
  29. package/dist/api/cloudflare.js.map +1 -0
  30. package/dist/api/github-copilot-headers.d.ts.map +1 -0
  31. package/dist/api/github-copilot-headers.js.map +1 -0
  32. package/dist/api/google-generative-ai.d.ts +13 -0
  33. package/dist/api/google-generative-ai.d.ts.map +1 -0
  34. package/dist/api/google-generative-ai.js +405 -0
  35. package/dist/api/google-generative-ai.js.map +1 -0
  36. package/dist/api/google-generative-ai.lazy.d.ts +3 -0
  37. package/dist/api/google-generative-ai.lazy.d.ts.map +1 -0
  38. package/dist/api/google-generative-ai.lazy.js +3 -0
  39. package/dist/api/google-generative-ai.lazy.js.map +1 -0
  40. package/dist/api/google-shared.d.ts.map +1 -0
  41. package/dist/api/google-shared.js.map +1 -0
  42. package/dist/api/google-vertex.d.ts +15 -0
  43. package/dist/api/google-vertex.d.ts.map +1 -0
  44. package/dist/api/google-vertex.js +454 -0
  45. package/dist/api/google-vertex.js.map +1 -0
  46. package/dist/api/google-vertex.lazy.d.ts +3 -0
  47. package/dist/api/google-vertex.lazy.d.ts.map +1 -0
  48. package/dist/api/google-vertex.lazy.js +3 -0
  49. package/dist/api/google-vertex.lazy.js.map +1 -0
  50. package/dist/api/lazy.d.ts +15 -0
  51. package/dist/api/lazy.d.ts.map +1 -0
  52. package/dist/api/lazy.js +59 -0
  53. package/dist/api/lazy.js.map +1 -0
  54. package/dist/api/mistral-conversations.d.ts +25 -0
  55. package/dist/api/mistral-conversations.d.ts.map +1 -0
  56. package/dist/api/mistral-conversations.js +555 -0
  57. package/dist/api/mistral-conversations.js.map +1 -0
  58. package/dist/api/mistral-conversations.lazy.d.ts +3 -0
  59. package/dist/api/mistral-conversations.lazy.d.ts.map +1 -0
  60. package/dist/api/mistral-conversations.lazy.js +3 -0
  61. package/dist/api/mistral-conversations.lazy.js.map +1 -0
  62. package/dist/{providers → api}/openai-codex-responses.d.ts +2 -3
  63. package/dist/api/openai-codex-responses.d.ts.map +1 -0
  64. package/dist/{providers → api}/openai-codex-responses.js +66 -45
  65. package/dist/api/openai-codex-responses.js.map +1 -0
  66. package/dist/api/openai-codex-responses.lazy.d.ts +3 -0
  67. package/dist/api/openai-codex-responses.lazy.d.ts.map +1 -0
  68. package/dist/api/openai-codex-responses.lazy.js +3 -0
  69. package/dist/api/openai-codex-responses.lazy.js.map +1 -0
  70. package/dist/{providers → api}/openai-completions.d.ts +2 -3
  71. package/dist/api/openai-completions.d.ts.map +1 -0
  72. package/dist/{providers → api}/openai-completions.js +99 -132
  73. package/dist/api/openai-completions.js.map +1 -0
  74. package/dist/api/openai-completions.lazy.d.ts +3 -0
  75. package/dist/api/openai-completions.lazy.d.ts.map +1 -0
  76. package/dist/api/openai-completions.lazy.js +3 -0
  77. package/dist/api/openai-completions.lazy.js.map +1 -0
  78. package/dist/api/openai-prompt-cache.d.ts.map +1 -0
  79. package/dist/api/openai-prompt-cache.js.map +1 -0
  80. package/dist/api/openai-responses-shared.d.ts.map +1 -0
  81. package/dist/{providers → api}/openai-responses-shared.js +37 -29
  82. package/dist/api/openai-responses-shared.js.map +1 -0
  83. package/dist/{providers → api}/openai-responses.d.ts +2 -3
  84. package/dist/api/openai-responses.d.ts.map +1 -0
  85. package/dist/{providers → api}/openai-responses.js +27 -32
  86. package/dist/api/openai-responses.js.map +1 -0
  87. package/dist/api/openai-responses.lazy.d.ts +3 -0
  88. package/dist/api/openai-responses.lazy.d.ts.map +1 -0
  89. package/dist/api/openai-responses.lazy.js +3 -0
  90. package/dist/api/openai-responses.lazy.js.map +1 -0
  91. package/dist/api/openrouter-images.d.ts +3 -0
  92. package/dist/api/openrouter-images.d.ts.map +1 -0
  93. package/dist/{providers/images/openrouter.js → api/openrouter-images.js} +5 -15
  94. package/dist/api/openrouter-images.js.map +1 -0
  95. package/dist/api/openrouter-images.lazy.d.ts +3 -0
  96. package/dist/api/openrouter-images.lazy.d.ts.map +1 -0
  97. package/dist/api/openrouter-images.lazy.js +4 -0
  98. package/dist/api/openrouter-images.lazy.js.map +1 -0
  99. package/dist/api/simple-options.d.ts.map +1 -0
  100. package/dist/api/simple-options.js.map +1 -0
  101. package/dist/api/transform-messages.d.ts.map +1 -0
  102. package/dist/api/transform-messages.js.map +1 -0
  103. package/dist/auth/context.d.ts +7 -0
  104. package/dist/auth/context.d.ts.map +1 -0
  105. package/dist/auth/context.js +42 -0
  106. package/dist/auth/context.js.map +1 -0
  107. package/dist/auth/credential-store.d.ts +16 -0
  108. package/dist/auth/credential-store.d.ts.map +1 -0
  109. package/dist/auth/credential-store.js +37 -0
  110. package/dist/auth/credential-store.js.map +1 -0
  111. package/dist/auth/helpers.d.ts +20 -0
  112. package/dist/auth/helpers.d.ts.map +1 -0
  113. package/dist/auth/helpers.js +46 -0
  114. package/dist/auth/helpers.js.map +1 -0
  115. package/dist/auth/resolve.d.ts +22 -0
  116. package/dist/auth/resolve.d.ts.map +1 -0
  117. package/dist/auth/resolve.js +86 -0
  118. package/dist/auth/resolve.js.map +1 -0
  119. package/dist/auth/types.d.ts +180 -0
  120. package/dist/auth/types.d.ts.map +1 -0
  121. package/dist/auth/types.js +2 -0
  122. package/dist/auth/types.js.map +1 -0
  123. package/dist/bedrock-provider.d.ts +2 -4
  124. package/dist/bedrock-provider.d.ts.map +1 -1
  125. package/dist/bedrock-provider.js +3 -4
  126. package/dist/bedrock-provider.js.map +1 -1
  127. package/dist/compat.d.ts +64 -0
  128. package/dist/compat.d.ts.map +1 -0
  129. package/dist/compat.js +181 -0
  130. package/dist/compat.js.map +1 -0
  131. package/dist/images-api-registry.d.ts +0 -1
  132. package/dist/images-api-registry.d.ts.map +1 -1
  133. package/dist/images-api-registry.js +0 -3
  134. package/dist/images-api-registry.js.map +1 -1
  135. package/dist/images-models.d.ts +93 -0
  136. package/dist/images-models.d.ts.map +1 -0
  137. package/dist/images-models.js +138 -0
  138. package/dist/images-models.js.map +1 -0
  139. package/dist/images.d.ts +1 -0
  140. package/dist/images.d.ts.map +1 -1
  141. package/dist/images.js +1 -0
  142. package/dist/images.js.map +1 -1
  143. package/dist/index.d.ts +29 -2
  144. package/dist/index.d.ts.map +1 -1
  145. package/dist/index.js +17 -4
  146. package/dist/index.js.map +1 -1
  147. package/dist/models.d.ts +133 -9
  148. package/dist/models.d.ts.map +1 -1
  149. package/dist/models.generated.d.ts +1793 -183
  150. package/dist/models.generated.d.ts.map +1 -1
  151. package/dist/models.generated.js +70 -17172
  152. package/dist/models.generated.js.map +1 -1
  153. package/dist/models.js +178 -17
  154. package/dist/models.js.map +1 -1
  155. package/dist/providers/all.d.ts +21 -0
  156. package/dist/providers/all.d.ts.map +1 -0
  157. package/dist/providers/all.js +114 -0
  158. package/dist/providers/all.js.map +1 -0
  159. package/dist/providers/amazon-bedrock.d.ts +2 -38
  160. package/dist/providers/amazon-bedrock.d.ts.map +1 -1
  161. package/dist/providers/amazon-bedrock.js +35 -865
  162. package/dist/providers/amazon-bedrock.js.map +1 -1
  163. package/dist/providers/amazon-bedrock.models.d.ts +1718 -0
  164. package/dist/providers/amazon-bedrock.models.d.ts.map +1 -0
  165. package/dist/providers/amazon-bedrock.models.js +1675 -0
  166. package/dist/providers/amazon-bedrock.models.js.map +1 -0
  167. package/dist/providers/ant-ling.d.ts +3 -0
  168. package/dist/providers/ant-ling.d.ts.map +1 -0
  169. package/dist/providers/ant-ling.js +15 -0
  170. package/dist/providers/ant-ling.js.map +1 -0
  171. package/dist/providers/ant-ling.models.d.ts +86 -0
  172. package/dist/providers/ant-ling.models.d.ts.map +1 -0
  173. package/dist/providers/ant-ling.models.js +60 -0
  174. package/dist/providers/ant-ling.models.js.map +1 -0
  175. package/dist/providers/anthropic.d.ts +2 -71
  176. package/dist/providers/anthropic.d.ts.map +1 -1
  177. package/dist/providers/anthropic.js +17 -973
  178. package/dist/providers/anthropic.js.map +1 -1
  179. package/dist/providers/anthropic.models.d.ts +458 -0
  180. package/dist/providers/anthropic.models.d.ts.map +1 -0
  181. package/dist/providers/anthropic.models.js +439 -0
  182. package/dist/providers/anthropic.models.js.map +1 -0
  183. package/dist/providers/azure-openai-responses.d.ts +2 -15
  184. package/dist/providers/azure-openai-responses.d.ts.map +1 -1
  185. package/dist/providers/azure-openai-responses.js +11 -230
  186. package/dist/providers/azure-openai-responses.js.map +1 -1
  187. package/dist/providers/azure-openai-responses.models.d.ts +804 -0
  188. package/dist/providers/azure-openai-responses.models.d.ts.map +1 -0
  189. package/dist/providers/azure-openai-responses.models.js +743 -0
  190. package/dist/providers/azure-openai-responses.models.js.map +1 -0
  191. package/dist/providers/cerebras.d.ts +3 -0
  192. package/dist/providers/cerebras.d.ts.map +1 -0
  193. package/dist/providers/cerebras.js +15 -0
  194. package/dist/providers/cerebras.js.map +1 -0
  195. package/dist/providers/cerebras.models.d.ts +45 -0
  196. package/dist/providers/cerebras.models.d.ts.map +1 -0
  197. package/dist/providers/cerebras.models.js +41 -0
  198. package/dist/providers/cerebras.models.js.map +1 -0
  199. package/dist/providers/cloudflare-ai-gateway.d.ts +3 -0
  200. package/dist/providers/cloudflare-ai-gateway.d.ts.map +1 -0
  201. package/dist/providers/cloudflare-ai-gateway.js +20 -0
  202. package/dist/providers/cloudflare-ai-gateway.js.map +1 -0
  203. package/dist/providers/cloudflare-ai-gateway.models.d.ts +765 -0
  204. package/dist/providers/cloudflare-ai-gateway.models.d.ts.map +1 -0
  205. package/dist/providers/cloudflare-ai-gateway.models.js +666 -0
  206. package/dist/providers/cloudflare-ai-gateway.models.js.map +1 -0
  207. package/dist/providers/cloudflare-auth.d.ts +4 -0
  208. package/dist/providers/cloudflare-auth.d.ts.map +1 -0
  209. package/dist/providers/cloudflare-auth.js +87 -0
  210. package/dist/providers/cloudflare-auth.js.map +1 -0
  211. package/dist/providers/cloudflare-workers-ai.d.ts +3 -0
  212. package/dist/providers/cloudflare-workers-ai.d.ts.map +1 -0
  213. package/dist/providers/cloudflare-workers-ai.js +14 -0
  214. package/dist/providers/cloudflare-workers-ai.js.map +1 -0
  215. package/dist/providers/cloudflare-workers-ai.models.d.ts +302 -0
  216. package/dist/providers/cloudflare-workers-ai.models.d.ts.map +1 -0
  217. package/dist/providers/cloudflare-workers-ai.models.js +239 -0
  218. package/dist/providers/cloudflare-workers-ai.models.js.map +1 -0
  219. package/dist/providers/deepseek.d.ts +3 -0
  220. package/dist/providers/deepseek.d.ts.map +1 -0
  221. package/dist/providers/deepseek.js +15 -0
  222. package/dist/providers/deepseek.js.map +1 -0
  223. package/dist/providers/deepseek.models.d.ts +63 -0
  224. package/dist/providers/deepseek.models.d.ts.map +1 -0
  225. package/dist/providers/deepseek.models.js +43 -0
  226. package/dist/providers/deepseek.models.js.map +1 -0
  227. package/dist/providers/faux.d.ts +43 -2
  228. package/dist/providers/faux.d.ts.map +1 -1
  229. package/dist/providers/faux.js +34 -7
  230. package/dist/providers/faux.js.map +1 -1
  231. package/dist/providers/fireworks.d.ts +3 -0
  232. package/dist/providers/fireworks.d.ts.map +1 -0
  233. package/dist/providers/fireworks.js +19 -0
  234. package/dist/providers/fireworks.js.map +1 -0
  235. package/dist/providers/fireworks.models.d.ts +353 -0
  236. package/dist/providers/fireworks.models.d.ts.map +1 -0
  237. package/dist/providers/fireworks.models.js +276 -0
  238. package/dist/providers/fireworks.models.js.map +1 -0
  239. package/dist/providers/github-copilot.d.ts +3 -0
  240. package/dist/providers/github-copilot.d.ts.map +1 -0
  241. package/dist/providers/github-copilot.js +25 -0
  242. package/dist/providers/github-copilot.js.map +1 -0
  243. package/dist/providers/github-copilot.models.d.ts +616 -0
  244. package/dist/providers/github-copilot.models.d.ts.map +1 -0
  245. package/dist/providers/github-copilot.models.js +426 -0
  246. package/dist/providers/github-copilot.models.js.map +1 -0
  247. package/dist/providers/google-vertex.d.ts +2 -15
  248. package/dist/providers/google-vertex.d.ts.map +1 -1
  249. package/dist/providers/google-vertex.js +30 -455
  250. package/dist/providers/google-vertex.js.map +1 -1
  251. package/dist/providers/google-vertex.models.d.ts +202 -0
  252. package/dist/providers/google-vertex.models.d.ts.map +1 -0
  253. package/dist/providers/google-vertex.models.js +182 -0
  254. package/dist/providers/google-vertex.models.js.map +1 -0
  255. package/dist/providers/google.d.ts +2 -13
  256. package/dist/providers/google.d.ts.map +1 -1
  257. package/dist/providers/google.js +12 -408
  258. package/dist/providers/google.js.map +1 -1
  259. package/dist/providers/google.models.d.ts +328 -0
  260. package/dist/providers/google.models.d.ts.map +1 -0
  261. package/dist/providers/google.models.js +288 -0
  262. package/dist/providers/google.models.js.map +1 -0
  263. package/dist/providers/groq.d.ts +3 -0
  264. package/dist/providers/groq.d.ts.map +1 -0
  265. package/dist/providers/groq.js +15 -0
  266. package/dist/providers/groq.js.map +1 -0
  267. package/dist/providers/groq.models.d.ts +128 -0
  268. package/dist/providers/groq.models.d.ts.map +1 -0
  269. package/dist/providers/groq.models.js +125 -0
  270. package/dist/providers/groq.models.js.map +1 -0
  271. package/dist/providers/huggingface.d.ts +3 -0
  272. package/dist/providers/huggingface.d.ts.map +1 -0
  273. package/dist/providers/huggingface.js +15 -0
  274. package/dist/providers/huggingface.js.map +1 -0
  275. package/dist/providers/huggingface.models.d.ts +883 -0
  276. package/dist/providers/huggingface.models.d.ts.map +1 -0
  277. package/dist/providers/huggingface.models.js +797 -0
  278. package/dist/providers/huggingface.models.js.map +1 -0
  279. package/dist/providers/images/{openrouter.d.ts → register-builtins.d.ts} +2 -2
  280. package/dist/providers/images/register-builtins.d.ts.map +1 -0
  281. package/dist/providers/images/register-builtins.js +34 -0
  282. package/dist/providers/images/register-builtins.js.map +1 -0
  283. package/dist/providers/kimi-coding.d.ts +3 -0
  284. package/dist/providers/kimi-coding.d.ts.map +1 -0
  285. package/dist/providers/kimi-coding.js +15 -0
  286. package/dist/providers/kimi-coding.js.map +1 -0
  287. package/dist/providers/kimi-coding.models.d.ts +63 -0
  288. package/dist/providers/kimi-coding.models.d.ts.map +1 -0
  289. package/dist/providers/kimi-coding.models.js +59 -0
  290. package/dist/providers/kimi-coding.models.js.map +1 -0
  291. package/dist/providers/minimax-cn.d.ts +3 -0
  292. package/dist/providers/minimax-cn.d.ts.map +1 -0
  293. package/dist/providers/minimax-cn.js +15 -0
  294. package/dist/providers/minimax-cn.js.map +1 -0
  295. package/dist/providers/minimax-cn.models.d.ts +54 -0
  296. package/dist/providers/minimax-cn.models.d.ts.map +1 -0
  297. package/dist/providers/minimax-cn.models.js +56 -0
  298. package/dist/providers/minimax-cn.models.js.map +1 -0
  299. package/dist/providers/minimax.d.ts +3 -0
  300. package/dist/providers/minimax.d.ts.map +1 -0
  301. package/dist/providers/minimax.js +15 -0
  302. package/dist/providers/minimax.js.map +1 -0
  303. package/dist/providers/minimax.models.d.ts +54 -0
  304. package/dist/providers/minimax.models.d.ts.map +1 -0
  305. package/dist/providers/minimax.models.js +56 -0
  306. package/dist/providers/minimax.models.js.map +1 -0
  307. package/dist/providers/mistral.d.ts +2 -25
  308. package/dist/providers/mistral.d.ts.map +1 -1
  309. package/dist/providers/mistral.js +12 -560
  310. package/dist/providers/mistral.js.map +1 -1
  311. package/dist/providers/mistral.models.d.ts +513 -0
  312. package/dist/providers/mistral.models.d.ts.map +1 -0
  313. package/dist/providers/mistral.models.js +515 -0
  314. package/dist/providers/mistral.models.js.map +1 -0
  315. package/dist/providers/moonshotai-cn.d.ts +3 -0
  316. package/dist/providers/moonshotai-cn.d.ts.map +1 -0
  317. package/dist/providers/moonshotai-cn.js +15 -0
  318. package/dist/providers/moonshotai-cn.js.map +1 -0
  319. package/dist/providers/moonshotai-cn.models.d.ts +234 -0
  320. package/dist/providers/moonshotai-cn.models.d.ts.map +1 -0
  321. package/dist/providers/moonshotai-cn.models.js +169 -0
  322. package/dist/providers/moonshotai-cn.models.js.map +1 -0
  323. package/dist/providers/moonshotai.d.ts +3 -0
  324. package/dist/providers/moonshotai.d.ts.map +1 -0
  325. package/dist/providers/moonshotai.js +15 -0
  326. package/dist/providers/moonshotai.js.map +1 -0
  327. package/dist/providers/moonshotai.models.d.ts +234 -0
  328. package/dist/providers/moonshotai.models.d.ts.map +1 -0
  329. package/dist/providers/moonshotai.models.js +169 -0
  330. package/dist/providers/moonshotai.models.js.map +1 -0
  331. package/dist/providers/nvidia.d.ts +3 -0
  332. package/dist/providers/nvidia.d.ts.map +1 -0
  333. package/dist/providers/nvidia.js +15 -0
  334. package/dist/providers/nvidia.js.map +1 -0
  335. package/dist/providers/nvidia.models.d.ts +535 -0
  336. package/dist/providers/nvidia.models.d.ts.map +1 -0
  337. package/dist/providers/nvidia.models.js +366 -0
  338. package/dist/providers/nvidia.models.js.map +1 -0
  339. package/dist/providers/openai-codex.d.ts +3 -0
  340. package/dist/providers/openai-codex.d.ts.map +1 -0
  341. package/dist/providers/openai-codex.js +18 -0
  342. package/dist/providers/openai-codex.js.map +1 -0
  343. package/dist/providers/openai-codex.models.d.ts +87 -0
  344. package/dist/providers/openai-codex.models.d.ts.map +1 -0
  345. package/dist/providers/openai-codex.models.js +77 -0
  346. package/dist/providers/openai-codex.models.js.map +1 -0
  347. package/dist/providers/openai.d.ts +3 -0
  348. package/dist/providers/openai.d.ts.map +1 -0
  349. package/dist/providers/openai.js +15 -0
  350. package/dist/providers/openai.js.map +1 -0
  351. package/dist/providers/openai.models.d.ts +805 -0
  352. package/dist/providers/openai.models.d.ts.map +1 -0
  353. package/dist/providers/openai.models.js +743 -0
  354. package/dist/providers/openai.models.js.map +1 -0
  355. package/dist/providers/opencode-go.d.ts +3 -0
  356. package/dist/providers/opencode-go.d.ts.map +1 -0
  357. package/dist/providers/opencode-go.js +18 -0
  358. package/dist/providers/opencode-go.js.map +1 -0
  359. package/dist/providers/opencode-go.models.d.ts +309 -0
  360. package/dist/providers/opencode-go.models.d.ts.map +1 -0
  361. package/dist/providers/opencode-go.models.js +240 -0
  362. package/dist/providers/opencode-go.models.js.map +1 -0
  363. package/dist/providers/opencode.d.ts +3 -0
  364. package/dist/providers/opencode.d.ts.map +1 -0
  365. package/dist/providers/opencode.js +22 -0
  366. package/dist/providers/opencode.js.map +1 -0
  367. package/dist/providers/opencode.models.d.ts +976 -0
  368. package/dist/providers/opencode.models.d.ts.map +1 -0
  369. package/dist/providers/opencode.models.js +815 -0
  370. package/dist/providers/opencode.models.js.map +1 -0
  371. package/dist/providers/openrouter-images.d.ts +3 -0
  372. package/dist/providers/openrouter-images.d.ts.map +1 -0
  373. package/dist/providers/openrouter-images.js +14 -0
  374. package/dist/providers/openrouter-images.js.map +1 -0
  375. package/dist/providers/openrouter.d.ts +3 -0
  376. package/dist/providers/openrouter.d.ts.map +1 -0
  377. package/dist/providers/openrouter.js +15 -0
  378. package/dist/providers/openrouter.js.map +1 -0
  379. package/dist/providers/openrouter.models.d.ts +5405 -0
  380. package/dist/providers/openrouter.models.d.ts.map +1 -0
  381. package/dist/providers/openrouter.models.js +4635 -0
  382. package/dist/providers/openrouter.models.js.map +1 -0
  383. package/dist/providers/together.d.ts +3 -0
  384. package/dist/providers/together.d.ts.map +1 -0
  385. package/dist/providers/together.js +15 -0
  386. package/dist/providers/together.js.map +1 -0
  387. package/dist/providers/together.models.d.ts +567 -0
  388. package/dist/providers/together.models.d.ts.map +1 -0
  389. package/dist/providers/together.models.js +361 -0
  390. package/dist/providers/together.models.js.map +1 -0
  391. package/dist/providers/vercel-ai-gateway.d.ts +3 -0
  392. package/dist/providers/vercel-ai-gateway.d.ts.map +1 -0
  393. package/dist/providers/vercel-ai-gateway.js +15 -0
  394. package/dist/providers/vercel-ai-gateway.js.map +1 -0
  395. package/dist/providers/vercel-ai-gateway.models.d.ts +2938 -0
  396. package/dist/providers/vercel-ai-gateway.models.d.ts.map +1 -0
  397. package/dist/providers/vercel-ai-gateway.models.js +2897 -0
  398. package/dist/providers/vercel-ai-gateway.models.js.map +1 -0
  399. package/dist/providers/xai.d.ts +3 -0
  400. package/dist/providers/xai.d.ts.map +1 -0
  401. package/dist/providers/xai.js +15 -0
  402. package/dist/providers/xai.js.map +1 -0
  403. package/dist/providers/xai.models.d.ts +157 -0
  404. package/dist/providers/xai.models.d.ts.map +1 -0
  405. package/dist/providers/xai.models.js +131 -0
  406. package/dist/providers/xai.models.js.map +1 -0
  407. package/dist/providers/xiaomi-token-plan-ams.d.ts +3 -0
  408. package/dist/providers/xiaomi-token-plan-ams.d.ts.map +1 -0
  409. package/dist/providers/xiaomi-token-plan-ams.js +15 -0
  410. package/dist/providers/xiaomi-token-plan-ams.js.map +1 -0
  411. package/dist/providers/xiaomi-token-plan-ams.models.d.ts +108 -0
  412. package/dist/providers/xiaomi-token-plan-ams.models.d.ts.map +1 -0
  413. package/dist/providers/xiaomi-token-plan-ams.models.js +95 -0
  414. package/dist/providers/xiaomi-token-plan-ams.models.js.map +1 -0
  415. package/dist/providers/xiaomi-token-plan-cn.d.ts +3 -0
  416. package/dist/providers/xiaomi-token-plan-cn.d.ts.map +1 -0
  417. package/dist/providers/xiaomi-token-plan-cn.js +15 -0
  418. package/dist/providers/xiaomi-token-plan-cn.js.map +1 -0
  419. package/dist/providers/xiaomi-token-plan-cn.models.d.ts +108 -0
  420. package/dist/providers/xiaomi-token-plan-cn.models.d.ts.map +1 -0
  421. package/dist/providers/xiaomi-token-plan-cn.models.js +95 -0
  422. package/dist/providers/xiaomi-token-plan-cn.models.js.map +1 -0
  423. package/dist/providers/xiaomi-token-plan-sgp.d.ts +3 -0
  424. package/dist/providers/xiaomi-token-plan-sgp.d.ts.map +1 -0
  425. package/dist/providers/xiaomi-token-plan-sgp.js +15 -0
  426. package/dist/providers/xiaomi-token-plan-sgp.js.map +1 -0
  427. package/dist/providers/xiaomi-token-plan-sgp.models.d.ts +108 -0
  428. package/dist/providers/xiaomi-token-plan-sgp.models.d.ts.map +1 -0
  429. package/dist/providers/xiaomi-token-plan-sgp.models.js +95 -0
  430. package/dist/providers/xiaomi-token-plan-sgp.models.js.map +1 -0
  431. package/dist/providers/xiaomi.d.ts +3 -0
  432. package/dist/providers/xiaomi.d.ts.map +1 -0
  433. package/dist/providers/xiaomi.js +15 -0
  434. package/dist/providers/xiaomi.js.map +1 -0
  435. package/dist/providers/xiaomi.models.d.ts +129 -0
  436. package/dist/providers/xiaomi.models.d.ts.map +1 -0
  437. package/dist/providers/xiaomi.models.js +113 -0
  438. package/dist/providers/xiaomi.models.js.map +1 -0
  439. package/dist/providers/zai-coding-cn.d.ts +3 -0
  440. package/dist/providers/zai-coding-cn.d.ts.map +1 -0
  441. package/dist/providers/zai-coding-cn.js +15 -0
  442. package/dist/providers/zai-coding-cn.js.map +1 -0
  443. package/dist/providers/zai-coding-cn.models.d.ts +153 -0
  444. package/dist/providers/zai-coding-cn.models.d.ts.map +1 -0
  445. package/dist/providers/zai-coding-cn.models.js +114 -0
  446. package/dist/providers/zai-coding-cn.models.js.map +1 -0
  447. package/dist/providers/zai.d.ts +3 -0
  448. package/dist/providers/zai.d.ts.map +1 -0
  449. package/dist/providers/zai.js +15 -0
  450. package/dist/providers/zai.js.map +1 -0
  451. package/dist/providers/zai.models.d.ts +153 -0
  452. package/dist/providers/zai.models.d.ts.map +1 -0
  453. package/dist/providers/zai.models.js +114 -0
  454. package/dist/providers/zai.models.js.map +1 -0
  455. package/dist/types.d.ts +67 -8
  456. package/dist/types.d.ts.map +1 -1
  457. package/dist/types.js.map +1 -1
  458. package/dist/utils/headers.d.ts +2 -0
  459. package/dist/utils/headers.d.ts.map +1 -1
  460. package/dist/utils/headers.js +10 -0
  461. package/dist/utils/headers.js.map +1 -1
  462. package/dist/utils/oauth/anthropic.d.ts +2 -0
  463. package/dist/utils/oauth/anthropic.d.ts.map +1 -1
  464. package/dist/utils/oauth/anthropic.js +31 -0
  465. package/dist/utils/oauth/anthropic.js.map +1 -1
  466. package/dist/utils/oauth/github-copilot.d.ts +2 -0
  467. package/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  468. package/dist/utils/oauth/github-copilot.js +33 -2
  469. package/dist/utils/oauth/github-copilot.js.map +1 -1
  470. package/dist/utils/oauth/load.d.ts +5 -0
  471. package/dist/utils/oauth/load.d.ts.map +1 -0
  472. package/dist/utils/oauth/load.js +22 -0
  473. package/dist/utils/oauth/load.js.map +1 -0
  474. package/dist/utils/oauth/openai-codex.d.ts +2 -0
  475. package/dist/utils/oauth/openai-codex.d.ts.map +1 -1
  476. package/dist/utils/oauth/openai-codex.js +49 -0
  477. package/dist/utils/oauth/openai-codex.js.map +1 -1
  478. package/package.json +15 -42
  479. package/dist/api-registry.d.ts +0 -20
  480. package/dist/api-registry.d.ts.map +0 -1
  481. package/dist/api-registry.js +0 -44
  482. package/dist/api-registry.js.map +0 -1
  483. package/dist/base.d.ts +0 -30
  484. package/dist/base.d.ts.map +0 -1
  485. package/dist/base.js +0 -18
  486. package/dist/base.js.map +0 -1
  487. package/dist/providers/cloudflare.d.ts.map +0 -1
  488. package/dist/providers/cloudflare.js.map +0 -1
  489. package/dist/providers/github-copilot-headers.d.ts.map +0 -1
  490. package/dist/providers/github-copilot-headers.js.map +0 -1
  491. package/dist/providers/google-shared.d.ts.map +0 -1
  492. package/dist/providers/google-shared.js.map +0 -1
  493. package/dist/providers/images/openrouter.d.ts.map +0 -1
  494. package/dist/providers/images/openrouter.js.map +0 -1
  495. package/dist/providers/openai-codex-responses.d.ts.map +0 -1
  496. package/dist/providers/openai-codex-responses.js.map +0 -1
  497. package/dist/providers/openai-completions.d.ts.map +0 -1
  498. package/dist/providers/openai-completions.js.map +0 -1
  499. package/dist/providers/openai-prompt-cache.d.ts.map +0 -1
  500. package/dist/providers/openai-prompt-cache.js.map +0 -1
  501. package/dist/providers/openai-responses-shared.d.ts.map +0 -1
  502. package/dist/providers/openai-responses-shared.js.map +0 -1
  503. package/dist/providers/openai-responses.d.ts.map +0 -1
  504. package/dist/providers/openai-responses.js.map +0 -1
  505. package/dist/providers/register-builtins.d.ts +0 -37
  506. package/dist/providers/register-builtins.d.ts.map +0 -1
  507. package/dist/providers/register-builtins.js +0 -191
  508. package/dist/providers/register-builtins.js.map +0 -1
  509. package/dist/providers/simple-options.d.ts.map +0 -1
  510. package/dist/providers/simple-options.js.map +0 -1
  511. package/dist/providers/transform-messages.d.ts.map +0 -1
  512. package/dist/providers/transform-messages.js.map +0 -1
  513. package/dist/stream.d.ts +0 -6
  514. package/dist/stream.d.ts.map +0 -1
  515. package/dist/stream.js +0 -37
  516. package/dist/stream.js.map +0 -1
  517. /package/dist/{providers → api}/github-copilot-headers.d.ts +0 -0
  518. /package/dist/{providers → api}/github-copilot-headers.js +0 -0
  519. /package/dist/{providers → api}/google-shared.d.ts +0 -0
  520. /package/dist/{providers → api}/google-shared.js +0 -0
  521. /package/dist/{providers → api}/openai-prompt-cache.d.ts +0 -0
  522. /package/dist/{providers → api}/openai-prompt-cache.js +0 -0
  523. /package/dist/{providers → api}/openai-responses-shared.d.ts +0 -0
  524. /package/dist/{providers → api}/simple-options.d.ts +0 -0
  525. /package/dist/{providers → api}/simple-options.js +0 -0
  526. /package/dist/{providers → api}/transform-messages.d.ts +0 -0
  527. /package/dist/{providers → api}/transform-messages.js +0 -0
@@ -0,0 +1,22 @@
1
+ import type { Api, ImagesApi, ImagesModel, Model } from "../types.ts";
2
+ import type { AuthContext, AuthResult, CredentialStore, ProviderAuth } from "./types.ts";
3
+ export type ModelsErrorCode = "model_source" | "model_validation" | "provider" | "stream" | "auth" | "oauth";
4
+ export declare class ModelsError extends Error {
5
+ readonly code: ModelsErrorCode;
6
+ constructor(code: ModelsErrorCode, message: string, options?: {
7
+ cause?: unknown;
8
+ });
9
+ }
10
+ /** Model shape auth resolution receives: chat or image-generation models. */
11
+ export type AuthModel = Model<Api> | ImagesModel<ImagesApi>;
12
+ /**
13
+ * Auth resolution shared by the `Models` and `ImagesModels` collections.
14
+ * A stored credential owns the provider: ambient/env is consulted only when
15
+ * nothing is stored. No silent env fallback after a failed refresh or for a
16
+ * credential type without a matching handler.
17
+ */
18
+ export declare function resolveProviderAuth(provider: {
19
+ id: string;
20
+ auth: ProviderAuth;
21
+ }, model: AuthModel, credentials: CredentialStore, authContext: AuthContext): Promise<AuthResult | undefined>;
22
+ //# sourceMappingURL=resolve.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resolve.d.ts","sourceRoot":"","sources":["../../src/auth/resolve.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACtE,OAAO,KAAK,EAGX,WAAW,EACX,UAAU,EAEV,eAAe,EAGf,YAAY,EACZ,MAAM,YAAY,CAAC;AAEpB,MAAM,MAAM,eAAe,GAAG,cAAc,GAAG,kBAAkB,GAAG,UAAU,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAC;AAE7G,qBAAa,WAAY,SAAQ,KAAK;IACrC,QAAQ,CAAC,IAAI,EAAE,eAAe,CAAC;IAE/B,YAAY,IAAI,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,OAAO,CAAA;KAAE,EAIhF;CACD;AAED,6EAA6E;AAC7E,MAAM,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC;AAE5D;;;;;GAKG;AACH,wBAAsB,mBAAmB,CACxC,QAAQ,EAAE;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,YAAY,CAAA;CAAE,EAC5C,KAAK,EAAE,SAAS,EAChB,WAAW,EAAE,eAAe,EAC5B,WAAW,EAAE,WAAW,GACtB,OAAO,CAAC,UAAU,GAAG,SAAS,CAAC,CAcjC","sourcesContent":["import type { Api, ImagesApi, ImagesModel, Model } from \"../types.ts\";\nimport type {\n\tApiKeyAuth,\n\tApiKeyCredential,\n\tAuthContext,\n\tAuthResult,\n\tCredential,\n\tCredentialStore,\n\tOAuthAuth,\n\tOAuthCredential,\n\tProviderAuth,\n} from \"./types.ts\";\n\nexport type ModelsErrorCode = \"model_source\" | \"model_validation\" | \"provider\" | \"stream\" | \"auth\" | \"oauth\";\n\nexport class ModelsError extends Error {\n\treadonly code: ModelsErrorCode;\n\n\tconstructor(code: ModelsErrorCode, message: string, options?: { cause?: unknown }) {\n\t\tsuper(message, options);\n\t\tthis.name = \"ModelsError\";\n\t\tthis.code = code;\n\t}\n}\n\n/** Model shape auth resolution receives: chat or image-generation models. */\nexport type AuthModel = Model<Api> | ImagesModel<ImagesApi>;\n\n/**\n * Auth resolution shared by the `Models` and `ImagesModels` collections.\n * A stored credential owns the provider: ambient/env is consulted only when\n * nothing is stored. No silent env fallback after a failed refresh or for a\n * credential type without a matching handler.\n */\nexport async function resolveProviderAuth(\n\tprovider: { id: string; auth: ProviderAuth },\n\tmodel: AuthModel,\n\tcredentials: CredentialStore,\n\tauthContext: AuthContext,\n): Promise<AuthResult | undefined> {\n\tconst stored = await readCredential(credentials, provider.id);\n\tif (stored) {\n\t\tif (stored.type === \"oauth\" && provider.auth.oauth) {\n\t\t\treturn resolveStoredOAuth(credentials, provider.id, provider.auth.oauth, stored);\n\t\t}\n\t\tif (stored.type === \"api-key\" && provider.auth.apiKey) {\n\t\t\treturn resolveApiKey(authContext, provider.auth.apiKey, model, stored);\n\t\t}\n\t\treturn undefined;\n\t}\n\n\t// Ambient (env vars, AWS profiles, ADC files).\n\treturn provider.auth.apiKey ? resolveApiKey(authContext, provider.auth.apiKey, model, undefined) : undefined;\n}\n\n/**\n * OAuth resolution with double-checked locking (same pattern as today's\n * AuthStorage): valid tokens cost zero locks; expired tokens lock, re-check\n * expiry under the lock, refresh once globally, and persist the rotated\n * credential before release.\n */\nasync function resolveStoredOAuth(\n\tcredentials: CredentialStore,\n\tproviderId: string,\n\toauth: OAuthAuth,\n\tstored: OAuthCredential,\n): Promise<AuthResult | undefined> {\n\tlet credential = stored;\n\n\tif (Date.now() >= credential.expires) {\n\t\t// Optimistic check said expired; the authoritative check runs under the lock.\n\t\tlet post: Credential | undefined;\n\t\ttry {\n\t\t\tpost = await credentials.modify(providerId, async (current) => {\n\t\t\t\tif (current?.type !== \"oauth\") return undefined; // logged out meanwhile\n\t\t\t\tif (Date.now() < current.expires) return undefined; // another process/request refreshed\n\t\t\t\ttry {\n\t\t\t\t\treturn await oauth.refresh(current);\n\t\t\t\t} catch (error) {\n\t\t\t\t\tthrow new ModelsError(\"oauth\", `OAuth refresh failed for ${providerId}`, { cause: error });\n\t\t\t\t}\n\t\t\t});\n\t\t} catch (error) {\n\t\t\tif (error instanceof ModelsError) throw error;\n\t\t\tthrow new ModelsError(\"auth\", `Credential store modify failed for ${providerId}`, { cause: error });\n\t\t}\n\t\tif (post?.type !== \"oauth\") return undefined; // logged out meanwhile\n\t\tcredential = post;\n\t}\n\n\ttry {\n\t\treturn { auth: await oauth.toAuth(credential), source: \"OAuth\" };\n\t} catch (error) {\n\t\tthrow new ModelsError(\"oauth\", `OAuth auth derivation failed for ${providerId}`, { cause: error });\n\t}\n}\n\nasync function resolveApiKey(\n\tauthContext: AuthContext,\n\tapiKey: ApiKeyAuth,\n\tmodel: AuthModel,\n\tcredential: ApiKeyCredential | undefined,\n): Promise<AuthResult | undefined> {\n\ttry {\n\t\treturn await apiKey.resolve({ model, ctx: authContext, credential });\n\t} catch (error) {\n\t\tthrow new ModelsError(\"auth\", `API key auth failed for provider ${model.provider}`, { cause: error });\n\t}\n}\n\nasync function readCredential(credentials: CredentialStore, providerId: string): Promise<Credential | undefined> {\n\ttry {\n\t\treturn await credentials.read(providerId);\n\t} catch (error) {\n\t\tthrow new ModelsError(\"auth\", `Credential store read failed for ${providerId}`, { cause: error });\n\t}\n}\n"]}
@@ -0,0 +1,86 @@
1
+ export class ModelsError extends Error {
2
+ code;
3
+ constructor(code, message, options) {
4
+ super(message, options);
5
+ this.name = "ModelsError";
6
+ this.code = code;
7
+ }
8
+ }
9
+ /**
10
+ * Auth resolution shared by the `Models` and `ImagesModels` collections.
11
+ * A stored credential owns the provider: ambient/env is consulted only when
12
+ * nothing is stored. No silent env fallback after a failed refresh or for a
13
+ * credential type without a matching handler.
14
+ */
15
+ export async function resolveProviderAuth(provider, model, credentials, authContext) {
16
+ const stored = await readCredential(credentials, provider.id);
17
+ if (stored) {
18
+ if (stored.type === "oauth" && provider.auth.oauth) {
19
+ return resolveStoredOAuth(credentials, provider.id, provider.auth.oauth, stored);
20
+ }
21
+ if (stored.type === "api-key" && provider.auth.apiKey) {
22
+ return resolveApiKey(authContext, provider.auth.apiKey, model, stored);
23
+ }
24
+ return undefined;
25
+ }
26
+ // Ambient (env vars, AWS profiles, ADC files).
27
+ return provider.auth.apiKey ? resolveApiKey(authContext, provider.auth.apiKey, model, undefined) : undefined;
28
+ }
29
+ /**
30
+ * OAuth resolution with double-checked locking (same pattern as today's
31
+ * AuthStorage): valid tokens cost zero locks; expired tokens lock, re-check
32
+ * expiry under the lock, refresh once globally, and persist the rotated
33
+ * credential before release.
34
+ */
35
+ async function resolveStoredOAuth(credentials, providerId, oauth, stored) {
36
+ let credential = stored;
37
+ if (Date.now() >= credential.expires) {
38
+ // Optimistic check said expired; the authoritative check runs under the lock.
39
+ let post;
40
+ try {
41
+ post = await credentials.modify(providerId, async (current) => {
42
+ if (current?.type !== "oauth")
43
+ return undefined; // logged out meanwhile
44
+ if (Date.now() < current.expires)
45
+ return undefined; // another process/request refreshed
46
+ try {
47
+ return await oauth.refresh(current);
48
+ }
49
+ catch (error) {
50
+ throw new ModelsError("oauth", `OAuth refresh failed for ${providerId}`, { cause: error });
51
+ }
52
+ });
53
+ }
54
+ catch (error) {
55
+ if (error instanceof ModelsError)
56
+ throw error;
57
+ throw new ModelsError("auth", `Credential store modify failed for ${providerId}`, { cause: error });
58
+ }
59
+ if (post?.type !== "oauth")
60
+ return undefined; // logged out meanwhile
61
+ credential = post;
62
+ }
63
+ try {
64
+ return { auth: await oauth.toAuth(credential), source: "OAuth" };
65
+ }
66
+ catch (error) {
67
+ throw new ModelsError("oauth", `OAuth auth derivation failed for ${providerId}`, { cause: error });
68
+ }
69
+ }
70
+ async function resolveApiKey(authContext, apiKey, model, credential) {
71
+ try {
72
+ return await apiKey.resolve({ model, ctx: authContext, credential });
73
+ }
74
+ catch (error) {
75
+ throw new ModelsError("auth", `API key auth failed for provider ${model.provider}`, { cause: error });
76
+ }
77
+ }
78
+ async function readCredential(credentials, providerId) {
79
+ try {
80
+ return await credentials.read(providerId);
81
+ }
82
+ catch (error) {
83
+ throw new ModelsError("auth", `Credential store read failed for ${providerId}`, { cause: error });
84
+ }
85
+ }
86
+ //# sourceMappingURL=resolve.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resolve.js","sourceRoot":"","sources":["../../src/auth/resolve.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Api, ImagesApi, ImagesModel, Model } from \"../types.ts\";\nimport type {\n\tApiKeyAuth,\n\tApiKeyCredential,\n\tAuthContext,\n\tAuthResult,\n\tCredential,\n\tCredentialStore,\n\tOAuthAuth,\n\tOAuthCredential,\n\tProviderAuth,\n} from \"./types.ts\";\n\nexport type ModelsErrorCode = \"model_source\" | \"model_validation\" | \"provider\" | \"stream\" | \"auth\" | \"oauth\";\n\nexport class ModelsError extends Error {\n\treadonly code: ModelsErrorCode;\n\n\tconstructor(code: ModelsErrorCode, message: string, options?: { cause?: unknown }) {\n\t\tsuper(message, options);\n\t\tthis.name = \"ModelsError\";\n\t\tthis.code = code;\n\t}\n}\n\n/** Model shape auth resolution receives: chat or image-generation models. */\nexport type AuthModel = Model<Api> | ImagesModel<ImagesApi>;\n\n/**\n * Auth resolution shared by the `Models` and `ImagesModels` collections.\n * A stored credential owns the provider: ambient/env is consulted only when\n * nothing is stored. No silent env fallback after a failed refresh or for a\n * credential type without a matching handler.\n */\nexport async function resolveProviderAuth(\n\tprovider: { id: string; auth: ProviderAuth },\n\tmodel: AuthModel,\n\tcredentials: CredentialStore,\n\tauthContext: AuthContext,\n): Promise<AuthResult | undefined> {\n\tconst stored = await readCredential(credentials, provider.id);\n\tif (stored) {\n\t\tif (stored.type === \"oauth\" && provider.auth.oauth) {\n\t\t\treturn resolveStoredOAuth(credentials, provider.id, provider.auth.oauth, stored);\n\t\t}\n\t\tif (stored.type === \"api-key\" && provider.auth.apiKey) {\n\t\t\treturn resolveApiKey(authContext, provider.auth.apiKey, model, stored);\n\t\t}\n\t\treturn undefined;\n\t}\n\n\t// Ambient (env vars, AWS profiles, ADC files).\n\treturn provider.auth.apiKey ? resolveApiKey(authContext, provider.auth.apiKey, model, undefined) : undefined;\n}\n\n/**\n * OAuth resolution with double-checked locking (same pattern as today's\n * AuthStorage): valid tokens cost zero locks; expired tokens lock, re-check\n * expiry under the lock, refresh once globally, and persist the rotated\n * credential before release.\n */\nasync function resolveStoredOAuth(\n\tcredentials: CredentialStore,\n\tproviderId: string,\n\toauth: OAuthAuth,\n\tstored: OAuthCredential,\n): Promise<AuthResult | undefined> {\n\tlet credential = stored;\n\n\tif (Date.now() >= credential.expires) {\n\t\t// Optimistic check said expired; the authoritative check runs under the lock.\n\t\tlet post: Credential | undefined;\n\t\ttry {\n\t\t\tpost = await credentials.modify(providerId, async (current) => {\n\t\t\t\tif (current?.type !== \"oauth\") return undefined; // logged out meanwhile\n\t\t\t\tif (Date.now() < current.expires) return undefined; // another process/request refreshed\n\t\t\t\ttry {\n\t\t\t\t\treturn await oauth.refresh(current);\n\t\t\t\t} catch (error) {\n\t\t\t\t\tthrow new ModelsError(\"oauth\", `OAuth refresh failed for ${providerId}`, { cause: error });\n\t\t\t\t}\n\t\t\t});\n\t\t} catch (error) {\n\t\t\tif (error instanceof ModelsError) throw error;\n\t\t\tthrow new ModelsError(\"auth\", `Credential store modify failed for ${providerId}`, { cause: error });\n\t\t}\n\t\tif (post?.type !== \"oauth\") return undefined; // logged out meanwhile\n\t\tcredential = post;\n\t}\n\n\ttry {\n\t\treturn { auth: await oauth.toAuth(credential), source: \"OAuth\" };\n\t} catch (error) {\n\t\tthrow new ModelsError(\"oauth\", `OAuth auth derivation failed for ${providerId}`, { cause: error });\n\t}\n}\n\nasync function resolveApiKey(\n\tauthContext: AuthContext,\n\tapiKey: ApiKeyAuth,\n\tmodel: AuthModel,\n\tcredential: ApiKeyCredential | undefined,\n): Promise<AuthResult | undefined> {\n\ttry {\n\t\treturn await apiKey.resolve({ model, ctx: authContext, credential });\n\t} catch (error) {\n\t\tthrow new ModelsError(\"auth\", `API key auth failed for provider ${model.provider}`, { cause: error });\n\t}\n}\n\nasync function readCredential(credentials: CredentialStore, providerId: string): Promise<Credential | undefined> {\n\ttry {\n\t\treturn await credentials.read(providerId);\n\t} catch (error) {\n\t\tthrow new ModelsError(\"auth\", `Credential store read failed for ${providerId}`, { cause: error });\n\t}\n}\n"]}
@@ -0,0 +1,180 @@
1
+ import type { Api, ImagesApi, ImagesModel, Model, ProviderEnv, ProviderHeaders } from "../types.ts";
2
+ import type { OAuthCredentials } from "../utils/oauth/types.ts";
3
+ /**
4
+ * Request auth for a single model request. If a value cannot be expressed as
5
+ * `apiKey`, `headers`, or `baseUrl`, it is provider config, not auth.
6
+ */
7
+ export interface ModelAuth {
8
+ apiKey?: string;
9
+ headers?: ProviderHeaders;
10
+ baseUrl?: string;
11
+ }
12
+ /**
13
+ * Stored api-key credential. `metadata` holds non-key values such as
14
+ * Cloudflare account/gateway ids.
15
+ */
16
+ export interface ApiKeyCredential {
17
+ type: "api-key";
18
+ key?: string;
19
+ metadata?: Record<string, string>;
20
+ }
21
+ /** Stored OAuth credential (`access`, `refresh`, `expires` from OAuthCredentials). */
22
+ export interface OAuthCredential extends OAuthCredentials {
23
+ type: "oauth";
24
+ }
25
+ /** One type-tagged credential per provider — the shape of today's auth.json. */
26
+ export type Credential = ApiKeyCredential | OAuthCredential;
27
+ /**
28
+ * App-owned credential storage, keyed by `Provider.id`, one credential per
29
+ * provider. `modify` is the only write path, so every mutation is a
30
+ * serialized read-modify-write; `Models.getAuth()` runs OAuth refresh inside
31
+ * `modify` so concurrent requests cannot double-refresh a rotated token. The
32
+ * app persists a credential after login via
33
+ * `modify(provider.id, async () => credential)`. Login/logout orchestration
34
+ * is app-owned.
35
+ *
36
+ * Error semantics: `read` resolves `undefined` for missing entries. Methods
37
+ * reject only on storage failure; `Models` wraps such rejections in
38
+ * `ModelsError` with code "auth". Best-effort stores that serve an in-memory
39
+ * view and record persistence errors internally (like coding-agent's
40
+ * AuthStorage) are valid implementations.
41
+ */
42
+ export interface CredentialStore {
43
+ /**
44
+ * Read the stored credential, possibly expired. Display/status use;
45
+ * resolved request auth comes from `Models.getAuth()`.
46
+ */
47
+ read(providerId: string): Promise<Credential | undefined>;
48
+ /**
49
+ * Serialized write — the only write path. `fn` sees the current credential
50
+ * because correct writes (refresh, login-during-refresh) depend on it;
51
+ * return the new credential, or undefined to leave the entry unchanged.
52
+ * Mutual exclusion per provider id, cross-process too where the backing
53
+ * store supports it (e.g. a file lock). Resolves with the post-write
54
+ * credential. Rejections from `fn` propagate.
55
+ */
56
+ modify(providerId: string, fn: (current: Credential | undefined) => Promise<Credential | undefined>): Promise<Credential | undefined>;
57
+ /** Remove a credential (logout). Implementations serialize this against `modify`. */
58
+ delete(providerId: string): Promise<void>;
59
+ }
60
+ /** Environment access for auth resolution. Injectable for tests and browsers. */
61
+ export interface AuthContext {
62
+ env(name: string): Promise<string | undefined>;
63
+ /** Check whether a file exists. Supports a leading `~`. Always false in browsers. */
64
+ fileExists(path: string): Promise<boolean>;
65
+ }
66
+ /** Result of resolving auth for a model. */
67
+ export interface AuthResult {
68
+ auth: ModelAuth;
69
+ /** Provider-scoped environment/config values resolved from credentials and ambient context. */
70
+ env?: ProviderEnv;
71
+ /** Human-readable label for status UI: "ANTHROPIC_API_KEY", "OAuth", "~/.aws/credentials". */
72
+ source?: string;
73
+ }
74
+ /**
75
+ * Prompt shown to the user during login. `signal` lets the flow cancel a
76
+ * pending prompt when an out-of-band event resolves the step, e.g. a
77
+ * `manual_code` prompt raced against a callback server, aborted when the
78
+ * callback wins.
79
+ */
80
+ export type AuthPrompt = {
81
+ signal?: AbortSignal;
82
+ } & ({
83
+ type: "text";
84
+ message: string;
85
+ placeholder?: string;
86
+ } | {
87
+ type: "secret";
88
+ message: string;
89
+ placeholder?: string;
90
+ } | {
91
+ type: "select";
92
+ message: string;
93
+ options: readonly {
94
+ id: string;
95
+ label: string;
96
+ description?: string;
97
+ }[];
98
+ } | {
99
+ type: "manual_code";
100
+ message: string;
101
+ placeholder?: string;
102
+ });
103
+ export type AuthEvent = {
104
+ type: "auth_url";
105
+ url: string;
106
+ instructions?: string;
107
+ } | {
108
+ type: "device_code";
109
+ userCode: string;
110
+ verificationUri: string;
111
+ intervalSeconds?: number;
112
+ expiresInSeconds?: number;
113
+ } | {
114
+ type: "progress";
115
+ message: string;
116
+ };
117
+ /**
118
+ * Login interaction callbacks serving both api-key and OAuth flows.
119
+ *
120
+ * `prompt()` returns the entered/selected string (`select` returns the option
121
+ * id). Rejects on cancel/abort. `signal` aborts the whole login flow;
122
+ * per-prompt cancellation uses `AuthPrompt.signal`.
123
+ */
124
+ export interface AuthLoginCallbacks {
125
+ signal?: AbortSignal;
126
+ prompt(prompt: AuthPrompt): Promise<string>;
127
+ notify(event: AuthEvent): void;
128
+ }
129
+ /**
130
+ * Api-key auth: stored key/metadata plus ambient sources (env vars, AWS
131
+ * profiles, ADC files). Ambient-only providers omit `login`.
132
+ */
133
+ export interface ApiKeyAuth {
134
+ /** Display name, e.g. "Anthropic API key". */
135
+ name: string;
136
+ /** Interactive setup (prompt for key/metadata). Absent = ambient-only. */
137
+ login?(callbacks: AuthLoginCallbacks): Promise<ApiKeyCredential>;
138
+ /**
139
+ * Resolve auth from the stored credential and/or ambient sources, merging
140
+ * per field (`credential.key ?? env("...")`, `metadata.accountId ?? env("...")`).
141
+ * undefined = not configured. Receives the chat or image-generation model
142
+ * the request is for (both carry `provider` and `baseUrl`).
143
+ */
144
+ resolve(input: {
145
+ model: Model<Api> | ImagesModel<ImagesApi>;
146
+ ctx: AuthContext;
147
+ credential?: ApiKeyCredential;
148
+ }): Promise<AuthResult | undefined>;
149
+ }
150
+ /**
151
+ * OAuth auth. The `refresh`/`toAuth` split lets `Models` own the locked
152
+ * refresh pattern: `refresh` produces a credential, `toAuth` derives request
153
+ * auth from whatever credential ends up stored.
154
+ */
155
+ export interface OAuthAuth {
156
+ /** Display name, e.g. "Anthropic (Claude Pro/Max)". */
157
+ name: string;
158
+ login(callbacks: AuthLoginCallbacks): Promise<OAuthCredential>;
159
+ /**
160
+ * Exchange the refresh token. Network call; throws on failure
161
+ * (invalid_grant etc.). `Models` runs this under the store lock.
162
+ */
163
+ refresh(credential: OAuthCredential): Promise<OAuthCredential>;
164
+ /**
165
+ * Side-effect-free derivation of request auth from a valid credential.
166
+ * Covers per-credential baseUrl (GitHub Copilot). Async so lazy wrappers
167
+ * can load the implementation on first use.
168
+ */
169
+ toAuth(credential: OAuthCredential): Promise<ModelAuth>;
170
+ }
171
+ /**
172
+ * Provider auth. At least one of `apiKey`/`oauth` must be present: even
173
+ * ambient-credential providers and keyless local servers provide `apiKey`
174
+ * auth whose `resolve()` reports whether the provider is configured.
175
+ */
176
+ export interface ProviderAuth {
177
+ apiKey?: ApiKeyAuth;
178
+ oauth?: OAuthAuth;
179
+ }
180
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/auth/types.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Api, ImagesApi, ImagesModel, Model, ProviderEnv, ProviderHeaders } from \"../types.ts\";\nimport type { OAuthCredentials } from \"../utils/oauth/types.ts\";\n\n/**\n * Request auth for a single model request. If a value cannot be expressed as\n * `apiKey`, `headers`, or `baseUrl`, it is provider config, not auth.\n */\nexport interface ModelAuth {\n\tapiKey?: string;\n\theaders?: ProviderHeaders;\n\tbaseUrl?: string;\n}\n\n/**\n * Stored api-key credential. `metadata` holds non-key values such as\n * Cloudflare account/gateway ids.\n */\nexport interface ApiKeyCredential {\n\ttype: \"api-key\";\n\tkey?: string;\n\tmetadata?: Record<string, string>;\n}\n\n/** Stored OAuth credential (`access`, `refresh`, `expires` from OAuthCredentials). */\nexport interface OAuthCredential extends OAuthCredentials {\n\ttype: \"oauth\";\n}\n\n/** One type-tagged credential per provider — the shape of today's auth.json. */\nexport type Credential = ApiKeyCredential | OAuthCredential;\n\n/**\n * App-owned credential storage, keyed by `Provider.id`, one credential per\n * provider. `modify` is the only write path, so every mutation is a\n * serialized read-modify-write; `Models.getAuth()` runs OAuth refresh inside\n * `modify` so concurrent requests cannot double-refresh a rotated token. The\n * app persists a credential after login via\n * `modify(provider.id, async () => credential)`. Login/logout orchestration\n * is app-owned.\n *\n * Error semantics: `read` resolves `undefined` for missing entries. Methods\n * reject only on storage failure; `Models` wraps such rejections in\n * `ModelsError` with code \"auth\". Best-effort stores that serve an in-memory\n * view and record persistence errors internally (like coding-agent's\n * AuthStorage) are valid implementations.\n */\nexport interface CredentialStore {\n\t/**\n\t * Read the stored credential, possibly expired. Display/status use;\n\t * resolved request auth comes from `Models.getAuth()`.\n\t */\n\tread(providerId: string): Promise<Credential | undefined>;\n\n\t/**\n\t * Serialized write — the only write path. `fn` sees the current credential\n\t * because correct writes (refresh, login-during-refresh) depend on it;\n\t * return the new credential, or undefined to leave the entry unchanged.\n\t * Mutual exclusion per provider id, cross-process too where the backing\n\t * store supports it (e.g. a file lock). Resolves with the post-write\n\t * credential. Rejections from `fn` propagate.\n\t */\n\tmodify(\n\t\tproviderId: string,\n\t\tfn: (current: Credential | undefined) => Promise<Credential | undefined>,\n\t): Promise<Credential | undefined>;\n\n\t/** Remove a credential (logout). Implementations serialize this against `modify`. */\n\tdelete(providerId: string): Promise<void>;\n}\n\n/** Environment access for auth resolution. Injectable for tests and browsers. */\nexport interface AuthContext {\n\tenv(name: string): Promise<string | undefined>;\n\t/** Check whether a file exists. Supports a leading `~`. Always false in browsers. */\n\tfileExists(path: string): Promise<boolean>;\n}\n\n/** Result of resolving auth for a model. */\nexport interface AuthResult {\n\tauth: ModelAuth;\n\t/** Provider-scoped environment/config values resolved from credentials and ambient context. */\n\tenv?: ProviderEnv;\n\t/** Human-readable label for status UI: \"ANTHROPIC_API_KEY\", \"OAuth\", \"~/.aws/credentials\". */\n\tsource?: string;\n}\n\n/**\n * Prompt shown to the user during login. `signal` lets the flow cancel a\n * pending prompt when an out-of-band event resolves the step, e.g. a\n * `manual_code` prompt raced against a callback server, aborted when the\n * callback wins.\n */\nexport type AuthPrompt = { signal?: AbortSignal } & (\n\t| { type: \"text\"; message: string; placeholder?: string }\n\t| { type: \"secret\"; message: string; placeholder?: string }\n\t| { type: \"select\"; message: string; options: readonly { id: string; label: string; description?: string }[] }\n\t| { type: \"manual_code\"; message: string; placeholder?: string }\n);\n\nexport type AuthEvent =\n\t| { type: \"auth_url\"; url: string; instructions?: string }\n\t| {\n\t\t\ttype: \"device_code\";\n\t\t\tuserCode: string;\n\t\t\tverificationUri: string;\n\t\t\tintervalSeconds?: number;\n\t\t\texpiresInSeconds?: number;\n\t }\n\t| { type: \"progress\"; message: string };\n\n/**\n * Login interaction callbacks serving both api-key and OAuth flows.\n *\n * `prompt()` returns the entered/selected string (`select` returns the option\n * id). Rejects on cancel/abort. `signal` aborts the whole login flow;\n * per-prompt cancellation uses `AuthPrompt.signal`.\n */\nexport interface AuthLoginCallbacks {\n\tsignal?: AbortSignal;\n\n\tprompt(prompt: AuthPrompt): Promise<string>;\n\tnotify(event: AuthEvent): void;\n}\n\n/**\n * Api-key auth: stored key/metadata plus ambient sources (env vars, AWS\n * profiles, ADC files). Ambient-only providers omit `login`.\n */\nexport interface ApiKeyAuth {\n\t/** Display name, e.g. \"Anthropic API key\". */\n\tname: string;\n\n\t/** Interactive setup (prompt for key/metadata). Absent = ambient-only. */\n\tlogin?(callbacks: AuthLoginCallbacks): Promise<ApiKeyCredential>;\n\n\t/**\n\t * Resolve auth from the stored credential and/or ambient sources, merging\n\t * per field (`credential.key ?? env(\"...\")`, `metadata.accountId ?? env(\"...\")`).\n\t * undefined = not configured. Receives the chat or image-generation model\n\t * the request is for (both carry `provider` and `baseUrl`).\n\t */\n\tresolve(input: {\n\t\tmodel: Model<Api> | ImagesModel<ImagesApi>;\n\t\tctx: AuthContext;\n\t\tcredential?: ApiKeyCredential;\n\t}): Promise<AuthResult | undefined>;\n}\n\n/**\n * OAuth auth. The `refresh`/`toAuth` split lets `Models` own the locked\n * refresh pattern: `refresh` produces a credential, `toAuth` derives request\n * auth from whatever credential ends up stored.\n */\nexport interface OAuthAuth {\n\t/** Display name, e.g. \"Anthropic (Claude Pro/Max)\". */\n\tname: string;\n\n\tlogin(callbacks: AuthLoginCallbacks): Promise<OAuthCredential>;\n\n\t/**\n\t * Exchange the refresh token. Network call; throws on failure\n\t * (invalid_grant etc.). `Models` runs this under the store lock.\n\t */\n\trefresh(credential: OAuthCredential): Promise<OAuthCredential>;\n\n\t/**\n\t * Side-effect-free derivation of request auth from a valid credential.\n\t * Covers per-credential baseUrl (GitHub Copilot). Async so lazy wrappers\n\t * can load the implementation on first use.\n\t */\n\ttoAuth(credential: OAuthCredential): Promise<ModelAuth>;\n}\n\n/**\n * Provider auth. At least one of `apiKey`/`oauth` must be present: even\n * ambient-credential providers and keyless local servers provide `apiKey`\n * auth whose `resolve()` reports whether the provider is configured.\n */\nexport interface ProviderAuth {\n\tapiKey?: ApiKeyAuth;\n\toauth?: OAuthAuth;\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/auth/types.ts"],"names":[],"mappings":"","sourcesContent":["import type { Api, ImagesApi, ImagesModel, Model, ProviderEnv, ProviderHeaders } from \"../types.ts\";\nimport type { OAuthCredentials } from \"../utils/oauth/types.ts\";\n\n/**\n * Request auth for a single model request. If a value cannot be expressed as\n * `apiKey`, `headers`, or `baseUrl`, it is provider config, not auth.\n */\nexport interface ModelAuth {\n\tapiKey?: string;\n\theaders?: ProviderHeaders;\n\tbaseUrl?: string;\n}\n\n/**\n * Stored api-key credential. `metadata` holds non-key values such as\n * Cloudflare account/gateway ids.\n */\nexport interface ApiKeyCredential {\n\ttype: \"api-key\";\n\tkey?: string;\n\tmetadata?: Record<string, string>;\n}\n\n/** Stored OAuth credential (`access`, `refresh`, `expires` from OAuthCredentials). */\nexport interface OAuthCredential extends OAuthCredentials {\n\ttype: \"oauth\";\n}\n\n/** One type-tagged credential per provider — the shape of today's auth.json. */\nexport type Credential = ApiKeyCredential | OAuthCredential;\n\n/**\n * App-owned credential storage, keyed by `Provider.id`, one credential per\n * provider. `modify` is the only write path, so every mutation is a\n * serialized read-modify-write; `Models.getAuth()` runs OAuth refresh inside\n * `modify` so concurrent requests cannot double-refresh a rotated token. The\n * app persists a credential after login via\n * `modify(provider.id, async () => credential)`. Login/logout orchestration\n * is app-owned.\n *\n * Error semantics: `read` resolves `undefined` for missing entries. Methods\n * reject only on storage failure; `Models` wraps such rejections in\n * `ModelsError` with code \"auth\". Best-effort stores that serve an in-memory\n * view and record persistence errors internally (like coding-agent's\n * AuthStorage) are valid implementations.\n */\nexport interface CredentialStore {\n\t/**\n\t * Read the stored credential, possibly expired. Display/status use;\n\t * resolved request auth comes from `Models.getAuth()`.\n\t */\n\tread(providerId: string): Promise<Credential | undefined>;\n\n\t/**\n\t * Serialized write — the only write path. `fn` sees the current credential\n\t * because correct writes (refresh, login-during-refresh) depend on it;\n\t * return the new credential, or undefined to leave the entry unchanged.\n\t * Mutual exclusion per provider id, cross-process too where the backing\n\t * store supports it (e.g. a file lock). Resolves with the post-write\n\t * credential. Rejections from `fn` propagate.\n\t */\n\tmodify(\n\t\tproviderId: string,\n\t\tfn: (current: Credential | undefined) => Promise<Credential | undefined>,\n\t): Promise<Credential | undefined>;\n\n\t/** Remove a credential (logout). Implementations serialize this against `modify`. */\n\tdelete(providerId: string): Promise<void>;\n}\n\n/** Environment access for auth resolution. Injectable for tests and browsers. */\nexport interface AuthContext {\n\tenv(name: string): Promise<string | undefined>;\n\t/** Check whether a file exists. Supports a leading `~`. Always false in browsers. */\n\tfileExists(path: string): Promise<boolean>;\n}\n\n/** Result of resolving auth for a model. */\nexport interface AuthResult {\n\tauth: ModelAuth;\n\t/** Provider-scoped environment/config values resolved from credentials and ambient context. */\n\tenv?: ProviderEnv;\n\t/** Human-readable label for status UI: \"ANTHROPIC_API_KEY\", \"OAuth\", \"~/.aws/credentials\". */\n\tsource?: string;\n}\n\n/**\n * Prompt shown to the user during login. `signal` lets the flow cancel a\n * pending prompt when an out-of-band event resolves the step, e.g. a\n * `manual_code` prompt raced against a callback server, aborted when the\n * callback wins.\n */\nexport type AuthPrompt = { signal?: AbortSignal } & (\n\t| { type: \"text\"; message: string; placeholder?: string }\n\t| { type: \"secret\"; message: string; placeholder?: string }\n\t| { type: \"select\"; message: string; options: readonly { id: string; label: string; description?: string }[] }\n\t| { type: \"manual_code\"; message: string; placeholder?: string }\n);\n\nexport type AuthEvent =\n\t| { type: \"auth_url\"; url: string; instructions?: string }\n\t| {\n\t\t\ttype: \"device_code\";\n\t\t\tuserCode: string;\n\t\t\tverificationUri: string;\n\t\t\tintervalSeconds?: number;\n\t\t\texpiresInSeconds?: number;\n\t }\n\t| { type: \"progress\"; message: string };\n\n/**\n * Login interaction callbacks serving both api-key and OAuth flows.\n *\n * `prompt()` returns the entered/selected string (`select` returns the option\n * id). Rejects on cancel/abort. `signal` aborts the whole login flow;\n * per-prompt cancellation uses `AuthPrompt.signal`.\n */\nexport interface AuthLoginCallbacks {\n\tsignal?: AbortSignal;\n\n\tprompt(prompt: AuthPrompt): Promise<string>;\n\tnotify(event: AuthEvent): void;\n}\n\n/**\n * Api-key auth: stored key/metadata plus ambient sources (env vars, AWS\n * profiles, ADC files). Ambient-only providers omit `login`.\n */\nexport interface ApiKeyAuth {\n\t/** Display name, e.g. \"Anthropic API key\". */\n\tname: string;\n\n\t/** Interactive setup (prompt for key/metadata). Absent = ambient-only. */\n\tlogin?(callbacks: AuthLoginCallbacks): Promise<ApiKeyCredential>;\n\n\t/**\n\t * Resolve auth from the stored credential and/or ambient sources, merging\n\t * per field (`credential.key ?? env(\"...\")`, `metadata.accountId ?? env(\"...\")`).\n\t * undefined = not configured. Receives the chat or image-generation model\n\t * the request is for (both carry `provider` and `baseUrl`).\n\t */\n\tresolve(input: {\n\t\tmodel: Model<Api> | ImagesModel<ImagesApi>;\n\t\tctx: AuthContext;\n\t\tcredential?: ApiKeyCredential;\n\t}): Promise<AuthResult | undefined>;\n}\n\n/**\n * OAuth auth. The `refresh`/`toAuth` split lets `Models` own the locked\n * refresh pattern: `refresh` produces a credential, `toAuth` derives request\n * auth from whatever credential ends up stored.\n */\nexport interface OAuthAuth {\n\t/** Display name, e.g. \"Anthropic (Claude Pro/Max)\". */\n\tname: string;\n\n\tlogin(callbacks: AuthLoginCallbacks): Promise<OAuthCredential>;\n\n\t/**\n\t * Exchange the refresh token. Network call; throws on failure\n\t * (invalid_grant etc.). `Models` runs this under the store lock.\n\t */\n\trefresh(credential: OAuthCredential): Promise<OAuthCredential>;\n\n\t/**\n\t * Side-effect-free derivation of request auth from a valid credential.\n\t * Covers per-credential baseUrl (GitHub Copilot). Async so lazy wrappers\n\t * can load the implementation on first use.\n\t */\n\ttoAuth(credential: OAuthCredential): Promise<ModelAuth>;\n}\n\n/**\n * Provider auth. At least one of `apiKey`/`oauth` must be present: even\n * ambient-credential providers and keyless local servers provide `apiKey`\n * auth whose `resolve()` reports whether the provider is configured.\n */\nexport interface ProviderAuth {\n\tapiKey?: ApiKeyAuth;\n\toauth?: OAuthAuth;\n}\n"]}
@@ -1,7 +1,5 @@
1
- import { register } from "./providers/amazon-bedrock.ts";
2
- export { register };
3
1
  export declare const bedrockProviderModule: {
4
- streamBedrock: import("./types.ts").StreamFunction<"bedrock-converse-stream", import("./providers/amazon-bedrock.ts").BedrockOptions>;
5
- streamSimpleBedrock: import("./types.ts").StreamFunction<"bedrock-converse-stream", import("./types.ts").SimpleStreamOptions>;
2
+ stream: import("./types.ts").StreamFunction<"bedrock-converse-stream", import("./api/bedrock-converse-stream.ts").BedrockOptions>;
3
+ streamSimple: import("./types.ts").StreamFunction<"bedrock-converse-stream", import("./types.ts").SimpleStreamOptions>;
6
4
  };
7
5
  //# sourceMappingURL=bedrock-provider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"bedrock-provider.d.ts","sourceRoot":"","sources":["../src/bedrock-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAsC,MAAM,+BAA+B,CAAC;AAE7F,OAAO,EAAE,QAAQ,EAAE,CAAC;AAEpB,eAAO,MAAM,qBAAqB;;;CAGjC,CAAC","sourcesContent":["import { register, streamBedrock, streamSimpleBedrock } from \"./providers/amazon-bedrock.ts\";\n\nexport { register };\n\nexport const bedrockProviderModule = {\n\tstreamBedrock,\n\tstreamSimpleBedrock,\n};\n"]}
1
+ {"version":3,"file":"bedrock-provider.d.ts","sourceRoot":"","sources":["../src/bedrock-provider.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,qBAAqB;;;CAGjC,CAAC","sourcesContent":["import { stream, streamSimple } from \"./api/bedrock-converse-stream.ts\";\n\nexport const bedrockProviderModule = {\n\tstream,\n\tstreamSimple,\n};\n"]}
@@ -1,7 +1,6 @@
1
- import { register, streamBedrock, streamSimpleBedrock } from "./providers/amazon-bedrock.js";
2
- export { register };
1
+ import { stream, streamSimple } from "./api/bedrock-converse-stream.js";
3
2
  export const bedrockProviderModule = {
4
- streamBedrock,
5
- streamSimpleBedrock,
3
+ stream,
4
+ streamSimple,
6
5
  };
7
6
  //# sourceMappingURL=bedrock-provider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"bedrock-provider.js","sourceRoot":"","sources":["../src/bedrock-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAE7F,OAAO,EAAE,QAAQ,EAAE,CAAC;AAEpB,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACpC,aAAa;IACb,mBAAmB;CACnB,CAAC","sourcesContent":["import { register, streamBedrock, streamSimpleBedrock } from \"./providers/amazon-bedrock.ts\";\n\nexport { register };\n\nexport const bedrockProviderModule = {\n\tstreamBedrock,\n\tstreamSimpleBedrock,\n};\n"]}
1
+ {"version":3,"file":"bedrock-provider.js","sourceRoot":"","sources":["../src/bedrock-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAExE,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACpC,MAAM;IACN,YAAY;CACZ,CAAC","sourcesContent":["import { stream, streamSimple } from \"./api/bedrock-converse-stream.ts\";\n\nexport const bedrockProviderModule = {\n\tstream,\n\tstreamSimple,\n};\n"]}
@@ -0,0 +1,64 @@
1
+ /**
2
+ * Temporary compatibility entrypoint preserving the old global pi-ai API
3
+ * surface: api-dispatch `stream()`/`complete()` with env API key injection,
4
+ * the api-registry, generated catalog reads (`getModel`/`getModels`/
5
+ * `getProviders`), per-API lazy stream wrappers, and image generation.
6
+ *
7
+ * Existing apps switch imports from "@earendil-works/pi-ai" to
8
+ * "@earendil-works/pi-ai/compat" unchanged; new code uses `createModels()`
9
+ * and the provider factories. This module is deleted with the coding-agent
10
+ * ModelManager migration.
11
+ */
12
+ export * from "./api/anthropic-messages.lazy.ts";
13
+ export * from "./api/azure-openai-responses.lazy.ts";
14
+ export * from "./api/bedrock-converse-stream.lazy.ts";
15
+ export * from "./api/google-generative-ai.lazy.ts";
16
+ export * from "./api/google-vertex.lazy.ts";
17
+ export * from "./api/mistral-conversations.lazy.ts";
18
+ export * from "./api/openai-codex-responses.lazy.ts";
19
+ export * from "./api/openai-completions.lazy.ts";
20
+ export * from "./api/openai-responses.lazy.ts";
21
+ export * from "./env-api-keys.ts";
22
+ export * from "./image-models.ts";
23
+ export * from "./images.ts";
24
+ export * from "./images-api-registry.ts";
25
+ export * from "./index.ts";
26
+ export * from "./providers/images/register-builtins.ts";
27
+ import { getBuiltinModel, getBuiltinModels, getBuiltinProviders } from "./providers/all.ts";
28
+ import { type FauxProviderRegistration, type RegisterFauxProviderOptions } from "./providers/faux.ts";
29
+ import type { Api, AssistantMessage, AssistantMessageEventStream, Context, Model, ProviderStreamOptions, SimpleStreamOptions, StreamFunction, StreamOptions } from "./types.ts";
30
+ /** @deprecated Static catalog read. Use `getBuiltinModel` from "@earendil-works/pi-ai/providers/all" or `Models.getModel()`. */
31
+ export declare const getModel: typeof getBuiltinModel;
32
+ /** @deprecated Static catalog read. Use `getBuiltinModels` from "@earendil-works/pi-ai/providers/all" or `Models.getModels()`. */
33
+ export declare const getModels: typeof getBuiltinModels;
34
+ /** @deprecated Static catalog read. Use `getBuiltinProviders` from "@earendil-works/pi-ai/providers/all" or `Models.getProviders()`. */
35
+ export declare const getProviders: typeof getBuiltinProviders;
36
+ export type ApiStreamFunction = (model: Model<Api>, context: Context, options?: StreamOptions) => AssistantMessageEventStream;
37
+ export type ApiStreamSimpleFunction = (model: Model<Api>, context: Context, options?: SimpleStreamOptions) => AssistantMessageEventStream;
38
+ export interface ApiProvider<TApi extends Api = Api, TOptions extends StreamOptions = StreamOptions> {
39
+ api: TApi;
40
+ stream: StreamFunction<TApi, TOptions>;
41
+ streamSimple: StreamFunction<TApi, SimpleStreamOptions>;
42
+ }
43
+ interface ApiProviderInternal {
44
+ api: Api;
45
+ stream: ApiStreamFunction;
46
+ streamSimple: ApiStreamSimpleFunction;
47
+ }
48
+ export declare function registerApiProvider<TApi extends Api, TOptions extends StreamOptions>(provider: ApiProvider<TApi, TOptions>, sourceId?: string): void;
49
+ export declare function getApiProvider(api: Api): ApiProviderInternal | undefined;
50
+ export declare function getApiProviders(): ApiProviderInternal[];
51
+ export declare function unregisterApiProviders(sourceId: string): void;
52
+ export declare function registerFauxProvider(options?: RegisterFauxProviderOptions): FauxProviderRegistration;
53
+ /**
54
+ * Registers the builtin API implementations into the api-registry without
55
+ * clobbering existing entries: compat may load after a test or extension has
56
+ * already registered an override for a builtin api id.
57
+ */
58
+ export declare function registerBuiltInApiProviders(): void;
59
+ export declare function resetApiProviders(): void;
60
+ export declare function stream<TApi extends Api>(model: Model<TApi>, context: Context, options?: ProviderStreamOptions): AssistantMessageEventStream;
61
+ export declare function complete<TApi extends Api>(model: Model<TApi>, context: Context, options?: ProviderStreamOptions): Promise<AssistantMessage>;
62
+ export declare function streamSimple<TApi extends Api>(model: Model<TApi>, context: Context, options?: SimpleStreamOptions): AssistantMessageEventStream;
63
+ export declare function completeSimple<TApi extends Api>(model: Model<TApi>, context: Context, options?: SimpleStreamOptions): Promise<AssistantMessage>;
64
+ //# sourceMappingURL=compat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compat.d.ts","sourceRoot":"","sources":["../src/compat.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Temporary compatibility entrypoint preserving the old global pi-ai API\n * surface: api-dispatch `stream()`/`complete()` with env API key injection,\n * the api-registry, generated catalog reads (`getModel`/`getModels`/\n * `getProviders`), per-API lazy stream wrappers, and image generation.\n *\n * Existing apps switch imports from \"@earendil-works/pi-ai\" to\n * \"@earendil-works/pi-ai/compat\" unchanged; new code uses `createModels()`\n * and the provider factories. This module is deleted with the coding-agent\n * ModelManager migration.\n */\n\nexport * from \"./api/anthropic-messages.lazy.ts\";\nexport * from \"./api/azure-openai-responses.lazy.ts\";\nexport * from \"./api/bedrock-converse-stream.lazy.ts\";\nexport * from \"./api/google-generative-ai.lazy.ts\";\nexport * from \"./api/google-vertex.lazy.ts\";\nexport * from \"./api/mistral-conversations.lazy.ts\";\nexport * from \"./api/openai-codex-responses.lazy.ts\";\nexport * from \"./api/openai-completions.lazy.ts\";\nexport * from \"./api/openai-responses.lazy.ts\";\nexport * from \"./env-api-keys.ts\";\nexport * from \"./image-models.ts\";\nexport * from \"./images.ts\";\nexport * from \"./images-api-registry.ts\";\nexport * from \"./index.ts\";\nexport * from \"./providers/images/register-builtins.ts\";\n\nimport { anthropicMessagesApi } from \"./api/anthropic-messages.lazy.ts\";\nimport { azureOpenAIResponsesApi } from \"./api/azure-openai-responses.lazy.ts\";\nimport { bedrockConverseStreamApi } from \"./api/bedrock-converse-stream.lazy.ts\";\nimport { googleGenerativeAIApi } from \"./api/google-generative-ai.lazy.ts\";\nimport { googleVertexApi } from \"./api/google-vertex.lazy.ts\";\nimport { mistralConversationsApi } from \"./api/mistral-conversations.lazy.ts\";\nimport { openAICodexResponsesApi } from \"./api/openai-codex-responses.lazy.ts\";\nimport { openAICompletionsApi } from \"./api/openai-completions.lazy.ts\";\nimport { openAIResponsesApi } from \"./api/openai-responses.lazy.ts\";\nimport { getEnvApiKey } from \"./env-api-keys.ts\";\nimport { builtinModels, getBuiltinModel, getBuiltinModels, getBuiltinProviders } from \"./providers/all.ts\";\nimport { createFauxCore, type FauxProviderRegistration, type RegisterFauxProviderOptions } from \"./providers/faux.ts\";\nimport type {\n\tApi,\n\tApiStreamOptions,\n\tAssistantMessage,\n\tAssistantMessageEventStream,\n\tContext,\n\tModel,\n\tProviderStreamOptions,\n\tProviderStreams,\n\tSimpleStreamOptions,\n\tStreamFunction,\n\tStreamOptions,\n} from \"./types.ts\";\n\n/** @deprecated Static catalog read. Use `getBuiltinModel` from \"@earendil-works/pi-ai/providers/all\" or `Models.getModel()`. */\nexport const getModel = getBuiltinModel;\n\n/** @deprecated Static catalog read. Use `getBuiltinModels` from \"@earendil-works/pi-ai/providers/all\" or `Models.getModels()`. */\nexport const getModels = getBuiltinModels;\n\n/** @deprecated Static catalog read. Use `getBuiltinProviders` from \"@earendil-works/pi-ai/providers/all\" or `Models.getProviders()`. */\nexport const getProviders = getBuiltinProviders;\n\nexport type ApiStreamFunction = (\n\tmodel: Model<Api>,\n\tcontext: Context,\n\toptions?: StreamOptions,\n) => AssistantMessageEventStream;\n\nexport type ApiStreamSimpleFunction = (\n\tmodel: Model<Api>,\n\tcontext: Context,\n\toptions?: SimpleStreamOptions,\n) => AssistantMessageEventStream;\n\nexport interface ApiProvider<TApi extends Api = Api, TOptions extends StreamOptions = StreamOptions> {\n\tapi: TApi;\n\tstream: StreamFunction<TApi, TOptions>;\n\tstreamSimple: StreamFunction<TApi, SimpleStreamOptions>;\n}\n\ninterface ApiProviderInternal {\n\tapi: Api;\n\tstream: ApiStreamFunction;\n\tstreamSimple: ApiStreamSimpleFunction;\n}\n\ntype RegisteredApiProvider = {\n\tprovider: ApiProviderInternal;\n\tsourceId?: string;\n};\n\nconst apiProviderRegistry = new Map<string, RegisteredApiProvider>();\n\nfunction wrapStream<TApi extends Api, TOptions extends StreamOptions>(\n\tapi: TApi,\n\tstream: StreamFunction<TApi, TOptions>,\n): ApiStreamFunction {\n\treturn (model, context, options) => {\n\t\tif (model.api !== api) {\n\t\t\tthrow new Error(`Mismatched api: ${model.api} expected ${api}`);\n\t\t}\n\t\treturn stream(model as Model<TApi>, context, options as TOptions);\n\t};\n}\n\nfunction wrapStreamSimple<TApi extends Api>(\n\tapi: TApi,\n\tstreamSimple: StreamFunction<TApi, SimpleStreamOptions>,\n): ApiStreamSimpleFunction {\n\treturn (model, context, options) => {\n\t\tif (model.api !== api) {\n\t\t\tthrow new Error(`Mismatched api: ${model.api} expected ${api}`);\n\t\t}\n\t\treturn streamSimple(model as Model<TApi>, context, options);\n\t};\n}\n\nexport function registerApiProvider<TApi extends Api, TOptions extends StreamOptions>(\n\tprovider: ApiProvider<TApi, TOptions>,\n\tsourceId?: string,\n): void {\n\tapiProviderRegistry.set(provider.api, {\n\t\tprovider: {\n\t\t\tapi: provider.api,\n\t\t\tstream: wrapStream(provider.api, provider.stream),\n\t\t\tstreamSimple: wrapStreamSimple(provider.api, provider.streamSimple),\n\t\t},\n\t\tsourceId,\n\t});\n}\n\nexport function getApiProvider(api: Api): ApiProviderInternal | undefined {\n\treturn apiProviderRegistry.get(api)?.provider;\n}\n\nexport function getApiProviders(): ApiProviderInternal[] {\n\treturn Array.from(apiProviderRegistry.values(), (entry) => entry.provider);\n}\n\nexport function unregisterApiProviders(sourceId: string): void {\n\tfor (const [api, entry] of apiProviderRegistry.entries()) {\n\t\tif (entry.sourceId === sourceId) {\n\t\t\tapiProviderRegistry.delete(api);\n\t\t}\n\t}\n}\n\nfunction clearApiProviders(): void {\n\tapiProviderRegistry.clear();\n}\n\nexport function registerFauxProvider(options: RegisterFauxProviderOptions = {}): FauxProviderRegistration {\n\tconst core = createFauxCore(options);\n\tconst sourceId = `faux-provider-${Math.random().toString(36).slice(2, 10)}`;\n\tregisterApiProvider({ api: core.api, stream: core.stream, streamSimple: core.streamSimple }, sourceId);\n\treturn {\n\t\tapi: core.api,\n\t\tmodels: core.models,\n\t\tgetModel: core.getModel,\n\t\tstate: core.state,\n\t\tsetResponses: core.setResponses,\n\t\tappendResponses: core.appendResponses,\n\t\tgetPendingResponseCount: core.getPendingResponseCount,\n\t\tunregister() {\n\t\t\tunregisterApiProviders(sourceId);\n\t\t},\n\t};\n}\n\nconst BUILTIN_APIS: [Api, ProviderStreams][] = [\n\t[\"anthropic-messages\", anthropicMessagesApi()],\n\t[\"openai-completions\", openAICompletionsApi()],\n\t[\"openai-responses\", openAIResponsesApi()],\n\t[\"openai-codex-responses\", openAICodexResponsesApi()],\n\t[\"azure-openai-responses\", azureOpenAIResponsesApi()],\n\t[\"google-generative-ai\", googleGenerativeAIApi()],\n\t[\"google-vertex\", googleVertexApi()],\n\t[\"mistral-conversations\", mistralConversationsApi()],\n\t[\"bedrock-converse-stream\", bedrockConverseStreamApi()],\n];\n\nconst builtinApiProviderInstances = new Map<Api, ReturnType<typeof getApiProvider>>();\n\n/**\n * Registers the builtin API implementations into the api-registry without\n * clobbering existing entries: compat may load after a test or extension has\n * already registered an override for a builtin api id.\n */\nexport function registerBuiltInApiProviders(): void {\n\tfor (const [api, streams] of BUILTIN_APIS) {\n\t\tif (!getApiProvider(api)) {\n\t\t\tregisterApiProvider({ api, stream: streams.stream, streamSimple: streams.streamSimple });\n\t\t}\n\t\tbuiltinApiProviderInstances.set(api, getApiProvider(api));\n\t}\n}\n\nexport function resetApiProviders(): void {\n\tclearApiProviders();\n\tbuiltinApiProviderInstances.clear();\n\tregisterBuiltInApiProviders();\n}\n\nregisterBuiltInApiProviders();\n\nconst compatModels = builtinModels();\n\nfunction hasExplicitApiKey(apiKey: string | undefined): apiKey is string {\n\treturn typeof apiKey === \"string\" && apiKey.trim().length > 0;\n}\n\nfunction withEnvApiKey<TOptions extends StreamOptions>(\n\tmodel: Model<Api>,\n\toptions: TOptions | undefined,\n): TOptions | undefined {\n\tif (hasExplicitApiKey(options?.apiKey)) return options;\n\tconst apiKey = getEnvApiKey(model.provider, options?.env);\n\tif (!apiKey) return options;\n\treturn { ...options, apiKey } as TOptions;\n}\n\nfunction shouldUseBuiltinModels(model: Model<Api>): boolean {\n\tconst builtin = compatModels.getModel(model.provider, model.id);\n\treturn builtin?.api === model.api && getApiProvider(model.api) === builtinApiProviderInstances.get(model.api);\n}\n\nfunction resolveApiProvider(api: Api) {\n\tconst provider = getApiProvider(api);\n\tif (!provider) {\n\t\tthrow new Error(`No API provider registered for api: ${api}`);\n\t}\n\treturn provider;\n}\n\nexport function stream<TApi extends Api>(\n\tmodel: Model<TApi>,\n\tcontext: Context,\n\toptions?: ProviderStreamOptions,\n): AssistantMessageEventStream {\n\tif (shouldUseBuiltinModels(model)) {\n\t\treturn compatModels.stream(model, context, options as ApiStreamOptions<TApi> | undefined);\n\t}\n\tconst provider = resolveApiProvider(model.api);\n\treturn provider.stream(model, context, withEnvApiKey(model, options) as StreamOptions);\n}\n\nexport async function complete<TApi extends Api>(\n\tmodel: Model<TApi>,\n\tcontext: Context,\n\toptions?: ProviderStreamOptions,\n): Promise<AssistantMessage> {\n\tconst s = stream(model, context, options);\n\treturn s.result();\n}\n\nexport function streamSimple<TApi extends Api>(\n\tmodel: Model<TApi>,\n\tcontext: Context,\n\toptions?: SimpleStreamOptions,\n): AssistantMessageEventStream {\n\tif (shouldUseBuiltinModels(model)) {\n\t\treturn compatModels.streamSimple(model, context, options);\n\t}\n\tconst provider = resolveApiProvider(model.api);\n\treturn provider.streamSimple(model, context, withEnvApiKey(model, options));\n}\n\nexport async function completeSimple<TApi extends Api>(\n\tmodel: Model<TApi>,\n\tcontext: Context,\n\toptions?: SimpleStreamOptions,\n): Promise<AssistantMessage> {\n\tconst s = streamSimple(model, context, options);\n\treturn s.result();\n}\n"]}