gsd-pi 2.74.0 → 2.75.0-dev.fd2382b9f

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 (1043) hide show
  1. package/README.md +186 -149
  2. package/dist/claude-cli-check.d.ts +10 -0
  3. package/dist/claude-cli-check.js +13 -3
  4. package/dist/cli.js +85 -0
  5. package/dist/headless-events.d.ts +1 -1
  6. package/dist/headless-events.js +5 -2
  7. package/dist/headless-query.js +4 -1
  8. package/dist/headless.js +5 -6
  9. package/dist/help-text.js +23 -0
  10. package/dist/loader.js +0 -0
  11. package/dist/onboarding.js +39 -14
  12. package/dist/resources/extensions/ask-user-questions.js +17 -5
  13. package/dist/resources/extensions/claude-code-cli/models.js +9 -0
  14. package/dist/resources/extensions/claude-code-cli/readiness.js +12 -2
  15. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +76 -4
  16. package/dist/resources/extensions/gsd/activity-log.js +16 -0
  17. package/dist/resources/extensions/gsd/auto/detect-stuck.js +20 -4
  18. package/dist/resources/extensions/gsd/auto/loop.js +214 -14
  19. package/dist/resources/extensions/gsd/auto/phases.js +273 -51
  20. package/dist/resources/extensions/gsd/auto/resolve.js +1 -1
  21. package/dist/resources/extensions/gsd/auto/run-unit.js +10 -1
  22. package/dist/resources/extensions/gsd/auto/session.js +15 -0
  23. package/dist/resources/extensions/gsd/auto-artifact-paths.js +20 -0
  24. package/dist/resources/extensions/gsd/auto-dashboard.js +15 -7
  25. package/dist/resources/extensions/gsd/auto-dispatch.js +123 -7
  26. package/dist/resources/extensions/gsd/auto-loop.js +1 -1
  27. package/dist/resources/extensions/gsd/auto-model-selection.js +64 -10
  28. package/dist/resources/extensions/gsd/auto-post-unit.js +229 -24
  29. package/dist/resources/extensions/gsd/auto-prompts.js +159 -33
  30. package/dist/resources/extensions/gsd/auto-recovery.js +81 -10
  31. package/dist/resources/extensions/gsd/auto-start.js +5 -3
  32. package/dist/resources/extensions/gsd/auto-unit-closeout.js +18 -0
  33. package/dist/resources/extensions/gsd/auto-verification.js +103 -5
  34. package/dist/resources/extensions/gsd/auto-worktree.js +57 -1
  35. package/dist/resources/extensions/gsd/auto.js +84 -27
  36. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +8 -21
  37. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +22 -4
  38. package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +5 -3
  39. package/dist/resources/extensions/gsd/bootstrap/query-tools.js +29 -0
  40. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +30 -8
  41. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +83 -9
  42. package/dist/resources/extensions/gsd/cache.js +16 -5
  43. package/dist/resources/extensions/gsd/commands/catalog.js +97 -3
  44. package/dist/resources/extensions/gsd/commands/handlers/core.js +11 -1
  45. package/dist/resources/extensions/gsd/commands/handlers/escalate.js +171 -0
  46. package/dist/resources/extensions/gsd/commands/handlers/ops.js +41 -0
  47. package/dist/resources/extensions/gsd/commands/handlers/workflow.js +295 -37
  48. package/dist/resources/extensions/gsd/commands-add-tests.js +111 -0
  49. package/dist/resources/extensions/gsd/commands-backlog.js +140 -0
  50. package/dist/resources/extensions/gsd/commands-cmux.js +5 -2
  51. package/dist/resources/extensions/gsd/commands-debug.js +388 -0
  52. package/dist/resources/extensions/gsd/commands-do.js +80 -0
  53. package/dist/resources/extensions/gsd/commands-extract-learnings.js +225 -0
  54. package/dist/resources/extensions/gsd/commands-handlers.js +21 -2
  55. package/dist/resources/extensions/gsd/commands-maintenance.js +6 -6
  56. package/dist/resources/extensions/gsd/commands-pr-branch.js +180 -0
  57. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +51 -4
  58. package/dist/resources/extensions/gsd/commands-scan.js +94 -0
  59. package/dist/resources/extensions/gsd/commands-session-report.js +82 -0
  60. package/dist/resources/extensions/gsd/commands-ship.js +187 -0
  61. package/dist/resources/extensions/gsd/commands-workflow-templates.js +101 -2
  62. package/dist/resources/extensions/gsd/custom-workflow-engine.js +74 -54
  63. package/dist/resources/extensions/gsd/db-writer.js +4 -5
  64. package/dist/resources/extensions/gsd/debug-session-store.js +238 -0
  65. package/dist/resources/extensions/gsd/definition-loader.js +7 -0
  66. package/dist/resources/extensions/gsd/docs/preferences-reference.md +17 -2
  67. package/dist/resources/extensions/gsd/doctor-git-checks.js +5 -1
  68. package/dist/resources/extensions/gsd/doctor-proactive.js +4 -1
  69. package/dist/resources/extensions/gsd/doctor-providers.js +48 -20
  70. package/dist/resources/extensions/gsd/doctor-runtime-checks.js +22 -4
  71. package/dist/resources/extensions/gsd/doctor.js +7 -1
  72. package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +144 -0
  73. package/dist/resources/extensions/gsd/ecosystem/loader.js +145 -0
  74. package/dist/resources/extensions/gsd/error-classifier.js +6 -3
  75. package/dist/resources/extensions/gsd/escalation.js +321 -0
  76. package/dist/resources/extensions/gsd/forensics.js +26 -29
  77. package/dist/resources/extensions/gsd/git-service.js +49 -2
  78. package/dist/resources/extensions/gsd/graph-context.js +157 -0
  79. package/dist/resources/extensions/gsd/graph.js +26 -2
  80. package/dist/resources/extensions/gsd/gsd-db.js +822 -18
  81. package/dist/resources/extensions/gsd/guided-flow.js +31 -6
  82. package/dist/resources/extensions/gsd/health-widget-core.js +42 -14
  83. package/dist/resources/extensions/gsd/health-widget.js +7 -4
  84. package/dist/resources/extensions/gsd/index.js +15 -2
  85. package/dist/resources/extensions/gsd/init-wizard.js +1 -0
  86. package/dist/resources/extensions/gsd/journal.js +27 -0
  87. package/dist/resources/extensions/gsd/md-importer.js +3 -4
  88. package/dist/resources/extensions/gsd/memory-store.js +19 -51
  89. package/dist/resources/extensions/gsd/metrics.js +20 -0
  90. package/dist/resources/extensions/gsd/milestone-validation-gates.js +13 -12
  91. package/dist/resources/extensions/gsd/model-cost-table.js +3 -1
  92. package/dist/resources/extensions/gsd/model-router.js +7 -1
  93. package/dist/resources/extensions/gsd/native-git-bridge.js +144 -9
  94. package/dist/resources/extensions/gsd/notification-widget.js +24 -39
  95. package/dist/resources/extensions/gsd/notifications.js +4 -0
  96. package/dist/resources/extensions/gsd/parallel-orchestrator.js +33 -1
  97. package/dist/resources/extensions/gsd/post-execution-checks.js +27 -11
  98. package/dist/resources/extensions/gsd/pre-execution-checks.js +97 -4
  99. package/dist/resources/extensions/gsd/preferences-models.js +21 -3
  100. package/dist/resources/extensions/gsd/preferences-types.js +4 -1
  101. package/dist/resources/extensions/gsd/preferences-validation.js +160 -10
  102. package/dist/resources/extensions/gsd/preferences.js +41 -10
  103. package/dist/resources/extensions/gsd/prompts/add-tests.md +35 -0
  104. package/dist/resources/extensions/gsd/prompts/debug-diagnose.md +25 -0
  105. package/dist/resources/extensions/gsd/prompts/debug-session-manager.md +80 -0
  106. package/dist/resources/extensions/gsd/prompts/execute-task.md +12 -0
  107. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +12 -0
  108. package/dist/resources/extensions/gsd/prompts/refine-slice.md +69 -0
  109. package/dist/resources/extensions/gsd/prompts/scan.md +79 -0
  110. package/dist/resources/extensions/gsd/prompts/workflow-oneshot.md +26 -0
  111. package/dist/resources/extensions/gsd/run-manager.js +37 -17
  112. package/dist/resources/extensions/gsd/safety/evidence-collector.js +15 -30
  113. package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +12 -2
  114. package/dist/resources/extensions/gsd/state.js +52 -4
  115. package/dist/resources/extensions/gsd/templates/PREFERENCES.md +19 -0
  116. package/dist/resources/extensions/gsd/tools/complete-slice.js +20 -0
  117. package/dist/resources/extensions/gsd/tools/complete-task.js +80 -0
  118. package/dist/resources/extensions/gsd/tools/plan-milestone.js +37 -12
  119. package/dist/resources/extensions/gsd/tools/plan-slice.js +5 -2
  120. package/dist/resources/extensions/gsd/tools/validate-milestone.js +39 -4
  121. package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +3 -14
  122. package/dist/resources/extensions/gsd/triage-resolution.js +2 -5
  123. package/dist/resources/extensions/gsd/unit-ownership.js +1 -1
  124. package/dist/resources/extensions/gsd/uok/audit-toggle.js +7 -0
  125. package/dist/resources/extensions/gsd/uok/audit.js +40 -0
  126. package/dist/resources/extensions/gsd/uok/contracts.js +1 -0
  127. package/dist/resources/extensions/gsd/uok/execution-graph.js +179 -0
  128. package/dist/resources/extensions/gsd/uok/flags.js +29 -0
  129. package/dist/resources/extensions/gsd/uok/gate-runner.js +109 -0
  130. package/dist/resources/extensions/gsd/uok/gitops.js +53 -0
  131. package/dist/resources/extensions/gsd/uok/kernel.js +85 -0
  132. package/dist/resources/extensions/gsd/uok/loop-adapter.js +133 -0
  133. package/dist/resources/extensions/gsd/uok/model-policy.js +66 -0
  134. package/dist/resources/extensions/gsd/uok/plan-v2.js +132 -0
  135. package/dist/resources/extensions/gsd/workflow-dispatch.js +64 -0
  136. package/dist/resources/extensions/gsd/workflow-install.js +327 -0
  137. package/dist/resources/extensions/gsd/workflow-logger.js +22 -0
  138. package/dist/resources/extensions/gsd/workflow-manifest.js +16 -69
  139. package/dist/resources/extensions/gsd/workflow-mcp.js +1 -6
  140. package/dist/resources/extensions/gsd/workflow-migration.js +21 -22
  141. package/dist/resources/extensions/gsd/workflow-plugins.js +346 -0
  142. package/dist/resources/extensions/gsd/workflow-projections.js +4 -1
  143. package/dist/resources/extensions/gsd/workflow-reconcile.js +14 -11
  144. package/dist/resources/extensions/gsd/workflow-templates/accessibility-audit.md +88 -0
  145. package/dist/resources/extensions/gsd/workflow-templates/api-breaking-change.md +117 -0
  146. package/dist/resources/extensions/gsd/workflow-templates/bugfix.md +1 -0
  147. package/dist/resources/extensions/gsd/workflow-templates/changelog-gen.md +82 -0
  148. package/dist/resources/extensions/gsd/workflow-templates/ci-bootstrap.md +144 -0
  149. package/dist/resources/extensions/gsd/workflow-templates/dead-code.md +81 -0
  150. package/dist/resources/extensions/gsd/workflow-templates/dep-upgrade.md +1 -0
  151. package/dist/resources/extensions/gsd/workflow-templates/docs-sync.yaml +76 -0
  152. package/dist/resources/extensions/gsd/workflow-templates/env-audit.yaml +88 -0
  153. package/dist/resources/extensions/gsd/workflow-templates/full-project.md +1 -0
  154. package/dist/resources/extensions/gsd/workflow-templates/hotfix.md +1 -0
  155. package/dist/resources/extensions/gsd/workflow-templates/issue-triage.md +84 -0
  156. package/dist/resources/extensions/gsd/workflow-templates/observability-setup.md +133 -0
  157. package/dist/resources/extensions/gsd/workflow-templates/onboarding-check.md +74 -0
  158. package/dist/resources/extensions/gsd/workflow-templates/performance-audit.md +125 -0
  159. package/dist/resources/extensions/gsd/workflow-templates/pr-review.md +67 -0
  160. package/dist/resources/extensions/gsd/workflow-templates/pr-triage.md +83 -0
  161. package/dist/resources/extensions/gsd/workflow-templates/refactor.md +1 -0
  162. package/dist/resources/extensions/gsd/workflow-templates/registry.json +184 -0
  163. package/dist/resources/extensions/gsd/workflow-templates/release.md +118 -0
  164. package/dist/resources/extensions/gsd/workflow-templates/rename-symbol.yaml +99 -0
  165. package/dist/resources/extensions/gsd/workflow-templates/security-audit.md +1 -0
  166. package/dist/resources/extensions/gsd/workflow-templates/small-feature.md +1 -0
  167. package/dist/resources/extensions/gsd/workflow-templates/spike.md +1 -0
  168. package/dist/resources/extensions/gsd/workflow-templates/test-backfill.yaml +73 -0
  169. package/dist/resources/extensions/gsd/worktree-resolver.js +42 -1
  170. package/dist/resources/extensions/remote-questions/commands.js +380 -0
  171. package/dist/resources/extensions/remote-questions/manager.js +39 -5
  172. package/dist/resources/extensions/remote-questions/telegram-adapter.js +79 -4
  173. package/dist/resources/extensions/shared/interview-ui.js +189 -1
  174. package/dist/resources/extensions/shared/layout-utils.js +17 -0
  175. package/dist/resources/extensions/shared/rtk-shared.js +47 -0
  176. package/dist/resources/extensions/shared/rtk.js +3 -46
  177. package/dist/resources/extensions/ttsr/ttsr-manager.js +3 -1
  178. package/dist/resources/skills/create-workflow/SKILL.md +33 -6
  179. package/dist/rtk-shared.d.ts +10 -0
  180. package/dist/rtk-shared.js +47 -0
  181. package/dist/rtk.d.ts +2 -6
  182. package/dist/rtk.js +3 -48
  183. package/dist/shared/workspace-types.d.ts +52 -0
  184. package/dist/shared/workspace-types.js +1 -0
  185. package/dist/tsconfig.extensions.tsbuildinfo +1 -0
  186. package/dist/update-check.d.ts +10 -0
  187. package/dist/update-check.js +24 -3
  188. package/dist/web/standalone/.next/BUILD_ID +1 -1
  189. package/dist/web/standalone/.next/app-path-routes-manifest.json +10 -10
  190. package/dist/web/standalone/.next/build-manifest.json +4 -4
  191. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  192. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  193. package/dist/web/standalone/.next/required-server-files.json +3 -3
  194. package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
  195. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  196. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  197. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  198. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  199. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  200. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  201. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  202. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  203. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  204. package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
  205. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  206. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  207. package/dist/web/standalone/.next/server/app/_not-found.rsc +4 -4
  208. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +4 -4
  209. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  210. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +4 -4
  211. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  212. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  213. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  214. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  215. package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
  216. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  217. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
  218. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  219. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
  220. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
  221. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
  222. package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
  223. package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
  224. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  225. package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
  226. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  227. package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
  228. package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
  229. package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
  230. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  231. package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
  232. package/dist/web/standalone/.next/server/app/api/experimental/route.js +2 -2
  233. package/dist/web/standalone/.next/server/app/api/experimental/route_client-reference-manifest.js +1 -1
  234. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  235. package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
  236. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  237. package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
  238. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  239. package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
  240. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  241. package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
  242. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  243. package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
  244. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  245. package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
  246. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  247. package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
  248. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  249. package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
  250. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  251. package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
  252. package/dist/web/standalone/.next/server/app/api/notifications/route.js +2 -2
  253. package/dist/web/standalone/.next/server/app/api/notifications/route_client-reference-manifest.js +1 -1
  254. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  255. package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
  256. package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
  257. package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
  258. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  259. package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
  260. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  261. package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
  262. package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +2 -2
  263. package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
  264. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  265. package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
  266. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  267. package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
  268. package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
  269. package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
  270. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  271. package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
  272. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  273. package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
  274. package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
  275. package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  276. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  277. package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
  278. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  279. package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
  280. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  281. package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
  282. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +2 -2
  283. package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
  284. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
  285. package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
  286. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
  287. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
  288. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
  289. package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
  290. package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
  291. package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
  292. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  293. package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
  294. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  295. package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
  296. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  297. package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
  298. package/dist/web/standalone/.next/server/app/index.html +1 -1
  299. package/dist/web/standalone/.next/server/app/index.rsc +5 -5
  300. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  301. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +5 -5
  302. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  303. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +4 -4
  304. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  305. package/dist/web/standalone/.next/server/app/page.js +2 -2
  306. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  307. package/dist/web/standalone/.next/server/app-paths-manifest.json +10 -10
  308. package/dist/web/standalone/.next/server/chunks/63.js +3 -3
  309. package/dist/web/standalone/.next/server/chunks/6897.js +3 -3
  310. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  311. package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
  312. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  313. package/dist/web/standalone/.next/server/middleware.js +2 -2
  314. package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
  315. package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
  316. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  317. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  318. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  319. package/dist/web/standalone/.next/static/chunks/2826.02df9631042cc18e.js +9 -0
  320. package/dist/web/standalone/.next/static/chunks/app/_not-found/{page-2f24283c162b6ab3.js → page-f2a7482d42a5614b.js} +1 -1
  321. package/dist/web/standalone/.next/static/chunks/app/{layout-9ecfd95f343793f0.js → layout-a16c7a7ecdf0c2cf.js} +1 -1
  322. package/dist/web/standalone/.next/static/chunks/app/page-f1e30ab6bb269149.js +1 -0
  323. package/dist/web/standalone/.next/static/chunks/main-app-fdab67f7802d7832.js +1 -0
  324. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
  325. package/dist/web/standalone/.next/static/chunks/{webpack-b868033a5834586d.js → webpack-6c7cda3e318eedb6.js} +1 -1
  326. package/dist/web/standalone/.next/static/css/3e9cdadb4d23b8a4.css +1 -0
  327. package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
  328. package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
  329. package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
  330. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
  331. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
  332. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
  333. package/dist/web/standalone/server.js +1 -1
  334. package/dist/welcome-screen.js +48 -24
  335. package/dist/wizard.js +2 -2
  336. package/dist/worktree-cli.d.ts +6 -5
  337. package/dist/worktree-cli.js +23 -7
  338. package/package.json +5 -4
  339. package/packages/daemon/package.json +2 -2
  340. package/packages/mcp-server/dist/index.d.ts +3 -0
  341. package/packages/mcp-server/dist/index.d.ts.map +1 -1
  342. package/packages/mcp-server/dist/index.js +3 -0
  343. package/packages/mcp-server/dist/index.js.map +1 -1
  344. package/packages/mcp-server/dist/readers/graph.d.ts +87 -0
  345. package/packages/mcp-server/dist/readers/graph.d.ts.map +1 -0
  346. package/packages/mcp-server/dist/readers/graph.js +655 -0
  347. package/packages/mcp-server/dist/readers/graph.js.map +1 -0
  348. package/packages/mcp-server/dist/readers/index.d.ts +2 -0
  349. package/packages/mcp-server/dist/readers/index.d.ts.map +1 -1
  350. package/packages/mcp-server/dist/readers/index.js +1 -0
  351. package/packages/mcp-server/dist/readers/index.js.map +1 -1
  352. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  353. package/packages/mcp-server/dist/server.js +65 -0
  354. package/packages/mcp-server/dist/server.js.map +1 -1
  355. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  356. package/packages/mcp-server/dist/workflow-tools.js +88 -6
  357. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  358. package/packages/mcp-server/package.json +2 -2
  359. package/packages/mcp-server/src/index.ts +15 -0
  360. package/packages/mcp-server/src/readers/graph.test.ts +604 -0
  361. package/packages/mcp-server/src/readers/graph.ts +855 -0
  362. package/packages/mcp-server/src/readers/index.ts +12 -0
  363. package/packages/mcp-server/src/server.ts +83 -0
  364. package/packages/mcp-server/src/workflow-tools.ts +95 -10
  365. package/packages/mcp-server/tsconfig.json +1 -0
  366. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -0
  367. package/packages/native/package.json +2 -2
  368. package/packages/native/tsconfig.tsbuildinfo +1 -0
  369. package/packages/pi-agent-core/package.json +1 -1
  370. package/packages/pi-agent-core/tsconfig.json +1 -0
  371. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -0
  372. package/packages/pi-ai/dist/index.d.ts +1 -9
  373. package/packages/pi-ai/dist/index.d.ts.map +1 -1
  374. package/packages/pi-ai/dist/index.js +1 -9
  375. package/packages/pi-ai/dist/index.js.map +1 -1
  376. package/packages/pi-ai/dist/models/capability-patches.d.ts +19 -0
  377. package/packages/pi-ai/dist/models/capability-patches.d.ts.map +1 -0
  378. package/packages/pi-ai/dist/models/capability-patches.js +37 -0
  379. package/packages/pi-ai/dist/models/capability-patches.js.map +1 -0
  380. package/packages/pi-ai/dist/{models.custom.d.ts → models/custom.d.ts} +1 -1
  381. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -0
  382. package/packages/pi-ai/dist/{models.custom.js → models/custom.js} +4 -4
  383. package/packages/pi-ai/dist/models/custom.js.map +1 -0
  384. package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts +1550 -0
  385. package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts.map +1 -0
  386. package/packages/pi-ai/dist/models/generated/amazon-bedrock.js +1552 -0
  387. package/packages/pi-ai/dist/models/generated/amazon-bedrock.js.map +1 -0
  388. package/packages/pi-ai/dist/models/generated/anthropic.d.ts +394 -0
  389. package/packages/pi-ai/dist/models/generated/anthropic.d.ts.map +1 -0
  390. package/packages/pi-ai/dist/models/generated/anthropic.js +396 -0
  391. package/packages/pi-ai/dist/models/generated/anthropic.js.map +1 -0
  392. package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts +700 -0
  393. package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts.map +1 -0
  394. package/packages/pi-ai/dist/models/generated/azure-openai-responses.js +702 -0
  395. package/packages/pi-ai/dist/models/generated/azure-openai-responses.js.map +1 -0
  396. package/packages/pi-ai/dist/models/generated/cerebras.d.ts +71 -0
  397. package/packages/pi-ai/dist/models/generated/cerebras.d.ts.map +1 -0
  398. package/packages/pi-ai/dist/models/generated/cerebras.js +73 -0
  399. package/packages/pi-ai/dist/models/generated/cerebras.js.map +1 -0
  400. package/packages/pi-ai/dist/models/generated/github-copilot.d.ts +590 -0
  401. package/packages/pi-ai/dist/models/generated/github-copilot.d.ts.map +1 -0
  402. package/packages/pi-ai/dist/models/generated/github-copilot.js +444 -0
  403. package/packages/pi-ai/dist/models/generated/github-copilot.js.map +1 -0
  404. package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts +173 -0
  405. package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts.map +1 -0
  406. package/packages/pi-ai/dist/models/generated/google-antigravity.js +175 -0
  407. package/packages/pi-ai/dist/models/generated/google-antigravity.js.map +1 -0
  408. package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts +105 -0
  409. package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts.map +1 -0
  410. package/packages/pi-ai/dist/models/generated/google-gemini-cli.js +107 -0
  411. package/packages/pi-ai/dist/models/generated/google-gemini-cli.js.map +1 -0
  412. package/packages/pi-ai/dist/models/generated/google-vertex.d.ts +207 -0
  413. package/packages/pi-ai/dist/models/generated/google-vertex.d.ts.map +1 -0
  414. package/packages/pi-ai/dist/models/generated/google-vertex.js +209 -0
  415. package/packages/pi-ai/dist/models/generated/google-vertex.js.map +1 -0
  416. package/packages/pi-ai/dist/models/generated/google.d.ts +462 -0
  417. package/packages/pi-ai/dist/models/generated/google.d.ts.map +1 -0
  418. package/packages/pi-ai/dist/models/generated/google.js +464 -0
  419. package/packages/pi-ai/dist/models/generated/google.js.map +1 -0
  420. package/packages/pi-ai/dist/models/generated/groq.d.ts +156 -0
  421. package/packages/pi-ai/dist/models/generated/groq.d.ts.map +1 -0
  422. package/packages/pi-ai/dist/models/generated/groq.js +158 -0
  423. package/packages/pi-ai/dist/models/generated/groq.js.map +1 -0
  424. package/packages/pi-ai/dist/models/generated/huggingface.d.ts +383 -0
  425. package/packages/pi-ai/dist/models/generated/huggingface.d.ts.map +1 -0
  426. package/packages/pi-ai/dist/models/generated/huggingface.js +347 -0
  427. package/packages/pi-ai/dist/models/generated/huggingface.js.map +1 -0
  428. package/packages/pi-ai/dist/{models.generated.d.ts → models/generated/index.d.ts} +137 -154
  429. package/packages/pi-ai/dist/{models.generated.d.ts.map → models/generated/index.d.ts.map} +1 -1
  430. package/packages/pi-ai/dist/models/generated/index.js +51 -0
  431. package/packages/pi-ai/dist/models/generated/index.js.map +1 -0
  432. package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts +37 -0
  433. package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts.map +1 -0
  434. package/packages/pi-ai/dist/models/generated/kimi-coding.js +39 -0
  435. package/packages/pi-ai/dist/models/generated/kimi-coding.js.map +1 -0
  436. package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts +105 -0
  437. package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts.map +1 -0
  438. package/packages/pi-ai/dist/models/generated/minimax-cn.js +107 -0
  439. package/packages/pi-ai/dist/models/generated/minimax-cn.js.map +1 -0
  440. package/packages/pi-ai/dist/models/generated/minimax.d.ts +105 -0
  441. package/packages/pi-ai/dist/models/generated/minimax.d.ts.map +1 -0
  442. package/packages/pi-ai/dist/models/generated/minimax.js +107 -0
  443. package/packages/pi-ai/dist/models/generated/minimax.js.map +1 -0
  444. package/packages/pi-ai/dist/models/generated/mistral.d.ts +445 -0
  445. package/packages/pi-ai/dist/models/generated/mistral.d.ts.map +1 -0
  446. package/packages/pi-ai/dist/models/generated/mistral.js +447 -0
  447. package/packages/pi-ai/dist/models/generated/mistral.js.map +1 -0
  448. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts +156 -0
  449. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts.map +1 -0
  450. package/packages/pi-ai/dist/models/generated/openai-codex.js +158 -0
  451. package/packages/pi-ai/dist/models/generated/openai-codex.js.map +1 -0
  452. package/packages/pi-ai/dist/models/generated/openai.d.ts +700 -0
  453. package/packages/pi-ai/dist/models/generated/openai.d.ts.map +1 -0
  454. package/packages/pi-ai/dist/models/generated/openai.js +702 -0
  455. package/packages/pi-ai/dist/models/generated/openai.js.map +1 -0
  456. package/packages/pi-ai/dist/models/generated/opencode-go.d.ts +122 -0
  457. package/packages/pi-ai/dist/models/generated/opencode-go.d.ts.map +1 -0
  458. package/packages/pi-ai/dist/models/generated/opencode-go.js +124 -0
  459. package/packages/pi-ai/dist/models/generated/opencode-go.js.map +1 -0
  460. package/packages/pi-ai/dist/models/generated/opencode.d.ts +530 -0
  461. package/packages/pi-ai/dist/models/generated/opencode.d.ts.map +1 -0
  462. package/packages/pi-ai/dist/models/generated/opencode.js +532 -0
  463. package/packages/pi-ai/dist/models/generated/opencode.js.map +1 -0
  464. package/packages/pi-ai/dist/models/generated/openrouter.d.ts +4287 -0
  465. package/packages/pi-ai/dist/models/generated/openrouter.d.ts.map +1 -0
  466. package/packages/pi-ai/dist/models/generated/openrouter.js +4289 -0
  467. package/packages/pi-ai/dist/models/generated/openrouter.js.map +1 -0
  468. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts +2604 -0
  469. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts.map +1 -0
  470. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js +2606 -0
  471. package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js.map +1 -0
  472. package/packages/pi-ai/dist/models/generated/xai.d.ts +411 -0
  473. package/packages/pi-ai/dist/models/generated/xai.d.ts.map +1 -0
  474. package/packages/pi-ai/dist/models/generated/xai.js +413 -0
  475. package/packages/pi-ai/dist/models/generated/xai.js.map +1 -0
  476. package/packages/pi-ai/dist/models/generated/zai.d.ts +276 -0
  477. package/packages/pi-ai/dist/models/generated/zai.d.ts.map +1 -0
  478. package/packages/pi-ai/dist/models/generated/zai.js +239 -0
  479. package/packages/pi-ai/dist/models/generated/zai.js.map +1 -0
  480. package/packages/pi-ai/dist/models/index.d.ts +27 -0
  481. package/packages/pi-ai/dist/models/index.d.ts.map +1 -0
  482. package/packages/pi-ai/dist/models/index.js +80 -0
  483. package/packages/pi-ai/dist/models/index.js.map +1 -0
  484. package/packages/pi-ai/dist/models.d.ts +1 -36
  485. package/packages/pi-ai/dist/models.d.ts.map +1 -1
  486. package/packages/pi-ai/dist/models.generated.test.js +18 -2
  487. package/packages/pi-ai/dist/models.generated.test.js.map +1 -1
  488. package/packages/pi-ai/dist/models.js +3 -112
  489. package/packages/pi-ai/dist/models.js.map +1 -1
  490. package/packages/pi-ai/dist/models.test.js +6 -5
  491. package/packages/pi-ai/dist/models.test.js.map +1 -1
  492. package/packages/pi-ai/dist/providers/amazon-bedrock.d.ts +22 -1
  493. package/packages/pi-ai/dist/providers/amazon-bedrock.d.ts.map +1 -1
  494. package/packages/pi-ai/dist/providers/amazon-bedrock.js +40 -6
  495. package/packages/pi-ai/dist/providers/amazon-bedrock.js.map +1 -1
  496. package/packages/pi-ai/dist/providers/amazon-bedrock.test.d.ts +2 -0
  497. package/packages/pi-ai/dist/providers/amazon-bedrock.test.d.ts.map +1 -0
  498. package/packages/pi-ai/dist/providers/amazon-bedrock.test.js +106 -0
  499. package/packages/pi-ai/dist/providers/amazon-bedrock.test.js.map +1 -0
  500. package/packages/pi-ai/dist/providers/anthropic-auth.test.js +42 -1
  501. package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
  502. package/packages/pi-ai/dist/providers/anthropic-shared.d.ts +20 -1
  503. package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
  504. package/packages/pi-ai/dist/providers/anthropic-shared.js +32 -2
  505. package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
  506. package/packages/pi-ai/dist/providers/anthropic-shared.test.js +12 -1
  507. package/packages/pi-ai/dist/providers/anthropic-shared.test.js.map +1 -1
  508. package/packages/pi-ai/dist/providers/anthropic.d.ts +11 -0
  509. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  510. package/packages/pi-ai/dist/providers/anthropic.js +18 -1
  511. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  512. package/packages/pi-ai/dist/utils/oauth/openai-codex.d.ts.map +1 -1
  513. package/packages/pi-ai/dist/utils/oauth/openai-codex.js +12 -0
  514. package/packages/pi-ai/dist/utils/oauth/openai-codex.js.map +1 -1
  515. package/packages/pi-ai/package.json +2 -2
  516. package/packages/pi-ai/scripts/generate-models.ts +124 -40
  517. package/packages/pi-ai/src/index.ts +1 -9
  518. package/packages/pi-ai/src/models/capability-patches.ts +43 -0
  519. package/packages/pi-ai/src/{models.custom.ts → models/custom.ts} +4 -4
  520. package/packages/pi-ai/src/models/generated/amazon-bedrock.ts +1554 -0
  521. package/packages/pi-ai/src/models/generated/anthropic.ts +398 -0
  522. package/packages/pi-ai/src/models/generated/azure-openai-responses.ts +704 -0
  523. package/packages/pi-ai/src/models/generated/cerebras.ts +75 -0
  524. package/packages/pi-ai/src/models/generated/github-copilot.ts +446 -0
  525. package/packages/pi-ai/src/models/generated/google-antigravity.ts +177 -0
  526. package/packages/pi-ai/src/models/generated/google-gemini-cli.ts +109 -0
  527. package/packages/pi-ai/src/models/generated/google-vertex.ts +211 -0
  528. package/packages/pi-ai/src/models/generated/google.ts +466 -0
  529. package/packages/pi-ai/src/models/generated/groq.ts +160 -0
  530. package/packages/pi-ai/src/models/generated/huggingface.ts +349 -0
  531. package/packages/pi-ai/src/models/generated/index.ts +52 -0
  532. package/packages/pi-ai/src/models/generated/kimi-coding.ts +41 -0
  533. package/packages/pi-ai/src/models/generated/minimax-cn.ts +109 -0
  534. package/packages/pi-ai/src/models/generated/minimax.ts +109 -0
  535. package/packages/pi-ai/src/models/generated/mistral.ts +449 -0
  536. package/packages/pi-ai/src/models/generated/openai-codex.ts +160 -0
  537. package/packages/pi-ai/src/models/generated/openai.ts +704 -0
  538. package/packages/pi-ai/src/models/generated/opencode-go.ts +126 -0
  539. package/packages/pi-ai/src/models/generated/opencode.ts +534 -0
  540. package/packages/pi-ai/src/models/generated/openrouter.ts +4291 -0
  541. package/packages/pi-ai/src/models/generated/vercel-ai-gateway.ts +2608 -0
  542. package/packages/pi-ai/src/models/generated/xai.ts +415 -0
  543. package/packages/pi-ai/src/models/generated/zai.ts +241 -0
  544. package/packages/pi-ai/src/models/index.ts +106 -0
  545. package/packages/pi-ai/src/models.generated.test.ts +18 -2
  546. package/packages/pi-ai/src/models.test.ts +6 -5
  547. package/packages/pi-ai/src/models.ts +3 -153
  548. package/packages/pi-ai/src/providers/amazon-bedrock.test.ts +164 -0
  549. package/packages/pi-ai/src/providers/amazon-bedrock.ts +41 -7
  550. package/packages/pi-ai/src/providers/anthropic-auth.test.ts +47 -1
  551. package/packages/pi-ai/src/providers/anthropic-shared.test.ts +15 -1
  552. package/packages/pi-ai/src/providers/anthropic-shared.ts +36 -3
  553. package/packages/pi-ai/src/providers/anthropic.ts +19 -1
  554. package/packages/pi-ai/src/utils/oauth/openai-codex.ts +15 -0
  555. package/packages/pi-ai/tsconfig.json +1 -0
  556. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -0
  557. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.d.ts +2 -0
  558. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.d.ts.map +1 -0
  559. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +38 -0
  560. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -0
  561. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  562. package/packages/pi-coding-agent/dist/core/agent-session.js +8 -2
  563. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  564. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +14 -0
  565. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
  566. package/packages/pi-coding-agent/dist/core/auth-storage.js +34 -0
  567. package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
  568. package/packages/pi-coding-agent/dist/core/auth-storage.test.js +74 -0
  569. package/packages/pi-coding-agent/dist/core/auth-storage.test.js.map +1 -1
  570. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +476 -1
  571. package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
  572. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +32 -0
  573. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
  574. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts +2 -0
  575. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts.map +1 -0
  576. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js +52 -0
  577. package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js.map +1 -0
  578. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  579. package/packages/pi-coding-agent/dist/core/model-registry.js +2 -2
  580. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  581. package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  582. package/packages/pi-coding-agent/dist/core/sdk.js +32 -0
  583. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  584. package/packages/pi-coding-agent/dist/core/skill-tool.test.js +2 -2
  585. package/packages/pi-coding-agent/dist/core/skill-tool.test.js.map +1 -1
  586. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.d.ts +2 -0
  587. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.d.ts.map +1 -0
  588. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.js +61 -0
  589. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.js.map +1 -0
  590. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +11 -0
  591. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
  592. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts +1 -0
  593. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
  594. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js +23 -9
  595. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
  596. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts +11 -0
  597. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -0
  598. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +63 -0
  599. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -0
  600. package/packages/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.d.ts +8 -5
  601. package/packages/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -1
  602. package/packages/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.js +27 -13
  603. package/packages/pi-coding-agent/dist/modes/interactive/components/compaction-summary-message.js.map +1 -1
  604. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  605. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +48 -34
  606. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  607. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts +8 -0
  608. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  609. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +68 -8
  610. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  611. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
  612. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js +22 -22
  613. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
  614. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts +4 -0
  615. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  616. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +315 -51
  617. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  618. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts +2 -0
  619. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts.map +1 -0
  620. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js +38 -0
  621. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js.map +1 -0
  622. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +14 -0
  623. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  624. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +70 -6
  625. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  626. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.d.ts +70 -0
  627. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.d.ts.map +1 -0
  628. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.js +77 -0
  629. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme-schema.js.map +1 -0
  630. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts +1 -66
  631. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  632. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js +1 -75
  633. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js.map +1 -1
  634. package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.d.ts +1 -1
  635. package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.d.ts.map +1 -1
  636. package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js +192 -24
  637. package/packages/pi-coding-agent/dist/modes/interactive/theme/themes.js.map +1 -1
  638. package/packages/pi-coding-agent/package.json +1 -1
  639. package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +56 -0
  640. package/packages/pi-coding-agent/src/core/agent-session.ts +12 -6
  641. package/packages/pi-coding-agent/src/core/auth-storage.test.ts +83 -0
  642. package/packages/pi-coding-agent/src/core/auth-storage.ts +35 -0
  643. package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +616 -1
  644. package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +37 -1
  645. package/packages/pi-coding-agent/src/core/model-registry-env-fallback.test.ts +59 -0
  646. package/packages/pi-coding-agent/src/core/model-registry.ts +2 -1
  647. package/packages/pi-coding-agent/src/core/sdk.ts +41 -0
  648. package/packages/pi-coding-agent/src/core/skill-tool.test.ts +2 -2
  649. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/chat-frame-compaction-tone.test.ts +92 -0
  650. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +19 -0
  651. package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +25 -10
  652. package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +87 -0
  653. package/packages/pi-coding-agent/src/modes/interactive/components/compaction-summary-message.ts +36 -15
  654. package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +53 -31
  655. package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +83 -7
  656. package/packages/pi-coding-agent/src/modes/interactive/components/user-message.ts +23 -26
  657. package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +386 -77
  658. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-ordering.test.ts +44 -0
  659. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +92 -6
  660. package/packages/pi-coding-agent/src/modes/interactive/theme/theme-schema.ts +83 -0
  661. package/packages/pi-coding-agent/src/modes/interactive/theme/theme.ts +2 -83
  662. package/packages/pi-coding-agent/src/modes/interactive/theme/themes.ts +208 -27
  663. package/packages/pi-coding-agent/src/types/ambient-modules.d.ts +69 -0
  664. package/packages/pi-coding-agent/tsconfig.json +3 -2
  665. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -0
  666. package/packages/pi-tui/dist/tui.d.ts.map +1 -1
  667. package/packages/pi-tui/dist/tui.js +9 -2
  668. package/packages/pi-tui/dist/tui.js.map +1 -1
  669. package/packages/pi-tui/package.json +1 -1
  670. package/packages/pi-tui/src/tui.ts +9 -1
  671. package/packages/pi-tui/tsconfig.json +1 -0
  672. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -0
  673. package/packages/rpc-client/package.json +1 -1
  674. package/packages/rpc-client/tsconfig.json +1 -0
  675. package/packages/rpc-client/tsconfig.tsbuildinfo +1 -0
  676. package/pkg/dist/modes/interactive/theme/theme-schema.d.ts +70 -0
  677. package/pkg/dist/modes/interactive/theme/theme-schema.d.ts.map +1 -0
  678. package/pkg/dist/modes/interactive/theme/theme-schema.js +77 -0
  679. package/pkg/dist/modes/interactive/theme/theme-schema.js.map +1 -0
  680. package/pkg/dist/modes/interactive/theme/theme.d.ts +1 -66
  681. package/pkg/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  682. package/pkg/dist/modes/interactive/theme/theme.js +1 -75
  683. package/pkg/dist/modes/interactive/theme/theme.js.map +1 -1
  684. package/pkg/dist/modes/interactive/theme/themes.d.ts +1 -1
  685. package/pkg/dist/modes/interactive/theme/themes.d.ts.map +1 -1
  686. package/pkg/dist/modes/interactive/theme/themes.js +192 -24
  687. package/pkg/dist/modes/interactive/theme/themes.js.map +1 -1
  688. package/pkg/package.json +1 -1
  689. package/src/resources/extensions/ask-user-questions.ts +24 -6
  690. package/src/resources/extensions/claude-code-cli/models.ts +9 -0
  691. package/src/resources/extensions/claude-code-cli/readiness.ts +13 -2
  692. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +94 -4
  693. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +84 -0
  694. package/src/resources/extensions/gsd/activity-log.ts +21 -0
  695. package/src/resources/extensions/gsd/auto/detect-stuck.ts +22 -4
  696. package/src/resources/extensions/gsd/auto/loop-deps.ts +11 -0
  697. package/src/resources/extensions/gsd/auto/loop.ts +268 -13
  698. package/src/resources/extensions/gsd/auto/phases.ts +349 -64
  699. package/src/resources/extensions/gsd/auto/resolve.ts +1 -1
  700. package/src/resources/extensions/gsd/auto/run-unit.ts +11 -1
  701. package/src/resources/extensions/gsd/auto/session.ts +17 -0
  702. package/src/resources/extensions/gsd/auto-artifact-paths.ts +20 -0
  703. package/src/resources/extensions/gsd/auto-dashboard.ts +21 -4
  704. package/src/resources/extensions/gsd/auto-dispatch.ts +139 -11
  705. package/src/resources/extensions/gsd/auto-loop.ts +1 -1
  706. package/src/resources/extensions/gsd/auto-model-selection.ts +82 -10
  707. package/src/resources/extensions/gsd/auto-post-unit.ts +247 -25
  708. package/src/resources/extensions/gsd/auto-prompts.ts +188 -35
  709. package/src/resources/extensions/gsd/auto-recovery.ts +92 -10
  710. package/src/resources/extensions/gsd/auto-start.ts +8 -6
  711. package/src/resources/extensions/gsd/auto-unit-closeout.ts +25 -1
  712. package/src/resources/extensions/gsd/auto-verification.ts +132 -5
  713. package/src/resources/extensions/gsd/auto-worktree.ts +66 -0
  714. package/src/resources/extensions/gsd/auto.ts +92 -28
  715. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +8 -21
  716. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +22 -4
  717. package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +5 -3
  718. package/src/resources/extensions/gsd/bootstrap/query-tools.ts +31 -0
  719. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +38 -8
  720. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +94 -8
  721. package/src/resources/extensions/gsd/cache.ts +16 -5
  722. package/src/resources/extensions/gsd/commands/catalog.ts +90 -3
  723. package/src/resources/extensions/gsd/commands/handlers/core.ts +11 -1
  724. package/src/resources/extensions/gsd/commands/handlers/escalate.ts +216 -0
  725. package/src/resources/extensions/gsd/commands/handlers/ops.ts +41 -0
  726. package/src/resources/extensions/gsd/commands/handlers/workflow.ts +352 -37
  727. package/src/resources/extensions/gsd/commands-add-tests.ts +137 -0
  728. package/src/resources/extensions/gsd/commands-backlog.ts +182 -0
  729. package/src/resources/extensions/gsd/commands-cmux.ts +6 -2
  730. package/src/resources/extensions/gsd/commands-debug.ts +484 -0
  731. package/src/resources/extensions/gsd/commands-do.ts +110 -0
  732. package/src/resources/extensions/gsd/commands-extract-learnings.ts +304 -0
  733. package/src/resources/extensions/gsd/commands-handlers.ts +19 -2
  734. package/src/resources/extensions/gsd/commands-maintenance.ts +6 -6
  735. package/src/resources/extensions/gsd/commands-pr-branch.ts +234 -0
  736. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +58 -4
  737. package/src/resources/extensions/gsd/commands-scan.ts +125 -0
  738. package/src/resources/extensions/gsd/commands-session-report.ts +101 -0
  739. package/src/resources/extensions/gsd/commands-ship.ts +219 -0
  740. package/src/resources/extensions/gsd/commands-workflow-templates.ts +129 -2
  741. package/src/resources/extensions/gsd/custom-workflow-engine.ts +85 -60
  742. package/src/resources/extensions/gsd/db-writer.ts +6 -5
  743. package/src/resources/extensions/gsd/debug-session-store.ts +377 -0
  744. package/src/resources/extensions/gsd/definition-loader.ts +7 -0
  745. package/src/resources/extensions/gsd/docs/preferences-reference.md +17 -2
  746. package/src/resources/extensions/gsd/doctor-git-checks.ts +5 -1
  747. package/src/resources/extensions/gsd/doctor-proactive.ts +4 -1
  748. package/src/resources/extensions/gsd/doctor-providers.ts +52 -22
  749. package/src/resources/extensions/gsd/doctor-runtime-checks.ts +23 -4
  750. package/src/resources/extensions/gsd/doctor-types.ts +1 -0
  751. package/src/resources/extensions/gsd/doctor.ts +7 -1
  752. package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +228 -0
  753. package/src/resources/extensions/gsd/ecosystem/loader.ts +201 -0
  754. package/src/resources/extensions/gsd/error-classifier.ts +6 -3
  755. package/src/resources/extensions/gsd/escalation.ts +367 -0
  756. package/src/resources/extensions/gsd/forensics.ts +25 -29
  757. package/src/resources/extensions/gsd/git-service.ts +68 -1
  758. package/src/resources/extensions/gsd/graph-context.ts +212 -0
  759. package/src/resources/extensions/gsd/graph.ts +33 -3
  760. package/src/resources/extensions/gsd/gsd-db.ts +1083 -21
  761. package/src/resources/extensions/gsd/guided-flow.ts +36 -2
  762. package/src/resources/extensions/gsd/health-widget-core.ts +43 -14
  763. package/src/resources/extensions/gsd/health-widget.ts +7 -3
  764. package/src/resources/extensions/gsd/index.ts +18 -2
  765. package/src/resources/extensions/gsd/init-wizard.ts +3 -2
  766. package/src/resources/extensions/gsd/journal.ts +30 -0
  767. package/src/resources/extensions/gsd/md-importer.ts +3 -5
  768. package/src/resources/extensions/gsd/memory-store.ts +31 -62
  769. package/src/resources/extensions/gsd/metrics.ts +27 -0
  770. package/src/resources/extensions/gsd/milestone-validation-gates.ts +13 -14
  771. package/src/resources/extensions/gsd/model-cost-table.ts +3 -1
  772. package/src/resources/extensions/gsd/model-router.ts +15 -1
  773. package/src/resources/extensions/gsd/native-git-bridge.ts +145 -18
  774. package/src/resources/extensions/gsd/notification-widget.ts +25 -43
  775. package/src/resources/extensions/gsd/notifications.ts +6 -0
  776. package/src/resources/extensions/gsd/parallel-orchestrator.ts +40 -1
  777. package/src/resources/extensions/gsd/post-execution-checks.ts +37 -14
  778. package/src/resources/extensions/gsd/pre-execution-checks.ts +98 -8
  779. package/src/resources/extensions/gsd/preferences-models.ts +21 -3
  780. package/src/resources/extensions/gsd/preferences-types.ts +47 -1
  781. package/src/resources/extensions/gsd/preferences-validation.ts +150 -9
  782. package/src/resources/extensions/gsd/preferences.ts +44 -10
  783. package/src/resources/extensions/gsd/prompts/add-tests.md +35 -0
  784. package/src/resources/extensions/gsd/prompts/debug-diagnose.md +25 -0
  785. package/src/resources/extensions/gsd/prompts/debug-session-manager.md +80 -0
  786. package/src/resources/extensions/gsd/prompts/execute-task.md +12 -0
  787. package/src/resources/extensions/gsd/prompts/plan-milestone.md +12 -0
  788. package/src/resources/extensions/gsd/prompts/refine-slice.md +69 -0
  789. package/src/resources/extensions/gsd/prompts/scan.md +79 -0
  790. package/src/resources/extensions/gsd/prompts/workflow-oneshot.md +26 -0
  791. package/src/resources/extensions/gsd/run-manager.ts +53 -19
  792. package/src/resources/extensions/gsd/safety/evidence-collector.ts +15 -31
  793. package/src/resources/extensions/gsd/session-lock.ts +14 -2
  794. package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +20 -1
  795. package/src/resources/extensions/gsd/state.ts +59 -4
  796. package/src/resources/extensions/gsd/templates/PREFERENCES.md +19 -0
  797. package/src/resources/extensions/gsd/tests/agent-end-retry.test.ts +1 -34
  798. package/src/resources/extensions/gsd/tests/artifact-corruption-2630.test.ts +7 -0
  799. package/src/resources/extensions/gsd/tests/artifacts-table-preserved-on-cache-invalidate.test.ts +177 -0
  800. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +49 -31
  801. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +20 -0
  802. package/src/resources/extensions/gsd/tests/auto-project-root-env.test.ts +7 -3
  803. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +123 -1
  804. package/src/resources/extensions/gsd/tests/auto-retry-mcp-churn-fixes.test.ts +272 -0
  805. package/src/resources/extensions/gsd/tests/auto-warning-noise-regression.test.ts +117 -0
  806. package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +39 -0
  807. package/src/resources/extensions/gsd/tests/autocomplete-regressions-1675.test.ts +39 -0
  808. package/src/resources/extensions/gsd/tests/cold-resume-db-reopen.test.ts +6 -2
  809. package/src/resources/extensions/gsd/tests/commands-backlog.test.ts +158 -0
  810. package/src/resources/extensions/gsd/tests/commands-do.test.ts +175 -0
  811. package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +340 -0
  812. package/src/resources/extensions/gsd/tests/commands-pr-branch.test.ts +68 -0
  813. package/src/resources/extensions/gsd/tests/commands-scan.test.ts +351 -0
  814. package/src/resources/extensions/gsd/tests/commands-session-report.test.ts +82 -0
  815. package/src/resources/extensions/gsd/tests/commands-ship.test.ts +71 -0
  816. package/src/resources/extensions/gsd/tests/commands-workflow-custom.test.ts +22 -6
  817. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  818. package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
  819. package/src/resources/extensions/gsd/tests/custom-workflow-engine.test.ts +63 -0
  820. package/src/resources/extensions/gsd/tests/debug-command-handler.test.ts +905 -0
  821. package/src/resources/extensions/gsd/tests/debug-command-lifecycle.integration.test.ts +1229 -0
  822. package/src/resources/extensions/gsd/tests/debug-session-store.test.ts +565 -0
  823. package/src/resources/extensions/gsd/tests/discuss-milestone-structured-questions.test.ts +64 -0
  824. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +67 -0
  825. package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +62 -18
  826. package/src/resources/extensions/gsd/tests/enhanced-verification-integration.test.ts +5 -0
  827. package/src/resources/extensions/gsd/tests/escalation.test.ts +818 -0
  828. package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +154 -0
  829. package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +39 -19
  830. package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +106 -0
  831. package/src/resources/extensions/gsd/tests/forensics-hook-key-parse.test.ts +74 -0
  832. package/src/resources/extensions/gsd/tests/graph-context.test.ts +337 -0
  833. package/src/resources/extensions/gsd/tests/graph-operations.test.ts +0 -4
  834. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +44 -1
  835. package/src/resources/extensions/gsd/tests/health-widget.test.ts +9 -3
  836. package/src/resources/extensions/gsd/tests/integration/doctor-git.test.ts +39 -0
  837. package/src/resources/extensions/gsd/tests/integration/doctor-proactive.test.ts +44 -0
  838. package/src/resources/extensions/gsd/tests/integration/doctor-runtime.test.ts +68 -1
  839. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +109 -11
  840. package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +51 -0
  841. package/src/resources/extensions/gsd/tests/integration/test-isolation.ts +53 -0
  842. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +242 -5
  843. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -2
  844. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -3
  845. package/src/resources/extensions/gsd/tests/milestone-status-tool.test.ts +3 -2
  846. package/src/resources/extensions/gsd/tests/model-cost-table.test.ts +2 -2
  847. package/src/resources/extensions/gsd/tests/model-router.test.ts +1 -1
  848. package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +59 -0
  849. package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +140 -0
  850. package/src/resources/extensions/gsd/tests/notification-widget.test.ts +1 -1
  851. package/src/resources/extensions/gsd/tests/plan-slice.test.ts +17 -0
  852. package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +79 -1
  853. package/src/resources/extensions/gsd/tests/post-execution-checks.test.ts +105 -1
  854. package/src/resources/extensions/gsd/tests/post-unit-state-rebuild.test.ts +2 -1
  855. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +275 -6
  856. package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +40 -1
  857. package/src/resources/extensions/gsd/tests/preferences.test.ts +214 -1
  858. package/src/resources/extensions/gsd/tests/progressive-planning.test.ts +539 -0
  859. package/src/resources/extensions/gsd/tests/projection-regression.test.ts +7 -0
  860. package/src/resources/extensions/gsd/tests/prompt-budget-enforcement.test.ts +27 -0
  861. package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +24 -0
  862. package/src/resources/extensions/gsd/tests/prompt-db.test.ts +1 -1
  863. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +90 -2
  864. package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +68 -1
  865. package/src/resources/extensions/gsd/tests/remote-notification-from-desktop.test.ts +107 -0
  866. package/src/resources/extensions/gsd/tests/requirements.test.ts +9 -0
  867. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +153 -0
  868. package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +180 -0
  869. package/src/resources/extensions/gsd/tests/slice-context-injection.test.ts +16 -4
  870. package/src/resources/extensions/gsd/tests/state-corruption-2945.test.ts +3 -0
  871. package/src/resources/extensions/gsd/tests/stuck-detection-coverage.test.ts +15 -0
  872. package/src/resources/extensions/gsd/tests/summary-render-parity.test.ts +5 -0
  873. package/src/resources/extensions/gsd/tests/token-profile.test.ts +8 -5
  874. package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +101 -0
  875. package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +86 -0
  876. package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +69 -0
  877. package/src/resources/extensions/gsd/tests/uok-flags.test.ts +69 -0
  878. package/src/resources/extensions/gsd/tests/uok-gate-runner.test.ts +70 -0
  879. package/src/resources/extensions/gsd/tests/uok-gitops-turn-action.test.ts +85 -0
  880. package/src/resources/extensions/gsd/tests/uok-gitops-wiring.test.ts +35 -0
  881. package/src/resources/extensions/gsd/tests/uok-kernel-path.test.ts +166 -0
  882. package/src/resources/extensions/gsd/tests/uok-model-policy.test.ts +89 -0
  883. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +167 -0
  884. package/src/resources/extensions/gsd/tests/uok-preferences.test.ts +42 -0
  885. package/src/resources/extensions/gsd/tests/validate-milestone-write-order.test.ts +39 -0
  886. package/src/resources/extensions/gsd/tests/workflow-install.test.ts +113 -0
  887. package/src/resources/extensions/gsd/tests/workflow-logger-wiring.test.ts +232 -0
  888. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +2 -2
  889. package/src/resources/extensions/gsd/tests/workflow-plugins.test.ts +310 -0
  890. package/src/resources/extensions/gsd/tests/workflow-projections.test.ts +7 -0
  891. package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +8 -2
  892. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +2 -1
  893. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +77 -2
  894. package/src/resources/extensions/gsd/tools/complete-slice.ts +26 -0
  895. package/src/resources/extensions/gsd/tools/complete-task.ts +87 -0
  896. package/src/resources/extensions/gsd/tools/plan-milestone.ts +42 -8
  897. package/src/resources/extensions/gsd/tools/plan-slice.ts +6 -1
  898. package/src/resources/extensions/gsd/tools/validate-milestone.ts +48 -3
  899. package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +3 -11
  900. package/src/resources/extensions/gsd/triage-resolution.ts +2 -7
  901. package/src/resources/extensions/gsd/types.ts +76 -1
  902. package/src/resources/extensions/gsd/unit-ownership.ts +2 -2
  903. package/src/resources/extensions/gsd/unit-runtime.ts +1 -0
  904. package/src/resources/extensions/gsd/uok/audit-toggle.ts +9 -0
  905. package/src/resources/extensions/gsd/uok/audit.ts +51 -0
  906. package/src/resources/extensions/gsd/uok/contracts.ts +136 -0
  907. package/src/resources/extensions/gsd/uok/execution-graph.ts +241 -0
  908. package/src/resources/extensions/gsd/uok/flags.ts +45 -0
  909. package/src/resources/extensions/gsd/uok/gate-runner.ts +146 -0
  910. package/src/resources/extensions/gsd/uok/gitops.ts +75 -0
  911. package/src/resources/extensions/gsd/uok/kernel.ts +117 -0
  912. package/src/resources/extensions/gsd/uok/loop-adapter.ts +162 -0
  913. package/src/resources/extensions/gsd/uok/model-policy.ts +112 -0
  914. package/src/resources/extensions/gsd/uok/plan-v2.ts +156 -0
  915. package/src/resources/extensions/gsd/workflow-dispatch.ts +106 -0
  916. package/src/resources/extensions/gsd/workflow-install.ts +423 -0
  917. package/src/resources/extensions/gsd/workflow-logger.ts +27 -1
  918. package/src/resources/extensions/gsd/workflow-manifest.ts +17 -104
  919. package/src/resources/extensions/gsd/workflow-mcp.ts +1 -6
  920. package/src/resources/extensions/gsd/workflow-migration.ts +21 -29
  921. package/src/resources/extensions/gsd/workflow-plugins.ts +403 -0
  922. package/src/resources/extensions/gsd/workflow-projections.ts +8 -1
  923. package/src/resources/extensions/gsd/workflow-reconcile.ts +15 -15
  924. package/src/resources/extensions/gsd/workflow-templates/accessibility-audit.md +88 -0
  925. package/src/resources/extensions/gsd/workflow-templates/api-breaking-change.md +117 -0
  926. package/src/resources/extensions/gsd/workflow-templates/bugfix.md +1 -0
  927. package/src/resources/extensions/gsd/workflow-templates/changelog-gen.md +82 -0
  928. package/src/resources/extensions/gsd/workflow-templates/ci-bootstrap.md +144 -0
  929. package/src/resources/extensions/gsd/workflow-templates/dead-code.md +81 -0
  930. package/src/resources/extensions/gsd/workflow-templates/dep-upgrade.md +1 -0
  931. package/src/resources/extensions/gsd/workflow-templates/docs-sync.yaml +76 -0
  932. package/src/resources/extensions/gsd/workflow-templates/env-audit.yaml +88 -0
  933. package/src/resources/extensions/gsd/workflow-templates/full-project.md +1 -0
  934. package/src/resources/extensions/gsd/workflow-templates/hotfix.md +1 -0
  935. package/src/resources/extensions/gsd/workflow-templates/issue-triage.md +84 -0
  936. package/src/resources/extensions/gsd/workflow-templates/observability-setup.md +133 -0
  937. package/src/resources/extensions/gsd/workflow-templates/onboarding-check.md +74 -0
  938. package/src/resources/extensions/gsd/workflow-templates/performance-audit.md +125 -0
  939. package/src/resources/extensions/gsd/workflow-templates/pr-review.md +67 -0
  940. package/src/resources/extensions/gsd/workflow-templates/pr-triage.md +83 -0
  941. package/src/resources/extensions/gsd/workflow-templates/refactor.md +1 -0
  942. package/src/resources/extensions/gsd/workflow-templates/registry.json +184 -0
  943. package/src/resources/extensions/gsd/workflow-templates/release.md +118 -0
  944. package/src/resources/extensions/gsd/workflow-templates/rename-symbol.yaml +99 -0
  945. package/src/resources/extensions/gsd/workflow-templates/security-audit.md +1 -0
  946. package/src/resources/extensions/gsd/workflow-templates/small-feature.md +1 -0
  947. package/src/resources/extensions/gsd/workflow-templates/spike.md +1 -0
  948. package/src/resources/extensions/gsd/workflow-templates/test-backfill.yaml +73 -0
  949. package/src/resources/extensions/gsd/workflow-templates.ts +7 -0
  950. package/src/resources/extensions/gsd/workspace-index.ts +9 -4
  951. package/src/resources/extensions/gsd/worktree-resolver.ts +47 -1
  952. package/src/resources/extensions/remote-questions/commands.ts +480 -0
  953. package/src/resources/extensions/remote-questions/manager.ts +49 -4
  954. package/src/resources/extensions/remote-questions/telegram-adapter.ts +86 -4
  955. package/src/resources/extensions/remote-questions/tests/command-polling.test.ts +246 -0
  956. package/src/resources/extensions/remote-questions/tests/remote-answer-normalization.test.ts +92 -0
  957. package/src/resources/extensions/remote-questions/tests/telegram-commands.test.ts +267 -0
  958. package/src/resources/extensions/shared/interview-ui.ts +195 -1
  959. package/src/resources/extensions/shared/layout-utils.ts +26 -0
  960. package/src/resources/extensions/shared/rtk-shared.ts +58 -0
  961. package/src/resources/extensions/shared/rtk.ts +12 -52
  962. package/src/resources/extensions/shared/tests/interview-preview.test.ts +177 -0
  963. package/src/resources/extensions/shared/tests/preview-layout.test.ts +120 -0
  964. package/src/resources/extensions/ttsr/ttsr-manager.ts +10 -5
  965. package/src/resources/skills/create-workflow/SKILL.md +33 -6
  966. package/dist/web/standalone/.next/static/chunks/2826.dd3dc8bbd3025fa5.js +0 -9
  967. package/dist/web/standalone/.next/static/chunks/app/page-7115e62689b5fd84.js +0 -1
  968. package/dist/web/standalone/.next/static/chunks/main-app-d3d4c336195465f9.js +0 -1
  969. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-ab5a8926e07ec673.js +0 -1
  970. package/dist/web/standalone/.next/static/css/f6e8833d46e738d8.css +0 -1
  971. package/packages/native/dist/ps/types.d.ts +0 -5
  972. package/packages/native/dist/ps/types.js +0 -2
  973. package/packages/native/src/ps/types.ts +0 -5
  974. package/packages/pi-ai/dist/models.custom.d.ts.map +0 -1
  975. package/packages/pi-ai/dist/models.custom.js.map +0 -1
  976. package/packages/pi-ai/dist/models.generated.js +0 -14343
  977. package/packages/pi-ai/dist/models.generated.js.map +0 -1
  978. package/packages/pi-ai/node_modules/@smithy/node-http-handler/LICENSE +0 -201
  979. package/packages/pi-ai/node_modules/@smithy/node-http-handler/README.md +0 -9
  980. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-cjs/index.js +0 -762
  981. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/build-abort-error.js +0 -19
  982. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/constants.js +0 -1
  983. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/get-transformed-headers.js +0 -9
  984. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/index.js +0 -3
  985. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/node-http-handler.js +0 -230
  986. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/node-http2-connection-manager.js +0 -87
  987. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/node-http2-connection-pool.js +0 -32
  988. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/node-http2-handler.js +0 -169
  989. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/readable.mock.js +0 -21
  990. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/server.mock.js +0 -88
  991. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/set-connection-timeout.js +0 -36
  992. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/set-request-timeout.js +0 -21
  993. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/set-socket-keep-alive.js +0 -22
  994. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/set-socket-timeout.js +0 -23
  995. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/stream-collector/collector.js +0 -8
  996. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/stream-collector/index.js +0 -41
  997. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/stream-collector/readable.mock.js +0 -21
  998. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/timing.js +0 -4
  999. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-es/write-request-body.js +0 -63
  1000. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/build-abort-error.d.ts +0 -10
  1001. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/constants.d.ts +0 -5
  1002. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/get-transformed-headers.d.ts +0 -4
  1003. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/index.d.ts +0 -3
  1004. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/node-http-handler.d.ts +0 -46
  1005. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/node-http2-connection-manager.d.ts +0 -24
  1006. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/node-http2-connection-pool.d.ts +0 -12
  1007. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/node-http2-handler.d.ts +0 -63
  1008. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/readable.mock.d.ts +0 -13
  1009. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/server.mock.d.ts +0 -12
  1010. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/set-connection-timeout.d.ts +0 -2
  1011. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/set-request-timeout.d.ts +0 -6
  1012. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/set-socket-keep-alive.d.ts +0 -6
  1013. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/set-socket-timeout.d.ts +0 -2
  1014. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/stream-collector/collector.d.ts +0 -5
  1015. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/stream-collector/index.d.ts +0 -6
  1016. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/stream-collector/readable.mock.d.ts +0 -13
  1017. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/timing.d.ts +0 -8
  1018. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/build-abort-error.d.ts +0 -10
  1019. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/constants.d.ts +0 -5
  1020. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/get-transformed-headers.d.ts +0 -4
  1021. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/index.d.ts +0 -3
  1022. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/node-http-handler.d.ts +0 -46
  1023. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/node-http2-connection-manager.d.ts +0 -24
  1024. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/node-http2-connection-pool.d.ts +0 -12
  1025. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/node-http2-handler.d.ts +0 -63
  1026. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/readable.mock.d.ts +0 -13
  1027. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/server.mock.d.ts +0 -12
  1028. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/set-connection-timeout.d.ts +0 -2
  1029. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/set-request-timeout.d.ts +0 -6
  1030. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/set-socket-keep-alive.d.ts +0 -6
  1031. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/set-socket-timeout.d.ts +0 -2
  1032. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/stream-collector/collector.d.ts +0 -5
  1033. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/stream-collector/index.d.ts +0 -6
  1034. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/stream-collector/readable.mock.d.ts +0 -13
  1035. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/timing.d.ts +0 -8
  1036. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/ts3.4/write-request-body.d.ts +0 -12
  1037. package/packages/pi-ai/node_modules/@smithy/node-http-handler/dist-types/write-request-body.d.ts +0 -12
  1038. package/packages/pi-ai/node_modules/@smithy/node-http-handler/package.json +0 -68
  1039. package/packages/pi-ai/oauth.d.ts +0 -1
  1040. package/packages/pi-ai/oauth.js +0 -1
  1041. package/packages/pi-ai/src/models.generated.ts +0 -14345
  1042. /package/dist/web/standalone/.next/static/{JpjdI2QtmIkQr4xz6gbhM → jaWw1Jh0TYayjbfOrFe8D}/_buildManifest.js +0 -0
  1043. /package/dist/web/standalone/.next/static/{JpjdI2QtmIkQr4xz6gbhM → jaWw1Jh0TYayjbfOrFe8D}/_ssgManifest.js +0 -0
