@caupulican/pi-adaptative 0.75.5

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 (740) hide show
  1. package/CHANGELOG.md +4341 -0
  2. package/README.md +655 -0
  3. package/dist/bun/cli.d.ts +3 -0
  4. package/dist/bun/cli.d.ts.map +1 -0
  5. package/dist/bun/cli.js +9 -0
  6. package/dist/bun/cli.js.map +1 -0
  7. package/dist/bun/register-bedrock.d.ts +2 -0
  8. package/dist/bun/register-bedrock.d.ts.map +1 -0
  9. package/dist/bun/register-bedrock.js +4 -0
  10. package/dist/bun/register-bedrock.js.map +1 -0
  11. package/dist/bun/restore-sandbox-env.d.ts +13 -0
  12. package/dist/bun/restore-sandbox-env.d.ts.map +1 -0
  13. package/dist/bun/restore-sandbox-env.js +32 -0
  14. package/dist/bun/restore-sandbox-env.js.map +1 -0
  15. package/dist/cli/args.d.ts +53 -0
  16. package/dist/cli/args.d.ts.map +1 -0
  17. package/dist/cli/args.js +341 -0
  18. package/dist/cli/args.js.map +1 -0
  19. package/dist/cli/config-selector.d.ts +14 -0
  20. package/dist/cli/config-selector.d.ts.map +1 -0
  21. package/dist/cli/config-selector.js +31 -0
  22. package/dist/cli/config-selector.js.map +1 -0
  23. package/dist/cli/file-processor.d.ts +15 -0
  24. package/dist/cli/file-processor.d.ts.map +1 -0
  25. package/dist/cli/file-processor.js +82 -0
  26. package/dist/cli/file-processor.js.map +1 -0
  27. package/dist/cli/initial-message.d.ts +18 -0
  28. package/dist/cli/initial-message.d.ts.map +1 -0
  29. package/dist/cli/initial-message.js +22 -0
  30. package/dist/cli/initial-message.js.map +1 -0
  31. package/dist/cli/list-models.d.ts +9 -0
  32. package/dist/cli/list-models.d.ts.map +1 -0
  33. package/dist/cli/list-models.js +98 -0
  34. package/dist/cli/list-models.js.map +1 -0
  35. package/dist/cli/session-picker.d.ts +9 -0
  36. package/dist/cli/session-picker.d.ts.map +1 -0
  37. package/dist/cli/session-picker.js +35 -0
  38. package/dist/cli/session-picker.js.map +1 -0
  39. package/dist/cli.d.ts +3 -0
  40. package/dist/cli.d.ts.map +1 -0
  41. package/dist/cli.js +18 -0
  42. package/dist/cli.js.map +1 -0
  43. package/dist/config.d.ts +92 -0
  44. package/dist/config.d.ts.map +1 -0
  45. package/dist/config.js +415 -0
  46. package/dist/config.js.map +1 -0
  47. package/dist/core/agent-session-runtime.d.ts +117 -0
  48. package/dist/core/agent-session-runtime.d.ts.map +1 -0
  49. package/dist/core/agent-session-runtime.js +300 -0
  50. package/dist/core/agent-session-runtime.js.map +1 -0
  51. package/dist/core/agent-session-services.d.ts +86 -0
  52. package/dist/core/agent-session-services.d.ts.map +1 -0
  53. package/dist/core/agent-session-services.js +118 -0
  54. package/dist/core/agent-session-services.js.map +1 -0
  55. package/dist/core/agent-session.d.ts +616 -0
  56. package/dist/core/agent-session.d.ts.map +1 -0
  57. package/dist/core/agent-session.js +2549 -0
  58. package/dist/core/agent-session.js.map +1 -0
  59. package/dist/core/auth-guidance.d.ts +5 -0
  60. package/dist/core/auth-guidance.d.ts.map +1 -0
  61. package/dist/core/auth-guidance.js +21 -0
  62. package/dist/core/auth-guidance.js.map +1 -0
  63. package/dist/core/auth-storage.d.ts +141 -0
  64. package/dist/core/auth-storage.d.ts.map +1 -0
  65. package/dist/core/auth-storage.js +442 -0
  66. package/dist/core/auth-storage.js.map +1 -0
  67. package/dist/core/bash-executor.d.ts +32 -0
  68. package/dist/core/bash-executor.d.ts.map +1 -0
  69. package/dist/core/bash-executor.js +111 -0
  70. package/dist/core/bash-executor.js.map +1 -0
  71. package/dist/core/compaction/branch-summarization.d.ts +88 -0
  72. package/dist/core/compaction/branch-summarization.d.ts.map +1 -0
  73. package/dist/core/compaction/branch-summarization.js +243 -0
  74. package/dist/core/compaction/branch-summarization.js.map +1 -0
  75. package/dist/core/compaction/compaction.d.ts +121 -0
  76. package/dist/core/compaction/compaction.d.ts.map +1 -0
  77. package/dist/core/compaction/compaction.js +625 -0
  78. package/dist/core/compaction/compaction.js.map +1 -0
  79. package/dist/core/compaction/index.d.ts +7 -0
  80. package/dist/core/compaction/index.d.ts.map +1 -0
  81. package/dist/core/compaction/index.js +7 -0
  82. package/dist/core/compaction/index.js.map +1 -0
  83. package/dist/core/compaction/utils.d.ts +38 -0
  84. package/dist/core/compaction/utils.d.ts.map +1 -0
  85. package/dist/core/compaction/utils.js +153 -0
  86. package/dist/core/compaction/utils.js.map +1 -0
  87. package/dist/core/defaults.d.ts +3 -0
  88. package/dist/core/defaults.d.ts.map +1 -0
  89. package/dist/core/defaults.js +2 -0
  90. package/dist/core/defaults.js.map +1 -0
  91. package/dist/core/diagnostics.d.ts +15 -0
  92. package/dist/core/diagnostics.d.ts.map +1 -0
  93. package/dist/core/diagnostics.js +2 -0
  94. package/dist/core/diagnostics.js.map +1 -0
  95. package/dist/core/event-bus.d.ts +9 -0
  96. package/dist/core/event-bus.d.ts.map +1 -0
  97. package/dist/core/event-bus.js +25 -0
  98. package/dist/core/event-bus.js.map +1 -0
  99. package/dist/core/exec.d.ts +29 -0
  100. package/dist/core/exec.d.ts.map +1 -0
  101. package/dist/core/exec.js +75 -0
  102. package/dist/core/exec.js.map +1 -0
  103. package/dist/core/export-html/ansi-to-html.d.ts +22 -0
  104. package/dist/core/export-html/ansi-to-html.d.ts.map +1 -0
  105. package/dist/core/export-html/ansi-to-html.js +249 -0
  106. package/dist/core/export-html/ansi-to-html.js.map +1 -0
  107. package/dist/core/export-html/index.d.ts +37 -0
  108. package/dist/core/export-html/index.d.ts.map +1 -0
  109. package/dist/core/export-html/index.js +226 -0
  110. package/dist/core/export-html/index.js.map +1 -0
  111. package/dist/core/export-html/template.css +1066 -0
  112. package/dist/core/export-html/template.html +55 -0
  113. package/dist/core/export-html/template.js +1851 -0
  114. package/dist/core/export-html/tool-renderer.d.ts +34 -0
  115. package/dist/core/export-html/tool-renderer.d.ts.map +1 -0
  116. package/dist/core/export-html/tool-renderer.js +108 -0
  117. package/dist/core/export-html/tool-renderer.js.map +1 -0
  118. package/dist/core/export-html/vendor/highlight.min.js +1213 -0
  119. package/dist/core/export-html/vendor/marked.min.js +6 -0
  120. package/dist/core/extensions/index.d.ts +12 -0
  121. package/dist/core/extensions/index.d.ts.map +1 -0
  122. package/dist/core/extensions/index.js +9 -0
  123. package/dist/core/extensions/index.js.map +1 -0
  124. package/dist/core/extensions/loader.d.ts +24 -0
  125. package/dist/core/extensions/loader.d.ts.map +1 -0
  126. package/dist/core/extensions/loader.js +481 -0
  127. package/dist/core/extensions/loader.js.map +1 -0
  128. package/dist/core/extensions/runner.d.ts +159 -0
  129. package/dist/core/extensions/runner.d.ts.map +1 -0
  130. package/dist/core/extensions/runner.js +828 -0
  131. package/dist/core/extensions/runner.js.map +1 -0
  132. package/dist/core/extensions/types.d.ts +1179 -0
  133. package/dist/core/extensions/types.d.ts.map +1 -0
  134. package/dist/core/extensions/types.js +45 -0
  135. package/dist/core/extensions/types.js.map +1 -0
  136. package/dist/core/extensions/wrapper.d.ts +20 -0
  137. package/dist/core/extensions/wrapper.d.ts.map +1 -0
  138. package/dist/core/extensions/wrapper.js +22 -0
  139. package/dist/core/extensions/wrapper.js.map +1 -0
  140. package/dist/core/footer-data-provider.d.ts +52 -0
  141. package/dist/core/footer-data-provider.d.ts.map +1 -0
  142. package/dist/core/footer-data-provider.js +310 -0
  143. package/dist/core/footer-data-provider.js.map +1 -0
  144. package/dist/core/http-dispatcher.d.ts +21 -0
  145. package/dist/core/http-dispatcher.d.ts.map +1 -0
  146. package/dist/core/http-dispatcher.js +48 -0
  147. package/dist/core/http-dispatcher.js.map +1 -0
  148. package/dist/core/index.d.ts +12 -0
  149. package/dist/core/index.d.ts.map +1 -0
  150. package/dist/core/index.js +12 -0
  151. package/dist/core/index.js.map +1 -0
  152. package/dist/core/keybindings.d.ts +353 -0
  153. package/dist/core/keybindings.d.ts.map +1 -0
  154. package/dist/core/keybindings.js +295 -0
  155. package/dist/core/keybindings.js.map +1 -0
  156. package/dist/core/messages.d.ts +77 -0
  157. package/dist/core/messages.d.ts.map +1 -0
  158. package/dist/core/messages.js +123 -0
  159. package/dist/core/messages.js.map +1 -0
  160. package/dist/core/model-registry.d.ts +150 -0
  161. package/dist/core/model-registry.d.ts.map +1 -0
  162. package/dist/core/model-registry.js +732 -0
  163. package/dist/core/model-registry.js.map +1 -0
  164. package/dist/core/model-resolver.d.ts +110 -0
  165. package/dist/core/model-resolver.d.ts.map +1 -0
  166. package/dist/core/model-resolver.js +495 -0
  167. package/dist/core/model-resolver.js.map +1 -0
  168. package/dist/core/output-guard.d.ts +7 -0
  169. package/dist/core/output-guard.d.ts.map +1 -0
  170. package/dist/core/output-guard.js +89 -0
  171. package/dist/core/output-guard.js.map +1 -0
  172. package/dist/core/package-manager.d.ts +204 -0
  173. package/dist/core/package-manager.d.ts.map +1 -0
  174. package/dist/core/package-manager.js +2040 -0
  175. package/dist/core/package-manager.js.map +1 -0
  176. package/dist/core/prompt-templates.d.ts +52 -0
  177. package/dist/core/prompt-templates.d.ts.map +1 -0
  178. package/dist/core/prompt-templates.js +238 -0
  179. package/dist/core/prompt-templates.js.map +1 -0
  180. package/dist/core/provider-display-names.d.ts +2 -0
  181. package/dist/core/provider-display-names.d.ts.map +1 -0
  182. package/dist/core/provider-display-names.js +33 -0
  183. package/dist/core/provider-display-names.js.map +1 -0
  184. package/dist/core/resolve-config-value.d.ts +23 -0
  185. package/dist/core/resolve-config-value.d.ts.map +1 -0
  186. package/dist/core/resolve-config-value.js +126 -0
  187. package/dist/core/resolve-config-value.js.map +1 -0
  188. package/dist/core/resource-loader.d.ts +194 -0
  189. package/dist/core/resource-loader.d.ts.map +1 -0
  190. package/dist/core/resource-loader.js +734 -0
  191. package/dist/core/resource-loader.js.map +1 -0
  192. package/dist/core/sdk.d.ts +107 -0
  193. package/dist/core/sdk.d.ts.map +1 -0
  194. package/dist/core/sdk.js +287 -0
  195. package/dist/core/sdk.js.map +1 -0
  196. package/dist/core/session-cwd.d.ts +19 -0
  197. package/dist/core/session-cwd.d.ts.map +1 -0
  198. package/dist/core/session-cwd.js +38 -0
  199. package/dist/core/session-cwd.js.map +1 -0
  200. package/dist/core/session-manager.d.ts +333 -0
  201. package/dist/core/session-manager.d.ts.map +1 -0
  202. package/dist/core/session-manager.js +1147 -0
  203. package/dist/core/session-manager.js.map +1 -0
  204. package/dist/core/settings-manager.d.ts +264 -0
  205. package/dist/core/settings-manager.d.ts.map +1 -0
  206. package/dist/core/settings-manager.js +795 -0
  207. package/dist/core/settings-manager.js.map +1 -0
  208. package/dist/core/skills.d.ts +60 -0
  209. package/dist/core/skills.d.ts.map +1 -0
  210. package/dist/core/skills.js +387 -0
  211. package/dist/core/skills.js.map +1 -0
  212. package/dist/core/slash-commands.d.ts +14 -0
  213. package/dist/core/slash-commands.d.ts.map +1 -0
  214. package/dist/core/slash-commands.js +25 -0
  215. package/dist/core/slash-commands.js.map +1 -0
  216. package/dist/core/source-info.d.ts +18 -0
  217. package/dist/core/source-info.d.ts.map +1 -0
  218. package/dist/core/source-info.js +19 -0
  219. package/dist/core/source-info.js.map +1 -0
  220. package/dist/core/system-prompt.d.ts +28 -0
  221. package/dist/core/system-prompt.d.ts.map +1 -0
  222. package/dist/core/system-prompt.js +132 -0
  223. package/dist/core/system-prompt.js.map +1 -0
  224. package/dist/core/telemetry.d.ts +3 -0
  225. package/dist/core/telemetry.d.ts.map +1 -0
  226. package/dist/core/telemetry.js +9 -0
  227. package/dist/core/telemetry.js.map +1 -0
  228. package/dist/core/timings.d.ts +8 -0
  229. package/dist/core/timings.d.ts.map +1 -0
  230. package/dist/core/timings.js +31 -0
  231. package/dist/core/timings.js.map +1 -0
  232. package/dist/core/tools/bash.d.ts +68 -0
  233. package/dist/core/tools/bash.d.ts.map +1 -0
  234. package/dist/core/tools/bash.js +337 -0
  235. package/dist/core/tools/bash.js.map +1 -0
  236. package/dist/core/tools/edit-diff.d.ts +87 -0
  237. package/dist/core/tools/edit-diff.d.ts.map +1 -0
  238. package/dist/core/tools/edit-diff.js +345 -0
  239. package/dist/core/tools/edit-diff.js.map +1 -0
  240. package/dist/core/tools/edit.d.ts +51 -0
  241. package/dist/core/tools/edit.d.ts.map +1 -0
  242. package/dist/core/tools/edit.js +287 -0
  243. package/dist/core/tools/edit.js.map +1 -0
  244. package/dist/core/tools/file-mutation-queue.d.ts +6 -0
  245. package/dist/core/tools/file-mutation-queue.d.ts.map +1 -0
  246. package/dist/core/tools/file-mutation-queue.js +52 -0
  247. package/dist/core/tools/file-mutation-queue.js.map +1 -0
  248. package/dist/core/tools/find.d.ts +35 -0
  249. package/dist/core/tools/find.d.ts.map +1 -0
  250. package/dist/core/tools/find.js +297 -0
  251. package/dist/core/tools/find.js.map +1 -0
  252. package/dist/core/tools/grep.d.ts +37 -0
  253. package/dist/core/tools/grep.d.ts.map +1 -0
  254. package/dist/core/tools/grep.js +304 -0
  255. package/dist/core/tools/grep.js.map +1 -0
  256. package/dist/core/tools/index.d.ts +40 -0
  257. package/dist/core/tools/index.d.ts.map +1 -0
  258. package/dist/core/tools/index.js +112 -0
  259. package/dist/core/tools/index.js.map +1 -0
  260. package/dist/core/tools/ls.d.ts +37 -0
  261. package/dist/core/tools/ls.d.ts.map +1 -0
  262. package/dist/core/tools/ls.js +169 -0
  263. package/dist/core/tools/ls.js.map +1 -0
  264. package/dist/core/tools/output-accumulator.d.ts +52 -0
  265. package/dist/core/tools/output-accumulator.d.ts.map +1 -0
  266. package/dist/core/tools/output-accumulator.js +184 -0
  267. package/dist/core/tools/output-accumulator.js.map +1 -0
  268. package/dist/core/tools/path-utils.d.ts +10 -0
  269. package/dist/core/tools/path-utils.d.ts.map +1 -0
  270. package/dist/core/tools/path-utils.js +99 -0
  271. package/dist/core/tools/path-utils.js.map +1 -0
  272. package/dist/core/tools/read.d.ts +35 -0
  273. package/dist/core/tools/read.d.ts.map +1 -0
  274. package/dist/core/tools/read.js +290 -0
  275. package/dist/core/tools/read.js.map +1 -0
  276. package/dist/core/tools/render-utils.d.ts +21 -0
  277. package/dist/core/tools/render-utils.d.ts.map +1 -0
  278. package/dist/core/tools/render-utils.js +49 -0
  279. package/dist/core/tools/render-utils.js.map +1 -0
  280. package/dist/core/tools/tool-definition-wrapper.d.ts +14 -0
  281. package/dist/core/tools/tool-definition-wrapper.d.ts.map +1 -0
  282. package/dist/core/tools/tool-definition-wrapper.js +34 -0
  283. package/dist/core/tools/tool-definition-wrapper.js.map +1 -0
  284. package/dist/core/tools/truncate.d.ts +70 -0
  285. package/dist/core/tools/truncate.d.ts.map +1 -0
  286. package/dist/core/tools/truncate.js +215 -0
  287. package/dist/core/tools/truncate.js.map +1 -0
  288. package/dist/core/tools/write.d.ts +26 -0
  289. package/dist/core/tools/write.d.ts.map +1 -0
  290. package/dist/core/tools/write.js +198 -0
  291. package/dist/core/tools/write.js.map +1 -0
  292. package/dist/index.d.ts +29 -0
  293. package/dist/index.d.ts.map +1 -0
  294. package/dist/index.js +42 -0
  295. package/dist/index.js.map +1 -0
  296. package/dist/main.d.ts +12 -0
  297. package/dist/main.d.ts.map +1 -0
  298. package/dist/main.js +578 -0
  299. package/dist/main.js.map +1 -0
  300. package/dist/migrations.d.ts +33 -0
  301. package/dist/migrations.d.ts.map +1 -0
  302. package/dist/migrations.js +281 -0
  303. package/dist/migrations.js.map +1 -0
  304. package/dist/modes/index.d.ts +9 -0
  305. package/dist/modes/index.d.ts.map +1 -0
  306. package/dist/modes/index.js +8 -0
  307. package/dist/modes/index.js.map +1 -0
  308. package/dist/modes/interactive/assets/clankolas.png +0 -0
  309. package/dist/modes/interactive/components/armin.d.ts +34 -0
  310. package/dist/modes/interactive/components/armin.d.ts.map +1 -0
  311. package/dist/modes/interactive/components/armin.js +333 -0
  312. package/dist/modes/interactive/components/armin.js.map +1 -0
  313. package/dist/modes/interactive/components/assistant-message.d.ts +20 -0
  314. package/dist/modes/interactive/components/assistant-message.d.ts.map +1 -0
  315. package/dist/modes/interactive/components/assistant-message.js +121 -0
  316. package/dist/modes/interactive/components/assistant-message.js.map +1 -0
  317. package/dist/modes/interactive/components/bash-execution.d.ts +34 -0
  318. package/dist/modes/interactive/components/bash-execution.d.ts.map +1 -0
  319. package/dist/modes/interactive/components/bash-execution.js +175 -0
  320. package/dist/modes/interactive/components/bash-execution.js.map +1 -0
  321. package/dist/modes/interactive/components/bordered-loader.d.ts +16 -0
  322. package/dist/modes/interactive/components/bordered-loader.d.ts.map +1 -0
  323. package/dist/modes/interactive/components/bordered-loader.js +54 -0
  324. package/dist/modes/interactive/components/bordered-loader.js.map +1 -0
  325. package/dist/modes/interactive/components/branch-summary-message.d.ts +16 -0
  326. package/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -0
  327. package/dist/modes/interactive/components/branch-summary-message.js +44 -0
  328. package/dist/modes/interactive/components/branch-summary-message.js.map +1 -0
  329. package/dist/modes/interactive/components/compaction-summary-message.d.ts +16 -0
  330. package/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -0
  331. package/dist/modes/interactive/components/compaction-summary-message.js +45 -0
  332. package/dist/modes/interactive/components/compaction-summary-message.js.map +1 -0
  333. package/dist/modes/interactive/components/config-selector.d.ts +71 -0
  334. package/dist/modes/interactive/components/config-selector.d.ts.map +1 -0
  335. package/dist/modes/interactive/components/config-selector.js +506 -0
  336. package/dist/modes/interactive/components/config-selector.js.map +1 -0
  337. package/dist/modes/interactive/components/countdown-timer.d.ts +14 -0
  338. package/dist/modes/interactive/components/countdown-timer.d.ts.map +1 -0
  339. package/dist/modes/interactive/components/countdown-timer.js +33 -0
  340. package/dist/modes/interactive/components/countdown-timer.js.map +1 -0
  341. package/dist/modes/interactive/components/custom-editor.d.ts +21 -0
  342. package/dist/modes/interactive/components/custom-editor.d.ts.map +1 -0
  343. package/dist/modes/interactive/components/custom-editor.js +70 -0
  344. package/dist/modes/interactive/components/custom-editor.js.map +1 -0
  345. package/dist/modes/interactive/components/custom-message.d.ts +20 -0
  346. package/dist/modes/interactive/components/custom-message.d.ts.map +1 -0
  347. package/dist/modes/interactive/components/custom-message.js +79 -0
  348. package/dist/modes/interactive/components/custom-message.js.map +1 -0
  349. package/dist/modes/interactive/components/daxnuts.d.ts +23 -0
  350. package/dist/modes/interactive/components/daxnuts.d.ts.map +1 -0
  351. package/dist/modes/interactive/components/daxnuts.js +140 -0
  352. package/dist/modes/interactive/components/daxnuts.js.map +1 -0
  353. package/dist/modes/interactive/components/diff.d.ts +12 -0
  354. package/dist/modes/interactive/components/diff.d.ts.map +1 -0
  355. package/dist/modes/interactive/components/diff.js +133 -0
  356. package/dist/modes/interactive/components/diff.js.map +1 -0
  357. package/dist/modes/interactive/components/dynamic-border.d.ts +15 -0
  358. package/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -0
  359. package/dist/modes/interactive/components/dynamic-border.js +21 -0
  360. package/dist/modes/interactive/components/dynamic-border.js.map +1 -0
  361. package/dist/modes/interactive/components/earendil-announcement.d.ts +5 -0
  362. package/dist/modes/interactive/components/earendil-announcement.d.ts.map +1 -0
  363. package/dist/modes/interactive/components/earendil-announcement.js +40 -0
  364. package/dist/modes/interactive/components/earendil-announcement.js.map +1 -0
  365. package/dist/modes/interactive/components/extension-editor.d.ts +20 -0
  366. package/dist/modes/interactive/components/extension-editor.d.ts.map +1 -0
  367. package/dist/modes/interactive/components/extension-editor.js +119 -0
  368. package/dist/modes/interactive/components/extension-editor.js.map +1 -0
  369. package/dist/modes/interactive/components/extension-input.d.ts +23 -0
  370. package/dist/modes/interactive/components/extension-input.d.ts.map +1 -0
  371. package/dist/modes/interactive/components/extension-input.js +61 -0
  372. package/dist/modes/interactive/components/extension-input.js.map +1 -0
  373. package/dist/modes/interactive/components/extension-selector.d.ts +26 -0
  374. package/dist/modes/interactive/components/extension-selector.d.ts.map +1 -0
  375. package/dist/modes/interactive/components/extension-selector.js +83 -0
  376. package/dist/modes/interactive/components/extension-selector.js.map +1 -0
  377. package/dist/modes/interactive/components/footer.d.ts +28 -0
  378. package/dist/modes/interactive/components/footer.d.ts.map +1 -0
  379. package/dist/modes/interactive/components/footer.js +210 -0
  380. package/dist/modes/interactive/components/footer.js.map +1 -0
  381. package/dist/modes/interactive/components/index.d.ts +32 -0
  382. package/dist/modes/interactive/components/index.d.ts.map +1 -0
  383. package/dist/modes/interactive/components/index.js +33 -0
  384. package/dist/modes/interactive/components/index.js.map +1 -0
  385. package/dist/modes/interactive/components/keybinding-hints.d.ts +13 -0
  386. package/dist/modes/interactive/components/keybinding-hints.d.ts.map +1 -0
  387. package/dist/modes/interactive/components/keybinding-hints.js +36 -0
  388. package/dist/modes/interactive/components/keybinding-hints.js.map +1 -0
  389. package/dist/modes/interactive/components/login-dialog.d.ts +54 -0
  390. package/dist/modes/interactive/components/login-dialog.d.ts.map +1 -0
  391. package/dist/modes/interactive/components/login-dialog.js +185 -0
  392. package/dist/modes/interactive/components/login-dialog.js.map +1 -0
  393. package/dist/modes/interactive/components/model-selector.d.ts +47 -0
  394. package/dist/modes/interactive/components/model-selector.d.ts.map +1 -0
  395. package/dist/modes/interactive/components/model-selector.js +278 -0
  396. package/dist/modes/interactive/components/model-selector.js.map +1 -0
  397. package/dist/modes/interactive/components/oauth-selector.d.ts +31 -0
  398. package/dist/modes/interactive/components/oauth-selector.d.ts.map +1 -0
  399. package/dist/modes/interactive/components/oauth-selector.js +165 -0
  400. package/dist/modes/interactive/components/oauth-selector.js.map +1 -0
  401. package/dist/modes/interactive/components/scoped-models-selector.d.ts +42 -0
  402. package/dist/modes/interactive/components/scoped-models-selector.d.ts.map +1 -0
  403. package/dist/modes/interactive/components/scoped-models-selector.js +290 -0
  404. package/dist/modes/interactive/components/scoped-models-selector.js.map +1 -0
  405. package/dist/modes/interactive/components/session-selector-search.d.ts +23 -0
  406. package/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -0
  407. package/dist/modes/interactive/components/session-selector-search.js +155 -0
  408. package/dist/modes/interactive/components/session-selector-search.js.map +1 -0
  409. package/dist/modes/interactive/components/session-selector.d.ts +96 -0
  410. package/dist/modes/interactive/components/session-selector.d.ts.map +1 -0
  411. package/dist/modes/interactive/components/session-selector.js +861 -0
  412. package/dist/modes/interactive/components/session-selector.js.map +1 -0
  413. package/dist/modes/interactive/components/settings-selector.d.ts +69 -0
  414. package/dist/modes/interactive/components/settings-selector.d.ts.map +1 -0
  415. package/dist/modes/interactive/components/settings-selector.js +390 -0
  416. package/dist/modes/interactive/components/settings-selector.js.map +1 -0
  417. package/dist/modes/interactive/components/show-images-selector.d.ts +10 -0
  418. package/dist/modes/interactive/components/show-images-selector.d.ts.map +1 -0
  419. package/dist/modes/interactive/components/show-images-selector.js +39 -0
  420. package/dist/modes/interactive/components/show-images-selector.js.map +1 -0
  421. package/dist/modes/interactive/components/skill-invocation-message.d.ts +17 -0
  422. package/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -0
  423. package/dist/modes/interactive/components/skill-invocation-message.js +47 -0
  424. package/dist/modes/interactive/components/skill-invocation-message.js.map +1 -0
  425. package/dist/modes/interactive/components/theme-selector.d.ts +11 -0
  426. package/dist/modes/interactive/components/theme-selector.d.ts.map +1 -0
  427. package/dist/modes/interactive/components/theme-selector.js +50 -0
  428. package/dist/modes/interactive/components/theme-selector.js.map +1 -0
  429. package/dist/modes/interactive/components/thinking-selector.d.ts +11 -0
  430. package/dist/modes/interactive/components/thinking-selector.d.ts.map +1 -0
  431. package/dist/modes/interactive/components/thinking-selector.js +51 -0
  432. package/dist/modes/interactive/components/thinking-selector.js.map +1 -0
  433. package/dist/modes/interactive/components/tool-execution.d.ts +63 -0
  434. package/dist/modes/interactive/components/tool-execution.d.ts.map +1 -0
  435. package/dist/modes/interactive/components/tool-execution.js +295 -0
  436. package/dist/modes/interactive/components/tool-execution.js.map +1 -0
  437. package/dist/modes/interactive/components/tree-selector.d.ts +89 -0
  438. package/dist/modes/interactive/components/tree-selector.d.ts.map +1 -0
  439. package/dist/modes/interactive/components/tree-selector.js +1093 -0
  440. package/dist/modes/interactive/components/tree-selector.js.map +1 -0
  441. package/dist/modes/interactive/components/user-message-selector.d.ts +30 -0
  442. package/dist/modes/interactive/components/user-message-selector.d.ts.map +1 -0
  443. package/dist/modes/interactive/components/user-message-selector.js +114 -0
  444. package/dist/modes/interactive/components/user-message-selector.js.map +1 -0
  445. package/dist/modes/interactive/components/user-message.d.ts +10 -0
  446. package/dist/modes/interactive/components/user-message.d.ts.map +1 -0
  447. package/dist/modes/interactive/components/user-message.js +29 -0
  448. package/dist/modes/interactive/components/user-message.js.map +1 -0
  449. package/dist/modes/interactive/components/visual-truncate.d.ts +24 -0
  450. package/dist/modes/interactive/components/visual-truncate.d.ts.map +1 -0
  451. package/dist/modes/interactive/components/visual-truncate.js +33 -0
  452. package/dist/modes/interactive/components/visual-truncate.js.map +1 -0
  453. package/dist/modes/interactive/interactive-mode.d.ts +370 -0
  454. package/dist/modes/interactive/interactive-mode.d.ts.map +1 -0
  455. package/dist/modes/interactive/interactive-mode.js +4659 -0
  456. package/dist/modes/interactive/interactive-mode.js.map +1 -0
  457. package/dist/modes/interactive/theme/dark.json +86 -0
  458. package/dist/modes/interactive/theme/light.json +85 -0
  459. package/dist/modes/interactive/theme/theme-schema.json +335 -0
  460. package/dist/modes/interactive/theme/theme.d.ts +100 -0
  461. package/dist/modes/interactive/theme/theme.d.ts.map +1 -0
  462. package/dist/modes/interactive/theme/theme.js +1024 -0
  463. package/dist/modes/interactive/theme/theme.js.map +1 -0
  464. package/dist/modes/print-mode.d.ts +28 -0
  465. package/dist/modes/print-mode.d.ts.map +1 -0
  466. package/dist/modes/print-mode.js +131 -0
  467. package/dist/modes/print-mode.js.map +1 -0
  468. package/dist/modes/rpc/jsonl.d.ts +17 -0
  469. package/dist/modes/rpc/jsonl.d.ts.map +1 -0
  470. package/dist/modes/rpc/jsonl.js +49 -0
  471. package/dist/modes/rpc/jsonl.js.map +1 -0
  472. package/dist/modes/rpc/rpc-client.d.ts +227 -0
  473. package/dist/modes/rpc/rpc-client.d.ts.map +1 -0
  474. package/dist/modes/rpc/rpc-client.js +467 -0
  475. package/dist/modes/rpc/rpc-client.js.map +1 -0
  476. package/dist/modes/rpc/rpc-mode.d.ts +20 -0
  477. package/dist/modes/rpc/rpc-mode.d.ts.map +1 -0
  478. package/dist/modes/rpc/rpc-mode.js +613 -0
  479. package/dist/modes/rpc/rpc-mode.js.map +1 -0
  480. package/dist/modes/rpc/rpc-types.d.ts +419 -0
  481. package/dist/modes/rpc/rpc-types.d.ts.map +1 -0
  482. package/dist/modes/rpc/rpc-types.js +8 -0
  483. package/dist/modes/rpc/rpc-types.js.map +1 -0
  484. package/dist/package-manager-cli.d.ts +4 -0
  485. package/dist/package-manager-cli.d.ts.map +1 -0
  486. package/dist/package-manager-cli.js +515 -0
  487. package/dist/package-manager-cli.js.map +1 -0
  488. package/dist/utils/ansi.d.ts +2 -0
  489. package/dist/utils/ansi.d.ts.map +1 -0
  490. package/dist/utils/ansi.js +52 -0
  491. package/dist/utils/ansi.js.map +1 -0
  492. package/dist/utils/changelog.d.ts +21 -0
  493. package/dist/utils/changelog.d.ts.map +1 -0
  494. package/dist/utils/changelog.js +87 -0
  495. package/dist/utils/changelog.js.map +1 -0
  496. package/dist/utils/child-process.d.ts +15 -0
  497. package/dist/utils/child-process.d.ts.map +1 -0
  498. package/dist/utils/child-process.js +88 -0
  499. package/dist/utils/child-process.js.map +1 -0
  500. package/dist/utils/clipboard-image.d.ts +11 -0
  501. package/dist/utils/clipboard-image.d.ts.map +1 -0
  502. package/dist/utils/clipboard-image.js +245 -0
  503. package/dist/utils/clipboard-image.js.map +1 -0
  504. package/dist/utils/clipboard-native.d.ts +10 -0
  505. package/dist/utils/clipboard-native.d.ts.map +1 -0
  506. package/dist/utils/clipboard-native.js +20 -0
  507. package/dist/utils/clipboard-native.js.map +1 -0
  508. package/dist/utils/clipboard.d.ts +2 -0
  509. package/dist/utils/clipboard.d.ts.map +1 -0
  510. package/dist/utils/clipboard.js +117 -0
  511. package/dist/utils/clipboard.js.map +1 -0
  512. package/dist/utils/exif-orientation.d.ts +5 -0
  513. package/dist/utils/exif-orientation.d.ts.map +1 -0
  514. package/dist/utils/exif-orientation.js +158 -0
  515. package/dist/utils/exif-orientation.js.map +1 -0
  516. package/dist/utils/frontmatter.d.ts +8 -0
  517. package/dist/utils/frontmatter.d.ts.map +1 -0
  518. package/dist/utils/frontmatter.js +26 -0
  519. package/dist/utils/frontmatter.js.map +1 -0
  520. package/dist/utils/fs-watch.d.ts +5 -0
  521. package/dist/utils/fs-watch.d.ts.map +1 -0
  522. package/dist/utils/fs-watch.js +25 -0
  523. package/dist/utils/fs-watch.js.map +1 -0
  524. package/dist/utils/git.d.ts +26 -0
  525. package/dist/utils/git.d.ts.map +1 -0
  526. package/dist/utils/git.js +163 -0
  527. package/dist/utils/git.js.map +1 -0
  528. package/dist/utils/html.d.ts +7 -0
  529. package/dist/utils/html.d.ts.map +1 -0
  530. package/dist/utils/html.js +40 -0
  531. package/dist/utils/html.js.map +1 -0
  532. package/dist/utils/image-convert.d.ts +9 -0
  533. package/dist/utils/image-convert.d.ts.map +1 -0
  534. package/dist/utils/image-convert.js +39 -0
  535. package/dist/utils/image-convert.js.map +1 -0
  536. package/dist/utils/image-resize-core.d.ts +30 -0
  537. package/dist/utils/image-resize-core.d.ts.map +1 -0
  538. package/dist/utils/image-resize-core.js +124 -0
  539. package/dist/utils/image-resize-core.js.map +1 -0
  540. package/dist/utils/image-resize-worker.d.ts +2 -0
  541. package/dist/utils/image-resize-worker.d.ts.map +1 -0
  542. package/dist/utils/image-resize-worker.js +31 -0
  543. package/dist/utils/image-resize-worker.js.map +1 -0
  544. package/dist/utils/image-resize.d.ts +16 -0
  545. package/dist/utils/image-resize.d.ts.map +1 -0
  546. package/dist/utils/image-resize.js +97 -0
  547. package/dist/utils/image-resize.js.map +1 -0
  548. package/dist/utils/mime.d.ts +3 -0
  549. package/dist/utils/mime.d.ts.map +1 -0
  550. package/dist/utils/mime.js +69 -0
  551. package/dist/utils/mime.js.map +1 -0
  552. package/dist/utils/paths.d.ts +31 -0
  553. package/dist/utils/paths.d.ts.map +1 -0
  554. package/dist/utils/paths.js +92 -0
  555. package/dist/utils/paths.js.map +1 -0
  556. package/dist/utils/photon.d.ts +21 -0
  557. package/dist/utils/photon.d.ts.map +1 -0
  558. package/dist/utils/photon.js +121 -0
  559. package/dist/utils/photon.js.map +1 -0
  560. package/dist/utils/pi-user-agent.d.ts +2 -0
  561. package/dist/utils/pi-user-agent.d.ts.map +1 -0
  562. package/dist/utils/pi-user-agent.js +5 -0
  563. package/dist/utils/pi-user-agent.js.map +1 -0
  564. package/dist/utils/shell.d.ts +30 -0
  565. package/dist/utils/shell.d.ts.map +1 -0
  566. package/dist/utils/shell.js +195 -0
  567. package/dist/utils/shell.js.map +1 -0
  568. package/dist/utils/sleep.d.ts +5 -0
  569. package/dist/utils/sleep.d.ts.map +1 -0
  570. package/dist/utils/sleep.js +17 -0
  571. package/dist/utils/sleep.js.map +1 -0
  572. package/dist/utils/syntax-highlight.d.ts +12 -0
  573. package/dist/utils/syntax-highlight.d.ts.map +1 -0
  574. package/dist/utils/syntax-highlight.js +118 -0
  575. package/dist/utils/syntax-highlight.js.map +1 -0
  576. package/dist/utils/tools-manager.d.ts +3 -0
  577. package/dist/utils/tools-manager.d.ts.map +1 -0
  578. package/dist/utils/tools-manager.js +328 -0
  579. package/dist/utils/tools-manager.js.map +1 -0
  580. package/dist/utils/version-check.d.ts +15 -0
  581. package/dist/utils/version-check.d.ts.map +1 -0
  582. package/dist/utils/version-check.js +82 -0
  583. package/dist/utils/version-check.js.map +1 -0
  584. package/dist/utils/windows-self-update.d.ts +3 -0
  585. package/dist/utils/windows-self-update.d.ts.map +1 -0
  586. package/dist/utils/windows-self-update.js +77 -0
  587. package/dist/utils/windows-self-update.js.map +1 -0
  588. package/docs/compaction.md +394 -0
  589. package/docs/custom-provider.md +733 -0
  590. package/docs/development.md +71 -0
  591. package/docs/docs.json +148 -0
  592. package/docs/extensions.md +2596 -0
  593. package/docs/images/doom-extension.png +0 -0
  594. package/docs/images/exy.png +0 -0
  595. package/docs/images/interactive-mode.png +0 -0
  596. package/docs/images/tree-view.png +0 -0
  597. package/docs/index.md +80 -0
  598. package/docs/json.md +82 -0
  599. package/docs/keybindings.md +197 -0
  600. package/docs/models.md +480 -0
  601. package/docs/packages.md +226 -0
  602. package/docs/prompt-templates.md +88 -0
  603. package/docs/providers.md +243 -0
  604. package/docs/quickstart.md +164 -0
  605. package/docs/rpc.md +1407 -0
  606. package/docs/sdk.md +1131 -0
  607. package/docs/session-format.md +412 -0
  608. package/docs/sessions.md +137 -0
  609. package/docs/settings.md +277 -0
  610. package/docs/shell-aliases.md +13 -0
  611. package/docs/skills.md +231 -0
  612. package/docs/terminal-setup.md +112 -0
  613. package/docs/termux.md +127 -0
  614. package/docs/themes.md +295 -0
  615. package/docs/tmux.md +61 -0
  616. package/docs/tui.md +918 -0
  617. package/docs/usage.md +279 -0
  618. package/docs/windows.md +17 -0
  619. package/examples/README.md +25 -0
  620. package/examples/extensions/README.md +208 -0
  621. package/examples/extensions/auto-commit-on-exit.ts +49 -0
  622. package/examples/extensions/bash-spawn-hook.ts +30 -0
  623. package/examples/extensions/bookmark.ts +50 -0
  624. package/examples/extensions/border-status-editor.ts +150 -0
  625. package/examples/extensions/built-in-tool-renderer.ts +249 -0
  626. package/examples/extensions/claude-rules.ts +86 -0
  627. package/examples/extensions/commands.ts +72 -0
  628. package/examples/extensions/confirm-destructive.ts +59 -0
  629. package/examples/extensions/custom-compaction.ts +127 -0
  630. package/examples/extensions/custom-footer.ts +64 -0
  631. package/examples/extensions/custom-header.ts +73 -0
  632. package/examples/extensions/custom-provider-anthropic/index.ts +604 -0
  633. package/examples/extensions/custom-provider-anthropic/package-lock.json +24 -0
  634. package/examples/extensions/custom-provider-anthropic/package.json +19 -0
  635. package/examples/extensions/custom-provider-gitlab-duo/index.ts +349 -0
  636. package/examples/extensions/custom-provider-gitlab-duo/package.json +16 -0
  637. package/examples/extensions/custom-provider-gitlab-duo/test.ts +82 -0
  638. package/examples/extensions/dirty-repo-guard.ts +56 -0
  639. package/examples/extensions/doom-overlay/README.md +46 -0
  640. package/examples/extensions/doom-overlay/doom/build/doom.js +21 -0
  641. package/examples/extensions/doom-overlay/doom/build/doom.wasm +0 -0
  642. package/examples/extensions/doom-overlay/doom/build.sh +152 -0
  643. package/examples/extensions/doom-overlay/doom/doomgeneric_pi.c +72 -0
  644. package/examples/extensions/doom-overlay/doom-component.ts +132 -0
  645. package/examples/extensions/doom-overlay/doom-engine.ts +173 -0
  646. package/examples/extensions/doom-overlay/doom-keys.ts +104 -0
  647. package/examples/extensions/doom-overlay/index.ts +74 -0
  648. package/examples/extensions/doom-overlay/wad-finder.ts +51 -0
  649. package/examples/extensions/dynamic-resources/SKILL.md +8 -0
  650. package/examples/extensions/dynamic-resources/dynamic.json +79 -0
  651. package/examples/extensions/dynamic-resources/dynamic.md +5 -0
  652. package/examples/extensions/dynamic-resources/index.ts +15 -0
  653. package/examples/extensions/dynamic-tools.ts +74 -0
  654. package/examples/extensions/event-bus.ts +43 -0
  655. package/examples/extensions/file-trigger.ts +41 -0
  656. package/examples/extensions/git-checkpoint.ts +53 -0
  657. package/examples/extensions/github-issue-autocomplete.ts +185 -0
  658. package/examples/extensions/handoff.ts +191 -0
  659. package/examples/extensions/hello.ts +26 -0
  660. package/examples/extensions/hidden-thinking-label.ts +53 -0
  661. package/examples/extensions/inline-bash.ts +94 -0
  662. package/examples/extensions/input-transform.ts +43 -0
  663. package/examples/extensions/interactive-shell.ts +196 -0
  664. package/examples/extensions/mac-system-theme.ts +47 -0
  665. package/examples/extensions/message-renderer.ts +59 -0
  666. package/examples/extensions/minimal-mode.ts +426 -0
  667. package/examples/extensions/modal-editor.ts +85 -0
  668. package/examples/extensions/model-status.ts +31 -0
  669. package/examples/extensions/notify.ts +55 -0
  670. package/examples/extensions/overlay-qa-tests.ts +1379 -0
  671. package/examples/extensions/overlay-test.ts +153 -0
  672. package/examples/extensions/permission-gate.ts +34 -0
  673. package/examples/extensions/pirate.ts +47 -0
  674. package/examples/extensions/plan-mode/README.md +65 -0
  675. package/examples/extensions/plan-mode/index.ts +340 -0
  676. package/examples/extensions/plan-mode/utils.ts +168 -0
  677. package/examples/extensions/preset.ts +430 -0
  678. package/examples/extensions/prompt-customizer.ts +97 -0
  679. package/examples/extensions/protected-paths.ts +30 -0
  680. package/examples/extensions/provider-payload.ts +18 -0
  681. package/examples/extensions/qna.ts +122 -0
  682. package/examples/extensions/question.ts +264 -0
  683. package/examples/extensions/questionnaire.ts +427 -0
  684. package/examples/extensions/rainbow-editor.ts +88 -0
  685. package/examples/extensions/reload-runtime.ts +37 -0
  686. package/examples/extensions/rpc-demo.ts +118 -0
  687. package/examples/extensions/sandbox/index.ts +321 -0
  688. package/examples/extensions/sandbox/package-lock.json +92 -0
  689. package/examples/extensions/sandbox/package.json +19 -0
  690. package/examples/extensions/send-user-message.ts +97 -0
  691. package/examples/extensions/session-name.ts +27 -0
  692. package/examples/extensions/shutdown-command.ts +63 -0
  693. package/examples/extensions/snake.ts +343 -0
  694. package/examples/extensions/space-invaders.ts +560 -0
  695. package/examples/extensions/ssh.ts +220 -0
  696. package/examples/extensions/status-line.ts +32 -0
  697. package/examples/extensions/structured-output.ts +65 -0
  698. package/examples/extensions/subagent/README.md +175 -0
  699. package/examples/extensions/subagent/agents/planner.md +37 -0
  700. package/examples/extensions/subagent/agents/reviewer.md +35 -0
  701. package/examples/extensions/subagent/agents/scout.md +50 -0
  702. package/examples/extensions/subagent/agents/worker.md +24 -0
  703. package/examples/extensions/subagent/agents.ts +126 -0
  704. package/examples/extensions/subagent/index.ts +1009 -0
  705. package/examples/extensions/subagent/prompts/implement-and-review.md +10 -0
  706. package/examples/extensions/subagent/prompts/implement.md +10 -0
  707. package/examples/extensions/subagent/prompts/scout-and-plan.md +9 -0
  708. package/examples/extensions/summarize.ts +206 -0
  709. package/examples/extensions/system-prompt-header.ts +17 -0
  710. package/examples/extensions/tic-tac-toe.ts +1008 -0
  711. package/examples/extensions/timed-confirm.ts +70 -0
  712. package/examples/extensions/titlebar-spinner.ts +58 -0
  713. package/examples/extensions/todo.ts +297 -0
  714. package/examples/extensions/tool-override.ts +144 -0
  715. package/examples/extensions/tools.ts +141 -0
  716. package/examples/extensions/trigger-compact.ts +50 -0
  717. package/examples/extensions/truncated-tool.ts +195 -0
  718. package/examples/extensions/widget-placement.ts +9 -0
  719. package/examples/extensions/with-deps/index.ts +32 -0
  720. package/examples/extensions/with-deps/package-lock.json +31 -0
  721. package/examples/extensions/with-deps/package.json +22 -0
  722. package/examples/extensions/working-indicator.ts +123 -0
  723. package/examples/extensions/working-message-test.ts +25 -0
  724. package/examples/rpc-extension-ui.ts +632 -0
  725. package/examples/sdk/01-minimal.ts +26 -0
  726. package/examples/sdk/02-custom-model.ts +53 -0
  727. package/examples/sdk/03-custom-prompt.ts +75 -0
  728. package/examples/sdk/04-skills.ts +55 -0
  729. package/examples/sdk/05-tools.ts +48 -0
  730. package/examples/sdk/06-extensions.ts +99 -0
  731. package/examples/sdk/07-context-files.ts +47 -0
  732. package/examples/sdk/08-prompt-templates.ts +51 -0
  733. package/examples/sdk/09-api-keys-and-oauth.ts +52 -0
  734. package/examples/sdk/10-settings.ts +53 -0
  735. package/examples/sdk/11-sessions.ts +52 -0
  736. package/examples/sdk/12-full-control.ts +77 -0
  737. package/examples/sdk/13-session-runtime.ts +67 -0
  738. package/examples/sdk/README.md +144 -0
  739. package/npm-shrinkwrap.json +1791 -0
  740. package/package.json +100 -0
