@gguf/claw 2026.2.4 → 2026.2.5

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 (616) hide show
  1. package/CHANGELOG.md +50 -1
  2. package/LICENSE +1 -1
  3. package/README.md +50 -43
  4. package/dist/{accounts-BlHoTziG.js → accounts-BgZmhIm6.js} +4 -4
  5. package/dist/{accounts-B5QZU96b.js → accounts-Dto4p9zB.js} +2 -2
  6. package/dist/{acp-cli-DU_cVWbN.js → acp-cli-BOKabdeW.js} +15 -15
  7. package/dist/{acp-cli-O8LcQigE.js → acp-cli-BwcHtBDk.js} +19 -19
  8. package/dist/{agent-BBI-UGkN.js → agent-DztWhVCH.js} +20 -13
  9. package/dist/{agent-DuQt3QDO.js → agent-_H-0rbHV.js} +21 -14
  10. package/dist/{agent-scope-jm0ZdXwM.js → agent-scope-C9VjJXEK.js} +5 -180
  11. package/dist/{agent-scope-CrgUOY3f.js → agent-scope-CMs5Y7l-.js} +6 -181
  12. package/dist/{agent-scope-COnICB_7.js → agent-scope-Csu2B6AM.js} +2 -2
  13. package/dist/{audit-D-OqdjQu.js → audit-BWbjQmyv.js} +182 -15
  14. package/dist/{audit-CWGOX7Eh.js → audit-ZY6Dk5Ec.js} +183 -16
  15. package/dist/{auth-viF_w60n.js → auth-CbhB03Rz.js} +2 -2
  16. package/dist/{auth-DK3l201_.js → auth-DksjO6WG.js} +2 -2
  17. package/dist/{auth-health-DcKoxhDo.js → auth-health-C4bElkgf.js} +1 -1
  18. package/dist/{auth-health-Ba9GTScq.js → auth-health-Ctf-_JFE.js} +1 -1
  19. package/dist/{auth-profiles-CfFGCDJa.js → auth-profiles-CYBuGiBb.js} +38 -13
  20. package/dist/build-info.json +2 -2
  21. package/dist/{call-CfqL-4Nc.js → call-90HgQQ8o.js} +34 -8
  22. package/dist/{call-CPBhMXxo.js → call-BTbA5OB4.js} +35 -9
  23. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  24. package/dist/canvas-host/a2ui/a2ui.bundle.js +29 -44
  25. package/dist/{channel-options-eRR8_a8h.js → channel-options-DrUmtdd9.js} +3 -3
  26. package/dist/{channel-options-BCSvD6JM.js → channel-options-uftAnT5P.js} +7 -7
  27. package/dist/{channel-selection-BAwiO0li.js → channel-selection-CJWYmCLf.js} +2 -2
  28. package/dist/{channel-selection-BCn8_qun.js → channel-selection-PZuuCvrp.js} +2 -2
  29. package/dist/{channel-summary-BkqO8zZ9.js → channel-summary-D9nzC5WB.js} +8 -42
  30. package/dist/{channel-summary-C8GoEKgH.js → channel-summary-DUiKDBLv.js} +9 -43
  31. package/dist/{channels-cli-CBGINubh.js → channels-cli-PAlqhOZ7.js} +56 -54
  32. package/dist/{channels-cli-yQo-Rzw6.js → channels-cli-PPk5wwuy.js} +59 -57
  33. package/dist/{channels-status-issues-C9vMMPG0.js → channels-status-issues-CJ8PJgDc.js} +1 -1
  34. package/dist/{channels-status-issues-DRXQXvhY.js → channels-status-issues-CrS1r5sr.js} +1 -1
  35. package/dist/{chrome-DlqPCh1y.js → chrome-B3IuUad-.js} +2 -2
  36. package/dist/{chrome-D2LUApAY.js → chrome-BNSd7Bie.js} +5 -5
  37. package/dist/{clack-prompter-OmDa1Hm1.js → clack-prompter-CEKDd_Vg.js} +5 -5
  38. package/dist/{clack-prompter-BJuVh97L.js → clack-prompter-DuBVnTKy.js} +4 -4
  39. package/dist/cli/daemon-cli.js +1 -1
  40. package/dist/cli-DBAccB3n.js +86 -0
  41. package/dist/cli-DD5dW58-.js +89 -0
  42. package/dist/{client-zqMhLTAX.js → client-BYVbRnuQ.js} +13 -5
  43. package/dist/{client-cU7Xg1MO.js → client-CxbkcEZ7.js} +12 -4
  44. package/dist/{command-options-51bBgSJL.js → command-options-DUUINcz0.js} +3 -3
  45. package/dist/{commands-DMKDOFmC.js → commands-DAC7XMAT.js} +5 -4
  46. package/dist/completion-cli-BPIeQDFy.js +773 -0
  47. package/dist/{completion-cli-BoF86Oeq.js → completion-cli-BbhA_JbG.js} +62 -15
  48. package/dist/{config-qgIz1lbh.js → config-CAuZ-EkU.js} +93 -31
  49. package/dist/{config-CGsoho7J.js → config-CG73z4h6.js} +61 -28
  50. package/dist/{config-DCT1RAo6.js → config-CKLedg5Y.js} +92 -30
  51. package/dist/{config-guard-CJuPkD5Y.js → config-guard-a5ynrKd-.js} +181 -57
  52. package/dist/{configure-C1_0rFdQ.js → configure-B47GYdlB.js} +33 -23
  53. package/dist/{configure-D0OAmW2s.js → configure-ChnTy7Jz.js} +31 -21
  54. package/dist/{control-service-BW5sW2U1.js → control-service-CS61Road.js} +13 -6
  55. package/dist/{control-service-Ds9ompnU.js → control-service-D2E9NKqQ.js} +12 -5
  56. package/dist/control-ui/assets/{index-RwcW4Xl0.css → index-BoXosYY6.css} +1 -1
  57. package/dist/control-ui/assets/index-Dm6g1E26.js +7553 -0
  58. package/dist/control-ui/assets/index-Dm6g1E26.js.map +1 -0
  59. package/dist/control-ui/index.html +2 -2
  60. package/dist/{cron-cli-Bn_e3WGb.js → cron-cli-CssI71-c.js} +20 -19
  61. package/dist/{cron-cli-BVARiNrv.js → cron-cli-Ys53MyTg.js} +24 -23
  62. package/dist/{daemon-cli-fHXAapHL.js → daemon-cli-B6aLZ8OE.js} +28 -23
  63. package/dist/{daemon-cli-yy_MAYxv.js → daemon-cli-CMKd_D6h.js} +26 -21
  64. package/dist/{daemon-runtime-vNkYv9tq.js → daemon-runtime-BCn_QIHK.js} +64 -7
  65. package/dist/{daemon-runtime-ELWW7q0C.js → daemon-runtime-DMd0mgTK.js} +64 -7
  66. package/dist/{deliver-Bsvrattg.js → deliver-C3bnXkg5.js} +12 -10
  67. package/dist/{deliver-Dl8TEyHM.js → deliver-CZPhTA7x.js} +7 -5
  68. package/dist/{deliver-eE21zdeQ.js → deliver-Cau4HL7W.js} +11 -9
  69. package/dist/{deps-BrcOX0ht.js → deps-BG1LonF6.js} +2 -2
  70. package/dist/{deps-wXkiMwLZ.js → deps-ytXmI88x.js} +2 -2
  71. package/dist/{devices-cli-BjlwgE6B.js → devices-cli-Cm0ENrXH.js} +16 -16
  72. package/dist/{devices-cli-BVc_Ic5O.js → devices-cli-D_rnGkqO.js} +12 -12
  73. package/dist/{directory-cli-cc9ivzEM.js → directory-cli-CGLolzJC.js} +15 -15
  74. package/dist/{directory-cli-CULRQACb.js → directory-cli-CTtv_AB7.js} +19 -19
  75. package/dist/{dispatcher-BNB5aCZ6.js → dispatcher-6oI-H42S.js} +1 -1
  76. package/dist/{dns-cli-BwDdBlsK.js → dns-cli-BRkJGLqK.js} +15 -15
  77. package/dist/{dns-cli-B79COhmu.js → dns-cli-CoeI4817.js} +11 -11
  78. package/dist/{docs-cli-BM55jf4Y.js → docs-cli-BH9bMx3a.js} +7 -7
  79. package/dist/{docs-cli-t7IEzxr8.js → docs-cli-Bh1Coji2.js} +10 -10
  80. package/dist/{doctor-CT9JPoCt.js → doctor-CwSrWRCp.js} +43 -38
  81. package/dist/{doctor-OmfNRlMS.js → doctor-JnMryC_M.js} +40 -35
  82. package/dist/entry.js +12 -8
  83. package/dist/{env-DOcCob95.js → env-0_mKbEWW.js} +2 -2
  84. package/dist/{errors-DdT2Dtkb.js → errors-CZ9opC6L.js} +4 -4
  85. package/dist/{exec-B7WKla_0.js → exec-BMnoMcZW.js} +1 -1
  86. package/dist/{exec-CTo4hK94.js → exec-HEWTMJ7j.js} +1 -1
  87. package/dist/{exec-approvals-WdYFyy5N.js → exec-approvals-BCEFzcbC.js} +19 -2
  88. package/dist/{exec-approvals-CK-Umdr3.js → exec-approvals-DZixgolZ.js} +19 -2
  89. package/dist/{exec-approvals-cli-DD_z4fL9.js → exec-approvals-cli-D7aVv5hN.js} +19 -19
  90. package/dist/{exec-approvals-cli-BK2toX2b.js → exec-approvals-cli-DzLp5G7t.js} +23 -23
  91. package/dist/extensionAPI.js +1186 -267
  92. package/dist/{gateway-cli-BCC0T5iY.js → gateway-cli-DHP5DRUH.js} +910 -199
  93. package/dist/{gateway-cli-BTlr6Uwl.js → gateway-cli-ape0pnBU.js} +912 -202
  94. package/dist/{gateway-rpc-CMAcradB.js → gateway-rpc-C8rNIC0P.js} +3 -3
  95. package/dist/{gateway-rpc-SvVB4Fmv.js → gateway-rpc-CWnTaSEY.js} +3 -3
  96. package/dist/{github-copilot-auth-BHLcQ1sN.js → github-copilot-auth-B_lK1g__.js} +173 -87
  97. package/dist/{github-copilot-auth-BoRchp_Q.js → github-copilot-auth-C8Uf0Q03.js} +174 -88
  98. package/dist/{github-copilot-token-BEtihsn6.js → github-copilot-token-B3SA95yo.js} +8 -2
  99. package/dist/{github-copilot-token-rP-6QdKv.js → github-copilot-token-SLWintYd.js} +7 -1
  100. package/dist/{github-copilot-token-VZsS4013.js → github-copilot-token-pGSmVaW-.js} +8 -2
  101. package/dist/{gmail-setup-utils-4czdWNCN.js → gmail-setup-utils-Bi6W14MK.js} +3 -3
  102. package/dist/{gmail-setup-utils-B1CTmT2V.js → gmail-setup-utils-QpN7TEXS.js} +4 -4
  103. package/dist/{health-format-B4_A88V3.js → health-format-B3eStY5r.js} +215 -21
  104. package/dist/{health-format-Ct8J0fwc.js → health-format-ND2rUbQO.js} +213 -19
  105. package/dist/{help-format-CGcnDM3D.js → help-format-Bozi4K9H.js} +1 -1
  106. package/dist/{helpers-DfgBr1D5.js → helpers-BIc7L8EF.js} +1 -1
  107. package/dist/{helpers-Cw9kFCkw.js → helpers-D66_XoIz.js} +1 -1
  108. package/dist/{hooks-cli-NmkXLKmj.js → hooks-cli-BMu_-4Ru.js} +49 -49
  109. package/dist/{hooks-cli-B-28F__A.js → hooks-cli-CmeQxEOM.js} +45 -45
  110. package/dist/{hooks-status-I3Y60zVN.js → hooks-status-CKmUPU-M.js} +3 -3
  111. package/dist/{hooks-status-XV9oQICf.js → hooks-status-DepPyfBb.js} +4 -4
  112. package/dist/{image-ClOB6QDJ.js → image-Ca_PtqY7.js} +8 -6
  113. package/dist/{image-BYmtfVH8.js → image-CgBndiQy.js} +9 -7
  114. package/dist/{image-CXg7Z0WD.js → image-nRwqkmtf.js} +8 -6
  115. package/dist/index.js +231 -105
  116. package/dist/{installs-C5cjVarj.js → installs-BhEjOqPy.js} +43 -6
  117. package/dist/{installs-W4Pc1LJz.js → installs-DsJkyWfL.js} +43 -6
  118. package/dist/{links-C9fyAH-V.js → links-B5pRdmo1.js} +1 -1
  119. package/dist/{links-jGisPfXW.js → links-D0uzJbi6.js} +1 -1
  120. package/dist/{loader-BYWxo-_j.js → loader-_Pj-TZS2.js} +920 -491
  121. package/dist/{logging-BnUUuH3y.js → logging-Cc7m6PTv.js} +1 -1
  122. package/dist/{logging-CLCWl7Iu.js → logging-TXWhN8jG.js} +2 -2
  123. package/dist/{login-qr-C2H_iQJU.js → login-qr-BIlr0vwe.js} +12 -7
  124. package/dist/{login-qr-7WOtj6zE.js → login-qr-CcOWO_dR.js} +9 -4
  125. package/dist/{login-qr-sEcxw1_U.js → login-qr-Cmsf7BGt.js} +11 -6
  126. package/dist/{logs-cli-C5v4fEDj.js → logs-cli-5L3NxTsc.js} +19 -19
  127. package/dist/{logs-cli-nVwK5g60.js → logs-cli-DtiFFkZL.js} +15 -15
  128. package/dist/{manager-rDmdE7O9.js → manager-BXiIQku7.js} +9 -7
  129. package/dist/{manager-JSP5pLyv.js → manager-C4ILl-d3.js} +10 -8
  130. package/dist/{manager-BArueSTR.js → manager-LpytrxUw.js} +12 -10
  131. package/dist/{manifest-registry-tuAcHxrV.js → manifest-registry-C69Z-I4v.js} +1 -1
  132. package/dist/{manifest-registry-BFpLJJDB.js → manifest-registry-DHaa1SJb.js} +1 -1
  133. package/dist/{message-channel-CAFcg7mw.js → message-channel-BlgPSDAh.js} +6 -1
  134. package/dist/{message-channel-CQGWXVL4.js → message-channel-Bpfe5l5f.js} +7 -2
  135. package/dist/{model-selection-Cp1maz7B.js → model-selection-DMUrNhQP.js} +41 -16
  136. package/dist/{model-selection-Cs1y6OBv.js → model-selection-mzTqrNoj.js} +38 -14
  137. package/dist/{models-cli-n9a8pESx.js → models-cli-DHzyyLvp.js} +49 -49
  138. package/dist/{models-cli-DGnLcr4X.js → models-cli-EhrWjNLH.js} +53 -53
  139. package/dist/{net-DaJz_a4n.js → net-C8YRVt16.js} +1 -1
  140. package/dist/{net-DeiCIMU6.js → net-CWMMy37F.js} +1 -1
  141. package/dist/{node-cli-rtEq-YyU.js → node-cli-2oYmIWJt.js} +30 -30
  142. package/dist/{node-cli-AOO0HsM1.js → node-cli-DH7Ykym5.js} +26 -26
  143. package/dist/{node-service-CjtBRyjp.js → node-service-BAYHx0E7.js} +2 -2
  144. package/dist/{node-service-BW_LhY5w.js → node-service-Lc1LlnFH.js} +2 -2
  145. package/dist/{nodes-cli-Coxj5hDA.js → nodes-cli-Bc5K-0Lt.js} +22 -22
  146. package/dist/{nodes-cli-ChBsNXzz.js → nodes-cli-hT8yYD7S.js} +18 -18
  147. package/dist/{nodes-screen-Ln98EX_f.js → nodes-screen-DGlNPbk4.js} +2 -2
  148. package/dist/{nodes-screen-DOhGEibx.js → nodes-screen-DT5HvhJV.js} +2 -2
  149. package/dist/{note-BFpD-42H.js → note-B5HnoeZX.js} +2 -2
  150. package/dist/{note-CBiVaqG7.js → note-Ci08TSbV.js} +1 -1
  151. package/dist/{onboard-channels-CF7lTDNu.js → onboard-channels-D-ZQTy5V.js} +9 -8
  152. package/dist/{onboard-channels-CJCy7TTQ.js → onboard-channels-DKT27PdN.js} +10 -9
  153. package/dist/{onboard-skills-DdFGj9pt.js → onboard-skills-YobctE-R.js} +259 -194
  154. package/dist/{onboard-skills-fL84FI8F.js → onboard-skills-s8J5xbUr.js} +259 -194
  155. package/dist/{onboarding-DcN1avQK.js → onboarding-BP4-5uzE.js} +96 -60
  156. package/dist/{pairing-cli-DbP9KqPL.js → pairing-cli-C8KHRjaU.js} +15 -15
  157. package/dist/{pairing-cli-B7RQFp4r.js → pairing-cli-i7wiTmYC.js} +19 -19
  158. package/dist/{pairing-labels-DK2aLSd2.js → pairing-labels-BbydDT7w.js} +1 -1
  159. package/dist/{pairing-labels-C6I3dD-m.js → pairing-labels-CtqLxbG6.js} +1 -1
  160. package/dist/{pairing-store-BnMngoWQ.js → pairing-store-DFq7WtOv.js} +2 -2
  161. package/dist/{pairing-store-DMex6WWe.js → pairing-store-DTfv_FGA.js} +1 -1
  162. package/dist/{path-env-CuGC6r1F.js → path-env-DP3DsVge.js} +2 -2
  163. package/dist/{path-env-CUhrC5DA.js → path-env-h3xp5PqO.js} +1 -1
  164. package/dist/{paths-xPuk88Yf.js → paths-B4kigINg.js} +2 -2
  165. package/dist/{paths-50eo6DV6.js → paths-Bb0nwPeu.js} +2 -2
  166. package/dist/{paths-RvF0P6tQ.js → paths-CTg8F3AE.js} +1 -1
  167. package/dist/{pi-embedded-helpers-DJgCXZEz.js → pi-embedded-helpers-BB4uACeq.js} +175 -170
  168. package/dist/{pi-embedded-helpers-DiK8Qn1l.js → pi-embedded-helpers-BxqZh6U7.js} +43 -19
  169. package/dist/{pi-embedded-helpers-CC00lEFI.js → pi-embedded-helpers-DF8SAHU-.js} +175 -170
  170. package/dist/{pi-model-discovery-DjGamP_B.js → pi-model-discovery-CV2V1HHz.js} +8 -1
  171. package/dist/{pi-model-discovery-CnK2Dol8.js → pi-model-discovery-DzEIEgHL.js} +8 -1
  172. package/dist/{pi-model-discovery-CsRo-xMp.js → pi-model-discovery-EhM2JAQo.js} +8 -1
  173. package/dist/{pi-tools.policy-DleRi9eC.js → pi-tools.policy-BQ8N5y8a.js} +5 -4
  174. package/dist/{plugin-auto-enable-JQ63k0Ce.js → plugin-auto-enable-Ci7TBlH2.js} +5 -5
  175. package/dist/{plugin-auto-enable-CIVp3SAp.js → plugin-auto-enable-DyW8lHTT.js} +4 -4
  176. package/dist/plugin-sdk/index.d.ts +228 -283
  177. package/dist/plugin-sdk/index.js +22528 -69091
  178. package/dist/plugin-sdk/pi-model-discovery-Dw3A6oXH.js +37 -0
  179. package/dist/{plugins-TrKFfrLt.js → plugins-BUPpq5aS.js} +3 -2
  180. package/dist/{plugins-D1CxUobm.js → plugins-BYIWo0Cp.js} +5 -4
  181. package/dist/{plugins-cli-17wYux52.js → plugins-cli-CGfxctIx.js} +50 -49
  182. package/dist/{plugins-cli-VyQWn_LW.js → plugins-cli-Dr_R2-FY.js} +46 -45
  183. package/dist/{ports-B27T1uRn.js → ports-0V-Mu4ch.js} +2 -2
  184. package/dist/{program-BA9_uWfO.js → program-oR55MCAT.js} +84 -81
  185. package/dist/{progress-uNDQDtGB.js → progress-xpLtQsNY.js} +1 -1
  186. package/dist/{prompt-style-gfROyHgB.js → prompt-style-vzh0MGHs.js} +1 -1
  187. package/dist/{pw-ai-BC4dLE7k.js → pw-ai-B7Fvw8DW.js} +4 -4
  188. package/dist/{pw-ai-DlTBXZjY.js → pw-ai-DYpQO6HI.js} +6 -6
  189. package/dist/{pw-ai-BEqPnalN.js → pw-ai-tNPuRNn3.js} +4 -4
  190. package/dist/{qmd-manager-8xWxIGbO.js → qmd-manager-BKkFEEN_.js} +9 -8
  191. package/dist/{plugin-sdk/qmd-manager-DvkA01DP.js → qmd-manager-CF52nuBg.js} +6 -6
  192. package/dist/{qmd-manager-BSCOmXYZ.js → qmd-manager-Dub8jfbo.js} +7 -6
  193. package/dist/{register.subclis-CWWz9WdX.js → register.subclis-BpIR6Iqi.js} +36 -30
  194. package/dist/{reply-CoztdrN_.js → reply-B8pOiUNN.js} +935 -506
  195. package/dist/rolldown-runtime-Cbj13DAv.js +20 -0
  196. package/dist/{routes-yI5QIzeL.js → routes-BSfXf8a5.js} +5 -5
  197. package/dist/{routes-Ds-tIZFJ.js → routes-DchZU3EK.js} +6 -6
  198. package/dist/{rpc-HF82_iLh.js → rpc-DqI3QH59.js} +3 -3
  199. package/dist/{rpc-HdKLb6jx.js → rpc-Vo2ACfn-.js} +3 -3
  200. package/dist/{run-main-B3krVvc1.js → run-main-DrVUUPHV.js} +84 -84
  201. package/dist/{sandbox-BXUfp_qv.js → sandbox-CV8VwPij.js} +36 -16
  202. package/dist/{sandbox-Cnq9TXEn.js → sandbox-DuqLKN5J.js} +34 -14
  203. package/dist/{sandbox-cli-C7j1V6tb.js → sandbox-cli-C0_Hrk7i.js} +25 -24
  204. package/dist/{sandbox-cli-CnS9JJlO.js → sandbox-cli-Ces6i3n2.js} +21 -20
  205. package/dist/{security-cli-Clg7RQT3.js → security-cli-CybLT9XS.js} +32 -30
  206. package/dist/{security-cli-BGd4NO4l.js → security-cli-T7yrd3lb.js} +28 -26
  207. package/dist/{server-context-D2cv-pIA.js → server-context-vChIAqjH.js} +6 -6
  208. package/dist/{server-context-CM_E6wD5.js → server-context-yKyxyxOJ.js} +5 -5
  209. package/dist/{server-node-events-IMwI538C.js → server-node-events-BR2vHqf6.js} +44 -43
  210. package/dist/{server-node-events-C5EqDe_U.js → server-node-events-D39FA0NG.js} +48 -47
  211. package/dist/{service-CAxAjHNB.js → service-BZesBIaG.js} +3 -3
  212. package/dist/{service-BoDHq_LN.js → service-_JwSmGSn.js} +2 -2
  213. package/dist/{service-audit-Bf33pqEM.js → service-audit-C-IA4omi.js} +6 -6
  214. package/dist/{service-audit-DBSAGhm8.js → service-audit-DDX1kO3k.js} +6 -6
  215. package/dist/session-cost-usage-BTXosU1k.js +692 -0
  216. package/dist/session-cost-usage-CBP4Hv9D.js +692 -0
  217. package/dist/session-key-CZkcvAtx.js +177 -0
  218. package/dist/session-key-Dm2EOhrH.js +177 -0
  219. package/dist/{shared-ChNOqAzp.js → shared-BmtNKsPq.js} +4 -4
  220. package/dist/{shared-D42-KbPa.js → shared-C1XLEyB0.js} +3 -3
  221. package/dist/{shared-xZjRQa6y.js → shared-C8_5pNbb.js} +4 -4
  222. package/dist/{shared-DBGw227P.js → shared-fnGLWyZ6.js} +3 -3
  223. package/dist/skill-scanner-BoGjHXUZ.js +255 -0
  224. package/dist/skill-scanner-Bp1D9gra.js +255 -0
  225. package/dist/{skills-DtwGIkTI.js → skills-CmU0Q92f.js} +3 -3
  226. package/dist/{skills-C4b1FA1e.js → skills-D5JDj3TR.js} +5 -5
  227. package/dist/{skills-cli-BPkuJAz9.js → skills-cli-C1yJvIkL.js} +16 -16
  228. package/dist/{skills-cli-b0ZmGlmh.js → skills-cli-DBC5zFat.js} +12 -12
  229. package/dist/{skills-status-CSCMqNZP.js → skills-status-CEvVUD3U.js} +3 -3
  230. package/dist/{skills-status-CWkBweWW.js → skills-status-DtXrj3fy.js} +2 -2
  231. package/dist/{status-BIWeu5mN.js → status-BRXuHUsK.js} +94 -58
  232. package/dist/{status-CcM6W8r4.js → status-BTGXSvZ1.js} +3 -3
  233. package/dist/{status-PjegR5Cv.js → status-DBZ5Z7ng.js} +4 -4
  234. package/dist/{subsystem-46MXi6Ip.js → subsystem-CAq3uyo7.js} +1 -1
  235. package/dist/{system-cli-B4FEIE5d.js → system-cli-Dqnt-b0D.js} +13 -13
  236. package/dist/{system-cli-BL_QZ1VP.js → system-cli-SJLtqI47.js} +17 -17
  237. package/dist/{systemd-DAgZTW06.js → systemd-8sIc6isV.js} +2 -2
  238. package/dist/{systemd-CNYEkRek.js → systemd-B-3NdMmA.js} +3 -3
  239. package/dist/{systemd-hints-CcgK8AJE.js → systemd-hints-DO88c_nD.js} +1 -1
  240. package/dist/{systemd-hints-okqOoOug.js → systemd-hints-Wim4Bq6j.js} +1 -1
  241. package/dist/{systemd-linger-CTe0ZDxD.js → systemd-linger-N-cIaegf.js} +8 -3
  242. package/dist/{systemd-linger-Cbkoh9qw.js → systemd-linger-SsSOsJST.js} +8 -3
  243. package/dist/{table-f0EgX-YI.js → table-CJSx0YID.js} +1 -1
  244. package/dist/{table-DuNe7Qes.js → table-CLtGjVsx.js} +2 -2
  245. package/dist/{tailscale-BUcKO8Rr.js → tailscale-9MusRvOi.js} +1 -1
  246. package/dist/{tailscale-Cvk3mQDZ.js → tailscale-BVGD9gSD.js} +2 -2
  247. package/dist/{tool-display-rIUh61kT.js → tool-display-BxZG0o1b.js} +2 -2
  248. package/dist/{tool-display-BMYWrp0L.js → tool-display-DmgKs6-V.js} +2 -2
  249. package/dist/{tui-cV-R-JXi.js → tui-DPorsF4z.js} +203 -75
  250. package/dist/{tui-DBmFYQTk.js → tui-XH6_v0qC.js} +204 -74
  251. package/dist/{tui-cli-B_CKOjZ1.js → tui-cli-DRSIBDgZ.js} +30 -29
  252. package/dist/{tui-cli-CVdJ28TX.js → tui-cli-DV_JAtnq.js} +26 -25
  253. package/dist/{update-BDyA5Iqy.js → update-DNAVcIQ7.js} +3 -3
  254. package/dist/{update-BIB5jGcv.js → update-DzMcwy1G.js} +3 -3
  255. package/dist/{update-cli-p49uMWby.js → update-cli-OAcZiYuA.js} +112 -27
  256. package/dist/{update-cli-C5vwquH_.js → update-cli-tQcy8mkI.js} +109 -23
  257. package/dist/{update-runner-8XFxQglY.js → update-runner-2i8_mIG5.js} +254 -17
  258. package/dist/{update-runner-s8Rs8ex3.js → update-runner-BDdk_K2S.js} +254 -17
  259. package/dist/usage-format-DvowRSs-.js +36 -0
  260. package/dist/usage-format-E3bMcUMV.js +36 -0
  261. package/dist/{utils-Dg0Xbl6w.js → utils-CKSrBNwq.js} +2 -2
  262. package/dist/{webhooks-cli-DkQGQ2ae.js → webhooks-cli-BztQHEco.js} +11 -11
  263. package/dist/{webhooks-cli-kRN8qR7B.js → webhooks-cli-ZAn97osC.js} +15 -15
  264. package/dist/{widearea-dns-BIhjVRG1.js → widearea-dns-CsSylzXH.js} +2 -2
  265. package/dist/{widearea-dns-D4yoSNNw.js → widearea-dns-D9Al4QRv.js} +2 -2
  266. package/dist/{ws-log-DQ6nkLys.js → ws-log-B7UNLFLC.js} +3 -3
  267. package/dist/{ws-log-C4IerKk4.js → ws-log-DJIXahf0.js} +2 -2
  268. package/dist/{wsl-DASmek7h.js → wsl-ATjkMwMA.js} +1 -1
  269. package/docs/.i18n/glossary.zh-CN.json +20 -0
  270. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  271. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  272. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  273. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  274. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  275. package/docs/bedrock.md +3 -3
  276. package/docs/channels/discord.md +2 -1
  277. package/docs/channels/feishu.md +72 -2
  278. package/docs/channels/telegram.md +19 -0
  279. package/docs/cli/devices.md +3 -0
  280. package/docs/cli/gateway.md +3 -0
  281. package/docs/cli/index.md +2 -0
  282. package/docs/cli/onboard.md +16 -2
  283. package/docs/concepts/features.md +53 -0
  284. package/docs/concepts/memory.md +1 -1
  285. package/docs/concepts/messages.md +1 -1
  286. package/docs/concepts/model-providers.md +11 -11
  287. package/docs/concepts/models.md +1 -1
  288. package/docs/concepts/multi-agent.md +2 -2
  289. package/docs/concepts/session.md +19 -3
  290. package/docs/docs.json +331 -182
  291. package/docs/gateway/cli-backends.md +7 -5
  292. package/docs/gateway/configuration-examples.md +4 -4
  293. package/docs/gateway/configuration.md +34 -16
  294. package/docs/gateway/heartbeat.md +61 -1
  295. package/docs/gateway/local-models.md +3 -3
  296. package/docs/gateway/network-model.md +17 -0
  297. package/docs/gateway/remote.md +3 -1
  298. package/docs/gateway/security/index.md +1 -1
  299. package/docs/help/faq.md +25 -26
  300. package/docs/help/submitting-a-pr.md +214 -0
  301. package/docs/help/submitting-an-issue.md +165 -0
  302. package/docs/index.md +127 -193
  303. package/docs/install/docker.md +2 -2
  304. package/docs/{platforms → install}/exe-dev.md +4 -3
  305. package/docs/{platforms → install}/fly.md +1 -1
  306. package/docs/install/index.md +4 -2
  307. package/docs/nodes/media-understanding.md +2 -2
  308. package/docs/platforms/digitalocean.md +2 -2
  309. package/docs/platforms/index.md +4 -4
  310. package/docs/platforms/linux.md +1 -1
  311. package/docs/platforms/mac/release.md +7 -7
  312. package/docs/platforms/oracle.md +1 -1
  313. package/docs/platforms/raspberry-pi.md +1 -1
  314. package/docs/providers/anthropic.md +3 -3
  315. package/docs/providers/index.md +1 -1
  316. package/docs/providers/minimax.md +3 -3
  317. package/docs/providers/models.md +1 -1
  318. package/docs/providers/ollama.md +60 -6
  319. package/docs/providers/openai.md +2 -2
  320. package/docs/providers/opencode.md +1 -1
  321. package/docs/providers/vercel-ai-gateway.md +1 -1
  322. package/docs/reference/credits.md +27 -0
  323. package/docs/reference/wizard.md +268 -0
  324. package/docs/start/bootstrapping.md +41 -0
  325. package/docs/start/docs-directory.md +64 -0
  326. package/docs/start/getting-started.md +109 -197
  327. package/docs/start/hubs.md +12 -0
  328. package/docs/start/onboarding.md +51 -81
  329. package/docs/start/openclaw.md +3 -20
  330. package/docs/start/quickstart.md +22 -0
  331. package/docs/start/setup.md +14 -1
  332. package/docs/start/wizard-cli-automation.md +141 -0
  333. package/docs/start/wizard-cli-reference.md +244 -0
  334. package/docs/start/wizard.md +48 -289
  335. package/docs/style.css +3 -0
  336. package/docs/testing.md +9 -9
  337. package/docs/token-use.md +2 -2
  338. package/docs/tools/index.md +3 -0
  339. package/docs/tools/llm-task.md +1 -1
  340. package/docs/tools/thinking.md +1 -0
  341. package/docs/tui.md +3 -0
  342. package/docs/vps.md +6 -6
  343. package/docs/web/control-ui.md +2 -0
  344. package/docs/web/dashboard.md +7 -7
  345. package/docs/zh-CN/channels/feishu.md +119 -3
  346. package/docs/zh-CN/concepts/features.md +59 -0
  347. package/docs/zh-CN/gateway/network-model.md +23 -0
  348. package/docs/zh-CN/gateway/remote.md +1 -1
  349. package/docs/zh-CN/help/faq.md +5 -5
  350. package/docs/zh-CN/index.md +124 -202
  351. package/docs/zh-CN/install/docker.md +1 -1
  352. package/docs/zh-CN/platforms/digitalocean.md +2 -2
  353. package/docs/zh-CN/platforms/index.md +4 -4
  354. package/docs/zh-CN/platforms/linux.md +1 -1
  355. package/docs/zh-CN/platforms/oracle.md +1 -1
  356. package/docs/zh-CN/platforms/raspberry-pi.md +1 -1
  357. package/docs/zh-CN/providers/ollama.md +1 -1
  358. package/docs/zh-CN/reference/credits.md +34 -0
  359. package/docs/zh-CN/start/docs-directory.md +70 -0
  360. package/docs/zh-CN/start/getting-started.md +1 -1
  361. package/docs/zh-CN/start/hubs.md +39 -30
  362. package/docs/zh-CN/start/quickstart.md +88 -0
  363. package/docs/zh-CN/vps.md +4 -4
  364. package/extensions/bluebubbles/package.json +1 -1
  365. package/extensions/bluebubbles/src/monitor.ts +9 -0
  366. package/extensions/copilot-proxy/index.ts +1 -0
  367. package/extensions/copilot-proxy/package.json +1 -1
  368. package/extensions/diagnostics-otel/package.json +1 -1
  369. package/extensions/discord/package.json +1 -1
  370. package/extensions/feishu/index.ts +49 -1
  371. package/extensions/feishu/openclaw.plugin.json +1 -0
  372. package/extensions/feishu/package.json +9 -5
  373. package/extensions/feishu/skills/feishu-doc/SKILL.md +105 -0
  374. package/extensions/feishu/skills/feishu-doc/references/block-types.md +103 -0
  375. package/extensions/feishu/skills/feishu-drive/SKILL.md +97 -0
  376. package/extensions/feishu/skills/feishu-perm/SKILL.md +119 -0
  377. package/extensions/feishu/skills/feishu-wiki/SKILL.md +111 -0
  378. package/extensions/feishu/src/accounts.ts +144 -0
  379. package/extensions/feishu/src/bitable.ts +459 -0
  380. package/extensions/feishu/src/bot.ts +871 -0
  381. package/extensions/feishu/src/channel.ts +267 -202
  382. package/extensions/feishu/src/client.ts +118 -0
  383. package/extensions/feishu/src/config-schema.ts +152 -26
  384. package/extensions/feishu/src/directory.ts +177 -0
  385. package/extensions/feishu/src/doc-schema.ts +47 -0
  386. package/extensions/feishu/src/docx.ts +521 -0
  387. package/extensions/feishu/src/drive-schema.ts +46 -0
  388. package/extensions/feishu/src/drive.ts +227 -0
  389. package/extensions/feishu/src/media.ts +527 -0
  390. package/extensions/feishu/src/mention.ts +126 -0
  391. package/extensions/feishu/src/monitor.ts +190 -0
  392. package/extensions/feishu/src/onboarding.ts +278 -200
  393. package/extensions/feishu/src/outbound.ts +40 -0
  394. package/extensions/feishu/src/perm-schema.ts +52 -0
  395. package/extensions/feishu/src/perm.ts +173 -0
  396. package/extensions/feishu/src/policy.ts +104 -0
  397. package/extensions/feishu/src/probe.ts +44 -0
  398. package/extensions/feishu/src/reactions.ts +160 -0
  399. package/extensions/feishu/src/reply-dispatcher.ts +184 -0
  400. package/extensions/feishu/src/runtime.ts +14 -0
  401. package/extensions/feishu/src/send.ts +358 -0
  402. package/extensions/feishu/src/targets.ts +78 -0
  403. package/extensions/feishu/src/tools-config.ts +21 -0
  404. package/extensions/feishu/src/types.ts +75 -0
  405. package/extensions/feishu/src/typing.ts +80 -0
  406. package/extensions/feishu/src/wiki-schema.ts +55 -0
  407. package/extensions/feishu/src/wiki.ts +232 -0
  408. package/extensions/google-antigravity-auth/package.json +1 -1
  409. package/extensions/google-gemini-cli-auth/package.json +1 -1
  410. package/extensions/googlechat/package.json +1 -1
  411. package/extensions/googlechat/src/monitor.ts +12 -1
  412. package/extensions/imessage/package.json +1 -1
  413. package/extensions/line/package.json +1 -1
  414. package/extensions/llm-task/package.json +1 -1
  415. package/extensions/lobster/package.json +1 -1
  416. package/extensions/matrix/CHANGELOG.md +6 -0
  417. package/extensions/matrix/package.json +1 -1
  418. package/extensions/matrix/src/config-schema.ts +1 -0
  419. package/extensions/matrix/src/matrix/monitor/handler.ts +9 -5
  420. package/extensions/matrix/src/types.ts +2 -0
  421. package/extensions/mattermost/package.json +1 -1
  422. package/extensions/mattermost/src/channel.test.ts +24 -0
  423. package/extensions/mattermost/src/config-schema.ts +1 -0
  424. package/extensions/mattermost/src/mattermost/monitor.ts +9 -5
  425. package/extensions/mattermost/src/types.ts +2 -0
  426. package/extensions/memory-core/package.json +1 -1
  427. package/extensions/memory-lancedb/node_modules/.bin/openai +2 -2
  428. package/extensions/memory-lancedb/node_modules/.bin/openai.CMD +2 -2
  429. package/extensions/memory-lancedb/node_modules/.bin/openai.ps1 +2 -2
  430. package/extensions/memory-lancedb/package.json +2 -2
  431. package/extensions/minimax-portal-auth/package.json +1 -1
  432. package/extensions/msteams/CHANGELOG.md +6 -0
  433. package/extensions/msteams/package.json +1 -1
  434. package/extensions/msteams/src/monitor-handler/message-handler.ts +1 -0
  435. package/extensions/msteams/src/reply-dispatcher.ts +7 -5
  436. package/extensions/nextcloud-talk/package.json +1 -1
  437. package/extensions/nextcloud-talk/src/config-schema.ts +1 -0
  438. package/extensions/nextcloud-talk/src/inbound.ts +10 -0
  439. package/extensions/nextcloud-talk/src/send.ts +7 -2
  440. package/extensions/nextcloud-talk/src/types.ts +2 -0
  441. package/extensions/nostr/CHANGELOG.md +6 -0
  442. package/extensions/nostr/package.json +1 -1
  443. package/extensions/open-prose/package.json +1 -1
  444. package/extensions/signal/package.json +1 -1
  445. package/extensions/slack/package.json +1 -1
  446. package/extensions/telegram/package.json +1 -1
  447. package/extensions/tlon/package.json +1 -1
  448. package/extensions/tlon/src/config-schema.ts +2 -0
  449. package/extensions/tlon/src/monitor/index.ts +41 -14
  450. package/extensions/tlon/src/monitor/utils.ts +1 -0
  451. package/extensions/twitch/CHANGELOG.md +6 -0
  452. package/extensions/twitch/package.json +1 -1
  453. package/extensions/twitch/src/config-schema.ts +2 -0
  454. package/extensions/twitch/src/monitor.ts +11 -0
  455. package/extensions/twitch/src/types.ts +2 -0
  456. package/extensions/voice-call/CHANGELOG.md +6 -0
  457. package/extensions/voice-call/package.json +1 -1
  458. package/extensions/voice-call/src/manager.test.ts +30 -0
  459. package/extensions/whatsapp/package.json +1 -1
  460. package/extensions/zalo/CHANGELOG.md +6 -0
  461. package/extensions/zalo/package.json +1 -1
  462. package/extensions/zalo/src/config-schema.ts +1 -0
  463. package/extensions/zalo/src/monitor.ts +11 -0
  464. package/extensions/zalo/src/types.ts +2 -0
  465. package/extensions/zalouser/CHANGELOG.md +6 -0
  466. package/extensions/zalouser/package.json +1 -1
  467. package/extensions/zalouser/src/config-schema.ts +1 -0
  468. package/extensions/zalouser/src/monitor.ts +12 -1
  469. package/extensions/zalouser/src/types.ts +2 -0
  470. package/package.json +14 -14
  471. package/dist/auth-profiles-3t9aTwDR.js +0 -11
  472. package/dist/auth-profiles-BYvLI-zr.js +0 -7
  473. package/dist/auth-profiles-DswR7tzt.js +0 -7
  474. package/dist/cli-BxIwNzhi.js +0 -89
  475. package/dist/cli-wFmvNjpg.js +0 -86
  476. package/dist/command-format-SkzzRqR1.js +0 -52
  477. package/dist/completion-cli-vxe-jqwC.js +0 -390
  478. package/dist/config-BwVg6hhl.js +0 -13
  479. package/dist/config-jKcyRiMo.js +0 -10
  480. package/dist/configure-DaecSBSI.js +0 -60
  481. package/dist/configure-t-7r9i4H.js +0 -64
  482. package/dist/control-service-Dag9b-dU.js +0 -16
  483. package/dist/control-service-DsUyuevF.js +0 -12
  484. package/dist/control-ui/assets/index-ryaCcbyp.js +0 -4584
  485. package/dist/control-ui/assets/index-ryaCcbyp.js.map +0 -1
  486. package/dist/daemon-cli-CUkUiGoK.js +0 -53
  487. package/dist/daemon-cli-D6FF4tmP.js +0 -49
  488. package/dist/deliver-BGnJ4-vz.js +0 -12
  489. package/dist/deliver-CXpx7BNb.js +0 -25
  490. package/dist/deliver-Ds2yqOA3.js +0 -21
  491. package/dist/doctor-BwqqPqMX.js +0 -58
  492. package/dist/doctor-DGrfzoKj.js +0 -62
  493. package/dist/github-copilot-token-B0CUgVkW.js +0 -4
  494. package/dist/github-copilot-token-B_uWT0Yi.js +0 -4
  495. package/dist/github-copilot-token-CXUZ9Lrb.js +0 -3
  496. package/dist/image-CgTMdnmz.js +0 -28
  497. package/dist/image-D1O-ebQc.js +0 -14
  498. package/dist/image-njq9Rf6U.js +0 -24
  499. package/dist/login-qr-BfbIJ1wP.js +0 -12
  500. package/dist/login-qr-CGWNrSQq.js +0 -9
  501. package/dist/login-qr-CUV9HZCg.js +0 -16
  502. package/dist/manager-DKpTd5pc.js +0 -10
  503. package/dist/manager-Dr_eVHpN.js +0 -10
  504. package/dist/manager-DtFcs1NT.js +0 -14
  505. package/dist/pi-model-discovery-BOramrmp.js +0 -3
  506. package/dist/pi-model-discovery-Bj98Srfa.js +0 -3
  507. package/dist/pi-model-discovery-DHPwfwKu.js +0 -3
  508. package/dist/plugin-sdk/agent-scope-qNPdmst1.js +0 -606
  509. package/dist/plugin-sdk/auth-profiles-D0LhX8iB.js +0 -7
  510. package/dist/plugin-sdk/chrome-DMuEXuKT.js +0 -1953
  511. package/dist/plugin-sdk/config-D5CsedNn.js +0 -5623
  512. package/dist/plugin-sdk/deliver-DOlMKwJ9.js +0 -12
  513. package/dist/plugin-sdk/deliver-Dl2ednkv.js +0 -2555
  514. package/dist/plugin-sdk/exec-CjyVHUuE.js +0 -1107
  515. package/dist/plugin-sdk/github-copilot-token-BoPqI-5_.js +0 -97
  516. package/dist/plugin-sdk/github-copilot-token-YEH9Bwov.js +0 -4
  517. package/dist/plugin-sdk/image-B_t0xXCb.js +0 -1419
  518. package/dist/plugin-sdk/image-DYTdodiR.js +0 -14
  519. package/dist/plugin-sdk/login-qr-B7ec28AI.js +0 -9
  520. package/dist/plugin-sdk/login-qr-BVBRxQRt.js +0 -470
  521. package/dist/plugin-sdk/manager-B-EITu1a.js +0 -10
  522. package/dist/plugin-sdk/manager-WCGzgWdf.js +0 -2868
  523. package/dist/plugin-sdk/model-selection-Bo7pocNu.js +0 -2667
  524. package/dist/plugin-sdk/paths-BFxmmTT5.js +0 -164
  525. package/dist/plugin-sdk/paths-Bkjq_KcG.js +0 -40
  526. package/dist/plugin-sdk/pi-embedded-helpers-fm5_Eokw.js +0 -8755
  527. package/dist/plugin-sdk/pi-model-discovery-CLgDNnGq.js +0 -13
  528. package/dist/plugin-sdk/pi-model-discovery-P2-pVRmz.js +0 -3
  529. package/dist/plugin-sdk/pw-ai-BN7Cwl9J.js +0 -1649
  530. package/dist/qmd-manager-CzArLjr6.js +0 -615
  531. package/dist/redact-BR0IM00e.js +0 -94
  532. package/dist/register.subclis-Bo-xmQ-W.js +0 -342
  533. package/dist/register.subclis-BuT7ZpPf.js +0 -3
  534. package/dist/restart-sentinel-CdcBcziq.js +0 -65
  535. package/dist/restart-sentinel-DywisDen.js +0 -65
  536. package/dist/runtime-guard-BG6JybtL.js +0 -60
  537. package/dist/runtime-guard-DvBpNsbR.js +0 -60
  538. package/dist/sqlite-Dz6S6ijV.js +0 -215
  539. package/dist/status.update-2ZdxeIeT.js +0 -79
  540. package/dist/status.update-ChwCPLBt.js +0 -79
  541. package/dist/systemd-linger-BZb1Uwsd.js +0 -7
  542. package/dist/systemd-linger-DemNCT5l.js +0 -9
  543. package/dist/transcript-events-fUhPZcB5.js +0 -17
  544. package/docs/_config.yml +0 -53
  545. package/docs/_layouts/default.html +0 -145
  546. package/docs/assets/docs-chat-widget.js +0 -667
  547. package/docs/assets/markdown.css +0 -179
  548. package/docs/assets/terminal.css +0 -473
  549. package/docs/assets/theme.js +0 -55
  550. package/extensions/feishu/README.md +0 -47
  551. /package/dist/{archive-BrH5WBhI.js → archive-D0z3LZDK.js} +0 -0
  552. /package/dist/{archive-mFgwsll-.js → archive-Dy3Ezb-5.js} +0 -0
  553. /package/dist/{boolean-CE7i9tBR.js → boolean-BgXe2hyu.js} +0 -0
  554. /package/dist/{brew-0HRgjHZw.js → brew-CAcErcKz.js} +0 -0
  555. /package/dist/{brew-Qdppmdlx.js → brew-CcZV0dSS.js} +0 -0
  556. /package/dist/{cli-utils-CukoNm8O.js → cli-utils-BkRQdAoC.js} +0 -0
  557. /package/dist/{cli-utils-DFbPmfWB.js → cli-utils-ByANh4Sp.js} +0 -0
  558. /package/dist/{plugin-sdk/command-format-CFzL448l.js → command-format-CFzL448l.js} +0 -0
  559. /package/dist/{command-format-BQK1OIvH.js → command-format-ChfKqObn.js} +0 -0
  560. /package/dist/{command-format-3xiXujG0.js → command-format-ayFsmwwz.js} +0 -0
  561. /package/dist/{constants-3er_81qc.js → constants-D1op9uGI.js} +0 -0
  562. /package/dist/{constants-CLUi6T-M.js → constants-HPrOsATF.js} +0 -0
  563. /package/dist/{exec-BIMFe4XS.js → exec-B8JKbXKW.js} +0 -0
  564. /package/dist/{format-BnjMmWWT.js → format-B7OjpGnt.js} +0 -0
  565. /package/dist/{format-hyFOmVZc.js → format-CS7EI0xF.js} +0 -0
  566. /package/dist/{help-format-af1XWYxC.js → help-format-CfZ94KRN.js} +0 -0
  567. /package/dist/{helpers-HZ-6iA1e.js → helpers-5yebzF4C.js} +0 -0
  568. /package/dist/{helpers-uGhPZ_kK.js → helpers-EKm3X92T.js} +0 -0
  569. /package/dist/{is-main-DD0MG3N8.js → is-main-B6kCyqsv.js} +0 -0
  570. /package/dist/{is-main-DrJg4t1R.js → is-main-qJ675wPV.js} +0 -0
  571. /package/dist/{logging-BdnOSVPD.js → logging-BWRYHvLp.js} +0 -0
  572. /package/dist/{logging-fywhKCmE.js → logging-CfEk_PnX.js} +0 -0
  573. /package/dist/{openclaw-root-Dean7Fp2.js → openclaw-root-9ILYSmJ9.js} +0 -0
  574. /package/dist/{openclaw-root-CJKDUIBP.js → openclaw-root-Cvotktkd.js} +0 -0
  575. /package/dist/{parse-BB0Cqon8.js → parse-BZz5lHzQ.js} +0 -0
  576. /package/dist/{parse-DLFPuO7w.js → parse-gTOGQPH6.js} +0 -0
  577. /package/dist/{parse-log-line-B3U8Kflp.js → parse-log-line-C6szvNBZ.js} +0 -0
  578. /package/dist/{parse-log-line-BmyeB3J2.js → parse-log-line-CARp5QyJ.js} +0 -0
  579. /package/dist/{parse-timeout-BIB19Upi.js → parse-timeout-CbVKLZ4B.js} +0 -0
  580. /package/dist/{parse-timeout-CmBmmqZZ.js → parse-timeout-Du-wHHNi.js} +0 -0
  581. /package/dist/{paths-VslOJiD2.js → paths-B1kfl4h5.js} +0 -0
  582. /package/dist/{paths-BDd7_JUB.js → paths-scjhy7N2.js} +0 -0
  583. /package/dist/{progress-Dn3kWpaL.js → progress-Da1ehW-x.js} +0 -0
  584. /package/dist/{prompt-style-D5D7b3cX.js → prompt-style-Dc0C5HC9.js} +0 -0
  585. /package/dist/{prompts-CIDznuZR.js → prompts-CXLLIBwP.js} +0 -0
  586. /package/dist/{prompts-CSlE5VZB.js → prompts-FbZThK8w.js} +0 -0
  587. /package/dist/{redact-BKh-zp-c.js → redact-B8YiFlwn.js} +0 -0
  588. /package/dist/{plugin-sdk/redact-wH73ib3-.js → redact-BIMJ3ntQ.js} +0 -0
  589. /package/dist/{redact-CDPAzwi8.js → redact-DJCFY628.js} +0 -0
  590. /package/dist/{plugin-sdk/sqlite-CqVsQPIl.js → sqlite-BKl1HJFe.js} +0 -0
  591. /package/dist/{sqlite-C59YNxdL.js → sqlite-Dnmf3LS7.js} +0 -0
  592. /package/dist/{sqlite-B_L84oiu.js → sqlite-DqUEZnjO.js} +0 -0
  593. /package/dist/{status-DkW6wMxZ.js → status-CRIEi8Mc.js} +0 -0
  594. /package/dist/{status-IDW1pkc0.js → status-tCu4RWZH.js} +0 -0
  595. /package/dist/{tailnet-BijMqkqa.js → tailnet-Byp3obcc.js} +0 -0
  596. /package/dist/{tailnet-Bk5cGmwE.js → tailnet-DLDGNuH2.js} +0 -0
  597. /package/dist/{plugin-sdk/transcript-events-DOI14YeV.js → transcript-events-CZ8CG4ht.js} +0 -0
  598. /package/dist/{transcript-events-Cj85Mq0h.js → transcript-events-ChU6IQwp.js} +0 -0
  599. /package/dist/{transcript-events-DW_H__a1.js → transcript-events-JLH5W4He.js} +0 -0
  600. /package/dist/{utils-PmTbZoD1.js → utils-DX85MiPR.js} +0 -0
  601. /package/dist/{ws-Cxo2p9fH.js → ws-CEcdsnN9.js} +0 -0
  602. /package/dist/{ws-DlSkA_BG.js → ws-D091yo4M.js} +0 -0
  603. /package/docs/{platforms → install}/gcp.md +0 -0
  604. /package/docs/{platforms → install}/hetzner.md +0 -0
  605. /package/docs/{platforms → install}/macos-vm.md +0 -0
  606. /package/docs/{northflank.mdx → install/northflank.mdx} +0 -0
  607. /package/docs/{railway.mdx → install/railway.mdx} +0 -0
  608. /package/docs/{render.mdx → install/render.mdx} +0 -0
  609. /package/docs/zh-CN/{platforms → install}/exe-dev.md +0 -0
  610. /package/docs/zh-CN/{platforms → install}/fly.md +0 -0
  611. /package/docs/zh-CN/{platforms → install}/gcp.md +0 -0
  612. /package/docs/zh-CN/{platforms → install}/hetzner.md +0 -0
  613. /package/docs/zh-CN/{platforms → install}/macos-vm.md +0 -0
  614. /package/docs/zh-CN/{northflank.mdx → install/northflank.mdx} +0 -0
  615. /package/docs/zh-CN/{railway.mdx → install/railway.mdx} +0 -0
  616. /package/docs/zh-CN/{render.mdx → install/render.mdx} +0 -0
