@termix-it/cryptoclaw 1.0.0

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 (1222) hide show
  1. package/CHANGELOG.md +1615 -0
  2. package/LICENSE +21 -0
  3. package/README-header.png +0 -0
  4. package/README.md +331 -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/cryptoclaw.mjs +14 -0
  18. package/dist/accounts-BPjR5SyC.js +251 -0
  19. package/dist/accounts-CIGHxE7R.js +251 -0
  20. package/dist/acp-cli-DBWmJpUJ.js +924 -0
  21. package/dist/acp-cli-DG9nygBk.js +926 -0
  22. package/dist/agent-3MZVCC-N.js +702 -0
  23. package/dist/agent-IDE9krld.js +702 -0
  24. package/dist/agent-scope-DBl1We79.js +370 -0
  25. package/dist/agent-scope-DLfFOxP6.js +370 -0
  26. package/dist/agent-scope-e_oNRhGi.js +606 -0
  27. package/dist/archive-Dy3Ezb-5.js +85 -0
  28. package/dist/archive-iT9wNsml.js +85 -0
  29. package/dist/audit-Bj_dxNaD.js +1853 -0
  30. package/dist/audit-jaTyyQX1.js +1853 -0
  31. package/dist/auth-RTEHx2eI.js +192 -0
  32. package/dist/auth-health-BlspzqyF.js +149 -0
  33. package/dist/auth-health-CCM6Z3vK.js +149 -0
  34. package/dist/auth-phxCaFNX.js +192 -0
  35. package/dist/auth-profiles-DoD7YxsD.js +2939 -0
  36. package/dist/boolean-BsqeuxE6.js +30 -0
  37. package/dist/brew-CAcErcKz.js +46 -0
  38. package/dist/brew-CqnNFIkD.js +46 -0
  39. package/dist/build-info.json +5 -0
  40. package/dist/call-D2DXG0AC.js +278 -0
  41. package/dist/call-DqxlETxE.js +278 -0
  42. package/dist/canvas-host/a2ui/.bundle.hash +1 -0
  43. package/dist/canvas-host/a2ui/a2ui.bundle.js +17765 -0
  44. package/dist/canvas-host/a2ui/index.html +307 -0
  45. package/dist/channel-options-BHpXOBuP.js +32 -0
  46. package/dist/channel-options-DUkxROTo.js +62 -0
  47. package/dist/channel-selection-BdigfMZZ.js +51 -0
  48. package/dist/channel-selection-D7jFTFec.js +51 -0
  49. package/dist/channel-summary-CobMoKN6.js +1120 -0
  50. package/dist/channel-summary-DS0kcHm2.js +1120 -0
  51. package/dist/channels-cli-D7ZNRrq7.js +1414 -0
  52. package/dist/channels-cli-DBwffwqw.js +1413 -0
  53. package/dist/channels-status-issues-C2UGSPvH.js +18 -0
  54. package/dist/channels-status-issues-Dxmd7zYk.js +18 -0
  55. package/dist/chrome-CwbWzmh4.js +1973 -0
  56. package/dist/chrome-SVqOMFxA.js +1953 -0
  57. package/dist/clack-prompter-k_egRADS.js +92 -0
  58. package/dist/clack-prompter-nSmn5cZ2.js +92 -0
  59. package/dist/cli/daemon-cli.js +2 -0
  60. package/dist/cli-C9xiWnx9.js +86 -0
  61. package/dist/cli-D6C9z94O.js +88 -0
  62. package/dist/cli-utils-B7iQwCY5.js +43 -0
  63. package/dist/cli-utils-CgOu3WAB.js +43 -0
  64. package/dist/client-BaTYzXOU.js +1617 -0
  65. package/dist/client-N6zH1neq.js +1617 -0
  66. package/dist/command-format-9IsYy-9N.js +52 -0
  67. package/dist/command-format-B0bnyrEA.js +38 -0
  68. package/dist/command-format-n_udBm8l.js +52 -0
  69. package/dist/command-options-DL1PhuUF.js +33 -0
  70. package/dist/commands-Dpeoos11.js +230 -0
  71. package/dist/completion-cli-B5nR7jt8.js +434 -0
  72. package/dist/completion-cli-CZ8zPqPs.js +773 -0
  73. package/dist/config-DSpb2aMV.js +4916 -0
  74. package/dist/config-IwiWafT3.js +5657 -0
  75. package/dist/config-dQK4rbfx.js +4916 -0
  76. package/dist/config-guard-DwIb5Y-v.js +5719 -0
  77. package/dist/configure-7M9mLC4o.js +896 -0
  78. package/dist/configure-CivCcvkA.js +896 -0
  79. package/dist/constants-C2T4hQIk.js +65 -0
  80. package/dist/constants-DBvu3LzZ.js +65 -0
  81. package/dist/control-service-BXC31sNw.js +61 -0
  82. package/dist/control-service-lVzEzp9f.js +61 -0
  83. package/dist/control-ui/apple-touch-icon.png +0 -0
  84. package/dist/control-ui/assets/index-DQ-7PWhX.js +7553 -0
  85. package/dist/control-ui/assets/index-DQ-7PWhX.js.map +1 -0
  86. package/dist/control-ui/assets/index-nlpH70Eh.css +1 -0
  87. package/dist/control-ui/favicon-32.png +0 -0
  88. package/dist/control-ui/favicon.ico +0 -0
  89. package/dist/control-ui/favicon.svg +22 -0
  90. package/dist/control-ui/index.html +17 -0
  91. package/dist/cron-cli-DS8ytfYQ.js +455 -0
  92. package/dist/cron-cli-Djb3HUdz.js +457 -0
  93. package/dist/daemon-cli-KoaJ2nJX.js +758 -0
  94. package/dist/daemon-cli-ZQIKLvAO.js +758 -0
  95. package/dist/daemon-runtime-CHWbAfKs.js +517 -0
  96. package/dist/daemon-runtime-DEjUQVjL.js +517 -0
  97. package/dist/deliver-DVRzRmNN.js +2557 -0
  98. package/dist/deliver-OfX6bSYR.js +2587 -0
  99. package/dist/deliver-sPBfRlXT.js +2587 -0
  100. package/dist/deps-BSdWD2wF.js +27 -0
  101. package/dist/deps-CZOfeWEp.js +27 -0
  102. package/dist/devices-cli-DHSpDnCS.js +207 -0
  103. package/dist/devices-cli-b9iF_uOi.js +205 -0
  104. package/dist/directory-cli-D0dTuAem.js +247 -0
  105. package/dist/directory-cli-qniSxsHo.js +245 -0
  106. package/dist/dispatcher-DA3u3CwV.js +160 -0
  107. package/dist/dns-cli-C0JUNb9O.js +201 -0
  108. package/dist/dns-cli-DwwMpMuN.js +199 -0
  109. package/dist/docs-cli-BlFHCHDz.js +161 -0
  110. package/dist/docs-cli-BpSPrY3Y.js +160 -0
  111. package/dist/doctor-Da1XgFcW.js +2584 -0
  112. package/dist/doctor-qrtookj-.js +2585 -0
  113. package/dist/entry.js +1156 -0
  114. package/dist/env-B2Cd_6IS.js +32 -0
  115. package/dist/errors--S5IAxQx.js +1952 -0
  116. package/dist/exec-CLQSz0CI.js +246 -0
  117. package/dist/exec-CW_QjkBi.js +246 -0
  118. package/dist/exec-D7I5LU33.js +1099 -0
  119. package/dist/exec-approvals-CuXem6Li.js +1043 -0
  120. package/dist/exec-approvals-P7vwSw4O.js +1043 -0
  121. package/dist/exec-approvals-cli-Csgqkksl.js +386 -0
  122. package/dist/exec-approvals-cli-Dk4yHE2L.js +388 -0
  123. package/dist/extensionAPI.js +64497 -0
  124. package/dist/format-B7OjpGnt.js +34 -0
  125. package/dist/format-Dv1wz41T.js +34 -0
  126. package/dist/gateway-cli-CJ7H2DgV.js +17352 -0
  127. package/dist/gateway-cli-CrKl-bIH.js +17352 -0
  128. package/dist/gateway-rpc--CH0NWWR.js +28 -0
  129. package/dist/gateway-rpc-BPfCU2Vi.js +28 -0
  130. package/dist/github-copilot-auth-CcPEEb3Q.js +1190 -0
  131. package/dist/github-copilot-auth-h3beCc_l.js +1190 -0
  132. package/dist/github-copilot-token-C1sArkX4.js +103 -0
  133. package/dist/github-copilot-token-DL6Pou2p.js +103 -0
  134. package/dist/github-copilot-token-hMl1wyZp.js +103 -0
  135. package/dist/gmail-setup-utils-CnVYPhaQ.js +428 -0
  136. package/dist/gmail-setup-utils-pZ9NnOvB.js +428 -0
  137. package/dist/health-format-BcsR5dtU.js +1211 -0
  138. package/dist/health-format-Pl8qK65t.js +1212 -0
  139. package/dist/help-format-BzWwbeSF.js +17 -0
  140. package/dist/help-format-CUnac_bT.js +17 -0
  141. package/dist/helpers-5yebzF4C.js +25 -0
  142. package/dist/helpers-CQI-5xS9.js +25 -0
  143. package/dist/helpers-CzQjTUbz.js +10 -0
  144. package/dist/helpers-OUt4hxkS.js +10 -0
  145. package/dist/hooks/bundled/boot-md/HOOK.md +19 -0
  146. package/dist/hooks/bundled/command-logger/HOOK.md +122 -0
  147. package/dist/hooks/bundled/session-memory/HOOK.md +109 -0
  148. package/dist/hooks/bundled/soul-evil/HOOK.md +71 -0
  149. package/dist/hooks-cli-BKHTdsn4.js +1058 -0
  150. package/dist/hooks-cli-zkLY25DX.js +1060 -0
  151. package/dist/hooks-status-BETsyuUR.js +443 -0
  152. package/dist/hooks-status-nPgxLL-x.js +443 -0
  153. package/dist/image-BFNcQzKp.js +629 -0
  154. package/dist/image-CC_YKDB-.js +1421 -0
  155. package/dist/image-DAsWVn7Q.js +629 -0
  156. package/dist/index.js +5900 -0
  157. package/dist/installs-Byb3s_8P.js +425 -0
  158. package/dist/installs-CELeuogN.js +425 -0
  159. package/dist/is-main-B6kCyqsv.js +25 -0
  160. package/dist/is-main-CBExsRNQ.js +25 -0
  161. package/dist/links-Brcj2Oc-.js +15 -0
  162. package/dist/links-cf9h8BXu.js +15 -0
  163. package/dist/loader-CU4bkeKe.js +61131 -0
  164. package/dist/logging-5MtSkLpb.js +1 -0
  165. package/dist/logging-BJRQDTME.js +15 -0
  166. package/dist/logging-CD55MXc7.js +15 -0
  167. package/dist/logging-kuFzZMsG.js +1 -0
  168. package/dist/login-qr-BCr2GKX6.js +475 -0
  169. package/dist/login-qr-BMbekoZW.js +478 -0
  170. package/dist/login-qr-HIPJAnbT.js +478 -0
  171. package/dist/logs-cli-CM7-XOcZ.js +230 -0
  172. package/dist/logs-cli-aqjT7oHu.js +228 -0
  173. package/dist/manager-C5m5qpB0.js +2871 -0
  174. package/dist/manager-CtGvmGvM.js +2872 -0
  175. package/dist/manager-DpZlm3gk.js +2870 -0
  176. package/dist/manifest-registry-BdTzIlta.js +669 -0
  177. package/dist/manifest-registry-DVQHMj0y.js +669 -0
  178. package/dist/message-channel-CfYBy4y3.js +110 -0
  179. package/dist/message-channel-CvHWS3C2.js +110 -0
  180. package/dist/model-selection-Av0fLq51.js +2940 -0
  181. package/dist/model-selection-DuI_Ue9Q.js +2691 -0
  182. package/dist/models-cli-C0JOZ5oP.js +2541 -0
  183. package/dist/models-cli-gmkzOpbq.js +2543 -0
  184. package/dist/net-D4G66Xui.js +137 -0
  185. package/dist/net-YrbuVTd2.js +137 -0
  186. package/dist/node-cli-BND9LLkM.js +1457 -0
  187. package/dist/node-cli-DNRB94ib.js +1459 -0
  188. package/dist/node-service-DTgDFo7M.js +67 -0
  189. package/dist/node-service-JEBcPQat.js +67 -0
  190. package/dist/nodes-cli-BCWlqHyR.js +1208 -0
  191. package/dist/nodes-cli-DWSo5dX7.js +1210 -0
  192. package/dist/nodes-screen-CMvShBEB.js +157 -0
  193. package/dist/nodes-screen-Cok3-EJw.js +157 -0
  194. package/dist/note-C5M2AQOP.js +73 -0
  195. package/dist/note-DEz9ZK7G.js +73 -0
  196. package/dist/onboard-channels-B75LjjVZ.js +671 -0
  197. package/dist/onboard-channels-DJz2TusQ.js +671 -0
  198. package/dist/onboard-skills-ByHkU9nx.js +3615 -0
  199. package/dist/onboard-skills-Wknr7pxR.js +3615 -0
  200. package/dist/onboarding-BejDjkx5.js +3455 -0
  201. package/dist/openclaw-root-YSGWCNem.js +84 -0
  202. package/dist/openclaw-root-_zPXSqgo.js +84 -0
  203. package/dist/pairing-cli-CFqD3IdI.js +122 -0
  204. package/dist/pairing-cli-Cn5vt4oI.js +120 -0
  205. package/dist/pairing-store-BHzy16_t.js +391 -0
  206. package/dist/pairing-store-BOhO49Bi.js +391 -0
  207. package/dist/parse-BZz5lHzQ.js +23 -0
  208. package/dist/parse-Bw0oH-rT.js +23 -0
  209. package/dist/parse-log-line-BxDgv4Uo.js +44 -0
  210. package/dist/parse-log-line-CUrpqe1w.js +44 -0
  211. package/dist/parse-timeout-D1XX_zN_.js +16 -0
  212. package/dist/parse-timeout-Du-wHHNi.js +16 -0
  213. package/dist/path-env-DQ-mM2ya.js +77 -0
  214. package/dist/path-env-eQ-HoQtS.js +77 -0
  215. package/dist/paths-C3yk0MGu.js +43 -0
  216. package/dist/paths-C90k-Dud.js +166 -0
  217. package/dist/paths-CGrNQEMk.js +201 -0
  218. package/dist/paths-D2ytuv-2.js +201 -0
  219. package/dist/paths-Dlp4VNXa.js +40 -0
  220. package/dist/paths-KUslkJRs.js +43 -0
  221. package/dist/pi-embedded-helpers-B7ARjDEK.js +1298 -0
  222. package/dist/pi-embedded-helpers-CQ9sq3Uu.js +8475 -0
  223. package/dist/pi-embedded-helpers-FPVRDeKf.js +1298 -0
  224. package/dist/pi-model-discovery-DWTTaAgY.js +20 -0
  225. package/dist/pi-model-discovery-EhM2JAQo.js +20 -0
  226. package/dist/pi-model-discovery-EwKVHlZB.js +20 -0
  227. package/dist/pi-tools.policy-Du4RZy9R.js +230 -0
  228. package/dist/plugin-auto-enable-EBxTHjFJ.js +461 -0
  229. package/dist/plugin-auto-enable-RwRwIUKC.js +461 -0
  230. package/dist/plugin-sdk/index.d.ts +8453 -0
  231. package/dist/plugin-sdk/index.js +23445 -0
  232. package/dist/plugin-sdk/pi-model-discovery-Dw3A6oXH.js +37 -0
  233. package/dist/plugins-BI-p2ba9.js +495 -0
  234. package/dist/plugins-Dk4UBZwz.js +496 -0
  235. package/dist/plugins-cli-CMg0G56J.js +441 -0
  236. package/dist/plugins-cli-CX7QeUjq.js +443 -0
  237. package/dist/ports-nXmd4Efh.js +96 -0
  238. package/dist/program-EAMJAB_2.js +191 -0
  239. package/dist/progress-D-Oc-KAH.js +133 -0
  240. package/dist/progress-DTEUicRP.js +133 -0
  241. package/dist/prompt-style-BBlJlXtd.js +9 -0
  242. package/dist/prompt-style-BntC_Eoo.js +9 -0
  243. package/dist/prompts-C2D9_VZC.js +10 -0
  244. package/dist/prompts-FbZThK8w.js +10 -0
  245. package/dist/pw-ai-D2jD_dho.js +1651 -0
  246. package/dist/pw-ai-D6JUaD41.js +1650 -0
  247. package/dist/pw-ai-ba2bHPGA.js +1649 -0
  248. package/dist/qmd-manager-B-ijyM7o.js +615 -0
  249. package/dist/qmd-manager-C_Jah5eo.js +618 -0
  250. package/dist/qmd-manager-xo4abL0u.js +618 -0
  251. package/dist/redact-1PNP01B_.js +97 -0
  252. package/dist/redact-BIMJ3ntQ.js +94 -0
  253. package/dist/redact-CVRUv382.js +97 -0
  254. package/dist/register.subclis-CJGimm3-.js +348 -0
  255. package/dist/reply-DfepuqG0.js +61133 -0
  256. package/dist/rolldown-runtime-Cbj13DAv.js +20 -0
  257. package/dist/routes-DkckwrRx.js +2410 -0
  258. package/dist/routes-Q42qtNl1.js +2410 -0
  259. package/dist/rpc-B4lvrGrD.js +95 -0
  260. package/dist/rpc-CbWcXAQK.js +95 -0
  261. package/dist/run-main-JFY3X4Xh.js +194 -0
  262. package/dist/sandbox-BGqDfFaH.js +2945 -0
  263. package/dist/sandbox-D_Tt3WRq.js +2945 -0
  264. package/dist/sandbox-cli-CaxqKiTq.js +461 -0
  265. package/dist/sandbox-cli-DA0Cbrzl.js +463 -0
  266. package/dist/security-cli-BZjA_GAD.js +508 -0
  267. package/dist/security-cli-Ct-pfF2h.js +506 -0
  268. package/dist/server-context-B9ez46MY.js +740 -0
  269. package/dist/server-context-C53lhEx_.js +740 -0
  270. package/dist/server-node-events-Cb6QOeDH.js +218 -0
  271. package/dist/server-node-events-DONmQvJg.js +216 -0
  272. package/dist/service-C0ccl5rU.js +680 -0
  273. package/dist/service-audit-AsnhO40e.js +542 -0
  274. package/dist/service-audit-BM-iyLL7.js +542 -0
  275. package/dist/service-mrQPgOXl.js +680 -0
  276. package/dist/session-cost-usage-B3HzifR9.js +692 -0
  277. package/dist/session-cost-usage-DH3c4xJA.js +692 -0
  278. package/dist/session-key-C-ig2pxJ.js +177 -0
  279. package/dist/session-key-CYpWeuht.js +177 -0
  280. package/dist/shared-CBcCIWC0.js +74 -0
  281. package/dist/shared-CtNMbLRE.js +150 -0
  282. package/dist/shared-DCh7fkR2.js +150 -0
  283. package/dist/shared-Na5zjEUc.js +74 -0
  284. package/dist/skill-scanner-AfOudYI1.js +255 -0
  285. package/dist/skill-scanner-BoGjHXUZ.js +255 -0
  286. package/dist/skills-7V483a6m.js +693 -0
  287. package/dist/skills-CsZRBUj0.js +694 -0
  288. package/dist/skills-cli-DQaq5LBX.js +290 -0
  289. package/dist/skills-cli-dVugbaAb.js +288 -0
  290. package/dist/skills-status-4_4zVBvV.js +187 -0
  291. package/dist/skills-status-cD4rfMR9.js +187 -0
  292. package/dist/sqlite-C4DljFNL.js +215 -0
  293. package/dist/sqlite-CvQzxS7q.js +197 -0
  294. package/dist/sqlite-Dnmf3LS7.js +215 -0
  295. package/dist/status-BakhDLuG.js +27 -0
  296. package/dist/status-BqtiImKF.js +21 -0
  297. package/dist/status-DHPz4Mg_.js +3364 -0
  298. package/dist/status-DSoYX3Ep.js +27 -0
  299. package/dist/status-Drziap9H.js +21 -0
  300. package/dist/subsystem-Btuh5yZj.js +834 -0
  301. package/dist/system-cli-CUQswQPX.js +83 -0
  302. package/dist/system-cli-Cz7in_Xr.js +81 -0
  303. package/dist/systemd-CFHiVC1D.js +438 -0
  304. package/dist/systemd-hints-CgQqk98i.js +19 -0
  305. package/dist/systemd-hints-DKVCFZS3.js +19 -0
  306. package/dist/systemd-kY3NnWdi.js +438 -0
  307. package/dist/systemd-linger-CFK5jDdq.js +75 -0
  308. package/dist/systemd-linger-CxBBzOjC.js +75 -0
  309. package/dist/table-DAOPkdc_.js +279 -0
  310. package/dist/table-DDQGlZSe.js +279 -0
  311. package/dist/tailnet-CZq_ZSNX.js +42 -0
  312. package/dist/tailnet-D5wOWpOX.js +42 -0
  313. package/dist/tailscale-BY0igR48.js +252 -0
  314. package/dist/tailscale-CCLcQalf.js +225 -0
  315. package/dist/tool-display-B2rS2o6B.js +795 -0
  316. package/dist/tool-display-Zbh1CRw5.js +795 -0
  317. package/dist/transcript-events-BOK6eOU8.js +17 -0
  318. package/dist/transcript-events-D2kT5WSz.js +17 -0
  319. package/dist/transcript-events-JLH5W4He.js +17 -0
  320. package/dist/tui-DFVs6pRO.js +2672 -0
  321. package/dist/tui-cli-CBKZVd1C.js +58 -0
  322. package/dist/tui-cli-DexeJOgZ.js +56 -0
  323. package/dist/tui-qPHLsB-x.js +2672 -0
  324. package/dist/update-B2q3duJD.js +317 -0
  325. package/dist/update-DNnej3C6.js +317 -0
  326. package/dist/update-cli-BPUtZjbl.js +1031 -0
  327. package/dist/update-cli-ehTYbpaU.js +1032 -0
  328. package/dist/update-runner-BfncKnU6.js +1375 -0
  329. package/dist/update-runner-DAeygRSU.js +1375 -0
  330. package/dist/usage-format-C4JfTbSp.js +36 -0
  331. package/dist/usage-format-DvowRSs-.js +36 -0
  332. package/dist/utils-7IMqr8vR.js +189 -0
  333. package/dist/utils-D7jskKIf.js +192 -0
  334. package/dist/wallet-manager-7KHKMCbT.js +264 -0
  335. package/dist/wallet-manager-CT1ykq2O.js +264 -0
  336. package/dist/webhooks-cli-C0CV-1jG.js +310 -0
  337. package/dist/webhooks-cli-DT16BygW.js +312 -0
  338. package/dist/widearea-dns-BJZTAyT3.js +127 -0
  339. package/dist/widearea-dns-Dk82I4Xa.js +127 -0
  340. package/dist/ws-6_dFpKWQ.js +13 -0
  341. package/dist/ws-D64QKPe6.js +13 -0
  342. package/dist/ws-log-BhQmGM0R.js +267 -0
  343. package/dist/ws-log-DsyLcTqD.js +267 -0
  344. package/dist/wsl-C24YfxH9.js +160 -0
  345. package/docs/.i18n/README.md +31 -0
  346. package/docs/.i18n/glossary.zh-CN.json +210 -0
  347. package/docs/.i18n/zh-CN.tm.jsonl +1329 -0
  348. package/docs/CNAME +1 -0
  349. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  350. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  351. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  352. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  353. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  354. package/docs/assets/openclaw-logo-text-dark.png +0 -0
  355. package/docs/assets/openclaw-logo-text.png +0 -0
  356. package/docs/assets/pixel-lobster.svg +60 -0
  357. package/docs/assets/showcase/agents-ui.jpg +0 -0
  358. package/docs/assets/showcase/bambu-cli.png +0 -0
  359. package/docs/assets/showcase/codexmonitor.png +0 -0
  360. package/docs/assets/showcase/gohome-grafana.png +0 -0
  361. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  362. package/docs/assets/showcase/oura-health.png +0 -0
  363. package/docs/assets/showcase/padel-cli.svg +11 -0
  364. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  365. package/docs/assets/showcase/papla-tts.jpg +0 -0
  366. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  367. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  368. package/docs/assets/showcase/roborock-status.svg +13 -0
  369. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  370. package/docs/assets/showcase/snag.png +0 -0
  371. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  372. package/docs/assets/showcase/wienerlinien.png +0 -0
  373. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  374. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  375. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  376. package/docs/automation/auth-monitoring.md +44 -0
  377. package/docs/automation/cron-jobs.md +468 -0
  378. package/docs/automation/cron-vs-heartbeat.md +282 -0
  379. package/docs/automation/gmail-pubsub.md +256 -0
  380. package/docs/automation/poll.md +69 -0
  381. package/docs/automation/webhook.md +163 -0
  382. package/docs/bedrock.md +176 -0
  383. package/docs/brave-search.md +41 -0
  384. package/docs/broadcast-groups.md +442 -0
  385. package/docs/channels/bluebubbles.md +338 -0
  386. package/docs/channels/discord.md +476 -0
  387. package/docs/channels/feishu.md +577 -0
  388. package/docs/channels/googlechat.md +250 -0
  389. package/docs/channels/grammy.md +31 -0
  390. package/docs/channels/imessage.md +299 -0
  391. package/docs/channels/index.md +46 -0
  392. package/docs/channels/line.md +186 -0
  393. package/docs/channels/location.md +56 -0
  394. package/docs/channels/matrix.md +233 -0
  395. package/docs/channels/mattermost.md +138 -0
  396. package/docs/channels/msteams.md +768 -0
  397. package/docs/channels/nextcloud-talk.md +136 -0
  398. package/docs/channels/nostr.md +233 -0
  399. package/docs/channels/signal.md +202 -0
  400. package/docs/channels/slack.md +548 -0
  401. package/docs/channels/telegram.md +769 -0
  402. package/docs/channels/tlon.md +132 -0
  403. package/docs/channels/troubleshooting.md +29 -0
  404. package/docs/channels/twitch.md +379 -0
  405. package/docs/channels/whatsapp.md +404 -0
  406. package/docs/channels/zalo.md +189 -0
  407. package/docs/channels/zalouser.md +140 -0
  408. package/docs/cli/acp.md +170 -0
  409. package/docs/cli/agent.md +24 -0
  410. package/docs/cli/agents.md +75 -0
  411. package/docs/cli/approvals.md +50 -0
  412. package/docs/cli/browser.md +107 -0
  413. package/docs/cli/channels.md +79 -0
  414. package/docs/cli/config.md +50 -0
  415. package/docs/cli/configure.md +33 -0
  416. package/docs/cli/cron.md +42 -0
  417. package/docs/cli/dashboard.md +16 -0
  418. package/docs/cli/devices.md +70 -0
  419. package/docs/cli/directory.md +63 -0
  420. package/docs/cli/dns.md +23 -0
  421. package/docs/cli/docs.md +15 -0
  422. package/docs/cli/doctor.md +41 -0
  423. package/docs/cli/gateway.md +202 -0
  424. package/docs/cli/health.md +21 -0
  425. package/docs/cli/hooks.md +304 -0
  426. package/docs/cli/index.md +1031 -0
  427. package/docs/cli/logs.md +24 -0
  428. package/docs/cli/memory.md +45 -0
  429. package/docs/cli/message.md +239 -0
  430. package/docs/cli/models.md +79 -0
  431. package/docs/cli/node.md +112 -0
  432. package/docs/cli/nodes.md +73 -0
  433. package/docs/cli/onboard.md +43 -0
  434. package/docs/cli/pairing.md +21 -0
  435. package/docs/cli/plugins.md +62 -0
  436. package/docs/cli/reset.md +17 -0
  437. package/docs/cli/sandbox.md +152 -0
  438. package/docs/cli/security.md +26 -0
  439. package/docs/cli/sessions.md +16 -0
  440. package/docs/cli/setup.md +29 -0
  441. package/docs/cli/skills.md +26 -0
  442. package/docs/cli/status.md +26 -0
  443. package/docs/cli/system.md +60 -0
  444. package/docs/cli/tui.md +23 -0
  445. package/docs/cli/uninstall.md +17 -0
  446. package/docs/cli/update.md +98 -0
  447. package/docs/cli/voicecall.md +34 -0
  448. package/docs/cli/webhooks.md +25 -0
  449. package/docs/concepts/agent-loop.md +146 -0
  450. package/docs/concepts/agent-workspace.md +233 -0
  451. package/docs/concepts/agent.md +123 -0
  452. package/docs/concepts/architecture.md +129 -0
  453. package/docs/concepts/channel-routing.md +114 -0
  454. package/docs/concepts/compaction.md +61 -0
  455. package/docs/concepts/context.md +161 -0
  456. package/docs/concepts/features.md +53 -0
  457. package/docs/concepts/group-messages.md +84 -0
  458. package/docs/concepts/groups.md +373 -0
  459. package/docs/concepts/markdown-formatting.md +130 -0
  460. package/docs/concepts/memory.md +546 -0
  461. package/docs/concepts/messages.md +154 -0
  462. package/docs/concepts/model-failover.md +149 -0
  463. package/docs/concepts/model-providers.md +316 -0
  464. package/docs/concepts/models.md +208 -0
  465. package/docs/concepts/multi-agent.md +376 -0
  466. package/docs/concepts/oauth.md +145 -0
  467. package/docs/concepts/presence.md +102 -0
  468. package/docs/concepts/queue.md +89 -0
  469. package/docs/concepts/retry.md +69 -0
  470. package/docs/concepts/session-pruning.md +122 -0
  471. package/docs/concepts/session-tool.md +193 -0
  472. package/docs/concepts/session.md +204 -0
  473. package/docs/concepts/sessions.md +10 -0
  474. package/docs/concepts/streaming.md +135 -0
  475. package/docs/concepts/system-prompt.md +115 -0
  476. package/docs/concepts/timezone.md +91 -0
  477. package/docs/concepts/typebox.md +289 -0
  478. package/docs/concepts/typing-indicators.md +68 -0
  479. package/docs/concepts/usage-tracking.md +35 -0
  480. package/docs/date-time.md +128 -0
  481. package/docs/debug/node-issue.md +83 -0
  482. package/docs/debugging.md +162 -0
  483. package/docs/diagnostics/flags.md +91 -0
  484. package/docs/docs.json +1736 -0
  485. package/docs/environment.md +81 -0
  486. package/docs/experiments/onboarding-config-protocol.md +40 -0
  487. package/docs/experiments/plans/cron-add-hardening.md +63 -0
  488. package/docs/experiments/plans/group-policy-hardening.md +40 -0
  489. package/docs/experiments/plans/openresponses-gateway.md +123 -0
  490. package/docs/experiments/proposals/model-config.md +36 -0
  491. package/docs/experiments/research/memory.md +228 -0
  492. package/docs/gateway/authentication.md +145 -0
  493. package/docs/gateway/background-process.md +93 -0
  494. package/docs/gateway/bonjour.md +167 -0
  495. package/docs/gateway/bridge-protocol.md +89 -0
  496. package/docs/gateway/cli-backends.md +225 -0
  497. package/docs/gateway/configuration-examples.md +606 -0
  498. package/docs/gateway/configuration.md +3411 -0
  499. package/docs/gateway/discovery.md +116 -0
  500. package/docs/gateway/doctor.md +282 -0
  501. package/docs/gateway/gateway-lock.md +34 -0
  502. package/docs/gateway/health.md +35 -0
  503. package/docs/gateway/heartbeat.md +362 -0
  504. package/docs/gateway/index.md +328 -0
  505. package/docs/gateway/local-models.md +150 -0
  506. package/docs/gateway/logging.md +113 -0
  507. package/docs/gateway/multiple-gateways.md +112 -0
  508. package/docs/gateway/network-model.md +17 -0
  509. package/docs/gateway/openai-http-api.md +118 -0
  510. package/docs/gateway/openresponses-http-api.md +317 -0
  511. package/docs/gateway/pairing.md +99 -0
  512. package/docs/gateway/protocol.md +221 -0
  513. package/docs/gateway/remote-gateway-readme.md +157 -0
  514. package/docs/gateway/remote.md +129 -0
  515. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +128 -0
  516. package/docs/gateway/sandboxing.md +193 -0
  517. package/docs/gateway/security/formal-verification.md +164 -0
  518. package/docs/gateway/security/index.md +825 -0
  519. package/docs/gateway/tailscale.md +127 -0
  520. package/docs/gateway/tools-invoke-http-api.md +85 -0
  521. package/docs/gateway/troubleshooting.md +767 -0
  522. package/docs/help/faq.md +2829 -0
  523. package/docs/help/index.md +21 -0
  524. package/docs/help/troubleshooting.md +98 -0
  525. package/docs/hooks/soul-evil.md +69 -0
  526. package/docs/hooks.md +913 -0
  527. package/docs/images/feishu-step2-create-app.png +0 -0
  528. package/docs/images/feishu-step3-credentials.png +0 -0
  529. package/docs/images/feishu-step4-permissions.png +0 -0
  530. package/docs/images/feishu-step5-bot-capability.png +0 -0
  531. package/docs/images/feishu-step6-event-subscription.png +0 -0
  532. package/docs/images/groups-flow.svg +52 -0
  533. package/docs/images/mobile-ui-screenshot.png +0 -0
  534. package/docs/index.md +192 -0
  535. package/docs/install/ansible.md +208 -0
  536. package/docs/install/bun.md +59 -0
  537. package/docs/install/development-channels.md +75 -0
  538. package/docs/install/docker.md +567 -0
  539. package/docs/install/exe-dev.md +126 -0
  540. package/docs/install/fly.md +486 -0
  541. package/docs/install/gcp.md +503 -0
  542. package/docs/install/hetzner.md +330 -0
  543. package/docs/install/index.md +187 -0
  544. package/docs/install/installer.md +123 -0
  545. package/docs/install/macos-vm.md +281 -0
  546. package/docs/install/migrating.md +192 -0
  547. package/docs/install/nix.md +96 -0
  548. package/docs/install/node.md +78 -0
  549. package/docs/install/northflank.mdx +53 -0
  550. package/docs/install/railway.mdx +99 -0
  551. package/docs/install/render.mdx +165 -0
  552. package/docs/install/uninstall.md +128 -0
  553. package/docs/install/updating.md +228 -0
  554. package/docs/logging.md +350 -0
  555. package/docs/multi-agent-sandbox-tools.md +395 -0
  556. package/docs/network.md +54 -0
  557. package/docs/nodes/audio.md +114 -0
  558. package/docs/nodes/camera.md +156 -0
  559. package/docs/nodes/images.md +72 -0
  560. package/docs/nodes/index.md +341 -0
  561. package/docs/nodes/location-command.md +113 -0
  562. package/docs/nodes/media-understanding.md +379 -0
  563. package/docs/nodes/talk.md +90 -0
  564. package/docs/nodes/voicewake.md +65 -0
  565. package/docs/perplexity.md +80 -0
  566. package/docs/pi-dev.md +70 -0
  567. package/docs/pi.md +612 -0
  568. package/docs/platforms/android.md +148 -0
  569. package/docs/platforms/digitalocean.md +262 -0
  570. package/docs/platforms/index.md +53 -0
  571. package/docs/platforms/ios.md +107 -0
  572. package/docs/platforms/linux.md +94 -0
  573. package/docs/platforms/mac/bundled-gateway.md +73 -0
  574. package/docs/platforms/mac/canvas.md +125 -0
  575. package/docs/platforms/mac/child-process.md +69 -0
  576. package/docs/platforms/mac/dev-setup.md +102 -0
  577. package/docs/platforms/mac/health.md +34 -0
  578. package/docs/platforms/mac/icon.md +31 -0
  579. package/docs/platforms/mac/logging.md +57 -0
  580. package/docs/platforms/mac/menu-bar.md +81 -0
  581. package/docs/platforms/mac/peekaboo.md +65 -0
  582. package/docs/platforms/mac/permissions.md +44 -0
  583. package/docs/platforms/mac/release.md +85 -0
  584. package/docs/platforms/mac/remote.md +83 -0
  585. package/docs/platforms/mac/signing.md +47 -0
  586. package/docs/platforms/mac/skills.md +33 -0
  587. package/docs/platforms/mac/voice-overlay.md +60 -0
  588. package/docs/platforms/mac/voicewake.md +67 -0
  589. package/docs/platforms/mac/webchat.md +41 -0
  590. package/docs/platforms/mac/xpc.md +61 -0
  591. package/docs/platforms/macos.md +203 -0
  592. package/docs/platforms/oracle.md +303 -0
  593. package/docs/platforms/raspberry-pi.md +358 -0
  594. package/docs/platforms/windows.md +159 -0
  595. package/docs/plugin.md +664 -0
  596. package/docs/plugins/agent-tools.md +99 -0
  597. package/docs/plugins/manifest.md +71 -0
  598. package/docs/plugins/voice-call.md +284 -0
  599. package/docs/plugins/zalouser.md +81 -0
  600. package/docs/prose.md +134 -0
  601. package/docs/providers/anthropic.md +152 -0
  602. package/docs/providers/claude-max-api-proxy.md +148 -0
  603. package/docs/providers/cloudflare-ai-gateway.md +71 -0
  604. package/docs/providers/deepgram.md +93 -0
  605. package/docs/providers/github-copilot.md +72 -0
  606. package/docs/providers/glm.md +33 -0
  607. package/docs/providers/index.md +63 -0
  608. package/docs/providers/minimax.md +208 -0
  609. package/docs/providers/models.md +51 -0
  610. package/docs/providers/moonshot.md +142 -0
  611. package/docs/providers/ollama.md +277 -0
  612. package/docs/providers/openai.md +62 -0
  613. package/docs/providers/opencode.md +36 -0
  614. package/docs/providers/openrouter.md +37 -0
  615. package/docs/providers/qwen.md +53 -0
  616. package/docs/providers/synthetic.md +99 -0
  617. package/docs/providers/venice.md +267 -0
  618. package/docs/providers/vercel-ai-gateway.md +50 -0
  619. package/docs/providers/xiaomi.md +64 -0
  620. package/docs/providers/zai.md +36 -0
  621. package/docs/refactor/clawnet.md +417 -0
  622. package/docs/refactor/exec-host.md +316 -0
  623. package/docs/refactor/outbound-session-mirroring.md +85 -0
  624. package/docs/refactor/plugin-sdk.md +214 -0
  625. package/docs/refactor/strict-config.md +93 -0
  626. package/docs/reference/AGENTS.default.md +124 -0
  627. package/docs/reference/RELEASING.md +120 -0
  628. package/docs/reference/api-usage-costs.md +137 -0
  629. package/docs/reference/credits.md +27 -0
  630. package/docs/reference/device-models.md +47 -0
  631. package/docs/reference/rpc.md +43 -0
  632. package/docs/reference/session-management-compaction.md +285 -0
  633. package/docs/reference/templates/AGENTS.dev.md +83 -0
  634. package/docs/reference/templates/AGENTS.md +218 -0
  635. package/docs/reference/templates/BOOT.md +10 -0
  636. package/docs/reference/templates/BOOTSTRAP.md +61 -0
  637. package/docs/reference/templates/HEARTBEAT.md +11 -0
  638. package/docs/reference/templates/IDENTITY.dev.md +47 -0
  639. package/docs/reference/templates/IDENTITY.md +27 -0
  640. package/docs/reference/templates/SOUL.dev.md +76 -0
  641. package/docs/reference/templates/SOUL.md +42 -0
  642. package/docs/reference/templates/TOOLS.dev.md +24 -0
  643. package/docs/reference/templates/TOOLS.md +46 -0
  644. package/docs/reference/templates/USER.dev.md +18 -0
  645. package/docs/reference/templates/USER.md +22 -0
  646. package/docs/reference/test.md +50 -0
  647. package/docs/reference/transcript-hygiene.md +129 -0
  648. package/docs/reference/wizard.md +268 -0
  649. package/docs/scripts.md +28 -0
  650. package/docs/security/formal-verification.md +164 -0
  651. package/docs/start/bootstrapping.md +41 -0
  652. package/docs/start/docs-directory.md +64 -0
  653. package/docs/start/getting-started.md +120 -0
  654. package/docs/start/hubs.md +197 -0
  655. package/docs/start/lore.md +219 -0
  656. package/docs/start/onboarding.md +80 -0
  657. package/docs/start/openclaw.md +224 -0
  658. package/docs/start/pairing.md +86 -0
  659. package/docs/start/quickstart.md +22 -0
  660. package/docs/start/setup.md +162 -0
  661. package/docs/start/showcase.md +416 -0
  662. package/docs/start/wizard-cli-automation.md +141 -0
  663. package/docs/start/wizard-cli-reference.md +244 -0
  664. package/docs/start/wizard.md +108 -0
  665. package/docs/style.css +3 -0
  666. package/docs/testing.md +368 -0
  667. package/docs/token-use.md +112 -0
  668. package/docs/tools/agent-send.md +53 -0
  669. package/docs/tools/apply-patch.md +50 -0
  670. package/docs/tools/browser-linux-troubleshooting.md +139 -0
  671. package/docs/tools/browser-login.md +68 -0
  672. package/docs/tools/browser.md +576 -0
  673. package/docs/tools/chrome-extension.md +178 -0
  674. package/docs/tools/clawhub.md +257 -0
  675. package/docs/tools/creating-skills.md +54 -0
  676. package/docs/tools/elevated.md +57 -0
  677. package/docs/tools/exec-approvals.md +246 -0
  678. package/docs/tools/exec.md +179 -0
  679. package/docs/tools/firecrawl.md +61 -0
  680. package/docs/tools/index.md +512 -0
  681. package/docs/tools/llm-task.md +115 -0
  682. package/docs/tools/lobster.md +342 -0
  683. package/docs/tools/reactions.md +22 -0
  684. package/docs/tools/skills-config.md +76 -0
  685. package/docs/tools/skills.md +300 -0
  686. package/docs/tools/slash-commands.md +198 -0
  687. package/docs/tools/subagents.md +151 -0
  688. package/docs/tools/thinking.md +74 -0
  689. package/docs/tools/web.md +261 -0
  690. package/docs/tts.md +396 -0
  691. package/docs/tui.md +162 -0
  692. package/docs/vps.md +43 -0
  693. package/docs/web/control-ui.md +223 -0
  694. package/docs/web/dashboard.md +46 -0
  695. package/docs/web/index.md +116 -0
  696. package/docs/web/webchat.md +49 -0
  697. package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
  698. package/docs/whatsapp-openclaw.jpg +0 -0
  699. package/docs/zh-CN/AGENTS.md +59 -0
  700. package/docs/zh-CN/automation/auth-monitoring.md +47 -0
  701. package/docs/zh-CN/automation/cron-jobs.md +424 -0
  702. package/docs/zh-CN/automation/cron-vs-heartbeat.md +286 -0
  703. package/docs/zh-CN/automation/gmail-pubsub.md +249 -0
  704. package/docs/zh-CN/automation/poll.md +76 -0
  705. package/docs/zh-CN/automation/webhook.md +163 -0
  706. package/docs/zh-CN/bedrock.md +170 -0
  707. package/docs/zh-CN/brave-search.md +48 -0
  708. package/docs/zh-CN/broadcast-groups.md +449 -0
  709. package/docs/zh-CN/channels/bluebubbles.md +271 -0
  710. package/docs/zh-CN/channels/discord.md +468 -0
  711. package/docs/zh-CN/channels/feishu.md +629 -0
  712. package/docs/zh-CN/channels/googlechat.md +257 -0
  713. package/docs/zh-CN/channels/grammy.md +38 -0
  714. package/docs/zh-CN/channels/imessage.md +302 -0
  715. package/docs/zh-CN/channels/index.md +53 -0
  716. package/docs/zh-CN/channels/line.md +180 -0
  717. package/docs/zh-CN/channels/location.md +63 -0
  718. package/docs/zh-CN/channels/matrix.md +221 -0
  719. package/docs/zh-CN/channels/mattermost.md +144 -0
  720. package/docs/zh-CN/channels/msteams.md +775 -0
  721. package/docs/zh-CN/channels/nextcloud-talk.md +142 -0
  722. package/docs/zh-CN/channels/nostr.md +240 -0
  723. package/docs/zh-CN/channels/signal.md +209 -0
  724. package/docs/zh-CN/channels/slack.md +531 -0
  725. package/docs/zh-CN/channels/telegram.md +751 -0
  726. package/docs/zh-CN/channels/tlon.md +136 -0
  727. package/docs/zh-CN/channels/troubleshooting.md +36 -0
  728. package/docs/zh-CN/channels/twitch.md +385 -0
  729. package/docs/zh-CN/channels/whatsapp.md +411 -0
  730. package/docs/zh-CN/channels/zalo.md +196 -0
  731. package/docs/zh-CN/channels/zalouser.md +147 -0
  732. package/docs/zh-CN/cli/acp.md +173 -0
  733. package/docs/zh-CN/cli/agent.md +30 -0
  734. package/docs/zh-CN/cli/agents.md +82 -0
  735. package/docs/zh-CN/cli/approvals.md +57 -0
  736. package/docs/zh-CN/cli/browser.md +114 -0
  737. package/docs/zh-CN/cli/channels.md +86 -0
  738. package/docs/zh-CN/cli/config.md +57 -0
  739. package/docs/zh-CN/cli/configure.md +38 -0
  740. package/docs/zh-CN/cli/cron.md +43 -0
  741. package/docs/zh-CN/cli/dashboard.md +23 -0
  742. package/docs/zh-CN/cli/devices.md +74 -0
  743. package/docs/zh-CN/cli/directory.md +70 -0
  744. package/docs/zh-CN/cli/dns.md +30 -0
  745. package/docs/zh-CN/cli/docs.md +22 -0
  746. package/docs/zh-CN/cli/doctor.md +48 -0
  747. package/docs/zh-CN/cli/gateway.md +206 -0
  748. package/docs/zh-CN/cli/health.md +28 -0
  749. package/docs/zh-CN/cli/hooks.md +311 -0
  750. package/docs/zh-CN/cli/index.md +1032 -0
  751. package/docs/zh-CN/cli/logs.md +31 -0
  752. package/docs/zh-CN/cli/memory.md +52 -0
  753. package/docs/zh-CN/cli/message.md +246 -0
  754. package/docs/zh-CN/cli/models.md +85 -0
  755. package/docs/zh-CN/cli/node.md +115 -0
  756. package/docs/zh-CN/cli/nodes.md +80 -0
  757. package/docs/zh-CN/cli/onboard.md +36 -0
  758. package/docs/zh-CN/cli/pairing.md +28 -0
  759. package/docs/zh-CN/cli/plugins.md +66 -0
  760. package/docs/zh-CN/cli/reset.md +24 -0
  761. package/docs/zh-CN/cli/sandbox.md +158 -0
  762. package/docs/zh-CN/cli/security.md +33 -0
  763. package/docs/zh-CN/cli/sessions.md +23 -0
  764. package/docs/zh-CN/cli/setup.md +36 -0
  765. package/docs/zh-CN/cli/skills.md +33 -0
  766. package/docs/zh-CN/cli/status.md +33 -0
  767. package/docs/zh-CN/cli/system.md +63 -0
  768. package/docs/zh-CN/cli/tui.md +30 -0
  769. package/docs/zh-CN/cli/uninstall.md +24 -0
  770. package/docs/zh-CN/cli/update.md +101 -0
  771. package/docs/zh-CN/cli/voicecall.md +41 -0
  772. package/docs/zh-CN/cli/webhooks.md +32 -0
  773. package/docs/zh-CN/concepts/agent-loop.md +146 -0
  774. package/docs/zh-CN/concepts/agent-workspace.md +219 -0
  775. package/docs/zh-CN/concepts/agent.md +115 -0
  776. package/docs/zh-CN/concepts/architecture.md +123 -0
  777. package/docs/zh-CN/concepts/channel-routing.md +117 -0
  778. package/docs/zh-CN/concepts/compaction.md +67 -0
  779. package/docs/zh-CN/concepts/context.md +168 -0
  780. package/docs/zh-CN/concepts/features.md +59 -0
  781. package/docs/zh-CN/concepts/group-messages.md +91 -0
  782. package/docs/zh-CN/concepts/groups.md +379 -0
  783. package/docs/zh-CN/concepts/markdown-formatting.md +117 -0
  784. package/docs/zh-CN/concepts/memory.md +412 -0
  785. package/docs/zh-CN/concepts/messages.md +141 -0
  786. package/docs/zh-CN/concepts/model-failover.md +145 -0
  787. package/docs/zh-CN/concepts/model-providers.md +320 -0
  788. package/docs/zh-CN/concepts/models.md +196 -0
  789. package/docs/zh-CN/concepts/multi-agent.md +372 -0
  790. package/docs/zh-CN/concepts/oauth.md +151 -0
  791. package/docs/zh-CN/concepts/presence.md +99 -0
  792. package/docs/zh-CN/concepts/queue.md +94 -0
  793. package/docs/zh-CN/concepts/retry.md +76 -0
  794. package/docs/zh-CN/concepts/session-pruning.md +129 -0
  795. package/docs/zh-CN/concepts/session-tool.md +200 -0
  796. package/docs/zh-CN/concepts/session.md +166 -0
  797. package/docs/zh-CN/concepts/sessions.md +17 -0
  798. package/docs/zh-CN/concepts/streaming.md +133 -0
  799. package/docs/zh-CN/concepts/system-prompt.md +101 -0
  800. package/docs/zh-CN/concepts/timezone.md +96 -0
  801. package/docs/zh-CN/concepts/typebox.md +284 -0
  802. package/docs/zh-CN/concepts/typing-indicators.md +74 -0
  803. package/docs/zh-CN/concepts/usage-tracking.md +42 -0
  804. package/docs/zh-CN/date-time.md +129 -0
  805. package/docs/zh-CN/debug/node-issue.md +90 -0
  806. package/docs/zh-CN/debugging.md +160 -0
  807. package/docs/zh-CN/diagnostics/flags.md +98 -0
  808. package/docs/zh-CN/environment.md +88 -0
  809. package/docs/zh-CN/experiments/onboarding-config-protocol.md +47 -0
  810. package/docs/zh-CN/experiments/plans/cron-add-hardening.md +70 -0
  811. package/docs/zh-CN/experiments/plans/group-policy-hardening.md +45 -0
  812. package/docs/zh-CN/experiments/plans/openresponses-gateway.md +121 -0
  813. package/docs/zh-CN/experiments/proposals/model-config.md +42 -0
  814. package/docs/zh-CN/experiments/research/memory.md +235 -0
  815. package/docs/zh-CN/gateway/authentication.md +142 -0
  816. package/docs/zh-CN/gateway/background-process.md +100 -0
  817. package/docs/zh-CN/gateway/bonjour.md +174 -0
  818. package/docs/zh-CN/gateway/bridge-protocol.md +86 -0
  819. package/docs/zh-CN/gateway/cli-backends.md +213 -0
  820. package/docs/zh-CN/gateway/configuration-examples.md +587 -0
  821. package/docs/zh-CN/gateway/configuration.md +3332 -0
  822. package/docs/zh-CN/gateway/discovery.md +123 -0
  823. package/docs/zh-CN/gateway/doctor.md +238 -0
  824. package/docs/zh-CN/gateway/gateway-lock.md +41 -0
  825. package/docs/zh-CN/gateway/health.md +42 -0
  826. package/docs/zh-CN/gateway/heartbeat.md +274 -0
  827. package/docs/zh-CN/gateway/index.md +335 -0
  828. package/docs/zh-CN/gateway/local-models.md +157 -0
  829. package/docs/zh-CN/gateway/logging.md +114 -0
  830. package/docs/zh-CN/gateway/multiple-gateways.md +119 -0
  831. package/docs/zh-CN/gateway/network-model.md +23 -0
  832. package/docs/zh-CN/gateway/openai-http-api.md +125 -0
  833. package/docs/zh-CN/gateway/openresponses-http-api.md +317 -0
  834. package/docs/zh-CN/gateway/pairing.md +99 -0
  835. package/docs/zh-CN/gateway/protocol.md +220 -0
  836. package/docs/zh-CN/gateway/remote-gateway-readme.md +164 -0
  837. package/docs/zh-CN/gateway/remote.md +133 -0
  838. package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +135 -0
  839. package/docs/zh-CN/gateway/sandboxing.md +188 -0
  840. package/docs/zh-CN/gateway/security/formal-verification.md +169 -0
  841. package/docs/zh-CN/gateway/security/index.md +777 -0
  842. package/docs/zh-CN/gateway/tailscale.md +124 -0
  843. package/docs/zh-CN/gateway/tools-invoke-http-api.md +92 -0
  844. package/docs/zh-CN/gateway/troubleshooting.md +771 -0
  845. package/docs/zh-CN/help/faq.md +2628 -0
  846. package/docs/zh-CN/help/index.md +28 -0
  847. package/docs/zh-CN/help/troubleshooting.md +104 -0
  848. package/docs/zh-CN/hooks/soul-evil.md +72 -0
  849. package/docs/zh-CN/hooks.md +919 -0
  850. package/docs/zh-CN/index.md +186 -0
  851. package/docs/zh-CN/install/ansible.md +215 -0
  852. package/docs/zh-CN/install/bun.md +65 -0
  853. package/docs/zh-CN/install/development-channels.md +81 -0
  854. package/docs/zh-CN/install/docker.md +532 -0
  855. package/docs/zh-CN/install/exe-dev.md +127 -0
  856. package/docs/zh-CN/install/fly.md +490 -0
  857. package/docs/zh-CN/install/gcp.md +510 -0
  858. package/docs/zh-CN/install/hetzner.md +337 -0
  859. package/docs/zh-CN/install/index.md +193 -0
  860. package/docs/zh-CN/install/installer.md +128 -0
  861. package/docs/zh-CN/install/macos-vm.md +288 -0
  862. package/docs/zh-CN/install/migrating.md +199 -0
  863. package/docs/zh-CN/install/nix.md +99 -0
  864. package/docs/zh-CN/install/node.md +85 -0
  865. package/docs/zh-CN/install/northflank.mdx +60 -0
  866. package/docs/zh-CN/install/railway.mdx +106 -0
  867. package/docs/zh-CN/install/render.mdx +169 -0
  868. package/docs/zh-CN/install/uninstall.md +135 -0
  869. package/docs/zh-CN/install/updating.md +233 -0
  870. package/docs/zh-CN/logging.md +329 -0
  871. package/docs/zh-CN/multi-agent-sandbox-tools.md +401 -0
  872. package/docs/zh-CN/network.md +59 -0
  873. package/docs/zh-CN/nodes/audio.md +120 -0
  874. package/docs/zh-CN/nodes/camera.md +162 -0
  875. package/docs/zh-CN/nodes/images.md +79 -0
  876. package/docs/zh-CN/nodes/index.md +348 -0
  877. package/docs/zh-CN/nodes/location-command.md +120 -0
  878. package/docs/zh-CN/nodes/media-understanding.md +380 -0
  879. package/docs/zh-CN/nodes/talk.md +97 -0
  880. package/docs/zh-CN/nodes/voicewake.md +72 -0
  881. package/docs/zh-CN/perplexity.md +84 -0
  882. package/docs/zh-CN/pi-dev.md +77 -0
  883. package/docs/zh-CN/pi.md +619 -0
  884. package/docs/zh-CN/platforms/android.md +155 -0
  885. package/docs/zh-CN/platforms/digitalocean.md +269 -0
  886. package/docs/zh-CN/platforms/index.md +60 -0
  887. package/docs/zh-CN/platforms/ios.md +114 -0
  888. package/docs/zh-CN/platforms/linux.md +101 -0
  889. package/docs/zh-CN/platforms/mac/bundled-gateway.md +75 -0
  890. package/docs/zh-CN/platforms/mac/canvas.md +128 -0
  891. package/docs/zh-CN/platforms/mac/child-process.md +73 -0
  892. package/docs/zh-CN/platforms/mac/dev-setup.md +109 -0
  893. package/docs/zh-CN/platforms/mac/health.md +41 -0
  894. package/docs/zh-CN/platforms/mac/icon.md +38 -0
  895. package/docs/zh-CN/platforms/mac/logging.md +64 -0
  896. package/docs/zh-CN/platforms/mac/menu-bar.md +88 -0
  897. package/docs/zh-CN/platforms/mac/peekaboo.md +62 -0
  898. package/docs/zh-CN/platforms/mac/permissions.md +46 -0
  899. package/docs/zh-CN/platforms/mac/release.md +92 -0
  900. package/docs/zh-CN/platforms/mac/remote.md +90 -0
  901. package/docs/zh-CN/platforms/mac/signing.md +54 -0
  902. package/docs/zh-CN/platforms/mac/skills.md +40 -0
  903. package/docs/zh-CN/platforms/mac/voice-overlay.md +67 -0
  904. package/docs/zh-CN/platforms/mac/voicewake.md +74 -0
  905. package/docs/zh-CN/platforms/mac/webchat.md +43 -0
  906. package/docs/zh-CN/platforms/mac/xpc.md +68 -0
  907. package/docs/zh-CN/platforms/macos.md +193 -0
  908. package/docs/zh-CN/platforms/oracle.md +310 -0
  909. package/docs/zh-CN/platforms/raspberry-pi.md +365 -0
  910. package/docs/zh-CN/platforms/windows.md +156 -0
  911. package/docs/zh-CN/plugin.md +639 -0
  912. package/docs/zh-CN/plugins/agent-tools.md +99 -0
  913. package/docs/zh-CN/plugins/manifest.md +68 -0
  914. package/docs/zh-CN/plugins/voice-call.md +250 -0
  915. package/docs/zh-CN/plugins/zalouser.md +88 -0
  916. package/docs/zh-CN/prose.md +141 -0
  917. package/docs/zh-CN/providers/anthropic.md +159 -0
  918. package/docs/zh-CN/providers/claude-max-api-proxy.md +155 -0
  919. package/docs/zh-CN/providers/deepgram.md +97 -0
  920. package/docs/zh-CN/providers/github-copilot.md +67 -0
  921. package/docs/zh-CN/providers/glm.md +39 -0
  922. package/docs/zh-CN/providers/index.md +68 -0
  923. package/docs/zh-CN/providers/minimax.md +206 -0
  924. package/docs/zh-CN/providers/models.md +55 -0
  925. package/docs/zh-CN/providers/moonshot.md +145 -0
  926. package/docs/zh-CN/providers/ollama.md +230 -0
  927. package/docs/zh-CN/providers/openai.md +68 -0
  928. package/docs/zh-CN/providers/opencode.md +41 -0
  929. package/docs/zh-CN/providers/openrouter.md +43 -0
  930. package/docs/zh-CN/providers/qwen.md +55 -0
  931. package/docs/zh-CN/providers/synthetic.md +102 -0
  932. package/docs/zh-CN/providers/venice.md +274 -0
  933. package/docs/zh-CN/providers/vercel-ai-gateway.md +57 -0
  934. package/docs/zh-CN/providers/xiaomi.md +68 -0
  935. package/docs/zh-CN/providers/zai.md +41 -0
  936. package/docs/zh-CN/refactor/clawnet.md +424 -0
  937. package/docs/zh-CN/refactor/exec-host.md +323 -0
  938. package/docs/zh-CN/refactor/outbound-session-mirroring.md +92 -0
  939. package/docs/zh-CN/refactor/plugin-sdk.md +221 -0
  940. package/docs/zh-CN/refactor/strict-config.md +100 -0
  941. package/docs/zh-CN/reference/AGENTS.default.md +131 -0
  942. package/docs/zh-CN/reference/RELEASING.md +123 -0
  943. package/docs/zh-CN/reference/api-usage-costs.md +136 -0
  944. package/docs/zh-CN/reference/credits.md +34 -0
  945. package/docs/zh-CN/reference/device-models.md +54 -0
  946. package/docs/zh-CN/reference/rpc.md +48 -0
  947. package/docs/zh-CN/reference/session-management-compaction.md +287 -0
  948. package/docs/zh-CN/reference/templates/AGENTS.dev.md +89 -0
  949. package/docs/zh-CN/reference/templates/AGENTS.md +225 -0
  950. package/docs/zh-CN/reference/templates/BOOT.md +17 -0
  951. package/docs/zh-CN/reference/templates/BOOTSTRAP.md +68 -0
  952. package/docs/zh-CN/reference/templates/HEARTBEAT.md +18 -0
  953. package/docs/zh-CN/reference/templates/IDENTITY.dev.md +54 -0
  954. package/docs/zh-CN/reference/templates/IDENTITY.md +35 -0
  955. package/docs/zh-CN/reference/templates/SOUL.dev.md +83 -0
  956. package/docs/zh-CN/reference/templates/SOUL.md +49 -0
  957. package/docs/zh-CN/reference/templates/TOOLS.dev.md +31 -0
  958. package/docs/zh-CN/reference/templates/TOOLS.md +53 -0
  959. package/docs/zh-CN/reference/templates/USER.dev.md +25 -0
  960. package/docs/zh-CN/reference/templates/USER.md +30 -0
  961. package/docs/zh-CN/reference/test.md +57 -0
  962. package/docs/zh-CN/reference/transcript-hygiene.md +109 -0
  963. package/docs/zh-CN/scripts.md +35 -0
  964. package/docs/zh-CN/security/formal-verification.md +171 -0
  965. package/docs/zh-CN/start/docs-directory.md +70 -0
  966. package/docs/zh-CN/start/getting-started.md +206 -0
  967. package/docs/zh-CN/start/hubs.md +200 -0
  968. package/docs/zh-CN/start/lore.md +226 -0
  969. package/docs/zh-CN/start/onboarding.md +105 -0
  970. package/docs/zh-CN/start/openclaw.md +248 -0
  971. package/docs/zh-CN/start/pairing.md +89 -0
  972. package/docs/zh-CN/start/quickstart.md +88 -0
  973. package/docs/zh-CN/start/setup.md +153 -0
  974. package/docs/zh-CN/start/showcase.md +423 -0
  975. package/docs/zh-CN/start/wizard.md +331 -0
  976. package/docs/zh-CN/testing.md +375 -0
  977. package/docs/zh-CN/token-use.md +119 -0
  978. package/docs/zh-CN/tools/agent-send.md +59 -0
  979. package/docs/zh-CN/tools/apply-patch.md +57 -0
  980. package/docs/zh-CN/tools/browser-linux-troubleshooting.md +144 -0
  981. package/docs/zh-CN/tools/browser-login.md +75 -0
  982. package/docs/zh-CN/tools/browser.md +553 -0
  983. package/docs/zh-CN/tools/chrome-extension.md +183 -0
  984. package/docs/zh-CN/tools/clawhub.md +209 -0
  985. package/docs/zh-CN/tools/creating-skills.md +61 -0
  986. package/docs/zh-CN/tools/elevated.md +64 -0
  987. package/docs/zh-CN/tools/exec-approvals.md +234 -0
  988. package/docs/zh-CN/tools/exec.md +169 -0
  989. package/docs/zh-CN/tools/firecrawl.md +68 -0
  990. package/docs/zh-CN/tools/index.md +515 -0
  991. package/docs/zh-CN/tools/llm-task.md +117 -0
  992. package/docs/zh-CN/tools/lobster.md +349 -0
  993. package/docs/zh-CN/tools/reactions.md +29 -0
  994. package/docs/zh-CN/tools/skills-config.md +78 -0
  995. package/docs/zh-CN/tools/skills.md +279 -0
  996. package/docs/zh-CN/tools/slash-commands.md +205 -0
  997. package/docs/zh-CN/tools/subagents.md +156 -0
  998. package/docs/zh-CN/tools/thinking.md +80 -0
  999. package/docs/zh-CN/tools/web.md +257 -0
  1000. package/docs/zh-CN/tts.md +375 -0
  1001. package/docs/zh-CN/tui.md +166 -0
  1002. package/docs/zh-CN/vps.md +47 -0
  1003. package/docs/zh-CN/web/control-ui.md +191 -0
  1004. package/docs/zh-CN/web/dashboard.md +53 -0
  1005. package/docs/zh-CN/web/index.md +118 -0
  1006. package/docs/zh-CN/web/webchat.md +56 -0
  1007. package/extensions/blockchain/cryptoclaw.plugin.json +17 -0
  1008. package/extensions/blockchain/index.ts +284 -0
  1009. package/extensions/blockchain/node_modules/.bin/cryptoclaw +21 -0
  1010. package/extensions/blockchain/node_modules/.bin/tsc +21 -0
  1011. package/extensions/blockchain/node_modules/.bin/tsserver +21 -0
  1012. package/extensions/blockchain/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +1 -0
  1013. package/extensions/blockchain/package.json +16 -0
  1014. package/extensions/blockchain/src/evm/chains.ts +150 -0
  1015. package/extensions/blockchain/src/evm/services/abi/erc1155.ts +128 -0
  1016. package/extensions/blockchain/src/evm/services/abi/erc20.ts +96 -0
  1017. package/extensions/blockchain/src/evm/services/abi/erc721.ts +130 -0
  1018. package/extensions/blockchain/src/evm/services/abi/erc8004-identity.ts +158 -0
  1019. package/extensions/blockchain/src/evm/services/abi/erc8004-reputation.ts +120 -0
  1020. package/extensions/blockchain/src/evm/services/abi/router-v2.ts +115 -0
  1021. package/extensions/blockchain/src/evm/services/abi/router-v3.ts +81 -0
  1022. package/extensions/blockchain/src/evm/services/agent-identity-config.test.ts +117 -0
  1023. package/extensions/blockchain/src/evm/services/agent-identity-config.ts +75 -0
  1024. package/extensions/blockchain/src/evm/services/agent-identity-store.ts +37 -0
  1025. package/extensions/blockchain/src/evm/services/agent-identity.ts +262 -0
  1026. package/extensions/blockchain/src/evm/services/balance.ts +76 -0
  1027. package/extensions/blockchain/src/evm/services/blocks.ts +25 -0
  1028. package/extensions/blockchain/src/evm/services/clients.ts +48 -0
  1029. package/extensions/blockchain/src/evm/services/contracts.ts +52 -0
  1030. package/extensions/blockchain/src/evm/services/dex-config.test.ts +145 -0
  1031. package/extensions/blockchain/src/evm/services/dex-config.ts +164 -0
  1032. package/extensions/blockchain/src/evm/services/ens.ts +27 -0
  1033. package/extensions/blockchain/src/evm/services/security.test.ts +127 -0
  1034. package/extensions/blockchain/src/evm/services/security.ts +110 -0
  1035. package/extensions/blockchain/src/evm/services/swap.test.ts +204 -0
  1036. package/extensions/blockchain/src/evm/services/swap.ts +534 -0
  1037. package/extensions/blockchain/src/evm/services/tokens.ts +118 -0
  1038. package/extensions/blockchain/src/evm/services/transactions.ts +54 -0
  1039. package/extensions/blockchain/src/evm/services/transfer.ts +174 -0
  1040. package/extensions/blockchain/src/evm/services/utils.ts +18 -0
  1041. package/extensions/blockchain/src/evm/tools/block-tools.ts +34 -0
  1042. package/extensions/blockchain/src/evm/tools/contract-tools.ts +138 -0
  1043. package/extensions/blockchain/src/evm/tools/identity-tools.ts +305 -0
  1044. package/extensions/blockchain/src/evm/tools/network-tools.ts +58 -0
  1045. package/extensions/blockchain/src/evm/tools/nft-tools.ts +103 -0
  1046. package/extensions/blockchain/src/evm/tools/security-tools.ts +38 -0
  1047. package/extensions/blockchain/src/evm/tools/swap-tools.ts +314 -0
  1048. package/extensions/blockchain/src/evm/tools/token-tools.ts +167 -0
  1049. package/extensions/blockchain/src/evm/tools/tx-tools.ts +73 -0
  1050. package/extensions/blockchain/src/evm/tools/wallet-tools.ts +196 -0
  1051. package/extensions/blockchain/src/tx-gate/confirmation.ts +55 -0
  1052. package/extensions/blockchain/src/tx-gate/spending-limits.ts +94 -0
  1053. package/extensions/blockchain/src/wallet/active-wallet.ts +27 -0
  1054. package/extensions/blockchain/src/wallet/key-guard.test.ts +156 -0
  1055. package/extensions/blockchain/src/wallet/key-guard.ts +80 -0
  1056. package/extensions/blockchain/src/wallet/keystore.ts +88 -0
  1057. package/extensions/blockchain/src/wallet/wallet-manager.test.ts +215 -0
  1058. package/extensions/blockchain/src/wallet/wallet-manager.ts +212 -0
  1059. package/extensions/copilot-proxy/README.md +24 -0
  1060. package/extensions/copilot-proxy/index.ts +149 -0
  1061. package/extensions/copilot-proxy/node_modules/.bin/cryptoclaw +21 -0
  1062. package/extensions/copilot-proxy/openclaw.plugin.json +9 -0
  1063. package/extensions/copilot-proxy/package.json +14 -0
  1064. package/extensions/diagnostics-otel/index.ts +15 -0
  1065. package/extensions/diagnostics-otel/node_modules/.bin/acorn +21 -0
  1066. package/extensions/diagnostics-otel/node_modules/.bin/cryptoclaw +21 -0
  1067. package/extensions/diagnostics-otel/openclaw.plugin.json +8 -0
  1068. package/extensions/diagnostics-otel/package.json +27 -0
  1069. package/extensions/diagnostics-otel/src/service.test.ts +227 -0
  1070. package/extensions/diagnostics-otel/src/service.ts +635 -0
  1071. package/extensions/discord/index.ts +17 -0
  1072. package/extensions/discord/node_modules/.bin/cryptoclaw +21 -0
  1073. package/extensions/discord/openclaw.plugin.json +9 -0
  1074. package/extensions/discord/package.json +14 -0
  1075. package/extensions/discord/src/channel.ts +422 -0
  1076. package/extensions/discord/src/runtime.ts +14 -0
  1077. package/extensions/imessage/index.ts +17 -0
  1078. package/extensions/imessage/node_modules/.bin/cryptoclaw +21 -0
  1079. package/extensions/imessage/openclaw.plugin.json +9 -0
  1080. package/extensions/imessage/package.json +14 -0
  1081. package/extensions/imessage/src/channel.ts +294 -0
  1082. package/extensions/imessage/src/runtime.ts +14 -0
  1083. package/extensions/memory-core/index.ts +38 -0
  1084. package/extensions/memory-core/node_modules/.bin/cryptoclaw +21 -0
  1085. package/extensions/memory-core/openclaw.plugin.json +9 -0
  1086. package/extensions/memory-core/package.json +17 -0
  1087. package/extensions/memory-lancedb/config.ts +139 -0
  1088. package/extensions/memory-lancedb/index.test.ts +295 -0
  1089. package/extensions/memory-lancedb/index.ts +608 -0
  1090. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv +21 -0
  1091. package/extensions/memory-lancedb/node_modules/.bin/cryptoclaw +21 -0
  1092. package/extensions/memory-lancedb/node_modules/.bin/openai +21 -0
  1093. package/extensions/memory-lancedb/openclaw.plugin.json +60 -0
  1094. package/extensions/memory-lancedb/package.json +19 -0
  1095. package/extensions/nostr/CHANGELOG.md +80 -0
  1096. package/extensions/nostr/README.md +136 -0
  1097. package/extensions/nostr/index.ts +68 -0
  1098. package/extensions/nostr/node_modules/.bin/cryptoclaw +21 -0
  1099. package/extensions/nostr/node_modules/.bin/tsc +21 -0
  1100. package/extensions/nostr/node_modules/.bin/tsserver +21 -0
  1101. package/extensions/nostr/openclaw.plugin.json +9 -0
  1102. package/extensions/nostr/package.json +34 -0
  1103. package/extensions/nostr/src/channel.test.ts +151 -0
  1104. package/extensions/nostr/src/channel.ts +353 -0
  1105. package/extensions/nostr/src/config-schema.ts +90 -0
  1106. package/extensions/nostr/src/metrics.ts +478 -0
  1107. package/extensions/nostr/src/nostr-bus.fuzz.test.ts +533 -0
  1108. package/extensions/nostr/src/nostr-bus.integration.test.ts +448 -0
  1109. package/extensions/nostr/src/nostr-bus.test.ts +199 -0
  1110. package/extensions/nostr/src/nostr-bus.ts +715 -0
  1111. package/extensions/nostr/src/nostr-profile-http.test.ts +378 -0
  1112. package/extensions/nostr/src/nostr-profile-http.ts +519 -0
  1113. package/extensions/nostr/src/nostr-profile-import.test.ts +119 -0
  1114. package/extensions/nostr/src/nostr-profile-import.ts +262 -0
  1115. package/extensions/nostr/src/nostr-profile.fuzz.test.ts +477 -0
  1116. package/extensions/nostr/src/nostr-profile.test.ts +410 -0
  1117. package/extensions/nostr/src/nostr-profile.ts +277 -0
  1118. package/extensions/nostr/src/nostr-state-store.test.ts +131 -0
  1119. package/extensions/nostr/src/nostr-state-store.ts +226 -0
  1120. package/extensions/nostr/src/runtime.ts +14 -0
  1121. package/extensions/nostr/src/seen-tracker.ts +303 -0
  1122. package/extensions/nostr/src/types.test.ts +157 -0
  1123. package/extensions/nostr/src/types.ts +101 -0
  1124. package/extensions/nostr/test/setup.ts +5 -0
  1125. package/extensions/signal/index.ts +17 -0
  1126. package/extensions/signal/node_modules/.bin/cryptoclaw +21 -0
  1127. package/extensions/signal/openclaw.plugin.json +9 -0
  1128. package/extensions/signal/package.json +14 -0
  1129. package/extensions/signal/src/channel.ts +315 -0
  1130. package/extensions/signal/src/runtime.ts +14 -0
  1131. package/extensions/slack/index.ts +17 -0
  1132. package/extensions/slack/node_modules/.bin/cryptoclaw +21 -0
  1133. package/extensions/slack/openclaw.plugin.json +9 -0
  1134. package/extensions/slack/package.json +14 -0
  1135. package/extensions/slack/src/channel.ts +604 -0
  1136. package/extensions/slack/src/runtime.ts +14 -0
  1137. package/extensions/telegram/index.ts +17 -0
  1138. package/extensions/telegram/node_modules/.bin/cryptoclaw +21 -0
  1139. package/extensions/telegram/openclaw.plugin.json +9 -0
  1140. package/extensions/telegram/package.json +14 -0
  1141. package/extensions/telegram/src/channel.ts +482 -0
  1142. package/extensions/telegram/src/runtime.ts +14 -0
  1143. package/extensions/voice-call/CHANGELOG.md +115 -0
  1144. package/extensions/voice-call/README.md +139 -0
  1145. package/extensions/voice-call/index.ts +493 -0
  1146. package/extensions/voice-call/node_modules/.bin/cryptoclaw +21 -0
  1147. package/extensions/voice-call/openclaw.plugin.json +559 -0
  1148. package/extensions/voice-call/package.json +19 -0
  1149. package/extensions/voice-call/src/allowlist.ts +19 -0
  1150. package/extensions/voice-call/src/cli.ts +279 -0
  1151. package/extensions/voice-call/src/config.test.ts +234 -0
  1152. package/extensions/voice-call/src/config.ts +523 -0
  1153. package/extensions/voice-call/src/core-bridge.ts +159 -0
  1154. package/extensions/voice-call/src/manager/context.ts +21 -0
  1155. package/extensions/voice-call/src/manager/events.ts +188 -0
  1156. package/extensions/voice-call/src/manager/lookup.ts +35 -0
  1157. package/extensions/voice-call/src/manager/outbound.ts +275 -0
  1158. package/extensions/voice-call/src/manager/state.ts +48 -0
  1159. package/extensions/voice-call/src/manager/store.ts +91 -0
  1160. package/extensions/voice-call/src/manager/timers.ts +89 -0
  1161. package/extensions/voice-call/src/manager/twiml.ts +9 -0
  1162. package/extensions/voice-call/src/manager.test.ts +224 -0
  1163. package/extensions/voice-call/src/manager.ts +887 -0
  1164. package/extensions/voice-call/src/media-stream.test.ts +96 -0
  1165. package/extensions/voice-call/src/media-stream.ts +411 -0
  1166. package/extensions/voice-call/src/providers/base.ts +67 -0
  1167. package/extensions/voice-call/src/providers/index.ts +10 -0
  1168. package/extensions/voice-call/src/providers/mock.ts +165 -0
  1169. package/extensions/voice-call/src/providers/plivo.test.ts +27 -0
  1170. package/extensions/voice-call/src/providers/plivo.ts +515 -0
  1171. package/extensions/voice-call/src/providers/stt-openai-realtime.ts +311 -0
  1172. package/extensions/voice-call/src/providers/telnyx.ts +371 -0
  1173. package/extensions/voice-call/src/providers/tts-openai.ts +259 -0
  1174. package/extensions/voice-call/src/providers/twilio/api.ts +42 -0
  1175. package/extensions/voice-call/src/providers/twilio/webhook.ts +32 -0
  1176. package/extensions/voice-call/src/providers/twilio.test.ts +60 -0
  1177. package/extensions/voice-call/src/providers/twilio.ts +626 -0
  1178. package/extensions/voice-call/src/response-generator.ts +158 -0
  1179. package/extensions/voice-call/src/runtime.ts +212 -0
  1180. package/extensions/voice-call/src/telephony-audio.ts +90 -0
  1181. package/extensions/voice-call/src/telephony-tts.ts +104 -0
  1182. package/extensions/voice-call/src/tunnel.ts +314 -0
  1183. package/extensions/voice-call/src/types.ts +272 -0
  1184. package/extensions/voice-call/src/utils.ts +14 -0
  1185. package/extensions/voice-call/src/voice-mapping.ts +67 -0
  1186. package/extensions/voice-call/src/webhook-security.test.ts +377 -0
  1187. package/extensions/voice-call/src/webhook-security.ts +689 -0
  1188. package/extensions/voice-call/src/webhook.ts +491 -0
  1189. package/extensions/whatsapp/index.ts +17 -0
  1190. package/extensions/whatsapp/node_modules/.bin/cryptoclaw +21 -0
  1191. package/extensions/whatsapp/openclaw.plugin.json +9 -0
  1192. package/extensions/whatsapp/package.json +14 -0
  1193. package/extensions/whatsapp/src/channel.ts +508 -0
  1194. package/extensions/whatsapp/src/runtime.ts +14 -0
  1195. package/package.json +242 -0
  1196. package/skills/aave-bsc/SKILL.md +55 -0
  1197. package/skills/agent-identity/SKILL.md +48 -0
  1198. package/skills/bird/SKILL.md +224 -0
  1199. package/skills/canvas/SKILL.md +204 -0
  1200. package/skills/coding-agent/SKILL.md +285 -0
  1201. package/skills/coingecko/SKILL.md +114 -0
  1202. package/skills/contract-deployer/SKILL.md +42 -0
  1203. package/skills/debank/SKILL.md +143 -0
  1204. package/skills/defi-dashboard/SKILL.md +49 -0
  1205. package/skills/defillama/SKILL.md +117 -0
  1206. package/skills/discord/SKILL.md +578 -0
  1207. package/skills/dune/SKILL.md +178 -0
  1208. package/skills/etherscan/SKILL.md +117 -0
  1209. package/skills/four-meme/SKILL.md +80 -0
  1210. package/skills/gas-tracker/SKILL.md +43 -0
  1211. package/skills/github/SKILL.md +77 -0
  1212. package/skills/macro-calendar/SKILL.md +132 -0
  1213. package/skills/market-data/SKILL.md +44 -0
  1214. package/skills/nft-manager/SKILL.md +46 -0
  1215. package/skills/portfolio-tracker/SKILL.md +55 -0
  1216. package/skills/security-check/SKILL.md +153 -0
  1217. package/skills/tmux/SKILL.md +135 -0
  1218. package/skills/tmux/scripts/find-sessions.sh +112 -0
  1219. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  1220. package/skills/token-swap/SKILL.md +71 -0
  1221. package/skills/wallet-manager/SKILL.md +65 -0
  1222. package/skills/whale-watcher/SKILL.md +43 -0