@@ -0,0 +1,733 @@
1
+ # Custom Providers
2
+
3
+ Extensions can register custom model providers via `pi.registerProvider()`. This enables:
4
+
5
+ - **Proxies** - Route requests through corporate proxies or API gateways
6
+ - **Custom endpoints** - Use self-hosted or private model deployments
7
+ - **OAuth/SSO** - Add authentication flows for enterprise providers
8
+ - **Custom APIs** - Implement streaming for non-standard LLM APIs
9
+
10
+ ## Example Extensions
11
+
12
+ See these complete provider examples:
13
+
14
+ - [`examples/extensions/custom-provider-anthropic/`](../examples/extensions/custom-provider-anthropic/)
15
+ - [`examples/extensions/custom-provider-gitlab-duo/`](../examples/extensions/custom-provider-gitlab-duo/)
16
+
17
+ ## Table of Contents
18
+
19
+ - [Example Extensions](#example-extensions)
20
+ - [Quick Reference](#quick-reference)
21
+ - [Override Existing Provider](#override-existing-provider)
22
+ - [Register New Provider](#register-new-provider)
23
+ - [Unregister Provider](#unregister-provider)
24
+ - [OAuth Support](#oauth-support)
25
+ - [Custom Streaming API](#custom-streaming-api)
26
+ - [Context Overflow Errors](#context-overflow-errors)
27
+ - [Testing Your Implementation](#testing-your-implementation)
28
+ - [Config Reference](#config-reference)
29
+ - [Model Definition Reference](#model-definition-reference)
30
+
31
+ ## Quick Reference
32
+
33
+ ```typescript
34
+ import type { ExtensionAPI } from "@earendil-works/pi-coding-agent";
35
+
36
+ export default function (pi: ExtensionAPI) {
37
+ // Override baseUrl for existing provider
38
+ pi.registerProvider("anthropic", {
39
+ baseUrl: "https://proxy.example.com"
40
+ });
41
+
42
+ // Register new provider with models
43
+ pi.registerProvider("my-provider", {
44
+ name: "My Provider",
45
+ baseUrl: "https://api.example.com",
46
+ apiKey: "MY_API_KEY",
47
+ api: "openai-completions",
48
+ models: [
49
+ {
50
+ id: "my-model",
51
+ name: "My Model",
52
+ reasoning: false,
53
+ input: ["text", "image"],
54
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
55
+ contextWindow: 128000,
56
+ maxTokens: 4096
57
+ }
58
+ ]
59
+ });
60
+ }
61
+ ```
62
+
63
+ The extension factory can also be `async`. For dynamic model discovery, fetch and register models in the factory instead of `session_start`. pi waits for the factory before startup continues, so the provider is available during interactive startup and to `pi --list-models`.
64
+
65
+ ## Override Existing Provider
66
+
67
+ The simplest use case: redirect an existing provider through a proxy.
68
+
69
+ ```typescript
70
+ // All Anthropic requests now go through your proxy
71
+ pi.registerProvider("anthropic", {
72
+ baseUrl: "https://proxy.example.com"
73
+ });
74
+
75
+ // Add custom headers to OpenAI requests
76
+ pi.registerProvider("openai", {
77
+ headers: {
78
+ "X-Custom-Header": "value"
79
+ }
80
+ });
81
+
82
+ // Both baseUrl and headers
83
+ pi.registerProvider("google", {
84
+ baseUrl: "https://ai-gateway.corp.com/google",
85
+ headers: {
86
+ "X-Corp-Auth": "CORP_AUTH_TOKEN" // env var or literal
87
+ }
88
+ });
89
+ ```
90
+
91
+ When only `baseUrl` and/or `headers` are provided (no `models`), all existing models for that provider are preserved with the new endpoint.
92
+
93
+ ## Register New Provider
94
+
95
+ To add a completely new provider, specify `models` along with the required configuration.
96
+
97
+ If the model list comes from a remote endpoint, use an async extension factory:
98
+
99
+ ```typescript
100
+ import type { ExtensionAPI } from "@earendil-works/pi-coding-agent";
101
+
102
+ export default async function (pi: ExtensionAPI) {
103
+ const response = await fetch("http://localhost:1234/v1/models");
104
+ const payload = (await response.json()) as {
105
+ data: Array<{
106
+ id: string;
107
+ name?: string;
108
+ context_window?: number;
109
+ max_tokens?: number;
110
+ }>;
111
+ };
112
+
113
+ pi.registerProvider("local-openai", {
114
+ baseUrl: "http://localhost:1234/v1",
115
+ apiKey: "LOCAL_OPENAI_API_KEY",
116
+ api: "openai-completions",
117
+ models: payload.data.map((model) => ({
118
+ id: model.id,
119
+ name: model.name ?? model.id,
120
+ reasoning: false,
121
+ input: ["text"],
122
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
123
+ contextWindow: model.context_window ?? 128000,
124
+ maxTokens: model.max_tokens ?? 4096,
125
+ })),
126
+ });
127
+ }
128
+ ```
129
+
130
+ This registers the fetched models before startup finishes.
131
+
132
+ ```typescript
133
+ pi.registerProvider("my-llm", {
134
+ baseUrl: "https://api.my-llm.com/v1",
135
+ apiKey: "MY_LLM_API_KEY", // env var name or literal value
136
+ api: "openai-completions", // which streaming API to use
137
+ models: [
138
+ {
139
+ id: "my-llm-large",
140
+ name: "My LLM Large",
141
+ reasoning: true, // supports extended thinking
142
+ input: ["text", "image"],
143
+ cost: {
144
+ input: 3.0, // $/million tokens
145
+ output: 15.0,
146
+ cacheRead: 0.3,
147
+ cacheWrite: 3.75
148
+ },
149
+ contextWindow: 200000,
150
+ maxTokens: 16384
151
+ }
152
+ ]
153
+ });
154
+ ```
155
+
156
+ When `models` is provided, it **replaces** all existing models for that provider.
157
+
158
+ ## Unregister Provider
159
+
160
+ Use `pi.unregisterProvider(name)` to remove a provider that was previously registered via `pi.registerProvider(name, ...)`:
161
+
162
+ ```typescript
163
+ // Register
164
+ pi.registerProvider("my-llm", {
165
+ baseUrl: "https://api.my-llm.com/v1",
166
+ apiKey: "MY_LLM_API_KEY",
167
+ api: "openai-completions",
168
+ models: [
169
+ {
170
+ id: "my-llm-large",
171
+ name: "My LLM Large",
172
+ reasoning: true,
173
+ input: ["text", "image"],
174
+ cost: { input: 3.0, output: 15.0, cacheRead: 0.3, cacheWrite: 3.75 },
175
+ contextWindow: 200000,
176
+ maxTokens: 16384
177
+ }
178
+ ]
179
+ });
180
+
181
+ // Later, remove it
182
+ pi.unregisterProvider("my-llm");
183
+ ```
184
+
185
+ Unregistering removes that provider's dynamic models, API key fallback, OAuth provider registration, and custom stream handler registrations. Any built-in models or provider behavior that were overridden are restored.
186
+
187
+ Calls made after the initial extension load phase are applied immediately, so no `/reload` is required.
188
+
189
+ ### API Types
190
+
191
+ The `api` field determines which streaming implementation is used:
192
+
193
+ | API | Use for |
194
+ |-----|---------|
195
+ | `anthropic-messages` | Anthropic Claude API and compatibles |
196
+ | `openai-completions` | OpenAI Chat Completions API and compatibles |
197
+ | `openai-responses` | OpenAI Responses API |
198
+ | `azure-openai-responses` | Azure OpenAI Responses API |
199
+ | `openai-codex-responses` | OpenAI Codex Responses API |
200
+ | `mistral-conversations` | Mistral SDK Conversations/Chat streaming |
201
+ | `google-generative-ai` | Google Generative AI API |
202
+ | `google-vertex` | Google Vertex AI API |
203
+ | `bedrock-converse-stream` | Amazon Bedrock Converse API |
204
+
205
+ Most OpenAI-compatible providers work with `openai-completions`. Use model-level `thinkingLevelMap` for model-specific thinking levels, and `compat` for provider quirks:
206
+
207
+ ```typescript
208
+ models: [{
209
+ id: "custom-model",
210
+ // ...
211
+ reasoning: true,
212
+ thinkingLevelMap: { // map pi levels to provider values; null hides unsupported levels
213
+ minimal: null,
214
+ low: null,
215
+ medium: null,
216
+ high: "default",
217
+ xhigh: "max"
218
+ },
219
+ compat: {
220
+ supportsDeveloperRole: false, // use "system" instead of "developer"
221
+ supportsReasoningEffort: true,
222
+ maxTokensField: "max_tokens", // instead of "max_completion_tokens"
223
+ requiresToolResultName: true, // tool results need name field
224
+ thinkingFormat: "qwen", // top-level enable_thinking: true
225
+ cacheControlFormat: "anthropic" // Anthropic-style cache_control markers
226
+ }
227
+ }]
228
+ ```
229
+
230
+ Use `openrouter` for OpenRouter-style `reasoning: { effort }` controls. Use `together` for Together-style `reasoning: { enabled }` controls; with `supportsReasoningEffort`, it also sends `reasoning_effort`. Use `qwen-chat-template` instead for local Qwen-compatible servers that read `chat_template_kwargs.enable_thinking`.
231
+ Use `cacheControlFormat: "anthropic"` for OpenAI-compatible providers that expose Anthropic-style prompt caching via `cache_control` on the system prompt, last tool definition, and last user/assistant text content.
232
+
233
+ For Anthropic-compatible providers using `api: "anthropic-messages"`, set `compat.forceAdaptiveThinking: true` on models or providers whose upstream model requires adaptive thinking (`thinking.type: "adaptive"` plus `output_config.effort`). Built-in adaptive Claude models set this automatically.
234
+
235
+ > Migration note: Mistral moved from `openai-completions` to `mistral-conversations`.
236
+ > Use `mistral-conversations` for native Mistral models.
237
+ > If you intentionally route Mistral-compatible/custom endpoints through `openai-completions`, set `compat` flags explicitly as needed.
238
+
239
+ ### Auth Header
240
+
241
+ If your provider expects `Authorization: Bearer <key>` but doesn't use a standard API, set `authHeader: true`:
242
+
243
+ ```typescript
244
+ pi.registerProvider("custom-api", {
245
+ baseUrl: "https://api.example.com",
246
+ apiKey: "MY_API_KEY",
247
+ authHeader: true, // adds Authorization: Bearer header
248
+ api: "openai-completions",
249
+ models: [...]
250
+ });
251
+ ```
252
+
253
+ ## OAuth Support
254
+
255
+ Add OAuth/SSO authentication that integrates with `/login`:
256
+
257
+ ```typescript
258
+ import type { OAuthCredentials, OAuthLoginCallbacks } from "@earendil-works/pi-ai";
259
+
260
+ pi.registerProvider("corporate-ai", {
261
+ baseUrl: "https://ai.corp.com/v1",
262
+ api: "openai-responses",
263
+ models: [...],
264
+ oauth: {
265
+ name: "Corporate AI (SSO)",
266
+
267
+ async login(callbacks: OAuthLoginCallbacks): Promise<OAuthCredentials> {
268
+ const method = await callbacks.onSelect({
269
+ message: "Select login method:",
270
+ options: [
271
+ { id: "browser", label: "Browser OAuth" },
272
+ { id: "device", label: "Device code" }
273
+ ]
274
+ });
275
+ if (!method) throw new Error("Login cancelled");
276
+
277
+ let code: string;
278
+ if (method === "device") {
279
+ callbacks.onDeviceCode({
280
+ userCode: "ABCD-1234",
281
+ verificationUri: "https://sso.corp.com/device",
282
+ intervalSeconds: 5,
283
+ expiresInSeconds: 900
284
+ });
285
+ code = await pollDeviceCodeUntilComplete();
286
+ } else {
287
+ callbacks.onAuth({ url: "https://sso.corp.com/authorize?..." });
288
+ code = await callbacks.onPrompt({ message: "Enter SSO code:" });
289
+ }
290
+
291
+ // Exchange for tokens (your implementation)
292
+ const tokens = await exchangeCodeForTokens(code);
293
+
294
+ return {
295
+ refresh: tokens.refreshToken,
296
+ access: tokens.accessToken,
297
+ expires: Date.now() + tokens.expiresIn * 1000
298
+ };
299
+ },
300
+
301
+ async refreshToken(credentials: OAuthCredentials): Promise<OAuthCredentials> {
302
+ const tokens = await refreshAccessToken(credentials.refresh);
303
+ return {
304
+ refresh: tokens.refreshToken ?? credentials.refresh,
305
+ access: tokens.accessToken,
306
+ expires: Date.now() + tokens.expiresIn * 1000
307
+ };
308
+ },
309
+
310
+ getApiKey(credentials: OAuthCredentials): string {
311
+ return credentials.access;
312
+ },
313
+
314
+ // Optional: modify models based on user's subscription
315
+ modifyModels(models, credentials) {
316
+ const region = decodeRegionFromToken(credentials.access);
317
+ return models.map(m => ({
318
+ ...m,
319
+ baseUrl: `https://${region}.ai.corp.com/v1`
320
+ }));
321
+ }
322
+ }
323
+ });
324
+ ```
325
+
326
+ After registration, users can authenticate via `/login corporate-ai`.
327
+
328
+ ### OAuthLoginCallbacks
329
+
330
+ The `callbacks` object provides three ways to authenticate:
331
+
332
+ ```typescript
333
+ interface OAuthLoginCallbacks {
334
+ // Open URL in browser (for OAuth redirects)
335
+ onAuth(params: { url: string }): void;
336
+
337
+ // Show device code (for device authorization flow)
338
+ onDeviceCode(params: {
339
+ userCode: string;
340
+ verificationUri: string;
341
+ intervalSeconds?: number;
342
+ expiresInSeconds?: number;
343
+ }): void;
344
+
345
+ // Prompt user for input (for manual token entry)
346
+ onPrompt(params: { message: string }): Promise<string>;
347
+
348
+ // Show an interactive selector, e.g. to choose browser OAuth vs device code
349
+ onSelect(params: {
350
+ message: string;
351
+ options: { id: string; label: string }[];
352
+ }): Promise<string | undefined>;
353
+ }
354
+ ```
355
+
356
+ ### OAuthCredentials
357
+
358
+ Credentials are persisted in `~/.pi/agent/auth.json`:
359
+
360
+ ```typescript
361
+ interface OAuthCredentials {
362
+ refresh: string; // Refresh token (for refreshToken())
363
+ access: string; // Access token (returned by getApiKey())
364
+ expires: number; // Expiration timestamp in milliseconds
365
+ }
366
+ ```
367
+
368
+ ## Custom Streaming API
369
+
370
+ For providers with non-standard APIs, implement `streamSimple`. Study the existing provider implementations before writing your own:
371
+
372
+ **Reference implementations:**
373
+ - [anthropic.ts](https://github.com/earendil-works/pi-mono/blob/main/packages/ai/src/providers/anthropic.ts) - Anthropic Messages API
374
+ - [mistral.ts](https://github.com/earendil-works/pi-mono/blob/main/packages/ai/src/providers/mistral.ts) - Mistral Conversations API
375
+ - [openai-completions.ts](https://github.com/earendil-works/pi-mono/blob/main/packages/ai/src/providers/openai-completions.ts) - OpenAI Chat Completions
376
+ - [openai-responses.ts](https://github.com/earendil-works/pi-mono/blob/main/packages/ai/src/providers/openai-responses.ts) - OpenAI Responses API
377
+ - [google.ts](https://github.com/earendil-works/pi-mono/blob/main/packages/ai/src/providers/google.ts) - Google Generative AI
378
+ - [amazon-bedrock.ts](https://github.com/earendil-works/pi-mono/blob/main/packages/ai/src/providers/amazon-bedrock.ts) - AWS Bedrock
379
+
380
+ ### Stream Pattern
381
+
382
+ All providers follow the same pattern:
383
+
384
+ ```typescript
385
+ import {
386
+ type AssistantMessage,
387
+ type AssistantMessageEventStream,
388
+ type Context,
389
+ type Model,
390
+ type SimpleStreamOptions,
391
+ calculateCost,
392
+ createAssistantMessageEventStream,
393
+ } from "@earendil-works/pi-ai";
394
+
395
+ function streamMyProvider(
396
+ model: Model<any>,
397
+ context: Context,
398
+ options?: SimpleStreamOptions
399
+ ): AssistantMessageEventStream {
400
+ const stream = createAssistantMessageEventStream();
401
+
402
+ (async () => {
403
+ // Initialize output message
404
+ const output: AssistantMessage = {
405
+ role: "assistant",
406
+ content: [],
407
+ api: model.api,
408
+ provider: model.provider,
409
+ model: model.id,
410
+ usage: {
411
+ input: 0,
412
+ output: 0,
413
+ cacheRead: 0,
414
+ cacheWrite: 0,
415
+ totalTokens: 0,
416
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0, total: 0 },
417
+ },
418
+ stopReason: "stop",
419
+ timestamp: Date.now(),
420
+ };
421
+
422
+ try {
423
+ // Push start event
424
+ stream.push({ type: "start", partial: output });
425
+
426
+ // Make API request and process response...
427
+ // Push content events as they arrive...
428
+
429
+ // Push done event
430
+ stream.push({
431
+ type: "done",
432
+ reason: output.stopReason as "stop" | "length" | "toolUse",
433
+ message: output
434
+ });
435
+ stream.end();
436
+ } catch (error) {
437
+ output.stopReason = options?.signal?.aborted ? "aborted" : "error";
438
+ output.errorMessage = error instanceof Error ? error.message : String(error);
439
+ stream.push({ type: "error", reason: output.stopReason, error: output });
440
+ stream.end();
441
+ }
442
+ })();
443
+
444
+ return stream;
445
+ }
446
+ ```
447
+
448
+ ### Event Types
449
+
450
+ Push events via `stream.push()` in this order:
451
+
452
+ 1. `{ type: "start", partial: output }` - Stream started
453
+
454
+ 2. Content events (repeatable, track `contentIndex` for each block):
455
+ - `{ type: "text_start", contentIndex, partial }` - Text block started
456
+ - `{ type: "text_delta", contentIndex, delta, partial }` - Text chunk
457
+ - `{ type: "text_end", contentIndex, content, partial }` - Text block ended
458
+ - `{ type: "thinking_start", contentIndex, partial }` - Thinking started
459
+ - `{ type: "thinking_delta", contentIndex, delta, partial }` - Thinking chunk
460
+ - `{ type: "thinking_end", contentIndex, content, partial }` - Thinking ended
461
+ - `{ type: "toolcall_start", contentIndex, partial }` - Tool call started
462
+ - `{ type: "toolcall_delta", contentIndex, delta, partial }` - Tool call JSON chunk
463
+ - `{ type: "toolcall_end", contentIndex, toolCall, partial }` - Tool call ended
464
+
465
+ 3. `{ type: "done", reason, message }` or `{ type: "error", reason, error }` - Stream ended
466
+
467
+ The `partial` field in each event contains the current `AssistantMessage` state. Update `output.content` as you receive data, then include `output` as the `partial`.
468
+
469
+ ### Content Blocks
470
+
471
+ Add content blocks to `output.content` as they arrive:
472
+
473
+ ```typescript
474
+ // Text block
475
+ output.content.push({ type: "text", text: "" });
476
+ stream.push({ type: "text_start", contentIndex: output.content.length - 1, partial: output });
477
+
478
+ // As text arrives
479
+ const block = output.content[contentIndex];
480
+ if (block.type === "text") {
481
+ block.text += delta;
482
+ stream.push({ type: "text_delta", contentIndex, delta, partial: output });
483
+ }
484
+
485
+ // When block completes
486
+ stream.push({ type: "text_end", contentIndex, content: block.text, partial: output });
487
+ ```
488
+
489
+ ### Tool Calls
490
+
491
+ Tool calls require accumulating JSON and parsing:
492
+
493
+ ```typescript
494
+ // Start tool call
495
+ output.content.push({
496
+ type: "toolCall",
497
+ id: toolCallId,
498
+ name: toolName,
499
+ arguments: {}
500
+ });
501
+ stream.push({ type: "toolcall_start", contentIndex: output.content.length - 1, partial: output });
502
+
503
+ // Accumulate JSON
504
+ let partialJson = "";
505
+ partialJson += jsonDelta;
506
+ try {
507
+ block.arguments = JSON.parse(partialJson);
508
+ } catch {}
509
+ stream.push({ type: "toolcall_delta", contentIndex, delta: jsonDelta, partial: output });
510
+
511
+ // Complete
512
+ stream.push({
513
+ type: "toolcall_end",
514
+ contentIndex,
515
+ toolCall: { type: "toolCall", id, name, arguments: block.arguments },
516
+ partial: output
517
+ });
518
+ ```
519
+
520
+ ### Usage and Cost
521
+
522
+ Update usage from API response and calculate cost:
523
+
524
+ ```typescript
525
+ output.usage.input = response.usage.input_tokens;
526
+ output.usage.output = response.usage.output_tokens;
527
+ output.usage.cacheRead = response.usage.cache_read_tokens ?? 0;
528
+ output.usage.cacheWrite = response.usage.cache_write_tokens ?? 0;
529
+ output.usage.totalTokens = output.usage.input + output.usage.output +
530
+ output.usage.cacheRead + output.usage.cacheWrite;
531
+ calculateCost(model, output.usage);
532
+ ```
533
+
534
+ ### Context Overflow Errors
535
+
536
+ When a request exceeds the model's context window, pi can recover automatically by compacting the conversation and retrying. This recovery only kicks in if pi recognizes the failure as an overflow.
537
+
538
+ Detection runs on the finalized assistant message:
539
+
540
+ - `stopReason === "error"`
541
+ - `errorMessage` matches one of pi's known overflow patterns (see [`packages/ai/src/utils/overflow.ts`](https://github.com/earendil-works/pi-mono/blob/main/packages/ai/src/utils/overflow.ts))
542
+
543
+ If your provider returns overflow errors with a message pi does not recognize, normalize the error from the same extension that registers the provider. Use a `message_end` handler to rewrite the assistant message so its `errorMessage` starts with a phrase pi recognizes. The generic fallback `context_length_exceeded` is the safest choice.
544
+
545
+ ```typescript
546
+ const MY_PROVIDER_OVERFLOW_PATTERN = /your provider's overflow phrase/i;
547
+
548
+ export default function (pi: ExtensionAPI) {
549
+ pi.registerProvider("my-provider", { /* ... */ });
550
+
551
+ pi.on("message_end", (event, ctx) => {
552
+ const message = event.message;
553
+ if (message.role !== "assistant") return;
554
+ if (message.stopReason !== "error") return;
555
+ if (
556
+ message.provider !== "my-provider" &&
557
+ ctx.model?.provider !== "my-provider"
558
+ )
559
+ return;
560
+
561
+ const errorMessage = message.errorMessage ?? "";
562
+ if (errorMessage.includes("context_length_exceeded")) return;
563
+ if (!MY_PROVIDER_OVERFLOW_PATTERN.test(errorMessage)) return;
564
+
565
+ return {
566
+ message: {
567
+ ...message,
568
+ errorMessage: `context_length_exceeded: ${errorMessage}`,
569
+ },
570
+ };
571
+ });
572
+ }
573
+ ```
574
+
575
+ `message_end` runs before pi tracks the assistant message for auto-compaction, so the rewritten `errorMessage` is what pi checks. With this in place, pi will:
576
+
577
+ 1. Detect the overflow from `errorMessage`.
578
+ 2. Drop the failed assistant message from live context.
579
+ 3. Run compaction.
580
+ 4. Retry the request once.
581
+
582
+ Guard the rewrite carefully:
583
+
584
+ - Scope it to your provider (`message.provider` and `ctx.model?.provider`) so unrelated errors from other providers are untouched.
585
+ - Match a provider-specific pattern, not pi's generic overflow patterns. Rewriting rate-limit or throttling errors (`rate limit`, `too many requests`) would falsely trigger compaction instead of pi's normal retry-with-backoff path.
586
+ - Skip when `errorMessage` already includes `context_length_exceeded` so the handler is idempotent.
587
+
588
+ ### Registration
589
+
590
+ Register your stream function:
591
+
592
+ ```typescript
593
+ pi.registerProvider("my-provider", {
594
+ baseUrl: "https://api.example.com",
595
+ apiKey: "MY_API_KEY",
596
+ api: "my-custom-api",
597
+ models: [...],
598
+ streamSimple: streamMyProvider
599
+ });
600
+ ```
601
+
602
+ ## Testing Your Implementation
603
+
604
+ Test your provider against the same test suites used by built-in providers. Copy and adapt these test files from [packages/ai/test/](https://github.com/earendil-works/pi-mono/tree/main/packages/ai/test):
605
+
606
+ | Test | Purpose |
607
+ |------|---------|
608
+ | `stream.test.ts` | Basic streaming, text output |
609
+ | `tokens.test.ts` | Token counting and usage |
610
+ | `abort.test.ts` | AbortSignal handling |
611
+ | `empty.test.ts` | Empty/minimal responses |
612
+ | `context-overflow.test.ts` | Context window limits |
613
+ | `image-limits.test.ts` | Image input handling |
614
+ | `unicode-surrogate.test.ts` | Unicode edge cases |
615
+ | `tool-call-without-result.test.ts` | Tool call edge cases |
616
+ | `image-tool-result.test.ts` | Images in tool results |
617
+ | `total-tokens.test.ts` | Total token calculation |
618
+ | `cross-provider-handoff.test.ts` | Context handoff between providers |
619
+
620
+ Run tests with your provider/model pairs to verify compatibility.
621
+
622
+ ## Config Reference
623
+
624
+ ```typescript
625
+ interface ProviderConfig {
626
+ /** Display name for the provider in UI such as /login. */
627
+ name?: string;
628
+
629
+ /** API endpoint URL. Required when defining models. */
630
+ baseUrl?: string;
631
+
632
+ /** API key or environment variable name. Required when defining models (unless oauth). */
633
+ apiKey?: string;
634
+
635
+ /** API type for streaming. Required at provider or model level when defining models. */
636
+ api?: Api;
637
+
638
+ /** Custom streaming implementation for non-standard APIs. */
639
+ streamSimple?: (
640
+ model: Model<Api>,
641
+ context: Context,
642
+ options?: SimpleStreamOptions
643
+ ) => AssistantMessageEventStream;
644
+
645
+ /** Custom headers to include in requests. Values can be env var names. */
646
+ headers?: Record<string, string>;
647
+
648
+ /** If true, adds Authorization: Bearer header with the resolved API key. */
649
+ authHeader?: boolean;
650
+
651
+ /** Models to register. If provided, replaces all existing models for this provider. */
652
+ models?: ProviderModelConfig[];
653
+
654
+ /** OAuth provider for /login support. */
655
+ oauth?: {
656
+ name: string;
657
+ login(callbacks: OAuthLoginCallbacks): Promise<OAuthCredentials>;
658
+ refreshToken(credentials: OAuthCredentials): Promise<OAuthCredentials>;
659
+ getApiKey(credentials: OAuthCredentials): string;
660
+ modifyModels?(models: Model<Api>[], credentials: OAuthCredentials): Model<Api>[];
661
+ };
662
+ }
663
+ ```
664
+
665
+ ## Model Definition Reference
666
+
667
+ ```typescript
668
+ interface ProviderModelConfig {
669
+ /** Model ID (e.g., "claude-sonnet-4-20250514"). */
670
+ id: string;
671
+
672
+ /** Display name (e.g., "Claude 4 Sonnet"). */
673
+ name: string;
674
+
675
+ /** API type override for this specific model. */
676
+ api?: Api;
677
+
678
+ /** API endpoint URL override for this specific model. */
679
+ baseUrl?: string;
680
+
681
+ /** Whether the model supports extended thinking. */
682
+ reasoning: boolean;
683
+
684
+ /** Maps pi thinking levels to provider/model-specific values; null marks a level unsupported. */
685
+ thinkingLevelMap?: Partial<Record<"off" | "minimal" | "low" | "medium" | "high" | "xhigh", string | null>>;
686
+
687
+ /** Supported input types. */
688
+ input: ("text" | "image")[];
689
+
690
+ /** Cost per million tokens (for usage tracking). */
691
+ cost: {
692
+ input: number;
693
+ output: number;
694
+ cacheRead: number;
695
+ cacheWrite: number;
696
+ };
697
+
698
+ /** Maximum context window size in tokens. */
699
+ contextWindow: number;
700
+
701
+ /** Maximum output tokens. */
702
+ maxTokens: number;
703
+
704
+ /** Custom headers for this specific model. */
705
+ headers?: Record<string, string>;
706
+
707
+ /** Compatibility settings for the selected API. */
708
+ compat?: {
709
+ // openai-completions
710
+ supportsStore?: boolean;
711
+ supportsDeveloperRole?: boolean;
712
+ supportsReasoningEffort?: boolean;
713
+ supportsUsageInStreaming?: boolean;
714
+ maxTokensField?: "max_completion_tokens" | "max_tokens";
715
+ requiresToolResultName?: boolean;
716
+ requiresAssistantAfterToolResult?: boolean;
717
+ requiresThinkingAsText?: boolean;
718
+ requiresReasoningContentOnAssistantMessages?: boolean;
719
+ thinkingFormat?: "openai" | "openrouter" | "deepseek" | "together" | "zai" | "qwen" | "qwen-chat-template";
720
+ cacheControlFormat?: "anthropic";
721
+
722
+ // anthropic-messages
723
+ supportsEagerToolInputStreaming?: boolean;
724
+ supportsLongCacheRetention?: boolean;
725
+ sendSessionAffinityHeaders?: boolean;
726
+ supportsCacheControlOnTools?: boolean;
727
+ forceAdaptiveThinking?: boolean;
728
+ };
729
+ }
730
+ ```
731
+
732
+ `openrouter` sends `reasoning: { effort }`. `deepseek` sends `thinking: { type: "enabled" | "disabled" }` and `reasoning_effort` when enabled. `together` sends `reasoning: { enabled }` and also `reasoning_effort` when `supportsReasoningEffort` is enabled. `qwen` is for DashScope-style top-level `enable_thinking`. Use `qwen-chat-template` for local Qwen-compatible servers that read `chat_template_kwargs.enable_thinking`.
733
+ `cacheControlFormat: "anthropic"` applies Anthropic-style `cache_control` markers to the system prompt, last tool definition, and last user/assistant text content.