@captain-app/openclaw 2026.2.4

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 (1686) hide show
  1. package/CHANGELOG.md +1528 -0
  2. package/LICENSE +21 -0
  3. package/README-header.png +0 -0
  4. package/README.md +539 -0
  5. package/assets/avatar-placeholder.svg +19 -0
  6. package/assets/chrome-extension/README.md +22 -0
  7. package/assets/chrome-extension/background.js +438 -0
  8. package/assets/chrome-extension/icons/icon128.png +0 -0
  9. package/assets/chrome-extension/icons/icon16.png +0 -0
  10. package/assets/chrome-extension/icons/icon32.png +0 -0
  11. package/assets/chrome-extension/icons/icon48.png +0 -0
  12. package/assets/chrome-extension/manifest.json +25 -0
  13. package/assets/chrome-extension/options.html +196 -0
  14. package/assets/chrome-extension/options.js +59 -0
  15. package/assets/dmg-background-small.png +0 -0
  16. package/assets/dmg-background.png +0 -0
  17. package/dist/accounts-ClnuDahN.js +250 -0
  18. package/dist/accounts-DzBgAM3C.js +251 -0
  19. package/dist/acp-cli-BEDDkzXH.js +926 -0
  20. package/dist/acp-cli-CwV4mdnW.js +923 -0
  21. package/dist/agent-CArjbSeE.js +695 -0
  22. package/dist/agent-CB7x5HLT.js +695 -0
  23. package/dist/agent-scope-BbT4OG2N.js +545 -0
  24. package/dist/agent-scope-C_O6Vpl0.js +545 -0
  25. package/dist/agent-scope-Csu2B6AM.js +606 -0
  26. package/dist/archive-CWrnG1CH.js +85 -0
  27. package/dist/archive-ccN9aDgq.js +85 -0
  28. package/dist/audit-DXPkQ275.js +1686 -0
  29. package/dist/audit-eH7nwgsM.js +1686 -0
  30. package/dist/auth-health-Bj7Gjbv0.js +149 -0
  31. package/dist/auth-health-CjjJhHey.js +149 -0
  32. package/dist/auth-nnRYiqpH.js +192 -0
  33. package/dist/auth-profiles-DVLfuixr.js +2954 -0
  34. package/dist/auth-y1BLPUhX.js +192 -0
  35. package/dist/boolean-Wzu0-e0P.js +30 -0
  36. package/dist/brew-Cqi8b49_.js +46 -0
  37. package/dist/brew-DyBGNK8A.js +46 -0
  38. package/dist/build-info.json +5 -0
  39. package/dist/call-B7EveN4V.js +252 -0
  40. package/dist/call-vuUQIjOj.js +252 -0
  41. package/dist/canvas-host/a2ui/.bundle.hash +1 -0
  42. package/dist/canvas-host/a2ui/a2ui.bundle.js +17780 -0
  43. package/dist/canvas-host/a2ui/index.html +307 -0
  44. package/dist/channel-options-CJfmOkol.js +32 -0
  45. package/dist/channel-options-lFguMTz1.js +62 -0
  46. package/dist/channel-selection-BmND9mWj.js +51 -0
  47. package/dist/channel-selection-cGhL9G0c.js +51 -0
  48. package/dist/channel-summary-B4G513Eb.js +1154 -0
  49. package/dist/channel-summary-MCwBCa5y.js +1154 -0
  50. package/dist/channels-cli-C2Of1mZG.js +1411 -0
  51. package/dist/channels-cli-DFynrP1H.js +1413 -0
  52. package/dist/channels-status-issues-YohTjZ-I.js +18 -0
  53. package/dist/channels-status-issues-ZcR1U-m5.js +18 -0
  54. package/dist/chrome-B3IuUad-.js +1953 -0
  55. package/dist/chrome-BZ9K48w9.js +1973 -0
  56. package/dist/clack-prompter-B9yLhyOm.js +92 -0
  57. package/dist/clack-prompter-BybM9xdL.js +92 -0
  58. package/dist/cli/daemon-cli.js +2 -0
  59. package/dist/cli-BJZdJwug.js +89 -0
  60. package/dist/cli-BQSoKu3d.js +86 -0
  61. package/dist/cli-utils-CO4jEMn0.js +43 -0
  62. package/dist/cli-utils-gtE-0a0D.js +43 -0
  63. package/dist/client-DPqNOpK3.js +1609 -0
  64. package/dist/client-DySXIFCA.js +1609 -0
  65. package/dist/command-format-CFzL448l.js +52 -0
  66. package/dist/command-format-DELazozB.js +52 -0
  67. package/dist/command-format-ayFsmwwz.js +38 -0
  68. package/dist/command-options-CsjxK4cZ.js +33 -0
  69. package/dist/commands-BRe9VTyU.js +229 -0
  70. package/dist/completion-cli-DlkjK0iC.js +390 -0
  71. package/dist/completion-cli-E6Pt41AL.js +387 -0
  72. package/dist/config-BtSTwPcH.js +4882 -0
  73. package/dist/config-DfMIMT-f.js +4881 -0
  74. package/dist/config-_d7_WcRv.js +5623 -0
  75. package/dist/config-guard-wSnm-U8a.js +5628 -0
  76. package/dist/configure-CPHAFKlg.js +895 -0
  77. package/dist/configure-DK1XgXYx.js +894 -0
  78. package/dist/constants-CNTiY-ZN.js +65 -0
  79. package/dist/constants-hpmbslG7.js +65 -0
  80. package/dist/control-service-CqX5g_ko.js +61 -0
  81. package/dist/control-service-o6xe3hEb.js +61 -0
  82. package/dist/control-ui/apple-touch-icon.png +0 -0
  83. package/dist/control-ui/assets/index-RwcW4Xl0.css +1 -0
  84. package/dist/control-ui/assets/index-ryaCcbyp.js +4584 -0
  85. package/dist/control-ui/assets/index-ryaCcbyp.js.map +1 -0
  86. package/dist/control-ui/favicon-32.png +0 -0
  87. package/dist/control-ui/favicon.ico +0 -0
  88. package/dist/control-ui/favicon.svg +22 -0
  89. package/dist/control-ui/index.html +17 -0
  90. package/dist/cron-cli-BoSaDgvH.js +453 -0
  91. package/dist/cron-cli-qVandvsD.js +456 -0
  92. package/dist/daemon-cli-C4gGWa15.js +760 -0
  93. package/dist/daemon-cli-DV_X0Krf.js +761 -0
  94. package/dist/daemon-runtime-D5hbSrdO.js +460 -0
  95. package/dist/daemon-runtime-DXUfrXBC.js +460 -0
  96. package/dist/deliver-BxK5nI2P.js +2587 -0
  97. package/dist/deliver-Dwzg9LUd.js +2557 -0
  98. package/dist/deliver-qpYZp20m.js +2587 -0
  99. package/dist/deps-CUXtMV9d.js +27 -0
  100. package/dist/deps-WBvZpFV_.js +27 -0
  101. package/dist/devices-cli-B2s18Qrh.js +207 -0
  102. package/dist/devices-cli-D1UEtMUJ.js +204 -0
  103. package/dist/directory-cli-BXQbrkfM.js +247 -0
  104. package/dist/directory-cli-CqA7tRbq.js +244 -0
  105. package/dist/dispatcher-Dyv7T-1r.js +160 -0
  106. package/dist/dns-cli-CWxKD22D.js +198 -0
  107. package/dist/dns-cli-CzKr_Fxj.js +201 -0
  108. package/dist/docs-cli-BNyxUbWr.js +159 -0
  109. package/dist/docs-cli-DYpTbo3i.js +161 -0
  110. package/dist/doctor-C8fDYZLq.js +2583 -0
  111. package/dist/doctor-hYcqp7c0.js +2585 -0
  112. package/dist/entry.js +1326 -0
  113. package/dist/env-l7QVNj6j.js +32 -0
  114. package/dist/errors-CMCg46fK.js +1952 -0
  115. package/dist/exec-B8JKbXKW.js +246 -0
  116. package/dist/exec-BMnoMcZW.js +1099 -0
  117. package/dist/exec-HEWTMJ7j.js +246 -0
  118. package/dist/exec-approvals-DtrnHx6M.js +1026 -0
  119. package/dist/exec-approvals-Y42bE8ud.js +1026 -0
  120. package/dist/exec-approvals-cli-CIedYxP3.js +385 -0
  121. package/dist/exec-approvals-cli-xpbxnj4O.js +388 -0
  122. package/dist/extensionAPI.js +66572 -0
  123. package/dist/format-Dzy9uRLE.js +34 -0
  124. package/dist/format-sj0fELBK.js +34 -0
  125. package/dist/gateway-cli-5A-KNLEC.js +16635 -0
  126. package/dist/gateway-cli-B8kS4chb.js +16637 -0
  127. package/dist/gateway-rpc-15n38Ize.js +28 -0
  128. package/dist/gateway-rpc-TMVRgGfj.js +28 -0
  129. package/dist/github-copilot-auth-DVZj4Zgh.js +1104 -0
  130. package/dist/github-copilot-auth-DeGYyLY9.js +1104 -0
  131. package/dist/github-copilot-token-B3SA95yo.js +103 -0
  132. package/dist/github-copilot-token-C8XFYz0i.js +103 -0
  133. package/dist/github-copilot-token-CnxakiSC.js +103 -0
  134. package/dist/gmail-setup-utils-CWPC386a.js +428 -0
  135. package/dist/gmail-setup-utils-eJVB5Ewp.js +428 -0
  136. package/dist/health-format-B0tMTk3C.js +1189 -0
  137. package/dist/health-format-DaURVaUn.js +1188 -0
  138. package/dist/help-format-CEsRHU2f.js +17 -0
  139. package/dist/help-format-GuCWws6r.js +17 -0
  140. package/dist/helpers-BEJ-phFf.js +25 -0
  141. package/dist/helpers-BtbBZVKZ.js +10 -0
  142. package/dist/helpers-C12w9zxf.js +10 -0
  143. package/dist/helpers-CzjGJZmJ.js +25 -0
  144. package/dist/hooks/bundled/boot-md/HOOK.md +19 -0
  145. package/dist/hooks/bundled/command-logger/HOOK.md +122 -0
  146. package/dist/hooks/bundled/session-memory/HOOK.md +109 -0
  147. package/dist/hooks/bundled/soul-evil/HOOK.md +71 -0
  148. package/dist/hooks-cli-BZCMAnW2.js +1058 -0
  149. package/dist/hooks-cli-D0CEFg3P.js +1061 -0
  150. package/dist/hooks-status-Bn7_O8PM.js +443 -0
  151. package/dist/hooks-status-BrWVfIn0.js +443 -0
  152. package/dist/image-BS022pvv.js +1421 -0
  153. package/dist/image-BzJtY34J.js +629 -0
  154. package/dist/image-CBqmIbQQ.js +629 -0
  155. package/dist/index.js +5809 -0
  156. package/dist/installs-BP4K5L33.js +388 -0
  157. package/dist/installs-DOpTt7VZ.js +388 -0
  158. package/dist/is-main-B4o72sqg.js +25 -0
  159. package/dist/is-main-PYGa3tDA.js +25 -0
  160. package/dist/links-B4nk2iDf.js +15 -0
  161. package/dist/links-DwjRqxgR.js +15 -0
  162. package/dist/loader-Cn4EV_pf.js +63690 -0
  163. package/dist/logging-CS3tbYDj.js +15 -0
  164. package/dist/logging-CY-Q5cwf.js +1 -0
  165. package/dist/logging-DhiLkhLw.js +15 -0
  166. package/dist/logging-pqyrk15z.js +1 -0
  167. package/dist/login-qr-CD164Aw1.js +478 -0
  168. package/dist/login-qr-D7Zdgji2.js +478 -0
  169. package/dist/login-qr-YgILJ4VC.js +475 -0
  170. package/dist/logs-cli-BdS0Uv0I.js +227 -0
  171. package/dist/logs-cli-CqSN1GzB.js +230 -0
  172. package/dist/manager-CfGY5zND.js +2870 -0
  173. package/dist/manager-CjuBqFRL.js +2870 -0
  174. package/dist/manager-CoBEAQKm.js +2872 -0
  175. package/dist/manifest-registry-Bwjq9Iev.js +668 -0
  176. package/dist/manifest-registry-D2Yntqcb.js +668 -0
  177. package/dist/message-channel-Cjsiqxok.js +105 -0
  178. package/dist/message-channel-D6v_oPAg.js +105 -0
  179. package/dist/model-selection-Cv5Ox_tY.js +2956 -0
  180. package/dist/model-selection-Dr-5U5-l.js +2708 -0
  181. package/dist/models-cli-B39ckynD.js +2541 -0
  182. package/dist/models-cli-DoiYsBYw.js +2544 -0
  183. package/dist/net-CFCxaipF.js +137 -0
  184. package/dist/net-DKJPqXuW.js +137 -0
  185. package/dist/node-cli-C_FYF-RA.js +1456 -0
  186. package/dist/node-cli-DWPoNsQS.js +1459 -0
  187. package/dist/node-service-DcJREOww.js +67 -0
  188. package/dist/node-service-DuZ9Us9h.js +67 -0
  189. package/dist/nodes-cli-Elo6tlen.js +1210 -0
  190. package/dist/nodes-cli-zqryRUWB.js +1207 -0
  191. package/dist/nodes-screen-C4aCrxie.js +157 -0
  192. package/dist/nodes-screen-D4PSynkR.js +157 -0
  193. package/dist/note-CQhSvgQv.js +73 -0
  194. package/dist/note-_C44YfAQ.js +73 -0
  195. package/dist/onboard-channels-CHBDi-ZA.js +670 -0
  196. package/dist/onboard-channels-DOEKyxaL.js +670 -0
  197. package/dist/onboard-skills-BUTXREDZ.js +3327 -0
  198. package/dist/onboard-skills-CSLYZmZA.js +3327 -0
  199. package/dist/onboarding-CgKb8b39.js +3232 -0
  200. package/dist/openclaw-root-9ILYSmJ9.js +84 -0
  201. package/dist/openclaw-root-Cvotktkd.js +84 -0
  202. package/dist/pairing-cli-B4UGR2at.js +114 -0
  203. package/dist/pairing-cli-BWDDl8cf.js +117 -0
  204. package/dist/pairing-labels-ClZ-fTWT.js +9 -0
  205. package/dist/pairing-labels-Ds7BPOkj.js +9 -0
  206. package/dist/pairing-store-DDLNuzmx.js +391 -0
  207. package/dist/pairing-store-DRn08lZD.js +391 -0
  208. package/dist/parse-87ybtYW1.js +23 -0
  209. package/dist/parse-OCFfznr3.js +23 -0
  210. package/dist/parse-log-line-C9aL5PUL.js +44 -0
  211. package/dist/parse-log-line-DxRaGzQb.js +44 -0
  212. package/dist/parse-timeout-CFqNj7No.js +16 -0
  213. package/dist/parse-timeout-DV8NQQWk.js +16 -0
  214. package/dist/path-env-C7kiJUgG.js +77 -0
  215. package/dist/path-env-DEj4CiFN.js +77 -0
  216. package/dist/paths-B-q1nXdY.js +43 -0
  217. package/dist/paths-B1kfl4h5.js +164 -0
  218. package/dist/paths-B4kigINg.js +40 -0
  219. package/dist/paths-CHGbP1-A.js +43 -0
  220. package/dist/paths-scjhy7N2.js +180 -0
  221. package/dist/pi-embedded-helpers-C19wUpMB.js +8451 -0
  222. package/dist/pi-embedded-helpers-CT5VuLCb.js +1293 -0
  223. package/dist/pi-embedded-helpers-Dl8e5Rf8.js +1293 -0
  224. package/dist/pi-model-discovery-B6CsmK6Y.js +20 -0
  225. package/dist/pi-model-discovery-DsRqYJLy.js +20 -0
  226. package/dist/pi-model-discovery-EhM2JAQo.js +20 -0
  227. package/dist/pi-tools.policy-BvkSDFDN.js +229 -0
  228. package/dist/plugin-auto-enable-Bd_StZzz.js +461 -0
  229. package/dist/plugin-auto-enable-DBhXb_0x.js +461 -0
  230. package/dist/plugin-sdk/agent-scope-DdwUKIOe.js +606 -0
  231. package/dist/plugin-sdk/chrome-G8apFa5p.js +1953 -0
  232. package/dist/plugin-sdk/command-format-qUVxzqYm.js +52 -0
  233. package/dist/plugin-sdk/config-Cm1M7tgH.js +5623 -0
  234. package/dist/plugin-sdk/deliver-Cl8uowiO.js +2557 -0
  235. package/dist/plugin-sdk/exec-Cm9b2r9Q.js +1107 -0
  236. package/dist/plugin-sdk/github-copilot-token-BHNcM4_B.js +103 -0
  237. package/dist/plugin-sdk/image-7PgoS2VD.js +1421 -0
  238. package/dist/plugin-sdk/index.d.ts +8908 -0
  239. package/dist/plugin-sdk/index.js +70888 -0
  240. package/dist/plugin-sdk/login-qr-qTALvWi2.js +475 -0
  241. package/dist/plugin-sdk/manager-Cs3EQZCb.js +2870 -0
  242. package/dist/plugin-sdk/model-selection-BgC1E1a7.js +2708 -0
  243. package/dist/plugin-sdk/paths-BYpoyRv5.js +164 -0
  244. package/dist/plugin-sdk/paths-DNQE-bvr.js +40 -0
  245. package/dist/plugin-sdk/pi-embedded-helpers-5jNqW_dE.js +8755 -0
  246. package/dist/plugin-sdk/pi-model-discovery-BUGEht9A.js +20 -0
  247. package/dist/plugin-sdk/pw-ai-COTtei4a.js +1649 -0
  248. package/dist/plugin-sdk/qmd-manager-ClSwiAJl.js +615 -0
  249. package/dist/plugin-sdk/redact-2AzjOfk2.js +94 -0
  250. package/dist/plugin-sdk/rolldown-runtime-Cbj13DAv.js +20 -0
  251. package/dist/plugin-sdk/sqlite-gCW7MlLs.js +215 -0
  252. package/dist/plugin-sdk/transcript-events-DGF257vD.js +17 -0
  253. package/dist/plugins-C3Bm-HQV.js +494 -0
  254. package/dist/plugins-QJjTXliB.js +495 -0
  255. package/dist/plugins-cli-DTci0JQb.js +443 -0
  256. package/dist/plugins-cli-wJsN1HHK.js +440 -0
  257. package/dist/ports-CiW9dmMq.js +96 -0
  258. package/dist/program-BWpTHh1I.js +188 -0
  259. package/dist/progress-Bcjniu7m.js +133 -0
  260. package/dist/progress-CvaSPjS9.js +133 -0
  261. package/dist/prompt-style-CFsleyxV.js +9 -0
  262. package/dist/prompt-style-DYJdrXyV.js +9 -0
  263. package/dist/prompts-Bt9fwsg2.js +10 -0
  264. package/dist/prompts-CudpZgTI.js +10 -0
  265. package/dist/pw-ai-08F3GD-3.js +1649 -0
  266. package/dist/pw-ai-ZmHxHQnx.js +1651 -0
  267. package/dist/pw-ai-tNPuRNn3.js +1649 -0
  268. package/dist/qmd-manager-2r-4n3sP.js +617 -0
  269. package/dist/qmd-manager-CF52nuBg.js +615 -0
  270. package/dist/qmd-manager-HEm5H2mk.js +616 -0
  271. package/dist/redact-BICFkpn7.js +97 -0
  272. package/dist/redact-BIMJ3ntQ.js +94 -0
  273. package/dist/redact-KzWHRS5J.js +97 -0
  274. package/dist/register.subclis-D2K25c84.js +348 -0
  275. package/dist/register.subclis-Dd8LbOLi.js +342 -0
  276. package/dist/reply-5UNWRwMn.js +63693 -0
  277. package/dist/restart-sentinel-Cr0vUxB8.js +65 -0
  278. package/dist/restart-sentinel-DUemCjgU.js +65 -0
  279. package/dist/rolldown-runtime-Cbj13DAv.js +20 -0
  280. package/dist/routes-C6UpTPas.js +2410 -0
  281. package/dist/routes-ClNyEvlm.js +2410 -0
  282. package/dist/rpc-D0mf7DIw.js +95 -0
  283. package/dist/rpc-DYdOrgd9.js +95 -0
  284. package/dist/run-main-CojI7gWx.js +194 -0
  285. package/dist/runtime-guard-68M_evhb.js +60 -0
  286. package/dist/runtime-guard-DkjmhnBD.js +60 -0
  287. package/dist/sandbox-Ca81z3Tw.js +2924 -0
  288. package/dist/sandbox-cli-D75GApgp.js +459 -0
  289. package/dist/sandbox-cli-E4SJsC1C.js +462 -0
  290. package/dist/sandbox-knontqD9.js +2925 -0
  291. package/dist/security-cli-BLihvXO-.js +503 -0
  292. package/dist/security-cli-IGQCsK4g.js +506 -0
  293. package/dist/server-context-B9GX5GOI.js +740 -0
  294. package/dist/server-context-BFH7HB_M.js +740 -0
  295. package/dist/server-node-events-CTdHBiEA.js +218 -0
  296. package/dist/server-node-events-DAV14qPr.js +215 -0
  297. package/dist/service-BZNBq9hq.js +680 -0
  298. package/dist/service-C-BLXx9U.js +680 -0
  299. package/dist/service-audit-BfJv4NqZ.js +542 -0
  300. package/dist/service-audit-Bw3M2OEI.js +542 -0
  301. package/dist/shared-5SH-45AX.js +74 -0
  302. package/dist/shared-BxRm5uLU.js +74 -0
  303. package/dist/shared-C80Rmxsd.js +150 -0
  304. package/dist/shared-fGK6_D2v.js +150 -0
  305. package/dist/skills-Bhp0l6UK.js +693 -0
  306. package/dist/skills-Tky2kCMO.js +694 -0
  307. package/dist/skills-cli-6rCClAE4.js +287 -0
  308. package/dist/skills-cli-C4nLCrLw.js +290 -0
  309. package/dist/skills-status-CENcKr3I.js +187 -0
  310. package/dist/skills-status-DX1eUYvk.js +187 -0
  311. package/dist/sqlite-CmdZSZRx.js +197 -0
  312. package/dist/sqlite-Dnmf3LS7.js +215 -0
  313. package/dist/sqlite-QDf0yuU0.js +215 -0
  314. package/dist/status-BSfGAp2D.js +27 -0
  315. package/dist/status-Bp_2NMjt.js +27 -0
  316. package/dist/status-C0ANDr0T.js +3140 -0
  317. package/dist/status-CCHBIZnm.js +21 -0
  318. package/dist/status-Vuqbw2Bb.js +21 -0
  319. package/dist/status.update-BZW5r8Su.js +79 -0
  320. package/dist/status.update-BnD93_O8.js +79 -0
  321. package/dist/subsystem-CAq3uyo7.js +834 -0
  322. package/dist/system-cli-Bb9zmCO1.js +83 -0
  323. package/dist/system-cli-TIIQ04ls.js +80 -0
  324. package/dist/systemd-0Qa_nGqe.js +438 -0
  325. package/dist/systemd-Czb0Xsm7.js +438 -0
  326. package/dist/systemd-hints-CWoEOQRb.js +19 -0
  327. package/dist/systemd-hints-Cv3RN_mZ.js +19 -0
  328. package/dist/systemd-linger-CsdvcIoS.js +75 -0
  329. package/dist/systemd-linger-DKUFHcLn.js +75 -0
  330. package/dist/table-DNPESyNj.js +279 -0
  331. package/dist/table-DS4-gmkV.js +279 -0
  332. package/dist/tailnet-Bg_vE5qi.js +42 -0
  333. package/dist/tailnet-CrNWlQRJ.js +42 -0
  334. package/dist/tailscale-CBv58toW.js +252 -0
  335. package/dist/tailscale-DCnMs7_q.js +225 -0
  336. package/dist/tool-display-BEACy9rK.js +795 -0
  337. package/dist/tool-display-NYQnSpdo.js +795 -0
  338. package/dist/transcript-events-CsB1Saa6.js +17 -0
  339. package/dist/transcript-events-DDYvbmRV.js +17 -0
  340. package/dist/transcript-events-JLH5W4He.js +17 -0
  341. package/dist/tui--NY0rnjr.js +2542 -0
  342. package/dist/tui-DqJfGtvM.js +2543 -0
  343. package/dist/tui-cli-BuHNY6wF.js +54 -0
  344. package/dist/tui-cli-LMFV982e.js +57 -0
  345. package/dist/update-CRpHtCgz.js +317 -0
  346. package/dist/update-D3qruxhj.js +317 -0
  347. package/dist/update-cli-CFF-pslM.js +948 -0
  348. package/dist/update-cli-cn9pEMX7.js +951 -0
  349. package/dist/update-runner-CxGU142L.js +1221 -0
  350. package/dist/update-runner-DNobz_ft.js +1221 -0
  351. package/dist/utils-CKSrBNwq.js +192 -0
  352. package/dist/utils-DX85MiPR.js +188 -0
  353. package/dist/webhooks-cli-BGtt2HAR.js +312 -0
  354. package/dist/webhooks-cli-DHLZrEO_.js +309 -0
  355. package/dist/widearea-dns-BpG7ATO8.js +127 -0
  356. package/dist/widearea-dns-D4wkCJly.js +127 -0
  357. package/dist/ws-3zr8WUwL.js +13 -0
  358. package/dist/ws-log-BXcT2xQk.js +267 -0
  359. package/dist/ws-log-DbDIUsgz.js +267 -0
  360. package/dist/ws-lzrgabja.js +13 -0
  361. package/dist/wsl-D2O2qOrl.js +160 -0
  362. package/docs/.i18n/README.md +31 -0
  363. package/docs/.i18n/glossary.zh-CN.json +190 -0
  364. package/docs/.i18n/zh-CN.tm.jsonl +1329 -0
  365. package/docs/CNAME +1 -0
  366. package/docs/_config.yml +53 -0
  367. package/docs/_layouts/default.html +145 -0
  368. package/docs/assets/markdown.css +179 -0
  369. package/docs/assets/openclaw-logo-text-dark.png +0 -0
  370. package/docs/assets/openclaw-logo-text.png +0 -0
  371. package/docs/assets/pixel-lobster.svg +60 -0
  372. package/docs/assets/showcase/agents-ui.jpg +0 -0
  373. package/docs/assets/showcase/bambu-cli.png +0 -0
  374. package/docs/assets/showcase/codexmonitor.png +0 -0
  375. package/docs/assets/showcase/gohome-grafana.png +0 -0
  376. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  377. package/docs/assets/showcase/oura-health.png +0 -0
  378. package/docs/assets/showcase/padel-cli.svg +11 -0
  379. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  380. package/docs/assets/showcase/papla-tts.jpg +0 -0
  381. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  382. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  383. package/docs/assets/showcase/roborock-status.svg +13 -0
  384. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  385. package/docs/assets/showcase/snag.png +0 -0
  386. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  387. package/docs/assets/showcase/wienerlinien.png +0 -0
  388. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  389. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  390. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  391. package/docs/assets/terminal.css +473 -0
  392. package/docs/assets/theme.js +55 -0
  393. package/docs/automation/auth-monitoring.md +44 -0
  394. package/docs/automation/cron-jobs.md +468 -0
  395. package/docs/automation/cron-vs-heartbeat.md +282 -0
  396. package/docs/automation/gmail-pubsub.md +256 -0
  397. package/docs/automation/poll.md +69 -0
  398. package/docs/automation/webhook.md +163 -0
  399. package/docs/bedrock.md +176 -0
  400. package/docs/brave-search.md +41 -0
  401. package/docs/broadcast-groups.md +442 -0
  402. package/docs/channels/bluebubbles.md +338 -0
  403. package/docs/channels/discord.md +475 -0
  404. package/docs/channels/feishu.md +507 -0
  405. package/docs/channels/googlechat.md +250 -0
  406. package/docs/channels/grammy.md +31 -0
  407. package/docs/channels/imessage.md +299 -0
  408. package/docs/channels/index.md +46 -0
  409. package/docs/channels/line.md +186 -0
  410. package/docs/channels/location.md +56 -0
  411. package/docs/channels/matrix.md +233 -0
  412. package/docs/channels/mattermost.md +138 -0
  413. package/docs/channels/msteams.md +768 -0
  414. package/docs/channels/nextcloud-talk.md +136 -0
  415. package/docs/channels/nostr.md +233 -0
  416. package/docs/channels/signal.md +202 -0
  417. package/docs/channels/slack.md +548 -0
  418. package/docs/channels/telegram.md +750 -0
  419. package/docs/channels/tlon.md +132 -0
  420. package/docs/channels/troubleshooting.md +29 -0
  421. package/docs/channels/twitch.md +379 -0
  422. package/docs/channels/whatsapp.md +404 -0
  423. package/docs/channels/zalo.md +189 -0
  424. package/docs/channels/zalouser.md +140 -0
  425. package/docs/cli/acp.md +170 -0
  426. package/docs/cli/agent.md +24 -0
  427. package/docs/cli/agents.md +75 -0
  428. package/docs/cli/approvals.md +50 -0
  429. package/docs/cli/browser.md +107 -0
  430. package/docs/cli/channels.md +79 -0
  431. package/docs/cli/config.md +50 -0
  432. package/docs/cli/configure.md +33 -0
  433. package/docs/cli/cron.md +42 -0
  434. package/docs/cli/dashboard.md +16 -0
  435. package/docs/cli/devices.md +67 -0
  436. package/docs/cli/directory.md +63 -0
  437. package/docs/cli/dns.md +23 -0
  438. package/docs/cli/docs.md +15 -0
  439. package/docs/cli/doctor.md +41 -0
  440. package/docs/cli/gateway.md +199 -0
  441. package/docs/cli/health.md +21 -0
  442. package/docs/cli/hooks.md +304 -0
  443. package/docs/cli/index.md +1029 -0
  444. package/docs/cli/logs.md +24 -0
  445. package/docs/cli/memory.md +45 -0
  446. package/docs/cli/message.md +239 -0
  447. package/docs/cli/models.md +79 -0
  448. package/docs/cli/node.md +112 -0
  449. package/docs/cli/nodes.md +73 -0
  450. package/docs/cli/onboard.md +29 -0
  451. package/docs/cli/pairing.md +21 -0
  452. package/docs/cli/plugins.md +62 -0
  453. package/docs/cli/reset.md +17 -0
  454. package/docs/cli/sandbox.md +152 -0
  455. package/docs/cli/security.md +26 -0
  456. package/docs/cli/sessions.md +16 -0
  457. package/docs/cli/setup.md +29 -0
  458. package/docs/cli/skills.md +26 -0
  459. package/docs/cli/status.md +26 -0
  460. package/docs/cli/system.md +60 -0
  461. package/docs/cli/tui.md +23 -0
  462. package/docs/cli/uninstall.md +17 -0
  463. package/docs/cli/update.md +98 -0
  464. package/docs/cli/voicecall.md +34 -0
  465. package/docs/cli/webhooks.md +25 -0
  466. package/docs/concepts/agent-loop.md +146 -0
  467. package/docs/concepts/agent-workspace.md +233 -0
  468. package/docs/concepts/agent.md +123 -0
  469. package/docs/concepts/architecture.md +129 -0
  470. package/docs/concepts/channel-routing.md +114 -0
  471. package/docs/concepts/compaction.md +61 -0
  472. package/docs/concepts/context.md +161 -0
  473. package/docs/concepts/group-messages.md +84 -0
  474. package/docs/concepts/groups.md +373 -0
  475. package/docs/concepts/markdown-formatting.md +130 -0
  476. package/docs/concepts/memory.md +546 -0
  477. package/docs/concepts/messages.md +154 -0
  478. package/docs/concepts/model-failover.md +149 -0
  479. package/docs/concepts/model-providers.md +316 -0
  480. package/docs/concepts/models.md +208 -0
  481. package/docs/concepts/multi-agent.md +376 -0
  482. package/docs/concepts/oauth.md +145 -0
  483. package/docs/concepts/presence.md +102 -0
  484. package/docs/concepts/queue.md +89 -0
  485. package/docs/concepts/retry.md +69 -0
  486. package/docs/concepts/session-pruning.md +122 -0
  487. package/docs/concepts/session-tool.md +193 -0
  488. package/docs/concepts/session.md +188 -0
  489. package/docs/concepts/sessions.md +10 -0
  490. package/docs/concepts/streaming.md +135 -0
  491. package/docs/concepts/system-prompt.md +115 -0
  492. package/docs/concepts/timezone.md +91 -0
  493. package/docs/concepts/typebox.md +289 -0
  494. package/docs/concepts/typing-indicators.md +68 -0
  495. package/docs/concepts/usage-tracking.md +35 -0
  496. package/docs/date-time.md +128 -0
  497. package/docs/debug/node-issue.md +83 -0
  498. package/docs/debugging.md +162 -0
  499. package/docs/diagnostics/flags.md +91 -0
  500. package/docs/docs.json +1587 -0
  501. package/docs/environment.md +81 -0
  502. package/docs/experiments/onboarding-config-protocol.md +40 -0
  503. package/docs/experiments/plans/cron-add-hardening.md +63 -0
  504. package/docs/experiments/plans/group-policy-hardening.md +40 -0
  505. package/docs/experiments/plans/openresponses-gateway.md +123 -0
  506. package/docs/experiments/proposals/model-config.md +36 -0
  507. package/docs/experiments/research/memory.md +228 -0
  508. package/docs/gateway/authentication.md +145 -0
  509. package/docs/gateway/background-process.md +93 -0
  510. package/docs/gateway/bonjour.md +167 -0
  511. package/docs/gateway/bridge-protocol.md +89 -0
  512. package/docs/gateway/cli-backends.md +223 -0
  513. package/docs/gateway/configuration-examples.md +606 -0
  514. package/docs/gateway/configuration.md +3393 -0
  515. package/docs/gateway/discovery.md +116 -0
  516. package/docs/gateway/doctor.md +282 -0
  517. package/docs/gateway/gateway-lock.md +34 -0
  518. package/docs/gateway/health.md +35 -0
  519. package/docs/gateway/heartbeat.md +302 -0
  520. package/docs/gateway/index.md +328 -0
  521. package/docs/gateway/local-models.md +150 -0
  522. package/docs/gateway/logging.md +113 -0
  523. package/docs/gateway/multiple-gateways.md +112 -0
  524. package/docs/gateway/openai-http-api.md +118 -0
  525. package/docs/gateway/openresponses-http-api.md +317 -0
  526. package/docs/gateway/pairing.md +99 -0
  527. package/docs/gateway/protocol.md +221 -0
  528. package/docs/gateway/remote-gateway-readme.md +157 -0
  529. package/docs/gateway/remote.md +127 -0
  530. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +128 -0
  531. package/docs/gateway/sandboxing.md +193 -0
  532. package/docs/gateway/security/formal-verification.md +164 -0
  533. package/docs/gateway/security/index.md +825 -0
  534. package/docs/gateway/tailscale.md +127 -0
  535. package/docs/gateway/tools-invoke-http-api.md +85 -0
  536. package/docs/gateway/troubleshooting.md +767 -0
  537. package/docs/help/faq.md +2830 -0
  538. package/docs/help/index.md +21 -0
  539. package/docs/help/troubleshooting.md +98 -0
  540. package/docs/hooks/soul-evil.md +69 -0
  541. package/docs/hooks.md +913 -0
  542. package/docs/images/feishu-step2-create-app.png +0 -0
  543. package/docs/images/feishu-step3-credentials.png +0 -0
  544. package/docs/images/feishu-step4-permissions.png +0 -0
  545. package/docs/images/feishu-step5-bot-capability.png +0 -0
  546. package/docs/images/feishu-step6-event-subscription.png +0 -0
  547. package/docs/images/groups-flow.svg +52 -0
  548. package/docs/images/mobile-ui-screenshot.png +0 -0
  549. package/docs/index.md +258 -0
  550. package/docs/install/ansible.md +208 -0
  551. package/docs/install/bun.md +59 -0
  552. package/docs/install/development-channels.md +75 -0
  553. package/docs/install/docker.md +567 -0
  554. package/docs/install/index.md +185 -0
  555. package/docs/install/installer.md +123 -0
  556. package/docs/install/migrating.md +192 -0
  557. package/docs/install/nix.md +96 -0
  558. package/docs/install/node.md +78 -0
  559. package/docs/install/uninstall.md +128 -0
  560. package/docs/install/updating.md +228 -0
  561. package/docs/logging.md +350 -0
  562. package/docs/multi-agent-sandbox-tools.md +395 -0
  563. package/docs/network.md +54 -0
  564. package/docs/nodes/audio.md +114 -0
  565. package/docs/nodes/camera.md +156 -0
  566. package/docs/nodes/images.md +72 -0
  567. package/docs/nodes/index.md +341 -0
  568. package/docs/nodes/location-command.md +113 -0
  569. package/docs/nodes/media-understanding.md +379 -0
  570. package/docs/nodes/talk.md +90 -0
  571. package/docs/nodes/voicewake.md +65 -0
  572. package/docs/northflank.mdx +53 -0
  573. package/docs/perplexity.md +80 -0
  574. package/docs/pi-dev.md +70 -0
  575. package/docs/pi.md +612 -0
  576. package/docs/platforms/android.md +148 -0
  577. package/docs/platforms/digitalocean.md +262 -0
  578. package/docs/platforms/exe-dev.md +125 -0
  579. package/docs/platforms/fly.md +486 -0
  580. package/docs/platforms/gcp.md +503 -0
  581. package/docs/platforms/hetzner.md +330 -0
  582. package/docs/platforms/index.md +53 -0
  583. package/docs/platforms/ios.md +107 -0
  584. package/docs/platforms/linux.md +94 -0
  585. package/docs/platforms/mac/bundled-gateway.md +73 -0
  586. package/docs/platforms/mac/canvas.md +125 -0
  587. package/docs/platforms/mac/child-process.md +69 -0
  588. package/docs/platforms/mac/dev-setup.md +102 -0
  589. package/docs/platforms/mac/health.md +34 -0
  590. package/docs/platforms/mac/icon.md +31 -0
  591. package/docs/platforms/mac/logging.md +57 -0
  592. package/docs/platforms/mac/menu-bar.md +81 -0
  593. package/docs/platforms/mac/peekaboo.md +65 -0
  594. package/docs/platforms/mac/permissions.md +44 -0
  595. package/docs/platforms/mac/release.md +85 -0
  596. package/docs/platforms/mac/remote.md +83 -0
  597. package/docs/platforms/mac/signing.md +47 -0
  598. package/docs/platforms/mac/skills.md +33 -0
  599. package/docs/platforms/mac/voice-overlay.md +60 -0
  600. package/docs/platforms/mac/voicewake.md +67 -0
  601. package/docs/platforms/mac/webchat.md +41 -0
  602. package/docs/platforms/mac/xpc.md +61 -0
  603. package/docs/platforms/macos-vm.md +281 -0
  604. package/docs/platforms/macos.md +203 -0
  605. package/docs/platforms/oracle.md +303 -0
  606. package/docs/platforms/raspberry-pi.md +358 -0
  607. package/docs/platforms/windows.md +159 -0
  608. package/docs/plugin.md +664 -0
  609. package/docs/plugins/agent-tools.md +99 -0
  610. package/docs/plugins/manifest.md +71 -0
  611. package/docs/plugins/voice-call.md +284 -0
  612. package/docs/plugins/zalouser.md +81 -0
  613. package/docs/prose.md +134 -0
  614. package/docs/providers/anthropic.md +152 -0
  615. package/docs/providers/claude-max-api-proxy.md +148 -0
  616. package/docs/providers/cloudflare-ai-gateway.md +71 -0
  617. package/docs/providers/deepgram.md +93 -0
  618. package/docs/providers/github-copilot.md +72 -0
  619. package/docs/providers/glm.md +33 -0
  620. package/docs/providers/index.md +63 -0
  621. package/docs/providers/minimax.md +208 -0
  622. package/docs/providers/models.md +51 -0
  623. package/docs/providers/moonshot.md +142 -0
  624. package/docs/providers/ollama.md +223 -0
  625. package/docs/providers/openai.md +62 -0
  626. package/docs/providers/opencode.md +36 -0
  627. package/docs/providers/openrouter.md +37 -0
  628. package/docs/providers/qwen.md +53 -0
  629. package/docs/providers/synthetic.md +99 -0
  630. package/docs/providers/venice.md +267 -0
  631. package/docs/providers/vercel-ai-gateway.md +50 -0
  632. package/docs/providers/xiaomi.md +64 -0
  633. package/docs/providers/zai.md +36 -0
  634. package/docs/railway.mdx +99 -0
  635. package/docs/refactor/clawnet.md +417 -0
  636. package/docs/refactor/exec-host.md +316 -0
  637. package/docs/refactor/outbound-session-mirroring.md +85 -0
  638. package/docs/refactor/plugin-sdk.md +214 -0
  639. package/docs/refactor/strict-config.md +93 -0
  640. package/docs/reference/AGENTS.default.md +124 -0
  641. package/docs/reference/RELEASING.md +120 -0
  642. package/docs/reference/api-usage-costs.md +137 -0
  643. package/docs/reference/device-models.md +47 -0
  644. package/docs/reference/rpc.md +43 -0
  645. package/docs/reference/session-management-compaction.md +285 -0
  646. package/docs/reference/templates/AGENTS.dev.md +83 -0
  647. package/docs/reference/templates/AGENTS.md +218 -0
  648. package/docs/reference/templates/BOOT.md +10 -0
  649. package/docs/reference/templates/BOOTSTRAP.md +61 -0
  650. package/docs/reference/templates/HEARTBEAT.md +11 -0
  651. package/docs/reference/templates/IDENTITY.dev.md +47 -0
  652. package/docs/reference/templates/IDENTITY.md +27 -0
  653. package/docs/reference/templates/SOUL.dev.md +76 -0
  654. package/docs/reference/templates/SOUL.md +42 -0
  655. package/docs/reference/templates/TOOLS.dev.md +24 -0
  656. package/docs/reference/templates/TOOLS.md +46 -0
  657. package/docs/reference/templates/USER.dev.md +18 -0
  658. package/docs/reference/templates/USER.md +22 -0
  659. package/docs/reference/test.md +50 -0
  660. package/docs/reference/transcript-hygiene.md +129 -0
  661. package/docs/render.mdx +165 -0
  662. package/docs/scripts.md +28 -0
  663. package/docs/security/formal-verification.md +164 -0
  664. package/docs/start/getting-started.md +208 -0
  665. package/docs/start/hubs.md +185 -0
  666. package/docs/start/lore.md +219 -0
  667. package/docs/start/onboarding.md +110 -0
  668. package/docs/start/openclaw.md +241 -0
  669. package/docs/start/pairing.md +86 -0
  670. package/docs/start/setup.md +149 -0
  671. package/docs/start/showcase.md +416 -0
  672. package/docs/start/wizard.md +349 -0
  673. package/docs/testing.md +368 -0
  674. package/docs/token-use.md +112 -0
  675. package/docs/tools/agent-send.md +53 -0
  676. package/docs/tools/apply-patch.md +50 -0
  677. package/docs/tools/browser-linux-troubleshooting.md +139 -0
  678. package/docs/tools/browser-login.md +68 -0
  679. package/docs/tools/browser.md +576 -0
  680. package/docs/tools/chrome-extension.md +178 -0
  681. package/docs/tools/clawhub.md +257 -0
  682. package/docs/tools/creating-skills.md +54 -0
  683. package/docs/tools/elevated.md +57 -0
  684. package/docs/tools/exec-approvals.md +246 -0
  685. package/docs/tools/exec.md +179 -0
  686. package/docs/tools/firecrawl.md +61 -0
  687. package/docs/tools/index.md +509 -0
  688. package/docs/tools/llm-task.md +115 -0
  689. package/docs/tools/lobster.md +342 -0
  690. package/docs/tools/reactions.md +22 -0
  691. package/docs/tools/skills-config.md +76 -0
  692. package/docs/tools/skills.md +300 -0
  693. package/docs/tools/slash-commands.md +198 -0
  694. package/docs/tools/subagents.md +151 -0
  695. package/docs/tools/thinking.md +73 -0
  696. package/docs/tools/web.md +261 -0
  697. package/docs/tts.md +396 -0
  698. package/docs/tui.md +159 -0
  699. package/docs/vps.md +43 -0
  700. package/docs/web/control-ui.md +221 -0
  701. package/docs/web/dashboard.md +46 -0
  702. package/docs/web/index.md +116 -0
  703. package/docs/web/webchat.md +49 -0
  704. package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
  705. package/docs/whatsapp-openclaw.jpg +0 -0
  706. package/docs/zh-CN/AGENTS.md +59 -0
  707. package/docs/zh-CN/automation/auth-monitoring.md +47 -0
  708. package/docs/zh-CN/automation/cron-jobs.md +424 -0
  709. package/docs/zh-CN/automation/cron-vs-heartbeat.md +286 -0
  710. package/docs/zh-CN/automation/gmail-pubsub.md +249 -0
  711. package/docs/zh-CN/automation/poll.md +76 -0
  712. package/docs/zh-CN/automation/webhook.md +163 -0
  713. package/docs/zh-CN/bedrock.md +170 -0
  714. package/docs/zh-CN/brave-search.md +48 -0
  715. package/docs/zh-CN/broadcast-groups.md +449 -0
  716. package/docs/zh-CN/channels/bluebubbles.md +271 -0
  717. package/docs/zh-CN/channels/discord.md +468 -0
  718. package/docs/zh-CN/channels/feishu.md +513 -0
  719. package/docs/zh-CN/channels/googlechat.md +257 -0
  720. package/docs/zh-CN/channels/grammy.md +38 -0
  721. package/docs/zh-CN/channels/imessage.md +302 -0
  722. package/docs/zh-CN/channels/index.md +53 -0
  723. package/docs/zh-CN/channels/line.md +180 -0
  724. package/docs/zh-CN/channels/location.md +63 -0
  725. package/docs/zh-CN/channels/matrix.md +221 -0
  726. package/docs/zh-CN/channels/mattermost.md +144 -0
  727. package/docs/zh-CN/channels/msteams.md +775 -0
  728. package/docs/zh-CN/channels/nextcloud-talk.md +142 -0
  729. package/docs/zh-CN/channels/nostr.md +240 -0
  730. package/docs/zh-CN/channels/signal.md +209 -0
  731. package/docs/zh-CN/channels/slack.md +531 -0
  732. package/docs/zh-CN/channels/telegram.md +751 -0
  733. package/docs/zh-CN/channels/tlon.md +136 -0
  734. package/docs/zh-CN/channels/troubleshooting.md +36 -0
  735. package/docs/zh-CN/channels/twitch.md +385 -0
  736. package/docs/zh-CN/channels/whatsapp.md +411 -0
  737. package/docs/zh-CN/channels/zalo.md +196 -0
  738. package/docs/zh-CN/channels/zalouser.md +147 -0
  739. package/docs/zh-CN/cli/acp.md +173 -0
  740. package/docs/zh-CN/cli/agent.md +30 -0
  741. package/docs/zh-CN/cli/agents.md +82 -0
  742. package/docs/zh-CN/cli/approvals.md +57 -0
  743. package/docs/zh-CN/cli/browser.md +114 -0
  744. package/docs/zh-CN/cli/channels.md +86 -0
  745. package/docs/zh-CN/cli/config.md +57 -0
  746. package/docs/zh-CN/cli/configure.md +38 -0
  747. package/docs/zh-CN/cli/cron.md +43 -0
  748. package/docs/zh-CN/cli/dashboard.md +23 -0
  749. package/docs/zh-CN/cli/devices.md +74 -0
  750. package/docs/zh-CN/cli/directory.md +70 -0
  751. package/docs/zh-CN/cli/dns.md +30 -0
  752. package/docs/zh-CN/cli/docs.md +22 -0
  753. package/docs/zh-CN/cli/doctor.md +48 -0
  754. package/docs/zh-CN/cli/gateway.md +206 -0
  755. package/docs/zh-CN/cli/health.md +28 -0
  756. package/docs/zh-CN/cli/hooks.md +311 -0
  757. package/docs/zh-CN/cli/index.md +1032 -0
  758. package/docs/zh-CN/cli/logs.md +31 -0
  759. package/docs/zh-CN/cli/memory.md +52 -0
  760. package/docs/zh-CN/cli/message.md +246 -0
  761. package/docs/zh-CN/cli/models.md +85 -0
  762. package/docs/zh-CN/cli/node.md +115 -0
  763. package/docs/zh-CN/cli/nodes.md +80 -0
  764. package/docs/zh-CN/cli/onboard.md +36 -0
  765. package/docs/zh-CN/cli/pairing.md +28 -0
  766. package/docs/zh-CN/cli/plugins.md +66 -0
  767. package/docs/zh-CN/cli/reset.md +24 -0
  768. package/docs/zh-CN/cli/sandbox.md +158 -0
  769. package/docs/zh-CN/cli/security.md +33 -0
  770. package/docs/zh-CN/cli/sessions.md +23 -0
  771. package/docs/zh-CN/cli/setup.md +36 -0
  772. package/docs/zh-CN/cli/skills.md +33 -0
  773. package/docs/zh-CN/cli/status.md +33 -0
  774. package/docs/zh-CN/cli/system.md +63 -0
  775. package/docs/zh-CN/cli/tui.md +30 -0
  776. package/docs/zh-CN/cli/uninstall.md +24 -0
  777. package/docs/zh-CN/cli/update.md +101 -0
  778. package/docs/zh-CN/cli/voicecall.md +41 -0
  779. package/docs/zh-CN/cli/webhooks.md +32 -0
  780. package/docs/zh-CN/concepts/agent-loop.md +146 -0
  781. package/docs/zh-CN/concepts/agent-workspace.md +219 -0
  782. package/docs/zh-CN/concepts/agent.md +115 -0
  783. package/docs/zh-CN/concepts/architecture.md +123 -0
  784. package/docs/zh-CN/concepts/channel-routing.md +117 -0
  785. package/docs/zh-CN/concepts/compaction.md +67 -0
  786. package/docs/zh-CN/concepts/context.md +168 -0
  787. package/docs/zh-CN/concepts/group-messages.md +91 -0
  788. package/docs/zh-CN/concepts/groups.md +379 -0
  789. package/docs/zh-CN/concepts/markdown-formatting.md +117 -0
  790. package/docs/zh-CN/concepts/memory.md +412 -0
  791. package/docs/zh-CN/concepts/messages.md +141 -0
  792. package/docs/zh-CN/concepts/model-failover.md +145 -0
  793. package/docs/zh-CN/concepts/model-providers.md +320 -0
  794. package/docs/zh-CN/concepts/models.md +196 -0
  795. package/docs/zh-CN/concepts/multi-agent.md +372 -0
  796. package/docs/zh-CN/concepts/oauth.md +151 -0
  797. package/docs/zh-CN/concepts/presence.md +99 -0
  798. package/docs/zh-CN/concepts/queue.md +94 -0
  799. package/docs/zh-CN/concepts/retry.md +76 -0
  800. package/docs/zh-CN/concepts/session-pruning.md +129 -0
  801. package/docs/zh-CN/concepts/session-tool.md +200 -0
  802. package/docs/zh-CN/concepts/session.md +166 -0
  803. package/docs/zh-CN/concepts/sessions.md +17 -0
  804. package/docs/zh-CN/concepts/streaming.md +133 -0
  805. package/docs/zh-CN/concepts/system-prompt.md +101 -0
  806. package/docs/zh-CN/concepts/timezone.md +96 -0
  807. package/docs/zh-CN/concepts/typebox.md +284 -0
  808. package/docs/zh-CN/concepts/typing-indicators.md +74 -0
  809. package/docs/zh-CN/concepts/usage-tracking.md +42 -0
  810. package/docs/zh-CN/date-time.md +129 -0
  811. package/docs/zh-CN/debug/node-issue.md +90 -0
  812. package/docs/zh-CN/debugging.md +160 -0
  813. package/docs/zh-CN/diagnostics/flags.md +98 -0
  814. package/docs/zh-CN/environment.md +88 -0
  815. package/docs/zh-CN/experiments/onboarding-config-protocol.md +47 -0
  816. package/docs/zh-CN/experiments/plans/cron-add-hardening.md +70 -0
  817. package/docs/zh-CN/experiments/plans/group-policy-hardening.md +45 -0
  818. package/docs/zh-CN/experiments/plans/openresponses-gateway.md +121 -0
  819. package/docs/zh-CN/experiments/proposals/model-config.md +42 -0
  820. package/docs/zh-CN/experiments/research/memory.md +235 -0
  821. package/docs/zh-CN/gateway/authentication.md +142 -0
  822. package/docs/zh-CN/gateway/background-process.md +100 -0
  823. package/docs/zh-CN/gateway/bonjour.md +174 -0
  824. package/docs/zh-CN/gateway/bridge-protocol.md +86 -0
  825. package/docs/zh-CN/gateway/cli-backends.md +213 -0
  826. package/docs/zh-CN/gateway/configuration-examples.md +587 -0
  827. package/docs/zh-CN/gateway/configuration.md +3332 -0
  828. package/docs/zh-CN/gateway/discovery.md +123 -0
  829. package/docs/zh-CN/gateway/doctor.md +238 -0
  830. package/docs/zh-CN/gateway/gateway-lock.md +41 -0
  831. package/docs/zh-CN/gateway/health.md +42 -0
  832. package/docs/zh-CN/gateway/heartbeat.md +274 -0
  833. package/docs/zh-CN/gateway/index.md +335 -0
  834. package/docs/zh-CN/gateway/local-models.md +157 -0
  835. package/docs/zh-CN/gateway/logging.md +114 -0
  836. package/docs/zh-CN/gateway/multiple-gateways.md +119 -0
  837. package/docs/zh-CN/gateway/openai-http-api.md +125 -0
  838. package/docs/zh-CN/gateway/openresponses-http-api.md +317 -0
  839. package/docs/zh-CN/gateway/pairing.md +99 -0
  840. package/docs/zh-CN/gateway/protocol.md +220 -0
  841. package/docs/zh-CN/gateway/remote-gateway-readme.md +164 -0
  842. package/docs/zh-CN/gateway/remote.md +133 -0
  843. package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +135 -0
  844. package/docs/zh-CN/gateway/sandboxing.md +188 -0
  845. package/docs/zh-CN/gateway/security/formal-verification.md +169 -0
  846. package/docs/zh-CN/gateway/security/index.md +777 -0
  847. package/docs/zh-CN/gateway/tailscale.md +124 -0
  848. package/docs/zh-CN/gateway/tools-invoke-http-api.md +92 -0
  849. package/docs/zh-CN/gateway/troubleshooting.md +771 -0
  850. package/docs/zh-CN/help/faq.md +2628 -0
  851. package/docs/zh-CN/help/index.md +28 -0
  852. package/docs/zh-CN/help/troubleshooting.md +104 -0
  853. package/docs/zh-CN/hooks/soul-evil.md +72 -0
  854. package/docs/zh-CN/hooks.md +919 -0
  855. package/docs/zh-CN/index.md +264 -0
  856. package/docs/zh-CN/install/ansible.md +215 -0
  857. package/docs/zh-CN/install/bun.md +65 -0
  858. package/docs/zh-CN/install/development-channels.md +81 -0
  859. package/docs/zh-CN/install/docker.md +532 -0
  860. package/docs/zh-CN/install/index.md +193 -0
  861. package/docs/zh-CN/install/installer.md +128 -0
  862. package/docs/zh-CN/install/migrating.md +199 -0
  863. package/docs/zh-CN/install/nix.md +99 -0
  864. package/docs/zh-CN/install/node.md +85 -0
  865. package/docs/zh-CN/install/uninstall.md +135 -0
  866. package/docs/zh-CN/install/updating.md +233 -0
  867. package/docs/zh-CN/logging.md +329 -0
  868. package/docs/zh-CN/multi-agent-sandbox-tools.md +401 -0
  869. package/docs/zh-CN/network.md +59 -0
  870. package/docs/zh-CN/nodes/audio.md +120 -0
  871. package/docs/zh-CN/nodes/camera.md +162 -0
  872. package/docs/zh-CN/nodes/images.md +79 -0
  873. package/docs/zh-CN/nodes/index.md +348 -0
  874. package/docs/zh-CN/nodes/location-command.md +120 -0
  875. package/docs/zh-CN/nodes/media-understanding.md +380 -0
  876. package/docs/zh-CN/nodes/talk.md +97 -0
  877. package/docs/zh-CN/nodes/voicewake.md +72 -0
  878. package/docs/zh-CN/northflank.mdx +60 -0
  879. package/docs/zh-CN/perplexity.md +84 -0
  880. package/docs/zh-CN/pi-dev.md +77 -0
  881. package/docs/zh-CN/pi.md +619 -0
  882. package/docs/zh-CN/platforms/android.md +155 -0
  883. package/docs/zh-CN/platforms/digitalocean.md +269 -0
  884. package/docs/zh-CN/platforms/exe-dev.md +127 -0
  885. package/docs/zh-CN/platforms/fly.md +490 -0
  886. package/docs/zh-CN/platforms/gcp.md +510 -0
  887. package/docs/zh-CN/platforms/hetzner.md +337 -0
  888. package/docs/zh-CN/platforms/index.md +60 -0
  889. package/docs/zh-CN/platforms/ios.md +114 -0
  890. package/docs/zh-CN/platforms/linux.md +101 -0
  891. package/docs/zh-CN/platforms/mac/bundled-gateway.md +75 -0
  892. package/docs/zh-CN/platforms/mac/canvas.md +128 -0
  893. package/docs/zh-CN/platforms/mac/child-process.md +73 -0
  894. package/docs/zh-CN/platforms/mac/dev-setup.md +109 -0
  895. package/docs/zh-CN/platforms/mac/health.md +41 -0
  896. package/docs/zh-CN/platforms/mac/icon.md +38 -0
  897. package/docs/zh-CN/platforms/mac/logging.md +64 -0
  898. package/docs/zh-CN/platforms/mac/menu-bar.md +88 -0
  899. package/docs/zh-CN/platforms/mac/peekaboo.md +62 -0
  900. package/docs/zh-CN/platforms/mac/permissions.md +46 -0
  901. package/docs/zh-CN/platforms/mac/release.md +92 -0
  902. package/docs/zh-CN/platforms/mac/remote.md +90 -0
  903. package/docs/zh-CN/platforms/mac/signing.md +54 -0
  904. package/docs/zh-CN/platforms/mac/skills.md +40 -0
  905. package/docs/zh-CN/platforms/mac/voice-overlay.md +67 -0
  906. package/docs/zh-CN/platforms/mac/voicewake.md +74 -0
  907. package/docs/zh-CN/platforms/mac/webchat.md +43 -0
  908. package/docs/zh-CN/platforms/mac/xpc.md +68 -0
  909. package/docs/zh-CN/platforms/macos-vm.md +288 -0
  910. package/docs/zh-CN/platforms/macos.md +193 -0
  911. package/docs/zh-CN/platforms/oracle.md +310 -0
  912. package/docs/zh-CN/platforms/raspberry-pi.md +365 -0
  913. package/docs/zh-CN/platforms/windows.md +156 -0
  914. package/docs/zh-CN/plugin.md +639 -0
  915. package/docs/zh-CN/plugins/agent-tools.md +99 -0
  916. package/docs/zh-CN/plugins/manifest.md +68 -0
  917. package/docs/zh-CN/plugins/voice-call.md +250 -0
  918. package/docs/zh-CN/plugins/zalouser.md +88 -0
  919. package/docs/zh-CN/prose.md +141 -0
  920. package/docs/zh-CN/providers/anthropic.md +159 -0
  921. package/docs/zh-CN/providers/claude-max-api-proxy.md +155 -0
  922. package/docs/zh-CN/providers/deepgram.md +97 -0
  923. package/docs/zh-CN/providers/github-copilot.md +67 -0
  924. package/docs/zh-CN/providers/glm.md +39 -0
  925. package/docs/zh-CN/providers/index.md +68 -0
  926. package/docs/zh-CN/providers/minimax.md +206 -0
  927. package/docs/zh-CN/providers/models.md +55 -0
  928. package/docs/zh-CN/providers/moonshot.md +145 -0
  929. package/docs/zh-CN/providers/ollama.md +230 -0
  930. package/docs/zh-CN/providers/openai.md +68 -0
  931. package/docs/zh-CN/providers/opencode.md +41 -0
  932. package/docs/zh-CN/providers/openrouter.md +43 -0
  933. package/docs/zh-CN/providers/qwen.md +55 -0
  934. package/docs/zh-CN/providers/synthetic.md +102 -0
  935. package/docs/zh-CN/providers/venice.md +274 -0
  936. package/docs/zh-CN/providers/vercel-ai-gateway.md +57 -0
  937. package/docs/zh-CN/providers/xiaomi.md +68 -0
  938. package/docs/zh-CN/providers/zai.md +41 -0
  939. package/docs/zh-CN/railway.mdx +106 -0
  940. package/docs/zh-CN/refactor/clawnet.md +424 -0
  941. package/docs/zh-CN/refactor/exec-host.md +323 -0
  942. package/docs/zh-CN/refactor/outbound-session-mirroring.md +92 -0
  943. package/docs/zh-CN/refactor/plugin-sdk.md +221 -0
  944. package/docs/zh-CN/refactor/strict-config.md +100 -0
  945. package/docs/zh-CN/reference/AGENTS.default.md +131 -0
  946. package/docs/zh-CN/reference/RELEASING.md +123 -0
  947. package/docs/zh-CN/reference/api-usage-costs.md +136 -0
  948. package/docs/zh-CN/reference/device-models.md +54 -0
  949. package/docs/zh-CN/reference/rpc.md +48 -0
  950. package/docs/zh-CN/reference/session-management-compaction.md +287 -0
  951. package/docs/zh-CN/reference/templates/AGENTS.dev.md +89 -0
  952. package/docs/zh-CN/reference/templates/AGENTS.md +225 -0
  953. package/docs/zh-CN/reference/templates/BOOT.md +17 -0
  954. package/docs/zh-CN/reference/templates/BOOTSTRAP.md +68 -0
  955. package/docs/zh-CN/reference/templates/HEARTBEAT.md +18 -0
  956. package/docs/zh-CN/reference/templates/IDENTITY.dev.md +54 -0
  957. package/docs/zh-CN/reference/templates/IDENTITY.md +35 -0
  958. package/docs/zh-CN/reference/templates/SOUL.dev.md +83 -0
  959. package/docs/zh-CN/reference/templates/SOUL.md +49 -0
  960. package/docs/zh-CN/reference/templates/TOOLS.dev.md +31 -0
  961. package/docs/zh-CN/reference/templates/TOOLS.md +53 -0
  962. package/docs/zh-CN/reference/templates/USER.dev.md +25 -0
  963. package/docs/zh-CN/reference/templates/USER.md +30 -0
  964. package/docs/zh-CN/reference/test.md +57 -0
  965. package/docs/zh-CN/reference/transcript-hygiene.md +109 -0
  966. package/docs/zh-CN/render.mdx +169 -0
  967. package/docs/zh-CN/scripts.md +35 -0
  968. package/docs/zh-CN/security/formal-verification.md +171 -0
  969. package/docs/zh-CN/start/getting-started.md +206 -0
  970. package/docs/zh-CN/start/hubs.md +191 -0
  971. package/docs/zh-CN/start/lore.md +226 -0
  972. package/docs/zh-CN/start/onboarding.md +105 -0
  973. package/docs/zh-CN/start/openclaw.md +248 -0
  974. package/docs/zh-CN/start/pairing.md +89 -0
  975. package/docs/zh-CN/start/setup.md +153 -0
  976. package/docs/zh-CN/start/showcase.md +423 -0
  977. package/docs/zh-CN/start/wizard.md +331 -0
  978. package/docs/zh-CN/testing.md +375 -0
  979. package/docs/zh-CN/token-use.md +119 -0
  980. package/docs/zh-CN/tools/agent-send.md +59 -0
  981. package/docs/zh-CN/tools/apply-patch.md +57 -0
  982. package/docs/zh-CN/tools/browser-linux-troubleshooting.md +144 -0
  983. package/docs/zh-CN/tools/browser-login.md +75 -0
  984. package/docs/zh-CN/tools/browser.md +553 -0
  985. package/docs/zh-CN/tools/chrome-extension.md +183 -0
  986. package/docs/zh-CN/tools/clawhub.md +209 -0
  987. package/docs/zh-CN/tools/creating-skills.md +61 -0
  988. package/docs/zh-CN/tools/elevated.md +64 -0
  989. package/docs/zh-CN/tools/exec-approvals.md +234 -0
  990. package/docs/zh-CN/tools/exec.md +169 -0
  991. package/docs/zh-CN/tools/firecrawl.md +68 -0
  992. package/docs/zh-CN/tools/index.md +515 -0
  993. package/docs/zh-CN/tools/llm-task.md +117 -0
  994. package/docs/zh-CN/tools/lobster.md +349 -0
  995. package/docs/zh-CN/tools/reactions.md +29 -0
  996. package/docs/zh-CN/tools/skills-config.md +78 -0
  997. package/docs/zh-CN/tools/skills.md +279 -0
  998. package/docs/zh-CN/tools/slash-commands.md +205 -0
  999. package/docs/zh-CN/tools/subagents.md +156 -0
  1000. package/docs/zh-CN/tools/thinking.md +80 -0
  1001. package/docs/zh-CN/tools/web.md +257 -0
  1002. package/docs/zh-CN/tts.md +375 -0
  1003. package/docs/zh-CN/tui.md +166 -0
  1004. package/docs/zh-CN/vps.md +47 -0
  1005. package/docs/zh-CN/web/control-ui.md +191 -0
  1006. package/docs/zh-CN/web/dashboard.md +53 -0
  1007. package/docs/zh-CN/web/index.md +118 -0
  1008. package/docs/zh-CN/web/webchat.md +56 -0
  1009. package/extensions/bluebubbles/README.md +45 -0
  1010. package/extensions/bluebubbles/index.ts +19 -0
  1011. package/extensions/bluebubbles/node_modules/.bin/openclaw +21 -0
  1012. package/extensions/bluebubbles/openclaw.plugin.json +9 -0
  1013. package/extensions/bluebubbles/package.json +36 -0
  1014. package/extensions/bluebubbles/src/accounts.ts +88 -0
  1015. package/extensions/bluebubbles/src/actions.test.ts +650 -0
  1016. package/extensions/bluebubbles/src/actions.ts +438 -0
  1017. package/extensions/bluebubbles/src/attachments.test.ts +345 -0
  1018. package/extensions/bluebubbles/src/attachments.ts +300 -0
  1019. package/extensions/bluebubbles/src/channel.ts +414 -0
  1020. package/extensions/bluebubbles/src/chat.test.ts +461 -0
  1021. package/extensions/bluebubbles/src/chat.ts +378 -0
  1022. package/extensions/bluebubbles/src/config-schema.ts +51 -0
  1023. package/extensions/bluebubbles/src/media-send.ts +174 -0
  1024. package/extensions/bluebubbles/src/monitor.test.ts +2342 -0
  1025. package/extensions/bluebubbles/src/monitor.ts +2490 -0
  1026. package/extensions/bluebubbles/src/onboarding.ts +352 -0
  1027. package/extensions/bluebubbles/src/probe.ts +135 -0
  1028. package/extensions/bluebubbles/src/reactions.test.ts +392 -0
  1029. package/extensions/bluebubbles/src/reactions.ts +188 -0
  1030. package/extensions/bluebubbles/src/runtime.ts +14 -0
  1031. package/extensions/bluebubbles/src/send.test.ts +808 -0
  1032. package/extensions/bluebubbles/src/send.ts +467 -0
  1033. package/extensions/bluebubbles/src/targets.test.ts +183 -0
  1034. package/extensions/bluebubbles/src/targets.ts +422 -0
  1035. package/extensions/bluebubbles/src/types.ts +127 -0
  1036. package/extensions/copilot-proxy/README.md +24 -0
  1037. package/extensions/copilot-proxy/index.ts +148 -0
  1038. package/extensions/copilot-proxy/node_modules/.bin/openclaw +21 -0
  1039. package/extensions/copilot-proxy/openclaw.plugin.json +9 -0
  1040. package/extensions/copilot-proxy/package.json +14 -0
  1041. package/extensions/diagnostics-otel/index.ts +15 -0
  1042. package/extensions/diagnostics-otel/node_modules/.bin/openclaw +21 -0
  1043. package/extensions/diagnostics-otel/openclaw.plugin.json +8 -0
  1044. package/extensions/diagnostics-otel/package.json +27 -0
  1045. package/extensions/diagnostics-otel/src/service.test.ts +226 -0
  1046. package/extensions/diagnostics-otel/src/service.ts +635 -0
  1047. package/extensions/discord/index.ts +17 -0
  1048. package/extensions/discord/node_modules/.bin/openclaw +21 -0
  1049. package/extensions/discord/openclaw.plugin.json +9 -0
  1050. package/extensions/discord/package.json +14 -0
  1051. package/extensions/discord/src/channel.ts +422 -0
  1052. package/extensions/discord/src/runtime.ts +14 -0
  1053. package/extensions/feishu/README.md +47 -0
  1054. package/extensions/feishu/index.ts +15 -0
  1055. package/extensions/feishu/node_modules/.bin/openclaw +21 -0
  1056. package/extensions/feishu/openclaw.plugin.json +9 -0
  1057. package/extensions/feishu/package.json +33 -0
  1058. package/extensions/feishu/src/channel.ts +276 -0
  1059. package/extensions/feishu/src/config-schema.ts +46 -0
  1060. package/extensions/feishu/src/onboarding.ts +278 -0
  1061. package/extensions/google-antigravity-auth/README.md +24 -0
  1062. package/extensions/google-antigravity-auth/index.ts +461 -0
  1063. package/extensions/google-antigravity-auth/node_modules/.bin/openclaw +21 -0
  1064. package/extensions/google-antigravity-auth/openclaw.plugin.json +9 -0
  1065. package/extensions/google-antigravity-auth/package.json +14 -0
  1066. package/extensions/google-gemini-cli-auth/README.md +35 -0
  1067. package/extensions/google-gemini-cli-auth/index.ts +88 -0
  1068. package/extensions/google-gemini-cli-auth/node_modules/.bin/openclaw +21 -0
  1069. package/extensions/google-gemini-cli-auth/oauth.test.ts +240 -0
  1070. package/extensions/google-gemini-cli-auth/oauth.ts +662 -0
  1071. package/extensions/google-gemini-cli-auth/openclaw.plugin.json +9 -0
  1072. package/extensions/google-gemini-cli-auth/package.json +14 -0
  1073. package/extensions/googlechat/index.ts +19 -0
  1074. package/extensions/googlechat/node_modules/.bin/openclaw +21 -0
  1075. package/extensions/googlechat/openclaw.plugin.json +9 -0
  1076. package/extensions/googlechat/package.json +39 -0
  1077. package/extensions/googlechat/src/accounts.ts +147 -0
  1078. package/extensions/googlechat/src/actions.ts +181 -0
  1079. package/extensions/googlechat/src/api.test.ts +61 -0
  1080. package/extensions/googlechat/src/api.ts +282 -0
  1081. package/extensions/googlechat/src/auth.ts +123 -0
  1082. package/extensions/googlechat/src/channel.ts +583 -0
  1083. package/extensions/googlechat/src/monitor.test.ts +22 -0
  1084. package/extensions/googlechat/src/monitor.ts +949 -0
  1085. package/extensions/googlechat/src/onboarding.ts +269 -0
  1086. package/extensions/googlechat/src/runtime.ts +14 -0
  1087. package/extensions/googlechat/src/targets.test.ts +32 -0
  1088. package/extensions/googlechat/src/targets.ts +65 -0
  1089. package/extensions/googlechat/src/types.config.ts +3 -0
  1090. package/extensions/googlechat/src/types.ts +73 -0
  1091. package/extensions/imessage/index.ts +17 -0
  1092. package/extensions/imessage/node_modules/.bin/openclaw +21 -0
  1093. package/extensions/imessage/openclaw.plugin.json +9 -0
  1094. package/extensions/imessage/package.json +14 -0
  1095. package/extensions/imessage/src/channel.ts +294 -0
  1096. package/extensions/imessage/src/runtime.ts +14 -0
  1097. package/extensions/line/index.ts +19 -0
  1098. package/extensions/line/node_modules/.bin/openclaw +21 -0
  1099. package/extensions/line/openclaw.plugin.json +9 -0
  1100. package/extensions/line/package.json +29 -0
  1101. package/extensions/line/src/card-command.ts +344 -0
  1102. package/extensions/line/src/channel.logout.test.ts +99 -0
  1103. package/extensions/line/src/channel.sendPayload.test.ts +306 -0
  1104. package/extensions/line/src/channel.ts +780 -0
  1105. package/extensions/line/src/runtime.ts +14 -0
  1106. package/extensions/llm-task/README.md +97 -0
  1107. package/extensions/llm-task/index.ts +6 -0
  1108. package/extensions/llm-task/node_modules/.bin/openclaw +21 -0
  1109. package/extensions/llm-task/openclaw.plugin.json +21 -0
  1110. package/extensions/llm-task/package.json +14 -0
  1111. package/extensions/llm-task/src/llm-task-tool.test.ts +138 -0
  1112. package/extensions/llm-task/src/llm-task-tool.ts +245 -0
  1113. package/extensions/lobster/README.md +75 -0
  1114. package/extensions/lobster/SKILL.md +97 -0
  1115. package/extensions/lobster/index.ts +14 -0
  1116. package/extensions/lobster/node_modules/.bin/openclaw +21 -0
  1117. package/extensions/lobster/openclaw.plugin.json +10 -0
  1118. package/extensions/lobster/package.json +14 -0
  1119. package/extensions/lobster/src/lobster-tool.test.ts +247 -0
  1120. package/extensions/lobster/src/lobster-tool.ts +328 -0
  1121. package/extensions/matrix/CHANGELOG.md +87 -0
  1122. package/extensions/matrix/index.ts +17 -0
  1123. package/extensions/matrix/node_modules/.bin/markdown-it +21 -0
  1124. package/extensions/matrix/node_modules/.bin/openclaw +21 -0
  1125. package/extensions/matrix/openclaw.plugin.json +9 -0
  1126. package/extensions/matrix/package.json +36 -0
  1127. package/extensions/matrix/src/actions.ts +195 -0
  1128. package/extensions/matrix/src/channel.directory.test.ts +64 -0
  1129. package/extensions/matrix/src/channel.ts +439 -0
  1130. package/extensions/matrix/src/config-schema.ts +62 -0
  1131. package/extensions/matrix/src/directory-live.ts +188 -0
  1132. package/extensions/matrix/src/group-mentions.ts +66 -0
  1133. package/extensions/matrix/src/matrix/accounts.test.ts +82 -0
  1134. package/extensions/matrix/src/matrix/accounts.ts +65 -0
  1135. package/extensions/matrix/src/matrix/actions/client.ts +57 -0
  1136. package/extensions/matrix/src/matrix/actions/messages.ts +128 -0
  1137. package/extensions/matrix/src/matrix/actions/pins.ts +76 -0
  1138. package/extensions/matrix/src/matrix/actions/reactions.ts +96 -0
  1139. package/extensions/matrix/src/matrix/actions/room.ts +85 -0
  1140. package/extensions/matrix/src/matrix/actions/summary.ts +75 -0
  1141. package/extensions/matrix/src/matrix/actions/types.ts +84 -0
  1142. package/extensions/matrix/src/matrix/actions.ts +15 -0
  1143. package/extensions/matrix/src/matrix/active-client.ts +11 -0
  1144. package/extensions/matrix/src/matrix/client/config.ts +160 -0
  1145. package/extensions/matrix/src/matrix/client/create-client.ts +123 -0
  1146. package/extensions/matrix/src/matrix/client/logging.ts +36 -0
  1147. package/extensions/matrix/src/matrix/client/runtime.ts +4 -0
  1148. package/extensions/matrix/src/matrix/client/shared.ts +170 -0
  1149. package/extensions/matrix/src/matrix/client/storage.ts +131 -0
  1150. package/extensions/matrix/src/matrix/client/types.ts +34 -0
  1151. package/extensions/matrix/src/matrix/client.test.ts +56 -0
  1152. package/extensions/matrix/src/matrix/client.ts +5 -0
  1153. package/extensions/matrix/src/matrix/credentials.ts +105 -0
  1154. package/extensions/matrix/src/matrix/deps.ts +60 -0
  1155. package/extensions/matrix/src/matrix/format.test.ts +33 -0
  1156. package/extensions/matrix/src/matrix/format.ts +22 -0
  1157. package/extensions/matrix/src/matrix/index.ts +11 -0
  1158. package/extensions/matrix/src/matrix/monitor/allowlist.test.ts +45 -0
  1159. package/extensions/matrix/src/matrix/monitor/allowlist.ts +103 -0
  1160. package/extensions/matrix/src/matrix/monitor/auto-join.ts +71 -0
  1161. package/extensions/matrix/src/matrix/monitor/direct.ts +104 -0
  1162. package/extensions/matrix/src/matrix/monitor/events.ts +101 -0
  1163. package/extensions/matrix/src/matrix/monitor/handler.ts +661 -0
  1164. package/extensions/matrix/src/matrix/monitor/index.ts +338 -0
  1165. package/extensions/matrix/src/matrix/monitor/location.ts +100 -0
  1166. package/extensions/matrix/src/matrix/monitor/media.test.ts +102 -0
  1167. package/extensions/matrix/src/matrix/monitor/media.ts +113 -0
  1168. package/extensions/matrix/src/matrix/monitor/mentions.ts +31 -0
  1169. package/extensions/matrix/src/matrix/monitor/replies.ts +97 -0
  1170. package/extensions/matrix/src/matrix/monitor/room-info.ts +55 -0
  1171. package/extensions/matrix/src/matrix/monitor/rooms.test.ts +39 -0
  1172. package/extensions/matrix/src/matrix/monitor/rooms.ts +47 -0
  1173. package/extensions/matrix/src/matrix/monitor/threads.ts +68 -0
  1174. package/extensions/matrix/src/matrix/monitor/types.ts +39 -0
  1175. package/extensions/matrix/src/matrix/poll-types.test.ts +21 -0
  1176. package/extensions/matrix/src/matrix/poll-types.ts +166 -0
  1177. package/extensions/matrix/src/matrix/probe.ts +70 -0
  1178. package/extensions/matrix/src/matrix/send/client.ts +66 -0
  1179. package/extensions/matrix/src/matrix/send/formatting.ts +89 -0
  1180. package/extensions/matrix/src/matrix/send/media.ts +229 -0
  1181. package/extensions/matrix/src/matrix/send/targets.test.ts +98 -0
  1182. package/extensions/matrix/src/matrix/send/targets.ts +136 -0
  1183. package/extensions/matrix/src/matrix/send/types.ts +109 -0
  1184. package/extensions/matrix/src/matrix/send.test.ts +171 -0
  1185. package/extensions/matrix/src/matrix/send.ts +260 -0
  1186. package/extensions/matrix/src/onboarding.ts +449 -0
  1187. package/extensions/matrix/src/outbound.ts +52 -0
  1188. package/extensions/matrix/src/resolve-targets.test.ts +48 -0
  1189. package/extensions/matrix/src/resolve-targets.ts +135 -0
  1190. package/extensions/matrix/src/runtime.ts +14 -0
  1191. package/extensions/matrix/src/tool-actions.ts +164 -0
  1192. package/extensions/matrix/src/types.ts +95 -0
  1193. package/extensions/mattermost/index.ts +17 -0
  1194. package/extensions/mattermost/node_modules/.bin/openclaw +21 -0
  1195. package/extensions/mattermost/openclaw.plugin.json +9 -0
  1196. package/extensions/mattermost/package.json +28 -0
  1197. package/extensions/mattermost/src/channel.test.ts +48 -0
  1198. package/extensions/mattermost/src/channel.ts +337 -0
  1199. package/extensions/mattermost/src/config-schema.ts +55 -0
  1200. package/extensions/mattermost/src/group-mentions.ts +15 -0
  1201. package/extensions/mattermost/src/mattermost/accounts.ts +128 -0
  1202. package/extensions/mattermost/src/mattermost/client.ts +220 -0
  1203. package/extensions/mattermost/src/mattermost/index.ts +9 -0
  1204. package/extensions/mattermost/src/mattermost/monitor-helpers.ts +166 -0
  1205. package/extensions/mattermost/src/mattermost/monitor.ts +987 -0
  1206. package/extensions/mattermost/src/mattermost/probe.ts +74 -0
  1207. package/extensions/mattermost/src/mattermost/send.ts +231 -0
  1208. package/extensions/mattermost/src/normalize.ts +46 -0
  1209. package/extensions/mattermost/src/onboarding-helpers.ts +44 -0
  1210. package/extensions/mattermost/src/onboarding.ts +186 -0
  1211. package/extensions/mattermost/src/runtime.ts +14 -0
  1212. package/extensions/mattermost/src/types.ts +50 -0
  1213. package/extensions/memory-core/index.ts +38 -0
  1214. package/extensions/memory-core/node_modules/.bin/openclaw +21 -0
  1215. package/extensions/memory-core/openclaw.plugin.json +9 -0
  1216. package/extensions/memory-core/package.json +17 -0
  1217. package/extensions/memory-lancedb/config.ts +139 -0
  1218. package/extensions/memory-lancedb/index.test.ts +295 -0
  1219. package/extensions/memory-lancedb/index.ts +608 -0
  1220. package/extensions/memory-lancedb/node_modules/.bin/openai +21 -0
  1221. package/extensions/memory-lancedb/node_modules/.bin/openclaw +21 -0
  1222. package/extensions/memory-lancedb/openclaw.plugin.json +60 -0
  1223. package/extensions/memory-lancedb/package.json +19 -0
  1224. package/extensions/minimax-portal-auth/README.md +33 -0
  1225. package/extensions/minimax-portal-auth/index.ts +155 -0
  1226. package/extensions/minimax-portal-auth/node_modules/.bin/openclaw +21 -0
  1227. package/extensions/minimax-portal-auth/oauth.ts +247 -0
  1228. package/extensions/minimax-portal-auth/openclaw.plugin.json +9 -0
  1229. package/extensions/minimax-portal-auth/package.json +14 -0
  1230. package/extensions/msteams/CHANGELOG.md +83 -0
  1231. package/extensions/msteams/index.ts +17 -0
  1232. package/extensions/msteams/node_modules/.bin/openclaw +21 -0
  1233. package/extensions/msteams/openclaw.plugin.json +9 -0
  1234. package/extensions/msteams/package.json +39 -0
  1235. package/extensions/msteams/src/attachments/download.ts +283 -0
  1236. package/extensions/msteams/src/attachments/graph.ts +353 -0
  1237. package/extensions/msteams/src/attachments/html.ts +90 -0
  1238. package/extensions/msteams/src/attachments/payload.ts +22 -0
  1239. package/extensions/msteams/src/attachments/shared.ts +291 -0
  1240. package/extensions/msteams/src/attachments/types.ts +37 -0
  1241. package/extensions/msteams/src/attachments.test.ts +459 -0
  1242. package/extensions/msteams/src/attachments.ts +18 -0
  1243. package/extensions/msteams/src/channel.directory.test.ts +48 -0
  1244. package/extensions/msteams/src/channel.ts +459 -0
  1245. package/extensions/msteams/src/conversation-store-fs.test.ts +88 -0
  1246. package/extensions/msteams/src/conversation-store-fs.ts +165 -0
  1247. package/extensions/msteams/src/conversation-store-memory.ts +47 -0
  1248. package/extensions/msteams/src/conversation-store.ts +41 -0
  1249. package/extensions/msteams/src/directory-live.ts +205 -0
  1250. package/extensions/msteams/src/errors.test.ts +45 -0
  1251. package/extensions/msteams/src/errors.ts +190 -0
  1252. package/extensions/msteams/src/file-consent-helpers.test.ts +243 -0
  1253. package/extensions/msteams/src/file-consent-helpers.ts +73 -0
  1254. package/extensions/msteams/src/file-consent.ts +126 -0
  1255. package/extensions/msteams/src/graph-chat.ts +53 -0
  1256. package/extensions/msteams/src/graph-upload.ts +453 -0
  1257. package/extensions/msteams/src/inbound.test.ts +66 -0
  1258. package/extensions/msteams/src/inbound.ts +48 -0
  1259. package/extensions/msteams/src/index.ts +4 -0
  1260. package/extensions/msteams/src/media-helpers.test.ts +189 -0
  1261. package/extensions/msteams/src/media-helpers.ts +86 -0
  1262. package/extensions/msteams/src/messenger.test.ts +248 -0
  1263. package/extensions/msteams/src/messenger.ts +495 -0
  1264. package/extensions/msteams/src/monitor-handler/inbound-media.ts +128 -0
  1265. package/extensions/msteams/src/monitor-handler/message-handler.ts +640 -0
  1266. package/extensions/msteams/src/monitor-handler.ts +162 -0
  1267. package/extensions/msteams/src/monitor-types.ts +5 -0
  1268. package/extensions/msteams/src/monitor.ts +295 -0
  1269. package/extensions/msteams/src/onboarding.ts +431 -0
  1270. package/extensions/msteams/src/outbound.ts +46 -0
  1271. package/extensions/msteams/src/pending-uploads.ts +89 -0
  1272. package/extensions/msteams/src/policy.test.ts +209 -0
  1273. package/extensions/msteams/src/policy.ts +273 -0
  1274. package/extensions/msteams/src/polls-store-memory.ts +32 -0
  1275. package/extensions/msteams/src/polls-store.test.ts +38 -0
  1276. package/extensions/msteams/src/polls.test.ts +72 -0
  1277. package/extensions/msteams/src/polls.ts +315 -0
  1278. package/extensions/msteams/src/probe.test.ts +58 -0
  1279. package/extensions/msteams/src/probe.ts +107 -0
  1280. package/extensions/msteams/src/reply-dispatcher.ts +130 -0
  1281. package/extensions/msteams/src/resolve-allowlist.ts +297 -0
  1282. package/extensions/msteams/src/runtime.ts +14 -0
  1283. package/extensions/msteams/src/sdk-types.ts +19 -0
  1284. package/extensions/msteams/src/sdk.ts +33 -0
  1285. package/extensions/msteams/src/send-context.ts +164 -0
  1286. package/extensions/msteams/src/send.ts +519 -0
  1287. package/extensions/msteams/src/sent-message-cache.test.ts +15 -0
  1288. package/extensions/msteams/src/sent-message-cache.ts +47 -0
  1289. package/extensions/msteams/src/storage.ts +25 -0
  1290. package/extensions/msteams/src/store-fs.ts +83 -0
  1291. package/extensions/msteams/src/token.ts +19 -0
  1292. package/extensions/nextcloud-talk/index.ts +17 -0
  1293. package/extensions/nextcloud-talk/node_modules/.bin/openclaw +21 -0
  1294. package/extensions/nextcloud-talk/openclaw.plugin.json +9 -0
  1295. package/extensions/nextcloud-talk/package.json +33 -0
  1296. package/extensions/nextcloud-talk/src/accounts.ts +174 -0
  1297. package/extensions/nextcloud-talk/src/channel.ts +409 -0
  1298. package/extensions/nextcloud-talk/src/config-schema.ts +78 -0
  1299. package/extensions/nextcloud-talk/src/format.ts +79 -0
  1300. package/extensions/nextcloud-talk/src/inbound.ts +317 -0
  1301. package/extensions/nextcloud-talk/src/monitor.ts +246 -0
  1302. package/extensions/nextcloud-talk/src/normalize.ts +39 -0
  1303. package/extensions/nextcloud-talk/src/onboarding.ts +343 -0
  1304. package/extensions/nextcloud-talk/src/policy.test.ts +33 -0
  1305. package/extensions/nextcloud-talk/src/policy.ts +180 -0
  1306. package/extensions/nextcloud-talk/src/room-info.ts +125 -0
  1307. package/extensions/nextcloud-talk/src/runtime.ts +14 -0
  1308. package/extensions/nextcloud-talk/src/send.ts +210 -0
  1309. package/extensions/nextcloud-talk/src/signature.ts +72 -0
  1310. package/extensions/nextcloud-talk/src/types.ts +179 -0
  1311. package/extensions/nostr/CHANGELOG.md +74 -0
  1312. package/extensions/nostr/README.md +136 -0
  1313. package/extensions/nostr/index.ts +68 -0
  1314. package/extensions/nostr/node_modules/.bin/openclaw +21 -0
  1315. package/extensions/nostr/openclaw.plugin.json +9 -0
  1316. package/extensions/nostr/package.json +34 -0
  1317. package/extensions/nostr/src/channel.test.ts +151 -0
  1318. package/extensions/nostr/src/channel.ts +353 -0
  1319. package/extensions/nostr/src/config-schema.ts +90 -0
  1320. package/extensions/nostr/src/metrics.ts +478 -0
  1321. package/extensions/nostr/src/nostr-bus.fuzz.test.ts +533 -0
  1322. package/extensions/nostr/src/nostr-bus.integration.test.ts +448 -0
  1323. package/extensions/nostr/src/nostr-bus.test.ts +199 -0
  1324. package/extensions/nostr/src/nostr-bus.ts +715 -0
  1325. package/extensions/nostr/src/nostr-profile-http.test.ts +378 -0
  1326. package/extensions/nostr/src/nostr-profile-http.ts +519 -0
  1327. package/extensions/nostr/src/nostr-profile-import.test.ts +119 -0
  1328. package/extensions/nostr/src/nostr-profile-import.ts +262 -0
  1329. package/extensions/nostr/src/nostr-profile.fuzz.test.ts +477 -0
  1330. package/extensions/nostr/src/nostr-profile.test.ts +410 -0
  1331. package/extensions/nostr/src/nostr-profile.ts +277 -0
  1332. package/extensions/nostr/src/nostr-state-store.test.ts +131 -0
  1333. package/extensions/nostr/src/nostr-state-store.ts +226 -0
  1334. package/extensions/nostr/src/runtime.ts +14 -0
  1335. package/extensions/nostr/src/seen-tracker.ts +303 -0
  1336. package/extensions/nostr/src/types.test.ts +157 -0
  1337. package/extensions/nostr/src/types.ts +101 -0
  1338. package/extensions/nostr/test/setup.ts +5 -0
  1339. package/extensions/open-prose/README.md +25 -0
  1340. package/extensions/open-prose/index.ts +5 -0
  1341. package/extensions/open-prose/node_modules/.bin/openclaw +21 -0
  1342. package/extensions/open-prose/openclaw.plugin.json +11 -0
  1343. package/extensions/open-prose/package.json +14 -0
  1344. package/extensions/open-prose/skills/prose/LICENSE +21 -0
  1345. package/extensions/open-prose/skills/prose/SKILL.md +323 -0
  1346. package/extensions/open-prose/skills/prose/alt-borges.md +141 -0
  1347. package/extensions/open-prose/skills/prose/alts/arabian-nights.md +358 -0
  1348. package/extensions/open-prose/skills/prose/alts/borges.md +360 -0
  1349. package/extensions/open-prose/skills/prose/alts/folk.md +322 -0
  1350. package/extensions/open-prose/skills/prose/alts/homer.md +346 -0
  1351. package/extensions/open-prose/skills/prose/alts/kafka.md +373 -0
  1352. package/extensions/open-prose/skills/prose/compiler.md +2971 -0
  1353. package/extensions/open-prose/skills/prose/examples/01-hello-world.prose +4 -0
  1354. package/extensions/open-prose/skills/prose/examples/02-research-and-summarize.prose +6 -0
  1355. package/extensions/open-prose/skills/prose/examples/03-code-review.prose +17 -0
  1356. package/extensions/open-prose/skills/prose/examples/04-write-and-refine.prose +14 -0
  1357. package/extensions/open-prose/skills/prose/examples/05-debug-issue.prose +20 -0
  1358. package/extensions/open-prose/skills/prose/examples/06-explain-codebase.prose +17 -0
  1359. package/extensions/open-prose/skills/prose/examples/07-refactor.prose +20 -0
  1360. package/extensions/open-prose/skills/prose/examples/08-blog-post.prose +20 -0
  1361. package/extensions/open-prose/skills/prose/examples/09-research-with-agents.prose +25 -0
  1362. package/extensions/open-prose/skills/prose/examples/10-code-review-agents.prose +32 -0
  1363. package/extensions/open-prose/skills/prose/examples/11-skills-and-imports.prose +27 -0
  1364. package/extensions/open-prose/skills/prose/examples/12-secure-agent-permissions.prose +43 -0
  1365. package/extensions/open-prose/skills/prose/examples/13-variables-and-context.prose +51 -0
  1366. package/extensions/open-prose/skills/prose/examples/14-composition-blocks.prose +48 -0
  1367. package/extensions/open-prose/skills/prose/examples/15-inline-sequences.prose +23 -0
  1368. package/extensions/open-prose/skills/prose/examples/16-parallel-reviews.prose +19 -0
  1369. package/extensions/open-prose/skills/prose/examples/17-parallel-research.prose +19 -0
  1370. package/extensions/open-prose/skills/prose/examples/18-mixed-parallel-sequential.prose +36 -0
  1371. package/extensions/open-prose/skills/prose/examples/19-advanced-parallel.prose +71 -0
  1372. package/extensions/open-prose/skills/prose/examples/20-fixed-loops.prose +20 -0
  1373. package/extensions/open-prose/skills/prose/examples/21-pipeline-operations.prose +35 -0
  1374. package/extensions/open-prose/skills/prose/examples/22-error-handling.prose +51 -0
  1375. package/extensions/open-prose/skills/prose/examples/23-retry-with-backoff.prose +63 -0
  1376. package/extensions/open-prose/skills/prose/examples/24-choice-blocks.prose +86 -0
  1377. package/extensions/open-prose/skills/prose/examples/25-conditionals.prose +114 -0
  1378. package/extensions/open-prose/skills/prose/examples/26-parameterized-blocks.prose +100 -0
  1379. package/extensions/open-prose/skills/prose/examples/27-string-interpolation.prose +105 -0
  1380. package/extensions/open-prose/skills/prose/examples/28-automated-pr-review.prose +37 -0
  1381. package/extensions/open-prose/skills/prose/examples/28-gas-town.prose +1572 -0
  1382. package/extensions/open-prose/skills/prose/examples/29-captains-chair.prose +218 -0
  1383. package/extensions/open-prose/skills/prose/examples/30-captains-chair-simple.prose +42 -0
  1384. package/extensions/open-prose/skills/prose/examples/31-captains-chair-with-memory.prose +145 -0
  1385. package/extensions/open-prose/skills/prose/examples/33-pr-review-autofix.prose +168 -0
  1386. package/extensions/open-prose/skills/prose/examples/34-content-pipeline.prose +204 -0
  1387. package/extensions/open-prose/skills/prose/examples/35-feature-factory.prose +296 -0
  1388. package/extensions/open-prose/skills/prose/examples/36-bug-hunter.prose +237 -0
  1389. package/extensions/open-prose/skills/prose/examples/37-the-forge.prose +1474 -0
  1390. package/extensions/open-prose/skills/prose/examples/38-skill-scan.prose +455 -0
  1391. package/extensions/open-prose/skills/prose/examples/39-architect-by-simulation.prose +277 -0
  1392. package/extensions/open-prose/skills/prose/examples/40-rlm-self-refine.prose +32 -0
  1393. package/extensions/open-prose/skills/prose/examples/41-rlm-divide-conquer.prose +38 -0
  1394. package/extensions/open-prose/skills/prose/examples/42-rlm-filter-recurse.prose +46 -0
  1395. package/extensions/open-prose/skills/prose/examples/43-rlm-pairwise.prose +50 -0
  1396. package/extensions/open-prose/skills/prose/examples/44-run-endpoint-ux-test.prose +261 -0
  1397. package/extensions/open-prose/skills/prose/examples/45-plugin-release.prose +159 -0
  1398. package/extensions/open-prose/skills/prose/examples/45-run-endpoint-ux-test-with-remediation.prose +637 -0
  1399. package/extensions/open-prose/skills/prose/examples/46-run-endpoint-ux-test-fast.prose +148 -0
  1400. package/extensions/open-prose/skills/prose/examples/46-workflow-crystallizer.prose +225 -0
  1401. package/extensions/open-prose/skills/prose/examples/47-language-self-improvement.prose +356 -0
  1402. package/extensions/open-prose/skills/prose/examples/48-habit-miner.prose +445 -0
  1403. package/extensions/open-prose/skills/prose/examples/49-prose-run-retrospective.prose +210 -0
  1404. package/extensions/open-prose/skills/prose/examples/README.md +391 -0
  1405. package/extensions/open-prose/skills/prose/examples/roadmap/README.md +22 -0
  1406. package/extensions/open-prose/skills/prose/examples/roadmap/iterative-refinement.prose +20 -0
  1407. package/extensions/open-prose/skills/prose/examples/roadmap/parallel-review.prose +18 -0
  1408. package/extensions/open-prose/skills/prose/examples/roadmap/simple-pipeline.prose +17 -0
  1409. package/extensions/open-prose/skills/prose/examples/roadmap/syntax/open-prose-syntax.prose +223 -0
  1410. package/extensions/open-prose/skills/prose/guidance/antipatterns.md +951 -0
  1411. package/extensions/open-prose/skills/prose/guidance/patterns.md +700 -0
  1412. package/extensions/open-prose/skills/prose/guidance/system-prompt.md +180 -0
  1413. package/extensions/open-prose/skills/prose/help.md +144 -0
  1414. package/extensions/open-prose/skills/prose/lib/README.md +108 -0
  1415. package/extensions/open-prose/skills/prose/lib/calibrator.prose +215 -0
  1416. package/extensions/open-prose/skills/prose/lib/cost-analyzer.prose +174 -0
  1417. package/extensions/open-prose/skills/prose/lib/error-forensics.prose +250 -0
  1418. package/extensions/open-prose/skills/prose/lib/inspector.prose +196 -0
  1419. package/extensions/open-prose/skills/prose/lib/profiler.prose +460 -0
  1420. package/extensions/open-prose/skills/prose/lib/program-improver.prose +275 -0
  1421. package/extensions/open-prose/skills/prose/lib/project-memory.prose +118 -0
  1422. package/extensions/open-prose/skills/prose/lib/user-memory.prose +93 -0
  1423. package/extensions/open-prose/skills/prose/lib/vm-improver.prose +243 -0
  1424. package/extensions/open-prose/skills/prose/primitives/session.md +593 -0
  1425. package/extensions/open-prose/skills/prose/prose.md +1237 -0
  1426. package/extensions/open-prose/skills/prose/state/filesystem.md +498 -0
  1427. package/extensions/open-prose/skills/prose/state/in-context.md +384 -0
  1428. package/extensions/open-prose/skills/prose/state/postgres.md +880 -0
  1429. package/extensions/open-prose/skills/prose/state/sqlite.md +574 -0
  1430. package/extensions/qwen-portal-auth/README.md +24 -0
  1431. package/extensions/qwen-portal-auth/index.ts +130 -0
  1432. package/extensions/qwen-portal-auth/oauth.ts +190 -0
  1433. package/extensions/qwen-portal-auth/openclaw.plugin.json +9 -0
  1434. package/extensions/signal/index.ts +17 -0
  1435. package/extensions/signal/node_modules/.bin/openclaw +21 -0
  1436. package/extensions/signal/openclaw.plugin.json +9 -0
  1437. package/extensions/signal/package.json +14 -0
  1438. package/extensions/signal/src/channel.ts +315 -0
  1439. package/extensions/signal/src/runtime.ts +14 -0
  1440. package/extensions/slack/index.ts +17 -0
  1441. package/extensions/slack/node_modules/.bin/openclaw +21 -0
  1442. package/extensions/slack/openclaw.plugin.json +9 -0
  1443. package/extensions/slack/package.json +14 -0
  1444. package/extensions/slack/src/channel.ts +604 -0
  1445. package/extensions/slack/src/runtime.ts +14 -0
  1446. package/extensions/telegram/index.ts +17 -0
  1447. package/extensions/telegram/node_modules/.bin/openclaw +21 -0
  1448. package/extensions/telegram/openclaw.plugin.json +9 -0
  1449. package/extensions/telegram/package.json +14 -0
  1450. package/extensions/telegram/src/channel.ts +482 -0
  1451. package/extensions/telegram/src/runtime.ts +14 -0
  1452. package/extensions/tlon/README.md +5 -0
  1453. package/extensions/tlon/index.ts +17 -0
  1454. package/extensions/tlon/node_modules/.bin/openclaw +21 -0
  1455. package/extensions/tlon/openclaw.plugin.json +9 -0
  1456. package/extensions/tlon/package.json +33 -0
  1457. package/extensions/tlon/src/channel.ts +392 -0
  1458. package/extensions/tlon/src/config-schema.test.ts +31 -0
  1459. package/extensions/tlon/src/config-schema.ts +43 -0
  1460. package/extensions/tlon/src/monitor/discovery.ts +76 -0
  1461. package/extensions/tlon/src/monitor/history.ts +90 -0
  1462. package/extensions/tlon/src/monitor/index.ts +553 -0
  1463. package/extensions/tlon/src/monitor/processed-messages.test.ts +23 -0
  1464. package/extensions/tlon/src/monitor/processed-messages.ts +46 -0
  1465. package/extensions/tlon/src/monitor/utils.ts +105 -0
  1466. package/extensions/tlon/src/onboarding.ts +214 -0
  1467. package/extensions/tlon/src/runtime.ts +14 -0
  1468. package/extensions/tlon/src/targets.ts +89 -0
  1469. package/extensions/tlon/src/types.ts +92 -0
  1470. package/extensions/tlon/src/urbit/auth.ts +18 -0
  1471. package/extensions/tlon/src/urbit/http-api.ts +38 -0
  1472. package/extensions/tlon/src/urbit/send.test.ts +38 -0
  1473. package/extensions/tlon/src/urbit/send.ts +131 -0
  1474. package/extensions/tlon/src/urbit/sse-client.test.ts +40 -0
  1475. package/extensions/tlon/src/urbit/sse-client.ts +395 -0
  1476. package/extensions/twitch/CHANGELOG.md +45 -0
  1477. package/extensions/twitch/README.md +89 -0
  1478. package/extensions/twitch/index.ts +20 -0
  1479. package/extensions/twitch/node_modules/.bin/openclaw +21 -0
  1480. package/extensions/twitch/openclaw.plugin.json +9 -0
  1481. package/extensions/twitch/package.json +20 -0
  1482. package/extensions/twitch/src/access-control.test.ts +489 -0
  1483. package/extensions/twitch/src/access-control.ts +166 -0
  1484. package/extensions/twitch/src/actions.ts +173 -0
  1485. package/extensions/twitch/src/client-manager-registry.ts +115 -0
  1486. package/extensions/twitch/src/config-schema.ts +82 -0
  1487. package/extensions/twitch/src/config.test.ts +87 -0
  1488. package/extensions/twitch/src/config.ts +116 -0
  1489. package/extensions/twitch/src/monitor.ts +261 -0
  1490. package/extensions/twitch/src/onboarding.test.ts +311 -0
  1491. package/extensions/twitch/src/onboarding.ts +417 -0
  1492. package/extensions/twitch/src/outbound.test.ts +373 -0
  1493. package/extensions/twitch/src/outbound.ts +184 -0
  1494. package/extensions/twitch/src/plugin.test.ts +39 -0
  1495. package/extensions/twitch/src/plugin.ts +274 -0
  1496. package/extensions/twitch/src/probe.test.ts +195 -0
  1497. package/extensions/twitch/src/probe.ts +120 -0
  1498. package/extensions/twitch/src/resolver.ts +137 -0
  1499. package/extensions/twitch/src/runtime.ts +14 -0
  1500. package/extensions/twitch/src/send.test.ts +289 -0
  1501. package/extensions/twitch/src/send.ts +136 -0
  1502. package/extensions/twitch/src/status.test.ts +270 -0
  1503. package/extensions/twitch/src/status.ts +178 -0
  1504. package/extensions/twitch/src/token.test.ts +171 -0
  1505. package/extensions/twitch/src/token.ts +91 -0
  1506. package/extensions/twitch/src/twitch-client.test.ts +589 -0
  1507. package/extensions/twitch/src/twitch-client.ts +277 -0
  1508. package/extensions/twitch/src/types.ts +141 -0
  1509. package/extensions/twitch/src/utils/markdown.ts +98 -0
  1510. package/extensions/twitch/src/utils/twitch.ts +78 -0
  1511. package/extensions/twitch/test/setup.ts +7 -0
  1512. package/extensions/voice-call/CHANGELOG.md +109 -0
  1513. package/extensions/voice-call/README.md +139 -0
  1514. package/extensions/voice-call/index.ts +493 -0
  1515. package/extensions/voice-call/node_modules/.bin/openclaw +21 -0
  1516. package/extensions/voice-call/openclaw.plugin.json +559 -0
  1517. package/extensions/voice-call/package.json +19 -0
  1518. package/extensions/voice-call/src/allowlist.ts +19 -0
  1519. package/extensions/voice-call/src/cli.ts +279 -0
  1520. package/extensions/voice-call/src/config.test.ts +234 -0
  1521. package/extensions/voice-call/src/config.ts +523 -0
  1522. package/extensions/voice-call/src/core-bridge.ts +159 -0
  1523. package/extensions/voice-call/src/manager/context.ts +21 -0
  1524. package/extensions/voice-call/src/manager/events.ts +188 -0
  1525. package/extensions/voice-call/src/manager/lookup.ts +35 -0
  1526. package/extensions/voice-call/src/manager/outbound.ts +275 -0
  1527. package/extensions/voice-call/src/manager/state.ts +48 -0
  1528. package/extensions/voice-call/src/manager/store.ts +91 -0
  1529. package/extensions/voice-call/src/manager/timers.ts +89 -0
  1530. package/extensions/voice-call/src/manager/twiml.ts +9 -0
  1531. package/extensions/voice-call/src/manager.test.ts +194 -0
  1532. package/extensions/voice-call/src/manager.ts +887 -0
  1533. package/extensions/voice-call/src/media-stream.test.ts +96 -0
  1534. package/extensions/voice-call/src/media-stream.ts +411 -0
  1535. package/extensions/voice-call/src/providers/base.ts +67 -0
  1536. package/extensions/voice-call/src/providers/index.ts +10 -0
  1537. package/extensions/voice-call/src/providers/mock.ts +165 -0
  1538. package/extensions/voice-call/src/providers/plivo.test.ts +27 -0
  1539. package/extensions/voice-call/src/providers/plivo.ts +515 -0
  1540. package/extensions/voice-call/src/providers/stt-openai-realtime.ts +311 -0
  1541. package/extensions/voice-call/src/providers/telnyx.ts +371 -0
  1542. package/extensions/voice-call/src/providers/tts-openai.ts +259 -0
  1543. package/extensions/voice-call/src/providers/twilio/api.ts +42 -0
  1544. package/extensions/voice-call/src/providers/twilio/webhook.ts +32 -0
  1545. package/extensions/voice-call/src/providers/twilio.test.ts +60 -0
  1546. package/extensions/voice-call/src/providers/twilio.ts +626 -0
  1547. package/extensions/voice-call/src/response-generator.ts +158 -0
  1548. package/extensions/voice-call/src/runtime.ts +212 -0
  1549. package/extensions/voice-call/src/telephony-audio.ts +90 -0
  1550. package/extensions/voice-call/src/telephony-tts.ts +104 -0
  1551. package/extensions/voice-call/src/tunnel.ts +314 -0
  1552. package/extensions/voice-call/src/types.ts +272 -0
  1553. package/extensions/voice-call/src/utils.ts +14 -0
  1554. package/extensions/voice-call/src/voice-mapping.ts +67 -0
  1555. package/extensions/voice-call/src/webhook-security.test.ts +377 -0
  1556. package/extensions/voice-call/src/webhook-security.ts +689 -0
  1557. package/extensions/voice-call/src/webhook.ts +491 -0
  1558. package/extensions/whatsapp/index.ts +17 -0
  1559. package/extensions/whatsapp/node_modules/.bin/openclaw +21 -0
  1560. package/extensions/whatsapp/openclaw.plugin.json +9 -0
  1561. package/extensions/whatsapp/package.json +14 -0
  1562. package/extensions/whatsapp/src/channel.ts +508 -0
  1563. package/extensions/whatsapp/src/runtime.ts +14 -0
  1564. package/extensions/zalo/CHANGELOG.md +89 -0
  1565. package/extensions/zalo/README.md +50 -0
  1566. package/extensions/zalo/index.ts +19 -0
  1567. package/extensions/zalo/node_modules/.bin/openclaw +21 -0
  1568. package/extensions/zalo/openclaw.plugin.json +9 -0
  1569. package/extensions/zalo/package.json +36 -0
  1570. package/extensions/zalo/src/accounts.ts +80 -0
  1571. package/extensions/zalo/src/actions.ts +67 -0
  1572. package/extensions/zalo/src/api.ts +208 -0
  1573. package/extensions/zalo/src/channel.directory.test.ts +43 -0
  1574. package/extensions/zalo/src/channel.ts +414 -0
  1575. package/extensions/zalo/src/config-schema.ts +24 -0
  1576. package/extensions/zalo/src/monitor.ts +753 -0
  1577. package/extensions/zalo/src/monitor.webhook.test.ts +73 -0
  1578. package/extensions/zalo/src/onboarding.ts +401 -0
  1579. package/extensions/zalo/src/probe.ts +46 -0
  1580. package/extensions/zalo/src/proxy.ts +21 -0
  1581. package/extensions/zalo/src/runtime.ts +14 -0
  1582. package/extensions/zalo/src/send.ts +124 -0
  1583. package/extensions/zalo/src/status-issues.ts +53 -0
  1584. package/extensions/zalo/src/token.ts +63 -0
  1585. package/extensions/zalo/src/types.ts +42 -0
  1586. package/extensions/zalouser/CHANGELOG.md +61 -0
  1587. package/extensions/zalouser/README.md +225 -0
  1588. package/extensions/zalouser/index.ts +31 -0
  1589. package/extensions/zalouser/node_modules/.bin/openclaw +21 -0
  1590. package/extensions/zalouser/openclaw.plugin.json +9 -0
  1591. package/extensions/zalouser/package.json +36 -0
  1592. package/extensions/zalouser/src/accounts.ts +135 -0
  1593. package/extensions/zalouser/src/channel.test.ts +18 -0
  1594. package/extensions/zalouser/src/channel.ts +686 -0
  1595. package/extensions/zalouser/src/config-schema.ts +27 -0
  1596. package/extensions/zalouser/src/monitor.ts +590 -0
  1597. package/extensions/zalouser/src/onboarding.ts +504 -0
  1598. package/extensions/zalouser/src/probe.ts +28 -0
  1599. package/extensions/zalouser/src/runtime.ts +14 -0
  1600. package/extensions/zalouser/src/send.ts +160 -0
  1601. package/extensions/zalouser/src/status-issues.test.ts +57 -0
  1602. package/extensions/zalouser/src/status-issues.ts +89 -0
  1603. package/extensions/zalouser/src/tool.ts +164 -0
  1604. package/extensions/zalouser/src/types.ts +108 -0
  1605. package/extensions/zalouser/src/zca.ts +202 -0
  1606. package/openclaw.mjs +14 -0
  1607. package/package.json +245 -0
  1608. package/skills/1password/SKILL.md +70 -0
  1609. package/skills/1password/references/cli-examples.md +29 -0
  1610. package/skills/1password/references/get-started.md +17 -0
  1611. package/skills/apple-notes/SKILL.md +77 -0
  1612. package/skills/apple-reminders/SKILL.md +96 -0
  1613. package/skills/bear-notes/SKILL.md +107 -0
  1614. package/skills/bird/SKILL.md +224 -0
  1615. package/skills/blogwatcher/SKILL.md +69 -0
  1616. package/skills/blucli/SKILL.md +47 -0
  1617. package/skills/bluebubbles/SKILL.md +131 -0
  1618. package/skills/camsnap/SKILL.md +45 -0
  1619. package/skills/canvas/SKILL.md +198 -0
  1620. package/skills/clawhub/SKILL.md +77 -0
  1621. package/skills/coding-agent/SKILL.md +284 -0
  1622. package/skills/discord/SKILL.md +578 -0
  1623. package/skills/eightctl/SKILL.md +50 -0
  1624. package/skills/food-order/SKILL.md +48 -0
  1625. package/skills/gemini/SKILL.md +43 -0
  1626. package/skills/ghostly-projects/SKILL.md +160 -0
  1627. package/skills/gifgrep/SKILL.md +79 -0
  1628. package/skills/github/SKILL.md +77 -0
  1629. package/skills/gog/SKILL.md +116 -0
  1630. package/skills/goplaces/SKILL.md +52 -0
  1631. package/skills/healthcheck/SKILL.md +245 -0
  1632. package/skills/himalaya/SKILL.md +257 -0
  1633. package/skills/himalaya/references/configuration.md +184 -0
  1634. package/skills/himalaya/references/message-composition.md +199 -0
  1635. package/skills/imsg/SKILL.md +74 -0
  1636. package/skills/linear/SKILL.md +111 -0
  1637. package/skills/linear/linear.sh +204 -0
  1638. package/skills/local-places/SERVER_README.md +101 -0
  1639. package/skills/local-places/SKILL.md +102 -0
  1640. package/skills/local-places/pyproject.toml +21 -0
  1641. package/skills/local-places/src/local_places/__init__.py +2 -0
  1642. package/skills/local-places/src/local_places/google_places.py +314 -0
  1643. package/skills/local-places/src/local_places/main.py +65 -0
  1644. package/skills/local-places/src/local_places/schemas.py +107 -0
  1645. package/skills/mcporter/SKILL.md +61 -0
  1646. package/skills/model-usage/SKILL.md +69 -0
  1647. package/skills/model-usage/references/codexbar-cli.md +33 -0
  1648. package/skills/model-usage/scripts/model_usage.py +310 -0
  1649. package/skills/nano-banana-pro/SKILL.md +58 -0
  1650. package/skills/nano-banana-pro/scripts/generate_image.py +184 -0
  1651. package/skills/nano-pdf/SKILL.md +38 -0
  1652. package/skills/notion/SKILL.md +172 -0
  1653. package/skills/obsidian/SKILL.md +81 -0
  1654. package/skills/openai-image-gen/SKILL.md +89 -0
  1655. package/skills/openai-image-gen/scripts/gen.py +240 -0
  1656. package/skills/openai-whisper/SKILL.md +38 -0
  1657. package/skills/openai-whisper-api/SKILL.md +52 -0
  1658. package/skills/openai-whisper-api/scripts/transcribe.sh +85 -0
  1659. package/skills/openhue/SKILL.md +51 -0
  1660. package/skills/oracle/SKILL.md +125 -0
  1661. package/skills/ordercli/SKILL.md +78 -0
  1662. package/skills/peekaboo/SKILL.md +190 -0
  1663. package/skills/sag/SKILL.md +87 -0
  1664. package/skills/session-logs/SKILL.md +115 -0
  1665. package/skills/sherpa-onnx-tts/SKILL.md +103 -0
  1666. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  1667. package/skills/skill-creator/SKILL.md +370 -0
  1668. package/skills/skill-creator/license.txt +202 -0
  1669. package/skills/skill-creator/scripts/init_skill.py +378 -0
  1670. package/skills/skill-creator/scripts/package_skill.py +111 -0
  1671. package/skills/skill-creator/scripts/quick_validate.py +101 -0
  1672. package/skills/slack/SKILL.md +144 -0
  1673. package/skills/songsee/SKILL.md +49 -0
  1674. package/skills/sonoscli/SKILL.md +46 -0
  1675. package/skills/spotify-player/SKILL.md +64 -0
  1676. package/skills/summarize/SKILL.md +87 -0
  1677. package/skills/things-mac/SKILL.md +86 -0
  1678. package/skills/tmux/SKILL.md +135 -0
  1679. package/skills/tmux/scripts/find-sessions.sh +112 -0
  1680. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  1681. package/skills/trello/SKILL.md +95 -0
  1682. package/skills/video-frames/SKILL.md +46 -0
  1683. package/skills/video-frames/scripts/frame.sh +81 -0
  1684. package/skills/voice-call/SKILL.md +45 -0
  1685. package/skills/wacli/SKILL.md +72 -0
  1686. package/skills/weather/SKILL.md +54 -0
