gsd-pi 2.74.0-dev.b741afb → 2.74.0-dev.ffbcc03

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 (403) hide show
  1. package/dist/resources/extensions/gsd/activity-log.js +16 -0
  2. package/dist/resources/extensions/gsd/auto/loop.js +147 -10
  3. package/dist/resources/extensions/gsd/auto/phases.js +113 -3
  4. package/dist/resources/extensions/gsd/auto/session.js +10 -0
  5. package/dist/resources/extensions/gsd/auto-dispatch.js +11 -1
  6. package/dist/resources/extensions/gsd/auto-model-selection.js +51 -5
  7. package/dist/resources/extensions/gsd/auto-post-unit.js +215 -8
  8. package/dist/resources/extensions/gsd/auto-recovery.js +24 -10
  9. package/dist/resources/extensions/gsd/auto-unit-closeout.js +18 -0
  10. package/dist/resources/extensions/gsd/auto-verification.js +100 -2
  11. package/dist/resources/extensions/gsd/auto.js +28 -2
  12. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +10 -1
  13. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +61 -9
  14. package/dist/resources/extensions/gsd/cache.js +16 -5
  15. package/dist/resources/extensions/gsd/commands/handlers/ops.js +5 -0
  16. package/dist/resources/extensions/gsd/commands-extract-learnings.js +225 -0
  17. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +1 -1
  18. package/dist/resources/extensions/gsd/docs/preferences-reference.md +14 -1
  19. package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +144 -0
  20. package/dist/resources/extensions/gsd/ecosystem/loader.js +145 -0
  21. package/dist/resources/extensions/gsd/git-service.js +49 -1
  22. package/dist/resources/extensions/gsd/graph-context.js +98 -7
  23. package/dist/resources/extensions/gsd/gsd-db.js +260 -2
  24. package/dist/resources/extensions/gsd/guided-flow.js +24 -1
  25. package/dist/resources/extensions/gsd/init-wizard.js +1 -0
  26. package/dist/resources/extensions/gsd/journal.js +27 -0
  27. package/dist/resources/extensions/gsd/metrics.js +19 -0
  28. package/dist/resources/extensions/gsd/parallel-orchestrator.js +33 -1
  29. package/dist/resources/extensions/gsd/preferences-models.js +20 -3
  30. package/dist/resources/extensions/gsd/preferences-types.js +1 -0
  31. package/dist/resources/extensions/gsd/preferences-validation.js +108 -2
  32. package/dist/resources/extensions/gsd/preferences.js +26 -0
  33. package/dist/resources/extensions/gsd/safety/evidence-collector.js +15 -30
  34. package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +12 -2
  35. package/dist/resources/extensions/gsd/templates/PREFERENCES.md +18 -0
  36. package/dist/resources/extensions/gsd/tools/complete-slice.js +5 -0
  37. package/dist/resources/extensions/gsd/tools/validate-milestone.js +39 -4
  38. package/dist/resources/extensions/gsd/unit-ownership.js +1 -1
  39. package/dist/resources/extensions/gsd/uok/audit-toggle.js +7 -0
  40. package/dist/resources/extensions/gsd/uok/audit.js +40 -0
  41. package/dist/resources/extensions/gsd/uok/contracts.js +1 -0
  42. package/dist/resources/extensions/gsd/uok/execution-graph.js +179 -0
  43. package/dist/resources/extensions/gsd/uok/flags.js +29 -0
  44. package/dist/resources/extensions/gsd/uok/gate-runner.js +109 -0
  45. package/dist/resources/extensions/gsd/uok/gitops.js +53 -0
  46. package/dist/resources/extensions/gsd/uok/kernel.js +80 -0
  47. package/dist/resources/extensions/gsd/uok/loop-adapter.js +133 -0
  48. package/dist/resources/extensions/gsd/uok/model-policy.js +66 -0
  49. package/dist/resources/extensions/gsd/uok/plan-v2.js +132 -0
  50. package/dist/resources/extensions/gsd/workflow-logger.js +22 -0
  51. package/dist/resources/extensions/ttsr/ttsr-manager.js +3 -1
  52. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  53. package/dist/web/standalone/.next/BUILD_ID +1 -1
  54. package/dist/web/standalone/.next/app-path-routes-manifest.json +9 -9
  55. package/dist/web/standalone/.next/build-manifest.json +2 -2
  56. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  57. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  58. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  59. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  60. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  61. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  62. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  63. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  64. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  65. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  66. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  67. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  68. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  69. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  70. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  71. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  72. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  73. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  74. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
  75. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +1 -1
  76. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
  77. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +1 -1
  78. package/dist/web/standalone/.next/server/app/index.html +1 -1
  79. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  80. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  81. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  82. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  83. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  84. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  85. package/dist/web/standalone/.next/server/app-paths-manifest.json +9 -9
  86. package/dist/web/standalone/.next/server/chunks/6897.js +3 -3
  87. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  88. package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
  89. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  90. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  91. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  92. package/package.json +1 -1
  93. package/packages/mcp-server/dist/readers/graph.d.ts +1 -1
  94. package/packages/mcp-server/dist/readers/graph.d.ts.map +1 -1
  95. package/packages/mcp-server/dist/readers/graph.js +107 -0
  96. package/packages/mcp-server/dist/readers/graph.js.map +1 -1
  97. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  98. package/packages/mcp-server/dist/workflow-tools.js +88 -6
  99. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  100. package/packages/mcp-server/src/readers/graph.test.ts +178 -0
  101. package/packages/mcp-server/src/readers/graph.ts +148 -1
  102. package/packages/mcp-server/src/workflow-tools.ts +95 -10
  103. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  104. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
  105. package/packages/pi-ai/dist/index.d.ts +1 -9
  106. package/packages/pi-ai/dist/index.d.ts.map +1 -1
  107. package/packages/pi-ai/dist/index.js +1 -9
  108. package/packages/pi-ai/dist/index.js.map +1 -1
  109. package/packages/pi-ai/dist/models/capability-patches.d.ts +19 -0
  110. package/packages/pi-ai/dist/models/capability-patches.d.ts.map +1 -0
  111. package/packages/pi-ai/dist/models/capability-patches.js +36 -0
  112. package/packages/pi-ai/dist/models/capability-patches.js.map +1 -0
  113. package/packages/pi-ai/dist/{models.custom.d.ts → models/custom.d.ts} +1 -1
  114. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -0
  115. package/packages/pi-ai/dist/{models.custom.js → models/custom.js} +4 -4
  116. package/packages/pi-ai/dist/models/custom.js.map +1 -0
  117. package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts +1482 -0
  118. package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts.map +1 -0
  119. package/packages/pi-ai/dist/models/generated/amazon-bedrock.js +1484 -0
  120. package/packages/pi-ai/dist/models/generated/amazon-bedrock.js.map +1 -0
  121. package/packages/pi-ai/dist/models/generated/anthropic.d.ts +377 -0
  122. package/packages/pi-ai/dist/models/generated/anthropic.d.ts.map +1 -0
  123. package/packages/pi-ai/dist/models/generated/anthropic.js +379 -0
  124. package/packages/pi-ai/dist/models/generated/anthropic.js.map +1 -0
  125. package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts +700 -0
  126. package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts.map +1 -0
  127. package/packages/pi-ai/dist/models/generated/azure-openai-responses.js +702 -0
  128. package/packages/pi-ai/dist/models/generated/azure-openai-responses.js.map +1 -0
  129. package/packages/pi-ai/dist/models/generated/cerebras.d.ts +71 -0
  130. package/packages/pi-ai/dist/models/generated/cerebras.d.ts.map +1 -0
  131. package/packages/pi-ai/dist/models/generated/cerebras.js +73 -0
  132. package/packages/pi-ai/dist/models/generated/cerebras.js.map +1 -0
  133. package/packages/pi-ai/dist/models/generated/github-copilot.d.ts +590 -0
  134. package/packages/pi-ai/dist/models/generated/github-copilot.d.ts.map +1 -0
  135. package/packages/pi-ai/dist/models/generated/github-copilot.js +444 -0
  136. package/packages/pi-ai/dist/models/generated/github-copilot.js.map +1 -0
  137. package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts +156 -0
  138. package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts.map +1 -0
  139. package/packages/pi-ai/dist/models/generated/google-antigravity.js +158 -0
  140. package/packages/pi-ai/dist/models/generated/google-antigravity.js.map +1 -0
  141. package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts +105 -0
  142. package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts.map +1 -0
  143. package/packages/pi-ai/dist/models/generated/google-gemini-cli.js +107 -0
  144. package/packages/pi-ai/dist/models/generated/google-gemini-cli.js.map +1 -0
  145. package/packages/pi-ai/dist/models/generated/google-vertex.d.ts +207 -0
  146. package/packages/pi-ai/dist/models/generated/google-vertex.d.ts.map +1 -0
  147. package/packages/pi-ai/dist/models/generated/google-vertex.js +209 -0
  148. package/packages/pi-ai/dist/models/generated/google-vertex.js.map +1 -0
  149. package/packages/pi-ai/dist/models/generated/google.d.ts +462 -0
  150. package/packages/pi-ai/dist/models/generated/google.d.ts.map +1 -0
  151. package/packages/pi-ai/dist/models/generated/google.js +464 -0
  152. package/packages/pi-ai/dist/models/generated/google.js.map +1 -0
  153. package/packages/pi-ai/dist/models/generated/groq.d.ts +309 -0
  154. package/packages/pi-ai/dist/models/generated/groq.d.ts.map +1 -0
  155. package/packages/pi-ai/dist/models/generated/groq.js +311 -0
  156. package/packages/pi-ai/dist/models/generated/groq.js.map +1 -0
  157. package/packages/pi-ai/dist/models/generated/huggingface.d.ts +383 -0
  158. package/packages/pi-ai/dist/models/generated/huggingface.d.ts.map +1 -0
  159. package/packages/pi-ai/dist/models/generated/huggingface.js +347 -0
  160. package/packages/pi-ai/dist/models/generated/huggingface.js.map +1 -0
  161. package/packages/pi-ai/dist/{models.generated.d.ts → models/generated/index.d.ts} +1 -1
  162. package/packages/pi-ai/dist/{models.generated.d.ts.map → models/generated/index.d.ts.map} +1 -1
  163. package/packages/pi-ai/dist/models/generated/index.js +51 -0
  164. package/packages/pi-ai/dist/models/generated/index.js.map +1 -0
  165. package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts +37 -0
  166. package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts.map +1 -0
  167. package/packages/pi-ai/dist/models/generated/kimi-coding.js +39 -0
  168. package/packages/pi-ai/dist/models/generated/kimi-coding.js.map +1 -0
  169. package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts +105 -0
  170. package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts.map +1 -0
  171. package/packages/pi-ai/dist/models/generated/minimax-cn.js +107 -0
  172. package/packages/pi-ai/dist/models/generated/minimax-cn.js.map +1 -0
  173. package/packages/pi-ai/dist/models/generated/minimax.d.ts +105 -0
  174. package/packages/pi-ai/dist/models/generated/minimax.d.ts.map +1 -0
  175. package/packages/pi-ai/dist/models/generated/minimax.js +107 -0
  176. package/packages/pi-ai/dist/models/generated/minimax.js.map +1 -0
  177. package/packages/pi-ai/dist/models/generated/mistral.d.ts +445 -0
  178. package/packages/pi-ai/dist/models/generated/mistral.d.ts.map +1 -0
  179. package/packages/pi-ai/dist/models/generated/mistral.js +447 -0
  180. package/packages/pi-ai/dist/models/generated/mistral.js.map +1 -0
  181. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts +139 -0
  182. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts.map +1 -0
  183. package/packages/pi-ai/dist/models/generated/openai-codex.js +141 -0
  184. package/packages/pi-ai/dist/models/generated/openai-codex.js.map +1 -0
  185. package/packages/pi-ai/dist/models/generated/openai.d.ts +700 -0
  186. package/packages/pi-ai/dist/models/generated/openai.d.ts.map +1 -0
  187. package/packages/pi-ai/dist/models/generated/openai.js +702 -0
  188. package/packages/pi-ai/dist/models/generated/openai.js.map +1 -0
  189. package/packages/pi-ai/dist/models/generated/opencode-go.d.ts +122 -0
  190. package/packages/pi-ai/dist/models/generated/opencode-go.d.ts.map +1 -0
  191. package/packages/pi-ai/dist/models/generated/opencode-go.js +124 -0
  192. package/packages/pi-ai/dist/models/generated/opencode-go.js.map +1 -0
  193. package/packages/pi-ai/dist/models/generated/opencode.d.ts +530 -0
  194. package/packages/pi-ai/dist/models/generated/opencode.d.ts.map +1 -0
  195. package/packages/pi-ai/dist/models/generated/opencode.js +532 -0
  196. package/packages/pi-ai/dist/models/generated/opencode.js.map +1 -0
  197. package/packages/pi-ai/dist/models/generated/openrouter.d.ts +4270 -0
  198. package/packages/pi-ai/dist/models/generated/openrouter.d.ts.map +1 -0
  199. package/packages/pi-ai/dist/models/generated/openrouter.js +4272 -0
  200. package/packages/pi-ai/dist/models/generated/openrouter.js.map +1 -0
  201. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts +2604 -0
  202. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts.map +1 -0
  203. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js +2606 -0
  204. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js.map +1 -0
  205. package/packages/pi-ai/dist/models/generated/xai.d.ts +411 -0
  206. package/packages/pi-ai/dist/models/generated/xai.d.ts.map +1 -0
  207. package/packages/pi-ai/dist/models/generated/xai.js +413 -0
  208. package/packages/pi-ai/dist/models/generated/xai.js.map +1 -0
  209. package/packages/pi-ai/dist/models/generated/zai.d.ts +276 -0
  210. package/packages/pi-ai/dist/models/generated/zai.d.ts.map +1 -0
  211. package/packages/pi-ai/dist/models/generated/zai.js +239 -0
  212. package/packages/pi-ai/dist/models/generated/zai.js.map +1 -0
  213. package/packages/pi-ai/dist/models/index.d.ts +27 -0
  214. package/packages/pi-ai/dist/models/index.d.ts.map +1 -0
  215. package/packages/pi-ai/dist/models/index.js +80 -0
  216. package/packages/pi-ai/dist/models/index.js.map +1 -0
  217. package/packages/pi-ai/dist/models.d.ts +1 -36
  218. package/packages/pi-ai/dist/models.d.ts.map +1 -1
  219. package/packages/pi-ai/dist/models.generated.test.js +1 -2
  220. package/packages/pi-ai/dist/models.generated.test.js.map +1 -1
  221. package/packages/pi-ai/dist/models.js +3 -112
  222. package/packages/pi-ai/dist/models.js.map +1 -1
  223. package/packages/pi-ai/dist/models.test.js +6 -5
  224. package/packages/pi-ai/dist/models.test.js.map +1 -1
  225. package/packages/pi-ai/scripts/generate-models.ts +74 -40
  226. package/packages/pi-ai/src/index.ts +1 -9
  227. package/packages/pi-ai/src/models/capability-patches.ts +40 -0
  228. package/packages/pi-ai/src/{models.custom.ts → models/custom.ts} +4 -4
  229. package/packages/pi-ai/src/models/generated/amazon-bedrock.ts +1486 -0
  230. package/packages/pi-ai/src/models/generated/anthropic.ts +381 -0
  231. package/packages/pi-ai/src/models/generated/azure-openai-responses.ts +704 -0
  232. package/packages/pi-ai/src/models/generated/cerebras.ts +75 -0
  233. package/packages/pi-ai/src/models/generated/github-copilot.ts +446 -0
  234. package/packages/pi-ai/src/models/generated/google-antigravity.ts +160 -0
  235. package/packages/pi-ai/src/models/generated/google-gemini-cli.ts +109 -0
  236. package/packages/pi-ai/src/models/generated/google-vertex.ts +211 -0
  237. package/packages/pi-ai/src/models/generated/google.ts +466 -0
  238. package/packages/pi-ai/src/models/generated/groq.ts +313 -0
  239. package/packages/pi-ai/src/models/generated/huggingface.ts +349 -0
  240. package/packages/pi-ai/src/models/generated/index.ts +52 -0
  241. package/packages/pi-ai/src/models/generated/kimi-coding.ts +41 -0
  242. package/packages/pi-ai/src/models/generated/minimax-cn.ts +109 -0
  243. package/packages/pi-ai/src/models/generated/minimax.ts +109 -0
  244. package/packages/pi-ai/src/models/generated/mistral.ts +449 -0
  245. package/packages/pi-ai/src/models/generated/openai-codex.ts +143 -0
  246. package/packages/pi-ai/src/models/generated/openai.ts +704 -0
  247. package/packages/pi-ai/src/models/generated/opencode-go.ts +126 -0
  248. package/packages/pi-ai/src/models/generated/opencode.ts +534 -0
  249. package/packages/pi-ai/src/models/generated/openrouter.ts +4274 -0
  250. package/packages/pi-ai/src/models/generated/vercel-ai-gateway.ts +2608 -0
  251. package/packages/pi-ai/src/models/generated/xai.ts +415 -0
  252. package/packages/pi-ai/src/models/generated/zai.ts +241 -0
  253. package/packages/pi-ai/src/models/index.ts +106 -0
  254. package/packages/pi-ai/src/models.generated.test.ts +1 -2
  255. package/packages/pi-ai/src/models.test.ts +6 -5
  256. package/packages/pi-ai/src/models.ts +3 -153
  257. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  258. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  259. package/packages/pi-coding-agent/dist/core/agent-session.js +8 -2
  260. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  261. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +472 -0
  262. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
  263. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts +2 -0
  264. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts.map +1 -0
  265. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js +52 -0
  266. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js.map +1 -0
  267. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  268. package/packages/pi-coding-agent/dist/core/model-registry.js +2 -2
  269. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  270. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +11 -0
  271. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
  272. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts +1 -0
  273. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
  274. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js +23 -9
  275. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
  276. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts +11 -0
  277. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -0
  278. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +47 -0
  279. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -0
  280. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +8 -0
  281. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  282. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +68 -8
  283. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  284. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
  285. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js +22 -22
  286. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
  287. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  288. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +232 -18
  289. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  290. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts +2 -0
  291. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts.map +1 -0
  292. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js +38 -0
  293. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js.map +1 -0
  294. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +14 -0
  295. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  296. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +70 -6
  297. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  298. package/packages/pi-coding-agent/src/core/agent-session.ts +12 -6
  299. package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +612 -0
  300. package/packages/pi-coding-agent/src/core/model-registry-env-fallback.test.ts +59 -0
  301. package/packages/pi-coding-agent/src/core/model-registry.ts +2 -1
  302. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +19 -0
  303. package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +25 -10
  304. package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +67 -0
  305. package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +83 -7
  306. package/packages/pi-coding-agent/src/modes/interactive/components/user-message.ts +23 -26
  307. package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +298 -41
  308. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-ordering.test.ts +44 -0
  309. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +92 -6
  310. package/packages/pi-coding-agent/src/types/ambient-modules.d.ts +69 -0
  311. package/packages/pi-coding-agent/tsconfig.json +2 -2
  312. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  313. package/src/resources/extensions/gsd/activity-log.ts +21 -0
  314. package/src/resources/extensions/gsd/auto/loop-deps.ts +4 -0
  315. package/src/resources/extensions/gsd/auto/loop.ts +159 -10
  316. package/src/resources/extensions/gsd/auto/phases.ts +123 -3
  317. package/src/resources/extensions/gsd/auto/session.ts +10 -0
  318. package/src/resources/extensions/gsd/auto-dispatch.ts +16 -6
  319. package/src/resources/extensions/gsd/auto-model-selection.ts +66 -5
  320. package/src/resources/extensions/gsd/auto-post-unit.ts +226 -9
  321. package/src/resources/extensions/gsd/auto-recovery.ts +29 -9
  322. package/src/resources/extensions/gsd/auto-unit-closeout.ts +25 -1
  323. package/src/resources/extensions/gsd/auto-verification.ts +129 -2
  324. package/src/resources/extensions/gsd/auto.ts +34 -2
  325. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +15 -1
  326. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +72 -8
  327. package/src/resources/extensions/gsd/cache.ts +16 -5
  328. package/src/resources/extensions/gsd/commands/handlers/ops.ts +5 -0
  329. package/src/resources/extensions/gsd/commands-extract-learnings.ts +304 -0
  330. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +1 -1
  331. package/src/resources/extensions/gsd/docs/preferences-reference.md +14 -1
  332. package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +228 -0
  333. package/src/resources/extensions/gsd/ecosystem/loader.ts +201 -0
  334. package/src/resources/extensions/gsd/git-service.ts +68 -0
  335. package/src/resources/extensions/gsd/graph-context.ts +139 -12
  336. package/src/resources/extensions/gsd/gsd-db.ts +321 -3
  337. package/src/resources/extensions/gsd/guided-flow.ts +33 -1
  338. package/src/resources/extensions/gsd/init-wizard.ts +3 -2
  339. package/src/resources/extensions/gsd/journal.ts +30 -0
  340. package/src/resources/extensions/gsd/metrics.ts +26 -0
  341. package/src/resources/extensions/gsd/parallel-orchestrator.ts +40 -1
  342. package/src/resources/extensions/gsd/preferences-models.ts +20 -3
  343. package/src/resources/extensions/gsd/preferences-types.ts +32 -0
  344. package/src/resources/extensions/gsd/preferences-validation.ts +107 -2
  345. package/src/resources/extensions/gsd/preferences.ts +28 -0
  346. package/src/resources/extensions/gsd/safety/evidence-collector.ts +15 -31
  347. package/src/resources/extensions/gsd/session-lock.ts +14 -2
  348. package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +20 -1
  349. package/src/resources/extensions/gsd/templates/PREFERENCES.md +18 -0
  350. package/src/resources/extensions/gsd/tests/artifacts-table-preserved-on-cache-invalidate.test.ts +177 -0
  351. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +7 -3
  352. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +20 -0
  353. package/src/resources/extensions/gsd/tests/auto-project-root-env.test.ts +7 -3
  354. package/src/resources/extensions/gsd/tests/auto-retry-mcp-churn-fixes.test.ts +272 -0
  355. package/src/resources/extensions/gsd/tests/cold-resume-db-reopen.test.ts +6 -2
  356. package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +340 -0
  357. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  358. package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
  359. package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +10 -7
  360. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +1 -1
  361. package/src/resources/extensions/gsd/tests/health-widget.test.ts +1 -1
  362. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -2
  363. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -3
  364. package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +79 -1
  365. package/src/resources/extensions/gsd/tests/post-unit-state-rebuild.test.ts +2 -1
  366. package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +40 -1
  367. package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +1 -1
  368. package/src/resources/extensions/gsd/tests/token-profile.test.ts +8 -5
  369. package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +101 -0
  370. package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +85 -0
  371. package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +69 -0
  372. package/src/resources/extensions/gsd/tests/uok-flags.test.ts +39 -0
  373. package/src/resources/extensions/gsd/tests/uok-gate-runner.test.ts +70 -0
  374. package/src/resources/extensions/gsd/tests/uok-gitops-turn-action.test.ts +85 -0
  375. package/src/resources/extensions/gsd/tests/uok-gitops-wiring.test.ts +35 -0
  376. package/src/resources/extensions/gsd/tests/uok-model-policy.test.ts +89 -0
  377. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +167 -0
  378. package/src/resources/extensions/gsd/tests/uok-preferences.test.ts +42 -0
  379. package/src/resources/extensions/gsd/tests/validate-milestone-write-order.test.ts +39 -0
  380. package/src/resources/extensions/gsd/tools/complete-slice.ts +9 -2
  381. package/src/resources/extensions/gsd/tools/validate-milestone.ts +48 -3
  382. package/src/resources/extensions/gsd/types.ts +14 -1
  383. package/src/resources/extensions/gsd/unit-ownership.ts +2 -2
  384. package/src/resources/extensions/gsd/uok/audit-toggle.ts +9 -0
  385. package/src/resources/extensions/gsd/uok/audit.ts +51 -0
  386. package/src/resources/extensions/gsd/uok/contracts.ts +135 -0
  387. package/src/resources/extensions/gsd/uok/execution-graph.ts +241 -0
  388. package/src/resources/extensions/gsd/uok/flags.ts +45 -0
  389. package/src/resources/extensions/gsd/uok/gate-runner.ts +146 -0
  390. package/src/resources/extensions/gsd/uok/gitops.ts +75 -0
  391. package/src/resources/extensions/gsd/uok/kernel.ts +105 -0
  392. package/src/resources/extensions/gsd/uok/loop-adapter.ts +162 -0
  393. package/src/resources/extensions/gsd/uok/model-policy.ts +112 -0
  394. package/src/resources/extensions/gsd/uok/plan-v2.ts +156 -0
  395. package/src/resources/extensions/gsd/workflow-logger.ts +27 -1
  396. package/src/resources/extensions/ttsr/ttsr-manager.ts +10 -5
  397. package/packages/pi-ai/dist/models.custom.d.ts.map +0 -1
  398. package/packages/pi-ai/dist/models.custom.js.map +0 -1
  399. package/packages/pi-ai/dist/models.generated.js +0 -14343
  400. package/packages/pi-ai/dist/models.generated.js.map +0 -1
  401. package/packages/pi-ai/src/models.generated.ts +0 -14345
  402. /package/dist/web/standalone/.next/static/{XnHY5eXUsTCFmNodWHetD → kn6xzWKYnogsxp2b6RpDD}/_buildManifest.js +0 -0
  403. /package/dist/web/standalone/.next/static/{XnHY5eXUsTCFmNodWHetD → kn6xzWKYnogsxp2b6RpDD}/_ssgManifest.js +0 -0
