@clawpump/claw-agent 0.1.4 → 0.1.6

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 (1214) hide show
  1. package/agent/.dockerignore +67 -0
  2. package/agent/.envrc +1 -1
  3. package/agent/.gitattributes +8 -0
  4. package/agent/AGENTS.md +216 -4
  5. package/agent/CONTRIBUTING.md +46 -8
  6. package/agent/Dockerfile +78 -35
  7. package/agent/MANIFEST.in +2 -0
  8. package/agent/README.md +12 -5
  9. package/agent/README.ur-pk.md +261 -0
  10. package/agent/README.zh-CN.md +11 -8
  11. package/agent/SECURITY.md +5 -4
  12. package/agent/acp_adapter/provenance.py +127 -0
  13. package/agent/acp_adapter/server.py +112 -5
  14. package/agent/acp_adapter/session.py +1 -6
  15. package/agent/acp_registry/agent.json +2 -2
  16. package/agent/agent/account_usage.py +313 -1
  17. package/agent/agent/agent_init.py +140 -37
  18. package/agent/agent/agent_runtime_helpers.py +342 -83
  19. package/agent/agent/anthropic_adapter.py +320 -33
  20. package/agent/agent/auxiliary_client.py +525 -105
  21. package/agent/agent/background_review.py +157 -19
  22. package/agent/agent/bedrock_adapter.py +71 -6
  23. package/agent/agent/billing_view.py +295 -0
  24. package/agent/agent/chat_completion_helpers.py +229 -4
  25. package/agent/agent/codex_responses_adapter.py +86 -10
  26. package/agent/agent/codex_runtime.py +153 -1
  27. package/agent/agent/coding_context.py +738 -0
  28. package/agent/agent/context_compressor.py +392 -44
  29. package/agent/agent/context_references.py +34 -1
  30. package/agent/agent/conversation_compression.py +159 -22
  31. package/agent/agent/conversation_loop.py +643 -908
  32. package/agent/agent/copilot_acp_client.py +4 -11
  33. package/agent/agent/credential_pool.py +5 -3
  34. package/agent/agent/credits_tracker.py +794 -0
  35. package/agent/agent/curator.py +91 -18
  36. package/agent/agent/curator_backup.py +26 -10
  37. package/agent/agent/display.py +42 -1
  38. package/agent/agent/error_classifier.py +52 -3
  39. package/agent/agent/errors.py +3 -0
  40. package/agent/agent/file_safety.py +0 -17
  41. package/agent/agent/gemini_native_adapter.py +31 -1
  42. package/agent/agent/i18n.py +48 -4
  43. package/agent/agent/image_gen_provider.py +74 -5
  44. package/agent/agent/image_routing.py +29 -0
  45. package/agent/agent/insights.py +8 -17
  46. package/agent/agent/lsp/install.py +3 -0
  47. package/agent/agent/memory_manager.py +326 -31
  48. package/agent/agent/message_content.py +50 -0
  49. package/agent/agent/model_metadata.py +214 -3
  50. package/agent/agent/moonshot_schema.py +8 -1
  51. package/agent/agent/onboarding.py +60 -0
  52. package/agent/agent/prompt_builder.py +327 -37
  53. package/agent/agent/redact.py +1 -0
  54. package/agent/agent/runtime_cwd.py +34 -5
  55. package/agent/agent/secret_scope.py +205 -0
  56. package/agent/agent/secret_sources/bitwarden.py +34 -2
  57. package/agent/agent/skill_commands.py +90 -1
  58. package/agent/agent/skill_preprocessing.py +1 -0
  59. package/agent/agent/skill_utils.py +209 -36
  60. package/agent/agent/ssl_guard.py +94 -0
  61. package/agent/agent/system_prompt.py +133 -5
  62. package/agent/agent/tool_executor.py +496 -70
  63. package/agent/agent/transports/anthropic.py +83 -21
  64. package/agent/agent/transports/chat_completions.py +94 -5
  65. package/agent/agent/transports/codex.py +67 -2
  66. package/agent/agent/transports/codex_app_server.py +1 -0
  67. package/agent/agent/transports/codex_app_server_session.py +30 -0
  68. package/agent/agent/transports/types.py +12 -0
  69. package/agent/agent/turn_context.py +408 -0
  70. package/agent/agent/turn_finalizer.py +428 -0
  71. package/agent/agent/turn_retry_state.py +68 -0
  72. package/agent/agent/usage_pricing.py +3 -0
  73. package/agent/apps/bootstrap-installer/package.json +6 -5
  74. package/agent/apps/bootstrap-installer/src/routes/failure.tsx +12 -5
  75. package/agent/apps/bootstrap-installer/src/routes/progress.tsx +1 -3
  76. package/agent/apps/bootstrap-installer/src/store.ts +3 -2
  77. package/agent/apps/bootstrap-installer/src-tauri/src/bootstrap.rs +172 -7
  78. package/agent/apps/bootstrap-installer/src-tauri/src/events.rs +14 -1
  79. package/agent/apps/bootstrap-installer/src-tauri/src/paths.rs +29 -0
  80. package/agent/apps/bootstrap-installer/src-tauri/src/powershell.rs +93 -3
  81. package/agent/apps/bootstrap-installer/src-tauri/src/update.rs +695 -39
  82. package/agent/apps/bootstrap-installer/tsconfig.json +3 -4
  83. package/agent/apps/desktop/DESIGN.md +167 -0
  84. package/agent/apps/desktop/README.md +20 -16
  85. package/agent/apps/desktop/assets/icon.icns +0 -0
  86. package/agent/apps/desktop/assets/icon.ico +0 -0
  87. package/agent/apps/desktop/assets/icon.png +0 -0
  88. package/agent/apps/desktop/electron/backend-env.cjs +112 -0
  89. package/agent/apps/desktop/electron/backend-env.test.cjs +111 -0
  90. package/agent/apps/desktop/electron/backend-probes.test.cjs +3 -1
  91. package/agent/apps/desktop/electron/backend-ready.cjs +66 -0
  92. package/agent/apps/desktop/electron/bootstrap-platform.cjs +52 -0
  93. package/agent/apps/desktop/electron/bootstrap-platform.test.cjs +59 -1
  94. package/agent/apps/desktop/electron/bootstrap-runner.cjs +176 -38
  95. package/agent/apps/desktop/electron/bootstrap-runner.test.cjs +112 -1
  96. package/agent/apps/desktop/electron/connection-config.cjs +288 -0
  97. package/agent/apps/desktop/electron/connection-config.test.cjs +396 -0
  98. package/agent/apps/desktop/electron/dashboard-token.cjs +99 -0
  99. package/agent/apps/desktop/electron/dashboard-token.test.cjs +142 -0
  100. package/agent/apps/desktop/electron/desktop-uninstall.cjs +232 -0
  101. package/agent/apps/desktop/electron/desktop-uninstall.test.cjs +246 -0
  102. package/agent/apps/desktop/electron/entitlements.mac.inherit.plist +2 -0
  103. package/agent/apps/desktop/electron/fs-read-dir.cjs +109 -0
  104. package/agent/apps/desktop/electron/fs-read-dir.test.cjs +364 -0
  105. package/agent/apps/desktop/electron/gateway-ws-probe.cjs +188 -0
  106. package/agent/apps/desktop/electron/gateway-ws-probe.test.cjs +122 -0
  107. package/agent/apps/desktop/electron/git-root.cjs +54 -0
  108. package/agent/apps/desktop/electron/git-root.test.cjs +40 -0
  109. package/agent/apps/desktop/electron/git-worktrees.cjs +174 -0
  110. package/agent/apps/desktop/electron/hardening.cjs +123 -28
  111. package/agent/apps/desktop/electron/hardening.test.cjs +163 -0
  112. package/agent/apps/desktop/electron/main.cjs +3121 -331
  113. package/agent/apps/desktop/electron/oauth-net-request.cjs +20 -0
  114. package/agent/apps/desktop/electron/oauth-net-request.test.cjs +34 -0
  115. package/agent/apps/desktop/electron/preload.cjs +52 -2
  116. package/agent/apps/desktop/electron/session-windows.cjs +124 -0
  117. package/agent/apps/desktop/electron/session-windows.test.cjs +199 -0
  118. package/agent/apps/desktop/electron/update-rebuild.cjs +29 -0
  119. package/agent/apps/desktop/electron/update-rebuild.test.cjs +55 -0
  120. package/agent/apps/desktop/electron/update-remote.cjs +56 -0
  121. package/agent/apps/desktop/electron/update-remote.test.cjs +78 -0
  122. package/agent/apps/desktop/electron/vscode-marketplace.cjs +331 -0
  123. package/agent/apps/desktop/electron/vscode-marketplace.test.cjs +113 -0
  124. package/agent/apps/desktop/electron/windows-child-process.test.cjs +57 -0
  125. package/agent/apps/desktop/electron/windows-user-env.cjs +76 -0
  126. package/agent/apps/desktop/electron/windows-user-env.test.cjs +90 -0
  127. package/agent/apps/desktop/electron/workspace-cwd.cjs +38 -0
  128. package/agent/apps/desktop/electron/workspace-cwd.test.cjs +45 -0
  129. package/agent/apps/desktop/eslint.config.mjs +0 -3
  130. package/agent/apps/desktop/index.html +27 -2
  131. package/agent/apps/desktop/package.json +31 -11
  132. package/agent/apps/desktop/pr-assets/session-source-folders.png +0 -0
  133. package/agent/apps/desktop/public/apple-touch-icon.png +0 -0
  134. package/agent/apps/desktop/public/nous-girl.jpg +0 -0
  135. package/agent/apps/desktop/scripts/assert-dist-built.cjs +70 -0
  136. package/agent/apps/desktop/scripts/assert-dist-built.test.cjs +84 -0
  137. package/agent/apps/desktop/scripts/before-pack.cjs +78 -0
  138. package/agent/apps/desktop/scripts/before-pack.test.cjs +53 -0
  139. package/agent/apps/desktop/scripts/diag-scroll-reset.mjs +229 -0
  140. package/agent/apps/desktop/scripts/patch-electron-builder-mac-binary.cjs +64 -0
  141. package/agent/apps/desktop/scripts/run-electron-builder.cjs +57 -0
  142. package/agent/apps/desktop/src/app/agents/index.tsx +53 -45
  143. package/agent/apps/desktop/src/app/artifacts/index.tsx +102 -83
  144. package/agent/apps/desktop/src/app/chat/chat-drop-overlay.tsx +29 -8
  145. package/agent/apps/desktop/src/app/chat/chat-swap-overlay.tsx +47 -0
  146. package/agent/apps/desktop/src/app/chat/composer/attachments.tsx +81 -45
  147. package/agent/apps/desktop/src/app/chat/composer/completion-drawer.tsx +13 -24
  148. package/agent/apps/desktop/src/app/chat/composer/context-menu.tsx +138 -88
  149. package/agent/apps/desktop/src/app/chat/composer/controls.tsx +138 -90
  150. package/agent/apps/desktop/src/app/chat/composer/enter-submit-dom-race.test.tsx +218 -0
  151. package/agent/apps/desktop/src/app/chat/composer/focus.ts +32 -0
  152. package/agent/apps/desktop/src/app/chat/composer/help-hint.tsx +38 -25
  153. package/agent/apps/desktop/src/app/chat/composer/hooks/use-live-completion-adapter.ts +7 -0
  154. package/agent/apps/desktop/src/app/chat/composer/hooks/use-mic-recorder.ts +22 -12
  155. package/agent/apps/desktop/src/app/chat/composer/hooks/use-slash-completions.ts +142 -14
  156. package/agent/apps/desktop/src/app/chat/composer/hooks/use-voice-conversation.ts +14 -11
  157. package/agent/apps/desktop/src/app/chat/composer/hooks/use-voice-recorder.ts +9 -6
  158. package/agent/apps/desktop/src/app/chat/composer/ime-composition-dom-repro.test.tsx +108 -0
  159. package/agent/apps/desktop/src/app/chat/composer/index.tsx +930 -180
  160. package/agent/apps/desktop/src/app/chat/composer/inline-refs.ts +136 -32
  161. package/agent/apps/desktop/src/app/chat/composer/model-pill.tsx +86 -0
  162. package/agent/apps/desktop/src/app/chat/composer/queue-panel.tsx +54 -75
  163. package/agent/apps/desktop/src/app/chat/composer/rich-editor.test.ts +117 -1
  164. package/agent/apps/desktop/src/app/chat/composer/rich-editor.ts +117 -6
  165. package/agent/apps/desktop/src/app/chat/composer/slash-nav-dom-repro.test.tsx +186 -0
  166. package/agent/apps/desktop/src/app/chat/composer/status-stack/index.tsx +202 -0
  167. package/agent/apps/desktop/src/app/chat/composer/status-stack/status-row.tsx +155 -0
  168. package/agent/apps/desktop/src/app/chat/composer/text-utils.test.ts +104 -0
  169. package/agent/apps/desktop/src/app/chat/composer/text-utils.ts +37 -9
  170. package/agent/apps/desktop/src/app/chat/composer/trigger-popover.test.tsx +50 -0
  171. package/agent/apps/desktop/src/app/chat/composer/trigger-popover.tsx +105 -40
  172. package/agent/apps/desktop/src/app/chat/composer/types.ts +5 -0
  173. package/agent/apps/desktop/src/app/chat/composer/url-dialog.tsx +11 -15
  174. package/agent/apps/desktop/src/app/chat/composer/voice-activity.tsx +8 -4
  175. package/agent/apps/desktop/src/app/chat/hooks/use-composer-actions.test.ts +57 -0
  176. package/agent/apps/desktop/src/app/chat/hooks/use-composer-actions.ts +70 -16
  177. package/agent/apps/desktop/src/app/chat/hooks/use-file-drop-zone.ts +52 -16
  178. package/agent/apps/desktop/src/app/chat/index.tsx +234 -81
  179. package/agent/apps/desktop/src/app/chat/perf-probe.tsx +69 -21
  180. package/agent/apps/desktop/src/app/chat/right-rail/preview-console.tsx +44 -40
  181. package/agent/apps/desktop/src/app/chat/right-rail/preview-file.tsx +71 -25
  182. package/agent/apps/desktop/src/app/chat/right-rail/preview-pane.test.tsx +40 -1
  183. package/agent/apps/desktop/src/app/chat/right-rail/preview-pane.tsx +55 -53
  184. package/agent/apps/desktop/src/app/chat/right-rail/preview.tsx +35 -17
  185. package/agent/apps/desktop/src/app/chat/scroll-to-bottom-button.test.tsx +67 -0
  186. package/agent/apps/desktop/src/app/chat/scroll-to-bottom-button.tsx +74 -0
  187. package/agent/apps/desktop/src/app/chat/sidebar/cron-jobs-section.tsx +356 -0
  188. package/agent/apps/desktop/src/app/chat/sidebar/index.tsx +1189 -364
  189. package/agent/apps/desktop/src/app/chat/sidebar/load-more-row.tsx +30 -0
  190. package/agent/apps/desktop/src/app/chat/sidebar/order.test.ts +21 -0
  191. package/agent/apps/desktop/src/app/chat/sidebar/order.ts +17 -0
  192. package/agent/apps/desktop/src/app/chat/sidebar/profile-switcher.tsx +524 -0
  193. package/agent/apps/desktop/src/app/chat/sidebar/session-actions-menu.tsx +80 -45
  194. package/agent/apps/desktop/src/app/chat/sidebar/session-row.tsx +120 -25
  195. package/agent/apps/desktop/src/app/chat/sidebar/virtual-session-list.tsx +7 -13
  196. package/agent/apps/desktop/src/app/chat/sidebar/workspace-groups.test.ts +149 -0
  197. package/agent/apps/desktop/src/app/chat/sidebar/workspace-groups.ts +326 -0
  198. package/agent/apps/desktop/src/app/chat/thread-loading.ts +7 -2
  199. package/agent/apps/desktop/src/app/command-center/index.tsx +320 -581
  200. package/agent/apps/desktop/src/app/command-palette/index.tsx +681 -0
  201. package/agent/apps/desktop/src/app/command-palette/marketplace-theme-page.tsx +157 -0
  202. package/agent/apps/desktop/src/app/cron/index.tsx +392 -324
  203. package/agent/apps/desktop/src/app/cron/job-state.ts +29 -0
  204. package/agent/apps/desktop/src/app/desktop-controller.tsx +618 -123
  205. package/agent/apps/desktop/src/app/floating-hud.ts +22 -0
  206. package/agent/apps/desktop/src/app/gateway/hooks/use-gateway-boot.test.tsx +265 -0
  207. package/agent/apps/desktop/src/app/gateway/hooks/use-gateway-boot.ts +260 -14
  208. package/agent/apps/desktop/src/app/gateway/hooks/use-gateway-request.ts +48 -4
  209. package/agent/apps/desktop/src/app/hooks/use-keybinds.ts +270 -0
  210. package/agent/apps/desktop/src/app/hooks/use-refresh-hotkey.ts +45 -0
  211. package/agent/apps/desktop/src/app/layout-constants.ts +19 -0
  212. package/agent/apps/desktop/src/app/messaging/index.tsx +136 -241
  213. package/agent/apps/desktop/src/app/messaging/platform-icon.tsx +95 -0
  214. package/agent/apps/desktop/src/app/model-visibility-overlay.tsx +31 -0
  215. package/agent/apps/desktop/src/app/overlays/overlay-search-input.tsx +18 -62
  216. package/agent/apps/desktop/src/app/overlays/overlay-split-layout.tsx +59 -7
  217. package/agent/apps/desktop/src/app/overlays/overlay-view.tsx +9 -5
  218. package/agent/apps/desktop/src/app/page-search-shell.tsx +42 -20
  219. package/agent/apps/desktop/src/app/profiles/create-profile-dialog.tsx +165 -0
  220. package/agent/apps/desktop/src/app/profiles/delete-profile-dialog.tsx +65 -0
  221. package/agent/apps/desktop/src/app/profiles/index.tsx +174 -199
  222. package/agent/apps/desktop/src/app/profiles/rename-profile-dialog.tsx +125 -0
  223. package/agent/apps/desktop/src/app/right-sidebar/files/dnd-manager.ts +27 -0
  224. package/agent/apps/desktop/src/app/right-sidebar/files/ipc.test.ts +100 -0
  225. package/agent/apps/desktop/src/app/right-sidebar/files/ipc.ts +12 -18
  226. package/agent/apps/desktop/src/app/right-sidebar/files/remote-picker.tsx +177 -0
  227. package/agent/apps/desktop/src/app/right-sidebar/files/tree.tsx +35 -21
  228. package/agent/apps/desktop/src/app/right-sidebar/files/use-project-tree.test.ts +75 -3
  229. package/agent/apps/desktop/src/app/right-sidebar/files/use-project-tree.ts +152 -5
  230. package/agent/apps/desktop/src/app/right-sidebar/index.test.tsx +75 -0
  231. package/agent/apps/desktop/src/app/right-sidebar/index.tsx +166 -129
  232. package/agent/apps/desktop/src/app/right-sidebar/store.ts +19 -4
  233. package/agent/apps/desktop/src/app/right-sidebar/terminal/buffer.ts +65 -0
  234. package/agent/apps/desktop/src/app/right-sidebar/terminal/index.tsx +29 -34
  235. package/agent/apps/desktop/src/app/right-sidebar/terminal/persistent.tsx +18 -6
  236. package/agent/apps/desktop/src/app/right-sidebar/terminal/selection.ts +93 -32
  237. package/agent/apps/desktop/src/app/right-sidebar/terminal/use-terminal-session.ts +381 -119
  238. package/agent/apps/desktop/src/app/routes.ts +9 -0
  239. package/agent/apps/desktop/src/app/session/hooks/use-cwd-actions.ts +17 -7
  240. package/agent/apps/desktop/src/app/session/hooks/use-message-stream.ts +365 -47
  241. package/agent/apps/desktop/src/app/session/hooks/use-model-controls.test.tsx +198 -0
  242. package/agent/apps/desktop/src/app/session/hooks/use-model-controls.ts +70 -34
  243. package/agent/apps/desktop/src/app/session/hooks/use-prompt-actions.test.tsx +1061 -0
  244. package/agent/apps/desktop/src/app/session/hooks/use-prompt-actions.ts +1143 -165
  245. package/agent/apps/desktop/src/app/session/hooks/use-route-resume.test.tsx +341 -2
  246. package/agent/apps/desktop/src/app/session/hooks/use-route-resume.ts +176 -5
  247. package/agent/apps/desktop/src/app/session/hooks/use-session-actions.test.tsx +259 -0
  248. package/agent/apps/desktop/src/app/session/hooks/use-session-actions.ts +452 -149
  249. package/agent/apps/desktop/src/app/session/hooks/use-session-state-cache.test.tsx +327 -0
  250. package/agent/apps/desktop/src/app/session/hooks/use-session-state-cache.ts +133 -4
  251. package/agent/apps/desktop/src/app/session-picker-overlay.tsx +32 -0
  252. package/agent/apps/desktop/src/app/session-switcher.tsx +107 -0
  253. package/agent/apps/desktop/src/app/settings/about-settings.tsx +45 -36
  254. package/agent/apps/desktop/src/app/settings/appearance-settings.tsx +243 -162
  255. package/agent/apps/desktop/src/app/settings/config-settings.tsx +86 -66
  256. package/agent/apps/desktop/src/app/settings/constants.ts +459 -122
  257. package/agent/apps/desktop/src/app/settings/credential-key-ui.tsx +373 -0
  258. package/agent/apps/desktop/src/app/settings/env-credentials.tsx +198 -0
  259. package/agent/apps/desktop/src/app/settings/env-var-actions-menu.tsx +136 -0
  260. package/agent/apps/desktop/src/app/settings/field-copy.ts +56 -0
  261. package/agent/apps/desktop/src/app/settings/gateway-settings.tsx +385 -72
  262. package/agent/apps/desktop/src/app/settings/helpers.test.ts +156 -1
  263. package/agent/apps/desktop/src/app/settings/helpers.ts +30 -2
  264. package/agent/apps/desktop/src/app/settings/index.tsx +118 -84
  265. package/agent/apps/desktop/src/app/settings/keys-settings.tsx +62 -419
  266. package/agent/apps/desktop/src/app/settings/mcp-settings.tsx +65 -60
  267. package/agent/apps/desktop/src/app/settings/model-settings.test.tsx +129 -5
  268. package/agent/apps/desktop/src/app/settings/model-settings.tsx +370 -65
  269. package/agent/apps/desktop/src/app/settings/notifications-settings.tsx +150 -0
  270. package/agent/apps/desktop/src/app/settings/primitives.tsx +5 -11
  271. package/agent/apps/desktop/src/app/settings/provider-config-panel.test.tsx +142 -0
  272. package/agent/apps/desktop/src/app/settings/provider-config-panel.tsx +182 -0
  273. package/agent/apps/desktop/src/app/settings/providers-settings.test.tsx +171 -0
  274. package/agent/apps/desktop/src/app/settings/providers-settings.tsx +471 -0
  275. package/agent/apps/desktop/src/app/settings/sessions-settings.tsx +183 -71
  276. package/agent/apps/desktop/src/app/settings/toolset-config-panel.test.tsx +135 -1
  277. package/agent/apps/desktop/src/app/settings/toolset-config-panel.tsx +180 -57
  278. package/agent/apps/desktop/src/app/settings/types.ts +9 -6
  279. package/agent/apps/desktop/src/app/settings/uninstall-section.tsx +185 -0
  280. package/agent/apps/desktop/src/app/settings/use-deep-link-highlight.ts +60 -0
  281. package/agent/apps/desktop/src/app/shell/app-shell.tsx +59 -13
  282. package/agent/apps/desktop/src/app/shell/gateway-menu-panel.tsx +37 -32
  283. package/agent/apps/desktop/src/app/shell/hooks/use-overlay-routing.ts +6 -3
  284. package/agent/apps/desktop/src/app/shell/hooks/use-statusbar-items.tsx +212 -53
  285. package/agent/apps/desktop/src/app/shell/keybind-panel.tsx +215 -0
  286. package/agent/apps/desktop/src/app/shell/model-edit-submenu.test.tsx +84 -0
  287. package/agent/apps/desktop/src/app/shell/model-edit-submenu.tsx +244 -0
  288. package/agent/apps/desktop/src/app/shell/model-menu-panel.tsx +392 -0
  289. package/agent/apps/desktop/src/app/shell/statusbar-controls.tsx +23 -33
  290. package/agent/apps/desktop/src/app/shell/titlebar-controls.tsx +79 -95
  291. package/agent/apps/desktop/src/app/shell/titlebar.ts +8 -2
  292. package/agent/apps/desktop/src/app/skills/index.test.tsx +11 -0
  293. package/agent/apps/desktop/src/app/skills/index.tsx +79 -64
  294. package/agent/apps/desktop/src/app/types.ts +85 -0
  295. package/agent/apps/desktop/src/app/updates-overlay.tsx +110 -105
  296. package/agent/apps/desktop/src/components/assistant-ui/ansi-text.tsx +34 -0
  297. package/agent/apps/desktop/src/components/assistant-ui/block-direction.test.tsx +129 -0
  298. package/agent/apps/desktop/src/components/assistant-ui/clarify-tool.tsx +102 -81
  299. package/agent/apps/desktop/src/components/assistant-ui/directive-text.tsx +92 -15
  300. package/agent/apps/desktop/src/components/assistant-ui/markdown-text.test.ts +38 -0
  301. package/agent/apps/desktop/src/components/assistant-ui/markdown-text.tsx +304 -45
  302. package/agent/apps/desktop/src/components/assistant-ui/message-render-boundary.test.tsx +80 -0
  303. package/agent/apps/desktop/src/components/assistant-ui/message-render-boundary.tsx +48 -0
  304. package/agent/apps/desktop/src/components/assistant-ui/streaming.test.tsx +142 -90
  305. package/agent/apps/desktop/src/components/assistant-ui/thread-list.tsx +337 -0
  306. package/agent/apps/desktop/src/components/assistant-ui/thread.tsx +667 -190
  307. package/agent/apps/desktop/src/components/assistant-ui/tool-approval-group.test.tsx +299 -0
  308. package/agent/apps/desktop/src/components/assistant-ui/tool-approval.test.tsx +133 -0
  309. package/agent/apps/desktop/src/components/assistant-ui/tool-approval.tsx +239 -0
  310. package/agent/apps/desktop/src/components/assistant-ui/tool-fallback-model.test.ts +31 -0
  311. package/agent/apps/desktop/src/components/assistant-ui/tool-fallback-model.ts +152 -134
  312. package/agent/apps/desktop/src/components/assistant-ui/tool-fallback.tsx +142 -150
  313. package/agent/apps/desktop/src/components/assistant-ui/tooltip-icon-button.tsx +14 -12
  314. package/agent/apps/desktop/src/components/assistant-ui/user-message-edit.test.tsx +141 -0
  315. package/agent/apps/desktop/src/components/assistant-ui/user-message-text.tsx +152 -0
  316. package/agent/apps/desktop/src/components/boot-failure-overlay.tsx +150 -33
  317. package/agent/apps/desktop/src/components/boot-failure-reauth.test.ts +100 -0
  318. package/agent/apps/desktop/src/components/boot-failure-reauth.ts +81 -0
  319. package/agent/apps/desktop/src/components/brand-mark.tsx +19 -0
  320. package/agent/apps/desktop/src/components/chat/code-card.tsx +1 -1
  321. package/agent/apps/desktop/src/components/chat/composer-dock.ts +31 -0
  322. package/agent/apps/desktop/src/components/chat/diff-lines.tsx +1 -1
  323. package/agent/apps/desktop/src/components/chat/disclosure-row.tsx +13 -3
  324. package/agent/apps/desktop/src/components/chat/expandable-block.tsx +52 -0
  325. package/agent/apps/desktop/src/components/chat/generated-image-result.tsx +174 -0
  326. package/agent/apps/desktop/src/components/chat/image-generation-placeholder.tsx +70 -37
  327. package/agent/apps/desktop/src/components/chat/intro.tsx +8 -7
  328. package/agent/apps/desktop/src/components/chat/preview-attachment.tsx +4 -2
  329. package/agent/apps/desktop/src/components/chat/shiki-highlighter.test.ts +37 -0
  330. package/agent/apps/desktop/src/components/chat/shiki-highlighter.tsx +96 -22
  331. package/agent/apps/desktop/src/components/chat/status-row.tsx +70 -0
  332. package/agent/apps/desktop/src/components/chat/status-section.tsx +42 -0
  333. package/agent/apps/desktop/src/components/chat/terminal-output.tsx +54 -0
  334. package/agent/apps/desktop/src/components/chat/zoomable-image.tsx +70 -109
  335. package/agent/apps/desktop/src/components/desktop-install-overlay.tsx +154 -84
  336. package/agent/apps/desktop/src/components/desktop-onboarding-overlay.test.tsx +38 -8
  337. package/agent/apps/desktop/src/components/desktop-onboarding-overlay.tsx +789 -233
  338. package/agent/apps/desktop/src/components/error-boundary.tsx +77 -0
  339. package/agent/apps/desktop/src/components/gateway-connecting-overlay.test.tsx +144 -0
  340. package/agent/apps/desktop/src/components/gateway-connecting-overlay.tsx +7 -1
  341. package/agent/apps/desktop/src/components/haptics-provider.tsx +24 -0
  342. package/agent/apps/desktop/src/components/language-switcher.test.tsx +53 -0
  343. package/agent/apps/desktop/src/components/language-switcher.tsx +175 -0
  344. package/agent/apps/desktop/src/components/model-picker.tsx +42 -40
  345. package/agent/apps/desktop/src/components/model-visibility-dialog.tsx +166 -0
  346. package/agent/apps/desktop/src/components/notifications.tsx +48 -27
  347. package/agent/apps/desktop/src/components/pane-shell/index.ts +1 -1
  348. package/agent/apps/desktop/src/components/pane-shell/pane-shell.tsx +146 -9
  349. package/agent/apps/desktop/src/components/prompt-overlays.tsx +234 -0
  350. package/agent/apps/desktop/src/components/session-picker.tsx +108 -0
  351. package/agent/apps/desktop/src/components/ui/action-status.tsx +25 -0
  352. package/agent/apps/desktop/src/components/ui/badge.tsx +35 -0
  353. package/agent/apps/desktop/src/components/ui/button.tsx +37 -13
  354. package/agent/apps/desktop/src/components/ui/confirm-dialog.tsx +109 -0
  355. package/agent/apps/desktop/src/components/ui/control.ts +25 -0
  356. package/agent/apps/desktop/src/components/ui/copy-button.test.tsx +36 -0
  357. package/agent/apps/desktop/src/components/ui/copy-button.tsx +38 -27
  358. package/agent/apps/desktop/src/components/ui/dialog.tsx +39 -11
  359. package/agent/apps/desktop/src/components/ui/dropdown-menu.tsx +98 -24
  360. package/agent/apps/desktop/src/components/ui/error-state.tsx +50 -0
  361. package/agent/apps/desktop/src/components/ui/fade-text.tsx +9 -2
  362. package/agent/apps/desktop/src/components/ui/{braille-spinner.tsx → glyph-spinner.tsx} +15 -13
  363. package/agent/apps/desktop/src/components/ui/input.tsx +5 -2
  364. package/agent/apps/desktop/src/components/ui/kbd.tsx +83 -12
  365. package/agent/apps/desktop/src/components/ui/log-view.tsx +19 -0
  366. package/agent/apps/desktop/src/components/ui/pagination.tsx +12 -5
  367. package/agent/apps/desktop/src/components/ui/popover.tsx +44 -0
  368. package/agent/apps/desktop/src/components/ui/search-field.tsx +80 -0
  369. package/agent/apps/desktop/src/components/ui/segmented-control.tsx +51 -0
  370. package/agent/apps/desktop/src/components/ui/select.tsx +10 -3
  371. package/agent/apps/desktop/src/components/ui/sheet.tsx +8 -2
  372. package/agent/apps/desktop/src/components/ui/sidebar.tsx +18 -25
  373. package/agent/apps/desktop/src/components/ui/switch.tsx +38 -15
  374. package/agent/apps/desktop/src/components/ui/textarea.tsx +4 -11
  375. package/agent/apps/desktop/src/components/ui/tool-icon.tsx +65 -0
  376. package/agent/apps/desktop/src/components/ui/tooltip.tsx +31 -4
  377. package/agent/apps/desktop/src/fonts/JetBrainsMono-Bold.woff2 +0 -0
  378. package/agent/apps/desktop/src/fonts/JetBrainsMono-Italic.woff2 +0 -0
  379. package/agent/apps/desktop/src/fonts/JetBrainsMono-Regular.woff2 +0 -0
  380. package/agent/apps/desktop/src/global.d.ts +181 -4
  381. package/agent/apps/desktop/src/hermes.test.ts +60 -0
  382. package/agent/apps/desktop/src/hermes.ts +190 -13
  383. package/agent/apps/desktop/src/hooks/use-image-download.ts +85 -0
  384. package/agent/apps/desktop/src/hooks/use-resize-observer.ts +13 -4
  385. package/agent/apps/desktop/src/hooks/use-worktree-info.ts +68 -0
  386. package/agent/apps/desktop/src/i18n/catalog.ts +12 -0
  387. package/agent/apps/desktop/src/i18n/context.test.tsx +232 -0
  388. package/agent/apps/desktop/src/i18n/context.tsx +183 -0
  389. package/agent/apps/desktop/src/i18n/define-locale.ts +41 -0
  390. package/agent/apps/desktop/src/i18n/en.ts +1921 -0
  391. package/agent/apps/desktop/src/i18n/index.ts +20 -0
  392. package/agent/apps/desktop/src/i18n/ja.ts +2053 -0
  393. package/agent/apps/desktop/src/i18n/languages.test.ts +43 -0
  394. package/agent/apps/desktop/src/i18n/languages.ts +86 -0
  395. package/agent/apps/desktop/src/i18n/runtime.test.ts +75 -0
  396. package/agent/apps/desktop/src/i18n/runtime.ts +53 -0
  397. package/agent/apps/desktop/src/i18n/types.ts +1559 -0
  398. package/agent/apps/desktop/src/i18n/zh-hant.ts +1992 -0
  399. package/agent/apps/desktop/src/i18n/zh.ts +2099 -0
  400. package/agent/apps/desktop/src/lib/ansi.test.ts +123 -0
  401. package/agent/apps/desktop/src/lib/ansi.ts +186 -0
  402. package/agent/apps/desktop/src/lib/chat-messages.test.ts +79 -0
  403. package/agent/apps/desktop/src/lib/chat-messages.ts +68 -29
  404. package/agent/apps/desktop/src/lib/chat-runtime.test.ts +65 -1
  405. package/agent/apps/desktop/src/lib/chat-runtime.ts +39 -3
  406. package/agent/apps/desktop/src/lib/completion-sound.ts +519 -0
  407. package/agent/apps/desktop/src/lib/desktop-fs.test.ts +116 -0
  408. package/agent/apps/desktop/src/lib/desktop-fs.ts +113 -0
  409. package/agent/apps/desktop/src/lib/desktop-slash-commands.test.ts +89 -6
  410. package/agent/apps/desktop/src/lib/desktop-slash-commands.ts +270 -131
  411. package/agent/apps/desktop/src/lib/external-link.test.tsx +27 -0
  412. package/agent/apps/desktop/src/lib/external-link.tsx +9 -2
  413. package/agent/apps/desktop/src/lib/gateway-events.test.ts +27 -0
  414. package/agent/apps/desktop/src/lib/gateway-events.ts +16 -0
  415. package/agent/apps/desktop/src/lib/gateway-ws-url.test.ts +78 -0
  416. package/agent/apps/desktop/src/lib/gateway-ws-url.ts +91 -0
  417. package/agent/apps/desktop/src/lib/generated-images.test.ts +97 -0
  418. package/agent/apps/desktop/src/lib/generated-images.ts +116 -0
  419. package/agent/apps/desktop/src/lib/haptics.ts +17 -0
  420. package/agent/apps/desktop/src/lib/icons.ts +10 -2
  421. package/agent/apps/desktop/src/lib/keybinds/actions.ts +137 -0
  422. package/agent/apps/desktop/src/lib/keybinds/combo.test.ts +86 -0
  423. package/agent/apps/desktop/src/lib/keybinds/combo.ts +195 -0
  424. package/agent/apps/desktop/src/lib/local-preview.ts +23 -2
  425. package/agent/apps/desktop/src/lib/markdown-preprocess.ts +20 -7
  426. package/agent/apps/desktop/src/lib/media.remote.test.ts +90 -0
  427. package/agent/apps/desktop/src/lib/media.ts +40 -1
  428. package/agent/apps/desktop/src/lib/model-status-label.test.ts +59 -0
  429. package/agent/apps/desktop/src/lib/model-status-label.ts +122 -0
  430. package/agent/apps/desktop/src/lib/mutable-ref.ts +6 -0
  431. package/agent/apps/desktop/src/lib/profile-color.ts +58 -0
  432. package/agent/apps/desktop/src/lib/query-client.ts +13 -0
  433. package/agent/apps/desktop/src/lib/remend-tail.test.ts +105 -0
  434. package/agent/apps/desktop/src/lib/remend-tail.ts +108 -0
  435. package/agent/apps/desktop/src/lib/session-export.ts +6 -3
  436. package/agent/apps/desktop/src/lib/session-ids.test.ts +44 -0
  437. package/agent/apps/desktop/src/lib/session-ids.ts +26 -0
  438. package/agent/apps/desktop/src/lib/session-search.test.ts +66 -0
  439. package/agent/apps/desktop/src/lib/session-search.ts +21 -0
  440. package/agent/apps/desktop/src/lib/session-source.ts +126 -0
  441. package/agent/apps/desktop/src/lib/storage.test.ts +25 -0
  442. package/agent/apps/desktop/src/lib/storage.ts +35 -1
  443. package/agent/apps/desktop/src/lib/todos.test.ts +46 -1
  444. package/agent/apps/desktop/src/lib/todos.ts +37 -0
  445. package/agent/apps/desktop/src/lib/tool-result-summary.ts +5 -1
  446. package/agent/apps/desktop/src/lib/update-copy.test.ts +38 -0
  447. package/agent/apps/desktop/src/lib/update-copy.ts +44 -0
  448. package/agent/apps/desktop/src/lib/use-enter-animation.ts +2 -2
  449. package/agent/apps/desktop/src/lib/yolo-session.ts +50 -0
  450. package/agent/apps/desktop/src/main.tsx +19 -19
  451. package/agent/apps/desktop/src/store/boot.ts +4 -3
  452. package/agent/apps/desktop/src/store/clarify.test.ts +81 -0
  453. package/agent/apps/desktop/src/store/clarify.ts +50 -13
  454. package/agent/apps/desktop/src/store/command-palette.ts +20 -0
  455. package/agent/apps/desktop/src/store/compaction.test.ts +53 -0
  456. package/agent/apps/desktop/src/store/compaction.ts +38 -0
  457. package/agent/apps/desktop/src/store/completion-sound.ts +32 -0
  458. package/agent/apps/desktop/src/store/composer-input-history.test.ts +147 -0
  459. package/agent/apps/desktop/src/store/composer-input-history.ts +158 -0
  460. package/agent/apps/desktop/src/store/composer-queue.test.ts +68 -0
  461. package/agent/apps/desktop/src/store/composer-queue.ts +76 -0
  462. package/agent/apps/desktop/src/store/composer-status.test.ts +99 -0
  463. package/agent/apps/desktop/src/store/composer-status.ts +277 -0
  464. package/agent/apps/desktop/src/store/composer.test.ts +106 -0
  465. package/agent/apps/desktop/src/store/composer.ts +116 -0
  466. package/agent/apps/desktop/src/store/cron.ts +19 -0
  467. package/agent/apps/desktop/src/store/gateway.ts +280 -6
  468. package/agent/apps/desktop/src/store/keybinds.ts +143 -0
  469. package/agent/apps/desktop/src/store/layout.ts +107 -9
  470. package/agent/apps/desktop/src/store/model-presets.test.ts +51 -0
  471. package/agent/apps/desktop/src/store/model-presets.ts +86 -0
  472. package/agent/apps/desktop/src/store/model-visibility.test.ts +99 -0
  473. package/agent/apps/desktop/src/store/model-visibility.ts +161 -0
  474. package/agent/apps/desktop/src/store/native-notifications.test.ts +192 -0
  475. package/agent/apps/desktop/src/store/native-notifications.ts +203 -0
  476. package/agent/apps/desktop/src/store/notifications.ts +10 -7
  477. package/agent/apps/desktop/src/store/onboarding.test.ts +271 -1
  478. package/agent/apps/desktop/src/store/onboarding.ts +268 -38
  479. package/agent/apps/desktop/src/store/preview.ts +10 -1
  480. package/agent/apps/desktop/src/store/profile.test.ts +89 -0
  481. package/agent/apps/desktop/src/store/profile.ts +395 -0
  482. package/agent/apps/desktop/src/store/prompts.test.ts +127 -0
  483. package/agent/apps/desktop/src/store/prompts.ts +117 -0
  484. package/agent/apps/desktop/src/store/session-switcher.test.ts +115 -0
  485. package/agent/apps/desktop/src/store/session-switcher.ts +128 -0
  486. package/agent/apps/desktop/src/store/session-sync.ts +25 -0
  487. package/agent/apps/desktop/src/store/session.test.ts +268 -2
  488. package/agent/apps/desktop/src/store/session.ts +392 -18
  489. package/agent/apps/desktop/src/store/subagents.ts +3 -0
  490. package/agent/apps/desktop/src/store/system-actions.ts +48 -0
  491. package/agent/apps/desktop/src/store/thread-scroll.ts +58 -5
  492. package/agent/apps/desktop/src/store/todos.test.ts +47 -0
  493. package/agent/apps/desktop/src/store/todos.ts +64 -0
  494. package/agent/apps/desktop/src/store/tool-dismiss.ts +45 -0
  495. package/agent/apps/desktop/src/store/translucency.ts +38 -0
  496. package/agent/apps/desktop/src/store/updates.test.ts +187 -2
  497. package/agent/apps/desktop/src/store/updates.ts +268 -18
  498. package/agent/apps/desktop/src/store/windows.test.ts +143 -0
  499. package/agent/apps/desktop/src/store/windows.ts +115 -0
  500. package/agent/apps/desktop/src/styles.css +510 -119
  501. package/agent/apps/desktop/src/themes/color.ts +142 -0
  502. package/agent/apps/desktop/src/themes/context.tsx +128 -75
  503. package/agent/apps/desktop/src/themes/install.test.ts +119 -0
  504. package/agent/apps/desktop/src/themes/install.ts +95 -0
  505. package/agent/apps/desktop/src/themes/presets.test.ts +33 -0
  506. package/agent/apps/desktop/src/themes/presets.ts +13 -4
  507. package/agent/apps/desktop/src/themes/profile-theme.test.ts +41 -0
  508. package/agent/apps/desktop/src/themes/types.ts +35 -0
  509. package/agent/apps/desktop/src/themes/user-themes.test.ts +63 -0
  510. package/agent/apps/desktop/src/themes/user-themes.ts +122 -0
  511. package/agent/apps/desktop/src/themes/vscode.test.ts +171 -0
  512. package/agent/apps/desktop/src/themes/vscode.ts +343 -0
  513. package/agent/apps/desktop/src/types/hermes.ts +138 -1
  514. package/agent/apps/desktop/tsconfig.json +2 -2
  515. package/agent/apps/desktop/vite.config.ts +18 -0
  516. package/agent/apps/shared/package.json +1 -1
  517. package/agent/apps/shared/src/json-rpc-gateway.ts +63 -2
  518. package/agent/apps/shared/tsconfig.json +2 -2
  519. package/agent/cli-config.yaml.example +78 -1
  520. package/agent/cli.py +2294 -3146
  521. package/agent/cron/blueprint_catalog.py +713 -0
  522. package/agent/cron/jobs.py +226 -110
  523. package/agent/cron/scheduler.py +468 -193
  524. package/agent/cron/scheduler_provider.py +177 -0
  525. package/agent/cron/scripts/__init__.py +1 -0
  526. package/agent/cron/scripts/classify_items.py +226 -0
  527. package/agent/cron/suggestion_catalog.py +154 -0
  528. package/agent/cron/suggestions.py +257 -0
  529. package/agent/docs/chronos-managed-cron-contract.md +196 -0
  530. package/agent/docs/design/profile-builder.md +146 -0
  531. package/agent/docs/middleware/README.md +260 -0
  532. package/agent/docs/observability/README.md +316 -0
  533. package/agent/docs/plans/2026-06-09-003-fix-telegram-stream-overflow-continuations-plan.md +240 -0
  534. package/agent/docs/rca-ssl-cacert-post-git-pull.md +54 -0
  535. package/agent/docs/relay-connector-contract.md +285 -0
  536. package/agent/gateway/authz_mixin.py +536 -0
  537. package/agent/gateway/channel_directory.py +65 -3
  538. package/agent/gateway/config.py +222 -12
  539. package/agent/gateway/display_config.py +10 -0
  540. package/agent/gateway/hooks.py +17 -0
  541. package/agent/gateway/kanban_watchers.py +1146 -0
  542. package/agent/gateway/message_timestamps.py +166 -0
  543. package/agent/gateway/platforms/ADDING_A_PLATFORM.md +29 -0
  544. package/agent/gateway/platforms/api_server.py +216 -38
  545. package/agent/gateway/platforms/base.py +210 -58
  546. package/agent/gateway/platforms/email.py +122 -12
  547. package/agent/gateway/platforms/feishu.py +80 -11
  548. package/agent/gateway/platforms/feishu_meeting_invite.py +212 -0
  549. package/agent/gateway/platforms/matrix.py +1498 -297
  550. package/agent/gateway/platforms/qqbot/adapter.py +6 -0
  551. package/agent/gateway/platforms/signal.py +8 -0
  552. package/agent/gateway/platforms/slack.py +308 -12
  553. package/agent/gateway/platforms/telegram.py +831 -24
  554. package/agent/gateway/platforms/webhook.py +109 -21
  555. package/agent/gateway/platforms/weixin.py +113 -2
  556. package/agent/gateway/platforms/whatsapp.py +94 -288
  557. package/agent/gateway/platforms/whatsapp_cloud.py +1956 -0
  558. package/agent/gateway/platforms/whatsapp_common.py +367 -0
  559. package/agent/gateway/platforms/yuanbao.py +608 -191
  560. package/agent/gateway/platforms/yuanbao_proto.py +232 -23
  561. package/agent/gateway/relay/__init__.py +375 -0
  562. package/agent/gateway/relay/adapter.py +222 -0
  563. package/agent/gateway/relay/auth.py +168 -0
  564. package/agent/gateway/relay/descriptor.py +118 -0
  565. package/agent/gateway/relay/transport.py +101 -0
  566. package/agent/gateway/relay/ws_transport.py +327 -0
  567. package/agent/gateway/response_filters.py +53 -0
  568. package/agent/gateway/rich_sent_store.py +80 -0
  569. package/agent/gateway/run.py +2940 -5001
  570. package/agent/gateway/session.py +109 -8
  571. package/agent/gateway/session_context.py +22 -4
  572. package/agent/gateway/slash_commands.py +3854 -0
  573. package/agent/gateway/status.py +141 -21
  574. package/agent/gateway/stream_consumer.py +288 -31
  575. package/agent/hermes-already-has-routines.md +1 -1
  576. package/agent/hermes_cli/__init__.py +62 -17
  577. package/agent/hermes_cli/_parser.py +30 -0
  578. package/agent/hermes_cli/_subprocess_compat.py +61 -0
  579. package/agent/hermes_cli/active_sessions.py +320 -0
  580. package/agent/hermes_cli/auth.py +707 -59
  581. package/agent/hermes_cli/auth_commands.py +39 -22
  582. package/agent/hermes_cli/backup.py +109 -7
  583. package/agent/hermes_cli/banner.py +88 -0
  584. package/agent/hermes_cli/blueprint_cmd.py +318 -0
  585. package/agent/hermes_cli/clawpump_cli.py +3 -3
  586. package/agent/hermes_cli/cli_agent_setup_mixin.py +684 -0
  587. package/agent/hermes_cli/cli_commands_mixin.py +2293 -0
  588. package/agent/hermes_cli/commands.py +216 -91
  589. package/agent/hermes_cli/config.py +967 -130
  590. package/agent/hermes_cli/container_boot.py +76 -11
  591. package/agent/hermes_cli/cron.py +5 -11
  592. package/agent/hermes_cli/curator.py +21 -0
  593. package/agent/hermes_cli/dashboard_auth/__init__.py +2 -0
  594. package/agent/hermes_cli/dashboard_auth/base.py +62 -0
  595. package/agent/hermes_cli/dashboard_auth/cookies.py +32 -19
  596. package/agent/hermes_cli/dashboard_auth/login_page.py +156 -6
  597. package/agent/hermes_cli/dashboard_auth/middleware.py +28 -4
  598. package/agent/hermes_cli/dashboard_auth/prefix.py +46 -2
  599. package/agent/hermes_cli/dashboard_auth/public_paths.py +6 -0
  600. package/agent/hermes_cli/dashboard_auth/routes.py +158 -2
  601. package/agent/hermes_cli/dashboard_auth/ws_tickets.py +85 -11
  602. package/agent/hermes_cli/dashboard_register.py +427 -0
  603. package/agent/hermes_cli/debug.py +155 -50
  604. package/agent/hermes_cli/distribution.py +227 -0
  605. package/agent/hermes_cli/doctor.py +255 -14
  606. package/agent/hermes_cli/dump.py +60 -6
  607. package/agent/hermes_cli/env_loader.py +33 -0
  608. package/agent/hermes_cli/gateway.py +755 -103
  609. package/agent/hermes_cli/gateway_enroll.py +250 -0
  610. package/agent/hermes_cli/gateway_windows.py +254 -11
  611. package/agent/hermes_cli/gui_uninstall.py +285 -0
  612. package/agent/hermes_cli/inventory.py +105 -4
  613. package/agent/hermes_cli/kanban.py +58 -71
  614. package/agent/hermes_cli/kanban_db.py +391 -14
  615. package/agent/hermes_cli/kanban_decompose.py +2 -2
  616. package/agent/hermes_cli/kanban_specify.py +3 -1
  617. package/agent/hermes_cli/logs.py +2 -0
  618. package/agent/hermes_cli/main.py +2889 -5287
  619. package/agent/hermes_cli/managed_scope.py +214 -0
  620. package/agent/hermes_cli/managed_uv.py +254 -0
  621. package/agent/hermes_cli/mcp_catalog.py +6 -3
  622. package/agent/hermes_cli/mcp_config.py +145 -21
  623. package/agent/hermes_cli/mcp_security.py +96 -0
  624. package/agent/hermes_cli/mcp_startup.py +32 -3
  625. package/agent/hermes_cli/memory_providers.py +149 -0
  626. package/agent/hermes_cli/memory_setup.py +97 -42
  627. package/agent/hermes_cli/middleware.py +313 -0
  628. package/agent/hermes_cli/model_catalog.py +31 -0
  629. package/agent/hermes_cli/model_cost_guard.py +134 -0
  630. package/agent/hermes_cli/model_normalize.py +2 -1
  631. package/agent/hermes_cli/model_setup_flows.py +2759 -0
  632. package/agent/hermes_cli/model_switch.py +242 -27
  633. package/agent/hermes_cli/models.py +284 -44
  634. package/agent/hermes_cli/nous_account.py +33 -6
  635. package/agent/hermes_cli/nous_billing.py +406 -0
  636. package/agent/hermes_cli/nous_subscription.py +202 -5
  637. package/agent/hermes_cli/platforms.py +1 -0
  638. package/agent/hermes_cli/plugins.py +218 -18
  639. package/agent/hermes_cli/plugins_cmd.py +249 -105
  640. package/agent/hermes_cli/portal_cli.py +56 -16
  641. package/agent/hermes_cli/profile_distribution.py +6 -1
  642. package/agent/hermes_cli/profiles.py +283 -32
  643. package/agent/hermes_cli/provider_catalog.py +170 -0
  644. package/agent/hermes_cli/providers.py +4 -1
  645. package/agent/hermes_cli/pty_bridge.py +53 -4
  646. package/agent/hermes_cli/runtime_provider.py +216 -34
  647. package/agent/hermes_cli/secret_prompt.py +4 -4
  648. package/agent/hermes_cli/secrets_cli.py +24 -0
  649. package/agent/hermes_cli/send_cmd.py +28 -2
  650. package/agent/hermes_cli/service_manager.py +166 -19
  651. package/agent/hermes_cli/session_listing.py +97 -0
  652. package/agent/hermes_cli/setup.py +158 -94
  653. package/agent/hermes_cli/setup_whatsapp_cloud.py +541 -0
  654. package/agent/hermes_cli/skills_config.py +8 -2
  655. package/agent/hermes_cli/skills_hub.py +149 -7
  656. package/agent/hermes_cli/status.py +2 -2
  657. package/agent/hermes_cli/subcommands/__init__.py +18 -0
  658. package/agent/hermes_cli/subcommands/_shared.py +29 -0
  659. package/agent/hermes_cli/subcommands/acp.py +52 -0
  660. package/agent/hermes_cli/subcommands/auth.py +109 -0
  661. package/agent/hermes_cli/subcommands/backup.py +38 -0
  662. package/agent/hermes_cli/subcommands/claw.py +92 -0
  663. package/agent/hermes_cli/subcommands/config.py +49 -0
  664. package/agent/hermes_cli/subcommands/cron.py +163 -0
  665. package/agent/hermes_cli/subcommands/dashboard.py +143 -0
  666. package/agent/hermes_cli/subcommands/debug.py +77 -0
  667. package/agent/hermes_cli/subcommands/doctor.py +35 -0
  668. package/agent/hermes_cli/subcommands/dump.py +28 -0
  669. package/agent/hermes_cli/subcommands/gateway.py +332 -0
  670. package/agent/hermes_cli/subcommands/gui.py +63 -0
  671. package/agent/hermes_cli/subcommands/hooks.py +77 -0
  672. package/agent/hermes_cli/subcommands/import_cmd.py +31 -0
  673. package/agent/hermes_cli/subcommands/insights.py +25 -0
  674. package/agent/hermes_cli/subcommands/login.py +78 -0
  675. package/agent/hermes_cli/subcommands/logout.py +28 -0
  676. package/agent/hermes_cli/subcommands/logs.py +78 -0
  677. package/agent/hermes_cli/subcommands/mcp.py +108 -0
  678. package/agent/hermes_cli/subcommands/memory.py +53 -0
  679. package/agent/hermes_cli/subcommands/model.py +72 -0
  680. package/agent/hermes_cli/subcommands/pairing.py +36 -0
  681. package/agent/hermes_cli/subcommands/plugins.py +94 -0
  682. package/agent/hermes_cli/subcommands/postinstall.py +23 -0
  683. package/agent/hermes_cli/subcommands/profile.py +203 -0
  684. package/agent/hermes_cli/subcommands/prompt_size.py +36 -0
  685. package/agent/hermes_cli/subcommands/security.py +62 -0
  686. package/agent/hermes_cli/subcommands/setup.py +58 -0
  687. package/agent/hermes_cli/subcommands/skills.py +298 -0
  688. package/agent/hermes_cli/subcommands/slack.py +60 -0
  689. package/agent/hermes_cli/subcommands/status.py +28 -0
  690. package/agent/hermes_cli/subcommands/tools.py +95 -0
  691. package/agent/hermes_cli/subcommands/uninstall.py +41 -0
  692. package/agent/hermes_cli/subcommands/update.py +70 -0
  693. package/agent/hermes_cli/subcommands/version.py +18 -0
  694. package/agent/hermes_cli/subcommands/webhook.py +76 -0
  695. package/agent/hermes_cli/subcommands/whatsapp.py +22 -0
  696. package/agent/hermes_cli/suggestions_cmd.py +153 -0
  697. package/agent/hermes_cli/telegram_managed_bot.py +358 -0
  698. package/agent/hermes_cli/tips.py +3 -4
  699. package/agent/hermes_cli/tools_config.py +155 -28
  700. package/agent/hermes_cli/uninstall.py +231 -35
  701. package/agent/hermes_cli/web_server.py +6188 -975
  702. package/agent/hermes_cli/win_pty_bridge.py +179 -0
  703. package/agent/hermes_cli/write_approval_commands.py +209 -0
  704. package/agent/hermes_constants.py +164 -33
  705. package/agent/hermes_logging.py +74 -2
  706. package/agent/hermes_state.py +919 -106
  707. package/agent/hermes_time.py +20 -0
  708. package/agent/locales/af.yaml +23 -0
  709. package/agent/locales/de.yaml +23 -0
  710. package/agent/locales/en.yaml +20 -0
  711. package/agent/locales/es.yaml +23 -0
  712. package/agent/locales/fr.yaml +23 -0
  713. package/agent/locales/ga.yaml +23 -0
  714. package/agent/locales/hu.yaml +23 -0
  715. package/agent/locales/it.yaml +23 -0
  716. package/agent/locales/ja.yaml +23 -0
  717. package/agent/locales/ko.yaml +23 -0
  718. package/agent/locales/pt.yaml +23 -0
  719. package/agent/locales/ru.yaml +23 -0
  720. package/agent/locales/tr.yaml +23 -0
  721. package/agent/locales/uk.yaml +23 -0
  722. package/agent/locales/zh-hant.yaml +23 -0
  723. package/agent/locales/zh.yaml +23 -0
  724. package/agent/model_tools.py +204 -40
  725. package/agent/optional-mcps/clawpump/manifest.yaml +15 -5
  726. package/agent/optional-mcps/clawpump-stdio/manifest.yaml +14 -4
  727. package/agent/optional-mcps/unreal-engine/manifest.yaml +54 -0
  728. package/agent/optional-skills/blockchain/hyperliquid/SKILL.md +2 -2
  729. package/agent/optional-skills/blockchain/hyperliquid/scripts/hyperliquid_client.py +1 -1
  730. package/agent/optional-skills/creative/kanban-video-orchestrator/SKILL.md +1 -1
  731. package/agent/optional-skills/creative/kanban-video-orchestrator/assets/setup.sh.tmpl +4 -3
  732. package/agent/optional-skills/creative/kanban-video-orchestrator/references/kanban-setup.md +6 -4
  733. package/agent/optional-skills/creative/kanban-video-orchestrator/references/tool-matrix.md +2 -2
  734. package/agent/{skills/software-development → optional-skills/devops}/hermes-s6-container-supervision/SKILL.md +2 -0
  735. package/agent/optional-skills/devops/watchers/SKILL.md +1 -1
  736. package/agent/optional-skills/devops/watchers/scripts/watch_github.py +2 -1
  737. package/agent/optional-skills/payments/mpp-agent/SKILL.md +124 -0
  738. package/agent/optional-skills/payments/stripe-link-cli/SKILL.md +184 -0
  739. package/agent/optional-skills/payments/stripe-projects/SKILL.md +120 -0
  740. package/agent/optional-skills/productivity/canvas/SKILL.md +1 -1
  741. package/agent/optional-skills/productivity/canvas/scripts/canvas_api.py +4 -1
  742. package/agent/optional-skills/productivity/shop/SKILL.md +224 -0
  743. package/agent/optional-skills/productivity/shop/references/catalog-mcp.md +236 -0
  744. package/agent/optional-skills/productivity/shop/references/direct-api.md +278 -0
  745. package/agent/optional-skills/productivity/shop/references/legal.md +3 -0
  746. package/agent/optional-skills/productivity/shop/references/safety.md +36 -0
  747. package/agent/optional-skills/productivity/shopify/SKILL.md +1 -1
  748. package/agent/optional-skills/productivity/siyuan/SKILL.md +1 -1
  749. package/agent/optional-skills/productivity/telephony/SKILL.md +4 -4
  750. package/agent/optional-skills/productivity/telephony/scripts/telephony.py +15 -15
  751. package/agent/optional-skills/security/1password/SKILL.md +1 -1
  752. package/agent/{skills/red-teaming → optional-skills/security}/godmode/SKILL.md +3 -4
  753. package/agent/{skills/red-teaming → optional-skills/security}/godmode/scripts/auto_jailbreak.py +3 -1
  754. package/agent/optional-skills/software-development/rest-graphql-debug/SKILL.md +1 -1
  755. package/agent/{skills → optional-skills}/software-development/subagent-driven-development/SKILL.md +5 -5
  756. package/agent/package-lock.json +4082 -7907
  757. package/agent/package.json +18 -3
  758. package/agent/plugins/browser/firecrawl/provider.py +4 -1
  759. package/agent/plugins/cron/__init__.py +344 -0
  760. package/agent/plugins/cron/chronos/__init__.py +241 -0
  761. package/agent/plugins/cron/chronos/_nas_client.py +123 -0
  762. package/agent/plugins/cron/chronos/plugin.yaml +9 -0
  763. package/agent/plugins/cron/chronos/verify.py +103 -0
  764. package/agent/plugins/dashboard_auth/basic/__init__.py +491 -0
  765. package/agent/plugins/dashboard_auth/basic/plugin.yaml +7 -0
  766. package/agent/plugins/dashboard_auth/nous/__init__.py +12 -14
  767. package/agent/plugins/dashboard_auth/self_hosted/__init__.py +736 -0
  768. package/agent/plugins/dashboard_auth/self_hosted/plugin.yaml +8 -0
  769. package/agent/plugins/disk-cleanup/disk_cleanup.py +100 -20
  770. package/agent/plugins/google_meet/audio_bridge.py +4 -0
  771. package/agent/plugins/google_meet/meet_bot.py +7 -1
  772. package/agent/plugins/hermes-achievements/dashboard/dist/index.js +9 -15
  773. package/agent/plugins/image_gen/fal/__init__.py +35 -6
  774. package/agent/plugins/image_gen/krea/__init__.py +56 -13
  775. package/agent/plugins/image_gen/openai/__init__.py +122 -24
  776. package/agent/plugins/image_gen/openai-codex/__init__.py +28 -2
  777. package/agent/plugins/image_gen/xai/__init__.py +92 -12
  778. package/agent/plugins/kanban/dashboard/dist/index.js +63 -48
  779. package/agent/plugins/kanban/dashboard/plugin_api.py +39 -35
  780. package/agent/plugins/memory/__init__.py +48 -5
  781. package/agent/plugins/memory/byterover/__init__.py +1 -0
  782. package/agent/plugins/memory/hindsight/README.md +1 -1
  783. package/agent/plugins/memory/hindsight/__init__.py +138 -24
  784. package/agent/plugins/memory/hindsight/plugin.yaml +1 -1
  785. package/agent/plugins/memory/honcho/README.md +13 -10
  786. package/agent/plugins/memory/honcho/cli.py +247 -122
  787. package/agent/plugins/memory/honcho/client.py +112 -102
  788. package/agent/plugins/memory/openviking/README.md +12 -1
  789. package/agent/plugins/memory/openviking/__init__.py +2281 -107
  790. package/agent/plugins/memory/openviking/plugin.yaml +1 -2
  791. package/agent/plugins/memory/supermemory/README.md +22 -10
  792. package/agent/plugins/memory/supermemory/__init__.py +142 -37
  793. package/agent/plugins/memory/supermemory/plugin.yaml +1 -1
  794. package/agent/plugins/model-providers/anthropic/__init__.py +1 -0
  795. package/agent/plugins/model-providers/bedrock/__init__.py +1 -0
  796. package/agent/plugins/model-providers/copilot-acp/__init__.py +1 -0
  797. package/agent/plugins/model-providers/custom/__init__.py +8 -2
  798. package/agent/plugins/model-providers/kimi-coding/__init__.py +16 -7
  799. package/agent/plugins/model-providers/minimax/__init__.py +60 -8
  800. package/agent/plugins/model-providers/opencode-zen/__init__.py +12 -3
  801. package/agent/plugins/model-providers/openrouter/__init__.py +75 -4
  802. package/agent/plugins/model-providers/xiaomi/__init__.py +2 -0
  803. package/agent/plugins/model-providers/zai/__init__.py +1 -0
  804. package/agent/plugins/observability/langfuse/__init__.py +147 -14
  805. package/agent/plugins/observability/nemo_relay/README.md +559 -0
  806. package/agent/plugins/observability/nemo_relay/__init__.py +962 -0
  807. package/agent/plugins/observability/nemo_relay/plugin.yaml +20 -0
  808. package/agent/plugins/platforms/discord/adapter.py +932 -61
  809. package/agent/plugins/platforms/discord/voice_mixer.py +379 -0
  810. package/agent/plugins/platforms/google_chat/adapter.py +9 -3
  811. package/agent/plugins/platforms/google_chat/oauth.py +1 -1
  812. package/agent/plugins/platforms/homeassistant/__init__.py +3 -0
  813. package/agent/{gateway/platforms/homeassistant.py → plugins/platforms/homeassistant/adapter.py} +128 -0
  814. package/agent/plugins/platforms/homeassistant/plugin.yaml +22 -0
  815. package/agent/plugins/platforms/irc/adapter.py +4 -1
  816. package/agent/plugins/platforms/line/adapter.py +16 -1
  817. package/agent/plugins/platforms/mattermost/adapter.py +100 -24
  818. package/agent/plugins/platforms/photon/README.md +179 -0
  819. package/agent/plugins/platforms/photon/__init__.py +4 -0
  820. package/agent/plugins/platforms/photon/adapter.py +1586 -0
  821. package/agent/plugins/platforms/photon/auth.py +1046 -0
  822. package/agent/plugins/platforms/photon/cli.py +439 -0
  823. package/agent/plugins/platforms/photon/plugin.yaml +88 -0
  824. package/agent/plugins/platforms/photon/sidecar/README.md +52 -0
  825. package/agent/plugins/platforms/photon/sidecar/index.mjs +720 -0
  826. package/agent/plugins/platforms/photon/sidecar/package-lock.json +1730 -0
  827. package/agent/plugins/platforms/photon/sidecar/package.json +25 -0
  828. package/agent/plugins/platforms/photon/sidecar/patch-spectrum-mixed-attachments.mjs +155 -0
  829. package/agent/plugins/platforms/raft/__init__.py +3 -0
  830. package/agent/plugins/platforms/raft/adapter.py +774 -0
  831. package/agent/plugins/platforms/raft/plugin.yaml +19 -0
  832. package/agent/plugins/platforms/simplex/adapter.py +777 -220
  833. package/agent/plugins/platforms/simplex/plugin.yaml +21 -2
  834. package/agent/plugins/platforms/teams/adapter.py +175 -5
  835. package/agent/plugins/plugin_utils.py +135 -0
  836. package/agent/plugins/video_gen/fal/__init__.py +10 -3
  837. package/agent/plugins/web/searxng/provider.py +15 -2
  838. package/agent/plugins/web/xai/provider.py +2 -2
  839. package/agent/providers/base.py +22 -3
  840. package/agent/pyproject.toml +115 -21
  841. package/agent/run_agent.py +733 -39
  842. package/agent/scripts/build_skills_index.py +51 -19
  843. package/agent/scripts/check_subprocess_stdin.py +177 -0
  844. package/agent/scripts/contributor_audit.py +2 -0
  845. package/agent/scripts/docker_config_migrate.py +67 -0
  846. package/agent/scripts/install.cmd +3 -3
  847. package/agent/scripts/install.ps1 +580 -154
  848. package/agent/scripts/install.sh +402 -185
  849. package/agent/scripts/lib/node-bootstrap.sh +39 -4
  850. package/agent/scripts/release.py +183 -0
  851. package/agent/scripts/run_tests.sh +1 -0
  852. package/agent/scripts/run_tests_parallel.py +18 -23
  853. package/agent/scripts/whatsapp-bridge/bridge.js +25 -4
  854. package/agent/setup.py +59 -0
  855. package/agent/skills/autonomous-ai-agents/codex/SKILL.md +19 -0
  856. package/agent/skills/autonomous-ai-agents/hermes-agent/SKILL.md +10 -3
  857. package/agent/skills/{mcp/native-mcp/SKILL.md → autonomous-ai-agents/hermes-agent/references/native-mcp.md} +0 -13
  858. package/agent/skills/{devops/webhook-subscriptions/SKILL.md → autonomous-ai-agents/hermes-agent/references/webhooks.md} +1 -11
  859. package/agent/skills/clawpump/SKILL.md +53 -5
  860. package/agent/skills/devops/kanban-orchestrator/SKILL.md +1 -0
  861. package/agent/skills/devops/kanban-worker/SKILL.md +1 -0
  862. package/agent/skills/github/github-auth/SKILL.md +2 -2
  863. package/agent/skills/github/github-auth/scripts/gh-env.sh +2 -2
  864. package/agent/skills/github/github-code-review/SKILL.md +2 -2
  865. package/agent/skills/github/github-issues/SKILL.md +2 -2
  866. package/agent/skills/github/github-pr-workflow/SKILL.md +2 -2
  867. package/agent/skills/github/github-repo-management/SKILL.md +2 -2
  868. package/agent/skills/media/gif-search/SKILL.md +1 -1
  869. package/agent/skills/media/youtube-content/SKILL.md +10 -7
  870. package/agent/skills/media/youtube-content/scripts/fetch_transcript.py +3 -3
  871. package/agent/skills/note-taking/obsidian/SKILL.md +1 -1
  872. package/agent/skills/productivity/airtable/SKILL.md +2 -2
  873. package/agent/skills/productivity/google-workspace/scripts/setup.py +33 -7
  874. package/agent/skills/productivity/notion/SKILL.md +2 -2
  875. package/agent/skills/productivity/teams-meeting-pipeline/SKILL.md +1 -1
  876. package/agent/skills/research/llm-wiki/SKILL.md +1 -1
  877. package/agent/skills/social-media/xurl/SKILL.md +9 -0
  878. package/agent/skills/software-development/hermes-agent-skill-authoring/SKILL.md +1 -1
  879. package/agent/skills/software-development/plan/SKILL.md +285 -5
  880. package/agent/skills/software-development/requesting-code-review/SKILL.md +2 -2
  881. package/agent/skills/software-development/simplify-code/SKILL.md +212 -0
  882. package/agent/skills/software-development/spike/SKILL.md +2 -2
  883. package/agent/skills/software-development/systematic-debugging/SKILL.md +1 -1
  884. package/agent/skills/software-development/test-driven-development/SKILL.md +1 -1
  885. package/agent/tools/approval.py +302 -4
  886. package/agent/tools/async_delegation.py +386 -0
  887. package/agent/tools/blueprints.py +325 -0
  888. package/agent/tools/browser_cdp_tool.py +3 -3
  889. package/agent/tools/browser_tool.py +34 -6
  890. package/agent/tools/checkpoint_manager.py +31 -1
  891. package/agent/tools/clarify_tool.py +55 -5
  892. package/agent/tools/code_execution_tool.py +31 -14
  893. package/agent/tools/computer_use/cua_backend.py +81 -3
  894. package/agent/tools/computer_use/tool.py +79 -5
  895. package/agent/tools/computer_use/vision_routing.py +55 -3
  896. package/agent/tools/credential_files.py +31 -12
  897. package/agent/tools/cronjob_tools.py +30 -20
  898. package/agent/tools/delegate_tool.py +356 -31
  899. package/agent/tools/env_probe.py +1 -0
  900. package/agent/tools/environments/docker.py +163 -8
  901. package/agent/tools/environments/file_sync.py +2 -1
  902. package/agent/tools/environments/local.py +74 -23
  903. package/agent/tools/environments/singularity.py +4 -1
  904. package/agent/tools/environments/ssh.py +78 -11
  905. package/agent/tools/file_operations.py +277 -41
  906. package/agent/tools/file_tools.py +166 -28
  907. package/agent/tools/image_generation_tool.py +515 -29
  908. package/agent/tools/kanban_tools.py +99 -0
  909. package/agent/tools/lazy_deps.py +33 -2
  910. package/agent/tools/mcp_oauth.py +5 -5
  911. package/agent/tools/mcp_oauth_manager.py +7 -5
  912. package/agent/tools/mcp_tool.py +840 -33
  913. package/agent/tools/memory_tool.py +335 -38
  914. package/agent/tools/osv_check.py +15 -1
  915. package/agent/tools/process_registry.py +155 -11
  916. package/agent/tools/read_extract.py +248 -0
  917. package/agent/tools/read_terminal_tool.py +93 -0
  918. package/agent/tools/schema_sanitizer.py +38 -0
  919. package/agent/tools/send_message_tool.py +163 -49
  920. package/agent/tools/session_search_tool.py +189 -7
  921. package/agent/tools/skill_manager_tool.py +202 -3
  922. package/agent/tools/skill_usage.py +52 -4
  923. package/agent/tools/skills_hub.py +184 -44
  924. package/agent/tools/skills_sync.py +232 -5
  925. package/agent/tools/skills_tool.py +125 -11
  926. package/agent/tools/terminal_tool.py +148 -26
  927. package/agent/tools/tirith_security.py +2 -0
  928. package/agent/tools/todo_tool.py +32 -1
  929. package/agent/tools/transcription_tools.py +13 -5
  930. package/agent/tools/tts_tool.py +332 -38
  931. package/agent/tools/url_safety.py +52 -1
  932. package/agent/tools/vision_tools.py +124 -39
  933. package/agent/tools/voice_mode.py +4 -3
  934. package/agent/tools/web_tools.py +45 -15
  935. package/agent/tools/write_approval.py +493 -0
  936. package/agent/toolsets.py +34 -10
  937. package/agent/trajectory_compressor.py +81 -10
  938. package/agent/tui_gateway/entry.py +43 -6
  939. package/agent/tui_gateway/server.py +3335 -330
  940. package/agent/tui_gateway/slash_worker.py +61 -0
  941. package/agent/tui_gateway/ws.py +67 -9
  942. package/agent/ui-tui/eslint.config.mjs +0 -4
  943. package/agent/ui-tui/package.json +6 -6
  944. package/agent/ui-tui/packages/hermes-ink/package.json +1 -1
  945. package/agent/ui-tui/packages/hermes-ink/src/ink/app-mouse.test.ts +34 -1
  946. package/agent/ui-tui/packages/hermes-ink/src/ink/app-rawmode-mouse.test.ts +91 -0
  947. package/agent/ui-tui/packages/hermes-ink/src/ink/components/App.tsx +35 -2
  948. package/agent/ui-tui/packages/hermes-ink/src/ink/events/input-event.ts +4 -11
  949. package/agent/ui-tui/packages/hermes-ink/src/ink/parse-keypress.test.ts +23 -57
  950. package/agent/ui-tui/packages/hermes-ink/src/ink/parse-keypress.ts +11 -135
  951. package/agent/ui-tui/packages/hermes-ink/src/ink/termio/tokenize.test.ts +185 -0
  952. package/agent/ui-tui/packages/hermes-ink/src/ink/termio/tokenize.ts +37 -3
  953. package/agent/ui-tui/packages/hermes-ink/src/utils/execFileNoThrow.ts +5 -5
  954. package/agent/ui-tui/src/__tests__/appChromeStatusRule.test.tsx +217 -0
  955. package/agent/ui-tui/src/__tests__/appChromeStatusRuleDevCredits.test.tsx +73 -0
  956. package/agent/ui-tui/src/__tests__/approvalAction.test.ts +11 -0
  957. package/agent/ui-tui/src/__tests__/billingCommand.test.ts +301 -0
  958. package/agent/ui-tui/src/__tests__/blockLayout.test.ts +122 -0
  959. package/agent/ui-tui/src/__tests__/brandingMcpCount.test.ts +111 -0
  960. package/agent/ui-tui/src/__tests__/completionApply.test.ts +51 -0
  961. package/agent/ui-tui/src/__tests__/createGatewayEventHandler.test.ts +487 -2
  962. package/agent/ui-tui/src/__tests__/createSlashHandler.test.ts +54 -0
  963. package/agent/ui-tui/src/__tests__/creditsCommand.test.ts +144 -0
  964. package/agent/ui-tui/src/__tests__/gatewayClient.test.ts +120 -99
  965. package/agent/ui-tui/src/__tests__/gracefulExit.test.ts +11 -0
  966. package/agent/ui-tui/src/__tests__/memoryMonitor.test.ts +102 -0
  967. package/agent/ui-tui/src/__tests__/paths.test.ts +41 -1
  968. package/agent/ui-tui/src/__tests__/terminalModes.test.ts +22 -0
  969. package/agent/ui-tui/src/__tests__/text.test.ts +23 -0
  970. package/agent/ui-tui/src/__tests__/textInputFastEcho.test.ts +37 -0
  971. package/agent/ui-tui/src/__tests__/turnControllerNotice.test.ts +43 -0
  972. package/agent/ui-tui/src/__tests__/useInputHandlers.test.ts +38 -1
  973. package/agent/ui-tui/src/__tests__/virtualHeights.test.ts +8 -0
  974. package/agent/ui-tui/src/app/createGatewayEventHandler.ts +102 -7
  975. package/agent/ui-tui/src/app/interfaces.ts +64 -1
  976. package/agent/ui-tui/src/app/overlayStore.ts +18 -2
  977. package/agent/ui-tui/src/app/slash/commands/billing.ts +332 -0
  978. package/agent/ui-tui/src/app/slash/commands/core.ts +31 -2
  979. package/agent/ui-tui/src/app/slash/commands/credits.ts +57 -0
  980. package/agent/ui-tui/src/app/slash/commands/ops.ts +28 -0
  981. package/agent/ui-tui/src/app/slash/commands/session.ts +32 -4
  982. package/agent/ui-tui/src/app/slash/registry.ts +4 -0
  983. package/agent/ui-tui/src/app/turnController.ts +145 -2
  984. package/agent/ui-tui/src/app/uiStore.ts +2 -0
  985. package/agent/ui-tui/src/app/useInputHandlers.ts +42 -4
  986. package/agent/ui-tui/src/app/useMainApp.ts +54 -8
  987. package/agent/ui-tui/src/app/useSessionLifecycle.ts +40 -31
  988. package/agent/ui-tui/src/app/useSubmission.ts +23 -31
  989. package/agent/ui-tui/src/components/appChrome.tsx +112 -5
  990. package/agent/ui-tui/src/components/appLayout.tsx +9 -0
  991. package/agent/ui-tui/src/components/appOverlays.tsx +25 -1
  992. package/agent/ui-tui/src/components/billingOverlay.tsx +684 -0
  993. package/agent/ui-tui/src/components/branding.tsx +15 -3
  994. package/agent/ui-tui/src/components/messageLine.tsx +25 -3
  995. package/agent/ui-tui/src/components/pluginsHub.tsx +238 -0
  996. package/agent/ui-tui/src/components/prompts.tsx +31 -17
  997. package/agent/ui-tui/src/components/streamingAssistant.tsx +63 -55
  998. package/agent/ui-tui/src/components/textInput.tsx +16 -0
  999. package/agent/ui-tui/src/config/env.ts +12 -0
  1000. package/agent/ui-tui/src/config/limits.ts +13 -0
  1001. package/agent/ui-tui/src/domain/blockLayout.ts +146 -0
  1002. package/agent/ui-tui/src/domain/paths.ts +24 -0
  1003. package/agent/ui-tui/src/domain/slash.ts +40 -0
  1004. package/agent/ui-tui/src/entry.tsx +35 -4
  1005. package/agent/ui-tui/src/gatewayClient.ts +22 -10
  1006. package/agent/ui-tui/src/gatewayTypes.ts +130 -1
  1007. package/agent/ui-tui/src/lib/gracefulExit.ts +24 -4
  1008. package/agent/ui-tui/src/lib/memory.test.ts +162 -0
  1009. package/agent/ui-tui/src/lib/memory.ts +60 -1
  1010. package/agent/ui-tui/src/lib/memoryMonitor.ts +79 -4
  1011. package/agent/ui-tui/src/lib/osc52.ts +1 -1
  1012. package/agent/ui-tui/src/lib/text.test.ts +32 -1
  1013. package/agent/ui-tui/src/lib/text.ts +29 -2
  1014. package/agent/ui-tui/src/lib/virtualHeights.ts +13 -0
  1015. package/agent/ui-tui/src/types.ts +5 -0
  1016. package/agent/ui-tui/tsconfig.build.json +0 -1
  1017. package/agent/ui-tui/tsconfig.json +2 -1
  1018. package/agent/utils.py +66 -2
  1019. package/agent/uv.lock +308 -696
  1020. package/agent/web/index.html +2 -2
  1021. package/agent/web/package.json +11 -6
  1022. package/agent/web/public/claw-bg.webp +0 -0
  1023. package/agent/web/public/claw-logo.webp +0 -0
  1024. package/agent/web/src/App.tsx +138 -48
  1025. package/agent/web/src/components/AutomationBlueprints.tsx +225 -0
  1026. package/agent/web/src/components/Backdrop.tsx +15 -0
  1027. package/agent/web/src/components/ChatSessionList.tsx +260 -0
  1028. package/agent/web/src/components/ChatSidebar.tsx +262 -78
  1029. package/agent/web/src/components/ConfirmDialog.tsx +122 -0
  1030. package/agent/web/src/components/ModelPickerDialog.tsx +111 -16
  1031. package/agent/web/src/components/ModelReloadConfirm.tsx +40 -0
  1032. package/agent/web/src/components/ProfileScopeBanner.tsx +30 -0
  1033. package/agent/web/src/components/ProfileSwitcher.tsx +67 -0
  1034. package/agent/web/src/components/ReasoningPicker.tsx +167 -0
  1035. package/agent/web/src/components/SkillEditorDialog.tsx +215 -0
  1036. package/agent/web/src/components/ThemeSwitcher.tsx +119 -4
  1037. package/agent/web/src/components/ToolsetConfigDrawer.tsx +457 -0
  1038. package/agent/web/src/contexts/PageHeaderProvider.tsx +7 -4
  1039. package/agent/web/src/contexts/ProfileProvider.tsx +137 -0
  1040. package/agent/web/src/contexts/SystemActions.tsx +6 -8
  1041. package/agent/web/src/contexts/profile-context.ts +19 -0
  1042. package/agent/web/src/contexts/useProfileScope.ts +6 -0
  1043. package/agent/web/src/i18n/af.ts +5 -4
  1044. package/agent/web/src/i18n/de.ts +5 -4
  1045. package/agent/web/src/i18n/en.ts +58 -4
  1046. package/agent/web/src/i18n/es.ts +5 -3
  1047. package/agent/web/src/i18n/fr.ts +5 -3
  1048. package/agent/web/src/i18n/ga.ts +5 -4
  1049. package/agent/web/src/i18n/hu.ts +5 -4
  1050. package/agent/web/src/i18n/it.ts +5 -4
  1051. package/agent/web/src/i18n/ja.ts +5 -4
  1052. package/agent/web/src/i18n/ko.ts +5 -4
  1053. package/agent/web/src/i18n/pt.ts +5 -3
  1054. package/agent/web/src/i18n/ru.ts +5 -4
  1055. package/agent/web/src/i18n/tr.ts +5 -4
  1056. package/agent/web/src/i18n/types.ts +59 -1
  1057. package/agent/web/src/i18n/uk.ts +5 -3
  1058. package/agent/web/src/i18n/zh-hant.ts +5 -4
  1059. package/agent/web/src/i18n/zh.ts +5 -4
  1060. package/agent/web/src/index.css +2 -2
  1061. package/agent/web/src/lib/api.ts +819 -52
  1062. package/agent/web/src/lib/dashboard-flags.ts +16 -7
  1063. package/agent/web/src/lib/reasoning-effort.test.ts +48 -0
  1064. package/agent/web/src/lib/reasoning-effort.ts +36 -0
  1065. package/agent/web/src/lib/session-refresh.test.ts +21 -0
  1066. package/agent/web/src/lib/session-refresh.ts +26 -0
  1067. package/agent/web/src/pages/ChannelsPage.tsx +529 -68
  1068. package/agent/web/src/pages/ChatPage.tsx +249 -56
  1069. package/agent/web/src/pages/ConfigPage.tsx +11 -1
  1070. package/agent/web/src/pages/CronPage.tsx +219 -31
  1071. package/agent/web/src/pages/EnvPage.tsx +25 -6
  1072. package/agent/web/src/pages/FilesPage.tsx +525 -0
  1073. package/agent/web/src/pages/McpPage.tsx +80 -3
  1074. package/agent/web/src/pages/ModelsPage.tsx +97 -12
  1075. package/agent/web/src/pages/PluginsPage.tsx +1 -1
  1076. package/agent/web/src/pages/ProfileBuilderPage.tsx +611 -0
  1077. package/agent/web/src/pages/ProfilesPage.tsx +1038 -172
  1078. package/agent/web/src/pages/SessionsPage.tsx +144 -13
  1079. package/agent/web/src/pages/SkillsPage.tsx +851 -70
  1080. package/agent/web/src/pages/SystemPage.tsx +340 -4
  1081. package/agent/web/src/pages/WalletPage.tsx +401 -0
  1082. package/agent/web/src/pages/WebhooksPage.tsx +145 -15
  1083. package/agent/web/src/pages/X402Page.tsx +207 -0
  1084. package/agent/web/src/plugins/registry.ts +28 -11
  1085. package/agent/web/src/plugins/sdk.d.ts +160 -0
  1086. package/agent/web/src/themes/context.tsx +112 -5
  1087. package/agent/web/src/themes/fonts.ts +167 -0
  1088. package/agent/web/src/themes/index.ts +7 -0
  1089. package/agent/web/tsconfig.app.json +0 -1
  1090. package/agent/web/vite.config.ts +1 -8
  1091. package/agent/web/vitest.config.ts +16 -0
  1092. package/package.json +1 -1
  1093. package/agent/apps/desktop/package-lock.json +0 -18363
  1094. package/agent/apps/desktop/src/app/chat/composer/skin-slash-popover.tsx +0 -56
  1095. package/agent/apps/desktop/src/components/assistant-ui/thread-virtualizer.tsx +0 -382
  1096. package/agent/apps/desktop/src/components/assistant-ui/todo-tool.tsx +0 -109
  1097. package/agent/apps/desktop/src/components/chat/generated-image-context.tsx +0 -19
  1098. package/agent/optional-skills/productivity/shop-app/SKILL.md +0 -340
  1099. package/agent/skills/autonomous-ai-agents/kanban-codex-lane/SKILL.md +0 -277
  1100. package/agent/skills/autonomous-ai-agents/kanban-codex-lane/templates/pmb-codex-lane-prompt.md +0 -57
  1101. package/agent/skills/diagramming/DESCRIPTION.md +0 -3
  1102. package/agent/skills/domain/DESCRIPTION.md +0 -24
  1103. package/agent/skills/gifs/DESCRIPTION.md +0 -3
  1104. package/agent/skills/inference-sh/DESCRIPTION.md +0 -19
  1105. package/agent/skills/mcp/DESCRIPTION.md +0 -3
  1106. package/agent/skills/media/spotify/SKILL.md +0 -135
  1107. package/agent/skills/mlops/training/DESCRIPTION.md +0 -3
  1108. package/agent/skills/mlops/vector-databases/DESCRIPTION.md +0 -3
  1109. package/agent/skills/productivity/linear/SKILL.md +0 -380
  1110. package/agent/skills/productivity/linear/scripts/linear_api.py +0 -445
  1111. package/agent/skills/software-development/debugging-hermes-tui-commands/SKILL.md +0 -152
  1112. package/agent/skills/software-development/writing-plans/SKILL.md +0 -297
  1113. package/agent/ui-tui/package-lock.json +0 -7449
  1114. package/agent/ui-tui/packages/hermes-ink/package-lock.json +0 -1289
  1115. package/agent/web/package-lock.json +0 -8887
  1116. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/PORT_NOTES.md +0 -0
  1117. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/SKILL.md +0 -0
  1118. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/prompts/system.md +0 -0
  1119. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/palettes/macaron.md +0 -0
  1120. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/palettes/mono-ink.md +0 -0
  1121. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/palettes/neon.md +0 -0
  1122. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/palettes/warm.md +0 -0
  1123. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/prompt-construction.md +0 -0
  1124. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/style-presets.md +0 -0
  1125. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/blueprint.md +0 -0
  1126. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/chalkboard.md +0 -0
  1127. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/editorial.md +0 -0
  1128. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/elegant.md +0 -0
  1129. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/fantasy-animation.md +0 -0
  1130. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/flat-doodle.md +0 -0
  1131. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/flat.md +0 -0
  1132. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/ink-notes.md +0 -0
  1133. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/intuition-machine.md +0 -0
  1134. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/minimal.md +0 -0
  1135. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/nature.md +0 -0
  1136. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/notion.md +0 -0
  1137. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/pixel-art.md +0 -0
  1138. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/playful.md +0 -0
  1139. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/retro.md +0 -0
  1140. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/scientific.md +0 -0
  1141. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/screen-print.md +0 -0
  1142. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/sketch-notes.md +0 -0
  1143. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/sketch.md +0 -0
  1144. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/vector-illustration.md +0 -0
  1145. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/vintage.md +0 -0
  1146. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/warm.md +0 -0
  1147. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles/watercolor.md +0 -0
  1148. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/styles.md +0 -0
  1149. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/usage.md +0 -0
  1150. /package/agent/{skills → optional-skills}/creative/baoyu-article-illustrator/references/workflow.md +0 -0
  1151. /package/agent/{skills → optional-skills}/creative/baoyu-comic/PORT_NOTES.md +0 -0
  1152. /package/agent/{skills → optional-skills}/creative/baoyu-comic/SKILL.md +0 -0
  1153. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/analysis-framework.md +0 -0
  1154. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/art-styles/chalk.md +0 -0
  1155. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/art-styles/ink-brush.md +0 -0
  1156. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/art-styles/ligne-claire.md +0 -0
  1157. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/art-styles/manga.md +0 -0
  1158. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/art-styles/minimalist.md +0 -0
  1159. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/art-styles/realistic.md +0 -0
  1160. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/auto-selection.md +0 -0
  1161. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/base-prompt.md +0 -0
  1162. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/character-template.md +0 -0
  1163. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/layouts/cinematic.md +0 -0
  1164. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/layouts/dense.md +0 -0
  1165. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/layouts/four-panel.md +0 -0
  1166. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/layouts/mixed.md +0 -0
  1167. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/layouts/splash.md +0 -0
  1168. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/layouts/standard.md +0 -0
  1169. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/layouts/webtoon.md +0 -0
  1170. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/ohmsha-guide.md +0 -0
  1171. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/partial-workflows.md +0 -0
  1172. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/presets/concept-story.md +0 -0
  1173. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/presets/four-panel.md +0 -0
  1174. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/presets/ohmsha.md +0 -0
  1175. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/presets/shoujo.md +0 -0
  1176. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/presets/wuxia.md +0 -0
  1177. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/storyboard-template.md +0 -0
  1178. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/tones/action.md +0 -0
  1179. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/tones/dramatic.md +0 -0
  1180. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/tones/energetic.md +0 -0
  1181. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/tones/neutral.md +0 -0
  1182. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/tones/romantic.md +0 -0
  1183. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/tones/vintage.md +0 -0
  1184. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/tones/warm.md +0 -0
  1185. /package/agent/{skills → optional-skills}/creative/baoyu-comic/references/workflow.md +0 -0
  1186. /package/agent/{skills → optional-skills}/creative/creative-ideation/SKILL.md +0 -0
  1187. /package/agent/{skills → optional-skills}/creative/creative-ideation/references/full-prompt-library.md +0 -0
  1188. /package/agent/{skills → optional-skills}/creative/pixel-art/ATTRIBUTION.md +0 -0
  1189. /package/agent/{skills → optional-skills}/creative/pixel-art/SKILL.md +0 -0
  1190. /package/agent/{skills → optional-skills}/creative/pixel-art/references/palettes.md +0 -0
  1191. /package/agent/{skills → optional-skills}/creative/pixel-art/scripts/__init__.py +0 -0
  1192. /package/agent/{skills → optional-skills}/creative/pixel-art/scripts/palettes.py +0 -0
  1193. /package/agent/{skills → optional-skills}/creative/pixel-art/scripts/pixel_art.py +0 -0
  1194. /package/agent/{skills → optional-skills}/creative/pixel-art/scripts/pixel_art_video.py +0 -0
  1195. /package/agent/{skills/mlops/inference → optional-skills/mlops}/obliteratus/SKILL.md +0 -0
  1196. /package/agent/{skills/mlops/inference → optional-skills/mlops}/obliteratus/references/analysis-modules.md +0 -0
  1197. /package/agent/{skills/mlops/inference → optional-skills/mlops}/obliteratus/references/methods-guide.md +0 -0
  1198. /package/agent/{skills/mlops/inference → optional-skills/mlops}/obliteratus/templates/abliteration-config.yaml +0 -0
  1199. /package/agent/{skills/mlops/inference → optional-skills/mlops}/obliteratus/templates/analysis-study.yaml +0 -0
  1200. /package/agent/{skills/mlops/inference → optional-skills/mlops}/obliteratus/templates/batch-abliteration.yaml +0 -0
  1201. /package/agent/{skills → optional-skills}/mlops/research/DESCRIPTION.md +0 -0
  1202. /package/agent/{skills → optional-skills}/mlops/research/dspy/SKILL.md +0 -0
  1203. /package/agent/{skills → optional-skills}/mlops/research/dspy/references/examples.md +0 -0
  1204. /package/agent/{skills → optional-skills}/mlops/research/dspy/references/modules.md +0 -0
  1205. /package/agent/{skills → optional-skills}/mlops/research/dspy/references/optimizers.md +0 -0
  1206. /package/agent/{skills/red-teaming → optional-skills/security}/godmode/references/jailbreak-templates.md +0 -0
  1207. /package/agent/{skills/red-teaming → optional-skills/security}/godmode/references/refusal-detection.md +0 -0
  1208. /package/agent/{skills/red-teaming → optional-skills/security}/godmode/scripts/godmode_race.py +0 -0
  1209. /package/agent/{skills/red-teaming → optional-skills/security}/godmode/scripts/load_godmode.py +0 -0
  1210. /package/agent/{skills/red-teaming → optional-skills/security}/godmode/scripts/parseltongue.py +0 -0
  1211. /package/agent/{skills/red-teaming → optional-skills/security}/godmode/templates/prefill-subtle.json +0 -0
  1212. /package/agent/{skills/red-teaming → optional-skills/security}/godmode/templates/prefill.json +0 -0
  1213. /package/agent/{skills → optional-skills}/software-development/subagent-driven-development/references/context-budget-discipline.md +0 -0
  1214. /package/agent/{skills → optional-skills}/software-development/subagent-driven-development/references/gates-taxonomy.md +0 -0
