@captain-app/openclaw 2026.2.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1686) hide show
  1. package/CHANGELOG.md +1528 -0
  2. package/LICENSE +21 -0
  3. package/README-header.png +0 -0
  4. package/README.md +539 -0
  5. package/assets/avatar-placeholder.svg +19 -0
  6. package/assets/chrome-extension/README.md +22 -0
  7. package/assets/chrome-extension/background.js +438 -0
  8. package/assets/chrome-extension/icons/icon128.png +0 -0
  9. package/assets/chrome-extension/icons/icon16.png +0 -0
  10. package/assets/chrome-extension/icons/icon32.png +0 -0
  11. package/assets/chrome-extension/icons/icon48.png +0 -0
  12. package/assets/chrome-extension/manifest.json +25 -0
  13. package/assets/chrome-extension/options.html +196 -0
  14. package/assets/chrome-extension/options.js +59 -0
  15. package/assets/dmg-background-small.png +0 -0
  16. package/assets/dmg-background.png +0 -0
  17. package/dist/accounts-ClnuDahN.js +250 -0
  18. package/dist/accounts-DzBgAM3C.js +251 -0
  19. package/dist/acp-cli-BEDDkzXH.js +926 -0
  20. package/dist/acp-cli-CwV4mdnW.js +923 -0
  21. package/dist/agent-CArjbSeE.js +695 -0
  22. package/dist/agent-CB7x5HLT.js +695 -0
  23. package/dist/agent-scope-BbT4OG2N.js +545 -0
  24. package/dist/agent-scope-C_O6Vpl0.js +545 -0
  25. package/dist/agent-scope-Csu2B6AM.js +606 -0
  26. package/dist/archive-CWrnG1CH.js +85 -0
  27. package/dist/archive-ccN9aDgq.js +85 -0
  28. package/dist/audit-DXPkQ275.js +1686 -0
  29. package/dist/audit-eH7nwgsM.js +1686 -0
  30. package/dist/auth-health-Bj7Gjbv0.js +149 -0
  31. package/dist/auth-health-CjjJhHey.js +149 -0
  32. package/dist/auth-nnRYiqpH.js +192 -0
  33. package/dist/auth-profiles-DVLfuixr.js +2954 -0
  34. package/dist/auth-y1BLPUhX.js +192 -0
  35. package/dist/boolean-Wzu0-e0P.js +30 -0
  36. package/dist/brew-Cqi8b49_.js +46 -0
  37. package/dist/brew-DyBGNK8A.js +46 -0
  38. package/dist/build-info.json +5 -0
  39. package/dist/call-B7EveN4V.js +252 -0
  40. package/dist/call-vuUQIjOj.js +252 -0
  41. package/dist/canvas-host/a2ui/.bundle.hash +1 -0
  42. package/dist/canvas-host/a2ui/a2ui.bundle.js +17780 -0
  43. package/dist/canvas-host/a2ui/index.html +307 -0
  44. package/dist/channel-options-CJfmOkol.js +32 -0
  45. package/dist/channel-options-lFguMTz1.js +62 -0
  46. package/dist/channel-selection-BmND9mWj.js +51 -0
  47. package/dist/channel-selection-cGhL9G0c.js +51 -0
  48. package/dist/channel-summary-B4G513Eb.js +1154 -0
  49. package/dist/channel-summary-MCwBCa5y.js +1154 -0
  50. package/dist/channels-cli-C2Of1mZG.js +1411 -0
  51. package/dist/channels-cli-DFynrP1H.js +1413 -0
  52. package/dist/channels-status-issues-YohTjZ-I.js +18 -0
  53. package/dist/channels-status-issues-ZcR1U-m5.js +18 -0
  54. package/dist/chrome-B3IuUad-.js +1953 -0
  55. package/dist/chrome-BZ9K48w9.js +1973 -0
  56. package/dist/clack-prompter-B9yLhyOm.js +92 -0
  57. package/dist/clack-prompter-BybM9xdL.js +92 -0
  58. package/dist/cli/daemon-cli.js +2 -0
  59. package/dist/cli-BJZdJwug.js +89 -0
  60. package/dist/cli-BQSoKu3d.js +86 -0
  61. package/dist/cli-utils-CO4jEMn0.js +43 -0
  62. package/dist/cli-utils-gtE-0a0D.js +43 -0
  63. package/dist/client-DPqNOpK3.js +1609 -0
  64. package/dist/client-DySXIFCA.js +1609 -0
  65. package/dist/command-format-CFzL448l.js +52 -0
  66. package/dist/command-format-DELazozB.js +52 -0
  67. package/dist/command-format-ayFsmwwz.js +38 -0
  68. package/dist/command-options-CsjxK4cZ.js +33 -0
  69. package/dist/commands-BRe9VTyU.js +229 -0
  70. package/dist/completion-cli-DlkjK0iC.js +390 -0
  71. package/dist/completion-cli-E6Pt41AL.js +387 -0
  72. package/dist/config-BtSTwPcH.js +4882 -0
  73. package/dist/config-DfMIMT-f.js +4881 -0
  74. package/dist/config-_d7_WcRv.js +5623 -0
  75. package/dist/config-guard-wSnm-U8a.js +5628 -0
  76. package/dist/configure-CPHAFKlg.js +895 -0
  77. package/dist/configure-DK1XgXYx.js +894 -0
  78. package/dist/constants-CNTiY-ZN.js +65 -0
  79. package/dist/constants-hpmbslG7.js +65 -0
  80. package/dist/control-service-CqX5g_ko.js +61 -0
  81. package/dist/control-service-o6xe3hEb.js +61 -0
  82. package/dist/control-ui/apple-touch-icon.png +0 -0
  83. package/dist/control-ui/assets/index-RwcW4Xl0.css +1 -0
  84. package/dist/control-ui/assets/index-ryaCcbyp.js +4584 -0
  85. package/dist/control-ui/assets/index-ryaCcbyp.js.map +1 -0
  86. package/dist/control-ui/favicon-32.png +0 -0
  87. package/dist/control-ui/favicon.ico +0 -0
  88. package/dist/control-ui/favicon.svg +22 -0
  89. package/dist/control-ui/index.html +17 -0
  90. package/dist/cron-cli-BoSaDgvH.js +453 -0
  91. package/dist/cron-cli-qVandvsD.js +456 -0
  92. package/dist/daemon-cli-C4gGWa15.js +760 -0
  93. package/dist/daemon-cli-DV_X0Krf.js +761 -0
  94. package/dist/daemon-runtime-D5hbSrdO.js +460 -0
  95. package/dist/daemon-runtime-DXUfrXBC.js +460 -0
  96. package/dist/deliver-BxK5nI2P.js +2587 -0
  97. package/dist/deliver-Dwzg9LUd.js +2557 -0
  98. package/dist/deliver-qpYZp20m.js +2587 -0
  99. package/dist/deps-CUXtMV9d.js +27 -0
  100. package/dist/deps-WBvZpFV_.js +27 -0
  101. package/dist/devices-cli-B2s18Qrh.js +207 -0
  102. package/dist/devices-cli-D1UEtMUJ.js +204 -0
  103. package/dist/directory-cli-BXQbrkfM.js +247 -0
  104. package/dist/directory-cli-CqA7tRbq.js +244 -0
  105. package/dist/dispatcher-Dyv7T-1r.js +160 -0
  106. package/dist/dns-cli-CWxKD22D.js +198 -0
  107. package/dist/dns-cli-CzKr_Fxj.js +201 -0
  108. package/dist/docs-cli-BNyxUbWr.js +159 -0
  109. package/dist/docs-cli-DYpTbo3i.js +161 -0
  110. package/dist/doctor-C8fDYZLq.js +2583 -0
  111. package/dist/doctor-hYcqp7c0.js +2585 -0
  112. package/dist/entry.js +1326 -0
  113. package/dist/env-l7QVNj6j.js +32 -0
  114. package/dist/errors-CMCg46fK.js +1952 -0
  115. package/dist/exec-B8JKbXKW.js +246 -0
  116. package/dist/exec-BMnoMcZW.js +1099 -0
  117. package/dist/exec-HEWTMJ7j.js +246 -0
  118. package/dist/exec-approvals-DtrnHx6M.js +1026 -0
  119. package/dist/exec-approvals-Y42bE8ud.js +1026 -0
  120. package/dist/exec-approvals-cli-CIedYxP3.js +385 -0
  121. package/dist/exec-approvals-cli-xpbxnj4O.js +388 -0
  122. package/dist/extensionAPI.js +66572 -0
  123. package/dist/format-Dzy9uRLE.js +34 -0
  124. package/dist/format-sj0fELBK.js +34 -0
  125. package/dist/gateway-cli-5A-KNLEC.js +16635 -0
  126. package/dist/gateway-cli-B8kS4chb.js +16637 -0
  127. package/dist/gateway-rpc-15n38Ize.js +28 -0
  128. package/dist/gateway-rpc-TMVRgGfj.js +28 -0
  129. package/dist/github-copilot-auth-DVZj4Zgh.js +1104 -0
  130. package/dist/github-copilot-auth-DeGYyLY9.js +1104 -0
  131. package/dist/github-copilot-token-B3SA95yo.js +103 -0
  132. package/dist/github-copilot-token-C8XFYz0i.js +103 -0
  133. package/dist/github-copilot-token-CnxakiSC.js +103 -0
  134. package/dist/gmail-setup-utils-CWPC386a.js +428 -0
  135. package/dist/gmail-setup-utils-eJVB5Ewp.js +428 -0
  136. package/dist/health-format-B0tMTk3C.js +1189 -0
  137. package/dist/health-format-DaURVaUn.js +1188 -0
  138. package/dist/help-format-CEsRHU2f.js +17 -0
  139. package/dist/help-format-GuCWws6r.js +17 -0
  140. package/dist/helpers-BEJ-phFf.js +25 -0
  141. package/dist/helpers-BtbBZVKZ.js +10 -0
  142. package/dist/helpers-C12w9zxf.js +10 -0
  143. package/dist/helpers-CzjGJZmJ.js +25 -0
  144. package/dist/hooks/bundled/boot-md/HOOK.md +19 -0
  145. package/dist/hooks/bundled/command-logger/HOOK.md +122 -0
  146. package/dist/hooks/bundled/session-memory/HOOK.md +109 -0
  147. package/dist/hooks/bundled/soul-evil/HOOK.md +71 -0
  148. package/dist/hooks-cli-BZCMAnW2.js +1058 -0
  149. package/dist/hooks-cli-D0CEFg3P.js +1061 -0
  150. package/dist/hooks-status-Bn7_O8PM.js +443 -0
  151. package/dist/hooks-status-BrWVfIn0.js +443 -0
  152. package/dist/image-BS022pvv.js +1421 -0
  153. package/dist/image-BzJtY34J.js +629 -0
  154. package/dist/image-CBqmIbQQ.js +629 -0
  155. package/dist/index.js +5809 -0
  156. package/dist/installs-BP4K5L33.js +388 -0
  157. package/dist/installs-DOpTt7VZ.js +388 -0
  158. package/dist/is-main-B4o72sqg.js +25 -0
  159. package/dist/is-main-PYGa3tDA.js +25 -0
  160. package/dist/links-B4nk2iDf.js +15 -0
  161. package/dist/links-DwjRqxgR.js +15 -0
  162. package/dist/loader-Cn4EV_pf.js +63690 -0
  163. package/dist/logging-CS3tbYDj.js +15 -0
  164. package/dist/logging-CY-Q5cwf.js +1 -0
  165. package/dist/logging-DhiLkhLw.js +15 -0
  166. package/dist/logging-pqyrk15z.js +1 -0
  167. package/dist/login-qr-CD164Aw1.js +478 -0
  168. package/dist/login-qr-D7Zdgji2.js +478 -0
  169. package/dist/login-qr-YgILJ4VC.js +475 -0
  170. package/dist/logs-cli-BdS0Uv0I.js +227 -0
  171. package/dist/logs-cli-CqSN1GzB.js +230 -0
  172. package/dist/manager-CfGY5zND.js +2870 -0
  173. package/dist/manager-CjuBqFRL.js +2870 -0
  174. package/dist/manager-CoBEAQKm.js +2872 -0
  175. package/dist/manifest-registry-Bwjq9Iev.js +668 -0
  176. package/dist/manifest-registry-D2Yntqcb.js +668 -0
  177. package/dist/message-channel-Cjsiqxok.js +105 -0
  178. package/dist/message-channel-D6v_oPAg.js +105 -0
  179. package/dist/model-selection-Cv5Ox_tY.js +2956 -0
  180. package/dist/model-selection-Dr-5U5-l.js +2708 -0
  181. package/dist/models-cli-B39ckynD.js +2541 -0
  182. package/dist/models-cli-DoiYsBYw.js +2544 -0
  183. package/dist/net-CFCxaipF.js +137 -0
  184. package/dist/net-DKJPqXuW.js +137 -0
  185. package/dist/node-cli-C_FYF-RA.js +1456 -0
  186. package/dist/node-cli-DWPoNsQS.js +1459 -0
  187. package/dist/node-service-DcJREOww.js +67 -0
  188. package/dist/node-service-DuZ9Us9h.js +67 -0
  189. package/dist/nodes-cli-Elo6tlen.js +1210 -0
  190. package/dist/nodes-cli-zqryRUWB.js +1207 -0
  191. package/dist/nodes-screen-C4aCrxie.js +157 -0
  192. package/dist/nodes-screen-D4PSynkR.js +157 -0
  193. package/dist/note-CQhSvgQv.js +73 -0
  194. package/dist/note-_C44YfAQ.js +73 -0
  195. package/dist/onboard-channels-CHBDi-ZA.js +670 -0
  196. package/dist/onboard-channels-DOEKyxaL.js +670 -0
  197. package/dist/onboard-skills-BUTXREDZ.js +3327 -0
  198. package/dist/onboard-skills-CSLYZmZA.js +3327 -0
  199. package/dist/onboarding-CgKb8b39.js +3232 -0
  200. package/dist/openclaw-root-9ILYSmJ9.js +84 -0
  201. package/dist/openclaw-root-Cvotktkd.js +84 -0
  202. package/dist/pairing-cli-B4UGR2at.js +114 -0
  203. package/dist/pairing-cli-BWDDl8cf.js +117 -0
  204. package/dist/pairing-labels-ClZ-fTWT.js +9 -0
  205. package/dist/pairing-labels-Ds7BPOkj.js +9 -0
  206. package/dist/pairing-store-DDLNuzmx.js +391 -0
  207. package/dist/pairing-store-DRn08lZD.js +391 -0
  208. package/dist/parse-87ybtYW1.js +23 -0
  209. package/dist/parse-OCFfznr3.js +23 -0
  210. package/dist/parse-log-line-C9aL5PUL.js +44 -0
  211. package/dist/parse-log-line-DxRaGzQb.js +44 -0
  212. package/dist/parse-timeout-CFqNj7No.js +16 -0
  213. package/dist/parse-timeout-DV8NQQWk.js +16 -0
  214. package/dist/path-env-C7kiJUgG.js +77 -0
  215. package/dist/path-env-DEj4CiFN.js +77 -0
  216. package/dist/paths-B-q1nXdY.js +43 -0
  217. package/dist/paths-B1kfl4h5.js +164 -0
  218. package/dist/paths-B4kigINg.js +40 -0
  219. package/dist/paths-CHGbP1-A.js +43 -0
  220. package/dist/paths-scjhy7N2.js +180 -0
  221. package/dist/pi-embedded-helpers-C19wUpMB.js +8451 -0
  222. package/dist/pi-embedded-helpers-CT5VuLCb.js +1293 -0
  223. package/dist/pi-embedded-helpers-Dl8e5Rf8.js +1293 -0
  224. package/dist/pi-model-discovery-B6CsmK6Y.js +20 -0
  225. package/dist/pi-model-discovery-DsRqYJLy.js +20 -0
  226. package/dist/pi-model-discovery-EhM2JAQo.js +20 -0
  227. package/dist/pi-tools.policy-BvkSDFDN.js +229 -0
  228. package/dist/plugin-auto-enable-Bd_StZzz.js +461 -0
  229. package/dist/plugin-auto-enable-DBhXb_0x.js +461 -0
  230. package/dist/plugin-sdk/agent-scope-DdwUKIOe.js +606 -0
  231. package/dist/plugin-sdk/chrome-G8apFa5p.js +1953 -0
  232. package/dist/plugin-sdk/command-format-qUVxzqYm.js +52 -0
  233. package/dist/plugin-sdk/config-Cm1M7tgH.js +5623 -0
  234. package/dist/plugin-sdk/deliver-Cl8uowiO.js +2557 -0
  235. package/dist/plugin-sdk/exec-Cm9b2r9Q.js +1107 -0
  236. package/dist/plugin-sdk/github-copilot-token-BHNcM4_B.js +103 -0
  237. package/dist/plugin-sdk/image-7PgoS2VD.js +1421 -0
  238. package/dist/plugin-sdk/index.d.ts +8908 -0
  239. package/dist/plugin-sdk/index.js +70888 -0
  240. package/dist/plugin-sdk/login-qr-qTALvWi2.js +475 -0
  241. package/dist/plugin-sdk/manager-Cs3EQZCb.js +2870 -0
  242. package/dist/plugin-sdk/model-selection-BgC1E1a7.js +2708 -0
  243. package/dist/plugin-sdk/paths-BYpoyRv5.js +164 -0
  244. package/dist/plugin-sdk/paths-DNQE-bvr.js +40 -0
  245. package/dist/plugin-sdk/pi-embedded-helpers-5jNqW_dE.js +8755 -0
  246. package/dist/plugin-sdk/pi-model-discovery-BUGEht9A.js +20 -0
  247. package/dist/plugin-sdk/pw-ai-COTtei4a.js +1649 -0
  248. package/dist/plugin-sdk/qmd-manager-ClSwiAJl.js +615 -0
  249. package/dist/plugin-sdk/redact-2AzjOfk2.js +94 -0
  250. package/dist/plugin-sdk/rolldown-runtime-Cbj13DAv.js +20 -0
  251. package/dist/plugin-sdk/sqlite-gCW7MlLs.js +215 -0
  252. package/dist/plugin-sdk/transcript-events-DGF257vD.js +17 -0
  253. package/dist/plugins-C3Bm-HQV.js +494 -0
  254. package/dist/plugins-QJjTXliB.js +495 -0
  255. package/dist/plugins-cli-DTci0JQb.js +443 -0
  256. package/dist/plugins-cli-wJsN1HHK.js +440 -0
  257. package/dist/ports-CiW9dmMq.js +96 -0
  258. package/dist/program-BWpTHh1I.js +188 -0
  259. package/dist/progress-Bcjniu7m.js +133 -0
  260. package/dist/progress-CvaSPjS9.js +133 -0
  261. package/dist/prompt-style-CFsleyxV.js +9 -0
  262. package/dist/prompt-style-DYJdrXyV.js +9 -0
  263. package/dist/prompts-Bt9fwsg2.js +10 -0
  264. package/dist/prompts-CudpZgTI.js +10 -0
  265. package/dist/pw-ai-08F3GD-3.js +1649 -0
  266. package/dist/pw-ai-ZmHxHQnx.js +1651 -0
  267. package/dist/pw-ai-tNPuRNn3.js +1649 -0
  268. package/dist/qmd-manager-2r-4n3sP.js +617 -0
  269. package/dist/qmd-manager-CF52nuBg.js +615 -0
  270. package/dist/qmd-manager-HEm5H2mk.js +616 -0
  271. package/dist/redact-BICFkpn7.js +97 -0
  272. package/dist/redact-BIMJ3ntQ.js +94 -0
  273. package/dist/redact-KzWHRS5J.js +97 -0
  274. package/dist/register.subclis-D2K25c84.js +348 -0
  275. package/dist/register.subclis-Dd8LbOLi.js +342 -0
  276. package/dist/reply-5UNWRwMn.js +63693 -0
  277. package/dist/restart-sentinel-Cr0vUxB8.js +65 -0
  278. package/dist/restart-sentinel-DUemCjgU.js +65 -0
  279. package/dist/rolldown-runtime-Cbj13DAv.js +20 -0
  280. package/dist/routes-C6UpTPas.js +2410 -0
  281. package/dist/routes-ClNyEvlm.js +2410 -0
  282. package/dist/rpc-D0mf7DIw.js +95 -0
  283. package/dist/rpc-DYdOrgd9.js +95 -0
  284. package/dist/run-main-CojI7gWx.js +194 -0
  285. package/dist/runtime-guard-68M_evhb.js +60 -0
  286. package/dist/runtime-guard-DkjmhnBD.js +60 -0
  287. package/dist/sandbox-Ca81z3Tw.js +2924 -0
  288. package/dist/sandbox-cli-D75GApgp.js +459 -0
  289. package/dist/sandbox-cli-E4SJsC1C.js +462 -0
  290. package/dist/sandbox-knontqD9.js +2925 -0
  291. package/dist/security-cli-BLihvXO-.js +503 -0
  292. package/dist/security-cli-IGQCsK4g.js +506 -0
  293. package/dist/server-context-B9GX5GOI.js +740 -0
  294. package/dist/server-context-BFH7HB_M.js +740 -0
  295. package/dist/server-node-events-CTdHBiEA.js +218 -0
  296. package/dist/server-node-events-DAV14qPr.js +215 -0
  297. package/dist/service-BZNBq9hq.js +680 -0
  298. package/dist/service-C-BLXx9U.js +680 -0
  299. package/dist/service-audit-BfJv4NqZ.js +542 -0
  300. package/dist/service-audit-Bw3M2OEI.js +542 -0
  301. package/dist/shared-5SH-45AX.js +74 -0
  302. package/dist/shared-BxRm5uLU.js +74 -0
  303. package/dist/shared-C80Rmxsd.js +150 -0
  304. package/dist/shared-fGK6_D2v.js +150 -0
  305. package/dist/skills-Bhp0l6UK.js +693 -0
  306. package/dist/skills-Tky2kCMO.js +694 -0
  307. package/dist/skills-cli-6rCClAE4.js +287 -0
  308. package/dist/skills-cli-C4nLCrLw.js +290 -0
  309. package/dist/skills-status-CENcKr3I.js +187 -0
  310. package/dist/skills-status-DX1eUYvk.js +187 -0
  311. package/dist/sqlite-CmdZSZRx.js +197 -0
  312. package/dist/sqlite-Dnmf3LS7.js +215 -0
  313. package/dist/sqlite-QDf0yuU0.js +215 -0
  314. package/dist/status-BSfGAp2D.js +27 -0
  315. package/dist/status-Bp_2NMjt.js +27 -0
  316. package/dist/status-C0ANDr0T.js +3140 -0
  317. package/dist/status-CCHBIZnm.js +21 -0
  318. package/dist/status-Vuqbw2Bb.js +21 -0
  319. package/dist/status.update-BZW5r8Su.js +79 -0
  320. package/dist/status.update-BnD93_O8.js +79 -0
  321. package/dist/subsystem-CAq3uyo7.js +834 -0
  322. package/dist/system-cli-Bb9zmCO1.js +83 -0
  323. package/dist/system-cli-TIIQ04ls.js +80 -0
  324. package/dist/systemd-0Qa_nGqe.js +438 -0
  325. package/dist/systemd-Czb0Xsm7.js +438 -0
  326. package/dist/systemd-hints-CWoEOQRb.js +19 -0
  327. package/dist/systemd-hints-Cv3RN_mZ.js +19 -0
  328. package/dist/systemd-linger-CsdvcIoS.js +75 -0
  329. package/dist/systemd-linger-DKUFHcLn.js +75 -0
  330. package/dist/table-DNPESyNj.js +279 -0
  331. package/dist/table-DS4-gmkV.js +279 -0
  332. package/dist/tailnet-Bg_vE5qi.js +42 -0
  333. package/dist/tailnet-CrNWlQRJ.js +42 -0
  334. package/dist/tailscale-CBv58toW.js +252 -0
  335. package/dist/tailscale-DCnMs7_q.js +225 -0
  336. package/dist/tool-display-BEACy9rK.js +795 -0
  337. package/dist/tool-display-NYQnSpdo.js +795 -0
  338. package/dist/transcript-events-CsB1Saa6.js +17 -0
  339. package/dist/transcript-events-DDYvbmRV.js +17 -0
  340. package/dist/transcript-events-JLH5W4He.js +17 -0
  341. package/dist/tui--NY0rnjr.js +2542 -0
  342. package/dist/tui-DqJfGtvM.js +2543 -0
  343. package/dist/tui-cli-BuHNY6wF.js +54 -0
  344. package/dist/tui-cli-LMFV982e.js +57 -0
  345. package/dist/update-CRpHtCgz.js +317 -0
  346. package/dist/update-D3qruxhj.js +317 -0
  347. package/dist/update-cli-CFF-pslM.js +948 -0
  348. package/dist/update-cli-cn9pEMX7.js +951 -0
  349. package/dist/update-runner-CxGU142L.js +1221 -0
  350. package/dist/update-runner-DNobz_ft.js +1221 -0
  351. package/dist/utils-CKSrBNwq.js +192 -0
  352. package/dist/utils-DX85MiPR.js +188 -0
  353. package/dist/webhooks-cli-BGtt2HAR.js +312 -0
  354. package/dist/webhooks-cli-DHLZrEO_.js +309 -0
  355. package/dist/widearea-dns-BpG7ATO8.js +127 -0
  356. package/dist/widearea-dns-D4wkCJly.js +127 -0
  357. package/dist/ws-3zr8WUwL.js +13 -0
  358. package/dist/ws-log-BXcT2xQk.js +267 -0
  359. package/dist/ws-log-DbDIUsgz.js +267 -0
  360. package/dist/ws-lzrgabja.js +13 -0
  361. package/dist/wsl-D2O2qOrl.js +160 -0
  362. package/docs/.i18n/README.md +31 -0
  363. package/docs/.i18n/glossary.zh-CN.json +190 -0
  364. package/docs/.i18n/zh-CN.tm.jsonl +1329 -0
  365. package/docs/CNAME +1 -0
  366. package/docs/_config.yml +53 -0
  367. package/docs/_layouts/default.html +145 -0
  368. package/docs/assets/markdown.css +179 -0
  369. package/docs/assets/openclaw-logo-text-dark.png +0 -0
  370. package/docs/assets/openclaw-logo-text.png +0 -0
  371. package/docs/assets/pixel-lobster.svg +60 -0
  372. package/docs/assets/showcase/agents-ui.jpg +0 -0
  373. package/docs/assets/showcase/bambu-cli.png +0 -0
  374. package/docs/assets/showcase/codexmonitor.png +0 -0
  375. package/docs/assets/showcase/gohome-grafana.png +0 -0
  376. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  377. package/docs/assets/showcase/oura-health.png +0 -0
  378. package/docs/assets/showcase/padel-cli.svg +11 -0
  379. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  380. package/docs/assets/showcase/papla-tts.jpg +0 -0
  381. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  382. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  383. package/docs/assets/showcase/roborock-status.svg +13 -0
  384. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  385. package/docs/assets/showcase/snag.png +0 -0
  386. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  387. package/docs/assets/showcase/wienerlinien.png +0 -0
  388. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  389. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  390. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  391. package/docs/assets/terminal.css +473 -0
  392. package/docs/assets/theme.js +55 -0
  393. package/docs/automation/auth-monitoring.md +44 -0
  394. package/docs/automation/cron-jobs.md +468 -0
  395. package/docs/automation/cron-vs-heartbeat.md +282 -0
  396. package/docs/automation/gmail-pubsub.md +256 -0
  397. package/docs/automation/poll.md +69 -0
  398. package/docs/automation/webhook.md +163 -0
  399. package/docs/bedrock.md +176 -0
  400. package/docs/brave-search.md +41 -0
  401. package/docs/broadcast-groups.md +442 -0
  402. package/docs/channels/bluebubbles.md +338 -0
  403. package/docs/channels/discord.md +475 -0
  404. package/docs/channels/feishu.md +507 -0
  405. package/docs/channels/googlechat.md +250 -0
  406. package/docs/channels/grammy.md +31 -0
  407. package/docs/channels/imessage.md +299 -0
  408. package/docs/channels/index.md +46 -0
  409. package/docs/channels/line.md +186 -0
  410. package/docs/channels/location.md +56 -0
  411. package/docs/channels/matrix.md +233 -0
  412. package/docs/channels/mattermost.md +138 -0
  413. package/docs/channels/msteams.md +768 -0
  414. package/docs/channels/nextcloud-talk.md +136 -0
  415. package/docs/channels/nostr.md +233 -0
  416. package/docs/channels/signal.md +202 -0
  417. package/docs/channels/slack.md +548 -0
  418. package/docs/channels/telegram.md +750 -0
  419. package/docs/channels/tlon.md +132 -0
  420. package/docs/channels/troubleshooting.md +29 -0
  421. package/docs/channels/twitch.md +379 -0
  422. package/docs/channels/whatsapp.md +404 -0
  423. package/docs/channels/zalo.md +189 -0
  424. package/docs/channels/zalouser.md +140 -0
  425. package/docs/cli/acp.md +170 -0
  426. package/docs/cli/agent.md +24 -0
  427. package/docs/cli/agents.md +75 -0
  428. package/docs/cli/approvals.md +50 -0
  429. package/docs/cli/browser.md +107 -0
  430. package/docs/cli/channels.md +79 -0
  431. package/docs/cli/config.md +50 -0
  432. package/docs/cli/configure.md +33 -0
  433. package/docs/cli/cron.md +42 -0
  434. package/docs/cli/dashboard.md +16 -0
  435. package/docs/cli/devices.md +67 -0
  436. package/docs/cli/directory.md +63 -0
  437. package/docs/cli/dns.md +23 -0
  438. package/docs/cli/docs.md +15 -0
  439. package/docs/cli/doctor.md +41 -0
  440. package/docs/cli/gateway.md +199 -0
  441. package/docs/cli/health.md +21 -0
  442. package/docs/cli/hooks.md +304 -0
  443. package/docs/cli/index.md +1029 -0
  444. package/docs/cli/logs.md +24 -0
  445. package/docs/cli/memory.md +45 -0
  446. package/docs/cli/message.md +239 -0
  447. package/docs/cli/models.md +79 -0
  448. package/docs/cli/node.md +112 -0
  449. package/docs/cli/nodes.md +73 -0
  450. package/docs/cli/onboard.md +29 -0
  451. package/docs/cli/pairing.md +21 -0
  452. package/docs/cli/plugins.md +62 -0
  453. package/docs/cli/reset.md +17 -0
  454. package/docs/cli/sandbox.md +152 -0
  455. package/docs/cli/security.md +26 -0
  456. package/docs/cli/sessions.md +16 -0
  457. package/docs/cli/setup.md +29 -0
  458. package/docs/cli/skills.md +26 -0
  459. package/docs/cli/status.md +26 -0
  460. package/docs/cli/system.md +60 -0
  461. package/docs/cli/tui.md +23 -0
  462. package/docs/cli/uninstall.md +17 -0
  463. package/docs/cli/update.md +98 -0
  464. package/docs/cli/voicecall.md +34 -0
  465. package/docs/cli/webhooks.md +25 -0
  466. package/docs/concepts/agent-loop.md +146 -0
  467. package/docs/concepts/agent-workspace.md +233 -0
  468. package/docs/concepts/agent.md +123 -0
  469. package/docs/concepts/architecture.md +129 -0
  470. package/docs/concepts/channel-routing.md +114 -0
  471. package/docs/concepts/compaction.md +61 -0
  472. package/docs/concepts/context.md +161 -0
  473. package/docs/concepts/group-messages.md +84 -0
  474. package/docs/concepts/groups.md +373 -0
  475. package/docs/concepts/markdown-formatting.md +130 -0
  476. package/docs/concepts/memory.md +546 -0
  477. package/docs/concepts/messages.md +154 -0
  478. package/docs/concepts/model-failover.md +149 -0
  479. package/docs/concepts/model-providers.md +316 -0
  480. package/docs/concepts/models.md +208 -0
  481. package/docs/concepts/multi-agent.md +376 -0
  482. package/docs/concepts/oauth.md +145 -0
  483. package/docs/concepts/presence.md +102 -0
  484. package/docs/concepts/queue.md +89 -0
  485. package/docs/concepts/retry.md +69 -0
  486. package/docs/concepts/session-pruning.md +122 -0
  487. package/docs/concepts/session-tool.md +193 -0
  488. package/docs/concepts/session.md +188 -0
  489. package/docs/concepts/sessions.md +10 -0
  490. package/docs/concepts/streaming.md +135 -0
  491. package/docs/concepts/system-prompt.md +115 -0
  492. package/docs/concepts/timezone.md +91 -0
  493. package/docs/concepts/typebox.md +289 -0
  494. package/docs/concepts/typing-indicators.md +68 -0
  495. package/docs/concepts/usage-tracking.md +35 -0
  496. package/docs/date-time.md +128 -0
  497. package/docs/debug/node-issue.md +83 -0
  498. package/docs/debugging.md +162 -0
  499. package/docs/diagnostics/flags.md +91 -0
  500. package/docs/docs.json +1587 -0
  501. package/docs/environment.md +81 -0
  502. package/docs/experiments/onboarding-config-protocol.md +40 -0
  503. package/docs/experiments/plans/cron-add-hardening.md +63 -0
  504. package/docs/experiments/plans/group-policy-hardening.md +40 -0
  505. package/docs/experiments/plans/openresponses-gateway.md +123 -0
  506. package/docs/experiments/proposals/model-config.md +36 -0
  507. package/docs/experiments/research/memory.md +228 -0
  508. package/docs/gateway/authentication.md +145 -0
  509. package/docs/gateway/background-process.md +93 -0
  510. package/docs/gateway/bonjour.md +167 -0
  511. package/docs/gateway/bridge-protocol.md +89 -0
  512. package/docs/gateway/cli-backends.md +223 -0
  513. package/docs/gateway/configuration-examples.md +606 -0
  514. package/docs/gateway/configuration.md +3393 -0
  515. package/docs/gateway/discovery.md +116 -0
  516. package/docs/gateway/doctor.md +282 -0
  517. package/docs/gateway/gateway-lock.md +34 -0
  518. package/docs/gateway/health.md +35 -0
  519. package/docs/gateway/heartbeat.md +302 -0
  520. package/docs/gateway/index.md +328 -0
  521. package/docs/gateway/local-models.md +150 -0
  522. package/docs/gateway/logging.md +113 -0
  523. package/docs/gateway/multiple-gateways.md +112 -0
  524. package/docs/gateway/openai-http-api.md +118 -0
  525. package/docs/gateway/openresponses-http-api.md +317 -0
  526. package/docs/gateway/pairing.md +99 -0
  527. package/docs/gateway/protocol.md +221 -0
  528. package/docs/gateway/remote-gateway-readme.md +157 -0
  529. package/docs/gateway/remote.md +127 -0
  530. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +128 -0
  531. package/docs/gateway/sandboxing.md +193 -0
  532. package/docs/gateway/security/formal-verification.md +164 -0
  533. package/docs/gateway/security/index.md +825 -0
  534. package/docs/gateway/tailscale.md +127 -0
  535. package/docs/gateway/tools-invoke-http-api.md +85 -0
  536. package/docs/gateway/troubleshooting.md +767 -0
  537. package/docs/help/faq.md +2830 -0
  538. package/docs/help/index.md +21 -0
  539. package/docs/help/troubleshooting.md +98 -0
  540. package/docs/hooks/soul-evil.md +69 -0
  541. package/docs/hooks.md +913 -0
  542. package/docs/images/feishu-step2-create-app.png +0 -0
  543. package/docs/images/feishu-step3-credentials.png +0 -0
  544. package/docs/images/feishu-step4-permissions.png +0 -0
  545. package/docs/images/feishu-step5-bot-capability.png +0 -0
  546. package/docs/images/feishu-step6-event-subscription.png +0 -0
  547. package/docs/images/groups-flow.svg +52 -0
  548. package/docs/images/mobile-ui-screenshot.png +0 -0
  549. package/docs/index.md +258 -0
  550. package/docs/install/ansible.md +208 -0
  551. package/docs/install/bun.md +59 -0
  552. package/docs/install/development-channels.md +75 -0
  553. package/docs/install/docker.md +567 -0
  554. package/docs/install/index.md +185 -0
  555. package/docs/install/installer.md +123 -0
  556. package/docs/install/migrating.md +192 -0
  557. package/docs/install/nix.md +96 -0
  558. package/docs/install/node.md +78 -0
  559. package/docs/install/uninstall.md +128 -0
  560. package/docs/install/updating.md +228 -0
  561. package/docs/logging.md +350 -0
  562. package/docs/multi-agent-sandbox-tools.md +395 -0
  563. package/docs/network.md +54 -0
  564. package/docs/nodes/audio.md +114 -0
  565. package/docs/nodes/camera.md +156 -0
  566. package/docs/nodes/images.md +72 -0
  567. package/docs/nodes/index.md +341 -0
  568. package/docs/nodes/location-command.md +113 -0
  569. package/docs/nodes/media-understanding.md +379 -0
  570. package/docs/nodes/talk.md +90 -0
  571. package/docs/nodes/voicewake.md +65 -0
  572. package/docs/northflank.mdx +53 -0
  573. package/docs/perplexity.md +80 -0
  574. package/docs/pi-dev.md +70 -0
  575. package/docs/pi.md +612 -0
  576. package/docs/platforms/android.md +148 -0
  577. package/docs/platforms/digitalocean.md +262 -0
  578. package/docs/platforms/exe-dev.md +125 -0
  579. package/docs/platforms/fly.md +486 -0
  580. package/docs/platforms/gcp.md +503 -0
  581. package/docs/platforms/hetzner.md +330 -0
  582. package/docs/platforms/index.md +53 -0
  583. package/docs/platforms/ios.md +107 -0
  584. package/docs/platforms/linux.md +94 -0
  585. package/docs/platforms/mac/bundled-gateway.md +73 -0
  586. package/docs/platforms/mac/canvas.md +125 -0
  587. package/docs/platforms/mac/child-process.md +69 -0
  588. package/docs/platforms/mac/dev-setup.md +102 -0
  589. package/docs/platforms/mac/health.md +34 -0
  590. package/docs/platforms/mac/icon.md +31 -0
  591. package/docs/platforms/mac/logging.md +57 -0
  592. package/docs/platforms/mac/menu-bar.md +81 -0
  593. package/docs/platforms/mac/peekaboo.md +65 -0
  594. package/docs/platforms/mac/permissions.md +44 -0
  595. package/docs/platforms/mac/release.md +85 -0
  596. package/docs/platforms/mac/remote.md +83 -0
  597. package/docs/platforms/mac/signing.md +47 -0
  598. package/docs/platforms/mac/skills.md +33 -0
  599. package/docs/platforms/mac/voice-overlay.md +60 -0
  600. package/docs/platforms/mac/voicewake.md +67 -0
  601. package/docs/platforms/mac/webchat.md +41 -0
  602. package/docs/platforms/mac/xpc.md +61 -0
  603. package/docs/platforms/macos-vm.md +281 -0
  604. package/docs/platforms/macos.md +203 -0
  605. package/docs/platforms/oracle.md +303 -0
  606. package/docs/platforms/raspberry-pi.md +358 -0
  607. package/docs/platforms/windows.md +159 -0
  608. package/docs/plugin.md +664 -0
  609. package/docs/plugins/agent-tools.md +99 -0
  610. package/docs/plugins/manifest.md +71 -0
  611. package/docs/plugins/voice-call.md +284 -0
  612. package/docs/plugins/zalouser.md +81 -0
  613. package/docs/prose.md +134 -0
  614. package/docs/providers/anthropic.md +152 -0
  615. package/docs/providers/claude-max-api-proxy.md +148 -0
  616. package/docs/providers/cloudflare-ai-gateway.md +71 -0
  617. package/docs/providers/deepgram.md +93 -0
  618. package/docs/providers/github-copilot.md +72 -0
  619. package/docs/providers/glm.md +33 -0
  620. package/docs/providers/index.md +63 -0
  621. package/docs/providers/minimax.md +208 -0
  622. package/docs/providers/models.md +51 -0
  623. package/docs/providers/moonshot.md +142 -0
  624. package/docs/providers/ollama.md +223 -0
  625. package/docs/providers/openai.md +62 -0
  626. package/docs/providers/opencode.md +36 -0
  627. package/docs/providers/openrouter.md +37 -0
  628. package/docs/providers/qwen.md +53 -0
  629. package/docs/providers/synthetic.md +99 -0
  630. package/docs/providers/venice.md +267 -0
  631. package/docs/providers/vercel-ai-gateway.md +50 -0
  632. package/docs/providers/xiaomi.md +64 -0
  633. package/docs/providers/zai.md +36 -0
  634. package/docs/railway.mdx +99 -0
  635. package/docs/refactor/clawnet.md +417 -0
  636. package/docs/refactor/exec-host.md +316 -0
  637. package/docs/refactor/outbound-session-mirroring.md +85 -0
  638. package/docs/refactor/plugin-sdk.md +214 -0
  639. package/docs/refactor/strict-config.md +93 -0
  640. package/docs/reference/AGENTS.default.md +124 -0
  641. package/docs/reference/RELEASING.md +120 -0
  642. package/docs/reference/api-usage-costs.md +137 -0
  643. package/docs/reference/device-models.md +47 -0
  644. package/docs/reference/rpc.md +43 -0
  645. package/docs/reference/session-management-compaction.md +285 -0
  646. package/docs/reference/templates/AGENTS.dev.md +83 -0
  647. package/docs/reference/templates/AGENTS.md +218 -0
  648. package/docs/reference/templates/BOOT.md +10 -0
  649. package/docs/reference/templates/BOOTSTRAP.md +61 -0
  650. package/docs/reference/templates/HEARTBEAT.md +11 -0
  651. package/docs/reference/templates/IDENTITY.dev.md +47 -0
  652. package/docs/reference/templates/IDENTITY.md +27 -0
  653. package/docs/reference/templates/SOUL.dev.md +76 -0
  654. package/docs/reference/templates/SOUL.md +42 -0
  655. package/docs/reference/templates/TOOLS.dev.md +24 -0
  656. package/docs/reference/templates/TOOLS.md +46 -0
  657. package/docs/reference/templates/USER.dev.md +18 -0
  658. package/docs/reference/templates/USER.md +22 -0
  659. package/docs/reference/test.md +50 -0
  660. package/docs/reference/transcript-hygiene.md +129 -0
  661. package/docs/render.mdx +165 -0
  662. package/docs/scripts.md +28 -0
  663. package/docs/security/formal-verification.md +164 -0
  664. package/docs/start/getting-started.md +208 -0
  665. package/docs/start/hubs.md +185 -0
  666. package/docs/start/lore.md +219 -0
  667. package/docs/start/onboarding.md +110 -0
  668. package/docs/start/openclaw.md +241 -0
  669. package/docs/start/pairing.md +86 -0
  670. package/docs/start/setup.md +149 -0
  671. package/docs/start/showcase.md +416 -0
  672. package/docs/start/wizard.md +349 -0
  673. package/docs/testing.md +368 -0
  674. package/docs/token-use.md +112 -0
  675. package/docs/tools/agent-send.md +53 -0
  676. package/docs/tools/apply-patch.md +50 -0
  677. package/docs/tools/browser-linux-troubleshooting.md +139 -0
  678. package/docs/tools/browser-login.md +68 -0
  679. package/docs/tools/browser.md +576 -0
  680. package/docs/tools/chrome-extension.md +178 -0
  681. package/docs/tools/clawhub.md +257 -0
  682. package/docs/tools/creating-skills.md +54 -0
  683. package/docs/tools/elevated.md +57 -0
  684. package/docs/tools/exec-approvals.md +246 -0
  685. package/docs/tools/exec.md +179 -0
  686. package/docs/tools/firecrawl.md +61 -0
  687. package/docs/tools/index.md +509 -0
  688. package/docs/tools/llm-task.md +115 -0
  689. package/docs/tools/lobster.md +342 -0
  690. package/docs/tools/reactions.md +22 -0
  691. package/docs/tools/skills-config.md +76 -0
  692. package/docs/tools/skills.md +300 -0
  693. package/docs/tools/slash-commands.md +198 -0
  694. package/docs/tools/subagents.md +151 -0
  695. package/docs/tools/thinking.md +73 -0
  696. package/docs/tools/web.md +261 -0
  697. package/docs/tts.md +396 -0
  698. package/docs/tui.md +159 -0
  699. package/docs/vps.md +43 -0
  700. package/docs/web/control-ui.md +221 -0
  701. package/docs/web/dashboard.md +46 -0
  702. package/docs/web/index.md +116 -0
  703. package/docs/web/webchat.md +49 -0
  704. package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
  705. package/docs/whatsapp-openclaw.jpg +0 -0
  706. package/docs/zh-CN/AGENTS.md +59 -0
  707. package/docs/zh-CN/automation/auth-monitoring.md +47 -0
  708. package/docs/zh-CN/automation/cron-jobs.md +424 -0
  709. package/docs/zh-CN/automation/cron-vs-heartbeat.md +286 -0
  710. package/docs/zh-CN/automation/gmail-pubsub.md +249 -0
  711. package/docs/zh-CN/automation/poll.md +76 -0
  712. package/docs/zh-CN/automation/webhook.md +163 -0
  713. package/docs/zh-CN/bedrock.md +170 -0
  714. package/docs/zh-CN/brave-search.md +48 -0
  715. package/docs/zh-CN/broadcast-groups.md +449 -0
  716. package/docs/zh-CN/channels/bluebubbles.md +271 -0
  717. package/docs/zh-CN/channels/discord.md +468 -0
  718. package/docs/zh-CN/channels/feishu.md +513 -0
  719. package/docs/zh-CN/channels/googlechat.md +257 -0
  720. package/docs/zh-CN/channels/grammy.md +38 -0
  721. package/docs/zh-CN/channels/imessage.md +302 -0
  722. package/docs/zh-CN/channels/index.md +53 -0
  723. package/docs/zh-CN/channels/line.md +180 -0
  724. package/docs/zh-CN/channels/location.md +63 -0
  725. package/docs/zh-CN/channels/matrix.md +221 -0
  726. package/docs/zh-CN/channels/mattermost.md +144 -0
  727. package/docs/zh-CN/channels/msteams.md +775 -0
  728. package/docs/zh-CN/channels/nextcloud-talk.md +142 -0
  729. package/docs/zh-CN/channels/nostr.md +240 -0
  730. package/docs/zh-CN/channels/signal.md +209 -0
  731. package/docs/zh-CN/channels/slack.md +531 -0
  732. package/docs/zh-CN/channels/telegram.md +751 -0
  733. package/docs/zh-CN/channels/tlon.md +136 -0
  734. package/docs/zh-CN/channels/troubleshooting.md +36 -0
  735. package/docs/zh-CN/channels/twitch.md +385 -0
  736. package/docs/zh-CN/channels/whatsapp.md +411 -0
  737. package/docs/zh-CN/channels/zalo.md +196 -0
  738. package/docs/zh-CN/channels/zalouser.md +147 -0
  739. package/docs/zh-CN/cli/acp.md +173 -0
  740. package/docs/zh-CN/cli/agent.md +30 -0
  741. package/docs/zh-CN/cli/agents.md +82 -0
  742. package/docs/zh-CN/cli/approvals.md +57 -0
  743. package/docs/zh-CN/cli/browser.md +114 -0
  744. package/docs/zh-CN/cli/channels.md +86 -0
  745. package/docs/zh-CN/cli/config.md +57 -0
  746. package/docs/zh-CN/cli/configure.md +38 -0
  747. package/docs/zh-CN/cli/cron.md +43 -0
  748. package/docs/zh-CN/cli/dashboard.md +23 -0
  749. package/docs/zh-CN/cli/devices.md +74 -0
  750. package/docs/zh-CN/cli/directory.md +70 -0
  751. package/docs/zh-CN/cli/dns.md +30 -0
  752. package/docs/zh-CN/cli/docs.md +22 -0
  753. package/docs/zh-CN/cli/doctor.md +48 -0
  754. package/docs/zh-CN/cli/gateway.md +206 -0
  755. package/docs/zh-CN/cli/health.md +28 -0
  756. package/docs/zh-CN/cli/hooks.md +311 -0
  757. package/docs/zh-CN/cli/index.md +1032 -0
  758. package/docs/zh-CN/cli/logs.md +31 -0
  759. package/docs/zh-CN/cli/memory.md +52 -0
  760. package/docs/zh-CN/cli/message.md +246 -0
  761. package/docs/zh-CN/cli/models.md +85 -0
  762. package/docs/zh-CN/cli/node.md +115 -0
  763. package/docs/zh-CN/cli/nodes.md +80 -0
  764. package/docs/zh-CN/cli/onboard.md +36 -0
  765. package/docs/zh-CN/cli/pairing.md +28 -0
  766. package/docs/zh-CN/cli/plugins.md +66 -0
  767. package/docs/zh-CN/cli/reset.md +24 -0
  768. package/docs/zh-CN/cli/sandbox.md +158 -0
  769. package/docs/zh-CN/cli/security.md +33 -0
  770. package/docs/zh-CN/cli/sessions.md +23 -0
  771. package/docs/zh-CN/cli/setup.md +36 -0
  772. package/docs/zh-CN/cli/skills.md +33 -0
  773. package/docs/zh-CN/cli/status.md +33 -0
  774. package/docs/zh-CN/cli/system.md +63 -0
  775. package/docs/zh-CN/cli/tui.md +30 -0
  776. package/docs/zh-CN/cli/uninstall.md +24 -0
  777. package/docs/zh-CN/cli/update.md +101 -0
  778. package/docs/zh-CN/cli/voicecall.md +41 -0
  779. package/docs/zh-CN/cli/webhooks.md +32 -0
  780. package/docs/zh-CN/concepts/agent-loop.md +146 -0
  781. package/docs/zh-CN/concepts/agent-workspace.md +219 -0
  782. package/docs/zh-CN/concepts/agent.md +115 -0
  783. package/docs/zh-CN/concepts/architecture.md +123 -0
  784. package/docs/zh-CN/concepts/channel-routing.md +117 -0
  785. package/docs/zh-CN/concepts/compaction.md +67 -0
  786. package/docs/zh-CN/concepts/context.md +168 -0
  787. package/docs/zh-CN/concepts/group-messages.md +91 -0
  788. package/docs/zh-CN/concepts/groups.md +379 -0
  789. package/docs/zh-CN/concepts/markdown-formatting.md +117 -0
  790. package/docs/zh-CN/concepts/memory.md +412 -0
  791. package/docs/zh-CN/concepts/messages.md +141 -0
  792. package/docs/zh-CN/concepts/model-failover.md +145 -0
  793. package/docs/zh-CN/concepts/model-providers.md +320 -0
  794. package/docs/zh-CN/concepts/models.md +196 -0
  795. package/docs/zh-CN/concepts/multi-agent.md +372 -0
  796. package/docs/zh-CN/concepts/oauth.md +151 -0
  797. package/docs/zh-CN/concepts/presence.md +99 -0
  798. package/docs/zh-CN/concepts/queue.md +94 -0
  799. package/docs/zh-CN/concepts/retry.md +76 -0
  800. package/docs/zh-CN/concepts/session-pruning.md +129 -0
  801. package/docs/zh-CN/concepts/session-tool.md +200 -0
  802. package/docs/zh-CN/concepts/session.md +166 -0
  803. package/docs/zh-CN/concepts/sessions.md +17 -0
  804. package/docs/zh-CN/concepts/streaming.md +133 -0
  805. package/docs/zh-CN/concepts/system-prompt.md +101 -0
  806. package/docs/zh-CN/concepts/timezone.md +96 -0
  807. package/docs/zh-CN/concepts/typebox.md +284 -0
  808. package/docs/zh-CN/concepts/typing-indicators.md +74 -0
  809. package/docs/zh-CN/concepts/usage-tracking.md +42 -0
  810. package/docs/zh-CN/date-time.md +129 -0
  811. package/docs/zh-CN/debug/node-issue.md +90 -0
  812. package/docs/zh-CN/debugging.md +160 -0
  813. package/docs/zh-CN/diagnostics/flags.md +98 -0
  814. package/docs/zh-CN/environment.md +88 -0
  815. package/docs/zh-CN/experiments/onboarding-config-protocol.md +47 -0
  816. package/docs/zh-CN/experiments/plans/cron-add-hardening.md +70 -0
  817. package/docs/zh-CN/experiments/plans/group-policy-hardening.md +45 -0
  818. package/docs/zh-CN/experiments/plans/openresponses-gateway.md +121 -0
  819. package/docs/zh-CN/experiments/proposals/model-config.md +42 -0
  820. package/docs/zh-CN/experiments/research/memory.md +235 -0
  821. package/docs/zh-CN/gateway/authentication.md +142 -0
  822. package/docs/zh-CN/gateway/background-process.md +100 -0
  823. package/docs/zh-CN/gateway/bonjour.md +174 -0
  824. package/docs/zh-CN/gateway/bridge-protocol.md +86 -0
  825. package/docs/zh-CN/gateway/cli-backends.md +213 -0
  826. package/docs/zh-CN/gateway/configuration-examples.md +587 -0
  827. package/docs/zh-CN/gateway/configuration.md +3332 -0
  828. package/docs/zh-CN/gateway/discovery.md +123 -0
  829. package/docs/zh-CN/gateway/doctor.md +238 -0
  830. package/docs/zh-CN/gateway/gateway-lock.md +41 -0
  831. package/docs/zh-CN/gateway/health.md +42 -0
  832. package/docs/zh-CN/gateway/heartbeat.md +274 -0
  833. package/docs/zh-CN/gateway/index.md +335 -0
  834. package/docs/zh-CN/gateway/local-models.md +157 -0
  835. package/docs/zh-CN/gateway/logging.md +114 -0
  836. package/docs/zh-CN/gateway/multiple-gateways.md +119 -0
  837. package/docs/zh-CN/gateway/openai-http-api.md +125 -0
  838. package/docs/zh-CN/gateway/openresponses-http-api.md +317 -0
  839. package/docs/zh-CN/gateway/pairing.md +99 -0
  840. package/docs/zh-CN/gateway/protocol.md +220 -0
  841. package/docs/zh-CN/gateway/remote-gateway-readme.md +164 -0
  842. package/docs/zh-CN/gateway/remote.md +133 -0
  843. package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +135 -0
  844. package/docs/zh-CN/gateway/sandboxing.md +188 -0
  845. package/docs/zh-CN/gateway/security/formal-verification.md +169 -0
  846. package/docs/zh-CN/gateway/security/index.md +777 -0
  847. package/docs/zh-CN/gateway/tailscale.md +124 -0
  848. package/docs/zh-CN/gateway/tools-invoke-http-api.md +92 -0
  849. package/docs/zh-CN/gateway/troubleshooting.md +771 -0
  850. package/docs/zh-CN/help/faq.md +2628 -0
  851. package/docs/zh-CN/help/index.md +28 -0
  852. package/docs/zh-CN/help/troubleshooting.md +104 -0
  853. package/docs/zh-CN/hooks/soul-evil.md +72 -0
  854. package/docs/zh-CN/hooks.md +919 -0
  855. package/docs/zh-CN/index.md +264 -0
  856. package/docs/zh-CN/install/ansible.md +215 -0
  857. package/docs/zh-CN/install/bun.md +65 -0
  858. package/docs/zh-CN/install/development-channels.md +81 -0
  859. package/docs/zh-CN/install/docker.md +532 -0
  860. package/docs/zh-CN/install/index.md +193 -0
  861. package/docs/zh-CN/install/installer.md +128 -0
  862. package/docs/zh-CN/install/migrating.md +199 -0
  863. package/docs/zh-CN/install/nix.md +99 -0
  864. package/docs/zh-CN/install/node.md +85 -0
  865. package/docs/zh-CN/install/uninstall.md +135 -0
  866. package/docs/zh-CN/install/updating.md +233 -0
  867. package/docs/zh-CN/logging.md +329 -0
  868. package/docs/zh-CN/multi-agent-sandbox-tools.md +401 -0
  869. package/docs/zh-CN/network.md +59 -0
  870. package/docs/zh-CN/nodes/audio.md +120 -0
  871. package/docs/zh-CN/nodes/camera.md +162 -0
  872. package/docs/zh-CN/nodes/images.md +79 -0
  873. package/docs/zh-CN/nodes/index.md +348 -0
  874. package/docs/zh-CN/nodes/location-command.md +120 -0
  875. package/docs/zh-CN/nodes/media-understanding.md +380 -0
  876. package/docs/zh-CN/nodes/talk.md +97 -0
  877. package/docs/zh-CN/nodes/voicewake.md +72 -0
  878. package/docs/zh-CN/northflank.mdx +60 -0
  879. package/docs/zh-CN/perplexity.md +84 -0
  880. package/docs/zh-CN/pi-dev.md +77 -0
  881. package/docs/zh-CN/pi.md +619 -0
  882. package/docs/zh-CN/platforms/android.md +155 -0
  883. package/docs/zh-CN/platforms/digitalocean.md +269 -0
  884. package/docs/zh-CN/platforms/exe-dev.md +127 -0
  885. package/docs/zh-CN/platforms/fly.md +490 -0
  886. package/docs/zh-CN/platforms/gcp.md +510 -0
  887. package/docs/zh-CN/platforms/hetzner.md +337 -0
  888. package/docs/zh-CN/platforms/index.md +60 -0
  889. package/docs/zh-CN/platforms/ios.md +114 -0
  890. package/docs/zh-CN/platforms/linux.md +101 -0
  891. package/docs/zh-CN/platforms/mac/bundled-gateway.md +75 -0
  892. package/docs/zh-CN/platforms/mac/canvas.md +128 -0
  893. package/docs/zh-CN/platforms/mac/child-process.md +73 -0
  894. package/docs/zh-CN/platforms/mac/dev-setup.md +109 -0
  895. package/docs/zh-CN/platforms/mac/health.md +41 -0
  896. package/docs/zh-CN/platforms/mac/icon.md +38 -0
  897. package/docs/zh-CN/platforms/mac/logging.md +64 -0
  898. package/docs/zh-CN/platforms/mac/menu-bar.md +88 -0
  899. package/docs/zh-CN/platforms/mac/peekaboo.md +62 -0
  900. package/docs/zh-CN/platforms/mac/permissions.md +46 -0
  901. package/docs/zh-CN/platforms/mac/release.md +92 -0
  902. package/docs/zh-CN/platforms/mac/remote.md +90 -0
  903. package/docs/zh-CN/platforms/mac/signing.md +54 -0
  904. package/docs/zh-CN/platforms/mac/skills.md +40 -0
  905. package/docs/zh-CN/platforms/mac/voice-overlay.md +67 -0
  906. package/docs/zh-CN/platforms/mac/voicewake.md +74 -0
  907. package/docs/zh-CN/platforms/mac/webchat.md +43 -0
  908. package/docs/zh-CN/platforms/mac/xpc.md +68 -0
  909. package/docs/zh-CN/platforms/macos-vm.md +288 -0
  910. package/docs/zh-CN/platforms/macos.md +193 -0
  911. package/docs/zh-CN/platforms/oracle.md +310 -0
  912. package/docs/zh-CN/platforms/raspberry-pi.md +365 -0
  913. package/docs/zh-CN/platforms/windows.md +156 -0
  914. package/docs/zh-CN/plugin.md +639 -0
  915. package/docs/zh-CN/plugins/agent-tools.md +99 -0
  916. package/docs/zh-CN/plugins/manifest.md +68 -0
  917. package/docs/zh-CN/plugins/voice-call.md +250 -0
  918. package/docs/zh-CN/plugins/zalouser.md +88 -0
  919. package/docs/zh-CN/prose.md +141 -0
  920. package/docs/zh-CN/providers/anthropic.md +159 -0
  921. package/docs/zh-CN/providers/claude-max-api-proxy.md +155 -0
  922. package/docs/zh-CN/providers/deepgram.md +97 -0
  923. package/docs/zh-CN/providers/github-copilot.md +67 -0
  924. package/docs/zh-CN/providers/glm.md +39 -0
  925. package/docs/zh-CN/providers/index.md +68 -0
  926. package/docs/zh-CN/providers/minimax.md +206 -0
  927. package/docs/zh-CN/providers/models.md +55 -0
  928. package/docs/zh-CN/providers/moonshot.md +145 -0
  929. package/docs/zh-CN/providers/ollama.md +230 -0
  930. package/docs/zh-CN/providers/openai.md +68 -0
  931. package/docs/zh-CN/providers/opencode.md +41 -0
  932. package/docs/zh-CN/providers/openrouter.md +43 -0
  933. package/docs/zh-CN/providers/qwen.md +55 -0
  934. package/docs/zh-CN/providers/synthetic.md +102 -0
  935. package/docs/zh-CN/providers/venice.md +274 -0
  936. package/docs/zh-CN/providers/vercel-ai-gateway.md +57 -0
  937. package/docs/zh-CN/providers/xiaomi.md +68 -0
  938. package/docs/zh-CN/providers/zai.md +41 -0
  939. package/docs/zh-CN/railway.mdx +106 -0
  940. package/docs/zh-CN/refactor/clawnet.md +424 -0
  941. package/docs/zh-CN/refactor/exec-host.md +323 -0
  942. package/docs/zh-CN/refactor/outbound-session-mirroring.md +92 -0
  943. package/docs/zh-CN/refactor/plugin-sdk.md +221 -0
  944. package/docs/zh-CN/refactor/strict-config.md +100 -0
  945. package/docs/zh-CN/reference/AGENTS.default.md +131 -0
  946. package/docs/zh-CN/reference/RELEASING.md +123 -0
  947. package/docs/zh-CN/reference/api-usage-costs.md +136 -0
  948. package/docs/zh-CN/reference/device-models.md +54 -0
  949. package/docs/zh-CN/reference/rpc.md +48 -0
  950. package/docs/zh-CN/reference/session-management-compaction.md +287 -0
  951. package/docs/zh-CN/reference/templates/AGENTS.dev.md +89 -0
  952. package/docs/zh-CN/reference/templates/AGENTS.md +225 -0
  953. package/docs/zh-CN/reference/templates/BOOT.md +17 -0
  954. package/docs/zh-CN/reference/templates/BOOTSTRAP.md +68 -0
  955. package/docs/zh-CN/reference/templates/HEARTBEAT.md +18 -0
  956. package/docs/zh-CN/reference/templates/IDENTITY.dev.md +54 -0
  957. package/docs/zh-CN/reference/templates/IDENTITY.md +35 -0
  958. package/docs/zh-CN/reference/templates/SOUL.dev.md +83 -0
  959. package/docs/zh-CN/reference/templates/SOUL.md +49 -0
  960. package/docs/zh-CN/reference/templates/TOOLS.dev.md +31 -0
  961. package/docs/zh-CN/reference/templates/TOOLS.md +53 -0
  962. package/docs/zh-CN/reference/templates/USER.dev.md +25 -0
  963. package/docs/zh-CN/reference/templates/USER.md +30 -0
  964. package/docs/zh-CN/reference/test.md +57 -0
  965. package/docs/zh-CN/reference/transcript-hygiene.md +109 -0
  966. package/docs/zh-CN/render.mdx +169 -0
  967. package/docs/zh-CN/scripts.md +35 -0
  968. package/docs/zh-CN/security/formal-verification.md +171 -0
  969. package/docs/zh-CN/start/getting-started.md +206 -0
  970. package/docs/zh-CN/start/hubs.md +191 -0
  971. package/docs/zh-CN/start/lore.md +226 -0
  972. package/docs/zh-CN/start/onboarding.md +105 -0
  973. package/docs/zh-CN/start/openclaw.md +248 -0
  974. package/docs/zh-CN/start/pairing.md +89 -0
  975. package/docs/zh-CN/start/setup.md +153 -0
  976. package/docs/zh-CN/start/showcase.md +423 -0
  977. package/docs/zh-CN/start/wizard.md +331 -0
  978. package/docs/zh-CN/testing.md +375 -0
  979. package/docs/zh-CN/token-use.md +119 -0
  980. package/docs/zh-CN/tools/agent-send.md +59 -0
  981. package/docs/zh-CN/tools/apply-patch.md +57 -0
  982. package/docs/zh-CN/tools/browser-linux-troubleshooting.md +144 -0
  983. package/docs/zh-CN/tools/browser-login.md +75 -0
  984. package/docs/zh-CN/tools/browser.md +553 -0
  985. package/docs/zh-CN/tools/chrome-extension.md +183 -0
  986. package/docs/zh-CN/tools/clawhub.md +209 -0
  987. package/docs/zh-CN/tools/creating-skills.md +61 -0
  988. package/docs/zh-CN/tools/elevated.md +64 -0
  989. package/docs/zh-CN/tools/exec-approvals.md +234 -0
  990. package/docs/zh-CN/tools/exec.md +169 -0
  991. package/docs/zh-CN/tools/firecrawl.md +68 -0
  992. package/docs/zh-CN/tools/index.md +515 -0
  993. package/docs/zh-CN/tools/llm-task.md +117 -0
  994. package/docs/zh-CN/tools/lobster.md +349 -0
  995. package/docs/zh-CN/tools/reactions.md +29 -0
  996. package/docs/zh-CN/tools/skills-config.md +78 -0
  997. package/docs/zh-CN/tools/skills.md +279 -0
  998. package/docs/zh-CN/tools/slash-commands.md +205 -0
  999. package/docs/zh-CN/tools/subagents.md +156 -0
  1000. package/docs/zh-CN/tools/thinking.md +80 -0
  1001. package/docs/zh-CN/tools/web.md +257 -0
  1002. package/docs/zh-CN/tts.md +375 -0
  1003. package/docs/zh-CN/tui.md +166 -0
  1004. package/docs/zh-CN/vps.md +47 -0
  1005. package/docs/zh-CN/web/control-ui.md +191 -0
  1006. package/docs/zh-CN/web/dashboard.md +53 -0
  1007. package/docs/zh-CN/web/index.md +118 -0
  1008. package/docs/zh-CN/web/webchat.md +56 -0
  1009. package/extensions/bluebubbles/README.md +45 -0
  1010. package/extensions/bluebubbles/index.ts +19 -0
  1011. package/extensions/bluebubbles/node_modules/.bin/openclaw +21 -0
  1012. package/extensions/bluebubbles/openclaw.plugin.json +9 -0
  1013. package/extensions/bluebubbles/package.json +36 -0
  1014. package/extensions/bluebubbles/src/accounts.ts +88 -0
  1015. package/extensions/bluebubbles/src/actions.test.ts +650 -0
  1016. package/extensions/bluebubbles/src/actions.ts +438 -0
  1017. package/extensions/bluebubbles/src/attachments.test.ts +345 -0
  1018. package/extensions/bluebubbles/src/attachments.ts +300 -0
  1019. package/extensions/bluebubbles/src/channel.ts +414 -0
  1020. package/extensions/bluebubbles/src/chat.test.ts +461 -0
  1021. package/extensions/bluebubbles/src/chat.ts +378 -0
  1022. package/extensions/bluebubbles/src/config-schema.ts +51 -0
  1023. package/extensions/bluebubbles/src/media-send.ts +174 -0
  1024. package/extensions/bluebubbles/src/monitor.test.ts +2342 -0
  1025. package/extensions/bluebubbles/src/monitor.ts +2490 -0
  1026. package/extensions/bluebubbles/src/onboarding.ts +352 -0
  1027. package/extensions/bluebubbles/src/probe.ts +135 -0
  1028. package/extensions/bluebubbles/src/reactions.test.ts +392 -0
  1029. package/extensions/bluebubbles/src/reactions.ts +188 -0
  1030. package/extensions/bluebubbles/src/runtime.ts +14 -0
  1031. package/extensions/bluebubbles/src/send.test.ts +808 -0
  1032. package/extensions/bluebubbles/src/send.ts +467 -0
  1033. package/extensions/bluebubbles/src/targets.test.ts +183 -0
  1034. package/extensions/bluebubbles/src/targets.ts +422 -0
  1035. package/extensions/bluebubbles/src/types.ts +127 -0
  1036. package/extensions/copilot-proxy/README.md +24 -0
  1037. package/extensions/copilot-proxy/index.ts +148 -0
  1038. package/extensions/copilot-proxy/node_modules/.bin/openclaw +21 -0
  1039. package/extensions/copilot-proxy/openclaw.plugin.json +9 -0
  1040. package/extensions/copilot-proxy/package.json +14 -0
  1041. package/extensions/diagnostics-otel/index.ts +15 -0
  1042. package/extensions/diagnostics-otel/node_modules/.bin/openclaw +21 -0
  1043. package/extensions/diagnostics-otel/openclaw.plugin.json +8 -0
  1044. package/extensions/diagnostics-otel/package.json +27 -0
  1045. package/extensions/diagnostics-otel/src/service.test.ts +226 -0
  1046. package/extensions/diagnostics-otel/src/service.ts +635 -0
  1047. package/extensions/discord/index.ts +17 -0
  1048. package/extensions/discord/node_modules/.bin/openclaw +21 -0
  1049. package/extensions/discord/openclaw.plugin.json +9 -0
  1050. package/extensions/discord/package.json +14 -0
  1051. package/extensions/discord/src/channel.ts +422 -0
  1052. package/extensions/discord/src/runtime.ts +14 -0
  1053. package/extensions/feishu/README.md +47 -0
  1054. package/extensions/feishu/index.ts +15 -0
  1055. package/extensions/feishu/node_modules/.bin/openclaw +21 -0
  1056. package/extensions/feishu/openclaw.plugin.json +9 -0
  1057. package/extensions/feishu/package.json +33 -0
  1058. package/extensions/feishu/src/channel.ts +276 -0
  1059. package/extensions/feishu/src/config-schema.ts +46 -0
  1060. package/extensions/feishu/src/onboarding.ts +278 -0
  1061. package/extensions/google-antigravity-auth/README.md +24 -0
  1062. package/extensions/google-antigravity-auth/index.ts +461 -0
  1063. package/extensions/google-antigravity-auth/node_modules/.bin/openclaw +21 -0
  1064. package/extensions/google-antigravity-auth/openclaw.plugin.json +9 -0
  1065. package/extensions/google-antigravity-auth/package.json +14 -0
  1066. package/extensions/google-gemini-cli-auth/README.md +35 -0
  1067. package/extensions/google-gemini-cli-auth/index.ts +88 -0
  1068. package/extensions/google-gemini-cli-auth/node_modules/.bin/openclaw +21 -0
  1069. package/extensions/google-gemini-cli-auth/oauth.test.ts +240 -0
  1070. package/extensions/google-gemini-cli-auth/oauth.ts +662 -0
  1071. package/extensions/google-gemini-cli-auth/openclaw.plugin.json +9 -0
  1072. package/extensions/google-gemini-cli-auth/package.json +14 -0
  1073. package/extensions/googlechat/index.ts +19 -0
  1074. package/extensions/googlechat/node_modules/.bin/openclaw +21 -0
  1075. package/extensions/googlechat/openclaw.plugin.json +9 -0
  1076. package/extensions/googlechat/package.json +39 -0
  1077. package/extensions/googlechat/src/accounts.ts +147 -0
  1078. package/extensions/googlechat/src/actions.ts +181 -0
  1079. package/extensions/googlechat/src/api.test.ts +61 -0
  1080. package/extensions/googlechat/src/api.ts +282 -0
  1081. package/extensions/googlechat/src/auth.ts +123 -0
  1082. package/extensions/googlechat/src/channel.ts +583 -0
  1083. package/extensions/googlechat/src/monitor.test.ts +22 -0
  1084. package/extensions/googlechat/src/monitor.ts +949 -0
  1085. package/extensions/googlechat/src/onboarding.ts +269 -0
  1086. package/extensions/googlechat/src/runtime.ts +14 -0
  1087. package/extensions/googlechat/src/targets.test.ts +32 -0
  1088. package/extensions/googlechat/src/targets.ts +65 -0
  1089. package/extensions/googlechat/src/types.config.ts +3 -0
  1090. package/extensions/googlechat/src/types.ts +73 -0
  1091. package/extensions/imessage/index.ts +17 -0
  1092. package/extensions/imessage/node_modules/.bin/openclaw +21 -0
  1093. package/extensions/imessage/openclaw.plugin.json +9 -0
  1094. package/extensions/imessage/package.json +14 -0
  1095. package/extensions/imessage/src/channel.ts +294 -0
  1096. package/extensions/imessage/src/runtime.ts +14 -0
  1097. package/extensions/line/index.ts +19 -0
  1098. package/extensions/line/node_modules/.bin/openclaw +21 -0
  1099. package/extensions/line/openclaw.plugin.json +9 -0
  1100. package/extensions/line/package.json +29 -0
  1101. package/extensions/line/src/card-command.ts +344 -0
  1102. package/extensions/line/src/channel.logout.test.ts +99 -0
  1103. package/extensions/line/src/channel.sendPayload.test.ts +306 -0
  1104. package/extensions/line/src/channel.ts +780 -0
  1105. package/extensions/line/src/runtime.ts +14 -0
  1106. package/extensions/llm-task/README.md +97 -0
  1107. package/extensions/llm-task/index.ts +6 -0
  1108. package/extensions/llm-task/node_modules/.bin/openclaw +21 -0
  1109. package/extensions/llm-task/openclaw.plugin.json +21 -0
  1110. package/extensions/llm-task/package.json +14 -0
  1111. package/extensions/llm-task/src/llm-task-tool.test.ts +138 -0
  1112. package/extensions/llm-task/src/llm-task-tool.ts +245 -0
  1113. package/extensions/lobster/README.md +75 -0
  1114. package/extensions/lobster/SKILL.md +97 -0
  1115. package/extensions/lobster/index.ts +14 -0
  1116. package/extensions/lobster/node_modules/.bin/openclaw +21 -0
  1117. package/extensions/lobster/openclaw.plugin.json +10 -0
  1118. package/extensions/lobster/package.json +14 -0
  1119. package/extensions/lobster/src/lobster-tool.test.ts +247 -0
  1120. package/extensions/lobster/src/lobster-tool.ts +328 -0
  1121. package/extensions/matrix/CHANGELOG.md +87 -0
  1122. package/extensions/matrix/index.ts +17 -0
  1123. package/extensions/matrix/node_modules/.bin/markdown-it +21 -0
  1124. package/extensions/matrix/node_modules/.bin/openclaw +21 -0
  1125. package/extensions/matrix/openclaw.plugin.json +9 -0
  1126. package/extensions/matrix/package.json +36 -0
  1127. package/extensions/matrix/src/actions.ts +195 -0
  1128. package/extensions/matrix/src/channel.directory.test.ts +64 -0
  1129. package/extensions/matrix/src/channel.ts +439 -0
  1130. package/extensions/matrix/src/config-schema.ts +62 -0
  1131. package/extensions/matrix/src/directory-live.ts +188 -0
  1132. package/extensions/matrix/src/group-mentions.ts +66 -0
  1133. package/extensions/matrix/src/matrix/accounts.test.ts +82 -0
  1134. package/extensions/matrix/src/matrix/accounts.ts +65 -0
  1135. package/extensions/matrix/src/matrix/actions/client.ts +57 -0
  1136. package/extensions/matrix/src/matrix/actions/messages.ts +128 -0
  1137. package/extensions/matrix/src/matrix/actions/pins.ts +76 -0
  1138. package/extensions/matrix/src/matrix/actions/reactions.ts +96 -0
  1139. package/extensions/matrix/src/matrix/actions/room.ts +85 -0
  1140. package/extensions/matrix/src/matrix/actions/summary.ts +75 -0
  1141. package/extensions/matrix/src/matrix/actions/types.ts +84 -0
  1142. package/extensions/matrix/src/matrix/actions.ts +15 -0
  1143. package/extensions/matrix/src/matrix/active-client.ts +11 -0
  1144. package/extensions/matrix/src/matrix/client/config.ts +160 -0
  1145. package/extensions/matrix/src/matrix/client/create-client.ts +123 -0
  1146. package/extensions/matrix/src/matrix/client/logging.ts +36 -0
  1147. package/extensions/matrix/src/matrix/client/runtime.ts +4 -0
  1148. package/extensions/matrix/src/matrix/client/shared.ts +170 -0
  1149. package/extensions/matrix/src/matrix/client/storage.ts +131 -0
  1150. package/extensions/matrix/src/matrix/client/types.ts +34 -0
  1151. package/extensions/matrix/src/matrix/client.test.ts +56 -0
  1152. package/extensions/matrix/src/matrix/client.ts +5 -0
  1153. package/extensions/matrix/src/matrix/credentials.ts +105 -0
  1154. package/extensions/matrix/src/matrix/deps.ts +60 -0
  1155. package/extensions/matrix/src/matrix/format.test.ts +33 -0
  1156. package/extensions/matrix/src/matrix/format.ts +22 -0
  1157. package/extensions/matrix/src/matrix/index.ts +11 -0
  1158. package/extensions/matrix/src/matrix/monitor/allowlist.test.ts +45 -0
  1159. package/extensions/matrix/src/matrix/monitor/allowlist.ts +103 -0
  1160. package/extensions/matrix/src/matrix/monitor/auto-join.ts +71 -0
  1161. package/extensions/matrix/src/matrix/monitor/direct.ts +104 -0
  1162. package/extensions/matrix/src/matrix/monitor/events.ts +101 -0
  1163. package/extensions/matrix/src/matrix/monitor/handler.ts +661 -0
  1164. package/extensions/matrix/src/matrix/monitor/index.ts +338 -0
  1165. package/extensions/matrix/src/matrix/monitor/location.ts +100 -0
  1166. package/extensions/matrix/src/matrix/monitor/media.test.ts +102 -0
  1167. package/extensions/matrix/src/matrix/monitor/media.ts +113 -0
  1168. package/extensions/matrix/src/matrix/monitor/mentions.ts +31 -0
  1169. package/extensions/matrix/src/matrix/monitor/replies.ts +97 -0
  1170. package/extensions/matrix/src/matrix/monitor/room-info.ts +55 -0
  1171. package/extensions/matrix/src/matrix/monitor/rooms.test.ts +39 -0
  1172. package/extensions/matrix/src/matrix/monitor/rooms.ts +47 -0
  1173. package/extensions/matrix/src/matrix/monitor/threads.ts +68 -0
  1174. package/extensions/matrix/src/matrix/monitor/types.ts +39 -0
  1175. package/extensions/matrix/src/matrix/poll-types.test.ts +21 -0
  1176. package/extensions/matrix/src/matrix/poll-types.ts +166 -0
  1177. package/extensions/matrix/src/matrix/probe.ts +70 -0
  1178. package/extensions/matrix/src/matrix/send/client.ts +66 -0
  1179. package/extensions/matrix/src/matrix/send/formatting.ts +89 -0
  1180. package/extensions/matrix/src/matrix/send/media.ts +229 -0
  1181. package/extensions/matrix/src/matrix/send/targets.test.ts +98 -0
  1182. package/extensions/matrix/src/matrix/send/targets.ts +136 -0
  1183. package/extensions/matrix/src/matrix/send/types.ts +109 -0
  1184. package/extensions/matrix/src/matrix/send.test.ts +171 -0
  1185. package/extensions/matrix/src/matrix/send.ts +260 -0
  1186. package/extensions/matrix/src/onboarding.ts +449 -0
  1187. package/extensions/matrix/src/outbound.ts +52 -0
  1188. package/extensions/matrix/src/resolve-targets.test.ts +48 -0
  1189. package/extensions/matrix/src/resolve-targets.ts +135 -0
  1190. package/extensions/matrix/src/runtime.ts +14 -0
  1191. package/extensions/matrix/src/tool-actions.ts +164 -0
  1192. package/extensions/matrix/src/types.ts +95 -0
  1193. package/extensions/mattermost/index.ts +17 -0
  1194. package/extensions/mattermost/node_modules/.bin/openclaw +21 -0
  1195. package/extensions/mattermost/openclaw.plugin.json +9 -0
  1196. package/extensions/mattermost/package.json +28 -0
  1197. package/extensions/mattermost/src/channel.test.ts +48 -0
  1198. package/extensions/mattermost/src/channel.ts +337 -0
  1199. package/extensions/mattermost/src/config-schema.ts +55 -0
  1200. package/extensions/mattermost/src/group-mentions.ts +15 -0
  1201. package/extensions/mattermost/src/mattermost/accounts.ts +128 -0
  1202. package/extensions/mattermost/src/mattermost/client.ts +220 -0
  1203. package/extensions/mattermost/src/mattermost/index.ts +9 -0
  1204. package/extensions/mattermost/src/mattermost/monitor-helpers.ts +166 -0
  1205. package/extensions/mattermost/src/mattermost/monitor.ts +987 -0
  1206. package/extensions/mattermost/src/mattermost/probe.ts +74 -0
  1207. package/extensions/mattermost/src/mattermost/send.ts +231 -0
  1208. package/extensions/mattermost/src/normalize.ts +46 -0
  1209. package/extensions/mattermost/src/onboarding-helpers.ts +44 -0
  1210. package/extensions/mattermost/src/onboarding.ts +186 -0
  1211. package/extensions/mattermost/src/runtime.ts +14 -0
  1212. package/extensions/mattermost/src/types.ts +50 -0
  1213. package/extensions/memory-core/index.ts +38 -0
  1214. package/extensions/memory-core/node_modules/.bin/openclaw +21 -0
  1215. package/extensions/memory-core/openclaw.plugin.json +9 -0
  1216. package/extensions/memory-core/package.json +17 -0
  1217. package/extensions/memory-lancedb/config.ts +139 -0
  1218. package/extensions/memory-lancedb/index.test.ts +295 -0
  1219. package/extensions/memory-lancedb/index.ts +608 -0
  1220. package/extensions/memory-lancedb/node_modules/.bin/openai +21 -0
  1221. package/extensions/memory-lancedb/node_modules/.bin/openclaw +21 -0
  1222. package/extensions/memory-lancedb/openclaw.plugin.json +60 -0
  1223. package/extensions/memory-lancedb/package.json +19 -0
  1224. package/extensions/minimax-portal-auth/README.md +33 -0
  1225. package/extensions/minimax-portal-auth/index.ts +155 -0
  1226. package/extensions/minimax-portal-auth/node_modules/.bin/openclaw +21 -0
  1227. package/extensions/minimax-portal-auth/oauth.ts +247 -0
  1228. package/extensions/minimax-portal-auth/openclaw.plugin.json +9 -0
  1229. package/extensions/minimax-portal-auth/package.json +14 -0
  1230. package/extensions/msteams/CHANGELOG.md +83 -0
  1231. package/extensions/msteams/index.ts +17 -0
  1232. package/extensions/msteams/node_modules/.bin/openclaw +21 -0
  1233. package/extensions/msteams/openclaw.plugin.json +9 -0
  1234. package/extensions/msteams/package.json +39 -0
  1235. package/extensions/msteams/src/attachments/download.ts +283 -0
  1236. package/extensions/msteams/src/attachments/graph.ts +353 -0
  1237. package/extensions/msteams/src/attachments/html.ts +90 -0
  1238. package/extensions/msteams/src/attachments/payload.ts +22 -0
  1239. package/extensions/msteams/src/attachments/shared.ts +291 -0
  1240. package/extensions/msteams/src/attachments/types.ts +37 -0
  1241. package/extensions/msteams/src/attachments.test.ts +459 -0
  1242. package/extensions/msteams/src/attachments.ts +18 -0
  1243. package/extensions/msteams/src/channel.directory.test.ts +48 -0
  1244. package/extensions/msteams/src/channel.ts +459 -0
  1245. package/extensions/msteams/src/conversation-store-fs.test.ts +88 -0
  1246. package/extensions/msteams/src/conversation-store-fs.ts +165 -0
  1247. package/extensions/msteams/src/conversation-store-memory.ts +47 -0
  1248. package/extensions/msteams/src/conversation-store.ts +41 -0
  1249. package/extensions/msteams/src/directory-live.ts +205 -0
  1250. package/extensions/msteams/src/errors.test.ts +45 -0
  1251. package/extensions/msteams/src/errors.ts +190 -0
  1252. package/extensions/msteams/src/file-consent-helpers.test.ts +243 -0
  1253. package/extensions/msteams/src/file-consent-helpers.ts +73 -0
  1254. package/extensions/msteams/src/file-consent.ts +126 -0
  1255. package/extensions/msteams/src/graph-chat.ts +53 -0
  1256. package/extensions/msteams/src/graph-upload.ts +453 -0
  1257. package/extensions/msteams/src/inbound.test.ts +66 -0
  1258. package/extensions/msteams/src/inbound.ts +48 -0
  1259. package/extensions/msteams/src/index.ts +4 -0
  1260. package/extensions/msteams/src/media-helpers.test.ts +189 -0
  1261. package/extensions/msteams/src/media-helpers.ts +86 -0
  1262. package/extensions/msteams/src/messenger.test.ts +248 -0
  1263. package/extensions/msteams/src/messenger.ts +495 -0
  1264. package/extensions/msteams/src/monitor-handler/inbound-media.ts +128 -0
  1265. package/extensions/msteams/src/monitor-handler/message-handler.ts +640 -0
  1266. package/extensions/msteams/src/monitor-handler.ts +162 -0
  1267. package/extensions/msteams/src/monitor-types.ts +5 -0
  1268. package/extensions/msteams/src/monitor.ts +295 -0
  1269. package/extensions/msteams/src/onboarding.ts +431 -0
  1270. package/extensions/msteams/src/outbound.ts +46 -0
  1271. package/extensions/msteams/src/pending-uploads.ts +89 -0
  1272. package/extensions/msteams/src/policy.test.ts +209 -0
  1273. package/extensions/msteams/src/policy.ts +273 -0
  1274. package/extensions/msteams/src/polls-store-memory.ts +32 -0
  1275. package/extensions/msteams/src/polls-store.test.ts +38 -0
  1276. package/extensions/msteams/src/polls.test.ts +72 -0
  1277. package/extensions/msteams/src/polls.ts +315 -0
  1278. package/extensions/msteams/src/probe.test.ts +58 -0
  1279. package/extensions/msteams/src/probe.ts +107 -0
  1280. package/extensions/msteams/src/reply-dispatcher.ts +130 -0
  1281. package/extensions/msteams/src/resolve-allowlist.ts +297 -0
  1282. package/extensions/msteams/src/runtime.ts +14 -0
  1283. package/extensions/msteams/src/sdk-types.ts +19 -0
  1284. package/extensions/msteams/src/sdk.ts +33 -0
  1285. package/extensions/msteams/src/send-context.ts +164 -0
  1286. package/extensions/msteams/src/send.ts +519 -0
  1287. package/extensions/msteams/src/sent-message-cache.test.ts +15 -0
  1288. package/extensions/msteams/src/sent-message-cache.ts +47 -0
  1289. package/extensions/msteams/src/storage.ts +25 -0
  1290. package/extensions/msteams/src/store-fs.ts +83 -0
  1291. package/extensions/msteams/src/token.ts +19 -0
  1292. package/extensions/nextcloud-talk/index.ts +17 -0
  1293. package/extensions/nextcloud-talk/node_modules/.bin/openclaw +21 -0
  1294. package/extensions/nextcloud-talk/openclaw.plugin.json +9 -0
  1295. package/extensions/nextcloud-talk/package.json +33 -0
  1296. package/extensions/nextcloud-talk/src/accounts.ts +174 -0
  1297. package/extensions/nextcloud-talk/src/channel.ts +409 -0
  1298. package/extensions/nextcloud-talk/src/config-schema.ts +78 -0
  1299. package/extensions/nextcloud-talk/src/format.ts +79 -0
  1300. package/extensions/nextcloud-talk/src/inbound.ts +317 -0
  1301. package/extensions/nextcloud-talk/src/monitor.ts +246 -0
  1302. package/extensions/nextcloud-talk/src/normalize.ts +39 -0
  1303. package/extensions/nextcloud-talk/src/onboarding.ts +343 -0
  1304. package/extensions/nextcloud-talk/src/policy.test.ts +33 -0
  1305. package/extensions/nextcloud-talk/src/policy.ts +180 -0
  1306. package/extensions/nextcloud-talk/src/room-info.ts +125 -0
  1307. package/extensions/nextcloud-talk/src/runtime.ts +14 -0
  1308. package/extensions/nextcloud-talk/src/send.ts +210 -0
  1309. package/extensions/nextcloud-talk/src/signature.ts +72 -0
  1310. package/extensions/nextcloud-talk/src/types.ts +179 -0
  1311. package/extensions/nostr/CHANGELOG.md +74 -0
  1312. package/extensions/nostr/README.md +136 -0
  1313. package/extensions/nostr/index.ts +68 -0
  1314. package/extensions/nostr/node_modules/.bin/openclaw +21 -0
  1315. package/extensions/nostr/openclaw.plugin.json +9 -0
  1316. package/extensions/nostr/package.json +34 -0
  1317. package/extensions/nostr/src/channel.test.ts +151 -0
  1318. package/extensions/nostr/src/channel.ts +353 -0
  1319. package/extensions/nostr/src/config-schema.ts +90 -0
  1320. package/extensions/nostr/src/metrics.ts +478 -0
  1321. package/extensions/nostr/src/nostr-bus.fuzz.test.ts +533 -0
  1322. package/extensions/nostr/src/nostr-bus.integration.test.ts +448 -0
  1323. package/extensions/nostr/src/nostr-bus.test.ts +199 -0
  1324. package/extensions/nostr/src/nostr-bus.ts +715 -0
  1325. package/extensions/nostr/src/nostr-profile-http.test.ts +378 -0
  1326. package/extensions/nostr/src/nostr-profile-http.ts +519 -0
  1327. package/extensions/nostr/src/nostr-profile-import.test.ts +119 -0
  1328. package/extensions/nostr/src/nostr-profile-import.ts +262 -0
  1329. package/extensions/nostr/src/nostr-profile.fuzz.test.ts +477 -0
  1330. package/extensions/nostr/src/nostr-profile.test.ts +410 -0
  1331. package/extensions/nostr/src/nostr-profile.ts +277 -0
  1332. package/extensions/nostr/src/nostr-state-store.test.ts +131 -0
  1333. package/extensions/nostr/src/nostr-state-store.ts +226 -0
  1334. package/extensions/nostr/src/runtime.ts +14 -0
  1335. package/extensions/nostr/src/seen-tracker.ts +303 -0
  1336. package/extensions/nostr/src/types.test.ts +157 -0
  1337. package/extensions/nostr/src/types.ts +101 -0
  1338. package/extensions/nostr/test/setup.ts +5 -0
  1339. package/extensions/open-prose/README.md +25 -0
  1340. package/extensions/open-prose/index.ts +5 -0
  1341. package/extensions/open-prose/node_modules/.bin/openclaw +21 -0
  1342. package/extensions/open-prose/openclaw.plugin.json +11 -0
  1343. package/extensions/open-prose/package.json +14 -0
  1344. package/extensions/open-prose/skills/prose/LICENSE +21 -0
  1345. package/extensions/open-prose/skills/prose/SKILL.md +323 -0
  1346. package/extensions/open-prose/skills/prose/alt-borges.md +141 -0
  1347. package/extensions/open-prose/skills/prose/alts/arabian-nights.md +358 -0
  1348. package/extensions/open-prose/skills/prose/alts/borges.md +360 -0
  1349. package/extensions/open-prose/skills/prose/alts/folk.md +322 -0
  1350. package/extensions/open-prose/skills/prose/alts/homer.md +346 -0
  1351. package/extensions/open-prose/skills/prose/alts/kafka.md +373 -0
  1352. package/extensions/open-prose/skills/prose/compiler.md +2971 -0
  1353. package/extensions/open-prose/skills/prose/examples/01-hello-world.prose +4 -0
  1354. package/extensions/open-prose/skills/prose/examples/02-research-and-summarize.prose +6 -0
  1355. package/extensions/open-prose/skills/prose/examples/03-code-review.prose +17 -0
  1356. package/extensions/open-prose/skills/prose/examples/04-write-and-refine.prose +14 -0
  1357. package/extensions/open-prose/skills/prose/examples/05-debug-issue.prose +20 -0
  1358. package/extensions/open-prose/skills/prose/examples/06-explain-codebase.prose +17 -0
  1359. package/extensions/open-prose/skills/prose/examples/07-refactor.prose +20 -0
  1360. package/extensions/open-prose/skills/prose/examples/08-blog-post.prose +20 -0
  1361. package/extensions/open-prose/skills/prose/examples/09-research-with-agents.prose +25 -0
  1362. package/extensions/open-prose/skills/prose/examples/10-code-review-agents.prose +32 -0
  1363. package/extensions/open-prose/skills/prose/examples/11-skills-and-imports.prose +27 -0
  1364. package/extensions/open-prose/skills/prose/examples/12-secure-agent-permissions.prose +43 -0
  1365. package/extensions/open-prose/skills/prose/examples/13-variables-and-context.prose +51 -0
  1366. package/extensions/open-prose/skills/prose/examples/14-composition-blocks.prose +48 -0
  1367. package/extensions/open-prose/skills/prose/examples/15-inline-sequences.prose +23 -0
  1368. package/extensions/open-prose/skills/prose/examples/16-parallel-reviews.prose +19 -0
  1369. package/extensions/open-prose/skills/prose/examples/17-parallel-research.prose +19 -0
  1370. package/extensions/open-prose/skills/prose/examples/18-mixed-parallel-sequential.prose +36 -0
  1371. package/extensions/open-prose/skills/prose/examples/19-advanced-parallel.prose +71 -0
  1372. package/extensions/open-prose/skills/prose/examples/20-fixed-loops.prose +20 -0
  1373. package/extensions/open-prose/skills/prose/examples/21-pipeline-operations.prose +35 -0
  1374. package/extensions/open-prose/skills/prose/examples/22-error-handling.prose +51 -0
  1375. package/extensions/open-prose/skills/prose/examples/23-retry-with-backoff.prose +63 -0
  1376. package/extensions/open-prose/skills/prose/examples/24-choice-blocks.prose +86 -0
  1377. package/extensions/open-prose/skills/prose/examples/25-conditionals.prose +114 -0
  1378. package/extensions/open-prose/skills/prose/examples/26-parameterized-blocks.prose +100 -0
  1379. package/extensions/open-prose/skills/prose/examples/27-string-interpolation.prose +105 -0
  1380. package/extensions/open-prose/skills/prose/examples/28-automated-pr-review.prose +37 -0
  1381. package/extensions/open-prose/skills/prose/examples/28-gas-town.prose +1572 -0
  1382. package/extensions/open-prose/skills/prose/examples/29-captains-chair.prose +218 -0
  1383. package/extensions/open-prose/skills/prose/examples/30-captains-chair-simple.prose +42 -0
  1384. package/extensions/open-prose/skills/prose/examples/31-captains-chair-with-memory.prose +145 -0
  1385. package/extensions/open-prose/skills/prose/examples/33-pr-review-autofix.prose +168 -0
  1386. package/extensions/open-prose/skills/prose/examples/34-content-pipeline.prose +204 -0
  1387. package/extensions/open-prose/skills/prose/examples/35-feature-factory.prose +296 -0
  1388. package/extensions/open-prose/skills/prose/examples/36-bug-hunter.prose +237 -0
  1389. package/extensions/open-prose/skills/prose/examples/37-the-forge.prose +1474 -0
  1390. package/extensions/open-prose/skills/prose/examples/38-skill-scan.prose +455 -0
  1391. package/extensions/open-prose/skills/prose/examples/39-architect-by-simulation.prose +277 -0
  1392. package/extensions/open-prose/skills/prose/examples/40-rlm-self-refine.prose +32 -0
  1393. package/extensions/open-prose/skills/prose/examples/41-rlm-divide-conquer.prose +38 -0
  1394. package/extensions/open-prose/skills/prose/examples/42-rlm-filter-recurse.prose +46 -0
  1395. package/extensions/open-prose/skills/prose/examples/43-rlm-pairwise.prose +50 -0
  1396. package/extensions/open-prose/skills/prose/examples/44-run-endpoint-ux-test.prose +261 -0
  1397. package/extensions/open-prose/skills/prose/examples/45-plugin-release.prose +159 -0
  1398. package/extensions/open-prose/skills/prose/examples/45-run-endpoint-ux-test-with-remediation.prose +637 -0
  1399. package/extensions/open-prose/skills/prose/examples/46-run-endpoint-ux-test-fast.prose +148 -0
  1400. package/extensions/open-prose/skills/prose/examples/46-workflow-crystallizer.prose +225 -0
  1401. package/extensions/open-prose/skills/prose/examples/47-language-self-improvement.prose +356 -0
  1402. package/extensions/open-prose/skills/prose/examples/48-habit-miner.prose +445 -0
  1403. package/extensions/open-prose/skills/prose/examples/49-prose-run-retrospective.prose +210 -0
  1404. package/extensions/open-prose/skills/prose/examples/README.md +391 -0
  1405. package/extensions/open-prose/skills/prose/examples/roadmap/README.md +22 -0
  1406. package/extensions/open-prose/skills/prose/examples/roadmap/iterative-refinement.prose +20 -0
  1407. package/extensions/open-prose/skills/prose/examples/roadmap/parallel-review.prose +18 -0
  1408. package/extensions/open-prose/skills/prose/examples/roadmap/simple-pipeline.prose +17 -0
  1409. package/extensions/open-prose/skills/prose/examples/roadmap/syntax/open-prose-syntax.prose +223 -0
  1410. package/extensions/open-prose/skills/prose/guidance/antipatterns.md +951 -0
  1411. package/extensions/open-prose/skills/prose/guidance/patterns.md +700 -0
  1412. package/extensions/open-prose/skills/prose/guidance/system-prompt.md +180 -0
  1413. package/extensions/open-prose/skills/prose/help.md +144 -0
  1414. package/extensions/open-prose/skills/prose/lib/README.md +108 -0
  1415. package/extensions/open-prose/skills/prose/lib/calibrator.prose +215 -0
  1416. package/extensions/open-prose/skills/prose/lib/cost-analyzer.prose +174 -0
  1417. package/extensions/open-prose/skills/prose/lib/error-forensics.prose +250 -0
  1418. package/extensions/open-prose/skills/prose/lib/inspector.prose +196 -0
  1419. package/extensions/open-prose/skills/prose/lib/profiler.prose +460 -0
  1420. package/extensions/open-prose/skills/prose/lib/program-improver.prose +275 -0
  1421. package/extensions/open-prose/skills/prose/lib/project-memory.prose +118 -0
  1422. package/extensions/open-prose/skills/prose/lib/user-memory.prose +93 -0
  1423. package/extensions/open-prose/skills/prose/lib/vm-improver.prose +243 -0
  1424. package/extensions/open-prose/skills/prose/primitives/session.md +593 -0
  1425. package/extensions/open-prose/skills/prose/prose.md +1237 -0
  1426. package/extensions/open-prose/skills/prose/state/filesystem.md +498 -0
  1427. package/extensions/open-prose/skills/prose/state/in-context.md +384 -0
  1428. package/extensions/open-prose/skills/prose/state/postgres.md +880 -0
  1429. package/extensions/open-prose/skills/prose/state/sqlite.md +574 -0
  1430. package/extensions/qwen-portal-auth/README.md +24 -0
  1431. package/extensions/qwen-portal-auth/index.ts +130 -0
  1432. package/extensions/qwen-portal-auth/oauth.ts +190 -0
  1433. package/extensions/qwen-portal-auth/openclaw.plugin.json +9 -0
  1434. package/extensions/signal/index.ts +17 -0
  1435. package/extensions/signal/node_modules/.bin/openclaw +21 -0
  1436. package/extensions/signal/openclaw.plugin.json +9 -0
  1437. package/extensions/signal/package.json +14 -0
  1438. package/extensions/signal/src/channel.ts +315 -0
  1439. package/extensions/signal/src/runtime.ts +14 -0
  1440. package/extensions/slack/index.ts +17 -0
  1441. package/extensions/slack/node_modules/.bin/openclaw +21 -0
  1442. package/extensions/slack/openclaw.plugin.json +9 -0
  1443. package/extensions/slack/package.json +14 -0
  1444. package/extensions/slack/src/channel.ts +604 -0
  1445. package/extensions/slack/src/runtime.ts +14 -0
  1446. package/extensions/telegram/index.ts +17 -0
  1447. package/extensions/telegram/node_modules/.bin/openclaw +21 -0
  1448. package/extensions/telegram/openclaw.plugin.json +9 -0
  1449. package/extensions/telegram/package.json +14 -0
  1450. package/extensions/telegram/src/channel.ts +482 -0
  1451. package/extensions/telegram/src/runtime.ts +14 -0
  1452. package/extensions/tlon/README.md +5 -0
  1453. package/extensions/tlon/index.ts +17 -0
  1454. package/extensions/tlon/node_modules/.bin/openclaw +21 -0
  1455. package/extensions/tlon/openclaw.plugin.json +9 -0
  1456. package/extensions/tlon/package.json +33 -0
  1457. package/extensions/tlon/src/channel.ts +392 -0
  1458. package/extensions/tlon/src/config-schema.test.ts +31 -0
  1459. package/extensions/tlon/src/config-schema.ts +43 -0
  1460. package/extensions/tlon/src/monitor/discovery.ts +76 -0
  1461. package/extensions/tlon/src/monitor/history.ts +90 -0
  1462. package/extensions/tlon/src/monitor/index.ts +553 -0
  1463. package/extensions/tlon/src/monitor/processed-messages.test.ts +23 -0
  1464. package/extensions/tlon/src/monitor/processed-messages.ts +46 -0
  1465. package/extensions/tlon/src/monitor/utils.ts +105 -0
  1466. package/extensions/tlon/src/onboarding.ts +214 -0
  1467. package/extensions/tlon/src/runtime.ts +14 -0
  1468. package/extensions/tlon/src/targets.ts +89 -0
  1469. package/extensions/tlon/src/types.ts +92 -0
  1470. package/extensions/tlon/src/urbit/auth.ts +18 -0
  1471. package/extensions/tlon/src/urbit/http-api.ts +38 -0
  1472. package/extensions/tlon/src/urbit/send.test.ts +38 -0
  1473. package/extensions/tlon/src/urbit/send.ts +131 -0
  1474. package/extensions/tlon/src/urbit/sse-client.test.ts +40 -0
  1475. package/extensions/tlon/src/urbit/sse-client.ts +395 -0
  1476. package/extensions/twitch/CHANGELOG.md +45 -0
  1477. package/extensions/twitch/README.md +89 -0
  1478. package/extensions/twitch/index.ts +20 -0
  1479. package/extensions/twitch/node_modules/.bin/openclaw +21 -0
  1480. package/extensions/twitch/openclaw.plugin.json +9 -0
  1481. package/extensions/twitch/package.json +20 -0
  1482. package/extensions/twitch/src/access-control.test.ts +489 -0
  1483. package/extensions/twitch/src/access-control.ts +166 -0
  1484. package/extensions/twitch/src/actions.ts +173 -0
  1485. package/extensions/twitch/src/client-manager-registry.ts +115 -0
  1486. package/extensions/twitch/src/config-schema.ts +82 -0
  1487. package/extensions/twitch/src/config.test.ts +87 -0
  1488. package/extensions/twitch/src/config.ts +116 -0
  1489. package/extensions/twitch/src/monitor.ts +261 -0
  1490. package/extensions/twitch/src/onboarding.test.ts +311 -0
  1491. package/extensions/twitch/src/onboarding.ts +417 -0
  1492. package/extensions/twitch/src/outbound.test.ts +373 -0
  1493. package/extensions/twitch/src/outbound.ts +184 -0
  1494. package/extensions/twitch/src/plugin.test.ts +39 -0
  1495. package/extensions/twitch/src/plugin.ts +274 -0
  1496. package/extensions/twitch/src/probe.test.ts +195 -0
  1497. package/extensions/twitch/src/probe.ts +120 -0
  1498. package/extensions/twitch/src/resolver.ts +137 -0
  1499. package/extensions/twitch/src/runtime.ts +14 -0
  1500. package/extensions/twitch/src/send.test.ts +289 -0
  1501. package/extensions/twitch/src/send.ts +136 -0
  1502. package/extensions/twitch/src/status.test.ts +270 -0
  1503. package/extensions/twitch/src/status.ts +178 -0
  1504. package/extensions/twitch/src/token.test.ts +171 -0
  1505. package/extensions/twitch/src/token.ts +91 -0
  1506. package/extensions/twitch/src/twitch-client.test.ts +589 -0
  1507. package/extensions/twitch/src/twitch-client.ts +277 -0
  1508. package/extensions/twitch/src/types.ts +141 -0
  1509. package/extensions/twitch/src/utils/markdown.ts +98 -0
  1510. package/extensions/twitch/src/utils/twitch.ts +78 -0
  1511. package/extensions/twitch/test/setup.ts +7 -0
  1512. package/extensions/voice-call/CHANGELOG.md +109 -0
  1513. package/extensions/voice-call/README.md +139 -0
  1514. package/extensions/voice-call/index.ts +493 -0
  1515. package/extensions/voice-call/node_modules/.bin/openclaw +21 -0
  1516. package/extensions/voice-call/openclaw.plugin.json +559 -0
  1517. package/extensions/voice-call/package.json +19 -0
  1518. package/extensions/voice-call/src/allowlist.ts +19 -0
  1519. package/extensions/voice-call/src/cli.ts +279 -0
  1520. package/extensions/voice-call/src/config.test.ts +234 -0
  1521. package/extensions/voice-call/src/config.ts +523 -0
  1522. package/extensions/voice-call/src/core-bridge.ts +159 -0
  1523. package/extensions/voice-call/src/manager/context.ts +21 -0
  1524. package/extensions/voice-call/src/manager/events.ts +188 -0
  1525. package/extensions/voice-call/src/manager/lookup.ts +35 -0
  1526. package/extensions/voice-call/src/manager/outbound.ts +275 -0
  1527. package/extensions/voice-call/src/manager/state.ts +48 -0
  1528. package/extensions/voice-call/src/manager/store.ts +91 -0
  1529. package/extensions/voice-call/src/manager/timers.ts +89 -0
  1530. package/extensions/voice-call/src/manager/twiml.ts +9 -0
  1531. package/extensions/voice-call/src/manager.test.ts +194 -0
  1532. package/extensions/voice-call/src/manager.ts +887 -0
  1533. package/extensions/voice-call/src/media-stream.test.ts +96 -0
  1534. package/extensions/voice-call/src/media-stream.ts +411 -0
  1535. package/extensions/voice-call/src/providers/base.ts +67 -0
  1536. package/extensions/voice-call/src/providers/index.ts +10 -0
  1537. package/extensions/voice-call/src/providers/mock.ts +165 -0
  1538. package/extensions/voice-call/src/providers/plivo.test.ts +27 -0
  1539. package/extensions/voice-call/src/providers/plivo.ts +515 -0
  1540. package/extensions/voice-call/src/providers/stt-openai-realtime.ts +311 -0
  1541. package/extensions/voice-call/src/providers/telnyx.ts +371 -0
  1542. package/extensions/voice-call/src/providers/tts-openai.ts +259 -0
  1543. package/extensions/voice-call/src/providers/twilio/api.ts +42 -0
  1544. package/extensions/voice-call/src/providers/twilio/webhook.ts +32 -0
  1545. package/extensions/voice-call/src/providers/twilio.test.ts +60 -0
  1546. package/extensions/voice-call/src/providers/twilio.ts +626 -0
  1547. package/extensions/voice-call/src/response-generator.ts +158 -0
  1548. package/extensions/voice-call/src/runtime.ts +212 -0
  1549. package/extensions/voice-call/src/telephony-audio.ts +90 -0
  1550. package/extensions/voice-call/src/telephony-tts.ts +104 -0
  1551. package/extensions/voice-call/src/tunnel.ts +314 -0
  1552. package/extensions/voice-call/src/types.ts +272 -0
  1553. package/extensions/voice-call/src/utils.ts +14 -0
  1554. package/extensions/voice-call/src/voice-mapping.ts +67 -0
  1555. package/extensions/voice-call/src/webhook-security.test.ts +377 -0
  1556. package/extensions/voice-call/src/webhook-security.ts +689 -0
  1557. package/extensions/voice-call/src/webhook.ts +491 -0
  1558. package/extensions/whatsapp/index.ts +17 -0
  1559. package/extensions/whatsapp/node_modules/.bin/openclaw +21 -0
  1560. package/extensions/whatsapp/openclaw.plugin.json +9 -0
  1561. package/extensions/whatsapp/package.json +14 -0
  1562. package/extensions/whatsapp/src/channel.ts +508 -0
  1563. package/extensions/whatsapp/src/runtime.ts +14 -0
  1564. package/extensions/zalo/CHANGELOG.md +89 -0
  1565. package/extensions/zalo/README.md +50 -0
  1566. package/extensions/zalo/index.ts +19 -0
  1567. package/extensions/zalo/node_modules/.bin/openclaw +21 -0
  1568. package/extensions/zalo/openclaw.plugin.json +9 -0
  1569. package/extensions/zalo/package.json +36 -0
  1570. package/extensions/zalo/src/accounts.ts +80 -0
  1571. package/extensions/zalo/src/actions.ts +67 -0
  1572. package/extensions/zalo/src/api.ts +208 -0
  1573. package/extensions/zalo/src/channel.directory.test.ts +43 -0
  1574. package/extensions/zalo/src/channel.ts +414 -0
  1575. package/extensions/zalo/src/config-schema.ts +24 -0
  1576. package/extensions/zalo/src/monitor.ts +753 -0
  1577. package/extensions/zalo/src/monitor.webhook.test.ts +73 -0
  1578. package/extensions/zalo/src/onboarding.ts +401 -0
  1579. package/extensions/zalo/src/probe.ts +46 -0
  1580. package/extensions/zalo/src/proxy.ts +21 -0
  1581. package/extensions/zalo/src/runtime.ts +14 -0
  1582. package/extensions/zalo/src/send.ts +124 -0
  1583. package/extensions/zalo/src/status-issues.ts +53 -0
  1584. package/extensions/zalo/src/token.ts +63 -0
  1585. package/extensions/zalo/src/types.ts +42 -0
  1586. package/extensions/zalouser/CHANGELOG.md +61 -0
  1587. package/extensions/zalouser/README.md +225 -0
  1588. package/extensions/zalouser/index.ts +31 -0
  1589. package/extensions/zalouser/node_modules/.bin/openclaw +21 -0
  1590. package/extensions/zalouser/openclaw.plugin.json +9 -0
  1591. package/extensions/zalouser/package.json +36 -0
  1592. package/extensions/zalouser/src/accounts.ts +135 -0
  1593. package/extensions/zalouser/src/channel.test.ts +18 -0
  1594. package/extensions/zalouser/src/channel.ts +686 -0
  1595. package/extensions/zalouser/src/config-schema.ts +27 -0
  1596. package/extensions/zalouser/src/monitor.ts +590 -0
  1597. package/extensions/zalouser/src/onboarding.ts +504 -0
  1598. package/extensions/zalouser/src/probe.ts +28 -0
  1599. package/extensions/zalouser/src/runtime.ts +14 -0
  1600. package/extensions/zalouser/src/send.ts +160 -0
  1601. package/extensions/zalouser/src/status-issues.test.ts +57 -0
  1602. package/extensions/zalouser/src/status-issues.ts +89 -0
  1603. package/extensions/zalouser/src/tool.ts +164 -0
  1604. package/extensions/zalouser/src/types.ts +108 -0
  1605. package/extensions/zalouser/src/zca.ts +202 -0
  1606. package/openclaw.mjs +14 -0
  1607. package/package.json +245 -0
  1608. package/skills/1password/SKILL.md +70 -0
  1609. package/skills/1password/references/cli-examples.md +29 -0
  1610. package/skills/1password/references/get-started.md +17 -0
  1611. package/skills/apple-notes/SKILL.md +77 -0
  1612. package/skills/apple-reminders/SKILL.md +96 -0
  1613. package/skills/bear-notes/SKILL.md +107 -0
  1614. package/skills/bird/SKILL.md +224 -0
  1615. package/skills/blogwatcher/SKILL.md +69 -0
  1616. package/skills/blucli/SKILL.md +47 -0
  1617. package/skills/bluebubbles/SKILL.md +131 -0
  1618. package/skills/camsnap/SKILL.md +45 -0
  1619. package/skills/canvas/SKILL.md +198 -0
  1620. package/skills/clawhub/SKILL.md +77 -0
  1621. package/skills/coding-agent/SKILL.md +284 -0
  1622. package/skills/discord/SKILL.md +578 -0
  1623. package/skills/eightctl/SKILL.md +50 -0
  1624. package/skills/food-order/SKILL.md +48 -0
  1625. package/skills/gemini/SKILL.md +43 -0
  1626. package/skills/ghostly-projects/SKILL.md +160 -0
  1627. package/skills/gifgrep/SKILL.md +79 -0
  1628. package/skills/github/SKILL.md +77 -0
  1629. package/skills/gog/SKILL.md +116 -0
  1630. package/skills/goplaces/SKILL.md +52 -0
  1631. package/skills/healthcheck/SKILL.md +245 -0
  1632. package/skills/himalaya/SKILL.md +257 -0
  1633. package/skills/himalaya/references/configuration.md +184 -0
  1634. package/skills/himalaya/references/message-composition.md +199 -0
  1635. package/skills/imsg/SKILL.md +74 -0
  1636. package/skills/linear/SKILL.md +111 -0
  1637. package/skills/linear/linear.sh +204 -0
  1638. package/skills/local-places/SERVER_README.md +101 -0
  1639. package/skills/local-places/SKILL.md +102 -0
  1640. package/skills/local-places/pyproject.toml +21 -0
  1641. package/skills/local-places/src/local_places/__init__.py +2 -0
  1642. package/skills/local-places/src/local_places/google_places.py +314 -0
  1643. package/skills/local-places/src/local_places/main.py +65 -0
  1644. package/skills/local-places/src/local_places/schemas.py +107 -0
  1645. package/skills/mcporter/SKILL.md +61 -0
  1646. package/skills/model-usage/SKILL.md +69 -0
  1647. package/skills/model-usage/references/codexbar-cli.md +33 -0
  1648. package/skills/model-usage/scripts/model_usage.py +310 -0
  1649. package/skills/nano-banana-pro/SKILL.md +58 -0
  1650. package/skills/nano-banana-pro/scripts/generate_image.py +184 -0
  1651. package/skills/nano-pdf/SKILL.md +38 -0
  1652. package/skills/notion/SKILL.md +172 -0
  1653. package/skills/obsidian/SKILL.md +81 -0
  1654. package/skills/openai-image-gen/SKILL.md +89 -0
  1655. package/skills/openai-image-gen/scripts/gen.py +240 -0
  1656. package/skills/openai-whisper/SKILL.md +38 -0
  1657. package/skills/openai-whisper-api/SKILL.md +52 -0
  1658. package/skills/openai-whisper-api/scripts/transcribe.sh +85 -0
  1659. package/skills/openhue/SKILL.md +51 -0
  1660. package/skills/oracle/SKILL.md +125 -0
  1661. package/skills/ordercli/SKILL.md +78 -0
  1662. package/skills/peekaboo/SKILL.md +190 -0
  1663. package/skills/sag/SKILL.md +87 -0
  1664. package/skills/session-logs/SKILL.md +115 -0
  1665. package/skills/sherpa-onnx-tts/SKILL.md +103 -0
  1666. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  1667. package/skills/skill-creator/SKILL.md +370 -0
  1668. package/skills/skill-creator/license.txt +202 -0
  1669. package/skills/skill-creator/scripts/init_skill.py +378 -0
  1670. package/skills/skill-creator/scripts/package_skill.py +111 -0
  1671. package/skills/skill-creator/scripts/quick_validate.py +101 -0
  1672. package/skills/slack/SKILL.md +144 -0
  1673. package/skills/songsee/SKILL.md +49 -0
  1674. package/skills/sonoscli/SKILL.md +46 -0
  1675. package/skills/spotify-player/SKILL.md +64 -0
  1676. package/skills/summarize/SKILL.md +87 -0
  1677. package/skills/things-mac/SKILL.md +86 -0
  1678. package/skills/tmux/SKILL.md +135 -0
  1679. package/skills/tmux/scripts/find-sessions.sh +112 -0
  1680. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  1681. package/skills/trello/SKILL.md +95 -0
  1682. package/skills/video-frames/SKILL.md +46 -0
  1683. package/skills/video-frames/scripts/frame.sh +81 -0
  1684. package/skills/voice-call/SKILL.md +45 -0
  1685. package/skills/wacli/SKILL.md +72 -0
  1686. package/skills/weather/SKILL.md +54 -0