@@ -0,0 +1,2543 @@
1
+ import { I as listThinkingLevelLabels, P as formatThinkingLevels, U as resolveResponseUsageMode, V as normalizeUsageDisplay } from "./pi-embedded-helpers-Dl8e5Rf8.js";
2
+ import { u as resolveGatewayPort } from "./paths-scjhy7N2.js";
3
+ import { H as parseAgentSessionKey, N as normalizeAgentId, P as normalizeMainKey, c as resolveDefaultAgentId, k as buildAgentMainSessionKey } from "./agent-scope-BbT4OG2N.js";
4
+ import { s as visibleWidth } from "./subsystem-CAq3uyo7.js";
5
+ import { i as loadConfig, j as VERSION } from "./config-BtSTwPcH.js";
6
+ import { m as GATEWAY_CLIENT_NAMES, p as GATEWAY_CLIENT_MODES } from "./message-channel-D6v_oPAg.js";
7
+ import { n as resolveToolDisplay, t as formatToolDetail } from "./tool-display-BEACy9rK.js";
8
+ import { a as extractContentFromMessage, c as formatContextUsageLine, d as resolveFinalAssistantText, i as composeThinkingAndContent, l as formatTokens, n as formatAge, o as extractTextFromMessage, p as formatTokenCount, r as asString, s as extractThinkingFromMessage, u as isCommandMessage, v as listChatCommands, y as listChatCommandsForConfig } from "./channel-summary-MCwBCa5y.js";
9
+ import { St as PROTOCOL_VERSION, t as GatewayClient } from "./client-DySXIFCA.js";
10
+ import chalk from "chalk";
11
+ import { spawn } from "node:child_process";
12
+ import { randomUUID } from "node:crypto";
13
+ import { Box, CombinedAutocompleteProvider, Container, Editor, Input, Key, Loader, Markdown, ProcessTerminal, SelectList, SettingsList, Spacer, TUI, Text, getEditorKeybindings, isKeyRelease, matchesKey, truncateToWidth } from "@mariozechner/pi-tui";
14
+ import { highlight, supportsLanguage } from "cli-highlight";
15
+
16
+ //#region src/tui/commands.ts
17
+ const VERBOSE_LEVELS = ["on", "off"];
18
+ const REASONING_LEVELS = ["on", "off"];
19
+ const ELEVATED_LEVELS = [
20
+ "on",
21
+ "off",
22
+ "ask",
23
+ "full"
24
+ ];
25
+ const ACTIVATION_LEVELS = ["mention", "always"];
26
+ const USAGE_FOOTER_LEVELS = [
27
+ "off",
28
+ "tokens",
29
+ "full"
30
+ ];
31
+ const COMMAND_ALIASES = { elev: "elevated" };
32
+ function parseCommand(input) {
33
+ const trimmed = input.replace(/^\//, "").trim();
34
+ if (!trimmed) return {
35
+ name: "",
36
+ args: ""
37
+ };
38
+ const [name, ...rest] = trimmed.split(/\s+/);
39
+ const normalized = name.toLowerCase();
40
+ return {
41
+ name: COMMAND_ALIASES[normalized] ?? normalized,
42
+ args: rest.join(" ").trim()
43
+ };
44
+ }
45
+ function getSlashCommands(options = {}) {
46
+ const thinkLevels = listThinkingLevelLabels(options.provider, options.model);
47
+ const commands = [
48
+ {
49
+ name: "help",
50
+ description: "Show slash command help"
51
+ },
52
+ {
53
+ name: "status",
54
+ description: "Show gateway status summary"
55
+ },
56
+ {
57
+ name: "agent",
58
+ description: "Switch agent (or open picker)"
59
+ },
60
+ {
61
+ name: "agents",
62
+ description: "Open agent picker"
63
+ },
64
+ {
65
+ name: "session",
66
+ description: "Switch session (or open picker)"
67
+ },
68
+ {
69
+ name: "sessions",
70
+ description: "Open session picker"
71
+ },
72
+ {
73
+ name: "model",
74
+ description: "Set model (or open picker)"
75
+ },
76
+ {
77
+ name: "models",
78
+ description: "Open model picker"
79
+ },
80
+ {
81
+ name: "think",
82
+ description: "Set thinking level",
83
+ getArgumentCompletions: (prefix) => thinkLevels.filter((v) => v.startsWith(prefix.toLowerCase())).map((value) => ({
84
+ value,
85
+ label: value
86
+ }))
87
+ },
88
+ {
89
+ name: "verbose",
90
+ description: "Set verbose on/off",
91
+ getArgumentCompletions: (prefix) => VERBOSE_LEVELS.filter((v) => v.startsWith(prefix.toLowerCase())).map((value) => ({
92
+ value,
93
+ label: value
94
+ }))
95
+ },
96
+ {
97
+ name: "reasoning",
98
+ description: "Set reasoning on/off",
99
+ getArgumentCompletions: (prefix) => REASONING_LEVELS.filter((v) => v.startsWith(prefix.toLowerCase())).map((value) => ({
100
+ value,
101
+ label: value
102
+ }))
103
+ },
104
+ {
105
+ name: "usage",
106
+ description: "Toggle per-response usage line",
107
+ getArgumentCompletions: (prefix) => USAGE_FOOTER_LEVELS.filter((v) => v.startsWith(prefix.toLowerCase())).map((value) => ({
108
+ value,
109
+ label: value
110
+ }))
111
+ },
112
+ {
113
+ name: "elevated",
114
+ description: "Set elevated on/off/ask/full",
115
+ getArgumentCompletions: (prefix) => ELEVATED_LEVELS.filter((v) => v.startsWith(prefix.toLowerCase())).map((value) => ({
116
+ value,
117
+ label: value
118
+ }))
119
+ },
120
+ {
121
+ name: "elev",
122
+ description: "Alias for /elevated",
123
+ getArgumentCompletions: (prefix) => ELEVATED_LEVELS.filter((v) => v.startsWith(prefix.toLowerCase())).map((value) => ({
124
+ value,
125
+ label: value
126
+ }))
127
+ },
128
+ {
129
+ name: "activation",
130
+ description: "Set group activation",
131
+ getArgumentCompletions: (prefix) => ACTIVATION_LEVELS.filter((v) => v.startsWith(prefix.toLowerCase())).map((value) => ({
132
+ value,
133
+ label: value
134
+ }))
135
+ },
136
+ {
137
+ name: "abort",
138
+ description: "Abort active run"
139
+ },
140
+ {
141
+ name: "new",
142
+ description: "Reset the session"
143
+ },
144
+ {
145
+ name: "reset",
146
+ description: "Reset the session"
147
+ },
148
+ {
149
+ name: "settings",
150
+ description: "Open settings"
151
+ },
152
+ {
153
+ name: "exit",
154
+ description: "Exit the TUI"
155
+ },
156
+ {
157
+ name: "quit",
158
+ description: "Exit the TUI"
159
+ }
160
+ ];
161
+ const seen = new Set(commands.map((command) => command.name));
162
+ const gatewayCommands = options.cfg ? listChatCommandsForConfig(options.cfg) : listChatCommands();
163
+ for (const command of gatewayCommands) {
164
+ const aliases = command.textAliases.length > 0 ? command.textAliases : [`/${command.key}`];
165
+ for (const alias of aliases) {
166
+ const name = alias.replace(/^\//, "").trim();
167
+ if (!name || seen.has(name)) continue;
168
+ seen.add(name);
169
+ commands.push({
170
+ name,
171
+ description: command.description
172
+ });
173
+ }
174
+ }
175
+ return commands;
176
+ }
177
+ function helpText(options = {}) {
178
+ return [
179
+ "Slash commands:",
180
+ "/help",
181
+ "/commands",
182
+ "/status",
183
+ "/agent <id> (or /agents)",
184
+ "/session <key> (or /sessions)",
185
+ "/model <provider/model> (or /models)",
186
+ `/think <${formatThinkingLevels(options.provider, options.model, "|")}>`,
187
+ "/verbose <on|off>",
188
+ "/reasoning <on|off>",
189
+ "/usage <off|tokens|full>",
190
+ "/elevated <on|off|ask|full>",
191
+ "/elev <on|off|ask|full>",
192
+ "/activation <mention|always>",
193
+ "/new or /reset",
194
+ "/abort",
195
+ "/settings",
196
+ "/exit"
197
+ ].join("\n");
198
+ }
199
+
200
+ //#endregion
201
+ //#region src/tui/theme/syntax-theme.ts
202
+ /**
203
+ * Syntax highlighting theme for code blocks.
204
+ * Uses chalk functions to style different token types.
205
+ */
206
+ function createSyntaxTheme(fallback) {
207
+ return {
208
+ keyword: chalk.hex("#C586C0"),
209
+ built_in: chalk.hex("#4EC9B0"),
210
+ type: chalk.hex("#4EC9B0"),
211
+ literal: chalk.hex("#569CD6"),
212
+ number: chalk.hex("#B5CEA8"),
213
+ string: chalk.hex("#CE9178"),
214
+ regexp: chalk.hex("#D16969"),
215
+ symbol: chalk.hex("#B5CEA8"),
216
+ class: chalk.hex("#4EC9B0"),
217
+ function: chalk.hex("#DCDCAA"),
218
+ title: chalk.hex("#DCDCAA"),
219
+ params: chalk.hex("#9CDCFE"),
220
+ comment: chalk.hex("#6A9955"),
221
+ doctag: chalk.hex("#608B4E"),
222
+ meta: chalk.hex("#9CDCFE"),
223
+ "meta-keyword": chalk.hex("#C586C0"),
224
+ "meta-string": chalk.hex("#CE9178"),
225
+ section: chalk.hex("#DCDCAA"),
226
+ tag: chalk.hex("#569CD6"),
227
+ name: chalk.hex("#9CDCFE"),
228
+ attr: chalk.hex("#9CDCFE"),
229
+ attribute: chalk.hex("#9CDCFE"),
230
+ variable: chalk.hex("#9CDCFE"),
231
+ bullet: chalk.hex("#D7BA7D"),
232
+ code: chalk.hex("#CE9178"),
233
+ emphasis: chalk.italic,
234
+ strong: chalk.bold,
235
+ formula: chalk.hex("#C586C0"),
236
+ link: chalk.hex("#4EC9B0"),
237
+ quote: chalk.hex("#6A9955"),
238
+ addition: chalk.hex("#B5CEA8"),
239
+ deletion: chalk.hex("#F44747"),
240
+ "selector-tag": chalk.hex("#D7BA7D"),
241
+ "selector-id": chalk.hex("#D7BA7D"),
242
+ "selector-class": chalk.hex("#D7BA7D"),
243
+ "selector-attr": chalk.hex("#D7BA7D"),
244
+ "selector-pseudo": chalk.hex("#D7BA7D"),
245
+ "template-tag": chalk.hex("#C586C0"),
246
+ "template-variable": chalk.hex("#9CDCFE"),
247
+ default: fallback
248
+ };
249
+ }
250
+
251
+ //#endregion
252
+ //#region src/tui/theme/theme.ts
253
+ const palette = {
254
+ text: "#E8E3D5",
255
+ dim: "#7B7F87",
256
+ accent: "#F6C453",
257
+ accentSoft: "#F2A65A",
258
+ border: "#3C414B",
259
+ userBg: "#2B2F36",
260
+ userText: "#F3EEE0",
261
+ systemText: "#9BA3B2",
262
+ toolPendingBg: "#1F2A2F",
263
+ toolSuccessBg: "#1E2D23",
264
+ toolErrorBg: "#2F1F1F",
265
+ toolTitle: "#F6C453",
266
+ toolOutput: "#E1DACB",
267
+ quote: "#8CC8FF",
268
+ quoteBorder: "#3B4D6B",
269
+ code: "#F0C987",
270
+ codeBlock: "#1E232A",
271
+ codeBorder: "#343A45",
272
+ link: "#7DD3A5",
273
+ error: "#F97066",
274
+ success: "#7DD3A5"
275
+ };
276
+ const fg = (hex) => (text) => chalk.hex(hex)(text);
277
+ const bg = (hex) => (text) => chalk.bgHex(hex)(text);
278
+ const syntaxTheme = createSyntaxTheme(fg(palette.code));
279
+ /**
280
+ * Highlight code with syntax coloring.
281
+ * Returns an array of lines with ANSI escape codes.
282
+ */
283
+ function highlightCode(code, lang) {
284
+ try {
285
+ return highlight(code, {
286
+ language: lang && supportsLanguage(lang) ? lang : void 0,
287
+ theme: syntaxTheme,
288
+ ignoreIllegals: true
289
+ }).split("\n");
290
+ } catch {
291
+ return code.split("\n").map((line) => fg(palette.code)(line));
292
+ }
293
+ }
294
+ const theme = {
295
+ fg: fg(palette.text),
296
+ dim: fg(palette.dim),
297
+ accent: fg(palette.accent),
298
+ accentSoft: fg(palette.accentSoft),
299
+ success: fg(palette.success),
300
+ error: fg(palette.error),
301
+ header: (text) => chalk.bold(fg(palette.accent)(text)),
302
+ system: fg(palette.systemText),
303
+ userBg: bg(palette.userBg),
304
+ userText: fg(palette.userText),
305
+ toolTitle: fg(palette.toolTitle),
306
+ toolOutput: fg(palette.toolOutput),
307
+ toolPendingBg: bg(palette.toolPendingBg),
308
+ toolSuccessBg: bg(palette.toolSuccessBg),
309
+ toolErrorBg: bg(palette.toolErrorBg),
310
+ border: fg(palette.border),
311
+ bold: (text) => chalk.bold(text),
312
+ italic: (text) => chalk.italic(text)
313
+ };
314
+ const markdownTheme = {
315
+ heading: (text) => chalk.bold(fg(palette.accent)(text)),
316
+ link: (text) => fg(palette.link)(text),
317
+ linkUrl: (text) => chalk.dim(text),
318
+ code: (text) => fg(palette.code)(text),
319
+ codeBlock: (text) => fg(palette.code)(text),
320
+ codeBlockBorder: (text) => fg(palette.codeBorder)(text),
321
+ quote: (text) => fg(palette.quote)(text),
322
+ quoteBorder: (text) => fg(palette.quoteBorder)(text),
323
+ hr: (text) => fg(palette.border)(text),
324
+ listBullet: (text) => fg(palette.accentSoft)(text),
325
+ bold: (text) => chalk.bold(text),
326
+ italic: (text) => chalk.italic(text),
327
+ strikethrough: (text) => chalk.strikethrough(text),
328
+ underline: (text) => chalk.underline(text),
329
+ highlightCode
330
+ };
331
+ const selectListTheme = {
332
+ selectedPrefix: (text) => fg(palette.accent)(text),
333
+ selectedText: (text) => chalk.bold(fg(palette.accent)(text)),
334
+ description: (text) => fg(palette.dim)(text),
335
+ scrollInfo: (text) => fg(palette.dim)(text),
336
+ noMatch: (text) => fg(palette.dim)(text)
337
+ };
338
+ const filterableSelectListTheme = {
339
+ ...selectListTheme,
340
+ filterLabel: (text) => fg(palette.dim)(text)
341
+ };
342
+ const settingsListTheme = {
343
+ label: (text, selected) => selected ? chalk.bold(fg(palette.accent)(text)) : fg(palette.text)(text),
344
+ value: (text, selected) => selected ? fg(palette.accentSoft)(text) : fg(palette.dim)(text),
345
+ description: (text) => fg(palette.systemText)(text),
346
+ cursor: fg(palette.accent)("→ "),
347
+ hint: (text) => fg(palette.dim)(text)
348
+ };
349
+ const editorTheme = {
350
+ borderColor: (text) => fg(palette.border)(text),
351
+ selectList: selectListTheme
352
+ };
353
+ const searchableSelectListTheme = {
354
+ selectedPrefix: (text) => fg(palette.accent)(text),
355
+ selectedText: (text) => chalk.bold(fg(palette.accent)(text)),
356
+ description: (text) => fg(palette.dim)(text),
357
+ scrollInfo: (text) => fg(palette.dim)(text),
358
+ noMatch: (text) => fg(palette.dim)(text),
359
+ searchPrompt: (text) => fg(palette.accentSoft)(text),
360
+ searchInput: (text) => fg(palette.text)(text),
361
+ matchHighlight: (text) => chalk.bold(fg(palette.accent)(text))
362
+ };
363
+
364
+ //#endregion
365
+ //#region src/tui/components/assistant-message.ts
366
+ var AssistantMessageComponent = class extends Container {
367
+ constructor(text) {
368
+ super();
369
+ this.body = new Markdown(text, 1, 0, markdownTheme, { color: (line) => theme.fg(line) });
370
+ this.addChild(new Spacer(1));
371
+ this.addChild(this.body);
372
+ }
373
+ setText(text) {
374
+ this.body.setText(text);
375
+ }
376
+ };
377
+
378
+ //#endregion
379
+ //#region src/tui/components/tool-execution.ts
380
+ const PREVIEW_LINES = 12;
381
+ function formatArgs(toolName, args) {
382
+ const detail = formatToolDetail(resolveToolDisplay({
383
+ name: toolName,
384
+ args
385
+ }));
386
+ if (detail) return detail;
387
+ if (!args || typeof args !== "object") return "";
388
+ try {
389
+ return JSON.stringify(args);
390
+ } catch {
391
+ return "";
392
+ }
393
+ }
394
+ function extractText(result) {
395
+ if (!result?.content) return "";
396
+ const lines = [];
397
+ for (const entry of result.content) if (entry.type === "text" && entry.text) lines.push(entry.text);
398
+ else if (entry.type === "image") {
399
+ const mime = entry.mimeType ?? "image";
400
+ const size = entry.bytes ? ` ${Math.round(entry.bytes / 1024)}kb` : "";
401
+ const omitted = entry.omitted ? " (omitted)" : "";
402
+ lines.push(`[${mime}${size}${omitted}]`);
403
+ }
404
+ return lines.join("\n").trim();
405
+ }
406
+ var ToolExecutionComponent = class extends Container {
407
+ constructor(toolName, args) {
408
+ super();
409
+ this.expanded = false;
410
+ this.isError = false;
411
+ this.isPartial = true;
412
+ this.toolName = toolName;
413
+ this.args = args;
414
+ this.box = new Box(1, 1, (line) => theme.toolPendingBg(line));
415
+ this.header = new Text("", 0, 0);
416
+ this.argsLine = new Text("", 0, 0);
417
+ this.output = new Markdown("", 0, 0, markdownTheme, { color: (line) => theme.toolOutput(line) });
418
+ this.addChild(new Spacer(1));
419
+ this.addChild(this.box);
420
+ this.box.addChild(this.header);
421
+ this.box.addChild(this.argsLine);
422
+ this.box.addChild(this.output);
423
+ this.refresh();
424
+ }
425
+ setArgs(args) {
426
+ this.args = args;
427
+ this.refresh();
428
+ }
429
+ setExpanded(expanded) {
430
+ this.expanded = expanded;
431
+ this.refresh();
432
+ }
433
+ setResult(result, opts) {
434
+ this.result = result;
435
+ this.isPartial = false;
436
+ this.isError = Boolean(opts?.isError);
437
+ this.refresh();
438
+ }
439
+ setPartialResult(result) {
440
+ this.result = result;
441
+ this.isPartial = true;
442
+ this.refresh();
443
+ }
444
+ refresh() {
445
+ const bg = this.isPartial ? theme.toolPendingBg : this.isError ? theme.toolErrorBg : theme.toolSuccessBg;
446
+ this.box.setBgFn((line) => bg(line));
447
+ const display = resolveToolDisplay({
448
+ name: this.toolName,
449
+ args: this.args
450
+ });
451
+ const title = `${display.emoji} ${display.label}${this.isPartial ? " (running)" : ""}`;
452
+ this.header.setText(theme.toolTitle(theme.bold(title)));
453
+ const argLine = formatArgs(this.toolName, this.args);
454
+ this.argsLine.setText(argLine ? theme.dim(argLine) : theme.dim(" "));
455
+ const text = extractText(this.result) || (this.isPartial ? "…" : "");
456
+ if (!this.expanded && text) {
457
+ const lines = text.split("\n");
458
+ const preview = lines.length > PREVIEW_LINES ? `${lines.slice(0, PREVIEW_LINES).join("\n")}\n…` : text;
459
+ this.output.setText(preview);
460
+ } else this.output.setText(text);
461
+ }
462
+ };
463
+
464
+ //#endregion
465
+ //#region src/tui/components/user-message.ts
466
+ var UserMessageComponent = class extends Container {
467
+ constructor(text) {
468
+ super();
469
+ this.body = new Markdown(text, 1, 1, markdownTheme, {
470
+ bgColor: (line) => theme.userBg(line),
471
+ color: (line) => theme.userText(line)
472
+ });
473
+ this.addChild(new Spacer(1));
474
+ this.addChild(this.body);
475
+ }
476
+ setText(text) {
477
+ this.body.setText(text);
478
+ }
479
+ };
480
+
481
+ //#endregion
482
+ //#region src/tui/components/chat-log.ts
483
+ var ChatLog = class extends Container {
484
+ constructor(..._args) {
485
+ super(..._args);
486
+ this.toolById = /* @__PURE__ */ new Map();
487
+ this.streamingRuns = /* @__PURE__ */ new Map();
488
+ this.toolsExpanded = false;
489
+ }
490
+ clearAll() {
491
+ this.clear();
492
+ this.toolById.clear();
493
+ this.streamingRuns.clear();
494
+ }
495
+ addSystem(text) {
496
+ this.addChild(new Spacer(1));
497
+ this.addChild(new Text(theme.system(text), 1, 0));
498
+ }
499
+ addUser(text) {
500
+ this.addChild(new UserMessageComponent(text));
501
+ }
502
+ resolveRunId(runId) {
503
+ return runId ?? "default";
504
+ }
505
+ startAssistant(text, runId) {
506
+ const component = new AssistantMessageComponent(text);
507
+ this.streamingRuns.set(this.resolveRunId(runId), component);
508
+ this.addChild(component);
509
+ return component;
510
+ }
511
+ updateAssistant(text, runId) {
512
+ const effectiveRunId = this.resolveRunId(runId);
513
+ const existing = this.streamingRuns.get(effectiveRunId);
514
+ if (!existing) {
515
+ this.startAssistant(text, runId);
516
+ return;
517
+ }
518
+ existing.setText(text);
519
+ }
520
+ finalizeAssistant(text, runId) {
521
+ const effectiveRunId = this.resolveRunId(runId);
522
+ const existing = this.streamingRuns.get(effectiveRunId);
523
+ if (existing) {
524
+ existing.setText(text);
525
+ this.streamingRuns.delete(effectiveRunId);
526
+ return;
527
+ }
528
+ this.addChild(new AssistantMessageComponent(text));
529
+ }
530
+ startTool(toolCallId, toolName, args) {
531
+ const existing = this.toolById.get(toolCallId);
532
+ if (existing) {
533
+ existing.setArgs(args);
534
+ return existing;
535
+ }
536
+ const component = new ToolExecutionComponent(toolName, args);
537
+ component.setExpanded(this.toolsExpanded);
538
+ this.toolById.set(toolCallId, component);
539
+ this.addChild(component);
540
+ return component;
541
+ }
542
+ updateToolArgs(toolCallId, args) {
543
+ const existing = this.toolById.get(toolCallId);
544
+ if (!existing) return;
545
+ existing.setArgs(args);
546
+ }
547
+ updateToolResult(toolCallId, result, opts) {
548
+ const existing = this.toolById.get(toolCallId);
549
+ if (!existing) return;
550
+ if (opts?.partial) {
551
+ existing.setPartialResult(result);
552
+ return;
553
+ }
554
+ existing.setResult(result, { isError: opts?.isError });
555
+ }
556
+ setToolsExpanded(expanded) {
557
+ this.toolsExpanded = expanded;
558
+ for (const tool of this.toolById.values()) tool.setExpanded(expanded);
559
+ }
560
+ };
561
+
562
+ //#endregion
563
+ //#region src/tui/components/custom-editor.ts
564
+ var CustomEditor = class extends Editor {
565
+ handleInput(data) {
566
+ if (matchesKey(data, Key.alt("enter")) && this.onAltEnter) {
567
+ this.onAltEnter();
568
+ return;
569
+ }
570
+ if (matchesKey(data, Key.ctrl("l")) && this.onCtrlL) {
571
+ this.onCtrlL();
572
+ return;
573
+ }
574
+ if (matchesKey(data, Key.ctrl("o")) && this.onCtrlO) {
575
+ this.onCtrlO();
576
+ return;
577
+ }
578
+ if (matchesKey(data, Key.ctrl("p")) && this.onCtrlP) {
579
+ this.onCtrlP();
580
+ return;
581
+ }
582
+ if (matchesKey(data, Key.ctrl("g")) && this.onCtrlG) {
583
+ this.onCtrlG();
584
+ return;
585
+ }
586
+ if (matchesKey(data, Key.ctrl("t")) && this.onCtrlT) {
587
+ this.onCtrlT();
588
+ return;
589
+ }
590
+ if (matchesKey(data, Key.shift("tab")) && this.onShiftTab) {
591
+ this.onShiftTab();
592
+ return;
593
+ }
594
+ if (matchesKey(data, Key.escape) && this.onEscape && !this.isShowingAutocomplete()) {
595
+ this.onEscape();
596
+ return;
597
+ }
598
+ if (matchesKey(data, Key.ctrl("c")) && this.onCtrlC) {
599
+ this.onCtrlC();
600
+ return;
601
+ }
602
+ if (matchesKey(data, Key.ctrl("d"))) {
603
+ if (this.getText().length === 0 && this.onCtrlD) this.onCtrlD();
604
+ return;
605
+ }
606
+ super.handleInput(data);
607
+ }
608
+ };
609
+
610
+ //#endregion
611
+ //#region src/tui/gateway-chat.ts
612
+ var GatewayChatClient = class {
613
+ constructor(opts) {
614
+ const resolved = resolveGatewayConnection(opts);
615
+ this.connection = resolved;
616
+ this.readyPromise = new Promise((resolve) => {
617
+ this.resolveReady = resolve;
618
+ });
619
+ this.client = new GatewayClient({
620
+ url: resolved.url,
621
+ token: resolved.token,
622
+ password: resolved.password,
623
+ clientName: GATEWAY_CLIENT_NAMES.GATEWAY_CLIENT,
624
+ clientDisplayName: "openclaw-tui",
625
+ clientVersion: VERSION,
626
+ platform: process.platform,
627
+ mode: GATEWAY_CLIENT_MODES.UI,
628
+ instanceId: randomUUID(),
629
+ minProtocol: PROTOCOL_VERSION,
630
+ maxProtocol: PROTOCOL_VERSION,
631
+ onHelloOk: (hello) => {
632
+ this.hello = hello;
633
+ this.resolveReady?.();
634
+ this.onConnected?.();
635
+ },
636
+ onEvent: (evt) => {
637
+ this.onEvent?.({
638
+ event: evt.event,
639
+ payload: evt.payload,
640
+ seq: evt.seq
641
+ });
642
+ },
643
+ onClose: (_code, reason) => {
644
+ this.onDisconnected?.(reason);
645
+ },
646
+ onGap: (info) => {
647
+ this.onGap?.(info);
648
+ }
649
+ });
650
+ }
651
+ start() {
652
+ this.client.start();
653
+ }
654
+ stop() {
655
+ this.client.stop();
656
+ }
657
+ async waitForReady() {
658
+ await this.readyPromise;
659
+ }
660
+ async sendChat(opts) {
661
+ const runId = randomUUID();
662
+ await this.client.request("chat.send", {
663
+ sessionKey: opts.sessionKey,
664
+ message: opts.message,
665
+ thinking: opts.thinking,
666
+ deliver: opts.deliver,
667
+ timeoutMs: opts.timeoutMs,
668
+ idempotencyKey: runId
669
+ });
670
+ return { runId };
671
+ }
672
+ async abortChat(opts) {
673
+ return await this.client.request("chat.abort", {
674
+ sessionKey: opts.sessionKey,
675
+ runId: opts.runId
676
+ });
677
+ }
678
+ async loadHistory(opts) {
679
+ return await this.client.request("chat.history", {
680
+ sessionKey: opts.sessionKey,
681
+ limit: opts.limit
682
+ });
683
+ }
684
+ async listSessions(opts) {
685
+ return await this.client.request("sessions.list", {
686
+ limit: opts?.limit,
687
+ activeMinutes: opts?.activeMinutes,
688
+ includeGlobal: opts?.includeGlobal,
689
+ includeUnknown: opts?.includeUnknown,
690
+ includeDerivedTitles: opts?.includeDerivedTitles,
691
+ includeLastMessage: opts?.includeLastMessage,
692
+ agentId: opts?.agentId
693
+ });
694
+ }
695
+ async listAgents() {
696
+ return await this.client.request("agents.list", {});
697
+ }
698
+ async patchSession(opts) {
699
+ return await this.client.request("sessions.patch", opts);
700
+ }
701
+ async resetSession(key) {
702
+ return await this.client.request("sessions.reset", { key });
703
+ }
704
+ async getStatus() {
705
+ return await this.client.request("status");
706
+ }
707
+ async listModels() {
708
+ const res = await this.client.request("models.list");
709
+ return Array.isArray(res?.models) ? res.models : [];
710
+ }
711
+ };
712
+ function resolveGatewayConnection(opts) {
713
+ const config = loadConfig();
714
+ const isRemoteMode = config.gateway?.mode === "remote";
715
+ const remote = isRemoteMode ? config.gateway?.remote : void 0;
716
+ const authToken = config.gateway?.auth?.token;
717
+ const localPort = resolveGatewayPort(config);
718
+ return {
719
+ url: (typeof opts.url === "string" && opts.url.trim().length > 0 ? opts.url.trim() : void 0) || (typeof remote?.url === "string" && remote.url.trim().length > 0 ? remote.url.trim() : void 0) || `ws://127.0.0.1:${localPort}`,
720
+ token: (typeof opts.token === "string" && opts.token.trim().length > 0 ? opts.token.trim() : void 0) || (isRemoteMode ? typeof remote?.token === "string" && remote.token.trim().length > 0 ? remote.token.trim() : void 0 : process.env.OPENCLAW_GATEWAY_TOKEN?.trim() || (typeof authToken === "string" && authToken.trim().length > 0 ? authToken.trim() : void 0)),
721
+ password: (typeof opts.password === "string" && opts.password.trim().length > 0 ? opts.password.trim() : void 0) || process.env.OPENCLAW_GATEWAY_PASSWORD?.trim() || (typeof remote?.password === "string" && remote.password.trim().length > 0 ? remote.password.trim() : void 0)
722
+ };
723
+ }
724
+
725
+ //#endregion
726
+ //#region src/utils/time-format.ts
727
+ function formatRelativeTime(timestamp) {
728
+ const diff = Date.now() - timestamp;
729
+ const seconds = Math.floor(diff / 1e3);
730
+ const minutes = Math.floor(seconds / 60);
731
+ const hours = Math.floor(minutes / 60);
732
+ const days = Math.floor(hours / 24);
733
+ if (seconds < 60) return "just now";
734
+ if (minutes < 60) return `${minutes}m ago`;
735
+ if (hours < 24) return `${hours}h ago`;
736
+ if (days === 1) return "Yesterday";
737
+ if (days < 7) return `${days}d ago`;
738
+ return new Date(timestamp).toLocaleDateString(void 0, {
739
+ month: "short",
740
+ day: "numeric"
741
+ });
742
+ }
743
+
744
+ //#endregion
745
+ //#region src/tui/components/fuzzy-filter.ts
746
+ /**
747
+ * Shared fuzzy filtering utilities for select list components.
748
+ */
749
+ /**
750
+ * Word boundary characters for matching.
751
+ */
752
+ const WORD_BOUNDARY_CHARS = /[\s\-_./:#@]/;
753
+ /**
754
+ * Check if position is at a word boundary.
755
+ */
756
+ function isWordBoundary(text, index) {
757
+ return index === 0 || WORD_BOUNDARY_CHARS.test(text[index - 1] ?? "");
758
+ }
759
+ /**
760
+ * Find index where query matches at a word boundary in text.
761
+ * Returns null if no match.
762
+ */
763
+ function findWordBoundaryIndex(text, query) {
764
+ if (!query) return null;
765
+ const textLower = text.toLowerCase();
766
+ const queryLower = query.toLowerCase();
767
+ const maxIndex = textLower.length - queryLower.length;
768
+ if (maxIndex < 0) return null;
769
+ for (let i = 0; i <= maxIndex; i++) if (textLower.startsWith(queryLower, i) && isWordBoundary(textLower, i)) return i;
770
+ return null;
771
+ }
772
+ /**
773
+ * Fuzzy match with pre-lowercased inputs (avoids toLowerCase on every keystroke).
774
+ * Returns score (lower = better) or null if no match.
775
+ */
776
+ function fuzzyMatchLower(queryLower, textLower) {
777
+ if (queryLower.length === 0) return 0;
778
+ if (queryLower.length > textLower.length) return null;
779
+ let queryIndex = 0;
780
+ let score = 0;
781
+ let lastMatchIndex = -1;
782
+ let consecutiveMatches = 0;
783
+ for (let i = 0; i < textLower.length && queryIndex < queryLower.length; i++) if (textLower[i] === queryLower[queryIndex]) {
784
+ const isAtWordBoundary = isWordBoundary(textLower, i);
785
+ if (lastMatchIndex === i - 1) {
786
+ consecutiveMatches++;
787
+ score -= consecutiveMatches * 5;
788
+ } else {
789
+ consecutiveMatches = 0;
790
+ if (lastMatchIndex >= 0) score += (i - lastMatchIndex - 1) * 2;
791
+ }
792
+ if (isAtWordBoundary) score -= 10;
793
+ score += i * .1;
794
+ lastMatchIndex = i;
795
+ queryIndex++;
796
+ }
797
+ return queryIndex < queryLower.length ? null : score;
798
+ }
799
+ /**
800
+ * Filter items using pre-lowercased searchTextLower field.
801
+ * Supports space-separated tokens (all must match).
802
+ */
803
+ function fuzzyFilterLower(items, queryLower) {
804
+ const trimmed = queryLower.trim();
805
+ if (!trimmed) return items;
806
+ const tokens = trimmed.split(/\s+/).filter((t) => t.length > 0);
807
+ if (tokens.length === 0) return items;
808
+ const results = [];
809
+ for (const item of items) {
810
+ const text = item.searchTextLower ?? "";
811
+ let totalScore = 0;
812
+ let allMatch = true;
813
+ for (const token of tokens) {
814
+ const score = fuzzyMatchLower(token, text);
815
+ if (score !== null) totalScore += score;
816
+ else {
817
+ allMatch = false;
818
+ break;
819
+ }
820
+ }
821
+ if (allMatch) results.push({
822
+ item,
823
+ score: totalScore
824
+ });
825
+ }
826
+ results.sort((a, b) => a.score - b.score);
827
+ return results.map((r) => r.item);
828
+ }
829
+ /**
830
+ * Prepare items for fuzzy filtering by pre-computing lowercase search text.
831
+ */
832
+ function prepareSearchItems(items) {
833
+ return items.map((item) => {
834
+ const parts = [];
835
+ if (item.label) parts.push(item.label);
836
+ if (item.description) parts.push(item.description);
837
+ if (item.searchText) parts.push(item.searchText);
838
+ return {
839
+ ...item,
840
+ searchTextLower: parts.join(" ").toLowerCase()
841
+ };
842
+ });
843
+ }
844
+
845
+ //#endregion
846
+ //#region src/tui/components/filterable-select-list.ts
847
+ /**
848
+ * Combines text input filtering with a select list.
849
+ * User types to filter, arrows/j/k to navigate, Enter to select, Escape to clear/cancel.
850
+ */
851
+ var FilterableSelectList = class {
852
+ constructor(items, maxVisible, theme) {
853
+ this.filterText = "";
854
+ this.allItems = prepareSearchItems(items);
855
+ this.maxVisible = maxVisible;
856
+ this.theme = theme;
857
+ this.input = new Input();
858
+ this.selectList = new SelectList(this.allItems, maxVisible, theme);
859
+ }
860
+ applyFilter() {
861
+ const queryLower = this.filterText.toLowerCase();
862
+ if (!queryLower.trim()) {
863
+ this.selectList = new SelectList(this.allItems, this.maxVisible, this.theme);
864
+ return;
865
+ }
866
+ this.selectList = new SelectList(fuzzyFilterLower(this.allItems, queryLower), this.maxVisible, this.theme);
867
+ }
868
+ invalidate() {
869
+ this.input.invalidate();
870
+ this.selectList.invalidate();
871
+ }
872
+ render(width) {
873
+ const lines = [];
874
+ const filterLabel = this.theme.filterLabel("Filter: ");
875
+ const inputText = this.input.render(width - 8)[0] ?? "";
876
+ lines.push(filterLabel + inputText);
877
+ lines.push(chalk.dim("─".repeat(Math.max(0, width))));
878
+ const listLines = this.selectList.render(width);
879
+ lines.push(...listLines);
880
+ return lines;
881
+ }
882
+ handleInput(keyData) {
883
+ const allowVimNav = !this.filterText.trim();
884
+ if (matchesKey(keyData, "up") || matchesKey(keyData, "ctrl+p") || allowVimNav && keyData === "k") {
885
+ this.selectList.handleInput("\x1B[A");
886
+ return;
887
+ }
888
+ if (matchesKey(keyData, "down") || matchesKey(keyData, "ctrl+n") || allowVimNav && keyData === "j") {
889
+ this.selectList.handleInput("\x1B[B");
890
+ return;
891
+ }
892
+ if (matchesKey(keyData, "enter")) {
893
+ const selected = this.selectList.getSelectedItem();
894
+ if (selected) this.onSelect?.(selected);
895
+ return;
896
+ }
897
+ if (getEditorKeybindings().matches(keyData, "selectCancel")) {
898
+ if (this.filterText) {
899
+ this.filterText = "";
900
+ this.input.setValue("");
901
+ this.applyFilter();
902
+ } else this.onCancel?.();
903
+ return;
904
+ }
905
+ const prevValue = this.input.getValue();
906
+ this.input.handleInput(keyData);
907
+ const newValue = this.input.getValue();
908
+ if (newValue !== prevValue) {
909
+ this.filterText = newValue;
910
+ this.applyFilter();
911
+ }
912
+ }
913
+ getSelectedItem() {
914
+ return this.selectList.getSelectedItem();
915
+ }
916
+ getFilterText() {
917
+ return this.filterText;
918
+ }
919
+ };
920
+
921
+ //#endregion
922
+ //#region src/tui/components/searchable-select-list.ts
923
+ /**
924
+ * A select list with a search input at the top for fuzzy filtering.
925
+ */
926
+ var SearchableSelectList = class {
927
+ constructor(items, maxVisible, theme) {
928
+ this.selectedIndex = 0;
929
+ this.regexCache = /* @__PURE__ */ new Map();
930
+ this.compareByScore = (a, b) => {
931
+ if (a.tier !== b.tier) return a.tier - b.tier;
932
+ if (a.score !== b.score) return a.score - b.score;
933
+ return this.getItemLabel(a.item).localeCompare(this.getItemLabel(b.item));
934
+ };
935
+ this.items = items;
936
+ this.filteredItems = items;
937
+ this.maxVisible = maxVisible;
938
+ this.theme = theme;
939
+ this.searchInput = new Input();
940
+ }
941
+ getCachedRegex(pattern) {
942
+ let regex = this.regexCache.get(pattern);
943
+ if (!regex) {
944
+ regex = new RegExp(this.escapeRegex(pattern), "gi");
945
+ this.regexCache.set(pattern, regex);
946
+ }
947
+ return regex;
948
+ }
949
+ updateFilter() {
950
+ const query = this.searchInput.getValue().trim();
951
+ if (!query) this.filteredItems = this.items;
952
+ else this.filteredItems = this.smartFilter(query);
953
+ this.selectedIndex = 0;
954
+ this.notifySelectionChange();
955
+ }
956
+ /**
957
+ * Smart filtering that prioritizes:
958
+ * 1. Exact substring match in label (highest priority)
959
+ * 2. Word-boundary prefix match in label
960
+ * 3. Exact substring in description
961
+ * 4. Fuzzy match (lowest priority)
962
+ */
963
+ smartFilter(query) {
964
+ const q = query.toLowerCase();
965
+ const scoredItems = [];
966
+ const fuzzyCandidates = [];
967
+ for (const item of this.items) {
968
+ const label = item.label.toLowerCase();
969
+ const desc = (item.description ?? "").toLowerCase();
970
+ const labelIndex = label.indexOf(q);
971
+ if (labelIndex !== -1) {
972
+ scoredItems.push({
973
+ item,
974
+ tier: 0,
975
+ score: labelIndex
976
+ });
977
+ continue;
978
+ }
979
+ const wordBoundaryIndex = findWordBoundaryIndex(label, q);
980
+ if (wordBoundaryIndex !== null) {
981
+ scoredItems.push({
982
+ item,
983
+ tier: 1,
984
+ score: wordBoundaryIndex
985
+ });
986
+ continue;
987
+ }
988
+ const descIndex = desc.indexOf(q);
989
+ if (descIndex !== -1) {
990
+ scoredItems.push({
991
+ item,
992
+ tier: 2,
993
+ score: descIndex
994
+ });
995
+ continue;
996
+ }
997
+ fuzzyCandidates.push(item);
998
+ }
999
+ scoredItems.sort(this.compareByScore);
1000
+ const fuzzyMatches = fuzzyFilterLower(prepareSearchItems(fuzzyCandidates), q);
1001
+ return [...scoredItems.map((s) => s.item), ...fuzzyMatches];
1002
+ }
1003
+ escapeRegex(str) {
1004
+ return str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
1005
+ }
1006
+ getItemLabel(item) {
1007
+ return item.label || item.value;
1008
+ }
1009
+ highlightMatch(text, query) {
1010
+ const tokens = query.trim().split(/\s+/).map((token) => token.toLowerCase()).filter((token) => token.length > 0);
1011
+ if (tokens.length === 0) return text;
1012
+ const uniqueTokens = Array.from(new Set(tokens)).toSorted((a, b) => b.length - a.length);
1013
+ let result = text;
1014
+ for (const token of uniqueTokens) {
1015
+ const regex = this.getCachedRegex(token);
1016
+ result = result.replace(regex, (match) => this.theme.matchHighlight(match));
1017
+ }
1018
+ return result;
1019
+ }
1020
+ setSelectedIndex(index) {
1021
+ this.selectedIndex = Math.max(0, Math.min(index, this.filteredItems.length - 1));
1022
+ }
1023
+ invalidate() {
1024
+ this.searchInput.invalidate();
1025
+ }
1026
+ render(width) {
1027
+ const lines = [];
1028
+ const prompt = this.theme.searchPrompt("search: ");
1029
+ const inputWidth = Math.max(1, width - visibleWidth(prompt));
1030
+ const inputText = this.searchInput.render(inputWidth)[0] ?? "";
1031
+ lines.push(`${prompt}${this.theme.searchInput(inputText)}`);
1032
+ lines.push("");
1033
+ const query = this.searchInput.getValue().trim();
1034
+ if (this.filteredItems.length === 0) {
1035
+ lines.push(this.theme.noMatch(" No matches"));
1036
+ return lines;
1037
+ }
1038
+ const startIndex = Math.max(0, Math.min(this.selectedIndex - Math.floor(this.maxVisible / 2), this.filteredItems.length - this.maxVisible));
1039
+ const endIndex = Math.min(startIndex + this.maxVisible, this.filteredItems.length);
1040
+ for (let i = startIndex; i < endIndex; i++) {
1041
+ const item = this.filteredItems[i];
1042
+ if (!item) continue;
1043
+ const isSelected = i === this.selectedIndex;
1044
+ lines.push(this.renderItemLine(item, isSelected, width, query));
1045
+ }
1046
+ if (this.filteredItems.length > this.maxVisible) {
1047
+ const scrollInfo = `${this.selectedIndex + 1}/${this.filteredItems.length}`;
1048
+ lines.push(this.theme.scrollInfo(` ${scrollInfo}`));
1049
+ }
1050
+ return lines;
1051
+ }
1052
+ renderItemLine(item, isSelected, width, query) {
1053
+ const prefix = isSelected ? "→ " : " ";
1054
+ const prefixWidth = prefix.length;
1055
+ const displayValue = this.getItemLabel(item);
1056
+ if (item.description && width > 40) {
1057
+ const truncatedValue = truncateToWidth(displayValue, Math.min(30, width - prefixWidth - 4), "");
1058
+ const valueText = this.highlightMatch(truncatedValue, query);
1059
+ const spacingWidth = Math.max(1, 32 - visibleWidth(valueText));
1060
+ const spacing = " ".repeat(spacingWidth);
1061
+ const remainingWidth = width - (prefixWidth + visibleWidth(valueText) + spacing.length) - 2;
1062
+ if (remainingWidth > 10) {
1063
+ const truncatedDesc = truncateToWidth(item.description, remainingWidth, "");
1064
+ const highlightedDesc = this.highlightMatch(truncatedDesc, query);
1065
+ const line = `${prefix}${valueText}${spacing}${isSelected ? highlightedDesc : this.theme.description(highlightedDesc)}`;
1066
+ return isSelected ? this.theme.selectedText(line) : line;
1067
+ }
1068
+ }
1069
+ const truncatedValue = truncateToWidth(displayValue, width - prefixWidth - 2, "");
1070
+ const line = `${prefix}${this.highlightMatch(truncatedValue, query)}`;
1071
+ return isSelected ? this.theme.selectedText(line) : line;
1072
+ }
1073
+ handleInput(keyData) {
1074
+ if (isKeyRelease(keyData)) return;
1075
+ const allowVimNav = !this.searchInput.getValue().trim();
1076
+ if (matchesKey(keyData, "up") || matchesKey(keyData, "ctrl+p") || allowVimNav && keyData === "k") {
1077
+ this.selectedIndex = Math.max(0, this.selectedIndex - 1);
1078
+ this.notifySelectionChange();
1079
+ return;
1080
+ }
1081
+ if (matchesKey(keyData, "down") || matchesKey(keyData, "ctrl+n") || allowVimNav && keyData === "j") {
1082
+ this.selectedIndex = Math.min(this.filteredItems.length - 1, this.selectedIndex + 1);
1083
+ this.notifySelectionChange();
1084
+ return;
1085
+ }
1086
+ if (matchesKey(keyData, "enter")) {
1087
+ const item = this.filteredItems[this.selectedIndex];
1088
+ if (item && this.onSelect) this.onSelect(item);
1089
+ return;
1090
+ }
1091
+ if (getEditorKeybindings().matches(keyData, "selectCancel")) {
1092
+ if (this.onCancel) this.onCancel();
1093
+ return;
1094
+ }
1095
+ const prevValue = this.searchInput.getValue();
1096
+ this.searchInput.handleInput(keyData);
1097
+ if (prevValue !== this.searchInput.getValue()) this.updateFilter();
1098
+ }
1099
+ notifySelectionChange() {
1100
+ const item = this.filteredItems[this.selectedIndex];
1101
+ if (item && this.onSelectionChange) this.onSelectionChange(item);
1102
+ }
1103
+ getSelectedItem() {
1104
+ return this.filteredItems[this.selectedIndex] ?? null;
1105
+ }
1106
+ };
1107
+
1108
+ //#endregion
1109
+ //#region src/tui/components/selectors.ts
1110
+ function createSearchableSelectList(items, maxVisible = 7) {
1111
+ return new SearchableSelectList(items, maxVisible, searchableSelectListTheme);
1112
+ }
1113
+ function createFilterableSelectList(items, maxVisible = 7) {
1114
+ return new FilterableSelectList(items, maxVisible, filterableSelectListTheme);
1115
+ }
1116
+ function createSettingsList(items, onChange, onCancel, maxVisible = 7) {
1117
+ return new SettingsList(items, maxVisible, settingsListTheme, onChange, onCancel);
1118
+ }
1119
+
1120
+ //#endregion
1121
+ //#region src/tui/tui-status-summary.ts
1122
+ function formatStatusSummary(summary) {
1123
+ const lines = [];
1124
+ lines.push("Gateway status");
1125
+ if (!summary.linkChannel) lines.push("Link channel: unknown");
1126
+ else {
1127
+ const linkLabel = summary.linkChannel.label ?? "Link channel";
1128
+ const linked = summary.linkChannel.linked === true;
1129
+ const authAge = linked && typeof summary.linkChannel.authAgeMs === "number" ? ` (last refreshed ${formatAge(summary.linkChannel.authAgeMs)})` : "";
1130
+ lines.push(`${linkLabel}: ${linked ? "linked" : "not linked"}${authAge}`);
1131
+ }
1132
+ const providerSummary = Array.isArray(summary.providerSummary) ? summary.providerSummary : [];
1133
+ if (providerSummary.length > 0) {
1134
+ lines.push("");
1135
+ lines.push("System:");
1136
+ for (const line of providerSummary) lines.push(` ${line}`);
1137
+ }
1138
+ const heartbeatAgents = summary.heartbeat?.agents ?? [];
1139
+ if (heartbeatAgents.length > 0) {
1140
+ const heartbeatParts = heartbeatAgents.map((agent) => {
1141
+ const agentId = agent.agentId ?? "unknown";
1142
+ if (!agent.enabled || !agent.everyMs) return `disabled (${agentId})`;
1143
+ return `${agent.every ?? "unknown"} (${agentId})`;
1144
+ });
1145
+ lines.push("");
1146
+ lines.push(`Heartbeat: ${heartbeatParts.join(", ")}`);
1147
+ }
1148
+ const sessionPaths = summary.sessions?.paths ?? [];
1149
+ if (sessionPaths.length === 1) lines.push(`Session store: ${sessionPaths[0]}`);
1150
+ else if (sessionPaths.length > 1) lines.push(`Session stores: ${sessionPaths.length}`);
1151
+ const defaults = summary.sessions?.defaults;
1152
+ const defaultModel = defaults?.model ?? "unknown";
1153
+ const defaultCtx = typeof defaults?.contextTokens === "number" ? ` (${formatTokenCount(defaults.contextTokens)} ctx)` : "";
1154
+ lines.push(`Default model: ${defaultModel}${defaultCtx}`);
1155
+ const sessionCount = summary.sessions?.count ?? 0;
1156
+ lines.push(`Active sessions: ${sessionCount}`);
1157
+ const recent = Array.isArray(summary.sessions?.recent) ? summary.sessions?.recent : [];
1158
+ if (recent.length > 0) {
1159
+ lines.push("Recent sessions:");
1160
+ for (const entry of recent) {
1161
+ const ageLabel = typeof entry.age === "number" ? formatAge(entry.age) : "no activity";
1162
+ const model = entry.model ?? "unknown";
1163
+ const usage = formatContextUsageLine({
1164
+ total: entry.totalTokens ?? null,
1165
+ context: entry.contextTokens ?? null,
1166
+ remaining: entry.remainingTokens ?? null,
1167
+ percent: entry.percentUsed ?? null
1168
+ });
1169
+ const flags = entry.flags?.length ? ` | flags: ${entry.flags.join(", ")}` : "";
1170
+ lines.push(`- ${entry.key}${entry.kind ? ` [${entry.kind}]` : ""} | ${ageLabel} | model ${model} | ${usage}${flags}`);
1171
+ }
1172
+ }
1173
+ const queued = Array.isArray(summary.queuedSystemEvents) ? summary.queuedSystemEvents : [];
1174
+ if (queued.length > 0) {
1175
+ const preview = queued.slice(0, 3).join(" | ");
1176
+ lines.push(`Queued system events (${queued.length}): ${preview}`);
1177
+ }
1178
+ return lines;
1179
+ }
1180
+
1181
+ //#endregion
1182
+ //#region src/tui/tui-command-handlers.ts
1183
+ function createCommandHandlers(context) {
1184
+ const { client, chatLog, tui, opts, state, deliverDefault, openOverlay, closeOverlay, refreshSessionInfo, loadHistory, setSession, refreshAgents, abortActive, setActivityStatus, formatSessionKey } = context;
1185
+ const setAgent = async (id) => {
1186
+ state.currentAgentId = normalizeAgentId(id);
1187
+ await setSession("");
1188
+ };
1189
+ const openModelSelector = async () => {
1190
+ try {
1191
+ const models = await client.listModels();
1192
+ if (models.length === 0) {
1193
+ chatLog.addSystem("no models available");
1194
+ tui.requestRender();
1195
+ return;
1196
+ }
1197
+ const selector = createSearchableSelectList(models.map((model) => ({
1198
+ value: `${model.provider}/${model.id}`,
1199
+ label: `${model.provider}/${model.id}`,
1200
+ description: model.name && model.name !== model.id ? model.name : ""
1201
+ })), 9);
1202
+ selector.onSelect = (item) => {
1203
+ (async () => {
1204
+ try {
1205
+ await client.patchSession({
1206
+ key: state.currentSessionKey,
1207
+ model: item.value
1208
+ });
1209
+ chatLog.addSystem(`model set to ${item.value}`);
1210
+ await refreshSessionInfo();
1211
+ } catch (err) {
1212
+ chatLog.addSystem(`model set failed: ${String(err)}`);
1213
+ }
1214
+ closeOverlay();
1215
+ tui.requestRender();
1216
+ })();
1217
+ };
1218
+ selector.onCancel = () => {
1219
+ closeOverlay();
1220
+ tui.requestRender();
1221
+ };
1222
+ openOverlay(selector);
1223
+ tui.requestRender();
1224
+ } catch (err) {
1225
+ chatLog.addSystem(`model list failed: ${String(err)}`);
1226
+ tui.requestRender();
1227
+ }
1228
+ };
1229
+ const openAgentSelector = async () => {
1230
+ await refreshAgents();
1231
+ if (state.agents.length === 0) {
1232
+ chatLog.addSystem("no agents found");
1233
+ tui.requestRender();
1234
+ return;
1235
+ }
1236
+ const selector = createSearchableSelectList(state.agents.map((agent) => ({
1237
+ value: agent.id,
1238
+ label: agent.name ? `${agent.id} (${agent.name})` : agent.id,
1239
+ description: agent.id === state.agentDefaultId ? "default" : ""
1240
+ })), 9);
1241
+ selector.onSelect = (item) => {
1242
+ (async () => {
1243
+ closeOverlay();
1244
+ await setAgent(item.value);
1245
+ tui.requestRender();
1246
+ })();
1247
+ };
1248
+ selector.onCancel = () => {
1249
+ closeOverlay();
1250
+ tui.requestRender();
1251
+ };
1252
+ openOverlay(selector);
1253
+ tui.requestRender();
1254
+ };
1255
+ const openSessionSelector = async () => {
1256
+ try {
1257
+ const selector = createFilterableSelectList((await client.listSessions({
1258
+ includeGlobal: false,
1259
+ includeUnknown: false,
1260
+ includeDerivedTitles: true,
1261
+ includeLastMessage: true,
1262
+ agentId: state.currentAgentId
1263
+ })).sessions.map((session) => {
1264
+ const title = session.derivedTitle ?? session.displayName;
1265
+ const formattedKey = formatSessionKey(session.key);
1266
+ const label = title && title !== formattedKey ? `${title} (${formattedKey})` : formattedKey;
1267
+ const timePart = session.updatedAt ? formatRelativeTime(session.updatedAt) : "";
1268
+ const preview = session.lastMessagePreview?.replace(/\s+/g, " ").trim();
1269
+ const description = timePart && preview ? `${timePart} · ${preview}` : preview ?? timePart;
1270
+ return {
1271
+ value: session.key,
1272
+ label,
1273
+ description,
1274
+ searchText: [
1275
+ session.displayName,
1276
+ session.label,
1277
+ session.subject,
1278
+ session.sessionId,
1279
+ session.key,
1280
+ session.lastMessagePreview
1281
+ ].filter(Boolean).join(" ")
1282
+ };
1283
+ }), 9);
1284
+ selector.onSelect = (item) => {
1285
+ (async () => {
1286
+ closeOverlay();
1287
+ await setSession(item.value);
1288
+ tui.requestRender();
1289
+ })();
1290
+ };
1291
+ selector.onCancel = () => {
1292
+ closeOverlay();
1293
+ tui.requestRender();
1294
+ };
1295
+ openOverlay(selector);
1296
+ tui.requestRender();
1297
+ } catch (err) {
1298
+ chatLog.addSystem(`sessions list failed: ${String(err)}`);
1299
+ tui.requestRender();
1300
+ }
1301
+ };
1302
+ const openSettings = () => {
1303
+ openOverlay(createSettingsList([{
1304
+ id: "tools",
1305
+ label: "Tool output",
1306
+ currentValue: state.toolsExpanded ? "expanded" : "collapsed",
1307
+ values: ["collapsed", "expanded"]
1308
+ }, {
1309
+ id: "thinking",
1310
+ label: "Show thinking",
1311
+ currentValue: state.showThinking ? "on" : "off",
1312
+ values: ["off", "on"]
1313
+ }], (id, value) => {
1314
+ if (id === "tools") {
1315
+ state.toolsExpanded = value === "expanded";
1316
+ chatLog.setToolsExpanded(state.toolsExpanded);
1317
+ }
1318
+ if (id === "thinking") {
1319
+ state.showThinking = value === "on";
1320
+ loadHistory();
1321
+ }
1322
+ tui.requestRender();
1323
+ }, () => {
1324
+ closeOverlay();
1325
+ tui.requestRender();
1326
+ }));
1327
+ tui.requestRender();
1328
+ };
1329
+ const handleCommand = async (raw) => {
1330
+ const { name, args } = parseCommand(raw);
1331
+ if (!name) return;
1332
+ switch (name) {
1333
+ case "help":
1334
+ chatLog.addSystem(helpText({
1335
+ provider: state.sessionInfo.modelProvider,
1336
+ model: state.sessionInfo.model
1337
+ }));
1338
+ break;
1339
+ case "status":
1340
+ try {
1341
+ const status = await client.getStatus();
1342
+ if (typeof status === "string") {
1343
+ chatLog.addSystem(status);
1344
+ break;
1345
+ }
1346
+ if (status && typeof status === "object") {
1347
+ const lines = formatStatusSummary(status);
1348
+ for (const line of lines) chatLog.addSystem(line);
1349
+ break;
1350
+ }
1351
+ chatLog.addSystem("status: unknown response");
1352
+ } catch (err) {
1353
+ chatLog.addSystem(`status failed: ${String(err)}`);
1354
+ }
1355
+ break;
1356
+ case "agent":
1357
+ if (!args) await openAgentSelector();
1358
+ else await setAgent(args);
1359
+ break;
1360
+ case "agents":
1361
+ await openAgentSelector();
1362
+ break;
1363
+ case "session":
1364
+ if (!args) await openSessionSelector();
1365
+ else await setSession(args);
1366
+ break;
1367
+ case "sessions":
1368
+ await openSessionSelector();
1369
+ break;
1370
+ case "model":
1371
+ if (!args) await openModelSelector();
1372
+ else try {
1373
+ await client.patchSession({
1374
+ key: state.currentSessionKey,
1375
+ model: args
1376
+ });
1377
+ chatLog.addSystem(`model set to ${args}`);
1378
+ await refreshSessionInfo();
1379
+ } catch (err) {
1380
+ chatLog.addSystem(`model set failed: ${String(err)}`);
1381
+ }
1382
+ break;
1383
+ case "models":
1384
+ await openModelSelector();
1385
+ break;
1386
+ case "think":
1387
+ if (!args) {
1388
+ const levels = formatThinkingLevels(state.sessionInfo.modelProvider, state.sessionInfo.model, "|");
1389
+ chatLog.addSystem(`usage: /think <${levels}>`);
1390
+ break;
1391
+ }
1392
+ try {
1393
+ await client.patchSession({
1394
+ key: state.currentSessionKey,
1395
+ thinkingLevel: args
1396
+ });
1397
+ chatLog.addSystem(`thinking set to ${args}`);
1398
+ await refreshSessionInfo();
1399
+ } catch (err) {
1400
+ chatLog.addSystem(`think failed: ${String(err)}`);
1401
+ }
1402
+ break;
1403
+ case "verbose":
1404
+ if (!args) {
1405
+ chatLog.addSystem("usage: /verbose <on|off>");
1406
+ break;
1407
+ }
1408
+ try {
1409
+ await client.patchSession({
1410
+ key: state.currentSessionKey,
1411
+ verboseLevel: args
1412
+ });
1413
+ chatLog.addSystem(`verbose set to ${args}`);
1414
+ await refreshSessionInfo();
1415
+ } catch (err) {
1416
+ chatLog.addSystem(`verbose failed: ${String(err)}`);
1417
+ }
1418
+ break;
1419
+ case "reasoning":
1420
+ if (!args) {
1421
+ chatLog.addSystem("usage: /reasoning <on|off>");
1422
+ break;
1423
+ }
1424
+ try {
1425
+ await client.patchSession({
1426
+ key: state.currentSessionKey,
1427
+ reasoningLevel: args
1428
+ });
1429
+ chatLog.addSystem(`reasoning set to ${args}`);
1430
+ await refreshSessionInfo();
1431
+ } catch (err) {
1432
+ chatLog.addSystem(`reasoning failed: ${String(err)}`);
1433
+ }
1434
+ break;
1435
+ case "usage": {
1436
+ const normalized = args ? normalizeUsageDisplay(args) : void 0;
1437
+ if (args && !normalized) {
1438
+ chatLog.addSystem("usage: /usage <off|tokens|full>");
1439
+ break;
1440
+ }
1441
+ const currentRaw = state.sessionInfo.responseUsage;
1442
+ const current = resolveResponseUsageMode(currentRaw);
1443
+ const next = normalized ?? (current === "off" ? "tokens" : current === "tokens" ? "full" : "off");
1444
+ try {
1445
+ await client.patchSession({
1446
+ key: state.currentSessionKey,
1447
+ responseUsage: next === "off" ? null : next
1448
+ });
1449
+ chatLog.addSystem(`usage footer: ${next}`);
1450
+ await refreshSessionInfo();
1451
+ } catch (err) {
1452
+ chatLog.addSystem(`usage failed: ${String(err)}`);
1453
+ }
1454
+ break;
1455
+ }
1456
+ case "elevated":
1457
+ if (!args) {
1458
+ chatLog.addSystem("usage: /elevated <on|off|ask|full>");
1459
+ break;
1460
+ }
1461
+ if (![
1462
+ "on",
1463
+ "off",
1464
+ "ask",
1465
+ "full"
1466
+ ].includes(args)) {
1467
+ chatLog.addSystem("usage: /elevated <on|off|ask|full>");
1468
+ break;
1469
+ }
1470
+ try {
1471
+ await client.patchSession({
1472
+ key: state.currentSessionKey,
1473
+ elevatedLevel: args
1474
+ });
1475
+ chatLog.addSystem(`elevated set to ${args}`);
1476
+ await refreshSessionInfo();
1477
+ } catch (err) {
1478
+ chatLog.addSystem(`elevated failed: ${String(err)}`);
1479
+ }
1480
+ break;
1481
+ case "activation":
1482
+ if (!args) {
1483
+ chatLog.addSystem("usage: /activation <mention|always>");
1484
+ break;
1485
+ }
1486
+ try {
1487
+ await client.patchSession({
1488
+ key: state.currentSessionKey,
1489
+ groupActivation: args === "always" ? "always" : "mention"
1490
+ });
1491
+ chatLog.addSystem(`activation set to ${args}`);
1492
+ await refreshSessionInfo();
1493
+ } catch (err) {
1494
+ chatLog.addSystem(`activation failed: ${String(err)}`);
1495
+ }
1496
+ break;
1497
+ case "new":
1498
+ case "reset":
1499
+ try {
1500
+ state.sessionInfo.inputTokens = null;
1501
+ state.sessionInfo.outputTokens = null;
1502
+ state.sessionInfo.totalTokens = null;
1503
+ tui.requestRender();
1504
+ await client.resetSession(state.currentSessionKey);
1505
+ chatLog.addSystem(`session ${state.currentSessionKey} reset`);
1506
+ await loadHistory();
1507
+ } catch (err) {
1508
+ chatLog.addSystem(`reset failed: ${String(err)}`);
1509
+ }
1510
+ break;
1511
+ case "abort":
1512
+ await abortActive();
1513
+ break;
1514
+ case "settings":
1515
+ openSettings();
1516
+ break;
1517
+ case "exit":
1518
+ case "quit":
1519
+ client.stop();
1520
+ tui.stop();
1521
+ process.exit(0);
1522
+ break;
1523
+ default:
1524
+ await sendMessage(raw);
1525
+ break;
1526
+ }
1527
+ tui.requestRender();
1528
+ };
1529
+ const sendMessage = async (text) => {
1530
+ try {
1531
+ chatLog.addUser(text);
1532
+ tui.requestRender();
1533
+ setActivityStatus("sending");
1534
+ const { runId } = await client.sendChat({
1535
+ sessionKey: state.currentSessionKey,
1536
+ message: text,
1537
+ thinking: opts.thinking,
1538
+ deliver: deliverDefault,
1539
+ timeoutMs: opts.timeoutMs
1540
+ });
1541
+ state.activeChatRunId = runId;
1542
+ setActivityStatus("waiting");
1543
+ } catch (err) {
1544
+ chatLog.addSystem(`send failed: ${String(err)}`);
1545
+ setActivityStatus("error");
1546
+ }
1547
+ tui.requestRender();
1548
+ };
1549
+ return {
1550
+ handleCommand,
1551
+ sendMessage,
1552
+ openModelSelector,
1553
+ openAgentSelector,
1554
+ openSessionSelector,
1555
+ openSettings,
1556
+ setAgent
1557
+ };
1558
+ }
1559
+
1560
+ //#endregion
1561
+ //#region src/tui/tui-stream-assembler.ts
1562
+ var TuiStreamAssembler = class {
1563
+ constructor() {
1564
+ this.runs = /* @__PURE__ */ new Map();
1565
+ }
1566
+ getOrCreateRun(runId) {
1567
+ let state = this.runs.get(runId);
1568
+ if (!state) {
1569
+ state = {
1570
+ thinkingText: "",
1571
+ contentText: "",
1572
+ displayText: ""
1573
+ };
1574
+ this.runs.set(runId, state);
1575
+ }
1576
+ return state;
1577
+ }
1578
+ updateRunState(state, message, showThinking) {
1579
+ const thinkingText = extractThinkingFromMessage(message);
1580
+ const contentText = extractContentFromMessage(message);
1581
+ if (thinkingText) state.thinkingText = thinkingText;
1582
+ if (contentText) state.contentText = contentText;
1583
+ state.displayText = composeThinkingAndContent({
1584
+ thinkingText: state.thinkingText,
1585
+ contentText: state.contentText,
1586
+ showThinking
1587
+ });
1588
+ }
1589
+ ingestDelta(runId, message, showThinking) {
1590
+ const state = this.getOrCreateRun(runId);
1591
+ const previousDisplayText = state.displayText;
1592
+ this.updateRunState(state, message, showThinking);
1593
+ if (!state.displayText || state.displayText === previousDisplayText) return null;
1594
+ return state.displayText;
1595
+ }
1596
+ finalize(runId, message, showThinking) {
1597
+ const state = this.getOrCreateRun(runId);
1598
+ this.updateRunState(state, message, showThinking);
1599
+ const finalComposed = state.displayText;
1600
+ const finalText = resolveFinalAssistantText({
1601
+ finalText: finalComposed,
1602
+ streamedText: state.displayText
1603
+ });
1604
+ this.runs.delete(runId);
1605
+ return finalText;
1606
+ }
1607
+ drop(runId) {
1608
+ this.runs.delete(runId);
1609
+ }
1610
+ };
1611
+
1612
+ //#endregion
1613
+ //#region src/tui/tui-event-handlers.ts
1614
+ function createEventHandlers(context) {
1615
+ const { chatLog, tui, state, setActivityStatus, refreshSessionInfo } = context;
1616
+ const finalizedRuns = /* @__PURE__ */ new Map();
1617
+ const sessionRuns = /* @__PURE__ */ new Map();
1618
+ let streamAssembler = new TuiStreamAssembler();
1619
+ let lastSessionKey = state.currentSessionKey;
1620
+ const pruneRunMap = (runs) => {
1621
+ if (runs.size <= 200) return;
1622
+ const keepUntil = Date.now() - 600 * 1e3;
1623
+ for (const [key, ts] of runs) {
1624
+ if (runs.size <= 150) break;
1625
+ if (ts < keepUntil) runs.delete(key);
1626
+ }
1627
+ if (runs.size > 200) for (const key of runs.keys()) {
1628
+ runs.delete(key);
1629
+ if (runs.size <= 150) break;
1630
+ }
1631
+ };
1632
+ const syncSessionKey = () => {
1633
+ if (state.currentSessionKey === lastSessionKey) return;
1634
+ lastSessionKey = state.currentSessionKey;
1635
+ finalizedRuns.clear();
1636
+ sessionRuns.clear();
1637
+ streamAssembler = new TuiStreamAssembler();
1638
+ };
1639
+ const noteSessionRun = (runId) => {
1640
+ sessionRuns.set(runId, Date.now());
1641
+ pruneRunMap(sessionRuns);
1642
+ };
1643
+ const noteFinalizedRun = (runId) => {
1644
+ finalizedRuns.set(runId, Date.now());
1645
+ sessionRuns.delete(runId);
1646
+ streamAssembler.drop(runId);
1647
+ pruneRunMap(finalizedRuns);
1648
+ };
1649
+ const handleChatEvent = (payload) => {
1650
+ if (!payload || typeof payload !== "object") return;
1651
+ const evt = payload;
1652
+ syncSessionKey();
1653
+ if (evt.sessionKey !== state.currentSessionKey) return;
1654
+ if (finalizedRuns.has(evt.runId)) {
1655
+ if (evt.state === "delta") return;
1656
+ if (evt.state === "final") return;
1657
+ }
1658
+ noteSessionRun(evt.runId);
1659
+ if (!state.activeChatRunId) state.activeChatRunId = evt.runId;
1660
+ if (evt.state === "delta") {
1661
+ const displayText = streamAssembler.ingestDelta(evt.runId, evt.message, state.showThinking);
1662
+ if (!displayText) return;
1663
+ chatLog.updateAssistant(displayText, evt.runId);
1664
+ setActivityStatus("streaming");
1665
+ }
1666
+ if (evt.state === "final") {
1667
+ if (isCommandMessage(evt.message)) {
1668
+ const text = extractTextFromMessage(evt.message);
1669
+ if (text) chatLog.addSystem(text);
1670
+ streamAssembler.drop(evt.runId);
1671
+ noteFinalizedRun(evt.runId);
1672
+ state.activeChatRunId = null;
1673
+ setActivityStatus("idle");
1674
+ refreshSessionInfo?.();
1675
+ tui.requestRender();
1676
+ return;
1677
+ }
1678
+ const stopReason = evt.message && typeof evt.message === "object" && !Array.isArray(evt.message) ? typeof evt.message.stopReason === "string" ? evt.message.stopReason : "" : "";
1679
+ const finalText = streamAssembler.finalize(evt.runId, evt.message, state.showThinking);
1680
+ chatLog.finalizeAssistant(finalText, evt.runId);
1681
+ noteFinalizedRun(evt.runId);
1682
+ state.activeChatRunId = null;
1683
+ setActivityStatus(stopReason === "error" ? "error" : "idle");
1684
+ refreshSessionInfo?.();
1685
+ }
1686
+ if (evt.state === "aborted") {
1687
+ chatLog.addSystem("run aborted");
1688
+ streamAssembler.drop(evt.runId);
1689
+ sessionRuns.delete(evt.runId);
1690
+ state.activeChatRunId = null;
1691
+ setActivityStatus("aborted");
1692
+ refreshSessionInfo?.();
1693
+ }
1694
+ if (evt.state === "error") {
1695
+ chatLog.addSystem(`run error: ${evt.errorMessage ?? "unknown"}`);
1696
+ streamAssembler.drop(evt.runId);
1697
+ sessionRuns.delete(evt.runId);
1698
+ state.activeChatRunId = null;
1699
+ setActivityStatus("error");
1700
+ refreshSessionInfo?.();
1701
+ }
1702
+ tui.requestRender();
1703
+ };
1704
+ const handleAgentEvent = (payload) => {
1705
+ if (!payload || typeof payload !== "object") return;
1706
+ const evt = payload;
1707
+ syncSessionKey();
1708
+ const isActiveRun = evt.runId === state.activeChatRunId;
1709
+ if (!isActiveRun && !sessionRuns.has(evt.runId)) return;
1710
+ if (evt.stream === "tool") {
1711
+ const data = evt.data ?? {};
1712
+ const phase = asString(data.phase, "");
1713
+ const toolCallId = asString(data.toolCallId, "");
1714
+ const toolName = asString(data.name, "tool");
1715
+ if (!toolCallId) return;
1716
+ if (phase === "start") chatLog.startTool(toolCallId, toolName, data.args);
1717
+ else if (phase === "update") chatLog.updateToolResult(toolCallId, data.partialResult, { partial: true });
1718
+ else if (phase === "result") chatLog.updateToolResult(toolCallId, data.result, { isError: Boolean(data.isError) });
1719
+ tui.requestRender();
1720
+ return;
1721
+ }
1722
+ if (evt.stream === "lifecycle") {
1723
+ if (!isActiveRun) return;
1724
+ const phase = typeof evt.data?.phase === "string" ? evt.data.phase : "";
1725
+ if (phase === "start") setActivityStatus("running");
1726
+ if (phase === "end") setActivityStatus("idle");
1727
+ if (phase === "error") setActivityStatus("error");
1728
+ tui.requestRender();
1729
+ }
1730
+ };
1731
+ return {
1732
+ handleChatEvent,
1733
+ handleAgentEvent
1734
+ };
1735
+ }
1736
+
1737
+ //#endregion
1738
+ //#region src/tui/tui-local-shell.ts
1739
+ function createLocalShellRunner(deps) {
1740
+ let localExecAsked = false;
1741
+ let localExecAllowed = false;
1742
+ const createSelector = deps.createSelector ?? createSearchableSelectList;
1743
+ const spawnCommand = deps.spawnCommand ?? spawn;
1744
+ const getCwd = deps.getCwd ?? (() => process.cwd());
1745
+ const env = deps.env ?? process.env;
1746
+ const maxChars = deps.maxOutputChars ?? 4e4;
1747
+ const ensureLocalExecAllowed = async () => {
1748
+ if (localExecAllowed) return true;
1749
+ if (localExecAsked) return false;
1750
+ localExecAsked = true;
1751
+ return await new Promise((resolve) => {
1752
+ deps.chatLog.addSystem("Allow local shell commands for this session?");
1753
+ deps.chatLog.addSystem("This runs commands on YOUR machine (not the gateway) and may delete files or reveal secrets.");
1754
+ deps.chatLog.addSystem("Select Yes/No (arrows + Enter), Esc to cancel.");
1755
+ const selector = createSelector([{
1756
+ value: "no",
1757
+ label: "No"
1758
+ }, {
1759
+ value: "yes",
1760
+ label: "Yes"
1761
+ }], 2);
1762
+ selector.onSelect = (item) => {
1763
+ deps.closeOverlay();
1764
+ if (item.value === "yes") {
1765
+ localExecAllowed = true;
1766
+ deps.chatLog.addSystem("local shell: enabled for this session");
1767
+ resolve(true);
1768
+ } else {
1769
+ deps.chatLog.addSystem("local shell: not enabled");
1770
+ resolve(false);
1771
+ }
1772
+ deps.tui.requestRender();
1773
+ };
1774
+ selector.onCancel = () => {
1775
+ deps.closeOverlay();
1776
+ deps.chatLog.addSystem("local shell: cancelled");
1777
+ deps.tui.requestRender();
1778
+ resolve(false);
1779
+ };
1780
+ deps.openOverlay(selector);
1781
+ deps.tui.requestRender();
1782
+ });
1783
+ };
1784
+ const runLocalShellLine = async (line) => {
1785
+ const cmd = line.slice(1);
1786
+ if (cmd === "") return;
1787
+ if (localExecAsked && !localExecAllowed) {
1788
+ deps.chatLog.addSystem("local shell: not enabled for this session");
1789
+ deps.tui.requestRender();
1790
+ return;
1791
+ }
1792
+ if (!await ensureLocalExecAllowed()) return;
1793
+ deps.chatLog.addSystem(`[local] $ ${cmd}`);
1794
+ deps.tui.requestRender();
1795
+ await new Promise((resolve) => {
1796
+ const child = spawnCommand(cmd, {
1797
+ shell: true,
1798
+ cwd: getCwd(),
1799
+ env
1800
+ });
1801
+ let stdout = "";
1802
+ let stderr = "";
1803
+ child.stdout.on("data", (buf) => {
1804
+ stdout += buf.toString("utf8");
1805
+ });
1806
+ child.stderr.on("data", (buf) => {
1807
+ stderr += buf.toString("utf8");
1808
+ });
1809
+ child.on("close", (code, signal) => {
1810
+ const combined = (stdout + (stderr ? (stdout ? "\n" : "") + stderr : "")).slice(0, maxChars).trimEnd();
1811
+ if (combined) for (const line of combined.split("\n")) deps.chatLog.addSystem(`[local] ${line}`);
1812
+ deps.chatLog.addSystem(`[local] exit ${code ?? "?"}${signal ? ` (signal ${String(signal)})` : ""}`);
1813
+ deps.tui.requestRender();
1814
+ resolve();
1815
+ });
1816
+ child.on("error", (err) => {
1817
+ deps.chatLog.addSystem(`[local] error: ${String(err)}`);
1818
+ deps.tui.requestRender();
1819
+ resolve();
1820
+ });
1821
+ });
1822
+ };
1823
+ return { runLocalShellLine };
1824
+ }
1825
+
1826
+ //#endregion
1827
+ //#region src/tui/tui-overlays.ts
1828
+ function createOverlayHandlers(host, fallbackFocus) {
1829
+ const openOverlay = (component) => {
1830
+ host.showOverlay(component);
1831
+ };
1832
+ const closeOverlay = () => {
1833
+ if (host.hasOverlay()) {
1834
+ host.hideOverlay();
1835
+ return;
1836
+ }
1837
+ host.setFocus(fallbackFocus);
1838
+ };
1839
+ return {
1840
+ openOverlay,
1841
+ closeOverlay
1842
+ };
1843
+ }
1844
+
1845
+ //#endregion
1846
+ //#region src/tui/tui-session-actions.ts
1847
+ function createSessionActions(context) {
1848
+ const { client, chatLog, tui, opts, state, agentNames, initialSessionInput, initialSessionAgentId, resolveSessionKey, updateHeader, updateFooter, updateAutocompleteProvider, setActivityStatus } = context;
1849
+ let refreshSessionInfoPromise = null;
1850
+ const applyAgentsResult = (result) => {
1851
+ state.agentDefaultId = normalizeAgentId(result.defaultId);
1852
+ state.sessionMainKey = normalizeMainKey(result.mainKey);
1853
+ state.sessionScope = result.scope ?? state.sessionScope;
1854
+ state.agents = result.agents.map((agent) => ({
1855
+ id: normalizeAgentId(agent.id),
1856
+ name: agent.name?.trim() || void 0
1857
+ }));
1858
+ agentNames.clear();
1859
+ for (const agent of state.agents) if (agent.name) agentNames.set(agent.id, agent.name);
1860
+ if (!state.initialSessionApplied) {
1861
+ if (initialSessionAgentId) {
1862
+ if (state.agents.some((agent) => agent.id === initialSessionAgentId)) state.currentAgentId = initialSessionAgentId;
1863
+ } else if (!state.agents.some((agent) => agent.id === state.currentAgentId)) state.currentAgentId = state.agents[0]?.id ?? normalizeAgentId(result.defaultId ?? state.currentAgentId);
1864
+ const nextSessionKey = resolveSessionKey(initialSessionInput);
1865
+ if (nextSessionKey !== state.currentSessionKey) state.currentSessionKey = nextSessionKey;
1866
+ state.initialSessionApplied = true;
1867
+ } else if (!state.agents.some((agent) => agent.id === state.currentAgentId)) state.currentAgentId = state.agents[0]?.id ?? normalizeAgentId(result.defaultId ?? state.currentAgentId);
1868
+ updateHeader();
1869
+ updateFooter();
1870
+ };
1871
+ const refreshAgents = async () => {
1872
+ try {
1873
+ applyAgentsResult(await client.listAgents());
1874
+ } catch (err) {
1875
+ chatLog.addSystem(`agents list failed: ${String(err)}`);
1876
+ }
1877
+ };
1878
+ const updateAgentFromSessionKey = (key) => {
1879
+ const parsed = parseAgentSessionKey(key);
1880
+ if (!parsed) return;
1881
+ const next = normalizeAgentId(parsed.agentId);
1882
+ if (next !== state.currentAgentId) state.currentAgentId = next;
1883
+ };
1884
+ const refreshSessionInfo = async () => {
1885
+ if (refreshSessionInfoPromise) return refreshSessionInfoPromise;
1886
+ refreshSessionInfoPromise = (async () => {
1887
+ try {
1888
+ const listAgentId = state.currentSessionKey === "global" || state.currentSessionKey === "unknown" ? void 0 : state.currentAgentId;
1889
+ const result = await client.listSessions({
1890
+ includeGlobal: false,
1891
+ includeUnknown: false,
1892
+ agentId: listAgentId
1893
+ });
1894
+ const entry = result.sessions.find((row) => {
1895
+ if (row.key === state.currentSessionKey) return true;
1896
+ return parseAgentSessionKey(row.key)?.rest === state.currentSessionKey;
1897
+ });
1898
+ state.sessionInfo = {
1899
+ thinkingLevel: entry?.thinkingLevel,
1900
+ verboseLevel: entry?.verboseLevel,
1901
+ reasoningLevel: entry?.reasoningLevel,
1902
+ model: entry?.model ?? result.defaults?.model ?? void 0,
1903
+ modelProvider: entry?.modelProvider ?? result.defaults?.modelProvider ?? void 0,
1904
+ contextTokens: entry?.contextTokens ?? result.defaults?.contextTokens,
1905
+ inputTokens: entry?.inputTokens ?? null,
1906
+ outputTokens: entry?.outputTokens ?? null,
1907
+ totalTokens: entry?.totalTokens ?? null,
1908
+ responseUsage: entry?.responseUsage,
1909
+ updatedAt: entry?.updatedAt ?? null,
1910
+ displayName: entry?.displayName
1911
+ };
1912
+ } catch (err) {
1913
+ chatLog.addSystem(`sessions list failed: ${String(err)}`);
1914
+ }
1915
+ updateAutocompleteProvider();
1916
+ updateFooter();
1917
+ tui.requestRender();
1918
+ })();
1919
+ try {
1920
+ await refreshSessionInfoPromise;
1921
+ } finally {
1922
+ refreshSessionInfoPromise = null;
1923
+ }
1924
+ };
1925
+ const loadHistory = async () => {
1926
+ try {
1927
+ const record = await client.loadHistory({
1928
+ sessionKey: state.currentSessionKey,
1929
+ limit: opts.historyLimit ?? 200
1930
+ });
1931
+ state.currentSessionId = typeof record.sessionId === "string" ? record.sessionId : null;
1932
+ state.sessionInfo.thinkingLevel = record.thinkingLevel ?? state.sessionInfo.thinkingLevel;
1933
+ chatLog.clearAll();
1934
+ chatLog.addSystem(`session ${state.currentSessionKey}`);
1935
+ for (const entry of record.messages ?? []) {
1936
+ if (!entry || typeof entry !== "object") continue;
1937
+ const message = entry;
1938
+ if (isCommandMessage(message)) {
1939
+ const text = extractTextFromMessage(message);
1940
+ if (text) chatLog.addSystem(text);
1941
+ continue;
1942
+ }
1943
+ if (message.role === "user") {
1944
+ const text = extractTextFromMessage(message);
1945
+ if (text) chatLog.addUser(text);
1946
+ continue;
1947
+ }
1948
+ if (message.role === "assistant") {
1949
+ const text = extractTextFromMessage(message, { includeThinking: state.showThinking });
1950
+ if (text) chatLog.finalizeAssistant(text);
1951
+ continue;
1952
+ }
1953
+ if (message.role === "toolResult") {
1954
+ const toolCallId = asString(message.toolCallId, "");
1955
+ const toolName = asString(message.toolName, "tool");
1956
+ chatLog.startTool(toolCallId, toolName, {}).setResult({
1957
+ content: Array.isArray(message.content) ? message.content : [],
1958
+ details: typeof message.details === "object" && message.details ? message.details : void 0
1959
+ }, { isError: Boolean(message.isError) });
1960
+ }
1961
+ }
1962
+ state.historyLoaded = true;
1963
+ } catch (err) {
1964
+ chatLog.addSystem(`history failed: ${String(err)}`);
1965
+ }
1966
+ await refreshSessionInfo();
1967
+ tui.requestRender();
1968
+ };
1969
+ const setSession = async (rawKey) => {
1970
+ const nextKey = resolveSessionKey(rawKey);
1971
+ updateAgentFromSessionKey(nextKey);
1972
+ state.currentSessionKey = nextKey;
1973
+ state.activeChatRunId = null;
1974
+ state.currentSessionId = null;
1975
+ state.historyLoaded = false;
1976
+ updateHeader();
1977
+ updateFooter();
1978
+ await loadHistory();
1979
+ };
1980
+ const abortActive = async () => {
1981
+ if (!state.activeChatRunId) {
1982
+ chatLog.addSystem("no active run");
1983
+ tui.requestRender();
1984
+ return;
1985
+ }
1986
+ try {
1987
+ await client.abortChat({
1988
+ sessionKey: state.currentSessionKey,
1989
+ runId: state.activeChatRunId
1990
+ });
1991
+ setActivityStatus("aborted");
1992
+ } catch (err) {
1993
+ chatLog.addSystem(`abort failed: ${String(err)}`);
1994
+ setActivityStatus("abort failed");
1995
+ }
1996
+ tui.requestRender();
1997
+ };
1998
+ return {
1999
+ applyAgentsResult,
2000
+ refreshAgents,
2001
+ refreshSessionInfo,
2002
+ loadHistory,
2003
+ setSession,
2004
+ abortActive
2005
+ };
2006
+ }
2007
+
2008
+ //#endregion
2009
+ //#region src/tui/tui-waiting.ts
2010
+ const defaultWaitingPhrases = [
2011
+ "flibbertigibbeting",
2012
+ "kerfuffling",
2013
+ "dillydallying",
2014
+ "twiddling thumbs",
2015
+ "noodling",
2016
+ "bamboozling",
2017
+ "moseying",
2018
+ "hobnobbing",
2019
+ "pondering",
2020
+ "conjuring"
2021
+ ];
2022
+ function pickWaitingPhrase(tick, phrases = defaultWaitingPhrases) {
2023
+ return phrases[Math.floor(tick / 10) % phrases.length] ?? phrases[0] ?? "waiting";
2024
+ }
2025
+ function shimmerText(theme, text, tick) {
2026
+ const width = 6;
2027
+ const hi = (ch) => theme.bold(theme.accentSoft(ch));
2028
+ const pos = tick % (text.length + width);
2029
+ const start = Math.max(0, pos - width);
2030
+ const end = Math.min(text.length - 1, pos);
2031
+ let out = "";
2032
+ for (let i = 0; i < text.length; i++) {
2033
+ const ch = text[i];
2034
+ out += i >= start && i <= end ? hi(ch) : theme.dim(ch);
2035
+ }
2036
+ return out;
2037
+ }
2038
+ function buildWaitingStatusMessage(params) {
2039
+ const phrase = pickWaitingPhrase(params.tick, params.phrases);
2040
+ return `${shimmerText(params.theme, `${phrase}…`, params.tick)} • ${params.elapsed} | ${params.connectionStatus}`;
2041
+ }
2042
+
2043
+ //#endregion
2044
+ //#region src/tui/tui.ts
2045
+ function createEditorSubmitHandler(params) {
2046
+ return (text) => {
2047
+ const raw = text;
2048
+ const value = raw.trim();
2049
+ params.editor.setText("");
2050
+ if (!value) return;
2051
+ if (raw.startsWith("!") && raw !== "!") {
2052
+ params.editor.addToHistory(raw);
2053
+ params.handleBangLine(raw);
2054
+ return;
2055
+ }
2056
+ params.editor.addToHistory(value);
2057
+ if (value.startsWith("/")) {
2058
+ params.handleCommand(value);
2059
+ return;
2060
+ }
2061
+ params.sendMessage(value);
2062
+ };
2063
+ }
2064
+ async function runTui(opts) {
2065
+ const config = loadConfig();
2066
+ const initialSessionInput = (opts.session ?? "").trim();
2067
+ let sessionScope = config.session?.scope ?? "per-sender";
2068
+ let sessionMainKey = normalizeMainKey(config.session?.mainKey);
2069
+ let agentDefaultId = resolveDefaultAgentId(config);
2070
+ let currentAgentId = agentDefaultId;
2071
+ let agents = [];
2072
+ const agentNames = /* @__PURE__ */ new Map();
2073
+ let currentSessionKey = "";
2074
+ let initialSessionApplied = false;
2075
+ let currentSessionId = null;
2076
+ let activeChatRunId = null;
2077
+ let historyLoaded = false;
2078
+ let isConnected = false;
2079
+ let wasDisconnected = false;
2080
+ let toolsExpanded = false;
2081
+ let showThinking = false;
2082
+ const deliverDefault = opts.deliver ?? false;
2083
+ const autoMessage = opts.message?.trim();
2084
+ let autoMessageSent = false;
2085
+ let sessionInfo = {};
2086
+ let lastCtrlCAt = 0;
2087
+ let activityStatus = "idle";
2088
+ let connectionStatus = "connecting";
2089
+ let statusTimeout = null;
2090
+ let statusTimer = null;
2091
+ let statusStartedAt = null;
2092
+ let lastActivityStatus = activityStatus;
2093
+ const state = {
2094
+ get agentDefaultId() {
2095
+ return agentDefaultId;
2096
+ },
2097
+ set agentDefaultId(value) {
2098
+ agentDefaultId = value;
2099
+ },
2100
+ get sessionMainKey() {
2101
+ return sessionMainKey;
2102
+ },
2103
+ set sessionMainKey(value) {
2104
+ sessionMainKey = value;
2105
+ },
2106
+ get sessionScope() {
2107
+ return sessionScope;
2108
+ },
2109
+ set sessionScope(value) {
2110
+ sessionScope = value;
2111
+ },
2112
+ get agents() {
2113
+ return agents;
2114
+ },
2115
+ set agents(value) {
2116
+ agents = value;
2117
+ },
2118
+ get currentAgentId() {
2119
+ return currentAgentId;
2120
+ },
2121
+ set currentAgentId(value) {
2122
+ currentAgentId = value;
2123
+ },
2124
+ get currentSessionKey() {
2125
+ return currentSessionKey;
2126
+ },
2127
+ set currentSessionKey(value) {
2128
+ currentSessionKey = value;
2129
+ },
2130
+ get currentSessionId() {
2131
+ return currentSessionId;
2132
+ },
2133
+ set currentSessionId(value) {
2134
+ currentSessionId = value;
2135
+ },
2136
+ get activeChatRunId() {
2137
+ return activeChatRunId;
2138
+ },
2139
+ set activeChatRunId(value) {
2140
+ activeChatRunId = value;
2141
+ },
2142
+ get historyLoaded() {
2143
+ return historyLoaded;
2144
+ },
2145
+ set historyLoaded(value) {
2146
+ historyLoaded = value;
2147
+ },
2148
+ get sessionInfo() {
2149
+ return sessionInfo;
2150
+ },
2151
+ set sessionInfo(value) {
2152
+ sessionInfo = value;
2153
+ },
2154
+ get initialSessionApplied() {
2155
+ return initialSessionApplied;
2156
+ },
2157
+ set initialSessionApplied(value) {
2158
+ initialSessionApplied = value;
2159
+ },
2160
+ get isConnected() {
2161
+ return isConnected;
2162
+ },
2163
+ set isConnected(value) {
2164
+ isConnected = value;
2165
+ },
2166
+ get autoMessageSent() {
2167
+ return autoMessageSent;
2168
+ },
2169
+ set autoMessageSent(value) {
2170
+ autoMessageSent = value;
2171
+ },
2172
+ get toolsExpanded() {
2173
+ return toolsExpanded;
2174
+ },
2175
+ set toolsExpanded(value) {
2176
+ toolsExpanded = value;
2177
+ },
2178
+ get showThinking() {
2179
+ return showThinking;
2180
+ },
2181
+ set showThinking(value) {
2182
+ showThinking = value;
2183
+ },
2184
+ get connectionStatus() {
2185
+ return connectionStatus;
2186
+ },
2187
+ set connectionStatus(value) {
2188
+ connectionStatus = value;
2189
+ },
2190
+ get activityStatus() {
2191
+ return activityStatus;
2192
+ },
2193
+ set activityStatus(value) {
2194
+ activityStatus = value;
2195
+ },
2196
+ get statusTimeout() {
2197
+ return statusTimeout;
2198
+ },
2199
+ set statusTimeout(value) {
2200
+ statusTimeout = value;
2201
+ },
2202
+ get lastCtrlCAt() {
2203
+ return lastCtrlCAt;
2204
+ },
2205
+ set lastCtrlCAt(value) {
2206
+ lastCtrlCAt = value;
2207
+ }
2208
+ };
2209
+ const client = new GatewayChatClient({
2210
+ url: opts.url,
2211
+ token: opts.token,
2212
+ password: opts.password
2213
+ });
2214
+ const tui = new TUI(new ProcessTerminal());
2215
+ const header = new Text("", 1, 0);
2216
+ const statusContainer = new Container();
2217
+ const footer = new Text("", 1, 0);
2218
+ const chatLog = new ChatLog();
2219
+ const editor = new CustomEditor(tui, editorTheme);
2220
+ const root = new Container();
2221
+ root.addChild(header);
2222
+ root.addChild(chatLog);
2223
+ root.addChild(statusContainer);
2224
+ root.addChild(footer);
2225
+ root.addChild(editor);
2226
+ const updateAutocompleteProvider = () => {
2227
+ editor.setAutocompleteProvider(new CombinedAutocompleteProvider(getSlashCommands({
2228
+ cfg: config,
2229
+ provider: sessionInfo.modelProvider,
2230
+ model: sessionInfo.model
2231
+ }), process.cwd()));
2232
+ };
2233
+ tui.addChild(root);
2234
+ tui.setFocus(editor);
2235
+ const formatSessionKey = (key) => {
2236
+ if (key === "global" || key === "unknown") return key;
2237
+ return parseAgentSessionKey(key)?.rest ?? key;
2238
+ };
2239
+ const formatAgentLabel = (id) => {
2240
+ const name = agentNames.get(id);
2241
+ return name ? `${id} (${name})` : id;
2242
+ };
2243
+ const resolveSessionKey = (raw) => {
2244
+ const trimmed = (raw ?? "").trim();
2245
+ if (sessionScope === "global") return "global";
2246
+ if (!trimmed) return buildAgentMainSessionKey({
2247
+ agentId: currentAgentId,
2248
+ mainKey: sessionMainKey
2249
+ });
2250
+ if (trimmed === "global" || trimmed === "unknown") return trimmed;
2251
+ if (trimmed.startsWith("agent:")) return trimmed;
2252
+ return `agent:${currentAgentId}:${trimmed}`;
2253
+ };
2254
+ currentSessionKey = resolveSessionKey(initialSessionInput);
2255
+ const updateHeader = () => {
2256
+ const sessionLabel = formatSessionKey(currentSessionKey);
2257
+ const agentLabel = formatAgentLabel(currentAgentId);
2258
+ header.setText(theme.header(`openclaw tui - ${client.connection.url} - agent ${agentLabel} - session ${sessionLabel}`));
2259
+ };
2260
+ const busyStates = new Set([
2261
+ "sending",
2262
+ "waiting",
2263
+ "streaming",
2264
+ "running"
2265
+ ]);
2266
+ let statusText = null;
2267
+ let statusLoader = null;
2268
+ const formatElapsed = (startMs) => {
2269
+ const totalSeconds = Math.max(0, Math.floor((Date.now() - startMs) / 1e3));
2270
+ if (totalSeconds < 60) return `${totalSeconds}s`;
2271
+ return `${Math.floor(totalSeconds / 60)}m ${totalSeconds % 60}s`;
2272
+ };
2273
+ const ensureStatusText = () => {
2274
+ if (statusText) return;
2275
+ statusContainer.clear();
2276
+ statusLoader?.stop();
2277
+ statusLoader = null;
2278
+ statusText = new Text("", 1, 0);
2279
+ statusContainer.addChild(statusText);
2280
+ };
2281
+ const ensureStatusLoader = () => {
2282
+ if (statusLoader) return;
2283
+ statusContainer.clear();
2284
+ statusText = null;
2285
+ statusLoader = new Loader(tui, (spinner) => theme.accent(spinner), (text) => theme.bold(theme.accentSoft(text)), "");
2286
+ statusContainer.addChild(statusLoader);
2287
+ };
2288
+ let waitingTick = 0;
2289
+ let waitingTimer = null;
2290
+ let waitingPhrase = null;
2291
+ const updateBusyStatusMessage = () => {
2292
+ if (!statusLoader || !statusStartedAt) return;
2293
+ const elapsed = formatElapsed(statusStartedAt);
2294
+ if (activityStatus === "waiting") {
2295
+ waitingTick++;
2296
+ statusLoader.setMessage(buildWaitingStatusMessage({
2297
+ theme,
2298
+ tick: waitingTick,
2299
+ elapsed,
2300
+ connectionStatus,
2301
+ phrases: waitingPhrase ? [waitingPhrase] : void 0
2302
+ }));
2303
+ return;
2304
+ }
2305
+ statusLoader.setMessage(`${activityStatus} • ${elapsed} | ${connectionStatus}`);
2306
+ };
2307
+ const startStatusTimer = () => {
2308
+ if (statusTimer) return;
2309
+ statusTimer = setInterval(() => {
2310
+ if (!busyStates.has(activityStatus)) return;
2311
+ updateBusyStatusMessage();
2312
+ }, 1e3);
2313
+ };
2314
+ const stopStatusTimer = () => {
2315
+ if (!statusTimer) return;
2316
+ clearInterval(statusTimer);
2317
+ statusTimer = null;
2318
+ };
2319
+ const startWaitingTimer = () => {
2320
+ if (waitingTimer) return;
2321
+ if (!waitingPhrase) waitingPhrase = defaultWaitingPhrases[Math.floor(Math.random() * defaultWaitingPhrases.length)] ?? defaultWaitingPhrases[0] ?? "waiting";
2322
+ waitingTick = 0;
2323
+ waitingTimer = setInterval(() => {
2324
+ if (activityStatus !== "waiting") return;
2325
+ updateBusyStatusMessage();
2326
+ }, 120);
2327
+ };
2328
+ const stopWaitingTimer = () => {
2329
+ if (!waitingTimer) return;
2330
+ clearInterval(waitingTimer);
2331
+ waitingTimer = null;
2332
+ waitingPhrase = null;
2333
+ };
2334
+ const renderStatus = () => {
2335
+ if (busyStates.has(activityStatus)) {
2336
+ if (!statusStartedAt || lastActivityStatus !== activityStatus) statusStartedAt = Date.now();
2337
+ ensureStatusLoader();
2338
+ if (activityStatus === "waiting") {
2339
+ stopStatusTimer();
2340
+ startWaitingTimer();
2341
+ } else {
2342
+ stopWaitingTimer();
2343
+ startStatusTimer();
2344
+ }
2345
+ updateBusyStatusMessage();
2346
+ } else {
2347
+ statusStartedAt = null;
2348
+ stopStatusTimer();
2349
+ stopWaitingTimer();
2350
+ statusLoader?.stop();
2351
+ statusLoader = null;
2352
+ ensureStatusText();
2353
+ const text = activityStatus ? `${connectionStatus} | ${activityStatus}` : connectionStatus;
2354
+ statusText?.setText(theme.dim(text));
2355
+ }
2356
+ lastActivityStatus = activityStatus;
2357
+ };
2358
+ const setConnectionStatus = (text, ttlMs) => {
2359
+ connectionStatus = text;
2360
+ renderStatus();
2361
+ if (statusTimeout) clearTimeout(statusTimeout);
2362
+ if (ttlMs && ttlMs > 0) statusTimeout = setTimeout(() => {
2363
+ connectionStatus = isConnected ? "connected" : "disconnected";
2364
+ renderStatus();
2365
+ }, ttlMs);
2366
+ };
2367
+ const setActivityStatus = (text) => {
2368
+ activityStatus = text;
2369
+ renderStatus();
2370
+ };
2371
+ const updateFooter = () => {
2372
+ const sessionKeyLabel = formatSessionKey(currentSessionKey);
2373
+ const sessionLabel = sessionInfo.displayName ? `${sessionKeyLabel} (${sessionInfo.displayName})` : sessionKeyLabel;
2374
+ const agentLabel = formatAgentLabel(currentAgentId);
2375
+ const modelLabel = sessionInfo.model ? sessionInfo.modelProvider ? `${sessionInfo.modelProvider}/${sessionInfo.model}` : sessionInfo.model : "unknown";
2376
+ const tokens = formatTokens(sessionInfo.totalTokens ?? null, sessionInfo.contextTokens ?? null);
2377
+ const think = sessionInfo.thinkingLevel ?? "off";
2378
+ const verbose = sessionInfo.verboseLevel ?? "off";
2379
+ const reasoning = sessionInfo.reasoningLevel ?? "off";
2380
+ const reasoningLabel = reasoning === "on" ? "reasoning" : reasoning === "stream" ? "reasoning:stream" : null;
2381
+ const footerParts = [
2382
+ `agent ${agentLabel}`,
2383
+ `session ${sessionLabel}`,
2384
+ modelLabel,
2385
+ think !== "off" ? `think ${think}` : null,
2386
+ verbose !== "off" ? `verbose ${verbose}` : null,
2387
+ reasoningLabel,
2388
+ tokens
2389
+ ].filter(Boolean);
2390
+ footer.setText(theme.dim(footerParts.join(" | ")));
2391
+ };
2392
+ const { openOverlay, closeOverlay } = createOverlayHandlers(tui, editor);
2393
+ const { refreshAgents, refreshSessionInfo, loadHistory, setSession, abortActive } = createSessionActions({
2394
+ client,
2395
+ chatLog,
2396
+ tui,
2397
+ opts,
2398
+ state,
2399
+ agentNames,
2400
+ initialSessionInput,
2401
+ initialSessionAgentId: (() => {
2402
+ if (!initialSessionInput) return null;
2403
+ const parsed = parseAgentSessionKey(initialSessionInput);
2404
+ return parsed ? normalizeAgentId(parsed.agentId) : null;
2405
+ })(),
2406
+ resolveSessionKey,
2407
+ updateHeader,
2408
+ updateFooter,
2409
+ updateAutocompleteProvider,
2410
+ setActivityStatus
2411
+ });
2412
+ const { handleChatEvent, handleAgentEvent } = createEventHandlers({
2413
+ chatLog,
2414
+ tui,
2415
+ state,
2416
+ setActivityStatus,
2417
+ refreshSessionInfo
2418
+ });
2419
+ const { handleCommand, sendMessage, openModelSelector, openAgentSelector, openSessionSelector } = createCommandHandlers({
2420
+ client,
2421
+ chatLog,
2422
+ tui,
2423
+ opts,
2424
+ state,
2425
+ deliverDefault,
2426
+ openOverlay,
2427
+ closeOverlay,
2428
+ refreshSessionInfo,
2429
+ loadHistory,
2430
+ setSession,
2431
+ refreshAgents,
2432
+ abortActive,
2433
+ setActivityStatus,
2434
+ formatSessionKey
2435
+ });
2436
+ const { runLocalShellLine } = createLocalShellRunner({
2437
+ chatLog,
2438
+ tui,
2439
+ openOverlay,
2440
+ closeOverlay
2441
+ });
2442
+ updateAutocompleteProvider();
2443
+ editor.onSubmit = createEditorSubmitHandler({
2444
+ editor,
2445
+ handleCommand,
2446
+ sendMessage,
2447
+ handleBangLine: runLocalShellLine
2448
+ });
2449
+ editor.onEscape = () => {
2450
+ abortActive();
2451
+ };
2452
+ editor.onCtrlC = () => {
2453
+ const now = Date.now();
2454
+ if (editor.getText().trim().length > 0) {
2455
+ editor.setText("");
2456
+ setActivityStatus("cleared input");
2457
+ tui.requestRender();
2458
+ return;
2459
+ }
2460
+ if (now - lastCtrlCAt < 1e3) {
2461
+ client.stop();
2462
+ tui.stop();
2463
+ process.exit(0);
2464
+ }
2465
+ lastCtrlCAt = now;
2466
+ setActivityStatus("press ctrl+c again to exit");
2467
+ tui.requestRender();
2468
+ };
2469
+ editor.onCtrlD = () => {
2470
+ client.stop();
2471
+ tui.stop();
2472
+ process.exit(0);
2473
+ };
2474
+ editor.onCtrlO = () => {
2475
+ toolsExpanded = !toolsExpanded;
2476
+ chatLog.setToolsExpanded(toolsExpanded);
2477
+ setActivityStatus(toolsExpanded ? "tools expanded" : "tools collapsed");
2478
+ tui.requestRender();
2479
+ };
2480
+ editor.onCtrlL = () => {
2481
+ openModelSelector();
2482
+ };
2483
+ editor.onCtrlG = () => {
2484
+ openAgentSelector();
2485
+ };
2486
+ editor.onCtrlP = () => {
2487
+ openSessionSelector();
2488
+ };
2489
+ editor.onCtrlT = () => {
2490
+ showThinking = !showThinking;
2491
+ loadHistory();
2492
+ };
2493
+ client.onEvent = (evt) => {
2494
+ if (evt.event === "chat") handleChatEvent(evt.payload);
2495
+ if (evt.event === "agent") handleAgentEvent(evt.payload);
2496
+ };
2497
+ client.onConnected = () => {
2498
+ isConnected = true;
2499
+ const reconnected = wasDisconnected;
2500
+ wasDisconnected = false;
2501
+ setConnectionStatus("connected");
2502
+ (async () => {
2503
+ await refreshAgents();
2504
+ updateHeader();
2505
+ await loadHistory();
2506
+ setConnectionStatus(reconnected ? "gateway reconnected" : "gateway connected", 4e3);
2507
+ tui.requestRender();
2508
+ if (!autoMessageSent && autoMessage) {
2509
+ autoMessageSent = true;
2510
+ await sendMessage(autoMessage);
2511
+ }
2512
+ updateFooter();
2513
+ tui.requestRender();
2514
+ })();
2515
+ };
2516
+ client.onDisconnected = (reason) => {
2517
+ isConnected = false;
2518
+ wasDisconnected = true;
2519
+ historyLoaded = false;
2520
+ setConnectionStatus(`gateway disconnected: ${reason?.trim() ? reason.trim() : "closed"}`, 5e3);
2521
+ setActivityStatus("idle");
2522
+ updateFooter();
2523
+ tui.requestRender();
2524
+ };
2525
+ client.onGap = (info) => {
2526
+ setConnectionStatus(`event gap: expected ${info.expected}, got ${info.received}`, 5e3);
2527
+ tui.requestRender();
2528
+ };
2529
+ updateHeader();
2530
+ setConnectionStatus("connecting");
2531
+ updateFooter();
2532
+ tui.start();
2533
+ client.start();
2534
+ await new Promise((resolve) => {
2535
+ const finish = () => resolve();
2536
+ process.once("exit", finish);
2537
+ process.once("SIGINT", finish);
2538
+ process.once("SIGTERM", finish);
2539
+ });
2540
+ }
2541
+
2542
+ //#endregion
2543
+ export { runTui as t };