clawdbot 2026.1.4-1

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 (550) hide show
  1. package/CHANGELOG.md +120 -0
  2. package/LICENSE +21 -0
  3. package/README-header.png +0 -0
  4. package/README.md +297 -0
  5. package/dist/agents/agent-paths.js +17 -0
  6. package/dist/agents/bash-process-registry.js +126 -0
  7. package/dist/agents/bash-tools.js +837 -0
  8. package/dist/agents/clawdbot-tools.js +30 -0
  9. package/dist/agents/clawdis-tools.js +27 -0
  10. package/dist/agents/context.js +34 -0
  11. package/dist/agents/defaults.js +6 -0
  12. package/dist/agents/model-auth.js +112 -0
  13. package/dist/agents/model-catalog.js +55 -0
  14. package/dist/agents/model-fallback.js +191 -0
  15. package/dist/agents/model-scan.js +263 -0
  16. package/dist/agents/model-selection.js +116 -0
  17. package/dist/agents/models-config.js +49 -0
  18. package/dist/agents/pi-embedded-helpers.js +74 -0
  19. package/dist/agents/pi-embedded-runner.js +407 -0
  20. package/dist/agents/pi-embedded-subscribe.js +568 -0
  21. package/dist/agents/pi-embedded-utils.js +20 -0
  22. package/dist/agents/pi-embedded.js +1 -0
  23. package/dist/agents/pi-oauth.js +88 -0
  24. package/dist/agents/pi-tools.js +433 -0
  25. package/dist/agents/sandbox-paths.js +68 -0
  26. package/dist/agents/sandbox.js +644 -0
  27. package/dist/agents/shell-utils.js +53 -0
  28. package/dist/agents/skills-install.js +244 -0
  29. package/dist/agents/skills-status.js +157 -0
  30. package/dist/agents/skills.js +470 -0
  31. package/dist/agents/steerable-agent-loop.js +338 -0
  32. package/dist/agents/steerable-provider-transport.js +48 -0
  33. package/dist/agents/system-prompt.js +104 -0
  34. package/dist/agents/tool-display.js +162 -0
  35. package/dist/agents/tool-images.js +138 -0
  36. package/dist/agents/tools/browser-tool.js +339 -0
  37. package/dist/agents/tools/canvas-tool.js +193 -0
  38. package/dist/agents/tools/common.js +88 -0
  39. package/dist/agents/tools/cron-tool.js +124 -0
  40. package/dist/agents/tools/discord-actions-guild.js +186 -0
  41. package/dist/agents/tools/discord-actions-messaging.js +285 -0
  42. package/dist/agents/tools/discord-actions-moderation.js +70 -0
  43. package/dist/agents/tools/discord-actions.js +56 -0
  44. package/dist/agents/tools/discord-schema.js +199 -0
  45. package/dist/agents/tools/discord-tool.js +16 -0
  46. package/dist/agents/tools/gateway-tool.js +46 -0
  47. package/dist/agents/tools/gateway.js +27 -0
  48. package/dist/agents/tools/image-tool.js +132 -0
  49. package/dist/agents/tools/nodes-tool.js +413 -0
  50. package/dist/agents/tools/nodes-utils.js +92 -0
  51. package/dist/agents/tools/sessions-helpers.js +88 -0
  52. package/dist/agents/tools/sessions-history-tool.js +53 -0
  53. package/dist/agents/tools/sessions-list-tool.js +143 -0
  54. package/dist/agents/tools/sessions-send-helpers.js +100 -0
  55. package/dist/agents/tools/sessions-send-tool.js +347 -0
  56. package/dist/agents/tools/slack-actions.js +129 -0
  57. package/dist/agents/tools/slack-schema.js +59 -0
  58. package/dist/agents/tools/slack-tool.js +16 -0
  59. package/dist/agents/usage.js +39 -0
  60. package/dist/agents/workspace.js +241 -0
  61. package/dist/auto-reply/chunk.js +76 -0
  62. package/dist/auto-reply/envelope.js +38 -0
  63. package/dist/auto-reply/group-activation.js +20 -0
  64. package/dist/auto-reply/heartbeat.js +57 -0
  65. package/dist/auto-reply/model.js +14 -0
  66. package/dist/auto-reply/reply/abort.js +14 -0
  67. package/dist/auto-reply/reply/agent-runner.js +371 -0
  68. package/dist/auto-reply/reply/block-streaming.js +34 -0
  69. package/dist/auto-reply/reply/body.js +29 -0
  70. package/dist/auto-reply/reply/commands.js +207 -0
  71. package/dist/auto-reply/reply/directive-handling.js +361 -0
  72. package/dist/auto-reply/reply/directives.js +47 -0
  73. package/dist/auto-reply/reply/followup-runner.js +149 -0
  74. package/dist/auto-reply/reply/groups.js +91 -0
  75. package/dist/auto-reply/reply/mentions.js +38 -0
  76. package/dist/auto-reply/reply/model-selection.js +114 -0
  77. package/dist/auto-reply/reply/queue.js +399 -0
  78. package/dist/auto-reply/reply/reply-tags.js +26 -0
  79. package/dist/auto-reply/reply/session-updates.js +87 -0
  80. package/dist/auto-reply/reply/session.js +160 -0
  81. package/dist/auto-reply/reply/typing.js +75 -0
  82. package/dist/auto-reply/reply.js +535 -0
  83. package/dist/auto-reply/send-policy.js +28 -0
  84. package/dist/auto-reply/status.js +158 -0
  85. package/dist/auto-reply/templating.js +9 -0
  86. package/dist/auto-reply/thinking.js +49 -0
  87. package/dist/auto-reply/tokens.js +2 -0
  88. package/dist/auto-reply/tool-meta.js +74 -0
  89. package/dist/auto-reply/transcription.js +57 -0
  90. package/dist/auto-reply/types.js +1 -0
  91. package/dist/browser/bridge-server.js +37 -0
  92. package/dist/browser/cdp.js +382 -0
  93. package/dist/browser/chrome.js +432 -0
  94. package/dist/browser/client-actions-core.js +67 -0
  95. package/dist/browser/client-actions-observe.js +24 -0
  96. package/dist/browser/client-actions-types.js +1 -0
  97. package/dist/browser/client-actions.js +3 -0
  98. package/dist/browser/client-fetch.js +43 -0
  99. package/dist/browser/client.js +105 -0
  100. package/dist/browser/config.js +140 -0
  101. package/dist/browser/constants.js +4 -0
  102. package/dist/browser/profiles-service.js +122 -0
  103. package/dist/browser/profiles.js +85 -0
  104. package/dist/browser/pw-ai.js +2 -0
  105. package/dist/browser/pw-session.js +144 -0
  106. package/dist/browser/pw-tools-core.js +363 -0
  107. package/dist/browser/routes/agent.js +535 -0
  108. package/dist/browser/routes/basic.js +155 -0
  109. package/dist/browser/routes/index.js +8 -0
  110. package/dist/browser/routes/tabs.js +105 -0
  111. package/dist/browser/routes/utils.js +62 -0
  112. package/dist/browser/screenshot.js +40 -0
  113. package/dist/browser/server-context.js +377 -0
  114. package/dist/browser/server.js +81 -0
  115. package/dist/browser/target-id.js +18 -0
  116. package/dist/browser/trash.js +21 -0
  117. package/dist/canvas-host/a2ui/.bundle.hash +1 -0
  118. package/dist/canvas-host/a2ui/a2ui.bundle.js +17768 -0
  119. package/dist/canvas-host/a2ui/index.html +246 -0
  120. package/dist/canvas-host/a2ui.js +187 -0
  121. package/dist/canvas-host/server.js +382 -0
  122. package/dist/cli/browser-cli-actions-input.js +459 -0
  123. package/dist/cli/browser-cli-actions-observe.js +56 -0
  124. package/dist/cli/browser-cli-examples.js +31 -0
  125. package/dist/cli/browser-cli-inspect.js +97 -0
  126. package/dist/cli/browser-cli-manage.js +286 -0
  127. package/dist/cli/browser-cli-shared.js +1 -0
  128. package/dist/cli/browser-cli.js +26 -0
  129. package/dist/cli/canvas-cli.js +416 -0
  130. package/dist/cli/cron-cli.js +454 -0
  131. package/dist/cli/deps.js +17 -0
  132. package/dist/cli/dns-cli.js +180 -0
  133. package/dist/cli/gateway-cli.js +489 -0
  134. package/dist/cli/gateway-rpc.js +20 -0
  135. package/dist/cli/hooks-cli.js +135 -0
  136. package/dist/cli/models-cli.js +248 -0
  137. package/dist/cli/nodes-camera.js +57 -0
  138. package/dist/cli/nodes-canvas.js +26 -0
  139. package/dist/cli/nodes-cli.js +946 -0
  140. package/dist/cli/nodes-screen.js +37 -0
  141. package/dist/cli/parse-duration.js +20 -0
  142. package/dist/cli/ports.js +97 -0
  143. package/dist/cli/program.js +406 -0
  144. package/dist/cli/prompt.js +19 -0
  145. package/dist/cli/tui-cli.js +35 -0
  146. package/dist/cli/wait.js +8 -0
  147. package/dist/commands/agent.js +645 -0
  148. package/dist/commands/antigravity-oauth.js +327 -0
  149. package/dist/commands/configure.js +480 -0
  150. package/dist/commands/doctor.js +484 -0
  151. package/dist/commands/health.js +108 -0
  152. package/dist/commands/models/aliases.js +64 -0
  153. package/dist/commands/models/fallbacks.js +99 -0
  154. package/dist/commands/models/image-fallbacks.js +99 -0
  155. package/dist/commands/models/list.js +323 -0
  156. package/dist/commands/models/scan.js +266 -0
  157. package/dist/commands/models/set-image.js +23 -0
  158. package/dist/commands/models/set.js +23 -0
  159. package/dist/commands/models/shared.js +72 -0
  160. package/dist/commands/models.js +7 -0
  161. package/dist/commands/onboard-auth.js +70 -0
  162. package/dist/commands/onboard-helpers.js +295 -0
  163. package/dist/commands/onboard-interactive.js +17 -0
  164. package/dist/commands/onboard-non-interactive.js +202 -0
  165. package/dist/commands/onboard-providers.js +634 -0
  166. package/dist/commands/onboard-remote.js +120 -0
  167. package/dist/commands/onboard-skills.js +148 -0
  168. package/dist/commands/onboard-types.js +1 -0
  169. package/dist/commands/onboard.js +12 -0
  170. package/dist/commands/send.js +124 -0
  171. package/dist/commands/sessions.js +212 -0
  172. package/dist/commands/setup.js +58 -0
  173. package/dist/commands/signal-install.js +135 -0
  174. package/dist/commands/status.js +207 -0
  175. package/dist/commands/update.js +16 -0
  176. package/dist/config/config.js +6 -0
  177. package/dist/config/defaults.js +61 -0
  178. package/dist/config/io.js +147 -0
  179. package/dist/config/legacy-migrate.js +13 -0
  180. package/dist/config/legacy.js +159 -0
  181. package/dist/config/paths.js +71 -0
  182. package/dist/config/schema.js +150 -0
  183. package/dist/config/sessions.js +282 -0
  184. package/dist/config/talk.js +31 -0
  185. package/dist/config/types.js +1 -0
  186. package/dist/config/validation.js +29 -0
  187. package/dist/config/zod-schema.js +831 -0
  188. package/dist/control-ui/assets/index-BFID3yAA.css +1 -0
  189. package/dist/control-ui/assets/index-CE_axlTS.js +2235 -0
  190. package/dist/control-ui/assets/index-CE_axlTS.js.map +1 -0
  191. package/dist/control-ui/index.html +15 -0
  192. package/dist/cron/isolated-agent.js +499 -0
  193. package/dist/cron/run-log.js +72 -0
  194. package/dist/cron/schedule.js +24 -0
  195. package/dist/cron/service.js +471 -0
  196. package/dist/cron/store.js +43 -0
  197. package/dist/cron/types.js +1 -0
  198. package/dist/daemon/constants.js +10 -0
  199. package/dist/daemon/launchd.js +276 -0
  200. package/dist/daemon/legacy.js +63 -0
  201. package/dist/daemon/program-args.js +76 -0
  202. package/dist/daemon/schtasks.js +257 -0
  203. package/dist/daemon/service.js +60 -0
  204. package/dist/daemon/systemd.js +266 -0
  205. package/dist/discord/index.js +2 -0
  206. package/dist/discord/monitor.js +1188 -0
  207. package/dist/discord/probe.js +54 -0
  208. package/dist/discord/send.js +577 -0
  209. package/dist/discord/token.js +8 -0
  210. package/dist/gateway/auth.js +121 -0
  211. package/dist/gateway/call.js +94 -0
  212. package/dist/gateway/chat-attachments.js +41 -0
  213. package/dist/gateway/client.js +180 -0
  214. package/dist/gateway/config-reload.js +274 -0
  215. package/dist/gateway/control-ui.js +184 -0
  216. package/dist/gateway/hooks-mapping.js +282 -0
  217. package/dist/gateway/hooks.js +168 -0
  218. package/dist/gateway/net.js +29 -0
  219. package/dist/gateway/protocol/index.js +61 -0
  220. package/dist/gateway/protocol/schema.js +560 -0
  221. package/dist/gateway/server-bridge-subscriptions.js +93 -0
  222. package/dist/gateway/server-bridge.js +1013 -0
  223. package/dist/gateway/server-browser.js +12 -0
  224. package/dist/gateway/server-chat.js +159 -0
  225. package/dist/gateway/server-constants.js +8 -0
  226. package/dist/gateway/server-discovery.js +62 -0
  227. package/dist/gateway/server-http.js +165 -0
  228. package/dist/gateway/server-methods/agent-job.js +125 -0
  229. package/dist/gateway/server-methods/agent.js +250 -0
  230. package/dist/gateway/server-methods/chat.js +200 -0
  231. package/dist/gateway/server-methods/config.js +50 -0
  232. package/dist/gateway/server-methods/connect.js +6 -0
  233. package/dist/gateway/server-methods/cron.js +83 -0
  234. package/dist/gateway/server-methods/health.js +28 -0
  235. package/dist/gateway/server-methods/models.js +16 -0
  236. package/dist/gateway/server-methods/nodes.js +294 -0
  237. package/dist/gateway/server-methods/providers.js +217 -0
  238. package/dist/gateway/server-methods/send.js +166 -0
  239. package/dist/gateway/server-methods/sessions.js +305 -0
  240. package/dist/gateway/server-methods/skills.js +83 -0
  241. package/dist/gateway/server-methods/system.js +118 -0
  242. package/dist/gateway/server-methods/talk.js +22 -0
  243. package/dist/gateway/server-methods/types.js +1 -0
  244. package/dist/gateway/server-methods/voicewake.js +30 -0
  245. package/dist/gateway/server-methods/web.js +58 -0
  246. package/dist/gateway/server-methods/wizard.js +100 -0
  247. package/dist/gateway/server-methods.js +53 -0
  248. package/dist/gateway/server-providers.js +644 -0
  249. package/dist/gateway/server-shared.js +1 -0
  250. package/dist/gateway/server-utils.js +35 -0
  251. package/dist/gateway/server.js +1437 -0
  252. package/dist/gateway/session-utils.js +216 -0
  253. package/dist/gateway/ws-log.js +349 -0
  254. package/dist/gateway/ws-logging.js +8 -0
  255. package/dist/globals.js +41 -0
  256. package/dist/hooks/gmail-ops.js +236 -0
  257. package/dist/hooks/gmail-setup-utils.js +278 -0
  258. package/dist/hooks/gmail-watcher.js +175 -0
  259. package/dist/hooks/gmail.js +177 -0
  260. package/dist/imessage/client.js +165 -0
  261. package/dist/imessage/index.js +3 -0
  262. package/dist/imessage/monitor.js +272 -0
  263. package/dist/imessage/probe.js +26 -0
  264. package/dist/imessage/send.js +83 -0
  265. package/dist/imessage/targets.js +176 -0
  266. package/dist/index.js +50 -0
  267. package/dist/infra/agent-events.js +46 -0
  268. package/dist/infra/binaries.js +9 -0
  269. package/dist/infra/bonjour-discovery.js +163 -0
  270. package/dist/infra/bonjour.js +200 -0
  271. package/dist/infra/bridge/server.js +562 -0
  272. package/dist/infra/canvas-host-url.js +54 -0
  273. package/dist/infra/env.js +8 -0
  274. package/dist/infra/errors.js +28 -0
  275. package/dist/infra/gateway-lock.js +8 -0
  276. package/dist/infra/heartbeat-events.js +21 -0
  277. package/dist/infra/heartbeat-runner.js +453 -0
  278. package/dist/infra/heartbeat-wake.js +61 -0
  279. package/dist/infra/is-main.js +37 -0
  280. package/dist/infra/machine-name.js +40 -0
  281. package/dist/infra/node-pairing.js +211 -0
  282. package/dist/infra/pam.js +42 -0
  283. package/dist/infra/path-env.js +92 -0
  284. package/dist/infra/ports.js +87 -0
  285. package/dist/infra/provider-summary.js +80 -0
  286. package/dist/infra/restart.js +29 -0
  287. package/dist/infra/retry.js +16 -0
  288. package/dist/infra/runtime-guard.js +59 -0
  289. package/dist/infra/system-events.js +44 -0
  290. package/dist/infra/system-presence.js +216 -0
  291. package/dist/infra/tailnet.js +46 -0
  292. package/dist/infra/tailscale.js +149 -0
  293. package/dist/infra/voicewake.js +77 -0
  294. package/dist/infra/widearea-dns.js +123 -0
  295. package/dist/infra/ws.js +13 -0
  296. package/dist/logger.js +52 -0
  297. package/dist/logging.js +490 -0
  298. package/dist/macos/gateway-daemon.js +141 -0
  299. package/dist/macos/relay.js +46 -0
  300. package/dist/media/constants.js +33 -0
  301. package/dist/media/host.js +42 -0
  302. package/dist/media/image-ops.js +121 -0
  303. package/dist/media/mime.js +115 -0
  304. package/dist/media/parse.js +81 -0
  305. package/dist/media/server.js +64 -0
  306. package/dist/media/store.js +139 -0
  307. package/dist/process/command-queue.js +97 -0
  308. package/dist/process/exec.js +75 -0
  309. package/dist/protocol.schema.json +2918 -0
  310. package/dist/provider-web.js +8 -0
  311. package/dist/providers/web/index.js +2 -0
  312. package/dist/runtime.js +8 -0
  313. package/dist/sessions/send-policy.js +68 -0
  314. package/dist/signal/client.js +134 -0
  315. package/dist/signal/daemon.js +69 -0
  316. package/dist/signal/index.js +3 -0
  317. package/dist/signal/monitor.js +336 -0
  318. package/dist/signal/probe.js +46 -0
  319. package/dist/signal/send.js +91 -0
  320. package/dist/slack/actions.js +97 -0
  321. package/dist/slack/index.js +5 -0
  322. package/dist/slack/monitor.js +1029 -0
  323. package/dist/slack/probe.js +47 -0
  324. package/dist/slack/send.js +131 -0
  325. package/dist/slack/token.js +10 -0
  326. package/dist/telegram/bot.js +394 -0
  327. package/dist/telegram/download.js +34 -0
  328. package/dist/telegram/index.js +4 -0
  329. package/dist/telegram/monitor.js +47 -0
  330. package/dist/telegram/probe.js +63 -0
  331. package/dist/telegram/proxy.js +9 -0
  332. package/dist/telegram/send.js +138 -0
  333. package/dist/telegram/token.js +30 -0
  334. package/dist/telegram/webhook-set.js +12 -0
  335. package/dist/telegram/webhook.js +56 -0
  336. package/dist/tui/commands.js +74 -0
  337. package/dist/tui/components/assistant-message.js +16 -0
  338. package/dist/tui/components/chat-log.js +92 -0
  339. package/dist/tui/components/custom-editor.js +53 -0
  340. package/dist/tui/components/selectors.js +8 -0
  341. package/dist/tui/components/tool-execution.js +111 -0
  342. package/dist/tui/components/user-message.js +17 -0
  343. package/dist/tui/gateway-chat.js +140 -0
  344. package/dist/tui/layout.js +41 -0
  345. package/dist/tui/message-list.js +57 -0
  346. package/dist/tui/theme/theme.js +80 -0
  347. package/dist/tui/theme.js +25 -0
  348. package/dist/tui/tui.js +708 -0
  349. package/dist/utils.js +133 -0
  350. package/dist/version.js +18 -0
  351. package/dist/web/active-listener.js +7 -0
  352. package/dist/web/auto-reply.js +1203 -0
  353. package/dist/web/inbound.js +481 -0
  354. package/dist/web/login-qr.js +204 -0
  355. package/dist/web/login.js +59 -0
  356. package/dist/web/media.js +148 -0
  357. package/dist/web/outbound.js +67 -0
  358. package/dist/web/qr-image.js +97 -0
  359. package/dist/web/reconnect.js +60 -0
  360. package/dist/web/reply-heartbeat-wake.js +61 -0
  361. package/dist/web/session.js +346 -0
  362. package/dist/wizard/clack-prompter.js +56 -0
  363. package/dist/wizard/onboarding.js +452 -0
  364. package/dist/wizard/prompts.js +6 -0
  365. package/dist/wizard/session.js +203 -0
  366. package/docs/AGENTS.default.md +116 -0
  367. package/docs/CNAME +1 -0
  368. package/docs/RELEASING.md +64 -0
  369. package/docs/_config.yml +51 -0
  370. package/docs/_layouts/default.html +145 -0
  371. package/docs/agent-send.md +21 -0
  372. package/docs/agent.md +104 -0
  373. package/docs/android/connect.md +131 -0
  374. package/docs/architecture.md +89 -0
  375. package/docs/assets/markdown.css +130 -0
  376. package/docs/assets/pixel-lobster.svg +60 -0
  377. package/docs/assets/terminal.css +497 -0
  378. package/docs/assets/theme.js +55 -0
  379. package/docs/audio.md +50 -0
  380. package/docs/background-process.md +74 -0
  381. package/docs/bash.md +32 -0
  382. package/docs/bonjour.md +159 -0
  383. package/docs/browser.md +289 -0
  384. package/docs/camera.md +152 -0
  385. package/docs/clawd.md +199 -0
  386. package/docs/clawdbot-mac.md +104 -0
  387. package/docs/configuration.md +1177 -0
  388. package/docs/control-api.md +49 -0
  389. package/docs/control-ui.md +83 -0
  390. package/docs/cron.md +374 -0
  391. package/docs/dashboard.md +17 -0
  392. package/docs/device-models.md +46 -0
  393. package/docs/discord.md +293 -0
  394. package/docs/discovery.md +112 -0
  395. package/docs/docker.md +251 -0
  396. package/docs/docs.json +86 -0
  397. package/docs/doctor.md +47 -0
  398. package/docs/elevated.md +31 -0
  399. package/docs/faq.md +640 -0
  400. package/docs/gateway/pairing.md +109 -0
  401. package/docs/gateway-lock.md +28 -0
  402. package/docs/gateway.md +174 -0
  403. package/docs/gmail-pubsub.md +191 -0
  404. package/docs/grammy.md +27 -0
  405. package/docs/group-messages.md +71 -0
  406. package/docs/groups.md +78 -0
  407. package/docs/health.md +28 -0
  408. package/docs/heartbeat.md +64 -0
  409. package/docs/images.md +52 -0
  410. package/docs/imessage.md +63 -0
  411. package/docs/index.md +182 -0
  412. package/docs/ios/connect.md +177 -0
  413. package/docs/ios/spec.md +236 -0
  414. package/docs/location-command.md +95 -0
  415. package/docs/logging.md +99 -0
  416. package/docs/lore.md +131 -0
  417. package/docs/mac/bun.md +133 -0
  418. package/docs/mac/canvas.md +161 -0
  419. package/docs/mac/child-process.md +72 -0
  420. package/docs/mac/dev-setup.md +81 -0
  421. package/docs/mac/health.md +28 -0
  422. package/docs/mac/icon.md +26 -0
  423. package/docs/mac/logging.md +51 -0
  424. package/docs/mac/menu-bar.md +69 -0
  425. package/docs/mac/peekaboo.md +170 -0
  426. package/docs/mac/permissions.md +40 -0
  427. package/docs/mac/release.md +76 -0
  428. package/docs/mac/remote.md +57 -0
  429. package/docs/mac/signing.md +41 -0
  430. package/docs/mac/skills.md +27 -0
  431. package/docs/mac/voice-overlay.md +52 -0
  432. package/docs/mac/voicewake.md +56 -0
  433. package/docs/mac/webchat.md +27 -0
  434. package/docs/mac/xpc.md +40 -0
  435. package/docs/models.md +90 -0
  436. package/docs/nix.md +49 -0
  437. package/docs/nodes.md +157 -0
  438. package/docs/onboarding-config-protocol.md +29 -0
  439. package/docs/onboarding.md +185 -0
  440. package/docs/presence.md +133 -0
  441. package/docs/queue.md +78 -0
  442. package/docs/refactor/browser-control-simplification.md +58 -0
  443. package/docs/refactor/canvas-a2ui.md +93 -0
  444. package/docs/refactor/cli-unification.md +64 -0
  445. package/docs/refactor/gateway-client.md +31 -0
  446. package/docs/refactor/gateway.md +99 -0
  447. package/docs/refactor/new-arch.md +171 -0
  448. package/docs/refactor/tui.md +26 -0
  449. package/docs/refactor/web-gateway-troubleshooting.md +37 -0
  450. package/docs/refactor/webagent-session.md +46 -0
  451. package/docs/remote-gateway-readme.md +148 -0
  452. package/docs/remote.md +66 -0
  453. package/docs/research/memory.md +227 -0
  454. package/docs/rpc.md +35 -0
  455. package/docs/security.md +168 -0
  456. package/docs/session-tool.md +119 -0
  457. package/docs/session.md +84 -0
  458. package/docs/sessions.md +8 -0
  459. package/docs/setup.md +118 -0
  460. package/docs/signal.md +113 -0
  461. package/docs/skills-config.md +58 -0
  462. package/docs/skills.md +149 -0
  463. package/docs/slack.md +158 -0
  464. package/docs/surface.md +20 -0
  465. package/docs/tailscale.md +71 -0
  466. package/docs/talk.md +79 -0
  467. package/docs/telegram.md +90 -0
  468. package/docs/templates/AGENTS.md +126 -0
  469. package/docs/templates/BOOTSTRAP.md +53 -0
  470. package/docs/templates/IDENTITY.md +17 -0
  471. package/docs/templates/SOUL.md +41 -0
  472. package/docs/templates/TOOLS.md +41 -0
  473. package/docs/templates/USER.md +22 -0
  474. package/docs/test.md +35 -0
  475. package/docs/thinking.md +46 -0
  476. package/docs/tools.md +248 -0
  477. package/docs/troubleshooting.md +227 -0
  478. package/docs/tui.md +69 -0
  479. package/docs/typebox.md +42 -0
  480. package/docs/voicewake.md +61 -0
  481. package/docs/web.md +115 -0
  482. package/docs/webchat.md +34 -0
  483. package/docs/webhook.md +132 -0
  484. package/docs/whatsapp-clawd.jpg +0 -0
  485. package/docs/whatsapp.md +142 -0
  486. package/docs/wizard.md +158 -0
  487. package/package.json +186 -0
  488. package/skills/apple-notes/SKILL.md +50 -0
  489. package/skills/apple-reminders/SKILL.md +67 -0
  490. package/skills/bear-notes/SKILL.md +79 -0
  491. package/skills/bird/SKILL.md +25 -0
  492. package/skills/blogwatcher/SKILL.md +46 -0
  493. package/skills/blucli/SKILL.md +27 -0
  494. package/skills/brave-search/SKILL.md +30 -0
  495. package/skills/brave-search/scripts/content.mjs +53 -0
  496. package/skills/brave-search/scripts/search.mjs +79 -0
  497. package/skills/camsnap/SKILL.md +25 -0
  498. package/skills/clawdhub/SKILL.md +53 -0
  499. package/skills/coding-agent/SKILL.md +275 -0
  500. package/skills/discord/SKILL.md +369 -0
  501. package/skills/eightctl/SKILL.md +29 -0
  502. package/skills/food-order/SKILL.md +41 -0
  503. package/skills/gemini/SKILL.md +23 -0
  504. package/skills/gifgrep/SKILL.md +47 -0
  505. package/skills/github/SKILL.md +47 -0
  506. package/skills/gog/SKILL.md +36 -0
  507. package/skills/goplaces/SKILL.md +30 -0
  508. package/skills/imsg/SKILL.md +25 -0
  509. package/skills/local-places/SERVER_README.md +101 -0
  510. package/skills/local-places/SKILL.md +91 -0
  511. package/skills/local-places/pyproject.toml +27 -0
  512. package/skills/local-places/src/local_places/__init__.py +2 -0
  513. package/skills/local-places/src/local_places/__pycache__/__init__.cpython-314.pyc +0 -0
  514. package/skills/local-places/src/local_places/__pycache__/google_places.cpython-314.pyc +0 -0
  515. package/skills/local-places/src/local_places/__pycache__/main.cpython-314.pyc +0 -0
  516. package/skills/local-places/src/local_places/__pycache__/schemas.cpython-314.pyc +0 -0
  517. package/skills/local-places/src/local_places/google_places.py +314 -0
  518. package/skills/local-places/src/local_places/main.py +65 -0
  519. package/skills/local-places/src/local_places/schemas.py +107 -0
  520. package/skills/mcporter/SKILL.md +38 -0
  521. package/skills/nano-banana-pro/SKILL.md +29 -0
  522. package/skills/nano-banana-pro/scripts/generate_image.py +167 -0
  523. package/skills/nano-pdf/SKILL.md +20 -0
  524. package/skills/notion/SKILL.md +156 -0
  525. package/skills/obsidian/SKILL.md +55 -0
  526. package/skills/openai-image-gen/SKILL.md +31 -0
  527. package/skills/openai-image-gen/scripts/gen.py +173 -0
  528. package/skills/openai-whisper/SKILL.md +19 -0
  529. package/skills/openai-whisper-api/SKILL.md +43 -0
  530. package/skills/openai-whisper-api/scripts/transcribe.sh +85 -0
  531. package/skills/openhue/SKILL.md +30 -0
  532. package/skills/oracle/SKILL.md +105 -0
  533. package/skills/ordercli/SKILL.md +47 -0
  534. package/skills/peekaboo/SKILL.md +153 -0
  535. package/skills/qmd/SKILL.md +26 -0
  536. package/skills/sag/SKILL.md +62 -0
  537. package/skills/slack/SKILL.md +143 -0
  538. package/skills/songsee/SKILL.md +29 -0
  539. package/skills/sonoscli/SKILL.md +26 -0
  540. package/skills/spotify-player/SKILL.md +34 -0
  541. package/skills/summarize/SKILL.md +49 -0
  542. package/skills/things-mac/SKILL.md +61 -0
  543. package/skills/tmux/SKILL.md +121 -0
  544. package/skills/tmux/scripts/find-sessions.sh +112 -0
  545. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  546. package/skills/trello/SKILL.md +84 -0
  547. package/skills/video-frames/SKILL.md +29 -0
  548. package/skills/video-frames/scripts/frame.sh +81 -0
  549. package/skills/wacli/SKILL.md +42 -0
  550. package/skills/weather/SKILL.md +49 -0