@@ -0,0 +1,1952 @@
1
+ import { o as createSubsystemLogger } from "./entry.js";
2
+ import { t as formatCliCommand } from "./command-format-ayFsmwwz.js";
3
+ import { t as CONFIG_DIR } from "./utils-DX85MiPR.js";
4
+ import { t as runCommandWithTimeout } from "./exec-B8JKbXKW.js";
5
+ import { t as rawDataToString } from "./ws-3zr8WUwL.js";
6
+ import { execFileSync, spawn } from "node:child_process";
7
+ import path from "node:path";
8
+ import os from "node:os";
9
+ import fs from "node:fs";
10
+ import fs$1 from "node:fs/promises";
11
+ import { randomBytes } from "node:crypto";
12
+ import { createServer } from "node:http";
13
+ import WebSocket, { WebSocketServer } from "ws";
14
+ import net from "node:net";
15
+
16
+ //#region src/browser/constants.ts
17
+ const DEFAULT_OPENCLAW_BROWSER_ENABLED = true;
18
+ const DEFAULT_BROWSER_EVALUATE_ENABLED = true;
19
+ const DEFAULT_OPENCLAW_BROWSER_COLOR = "#FF4500";
20
+ const DEFAULT_OPENCLAW_BROWSER_PROFILE_NAME = "openclaw";
21
+ const DEFAULT_BROWSER_DEFAULT_PROFILE_NAME = "chrome";
22
+ const DEFAULT_AI_SNAPSHOT_MAX_CHARS = 8e4;
23
+ const DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS = 1e4;
24
+ const DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH = 6;
25
+
26
+ //#endregion
27
+ //#region src/browser/extension-relay.ts
28
+ const RELAY_AUTH_HEADER = "x-openclaw-relay-token";
29
+ function headerValue(value) {
30
+ if (!value) return;
31
+ if (Array.isArray(value)) return value[0];
32
+ return value;
33
+ }
34
+ function getHeader(req, name) {
35
+ return headerValue(req.headers[name.toLowerCase()]);
36
+ }
37
+ function isLoopbackHost$1(host) {
38
+ const h = host.trim().toLowerCase();
39
+ return h === "localhost" || h === "127.0.0.1" || h === "0.0.0.0" || h === "[::1]" || h === "::1" || h === "[::]" || h === "::";
40
+ }
41
+ function isLoopbackAddress(ip) {
42
+ if (!ip) return false;
43
+ if (ip === "127.0.0.1") return true;
44
+ if (ip.startsWith("127.")) return true;
45
+ if (ip === "::1") return true;
46
+ if (ip.startsWith("::ffff:127.")) return true;
47
+ return false;
48
+ }
49
+ function parseBaseUrl(raw) {
50
+ const parsed = new URL(raw.trim().replace(/\/$/, ""));
51
+ if (parsed.protocol !== "http:" && parsed.protocol !== "https:") throw new Error(`extension relay cdpUrl must be http(s), got ${parsed.protocol}`);
52
+ const host = parsed.hostname;
53
+ const port = parsed.port?.trim() !== "" ? Number(parsed.port) : parsed.protocol === "https:" ? 443 : 80;
54
+ if (!Number.isFinite(port) || port <= 0 || port > 65535) throw new Error(`extension relay cdpUrl has invalid port: ${parsed.port || "(empty)"}`);
55
+ return {
56
+ host,
57
+ port,
58
+ baseUrl: parsed.toString().replace(/\/$/, "")
59
+ };
60
+ }
61
+ function text(res, status, bodyText) {
62
+ const body = Buffer.from(bodyText);
63
+ res.write(`HTTP/1.1 ${status} ${status === 200 ? "OK" : "ERR"}\r\nContent-Type: text/plain; charset=utf-8\r
64
+ Content-Length: ${body.length}\r\nConnection: close\r
65
+ \r
66
+ `);
67
+ res.write(body);
68
+ res.end();
69
+ }
70
+ function rejectUpgrade(socket, status, bodyText) {
71
+ text(socket, status, bodyText);
72
+ try {
73
+ socket.destroy();
74
+ } catch {}
75
+ }
76
+ const serversByPort = /* @__PURE__ */ new Map();
77
+ const relayAuthByPort = /* @__PURE__ */ new Map();
78
+ function relayAuthTokenForUrl(url) {
79
+ try {
80
+ const parsed = new URL(url);
81
+ if (!isLoopbackHost$1(parsed.hostname)) return null;
82
+ const port = parsed.port?.trim() !== "" ? Number(parsed.port) : parsed.protocol === "https:" || parsed.protocol === "wss:" ? 443 : 80;
83
+ if (!Number.isFinite(port)) return null;
84
+ return relayAuthByPort.get(port) ?? null;
85
+ } catch {
86
+ return null;
87
+ }
88
+ }
89
+ function getChromeExtensionRelayAuthHeaders(url) {
90
+ const token = relayAuthTokenForUrl(url);
91
+ if (!token) return {};
92
+ return { [RELAY_AUTH_HEADER]: token };
93
+ }
94
+ async function ensureChromeExtensionRelayServer(opts) {
95
+ const info = parseBaseUrl(opts.cdpUrl);
96
+ if (!isLoopbackHost$1(info.host)) throw new Error(`extension relay requires loopback cdpUrl host (got ${info.host})`);
97
+ const existing = serversByPort.get(info.port);
98
+ if (existing) return existing;
99
+ let extensionWs = null;
100
+ const cdpClients = /* @__PURE__ */ new Set();
101
+ const connectedTargets = /* @__PURE__ */ new Map();
102
+ const pendingExtension = /* @__PURE__ */ new Map();
103
+ let nextExtensionId = 1;
104
+ const sendToExtension = async (payload) => {
105
+ const ws = extensionWs;
106
+ if (!ws || ws.readyState !== WebSocket.OPEN) throw new Error("Chrome extension not connected");
107
+ ws.send(JSON.stringify(payload));
108
+ return await new Promise((resolve, reject) => {
109
+ const timer = setTimeout(() => {
110
+ pendingExtension.delete(payload.id);
111
+ reject(/* @__PURE__ */ new Error(`extension request timeout: ${payload.params.method}`));
112
+ }, 3e4);
113
+ pendingExtension.set(payload.id, {
114
+ resolve,
115
+ reject,
116
+ timer
117
+ });
118
+ });
119
+ };
120
+ const broadcastToCdpClients = (evt) => {
121
+ const msg = JSON.stringify(evt);
122
+ for (const ws of cdpClients) {
123
+ if (ws.readyState !== WebSocket.OPEN) continue;
124
+ ws.send(msg);
125
+ }
126
+ };
127
+ const sendResponseToCdp = (ws, res) => {
128
+ if (ws.readyState !== WebSocket.OPEN) return;
129
+ ws.send(JSON.stringify(res));
130
+ };
131
+ const ensureTargetEventsForClient = (ws, mode) => {
132
+ for (const target of connectedTargets.values()) if (mode === "autoAttach") ws.send(JSON.stringify({
133
+ method: "Target.attachedToTarget",
134
+ params: {
135
+ sessionId: target.sessionId,
136
+ targetInfo: {
137
+ ...target.targetInfo,
138
+ attached: true
139
+ },
140
+ waitingForDebugger: false
141
+ }
142
+ }));
143
+ else ws.send(JSON.stringify({
144
+ method: "Target.targetCreated",
145
+ params: { targetInfo: {
146
+ ...target.targetInfo,
147
+ attached: true
148
+ } }
149
+ }));
150
+ };
151
+ const routeCdpCommand = async (cmd) => {
152
+ switch (cmd.method) {
153
+ case "Browser.getVersion": return {
154
+ protocolVersion: "1.3",
155
+ product: "Chrome/OpenClaw-Extension-Relay",
156
+ revision: "0",
157
+ userAgent: "OpenClaw-Extension-Relay",
158
+ jsVersion: "V8"
159
+ };
160
+ case "Browser.setDownloadBehavior": return {};
161
+ case "Target.setAutoAttach":
162
+ case "Target.setDiscoverTargets": return {};
163
+ case "Target.getTargets": return { targetInfos: Array.from(connectedTargets.values()).map((t) => ({
164
+ ...t.targetInfo,
165
+ attached: true
166
+ })) };
167
+ case "Target.getTargetInfo": {
168
+ const params = cmd.params ?? {};
169
+ const targetId = typeof params.targetId === "string" ? params.targetId : void 0;
170
+ if (targetId) {
171
+ for (const t of connectedTargets.values()) if (t.targetId === targetId) return { targetInfo: t.targetInfo };
172
+ }
173
+ if (cmd.sessionId && connectedTargets.has(cmd.sessionId)) {
174
+ const t = connectedTargets.get(cmd.sessionId);
175
+ if (t) return { targetInfo: t.targetInfo };
176
+ }
177
+ return { targetInfo: Array.from(connectedTargets.values())[0]?.targetInfo };
178
+ }
179
+ case "Target.attachToTarget": {
180
+ const params = cmd.params ?? {};
181
+ const targetId = typeof params.targetId === "string" ? params.targetId : void 0;
182
+ if (!targetId) throw new Error("targetId required");
183
+ for (const t of connectedTargets.values()) if (t.targetId === targetId) return { sessionId: t.sessionId };
184
+ throw new Error("target not found");
185
+ }
186
+ default: return await sendToExtension({
187
+ id: nextExtensionId++,
188
+ method: "forwardCDPCommand",
189
+ params: {
190
+ method: cmd.method,
191
+ sessionId: cmd.sessionId,
192
+ params: cmd.params
193
+ }
194
+ });
195
+ }
196
+ };
197
+ const relayAuthToken = randomBytes(32).toString("base64url");
198
+ const server = createServer((req, res) => {
199
+ const path = new URL(req.url ?? "/", info.baseUrl).pathname;
200
+ if (path.startsWith("/json")) {
201
+ const token = getHeader(req, RELAY_AUTH_HEADER);
202
+ if (!token || token !== relayAuthToken) {
203
+ res.writeHead(401);
204
+ res.end("Unauthorized");
205
+ return;
206
+ }
207
+ }
208
+ if (req.method === "HEAD" && path === "/") {
209
+ res.writeHead(200);
210
+ res.end();
211
+ return;
212
+ }
213
+ if (path === "/") {
214
+ res.writeHead(200, { "Content-Type": "text/plain; charset=utf-8" });
215
+ res.end("OK");
216
+ return;
217
+ }
218
+ if (path === "/extension/status") {
219
+ res.writeHead(200, { "Content-Type": "application/json" });
220
+ res.end(JSON.stringify({ connected: Boolean(extensionWs) }));
221
+ return;
222
+ }
223
+ const cdpWsUrl = `${`ws://${req.headers.host?.trim() || `${info.host}:${info.port}`}`}/cdp`;
224
+ if ((path === "/json/version" || path === "/json/version/") && (req.method === "GET" || req.method === "PUT")) {
225
+ const payload = {
226
+ Browser: "OpenClaw/extension-relay",
227
+ "Protocol-Version": "1.3"
228
+ };
229
+ if (extensionWs) payload.webSocketDebuggerUrl = cdpWsUrl;
230
+ res.writeHead(200, { "Content-Type": "application/json" });
231
+ res.end(JSON.stringify(payload));
232
+ return;
233
+ }
234
+ if (new Set([
235
+ "/json",
236
+ "/json/",
237
+ "/json/list",
238
+ "/json/list/"
239
+ ]).has(path) && (req.method === "GET" || req.method === "PUT")) {
240
+ const list = Array.from(connectedTargets.values()).map((t) => ({
241
+ id: t.targetId,
242
+ type: t.targetInfo.type ?? "page",
243
+ title: t.targetInfo.title ?? "",
244
+ description: t.targetInfo.title ?? "",
245
+ url: t.targetInfo.url ?? "",
246
+ webSocketDebuggerUrl: cdpWsUrl,
247
+ devtoolsFrontendUrl: `/devtools/inspector.html?ws=${cdpWsUrl.replace("ws://", "")}`
248
+ }));
249
+ res.writeHead(200, { "Content-Type": "application/json" });
250
+ res.end(JSON.stringify(list));
251
+ return;
252
+ }
253
+ const activateMatch = path.match(/^\/json\/activate\/(.+)$/);
254
+ if (activateMatch && (req.method === "GET" || req.method === "PUT")) {
255
+ const targetId = decodeURIComponent(activateMatch[1] ?? "").trim();
256
+ if (!targetId) {
257
+ res.writeHead(400);
258
+ res.end("targetId required");
259
+ return;
260
+ }
261
+ (async () => {
262
+ try {
263
+ await sendToExtension({
264
+ id: nextExtensionId++,
265
+ method: "forwardCDPCommand",
266
+ params: {
267
+ method: "Target.activateTarget",
268
+ params: { targetId }
269
+ }
270
+ });
271
+ } catch {}
272
+ })();
273
+ res.writeHead(200);
274
+ res.end("OK");
275
+ return;
276
+ }
277
+ const closeMatch = path.match(/^\/json\/close\/(.+)$/);
278
+ if (closeMatch && (req.method === "GET" || req.method === "PUT")) {
279
+ const targetId = decodeURIComponent(closeMatch[1] ?? "").trim();
280
+ if (!targetId) {
281
+ res.writeHead(400);
282
+ res.end("targetId required");
283
+ return;
284
+ }
285
+ (async () => {
286
+ try {
287
+ await sendToExtension({
288
+ id: nextExtensionId++,
289
+ method: "forwardCDPCommand",
290
+ params: {
291
+ method: "Target.closeTarget",
292
+ params: { targetId }
293
+ }
294
+ });
295
+ } catch {}
296
+ })();
297
+ res.writeHead(200);
298
+ res.end("OK");
299
+ return;
300
+ }
301
+ res.writeHead(404);
302
+ res.end("not found");
303
+ });
304
+ const wssExtension = new WebSocketServer({ noServer: true });
305
+ const wssCdp = new WebSocketServer({ noServer: true });
306
+ server.on("upgrade", (req, socket, head) => {
307
+ const pathname = new URL(req.url ?? "/", info.baseUrl).pathname;
308
+ const remote = req.socket.remoteAddress;
309
+ if (!isLoopbackAddress(remote)) {
310
+ rejectUpgrade(socket, 403, "Forbidden");
311
+ return;
312
+ }
313
+ const origin = headerValue(req.headers.origin);
314
+ if (origin && !origin.startsWith("chrome-extension://")) {
315
+ rejectUpgrade(socket, 403, "Forbidden: invalid origin");
316
+ return;
317
+ }
318
+ if (pathname === "/extension") {
319
+ if (extensionWs) {
320
+ rejectUpgrade(socket, 409, "Extension already connected");
321
+ return;
322
+ }
323
+ wssExtension.handleUpgrade(req, socket, head, (ws) => {
324
+ wssExtension.emit("connection", ws, req);
325
+ });
326
+ return;
327
+ }
328
+ if (pathname === "/cdp") {
329
+ const token = getHeader(req, RELAY_AUTH_HEADER);
330
+ if (!token || token !== relayAuthToken) {
331
+ rejectUpgrade(socket, 401, "Unauthorized");
332
+ return;
333
+ }
334
+ if (!extensionWs) {
335
+ rejectUpgrade(socket, 503, "Extension not connected");
336
+ return;
337
+ }
338
+ wssCdp.handleUpgrade(req, socket, head, (ws) => {
339
+ wssCdp.emit("connection", ws, req);
340
+ });
341
+ return;
342
+ }
343
+ rejectUpgrade(socket, 404, "Not Found");
344
+ });
345
+ wssExtension.on("connection", (ws) => {
346
+ extensionWs = ws;
347
+ const ping = setInterval(() => {
348
+ if (ws.readyState !== WebSocket.OPEN) return;
349
+ ws.send(JSON.stringify({ method: "ping" }));
350
+ }, 5e3);
351
+ ws.on("message", (data) => {
352
+ let parsed = null;
353
+ try {
354
+ parsed = JSON.parse(rawDataToString(data));
355
+ } catch {
356
+ return;
357
+ }
358
+ if (parsed && typeof parsed === "object" && "id" in parsed && typeof parsed.id === "number") {
359
+ const pending = pendingExtension.get(parsed.id);
360
+ if (!pending) return;
361
+ pendingExtension.delete(parsed.id);
362
+ clearTimeout(pending.timer);
363
+ if ("error" in parsed && typeof parsed.error === "string" && parsed.error.trim()) pending.reject(new Error(parsed.error));
364
+ else pending.resolve(parsed.result);
365
+ return;
366
+ }
367
+ if (parsed && typeof parsed === "object" && "method" in parsed) {
368
+ if (parsed.method === "pong") return;
369
+ if (parsed.method !== "forwardCDPEvent") return;
370
+ const evt = parsed;
371
+ const method = evt.params?.method;
372
+ const params = evt.params?.params;
373
+ const sessionId = evt.params?.sessionId;
374
+ if (!method || typeof method !== "string") return;
375
+ if (method === "Target.attachedToTarget") {
376
+ const attached = params ?? {};
377
+ if ((attached?.targetInfo?.type ?? "page") !== "page") return;
378
+ if (attached?.sessionId && attached?.targetInfo?.targetId) {
379
+ const prev = connectedTargets.get(attached.sessionId);
380
+ const nextTargetId = attached.targetInfo.targetId;
381
+ const prevTargetId = prev?.targetId;
382
+ const changedTarget = Boolean(prev && prevTargetId && prevTargetId !== nextTargetId);
383
+ connectedTargets.set(attached.sessionId, {
384
+ sessionId: attached.sessionId,
385
+ targetId: nextTargetId,
386
+ targetInfo: attached.targetInfo
387
+ });
388
+ if (changedTarget && prevTargetId) broadcastToCdpClients({
389
+ method: "Target.detachedFromTarget",
390
+ params: {
391
+ sessionId: attached.sessionId,
392
+ targetId: prevTargetId
393
+ },
394
+ sessionId: attached.sessionId
395
+ });
396
+ if (!prev || changedTarget) broadcastToCdpClients({
397
+ method,
398
+ params,
399
+ sessionId
400
+ });
401
+ return;
402
+ }
403
+ }
404
+ if (method === "Target.detachedFromTarget") {
405
+ const detached = params ?? {};
406
+ if (detached?.sessionId) connectedTargets.delete(detached.sessionId);
407
+ broadcastToCdpClients({
408
+ method,
409
+ params,
410
+ sessionId
411
+ });
412
+ return;
413
+ }
414
+ if (method === "Target.targetInfoChanged") {
415
+ const targetInfo = (params ?? {})?.targetInfo;
416
+ const targetId = targetInfo?.targetId;
417
+ if (targetId && (targetInfo?.type ?? "page") === "page") for (const [sid, target] of connectedTargets) {
418
+ if (target.targetId !== targetId) continue;
419
+ connectedTargets.set(sid, {
420
+ ...target,
421
+ targetInfo: {
422
+ ...target.targetInfo,
423
+ ...targetInfo
424
+ }
425
+ });
426
+ }
427
+ }
428
+ broadcastToCdpClients({
429
+ method,
430
+ params,
431
+ sessionId
432
+ });
433
+ }
434
+ });
435
+ ws.on("close", () => {
436
+ clearInterval(ping);
437
+ extensionWs = null;
438
+ for (const [, pending] of pendingExtension) {
439
+ clearTimeout(pending.timer);
440
+ pending.reject(/* @__PURE__ */ new Error("extension disconnected"));
441
+ }
442
+ pendingExtension.clear();
443
+ connectedTargets.clear();
444
+ for (const client of cdpClients) try {
445
+ client.close(1011, "extension disconnected");
446
+ } catch {}
447
+ cdpClients.clear();
448
+ });
449
+ });
450
+ wssCdp.on("connection", (ws) => {
451
+ cdpClients.add(ws);
452
+ ws.on("message", async (data) => {
453
+ let cmd = null;
454
+ try {
455
+ cmd = JSON.parse(rawDataToString(data));
456
+ } catch {
457
+ return;
458
+ }
459
+ if (!cmd || typeof cmd !== "object") return;
460
+ if (typeof cmd.id !== "number" || typeof cmd.method !== "string") return;
461
+ if (!extensionWs) {
462
+ sendResponseToCdp(ws, {
463
+ id: cmd.id,
464
+ sessionId: cmd.sessionId,
465
+ error: { message: "Extension not connected" }
466
+ });
467
+ return;
468
+ }
469
+ try {
470
+ const result = await routeCdpCommand(cmd);
471
+ if (cmd.method === "Target.setAutoAttach" && !cmd.sessionId) ensureTargetEventsForClient(ws, "autoAttach");
472
+ if (cmd.method === "Target.setDiscoverTargets") {
473
+ if ((cmd.params ?? {}).discover === true) ensureTargetEventsForClient(ws, "discover");
474
+ }
475
+ if (cmd.method === "Target.attachToTarget") {
476
+ const params = cmd.params ?? {};
477
+ const targetId = typeof params.targetId === "string" ? params.targetId : void 0;
478
+ if (targetId) {
479
+ const target = Array.from(connectedTargets.values()).find((t) => t.targetId === targetId);
480
+ if (target) ws.send(JSON.stringify({
481
+ method: "Target.attachedToTarget",
482
+ params: {
483
+ sessionId: target.sessionId,
484
+ targetInfo: {
485
+ ...target.targetInfo,
486
+ attached: true
487
+ },
488
+ waitingForDebugger: false
489
+ }
490
+ }));
491
+ }
492
+ }
493
+ sendResponseToCdp(ws, {
494
+ id: cmd.id,
495
+ sessionId: cmd.sessionId,
496
+ result
497
+ });
498
+ } catch (err) {
499
+ sendResponseToCdp(ws, {
500
+ id: cmd.id,
501
+ sessionId: cmd.sessionId,
502
+ error: { message: err instanceof Error ? err.message : String(err) }
503
+ });
504
+ }
505
+ });
506
+ ws.on("close", () => {
507
+ cdpClients.delete(ws);
508
+ });
509
+ });
510
+ await new Promise((resolve, reject) => {
511
+ server.listen(info.port, info.host, () => resolve());
512
+ server.once("error", reject);
513
+ });
514
+ const port = server.address()?.port ?? info.port;
515
+ const host = info.host;
516
+ const relay = {
517
+ host,
518
+ port,
519
+ baseUrl: `${new URL(info.baseUrl).protocol}//${host}:${port}`,
520
+ cdpWsUrl: `ws://${host}:${port}/cdp`,
521
+ extensionConnected: () => Boolean(extensionWs),
522
+ stop: async () => {
523
+ serversByPort.delete(port);
524
+ relayAuthByPort.delete(port);
525
+ try {
526
+ extensionWs?.close(1001, "server stopping");
527
+ } catch {}
528
+ for (const ws of cdpClients) try {
529
+ ws.close(1001, "server stopping");
530
+ } catch {}
531
+ await new Promise((resolve) => {
532
+ server.close(() => resolve());
533
+ });
534
+ wssExtension.close();
535
+ wssCdp.close();
536
+ }
537
+ };
538
+ relayAuthByPort.set(port, relayAuthToken);
539
+ serversByPort.set(port, relay);
540
+ return relay;
541
+ }
542
+ async function stopChromeExtensionRelayServer(opts) {
543
+ const info = parseBaseUrl(opts.cdpUrl);
544
+ const existing = serversByPort.get(info.port);
545
+ if (!existing) return false;
546
+ await existing.stop();
547
+ relayAuthByPort.delete(info.port);
548
+ return true;
549
+ }
550
+
551
+ //#endregion
552
+ //#region src/browser/cdp.helpers.ts
553
+ function isLoopbackHost(host) {
554
+ const h = host.trim().toLowerCase();
555
+ return h === "localhost" || h === "127.0.0.1" || h === "0.0.0.0" || h === "[::1]" || h === "::1" || h === "[::]" || h === "::";
556
+ }
557
+ function getHeadersWithAuth(url, headers = {}) {
558
+ const mergedHeaders = {
559
+ ...getChromeExtensionRelayAuthHeaders(url),
560
+ ...headers
561
+ };
562
+ try {
563
+ const parsed = new URL(url);
564
+ if (Object.keys(mergedHeaders).some((key) => key.toLowerCase() === "authorization")) return mergedHeaders;
565
+ if (parsed.username || parsed.password) {
566
+ const auth = Buffer.from(`${parsed.username}:${parsed.password}`).toString("base64");
567
+ return {
568
+ ...mergedHeaders,
569
+ Authorization: `Basic ${auth}`
570
+ };
571
+ }
572
+ } catch {}
573
+ return mergedHeaders;
574
+ }
575
+ function appendCdpPath(cdpUrl, path) {
576
+ const url = new URL(cdpUrl);
577
+ url.pathname = `${url.pathname.replace(/\/$/, "")}${path.startsWith("/") ? path : `/${path}`}`;
578
+ return url.toString();
579
+ }
580
+ function createCdpSender(ws) {
581
+ let nextId = 1;
582
+ const pending = /* @__PURE__ */ new Map();
583
+ const send = (method, params) => {
584
+ const id = nextId++;
585
+ const msg = {
586
+ id,
587
+ method,
588
+ params
589
+ };
590
+ ws.send(JSON.stringify(msg));
591
+ return new Promise((resolve, reject) => {
592
+ pending.set(id, {
593
+ resolve,
594
+ reject
595
+ });
596
+ });
597
+ };
598
+ const closeWithError = (err) => {
599
+ for (const [, p] of pending) p.reject(err);
600
+ pending.clear();
601
+ try {
602
+ ws.close();
603
+ } catch {}
604
+ };
605
+ ws.on("message", (data) => {
606
+ try {
607
+ const parsed = JSON.parse(rawDataToString(data));
608
+ if (typeof parsed.id !== "number") return;
609
+ const p = pending.get(parsed.id);
610
+ if (!p) return;
611
+ pending.delete(parsed.id);
612
+ if (parsed.error?.message) {
613
+ p.reject(new Error(parsed.error.message));
614
+ return;
615
+ }
616
+ p.resolve(parsed.result);
617
+ } catch {}
618
+ });
619
+ ws.on("close", () => {
620
+ closeWithError(/* @__PURE__ */ new Error("CDP socket closed"));
621
+ });
622
+ return {
623
+ send,
624
+ closeWithError
625
+ };
626
+ }
627
+ async function fetchJson(url, timeoutMs = 1500, init) {
628
+ const ctrl = new AbortController();
629
+ const t = setTimeout(() => ctrl.abort(), timeoutMs);
630
+ try {
631
+ const headers = getHeadersWithAuth(url, init?.headers || {});
632
+ const res = await fetch(url, {
633
+ ...init,
634
+ headers,
635
+ signal: ctrl.signal
636
+ });
637
+ if (!res.ok) throw new Error(`HTTP ${res.status}`);
638
+ return await res.json();
639
+ } finally {
640
+ clearTimeout(t);
641
+ }
642
+ }
643
+ async function withCdpSocket(wsUrl, fn, opts) {
644
+ const headers = getHeadersWithAuth(wsUrl, opts?.headers ?? {});
645
+ const ws = new WebSocket(wsUrl, {
646
+ handshakeTimeout: 5e3,
647
+ ...Object.keys(headers).length ? { headers } : {}
648
+ });
649
+ const { send, closeWithError } = createCdpSender(ws);
650
+ await new Promise((resolve, reject) => {
651
+ ws.once("open", () => resolve());
652
+ ws.once("error", (err) => reject(err));
653
+ });
654
+ try {
655
+ return await fn(send);
656
+ } catch (err) {
657
+ closeWithError(err instanceof Error ? err : new Error(String(err)));
658
+ throw err;
659
+ } finally {
660
+ try {
661
+ ws.close();
662
+ } catch {}
663
+ }
664
+ }
665
+
666
+ //#endregion
667
+ //#region src/browser/cdp.ts
668
+ function normalizeCdpWsUrl(wsUrl, cdpUrl) {
669
+ const ws = new URL(wsUrl);
670
+ const cdp = new URL(cdpUrl);
671
+ if (isLoopbackHost(ws.hostname) && !isLoopbackHost(cdp.hostname)) {
672
+ ws.hostname = cdp.hostname;
673
+ const cdpPort = cdp.port || (cdp.protocol === "https:" ? "443" : "80");
674
+ if (cdpPort) ws.port = cdpPort;
675
+ ws.protocol = cdp.protocol === "https:" ? "wss:" : "ws:";
676
+ }
677
+ if (cdp.protocol === "https:" && ws.protocol === "ws:") ws.protocol = "wss:";
678
+ if (!ws.username && !ws.password && (cdp.username || cdp.password)) {
679
+ ws.username = cdp.username;
680
+ ws.password = cdp.password;
681
+ }
682
+ for (const [key, value] of cdp.searchParams.entries()) if (!ws.searchParams.has(key)) ws.searchParams.append(key, value);
683
+ return ws.toString();
684
+ }
685
+ async function captureScreenshot(opts) {
686
+ return await withCdpSocket(opts.wsUrl, async (send) => {
687
+ await send("Page.enable");
688
+ let clip;
689
+ if (opts.fullPage) {
690
+ const metrics = await send("Page.getLayoutMetrics");
691
+ const size = metrics?.cssContentSize ?? metrics?.contentSize;
692
+ const width = Number(size?.width ?? 0);
693
+ const height = Number(size?.height ?? 0);
694
+ if (width > 0 && height > 0) clip = {
695
+ x: 0,
696
+ y: 0,
697
+ width,
698
+ height,
699
+ scale: 1
700
+ };
701
+ }
702
+ const format = opts.format ?? "png";
703
+ const quality = format === "jpeg" ? Math.max(0, Math.min(100, Math.round(opts.quality ?? 85))) : void 0;
704
+ const base64 = (await send("Page.captureScreenshot", {
705
+ format,
706
+ ...quality !== void 0 ? { quality } : {},
707
+ fromSurface: true,
708
+ captureBeyondViewport: true,
709
+ ...clip ? { clip } : {}
710
+ }))?.data;
711
+ if (!base64) throw new Error("Screenshot failed: missing data");
712
+ return Buffer.from(base64, "base64");
713
+ });
714
+ }
715
+ async function createTargetViaCdp(opts) {
716
+ const version = await fetchJson(appendCdpPath(opts.cdpUrl, "/json/version"), 1500);
717
+ const wsUrlRaw = String(version?.webSocketDebuggerUrl ?? "").trim();
718
+ const wsUrl = wsUrlRaw ? normalizeCdpWsUrl(wsUrlRaw, opts.cdpUrl) : "";
719
+ if (!wsUrl) throw new Error("CDP /json/version missing webSocketDebuggerUrl");
720
+ return await withCdpSocket(wsUrl, async (send) => {
721
+ const created = await send("Target.createTarget", { url: opts.url });
722
+ const targetId = String(created?.targetId ?? "").trim();
723
+ if (!targetId) throw new Error("CDP Target.createTarget returned no targetId");
724
+ return { targetId };
725
+ });
726
+ }
727
+ function axValue(v) {
728
+ if (!v || typeof v !== "object") return "";
729
+ const value = v.value;
730
+ if (typeof value === "string") return value;
731
+ if (typeof value === "number" || typeof value === "boolean") return String(value);
732
+ return "";
733
+ }
734
+ function formatAriaSnapshot(nodes, limit) {
735
+ const byId = /* @__PURE__ */ new Map();
736
+ for (const n of nodes) if (n.nodeId) byId.set(n.nodeId, n);
737
+ const referenced = /* @__PURE__ */ new Set();
738
+ for (const n of nodes) for (const c of n.childIds ?? []) referenced.add(c);
739
+ const root = nodes.find((n) => n.nodeId && !referenced.has(n.nodeId)) ?? nodes[0];
740
+ if (!root?.nodeId) return [];
741
+ const out = [];
742
+ const stack = [{
743
+ id: root.nodeId,
744
+ depth: 0
745
+ }];
746
+ while (stack.length && out.length < limit) {
747
+ const popped = stack.pop();
748
+ if (!popped) break;
749
+ const { id, depth } = popped;
750
+ const n = byId.get(id);
751
+ if (!n) continue;
752
+ const role = axValue(n.role);
753
+ const name = axValue(n.name);
754
+ const value = axValue(n.value);
755
+ const description = axValue(n.description);
756
+ const ref = `ax${out.length + 1}`;
757
+ out.push({
758
+ ref,
759
+ role: role || "unknown",
760
+ name: name || "",
761
+ ...value ? { value } : {},
762
+ ...description ? { description } : {},
763
+ ...typeof n.backendDOMNodeId === "number" ? { backendDOMNodeId: n.backendDOMNodeId } : {},
764
+ depth
765
+ });
766
+ const children = (n.childIds ?? []).filter((c) => byId.has(c));
767
+ for (let i = children.length - 1; i >= 0; i--) {
768
+ const child = children[i];
769
+ if (child) stack.push({
770
+ id: child,
771
+ depth: depth + 1
772
+ });
773
+ }
774
+ }
775
+ return out;
776
+ }
777
+ async function snapshotAria(opts) {
778
+ const limit = Math.max(1, Math.min(2e3, Math.floor(opts.limit ?? 500)));
779
+ return await withCdpSocket(opts.wsUrl, async (send) => {
780
+ await send("Accessibility.enable").catch(() => {});
781
+ const res = await send("Accessibility.getFullAXTree");
782
+ return { nodes: formatAriaSnapshot(Array.isArray(res?.nodes) ? res.nodes : [], limit) };
783
+ });
784
+ }
785
+
786
+ //#endregion
787
+ //#region src/infra/ports-format.ts
788
+ function classifyPortListener(listener, port) {
789
+ const raw = `${listener.commandLine ?? ""} ${listener.command ?? ""}`.trim().toLowerCase();
790
+ if (raw.includes("openclaw")) return "gateway";
791
+ if (raw.includes("ssh")) {
792
+ const portToken = String(port);
793
+ const tunnelPattern = new RegExp(`-(l|r)\\s*${portToken}\\b|-(l|r)${portToken}\\b|:${portToken}\\b`);
794
+ if (!raw || tunnelPattern.test(raw)) return "ssh";
795
+ return "ssh";
796
+ }
797
+ return "unknown";
798
+ }
799
+ function buildPortHints(listeners, port) {
800
+ if (listeners.length === 0) return [];
801
+ const kinds = new Set(listeners.map((listener) => classifyPortListener(listener, port)));
802
+ const hints = [];
803
+ if (kinds.has("gateway")) hints.push(`Gateway already running locally. Stop it (${formatCliCommand("openclaw gateway stop")}) or use a different port.`);
804
+ if (kinds.has("ssh")) hints.push("SSH tunnel already bound to this port. Close the tunnel or use a different local port in -L.");
805
+ if (kinds.has("unknown")) hints.push("Another process is listening on this port.");
806
+ if (listeners.length > 1) hints.push("Multiple listeners detected; ensure only one gateway/tunnel per port unless intentionally running isolated profiles.");
807
+ return hints;
808
+ }
809
+ function formatPortListener(listener) {
810
+ return `${listener.pid ? `pid ${listener.pid}` : "pid ?"}${listener.user ? ` ${listener.user}` : ""}: ${listener.commandLine || listener.command || "unknown"}${listener.address ? ` (${listener.address})` : ""}`;
811
+ }
812
+ function formatPortDiagnostics(diagnostics) {
813
+ if (diagnostics.status !== "busy") return [`Port ${diagnostics.port} is free.`];
814
+ const lines = [`Port ${diagnostics.port} is already in use.`];
815
+ for (const listener of diagnostics.listeners) lines.push(`- ${formatPortListener(listener)}`);
816
+ for (const hint of diagnostics.hints) lines.push(`- ${hint}`);
817
+ return lines;
818
+ }
819
+
820
+ //#endregion
821
+ //#region src/infra/ports-lsof.ts
822
+ const LSOF_CANDIDATES = process.platform === "darwin" ? ["/usr/sbin/lsof", "/usr/bin/lsof"] : ["/usr/bin/lsof", "/usr/sbin/lsof"];
823
+ async function canExecute(path) {
824
+ try {
825
+ await fs$1.access(path, fs.constants.X_OK);
826
+ return true;
827
+ } catch {
828
+ return false;
829
+ }
830
+ }
831
+ async function resolveLsofCommand() {
832
+ for (const candidate of LSOF_CANDIDATES) if (await canExecute(candidate)) return candidate;
833
+ return "lsof";
834
+ }
835
+ function resolveLsofCommandSync() {
836
+ for (const candidate of LSOF_CANDIDATES) try {
837
+ fs.accessSync(candidate, fs.constants.X_OK);
838
+ return candidate;
839
+ } catch {}
840
+ return "lsof";
841
+ }
842
+
843
+ //#endregion
844
+ //#region src/infra/ports-inspect.ts
845
+ function isErrno$1(err) {
846
+ return Boolean(err && typeof err === "object" && "code" in err);
847
+ }
848
+ async function runCommandSafe(argv, timeoutMs = 5e3) {
849
+ try {
850
+ const res = await runCommandWithTimeout(argv, { timeoutMs });
851
+ return {
852
+ stdout: res.stdout,
853
+ stderr: res.stderr,
854
+ code: res.code ?? 1
855
+ };
856
+ } catch (err) {
857
+ return {
858
+ stdout: "",
859
+ stderr: "",
860
+ code: 1,
861
+ error: String(err)
862
+ };
863
+ }
864
+ }
865
+ function parseLsofFieldOutput(output) {
866
+ const lines = output.split(/\r?\n/).filter(Boolean);
867
+ const listeners = [];
868
+ let current = {};
869
+ for (const line of lines) if (line.startsWith("p")) {
870
+ if (current.pid || current.command) listeners.push(current);
871
+ const pid = Number.parseInt(line.slice(1), 10);
872
+ current = Number.isFinite(pid) ? { pid } : {};
873
+ } else if (line.startsWith("c")) current.command = line.slice(1);
874
+ else if (line.startsWith("n")) {
875
+ if (!current.address) current.address = line.slice(1);
876
+ }
877
+ if (current.pid || current.command) listeners.push(current);
878
+ return listeners;
879
+ }
880
+ async function resolveUnixCommandLine(pid) {
881
+ const res = await runCommandSafe([
882
+ "ps",
883
+ "-p",
884
+ String(pid),
885
+ "-o",
886
+ "command="
887
+ ]);
888
+ if (res.code !== 0) return;
889
+ return res.stdout.trim() || void 0;
890
+ }
891
+ async function resolveUnixUser(pid) {
892
+ const res = await runCommandSafe([
893
+ "ps",
894
+ "-p",
895
+ String(pid),
896
+ "-o",
897
+ "user="
898
+ ]);
899
+ if (res.code !== 0) return;
900
+ return res.stdout.trim() || void 0;
901
+ }
902
+ async function readUnixListeners(port) {
903
+ const errors = [];
904
+ const res = await runCommandSafe([
905
+ await resolveLsofCommand(),
906
+ "-nP",
907
+ `-iTCP:${port}`,
908
+ "-sTCP:LISTEN",
909
+ "-FpFcn"
910
+ ]);
911
+ if (res.code === 0) {
912
+ const listeners = parseLsofFieldOutput(res.stdout);
913
+ await Promise.all(listeners.map(async (listener) => {
914
+ if (!listener.pid) return;
915
+ const [commandLine, user] = await Promise.all([resolveUnixCommandLine(listener.pid), resolveUnixUser(listener.pid)]);
916
+ if (commandLine) listener.commandLine = commandLine;
917
+ if (user) listener.user = user;
918
+ }));
919
+ return {
920
+ listeners,
921
+ detail: res.stdout.trim() || void 0,
922
+ errors
923
+ };
924
+ }
925
+ const stderr = res.stderr.trim();
926
+ if (res.code === 1 && !res.error && !stderr) return {
927
+ listeners: [],
928
+ detail: void 0,
929
+ errors
930
+ };
931
+ if (res.error) errors.push(res.error);
932
+ const detail = [stderr, res.stdout.trim()].filter(Boolean).join("\n");
933
+ if (detail) errors.push(detail);
934
+ return {
935
+ listeners: [],
936
+ detail: void 0,
937
+ errors
938
+ };
939
+ }
940
+ function parseNetstatListeners(output, port) {
941
+ const listeners = [];
942
+ const portToken = `:${port}`;
943
+ for (const rawLine of output.split(/\r?\n/)) {
944
+ const line = rawLine.trim();
945
+ if (!line) continue;
946
+ if (!line.toLowerCase().includes("listen")) continue;
947
+ if (!line.includes(portToken)) continue;
948
+ const parts = line.split(/\s+/);
949
+ if (parts.length < 4) continue;
950
+ const pidRaw = parts.at(-1);
951
+ const pid = pidRaw ? Number.parseInt(pidRaw, 10) : NaN;
952
+ const localAddr = parts[1];
953
+ const listener = {};
954
+ if (Number.isFinite(pid)) listener.pid = pid;
955
+ if (localAddr?.includes(portToken)) listener.address = localAddr;
956
+ listeners.push(listener);
957
+ }
958
+ return listeners;
959
+ }
960
+ async function resolveWindowsImageName(pid) {
961
+ const res = await runCommandSafe([
962
+ "tasklist",
963
+ "/FI",
964
+ `PID eq ${pid}`,
965
+ "/FO",
966
+ "LIST"
967
+ ]);
968
+ if (res.code !== 0) return;
969
+ for (const rawLine of res.stdout.split(/\r?\n/)) {
970
+ const line = rawLine.trim();
971
+ if (!line.toLowerCase().startsWith("image name:")) continue;
972
+ return line.slice(11).trim() || void 0;
973
+ }
974
+ }
975
+ async function resolveWindowsCommandLine(pid) {
976
+ const res = await runCommandSafe([
977
+ "wmic",
978
+ "process",
979
+ "where",
980
+ `ProcessId=${pid}`,
981
+ "get",
982
+ "CommandLine",
983
+ "/value"
984
+ ]);
985
+ if (res.code !== 0) return;
986
+ for (const rawLine of res.stdout.split(/\r?\n/)) {
987
+ const line = rawLine.trim();
988
+ if (!line.toLowerCase().startsWith("commandline=")) continue;
989
+ return line.slice(12).trim() || void 0;
990
+ }
991
+ }
992
+ async function readWindowsListeners(port) {
993
+ const errors = [];
994
+ const res = await runCommandSafe([
995
+ "netstat",
996
+ "-ano",
997
+ "-p",
998
+ "tcp"
999
+ ]);
1000
+ if (res.code !== 0) {
1001
+ if (res.error) errors.push(res.error);
1002
+ const detail = [res.stderr.trim(), res.stdout.trim()].filter(Boolean).join("\n");
1003
+ if (detail) errors.push(detail);
1004
+ return {
1005
+ listeners: [],
1006
+ errors
1007
+ };
1008
+ }
1009
+ const listeners = parseNetstatListeners(res.stdout, port);
1010
+ await Promise.all(listeners.map(async (listener) => {
1011
+ if (!listener.pid) return;
1012
+ const [imageName, commandLine] = await Promise.all([resolveWindowsImageName(listener.pid), resolveWindowsCommandLine(listener.pid)]);
1013
+ if (imageName) listener.command = imageName;
1014
+ if (commandLine) listener.commandLine = commandLine;
1015
+ }));
1016
+ return {
1017
+ listeners,
1018
+ detail: res.stdout.trim() || void 0,
1019
+ errors
1020
+ };
1021
+ }
1022
+ async function tryListenOnHost(port, host) {
1023
+ try {
1024
+ await new Promise((resolve, reject) => {
1025
+ const tester = net.createServer().once("error", (err) => reject(err)).once("listening", () => {
1026
+ tester.close(() => resolve());
1027
+ }).listen({
1028
+ port,
1029
+ host,
1030
+ exclusive: true
1031
+ });
1032
+ });
1033
+ return "free";
1034
+ } catch (err) {
1035
+ if (isErrno$1(err) && err.code === "EADDRINUSE") return "busy";
1036
+ if (isErrno$1(err) && (err.code === "EADDRNOTAVAIL" || err.code === "EAFNOSUPPORT")) return "skip";
1037
+ return "unknown";
1038
+ }
1039
+ }
1040
+ async function checkPortInUse(port) {
1041
+ const hosts = [
1042
+ "127.0.0.1",
1043
+ "0.0.0.0",
1044
+ "::1",
1045
+ "::"
1046
+ ];
1047
+ let sawUnknown = false;
1048
+ for (const host of hosts) {
1049
+ const result = await tryListenOnHost(port, host);
1050
+ if (result === "busy") return "busy";
1051
+ if (result === "unknown") sawUnknown = true;
1052
+ }
1053
+ return sawUnknown ? "unknown" : "free";
1054
+ }
1055
+ async function inspectPortUsage(port) {
1056
+ const errors = [];
1057
+ const result = process.platform === "win32" ? await readWindowsListeners(port) : await readUnixListeners(port);
1058
+ errors.push(...result.errors);
1059
+ let listeners = result.listeners;
1060
+ let status = listeners.length > 0 ? "busy" : "unknown";
1061
+ if (listeners.length === 0) status = await checkPortInUse(port);
1062
+ if (status !== "busy") listeners = [];
1063
+ const hints = buildPortHints(listeners, port);
1064
+ if (status === "busy" && listeners.length === 0) hints.push("Port is in use but process details are unavailable (install lsof or run as an admin user).");
1065
+ return {
1066
+ port,
1067
+ status,
1068
+ listeners,
1069
+ hints,
1070
+ detail: result.detail,
1071
+ errors: errors.length > 0 ? errors : void 0
1072
+ };
1073
+ }
1074
+
1075
+ //#endregion
1076
+ //#region src/infra/ports.ts
1077
+ var PortInUseError = class extends Error {
1078
+ constructor(port, details) {
1079
+ super(`Port ${port} is already in use.`);
1080
+ this.name = "PortInUseError";
1081
+ this.port = port;
1082
+ this.details = details;
1083
+ }
1084
+ };
1085
+ function isErrno(err) {
1086
+ return Boolean(err && typeof err === "object" && "code" in err);
1087
+ }
1088
+ async function describePortOwner(port) {
1089
+ const diagnostics = await inspectPortUsage(port);
1090
+ if (diagnostics.listeners.length === 0) return;
1091
+ return formatPortDiagnostics(diagnostics).join("\n");
1092
+ }
1093
+ async function ensurePortAvailable(port) {
1094
+ try {
1095
+ await new Promise((resolve, reject) => {
1096
+ const tester = net.createServer().once("error", (err) => reject(err)).once("listening", () => {
1097
+ tester.close(() => resolve());
1098
+ }).listen(port);
1099
+ });
1100
+ } catch (err) {
1101
+ if (isErrno(err) && err.code === "EADDRINUSE") throw new PortInUseError(port, await describePortOwner(port));
1102
+ throw err;
1103
+ }
1104
+ }
1105
+
1106
+ //#endregion
1107
+ //#region src/browser/chrome.executables.ts
1108
+ const CHROMIUM_BUNDLE_IDS = new Set([
1109
+ "com.google.Chrome",
1110
+ "com.google.Chrome.beta",
1111
+ "com.google.Chrome.canary",
1112
+ "com.google.Chrome.dev",
1113
+ "com.brave.Browser",
1114
+ "com.brave.Browser.beta",
1115
+ "com.brave.Browser.nightly",
1116
+ "com.microsoft.Edge",
1117
+ "com.microsoft.EdgeBeta",
1118
+ "com.microsoft.EdgeDev",
1119
+ "com.microsoft.EdgeCanary",
1120
+ "org.chromium.Chromium",
1121
+ "com.vivaldi.Vivaldi",
1122
+ "com.operasoftware.Opera",
1123
+ "com.operasoftware.OperaGX",
1124
+ "com.yandex.desktop.yandex-browser",
1125
+ "company.thebrowser.Browser"
1126
+ ]);
1127
+ const CHROMIUM_DESKTOP_IDS = new Set([
1128
+ "google-chrome.desktop",
1129
+ "google-chrome-beta.desktop",
1130
+ "google-chrome-unstable.desktop",
1131
+ "brave-browser.desktop",
1132
+ "microsoft-edge.desktop",
1133
+ "microsoft-edge-beta.desktop",
1134
+ "microsoft-edge-dev.desktop",
1135
+ "microsoft-edge-canary.desktop",
1136
+ "chromium.desktop",
1137
+ "chromium-browser.desktop",
1138
+ "vivaldi.desktop",
1139
+ "vivaldi-stable.desktop",
1140
+ "opera.desktop",
1141
+ "opera-gx.desktop",
1142
+ "yandex-browser.desktop",
1143
+ "org.chromium.Chromium.desktop"
1144
+ ]);
1145
+ const CHROMIUM_EXE_NAMES = new Set([
1146
+ "chrome.exe",
1147
+ "msedge.exe",
1148
+ "brave.exe",
1149
+ "brave-browser.exe",
1150
+ "chromium.exe",
1151
+ "vivaldi.exe",
1152
+ "opera.exe",
1153
+ "launcher.exe",
1154
+ "yandex.exe",
1155
+ "yandexbrowser.exe",
1156
+ "google chrome",
1157
+ "google chrome canary",
1158
+ "brave browser",
1159
+ "microsoft edge",
1160
+ "chromium",
1161
+ "chrome",
1162
+ "brave",
1163
+ "msedge",
1164
+ "brave-browser",
1165
+ "google-chrome",
1166
+ "google-chrome-stable",
1167
+ "google-chrome-beta",
1168
+ "google-chrome-unstable",
1169
+ "microsoft-edge",
1170
+ "microsoft-edge-beta",
1171
+ "microsoft-edge-dev",
1172
+ "microsoft-edge-canary",
1173
+ "chromium-browser",
1174
+ "vivaldi",
1175
+ "vivaldi-stable",
1176
+ "opera",
1177
+ "opera-stable",
1178
+ "opera-gx",
1179
+ "yandex-browser"
1180
+ ]);
1181
+ function exists$1(filePath) {
1182
+ try {
1183
+ return fs.existsSync(filePath);
1184
+ } catch {
1185
+ return false;
1186
+ }
1187
+ }
1188
+ function execText(command, args, timeoutMs = 1200, maxBuffer = 1024 * 1024) {
1189
+ try {
1190
+ const output = execFileSync(command, args, {
1191
+ timeout: timeoutMs,
1192
+ encoding: "utf8",
1193
+ maxBuffer
1194
+ });
1195
+ return String(output ?? "").trim() || null;
1196
+ } catch {
1197
+ return null;
1198
+ }
1199
+ }
1200
+ function inferKindFromIdentifier(identifier) {
1201
+ const id = identifier.toLowerCase();
1202
+ if (id.includes("brave")) return "brave";
1203
+ if (id.includes("edge")) return "edge";
1204
+ if (id.includes("chromium")) return "chromium";
1205
+ if (id.includes("canary")) return "canary";
1206
+ if (id.includes("opera") || id.includes("vivaldi") || id.includes("yandex") || id.includes("thebrowser")) return "chromium";
1207
+ return "chrome";
1208
+ }
1209
+ function inferKindFromExecutableName(name) {
1210
+ const lower = name.toLowerCase();
1211
+ if (lower.includes("brave")) return "brave";
1212
+ if (lower.includes("edge") || lower.includes("msedge")) return "edge";
1213
+ if (lower.includes("chromium")) return "chromium";
1214
+ if (lower.includes("canary") || lower.includes("sxs")) return "canary";
1215
+ if (lower.includes("opera") || lower.includes("vivaldi") || lower.includes("yandex")) return "chromium";
1216
+ return "chrome";
1217
+ }
1218
+ function detectDefaultChromiumExecutable(platform) {
1219
+ if (platform === "darwin") return detectDefaultChromiumExecutableMac();
1220
+ if (platform === "linux") return detectDefaultChromiumExecutableLinux();
1221
+ if (platform === "win32") return detectDefaultChromiumExecutableWindows();
1222
+ return null;
1223
+ }
1224
+ function detectDefaultChromiumExecutableMac() {
1225
+ const bundleId = detectDefaultBrowserBundleIdMac();
1226
+ if (!bundleId || !CHROMIUM_BUNDLE_IDS.has(bundleId)) return null;
1227
+ const appPathRaw = execText("/usr/bin/osascript", ["-e", `POSIX path of (path to application id "${bundleId}")`]);
1228
+ if (!appPathRaw) return null;
1229
+ const appPath = appPathRaw.trim().replace(/\/$/, "");
1230
+ const exeName = execText("/usr/bin/defaults", [
1231
+ "read",
1232
+ path.join(appPath, "Contents", "Info"),
1233
+ "CFBundleExecutable"
1234
+ ]);
1235
+ if (!exeName) return null;
1236
+ const exePath = path.join(appPath, "Contents", "MacOS", exeName.trim());
1237
+ if (!exists$1(exePath)) return null;
1238
+ return {
1239
+ kind: inferKindFromIdentifier(bundleId),
1240
+ path: exePath
1241
+ };
1242
+ }
1243
+ function detectDefaultBrowserBundleIdMac() {
1244
+ const plistPath = path.join(os.homedir(), "Library/Preferences/com.apple.LaunchServices/com.apple.launchservices.secure.plist");
1245
+ if (!exists$1(plistPath)) return null;
1246
+ const handlersRaw = execText("/usr/bin/plutil", [
1247
+ "-extract",
1248
+ "LSHandlers",
1249
+ "json",
1250
+ "-o",
1251
+ "-",
1252
+ "--",
1253
+ plistPath
1254
+ ], 2e3, 5 * 1024 * 1024);
1255
+ if (!handlersRaw) return null;
1256
+ let handlers;
1257
+ try {
1258
+ handlers = JSON.parse(handlersRaw);
1259
+ } catch {
1260
+ return null;
1261
+ }
1262
+ if (!Array.isArray(handlers)) return null;
1263
+ const resolveScheme = (scheme) => {
1264
+ let candidate = null;
1265
+ for (const entry of handlers) {
1266
+ if (!entry || typeof entry !== "object") continue;
1267
+ const record = entry;
1268
+ if (record.LSHandlerURLScheme !== scheme) continue;
1269
+ const role = typeof record.LSHandlerRoleAll === "string" && record.LSHandlerRoleAll || typeof record.LSHandlerRoleViewer === "string" && record.LSHandlerRoleViewer || null;
1270
+ if (role) candidate = role;
1271
+ }
1272
+ return candidate;
1273
+ };
1274
+ return resolveScheme("http") ?? resolveScheme("https");
1275
+ }
1276
+ function detectDefaultChromiumExecutableLinux() {
1277
+ const desktopId = execText("xdg-settings", ["get", "default-web-browser"]) || execText("xdg-mime", [
1278
+ "query",
1279
+ "default",
1280
+ "x-scheme-handler/http"
1281
+ ]);
1282
+ if (!desktopId) return null;
1283
+ const trimmed = desktopId.trim();
1284
+ if (!CHROMIUM_DESKTOP_IDS.has(trimmed)) return null;
1285
+ const desktopPath = findDesktopFilePath(trimmed);
1286
+ if (!desktopPath) return null;
1287
+ const execLine = readDesktopExecLine(desktopPath);
1288
+ if (!execLine) return null;
1289
+ const command = extractExecutableFromExecLine(execLine);
1290
+ if (!command) return null;
1291
+ const resolved = resolveLinuxExecutablePath(command);
1292
+ if (!resolved) return null;
1293
+ const exeName = path.posix.basename(resolved).toLowerCase();
1294
+ if (!CHROMIUM_EXE_NAMES.has(exeName)) return null;
1295
+ return {
1296
+ kind: inferKindFromExecutableName(exeName),
1297
+ path: resolved
1298
+ };
1299
+ }
1300
+ function detectDefaultChromiumExecutableWindows() {
1301
+ const progId = readWindowsProgId();
1302
+ const command = (progId ? readWindowsCommandForProgId(progId) : null) || readWindowsCommandForProgId("http");
1303
+ if (!command) return null;
1304
+ const exePath = extractWindowsExecutablePath(expandWindowsEnvVars(command));
1305
+ if (!exePath) return null;
1306
+ if (!exists$1(exePath)) return null;
1307
+ const exeName = path.win32.basename(exePath).toLowerCase();
1308
+ if (!CHROMIUM_EXE_NAMES.has(exeName)) return null;
1309
+ return {
1310
+ kind: inferKindFromExecutableName(exeName),
1311
+ path: exePath
1312
+ };
1313
+ }
1314
+ function findDesktopFilePath(desktopId) {
1315
+ const candidates = [
1316
+ path.join(os.homedir(), ".local", "share", "applications", desktopId),
1317
+ path.join("/usr/local/share/applications", desktopId),
1318
+ path.join("/usr/share/applications", desktopId),
1319
+ path.join("/var/lib/snapd/desktop/applications", desktopId)
1320
+ ];
1321
+ for (const candidate of candidates) if (exists$1(candidate)) return candidate;
1322
+ return null;
1323
+ }
1324
+ function readDesktopExecLine(desktopPath) {
1325
+ try {
1326
+ const lines = fs.readFileSync(desktopPath, "utf8").split(/\r?\n/);
1327
+ for (const line of lines) if (line.startsWith("Exec=")) return line.slice(5).trim();
1328
+ } catch {}
1329
+ return null;
1330
+ }
1331
+ function extractExecutableFromExecLine(execLine) {
1332
+ const tokens = splitExecLine(execLine);
1333
+ for (const token of tokens) {
1334
+ if (!token) continue;
1335
+ if (token === "env") continue;
1336
+ if (token.includes("=") && !token.startsWith("/") && !token.includes("\\")) continue;
1337
+ return token.replace(/^["']|["']$/g, "");
1338
+ }
1339
+ return null;
1340
+ }
1341
+ function splitExecLine(line) {
1342
+ const tokens = [];
1343
+ let current = "";
1344
+ let inQuotes = false;
1345
+ let quoteChar = "";
1346
+ for (let i = 0; i < line.length; i += 1) {
1347
+ const ch = line[i];
1348
+ if ((ch === "\"" || ch === "'") && (!inQuotes || ch === quoteChar)) {
1349
+ if (inQuotes) {
1350
+ inQuotes = false;
1351
+ quoteChar = "";
1352
+ } else {
1353
+ inQuotes = true;
1354
+ quoteChar = ch;
1355
+ }
1356
+ continue;
1357
+ }
1358
+ if (!inQuotes && /\s/.test(ch)) {
1359
+ if (current) {
1360
+ tokens.push(current);
1361
+ current = "";
1362
+ }
1363
+ continue;
1364
+ }
1365
+ current += ch;
1366
+ }
1367
+ if (current) tokens.push(current);
1368
+ return tokens;
1369
+ }
1370
+ function resolveLinuxExecutablePath(command) {
1371
+ const cleaned = command.trim().replace(/%[a-zA-Z]/g, "");
1372
+ if (!cleaned) return null;
1373
+ if (cleaned.startsWith("/")) return cleaned;
1374
+ const resolved = execText("which", [cleaned], 800);
1375
+ return resolved ? resolved.trim() : null;
1376
+ }
1377
+ function readWindowsProgId() {
1378
+ const output = execText("reg", [
1379
+ "query",
1380
+ "HKCU\\Software\\Microsoft\\Windows\\Shell\\Associations\\UrlAssociations\\http\\UserChoice",
1381
+ "/v",
1382
+ "ProgId"
1383
+ ]);
1384
+ if (!output) return null;
1385
+ return output.match(/ProgId\s+REG_\w+\s+(.+)$/im)?.[1]?.trim() || null;
1386
+ }
1387
+ function readWindowsCommandForProgId(progId) {
1388
+ const output = execText("reg", [
1389
+ "query",
1390
+ progId === "http" ? "HKCR\\http\\shell\\open\\command" : `HKCR\\${progId}\\shell\\open\\command`,
1391
+ "/ve"
1392
+ ]);
1393
+ if (!output) return null;
1394
+ return output.match(/REG_\w+\s+(.+)$/im)?.[1]?.trim() || null;
1395
+ }
1396
+ function expandWindowsEnvVars(value) {
1397
+ return value.replace(/%([^%]+)%/g, (_match, name) => {
1398
+ const key = String(name ?? "").trim();
1399
+ return key ? process.env[key] ?? `%${key}%` : _match;
1400
+ });
1401
+ }
1402
+ function extractWindowsExecutablePath(command) {
1403
+ const quoted = command.match(/"([^"]+\\.exe)"/i);
1404
+ if (quoted?.[1]) return quoted[1];
1405
+ const unquoted = command.match(/([^\\s]+\\.exe)/i);
1406
+ if (unquoted?.[1]) return unquoted[1];
1407
+ return null;
1408
+ }
1409
+ function findFirstExecutable(candidates) {
1410
+ for (const candidate of candidates) if (exists$1(candidate.path)) return candidate;
1411
+ return null;
1412
+ }
1413
+ function findChromeExecutableMac() {
1414
+ return findFirstExecutable([
1415
+ {
1416
+ kind: "chrome",
1417
+ path: "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome"
1418
+ },
1419
+ {
1420
+ kind: "chrome",
1421
+ path: path.join(os.homedir(), "Applications/Google Chrome.app/Contents/MacOS/Google Chrome")
1422
+ },
1423
+ {
1424
+ kind: "brave",
1425
+ path: "/Applications/Brave Browser.app/Contents/MacOS/Brave Browser"
1426
+ },
1427
+ {
1428
+ kind: "brave",
1429
+ path: path.join(os.homedir(), "Applications/Brave Browser.app/Contents/MacOS/Brave Browser")
1430
+ },
1431
+ {
1432
+ kind: "edge",
1433
+ path: "/Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge"
1434
+ },
1435
+ {
1436
+ kind: "edge",
1437
+ path: path.join(os.homedir(), "Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge")
1438
+ },
1439
+ {
1440
+ kind: "chromium",
1441
+ path: "/Applications/Chromium.app/Contents/MacOS/Chromium"
1442
+ },
1443
+ {
1444
+ kind: "chromium",
1445
+ path: path.join(os.homedir(), "Applications/Chromium.app/Contents/MacOS/Chromium")
1446
+ },
1447
+ {
1448
+ kind: "canary",
1449
+ path: "/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary"
1450
+ },
1451
+ {
1452
+ kind: "canary",
1453
+ path: path.join(os.homedir(), "Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary")
1454
+ }
1455
+ ]);
1456
+ }
1457
+ function findChromeExecutableLinux() {
1458
+ return findFirstExecutable([
1459
+ {
1460
+ kind: "chrome",
1461
+ path: "/usr/bin/google-chrome"
1462
+ },
1463
+ {
1464
+ kind: "chrome",
1465
+ path: "/usr/bin/google-chrome-stable"
1466
+ },
1467
+ {
1468
+ kind: "chrome",
1469
+ path: "/usr/bin/chrome"
1470
+ },
1471
+ {
1472
+ kind: "brave",
1473
+ path: "/usr/bin/brave-browser"
1474
+ },
1475
+ {
1476
+ kind: "brave",
1477
+ path: "/usr/bin/brave-browser-stable"
1478
+ },
1479
+ {
1480
+ kind: "brave",
1481
+ path: "/usr/bin/brave"
1482
+ },
1483
+ {
1484
+ kind: "brave",
1485
+ path: "/snap/bin/brave"
1486
+ },
1487
+ {
1488
+ kind: "edge",
1489
+ path: "/usr/bin/microsoft-edge"
1490
+ },
1491
+ {
1492
+ kind: "edge",
1493
+ path: "/usr/bin/microsoft-edge-stable"
1494
+ },
1495
+ {
1496
+ kind: "chromium",
1497
+ path: "/usr/bin/chromium"
1498
+ },
1499
+ {
1500
+ kind: "chromium",
1501
+ path: "/usr/bin/chromium-browser"
1502
+ },
1503
+ {
1504
+ kind: "chromium",
1505
+ path: "/snap/bin/chromium"
1506
+ }
1507
+ ]);
1508
+ }
1509
+ function findChromeExecutableWindows() {
1510
+ const localAppData = process.env.LOCALAPPDATA ?? "";
1511
+ const programFiles = process.env.ProgramFiles ?? "C:\\Program Files";
1512
+ const programFilesX86 = process.env["ProgramFiles(x86)"] ?? "C:\\Program Files (x86)";
1513
+ const joinWin = path.win32.join;
1514
+ const candidates = [];
1515
+ if (localAppData) {
1516
+ candidates.push({
1517
+ kind: "chrome",
1518
+ path: joinWin(localAppData, "Google", "Chrome", "Application", "chrome.exe")
1519
+ });
1520
+ candidates.push({
1521
+ kind: "brave",
1522
+ path: joinWin(localAppData, "BraveSoftware", "Brave-Browser", "Application", "brave.exe")
1523
+ });
1524
+ candidates.push({
1525
+ kind: "edge",
1526
+ path: joinWin(localAppData, "Microsoft", "Edge", "Application", "msedge.exe")
1527
+ });
1528
+ candidates.push({
1529
+ kind: "chromium",
1530
+ path: joinWin(localAppData, "Chromium", "Application", "chrome.exe")
1531
+ });
1532
+ candidates.push({
1533
+ kind: "canary",
1534
+ path: joinWin(localAppData, "Google", "Chrome SxS", "Application", "chrome.exe")
1535
+ });
1536
+ }
1537
+ candidates.push({
1538
+ kind: "chrome",
1539
+ path: joinWin(programFiles, "Google", "Chrome", "Application", "chrome.exe")
1540
+ });
1541
+ candidates.push({
1542
+ kind: "chrome",
1543
+ path: joinWin(programFilesX86, "Google", "Chrome", "Application", "chrome.exe")
1544
+ });
1545
+ candidates.push({
1546
+ kind: "brave",
1547
+ path: joinWin(programFiles, "BraveSoftware", "Brave-Browser", "Application", "brave.exe")
1548
+ });
1549
+ candidates.push({
1550
+ kind: "brave",
1551
+ path: joinWin(programFilesX86, "BraveSoftware", "Brave-Browser", "Application", "brave.exe")
1552
+ });
1553
+ candidates.push({
1554
+ kind: "edge",
1555
+ path: joinWin(programFiles, "Microsoft", "Edge", "Application", "msedge.exe")
1556
+ });
1557
+ candidates.push({
1558
+ kind: "edge",
1559
+ path: joinWin(programFilesX86, "Microsoft", "Edge", "Application", "msedge.exe")
1560
+ });
1561
+ return findFirstExecutable(candidates);
1562
+ }
1563
+ function resolveBrowserExecutableForPlatform(resolved, platform) {
1564
+ if (resolved.executablePath) {
1565
+ if (!exists$1(resolved.executablePath)) throw new Error(`browser.executablePath not found: ${resolved.executablePath}`);
1566
+ return {
1567
+ kind: "custom",
1568
+ path: resolved.executablePath
1569
+ };
1570
+ }
1571
+ const detected = detectDefaultChromiumExecutable(platform);
1572
+ if (detected) return detected;
1573
+ if (platform === "darwin") return findChromeExecutableMac();
1574
+ if (platform === "linux") return findChromeExecutableLinux();
1575
+ if (platform === "win32") return findChromeExecutableWindows();
1576
+ return null;
1577
+ }
1578
+
1579
+ //#endregion
1580
+ //#region src/browser/chrome.profile-decoration.ts
1581
+ function decoratedMarkerPath(userDataDir) {
1582
+ return path.join(userDataDir, ".openclaw-profile-decorated");
1583
+ }
1584
+ function safeReadJson(filePath) {
1585
+ try {
1586
+ if (!fs.existsSync(filePath)) return null;
1587
+ const raw = fs.readFileSync(filePath, "utf-8");
1588
+ const parsed = JSON.parse(raw);
1589
+ if (typeof parsed !== "object" || parsed === null || Array.isArray(parsed)) return null;
1590
+ return parsed;
1591
+ } catch {
1592
+ return null;
1593
+ }
1594
+ }
1595
+ function safeWriteJson(filePath, data) {
1596
+ fs.mkdirSync(path.dirname(filePath), { recursive: true });
1597
+ fs.writeFileSync(filePath, JSON.stringify(data, null, 2));
1598
+ }
1599
+ function setDeep(obj, keys, value) {
1600
+ let node = obj;
1601
+ for (const key of keys.slice(0, -1)) {
1602
+ const next = node[key];
1603
+ if (typeof next !== "object" || next === null || Array.isArray(next)) node[key] = {};
1604
+ node = node[key];
1605
+ }
1606
+ node[keys[keys.length - 1] ?? ""] = value;
1607
+ }
1608
+ function parseHexRgbToSignedArgbInt(hex) {
1609
+ const cleaned = hex.trim().replace(/^#/, "");
1610
+ if (!/^[0-9a-fA-F]{6}$/.test(cleaned)) return null;
1611
+ const argbUnsigned = 255 << 24 | Number.parseInt(cleaned, 16);
1612
+ return argbUnsigned > 2147483647 ? argbUnsigned - 4294967296 : argbUnsigned;
1613
+ }
1614
+ function isProfileDecorated(userDataDir, desiredName, desiredColorHex) {
1615
+ const desiredColorInt = parseHexRgbToSignedArgbInt(desiredColorHex);
1616
+ const localStatePath = path.join(userDataDir, "Local State");
1617
+ const preferencesPath = path.join(userDataDir, "Default", "Preferences");
1618
+ const profile = safeReadJson(localStatePath)?.profile;
1619
+ const infoCache = typeof profile === "object" && profile !== null && !Array.isArray(profile) ? profile.info_cache : null;
1620
+ const info = typeof infoCache === "object" && infoCache !== null && !Array.isArray(infoCache) && typeof infoCache.Default === "object" && infoCache.Default !== null && !Array.isArray(infoCache.Default) ? infoCache.Default : null;
1621
+ const prefs = safeReadJson(preferencesPath);
1622
+ const browserTheme = (() => {
1623
+ const browser = prefs?.browser;
1624
+ const theme = typeof browser === "object" && browser !== null && !Array.isArray(browser) ? browser.theme : null;
1625
+ return typeof theme === "object" && theme !== null && !Array.isArray(theme) ? theme : null;
1626
+ })();
1627
+ const autogeneratedTheme = (() => {
1628
+ const autogenerated = prefs?.autogenerated;
1629
+ const theme = typeof autogenerated === "object" && autogenerated !== null && !Array.isArray(autogenerated) ? autogenerated.theme : null;
1630
+ return typeof theme === "object" && theme !== null && !Array.isArray(theme) ? theme : null;
1631
+ })();
1632
+ const nameOk = typeof info?.name === "string" ? info.name === desiredName : true;
1633
+ if (desiredColorInt == null) return nameOk;
1634
+ const localSeedOk = typeof info?.profile_color_seed === "number" ? info.profile_color_seed === desiredColorInt : false;
1635
+ const prefOk = typeof browserTheme?.user_color2 === "number" && browserTheme.user_color2 === desiredColorInt || typeof autogeneratedTheme?.color === "number" && autogeneratedTheme.color === desiredColorInt;
1636
+ return nameOk && localSeedOk && prefOk;
1637
+ }
1638
+ /**
1639
+ * Best-effort profile decoration (name + lobster-orange). Chrome preference keys
1640
+ * vary by version; we keep this conservative and idempotent.
1641
+ */
1642
+ function decorateOpenClawProfile(userDataDir, opts) {
1643
+ const desiredName = opts?.name ?? DEFAULT_OPENCLAW_BROWSER_PROFILE_NAME;
1644
+ const desiredColor = (opts?.color ?? DEFAULT_OPENCLAW_BROWSER_COLOR).toUpperCase();
1645
+ const desiredColorInt = parseHexRgbToSignedArgbInt(desiredColor);
1646
+ const localStatePath = path.join(userDataDir, "Local State");
1647
+ const preferencesPath = path.join(userDataDir, "Default", "Preferences");
1648
+ const localState = safeReadJson(localStatePath) ?? {};
1649
+ setDeep(localState, [
1650
+ "profile",
1651
+ "info_cache",
1652
+ "Default",
1653
+ "name"
1654
+ ], desiredName);
1655
+ setDeep(localState, [
1656
+ "profile",
1657
+ "info_cache",
1658
+ "Default",
1659
+ "shortcut_name"
1660
+ ], desiredName);
1661
+ setDeep(localState, [
1662
+ "profile",
1663
+ "info_cache",
1664
+ "Default",
1665
+ "user_name"
1666
+ ], desiredName);
1667
+ setDeep(localState, [
1668
+ "profile",
1669
+ "info_cache",
1670
+ "Default",
1671
+ "profile_color"
1672
+ ], desiredColor);
1673
+ setDeep(localState, [
1674
+ "profile",
1675
+ "info_cache",
1676
+ "Default",
1677
+ "user_color"
1678
+ ], desiredColor);
1679
+ if (desiredColorInt != null) {
1680
+ setDeep(localState, [
1681
+ "profile",
1682
+ "info_cache",
1683
+ "Default",
1684
+ "profile_color_seed"
1685
+ ], desiredColorInt);
1686
+ setDeep(localState, [
1687
+ "profile",
1688
+ "info_cache",
1689
+ "Default",
1690
+ "profile_highlight_color"
1691
+ ], desiredColorInt);
1692
+ setDeep(localState, [
1693
+ "profile",
1694
+ "info_cache",
1695
+ "Default",
1696
+ "default_avatar_fill_color"
1697
+ ], desiredColorInt);
1698
+ setDeep(localState, [
1699
+ "profile",
1700
+ "info_cache",
1701
+ "Default",
1702
+ "default_avatar_stroke_color"
1703
+ ], desiredColorInt);
1704
+ }
1705
+ safeWriteJson(localStatePath, localState);
1706
+ const prefs = safeReadJson(preferencesPath) ?? {};
1707
+ setDeep(prefs, ["profile", "name"], desiredName);
1708
+ setDeep(prefs, ["profile", "profile_color"], desiredColor);
1709
+ setDeep(prefs, ["profile", "user_color"], desiredColor);
1710
+ if (desiredColorInt != null) {
1711
+ setDeep(prefs, [
1712
+ "autogenerated",
1713
+ "theme",
1714
+ "color"
1715
+ ], desiredColorInt);
1716
+ setDeep(prefs, [
1717
+ "browser",
1718
+ "theme",
1719
+ "user_color2"
1720
+ ], desiredColorInt);
1721
+ }
1722
+ safeWriteJson(preferencesPath, prefs);
1723
+ try {
1724
+ fs.writeFileSync(decoratedMarkerPath(userDataDir), `${Date.now()}\n`, "utf-8");
1725
+ } catch {}
1726
+ }
1727
+ function ensureProfileCleanExit(userDataDir) {
1728
+ const preferencesPath = path.join(userDataDir, "Default", "Preferences");
1729
+ const prefs = safeReadJson(preferencesPath) ?? {};
1730
+ setDeep(prefs, ["exit_type"], "Normal");
1731
+ setDeep(prefs, ["exited_cleanly"], true);
1732
+ safeWriteJson(preferencesPath, prefs);
1733
+ }
1734
+
1735
+ //#endregion
1736
+ //#region src/browser/chrome.ts
1737
+ const log = createSubsystemLogger("browser").child("chrome");
1738
+ function exists(filePath) {
1739
+ try {
1740
+ return fs.existsSync(filePath);
1741
+ } catch {
1742
+ return false;
1743
+ }
1744
+ }
1745
+ function resolveBrowserExecutable(resolved) {
1746
+ return resolveBrowserExecutableForPlatform(resolved, process.platform);
1747
+ }
1748
+ function resolveOpenClawUserDataDir(profileName = DEFAULT_OPENCLAW_BROWSER_PROFILE_NAME) {
1749
+ return path.join(CONFIG_DIR, "browser", profileName, "user-data");
1750
+ }
1751
+ function cdpUrlForPort(cdpPort) {
1752
+ return `http://127.0.0.1:${cdpPort}`;
1753
+ }
1754
+ async function isChromeReachable(cdpUrl, timeoutMs = 500) {
1755
+ const version = await fetchChromeVersion(cdpUrl, timeoutMs);
1756
+ return Boolean(version);
1757
+ }
1758
+ async function fetchChromeVersion(cdpUrl, timeoutMs = 500) {
1759
+ const ctrl = new AbortController();
1760
+ const t = setTimeout(() => ctrl.abort(), timeoutMs);
1761
+ try {
1762
+ const versionUrl = appendCdpPath(cdpUrl, "/json/version");
1763
+ const res = await fetch(versionUrl, {
1764
+ signal: ctrl.signal,
1765
+ headers: getHeadersWithAuth(versionUrl)
1766
+ });
1767
+ if (!res.ok) return null;
1768
+ const data = await res.json();
1769
+ if (!data || typeof data !== "object") return null;
1770
+ return data;
1771
+ } catch {
1772
+ return null;
1773
+ } finally {
1774
+ clearTimeout(t);
1775
+ }
1776
+ }
1777
+ async function getChromeWebSocketUrl(cdpUrl, timeoutMs = 500) {
1778
+ const version = await fetchChromeVersion(cdpUrl, timeoutMs);
1779
+ const wsUrl = String(version?.webSocketDebuggerUrl ?? "").trim();
1780
+ if (!wsUrl) return null;
1781
+ return normalizeCdpWsUrl(wsUrl, cdpUrl);
1782
+ }
1783
+ async function canOpenWebSocket(wsUrl, timeoutMs = 800) {
1784
+ return await new Promise((resolve) => {
1785
+ const headers = getHeadersWithAuth(wsUrl);
1786
+ const ws = new WebSocket(wsUrl, {
1787
+ handshakeTimeout: timeoutMs,
1788
+ ...Object.keys(headers).length ? { headers } : {}
1789
+ });
1790
+ const timer = setTimeout(() => {
1791
+ try {
1792
+ ws.terminate();
1793
+ } catch {}
1794
+ resolve(false);
1795
+ }, Math.max(50, timeoutMs + 25));
1796
+ ws.once("open", () => {
1797
+ clearTimeout(timer);
1798
+ try {
1799
+ ws.close();
1800
+ } catch {}
1801
+ resolve(true);
1802
+ });
1803
+ ws.once("error", () => {
1804
+ clearTimeout(timer);
1805
+ resolve(false);
1806
+ });
1807
+ });
1808
+ }
1809
+ async function isChromeCdpReady(cdpUrl, timeoutMs = 500, handshakeTimeoutMs = 800) {
1810
+ const wsUrl = await getChromeWebSocketUrl(cdpUrl, timeoutMs);
1811
+ if (!wsUrl) return false;
1812
+ return await canOpenWebSocket(wsUrl, handshakeTimeoutMs);
1813
+ }
1814
+ async function launchOpenClawChrome(resolved, profile) {
1815
+ if (!profile.cdpIsLoopback) throw new Error(`Profile "${profile.name}" is remote; cannot launch local Chrome.`);
1816
+ await ensurePortAvailable(profile.cdpPort);
1817
+ const exe = resolveBrowserExecutable(resolved);
1818
+ if (!exe) throw new Error("No supported browser found (Chrome/Brave/Edge/Chromium on macOS, Linux, or Windows).");
1819
+ const userDataDir = resolveOpenClawUserDataDir(profile.name);
1820
+ fs.mkdirSync(userDataDir, { recursive: true });
1821
+ const needsDecorate = !isProfileDecorated(userDataDir, profile.name, (profile.color ?? DEFAULT_OPENCLAW_BROWSER_COLOR).toUpperCase());
1822
+ const spawnOnce = () => {
1823
+ const args = [
1824
+ `--remote-debugging-port=${profile.cdpPort}`,
1825
+ `--user-data-dir=${userDataDir}`,
1826
+ "--no-first-run",
1827
+ "--no-default-browser-check",
1828
+ "--disable-sync",
1829
+ "--disable-background-networking",
1830
+ "--disable-component-update",
1831
+ "--disable-features=Translate,MediaRouter",
1832
+ "--disable-session-crashed-bubble",
1833
+ "--hide-crash-restore-bubble",
1834
+ "--password-store=basic"
1835
+ ];
1836
+ if (resolved.headless) {
1837
+ args.push("--headless=new");
1838
+ args.push("--disable-gpu");
1839
+ }
1840
+ if (resolved.noSandbox) {
1841
+ args.push("--no-sandbox");
1842
+ args.push("--disable-setuid-sandbox");
1843
+ }
1844
+ if (process.platform === "linux") args.push("--disable-dev-shm-usage");
1845
+ args.push("about:blank");
1846
+ return spawn(exe.path, args, {
1847
+ stdio: "pipe",
1848
+ env: {
1849
+ ...process.env,
1850
+ HOME: os.homedir()
1851
+ }
1852
+ });
1853
+ };
1854
+ const startedAt = Date.now();
1855
+ const localStatePath = path.join(userDataDir, "Local State");
1856
+ const preferencesPath = path.join(userDataDir, "Default", "Preferences");
1857
+ if (!exists(localStatePath) || !exists(preferencesPath)) {
1858
+ const bootstrap = spawnOnce();
1859
+ const deadline = Date.now() + 1e4;
1860
+ while (Date.now() < deadline) {
1861
+ if (exists(localStatePath) && exists(preferencesPath)) break;
1862
+ await new Promise((r) => setTimeout(r, 100));
1863
+ }
1864
+ try {
1865
+ bootstrap.kill("SIGTERM");
1866
+ } catch {}
1867
+ const exitDeadline = Date.now() + 5e3;
1868
+ while (Date.now() < exitDeadline) {
1869
+ if (bootstrap.exitCode != null) break;
1870
+ await new Promise((r) => setTimeout(r, 50));
1871
+ }
1872
+ }
1873
+ if (needsDecorate) try {
1874
+ decorateOpenClawProfile(userDataDir, {
1875
+ name: profile.name,
1876
+ color: profile.color
1877
+ });
1878
+ log.info(`🦞 openclaw browser profile decorated (${profile.color})`);
1879
+ } catch (err) {
1880
+ log.warn(`openclaw browser profile decoration failed: ${String(err)}`);
1881
+ }
1882
+ try {
1883
+ ensureProfileCleanExit(userDataDir);
1884
+ } catch (err) {
1885
+ log.warn(`openclaw browser clean-exit prefs failed: ${String(err)}`);
1886
+ }
1887
+ const proc = spawnOnce();
1888
+ const readyDeadline = Date.now() + 15e3;
1889
+ while (Date.now() < readyDeadline) {
1890
+ if (await isChromeReachable(profile.cdpUrl, 500)) break;
1891
+ await new Promise((r) => setTimeout(r, 200));
1892
+ }
1893
+ if (!await isChromeReachable(profile.cdpUrl, 500)) {
1894
+ try {
1895
+ proc.kill("SIGKILL");
1896
+ } catch {}
1897
+ throw new Error(`Failed to start Chrome CDP on port ${profile.cdpPort} for profile "${profile.name}".`);
1898
+ }
1899
+ const pid = proc.pid ?? -1;
1900
+ log.info(`🦞 openclaw browser started (${exe.kind}) profile "${profile.name}" on 127.0.0.1:${profile.cdpPort} (pid ${pid})`);
1901
+ return {
1902
+ pid,
1903
+ exe,
1904
+ userDataDir,
1905
+ cdpPort: profile.cdpPort,
1906
+ startedAt,
1907
+ proc
1908
+ };
1909
+ }
1910
+ async function stopOpenClawChrome(running, timeoutMs = 2500) {
1911
+ const proc = running.proc;
1912
+ if (proc.killed) return;
1913
+ try {
1914
+ proc.kill("SIGTERM");
1915
+ } catch {}
1916
+ const start = Date.now();
1917
+ while (Date.now() - start < timeoutMs) {
1918
+ if (!proc.exitCode && proc.killed) break;
1919
+ if (!await isChromeReachable(cdpUrlForPort(running.cdpPort), 200)) return;
1920
+ await new Promise((r) => setTimeout(r, 100));
1921
+ }
1922
+ try {
1923
+ proc.kill("SIGKILL");
1924
+ } catch {}
1925
+ }
1926
+
1927
+ //#endregion
1928
+ //#region src/infra/errors.ts
1929
+ function extractErrorCode(err) {
1930
+ if (!err || typeof err !== "object") return;
1931
+ const code = err.code;
1932
+ if (typeof code === "string") return code;
1933
+ if (typeof code === "number") return String(code);
1934
+ }
1935
+ function formatErrorMessage(err) {
1936
+ if (err instanceof Error) return err.message || err.name || "Error";
1937
+ if (typeof err === "string") return err;
1938
+ if (typeof err === "number" || typeof err === "boolean" || typeof err === "bigint") return String(err);
1939
+ try {
1940
+ return JSON.stringify(err);
1941
+ } catch {
1942
+ return Object.prototype.toString.call(err);
1943
+ }
1944
+ }
1945
+ function formatUncaughtError(err) {
1946
+ if (extractErrorCode(err) === "INVALID_CONFIG") return formatErrorMessage(err);
1947
+ if (err instanceof Error) return err.stack ?? err.message ?? err.name;
1948
+ return formatErrorMessage(err);
1949
+ }
1950
+
1951
+ //#endregion
1952
+ export { DEFAULT_OPENCLAW_BROWSER_ENABLED as A, stopChromeExtensionRelayServer as C, DEFAULT_BROWSER_DEFAULT_PROFILE_NAME as D, DEFAULT_AI_SNAPSHOT_MAX_CHARS as E, DEFAULT_BROWSER_EVALUATE_ENABLED as O, ensureChromeExtensionRelayServer as S, DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS as T, formatAriaSnapshot as _, isChromeCdpReady as a, appendCdpPath as b, resolveOpenClawUserDataDir as c, ensurePortAvailable as d, inspectPortUsage as f, createTargetViaCdp as g, captureScreenshot as h, getChromeWebSocketUrl as i, DEFAULT_OPENCLAW_BROWSER_PROFILE_NAME as j, DEFAULT_OPENCLAW_BROWSER_COLOR as k, stopOpenClawChrome as l, formatPortDiagnostics as m, formatErrorMessage as n, isChromeReachable as o, resolveLsofCommandSync as p, formatUncaughtError as r, launchOpenClawChrome as s, extractErrorCode as t, resolveBrowserExecutableForPlatform as u, normalizeCdpWsUrl as v, DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH as w, getHeadersWithAuth as x, snapshotAria as y };