@@ -0,0 +1,1210 @@
1
+ import "./paths-CGrNQEMk.js";
2
+ import { L as isRich, R as theme, c as defaultRuntime } from "./subsystem-Btuh5yZj.js";
3
+ import { _ as shortenHomePath, g as shortenHomeInString } from "./utils-D7jskKIf.js";
4
+ import "./exec-CW_QjkBi.js";
5
+ import { c as resolveDefaultAgentId, n as resolveAgentConfig } from "./agent-scope-DLfFOxP6.js";
6
+ import "./model-selection-Av0fLq51.js";
7
+ import "./github-copilot-token-hMl1wyZp.js";
8
+ import "./boolean-BsqeuxE6.js";
9
+ import "./env-B2Cd_6IS.js";
10
+ import { h as parseDurationMs, i as loadConfig } from "./config-dQK4rbfx.js";
11
+ import "./manifest-registry-DVQHMj0y.js";
12
+ import "./message-channel-CvHWS3C2.js";
13
+ import "./client-BaTYzXOU.js";
14
+ import { i as randomIdempotencyKey } from "./call-DqxlETxE.js";
15
+ import { t as formatDocsLink } from "./links-Brcj2Oc-.js";
16
+ import { r as runCommandWithRuntime } from "./cli-utils-CgOu3WAB.js";
17
+ import "./progress-DTEUicRP.js";
18
+ import { o as maxAsk, p as resolveExecApprovalsFromFile, s as minSecurity } from "./exec-approvals-CuXem6Li.js";
19
+ import { a as canvasSnapshotTempPath, c as parseCameraClipPayload, d as buildNodeShellCommand, i as parseEnvPairs, l as parseCameraSnapPayload, n as screenRecordTempPath, o as parseCanvasSnapshotPayload, r as writeScreenRecordToFile, s as cameraTempPath, t as parseScreenRecordPayload, u as writeBase64ToFile } from "./nodes-screen-Cok3-EJw.js";
20
+ import { t as parseTimeoutMs } from "./parse-timeout-Du-wHHNi.js";
21
+ import { t as renderTable } from "./table-DAOPkdc_.js";
22
+ import { a as formatAge, c as parsePairingList, i as unauthorizedHintForMessage, n as nodesCallOpts, o as formatPermissions, r as resolveNodeId, s as parseNodeList, t as callGatewayCli } from "./rpc-CbWcXAQK.js";
23
+ import path from "node:path";
24
+ import fs from "node:fs/promises";
25
+
26
+ //#region src/cli/nodes-cli/cli-utils.ts
27
+ function getNodesTheme() {
28
+ const rich = isRich();
29
+ const color = (fn) => (value) => rich ? fn(value) : value;
30
+ return {
31
+ rich,
32
+ heading: color(theme.heading),
33
+ ok: color(theme.success),
34
+ warn: color(theme.warn),
35
+ muted: color(theme.muted),
36
+ error: color(theme.error)
37
+ };
38
+ }
39
+ function runNodesCommand(label, action) {
40
+ return runCommandWithRuntime(defaultRuntime, action, (err) => {
41
+ const message = String(err);
42
+ const { error, warn } = getNodesTheme();
43
+ defaultRuntime.error(error(`nodes ${label} failed: ${message}`));
44
+ const hint = unauthorizedHintForMessage(message);
45
+ if (hint) defaultRuntime.error(warn(hint));
46
+ defaultRuntime.exit(1);
47
+ });
48
+ }
49
+
50
+ //#endregion
51
+ //#region src/cli/nodes-cli/register.camera.ts
52
+ const parseFacing = (value) => {
53
+ const v = String(value ?? "").trim().toLowerCase();
54
+ if (v === "front" || v === "back") return v;
55
+ throw new Error(`invalid facing: ${value} (expected front|back)`);
56
+ };
57
+ function registerNodesCameraCommands(nodes) {
58
+ const camera = nodes.command("camera").description("Capture camera media from a paired node");
59
+ nodesCallOpts(camera.command("list").description("List available cameras on a node").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").action(async (opts) => {
60
+ await runNodesCommand("camera list", async () => {
61
+ const raw = await callGatewayCli("node.invoke", opts, {
62
+ nodeId: await resolveNodeId(opts, String(opts.node ?? "")),
63
+ command: "camera.list",
64
+ params: {},
65
+ idempotencyKey: randomIdempotencyKey()
66
+ });
67
+ const res = typeof raw === "object" && raw !== null ? raw : {};
68
+ const payload = typeof res.payload === "object" && res.payload !== null ? res.payload : {};
69
+ const devices = Array.isArray(payload.devices) ? payload.devices : [];
70
+ if (opts.json) {
71
+ defaultRuntime.log(JSON.stringify(devices, null, 2));
72
+ return;
73
+ }
74
+ if (devices.length === 0) {
75
+ const { muted } = getNodesTheme();
76
+ defaultRuntime.log(muted("No cameras reported."));
77
+ return;
78
+ }
79
+ const { heading, muted } = getNodesTheme();
80
+ const tableWidth = Math.max(60, (process.stdout.columns ?? 120) - 1);
81
+ const rows = devices.map((device) => ({
82
+ Name: typeof device.name === "string" ? device.name : "Unknown Camera",
83
+ Position: typeof device.position === "string" ? device.position : muted("unspecified"),
84
+ ID: typeof device.id === "string" ? device.id : ""
85
+ }));
86
+ defaultRuntime.log(heading("Cameras"));
87
+ defaultRuntime.log(renderTable({
88
+ width: tableWidth,
89
+ columns: [
90
+ {
91
+ key: "Name",
92
+ header: "Name",
93
+ minWidth: 14,
94
+ flex: true
95
+ },
96
+ {
97
+ key: "Position",
98
+ header: "Position",
99
+ minWidth: 10
100
+ },
101
+ {
102
+ key: "ID",
103
+ header: "ID",
104
+ minWidth: 10,
105
+ flex: true
106
+ }
107
+ ],
108
+ rows
109
+ }).trimEnd());
110
+ });
111
+ }), { timeoutMs: 6e4 });
112
+ nodesCallOpts(camera.command("snap").description("Capture a photo from a node camera (prints MEDIA:<path>)").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--facing <front|back|both>", "Camera facing", "both").option("--device-id <id>", "Camera device id (from nodes camera list)").option("--max-width <px>", "Max width in px (optional)").option("--quality <0-1>", "JPEG quality (default 0.9)").option("--delay-ms <ms>", "Delay before capture in ms (macOS default 2000)").option("--invoke-timeout <ms>", "Node invoke timeout in ms (default 20000)", "20000").action(async (opts) => {
113
+ await runNodesCommand("camera snap", async () => {
114
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
115
+ const facingOpt = String(opts.facing ?? "both").trim().toLowerCase();
116
+ const facings = facingOpt === "both" ? ["front", "back"] : facingOpt === "front" || facingOpt === "back" ? [facingOpt] : (() => {
117
+ throw new Error(`invalid facing: ${String(opts.facing)} (expected front|back|both)`);
118
+ })();
119
+ const maxWidth = opts.maxWidth ? Number.parseInt(String(opts.maxWidth), 10) : void 0;
120
+ const quality = opts.quality ? Number.parseFloat(String(opts.quality)) : void 0;
121
+ const delayMs = opts.delayMs ? Number.parseInt(String(opts.delayMs), 10) : void 0;
122
+ const deviceId = opts.deviceId ? String(opts.deviceId).trim() : void 0;
123
+ const timeoutMs = opts.invokeTimeout ? Number.parseInt(String(opts.invokeTimeout), 10) : void 0;
124
+ const results = [];
125
+ for (const facing of facings) {
126
+ const invokeParams = {
127
+ nodeId,
128
+ command: "camera.snap",
129
+ params: {
130
+ facing,
131
+ maxWidth: Number.isFinite(maxWidth) ? maxWidth : void 0,
132
+ quality: Number.isFinite(quality) ? quality : void 0,
133
+ format: "jpg",
134
+ delayMs: Number.isFinite(delayMs) ? delayMs : void 0,
135
+ deviceId: deviceId || void 0
136
+ },
137
+ idempotencyKey: randomIdempotencyKey()
138
+ };
139
+ if (typeof timeoutMs === "number" && Number.isFinite(timeoutMs)) invokeParams.timeoutMs = timeoutMs;
140
+ const raw = await callGatewayCli("node.invoke", opts, invokeParams);
141
+ const payload = parseCameraSnapPayload((typeof raw === "object" && raw !== null ? raw : {}).payload);
142
+ const filePath = cameraTempPath({
143
+ kind: "snap",
144
+ facing,
145
+ ext: payload.format === "jpeg" ? "jpg" : payload.format
146
+ });
147
+ await writeBase64ToFile(filePath, payload.base64);
148
+ results.push({
149
+ facing,
150
+ path: filePath,
151
+ width: payload.width,
152
+ height: payload.height
153
+ });
154
+ }
155
+ if (opts.json) {
156
+ defaultRuntime.log(JSON.stringify({ files: results }, null, 2));
157
+ return;
158
+ }
159
+ defaultRuntime.log(results.map((r) => `MEDIA:${shortenHomePath(r.path)}`).join("\n"));
160
+ });
161
+ }), { timeoutMs: 6e4 });
162
+ nodesCallOpts(camera.command("clip").description("Capture a short video clip from a node camera (prints MEDIA:<path>)").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--facing <front|back>", "Camera facing", "front").option("--device-id <id>", "Camera device id (from nodes camera list)").option("--duration <ms|10s|1m>", "Duration (default 3000ms; supports ms/s/m, e.g. 10s)", "3000").option("--no-audio", "Disable audio capture").option("--invoke-timeout <ms>", "Node invoke timeout in ms (default 90000)", "90000").action(async (opts) => {
163
+ await runNodesCommand("camera clip", async () => {
164
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
165
+ const facing = parseFacing(String(opts.facing ?? "front"));
166
+ const durationMs = parseDurationMs(String(opts.duration ?? "3000"));
167
+ const includeAudio = opts.audio !== false;
168
+ const timeoutMs = opts.invokeTimeout ? Number.parseInt(String(opts.invokeTimeout), 10) : void 0;
169
+ const deviceId = opts.deviceId ? String(opts.deviceId).trim() : void 0;
170
+ const invokeParams = {
171
+ nodeId,
172
+ command: "camera.clip",
173
+ params: {
174
+ facing,
175
+ durationMs: Number.isFinite(durationMs) ? durationMs : void 0,
176
+ includeAudio,
177
+ format: "mp4",
178
+ deviceId: deviceId || void 0
179
+ },
180
+ idempotencyKey: randomIdempotencyKey()
181
+ };
182
+ if (typeof timeoutMs === "number" && Number.isFinite(timeoutMs)) invokeParams.timeoutMs = timeoutMs;
183
+ const raw = await callGatewayCli("node.invoke", opts, invokeParams);
184
+ const payload = parseCameraClipPayload((typeof raw === "object" && raw !== null ? raw : {}).payload);
185
+ const filePath = cameraTempPath({
186
+ kind: "clip",
187
+ facing,
188
+ ext: payload.format
189
+ });
190
+ await writeBase64ToFile(filePath, payload.base64);
191
+ if (opts.json) {
192
+ defaultRuntime.log(JSON.stringify({ file: {
193
+ facing,
194
+ path: filePath,
195
+ durationMs: payload.durationMs,
196
+ hasAudio: payload.hasAudio
197
+ } }, null, 2));
198
+ return;
199
+ }
200
+ defaultRuntime.log(`MEDIA:${shortenHomePath(filePath)}`);
201
+ });
202
+ }), { timeoutMs: 9e4 });
203
+ }
204
+
205
+ //#endregion
206
+ //#region src/cli/nodes-cli/a2ui-jsonl.ts
207
+ const A2UI_ACTION_KEYS = [
208
+ "beginRendering",
209
+ "surfaceUpdate",
210
+ "dataModelUpdate",
211
+ "deleteSurface",
212
+ "createSurface"
213
+ ];
214
+ function buildA2UITextJsonl(text) {
215
+ const surfaceId = "main";
216
+ const rootId = "root";
217
+ const textId = "text";
218
+ return [{ surfaceUpdate: {
219
+ surfaceId,
220
+ components: [{
221
+ id: rootId,
222
+ component: { Column: { children: { explicitList: [textId] } } }
223
+ }, {
224
+ id: textId,
225
+ component: { Text: {
226
+ text: { literalString: text },
227
+ usageHint: "body"
228
+ } }
229
+ }]
230
+ } }, { beginRendering: {
231
+ surfaceId,
232
+ root: rootId
233
+ } }].map((payload) => JSON.stringify(payload)).join("\n");
234
+ }
235
+ function validateA2UIJsonl(jsonl) {
236
+ const lines = jsonl.split(/\r?\n/);
237
+ const errors = [];
238
+ let sawV08 = false;
239
+ let sawV09 = false;
240
+ let messageCount = 0;
241
+ lines.forEach((line, idx) => {
242
+ const trimmed = line.trim();
243
+ if (!trimmed) return;
244
+ messageCount += 1;
245
+ let obj;
246
+ try {
247
+ obj = JSON.parse(trimmed);
248
+ } catch (err) {
249
+ errors.push(`line ${idx + 1}: ${String(err)}`);
250
+ return;
251
+ }
252
+ if (!obj || typeof obj !== "object" || Array.isArray(obj)) {
253
+ errors.push(`line ${idx + 1}: expected JSON object`);
254
+ return;
255
+ }
256
+ const record = obj;
257
+ const actionKeys = A2UI_ACTION_KEYS.filter((key) => key in record);
258
+ if (actionKeys.length !== 1) {
259
+ errors.push(`line ${idx + 1}: expected exactly one action key (${A2UI_ACTION_KEYS.join(", ")})`);
260
+ return;
261
+ }
262
+ if (actionKeys[0] === "createSurface") sawV09 = true;
263
+ else sawV08 = true;
264
+ });
265
+ if (messageCount === 0) errors.push("no JSONL messages found");
266
+ if (sawV08 && sawV09) errors.push("mixed A2UI v0.8 and v0.9 messages in one file");
267
+ if (errors.length > 0) throw new Error(`Invalid A2UI JSONL:\n- ${errors.join("\n- ")}`);
268
+ return {
269
+ version: sawV09 ? "v0.9" : "v0.8",
270
+ messageCount
271
+ };
272
+ }
273
+
274
+ //#endregion
275
+ //#region src/cli/nodes-cli/register.canvas.ts
276
+ async function invokeCanvas(opts, command, params) {
277
+ const invokeParams = {
278
+ nodeId: await resolveNodeId(opts, String(opts.node ?? "")),
279
+ command,
280
+ params,
281
+ idempotencyKey: randomIdempotencyKey()
282
+ };
283
+ const timeoutMs = parseTimeoutMs(opts.invokeTimeout);
284
+ if (typeof timeoutMs === "number") invokeParams.timeoutMs = timeoutMs;
285
+ return await callGatewayCli("node.invoke", opts, invokeParams);
286
+ }
287
+ function registerNodesCanvasCommands(nodes) {
288
+ const canvas = nodes.command("canvas").description("Capture or render canvas content from a paired node");
289
+ nodesCallOpts(canvas.command("snapshot").description("Capture a canvas snapshot (prints MEDIA:<path>)").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--format <png|jpg|jpeg>", "Image format", "jpg").option("--max-width <px>", "Max width in px (optional)").option("--quality <0-1>", "JPEG quality (optional)").option("--invoke-timeout <ms>", "Node invoke timeout in ms (default 20000)", "20000").action(async (opts) => {
290
+ await runNodesCommand("canvas snapshot", async () => {
291
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
292
+ const formatOpt = String(opts.format ?? "jpg").trim().toLowerCase();
293
+ const formatForParams = formatOpt === "jpg" ? "jpeg" : formatOpt === "jpeg" ? "jpeg" : "png";
294
+ if (formatForParams !== "png" && formatForParams !== "jpeg") throw new Error(`invalid format: ${String(opts.format)} (expected png|jpg|jpeg)`);
295
+ const maxWidth = opts.maxWidth ? Number.parseInt(String(opts.maxWidth), 10) : void 0;
296
+ const quality = opts.quality ? Number.parseFloat(String(opts.quality)) : void 0;
297
+ const timeoutMs = opts.invokeTimeout ? Number.parseInt(String(opts.invokeTimeout), 10) : void 0;
298
+ const invokeParams = {
299
+ nodeId,
300
+ command: "canvas.snapshot",
301
+ params: {
302
+ format: formatForParams,
303
+ maxWidth: Number.isFinite(maxWidth) ? maxWidth : void 0,
304
+ quality: Number.isFinite(quality) ? quality : void 0
305
+ },
306
+ idempotencyKey: randomIdempotencyKey()
307
+ };
308
+ if (typeof timeoutMs === "number" && Number.isFinite(timeoutMs)) invokeParams.timeoutMs = timeoutMs;
309
+ const raw = await callGatewayCli("node.invoke", opts, invokeParams);
310
+ const payload = parseCanvasSnapshotPayload((typeof raw === "object" && raw !== null ? raw : {}).payload);
311
+ const filePath = canvasSnapshotTempPath({ ext: payload.format === "jpeg" ? "jpg" : payload.format });
312
+ await writeBase64ToFile(filePath, payload.base64);
313
+ if (opts.json) {
314
+ defaultRuntime.log(JSON.stringify({ file: {
315
+ path: filePath,
316
+ format: payload.format
317
+ } }, null, 2));
318
+ return;
319
+ }
320
+ defaultRuntime.log(`MEDIA:${shortenHomePath(filePath)}`);
321
+ });
322
+ }), { timeoutMs: 6e4 });
323
+ nodesCallOpts(canvas.command("present").description("Show the canvas (optionally with a target URL/path)").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--target <urlOrPath>", "Target URL/path (optional)").option("--x <px>", "Placement x coordinate").option("--y <px>", "Placement y coordinate").option("--width <px>", "Placement width").option("--height <px>", "Placement height").option("--invoke-timeout <ms>", "Node invoke timeout in ms").action(async (opts) => {
324
+ await runNodesCommand("canvas present", async () => {
325
+ const placement = {
326
+ x: opts.x ? Number.parseFloat(opts.x) : void 0,
327
+ y: opts.y ? Number.parseFloat(opts.y) : void 0,
328
+ width: opts.width ? Number.parseFloat(opts.width) : void 0,
329
+ height: opts.height ? Number.parseFloat(opts.height) : void 0
330
+ };
331
+ const params = {};
332
+ if (opts.target) params.url = String(opts.target);
333
+ if (Number.isFinite(placement.x) || Number.isFinite(placement.y) || Number.isFinite(placement.width) || Number.isFinite(placement.height)) params.placement = placement;
334
+ await invokeCanvas(opts, "canvas.present", params);
335
+ if (!opts.json) {
336
+ const { ok } = getNodesTheme();
337
+ defaultRuntime.log(ok("canvas present ok"));
338
+ }
339
+ });
340
+ }));
341
+ nodesCallOpts(canvas.command("hide").description("Hide the canvas").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--invoke-timeout <ms>", "Node invoke timeout in ms").action(async (opts) => {
342
+ await runNodesCommand("canvas hide", async () => {
343
+ await invokeCanvas(opts, "canvas.hide", void 0);
344
+ if (!opts.json) {
345
+ const { ok } = getNodesTheme();
346
+ defaultRuntime.log(ok("canvas hide ok"));
347
+ }
348
+ });
349
+ }));
350
+ nodesCallOpts(canvas.command("navigate").description("Navigate the canvas to a URL").argument("<url>", "Target URL/path").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--invoke-timeout <ms>", "Node invoke timeout in ms").action(async (url, opts) => {
351
+ await runNodesCommand("canvas navigate", async () => {
352
+ await invokeCanvas(opts, "canvas.navigate", { url });
353
+ if (!opts.json) {
354
+ const { ok } = getNodesTheme();
355
+ defaultRuntime.log(ok("canvas navigate ok"));
356
+ }
357
+ });
358
+ }));
359
+ nodesCallOpts(canvas.command("eval").description("Evaluate JavaScript in the canvas").argument("[js]", "JavaScript to evaluate").option("--js <code>", "JavaScript to evaluate").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--invoke-timeout <ms>", "Node invoke timeout in ms").action(async (jsArg, opts) => {
360
+ await runNodesCommand("canvas eval", async () => {
361
+ const js = opts.js ?? jsArg;
362
+ if (!js) throw new Error("missing --js or <js>");
363
+ const raw = await invokeCanvas(opts, "canvas.eval", { javaScript: js });
364
+ if (opts.json) {
365
+ defaultRuntime.log(JSON.stringify(raw, null, 2));
366
+ return;
367
+ }
368
+ const payload = typeof raw === "object" && raw !== null ? raw.payload : void 0;
369
+ if (payload?.result) defaultRuntime.log(payload.result);
370
+ else {
371
+ const { ok } = getNodesTheme();
372
+ defaultRuntime.log(ok("canvas eval ok"));
373
+ }
374
+ });
375
+ }));
376
+ const a2ui = canvas.command("a2ui").description("Render A2UI content on the canvas");
377
+ nodesCallOpts(a2ui.command("push").description("Push A2UI JSONL to the canvas").option("--jsonl <path>", "Path to JSONL payload").option("--text <text>", "Render a quick A2UI text payload").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--invoke-timeout <ms>", "Node invoke timeout in ms").action(async (opts) => {
378
+ await runNodesCommand("canvas a2ui push", async () => {
379
+ const hasJsonl = Boolean(opts.jsonl);
380
+ const hasText = typeof opts.text === "string";
381
+ if (hasJsonl === hasText) throw new Error("provide exactly one of --jsonl or --text");
382
+ const jsonl = hasText ? buildA2UITextJsonl(String(opts.text ?? "")) : await fs.readFile(String(opts.jsonl), "utf8");
383
+ const { version, messageCount } = validateA2UIJsonl(jsonl);
384
+ if (version === "v0.9") throw new Error("Detected A2UI v0.9 JSONL (createSurface). OpenClaw currently supports v0.8 only.");
385
+ await invokeCanvas(opts, "canvas.a2ui.pushJSONL", { jsonl });
386
+ if (!opts.json) {
387
+ const { ok } = getNodesTheme();
388
+ defaultRuntime.log(ok(`canvas a2ui push ok (v0.8, ${messageCount} message${messageCount === 1 ? "" : "s"})`));
389
+ }
390
+ });
391
+ }));
392
+ nodesCallOpts(a2ui.command("reset").description("Reset A2UI renderer state").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--invoke-timeout <ms>", "Node invoke timeout in ms").action(async (opts) => {
393
+ await runNodesCommand("canvas a2ui reset", async () => {
394
+ await invokeCanvas(opts, "canvas.a2ui.reset", void 0);
395
+ if (!opts.json) {
396
+ const { ok } = getNodesTheme();
397
+ defaultRuntime.log(ok("canvas a2ui reset ok"));
398
+ }
399
+ });
400
+ }));
401
+ }
402
+
403
+ //#endregion
404
+ //#region src/cli/nodes-cli/register.invoke.ts
405
+ function normalizeExecSecurity(value) {
406
+ const normalized = value?.trim().toLowerCase();
407
+ if (normalized === "deny" || normalized === "allowlist" || normalized === "full") return normalized;
408
+ return null;
409
+ }
410
+ function normalizeExecAsk(value) {
411
+ const normalized = value?.trim().toLowerCase();
412
+ if (normalized === "off" || normalized === "on-miss" || normalized === "always") return normalized;
413
+ return null;
414
+ }
415
+ function mergePathPrepend(existing, prepend) {
416
+ if (prepend.length === 0) return existing;
417
+ const partsExisting = (existing ?? "").split(path.delimiter).map((part) => part.trim()).filter(Boolean);
418
+ const merged = [];
419
+ const seen = /* @__PURE__ */ new Set();
420
+ for (const part of [...prepend, ...partsExisting]) {
421
+ if (seen.has(part)) continue;
422
+ seen.add(part);
423
+ merged.push(part);
424
+ }
425
+ return merged.join(path.delimiter);
426
+ }
427
+ function applyPathPrepend(env, prepend, options) {
428
+ if (!Array.isArray(prepend) || prepend.length === 0) return;
429
+ if (options?.requireExisting && !env.PATH) return;
430
+ const merged = mergePathPrepend(env.PATH, prepend);
431
+ if (merged) env.PATH = merged;
432
+ }
433
+ function resolveExecDefaults(cfg, agentId) {
434
+ const globalExec = cfg?.tools?.exec;
435
+ if (!agentId) return globalExec ? {
436
+ security: globalExec.security,
437
+ ask: globalExec.ask,
438
+ node: globalExec.node,
439
+ pathPrepend: globalExec.pathPrepend,
440
+ safeBins: globalExec.safeBins
441
+ } : void 0;
442
+ const agentExec = resolveAgentConfig(cfg, agentId)?.tools?.exec;
443
+ return {
444
+ security: agentExec?.security ?? globalExec?.security,
445
+ ask: agentExec?.ask ?? globalExec?.ask,
446
+ node: agentExec?.node ?? globalExec?.node,
447
+ pathPrepend: agentExec?.pathPrepend ?? globalExec?.pathPrepend,
448
+ safeBins: agentExec?.safeBins ?? globalExec?.safeBins
449
+ };
450
+ }
451
+ async function resolveNodePlatform(opts, nodeId) {
452
+ try {
453
+ const match = parseNodeList(await callGatewayCli("node.list", opts, {})).find((node) => node.nodeId === nodeId);
454
+ return typeof match?.platform === "string" ? match.platform : null;
455
+ } catch {
456
+ return null;
457
+ }
458
+ }
459
+ function registerNodesInvokeCommands(nodes) {
460
+ nodesCallOpts(nodes.command("invoke").description("Invoke a command on a paired node").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").requiredOption("--command <command>", "Command (e.g. canvas.eval)").option("--params <json>", "JSON object string for params", "{}").option("--invoke-timeout <ms>", "Node invoke timeout in ms (default 15000)", "15000").option("--idempotency-key <key>", "Idempotency key (optional)").action(async (opts) => {
461
+ await runNodesCommand("invoke", async () => {
462
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
463
+ const command = String(opts.command ?? "").trim();
464
+ if (!nodeId || !command) {
465
+ const { error } = getNodesTheme();
466
+ defaultRuntime.error(error("--node and --command required"));
467
+ defaultRuntime.exit(1);
468
+ return;
469
+ }
470
+ const params = JSON.parse(String(opts.params ?? "{}"));
471
+ const timeoutMs = opts.invokeTimeout ? Number.parseInt(String(opts.invokeTimeout), 10) : void 0;
472
+ const invokeParams = {
473
+ nodeId,
474
+ command,
475
+ params,
476
+ idempotencyKey: String(opts.idempotencyKey ?? randomIdempotencyKey())
477
+ };
478
+ if (typeof timeoutMs === "number" && Number.isFinite(timeoutMs)) invokeParams.timeoutMs = timeoutMs;
479
+ const result = await callGatewayCli("node.invoke", opts, invokeParams);
480
+ defaultRuntime.log(JSON.stringify(result, null, 2));
481
+ });
482
+ }), { timeoutMs: 3e4 });
483
+ nodesCallOpts(nodes.command("run").description("Run a shell command on a node (mac only)").option("--node <idOrNameOrIp>", "Node id, name, or IP").option("--cwd <path>", "Working directory").option("--env <key=val>", "Environment override (repeatable)", (value, prev = []) => [...prev, value]).option("--raw <command>", "Run a raw shell command string (sh -lc / cmd.exe /c)").option("--agent <id>", "Agent id (default: configured default agent)").option("--ask <mode>", "Exec ask mode (off|on-miss|always)").option("--security <mode>", "Exec security mode (deny|allowlist|full)").option("--command-timeout <ms>", "Command timeout (ms)").option("--needs-screen-recording", "Require screen recording permission").option("--invoke-timeout <ms>", "Node invoke timeout in ms (default 30000)", "30000").argument("[command...]", "Command and args").action(async (command, opts) => {
484
+ await runNodesCommand("run", async () => {
485
+ const cfg = loadConfig();
486
+ const agentId = opts.agent?.trim() || resolveDefaultAgentId(cfg);
487
+ const execDefaults = resolveExecDefaults(cfg, agentId);
488
+ const raw = typeof opts.raw === "string" ? opts.raw.trim() : "";
489
+ if (raw && Array.isArray(command) && command.length > 0) throw new Error("use --raw or argv, not both");
490
+ if (!raw && (!Array.isArray(command) || command.length === 0)) throw new Error("command required");
491
+ const nodeQuery = String(opts.node ?? "").trim() || execDefaults?.node?.trim() || "";
492
+ if (!nodeQuery) throw new Error("node required (set --node or tools.exec.node)");
493
+ const nodeId = await resolveNodeId(opts, nodeQuery);
494
+ const env = parseEnvPairs(opts.env);
495
+ const timeoutMs = parseTimeoutMs(opts.commandTimeout);
496
+ const invokeTimeout = parseTimeoutMs(opts.invokeTimeout);
497
+ let argv = Array.isArray(command) ? command : [];
498
+ let rawCommand;
499
+ if (raw) {
500
+ rawCommand = raw;
501
+ const platform = await resolveNodePlatform(opts, nodeId);
502
+ argv = buildNodeShellCommand(rawCommand, platform ?? void 0);
503
+ }
504
+ const nodeEnv = env ? { ...env } : void 0;
505
+ if (nodeEnv) applyPathPrepend(nodeEnv, execDefaults?.pathPrepend, { requireExisting: true });
506
+ let approvedByAsk = false;
507
+ let approvalDecision = null;
508
+ const configuredSecurity = normalizeExecSecurity(execDefaults?.security) ?? "allowlist";
509
+ const requestedSecurity = normalizeExecSecurity(opts.security);
510
+ if (opts.security && !requestedSecurity) throw new Error("invalid --security (use deny|allowlist|full)");
511
+ const configuredAsk = normalizeExecAsk(execDefaults?.ask) ?? "on-miss";
512
+ const requestedAsk = normalizeExecAsk(opts.ask);
513
+ if (opts.ask && !requestedAsk) throw new Error("invalid --ask (use off|on-miss|always)");
514
+ const security = minSecurity(configuredSecurity, requestedSecurity ?? configuredSecurity);
515
+ const ask = maxAsk(configuredAsk, requestedAsk ?? configuredAsk);
516
+ const approvalsSnapshot = await callGatewayCli("exec.approvals.node.get", opts, { nodeId });
517
+ const approvalsFile = approvalsSnapshot && typeof approvalsSnapshot === "object" ? approvalsSnapshot.file : void 0;
518
+ if (!approvalsFile || typeof approvalsFile !== "object") throw new Error("exec approvals unavailable");
519
+ const approvals = resolveExecApprovalsFromFile({
520
+ file: approvalsFile,
521
+ agentId,
522
+ overrides: {
523
+ security,
524
+ ask
525
+ }
526
+ });
527
+ const hostSecurity = minSecurity(security, approvals.agent.security);
528
+ const hostAsk = maxAsk(ask, approvals.agent.ask);
529
+ const askFallback = approvals.agent.askFallback;
530
+ if (hostSecurity === "deny") throw new Error("exec denied: host=node security=deny");
531
+ if (hostAsk === "always" || hostAsk === "on-miss") {
532
+ const decisionResult = await callGatewayCli("exec.approval.request", opts, {
533
+ command: rawCommand ?? argv.join(" "),
534
+ cwd: opts.cwd,
535
+ host: "node",
536
+ security: hostSecurity,
537
+ ask: hostAsk,
538
+ agentId,
539
+ resolvedPath: void 0,
540
+ sessionKey: void 0,
541
+ timeoutMs: 12e4
542
+ });
543
+ const decision = decisionResult && typeof decisionResult === "object" ? decisionResult.decision ?? null : null;
544
+ if (decision === "deny") throw new Error("exec denied: user denied");
545
+ if (!decision) if (askFallback === "full") {
546
+ approvedByAsk = true;
547
+ approvalDecision = "allow-once";
548
+ } else if (askFallback === "allowlist") {} else throw new Error("exec denied: approval required (approval UI not available)");
549
+ if (decision === "allow-once") {
550
+ approvedByAsk = true;
551
+ approvalDecision = "allow-once";
552
+ }
553
+ if (decision === "allow-always") {
554
+ approvedByAsk = true;
555
+ approvalDecision = "allow-always";
556
+ }
557
+ }
558
+ const invokeParams = {
559
+ nodeId,
560
+ command: "system.run",
561
+ params: {
562
+ command: argv,
563
+ cwd: opts.cwd,
564
+ env: nodeEnv,
565
+ timeoutMs,
566
+ needsScreenRecording: opts.needsScreenRecording === true
567
+ },
568
+ idempotencyKey: String(opts.idempotencyKey ?? randomIdempotencyKey())
569
+ };
570
+ if (agentId) invokeParams.params.agentId = agentId;
571
+ if (rawCommand) invokeParams.params.rawCommand = rawCommand;
572
+ invokeParams.params.approved = approvedByAsk;
573
+ if (approvalDecision) invokeParams.params.approvalDecision = approvalDecision;
574
+ if (invokeTimeout !== void 0) invokeParams.timeoutMs = invokeTimeout;
575
+ const result = await callGatewayCli("node.invoke", opts, invokeParams);
576
+ if (opts.json) {
577
+ defaultRuntime.log(JSON.stringify(result, null, 2));
578
+ return;
579
+ }
580
+ const payload = typeof result === "object" && result !== null ? result.payload : void 0;
581
+ const stdout = typeof payload?.stdout === "string" ? payload.stdout : "";
582
+ const stderr = typeof payload?.stderr === "string" ? payload.stderr : "";
583
+ const exitCode = typeof payload?.exitCode === "number" ? payload.exitCode : null;
584
+ const timedOut = payload?.timedOut === true;
585
+ const success = payload?.success === true;
586
+ if (stdout) process.stdout.write(stdout);
587
+ if (stderr) process.stderr.write(stderr);
588
+ if (timedOut) {
589
+ const { error } = getNodesTheme();
590
+ defaultRuntime.error(error("run timed out"));
591
+ defaultRuntime.exit(1);
592
+ return;
593
+ }
594
+ if (exitCode !== null && exitCode !== 0) {
595
+ const hint = unauthorizedHintForMessage(`${stderr}\n${stdout}`);
596
+ if (hint) {
597
+ const { warn } = getNodesTheme();
598
+ defaultRuntime.error(warn(hint));
599
+ }
600
+ }
601
+ if (exitCode !== null && exitCode !== 0 && !success) {
602
+ const { error } = getNodesTheme();
603
+ defaultRuntime.error(error(`run exit ${exitCode}`));
604
+ defaultRuntime.exit(1);
605
+ return;
606
+ }
607
+ });
608
+ }), { timeoutMs: 35e3 });
609
+ }
610
+
611
+ //#endregion
612
+ //#region src/cli/nodes-cli/register.location.ts
613
+ function registerNodesLocationCommands(nodes) {
614
+ nodesCallOpts(nodes.command("location").description("Fetch location from a paired node").command("get").description("Fetch the current location from a node").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--max-age <ms>", "Use cached location newer than this (ms)").option("--accuracy <coarse|balanced|precise>", "Desired accuracy (default: balanced/precise depending on node setting)").option("--location-timeout <ms>", "Location fix timeout (ms)", "10000").option("--invoke-timeout <ms>", "Node invoke timeout in ms (default 20000)", "20000").action(async (opts) => {
615
+ await runNodesCommand("location get", async () => {
616
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
617
+ const maxAgeMs = opts.maxAge ? Number.parseInt(String(opts.maxAge), 10) : void 0;
618
+ const desiredAccuracyRaw = typeof opts.accuracy === "string" ? opts.accuracy.trim().toLowerCase() : void 0;
619
+ const desiredAccuracy = desiredAccuracyRaw === "coarse" || desiredAccuracyRaw === "balanced" || desiredAccuracyRaw === "precise" ? desiredAccuracyRaw : void 0;
620
+ const timeoutMs = opts.locationTimeout ? Number.parseInt(String(opts.locationTimeout), 10) : void 0;
621
+ const invokeTimeoutMs = opts.invokeTimeout ? Number.parseInt(String(opts.invokeTimeout), 10) : void 0;
622
+ const invokeParams = {
623
+ nodeId,
624
+ command: "location.get",
625
+ params: {
626
+ maxAgeMs: Number.isFinite(maxAgeMs) ? maxAgeMs : void 0,
627
+ desiredAccuracy,
628
+ timeoutMs: Number.isFinite(timeoutMs) ? timeoutMs : void 0
629
+ },
630
+ idempotencyKey: randomIdempotencyKey()
631
+ };
632
+ if (typeof invokeTimeoutMs === "number" && Number.isFinite(invokeTimeoutMs)) invokeParams.timeoutMs = invokeTimeoutMs;
633
+ const raw = await callGatewayCli("node.invoke", opts, invokeParams);
634
+ const res = typeof raw === "object" && raw !== null ? raw : {};
635
+ const payload = res.payload && typeof res.payload === "object" ? res.payload : {};
636
+ if (opts.json) {
637
+ defaultRuntime.log(JSON.stringify(payload, null, 2));
638
+ return;
639
+ }
640
+ const lat = payload.lat;
641
+ const lon = payload.lon;
642
+ const acc = payload.accuracyMeters;
643
+ if (typeof lat === "number" && typeof lon === "number") {
644
+ const accText = typeof acc === "number" ? ` ±${acc.toFixed(1)}m` : "";
645
+ defaultRuntime.log(`${lat},${lon}${accText}`);
646
+ return;
647
+ }
648
+ defaultRuntime.log(JSON.stringify(payload));
649
+ });
650
+ }), { timeoutMs: 3e4 });
651
+ }
652
+
653
+ //#endregion
654
+ //#region src/cli/nodes-cli/register.notify.ts
655
+ function registerNodesNotifyCommand(nodes) {
656
+ nodesCallOpts(nodes.command("notify").description("Send a local notification on a node (mac only)").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--title <text>", "Notification title").option("--body <text>", "Notification body").option("--sound <name>", "Notification sound").option("--priority <passive|active|timeSensitive>", "Notification priority").option("--delivery <system|overlay|auto>", "Delivery mode", "system").option("--invoke-timeout <ms>", "Node invoke timeout in ms (default 15000)", "15000").action(async (opts) => {
657
+ await runNodesCommand("notify", async () => {
658
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
659
+ const title = String(opts.title ?? "").trim();
660
+ const body = String(opts.body ?? "").trim();
661
+ if (!title && !body) throw new Error("missing --title or --body");
662
+ const invokeTimeout = opts.invokeTimeout ? Number.parseInt(String(opts.invokeTimeout), 10) : void 0;
663
+ const invokeParams = {
664
+ nodeId,
665
+ command: "system.notify",
666
+ params: {
667
+ title,
668
+ body,
669
+ sound: opts.sound,
670
+ priority: opts.priority,
671
+ delivery: opts.delivery
672
+ },
673
+ idempotencyKey: String(opts.idempotencyKey ?? randomIdempotencyKey())
674
+ };
675
+ if (typeof invokeTimeout === "number" && Number.isFinite(invokeTimeout)) invokeParams.timeoutMs = invokeTimeout;
676
+ const result = await callGatewayCli("node.invoke", opts, invokeParams);
677
+ if (opts.json) {
678
+ defaultRuntime.log(JSON.stringify(result, null, 2));
679
+ return;
680
+ }
681
+ const { ok } = getNodesTheme();
682
+ defaultRuntime.log(ok("notify ok"));
683
+ });
684
+ }));
685
+ }
686
+
687
+ //#endregion
688
+ //#region src/cli/nodes-cli/register.pairing.ts
689
+ function registerNodesPairingCommands(nodes) {
690
+ nodesCallOpts(nodes.command("pending").description("List pending pairing requests").action(async (opts) => {
691
+ await runNodesCommand("pending", async () => {
692
+ const { pending } = parsePairingList(await callGatewayCli("node.pair.list", opts, {}));
693
+ if (opts.json) {
694
+ defaultRuntime.log(JSON.stringify(pending, null, 2));
695
+ return;
696
+ }
697
+ if (pending.length === 0) {
698
+ const { muted } = getNodesTheme();
699
+ defaultRuntime.log(muted("No pending pairing requests."));
700
+ return;
701
+ }
702
+ const { heading, warn, muted } = getNodesTheme();
703
+ const tableWidth = Math.max(60, (process.stdout.columns ?? 120) - 1);
704
+ const now = Date.now();
705
+ const rows = pending.map((r) => ({
706
+ Request: r.requestId,
707
+ Node: r.displayName?.trim() ? r.displayName.trim() : r.nodeId,
708
+ IP: r.remoteIp ?? "",
709
+ Requested: typeof r.ts === "number" ? `${formatAge(Math.max(0, now - r.ts))} ago` : muted("unknown"),
710
+ Repair: r.isRepair ? warn("yes") : ""
711
+ }));
712
+ defaultRuntime.log(heading("Pending"));
713
+ defaultRuntime.log(renderTable({
714
+ width: tableWidth,
715
+ columns: [
716
+ {
717
+ key: "Request",
718
+ header: "Request",
719
+ minWidth: 8
720
+ },
721
+ {
722
+ key: "Node",
723
+ header: "Node",
724
+ minWidth: 14,
725
+ flex: true
726
+ },
727
+ {
728
+ key: "IP",
729
+ header: "IP",
730
+ minWidth: 10
731
+ },
732
+ {
733
+ key: "Requested",
734
+ header: "Requested",
735
+ minWidth: 12
736
+ },
737
+ {
738
+ key: "Repair",
739
+ header: "Repair",
740
+ minWidth: 6
741
+ }
742
+ ],
743
+ rows
744
+ }).trimEnd());
745
+ });
746
+ }));
747
+ nodesCallOpts(nodes.command("approve").description("Approve a pending pairing request").argument("<requestId>", "Pending request id").action(async (requestId, opts) => {
748
+ await runNodesCommand("approve", async () => {
749
+ const result = await callGatewayCli("node.pair.approve", opts, { requestId });
750
+ defaultRuntime.log(JSON.stringify(result, null, 2));
751
+ });
752
+ }));
753
+ nodesCallOpts(nodes.command("reject").description("Reject a pending pairing request").argument("<requestId>", "Pending request id").action(async (requestId, opts) => {
754
+ await runNodesCommand("reject", async () => {
755
+ const result = await callGatewayCli("node.pair.reject", opts, { requestId });
756
+ defaultRuntime.log(JSON.stringify(result, null, 2));
757
+ });
758
+ }));
759
+ nodesCallOpts(nodes.command("rename").description("Rename a paired node (display name override)").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").requiredOption("--name <displayName>", "New display name").action(async (opts) => {
760
+ await runNodesCommand("rename", async () => {
761
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
762
+ const name = String(opts.name ?? "").trim();
763
+ if (!nodeId || !name) {
764
+ defaultRuntime.error("--node and --name required");
765
+ defaultRuntime.exit(1);
766
+ return;
767
+ }
768
+ const result = await callGatewayCli("node.rename", opts, {
769
+ nodeId,
770
+ displayName: name
771
+ });
772
+ if (opts.json) {
773
+ defaultRuntime.log(JSON.stringify(result, null, 2));
774
+ return;
775
+ }
776
+ const { ok } = getNodesTheme();
777
+ defaultRuntime.log(ok(`node rename ok: ${nodeId} -> ${name}`));
778
+ });
779
+ }));
780
+ }
781
+
782
+ //#endregion
783
+ //#region src/cli/nodes-cli/register.screen.ts
784
+ function registerNodesScreenCommands(nodes) {
785
+ nodesCallOpts(nodes.command("screen").description("Capture screen recordings from a paired node").command("record").description("Capture a short screen recording from a node (prints MEDIA:<path>)").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").option("--screen <index>", "Screen index (0 = primary)", "0").option("--duration <ms|10s>", "Clip duration (ms or 10s)", "10000").option("--fps <fps>", "Frames per second", "10").option("--no-audio", "Disable microphone audio capture").option("--out <path>", "Output path").option("--invoke-timeout <ms>", "Node invoke timeout in ms (default 120000)", "120000").action(async (opts) => {
786
+ await runNodesCommand("screen record", async () => {
787
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
788
+ const durationMs = parseDurationMs(opts.duration ?? "");
789
+ const screenIndex = Number.parseInt(String(opts.screen ?? "0"), 10);
790
+ const fps = Number.parseFloat(String(opts.fps ?? "10"));
791
+ const timeoutMs = opts.invokeTimeout ? Number.parseInt(String(opts.invokeTimeout), 10) : void 0;
792
+ const invokeParams = {
793
+ nodeId,
794
+ command: "screen.record",
795
+ params: {
796
+ durationMs: Number.isFinite(durationMs) ? durationMs : void 0,
797
+ screenIndex: Number.isFinite(screenIndex) ? screenIndex : void 0,
798
+ fps: Number.isFinite(fps) ? fps : void 0,
799
+ format: "mp4",
800
+ includeAudio: opts.audio !== false
801
+ },
802
+ idempotencyKey: randomIdempotencyKey()
803
+ };
804
+ if (typeof timeoutMs === "number" && Number.isFinite(timeoutMs)) invokeParams.timeoutMs = timeoutMs;
805
+ const raw = await callGatewayCli("node.invoke", opts, invokeParams);
806
+ const parsed = parseScreenRecordPayload((typeof raw === "object" && raw !== null ? raw : {}).payload);
807
+ const written = await writeScreenRecordToFile(opts.out ?? screenRecordTempPath({ ext: parsed.format || "mp4" }), parsed.base64);
808
+ if (opts.json) {
809
+ defaultRuntime.log(JSON.stringify({ file: {
810
+ path: written.path,
811
+ durationMs: parsed.durationMs,
812
+ fps: parsed.fps,
813
+ screenIndex: parsed.screenIndex,
814
+ hasAudio: parsed.hasAudio
815
+ } }, null, 2));
816
+ return;
817
+ }
818
+ defaultRuntime.log(`MEDIA:${shortenHomePath(written.path)}`);
819
+ });
820
+ }), { timeoutMs: 18e4 });
821
+ }
822
+
823
+ //#endregion
824
+ //#region src/cli/nodes-cli/register.status.ts
825
+ function formatVersionLabel(raw) {
826
+ const trimmed = raw.trim();
827
+ if (!trimmed) return raw;
828
+ if (trimmed.toLowerCase().startsWith("v")) return trimmed;
829
+ return /^\d/.test(trimmed) ? `v${trimmed}` : trimmed;
830
+ }
831
+ function resolveNodeVersions(node) {
832
+ const core = node.coreVersion?.trim() || void 0;
833
+ const ui = node.uiVersion?.trim() || void 0;
834
+ if (core || ui) return {
835
+ core,
836
+ ui
837
+ };
838
+ const legacy = node.version?.trim();
839
+ if (!legacy) return {
840
+ core: void 0,
841
+ ui: void 0
842
+ };
843
+ const platform = node.platform?.trim().toLowerCase() ?? "";
844
+ return platform === "darwin" || platform === "linux" || platform === "win32" || platform === "windows" ? {
845
+ core: legacy,
846
+ ui: void 0
847
+ } : {
848
+ core: void 0,
849
+ ui: legacy
850
+ };
851
+ }
852
+ function formatNodeVersions(node) {
853
+ const { core, ui } = resolveNodeVersions(node);
854
+ const parts = [];
855
+ if (core) parts.push(`core ${formatVersionLabel(core)}`);
856
+ if (ui) parts.push(`ui ${formatVersionLabel(ui)}`);
857
+ return parts.length > 0 ? parts.join(" · ") : null;
858
+ }
859
+ function formatPathEnv(raw) {
860
+ if (typeof raw !== "string") return null;
861
+ const trimmed = raw.trim();
862
+ if (!trimmed) return null;
863
+ const parts = trimmed.split(":").filter(Boolean);
864
+ return shortenHomeInString(parts.length <= 3 ? trimmed : `${parts.slice(0, 2).join(":")}:…:${parts.slice(-1)[0]}`);
865
+ }
866
+ function parseSinceMs(raw, label) {
867
+ if (raw === void 0 || raw === null) return;
868
+ const value = typeof raw === "string" ? raw.trim() : typeof raw === "number" ? String(raw).trim() : null;
869
+ if (value === null) {
870
+ defaultRuntime.error(`${label}: invalid duration value`);
871
+ defaultRuntime.exit(1);
872
+ return;
873
+ }
874
+ if (!value) return;
875
+ try {
876
+ return parseDurationMs(value);
877
+ } catch (err) {
878
+ const message = err instanceof Error ? err.message : String(err);
879
+ defaultRuntime.error(`${label}: ${message}`);
880
+ defaultRuntime.exit(1);
881
+ return;
882
+ }
883
+ }
884
+ function registerNodesStatusCommands(nodes) {
885
+ nodesCallOpts(nodes.command("status").description("List known nodes with connection status and capabilities").option("--connected", "Only show connected nodes").option("--last-connected <duration>", "Only show nodes connected within duration (e.g. 24h)").action(async (opts) => {
886
+ await runNodesCommand("status", async () => {
887
+ const connectedOnly = Boolean(opts.connected);
888
+ const sinceMs = parseSinceMs(opts.lastConnected, "Invalid --last-connected");
889
+ const result = await callGatewayCli("node.list", opts, {});
890
+ const obj = typeof result === "object" && result !== null ? result : {};
891
+ const { ok, warn, muted } = getNodesTheme();
892
+ const tableWidth = Math.max(60, (process.stdout.columns ?? 120) - 1);
893
+ const now = Date.now();
894
+ const nodes = parseNodeList(result);
895
+ const lastConnectedById = sinceMs !== void 0 ? new Map(parsePairingList(await callGatewayCli("node.pair.list", opts, {})).paired.map((entry) => [entry.nodeId, entry])) : null;
896
+ const filtered = nodes.filter((n) => {
897
+ if (connectedOnly && !n.connected) return false;
898
+ if (sinceMs !== void 0) {
899
+ const paired = lastConnectedById?.get(n.nodeId);
900
+ const lastConnectedAtMs = typeof paired?.lastConnectedAtMs === "number" ? paired.lastConnectedAtMs : typeof n.connectedAtMs === "number" ? n.connectedAtMs : void 0;
901
+ if (typeof lastConnectedAtMs !== "number") return false;
902
+ if (now - lastConnectedAtMs > sinceMs) return false;
903
+ }
904
+ return true;
905
+ });
906
+ if (opts.json) {
907
+ const ts = typeof obj.ts === "number" ? obj.ts : Date.now();
908
+ defaultRuntime.log(JSON.stringify({
909
+ ...obj,
910
+ ts,
911
+ nodes: filtered
912
+ }, null, 2));
913
+ return;
914
+ }
915
+ const pairedCount = filtered.filter((n) => Boolean(n.paired)).length;
916
+ const connectedCount = filtered.filter((n) => Boolean(n.connected)).length;
917
+ const filteredLabel = filtered.length !== nodes.length ? ` (of ${nodes.length})` : "";
918
+ defaultRuntime.log(`Known: ${filtered.length}${filteredLabel} · Paired: ${pairedCount} · Connected: ${connectedCount}`);
919
+ if (filtered.length === 0) return;
920
+ const rows = filtered.map((n) => {
921
+ const name = n.displayName?.trim() ? n.displayName.trim() : n.nodeId;
922
+ const perms = formatPermissions(n.permissions);
923
+ const versions = formatNodeVersions(n);
924
+ const pathEnv = formatPathEnv(n.pathEnv);
925
+ const detailParts = [
926
+ n.deviceFamily ? `device: ${n.deviceFamily}` : null,
927
+ n.modelIdentifier ? `hw: ${n.modelIdentifier}` : null,
928
+ perms ? `perms: ${perms}` : null,
929
+ versions,
930
+ pathEnv ? `path: ${pathEnv}` : null
931
+ ].filter(Boolean);
932
+ const caps = Array.isArray(n.caps) ? n.caps.map(String).filter(Boolean).toSorted().join(", ") : "?";
933
+ const paired = n.paired ? ok("paired") : warn("unpaired");
934
+ const connected = n.connected ? ok("connected") : muted("disconnected");
935
+ const since = typeof n.connectedAtMs === "number" ? ` (${formatAge(Math.max(0, now - n.connectedAtMs))} ago)` : "";
936
+ return {
937
+ Node: name,
938
+ ID: n.nodeId,
939
+ IP: n.remoteIp ?? "",
940
+ Detail: detailParts.join(" · "),
941
+ Status: `${paired} · ${connected}${since}`,
942
+ Caps: caps
943
+ };
944
+ });
945
+ defaultRuntime.log(renderTable({
946
+ width: tableWidth,
947
+ columns: [
948
+ {
949
+ key: "Node",
950
+ header: "Node",
951
+ minWidth: 14,
952
+ flex: true
953
+ },
954
+ {
955
+ key: "ID",
956
+ header: "ID",
957
+ minWidth: 10
958
+ },
959
+ {
960
+ key: "IP",
961
+ header: "IP",
962
+ minWidth: 10
963
+ },
964
+ {
965
+ key: "Detail",
966
+ header: "Detail",
967
+ minWidth: 18,
968
+ flex: true
969
+ },
970
+ {
971
+ key: "Status",
972
+ header: "Status",
973
+ minWidth: 18
974
+ },
975
+ {
976
+ key: "Caps",
977
+ header: "Caps",
978
+ minWidth: 12,
979
+ flex: true
980
+ }
981
+ ],
982
+ rows
983
+ }).trimEnd());
984
+ });
985
+ }));
986
+ nodesCallOpts(nodes.command("describe").description("Describe a node (capabilities + supported invoke commands)").requiredOption("--node <idOrNameOrIp>", "Node id, name, or IP").action(async (opts) => {
987
+ await runNodesCommand("describe", async () => {
988
+ const nodeId = await resolveNodeId(opts, String(opts.node ?? ""));
989
+ const result = await callGatewayCli("node.describe", opts, { nodeId });
990
+ if (opts.json) {
991
+ defaultRuntime.log(JSON.stringify(result, null, 2));
992
+ return;
993
+ }
994
+ const obj = typeof result === "object" && result !== null ? result : {};
995
+ const displayName = typeof obj.displayName === "string" ? obj.displayName : nodeId;
996
+ const connected = Boolean(obj.connected);
997
+ const paired = Boolean(obj.paired);
998
+ const caps = Array.isArray(obj.caps) ? obj.caps.map(String).filter(Boolean).toSorted() : null;
999
+ const commands = Array.isArray(obj.commands) ? obj.commands.map(String).filter(Boolean).toSorted() : [];
1000
+ const perms = formatPermissions(obj.permissions);
1001
+ const family = typeof obj.deviceFamily === "string" ? obj.deviceFamily : null;
1002
+ const model = typeof obj.modelIdentifier === "string" ? obj.modelIdentifier : null;
1003
+ const ip = typeof obj.remoteIp === "string" ? obj.remoteIp : null;
1004
+ const pathEnv = typeof obj.pathEnv === "string" ? obj.pathEnv : null;
1005
+ const versions = formatNodeVersions(obj);
1006
+ const { heading, ok, warn, muted } = getNodesTheme();
1007
+ const status = `${paired ? ok("paired") : warn("unpaired")} · ${connected ? ok("connected") : muted("disconnected")}`;
1008
+ const tableWidth = Math.max(60, (process.stdout.columns ?? 120) - 1);
1009
+ const rows = [
1010
+ {
1011
+ Field: "ID",
1012
+ Value: nodeId
1013
+ },
1014
+ displayName ? {
1015
+ Field: "Name",
1016
+ Value: displayName
1017
+ } : null,
1018
+ ip ? {
1019
+ Field: "IP",
1020
+ Value: ip
1021
+ } : null,
1022
+ family ? {
1023
+ Field: "Device",
1024
+ Value: family
1025
+ } : null,
1026
+ model ? {
1027
+ Field: "Model",
1028
+ Value: model
1029
+ } : null,
1030
+ perms ? {
1031
+ Field: "Perms",
1032
+ Value: perms
1033
+ } : null,
1034
+ versions ? {
1035
+ Field: "Version",
1036
+ Value: versions
1037
+ } : null,
1038
+ pathEnv ? {
1039
+ Field: "PATH",
1040
+ Value: pathEnv
1041
+ } : null,
1042
+ {
1043
+ Field: "Status",
1044
+ Value: status
1045
+ },
1046
+ {
1047
+ Field: "Caps",
1048
+ Value: caps ? caps.join(", ") : "?"
1049
+ }
1050
+ ].filter(Boolean);
1051
+ defaultRuntime.log(heading("Node"));
1052
+ defaultRuntime.log(renderTable({
1053
+ width: tableWidth,
1054
+ columns: [{
1055
+ key: "Field",
1056
+ header: "Field",
1057
+ minWidth: 8
1058
+ }, {
1059
+ key: "Value",
1060
+ header: "Value",
1061
+ minWidth: 24,
1062
+ flex: true
1063
+ }],
1064
+ rows
1065
+ }).trimEnd());
1066
+ defaultRuntime.log("");
1067
+ defaultRuntime.log(heading("Commands"));
1068
+ if (commands.length === 0) {
1069
+ defaultRuntime.log(muted("- (none reported)"));
1070
+ return;
1071
+ }
1072
+ for (const c of commands) defaultRuntime.log(`- ${c}`);
1073
+ });
1074
+ }));
1075
+ nodesCallOpts(nodes.command("list").description("List pending and paired nodes").option("--connected", "Only show connected nodes").option("--last-connected <duration>", "Only show nodes connected within duration (e.g. 24h)").action(async (opts) => {
1076
+ await runNodesCommand("list", async () => {
1077
+ const connectedOnly = Boolean(opts.connected);
1078
+ const sinceMs = parseSinceMs(opts.lastConnected, "Invalid --last-connected");
1079
+ const { pending, paired } = parsePairingList(await callGatewayCli("node.pair.list", opts, {}));
1080
+ const { heading, muted, warn } = getNodesTheme();
1081
+ const tableWidth = Math.max(60, (process.stdout.columns ?? 120) - 1);
1082
+ const now = Date.now();
1083
+ const hasFilters = connectedOnly || sinceMs !== void 0;
1084
+ const pendingRows = hasFilters ? [] : pending;
1085
+ const connectedById = hasFilters ? new Map(parseNodeList(await callGatewayCli("node.list", opts, {})).map((node) => [node.nodeId, node])) : null;
1086
+ const filteredPaired = paired.filter((node) => {
1087
+ if (connectedOnly) {
1088
+ if (!(connectedById?.get(node.nodeId))?.connected) return false;
1089
+ }
1090
+ if (sinceMs !== void 0) {
1091
+ const live = connectedById?.get(node.nodeId);
1092
+ const lastConnectedAtMs = typeof node.lastConnectedAtMs === "number" ? node.lastConnectedAtMs : typeof live?.connectedAtMs === "number" ? live.connectedAtMs : void 0;
1093
+ if (typeof lastConnectedAtMs !== "number") return false;
1094
+ if (now - lastConnectedAtMs > sinceMs) return false;
1095
+ }
1096
+ return true;
1097
+ });
1098
+ const filteredLabel = hasFilters && filteredPaired.length !== paired.length ? ` (of ${paired.length})` : "";
1099
+ defaultRuntime.log(`Pending: ${pendingRows.length} · Paired: ${filteredPaired.length}${filteredLabel}`);
1100
+ if (opts.json) {
1101
+ defaultRuntime.log(JSON.stringify({
1102
+ pending: pendingRows,
1103
+ paired: filteredPaired
1104
+ }, null, 2));
1105
+ return;
1106
+ }
1107
+ if (pendingRows.length > 0) {
1108
+ const pendingRowsRendered = pendingRows.map((r) => ({
1109
+ Request: r.requestId,
1110
+ Node: r.displayName?.trim() ? r.displayName.trim() : r.nodeId,
1111
+ IP: r.remoteIp ?? "",
1112
+ Requested: typeof r.ts === "number" ? `${formatAge(Math.max(0, now - r.ts))} ago` : muted("unknown"),
1113
+ Repair: r.isRepair ? warn("yes") : ""
1114
+ }));
1115
+ defaultRuntime.log("");
1116
+ defaultRuntime.log(heading("Pending"));
1117
+ defaultRuntime.log(renderTable({
1118
+ width: tableWidth,
1119
+ columns: [
1120
+ {
1121
+ key: "Request",
1122
+ header: "Request",
1123
+ minWidth: 8
1124
+ },
1125
+ {
1126
+ key: "Node",
1127
+ header: "Node",
1128
+ minWidth: 14,
1129
+ flex: true
1130
+ },
1131
+ {
1132
+ key: "IP",
1133
+ header: "IP",
1134
+ minWidth: 10
1135
+ },
1136
+ {
1137
+ key: "Requested",
1138
+ header: "Requested",
1139
+ minWidth: 12
1140
+ },
1141
+ {
1142
+ key: "Repair",
1143
+ header: "Repair",
1144
+ minWidth: 6
1145
+ }
1146
+ ],
1147
+ rows: pendingRowsRendered
1148
+ }).trimEnd());
1149
+ }
1150
+ if (filteredPaired.length > 0) {
1151
+ const pairedRows = filteredPaired.map((n) => {
1152
+ const live = connectedById?.get(n.nodeId);
1153
+ const lastConnectedAtMs = typeof n.lastConnectedAtMs === "number" ? n.lastConnectedAtMs : typeof live?.connectedAtMs === "number" ? live.connectedAtMs : void 0;
1154
+ return {
1155
+ Node: n.displayName?.trim() ? n.displayName.trim() : n.nodeId,
1156
+ Id: n.nodeId,
1157
+ IP: n.remoteIp ?? "",
1158
+ LastConnect: typeof lastConnectedAtMs === "number" ? `${formatAge(Math.max(0, now - lastConnectedAtMs))} ago` : muted("unknown")
1159
+ };
1160
+ });
1161
+ defaultRuntime.log("");
1162
+ defaultRuntime.log(heading("Paired"));
1163
+ defaultRuntime.log(renderTable({
1164
+ width: tableWidth,
1165
+ columns: [
1166
+ {
1167
+ key: "Node",
1168
+ header: "Node",
1169
+ minWidth: 14,
1170
+ flex: true
1171
+ },
1172
+ {
1173
+ key: "Id",
1174
+ header: "ID",
1175
+ minWidth: 10
1176
+ },
1177
+ {
1178
+ key: "IP",
1179
+ header: "IP",
1180
+ minWidth: 10
1181
+ },
1182
+ {
1183
+ key: "LastConnect",
1184
+ header: "Last Connect",
1185
+ minWidth: 14
1186
+ }
1187
+ ],
1188
+ rows: pairedRows
1189
+ }).trimEnd());
1190
+ }
1191
+ });
1192
+ }));
1193
+ }
1194
+
1195
+ //#endregion
1196
+ //#region src/cli/nodes-cli/register.ts
1197
+ function registerNodesCli(program) {
1198
+ const nodes = program.command("nodes").description("Manage gateway-owned node pairing").addHelpText("after", () => `\n${theme.muted("Docs:")} ${formatDocsLink("/cli/nodes", "docs.cryptoclaw.ai/cli/nodes")}\n`);
1199
+ registerNodesStatusCommands(nodes);
1200
+ registerNodesPairingCommands(nodes);
1201
+ registerNodesInvokeCommands(nodes);
1202
+ registerNodesNotifyCommand(nodes);
1203
+ registerNodesCanvasCommands(nodes);
1204
+ registerNodesCameraCommands(nodes);
1205
+ registerNodesScreenCommands(nodes);
1206
+ registerNodesLocationCommands(nodes);
1207
+ }
1208
+
1209
+ //#endregion
1210
+ export { registerNodesCli };