@@ -0,0 +1,708 @@
1
+ import { CombinedAutocompleteProvider, Container, ProcessTerminal, Text, TUI, } from "@mariozechner/pi-tui";
2
+ import { loadConfig } from "../config/config.js";
3
+ import { getSlashCommands, helpText, parseCommand } from "./commands.js";
4
+ import { ChatLog } from "./components/chat-log.js";
5
+ import { CustomEditor } from "./components/custom-editor.js";
6
+ import { createSelectList, createSettingsList, } from "./components/selectors.js";
7
+ import { GatewayChatClient } from "./gateway-chat.js";
8
+ import { editorTheme, theme } from "./theme/theme.js";
9
+ function extractTextBlocks(content, opts) {
10
+ if (typeof content === "string")
11
+ return content.trim();
12
+ if (!Array.isArray(content))
13
+ return "";
14
+ const parts = [];
15
+ for (const block of content) {
16
+ if (!block || typeof block !== "object")
17
+ continue;
18
+ const record = block;
19
+ if (record.type === "text" && typeof record.text === "string") {
20
+ parts.push(record.text);
21
+ }
22
+ if (opts?.includeThinking &&
23
+ record.type === "thinking" &&
24
+ typeof record.thinking === "string") {
25
+ parts.push(`[thinking]\n${record.thinking}`);
26
+ }
27
+ }
28
+ return parts.join("\n").trim();
29
+ }
30
+ function extractTextFromMessage(message, opts) {
31
+ if (!message || typeof message !== "object")
32
+ return "";
33
+ const record = message;
34
+ return extractTextBlocks(record.content, opts);
35
+ }
36
+ function formatTokens(total, context) {
37
+ if (!total && !context)
38
+ return "tokens ?";
39
+ if (!context)
40
+ return `tokens ${total ?? 0}`;
41
+ const pct = typeof total === "number" && context > 0
42
+ ? Math.min(999, Math.round((total / context) * 100))
43
+ : null;
44
+ return `tokens ${total ?? 0}/${context}${pct !== null ? ` (${pct}%)` : ""}`;
45
+ }
46
+ function asString(value, fallback = "") {
47
+ if (typeof value === "string")
48
+ return value;
49
+ if (typeof value === "number" || typeof value === "boolean") {
50
+ return String(value);
51
+ }
52
+ return fallback;
53
+ }
54
+ export async function runTui(opts) {
55
+ const config = loadConfig();
56
+ const defaultSession = (opts.session ?? config.session?.mainKey ?? "main").trim() || "main";
57
+ let currentSessionKey = defaultSession;
58
+ let currentSessionId = null;
59
+ let activeChatRunId = null;
60
+ const finalizedRuns = new Map();
61
+ let historyLoaded = false;
62
+ let isConnected = false;
63
+ let toolsExpanded = false;
64
+ let showThinking = false;
65
+ let deliverDefault = Boolean(opts.deliver);
66
+ let sessionInfo = {};
67
+ let lastCtrlCAt = 0;
68
+ const client = new GatewayChatClient({
69
+ url: opts.url,
70
+ token: opts.token,
71
+ password: opts.password,
72
+ });
73
+ const header = new Text("", 1, 0);
74
+ const status = new Text("", 1, 0);
75
+ const footer = new Text("", 1, 0);
76
+ const chatLog = new ChatLog();
77
+ const editor = new CustomEditor(editorTheme);
78
+ const overlay = new Container();
79
+ const root = new Container();
80
+ root.addChild(header);
81
+ root.addChild(overlay);
82
+ root.addChild(chatLog);
83
+ root.addChild(status);
84
+ root.addChild(footer);
85
+ root.addChild(editor);
86
+ const tui = new TUI(new ProcessTerminal());
87
+ tui.addChild(root);
88
+ tui.setFocus(editor);
89
+ const updateHeader = () => {
90
+ header.setText(theme.header(`clawdbot tui - ${client.connection.url} - session ${currentSessionKey}`));
91
+ };
92
+ const setStatus = (text) => {
93
+ status.setText(theme.dim(text));
94
+ };
95
+ const updateFooter = () => {
96
+ const connection = isConnected ? "connected" : "disconnected";
97
+ const sessionLabel = sessionInfo.displayName
98
+ ? `${currentSessionKey} (${sessionInfo.displayName})`
99
+ : currentSessionKey;
100
+ const modelLabel = sessionInfo.model ?? "unknown";
101
+ const tokens = formatTokens(sessionInfo.totalTokens ?? null, sessionInfo.contextTokens ?? null);
102
+ const think = sessionInfo.thinkingLevel ?? "off";
103
+ const verbose = sessionInfo.verboseLevel ?? "off";
104
+ const deliver = deliverDefault ? "on" : "off";
105
+ footer.setText(theme.dim(`${connection} | session ${sessionLabel} | model ${modelLabel} | think ${think} | verbose ${verbose} | ${tokens} | deliver ${deliver}`));
106
+ };
107
+ const closeOverlay = () => {
108
+ overlay.clear();
109
+ tui.setFocus(editor);
110
+ };
111
+ const openOverlay = (component) => {
112
+ overlay.clear();
113
+ overlay.addChild(component);
114
+ tui.setFocus(component);
115
+ };
116
+ const refreshSessionInfo = async () => {
117
+ try {
118
+ const result = await client.listSessions({
119
+ includeGlobal: false,
120
+ includeUnknown: false,
121
+ });
122
+ const entry = result.sessions.find((row) => row.key === currentSessionKey);
123
+ sessionInfo = {
124
+ thinkingLevel: entry?.thinkingLevel,
125
+ verboseLevel: entry?.verboseLevel,
126
+ model: entry?.model ?? result.defaults?.model ?? undefined,
127
+ contextTokens: entry?.contextTokens ?? result.defaults?.contextTokens,
128
+ totalTokens: entry?.totalTokens ?? null,
129
+ updatedAt: entry?.updatedAt ?? null,
130
+ displayName: entry?.displayName,
131
+ };
132
+ }
133
+ catch (err) {
134
+ chatLog.addSystem(`sessions list failed: ${String(err)}`);
135
+ }
136
+ updateFooter();
137
+ tui.requestRender();
138
+ };
139
+ const loadHistory = async () => {
140
+ try {
141
+ const history = await client.loadHistory({
142
+ sessionKey: currentSessionKey,
143
+ limit: opts.historyLimit ?? 200,
144
+ });
145
+ const record = history;
146
+ currentSessionId =
147
+ typeof record.sessionId === "string" ? record.sessionId : null;
148
+ sessionInfo.thinkingLevel =
149
+ record.thinkingLevel ?? sessionInfo.thinkingLevel;
150
+ chatLog.clearAll();
151
+ chatLog.addSystem(`session ${currentSessionKey}`);
152
+ for (const entry of record.messages ?? []) {
153
+ if (!entry || typeof entry !== "object")
154
+ continue;
155
+ const message = entry;
156
+ if (message.role === "user") {
157
+ const text = extractTextFromMessage(message);
158
+ if (text)
159
+ chatLog.addUser(text);
160
+ continue;
161
+ }
162
+ if (message.role === "assistant") {
163
+ const text = extractTextFromMessage(message, {
164
+ includeThinking: showThinking,
165
+ });
166
+ if (text)
167
+ chatLog.finalizeAssistant(text);
168
+ continue;
169
+ }
170
+ if (message.role === "toolResult") {
171
+ const toolCallId = asString(message.toolCallId, "");
172
+ const toolName = asString(message.toolName, "tool");
173
+ const component = chatLog.startTool(toolCallId, toolName, {});
174
+ component.setResult({
175
+ content: Array.isArray(message.content)
176
+ ? message.content
177
+ : [],
178
+ details: typeof message.details === "object" && message.details
179
+ ? message.details
180
+ : undefined,
181
+ }, { isError: Boolean(message.isError) });
182
+ }
183
+ }
184
+ historyLoaded = true;
185
+ }
186
+ catch (err) {
187
+ chatLog.addSystem(`history failed: ${String(err)}`);
188
+ }
189
+ await refreshSessionInfo();
190
+ tui.requestRender();
191
+ };
192
+ const setSession = async (key) => {
193
+ currentSessionKey = key;
194
+ activeChatRunId = null;
195
+ currentSessionId = null;
196
+ historyLoaded = false;
197
+ updateHeader();
198
+ await loadHistory();
199
+ };
200
+ const abortActive = async () => {
201
+ if (!activeChatRunId) {
202
+ chatLog.addSystem("no active run");
203
+ tui.requestRender();
204
+ return;
205
+ }
206
+ try {
207
+ await client.abortChat({
208
+ sessionKey: currentSessionKey,
209
+ runId: activeChatRunId,
210
+ });
211
+ setStatus("aborted");
212
+ }
213
+ catch (err) {
214
+ chatLog.addSystem(`abort failed: ${String(err)}`);
215
+ setStatus("abort failed");
216
+ }
217
+ tui.requestRender();
218
+ };
219
+ const noteFinalizedRun = (runId) => {
220
+ finalizedRuns.set(runId, Date.now());
221
+ if (finalizedRuns.size <= 200)
222
+ return;
223
+ const keepUntil = Date.now() - 10 * 60 * 1000;
224
+ for (const [key, ts] of finalizedRuns) {
225
+ if (finalizedRuns.size <= 150)
226
+ break;
227
+ if (ts < keepUntil)
228
+ finalizedRuns.delete(key);
229
+ }
230
+ if (finalizedRuns.size > 200) {
231
+ for (const key of finalizedRuns.keys()) {
232
+ finalizedRuns.delete(key);
233
+ if (finalizedRuns.size <= 150)
234
+ break;
235
+ }
236
+ }
237
+ };
238
+ const handleChatEvent = (payload) => {
239
+ if (!payload || typeof payload !== "object")
240
+ return;
241
+ const evt = payload;
242
+ if (evt.sessionKey !== currentSessionKey)
243
+ return;
244
+ if (finalizedRuns.has(evt.runId)) {
245
+ if (evt.state === "delta")
246
+ return;
247
+ if (evt.state === "final")
248
+ return;
249
+ }
250
+ if (evt.state === "delta") {
251
+ const text = extractTextFromMessage(evt.message, {
252
+ includeThinking: showThinking,
253
+ });
254
+ if (!text)
255
+ return;
256
+ chatLog.updateAssistant(text, evt.runId);
257
+ setStatus("streaming");
258
+ }
259
+ if (evt.state === "final") {
260
+ const text = extractTextFromMessage(evt.message, {
261
+ includeThinking: showThinking,
262
+ });
263
+ chatLog.finalizeAssistant(text || "(no output)", evt.runId);
264
+ noteFinalizedRun(evt.runId);
265
+ activeChatRunId = null;
266
+ setStatus("idle");
267
+ }
268
+ if (evt.state === "aborted") {
269
+ chatLog.addSystem("run aborted");
270
+ activeChatRunId = null;
271
+ setStatus("aborted");
272
+ }
273
+ if (evt.state === "error") {
274
+ chatLog.addSystem(`run error: ${evt.errorMessage ?? "unknown"}`);
275
+ activeChatRunId = null;
276
+ setStatus("error");
277
+ }
278
+ tui.requestRender();
279
+ };
280
+ const handleAgentEvent = (payload) => {
281
+ if (!payload || typeof payload !== "object")
282
+ return;
283
+ const evt = payload;
284
+ if (!currentSessionId || evt.runId !== currentSessionId)
285
+ return;
286
+ if (evt.stream === "tool") {
287
+ const data = evt.data ?? {};
288
+ const phase = asString(data.phase, "");
289
+ const toolCallId = asString(data.toolCallId, "");
290
+ const toolName = asString(data.name, "tool");
291
+ if (!toolCallId)
292
+ return;
293
+ if (phase === "start") {
294
+ chatLog.startTool(toolCallId, toolName, data.args);
295
+ }
296
+ else if (phase === "update") {
297
+ chatLog.updateToolResult(toolCallId, data.partialResult, {
298
+ partial: true,
299
+ });
300
+ }
301
+ else if (phase === "result") {
302
+ chatLog.updateToolResult(toolCallId, data.result, {
303
+ isError: Boolean(data.isError),
304
+ });
305
+ }
306
+ tui.requestRender();
307
+ return;
308
+ }
309
+ if (evt.stream === "job") {
310
+ const state = typeof evt.data?.state === "string" ? evt.data.state : "";
311
+ if (state === "started")
312
+ setStatus("running");
313
+ if (state === "done")
314
+ setStatus("idle");
315
+ if (state === "error")
316
+ setStatus("error");
317
+ tui.requestRender();
318
+ }
319
+ };
320
+ const openModelSelector = async () => {
321
+ try {
322
+ const models = await client.listModels();
323
+ if (models.length === 0) {
324
+ chatLog.addSystem("no models available");
325
+ tui.requestRender();
326
+ return;
327
+ }
328
+ const items = models.map((model) => ({
329
+ value: `${model.provider}/${model.id}`,
330
+ label: `${model.provider}/${model.id}`,
331
+ description: model.name && model.name !== model.id ? model.name : "",
332
+ }));
333
+ const selector = createSelectList(items, 9);
334
+ selector.onSelect = (item) => {
335
+ void (async () => {
336
+ try {
337
+ await client.patchSession({
338
+ key: currentSessionKey,
339
+ model: item.value,
340
+ });
341
+ chatLog.addSystem(`model set to ${item.value}`);
342
+ await refreshSessionInfo();
343
+ }
344
+ catch (err) {
345
+ chatLog.addSystem(`model set failed: ${String(err)}`);
346
+ }
347
+ closeOverlay();
348
+ tui.requestRender();
349
+ })();
350
+ };
351
+ selector.onCancel = () => {
352
+ closeOverlay();
353
+ tui.requestRender();
354
+ };
355
+ openOverlay(selector);
356
+ tui.requestRender();
357
+ }
358
+ catch (err) {
359
+ chatLog.addSystem(`model list failed: ${String(err)}`);
360
+ tui.requestRender();
361
+ }
362
+ };
363
+ const openSessionSelector = async () => {
364
+ try {
365
+ const result = await client.listSessions({
366
+ includeGlobal: false,
367
+ includeUnknown: false,
368
+ });
369
+ const items = result.sessions.map((session) => ({
370
+ value: session.key,
371
+ label: session.displayName ?? session.key,
372
+ description: session.updatedAt
373
+ ? new Date(session.updatedAt).toLocaleString()
374
+ : "",
375
+ }));
376
+ const selector = createSelectList(items, 9);
377
+ selector.onSelect = (item) => {
378
+ void (async () => {
379
+ closeOverlay();
380
+ await setSession(item.value);
381
+ tui.requestRender();
382
+ })();
383
+ };
384
+ selector.onCancel = () => {
385
+ closeOverlay();
386
+ tui.requestRender();
387
+ };
388
+ openOverlay(selector);
389
+ tui.requestRender();
390
+ }
391
+ catch (err) {
392
+ chatLog.addSystem(`sessions list failed: ${String(err)}`);
393
+ tui.requestRender();
394
+ }
395
+ };
396
+ const openSettings = () => {
397
+ const items = [
398
+ {
399
+ id: "deliver",
400
+ label: "Deliver replies",
401
+ currentValue: deliverDefault ? "on" : "off",
402
+ values: ["off", "on"],
403
+ },
404
+ {
405
+ id: "tools",
406
+ label: "Tool output",
407
+ currentValue: toolsExpanded ? "expanded" : "collapsed",
408
+ values: ["collapsed", "expanded"],
409
+ },
410
+ {
411
+ id: "thinking",
412
+ label: "Show thinking",
413
+ currentValue: showThinking ? "on" : "off",
414
+ values: ["off", "on"],
415
+ },
416
+ ];
417
+ const settings = createSettingsList(items, (id, value) => {
418
+ if (id === "deliver") {
419
+ deliverDefault = value === "on";
420
+ updateFooter();
421
+ }
422
+ if (id === "tools") {
423
+ toolsExpanded = value === "expanded";
424
+ chatLog.setToolsExpanded(toolsExpanded);
425
+ }
426
+ if (id === "thinking") {
427
+ showThinking = value === "on";
428
+ void loadHistory();
429
+ }
430
+ tui.requestRender();
431
+ }, () => {
432
+ closeOverlay();
433
+ tui.requestRender();
434
+ });
435
+ openOverlay(settings);
436
+ tui.requestRender();
437
+ };
438
+ const handleCommand = async (raw) => {
439
+ const { name, args } = parseCommand(raw);
440
+ if (!name)
441
+ return;
442
+ switch (name) {
443
+ case "help":
444
+ chatLog.addSystem(helpText());
445
+ break;
446
+ case "status":
447
+ try {
448
+ const status = await client.getStatus();
449
+ chatLog.addSystem(typeof status === "string"
450
+ ? status
451
+ : JSON.stringify(status, null, 2));
452
+ }
453
+ catch (err) {
454
+ chatLog.addSystem(`status failed: ${String(err)}`);
455
+ }
456
+ break;
457
+ case "session":
458
+ if (!args) {
459
+ await openSessionSelector();
460
+ }
461
+ else {
462
+ await setSession(args);
463
+ }
464
+ break;
465
+ case "sessions":
466
+ await openSessionSelector();
467
+ break;
468
+ case "model":
469
+ if (!args) {
470
+ await openModelSelector();
471
+ }
472
+ else {
473
+ try {
474
+ await client.patchSession({
475
+ key: currentSessionKey,
476
+ model: args,
477
+ });
478
+ chatLog.addSystem(`model set to ${args}`);
479
+ await refreshSessionInfo();
480
+ }
481
+ catch (err) {
482
+ chatLog.addSystem(`model set failed: ${String(err)}`);
483
+ }
484
+ }
485
+ break;
486
+ case "models":
487
+ await openModelSelector();
488
+ break;
489
+ case "think":
490
+ if (!args) {
491
+ chatLog.addSystem("usage: /think <off|minimal|low|medium|high>");
492
+ break;
493
+ }
494
+ try {
495
+ await client.patchSession({
496
+ key: currentSessionKey,
497
+ thinkingLevel: args,
498
+ });
499
+ chatLog.addSystem(`thinking set to ${args}`);
500
+ await refreshSessionInfo();
501
+ }
502
+ catch (err) {
503
+ chatLog.addSystem(`think failed: ${String(err)}`);
504
+ }
505
+ break;
506
+ case "verbose":
507
+ if (!args) {
508
+ chatLog.addSystem("usage: /verbose <on|off>");
509
+ break;
510
+ }
511
+ try {
512
+ await client.patchSession({
513
+ key: currentSessionKey,
514
+ verboseLevel: args,
515
+ });
516
+ chatLog.addSystem(`verbose set to ${args}`);
517
+ await refreshSessionInfo();
518
+ }
519
+ catch (err) {
520
+ chatLog.addSystem(`verbose failed: ${String(err)}`);
521
+ }
522
+ break;
523
+ case "elevated":
524
+ if (!args) {
525
+ chatLog.addSystem("usage: /elevated <on|off>");
526
+ break;
527
+ }
528
+ try {
529
+ await client.patchSession({
530
+ key: currentSessionKey,
531
+ elevatedLevel: args,
532
+ });
533
+ chatLog.addSystem(`elevated set to ${args}`);
534
+ await refreshSessionInfo();
535
+ }
536
+ catch (err) {
537
+ chatLog.addSystem(`elevated failed: ${String(err)}`);
538
+ }
539
+ break;
540
+ case "activation":
541
+ if (!args) {
542
+ chatLog.addSystem("usage: /activation <mention|always>");
543
+ break;
544
+ }
545
+ try {
546
+ await client.patchSession({
547
+ key: currentSessionKey,
548
+ groupActivation: args === "always" ? "always" : "mention",
549
+ });
550
+ chatLog.addSystem(`activation set to ${args}`);
551
+ await refreshSessionInfo();
552
+ }
553
+ catch (err) {
554
+ chatLog.addSystem(`activation failed: ${String(err)}`);
555
+ }
556
+ break;
557
+ case "deliver":
558
+ if (!args) {
559
+ chatLog.addSystem("usage: /deliver <on|off>");
560
+ break;
561
+ }
562
+ deliverDefault = args === "on";
563
+ updateFooter();
564
+ chatLog.addSystem(`deliver ${deliverDefault ? "on" : "off"}`);
565
+ break;
566
+ case "new":
567
+ case "reset":
568
+ try {
569
+ await client.resetSession(currentSessionKey);
570
+ chatLog.addSystem(`session ${currentSessionKey} reset`);
571
+ await loadHistory();
572
+ }
573
+ catch (err) {
574
+ chatLog.addSystem(`reset failed: ${String(err)}`);
575
+ }
576
+ break;
577
+ case "abort":
578
+ await abortActive();
579
+ break;
580
+ case "settings":
581
+ openSettings();
582
+ break;
583
+ case "exit":
584
+ case "quit":
585
+ client.stop();
586
+ tui.stop();
587
+ process.exit(0);
588
+ break;
589
+ default:
590
+ chatLog.addSystem(`unknown command: /${name}`);
591
+ break;
592
+ }
593
+ tui.requestRender();
594
+ };
595
+ const sendMessage = async (text) => {
596
+ try {
597
+ chatLog.addUser(text);
598
+ tui.requestRender();
599
+ setStatus("sending");
600
+ const { runId } = await client.sendChat({
601
+ sessionKey: currentSessionKey,
602
+ message: text,
603
+ thinking: opts.thinking,
604
+ deliver: deliverDefault,
605
+ timeoutMs: opts.timeoutMs,
606
+ });
607
+ activeChatRunId = runId;
608
+ setStatus("waiting");
609
+ }
610
+ catch (err) {
611
+ chatLog.addSystem(`send failed: ${String(err)}`);
612
+ setStatus("error");
613
+ }
614
+ tui.requestRender();
615
+ };
616
+ editor.setAutocompleteProvider(new CombinedAutocompleteProvider(getSlashCommands(), process.cwd()));
617
+ editor.onSubmit = (text) => {
618
+ const value = text.trim();
619
+ editor.setText("");
620
+ if (!value)
621
+ return;
622
+ if (value.startsWith("/")) {
623
+ void handleCommand(value);
624
+ return;
625
+ }
626
+ void sendMessage(value);
627
+ };
628
+ editor.onEscape = () => {
629
+ void abortActive();
630
+ };
631
+ editor.onCtrlC = () => {
632
+ const now = Date.now();
633
+ if (editor.getText().trim().length > 0) {
634
+ editor.setText("");
635
+ setStatus("cleared input");
636
+ tui.requestRender();
637
+ return;
638
+ }
639
+ if (now - lastCtrlCAt < 1000) {
640
+ client.stop();
641
+ tui.stop();
642
+ process.exit(0);
643
+ }
644
+ lastCtrlCAt = now;
645
+ setStatus("press ctrl+c again to exit");
646
+ tui.requestRender();
647
+ };
648
+ editor.onCtrlD = () => {
649
+ client.stop();
650
+ tui.stop();
651
+ process.exit(0);
652
+ };
653
+ editor.onCtrlO = () => {
654
+ toolsExpanded = !toolsExpanded;
655
+ chatLog.setToolsExpanded(toolsExpanded);
656
+ setStatus(toolsExpanded ? "tools expanded" : "tools collapsed");
657
+ tui.requestRender();
658
+ };
659
+ editor.onCtrlL = () => {
660
+ void openModelSelector();
661
+ };
662
+ editor.onCtrlP = () => {
663
+ void openSessionSelector();
664
+ };
665
+ editor.onCtrlT = () => {
666
+ showThinking = !showThinking;
667
+ void loadHistory();
668
+ };
669
+ client.onEvent = (evt) => {
670
+ if (evt.event === "chat")
671
+ handleChatEvent(evt.payload);
672
+ if (evt.event === "agent")
673
+ handleAgentEvent(evt.payload);
674
+ };
675
+ client.onConnected = () => {
676
+ isConnected = true;
677
+ setStatus("connected");
678
+ updateHeader();
679
+ if (!historyLoaded) {
680
+ void loadHistory().then(() => {
681
+ chatLog.addSystem("gateway connected");
682
+ tui.requestRender();
683
+ });
684
+ }
685
+ else {
686
+ chatLog.addSystem("gateway reconnected");
687
+ }
688
+ updateFooter();
689
+ tui.requestRender();
690
+ };
691
+ client.onDisconnected = (reason) => {
692
+ isConnected = false;
693
+ chatLog.addSystem(`gateway disconnected: ${reason || "closed"}`);
694
+ setStatus("disconnected");
695
+ updateFooter();
696
+ tui.requestRender();
697
+ };
698
+ client.onGap = (info) => {
699
+ chatLog.addSystem(`event gap: expected ${info.expected}, got ${info.received}`);
700
+ tui.requestRender();
701
+ };
702
+ updateHeader();
703
+ setStatus("connecting");
704
+ updateFooter();
705
+ chatLog.addSystem("connecting...");
706
+ tui.start();
707
+ client.start();
708
+ }