@@ -1,1107 +0,0 @@
1
- import { a as resolveOAuthDir, n as resolveConfigPath } from "./paths-BFxmmTT5.js";
2
- import { createRequire } from "node:module";
3
- import os from "node:os";
4
- import path from "node:path";
5
- import fs from "node:fs";
6
- import { Logger } from "tslog";
7
- import json5 from "json5";
8
- import chalk, { Chalk } from "chalk";
9
- import { execFile, spawn } from "node:child_process";
10
- import { promisify } from "node:util";
11
-
12
- //#region src/plugins/runtime.ts
13
- const createEmptyRegistry = () => ({
14
- plugins: [],
15
- tools: [],
16
- hooks: [],
17
- typedHooks: [],
18
- channels: [],
19
- providers: [],
20
- gatewayHandlers: {},
21
- httpHandlers: [],
22
- httpRoutes: [],
23
- cliRegistrars: [],
24
- services: [],
25
- commands: [],
26
- diagnostics: []
27
- });
28
- const REGISTRY_STATE = Symbol.for("openclaw.pluginRegistryState");
29
- const state = (() => {
30
- const globalState = globalThis;
31
- if (!globalState[REGISTRY_STATE]) globalState[REGISTRY_STATE] = {
32
- registry: createEmptyRegistry(),
33
- key: null
34
- };
35
- return globalState[REGISTRY_STATE];
36
- })();
37
- function setActivePluginRegistry(registry, cacheKey) {
38
- state.registry = registry;
39
- state.key = cacheKey ?? null;
40
- }
41
- function getActivePluginRegistry() {
42
- return state.registry;
43
- }
44
- function requireActivePluginRegistry() {
45
- if (!state.registry) state.registry = createEmptyRegistry();
46
- return state.registry;
47
- }
48
-
49
- //#endregion
50
- //#region src/channels/registry.ts
51
- const CHAT_CHANNEL_ORDER = [
52
- "telegram",
53
- "whatsapp",
54
- "discord",
55
- "googlechat",
56
- "slack",
57
- "signal",
58
- "imessage"
59
- ];
60
- const CHANNEL_IDS = [...CHAT_CHANNEL_ORDER];
61
- const CHAT_CHANNEL_META = {
62
- telegram: {
63
- id: "telegram",
64
- label: "Telegram",
65
- selectionLabel: "Telegram (Bot API)",
66
- detailLabel: "Telegram Bot",
67
- docsPath: "/channels/telegram",
68
- docsLabel: "telegram",
69
- blurb: "simplest way to get started — register a bot with @BotFather and get going.",
70
- systemImage: "paperplane",
71
- selectionDocsPrefix: "",
72
- selectionDocsOmitLabel: true,
73
- selectionExtras: ["https://openclaw.ai"]
74
- },
75
- whatsapp: {
76
- id: "whatsapp",
77
- label: "WhatsApp",
78
- selectionLabel: "WhatsApp (QR link)",
79
- detailLabel: "WhatsApp Web",
80
- docsPath: "/channels/whatsapp",
81
- docsLabel: "whatsapp",
82
- blurb: "works with your own number; recommend a separate phone + eSIM.",
83
- systemImage: "message"
84
- },
85
- discord: {
86
- id: "discord",
87
- label: "Discord",
88
- selectionLabel: "Discord (Bot API)",
89
- detailLabel: "Discord Bot",
90
- docsPath: "/channels/discord",
91
- docsLabel: "discord",
92
- blurb: "very well supported right now.",
93
- systemImage: "bubble.left.and.bubble.right"
94
- },
95
- googlechat: {
96
- id: "googlechat",
97
- label: "Google Chat",
98
- selectionLabel: "Google Chat (Chat API)",
99
- detailLabel: "Google Chat",
100
- docsPath: "/channels/googlechat",
101
- docsLabel: "googlechat",
102
- blurb: "Google Workspace Chat app with HTTP webhook.",
103
- systemImage: "message.badge"
104
- },
105
- slack: {
106
- id: "slack",
107
- label: "Slack",
108
- selectionLabel: "Slack (Socket Mode)",
109
- detailLabel: "Slack Bot",
110
- docsPath: "/channels/slack",
111
- docsLabel: "slack",
112
- blurb: "supported (Socket Mode).",
113
- systemImage: "number"
114
- },
115
- signal: {
116
- id: "signal",
117
- label: "Signal",
118
- selectionLabel: "Signal (signal-cli)",
119
- detailLabel: "Signal REST",
120
- docsPath: "/channels/signal",
121
- docsLabel: "signal",
122
- blurb: "signal-cli linked device; more setup (David Reagans: \"Hop on Discord.\").",
123
- systemImage: "antenna.radiowaves.left.and.right"
124
- },
125
- imessage: {
126
- id: "imessage",
127
- label: "iMessage",
128
- selectionLabel: "iMessage (imsg)",
129
- detailLabel: "iMessage",
130
- docsPath: "/channels/imessage",
131
- docsLabel: "imessage",
132
- blurb: "this is still a work in progress.",
133
- systemImage: "message.fill"
134
- }
135
- };
136
- const CHAT_CHANNEL_ALIASES = {
137
- imsg: "imessage",
138
- "google-chat": "googlechat",
139
- gchat: "googlechat"
140
- };
141
- const normalizeChannelKey = (raw) => {
142
- return raw?.trim().toLowerCase() || void 0;
143
- };
144
- function getChatChannelMeta(id) {
145
- return CHAT_CHANNEL_META[id];
146
- }
147
- function normalizeChatChannelId(raw) {
148
- const normalized = normalizeChannelKey(raw);
149
- if (!normalized) return null;
150
- const resolved = CHAT_CHANNEL_ALIASES[normalized] ?? normalized;
151
- return CHAT_CHANNEL_ORDER.includes(resolved) ? resolved : null;
152
- }
153
- function normalizeChannelId(raw) {
154
- return normalizeChatChannelId(raw);
155
- }
156
- function normalizeAnyChannelId(raw) {
157
- const key = normalizeChannelKey(raw);
158
- if (!key) return null;
159
- return requireActivePluginRegistry().channels.find((entry) => {
160
- const id = String(entry.plugin.id ?? "").trim().toLowerCase();
161
- if (id && id === key) return true;
162
- return (entry.plugin.meta.aliases ?? []).some((alias) => alias.trim().toLowerCase() === key);
163
- })?.plugin.id ?? null;
164
- }
165
-
166
- //#endregion
167
- //#region src/logging/config.ts
168
- function readLoggingConfig() {
169
- const configPath = resolveConfigPath();
170
- try {
171
- if (!fs.existsSync(configPath)) return;
172
- const raw = fs.readFileSync(configPath, "utf-8");
173
- const logging = json5.parse(raw)?.logging;
174
- if (!logging || typeof logging !== "object" || Array.isArray(logging)) return;
175
- return logging;
176
- } catch {
177
- return;
178
- }
179
- }
180
-
181
- //#endregion
182
- //#region src/logging/levels.ts
183
- const ALLOWED_LOG_LEVELS = [
184
- "silent",
185
- "fatal",
186
- "error",
187
- "warn",
188
- "info",
189
- "debug",
190
- "trace"
191
- ];
192
- function normalizeLogLevel(level, fallback = "info") {
193
- const candidate = (level ?? fallback).trim();
194
- return ALLOWED_LOG_LEVELS.includes(candidate) ? candidate : fallback;
195
- }
196
- function levelToMinLevel(level) {
197
- return {
198
- fatal: 0,
199
- error: 1,
200
- warn: 2,
201
- info: 3,
202
- debug: 4,
203
- trace: 5,
204
- silent: Number.POSITIVE_INFINITY
205
- }[level];
206
- }
207
-
208
- //#endregion
209
- //#region src/logging/state.ts
210
- const loggingState = {
211
- cachedLogger: null,
212
- cachedSettings: null,
213
- cachedConsoleSettings: null,
214
- overrideSettings: null,
215
- consolePatched: false,
216
- forceConsoleToStderr: false,
217
- consoleTimestampPrefix: false,
218
- consoleSubsystemFilter: null,
219
- resolvingConsoleSettings: false,
220
- rawConsole: null
221
- };
222
-
223
- //#endregion
224
- //#region src/logging/logger.ts
225
- const DEFAULT_LOG_DIR = "/tmp/openclaw";
226
- const DEFAULT_LOG_FILE = path.join(DEFAULT_LOG_DIR, "openclaw.log");
227
- const LOG_PREFIX = "openclaw";
228
- const LOG_SUFFIX = ".log";
229
- const MAX_LOG_AGE_MS = 1440 * 60 * 1e3;
230
- const requireConfig$1 = createRequire(import.meta.url);
231
- const externalTransports = /* @__PURE__ */ new Set();
232
- function attachExternalTransport(logger, transport) {
233
- logger.attachTransport((logObj) => {
234
- if (!externalTransports.has(transport)) return;
235
- try {
236
- transport(logObj);
237
- } catch {}
238
- });
239
- }
240
- function resolveSettings() {
241
- let cfg = loggingState.overrideSettings ?? readLoggingConfig();
242
- if (!cfg) try {
243
- cfg = requireConfig$1("../config/config.js").loadConfig?.().logging;
244
- } catch {
245
- cfg = void 0;
246
- }
247
- return {
248
- level: normalizeLogLevel(cfg?.level, "info"),
249
- file: cfg?.file ?? defaultRollingPathForToday()
250
- };
251
- }
252
- function settingsChanged(a, b) {
253
- if (!a) return true;
254
- return a.level !== b.level || a.file !== b.file;
255
- }
256
- function isFileLogLevelEnabled(level) {
257
- const settings = loggingState.cachedSettings ?? resolveSettings();
258
- if (!loggingState.cachedSettings) loggingState.cachedSettings = settings;
259
- if (settings.level === "silent") return false;
260
- return levelToMinLevel(level) <= levelToMinLevel(settings.level);
261
- }
262
- function buildLogger(settings) {
263
- fs.mkdirSync(path.dirname(settings.file), { recursive: true });
264
- if (isRollingPath(settings.file)) pruneOldRollingLogs(path.dirname(settings.file));
265
- const logger = new Logger({
266
- name: "openclaw",
267
- minLevel: levelToMinLevel(settings.level),
268
- type: "hidden"
269
- });
270
- logger.attachTransport((logObj) => {
271
- try {
272
- const time = logObj.date?.toISOString?.() ?? (/* @__PURE__ */ new Date()).toISOString();
273
- const line = JSON.stringify({
274
- ...logObj,
275
- time
276
- });
277
- fs.appendFileSync(settings.file, `${line}\n`, { encoding: "utf8" });
278
- } catch {}
279
- });
280
- for (const transport of externalTransports) attachExternalTransport(logger, transport);
281
- return logger;
282
- }
283
- function getLogger() {
284
- const settings = resolveSettings();
285
- const cachedLogger = loggingState.cachedLogger;
286
- const cachedSettings = loggingState.cachedSettings;
287
- if (!cachedLogger || settingsChanged(cachedSettings, settings)) {
288
- loggingState.cachedLogger = buildLogger(settings);
289
- loggingState.cachedSettings = settings;
290
- }
291
- return loggingState.cachedLogger;
292
- }
293
- function getChildLogger(bindings, opts) {
294
- const base = getLogger();
295
- const minLevel = opts?.level ? levelToMinLevel(opts.level) : void 0;
296
- const name = bindings ? JSON.stringify(bindings) : void 0;
297
- return base.getSubLogger({
298
- name,
299
- minLevel,
300
- prefix: bindings ? [name ?? ""] : []
301
- });
302
- }
303
- function toPinoLikeLogger(logger, level) {
304
- const buildChild = (bindings) => toPinoLikeLogger(logger.getSubLogger({ name: bindings ? JSON.stringify(bindings) : void 0 }), level);
305
- return {
306
- level,
307
- child: buildChild,
308
- trace: (...args) => logger.trace(...args),
309
- debug: (...args) => logger.debug(...args),
310
- info: (...args) => logger.info(...args),
311
- warn: (...args) => logger.warn(...args),
312
- error: (...args) => logger.error(...args),
313
- fatal: (...args) => logger.fatal(...args)
314
- };
315
- }
316
- function registerLogTransport(transport) {
317
- externalTransports.add(transport);
318
- const logger = loggingState.cachedLogger;
319
- if (logger) attachExternalTransport(logger, transport);
320
- return () => {
321
- externalTransports.delete(transport);
322
- };
323
- }
324
- function formatLocalDate(date) {
325
- return `${date.getFullYear()}-${String(date.getMonth() + 1).padStart(2, "0")}-${String(date.getDate()).padStart(2, "0")}`;
326
- }
327
- function defaultRollingPathForToday() {
328
- const today = formatLocalDate(/* @__PURE__ */ new Date());
329
- return path.join(DEFAULT_LOG_DIR, `${LOG_PREFIX}-${today}${LOG_SUFFIX}`);
330
- }
331
- function isRollingPath(file) {
332
- const base = path.basename(file);
333
- return base.startsWith(`${LOG_PREFIX}-`) && base.endsWith(LOG_SUFFIX) && base.length === `${LOG_PREFIX}-YYYY-MM-DD${LOG_SUFFIX}`.length;
334
- }
335
- function pruneOldRollingLogs(dir) {
336
- try {
337
- const entries = fs.readdirSync(dir, { withFileTypes: true });
338
- const cutoff = Date.now() - MAX_LOG_AGE_MS;
339
- for (const entry of entries) {
340
- if (!entry.isFile()) continue;
341
- if (!entry.name.startsWith(`${LOG_PREFIX}-`) || !entry.name.endsWith(LOG_SUFFIX)) continue;
342
- const fullPath = path.join(dir, entry.name);
343
- try {
344
- if (fs.statSync(fullPath).mtimeMs < cutoff) fs.rmSync(fullPath, { force: true });
345
- } catch {}
346
- }
347
- } catch {}
348
- }
349
-
350
- //#endregion
351
- //#region src/terminal/palette.ts
352
- const LOBSTER_PALETTE = {
353
- accent: "#FF5A2D",
354
- accentBright: "#FF7A3D",
355
- accentDim: "#D14A22",
356
- info: "#FF8A5B",
357
- success: "#2FBF71",
358
- warn: "#FFB020",
359
- error: "#E23D2D",
360
- muted: "#8B7F77"
361
- };
362
-
363
- //#endregion
364
- //#region src/terminal/theme.ts
365
- const hasForceColor = typeof process.env.FORCE_COLOR === "string" && process.env.FORCE_COLOR.trim().length > 0 && process.env.FORCE_COLOR.trim() !== "0";
366
- const baseChalk = process.env.NO_COLOR && !hasForceColor ? new Chalk({ level: 0 }) : chalk;
367
- const hex = (value) => baseChalk.hex(value);
368
- const theme = {
369
- accent: hex(LOBSTER_PALETTE.accent),
370
- accentBright: hex(LOBSTER_PALETTE.accentBright),
371
- accentDim: hex(LOBSTER_PALETTE.accentDim),
372
- info: hex(LOBSTER_PALETTE.info),
373
- success: hex(LOBSTER_PALETTE.success),
374
- warn: hex(LOBSTER_PALETTE.warn),
375
- error: hex(LOBSTER_PALETTE.error),
376
- muted: hex(LOBSTER_PALETTE.muted),
377
- heading: baseChalk.bold.hex(LOBSTER_PALETTE.accent),
378
- command: hex(LOBSTER_PALETTE.accentBright),
379
- option: hex(LOBSTER_PALETTE.warn)
380
- };
381
- const isRich = () => Boolean(baseChalk.level > 0);
382
- const colorize = (rich, color, value) => rich ? color(value) : value;
383
-
384
- //#endregion
385
- //#region src/globals.ts
386
- let globalVerbose = false;
387
- function setVerbose(v) {
388
- globalVerbose = v;
389
- }
390
- function isVerbose() {
391
- return globalVerbose;
392
- }
393
- function shouldLogVerbose() {
394
- return globalVerbose || isFileLogLevelEnabled("debug");
395
- }
396
- function logVerbose(message) {
397
- if (!shouldLogVerbose()) return;
398
- try {
399
- getLogger().debug({ message }, "verbose");
400
- } catch {}
401
- if (!globalVerbose) return;
402
- console.log(theme.muted(message));
403
- }
404
- function logVerboseConsole(message) {
405
- if (!globalVerbose) return;
406
- console.log(theme.muted(message));
407
- }
408
- const success = theme.success;
409
- const warn = theme.warn;
410
- const info = theme.info;
411
- const danger = theme.error;
412
-
413
- //#endregion
414
- //#region src/utils.ts
415
- async function ensureDir(dir) {
416
- await fs.promises.mkdir(dir, { recursive: true });
417
- }
418
- function clampNumber(value, min, max) {
419
- return Math.max(min, Math.min(max, value));
420
- }
421
- function clampInt(value, min, max) {
422
- return clampNumber(Math.floor(value), min, max);
423
- }
424
- function normalizeE164(number) {
425
- const digits = number.replace(/^whatsapp:/, "").trim().replace(/[^\d+]/g, "");
426
- if (digits.startsWith("+")) return `+${digits.slice(1)}`;
427
- return `+${digits}`;
428
- }
429
- /**
430
- * "Self-chat mode" heuristic (single phone): the gateway is logged in as the owner's own WhatsApp account,
431
- * and `channels.whatsapp.allowFrom` includes that same number. Used to avoid side-effects that make no sense when the
432
- * "bot" and the human are the same WhatsApp identity (e.g. auto read receipts, @mention JID triggers).
433
- */
434
- function isSelfChatMode(selfE164, allowFrom) {
435
- if (!selfE164) return false;
436
- if (!Array.isArray(allowFrom) || allowFrom.length === 0) return false;
437
- const normalizedSelf = normalizeE164(selfE164);
438
- return allowFrom.some((n) => {
439
- if (n === "*") return false;
440
- try {
441
- return normalizeE164(String(n)) === normalizedSelf;
442
- } catch {
443
- return false;
444
- }
445
- });
446
- }
447
- function toWhatsappJid(number) {
448
- const withoutPrefix = number.replace(/^whatsapp:/, "").trim();
449
- if (withoutPrefix.includes("@")) return withoutPrefix;
450
- return `${normalizeE164(withoutPrefix).replace(/\D/g, "")}@s.whatsapp.net`;
451
- }
452
- function resolveLidMappingDirs(opts) {
453
- const dirs = /* @__PURE__ */ new Set();
454
- const addDir = (dir) => {
455
- if (!dir) return;
456
- dirs.add(resolveUserPath(dir));
457
- };
458
- addDir(opts?.authDir);
459
- for (const dir of opts?.lidMappingDirs ?? []) addDir(dir);
460
- addDir(resolveOAuthDir());
461
- addDir(path.join(CONFIG_DIR, "credentials"));
462
- return [...dirs];
463
- }
464
- function readLidReverseMapping(lid, opts) {
465
- const mappingFilename = `lid-mapping-${lid}_reverse.json`;
466
- const mappingDirs = resolveLidMappingDirs(opts);
467
- for (const dir of mappingDirs) {
468
- const mappingPath = path.join(dir, mappingFilename);
469
- try {
470
- const data = fs.readFileSync(mappingPath, "utf8");
471
- const phone = JSON.parse(data);
472
- if (phone === null || phone === void 0) continue;
473
- return normalizeE164(String(phone));
474
- } catch {}
475
- }
476
- return null;
477
- }
478
- function jidToE164(jid, opts) {
479
- const match = jid.match(/^(\d+)(?::\d+)?@(s\.whatsapp\.net|hosted)$/);
480
- if (match) return `+${match[1]}`;
481
- const lidMatch = jid.match(/^(\d+)(?::\d+)?@(lid|hosted\.lid)$/);
482
- if (lidMatch) {
483
- const lid = lidMatch[1];
484
- const phone = readLidReverseMapping(lid, opts);
485
- if (phone) return phone;
486
- if (opts?.logMissing ?? shouldLogVerbose()) logVerbose(`LID mapping not found for ${lid}; skipping inbound message`);
487
- }
488
- return null;
489
- }
490
- async function resolveJidToE164(jid, opts) {
491
- if (!jid) return null;
492
- const direct = jidToE164(jid, opts);
493
- if (direct) return direct;
494
- if (!/(@lid|@hosted\.lid)$/.test(jid)) return null;
495
- if (!opts?.lidLookup?.getPNForLID) return null;
496
- try {
497
- const pnJid = await opts.lidLookup.getPNForLID(jid);
498
- if (!pnJid) return null;
499
- return jidToE164(pnJid, opts);
500
- } catch (err) {
501
- if (shouldLogVerbose()) logVerbose(`LID mapping lookup failed for ${jid}: ${String(err)}`);
502
- return null;
503
- }
504
- }
505
- function sleep(ms) {
506
- return new Promise((resolve) => setTimeout(resolve, ms));
507
- }
508
- function isHighSurrogate(codeUnit) {
509
- return codeUnit >= 55296 && codeUnit <= 56319;
510
- }
511
- function isLowSurrogate(codeUnit) {
512
- return codeUnit >= 56320 && codeUnit <= 57343;
513
- }
514
- function sliceUtf16Safe(input, start, end) {
515
- const len = input.length;
516
- let from = start < 0 ? Math.max(len + start, 0) : Math.min(start, len);
517
- let to = end === void 0 ? len : end < 0 ? Math.max(len + end, 0) : Math.min(end, len);
518
- if (to < from) {
519
- const tmp = from;
520
- from = to;
521
- to = tmp;
522
- }
523
- if (from > 0 && from < len) {
524
- if (isLowSurrogate(input.charCodeAt(from)) && isHighSurrogate(input.charCodeAt(from - 1))) from += 1;
525
- }
526
- if (to > 0 && to < len) {
527
- if (isHighSurrogate(input.charCodeAt(to - 1)) && isLowSurrogate(input.charCodeAt(to))) to -= 1;
528
- }
529
- return input.slice(from, to);
530
- }
531
- function truncateUtf16Safe(input, maxLen) {
532
- const limit = Math.max(0, Math.floor(maxLen));
533
- if (input.length <= limit) return input;
534
- return sliceUtf16Safe(input, 0, limit);
535
- }
536
- function resolveUserPath(input) {
537
- const trimmed = input.trim();
538
- if (!trimmed) return trimmed;
539
- if (trimmed.startsWith("~")) {
540
- const expanded = trimmed.replace(/^~(?=$|[\\/])/, os.homedir());
541
- return path.resolve(expanded);
542
- }
543
- return path.resolve(trimmed);
544
- }
545
- function resolveConfigDir(env = process.env, homedir = os.homedir) {
546
- const override = env.OPENCLAW_STATE_DIR?.trim() || env.CLAWDBOT_STATE_DIR?.trim();
547
- if (override) return resolveUserPath(override);
548
- const newDir = path.join(homedir(), ".openclaw");
549
- try {
550
- if (fs.existsSync(newDir)) return newDir;
551
- } catch {}
552
- return newDir;
553
- }
554
- function resolveHomeDir() {
555
- const envHome = process.env.HOME?.trim();
556
- if (envHome) return envHome;
557
- const envProfile = process.env.USERPROFILE?.trim();
558
- if (envProfile) return envProfile;
559
- try {
560
- const home = os.homedir();
561
- return home?.trim() ? home : void 0;
562
- } catch {
563
- return;
564
- }
565
- }
566
- function shortenHomePath(input) {
567
- if (!input) return input;
568
- const home = resolveHomeDir();
569
- if (!home) return input;
570
- if (input === home) return "~";
571
- if (input.startsWith(`${home}/`)) return `~${input.slice(home.length)}`;
572
- return input;
573
- }
574
- function shortenHomeInString(input) {
575
- if (!input) return input;
576
- const home = resolveHomeDir();
577
- if (!home) return input;
578
- return input.split(home).join("~");
579
- }
580
- function formatTerminalLink(label, url, opts) {
581
- const esc = "\x1B";
582
- const safeLabel = label.replaceAll(esc, "");
583
- const safeUrl = url.replaceAll(esc, "");
584
- if (!(opts?.force === true ? true : opts?.force === false ? false : Boolean(process.stdout.isTTY))) return opts?.fallback ?? `${safeLabel} (${safeUrl})`;
585
- return `\u001b]8;;${safeUrl}\u0007${safeLabel}\u001b]8;;\u0007`;
586
- }
587
- const CONFIG_DIR = resolveConfigDir();
588
-
589
- //#endregion
590
- //#region src/terminal/progress-line.ts
591
- let activeStream = null;
592
- function registerActiveProgressLine(stream) {
593
- if (!stream.isTTY) return;
594
- activeStream = stream;
595
- }
596
- function clearActiveProgressLine() {
597
- if (!activeStream?.isTTY) return;
598
- activeStream.write("\r\x1B[2K");
599
- }
600
- function unregisterActiveProgressLine(stream) {
601
- if (!activeStream) return;
602
- if (stream && activeStream !== stream) return;
603
- activeStream = null;
604
- }
605
-
606
- //#endregion
607
- //#region src/terminal/restore.ts
608
- const RESET_SEQUENCE = "\x1B[0m\x1B[?25h\x1B[?1000l\x1B[?1002l\x1B[?1003l\x1B[?1006l\x1B[?2004l";
609
- function reportRestoreFailure(scope, err, reason) {
610
- const suffix = reason ? ` (${reason})` : "";
611
- const message = `[terminal] restore ${scope} failed${suffix}: ${String(err)}`;
612
- try {
613
- process.stderr.write(`${message}\n`);
614
- } catch (writeErr) {
615
- console.error(`[terminal] restore reporting failed${suffix}: ${String(writeErr)}`);
616
- }
617
- }
618
- function restoreTerminalState(reason) {
619
- try {
620
- clearActiveProgressLine();
621
- } catch (err) {
622
- reportRestoreFailure("progress line", err, reason);
623
- }
624
- const stdin = process.stdin;
625
- if (stdin.isTTY && typeof stdin.setRawMode === "function") {
626
- try {
627
- stdin.setRawMode(false);
628
- } catch (err) {
629
- reportRestoreFailure("raw mode", err, reason);
630
- }
631
- if (typeof stdin.isPaused === "function" && stdin.isPaused()) try {
632
- stdin.resume();
633
- } catch (err) {
634
- reportRestoreFailure("stdin resume", err, reason);
635
- }
636
- }
637
- if (process.stdout.isTTY) try {
638
- process.stdout.write(RESET_SEQUENCE);
639
- } catch (err) {
640
- reportRestoreFailure("stdout reset", err, reason);
641
- }
642
- }
643
-
644
- //#endregion
645
- //#region src/runtime.ts
646
- const defaultRuntime = {
647
- log: (...args) => {
648
- clearActiveProgressLine();
649
- console.log(...args);
650
- },
651
- error: (...args) => {
652
- clearActiveProgressLine();
653
- console.error(...args);
654
- },
655
- exit: (code) => {
656
- restoreTerminalState("runtime exit");
657
- process.exit(code);
658
- throw new Error("unreachable");
659
- }
660
- };
661
-
662
- //#endregion
663
- //#region src/terminal/ansi.ts
664
- const ANSI_SGR_PATTERN = "\\x1b\\[[0-9;]*m";
665
- const OSC8_PATTERN = "\\x1b\\]8;;.*?\\x1b\\\\|\\x1b\\]8;;\\x1b\\\\";
666
- const ANSI_REGEX = new RegExp(ANSI_SGR_PATTERN, "g");
667
- const OSC8_REGEX = new RegExp(OSC8_PATTERN, "g");
668
-
669
- //#endregion
670
- //#region src/logging/console.ts
671
- const requireConfig = createRequire(import.meta.url);
672
- function normalizeConsoleLevel(level) {
673
- if (isVerbose()) return "debug";
674
- return normalizeLogLevel(level, "info");
675
- }
676
- function normalizeConsoleStyle(style) {
677
- if (style === "compact" || style === "json" || style === "pretty") return style;
678
- if (!process.stdout.isTTY) return "compact";
679
- return "pretty";
680
- }
681
- function resolveConsoleSettings() {
682
- let cfg = loggingState.overrideSettings ?? readLoggingConfig();
683
- if (!cfg) if (loggingState.resolvingConsoleSettings) cfg = void 0;
684
- else {
685
- loggingState.resolvingConsoleSettings = true;
686
- try {
687
- cfg = requireConfig("../config/config.js").loadConfig?.().logging;
688
- } catch {
689
- cfg = void 0;
690
- } finally {
691
- loggingState.resolvingConsoleSettings = false;
692
- }
693
- }
694
- return {
695
- level: normalizeConsoleLevel(cfg?.consoleLevel),
696
- style: normalizeConsoleStyle(cfg?.consoleStyle)
697
- };
698
- }
699
- function consoleSettingsChanged(a, b) {
700
- if (!a) return true;
701
- return a.level !== b.level || a.style !== b.style;
702
- }
703
- function getConsoleSettings() {
704
- const settings = resolveConsoleSettings();
705
- const cached = loggingState.cachedConsoleSettings;
706
- if (!cached || consoleSettingsChanged(cached, settings)) loggingState.cachedConsoleSettings = settings;
707
- return loggingState.cachedConsoleSettings;
708
- }
709
- function shouldLogSubsystemToConsole(subsystem) {
710
- const filter = loggingState.consoleSubsystemFilter;
711
- if (!filter || filter.length === 0) return true;
712
- return filter.some((prefix) => subsystem === prefix || subsystem.startsWith(`${prefix}/`));
713
- }
714
-
715
- //#endregion
716
- //#region src/logging/subsystem.ts
717
- function shouldLogToConsole(level, settings) {
718
- if (settings.level === "silent") return false;
719
- return levelToMinLevel(level) <= levelToMinLevel(settings.level);
720
- }
721
- function isRichConsoleEnv() {
722
- const term = (process.env.TERM ?? "").toLowerCase();
723
- if (process.env.COLORTERM || process.env.TERM_PROGRAM) return true;
724
- return term.length > 0 && term !== "dumb";
725
- }
726
- function getColorForConsole() {
727
- const hasForceColor = typeof process.env.FORCE_COLOR === "string" && process.env.FORCE_COLOR.trim().length > 0 && process.env.FORCE_COLOR.trim() !== "0";
728
- if (process.env.NO_COLOR && !hasForceColor) return new Chalk({ level: 0 });
729
- return Boolean(process.stdout.isTTY || process.stderr.isTTY) || isRichConsoleEnv() ? new Chalk({ level: 1 }) : new Chalk({ level: 0 });
730
- }
731
- const SUBSYSTEM_COLORS = [
732
- "cyan",
733
- "green",
734
- "yellow",
735
- "blue",
736
- "magenta",
737
- "red"
738
- ];
739
- const SUBSYSTEM_COLOR_OVERRIDES = { "gmail-watcher": "blue" };
740
- const SUBSYSTEM_PREFIXES_TO_DROP = [
741
- "gateway",
742
- "channels",
743
- "providers"
744
- ];
745
- const SUBSYSTEM_MAX_SEGMENTS = 2;
746
- const CHANNEL_SUBSYSTEM_PREFIXES = new Set(CHAT_CHANNEL_ORDER);
747
- function pickSubsystemColor(color, subsystem) {
748
- const override = SUBSYSTEM_COLOR_OVERRIDES[subsystem];
749
- if (override) return color[override];
750
- let hash = 0;
751
- for (let i = 0; i < subsystem.length; i += 1) hash = hash * 31 + subsystem.charCodeAt(i) | 0;
752
- return color[SUBSYSTEM_COLORS[Math.abs(hash) % SUBSYSTEM_COLORS.length]];
753
- }
754
- function formatSubsystemForConsole(subsystem) {
755
- const parts = subsystem.split("/").filter(Boolean);
756
- const original = parts.join("/") || subsystem;
757
- while (parts.length > 0 && SUBSYSTEM_PREFIXES_TO_DROP.includes(parts[0])) parts.shift();
758
- if (parts.length === 0) return original;
759
- if (CHANNEL_SUBSYSTEM_PREFIXES.has(parts[0])) return parts[0];
760
- if (parts.length > SUBSYSTEM_MAX_SEGMENTS) return parts.slice(-SUBSYSTEM_MAX_SEGMENTS).join("/");
761
- return parts.join("/");
762
- }
763
- function stripRedundantSubsystemPrefixForConsole(message, displaySubsystem) {
764
- if (!displaySubsystem) return message;
765
- if (message.startsWith("[")) {
766
- const closeIdx = message.indexOf("]");
767
- if (closeIdx > 1) {
768
- if (message.slice(1, closeIdx).toLowerCase() === displaySubsystem.toLowerCase()) {
769
- let i = closeIdx + 1;
770
- while (message[i] === " ") i += 1;
771
- return message.slice(i);
772
- }
773
- }
774
- }
775
- if (message.slice(0, displaySubsystem.length).toLowerCase() !== displaySubsystem.toLowerCase()) return message;
776
- const next = message.slice(displaySubsystem.length, displaySubsystem.length + 1);
777
- if (next !== ":" && next !== " ") return message;
778
- let i = displaySubsystem.length;
779
- while (message[i] === " ") i += 1;
780
- if (message[i] === ":") i += 1;
781
- while (message[i] === " ") i += 1;
782
- return message.slice(i);
783
- }
784
- function formatConsoleLine(opts) {
785
- const displaySubsystem = opts.style === "json" ? opts.subsystem : formatSubsystemForConsole(opts.subsystem);
786
- if (opts.style === "json") return JSON.stringify({
787
- time: (/* @__PURE__ */ new Date()).toISOString(),
788
- level: opts.level,
789
- subsystem: displaySubsystem,
790
- message: opts.message,
791
- ...opts.meta
792
- });
793
- const color = getColorForConsole();
794
- const prefix = `[${displaySubsystem}]`;
795
- const prefixColor = pickSubsystemColor(color, displaySubsystem);
796
- const levelColor = opts.level === "error" || opts.level === "fatal" ? color.red : opts.level === "warn" ? color.yellow : opts.level === "debug" || opts.level === "trace" ? color.gray : color.cyan;
797
- const displayMessage = stripRedundantSubsystemPrefixForConsole(opts.message, displaySubsystem);
798
- return `${[(() => {
799
- if (opts.style === "pretty") return color.gray((/* @__PURE__ */ new Date()).toISOString().slice(11, 19));
800
- if (loggingState.consoleTimestampPrefix) return color.gray((/* @__PURE__ */ new Date()).toISOString());
801
- return "";
802
- })(), prefixColor(prefix)].filter(Boolean).join(" ")} ${levelColor(displayMessage)}`;
803
- }
804
- function writeConsoleLine(level, line) {
805
- clearActiveProgressLine();
806
- const sanitized = process.platform === "win32" && process.env.GITHUB_ACTIONS === "true" ? line.replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g, "?").replace(/[\uD800-\uDFFF]/g, "?") : line;
807
- const sink = loggingState.rawConsole ?? console;
808
- if (loggingState.forceConsoleToStderr || level === "error" || level === "fatal") (sink.error ?? console.error)(sanitized);
809
- else if (level === "warn") (sink.warn ?? console.warn)(sanitized);
810
- else (sink.log ?? console.log)(sanitized);
811
- }
812
- function logToFile(fileLogger, level, message, meta) {
813
- if (level === "silent") return;
814
- const method = fileLogger[level];
815
- if (typeof method !== "function") return;
816
- if (meta && Object.keys(meta).length > 0) method.call(fileLogger, meta, message);
817
- else method.call(fileLogger, message);
818
- }
819
- function createSubsystemLogger(subsystem) {
820
- let fileLogger = null;
821
- const getFileLogger = () => {
822
- if (!fileLogger) fileLogger = getChildLogger({ subsystem });
823
- return fileLogger;
824
- };
825
- const emit = (level, message, meta) => {
826
- const consoleSettings = getConsoleSettings();
827
- let consoleMessageOverride;
828
- let fileMeta = meta;
829
- if (meta && Object.keys(meta).length > 0) {
830
- const { consoleMessage, ...rest } = meta;
831
- if (typeof consoleMessage === "string") consoleMessageOverride = consoleMessage;
832
- fileMeta = Object.keys(rest).length > 0 ? rest : void 0;
833
- }
834
- logToFile(getFileLogger(), level, message, fileMeta);
835
- if (!shouldLogToConsole(level, { level: consoleSettings.level })) return;
836
- if (!shouldLogSubsystemToConsole(subsystem)) return;
837
- const consoleMessage = consoleMessageOverride ?? message;
838
- if (!isVerbose() && subsystem === "agent/embedded" && /(sessionId|runId)=probe-/.test(consoleMessage)) return;
839
- writeConsoleLine(level, formatConsoleLine({
840
- level,
841
- subsystem,
842
- message: consoleSettings.style === "json" ? message : consoleMessage,
843
- style: consoleSettings.style,
844
- meta: fileMeta
845
- }));
846
- };
847
- return {
848
- subsystem,
849
- trace: (message, meta) => emit("trace", message, meta),
850
- debug: (message, meta) => emit("debug", message, meta),
851
- info: (message, meta) => emit("info", message, meta),
852
- warn: (message, meta) => emit("warn", message, meta),
853
- error: (message, meta) => emit("error", message, meta),
854
- fatal: (message, meta) => emit("fatal", message, meta),
855
- raw: (message) => {
856
- logToFile(getFileLogger(), "info", message, { raw: true });
857
- if (shouldLogSubsystemToConsole(subsystem)) {
858
- if (!isVerbose() && subsystem === "agent/embedded" && /(sessionId|runId)=probe-/.test(message)) return;
859
- writeConsoleLine("info", message);
860
- }
861
- },
862
- child: (name) => createSubsystemLogger(`${subsystem}/${name}`)
863
- };
864
- }
865
-
866
- //#endregion
867
- //#region src/logger.ts
868
- const subsystemPrefixRe = /^([a-z][a-z0-9-]{1,20}):\s+(.*)$/i;
869
- function splitSubsystem(message) {
870
- const match = message.match(subsystemPrefixRe);
871
- if (!match) return null;
872
- const [, subsystem, rest] = match;
873
- return {
874
- subsystem,
875
- rest
876
- };
877
- }
878
- function logInfo(message, runtime = defaultRuntime) {
879
- const parsed = runtime === defaultRuntime ? splitSubsystem(message) : null;
880
- if (parsed) {
881
- createSubsystemLogger(parsed.subsystem).info(parsed.rest);
882
- return;
883
- }
884
- runtime.log(info(message));
885
- getLogger().info(message);
886
- }
887
- function logWarn(message, runtime = defaultRuntime) {
888
- const parsed = runtime === defaultRuntime ? splitSubsystem(message) : null;
889
- if (parsed) {
890
- createSubsystemLogger(parsed.subsystem).warn(parsed.rest);
891
- return;
892
- }
893
- runtime.log(warn(message));
894
- getLogger().warn(message);
895
- }
896
- function logError(message, runtime = defaultRuntime) {
897
- const parsed = runtime === defaultRuntime ? splitSubsystem(message) : null;
898
- if (parsed) {
899
- createSubsystemLogger(parsed.subsystem).error(parsed.rest);
900
- return;
901
- }
902
- runtime.error(danger(message));
903
- getLogger().error(message);
904
- }
905
- function logDebug(message) {
906
- getLogger().debug(message);
907
- logVerboseConsole(message);
908
- }
909
-
910
- //#endregion
911
- //#region src/process/spawn-utils.ts
912
- const DEFAULT_RETRY_CODES = ["EBADF"];
913
- function resolveCommandStdio(params) {
914
- return [
915
- params.hasInput ? "pipe" : params.preferInherit ? "inherit" : "pipe",
916
- "pipe",
917
- "pipe"
918
- ];
919
- }
920
- function formatSpawnError(err) {
921
- if (!(err instanceof Error)) return String(err);
922
- const details = err;
923
- const parts = [];
924
- const message = err.message?.trim();
925
- if (message) parts.push(message);
926
- if (details.code && !message?.includes(details.code)) parts.push(details.code);
927
- if (details.syscall) parts.push(`syscall=${details.syscall}`);
928
- if (typeof details.errno === "number") parts.push(`errno=${details.errno}`);
929
- return parts.join(" ");
930
- }
931
- function shouldRetry(err, codes) {
932
- const code = err && typeof err === "object" && "code" in err ? String(err.code) : "";
933
- return code.length > 0 && codes.includes(code);
934
- }
935
- async function spawnAndWaitForSpawn(spawnImpl, argv, options) {
936
- const child = spawnImpl(argv[0], argv.slice(1), options);
937
- return await new Promise((resolve, reject) => {
938
- let settled = false;
939
- const cleanup = () => {
940
- child.removeListener("error", onError);
941
- child.removeListener("spawn", onSpawn);
942
- };
943
- const finishResolve = () => {
944
- if (settled) return;
945
- settled = true;
946
- cleanup();
947
- resolve(child);
948
- };
949
- const onError = (err) => {
950
- if (settled) return;
951
- settled = true;
952
- cleanup();
953
- reject(err);
954
- };
955
- const onSpawn = () => {
956
- finishResolve();
957
- };
958
- child.once("error", onError);
959
- child.once("spawn", onSpawn);
960
- process.nextTick(() => {
961
- if (typeof child.pid === "number") finishResolve();
962
- });
963
- });
964
- }
965
- async function spawnWithFallback(params) {
966
- const spawnImpl = params.spawnImpl ?? spawn;
967
- const retryCodes = params.retryCodes ?? DEFAULT_RETRY_CODES;
968
- const baseOptions = { ...params.options };
969
- const fallbacks = params.fallbacks ?? [];
970
- const attempts = [{ options: baseOptions }, ...fallbacks.map((fallback) => ({
971
- label: fallback.label,
972
- options: {
973
- ...baseOptions,
974
- ...fallback.options
975
- }
976
- }))];
977
- let lastError;
978
- for (let index = 0; index < attempts.length; index += 1) {
979
- const attempt = attempts[index];
980
- try {
981
- return {
982
- child: await spawnAndWaitForSpawn(spawnImpl, params.argv, attempt.options),
983
- usedFallback: index > 0,
984
- fallbackLabel: attempt.label
985
- };
986
- } catch (err) {
987
- lastError = err;
988
- const nextFallback = fallbacks[index];
989
- if (!nextFallback || !shouldRetry(err, retryCodes)) throw err;
990
- params.onFallback?.(err, nextFallback);
991
- }
992
- }
993
- throw lastError;
994
- }
995
-
996
- //#endregion
997
- //#region src/process/exec.ts
998
- const execFileAsync = promisify(execFile);
999
- /**
1000
- * Resolves a command for Windows compatibility.
1001
- * On Windows, non-.exe commands (like npm, pnpm) require their .cmd extension.
1002
- */
1003
- function resolveCommand(command) {
1004
- if (process.platform !== "win32") return command;
1005
- const basename = path.basename(command).toLowerCase();
1006
- if (path.extname(basename)) return command;
1007
- if ([
1008
- "npm",
1009
- "pnpm",
1010
- "yarn",
1011
- "npx"
1012
- ].includes(basename)) return `${command}.cmd`;
1013
- return command;
1014
- }
1015
- async function runExec(command, args, opts = 1e4) {
1016
- const options = typeof opts === "number" ? {
1017
- timeout: opts,
1018
- encoding: "utf8"
1019
- } : {
1020
- timeout: opts.timeoutMs,
1021
- maxBuffer: opts.maxBuffer,
1022
- encoding: "utf8"
1023
- };
1024
- try {
1025
- const { stdout, stderr } = await execFileAsync(resolveCommand(command), args, options);
1026
- if (shouldLogVerbose()) {
1027
- if (stdout.trim()) logDebug(stdout.trim());
1028
- if (stderr.trim()) logError(stderr.trim());
1029
- }
1030
- return {
1031
- stdout,
1032
- stderr
1033
- };
1034
- } catch (err) {
1035
- if (shouldLogVerbose()) logError(danger(`Command failed: ${command} ${args.join(" ")}`));
1036
- throw err;
1037
- }
1038
- }
1039
- async function runCommandWithTimeout(argv, optionsOrTimeout) {
1040
- const options = typeof optionsOrTimeout === "number" ? { timeoutMs: optionsOrTimeout } : optionsOrTimeout;
1041
- const { timeoutMs, cwd, input, env } = options;
1042
- const { windowsVerbatimArguments } = options;
1043
- const hasInput = input !== void 0;
1044
- const shouldSuppressNpmFund = (() => {
1045
- const cmd = path.basename(argv[0] ?? "");
1046
- if (cmd === "npm" || cmd === "npm.cmd" || cmd === "npm.exe") return true;
1047
- if (cmd === "node" || cmd === "node.exe") return (argv[1] ?? "").includes("npm-cli.js");
1048
- return false;
1049
- })();
1050
- const resolvedEnv = env ? {
1051
- ...process.env,
1052
- ...env
1053
- } : { ...process.env };
1054
- if (shouldSuppressNpmFund) {
1055
- if (resolvedEnv.NPM_CONFIG_FUND == null) resolvedEnv.NPM_CONFIG_FUND = "false";
1056
- if (resolvedEnv.npm_config_fund == null) resolvedEnv.npm_config_fund = "false";
1057
- }
1058
- const stdio = resolveCommandStdio({
1059
- hasInput,
1060
- preferInherit: true
1061
- });
1062
- const child = spawn(resolveCommand(argv[0]), argv.slice(1), {
1063
- stdio,
1064
- cwd,
1065
- env: resolvedEnv,
1066
- windowsVerbatimArguments
1067
- });
1068
- return await new Promise((resolve, reject) => {
1069
- let stdout = "";
1070
- let stderr = "";
1071
- let settled = false;
1072
- const timer = setTimeout(() => {
1073
- if (typeof child.kill === "function") child.kill("SIGKILL");
1074
- }, timeoutMs);
1075
- if (hasInput && child.stdin) {
1076
- child.stdin.write(input ?? "");
1077
- child.stdin.end();
1078
- }
1079
- child.stdout?.on("data", (d) => {
1080
- stdout += d.toString();
1081
- });
1082
- child.stderr?.on("data", (d) => {
1083
- stderr += d.toString();
1084
- });
1085
- child.on("error", (err) => {
1086
- if (settled) return;
1087
- settled = true;
1088
- clearTimeout(timer);
1089
- reject(err);
1090
- });
1091
- child.on("close", (code, signal) => {
1092
- if (settled) return;
1093
- settled = true;
1094
- clearTimeout(timer);
1095
- resolve({
1096
- stdout,
1097
- stderr,
1098
- code,
1099
- signal,
1100
- killed: child.killed
1101
- });
1102
- });
1103
- });
1104
- }
1105
-
1106
- //#endregion
1107
- export { setActivePluginRegistry as $, truncateUtf16Safe as A, theme as B, resolveJidToE164 as C, sleep as D, shortenHomePath as E, shouldLogVerbose as F, CHANNEL_IDS as G, registerLogTransport as H, success as I, normalizeAnyChannelId as J, CHAT_CHANNEL_ORDER as K, warn as L, info as M, logVerbose as N, sliceUtf16Safe as O, setVerbose as P, requireActivePluginRegistry as Q, colorize as R, resolveConfigDir as S, shortenHomeInString as T, toPinoLikeLogger as U, getChildLogger as V, normalizeLogLevel as W, normalizeChatChannelId as X, normalizeChannelId as Y, getActivePluginRegistry as Z, ensureDir as _, logDebug as a, jidToE164 as b, logWarn as c, clearActiveProgressLine as d, registerActiveProgressLine as f, clampNumber as g, clampInt as h, spawnWithFallback as i, danger as j, toWhatsappJid as k, createSubsystemLogger as l, CONFIG_DIR as m, runExec as n, logError as o, unregisterActiveProgressLine as p, getChatChannelMeta as q, formatSpawnError as r, logInfo as s, runCommandWithTimeout as t, defaultRuntime as u, formatTerminalLink as v, resolveUserPath as w, normalizeE164 as x, isSelfChatMode as y, isRich as z };