@@ -0,0 +1,4274 @@
1
+ // This file is auto-generated by scripts/generate-models.ts
2
+ // Do not edit manually - run 'npm run generate-models' to update
3
+
4
+ import type { Model } from "../../types.js";
5
+
6
+ export const OPENROUTER_MODELS = {
7
+ "ai21/jamba-large-1.7": {
8
+ id: "ai21/jamba-large-1.7",
9
+ name: "AI21: Jamba Large 1.7",
10
+ api: "openai-completions",
11
+ provider: "openrouter",
12
+ baseUrl: "https://openrouter.ai/api/v1",
13
+ reasoning: false,
14
+ input: ["text"],
15
+ cost: {
16
+ input: 2,
17
+ output: 8,
18
+ cacheRead: 0,
19
+ cacheWrite: 0,
20
+ },
21
+ contextWindow: 256000,
22
+ maxTokens: 4096,
23
+ } satisfies Model<"openai-completions">,
24
+ "alibaba/tongyi-deepresearch-30b-a3b": {
25
+ id: "alibaba/tongyi-deepresearch-30b-a3b",
26
+ name: "Tongyi DeepResearch 30B A3B",
27
+ api: "openai-completions",
28
+ provider: "openrouter",
29
+ baseUrl: "https://openrouter.ai/api/v1",
30
+ reasoning: true,
31
+ input: ["text"],
32
+ cost: {
33
+ input: 0.09,
34
+ output: 0.44999999999999996,
35
+ cacheRead: 0.09,
36
+ cacheWrite: 0,
37
+ },
38
+ contextWindow: 131072,
39
+ maxTokens: 131072,
40
+ } satisfies Model<"openai-completions">,
41
+ "allenai/olmo-3.1-32b-instruct": {
42
+ id: "allenai/olmo-3.1-32b-instruct",
43
+ name: "AllenAI: Olmo 3.1 32B Instruct",
44
+ api: "openai-completions",
45
+ provider: "openrouter",
46
+ baseUrl: "https://openrouter.ai/api/v1",
47
+ reasoning: false,
48
+ input: ["text"],
49
+ cost: {
50
+ input: 0.19999999999999998,
51
+ output: 0.6,
52
+ cacheRead: 0,
53
+ cacheWrite: 0,
54
+ },
55
+ contextWindow: 65536,
56
+ maxTokens: 4096,
57
+ } satisfies Model<"openai-completions">,
58
+ "amazon/nova-2-lite-v1": {
59
+ id: "amazon/nova-2-lite-v1",
60
+ name: "Amazon: Nova 2 Lite",
61
+ api: "openai-completions",
62
+ provider: "openrouter",
63
+ baseUrl: "https://openrouter.ai/api/v1",
64
+ reasoning: true,
65
+ input: ["text", "image"],
66
+ cost: {
67
+ input: 0.3,
68
+ output: 2.5,
69
+ cacheRead: 0,
70
+ cacheWrite: 0,
71
+ },
72
+ contextWindow: 1000000,
73
+ maxTokens: 65535,
74
+ } satisfies Model<"openai-completions">,
75
+ "amazon/nova-lite-v1": {
76
+ id: "amazon/nova-lite-v1",
77
+ name: "Amazon: Nova Lite 1.0",
78
+ api: "openai-completions",
79
+ provider: "openrouter",
80
+ baseUrl: "https://openrouter.ai/api/v1",
81
+ reasoning: false,
82
+ input: ["text", "image"],
83
+ cost: {
84
+ input: 0.06,
85
+ output: 0.24,
86
+ cacheRead: 0,
87
+ cacheWrite: 0,
88
+ },
89
+ contextWindow: 300000,
90
+ maxTokens: 5120,
91
+ } satisfies Model<"openai-completions">,
92
+ "amazon/nova-micro-v1": {
93
+ id: "amazon/nova-micro-v1",
94
+ name: "Amazon: Nova Micro 1.0",
95
+ api: "openai-completions",
96
+ provider: "openrouter",
97
+ baseUrl: "https://openrouter.ai/api/v1",
98
+ reasoning: false,
99
+ input: ["text"],
100
+ cost: {
101
+ input: 0.035,
102
+ output: 0.14,
103
+ cacheRead: 0,
104
+ cacheWrite: 0,
105
+ },
106
+ contextWindow: 128000,
107
+ maxTokens: 5120,
108
+ } satisfies Model<"openai-completions">,
109
+ "amazon/nova-premier-v1": {
110
+ id: "amazon/nova-premier-v1",
111
+ name: "Amazon: Nova Premier 1.0",
112
+ api: "openai-completions",
113
+ provider: "openrouter",
114
+ baseUrl: "https://openrouter.ai/api/v1",
115
+ reasoning: false,
116
+ input: ["text", "image"],
117
+ cost: {
118
+ input: 2.5,
119
+ output: 12.5,
120
+ cacheRead: 0.625,
121
+ cacheWrite: 0,
122
+ },
123
+ contextWindow: 1000000,
124
+ maxTokens: 32000,
125
+ } satisfies Model<"openai-completions">,
126
+ "amazon/nova-pro-v1": {
127
+ id: "amazon/nova-pro-v1",
128
+ name: "Amazon: Nova Pro 1.0",
129
+ api: "openai-completions",
130
+ provider: "openrouter",
131
+ baseUrl: "https://openrouter.ai/api/v1",
132
+ reasoning: false,
133
+ input: ["text", "image"],
134
+ cost: {
135
+ input: 0.7999999999999999,
136
+ output: 3.1999999999999997,
137
+ cacheRead: 0,
138
+ cacheWrite: 0,
139
+ },
140
+ contextWindow: 300000,
141
+ maxTokens: 5120,
142
+ } satisfies Model<"openai-completions">,
143
+ "anthropic/claude-3-haiku": {
144
+ id: "anthropic/claude-3-haiku",
145
+ name: "Anthropic: Claude 3 Haiku",
146
+ api: "openai-completions",
147
+ provider: "openrouter",
148
+ baseUrl: "https://openrouter.ai/api/v1",
149
+ reasoning: false,
150
+ input: ["text", "image"],
151
+ cost: {
152
+ input: 0.25,
153
+ output: 1.25,
154
+ cacheRead: 0.03,
155
+ cacheWrite: 0.3,
156
+ },
157
+ contextWindow: 200000,
158
+ maxTokens: 4096,
159
+ } satisfies Model<"openai-completions">,
160
+ "anthropic/claude-3.5-haiku": {
161
+ id: "anthropic/claude-3.5-haiku",
162
+ name: "Anthropic: Claude 3.5 Haiku",
163
+ api: "openai-completions",
164
+ provider: "openrouter",
165
+ baseUrl: "https://openrouter.ai/api/v1",
166
+ reasoning: false,
167
+ input: ["text", "image"],
168
+ cost: {
169
+ input: 0.7999999999999999,
170
+ output: 4,
171
+ cacheRead: 0.08,
172
+ cacheWrite: 1,
173
+ },
174
+ contextWindow: 200000,
175
+ maxTokens: 8192,
176
+ } satisfies Model<"openai-completions">,
177
+ "anthropic/claude-3.7-sonnet": {
178
+ id: "anthropic/claude-3.7-sonnet",
179
+ name: "Anthropic: Claude 3.7 Sonnet",
180
+ api: "openai-completions",
181
+ provider: "openrouter",
182
+ baseUrl: "https://openrouter.ai/api/v1",
183
+ reasoning: true,
184
+ input: ["text", "image"],
185
+ cost: {
186
+ input: 3,
187
+ output: 15,
188
+ cacheRead: 0.3,
189
+ cacheWrite: 3.75,
190
+ },
191
+ contextWindow: 200000,
192
+ maxTokens: 128000,
193
+ } satisfies Model<"openai-completions">,
194
+ "anthropic/claude-3.7-sonnet:thinking": {
195
+ id: "anthropic/claude-3.7-sonnet:thinking",
196
+ name: "Anthropic: Claude 3.7 Sonnet (thinking)",
197
+ api: "openai-completions",
198
+ provider: "openrouter",
199
+ baseUrl: "https://openrouter.ai/api/v1",
200
+ reasoning: true,
201
+ input: ["text", "image"],
202
+ cost: {
203
+ input: 3,
204
+ output: 15,
205
+ cacheRead: 0.3,
206
+ cacheWrite: 3.75,
207
+ },
208
+ contextWindow: 200000,
209
+ maxTokens: 64000,
210
+ } satisfies Model<"openai-completions">,
211
+ "anthropic/claude-haiku-4.5": {
212
+ id: "anthropic/claude-haiku-4.5",
213
+ name: "Anthropic: Claude Haiku 4.5",
214
+ api: "openai-completions",
215
+ provider: "openrouter",
216
+ baseUrl: "https://openrouter.ai/api/v1",
217
+ reasoning: true,
218
+ input: ["text", "image"],
219
+ cost: {
220
+ input: 1,
221
+ output: 5,
222
+ cacheRead: 0.09999999999999999,
223
+ cacheWrite: 1.25,
224
+ },
225
+ contextWindow: 200000,
226
+ maxTokens: 64000,
227
+ } satisfies Model<"openai-completions">,
228
+ "anthropic/claude-opus-4": {
229
+ id: "anthropic/claude-opus-4",
230
+ name: "Anthropic: Claude Opus 4",
231
+ api: "openai-completions",
232
+ provider: "openrouter",
233
+ baseUrl: "https://openrouter.ai/api/v1",
234
+ reasoning: true,
235
+ input: ["text", "image"],
236
+ cost: {
237
+ input: 15,
238
+ output: 75,
239
+ cacheRead: 1.5,
240
+ cacheWrite: 18.75,
241
+ },
242
+ contextWindow: 200000,
243
+ maxTokens: 32000,
244
+ } satisfies Model<"openai-completions">,
245
+ "anthropic/claude-opus-4.1": {
246
+ id: "anthropic/claude-opus-4.1",
247
+ name: "Anthropic: Claude Opus 4.1",
248
+ api: "openai-completions",
249
+ provider: "openrouter",
250
+ baseUrl: "https://openrouter.ai/api/v1",
251
+ reasoning: true,
252
+ input: ["text", "image"],
253
+ cost: {
254
+ input: 15,
255
+ output: 75,
256
+ cacheRead: 1.5,
257
+ cacheWrite: 18.75,
258
+ },
259
+ contextWindow: 200000,
260
+ maxTokens: 32000,
261
+ } satisfies Model<"openai-completions">,
262
+ "anthropic/claude-opus-4.5": {
263
+ id: "anthropic/claude-opus-4.5",
264
+ name: "Anthropic: Claude Opus 4.5",
265
+ api: "openai-completions",
266
+ provider: "openrouter",
267
+ baseUrl: "https://openrouter.ai/api/v1",
268
+ reasoning: true,
269
+ input: ["text", "image"],
270
+ cost: {
271
+ input: 5,
272
+ output: 25,
273
+ cacheRead: 0.5,
274
+ cacheWrite: 6.25,
275
+ },
276
+ contextWindow: 200000,
277
+ maxTokens: 64000,
278
+ } satisfies Model<"openai-completions">,
279
+ "anthropic/claude-opus-4.6": {
280
+ id: "anthropic/claude-opus-4.6",
281
+ name: "Anthropic: Claude Opus 4.6",
282
+ api: "openai-completions",
283
+ provider: "openrouter",
284
+ baseUrl: "https://openrouter.ai/api/v1",
285
+ reasoning: true,
286
+ input: ["text", "image"],
287
+ cost: {
288
+ input: 5,
289
+ output: 25,
290
+ cacheRead: 0.5,
291
+ cacheWrite: 6.25,
292
+ },
293
+ contextWindow: 1000000,
294
+ maxTokens: 128000,
295
+ } satisfies Model<"openai-completions">,
296
+ "anthropic/claude-opus-4.6-fast": {
297
+ id: "anthropic/claude-opus-4.6-fast",
298
+ name: "Anthropic: Claude Opus 4.6 (Fast)",
299
+ api: "openai-completions",
300
+ provider: "openrouter",
301
+ baseUrl: "https://openrouter.ai/api/v1",
302
+ reasoning: true,
303
+ input: ["text", "image"],
304
+ cost: {
305
+ input: 30,
306
+ output: 150,
307
+ cacheRead: 3,
308
+ cacheWrite: 37.5,
309
+ },
310
+ contextWindow: 1000000,
311
+ maxTokens: 128000,
312
+ } satisfies Model<"openai-completions">,
313
+ "anthropic/claude-sonnet-4": {
314
+ id: "anthropic/claude-sonnet-4",
315
+ name: "Anthropic: Claude Sonnet 4",
316
+ api: "openai-completions",
317
+ provider: "openrouter",
318
+ baseUrl: "https://openrouter.ai/api/v1",
319
+ reasoning: true,
320
+ input: ["text", "image"],
321
+ cost: {
322
+ input: 3,
323
+ output: 15,
324
+ cacheRead: 0.3,
325
+ cacheWrite: 3.75,
326
+ },
327
+ contextWindow: 1000000,
328
+ maxTokens: 64000,
329
+ } satisfies Model<"openai-completions">,
330
+ "anthropic/claude-sonnet-4.5": {
331
+ id: "anthropic/claude-sonnet-4.5",
332
+ name: "Anthropic: Claude Sonnet 4.5",
333
+ api: "openai-completions",
334
+ provider: "openrouter",
335
+ baseUrl: "https://openrouter.ai/api/v1",
336
+ reasoning: true,
337
+ input: ["text", "image"],
338
+ cost: {
339
+ input: 3,
340
+ output: 15,
341
+ cacheRead: 0.3,
342
+ cacheWrite: 3.75,
343
+ },
344
+ contextWindow: 1000000,
345
+ maxTokens: 64000,
346
+ } satisfies Model<"openai-completions">,
347
+ "anthropic/claude-sonnet-4.6": {
348
+ id: "anthropic/claude-sonnet-4.6",
349
+ name: "Anthropic: Claude Sonnet 4.6",
350
+ api: "openai-completions",
351
+ provider: "openrouter",
352
+ baseUrl: "https://openrouter.ai/api/v1",
353
+ reasoning: true,
354
+ input: ["text", "image"],
355
+ cost: {
356
+ input: 3,
357
+ output: 15,
358
+ cacheRead: 0.3,
359
+ cacheWrite: 3.75,
360
+ },
361
+ contextWindow: 1000000,
362
+ maxTokens: 128000,
363
+ } satisfies Model<"openai-completions">,
364
+ "arcee-ai/trinity-large-preview:free": {
365
+ id: "arcee-ai/trinity-large-preview:free",
366
+ name: "Arcee AI: Trinity Large Preview (free)",
367
+ api: "openai-completions",
368
+ provider: "openrouter",
369
+ baseUrl: "https://openrouter.ai/api/v1",
370
+ reasoning: false,
371
+ input: ["text"],
372
+ cost: {
373
+ input: 0,
374
+ output: 0,
375
+ cacheRead: 0,
376
+ cacheWrite: 0,
377
+ },
378
+ contextWindow: 131000,
379
+ maxTokens: 4096,
380
+ } satisfies Model<"openai-completions">,
381
+ "arcee-ai/trinity-large-thinking": {
382
+ id: "arcee-ai/trinity-large-thinking",
383
+ name: "Arcee AI: Trinity Large Thinking",
384
+ api: "openai-completions",
385
+ provider: "openrouter",
386
+ baseUrl: "https://openrouter.ai/api/v1",
387
+ reasoning: true,
388
+ input: ["text"],
389
+ cost: {
390
+ input: 0.22,
391
+ output: 0.85,
392
+ cacheRead: 0,
393
+ cacheWrite: 0,
394
+ },
395
+ contextWindow: 262144,
396
+ maxTokens: 262144,
397
+ } satisfies Model<"openai-completions">,
398
+ "arcee-ai/trinity-mini": {
399
+ id: "arcee-ai/trinity-mini",
400
+ name: "Arcee AI: Trinity Mini",
401
+ api: "openai-completions",
402
+ provider: "openrouter",
403
+ baseUrl: "https://openrouter.ai/api/v1",
404
+ reasoning: true,
405
+ input: ["text"],
406
+ cost: {
407
+ input: 0.045,
408
+ output: 0.15,
409
+ cacheRead: 0,
410
+ cacheWrite: 0,
411
+ },
412
+ contextWindow: 131072,
413
+ maxTokens: 131072,
414
+ } satisfies Model<"openai-completions">,
415
+ "arcee-ai/virtuoso-large": {
416
+ id: "arcee-ai/virtuoso-large",
417
+ name: "Arcee AI: Virtuoso Large",
418
+ api: "openai-completions",
419
+ provider: "openrouter",
420
+ baseUrl: "https://openrouter.ai/api/v1",
421
+ reasoning: false,
422
+ input: ["text"],
423
+ cost: {
424
+ input: 0.75,
425
+ output: 1.2,
426
+ cacheRead: 0,
427
+ cacheWrite: 0,
428
+ },
429
+ contextWindow: 131072,
430
+ maxTokens: 64000,
431
+ } satisfies Model<"openai-completions">,
432
+ "auto": {
433
+ id: "auto",
434
+ name: "Auto",
435
+ api: "openai-completions",
436
+ provider: "openrouter",
437
+ baseUrl: "https://openrouter.ai/api/v1",
438
+ reasoning: true,
439
+ input: ["text", "image"],
440
+ cost: {
441
+ input: 0,
442
+ output: 0,
443
+ cacheRead: 0,
444
+ cacheWrite: 0,
445
+ },
446
+ contextWindow: 2000000,
447
+ maxTokens: 30000,
448
+ } satisfies Model<"openai-completions">,
449
+ "baidu/ernie-4.5-21b-a3b": {
450
+ id: "baidu/ernie-4.5-21b-a3b",
451
+ name: "Baidu: ERNIE 4.5 21B A3B",
452
+ api: "openai-completions",
453
+ provider: "openrouter",
454
+ baseUrl: "https://openrouter.ai/api/v1",
455
+ reasoning: false,
456
+ input: ["text"],
457
+ cost: {
458
+ input: 0.07,
459
+ output: 0.28,
460
+ cacheRead: 0,
461
+ cacheWrite: 0,
462
+ },
463
+ contextWindow: 120000,
464
+ maxTokens: 8000,
465
+ } satisfies Model<"openai-completions">,
466
+ "baidu/ernie-4.5-vl-28b-a3b": {
467
+ id: "baidu/ernie-4.5-vl-28b-a3b",
468
+ name: "Baidu: ERNIE 4.5 VL 28B A3B",
469
+ api: "openai-completions",
470
+ provider: "openrouter",
471
+ baseUrl: "https://openrouter.ai/api/v1",
472
+ reasoning: true,
473
+ input: ["text", "image"],
474
+ cost: {
475
+ input: 0.14,
476
+ output: 0.56,
477
+ cacheRead: 0,
478
+ cacheWrite: 0,
479
+ },
480
+ contextWindow: 30000,
481
+ maxTokens: 8000,
482
+ } satisfies Model<"openai-completions">,
483
+ "bytedance-seed/seed-1.6": {
484
+ id: "bytedance-seed/seed-1.6",
485
+ name: "ByteDance Seed: Seed 1.6",
486
+ api: "openai-completions",
487
+ provider: "openrouter",
488
+ baseUrl: "https://openrouter.ai/api/v1",
489
+ reasoning: true,
490
+ input: ["text", "image"],
491
+ cost: {
492
+ input: 0.25,
493
+ output: 2,
494
+ cacheRead: 0,
495
+ cacheWrite: 0,
496
+ },
497
+ contextWindow: 262144,
498
+ maxTokens: 32768,
499
+ } satisfies Model<"openai-completions">,
500
+ "bytedance-seed/seed-1.6-flash": {
501
+ id: "bytedance-seed/seed-1.6-flash",
502
+ name: "ByteDance Seed: Seed 1.6 Flash",
503
+ api: "openai-completions",
504
+ provider: "openrouter",
505
+ baseUrl: "https://openrouter.ai/api/v1",
506
+ reasoning: true,
507
+ input: ["text", "image"],
508
+ cost: {
509
+ input: 0.075,
510
+ output: 0.3,
511
+ cacheRead: 0,
512
+ cacheWrite: 0,
513
+ },
514
+ contextWindow: 262144,
515
+ maxTokens: 32768,
516
+ } satisfies Model<"openai-completions">,
517
+ "bytedance-seed/seed-2.0-lite": {
518
+ id: "bytedance-seed/seed-2.0-lite",
519
+ name: "ByteDance Seed: Seed-2.0-Lite",
520
+ api: "openai-completions",
521
+ provider: "openrouter",
522
+ baseUrl: "https://openrouter.ai/api/v1",
523
+ reasoning: true,
524
+ input: ["text", "image"],
525
+ cost: {
526
+ input: 0.25,
527
+ output: 2,
528
+ cacheRead: 0,
529
+ cacheWrite: 0,
530
+ },
531
+ contextWindow: 262144,
532
+ maxTokens: 131072,
533
+ } satisfies Model<"openai-completions">,
534
+ "bytedance-seed/seed-2.0-mini": {
535
+ id: "bytedance-seed/seed-2.0-mini",
536
+ name: "ByteDance Seed: Seed-2.0-Mini",
537
+ api: "openai-completions",
538
+ provider: "openrouter",
539
+ baseUrl: "https://openrouter.ai/api/v1",
540
+ reasoning: true,
541
+ input: ["text", "image"],
542
+ cost: {
543
+ input: 0.09999999999999999,
544
+ output: 0.39999999999999997,
545
+ cacheRead: 0,
546
+ cacheWrite: 0,
547
+ },
548
+ contextWindow: 262144,
549
+ maxTokens: 131072,
550
+ } satisfies Model<"openai-completions">,
551
+ "cohere/command-r-08-2024": {
552
+ id: "cohere/command-r-08-2024",
553
+ name: "Cohere: Command R (08-2024)",
554
+ api: "openai-completions",
555
+ provider: "openrouter",
556
+ baseUrl: "https://openrouter.ai/api/v1",
557
+ reasoning: false,
558
+ input: ["text"],
559
+ cost: {
560
+ input: 0.15,
561
+ output: 0.6,
562
+ cacheRead: 0,
563
+ cacheWrite: 0,
564
+ },
565
+ contextWindow: 128000,
566
+ maxTokens: 4000,
567
+ } satisfies Model<"openai-completions">,
568
+ "cohere/command-r-plus-08-2024": {
569
+ id: "cohere/command-r-plus-08-2024",
570
+ name: "Cohere: Command R+ (08-2024)",
571
+ api: "openai-completions",
572
+ provider: "openrouter",
573
+ baseUrl: "https://openrouter.ai/api/v1",
574
+ reasoning: false,
575
+ input: ["text"],
576
+ cost: {
577
+ input: 2.5,
578
+ output: 10,
579
+ cacheRead: 0,
580
+ cacheWrite: 0,
581
+ },
582
+ contextWindow: 128000,
583
+ maxTokens: 4000,
584
+ } satisfies Model<"openai-completions">,
585
+ "deepseek/deepseek-chat": {
586
+ id: "deepseek/deepseek-chat",
587
+ name: "DeepSeek: DeepSeek V3",
588
+ api: "openai-completions",
589
+ provider: "openrouter",
590
+ baseUrl: "https://openrouter.ai/api/v1",
591
+ reasoning: false,
592
+ input: ["text"],
593
+ cost: {
594
+ input: 0.32,
595
+ output: 0.8899999999999999,
596
+ cacheRead: 0,
597
+ cacheWrite: 0,
598
+ },
599
+ contextWindow: 163840,
600
+ maxTokens: 163840,
601
+ } satisfies Model<"openai-completions">,
602
+ "deepseek/deepseek-chat-v3-0324": {
603
+ id: "deepseek/deepseek-chat-v3-0324",
604
+ name: "DeepSeek: DeepSeek V3 0324",
605
+ api: "openai-completions",
606
+ provider: "openrouter",
607
+ baseUrl: "https://openrouter.ai/api/v1",
608
+ reasoning: true,
609
+ input: ["text"],
610
+ cost: {
611
+ input: 0.19999999999999998,
612
+ output: 0.77,
613
+ cacheRead: 0.135,
614
+ cacheWrite: 0,
615
+ },
616
+ contextWindow: 163840,
617
+ maxTokens: 4096,
618
+ } satisfies Model<"openai-completions">,
619
+ "deepseek/deepseek-chat-v3.1": {
620
+ id: "deepseek/deepseek-chat-v3.1",
621
+ name: "DeepSeek: DeepSeek V3.1",
622
+ api: "openai-completions",
623
+ provider: "openrouter",
624
+ baseUrl: "https://openrouter.ai/api/v1",
625
+ reasoning: true,
626
+ input: ["text"],
627
+ cost: {
628
+ input: 0.15,
629
+ output: 0.75,
630
+ cacheRead: 0,
631
+ cacheWrite: 0,
632
+ },
633
+ contextWindow: 32768,
634
+ maxTokens: 7168,
635
+ } satisfies Model<"openai-completions">,
636
+ "deepseek/deepseek-r1": {
637
+ id: "deepseek/deepseek-r1",
638
+ name: "DeepSeek: R1",
639
+ api: "openai-completions",
640
+ provider: "openrouter",
641
+ baseUrl: "https://openrouter.ai/api/v1",
642
+ reasoning: true,
643
+ input: ["text"],
644
+ cost: {
645
+ input: 0.7,
646
+ output: 2.5,
647
+ cacheRead: 0,
648
+ cacheWrite: 0,
649
+ },
650
+ contextWindow: 64000,
651
+ maxTokens: 16000,
652
+ } satisfies Model<"openai-completions">,
653
+ "deepseek/deepseek-r1-0528": {
654
+ id: "deepseek/deepseek-r1-0528",
655
+ name: "DeepSeek: R1 0528",
656
+ api: "openai-completions",
657
+ provider: "openrouter",
658
+ baseUrl: "https://openrouter.ai/api/v1",
659
+ reasoning: true,
660
+ input: ["text"],
661
+ cost: {
662
+ input: 0.5,
663
+ output: 2.1500000000000004,
664
+ cacheRead: 0.35,
665
+ cacheWrite: 0,
666
+ },
667
+ contextWindow: 163840,
668
+ maxTokens: 4096,
669
+ } satisfies Model<"openai-completions">,
670
+ "deepseek/deepseek-v3.1-terminus": {
671
+ id: "deepseek/deepseek-v3.1-terminus",
672
+ name: "DeepSeek: DeepSeek V3.1 Terminus",
673
+ api: "openai-completions",
674
+ provider: "openrouter",
675
+ baseUrl: "https://openrouter.ai/api/v1",
676
+ reasoning: true,
677
+ input: ["text"],
678
+ cost: {
679
+ input: 0.21,
680
+ output: 0.7899999999999999,
681
+ cacheRead: 0.1300000002,
682
+ cacheWrite: 0,
683
+ },
684
+ contextWindow: 163840,
685
+ maxTokens: 4096,
686
+ } satisfies Model<"openai-completions">,
687
+ "deepseek/deepseek-v3.2": {
688
+ id: "deepseek/deepseek-v3.2",
689
+ name: "DeepSeek: DeepSeek V3.2",
690
+ api: "openai-completions",
691
+ provider: "openrouter",
692
+ baseUrl: "https://openrouter.ai/api/v1",
693
+ reasoning: true,
694
+ input: ["text"],
695
+ cost: {
696
+ input: 0.26,
697
+ output: 0.38,
698
+ cacheRead: 0.13,
699
+ cacheWrite: 0,
700
+ },
701
+ contextWindow: 163840,
702
+ maxTokens: 4096,
703
+ } satisfies Model<"openai-completions">,
704
+ "deepseek/deepseek-v3.2-exp": {
705
+ id: "deepseek/deepseek-v3.2-exp",
706
+ name: "DeepSeek: DeepSeek V3.2 Exp",
707
+ api: "openai-completions",
708
+ provider: "openrouter",
709
+ baseUrl: "https://openrouter.ai/api/v1",
710
+ reasoning: true,
711
+ input: ["text"],
712
+ cost: {
713
+ input: 0.27,
714
+ output: 0.41,
715
+ cacheRead: 0,
716
+ cacheWrite: 0,
717
+ },
718
+ contextWindow: 163840,
719
+ maxTokens: 65536,
720
+ } satisfies Model<"openai-completions">,
721
+ "essentialai/rnj-1-instruct": {
722
+ id: "essentialai/rnj-1-instruct",
723
+ name: "EssentialAI: Rnj 1 Instruct",
724
+ api: "openai-completions",
725
+ provider: "openrouter",
726
+ baseUrl: "https://openrouter.ai/api/v1",
727
+ reasoning: false,
728
+ input: ["text"],
729
+ cost: {
730
+ input: 0.15,
731
+ output: 0.15,
732
+ cacheRead: 0,
733
+ cacheWrite: 0,
734
+ },
735
+ contextWindow: 32768,
736
+ maxTokens: 4096,
737
+ } satisfies Model<"openai-completions">,
738
+ "google/gemini-2.0-flash-001": {
739
+ id: "google/gemini-2.0-flash-001",
740
+ name: "Google: Gemini 2.0 Flash",
741
+ api: "openai-completions",
742
+ provider: "openrouter",
743
+ baseUrl: "https://openrouter.ai/api/v1",
744
+ reasoning: false,
745
+ input: ["text", "image"],
746
+ cost: {
747
+ input: 0.09999999999999999,
748
+ output: 0.39999999999999997,
749
+ cacheRead: 0.024999999999999998,
750
+ cacheWrite: 0.08333333333333334,
751
+ },
752
+ contextWindow: 1048576,
753
+ maxTokens: 8192,
754
+ } satisfies Model<"openai-completions">,
755
+ "google/gemini-2.0-flash-lite-001": {
756
+ id: "google/gemini-2.0-flash-lite-001",
757
+ name: "Google: Gemini 2.0 Flash Lite",
758
+ api: "openai-completions",
759
+ provider: "openrouter",
760
+ baseUrl: "https://openrouter.ai/api/v1",
761
+ reasoning: false,
762
+ input: ["text", "image"],
763
+ cost: {
764
+ input: 0.075,
765
+ output: 0.3,
766
+ cacheRead: 0,
767
+ cacheWrite: 0,
768
+ },
769
+ contextWindow: 1048576,
770
+ maxTokens: 8192,
771
+ } satisfies Model<"openai-completions">,
772
+ "google/gemini-2.5-flash": {
773
+ id: "google/gemini-2.5-flash",
774
+ name: "Google: Gemini 2.5 Flash",
775
+ api: "openai-completions",
776
+ provider: "openrouter",
777
+ baseUrl: "https://openrouter.ai/api/v1",
778
+ reasoning: true,
779
+ input: ["text", "image"],
780
+ cost: {
781
+ input: 0.3,
782
+ output: 2.5,
783
+ cacheRead: 0.03,
784
+ cacheWrite: 0.08333333333333334,
785
+ },
786
+ contextWindow: 1048576,
787
+ maxTokens: 65535,
788
+ } satisfies Model<"openai-completions">,
789
+ "google/gemini-2.5-flash-lite": {
790
+ id: "google/gemini-2.5-flash-lite",
791
+ name: "Google: Gemini 2.5 Flash Lite",
792
+ api: "openai-completions",
793
+ provider: "openrouter",
794
+ baseUrl: "https://openrouter.ai/api/v1",
795
+ reasoning: true,
796
+ input: ["text", "image"],
797
+ cost: {
798
+ input: 0.09999999999999999,
799
+ output: 0.39999999999999997,
800
+ cacheRead: 0.01,
801
+ cacheWrite: 0.08333333333333334,
802
+ },
803
+ contextWindow: 1048576,
804
+ maxTokens: 65535,
805
+ } satisfies Model<"openai-completions">,
806
+ "google/gemini-2.5-flash-lite-preview-09-2025": {
807
+ id: "google/gemini-2.5-flash-lite-preview-09-2025",
808
+ name: "Google: Gemini 2.5 Flash Lite Preview 09-2025",
809
+ api: "openai-completions",
810
+ provider: "openrouter",
811
+ baseUrl: "https://openrouter.ai/api/v1",
812
+ reasoning: true,
813
+ input: ["text", "image"],
814
+ cost: {
815
+ input: 0.09999999999999999,
816
+ output: 0.39999999999999997,
817
+ cacheRead: 0.01,
818
+ cacheWrite: 0.08333333333333334,
819
+ },
820
+ contextWindow: 1048576,
821
+ maxTokens: 65535,
822
+ } satisfies Model<"openai-completions">,
823
+ "google/gemini-2.5-pro": {
824
+ id: "google/gemini-2.5-pro",
825
+ name: "Google: Gemini 2.5 Pro",
826
+ api: "openai-completions",
827
+ provider: "openrouter",
828
+ baseUrl: "https://openrouter.ai/api/v1",
829
+ reasoning: true,
830
+ input: ["text", "image"],
831
+ cost: {
832
+ input: 1.25,
833
+ output: 10,
834
+ cacheRead: 0.125,
835
+ cacheWrite: 0.375,
836
+ },
837
+ contextWindow: 1048576,
838
+ maxTokens: 65536,
839
+ } satisfies Model<"openai-completions">,
840
+ "google/gemini-2.5-pro-preview": {
841
+ id: "google/gemini-2.5-pro-preview",
842
+ name: "Google: Gemini 2.5 Pro Preview 06-05",
843
+ api: "openai-completions",
844
+ provider: "openrouter",
845
+ baseUrl: "https://openrouter.ai/api/v1",
846
+ reasoning: true,
847
+ input: ["text", "image"],
848
+ cost: {
849
+ input: 1.25,
850
+ output: 10,
851
+ cacheRead: 0.125,
852
+ cacheWrite: 0.375,
853
+ },
854
+ contextWindow: 1048576,
855
+ maxTokens: 65536,
856
+ } satisfies Model<"openai-completions">,
857
+ "google/gemini-2.5-pro-preview-05-06": {
858
+ id: "google/gemini-2.5-pro-preview-05-06",
859
+ name: "Google: Gemini 2.5 Pro Preview 05-06",
860
+ api: "openai-completions",
861
+ provider: "openrouter",
862
+ baseUrl: "https://openrouter.ai/api/v1",
863
+ reasoning: true,
864
+ input: ["text", "image"],
865
+ cost: {
866
+ input: 1.25,
867
+ output: 10,
868
+ cacheRead: 0.125,
869
+ cacheWrite: 0.375,
870
+ },
871
+ contextWindow: 1048576,
872
+ maxTokens: 65535,
873
+ } satisfies Model<"openai-completions">,
874
+ "google/gemini-3-flash-preview": {
875
+ id: "google/gemini-3-flash-preview",
876
+ name: "Google: Gemini 3 Flash Preview",
877
+ api: "openai-completions",
878
+ provider: "openrouter",
879
+ baseUrl: "https://openrouter.ai/api/v1",
880
+ reasoning: true,
881
+ input: ["text", "image"],
882
+ cost: {
883
+ input: 0.5,
884
+ output: 3,
885
+ cacheRead: 0.049999999999999996,
886
+ cacheWrite: 0.08333333333333334,
887
+ },
888
+ contextWindow: 1048576,
889
+ maxTokens: 65536,
890
+ } satisfies Model<"openai-completions">,
891
+ "google/gemini-3.1-flash-lite-preview": {
892
+ id: "google/gemini-3.1-flash-lite-preview",
893
+ name: "Google: Gemini 3.1 Flash Lite Preview",
894
+ api: "openai-completions",
895
+ provider: "openrouter",
896
+ baseUrl: "https://openrouter.ai/api/v1",
897
+ reasoning: true,
898
+ input: ["text", "image"],
899
+ cost: {
900
+ input: 0.25,
901
+ output: 1.5,
902
+ cacheRead: 0.024999999999999998,
903
+ cacheWrite: 0.08333333333333334,
904
+ },
905
+ contextWindow: 1048576,
906
+ maxTokens: 65536,
907
+ } satisfies Model<"openai-completions">,
908
+ "google/gemini-3.1-pro-preview": {
909
+ id: "google/gemini-3.1-pro-preview",
910
+ name: "Google: Gemini 3.1 Pro Preview",
911
+ api: "openai-completions",
912
+ provider: "openrouter",
913
+ baseUrl: "https://openrouter.ai/api/v1",
914
+ reasoning: true,
915
+ input: ["text", "image"],
916
+ cost: {
917
+ input: 2,
918
+ output: 12,
919
+ cacheRead: 0.19999999999999998,
920
+ cacheWrite: 0.375,
921
+ },
922
+ contextWindow: 1048576,
923
+ maxTokens: 65536,
924
+ } satisfies Model<"openai-completions">,
925
+ "google/gemini-3.1-pro-preview-customtools": {
926
+ id: "google/gemini-3.1-pro-preview-customtools",
927
+ name: "Google: Gemini 3.1 Pro Preview Custom Tools",
928
+ api: "openai-completions",
929
+ provider: "openrouter",
930
+ baseUrl: "https://openrouter.ai/api/v1",
931
+ reasoning: true,
932
+ input: ["text", "image"],
933
+ cost: {
934
+ input: 2,
935
+ output: 12,
936
+ cacheRead: 0.19999999999999998,
937
+ cacheWrite: 0.375,
938
+ },
939
+ contextWindow: 1048576,
940
+ maxTokens: 65536,
941
+ } satisfies Model<"openai-completions">,
942
+ "google/gemma-4-26b-a4b-it": {
943
+ id: "google/gemma-4-26b-a4b-it",
944
+ name: "Google: Gemma 4 26B A4B ",
945
+ api: "openai-completions",
946
+ provider: "openrouter",
947
+ baseUrl: "https://openrouter.ai/api/v1",
948
+ reasoning: true,
949
+ input: ["text", "image"],
950
+ cost: {
951
+ input: 0.12,
952
+ output: 0.39999999999999997,
953
+ cacheRead: 0,
954
+ cacheWrite: 0,
955
+ },
956
+ contextWindow: 262144,
957
+ maxTokens: 262144,
958
+ } satisfies Model<"openai-completions">,
959
+ "google/gemma-4-26b-a4b-it:free": {
960
+ id: "google/gemma-4-26b-a4b-it:free",
961
+ name: "Google: Gemma 4 26B A4B (free)",
962
+ api: "openai-completions",
963
+ provider: "openrouter",
964
+ baseUrl: "https://openrouter.ai/api/v1",
965
+ reasoning: true,
966
+ input: ["text", "image"],
967
+ cost: {
968
+ input: 0,
969
+ output: 0,
970
+ cacheRead: 0,
971
+ cacheWrite: 0,
972
+ },
973
+ contextWindow: 262144,
974
+ maxTokens: 32768,
975
+ } satisfies Model<"openai-completions">,
976
+ "google/gemma-4-31b-it": {
977
+ id: "google/gemma-4-31b-it",
978
+ name: "Google: Gemma 4 31B",
979
+ api: "openai-completions",
980
+ provider: "openrouter",
981
+ baseUrl: "https://openrouter.ai/api/v1",
982
+ reasoning: true,
983
+ input: ["text", "image"],
984
+ cost: {
985
+ input: 0.14,
986
+ output: 0.39999999999999997,
987
+ cacheRead: 0,
988
+ cacheWrite: 0,
989
+ },
990
+ contextWindow: 262144,
991
+ maxTokens: 131072,
992
+ } satisfies Model<"openai-completions">,
993
+ "google/gemma-4-31b-it:free": {
994
+ id: "google/gemma-4-31b-it:free",
995
+ name: "Google: Gemma 4 31B (free)",
996
+ api: "openai-completions",
997
+ provider: "openrouter",
998
+ baseUrl: "https://openrouter.ai/api/v1",
999
+ reasoning: true,
1000
+ input: ["text", "image"],
1001
+ cost: {
1002
+ input: 0,
1003
+ output: 0,
1004
+ cacheRead: 0,
1005
+ cacheWrite: 0,
1006
+ },
1007
+ contextWindow: 262144,
1008
+ maxTokens: 32768,
1009
+ } satisfies Model<"openai-completions">,
1010
+ "inception/mercury": {
1011
+ id: "inception/mercury",
1012
+ name: "Inception: Mercury",
1013
+ api: "openai-completions",
1014
+ provider: "openrouter",
1015
+ baseUrl: "https://openrouter.ai/api/v1",
1016
+ reasoning: false,
1017
+ input: ["text"],
1018
+ cost: {
1019
+ input: 0.25,
1020
+ output: 0.75,
1021
+ cacheRead: 0.024999999999999998,
1022
+ cacheWrite: 0,
1023
+ },
1024
+ contextWindow: 128000,
1025
+ maxTokens: 32000,
1026
+ } satisfies Model<"openai-completions">,
1027
+ "inception/mercury-2": {
1028
+ id: "inception/mercury-2",
1029
+ name: "Inception: Mercury 2",
1030
+ api: "openai-completions",
1031
+ provider: "openrouter",
1032
+ baseUrl: "https://openrouter.ai/api/v1",
1033
+ reasoning: true,
1034
+ input: ["text"],
1035
+ cost: {
1036
+ input: 0.25,
1037
+ output: 0.75,
1038
+ cacheRead: 0.024999999999999998,
1039
+ cacheWrite: 0,
1040
+ },
1041
+ contextWindow: 128000,
1042
+ maxTokens: 50000,
1043
+ } satisfies Model<"openai-completions">,
1044
+ "inception/mercury-coder": {
1045
+ id: "inception/mercury-coder",
1046
+ name: "Inception: Mercury Coder",
1047
+ api: "openai-completions",
1048
+ provider: "openrouter",
1049
+ baseUrl: "https://openrouter.ai/api/v1",
1050
+ reasoning: false,
1051
+ input: ["text"],
1052
+ cost: {
1053
+ input: 0.25,
1054
+ output: 0.75,
1055
+ cacheRead: 0.024999999999999998,
1056
+ cacheWrite: 0,
1057
+ },
1058
+ contextWindow: 128000,
1059
+ maxTokens: 32000,
1060
+ } satisfies Model<"openai-completions">,
1061
+ "kwaipilot/kat-coder-pro-v2": {
1062
+ id: "kwaipilot/kat-coder-pro-v2",
1063
+ name: "Kwaipilot: KAT-Coder-Pro V2",
1064
+ api: "openai-completions",
1065
+ provider: "openrouter",
1066
+ baseUrl: "https://openrouter.ai/api/v1",
1067
+ reasoning: false,
1068
+ input: ["text"],
1069
+ cost: {
1070
+ input: 0.3,
1071
+ output: 1.2,
1072
+ cacheRead: 0.06,
1073
+ cacheWrite: 0,
1074
+ },
1075
+ contextWindow: 256000,
1076
+ maxTokens: 80000,
1077
+ } satisfies Model<"openai-completions">,
1078
+ "meituan/longcat-flash-chat": {
1079
+ id: "meituan/longcat-flash-chat",
1080
+ name: "Meituan: LongCat Flash Chat",
1081
+ api: "openai-completions",
1082
+ provider: "openrouter",
1083
+ baseUrl: "https://openrouter.ai/api/v1",
1084
+ reasoning: false,
1085
+ input: ["text"],
1086
+ cost: {
1087
+ input: 0.19999999999999998,
1088
+ output: 0.7999999999999999,
1089
+ cacheRead: 0.19999999999999998,
1090
+ cacheWrite: 0,
1091
+ },
1092
+ contextWindow: 131072,
1093
+ maxTokens: 131072,
1094
+ } satisfies Model<"openai-completions">,
1095
+ "meta-llama/llama-3-8b-instruct": {
1096
+ id: "meta-llama/llama-3-8b-instruct",
1097
+ name: "Meta: Llama 3 8B Instruct",
1098
+ api: "openai-completions",
1099
+ provider: "openrouter",
1100
+ baseUrl: "https://openrouter.ai/api/v1",
1101
+ reasoning: false,
1102
+ input: ["text"],
1103
+ cost: {
1104
+ input: 0.03,
1105
+ output: 0.04,
1106
+ cacheRead: 0,
1107
+ cacheWrite: 0,
1108
+ },
1109
+ contextWindow: 8192,
1110
+ maxTokens: 16384,
1111
+ } satisfies Model<"openai-completions">,
1112
+ "meta-llama/llama-3.1-70b-instruct": {
1113
+ id: "meta-llama/llama-3.1-70b-instruct",
1114
+ name: "Meta: Llama 3.1 70B Instruct",
1115
+ api: "openai-completions",
1116
+ provider: "openrouter",
1117
+ baseUrl: "https://openrouter.ai/api/v1",
1118
+ reasoning: false,
1119
+ input: ["text"],
1120
+ cost: {
1121
+ input: 0.39999999999999997,
1122
+ output: 0.39999999999999997,
1123
+ cacheRead: 0,
1124
+ cacheWrite: 0,
1125
+ },
1126
+ contextWindow: 131072,
1127
+ maxTokens: 4096,
1128
+ } satisfies Model<"openai-completions">,
1129
+ "meta-llama/llama-3.1-8b-instruct": {
1130
+ id: "meta-llama/llama-3.1-8b-instruct",
1131
+ name: "Meta: Llama 3.1 8B Instruct",
1132
+ api: "openai-completions",
1133
+ provider: "openrouter",
1134
+ baseUrl: "https://openrouter.ai/api/v1",
1135
+ reasoning: false,
1136
+ input: ["text"],
1137
+ cost: {
1138
+ input: 0.02,
1139
+ output: 0.049999999999999996,
1140
+ cacheRead: 0,
1141
+ cacheWrite: 0,
1142
+ },
1143
+ contextWindow: 16384,
1144
+ maxTokens: 16384,
1145
+ } satisfies Model<"openai-completions">,
1146
+ "meta-llama/llama-3.3-70b-instruct": {
1147
+ id: "meta-llama/llama-3.3-70b-instruct",
1148
+ name: "Meta: Llama 3.3 70B Instruct",
1149
+ api: "openai-completions",
1150
+ provider: "openrouter",
1151
+ baseUrl: "https://openrouter.ai/api/v1",
1152
+ reasoning: false,
1153
+ input: ["text"],
1154
+ cost: {
1155
+ input: 0.09999999999999999,
1156
+ output: 0.32,
1157
+ cacheRead: 0,
1158
+ cacheWrite: 0,
1159
+ },
1160
+ contextWindow: 131072,
1161
+ maxTokens: 16384,
1162
+ } satisfies Model<"openai-completions">,
1163
+ "meta-llama/llama-3.3-70b-instruct:free": {
1164
+ id: "meta-llama/llama-3.3-70b-instruct:free",
1165
+ name: "Meta: Llama 3.3 70B Instruct (free)",
1166
+ api: "openai-completions",
1167
+ provider: "openrouter",
1168
+ baseUrl: "https://openrouter.ai/api/v1",
1169
+ reasoning: false,
1170
+ input: ["text"],
1171
+ cost: {
1172
+ input: 0,
1173
+ output: 0,
1174
+ cacheRead: 0,
1175
+ cacheWrite: 0,
1176
+ },
1177
+ contextWindow: 65536,
1178
+ maxTokens: 4096,
1179
+ } satisfies Model<"openai-completions">,
1180
+ "meta-llama/llama-4-maverick": {
1181
+ id: "meta-llama/llama-4-maverick",
1182
+ name: "Meta: Llama 4 Maverick",
1183
+ api: "openai-completions",
1184
+ provider: "openrouter",
1185
+ baseUrl: "https://openrouter.ai/api/v1",
1186
+ reasoning: false,
1187
+ input: ["text", "image"],
1188
+ cost: {
1189
+ input: 0.15,
1190
+ output: 0.6,
1191
+ cacheRead: 0,
1192
+ cacheWrite: 0,
1193
+ },
1194
+ contextWindow: 1048576,
1195
+ maxTokens: 16384,
1196
+ } satisfies Model<"openai-completions">,
1197
+ "meta-llama/llama-4-scout": {
1198
+ id: "meta-llama/llama-4-scout",
1199
+ name: "Meta: Llama 4 Scout",
1200
+ api: "openai-completions",
1201
+ provider: "openrouter",
1202
+ baseUrl: "https://openrouter.ai/api/v1",
1203
+ reasoning: false,
1204
+ input: ["text", "image"],
1205
+ cost: {
1206
+ input: 0.08,
1207
+ output: 0.3,
1208
+ cacheRead: 0,
1209
+ cacheWrite: 0,
1210
+ },
1211
+ contextWindow: 327680,
1212
+ maxTokens: 16384,
1213
+ } satisfies Model<"openai-completions">,
1214
+ "minimax/minimax-m1": {
1215
+ id: "minimax/minimax-m1",
1216
+ name: "MiniMax: MiniMax M1",
1217
+ api: "openai-completions",
1218
+ provider: "openrouter",
1219
+ baseUrl: "https://openrouter.ai/api/v1",
1220
+ reasoning: true,
1221
+ input: ["text"],
1222
+ cost: {
1223
+ input: 0.39999999999999997,
1224
+ output: 2.2,
1225
+ cacheRead: 0,
1226
+ cacheWrite: 0,
1227
+ },
1228
+ contextWindow: 1000000,
1229
+ maxTokens: 40000,
1230
+ } satisfies Model<"openai-completions">,
1231
+ "minimax/minimax-m2": {
1232
+ id: "minimax/minimax-m2",
1233
+ name: "MiniMax: MiniMax M2",
1234
+ api: "openai-completions",
1235
+ provider: "openrouter",
1236
+ baseUrl: "https://openrouter.ai/api/v1",
1237
+ reasoning: true,
1238
+ input: ["text"],
1239
+ cost: {
1240
+ input: 0.255,
1241
+ output: 1,
1242
+ cacheRead: 0.03,
1243
+ cacheWrite: 0,
1244
+ },
1245
+ contextWindow: 196608,
1246
+ maxTokens: 196608,
1247
+ } satisfies Model<"openai-completions">,
1248
+ "minimax/minimax-m2.1": {
1249
+ id: "minimax/minimax-m2.1",
1250
+ name: "MiniMax: MiniMax M2.1",
1251
+ api: "openai-completions",
1252
+ provider: "openrouter",
1253
+ baseUrl: "https://openrouter.ai/api/v1",
1254
+ reasoning: true,
1255
+ input: ["text"],
1256
+ cost: {
1257
+ input: 0.29,
1258
+ output: 0.95,
1259
+ cacheRead: 0.03,
1260
+ cacheWrite: 0,
1261
+ },
1262
+ contextWindow: 196608,
1263
+ maxTokens: 196608,
1264
+ } satisfies Model<"openai-completions">,
1265
+ "minimax/minimax-m2.5": {
1266
+ id: "minimax/minimax-m2.5",
1267
+ name: "MiniMax: MiniMax M2.5",
1268
+ api: "openai-completions",
1269
+ provider: "openrouter",
1270
+ baseUrl: "https://openrouter.ai/api/v1",
1271
+ reasoning: true,
1272
+ input: ["text"],
1273
+ cost: {
1274
+ input: 0.118,
1275
+ output: 0.9900000000000001,
1276
+ cacheRead: 0.059,
1277
+ cacheWrite: 0,
1278
+ },
1279
+ contextWindow: 196608,
1280
+ maxTokens: 65536,
1281
+ } satisfies Model<"openai-completions">,
1282
+ "minimax/minimax-m2.5:free": {
1283
+ id: "minimax/minimax-m2.5:free",
1284
+ name: "MiniMax: MiniMax M2.5 (free)",
1285
+ api: "openai-completions",
1286
+ provider: "openrouter",
1287
+ baseUrl: "https://openrouter.ai/api/v1",
1288
+ reasoning: true,
1289
+ input: ["text"],
1290
+ cost: {
1291
+ input: 0,
1292
+ output: 0,
1293
+ cacheRead: 0,
1294
+ cacheWrite: 0,
1295
+ },
1296
+ contextWindow: 196608,
1297
+ maxTokens: 8192,
1298
+ } satisfies Model<"openai-completions">,
1299
+ "minimax/minimax-m2.7": {
1300
+ id: "minimax/minimax-m2.7",
1301
+ name: "MiniMax: MiniMax M2.7",
1302
+ api: "openai-completions",
1303
+ provider: "openrouter",
1304
+ baseUrl: "https://openrouter.ai/api/v1",
1305
+ reasoning: true,
1306
+ input: ["text"],
1307
+ cost: {
1308
+ input: 0.3,
1309
+ output: 1.2,
1310
+ cacheRead: 0.059,
1311
+ cacheWrite: 0,
1312
+ },
1313
+ contextWindow: 196608,
1314
+ maxTokens: 4096,
1315
+ } satisfies Model<"openai-completions">,
1316
+ "mistralai/codestral-2508": {
1317
+ id: "mistralai/codestral-2508",
1318
+ name: "Mistral: Codestral 2508",
1319
+ api: "openai-completions",
1320
+ provider: "openrouter",
1321
+ baseUrl: "https://openrouter.ai/api/v1",
1322
+ reasoning: false,
1323
+ input: ["text"],
1324
+ cost: {
1325
+ input: 0.3,
1326
+ output: 0.8999999999999999,
1327
+ cacheRead: 0.03,
1328
+ cacheWrite: 0,
1329
+ },
1330
+ contextWindow: 256000,
1331
+ maxTokens: 4096,
1332
+ } satisfies Model<"openai-completions">,
1333
+ "mistralai/devstral-2512": {
1334
+ id: "mistralai/devstral-2512",
1335
+ name: "Mistral: Devstral 2 2512",
1336
+ api: "openai-completions",
1337
+ provider: "openrouter",
1338
+ baseUrl: "https://openrouter.ai/api/v1",
1339
+ reasoning: false,
1340
+ input: ["text"],
1341
+ cost: {
1342
+ input: 0.39999999999999997,
1343
+ output: 2,
1344
+ cacheRead: 0.04,
1345
+ cacheWrite: 0,
1346
+ },
1347
+ contextWindow: 262144,
1348
+ maxTokens: 4096,
1349
+ } satisfies Model<"openai-completions">,
1350
+ "mistralai/devstral-medium": {
1351
+ id: "mistralai/devstral-medium",
1352
+ name: "Mistral: Devstral Medium",
1353
+ api: "openai-completions",
1354
+ provider: "openrouter",
1355
+ baseUrl: "https://openrouter.ai/api/v1",
1356
+ reasoning: false,
1357
+ input: ["text"],
1358
+ cost: {
1359
+ input: 0.39999999999999997,
1360
+ output: 2,
1361
+ cacheRead: 0.04,
1362
+ cacheWrite: 0,
1363
+ },
1364
+ contextWindow: 131072,
1365
+ maxTokens: 4096,
1366
+ } satisfies Model<"openai-completions">,
1367
+ "mistralai/devstral-small": {
1368
+ id: "mistralai/devstral-small",
1369
+ name: "Mistral: Devstral Small 1.1",
1370
+ api: "openai-completions",
1371
+ provider: "openrouter",
1372
+ baseUrl: "https://openrouter.ai/api/v1",
1373
+ reasoning: false,
1374
+ input: ["text"],
1375
+ cost: {
1376
+ input: 0.09999999999999999,
1377
+ output: 0.3,
1378
+ cacheRead: 0.01,
1379
+ cacheWrite: 0,
1380
+ },
1381
+ contextWindow: 131072,
1382
+ maxTokens: 4096,
1383
+ } satisfies Model<"openai-completions">,
1384
+ "mistralai/ministral-14b-2512": {
1385
+ id: "mistralai/ministral-14b-2512",
1386
+ name: "Mistral: Ministral 3 14B 2512",
1387
+ api: "openai-completions",
1388
+ provider: "openrouter",
1389
+ baseUrl: "https://openrouter.ai/api/v1",
1390
+ reasoning: false,
1391
+ input: ["text", "image"],
1392
+ cost: {
1393
+ input: 0.19999999999999998,
1394
+ output: 0.19999999999999998,
1395
+ cacheRead: 0.02,
1396
+ cacheWrite: 0,
1397
+ },
1398
+ contextWindow: 262144,
1399
+ maxTokens: 4096,
1400
+ } satisfies Model<"openai-completions">,
1401
+ "mistralai/ministral-3b-2512": {
1402
+ id: "mistralai/ministral-3b-2512",
1403
+ name: "Mistral: Ministral 3 3B 2512",
1404
+ api: "openai-completions",
1405
+ provider: "openrouter",
1406
+ baseUrl: "https://openrouter.ai/api/v1",
1407
+ reasoning: false,
1408
+ input: ["text", "image"],
1409
+ cost: {
1410
+ input: 0.09999999999999999,
1411
+ output: 0.09999999999999999,
1412
+ cacheRead: 0.01,
1413
+ cacheWrite: 0,
1414
+ },
1415
+ contextWindow: 131072,
1416
+ maxTokens: 4096,
1417
+ } satisfies Model<"openai-completions">,
1418
+ "mistralai/ministral-8b-2512": {
1419
+ id: "mistralai/ministral-8b-2512",
1420
+ name: "Mistral: Ministral 3 8B 2512",
1421
+ api: "openai-completions",
1422
+ provider: "openrouter",
1423
+ baseUrl: "https://openrouter.ai/api/v1",
1424
+ reasoning: false,
1425
+ input: ["text", "image"],
1426
+ cost: {
1427
+ input: 0.15,
1428
+ output: 0.15,
1429
+ cacheRead: 0.015,
1430
+ cacheWrite: 0,
1431
+ },
1432
+ contextWindow: 262144,
1433
+ maxTokens: 4096,
1434
+ } satisfies Model<"openai-completions">,
1435
+ "mistralai/mistral-large": {
1436
+ id: "mistralai/mistral-large",
1437
+ name: "Mistral Large",
1438
+ api: "openai-completions",
1439
+ provider: "openrouter",
1440
+ baseUrl: "https://openrouter.ai/api/v1",
1441
+ reasoning: false,
1442
+ input: ["text"],
1443
+ cost: {
1444
+ input: 2,
1445
+ output: 6,
1446
+ cacheRead: 0.19999999999999998,
1447
+ cacheWrite: 0,
1448
+ },
1449
+ contextWindow: 128000,
1450
+ maxTokens: 4096,
1451
+ } satisfies Model<"openai-completions">,
1452
+ "mistralai/mistral-large-2407": {
1453
+ id: "mistralai/mistral-large-2407",
1454
+ name: "Mistral Large 2407",
1455
+ api: "openai-completions",
1456
+ provider: "openrouter",
1457
+ baseUrl: "https://openrouter.ai/api/v1",
1458
+ reasoning: false,
1459
+ input: ["text"],
1460
+ cost: {
1461
+ input: 2,
1462
+ output: 6,
1463
+ cacheRead: 0.19999999999999998,
1464
+ cacheWrite: 0,
1465
+ },
1466
+ contextWindow: 131072,
1467
+ maxTokens: 4096,
1468
+ } satisfies Model<"openai-completions">,
1469
+ "mistralai/mistral-large-2411": {
1470
+ id: "mistralai/mistral-large-2411",
1471
+ name: "Mistral Large 2411",
1472
+ api: "openai-completions",
1473
+ provider: "openrouter",
1474
+ baseUrl: "https://openrouter.ai/api/v1",
1475
+ reasoning: false,
1476
+ input: ["text"],
1477
+ cost: {
1478
+ input: 2,
1479
+ output: 6,
1480
+ cacheRead: 0.19999999999999998,
1481
+ cacheWrite: 0,
1482
+ },
1483
+ contextWindow: 131072,
1484
+ maxTokens: 4096,
1485
+ } satisfies Model<"openai-completions">,
1486
+ "mistralai/mistral-large-2512": {
1487
+ id: "mistralai/mistral-large-2512",
1488
+ name: "Mistral: Mistral Large 3 2512",
1489
+ api: "openai-completions",
1490
+ provider: "openrouter",
1491
+ baseUrl: "https://openrouter.ai/api/v1",
1492
+ reasoning: false,
1493
+ input: ["text", "image"],
1494
+ cost: {
1495
+ input: 0.5,
1496
+ output: 1.5,
1497
+ cacheRead: 0.049999999999999996,
1498
+ cacheWrite: 0,
1499
+ },
1500
+ contextWindow: 262144,
1501
+ maxTokens: 4096,
1502
+ } satisfies Model<"openai-completions">,
1503
+ "mistralai/mistral-medium-3": {
1504
+ id: "mistralai/mistral-medium-3",
1505
+ name: "Mistral: Mistral Medium 3",
1506
+ api: "openai-completions",
1507
+ provider: "openrouter",
1508
+ baseUrl: "https://openrouter.ai/api/v1",
1509
+ reasoning: false,
1510
+ input: ["text", "image"],
1511
+ cost: {
1512
+ input: 0.39999999999999997,
1513
+ output: 2,
1514
+ cacheRead: 0.04,
1515
+ cacheWrite: 0,
1516
+ },
1517
+ contextWindow: 131072,
1518
+ maxTokens: 4096,
1519
+ } satisfies Model<"openai-completions">,
1520
+ "mistralai/mistral-medium-3.1": {
1521
+ id: "mistralai/mistral-medium-3.1",
1522
+ name: "Mistral: Mistral Medium 3.1",
1523
+ api: "openai-completions",
1524
+ provider: "openrouter",
1525
+ baseUrl: "https://openrouter.ai/api/v1",
1526
+ reasoning: false,
1527
+ input: ["text", "image"],
1528
+ cost: {
1529
+ input: 0.39999999999999997,
1530
+ output: 2,
1531
+ cacheRead: 0.04,
1532
+ cacheWrite: 0,
1533
+ },
1534
+ contextWindow: 131072,
1535
+ maxTokens: 4096,
1536
+ } satisfies Model<"openai-completions">,
1537
+ "mistralai/mistral-nemo": {
1538
+ id: "mistralai/mistral-nemo",
1539
+ name: "Mistral: Mistral Nemo",
1540
+ api: "openai-completions",
1541
+ provider: "openrouter",
1542
+ baseUrl: "https://openrouter.ai/api/v1",
1543
+ reasoning: false,
1544
+ input: ["text"],
1545
+ cost: {
1546
+ input: 0.02,
1547
+ output: 0.04,
1548
+ cacheRead: 0,
1549
+ cacheWrite: 0,
1550
+ },
1551
+ contextWindow: 131072,
1552
+ maxTokens: 16384,
1553
+ } satisfies Model<"openai-completions">,
1554
+ "mistralai/mistral-saba": {
1555
+ id: "mistralai/mistral-saba",
1556
+ name: "Mistral: Saba",
1557
+ api: "openai-completions",
1558
+ provider: "openrouter",
1559
+ baseUrl: "https://openrouter.ai/api/v1",
1560
+ reasoning: false,
1561
+ input: ["text"],
1562
+ cost: {
1563
+ input: 0.19999999999999998,
1564
+ output: 0.6,
1565
+ cacheRead: 0.02,
1566
+ cacheWrite: 0,
1567
+ },
1568
+ contextWindow: 32768,
1569
+ maxTokens: 4096,
1570
+ } satisfies Model<"openai-completions">,
1571
+ "mistralai/mistral-small-2603": {
1572
+ id: "mistralai/mistral-small-2603",
1573
+ name: "Mistral: Mistral Small 4",
1574
+ api: "openai-completions",
1575
+ provider: "openrouter",
1576
+ baseUrl: "https://openrouter.ai/api/v1",
1577
+ reasoning: true,
1578
+ input: ["text", "image"],
1579
+ cost: {
1580
+ input: 0.15,
1581
+ output: 0.6,
1582
+ cacheRead: 0.015,
1583
+ cacheWrite: 0,
1584
+ },
1585
+ contextWindow: 262144,
1586
+ maxTokens: 4096,
1587
+ } satisfies Model<"openai-completions">,
1588
+ "mistralai/mistral-small-3.2-24b-instruct": {
1589
+ id: "mistralai/mistral-small-3.2-24b-instruct",
1590
+ name: "Mistral: Mistral Small 3.2 24B",
1591
+ api: "openai-completions",
1592
+ provider: "openrouter",
1593
+ baseUrl: "https://openrouter.ai/api/v1",
1594
+ reasoning: false,
1595
+ input: ["text", "image"],
1596
+ cost: {
1597
+ input: 0.075,
1598
+ output: 0.19999999999999998,
1599
+ cacheRead: 0,
1600
+ cacheWrite: 0,
1601
+ },
1602
+ contextWindow: 128000,
1603
+ maxTokens: 4096,
1604
+ } satisfies Model<"openai-completions">,
1605
+ "mistralai/mistral-small-creative": {
1606
+ id: "mistralai/mistral-small-creative",
1607
+ name: "Mistral: Mistral Small Creative",
1608
+ api: "openai-completions",
1609
+ provider: "openrouter",
1610
+ baseUrl: "https://openrouter.ai/api/v1",
1611
+ reasoning: false,
1612
+ input: ["text"],
1613
+ cost: {
1614
+ input: 0.09999999999999999,
1615
+ output: 0.3,
1616
+ cacheRead: 0.01,
1617
+ cacheWrite: 0,
1618
+ },
1619
+ contextWindow: 32768,
1620
+ maxTokens: 4096,
1621
+ } satisfies Model<"openai-completions">,
1622
+ "mistralai/mixtral-8x22b-instruct": {
1623
+ id: "mistralai/mixtral-8x22b-instruct",
1624
+ name: "Mistral: Mixtral 8x22B Instruct",
1625
+ api: "openai-completions",
1626
+ provider: "openrouter",
1627
+ baseUrl: "https://openrouter.ai/api/v1",
1628
+ reasoning: false,
1629
+ input: ["text"],
1630
+ cost: {
1631
+ input: 2,
1632
+ output: 6,
1633
+ cacheRead: 0.19999999999999998,
1634
+ cacheWrite: 0,
1635
+ },
1636
+ contextWindow: 65536,
1637
+ maxTokens: 4096,
1638
+ } satisfies Model<"openai-completions">,
1639
+ "mistralai/mixtral-8x7b-instruct": {
1640
+ id: "mistralai/mixtral-8x7b-instruct",
1641
+ name: "Mistral: Mixtral 8x7B Instruct",
1642
+ api: "openai-completions",
1643
+ provider: "openrouter",
1644
+ baseUrl: "https://openrouter.ai/api/v1",
1645
+ reasoning: false,
1646
+ input: ["text"],
1647
+ cost: {
1648
+ input: 0.54,
1649
+ output: 0.54,
1650
+ cacheRead: 0,
1651
+ cacheWrite: 0,
1652
+ },
1653
+ contextWindow: 32768,
1654
+ maxTokens: 16384,
1655
+ } satisfies Model<"openai-completions">,
1656
+ "mistralai/pixtral-large-2411": {
1657
+ id: "mistralai/pixtral-large-2411",
1658
+ name: "Mistral: Pixtral Large 2411",
1659
+ api: "openai-completions",
1660
+ provider: "openrouter",
1661
+ baseUrl: "https://openrouter.ai/api/v1",
1662
+ reasoning: false,
1663
+ input: ["text", "image"],
1664
+ cost: {
1665
+ input: 2,
1666
+ output: 6,
1667
+ cacheRead: 0.19999999999999998,
1668
+ cacheWrite: 0,
1669
+ },
1670
+ contextWindow: 131072,
1671
+ maxTokens: 4096,
1672
+ } satisfies Model<"openai-completions">,
1673
+ "mistralai/voxtral-small-24b-2507": {
1674
+ id: "mistralai/voxtral-small-24b-2507",
1675
+ name: "Mistral: Voxtral Small 24B 2507",
1676
+ api: "openai-completions",
1677
+ provider: "openrouter",
1678
+ baseUrl: "https://openrouter.ai/api/v1",
1679
+ reasoning: false,
1680
+ input: ["text"],
1681
+ cost: {
1682
+ input: 0.09999999999999999,
1683
+ output: 0.3,
1684
+ cacheRead: 0.01,
1685
+ cacheWrite: 0,
1686
+ },
1687
+ contextWindow: 32000,
1688
+ maxTokens: 4096,
1689
+ } satisfies Model<"openai-completions">,
1690
+ "moonshotai/kimi-k2": {
1691
+ id: "moonshotai/kimi-k2",
1692
+ name: "MoonshotAI: Kimi K2 0711",
1693
+ api: "openai-completions",
1694
+ provider: "openrouter",
1695
+ baseUrl: "https://openrouter.ai/api/v1",
1696
+ reasoning: false,
1697
+ input: ["text"],
1698
+ cost: {
1699
+ input: 0.5700000000000001,
1700
+ output: 2.3,
1701
+ cacheRead: 0,
1702
+ cacheWrite: 0,
1703
+ },
1704
+ contextWindow: 131072,
1705
+ maxTokens: 131072,
1706
+ } satisfies Model<"openai-completions">,
1707
+ "moonshotai/kimi-k2-0905": {
1708
+ id: "moonshotai/kimi-k2-0905",
1709
+ name: "MoonshotAI: Kimi K2 0905",
1710
+ api: "openai-completions",
1711
+ provider: "openrouter",
1712
+ baseUrl: "https://openrouter.ai/api/v1",
1713
+ reasoning: false,
1714
+ input: ["text"],
1715
+ cost: {
1716
+ input: 0.39999999999999997,
1717
+ output: 2,
1718
+ cacheRead: 0,
1719
+ cacheWrite: 0,
1720
+ },
1721
+ contextWindow: 262144,
1722
+ maxTokens: 262144,
1723
+ } satisfies Model<"openai-completions">,
1724
+ "moonshotai/kimi-k2-thinking": {
1725
+ id: "moonshotai/kimi-k2-thinking",
1726
+ name: "MoonshotAI: Kimi K2 Thinking",
1727
+ api: "openai-completions",
1728
+ provider: "openrouter",
1729
+ baseUrl: "https://openrouter.ai/api/v1",
1730
+ reasoning: true,
1731
+ input: ["text"],
1732
+ cost: {
1733
+ input: 0.6,
1734
+ output: 2.5,
1735
+ cacheRead: 0,
1736
+ cacheWrite: 0,
1737
+ },
1738
+ contextWindow: 262144,
1739
+ maxTokens: 4096,
1740
+ } satisfies Model<"openai-completions">,
1741
+ "moonshotai/kimi-k2.5": {
1742
+ id: "moonshotai/kimi-k2.5",
1743
+ name: "MoonshotAI: Kimi K2.5",
1744
+ api: "openai-completions",
1745
+ provider: "openrouter",
1746
+ baseUrl: "https://openrouter.ai/api/v1",
1747
+ reasoning: true,
1748
+ input: ["text", "image"],
1749
+ cost: {
1750
+ input: 0.41,
1751
+ output: 2.06,
1752
+ cacheRead: 0.07,
1753
+ cacheWrite: 0,
1754
+ },
1755
+ contextWindow: 262144,
1756
+ maxTokens: 4096,
1757
+ } satisfies Model<"openai-completions">,
1758
+ "nex-agi/deepseek-v3.1-nex-n1": {
1759
+ id: "nex-agi/deepseek-v3.1-nex-n1",
1760
+ name: "Nex AGI: DeepSeek V3.1 Nex N1",
1761
+ api: "openai-completions",
1762
+ provider: "openrouter",
1763
+ baseUrl: "https://openrouter.ai/api/v1",
1764
+ reasoning: false,
1765
+ input: ["text"],
1766
+ cost: {
1767
+ input: 0.135,
1768
+ output: 0.5,
1769
+ cacheRead: 0,
1770
+ cacheWrite: 0,
1771
+ },
1772
+ contextWindow: 131072,
1773
+ maxTokens: 163840,
1774
+ } satisfies Model<"openai-completions">,
1775
+ "nvidia/llama-3.1-nemotron-70b-instruct": {
1776
+ id: "nvidia/llama-3.1-nemotron-70b-instruct",
1777
+ name: "NVIDIA: Llama 3.1 Nemotron 70B Instruct",
1778
+ api: "openai-completions",
1779
+ provider: "openrouter",
1780
+ baseUrl: "https://openrouter.ai/api/v1",
1781
+ reasoning: false,
1782
+ input: ["text"],
1783
+ cost: {
1784
+ input: 1.2,
1785
+ output: 1.2,
1786
+ cacheRead: 0,
1787
+ cacheWrite: 0,
1788
+ },
1789
+ contextWindow: 131072,
1790
+ maxTokens: 16384,
1791
+ } satisfies Model<"openai-completions">,
1792
+ "nvidia/llama-3.3-nemotron-super-49b-v1.5": {
1793
+ id: "nvidia/llama-3.3-nemotron-super-49b-v1.5",
1794
+ name: "NVIDIA: Llama 3.3 Nemotron Super 49B V1.5",
1795
+ api: "openai-completions",
1796
+ provider: "openrouter",
1797
+ baseUrl: "https://openrouter.ai/api/v1",
1798
+ reasoning: true,
1799
+ input: ["text"],
1800
+ cost: {
1801
+ input: 0.09999999999999999,
1802
+ output: 0.39999999999999997,
1803
+ cacheRead: 0,
1804
+ cacheWrite: 0,
1805
+ },
1806
+ contextWindow: 131072,
1807
+ maxTokens: 4096,
1808
+ } satisfies Model<"openai-completions">,
1809
+ "nvidia/nemotron-3-nano-30b-a3b": {
1810
+ id: "nvidia/nemotron-3-nano-30b-a3b",
1811
+ name: "NVIDIA: Nemotron 3 Nano 30B A3B",
1812
+ api: "openai-completions",
1813
+ provider: "openrouter",
1814
+ baseUrl: "https://openrouter.ai/api/v1",
1815
+ reasoning: true,
1816
+ input: ["text"],
1817
+ cost: {
1818
+ input: 0.049999999999999996,
1819
+ output: 0.19999999999999998,
1820
+ cacheRead: 0,
1821
+ cacheWrite: 0,
1822
+ },
1823
+ contextWindow: 262144,
1824
+ maxTokens: 4096,
1825
+ } satisfies Model<"openai-completions">,
1826
+ "nvidia/nemotron-3-nano-30b-a3b:free": {
1827
+ id: "nvidia/nemotron-3-nano-30b-a3b:free",
1828
+ name: "NVIDIA: Nemotron 3 Nano 30B A3B (free)",
1829
+ api: "openai-completions",
1830
+ provider: "openrouter",
1831
+ baseUrl: "https://openrouter.ai/api/v1",
1832
+ reasoning: true,
1833
+ input: ["text"],
1834
+ cost: {
1835
+ input: 0,
1836
+ output: 0,
1837
+ cacheRead: 0,
1838
+ cacheWrite: 0,
1839
+ },
1840
+ contextWindow: 256000,
1841
+ maxTokens: 4096,
1842
+ } satisfies Model<"openai-completions">,
1843
+ "nvidia/nemotron-3-super-120b-a12b": {
1844
+ id: "nvidia/nemotron-3-super-120b-a12b",
1845
+ name: "NVIDIA: Nemotron 3 Super",
1846
+ api: "openai-completions",
1847
+ provider: "openrouter",
1848
+ baseUrl: "https://openrouter.ai/api/v1",
1849
+ reasoning: true,
1850
+ input: ["text"],
1851
+ cost: {
1852
+ input: 0.09999999999999999,
1853
+ output: 0.5,
1854
+ cacheRead: 0.09999999999999999,
1855
+ cacheWrite: 0,
1856
+ },
1857
+ contextWindow: 262144,
1858
+ maxTokens: 4096,
1859
+ } satisfies Model<"openai-completions">,
1860
+ "nvidia/nemotron-3-super-120b-a12b:free": {
1861
+ id: "nvidia/nemotron-3-super-120b-a12b:free",
1862
+ name: "NVIDIA: Nemotron 3 Super (free)",
1863
+ api: "openai-completions",
1864
+ provider: "openrouter",
1865
+ baseUrl: "https://openrouter.ai/api/v1",
1866
+ reasoning: true,
1867
+ input: ["text"],
1868
+ cost: {
1869
+ input: 0,
1870
+ output: 0,
1871
+ cacheRead: 0,
1872
+ cacheWrite: 0,
1873
+ },
1874
+ contextWindow: 262144,
1875
+ maxTokens: 262144,
1876
+ } satisfies Model<"openai-completions">,
1877
+ "nvidia/nemotron-nano-12b-v2-vl:free": {
1878
+ id: "nvidia/nemotron-nano-12b-v2-vl:free",
1879
+ name: "NVIDIA: Nemotron Nano 12B 2 VL (free)",
1880
+ api: "openai-completions",
1881
+ provider: "openrouter",
1882
+ baseUrl: "https://openrouter.ai/api/v1",
1883
+ reasoning: true,
1884
+ input: ["text", "image"],
1885
+ cost: {
1886
+ input: 0,
1887
+ output: 0,
1888
+ cacheRead: 0,
1889
+ cacheWrite: 0,
1890
+ },
1891
+ contextWindow: 128000,
1892
+ maxTokens: 128000,
1893
+ } satisfies Model<"openai-completions">,
1894
+ "nvidia/nemotron-nano-9b-v2": {
1895
+ id: "nvidia/nemotron-nano-9b-v2",
1896
+ name: "NVIDIA: Nemotron Nano 9B V2",
1897
+ api: "openai-completions",
1898
+ provider: "openrouter",
1899
+ baseUrl: "https://openrouter.ai/api/v1",
1900
+ reasoning: true,
1901
+ input: ["text"],
1902
+ cost: {
1903
+ input: 0.04,
1904
+ output: 0.16,
1905
+ cacheRead: 0,
1906
+ cacheWrite: 0,
1907
+ },
1908
+ contextWindow: 131072,
1909
+ maxTokens: 4096,
1910
+ } satisfies Model<"openai-completions">,
1911
+ "nvidia/nemotron-nano-9b-v2:free": {
1912
+ id: "nvidia/nemotron-nano-9b-v2:free",
1913
+ name: "NVIDIA: Nemotron Nano 9B V2 (free)",
1914
+ api: "openai-completions",
1915
+ provider: "openrouter",
1916
+ baseUrl: "https://openrouter.ai/api/v1",
1917
+ reasoning: true,
1918
+ input: ["text"],
1919
+ cost: {
1920
+ input: 0,
1921
+ output: 0,
1922
+ cacheRead: 0,
1923
+ cacheWrite: 0,
1924
+ },
1925
+ contextWindow: 128000,
1926
+ maxTokens: 4096,
1927
+ } satisfies Model<"openai-completions">,
1928
+ "openai/gpt-3.5-turbo": {
1929
+ id: "openai/gpt-3.5-turbo",
1930
+ name: "OpenAI: GPT-3.5 Turbo",
1931
+ api: "openai-completions",
1932
+ provider: "openrouter",
1933
+ baseUrl: "https://openrouter.ai/api/v1",
1934
+ reasoning: false,
1935
+ input: ["text"],
1936
+ cost: {
1937
+ input: 0.5,
1938
+ output: 1.5,
1939
+ cacheRead: 0,
1940
+ cacheWrite: 0,
1941
+ },
1942
+ contextWindow: 16385,
1943
+ maxTokens: 4096,
1944
+ } satisfies Model<"openai-completions">,
1945
+ "openai/gpt-3.5-turbo-0613": {
1946
+ id: "openai/gpt-3.5-turbo-0613",
1947
+ name: "OpenAI: GPT-3.5 Turbo (older v0613)",
1948
+ api: "openai-completions",
1949
+ provider: "openrouter",
1950
+ baseUrl: "https://openrouter.ai/api/v1",
1951
+ reasoning: false,
1952
+ input: ["text"],
1953
+ cost: {
1954
+ input: 1,
1955
+ output: 2,
1956
+ cacheRead: 0,
1957
+ cacheWrite: 0,
1958
+ },
1959
+ contextWindow: 4095,
1960
+ maxTokens: 4096,
1961
+ } satisfies Model<"openai-completions">,
1962
+ "openai/gpt-3.5-turbo-16k": {
1963
+ id: "openai/gpt-3.5-turbo-16k",
1964
+ name: "OpenAI: GPT-3.5 Turbo 16k",
1965
+ api: "openai-completions",
1966
+ provider: "openrouter",
1967
+ baseUrl: "https://openrouter.ai/api/v1",
1968
+ reasoning: false,
1969
+ input: ["text"],
1970
+ cost: {
1971
+ input: 3,
1972
+ output: 4,
1973
+ cacheRead: 0,
1974
+ cacheWrite: 0,
1975
+ },
1976
+ contextWindow: 16385,
1977
+ maxTokens: 4096,
1978
+ } satisfies Model<"openai-completions">,
1979
+ "openai/gpt-4": {
1980
+ id: "openai/gpt-4",
1981
+ name: "OpenAI: GPT-4",
1982
+ api: "openai-completions",
1983
+ provider: "openrouter",
1984
+ baseUrl: "https://openrouter.ai/api/v1",
1985
+ reasoning: false,
1986
+ input: ["text"],
1987
+ cost: {
1988
+ input: 30,
1989
+ output: 60,
1990
+ cacheRead: 0,
1991
+ cacheWrite: 0,
1992
+ },
1993
+ contextWindow: 8191,
1994
+ maxTokens: 4096,
1995
+ } satisfies Model<"openai-completions">,
1996
+ "openai/gpt-4-0314": {
1997
+ id: "openai/gpt-4-0314",
1998
+ name: "OpenAI: GPT-4 (older v0314)",
1999
+ api: "openai-completions",
2000
+ provider: "openrouter",
2001
+ baseUrl: "https://openrouter.ai/api/v1",
2002
+ reasoning: false,
2003
+ input: ["text"],
2004
+ cost: {
2005
+ input: 30,
2006
+ output: 60,
2007
+ cacheRead: 0,
2008
+ cacheWrite: 0,
2009
+ },
2010
+ contextWindow: 8191,
2011
+ maxTokens: 4096,
2012
+ } satisfies Model<"openai-completions">,
2013
+ "openai/gpt-4-1106-preview": {
2014
+ id: "openai/gpt-4-1106-preview",
2015
+ name: "OpenAI: GPT-4 Turbo (older v1106)",
2016
+ api: "openai-completions",
2017
+ provider: "openrouter",
2018
+ baseUrl: "https://openrouter.ai/api/v1",
2019
+ reasoning: false,
2020
+ input: ["text"],
2021
+ cost: {
2022
+ input: 10,
2023
+ output: 30,
2024
+ cacheRead: 0,
2025
+ cacheWrite: 0,
2026
+ },
2027
+ contextWindow: 128000,
2028
+ maxTokens: 4096,
2029
+ } satisfies Model<"openai-completions">,
2030
+ "openai/gpt-4-turbo": {
2031
+ id: "openai/gpt-4-turbo",
2032
+ name: "OpenAI: GPT-4 Turbo",
2033
+ api: "openai-completions",
2034
+ provider: "openrouter",
2035
+ baseUrl: "https://openrouter.ai/api/v1",
2036
+ reasoning: false,
2037
+ input: ["text", "image"],
2038
+ cost: {
2039
+ input: 10,
2040
+ output: 30,
2041
+ cacheRead: 0,
2042
+ cacheWrite: 0,
2043
+ },
2044
+ contextWindow: 128000,
2045
+ maxTokens: 4096,
2046
+ } satisfies Model<"openai-completions">,
2047
+ "openai/gpt-4-turbo-preview": {
2048
+ id: "openai/gpt-4-turbo-preview",
2049
+ name: "OpenAI: GPT-4 Turbo Preview",
2050
+ api: "openai-completions",
2051
+ provider: "openrouter",
2052
+ baseUrl: "https://openrouter.ai/api/v1",
2053
+ reasoning: false,
2054
+ input: ["text"],
2055
+ cost: {
2056
+ input: 10,
2057
+ output: 30,
2058
+ cacheRead: 0,
2059
+ cacheWrite: 0,
2060
+ },
2061
+ contextWindow: 128000,
2062
+ maxTokens: 4096,
2063
+ } satisfies Model<"openai-completions">,
2064
+ "openai/gpt-4.1": {
2065
+ id: "openai/gpt-4.1",
2066
+ name: "OpenAI: GPT-4.1",
2067
+ api: "openai-completions",
2068
+ provider: "openrouter",
2069
+ baseUrl: "https://openrouter.ai/api/v1",
2070
+ reasoning: false,
2071
+ input: ["text", "image"],
2072
+ cost: {
2073
+ input: 2,
2074
+ output: 8,
2075
+ cacheRead: 0.5,
2076
+ cacheWrite: 0,
2077
+ },
2078
+ contextWindow: 1047576,
2079
+ maxTokens: 4096,
2080
+ } satisfies Model<"openai-completions">,
2081
+ "openai/gpt-4.1-mini": {
2082
+ id: "openai/gpt-4.1-mini",
2083
+ name: "OpenAI: GPT-4.1 Mini",
2084
+ api: "openai-completions",
2085
+ provider: "openrouter",
2086
+ baseUrl: "https://openrouter.ai/api/v1",
2087
+ reasoning: false,
2088
+ input: ["text", "image"],
2089
+ cost: {
2090
+ input: 0.39999999999999997,
2091
+ output: 1.5999999999999999,
2092
+ cacheRead: 0.09999999999999999,
2093
+ cacheWrite: 0,
2094
+ },
2095
+ contextWindow: 1047576,
2096
+ maxTokens: 32768,
2097
+ } satisfies Model<"openai-completions">,
2098
+ "openai/gpt-4.1-nano": {
2099
+ id: "openai/gpt-4.1-nano",
2100
+ name: "OpenAI: GPT-4.1 Nano",
2101
+ api: "openai-completions",
2102
+ provider: "openrouter",
2103
+ baseUrl: "https://openrouter.ai/api/v1",
2104
+ reasoning: false,
2105
+ input: ["text", "image"],
2106
+ cost: {
2107
+ input: 0.09999999999999999,
2108
+ output: 0.39999999999999997,
2109
+ cacheRead: 0.024999999999999998,
2110
+ cacheWrite: 0,
2111
+ },
2112
+ contextWindow: 1047576,
2113
+ maxTokens: 32768,
2114
+ } satisfies Model<"openai-completions">,
2115
+ "openai/gpt-4o": {
2116
+ id: "openai/gpt-4o",
2117
+ name: "OpenAI: GPT-4o",
2118
+ api: "openai-completions",
2119
+ provider: "openrouter",
2120
+ baseUrl: "https://openrouter.ai/api/v1",
2121
+ reasoning: false,
2122
+ input: ["text", "image"],
2123
+ cost: {
2124
+ input: 2.5,
2125
+ output: 10,
2126
+ cacheRead: 0,
2127
+ cacheWrite: 0,
2128
+ },
2129
+ contextWindow: 128000,
2130
+ maxTokens: 16384,
2131
+ } satisfies Model<"openai-completions">,
2132
+ "openai/gpt-4o-2024-05-13": {
2133
+ id: "openai/gpt-4o-2024-05-13",
2134
+ name: "OpenAI: GPT-4o (2024-05-13)",
2135
+ api: "openai-completions",
2136
+ provider: "openrouter",
2137
+ baseUrl: "https://openrouter.ai/api/v1",
2138
+ reasoning: false,
2139
+ input: ["text", "image"],
2140
+ cost: {
2141
+ input: 5,
2142
+ output: 15,
2143
+ cacheRead: 0,
2144
+ cacheWrite: 0,
2145
+ },
2146
+ contextWindow: 128000,
2147
+ maxTokens: 4096,
2148
+ } satisfies Model<"openai-completions">,
2149
+ "openai/gpt-4o-2024-08-06": {
2150
+ id: "openai/gpt-4o-2024-08-06",
2151
+ name: "OpenAI: GPT-4o (2024-08-06)",
2152
+ api: "openai-completions",
2153
+ provider: "openrouter",
2154
+ baseUrl: "https://openrouter.ai/api/v1",
2155
+ reasoning: false,
2156
+ input: ["text", "image"],
2157
+ cost: {
2158
+ input: 2.5,
2159
+ output: 10,
2160
+ cacheRead: 1.25,
2161
+ cacheWrite: 0,
2162
+ },
2163
+ contextWindow: 128000,
2164
+ maxTokens: 16384,
2165
+ } satisfies Model<"openai-completions">,
2166
+ "openai/gpt-4o-2024-11-20": {
2167
+ id: "openai/gpt-4o-2024-11-20",
2168
+ name: "OpenAI: GPT-4o (2024-11-20)",
2169
+ api: "openai-completions",
2170
+ provider: "openrouter",
2171
+ baseUrl: "https://openrouter.ai/api/v1",
2172
+ reasoning: false,
2173
+ input: ["text", "image"],
2174
+ cost: {
2175
+ input: 2.5,
2176
+ output: 10,
2177
+ cacheRead: 1.25,
2178
+ cacheWrite: 0,
2179
+ },
2180
+ contextWindow: 128000,
2181
+ maxTokens: 16384,
2182
+ } satisfies Model<"openai-completions">,
2183
+ "openai/gpt-4o-audio-preview": {
2184
+ id: "openai/gpt-4o-audio-preview",
2185
+ name: "OpenAI: GPT-4o Audio",
2186
+ api: "openai-completions",
2187
+ provider: "openrouter",
2188
+ baseUrl: "https://openrouter.ai/api/v1",
2189
+ reasoning: false,
2190
+ input: ["text"],
2191
+ cost: {
2192
+ input: 2.5,
2193
+ output: 10,
2194
+ cacheRead: 0,
2195
+ cacheWrite: 0,
2196
+ },
2197
+ contextWindow: 128000,
2198
+ maxTokens: 16384,
2199
+ } satisfies Model<"openai-completions">,
2200
+ "openai/gpt-4o-mini": {
2201
+ id: "openai/gpt-4o-mini",
2202
+ name: "OpenAI: GPT-4o-mini",
2203
+ api: "openai-completions",
2204
+ provider: "openrouter",
2205
+ baseUrl: "https://openrouter.ai/api/v1",
2206
+ reasoning: false,
2207
+ input: ["text", "image"],
2208
+ cost: {
2209
+ input: 0.15,
2210
+ output: 0.6,
2211
+ cacheRead: 0.075,
2212
+ cacheWrite: 0,
2213
+ },
2214
+ contextWindow: 128000,
2215
+ maxTokens: 16384,
2216
+ } satisfies Model<"openai-completions">,
2217
+ "openai/gpt-4o-mini-2024-07-18": {
2218
+ id: "openai/gpt-4o-mini-2024-07-18",
2219
+ name: "OpenAI: GPT-4o-mini (2024-07-18)",
2220
+ api: "openai-completions",
2221
+ provider: "openrouter",
2222
+ baseUrl: "https://openrouter.ai/api/v1",
2223
+ reasoning: false,
2224
+ input: ["text", "image"],
2225
+ cost: {
2226
+ input: 0.15,
2227
+ output: 0.6,
2228
+ cacheRead: 0.075,
2229
+ cacheWrite: 0,
2230
+ },
2231
+ contextWindow: 128000,
2232
+ maxTokens: 16384,
2233
+ } satisfies Model<"openai-completions">,
2234
+ "openai/gpt-4o:extended": {
2235
+ id: "openai/gpt-4o:extended",
2236
+ name: "OpenAI: GPT-4o (extended)",
2237
+ api: "openai-completions",
2238
+ provider: "openrouter",
2239
+ baseUrl: "https://openrouter.ai/api/v1",
2240
+ reasoning: false,
2241
+ input: ["text", "image"],
2242
+ cost: {
2243
+ input: 6,
2244
+ output: 18,
2245
+ cacheRead: 0,
2246
+ cacheWrite: 0,
2247
+ },
2248
+ contextWindow: 128000,
2249
+ maxTokens: 64000,
2250
+ } satisfies Model<"openai-completions">,
2251
+ "openai/gpt-5": {
2252
+ id: "openai/gpt-5",
2253
+ name: "OpenAI: GPT-5",
2254
+ api: "openai-completions",
2255
+ provider: "openrouter",
2256
+ baseUrl: "https://openrouter.ai/api/v1",
2257
+ reasoning: true,
2258
+ input: ["text", "image"],
2259
+ cost: {
2260
+ input: 1.25,
2261
+ output: 10,
2262
+ cacheRead: 0.125,
2263
+ cacheWrite: 0,
2264
+ },
2265
+ contextWindow: 400000,
2266
+ maxTokens: 128000,
2267
+ } satisfies Model<"openai-completions">,
2268
+ "openai/gpt-5-codex": {
2269
+ id: "openai/gpt-5-codex",
2270
+ name: "OpenAI: GPT-5 Codex",
2271
+ api: "openai-completions",
2272
+ provider: "openrouter",
2273
+ baseUrl: "https://openrouter.ai/api/v1",
2274
+ reasoning: true,
2275
+ input: ["text", "image"],
2276
+ cost: {
2277
+ input: 1.25,
2278
+ output: 10,
2279
+ cacheRead: 0.125,
2280
+ cacheWrite: 0,
2281
+ },
2282
+ contextWindow: 400000,
2283
+ maxTokens: 128000,
2284
+ } satisfies Model<"openai-completions">,
2285
+ "openai/gpt-5-image": {
2286
+ id: "openai/gpt-5-image",
2287
+ name: "OpenAI: GPT-5 Image",
2288
+ api: "openai-completions",
2289
+ provider: "openrouter",
2290
+ baseUrl: "https://openrouter.ai/api/v1",
2291
+ reasoning: true,
2292
+ input: ["text", "image"],
2293
+ cost: {
2294
+ input: 10,
2295
+ output: 10,
2296
+ cacheRead: 1.25,
2297
+ cacheWrite: 0,
2298
+ },
2299
+ contextWindow: 400000,
2300
+ maxTokens: 128000,
2301
+ } satisfies Model<"openai-completions">,
2302
+ "openai/gpt-5-image-mini": {
2303
+ id: "openai/gpt-5-image-mini",
2304
+ name: "OpenAI: GPT-5 Image Mini",
2305
+ api: "openai-completions",
2306
+ provider: "openrouter",
2307
+ baseUrl: "https://openrouter.ai/api/v1",
2308
+ reasoning: true,
2309
+ input: ["text", "image"],
2310
+ cost: {
2311
+ input: 2.5,
2312
+ output: 2,
2313
+ cacheRead: 0.25,
2314
+ cacheWrite: 0,
2315
+ },
2316
+ contextWindow: 400000,
2317
+ maxTokens: 128000,
2318
+ } satisfies Model<"openai-completions">,
2319
+ "openai/gpt-5-mini": {
2320
+ id: "openai/gpt-5-mini",
2321
+ name: "OpenAI: GPT-5 Mini",
2322
+ api: "openai-completions",
2323
+ provider: "openrouter",
2324
+ baseUrl: "https://openrouter.ai/api/v1",
2325
+ reasoning: true,
2326
+ input: ["text", "image"],
2327
+ cost: {
2328
+ input: 0.25,
2329
+ output: 2,
2330
+ cacheRead: 0.024999999999999998,
2331
+ cacheWrite: 0,
2332
+ },
2333
+ contextWindow: 400000,
2334
+ maxTokens: 128000,
2335
+ } satisfies Model<"openai-completions">,
2336
+ "openai/gpt-5-nano": {
2337
+ id: "openai/gpt-5-nano",
2338
+ name: "OpenAI: GPT-5 Nano",
2339
+ api: "openai-completions",
2340
+ provider: "openrouter",
2341
+ baseUrl: "https://openrouter.ai/api/v1",
2342
+ reasoning: true,
2343
+ input: ["text", "image"],
2344
+ cost: {
2345
+ input: 0.049999999999999996,
2346
+ output: 0.39999999999999997,
2347
+ cacheRead: 0.01,
2348
+ cacheWrite: 0,
2349
+ },
2350
+ contextWindow: 400000,
2351
+ maxTokens: 4096,
2352
+ } satisfies Model<"openai-completions">,
2353
+ "openai/gpt-5-pro": {
2354
+ id: "openai/gpt-5-pro",
2355
+ name: "OpenAI: GPT-5 Pro",
2356
+ api: "openai-completions",
2357
+ provider: "openrouter",
2358
+ baseUrl: "https://openrouter.ai/api/v1",
2359
+ reasoning: true,
2360
+ input: ["text", "image"],
2361
+ cost: {
2362
+ input: 15,
2363
+ output: 120,
2364
+ cacheRead: 0,
2365
+ cacheWrite: 0,
2366
+ },
2367
+ contextWindow: 400000,
2368
+ maxTokens: 128000,
2369
+ } satisfies Model<"openai-completions">,
2370
+ "openai/gpt-5.1": {
2371
+ id: "openai/gpt-5.1",
2372
+ name: "OpenAI: GPT-5.1",
2373
+ api: "openai-completions",
2374
+ provider: "openrouter",
2375
+ baseUrl: "https://openrouter.ai/api/v1",
2376
+ reasoning: true,
2377
+ input: ["text", "image"],
2378
+ cost: {
2379
+ input: 1.25,
2380
+ output: 10,
2381
+ cacheRead: 0.13,
2382
+ cacheWrite: 0,
2383
+ },
2384
+ contextWindow: 400000,
2385
+ maxTokens: 128000,
2386
+ } satisfies Model<"openai-completions">,
2387
+ "openai/gpt-5.1-chat": {
2388
+ id: "openai/gpt-5.1-chat",
2389
+ name: "OpenAI: GPT-5.1 Chat",
2390
+ api: "openai-completions",
2391
+ provider: "openrouter",
2392
+ baseUrl: "https://openrouter.ai/api/v1",
2393
+ reasoning: false,
2394
+ input: ["text", "image"],
2395
+ cost: {
2396
+ input: 1.25,
2397
+ output: 10,
2398
+ cacheRead: 0.125,
2399
+ cacheWrite: 0,
2400
+ },
2401
+ contextWindow: 128000,
2402
+ maxTokens: 16384,
2403
+ } satisfies Model<"openai-completions">,
2404
+ "openai/gpt-5.1-codex": {
2405
+ id: "openai/gpt-5.1-codex",
2406
+ name: "OpenAI: GPT-5.1-Codex",
2407
+ api: "openai-completions",
2408
+ provider: "openrouter",
2409
+ baseUrl: "https://openrouter.ai/api/v1",
2410
+ reasoning: true,
2411
+ input: ["text", "image"],
2412
+ cost: {
2413
+ input: 1.25,
2414
+ output: 10,
2415
+ cacheRead: 0.125,
2416
+ cacheWrite: 0,
2417
+ },
2418
+ contextWindow: 400000,
2419
+ maxTokens: 128000,
2420
+ } satisfies Model<"openai-completions">,
2421
+ "openai/gpt-5.1-codex-max": {
2422
+ id: "openai/gpt-5.1-codex-max",
2423
+ name: "OpenAI: GPT-5.1-Codex-Max",
2424
+ api: "openai-completions",
2425
+ provider: "openrouter",
2426
+ baseUrl: "https://openrouter.ai/api/v1",
2427
+ reasoning: true,
2428
+ input: ["text", "image"],
2429
+ cost: {
2430
+ input: 1.25,
2431
+ output: 10,
2432
+ cacheRead: 0.125,
2433
+ cacheWrite: 0,
2434
+ },
2435
+ contextWindow: 400000,
2436
+ maxTokens: 128000,
2437
+ } satisfies Model<"openai-completions">,
2438
+ "openai/gpt-5.1-codex-mini": {
2439
+ id: "openai/gpt-5.1-codex-mini",
2440
+ name: "OpenAI: GPT-5.1-Codex-Mini",
2441
+ api: "openai-completions",
2442
+ provider: "openrouter",
2443
+ baseUrl: "https://openrouter.ai/api/v1",
2444
+ reasoning: true,
2445
+ input: ["text", "image"],
2446
+ cost: {
2447
+ input: 0.25,
2448
+ output: 2,
2449
+ cacheRead: 0.03,
2450
+ cacheWrite: 0,
2451
+ },
2452
+ contextWindow: 400000,
2453
+ maxTokens: 128000,
2454
+ } satisfies Model<"openai-completions">,
2455
+ "openai/gpt-5.2": {
2456
+ id: "openai/gpt-5.2",
2457
+ name: "OpenAI: GPT-5.2",
2458
+ api: "openai-completions",
2459
+ provider: "openrouter",
2460
+ baseUrl: "https://openrouter.ai/api/v1",
2461
+ reasoning: true,
2462
+ input: ["text", "image"],
2463
+ cost: {
2464
+ input: 1.75,
2465
+ output: 14,
2466
+ cacheRead: 0.175,
2467
+ cacheWrite: 0,
2468
+ },
2469
+ contextWindow: 400000,
2470
+ maxTokens: 128000,
2471
+ } satisfies Model<"openai-completions">,
2472
+ "openai/gpt-5.2-chat": {
2473
+ id: "openai/gpt-5.2-chat",
2474
+ name: "OpenAI: GPT-5.2 Chat",
2475
+ api: "openai-completions",
2476
+ provider: "openrouter",
2477
+ baseUrl: "https://openrouter.ai/api/v1",
2478
+ reasoning: false,
2479
+ input: ["text", "image"],
2480
+ cost: {
2481
+ input: 1.75,
2482
+ output: 14,
2483
+ cacheRead: 0.175,
2484
+ cacheWrite: 0,
2485
+ },
2486
+ contextWindow: 128000,
2487
+ maxTokens: 32000,
2488
+ } satisfies Model<"openai-completions">,
2489
+ "openai/gpt-5.2-codex": {
2490
+ id: "openai/gpt-5.2-codex",
2491
+ name: "OpenAI: GPT-5.2-Codex",
2492
+ api: "openai-completions",
2493
+ provider: "openrouter",
2494
+ baseUrl: "https://openrouter.ai/api/v1",
2495
+ reasoning: true,
2496
+ input: ["text", "image"],
2497
+ cost: {
2498
+ input: 1.75,
2499
+ output: 14,
2500
+ cacheRead: 0.175,
2501
+ cacheWrite: 0,
2502
+ },
2503
+ contextWindow: 400000,
2504
+ maxTokens: 128000,
2505
+ } satisfies Model<"openai-completions">,
2506
+ "openai/gpt-5.2-pro": {
2507
+ id: "openai/gpt-5.2-pro",
2508
+ name: "OpenAI: GPT-5.2 Pro",
2509
+ api: "openai-completions",
2510
+ provider: "openrouter",
2511
+ baseUrl: "https://openrouter.ai/api/v1",
2512
+ reasoning: true,
2513
+ input: ["text", "image"],
2514
+ cost: {
2515
+ input: 21,
2516
+ output: 168,
2517
+ cacheRead: 0,
2518
+ cacheWrite: 0,
2519
+ },
2520
+ contextWindow: 400000,
2521
+ maxTokens: 128000,
2522
+ } satisfies Model<"openai-completions">,
2523
+ "openai/gpt-5.3-chat": {
2524
+ id: "openai/gpt-5.3-chat",
2525
+ name: "OpenAI: GPT-5.3 Chat",
2526
+ api: "openai-completions",
2527
+ provider: "openrouter",
2528
+ baseUrl: "https://openrouter.ai/api/v1",
2529
+ reasoning: false,
2530
+ input: ["text", "image"],
2531
+ cost: {
2532
+ input: 1.75,
2533
+ output: 14,
2534
+ cacheRead: 0.175,
2535
+ cacheWrite: 0,
2536
+ },
2537
+ contextWindow: 128000,
2538
+ maxTokens: 16384,
2539
+ } satisfies Model<"openai-completions">,
2540
+ "openai/gpt-5.3-codex": {
2541
+ id: "openai/gpt-5.3-codex",
2542
+ name: "OpenAI: GPT-5.3-Codex",
2543
+ api: "openai-completions",
2544
+ provider: "openrouter",
2545
+ baseUrl: "https://openrouter.ai/api/v1",
2546
+ reasoning: true,
2547
+ input: ["text", "image"],
2548
+ cost: {
2549
+ input: 1.75,
2550
+ output: 14,
2551
+ cacheRead: 0.175,
2552
+ cacheWrite: 0,
2553
+ },
2554
+ contextWindow: 400000,
2555
+ maxTokens: 128000,
2556
+ } satisfies Model<"openai-completions">,
2557
+ "openai/gpt-5.4": {
2558
+ id: "openai/gpt-5.4",
2559
+ name: "OpenAI: GPT-5.4",
2560
+ api: "openai-completions",
2561
+ provider: "openrouter",
2562
+ baseUrl: "https://openrouter.ai/api/v1",
2563
+ reasoning: true,
2564
+ input: ["text", "image"],
2565
+ cost: {
2566
+ input: 2.5,
2567
+ output: 15,
2568
+ cacheRead: 0.25,
2569
+ cacheWrite: 0,
2570
+ },
2571
+ contextWindow: 1050000,
2572
+ maxTokens: 128000,
2573
+ } satisfies Model<"openai-completions">,
2574
+ "openai/gpt-5.4-mini": {
2575
+ id: "openai/gpt-5.4-mini",
2576
+ name: "OpenAI: GPT-5.4 Mini",
2577
+ api: "openai-completions",
2578
+ provider: "openrouter",
2579
+ baseUrl: "https://openrouter.ai/api/v1",
2580
+ reasoning: true,
2581
+ input: ["text", "image"],
2582
+ cost: {
2583
+ input: 0.75,
2584
+ output: 4.5,
2585
+ cacheRead: 0.075,
2586
+ cacheWrite: 0,
2587
+ },
2588
+ contextWindow: 400000,
2589
+ maxTokens: 128000,
2590
+ } satisfies Model<"openai-completions">,
2591
+ "openai/gpt-5.4-nano": {
2592
+ id: "openai/gpt-5.4-nano",
2593
+ name: "OpenAI: GPT-5.4 Nano",
2594
+ api: "openai-completions",
2595
+ provider: "openrouter",
2596
+ baseUrl: "https://openrouter.ai/api/v1",
2597
+ reasoning: true,
2598
+ input: ["text", "image"],
2599
+ cost: {
2600
+ input: 0.19999999999999998,
2601
+ output: 1.25,
2602
+ cacheRead: 0.02,
2603
+ cacheWrite: 0,
2604
+ },
2605
+ contextWindow: 400000,
2606
+ maxTokens: 128000,
2607
+ } satisfies Model<"openai-completions">,
2608
+ "openai/gpt-5.4-pro": {
2609
+ id: "openai/gpt-5.4-pro",
2610
+ name: "OpenAI: GPT-5.4 Pro",
2611
+ api: "openai-completions",
2612
+ provider: "openrouter",
2613
+ baseUrl: "https://openrouter.ai/api/v1",
2614
+ reasoning: true,
2615
+ input: ["text", "image"],
2616
+ cost: {
2617
+ input: 30,
2618
+ output: 180,
2619
+ cacheRead: 0,
2620
+ cacheWrite: 0,
2621
+ },
2622
+ contextWindow: 1050000,
2623
+ maxTokens: 128000,
2624
+ } satisfies Model<"openai-completions">,
2625
+ "openai/gpt-audio": {
2626
+ id: "openai/gpt-audio",
2627
+ name: "OpenAI: GPT Audio",
2628
+ api: "openai-completions",
2629
+ provider: "openrouter",
2630
+ baseUrl: "https://openrouter.ai/api/v1",
2631
+ reasoning: false,
2632
+ input: ["text"],
2633
+ cost: {
2634
+ input: 2.5,
2635
+ output: 10,
2636
+ cacheRead: 0,
2637
+ cacheWrite: 0,
2638
+ },
2639
+ contextWindow: 128000,
2640
+ maxTokens: 16384,
2641
+ } satisfies Model<"openai-completions">,
2642
+ "openai/gpt-audio-mini": {
2643
+ id: "openai/gpt-audio-mini",
2644
+ name: "OpenAI: GPT Audio Mini",
2645
+ api: "openai-completions",
2646
+ provider: "openrouter",
2647
+ baseUrl: "https://openrouter.ai/api/v1",
2648
+ reasoning: false,
2649
+ input: ["text"],
2650
+ cost: {
2651
+ input: 0.6,
2652
+ output: 2.4,
2653
+ cacheRead: 0,
2654
+ cacheWrite: 0,
2655
+ },
2656
+ contextWindow: 128000,
2657
+ maxTokens: 16384,
2658
+ } satisfies Model<"openai-completions">,
2659
+ "openai/gpt-oss-120b": {
2660
+ id: "openai/gpt-oss-120b",
2661
+ name: "OpenAI: gpt-oss-120b",
2662
+ api: "openai-completions",
2663
+ provider: "openrouter",
2664
+ baseUrl: "https://openrouter.ai/api/v1",
2665
+ reasoning: true,
2666
+ input: ["text"],
2667
+ cost: {
2668
+ input: 0.039,
2669
+ output: 0.19,
2670
+ cacheRead: 0,
2671
+ cacheWrite: 0,
2672
+ },
2673
+ contextWindow: 131072,
2674
+ maxTokens: 4096,
2675
+ } satisfies Model<"openai-completions">,
2676
+ "openai/gpt-oss-120b:free": {
2677
+ id: "openai/gpt-oss-120b:free",
2678
+ name: "OpenAI: gpt-oss-120b (free)",
2679
+ api: "openai-completions",
2680
+ provider: "openrouter",
2681
+ baseUrl: "https://openrouter.ai/api/v1",
2682
+ reasoning: true,
2683
+ input: ["text"],
2684
+ cost: {
2685
+ input: 0,
2686
+ output: 0,
2687
+ cacheRead: 0,
2688
+ cacheWrite: 0,
2689
+ },
2690
+ contextWindow: 131072,
2691
+ maxTokens: 131072,
2692
+ } satisfies Model<"openai-completions">,
2693
+ "openai/gpt-oss-20b": {
2694
+ id: "openai/gpt-oss-20b",
2695
+ name: "OpenAI: gpt-oss-20b",
2696
+ api: "openai-completions",
2697
+ provider: "openrouter",
2698
+ baseUrl: "https://openrouter.ai/api/v1",
2699
+ reasoning: true,
2700
+ input: ["text"],
2701
+ cost: {
2702
+ input: 0.03,
2703
+ output: 0.14,
2704
+ cacheRead: 0,
2705
+ cacheWrite: 0,
2706
+ },
2707
+ contextWindow: 131072,
2708
+ maxTokens: 4096,
2709
+ } satisfies Model<"openai-completions">,
2710
+ "openai/gpt-oss-20b:free": {
2711
+ id: "openai/gpt-oss-20b:free",
2712
+ name: "OpenAI: gpt-oss-20b (free)",
2713
+ api: "openai-completions",
2714
+ provider: "openrouter",
2715
+ baseUrl: "https://openrouter.ai/api/v1",
2716
+ reasoning: true,
2717
+ input: ["text"],
2718
+ cost: {
2719
+ input: 0,
2720
+ output: 0,
2721
+ cacheRead: 0,
2722
+ cacheWrite: 0,
2723
+ },
2724
+ contextWindow: 131072,
2725
+ maxTokens: 8192,
2726
+ } satisfies Model<"openai-completions">,
2727
+ "openai/gpt-oss-safeguard-20b": {
2728
+ id: "openai/gpt-oss-safeguard-20b",
2729
+ name: "OpenAI: gpt-oss-safeguard-20b",
2730
+ api: "openai-completions",
2731
+ provider: "openrouter",
2732
+ baseUrl: "https://openrouter.ai/api/v1",
2733
+ reasoning: true,
2734
+ input: ["text"],
2735
+ cost: {
2736
+ input: 0.075,
2737
+ output: 0.3,
2738
+ cacheRead: 0.037,
2739
+ cacheWrite: 0,
2740
+ },
2741
+ contextWindow: 131072,
2742
+ maxTokens: 65536,
2743
+ } satisfies Model<"openai-completions">,
2744
+ "openai/o1": {
2745
+ id: "openai/o1",
2746
+ name: "OpenAI: o1",
2747
+ api: "openai-completions",
2748
+ provider: "openrouter",
2749
+ baseUrl: "https://openrouter.ai/api/v1",
2750
+ reasoning: true,
2751
+ input: ["text", "image"],
2752
+ cost: {
2753
+ input: 15,
2754
+ output: 60,
2755
+ cacheRead: 7.5,
2756
+ cacheWrite: 0,
2757
+ },
2758
+ contextWindow: 200000,
2759
+ maxTokens: 100000,
2760
+ } satisfies Model<"openai-completions">,
2761
+ "openai/o3": {
2762
+ id: "openai/o3",
2763
+ name: "OpenAI: o3",
2764
+ api: "openai-completions",
2765
+ provider: "openrouter",
2766
+ baseUrl: "https://openrouter.ai/api/v1",
2767
+ reasoning: true,
2768
+ input: ["text", "image"],
2769
+ cost: {
2770
+ input: 2,
2771
+ output: 8,
2772
+ cacheRead: 0.5,
2773
+ cacheWrite: 0,
2774
+ },
2775
+ contextWindow: 200000,
2776
+ maxTokens: 100000,
2777
+ } satisfies Model<"openai-completions">,
2778
+ "openai/o3-deep-research": {
2779
+ id: "openai/o3-deep-research",
2780
+ name: "OpenAI: o3 Deep Research",
2781
+ api: "openai-completions",
2782
+ provider: "openrouter",
2783
+ baseUrl: "https://openrouter.ai/api/v1",
2784
+ reasoning: true,
2785
+ input: ["text", "image"],
2786
+ cost: {
2787
+ input: 10,
2788
+ output: 40,
2789
+ cacheRead: 2.5,
2790
+ cacheWrite: 0,
2791
+ },
2792
+ contextWindow: 200000,
2793
+ maxTokens: 100000,
2794
+ } satisfies Model<"openai-completions">,
2795
+ "openai/o3-mini": {
2796
+ id: "openai/o3-mini",
2797
+ name: "OpenAI: o3 Mini",
2798
+ api: "openai-completions",
2799
+ provider: "openrouter",
2800
+ baseUrl: "https://openrouter.ai/api/v1",
2801
+ reasoning: true,
2802
+ input: ["text"],
2803
+ cost: {
2804
+ input: 1.1,
2805
+ output: 4.4,
2806
+ cacheRead: 0.55,
2807
+ cacheWrite: 0,
2808
+ },
2809
+ contextWindow: 200000,
2810
+ maxTokens: 100000,
2811
+ } satisfies Model<"openai-completions">,
2812
+ "openai/o3-mini-high": {
2813
+ id: "openai/o3-mini-high",
2814
+ name: "OpenAI: o3 Mini High",
2815
+ api: "openai-completions",
2816
+ provider: "openrouter",
2817
+ baseUrl: "https://openrouter.ai/api/v1",
2818
+ reasoning: true,
2819
+ input: ["text"],
2820
+ cost: {
2821
+ input: 1.1,
2822
+ output: 4.4,
2823
+ cacheRead: 0.55,
2824
+ cacheWrite: 0,
2825
+ },
2826
+ contextWindow: 200000,
2827
+ maxTokens: 100000,
2828
+ } satisfies Model<"openai-completions">,
2829
+ "openai/o3-pro": {
2830
+ id: "openai/o3-pro",
2831
+ name: "OpenAI: o3 Pro",
2832
+ api: "openai-completions",
2833
+ provider: "openrouter",
2834
+ baseUrl: "https://openrouter.ai/api/v1",
2835
+ reasoning: true,
2836
+ input: ["text", "image"],
2837
+ cost: {
2838
+ input: 20,
2839
+ output: 80,
2840
+ cacheRead: 0,
2841
+ cacheWrite: 0,
2842
+ },
2843
+ contextWindow: 200000,
2844
+ maxTokens: 100000,
2845
+ } satisfies Model<"openai-completions">,
2846
+ "openai/o4-mini": {
2847
+ id: "openai/o4-mini",
2848
+ name: "OpenAI: o4 Mini",
2849
+ api: "openai-completions",
2850
+ provider: "openrouter",
2851
+ baseUrl: "https://openrouter.ai/api/v1",
2852
+ reasoning: true,
2853
+ input: ["text", "image"],
2854
+ cost: {
2855
+ input: 1.1,
2856
+ output: 4.4,
2857
+ cacheRead: 0.275,
2858
+ cacheWrite: 0,
2859
+ },
2860
+ contextWindow: 200000,
2861
+ maxTokens: 100000,
2862
+ } satisfies Model<"openai-completions">,
2863
+ "openai/o4-mini-deep-research": {
2864
+ id: "openai/o4-mini-deep-research",
2865
+ name: "OpenAI: o4 Mini Deep Research",
2866
+ api: "openai-completions",
2867
+ provider: "openrouter",
2868
+ baseUrl: "https://openrouter.ai/api/v1",
2869
+ reasoning: true,
2870
+ input: ["text", "image"],
2871
+ cost: {
2872
+ input: 2,
2873
+ output: 8,
2874
+ cacheRead: 0.5,
2875
+ cacheWrite: 0,
2876
+ },
2877
+ contextWindow: 200000,
2878
+ maxTokens: 100000,
2879
+ } satisfies Model<"openai-completions">,
2880
+ "openai/o4-mini-high": {
2881
+ id: "openai/o4-mini-high",
2882
+ name: "OpenAI: o4 Mini High",
2883
+ api: "openai-completions",
2884
+ provider: "openrouter",
2885
+ baseUrl: "https://openrouter.ai/api/v1",
2886
+ reasoning: true,
2887
+ input: ["text", "image"],
2888
+ cost: {
2889
+ input: 1.1,
2890
+ output: 4.4,
2891
+ cacheRead: 0.275,
2892
+ cacheWrite: 0,
2893
+ },
2894
+ contextWindow: 200000,
2895
+ maxTokens: 100000,
2896
+ } satisfies Model<"openai-completions">,
2897
+ "openrouter/auto": {
2898
+ id: "openrouter/auto",
2899
+ name: "Auto Router",
2900
+ api: "openai-completions",
2901
+ provider: "openrouter",
2902
+ baseUrl: "https://openrouter.ai/api/v1",
2903
+ reasoning: true,
2904
+ input: ["text", "image"],
2905
+ cost: {
2906
+ input: -1000000,
2907
+ output: -1000000,
2908
+ cacheRead: 0,
2909
+ cacheWrite: 0,
2910
+ },
2911
+ contextWindow: 2000000,
2912
+ maxTokens: 4096,
2913
+ } satisfies Model<"openai-completions">,
2914
+ "openrouter/free": {
2915
+ id: "openrouter/free",
2916
+ name: "Free Models Router",
2917
+ api: "openai-completions",
2918
+ provider: "openrouter",
2919
+ baseUrl: "https://openrouter.ai/api/v1",
2920
+ reasoning: true,
2921
+ input: ["text", "image"],
2922
+ cost: {
2923
+ input: 0,
2924
+ output: 0,
2925
+ cacheRead: 0,
2926
+ cacheWrite: 0,
2927
+ },
2928
+ contextWindow: 200000,
2929
+ maxTokens: 4096,
2930
+ } satisfies Model<"openai-completions">,
2931
+ "prime-intellect/intellect-3": {
2932
+ id: "prime-intellect/intellect-3",
2933
+ name: "Prime Intellect: INTELLECT-3",
2934
+ api: "openai-completions",
2935
+ provider: "openrouter",
2936
+ baseUrl: "https://openrouter.ai/api/v1",
2937
+ reasoning: true,
2938
+ input: ["text"],
2939
+ cost: {
2940
+ input: 0.19999999999999998,
2941
+ output: 1.1,
2942
+ cacheRead: 0,
2943
+ cacheWrite: 0,
2944
+ },
2945
+ contextWindow: 131072,
2946
+ maxTokens: 131072,
2947
+ } satisfies Model<"openai-completions">,
2948
+ "qwen/qwen-2.5-72b-instruct": {
2949
+ id: "qwen/qwen-2.5-72b-instruct",
2950
+ name: "Qwen2.5 72B Instruct",
2951
+ api: "openai-completions",
2952
+ provider: "openrouter",
2953
+ baseUrl: "https://openrouter.ai/api/v1",
2954
+ reasoning: false,
2955
+ input: ["text"],
2956
+ cost: {
2957
+ input: 0.12,
2958
+ output: 0.39,
2959
+ cacheRead: 0,
2960
+ cacheWrite: 0,
2961
+ },
2962
+ contextWindow: 32768,
2963
+ maxTokens: 16384,
2964
+ } satisfies Model<"openai-completions">,
2965
+ "qwen/qwen-2.5-7b-instruct": {
2966
+ id: "qwen/qwen-2.5-7b-instruct",
2967
+ name: "Qwen: Qwen2.5 7B Instruct",
2968
+ api: "openai-completions",
2969
+ provider: "openrouter",
2970
+ baseUrl: "https://openrouter.ai/api/v1",
2971
+ reasoning: false,
2972
+ input: ["text"],
2973
+ cost: {
2974
+ input: 0.04,
2975
+ output: 0.09999999999999999,
2976
+ cacheRead: 0,
2977
+ cacheWrite: 0,
2978
+ },
2979
+ contextWindow: 32768,
2980
+ maxTokens: 32768,
2981
+ } satisfies Model<"openai-completions">,
2982
+ "qwen/qwen-max": {
2983
+ id: "qwen/qwen-max",
2984
+ name: "Qwen: Qwen-Max ",
2985
+ api: "openai-completions",
2986
+ provider: "openrouter",
2987
+ baseUrl: "https://openrouter.ai/api/v1",
2988
+ reasoning: false,
2989
+ input: ["text"],
2990
+ cost: {
2991
+ input: 1.04,
2992
+ output: 4.16,
2993
+ cacheRead: 0.20800000000000002,
2994
+ cacheWrite: 0,
2995
+ },
2996
+ contextWindow: 32768,
2997
+ maxTokens: 8192,
2998
+ } satisfies Model<"openai-completions">,
2999
+ "qwen/qwen-plus": {
3000
+ id: "qwen/qwen-plus",
3001
+ name: "Qwen: Qwen-Plus",
3002
+ api: "openai-completions",
3003
+ provider: "openrouter",
3004
+ baseUrl: "https://openrouter.ai/api/v1",
3005
+ reasoning: false,
3006
+ input: ["text"],
3007
+ cost: {
3008
+ input: 0.26,
3009
+ output: 0.78,
3010
+ cacheRead: 0.052000000000000005,
3011
+ cacheWrite: 0,
3012
+ },
3013
+ contextWindow: 1000000,
3014
+ maxTokens: 32768,
3015
+ } satisfies Model<"openai-completions">,
3016
+ "qwen/qwen-plus-2025-07-28": {
3017
+ id: "qwen/qwen-plus-2025-07-28",
3018
+ name: "Qwen: Qwen Plus 0728",
3019
+ api: "openai-completions",
3020
+ provider: "openrouter",
3021
+ baseUrl: "https://openrouter.ai/api/v1",
3022
+ reasoning: false,
3023
+ input: ["text"],
3024
+ cost: {
3025
+ input: 0.26,
3026
+ output: 0.78,
3027
+ cacheRead: 0,
3028
+ cacheWrite: 0,
3029
+ },
3030
+ contextWindow: 1000000,
3031
+ maxTokens: 32768,
3032
+ } satisfies Model<"openai-completions">,
3033
+ "qwen/qwen-plus-2025-07-28:thinking": {
3034
+ id: "qwen/qwen-plus-2025-07-28:thinking",
3035
+ name: "Qwen: Qwen Plus 0728 (thinking)",
3036
+ api: "openai-completions",
3037
+ provider: "openrouter",
3038
+ baseUrl: "https://openrouter.ai/api/v1",
3039
+ reasoning: true,
3040
+ input: ["text"],
3041
+ cost: {
3042
+ input: 0.26,
3043
+ output: 0.78,
3044
+ cacheRead: 0,
3045
+ cacheWrite: 0,
3046
+ },
3047
+ contextWindow: 1000000,
3048
+ maxTokens: 32768,
3049
+ } satisfies Model<"openai-completions">,
3050
+ "qwen/qwen-turbo": {
3051
+ id: "qwen/qwen-turbo",
3052
+ name: "Qwen: Qwen-Turbo",
3053
+ api: "openai-completions",
3054
+ provider: "openrouter",
3055
+ baseUrl: "https://openrouter.ai/api/v1",
3056
+ reasoning: false,
3057
+ input: ["text"],
3058
+ cost: {
3059
+ input: 0.0325,
3060
+ output: 0.13,
3061
+ cacheRead: 0.006500000000000001,
3062
+ cacheWrite: 0,
3063
+ },
3064
+ contextWindow: 131072,
3065
+ maxTokens: 8192,
3066
+ } satisfies Model<"openai-completions">,
3067
+ "qwen/qwen-vl-max": {
3068
+ id: "qwen/qwen-vl-max",
3069
+ name: "Qwen: Qwen VL Max",
3070
+ api: "openai-completions",
3071
+ provider: "openrouter",
3072
+ baseUrl: "https://openrouter.ai/api/v1",
3073
+ reasoning: false,
3074
+ input: ["text", "image"],
3075
+ cost: {
3076
+ input: 0.52,
3077
+ output: 2.08,
3078
+ cacheRead: 0,
3079
+ cacheWrite: 0,
3080
+ },
3081
+ contextWindow: 131072,
3082
+ maxTokens: 32768,
3083
+ } satisfies Model<"openai-completions">,
3084
+ "qwen/qwen3-14b": {
3085
+ id: "qwen/qwen3-14b",
3086
+ name: "Qwen: Qwen3 14B",
3087
+ api: "openai-completions",
3088
+ provider: "openrouter",
3089
+ baseUrl: "https://openrouter.ai/api/v1",
3090
+ reasoning: true,
3091
+ input: ["text"],
3092
+ cost: {
3093
+ input: 0.06,
3094
+ output: 0.24,
3095
+ cacheRead: 0,
3096
+ cacheWrite: 0,
3097
+ },
3098
+ contextWindow: 40960,
3099
+ maxTokens: 40960,
3100
+ } satisfies Model<"openai-completions">,
3101
+ "qwen/qwen3-235b-a22b": {
3102
+ id: "qwen/qwen3-235b-a22b",
3103
+ name: "Qwen: Qwen3 235B A22B",
3104
+ api: "openai-completions",
3105
+ provider: "openrouter",
3106
+ baseUrl: "https://openrouter.ai/api/v1",
3107
+ reasoning: true,
3108
+ input: ["text"],
3109
+ cost: {
3110
+ input: 0.45499999999999996,
3111
+ output: 1.8199999999999998,
3112
+ cacheRead: 0,
3113
+ cacheWrite: 0,
3114
+ },
3115
+ contextWindow: 131072,
3116
+ maxTokens: 8192,
3117
+ } satisfies Model<"openai-completions">,
3118
+ "qwen/qwen3-235b-a22b-2507": {
3119
+ id: "qwen/qwen3-235b-a22b-2507",
3120
+ name: "Qwen: Qwen3 235B A22B Instruct 2507",
3121
+ api: "openai-completions",
3122
+ provider: "openrouter",
3123
+ baseUrl: "https://openrouter.ai/api/v1",
3124
+ reasoning: true,
3125
+ input: ["text"],
3126
+ cost: {
3127
+ input: 0.071,
3128
+ output: 0.09999999999999999,
3129
+ cacheRead: 0,
3130
+ cacheWrite: 0,
3131
+ },
3132
+ contextWindow: 262144,
3133
+ maxTokens: 4096,
3134
+ } satisfies Model<"openai-completions">,
3135
+ "qwen/qwen3-235b-a22b-thinking-2507": {
3136
+ id: "qwen/qwen3-235b-a22b-thinking-2507",
3137
+ name: "Qwen: Qwen3 235B A22B Thinking 2507",
3138
+ api: "openai-completions",
3139
+ provider: "openrouter",
3140
+ baseUrl: "https://openrouter.ai/api/v1",
3141
+ reasoning: true,
3142
+ input: ["text"],
3143
+ cost: {
3144
+ input: 0.14950000000000002,
3145
+ output: 1.495,
3146
+ cacheRead: 0,
3147
+ cacheWrite: 0,
3148
+ },
3149
+ contextWindow: 131072,
3150
+ maxTokens: 4096,
3151
+ } satisfies Model<"openai-completions">,
3152
+ "qwen/qwen3-30b-a3b": {
3153
+ id: "qwen/qwen3-30b-a3b",
3154
+ name: "Qwen: Qwen3 30B A3B",
3155
+ api: "openai-completions",
3156
+ provider: "openrouter",
3157
+ baseUrl: "https://openrouter.ai/api/v1",
3158
+ reasoning: true,
3159
+ input: ["text"],
3160
+ cost: {
3161
+ input: 0.08,
3162
+ output: 0.28,
3163
+ cacheRead: 0,
3164
+ cacheWrite: 0,
3165
+ },
3166
+ contextWindow: 40960,
3167
+ maxTokens: 40960,
3168
+ } satisfies Model<"openai-completions">,
3169
+ "qwen/qwen3-30b-a3b-instruct-2507": {
3170
+ id: "qwen/qwen3-30b-a3b-instruct-2507",
3171
+ name: "Qwen: Qwen3 30B A3B Instruct 2507",
3172
+ api: "openai-completions",
3173
+ provider: "openrouter",
3174
+ baseUrl: "https://openrouter.ai/api/v1",
3175
+ reasoning: false,
3176
+ input: ["text"],
3177
+ cost: {
3178
+ input: 0.09,
3179
+ output: 0.3,
3180
+ cacheRead: 0,
3181
+ cacheWrite: 0,
3182
+ },
3183
+ contextWindow: 262144,
3184
+ maxTokens: 262144,
3185
+ } satisfies Model<"openai-completions">,
3186
+ "qwen/qwen3-30b-a3b-thinking-2507": {
3187
+ id: "qwen/qwen3-30b-a3b-thinking-2507",
3188
+ name: "Qwen: Qwen3 30B A3B Thinking 2507",
3189
+ api: "openai-completions",
3190
+ provider: "openrouter",
3191
+ baseUrl: "https://openrouter.ai/api/v1",
3192
+ reasoning: true,
3193
+ input: ["text"],
3194
+ cost: {
3195
+ input: 0.08,
3196
+ output: 0.39999999999999997,
3197
+ cacheRead: 0.08,
3198
+ cacheWrite: 0,
3199
+ },
3200
+ contextWindow: 131072,
3201
+ maxTokens: 131072,
3202
+ } satisfies Model<"openai-completions">,
3203
+ "qwen/qwen3-32b": {
3204
+ id: "qwen/qwen3-32b",
3205
+ name: "Qwen: Qwen3 32B",
3206
+ api: "openai-completions",
3207
+ provider: "openrouter",
3208
+ baseUrl: "https://openrouter.ai/api/v1",
3209
+ reasoning: true,
3210
+ input: ["text"],
3211
+ cost: {
3212
+ input: 0.08,
3213
+ output: 0.24,
3214
+ cacheRead: 0.04,
3215
+ cacheWrite: 0,
3216
+ },
3217
+ contextWindow: 40960,
3218
+ maxTokens: 40960,
3219
+ } satisfies Model<"openai-completions">,
3220
+ "qwen/qwen3-8b": {
3221
+ id: "qwen/qwen3-8b",
3222
+ name: "Qwen: Qwen3 8B",
3223
+ api: "openai-completions",
3224
+ provider: "openrouter",
3225
+ baseUrl: "https://openrouter.ai/api/v1",
3226
+ reasoning: true,
3227
+ input: ["text"],
3228
+ cost: {
3229
+ input: 0.049999999999999996,
3230
+ output: 0.39999999999999997,
3231
+ cacheRead: 0.049999999999999996,
3232
+ cacheWrite: 0,
3233
+ },
3234
+ contextWindow: 40960,
3235
+ maxTokens: 8192,
3236
+ } satisfies Model<"openai-completions">,
3237
+ "qwen/qwen3-coder": {
3238
+ id: "qwen/qwen3-coder",
3239
+ name: "Qwen: Qwen3 Coder 480B A35B",
3240
+ api: "openai-completions",
3241
+ provider: "openrouter",
3242
+ baseUrl: "https://openrouter.ai/api/v1",
3243
+ reasoning: false,
3244
+ input: ["text"],
3245
+ cost: {
3246
+ input: 0.22,
3247
+ output: 1,
3248
+ cacheRead: 0.022,
3249
+ cacheWrite: 0,
3250
+ },
3251
+ contextWindow: 262144,
3252
+ maxTokens: 4096,
3253
+ } satisfies Model<"openai-completions">,
3254
+ "qwen/qwen3-coder-30b-a3b-instruct": {
3255
+ id: "qwen/qwen3-coder-30b-a3b-instruct",
3256
+ name: "Qwen: Qwen3 Coder 30B A3B Instruct",
3257
+ api: "openai-completions",
3258
+ provider: "openrouter",
3259
+ baseUrl: "https://openrouter.ai/api/v1",
3260
+ reasoning: false,
3261
+ input: ["text"],
3262
+ cost: {
3263
+ input: 0.07,
3264
+ output: 0.27,
3265
+ cacheRead: 0,
3266
+ cacheWrite: 0,
3267
+ },
3268
+ contextWindow: 160000,
3269
+ maxTokens: 32768,
3270
+ } satisfies Model<"openai-completions">,
3271
+ "qwen/qwen3-coder-flash": {
3272
+ id: "qwen/qwen3-coder-flash",
3273
+ name: "Qwen: Qwen3 Coder Flash",
3274
+ api: "openai-completions",
3275
+ provider: "openrouter",
3276
+ baseUrl: "https://openrouter.ai/api/v1",
3277
+ reasoning: false,
3278
+ input: ["text"],
3279
+ cost: {
3280
+ input: 0.195,
3281
+ output: 0.975,
3282
+ cacheRead: 0.039,
3283
+ cacheWrite: 0,
3284
+ },
3285
+ contextWindow: 1000000,
3286
+ maxTokens: 65536,
3287
+ } satisfies Model<"openai-completions">,
3288
+ "qwen/qwen3-coder-next": {
3289
+ id: "qwen/qwen3-coder-next",
3290
+ name: "Qwen: Qwen3 Coder Next",
3291
+ api: "openai-completions",
3292
+ provider: "openrouter",
3293
+ baseUrl: "https://openrouter.ai/api/v1",
3294
+ reasoning: false,
3295
+ input: ["text"],
3296
+ cost: {
3297
+ input: 0.15,
3298
+ output: 0.7999999999999999,
3299
+ cacheRead: 0.12,
3300
+ cacheWrite: 0,
3301
+ },
3302
+ contextWindow: 262144,
3303
+ maxTokens: 262144,
3304
+ } satisfies Model<"openai-completions">,
3305
+ "qwen/qwen3-coder-plus": {
3306
+ id: "qwen/qwen3-coder-plus",
3307
+ name: "Qwen: Qwen3 Coder Plus",
3308
+ api: "openai-completions",
3309
+ provider: "openrouter",
3310
+ baseUrl: "https://openrouter.ai/api/v1",
3311
+ reasoning: false,
3312
+ input: ["text"],
3313
+ cost: {
3314
+ input: 0.65,
3315
+ output: 3.25,
3316
+ cacheRead: 0.13,
3317
+ cacheWrite: 0,
3318
+ },
3319
+ contextWindow: 1000000,
3320
+ maxTokens: 65536,
3321
+ } satisfies Model<"openai-completions">,
3322
+ "qwen/qwen3-coder:free": {
3323
+ id: "qwen/qwen3-coder:free",
3324
+ name: "Qwen: Qwen3 Coder 480B A35B (free)",
3325
+ api: "openai-completions",
3326
+ provider: "openrouter",
3327
+ baseUrl: "https://openrouter.ai/api/v1",
3328
+ reasoning: false,
3329
+ input: ["text"],
3330
+ cost: {
3331
+ input: 0,
3332
+ output: 0,
3333
+ cacheRead: 0,
3334
+ cacheWrite: 0,
3335
+ },
3336
+ contextWindow: 262000,
3337
+ maxTokens: 262000,
3338
+ } satisfies Model<"openai-completions">,
3339
+ "qwen/qwen3-max": {
3340
+ id: "qwen/qwen3-max",
3341
+ name: "Qwen: Qwen3 Max",
3342
+ api: "openai-completions",
3343
+ provider: "openrouter",
3344
+ baseUrl: "https://openrouter.ai/api/v1",
3345
+ reasoning: false,
3346
+ input: ["text"],
3347
+ cost: {
3348
+ input: 0.78,
3349
+ output: 3.9,
3350
+ cacheRead: 0.156,
3351
+ cacheWrite: 0,
3352
+ },
3353
+ contextWindow: 262144,
3354
+ maxTokens: 32768,
3355
+ } satisfies Model<"openai-completions">,
3356
+ "qwen/qwen3-max-thinking": {
3357
+ id: "qwen/qwen3-max-thinking",
3358
+ name: "Qwen: Qwen3 Max Thinking",
3359
+ api: "openai-completions",
3360
+ provider: "openrouter",
3361
+ baseUrl: "https://openrouter.ai/api/v1",
3362
+ reasoning: true,
3363
+ input: ["text"],
3364
+ cost: {
3365
+ input: 0.78,
3366
+ output: 3.9,
3367
+ cacheRead: 0,
3368
+ cacheWrite: 0,
3369
+ },
3370
+ contextWindow: 262144,
3371
+ maxTokens: 32768,
3372
+ } satisfies Model<"openai-completions">,
3373
+ "qwen/qwen3-next-80b-a3b-instruct": {
3374
+ id: "qwen/qwen3-next-80b-a3b-instruct",
3375
+ name: "Qwen: Qwen3 Next 80B A3B Instruct",
3376
+ api: "openai-completions",
3377
+ provider: "openrouter",
3378
+ baseUrl: "https://openrouter.ai/api/v1",
3379
+ reasoning: false,
3380
+ input: ["text"],
3381
+ cost: {
3382
+ input: 0.09,
3383
+ output: 1.1,
3384
+ cacheRead: 0,
3385
+ cacheWrite: 0,
3386
+ },
3387
+ contextWindow: 262144,
3388
+ maxTokens: 4096,
3389
+ } satisfies Model<"openai-completions">,
3390
+ "qwen/qwen3-next-80b-a3b-instruct:free": {
3391
+ id: "qwen/qwen3-next-80b-a3b-instruct:free",
3392
+ name: "Qwen: Qwen3 Next 80B A3B Instruct (free)",
3393
+ api: "openai-completions",
3394
+ provider: "openrouter",
3395
+ baseUrl: "https://openrouter.ai/api/v1",
3396
+ reasoning: false,
3397
+ input: ["text"],
3398
+ cost: {
3399
+ input: 0,
3400
+ output: 0,
3401
+ cacheRead: 0,
3402
+ cacheWrite: 0,
3403
+ },
3404
+ contextWindow: 262144,
3405
+ maxTokens: 4096,
3406
+ } satisfies Model<"openai-completions">,
3407
+ "qwen/qwen3-next-80b-a3b-thinking": {
3408
+ id: "qwen/qwen3-next-80b-a3b-thinking",
3409
+ name: "Qwen: Qwen3 Next 80B A3B Thinking",
3410
+ api: "openai-completions",
3411
+ provider: "openrouter",
3412
+ baseUrl: "https://openrouter.ai/api/v1",
3413
+ reasoning: true,
3414
+ input: ["text"],
3415
+ cost: {
3416
+ input: 0.0975,
3417
+ output: 0.78,
3418
+ cacheRead: 0,
3419
+ cacheWrite: 0,
3420
+ },
3421
+ contextWindow: 131072,
3422
+ maxTokens: 32768,
3423
+ } satisfies Model<"openai-completions">,
3424
+ "qwen/qwen3-vl-235b-a22b-instruct": {
3425
+ id: "qwen/qwen3-vl-235b-a22b-instruct",
3426
+ name: "Qwen: Qwen3 VL 235B A22B Instruct",
3427
+ api: "openai-completions",
3428
+ provider: "openrouter",
3429
+ baseUrl: "https://openrouter.ai/api/v1",
3430
+ reasoning: false,
3431
+ input: ["text", "image"],
3432
+ cost: {
3433
+ input: 0.19999999999999998,
3434
+ output: 0.88,
3435
+ cacheRead: 0.11,
3436
+ cacheWrite: 0,
3437
+ },
3438
+ contextWindow: 262144,
3439
+ maxTokens: 4096,
3440
+ } satisfies Model<"openai-completions">,
3441
+ "qwen/qwen3-vl-235b-a22b-thinking": {
3442
+ id: "qwen/qwen3-vl-235b-a22b-thinking",
3443
+ name: "Qwen: Qwen3 VL 235B A22B Thinking",
3444
+ api: "openai-completions",
3445
+ provider: "openrouter",
3446
+ baseUrl: "https://openrouter.ai/api/v1",
3447
+ reasoning: true,
3448
+ input: ["text", "image"],
3449
+ cost: {
3450
+ input: 0.26,
3451
+ output: 2.6,
3452
+ cacheRead: 0,
3453
+ cacheWrite: 0,
3454
+ },
3455
+ contextWindow: 131072,
3456
+ maxTokens: 32768,
3457
+ } satisfies Model<"openai-completions">,
3458
+ "qwen/qwen3-vl-30b-a3b-instruct": {
3459
+ id: "qwen/qwen3-vl-30b-a3b-instruct",
3460
+ name: "Qwen: Qwen3 VL 30B A3B Instruct",
3461
+ api: "openai-completions",
3462
+ provider: "openrouter",
3463
+ baseUrl: "https://openrouter.ai/api/v1",
3464
+ reasoning: false,
3465
+ input: ["text", "image"],
3466
+ cost: {
3467
+ input: 0.13,
3468
+ output: 0.52,
3469
+ cacheRead: 0,
3470
+ cacheWrite: 0,
3471
+ },
3472
+ contextWindow: 131072,
3473
+ maxTokens: 32768,
3474
+ } satisfies Model<"openai-completions">,
3475
+ "qwen/qwen3-vl-30b-a3b-thinking": {
3476
+ id: "qwen/qwen3-vl-30b-a3b-thinking",
3477
+ name: "Qwen: Qwen3 VL 30B A3B Thinking",
3478
+ api: "openai-completions",
3479
+ provider: "openrouter",
3480
+ baseUrl: "https://openrouter.ai/api/v1",
3481
+ reasoning: true,
3482
+ input: ["text", "image"],
3483
+ cost: {
3484
+ input: 0.13,
3485
+ output: 1.56,
3486
+ cacheRead: 0,
3487
+ cacheWrite: 0,
3488
+ },
3489
+ contextWindow: 131072,
3490
+ maxTokens: 32768,
3491
+ } satisfies Model<"openai-completions">,
3492
+ "qwen/qwen3-vl-32b-instruct": {
3493
+ id: "qwen/qwen3-vl-32b-instruct",
3494
+ name: "Qwen: Qwen3 VL 32B Instruct",
3495
+ api: "openai-completions",
3496
+ provider: "openrouter",
3497
+ baseUrl: "https://openrouter.ai/api/v1",
3498
+ reasoning: false,
3499
+ input: ["text", "image"],
3500
+ cost: {
3501
+ input: 0.10400000000000001,
3502
+ output: 0.41600000000000004,
3503
+ cacheRead: 0,
3504
+ cacheWrite: 0,
3505
+ },
3506
+ contextWindow: 131072,
3507
+ maxTokens: 32768,
3508
+ } satisfies Model<"openai-completions">,
3509
+ "qwen/qwen3-vl-8b-instruct": {
3510
+ id: "qwen/qwen3-vl-8b-instruct",
3511
+ name: "Qwen: Qwen3 VL 8B Instruct",
3512
+ api: "openai-completions",
3513
+ provider: "openrouter",
3514
+ baseUrl: "https://openrouter.ai/api/v1",
3515
+ reasoning: false,
3516
+ input: ["text", "image"],
3517
+ cost: {
3518
+ input: 0.08,
3519
+ output: 0.5,
3520
+ cacheRead: 0,
3521
+ cacheWrite: 0,
3522
+ },
3523
+ contextWindow: 131072,
3524
+ maxTokens: 32768,
3525
+ } satisfies Model<"openai-completions">,
3526
+ "qwen/qwen3-vl-8b-thinking": {
3527
+ id: "qwen/qwen3-vl-8b-thinking",
3528
+ name: "Qwen: Qwen3 VL 8B Thinking",
3529
+ api: "openai-completions",
3530
+ provider: "openrouter",
3531
+ baseUrl: "https://openrouter.ai/api/v1",
3532
+ reasoning: true,
3533
+ input: ["text", "image"],
3534
+ cost: {
3535
+ input: 0.117,
3536
+ output: 1.365,
3537
+ cacheRead: 0,
3538
+ cacheWrite: 0,
3539
+ },
3540
+ contextWindow: 131072,
3541
+ maxTokens: 32768,
3542
+ } satisfies Model<"openai-completions">,
3543
+ "qwen/qwen3.5-122b-a10b": {
3544
+ id: "qwen/qwen3.5-122b-a10b",
3545
+ name: "Qwen: Qwen3.5-122B-A10B",
3546
+ api: "openai-completions",
3547
+ provider: "openrouter",
3548
+ baseUrl: "https://openrouter.ai/api/v1",
3549
+ reasoning: true,
3550
+ input: ["text", "image"],
3551
+ cost: {
3552
+ input: 0.26,
3553
+ output: 2.08,
3554
+ cacheRead: 0,
3555
+ cacheWrite: 0,
3556
+ },
3557
+ contextWindow: 262144,
3558
+ maxTokens: 65536,
3559
+ } satisfies Model<"openai-completions">,
3560
+ "qwen/qwen3.5-27b": {
3561
+ id: "qwen/qwen3.5-27b",
3562
+ name: "Qwen: Qwen3.5-27B",
3563
+ api: "openai-completions",
3564
+ provider: "openrouter",
3565
+ baseUrl: "https://openrouter.ai/api/v1",
3566
+ reasoning: true,
3567
+ input: ["text", "image"],
3568
+ cost: {
3569
+ input: 0.195,
3570
+ output: 1.56,
3571
+ cacheRead: 0,
3572
+ cacheWrite: 0,
3573
+ },
3574
+ contextWindow: 262144,
3575
+ maxTokens: 65536,
3576
+ } satisfies Model<"openai-completions">,
3577
+ "qwen/qwen3.5-35b-a3b": {
3578
+ id: "qwen/qwen3.5-35b-a3b",
3579
+ name: "Qwen: Qwen3.5-35B-A3B",
3580
+ api: "openai-completions",
3581
+ provider: "openrouter",
3582
+ baseUrl: "https://openrouter.ai/api/v1",
3583
+ reasoning: true,
3584
+ input: ["text", "image"],
3585
+ cost: {
3586
+ input: 0.1625,
3587
+ output: 1.3,
3588
+ cacheRead: 0,
3589
+ cacheWrite: 0,
3590
+ },
3591
+ contextWindow: 262144,
3592
+ maxTokens: 65536,
3593
+ } satisfies Model<"openai-completions">,
3594
+ "qwen/qwen3.5-397b-a17b": {
3595
+ id: "qwen/qwen3.5-397b-a17b",
3596
+ name: "Qwen: Qwen3.5 397B A17B",
3597
+ api: "openai-completions",
3598
+ provider: "openrouter",
3599
+ baseUrl: "https://openrouter.ai/api/v1",
3600
+ reasoning: true,
3601
+ input: ["text", "image"],
3602
+ cost: {
3603
+ input: 0.39,
3604
+ output: 2.34,
3605
+ cacheRead: 0,
3606
+ cacheWrite: 0,
3607
+ },
3608
+ contextWindow: 262144,
3609
+ maxTokens: 65536,
3610
+ } satisfies Model<"openai-completions">,
3611
+ "qwen/qwen3.5-9b": {
3612
+ id: "qwen/qwen3.5-9b",
3613
+ name: "Qwen: Qwen3.5-9B",
3614
+ api: "openai-completions",
3615
+ provider: "openrouter",
3616
+ baseUrl: "https://openrouter.ai/api/v1",
3617
+ reasoning: true,
3618
+ input: ["text", "image"],
3619
+ cost: {
3620
+ input: 0.049999999999999996,
3621
+ output: 0.15,
3622
+ cacheRead: 0,
3623
+ cacheWrite: 0,
3624
+ },
3625
+ contextWindow: 256000,
3626
+ maxTokens: 32768,
3627
+ } satisfies Model<"openai-completions">,
3628
+ "qwen/qwen3.5-flash-02-23": {
3629
+ id: "qwen/qwen3.5-flash-02-23",
3630
+ name: "Qwen: Qwen3.5-Flash",
3631
+ api: "openai-completions",
3632
+ provider: "openrouter",
3633
+ baseUrl: "https://openrouter.ai/api/v1",
3634
+ reasoning: true,
3635
+ input: ["text", "image"],
3636
+ cost: {
3637
+ input: 0.065,
3638
+ output: 0.26,
3639
+ cacheRead: 0,
3640
+ cacheWrite: 0,
3641
+ },
3642
+ contextWindow: 1000000,
3643
+ maxTokens: 65536,
3644
+ } satisfies Model<"openai-completions">,
3645
+ "qwen/qwen3.5-plus-02-15": {
3646
+ id: "qwen/qwen3.5-plus-02-15",
3647
+ name: "Qwen: Qwen3.5 Plus 2026-02-15",
3648
+ api: "openai-completions",
3649
+ provider: "openrouter",
3650
+ baseUrl: "https://openrouter.ai/api/v1",
3651
+ reasoning: true,
3652
+ input: ["text", "image"],
3653
+ cost: {
3654
+ input: 0.26,
3655
+ output: 1.56,
3656
+ cacheRead: 0,
3657
+ cacheWrite: 0,
3658
+ },
3659
+ contextWindow: 1000000,
3660
+ maxTokens: 65536,
3661
+ } satisfies Model<"openai-completions">,
3662
+ "qwen/qwen3.6-plus": {
3663
+ id: "qwen/qwen3.6-plus",
3664
+ name: "Qwen: Qwen3.6 Plus",
3665
+ api: "openai-completions",
3666
+ provider: "openrouter",
3667
+ baseUrl: "https://openrouter.ai/api/v1",
3668
+ reasoning: true,
3669
+ input: ["text", "image"],
3670
+ cost: {
3671
+ input: 0.325,
3672
+ output: 1.95,
3673
+ cacheRead: 0,
3674
+ cacheWrite: 0,
3675
+ },
3676
+ contextWindow: 1000000,
3677
+ maxTokens: 65536,
3678
+ } satisfies Model<"openai-completions">,
3679
+ "qwen/qwq-32b": {
3680
+ id: "qwen/qwq-32b",
3681
+ name: "Qwen: QwQ 32B",
3682
+ api: "openai-completions",
3683
+ provider: "openrouter",
3684
+ baseUrl: "https://openrouter.ai/api/v1",
3685
+ reasoning: true,
3686
+ input: ["text"],
3687
+ cost: {
3688
+ input: 0.15,
3689
+ output: 0.58,
3690
+ cacheRead: 0,
3691
+ cacheWrite: 0,
3692
+ },
3693
+ contextWindow: 131072,
3694
+ maxTokens: 131072,
3695
+ } satisfies Model<"openai-completions">,
3696
+ "rekaai/reka-edge": {
3697
+ id: "rekaai/reka-edge",
3698
+ name: "Reka Edge",
3699
+ api: "openai-completions",
3700
+ provider: "openrouter",
3701
+ baseUrl: "https://openrouter.ai/api/v1",
3702
+ reasoning: false,
3703
+ input: ["text", "image"],
3704
+ cost: {
3705
+ input: 0.09999999999999999,
3706
+ output: 0.09999999999999999,
3707
+ cacheRead: 0,
3708
+ cacheWrite: 0,
3709
+ },
3710
+ contextWindow: 16384,
3711
+ maxTokens: 16384,
3712
+ } satisfies Model<"openai-completions">,
3713
+ "relace/relace-search": {
3714
+ id: "relace/relace-search",
3715
+ name: "Relace: Relace Search",
3716
+ api: "openai-completions",
3717
+ provider: "openrouter",
3718
+ baseUrl: "https://openrouter.ai/api/v1",
3719
+ reasoning: false,
3720
+ input: ["text"],
3721
+ cost: {
3722
+ input: 1,
3723
+ output: 3,
3724
+ cacheRead: 0,
3725
+ cacheWrite: 0,
3726
+ },
3727
+ contextWindow: 256000,
3728
+ maxTokens: 128000,
3729
+ } satisfies Model<"openai-completions">,
3730
+ "sao10k/l3-euryale-70b": {
3731
+ id: "sao10k/l3-euryale-70b",
3732
+ name: "Sao10k: Llama 3 Euryale 70B v2.1",
3733
+ api: "openai-completions",
3734
+ provider: "openrouter",
3735
+ baseUrl: "https://openrouter.ai/api/v1",
3736
+ reasoning: false,
3737
+ input: ["text"],
3738
+ cost: {
3739
+ input: 1.48,
3740
+ output: 1.48,
3741
+ cacheRead: 0,
3742
+ cacheWrite: 0,
3743
+ },
3744
+ contextWindow: 8192,
3745
+ maxTokens: 8192,
3746
+ } satisfies Model<"openai-completions">,
3747
+ "sao10k/l3.1-euryale-70b": {
3748
+ id: "sao10k/l3.1-euryale-70b",
3749
+ name: "Sao10K: Llama 3.1 Euryale 70B v2.2",
3750
+ api: "openai-completions",
3751
+ provider: "openrouter",
3752
+ baseUrl: "https://openrouter.ai/api/v1",
3753
+ reasoning: false,
3754
+ input: ["text"],
3755
+ cost: {
3756
+ input: 0.85,
3757
+ output: 0.85,
3758
+ cacheRead: 0,
3759
+ cacheWrite: 0,
3760
+ },
3761
+ contextWindow: 131072,
3762
+ maxTokens: 16384,
3763
+ } satisfies Model<"openai-completions">,
3764
+ "stepfun/step-3.5-flash": {
3765
+ id: "stepfun/step-3.5-flash",
3766
+ name: "StepFun: Step 3.5 Flash",
3767
+ api: "openai-completions",
3768
+ provider: "openrouter",
3769
+ baseUrl: "https://openrouter.ai/api/v1",
3770
+ reasoning: true,
3771
+ input: ["text"],
3772
+ cost: {
3773
+ input: 0.09999999999999999,
3774
+ output: 0.3,
3775
+ cacheRead: 0,
3776
+ cacheWrite: 0,
3777
+ },
3778
+ contextWindow: 262144,
3779
+ maxTokens: 65536,
3780
+ } satisfies Model<"openai-completions">,
3781
+ "thedrummer/rocinante-12b": {
3782
+ id: "thedrummer/rocinante-12b",
3783
+ name: "TheDrummer: Rocinante 12B",
3784
+ api: "openai-completions",
3785
+ provider: "openrouter",
3786
+ baseUrl: "https://openrouter.ai/api/v1",
3787
+ reasoning: false,
3788
+ input: ["text"],
3789
+ cost: {
3790
+ input: 0.16999999999999998,
3791
+ output: 0.43,
3792
+ cacheRead: 0,
3793
+ cacheWrite: 0,
3794
+ },
3795
+ contextWindow: 32768,
3796
+ maxTokens: 32768,
3797
+ } satisfies Model<"openai-completions">,
3798
+ "thedrummer/unslopnemo-12b": {
3799
+ id: "thedrummer/unslopnemo-12b",
3800
+ name: "TheDrummer: UnslopNemo 12B",
3801
+ api: "openai-completions",
3802
+ provider: "openrouter",
3803
+ baseUrl: "https://openrouter.ai/api/v1",
3804
+ reasoning: false,
3805
+ input: ["text"],
3806
+ cost: {
3807
+ input: 0.39999999999999997,
3808
+ output: 0.39999999999999997,
3809
+ cacheRead: 0,
3810
+ cacheWrite: 0,
3811
+ },
3812
+ contextWindow: 32768,
3813
+ maxTokens: 32768,
3814
+ } satisfies Model<"openai-completions">,
3815
+ "tngtech/deepseek-r1t2-chimera": {
3816
+ id: "tngtech/deepseek-r1t2-chimera",
3817
+ name: "TNG: DeepSeek R1T2 Chimera",
3818
+ api: "openai-completions",
3819
+ provider: "openrouter",
3820
+ baseUrl: "https://openrouter.ai/api/v1",
3821
+ reasoning: true,
3822
+ input: ["text"],
3823
+ cost: {
3824
+ input: 0.3,
3825
+ output: 1.1,
3826
+ cacheRead: 0.15,
3827
+ cacheWrite: 0,
3828
+ },
3829
+ contextWindow: 163840,
3830
+ maxTokens: 163840,
3831
+ } satisfies Model<"openai-completions">,
3832
+ "upstage/solar-pro-3": {
3833
+ id: "upstage/solar-pro-3",
3834
+ name: "Upstage: Solar Pro 3",
3835
+ api: "openai-completions",
3836
+ provider: "openrouter",
3837
+ baseUrl: "https://openrouter.ai/api/v1",
3838
+ reasoning: true,
3839
+ input: ["text"],
3840
+ cost: {
3841
+ input: 0.15,
3842
+ output: 0.6,
3843
+ cacheRead: 0.015,
3844
+ cacheWrite: 0,
3845
+ },
3846
+ contextWindow: 128000,
3847
+ maxTokens: 4096,
3848
+ } satisfies Model<"openai-completions">,
3849
+ "x-ai/grok-3": {
3850
+ id: "x-ai/grok-3",
3851
+ name: "xAI: Grok 3",
3852
+ api: "openai-completions",
3853
+ provider: "openrouter",
3854
+ baseUrl: "https://openrouter.ai/api/v1",
3855
+ reasoning: false,
3856
+ input: ["text"],
3857
+ cost: {
3858
+ input: 3,
3859
+ output: 15,
3860
+ cacheRead: 0.75,
3861
+ cacheWrite: 0,
3862
+ },
3863
+ contextWindow: 131072,
3864
+ maxTokens: 4096,
3865
+ } satisfies Model<"openai-completions">,
3866
+ "x-ai/grok-3-beta": {
3867
+ id: "x-ai/grok-3-beta",
3868
+ name: "xAI: Grok 3 Beta",
3869
+ api: "openai-completions",
3870
+ provider: "openrouter",
3871
+ baseUrl: "https://openrouter.ai/api/v1",
3872
+ reasoning: false,
3873
+ input: ["text"],
3874
+ cost: {
3875
+ input: 3,
3876
+ output: 15,
3877
+ cacheRead: 0.75,
3878
+ cacheWrite: 0,
3879
+ },
3880
+ contextWindow: 131072,
3881
+ maxTokens: 4096,
3882
+ } satisfies Model<"openai-completions">,
3883
+ "x-ai/grok-3-mini": {
3884
+ id: "x-ai/grok-3-mini",
3885
+ name: "xAI: Grok 3 Mini",
3886
+ api: "openai-completions",
3887
+ provider: "openrouter",
3888
+ baseUrl: "https://openrouter.ai/api/v1",
3889
+ reasoning: true,
3890
+ input: ["text"],
3891
+ cost: {
3892
+ input: 0.3,
3893
+ output: 0.5,
3894
+ cacheRead: 0.075,
3895
+ cacheWrite: 0,
3896
+ },
3897
+ contextWindow: 131072,
3898
+ maxTokens: 4096,
3899
+ } satisfies Model<"openai-completions">,
3900
+ "x-ai/grok-3-mini-beta": {
3901
+ id: "x-ai/grok-3-mini-beta",
3902
+ name: "xAI: Grok 3 Mini Beta",
3903
+ api: "openai-completions",
3904
+ provider: "openrouter",
3905
+ baseUrl: "https://openrouter.ai/api/v1",
3906
+ reasoning: true,
3907
+ input: ["text"],
3908
+ cost: {
3909
+ input: 0.3,
3910
+ output: 0.5,
3911
+ cacheRead: 0.075,
3912
+ cacheWrite: 0,
3913
+ },
3914
+ contextWindow: 131072,
3915
+ maxTokens: 4096,
3916
+ } satisfies Model<"openai-completions">,
3917
+ "x-ai/grok-4": {
3918
+ id: "x-ai/grok-4",
3919
+ name: "xAI: Grok 4",
3920
+ api: "openai-completions",
3921
+ provider: "openrouter",
3922
+ baseUrl: "https://openrouter.ai/api/v1",
3923
+ reasoning: true,
3924
+ input: ["text", "image"],
3925
+ cost: {
3926
+ input: 3,
3927
+ output: 15,
3928
+ cacheRead: 0.75,
3929
+ cacheWrite: 0,
3930
+ },
3931
+ contextWindow: 256000,
3932
+ maxTokens: 4096,
3933
+ } satisfies Model<"openai-completions">,
3934
+ "x-ai/grok-4-fast": {
3935
+ id: "x-ai/grok-4-fast",
3936
+ name: "xAI: Grok 4 Fast",
3937
+ api: "openai-completions",
3938
+ provider: "openrouter",
3939
+ baseUrl: "https://openrouter.ai/api/v1",
3940
+ reasoning: true,
3941
+ input: ["text", "image"],
3942
+ cost: {
3943
+ input: 0.19999999999999998,
3944
+ output: 0.5,
3945
+ cacheRead: 0.049999999999999996,
3946
+ cacheWrite: 0,
3947
+ },
3948
+ contextWindow: 2000000,
3949
+ maxTokens: 30000,
3950
+ } satisfies Model<"openai-completions">,
3951
+ "x-ai/grok-4.1-fast": {
3952
+ id: "x-ai/grok-4.1-fast",
3953
+ name: "xAI: Grok 4.1 Fast",
3954
+ api: "openai-completions",
3955
+ provider: "openrouter",
3956
+ baseUrl: "https://openrouter.ai/api/v1",
3957
+ reasoning: true,
3958
+ input: ["text", "image"],
3959
+ cost: {
3960
+ input: 0.19999999999999998,
3961
+ output: 0.5,
3962
+ cacheRead: 0.049999999999999996,
3963
+ cacheWrite: 0,
3964
+ },
3965
+ contextWindow: 2000000,
3966
+ maxTokens: 30000,
3967
+ } satisfies Model<"openai-completions">,
3968
+ "x-ai/grok-4.20": {
3969
+ id: "x-ai/grok-4.20",
3970
+ name: "xAI: Grok 4.20",
3971
+ api: "openai-completions",
3972
+ provider: "openrouter",
3973
+ baseUrl: "https://openrouter.ai/api/v1",
3974
+ reasoning: true,
3975
+ input: ["text", "image"],
3976
+ cost: {
3977
+ input: 2,
3978
+ output: 6,
3979
+ cacheRead: 0.19999999999999998,
3980
+ cacheWrite: 0,
3981
+ },
3982
+ contextWindow: 2000000,
3983
+ maxTokens: 4096,
3984
+ } satisfies Model<"openai-completions">,
3985
+ "x-ai/grok-code-fast-1": {
3986
+ id: "x-ai/grok-code-fast-1",
3987
+ name: "xAI: Grok Code Fast 1",
3988
+ api: "openai-completions",
3989
+ provider: "openrouter",
3990
+ baseUrl: "https://openrouter.ai/api/v1",
3991
+ reasoning: true,
3992
+ input: ["text"],
3993
+ cost: {
3994
+ input: 0.19999999999999998,
3995
+ output: 1.5,
3996
+ cacheRead: 0.02,
3997
+ cacheWrite: 0,
3998
+ },
3999
+ contextWindow: 256000,
4000
+ maxTokens: 10000,
4001
+ } satisfies Model<"openai-completions">,
4002
+ "xiaomi/mimo-v2-flash": {
4003
+ id: "xiaomi/mimo-v2-flash",
4004
+ name: "Xiaomi: MiMo-V2-Flash",
4005
+ api: "openai-completions",
4006
+ provider: "openrouter",
4007
+ baseUrl: "https://openrouter.ai/api/v1",
4008
+ reasoning: true,
4009
+ input: ["text"],
4010
+ cost: {
4011
+ input: 0.09,
4012
+ output: 0.29,
4013
+ cacheRead: 0.045,
4014
+ cacheWrite: 0,
4015
+ },
4016
+ contextWindow: 262144,
4017
+ maxTokens: 65536,
4018
+ } satisfies Model<"openai-completions">,
4019
+ "xiaomi/mimo-v2-omni": {
4020
+ id: "xiaomi/mimo-v2-omni",
4021
+ name: "Xiaomi: MiMo-V2-Omni",
4022
+ api: "openai-completions",
4023
+ provider: "openrouter",
4024
+ baseUrl: "https://openrouter.ai/api/v1",
4025
+ reasoning: true,
4026
+ input: ["text", "image"],
4027
+ cost: {
4028
+ input: 0.39999999999999997,
4029
+ output: 2,
4030
+ cacheRead: 0.08,
4031
+ cacheWrite: 0,
4032
+ },
4033
+ contextWindow: 262144,
4034
+ maxTokens: 65536,
4035
+ } satisfies Model<"openai-completions">,
4036
+ "xiaomi/mimo-v2-pro": {
4037
+ id: "xiaomi/mimo-v2-pro",
4038
+ name: "Xiaomi: MiMo-V2-Pro",
4039
+ api: "openai-completions",
4040
+ provider: "openrouter",
4041
+ baseUrl: "https://openrouter.ai/api/v1",
4042
+ reasoning: true,
4043
+ input: ["text"],
4044
+ cost: {
4045
+ input: 1,
4046
+ output: 3,
4047
+ cacheRead: 0.19999999999999998,
4048
+ cacheWrite: 0,
4049
+ },
4050
+ contextWindow: 1048576,
4051
+ maxTokens: 131072,
4052
+ } satisfies Model<"openai-completions">,
4053
+ "z-ai/glm-4-32b": {
4054
+ id: "z-ai/glm-4-32b",
4055
+ name: "Z.ai: GLM 4 32B ",
4056
+ api: "openai-completions",
4057
+ provider: "openrouter",
4058
+ baseUrl: "https://openrouter.ai/api/v1",
4059
+ reasoning: false,
4060
+ input: ["text"],
4061
+ cost: {
4062
+ input: 0.09999999999999999,
4063
+ output: 0.09999999999999999,
4064
+ cacheRead: 0,
4065
+ cacheWrite: 0,
4066
+ },
4067
+ contextWindow: 128000,
4068
+ maxTokens: 4096,
4069
+ } satisfies Model<"openai-completions">,
4070
+ "z-ai/glm-4.5": {
4071
+ id: "z-ai/glm-4.5",
4072
+ name: "Z.ai: GLM 4.5",
4073
+ api: "openai-completions",
4074
+ provider: "openrouter",
4075
+ baseUrl: "https://openrouter.ai/api/v1",
4076
+ reasoning: true,
4077
+ input: ["text"],
4078
+ cost: {
4079
+ input: 0.6,
4080
+ output: 2.2,
4081
+ cacheRead: 0.11,
4082
+ cacheWrite: 0,
4083
+ },
4084
+ contextWindow: 131072,
4085
+ maxTokens: 98304,
4086
+ } satisfies Model<"openai-completions">,
4087
+ "z-ai/glm-4.5-air": {
4088
+ id: "z-ai/glm-4.5-air",
4089
+ name: "Z.ai: GLM 4.5 Air",
4090
+ api: "openai-completions",
4091
+ provider: "openrouter",
4092
+ baseUrl: "https://openrouter.ai/api/v1",
4093
+ reasoning: true,
4094
+ input: ["text"],
4095
+ cost: {
4096
+ input: 0.13,
4097
+ output: 0.85,
4098
+ cacheRead: 0.024999999999999998,
4099
+ cacheWrite: 0,
4100
+ },
4101
+ contextWindow: 131072,
4102
+ maxTokens: 98304,
4103
+ } satisfies Model<"openai-completions">,
4104
+ "z-ai/glm-4.5-air:free": {
4105
+ id: "z-ai/glm-4.5-air:free",
4106
+ name: "Z.ai: GLM 4.5 Air (free)",
4107
+ api: "openai-completions",
4108
+ provider: "openrouter",
4109
+ baseUrl: "https://openrouter.ai/api/v1",
4110
+ reasoning: true,
4111
+ input: ["text"],
4112
+ cost: {
4113
+ input: 0,
4114
+ output: 0,
4115
+ cacheRead: 0,
4116
+ cacheWrite: 0,
4117
+ },
4118
+ contextWindow: 131072,
4119
+ maxTokens: 96000,
4120
+ } satisfies Model<"openai-completions">,
4121
+ "z-ai/glm-4.5v": {
4122
+ id: "z-ai/glm-4.5v",
4123
+ name: "Z.ai: GLM 4.5V",
4124
+ api: "openai-completions",
4125
+ provider: "openrouter",
4126
+ baseUrl: "https://openrouter.ai/api/v1",
4127
+ reasoning: true,
4128
+ input: ["text", "image"],
4129
+ cost: {
4130
+ input: 0.6,
4131
+ output: 1.7999999999999998,
4132
+ cacheRead: 0.11,
4133
+ cacheWrite: 0,
4134
+ },
4135
+ contextWindow: 65536,
4136
+ maxTokens: 16384,
4137
+ } satisfies Model<"openai-completions">,
4138
+ "z-ai/glm-4.6": {
4139
+ id: "z-ai/glm-4.6",
4140
+ name: "Z.ai: GLM 4.6",
4141
+ api: "openai-completions",
4142
+ provider: "openrouter",
4143
+ baseUrl: "https://openrouter.ai/api/v1",
4144
+ reasoning: true,
4145
+ input: ["text"],
4146
+ cost: {
4147
+ input: 0.39,
4148
+ output: 1.9,
4149
+ cacheRead: 0,
4150
+ cacheWrite: 0,
4151
+ },
4152
+ contextWindow: 204800,
4153
+ maxTokens: 204800,
4154
+ } satisfies Model<"openai-completions">,
4155
+ "z-ai/glm-4.6v": {
4156
+ id: "z-ai/glm-4.6v",
4157
+ name: "Z.ai: GLM 4.6V",
4158
+ api: "openai-completions",
4159
+ provider: "openrouter",
4160
+ baseUrl: "https://openrouter.ai/api/v1",
4161
+ reasoning: true,
4162
+ input: ["text", "image"],
4163
+ cost: {
4164
+ input: 0.3,
4165
+ output: 0.8999999999999999,
4166
+ cacheRead: 0,
4167
+ cacheWrite: 0,
4168
+ },
4169
+ contextWindow: 131072,
4170
+ maxTokens: 131072,
4171
+ } satisfies Model<"openai-completions">,
4172
+ "z-ai/glm-4.7": {
4173
+ id: "z-ai/glm-4.7",
4174
+ name: "Z.ai: GLM 4.7",
4175
+ api: "openai-completions",
4176
+ provider: "openrouter",
4177
+ baseUrl: "https://openrouter.ai/api/v1",
4178
+ reasoning: true,
4179
+ input: ["text"],
4180
+ cost: {
4181
+ input: 0.39,
4182
+ output: 1.75,
4183
+ cacheRead: 0.195,
4184
+ cacheWrite: 0,
4185
+ },
4186
+ contextWindow: 202752,
4187
+ maxTokens: 65535,
4188
+ } satisfies Model<"openai-completions">,
4189
+ "z-ai/glm-4.7-flash": {
4190
+ id: "z-ai/glm-4.7-flash",
4191
+ name: "Z.ai: GLM 4.7 Flash",
4192
+ api: "openai-completions",
4193
+ provider: "openrouter",
4194
+ baseUrl: "https://openrouter.ai/api/v1",
4195
+ reasoning: true,
4196
+ input: ["text"],
4197
+ cost: {
4198
+ input: 0.06,
4199
+ output: 0.39999999999999997,
4200
+ cacheRead: 0.0100000002,
4201
+ cacheWrite: 0,
4202
+ },
4203
+ contextWindow: 202752,
4204
+ maxTokens: 4096,
4205
+ } satisfies Model<"openai-completions">,
4206
+ "z-ai/glm-5": {
4207
+ id: "z-ai/glm-5",
4208
+ name: "Z.ai: GLM 5",
4209
+ api: "openai-completions",
4210
+ provider: "openrouter",
4211
+ baseUrl: "https://openrouter.ai/api/v1",
4212
+ reasoning: true,
4213
+ input: ["text"],
4214
+ cost: {
4215
+ input: 0.6,
4216
+ output: 1.9,
4217
+ cacheRead: 0.119,
4218
+ cacheWrite: 0,
4219
+ },
4220
+ contextWindow: 80000,
4221
+ maxTokens: 131072,
4222
+ } satisfies Model<"openai-completions">,
4223
+ "z-ai/glm-5-turbo": {
4224
+ id: "z-ai/glm-5-turbo",
4225
+ name: "Z.ai: GLM 5 Turbo",
4226
+ api: "openai-completions",
4227
+ provider: "openrouter",
4228
+ baseUrl: "https://openrouter.ai/api/v1",
4229
+ reasoning: true,
4230
+ input: ["text"],
4231
+ cost: {
4232
+ input: 1.2,
4233
+ output: 4,
4234
+ cacheRead: 0.24,
4235
+ cacheWrite: 0,
4236
+ },
4237
+ contextWindow: 202752,
4238
+ maxTokens: 131072,
4239
+ } satisfies Model<"openai-completions">,
4240
+ "z-ai/glm-5.1": {
4241
+ id: "z-ai/glm-5.1",
4242
+ name: "Z.ai: GLM 5.1",
4243
+ api: "openai-completions",
4244
+ provider: "openrouter",
4245
+ baseUrl: "https://openrouter.ai/api/v1",
4246
+ reasoning: true,
4247
+ input: ["text"],
4248
+ cost: {
4249
+ input: 0.95,
4250
+ output: 3.15,
4251
+ cacheRead: 0.475,
4252
+ cacheWrite: 0,
4253
+ },
4254
+ contextWindow: 202752,
4255
+ maxTokens: 65535,
4256
+ } satisfies Model<"openai-completions">,
4257
+ "z-ai/glm-5v-turbo": {
4258
+ id: "z-ai/glm-5v-turbo",
4259
+ name: "Z.ai: GLM 5V Turbo",
4260
+ api: "openai-completions",
4261
+ provider: "openrouter",
4262
+ baseUrl: "https://openrouter.ai/api/v1",
4263
+ reasoning: true,
4264
+ input: ["text", "image"],
4265
+ cost: {
4266
+ input: 1.2,
4267
+ output: 4,
4268
+ cacheRead: 0.24,
4269
+ cacheWrite: 0,
4270
+ },
4271
+ contextWindow: 202752,
4272
+ maxTokens: 131072,
4273
+ } satisfies Model<"openai-completions">,
4274
+ } as const satisfies Record<string, Model<any>>;