@pellux/goodvibes-tui 0.18.11 → 0.18.13

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 (570) hide show
  1. package/CHANGELOG.md +72 -0
  2. package/README.md +1 -1
  3. package/docs/foundation-artifacts/operator-contract.json +1 -1
  4. package/package.json +2 -2
  5. package/src/config/index.ts +1 -138
  6. package/src/config/subscription-providers.ts +1 -127
  7. package/src/core/conversation-rendering.ts +5 -5
  8. package/src/core/conversation.ts +177 -424
  9. package/src/core/history.ts +45 -0
  10. package/src/core/orchestrator.ts +3 -733
  11. package/src/core/system-message-router.ts +19 -58
  12. package/src/input/command-registry.ts +3 -3
  13. package/src/input/commands/session-content.ts +2 -2
  14. package/src/input/commands/session-workflow.ts +1 -1
  15. package/src/input/handler-content-actions.ts +2 -2
  16. package/src/input/handler-feed.ts +2 -2
  17. package/src/input/handler-modal-token-routes.ts +1 -1
  18. package/src/input/handler-ui-state.ts +1 -1
  19. package/src/input/handler.ts +1 -1
  20. package/src/input/search.ts +1 -1
  21. package/src/input/selection.ts +2 -2
  22. package/src/input/session-picker-modal.ts +1 -1
  23. package/src/main.ts +1 -1
  24. package/src/panels/agent-inspector-panel.ts +3 -3
  25. package/src/panels/agent-logs-panel.ts +3 -3
  26. package/src/panels/approval-panel.ts +2 -2
  27. package/src/panels/automation-control-panel.ts +3 -3
  28. package/src/panels/base-panel.ts +14 -14
  29. package/src/panels/builtin/agent.ts +1 -0
  30. package/src/panels/builtin/operations.ts +2 -1
  31. package/src/panels/builtin/session.ts +2 -2
  32. package/src/panels/builtin/shared.ts +5 -5
  33. package/src/panels/cockpit-panel.ts +2 -2
  34. package/src/panels/communication-panel.ts +3 -3
  35. package/src/panels/context-visualizer-panel.ts +6 -3
  36. package/src/panels/control-plane-panel.ts +3 -3
  37. package/src/panels/cost-tracker-panel.ts +3 -3
  38. package/src/panels/debug-panel.ts +2 -2
  39. package/src/panels/diff-panel.ts +2 -2
  40. package/src/panels/docs-panel.ts +1 -1
  41. package/src/panels/eval-panel.ts +2 -2
  42. package/src/panels/file-explorer-panel.ts +3 -3
  43. package/src/panels/file-preview-panel.ts +3 -3
  44. package/src/panels/forensics-panel.ts +2 -2
  45. package/src/panels/git-panel.ts +1 -1
  46. package/src/panels/hooks-panel.ts +3 -3
  47. package/src/panels/incident-review-panel.ts +1 -1
  48. package/src/panels/intelligence-panel.ts +2 -2
  49. package/src/panels/knowledge-panel.ts +1 -1
  50. package/src/panels/local-auth-panel.ts +2 -2
  51. package/src/panels/marketplace-panel.ts +1 -1
  52. package/src/panels/mcp-panel.ts +3 -3
  53. package/src/panels/memory-panel.ts +1 -1
  54. package/src/panels/ops-control-panel.ts +3 -3
  55. package/src/panels/ops-strategy-panel.ts +2 -2
  56. package/src/panels/orchestration-panel.ts +2 -2
  57. package/src/panels/panel-list-panel.ts +6 -6
  58. package/src/panels/plan-dashboard-panel.ts +1 -1
  59. package/src/panels/plugins-panel.ts +2 -2
  60. package/src/panels/policy-panel.ts +2 -2
  61. package/src/panels/polish.ts +3 -3
  62. package/src/panels/provider-accounts-panel.ts +2 -2
  63. package/src/panels/provider-health-domains.ts +5 -1
  64. package/src/panels/provider-health-panel.ts +7 -3
  65. package/src/panels/provider-stats-panel.ts +3 -3
  66. package/src/panels/remote-panel.ts +3 -3
  67. package/src/panels/routes-panel.ts +3 -3
  68. package/src/panels/sandbox-panel.ts +2 -2
  69. package/src/panels/schedule-panel.ts +1 -1
  70. package/src/panels/security-panel.ts +2 -2
  71. package/src/panels/services-panel.ts +2 -2
  72. package/src/panels/session-browser-panel.ts +3 -3
  73. package/src/panels/settings-sync-panel.ts +2 -2
  74. package/src/panels/skills-panel.ts +6 -6
  75. package/src/panels/subscription-panel.ts +2 -2
  76. package/src/panels/symbol-outline-panel.ts +3 -3
  77. package/src/panels/system-messages-panel.ts +4 -4
  78. package/src/panels/tasks-panel.ts +2 -2
  79. package/src/panels/thinking-panel.ts +3 -3
  80. package/src/panels/token-budget-panel.ts +7 -3
  81. package/src/panels/tool-inspector-panel.ts +3 -3
  82. package/src/panels/types.ts +5 -5
  83. package/src/panels/watchers-panel.ts +3 -3
  84. package/src/panels/welcome-panel.ts +1 -1
  85. package/src/panels/worktree-panel.ts +2 -2
  86. package/src/panels/wrfc-panel.ts +3 -3
  87. package/src/permissions/prompt.ts +3 -22
  88. package/src/plugins/loader.ts +15 -304
  89. package/src/renderer/agent-detail-modal.ts +1 -1
  90. package/src/renderer/autocomplete-overlay.ts +2 -2
  91. package/src/renderer/bookmark-modal.ts +1 -1
  92. package/src/renderer/bottom-bar.ts +2 -2
  93. package/src/renderer/buffer.ts +1 -1
  94. package/src/renderer/code-block.ts +2 -2
  95. package/src/renderer/compositor.ts +2 -2
  96. package/src/renderer/context-inspector.ts +1 -1
  97. package/src/renderer/conversation-layout.ts +2 -2
  98. package/src/renderer/conversation-overlays.ts +1 -1
  99. package/src/renderer/conversation-surface.ts +2 -2
  100. package/src/renderer/diff-view.ts +2 -2
  101. package/src/renderer/diff.ts +1 -1
  102. package/src/renderer/file-picker-overlay.ts +2 -2
  103. package/src/renderer/file-tree.ts +2 -2
  104. package/src/renderer/help-overlay.ts +1 -1
  105. package/src/renderer/history-search-overlay.ts +2 -2
  106. package/src/renderer/live-tail-modal.ts +1 -1
  107. package/src/renderer/markdown.ts +2 -2
  108. package/src/renderer/modal-factory.ts +3 -3
  109. package/src/renderer/model-picker-overlay.ts +2 -2
  110. package/src/renderer/overlay-box.ts +2 -2
  111. package/src/renderer/panel-composite.ts +1 -1
  112. package/src/renderer/panel-picker-overlay.ts +2 -2
  113. package/src/renderer/panel-tab-bar.ts +1 -1
  114. package/src/renderer/panel-workspace-bar.ts +1 -1
  115. package/src/renderer/process-indicator.ts +2 -2
  116. package/src/renderer/process-modal.ts +1 -1
  117. package/src/renderer/profile-picker-modal.ts +2 -2
  118. package/src/renderer/progress.ts +2 -2
  119. package/src/renderer/search-overlay.ts +2 -2
  120. package/src/renderer/selection-modal-overlay.ts +2 -2
  121. package/src/renderer/session-picker-modal.ts +2 -2
  122. package/src/renderer/settings-modal.ts +2 -2
  123. package/src/renderer/shell-surface.ts +1 -1
  124. package/src/renderer/system-message.ts +1 -1
  125. package/src/renderer/tab-strip.ts +2 -2
  126. package/src/renderer/text-layout.ts +1 -1
  127. package/src/renderer/thinking.ts +1 -1
  128. package/src/renderer/tool-call.ts +2 -2
  129. package/src/renderer/ui-factory.ts +2 -2
  130. package/src/runtime/bootstrap-command-context.ts +7 -8
  131. package/src/runtime/bootstrap-command-parts.ts +4 -6
  132. package/src/runtime/bootstrap-core.ts +5 -4
  133. package/src/runtime/bootstrap-hook-bridge.ts +16 -175
  134. package/src/runtime/bootstrap-shell.ts +5 -5
  135. package/src/runtime/bootstrap.ts +6 -5
  136. package/src/runtime/context.ts +4 -20
  137. package/src/runtime/diagnostics/panels/index.ts +1 -1
  138. package/src/runtime/diagnostics/panels/ops.ts +1 -1
  139. package/src/runtime/diagnostics/panels/panel-resources.ts +118 -0
  140. package/src/runtime/perf/panel-contracts.ts +32 -0
  141. package/src/runtime/perf/panel-health-monitor.ts +18 -0
  142. package/src/runtime/services.ts +6 -6
  143. package/src/runtime/store/domains/conversation.ts +1 -181
  144. package/src/runtime/store/domains/permissions.ts +1 -143
  145. package/src/runtime/store/helpers/reducers/conversation.ts +1 -228
  146. package/src/runtime/store/helpers/reducers/lifecycle.ts +1 -440
  147. package/src/runtime/store/selectors/index.ts +11 -6
  148. package/src/runtime/store/state.ts +12 -4
  149. package/src/runtime/ui-read-models-observability-security.ts +2 -2
  150. package/src/runtime/ui-read-models-observability-system.ts +1 -1
  151. package/src/runtime/ui-service-queries.ts +1 -1
  152. package/src/runtime/ui-services.ts +1 -1
  153. package/src/shell/ui-openers.ts +1 -1
  154. package/src/tools/index.ts +1 -186
  155. package/src/types/grid.ts +48 -0
  156. package/src/utils/clipboard.ts +21 -0
  157. package/src/utils/splash-lines.ts +1 -1
  158. package/src/utils/terminal-width.ts +185 -0
  159. package/src/version.ts +1 -1
  160. package/src/acp/connection.ts +0 -447
  161. package/src/acp/index.ts +0 -7
  162. package/src/acp/manager.ts +0 -1
  163. package/src/adapters/bluebubbles/index.ts +0 -127
  164. package/src/adapters/discord/index.ts +0 -297
  165. package/src/adapters/github/index.ts +0 -73
  166. package/src/adapters/google-chat/index.ts +0 -119
  167. package/src/adapters/imessage/index.ts +0 -92
  168. package/src/adapters/index.ts +0 -15
  169. package/src/adapters/matrix/index.ts +0 -116
  170. package/src/adapters/mattermost/index.ts +0 -151
  171. package/src/adapters/msteams/index.ts +0 -180
  172. package/src/adapters/ntfy/index.ts +0 -118
  173. package/src/adapters/signal/index.ts +0 -92
  174. package/src/adapters/slack/index.ts +0 -323
  175. package/src/adapters/telegram/index.ts +0 -160
  176. package/src/adapters/types.ts +0 -97
  177. package/src/adapters/webhook/index.ts +0 -178
  178. package/src/adapters/whatsapp/index.ts +0 -135
  179. package/src/agents/message-bus-core.ts +0 -312
  180. package/src/agents/message-bus.ts +0 -2
  181. package/src/agents/orchestrator-prompts.ts +0 -351
  182. package/src/agents/orchestrator-runner.ts +0 -668
  183. package/src/agents/orchestrator.ts +0 -438
  184. package/src/agents/session.ts +0 -108
  185. package/src/agents/worktree.ts +0 -153
  186. package/src/agents/wrfc-config.ts +0 -47
  187. package/src/agents/wrfc-controller.ts +0 -747
  188. package/src/agents/wrfc-gate-runtime.ts +0 -75
  189. package/src/agents/wrfc-reporting.ts +0 -284
  190. package/src/agents/wrfc-runtime-events.ts +0 -150
  191. package/src/agents/wrfc-types.ts +0 -67
  192. package/src/automation/delivery-manager.ts +0 -368
  193. package/src/automation/index.ts +0 -72
  194. package/src/automation/manager-runtime-delivery.ts +0 -139
  195. package/src/automation/manager-runtime-events.ts +0 -131
  196. package/src/automation/manager-runtime-execution.ts +0 -511
  197. package/src/automation/manager-runtime-helpers.ts +0 -433
  198. package/src/automation/manager-runtime-job-mutations.ts +0 -175
  199. package/src/automation/manager-runtime-reconcile.ts +0 -148
  200. package/src/automation/manager-runtime-scheduling.ts +0 -189
  201. package/src/automation/manager-runtime-sync.ts +0 -54
  202. package/src/automation/manager-runtime.ts +0 -721
  203. package/src/automation/manager.ts +0 -10
  204. package/src/automation/service.ts +0 -242
  205. package/src/channels/builtin/account-actions.ts +0 -490
  206. package/src/channels/builtin/accounts.ts +0 -433
  207. package/src/channels/builtin/contracts.ts +0 -405
  208. package/src/channels/builtin/plugins.ts +0 -308
  209. package/src/channels/builtin/rendering.ts +0 -174
  210. package/src/channels/builtin/setup-schema.ts +0 -504
  211. package/src/channels/builtin/shared.ts +0 -96
  212. package/src/channels/builtin/surfaces.ts +0 -57
  213. package/src/channels/builtin/targets.ts +0 -693
  214. package/src/channels/builtin-runtime.ts +0 -443
  215. package/src/channels/delivery/shared.ts +0 -199
  216. package/src/channels/delivery/strategies-bridge.ts +0 -246
  217. package/src/channels/delivery/strategies-core.ts +0 -299
  218. package/src/channels/delivery/strategies-enterprise.ts +0 -178
  219. package/src/channels/delivery/types.ts +0 -59
  220. package/src/channels/delivery-router.ts +0 -127
  221. package/src/channels/index.ts +0 -77
  222. package/src/channels/plugin-registry.ts +0 -551
  223. package/src/channels/provider-runtime.ts +0 -330
  224. package/src/channels/reply-pipeline.ts +0 -522
  225. package/src/channels/route-manager.ts +0 -340
  226. package/src/channels/surface-registry.ts +0 -186
  227. package/src/config/helper-model.ts +0 -1
  228. package/src/config/manager.ts +0 -8
  229. package/src/config/subscription-auth.ts +0 -31
  230. package/src/config/tool-llm.ts +0 -110
  231. package/src/control-plane/approval-broker.ts +0 -351
  232. package/src/control-plane/gateway.ts +0 -1
  233. package/src/control-plane/index.ts +0 -54
  234. package/src/control-plane/media-contract-schemas.ts +0 -1
  235. package/src/control-plane/method-catalog-admin.ts +0 -1
  236. package/src/control-plane/method-catalog-channels.ts +0 -1
  237. package/src/control-plane/method-catalog-control-automation.ts +0 -1
  238. package/src/control-plane/method-catalog-control-core.ts +0 -1
  239. package/src/control-plane/method-catalog-control.ts +0 -1
  240. package/src/control-plane/method-catalog-events.ts +0 -1
  241. package/src/control-plane/method-catalog-knowledge.ts +0 -1
  242. package/src/control-plane/method-catalog-media.ts +0 -1
  243. package/src/control-plane/method-catalog-runtime.ts +0 -1
  244. package/src/control-plane/method-catalog-shared.ts +0 -1
  245. package/src/control-plane/method-catalog.ts +0 -1
  246. package/src/control-plane/operator-contract-schemas-admin.ts +0 -1
  247. package/src/control-plane/operator-contract-schemas-channels.ts +0 -1
  248. package/src/control-plane/operator-contract-schemas-control.ts +0 -1
  249. package/src/control-plane/operator-contract-schemas-domains.ts +0 -1
  250. package/src/control-plane/operator-contract-schemas-knowledge.ts +0 -1
  251. package/src/control-plane/operator-contract-schemas-media.ts +0 -1
  252. package/src/control-plane/operator-contract-schemas-permissions.ts +0 -1
  253. package/src/control-plane/operator-contract-schemas-remote.ts +0 -1
  254. package/src/control-plane/operator-contract-schemas-runtime.ts +0 -1
  255. package/src/control-plane/operator-contract-schemas-shared.ts +0 -1
  256. package/src/control-plane/operator-contract-schemas-telemetry.ts +0 -1
  257. package/src/control-plane/operator-contract-schemas.ts +0 -1
  258. package/src/control-plane/operator-contract.ts +0 -165
  259. package/src/control-plane/session-broker.ts +0 -780
  260. package/src/core/compaction-sections.ts +0 -492
  261. package/src/core/compaction-types.ts +0 -147
  262. package/src/core/context-compaction.ts +0 -542
  263. package/src/core/conversation-compaction.ts +0 -68
  264. package/src/core/conversation-diff.ts +0 -55
  265. package/src/core/conversation-utils.ts +0 -72
  266. package/src/core/event-replay.ts +0 -287
  267. package/src/core/orchestrator-context-runtime.ts +0 -407
  268. package/src/core/orchestrator-follow-up-runtime.ts +0 -134
  269. package/src/core/orchestrator-runtime.ts +0 -132
  270. package/src/core/orchestrator-tool-runtime.ts +0 -468
  271. package/src/core/orchestrator-turn-helpers.ts +0 -355
  272. package/src/core/orchestrator-turn-loop.ts +0 -443
  273. package/src/core/plan-command-handler.ts +0 -169
  274. package/src/core/transcript-events/classify.ts +0 -95
  275. package/src/core/transcript-events/index.ts +0 -15
  276. package/src/daemon/control-plane.ts +0 -522
  277. package/src/daemon/facade-composition.ts +0 -398
  278. package/src/daemon/facade.ts +0 -638
  279. package/src/daemon/helpers.ts +0 -74
  280. package/src/daemon/http/router-route-contexts.ts +0 -370
  281. package/src/daemon/http/router.ts +0 -531
  282. package/src/daemon/http-listener.ts +0 -301
  283. package/src/daemon/index.ts +0 -1
  284. package/src/daemon/server.ts +0 -1
  285. package/src/daemon/service-manager.ts +0 -413
  286. package/src/daemon/surface-actions.ts +0 -183
  287. package/src/daemon/surface-delivery.ts +0 -530
  288. package/src/daemon/surface-policy.ts +0 -60
  289. package/src/daemon/transport-events.ts +0 -110
  290. package/src/daemon/types.ts +0 -191
  291. package/src/export/markdown.ts +0 -213
  292. package/src/export/session-export.ts +0 -1
  293. package/src/git/index.ts +0 -1
  294. package/src/git/service.ts +0 -414
  295. package/src/hooks/chain-engine.ts +0 -414
  296. package/src/hooks/dispatcher.ts +0 -414
  297. package/src/hooks/hook-api.ts +0 -170
  298. package/src/hooks/index.ts +0 -48
  299. package/src/hooks/runners/agent.ts +0 -93
  300. package/src/hooks/runners/prompt.ts +0 -69
  301. package/src/hooks/workbench.ts +0 -360
  302. package/src/integrations/index.ts +0 -42
  303. package/src/integrations/notifier.ts +0 -206
  304. package/src/integrations/webhooks.ts +0 -1
  305. package/src/knowledge/consolidation.ts +0 -346
  306. package/src/knowledge/graphql.ts +0 -324
  307. package/src/knowledge/index.ts +0 -60
  308. package/src/knowledge/ingest-compile.ts +0 -386
  309. package/src/knowledge/ingest-context.ts +0 -18
  310. package/src/knowledge/ingest-inputs.ts +0 -387
  311. package/src/knowledge/ingest.ts +0 -1
  312. package/src/knowledge/internal.ts +0 -257
  313. package/src/knowledge/knowledge-api.ts +0 -432
  314. package/src/knowledge/lint.ts +0 -121
  315. package/src/knowledge/memory-sync.ts +0 -62
  316. package/src/knowledge/packet.ts +0 -370
  317. package/src/knowledge/scheduling.ts +0 -283
  318. package/src/knowledge/service.ts +0 -715
  319. package/src/mcp/client.ts +0 -383
  320. package/src/mcp/index.ts +0 -12
  321. package/src/mcp/mcp-api.ts +0 -90
  322. package/src/mcp/registry.ts +0 -1
  323. package/src/media/builtin-image-understanding.ts +0 -303
  324. package/src/media/builtin-providers.ts +0 -26
  325. package/src/media/index.ts +0 -18
  326. package/src/multimodal/index.ts +0 -13
  327. package/src/multimodal/service.ts +0 -492
  328. package/src/permissions/briefs/build.ts +0 -88
  329. package/src/permissions/manager.ts +0 -1
  330. package/src/plugins/api.ts +0 -383
  331. package/src/plugins/manager.ts +0 -481
  332. package/src/profiles/shape.ts +0 -58
  333. package/src/providers/amazon-bedrock-mantle.ts +0 -50
  334. package/src/providers/amazon-bedrock.ts +0 -61
  335. package/src/providers/anthropic-compat.ts +0 -373
  336. package/src/providers/anthropic-sdk-provider.ts +0 -230
  337. package/src/providers/anthropic-vertex.ts +0 -59
  338. package/src/providers/anthropic.ts +0 -469
  339. package/src/providers/auto-register.ts +0 -417
  340. package/src/providers/builtin-catalog.ts +0 -326
  341. package/src/providers/builtin-registry.ts +0 -575
  342. package/src/providers/cache-planner.ts +0 -258
  343. package/src/providers/capabilities.ts +0 -1
  344. package/src/providers/custom-loader.ts +0 -425
  345. package/src/providers/discovered-compat.ts +0 -7
  346. package/src/providers/discovered-factory.ts +0 -61
  347. package/src/providers/discovered-traits.ts +0 -138
  348. package/src/providers/gemini.ts +0 -462
  349. package/src/providers/github-copilot.ts +0 -254
  350. package/src/providers/index.ts +0 -1
  351. package/src/providers/interface.ts +0 -185
  352. package/src/providers/llama-cpp.ts +0 -402
  353. package/src/providers/lm-studio-helpers.ts +0 -367
  354. package/src/providers/lm-studio.ts +0 -484
  355. package/src/providers/model-catalog-cache.ts +0 -221
  356. package/src/providers/model-catalog-notifications.ts +0 -97
  357. package/src/providers/model-catalog-synthetic.ts +0 -202
  358. package/src/providers/model-catalog.ts +0 -211
  359. package/src/providers/model-limits.ts +0 -1
  360. package/src/providers/ollama.ts +0 -469
  361. package/src/providers/openai-codex.ts +0 -472
  362. package/src/providers/openai-compat.ts +0 -615
  363. package/src/providers/openai.ts +0 -231
  364. package/src/providers/optimizer.ts +0 -1
  365. package/src/providers/provider-api.ts +0 -1
  366. package/src/providers/registry-helpers.ts +0 -34
  367. package/src/providers/registry-models.ts +0 -77
  368. package/src/providers/registry-types.ts +0 -67
  369. package/src/providers/registry.ts +0 -1
  370. package/src/providers/runtime-metadata.ts +0 -149
  371. package/src/providers/runtime-snapshot.ts +0 -130
  372. package/src/providers/synthetic.ts +0 -561
  373. package/src/providers/tier-prompts.ts +0 -84
  374. package/src/providers/tool-formats.ts +0 -414
  375. package/src/runtime/auth/inspection.ts +0 -125
  376. package/src/runtime/bootstrap-background.ts +0 -157
  377. package/src/runtime/bootstrap-helpers.ts +0 -88
  378. package/src/runtime/bootstrap-runtime-events.ts +0 -254
  379. package/src/runtime/bootstrap-services.ts +0 -197
  380. package/src/runtime/compaction/index.ts +0 -1
  381. package/src/runtime/compaction/lifecycle.ts +0 -1
  382. package/src/runtime/compaction/manager.ts +0 -474
  383. package/src/runtime/compaction/quality-score.ts +0 -1
  384. package/src/runtime/compaction/resume-repair.ts +0 -1
  385. package/src/runtime/compaction/strategies/autocompact.ts +0 -1
  386. package/src/runtime/compaction/strategies/boundary-commit.ts +0 -1
  387. package/src/runtime/compaction/strategies/collapse.ts +0 -1
  388. package/src/runtime/compaction/strategies/index.ts +0 -1
  389. package/src/runtime/compaction/strategies/microcompact.ts +0 -1
  390. package/src/runtime/compaction/strategies/reactive.ts +0 -1
  391. package/src/runtime/compaction/types.ts +0 -1
  392. package/src/runtime/ecosystem/recommendations.ts +0 -117
  393. package/src/runtime/emitters/agents.ts +0 -96
  394. package/src/runtime/emitters/automation.ts +0 -112
  395. package/src/runtime/emitters/communication.ts +0 -53
  396. package/src/runtime/emitters/compaction.ts +0 -161
  397. package/src/runtime/emitters/control-plane.ts +0 -65
  398. package/src/runtime/emitters/deliveries.ts +0 -65
  399. package/src/runtime/emitters/forensics.ts +0 -17
  400. package/src/runtime/emitters/index.ts +0 -59
  401. package/src/runtime/emitters/knowledge.ts +0 -129
  402. package/src/runtime/emitters/mcp.ts +0 -95
  403. package/src/runtime/emitters/ops.ts +0 -163
  404. package/src/runtime/emitters/orchestration.ts +0 -87
  405. package/src/runtime/emitters/permissions.ts +0 -98
  406. package/src/runtime/emitters/planner.ts +0 -23
  407. package/src/runtime/emitters/plugins.ts +0 -78
  408. package/src/runtime/emitters/providers.ts +0 -30
  409. package/src/runtime/emitters/routes.ts +0 -57
  410. package/src/runtime/emitters/security.ts +0 -53
  411. package/src/runtime/emitters/session.ts +0 -93
  412. package/src/runtime/emitters/surfaces.ts +0 -57
  413. package/src/runtime/emitters/tasks.ts +0 -69
  414. package/src/runtime/emitters/tools.ts +0 -140
  415. package/src/runtime/emitters/transport.ts +0 -78
  416. package/src/runtime/emitters/turn.ts +0 -155
  417. package/src/runtime/emitters/ui.ts +0 -57
  418. package/src/runtime/emitters/watchers.ts +0 -57
  419. package/src/runtime/emitters/workflows.ts +0 -79
  420. package/src/runtime/eval/index.ts +0 -48
  421. package/src/runtime/eval/runner.ts +0 -163
  422. package/src/runtime/eval/suites.ts +0 -264
  423. package/src/runtime/events/domain-map.ts +0 -148
  424. package/src/runtime/events/index.ts +0 -1
  425. package/src/runtime/events/turn.ts +0 -1
  426. package/src/runtime/events/workflows.ts +0 -1
  427. package/src/runtime/forensics/collector.ts +0 -693
  428. package/src/runtime/forensics/index.ts +0 -23
  429. package/src/runtime/foundation-clients.ts +0 -78
  430. package/src/runtime/foundation-services.ts +0 -96
  431. package/src/runtime/guidance.ts +0 -183
  432. package/src/runtime/health/effect-handlers.ts +0 -189
  433. package/src/runtime/health/index.ts +0 -70
  434. package/src/runtime/health/wiring.ts +0 -115
  435. package/src/runtime/integration/helpers.ts +0 -640
  436. package/src/runtime/lifecycle.ts +0 -107
  437. package/src/runtime/mcp/index.ts +0 -68
  438. package/src/runtime/mcp/manager.ts +0 -513
  439. package/src/runtime/network/inbound.ts +0 -131
  440. package/src/runtime/network/index.ts +0 -30
  441. package/src/runtime/network/outbound.ts +0 -292
  442. package/src/runtime/network/shared.ts +0 -82
  443. package/src/runtime/operator-client.ts +0 -235
  444. package/src/runtime/ops/control-plane.ts +0 -363
  445. package/src/runtime/ops/index.ts +0 -122
  446. package/src/runtime/ops/playbooks/index.ts +0 -10
  447. package/src/runtime/ops/playbooks/session-unrecoverable.ts +0 -196
  448. package/src/runtime/ops/playbooks/stuck-turn.ts +0 -197
  449. package/src/runtime/ops/runtime-context.ts +0 -100
  450. package/src/runtime/ops-api.ts +0 -27
  451. package/src/runtime/orchestration/spawn-policy.ts +0 -83
  452. package/src/runtime/peer-client.ts +0 -404
  453. package/src/runtime/perf/index.ts +0 -57
  454. package/src/runtime/perf/slo-collector.ts +0 -375
  455. package/src/runtime/permissions/index.ts +0 -190
  456. package/src/runtime/permissions/policy-runtime.ts +0 -1
  457. package/src/runtime/permissions/preflight.ts +0 -101
  458. package/src/runtime/permissions/rule-suggestions.ts +0 -36
  459. package/src/runtime/plugins/hot-reload.ts +0 -221
  460. package/src/runtime/plugins/index.ts +0 -84
  461. package/src/runtime/plugins/lifecycle.ts +0 -95
  462. package/src/runtime/plugins/manager.ts +0 -474
  463. package/src/runtime/plugins/manifest.ts +0 -167
  464. package/src/runtime/plugins/quarantine.ts +0 -202
  465. package/src/runtime/plugins/trust.ts +0 -291
  466. package/src/runtime/plugins/types.ts +0 -205
  467. package/src/runtime/provider-accounts/registry.ts +0 -326
  468. package/src/runtime/remote/distributed-runtime-contract-schemas.ts +0 -386
  469. package/src/runtime/remote/index.ts +0 -488
  470. package/src/runtime/remote/runner-registry.ts +0 -438
  471. package/src/runtime/remote/supervisor.ts +0 -70
  472. package/src/runtime/runtime-hook-api.ts +0 -5
  473. package/src/runtime/runtime-knowledge-api.ts +0 -14
  474. package/src/runtime/runtime-mcp-api.ts +0 -5
  475. package/src/runtime/runtime-ops-api.ts +0 -86
  476. package/src/runtime/runtime-provider-api.ts +0 -18
  477. package/src/runtime/session-maintenance.ts +0 -188
  478. package/src/runtime/session-persistence.ts +0 -288
  479. package/src/runtime/session-return-context.ts +0 -195
  480. package/src/runtime/settings/control-plane-store.ts +0 -258
  481. package/src/runtime/settings/control-plane.ts +0 -599
  482. package/src/runtime/shell-command-extensions.ts +0 -54
  483. package/src/runtime/shell-command-ops.ts +0 -207
  484. package/src/runtime/shell-command-platform.ts +0 -47
  485. package/src/runtime/shell-command-services.ts +0 -143
  486. package/src/runtime/shell-command-workspace.ts +0 -31
  487. package/src/runtime/tasks/adapters/acp-adapter.ts +0 -211
  488. package/src/runtime/tasks/adapters/agent-adapter.ts +0 -208
  489. package/src/runtime/tasks/adapters/index.ts +0 -16
  490. package/src/runtime/tasks/adapters/process-adapter.ts +0 -214
  491. package/src/runtime/tasks/adapters/scheduler-adapter.ts +0 -193
  492. package/src/runtime/tasks/index.ts +0 -68
  493. package/src/runtime/tasks/manager.ts +0 -415
  494. package/src/runtime/telemetry/api-helpers.ts +0 -517
  495. package/src/runtime/telemetry/api.ts +0 -768
  496. package/src/runtime/telemetry/index.ts +0 -178
  497. package/src/runtime/telemetry/instrumentation/domain-bridge-agent-session.ts +0 -440
  498. package/src/runtime/telemetry/instrumentation/domain-bridge-plugin-mcp.ts +0 -200
  499. package/src/runtime/telemetry/instrumentation/domain-bridge-shared.ts +0 -18
  500. package/src/runtime/telemetry/instrumentation/domain-bridge-transport-task.ts +0 -204
  501. package/src/runtime/telemetry/instrumentation/domain-bridge.ts +0 -125
  502. package/src/runtime/telemetry/instrumentation/index.ts +0 -67
  503. package/src/runtime/tools/context.ts +0 -114
  504. package/src/runtime/tools/index.ts +0 -46
  505. package/src/runtime/tools/phased-executor.ts +0 -448
  506. package/src/runtime/tools/phases/budget.ts +0 -130
  507. package/src/runtime/tools/phases/execute.ts +0 -69
  508. package/src/runtime/tools/phases/index.ts +0 -13
  509. package/src/runtime/tools/phases/map-output.ts +0 -98
  510. package/src/runtime/tools/phases/permission.ts +0 -133
  511. package/src/runtime/tools/phases/posthook.ts +0 -57
  512. package/src/runtime/tools/phases/prehook.ts +0 -68
  513. package/src/runtime/tools/phases/validate.ts +0 -53
  514. package/src/runtime/transports/direct.ts +0 -73
  515. package/src/runtime/transports/http-helpers.ts +0 -218
  516. package/src/runtime/transports/http-types.ts +0 -364
  517. package/src/runtime/transports/http.ts +0 -629
  518. package/src/runtime/transports/realtime.ts +0 -50
  519. package/src/runtime/transports/remote-events.ts +0 -16
  520. package/src/runtime/transports/shared.ts +0 -39
  521. package/src/runtime/transports/ui-runtime-events.ts +0 -35
  522. package/src/runtime/ui-read-models-core.ts +0 -95
  523. package/src/runtime/ui-read-models-operations.ts +0 -203
  524. package/src/runtime/worktree/registry.ts +0 -252
  525. package/src/sessions/manager.ts +0 -14
  526. package/src/state/file-watcher.ts +0 -294
  527. package/src/state/index.ts +0 -56
  528. package/src/state/knowledge-injection.ts +0 -214
  529. package/src/state/memory-embedding-http.ts +0 -642
  530. package/src/state/memory-embeddings.ts +0 -312
  531. package/src/state/memory-ingest.ts +0 -132
  532. package/src/state/memory-registry.ts +0 -111
  533. package/src/state/memory-store-helpers.ts +0 -160
  534. package/src/state/memory-store.ts +0 -728
  535. package/src/state/memory-vector-store.ts +0 -418
  536. package/src/templates/manager.ts +0 -187
  537. package/src/tools/agent/index.ts +0 -610
  538. package/src/tools/agent/manager.ts +0 -476
  539. package/src/tools/analyze/git-modes.ts +0 -380
  540. package/src/tools/analyze/index.ts +0 -128
  541. package/src/tools/channel/agent-tools.ts +0 -16
  542. package/src/tools/channel/index.ts +0 -268
  543. package/src/tools/control/index.ts +0 -90
  544. package/src/tools/edit/core.ts +0 -619
  545. package/src/tools/edit/index.ts +0 -4
  546. package/src/tools/edit/phased.ts +0 -33
  547. package/src/tools/fetch/index.ts +0 -3
  548. package/src/tools/fetch/phased.ts +0 -34
  549. package/src/tools/fetch/runtime.ts +0 -499
  550. package/src/tools/mcp/index.ts +0 -190
  551. package/src/tools/remote-trigger/index.ts +0 -130
  552. package/src/tools/shared/auto-heal.ts +0 -282
  553. package/src/tools/state/index.ts +0 -688
  554. package/src/tools/web-search/index.ts +0 -38
  555. package/src/tools/write/index.ts +0 -604
  556. package/src/tools/write/phased.ts +0 -41
  557. package/src/types/generated/foundation-client-types.ts +0 -22
  558. package/src/watchers/index.ts +0 -11
  559. package/src/watchers/registry.ts +0 -517
  560. package/src/web-search/index.ts +0 -26
  561. package/src/web-search/provider-registry.ts +0 -64
  562. package/src/web-search/providers/brave.ts +0 -100
  563. package/src/web-search/providers/duckduckgo.ts +0 -270
  564. package/src/web-search/providers/exa.ts +0 -77
  565. package/src/web-search/providers/firecrawl.ts +0 -90
  566. package/src/web-search/providers/perplexity.ts +0 -86
  567. package/src/web-search/providers/searxng.ts +0 -88
  568. package/src/web-search/providers/shared.ts +0 -249
  569. package/src/web-search/providers/tavily.ts +0 -90
  570. package/src/web-search/service.ts +0 -142
