@qqbrowser/openclaw-qbot 0.10.1 → 0.10.2

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 (214) hide show
  1. package/dist/{agents-Cd1yL8fG.js → agents-CCGNI0th.js} +1 -1
  2. package/dist/{agents.config-CaRMmWS8.js → agents.config-B9_IT_un.js} +1 -1
  3. package/dist/{agents.config-DSCcdYtv.js → agents.config-D8Q8p7re.js} +1 -1
  4. package/dist/{auth-choice-MqcWuVyu.js → auth-choice-DacG9sC7.js} +1 -1
  5. package/dist/{auth-choice-BmI4sIGs.js → auth-choice-EAV1bi1K.js} +1 -1
  6. package/dist/{banner-CAtilyXr.js → banner-DiQjNe9B.js} +1 -1
  7. package/dist/build-info.json +3 -3
  8. package/dist/bundled/boot-md/handler.js +1 -1
  9. package/dist/bundled/session-memory/handler.js +1 -1
  10. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  11. package/dist/{channel-options-CCqtIYCc.js → channel-options-DcI5T_Su.js} +1 -1
  12. package/dist/{channel-options-CKoyPq8p.js → channel-options-llKYy0-2.js} +1 -1
  13. package/dist/{channel-web-CwUfYqjg.js → channel-web-Qr8ST6tz.js} +1 -1
  14. package/dist/{channel-web-CCSMlUux.js → channel-web-TKrgB4oQ.js} +1 -1
  15. package/dist/{channels-cli-BfgVv5jH.js → channels-cli-BtyzpSQo.js} +1 -1
  16. package/dist/{channels-cli-BvGXgERj.js → channels-cli-CrdwqyiA.js} +1 -1
  17. package/dist/{cli-Bt--1dhL.js → cli-BDzG5MP5.js} +1 -1
  18. package/dist/{cli-CBg8KhmQ.js → cli-BY5POVX1.js} +1 -1
  19. package/dist/{command-registry-D_jtBegA.js → command-registry-DtMCIKRu.js} +1 -1
  20. package/dist/{compact-CYbPi7_-.js → compact-uyQDx8pN.js} +36 -36
  21. package/dist/{compact.runtime-BQu-8DFN.js → compact.runtime-BvWn8-VF.js} +1 -1
  22. package/dist/{compact.runtime-D-fOpaU3.js → compact.runtime-CbCNReBm.js} +1 -1
  23. package/dist/{compact.runtime-owWgKVDf.js → compact.runtime-DcRVnY_G.js} +1 -1
  24. package/dist/{compact.runtime-CrzmR0tV.js → compact.runtime-dgJTRf2V.js} +1 -1
  25. package/dist/{completion-cli-Bw_hBrlA.js → completion-cli-ByNU0Lbo.js} +1 -1
  26. package/dist/{completion-cli-BVbT_aR2.js → completion-cli-DHH7Zr2u.js} +1 -1
  27. package/dist/{config-cli-CwW76_j_.js → config-cli-BeVM5uz1.js} +1 -1
  28. package/dist/{config-cli-F-lkPjjz.js → config-cli-CcE1aKR3.js} +1 -1
  29. package/dist/{configure-DFlnM_zh.js → configure-CF42Va3r.js} +1 -1
  30. package/dist/{configure--c4tTVPz.js → configure-CYw7mK89.js} +1 -1
  31. package/dist/{deps-send-whatsapp.runtime-CqISN5vF.js → deps-send-whatsapp.runtime-7SqhJmWZ.js} +1 -1
  32. package/dist/{deps-send-whatsapp.runtime-C1zG74Si.js → deps-send-whatsapp.runtime-Bocaadqa.js} +1 -1
  33. package/dist/{deps-send-whatsapp.runtime-B5GMQIFv.js → deps-send-whatsapp.runtime-CjA6T7V6.js} +1 -1
  34. package/dist/{deps-send-whatsapp.runtime-CJnSJVnN.js → deps-send-whatsapp.runtime-DTyzQeR_.js} +1 -1
  35. package/dist/{doctor-completion-DI7mGC3D.js → doctor-completion-C15UB3EM.js} +1 -1
  36. package/dist/{doctor-completion-C9CPhCor.js → doctor-completion-KLuf1f33.js} +1 -1
  37. package/dist/entry.js +1 -1
  38. package/dist/extensionAPI.js +1 -1
  39. package/dist/{gateway-cli-BMmU2dsG.js → gateway-cli-CHyybU4X.js} +2 -2
  40. package/dist/{gateway-cli-Kp-caOwI.js → gateway-cli-DV3M2tJP.js} +2 -2
  41. package/dist/{health-B_-ZE5FK.js → health-2MbtCw6U.js} +1 -1
  42. package/dist/{health-CIZFVJEG.js → health-Dmtcw9K8.js} +1 -1
  43. package/dist/{hooks-cli-BoxAnC-E.js → hooks-cli-BaoD0-6l.js} +1 -1
  44. package/dist/{hooks-cli-CnCOjVv0.js → hooks-cli-DWCe4aHR.js} +1 -1
  45. package/dist/index.js +2 -2
  46. package/dist/llm-slug-generator.js +1 -1
  47. package/dist/{models-BBYqej07.js → models-DKf-4KoV.js} +1 -1
  48. package/dist/{models-cli-CMMhnlHo.js → models-cli-Bc8cIZ0A.js} +1 -1
  49. package/dist/{models-cli-CqbDyDn2.js → models-cli-Ble64nV3.js} +1 -1
  50. package/dist/{npm-resolution-CBlwQq3a.js → npm-resolution-BzXV2s2P.js} +1 -1
  51. package/dist/{npm-resolution--_-0q2ks.js → npm-resolution-CZUqHH_2.js} +1 -1
  52. package/dist/{onboard-DZG0HnuP.js → onboard-B8dVlGVk.js} +2 -2
  53. package/dist/{onboard-DlCEww7K.js → onboard-By9pkNca.js} +2 -2
  54. package/dist/{onboard-channels-BDMtq3ex.js → onboard-channels-C5lcb7dF.js} +1 -1
  55. package/dist/{onboard-channels-BO3AN_eA.js → onboard-channels-DFB6deX0.js} +1 -1
  56. package/dist/{onboarding-m-m__16h.js → onboarding-C7vbkuBI.js} +1 -1
  57. package/dist/{onboarding-CxRTJCBM.js → onboarding-DCldCoVy.js} +1 -1
  58. package/dist/{onboarding.finalize-BJxMhYUa.js → onboarding.finalize-C-b9zSIO.js} +1 -1
  59. package/dist/{onboarding.finalize-UiX3YmbI.js → onboarding.finalize-XCttW8IU.js} +1 -1
  60. package/dist/{pi-embedded-X_Svd4Wi.js → pi-embedded-CoHiJa9Q.js} +8 -8
  61. package/dist/{pi-embedded-6yGEd2xd.js → pi-embedded-DLlQ5e_w.js} +8 -8
  62. package/dist/{plugin-registry-DYwEy5eM.js → plugin-registry-C_HKxFxs.js} +1 -1
  63. package/dist/{plugin-registry-CN2aCPP7.js → plugin-registry-DBgXa8jD.js} +1 -1
  64. package/dist/plugin-sdk/{channel-web-Bg8DNyeb.js → channel-web-CMlv9Yzv.js} +1 -1
  65. package/dist/plugin-sdk/{channel-web-B795Ild9.cjs → channel-web-D1tzaMsH.cjs} +1 -1
  66. package/dist/plugin-sdk/{channel-web-D5zxPW-x.js → channel-web-DowgDxtO.js} +1 -1
  67. package/dist/plugin-sdk/{channel-web-CW42ALB5.cjs → channel-web-VsaRZCG2.cjs} +1 -1
  68. package/dist/plugin-sdk/{compact.runtime-Cr6oI5li.js → compact.runtime-B4M-VPyN.js} +1 -1
  69. package/dist/plugin-sdk/{compact.runtime-BR00C0_i.cjs → compact.runtime-BeWqnWW5.cjs} +1 -1
  70. package/dist/plugin-sdk/{compact.runtime-DOcQzBT5.cjs → compact.runtime-BnF9vU5j.cjs} +1 -1
  71. package/dist/plugin-sdk/{compact.runtime-D-3vVYGF.js → compact.runtime-C5vcsriA.js} +1 -1
  72. package/dist/plugin-sdk/{compact.runtime-BBqQuOlJ.cjs → compact.runtime-CS04yjUP.cjs} +1 -1
  73. package/dist/plugin-sdk/{compact.runtime-CGKItjCQ.js → compact.runtime-CepgZBh6.js} +1 -1
  74. package/dist/plugin-sdk/{compact.runtime-C-sPm0kL.cjs → compact.runtime-CuGn1L3D.cjs} +1 -1
  75. package/dist/plugin-sdk/{compact.runtime-CAiT8DtI.js → compact.runtime-DNocZUm6.js} +1 -1
  76. package/dist/plugin-sdk/{compact.runtime-CmQT69OD.cjs → compact.runtime-DQRsRwKH.cjs} +1 -1
  77. package/dist/plugin-sdk/{compact.runtime-BXuXwnQ_.cjs → compact.runtime-DnWYG9Ij.cjs} +1 -1
  78. package/dist/plugin-sdk/{compact.runtime-BxzvSPrQ.js → compact.runtime-W8dIsxRV.js} +1 -1
  79. package/dist/plugin-sdk/{compact.runtime-B1fslZX1.js → compact.runtime-hS2NXspw.js} +1 -1
  80. package/dist/plugin-sdk/compat.cjs +1 -1
  81. package/dist/plugin-sdk/compat.js +1 -1
  82. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-WXiE5pA7.js → deps-send-whatsapp.runtime-B5Nz8XrQ.js} +1 -1
  83. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-DKoOiTZZ.cjs → deps-send-whatsapp.runtime-B5R8WAYy.cjs} +1 -1
  84. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-DlO-S_iA.js → deps-send-whatsapp.runtime-B6ua6LoP.js} +1 -1
  85. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-BUuj08qp.cjs → deps-send-whatsapp.runtime-BPMIzR5x.cjs} +1 -1
  86. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-iI9qWUzR.cjs → deps-send-whatsapp.runtime-Bpq7VeGO.cjs} +1 -1
  87. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-3kX5dnHC.js → deps-send-whatsapp.runtime-D3YUudyV.js} +1 -1
  88. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-Xn1KqyPS.js → deps-send-whatsapp.runtime-DFxWO5_f.js} +1 -1
  89. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-CE9LgvzJ.cjs → deps-send-whatsapp.runtime-DZ_pLOPK.cjs} +1 -1
  90. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-t0Z0IyDq.cjs → deps-send-whatsapp.runtime-DyoJd0Hw.cjs} +1 -1
  91. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-rOnSc6qE.js → deps-send-whatsapp.runtime-ZkaerhQ1.js} +1 -1
  92. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-QUlRFE48.cjs → deps-send-whatsapp.runtime-_wzNB18A.cjs} +1 -1
  93. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-DKVfDIzU.js → deps-send-whatsapp.runtime-bBd46QxW.js} +1 -1
  94. package/dist/plugin-sdk/{dispatch-DAaOM5c1.cjs → dispatch-B8dzPpi1.cjs} +8 -8
  95. package/dist/plugin-sdk/{dispatch-DYRrW05S.js → dispatch-B9FQyNfe.js} +36 -36
  96. package/dist/plugin-sdk/{dispatch-Dl0eaYcY.cjs → dispatch-BB5AfYlI.cjs} +8 -8
  97. package/dist/plugin-sdk/{dispatch-_tJF5hSh.cjs → dispatch-BIaey_BU.cjs} +8 -8
  98. package/dist/plugin-sdk/{dispatch-B13B2T1k.js → dispatch-BY1FkQOr.js} +8 -8
  99. package/dist/plugin-sdk/{dispatch-cPg1rBWu.cjs → dispatch-Bybxc9Yl.cjs} +8 -8
  100. package/dist/plugin-sdk/{dispatch-BlOkbw2U.js → dispatch-CADw_Fi7.js} +8 -8
  101. package/dist/plugin-sdk/{dispatch-Dap2ZPC9.js → dispatch-CZqPeEcw.js} +8 -8
  102. package/dist/plugin-sdk/{dispatch-BaBcLOry.js → dispatch-DafB1x1O.js} +8 -8
  103. package/dist/plugin-sdk/{dispatch-D2Km7gvG.cjs → dispatch-DcyylSdu.cjs} +8 -8
  104. package/dist/plugin-sdk/index.cjs +1 -1
  105. package/dist/plugin-sdk/index.js +1 -1
  106. package/dist/plugin-sdk/irc.cjs +1 -1
  107. package/dist/plugin-sdk/irc.js +1 -1
  108. package/dist/plugin-sdk/matrix.cjs +1 -1
  109. package/dist/plugin-sdk/matrix.js +1 -1
  110. package/dist/plugin-sdk/msteams.cjs +1 -1
  111. package/dist/plugin-sdk/msteams.js +1 -1
  112. package/dist/plugin-sdk/nextcloud-talk.cjs +1 -1
  113. package/dist/plugin-sdk/nextcloud-talk.js +1 -1
  114. package/dist/plugin-sdk/{reply-JD6VIW5N.cjs → reply-6D8nZUZ1.cjs} +8 -8
  115. package/dist/plugin-sdk/{reply-73PF8kN_.js → reply-gpVkJsEs.js} +8 -8
  116. package/dist/plugin-sdk/{slash-dispatch.runtime-DAgDLU__.js → slash-dispatch.runtime-2hUZv0o4.js} +1 -1
  117. package/dist/plugin-sdk/{slash-dispatch.runtime-BfheQLfD.js → slash-dispatch.runtime-B4sdtKqK.js} +1 -1
  118. package/dist/plugin-sdk/{slash-dispatch.runtime-CmVqJqfV.js → slash-dispatch.runtime-BCAWJ135.js} +1 -1
  119. package/dist/plugin-sdk/{slash-dispatch.runtime-wWa-kKvH.js → slash-dispatch.runtime-BJX-7mTD.js} +1 -1
  120. package/dist/plugin-sdk/{slash-dispatch.runtime-C6cMCwSp.js → slash-dispatch.runtime-BY3aBzxK.js} +1 -1
  121. package/dist/plugin-sdk/{slash-dispatch.runtime-BVXTmhZU.js → slash-dispatch.runtime-CHFbytW1.js} +1 -1
  122. package/dist/plugin-sdk/{slash-dispatch.runtime-BcO6NdxL.cjs → slash-dispatch.runtime-Cf-EuMPD.cjs} +1 -1
  123. package/dist/plugin-sdk/{slash-dispatch.runtime-CYmmyw9o.cjs → slash-dispatch.runtime-CukipBLa.cjs} +1 -1
  124. package/dist/plugin-sdk/{slash-dispatch.runtime-DNI9fZFo.cjs → slash-dispatch.runtime-D7JTU7km.cjs} +1 -1
  125. package/dist/plugin-sdk/{slash-dispatch.runtime-BQWrcjEG.cjs → slash-dispatch.runtime-DZq0olM2.cjs} +1 -1
  126. package/dist/plugin-sdk/{slash-dispatch.runtime-Cp5-cPgM.cjs → slash-dispatch.runtime-ILA0KH-p.cjs} +1 -1
  127. package/dist/plugin-sdk/{slash-dispatch.runtime-CD6AFEn3.cjs → slash-dispatch.runtime-_i2UiDTt.cjs} +1 -1
  128. package/dist/plugin-sdk/{subagent-registry-runtime-BINR9wKz.cjs → subagent-registry-runtime-7wfZ9Ydg.cjs} +1 -1
  129. package/dist/plugin-sdk/{subagent-registry-runtime-q6csFFiS.js → subagent-registry-runtime-B6Go3QMY.js} +1 -1
  130. package/dist/plugin-sdk/{subagent-registry-runtime-CPYQLLoh.cjs → subagent-registry-runtime-Bf71VzVF.cjs} +1 -1
  131. package/dist/plugin-sdk/{subagent-registry-runtime-DCd8DMgz.js → subagent-registry-runtime-CKlyWpvM.js} +1 -1
  132. package/dist/plugin-sdk/{subagent-registry-runtime-BfT45xXa.cjs → subagent-registry-runtime-CcyvhbJH.cjs} +1 -1
  133. package/dist/plugin-sdk/{subagent-registry-runtime-DYhr9YcP.js → subagent-registry-runtime-D4y3Fxlu.js} +1 -1
  134. package/dist/plugin-sdk/{subagent-registry-runtime-BBwsJL9B.cjs → subagent-registry-runtime-DFCUhuvT.cjs} +1 -1
  135. package/dist/plugin-sdk/{subagent-registry-runtime-CjnSOShL.js → subagent-registry-runtime-DWZUy1eI.js} +1 -1
  136. package/dist/plugin-sdk/{subagent-registry-runtime-B9uDb_ij.js → subagent-registry-runtime-DkCs3cQj.js} +1 -1
  137. package/dist/plugin-sdk/{subagent-registry-runtime-DB8YDuGj.js → subagent-registry-runtime-RrhCNI-u.js} +1 -1
  138. package/dist/plugin-sdk/{subagent-registry-runtime-iiOzLeYb.cjs → subagent-registry-runtime-S2yCcuWA.cjs} +1 -1
  139. package/dist/plugin-sdk/{subagent-registry-runtime-ClkQBnJu.cjs → subagent-registry-runtime-zTYi4rJR.cjs} +1 -1
  140. package/dist/plugin-sdk/{web-Bh78uOi8.cjs → web-C-_Bja5u.cjs} +1 -1
  141. package/dist/plugin-sdk/{web-C4ezqWIt.js → web-C7h16O4t.js} +1 -1
  142. package/dist/plugin-sdk/{web-B7d3p3kx.cjs → web-Cf2Ivjcn.cjs} +1 -1
  143. package/dist/plugin-sdk/{web-DFDao2So.cjs → web-CfvlhITy.cjs} +1 -1
  144. package/dist/plugin-sdk/{web-JciOW43P.js → web-DzgvdKmn.js} +1 -1
  145. package/dist/plugin-sdk/{web-Bg2LIMdb.cjs → web-RmaRbUK1.cjs} +1 -1
  146. package/dist/plugin-sdk/{web-SwpoHf2A.js → web-bHdImk0G.js} +1 -1
  147. package/dist/plugin-sdk/{web-DjbeDvyv.js → web-bT52Rp59.js} +1 -1
  148. package/dist/plugin-sdk/{web-vSFigMHz.cjs → web-pFlzmHcu.cjs} +1 -1
  149. package/dist/plugin-sdk/{web-BEuW8Yqw.js → web-rFQBs9b0.js} +1 -1
  150. package/dist/plugin-sdk/{web--8MBOleK.js → web-uQqWClDT.js} +1 -1
  151. package/dist/plugin-sdk/{web-BPQv-4Qv.cjs → web-wnw_PMil.cjs} +1 -1
  152. package/dist/plugin-sdk/whatsapp.cjs +1 -1
  153. package/dist/plugin-sdk/whatsapp.js +1 -1
  154. package/dist/{plugins-cli-PVHBZeb8.js → plugins-cli-BjLj52hA.js} +1 -1
  155. package/dist/{plugins-cli-CnXgwZzI.js → plugins-cli-CwQOOOym.js} +1 -1
  156. package/dist/ports-BDZyt9rk.js +2 -0
  157. package/dist/ports-DmJX-iq9.js +2 -0
  158. package/dist/{program-D53eGuSf.js → program-RvezCMDs.js} +2 -2
  159. package/dist/{program-context-n-ovYq69.js → program-context-C4vPkfWW.js} +1 -1
  160. package/dist/{prompt-select-styled-DolCW-_j.js → prompt-select-styled-C-zw_5_b.js} +1 -1
  161. package/dist/{prompt-select-styled-DZnefcrY.js → prompt-select-styled-CoP6cSMX.js} +1 -1
  162. package/dist/{provider-auth-helpers-BLm2bdp5.js → provider-auth-helpers-DeCLF5oV.js} +1 -1
  163. package/dist/{provider-auth-helpers-DPz0vN_c.js → provider-auth-helpers-Rv3hdZ7j.js} +1 -1
  164. package/dist/{push-apns-BBv62ncV.js → push-apns-BfTKAzRZ.js} +1 -1
  165. package/dist/{push-apns-DIV5dBPP.js → push-apns-CeY33Rxc.js} +1 -1
  166. package/dist/{register.agent-DQdoMfmw.js → register.agent-CANRVL5k.js} +1 -1
  167. package/dist/{register.agent-DHOTtB8X.js → register.agent-He4UYNpV.js} +1 -1
  168. package/dist/{register.configure-C2N82brC.js → register.configure-CqsxTDtC.js} +1 -1
  169. package/dist/{register.configure-C6zjzaEo.js → register.configure-CwuLuKsv.js} +1 -1
  170. package/dist/{register.maintenance-CStaPxaB.js → register.maintenance-B5cnDjLy.js} +1 -1
  171. package/dist/{register.maintenance-aKBTd9Zp.js → register.maintenance-CHJQh81L.js} +1 -1
  172. package/dist/{register.message-DHDcOA8X.js → register.message-CEcXemHd.js} +1 -1
  173. package/dist/{register.message-Dh72QHKA.js → register.message-DoA6MALf.js} +1 -1
  174. package/dist/{register.onboard-DB9FWAKT.js → register.onboard-B01N1AYH.js} +1 -1
  175. package/dist/{register.onboard-Bu9gpFlA.js → register.onboard-B5iQpfVG.js} +1 -1
  176. package/dist/{register.setup-D76IRs4s.js → register.setup-BTKZzyRh.js} +1 -1
  177. package/dist/{register.setup-CeG2ETmr.js → register.setup-CPGByOtO.js} +1 -1
  178. package/dist/{register.status-health-sessions-mPGKFjIz.js → register.status-health-sessions-CPmSNp3F.js} +1 -1
  179. package/dist/{register.status-health-sessions-Dtpd1P2M.js → register.status-health-sessions-hrQLxH-w.js} +1 -1
  180. package/dist/{register.subclis-Drp2dGBe.js → register.subclis-CqVDIyhT.js} +1 -1
  181. package/dist/{reply-DwfVhea1.js → reply-mWIMy_ju.js} +8 -8
  182. package/dist/{run-main-CjwjyWA6.js → run-main-B2f6FBb0.js} +1 -1
  183. package/dist/{server-node-events-CL0pWoMa.js → server-node-events-BtKnElP0.js} +1 -1
  184. package/dist/{server-node-events-ChPQ984b.js → server-node-events-DnyBXZtB.js} +1 -1
  185. package/dist/{slash-dispatch.runtime-jR7ZpRLo.js → slash-dispatch.runtime-B8S9VVjy.js} +1 -1
  186. package/dist/{slash-dispatch.runtime-CHDiNcch.js → slash-dispatch.runtime-CS58xiJF.js} +1 -1
  187. package/dist/{slash-dispatch.runtime-DgsOlRbg.js → slash-dispatch.runtime-CZrxUnBW.js} +1 -1
  188. package/dist/{slash-dispatch.runtime-Bh87LG5X.js → slash-dispatch.runtime-Cq_OU6GL.js} +1 -1
  189. package/dist/{status-o3Gfr-6l.js → status-C3OhTrWE.js} +1 -1
  190. package/dist/{status-BSHWBrg0.js → status-tL-XCvJC.js} +1 -1
  191. package/dist/{subagent-registry-runtime-B8nEWxYm.js → subagent-registry-runtime-BvPAovsV.js} +1 -1
  192. package/dist/{subagent-registry-runtime-D5PhzS7u.js → subagent-registry-runtime-ClREKCLG.js} +1 -1
  193. package/dist/{subagent-registry-runtime-C6xoTyr_.js → subagent-registry-runtime-D2cjV86K.js} +1 -1
  194. package/dist/{subagent-registry-runtime-DU6-3b5M.js → subagent-registry-runtime-dcrGDOTV.js} +1 -1
  195. package/dist/{update-cli-DU5tRH3c.js → update-cli-CZsuMrHE.js} +1 -1
  196. package/dist/{update-cli-CL_cUjuq.js → update-cli-DAPHNGDM.js} +1 -1
  197. package/dist/{update-runner-DG-1TYYc.js → update-runner-DZkN4otc.js} +1 -1
  198. package/dist/{update-runner-DABdlxfN.js → update-runner-DhaHCCx3.js} +1 -1
  199. package/dist/{web-C0WkwHal.js → web-BPloShgg.js} +1 -1
  200. package/dist/{web-u71NbOpT.js → web-BbOH61Lx.js} +1 -1
  201. package/dist/{web-DPQjx48C.js → web-CMSYMAHG.js} +1 -1
  202. package/dist/{web-Dfi2WjvN.js → web-WBvnAfBv.js} +1 -1
  203. package/extensions/qqbrowser-skill-control/index.js +1 -1
  204. package/node_modules/@google/genai/dist/index.cjs +8 -8
  205. package/node_modules/@google/genai/dist/index.mjs +8 -8
  206. package/node_modules/@google/genai/dist/node/index.cjs +8 -8
  207. package/node_modules/@google/genai/dist/node/index.mjs +8 -8
  208. package/node_modules/@google/genai/dist/vertex_internal/index.cjs +1 -1
  209. package/node_modules/@google/genai/dist/vertex_internal/index.js +1 -1
  210. package/node_modules/@google/genai/dist/web/index.mjs +8 -8
  211. package/node_modules/@google/genai/package.json +1 -1
  212. package/package.json +1 -1
  213. package/dist/ports-BAaLOkJp.js +0 -2
  214. package/dist/ports-DDWP1p0X.js +0 -2