@@ -41,11 +41,59 @@ function setSessionHeader(headers: Headers, token: string): void {
41
41
  }
42
42
  }
43
43
 
44
+ // ── Global management-profile scope ──────────────────────────────────
45
+ // The dashboard is a machine-level management surface: one header switcher
46
+ // (ProfileProvider in App.tsx) decides which profile the management pages
47
+ // read/write, and fetchJSON transparently appends ?profile=<name> to the
48
+ // profile-scoped endpoint families below. "" = the dashboard process's own
49
+ // profile (legacy behavior). Calls that already carry an explicit profile
50
+ // (e.g. ProfileBuilder writes) are left untouched — explicit beats global.
51
+ let _managementProfile = "";
52
+
53
+ export function setManagementProfile(name: string): void {
54
+ _managementProfile = (name || "").trim();
55
+ }
56
+
57
+ export function getManagementProfile(): string {
58
+ return _managementProfile;
59
+ }
60
+
61
+ // Endpoint families that honor ?profile= on the backend (web_server.py
62
+ // _profile_scope or explicit per-profile DB opens). Anything else — ops,
63
+ // pairing, cron (which has its own per-job profile params), profiles
64
+ // themselves — is machine-global or self-scoped and must NOT be rewritten.
65
+ const PROFILE_SCOPED_PREFIXES = [
66
+ "/api/status",
67
+ "/api/gateway",
68
+ "/api/analytics",
69
+ "/api/skills",
70
+ "/api/tools/toolsets",
71
+ "/api/config",
72
+ "/api/env",
73
+ "/api/mcp",
74
+ "/api/messaging/platforms",
75
+ "/api/messaging/telegram/onboarding",
76
+ "/api/model/info",
77
+ "/api/model/set",
78
+ "/api/model/auxiliary",
79
+ "/api/model/options",
80
+ ];
81
+
82
+ function withManagementProfile(url: string): string {
83
+ if (!_managementProfile) return url;
84
+ if (url.includes("profile=")) return url; // explicit param wins
85
+ const path = url.split("?")[0];
86
+ if (!PROFILE_SCOPED_PREFIXES.some((p) => path.startsWith(p))) return url;
87
+ const sep = url.includes("?") ? "&" : "?";
88
+ return `${url}${sep}profile=${encodeURIComponent(_managementProfile)}`;
89
+ }
90
+
44
91
  export async function fetchJSON<T>(
45
92
  url: string,
46
93
  init?: RequestInit,
47
94
  options?: FetchJSONOptions,
48
95
  ): Promise<T> {
96
+ url = withManagementProfile(url);
49
97
  // Inject the session token into all /api/ requests.
50
98
  const headers = new Headers(init?.headers);
51
99
  const token = window.__HERMES_SESSION_TOKEN__;
@@ -192,8 +240,147 @@ export async function buildWsAuthParam(): Promise<[string, string]> {
192
240
  return ["token", token];
193
241
  }
194
242
 
243
+ /**
244
+ * Authenticated ``fetch`` for dashboard ``/api/...`` requests that aren't
245
+ * plain JSON — file uploads (``FormData``), binary downloads (blobs), etc.
246
+ * Mirrors ``fetchJSON``'s auth handling but returns the raw ``Response`` so
247
+ * the caller can read ``.blob()`` / ``.formData()`` / stream it.
248
+ *
249
+ * Auth, in both modes, exactly as ``fetchJSON`` does it:
250
+ * - loopback / ``--insecure``: attach the ``X-Hermes-Session-Token`` header.
251
+ * - gated OAuth: no token header (it's absent by design); the
252
+ * ``hermes_session_at`` cookie rides along via ``credentials: 'include'``.
253
+ *
254
+ * Unlike ``fetchJSON`` this does NOT parse the body, does NOT throw on
255
+ * non-2xx (the caller decides — a 404 on a download is meaningful), and
256
+ * does NOT run the global 401 → /login redirect (binary endpoints aren't
257
+ * navigation targets). Callers that want the redirect behaviour should use
258
+ * ``fetchJSON``.
259
+ */
260
+ export async function authedFetch(
261
+ url: string,
262
+ init?: RequestInit,
263
+ ): Promise<Response> {
264
+ const headers = new Headers(init?.headers);
265
+ const token = window.__HERMES_SESSION_TOKEN__;
266
+ if (token) {
267
+ setSessionHeader(headers, token);
268
+ }
269
+ return fetch(`${BASE}${url}`, {
270
+ ...init,
271
+ headers,
272
+ credentials: init?.credentials ?? "include",
273
+ });
274
+ }
275
+
276
+ /**
277
+ * Build an absolute ``ws(s)://`` URL for a dashboard WebSocket endpoint,
278
+ * with the correct auth query param appended for the active mode (fresh
279
+ * single-use ``ticket`` in gated mode, ``token`` in loopback). Plugins and
280
+ * the SPA should use this instead of hand-assembling a WS URL + reading
281
+ * ``window.__HERMES_SESSION_TOKEN__`` directly, so the gated-mode ticket
282
+ * path can never be forgotten.
283
+ *
284
+ * ``path`` is the dashboard-relative path (e.g.
285
+ * ``"/api/plugins/kanban/events"``); the base-path prefix and host are
286
+ * applied here. Extra query params can be supplied via ``params`` and are
287
+ * merged before the auth param.
288
+ */
289
+ export async function buildWsUrl(
290
+ path: string,
291
+ params?: Record<string, string>,
292
+ ): Promise<string> {
293
+ const [authName, authValue] = await buildWsAuthParam();
294
+ const proto = window.location.protocol === "https:" ? "wss:" : "ws:";
295
+ const qs = new URLSearchParams(params ?? {});
296
+ qs.set(authName, authValue);
297
+ return `${proto}//${window.location.host}${BASE}${path}?${qs}`;
298
+ }
299
+
300
+ /** Build a ``?profile=<name>`` query suffix, or "" when unset.
301
+ *
302
+ * Used by the skills/toolsets endpoints so the dashboard can manage a
303
+ * profile other than the one the server process runs under. */
304
+ function profileQuery(profile?: string): string {
305
+ return profile ? `?profile=${encodeURIComponent(profile)}` : "";
306
+ }
307
+
308
+ function appendProfileParam(url: string, profile?: string): string {
309
+ if (!profile || url.includes("profile=")) return url;
310
+ return `${url}${url.includes("?") ? "&" : "?"}profile=${encodeURIComponent(profile)}`;
311
+ }
312
+
313
+ export interface AgentWalletBalance {
314
+ agent_id: string;
315
+ name?: string | null;
316
+ wallet_address: string | null;
317
+ sol_balance: number | null;
318
+ usdc_balance: number | null;
319
+ updated_at: string;
320
+ }
321
+
322
+ export interface WalletBalancesResponse {
323
+ ok: boolean;
324
+ error?: string;
325
+ wallets: AgentWalletBalance[];
326
+ }
327
+
328
+ export interface WalletTransferInput {
329
+ agent_id: string;
330
+ to: string;
331
+ amount: number;
332
+ token: string;
333
+ add_to_whitelist?: boolean;
334
+ label?: string;
335
+ }
336
+
337
+ export interface WalletTransferResponse {
338
+ ok: boolean;
339
+ error?: string;
340
+ code?: string;
341
+ result?: unknown;
342
+ }
343
+
344
+ export interface X402Pricing {
345
+ network?: string;
346
+ asset?: string;
347
+ scheme?: string;
348
+ priceUsdc?: number | null;
349
+ priceLabel?: string;
350
+ }
351
+
352
+ export interface X402Result {
353
+ resourceUrl?: string;
354
+ name?: string;
355
+ description?: string;
356
+ category?: string;
357
+ method?: string;
358
+ host?: string;
359
+ match?: string;
360
+ qualityScore?: number | null;
361
+ verified?: boolean;
362
+ pricing?: X402Pricing[];
363
+ }
364
+
365
+ export interface X402SearchResponse {
366
+ ok: boolean;
367
+ error?: string;
368
+ query?: string;
369
+ results: X402Result[];
370
+ }
371
+
195
372
  export const api = {
196
373
  getStatus: () => fetchJSON<StatusResponse>("/api/status"),
374
+ getWalletBalances: () =>
375
+ fetchJSON<WalletBalancesResponse>("/api/wallet/balances"),
376
+ searchX402: (q: string) =>
377
+ fetchJSON<X402SearchResponse>(`/api/x402/search?q=${encodeURIComponent(q)}`),
378
+ transferWallet: (body: WalletTransferInput) =>
379
+ fetchJSON<WalletTransferResponse>("/api/wallet/transfer", {
380
+ method: "POST",
381
+ headers: { "Content-Type": "application/json" },
382
+ body: JSON.stringify(body),
383
+ }),
197
384
  /**
198
385
  * Identity probe for the dashboard auth gate (Phase 7).
199
386
  *
@@ -226,47 +413,107 @@ export const api = {
226
413
  window.location.assign("/login");
227
414
  return r;
228
415
  }),
229
- getSessions: (limit = 20, offset = 0) =>
230
- fetchJSON<PaginatedSessions>(`/api/sessions?limit=${limit}&offset=${offset}`),
231
- getSessionMessages: (id: string) =>
232
- fetchJSON<SessionMessagesResponse>(`/api/sessions/${encodeURIComponent(id)}/messages`),
416
+ getSessions: (
417
+ limit = 20,
418
+ offset = 0,
419
+ profile = getManagementProfile(),
420
+ order: "created" | "recent" = "created",
421
+ ) =>
422
+ fetchJSON<PaginatedSessions>(
423
+ appendProfileParam(
424
+ `/api/sessions?limit=${limit}&offset=${offset}&order=${order}`,
425
+ profile,
426
+ ),
427
+ ),
428
+ getSessionMessages: (id: string, profile = getManagementProfile()) =>
429
+ fetchJSON<SessionMessagesResponse>(
430
+ appendProfileParam(`/api/sessions/${encodeURIComponent(id)}/messages`, profile),
431
+ ),
233
432
  getSessionLatestDescendant: (id: string) =>
234
433
  fetchJSON<SessionLatestDescendantResponse>(
235
434
  `/api/sessions/${encodeURIComponent(id)}/latest-descendant`,
236
435
  ),
237
- deleteSession: (id: string) =>
238
- fetchJSON<{ ok: boolean }>(`/api/sessions/${encodeURIComponent(id)}`, {
239
- method: "DELETE",
240
- }),
241
- getEmptySessionsCount: () =>
242
- fetchJSON<{ count: number }>("/api/sessions/empty/count"),
243
- deleteEmptySessions: () =>
244
- fetchJSON<{ ok: boolean; deleted: number }>("/api/sessions/empty", {
245
- method: "DELETE",
246
- }),
247
- bulkDeleteSessions: (ids: string[]) =>
436
+ deleteSession: (id: string, profile = getManagementProfile()) =>
437
+ fetchJSON<{ ok: boolean }>(
438
+ appendProfileParam(`/api/sessions/${encodeURIComponent(id)}`, profile),
439
+ {
440
+ method: "DELETE",
441
+ },
442
+ ),
443
+ getEmptySessionsCount: (profile = getManagementProfile()) =>
444
+ fetchJSON<{ count: number }>(
445
+ appendProfileParam("/api/sessions/empty/count", profile),
446
+ ),
447
+ deleteEmptySessions: (profile = getManagementProfile()) =>
448
+ fetchJSON<{ ok: boolean; deleted: number }>(
449
+ appendProfileParam("/api/sessions/empty", profile),
450
+ {
451
+ method: "DELETE",
452
+ },
453
+ ),
454
+ bulkDeleteSessions: (ids: string[], profile = getManagementProfile()) =>
248
455
  fetchJSON<{ ok: boolean; deleted: number }>("/api/sessions/bulk-delete", {
249
456
  method: "POST",
250
457
  headers: { "Content-Type": "application/json" },
251
- body: JSON.stringify({ ids }),
458
+ body: JSON.stringify({ ids, profile: profile || undefined }),
252
459
  }),
253
- renameSession: (id: string, title: string) =>
460
+ renameSession: (id: string, title: string, profile = getManagementProfile()) =>
254
461
  fetchJSON<{ ok: boolean; title: string }>(
255
462
  `/api/sessions/${encodeURIComponent(id)}`,
256
463
  {
257
464
  method: "PATCH",
258
465
  headers: { "Content-Type": "application/json" },
259
- body: JSON.stringify({ title }),
466
+ body: JSON.stringify({ title, profile: profile || undefined }),
260
467
  },
261
468
  ),
262
- getSessionStats: () => fetchJSON<SessionStoreStats>("/api/sessions/stats"),
263
- exportSessionUrl: (id: string) =>
264
- `/api/sessions/${encodeURIComponent(id)}/export`,
265
- pruneSessions: (older_than_days: number, source?: string) =>
469
+ getSessionStats: (profile = getManagementProfile()) =>
470
+ fetchJSON<SessionStoreStats>(appendProfileParam("/api/sessions/stats", profile)),
471
+ exportSessionUrl: (id: string, profile = getManagementProfile()) =>
472
+ appendProfileParam(`/api/sessions/${encodeURIComponent(id)}/export`, profile),
473
+ pruneSessions: (
474
+ older_than_days: number,
475
+ source?: string,
476
+ profile = getManagementProfile(),
477
+ ) =>
266
478
  fetchJSON<{ ok: boolean; removed: number }>("/api/sessions/prune", {
267
479
  method: "POST",
268
480
  headers: { "Content-Type": "application/json" },
269
- body: JSON.stringify({ older_than_days, source }),
481
+ body: JSON.stringify({ older_than_days, source, profile: profile || undefined }),
482
+ }),
483
+ listFiles: (path?: string) => {
484
+ const query = path ? `?path=${encodeURIComponent(path)}` : "";
485
+ return fetchJSON<ManagedFilesResponse>(`/api/files${query}`);
486
+ },
487
+ readFile: (path: string) =>
488
+ fetchJSON<ManagedFileReadResponse>(
489
+ `/api/files/read?path=${encodeURIComponent(path)}`,
490
+ ),
491
+ uploadFile: (path: string, file: File, overwrite = true) => {
492
+ // Stream the raw bytes as multipart/form-data. Do NOT set Content-Type —
493
+ // the browser adds the multipart boundary automatically. Sending the file
494
+ // as base64 JSON (the old path) inflated the body ~33%, buffered the whole
495
+ // file in memory, and 502'd on large backup archives behind the proxy
496
+ // (NS-501).
497
+ const form = new FormData();
498
+ form.append("path", path);
499
+ form.append("overwrite", String(overwrite));
500
+ form.append("file", file, file.name);
501
+ return fetchJSON<ManagedFileWriteResponse>("/api/files/upload-stream", {
502
+ method: "POST",
503
+ body: form,
504
+ });
505
+ },
506
+ createDirectory: (path: string) =>
507
+ fetchJSON<ManagedFileWriteResponse>("/api/files/mkdir", {
508
+ method: "POST",
509
+ headers: { "Content-Type": "application/json" },
510
+ body: JSON.stringify({ path }),
511
+ }),
512
+ deleteFile: (path: string, recursive = false) =>
513
+ fetchJSON<{ ok: boolean; path: string }>("/api/files", {
514
+ method: "DELETE",
515
+ headers: { "Content-Type": "application/json" },
516
+ body: JSON.stringify({ path, recursive }),
270
517
  }),
271
518
  getLogs: (params: { file?: string; lines?: number; level?: string; component?: string }) => {
272
519
  const qs = new URLSearchParams();
@@ -276,10 +523,14 @@ export const api = {
276
523
  if (params.component && params.component !== "all") qs.set("component", params.component);
277
524
  return fetchJSON<LogsResponse>(`/api/logs?${qs.toString()}`);
278
525
  },
279
- getAnalytics: (days: number) =>
280
- fetchJSON<AnalyticsResponse>(`/api/analytics/usage?days=${days}`),
281
- getModelsAnalytics: (days: number) =>
282
- fetchJSON<ModelsAnalyticsResponse>(`/api/analytics/models?days=${days}`),
526
+ getAnalytics: (days: number, profile = getManagementProfile()) =>
527
+ fetchJSON<AnalyticsResponse>(
528
+ appendProfileParam(`/api/analytics/usage?days=${days}`, profile),
529
+ ),
530
+ getModelsAnalytics: (days: number, profile = getManagementProfile()) =>
531
+ fetchJSON<ModelsAnalyticsResponse>(
532
+ appendProfileParam(`/api/analytics/models?days=${days}`, profile),
533
+ ),
283
534
  getConfig: () => fetchJSON<Record<string, unknown>>("/api/config"),
284
535
  getDefaults: () => fetchJSON<Record<string, unknown>>("/api/config/defaults"),
285
536
  getSchema: () => fetchJSON<{ fields: Record<string, unknown>; category_order: string[] }>("/api/config/schema"),
@@ -298,7 +549,7 @@ export const api = {
298
549
  headers: { "Content-Type": "application/json" },
299
550
  body: JSON.stringify({ config }),
300
551
  }),
301
- getConfigRaw: () => fetchJSON<{ yaml: string }>("/api/config/raw"),
552
+ getConfigRaw: () => fetchJSON<{ yaml: string; path?: string }>("/api/config/raw"),
302
553
  saveConfigRaw: (yaml_text: string) =>
303
554
  fetchJSON<{ ok: boolean }>("/api/config/raw", {
304
555
  method: "PUT",
@@ -333,7 +584,9 @@ export const api = {
333
584
  // Cron jobs
334
585
  getCronJobs: (profile = "all") =>
335
586
  fetchJSON<CronJob[]>(`/api/cron/jobs?profile=${encodeURIComponent(profile)}`),
336
- createCronJob: (job: { prompt: string; schedule: string; name?: string; deliver?: string }, profile = "default") =>
587
+ getCronDeliveryTargets: () =>
588
+ fetchJSON<{ targets: CronDeliveryTarget[] }>("/api/cron/delivery-targets"),
589
+ createCronJob: (job: { prompt: string; schedule: string; name?: string; deliver?: string; skills?: string[] }, profile = "default") =>
337
590
  fetchJSON<CronJob>(`/api/cron/jobs?profile=${encodeURIComponent(profile)}`, {
338
591
  method: "POST",
339
592
  headers: { "Content-Type": "application/json" },
@@ -343,7 +596,7 @@ export const api = {
343
596
  fetchJSON<CronJob>(`/api/cron/jobs/${encodeURIComponent(id)}/pause?profile=${encodeURIComponent(profile)}`, { method: "POST" }),
344
597
  updateCronJob: (
345
598
  id: string,
346
- updates: { prompt?: string; schedule?: string; name?: string; deliver?: string },
599
+ updates: { prompt?: string; schedule?: string; name?: string; deliver?: string; skills?: string[] },
347
600
  profile = "default",
348
601
  ) =>
349
602
  fetchJSON<CronJob>(
@@ -361,15 +614,83 @@ export const api = {
361
614
  deleteCronJob: (id: string, profile = "default") =>
362
615
  fetchJSON<{ ok: boolean }>(`/api/cron/jobs/${encodeURIComponent(id)}?profile=${encodeURIComponent(profile)}`, { method: "DELETE" }),
363
616
 
364
- // Profiles (minimal)
617
+ // Automation Blueprints — parameterized automation blueprints
618
+ getAutomationBlueprints: () =>
619
+ fetchJSON<{ blueprints: AutomationBlueprint[] }>("/api/cron/blueprints"),
620
+ instantiateAutomationBlueprint: (
621
+ body: { blueprint: string; values: Record<string, string> },
622
+ profile = "default",
623
+ ) =>
624
+ fetchJSON<CronJob>(`/api/cron/blueprints/instantiate?profile=${encodeURIComponent(profile)}`, {
625
+ method: "POST",
626
+ headers: { "Content-Type": "application/json" },
627
+ body: JSON.stringify(body),
628
+ }),
629
+
630
+ // Profiles
365
631
  getProfiles: () =>
366
632
  fetchJSON<{ profiles: ProfileInfo[] }>("/api/profiles"),
367
- createProfile: (body: { name: string; clone_from_default: boolean }) =>
368
- fetchJSON<{ ok: boolean; name: string; path: string }>("/api/profiles", {
633
+ getActiveProfile: () =>
634
+ fetchJSON<ActiveProfileInfo>("/api/profiles/active"),
635
+ setActiveProfile: (name: string) =>
636
+ fetchJSON<{ ok: boolean; active: string }>("/api/profiles/active", {
637
+ method: "POST",
638
+ headers: { "Content-Type": "application/json" },
639
+ body: JSON.stringify({ name }),
640
+ }),
641
+ createProfile: (body: {
642
+ name: string;
643
+ clone_from?: string | null;
644
+ clone_from_default?: boolean;
645
+ clone_all?: boolean;
646
+ no_skills?: boolean;
647
+ description?: string;
648
+ provider?: string;
649
+ model?: string;
650
+ mcp_servers?: McpServerCreate[];
651
+ keep_skills?: string[];
652
+ hub_skills?: string[];
653
+ }) =>
654
+ fetchJSON<{
655
+ ok: boolean;
656
+ name: string;
657
+ path: string;
658
+ model_set?: boolean;
659
+ mcp_written?: number;
660
+ skills_disabled?: number;
661
+ hub_installs?: Array<{ identifier: string; pid: number | null }>;
662
+ }>("/api/profiles", {
369
663
  method: "POST",
370
664
  headers: { "Content-Type": "application/json" },
371
665
  body: JSON.stringify(body),
372
666
  }),
667
+ updateProfileDescription: (name: string, description: string) =>
668
+ fetchJSON<{ ok: boolean; description: string; description_auto: boolean }>(
669
+ `/api/profiles/${encodeURIComponent(name)}/description`,
670
+ {
671
+ method: "PUT",
672
+ headers: { "Content-Type": "application/json" },
673
+ body: JSON.stringify({ description }),
674
+ },
675
+ ),
676
+ describeProfileAuto: (name: string, overwrite = true) =>
677
+ fetchJSON<ProfileDescribeAutoResult>(
678
+ `/api/profiles/${encodeURIComponent(name)}/describe-auto`,
679
+ {
680
+ method: "POST",
681
+ headers: { "Content-Type": "application/json" },
682
+ body: JSON.stringify({ overwrite }),
683
+ },
684
+ ),
685
+ setProfileModel: (name: string, provider: string, model: string) =>
686
+ fetchJSON<{ ok: boolean; provider: string; model: string }>(
687
+ `/api/profiles/${encodeURIComponent(name)}/model`,
688
+ {
689
+ method: "PUT",
690
+ headers: { "Content-Type": "application/json" },
691
+ body: JSON.stringify({ provider, model }),
692
+ },
693
+ ),
373
694
  renameProfile: (name: string, newName: string) =>
374
695
  fetchJSON<{ ok: boolean; name: string; path: string }>(
375
696
  `/api/profiles/${encodeURIComponent(name)}`,
@@ -403,18 +724,82 @@ export const api = {
403
724
  ),
404
725
 
405
726
  // Skills & Toolsets
406
- getSkills: () => fetchJSON<SkillInfo[]>("/api/skills"),
407
- toggleSkill: (name: string, enabled: boolean) =>
727
+ //
728
+ // All calls accept an optional ``profile`` so the Skills page can manage
729
+ // any profile's skills/toolsets — not just the one the dashboard process
730
+ // runs under. Omitted/empty profile = the dashboard's own profile.
731
+ getSkills: (profile?: string) =>
732
+ fetchJSON<SkillInfo[]>(`/api/skills${profileQuery(profile)}`),
733
+ toggleSkill: (name: string, enabled: boolean, profile?: string) =>
408
734
  fetchJSON<{ ok: boolean }>("/api/skills/toggle", {
409
735
  method: "PUT",
410
736
  headers: { "Content-Type": "application/json" },
411
- body: JSON.stringify({ name, enabled }),
737
+ body: JSON.stringify({ name, enabled, profile: profile || undefined }),
738
+ }),
739
+ getSkillContent: (name: string, profile?: string) =>
740
+ fetchJSON<SkillContent>(
741
+ `/api/skills/content?name=${encodeURIComponent(name)}${profile ? `&profile=${encodeURIComponent(profile)}` : ""}`,
742
+ ),
743
+ createSkill: (skill: { name: string; content: string; category?: string }, profile?: string) =>
744
+ fetchJSON<SkillWriteResult>("/api/skills", {
745
+ method: "POST",
746
+ headers: { "Content-Type": "application/json" },
747
+ body: JSON.stringify({ ...skill, profile: profile || undefined }),
748
+ }),
749
+ updateSkillContent: (name: string, content: string, profile?: string) =>
750
+ fetchJSON<SkillWriteResult>("/api/skills/content", {
751
+ method: "PUT",
752
+ headers: { "Content-Type": "application/json" },
753
+ body: JSON.stringify({ name, content, profile: profile || undefined }),
412
754
  }),
413
- getToolsets: () => fetchJSON<ToolsetInfo[]>("/api/tools/toolsets"),
755
+ getToolsets: (profile?: string) =>
756
+ fetchJSON<ToolsetInfo[]>(`/api/tools/toolsets${profileQuery(profile)}`),
757
+ toggleToolset: (name: string, enabled: boolean, profile?: string) =>
758
+ fetchJSON<{ ok: boolean; name: string; enabled: boolean }>(
759
+ `/api/tools/toolsets/${encodeURIComponent(name)}`,
760
+ {
761
+ method: "PUT",
762
+ headers: { "Content-Type": "application/json" },
763
+ body: JSON.stringify({ enabled, profile: profile || undefined }),
764
+ },
765
+ ),
766
+ getToolsetConfig: (name: string, profile?: string) =>
767
+ fetchJSON<ToolsetConfig>(
768
+ `/api/tools/toolsets/${encodeURIComponent(name)}/config${profileQuery(profile)}`,
769
+ ),
770
+ selectToolsetProvider: (name: string, provider: string, profile?: string) =>
771
+ fetchJSON<{ ok: boolean; name: string; provider: string }>(
772
+ `/api/tools/toolsets/${encodeURIComponent(name)}/provider`,
773
+ {
774
+ method: "PUT",
775
+ headers: { "Content-Type": "application/json" },
776
+ body: JSON.stringify({ provider, profile: profile || undefined }),
777
+ },
778
+ ),
779
+ saveToolsetEnv: (name: string, env: Record<string, string>, profile?: string) =>
780
+ fetchJSON<ToolsetEnvResult>(
781
+ `/api/tools/toolsets/${encodeURIComponent(name)}/env`,
782
+ {
783
+ method: "PUT",
784
+ headers: { "Content-Type": "application/json" },
785
+ body: JSON.stringify({ env, profile: profile || undefined }),
786
+ },
787
+ ),
788
+ runToolsetPostSetup: (name: string, key: string, profile?: string) =>
789
+ fetchJSON<ActionResponse & { key: string }>(
790
+ `/api/tools/toolsets/${encodeURIComponent(name)}/post-setup`,
791
+ {
792
+ method: "POST",
793
+ headers: { "Content-Type": "application/json" },
794
+ body: JSON.stringify({ key, profile: profile || undefined }),
795
+ },
796
+ ),
414
797
 
415
798
  // Session search (FTS5)
416
- searchSessions: (q: string) =>
417
- fetchJSON<SessionSearchResponse>(`/api/sessions/search?q=${encodeURIComponent(q)}`),
799
+ searchSessions: (q: string, profile = getManagementProfile()) =>
800
+ fetchJSON<SessionSearchResponse>(
801
+ appendProfileParam(`/api/sessions/search?q=${encodeURIComponent(q)}`, profile),
802
+ ),
418
803
 
419
804
  // OAuth provider management
420
805
  getOAuthProviders: () =>
@@ -474,7 +859,7 @@ export const api = {
474
859
 
475
860
  // Messaging platforms (gateway channels)
476
861
  getMessagingPlatforms: () =>
477
- fetchJSON<{ platforms: MessagingPlatform[] }>("/api/messaging/platforms"),
862
+ fetchJSON<MessagingPlatformsResponse>("/api/messaging/platforms"),
478
863
  updateMessagingPlatform: (id: string, body: MessagingPlatformUpdate) =>
479
864
  fetchJSON<{ ok: boolean; platform: string }>(
480
865
  `/api/messaging/platforms/${encodeURIComponent(id)}`,
@@ -489,12 +874,46 @@ export const api = {
489
874
  `/api/messaging/platforms/${encodeURIComponent(id)}/test`,
490
875
  { method: "POST" },
491
876
  ),
877
+ startTelegramOnboarding: (body: { bot_name?: string }) =>
878
+ fetchJSON<TelegramOnboardingStartResponse>(
879
+ "/api/messaging/telegram/onboarding/start",
880
+ {
881
+ method: "POST",
882
+ headers: { "Content-Type": "application/json" },
883
+ body: JSON.stringify(body),
884
+ },
885
+ ),
886
+ getTelegramOnboardingStatus: (pairingId: string) =>
887
+ fetchJSON<TelegramOnboardingStatusResponse>(
888
+ `/api/messaging/telegram/onboarding/${encodeURIComponent(pairingId)}`,
889
+ ),
890
+ applyTelegramOnboarding: (
891
+ pairingId: string,
892
+ body: { allowed_user_ids: string[]; profile?: string },
893
+ ) =>
894
+ fetchJSON<TelegramOnboardingApplyResponse>(
895
+ `/api/messaging/telegram/onboarding/${encodeURIComponent(pairingId)}/apply`,
896
+ {
897
+ method: "POST",
898
+ headers: { "Content-Type": "application/json" },
899
+ body: JSON.stringify(body),
900
+ },
901
+ ),
902
+ cancelTelegramOnboarding: (pairingId: string) =>
903
+ fetchJSON<{ ok: boolean }>(
904
+ `/api/messaging/telegram/onboarding/${encodeURIComponent(pairingId)}`,
905
+ { method: "DELETE" },
906
+ ),
492
907
 
493
908
  // Gateway / update actions
494
909
  restartGateway: () =>
495
910
  fetchJSON<ActionResponse>("/api/gateway/restart", { method: "POST" }),
496
911
  updateHermes: () =>
497
912
  fetchJSON<ActionResponse>("/api/hermes/update", { method: "POST" }),
913
+ checkHermesUpdate: (force = false) =>
914
+ fetchJSON<UpdateCheckResponse>(
915
+ `/api/hermes/update/check${force ? "?force=true" : ""}`,
916
+ ),
498
917
  getActionStatus: (name: string, lines = 200) =>
499
918
  fetchJSON<ActionStatusResponse>(
500
919
  `/api/actions/${encodeURIComponent(name)}/status?lines=${lines}`,
@@ -565,6 +984,14 @@ export const api = {
565
984
  headers: { "Content-Type": "application/json" },
566
985
  body: JSON.stringify({ name }),
567
986
  }),
987
+ getFontPref: () =>
988
+ fetchJSON<DashboardFontResponse>("/api/dashboard/font"),
989
+ setFontPref: (font: string) =>
990
+ fetchJSON<{ ok: boolean; font: string }>("/api/dashboard/font", {
991
+ method: "PUT",
992
+ headers: { "Content-Type": "application/json" },
993
+ body: JSON.stringify({ font }),
994
+ }),
568
995
 
569
996
  // ── Admin: MCP servers ──────────────────────────────────────────────
570
997
  getMcpServers: () => fetchJSON<{ servers: McpServer[] }>("/api/mcp/servers"),
@@ -631,6 +1058,8 @@ export const api = {
631
1058
 
632
1059
  // ── Admin: Webhooks ─────────────────────────────────────────────────
633
1060
  getWebhooks: () => fetchJSON<WebhooksResponse>("/api/webhooks"),
1061
+ enableWebhooks: () =>
1062
+ fetchJSON<WebhookEnableResponse>("/api/webhooks/enable", { method: "POST" }),
634
1063
  createWebhook: (body: WebhookCreate) =>
635
1064
  fetchJSON<WebhookRoute & { secret: string }>("/api/webhooks", {
636
1065
  method: "POST",
@@ -705,11 +1134,11 @@ export const api = {
705
1134
  headers: { "Content-Type": "application/json" },
706
1135
  body: JSON.stringify({ output }),
707
1136
  }),
708
- runImport: (archive: string) =>
1137
+ runImport: (archive: string, force = false) =>
709
1138
  fetchJSON<ActionResponse>("/api/ops/import", {
710
1139
  method: "POST",
711
1140
  headers: { "Content-Type": "application/json" },
712
- body: JSON.stringify({ archive }),
1141
+ body: JSON.stringify({ archive, force }),
713
1142
  }),
714
1143
  getHooks: () => fetchJSON<HooksResponse>("/api/ops/hooks"),
715
1144
  createHook: (body: HookCreate) =>
@@ -749,6 +1178,15 @@ export const api = {
749
1178
  runDump: () => fetchJSON<ActionResponse>("/api/ops/dump", { method: "POST" }),
750
1179
  runConfigMigrate: () =>
751
1180
  fetchJSON<ActionResponse>("/api/ops/config-migrate", { method: "POST" }),
1181
+ runDebugShare: (opts?: { redact?: boolean; lines?: number }) =>
1182
+ fetchJSON<DebugShareResponse>("/api/ops/debug-share", {
1183
+ method: "POST",
1184
+ headers: { "Content-Type": "application/json" },
1185
+ body: JSON.stringify({
1186
+ redact: opts?.redact ?? true,
1187
+ lines: opts?.lines ?? 200,
1188
+ }),
1189
+ }),
752
1190
 
753
1191
 
754
1192
  getCheckpoints: () => fetchJSON<CheckpointsResponse>("/api/ops/checkpoints"),
@@ -756,23 +1194,41 @@ export const api = {
756
1194
  fetchJSON<ActionResponse>("/api/ops/checkpoints/prune", { method: "POST" }),
757
1195
 
758
1196
  // ── Admin: Skills hub ───────────────────────────────────────────────
759
- installSkillFromHub: (identifier: string) =>
1197
+ // ``profile`` scopes install/uninstall/update and the installed-state
1198
+ // annotations to that profile (omitted = the dashboard's own profile).
1199
+ installSkillFromHub: (identifier: string, profile?: string) =>
760
1200
  fetchJSON<ActionResponse>("/api/skills/hub/install", {
761
1201
  method: "POST",
762
1202
  headers: { "Content-Type": "application/json" },
763
- body: JSON.stringify({ identifier }),
1203
+ body: JSON.stringify({ identifier, profile: profile || undefined }),
764
1204
  }),
765
- uninstallSkillFromHub: (name: string) =>
1205
+ uninstallSkillFromHub: (name: string, profile?: string) =>
766
1206
  fetchJSON<ActionResponse>("/api/skills/hub/uninstall", {
767
1207
  method: "POST",
768
1208
  headers: { "Content-Type": "application/json" },
769
- body: JSON.stringify({ name }),
1209
+ body: JSON.stringify({ name, profile: profile || undefined }),
770
1210
  }),
771
- updateSkillsFromHub: () =>
772
- fetchJSON<ActionResponse>("/api/skills/hub/update", { method: "POST" }),
773
- searchSkillsHub: (q: string, source = "all", limit = 20) =>
774
- fetchJSON<{ results: SkillHubResult[] }>(
775
- `/api/skills/hub/search?q=${encodeURIComponent(q)}&source=${encodeURIComponent(source)}&limit=${limit}`,
1211
+ updateSkillsFromHub: (profile?: string) =>
1212
+ fetchJSON<ActionResponse>("/api/skills/hub/update", {
1213
+ method: "POST",
1214
+ headers: { "Content-Type": "application/json" },
1215
+ body: JSON.stringify({ profile: profile || undefined }),
1216
+ }),
1217
+ searchSkillsHub: (q: string, source = "all", limit = 20, profile?: string) =>
1218
+ fetchJSON<SkillHubSearchResponse>(
1219
+ `/api/skills/hub/search?q=${encodeURIComponent(q)}&source=${encodeURIComponent(source)}&limit=${limit}${profile ? `&profile=${encodeURIComponent(profile)}` : ""}`,
1220
+ ),
1221
+ getSkillHubSources: (profile?: string) =>
1222
+ fetchJSON<SkillHubSourcesResponse>(
1223
+ `/api/skills/hub/sources${profileQuery(profile)}`,
1224
+ ),
1225
+ previewSkillFromHub: (identifier: string) =>
1226
+ fetchJSON<SkillHubPreview>(
1227
+ `/api/skills/hub/preview?identifier=${encodeURIComponent(identifier)}`,
1228
+ ),
1229
+ scanSkillFromHub: (identifier: string) =>
1230
+ fetchJSON<SkillHubScan>(
1231
+ `/api/skills/hub/scan?identifier=${encodeURIComponent(identifier)}`,
776
1232
  ),
777
1233
  };
778
1234
 
@@ -802,6 +1258,16 @@ export interface ActionResponse {
802
1258
  update_command?: string;
803
1259
  }
804
1260
 
1261
+ export interface DebugShareResponse {
1262
+ ok: boolean;
1263
+ // label -> paste URL, e.g. { Report: "https://paste.rs/abc", "agent.log": "..." }
1264
+ urls: Record<string, string>;
1265
+ // "label: error" strings for optional full-log uploads that failed.
1266
+ failures: string[];
1267
+ redacted: boolean;
1268
+ auto_delete_seconds: number;
1269
+ }
1270
+
805
1271
  export interface SessionStoreStats {
806
1272
  total: number;
807
1273
  active_store: number;
@@ -820,6 +1286,77 @@ export interface SkillHubResult {
820
1286
  tags: string[];
821
1287
  }
822
1288
 
1289
+ /** Lock-entry summary for an already-installed hub skill (keyed by identifier). */
1290
+ export interface SkillHubInstalledEntry {
1291
+ name: string | null;
1292
+ trust_level: string | null;
1293
+ scan_verdict: string | null;
1294
+ }
1295
+
1296
+ export interface SkillHubSearchResponse {
1297
+ results: SkillHubResult[];
1298
+ /** source_id -> number of results returned by that source. */
1299
+ source_counts: Record<string, number>;
1300
+ /** source ids that didn't return within the parallel-search timeout. */
1301
+ timed_out: string[];
1302
+ /** identifier -> installed lock entry (for "already installed" badges). */
1303
+ installed: Record<string, SkillHubInstalledEntry>;
1304
+ }
1305
+
1306
+ export interface SkillHubSource {
1307
+ id: string;
1308
+ label: string;
1309
+ /** GitHub only: whether the API is currently rate-limited. */
1310
+ rate_limited?: boolean;
1311
+ /** hermes-index only: whether the centralized index loaded. */
1312
+ available?: boolean;
1313
+ }
1314
+
1315
+ export interface SkillHubSourcesResponse {
1316
+ sources: SkillHubSource[];
1317
+ index_available: boolean;
1318
+ /** Featured/popular skills from the centralized index (zero extra API calls). */
1319
+ featured: SkillHubResult[];
1320
+ installed: Record<string, SkillHubInstalledEntry>;
1321
+ }
1322
+
1323
+ export interface SkillHubPreview {
1324
+ name: string;
1325
+ description: string;
1326
+ source: string;
1327
+ identifier: string;
1328
+ trust_level: string;
1329
+ repo: string | null;
1330
+ tags: string[];
1331
+ /** Rendered SKILL.md content (the actual skill text). */
1332
+ skill_md: string;
1333
+ /** Relative paths of every file in the bundle. */
1334
+ files: string[];
1335
+ }
1336
+
1337
+ export interface SkillHubScanFinding {
1338
+ severity: string;
1339
+ category: string;
1340
+ file: string;
1341
+ line: number;
1342
+ description: string;
1343
+ }
1344
+
1345
+ export interface SkillHubScan {
1346
+ name: string;
1347
+ identifier: string;
1348
+ source: string;
1349
+ trust_level: string;
1350
+ /** "safe" | "caution" | "dangerous". */
1351
+ verdict: string;
1352
+ summary: string;
1353
+ /** Install-policy decision for this trust+verdict combo. */
1354
+ policy: "allow" | "ask" | "block";
1355
+ policy_reason: string;
1356
+ findings: SkillHubScanFinding[];
1357
+ severity_counts: Record<string, number>;
1358
+ }
1359
+
823
1360
  // ── Admin types ───────────────────────────────────────────────────────
824
1361
 
825
1362
  export interface McpServer {
@@ -841,6 +1378,17 @@ export interface McpCatalogEntry {
841
1378
  transport: "http" | "stdio";
842
1379
  auth_type: "api_key" | "oauth" | "none";
843
1380
  required_env: Array<{ name: string; prompt: string; required: boolean }>;
1381
+ // Transport details — what actually connects (http) or runs (stdio).
1382
+ command: string | null;
1383
+ args: string[];
1384
+ url: string | null;
1385
+ // Git bootstrap (only set for entries that clone + build locally).
1386
+ install_url: string | null;
1387
+ install_ref: string | null;
1388
+ bootstrap: string[];
1389
+ // Default tool pre-selection (null = all tools pre-checked) + guidance text.
1390
+ default_enabled: string[] | null;
1391
+ post_install: string;
844
1392
  needs_install: boolean;
845
1393
  installed: boolean;
846
1394
  enabled: boolean;
@@ -875,6 +1423,7 @@ export interface MessagingPlatformEnvVar {
875
1423
  redacted_value: string | null;
876
1424
  description: string;
877
1425
  prompt: string;
1426
+ help: string;
878
1427
  url: string | null;
879
1428
  is_password: boolean;
880
1429
  advanced: boolean;
@@ -890,7 +1439,7 @@ export interface MessagingPlatform {
890
1439
  gateway_running: boolean;
891
1440
  /**
892
1441
  * "connected" | "disabled" | "not_configured" | "pending_restart" |
893
- * "gateway_stopped" | "disconnected" | "fatal" | string
1442
+ * "gateway_stopped" | "startup_failed" | "disconnected" | "fatal" | string
894
1443
  */
895
1444
  state: string;
896
1445
  error_code: string | null;
@@ -900,6 +1449,12 @@ export interface MessagingPlatform {
900
1449
  env_vars: MessagingPlatformEnvVar[];
901
1450
  }
902
1451
 
1452
+ export interface MessagingPlatformsResponse {
1453
+ env_path: string;
1454
+ gateway_start_command: string;
1455
+ platforms: MessagingPlatform[];
1456
+ }
1457
+
903
1458
  export interface MessagingPlatformUpdate {
904
1459
  enabled?: boolean;
905
1460
  env?: Record<string, string>;
@@ -945,6 +1500,17 @@ export interface WebhooksResponse {
945
1500
  subscriptions: WebhookRoute[];
946
1501
  }
947
1502
 
1503
+ export interface WebhookEnableResponse {
1504
+ ok: boolean;
1505
+ platform: "webhook";
1506
+ enabled: true;
1507
+ needs_restart: boolean;
1508
+ restart_started?: boolean;
1509
+ restart_action?: string;
1510
+ restart_pid?: number | null;
1511
+ restart_error?: string;
1512
+ }
1513
+
948
1514
  export interface WebhookCreate {
949
1515
  name: string;
950
1516
  description?: string;
@@ -1009,6 +1575,18 @@ export interface HookCreate {
1009
1575
  approve?: boolean;
1010
1576
  }
1011
1577
 
1578
+ export interface UpdateCheckResponse {
1579
+ install_method: string;
1580
+ current_version: string;
1581
+ // commits behind: >=1 known count, 0 up to date, -1 behind by unknown
1582
+ // count (nix/pypi), or null when the check could not run.
1583
+ behind: number | null;
1584
+ update_available: boolean;
1585
+ can_apply: boolean;
1586
+ update_command: string;
1587
+ message: string | null;
1588
+ }
1589
+
1012
1590
  export interface SystemStats {
1013
1591
  os: string;
1014
1592
  os_release: string;
@@ -1098,6 +1676,9 @@ export interface StatusResponse {
1098
1676
  * Empty in loopback mode; empty + ``auth_required=true`` is a
1099
1677
  * fail-closed state (the dashboard will refuse to bind). */
1100
1678
  auth_providers?: string[];
1679
+ /** False when the dashboard is running in a hosted/managed layout where
1680
+ * updates are handled by the outer launcher instead of ``hermes update``. */
1681
+ can_update_hermes?: boolean;
1101
1682
  config_path: string;
1102
1683
  config_version: number;
1103
1684
  env_path: string;
@@ -1154,6 +1735,36 @@ export interface EnvVarInfo {
1154
1735
  is_password: boolean;
1155
1736
  tools: string[];
1156
1737
  advanced: boolean;
1738
+ /** True when this var is a messaging-platform credential owned by the Channels page. */
1739
+ channel_managed?: boolean;
1740
+ }
1741
+
1742
+ export interface TelegramOnboardingStartResponse {
1743
+ pairing_id: string;
1744
+ suggested_username: string;
1745
+ deep_link: string;
1746
+ qr_payload: string;
1747
+ expires_at: string;
1748
+ }
1749
+
1750
+ export type TelegramOnboardingStatusResponse =
1751
+ | { status: "waiting"; expires_at: string }
1752
+ | {
1753
+ status: "ready";
1754
+ bot_username: string;
1755
+ owner_user_id?: string;
1756
+ expires_at: string;
1757
+ };
1758
+
1759
+ export interface TelegramOnboardingApplyResponse {
1760
+ ok: boolean;
1761
+ platform: "telegram";
1762
+ bot_username?: string;
1763
+ needs_restart: boolean;
1764
+ restart_started?: boolean;
1765
+ restart_action?: string;
1766
+ restart_pid?: number | null;
1767
+ restart_error?: string;
1157
1768
  }
1158
1769
 
1159
1770
  export interface SessionMessage {
@@ -1178,6 +1789,44 @@ export interface LogsResponse {
1178
1789
  lines: string[];
1179
1790
  }
1180
1791
 
1792
+ export interface ManagedFileEntry {
1793
+ name: string;
1794
+ path: string;
1795
+ is_directory: boolean;
1796
+ size: number | null;
1797
+ mtime: number;
1798
+ mime_type: string | null;
1799
+ }
1800
+
1801
+ export interface ManagedFilesResponse {
1802
+ root: string | null;
1803
+ path: string;
1804
+ parent: string | null;
1805
+ locked_root: string | null;
1806
+ can_change_path: boolean;
1807
+ entries: ManagedFileEntry[];
1808
+ }
1809
+
1810
+ export interface ManagedFileReadResponse {
1811
+ name: string;
1812
+ path: string;
1813
+ size: number;
1814
+ mime_type: string;
1815
+ data_url: string;
1816
+ root: string | null;
1817
+ locked_root: string | null;
1818
+ can_change_path: boolean;
1819
+ }
1820
+
1821
+ export interface ManagedFileWriteResponse {
1822
+ ok: boolean;
1823
+ path: string;
1824
+ entry: ManagedFileEntry;
1825
+ root: string | null;
1826
+ locked_root: string | null;
1827
+ can_change_path: boolean;
1828
+ }
1829
+
1181
1830
  export interface AnalyticsDailyEntry {
1182
1831
  day: string;
1183
1832
  input_tokens: number;
@@ -1234,6 +1883,18 @@ export interface AnalyticsResponse {
1234
1883
  };
1235
1884
  }
1236
1885
 
1886
+ export interface ActiveProfileInfo {
1887
+ active: string;
1888
+ current: string;
1889
+ }
1890
+
1891
+ export interface ProfileDescribeAutoResult {
1892
+ ok: boolean;
1893
+ reason: string;
1894
+ description: string | null;
1895
+ description_auto: boolean;
1896
+ }
1897
+
1237
1898
  export interface ProfileInfo {
1238
1899
  name: string;
1239
1900
  path: string;
@@ -1242,6 +1903,13 @@ export interface ProfileInfo {
1242
1903
  provider: string | null;
1243
1904
  has_env: boolean;
1244
1905
  skill_count: number;
1906
+ gateway_running: boolean;
1907
+ description: string;
1908
+ description_auto: boolean;
1909
+ distribution_name: string | null;
1910
+ distribution_version: string | null;
1911
+ distribution_source: string | null;
1912
+ has_alias: boolean;
1245
1913
  }
1246
1914
 
1247
1915
  export interface ModelsAnalyticsModelEntry {
@@ -1293,6 +1961,7 @@ export interface CronJob {
1293
1961
  name?: string | null;
1294
1962
  prompt?: string | null;
1295
1963
  script?: string | null;
1964
+ skills?: string[] | null;
1296
1965
  schedule?: { kind?: string; expr?: string; display?: string };
1297
1966
  schedule_display?: string | null;
1298
1967
  enabled: boolean;
@@ -1303,6 +1972,36 @@ export interface CronJob {
1303
1972
  last_error?: string | null;
1304
1973
  }
1305
1974
 
1975
+ export interface CronDeliveryTarget {
1976
+ id: string;
1977
+ name: string;
1978
+ home_target_set: boolean;
1979
+ home_env_var: string | null;
1980
+ }
1981
+
1982
+ export interface AutomationBlueprintField {
1983
+ name: string;
1984
+ type: "time" | "enum" | "text" | "weekdays";
1985
+ label: string;
1986
+ default: string | null;
1987
+ options: string[];
1988
+ optional: boolean;
1989
+ /** When false, options are suggestions — any value is accepted. */
1990
+ strict?: boolean;
1991
+ help: string;
1992
+ }
1993
+
1994
+ export interface AutomationBlueprint {
1995
+ key: string;
1996
+ title: string;
1997
+ description: string;
1998
+ category: string;
1999
+ tags: string[];
2000
+ fields: AutomationBlueprintField[];
2001
+ command: string;
2002
+ appUrl: string;
2003
+ }
2004
+
1306
2005
  export interface SkillInfo {
1307
2006
  name: string;
1308
2007
  description: string;
@@ -1310,6 +2009,19 @@ export interface SkillInfo {
1310
2009
  enabled: boolean;
1311
2010
  }
1312
2011
 
2012
+ export interface SkillContent {
2013
+ name: string;
2014
+ content: string;
2015
+ path: string;
2016
+ }
2017
+
2018
+ export interface SkillWriteResult {
2019
+ success: boolean;
2020
+ message?: string;
2021
+ path?: string;
2022
+ error?: string;
2023
+ }
2024
+
1313
2025
  export interface ToolsetInfo {
1314
2026
  name: string;
1315
2027
  label: string;
@@ -1319,6 +2031,39 @@ export interface ToolsetInfo {
1319
2031
  tools: string[];
1320
2032
  }
1321
2033
 
2034
+ export interface ToolsetProviderEnvVar {
2035
+ key: string;
2036
+ prompt: string;
2037
+ url: string | null;
2038
+ default: string | null;
2039
+ is_set: boolean;
2040
+ }
2041
+
2042
+ export interface ToolsetProvider {
2043
+ name: string;
2044
+ badge: string;
2045
+ tag: string;
2046
+ env_vars: ToolsetProviderEnvVar[];
2047
+ post_setup: string | null;
2048
+ requires_nous_auth: boolean;
2049
+ is_active: boolean;
2050
+ }
2051
+
2052
+ export interface ToolsetConfig {
2053
+ name: string;
2054
+ has_category: boolean;
2055
+ providers: ToolsetProvider[];
2056
+ active_provider: string | null;
2057
+ }
2058
+
2059
+ export interface ToolsetEnvResult {
2060
+ ok: boolean;
2061
+ name: string;
2062
+ saved: string[];
2063
+ skipped: string[];
2064
+ is_set: Record<string, boolean>;
2065
+ }
2066
+
1322
2067
  export interface SessionSearchResult {
1323
2068
  session_id: string;
1324
2069
  snippet: string;
@@ -1382,20 +2127,37 @@ export interface AuxiliaryModelsResponse {
1382
2127
  }
1383
2128
 
1384
2129
  export interface ModelAssignmentRequest {
2130
+ confirm_expensive_model?: boolean;
1385
2131
  scope: "main" | "auxiliary";
1386
2132
  provider: string;
1387
2133
  model: string;
2134
+ /** Optional OpenAI-compatible endpoint URL for custom/local main providers. */
2135
+ base_url?: string;
1388
2136
  /** For auxiliary: task slot name, "" for all, "__reset__" to reset all. */
1389
2137
  task?: string;
1390
2138
  }
1391
2139
 
2140
+ /** An auxiliary task still pinned to a provider that differs from the
2141
+ * newly-selected main provider after a main-model switch. */
2142
+ export interface StaleAuxAssignment {
2143
+ task: string;
2144
+ provider: string;
2145
+ model: string;
2146
+ }
2147
+
1392
2148
  export interface ModelAssignmentResponse {
2149
+ confirm_message?: string;
2150
+ confirm_required?: boolean;
1393
2151
  ok: boolean;
1394
2152
  scope?: string;
1395
2153
  provider?: string;
1396
2154
  model?: string;
1397
2155
  tasks?: string[];
1398
2156
  reset?: boolean;
2157
+ /** Auxiliary slots still pinned to a different provider than the new main.
2158
+ * Switching main never clears aux pins; this lets the UI warn the user
2159
+ * their helper tasks aren't following the switch. Only set on scope:'main'. */
2160
+ stale_aux?: StaleAuxAssignment[];
1399
2161
  }
1400
2162
 
1401
2163
  // ── OAuth provider types ────────────────────────────────────────────────
@@ -1472,6 +2234,11 @@ export interface DashboardThemesResponse {
1472
2234
  themes: DashboardThemeSummary[];
1473
2235
  }
1474
2236
 
2237
+ export interface DashboardFontResponse {
2238
+ /** Active font-override id, or "theme" when no override is set. */
2239
+ font: string;
2240
+ }
2241
+
1475
2242
  // ── Dashboard plugin types ─────────────────────────────────────────────
1476
2243
 
1477
2244
  export interface PluginManifestResponse {