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