@@ -1,4 +1,4 @@
1
- import{t as e}from"./rolldown-runtime-CNxR59P3.js";import{A as t,k as n,p as r,t as i,y as a}from"./subsystem-C5XF2Fy5.js";import{l as o}from"./utils-UGOV_184.js";import{Hn as s,Jn as c,Kn as l,Lr as u,Rr as d,Xs as f,qs as p,yc as m}from"./model-selection-BLbnMb5E.js";import{Gt as h,Kt as g,Mr as _,Qr as v,Un as y,Wn as b,Yt as x,ai as S,br as C,ii as w,kr as T,oi as E,qt as D,si as O,t as ee,v as k,wn as A}from"./reply-DwfVhea1.js";import{b as te,d as ne,f as j,i as M}from"./agent-scope-DXZc3eNT.js";import{E as re,c as N,h as P,u as F}from"./session-key-D3P0tf5P.js";import{t as I}from"./env-D7wNuBx1.js";import{g as ie,lt as L,n as R,t as ae,v as z}from"./plugins-CYLrFT4h.js";import{a as oe,r as B}from"./errors-Bunti32V.js";import{c as V,n as se}from"./paths-yLEk_25I.js";import{t as H}from"./tokens-XGbQGn67.js";import{t as ce}from"./deliver-DUNkj4hy.js";import{n as le,t as ue}from"./call-JB-cGR9n.js";import{n as de}from"./progress-LNttnI-y.js";import{a as U,n as W,o as fe,t as pe}from"./heartbeat-visibility-q74UdY8O.js";import G from"node:path";import K from"node:fs/promises";const me=/^(?:([01]\d|2[0-3]):([0-5]\d)|24:00)$/;function he(e,t){let n=t?.trim();if(!n||n===`user`)return _(e.agents?.defaults?.userTimezone);if(n===`local`)return Intl.DateTimeFormat().resolvedOptions().timeZone?.trim()||`UTC`;try{return new Intl.DateTimeFormat(`en-US`,{timeZone:n}).format(new Date),n}catch{return _(e.agents?.defaults?.userTimezone)}}function ge(e,t){if(!t||!me.test(t))return null;let[n,r]=t.split(`:`),i=Number(n),a=Number(r);return!Number.isFinite(i)||!Number.isFinite(a)?null:i===24?!e.allow24||a!==0?null:1440:i*60+a}function _e(e,t){try{let n=new Intl.DateTimeFormat(`en-US`,{timeZone:t,hour:`2-digit`,minute:`2-digit`,hourCycle:`h23`}).formatToParts(new Date(e)),r={};for(let e of n)e.type!==`literal`&&(r[e.type]=e.value);let i=Number(r.hour),a=Number(r.minute);return!Number.isFinite(i)||!Number.isFinite(a)?null:i*60+a}catch{return null}}function ve(e,t,n){let r=t?.activeHours;if(!r)return!0;let i=ge({allow24:!1},r.start),a=ge({allow24:!0},r.end);if(i===null||a===null)return!0;if(i===a)return!1;let o=he(e,r.timezone),s=_e(n??Date.now(),o);return s===null?!0:a>i?s>=i&&s<a:s>=i||s<a}function ye(e,t){let n=t?.deliverToUser??!0,r=e.join(`
1
+ import{t as e}from"./rolldown-runtime-CNxR59P3.js";import{A as t,k as n,p as r,t as i,y as a}from"./subsystem-C5XF2Fy5.js";import{l as o}from"./utils-UGOV_184.js";import{Hn as s,Jn as c,Kn as l,Lr as u,Rr as d,Xs as f,qs as p,yc as m}from"./model-selection-BLbnMb5E.js";import{Gt as h,Kt as g,Mr as _,Qr as v,Un as y,Wn as b,Yt as x,ai as S,br as C,ii as w,kr as T,oi as E,qt as D,si as O,t as ee,v as k,wn as A}from"./reply-mWIMy_ju.js";import{b as te,d as ne,f as j,i as M}from"./agent-scope-DXZc3eNT.js";import{E as re,c as N,h as P,u as F}from"./session-key-D3P0tf5P.js";import{t as I}from"./env-D7wNuBx1.js";import{g as ie,lt as L,n as R,t as ae,v as z}from"./plugins-CYLrFT4h.js";import{a as oe,r as B}from"./errors-Bunti32V.js";import{c as V,n as se}from"./paths-yLEk_25I.js";import{t as H}from"./tokens-XGbQGn67.js";import{t as ce}from"./deliver-DUNkj4hy.js";import{n as le,t as ue}from"./call-JB-cGR9n.js";import{n as de}from"./progress-LNttnI-y.js";import{a as U,n as W,o as fe,t as pe}from"./heartbeat-visibility-q74UdY8O.js";import G from"node:path";import K from"node:fs/promises";const me=/^(?:([01]\d|2[0-3]):([0-5]\d)|24:00)$/;function he(e,t){let n=t?.trim();if(!n||n===`user`)return _(e.agents?.defaults?.userTimezone);if(n===`local`)return Intl.DateTimeFormat().resolvedOptions().timeZone?.trim()||`UTC`;try{return new Intl.DateTimeFormat(`en-US`,{timeZone:n}).format(new Date),n}catch{return _(e.agents?.defaults?.userTimezone)}}function ge(e,t){if(!t||!me.test(t))return null;let[n,r]=t.split(`:`),i=Number(n),a=Number(r);return!Number.isFinite(i)||!Number.isFinite(a)?null:i===24?!e.allow24||a!==0?null:1440:i*60+a}function _e(e,t){try{let n=new Intl.DateTimeFormat(`en-US`,{timeZone:t,hour:`2-digit`,minute:`2-digit`,hourCycle:`h23`}).formatToParts(new Date(e)),r={};for(let e of n)e.type!==`literal`&&(r[e.type]=e.value);let i=Number(r.hour),a=Number(r.minute);return!Number.isFinite(i)||!Number.isFinite(a)?null:i*60+a}catch{return null}}function ve(e,t,n){let r=t?.activeHours;if(!r)return!0;let i=ge({allow24:!1},r.start),a=ge({allow24:!0},r.end);if(i===null||a===null)return!0;if(i===a)return!1;let o=he(e,r.timezone),s=_e(n??Date.now(),o);return s===null?!0:a>i?s>=i&&s<a:s>=i||s<a}function ye(e,t){let n=t?.deliverToUser??!0,r=e.join(`
2
2
  `).trim();return r?n?`A scheduled reminder has been triggered. The reminder content is:
3
3
 
4
4
  `+r+`
@@ -1,4 +1,4 @@
1
- import{t as e}from"./rolldown-runtime-CNxR59P3.js";import{A as t,k as n,p as r,t as i,y as a}from"./subsystem-BLbY429l.js";import{i as o}from"./entry.js";import{En as s,Ft as c,Lt as l,Po as u,Tn as d,jo as f,jt as p}from"./auth-profiles-C8rZRS0X.js";import{b as m,d as h,f as g,i as _}from"./agent-scope-DAWJwFfl.js";import{E as v,c as y,h as b,u as x}from"./session-key-C7F_iqYg.js";import{c as S}from"./utils-CGdo13HV.js";import{t as C}from"./parse-duration-XTjMKl8s.js";import{g as w,lt as T,n as E,t as D,v as O}from"./plugins-DNlgeTTc.js";import{a as k,r as A}from"./errors-6SQWM9dj.js";import{$r as j,Ar as M,Nr as N,Q as ee,Tn as P,ai as te,ci as F,ct as ne,oi as re,ot as ie,pr as ae,si as I,sr as oe,st as se,ut as ce,vt as le,yt as ue}from"./compact-CYbPi7_-.js";import{c as L,n as de}from"./paths-BfjJY2VL.js";import{t as R}from"./tokens-DRM8vzJx.js";import{t as z}from"./deliver-SqSusZP3.js";import{n as fe,t as pe}from"./call-BWx7hNtl.js";import{n as me}from"./progress-d1m2sqR1.js";import{a as B,n as V,o as he,t as ge}from"./heartbeat-visibility-BQ_esv2m.js";import H from"node:path";import U from"node:fs/promises";const _e=/^(?:([01]\d|2[0-3]):([0-5]\d)|24:00)$/;function ve(e,t){let n=t?.trim();if(!n||n===`user`)return N(e.agents?.defaults?.userTimezone);if(n===`local`)return Intl.DateTimeFormat().resolvedOptions().timeZone?.trim()||`UTC`;try{return new Intl.DateTimeFormat(`en-US`,{timeZone:n}).format(new Date),n}catch{return N(e.agents?.defaults?.userTimezone)}}function W(e,t){if(!t||!_e.test(t))return null;let[n,r]=t.split(`:`),i=Number(n),a=Number(r);return!Number.isFinite(i)||!Number.isFinite(a)?null:i===24?!e.allow24||a!==0?null:1440:i*60+a}function ye(e,t){try{let n=new Intl.DateTimeFormat(`en-US`,{timeZone:t,hour:`2-digit`,minute:`2-digit`,hourCycle:`h23`}).formatToParts(new Date(e)),r={};for(let e of n)e.type!==`literal`&&(r[e.type]=e.value);let i=Number(r.hour),a=Number(r.minute);return!Number.isFinite(i)||!Number.isFinite(a)?null:i*60+a}catch{return null}}function be(e,t,n){let r=t?.activeHours;if(!r)return!0;let i=W({allow24:!1},r.start),a=W({allow24:!0},r.end);if(i===null||a===null)return!0;if(i===a)return!1;let o=ve(e,r.timezone),s=ye(n??Date.now(),o);return s===null?!0:a>i?s>=i&&s<a:s>=i||s<a}function xe(e,t){let n=t?.deliverToUser??!0,r=e.join(`
1
+ import{t as e}from"./rolldown-runtime-CNxR59P3.js";import{A as t,k as n,p as r,t as i,y as a}from"./subsystem-BLbY429l.js";import{i as o}from"./entry.js";import{En as s,Ft as c,Lt as l,Po as u,Tn as d,jo as f,jt as p}from"./auth-profiles-C8rZRS0X.js";import{b as m,d as h,f as g,i as _}from"./agent-scope-DAWJwFfl.js";import{E as v,c as y,h as b,u as x}from"./session-key-C7F_iqYg.js";import{c as S}from"./utils-CGdo13HV.js";import{t as C}from"./parse-duration-XTjMKl8s.js";import{g as w,lt as T,n as E,t as D,v as O}from"./plugins-DNlgeTTc.js";import{a as k,r as A}from"./errors-6SQWM9dj.js";import{$r as j,Ar as M,Nr as N,Q as ee,Tn as P,ai as te,ci as F,ct as ne,oi as re,ot as ie,pr as ae,si as I,sr as oe,st as se,ut as ce,vt as le,yt as ue}from"./compact-uyQDx8pN.js";import{c as L,n as de}from"./paths-BfjJY2VL.js";import{t as R}from"./tokens-DRM8vzJx.js";import{t as z}from"./deliver-SqSusZP3.js";import{n as fe,t as pe}from"./call-BWx7hNtl.js";import{n as me}from"./progress-d1m2sqR1.js";import{a as B,n as V,o as he,t as ge}from"./heartbeat-visibility-BQ_esv2m.js";import H from"node:path";import U from"node:fs/promises";const _e=/^(?:([01]\d|2[0-3]):([0-5]\d)|24:00)$/;function ve(e,t){let n=t?.trim();if(!n||n===`user`)return N(e.agents?.defaults?.userTimezone);if(n===`local`)return Intl.DateTimeFormat().resolvedOptions().timeZone?.trim()||`UTC`;try{return new Intl.DateTimeFormat(`en-US`,{timeZone:n}).format(new Date),n}catch{return N(e.agents?.defaults?.userTimezone)}}function W(e,t){if(!t||!_e.test(t))return null;let[n,r]=t.split(`:`),i=Number(n),a=Number(r);return!Number.isFinite(i)||!Number.isFinite(a)?null:i===24?!e.allow24||a!==0?null:1440:i*60+a}function ye(e,t){try{let n=new Intl.DateTimeFormat(`en-US`,{timeZone:t,hour:`2-digit`,minute:`2-digit`,hourCycle:`h23`}).formatToParts(new Date(e)),r={};for(let e of n)e.type!==`literal`&&(r[e.type]=e.value);let i=Number(r.hour),a=Number(r.minute);return!Number.isFinite(i)||!Number.isFinite(a)?null:i*60+a}catch{return null}}function be(e,t,n){let r=t?.activeHours;if(!r)return!0;let i=W({allow24:!1},r.start),a=W({allow24:!0},r.end);if(i===null||a===null)return!0;if(i===a)return!1;let o=ve(e,r.timezone),s=ye(n??Date.now(),o);return s===null?!0:a>i?s>=i&&s<a:s>=i||s<a}function xe(e,t){let n=t?.deliverToUser??!0,r=e.join(`
2
2
  `).trim();return r?n?`A scheduled reminder has been triggered. The reminder content is:
3
3
 
4
4
  `+r+`
@@ -1,4 +1,4 @@
1
- import{A as e,p as t}from"./subsystem-BLbY429l.js";import"./paths-BjD3T_xq.js";import"./boolean-D15s2V33.js";import{Bo as n,jo as r,xa as i}from"./auth-profiles-C8rZRS0X.js";import{t as a}from"./command-format-CLxIPuLR.js";import{d as o,f as s}from"./agent-scope-DAWJwFfl.js";import{t as c,v as l,x as u}from"./utils-CGdo13HV.js";import"./openclaw-root-CnsBf6ZU.js";import"./github-copilot-token-C79yeDKS.js";import{_ as d}from"./env-overrides-DHtB4kK3.js";import"./version-q3SkUw2K.js";import{n as f,r as p}from"./scan-paths-CWtvWW40.js";import"./registry-BptzrW8D.js";import"./skills-Bz_S4lPh.js";import{m}from"./frontmatter-C7mzDNxd.js";import"./plugins-DNlgeTTc.js";import"./logger-kQAOe3qp.js";import"./exec-B3eleY5O.js";import"./windows-spawn-7oINn5ao.js";import"./redact-CnRxK70G.js";import"./path-alias-guards-kY_ZbWs-.js";import"./errors-6SQWM9dj.js";import"./send-vNcod64S.js";import"./send-CyarIb2w.js";import"./compact-CYbPi7_-.js";import"./paths-BfjJY2VL.js";import"./chat-envelope-Bznn2SoS.js";import"./models-config-DZzS67GS.js";import"./tokens-DRM8vzJx.js";import"./with-timeout-c1CzdShT.js";import"./deliver-SqSusZP3.js";import"./diagnostic-D1H7_8QG.js";import"./send-Dj7NBAWg.js";import"./pi-model-discovery-BPkhPDMr.js";import"./exec-approvals-allowlist-CGjRWREs.js";import"./exec-safe-bin-runtime-policy-v44u39fl.js";import"./model-catalog-mt0IcDfR.js";import"./fetch-B4bz67_N.js";import"./audio-transcription-runner-BIKj1CBU.js";import"./fetch-guard-DaZmvp-L.js";import"./image-BVbOr9yV.js";import"./tool-display-DJDtttQg.js";import"./api-key-rotation-BpEL4aeX.js";import"./proxy-fetch-gWETR3cl.js";import"./ir-DdjufzKF.js";import"./render-DrrPmnMI.js";import"./target-errors-D6wejRd6.js";import"./commands-Dy7duWlt.js";import"./commands-registry-DT6FDUev.js";import"./session-cost-usage-CHtVgnE8.js";import"./session-utils-Bpdyx2A2.js";import"./sqlite-CILF3z9U.js";import"./call-BWx7hNtl.js";import"./pi-tools.policy-B6q8YOfg.js";import"./pairing-store-BaaVy1zB.js";import"./fetch-Dh-apy46.js";import"./skill-commands-DCqPy_Aa.js";import"./workspace-dirs-A8Vib9_B.js";import"./pairing-token-zdbQ951y.js";import"./channel-activity-BhiLsKvM.js";import"./tables-DENKrP-W.js";import"./kill-tree-D6nPx1_o.js";import"./runtime-web-tools-BYhCkBV8.js";import"./runtime-CK7gqwEF.js";import"./node-shell-BVZylVP6.js";import"./stagger-DxzgG2jd.js";import"./channel-selection-BPxE8JR7.js";import"./plugin-auto-enable-adba5Evb.js";import"./send-ChILboDj.js";import"./outbound-attachment-CVcDBkAD.js";import"./delivery-queue-nkPJu0fY.js";import"./send-COpehmAB.js";import"./system-run-command-DsWBVvSK.js";import"./fetch-Ce-scEU-.js";import"./command-secret-targets-BEjtBf5Z.js";import"./connection-auth-CjaeEu5D.js";import"./onboard-helpers-DOlI17Ac.js";import"./prompt-style-BThRSQJR.js";import"./pairing-labels-CZ-aX-up.js";import"./search-manager-CV2YsAym.js";import"./manager-CxZRoQkE.js";import"./memory-cli-C8fBBPgv.js";import{t as h}from"./links-CBnmRP9D.js";import"./cli-utils-BleB1eys.js";import"./help-format-B4aEI7V9.js";import"./progress-d1m2sqR1.js";import"./exec-approvals-BXO9Cezj.js";import{a as ee,c as g,l as te,n as _,u as v}from"./install-safe-path-C6kc_8NW.js";import{a as y,c as b,f as ne,i as re,l as ie,n as ae,o as x,r as oe,s as se,t as ce,u as le}from"./npm-pack-install-C0te3Oap.js";import{n as ue,t as de}from"./table-CR7TFMew.js";import{a as S,t as C}from"./workspace-xNEpaJvu.js";import{t as w}from"./hooks-status-BHt-Xvh4.js";import{i as T,n as E,r as fe,t as pe}from"./npm-resolution--_-0q2ks.js";import D from"node:path";import O from"node:fs";import k from"node:fs/promises";async function me(e){let t=e.spec.trim(),n=d(t);return n?{ok:!1,error:n}:ce(await ae({tempDirPrefix:e.tempDirPrefix,spec:t,timeoutMs:e.timeoutMs,expectedIntegrity:e.expectedIntegrity,onIntegrityDrift:e.onIntegrityDrift,warn:e.warn,installFromArchive:e.installFromArchive,archiveInstallParams:e.archiveInstallParams}))}const A={};function j(e){return{hooksDir:e.hooksDir,timeoutMs:e.timeoutMs,logger:e.logger,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId}}function M(e){return e?e===`.`||e===`..`?`invalid hook name: reserved path segment`:e.includes(`/`)||e.includes(`\\`)?`invalid hook name: path separators not allowed`:null:`invalid hook name: missing`}function N(e,t){let n=t?l(t):D.join(c,`hooks`),r=M(e);if(r)throw Error(r);let i=_({baseDir:n,id:e,invalidNameMessage:`invalid hook name: path traversal detected`});if(!i.ok)throw Error(i.error);return i.path}async function P(e){let t=e[m]?.hooks;if(!Array.isArray(t))throw Error(`package.json missing openclaw.hooks`);let n=t.map(e=>typeof e==`string`?e.trim():``).filter(Boolean);if(n.length===0)throw Error(`package.json openclaw.hooks is empty`);return n}async function F(e,t){return await re({baseDir:t?l(t):D.join(c,`hooks`),id:e,invalidNameMessage:`invalid hook name: path traversal detected`,boundaryLabel:`hooks directory`})}async function I(e){let t=await F(e.id,e.hooksDir);if(!t.ok)return t;let n=t.targetDir,r=await oe({mode:e.mode,targetDir:n,alreadyExistsError:e.alreadyExistsError(n)});return r.ok?{ok:!0,targetDir:n}:r}async function L(e,t){return await g(D.join(e,`package.json`))?await he({packageDir:e,hooksDir:t.hooksDir,timeoutMs:t.timeoutMs,logger:t.logger,mode:t.mode,dryRun:t.dryRun,expectedHookPackId:t.expectedHookPackId}):await ge({hookDir:e,hooksDir:t.hooksDir,logger:t.logger,mode:t.mode,dryRun:t.dryRun,expectedHookPackId:t.expectedHookPackId})}async function R(e){let t=D.join(e,`HOOK.md`);if(!await g(t))throw Error(`HOOK.md missing in ${e}`);return S(await k.readFile(t,`utf-8`)).name||D.basename(e)}async function z(e){if(!await g(D.join(e,`HOOK.md`)))throw Error(`HOOK.md missing in ${e}`);if(!await Promise.all([`handler.ts`,`handler.js`,`index.ts`,`index.js`].map(async t=>g(D.join(e,t)))).then(e=>e.some(Boolean)))throw Error(`handler.ts/handler.js/index.ts/index.js missing in ${e}`)}async function he(e){let{logger:t,timeoutMs:n,mode:r,dryRun:i}=b(e,A),a=D.join(e.packageDir,`package.json`);if(!await g(a))return{ok:!1,error:`package.json missing`};let o;try{o=await te(a)}catch(e){return{ok:!1,error:`invalid package.json: ${String(e)}`}}let s;try{s=await P(o)}catch(e){return{ok:!1,error:String(e)}}let c=typeof o.name==`string`?o.name:``,l=c?ee(c):D.basename(e.packageDir),u=M(l);if(u)return{ok:!1,error:u};if(e.expectedHookPackId&&e.expectedHookPackId!==l)return{ok:!1,error:`hook pack id mismatch: expected ${e.expectedHookPackId}, got ${l}`};let d=await I({id:l,hooksDir:e.hooksDir,mode:r,alreadyExistsError:e=>`hook pack already exists: ${e} (delete it first)`});if(!d.ok)return d;let m=d.targetDir,h=[];for(let t of s){let n=D.resolve(e.packageDir,t);if(!f(e.packageDir,n))return{ok:!1,error:`openclaw.hooks entry escapes package directory: ${t}`};if(await z(n),!p(e.packageDir,n,{requireRealpath:!0}))return{ok:!1,error:`openclaw.hooks entry resolves outside package directory: ${t}`};let r=await R(n);h.push(r)}if(i)return{ok:!0,hookPackId:l,hooks:h,targetDir:m,version:typeof o.version==`string`?o.version:void 0};let _=await x({sourceDir:e.packageDir,targetDir:m,mode:r,timeoutMs:n,logger:t,copyErrorPrefix:`failed to copy hook pack`,depsLogMessage:`Installing hook pack dependencies…`,manifestDependencies:o.dependencies});return _.ok?{ok:!0,hookPackId:l,hooks:h,targetDir:m,version:typeof o.version==`string`?o.version:void 0}:_}async function ge(e){let{logger:t,mode:n,dryRun:r}=se(e,A);await z(e.hookDir);let i=await R(e.hookDir),a=M(i);if(a)return{ok:!1,error:a};if(e.expectedHookPackId&&e.expectedHookPackId!==i)return{ok:!1,error:`hook id mismatch: expected ${e.expectedHookPackId}, got ${i}`};let o=await I({id:i,hooksDir:e.hooksDir,mode:n,alreadyExistsError:e=>`hook already exists: ${e} (delete it first)`});if(!o.ok)return o;let s=o.targetDir;if(r)return{ok:!0,hookPackId:i,hooks:[i],targetDir:s};let c=await y({sourceDir:e.hookDir,targetDir:s,mode:n,timeoutMs:12e4,logger:t,copyErrorPrefix:`failed to copy hook`,hasDeps:!1,depsLogMessage:`Installing hook dependencies…`});return c.ok?{ok:!0,hookPackId:i,hooks:[i],targetDir:s}:c}async function B(e){let t=e.logger??A,n=e.timeoutMs??12e4,r=await ne(e.archivePath);if(!r.ok)return r;let i=r.path;return await le({archivePath:i,tempDirPrefix:`openclaw-hook-`,timeoutMs:n,logger:t,onExtracted:async r=>await L(r,j({hooksDir:e.hooksDir,timeoutMs:n,logger:t,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId}))})}async function V(e){let{logger:t,timeoutMs:n,mode:r,dryRun:i}=b(e,A),a=e.expectedHookPackId,o=e.spec;return t.info?.(`Downloading ${o.trim()}…`),await me({tempDirPrefix:`openclaw-hook-pack-`,spec:o,timeoutMs:n,expectedIntegrity:e.expectedIntegrity,onIntegrityDrift:e.onIntegrityDrift,warn:e=>{t.warn?.(e)},installFromArchive:B,archiveInstallParams:j({hooksDir:e.hooksDir,timeoutMs:n,logger:t,mode:r,dryRun:i,expectedHookPackId:a})})}async function H(e){let t=await ie(e.path);if(!t.ok)return t;let{resolvedPath:n,stat:r}=t,i=j({hooksDir:e.hooksDir,timeoutMs:e.timeoutMs,logger:e.logger,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId});return r.isDirectory()?await L(n,i):v(n)?await B({archivePath:n,...i}):{ok:!1,error:`unsupported hook file: ${n}`}}function U(e,t){let{hookId:n,...r}=t,i={...e.hooks?.internal?.installs,[n]:{...e.hooks?.internal?.installs?.[n],...r,installedAt:r.installedAt??new Date().toISOString()}};return{...e,hooks:{...e.hooks,internal:{...e.hooks?.internal,installs:{...i,[n]:i[n]}}}}}function _e(e,t){let n=new Map;for(let t of e)n.set(t.hook.name,t);for(let e of t)n.set(e.hook.name,e);return Array.from(n.values())}function W(e){let t=o(e,s(e)),n=C(t,{config:e});return w(t,{config:e,entries:_e(T({config:e,workspaceDir:t}).hooks.map(e=>e.entry),n)})}function G(e,t,n){let r=e.hooks.find(e=>e.name===t);if(!r)throw Error(`Hook "${t}" not found`);if(r.managedByPlugin)throw Error(`Hook "${t}" is managed by plugin "${r.pluginId??`unknown`}" and cannot be enabled/disabled.`);if(n?.requireEligible&&!r.eligible)throw Error(`Hook "${t}" is not eligible (missing requirements)`);return r}function K(e){let t={...e.config.hooks?.internal?.entries};t[e.hookName]={...t[e.hookName],enabled:e.enabled};let n={...e.config.hooks?.internal,...e.ensureHooksEnabled?{enabled:!0}:{},entries:t};return{...e.config,hooks:{...e.config.hooks,internal:n}}}function ve(t){return t.eligible?e.success(`✓ ready`):t.disabled?e.warn(`⏸ disabled`):e.error(`✗ missing`)}function ye(t){return`${t.emoji??`🔗`} ${e.command(t.name)}`}function be(e){return e.managedByPlugin?`plugin:${e.pluginId??`unknown`}`:e.source}function xe(e){let t=[];return e.missing.bins.length>0&&t.push(`bins: ${e.missing.bins.join(`, `)}`),e.missing.anyBins.length>0&&t.push(`anyBins: ${e.missing.anyBins.join(`, `)}`),e.missing.env.length>0&&t.push(`env: ${e.missing.env.join(`, `)}`),e.missing.config.length>0&&t.push(`config: ${e.missing.config.join(`, `)}`),e.missing.os.length>0&&t.push(`os: ${e.missing.os.join(`, `)}`),t.join(`; `)}function Se(n){t.error(`${e.error(`Error:`)} ${n instanceof Error?n.message:String(n)}`),process.exit(1)}async function q(e){try{await e()}catch(e){Se(e)}}function J(){return{info:e=>t.log(e),warn:n=>t.log(e.warn(n))}}function Y(){t.log(`Restart the gateway to load hooks.`)}function X(n,r){let i=r.resolution.resolvedSpec??r.spec;t.log(e.warn(`Integrity drift detected for "${n}" (${i})\nExpected: ${r.expectedIntegrity}\nActual: ${r.actualIntegrity}`))}async function Z(e){try{let t=await k.readFile(D.join(e,`package.json`),`utf-8`),n=JSON.parse(t);return typeof n.version==`string`?n.version:void 0}catch{return}}function Q(e,t){let n={...e.hooks?.internal?.entries};for(let e of t)n[e]={...n[e],enabled:!0};return{...e,hooks:{...e.hooks,internal:{...e.hooks?.internal,enabled:!0,entries:n}}}}function $(t,n){let r=n.eligible?t.hooks.filter(e=>e.eligible):t.hooks;if(n.json){let e={workspaceDir:t.workspaceDir,managedHooksDir:t.managedHooksDir,hooks:r.map(e=>({name:e.name,description:e.description,emoji:e.emoji,eligible:e.eligible,disabled:e.disabled,source:e.source,pluginId:e.pluginId,events:e.events,homepage:e.homepage,missing:e.missing,managedByPlugin:e.managedByPlugin}))};return JSON.stringify(e,null,2)}if(r.length===0)return n.eligible?`No eligible hooks found. Run \`${a(`openclaw hooks list`)}\` to see all hooks.`:`No hooks found.`;let i=r.filter(e=>e.eligible),o=de(),s=r.map(t=>{let n=xe(t);return{Status:ve(t),Hook:ye(t),Description:e.muted(t.description),Source:be(t),Missing:n?e.warn(n):``}}),c=[{key:`Status`,header:`Status`,minWidth:10},{key:`Hook`,header:`Hook`,minWidth:18,flex:!0},{key:`Description`,header:`Description`,minWidth:24,flex:!0},{key:`Source`,header:`Source`,minWidth:12,flex:!0}];n.verbose&&c.push({key:`Missing`,header:`Missing`,minWidth:18,flex:!0});let l=[];return l.push(`${e.heading(`Hooks`)} ${e.muted(`(${i.length}/${r.length} ready)`)}`),l.push(ue({width:o,columns:c,rows:s}).trimEnd()),l.join(`
1
+ import{A as e,p as t}from"./subsystem-BLbY429l.js";import"./paths-BjD3T_xq.js";import"./boolean-D15s2V33.js";import{Bo as n,jo as r,xa as i}from"./auth-profiles-C8rZRS0X.js";import{t as a}from"./command-format-CLxIPuLR.js";import{d as o,f as s}from"./agent-scope-DAWJwFfl.js";import{t as c,v as l,x as u}from"./utils-CGdo13HV.js";import"./openclaw-root-CnsBf6ZU.js";import"./github-copilot-token-C79yeDKS.js";import{_ as d}from"./env-overrides-DHtB4kK3.js";import"./version-q3SkUw2K.js";import{n as f,r as p}from"./scan-paths-CWtvWW40.js";import"./registry-BptzrW8D.js";import"./skills-Bz_S4lPh.js";import{m}from"./frontmatter-C7mzDNxd.js";import"./plugins-DNlgeTTc.js";import"./logger-kQAOe3qp.js";import"./exec-B3eleY5O.js";import"./windows-spawn-7oINn5ao.js";import"./redact-CnRxK70G.js";import"./path-alias-guards-kY_ZbWs-.js";import"./errors-6SQWM9dj.js";import"./send-vNcod64S.js";import"./send-CyarIb2w.js";import"./compact-uyQDx8pN.js";import"./paths-BfjJY2VL.js";import"./chat-envelope-Bznn2SoS.js";import"./models-config-DZzS67GS.js";import"./tokens-DRM8vzJx.js";import"./with-timeout-c1CzdShT.js";import"./deliver-SqSusZP3.js";import"./diagnostic-D1H7_8QG.js";import"./send-Dj7NBAWg.js";import"./pi-model-discovery-BPkhPDMr.js";import"./exec-approvals-allowlist-CGjRWREs.js";import"./exec-safe-bin-runtime-policy-v44u39fl.js";import"./model-catalog-mt0IcDfR.js";import"./fetch-B4bz67_N.js";import"./audio-transcription-runner-BIKj1CBU.js";import"./fetch-guard-DaZmvp-L.js";import"./image-BVbOr9yV.js";import"./tool-display-DJDtttQg.js";import"./api-key-rotation-BpEL4aeX.js";import"./proxy-fetch-gWETR3cl.js";import"./ir-DdjufzKF.js";import"./render-DrrPmnMI.js";import"./target-errors-D6wejRd6.js";import"./commands-Dy7duWlt.js";import"./commands-registry-DT6FDUev.js";import"./session-cost-usage-CHtVgnE8.js";import"./session-utils-Bpdyx2A2.js";import"./sqlite-CILF3z9U.js";import"./call-BWx7hNtl.js";import"./pi-tools.policy-B6q8YOfg.js";import"./pairing-store-BaaVy1zB.js";import"./fetch-Dh-apy46.js";import"./skill-commands-DCqPy_Aa.js";import"./workspace-dirs-A8Vib9_B.js";import"./pairing-token-zdbQ951y.js";import"./channel-activity-BhiLsKvM.js";import"./tables-DENKrP-W.js";import"./kill-tree-D6nPx1_o.js";import"./runtime-web-tools-BYhCkBV8.js";import"./runtime-CK7gqwEF.js";import"./node-shell-BVZylVP6.js";import"./stagger-DxzgG2jd.js";import"./channel-selection-BPxE8JR7.js";import"./plugin-auto-enable-adba5Evb.js";import"./send-ChILboDj.js";import"./outbound-attachment-CVcDBkAD.js";import"./delivery-queue-nkPJu0fY.js";import"./send-COpehmAB.js";import"./system-run-command-DsWBVvSK.js";import"./fetch-Ce-scEU-.js";import"./command-secret-targets-BEjtBf5Z.js";import"./connection-auth-CjaeEu5D.js";import"./onboard-helpers-DOlI17Ac.js";import"./prompt-style-BThRSQJR.js";import"./pairing-labels-CZ-aX-up.js";import"./search-manager-CV2YsAym.js";import"./manager-CxZRoQkE.js";import"./memory-cli-C8fBBPgv.js";import{t as h}from"./links-CBnmRP9D.js";import"./cli-utils-BleB1eys.js";import"./help-format-B4aEI7V9.js";import"./progress-d1m2sqR1.js";import"./exec-approvals-BXO9Cezj.js";import{a as ee,c as g,l as te,n as _,u as v}from"./install-safe-path-C6kc_8NW.js";import{a as y,c as b,f as ne,i as re,l as ie,n as ae,o as x,r as oe,s as se,t as ce,u as le}from"./npm-pack-install-C0te3Oap.js";import{n as ue,t as de}from"./table-CR7TFMew.js";import{a as S,t as C}from"./workspace-xNEpaJvu.js";import{t as w}from"./hooks-status-BHt-Xvh4.js";import{i as T,n as E,r as fe,t as pe}from"./npm-resolution-CZUqHH_2.js";import D from"node:path";import O from"node:fs";import k from"node:fs/promises";async function me(e){let t=e.spec.trim(),n=d(t);return n?{ok:!1,error:n}:ce(await ae({tempDirPrefix:e.tempDirPrefix,spec:t,timeoutMs:e.timeoutMs,expectedIntegrity:e.expectedIntegrity,onIntegrityDrift:e.onIntegrityDrift,warn:e.warn,installFromArchive:e.installFromArchive,archiveInstallParams:e.archiveInstallParams}))}const A={};function j(e){return{hooksDir:e.hooksDir,timeoutMs:e.timeoutMs,logger:e.logger,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId}}function M(e){return e?e===`.`||e===`..`?`invalid hook name: reserved path segment`:e.includes(`/`)||e.includes(`\\`)?`invalid hook name: path separators not allowed`:null:`invalid hook name: missing`}function N(e,t){let n=t?l(t):D.join(c,`hooks`),r=M(e);if(r)throw Error(r);let i=_({baseDir:n,id:e,invalidNameMessage:`invalid hook name: path traversal detected`});if(!i.ok)throw Error(i.error);return i.path}async function P(e){let t=e[m]?.hooks;if(!Array.isArray(t))throw Error(`package.json missing openclaw.hooks`);let n=t.map(e=>typeof e==`string`?e.trim():``).filter(Boolean);if(n.length===0)throw Error(`package.json openclaw.hooks is empty`);return n}async function F(e,t){return await re({baseDir:t?l(t):D.join(c,`hooks`),id:e,invalidNameMessage:`invalid hook name: path traversal detected`,boundaryLabel:`hooks directory`})}async function I(e){let t=await F(e.id,e.hooksDir);if(!t.ok)return t;let n=t.targetDir,r=await oe({mode:e.mode,targetDir:n,alreadyExistsError:e.alreadyExistsError(n)});return r.ok?{ok:!0,targetDir:n}:r}async function L(e,t){return await g(D.join(e,`package.json`))?await he({packageDir:e,hooksDir:t.hooksDir,timeoutMs:t.timeoutMs,logger:t.logger,mode:t.mode,dryRun:t.dryRun,expectedHookPackId:t.expectedHookPackId}):await ge({hookDir:e,hooksDir:t.hooksDir,logger:t.logger,mode:t.mode,dryRun:t.dryRun,expectedHookPackId:t.expectedHookPackId})}async function R(e){let t=D.join(e,`HOOK.md`);if(!await g(t))throw Error(`HOOK.md missing in ${e}`);return S(await k.readFile(t,`utf-8`)).name||D.basename(e)}async function z(e){if(!await g(D.join(e,`HOOK.md`)))throw Error(`HOOK.md missing in ${e}`);if(!await Promise.all([`handler.ts`,`handler.js`,`index.ts`,`index.js`].map(async t=>g(D.join(e,t)))).then(e=>e.some(Boolean)))throw Error(`handler.ts/handler.js/index.ts/index.js missing in ${e}`)}async function he(e){let{logger:t,timeoutMs:n,mode:r,dryRun:i}=b(e,A),a=D.join(e.packageDir,`package.json`);if(!await g(a))return{ok:!1,error:`package.json missing`};let o;try{o=await te(a)}catch(e){return{ok:!1,error:`invalid package.json: ${String(e)}`}}let s;try{s=await P(o)}catch(e){return{ok:!1,error:String(e)}}let c=typeof o.name==`string`?o.name:``,l=c?ee(c):D.basename(e.packageDir),u=M(l);if(u)return{ok:!1,error:u};if(e.expectedHookPackId&&e.expectedHookPackId!==l)return{ok:!1,error:`hook pack id mismatch: expected ${e.expectedHookPackId}, got ${l}`};let d=await I({id:l,hooksDir:e.hooksDir,mode:r,alreadyExistsError:e=>`hook pack already exists: ${e} (delete it first)`});if(!d.ok)return d;let m=d.targetDir,h=[];for(let t of s){let n=D.resolve(e.packageDir,t);if(!f(e.packageDir,n))return{ok:!1,error:`openclaw.hooks entry escapes package directory: ${t}`};if(await z(n),!p(e.packageDir,n,{requireRealpath:!0}))return{ok:!1,error:`openclaw.hooks entry resolves outside package directory: ${t}`};let r=await R(n);h.push(r)}if(i)return{ok:!0,hookPackId:l,hooks:h,targetDir:m,version:typeof o.version==`string`?o.version:void 0};let _=await x({sourceDir:e.packageDir,targetDir:m,mode:r,timeoutMs:n,logger:t,copyErrorPrefix:`failed to copy hook pack`,depsLogMessage:`Installing hook pack dependencies…`,manifestDependencies:o.dependencies});return _.ok?{ok:!0,hookPackId:l,hooks:h,targetDir:m,version:typeof o.version==`string`?o.version:void 0}:_}async function ge(e){let{logger:t,mode:n,dryRun:r}=se(e,A);await z(e.hookDir);let i=await R(e.hookDir),a=M(i);if(a)return{ok:!1,error:a};if(e.expectedHookPackId&&e.expectedHookPackId!==i)return{ok:!1,error:`hook id mismatch: expected ${e.expectedHookPackId}, got ${i}`};let o=await I({id:i,hooksDir:e.hooksDir,mode:n,alreadyExistsError:e=>`hook already exists: ${e} (delete it first)`});if(!o.ok)return o;let s=o.targetDir;if(r)return{ok:!0,hookPackId:i,hooks:[i],targetDir:s};let c=await y({sourceDir:e.hookDir,targetDir:s,mode:n,timeoutMs:12e4,logger:t,copyErrorPrefix:`failed to copy hook`,hasDeps:!1,depsLogMessage:`Installing hook dependencies…`});return c.ok?{ok:!0,hookPackId:i,hooks:[i],targetDir:s}:c}async function B(e){let t=e.logger??A,n=e.timeoutMs??12e4,r=await ne(e.archivePath);if(!r.ok)return r;let i=r.path;return await le({archivePath:i,tempDirPrefix:`openclaw-hook-`,timeoutMs:n,logger:t,onExtracted:async r=>await L(r,j({hooksDir:e.hooksDir,timeoutMs:n,logger:t,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId}))})}async function V(e){let{logger:t,timeoutMs:n,mode:r,dryRun:i}=b(e,A),a=e.expectedHookPackId,o=e.spec;return t.info?.(`Downloading ${o.trim()}…`),await me({tempDirPrefix:`openclaw-hook-pack-`,spec:o,timeoutMs:n,expectedIntegrity:e.expectedIntegrity,onIntegrityDrift:e.onIntegrityDrift,warn:e=>{t.warn?.(e)},installFromArchive:B,archiveInstallParams:j({hooksDir:e.hooksDir,timeoutMs:n,logger:t,mode:r,dryRun:i,expectedHookPackId:a})})}async function H(e){let t=await ie(e.path);if(!t.ok)return t;let{resolvedPath:n,stat:r}=t,i=j({hooksDir:e.hooksDir,timeoutMs:e.timeoutMs,logger:e.logger,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId});return r.isDirectory()?await L(n,i):v(n)?await B({archivePath:n,...i}):{ok:!1,error:`unsupported hook file: ${n}`}}function U(e,t){let{hookId:n,...r}=t,i={...e.hooks?.internal?.installs,[n]:{...e.hooks?.internal?.installs?.[n],...r,installedAt:r.installedAt??new Date().toISOString()}};return{...e,hooks:{...e.hooks,internal:{...e.hooks?.internal,installs:{...i,[n]:i[n]}}}}}function _e(e,t){let n=new Map;for(let t of e)n.set(t.hook.name,t);for(let e of t)n.set(e.hook.name,e);return Array.from(n.values())}function W(e){let t=o(e,s(e)),n=C(t,{config:e});return w(t,{config:e,entries:_e(T({config:e,workspaceDir:t}).hooks.map(e=>e.entry),n)})}function G(e,t,n){let r=e.hooks.find(e=>e.name===t);if(!r)throw Error(`Hook "${t}" not found`);if(r.managedByPlugin)throw Error(`Hook "${t}" is managed by plugin "${r.pluginId??`unknown`}" and cannot be enabled/disabled.`);if(n?.requireEligible&&!r.eligible)throw Error(`Hook "${t}" is not eligible (missing requirements)`);return r}function K(e){let t={...e.config.hooks?.internal?.entries};t[e.hookName]={...t[e.hookName],enabled:e.enabled};let n={...e.config.hooks?.internal,...e.ensureHooksEnabled?{enabled:!0}:{},entries:t};return{...e.config,hooks:{...e.config.hooks,internal:n}}}function ve(t){return t.eligible?e.success(`✓ ready`):t.disabled?e.warn(`⏸ disabled`):e.error(`✗ missing`)}function ye(t){return`${t.emoji??`🔗`} ${e.command(t.name)}`}function be(e){return e.managedByPlugin?`plugin:${e.pluginId??`unknown`}`:e.source}function xe(e){let t=[];return e.missing.bins.length>0&&t.push(`bins: ${e.missing.bins.join(`, `)}`),e.missing.anyBins.length>0&&t.push(`anyBins: ${e.missing.anyBins.join(`, `)}`),e.missing.env.length>0&&t.push(`env: ${e.missing.env.join(`, `)}`),e.missing.config.length>0&&t.push(`config: ${e.missing.config.join(`, `)}`),e.missing.os.length>0&&t.push(`os: ${e.missing.os.join(`, `)}`),t.join(`; `)}function Se(n){t.error(`${e.error(`Error:`)} ${n instanceof Error?n.message:String(n)}`),process.exit(1)}async function q(e){try{await e()}catch(e){Se(e)}}function J(){return{info:e=>t.log(e),warn:n=>t.log(e.warn(n))}}function Y(){t.log(`Restart the gateway to load hooks.`)}function X(n,r){let i=r.resolution.resolvedSpec??r.spec;t.log(e.warn(`Integrity drift detected for "${n}" (${i})\nExpected: ${r.expectedIntegrity}\nActual: ${r.actualIntegrity}`))}async function Z(e){try{let t=await k.readFile(D.join(e,`package.json`),`utf-8`),n=JSON.parse(t);return typeof n.version==`string`?n.version:void 0}catch{return}}function Q(e,t){let n={...e.hooks?.internal?.entries};for(let e of t)n[e]={...n[e],enabled:!0};return{...e,hooks:{...e.hooks,internal:{...e.hooks?.internal,enabled:!0,entries:n}}}}function $(t,n){let r=n.eligible?t.hooks.filter(e=>e.eligible):t.hooks;if(n.json){let e={workspaceDir:t.workspaceDir,managedHooksDir:t.managedHooksDir,hooks:r.map(e=>({name:e.name,description:e.description,emoji:e.emoji,eligible:e.eligible,disabled:e.disabled,source:e.source,pluginId:e.pluginId,events:e.events,homepage:e.homepage,missing:e.missing,managedByPlugin:e.managedByPlugin}))};return JSON.stringify(e,null,2)}if(r.length===0)return n.eligible?`No eligible hooks found. Run \`${a(`openclaw hooks list`)}\` to see all hooks.`:`No hooks found.`;let i=r.filter(e=>e.eligible),o=de(),s=r.map(t=>{let n=xe(t);return{Status:ve(t),Hook:ye(t),Description:e.muted(t.description),Source:be(t),Missing:n?e.warn(n):``}}),c=[{key:`Status`,header:`Status`,minWidth:10},{key:`Hook`,header:`Hook`,minWidth:18,flex:!0},{key:`Description`,header:`Description`,minWidth:24,flex:!0},{key:`Source`,header:`Source`,minWidth:12,flex:!0}];n.verbose&&c.push({key:`Missing`,header:`Missing`,minWidth:18,flex:!0});let l=[];return l.push(`${e.heading(`Hooks`)} ${e.muted(`(${i.length}/${r.length} ready)`)}`),l.push(ue({width:o,columns:c,rows:s}).trimEnd()),l.join(`
2
2
  `)}function Ce(t,n,r){let i=t.hooks.find(e=>e.name===n||e.hookKey===n);if(!i)return r.json?JSON.stringify({error:`not found`,hook:n},null,2):`Hook "${n}" not found. Run \`${a(`openclaw hooks list`)}\` to see available hooks.`;if(r.json)return JSON.stringify(i,null,2);let o=[],s=i.emoji??`🔗`,c=i.eligible?e.success(`✓ Ready`):i.disabled?e.warn(`⏸ Disabled`):e.error(`✗ Missing requirements`);if(o.push(`${s} ${e.heading(i.name)} ${c}`),o.push(``),o.push(i.description),o.push(``),o.push(e.heading(`Details:`)),i.managedByPlugin?o.push(`${e.muted(` Source:`)} ${i.source} (${i.pluginId??`unknown`})`):o.push(`${e.muted(` Source:`)} ${i.source}`),o.push(`${e.muted(` Path:`)} ${u(i.filePath)}`),o.push(`${e.muted(` Handler:`)} ${u(i.handlerPath)}`),i.homepage&&o.push(`${e.muted(` Homepage:`)} ${i.homepage}`),i.events.length>0&&o.push(`${e.muted(` Events:`)} ${i.events.join(`, `)}`),i.managedByPlugin&&o.push(e.muted(` Managed by plugin; enable/disable via hooks CLI not available.`)),i.requirements.bins.length>0||i.requirements.anyBins.length>0||i.requirements.env.length>0||i.requirements.config.length>0||i.requirements.os.length>0){if(o.push(``),o.push(e.heading(`Requirements:`)),i.requirements.bins.length>0){let t=i.requirements.bins.map(t=>i.missing.bins.includes(t)?e.error(`✗ ${t}`):e.success(`✓ ${t}`));o.push(`${e.muted(` Binaries:`)} ${t.join(`, `)}`)}if(i.requirements.anyBins.length>0){let t=i.missing.anyBins.length>0?e.error(`✗ (any of: ${i.requirements.anyBins.join(`, `)})`):e.success(`✓ (any of: ${i.requirements.anyBins.join(`, `)})`);o.push(`${e.muted(` Any binary:`)} ${t}`)}if(i.requirements.env.length>0){let t=i.requirements.env.map(t=>i.missing.env.includes(t)?e.error(`✗ ${t}`):e.success(`✓ ${t}`));o.push(`${e.muted(` Environment:`)} ${t.join(`, `)}`)}if(i.requirements.config.length>0){let t=i.configChecks.map(t=>t.satisfied?e.success(`✓ ${t.path}`):e.error(`✗ ${t.path}`));o.push(`${e.muted(` Config:`)} ${t.join(`, `)}`)}if(i.requirements.os.length>0){let t=i.missing.os.length>0?e.error(`✗ (${i.requirements.os.join(`, `)})`):e.success(`✓ (${i.requirements.os.join(`, `)})`);o.push(`${e.muted(` OS:`)} ${t}`)}}return o.join(`
3
3
  `)}function we(t,n){if(n.json){let e=t.hooks.filter(e=>e.eligible),n=t.hooks.filter(e=>!e.eligible);return JSON.stringify({total:t.hooks.length,eligible:e.length,notEligible:n.length,hooks:{eligible:e.map(e=>e.name),notEligible:n.map(e=>({name:e.name,missing:e.missing}))}},null,2)}let r=t.hooks.filter(e=>e.eligible),i=t.hooks.filter(e=>!e.eligible),a=[];if(a.push(e.heading(`Hooks Status`)),a.push(``),a.push(`${e.muted(`Total hooks:`)} ${t.hooks.length}`),a.push(`${e.success(`Ready:`)} ${r.length}`),a.push(`${e.warn(`Not ready:`)} ${i.length}`),i.length>0){a.push(``),a.push(e.heading(`Hooks not ready:`));for(let e of i){let t=[];e.disabled&&t.push(`disabled`),e.missing.bins.length>0&&t.push(`bins: ${e.missing.bins.join(`, `)}`),e.missing.anyBins.length>0&&t.push(`anyBins: ${e.missing.anyBins.join(`, `)}`),e.missing.env.length>0&&t.push(`env: ${e.missing.env.join(`, `)}`),e.missing.config.length>0&&t.push(`config: ${e.missing.config.join(`, `)}`),e.missing.os.length>0&&t.push(`os: ${e.missing.os.join(`, `)}`),a.push(` ${e.emoji??`🔗`} ${e.name} - ${t.join(`; `)}`)}}return a.join(`
4
4
  `)}async function Te(i){let a=r(),o=G(W(a),i,{requireEligible:!0});await n(K({config:a,hookName:i,enabled:!0,ensureHooksEnabled:!0})),t.log(`${e.success(`✓`)} Enabled hook: ${o.emoji??`🔗`} ${e.command(i)}`)}async function Ee(i){let a=r(),o=G(W(a),i);await n(K({config:a,hookName:i,enabled:!1})),t.log(`${e.warn(`⏸`)} Disabled hook: ${o.emoji??`🔗`} ${e.command(i)}`)}function De(a){let o=a.command(`hooks`).description(`Manage internal agent hooks`).addHelpText(`after`,()=>`\n${e.muted(`Docs:`)} ${h(`/cli/hooks`,`docs.openclaw.ai/cli/hooks`)}\n`);o.command(`list`).description(`List all hooks`).option(`--eligible`,`Show only eligible hooks`,!1).option(`--json`,`Output as JSON`,!1).option(`-v, --verbose`,`Show more details including missing requirements`,!1).action(async e=>q(async()=>{let n=W(r());t.log($(n,e))})),o.command(`info <name>`).description(`Show detailed information about a hook`).option(`--json`,`Output as JSON`,!1).action(async(e,n)=>q(async()=>{let i=W(r());t.log(Ce(i,e,n))})),o.command(`check`).description(`Check hooks eligibility status`).option(`--json`,`Output as JSON`,!1).action(async e=>q(async()=>{let n=W(r());t.log(we(n,e))})),o.command(`enable <name>`).description(`Enable a hook`).action(async e=>q(async()=>{await Te(e)})),o.command(`disable <name>`).description(`Disable a hook`).action(async e=>q(async()=>{await Ee(e)})),o.command(`install`).description(`Install a hook pack (path, archive, or npm spec)`).argument(`<path-or-spec>`,`Path to a hook pack or npm package spec`).option(`-l, --link`,`Link a local path instead of copying`,!1).option(`--pin`,`Record npm installs as exact resolved <name>@<version>`,!1).action(async(i,a)=>{let o=l(i),s=r();if(O.existsSync(o)){if(a.link){O.statSync(o).isDirectory()||(t.error(`Linked hook paths must be directories.`),process.exit(1));let e=s.hooks?.internal?.load?.extraDirs??[],r=Array.from(new Set([...e,o])),i=await H({path:o,dryRun:!0});i.ok||(t.error(i.error),process.exit(1));let a={...s,hooks:{...s.hooks,internal:{...s.hooks?.internal,enabled:!0,load:{...s.hooks?.internal?.load,extraDirs:r}}}};a=Q(a,i.hooks),a=U(a,{hookId:i.hookPackId,source:`path`,sourcePath:o,installPath:o,version:i.version,hooks:i.hooks}),await n(a),t.log(`Linked hook path: ${u(o)}`),Y();return}let e=await H({path:o,logger:J()});e.ok||(t.error(e.error),process.exit(1));let r=Q(s,e.hooks),i=v(o)?`archive`:`path`;r=U(r,{hookId:e.hookPackId,source:i,sourcePath:o,installPath:e.targetDir,version:e.version,hooks:e.hooks}),await n(r),t.log(`Installed hooks: ${e.hooks.join(`, `)}`),Y();return}a.link&&(t.error("`--link` requires a local path."),process.exit(1)),fe(i,[`.zip`,`.tgz`,`.tar.gz`,`.tar`])&&(t.error(`Path not found: ${o}`),process.exit(1));let c=await V({spec:i,logger:J()});c.ok||(t.error(c.error),process.exit(1));let d=Q(s,c.hooks),f=E(i,!!a.pin,c.targetDir,c.version,c.npmResolution,t.log,e.warn);d=U(d,{hookId:c.hookPackId,...f,hooks:c.hooks}),await n(d),t.log(`Installed hooks: ${c.hooks.join(`, `)}`),Y()}),o.command(`update`).description(`Update installed hooks (npm installs only)`).argument(`[id]`,`Hook pack id (omit with --all)`).option(`--all`,`Update all tracked hooks`,!1).option(`--dry-run`,`Show what would change without writing`,!1).action(async(a,o)=>{let s=r(),c=s.hooks?.internal?.installs??{},l=o.all?Object.keys(c):a?[a]:[];l.length===0&&(t.error(`Provide a hook id or use --all.`),process.exit(1));let u=s,d=0;for(let n of l){let r=c[n];if(!r){t.log(e.warn(`No install record for "${n}".`));continue}if(r.source!==`npm`){t.log(e.warn(`Skipping "${n}" (source: ${r.source}).`));continue}if(!r.spec){t.log(e.warn(`Skipping "${n}" (missing npm spec).`));continue}let a;try{a=r.installPath??N(n)}catch(r){t.log(e.error(`Invalid install path for "${n}": ${String(r)}`));continue}let s=await Z(a);if(o.dryRun){let i=await V({spec:r.spec,mode:`update`,dryRun:!0,expectedHookPackId:n,expectedIntegrity:r.integrity,onIntegrityDrift:async e=>(X(n,e),!0),logger:J()});if(!i.ok){t.log(e.error(`Failed to check ${n}: ${i.error}`));continue}let a=i.version??`unknown`,o=s??`unknown`;s&&i.version&&s===i.version?t.log(`${n} is up to date (${o}).`):t.log(`Would update ${n}: ${o} → ${a}.`);continue}let l=await V({spec:r.spec,mode:`update`,expectedHookPackId:n,expectedIntegrity:r.integrity,onIntegrityDrift:async e=>(X(n,e),await i(`Continue updating "${n}" with this artifact?`)),logger:J()});if(!l.ok){t.log(e.error(`Failed to update ${n}: ${l.error}`));continue}let f=l.version??await Z(l.targetDir);u=U(u,{hookId:n,...pe({spec:r.spec,installPath:l.targetDir,version:f,resolution:l.npmResolution}),hooks:l.hooks}),d+=1;let p=s??`unknown`,m=f??`unknown`;s&&f&&s===f?t.log(`${n} already at ${p}.`):t.log(`Updated ${n}: ${p} → ${m}.`)}d>0&&(await n(u),Y())}),o.action(async()=>q(async()=>{let e=W(r());t.log($(e,{}))}))}export{De as registerHooksCli};
@@ -1,4 +1,4 @@
1
- import"./paths-B4IRk3wi.js";import{A as e,p as t}from"./subsystem-C5XF2Fy5.js";import{S as n,t as r,y as i}from"./utils-UGOV_184.js";import{Lo as a,nc as o,qs as s}from"./model-selection-BLbnMb5E.js";import"./reply-DwfVhea1.js";import{d as c,f as l}from"./agent-scope-DXZc3eNT.js";import"./openclaw-root-D_0Q6--h.js";import"./github-copilot-token-DGYAlOmV.js";import{t as u}from"./command-format-BbDT1tlm.js";import"./boolean-Ch3DfXPy.js";import"./env-D7wNuBx1.js";import{_ as d}from"./env-overrides-DXJbFrwI.js";import{n as f,r as p}from"./scan-paths-C13EseXp.js";import"./registry-hFAtCSWG.js";import"./skills-CzUpDbU-.js";import{m}from"./frontmatter-BkZkwkVO.js";import"./plugins-CYLrFT4h.js";import"./logger-Bl8URnrW.js";import"./exec-DHqLtFYt.js";import"./windows-spawn-AB7ItGAE.js";import"./redact-3_CiXMY6.js";import"./path-alias-guards-mvyLCPlN.js";import"./errors-Bunti32V.js";import"./send-C7rOdjPO.js";import"./send-BwblpWbK.js";import"./paths-yLEk_25I.js";import"./chat-envelope-HVpKusFc.js";import"./audio-transcription-runner-BwjMhAUa.js";import"./image-BP1cfEh1.js";import"./models-config-BlQ39qlq.js";import"./tool-display-DjuSUUbH.js";import"./fetch-guard-7BAwnP4a.js";import"./api-key-rotation-Rz2ESQSA.js";import"./local-roots-aA-4ohTq.js";import"./model-catalog-D-hkNWin.js";import"./proxy-fetch-BADsUK4d.js";import"./tokens-XGbQGn67.js";import"./deliver-DUNkj4hy.js";import"./commands-CGpM84iR.js";import"./commands-registry-DlvNUkXz.js";import"./pairing-store-EmfFQVcs.js";import"./fetch-Dikjvc5M.js";import"./call-JB-cGR9n.js";import"./with-timeout-WveKxvFV.js";import"./diagnostic-BEZszppF.js";import"./send-NbU9-scF2.js";import"./pi-model-discovery-DnJkNRc-.js";import"./exec-approvals-allowlist-B-Yf6RsU.js";import"./exec-safe-bin-runtime-policy-CRPHdPbF.js";import"./ir-CNTx85qV.js";import"./render-D8OWO2hT.js";import"./target-errors-CoEHv_2r.js";import"./read-only-account-inspect-B0cm8yrv.js";import"./channel-selection-si1OzWyQ.js";import"./plugin-auto-enable-CTgkkJK7.js";import"./send-DmHpf5Fz.js";import"./outbound-attachment-9-8VNvRG.js";import"./delivery-queue-CKbauSFq.js";import"./send-AQ3CJLpI.js";import"./channel-activity-Dw6F-ehJ.js";import"./tables-fl9iXahm.js";import"./fetch-Bn0mWg6a.js";import"./skill-commands-DlHVddAk.js";import"./workspace-dirs-BhF1Dzxt.js";import"./pairing-token-B8RdfK2y.js";import"./restart-BeJuoXCx.js";import"./runtime-web-tools-C4F6aaRh.js";import"./command-secret-targets-CfXtLkLF.js";import"./session-cost-usage-BgqKixv0.js";import"./connection-auth-smZlFWxD.js";import"./onboard-helpers-D90u4wVK.js";import"./prompt-style-CXKekIBY.js";import"./pairing-labels-PIuZfthz.js";import"./memory-cli-BouV_wyL.js";import"./query-expansion-0OxEb1Io.js";import"./manager-CI6O4QH6.js";import{t as h}from"./links-CySwdMcF.js";import"./cli-utils-BY7dLMFy.js";import"./help-format-BRbF_INg.js";import"./progress-LNttnI-y.js";import"./exec-approvals-BpBNEy6i.js";import"./nodes-screen-8nRBsfID.js";import"./system-run-command-E8ymBXHh.js";import"./runtime-DYttInEE.js";import"./stagger-DmFYysrJ.js";import{a as ee,c as g,l as te,n as _,u as v}from"./install-safe-path-iesxijn2.js";import{a as y,c as b,f as ne,i as re,l as ie,n as ae,o as x,r as oe,s as se,t as ce,u as le}from"./npm-pack-install-B23L-AtF.js";import{n as ue,t as de}from"./table-CY440fI1.js";import{a as S,t as C}from"./workspace-C45T1Cxg.js";import{t as w}from"./hooks-status-CRJ4J0ZW.js";import{i as T,n as E,r as fe,t as pe}from"./npm-resolution-CBlwQq3a.js";import D from"node:fs";import O from"node:path";import k from"node:fs/promises";async function me(e){let t=e.spec.trim(),n=d(t);return n?{ok:!1,error:n}:ce(await ae({tempDirPrefix:e.tempDirPrefix,spec:t,timeoutMs:e.timeoutMs,expectedIntegrity:e.expectedIntegrity,onIntegrityDrift:e.onIntegrityDrift,warn:e.warn,installFromArchive:e.installFromArchive,archiveInstallParams:e.archiveInstallParams}))}const A={};function j(e){return{hooksDir:e.hooksDir,timeoutMs:e.timeoutMs,logger:e.logger,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId}}function M(e){return e?e===`.`||e===`..`?`invalid hook name: reserved path segment`:e.includes(`/`)||e.includes(`\\`)?`invalid hook name: path separators not allowed`:null:`invalid hook name: missing`}function N(e,t){let n=t?i(t):O.join(r,`hooks`),a=M(e);if(a)throw Error(a);let o=_({baseDir:n,id:e,invalidNameMessage:`invalid hook name: path traversal detected`});if(!o.ok)throw Error(o.error);return o.path}async function P(e){let t=e[m]?.hooks;if(!Array.isArray(t))throw Error(`package.json missing openclaw.hooks`);let n=t.map(e=>typeof e==`string`?e.trim():``).filter(Boolean);if(n.length===0)throw Error(`package.json openclaw.hooks is empty`);return n}async function F(e,t){return await re({baseDir:t?i(t):O.join(r,`hooks`),id:e,invalidNameMessage:`invalid hook name: path traversal detected`,boundaryLabel:`hooks directory`})}async function I(e){let t=await F(e.id,e.hooksDir);if(!t.ok)return t;let n=t.targetDir,r=await oe({mode:e.mode,targetDir:n,alreadyExistsError:e.alreadyExistsError(n)});return r.ok?{ok:!0,targetDir:n}:r}async function L(e,t){return await g(O.join(e,`package.json`))?await he({packageDir:e,hooksDir:t.hooksDir,timeoutMs:t.timeoutMs,logger:t.logger,mode:t.mode,dryRun:t.dryRun,expectedHookPackId:t.expectedHookPackId}):await ge({hookDir:e,hooksDir:t.hooksDir,logger:t.logger,mode:t.mode,dryRun:t.dryRun,expectedHookPackId:t.expectedHookPackId})}async function R(e){let t=O.join(e,`HOOK.md`);if(!await g(t))throw Error(`HOOK.md missing in ${e}`);return S(await k.readFile(t,`utf-8`)).name||O.basename(e)}async function z(e){if(!await g(O.join(e,`HOOK.md`)))throw Error(`HOOK.md missing in ${e}`);if(!await Promise.all([`handler.ts`,`handler.js`,`index.ts`,`index.js`].map(async t=>g(O.join(e,t)))).then(e=>e.some(Boolean)))throw Error(`handler.ts/handler.js/index.ts/index.js missing in ${e}`)}async function he(e){let{logger:t,timeoutMs:n,mode:r,dryRun:i}=b(e,A),a=O.join(e.packageDir,`package.json`);if(!await g(a))return{ok:!1,error:`package.json missing`};let o;try{o=await te(a)}catch(e){return{ok:!1,error:`invalid package.json: ${String(e)}`}}let s;try{s=await P(o)}catch(e){return{ok:!1,error:String(e)}}let c=typeof o.name==`string`?o.name:``,l=c?ee(c):O.basename(e.packageDir),u=M(l);if(u)return{ok:!1,error:u};if(e.expectedHookPackId&&e.expectedHookPackId!==l)return{ok:!1,error:`hook pack id mismatch: expected ${e.expectedHookPackId}, got ${l}`};let d=await I({id:l,hooksDir:e.hooksDir,mode:r,alreadyExistsError:e=>`hook pack already exists: ${e} (delete it first)`});if(!d.ok)return d;let m=d.targetDir,h=[];for(let t of s){let n=O.resolve(e.packageDir,t);if(!f(e.packageDir,n))return{ok:!1,error:`openclaw.hooks entry escapes package directory: ${t}`};if(await z(n),!p(e.packageDir,n,{requireRealpath:!0}))return{ok:!1,error:`openclaw.hooks entry resolves outside package directory: ${t}`};let r=await R(n);h.push(r)}if(i)return{ok:!0,hookPackId:l,hooks:h,targetDir:m,version:typeof o.version==`string`?o.version:void 0};let _=await x({sourceDir:e.packageDir,targetDir:m,mode:r,timeoutMs:n,logger:t,copyErrorPrefix:`failed to copy hook pack`,depsLogMessage:`Installing hook pack dependencies…`,manifestDependencies:o.dependencies});return _.ok?{ok:!0,hookPackId:l,hooks:h,targetDir:m,version:typeof o.version==`string`?o.version:void 0}:_}async function ge(e){let{logger:t,mode:n,dryRun:r}=se(e,A);await z(e.hookDir);let i=await R(e.hookDir),a=M(i);if(a)return{ok:!1,error:a};if(e.expectedHookPackId&&e.expectedHookPackId!==i)return{ok:!1,error:`hook id mismatch: expected ${e.expectedHookPackId}, got ${i}`};let o=await I({id:i,hooksDir:e.hooksDir,mode:n,alreadyExistsError:e=>`hook already exists: ${e} (delete it first)`});if(!o.ok)return o;let s=o.targetDir;if(r)return{ok:!0,hookPackId:i,hooks:[i],targetDir:s};let c=await y({sourceDir:e.hookDir,targetDir:s,mode:n,timeoutMs:12e4,logger:t,copyErrorPrefix:`failed to copy hook`,hasDeps:!1,depsLogMessage:`Installing hook dependencies…`});return c.ok?{ok:!0,hookPackId:i,hooks:[i],targetDir:s}:c}async function B(e){let t=e.logger??A,n=e.timeoutMs??12e4,r=await ne(e.archivePath);if(!r.ok)return r;let i=r.path;return await le({archivePath:i,tempDirPrefix:`openclaw-hook-`,timeoutMs:n,logger:t,onExtracted:async r=>await L(r,j({hooksDir:e.hooksDir,timeoutMs:n,logger:t,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId}))})}async function V(e){let{logger:t,timeoutMs:n,mode:r,dryRun:i}=b(e,A),a=e.expectedHookPackId,o=e.spec;return t.info?.(`Downloading ${o.trim()}…`),await me({tempDirPrefix:`openclaw-hook-pack-`,spec:o,timeoutMs:n,expectedIntegrity:e.expectedIntegrity,onIntegrityDrift:e.onIntegrityDrift,warn:e=>{t.warn?.(e)},installFromArchive:B,archiveInstallParams:j({hooksDir:e.hooksDir,timeoutMs:n,logger:t,mode:r,dryRun:i,expectedHookPackId:a})})}async function H(e){let t=await ie(e.path);if(!t.ok)return t;let{resolvedPath:n,stat:r}=t,i=j({hooksDir:e.hooksDir,timeoutMs:e.timeoutMs,logger:e.logger,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId});return r.isDirectory()?await L(n,i):v(n)?await B({archivePath:n,...i}):{ok:!1,error:`unsupported hook file: ${n}`}}function U(e,t){let{hookId:n,...r}=t,i={...e.hooks?.internal?.installs,[n]:{...e.hooks?.internal?.installs?.[n],...r,installedAt:r.installedAt??new Date().toISOString()}};return{...e,hooks:{...e.hooks,internal:{...e.hooks?.internal,installs:{...i,[n]:i[n]}}}}}function _e(e,t){let n=new Map;for(let t of e)n.set(t.hook.name,t);for(let e of t)n.set(e.hook.name,e);return Array.from(n.values())}function W(e){let t=c(e,l(e)),n=C(t,{config:e});return w(t,{config:e,entries:_e(T({config:e,workspaceDir:t}).hooks.map(e=>e.entry),n)})}function G(e,t,n){let r=e.hooks.find(e=>e.name===t);if(!r)throw Error(`Hook "${t}" not found`);if(r.managedByPlugin)throw Error(`Hook "${t}" is managed by plugin "${r.pluginId??`unknown`}" and cannot be enabled/disabled.`);if(n?.requireEligible&&!r.eligible)throw Error(`Hook "${t}" is not eligible (missing requirements)`);return r}function K(e){let t={...e.config.hooks?.internal?.entries};t[e.hookName]={...t[e.hookName],enabled:e.enabled};let n={...e.config.hooks?.internal,...e.ensureHooksEnabled?{enabled:!0}:{},entries:t};return{...e.config,hooks:{...e.config.hooks,internal:n}}}function ve(t){return t.eligible?e.success(`✓ ready`):t.disabled?e.warn(`⏸ disabled`):e.error(`✗ missing`)}function ye(t){return`${t.emoji??`🔗`} ${e.command(t.name)}`}function be(e){return e.managedByPlugin?`plugin:${e.pluginId??`unknown`}`:e.source}function xe(e){let t=[];return e.missing.bins.length>0&&t.push(`bins: ${e.missing.bins.join(`, `)}`),e.missing.anyBins.length>0&&t.push(`anyBins: ${e.missing.anyBins.join(`, `)}`),e.missing.env.length>0&&t.push(`env: ${e.missing.env.join(`, `)}`),e.missing.config.length>0&&t.push(`config: ${e.missing.config.join(`, `)}`),e.missing.os.length>0&&t.push(`os: ${e.missing.os.join(`, `)}`),t.join(`; `)}function Se(n){t.error(`${e.error(`Error:`)} ${n instanceof Error?n.message:String(n)}`),process.exit(1)}async function q(e){try{await e()}catch(e){Se(e)}}function J(){return{info:e=>t.log(e),warn:n=>t.log(e.warn(n))}}function Y(){t.log(`Restart the gateway to load hooks.`)}function X(n,r){let i=r.resolution.resolvedSpec??r.spec;t.log(e.warn(`Integrity drift detected for "${n}" (${i})\nExpected: ${r.expectedIntegrity}\nActual: ${r.actualIntegrity}`))}async function Z(e){try{let t=await k.readFile(O.join(e,`package.json`),`utf-8`),n=JSON.parse(t);return typeof n.version==`string`?n.version:void 0}catch{return}}function Q(e,t){let n={...e.hooks?.internal?.entries};for(let e of t)n[e]={...n[e],enabled:!0};return{...e,hooks:{...e.hooks,internal:{...e.hooks?.internal,enabled:!0,entries:n}}}}function $(t,n){let r=n.eligible?t.hooks.filter(e=>e.eligible):t.hooks;if(n.json){let e={workspaceDir:t.workspaceDir,managedHooksDir:t.managedHooksDir,hooks:r.map(e=>({name:e.name,description:e.description,emoji:e.emoji,eligible:e.eligible,disabled:e.disabled,source:e.source,pluginId:e.pluginId,events:e.events,homepage:e.homepage,missing:e.missing,managedByPlugin:e.managedByPlugin}))};return JSON.stringify(e,null,2)}if(r.length===0)return n.eligible?`No eligible hooks found. Run \`${u(`openclaw hooks list`)}\` to see all hooks.`:`No hooks found.`;let i=r.filter(e=>e.eligible),a=de(),o=r.map(t=>{let n=xe(t);return{Status:ve(t),Hook:ye(t),Description:e.muted(t.description),Source:be(t),Missing:n?e.warn(n):``}}),s=[{key:`Status`,header:`Status`,minWidth:10},{key:`Hook`,header:`Hook`,minWidth:18,flex:!0},{key:`Description`,header:`Description`,minWidth:24,flex:!0},{key:`Source`,header:`Source`,minWidth:12,flex:!0}];n.verbose&&s.push({key:`Missing`,header:`Missing`,minWidth:18,flex:!0});let c=[];return c.push(`${e.heading(`Hooks`)} ${e.muted(`(${i.length}/${r.length} ready)`)}`),c.push(ue({width:a,columns:s,rows:o}).trimEnd()),c.join(`
1
+ import"./paths-B4IRk3wi.js";import{A as e,p as t}from"./subsystem-C5XF2Fy5.js";import{S as n,t as r,y as i}from"./utils-UGOV_184.js";import{Lo as a,nc as o,qs as s}from"./model-selection-BLbnMb5E.js";import"./reply-mWIMy_ju.js";import{d as c,f as l}from"./agent-scope-DXZc3eNT.js";import"./openclaw-root-D_0Q6--h.js";import"./github-copilot-token-DGYAlOmV.js";import{t as u}from"./command-format-BbDT1tlm.js";import"./boolean-Ch3DfXPy.js";import"./env-D7wNuBx1.js";import{_ as d}from"./env-overrides-DXJbFrwI.js";import{n as f,r as p}from"./scan-paths-C13EseXp.js";import"./registry-hFAtCSWG.js";import"./skills-CzUpDbU-.js";import{m}from"./frontmatter-BkZkwkVO.js";import"./plugins-CYLrFT4h.js";import"./logger-Bl8URnrW.js";import"./exec-DHqLtFYt.js";import"./windows-spawn-AB7ItGAE.js";import"./redact-3_CiXMY6.js";import"./path-alias-guards-mvyLCPlN.js";import"./errors-Bunti32V.js";import"./send-C7rOdjPO.js";import"./send-BwblpWbK.js";import"./paths-yLEk_25I.js";import"./chat-envelope-HVpKusFc.js";import"./audio-transcription-runner-BwjMhAUa.js";import"./image-BP1cfEh1.js";import"./models-config-BlQ39qlq.js";import"./tool-display-DjuSUUbH.js";import"./fetch-guard-7BAwnP4a.js";import"./api-key-rotation-Rz2ESQSA.js";import"./local-roots-aA-4ohTq.js";import"./model-catalog-D-hkNWin.js";import"./proxy-fetch-BADsUK4d.js";import"./tokens-XGbQGn67.js";import"./deliver-DUNkj4hy.js";import"./commands-CGpM84iR.js";import"./commands-registry-DlvNUkXz.js";import"./pairing-store-EmfFQVcs.js";import"./fetch-Dikjvc5M.js";import"./call-JB-cGR9n.js";import"./with-timeout-WveKxvFV.js";import"./diagnostic-BEZszppF.js";import"./send-NbU9-scF2.js";import"./pi-model-discovery-DnJkNRc-.js";import"./exec-approvals-allowlist-B-Yf6RsU.js";import"./exec-safe-bin-runtime-policy-CRPHdPbF.js";import"./ir-CNTx85qV.js";import"./render-D8OWO2hT.js";import"./target-errors-CoEHv_2r.js";import"./read-only-account-inspect-B0cm8yrv.js";import"./channel-selection-si1OzWyQ.js";import"./plugin-auto-enable-CTgkkJK7.js";import"./send-DmHpf5Fz.js";import"./outbound-attachment-9-8VNvRG.js";import"./delivery-queue-CKbauSFq.js";import"./send-AQ3CJLpI.js";import"./channel-activity-Dw6F-ehJ.js";import"./tables-fl9iXahm.js";import"./fetch-Bn0mWg6a.js";import"./skill-commands-DlHVddAk.js";import"./workspace-dirs-BhF1Dzxt.js";import"./pairing-token-B8RdfK2y.js";import"./restart-BeJuoXCx.js";import"./runtime-web-tools-C4F6aaRh.js";import"./command-secret-targets-CfXtLkLF.js";import"./session-cost-usage-BgqKixv0.js";import"./connection-auth-smZlFWxD.js";import"./onboard-helpers-D90u4wVK.js";import"./prompt-style-CXKekIBY.js";import"./pairing-labels-PIuZfthz.js";import"./memory-cli-BouV_wyL.js";import"./query-expansion-0OxEb1Io.js";import"./manager-CI6O4QH6.js";import{t as h}from"./links-CySwdMcF.js";import"./cli-utils-BY7dLMFy.js";import"./help-format-BRbF_INg.js";import"./progress-LNttnI-y.js";import"./exec-approvals-BpBNEy6i.js";import"./nodes-screen-8nRBsfID.js";import"./system-run-command-E8ymBXHh.js";import"./runtime-DYttInEE.js";import"./stagger-DmFYysrJ.js";import{a as ee,c as g,l as te,n as _,u as v}from"./install-safe-path-iesxijn2.js";import{a as y,c as b,f as ne,i as re,l as ie,n as ae,o as x,r as oe,s as se,t as ce,u as le}from"./npm-pack-install-B23L-AtF.js";import{n as ue,t as de}from"./table-CY440fI1.js";import{a as S,t as C}from"./workspace-C45T1Cxg.js";import{t as w}from"./hooks-status-CRJ4J0ZW.js";import{i as T,n as E,r as fe,t as pe}from"./npm-resolution-BzXV2s2P.js";import D from"node:fs";import O from"node:path";import k from"node:fs/promises";async function me(e){let t=e.spec.trim(),n=d(t);return n?{ok:!1,error:n}:ce(await ae({tempDirPrefix:e.tempDirPrefix,spec:t,timeoutMs:e.timeoutMs,expectedIntegrity:e.expectedIntegrity,onIntegrityDrift:e.onIntegrityDrift,warn:e.warn,installFromArchive:e.installFromArchive,archiveInstallParams:e.archiveInstallParams}))}const A={};function j(e){return{hooksDir:e.hooksDir,timeoutMs:e.timeoutMs,logger:e.logger,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId}}function M(e){return e?e===`.`||e===`..`?`invalid hook name: reserved path segment`:e.includes(`/`)||e.includes(`\\`)?`invalid hook name: path separators not allowed`:null:`invalid hook name: missing`}function N(e,t){let n=t?i(t):O.join(r,`hooks`),a=M(e);if(a)throw Error(a);let o=_({baseDir:n,id:e,invalidNameMessage:`invalid hook name: path traversal detected`});if(!o.ok)throw Error(o.error);return o.path}async function P(e){let t=e[m]?.hooks;if(!Array.isArray(t))throw Error(`package.json missing openclaw.hooks`);let n=t.map(e=>typeof e==`string`?e.trim():``).filter(Boolean);if(n.length===0)throw Error(`package.json openclaw.hooks is empty`);return n}async function F(e,t){return await re({baseDir:t?i(t):O.join(r,`hooks`),id:e,invalidNameMessage:`invalid hook name: path traversal detected`,boundaryLabel:`hooks directory`})}async function I(e){let t=await F(e.id,e.hooksDir);if(!t.ok)return t;let n=t.targetDir,r=await oe({mode:e.mode,targetDir:n,alreadyExistsError:e.alreadyExistsError(n)});return r.ok?{ok:!0,targetDir:n}:r}async function L(e,t){return await g(O.join(e,`package.json`))?await he({packageDir:e,hooksDir:t.hooksDir,timeoutMs:t.timeoutMs,logger:t.logger,mode:t.mode,dryRun:t.dryRun,expectedHookPackId:t.expectedHookPackId}):await ge({hookDir:e,hooksDir:t.hooksDir,logger:t.logger,mode:t.mode,dryRun:t.dryRun,expectedHookPackId:t.expectedHookPackId})}async function R(e){let t=O.join(e,`HOOK.md`);if(!await g(t))throw Error(`HOOK.md missing in ${e}`);return S(await k.readFile(t,`utf-8`)).name||O.basename(e)}async function z(e){if(!await g(O.join(e,`HOOK.md`)))throw Error(`HOOK.md missing in ${e}`);if(!await Promise.all([`handler.ts`,`handler.js`,`index.ts`,`index.js`].map(async t=>g(O.join(e,t)))).then(e=>e.some(Boolean)))throw Error(`handler.ts/handler.js/index.ts/index.js missing in ${e}`)}async function he(e){let{logger:t,timeoutMs:n,mode:r,dryRun:i}=b(e,A),a=O.join(e.packageDir,`package.json`);if(!await g(a))return{ok:!1,error:`package.json missing`};let o;try{o=await te(a)}catch(e){return{ok:!1,error:`invalid package.json: ${String(e)}`}}let s;try{s=await P(o)}catch(e){return{ok:!1,error:String(e)}}let c=typeof o.name==`string`?o.name:``,l=c?ee(c):O.basename(e.packageDir),u=M(l);if(u)return{ok:!1,error:u};if(e.expectedHookPackId&&e.expectedHookPackId!==l)return{ok:!1,error:`hook pack id mismatch: expected ${e.expectedHookPackId}, got ${l}`};let d=await I({id:l,hooksDir:e.hooksDir,mode:r,alreadyExistsError:e=>`hook pack already exists: ${e} (delete it first)`});if(!d.ok)return d;let m=d.targetDir,h=[];for(let t of s){let n=O.resolve(e.packageDir,t);if(!f(e.packageDir,n))return{ok:!1,error:`openclaw.hooks entry escapes package directory: ${t}`};if(await z(n),!p(e.packageDir,n,{requireRealpath:!0}))return{ok:!1,error:`openclaw.hooks entry resolves outside package directory: ${t}`};let r=await R(n);h.push(r)}if(i)return{ok:!0,hookPackId:l,hooks:h,targetDir:m,version:typeof o.version==`string`?o.version:void 0};let _=await x({sourceDir:e.packageDir,targetDir:m,mode:r,timeoutMs:n,logger:t,copyErrorPrefix:`failed to copy hook pack`,depsLogMessage:`Installing hook pack dependencies…`,manifestDependencies:o.dependencies});return _.ok?{ok:!0,hookPackId:l,hooks:h,targetDir:m,version:typeof o.version==`string`?o.version:void 0}:_}async function ge(e){let{logger:t,mode:n,dryRun:r}=se(e,A);await z(e.hookDir);let i=await R(e.hookDir),a=M(i);if(a)return{ok:!1,error:a};if(e.expectedHookPackId&&e.expectedHookPackId!==i)return{ok:!1,error:`hook id mismatch: expected ${e.expectedHookPackId}, got ${i}`};let o=await I({id:i,hooksDir:e.hooksDir,mode:n,alreadyExistsError:e=>`hook already exists: ${e} (delete it first)`});if(!o.ok)return o;let s=o.targetDir;if(r)return{ok:!0,hookPackId:i,hooks:[i],targetDir:s};let c=await y({sourceDir:e.hookDir,targetDir:s,mode:n,timeoutMs:12e4,logger:t,copyErrorPrefix:`failed to copy hook`,hasDeps:!1,depsLogMessage:`Installing hook dependencies…`});return c.ok?{ok:!0,hookPackId:i,hooks:[i],targetDir:s}:c}async function B(e){let t=e.logger??A,n=e.timeoutMs??12e4,r=await ne(e.archivePath);if(!r.ok)return r;let i=r.path;return await le({archivePath:i,tempDirPrefix:`openclaw-hook-`,timeoutMs:n,logger:t,onExtracted:async r=>await L(r,j({hooksDir:e.hooksDir,timeoutMs:n,logger:t,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId}))})}async function V(e){let{logger:t,timeoutMs:n,mode:r,dryRun:i}=b(e,A),a=e.expectedHookPackId,o=e.spec;return t.info?.(`Downloading ${o.trim()}…`),await me({tempDirPrefix:`openclaw-hook-pack-`,spec:o,timeoutMs:n,expectedIntegrity:e.expectedIntegrity,onIntegrityDrift:e.onIntegrityDrift,warn:e=>{t.warn?.(e)},installFromArchive:B,archiveInstallParams:j({hooksDir:e.hooksDir,timeoutMs:n,logger:t,mode:r,dryRun:i,expectedHookPackId:a})})}async function H(e){let t=await ie(e.path);if(!t.ok)return t;let{resolvedPath:n,stat:r}=t,i=j({hooksDir:e.hooksDir,timeoutMs:e.timeoutMs,logger:e.logger,mode:e.mode,dryRun:e.dryRun,expectedHookPackId:e.expectedHookPackId});return r.isDirectory()?await L(n,i):v(n)?await B({archivePath:n,...i}):{ok:!1,error:`unsupported hook file: ${n}`}}function U(e,t){let{hookId:n,...r}=t,i={...e.hooks?.internal?.installs,[n]:{...e.hooks?.internal?.installs?.[n],...r,installedAt:r.installedAt??new Date().toISOString()}};return{...e,hooks:{...e.hooks,internal:{...e.hooks?.internal,installs:{...i,[n]:i[n]}}}}}function _e(e,t){let n=new Map;for(let t of e)n.set(t.hook.name,t);for(let e of t)n.set(e.hook.name,e);return Array.from(n.values())}function W(e){let t=c(e,l(e)),n=C(t,{config:e});return w(t,{config:e,entries:_e(T({config:e,workspaceDir:t}).hooks.map(e=>e.entry),n)})}function G(e,t,n){let r=e.hooks.find(e=>e.name===t);if(!r)throw Error(`Hook "${t}" not found`);if(r.managedByPlugin)throw Error(`Hook "${t}" is managed by plugin "${r.pluginId??`unknown`}" and cannot be enabled/disabled.`);if(n?.requireEligible&&!r.eligible)throw Error(`Hook "${t}" is not eligible (missing requirements)`);return r}function K(e){let t={...e.config.hooks?.internal?.entries};t[e.hookName]={...t[e.hookName],enabled:e.enabled};let n={...e.config.hooks?.internal,...e.ensureHooksEnabled?{enabled:!0}:{},entries:t};return{...e.config,hooks:{...e.config.hooks,internal:n}}}function ve(t){return t.eligible?e.success(`✓ ready`):t.disabled?e.warn(`⏸ disabled`):e.error(`✗ missing`)}function ye(t){return`${t.emoji??`🔗`} ${e.command(t.name)}`}function be(e){return e.managedByPlugin?`plugin:${e.pluginId??`unknown`}`:e.source}function xe(e){let t=[];return e.missing.bins.length>0&&t.push(`bins: ${e.missing.bins.join(`, `)}`),e.missing.anyBins.length>0&&t.push(`anyBins: ${e.missing.anyBins.join(`, `)}`),e.missing.env.length>0&&t.push(`env: ${e.missing.env.join(`, `)}`),e.missing.config.length>0&&t.push(`config: ${e.missing.config.join(`, `)}`),e.missing.os.length>0&&t.push(`os: ${e.missing.os.join(`, `)}`),t.join(`; `)}function Se(n){t.error(`${e.error(`Error:`)} ${n instanceof Error?n.message:String(n)}`),process.exit(1)}async function q(e){try{await e()}catch(e){Se(e)}}function J(){return{info:e=>t.log(e),warn:n=>t.log(e.warn(n))}}function Y(){t.log(`Restart the gateway to load hooks.`)}function X(n,r){let i=r.resolution.resolvedSpec??r.spec;t.log(e.warn(`Integrity drift detected for "${n}" (${i})\nExpected: ${r.expectedIntegrity}\nActual: ${r.actualIntegrity}`))}async function Z(e){try{let t=await k.readFile(O.join(e,`package.json`),`utf-8`),n=JSON.parse(t);return typeof n.version==`string`?n.version:void 0}catch{return}}function Q(e,t){let n={...e.hooks?.internal?.entries};for(let e of t)n[e]={...n[e],enabled:!0};return{...e,hooks:{...e.hooks,internal:{...e.hooks?.internal,enabled:!0,entries:n}}}}function $(t,n){let r=n.eligible?t.hooks.filter(e=>e.eligible):t.hooks;if(n.json){let e={workspaceDir:t.workspaceDir,managedHooksDir:t.managedHooksDir,hooks:r.map(e=>({name:e.name,description:e.description,emoji:e.emoji,eligible:e.eligible,disabled:e.disabled,source:e.source,pluginId:e.pluginId,events:e.events,homepage:e.homepage,missing:e.missing,managedByPlugin:e.managedByPlugin}))};return JSON.stringify(e,null,2)}if(r.length===0)return n.eligible?`No eligible hooks found. Run \`${u(`openclaw hooks list`)}\` to see all hooks.`:`No hooks found.`;let i=r.filter(e=>e.eligible),a=de(),o=r.map(t=>{let n=xe(t);return{Status:ve(t),Hook:ye(t),Description:e.muted(t.description),Source:be(t),Missing:n?e.warn(n):``}}),s=[{key:`Status`,header:`Status`,minWidth:10},{key:`Hook`,header:`Hook`,minWidth:18,flex:!0},{key:`Description`,header:`Description`,minWidth:24,flex:!0},{key:`Source`,header:`Source`,minWidth:12,flex:!0}];n.verbose&&s.push({key:`Missing`,header:`Missing`,minWidth:18,flex:!0});let c=[];return c.push(`${e.heading(`Hooks`)} ${e.muted(`(${i.length}/${r.length} ready)`)}`),c.push(ue({width:a,columns:s,rows:o}).trimEnd()),c.join(`
2
2
  `)}function Ce(t,r,i){let a=t.hooks.find(e=>e.name===r||e.hookKey===r);if(!a)return i.json?JSON.stringify({error:`not found`,hook:r},null,2):`Hook "${r}" not found. Run \`${u(`openclaw hooks list`)}\` to see available hooks.`;if(i.json)return JSON.stringify(a,null,2);let o=[],s=a.emoji??`🔗`,c=a.eligible?e.success(`✓ Ready`):a.disabled?e.warn(`⏸ Disabled`):e.error(`✗ Missing requirements`);if(o.push(`${s} ${e.heading(a.name)} ${c}`),o.push(``),o.push(a.description),o.push(``),o.push(e.heading(`Details:`)),a.managedByPlugin?o.push(`${e.muted(` Source:`)} ${a.source} (${a.pluginId??`unknown`})`):o.push(`${e.muted(` Source:`)} ${a.source}`),o.push(`${e.muted(` Path:`)} ${n(a.filePath)}`),o.push(`${e.muted(` Handler:`)} ${n(a.handlerPath)}`),a.homepage&&o.push(`${e.muted(` Homepage:`)} ${a.homepage}`),a.events.length>0&&o.push(`${e.muted(` Events:`)} ${a.events.join(`, `)}`),a.managedByPlugin&&o.push(e.muted(` Managed by plugin; enable/disable via hooks CLI not available.`)),a.requirements.bins.length>0||a.requirements.anyBins.length>0||a.requirements.env.length>0||a.requirements.config.length>0||a.requirements.os.length>0){if(o.push(``),o.push(e.heading(`Requirements:`)),a.requirements.bins.length>0){let t=a.requirements.bins.map(t=>a.missing.bins.includes(t)?e.error(`✗ ${t}`):e.success(`✓ ${t}`));o.push(`${e.muted(` Binaries:`)} ${t.join(`, `)}`)}if(a.requirements.anyBins.length>0){let t=a.missing.anyBins.length>0?e.error(`✗ (any of: ${a.requirements.anyBins.join(`, `)})`):e.success(`✓ (any of: ${a.requirements.anyBins.join(`, `)})`);o.push(`${e.muted(` Any binary:`)} ${t}`)}if(a.requirements.env.length>0){let t=a.requirements.env.map(t=>a.missing.env.includes(t)?e.error(`✗ ${t}`):e.success(`✓ ${t}`));o.push(`${e.muted(` Environment:`)} ${t.join(`, `)}`)}if(a.requirements.config.length>0){let t=a.configChecks.map(t=>t.satisfied?e.success(`✓ ${t.path}`):e.error(`✗ ${t.path}`));o.push(`${e.muted(` Config:`)} ${t.join(`, `)}`)}if(a.requirements.os.length>0){let t=a.missing.os.length>0?e.error(`✗ (${a.requirements.os.join(`, `)})`):e.success(`✓ (${a.requirements.os.join(`, `)})`);o.push(`${e.muted(` OS:`)} ${t}`)}}return o.join(`
3
3
  `)}function we(t,n){if(n.json){let e=t.hooks.filter(e=>e.eligible),n=t.hooks.filter(e=>!e.eligible);return JSON.stringify({total:t.hooks.length,eligible:e.length,notEligible:n.length,hooks:{eligible:e.map(e=>e.name),notEligible:n.map(e=>({name:e.name,missing:e.missing}))}},null,2)}let r=t.hooks.filter(e=>e.eligible),i=t.hooks.filter(e=>!e.eligible),a=[];if(a.push(e.heading(`Hooks Status`)),a.push(``),a.push(`${e.muted(`Total hooks:`)} ${t.hooks.length}`),a.push(`${e.success(`Ready:`)} ${r.length}`),a.push(`${e.warn(`Not ready:`)} ${i.length}`),i.length>0){a.push(``),a.push(e.heading(`Hooks not ready:`));for(let e of i){let t=[];e.disabled&&t.push(`disabled`),e.missing.bins.length>0&&t.push(`bins: ${e.missing.bins.join(`, `)}`),e.missing.anyBins.length>0&&t.push(`anyBins: ${e.missing.anyBins.join(`, `)}`),e.missing.env.length>0&&t.push(`env: ${e.missing.env.join(`, `)}`),e.missing.config.length>0&&t.push(`config: ${e.missing.config.join(`, `)}`),e.missing.os.length>0&&t.push(`os: ${e.missing.os.join(`, `)}`),a.push(` ${e.emoji??`🔗`} ${e.name} - ${t.join(`; `)}`)}}return a.join(`
4
4
  `)}async function Te(n){let r=s(),i=G(W(r),n,{requireEligible:!0});await o(K({config:r,hookName:n,enabled:!0,ensureHooksEnabled:!0})),t.log(`${e.success(`✓`)} Enabled hook: ${i.emoji??`🔗`} ${e.command(n)}`)}async function Ee(n){let r=s(),i=G(W(r),n);await o(K({config:r,hookName:n,enabled:!1})),t.log(`${e.warn(`⏸`)} Disabled hook: ${i.emoji??`🔗`} ${e.command(n)}`)}function De(r){let c=r.command(`hooks`).description(`Manage internal agent hooks`).addHelpText(`after`,()=>`\n${e.muted(`Docs:`)} ${h(`/cli/hooks`,`docs.openclaw.ai/cli/hooks`)}\n`);c.command(`list`).description(`List all hooks`).option(`--eligible`,`Show only eligible hooks`,!1).option(`--json`,`Output as JSON`,!1).option(`-v, --verbose`,`Show more details including missing requirements`,!1).action(async e=>q(async()=>{let n=W(s());t.log($(n,e))})),c.command(`info <name>`).description(`Show detailed information about a hook`).option(`--json`,`Output as JSON`,!1).action(async(e,n)=>q(async()=>{let r=W(s());t.log(Ce(r,e,n))})),c.command(`check`).description(`Check hooks eligibility status`).option(`--json`,`Output as JSON`,!1).action(async e=>q(async()=>{let n=W(s());t.log(we(n,e))})),c.command(`enable <name>`).description(`Enable a hook`).action(async e=>q(async()=>{await Te(e)})),c.command(`disable <name>`).description(`Disable a hook`).action(async e=>q(async()=>{await Ee(e)})),c.command(`install`).description(`Install a hook pack (path, archive, or npm spec)`).argument(`<path-or-spec>`,`Path to a hook pack or npm package spec`).option(`-l, --link`,`Link a local path instead of copying`,!1).option(`--pin`,`Record npm installs as exact resolved <name>@<version>`,!1).action(async(r,a)=>{let c=i(r),l=s();if(D.existsSync(c)){if(a.link){D.statSync(c).isDirectory()||(t.error(`Linked hook paths must be directories.`),process.exit(1));let e=l.hooks?.internal?.load?.extraDirs??[],r=Array.from(new Set([...e,c])),i=await H({path:c,dryRun:!0});i.ok||(t.error(i.error),process.exit(1));let a={...l,hooks:{...l.hooks,internal:{...l.hooks?.internal,enabled:!0,load:{...l.hooks?.internal?.load,extraDirs:r}}}};a=Q(a,i.hooks),a=U(a,{hookId:i.hookPackId,source:`path`,sourcePath:c,installPath:c,version:i.version,hooks:i.hooks}),await o(a),t.log(`Linked hook path: ${n(c)}`),Y();return}let e=await H({path:c,logger:J()});e.ok||(t.error(e.error),process.exit(1));let r=Q(l,e.hooks),i=v(c)?`archive`:`path`;r=U(r,{hookId:e.hookPackId,source:i,sourcePath:c,installPath:e.targetDir,version:e.version,hooks:e.hooks}),await o(r),t.log(`Installed hooks: ${e.hooks.join(`, `)}`),Y();return}a.link&&(t.error("`--link` requires a local path."),process.exit(1)),fe(r,[`.zip`,`.tgz`,`.tar.gz`,`.tar`])&&(t.error(`Path not found: ${c}`),process.exit(1));let u=await V({spec:r,logger:J()});u.ok||(t.error(u.error),process.exit(1));let d=Q(l,u.hooks),f=E(r,!!a.pin,u.targetDir,u.version,u.npmResolution,t.log,e.warn);d=U(d,{hookId:u.hookPackId,...f,hooks:u.hooks}),await o(d),t.log(`Installed hooks: ${u.hooks.join(`, `)}`),Y()}),c.command(`update`).description(`Update installed hooks (npm installs only)`).argument(`[id]`,`Hook pack id (omit with --all)`).option(`--all`,`Update all tracked hooks`,!1).option(`--dry-run`,`Show what would change without writing`,!1).action(async(n,r)=>{let i=s(),c=i.hooks?.internal?.installs??{},l=r.all?Object.keys(c):n?[n]:[];l.length===0&&(t.error(`Provide a hook id or use --all.`),process.exit(1));let u=i,d=0;for(let n of l){let i=c[n];if(!i){t.log(e.warn(`No install record for "${n}".`));continue}if(i.source!==`npm`){t.log(e.warn(`Skipping "${n}" (source: ${i.source}).`));continue}if(!i.spec){t.log(e.warn(`Skipping "${n}" (missing npm spec).`));continue}let o;try{o=i.installPath??N(n)}catch(r){t.log(e.error(`Invalid install path for "${n}": ${String(r)}`));continue}let s=await Z(o);if(r.dryRun){let r=await V({spec:i.spec,mode:`update`,dryRun:!0,expectedHookPackId:n,expectedIntegrity:i.integrity,onIntegrityDrift:async e=>(X(n,e),!0),logger:J()});if(!r.ok){t.log(e.error(`Failed to check ${n}: ${r.error}`));continue}let a=r.version??`unknown`,o=s??`unknown`;s&&r.version&&s===r.version?t.log(`${n} is up to date (${o}).`):t.log(`Would update ${n}: ${o} → ${a}.`);continue}let l=await V({spec:i.spec,mode:`update`,expectedHookPackId:n,expectedIntegrity:i.integrity,onIntegrityDrift:async e=>(X(n,e),await a(`Continue updating "${n}" with this artifact?`)),logger:J()});if(!l.ok){t.log(e.error(`Failed to update ${n}: ${l.error}`));continue}let f=l.version??await Z(l.targetDir);u=U(u,{hookId:n,...pe({spec:i.spec,installPath:l.targetDir,version:f,resolution:l.npmResolution}),hooks:l.hooks}),d+=1;let p=s??`unknown`,m=f??`unknown`;s&&f&&s===f?t.log(`${n} already at ${p}.`):t.log(`Updated ${n}: ${p} → ${m}.`)}d>0&&(await o(u),Y())}),c.action(async()=>q(async()=>{let e=W(s());t.log($(e,{}))}))}export{De as registerHooksCli};
package/dist/index.js CHANGED
@@ -1,3 +1,3 @@
1
1
  #!/usr/bin/env node
2
- import"./paths-B4IRk3wi.js";import{A as e,B as t,J as n,K as r,R as i,W as a,Y as o,d as s,k as c,p as l,q as u,r as d,w as f}from"./subsystem-C5XF2Fy5.js";import{T as p,l as ee,m as te,n as ne}from"./utils-UGOV_184.js";import{Dr as m,Er as h,Hn as re,Io as ie,Kn as ae,Lo as oe,Ml as se,aa as ce,ia as le,oa as ue,qs as g,ra as de,zl as fe}from"./model-selection-BLbnMb5E.js";import{Ft as pe,gt as _,t as me}from"./reply-DwfVhea1.js";import"./agent-scope-DXZc3eNT.js";import"./openclaw-root-D_0Q6--h.js";import"./github-copilot-token-DGYAlOmV.js";import{n as he,r as v}from"./command-format-BbDT1tlm.js";import"./boolean-Ch3DfXPy.js";import{r as y,t as b}from"./env-D7wNuBx1.js";import"./env-overrides-DXJbFrwI.js";import"./registry-hFAtCSWG.js";import"./skills-CzUpDbU-.js";import"./frontmatter-BkZkwkVO.js";import"./plugins-CYLrFT4h.js";import"./logger-Bl8URnrW.js";import{n as x,t as S}from"./exec-DHqLtFYt.js";import"./windows-spawn-AB7ItGAE.js";import"./redact-3_CiXMY6.js";import"./path-alias-guards-mvyLCPlN.js";import{i as C}from"./errors-Bunti32V.js";import"./send-C7rOdjPO.js";import"./send-BwblpWbK.js";import{c as w}from"./paths-yLEk_25I.js";import"./chat-envelope-HVpKusFc.js";import{S as T,l as E}from"./audio-transcription-runner-BwjMhAUa.js";import"./image-BP1cfEh1.js";import"./models-config-BlQ39qlq.js";import"./tool-display-DjuSUUbH.js";import"./fetch-guard-7BAwnP4a.js";import"./api-key-rotation-Rz2ESQSA.js";import"./local-roots-aA-4ohTq.js";import"./model-catalog-D-hkNWin.js";import"./proxy-fetch-BADsUK4d.js";import"./tokens-XGbQGn67.js";import"./deliver-DUNkj4hy.js";import"./commands-CGpM84iR.js";import"./commands-registry-DlvNUkXz.js";import"./pairing-store-EmfFQVcs.js";import"./fetch-Dikjvc5M.js";import"./call-JB-cGR9n.js";import"./with-timeout-WveKxvFV.js";import"./diagnostic-BEZszppF.js";import"./send-NbU9-scF2.js";import"./pi-model-discovery-DnJkNRc-.js";import"./exec-approvals-allowlist-B-Yf6RsU.js";import"./exec-safe-bin-runtime-policy-CRPHdPbF.js";import"./ir-CNTx85qV.js";import"./render-D8OWO2hT.js";import"./target-errors-CoEHv_2r.js";import"./read-only-account-inspect-B0cm8yrv.js";import"./channel-selection-si1OzWyQ.js";import"./plugin-auto-enable-CTgkkJK7.js";import"./send-DmHpf5Fz.js";import"./outbound-attachment-9-8VNvRG.js";import"./delivery-queue-CKbauSFq.js";import"./send-AQ3CJLpI.js";import"./channel-activity-Dw6F-ehJ.js";import"./tables-fl9iXahm.js";import"./fetch-Bn0mWg6a.js";import"./skill-commands-DlHVddAk.js";import"./workspace-dirs-BhF1Dzxt.js";import"./pairing-token-B8RdfK2y.js";import"./restart-BeJuoXCx.js";import"./runtime-web-tools-C4F6aaRh.js";import"./command-secret-targets-CfXtLkLF.js";import"./session-cost-usage-BgqKixv0.js";import"./connection-auth-smZlFWxD.js";import"./onboard-helpers-D90u4wVK.js";import"./prompt-style-CXKekIBY.js";import"./pairing-labels-PIuZfthz.js";import"./memory-cli-BouV_wyL.js";import"./query-expansion-0OxEb1Io.js";import"./manager-CI6O4QH6.js";import{t as D}from"./links-CySwdMcF.js";import"./cli-utils-BY7dLMFy.js";import"./help-format-BRbF_INg.js";import"./progress-LNttnI-y.js";import"./exec-approvals-BpBNEy6i.js";import"./nodes-screen-8nRBsfID.js";import"./system-run-command-E8ymBXHh.js";import"./runtime-DYttInEE.js";import"./stagger-DmFYysrJ.js";import{r as O,t as k}from"./channel-web-CCSMlUux.js";import"./outbound-BevYwvMh.js";import"./session-BSRnpwSq.js";import"./login-DSZdCiDx.js";import{t as A}from"./is-main-DG5ueqhF.js";import{t as j}from"./path-env-BPd1Yd-i.js";import{t as M}from"./runtime-guard-DFYBaYZS.js";import"./ports-DDWP1p0X.js";import{i as N,n as P,o as F,s as I}from"./program-context-n-ovYq69.js";import"./plugin-registry-CN2aCPP7.js";import{n as L}from"./channel-options-CCqtIYCc.js";import R from"node:process";import{fileURLToPath as ge}from"node:url";import{Command as _e,InvalidArgumentError as ve}from"commander";function ye(){let e,t=()=>(e===void 0&&(e=L()),e);return{programVersion:se,get channelOptions(){return t()},get messageChannelOptions(){return t().join(`|`)},get agentChannelOptions(){return[`last`,...t()].join(`|`)}}}const z=`All your chats, one OpenClaw.`,B={newYear:`New Year's Day: New year, new config—same old EADDRINUSE, but this time we resolve it like grown-ups.`,lunarNewYear:`Lunar New Year: May your builds be lucky, your branches prosperous, and your merge conflicts chased away with fireworks.`,christmas:`Christmas: Ho ho ho—Santa's little claw-sistant is here to ship joy, roll back chaos, and stash the keys safely.`,eid:`Eid al-Fitr: Celebration mode: queues cleared, tasks completed, and good vibes committed to main with clean history.`,diwali:`Diwali: Let the logs sparkle and the bugs flee—today we light up the terminal and ship with pride.`,easter:`Easter: I found your missing environment variable—consider it a tiny CLI egg hunt with fewer jellybeans.`,hanukkah:`Hanukkah: Eight nights, eight retries, zero shame—may your gateway stay lit and your deployments stay peaceful.`,halloween:`Halloween: Spooky season: beware haunted dependencies, cursed caches, and the ghost of node_modules past.`,thanksgiving:`Thanksgiving: Grateful for stable ports, working DNS, and a bot that reads the logs so nobody has to.`,valentines:`Valentine's Day: Roses are typed, violets are piped—I'll automate the chores so you can spend time with humans.`},V=[`Your terminal just grew claws—type something and let the bot pinch the busywork.`,`Welcome to the command line: where dreams compile and confidence segfaults.`,`I run on caffeine, JSON5, and the audacity of "it worked on my machine."`,`Gateway online—please keep hands, feet, and appendages inside the shell at all times.`,`I speak fluent bash, mild sarcasm, and aggressive tab-completion energy.`,`One CLI to rule them all, and one more restart because you changed the port.`,`If it works, it's automation; if it breaks, it's a "learning opportunity."`,`Pairing codes exist because even bots believe in consent—and good security hygiene.`,`Your .env is showing; don't worry, I'll pretend I didn't see it.`,`I'll do the boring stuff while you dramatically stare at the logs like it's cinema.`,`I'm not saying your workflow is chaotic... I'm just bringing a linter and a helmet.`,`Type the command with confidence—nature will provide the stack trace if needed.`,`I don't judge, but your missing API keys are absolutely judging you.`,`I can grep it, git blame it, and gently roast it—pick your coping mechanism.`,`Hot reload for config, cold sweat for deploys.`,`I'm the assistant your terminal demanded, not the one your sleep schedule requested.`,`I keep secrets like a vault... unless you print them in debug logs again.`,`Automation with claws: minimal fuss, maximal pinch.`,`I'm basically a Swiss Army knife, but with more opinions and fewer sharp edges.`,`If you're lost, run doctor; if you're brave, run prod; if you're wise, run tests.`,`Your task has been queued; your dignity has been deprecated.`,`I can't fix your code taste, but I can fix your build and your backlog.`,`I'm not magic—I'm just extremely persistent with retries and coping strategies.`,`It's not "failing," it's "discovering new ways to configure the same thing wrong."`,`Give me a workspace and I'll give you fewer tabs, fewer toggles, and more oxygen.`,`I read logs so you can keep pretending you don't have to.`,`If something's on fire, I can't extinguish it—but I can write a beautiful postmortem.`,`I'll refactor your busywork like it owes me money.`,`Say "stop" and I'll stop—say "ship" and we'll both learn a lesson.`,`I'm the reason your shell history looks like a hacker-movie montage.`,`I'm like tmux: confusing at first, then suddenly you can't live without me.`,`I can run local, remote, or purely on vibes—results may vary with DNS.`,`If you can describe it, I can probably automate it—or at least make it funnier.`,`Your config is valid, your assumptions are not.`,`I don't just autocomplete—I auto-commit (emotionally), then ask you to review (logically).`,`Less clicking, more shipping, fewer "where did that file go" moments.`,`Claws out, commit in—let's ship something mildly responsible.`,`I'll butter your workflow like a lobster roll: messy, delicious, effective.`,`Shell yeah—I'm here to pinch the toil and leave you the glory.`,`If it's repetitive, I'll automate it; if it's hard, I'll bring jokes and a rollback plan.`,`The only crab in your contacts you actually want to hear from. 🦞`,`WhatsApp automation without the "please accept our new privacy policy".`,`iMessage green bubble energy, but for everyone.`,`No $999 stand required.`,`We ship features faster than Apple ships calculator updates.`,`Your AI assistant, now without the $3,499 headset.`,`Ah, the fruit tree company! 🍎`,`Greetings, Professor Falken`,`I don't sleep, I just enter low-power mode and dream of clean diffs.`,`Your personal assistant, minus the passive-aggressive calendar reminders.`,`Built by lobsters, for humans. Don't question the hierarchy.`,`I've seen your commit messages. We'll work on that together.`,`More integrations than your therapist's intake form.`,`Running on your hardware, reading your logs, judging nothing (mostly).`,`The only open-source project where the mascot could eat the competition.`,`Self-hosted, self-updating, self-aware (just kidding... unless?).`,`I autocomplete your thoughts—just slower and with more API calls.`,`Somewhere between 'hello world' and 'oh god what have I built.'`,`Your .zshrc wishes it could do what I do.`,`I've read more man pages than any human should—so you don't have to.`,`Powered by open source, sustained by spite and good documentation.`,`I'm the middleware between your ambition and your attention span.`,`Finally, a use for that always-on Mac Mini under your desk.`,`Like having a senior engineer on call, except I don't bill hourly or sigh audibly.`,`Making 'I'll automate that later' happen now.`,`Your second brain, except this one actually remembers where you left things.`,`Half butler, half debugger, full crustacean.`,`I don't have opinions about tabs vs spaces. I have opinions about everything else.`,`Open source means you can see exactly how I judge your config.`,`I've survived more breaking changes than your last three relationships.`,`Runs on a Raspberry Pi. Dreams of a rack in Iceland.`,`The lobster in your shell. 🦞`,`Alexa, but with taste.`,`I'm not AI-powered, I'm AI-possessed. Big difference.`,`Deployed locally, trusted globally, debugged eternally.`,`You had me at 'openclaw gateway start.'`,B.newYear,B.lunarNewYear,B.christmas,B.eid,B.diwali,B.easter,B.hanukkah,B.halloween,B.thanksgiving,B.valentines],H=1440*60*1e3;function U(e){return{year:e.getUTCFullYear(),month:e.getUTCMonth(),day:e.getUTCDate()}}const W=(e,t)=>n=>{let r=U(n);return r.month===e&&r.day===t},G=(e,t=1)=>n=>{let r=U(n);return e.some(([e,n,i])=>{if(r.year!==e)return!1;let a=Date.UTC(e,n,i),o=Date.UTC(r.year,r.month,r.day);return o>=a&&o<a+t*H})},be=new Map([[B.newYear,W(0,1)],[B.lunarNewYear,G([[2025,0,29],[2026,1,17],[2027,1,6]],1)],[B.eid,G([[2025,2,30],[2025,2,31],[2026,2,20],[2027,2,10]],1)],[B.diwali,G([[2025,9,20],[2026,10,8],[2027,9,28]],1)],[B.easter,G([[2025,3,20],[2026,3,5],[2027,2,28]],1)],[B.hanukkah,(e=>t=>{let n=U(t),r=e.find(e=>e.year===n.year);if(!r)return!1;let i=Date.UTC(r.year,r.month,r.day),a=Date.UTC(n.year,n.month,n.day);return a>=i&&a<i+r.duration*H})([{year:2025,month:11,day:15,duration:8},{year:2026,month:11,day:5,duration:8},{year:2027,month:11,day:25,duration:8}])],[B.halloween,W(9,31)],[B.thanksgiving,e=>{let t=U(e);if(t.month!==10)return!1;let n=1+(4-new Date(Date.UTC(t.year,10,1)).getUTCDay()+7)%7+21;return t.day===n}],[B.valentines,W(1,14)],[B.christmas,W(11,25)]]);function xe(e,t){let n=be.get(e);return n?n(t):!0}function Se(e={}){if(V.length===0)return[z];let t=e.now?e.now():new Date,n=V.filter(e=>xe(e,t));return n.length>0?n:V}function Ce(e={}){if(e.mode===`off`)return``;if(e.mode===`default`)return z;let t=(e.env??process.env)?.OPENCLAW_TAGLINE_INDEX;if(t!==void 0){let e=Number.parseInt(t,10);if(!Number.isNaN(e)&&e>=0){let t=V.length>0?V:[z];return t[e%t.length]}}let n=Se(e),r=e.random??Math.random;return n[Math.floor(r()*n.length)%n.length]}let K=!1;typeof Intl<`u`&&`Segmenter`in Intl&&new Intl.Segmenter(void 0,{granularity:`grapheme`});const we=e=>e.some(e=>e===`--json`||e.startsWith(`--json=`)),Te=e=>e.some(e=>e===`--version`||e===`-V`)||o(e);function q(e){if(e===`random`||e===`default`||e===`off`)return e}function Ee(e){let t=q(e.mode);if(t)return t;try{return q(g().cli?.banner?.taglineMode)}catch{return}}function J(t,n={}){let r=n.commit??_({env:n.env,moduleUrl:import.meta.url})??`unknown`,i=Ce({...n,mode:Ee(n)}),a=n.richTty??c(),o=`🦞 OpenClaw`,l=n.columns??process.stdout.columns??120,u=`${o} ${t} (${r})`,d=i?`${u} — ${i}`:u,f=s(d)<=l;if(a){if(f)return i?`${e.heading(o)} ${e.info(t)} ${e.muted(`(${r})`)} ${e.muted(`—`)} ${e.accentDim(i)}`:`${e.heading(o)} ${e.info(t)} ${e.muted(`(${r})`)}`;let n=`${e.heading(o)} ${e.info(t)} ${e.muted(`(${r})`)}`;return i?`${n}\n${`${` `.repeat(3)}${e.accentDim(i)}`}`:n}if(f)return d;let p=u;return i?`${p}\n${`${` `.repeat(3)}${i}`}`:p}function De(e,t={}){if(K)return;let n=t.argv??process.argv;if(!process.stdout.isTTY||we(n)||Te(n))return;let r=J(e,t);process.stdout.write(`\n${r}\n\n`),K=!0}function Oe(){return K}const Y=i.join(`|`);function ke(e){let n=t(e);if(!n)throw new ve(`Invalid --log-level (use ${Y})`);return n}const X=v(),Ae=ee(X),je=new Set([...N(),...I()]),Me=[[`openclaw models --help`,`Show detailed help for the models command.`],[`openclaw channels login --verbose`,`Link personal WhatsApp Web and show QR + connection logs.`],[`openclaw message send --target +15555550123 --message "Hi" --json`,`Send via your web session and print JSON result.`],[`openclaw gateway --port 18789`,`Run the WebSocket Gateway locally.`],[`openclaw --dev gateway`,`Run a dev Gateway (isolated state/config) on ws://127.0.0.1:19001.`],[`openclaw gateway --force`,`Kill anything bound to the default gateway port, then start it.`],[`openclaw gateway ...`,`Gateway control via WebSocket.`],[`openclaw agent --to +15555550123 --message "Run summary" --deliver`,`Talk directly to the agent using the Gateway; optionally send the WhatsApp reply.`],[`openclaw message send --channel telegram --target @mychat --message "Hi"`,`Send via your Telegram bot.`]];function Ne(t,n){t.name(X).description(``).version(n.programVersion).option(`--dev`,`Dev profile: isolate state under ~/.qbotclaw-dev, default gateway port 19001, and shift derived ports (browser/canvas)`).option(`--profile <name>`,`Use a named profile (isolates OPENCLAW_STATE_DIR/OPENCLAW_CONFIG_PATH under ~/.qbotclaw-<name>)`).option(`--log-level <level>`,`Global log level override for file + console (${Y})`,ke),t.option(`--no-color`,`Disable ANSI colors`,!1),t.helpOption(`-h, --help`,`Display help for command`),t.helpCommand(`help [command]`,`Display help for command`),t.configureHelp({sortSubcommands:!0,sortOptions:!0,optionTerm:t=>e.option(t.flags),subcommandTerm:n=>{let r=n.parent===t&&je.has(n.name());return e.command(r?`${n.name()} *`:n.name())}});let r=t=>{let n=t;return RegExp(`^Usage:\\s+${Ae}\\s+\\[options\\]\\s+\\[command\\]\\s*$`,`m`).test(n)&&/^Commands:/m.test(n)&&(n=n.replace(/^Commands:/m,`Commands:\n ${e.muted(`Hint: commands suffixed with * have subcommands. Run <command> --help for details.`)}`)),n.replace(/^Usage:/gm,e.heading(`Usage:`)).replace(/^Options:/gm,e.heading(`Options:`)).replace(/^Commands:/gm,e.heading(`Commands:`))};if(t.configureOutput({writeOut:e=>{process.stdout.write(r(e))},writeErr:e=>{process.stderr.write(r(e))},outputError:(t,n)=>n(e.error(t))}),u(process.argv,`-V`)||u(process.argv,`--version`)||o(process.argv)){let e=_({moduleUrl:import.meta.url});console.log(e?`OpenClaw ${n.programVersion} (${e})`:`OpenClaw ${n.programVersion}`),process.exit(0)}t.addHelpText(`beforeAll`,()=>{if(Oe())return``;let e=c();return`\n${J(n.programVersion,{richTty:e})}\n`});let i=Me.map(([t,n])=>` ${e.command(he(t,X))}\n ${e.muted(n)}`).join(`
3
- `);t.addHelpText(`afterAll`,({command:n})=>{if(n!==t)return``;let r=D(`/cli`,`docs.openclaw.ai/cli`);return`\n${e.heading(`Examples:`)}\n${i}\n\n${e.muted(`Docs:`)} ${r}\n`})}function Pe(e){let t=e;for(;t.parent&&t.parent.parent;)t=t.parent;let n=t.name(),r=v();!n||n===r||(process.title=`${r}-${n}`)}const Fe=new Set([`message`,`channels`,`directory`,`agents`,`configure`,`onboard`,`status`,`health`]),Ie=new Set([`backup`,`doctor`,`completion`,`secrets`]),Z=new Set([`config set`]);let Q,$;function Le(e){let[t,n]=e;return t?!!(Ie.has(t)||t===`config`&&n===`validate`):!1}function Re(){return Q??=import(`./config-guard-0_afzaJz.js`),Q}function ze(){return $??=import(`./plugin-registry-CN2aCPP7.js`).then(e=>e.n),$}function Be(e){let t=e;for(;t.parent;)t=t.parent;return t}function Ve(e){let t=Be(e);if(typeof t.getOptionValueSource!=`function`||t.getOptionValueSource(`logLevel`)!==`cli`)return;let n=t.opts().logLevel;return typeof n==`string`?n:void 0}function He(e,t){if(!u(t,`--json`))return!1;let n=`${e[0]??``} ${e[1]??``}`.trim();return!Z.has(n)}function Ue(e,t){e.hook(`preAction`,async(e,i)=>{Pe(i);let o=process.argv;if(n(o))return;let s=a(o,2);b(process.env.OPENCLAW_HIDE_BANNER)||s[0]===`update`||s[0]===`completion`||s[0]===`plugins`&&s[1]===`update`||De(t);let c=r(o,{includeDebug:!0});f(c);let u=Ve(i);if(u&&(process.env.OPENCLAW_LOG_LEVEL=u),c||(process.env.NODE_NO_WARNINGS??=`1`),Le(s))return;let d=He(s,o),{ensureConfigReady:p}=await Re();if(await p({runtime:l,commandPath:s,...d?{suppressDoctorStdout:!0}:{}}),Fe.has(s[0])){let{ensurePluginRegistryLoaded:e}=await ze();e()}})}function We(){let e=new _e,t=ye(),n=process.argv;return P(e,t),Ne(e,t),Ue(e,t.programVersion),F(e,t,n),e}fe({quiet:!0}),y(),j(),d(),M();const Ge=We();A({currentFile:ge(import.meta.url)})&&(E(),R.on(`uncaughtException`,e=>{console.error(`[openclaw] Uncaught exception:`,C(e)),R.exit(1)}),Ge.parseAsync(R.argv).catch(e=>{console.error(`[openclaw] CLI failed:`,C(e)),R.exit(1)}));export{de as PortInUseError,T as applyTemplate,ne as assertWebChannel,pe as createDefaultDeps,h as deriveSessionKey,le as describePortOwner,ie as ensureBinary,ce as ensurePortAvailable,me as getReplyFromConfig,ue as handlePortError,g as loadConfig,re as loadSessionStore,k as monitorWebChannel,te as normalizeE164,oe as promptYesNo,m as resolveSessionKey,w as resolveStorePath,S as runCommandWithTimeout,x as runExec,ae as saveSessionStore,p as toWhatsappJid,O as waitForever};
2
+ import"./paths-B4IRk3wi.js";import{A as e,B as t,J as n,K as r,R as i,W as a,Y as o,d as s,k as c,p as l,q as u,r as d,w as f}from"./subsystem-C5XF2Fy5.js";import{T as p,l as ee,m as te,n as ne}from"./utils-UGOV_184.js";import{Dr as m,Er as h,Hn as re,Io as ie,Kn as ae,Lo as oe,Ml as se,aa as ce,ia as le,oa as ue,qs as g,ra as de,zl as fe}from"./model-selection-BLbnMb5E.js";import{Ft as pe,gt as _,t as me}from"./reply-mWIMy_ju.js";import"./agent-scope-DXZc3eNT.js";import"./openclaw-root-D_0Q6--h.js";import"./github-copilot-token-DGYAlOmV.js";import{n as he,r as v}from"./command-format-BbDT1tlm.js";import"./boolean-Ch3DfXPy.js";import{r as y,t as b}from"./env-D7wNuBx1.js";import"./env-overrides-DXJbFrwI.js";import"./registry-hFAtCSWG.js";import"./skills-CzUpDbU-.js";import"./frontmatter-BkZkwkVO.js";import"./plugins-CYLrFT4h.js";import"./logger-Bl8URnrW.js";import{n as x,t as S}from"./exec-DHqLtFYt.js";import"./windows-spawn-AB7ItGAE.js";import"./redact-3_CiXMY6.js";import"./path-alias-guards-mvyLCPlN.js";import{i as C}from"./errors-Bunti32V.js";import"./send-C7rOdjPO.js";import"./send-BwblpWbK.js";import{c as w}from"./paths-yLEk_25I.js";import"./chat-envelope-HVpKusFc.js";import{S as T,l as E}from"./audio-transcription-runner-BwjMhAUa.js";import"./image-BP1cfEh1.js";import"./models-config-BlQ39qlq.js";import"./tool-display-DjuSUUbH.js";import"./fetch-guard-7BAwnP4a.js";import"./api-key-rotation-Rz2ESQSA.js";import"./local-roots-aA-4ohTq.js";import"./model-catalog-D-hkNWin.js";import"./proxy-fetch-BADsUK4d.js";import"./tokens-XGbQGn67.js";import"./deliver-DUNkj4hy.js";import"./commands-CGpM84iR.js";import"./commands-registry-DlvNUkXz.js";import"./pairing-store-EmfFQVcs.js";import"./fetch-Dikjvc5M.js";import"./call-JB-cGR9n.js";import"./with-timeout-WveKxvFV.js";import"./diagnostic-BEZszppF.js";import"./send-NbU9-scF2.js";import"./pi-model-discovery-DnJkNRc-.js";import"./exec-approvals-allowlist-B-Yf6RsU.js";import"./exec-safe-bin-runtime-policy-CRPHdPbF.js";import"./ir-CNTx85qV.js";import"./render-D8OWO2hT.js";import"./target-errors-CoEHv_2r.js";import"./read-only-account-inspect-B0cm8yrv.js";import"./channel-selection-si1OzWyQ.js";import"./plugin-auto-enable-CTgkkJK7.js";import"./send-DmHpf5Fz.js";import"./outbound-attachment-9-8VNvRG.js";import"./delivery-queue-CKbauSFq.js";import"./send-AQ3CJLpI.js";import"./channel-activity-Dw6F-ehJ.js";import"./tables-fl9iXahm.js";import"./fetch-Bn0mWg6a.js";import"./skill-commands-DlHVddAk.js";import"./workspace-dirs-BhF1Dzxt.js";import"./pairing-token-B8RdfK2y.js";import"./restart-BeJuoXCx.js";import"./runtime-web-tools-C4F6aaRh.js";import"./command-secret-targets-CfXtLkLF.js";import"./session-cost-usage-BgqKixv0.js";import"./connection-auth-smZlFWxD.js";import"./onboard-helpers-D90u4wVK.js";import"./prompt-style-CXKekIBY.js";import"./pairing-labels-PIuZfthz.js";import"./memory-cli-BouV_wyL.js";import"./query-expansion-0OxEb1Io.js";import"./manager-CI6O4QH6.js";import{t as D}from"./links-CySwdMcF.js";import"./cli-utils-BY7dLMFy.js";import"./help-format-BRbF_INg.js";import"./progress-LNttnI-y.js";import"./exec-approvals-BpBNEy6i.js";import"./nodes-screen-8nRBsfID.js";import"./system-run-command-E8ymBXHh.js";import"./runtime-DYttInEE.js";import"./stagger-DmFYysrJ.js";import{r as O,t as k}from"./channel-web-TKrgB4oQ.js";import"./outbound-BevYwvMh.js";import"./session-BSRnpwSq.js";import"./login-DSZdCiDx.js";import{t as A}from"./is-main-DG5ueqhF.js";import{t as j}from"./path-env-BPd1Yd-i.js";import{t as M}from"./runtime-guard-DFYBaYZS.js";import"./ports-BDZyt9rk.js";import{i as N,n as P,o as F,s as I}from"./program-context-C4vPkfWW.js";import"./plugin-registry-DBgXa8jD.js";import{n as L}from"./channel-options-DcI5T_Su.js";import R from"node:process";import{fileURLToPath as ge}from"node:url";import{Command as _e,InvalidArgumentError as ve}from"commander";function ye(){let e,t=()=>(e===void 0&&(e=L()),e);return{programVersion:se,get channelOptions(){return t()},get messageChannelOptions(){return t().join(`|`)},get agentChannelOptions(){return[`last`,...t()].join(`|`)}}}const z=`All your chats, one OpenClaw.`,B={newYear:`New Year's Day: New year, new config—same old EADDRINUSE, but this time we resolve it like grown-ups.`,lunarNewYear:`Lunar New Year: May your builds be lucky, your branches prosperous, and your merge conflicts chased away with fireworks.`,christmas:`Christmas: Ho ho ho—Santa's little claw-sistant is here to ship joy, roll back chaos, and stash the keys safely.`,eid:`Eid al-Fitr: Celebration mode: queues cleared, tasks completed, and good vibes committed to main with clean history.`,diwali:`Diwali: Let the logs sparkle and the bugs flee—today we light up the terminal and ship with pride.`,easter:`Easter: I found your missing environment variable—consider it a tiny CLI egg hunt with fewer jellybeans.`,hanukkah:`Hanukkah: Eight nights, eight retries, zero shame—may your gateway stay lit and your deployments stay peaceful.`,halloween:`Halloween: Spooky season: beware haunted dependencies, cursed caches, and the ghost of node_modules past.`,thanksgiving:`Thanksgiving: Grateful for stable ports, working DNS, and a bot that reads the logs so nobody has to.`,valentines:`Valentine's Day: Roses are typed, violets are piped—I'll automate the chores so you can spend time with humans.`},V=[`Your terminal just grew claws—type something and let the bot pinch the busywork.`,`Welcome to the command line: where dreams compile and confidence segfaults.`,`I run on caffeine, JSON5, and the audacity of "it worked on my machine."`,`Gateway online—please keep hands, feet, and appendages inside the shell at all times.`,`I speak fluent bash, mild sarcasm, and aggressive tab-completion energy.`,`One CLI to rule them all, and one more restart because you changed the port.`,`If it works, it's automation; if it breaks, it's a "learning opportunity."`,`Pairing codes exist because even bots believe in consent—and good security hygiene.`,`Your .env is showing; don't worry, I'll pretend I didn't see it.`,`I'll do the boring stuff while you dramatically stare at the logs like it's cinema.`,`I'm not saying your workflow is chaotic... I'm just bringing a linter and a helmet.`,`Type the command with confidence—nature will provide the stack trace if needed.`,`I don't judge, but your missing API keys are absolutely judging you.`,`I can grep it, git blame it, and gently roast it—pick your coping mechanism.`,`Hot reload for config, cold sweat for deploys.`,`I'm the assistant your terminal demanded, not the one your sleep schedule requested.`,`I keep secrets like a vault... unless you print them in debug logs again.`,`Automation with claws: minimal fuss, maximal pinch.`,`I'm basically a Swiss Army knife, but with more opinions and fewer sharp edges.`,`If you're lost, run doctor; if you're brave, run prod; if you're wise, run tests.`,`Your task has been queued; your dignity has been deprecated.`,`I can't fix your code taste, but I can fix your build and your backlog.`,`I'm not magic—I'm just extremely persistent with retries and coping strategies.`,`It's not "failing," it's "discovering new ways to configure the same thing wrong."`,`Give me a workspace and I'll give you fewer tabs, fewer toggles, and more oxygen.`,`I read logs so you can keep pretending you don't have to.`,`If something's on fire, I can't extinguish it—but I can write a beautiful postmortem.`,`I'll refactor your busywork like it owes me money.`,`Say "stop" and I'll stop—say "ship" and we'll both learn a lesson.`,`I'm the reason your shell history looks like a hacker-movie montage.`,`I'm like tmux: confusing at first, then suddenly you can't live without me.`,`I can run local, remote, or purely on vibes—results may vary with DNS.`,`If you can describe it, I can probably automate it—or at least make it funnier.`,`Your config is valid, your assumptions are not.`,`I don't just autocomplete—I auto-commit (emotionally), then ask you to review (logically).`,`Less clicking, more shipping, fewer "where did that file go" moments.`,`Claws out, commit in—let's ship something mildly responsible.`,`I'll butter your workflow like a lobster roll: messy, delicious, effective.`,`Shell yeah—I'm here to pinch the toil and leave you the glory.`,`If it's repetitive, I'll automate it; if it's hard, I'll bring jokes and a rollback plan.`,`The only crab in your contacts you actually want to hear from. 🦞`,`WhatsApp automation without the "please accept our new privacy policy".`,`iMessage green bubble energy, but for everyone.`,`No $999 stand required.`,`We ship features faster than Apple ships calculator updates.`,`Your AI assistant, now without the $3,499 headset.`,`Ah, the fruit tree company! 🍎`,`Greetings, Professor Falken`,`I don't sleep, I just enter low-power mode and dream of clean diffs.`,`Your personal assistant, minus the passive-aggressive calendar reminders.`,`Built by lobsters, for humans. Don't question the hierarchy.`,`I've seen your commit messages. We'll work on that together.`,`More integrations than your therapist's intake form.`,`Running on your hardware, reading your logs, judging nothing (mostly).`,`The only open-source project where the mascot could eat the competition.`,`Self-hosted, self-updating, self-aware (just kidding... unless?).`,`I autocomplete your thoughts—just slower and with more API calls.`,`Somewhere between 'hello world' and 'oh god what have I built.'`,`Your .zshrc wishes it could do what I do.`,`I've read more man pages than any human should—so you don't have to.`,`Powered by open source, sustained by spite and good documentation.`,`I'm the middleware between your ambition and your attention span.`,`Finally, a use for that always-on Mac Mini under your desk.`,`Like having a senior engineer on call, except I don't bill hourly or sigh audibly.`,`Making 'I'll automate that later' happen now.`,`Your second brain, except this one actually remembers where you left things.`,`Half butler, half debugger, full crustacean.`,`I don't have opinions about tabs vs spaces. I have opinions about everything else.`,`Open source means you can see exactly how I judge your config.`,`I've survived more breaking changes than your last three relationships.`,`Runs on a Raspberry Pi. Dreams of a rack in Iceland.`,`The lobster in your shell. 🦞`,`Alexa, but with taste.`,`I'm not AI-powered, I'm AI-possessed. Big difference.`,`Deployed locally, trusted globally, debugged eternally.`,`You had me at 'openclaw gateway start.'`,B.newYear,B.lunarNewYear,B.christmas,B.eid,B.diwali,B.easter,B.hanukkah,B.halloween,B.thanksgiving,B.valentines],H=1440*60*1e3;function U(e){return{year:e.getUTCFullYear(),month:e.getUTCMonth(),day:e.getUTCDate()}}const W=(e,t)=>n=>{let r=U(n);return r.month===e&&r.day===t},G=(e,t=1)=>n=>{let r=U(n);return e.some(([e,n,i])=>{if(r.year!==e)return!1;let a=Date.UTC(e,n,i),o=Date.UTC(r.year,r.month,r.day);return o>=a&&o<a+t*H})},be=new Map([[B.newYear,W(0,1)],[B.lunarNewYear,G([[2025,0,29],[2026,1,17],[2027,1,6]],1)],[B.eid,G([[2025,2,30],[2025,2,31],[2026,2,20],[2027,2,10]],1)],[B.diwali,G([[2025,9,20],[2026,10,8],[2027,9,28]],1)],[B.easter,G([[2025,3,20],[2026,3,5],[2027,2,28]],1)],[B.hanukkah,(e=>t=>{let n=U(t),r=e.find(e=>e.year===n.year);if(!r)return!1;let i=Date.UTC(r.year,r.month,r.day),a=Date.UTC(n.year,n.month,n.day);return a>=i&&a<i+r.duration*H})([{year:2025,month:11,day:15,duration:8},{year:2026,month:11,day:5,duration:8},{year:2027,month:11,day:25,duration:8}])],[B.halloween,W(9,31)],[B.thanksgiving,e=>{let t=U(e);if(t.month!==10)return!1;let n=1+(4-new Date(Date.UTC(t.year,10,1)).getUTCDay()+7)%7+21;return t.day===n}],[B.valentines,W(1,14)],[B.christmas,W(11,25)]]);function xe(e,t){let n=be.get(e);return n?n(t):!0}function Se(e={}){if(V.length===0)return[z];let t=e.now?e.now():new Date,n=V.filter(e=>xe(e,t));return n.length>0?n:V}function Ce(e={}){if(e.mode===`off`)return``;if(e.mode===`default`)return z;let t=(e.env??process.env)?.OPENCLAW_TAGLINE_INDEX;if(t!==void 0){let e=Number.parseInt(t,10);if(!Number.isNaN(e)&&e>=0){let t=V.length>0?V:[z];return t[e%t.length]}}let n=Se(e),r=e.random??Math.random;return n[Math.floor(r()*n.length)%n.length]}let K=!1;typeof Intl<`u`&&`Segmenter`in Intl&&new Intl.Segmenter(void 0,{granularity:`grapheme`});const we=e=>e.some(e=>e===`--json`||e.startsWith(`--json=`)),Te=e=>e.some(e=>e===`--version`||e===`-V`)||o(e);function q(e){if(e===`random`||e===`default`||e===`off`)return e}function Ee(e){let t=q(e.mode);if(t)return t;try{return q(g().cli?.banner?.taglineMode)}catch{return}}function J(t,n={}){let r=n.commit??_({env:n.env,moduleUrl:import.meta.url})??`unknown`,i=Ce({...n,mode:Ee(n)}),a=n.richTty??c(),o=`🦞 OpenClaw`,l=n.columns??process.stdout.columns??120,u=`${o} ${t} (${r})`,d=i?`${u} — ${i}`:u,f=s(d)<=l;if(a){if(f)return i?`${e.heading(o)} ${e.info(t)} ${e.muted(`(${r})`)} ${e.muted(`—`)} ${e.accentDim(i)}`:`${e.heading(o)} ${e.info(t)} ${e.muted(`(${r})`)}`;let n=`${e.heading(o)} ${e.info(t)} ${e.muted(`(${r})`)}`;return i?`${n}\n${`${` `.repeat(3)}${e.accentDim(i)}`}`:n}if(f)return d;let p=u;return i?`${p}\n${`${` `.repeat(3)}${i}`}`:p}function De(e,t={}){if(K)return;let n=t.argv??process.argv;if(!process.stdout.isTTY||we(n)||Te(n))return;let r=J(e,t);process.stdout.write(`\n${r}\n\n`),K=!0}function Oe(){return K}const Y=i.join(`|`);function ke(e){let n=t(e);if(!n)throw new ve(`Invalid --log-level (use ${Y})`);return n}const X=v(),Ae=ee(X),je=new Set([...N(),...I()]),Me=[[`openclaw models --help`,`Show detailed help for the models command.`],[`openclaw channels login --verbose`,`Link personal WhatsApp Web and show QR + connection logs.`],[`openclaw message send --target +15555550123 --message "Hi" --json`,`Send via your web session and print JSON result.`],[`openclaw gateway --port 18789`,`Run the WebSocket Gateway locally.`],[`openclaw --dev gateway`,`Run a dev Gateway (isolated state/config) on ws://127.0.0.1:19001.`],[`openclaw gateway --force`,`Kill anything bound to the default gateway port, then start it.`],[`openclaw gateway ...`,`Gateway control via WebSocket.`],[`openclaw agent --to +15555550123 --message "Run summary" --deliver`,`Talk directly to the agent using the Gateway; optionally send the WhatsApp reply.`],[`openclaw message send --channel telegram --target @mychat --message "Hi"`,`Send via your Telegram bot.`]];function Ne(t,n){t.name(X).description(``).version(n.programVersion).option(`--dev`,`Dev profile: isolate state under ~/.qbotclaw-dev, default gateway port 19001, and shift derived ports (browser/canvas)`).option(`--profile <name>`,`Use a named profile (isolates OPENCLAW_STATE_DIR/OPENCLAW_CONFIG_PATH under ~/.qbotclaw-<name>)`).option(`--log-level <level>`,`Global log level override for file + console (${Y})`,ke),t.option(`--no-color`,`Disable ANSI colors`,!1),t.helpOption(`-h, --help`,`Display help for command`),t.helpCommand(`help [command]`,`Display help for command`),t.configureHelp({sortSubcommands:!0,sortOptions:!0,optionTerm:t=>e.option(t.flags),subcommandTerm:n=>{let r=n.parent===t&&je.has(n.name());return e.command(r?`${n.name()} *`:n.name())}});let r=t=>{let n=t;return RegExp(`^Usage:\\s+${Ae}\\s+\\[options\\]\\s+\\[command\\]\\s*$`,`m`).test(n)&&/^Commands:/m.test(n)&&(n=n.replace(/^Commands:/m,`Commands:\n ${e.muted(`Hint: commands suffixed with * have subcommands. Run <command> --help for details.`)}`)),n.replace(/^Usage:/gm,e.heading(`Usage:`)).replace(/^Options:/gm,e.heading(`Options:`)).replace(/^Commands:/gm,e.heading(`Commands:`))};if(t.configureOutput({writeOut:e=>{process.stdout.write(r(e))},writeErr:e=>{process.stderr.write(r(e))},outputError:(t,n)=>n(e.error(t))}),u(process.argv,`-V`)||u(process.argv,`--version`)||o(process.argv)){let e=_({moduleUrl:import.meta.url});console.log(e?`OpenClaw ${n.programVersion} (${e})`:`OpenClaw ${n.programVersion}`),process.exit(0)}t.addHelpText(`beforeAll`,()=>{if(Oe())return``;let e=c();return`\n${J(n.programVersion,{richTty:e})}\n`});let i=Me.map(([t,n])=>` ${e.command(he(t,X))}\n ${e.muted(n)}`).join(`
3
+ `);t.addHelpText(`afterAll`,({command:n})=>{if(n!==t)return``;let r=D(`/cli`,`docs.openclaw.ai/cli`);return`\n${e.heading(`Examples:`)}\n${i}\n\n${e.muted(`Docs:`)} ${r}\n`})}function Pe(e){let t=e;for(;t.parent&&t.parent.parent;)t=t.parent;let n=t.name(),r=v();!n||n===r||(process.title=`${r}-${n}`)}const Fe=new Set([`message`,`channels`,`directory`,`agents`,`configure`,`onboard`,`status`,`health`]),Ie=new Set([`backup`,`doctor`,`completion`,`secrets`]),Z=new Set([`config set`]);let Q,$;function Le(e){let[t,n]=e;return t?!!(Ie.has(t)||t===`config`&&n===`validate`):!1}function Re(){return Q??=import(`./config-guard-0_afzaJz.js`),Q}function ze(){return $??=import(`./plugin-registry-DBgXa8jD.js`).then(e=>e.n),$}function Be(e){let t=e;for(;t.parent;)t=t.parent;return t}function Ve(e){let t=Be(e);if(typeof t.getOptionValueSource!=`function`||t.getOptionValueSource(`logLevel`)!==`cli`)return;let n=t.opts().logLevel;return typeof n==`string`?n:void 0}function He(e,t){if(!u(t,`--json`))return!1;let n=`${e[0]??``} ${e[1]??``}`.trim();return!Z.has(n)}function Ue(e,t){e.hook(`preAction`,async(e,i)=>{Pe(i);let o=process.argv;if(n(o))return;let s=a(o,2);b(process.env.OPENCLAW_HIDE_BANNER)||s[0]===`update`||s[0]===`completion`||s[0]===`plugins`&&s[1]===`update`||De(t);let c=r(o,{includeDebug:!0});f(c);let u=Ve(i);if(u&&(process.env.OPENCLAW_LOG_LEVEL=u),c||(process.env.NODE_NO_WARNINGS??=`1`),Le(s))return;let d=He(s,o),{ensureConfigReady:p}=await Re();if(await p({runtime:l,commandPath:s,...d?{suppressDoctorStdout:!0}:{}}),Fe.has(s[0])){let{ensurePluginRegistryLoaded:e}=await ze();e()}})}function We(){let e=new _e,t=ye(),n=process.argv;return P(e,t),Ne(e,t),Ue(e,t.programVersion),F(e,t,n),e}fe({quiet:!0}),y(),j(),d(),M();const Ge=We();A({currentFile:ge(import.meta.url)})&&(E(),R.on(`uncaughtException`,e=>{console.error(`[openclaw] Uncaught exception:`,C(e)),R.exit(1)}),Ge.parseAsync(R.argv).catch(e=>{console.error(`[openclaw] CLI failed:`,C(e)),R.exit(1)}));export{de as PortInUseError,T as applyTemplate,ne as assertWebChannel,pe as createDefaultDeps,h as deriveSessionKey,le as describePortOwner,ie as ensureBinary,ce as ensurePortAvailable,me as getReplyFromConfig,ue as handlePortError,g as loadConfig,re as loadSessionStore,k as monitorWebChannel,te as normalizeE164,oe as promptYesNo,m as resolveSessionKey,w as resolveStorePath,S as runCommandWithTimeout,x as runExec,ae as saveSessionStore,p as toWhatsappJid,O as waitForever};
@@ -1,4 +1,4 @@
1
- import{G as e,H as t,K as n,V as r}from"./paths-CrCoPIVK.js";import"./paths-CChBdtE8.js";import{t as i}from"./subsystem-Bc2XrjUz.js";import"./workspace-B0ZQeHXg.js";import"./utils-D3t-vPka.js";import{l as a,rc as o}from"./model-selection-D7mdJmGK.js";import"./github-copilot-token-DePP-lIf.js";import"./boolean-DypnRoRK.js";import"./proxy-env-DcmW_urA.js";import"./frontmatter-CzpfPBFl.js";import"./logger-5W0OocJW.js";import"./send-4h1tQwX3.js";import"./send-CciNyaWL.js";import{t as s}from"./pi-embedded-X_Svd4Wi.js";import"./tokens-CL2fSjGl.js";import"./deliver-BhWhLvQO.js";import"./diagnostic-VBPCgF9l.js";import"./send--9G8eXo4.js";import"./pi-model-discovery-BonZ1N3x.js";import"./image-BBO-0uLG.js";import"./audio-transcription-runner-9H9eUZ1D.js";import"./fetch-DBat25iG.js";import"./fetch-guard-DvaNcypz.js";import"./api-key-rotation-DayEfYpa.js";import"./proxy-fetch-BZ9O8Dvj.js";import"./ir-BTfsA9Dd.js";import"./render-CBsnn-2A.js";import"./target-errors-Dnkqss9y.js";import"./commands-registry-C5Hg7gyk.js";import"./fetch-_g8lZ8K8.js";import"./skill-commands-CtprBvm0.js";import"./channel-activity-htoVXTET.js";import"./tables-_t5V36m9.js";import"./send-hlES-kRl2.js";import"./outbound-attachment-E89zumcH.js";import"./send-7qgAI0ap.js";import"./fetch-BJT3BrkJ.js";import"./query-expansion-BUUx_oWg.js";import"./manager-CN_rQm1L.js";import c from"node:fs/promises";import l from"node:os";import u from"node:path";const d=i(`llm-slug-generator`);async function f(i){let f=null;try{let d=n(i.cfg),p=e(i.cfg,d),m=r(i.cfg,d),h=await c.mkdtemp(u.join(l.tmpdir(),`openclaw-slug-`));f=u.join(h,`session.jsonl`);let g=`Based on this conversation, generate a short 1-2 word filename slug (lowercase, hyphen-separated, no file extension).
1
+ import{G as e,H as t,K as n,V as r}from"./paths-CrCoPIVK.js";import"./paths-CChBdtE8.js";import{t as i}from"./subsystem-Bc2XrjUz.js";import"./workspace-B0ZQeHXg.js";import"./utils-D3t-vPka.js";import{l as a,rc as o}from"./model-selection-D7mdJmGK.js";import"./github-copilot-token-DePP-lIf.js";import"./boolean-DypnRoRK.js";import"./proxy-env-DcmW_urA.js";import"./frontmatter-CzpfPBFl.js";import"./logger-5W0OocJW.js";import"./send-4h1tQwX3.js";import"./send-CciNyaWL.js";import{t as s}from"./pi-embedded-CoHiJa9Q.js";import"./tokens-CL2fSjGl.js";import"./deliver-BhWhLvQO.js";import"./diagnostic-VBPCgF9l.js";import"./send--9G8eXo4.js";import"./pi-model-discovery-BonZ1N3x.js";import"./image-BBO-0uLG.js";import"./audio-transcription-runner-9H9eUZ1D.js";import"./fetch-DBat25iG.js";import"./fetch-guard-DvaNcypz.js";import"./api-key-rotation-DayEfYpa.js";import"./proxy-fetch-BZ9O8Dvj.js";import"./ir-BTfsA9Dd.js";import"./render-CBsnn-2A.js";import"./target-errors-Dnkqss9y.js";import"./commands-registry-C5Hg7gyk.js";import"./fetch-_g8lZ8K8.js";import"./skill-commands-CtprBvm0.js";import"./channel-activity-htoVXTET.js";import"./tables-_t5V36m9.js";import"./send-hlES-kRl2.js";import"./outbound-attachment-E89zumcH.js";import"./send-7qgAI0ap.js";import"./fetch-BJT3BrkJ.js";import"./query-expansion-BUUx_oWg.js";import"./manager-CN_rQm1L.js";import c from"node:fs/promises";import l from"node:os";import u from"node:path";const d=i(`llm-slug-generator`);async function f(i){let f=null;try{let d=n(i.cfg),p=e(i.cfg,d),m=r(i.cfg,d),h=await c.mkdtemp(u.join(l.tmpdir(),`openclaw-slug-`));f=u.join(h,`session.jsonl`);let g=`Based on this conversation, generate a short 1-2 word filename slug (lowercase, hyphen-separated, no file extension).
2
2
 
3
3
  Conversation summary:
4
4
  ${i.sessionContent.slice(0,2e3)}
@@ -1,2 +1,2 @@
1
- import{A as e,O as t,k as n}from"./subsystem-BLbY429l.js";import"./paths-BjD3T_xq.js";import"./boolean-D15s2V33.js";import{Gc as r,Hc as i,Io as a,Kc as o,Lc as s,Mc as c,Oo as l,Qc as u,Rc as d,Ro as f,Sc as p,Tc as m,Xc as h,Yc as g,cl as _,dl as v,du as y,eu as b,fl as x,fu as S,hl as ee,jc as C,jo as w,l as te,ml as T,n as ne,pu as re,r as E,sl as D,so as O,ul as k,vl as ie,xc as A,yc as j}from"./auth-profiles-C8rZRS0X.js";import{t as M}from"./command-format-CLxIPuLR.js";import{F as ae,N,P,a as oe,d as se,f as ce,j as le,l as ue,s as de}from"./agent-scope-DAWJwFfl.js";import{x as F}from"./utils-CGdo13HV.js";import{r as fe}from"./string-normalization-DJT5zuUF.js";import"./openclaw-root-CnsBf6ZU.js";import{i as pe,l as I}from"./types.secrets-D4tbc3Wq.js";import"./github-copilot-token-C79yeDKS.js";import"./env-overrides-DHtB4kK3.js";import"./version-q3SkUw2K.js";import{t as me}from"./parse-duration-XTjMKl8s.js";import"./registry-BptzrW8D.js";import"./skills-Bz_S4lPh.js";import"./frontmatter-C7mzDNxd.js";import"./plugins-DNlgeTTc.js";import"./logger-kQAOe3qp.js";import"./exec-B3eleY5O.js";import"./windows-spawn-7oINn5ao.js";import"./redact-CnRxK70G.js";import"./path-alias-guards-kY_ZbWs-.js";import"./errors-6SQWM9dj.js";import"./send-vNcod64S.js";import"./send-CyarIb2w.js";import{Tr as he,Xr as L,an as ge,cr as _e,fn as ve,hn as ye,in as be,mn as xe,nn as R,rn as Se}from"./compact-CYbPi7_-.js";import{i as Ce,s as we}from"./paths-BfjJY2VL.js";import"./chat-envelope-Bznn2SoS.js";import"./models-config-DZzS67GS.js";import"./tokens-DRM8vzJx.js";import"./with-timeout-c1CzdShT.js";import"./deliver-SqSusZP3.js";import"./diagnostic-D1H7_8QG.js";import"./send-Dj7NBAWg.js";import{n as Te,t as Ee}from"./pi-model-discovery-BPkhPDMr.js";import"./exec-approvals-allowlist-CGjRWREs.js";import"./exec-safe-bin-runtime-policy-v44u39fl.js";import{n as De}from"./model-catalog-mt0IcDfR.js";import"./fetch-B4bz67_N.js";import"./audio-transcription-runner-BIKj1CBU.js";import"./fetch-guard-DaZmvp-L.js";import"./image-BVbOr9yV.js";import"./tool-display-DJDtttQg.js";import"./api-key-rotation-BpEL4aeX.js";import"./proxy-fetch-gWETR3cl.js";import"./ir-DdjufzKF.js";import"./render-DrrPmnMI.js";import"./target-errors-D6wejRd6.js";import"./commands-Dy7duWlt.js";import"./commands-registry-DT6FDUev.js";import"./session-cost-usage-CHtVgnE8.js";import"./session-utils-Bpdyx2A2.js";import"./sqlite-CILF3z9U.js";import"./call-BWx7hNtl.js";import"./pi-tools.policy-B6q8YOfg.js";import"./pairing-store-BaaVy1zB.js";import"./fetch-Dh-apy46.js";import"./skill-commands-DCqPy_Aa.js";import"./workspace-dirs-A8Vib9_B.js";import"./pairing-token-zdbQ951y.js";import"./channel-activity-BhiLsKvM.js";import"./tables-DENKrP-W.js";import"./kill-tree-D6nPx1_o.js";import"./runtime-web-tools-BYhCkBV8.js";import"./runtime-CK7gqwEF.js";import"./node-shell-BVZylVP6.js";import"./stagger-DxzgG2jd.js";import"./channel-selection-BPxE8JR7.js";import"./plugin-auto-enable-adba5Evb.js";import"./send-ChILboDj.js";import"./outbound-attachment-CVcDBkAD.js";import"./delivery-queue-nkPJu0fY.js";import"./send-COpehmAB.js";import"./system-run-command-DsWBVvSK.js";import"./fetch-Ce-scEU-.js";import{i as Oe,s as z}from"./command-secret-targets-BEjtBf5Z.js";import"./connection-auth-CjaeEu5D.js";import{f as B}from"./onboard-helpers-DOlI17Ac.js";import{n as V,r as H,t as ke}from"./prompt-style-BThRSQJR.js";import"./pairing-labels-CZ-aX-up.js";import"./search-manager-CV2YsAym.js";import"./manager-CxZRoQkE.js";import"./memory-cli-C8fBBPgv.js";import"./links-CBnmRP9D.js";import"./cli-utils-BleB1eys.js";import"./help-format-B4aEI7V9.js";import{r as Ae}from"./progress-d1m2sqR1.js";import"./exec-approvals-BXO9Cezj.js";import"./provider-env-vars-Dt0Q29Su.js";import"./note-Dp-d_utk.js";import{t as je}from"./clack-prompter-DBPdGdqp.js";import"./issue-format-CN9PHzXY.js";import{n as Me,t as Ne}from"./table-CR7TFMew.js";import{t as U}from"./model-param-b-B0r2cPDw.js";import{n as W}from"./format-Ce7I7s-k.js";import{a as G,c as Pe,d as Fe,f as Ie,i as Le,l as K,m as q,n as Re,o as ze,p as Be,r as Ve,s as He,t as Ue,u as We}from"./openai-codex-model-default-DuRfnfUm.js";import{Mt as Ge,h as Ke,n as qe}from"./auth-token-DZLZ3d_I.js";import{t as Je}from"./oauth-env-DAamJ1oz.js";import{n as J}from"./logging-B7XHbCNn.js";import{a as Ye,i as Xe,n as Ze,o as Qe,r as $e,s as et,t as tt}from"./provider-auth-helpers-BLm2bdp5.js";import"./oauth-tls-preflight-BSBRDIfC.js";import nt from"node:path";import rt from"node:fs/promises";import it from"node:crypto";import{complete as at,getEnvApiKey as ot,getModel as st}from"@mariozechner/pi-ai";import{Type as ct}from"@sinclair/typebox";import{cancel as lt,confirm as ut,isCancel as dt,multiselect as ft,select as pt,text as mt}from"@clack/prompts";async function ht(e){try{let{snapshot:e}=await a();if(e.valid)return e.resolved}catch{}return e}async function gt(e){let t=w(),n=await ht(t),{resolvedConfig:r,diagnostics:i}=await z({config:t,commandName:e.commandName,targetIds:Oe()});if(e.runtime)for(let t of i)e.runtime.log(`[secrets] ${t}`);return f(r,n),{sourceConfig:n,resolvedConfig:r,diagnostics:i}}async function Y(e){return(await gt(e)).resolvedConfig}async function _t(e,t){Le(e);let n=(await Y({commandName:`models aliases list`,runtime:t})).agents?.defaults?.models??{},r=Object.entries(n).reduce((e,[t,n])=>{let r=n?.alias?.trim();return r&&(e[r]=t),e},{});if(e.json){t.log(JSON.stringify({aliases:r},null,2));return}if(e.plain){for(let[e,n]of Object.entries(r))t.log(`${e} ${n}`);return}if(t.log(`Aliases (${Object.keys(r).length}):`),Object.keys(r).length===0){t.log(`- none`);return}for(let[e,n]of Object.entries(r))t.log(`- ${e} -> ${n}`)}async function vt(e,t,n){let r=We(e),i=Be({raw:t,cfg:await Y({commandName:`models aliases add`,runtime:n})});await q(e=>{let t=`${i.provider}/${i.model}`,n={...e.agents?.defaults?.models};for(let[e,i]of Object.entries(n)){let n=i?.alias?.trim();if(n&&n===r&&e!==t)throw Error(`Alias ${r} already points to ${e}.`)}return n[t]={...n[t]??{},alias:r},{...e,agents:{...e.agents,defaults:{...e.agents?.defaults,models:n}}}}),J(n),n.log(`Alias ${r} -> ${i.provider}/${i.model}`)}async function yt(e,t){let n=We(e),r=await q(e=>{let t={...e.agents?.defaults?.models},r=!1;for(let[e,i]of Object.entries(t))if(i?.alias?.trim()===n){t[e]={...i,alias:void 0},r=!0;break}if(!r)throw Error(`Alias not found: ${n}`);return{...e,agents:{...e.agents,defaults:{...e.agents?.defaults,models:t}}}});J(t),(!r.agents?.defaults?.models||Object.values(r.agents.defaults.models).every(e=>!e?.alias?.trim()))&&t.log(`No aliases configured.`)}function bt(e){return(typeof e==`symbol`||dt(e))&&(lt(`Cancelled.`),process.exit(0)),e}const xt=async e=>bt(await ut({...e,message:V(e.message)})),X=async e=>bt(await mt({...e,message:V(e.message)})),St=async e=>bt(await pt({...e,message:V(e.message),options:e.options.map(e=>e.hint===void 0?e:{...e,hint:ke(e.hint)})}));function Ct(e){let t=e?.trim();return t?r(t)===`anthropic`?`anthropic`:`custom`:null}function wt(e){return`${r(e)}:manual`}async function Tt(e,t){let n=Ct(e.provider??`anthropic`);if(n!==`anthropic`)throw Error(`Only --provider anthropic is supported for setup-token.`);if(!process.stdin.isTTY)throw Error(`setup-token requires an interactive TTY.`);if(!e.yes&&!await xt({message:"Have you run `claude setup-token` and copied the token?",initialValue:!0}))return;let r=await X({message:`Paste Anthropic setup-token`,validate:e=>qe(String(e??``))}),i=String(r??``).trim(),a=wt(n);p({profileId:a,credential:{type:`token`,provider:n,token:i}}),await q(e=>Ke(e,{profileId:a,provider:n,mode:`token`})),J(t),t.log(`Auth profile: ${a} (${n}/token)`)}async function Et(e,t){let n=e.provider?.trim();if(!n)throw Error(`Missing --provider.`);let i=r(n),a=e.profileId?.trim()||wt(i),o=await X({message:`Paste token for ${i}`,validate:e=>e?.trim()?void 0:`Required`}),s=String(o??``).trim(),c=e.expiresIn?.trim()&&e.expiresIn.trim().length>0?Date.now()+me(String(e.expiresIn??``).trim(),{defaultUnit:`d`}):void 0;p({profileId:a,credential:{type:`token`,provider:i,token:s,...c?{expires:c}:{}}}),await q(e=>Ke(e,{profileId:a,provider:i,mode:`token`})),J(t),t.log(`Auth profile: ${a} (${i}/token)`)}async function Dt(e,t){let n=await St({message:`Token provider`,options:[{value:`anthropic`,label:`anthropic`},{value:`custom`,label:`custom (type provider id)`}]}),i=n===`custom`?r(String(await X({message:`Provider id`,validate:e=>e?.trim()?void 0:`Required`}))):n;if(await St({message:`Token method`,options:[...i===`anthropic`?[{value:`setup-token`,label:`setup-token (claude)`,hint:"Paste a setup-token from `claude setup-token`"}]:[],{value:`paste`,label:`paste token`}]})===`setup-token`){await Tt({provider:i},t);return}let a=wt(i);await Et({provider:i,profileId:String(await X({message:`Profile id`,initialValue:a,validate:e=>e?.trim()?void 0:`Required`})).trim(),expiresIn:await xt({message:`Does this token expire?`,initialValue:!1})?String(await X({message:`Expires in (duration)`,initialValue:`365d`,validate:e=>{try{me(String(e??``),{defaultUnit:`d`});return}catch{return`Invalid duration (e.g. 365d, 12h, 30m)`}}})).trim():void 0},t)}function Ot(e,t){let n=t?.trim();if(!n)return null;let r=Xe(e,n);if(r)return r;let i=e.map(e=>e.id).filter(Boolean).toSorted((e,t)=>e.localeCompare(t)),a=i.length>0?i.join(`, `):`(none)`;throw Error(`Unknown provider "${n}". Loaded providers: ${a}. Verify plugins via \`${M(`openclaw plugins list --json`)}\`.`)}function kt(e){return e.type===`api_key`?`api_key`:e.type===`token`?`token`:`oauth`}async function At(e){let t=await Ye({prompter:e.prompter,runtime:e.runtime,isRemote:Je(),openUrl:async e=>{await B(e)},localBrowserMessage:`Complete sign-in in browser…`});if(!t)throw Error(`OpenAI Codex OAuth did not return credentials.`);let n=await Ge(`openai-codex`,t,e.agentDir,{syncSiblingAgents:!0});await q(t=>{let r=Ke(t,{profileId:n,provider:`openai-codex`,mode:`oauth`});return e.opts.setDefault&&(r=Re(r).next),r}),J(e.runtime),e.runtime.log(`Auth profile: ${n} (openai-codex/oauth)`),e.opts.setDefault?e.runtime.log(`Default model set to ${Ue}`):e.runtime.log(`Default model available: ${Ue} (use --set-default to apply)`)}async function jt(e,t){if(!process.stdin.isTTY)throw Error(`models auth login requires an interactive TTY.`);let n=await Pe(),i=ce(n),a=oe(n,i),o=se(n,i)??le(),s=r(String(e.provider??``)),c=je();if(s===`openai-codex`){await At({opts:e,runtime:t,prompter:c,agentDir:a});return}let l=et({config:n,workspaceDir:o});if(l.length===0)throw Error(`No provider plugins found. Install one via \`${M(`openclaw plugins install`)}\`.`);let u=Ot(l,e.provider)??await c.select({message:`Select a provider`,options:l.map(e=>({value:e.id,label:e.label,hint:e.docsPath?`Docs: ${e.docsPath}`:void 0}))}).then(e=>Xe(l,String(e)));if(!u)throw Error(`Unknown provider. Use --provider <id> to pick a provider plugin.`);let d=$e(u,e.method)??(u.auth.length===1?u.auth[0]:await c.select({message:`Auth method for ${u.label}`,options:u.auth.map(e=>({value:e.id,label:e.label,hint:e.hint}))}).then(e=>u.auth.find(t=>t.id===String(e))));if(!d)throw Error(`Unknown auth method. Use --method <id> to select one.`);let f=Je(),m=await d.run({config:n,agentDir:a,workspaceDir:o,prompter:c,runtime:t,isRemote:f,openUrl:async e=>{await B(e)},oauth:{createVpsAwareHandlers:e=>Qe(e)}});for(let e of m.profiles)p({profileId:e.profileId,credential:e.credential,agentDir:a});await q(t=>{let n=t;m.configPatch&&(n=Ze(n,m.configPatch));for(let e of m.profiles)n=Ke(n,{profileId:e.profileId,provider:e.credential.provider,mode:kt(e.credential)});return e.setDefault&&m.defaultModel&&(n=tt(n,m.defaultModel)),n}),J(t);for(let e of m.profiles)t.log(`Auth profile: ${e.profileId} (${e.credential.provider}/${kt(e.credential)})`);m.defaultModel&&t.log(e.setDefault?`Default model set to ${m.defaultModel}`:`Default model available: ${m.defaultModel} (use --set-default to apply)`),m.notes&&m.notes.length>0&&await c.note(m.notes.join(`
1
+ import{A as e,O as t,k as n}from"./subsystem-BLbY429l.js";import"./paths-BjD3T_xq.js";import"./boolean-D15s2V33.js";import{Gc as r,Hc as i,Io as a,Kc as o,Lc as s,Mc as c,Oo as l,Qc as u,Rc as d,Ro as f,Sc as p,Tc as m,Xc as h,Yc as g,cl as _,dl as v,du as y,eu as b,fl as x,fu as S,hl as ee,jc as C,jo as w,l as te,ml as T,n as ne,pu as re,r as E,sl as D,so as O,ul as k,vl as ie,xc as A,yc as j}from"./auth-profiles-C8rZRS0X.js";import{t as M}from"./command-format-CLxIPuLR.js";import{F as ae,N,P,a as oe,d as se,f as ce,j as le,l as ue,s as de}from"./agent-scope-DAWJwFfl.js";import{x as F}from"./utils-CGdo13HV.js";import{r as fe}from"./string-normalization-DJT5zuUF.js";import"./openclaw-root-CnsBf6ZU.js";import{i as pe,l as I}from"./types.secrets-D4tbc3Wq.js";import"./github-copilot-token-C79yeDKS.js";import"./env-overrides-DHtB4kK3.js";import"./version-q3SkUw2K.js";import{t as me}from"./parse-duration-XTjMKl8s.js";import"./registry-BptzrW8D.js";import"./skills-Bz_S4lPh.js";import"./frontmatter-C7mzDNxd.js";import"./plugins-DNlgeTTc.js";import"./logger-kQAOe3qp.js";import"./exec-B3eleY5O.js";import"./windows-spawn-7oINn5ao.js";import"./redact-CnRxK70G.js";import"./path-alias-guards-kY_ZbWs-.js";import"./errors-6SQWM9dj.js";import"./send-vNcod64S.js";import"./send-CyarIb2w.js";import{Tr as he,Xr as L,an as ge,cr as _e,fn as ve,hn as ye,in as be,mn as xe,nn as R,rn as Se}from"./compact-uyQDx8pN.js";import{i as Ce,s as we}from"./paths-BfjJY2VL.js";import"./chat-envelope-Bznn2SoS.js";import"./models-config-DZzS67GS.js";import"./tokens-DRM8vzJx.js";import"./with-timeout-c1CzdShT.js";import"./deliver-SqSusZP3.js";import"./diagnostic-D1H7_8QG.js";import"./send-Dj7NBAWg.js";import{n as Te,t as Ee}from"./pi-model-discovery-BPkhPDMr.js";import"./exec-approvals-allowlist-CGjRWREs.js";import"./exec-safe-bin-runtime-policy-v44u39fl.js";import{n as De}from"./model-catalog-mt0IcDfR.js";import"./fetch-B4bz67_N.js";import"./audio-transcription-runner-BIKj1CBU.js";import"./fetch-guard-DaZmvp-L.js";import"./image-BVbOr9yV.js";import"./tool-display-DJDtttQg.js";import"./api-key-rotation-BpEL4aeX.js";import"./proxy-fetch-gWETR3cl.js";import"./ir-DdjufzKF.js";import"./render-DrrPmnMI.js";import"./target-errors-D6wejRd6.js";import"./commands-Dy7duWlt.js";import"./commands-registry-DT6FDUev.js";import"./session-cost-usage-CHtVgnE8.js";import"./session-utils-Bpdyx2A2.js";import"./sqlite-CILF3z9U.js";import"./call-BWx7hNtl.js";import"./pi-tools.policy-B6q8YOfg.js";import"./pairing-store-BaaVy1zB.js";import"./fetch-Dh-apy46.js";import"./skill-commands-DCqPy_Aa.js";import"./workspace-dirs-A8Vib9_B.js";import"./pairing-token-zdbQ951y.js";import"./channel-activity-BhiLsKvM.js";import"./tables-DENKrP-W.js";import"./kill-tree-D6nPx1_o.js";import"./runtime-web-tools-BYhCkBV8.js";import"./runtime-CK7gqwEF.js";import"./node-shell-BVZylVP6.js";import"./stagger-DxzgG2jd.js";import"./channel-selection-BPxE8JR7.js";import"./plugin-auto-enable-adba5Evb.js";import"./send-ChILboDj.js";import"./outbound-attachment-CVcDBkAD.js";import"./delivery-queue-nkPJu0fY.js";import"./send-COpehmAB.js";import"./system-run-command-DsWBVvSK.js";import"./fetch-Ce-scEU-.js";import{i as Oe,s as z}from"./command-secret-targets-BEjtBf5Z.js";import"./connection-auth-CjaeEu5D.js";import{f as B}from"./onboard-helpers-DOlI17Ac.js";import{n as V,r as H,t as ke}from"./prompt-style-BThRSQJR.js";import"./pairing-labels-CZ-aX-up.js";import"./search-manager-CV2YsAym.js";import"./manager-CxZRoQkE.js";import"./memory-cli-C8fBBPgv.js";import"./links-CBnmRP9D.js";import"./cli-utils-BleB1eys.js";import"./help-format-B4aEI7V9.js";import{r as Ae}from"./progress-d1m2sqR1.js";import"./exec-approvals-BXO9Cezj.js";import"./provider-env-vars-Dt0Q29Su.js";import"./note-Dp-d_utk.js";import{t as je}from"./clack-prompter-DBPdGdqp.js";import"./issue-format-CN9PHzXY.js";import{n as Me,t as Ne}from"./table-CR7TFMew.js";import{t as U}from"./model-param-b-B0r2cPDw.js";import{n as W}from"./format-Ce7I7s-k.js";import{a as G,c as Pe,d as Fe,f as Ie,i as Le,l as K,m as q,n as Re,o as ze,p as Be,r as Ve,s as He,t as Ue,u as We}from"./openai-codex-model-default-DuRfnfUm.js";import{Mt as Ge,h as Ke,n as qe}from"./auth-token-DZLZ3d_I.js";import{t as Je}from"./oauth-env-DAamJ1oz.js";import{n as J}from"./logging-B7XHbCNn.js";import{a as Ye,i as Xe,n as Ze,o as Qe,r as $e,s as et,t as tt}from"./provider-auth-helpers-DeCLF5oV.js";import"./oauth-tls-preflight-BSBRDIfC.js";import nt from"node:path";import rt from"node:fs/promises";import it from"node:crypto";import{complete as at,getEnvApiKey as ot,getModel as st}from"@mariozechner/pi-ai";import{Type as ct}from"@sinclair/typebox";import{cancel as lt,confirm as ut,isCancel as dt,multiselect as ft,select as pt,text as mt}from"@clack/prompts";async function ht(e){try{let{snapshot:e}=await a();if(e.valid)return e.resolved}catch{}return e}async function gt(e){let t=w(),n=await ht(t),{resolvedConfig:r,diagnostics:i}=await z({config:t,commandName:e.commandName,targetIds:Oe()});if(e.runtime)for(let t of i)e.runtime.log(`[secrets] ${t}`);return f(r,n),{sourceConfig:n,resolvedConfig:r,diagnostics:i}}async function Y(e){return(await gt(e)).resolvedConfig}async function _t(e,t){Le(e);let n=(await Y({commandName:`models aliases list`,runtime:t})).agents?.defaults?.models??{},r=Object.entries(n).reduce((e,[t,n])=>{let r=n?.alias?.trim();return r&&(e[r]=t),e},{});if(e.json){t.log(JSON.stringify({aliases:r},null,2));return}if(e.plain){for(let[e,n]of Object.entries(r))t.log(`${e} ${n}`);return}if(t.log(`Aliases (${Object.keys(r).length}):`),Object.keys(r).length===0){t.log(`- none`);return}for(let[e,n]of Object.entries(r))t.log(`- ${e} -> ${n}`)}async function vt(e,t,n){let r=We(e),i=Be({raw:t,cfg:await Y({commandName:`models aliases add`,runtime:n})});await q(e=>{let t=`${i.provider}/${i.model}`,n={...e.agents?.defaults?.models};for(let[e,i]of Object.entries(n)){let n=i?.alias?.trim();if(n&&n===r&&e!==t)throw Error(`Alias ${r} already points to ${e}.`)}return n[t]={...n[t]??{},alias:r},{...e,agents:{...e.agents,defaults:{...e.agents?.defaults,models:n}}}}),J(n),n.log(`Alias ${r} -> ${i.provider}/${i.model}`)}async function yt(e,t){let n=We(e),r=await q(e=>{let t={...e.agents?.defaults?.models},r=!1;for(let[e,i]of Object.entries(t))if(i?.alias?.trim()===n){t[e]={...i,alias:void 0},r=!0;break}if(!r)throw Error(`Alias not found: ${n}`);return{...e,agents:{...e.agents,defaults:{...e.agents?.defaults,models:t}}}});J(t),(!r.agents?.defaults?.models||Object.values(r.agents.defaults.models).every(e=>!e?.alias?.trim()))&&t.log(`No aliases configured.`)}function bt(e){return(typeof e==`symbol`||dt(e))&&(lt(`Cancelled.`),process.exit(0)),e}const xt=async e=>bt(await ut({...e,message:V(e.message)})),X=async e=>bt(await mt({...e,message:V(e.message)})),St=async e=>bt(await pt({...e,message:V(e.message),options:e.options.map(e=>e.hint===void 0?e:{...e,hint:ke(e.hint)})}));function Ct(e){let t=e?.trim();return t?r(t)===`anthropic`?`anthropic`:`custom`:null}function wt(e){return`${r(e)}:manual`}async function Tt(e,t){let n=Ct(e.provider??`anthropic`);if(n!==`anthropic`)throw Error(`Only --provider anthropic is supported for setup-token.`);if(!process.stdin.isTTY)throw Error(`setup-token requires an interactive TTY.`);if(!e.yes&&!await xt({message:"Have you run `claude setup-token` and copied the token?",initialValue:!0}))return;let r=await X({message:`Paste Anthropic setup-token`,validate:e=>qe(String(e??``))}),i=String(r??``).trim(),a=wt(n);p({profileId:a,credential:{type:`token`,provider:n,token:i}}),await q(e=>Ke(e,{profileId:a,provider:n,mode:`token`})),J(t),t.log(`Auth profile: ${a} (${n}/token)`)}async function Et(e,t){let n=e.provider?.trim();if(!n)throw Error(`Missing --provider.`);let i=r(n),a=e.profileId?.trim()||wt(i),o=await X({message:`Paste token for ${i}`,validate:e=>e?.trim()?void 0:`Required`}),s=String(o??``).trim(),c=e.expiresIn?.trim()&&e.expiresIn.trim().length>0?Date.now()+me(String(e.expiresIn??``).trim(),{defaultUnit:`d`}):void 0;p({profileId:a,credential:{type:`token`,provider:i,token:s,...c?{expires:c}:{}}}),await q(e=>Ke(e,{profileId:a,provider:i,mode:`token`})),J(t),t.log(`Auth profile: ${a} (${i}/token)`)}async function Dt(e,t){let n=await St({message:`Token provider`,options:[{value:`anthropic`,label:`anthropic`},{value:`custom`,label:`custom (type provider id)`}]}),i=n===`custom`?r(String(await X({message:`Provider id`,validate:e=>e?.trim()?void 0:`Required`}))):n;if(await St({message:`Token method`,options:[...i===`anthropic`?[{value:`setup-token`,label:`setup-token (claude)`,hint:"Paste a setup-token from `claude setup-token`"}]:[],{value:`paste`,label:`paste token`}]})===`setup-token`){await Tt({provider:i},t);return}let a=wt(i);await Et({provider:i,profileId:String(await X({message:`Profile id`,initialValue:a,validate:e=>e?.trim()?void 0:`Required`})).trim(),expiresIn:await xt({message:`Does this token expire?`,initialValue:!1})?String(await X({message:`Expires in (duration)`,initialValue:`365d`,validate:e=>{try{me(String(e??``),{defaultUnit:`d`});return}catch{return`Invalid duration (e.g. 365d, 12h, 30m)`}}})).trim():void 0},t)}function Ot(e,t){let n=t?.trim();if(!n)return null;let r=Xe(e,n);if(r)return r;let i=e.map(e=>e.id).filter(Boolean).toSorted((e,t)=>e.localeCompare(t)),a=i.length>0?i.join(`, `):`(none)`;throw Error(`Unknown provider "${n}". Loaded providers: ${a}. Verify plugins via \`${M(`openclaw plugins list --json`)}\`.`)}function kt(e){return e.type===`api_key`?`api_key`:e.type===`token`?`token`:`oauth`}async function At(e){let t=await Ye({prompter:e.prompter,runtime:e.runtime,isRemote:Je(),openUrl:async e=>{await B(e)},localBrowserMessage:`Complete sign-in in browser…`});if(!t)throw Error(`OpenAI Codex OAuth did not return credentials.`);let n=await Ge(`openai-codex`,t,e.agentDir,{syncSiblingAgents:!0});await q(t=>{let r=Ke(t,{profileId:n,provider:`openai-codex`,mode:`oauth`});return e.opts.setDefault&&(r=Re(r).next),r}),J(e.runtime),e.runtime.log(`Auth profile: ${n} (openai-codex/oauth)`),e.opts.setDefault?e.runtime.log(`Default model set to ${Ue}`):e.runtime.log(`Default model available: ${Ue} (use --set-default to apply)`)}async function jt(e,t){if(!process.stdin.isTTY)throw Error(`models auth login requires an interactive TTY.`);let n=await Pe(),i=ce(n),a=oe(n,i),o=se(n,i)??le(),s=r(String(e.provider??``)),c=je();if(s===`openai-codex`){await At({opts:e,runtime:t,prompter:c,agentDir:a});return}let l=et({config:n,workspaceDir:o});if(l.length===0)throw Error(`No provider plugins found. Install one via \`${M(`openclaw plugins install`)}\`.`);let u=Ot(l,e.provider)??await c.select({message:`Select a provider`,options:l.map(e=>({value:e.id,label:e.label,hint:e.docsPath?`Docs: ${e.docsPath}`:void 0}))}).then(e=>Xe(l,String(e)));if(!u)throw Error(`Unknown provider. Use --provider <id> to pick a provider plugin.`);let d=$e(u,e.method)??(u.auth.length===1?u.auth[0]:await c.select({message:`Auth method for ${u.label}`,options:u.auth.map(e=>({value:e.id,label:e.label,hint:e.hint}))}).then(e=>u.auth.find(t=>t.id===String(e))));if(!d)throw Error(`Unknown auth method. Use --method <id> to select one.`);let f=Je(),m=await d.run({config:n,agentDir:a,workspaceDir:o,prompter:c,runtime:t,isRemote:f,openUrl:async e=>{await B(e)},oauth:{createVpsAwareHandlers:e=>Qe(e)}});for(let e of m.profiles)p({profileId:e.profileId,credential:e.credential,agentDir:a});await q(t=>{let n=t;m.configPatch&&(n=Ze(n,m.configPatch));for(let e of m.profiles)n=Ke(n,{profileId:e.profileId,provider:e.credential.provider,mode:kt(e.credential)});return e.setDefault&&m.defaultModel&&(n=tt(n,m.defaultModel)),n}),J(t);for(let e of m.profiles)t.log(`Auth profile: ${e.profileId} (${e.credential.provider}/${kt(e.credential)})`);m.defaultModel&&t.log(e.setDefault?`Default model set to ${m.defaultModel}`:`Default model available: ${m.defaultModel} (use --set-default to apply)`),m.notes&&m.notes.length>0&&await c.note(m.notes.join(`
2
2
  `),`Provider notes`)}function Mt(e,t){let n=Fe({cfg:e,rawAgentId:t})??ce(e);return{agentId:n,agentDir:oe(e,n)}}function Nt(e,t){let n=r(t),i=e.order?.[n];return Array.isArray(i)?i:[]}async function Pt(e,t){let n=e.provider?.trim();if(!n)throw Error(`Missing --provider.`);let i=r(n),a=await Y({commandName:`models auth-order`,runtime:t}),{agentId:o,agentDir:s}=Mt(a,e.agent);return{cfg:a,agentId:o,agentDir:s,provider:i}}async function Ft(e,t){let{agentId:n,agentDir:r,provider:i}=await Pt(e,t),a=Nt(m(r,{allowKeychainPrompt:!1}),i);if(e.json){t.log(JSON.stringify({agentId:n,agentDir:r,provider:i,authStorePath:F(`${r}/auth-profiles.json`),order:a.length>0?a:null},null,2));return}t.log(`Agent: ${n}`),t.log(`Provider: ${i}`),t.log(`Auth file: ${F(`${r}/auth-profiles.json`)}`),t.log(a.length>0?`Order override: ${a.join(`, `)}`:`Order override: (none)`)}async function It(e,t){let{agentId:n,agentDir:r,provider:i}=await Pt(e,t);if(!await A({agentDir:r,provider:i,order:null}))throw Error(`Failed to update auth-profiles.json (lock busy?).`);t.log(`Agent: ${n}`),t.log(`Provider: ${i}`),t.log(`Cleared per-agent order override.`)}async function Lt(e,t){let{agentId:n,agentDir:i,provider:a}=await Pt(e,t),o=m(i,{allowKeychainPrompt:!1}),s=a,c=fe(e.order??[]);if(c.length===0)throw Error(`Missing profile ids. Provide one or more profile ids.`);for(let e of c){let t=o.profiles[e];if(!t)throw Error(`Auth profile "${e}" not found in ${i}.`);if(r(t.provider)!==s)throw Error(`Auth profile "${e}" is for ${t.provider}, not ${a}.`)}let l=await A({agentDir:i,provider:a,order:c});if(!l)throw Error(`Failed to update auth-profiles.json (lock busy?).`);t.log(`Agent: ${n}`),t.log(`Provider: ${a}`),t.log(`Order override: ${Nt(l,a).join(`, `)}`)}function Z(e,t){return N(e.agents?.defaults?.[t])}function Rt(e,t){let n=ae(e.agents?.defaults?.[t.key]);return{...e,agents:{...e.agents,defaults:{...e.agents?.defaults,[t.key]:K(n,{fallbacks:t.fallbacks}),...t.models?{models:t.models}:void 0}}}}async function zt(e,t,n){Le(t);let r=Z(await Y({commandName:`models ${e.key} list`,runtime:n}),e.key);if(t.json){n.log(JSON.stringify({fallbacks:r},null,2));return}if(t.plain){for(let e of r)n.log(e);return}if(n.log(`${e.label} (${r.length}):`),r.length===0){n.log(`- none`);return}for(let e of r)n.log(`- ${e}`)}async function Bt(e,t,n){let r=await q(n=>{let r=Be({raw:t,cfg:n}),a=i(r.provider,r.model),o={...n.agents?.defaults?.models};o[a]||(o[a]={});let s=Z(n,e.key);return Ie({cfg:n,entries:s}).includes(a)?n:Rt(n,{key:e.key,fallbacks:[...s,a],models:o})});J(n),n.log(`${e.logPrefix}: ${Z(r,e.key).join(`, `)}`)}async function Vt(e,t,n){let r=await q(n=>{let r=Be({raw:t,cfg:n}),a=i(r.provider,r.model),o=s({cfg:n,defaultProvider:S}),c=Z(n,e.key),l=c.filter(e=>{let t=u({raw:String(e??``),defaultProvider:S,aliasIndex:o});return t?i(t.ref.provider,t.ref.model)!==a:!0});if(l.length===c.length)throw Error(`${e.notFoundLabel} not found: ${a}`);return Rt(n,{key:e.key,fallbacks:l})});J(n),n.log(`${e.logPrefix}: ${Z(r,e.key).join(`, `)}`)}async function Ht(e,t){await q(t=>Rt(t,{key:e.key,fallbacks:[]})),J(t),t.log(e.clearedMessage)}async function Ut(e,t){return await zt({label:`Fallbacks`,key:`model`},e,t)}async function Wt(e,t){return await Bt({label:`Fallbacks`,key:`model`,logPrefix:`Fallbacks`},e,t)}async function Gt(e,t){return await Vt({label:`Fallbacks`,key:`model`,notFoundLabel:`Fallback`,logPrefix:`Fallbacks`},e,t)}async function Kt(e){return await Ht({key:`model`,clearedMessage:`Fallback list cleared.`},e)}async function qt(e,t){return await zt({label:`Image fallbacks`,key:`imageModel`},e,t)}async function Jt(e,t){return await Bt({label:`Image fallbacks`,key:`imageModel`,logPrefix:`Image fallbacks`},e,t)}async function Yt(e,t){return await Vt({label:`Image fallbacks`,key:`imageModel`,notFoundLabel:`Image fallback`,logPrefix:`Image fallbacks`},e,t)}async function Xt(e){return await Ht({key:`imageModel`,clearedMessage:`Image fallback list cleared.`},e)}function Zt(e){let t=g({cfg:e,defaultProvider:S,defaultModel:y}),n=s({cfg:e,defaultProvider:S}),r=[],a=new Map,c=new Map;for(let[e,t]of n.byKey.entries())c.set(e,t);let l=(e,t)=>{let n=i(e.provider,e.model);a.has(n)||(a.set(n,new Set),r.push(n)),a.get(n)?.add(t)};l(t,`default`);let d=N(e.agents?.defaults?.model),f=N(e.agents?.defaults?.imageModel),p=P(e.agents?.defaults?.imageModel)??``;if(d.forEach((e,t)=>{let r=u({raw:String(e??``),defaultProvider:S,aliasIndex:n});r&&l(r.ref,`fallback#${t+1}`)}),p){let e=u({raw:p,defaultProvider:S,aliasIndex:n});e&&l(e.ref,`image`)}f.forEach((e,t)=>{let r=u({raw:String(e??``),defaultProvider:S,aliasIndex:n});r&&l(r.ref,`img-fallback#${t+1}`)});for(let t of Object.keys(e.agents?.defaults?.models??{})){let e=o(String(t??``),S);e&&l(e,`configured`)}return{entries:r.map(e=>{let t=e.indexOf(`/`);return{key:e,ref:{provider:t===-1?e:e.slice(0,t),model:t===-1?``:e.slice(t+1)},tags:a.get(e)??new Set,aliases:c.get(e)??[]}})}}const Qt=`MODEL_AVAILABILITY_UNAVAILABLE`;function $t(e){return e instanceof Error?e.stack??`${e.name}: ${e.message}`:String(e)}function en(e){return e instanceof Error?e.code===Qt:!1}const tn=(e,t,n)=>!t||!n?!1:!!(j(n,e).length>0||e===`amazon-bedrock`&&v()||x(e)||_(t,e));function nn(e){let t=Error(e);return t.code=Qt,t}function rn(e){return en(e)&&e instanceof Error?e:nn(`Model availability unavailable: getAvailable() failed.\n${$t(e)}`)}function an(e){if(!Array.isArray(e))throw nn(`Model availability unavailable: getAvailable() returned a non-array value.`);for(let t of e)if(!t||typeof t!=`object`||typeof t.provider!=`string`||typeof t.id!=`string`)throw nn(`Model availability unavailable: getAvailable() returned invalid model entries.`);return e}function on(e){let t;try{t=e.getAvailable()}catch(e){throw rn(e)}try{return an(t)}catch(e){throw rn(e)}}async function sn(e,t){let n=c(),r=Te(Ee(n),n),a=r.getAll(),o,s;try{let e=on(r);o=new Set(e.map(e=>i(e.provider,e.id)))}catch(e){if(!en(e))throw e;o=void 0,s||=$t(e)}return{registry:r,models:a,availableKeys:o,availabilityErrorMessage:s}}function cn(e){let{model:t,key:n,tags:r,aliases:a=[],availableKeys:o,cfg:s,authStore:c,allowProviderAvailabilityFallback:l=!1}=e;if(!t)return{key:n,name:n,input:`-`,contextWindow:null,local:null,available:null,tags:[...r,`missing`],missing:!0};let u=t.input.join(`+`)||`text`,d=He(t.baseUrl),f=o?.has(i(t.provider,t.id))??!1,p=o!==void 0&&!l?f:f||(s&&c?tn(t.provider,s,c):!1),m=a.length>0?[`alias:${a.join(`,`)}`]:[],h=new Set(r);if(m.length>0){for(let e of h)(e===`alias`||e.startsWith(`alias:`))&&h.delete(e);for(let e of m)h.add(e)}return{key:n,name:t.name||t.id,input:u,contextWindow:t.contextWindow??null,local:d,available:p,tags:Array.from(h),missing:!1}}function ln(e,t){return!(e.provider&&t.provider.toLowerCase()!==e.provider||e.local&&!He(t.baseUrl??``))}function un(e){let t=e.context.configuredByKey.get(e.key);return cn({model:e.model,key:e.key,tags:t?Array.from(t.tags):[],aliases:t?.aliases??[],availableKeys:e.context.availableKeys,cfg:e.context.cfg,authStore:e.context.authStore,allowProviderAvailabilityFallback:e.allowProviderAvailabilityFallback??!1})}async function dn(e,t){let n=await sn(e,t);return{...n,discoveredKeys:new Set(n.models.map(e=>i(e.provider,e.id)))}}function fn(e){let t=new Set,n=[...e.models].toSorted((e,t)=>{let n=e.provider.localeCompare(t.provider);return n===0?e.id.localeCompare(t.id):n});for(let r of n){if(!ln(e.context.filter,r))continue;let n=i(r.provider,r.id);e.rows.push(un({model:r,key:n,context:e.context})),t.add(n)}return t}async function pn(e){let t=await De({config:e.context.cfg});for(let n of t){if(e.context.filter.provider&&n.provider.toLowerCase()!==e.context.filter.provider)continue;let t=i(n.provider,n.id);if(e.seenKeys.has(t))continue;let r=L({provider:n.provider,modelId:n.id,modelRegistry:e.modelRegistry,cfg:e.context.cfg});!r||!ln(e.context.filter,r)||(e.rows.push(un({model:r,key:t,context:e.context,allowProviderAvailabilityFallback:!e.context.discoveredKeys.has(t)})),e.seenKeys.add(t))}}function mn(e){for(let t of e.entries){if(e.context.filter.provider&&t.ref.provider.toLowerCase()!==e.context.filter.provider)continue;let n=L({provider:t.ref.provider,modelId:t.ref.model,modelRegistry:e.modelRegistry,cfg:e.context.cfg});e.context.filter.local&&n&&!He(n.baseUrl??``)||e.context.filter.local&&!n||e.rows.push(cn({model:n,key:t.key,tags:Array.from(t.tags),aliases:t.aliases,availableKeys:e.context.availableKeys,cfg:e.context.cfg,authStore:e.context.authStore,allowProviderAvailabilityFallback:n?!e.context.discoveredKeys.has(i(n.provider,n.id)):!1}))}}const hn=e=>!!(n()&&!e?.json&&!e?.plain),Q=(e,t)=>e.padEnd(t),gn=(t,n)=>n?t===`default`?e.success(t):t===`image`?e.accentBright(t):t===`configured`?e.accent(t):t===`missing`?e.error(t):t.startsWith(`fallback#`)||t.startsWith(`img-fallback#`)?e.warn(t):t.startsWith(`alias:`)?e.accentDim(t):e.muted(t):t,_n=(e,t)=>e.length<=t?e:t<=3?e.slice(0,t):`${e.slice(0,t-3)}...`;function vn(n,r,i={}){if(i.json){r.log(JSON.stringify({count:n.length,models:n},null,2));return}if(i.plain){for(let e of n)r.log(e.key);return}let a=hn(i),o=[Q(`Model`,42),Q(`Input`,10),Q(`Ctx`,8),Q(`Local`,5),Q(`Auth`,5),`Tags`].join(` `);r.log(a?e.heading(o):o);for(let i of n){let n=Q(_n(i.key,42),42),o=Q(i.input||`-`,10),s=Q(ze(i.contextWindow),8),c=Q(i.local===null?`-`:i.local?`yes`:`no`,5),l=Q(i.available===null?`-`:i.available?`yes`:`no`,5),u=i.tags.length>0?a?i.tags.map(e=>gn(e,a)).join(`,`):i.tags.join(`,`):``,d=t(a,i.input.includes(`image`)?e.accentBright:e.info,o),f=t(a,i.local===null?e.muted:i.local?e.success:e.muted,c),p=t(a,i.available===null?e.muted:i.available?e.success:e.error,l),m=[a?e.accent(n):n,d,s,f,p,u].join(` `);r.log(m)}}async function yn(e,t){Le(e);let{ensureAuthProfileStore:n}=await import(`./auth-profiles-C8rZRS0X.js`).then(e=>e.t),{ensureOpenClawModelsJson:r}=await import(`./models-config-DZzS67GS.js`).then(e=>e.n),{sourceConfig:i,resolvedConfig:a}=await gt({commandName:`models list`,runtime:t}),s=n(),c=(()=>{let t=e.provider?.trim();if(t)return o(`${t}/_`,`anthropic`)?.provider??t.toLowerCase()})(),l,u=new Set,d,f;try{await r(i??a);let e=await dn(a,{sourceConfig:i});l=e.registry,u=e.discoveredKeys,d=e.availableKeys,f=e.availabilityErrorMessage}catch(e){t.error(`Model registry unavailable:\n${$t(e)}`),process.exitCode=1;return}f!==void 0&&t.error(`Model availability lookup failed; falling back to auth heuristics for discovered models: ${f}`);let{entries:p}=Zt(a),m=new Map(p.map(e=>[e.key,e])),h=[],g={cfg:a,authStore:s,availableKeys:d,configuredByKey:m,discoveredKeys:u,filter:{provider:c,local:e.local}};if(e.all){let e=fn({rows:h,models:l?.getAll()??[],context:g});l&&await pn({rows:h,modelRegistry:l,context:g,seenKeys:e})}else{let e=l;if(!e){t.error(`Model registry unavailable.`),process.exitCode=1;return}mn({rows:h,entries:p,modelRegistry:e,context:g})}if(h.length===0){t.log(`No models found.`);return}vn(h,t,e)}function bn(e){return b(e,{includeEnvVarName:!1})?`marker(${e.trim()})`:R(e)}function xn(e){let t=typeof e.value==`string`?e.value.trim():``;if(t){let n=bn(t);return e.kind===`token`?`token:${n}`:n}if(e.ref){let t=`ref(${e.ref.source}:${e.ref.id})`;return e.kind===`token`?`token:${t}`:t}return e.kind===`token`?`token:missing`:`missing`}function Sn(e){let{provider:t,cfg:n,store:r}=e,i=Date.now(),a=j(r,t),o=(e,t)=>{let n=te(r,t);if(!n||i>=n)return e;let a=r.usageStats?.[t];return`${e} [${typeof a?.disabledUntil==`number`&&i<a.disabledUntil?`disabled${a.disabledReason?`:${a.disabledReason}`:``}`:`cooldown`} ${ge(n-i)}]`},s=a.map(e=>{let t=r.profiles[e];if(!t)return`${e}=missing`;if(t.type===`api_key`)return o(`${e}=${xn({value:t.key,ref:t.keyRef,kind:`api-key`})}`,e);if(t.type===`token`)return o(`${e}=${xn({value:t.token,ref:t.tokenRef,kind:`token`})}`,e);let i=re({cfg:n,store:r,profileId:e}),a=i===e?``:i.startsWith(e)?i.slice(e.length).trim():`(${i})`;return o(`${e}=OAuth${a?` ${a}`:``}`,e)}),c=a.filter(e=>r.profiles[e]?.type===`oauth`).length,l=a.filter(e=>r.profiles[e]?.type===`token`).length,u=a.filter(e=>r.profiles[e]?.type===`api_key`).length,d=x(t),f=D(n,t),p=T({cfg:n,provider:t});return{provider:t,effective:a.length>0?{kind:`profiles`,detail:F(C())}:d?{kind:`env`,detail:d.source.includes(`OAUTH_TOKEN`)||d.source.toLowerCase().includes(`oauth`)?`OAuth (env)`:R(d.apiKey)}:p?{kind:`models.json`,detail:bn(p.apiKey)}:{kind:`missing`,detail:`missing`},profiles:{count:a.length,oauth:c,token:l,apiKey:u,labels:s},...d?{env:{value:d.source.includes(`OAUTH_TOKEN`)||d.source.toLowerCase().includes(`oauth`)?`OAuth (env)`:R(d.apiKey),source:d.source}}:{},...f?{modelsJson:{value:bn(f),source:`models.json: ${F(e.modelsPath)}`}}:{}}}function Cn(e){return e?e===`auth`||e===`auth_permanent`?`auth`:e===`rate_limit`||e===`overloaded`?`rate_limit`:e===`billing`?`billing`:e===`timeout`?`timeout`:e===`format`?`format`:`unknown`:`unknown`}function wn(e){let t=new Map;for(let n of e){let e=o(String(n??``),S);if(!e)continue;let r=t.get(e.provider)??[];r.includes(e.model)||r.push(e.model),t.set(e.provider,r)}return t}function Tn(e){let{provider:t,candidates:n,catalog:r}=e,i=n.get(t);if(i&&i.length>0)return{provider:t,model:i[0]};let a=r.find(e=>e.provider===t);return a?{provider:a.provider,model:a.id}:null}function En(e){return e===`missing_credential`?`missing_credential`:e===`expired`?`expired`:e===`invalid_expires`?`invalid_expires`:e===`unresolved_ref`?`unresolved_ref`:`ineligible_profile`}function Dn(e){let t=`Auth profile credentials are missing or expired.`;return e===`expired`?`${t}\n↳ Auth reason [expired]: token credentials are expired.`:e===`invalid_expires`?`${t}\n↳ Auth reason [invalid_expires]: token expires must be a positive Unix ms timestamp.`:e===`missing_credential`?`${t}\n↳ Auth reason [missing_credential]: no inline credential or SecretRef is configured.`:e===`unresolved_ref`?`${t}\n↳ Auth reason [unresolved_ref]: configured SecretRef could not be resolved.`:`${t}\n↳ Auth reason [ineligible_profile]: profile is incompatible with provider config.`}function On(e,t){let n=t.secrets?.defaults;return e.type===`api_key`?I(e.key)===void 0?pe(e.keyRef,n):null:e.type===`token`&&I(e.token)===void 0?pe(e.tokenRef,n):null}function kn(e){return`Auth profile credentials are missing or expired.\n↳ Auth reason [unresolved_ref]: could not resolve SecretRef "${e}".`}async function An(e){if(!e.profile)return null;let t=On(e.profile,e.cfg);if(!t)return null;try{return await O(t,{config:e.cfg,env:process.env,cache:e.cache}),null}catch{return{reasonCode:`unresolved_ref`,error:kn(`${t.source}:${t.provider}:${t.id}`)}}}async function jn(e){let{cfg:t,providers:n,modelCandidates:i,options:a}=e,o=m(),s=a.provider?.trim(),c=s?r(s):null,l=new Set((a.profileIds??[]).map(e=>e.trim()).filter(Boolean)),u={},f=await De({config:t}),p=wn(i),h=[],g=[];for(let e of n){let n=r(e);if(c&&n!==c)continue;let i=Tn({provider:n,candidates:p,catalog:f}),a=j(o,n),s=d(o.order,n)??d(t?.auth?.order,n),m=s&&s.length>0?new Set(E({cfg:t,store:o,provider:n})):null,v=l.size?a.filter(e=>l.has(e)):a;if(v.length>0){for(let e of v){let r=o.profiles[e],a=r?.type,c=re({cfg:t,store:o,profileId:e});if(s&&!s.includes(e)){g.push({provider:n,profileId:e,model:i?`${i.provider}/${i.model}`:void 0,label:c,source:`profile`,mode:a,status:`unknown`,reasonCode:`excluded_by_auth_order`,error:`Excluded by auth.order for this provider.`});continue}if(m&&!m.has(e)){let r=En(ne({cfg:t,store:o,provider:n,profileId:e}).reasonCode);g.push({provider:n,model:i?`${i.provider}/${i.model}`:void 0,profileId:e,label:c,source:`profile`,mode:a,status:`unknown`,reasonCode:r,error:Dn(r)});continue}let l=await An({cfg:t,profile:r,cache:u});if(l){g.push({provider:n,model:i?`${i.provider}/${i.model}`:void 0,profileId:e,label:c,source:`profile`,mode:a,status:`unknown`,reasonCode:l.reasonCode,error:l.error});continue}if(!i){g.push({provider:n,model:void 0,profileId:e,label:c,source:`profile`,mode:a,status:`no_model`,reasonCode:`no_model`,error:`No model available for probe`});continue}h.push({provider:n,model:i,profileId:e,label:c,source:`profile`,mode:a})}continue}if(l.size>0)continue;let y=x(n),b=_(t,n);if(!y&&!b)continue;let S=y?`env`:`models.json`,ee=y?`env`:`models.json`,C=y?.source.includes(`OAUTH_TOKEN`)?`oauth`:`api_key`;if(!i){g.push({provider:n,model:void 0,label:S,source:ee,mode:C,status:`no_model`,reasonCode:`no_model`,error:`No model available for probe`});continue}h.push({provider:n,model:i,label:S,source:ee,mode:C})}return{targets:h,results:g}}async function Mn(e){let{cfg:t,agentId:n,agentDir:r,workspaceDir:i,sessionDir:a,target:o,timeoutMs:s,maxTokens:c}=e;if(!o.model)return{provider:o.provider,model:void 0,profileId:o.profileId,label:o.label,source:o.source,mode:o.mode,status:`no_model`,reasonCode:`no_model`,error:`No model available for probe`};let l=`probe-${o.provider}-${it.randomUUID()}`,u=Ce(l,n);await rt.mkdir(a,{recursive:!0});let d=Date.now();try{return await _e({sessionId:l,sessionFile:u,agentId:n,workspaceDir:i,agentDir:r,config:t,prompt:`Reply with OK. Do not use tools.`,provider:o.model.provider,model:o.model.model,authProfileId:o.profileId,authProfileIdSource:o.profileId?`user`:void 0,timeoutMs:s,runId:`probe-${it.randomUUID()}`,lane:`auth-probe:${o.provider}:${o.profileId??o.source}`,thinkLevel:`off`,reasoningLevel:`off`,verboseLevel:`off`,streamParams:{maxTokens:c}}),{provider:o.provider,model:`${o.model.provider}/${o.model.model}`,profileId:o.profileId,label:o.label,source:o.source,mode:o.mode,status:`ok`,latencyMs:Date.now()-d}}catch(e){let t=he(e);return{provider:o.provider,model:`${o.model.provider}/${o.model.model}`,profileId:o.profileId,label:o.label,source:o.source,mode:o.mode,status:Cn(t.reason),error:W(t.message),latencyMs:Date.now()-d}}}async function Nn(e){let{cfg:t,targets:n,timeoutMs:r,maxTokens:i,onProgress:a}=e,o=Math.max(1,Math.min(n.length||1,e.concurrency)),s=ce(t),l=c(),u=se(t,s)??le(),d=we(s);await rt.mkdir(u,{recursive:!0});let f=0,p=Array.from({length:n.length}),m=0,h=async()=>{for(;;){let e=m;if(m+=1,e>=n.length)return;let o=n[e];a?.({completed:f,total:n.length,label:`Probing ${o.provider}${o.profileId?` (${o.label})`:``}`}),p[e]=await Mn({cfg:t,agentId:s,agentDir:l,workspaceDir:u,sessionDir:d,target:o,timeoutMs:r,maxTokens:i}),f+=1,a?.({completed:f,total:n.length})}};return await Promise.all(Array.from({length:o},()=>h())),p.filter(e=>!!e)}async function Pn(e){let t=Date.now(),n=await jn({cfg:e.cfg,providers:e.providers,modelCandidates:e.modelCandidates,options:e.options}),r=n.targets.length;e.onProgress?.({completed:0,total:r});let i=r?await Nn({cfg:e.cfg,targets:n.targets,timeoutMs:e.options.timeoutMs,maxTokens:e.options.maxTokens,concurrency:e.options.concurrency,onProgress:e.onProgress}):[],a=Date.now();return{startedAt:t,finishedAt:a,durationMs:a-t,totalTargets:r,options:e.options,results:[...n.results,...i]}}function Fn(e){return!e&&e!==0?`-`:G(e)}function In(e){return e.slice().toSorted((e,t)=>{let n=e.provider.localeCompare(t.provider);if(n!==0)return n;let r=e.label||e.profileId||``,i=t.label||t.profileId||``;return r.localeCompare(i)})}function Ln(e){return e.totalTargets===0?`No probe targets.`:`Probed ${e.totalTargets} target${e.totalTargets===1?``:`s`} in ${G(e.durationMs)}`}async function Rn(n,r){if(Le(n),n.plain&&n.probe)throw Error(`--probe cannot be used with --plain output.`);let i=l().configPath,a=await Y({commandName:`models status`,runtime:r}),d=Fe({cfg:a,rawAgentId:n.agent}),f=d?oe(a,d):c(),p=d?de(a,d):void 0,_=d?ue(a,d):void 0,v=d?h({cfg:a,agentId:d}):g({cfg:a,defaultProvider:S,defaultModel:y}),b=P(a.agents?.defaults?.model)??``,w=p??b,T=`${v.provider}/${v.model}`,ne=w||T,re=N(a.agents?.defaults?.model),E=_??re,D=P(a.agents?.defaults?.imageModel)??``,O=N(a.agents?.defaults?.imageModel),k=Object.entries(a.agents?.defaults?.models??{}).reduce((e,[t,n])=>{let r=typeof n?.alias==`string`?n.alias.trim():void 0;return r&&(e[r]=t),e},{}),A=Object.keys(a.agents?.defaults?.models??{}),j=m(f),ae=nt.join(f,`models.json`),se=new Set(Object.values(j.profiles).map(e=>e.provider).filter(e=>!!e)),ce=new Set(Object.keys(a.models?.providers??{}).map(e=>typeof e==`string`?e.trim():``).filter(Boolean)),le=new Set,fe=new Set;for(let e of[ne,...E,D,...O,...A]){let t=o(String(e??``),S);t?.provider&&le.add(t.provider)}for(let e of[ne,...E,D,...O]){let t=o(String(e??``),S);t?.provider&&fe.add(t.provider)}let pe=new Set;for(let e of[`anthropic`,`github-copilot`,`google-vertex`,`openai`,`google`,`groq`,`cerebras`,`xai`,`openrouter`,`zai`,`mistral`,`synthetic`])x(e)&&pe.add(e);let I=Array.from(new Set([...se,...ce,...le,...pe])).map(e=>typeof e==`string`?e.trim():``).filter(Boolean).toSorted((e,t)=>e.localeCompare(t)),me=ee(),he=ie(process.env)||a.env?.shellEnv?.enabled===!0,L=I.map(e=>Sn({provider:e,cfg:a,store:j,modelsPath:ae})).filter(e=>e.profiles.count>0||!!e.env||!!e.modelsJson),_e=new Map(L.map(e=>[e.provider,e])),R=Array.from(fe).filter(e=>!_e.has(e)).toSorted((e,t)=>e.localeCompare(t)),Ce=n.probeProfile?(Array.isArray(n.probeProfile)?n.probeProfile:[n.probeProfile]).flatMap(e=>String(e??``).split(`,`)).map(e=>e.trim()).filter(Boolean):[],we=n.probeTimeout?Number(n.probeTimeout):8e3;if(!Number.isFinite(we)||we<=0)throw Error(`--probe-timeout must be a positive number (ms).`);let Te=n.probeConcurrency?Number(n.probeConcurrency):2;if(!Number.isFinite(Te)||Te<=0)throw Error(`--probe-concurrency must be > 0.`);let Ee=n.probeMaxTokens?Number(n.probeMaxTokens):8;if(!Number.isFinite(Ee)||Ee<=0)throw Error(`--probe-max-tokens must be > 0.`);let De=s({cfg:a,defaultProvider:S}),Oe=[w||T,...E,D,...O,...A].filter(Boolean).map(e=>u({raw:String(e??``),defaultProvider:S,aliasIndex:De})?.ref).filter(e=>!!e).map(e=>`${e.provider}/${e.model}`),z;n.probe&&(z=await Ae({label:`Probing auth profiles…`,total:1},async e=>await Pn({cfg:a,providers:I,modelCandidates:Oe,options:{provider:n.probeProvider,profileIds:Ce,timeoutMs:we,concurrency:Te,maxTokens:Ee},onProgress:e})));let B=L.filter(e=>e.profiles.oauth>0||e.profiles.token>0||e.env?.value===`OAuth (env)`).map(e=>{let t=e.profiles.oauth+e.profiles.token+(e.env?.value===`OAuth (env)`?1:0);return`${e.provider} (${t})`}),V=be({store:j,cfg:a,warnAfterMs:Se,providers:I}),H=V.profiles.filter(e=>e.type===`oauth`||e.type===`token`),ke=(()=>{let e=Date.now(),t=[];for(let n of Object.keys(j.usageStats??{})){let r=te(j,n);if(!r||e>=r)continue;let i=j.usageStats?.[n],a=typeof i?.disabledUntil==`number`&&e<i.disabledUntil?`disabled`:`cooldown`;t.push({profileId:n,provider:j.profiles[n]?.provider,kind:a,reason:i?.disabledReason,until:r,remainingMs:r-e})}return t.toSorted((e,t)=>e.remainingMs-t.remainingMs)})(),je=(()=>{let e=H.some(e=>[`expired`,`missing`].includes(e.status))||R.length>0,t=H.some(e=>e.status===`expiring`);return e?1:t?2:0})();if(n.json){r.log(JSON.stringify({configPath:i,...d?{agentId:d}:{},agentDir:f,defaultModel:ne,resolvedDefault:T,fallbacks:E,imageModel:D||null,imageFallbacks:O,...d?{modelConfig:{defaultSource:p?`agent`:`defaults`,fallbacksSource:_===void 0?`defaults`:`agent`}}:{},aliases:k,allowed:A,auth:{storePath:C(f),shellEnvFallback:{enabled:he,appliedKeys:me},providersWithOAuth:B,missingProvidersInUse:R,providers:L,unusableProfiles:ke,oauth:{warnAfterMs:V.warnAfterMs,profiles:V.profiles,providers:V.providers},probes:z}},null,2)),n.check&&r.exit(je);return}if(n.plain){r.log(T),n.check&&r.exit(je);return}let U=hn(n),W=n=>t(U,e.accent,n.padEnd(14)),G=(e,t)=>W(t?`${e} (${t})`:e),Pe=w&&w!==T?`${T} (from ${w})`:T;r.log(`${W(`Config`)}${t(U,e.muted,`:`)} ${t(U,e.info,F(i))}`),r.log(`${W(`Agent dir`)}${t(U,e.muted,`:`)} ${t(U,e.info,F(f))}`),r.log(`${G(`Default`,d?p?`agent`:`defaults`:void 0)}${t(U,e.muted,`:`)} ${t(U,e.success,Pe)}`),r.log(`${G(`Fallbacks (${E.length||0})`,d?_===void 0?`defaults`:`agent`:void 0)}${t(U,e.muted,`:`)} ${t(U,E.length?e.warn:e.muted,E.length?E.join(`, `):`-`)}`),r.log(`${G(`Image model`,d?`defaults`:void 0)}${t(U,e.muted,`:`)} ${t(U,D?e.accentBright:e.muted,D||`-`)}`),r.log(`${G(`Image fallbacks (${O.length||0})`,d?`defaults`:void 0)}${t(U,e.muted,`:`)} ${t(U,O.length?e.accentBright:e.muted,O.length?O.join(`, `):`-`)}`),r.log(`${W(`Aliases (${Object.keys(k).length||0})`)}${t(U,e.muted,`:`)} ${t(U,Object.keys(k).length?e.accent:e.muted,Object.keys(k).length?Object.entries(k).map(([t,n])=>U?`${e.accentDim(t)} ${e.muted(`->`)} ${e.info(n)}`:`${t} -> ${n}`).join(`, `):`-`)}`),r.log(`${W(`Configured models (${A.length||0})`)}${t(U,e.muted,`:`)} ${t(U,A.length?e.info:e.muted,A.length?A.join(`, `):`all`)}`),r.log(``),r.log(t(U,e.heading,`Auth overview`)),r.log(`${W(`Auth store`)}${t(U,e.muted,`:`)} ${t(U,e.info,F(C(f)))}`),r.log(`${W(`Shell env`)}${t(U,e.muted,`:`)} ${t(U,he?e.success:e.muted,he?`on`:`off`)}${me.length?t(U,e.muted,` (applied: ${me.join(`, `)})`):``}`),r.log(`${W(`Providers w/ OAuth/tokens (${B.length||0})`)}${t(U,e.muted,`:`)} ${t(U,B.length?e.info:e.muted,B.length?B.join(`, `):`-`)}`);let Ie=n=>t(U,e.warn,n),K=(n,r)=>`${Ie(n)}=${t(U,e.info,r)}`,q=()=>t(U,e.muted,` | `);for(let n of L){let i=q(),a=[];a.push(K(`effective`,`${t(U,e.accentBright,n.effective.kind)}:${t(U,e.muted,n.effective.detail)}`)),n.profiles.count>0&&(a.push(K(`profiles`,`${n.profiles.count} (oauth=${n.profiles.oauth}, token=${n.profiles.token}, api_key=${n.profiles.apiKey})`)),n.profiles.labels.length>0&&a.push(t(U,e.info,n.profiles.labels.join(`, `)))),n.env&&a.push(K(`env`,`${n.env.value}${i}${K(`source`,n.env.source)}`)),n.modelsJson&&a.push(K(`models.json`,`${n.modelsJson.value}${i}${K(`source`,n.modelsJson.source)}`)),r.log(`- ${e.heading(n.provider)} ${a.join(i)}`)}if(R.length>0){r.log(``),r.log(t(U,e.heading,`Missing auth`));for(let t of R){let n=t===`anthropic`?`Run \`claude setup-token\`, then \`${M(`openclaw models auth setup-token`)}\` or \`${M(`openclaw configure`)}\`.`:`Run \`${M(`openclaw configure`)}\` or set an API key env var.`;r.log(`- ${e.heading(t)} ${n}`)}}if(r.log(``),r.log(t(U,e.heading,`OAuth/token status`)),H.length===0)r.log(t(U,e.muted,`- none`));else{let n=new Map,i=Array.from(new Set(H.map(e=>ye(e.provider)).filter(e=>!!e)));if(i.length>0)try{let e=await ve({providers:i,agentDir:f,timeoutMs:3500});for(let t of e.providers){let e=xe(t,{now:Date.now(),maxWindows:2,includeResets:!0});e&&n.set(t.provider,e)}}catch{}let a=n=>n===`ok`?t(U,e.success,`ok`):n===`static`?t(U,e.muted,`static`):n===`expiring`?t(U,e.warn,`expiring`):n===`missing`?t(U,e.warn,`unknown`):t(U,e.error,`expired`),o=new Map;for(let e of H){let t=o.get(e.provider);t?t.push(e):o.set(e.provider,[e])}for(let[i,s]of o){let o=ye(i),c=o?n.get(o):void 0,l=c?t(U,e.muted,` usage: ${c}`):``;r.log(`- ${t(U,e.heading,i)}${l}`);for(let n of s){let i=n.label||n.profileId,o=t(U,e.accent,i),s=a(n.status),c=n.status===`static`?``:n.expiresAt?` expires in ${ge(n.remainingMs)}`:` expires unknown`;r.log(` - ${o} ${s}${c}`)}}}if(z)if(r.log(``),r.log(t(U,e.heading,`Auth probes`)),z.results.length===0)r.log(t(U,e.muted,`- none`));else{let n=Ne(),i=In(z.results),a=t=>t===`ok`?e.success:t===`rate_limit`||t===`timeout`||t===`billing`?e.warn:t===`auth`||t===`format`?e.error:e.muted,o=i.map(n=>{let r=t(U,a(n.status),n.status),i=Fn(n.latencyMs),o=n.model??`${n.provider}/-`,s=n.mode?` ${t(U,e.muted,`(${n.mode})`)}`:``,c=`${t(U,e.accent,n.label)}${s}`,l=n.error?.trim(),u=l?`\n${t(U,e.muted,`↳ ${l}`)}`:``,d=`${r}${t(U,e.muted,` · ${i}`)}${u}`;return{Model:t(U,e.heading,o),Profile:c,Status:d}});r.log(Me({width:n,columns:[{key:`Model`,header:`Model`,minWidth:18},{key:`Profile`,header:`Profile`,minWidth:24},{key:`Status`,header:`Status`,minWidth:12}],rows:o}).trimEnd()),r.log(t(U,e.muted,Ln(z)))}n.check&&r.exit(je)}const zn={name:`ping`,description:`Return OK.`,parameters:ct.Object({})};function Bn(e){return typeof e!=`number`||!Number.isFinite(e)||e<=0?null:e>0xe8d4a51000?Math.round(e):Math.round(e*1e3)}function Vn(e){return e&&e.toLowerCase().split(/[^a-z]+/).filter(Boolean).includes(`image`)?[`text`,`image`]:[`text`]}function $(e){if(typeof e==`number`&&Number.isFinite(e))return e;if(typeof e!=`string`)return null;let t=e.trim();if(!t)return null;let n=Number(t);return Number.isFinite(n)?n:null}function Hn(e){if(!e||typeof e!=`object`)return null;let t=e,n=$(t.prompt),r=$(t.completion),i=$(t.request)??0,a=$(t.image)??0,o=$(t.web_search)??0,s=$(t.internal_reasoning)??0;return n===null||r===null?null:{prompt:n,completion:r,request:i,image:a,webSearch:o,internalReasoning:s}}function Un(e){return e.id.endsWith(`:free`)?!0:e.pricing?e.pricing.prompt===0&&e.pricing.completion===0:!1}async function Wn(e,t){let n=new AbortController,r=setTimeout(n.abort.bind(n),e);try{return await t(n.signal)}finally{clearTimeout(r)}}async function Gn(e){let t=await e(`https://openrouter.ai/api/v1/models`,{headers:{Accept:`application/json`}});if(!t.ok)throw Error(`OpenRouter /models failed: HTTP ${t.status}`);let n=await t.json();return(Array.isArray(n.data)?n.data:[]).map(e=>{if(!e||typeof e!=`object`)return null;let t=e,n=typeof t.id==`string`?t.id.trim():``;if(!n)return null;let r=typeof t.name==`string`&&t.name.trim()?t.name.trim():n,i=typeof t.context_length==`number`&&Number.isFinite(t.context_length)?t.context_length:null,a=typeof t.max_completion_tokens==`number`&&Number.isFinite(t.max_completion_tokens)?t.max_completion_tokens:typeof t.max_output_tokens==`number`&&Number.isFinite(t.max_output_tokens)?t.max_output_tokens:null,o=Array.isArray(t.supported_parameters)?t.supported_parameters.filter(e=>typeof e==`string`).map(e=>e.trim()).filter(Boolean):[];return{id:n,name:r,contextLength:i,maxCompletionTokens:a,supportedParameters:o,supportedParametersCount:o.length,supportsToolsMeta:o.includes(`tools`),modality:typeof t.modality==`string`&&t.modality.trim()?t.modality.trim():null,inferredParamB:U(`${n} ${r}`),createdAtMs:Bn(t.created_at),pricing:Hn(t.pricing)}}).filter(e=>!!e)}async function Kn(e,t,n){let r={messages:[{role:`user`,content:`Call the ping tool with {} and nothing else.`,timestamp:Date.now()}],tools:[zn]},i=Date.now();try{return(await Wn(n,n=>at(e,r,{apiKey:t,maxTokens:256,temperature:0,toolChoice:`required`,signal:n}))).content.some(e=>e.type===`toolCall`)?{ok:!0,latencyMs:Date.now()-i}:{ok:!1,latencyMs:Date.now()-i,error:`No tool call returned`}}catch(e){return{ok:!1,latencyMs:Date.now()-i,error:e instanceof Error?e.message:String(e)}}}async function qn(e,t,n){let r={messages:[{role:`user`,content:[{type:`text`,text:`Reply with OK.`},{type:`image`,data:`iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mP8/x8AAwMCAO+X3mIAAAAASUVORK5CYII=`,mimeType:`image/png`}],timestamp:Date.now()}]},i=Date.now();try{return await Wn(n,n=>at(e,r,{apiKey:t,maxTokens:16,temperature:0,signal:n})),{ok:!0,latencyMs:Date.now()-i}}catch(e){return{ok:!1,latencyMs:Date.now()-i,error:e instanceof Error?e.message:String(e)}}}function Jn(e){return e.input?.includes(`image`)?e:{...e,input:Array.from(new Set([...e.input??[],`image`]))}}function Yn(e){let{entry:t,isFree:n}=e;return{id:t.id,name:t.name,provider:`openrouter`,modelRef:`openrouter/${t.id}`,contextLength:t.contextLength,maxCompletionTokens:t.maxCompletionTokens,supportedParametersCount:t.supportedParametersCount,supportsToolsMeta:t.supportsToolsMeta,modality:t.modality,inferredParamB:t.inferredParamB,createdAtMs:t.createdAtMs,pricing:t.pricing,isFree:n,tool:e.tool,image:e.image}}async function Xn(e,t,n,r){let i=Math.max(1,Math.floor(t)),a=Array.from({length:e.length},()=>void 0),o=0,s=0,c=async()=>{for(;;){let t=o;if(o+=1,t>=e.length)return;a[t]=await n(e[t],t),s+=1,r?.onProgress?.(s,e.length)}};return e.length===0?(r?.onProgress?.(0,0),a):(await Promise.all(Array.from({length:Math.min(i,e.length)},()=>c())),a)}async function Zn(e={}){let t=e.fetchImpl??fetch,n=e.probe??!0,r=e.apiKey?.trim()||ot(`openrouter`)||``;if(n&&!r)throw Error(`Missing OpenRouter API key. Set OPENROUTER_API_KEY to run models scan.`);let i=Math.max(1,Math.floor(e.timeoutMs??12e3)),a=Math.max(1,Math.floor(e.concurrency??3)),o=Math.max(0,Math.floor(e.minParamB??0)),s=Math.max(0,Math.floor(e.maxAgeDays??0)),c=e.providerFilter?.trim().toLowerCase()??``,l=await Gn(t),u=Date.now(),d=l.filter(e=>!(!Un(e)||c&&(e.id.split(`/`)[0]?.toLowerCase()??``)!==c||o>0&&(e.inferredParamB??0)<o||s>0&&e.createdAtMs&&(u-e.createdAtMs)/(1440*60*1e3)>s)),f=st(`openrouter`,`openrouter/auto`);return e.onProgress?.({phase:`probe`,completed:0,total:d.length}),Xn(d,a,async e=>{let t=Un(e);if(!n)return Yn({entry:e,isFree:t,tool:{ok:!1,latencyMs:null,skipped:!0},image:{ok:!1,latencyMs:null,skipped:!0}});let a={...f,id:e.id,name:e.name||e.id,contextWindow:e.contextLength??f.contextWindow,maxTokens:e.maxCompletionTokens??f.maxTokens,input:Vn(e.modality),reasoning:f.reasoning};return Yn({entry:e,isFree:t,tool:await Kn(a,r,i),image:a.input?.includes(`image`)?await qn(Jn(a),r,i):{ok:!1,latencyMs:null,skipped:!0}})},{onProgress:(t,n)=>e.onProgress?.({phase:`probe`,completed:t,total:n})})}const Qn=e=>ft({...e,message:V(e.message),options:e.options.map(e=>e.hint===void 0?e:{...e,hint:ke(e.hint)})});function $n(e,t){if(dt(e))throw lt(H(`Model scan cancelled.`)??`Model scan cancelled.`),t.exit(0),Error(`unreachable`);return e}function er(e){return e.slice().toSorted((e,t)=>{let n=e.image.ok?1:0,r=t.image.ok?1:0;if(n!==r)return r-n;let i=e.tool.latencyMs??1/0,a=t.tool.latencyMs??1/0;return i===a?nr(e,t):i-a})}function tr(e){return e.slice().toSorted((e,t)=>{let n=e.image.latencyMs??1/0,r=t.image.latencyMs??1/0;return n===r?nr(e,t):n-r})}function nr(e,t){let n=e.contextLength??0,r=t.contextLength??0;if(n!==r)return r-n;let i=e.inferredParamB??0,a=t.inferredParamB??0;return i===a?e.modelRef.localeCompare(t.modelRef):a-i}function rr(e){return[e.tool.ok?`tool ${G(e.tool.latencyMs)}`:`tool fail`,e.image.skipped?`img skip`:e.image.ok?`img ${G(e.image.latencyMs)}`:`img fail`,e.contextLength?`ctx ${ze(e.contextLength)}`:`ctx ?`,e.inferredParamB?`${e.inferredParamB}b`:null].filter(Boolean).join(` | `)}function ir(e,t){let n=e.filter(e=>e.tool.ok),r=e.filter(e=>e.image.ok),i=e.filter(e=>e.tool.ok&&e.image.ok),a=r.filter(e=>!e.tool.ok);t.log(`Scan results: tested ${e.length}, tool ok ${n.length}, image ok ${r.length}, tool+image ok ${i.length}, image only ${a.length}`)}function ar(e,t){let n=[Q(`Model`,42),Q(`Tool`,10),Q(`Image`,10),Q(`Ctx`,8),Q(`Params`,8),`Notes`].join(` `);t.log(n);for(let n of e){let e=Q(_n(n.modelRef,42),42),r=Q(n.tool.ok?G(n.tool.latencyMs):`fail`,10),i=Q(n.image.ok?G(n.image.latencyMs):n.image.skipped?`skip`:`fail`,10),a=Q(ze(n.contextLength),8),o=Q(n.inferredParamB?`${n.inferredParamB}b`:`-`,8),s=n.modality?`modality:${n.modality}`:``;t.log([e,r,i,a,o,s].join(` `))}}async function or(e,t){let n=e.minParams?Number(e.minParams):void 0;if(n!==void 0&&(!Number.isFinite(n)||n<0))throw Error(`--min-params must be >= 0`);let r=e.maxAgeDays?Number(e.maxAgeDays):void 0;if(r!==void 0&&(!Number.isFinite(r)||r<0))throw Error(`--max-age-days must be >= 0`);let i=e.maxCandidates?Number(e.maxCandidates):6;if(!Number.isFinite(i)||i<=0)throw Error(`--max-candidates must be > 0`);let a=e.timeout?Number(e.timeout):void 0;if(a!==void 0&&(!Number.isFinite(a)||a<=0))throw Error(`--timeout must be > 0`);let o=e.concurrency?Number(e.concurrency):void 0;if(o!==void 0&&(!Number.isFinite(o)||o<=0))throw Error(`--concurrency must be > 0`);let s=await Y({commandName:`models scan`,runtime:t}),c=e.probe??!0,l;if(c)try{l=(await k({provider:`openrouter`,cfg:s})).apiKey}catch{l=void 0}let u=await Ae({label:`Scanning OpenRouter models...`,indeterminate:!1,enabled:e.json!==!0},async t=>await Zn({apiKey:l??void 0,minParamB:n,maxAgeDays:r,providerFilter:e.provider,timeoutMs:a,concurrency:o,probe:c,onProgress:({phase:e,completed:n,total:r})=>{e===`probe`&&t({completed:n,total:r,label:`${c?`Probing models`:`Scanning models`} (${n}/${r})`})}}));if(!c){e.json?t.log(JSON.stringify(u,null,2)):(t.log(`Found ${u.length} OpenRouter free models (metadata only; pass --probe to test tools/images).`),ar(er(u),t));return}let d=u.filter(e=>e.tool.ok);if(d.length===0)throw Error(`No tool-capable OpenRouter free models found.`);let f=er(u),p=er(d),m=tr(u.filter(e=>e.image.ok)),h=p.filter(e=>e.image.ok),g=(h.length>0?h:p).slice(0,Math.floor(i)).map(e=>e.modelRef),_=m.slice(0,Math.floor(i)).map(e=>e.modelRef);e.json||(ir(u,t),ar(f,t));let v=e.input===!1,y=process.stdin.isTTY&&!e.yes&&!v&&!e.json,b=g,x=_;if(y)b=$n(await Qn({message:`Select fallback models (ordered)`,options:p.map(e=>({value:e.modelRef,label:e.modelRef,hint:rr(e)})),initialValues:g}),t),m.length>0&&(x=$n(await Qn({message:`Select image fallback models (ordered)`,options:m.map(e=>({value:e.modelRef,label:e.modelRef,hint:rr(e)})),initialValues:_}),t));else if(!process.stdin.isTTY&&!e.yes&&!v&&!e.json)throw Error(`Non-interactive scan: pass --yes to apply defaults.`);if(b.length===0)throw Error(`No models selected for fallbacks.`);if(e.setImage&&x.length===0)throw Error(`No image-capable models selected for image model.`);if(await q(t=>{let n={...t.agents?.defaults?.models};for(let e of b)n[e]||(n[e]={});for(let e of x)n[e]||(n[e]={});let r=ae(t.agents?.defaults?.imageModel),i=x.length>0?{...r?.primary?{primary:r.primary}:void 0,fallbacks:x,...e.setImage?{primary:x[0]}:{}}:t.agents?.defaults?.imageModel,a=ae(t.agents?.defaults?.model),o={...t.agents?.defaults,model:{...a?.primary?{primary:a.primary}:void 0,fallbacks:b,...e.setDefault?{primary:b[0]}:{}},...i?{imageModel:i}:{},models:n};return{...t,agents:{...t.agents,defaults:o}}}),e.json){t.log(JSON.stringify({selected:b,selectedImages:x,setDefault:!!e.setDefault,setImage:!!e.setImage,results:u,warnings:[]},null,2));return}J(t),t.log(`Fallbacks: ${b.join(`, `)}`),x.length>0&&t.log(`Image fallbacks: ${x.join(`, `)}`),e.setDefault&&t.log(`Default model: ${b[0]}`),e.setImage&&x.length>0&&t.log(`Image model: ${x[0]}`)}async function sr(e,t){let n=await q(t=>Ve({cfg:t,modelRaw:e,field:`model`}));J(t),t.log(`Default model: ${P(n.agents?.defaults?.model)??e}`)}async function cr(e,t){let n=await q(t=>Ve({cfg:t,modelRaw:e,field:`imageModel`}));J(t),t.log(`Image model: ${P(n.agents?.defaults?.imageModel)??e}`)}export{Et as _,Xt as a,_t as b,Wt as c,Gt as d,It as f,jt as g,Dt as h,Jt as i,Kt as l,Lt as m,yn as modelsListCommand,Rn as modelsStatusCommand,sr as n,qt as o,Ft as p,or as r,Yt as s,cr as t,Ut as u,Tt as v,yt as x,vt as y};