@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,1212 @@
1
+ import { Fn as resolveEffectiveMessagesConfig, O as resolveHeartbeatDeliveryTarget, Rn as resolveUserTimezone, br as peekSystemEvents, cn as emitHeartbeatEvent, cr as DEFAULT_HEARTBEAT_ACK_MAX_CHARS, dn as resolveIndicatorType, dr as resolveHeartbeatPrompt$1, et as requestHeartbeatNow, fr as stripHeartbeatToken, ir as CommandLane, k as resolveHeartbeatSenderContext, lr as DEFAULT_HEARTBEAT_EVERY, nr as getQueueSize, sn as resolveHeartbeatVisibility, t as getReplyFromConfig, tt as setHeartbeatWakeHandler, ur as isHeartbeatContentEffectivelyEmpty } from "./reply-DfepuqG0.js";
2
+ import { c as normalizeAgentId, m as toAgentStoreSessionKey, u as resolveAgentIdFromSessionKey } from "./session-key-CYpWeuht.js";
3
+ import { D as info, I as colorize, L as isRich, R as theme, c as defaultRuntime, t as createSubsystemLogger } from "./subsystem-Btuh5yZj.js";
4
+ import { c as resolveDefaultAgentId, m as DEFAULT_HEARTBEAT_FILENAME, n as resolveAgentConfig, s as resolveAgentWorkspaceDir } from "./agent-scope-DLfFOxP6.js";
5
+ import { t as isTruthyEnvValue } from "./env-B2Cd_6IS.js";
6
+ import { h as parseDurationMs, i as loadConfig } from "./config-dQK4rbfx.js";
7
+ import { f as resolvePreferredAccountId, n as listChannelPlugins, t as getChannelPlugin, u as buildChannelAccountBindings } from "./plugins-Dk4UBZwz.js";
8
+ import { F as resolveAgentMainSessionKey, P as canonicalizeMainSessionAlias, d as loadSessionStore, g as updateSessionStore, m as saveSessionStore } from "./sandbox-D_Tt3WRq.js";
9
+ import { T as formatErrorMessage } from "./chrome-CwbWzmh4.js";
10
+ import { o as resolveStorePath } from "./paths-C3yk0MGu.js";
11
+ import { W as HEARTBEAT_TOKEN, t as deliverOutboundPayloads } from "./deliver-sPBfRlXT.js";
12
+ import { n as callGateway, t as buildGatewayConnectionDetails } from "./call-DqxlETxE.js";
13
+ import { n as withProgress } from "./progress-DTEUicRP.js";
14
+ import { t as resolveChannelDefaultAccountId } from "./helpers-CzQjTUbz.js";
15
+ import path from "node:path";
16
+ import fs from "node:fs/promises";
17
+
18
+ //#region src/infra/heartbeat-runner.ts
19
+ const log = createSubsystemLogger("gateway/heartbeat");
20
+ let heartbeatsEnabled = true;
21
+ function setHeartbeatsEnabled(enabled) {
22
+ heartbeatsEnabled = enabled;
23
+ }
24
+ const DEFAULT_HEARTBEAT_TARGET = "last";
25
+ const ACTIVE_HOURS_TIME_PATTERN = /^([01]\d|2[0-3]|24):([0-5]\d)$/;
26
+ const EXEC_EVENT_PROMPT = "An async command you ran earlier has completed. The result is shown in the system messages above. Please relay the command output to the user in a helpful way. If the command succeeded, share the relevant output. If it failed, explain what went wrong.";
27
+ function resolveActiveHoursTimezone(cfg, raw) {
28
+ const trimmed = raw?.trim();
29
+ if (!trimmed || trimmed === "user") return resolveUserTimezone(cfg.agents?.defaults?.userTimezone);
30
+ if (trimmed === "local") return Intl.DateTimeFormat().resolvedOptions().timeZone?.trim() || "UTC";
31
+ try {
32
+ new Intl.DateTimeFormat("en-US", { timeZone: trimmed }).format(/* @__PURE__ */ new Date());
33
+ return trimmed;
34
+ } catch {
35
+ return resolveUserTimezone(cfg.agents?.defaults?.userTimezone);
36
+ }
37
+ }
38
+ function parseActiveHoursTime(opts, raw) {
39
+ if (!raw || !ACTIVE_HOURS_TIME_PATTERN.test(raw)) return null;
40
+ const [hourStr, minuteStr] = raw.split(":");
41
+ const hour = Number(hourStr);
42
+ const minute = Number(minuteStr);
43
+ if (!Number.isFinite(hour) || !Number.isFinite(minute)) return null;
44
+ if (hour === 24) {
45
+ if (!opts.allow24 || minute !== 0) return null;
46
+ return 1440;
47
+ }
48
+ return hour * 60 + minute;
49
+ }
50
+ function resolveMinutesInTimeZone(nowMs, timeZone) {
51
+ try {
52
+ const parts = new Intl.DateTimeFormat("en-US", {
53
+ timeZone,
54
+ hour: "2-digit",
55
+ minute: "2-digit",
56
+ hourCycle: "h23"
57
+ }).formatToParts(new Date(nowMs));
58
+ const map = {};
59
+ for (const part of parts) if (part.type !== "literal") map[part.type] = part.value;
60
+ const hour = Number(map.hour);
61
+ const minute = Number(map.minute);
62
+ if (!Number.isFinite(hour) || !Number.isFinite(minute)) return null;
63
+ return hour * 60 + minute;
64
+ } catch {
65
+ return null;
66
+ }
67
+ }
68
+ function isWithinActiveHours(cfg, heartbeat, nowMs) {
69
+ const active = heartbeat?.activeHours;
70
+ if (!active) return true;
71
+ const startMin = parseActiveHoursTime({ allow24: false }, active.start);
72
+ const endMin = parseActiveHoursTime({ allow24: true }, active.end);
73
+ if (startMin === null || endMin === null) return true;
74
+ if (startMin === endMin) return true;
75
+ const timeZone = resolveActiveHoursTimezone(cfg, active.timezone);
76
+ const currentMin = resolveMinutesInTimeZone(nowMs ?? Date.now(), timeZone);
77
+ if (currentMin === null) return true;
78
+ if (endMin > startMin) return currentMin >= startMin && currentMin < endMin;
79
+ return currentMin >= startMin || currentMin < endMin;
80
+ }
81
+ function hasExplicitHeartbeatAgents(cfg) {
82
+ return (cfg.agents?.list ?? []).some((entry) => Boolean(entry?.heartbeat));
83
+ }
84
+ function isHeartbeatEnabledForAgent(cfg, agentId) {
85
+ const resolvedAgentId = normalizeAgentId(agentId ?? resolveDefaultAgentId(cfg));
86
+ const list = cfg.agents?.list ?? [];
87
+ if (hasExplicitHeartbeatAgents(cfg)) return list.some((entry) => Boolean(entry?.heartbeat) && normalizeAgentId(entry?.id) === resolvedAgentId);
88
+ return resolvedAgentId === resolveDefaultAgentId(cfg);
89
+ }
90
+ function resolveHeartbeatConfig(cfg, agentId) {
91
+ const defaults = cfg.agents?.defaults?.heartbeat;
92
+ if (!agentId) return defaults;
93
+ const overrides = resolveAgentConfig(cfg, agentId)?.heartbeat;
94
+ if (!defaults && !overrides) return overrides;
95
+ return {
96
+ ...defaults,
97
+ ...overrides
98
+ };
99
+ }
100
+ function resolveHeartbeatSummaryForAgent(cfg, agentId) {
101
+ const defaults = cfg.agents?.defaults?.heartbeat;
102
+ const overrides = agentId ? resolveAgentConfig(cfg, agentId)?.heartbeat : void 0;
103
+ if (!isHeartbeatEnabledForAgent(cfg, agentId)) return {
104
+ enabled: false,
105
+ every: "disabled",
106
+ everyMs: null,
107
+ prompt: resolveHeartbeatPrompt$1(defaults?.prompt),
108
+ target: defaults?.target ?? DEFAULT_HEARTBEAT_TARGET,
109
+ model: defaults?.model,
110
+ ackMaxChars: Math.max(0, defaults?.ackMaxChars ?? DEFAULT_HEARTBEAT_ACK_MAX_CHARS)
111
+ };
112
+ const merged = defaults || overrides ? {
113
+ ...defaults,
114
+ ...overrides
115
+ } : void 0;
116
+ return {
117
+ enabled: true,
118
+ every: merged?.every ?? defaults?.every ?? overrides?.every ?? DEFAULT_HEARTBEAT_EVERY,
119
+ everyMs: resolveHeartbeatIntervalMs(cfg, void 0, merged),
120
+ prompt: resolveHeartbeatPrompt$1(merged?.prompt ?? defaults?.prompt ?? overrides?.prompt),
121
+ target: merged?.target ?? defaults?.target ?? overrides?.target ?? DEFAULT_HEARTBEAT_TARGET,
122
+ model: merged?.model ?? defaults?.model ?? overrides?.model,
123
+ ackMaxChars: Math.max(0, merged?.ackMaxChars ?? defaults?.ackMaxChars ?? overrides?.ackMaxChars ?? DEFAULT_HEARTBEAT_ACK_MAX_CHARS)
124
+ };
125
+ }
126
+ function resolveHeartbeatAgents(cfg) {
127
+ const list = cfg.agents?.list ?? [];
128
+ if (hasExplicitHeartbeatAgents(cfg)) return list.filter((entry) => entry?.heartbeat).map((entry) => {
129
+ const id = normalizeAgentId(entry.id);
130
+ return {
131
+ agentId: id,
132
+ heartbeat: resolveHeartbeatConfig(cfg, id)
133
+ };
134
+ }).filter((entry) => entry.agentId);
135
+ const fallbackId = resolveDefaultAgentId(cfg);
136
+ return [{
137
+ agentId: fallbackId,
138
+ heartbeat: resolveHeartbeatConfig(cfg, fallbackId)
139
+ }];
140
+ }
141
+ function resolveHeartbeatIntervalMs(cfg, overrideEvery, heartbeat) {
142
+ const raw = overrideEvery ?? heartbeat?.every ?? cfg.agents?.defaults?.heartbeat?.every ?? DEFAULT_HEARTBEAT_EVERY;
143
+ if (!raw) return null;
144
+ const trimmed = String(raw).trim();
145
+ if (!trimmed) return null;
146
+ let ms;
147
+ try {
148
+ ms = parseDurationMs(trimmed, { defaultUnit: "m" });
149
+ } catch {
150
+ return null;
151
+ }
152
+ if (ms <= 0) return null;
153
+ return ms;
154
+ }
155
+ function resolveHeartbeatPrompt(cfg, heartbeat) {
156
+ return resolveHeartbeatPrompt$1(heartbeat?.prompt ?? cfg.agents?.defaults?.heartbeat?.prompt);
157
+ }
158
+ function resolveHeartbeatAckMaxChars(cfg, heartbeat) {
159
+ return Math.max(0, heartbeat?.ackMaxChars ?? cfg.agents?.defaults?.heartbeat?.ackMaxChars ?? DEFAULT_HEARTBEAT_ACK_MAX_CHARS);
160
+ }
161
+ function resolveHeartbeatSession(cfg, agentId, heartbeat) {
162
+ const sessionCfg = cfg.session;
163
+ const scope = sessionCfg?.scope ?? "per-sender";
164
+ const resolvedAgentId = normalizeAgentId(agentId ?? resolveDefaultAgentId(cfg));
165
+ const mainSessionKey = scope === "global" ? "global" : resolveAgentMainSessionKey({
166
+ cfg,
167
+ agentId: resolvedAgentId
168
+ });
169
+ const storeAgentId = scope === "global" ? resolveDefaultAgentId(cfg) : resolvedAgentId;
170
+ const storePath = resolveStorePath(sessionCfg?.store, { agentId: storeAgentId });
171
+ const store = loadSessionStore(storePath);
172
+ const mainEntry = store[mainSessionKey];
173
+ if (scope === "global") return {
174
+ sessionKey: mainSessionKey,
175
+ storePath,
176
+ store,
177
+ entry: mainEntry
178
+ };
179
+ const trimmed = heartbeat?.session?.trim() ?? "";
180
+ if (!trimmed) return {
181
+ sessionKey: mainSessionKey,
182
+ storePath,
183
+ store,
184
+ entry: mainEntry
185
+ };
186
+ const normalized = trimmed.toLowerCase();
187
+ if (normalized === "main" || normalized === "global") return {
188
+ sessionKey: mainSessionKey,
189
+ storePath,
190
+ store,
191
+ entry: mainEntry
192
+ };
193
+ const canonical = canonicalizeMainSessionAlias({
194
+ cfg,
195
+ agentId: resolvedAgentId,
196
+ sessionKey: toAgentStoreSessionKey({
197
+ agentId: resolvedAgentId,
198
+ requestKey: trimmed,
199
+ mainKey: cfg.session?.mainKey
200
+ })
201
+ });
202
+ if (canonical !== "global") {
203
+ if (resolveAgentIdFromSessionKey(canonical) === normalizeAgentId(resolvedAgentId)) return {
204
+ sessionKey: canonical,
205
+ storePath,
206
+ store,
207
+ entry: store[canonical]
208
+ };
209
+ }
210
+ return {
211
+ sessionKey: mainSessionKey,
212
+ storePath,
213
+ store,
214
+ entry: mainEntry
215
+ };
216
+ }
217
+ function resolveHeartbeatReplyPayload(replyResult) {
218
+ if (!replyResult) return;
219
+ if (!Array.isArray(replyResult)) return replyResult;
220
+ for (let idx = replyResult.length - 1; idx >= 0; idx -= 1) {
221
+ const payload = replyResult[idx];
222
+ if (!payload) continue;
223
+ if (payload.text || payload.mediaUrl || payload.mediaUrls && payload.mediaUrls.length > 0) return payload;
224
+ }
225
+ }
226
+ function resolveHeartbeatReasoningPayloads(replyResult) {
227
+ return (Array.isArray(replyResult) ? replyResult : replyResult ? [replyResult] : []).filter((payload) => {
228
+ return (typeof payload.text === "string" ? payload.text : "").trimStart().startsWith("Reasoning:");
229
+ });
230
+ }
231
+ async function restoreHeartbeatUpdatedAt(params) {
232
+ const { storePath, sessionKey, updatedAt } = params;
233
+ if (typeof updatedAt !== "number") return;
234
+ const entry = loadSessionStore(storePath)[sessionKey];
235
+ if (!entry) return;
236
+ const nextUpdatedAt = Math.max(entry.updatedAt ?? 0, updatedAt);
237
+ if (entry.updatedAt === nextUpdatedAt) return;
238
+ await updateSessionStore(storePath, (nextStore) => {
239
+ const nextEntry = nextStore[sessionKey] ?? entry;
240
+ if (!nextEntry) return;
241
+ const resolvedUpdatedAt = Math.max(nextEntry.updatedAt ?? 0, updatedAt);
242
+ if (nextEntry.updatedAt === resolvedUpdatedAt) return;
243
+ nextStore[sessionKey] = {
244
+ ...nextEntry,
245
+ updatedAt: resolvedUpdatedAt
246
+ };
247
+ });
248
+ }
249
+ function normalizeHeartbeatReply(payload, responsePrefix, ackMaxChars) {
250
+ const stripped = stripHeartbeatToken(payload.text, {
251
+ mode: "heartbeat",
252
+ maxAckChars: ackMaxChars
253
+ });
254
+ const hasMedia = Boolean(payload.mediaUrl || (payload.mediaUrls?.length ?? 0) > 0);
255
+ if (stripped.shouldSkip && !hasMedia) return {
256
+ shouldSkip: true,
257
+ text: "",
258
+ hasMedia
259
+ };
260
+ let finalText = stripped.text;
261
+ if (responsePrefix && finalText && !finalText.startsWith(responsePrefix)) finalText = `${responsePrefix} ${finalText}`;
262
+ return {
263
+ shouldSkip: false,
264
+ text: finalText,
265
+ hasMedia
266
+ };
267
+ }
268
+ async function runHeartbeatOnce(opts) {
269
+ const cfg = opts.cfg ?? loadConfig();
270
+ const agentId = normalizeAgentId(opts.agentId ?? resolveDefaultAgentId(cfg));
271
+ const heartbeat = opts.heartbeat ?? resolveHeartbeatConfig(cfg, agentId);
272
+ if (!heartbeatsEnabled) return {
273
+ status: "skipped",
274
+ reason: "disabled"
275
+ };
276
+ if (!isHeartbeatEnabledForAgent(cfg, agentId)) return {
277
+ status: "skipped",
278
+ reason: "disabled"
279
+ };
280
+ if (!resolveHeartbeatIntervalMs(cfg, void 0, heartbeat)) return {
281
+ status: "skipped",
282
+ reason: "disabled"
283
+ };
284
+ const startedAt = opts.deps?.nowMs?.() ?? Date.now();
285
+ if (!isWithinActiveHours(cfg, heartbeat, startedAt)) return {
286
+ status: "skipped",
287
+ reason: "quiet-hours"
288
+ };
289
+ if ((opts.deps?.getQueueSize ?? getQueueSize)(CommandLane.Main) > 0) return {
290
+ status: "skipped",
291
+ reason: "requests-in-flight"
292
+ };
293
+ const isExecEventReason = opts.reason === "exec-event";
294
+ const workspaceDir = resolveAgentWorkspaceDir(cfg, agentId);
295
+ const heartbeatFilePath = path.join(workspaceDir, DEFAULT_HEARTBEAT_FILENAME);
296
+ try {
297
+ if (isHeartbeatContentEffectivelyEmpty(await fs.readFile(heartbeatFilePath, "utf-8")) && !isExecEventReason) {
298
+ emitHeartbeatEvent({
299
+ status: "skipped",
300
+ reason: "empty-heartbeat-file",
301
+ durationMs: Date.now() - startedAt
302
+ });
303
+ return {
304
+ status: "skipped",
305
+ reason: "empty-heartbeat-file"
306
+ };
307
+ }
308
+ } catch {}
309
+ const { entry, sessionKey, storePath } = resolveHeartbeatSession(cfg, agentId, heartbeat);
310
+ const previousUpdatedAt = entry?.updatedAt;
311
+ const delivery = resolveHeartbeatDeliveryTarget({
312
+ cfg,
313
+ entry,
314
+ heartbeat
315
+ });
316
+ const heartbeatAccountId = heartbeat?.accountId?.trim();
317
+ if (delivery.reason === "unknown-account") log.warn("heartbeat: unknown accountId", {
318
+ accountId: delivery.accountId ?? heartbeatAccountId ?? null,
319
+ target: heartbeat?.target ?? "last"
320
+ });
321
+ else if (heartbeatAccountId) log.info("heartbeat: using explicit accountId", {
322
+ accountId: delivery.accountId ?? heartbeatAccountId,
323
+ target: heartbeat?.target ?? "last",
324
+ channel: delivery.channel
325
+ });
326
+ const visibility = delivery.channel !== "none" ? resolveHeartbeatVisibility({
327
+ cfg,
328
+ channel: delivery.channel,
329
+ accountId: delivery.accountId
330
+ }) : {
331
+ showOk: false,
332
+ showAlerts: true,
333
+ useIndicator: true
334
+ };
335
+ const { sender } = resolveHeartbeatSenderContext({
336
+ cfg,
337
+ entry,
338
+ delivery
339
+ });
340
+ const responsePrefix = resolveEffectiveMessagesConfig(cfg, agentId, {
341
+ channel: delivery.channel !== "none" ? delivery.channel : void 0,
342
+ accountId: delivery.accountId
343
+ }).responsePrefix;
344
+ const hasExecCompletion = (opts.reason === "exec-event" ? peekSystemEvents(sessionKey) : []).some((evt) => evt.includes("Exec finished"));
345
+ const ctx = {
346
+ Body: hasExecCompletion ? EXEC_EVENT_PROMPT : resolveHeartbeatPrompt(cfg, heartbeat),
347
+ From: sender,
348
+ To: sender,
349
+ Provider: hasExecCompletion ? "exec-event" : "heartbeat",
350
+ SessionKey: sessionKey
351
+ };
352
+ if (!visibility.showAlerts && !visibility.showOk && !visibility.useIndicator) {
353
+ emitHeartbeatEvent({
354
+ status: "skipped",
355
+ reason: "alerts-disabled",
356
+ durationMs: Date.now() - startedAt,
357
+ channel: delivery.channel !== "none" ? delivery.channel : void 0,
358
+ accountId: delivery.accountId
359
+ });
360
+ return {
361
+ status: "skipped",
362
+ reason: "alerts-disabled"
363
+ };
364
+ }
365
+ const heartbeatOkText = responsePrefix ? `${responsePrefix} ${HEARTBEAT_TOKEN}` : HEARTBEAT_TOKEN;
366
+ const canAttemptHeartbeatOk = Boolean(visibility.showOk && delivery.channel !== "none" && delivery.to);
367
+ const maybeSendHeartbeatOk = async () => {
368
+ if (!canAttemptHeartbeatOk || delivery.channel === "none" || !delivery.to) return false;
369
+ const heartbeatPlugin = getChannelPlugin(delivery.channel);
370
+ if (heartbeatPlugin?.heartbeat?.checkReady) {
371
+ if (!(await heartbeatPlugin.heartbeat.checkReady({
372
+ cfg,
373
+ accountId: delivery.accountId,
374
+ deps: opts.deps
375
+ })).ok) return false;
376
+ }
377
+ await deliverOutboundPayloads({
378
+ cfg,
379
+ channel: delivery.channel,
380
+ to: delivery.to,
381
+ accountId: delivery.accountId,
382
+ payloads: [{ text: heartbeatOkText }],
383
+ deps: opts.deps
384
+ });
385
+ return true;
386
+ };
387
+ try {
388
+ const replyResult = await getReplyFromConfig(ctx, { isHeartbeat: true }, cfg);
389
+ const replyPayload = resolveHeartbeatReplyPayload(replyResult);
390
+ const reasoningPayloads = heartbeat?.includeReasoning === true ? resolveHeartbeatReasoningPayloads(replyResult).filter((payload) => payload !== replyPayload) : [];
391
+ if (!replyPayload || !replyPayload.text && !replyPayload.mediaUrl && !replyPayload.mediaUrls?.length) {
392
+ await restoreHeartbeatUpdatedAt({
393
+ storePath,
394
+ sessionKey,
395
+ updatedAt: previousUpdatedAt
396
+ });
397
+ const okSent = await maybeSendHeartbeatOk();
398
+ emitHeartbeatEvent({
399
+ status: "ok-empty",
400
+ reason: opts.reason,
401
+ durationMs: Date.now() - startedAt,
402
+ channel: delivery.channel !== "none" ? delivery.channel : void 0,
403
+ accountId: delivery.accountId,
404
+ silent: !okSent,
405
+ indicatorType: visibility.useIndicator ? resolveIndicatorType("ok-empty") : void 0
406
+ });
407
+ return {
408
+ status: "ran",
409
+ durationMs: Date.now() - startedAt
410
+ };
411
+ }
412
+ const normalized = normalizeHeartbeatReply(replyPayload, responsePrefix, resolveHeartbeatAckMaxChars(cfg, heartbeat));
413
+ const execFallbackText = hasExecCompletion && !normalized.text.trim() && replyPayload.text?.trim() ? replyPayload.text.trim() : null;
414
+ if (execFallbackText) {
415
+ normalized.text = execFallbackText;
416
+ normalized.shouldSkip = false;
417
+ }
418
+ const shouldSkipMain = normalized.shouldSkip && !normalized.hasMedia && !hasExecCompletion;
419
+ if (shouldSkipMain && reasoningPayloads.length === 0) {
420
+ await restoreHeartbeatUpdatedAt({
421
+ storePath,
422
+ sessionKey,
423
+ updatedAt: previousUpdatedAt
424
+ });
425
+ const okSent = await maybeSendHeartbeatOk();
426
+ emitHeartbeatEvent({
427
+ status: "ok-token",
428
+ reason: opts.reason,
429
+ durationMs: Date.now() - startedAt,
430
+ channel: delivery.channel !== "none" ? delivery.channel : void 0,
431
+ accountId: delivery.accountId,
432
+ silent: !okSent,
433
+ indicatorType: visibility.useIndicator ? resolveIndicatorType("ok-token") : void 0
434
+ });
435
+ return {
436
+ status: "ran",
437
+ durationMs: Date.now() - startedAt
438
+ };
439
+ }
440
+ const mediaUrls = replyPayload.mediaUrls ?? (replyPayload.mediaUrl ? [replyPayload.mediaUrl] : []);
441
+ const prevHeartbeatText = typeof entry?.lastHeartbeatText === "string" ? entry.lastHeartbeatText : "";
442
+ const prevHeartbeatAt = typeof entry?.lastHeartbeatSentAt === "number" ? entry.lastHeartbeatSentAt : void 0;
443
+ if (!shouldSkipMain && !mediaUrls.length && Boolean(prevHeartbeatText.trim()) && normalized.text.trim() === prevHeartbeatText.trim() && typeof prevHeartbeatAt === "number" && startedAt - prevHeartbeatAt < 1440 * 60 * 1e3) {
444
+ await restoreHeartbeatUpdatedAt({
445
+ storePath,
446
+ sessionKey,
447
+ updatedAt: previousUpdatedAt
448
+ });
449
+ emitHeartbeatEvent({
450
+ status: "skipped",
451
+ reason: "duplicate",
452
+ preview: normalized.text.slice(0, 200),
453
+ durationMs: Date.now() - startedAt,
454
+ hasMedia: false,
455
+ channel: delivery.channel !== "none" ? delivery.channel : void 0,
456
+ accountId: delivery.accountId
457
+ });
458
+ return {
459
+ status: "ran",
460
+ durationMs: Date.now() - startedAt
461
+ };
462
+ }
463
+ const previewText = shouldSkipMain ? reasoningPayloads.map((payload) => payload.text).filter((text) => Boolean(text?.trim())).join("\n") : normalized.text;
464
+ if (delivery.channel === "none" || !delivery.to) {
465
+ emitHeartbeatEvent({
466
+ status: "skipped",
467
+ reason: delivery.reason ?? "no-target",
468
+ preview: previewText?.slice(0, 200),
469
+ durationMs: Date.now() - startedAt,
470
+ hasMedia: mediaUrls.length > 0,
471
+ accountId: delivery.accountId
472
+ });
473
+ return {
474
+ status: "ran",
475
+ durationMs: Date.now() - startedAt
476
+ };
477
+ }
478
+ if (!visibility.showAlerts) {
479
+ await restoreHeartbeatUpdatedAt({
480
+ storePath,
481
+ sessionKey,
482
+ updatedAt: previousUpdatedAt
483
+ });
484
+ emitHeartbeatEvent({
485
+ status: "skipped",
486
+ reason: "alerts-disabled",
487
+ preview: previewText?.slice(0, 200),
488
+ durationMs: Date.now() - startedAt,
489
+ channel: delivery.channel,
490
+ hasMedia: mediaUrls.length > 0,
491
+ accountId: delivery.accountId,
492
+ indicatorType: visibility.useIndicator ? resolveIndicatorType("sent") : void 0
493
+ });
494
+ return {
495
+ status: "ran",
496
+ durationMs: Date.now() - startedAt
497
+ };
498
+ }
499
+ const deliveryAccountId = delivery.accountId;
500
+ const heartbeatPlugin = getChannelPlugin(delivery.channel);
501
+ if (heartbeatPlugin?.heartbeat?.checkReady) {
502
+ const readiness = await heartbeatPlugin.heartbeat.checkReady({
503
+ cfg,
504
+ accountId: deliveryAccountId,
505
+ deps: opts.deps
506
+ });
507
+ if (!readiness.ok) {
508
+ emitHeartbeatEvent({
509
+ status: "skipped",
510
+ reason: readiness.reason,
511
+ preview: previewText?.slice(0, 200),
512
+ durationMs: Date.now() - startedAt,
513
+ hasMedia: mediaUrls.length > 0,
514
+ channel: delivery.channel,
515
+ accountId: delivery.accountId
516
+ });
517
+ log.info("heartbeat: channel not ready", {
518
+ channel: delivery.channel,
519
+ reason: readiness.reason
520
+ });
521
+ return {
522
+ status: "skipped",
523
+ reason: readiness.reason
524
+ };
525
+ }
526
+ }
527
+ await deliverOutboundPayloads({
528
+ cfg,
529
+ channel: delivery.channel,
530
+ to: delivery.to,
531
+ accountId: deliveryAccountId,
532
+ payloads: [...reasoningPayloads, ...shouldSkipMain ? [] : [{
533
+ text: normalized.text,
534
+ mediaUrls
535
+ }]],
536
+ deps: opts.deps
537
+ });
538
+ if (!shouldSkipMain && normalized.text.trim()) {
539
+ const store = loadSessionStore(storePath);
540
+ const current = store[sessionKey];
541
+ if (current) {
542
+ store[sessionKey] = {
543
+ ...current,
544
+ lastHeartbeatText: normalized.text,
545
+ lastHeartbeatSentAt: startedAt
546
+ };
547
+ await saveSessionStore(storePath, store);
548
+ }
549
+ }
550
+ emitHeartbeatEvent({
551
+ status: "sent",
552
+ to: delivery.to,
553
+ preview: previewText?.slice(0, 200),
554
+ durationMs: Date.now() - startedAt,
555
+ hasMedia: mediaUrls.length > 0,
556
+ channel: delivery.channel,
557
+ accountId: delivery.accountId,
558
+ indicatorType: visibility.useIndicator ? resolveIndicatorType("sent") : void 0
559
+ });
560
+ return {
561
+ status: "ran",
562
+ durationMs: Date.now() - startedAt
563
+ };
564
+ } catch (err) {
565
+ const reason = formatErrorMessage(err);
566
+ emitHeartbeatEvent({
567
+ status: "failed",
568
+ reason,
569
+ durationMs: Date.now() - startedAt,
570
+ channel: delivery.channel !== "none" ? delivery.channel : void 0,
571
+ accountId: delivery.accountId,
572
+ indicatorType: visibility.useIndicator ? resolveIndicatorType("failed") : void 0
573
+ });
574
+ log.error(`heartbeat failed: ${reason}`, { error: reason });
575
+ return {
576
+ status: "failed",
577
+ reason
578
+ };
579
+ }
580
+ }
581
+ function startHeartbeatRunner(opts) {
582
+ const runtime = opts.runtime ?? defaultRuntime;
583
+ const runOnce = opts.runOnce ?? runHeartbeatOnce;
584
+ const state = {
585
+ cfg: opts.cfg ?? loadConfig(),
586
+ runtime,
587
+ agents: /* @__PURE__ */ new Map(),
588
+ timer: null,
589
+ stopped: false
590
+ };
591
+ let initialized = false;
592
+ const resolveNextDue = (now, intervalMs, prevState) => {
593
+ if (typeof prevState?.lastRunMs === "number") return prevState.lastRunMs + intervalMs;
594
+ if (prevState && prevState.intervalMs === intervalMs && prevState.nextDueMs > now) return prevState.nextDueMs;
595
+ return now + intervalMs;
596
+ };
597
+ const scheduleNext = () => {
598
+ if (state.stopped) return;
599
+ if (state.timer) {
600
+ clearTimeout(state.timer);
601
+ state.timer = null;
602
+ }
603
+ if (state.agents.size === 0) return;
604
+ const now = Date.now();
605
+ let nextDue = Number.POSITIVE_INFINITY;
606
+ for (const agent of state.agents.values()) if (agent.nextDueMs < nextDue) nextDue = agent.nextDueMs;
607
+ if (!Number.isFinite(nextDue)) return;
608
+ const delay = Math.max(0, nextDue - now);
609
+ state.timer = setTimeout(() => {
610
+ requestHeartbeatNow({
611
+ reason: "interval",
612
+ coalesceMs: 0
613
+ });
614
+ }, delay);
615
+ state.timer.unref?.();
616
+ };
617
+ const updateConfig = (cfg) => {
618
+ if (state.stopped) return;
619
+ const now = Date.now();
620
+ const prevAgents = state.agents;
621
+ const prevEnabled = prevAgents.size > 0;
622
+ const nextAgents = /* @__PURE__ */ new Map();
623
+ const intervals = [];
624
+ for (const agent of resolveHeartbeatAgents(cfg)) {
625
+ const intervalMs = resolveHeartbeatIntervalMs(cfg, void 0, agent.heartbeat);
626
+ if (!intervalMs) continue;
627
+ intervals.push(intervalMs);
628
+ const prevState = prevAgents.get(agent.agentId);
629
+ const nextDueMs = resolveNextDue(now, intervalMs, prevState);
630
+ nextAgents.set(agent.agentId, {
631
+ agentId: agent.agentId,
632
+ heartbeat: agent.heartbeat,
633
+ intervalMs,
634
+ lastRunMs: prevState?.lastRunMs,
635
+ nextDueMs
636
+ });
637
+ }
638
+ state.cfg = cfg;
639
+ state.agents = nextAgents;
640
+ const nextEnabled = nextAgents.size > 0;
641
+ if (!initialized) {
642
+ if (!nextEnabled) log.info("heartbeat: disabled", { enabled: false });
643
+ else log.info("heartbeat: started", { intervalMs: Math.min(...intervals) });
644
+ initialized = true;
645
+ } else if (prevEnabled !== nextEnabled) if (!nextEnabled) log.info("heartbeat: disabled", { enabled: false });
646
+ else log.info("heartbeat: started", { intervalMs: Math.min(...intervals) });
647
+ scheduleNext();
648
+ };
649
+ const run = async (params) => {
650
+ if (!heartbeatsEnabled) return {
651
+ status: "skipped",
652
+ reason: "disabled"
653
+ };
654
+ if (state.agents.size === 0) return {
655
+ status: "skipped",
656
+ reason: "disabled"
657
+ };
658
+ const reason = params?.reason;
659
+ const isInterval = reason === "interval";
660
+ const startedAt = Date.now();
661
+ const now = startedAt;
662
+ let ran = false;
663
+ for (const agent of state.agents.values()) {
664
+ if (isInterval && now < agent.nextDueMs) continue;
665
+ const res = await runOnce({
666
+ cfg: state.cfg,
667
+ agentId: agent.agentId,
668
+ heartbeat: agent.heartbeat,
669
+ reason,
670
+ deps: { runtime: state.runtime }
671
+ });
672
+ if (res.status === "skipped" && res.reason === "requests-in-flight") return res;
673
+ if (res.status !== "skipped" || res.reason !== "disabled") {
674
+ agent.lastRunMs = now;
675
+ agent.nextDueMs = now + agent.intervalMs;
676
+ }
677
+ if (res.status === "ran") ran = true;
678
+ }
679
+ scheduleNext();
680
+ if (ran) return {
681
+ status: "ran",
682
+ durationMs: Date.now() - startedAt
683
+ };
684
+ return {
685
+ status: "skipped",
686
+ reason: isInterval ? "not-due" : "disabled"
687
+ };
688
+ };
689
+ setHeartbeatWakeHandler(async (params) => run({ reason: params.reason }));
690
+ updateConfig(state.cfg);
691
+ const cleanup = () => {
692
+ state.stopped = true;
693
+ setHeartbeatWakeHandler(null);
694
+ if (state.timer) clearTimeout(state.timer);
695
+ state.timer = null;
696
+ };
697
+ opts.abortSignal?.addEventListener("abort", cleanup, { once: true });
698
+ return {
699
+ stop: cleanup,
700
+ updateConfig
701
+ };
702
+ }
703
+
704
+ //#endregion
705
+ //#region src/commands/health.ts
706
+ const DEFAULT_TIMEOUT_MS = 1e4;
707
+ const debugHealth = (...args) => {
708
+ if (isTruthyEnvValue(process.env.CRYPTOCLAW_DEBUG_HEALTH)) console.warn("[health:debug]", ...args);
709
+ };
710
+ const formatDurationParts = (ms) => {
711
+ if (!Number.isFinite(ms)) return "unknown";
712
+ if (ms < 1e3) return `${Math.max(0, Math.round(ms))}ms`;
713
+ const units = [
714
+ {
715
+ label: "w",
716
+ size: 10080 * 60 * 1e3
717
+ },
718
+ {
719
+ label: "d",
720
+ size: 1440 * 60 * 1e3
721
+ },
722
+ {
723
+ label: "h",
724
+ size: 3600 * 1e3
725
+ },
726
+ {
727
+ label: "m",
728
+ size: 60 * 1e3
729
+ },
730
+ {
731
+ label: "s",
732
+ size: 1e3
733
+ }
734
+ ];
735
+ let remaining = Math.max(0, Math.floor(ms));
736
+ const parts = [];
737
+ for (const unit of units) {
738
+ const value = Math.floor(remaining / unit.size);
739
+ if (value > 0) {
740
+ parts.push(`${value}${unit.label}`);
741
+ remaining -= value * unit.size;
742
+ }
743
+ }
744
+ if (parts.length === 0) return "0s";
745
+ return parts.join(" ");
746
+ };
747
+ const resolveHeartbeatSummary = (cfg, agentId) => resolveHeartbeatSummaryForAgent(cfg, agentId);
748
+ const resolveAgentOrder = (cfg) => {
749
+ const defaultAgentId = resolveDefaultAgentId(cfg);
750
+ const entries = Array.isArray(cfg.agents?.list) ? cfg.agents.list : [];
751
+ const seen = /* @__PURE__ */ new Set();
752
+ const ordered = [];
753
+ for (const entry of entries) {
754
+ if (!entry || typeof entry !== "object") continue;
755
+ if (typeof entry.id !== "string" || !entry.id.trim()) continue;
756
+ const id = normalizeAgentId(entry.id);
757
+ if (!id || seen.has(id)) continue;
758
+ seen.add(id);
759
+ ordered.push({
760
+ id,
761
+ name: typeof entry.name === "string" ? entry.name : void 0
762
+ });
763
+ }
764
+ if (!seen.has(defaultAgentId)) ordered.unshift({ id: defaultAgentId });
765
+ if (ordered.length === 0) ordered.push({ id: defaultAgentId });
766
+ return {
767
+ defaultAgentId,
768
+ ordered
769
+ };
770
+ };
771
+ const buildSessionSummary = (storePath) => {
772
+ const store = loadSessionStore(storePath);
773
+ const sessions = Object.entries(store).filter(([key]) => key !== "global" && key !== "unknown").map(([key, entry]) => ({
774
+ key,
775
+ updatedAt: entry?.updatedAt ?? 0
776
+ })).toSorted((a, b) => b.updatedAt - a.updatedAt);
777
+ const recent = sessions.slice(0, 5).map((s) => ({
778
+ key: s.key,
779
+ updatedAt: s.updatedAt || null,
780
+ age: s.updatedAt ? Date.now() - s.updatedAt : null
781
+ }));
782
+ return {
783
+ path: storePath,
784
+ count: sessions.length,
785
+ recent
786
+ };
787
+ };
788
+ const isAccountEnabled = (account) => {
789
+ if (!account || typeof account !== "object") return true;
790
+ return account.enabled !== false;
791
+ };
792
+ const asRecord = (value) => value && typeof value === "object" ? value : null;
793
+ const formatProbeLine = (probe, opts = {}) => {
794
+ const record = asRecord(probe);
795
+ if (!record) return null;
796
+ const ok = typeof record.ok === "boolean" ? record.ok : void 0;
797
+ if (ok === void 0) return null;
798
+ const elapsedMs = typeof record.elapsedMs === "number" ? record.elapsedMs : null;
799
+ const status = typeof record.status === "number" ? record.status : null;
800
+ const error = typeof record.error === "string" ? record.error : null;
801
+ const bot = asRecord(record.bot);
802
+ const botUsername = bot && typeof bot.username === "string" ? bot.username : null;
803
+ const webhook = asRecord(record.webhook);
804
+ const webhookUrl = webhook && typeof webhook.url === "string" ? webhook.url : null;
805
+ const usernames = /* @__PURE__ */ new Set();
806
+ if (botUsername) usernames.add(botUsername);
807
+ for (const extra of opts.botUsernames ?? []) if (extra) usernames.add(extra);
808
+ if (ok) {
809
+ let label = "ok";
810
+ if (usernames.size > 0) label += ` (@${Array.from(usernames).join(", @")})`;
811
+ if (elapsedMs != null) label += ` (${elapsedMs}ms)`;
812
+ if (webhookUrl) label += ` - webhook ${webhookUrl}`;
813
+ return label;
814
+ }
815
+ let label = `failed (${status ?? "unknown"})`;
816
+ if (error) label += ` - ${error}`;
817
+ return label;
818
+ };
819
+ const formatAccountProbeTiming = (summary) => {
820
+ const probe = asRecord(summary.probe);
821
+ if (!probe) return null;
822
+ const elapsedMs = typeof probe.elapsedMs === "number" ? Math.round(probe.elapsedMs) : null;
823
+ const ok = typeof probe.ok === "boolean" ? probe.ok : null;
824
+ if (elapsedMs == null && ok !== true) return null;
825
+ const accountId = summary.accountId || "default";
826
+ const botRecord = asRecord(probe.bot);
827
+ const botUsername = botRecord && typeof botRecord.username === "string" ? botRecord.username : null;
828
+ return `${botUsername ? `@${botUsername}` : accountId}:${accountId}:${elapsedMs != null ? `${elapsedMs}ms` : "ok"}`;
829
+ };
830
+ const isProbeFailure = (summary) => {
831
+ const probe = asRecord(summary.probe);
832
+ if (!probe) return false;
833
+ return (typeof probe.ok === "boolean" ? probe.ok : null) === false;
834
+ };
835
+ function styleHealthChannelLine(line) {
836
+ const colon = line.indexOf(":");
837
+ if (colon === -1) return line;
838
+ const label = line.slice(0, colon + 1);
839
+ const detail = line.slice(colon + 1).trimStart();
840
+ const normalized = detail.toLowerCase();
841
+ const applyPrefix = (prefix, color) => `${label} ${color(detail.slice(0, prefix.length))}${detail.slice(prefix.length)}`;
842
+ if (normalized.startsWith("failed")) return applyPrefix("failed", theme.error);
843
+ if (normalized.startsWith("ok")) return applyPrefix("ok", theme.success);
844
+ if (normalized.startsWith("linked")) return applyPrefix("linked", theme.success);
845
+ if (normalized.startsWith("configured")) return applyPrefix("configured", theme.success);
846
+ if (normalized.startsWith("not linked")) return applyPrefix("not linked", theme.warn);
847
+ if (normalized.startsWith("not configured")) return applyPrefix("not configured", theme.muted);
848
+ if (normalized.startsWith("unknown")) return applyPrefix("unknown", theme.warn);
849
+ return line;
850
+ }
851
+ const formatHealthChannelLines = (summary, opts = {}) => {
852
+ const channels = summary.channels ?? {};
853
+ const channelOrder = summary.channelOrder?.length > 0 ? summary.channelOrder : Object.keys(channels);
854
+ const accountMode = opts.accountMode ?? "default";
855
+ const lines = [];
856
+ for (const channelId of channelOrder) {
857
+ const channelSummary = channels[channelId];
858
+ if (!channelSummary) continue;
859
+ const plugin = getChannelPlugin(channelId);
860
+ const label = summary.channelLabels?.[channelId] ?? plugin?.meta.label ?? channelId;
861
+ const accountSummaries = channelSummary.accounts ?? {};
862
+ const accountIds = opts.accountIdsByChannel?.[channelId];
863
+ const filteredSummaries = accountIds && accountIds.length > 0 ? accountIds.map((accountId) => accountSummaries[accountId]).filter((entry) => Boolean(entry)) : void 0;
864
+ const listSummaries = accountMode === "all" ? Object.values(accountSummaries) : filteredSummaries ?? (channelSummary.accounts ? Object.values(accountSummaries) : []);
865
+ const baseSummary = filteredSummaries && filteredSummaries.length > 0 ? filteredSummaries[0] : channelSummary;
866
+ const botUsernames = listSummaries ? listSummaries.map((account) => {
867
+ const probeRecord = asRecord(account.probe);
868
+ const bot = probeRecord ? asRecord(probeRecord.bot) : null;
869
+ return bot && typeof bot.username === "string" ? bot.username : null;
870
+ }).filter((value) => Boolean(value)) : [];
871
+ const linked = typeof baseSummary.linked === "boolean" ? baseSummary.linked : null;
872
+ if (linked !== null) {
873
+ if (linked) {
874
+ const authAgeMs = typeof baseSummary.authAgeMs === "number" ? baseSummary.authAgeMs : null;
875
+ const authLabel = authAgeMs != null ? ` (auth age ${Math.round(authAgeMs / 6e4)}m)` : "";
876
+ lines.push(`${label}: linked${authLabel}`);
877
+ } else lines.push(`${label}: not linked`);
878
+ continue;
879
+ }
880
+ const configured = typeof baseSummary.configured === "boolean" ? baseSummary.configured : null;
881
+ if (configured === false) {
882
+ lines.push(`${label}: not configured`);
883
+ continue;
884
+ }
885
+ const accountTimings = accountMode === "all" ? listSummaries.map((account) => formatAccountProbeTiming(account)).filter((value) => Boolean(value)) : [];
886
+ const failedSummary = listSummaries.find((summary) => isProbeFailure(summary));
887
+ if (failedSummary) {
888
+ const failureLine = formatProbeLine(failedSummary.probe, { botUsernames });
889
+ if (failureLine) {
890
+ lines.push(`${label}: ${failureLine}`);
891
+ continue;
892
+ }
893
+ }
894
+ if (accountTimings.length > 0) {
895
+ lines.push(`${label}: ok (${accountTimings.join(", ")})`);
896
+ continue;
897
+ }
898
+ const probeLine = formatProbeLine(baseSummary.probe, { botUsernames });
899
+ if (probeLine) {
900
+ lines.push(`${label}: ${probeLine}`);
901
+ continue;
902
+ }
903
+ if (configured === true) {
904
+ lines.push(`${label}: configured`);
905
+ continue;
906
+ }
907
+ lines.push(`${label}: unknown`);
908
+ }
909
+ return lines;
910
+ };
911
+ async function getHealthSnapshot(params) {
912
+ const timeoutMs = params?.timeoutMs;
913
+ const cfg = loadConfig();
914
+ const { defaultAgentId, ordered } = resolveAgentOrder(cfg);
915
+ const channelBindings = buildChannelAccountBindings(cfg);
916
+ const sessionCache = /* @__PURE__ */ new Map();
917
+ const agents = ordered.map((entry) => {
918
+ const storePath = resolveStorePath(cfg.session?.store, { agentId: entry.id });
919
+ const sessions = sessionCache.get(storePath) ?? buildSessionSummary(storePath);
920
+ sessionCache.set(storePath, sessions);
921
+ return {
922
+ agentId: entry.id,
923
+ name: entry.name,
924
+ isDefault: entry.id === defaultAgentId,
925
+ heartbeat: resolveHeartbeatSummary(cfg, entry.id),
926
+ sessions
927
+ };
928
+ });
929
+ const defaultAgent = agents.find((agent) => agent.isDefault) ?? agents[0];
930
+ const heartbeatSeconds = defaultAgent?.heartbeat.everyMs ? Math.round(defaultAgent.heartbeat.everyMs / 1e3) : 0;
931
+ const sessions = defaultAgent?.sessions ?? buildSessionSummary(resolveStorePath(cfg.session?.store, { agentId: defaultAgentId }));
932
+ const start = Date.now();
933
+ const cappedTimeout = Math.max(1e3, timeoutMs ?? DEFAULT_TIMEOUT_MS);
934
+ const doProbe = params?.probe !== false;
935
+ const channels = {};
936
+ const channelOrder = listChannelPlugins().map((plugin) => plugin.id);
937
+ const channelLabels = {};
938
+ for (const plugin of listChannelPlugins()) {
939
+ channelLabels[plugin.id] = plugin.meta.label ?? plugin.id;
940
+ const accountIds = plugin.config.listAccountIds(cfg);
941
+ const defaultAccountId = resolveChannelDefaultAccountId({
942
+ plugin,
943
+ cfg,
944
+ accountIds
945
+ });
946
+ const boundAccounts = channelBindings.get(plugin.id)?.get(defaultAgentId) ?? [];
947
+ const preferredAccountId = resolvePreferredAccountId({
948
+ accountIds,
949
+ defaultAccountId,
950
+ boundAccounts
951
+ });
952
+ const boundAccountIdsAll = Array.from(new Set(Array.from(channelBindings.get(plugin.id)?.values() ?? []).flatMap((ids) => ids)));
953
+ const accountIdsToProbe = Array.from(new Set([
954
+ preferredAccountId,
955
+ defaultAccountId,
956
+ ...accountIds,
957
+ ...boundAccountIdsAll
958
+ ].filter((value) => value && value.trim())));
959
+ debugHealth("channel", {
960
+ id: plugin.id,
961
+ accountIds,
962
+ defaultAccountId,
963
+ boundAccounts,
964
+ preferredAccountId,
965
+ accountIdsToProbe
966
+ });
967
+ const accountSummaries = {};
968
+ for (const accountId of accountIdsToProbe) {
969
+ const account = plugin.config.resolveAccount(cfg, accountId);
970
+ const enabled = plugin.config.isEnabled ? plugin.config.isEnabled(account, cfg) : isAccountEnabled(account);
971
+ const configured = plugin.config.isConfigured ? await plugin.config.isConfigured(account, cfg) : true;
972
+ let probe;
973
+ let lastProbeAt = null;
974
+ if (enabled && configured && doProbe && plugin.status?.probeAccount) try {
975
+ probe = await plugin.status.probeAccount({
976
+ account,
977
+ timeoutMs: cappedTimeout,
978
+ cfg
979
+ });
980
+ lastProbeAt = Date.now();
981
+ } catch (err) {
982
+ probe = {
983
+ ok: false,
984
+ error: formatErrorMessage(err)
985
+ };
986
+ lastProbeAt = Date.now();
987
+ }
988
+ const probeRecord = probe && typeof probe === "object" ? probe : null;
989
+ const bot = probeRecord && typeof probeRecord.bot === "object" ? probeRecord.bot : null;
990
+ if (bot?.username) debugHealth("probe.bot", {
991
+ channel: plugin.id,
992
+ accountId,
993
+ username: bot.username
994
+ });
995
+ const snapshot = {
996
+ accountId,
997
+ enabled,
998
+ configured
999
+ };
1000
+ if (probe !== void 0) snapshot.probe = probe;
1001
+ if (lastProbeAt) snapshot.lastProbeAt = lastProbeAt;
1002
+ const summary = plugin.status?.buildChannelSummary ? await plugin.status.buildChannelSummary({
1003
+ account,
1004
+ cfg,
1005
+ defaultAccountId: accountId,
1006
+ snapshot
1007
+ }) : void 0;
1008
+ const record = summary && typeof summary === "object" ? summary : {
1009
+ accountId,
1010
+ configured,
1011
+ probe,
1012
+ lastProbeAt
1013
+ };
1014
+ if (record.configured === void 0) record.configured = configured;
1015
+ if (record.lastProbeAt === void 0 && lastProbeAt) record.lastProbeAt = lastProbeAt;
1016
+ record.accountId = accountId;
1017
+ accountSummaries[accountId] = record;
1018
+ }
1019
+ const fallbackSummary = accountSummaries[preferredAccountId] ?? accountSummaries[defaultAccountId] ?? accountSummaries[accountIdsToProbe[0] ?? preferredAccountId] ?? accountSummaries[Object.keys(accountSummaries)[0]];
1020
+ if (fallbackSummary) channels[plugin.id] = {
1021
+ ...fallbackSummary,
1022
+ accounts: accountSummaries
1023
+ };
1024
+ }
1025
+ return {
1026
+ ok: true,
1027
+ ts: Date.now(),
1028
+ durationMs: Date.now() - start,
1029
+ channels,
1030
+ channelOrder,
1031
+ channelLabels,
1032
+ heartbeatSeconds,
1033
+ defaultAgentId,
1034
+ agents,
1035
+ sessions: {
1036
+ path: sessions.path,
1037
+ count: sessions.count,
1038
+ recent: sessions.recent
1039
+ }
1040
+ };
1041
+ }
1042
+ async function healthCommand(opts, runtime) {
1043
+ const cfg = opts.config ?? loadConfig();
1044
+ const summary = await withProgress({
1045
+ label: "Checking gateway health…",
1046
+ indeterminate: true,
1047
+ enabled: opts.json !== true
1048
+ }, async () => await callGateway({
1049
+ method: "health",
1050
+ params: opts.verbose ? { probe: true } : void 0,
1051
+ timeoutMs: opts.timeoutMs,
1052
+ config: cfg
1053
+ }));
1054
+ if (opts.json) runtime.log(JSON.stringify(summary, null, 2));
1055
+ else {
1056
+ const debugEnabled = isTruthyEnvValue(process.env.CRYPTOCLAW_DEBUG_HEALTH);
1057
+ if (opts.verbose) {
1058
+ const details = buildGatewayConnectionDetails({ config: cfg });
1059
+ runtime.log(info("Gateway connection:"));
1060
+ for (const line of details.message.split("\n")) runtime.log(` ${line}`);
1061
+ }
1062
+ const localAgents = resolveAgentOrder(cfg);
1063
+ const defaultAgentId = summary.defaultAgentId ?? localAgents.defaultAgentId;
1064
+ const agents = Array.isArray(summary.agents) ? summary.agents : [];
1065
+ const fallbackAgents = localAgents.ordered.map((entry) => {
1066
+ const storePath = resolveStorePath(cfg.session?.store, { agentId: entry.id });
1067
+ return {
1068
+ agentId: entry.id,
1069
+ name: entry.name,
1070
+ isDefault: entry.id === localAgents.defaultAgentId,
1071
+ heartbeat: resolveHeartbeatSummary(cfg, entry.id),
1072
+ sessions: buildSessionSummary(storePath)
1073
+ };
1074
+ });
1075
+ const resolvedAgents = agents.length > 0 ? agents : fallbackAgents;
1076
+ const displayAgents = opts.verbose ? resolvedAgents : resolvedAgents.filter((agent) => agent.agentId === defaultAgentId);
1077
+ const channelBindings = buildChannelAccountBindings(cfg);
1078
+ if (debugEnabled) {
1079
+ runtime.log(info("[debug] local channel accounts"));
1080
+ for (const plugin of listChannelPlugins()) {
1081
+ const accountIds = plugin.config.listAccountIds(cfg);
1082
+ const defaultAccountId = resolveChannelDefaultAccountId({
1083
+ plugin,
1084
+ cfg,
1085
+ accountIds
1086
+ });
1087
+ runtime.log(` ${plugin.id}: accounts=${accountIds.join(", ") || "(none)"} default=${defaultAccountId}`);
1088
+ for (const accountId of accountIds) {
1089
+ const account = plugin.config.resolveAccount(cfg, accountId);
1090
+ const record = asRecord(account);
1091
+ const tokenSource = record && typeof record.tokenSource === "string" ? record.tokenSource : void 0;
1092
+ const configured = plugin.config.isConfigured ? await plugin.config.isConfigured(account, cfg) : true;
1093
+ runtime.log(` - ${accountId}: configured=${configured}${tokenSource ? ` tokenSource=${tokenSource}` : ""}`);
1094
+ }
1095
+ }
1096
+ runtime.log(info("[debug] bindings map"));
1097
+ for (const [channelId, byAgent] of channelBindings.entries()) {
1098
+ const entries = Array.from(byAgent.entries()).map(([agentId, ids]) => `${agentId}=[${ids.join(", ")}]`);
1099
+ runtime.log(` ${channelId}: ${entries.join(" ")}`);
1100
+ }
1101
+ runtime.log(info("[debug] gateway channel probes"));
1102
+ for (const [channelId, channelSummary] of Object.entries(summary.channels ?? {})) {
1103
+ const accounts = channelSummary.accounts ?? {};
1104
+ const probes = Object.entries(accounts).map(([accountId, accountSummary]) => {
1105
+ const probe = asRecord(accountSummary.probe);
1106
+ const bot = probe ? asRecord(probe.bot) : null;
1107
+ return `${accountId}=${(bot && typeof bot.username === "string" ? bot.username : null) ?? "(no bot)"}`;
1108
+ });
1109
+ runtime.log(` ${channelId}: ${probes.join(", ") || "(none)"}`);
1110
+ }
1111
+ }
1112
+ const channelAccountFallbacks = Object.fromEntries(listChannelPlugins().map((plugin) => {
1113
+ const accountIds = plugin.config.listAccountIds(cfg);
1114
+ const preferred = resolvePreferredAccountId({
1115
+ accountIds,
1116
+ defaultAccountId: resolveChannelDefaultAccountId({
1117
+ plugin,
1118
+ cfg,
1119
+ accountIds
1120
+ }),
1121
+ boundAccounts: channelBindings.get(plugin.id)?.get(defaultAgentId) ?? []
1122
+ });
1123
+ return [plugin.id, [preferred]];
1124
+ }));
1125
+ const accountIdsByChannel = (() => {
1126
+ const entries = displayAgents.length > 0 ? displayAgents : resolvedAgents;
1127
+ const byChannel = {};
1128
+ for (const [channelId, byAgent] of channelBindings.entries()) {
1129
+ const accountIds = [];
1130
+ for (const agent of entries) {
1131
+ const ids = byAgent.get(agent.agentId) ?? [];
1132
+ for (const id of ids) if (!accountIds.includes(id)) accountIds.push(id);
1133
+ }
1134
+ if (accountIds.length > 0) byChannel[channelId] = accountIds;
1135
+ }
1136
+ for (const [channelId, fallbackIds] of Object.entries(channelAccountFallbacks)) if (!byChannel[channelId] || byChannel[channelId].length === 0) byChannel[channelId] = fallbackIds;
1137
+ return byChannel;
1138
+ })();
1139
+ const channelLines = Object.keys(accountIdsByChannel).length > 0 ? formatHealthChannelLines(summary, {
1140
+ accountMode: opts.verbose ? "all" : "default",
1141
+ accountIdsByChannel
1142
+ }) : formatHealthChannelLines(summary, { accountMode: opts.verbose ? "all" : "default" });
1143
+ for (const line of channelLines) runtime.log(styleHealthChannelLine(line));
1144
+ for (const plugin of listChannelPlugins()) {
1145
+ const channelSummary = summary.channels?.[plugin.id];
1146
+ if (!channelSummary || channelSummary.linked !== true) continue;
1147
+ if (!plugin.status?.logSelfId) continue;
1148
+ const boundAccounts = channelBindings.get(plugin.id)?.get(defaultAgentId) ?? [];
1149
+ const accountIds = plugin.config.listAccountIds(cfg);
1150
+ const accountId = resolvePreferredAccountId({
1151
+ accountIds,
1152
+ defaultAccountId: resolveChannelDefaultAccountId({
1153
+ plugin,
1154
+ cfg,
1155
+ accountIds
1156
+ }),
1157
+ boundAccounts
1158
+ });
1159
+ const account = plugin.config.resolveAccount(cfg, accountId);
1160
+ plugin.status.logSelfId({
1161
+ account,
1162
+ cfg,
1163
+ runtime,
1164
+ includeChannelPrefix: true
1165
+ });
1166
+ }
1167
+ if (resolvedAgents.length > 0) {
1168
+ const agentLabels = resolvedAgents.map((agent) => agent.isDefault ? `${agent.agentId} (default)` : agent.agentId);
1169
+ runtime.log(info(`Agents: ${agentLabels.join(", ")}`));
1170
+ }
1171
+ const heartbeatParts = displayAgents.map((agent) => {
1172
+ const everyMs = agent.heartbeat?.everyMs;
1173
+ return `${everyMs ? formatDurationParts(everyMs) : "disabled"} (${agent.agentId})`;
1174
+ }).filter(Boolean);
1175
+ if (heartbeatParts.length > 0) runtime.log(info(`Heartbeat interval: ${heartbeatParts.join(", ")}`));
1176
+ if (displayAgents.length === 0) {
1177
+ runtime.log(info(`Session store: ${summary.sessions.path} (${summary.sessions.count} entries)`));
1178
+ if (summary.sessions.recent.length > 0) for (const r of summary.sessions.recent) runtime.log(`- ${r.key} (${r.updatedAt ? `${Math.round((Date.now() - r.updatedAt) / 6e4)}m ago` : "no activity"})`);
1179
+ } else for (const agent of displayAgents) {
1180
+ runtime.log(info(`Session store (${agent.agentId}): ${agent.sessions.path} (${agent.sessions.count} entries)`));
1181
+ if (agent.sessions.recent.length > 0) for (const r of agent.sessions.recent) runtime.log(`- ${r.key} (${r.updatedAt ? `${Math.round((Date.now() - r.updatedAt) / 6e4)}m ago` : "no activity"})`);
1182
+ }
1183
+ }
1184
+ }
1185
+
1186
+ //#endregion
1187
+ //#region src/commands/health-format.ts
1188
+ const formatKv = (line, rich) => {
1189
+ const idx = line.indexOf(": ");
1190
+ if (idx <= 0) return colorize(rich, theme.muted, line);
1191
+ const key = line.slice(0, idx);
1192
+ const value = line.slice(idx + 2);
1193
+ const valueColor = key === "Gateway target" || key === "Config" ? theme.command : key === "Source" ? theme.muted : theme.info;
1194
+ return `${colorize(rich, theme.muted, `${key}:`)} ${colorize(rich, valueColor, value)}`;
1195
+ };
1196
+ function formatHealthCheckFailure(err, opts = {}) {
1197
+ const rich = opts.rich ?? isRich();
1198
+ const raw = String(err);
1199
+ const message = err instanceof Error ? err.message : raw;
1200
+ if (!rich) return `Health check failed: ${raw}`;
1201
+ const lines = message.split("\n").map((l) => l.trimEnd()).filter(Boolean);
1202
+ const detailsIdx = lines.findIndex((l) => l.startsWith("Gateway target: "));
1203
+ const summaryLines = (detailsIdx >= 0 ? lines.slice(0, detailsIdx) : lines).map((l) => l.trim()).filter(Boolean);
1204
+ const detailLines = detailsIdx >= 0 ? lines.slice(detailsIdx) : [];
1205
+ const summary = summaryLines.length > 0 ? summaryLines.join(" ") : message;
1206
+ const out = [`${colorize(rich, theme.error.bold, "Health check failed")}: ${summary}`];
1207
+ for (const line of detailLines) out.push(` ${formatKv(line, rich)}`);
1208
+ return out.join("\n");
1209
+ }
1210
+
1211
+ //#endregion
1212
+ export { resolveHeartbeatSummaryForAgent as a, startHeartbeatRunner as c, healthCommand as i, formatHealthChannelLines as n, runHeartbeatOnce as o, getHealthSnapshot as r, setHeartbeatsEnabled as s, formatHealthCheckFailure as t };