@@ -0,0 +1,4291 @@
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.7": {
297
+ id: "anthropic/claude-opus-4.7",
298
+ name: "Anthropic: Claude Opus 4.7",
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: 5,
306
+ output: 25,
307
+ cacheRead: 0.5,
308
+ cacheWrite: 6.25,
309
+ },
310
+ contextWindow: 1000000,
311
+ maxTokens: 128000,
312
+ } satisfies Model<"openai-completions">,
313
+ "anthropic/claude-opus-4.6-fast": {
314
+ id: "anthropic/claude-opus-4.6-fast",
315
+ name: "Anthropic: Claude Opus 4.6 (Fast)",
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: 30,
323
+ output: 150,
324
+ cacheRead: 3,
325
+ cacheWrite: 37.5,
326
+ },
327
+ contextWindow: 1000000,
328
+ maxTokens: 128000,
329
+ } satisfies Model<"openai-completions">,
330
+ "anthropic/claude-sonnet-4": {
331
+ id: "anthropic/claude-sonnet-4",
332
+ name: "Anthropic: Claude Sonnet 4",
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.5": {
348
+ id: "anthropic/claude-sonnet-4.5",
349
+ name: "Anthropic: Claude Sonnet 4.5",
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: 64000,
363
+ } satisfies Model<"openai-completions">,
364
+ "anthropic/claude-sonnet-4.6": {
365
+ id: "anthropic/claude-sonnet-4.6",
366
+ name: "Anthropic: Claude Sonnet 4.6",
367
+ api: "openai-completions",
368
+ provider: "openrouter",
369
+ baseUrl: "https://openrouter.ai/api/v1",
370
+ reasoning: true,
371
+ input: ["text", "image"],
372
+ cost: {
373
+ input: 3,
374
+ output: 15,
375
+ cacheRead: 0.3,
376
+ cacheWrite: 3.75,
377
+ },
378
+ contextWindow: 1000000,
379
+ maxTokens: 128000,
380
+ } satisfies Model<"openai-completions">,
381
+ "arcee-ai/trinity-large-preview:free": {
382
+ id: "arcee-ai/trinity-large-preview:free",
383
+ name: "Arcee AI: Trinity Large Preview (free)",
384
+ api: "openai-completions",
385
+ provider: "openrouter",
386
+ baseUrl: "https://openrouter.ai/api/v1",
387
+ reasoning: false,
388
+ input: ["text"],
389
+ cost: {
390
+ input: 0,
391
+ output: 0,
392
+ cacheRead: 0,
393
+ cacheWrite: 0,
394
+ },
395
+ contextWindow: 131000,
396
+ maxTokens: 4096,
397
+ } satisfies Model<"openai-completions">,
398
+ "arcee-ai/trinity-large-thinking": {
399
+ id: "arcee-ai/trinity-large-thinking",
400
+ name: "Arcee AI: Trinity Large Thinking",
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.22,
408
+ output: 0.85,
409
+ cacheRead: 0,
410
+ cacheWrite: 0,
411
+ },
412
+ contextWindow: 262144,
413
+ maxTokens: 262144,
414
+ } satisfies Model<"openai-completions">,
415
+ "arcee-ai/trinity-mini": {
416
+ id: "arcee-ai/trinity-mini",
417
+ name: "Arcee AI: Trinity Mini",
418
+ api: "openai-completions",
419
+ provider: "openrouter",
420
+ baseUrl: "https://openrouter.ai/api/v1",
421
+ reasoning: true,
422
+ input: ["text"],
423
+ cost: {
424
+ input: 0.045,
425
+ output: 0.15,
426
+ cacheRead: 0,
427
+ cacheWrite: 0,
428
+ },
429
+ contextWindow: 131072,
430
+ maxTokens: 131072,
431
+ } satisfies Model<"openai-completions">,
432
+ "arcee-ai/virtuoso-large": {
433
+ id: "arcee-ai/virtuoso-large",
434
+ name: "Arcee AI: Virtuoso Large",
435
+ api: "openai-completions",
436
+ provider: "openrouter",
437
+ baseUrl: "https://openrouter.ai/api/v1",
438
+ reasoning: false,
439
+ input: ["text"],
440
+ cost: {
441
+ input: 0.75,
442
+ output: 1.2,
443
+ cacheRead: 0,
444
+ cacheWrite: 0,
445
+ },
446
+ contextWindow: 131072,
447
+ maxTokens: 64000,
448
+ } satisfies Model<"openai-completions">,
449
+ "auto": {
450
+ id: "auto",
451
+ name: "Auto",
452
+ api: "openai-completions",
453
+ provider: "openrouter",
454
+ baseUrl: "https://openrouter.ai/api/v1",
455
+ reasoning: true,
456
+ input: ["text", "image"],
457
+ cost: {
458
+ input: 0,
459
+ output: 0,
460
+ cacheRead: 0,
461
+ cacheWrite: 0,
462
+ },
463
+ contextWindow: 2000000,
464
+ maxTokens: 30000,
465
+ } satisfies Model<"openai-completions">,
466
+ "baidu/ernie-4.5-21b-a3b": {
467
+ id: "baidu/ernie-4.5-21b-a3b",
468
+ name: "Baidu: ERNIE 4.5 21B A3B",
469
+ api: "openai-completions",
470
+ provider: "openrouter",
471
+ baseUrl: "https://openrouter.ai/api/v1",
472
+ reasoning: false,
473
+ input: ["text"],
474
+ cost: {
475
+ input: 0.07,
476
+ output: 0.28,
477
+ cacheRead: 0,
478
+ cacheWrite: 0,
479
+ },
480
+ contextWindow: 120000,
481
+ maxTokens: 8000,
482
+ } satisfies Model<"openai-completions">,
483
+ "baidu/ernie-4.5-vl-28b-a3b": {
484
+ id: "baidu/ernie-4.5-vl-28b-a3b",
485
+ name: "Baidu: ERNIE 4.5 VL 28B A3B",
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.14,
493
+ output: 0.56,
494
+ cacheRead: 0,
495
+ cacheWrite: 0,
496
+ },
497
+ contextWindow: 30000,
498
+ maxTokens: 8000,
499
+ } satisfies Model<"openai-completions">,
500
+ "bytedance-seed/seed-1.6": {
501
+ id: "bytedance-seed/seed-1.6",
502
+ name: "ByteDance Seed: Seed 1.6",
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.25,
510
+ output: 2,
511
+ cacheRead: 0,
512
+ cacheWrite: 0,
513
+ },
514
+ contextWindow: 262144,
515
+ maxTokens: 32768,
516
+ } satisfies Model<"openai-completions">,
517
+ "bytedance-seed/seed-1.6-flash": {
518
+ id: "bytedance-seed/seed-1.6-flash",
519
+ name: "ByteDance Seed: Seed 1.6 Flash",
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.075,
527
+ output: 0.3,
528
+ cacheRead: 0,
529
+ cacheWrite: 0,
530
+ },
531
+ contextWindow: 262144,
532
+ maxTokens: 32768,
533
+ } satisfies Model<"openai-completions">,
534
+ "bytedance-seed/seed-2.0-lite": {
535
+ id: "bytedance-seed/seed-2.0-lite",
536
+ name: "ByteDance Seed: Seed-2.0-Lite",
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.25,
544
+ output: 2,
545
+ cacheRead: 0,
546
+ cacheWrite: 0,
547
+ },
548
+ contextWindow: 262144,
549
+ maxTokens: 131072,
550
+ } satisfies Model<"openai-completions">,
551
+ "bytedance-seed/seed-2.0-mini": {
552
+ id: "bytedance-seed/seed-2.0-mini",
553
+ name: "ByteDance Seed: Seed-2.0-Mini",
554
+ api: "openai-completions",
555
+ provider: "openrouter",
556
+ baseUrl: "https://openrouter.ai/api/v1",
557
+ reasoning: true,
558
+ input: ["text", "image"],
559
+ cost: {
560
+ input: 0.09999999999999999,
561
+ output: 0.39999999999999997,
562
+ cacheRead: 0,
563
+ cacheWrite: 0,
564
+ },
565
+ contextWindow: 262144,
566
+ maxTokens: 131072,
567
+ } satisfies Model<"openai-completions">,
568
+ "cohere/command-r-08-2024": {
569
+ id: "cohere/command-r-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: 0.15,
578
+ output: 0.6,
579
+ cacheRead: 0,
580
+ cacheWrite: 0,
581
+ },
582
+ contextWindow: 128000,
583
+ maxTokens: 4000,
584
+ } satisfies Model<"openai-completions">,
585
+ "cohere/command-r-plus-08-2024": {
586
+ id: "cohere/command-r-plus-08-2024",
587
+ name: "Cohere: Command R+ (08-2024)",
588
+ api: "openai-completions",
589
+ provider: "openrouter",
590
+ baseUrl: "https://openrouter.ai/api/v1",
591
+ reasoning: false,
592
+ input: ["text"],
593
+ cost: {
594
+ input: 2.5,
595
+ output: 10,
596
+ cacheRead: 0,
597
+ cacheWrite: 0,
598
+ },
599
+ contextWindow: 128000,
600
+ maxTokens: 4000,
601
+ } satisfies Model<"openai-completions">,
602
+ "deepseek/deepseek-chat": {
603
+ id: "deepseek/deepseek-chat",
604
+ name: "DeepSeek: DeepSeek V3",
605
+ api: "openai-completions",
606
+ provider: "openrouter",
607
+ baseUrl: "https://openrouter.ai/api/v1",
608
+ reasoning: false,
609
+ input: ["text"],
610
+ cost: {
611
+ input: 0.32,
612
+ output: 0.8899999999999999,
613
+ cacheRead: 0,
614
+ cacheWrite: 0,
615
+ },
616
+ contextWindow: 163840,
617
+ maxTokens: 163840,
618
+ } satisfies Model<"openai-completions">,
619
+ "deepseek/deepseek-chat-v3-0324": {
620
+ id: "deepseek/deepseek-chat-v3-0324",
621
+ name: "DeepSeek: DeepSeek V3 0324",
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.19999999999999998,
629
+ output: 0.77,
630
+ cacheRead: 0.135,
631
+ cacheWrite: 0,
632
+ },
633
+ contextWindow: 163840,
634
+ maxTokens: 4096,
635
+ } satisfies Model<"openai-completions">,
636
+ "deepseek/deepseek-chat-v3.1": {
637
+ id: "deepseek/deepseek-chat-v3.1",
638
+ name: "DeepSeek: DeepSeek V3.1",
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.15,
646
+ output: 0.75,
647
+ cacheRead: 0,
648
+ cacheWrite: 0,
649
+ },
650
+ contextWindow: 32768,
651
+ maxTokens: 7168,
652
+ } satisfies Model<"openai-completions">,
653
+ "deepseek/deepseek-r1": {
654
+ id: "deepseek/deepseek-r1",
655
+ name: "DeepSeek: R1",
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.7,
663
+ output: 2.5,
664
+ cacheRead: 0,
665
+ cacheWrite: 0,
666
+ },
667
+ contextWindow: 64000,
668
+ maxTokens: 16000,
669
+ } satisfies Model<"openai-completions">,
670
+ "deepseek/deepseek-r1-0528": {
671
+ id: "deepseek/deepseek-r1-0528",
672
+ name: "DeepSeek: R1 0528",
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.5,
680
+ output: 2.1500000000000004,
681
+ cacheRead: 0.35,
682
+ cacheWrite: 0,
683
+ },
684
+ contextWindow: 163840,
685
+ maxTokens: 4096,
686
+ } satisfies Model<"openai-completions">,
687
+ "deepseek/deepseek-v3.1-terminus": {
688
+ id: "deepseek/deepseek-v3.1-terminus",
689
+ name: "DeepSeek: DeepSeek V3.1 Terminus",
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.21,
697
+ output: 0.7899999999999999,
698
+ cacheRead: 0.1300000002,
699
+ cacheWrite: 0,
700
+ },
701
+ contextWindow: 163840,
702
+ maxTokens: 4096,
703
+ } satisfies Model<"openai-completions">,
704
+ "deepseek/deepseek-v3.2": {
705
+ id: "deepseek/deepseek-v3.2",
706
+ name: "DeepSeek: DeepSeek V3.2",
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.26,
714
+ output: 0.38,
715
+ cacheRead: 0.13,
716
+ cacheWrite: 0,
717
+ },
718
+ contextWindow: 163840,
719
+ maxTokens: 4096,
720
+ } satisfies Model<"openai-completions">,
721
+ "deepseek/deepseek-v3.2-exp": {
722
+ id: "deepseek/deepseek-v3.2-exp",
723
+ name: "DeepSeek: DeepSeek V3.2 Exp",
724
+ api: "openai-completions",
725
+ provider: "openrouter",
726
+ baseUrl: "https://openrouter.ai/api/v1",
727
+ reasoning: true,
728
+ input: ["text"],
729
+ cost: {
730
+ input: 0.27,
731
+ output: 0.41,
732
+ cacheRead: 0,
733
+ cacheWrite: 0,
734
+ },
735
+ contextWindow: 163840,
736
+ maxTokens: 65536,
737
+ } satisfies Model<"openai-completions">,
738
+ "essentialai/rnj-1-instruct": {
739
+ id: "essentialai/rnj-1-instruct",
740
+ name: "EssentialAI: Rnj 1 Instruct",
741
+ api: "openai-completions",
742
+ provider: "openrouter",
743
+ baseUrl: "https://openrouter.ai/api/v1",
744
+ reasoning: false,
745
+ input: ["text"],
746
+ cost: {
747
+ input: 0.15,
748
+ output: 0.15,
749
+ cacheRead: 0,
750
+ cacheWrite: 0,
751
+ },
752
+ contextWindow: 32768,
753
+ maxTokens: 4096,
754
+ } satisfies Model<"openai-completions">,
755
+ "google/gemini-2.0-flash-001": {
756
+ id: "google/gemini-2.0-flash-001",
757
+ name: "Google: Gemini 2.0 Flash",
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.09999999999999999,
765
+ output: 0.39999999999999997,
766
+ cacheRead: 0.024999999999999998,
767
+ cacheWrite: 0.08333333333333334,
768
+ },
769
+ contextWindow: 1048576,
770
+ maxTokens: 8192,
771
+ } satisfies Model<"openai-completions">,
772
+ "google/gemini-2.0-flash-lite-001": {
773
+ id: "google/gemini-2.0-flash-lite-001",
774
+ name: "Google: Gemini 2.0 Flash Lite",
775
+ api: "openai-completions",
776
+ provider: "openrouter",
777
+ baseUrl: "https://openrouter.ai/api/v1",
778
+ reasoning: false,
779
+ input: ["text", "image"],
780
+ cost: {
781
+ input: 0.075,
782
+ output: 0.3,
783
+ cacheRead: 0,
784
+ cacheWrite: 0,
785
+ },
786
+ contextWindow: 1048576,
787
+ maxTokens: 8192,
788
+ } satisfies Model<"openai-completions">,
789
+ "google/gemini-2.5-flash": {
790
+ id: "google/gemini-2.5-flash",
791
+ name: "Google: Gemini 2.5 Flash",
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.3,
799
+ output: 2.5,
800
+ cacheRead: 0.03,
801
+ cacheWrite: 0.08333333333333334,
802
+ },
803
+ contextWindow: 1048576,
804
+ maxTokens: 65535,
805
+ } satisfies Model<"openai-completions">,
806
+ "google/gemini-2.5-flash-lite": {
807
+ id: "google/gemini-2.5-flash-lite",
808
+ name: "Google: Gemini 2.5 Flash Lite",
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-flash-lite-preview-09-2025": {
824
+ id: "google/gemini-2.5-flash-lite-preview-09-2025",
825
+ name: "Google: Gemini 2.5 Flash Lite Preview 09-2025",
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: 0.09999999999999999,
833
+ output: 0.39999999999999997,
834
+ cacheRead: 0.01,
835
+ cacheWrite: 0.08333333333333334,
836
+ },
837
+ contextWindow: 1048576,
838
+ maxTokens: 65535,
839
+ } satisfies Model<"openai-completions">,
840
+ "google/gemini-2.5-pro": {
841
+ id: "google/gemini-2.5-pro",
842
+ name: "Google: Gemini 2.5 Pro",
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": {
858
+ id: "google/gemini-2.5-pro-preview",
859
+ name: "Google: Gemini 2.5 Pro Preview 06-05",
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: 65536,
873
+ } satisfies Model<"openai-completions">,
874
+ "google/gemini-2.5-pro-preview-05-06": {
875
+ id: "google/gemini-2.5-pro-preview-05-06",
876
+ name: "Google: Gemini 2.5 Pro Preview 05-06",
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: 1.25,
884
+ output: 10,
885
+ cacheRead: 0.125,
886
+ cacheWrite: 0.375,
887
+ },
888
+ contextWindow: 1048576,
889
+ maxTokens: 65535,
890
+ } satisfies Model<"openai-completions">,
891
+ "google/gemini-3-flash-preview": {
892
+ id: "google/gemini-3-flash-preview",
893
+ name: "Google: Gemini 3 Flash 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.5,
901
+ output: 3,
902
+ cacheRead: 0.049999999999999996,
903
+ cacheWrite: 0.08333333333333334,
904
+ },
905
+ contextWindow: 1048576,
906
+ maxTokens: 65536,
907
+ } satisfies Model<"openai-completions">,
908
+ "google/gemini-3.1-flash-lite-preview": {
909
+ id: "google/gemini-3.1-flash-lite-preview",
910
+ name: "Google: Gemini 3.1 Flash Lite 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: 0.25,
918
+ output: 1.5,
919
+ cacheRead: 0.024999999999999998,
920
+ cacheWrite: 0.08333333333333334,
921
+ },
922
+ contextWindow: 1048576,
923
+ maxTokens: 65536,
924
+ } satisfies Model<"openai-completions">,
925
+ "google/gemini-3.1-pro-preview": {
926
+ id: "google/gemini-3.1-pro-preview",
927
+ name: "Google: Gemini 3.1 Pro Preview",
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/gemini-3.1-pro-preview-customtools": {
943
+ id: "google/gemini-3.1-pro-preview-customtools",
944
+ name: "Google: Gemini 3.1 Pro Preview Custom Tools",
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: 2,
952
+ output: 12,
953
+ cacheRead: 0.19999999999999998,
954
+ cacheWrite: 0.375,
955
+ },
956
+ contextWindow: 1048576,
957
+ maxTokens: 65536,
958
+ } satisfies Model<"openai-completions">,
959
+ "google/gemma-4-26b-a4b-it": {
960
+ id: "google/gemma-4-26b-a4b-it",
961
+ name: "Google: Gemma 4 26B A4B ",
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.12,
969
+ output: 0.39999999999999997,
970
+ cacheRead: 0,
971
+ cacheWrite: 0,
972
+ },
973
+ contextWindow: 262144,
974
+ maxTokens: 262144,
975
+ } satisfies Model<"openai-completions">,
976
+ "google/gemma-4-26b-a4b-it:free": {
977
+ id: "google/gemma-4-26b-a4b-it:free",
978
+ name: "Google: Gemma 4 26B A4B (free)",
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,
986
+ output: 0,
987
+ cacheRead: 0,
988
+ cacheWrite: 0,
989
+ },
990
+ contextWindow: 262144,
991
+ maxTokens: 32768,
992
+ } satisfies Model<"openai-completions">,
993
+ "google/gemma-4-31b-it": {
994
+ id: "google/gemma-4-31b-it",
995
+ name: "Google: Gemma 4 31B",
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.14,
1003
+ output: 0.39999999999999997,
1004
+ cacheRead: 0,
1005
+ cacheWrite: 0,
1006
+ },
1007
+ contextWindow: 262144,
1008
+ maxTokens: 131072,
1009
+ } satisfies Model<"openai-completions">,
1010
+ "google/gemma-4-31b-it:free": {
1011
+ id: "google/gemma-4-31b-it:free",
1012
+ name: "Google: Gemma 4 31B (free)",
1013
+ api: "openai-completions",
1014
+ provider: "openrouter",
1015
+ baseUrl: "https://openrouter.ai/api/v1",
1016
+ reasoning: true,
1017
+ input: ["text", "image"],
1018
+ cost: {
1019
+ input: 0,
1020
+ output: 0,
1021
+ cacheRead: 0,
1022
+ cacheWrite: 0,
1023
+ },
1024
+ contextWindow: 262144,
1025
+ maxTokens: 32768,
1026
+ } satisfies Model<"openai-completions">,
1027
+ "inception/mercury": {
1028
+ id: "inception/mercury",
1029
+ name: "Inception: Mercury",
1030
+ api: "openai-completions",
1031
+ provider: "openrouter",
1032
+ baseUrl: "https://openrouter.ai/api/v1",
1033
+ reasoning: false,
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: 32000,
1043
+ } satisfies Model<"openai-completions">,
1044
+ "inception/mercury-2": {
1045
+ id: "inception/mercury-2",
1046
+ name: "Inception: Mercury 2",
1047
+ api: "openai-completions",
1048
+ provider: "openrouter",
1049
+ baseUrl: "https://openrouter.ai/api/v1",
1050
+ reasoning: true,
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: 50000,
1060
+ } satisfies Model<"openai-completions">,
1061
+ "inception/mercury-coder": {
1062
+ id: "inception/mercury-coder",
1063
+ name: "Inception: Mercury Coder",
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.25,
1071
+ output: 0.75,
1072
+ cacheRead: 0.024999999999999998,
1073
+ cacheWrite: 0,
1074
+ },
1075
+ contextWindow: 128000,
1076
+ maxTokens: 32000,
1077
+ } satisfies Model<"openai-completions">,
1078
+ "kwaipilot/kat-coder-pro-v2": {
1079
+ id: "kwaipilot/kat-coder-pro-v2",
1080
+ name: "Kwaipilot: KAT-Coder-Pro V2",
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.3,
1088
+ output: 1.2,
1089
+ cacheRead: 0.06,
1090
+ cacheWrite: 0,
1091
+ },
1092
+ contextWindow: 256000,
1093
+ maxTokens: 80000,
1094
+ } satisfies Model<"openai-completions">,
1095
+ "meituan/longcat-flash-chat": {
1096
+ id: "meituan/longcat-flash-chat",
1097
+ name: "Meituan: LongCat Flash Chat",
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.19999999999999998,
1105
+ output: 0.7999999999999999,
1106
+ cacheRead: 0.19999999999999998,
1107
+ cacheWrite: 0,
1108
+ },
1109
+ contextWindow: 131072,
1110
+ maxTokens: 131072,
1111
+ } satisfies Model<"openai-completions">,
1112
+ "meta-llama/llama-3-8b-instruct": {
1113
+ id: "meta-llama/llama-3-8b-instruct",
1114
+ name: "Meta: Llama 3 8B 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.03,
1122
+ output: 0.04,
1123
+ cacheRead: 0,
1124
+ cacheWrite: 0,
1125
+ },
1126
+ contextWindow: 8192,
1127
+ maxTokens: 16384,
1128
+ } satisfies Model<"openai-completions">,
1129
+ "meta-llama/llama-3.1-70b-instruct": {
1130
+ id: "meta-llama/llama-3.1-70b-instruct",
1131
+ name: "Meta: Llama 3.1 70B 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.39999999999999997,
1139
+ output: 0.39999999999999997,
1140
+ cacheRead: 0,
1141
+ cacheWrite: 0,
1142
+ },
1143
+ contextWindow: 131072,
1144
+ maxTokens: 4096,
1145
+ } satisfies Model<"openai-completions">,
1146
+ "meta-llama/llama-3.1-8b-instruct": {
1147
+ id: "meta-llama/llama-3.1-8b-instruct",
1148
+ name: "Meta: Llama 3.1 8B 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.02,
1156
+ output: 0.049999999999999996,
1157
+ cacheRead: 0,
1158
+ cacheWrite: 0,
1159
+ },
1160
+ contextWindow: 16384,
1161
+ maxTokens: 16384,
1162
+ } satisfies Model<"openai-completions">,
1163
+ "meta-llama/llama-3.3-70b-instruct": {
1164
+ id: "meta-llama/llama-3.3-70b-instruct",
1165
+ name: "Meta: Llama 3.3 70B Instruct",
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.09999999999999999,
1173
+ output: 0.32,
1174
+ cacheRead: 0,
1175
+ cacheWrite: 0,
1176
+ },
1177
+ contextWindow: 131072,
1178
+ maxTokens: 16384,
1179
+ } satisfies Model<"openai-completions">,
1180
+ "meta-llama/llama-3.3-70b-instruct:free": {
1181
+ id: "meta-llama/llama-3.3-70b-instruct:free",
1182
+ name: "Meta: Llama 3.3 70B Instruct (free)",
1183
+ api: "openai-completions",
1184
+ provider: "openrouter",
1185
+ baseUrl: "https://openrouter.ai/api/v1",
1186
+ reasoning: false,
1187
+ input: ["text"],
1188
+ cost: {
1189
+ input: 0,
1190
+ output: 0,
1191
+ cacheRead: 0,
1192
+ cacheWrite: 0,
1193
+ },
1194
+ contextWindow: 65536,
1195
+ maxTokens: 4096,
1196
+ } satisfies Model<"openai-completions">,
1197
+ "meta-llama/llama-4-maverick": {
1198
+ id: "meta-llama/llama-4-maverick",
1199
+ name: "Meta: Llama 4 Maverick",
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.15,
1207
+ output: 0.6,
1208
+ cacheRead: 0,
1209
+ cacheWrite: 0,
1210
+ },
1211
+ contextWindow: 1048576,
1212
+ maxTokens: 16384,
1213
+ } satisfies Model<"openai-completions">,
1214
+ "meta-llama/llama-4-scout": {
1215
+ id: "meta-llama/llama-4-scout",
1216
+ name: "Meta: Llama 4 Scout",
1217
+ api: "openai-completions",
1218
+ provider: "openrouter",
1219
+ baseUrl: "https://openrouter.ai/api/v1",
1220
+ reasoning: false,
1221
+ input: ["text", "image"],
1222
+ cost: {
1223
+ input: 0.08,
1224
+ output: 0.3,
1225
+ cacheRead: 0,
1226
+ cacheWrite: 0,
1227
+ },
1228
+ contextWindow: 327680,
1229
+ maxTokens: 16384,
1230
+ } satisfies Model<"openai-completions">,
1231
+ "minimax/minimax-m1": {
1232
+ id: "minimax/minimax-m1",
1233
+ name: "MiniMax: MiniMax M1",
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.39999999999999997,
1241
+ output: 2.2,
1242
+ cacheRead: 0,
1243
+ cacheWrite: 0,
1244
+ },
1245
+ contextWindow: 1000000,
1246
+ maxTokens: 40000,
1247
+ } satisfies Model<"openai-completions">,
1248
+ "minimax/minimax-m2": {
1249
+ id: "minimax/minimax-m2",
1250
+ name: "MiniMax: MiniMax M2",
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.255,
1258
+ output: 1,
1259
+ cacheRead: 0.03,
1260
+ cacheWrite: 0,
1261
+ },
1262
+ contextWindow: 196608,
1263
+ maxTokens: 196608,
1264
+ } satisfies Model<"openai-completions">,
1265
+ "minimax/minimax-m2.1": {
1266
+ id: "minimax/minimax-m2.1",
1267
+ name: "MiniMax: MiniMax M2.1",
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.29,
1275
+ output: 0.95,
1276
+ cacheRead: 0.03,
1277
+ cacheWrite: 0,
1278
+ },
1279
+ contextWindow: 196608,
1280
+ maxTokens: 196608,
1281
+ } satisfies Model<"openai-completions">,
1282
+ "minimax/minimax-m2.5": {
1283
+ id: "minimax/minimax-m2.5",
1284
+ name: "MiniMax: MiniMax M2.5",
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.118,
1292
+ output: 0.9900000000000001,
1293
+ cacheRead: 0.059,
1294
+ cacheWrite: 0,
1295
+ },
1296
+ contextWindow: 196608,
1297
+ maxTokens: 65536,
1298
+ } satisfies Model<"openai-completions">,
1299
+ "minimax/minimax-m2.5:free": {
1300
+ id: "minimax/minimax-m2.5:free",
1301
+ name: "MiniMax: MiniMax M2.5 (free)",
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,
1309
+ output: 0,
1310
+ cacheRead: 0,
1311
+ cacheWrite: 0,
1312
+ },
1313
+ contextWindow: 196608,
1314
+ maxTokens: 8192,
1315
+ } satisfies Model<"openai-completions">,
1316
+ "minimax/minimax-m2.7": {
1317
+ id: "minimax/minimax-m2.7",
1318
+ name: "MiniMax: MiniMax M2.7",
1319
+ api: "openai-completions",
1320
+ provider: "openrouter",
1321
+ baseUrl: "https://openrouter.ai/api/v1",
1322
+ reasoning: true,
1323
+ input: ["text"],
1324
+ cost: {
1325
+ input: 0.3,
1326
+ output: 1.2,
1327
+ cacheRead: 0.059,
1328
+ cacheWrite: 0,
1329
+ },
1330
+ contextWindow: 196608,
1331
+ maxTokens: 4096,
1332
+ } satisfies Model<"openai-completions">,
1333
+ "mistralai/codestral-2508": {
1334
+ id: "mistralai/codestral-2508",
1335
+ name: "Mistral: Codestral 2508",
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.3,
1343
+ output: 0.8999999999999999,
1344
+ cacheRead: 0.03,
1345
+ cacheWrite: 0,
1346
+ },
1347
+ contextWindow: 256000,
1348
+ maxTokens: 4096,
1349
+ } satisfies Model<"openai-completions">,
1350
+ "mistralai/devstral-2512": {
1351
+ id: "mistralai/devstral-2512",
1352
+ name: "Mistral: Devstral 2 2512",
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: 262144,
1365
+ maxTokens: 4096,
1366
+ } satisfies Model<"openai-completions">,
1367
+ "mistralai/devstral-medium": {
1368
+ id: "mistralai/devstral-medium",
1369
+ name: "Mistral: Devstral Medium",
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.39999999999999997,
1377
+ output: 2,
1378
+ cacheRead: 0.04,
1379
+ cacheWrite: 0,
1380
+ },
1381
+ contextWindow: 131072,
1382
+ maxTokens: 4096,
1383
+ } satisfies Model<"openai-completions">,
1384
+ "mistralai/devstral-small": {
1385
+ id: "mistralai/devstral-small",
1386
+ name: "Mistral: Devstral Small 1.1",
1387
+ api: "openai-completions",
1388
+ provider: "openrouter",
1389
+ baseUrl: "https://openrouter.ai/api/v1",
1390
+ reasoning: false,
1391
+ input: ["text"],
1392
+ cost: {
1393
+ input: 0.09999999999999999,
1394
+ output: 0.3,
1395
+ cacheRead: 0.01,
1396
+ cacheWrite: 0,
1397
+ },
1398
+ contextWindow: 131072,
1399
+ maxTokens: 4096,
1400
+ } satisfies Model<"openai-completions">,
1401
+ "mistralai/ministral-14b-2512": {
1402
+ id: "mistralai/ministral-14b-2512",
1403
+ name: "Mistral: Ministral 3 14B 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.19999999999999998,
1411
+ output: 0.19999999999999998,
1412
+ cacheRead: 0.02,
1413
+ cacheWrite: 0,
1414
+ },
1415
+ contextWindow: 262144,
1416
+ maxTokens: 4096,
1417
+ } satisfies Model<"openai-completions">,
1418
+ "mistralai/ministral-3b-2512": {
1419
+ id: "mistralai/ministral-3b-2512",
1420
+ name: "Mistral: Ministral 3 3B 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.09999999999999999,
1428
+ output: 0.09999999999999999,
1429
+ cacheRead: 0.01,
1430
+ cacheWrite: 0,
1431
+ },
1432
+ contextWindow: 131072,
1433
+ maxTokens: 4096,
1434
+ } satisfies Model<"openai-completions">,
1435
+ "mistralai/ministral-8b-2512": {
1436
+ id: "mistralai/ministral-8b-2512",
1437
+ name: "Mistral: Ministral 3 8B 2512",
1438
+ api: "openai-completions",
1439
+ provider: "openrouter",
1440
+ baseUrl: "https://openrouter.ai/api/v1",
1441
+ reasoning: false,
1442
+ input: ["text", "image"],
1443
+ cost: {
1444
+ input: 0.15,
1445
+ output: 0.15,
1446
+ cacheRead: 0.015,
1447
+ cacheWrite: 0,
1448
+ },
1449
+ contextWindow: 262144,
1450
+ maxTokens: 4096,
1451
+ } satisfies Model<"openai-completions">,
1452
+ "mistralai/mistral-large": {
1453
+ id: "mistralai/mistral-large",
1454
+ name: "Mistral Large",
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: 128000,
1467
+ maxTokens: 4096,
1468
+ } satisfies Model<"openai-completions">,
1469
+ "mistralai/mistral-large-2407": {
1470
+ id: "mistralai/mistral-large-2407",
1471
+ name: "Mistral Large 2407",
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-2411": {
1487
+ id: "mistralai/mistral-large-2411",
1488
+ name: "Mistral Large 2411",
1489
+ api: "openai-completions",
1490
+ provider: "openrouter",
1491
+ baseUrl: "https://openrouter.ai/api/v1",
1492
+ reasoning: false,
1493
+ input: ["text"],
1494
+ cost: {
1495
+ input: 2,
1496
+ output: 6,
1497
+ cacheRead: 0.19999999999999998,
1498
+ cacheWrite: 0,
1499
+ },
1500
+ contextWindow: 131072,
1501
+ maxTokens: 4096,
1502
+ } satisfies Model<"openai-completions">,
1503
+ "mistralai/mistral-large-2512": {
1504
+ id: "mistralai/mistral-large-2512",
1505
+ name: "Mistral: Mistral Large 3 2512",
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.5,
1513
+ output: 1.5,
1514
+ cacheRead: 0.049999999999999996,
1515
+ cacheWrite: 0,
1516
+ },
1517
+ contextWindow: 262144,
1518
+ maxTokens: 4096,
1519
+ } satisfies Model<"openai-completions">,
1520
+ "mistralai/mistral-medium-3": {
1521
+ id: "mistralai/mistral-medium-3",
1522
+ name: "Mistral: Mistral Medium 3",
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-medium-3.1": {
1538
+ id: "mistralai/mistral-medium-3.1",
1539
+ name: "Mistral: Mistral Medium 3.1",
1540
+ api: "openai-completions",
1541
+ provider: "openrouter",
1542
+ baseUrl: "https://openrouter.ai/api/v1",
1543
+ reasoning: false,
1544
+ input: ["text", "image"],
1545
+ cost: {
1546
+ input: 0.39999999999999997,
1547
+ output: 2,
1548
+ cacheRead: 0.04,
1549
+ cacheWrite: 0,
1550
+ },
1551
+ contextWindow: 131072,
1552
+ maxTokens: 4096,
1553
+ } satisfies Model<"openai-completions">,
1554
+ "mistralai/mistral-nemo": {
1555
+ id: "mistralai/mistral-nemo",
1556
+ name: "Mistral: Mistral Nemo",
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.02,
1564
+ output: 0.04,
1565
+ cacheRead: 0,
1566
+ cacheWrite: 0,
1567
+ },
1568
+ contextWindow: 131072,
1569
+ maxTokens: 16384,
1570
+ } satisfies Model<"openai-completions">,
1571
+ "mistralai/mistral-saba": {
1572
+ id: "mistralai/mistral-saba",
1573
+ name: "Mistral: Saba",
1574
+ api: "openai-completions",
1575
+ provider: "openrouter",
1576
+ baseUrl: "https://openrouter.ai/api/v1",
1577
+ reasoning: false,
1578
+ input: ["text"],
1579
+ cost: {
1580
+ input: 0.19999999999999998,
1581
+ output: 0.6,
1582
+ cacheRead: 0.02,
1583
+ cacheWrite: 0,
1584
+ },
1585
+ contextWindow: 32768,
1586
+ maxTokens: 4096,
1587
+ } satisfies Model<"openai-completions">,
1588
+ "mistralai/mistral-small-2603": {
1589
+ id: "mistralai/mistral-small-2603",
1590
+ name: "Mistral: Mistral Small 4",
1591
+ api: "openai-completions",
1592
+ provider: "openrouter",
1593
+ baseUrl: "https://openrouter.ai/api/v1",
1594
+ reasoning: true,
1595
+ input: ["text", "image"],
1596
+ cost: {
1597
+ input: 0.15,
1598
+ output: 0.6,
1599
+ cacheRead: 0.015,
1600
+ cacheWrite: 0,
1601
+ },
1602
+ contextWindow: 262144,
1603
+ maxTokens: 4096,
1604
+ } satisfies Model<"openai-completions">,
1605
+ "mistralai/mistral-small-3.2-24b-instruct": {
1606
+ id: "mistralai/mistral-small-3.2-24b-instruct",
1607
+ name: "Mistral: Mistral Small 3.2 24B",
1608
+ api: "openai-completions",
1609
+ provider: "openrouter",
1610
+ baseUrl: "https://openrouter.ai/api/v1",
1611
+ reasoning: false,
1612
+ input: ["text", "image"],
1613
+ cost: {
1614
+ input: 0.075,
1615
+ output: 0.19999999999999998,
1616
+ cacheRead: 0,
1617
+ cacheWrite: 0,
1618
+ },
1619
+ contextWindow: 128000,
1620
+ maxTokens: 4096,
1621
+ } satisfies Model<"openai-completions">,
1622
+ "mistralai/mistral-small-creative": {
1623
+ id: "mistralai/mistral-small-creative",
1624
+ name: "Mistral: Mistral Small Creative",
1625
+ api: "openai-completions",
1626
+ provider: "openrouter",
1627
+ baseUrl: "https://openrouter.ai/api/v1",
1628
+ reasoning: false,
1629
+ input: ["text"],
1630
+ cost: {
1631
+ input: 0.09999999999999999,
1632
+ output: 0.3,
1633
+ cacheRead: 0.01,
1634
+ cacheWrite: 0,
1635
+ },
1636
+ contextWindow: 32768,
1637
+ maxTokens: 4096,
1638
+ } satisfies Model<"openai-completions">,
1639
+ "mistralai/mixtral-8x22b-instruct": {
1640
+ id: "mistralai/mixtral-8x22b-instruct",
1641
+ name: "Mistral: Mixtral 8x22B 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: 2,
1649
+ output: 6,
1650
+ cacheRead: 0.19999999999999998,
1651
+ cacheWrite: 0,
1652
+ },
1653
+ contextWindow: 65536,
1654
+ maxTokens: 4096,
1655
+ } satisfies Model<"openai-completions">,
1656
+ "mistralai/mixtral-8x7b-instruct": {
1657
+ id: "mistralai/mixtral-8x7b-instruct",
1658
+ name: "Mistral: Mixtral 8x7B Instruct",
1659
+ api: "openai-completions",
1660
+ provider: "openrouter",
1661
+ baseUrl: "https://openrouter.ai/api/v1",
1662
+ reasoning: false,
1663
+ input: ["text"],
1664
+ cost: {
1665
+ input: 0.54,
1666
+ output: 0.54,
1667
+ cacheRead: 0,
1668
+ cacheWrite: 0,
1669
+ },
1670
+ contextWindow: 32768,
1671
+ maxTokens: 16384,
1672
+ } satisfies Model<"openai-completions">,
1673
+ "mistralai/pixtral-large-2411": {
1674
+ id: "mistralai/pixtral-large-2411",
1675
+ name: "Mistral: Pixtral Large 2411",
1676
+ api: "openai-completions",
1677
+ provider: "openrouter",
1678
+ baseUrl: "https://openrouter.ai/api/v1",
1679
+ reasoning: false,
1680
+ input: ["text", "image"],
1681
+ cost: {
1682
+ input: 2,
1683
+ output: 6,
1684
+ cacheRead: 0.19999999999999998,
1685
+ cacheWrite: 0,
1686
+ },
1687
+ contextWindow: 131072,
1688
+ maxTokens: 4096,
1689
+ } satisfies Model<"openai-completions">,
1690
+ "mistralai/voxtral-small-24b-2507": {
1691
+ id: "mistralai/voxtral-small-24b-2507",
1692
+ name: "Mistral: Voxtral Small 24B 2507",
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.09999999999999999,
1700
+ output: 0.3,
1701
+ cacheRead: 0.01,
1702
+ cacheWrite: 0,
1703
+ },
1704
+ contextWindow: 32000,
1705
+ maxTokens: 4096,
1706
+ } satisfies Model<"openai-completions">,
1707
+ "moonshotai/kimi-k2": {
1708
+ id: "moonshotai/kimi-k2",
1709
+ name: "MoonshotAI: Kimi K2 0711",
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.5700000000000001,
1717
+ output: 2.3,
1718
+ cacheRead: 0,
1719
+ cacheWrite: 0,
1720
+ },
1721
+ contextWindow: 131072,
1722
+ maxTokens: 131072,
1723
+ } satisfies Model<"openai-completions">,
1724
+ "moonshotai/kimi-k2-0905": {
1725
+ id: "moonshotai/kimi-k2-0905",
1726
+ name: "MoonshotAI: Kimi K2 0905",
1727
+ api: "openai-completions",
1728
+ provider: "openrouter",
1729
+ baseUrl: "https://openrouter.ai/api/v1",
1730
+ reasoning: false,
1731
+ input: ["text"],
1732
+ cost: {
1733
+ input: 0.39999999999999997,
1734
+ output: 2,
1735
+ cacheRead: 0,
1736
+ cacheWrite: 0,
1737
+ },
1738
+ contextWindow: 262144,
1739
+ maxTokens: 262144,
1740
+ } satisfies Model<"openai-completions">,
1741
+ "moonshotai/kimi-k2-thinking": {
1742
+ id: "moonshotai/kimi-k2-thinking",
1743
+ name: "MoonshotAI: Kimi K2 Thinking",
1744
+ api: "openai-completions",
1745
+ provider: "openrouter",
1746
+ baseUrl: "https://openrouter.ai/api/v1",
1747
+ reasoning: true,
1748
+ input: ["text"],
1749
+ cost: {
1750
+ input: 0.6,
1751
+ output: 2.5,
1752
+ cacheRead: 0,
1753
+ cacheWrite: 0,
1754
+ },
1755
+ contextWindow: 262144,
1756
+ maxTokens: 4096,
1757
+ } satisfies Model<"openai-completions">,
1758
+ "moonshotai/kimi-k2.5": {
1759
+ id: "moonshotai/kimi-k2.5",
1760
+ name: "MoonshotAI: Kimi K2.5",
1761
+ api: "openai-completions",
1762
+ provider: "openrouter",
1763
+ baseUrl: "https://openrouter.ai/api/v1",
1764
+ reasoning: true,
1765
+ input: ["text", "image"],
1766
+ cost: {
1767
+ input: 0.41,
1768
+ output: 2.06,
1769
+ cacheRead: 0.07,
1770
+ cacheWrite: 0,
1771
+ },
1772
+ contextWindow: 262144,
1773
+ maxTokens: 4096,
1774
+ } satisfies Model<"openai-completions">,
1775
+ "nex-agi/deepseek-v3.1-nex-n1": {
1776
+ id: "nex-agi/deepseek-v3.1-nex-n1",
1777
+ name: "Nex AGI: DeepSeek V3.1 Nex N1",
1778
+ api: "openai-completions",
1779
+ provider: "openrouter",
1780
+ baseUrl: "https://openrouter.ai/api/v1",
1781
+ reasoning: false,
1782
+ input: ["text"],
1783
+ cost: {
1784
+ input: 0.135,
1785
+ output: 0.5,
1786
+ cacheRead: 0,
1787
+ cacheWrite: 0,
1788
+ },
1789
+ contextWindow: 131072,
1790
+ maxTokens: 163840,
1791
+ } satisfies Model<"openai-completions">,
1792
+ "nvidia/llama-3.1-nemotron-70b-instruct": {
1793
+ id: "nvidia/llama-3.1-nemotron-70b-instruct",
1794
+ name: "NVIDIA: Llama 3.1 Nemotron 70B Instruct",
1795
+ api: "openai-completions",
1796
+ provider: "openrouter",
1797
+ baseUrl: "https://openrouter.ai/api/v1",
1798
+ reasoning: false,
1799
+ input: ["text"],
1800
+ cost: {
1801
+ input: 1.2,
1802
+ output: 1.2,
1803
+ cacheRead: 0,
1804
+ cacheWrite: 0,
1805
+ },
1806
+ contextWindow: 131072,
1807
+ maxTokens: 16384,
1808
+ } satisfies Model<"openai-completions">,
1809
+ "nvidia/llama-3.3-nemotron-super-49b-v1.5": {
1810
+ id: "nvidia/llama-3.3-nemotron-super-49b-v1.5",
1811
+ name: "NVIDIA: Llama 3.3 Nemotron Super 49B V1.5",
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.09999999999999999,
1819
+ output: 0.39999999999999997,
1820
+ cacheRead: 0,
1821
+ cacheWrite: 0,
1822
+ },
1823
+ contextWindow: 131072,
1824
+ maxTokens: 4096,
1825
+ } satisfies Model<"openai-completions">,
1826
+ "nvidia/nemotron-3-nano-30b-a3b": {
1827
+ id: "nvidia/nemotron-3-nano-30b-a3b",
1828
+ name: "NVIDIA: Nemotron 3 Nano 30B A3B",
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.049999999999999996,
1836
+ output: 0.19999999999999998,
1837
+ cacheRead: 0,
1838
+ cacheWrite: 0,
1839
+ },
1840
+ contextWindow: 262144,
1841
+ maxTokens: 4096,
1842
+ } satisfies Model<"openai-completions">,
1843
+ "nvidia/nemotron-3-nano-30b-a3b:free": {
1844
+ id: "nvidia/nemotron-3-nano-30b-a3b:free",
1845
+ name: "NVIDIA: Nemotron 3 Nano 30B A3B (free)",
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,
1853
+ output: 0,
1854
+ cacheRead: 0,
1855
+ cacheWrite: 0,
1856
+ },
1857
+ contextWindow: 256000,
1858
+ maxTokens: 4096,
1859
+ } satisfies Model<"openai-completions">,
1860
+ "nvidia/nemotron-3-super-120b-a12b": {
1861
+ id: "nvidia/nemotron-3-super-120b-a12b",
1862
+ name: "NVIDIA: Nemotron 3 Super",
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.09999999999999999,
1870
+ output: 0.5,
1871
+ cacheRead: 0.09999999999999999,
1872
+ cacheWrite: 0,
1873
+ },
1874
+ contextWindow: 262144,
1875
+ maxTokens: 4096,
1876
+ } satisfies Model<"openai-completions">,
1877
+ "nvidia/nemotron-3-super-120b-a12b:free": {
1878
+ id: "nvidia/nemotron-3-super-120b-a12b:free",
1879
+ name: "NVIDIA: Nemotron 3 Super (free)",
1880
+ api: "openai-completions",
1881
+ provider: "openrouter",
1882
+ baseUrl: "https://openrouter.ai/api/v1",
1883
+ reasoning: true,
1884
+ input: ["text"],
1885
+ cost: {
1886
+ input: 0,
1887
+ output: 0,
1888
+ cacheRead: 0,
1889
+ cacheWrite: 0,
1890
+ },
1891
+ contextWindow: 262144,
1892
+ maxTokens: 262144,
1893
+ } satisfies Model<"openai-completions">,
1894
+ "nvidia/nemotron-nano-12b-v2-vl:free": {
1895
+ id: "nvidia/nemotron-nano-12b-v2-vl:free",
1896
+ name: "NVIDIA: Nemotron Nano 12B 2 VL (free)",
1897
+ api: "openai-completions",
1898
+ provider: "openrouter",
1899
+ baseUrl: "https://openrouter.ai/api/v1",
1900
+ reasoning: true,
1901
+ input: ["text", "image"],
1902
+ cost: {
1903
+ input: 0,
1904
+ output: 0,
1905
+ cacheRead: 0,
1906
+ cacheWrite: 0,
1907
+ },
1908
+ contextWindow: 128000,
1909
+ maxTokens: 128000,
1910
+ } satisfies Model<"openai-completions">,
1911
+ "nvidia/nemotron-nano-9b-v2": {
1912
+ id: "nvidia/nemotron-nano-9b-v2",
1913
+ name: "NVIDIA: Nemotron Nano 9B V2",
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.04,
1921
+ output: 0.16,
1922
+ cacheRead: 0,
1923
+ cacheWrite: 0,
1924
+ },
1925
+ contextWindow: 131072,
1926
+ maxTokens: 4096,
1927
+ } satisfies Model<"openai-completions">,
1928
+ "nvidia/nemotron-nano-9b-v2:free": {
1929
+ id: "nvidia/nemotron-nano-9b-v2:free",
1930
+ name: "NVIDIA: Nemotron Nano 9B V2 (free)",
1931
+ api: "openai-completions",
1932
+ provider: "openrouter",
1933
+ baseUrl: "https://openrouter.ai/api/v1",
1934
+ reasoning: true,
1935
+ input: ["text"],
1936
+ cost: {
1937
+ input: 0,
1938
+ output: 0,
1939
+ cacheRead: 0,
1940
+ cacheWrite: 0,
1941
+ },
1942
+ contextWindow: 128000,
1943
+ maxTokens: 4096,
1944
+ } satisfies Model<"openai-completions">,
1945
+ "openai/gpt-3.5-turbo": {
1946
+ id: "openai/gpt-3.5-turbo",
1947
+ name: "OpenAI: GPT-3.5 Turbo",
1948
+ api: "openai-completions",
1949
+ provider: "openrouter",
1950
+ baseUrl: "https://openrouter.ai/api/v1",
1951
+ reasoning: false,
1952
+ input: ["text"],
1953
+ cost: {
1954
+ input: 0.5,
1955
+ output: 1.5,
1956
+ cacheRead: 0,
1957
+ cacheWrite: 0,
1958
+ },
1959
+ contextWindow: 16385,
1960
+ maxTokens: 4096,
1961
+ } satisfies Model<"openai-completions">,
1962
+ "openai/gpt-3.5-turbo-0613": {
1963
+ id: "openai/gpt-3.5-turbo-0613",
1964
+ name: "OpenAI: GPT-3.5 Turbo (older v0613)",
1965
+ api: "openai-completions",
1966
+ provider: "openrouter",
1967
+ baseUrl: "https://openrouter.ai/api/v1",
1968
+ reasoning: false,
1969
+ input: ["text"],
1970
+ cost: {
1971
+ input: 1,
1972
+ output: 2,
1973
+ cacheRead: 0,
1974
+ cacheWrite: 0,
1975
+ },
1976
+ contextWindow: 4095,
1977
+ maxTokens: 4096,
1978
+ } satisfies Model<"openai-completions">,
1979
+ "openai/gpt-3.5-turbo-16k": {
1980
+ id: "openai/gpt-3.5-turbo-16k",
1981
+ name: "OpenAI: GPT-3.5 Turbo 16k",
1982
+ api: "openai-completions",
1983
+ provider: "openrouter",
1984
+ baseUrl: "https://openrouter.ai/api/v1",
1985
+ reasoning: false,
1986
+ input: ["text"],
1987
+ cost: {
1988
+ input: 3,
1989
+ output: 4,
1990
+ cacheRead: 0,
1991
+ cacheWrite: 0,
1992
+ },
1993
+ contextWindow: 16385,
1994
+ maxTokens: 4096,
1995
+ } satisfies Model<"openai-completions">,
1996
+ "openai/gpt-4": {
1997
+ id: "openai/gpt-4",
1998
+ name: "OpenAI: GPT-4",
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-0314": {
2014
+ id: "openai/gpt-4-0314",
2015
+ name: "OpenAI: GPT-4 (older v0314)",
2016
+ api: "openai-completions",
2017
+ provider: "openrouter",
2018
+ baseUrl: "https://openrouter.ai/api/v1",
2019
+ reasoning: false,
2020
+ input: ["text"],
2021
+ cost: {
2022
+ input: 30,
2023
+ output: 60,
2024
+ cacheRead: 0,
2025
+ cacheWrite: 0,
2026
+ },
2027
+ contextWindow: 8191,
2028
+ maxTokens: 4096,
2029
+ } satisfies Model<"openai-completions">,
2030
+ "openai/gpt-4-1106-preview": {
2031
+ id: "openai/gpt-4-1106-preview",
2032
+ name: "OpenAI: GPT-4 Turbo (older v1106)",
2033
+ api: "openai-completions",
2034
+ provider: "openrouter",
2035
+ baseUrl: "https://openrouter.ai/api/v1",
2036
+ reasoning: false,
2037
+ input: ["text"],
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": {
2048
+ id: "openai/gpt-4-turbo",
2049
+ name: "OpenAI: GPT-4 Turbo",
2050
+ api: "openai-completions",
2051
+ provider: "openrouter",
2052
+ baseUrl: "https://openrouter.ai/api/v1",
2053
+ reasoning: false,
2054
+ input: ["text", "image"],
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-turbo-preview": {
2065
+ id: "openai/gpt-4-turbo-preview",
2066
+ name: "OpenAI: GPT-4 Turbo Preview",
2067
+ api: "openai-completions",
2068
+ provider: "openrouter",
2069
+ baseUrl: "https://openrouter.ai/api/v1",
2070
+ reasoning: false,
2071
+ input: ["text"],
2072
+ cost: {
2073
+ input: 10,
2074
+ output: 30,
2075
+ cacheRead: 0,
2076
+ cacheWrite: 0,
2077
+ },
2078
+ contextWindow: 128000,
2079
+ maxTokens: 4096,
2080
+ } satisfies Model<"openai-completions">,
2081
+ "openai/gpt-4.1": {
2082
+ id: "openai/gpt-4.1",
2083
+ name: "OpenAI: GPT-4.1",
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: 2,
2091
+ output: 8,
2092
+ cacheRead: 0.5,
2093
+ cacheWrite: 0,
2094
+ },
2095
+ contextWindow: 1047576,
2096
+ maxTokens: 4096,
2097
+ } satisfies Model<"openai-completions">,
2098
+ "openai/gpt-4.1-mini": {
2099
+ id: "openai/gpt-4.1-mini",
2100
+ name: "OpenAI: GPT-4.1 Mini",
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.39999999999999997,
2108
+ output: 1.5999999999999999,
2109
+ cacheRead: 0.09999999999999999,
2110
+ cacheWrite: 0,
2111
+ },
2112
+ contextWindow: 1047576,
2113
+ maxTokens: 32768,
2114
+ } satisfies Model<"openai-completions">,
2115
+ "openai/gpt-4.1-nano": {
2116
+ id: "openai/gpt-4.1-nano",
2117
+ name: "OpenAI: GPT-4.1 Nano",
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: 0.09999999999999999,
2125
+ output: 0.39999999999999997,
2126
+ cacheRead: 0.024999999999999998,
2127
+ cacheWrite: 0,
2128
+ },
2129
+ contextWindow: 1047576,
2130
+ maxTokens: 32768,
2131
+ } satisfies Model<"openai-completions">,
2132
+ "openai/gpt-4o": {
2133
+ id: "openai/gpt-4o",
2134
+ name: "OpenAI: GPT-4o",
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: 2.5,
2142
+ output: 10,
2143
+ cacheRead: 0,
2144
+ cacheWrite: 0,
2145
+ },
2146
+ contextWindow: 128000,
2147
+ maxTokens: 16384,
2148
+ } satisfies Model<"openai-completions">,
2149
+ "openai/gpt-4o-2024-05-13": {
2150
+ id: "openai/gpt-4o-2024-05-13",
2151
+ name: "OpenAI: GPT-4o (2024-05-13)",
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: 5,
2159
+ output: 15,
2160
+ cacheRead: 0,
2161
+ cacheWrite: 0,
2162
+ },
2163
+ contextWindow: 128000,
2164
+ maxTokens: 4096,
2165
+ } satisfies Model<"openai-completions">,
2166
+ "openai/gpt-4o-2024-08-06": {
2167
+ id: "openai/gpt-4o-2024-08-06",
2168
+ name: "OpenAI: GPT-4o (2024-08-06)",
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-2024-11-20": {
2184
+ id: "openai/gpt-4o-2024-11-20",
2185
+ name: "OpenAI: GPT-4o (2024-11-20)",
2186
+ api: "openai-completions",
2187
+ provider: "openrouter",
2188
+ baseUrl: "https://openrouter.ai/api/v1",
2189
+ reasoning: false,
2190
+ input: ["text", "image"],
2191
+ cost: {
2192
+ input: 2.5,
2193
+ output: 10,
2194
+ cacheRead: 1.25,
2195
+ cacheWrite: 0,
2196
+ },
2197
+ contextWindow: 128000,
2198
+ maxTokens: 16384,
2199
+ } satisfies Model<"openai-completions">,
2200
+ "openai/gpt-4o-audio-preview": {
2201
+ id: "openai/gpt-4o-audio-preview",
2202
+ name: "OpenAI: GPT-4o Audio",
2203
+ api: "openai-completions",
2204
+ provider: "openrouter",
2205
+ baseUrl: "https://openrouter.ai/api/v1",
2206
+ reasoning: false,
2207
+ input: ["text"],
2208
+ cost: {
2209
+ input: 2.5,
2210
+ output: 10,
2211
+ cacheRead: 0,
2212
+ cacheWrite: 0,
2213
+ },
2214
+ contextWindow: 128000,
2215
+ maxTokens: 16384,
2216
+ } satisfies Model<"openai-completions">,
2217
+ "openai/gpt-4o-mini": {
2218
+ id: "openai/gpt-4o-mini",
2219
+ name: "OpenAI: GPT-4o-mini",
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-mini-2024-07-18": {
2235
+ id: "openai/gpt-4o-mini-2024-07-18",
2236
+ name: "OpenAI: GPT-4o-mini (2024-07-18)",
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: 0.15,
2244
+ output: 0.6,
2245
+ cacheRead: 0.075,
2246
+ cacheWrite: 0,
2247
+ },
2248
+ contextWindow: 128000,
2249
+ maxTokens: 16384,
2250
+ } satisfies Model<"openai-completions">,
2251
+ "openai/gpt-4o:extended": {
2252
+ id: "openai/gpt-4o:extended",
2253
+ name: "OpenAI: GPT-4o (extended)",
2254
+ api: "openai-completions",
2255
+ provider: "openrouter",
2256
+ baseUrl: "https://openrouter.ai/api/v1",
2257
+ reasoning: false,
2258
+ input: ["text", "image"],
2259
+ cost: {
2260
+ input: 6,
2261
+ output: 18,
2262
+ cacheRead: 0,
2263
+ cacheWrite: 0,
2264
+ },
2265
+ contextWindow: 128000,
2266
+ maxTokens: 64000,
2267
+ } satisfies Model<"openai-completions">,
2268
+ "openai/gpt-5": {
2269
+ id: "openai/gpt-5",
2270
+ name: "OpenAI: GPT-5",
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-codex": {
2286
+ id: "openai/gpt-5-codex",
2287
+ name: "OpenAI: GPT-5 Codex",
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: 1.25,
2295
+ output: 10,
2296
+ cacheRead: 0.125,
2297
+ cacheWrite: 0,
2298
+ },
2299
+ contextWindow: 400000,
2300
+ maxTokens: 128000,
2301
+ } satisfies Model<"openai-completions">,
2302
+ "openai/gpt-5-image": {
2303
+ id: "openai/gpt-5-image",
2304
+ name: "OpenAI: GPT-5 Image",
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: 10,
2312
+ output: 10,
2313
+ cacheRead: 1.25,
2314
+ cacheWrite: 0,
2315
+ },
2316
+ contextWindow: 400000,
2317
+ maxTokens: 128000,
2318
+ } satisfies Model<"openai-completions">,
2319
+ "openai/gpt-5-image-mini": {
2320
+ id: "openai/gpt-5-image-mini",
2321
+ name: "OpenAI: GPT-5 Image 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: 2.5,
2329
+ output: 2,
2330
+ cacheRead: 0.25,
2331
+ cacheWrite: 0,
2332
+ },
2333
+ contextWindow: 400000,
2334
+ maxTokens: 128000,
2335
+ } satisfies Model<"openai-completions">,
2336
+ "openai/gpt-5-mini": {
2337
+ id: "openai/gpt-5-mini",
2338
+ name: "OpenAI: GPT-5 Mini",
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.25,
2346
+ output: 2,
2347
+ cacheRead: 0.024999999999999998,
2348
+ cacheWrite: 0,
2349
+ },
2350
+ contextWindow: 400000,
2351
+ maxTokens: 128000,
2352
+ } satisfies Model<"openai-completions">,
2353
+ "openai/gpt-5-nano": {
2354
+ id: "openai/gpt-5-nano",
2355
+ name: "OpenAI: GPT-5 Nano",
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: 0.049999999999999996,
2363
+ output: 0.39999999999999997,
2364
+ cacheRead: 0.01,
2365
+ cacheWrite: 0,
2366
+ },
2367
+ contextWindow: 400000,
2368
+ maxTokens: 4096,
2369
+ } satisfies Model<"openai-completions">,
2370
+ "openai/gpt-5-pro": {
2371
+ id: "openai/gpt-5-pro",
2372
+ name: "OpenAI: GPT-5 Pro",
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: 15,
2380
+ output: 120,
2381
+ cacheRead: 0,
2382
+ cacheWrite: 0,
2383
+ },
2384
+ contextWindow: 400000,
2385
+ maxTokens: 128000,
2386
+ } satisfies Model<"openai-completions">,
2387
+ "openai/gpt-5.1": {
2388
+ id: "openai/gpt-5.1",
2389
+ name: "OpenAI: GPT-5.1",
2390
+ api: "openai-completions",
2391
+ provider: "openrouter",
2392
+ baseUrl: "https://openrouter.ai/api/v1",
2393
+ reasoning: true,
2394
+ input: ["text", "image"],
2395
+ cost: {
2396
+ input: 1.25,
2397
+ output: 10,
2398
+ cacheRead: 0.13,
2399
+ cacheWrite: 0,
2400
+ },
2401
+ contextWindow: 400000,
2402
+ maxTokens: 128000,
2403
+ } satisfies Model<"openai-completions">,
2404
+ "openai/gpt-5.1-chat": {
2405
+ id: "openai/gpt-5.1-chat",
2406
+ name: "OpenAI: GPT-5.1 Chat",
2407
+ api: "openai-completions",
2408
+ provider: "openrouter",
2409
+ baseUrl: "https://openrouter.ai/api/v1",
2410
+ reasoning: false,
2411
+ input: ["text", "image"],
2412
+ cost: {
2413
+ input: 1.25,
2414
+ output: 10,
2415
+ cacheRead: 0.125,
2416
+ cacheWrite: 0,
2417
+ },
2418
+ contextWindow: 128000,
2419
+ maxTokens: 16384,
2420
+ } satisfies Model<"openai-completions">,
2421
+ "openai/gpt-5.1-codex": {
2422
+ id: "openai/gpt-5.1-codex",
2423
+ name: "OpenAI: GPT-5.1-Codex",
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-max": {
2439
+ id: "openai/gpt-5.1-codex-max",
2440
+ name: "OpenAI: GPT-5.1-Codex-Max",
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: 1.25,
2448
+ output: 10,
2449
+ cacheRead: 0.125,
2450
+ cacheWrite: 0,
2451
+ },
2452
+ contextWindow: 400000,
2453
+ maxTokens: 128000,
2454
+ } satisfies Model<"openai-completions">,
2455
+ "openai/gpt-5.1-codex-mini": {
2456
+ id: "openai/gpt-5.1-codex-mini",
2457
+ name: "OpenAI: GPT-5.1-Codex-Mini",
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: 0.25,
2465
+ output: 2,
2466
+ cacheRead: 0.03,
2467
+ cacheWrite: 0,
2468
+ },
2469
+ contextWindow: 400000,
2470
+ maxTokens: 128000,
2471
+ } satisfies Model<"openai-completions">,
2472
+ "openai/gpt-5.2": {
2473
+ id: "openai/gpt-5.2",
2474
+ name: "OpenAI: GPT-5.2",
2475
+ api: "openai-completions",
2476
+ provider: "openrouter",
2477
+ baseUrl: "https://openrouter.ai/api/v1",
2478
+ reasoning: true,
2479
+ input: ["text", "image"],
2480
+ cost: {
2481
+ input: 1.75,
2482
+ output: 14,
2483
+ cacheRead: 0.175,
2484
+ cacheWrite: 0,
2485
+ },
2486
+ contextWindow: 400000,
2487
+ maxTokens: 128000,
2488
+ } satisfies Model<"openai-completions">,
2489
+ "openai/gpt-5.2-chat": {
2490
+ id: "openai/gpt-5.2-chat",
2491
+ name: "OpenAI: GPT-5.2 Chat",
2492
+ api: "openai-completions",
2493
+ provider: "openrouter",
2494
+ baseUrl: "https://openrouter.ai/api/v1",
2495
+ reasoning: false,
2496
+ input: ["text", "image"],
2497
+ cost: {
2498
+ input: 1.75,
2499
+ output: 14,
2500
+ cacheRead: 0.175,
2501
+ cacheWrite: 0,
2502
+ },
2503
+ contextWindow: 128000,
2504
+ maxTokens: 32000,
2505
+ } satisfies Model<"openai-completions">,
2506
+ "openai/gpt-5.2-codex": {
2507
+ id: "openai/gpt-5.2-codex",
2508
+ name: "OpenAI: GPT-5.2-Codex",
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: 1.75,
2516
+ output: 14,
2517
+ cacheRead: 0.175,
2518
+ cacheWrite: 0,
2519
+ },
2520
+ contextWindow: 400000,
2521
+ maxTokens: 128000,
2522
+ } satisfies Model<"openai-completions">,
2523
+ "openai/gpt-5.2-pro": {
2524
+ id: "openai/gpt-5.2-pro",
2525
+ name: "OpenAI: GPT-5.2 Pro",
2526
+ api: "openai-completions",
2527
+ provider: "openrouter",
2528
+ baseUrl: "https://openrouter.ai/api/v1",
2529
+ reasoning: true,
2530
+ input: ["text", "image"],
2531
+ cost: {
2532
+ input: 21,
2533
+ output: 168,
2534
+ cacheRead: 0,
2535
+ cacheWrite: 0,
2536
+ },
2537
+ contextWindow: 400000,
2538
+ maxTokens: 128000,
2539
+ } satisfies Model<"openai-completions">,
2540
+ "openai/gpt-5.3-chat": {
2541
+ id: "openai/gpt-5.3-chat",
2542
+ name: "OpenAI: GPT-5.3 Chat",
2543
+ api: "openai-completions",
2544
+ provider: "openrouter",
2545
+ baseUrl: "https://openrouter.ai/api/v1",
2546
+ reasoning: false,
2547
+ input: ["text", "image"],
2548
+ cost: {
2549
+ input: 1.75,
2550
+ output: 14,
2551
+ cacheRead: 0.175,
2552
+ cacheWrite: 0,
2553
+ },
2554
+ contextWindow: 128000,
2555
+ maxTokens: 16384,
2556
+ } satisfies Model<"openai-completions">,
2557
+ "openai/gpt-5.3-codex": {
2558
+ id: "openai/gpt-5.3-codex",
2559
+ name: "OpenAI: GPT-5.3-Codex",
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: 1.75,
2567
+ output: 14,
2568
+ cacheRead: 0.175,
2569
+ cacheWrite: 0,
2570
+ },
2571
+ contextWindow: 400000,
2572
+ maxTokens: 128000,
2573
+ } satisfies Model<"openai-completions">,
2574
+ "openai/gpt-5.4": {
2575
+ id: "openai/gpt-5.4",
2576
+ name: "OpenAI: GPT-5.4",
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: 2.5,
2584
+ output: 15,
2585
+ cacheRead: 0.25,
2586
+ cacheWrite: 0,
2587
+ },
2588
+ contextWindow: 1050000,
2589
+ maxTokens: 128000,
2590
+ } satisfies Model<"openai-completions">,
2591
+ "openai/gpt-5.4-mini": {
2592
+ id: "openai/gpt-5.4-mini",
2593
+ name: "OpenAI: GPT-5.4 Mini",
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.75,
2601
+ output: 4.5,
2602
+ cacheRead: 0.075,
2603
+ cacheWrite: 0,
2604
+ },
2605
+ contextWindow: 400000,
2606
+ maxTokens: 128000,
2607
+ } satisfies Model<"openai-completions">,
2608
+ "openai/gpt-5.4-nano": {
2609
+ id: "openai/gpt-5.4-nano",
2610
+ name: "OpenAI: GPT-5.4 Nano",
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: 0.19999999999999998,
2618
+ output: 1.25,
2619
+ cacheRead: 0.02,
2620
+ cacheWrite: 0,
2621
+ },
2622
+ contextWindow: 400000,
2623
+ maxTokens: 128000,
2624
+ } satisfies Model<"openai-completions">,
2625
+ "openai/gpt-5.4-pro": {
2626
+ id: "openai/gpt-5.4-pro",
2627
+ name: "OpenAI: GPT-5.4 Pro",
2628
+ api: "openai-completions",
2629
+ provider: "openrouter",
2630
+ baseUrl: "https://openrouter.ai/api/v1",
2631
+ reasoning: true,
2632
+ input: ["text", "image"],
2633
+ cost: {
2634
+ input: 30,
2635
+ output: 180,
2636
+ cacheRead: 0,
2637
+ cacheWrite: 0,
2638
+ },
2639
+ contextWindow: 1050000,
2640
+ maxTokens: 128000,
2641
+ } satisfies Model<"openai-completions">,
2642
+ "openai/gpt-audio": {
2643
+ id: "openai/gpt-audio",
2644
+ name: "OpenAI: GPT Audio",
2645
+ api: "openai-completions",
2646
+ provider: "openrouter",
2647
+ baseUrl: "https://openrouter.ai/api/v1",
2648
+ reasoning: false,
2649
+ input: ["text"],
2650
+ cost: {
2651
+ input: 2.5,
2652
+ output: 10,
2653
+ cacheRead: 0,
2654
+ cacheWrite: 0,
2655
+ },
2656
+ contextWindow: 128000,
2657
+ maxTokens: 16384,
2658
+ } satisfies Model<"openai-completions">,
2659
+ "openai/gpt-audio-mini": {
2660
+ id: "openai/gpt-audio-mini",
2661
+ name: "OpenAI: GPT Audio Mini",
2662
+ api: "openai-completions",
2663
+ provider: "openrouter",
2664
+ baseUrl: "https://openrouter.ai/api/v1",
2665
+ reasoning: false,
2666
+ input: ["text"],
2667
+ cost: {
2668
+ input: 0.6,
2669
+ output: 2.4,
2670
+ cacheRead: 0,
2671
+ cacheWrite: 0,
2672
+ },
2673
+ contextWindow: 128000,
2674
+ maxTokens: 16384,
2675
+ } satisfies Model<"openai-completions">,
2676
+ "openai/gpt-oss-120b": {
2677
+ id: "openai/gpt-oss-120b",
2678
+ name: "OpenAI: gpt-oss-120b",
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.039,
2686
+ output: 0.19,
2687
+ cacheRead: 0,
2688
+ cacheWrite: 0,
2689
+ },
2690
+ contextWindow: 131072,
2691
+ maxTokens: 4096,
2692
+ } satisfies Model<"openai-completions">,
2693
+ "openai/gpt-oss-120b:free": {
2694
+ id: "openai/gpt-oss-120b:free",
2695
+ name: "OpenAI: gpt-oss-120b (free)",
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,
2703
+ output: 0,
2704
+ cacheRead: 0,
2705
+ cacheWrite: 0,
2706
+ },
2707
+ contextWindow: 131072,
2708
+ maxTokens: 131072,
2709
+ } satisfies Model<"openai-completions">,
2710
+ "openai/gpt-oss-20b": {
2711
+ id: "openai/gpt-oss-20b",
2712
+ name: "OpenAI: gpt-oss-20b",
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.03,
2720
+ output: 0.14,
2721
+ cacheRead: 0,
2722
+ cacheWrite: 0,
2723
+ },
2724
+ contextWindow: 131072,
2725
+ maxTokens: 4096,
2726
+ } satisfies Model<"openai-completions">,
2727
+ "openai/gpt-oss-20b:free": {
2728
+ id: "openai/gpt-oss-20b:free",
2729
+ name: "OpenAI: gpt-oss-20b (free)",
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,
2737
+ output: 0,
2738
+ cacheRead: 0,
2739
+ cacheWrite: 0,
2740
+ },
2741
+ contextWindow: 131072,
2742
+ maxTokens: 8192,
2743
+ } satisfies Model<"openai-completions">,
2744
+ "openai/gpt-oss-safeguard-20b": {
2745
+ id: "openai/gpt-oss-safeguard-20b",
2746
+ name: "OpenAI: gpt-oss-safeguard-20b",
2747
+ api: "openai-completions",
2748
+ provider: "openrouter",
2749
+ baseUrl: "https://openrouter.ai/api/v1",
2750
+ reasoning: true,
2751
+ input: ["text"],
2752
+ cost: {
2753
+ input: 0.075,
2754
+ output: 0.3,
2755
+ cacheRead: 0.037,
2756
+ cacheWrite: 0,
2757
+ },
2758
+ contextWindow: 131072,
2759
+ maxTokens: 65536,
2760
+ } satisfies Model<"openai-completions">,
2761
+ "openai/o1": {
2762
+ id: "openai/o1",
2763
+ name: "OpenAI: o1",
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: 15,
2771
+ output: 60,
2772
+ cacheRead: 7.5,
2773
+ cacheWrite: 0,
2774
+ },
2775
+ contextWindow: 200000,
2776
+ maxTokens: 100000,
2777
+ } satisfies Model<"openai-completions">,
2778
+ "openai/o3": {
2779
+ id: "openai/o3",
2780
+ name: "OpenAI: o3",
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: 2,
2788
+ output: 8,
2789
+ cacheRead: 0.5,
2790
+ cacheWrite: 0,
2791
+ },
2792
+ contextWindow: 200000,
2793
+ maxTokens: 100000,
2794
+ } satisfies Model<"openai-completions">,
2795
+ "openai/o3-deep-research": {
2796
+ id: "openai/o3-deep-research",
2797
+ name: "OpenAI: o3 Deep Research",
2798
+ api: "openai-completions",
2799
+ provider: "openrouter",
2800
+ baseUrl: "https://openrouter.ai/api/v1",
2801
+ reasoning: true,
2802
+ input: ["text", "image"],
2803
+ cost: {
2804
+ input: 10,
2805
+ output: 40,
2806
+ cacheRead: 2.5,
2807
+ cacheWrite: 0,
2808
+ },
2809
+ contextWindow: 200000,
2810
+ maxTokens: 100000,
2811
+ } satisfies Model<"openai-completions">,
2812
+ "openai/o3-mini": {
2813
+ id: "openai/o3-mini",
2814
+ name: "OpenAI: o3 Mini",
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-mini-high": {
2830
+ id: "openai/o3-mini-high",
2831
+ name: "OpenAI: o3 Mini High",
2832
+ api: "openai-completions",
2833
+ provider: "openrouter",
2834
+ baseUrl: "https://openrouter.ai/api/v1",
2835
+ reasoning: true,
2836
+ input: ["text"],
2837
+ cost: {
2838
+ input: 1.1,
2839
+ output: 4.4,
2840
+ cacheRead: 0.55,
2841
+ cacheWrite: 0,
2842
+ },
2843
+ contextWindow: 200000,
2844
+ maxTokens: 100000,
2845
+ } satisfies Model<"openai-completions">,
2846
+ "openai/o3-pro": {
2847
+ id: "openai/o3-pro",
2848
+ name: "OpenAI: o3 Pro",
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: 20,
2856
+ output: 80,
2857
+ cacheRead: 0,
2858
+ cacheWrite: 0,
2859
+ },
2860
+ contextWindow: 200000,
2861
+ maxTokens: 100000,
2862
+ } satisfies Model<"openai-completions">,
2863
+ "openai/o4-mini": {
2864
+ id: "openai/o4-mini",
2865
+ name: "OpenAI: o4 Mini",
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: 1.1,
2873
+ output: 4.4,
2874
+ cacheRead: 0.275,
2875
+ cacheWrite: 0,
2876
+ },
2877
+ contextWindow: 200000,
2878
+ maxTokens: 100000,
2879
+ } satisfies Model<"openai-completions">,
2880
+ "openai/o4-mini-deep-research": {
2881
+ id: "openai/o4-mini-deep-research",
2882
+ name: "OpenAI: o4 Mini Deep Research",
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: 2,
2890
+ output: 8,
2891
+ cacheRead: 0.5,
2892
+ cacheWrite: 0,
2893
+ },
2894
+ contextWindow: 200000,
2895
+ maxTokens: 100000,
2896
+ } satisfies Model<"openai-completions">,
2897
+ "openai/o4-mini-high": {
2898
+ id: "openai/o4-mini-high",
2899
+ name: "OpenAI: o4 Mini High",
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: 1.1,
2907
+ output: 4.4,
2908
+ cacheRead: 0.275,
2909
+ cacheWrite: 0,
2910
+ },
2911
+ contextWindow: 200000,
2912
+ maxTokens: 100000,
2913
+ } satisfies Model<"openai-completions">,
2914
+ "openrouter/auto": {
2915
+ id: "openrouter/auto",
2916
+ name: "Auto 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: -1000000,
2924
+ output: -1000000,
2925
+ cacheRead: 0,
2926
+ cacheWrite: 0,
2927
+ },
2928
+ contextWindow: 2000000,
2929
+ maxTokens: 4096,
2930
+ } satisfies Model<"openai-completions">,
2931
+ "openrouter/free": {
2932
+ id: "openrouter/free",
2933
+ name: "Free Models Router",
2934
+ api: "openai-completions",
2935
+ provider: "openrouter",
2936
+ baseUrl: "https://openrouter.ai/api/v1",
2937
+ reasoning: true,
2938
+ input: ["text", "image"],
2939
+ cost: {
2940
+ input: 0,
2941
+ output: 0,
2942
+ cacheRead: 0,
2943
+ cacheWrite: 0,
2944
+ },
2945
+ contextWindow: 200000,
2946
+ maxTokens: 4096,
2947
+ } satisfies Model<"openai-completions">,
2948
+ "prime-intellect/intellect-3": {
2949
+ id: "prime-intellect/intellect-3",
2950
+ name: "Prime Intellect: INTELLECT-3",
2951
+ api: "openai-completions",
2952
+ provider: "openrouter",
2953
+ baseUrl: "https://openrouter.ai/api/v1",
2954
+ reasoning: true,
2955
+ input: ["text"],
2956
+ cost: {
2957
+ input: 0.19999999999999998,
2958
+ output: 1.1,
2959
+ cacheRead: 0,
2960
+ cacheWrite: 0,
2961
+ },
2962
+ contextWindow: 131072,
2963
+ maxTokens: 131072,
2964
+ } satisfies Model<"openai-completions">,
2965
+ "qwen/qwen-2.5-72b-instruct": {
2966
+ id: "qwen/qwen-2.5-72b-instruct",
2967
+ name: "Qwen2.5 72B 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.12,
2975
+ output: 0.39,
2976
+ cacheRead: 0,
2977
+ cacheWrite: 0,
2978
+ },
2979
+ contextWindow: 32768,
2980
+ maxTokens: 16384,
2981
+ } satisfies Model<"openai-completions">,
2982
+ "qwen/qwen-2.5-7b-instruct": {
2983
+ id: "qwen/qwen-2.5-7b-instruct",
2984
+ name: "Qwen: Qwen2.5 7B Instruct",
2985
+ api: "openai-completions",
2986
+ provider: "openrouter",
2987
+ baseUrl: "https://openrouter.ai/api/v1",
2988
+ reasoning: false,
2989
+ input: ["text"],
2990
+ cost: {
2991
+ input: 0.04,
2992
+ output: 0.09999999999999999,
2993
+ cacheRead: 0,
2994
+ cacheWrite: 0,
2995
+ },
2996
+ contextWindow: 32768,
2997
+ maxTokens: 32768,
2998
+ } satisfies Model<"openai-completions">,
2999
+ "qwen/qwen-max": {
3000
+ id: "qwen/qwen-max",
3001
+ name: "Qwen: Qwen-Max ",
3002
+ api: "openai-completions",
3003
+ provider: "openrouter",
3004
+ baseUrl: "https://openrouter.ai/api/v1",
3005
+ reasoning: false,
3006
+ input: ["text"],
3007
+ cost: {
3008
+ input: 1.04,
3009
+ output: 4.16,
3010
+ cacheRead: 0.20800000000000002,
3011
+ cacheWrite: 0,
3012
+ },
3013
+ contextWindow: 32768,
3014
+ maxTokens: 8192,
3015
+ } satisfies Model<"openai-completions">,
3016
+ "qwen/qwen-plus": {
3017
+ id: "qwen/qwen-plus",
3018
+ name: "Qwen: Qwen-Plus",
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.052000000000000005,
3028
+ cacheWrite: 0,
3029
+ },
3030
+ contextWindow: 1000000,
3031
+ maxTokens: 32768,
3032
+ } satisfies Model<"openai-completions">,
3033
+ "qwen/qwen-plus-2025-07-28": {
3034
+ id: "qwen/qwen-plus-2025-07-28",
3035
+ name: "Qwen: Qwen Plus 0728",
3036
+ api: "openai-completions",
3037
+ provider: "openrouter",
3038
+ baseUrl: "https://openrouter.ai/api/v1",
3039
+ reasoning: false,
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-plus-2025-07-28:thinking": {
3051
+ id: "qwen/qwen-plus-2025-07-28:thinking",
3052
+ name: "Qwen: Qwen Plus 0728 (thinking)",
3053
+ api: "openai-completions",
3054
+ provider: "openrouter",
3055
+ baseUrl: "https://openrouter.ai/api/v1",
3056
+ reasoning: true,
3057
+ input: ["text"],
3058
+ cost: {
3059
+ input: 0.26,
3060
+ output: 0.78,
3061
+ cacheRead: 0,
3062
+ cacheWrite: 0,
3063
+ },
3064
+ contextWindow: 1000000,
3065
+ maxTokens: 32768,
3066
+ } satisfies Model<"openai-completions">,
3067
+ "qwen/qwen-turbo": {
3068
+ id: "qwen/qwen-turbo",
3069
+ name: "Qwen: Qwen-Turbo",
3070
+ api: "openai-completions",
3071
+ provider: "openrouter",
3072
+ baseUrl: "https://openrouter.ai/api/v1",
3073
+ reasoning: false,
3074
+ input: ["text"],
3075
+ cost: {
3076
+ input: 0.0325,
3077
+ output: 0.13,
3078
+ cacheRead: 0.006500000000000001,
3079
+ cacheWrite: 0,
3080
+ },
3081
+ contextWindow: 131072,
3082
+ maxTokens: 8192,
3083
+ } satisfies Model<"openai-completions">,
3084
+ "qwen/qwen-vl-max": {
3085
+ id: "qwen/qwen-vl-max",
3086
+ name: "Qwen: Qwen VL Max",
3087
+ api: "openai-completions",
3088
+ provider: "openrouter",
3089
+ baseUrl: "https://openrouter.ai/api/v1",
3090
+ reasoning: false,
3091
+ input: ["text", "image"],
3092
+ cost: {
3093
+ input: 0.52,
3094
+ output: 2.08,
3095
+ cacheRead: 0,
3096
+ cacheWrite: 0,
3097
+ },
3098
+ contextWindow: 131072,
3099
+ maxTokens: 32768,
3100
+ } satisfies Model<"openai-completions">,
3101
+ "qwen/qwen3-14b": {
3102
+ id: "qwen/qwen3-14b",
3103
+ name: "Qwen: Qwen3 14B",
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.06,
3111
+ output: 0.24,
3112
+ cacheRead: 0,
3113
+ cacheWrite: 0,
3114
+ },
3115
+ contextWindow: 40960,
3116
+ maxTokens: 40960,
3117
+ } satisfies Model<"openai-completions">,
3118
+ "qwen/qwen3-235b-a22b": {
3119
+ id: "qwen/qwen3-235b-a22b",
3120
+ name: "Qwen: Qwen3 235B A22B",
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.45499999999999996,
3128
+ output: 1.8199999999999998,
3129
+ cacheRead: 0,
3130
+ cacheWrite: 0,
3131
+ },
3132
+ contextWindow: 131072,
3133
+ maxTokens: 8192,
3134
+ } satisfies Model<"openai-completions">,
3135
+ "qwen/qwen3-235b-a22b-2507": {
3136
+ id: "qwen/qwen3-235b-a22b-2507",
3137
+ name: "Qwen: Qwen3 235B A22B Instruct 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.071,
3145
+ output: 0.09999999999999999,
3146
+ cacheRead: 0,
3147
+ cacheWrite: 0,
3148
+ },
3149
+ contextWindow: 262144,
3150
+ maxTokens: 4096,
3151
+ } satisfies Model<"openai-completions">,
3152
+ "qwen/qwen3-235b-a22b-thinking-2507": {
3153
+ id: "qwen/qwen3-235b-a22b-thinking-2507",
3154
+ name: "Qwen: Qwen3 235B A22B Thinking 2507",
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.14950000000000002,
3162
+ output: 1.495,
3163
+ cacheRead: 0,
3164
+ cacheWrite: 0,
3165
+ },
3166
+ contextWindow: 131072,
3167
+ maxTokens: 4096,
3168
+ } satisfies Model<"openai-completions">,
3169
+ "qwen/qwen3-30b-a3b": {
3170
+ id: "qwen/qwen3-30b-a3b",
3171
+ name: "Qwen: Qwen3 30B A3B",
3172
+ api: "openai-completions",
3173
+ provider: "openrouter",
3174
+ baseUrl: "https://openrouter.ai/api/v1",
3175
+ reasoning: true,
3176
+ input: ["text"],
3177
+ cost: {
3178
+ input: 0.08,
3179
+ output: 0.28,
3180
+ cacheRead: 0,
3181
+ cacheWrite: 0,
3182
+ },
3183
+ contextWindow: 40960,
3184
+ maxTokens: 40960,
3185
+ } satisfies Model<"openai-completions">,
3186
+ "qwen/qwen3-30b-a3b-instruct-2507": {
3187
+ id: "qwen/qwen3-30b-a3b-instruct-2507",
3188
+ name: "Qwen: Qwen3 30B A3B Instruct 2507",
3189
+ api: "openai-completions",
3190
+ provider: "openrouter",
3191
+ baseUrl: "https://openrouter.ai/api/v1",
3192
+ reasoning: false,
3193
+ input: ["text"],
3194
+ cost: {
3195
+ input: 0.09,
3196
+ output: 0.3,
3197
+ cacheRead: 0,
3198
+ cacheWrite: 0,
3199
+ },
3200
+ contextWindow: 262144,
3201
+ maxTokens: 262144,
3202
+ } satisfies Model<"openai-completions">,
3203
+ "qwen/qwen3-30b-a3b-thinking-2507": {
3204
+ id: "qwen/qwen3-30b-a3b-thinking-2507",
3205
+ name: "Qwen: Qwen3 30B A3B Thinking 2507",
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.39999999999999997,
3214
+ cacheRead: 0.08,
3215
+ cacheWrite: 0,
3216
+ },
3217
+ contextWindow: 131072,
3218
+ maxTokens: 131072,
3219
+ } satisfies Model<"openai-completions">,
3220
+ "qwen/qwen3-32b": {
3221
+ id: "qwen/qwen3-32b",
3222
+ name: "Qwen: Qwen3 32B",
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.08,
3230
+ output: 0.24,
3231
+ cacheRead: 0.04,
3232
+ cacheWrite: 0,
3233
+ },
3234
+ contextWindow: 40960,
3235
+ maxTokens: 40960,
3236
+ } satisfies Model<"openai-completions">,
3237
+ "qwen/qwen3-8b": {
3238
+ id: "qwen/qwen3-8b",
3239
+ name: "Qwen: Qwen3 8B",
3240
+ api: "openai-completions",
3241
+ provider: "openrouter",
3242
+ baseUrl: "https://openrouter.ai/api/v1",
3243
+ reasoning: true,
3244
+ input: ["text"],
3245
+ cost: {
3246
+ input: 0.049999999999999996,
3247
+ output: 0.39999999999999997,
3248
+ cacheRead: 0.049999999999999996,
3249
+ cacheWrite: 0,
3250
+ },
3251
+ contextWindow: 40960,
3252
+ maxTokens: 8192,
3253
+ } satisfies Model<"openai-completions">,
3254
+ "qwen/qwen3-coder": {
3255
+ id: "qwen/qwen3-coder",
3256
+ name: "Qwen: Qwen3 Coder 480B A35B",
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.22,
3264
+ output: 1,
3265
+ cacheRead: 0.022,
3266
+ cacheWrite: 0,
3267
+ },
3268
+ contextWindow: 262144,
3269
+ maxTokens: 4096,
3270
+ } satisfies Model<"openai-completions">,
3271
+ "qwen/qwen3-coder-30b-a3b-instruct": {
3272
+ id: "qwen/qwen3-coder-30b-a3b-instruct",
3273
+ name: "Qwen: Qwen3 Coder 30B A3B Instruct",
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.07,
3281
+ output: 0.27,
3282
+ cacheRead: 0,
3283
+ cacheWrite: 0,
3284
+ },
3285
+ contextWindow: 160000,
3286
+ maxTokens: 32768,
3287
+ } satisfies Model<"openai-completions">,
3288
+ "qwen/qwen3-coder-flash": {
3289
+ id: "qwen/qwen3-coder-flash",
3290
+ name: "Qwen: Qwen3 Coder Flash",
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.195,
3298
+ output: 0.975,
3299
+ cacheRead: 0.039,
3300
+ cacheWrite: 0,
3301
+ },
3302
+ contextWindow: 1000000,
3303
+ maxTokens: 65536,
3304
+ } satisfies Model<"openai-completions">,
3305
+ "qwen/qwen3-coder-next": {
3306
+ id: "qwen/qwen3-coder-next",
3307
+ name: "Qwen: Qwen3 Coder Next",
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.15,
3315
+ output: 0.7999999999999999,
3316
+ cacheRead: 0.12,
3317
+ cacheWrite: 0,
3318
+ },
3319
+ contextWindow: 262144,
3320
+ maxTokens: 262144,
3321
+ } satisfies Model<"openai-completions">,
3322
+ "qwen/qwen3-coder-plus": {
3323
+ id: "qwen/qwen3-coder-plus",
3324
+ name: "Qwen: Qwen3 Coder Plus",
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.65,
3332
+ output: 3.25,
3333
+ cacheRead: 0.13,
3334
+ cacheWrite: 0,
3335
+ },
3336
+ contextWindow: 1000000,
3337
+ maxTokens: 65536,
3338
+ } satisfies Model<"openai-completions">,
3339
+ "qwen/qwen3-coder:free": {
3340
+ id: "qwen/qwen3-coder:free",
3341
+ name: "Qwen: Qwen3 Coder 480B A35B (free)",
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,
3349
+ output: 0,
3350
+ cacheRead: 0,
3351
+ cacheWrite: 0,
3352
+ },
3353
+ contextWindow: 262000,
3354
+ maxTokens: 262000,
3355
+ } satisfies Model<"openai-completions">,
3356
+ "qwen/qwen3-max": {
3357
+ id: "qwen/qwen3-max",
3358
+ name: "Qwen: Qwen3 Max",
3359
+ api: "openai-completions",
3360
+ provider: "openrouter",
3361
+ baseUrl: "https://openrouter.ai/api/v1",
3362
+ reasoning: false,
3363
+ input: ["text"],
3364
+ cost: {
3365
+ input: 0.78,
3366
+ output: 3.9,
3367
+ cacheRead: 0.156,
3368
+ cacheWrite: 0,
3369
+ },
3370
+ contextWindow: 262144,
3371
+ maxTokens: 32768,
3372
+ } satisfies Model<"openai-completions">,
3373
+ "qwen/qwen3-max-thinking": {
3374
+ id: "qwen/qwen3-max-thinking",
3375
+ name: "Qwen: Qwen3 Max Thinking",
3376
+ api: "openai-completions",
3377
+ provider: "openrouter",
3378
+ baseUrl: "https://openrouter.ai/api/v1",
3379
+ reasoning: true,
3380
+ input: ["text"],
3381
+ cost: {
3382
+ input: 0.78,
3383
+ output: 3.9,
3384
+ cacheRead: 0,
3385
+ cacheWrite: 0,
3386
+ },
3387
+ contextWindow: 262144,
3388
+ maxTokens: 32768,
3389
+ } satisfies Model<"openai-completions">,
3390
+ "qwen/qwen3-next-80b-a3b-instruct": {
3391
+ id: "qwen/qwen3-next-80b-a3b-instruct",
3392
+ name: "Qwen: Qwen3 Next 80B A3B Instruct",
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.09,
3400
+ output: 1.1,
3401
+ cacheRead: 0,
3402
+ cacheWrite: 0,
3403
+ },
3404
+ contextWindow: 262144,
3405
+ maxTokens: 4096,
3406
+ } satisfies Model<"openai-completions">,
3407
+ "qwen/qwen3-next-80b-a3b-instruct:free": {
3408
+ id: "qwen/qwen3-next-80b-a3b-instruct:free",
3409
+ name: "Qwen: Qwen3 Next 80B A3B Instruct (free)",
3410
+ api: "openai-completions",
3411
+ provider: "openrouter",
3412
+ baseUrl: "https://openrouter.ai/api/v1",
3413
+ reasoning: false,
3414
+ input: ["text"],
3415
+ cost: {
3416
+ input: 0,
3417
+ output: 0,
3418
+ cacheRead: 0,
3419
+ cacheWrite: 0,
3420
+ },
3421
+ contextWindow: 262144,
3422
+ maxTokens: 4096,
3423
+ } satisfies Model<"openai-completions">,
3424
+ "qwen/qwen3-next-80b-a3b-thinking": {
3425
+ id: "qwen/qwen3-next-80b-a3b-thinking",
3426
+ name: "Qwen: Qwen3 Next 80B A3B Thinking",
3427
+ api: "openai-completions",
3428
+ provider: "openrouter",
3429
+ baseUrl: "https://openrouter.ai/api/v1",
3430
+ reasoning: true,
3431
+ input: ["text"],
3432
+ cost: {
3433
+ input: 0.0975,
3434
+ output: 0.78,
3435
+ cacheRead: 0,
3436
+ cacheWrite: 0,
3437
+ },
3438
+ contextWindow: 131072,
3439
+ maxTokens: 32768,
3440
+ } satisfies Model<"openai-completions">,
3441
+ "qwen/qwen3-vl-235b-a22b-instruct": {
3442
+ id: "qwen/qwen3-vl-235b-a22b-instruct",
3443
+ name: "Qwen: Qwen3 VL 235B A22B Instruct",
3444
+ api: "openai-completions",
3445
+ provider: "openrouter",
3446
+ baseUrl: "https://openrouter.ai/api/v1",
3447
+ reasoning: false,
3448
+ input: ["text", "image"],
3449
+ cost: {
3450
+ input: 0.19999999999999998,
3451
+ output: 0.88,
3452
+ cacheRead: 0.11,
3453
+ cacheWrite: 0,
3454
+ },
3455
+ contextWindow: 262144,
3456
+ maxTokens: 4096,
3457
+ } satisfies Model<"openai-completions">,
3458
+ "qwen/qwen3-vl-235b-a22b-thinking": {
3459
+ id: "qwen/qwen3-vl-235b-a22b-thinking",
3460
+ name: "Qwen: Qwen3 VL 235B A22B Thinking",
3461
+ api: "openai-completions",
3462
+ provider: "openrouter",
3463
+ baseUrl: "https://openrouter.ai/api/v1",
3464
+ reasoning: true,
3465
+ input: ["text", "image"],
3466
+ cost: {
3467
+ input: 0.26,
3468
+ output: 2.6,
3469
+ cacheRead: 0,
3470
+ cacheWrite: 0,
3471
+ },
3472
+ contextWindow: 131072,
3473
+ maxTokens: 32768,
3474
+ } satisfies Model<"openai-completions">,
3475
+ "qwen/qwen3-vl-30b-a3b-instruct": {
3476
+ id: "qwen/qwen3-vl-30b-a3b-instruct",
3477
+ name: "Qwen: Qwen3 VL 30B A3B Instruct",
3478
+ api: "openai-completions",
3479
+ provider: "openrouter",
3480
+ baseUrl: "https://openrouter.ai/api/v1",
3481
+ reasoning: false,
3482
+ input: ["text", "image"],
3483
+ cost: {
3484
+ input: 0.13,
3485
+ output: 0.52,
3486
+ cacheRead: 0,
3487
+ cacheWrite: 0,
3488
+ },
3489
+ contextWindow: 131072,
3490
+ maxTokens: 32768,
3491
+ } satisfies Model<"openai-completions">,
3492
+ "qwen/qwen3-vl-30b-a3b-thinking": {
3493
+ id: "qwen/qwen3-vl-30b-a3b-thinking",
3494
+ name: "Qwen: Qwen3 VL 30B A3B Thinking",
3495
+ api: "openai-completions",
3496
+ provider: "openrouter",
3497
+ baseUrl: "https://openrouter.ai/api/v1",
3498
+ reasoning: true,
3499
+ input: ["text", "image"],
3500
+ cost: {
3501
+ input: 0.13,
3502
+ output: 1.56,
3503
+ cacheRead: 0,
3504
+ cacheWrite: 0,
3505
+ },
3506
+ contextWindow: 131072,
3507
+ maxTokens: 32768,
3508
+ } satisfies Model<"openai-completions">,
3509
+ "qwen/qwen3-vl-32b-instruct": {
3510
+ id: "qwen/qwen3-vl-32b-instruct",
3511
+ name: "Qwen: Qwen3 VL 32B 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.10400000000000001,
3519
+ output: 0.41600000000000004,
3520
+ cacheRead: 0,
3521
+ cacheWrite: 0,
3522
+ },
3523
+ contextWindow: 131072,
3524
+ maxTokens: 32768,
3525
+ } satisfies Model<"openai-completions">,
3526
+ "qwen/qwen3-vl-8b-instruct": {
3527
+ id: "qwen/qwen3-vl-8b-instruct",
3528
+ name: "Qwen: Qwen3 VL 8B Instruct",
3529
+ api: "openai-completions",
3530
+ provider: "openrouter",
3531
+ baseUrl: "https://openrouter.ai/api/v1",
3532
+ reasoning: false,
3533
+ input: ["text", "image"],
3534
+ cost: {
3535
+ input: 0.08,
3536
+ output: 0.5,
3537
+ cacheRead: 0,
3538
+ cacheWrite: 0,
3539
+ },
3540
+ contextWindow: 131072,
3541
+ maxTokens: 32768,
3542
+ } satisfies Model<"openai-completions">,
3543
+ "qwen/qwen3-vl-8b-thinking": {
3544
+ id: "qwen/qwen3-vl-8b-thinking",
3545
+ name: "Qwen: Qwen3 VL 8B Thinking",
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.117,
3553
+ output: 1.365,
3554
+ cacheRead: 0,
3555
+ cacheWrite: 0,
3556
+ },
3557
+ contextWindow: 131072,
3558
+ maxTokens: 32768,
3559
+ } satisfies Model<"openai-completions">,
3560
+ "qwen/qwen3.5-122b-a10b": {
3561
+ id: "qwen/qwen3.5-122b-a10b",
3562
+ name: "Qwen: Qwen3.5-122B-A10B",
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.26,
3570
+ output: 2.08,
3571
+ cacheRead: 0,
3572
+ cacheWrite: 0,
3573
+ },
3574
+ contextWindow: 262144,
3575
+ maxTokens: 65536,
3576
+ } satisfies Model<"openai-completions">,
3577
+ "qwen/qwen3.5-27b": {
3578
+ id: "qwen/qwen3.5-27b",
3579
+ name: "Qwen: Qwen3.5-27B",
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.195,
3587
+ output: 1.56,
3588
+ cacheRead: 0,
3589
+ cacheWrite: 0,
3590
+ },
3591
+ contextWindow: 262144,
3592
+ maxTokens: 65536,
3593
+ } satisfies Model<"openai-completions">,
3594
+ "qwen/qwen3.5-35b-a3b": {
3595
+ id: "qwen/qwen3.5-35b-a3b",
3596
+ name: "Qwen: Qwen3.5-35B-A3B",
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.1625,
3604
+ output: 1.3,
3605
+ cacheRead: 0,
3606
+ cacheWrite: 0,
3607
+ },
3608
+ contextWindow: 262144,
3609
+ maxTokens: 65536,
3610
+ } satisfies Model<"openai-completions">,
3611
+ "qwen/qwen3.5-397b-a17b": {
3612
+ id: "qwen/qwen3.5-397b-a17b",
3613
+ name: "Qwen: Qwen3.5 397B A17B",
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.39,
3621
+ output: 2.34,
3622
+ cacheRead: 0,
3623
+ cacheWrite: 0,
3624
+ },
3625
+ contextWindow: 262144,
3626
+ maxTokens: 65536,
3627
+ } satisfies Model<"openai-completions">,
3628
+ "qwen/qwen3.5-9b": {
3629
+ id: "qwen/qwen3.5-9b",
3630
+ name: "Qwen: Qwen3.5-9B",
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.049999999999999996,
3638
+ output: 0.15,
3639
+ cacheRead: 0,
3640
+ cacheWrite: 0,
3641
+ },
3642
+ contextWindow: 256000,
3643
+ maxTokens: 32768,
3644
+ } satisfies Model<"openai-completions">,
3645
+ "qwen/qwen3.5-flash-02-23": {
3646
+ id: "qwen/qwen3.5-flash-02-23",
3647
+ name: "Qwen: Qwen3.5-Flash",
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.065,
3655
+ output: 0.26,
3656
+ cacheRead: 0,
3657
+ cacheWrite: 0,
3658
+ },
3659
+ contextWindow: 1000000,
3660
+ maxTokens: 65536,
3661
+ } satisfies Model<"openai-completions">,
3662
+ "qwen/qwen3.5-plus-02-15": {
3663
+ id: "qwen/qwen3.5-plus-02-15",
3664
+ name: "Qwen: Qwen3.5 Plus 2026-02-15",
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.26,
3672
+ output: 1.56,
3673
+ cacheRead: 0,
3674
+ cacheWrite: 0,
3675
+ },
3676
+ contextWindow: 1000000,
3677
+ maxTokens: 65536,
3678
+ } satisfies Model<"openai-completions">,
3679
+ "qwen/qwen3.6-plus": {
3680
+ id: "qwen/qwen3.6-plus",
3681
+ name: "Qwen: Qwen3.6 Plus",
3682
+ api: "openai-completions",
3683
+ provider: "openrouter",
3684
+ baseUrl: "https://openrouter.ai/api/v1",
3685
+ reasoning: true,
3686
+ input: ["text", "image"],
3687
+ cost: {
3688
+ input: 0.325,
3689
+ output: 1.95,
3690
+ cacheRead: 0,
3691
+ cacheWrite: 0,
3692
+ },
3693
+ contextWindow: 1000000,
3694
+ maxTokens: 65536,
3695
+ } satisfies Model<"openai-completions">,
3696
+ "qwen/qwq-32b": {
3697
+ id: "qwen/qwq-32b",
3698
+ name: "Qwen: QwQ 32B",
3699
+ api: "openai-completions",
3700
+ provider: "openrouter",
3701
+ baseUrl: "https://openrouter.ai/api/v1",
3702
+ reasoning: true,
3703
+ input: ["text"],
3704
+ cost: {
3705
+ input: 0.15,
3706
+ output: 0.58,
3707
+ cacheRead: 0,
3708
+ cacheWrite: 0,
3709
+ },
3710
+ contextWindow: 131072,
3711
+ maxTokens: 131072,
3712
+ } satisfies Model<"openai-completions">,
3713
+ "rekaai/reka-edge": {
3714
+ id: "rekaai/reka-edge",
3715
+ name: "Reka Edge",
3716
+ api: "openai-completions",
3717
+ provider: "openrouter",
3718
+ baseUrl: "https://openrouter.ai/api/v1",
3719
+ reasoning: false,
3720
+ input: ["text", "image"],
3721
+ cost: {
3722
+ input: 0.09999999999999999,
3723
+ output: 0.09999999999999999,
3724
+ cacheRead: 0,
3725
+ cacheWrite: 0,
3726
+ },
3727
+ contextWindow: 16384,
3728
+ maxTokens: 16384,
3729
+ } satisfies Model<"openai-completions">,
3730
+ "relace/relace-search": {
3731
+ id: "relace/relace-search",
3732
+ name: "Relace: Relace Search",
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,
3740
+ output: 3,
3741
+ cacheRead: 0,
3742
+ cacheWrite: 0,
3743
+ },
3744
+ contextWindow: 256000,
3745
+ maxTokens: 128000,
3746
+ } satisfies Model<"openai-completions">,
3747
+ "sao10k/l3-euryale-70b": {
3748
+ id: "sao10k/l3-euryale-70b",
3749
+ name: "Sao10k: Llama 3 Euryale 70B v2.1",
3750
+ api: "openai-completions",
3751
+ provider: "openrouter",
3752
+ baseUrl: "https://openrouter.ai/api/v1",
3753
+ reasoning: false,
3754
+ input: ["text"],
3755
+ cost: {
3756
+ input: 1.48,
3757
+ output: 1.48,
3758
+ cacheRead: 0,
3759
+ cacheWrite: 0,
3760
+ },
3761
+ contextWindow: 8192,
3762
+ maxTokens: 8192,
3763
+ } satisfies Model<"openai-completions">,
3764
+ "sao10k/l3.1-euryale-70b": {
3765
+ id: "sao10k/l3.1-euryale-70b",
3766
+ name: "Sao10K: Llama 3.1 Euryale 70B v2.2",
3767
+ api: "openai-completions",
3768
+ provider: "openrouter",
3769
+ baseUrl: "https://openrouter.ai/api/v1",
3770
+ reasoning: false,
3771
+ input: ["text"],
3772
+ cost: {
3773
+ input: 0.85,
3774
+ output: 0.85,
3775
+ cacheRead: 0,
3776
+ cacheWrite: 0,
3777
+ },
3778
+ contextWindow: 131072,
3779
+ maxTokens: 16384,
3780
+ } satisfies Model<"openai-completions">,
3781
+ "stepfun/step-3.5-flash": {
3782
+ id: "stepfun/step-3.5-flash",
3783
+ name: "StepFun: Step 3.5 Flash",
3784
+ api: "openai-completions",
3785
+ provider: "openrouter",
3786
+ baseUrl: "https://openrouter.ai/api/v1",
3787
+ reasoning: true,
3788
+ input: ["text"],
3789
+ cost: {
3790
+ input: 0.09999999999999999,
3791
+ output: 0.3,
3792
+ cacheRead: 0,
3793
+ cacheWrite: 0,
3794
+ },
3795
+ contextWindow: 262144,
3796
+ maxTokens: 65536,
3797
+ } satisfies Model<"openai-completions">,
3798
+ "thedrummer/rocinante-12b": {
3799
+ id: "thedrummer/rocinante-12b",
3800
+ name: "TheDrummer: Rocinante 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.16999999999999998,
3808
+ output: 0.43,
3809
+ cacheRead: 0,
3810
+ cacheWrite: 0,
3811
+ },
3812
+ contextWindow: 32768,
3813
+ maxTokens: 32768,
3814
+ } satisfies Model<"openai-completions">,
3815
+ "thedrummer/unslopnemo-12b": {
3816
+ id: "thedrummer/unslopnemo-12b",
3817
+ name: "TheDrummer: UnslopNemo 12B",
3818
+ api: "openai-completions",
3819
+ provider: "openrouter",
3820
+ baseUrl: "https://openrouter.ai/api/v1",
3821
+ reasoning: false,
3822
+ input: ["text"],
3823
+ cost: {
3824
+ input: 0.39999999999999997,
3825
+ output: 0.39999999999999997,
3826
+ cacheRead: 0,
3827
+ cacheWrite: 0,
3828
+ },
3829
+ contextWindow: 32768,
3830
+ maxTokens: 32768,
3831
+ } satisfies Model<"openai-completions">,
3832
+ "tngtech/deepseek-r1t2-chimera": {
3833
+ id: "tngtech/deepseek-r1t2-chimera",
3834
+ name: "TNG: DeepSeek R1T2 Chimera",
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.3,
3842
+ output: 1.1,
3843
+ cacheRead: 0.15,
3844
+ cacheWrite: 0,
3845
+ },
3846
+ contextWindow: 163840,
3847
+ maxTokens: 163840,
3848
+ } satisfies Model<"openai-completions">,
3849
+ "upstage/solar-pro-3": {
3850
+ id: "upstage/solar-pro-3",
3851
+ name: "Upstage: Solar Pro 3",
3852
+ api: "openai-completions",
3853
+ provider: "openrouter",
3854
+ baseUrl: "https://openrouter.ai/api/v1",
3855
+ reasoning: true,
3856
+ input: ["text"],
3857
+ cost: {
3858
+ input: 0.15,
3859
+ output: 0.6,
3860
+ cacheRead: 0.015,
3861
+ cacheWrite: 0,
3862
+ },
3863
+ contextWindow: 128000,
3864
+ maxTokens: 4096,
3865
+ } satisfies Model<"openai-completions">,
3866
+ "x-ai/grok-3": {
3867
+ id: "x-ai/grok-3",
3868
+ name: "xAI: Grok 3",
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-beta": {
3884
+ id: "x-ai/grok-3-beta",
3885
+ name: "xAI: Grok 3 Beta",
3886
+ api: "openai-completions",
3887
+ provider: "openrouter",
3888
+ baseUrl: "https://openrouter.ai/api/v1",
3889
+ reasoning: false,
3890
+ input: ["text"],
3891
+ cost: {
3892
+ input: 3,
3893
+ output: 15,
3894
+ cacheRead: 0.75,
3895
+ cacheWrite: 0,
3896
+ },
3897
+ contextWindow: 131072,
3898
+ maxTokens: 4096,
3899
+ } satisfies Model<"openai-completions">,
3900
+ "x-ai/grok-3-mini": {
3901
+ id: "x-ai/grok-3-mini",
3902
+ name: "xAI: Grok 3 Mini",
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-3-mini-beta": {
3918
+ id: "x-ai/grok-3-mini-beta",
3919
+ name: "xAI: Grok 3 Mini Beta",
3920
+ api: "openai-completions",
3921
+ provider: "openrouter",
3922
+ baseUrl: "https://openrouter.ai/api/v1",
3923
+ reasoning: true,
3924
+ input: ["text"],
3925
+ cost: {
3926
+ input: 0.3,
3927
+ output: 0.5,
3928
+ cacheRead: 0.075,
3929
+ cacheWrite: 0,
3930
+ },
3931
+ contextWindow: 131072,
3932
+ maxTokens: 4096,
3933
+ } satisfies Model<"openai-completions">,
3934
+ "x-ai/grok-4": {
3935
+ id: "x-ai/grok-4",
3936
+ name: "xAI: Grok 4",
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: 3,
3944
+ output: 15,
3945
+ cacheRead: 0.75,
3946
+ cacheWrite: 0,
3947
+ },
3948
+ contextWindow: 256000,
3949
+ maxTokens: 4096,
3950
+ } satisfies Model<"openai-completions">,
3951
+ "x-ai/grok-4-fast": {
3952
+ id: "x-ai/grok-4-fast",
3953
+ name: "xAI: Grok 4 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.1-fast": {
3969
+ id: "x-ai/grok-4.1-fast",
3970
+ name: "xAI: Grok 4.1 Fast",
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: 0.19999999999999998,
3978
+ output: 0.5,
3979
+ cacheRead: 0.049999999999999996,
3980
+ cacheWrite: 0,
3981
+ },
3982
+ contextWindow: 2000000,
3983
+ maxTokens: 30000,
3984
+ } satisfies Model<"openai-completions">,
3985
+ "x-ai/grok-4.20": {
3986
+ id: "x-ai/grok-4.20",
3987
+ name: "xAI: Grok 4.20",
3988
+ api: "openai-completions",
3989
+ provider: "openrouter",
3990
+ baseUrl: "https://openrouter.ai/api/v1",
3991
+ reasoning: true,
3992
+ input: ["text", "image"],
3993
+ cost: {
3994
+ input: 2,
3995
+ output: 6,
3996
+ cacheRead: 0.19999999999999998,
3997
+ cacheWrite: 0,
3998
+ },
3999
+ contextWindow: 2000000,
4000
+ maxTokens: 4096,
4001
+ } satisfies Model<"openai-completions">,
4002
+ "x-ai/grok-code-fast-1": {
4003
+ id: "x-ai/grok-code-fast-1",
4004
+ name: "xAI: Grok Code Fast 1",
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.19999999999999998,
4012
+ output: 1.5,
4013
+ cacheRead: 0.02,
4014
+ cacheWrite: 0,
4015
+ },
4016
+ contextWindow: 256000,
4017
+ maxTokens: 10000,
4018
+ } satisfies Model<"openai-completions">,
4019
+ "xiaomi/mimo-v2-flash": {
4020
+ id: "xiaomi/mimo-v2-flash",
4021
+ name: "Xiaomi: MiMo-V2-Flash",
4022
+ api: "openai-completions",
4023
+ provider: "openrouter",
4024
+ baseUrl: "https://openrouter.ai/api/v1",
4025
+ reasoning: true,
4026
+ input: ["text"],
4027
+ cost: {
4028
+ input: 0.09,
4029
+ output: 0.29,
4030
+ cacheRead: 0.045,
4031
+ cacheWrite: 0,
4032
+ },
4033
+ contextWindow: 262144,
4034
+ maxTokens: 65536,
4035
+ } satisfies Model<"openai-completions">,
4036
+ "xiaomi/mimo-v2-omni": {
4037
+ id: "xiaomi/mimo-v2-omni",
4038
+ name: "Xiaomi: MiMo-V2-Omni",
4039
+ api: "openai-completions",
4040
+ provider: "openrouter",
4041
+ baseUrl: "https://openrouter.ai/api/v1",
4042
+ reasoning: true,
4043
+ input: ["text", "image"],
4044
+ cost: {
4045
+ input: 0.39999999999999997,
4046
+ output: 2,
4047
+ cacheRead: 0.08,
4048
+ cacheWrite: 0,
4049
+ },
4050
+ contextWindow: 262144,
4051
+ maxTokens: 65536,
4052
+ } satisfies Model<"openai-completions">,
4053
+ "xiaomi/mimo-v2-pro": {
4054
+ id: "xiaomi/mimo-v2-pro",
4055
+ name: "Xiaomi: MiMo-V2-Pro",
4056
+ api: "openai-completions",
4057
+ provider: "openrouter",
4058
+ baseUrl: "https://openrouter.ai/api/v1",
4059
+ reasoning: true,
4060
+ input: ["text"],
4061
+ cost: {
4062
+ input: 1,
4063
+ output: 3,
4064
+ cacheRead: 0.19999999999999998,
4065
+ cacheWrite: 0,
4066
+ },
4067
+ contextWindow: 1048576,
4068
+ maxTokens: 131072,
4069
+ } satisfies Model<"openai-completions">,
4070
+ "z-ai/glm-4-32b": {
4071
+ id: "z-ai/glm-4-32b",
4072
+ name: "Z.ai: GLM 4 32B ",
4073
+ api: "openai-completions",
4074
+ provider: "openrouter",
4075
+ baseUrl: "https://openrouter.ai/api/v1",
4076
+ reasoning: false,
4077
+ input: ["text"],
4078
+ cost: {
4079
+ input: 0.09999999999999999,
4080
+ output: 0.09999999999999999,
4081
+ cacheRead: 0,
4082
+ cacheWrite: 0,
4083
+ },
4084
+ contextWindow: 128000,
4085
+ maxTokens: 4096,
4086
+ } satisfies Model<"openai-completions">,
4087
+ "z-ai/glm-4.5": {
4088
+ id: "z-ai/glm-4.5",
4089
+ name: "Z.ai: GLM 4.5",
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.6,
4097
+ output: 2.2,
4098
+ cacheRead: 0.11,
4099
+ cacheWrite: 0,
4100
+ },
4101
+ contextWindow: 131072,
4102
+ maxTokens: 98304,
4103
+ } satisfies Model<"openai-completions">,
4104
+ "z-ai/glm-4.5-air": {
4105
+ id: "z-ai/glm-4.5-air",
4106
+ name: "Z.ai: GLM 4.5 Air",
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.13,
4114
+ output: 0.85,
4115
+ cacheRead: 0.024999999999999998,
4116
+ cacheWrite: 0,
4117
+ },
4118
+ contextWindow: 131072,
4119
+ maxTokens: 98304,
4120
+ } satisfies Model<"openai-completions">,
4121
+ "z-ai/glm-4.5-air:free": {
4122
+ id: "z-ai/glm-4.5-air:free",
4123
+ name: "Z.ai: GLM 4.5 Air (free)",
4124
+ api: "openai-completions",
4125
+ provider: "openrouter",
4126
+ baseUrl: "https://openrouter.ai/api/v1",
4127
+ reasoning: true,
4128
+ input: ["text"],
4129
+ cost: {
4130
+ input: 0,
4131
+ output: 0,
4132
+ cacheRead: 0,
4133
+ cacheWrite: 0,
4134
+ },
4135
+ contextWindow: 131072,
4136
+ maxTokens: 96000,
4137
+ } satisfies Model<"openai-completions">,
4138
+ "z-ai/glm-4.5v": {
4139
+ id: "z-ai/glm-4.5v",
4140
+ name: "Z.ai: GLM 4.5V",
4141
+ api: "openai-completions",
4142
+ provider: "openrouter",
4143
+ baseUrl: "https://openrouter.ai/api/v1",
4144
+ reasoning: true,
4145
+ input: ["text", "image"],
4146
+ cost: {
4147
+ input: 0.6,
4148
+ output: 1.7999999999999998,
4149
+ cacheRead: 0.11,
4150
+ cacheWrite: 0,
4151
+ },
4152
+ contextWindow: 65536,
4153
+ maxTokens: 16384,
4154
+ } satisfies Model<"openai-completions">,
4155
+ "z-ai/glm-4.6": {
4156
+ id: "z-ai/glm-4.6",
4157
+ name: "Z.ai: GLM 4.6",
4158
+ api: "openai-completions",
4159
+ provider: "openrouter",
4160
+ baseUrl: "https://openrouter.ai/api/v1",
4161
+ reasoning: true,
4162
+ input: ["text"],
4163
+ cost: {
4164
+ input: 0.39,
4165
+ output: 1.9,
4166
+ cacheRead: 0,
4167
+ cacheWrite: 0,
4168
+ },
4169
+ contextWindow: 204800,
4170
+ maxTokens: 204800,
4171
+ } satisfies Model<"openai-completions">,
4172
+ "z-ai/glm-4.6v": {
4173
+ id: "z-ai/glm-4.6v",
4174
+ name: "Z.ai: GLM 4.6V",
4175
+ api: "openai-completions",
4176
+ provider: "openrouter",
4177
+ baseUrl: "https://openrouter.ai/api/v1",
4178
+ reasoning: true,
4179
+ input: ["text", "image"],
4180
+ cost: {
4181
+ input: 0.3,
4182
+ output: 0.8999999999999999,
4183
+ cacheRead: 0,
4184
+ cacheWrite: 0,
4185
+ },
4186
+ contextWindow: 131072,
4187
+ maxTokens: 131072,
4188
+ } satisfies Model<"openai-completions">,
4189
+ "z-ai/glm-4.7": {
4190
+ id: "z-ai/glm-4.7",
4191
+ name: "Z.ai: GLM 4.7",
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.39,
4199
+ output: 1.75,
4200
+ cacheRead: 0.195,
4201
+ cacheWrite: 0,
4202
+ },
4203
+ contextWindow: 202752,
4204
+ maxTokens: 65535,
4205
+ } satisfies Model<"openai-completions">,
4206
+ "z-ai/glm-4.7-flash": {
4207
+ id: "z-ai/glm-4.7-flash",
4208
+ name: "Z.ai: GLM 4.7 Flash",
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.06,
4216
+ output: 0.39999999999999997,
4217
+ cacheRead: 0.0100000002,
4218
+ cacheWrite: 0,
4219
+ },
4220
+ contextWindow: 202752,
4221
+ maxTokens: 4096,
4222
+ } satisfies Model<"openai-completions">,
4223
+ "z-ai/glm-5": {
4224
+ id: "z-ai/glm-5",
4225
+ name: "Z.ai: GLM 5",
4226
+ api: "openai-completions",
4227
+ provider: "openrouter",
4228
+ baseUrl: "https://openrouter.ai/api/v1",
4229
+ reasoning: true,
4230
+ input: ["text"],
4231
+ cost: {
4232
+ input: 0.6,
4233
+ output: 1.9,
4234
+ cacheRead: 0.119,
4235
+ cacheWrite: 0,
4236
+ },
4237
+ contextWindow: 80000,
4238
+ maxTokens: 131072,
4239
+ } satisfies Model<"openai-completions">,
4240
+ "z-ai/glm-5-turbo": {
4241
+ id: "z-ai/glm-5-turbo",
4242
+ name: "Z.ai: GLM 5 Turbo",
4243
+ api: "openai-completions",
4244
+ provider: "openrouter",
4245
+ baseUrl: "https://openrouter.ai/api/v1",
4246
+ reasoning: true,
4247
+ input: ["text"],
4248
+ cost: {
4249
+ input: 1.2,
4250
+ output: 4,
4251
+ cacheRead: 0.24,
4252
+ cacheWrite: 0,
4253
+ },
4254
+ contextWindow: 202752,
4255
+ maxTokens: 131072,
4256
+ } satisfies Model<"openai-completions">,
4257
+ "z-ai/glm-5.1": {
4258
+ id: "z-ai/glm-5.1",
4259
+ name: "Z.ai: GLM 5.1",
4260
+ api: "openai-completions",
4261
+ provider: "openrouter",
4262
+ baseUrl: "https://openrouter.ai/api/v1",
4263
+ reasoning: true,
4264
+ input: ["text"],
4265
+ cost: {
4266
+ input: 0.95,
4267
+ output: 3.15,
4268
+ cacheRead: 0.475,
4269
+ cacheWrite: 0,
4270
+ },
4271
+ contextWindow: 202752,
4272
+ maxTokens: 65535,
4273
+ } satisfies Model<"openai-completions">,
4274
+ "z-ai/glm-5v-turbo": {
4275
+ id: "z-ai/glm-5v-turbo",
4276
+ name: "Z.ai: GLM 5V Turbo",
4277
+ api: "openai-completions",
4278
+ provider: "openrouter",
4279
+ baseUrl: "https://openrouter.ai/api/v1",
4280
+ reasoning: true,
4281
+ input: ["text", "image"],
4282
+ cost: {
4283
+ input: 1.2,
4284
+ output: 4,
4285
+ cacheRead: 0.24,
4286
+ cacheWrite: 0,
4287
+ },
4288
+ contextWindow: 202752,
4289
+ maxTokens: 131072,
4290
+ } satisfies Model<"openai-completions">,
4291
+ } as const satisfies Record<string, Model<any>>;