@@ -1,61 +0,0 @@
1
- import type { DiscoveredServer } from '@pellux/goodvibes-sdk/platform/discovery/scanner';
2
- import type { LLMProvider } from '@pellux/goodvibes-sdk/platform/providers/interface';
3
- import { getDiscoveredTraits } from '@pellux/goodvibes-sdk/platform/providers/discovered-traits';
4
- import { LocalAIProvider, TGIProvider, VLLMProvider } from '@pellux/goodvibes-sdk/platform/providers/discovered-compat';
5
- import { LlamaCppProvider } from '@pellux/goodvibes-sdk/platform/providers/llama-cpp';
6
- import { LMStudioProvider } from '@pellux/goodvibes-sdk/platform/providers/lm-studio';
7
- import { OpenAICompatProvider } from '@pellux/goodvibes-sdk/platform/providers/openai-compat';
8
- import { OllamaProvider } from '@pellux/goodvibes-sdk/platform/providers/ollama';
9
-
10
- export function createDiscoveredProvider(server: DiscoveredServer): LLMProvider {
11
- const traits = getDiscoveredTraits(server.serverType);
12
- const common = {
13
- name: server.name,
14
- baseURL: server.baseURL,
15
- apiKey: '',
16
- defaultModel: server.models[0]!,
17
- models: server.models,
18
- capabilities: traits.providerCapabilities,
19
- };
20
-
21
- switch (traits.adapter) {
22
- case 'lm-studio':
23
- return new LMStudioProvider(common);
24
- case 'ollama':
25
- return new OllamaProvider({
26
- ...common,
27
- reasoningFormat: traits.reasoningFormat,
28
- });
29
- case 'vllm':
30
- return new VLLMProvider({
31
- ...common,
32
- reasoningFormat: traits.reasoningFormat,
33
- });
34
- case 'llamacpp':
35
- return new LlamaCppProvider({
36
- ...common,
37
- reasoningFormat: traits.reasoningFormat,
38
- });
39
- case 'tgi':
40
- return new TGIProvider({
41
- ...common,
42
- reasoningFormat: traits.reasoningFormat,
43
- });
44
- case 'localai':
45
- return new LocalAIProvider({
46
- ...common,
47
- reasoningFormat: traits.reasoningFormat,
48
- });
49
- default:
50
- return new OpenAICompatProvider({
51
- ...common,
52
- reasoningFormat: traits.reasoningFormat,
53
- });
54
- }
55
- }
56
-
57
- export function getDiscoveredReasoningFormat(
58
- serverType: DiscoveredServer['serverType'],
59
- ): 'llamacpp' | 'none' {
60
- return getDiscoveredTraits(serverType).reasoningFormat;
61
- }
@@ -1,138 +0,0 @@
1
- import type { ServerType } from '@pellux/goodvibes-sdk/platform/discovery/scanner';
2
- import type { ProviderCapability } from '@pellux/goodvibes-sdk/platform/providers/capabilities';
3
-
4
- export interface DiscoveredServerTraits {
5
- readonly adapter:
6
- | 'lm-studio'
7
- | 'ollama'
8
- | 'vllm'
9
- | 'llamacpp'
10
- | 'tgi'
11
- | 'localai'
12
- | 'compat';
13
- readonly reasoningFormat: 'llamacpp' | 'none';
14
- readonly providerCapabilities?: Partial<ProviderCapability>;
15
- readonly modelCapabilities: {
16
- toolCalling: boolean;
17
- codeEditing: boolean;
18
- reasoning: boolean;
19
- multimodal: boolean;
20
- };
21
- readonly reasoningEffort?: string[];
22
- }
23
-
24
- const DEFAULT_MODEL_CAPABILITIES = {
25
- toolCalling: true,
26
- codeEditing: true,
27
- reasoning: false,
28
- multimodal: false,
29
- } as const;
30
-
31
- const HIGH_TIMEOUT_MS = 300_000;
32
-
33
- export function getDiscoveredTraits(serverType: ServerType): DiscoveredServerTraits {
34
- switch (serverType) {
35
- case 'lm-studio':
36
- return {
37
- adapter: 'lm-studio',
38
- reasoningFormat: 'none',
39
- providerCapabilities: {
40
- streaming: true,
41
- toolCalling: true,
42
- parallelTools: true,
43
- jsonMode: false,
44
- reasoningControls: true,
45
- timeoutMs: HIGH_TIMEOUT_MS,
46
- },
47
- modelCapabilities: {
48
- ...DEFAULT_MODEL_CAPABILITIES,
49
- reasoning: true,
50
- },
51
- reasoningEffort: ['instant', 'low', 'medium', 'high'],
52
- };
53
- case 'ollama':
54
- return {
55
- adapter: 'ollama',
56
- reasoningFormat: 'llamacpp',
57
- providerCapabilities: {
58
- streaming: true,
59
- toolCalling: true,
60
- parallelTools: false,
61
- jsonMode: true,
62
- reasoningControls: true,
63
- timeoutMs: HIGH_TIMEOUT_MS,
64
- },
65
- modelCapabilities: {
66
- ...DEFAULT_MODEL_CAPABILITIES,
67
- reasoning: true,
68
- },
69
- reasoningEffort: ['instant', 'low', 'medium', 'high'],
70
- };
71
- case 'vllm':
72
- return {
73
- adapter: 'vllm',
74
- reasoningFormat: 'none',
75
- providerCapabilities: {
76
- streaming: true,
77
- toolCalling: true,
78
- parallelTools: false,
79
- jsonMode: true,
80
- reasoningControls: false,
81
- timeoutMs: HIGH_TIMEOUT_MS,
82
- },
83
- modelCapabilities: DEFAULT_MODEL_CAPABILITIES,
84
- };
85
- case 'llamacpp':
86
- return {
87
- adapter: 'llamacpp',
88
- reasoningFormat: 'llamacpp',
89
- providerCapabilities: {
90
- streaming: true,
91
- toolCalling: true,
92
- parallelTools: false,
93
- jsonMode: true,
94
- reasoningControls: true,
95
- timeoutMs: HIGH_TIMEOUT_MS,
96
- },
97
- modelCapabilities: {
98
- ...DEFAULT_MODEL_CAPABILITIES,
99
- reasoning: true,
100
- },
101
- reasoningEffort: ['instant', 'low', 'medium', 'high'],
102
- };
103
- case 'tgi':
104
- return {
105
- adapter: 'tgi',
106
- reasoningFormat: 'none',
107
- providerCapabilities: {
108
- streaming: true,
109
- toolCalling: true,
110
- parallelTools: false,
111
- jsonMode: true,
112
- reasoningControls: false,
113
- timeoutMs: HIGH_TIMEOUT_MS,
114
- },
115
- modelCapabilities: DEFAULT_MODEL_CAPABILITIES,
116
- };
117
- case 'localai':
118
- return {
119
- adapter: 'localai',
120
- reasoningFormat: 'none',
121
- providerCapabilities: {
122
- streaming: true,
123
- toolCalling: true,
124
- parallelTools: false,
125
- jsonMode: true,
126
- reasoningControls: false,
127
- timeoutMs: HIGH_TIMEOUT_MS,
128
- },
129
- modelCapabilities: DEFAULT_MODEL_CAPABILITIES,
130
- };
131
- default:
132
- return {
133
- adapter: 'compat',
134
- reasoningFormat: 'none',
135
- modelCapabilities: DEFAULT_MODEL_CAPABILITIES,
136
- };
137
- }
138
- }
@@ -1,462 +0,0 @@
1
- import type {
2
- LLMProvider,
3
- ChatRequest,
4
- ChatResponse,
5
- ProviderEmbeddingRequest,
6
- ProviderEmbeddingResult,
7
- ProviderRuntimeMetadata,
8
- ProviderRuntimeMetadataDeps,
9
- } from '@pellux/goodvibes-sdk/platform/providers/interface';
10
- import { REASONING_BUDGET_MAP } from '@pellux/goodvibes-sdk/platform/providers/interface';
11
- import { ProviderError } from '@pellux/goodvibes-sdk/platform/types/errors';
12
- import { withRetry } from '@pellux/goodvibes-sdk/platform/utils/retry';
13
- import { logger } from '@pellux/goodvibes-sdk/platform/utils/logger';
14
- import {
15
- toGeminiFunctionDeclarations,
16
- toGeminiContents,
17
- fromGeminiParts,
18
- } from '@pellux/goodvibes-sdk/platform/providers/tool-formats';
19
- import type { GeminiPart } from '@pellux/goodvibes-sdk/platform/providers/tool-formats';
20
- import type { CacheHitTracker } from '@pellux/goodvibes-sdk/platform/providers/cache-strategy';
21
- import { summarizeError, toProviderError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
22
-
23
- const GEMINI_API_BASE = 'https://generativelanguage.googleapis.com/v1beta';
24
- const GEMINI_CACHE_TTL_SECONDS = 3600;
25
- const NOOP_CACHE_HIT_TRACKER: Pick<CacheHitTracker, 'recordTurn'> = {
26
- recordTurn: () => {},
27
- };
28
-
29
- interface GeminiCandidate {
30
- content: { parts: GeminiPart[]; role: string };
31
- finishReason: string;
32
- }
33
-
34
- interface GeminiResponseBody {
35
- candidates?: GeminiCandidate[];
36
- usageMetadata?: {
37
- promptTokenCount?: number;
38
- candidatesTokenCount?: number;
39
- cachedContentTokenCount?: number;
40
- };
41
- }
42
-
43
- /**
44
- * GeminiProvider — calls the Gemini generateContent API directly via fetch.
45
- * Tools are `functionDeclarations` inside a `tools` array.
46
- * Tool calls come as `functionCall` parts; results as `functionResponse` parts.
47
- * Uses streamGenerateContent for real-time token delivery when onDelta is provided.
48
- */
49
- export class GeminiProvider implements LLMProvider {
50
- readonly name = 'gemini';
51
- /** Maps function call name → thoughtSignature for the current turn. */
52
- private thoughtSignatures = new Map<string, string>();
53
- readonly models: string[] = [];
54
-
55
- private readonly apiKey: string;
56
- private readonly embeddingModel = 'gemini-embedding-001';
57
- private readonly cacheHitTracker: Pick<CacheHitTracker, 'recordTurn'>;
58
-
59
- /** Active cached content resource name (e.g., "cachedContents/abc123") */
60
- private cachedContentName: string | null = null;
61
- /** Hash of the content that was cached (systemPrompt + tools + model) */
62
- private cachedContentHash: string | null = null;
63
- /** When the cache expires (epoch ms) */
64
- private cachedContentExpiry: number = 0;
65
- /** Hashes known to be below the 32K cache minimum — skip API call */
66
- private uncacheableHashes = new Set<string>();
67
-
68
- constructor(apiKey: string, cacheHitTracker: Pick<CacheHitTracker, 'recordTurn'> = NOOP_CACHE_HIT_TRACKER) {
69
- this.apiKey = apiKey;
70
- this.cacheHitTracker = cacheHitTracker;
71
- }
72
-
73
- private computeCacheHash(
74
- systemPrompt: string | undefined,
75
- tools: import('./interface.ts').ChatRequest['tools'],
76
- model: string,
77
- ): string {
78
- const raw = (systemPrompt ?? '') + JSON.stringify(tools ?? []) + model;
79
- const hasher = new Bun.CryptoHasher('sha256');
80
- hasher.update(raw);
81
- return hasher.digest('hex');
82
- }
83
-
84
- private async ensureCachedContent(
85
- systemPrompt: string | undefined,
86
- tools: import('./interface.ts').ChatRequest['tools'],
87
- model: string,
88
- ): Promise<string | null> {
89
- // Skip if no system prompt and no tools
90
- if (!systemPrompt && (!tools || tools.length === 0)) return null;
91
-
92
- const hash = this.computeCacheHash(systemPrompt, tools, model);
93
-
94
- // Skip if previously determined to be below 32K threshold
95
- if (this.uncacheableHashes.has(hash)) return null;
96
-
97
- // Reuse existing cache if hash matches and not expired (with 60s buffer)
98
- if (
99
- this.cachedContentName &&
100
- this.cachedContentHash === hash &&
101
- this.cachedContentExpiry > Date.now() + 60_000
102
- ) {
103
- return this.cachedContentName;
104
- }
105
-
106
- // Estimate tokens — skip if below 28K (conservative buffer below 32K minimum)
107
- const estimatedChars = (systemPrompt?.length ?? 0) + JSON.stringify(tools ?? []).length;
108
- if (estimatedChars / 3 < 28_000) {
109
- if (this.uncacheableHashes.size >= 50) this.uncacheableHashes.clear();
110
- this.uncacheableHashes.add(hash);
111
- logger.debug('[Gemini] Content below 32K cache threshold, skipping cache', {
112
- estimatedTokens: Math.round(estimatedChars / 3),
113
- });
114
- return null;
115
- }
116
-
117
- // Delete old cache if hash changed (fire-and-forget)
118
- if (this.cachedContentName && this.cachedContentHash !== hash) {
119
- const oldName = this.cachedContentName;
120
- fetch(`${GEMINI_API_BASE}/${oldName}`, {
121
- method: 'DELETE',
122
- headers: { 'x-goog-api-key': this.apiKey },
123
- }).catch(err => logger.warn('[Gemini] Failed to delete old cache', { error: summarizeError(err) }));
124
- }
125
-
126
- // Create new cached content
127
- try {
128
- const cacheBody: Record<string, unknown> = {
129
- model: `models/${model}`,
130
- ttl: `${GEMINI_CACHE_TTL_SECONDS}s`,
131
- };
132
-
133
- if (systemPrompt) {
134
- cacheBody['systemInstruction'] = { parts: [{ text: systemPrompt }] };
135
- }
136
-
137
- if (tools && tools.length > 0) {
138
- cacheBody['tools'] = [{ functionDeclarations: toGeminiFunctionDeclarations(tools) }];
139
- }
140
-
141
- const res = await fetch(`${GEMINI_API_BASE}/cachedContents`, {
142
- method: 'POST',
143
- headers: {
144
- 'Content-Type': 'application/json',
145
- 'x-goog-api-key': this.apiKey,
146
- },
147
- body: JSON.stringify(cacheBody),
148
- });
149
-
150
- if (!res.ok) {
151
- const text = await res.text().catch(() => '');
152
- if (text.includes('too few tokens') || text.includes('minimum')) {
153
- if (this.uncacheableHashes.size >= 50) this.uncacheableHashes.clear();
154
- this.uncacheableHashes.add(hash);
155
- logger.debug('[Gemini] Content below cache minimum', { status: res.status, error: text.slice(0, 200) });
156
- } else {
157
- logger.debug('[Gemini] Cache creation failed', { status: res.status, error: text.slice(0, 200) });
158
- }
159
- return null;
160
- }
161
-
162
- const data = await res.json() as { name: string; expireTime: string };
163
- this.cachedContentName = data.name;
164
- this.cachedContentHash = hash;
165
- this.cachedContentExpiry = new Date(data.expireTime).getTime();
166
-
167
- logger.info(`[Gemini] Created cache: ${data.name} (expires ${data.expireTime})`);
168
- return data.name;
169
- } catch (err) {
170
- logger.debug('[Gemini] Cache creation error', { error: summarizeError(err) });
171
- return null;
172
- }
173
- }
174
-
175
- async chat(params: ChatRequest): Promise<ChatResponse> {
176
- const { messages, tools, model, maxTokens, signal, systemPrompt, onDelta, reasoningEffort } = params;
177
-
178
- return withRetry(async () => {
179
- const { contents, systemInstruction } = toGeminiContents(messages, systemPrompt);
180
-
181
- // Inject thoughtSignatures into both model functionCall parts and user functionResponse parts
182
- // (Gemini thinking models require the signature on both sides of the round-trip)
183
- for (const c of contents) {
184
- for (const part of c.parts) {
185
- const p = part as Record<string, unknown>;
186
- if (p.functionCall) {
187
- const fc = p.functionCall as { name: string };
188
- const sig = this.thoughtSignatures.get(fc.name);
189
- if (sig) p.thoughtSignature = sig;
190
- }
191
- if (p.functionResponse) {
192
- const fr = p.functionResponse as { name: string };
193
- const sig = this.thoughtSignatures.get(fr.name);
194
- if (sig) p.thoughtSignature = sig;
195
- }
196
- }
197
- }
198
-
199
- const body: Record<string, unknown> = { contents };
200
-
201
- const cachedName = await this.ensureCachedContent(systemPrompt, tools, model);
202
-
203
- if (cachedName) {
204
- // Cached content already contains systemInstruction and tools — do NOT resend them
205
- body['cachedContent'] = cachedName;
206
- } else {
207
- if (systemInstruction) {
208
- body['systemInstruction'] = systemInstruction;
209
- }
210
-
211
- if (tools && tools.length > 0) {
212
- body['tools'] = [{
213
- functionDeclarations: toGeminiFunctionDeclarations(tools),
214
- }];
215
- }
216
- }
217
-
218
- if (maxTokens) {
219
- body['generationConfig'] = { maxOutputTokens: maxTokens };
220
- }
221
-
222
- if (reasoningEffort) {
223
- const budget = REASONING_BUDGET_MAP[reasoningEffort];
224
- if (budget !== undefined) {
225
- body['generationConfig'] = {
226
- ...(body['generationConfig'] as Record<string, unknown> ?? {}),
227
- thinking_config: { thinking_budget: budget },
228
- };
229
- }
230
- }
231
-
232
- // Always use streaming endpoint; parse NDJSON chunks
233
- const url = `${GEMINI_API_BASE}/models/${model}:streamGenerateContent?alt=sse`;
234
-
235
- let res: Response;
236
- try {
237
- res = await fetch(url, {
238
- method: 'POST',
239
- headers: {
240
- 'Content-Type': 'application/json',
241
- 'x-goog-api-key': this.apiKey,
242
- },
243
- body: JSON.stringify(body),
244
- signal,
245
- });
246
- } catch (err: unknown) {
247
- throw toProviderError(err, {
248
- provider: this.name,
249
- operation: 'chat',
250
- phase: 'request',
251
- });
252
- }
253
-
254
- if (!res.ok) {
255
- const text = await res.text().catch(() => 'unknown error');
256
- throw new ProviderError(`Gemini API error ${res.status}: ${text}`, {
257
- statusCode: res.status,
258
- provider: this.name,
259
- operation: 'chat',
260
- phase: 'request',
261
- });
262
- }
263
-
264
- // Accumulate state from streaming chunks
265
- const allParts: GeminiPart[] = [];
266
- let inputTokens = 0;
267
- let outputTokens = 0;
268
- let cacheReadTokens = 0;
269
- let lastFinishReason = '';
270
- let streamedText = '';
271
-
272
- const reader = res.body?.getReader();
273
- if (!reader) {
274
- throw new ProviderError('Gemini chat returned no response body.', {
275
- statusCode: 502,
276
- provider: this.name,
277
- operation: 'chat',
278
- phase: 'response',
279
- });
280
- }
281
-
282
- const decoder = new TextDecoder();
283
- let buffer = '';
284
-
285
- try {
286
- while (true) {
287
- const { done, value } = await reader.read();
288
- if (done) break;
289
-
290
- buffer += decoder.decode(value, { stream: true });
291
- const lines = buffer.split('\n');
292
- buffer = lines.pop() ?? '';
293
-
294
- for (const line of lines) {
295
- if (!line.startsWith('data: ')) continue;
296
- const data = line.slice(6).trim();
297
- if (!data || data === '[DONE]') continue;
298
-
299
- let chunk: GeminiResponseBody;
300
- try {
301
- chunk = JSON.parse(data) as GeminiResponseBody;
302
- } catch {
303
- logger.debug('Gemini SSE: failed to parse JSON chunk', { data });
304
- continue;
305
- }
306
-
307
- const candidate = chunk.candidates?.[0];
308
- if (candidate) {
309
- const parts = candidate.content?.parts ?? [];
310
- for (const part of parts) {
311
- allParts.push(part);
312
- if (part.text && onDelta) {
313
- streamedText += part.text;
314
- onDelta({ content: part.text });
315
- }
316
- if (part.functionCall) {
317
- // Capture thoughtSignature if present (Gemini thinking models)
318
- if ((part as Record<string, unknown>).thoughtSignature) {
319
- this.thoughtSignatures.set(part.functionCall.name, (part as Record<string, unknown>).thoughtSignature as string);
320
- }
321
- if (onDelta) {
322
- onDelta({ toolCalls: [{ index: 0, name: part.functionCall.name, arguments: JSON.stringify(part.functionCall.args) }] });
323
- }
324
- }
325
- }
326
- if (candidate.finishReason) {
327
- lastFinishReason = candidate.finishReason;
328
- }
329
- }
330
-
331
- if (chunk.usageMetadata) {
332
- inputTokens = chunk.usageMetadata.promptTokenCount ?? inputTokens;
333
- outputTokens = chunk.usageMetadata.candidatesTokenCount ?? outputTokens;
334
- cacheReadTokens = chunk.usageMetadata.cachedContentTokenCount ?? cacheReadTokens;
335
- }
336
- }
337
- }
338
- } finally {
339
- reader.releaseLock();
340
- }
341
-
342
- // Use streamed text directly if available (avoids re-parsing duplicated text parts)
343
- const { text: parsedText, toolCalls } = fromGeminiParts(allParts);
344
- // Prefer streamedText for content; fall back to parsed if no streaming happened
345
- const text = streamedText || parsedText;
346
-
347
- let stopReason: ChatResponse['stopReason'] = 'end';
348
- if (lastFinishReason === 'MAX_TOKENS') stopReason = 'max_tokens';
349
- else if (toolCalls.length > 0) stopReason = 'tool_use';
350
-
351
- // Clear old signatures — new ones were captured from this response's functionCall parts
352
- // (kept across calls within a tool-use loop, cleared when no new functionCalls arrive)
353
- if (toolCalls.length === 0) {
354
- this.thoughtSignatures.clear();
355
- }
356
-
357
- this.cacheHitTracker.recordTurn({
358
- inputTokens,
359
- cacheReadTokens,
360
- });
361
-
362
- return {
363
- content: text,
364
- toolCalls,
365
- usage: {
366
- inputTokens,
367
- outputTokens,
368
- ...(cacheReadTokens > 0 ? { cacheReadTokens } : {}),
369
- // cacheWriteTokens is omitted: Gemini does not charge separately for cache writes
370
- },
371
- stopReason,
372
- };
373
- });
374
- }
375
-
376
- async embed(request: ProviderEmbeddingRequest): Promise<ProviderEmbeddingResult> {
377
- const model = request.model ?? this.embeddingModel;
378
- const body: Record<string, unknown> = {
379
- content: { parts: [{ text: request.text }] },
380
- };
381
- if (request.dimensions) {
382
- body['config'] = { outputDimensionality: request.dimensions };
383
- }
384
-
385
- let res: Response;
386
- try {
387
- res = await fetch(`${GEMINI_API_BASE}/models/${model}:embedContent`, {
388
- method: 'POST',
389
- headers: {
390
- 'Content-Type': 'application/json',
391
- 'x-goog-api-key': this.apiKey,
392
- },
393
- body: JSON.stringify(body),
394
- signal: request.signal,
395
- });
396
- } catch (error: unknown) {
397
- throw toProviderError(error, {
398
- provider: this.name,
399
- operation: 'embed',
400
- phase: 'request',
401
- });
402
- }
403
-
404
- if (!res.ok) {
405
- const text = await res.text().catch(() => 'unknown error');
406
- throw new ProviderError(`Gemini embeddings API error ${res.status}: ${text}`, {
407
- statusCode: res.status,
408
- provider: this.name,
409
- operation: 'embed',
410
- phase: 'request',
411
- });
412
- }
413
-
414
- const data = await res.json() as { embedding?: { values?: number[] } };
415
- const values = data.embedding?.values ?? [];
416
- return {
417
- vector: Float32Array.from(values),
418
- dimensions: values.length,
419
- modelId: model,
420
- metadata: {
421
- usage: request.usage,
422
- provider: this.name,
423
- },
424
- };
425
- }
426
-
427
- async describeRuntime(deps: ProviderRuntimeMetadataDeps): Promise<ProviderRuntimeMetadata> {
428
- const { buildStandardProviderAuthRoutes } = await import('./runtime-metadata.ts');
429
- const authRoutes = await buildStandardProviderAuthRoutes({
430
- providerId: 'gemini',
431
- apiKeyEnvVars: ['GEMINI_API_KEY', 'GOOGLE_API_KEY', 'GOOGLE_GEMINI_API_KEY'],
432
- serviceNames: ['gemini'],
433
- }, deps);
434
- return {
435
- auth: {
436
- mode: 'api-key',
437
- configured: Boolean(this.apiKey),
438
- detail: this.apiKey ? 'Gemini API key available' : 'Gemini API key is not configured',
439
- envVars: ['GEMINI_API_KEY', 'GOOGLE_API_KEY', 'GOOGLE_GEMINI_API_KEY'],
440
- routes: authRoutes,
441
- },
442
- models: {
443
- models: this.models,
444
- embeddingModel: this.embeddingModel,
445
- embeddingDimensions: 384,
446
- },
447
- usage: {
448
- streaming: true,
449
- toolCalling: true,
450
- parallelTools: true,
451
- notes: ['Embeddings use Gemini embedContent with reduced output dimensionality when requested.'],
452
- },
453
- policy: {
454
- local: false,
455
- streamProtocol: 'gemini-sse',
456
- reasoningMode: 'thinking_budget',
457
- supportedReasoningEfforts: ['instant', 'low', 'medium', 'high'],
458
- cacheStrategy: 'gemini-cached-content',
459
- },
460
- };
461
- }
462
- }