@termix-it/cryptoclaw 1.0.6 → 1.0.8

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 (330) hide show
  1. package/README.md +119 -116
  2. package/dist/{accounts-Bod7973i.js → accounts-CucAhPu5.js} +7 -7
  3. package/dist/{accounts-BSIXwC37.js → accounts-DarjcXFz.js} +1 -1
  4. package/dist/{accounts-D3YOECeq.js → accounts-DjUjM_0M.js} +1 -1
  5. package/dist/{acp-cli-CGC73qiP.js → acp-cli-BKEdLWJH.js} +8 -8
  6. package/dist/{agent-scope-BGsA4zEf.js → agent-scope-C5bklqr1.js} +17 -17
  7. package/dist/{agents-SpePW-me.js → agents-C26D9541.js} +14 -14
  8. package/dist/{agents.config-g0LyahNR.js → agents.config-BSkzwDQZ.js} +2 -2
  9. package/dist/{api-key-rotation-BoN0bfDN.js → api-key-rotation-DUAhkuoF.js} +1 -1
  10. package/dist/{audio-preflight-CN6L8zsG.js → audio-preflight-DFpELnh5.js} +34 -34
  11. package/dist/{audio-transcription-runner-D6NSiBUN.js → audio-transcription-runner-C1T1UDgG.js} +23 -23
  12. package/dist/{audit-C3kgCKKq.js → audit-BJ5b9jj6.js} +29 -29
  13. package/dist/{auth-BQOIUcK5.js → auth-CgV_wGar.js} +1 -1
  14. package/dist/{auth-choice-ClGYfSky.js → auth-choice-DG-39eTP.js} +13 -13
  15. package/dist/{auth-choice-pU5ch2o1.js → auth-choice-tnRPpsDE.js} +11 -11
  16. package/dist/{auth-choice.apply-helpers-BF8uDNAl.js → auth-choice.apply-helpers-DAj6Co-H.js} +1 -1
  17. package/dist/{auth-profiles-yB_p54Kf.js → auth-profiles-CtYlKXxI.js} +16 -16
  18. package/dist/{auth-token-C_wfhGFh.js → auth-token-Ijqjdh1h.js} +1 -1
  19. package/dist/{banner-C01HhkYN.js → banner-CY1oW10M.js} +2 -2
  20. package/dist/{bonjour-discovery-DRbbMuPV.js → bonjour-discovery-ttcR8uJV.js} +1 -1
  21. package/dist/{browser-cli-t5Ko46IP.js → browser-cli-DosaTN2z.js} +12 -12
  22. package/dist/build-info.json +3 -3
  23. package/dist/{call-CeJbHmC5.js → call-BHrnZxI1.js} +10 -10
  24. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  25. package/dist/{channel-account-context-CZg6xYM_.js → channel-account-context-BjsJwBrl.js} +5 -5
  26. package/dist/{channel-activity-CtUzm0zi.js → channel-activity-CudRDPXk.js} +1 -1
  27. package/dist/{channel-options-DKP2et7c.js → channel-options-DRQo8X5b.js} +3 -3
  28. package/dist/{channel-selection-BGFLNPuZ.js → channel-selection-D2KncGab.js} +1 -1
  29. package/dist/{channel-web-CjBStv9j.js → channel-web-BxqW0jAU.js} +17 -17
  30. package/dist/{channels-cli-B7QQDJC8.js → channels-cli-BgpYg0HG.js} +93 -93
  31. package/dist/{channels-status-issues-UpBSKB6j.js → channels-status-issues-JgPH8x7b.js} +1 -1
  32. package/dist/{chrome-NrlBIdcn.js → chrome-m5f8q2YK.js} +4 -4
  33. package/dist/{clawbot-cli-fmA08wJd.js → clawbot-cli-CrkYNKVe.js} +11 -11
  34. package/dist/cli/daemon-cli.js +1 -1
  35. package/dist/{cli-DO7xcifm.js → cli-2paqSkPz.js} +73 -73
  36. package/dist/{client-Kkj2aHgb.js → client-BqLxmdBY.js} +2 -2
  37. package/dist/{command-registry-Ckb_NblW.js → command-registry-C3IdEOLg.js} +11 -11
  38. package/dist/{command-secret-targets-CVAt80vu.js → command-secret-targets-_FGz0zdz.js} +4 -4
  39. package/dist/{commands-BYuioJO3.js → commands-CP-eujrx.js} +1 -1
  40. package/dist/{commands-registry-DCOqmmUF.js → commands-registry-BxWE_gts.js} +3 -3
  41. package/dist/{completion-cli-3DXayCwj.js → completion-cli-D_Hp6T_X.js} +13 -13
  42. package/dist/{config-cli-DDe7yEGq.js → config-cli-DLVXpjXN.js} +7 -7
  43. package/dist/{config-guard-DpzGAFpd.js → config-guard-D9yUiM86.js} +3 -3
  44. package/dist/{config-validation-BS6k_44h.js → config-validation-C-plaBVT.js} +3 -3
  45. package/dist/{configure-M4LELgRU.js → configure-idrmyczj.js} +17 -17
  46. package/dist/{control-ui-assets-CYQNSPY0.js → control-ui-assets-1CYoFkJQ.js} +1 -1
  47. package/dist/{cron-cli-C0tDGxo5.js → cron-cli-CxAxkYel.js} +11 -11
  48. package/dist/{daemon-cli-D7rQUQZq.js → daemon-cli-Bntp6emS.js} +15 -15
  49. package/dist/{daemon-install-C_ygPena.js → daemon-install-LNixC8Pb.js} +4 -4
  50. package/dist/{daemon-install-helpers-so86sfkZ.js → daemon-install-helpers-CyjpUUrm.js} +11 -11
  51. package/dist/{deliver-Bh8OdZ9H.js → deliver-HkPDAwY2.js} +7 -7
  52. package/dist/deliver-runtime-B5yIMxQR.js +61 -0
  53. package/dist/deps-send-discord.runtime-sLYAyx_-.js +36 -0
  54. package/dist/deps-send-imessage.runtime-2cWGJS5r.js +35 -0
  55. package/dist/deps-send-signal.runtime-kNxDQhbE.js +34 -0
  56. package/dist/deps-send-slack.runtime-D3QFxyKO.js +32 -0
  57. package/dist/{deps-send-telegram.runtime-DhLKcoGf.js → deps-send-telegram.runtime-DUo2GPb7.js} +16 -16
  58. package/dist/deps-send-whatsapp.runtime-CHgCReeR.js +119 -0
  59. package/dist/{devices-cli-DKERiq8E.js → devices-cli-DDu3iEJN.js} +8 -8
  60. package/dist/{diagnostic-Dp-KkeSq.js → diagnostic-3zN7XEY1.js} +1 -1
  61. package/dist/{diagnostics-Cuvdgf7E.js → diagnostics-Dys24A-s.js} +5 -5
  62. package/dist/{directory-cli-DFN_WTag.js → directory-cli-BgL_9wd5.js} +7 -7
  63. package/dist/{dns-cli-DO8cd5zZ.js → dns-cli-B0zPrZBi.js} +5 -5
  64. package/dist/{dock-DjC0vgOm.js → dock-BaM5oTqE.js} +4 -4
  65. package/dist/{docs-cli-GcB4tM-4.js → docs-cli-4R8XltvA.js} +4 -4
  66. package/dist/{doctor-completion-3P8WMHdK.js → doctor-completion-5TLzN3Se.js} +2 -2
  67. package/dist/{doctor-config-flow-WQpcISHd.js → doctor-config-flow-DWHPUDqY.js} +15 -15
  68. package/dist/{enable-Di6fjV84.js → enable-BP58hyxE.js} +1 -1
  69. package/dist/entry.js +2 -2
  70. package/dist/{exec-approvals-allowlist-CSsG6lrG.js → exec-approvals-allowlist-CGQJSJfD.js} +1 -1
  71. package/dist/{exec-approvals-cli-BuZEm_3t.js → exec-approvals-cli-DmOSbNpe.js} +16 -16
  72. package/dist/{exec-safe-bin-runtime-policy-ukabtnTn.js → exec-safe-bin-runtime-policy-nkIQWrRj.js} +2 -2
  73. package/dist/{fetch-guard-0V5i-cZz.js → fetch-guard-CS_3jTMA.js} +1 -1
  74. package/dist/{fetch-DmaNytop.js → fetch-qkXypRi6.js} +3 -3
  75. package/dist/{fs-safe-DTO6fZ7N.js → fs-safe-CYrszQI6.js} +24 -24
  76. package/dist/{gateway-cli-VJJtBtt2.js → gateway-cli-Ct4tgMMm.js} +153 -153
  77. package/dist/{gateway-rpc-BLIo1-nR.js → gateway-rpc-eEkc-oSq.js} +1 -1
  78. package/dist/{health-Ry4jLJFh.js → health-CWuNlSLA.js} +11 -11
  79. package/dist/{hooks-cli-CpYtmeh1.js → hooks-cli-DdEAtyWm.js} +81 -81
  80. package/dist/{hooks-status-C_u7irQ4.js → hooks-status-NIiTaX__.js} +1 -1
  81. package/dist/{image-5Dop2pwF.js → image-ktIANJRi.js} +5 -5
  82. package/dist/{image-ops-Ba5soKsa.js → image-ops-WJSAG5_7.js} +10 -10
  83. package/dist/image-runtime-C0VvqoAb.js +55 -0
  84. package/dist/{inspect-Bnp4NJm0.js → inspect-DWaajebj.js} +4 -4
  85. package/dist/{install-safe-path-DgGlNCpx.js → install-safe-path-BmAf3bF5.js} +25 -25
  86. package/dist/{installs-Bjh1q5wQ.js → installs-DMDJeMmr.js} +9 -9
  87. package/dist/{ipv4-BsIL6DPy.js → ipv4-DIovCoyM.js} +1 -1
  88. package/dist/{ir-SEi7gUP9.js → ir-xdB7409t.js} +8 -8
  89. package/dist/{issue-format-DEHEwGJB.js → issue-format-DaXc0Ssz.js} +1 -1
  90. package/dist/{json-files-rR19q30D.js → json-files-CuJjdF_0.js} +8 -8
  91. package/dist/{lifecycle-core-t2Q34Tiu.js → lifecycle-core-BinqEyma.js} +5 -5
  92. package/dist/{login-DKh_sv9q.js → login-62iNga_2.js} +3 -3
  93. package/dist/{login-qr-9Wvtlmqz.js → login-qr-DMWPhIpQ.js} +6 -6
  94. package/dist/{logs-cli-BQTvPOds.js → logs-cli-BN9aRZlE.js} +9 -9
  95. package/dist/{manager-DKcbmdLj.js → manager-DstlJwRR.js} +14 -14
  96. package/dist/{manager-runtime-CdY_4s56.js → manager-runtime-DktggQQ7.js} +9 -9
  97. package/dist/{manifest-registry-CzoQ4XAn.js → manifest-registry-DjbHJw7g.js} +1 -1
  98. package/dist/{memory-cli-CEZedlbs.js → memory-cli-B4tlY2Jz.js} +12 -12
  99. package/dist/{model-B2Sraf73.js → model-BLdajRK2.js} +2 -2
  100. package/dist/{model-catalog-B9Kd_iNy.js → model-catalog-DorZGOmy.js} +3 -3
  101. package/dist/{model-picker-DyLoTKdE.js → model-picker-Cn-yEB3e.js} +4 -4
  102. package/dist/{models-CZbq8HGI.js → models-B_vCWO9r.js} +17 -17
  103. package/dist/{models-cli-8aPPSLLl.js → models-cli-BBMBrNuk.js} +78 -78
  104. package/dist/{models-config-C7yYEUbY.js → models-config-VlzOga1W.js} +6 -6
  105. package/dist/{net-CfwQaj6f.js → net-DFijUFfS.js} +2 -2
  106. package/dist/{node-cli-BRIl5jr7.js → node-cli-BfSkX-wS.js} +33 -33
  107. package/dist/{node-command-policy-yJ_VpCHq.js → node-command-policy-BMgJ81FO.js} +1 -1
  108. package/dist/{node-service-9R10zILv.js → node-service-BeDB4avc.js} +1 -1
  109. package/dist/{nodes-cli-CARJm2ko.js → nodes-cli-D0etQIcH.js} +16 -16
  110. package/dist/{nodes-screen-DF7EBTLu.js → nodes-screen-DWVpmvMz.js} +7 -7
  111. package/dist/{npm-pack-install-DdqL1Mh1.js → npm-pack-install-BUyXXcPz.js} +18 -18
  112. package/dist/{npm-resolution-BaKXXkK7.js → npm-resolution-DSDaOY0G.js} +4 -4
  113. package/dist/{onboard-C7cwcgUt.js → onboard-BEv6XhMg.js} +6 -6
  114. package/dist/{onboard-channels-VhiLL846.js → onboard-channels-DAQmVNUf.js} +21 -21
  115. package/dist/{onboard-custom-2gc6FKvI.js → onboard-custom-BIY24QCh.js} +4 -4
  116. package/dist/{onboard-helpers-Mort99IL.js → onboard-helpers-CPO08jBg.js} +10 -10
  117. package/dist/{onboard-hooks-DPho1fkd.js → onboard-hooks-CK-gx645.js} +4 -4
  118. package/dist/{onboard-remote-BfScc2nM.js → onboard-remote-SQzkLmdW.js} +4 -4
  119. package/dist/{onboard-skills-CkZeXqxE.js → onboard-skills-B2UtgSDa.js} +4 -4
  120. package/dist/{onboarding-DyjqYKzZ.js → onboarding-CWdu0f2f.js} +14 -14
  121. package/dist/{onboarding.finalize-Rn8lrC90.js → onboarding.finalize-BD5_L4rw.js} +87 -87
  122. package/dist/{onboarding.gateway-config-D83188RW.js → onboarding.gateway-config-CBJgsZvM.js} +18 -18
  123. package/dist/{onboarding.secret-input-CG_ZOH5i.js → onboarding.secret-input-B_lhRVqi.js} +1 -1
  124. package/dist/{openai-model-default-D1kdZKT2.js → openai-model-default-OdIXYQox.js} +2 -2
  125. package/dist/{openclaw-root-BU3lu8pM.js → openclaw-root-BFfBQ6FD.js} +8 -8
  126. package/dist/{outbound-attachment-MWhTrPYa.js → outbound-attachment-BewsAqvJ.js} +2 -2
  127. package/dist/{outbound-BrhmfCk2.js → outbound-m-MM0HUr.js} +3 -3
  128. package/dist/{pairing-cli-BLxX0PoT.js → pairing-cli-CjrZxYPI.js} +8 -8
  129. package/dist/{pairing-labels-C1jblVNc.js → pairing-labels-BU1EH5qm.js} +1 -1
  130. package/dist/{pairing-store-B_UHGVGM.js → pairing-store-CrEzWjmd.js} +3 -3
  131. package/dist/{path-alias-guards-DhIwq92y.js → path-alias-guards-DbNvNQar.js} +3 -3
  132. package/dist/{path-safety-BjIM4N4t.js → path-safety-ClQO4BB6.js} +1 -1
  133. package/dist/{paths-CGf7Nrz-.js → paths-BaZIBy3U.js} +9 -9
  134. package/dist/{pi-embedded-helpers-D9bQLeoK.js → pi-embedded-helpers-CJZP0u_Y.js} +6 -6
  135. package/dist/{pi-model-discovery-BmqY0Fxk.js → pi-model-discovery-IzndsQh-.js} +1 -1
  136. package/dist/{pi-model-discovery-runtime-Ce9Tz7Qj.js → pi-model-discovery-runtime-Bc-2_ZlP.js} +5 -5
  137. package/dist/{pi-tools.before-tool-call.runtime-B3faxm6v.js → pi-tools.before-tool-call.runtime-D4tLWmkM.js} +5 -5
  138. package/dist/{pi-tools.policy-B1sTh_x1.js → pi-tools.policy-B72vqcZC.js} +5 -5
  139. package/dist/{plugin-auto-enable-DFhRs_Ha.js → plugin-auto-enable-BJfAN-kO.js} +3 -3
  140. package/dist/{plugin-registry-34ghMzQO.js → plugin-registry-Coex6Pjp.js} +3 -3
  141. package/dist/plugin-sdk/{accounts-UnMpt5N3.js → accounts-8MUKWeGv.js} +2 -2
  142. package/dist/plugin-sdk/{accounts-B9LsoWRN.js → accounts-C1nsQfAq.js} +3 -3
  143. package/dist/plugin-sdk/{accounts-raZ4ECkq.js → accounts-CPoohfrp.js} +2 -2
  144. package/dist/plugin-sdk/{active-listener-Eb16HTkk.js → active-listener-Degi0it3.js} +2 -2
  145. package/dist/plugin-sdk/{api-key-rotation-CVee9nRS.js → api-key-rotation-CbsZTTUf.js} +2 -2
  146. package/dist/plugin-sdk/{audio-preflight-B82VQczF.js → audio-preflight-De3ToOLv.js} +26 -26
  147. package/dist/plugin-sdk/{audio-transcription-runner-qZ6rKQHs.js → audio-transcription-runner-B99FfbzJ.js} +11 -11
  148. package/dist/plugin-sdk/{audit-membership-runtime-Re50ULXH.js → audit-membership-runtime-DS34hPU6.js} +2 -2
  149. package/dist/plugin-sdk/{channel-activity-DhjaEnHr.js → channel-activity-DdXRr2be.js} +3 -3
  150. package/dist/plugin-sdk/{channel-web-Cd9ofl4F.js → channel-web-DyO5wH-M.js} +18 -18
  151. package/dist/plugin-sdk/{chrome-DkRruWw9.js → chrome-D9S09VjY.js} +6 -6
  152. package/dist/plugin-sdk/{commands-registry-DCIdoQuk.js → commands-registry-7sKgV6b6.js} +4 -4
  153. package/dist/plugin-sdk/{config-Dq7-4cgI.js → config-hSLjGMqo.js} +7 -7
  154. package/dist/plugin-sdk/{deliver-BFO3PdBy.js → deliver-CmBonhhr.js} +10 -10
  155. package/dist/plugin-sdk/deliver-runtime-DzqXq4YW.js +32 -0
  156. package/dist/plugin-sdk/deps-send-discord.runtime-BWZWUTzd.js +23 -0
  157. package/dist/plugin-sdk/deps-send-imessage.runtime-BbcpP4Hy.js +22 -0
  158. package/dist/plugin-sdk/deps-send-signal.runtime-DnuZ-6OX.js +21 -0
  159. package/dist/plugin-sdk/deps-send-slack.runtime-C-K73-e_.js +19 -0
  160. package/dist/plugin-sdk/deps-send-telegram.runtime-B47VZANU.js +24 -0
  161. package/dist/plugin-sdk/deps-send-whatsapp.runtime-CbVoeht-.js +57 -0
  162. package/dist/plugin-sdk/{diagnostic-DiXA_NOk.js → diagnostic-XZ76ECg1.js} +2 -2
  163. package/dist/plugin-sdk/{errors-x0EvNKYN.js → errors-C-TFeu_U.js} +1 -1
  164. package/dist/plugin-sdk/{fetch-guard-DHh-3Pq7.js → fetch-guard-BNChovQk.js} +2 -2
  165. package/dist/plugin-sdk/{fs-safe-Obb1u_C-.js → fs-safe-B8jm0acc.js} +3 -3
  166. package/dist/plugin-sdk/{image-C2hwEt8m.js → image-BzikjBti.js} +6 -6
  167. package/dist/plugin-sdk/{image-ops-C7Kt1ryv.js → image-ops-DBR1x_FT.js} +2 -2
  168. package/dist/plugin-sdk/image-runtime-BfyyxB88.js +25 -0
  169. package/dist/plugin-sdk/index.js +50 -50
  170. package/dist/plugin-sdk/{ir-DEyFvrC3.js → ir-CvW_AaoY.js} +7 -7
  171. package/dist/plugin-sdk/{local-roots-BS6aNMOU.js → local-roots-CW4yjHjO.js} +4 -4
  172. package/dist/plugin-sdk/{logger-COmHOvdm.js → logger-z1vqlUc1.js} +2 -2
  173. package/dist/plugin-sdk/{login-C0QJfY7H.js → login-BzaOlpPR.js} +4 -4
  174. package/dist/plugin-sdk/{login-qr-0qmwdPb0.js → login-qr-C0z_KRnC.js} +5 -5
  175. package/dist/plugin-sdk/{manager-8RgL4Sdy.js → manager-DTf6k6ib.js} +8 -8
  176. package/dist/plugin-sdk/manager-runtime-PlVcxBdF.js +15 -0
  177. package/dist/plugin-sdk/{outbound-r2idzBjf.js → outbound-DmES81b6.js} +5 -5
  178. package/dist/plugin-sdk/{outbound-attachment-D2rmCK5Q.js → outbound-attachment-BYR_GvCl.js} +2 -2
  179. package/dist/plugin-sdk/{path-alias-guards-DlbgzmZl.js → path-alias-guards-CMpHLrQn.js} +1 -1
  180. package/dist/plugin-sdk/{paths-B2ytnsaB.js → paths-NcyWgkDa.js} +1 -1
  181. package/dist/plugin-sdk/{pi-embedded-helpers-xCyAR479.js → pi-embedded-helpers-6BaZvTwA.js} +16 -16
  182. package/dist/plugin-sdk/{pi-model-discovery-C31bQ9NT.js → pi-model-discovery-DYyEobhW.js} +1 -1
  183. package/dist/plugin-sdk/pi-model-discovery-runtime-CF3YRFcs.js +8 -0
  184. package/dist/plugin-sdk/{pi-tools.before-tool-call.runtime-BPpgalFg.js → pi-tools.before-tool-call.runtime-ocH9ttx6.js} +4 -4
  185. package/dist/plugin-sdk/{plugins-CRPN1AUk.js → plugins-B_UiQZHB.js} +4 -4
  186. package/dist/plugin-sdk/{proxy-fetch-BZAtM2fT.js → proxy-fetch-DxlXp4Yi.js} +1 -1
  187. package/dist/plugin-sdk/{pw-ai-kU3tw4ws.js → pw-ai-B-yFpAtd.js} +9 -9
  188. package/dist/plugin-sdk/{qmd-manager-5TI5OD4_.js → qmd-manager-uz9PCVkw.js} +7 -7
  189. package/dist/plugin-sdk/{query-expansion-miz9J0WR.js → query-expansion-D8bZEHLi.js} +4 -4
  190. package/dist/plugin-sdk/{redact-DZTeCKgA.js → redact-DIGZ7dEc.js} +1 -1
  191. package/dist/plugin-sdk/{reply-2zncCurP.js → reply-DHKovUx3.js} +73 -73
  192. package/dist/plugin-sdk/{resolve-outbound-target-BZynpUy7.js → resolve-outbound-target-DAomg7DR.js} +2 -2
  193. package/dist/plugin-sdk/{run-with-concurrency-BdEQVn3N.js → run-with-concurrency-qFOkp49n.js} +1 -1
  194. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-D6QQrKEg.js +10 -0
  195. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-C9sD41-7.js +19 -0
  196. package/dist/plugin-sdk/{send-DXAc8sNQ.js → send-AAxixxac.js} +6 -6
  197. package/dist/plugin-sdk/{send-srOsTG5v.js → send-BikqI3_Q.js} +5 -5
  198. package/dist/plugin-sdk/{send-DDxJMLW5.js → send-D7LHac9D.js} +7 -7
  199. package/dist/plugin-sdk/{send-BraCxR1K.js → send-DHx11WPi.js} +13 -13
  200. package/dist/plugin-sdk/{send-DGJD5miT.js → send-iL8NdxQL.js} +8 -8
  201. package/dist/plugin-sdk/{session-DPtviLOH.js → session-B8SERluE.js} +3 -3
  202. package/dist/plugin-sdk/{skill-commands-9Q1xjzBv.js → skill-commands-BBiGcASQ.js} +4 -4
  203. package/dist/plugin-sdk/{skills-DibmdNLb.js → skills-uVCpkzHJ.js} +6 -6
  204. package/dist/plugin-sdk/slack.js +2 -2
  205. package/dist/plugin-sdk/slash-commands.runtime-UF19zDim.js +13 -0
  206. package/dist/plugin-sdk/slash-dispatch.runtime-CSdhHD27.js +52 -0
  207. package/dist/plugin-sdk/slash-skill-commands.runtime-B9xCsuLJ.js +16 -0
  208. package/dist/plugin-sdk/{ssrf-C6DhX4-H.js → ssrf-BvmhOmnD.js} +1 -1
  209. package/dist/plugin-sdk/{store-ZIdTTfE4.js → store-CDD0KdbU.js} +2 -2
  210. package/dist/plugin-sdk/subagent-registry-runtime-C4cuhBu-.js +52 -0
  211. package/dist/plugin-sdk/{tables-BssKNJPW.js → tables-DnzlEbCE.js} +1 -1
  212. package/dist/plugin-sdk/{target-errors-CXWbQSBp.js → target-errors-BInUjyyh.js} +2 -2
  213. package/dist/plugin-sdk/{thinking-DMfnE3HJ.js → thinking-CLc4CsZU.js} +7 -7
  214. package/dist/plugin-sdk/{tokens-XT-8y62w.js → tokens-DuRErjk3.js} +1 -1
  215. package/dist/plugin-sdk/{tool-images-DbDPeOjK.js → tool-images-h8wHgEL8.js} +2 -2
  216. package/dist/plugin-sdk/web-Btk9r9Ct.js +56 -0
  217. package/dist/plugin-sdk/{whatsapp-actions-DKfas9MG.js → whatsapp-actions-BBLa4ciE.js} +17 -17
  218. package/dist/{plugins-DO_6iMZV.js → plugins-B4AetCpQ.js} +2 -2
  219. package/dist/{plugins-cli-CrVhFNFQ.js → plugins-cli-BC1OrfRZ.js} +83 -83
  220. package/dist/{ports-D7wHAklC.js → ports-BUQm2J6L.js} +1 -1
  221. package/dist/{ports-jknVhOJa.js → ports-BpZiRmiG.js} +2 -2
  222. package/dist/{program-DJShjgis.js → program-DP3cy7oT.js} +81 -81
  223. package/dist/{prompt-select-styled-BEQND6Pn.js → prompt-select-styled-doOKqwJk.js} +40 -40
  224. package/dist/{provider-auth-helpers-CHEChUx_.js → provider-auth-helpers-DcmZK4IP.js} +5 -5
  225. package/dist/{proxy-env-C61VbSzS.js → proxy-env-BEfRNPmW.js} +1 -1
  226. package/dist/{push-apns-BPEC7SVy.js → push-apns-Duv_LH_E.js} +5 -5
  227. package/dist/{pw-ai-BWsikzYD.js → pw-ai-Ds5f7Rvv.js} +18 -18
  228. package/dist/{qmd-manager-DefwbEao.js → qmd-manager-4HixPUdU.js} +20 -20
  229. package/dist/{qr-cli-CoXD6uPd.js → qr-cli-D4MiTFeD.js} +2 -2
  230. package/dist/{query-expansion-BlsKiJrV.js → query-expansion-DfWHFCTw.js} +12 -12
  231. package/dist/{redact-snapshot-M27Gs1s9.js → redact-snapshot-BE1hcZlN.js} +1 -1
  232. package/dist/{register.agent-t529UsnC.js → register.agent-DFd8-wLc.js} +94 -94
  233. package/dist/register.configure-Cu6y9WMa.js +165 -0
  234. package/dist/{register.maintenance-FmxcJgcW.js → register.maintenance-CouoMEPC.js} +95 -95
  235. package/dist/{register.message-BCoDh2cF.js → register.message-g4CdwiKD.js} +74 -74
  236. package/dist/{register.onboard-DZar0J8o.js → register.onboard-DlKw4xXK.js} +18 -18
  237. package/dist/{register.setup-D14CyWuc.js → register.setup-kxCLJtkA.js} +21 -21
  238. package/dist/{register.status-health-sessions-B6crPNF9.js → register.status-health-sessions-BakEjuIX.js} +88 -88
  239. package/dist/{register.subclis-BAATApi1.js → register.subclis-E3VXJcR8.js} +31 -31
  240. package/dist/{rpc-CA7yGckN.js → rpc-C9k7pLBW.js} +1 -1
  241. package/dist/{run-main-B19t_gLX.js → run-main-k4NWKRqz.js} +92 -92
  242. package/dist/{runtime-D_htBj_7.js → runtime-CagDsJFx.js} +3 -3
  243. package/dist/{runtime-config-collectors-mLMSoY2n.js → runtime-config-collectors-D0I8Qs4G.js} +1 -1
  244. package/dist/{runtime-whatsapp-login.runtime-BtBGjvx6.js → runtime-whatsapp-login.runtime-BvfhsLJm.js} +7 -7
  245. package/dist/{runtime-whatsapp-outbound.runtime-D1d2rg_z.js → runtime-whatsapp-outbound.runtime-QL3Riu-B.js} +15 -15
  246. package/dist/{sandbox-C-8JxFW5.js → sandbox-CgTcwizP.js} +18 -18
  247. package/dist/{sandbox-cli-xIBSXLbp.js → sandbox-cli-56gCyo4f.js} +25 -25
  248. package/dist/{secrets-cli-DwpF8ldn.js → secrets-cli-BjzX5BIS.js} +11 -11
  249. package/dist/{security-cli-BjfOTh6K.js → security-cli-C8_7pezc.js} +42 -42
  250. package/dist/{send-NBLtGiEh.js → send-B1C9OCt2.js} +8 -8
  251. package/dist/{send-Cp2_MKSV.js → send-BCdpg1w2.js} +5 -5
  252. package/dist/{send-BzRMouwD.js → send-BhJJuiPi.js} +4 -4
  253. package/dist/{send-DrEo-BBc.js → send-CkFo9xha.js} +6 -6
  254. package/dist/{send-D2Kyg_GY.js → send-DDvvsvcJ.js} +11 -11
  255. package/dist/{server-Cz0R7Scf.js → server-EsF-rWXM.js} +20 -20
  256. package/dist/{server-context-vco06zxO.js → server-context-DAejIBKi.js} +12 -12
  257. package/dist/{server-lifecycle-BnUgXA5X.js → server-lifecycle-C0IxrwRk.js} +2 -2
  258. package/dist/{server-middleware-D5lrCTcL.js → server-middleware-B8_ZaIoM.js} +1 -1
  259. package/dist/{server-node-events-BTTa3-DI.js → server-node-events-1jnvsPrM.js} +74 -74
  260. package/dist/{service-B6Pm7AZA.js → service-T5lT7h-M.js} +15 -15
  261. package/dist/{session-CDSphrCx.js → session-XvQQBDSC.js} +1 -1
  262. package/dist/{session-utils-LerBXiBL.js → session-utils-CDs6jjz-.js} +6 -6
  263. package/dist/{sessions-UwbRBc7C.js → sessions-D4pBAOV-.js} +15 -15
  264. package/dist/{sessions-C7q1EhRK.js → sessions-JCqDw8Bf.js} +4 -4
  265. package/dist/{shared-BVq1q5D-.js → shared-BrmHcYtZ.js} +1 -1
  266. package/dist/{shared-sIizRbI9.js → shared-DaWK788E.js} +3 -3
  267. package/dist/{skill-commands-CeEZlRJj.js → skill-commands-DDRb6be1.js} +5 -5
  268. package/dist/{skill-scanner-DGx7tLvP.js → skill-scanner-BdA-XFky.js} +6 -6
  269. package/dist/{skills-B16i2mme.js → skills-Dde3dh7M.js} +3 -3
  270. package/dist/{skills-cli-COBPySVc.js → skills-cli-hPtKeBYo.js} +5 -5
  271. package/dist/{skills-install-CEgXF7D3.js → skills-install-BG5c8jOQ.js} +6 -6
  272. package/dist/{skills-status-BGvLXtop.js → skills-status-Cl0jR0kA.js} +1 -1
  273. package/dist/{slash-commands.runtime-BLl455Ha.js → slash-commands.runtime-WyW5W0r3.js} +11 -11
  274. package/dist/slash-dispatch.runtime-e_hnJMYz.js +114 -0
  275. package/dist/{slash-skill-commands.runtime-NP-EeAgb.js → slash-skill-commands.runtime-DCZQC-hJ.js} +15 -15
  276. package/dist/{status-4fmTPmZ8.js → status-KrF4yDJE.js} +27 -27
  277. package/dist/{status.update-BincwEhI.js → status.update-ovXdI8fy.js} +2 -2
  278. package/dist/{store-C4eyKOP_.js → store-OqcrqyHY.js} +5 -5
  279. package/dist/{subagent-registry-B29QoX6u.js → subagent-registry-CqQCPU35.js} +149 -149
  280. package/dist/subagent-registry-runtime-DZ2NcDAS.js +114 -0
  281. package/dist/{system-cli-DeCdNdxg.js → system-cli-C6XjjyMr.js} +9 -9
  282. package/dist/{system-run-command-DVel5yZQ.js → system-run-command-B1auaqvg.js} +1 -1
  283. package/dist/{systemd-BPu08aN2.js → systemd-CvSjUuUT.js} +9 -9
  284. package/dist/{systemd-hints-PEGoMeNi.js → systemd-hints-DPrvbOr-.js} +6 -6
  285. package/dist/{systemd-linger-ckxguBpS.js → systemd-linger-DWtUqeeE.js} +1 -1
  286. package/dist/{tables-CM4RCywz.js → tables-BSWzRw5b.js} +1 -1
  287. package/dist/{tailnet-D8ZmZFEq.js → tailnet-Bdvg29Ll.js} +1 -1
  288. package/dist/{target-errors-Dq-K3j_S.js → target-errors-D0aWoxbs.js} +4 -4
  289. package/dist/{tool-images-C96-GuZE.js → tool-images-J7V8AfTu.js} +1 -1
  290. package/dist/{tui-Cby-FNU6.js → tui-DlcwmY1x.js} +6 -6
  291. package/dist/{tui-cli-BpgQL5Pu.js → tui-cli-zm_Sa4E5.js} +32 -32
  292. package/dist/{update-DNmbn7VE.js → update-Gbhw9u0F.js} +3 -3
  293. package/dist/{update-cli-kVzXT8I-.js → update-cli-Co-CAt0w.js} +104 -104
  294. package/dist/{update-runner-C-d9Tjog.js → update-runner-kKiJKth8.js} +16 -16
  295. package/dist/web-Bx-fQR1C.js +118 -0
  296. package/dist/{webhooks-cli-BeC7vAYz.js → webhooks-cli-B-O0TVtX.js} +6 -6
  297. package/dist/{whatsapp-actions-oSO9PcWD.js → whatsapp-actions-DaNP01Yk.js} +17 -17
  298. package/dist/{with-timeout-YDfOtKvh.js → with-timeout-xp4bBUMy.js} +3 -3
  299. package/dist/{workspace-CZkOfauh.js → workspace-BXI1yRZ5.js} +1 -1
  300. package/dist/{workspace-dirs-BSD3q0pa.js → workspace-dirs-BY9k_sye.js} +1 -1
  301. package/dist/{wsl-CsGe5QCP.js → wsl-CvQfS6aU.js} +2 -2
  302. package/package.json +2 -2
  303. package/dist/deliver-runtime-DkDQPjmE.js +0 -61
  304. package/dist/deps-send-discord.runtime-DhhOEbEN.js +0 -36
  305. package/dist/deps-send-imessage.runtime-CeatZSyv.js +0 -35
  306. package/dist/deps-send-signal.runtime-xlqQXnR0.js +0 -34
  307. package/dist/deps-send-slack.runtime-m3yDRYug.js +0 -32
  308. package/dist/deps-send-whatsapp.runtime-DZR3Tix2.js +0 -119
  309. package/dist/image-runtime-vjBJe2FQ.js +0 -55
  310. package/dist/plugin-sdk/deliver-runtime-BWZ4MjCx.js +0 -32
  311. package/dist/plugin-sdk/deps-send-discord.runtime-DOOrRWmj.js +0 -23
  312. package/dist/plugin-sdk/deps-send-imessage.runtime-B5w4Zb7g.js +0 -22
  313. package/dist/plugin-sdk/deps-send-signal.runtime-NUsgzgnc.js +0 -21
  314. package/dist/plugin-sdk/deps-send-slack.runtime-30nkLxsY.js +0 -19
  315. package/dist/plugin-sdk/deps-send-telegram.runtime-D2BsaDBJ.js +0 -24
  316. package/dist/plugin-sdk/deps-send-whatsapp.runtime-DMtrDoHb.js +0 -57
  317. package/dist/plugin-sdk/image-runtime-Vtwamfai.js +0 -25
  318. package/dist/plugin-sdk/manager-runtime-B7jfPrQb.js +0 -15
  319. package/dist/plugin-sdk/pi-model-discovery-runtime-C5Suk1AS.js +0 -8
  320. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-BhSqT2c_.js +0 -10
  321. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-DrZrtcgL.js +0 -19
  322. package/dist/plugin-sdk/slash-commands.runtime-z1q_nPnV.js +0 -13
  323. package/dist/plugin-sdk/slash-dispatch.runtime-CR4I_6w5.js +0 -52
  324. package/dist/plugin-sdk/slash-skill-commands.runtime-BzB0BO-7.js +0 -16
  325. package/dist/plugin-sdk/subagent-registry-runtime-UnNrLL2P.js +0 -52
  326. package/dist/plugin-sdk/web-D7S-5qkT.js +0 -56
  327. package/dist/register.configure-Dn11C-E_.js +0 -165
  328. package/dist/slash-dispatch.runtime-BtsEX-_Q.js +0 -114
  329. package/dist/subagent-registry-runtime-ChT29jt0.js +0 -114
  330. package/dist/web-CrLnsppN.js +0 -118
@@ -3,12 +3,12 @@ import { g as resolveStateDir, i as isNixMode, l as resolveGatewayLockDir, o as
3
3
  import { a as setConsoleSubsystemFilter, d as defaultRuntime, n as runtimeForLogger, o as setConsoleTimestampPrefix, t as createSubsystemLogger } from "./subsystem-Cfn2Pryx.js";
4
4
  import "./boolean-DtWR5bt3.js";
5
5
  import { i as logAcceptedEnvOption, r as isTruthyEnvValue } from "./entry.js";
6
- import { At as AVATAR_MAX_BYTES, B as parseConfigJson5, Bn as buildTalkConfigResponse, Dn as applyMergePatch, Dr as resolveDefaultModelForAgent, Er as resolveConfiguredModelRef, Fi as DEFAULT_CONTEXT_TOKENS, G as writeConfigFile, H as readConfigFileSnapshotForWrite, Hn as resolveAgentMaxConcurrent, I as migrateLegacyConfig, Ii as DEFAULT_MODEL, K as validateConfigObjectWithPlugins, Li as DEFAULT_PROVIDER, Lt as looksLikeAvatarPath, Mt as isAvatarHttpUrl, Nr as resolveThinkingDefault, Nt as isAvatarImageDataUrl, On as applyLegacyMigrations, Or as resolveHooksGmailModel, R as createConfigIO, U as resolveConfigSnapshotHash, Un as resolveSubagentMaxConcurrent, V as readConfigFileSnapshot, dr as isPidAlive, fr as buildAllowedModelSet, gr as getModelRefStatus, ji as normalizeSecretInput, jr as resolveSubagentConfiguredModelSelection, kn as ensureControlUiAllowedOriginsForNonLoopbackBind, mt as parseByteSize, pt as parseDurationMs, q as OpenClawSchema, vr as isCliProvider, wr as resolveAllowedModelRef, xr as normalizeModelSelection, z as loadConfig } from "./auth-profiles-yB_p54Kf.js";
6
+ import { At as AVATAR_MAX_BYTES, B as parseConfigJson5, Bn as buildTalkConfigResponse, Dn as applyMergePatch, Dr as resolveDefaultModelForAgent, Er as resolveConfiguredModelRef, Fi as DEFAULT_CONTEXT_TOKENS, G as writeConfigFile, H as readConfigFileSnapshotForWrite, Hn as resolveAgentMaxConcurrent, I as migrateLegacyConfig, Ii as DEFAULT_MODEL, K as validateConfigObjectWithPlugins, Li as DEFAULT_PROVIDER, Lt as looksLikeAvatarPath, Mt as isAvatarHttpUrl, Nr as resolveThinkingDefault, Nt as isAvatarImageDataUrl, On as applyLegacyMigrations, Or as resolveHooksGmailModel, R as createConfigIO, U as resolveConfigSnapshotHash, Un as resolveSubagentMaxConcurrent, V as readConfigFileSnapshot, dr as isPidAlive, fr as buildAllowedModelSet, gr as getModelRefStatus, ji as normalizeSecretInput, jr as resolveSubagentConfiguredModelSelection, kn as ensureControlUiAllowedOriginsForNonLoopbackBind, mt as parseByteSize, pt as parseDurationMs, q as OpenClawSchema, vr as isCliProvider, wr as resolveAllowedModelRef, xr as normalizeModelSelection, z as loadConfig } from "./auth-profiles-CtYlKXxI.js";
7
7
  import { t as formatCliCommand } from "./command-format-CLEQe4bk.js";
8
- import { A as resolveDefaultAgentWorkspaceDir, C as DEFAULT_SOUL_FILENAME, E as ensureAgentWorkspace, O as isWorkspaceOnboardingCompleted, S as DEFAULT_MEMORY_FILENAME, T as DEFAULT_USER_FILENAME, a as resolveAgentDir, b as DEFAULT_IDENTITY_FILENAME, c as resolveAgentModelFallbacksOverride, d as resolveDefaultAgentId, g as DEFAULT_AGENTS_FILENAME, i as resolveAgentConfig, j as resolveWorkspaceTemplateDir, l as resolveAgentSkillsFilter, m as resolveSessionAgentId, n as listAgentEntries, r as listAgentIds, u as resolveAgentWorkspaceDir, v as DEFAULT_BOOTSTRAP_FILENAME, w as DEFAULT_TOOLS_FILENAME, x as DEFAULT_MEMORY_ALT_FILENAME, y as DEFAULT_HEARTBEAT_FILENAME } from "./agent-scope-BGsA4zEf.js";
8
+ import { A as resolveDefaultAgentWorkspaceDir, C as DEFAULT_SOUL_FILENAME, E as ensureAgentWorkspace, O as isWorkspaceOnboardingCompleted, S as DEFAULT_MEMORY_FILENAME, T as DEFAULT_USER_FILENAME, a as resolveAgentDir, b as DEFAULT_IDENTITY_FILENAME, c as resolveAgentModelFallbacksOverride, d as resolveDefaultAgentId, g as DEFAULT_AGENTS_FILENAME, i as resolveAgentConfig, j as resolveWorkspaceTemplateDir, l as resolveAgentSkillsFilter, m as resolveSessionAgentId, n as listAgentEntries, r as listAgentIds, u as resolveAgentWorkspaceDir, v as DEFAULT_BOOTSTRAP_FILENAME, w as DEFAULT_TOOLS_FILENAME, x as DEFAULT_MEMORY_ALT_FILENAME, y as DEFAULT_HEARTBEAT_FILENAME } from "./agent-scope-C5bklqr1.js";
9
9
  import { C as isCronRunSessionKey, E as parseAgentSessionKey, T as isSubagentSessionKey, _ as normalizeAccountId$1, c as normalizeAgentId, g as DEFAULT_ACCOUNT_ID, h as toAgentStoreSessionKey, l as normalizeMainKey, m as toAgentRequestSessionKey, o as classifySessionKeyShape, r as buildAgentMainSessionKey, t as DEFAULT_AGENT_ID, u as resolveAgentIdFromSessionKey } from "./session-key-k6urs9r-.js";
10
10
  import { E as isPlainObject, S as sleep, T as truncateUtf16Safe, n as clamp, s as ensureDir, v as resolveUserPath, x as shortenHomePath } from "./utils-cwpAMi-t.js";
11
- import { a as openBoundaryFileSync, f as isNotFoundPathError, g as matchesSkillFilter, i as openBoundaryFile, o as openVerifiedFileSync, s as sameFileIdentity, t as resolveOpenClawPackageRoot } from "./openclaw-root-BU3lu8pM.js";
11
+ import { a as openBoundaryFileSync, f as isNotFoundPathError, g as matchesSkillFilter, i as openBoundaryFile, o as openVerifiedFileSync, s as sameFileIdentity, t as resolveOpenClawPackageRoot } from "./openclaw-root-BFfBQ6FD.js";
12
12
  import { i as logWarn, t as logDebug } from "./logger-DB-PHqB2.js";
13
13
  import { n as runExec, t as runCommandWithTimeout } from "./exec-B45rafWZ.js";
14
14
  import { C as clearInternalHooks, E as triggerInternalHook, T as registerInternalHook, h as createEmptyPluginRegistry, t as CHANNEL_IDS, u as getActivePluginRegistry, w as createInternalHookEvent } from "./registry-BrR1Dq5T.js";
@@ -16,105 +16,105 @@ import "./github-copilot-token-Byc_YVYE.js";
16
16
  import "./host-env-security-lcjXF83D.js";
17
17
  import { n as resolveRuntimeServiceVersion, t as VERSION } from "./version-DdJhsIqk.js";
18
18
  import "./env-vars-mSSOl7Rv.js";
19
- import { u as isTestDefaultMemorySlotDisabled } from "./manifest-registry-CzoQ4XAn.js";
20
- import "./dock-DjC0vgOm.js";
21
- import "./model-B2Sraf73.js";
22
- import "./pi-model-discovery-BmqY0Fxk.js";
23
- import { d as startDiagnosticHeartbeat, f as stopDiagnosticHeartbeat, m as isDiagnosticsEnabled } from "./diagnostic-Dp-KkeSq.js";
19
+ import { u as isTestDefaultMemorySlotDisabled } from "./manifest-registry-DjbHJw7g.js";
20
+ import "./dock-BaM5oTqE.js";
21
+ import "./model-BLdajRK2.js";
22
+ import "./pi-model-discovery-IzndsQh-.js";
23
+ import { d as startDiagnosticHeartbeat, f as stopDiagnosticHeartbeat, m as isDiagnosticsEnabled } from "./diagnostic-3zN7XEY1.js";
24
24
  import { d as hasBinary } from "./frontmatter-D2o8_Jfu.js";
25
- import { i as loadWorkspaceSkillEntries, r as buildWorkspaceSkillSnapshot } from "./skills-B16i2mme.js";
26
- import { n as assertNoPathAliasEscape } from "./path-alias-guards-DhIwq92y.js";
27
- import { t as buildWorkspaceSkillStatus } from "./skills-status-BGvLXtop.js";
25
+ import { i as loadWorkspaceSkillEntries, r as buildWorkspaceSkillSnapshot } from "./skills-Dde3dh7M.js";
26
+ import { n as assertNoPathAliasEscape } from "./path-alias-guards-DbNvNQar.js";
27
+ import { t as buildWorkspaceSkillStatus } from "./skills-status-Cl0jR0kA.js";
28
28
  import { _ as normalizeGatewayClientMode, f as GATEWAY_CLIENT_CAPS, g as hasGatewayClientCap, h as GATEWAY_CLIENT_NAMES, i as isGatewayMessageChannel, l as normalizeMessageChannel, m as GATEWAY_CLIENT_MODES, n as isDeliverableMessageChannel, p as GATEWAY_CLIENT_IDS, r as isGatewayCliClient, s as isWebchatClient, t as INTERNAL_MESSAGE_CHANNEL } from "./message-channel-CXgeX9no.js";
29
- import { $ as resolveAgentMainSessionKey, A as readSessionPreviewItemsFromTranscript, B as cleanStaleLockFiles, C as normalizeSessionDeliveryFields, D as capArrayByJsonBytes, E as archiveSessionTranscripts, G as resolveSessionResetPolicy, I as stripInlineDirectiveTagsForDisplay, L as stripInlineDirectiveTagsFromMessageForDisplay, M as resolveSessionTranscriptCandidates, N as stripEnvelopeFromMessage, O as cleanupArchivedSessionTranscripts, P as stripEnvelopeFromMessages, Q as canonicalizeMainSessionAlias, R as jsonUtf8Bytes, T as archiveFileOnDisk, U as evaluateSessionFreshness, Y as mergeSessionEntry, Z as setSessionRuntimeModel, d as updateSessionStore, et as resolveExplicitAgentSessionKey, it as snapshotSessionOrigin, k as readSessionMessages, n as parseSessionThreadInfo, nt as resolveMainSessionKeyFromConfig, o as loadSessionStore, t as extractDeliveryInfo, tt as resolveMainSessionKey, x as mergeDeliveryContext, y as deliveryContextFromSession } from "./sessions-UwbRBc7C.js";
30
- import { m as buildChannelAccountBindings, n as listChannelPlugins, r as normalizeChannelId, t as getChannelPlugin, w as normalizeWhatsAppTarget } from "./plugins-DO_6iMZV.js";
31
- import { i as resolveWhatsAppAccount } from "./accounts-Bod7973i.js";
32
- import "./accounts-BSIXwC37.js";
29
+ import { $ as resolveAgentMainSessionKey, A as readSessionPreviewItemsFromTranscript, B as cleanStaleLockFiles, C as normalizeSessionDeliveryFields, D as capArrayByJsonBytes, E as archiveSessionTranscripts, G as resolveSessionResetPolicy, I as stripInlineDirectiveTagsForDisplay, L as stripInlineDirectiveTagsFromMessageForDisplay, M as resolveSessionTranscriptCandidates, N as stripEnvelopeFromMessage, O as cleanupArchivedSessionTranscripts, P as stripEnvelopeFromMessages, Q as canonicalizeMainSessionAlias, R as jsonUtf8Bytes, T as archiveFileOnDisk, U as evaluateSessionFreshness, Y as mergeSessionEntry, Z as setSessionRuntimeModel, d as updateSessionStore, et as resolveExplicitAgentSessionKey, it as snapshotSessionOrigin, k as readSessionMessages, n as parseSessionThreadInfo, nt as resolveMainSessionKeyFromConfig, o as loadSessionStore, t as extractDeliveryInfo, tt as resolveMainSessionKey, x as mergeDeliveryContext, y as deliveryContextFromSession } from "./sessions-D4pBAOV-.js";
30
+ import { m as buildChannelAccountBindings, n as listChannelPlugins, r as normalizeChannelId, t as getChannelPlugin, w as normalizeWhatsAppTarget } from "./plugins-B4AetCpQ.js";
31
+ import { i as resolveWhatsAppAccount } from "./accounts-CucAhPu5.js";
32
+ import "./accounts-DarjcXFz.js";
33
33
  import "./logging-CcxUDNcI.js";
34
- import "./accounts-D3YOECeq.js";
35
- import "./send-BzRMouwD.js";
36
- import "./send-D2Kyg_GY.js";
37
- import { $n as DEFAULT_INPUT_IMAGE_MAX_BYTES, $r as emitAgentEvent, $t as stripLegacyDeliveryFields, Ar as resolveTtsAutoMode, At as resetDirectoryCache, B as resolveAgentAvatar, Bt as writeRestartSentinel, Cn as setGatewaySigusr1RestartPolicy, Cr as resolveUserTimezone, D as handleSlackHttpRequest, Dn as normalizeGroupActivation, Dr as isTtsEnabled, Dt as resolveSessionDeliveryTarget, En as unbindThreadBindingsBySessionKey, Er as getTtsProvider, Et as resolveOutboundTarget, F as resolveAgentDeliveryPlan, Fn as resolveBootstrapWarningSignaturesSeen, Fr as setTtsProvider, Ft as formatDoctorNonInteractiveHint, Gr as waitForActiveTasks, Gt as normalizeOptionalAgentId, Hr as markGatewayDraining, Ht as normalizeCronJobCreate, I as resolveAgentOutboundTarget, In as formatZonedTimestamp, Ir as textToSpeech, It as formatRestartSentinelMessage, J as buildHistoryContextFromEntries, Jt as normalizePayloadToSystemText, Kr as CommandLane, Kt as normalizeOptionalSessionKey, L as createOutboundSendDeps, Lr as OPENAI_TTS_MODELS, Mr as resolveTtsPrefsPath, Mt as runWithModelFallback, N as agentCommandFromIngress, Nr as resolveTtsProviderOrder, O as readJsonBodyWithLimit, Or as isTtsProviderConfigured, Ot as resolveOutboundChannelPlugin, Pr as setTtsEnabled, Pt as consumeRestartSentinel, Qn as ACP_SESSION_IDENTITY_RENDERER_VERSION, Qr as clearAgentRunContext, Qt as hasLegacyDeliveryHints, R as createDefaultDeps, Rr as OPENAI_TTS_VOICES, Rt as summarizeRestartSentinel, Sn as scheduleGatewaySigusr1Restart, T as resolveAgentOutboundIdentity, Tn as triggerOpenClawRestart, Tr as clearBootstrapSnapshot, Un as enqueueSystemEvent, Ur as resetAllLanes, Ut as normalizeCronJobPatch, Vr as getTotalQueueSize, Vt as normalizeHttpWebhookUrl, W as createReplyPrefixOptions, Wn as isSystemEventContextChanged, Wr as setCommandLaneConcurrency, Wt as inferLegacyName, Xt as migrateLegacyCronPayload, Yt as normalizeRequiredName, Zr as stripHeartbeatToken, Zt as buildDeliveryFromLegacyPayload, _ as getPluginToolMeta, _n as consumeGatewaySigusr1RestartAuthorization, _r as getAcpSessionManager, _t as readLatestAssistantReply, an as isExternalHookSession, ar as normalizeMimeList, at as dispatchInboundMessage, b as loadOpenClawPlugins, bn as isGatewaySigusr1RestartExternallyAllowed, bt as ensureOutboundSessionEntry, c as runSubagentAnnounceFlow, cn as resolveSessionAuthProfileOverride, cr as resolveAgentTimeoutMs, d as abortEmbeddedPiRun, ei as getAgentRunContext, er as DEFAULT_INPUT_IMAGE_MIMES, f as getActiveEmbeddedRunCount, ft as resolveCronStyleNow, gn as buildOutboundSessionContext, gt as createOpenClawTools, h as buildDefaultToolPolicyPipelineSteps, hn as parseVerboseOverride, ht as runCliAgent, i as initSubagentRegistry, in as getHookType, ir as extractImageContentFromSource, jr as resolveTtsConfig, k as requestBodyErrorToText, kn as loadProviderUsageSummary, kr as resolveTtsApiKey, l as clearSessionQueues, lr as normalizeSendPolicy, m as applyToolPolicyPipeline, mn as applyVerboseOverride, mr as stopSubagentsForRequester, mt as setCliSessionId, ni as registerAgentRunContext, nn as buildSafeExternalPrompt, nr as DEFAULT_INPUT_TIMEOUT_MS, o as listDescendantRunsForRequester, on as applyBrowserProxyPaths, or as resolveInputFileLimits, ot as createReplyDispatcher, p as waitForEmbeddedPiRunEnd, pn as applyModelOverrideToSessionEntry, pr as isAbortRequestText, pt as getCliSessionId, qn as requestHeartbeatNow, qr as DEFAULT_HEARTBEAT_ACK_MAX_CHARS, qt as normalizeOptionalText, rn as detectSuspiciousPatterns, rr as extractFileContentFromSource, sn as persistBrowserProxyFiles, st as getTotalPendingReplies, t as countActiveDescendantRuns, ti as onAgentEvent, tr as DEFAULT_INPUT_MAX_REDIRECTS, u as runEmbeddedPiAgent, ur as resolveSendPolicy, ut as buildBareSessionResetPrompt, v as resolvePluginTools, vn as deferGatewayRestartUntilIdle, vr as resolveAgentSessionDirs, vt as resolveAnnounceTargetFromKey, wn as setPreRestartDeferralCheck, x as createPluginRuntime, xn as markGatewaySigusr1RestartHandled, xt as resolveOutboundSessionRoute, yn as emitGatewayRestart, yr as resolveAgentIdentity, z as createOutboundSendDeps$1, zr as getActiveTaskCount } from "./subagent-registry-B29QoX6u.js";
34
+ import "./accounts-DjUjM_0M.js";
35
+ import "./send-BhJJuiPi.js";
36
+ import "./send-DDvvsvcJ.js";
37
+ import { $n as DEFAULT_INPUT_IMAGE_MAX_BYTES, $r as emitAgentEvent, $t as stripLegacyDeliveryFields, Ar as resolveTtsAutoMode, At as resetDirectoryCache, B as resolveAgentAvatar, Bt as writeRestartSentinel, Cn as setGatewaySigusr1RestartPolicy, Cr as resolveUserTimezone, D as handleSlackHttpRequest, Dn as normalizeGroupActivation, Dr as isTtsEnabled, Dt as resolveSessionDeliveryTarget, En as unbindThreadBindingsBySessionKey, Er as getTtsProvider, Et as resolveOutboundTarget, F as resolveAgentDeliveryPlan, Fn as resolveBootstrapWarningSignaturesSeen, Fr as setTtsProvider, Ft as formatDoctorNonInteractiveHint, Gr as waitForActiveTasks, Gt as normalizeOptionalAgentId, Hr as markGatewayDraining, Ht as normalizeCronJobCreate, I as resolveAgentOutboundTarget, In as formatZonedTimestamp, Ir as textToSpeech, It as formatRestartSentinelMessage, J as buildHistoryContextFromEntries, Jt as normalizePayloadToSystemText, Kr as CommandLane, Kt as normalizeOptionalSessionKey, L as createOutboundSendDeps, Lr as OPENAI_TTS_MODELS, Mr as resolveTtsPrefsPath, Mt as runWithModelFallback, N as agentCommandFromIngress, Nr as resolveTtsProviderOrder, O as readJsonBodyWithLimit, Or as isTtsProviderConfigured, Ot as resolveOutboundChannelPlugin, Pr as setTtsEnabled, Pt as consumeRestartSentinel, Qn as ACP_SESSION_IDENTITY_RENDERER_VERSION, Qr as clearAgentRunContext, Qt as hasLegacyDeliveryHints, R as createDefaultDeps, Rr as OPENAI_TTS_VOICES, Rt as summarizeRestartSentinel, Sn as scheduleGatewaySigusr1Restart, T as resolveAgentOutboundIdentity, Tn as triggerOpenClawRestart, Tr as clearBootstrapSnapshot, Un as enqueueSystemEvent, Ur as resetAllLanes, Ut as normalizeCronJobPatch, Vr as getTotalQueueSize, Vt as normalizeHttpWebhookUrl, W as createReplyPrefixOptions, Wn as isSystemEventContextChanged, Wr as setCommandLaneConcurrency, Wt as inferLegacyName, Xt as migrateLegacyCronPayload, Yt as normalizeRequiredName, Zr as stripHeartbeatToken, Zt as buildDeliveryFromLegacyPayload, _ as getPluginToolMeta, _n as consumeGatewaySigusr1RestartAuthorization, _r as getAcpSessionManager, _t as readLatestAssistantReply, an as isExternalHookSession, ar as normalizeMimeList, at as dispatchInboundMessage, b as loadOpenClawPlugins, bn as isGatewaySigusr1RestartExternallyAllowed, bt as ensureOutboundSessionEntry, c as runSubagentAnnounceFlow, cn as resolveSessionAuthProfileOverride, cr as resolveAgentTimeoutMs, d as abortEmbeddedPiRun, ei as getAgentRunContext, er as DEFAULT_INPUT_IMAGE_MIMES, f as getActiveEmbeddedRunCount, ft as resolveCronStyleNow, gn as buildOutboundSessionContext, gt as createOpenClawTools, h as buildDefaultToolPolicyPipelineSteps, hn as parseVerboseOverride, ht as runCliAgent, i as initSubagentRegistry, in as getHookType, ir as extractImageContentFromSource, jr as resolveTtsConfig, k as requestBodyErrorToText, kn as loadProviderUsageSummary, kr as resolveTtsApiKey, l as clearSessionQueues, lr as normalizeSendPolicy, m as applyToolPolicyPipeline, mn as applyVerboseOverride, mr as stopSubagentsForRequester, mt as setCliSessionId, ni as registerAgentRunContext, nn as buildSafeExternalPrompt, nr as DEFAULT_INPUT_TIMEOUT_MS, o as listDescendantRunsForRequester, on as applyBrowserProxyPaths, or as resolveInputFileLimits, ot as createReplyDispatcher, p as waitForEmbeddedPiRunEnd, pn as applyModelOverrideToSessionEntry, pr as isAbortRequestText, pt as getCliSessionId, qn as requestHeartbeatNow, qr as DEFAULT_HEARTBEAT_ACK_MAX_CHARS, qt as normalizeOptionalText, rn as detectSuspiciousPatterns, rr as extractFileContentFromSource, sn as persistBrowserProxyFiles, st as getTotalPendingReplies, t as countActiveDescendantRuns, ti as onAgentEvent, tr as DEFAULT_INPUT_MAX_REDIRECTS, u as runEmbeddedPiAgent, ur as resolveSendPolicy, ut as buildBareSessionResetPrompt, v as resolvePluginTools, vn as deferGatewayRestartUntilIdle, vr as resolveAgentSessionDirs, vt as resolveAnnounceTargetFromKey, wn as setPreRestartDeferralCheck, x as createPluginRuntime, xn as markGatewaySigusr1RestartHandled, xt as resolveOutboundSessionRoute, yn as emitGatewayRestart, yr as resolveAgentIdentity, z as createOutboundSendDeps$1, zr as getActiveTaskCount } from "./subagent-registry-CqQCPU35.js";
38
38
  import { c as resolveStorePath, i as resolveSessionTranscriptPath, n as resolveSessionFilePath, r as resolveSessionFilePathOptions, s as resolveSessionTranscriptsDirForAgent } from "./paths-DvFmz0MB.js";
39
39
  import { i as normalizeInputProvenance } from "./input-provenance-C8z9KgIz.js";
40
40
  import "./chat-envelope-D3RSz140.js";
41
- import { n as readJsonFile, r as writeJsonAtomic, t as createAsyncLock } from "./json-files-rR19q30D.js";
42
- import { $ as validateNodePairRejectParams, $t as roleScopesAllow, A as validateCronStatusParams, At as validateWizardStartParams, B as validateExecApprovalsGetParams, C as validateConfigSetParams, Ct as validateToolsCatalogParams, D as validateCronRemoveParams, Dt as validateWebLoginWaitParams, E as validateCronListParams, Et as validateWebLoginStartParams, F as validateDevicePairRemoveParams, G as validateModelsListParams, Gt as rejectDevicePairing, H as validateExecApprovalsNodeSetParams, Ht as ensureDeviceToken, I as validateDeviceTokenRevokeParams, It as parseSessionLabel, J as validateNodeInvokeParams, Jt as revokeDeviceToken, K as validateNodeDescribeParams, Kt as removePairedDevice, L as validateDeviceTokenRotateParams, Lt as buildDeviceAuthPayload, M as validateDevicePairApproveParams, Mt as PROTOCOL_VERSION, N as validateDevicePairListParams, Nt as ErrorCodes, O as validateCronRunParams, Ot as validateWizardCancelParams, P as validateDevicePairRejectParams, Pt as errorShape, Q as validateNodePairListParams, Qt as verifyDeviceToken, R as validateExecApprovalRequestParams, Rt as buildDeviceAuthPayloadV3, S as validateConfigSchemaParams, St as validateTalkModeParams, T as validateCronAddParams, Tt as validateWakeParams, U as validateExecApprovalsSetParams, Ut as getPairedDevice, V as validateExecApprovalsNodeGetParams, Vt as approveDevicePairing, W as validateLogsTailParams, Wt as listDevicePairing, X as validateNodeListParams, Xt as summarizeDeviceTokens, Y as validateNodeInvokeResultParams, Yt as rotateDeviceToken, Z as validateNodePairApproveParams, Zt as updatePairedDeviceMetadata, _ as validateChatInjectParams, _t as validateSkillsBinsParams, a as validateAgentWaitParams, at as validateRequestFrame, b as validateConfigGetParams, bt as validateSkillsUpdateParams, c as validateAgentsFilesGetParams, ct as validateSendParams, d as validateAgentsListParams, dt as validateSessionsListParams, et as validateNodePairRequestParams, f as validateAgentsUpdateParams, ft as validateSessionsPatchParams, g as validateChatHistoryParams, gt as validateSessionsUsageParams, h as validateChatAbortParams, ht as validateSessionsResolveParams, i as validateAgentParams, in as verifyDeviceSignature, it as validatePushTestParams, j as validateCronUpdateParams, jt as validateWizardStatusParams, k as validateCronRunsParams, kt as validateWizardNextParams, l as validateAgentsFilesListParams, lt as validateSessionsCompactParams, m as validateChannelsStatusParams, mt as validateSessionsResetParams, n as formatValidationErrors, nt as validateNodeRenameParams, o as validateAgentsCreateParams, ot as validateSecretsResolveParams, p as validateChannelsLogoutParams, pt as validateSessionsPreviewParams, q as validateNodeEventParams, qt as requestDevicePairing, r as validateAgentIdentityParams, rn as normalizeDevicePublicKeyBase64Url, rt as validatePollParams, s as validateAgentsDeleteParams, st as validateSecretsResolveResult, tn as deriveDeviceIdFromPublicKey, tt as validateNodePairVerifyParams, u as validateAgentsFilesSetParams, ut as validateSessionsDeleteParams, v as validateChatSendParams, vt as validateSkillsInstallParams, w as validateConnectParams, wt as validateUpdateRunParams, x as validateConfigPatchParams, xt as validateTalkConfigParams, y as validateConfigApplyParams, yt as validateSkillsStatusParams, z as validateExecApprovalResolveParams, zt as normalizeDeviceMetadataForAuth } from "./client-Kkj2aHgb.js";
43
- import { c as ADMIN_SCOPE$3, d as isNodeRoleMethod, n as callGateway, p as loadGatewayTlsRuntime$1, u as authorizeOperatorScopesForMethod } from "./call-CeJbHmC5.js";
41
+ import { n as readJsonFile, r as writeJsonAtomic, t as createAsyncLock } from "./json-files-CuJjdF_0.js";
42
+ import { $ as validateNodePairRejectParams, $t as roleScopesAllow, A as validateCronStatusParams, At as validateWizardStartParams, B as validateExecApprovalsGetParams, C as validateConfigSetParams, Ct as validateToolsCatalogParams, D as validateCronRemoveParams, Dt as validateWebLoginWaitParams, E as validateCronListParams, Et as validateWebLoginStartParams, F as validateDevicePairRemoveParams, G as validateModelsListParams, Gt as rejectDevicePairing, H as validateExecApprovalsNodeSetParams, Ht as ensureDeviceToken, I as validateDeviceTokenRevokeParams, It as parseSessionLabel, J as validateNodeInvokeParams, Jt as revokeDeviceToken, K as validateNodeDescribeParams, Kt as removePairedDevice, L as validateDeviceTokenRotateParams, Lt as buildDeviceAuthPayload, M as validateDevicePairApproveParams, Mt as PROTOCOL_VERSION, N as validateDevicePairListParams, Nt as ErrorCodes, O as validateCronRunParams, Ot as validateWizardCancelParams, P as validateDevicePairRejectParams, Pt as errorShape, Q as validateNodePairListParams, Qt as verifyDeviceToken, R as validateExecApprovalRequestParams, Rt as buildDeviceAuthPayloadV3, S as validateConfigSchemaParams, St as validateTalkModeParams, T as validateCronAddParams, Tt as validateWakeParams, U as validateExecApprovalsSetParams, Ut as getPairedDevice, V as validateExecApprovalsNodeGetParams, Vt as approveDevicePairing, W as validateLogsTailParams, Wt as listDevicePairing, X as validateNodeListParams, Xt as summarizeDeviceTokens, Y as validateNodeInvokeResultParams, Yt as rotateDeviceToken, Z as validateNodePairApproveParams, Zt as updatePairedDeviceMetadata, _ as validateChatInjectParams, _t as validateSkillsBinsParams, a as validateAgentWaitParams, at as validateRequestFrame, b as validateConfigGetParams, bt as validateSkillsUpdateParams, c as validateAgentsFilesGetParams, ct as validateSendParams, d as validateAgentsListParams, dt as validateSessionsListParams, et as validateNodePairRequestParams, f as validateAgentsUpdateParams, ft as validateSessionsPatchParams, g as validateChatHistoryParams, gt as validateSessionsUsageParams, h as validateChatAbortParams, ht as validateSessionsResolveParams, i as validateAgentParams, in as verifyDeviceSignature, it as validatePushTestParams, j as validateCronUpdateParams, jt as validateWizardStatusParams, k as validateCronRunsParams, kt as validateWizardNextParams, l as validateAgentsFilesListParams, lt as validateSessionsCompactParams, m as validateChannelsStatusParams, mt as validateSessionsResetParams, n as formatValidationErrors, nt as validateNodeRenameParams, o as validateAgentsCreateParams, ot as validateSecretsResolveParams, p as validateChannelsLogoutParams, pt as validateSessionsPreviewParams, q as validateNodeEventParams, qt as requestDevicePairing, r as validateAgentIdentityParams, rn as normalizeDevicePublicKeyBase64Url, rt as validatePollParams, s as validateAgentsDeleteParams, st as validateSecretsResolveResult, tn as deriveDeviceIdFromPublicKey, tt as validateNodePairVerifyParams, u as validateAgentsFilesSetParams, ut as validateSessionsDeleteParams, v as validateChatSendParams, vt as validateSkillsInstallParams, w as validateConnectParams, wt as validateUpdateRunParams, x as validateConfigPatchParams, xt as validateTalkConfigParams, y as validateConfigApplyParams, yt as validateSkillsStatusParams, z as validateExecApprovalResolveParams, zt as normalizeDeviceMetadataForAuth } from "./client-BqLxmdBY.js";
43
+ import { c as ADMIN_SCOPE$3, d as isNodeRoleMethod, n as callGateway, p as loadGatewayTlsRuntime$1, u as authorizeOperatorScopesForMethod } from "./call-BHrnZxI1.js";
44
44
  import "./pairing-token-BXrId5bQ.js";
45
45
  import { t as safeEqualSecret } from "./secret-equal-Gla36CGi.js";
46
- import { a as isTrustedProxyAddress, c as pickPrimaryLanIPv4, d as resolveGatewayListenHosts, f as rawDataToString, l as resolveClientIp, n as isLoopbackAddress, o as isValidIPv4, r as isLoopbackHost, s as normalizeHostHeader, t as isLocalishHost, u as resolveGatewayBindHost } from "./net-CfwQaj6f.js";
47
- import { n as pickPrimaryTailnetIPv4, r as pickPrimaryTailnetIPv6 } from "./tailnet-D8ZmZFEq.js";
46
+ import { a as isTrustedProxyAddress, c as pickPrimaryLanIPv4, d as resolveGatewayListenHosts, f as rawDataToString, l as resolveClientIp, n as isLoopbackAddress, o as isValidIPv4, r as isLoopbackHost, s as normalizeHostHeader, t as isLocalishHost, u as resolveGatewayBindHost } from "./net-DFijUFfS.js";
47
+ import { n as pickPrimaryTailnetIPv4, r as pickPrimaryTailnetIPv6 } from "./tailnet-Bdvg29Ll.js";
48
48
  import { i as isSilentReplyText, n as SILENT_REPLY_TOKEN } from "./tokens-BaNa8Czl.js";
49
- import { a as getMachineDisplayName, i as startBrowserControlServiceFromConfig, n as createBrowserRouteDispatcher, r as createBrowserControlContext } from "./with-timeout-YDfOtKvh.js";
50
- import { j as runGlobalGatewayStopSafely, k as getGlobalHookRunner, o as normalizeReplyPayloadsForDelivery, t as deliverOutboundPayloads } from "./deliver-Bh8OdZ9H.js";
51
- import { c as detectMime } from "./image-ops-Ba5soKsa.js";
52
- import { b as resolveCronStorePath, x as saveCronStore, y as loadCronStore } from "./send-NBLtGiEh.js";
53
- import "./pi-embedded-helpers-D9bQLeoK.js";
54
- import { C as resolveToolProfilePolicy, _ as collectExplicitAllowlist, y as mergeAlsoAllowPolicy } from "./sandbox-C-8JxFW5.js";
49
+ import { a as getMachineDisplayName, i as startBrowserControlServiceFromConfig, n as createBrowserRouteDispatcher, r as createBrowserControlContext } from "./with-timeout-xp4bBUMy.js";
50
+ import { j as runGlobalGatewayStopSafely, k as getGlobalHookRunner, o as normalizeReplyPayloadsForDelivery, t as deliverOutboundPayloads } from "./deliver-HkPDAwY2.js";
51
+ import { c as detectMime } from "./image-ops-WJSAG5_7.js";
52
+ import { b as resolveCronStorePath, x as saveCronStore, y as loadCronStore } from "./send-B1C9OCt2.js";
53
+ import "./pi-embedded-helpers-CJZP0u_Y.js";
54
+ import { C as resolveToolProfilePolicy, _ as collectExplicitAllowlist, y as mergeAlsoAllowPolicy } from "./sandbox-CgTcwizP.js";
55
55
  import { i as listCoreToolSections, n as PROFILE_OPTIONS, o as resolveCoreToolProfiles } from "./tool-catalog-C04U7H3F.js";
56
- import "./chrome-NrlBIdcn.js";
56
+ import "./chrome-m5f8q2YK.js";
57
57
  import { i as enableTailscaleServe, n as disableTailscaleServe, o as getTailnetHostname, r as enableTailscaleFunnel, t as disableTailscaleFunnel } from "./tailscale-D4zNU-0Q.js";
58
- import { a as resolveGatewayAuth, c as AUTH_RATE_LIMIT_SCOPE_SHARED_SECRET, i as isLocalDirectRequest, l as createAuthRateLimiter, n as authorizeHttpGatewayConnect, o as AUTH_RATE_LIMIT_SCOPE_DEVICE_TOKEN, r as authorizeWsControlUiGatewayConnect, s as AUTH_RATE_LIMIT_SCOPE_HOOK_AUTH, t as assertGatewayAuthConfigured, u as normalizeRateLimitClientIp } from "./auth-BQOIUcK5.js";
59
- import { l as ensureGatewayStartupAuth, u as mergeGatewayTailscaleConfig } from "./server-context-vco06zxO.js";
60
- import "./paths-CGf7Nrz-.js";
58
+ import { a as resolveGatewayAuth, c as AUTH_RATE_LIMIT_SCOPE_SHARED_SECRET, i as isLocalDirectRequest, l as createAuthRateLimiter, n as authorizeHttpGatewayConnect, o as AUTH_RATE_LIMIT_SCOPE_DEVICE_TOKEN, r as authorizeWsControlUiGatewayConnect, s as AUTH_RATE_LIMIT_SCOPE_HOOK_AUTH, t as assertGatewayAuthConfigured, u as normalizeRateLimitClientIp } from "./auth-CgV_wGar.js";
59
+ import { l as ensureGatewayStartupAuth, u as mergeGatewayTailscaleConfig } from "./server-context-DAejIBKi.js";
60
+ import "./paths-BaZIBy3U.js";
61
61
  import { a as testRegexWithBoundedInput, i as compileSafeRegex } from "./redact-DwuqxSL3.js";
62
62
  import { o as isErrno, r as formatErrorMessage } from "./errors-CIvF1JsC.js";
63
- import { i as openFileWithinRoot, l as writeFileWithinRoot, s as readLocalFileSafely, t as SafeOpenError } from "./fs-safe-DTO6fZ7N.js";
64
- import { n as SsrFBlockedError } from "./proxy-env-C61VbSzS.js";
65
- import "./store-C4eyKOP_.js";
66
- import { n as inspectPortUsage, o as formatPortDiagnostics, t as ensurePortAvailable } from "./ports-jknVhOJa.js";
63
+ import { i as openFileWithinRoot, l as writeFileWithinRoot, s as readLocalFileSafely, t as SafeOpenError } from "./fs-safe-CYrszQI6.js";
64
+ import { n as SsrFBlockedError } from "./proxy-env-BEfRNPmW.js";
65
+ import "./store-OqcrqyHY.js";
66
+ import { n as inspectPortUsage, o as formatPortDiagnostics, t as ensurePortAvailable } from "./ports-BpZiRmiG.js";
67
67
  import { t as movePathToTrash } from "./trash-Dq9t9uID.js";
68
- import "./server-middleware-D5lrCTcL.js";
69
- import "./tool-images-C96-GuZE.js";
68
+ import "./server-middleware-B8_ZaIoM.js";
69
+ import "./tool-images-J7V8AfTu.js";
70
70
  import { a as normalizeElevatedLevel, c as normalizeUsageDisplay, d as supportsXHighThinking, l as normalizeVerboseLevel, n as formatXHighModelHint, o as normalizeReasoningLevel, s as normalizeThinkLevel, t as formatThinkingLevels } from "./thinking-CrcT589P.js";
71
- import "./models-config-C7yYEUbY.js";
72
- import "./exec-approvals-allowlist-CSsG6lrG.js";
73
- import "./exec-safe-bin-runtime-policy-ukabtnTn.js";
74
- import { n as loadModelCatalog } from "./model-catalog-B9Kd_iNy.js";
75
- import "./fetch-DmaNytop.js";
76
- import { g as registerUnhandledRejectionHandler } from "./audio-transcription-runner-D6NSiBUN.js";
77
- import { t as fetchWithSsrFGuard } from "./fetch-guard-0V5i-cZz.js";
78
- import { b as extractTextFromChatContent } from "./image-5Dop2pwF.js";
71
+ import "./models-config-VlzOga1W.js";
72
+ import "./exec-approvals-allowlist-CGQJSJfD.js";
73
+ import "./exec-safe-bin-runtime-policy-nkIQWrRj.js";
74
+ import { n as loadModelCatalog } from "./model-catalog-DorZGOmy.js";
75
+ import "./fetch-qkXypRi6.js";
76
+ import { g as registerUnhandledRejectionHandler } from "./audio-transcription-runner-C1T1UDgG.js";
77
+ import { t as fetchWithSsrFGuard } from "./fetch-guard-CS_3jTMA.js";
78
+ import { b as extractTextFromChatContent } from "./image-ktIANJRi.js";
79
79
  import "./tool-display-DJA6wQza.js";
80
- import "./api-key-rotation-BoN0bfDN.js";
80
+ import "./api-key-rotation-DUAhkuoF.js";
81
81
  import "./proxy-fetch-BSCpx7Yz.js";
82
- import "./ir-SEi7gUP9.js";
82
+ import "./ir-xdB7409t.js";
83
83
  import "./render-CCLsW6Lz.js";
84
- import { a as ToolInputError } from "./target-errors-Dq-K3j_S.js";
85
- import { r as isRestartEnabled } from "./commands-BYuioJO3.js";
86
- import "./commands-registry-DCOqmmUF.js";
84
+ import { a as ToolInputError } from "./target-errors-D0aWoxbs.js";
85
+ import { r as isRestartEnabled } from "./commands-CP-eujrx.js";
86
+ import "./commands-registry-BxWE_gts.js";
87
87
  import "./fetch-Cep8cXb2.js";
88
- import { a as readChannelAllowFromStoreSync } from "./pairing-store-B_UHGVGM.js";
88
+ import { a as readChannelAllowFromStoreSync } from "./pairing-store-CrEzWjmd.js";
89
89
  import { a as mergeExecApprovalsSocketDefaults, c as readExecApprovalsSnapshot, p as saveExecApprovals, r as ensureExecApprovals, s as normalizeExecApprovals, t as DEFAULT_EXEC_APPROVAL_TIMEOUT_MS } from "./exec-approvals-BXpO0clf.js";
90
- import { _ as matchSystemRunApprovalBinding, g as buildSystemRunApprovalBinding, h as resolveSystemRunApprovalRuntimeContext, m as resolveSystemRunApprovalRequestContext, v as missingSystemRunApprovalBinding, y as toSystemRunApprovalMismatchError } from "./nodes-screen-DF7EBTLu.js";
91
- import { n as resolveSystemRunCommand } from "./system-run-command-DVel5yZQ.js";
92
- import { a as loadCombinedSessionStoreForGateway, c as resolveGatewaySessionStoreTarget, f as computeBackoff, i as listSessionsFromStore, l as resolveSessionModelRef, o as loadSessionEntry, p as sleepWithAbort, r as listAgentsForGateway, s as pruneLegacyStoreKeys, t as canonicalizeSpawnedByForAgent, u as lookupContextTokens } from "./session-utils-LerBXiBL.js";
90
+ import { _ as matchSystemRunApprovalBinding, g as buildSystemRunApprovalBinding, h as resolveSystemRunApprovalRuntimeContext, m as resolveSystemRunApprovalRequestContext, v as missingSystemRunApprovalBinding, y as toSystemRunApprovalMismatchError } from "./nodes-screen-DWVpmvMz.js";
91
+ import { n as resolveSystemRunCommand } from "./system-run-command-B1auaqvg.js";
92
+ import { a as loadCombinedSessionStoreForGateway, c as resolveGatewaySessionStoreTarget, f as computeBackoff, i as listSessionsFromStore, l as resolveSessionModelRef, o as loadSessionEntry, p as sleepWithAbort, r as listAgentsForGateway, s as pruneLegacyStoreKeys, t as canonicalizeSpawnedByForAgent, u as lookupContextTokens } from "./session-utils-CDs6jjz-.js";
93
93
  import { c as hasNonzeroUsage, i as loadSessionUsageTimeSeries, n as loadCostUsageSummary, r as loadSessionCostSummary, s as deriveSessionTotalTokens, t as discoverAllSessions } from "./session-cost-usage-TIBv8Nm4.js";
94
94
  import { n as formatTokenCount, r as formatUsd } from "./usage-format-eNPY7j3q.js";
95
- import { _ as updatePairedNodeMetadata, a as getRemoteSkillEligibility, b as getSkillsSnapshotVersion, c as refreshRemoteBinsForConnectedNodes, d as setSkillsRemoteRegistry, f as approveNodePairing, g as requestNodePairing, h as renamePairedNode, l as refreshRemoteNodeBins, m as rejectNodePairing, o as primeRemoteSkillsCache, p as listNodePairing, s as recordRemoteNodeInfo, u as removeRemoteNodeInfo, v as verifyNodeToken, x as registerSkillsChangeListener } from "./skill-commands-CeEZlRJj.js";
96
- import { t as listAgentWorkspaceDirs } from "./workspace-dirs-BSD3q0pa.js";
97
- import { t as getChannelActivity } from "./channel-activity-CtUzm0zi.js";
95
+ import { _ as updatePairedNodeMetadata, a as getRemoteSkillEligibility, b as getSkillsSnapshotVersion, c as refreshRemoteBinsForConnectedNodes, d as setSkillsRemoteRegistry, f as approveNodePairing, g as requestNodePairing, h as renamePairedNode, l as refreshRemoteNodeBins, m as rejectNodePairing, o as primeRemoteSkillsCache, p as listNodePairing, s as recordRemoteNodeInfo, u as removeRemoteNodeInfo, v as verifyNodeToken, x as registerSkillsChangeListener } from "./skill-commands-DDRb6be1.js";
96
+ import { t as listAgentWorkspaceDirs } from "./workspace-dirs-BY9k_sye.js";
97
+ import { t as getChannelActivity } from "./channel-activity-CudRDPXk.js";
98
98
  import { n as normalizePollInput } from "./polls-C67dmFc-.js";
99
- import "./tables-CM4RCywz.js";
100
- import "./server-lifecycle-BnUgXA5X.js";
99
+ import "./tables-BSWzRw5b.js";
100
+ import "./server-lifecycle-C0IxrwRk.js";
101
101
  import { i as parseAbsoluteTimeMs, n as resolveCronStaggerMs, r as resolveDefaultCronStaggerMs, t as normalizeCronStaggerMs } from "./stagger-C4U8O7GM.js";
102
- import { n as resolveMessageChannelSelection } from "./channel-selection-BGFLNPuZ.js";
103
- import { i as buildChannelUiCatalog, t as applyPluginAutoEnable } from "./plugin-auto-enable-DFhRs_Ha.js";
104
- import "./send-Cp2_MKSV.js";
105
- import "./outbound-attachment-MWhTrPYa.js";
102
+ import { n as resolveMessageChannelSelection } from "./channel-selection-D2KncGab.js";
103
+ import { i as buildChannelUiCatalog, t as applyPluginAutoEnable } from "./plugin-auto-enable-BJfAN-kO.js";
104
+ import "./send-BCdpg1w2.js";
105
+ import "./outbound-attachment-BewsAqvJ.js";
106
106
  import "./delivery-queue-Bl-IGZt-.js";
107
- import "./send-DrEo-BBc.js";
108
- import { a as resolveSubagentToolPolicy, i as resolveGroupToolPolicy, r as resolveEffectiveToolPolicy } from "./pi-tools.policy-B1sTh_x1.js";
107
+ import "./send-CkFo9xha.js";
108
+ import { a as resolveSubagentToolPolicy, i as resolveGroupToolPolicy, r as resolveEffectiveToolPolicy } from "./pi-tools.policy-B72vqcZC.js";
109
109
  import "./proxy-Dgwoliym.js";
110
- import { f as isKnownSecretTargetId, n as GATEWAY_AUTH_SURFACE_PATHS, r as evaluateGatewayAuthSurfaceStates } from "./runtime-config-collectors-mLMSoY2n.js";
111
- import "./command-secret-targets-CVAt80vu.js";
112
- import { C as normalizeControlUiBasePath, S as buildControlUiAvatarUrl, c as handleReset, w as resolveAssistantAvatarUrl, x as CONTROL_UI_AVATAR_PREFIX } from "./onboard-helpers-Mort99IL.js";
110
+ import { f as isKnownSecretTargetId, n as GATEWAY_AUTH_SURFACE_PATHS, r as evaluateGatewayAuthSurfaceStates } from "./runtime-config-collectors-D0I8Qs4G.js";
111
+ import "./command-secret-targets-_FGz0zdz.js";
112
+ import { C as normalizeControlUiBasePath, S as buildControlUiAvatarUrl, c as handleReset, w as resolveAssistantAvatarUrl, x as CONTROL_UI_AVATAR_PREFIX } from "./onboard-helpers-CPO08jBg.js";
113
113
  import "./prompt-style-BfCTyCoH.js";
114
- import "./pairing-labels-C1jblVNc.js";
115
- import { i as resolveMemoryBackendConfig, r as getMemorySearchManager } from "./memory-cli-CEZedlbs.js";
116
- import { r as resolveMemorySearchConfig } from "./manager-DKcbmdLj.js";
117
- import "./query-expansion-BlsKiJrV.js";
114
+ import "./pairing-labels-BU1EH5qm.js";
115
+ import { i as resolveMemoryBackendConfig, r as getMemorySearchManager } from "./memory-cli-B4tlY2Jz.js";
116
+ import { r as resolveMemorySearchConfig } from "./manager-DstlJwRR.js";
117
+ import "./query-expansion-DfWHFCTw.js";
118
118
  import { t as formatDocsLink } from "./links-BVDZVrXu.js";
119
119
  import { n as runCommandWithRuntime } from "./cli-utils-BKqG4ZT-.js";
120
120
  import { t as formatHelpExamples } from "./help-format-CMlnk7BV.js";
@@ -125,44 +125,44 @@ import { n as DEFAULT_GATEWAY_HTTP_TOOL_DENY } from "./dangerous-tools-Dpi4An5r.
125
125
  import { n as inheritOptionFromParent } from "./command-options-DVCpMofi.js";
126
126
  import { t as WizardCancelledError } from "./prompts-l_pUOv42.js";
127
127
  import { t as resolveChannelDefaultAccountId } from "./helpers-D7MilaX-.js";
128
- import { a as pruneAgentConfig, i as loadAgentIdentity, r as findAgentEntryIndex, t as applyAgentConfig } from "./agents.config-g0LyahNR.js";
129
- import { t as isWithinDir } from "./path-safety-BjIM4N4t.js";
130
- import "./install-safe-path-DgGlNCpx.js";
131
- import "./skill-scanner-DGx7tLvP.js";
132
- import { n as formatConfigIssueLines } from "./issue-format-DEHEwGJB.js";
128
+ import { a as pruneAgentConfig, i as loadAgentIdentity, r as findAgentEntryIndex, t as applyAgentConfig } from "./agents.config-BSkzwDQZ.js";
129
+ import { t as isWithinDir } from "./path-safety-ClQO4BB6.js";
130
+ import "./install-safe-path-BmAf3bF5.js";
131
+ import "./skill-scanner-BdA-XFky.js";
132
+ import { n as formatConfigIssueLines } from "./issue-format-DaXc0Ssz.js";
133
133
  import { t as buildChannelAccountSnapshot } from "./status-dOhj12u0.js";
134
- import "./channels-status-issues-UpBSKB6j.js";
135
- import { a as buildBaseHints, i as applySensitiveHints, n as redactConfigSnapshot, o as mapSensitivePaths, r as restoreRedactedValues, s as applyDerivedTags, t as redactConfigObject } from "./redact-snapshot-M27Gs1s9.js";
136
- import "./daemon-install-helpers-so86sfkZ.js";
134
+ import "./channels-status-issues-JgPH8x7b.js";
135
+ import { a as buildBaseHints, i as applySensitiveHints, n as redactConfigSnapshot, o as mapSensitivePaths, r as restoreRedactedValues, s as applyDerivedTags, t as redactConfigObject } from "./redact-snapshot-BE1hcZlN.js";
136
+ import "./daemon-install-helpers-CyjpUUrm.js";
137
137
  import "./runtime-guard-DFO22ThU.js";
138
- import "./systemd-BPu08aN2.js";
139
- import "./service-B6Pm7AZA.js";
140
- import "./lifecycle-core-t2Q34Tiu.js";
141
- import "./systemd-hints-PEGoMeNi.js";
138
+ import "./systemd-CvSjUuUT.js";
139
+ import "./service-T5lT7h-M.js";
140
+ import "./lifecycle-core-BinqEyma.js";
141
+ import "./systemd-hints-DPrvbOr-.js";
142
142
  import { t as parsePort$1 } from "./parse-port-CboE2EQm.js";
143
- import { n as addGatewayServiceCommands } from "./daemon-cli-D7rQUQZq.js";
144
- import "./diagnostics-Cuvdgf7E.js";
143
+ import { n as addGatewayServiceCommands } from "./daemon-cli-Bntp6emS.js";
144
+ import "./diagnostics-Dys24A-s.js";
145
145
  import "./table-BR-agoRi.js";
146
146
  import { n as resolveWideAreaDiscoveryDomain, r as writeWideAreaGatewayZone } from "./widearea-dns-CSYY8XGu.js";
147
- import { i as toOptionString, n as extractGatewayMiskeys, r as maybeExplainGatewayServiceStop, t as describeUnknownError } from "./shared-BVq1q5D-.js";
148
- import { a as probeGateway, n as collectEnabledInsecureOrDangerousFlags } from "./audit-C3kgCKKq.js";
149
- import { t as discoverGatewayBeacons } from "./bonjour-discovery-DRbbMuPV.js";
150
- import { i as pickGatewaySelfPresence, r as getStatusSummary } from "./status-4fmTPmZ8.js";
151
- import { a as styleHealthChannelLine, c as setHeartbeatsEnabled, l as startHeartbeatRunner, n as getHealthSnapshot, s as runHeartbeatOnce, t as formatHealthChannelLines, u as isCronSystemEvent } from "./health-Ry4jLJFh.js";
152
- import { a as resolveControlUiRootSync, i as resolveControlUiRootOverrideSync, t as ensureControlUiAssetsBuilt } from "./control-ui-assets-CYQNSPY0.js";
153
- import { h as normalizeUpdateChannel, l as DEFAULT_PACKAGE_CHANNEL, n as checkUpdateStatus, o as resolveNpmChannelTag, r as compareSemverStrings } from "./channel-account-context-CZg6xYM_.js";
154
- import { a as resolveCommandSecretsFromActiveRuntimeSnapshot, i as prepareSecretsRuntimeSnapshot, n as clearSecretsRuntimeSnapshot, r as getActiveSecretsRuntimeSnapshot, t as activateSecretsRuntimeSnapshot } from "./runtime-D_htBj_7.js";
155
- import "./onboarding.secret-input-CG_ZOH5i.js";
156
- import { t as runOnboardingWizard } from "./onboarding-DyjqYKzZ.js";
157
- import { a as sendApnsAlert, c as parseMessageWithAttachments, d as shouldLogWs, f as summarizeAgentEventForWsLog, i as resolveApnsAuthConfigFromEnv, l as formatForLog, n as normalizeApnsEnvironment, o as sendApnsBackgroundWake, p as setGatewayWsLogStyle, s as normalizeRpcAttachmentsToChatAttachments, t as loadApnsRegistration, u as logWs } from "./push-apns-BPEC7SVy.js";
147
+ import { i as toOptionString, n as extractGatewayMiskeys, r as maybeExplainGatewayServiceStop, t as describeUnknownError } from "./shared-BrmHcYtZ.js";
148
+ import { a as probeGateway, n as collectEnabledInsecureOrDangerousFlags } from "./audit-BJ5b9jj6.js";
149
+ import { t as discoverGatewayBeacons } from "./bonjour-discovery-ttcR8uJV.js";
150
+ import { i as pickGatewaySelfPresence, r as getStatusSummary } from "./status-KrF4yDJE.js";
151
+ import { a as styleHealthChannelLine, c as setHeartbeatsEnabled, l as startHeartbeatRunner, n as getHealthSnapshot, s as runHeartbeatOnce, t as formatHealthChannelLines, u as isCronSystemEvent } from "./health-CWuNlSLA.js";
152
+ import { a as resolveControlUiRootSync, i as resolveControlUiRootOverrideSync, t as ensureControlUiAssetsBuilt } from "./control-ui-assets-1CYoFkJQ.js";
153
+ import { h as normalizeUpdateChannel, l as DEFAULT_PACKAGE_CHANNEL, n as checkUpdateStatus, o as resolveNpmChannelTag, r as compareSemverStrings } from "./channel-account-context-BjsJwBrl.js";
154
+ import { a as resolveCommandSecretsFromActiveRuntimeSnapshot, i as prepareSecretsRuntimeSnapshot, n as clearSecretsRuntimeSnapshot, r as getActiveSecretsRuntimeSnapshot, t as activateSecretsRuntimeSnapshot } from "./runtime-CagDsJFx.js";
155
+ import "./onboarding.secret-input-B_lhRVqi.js";
156
+ import { t as runOnboardingWizard } from "./onboarding-CWdu0f2f.js";
157
+ import { a as sendApnsAlert, c as parseMessageWithAttachments, d as shouldLogWs, f as summarizeAgentEventForWsLog, i as resolveApnsAuthConfigFromEnv, l as formatForLog, n as normalizeApnsEnvironment, o as sendApnsBackgroundWake, p as setGatewayWsLogStyle, s as normalizeRpcAttachmentsToChatAttachments, t as loadApnsRegistration, u as logWs } from "./push-apns-Duv_LH_E.js";
158
158
  import { T as resolveGmailHookRuntimeConfig, _ as buildGogWatchServeArgs, i as ensureTailscaleEndpoint, v as buildGogWatchStartArgs } from "./gmail-setup-utils-UZt9IM9y.js";
159
- import { n as isNodeCommandAllowed, r as resolveNodeCommandAllowlist } from "./node-command-policy-yJ_VpCHq.js";
160
- import "./node-service-9R10zILv.js";
161
- import "./status.update-BincwEhI.js";
162
- import { t as installSkill } from "./skills-install-CEgXF7D3.js";
163
- import { t as runGatewayUpdate } from "./update-runner-C-d9Tjog.js";
164
- import { i as shouldIncludeHook, r as resolveHookConfig, t as loadWorkspaceHookEntries } from "./workspace-CZkOfauh.js";
165
- import { n as forceFreePortAndWait, r as waitForPortBindable } from "./ports-D7wHAklC.js";
159
+ import { n as isNodeCommandAllowed, r as resolveNodeCommandAllowlist } from "./node-command-policy-BMgJ81FO.js";
160
+ import "./node-service-BeDB4avc.js";
161
+ import "./status.update-ovXdI8fy.js";
162
+ import { t as installSkill } from "./skills-install-BG5c8jOQ.js";
163
+ import { t as runGatewayUpdate } from "./update-runner-kKiJKth8.js";
164
+ import { i as shouldIncludeHook, r as resolveHookConfig, t as loadWorkspaceHookEntries } from "./workspace-BXI1yRZ5.js";
165
+ import { n as forceFreePortAndWait, r as waitForPortBindable } from "./ports-BUQm2J6L.js";
166
166
  import { spawn, spawnSync } from "node:child_process";
167
167
  import { fileURLToPath, pathToFileURL } from "node:url";
168
168
  import os from "node:os";
@@ -171,7 +171,7 @@ import * as fsSync from "node:fs";
171
171
  import fs from "node:fs";
172
172
  import chalk from "chalk";
173
173
  import { isDeepStrictEqual } from "node:util";
174
- import fsPromises from "node:fs/promises";
174
+ import fs$1 from "node:fs/promises";
175
175
  import crypto, { createHash, randomBytes, randomUUID } from "node:crypto";
176
176
  import { z } from "zod";
177
177
  import { CURRENT_SESSION_VERSION, SessionManager } from "@mariozechner/pi-coding-agent";
@@ -1241,7 +1241,7 @@ function resolveCheckIntervalMs(cfg) {
1241
1241
  }
1242
1242
  async function readState(statePath) {
1243
1243
  try {
1244
- const raw = await fsPromises.readFile(statePath, "utf-8");
1244
+ const raw = await fs$1.readFile(statePath, "utf-8");
1245
1245
  const parsed = JSON.parse(raw);
1246
1246
  return parsed && typeof parsed === "object" ? parsed : {};
1247
1247
  } catch {
@@ -1322,7 +1322,7 @@ async function runAutoUpdateCommand(params) {
1322
1322
  path.join(params.root, "dist", "index.mjs")
1323
1323
  ];
1324
1324
  for (const candidate of candidates) try {
1325
- await fsPromises.access(candidate);
1325
+ await fs$1.access(candidate);
1326
1326
  argv.push(execPath, candidate, ...baseArgs);
1327
1327
  break;
1328
1328
  } catch {}
@@ -4453,20 +4453,20 @@ async function drainPendingWrite(filePath) {
4453
4453
  if (pending) await pending.catch(() => void 0);
4454
4454
  }
4455
4455
  async function pruneIfNeeded(filePath, opts) {
4456
- const stat = await fsPromises.stat(filePath).catch(() => null);
4456
+ const stat = await fs$1.stat(filePath).catch(() => null);
4457
4457
  if (!stat || stat.size <= opts.maxBytes) return;
4458
- const lines = (await fsPromises.readFile(filePath, "utf-8").catch(() => "")).split("\n").map((l) => l.trim()).filter(Boolean);
4458
+ const lines = (await fs$1.readFile(filePath, "utf-8").catch(() => "")).split("\n").map((l) => l.trim()).filter(Boolean);
4459
4459
  const kept = lines.slice(Math.max(0, lines.length - opts.keepLines));
4460
4460
  const { randomBytes } = await import("node:crypto");
4461
4461
  const tmp = `${filePath}.${process.pid}.${randomBytes(8).toString("hex")}.tmp`;
4462
- await fsPromises.writeFile(tmp, `${kept.join("\n")}\n`, "utf-8");
4463
- await fsPromises.rename(tmp, filePath);
4462
+ await fs$1.writeFile(tmp, `${kept.join("\n")}\n`, "utf-8");
4463
+ await fs$1.rename(tmp, filePath);
4464
4464
  }
4465
4465
  async function appendCronRunLog(filePath, entry, opts) {
4466
4466
  const resolved = path.resolve(filePath);
4467
4467
  const next = (writesByPath.get(resolved) ?? Promise.resolve()).catch(() => void 0).then(async () => {
4468
- await fsPromises.mkdir(path.dirname(resolved), { recursive: true });
4469
- await fsPromises.appendFile(resolved, `${JSON.stringify(entry)}\n`, "utf-8");
4468
+ await fs$1.mkdir(path.dirname(resolved), { recursive: true });
4469
+ await fs$1.appendFile(resolved, `${JSON.stringify(entry)}\n`, "utf-8");
4470
4470
  await pruneIfNeeded(resolved, {
4471
4471
  maxBytes: opts?.maxBytes ?? DEFAULT_CRON_RUN_LOG_MAX_BYTES,
4472
4472
  keepLines: opts?.keepLines ?? DEFAULT_CRON_RUN_LOG_KEEP_LINES
@@ -4560,7 +4560,7 @@ function filterRunLogEntries(entries, opts) {
4560
4560
  async function readCronRunLogEntriesPage(filePath, opts) {
4561
4561
  await drainPendingWrite(filePath);
4562
4562
  const limit = Math.max(1, Math.min(200, Math.floor(opts?.limit ?? 50)));
4563
- const raw = await fsPromises.readFile(path.resolve(filePath), "utf-8").catch(() => "");
4563
+ const raw = await fs$1.readFile(path.resolve(filePath), "utf-8").catch(() => "");
4564
4564
  const statuses = normalizeRunStatuses(opts);
4565
4565
  const deliveryStatuses = normalizeDeliveryStatuses(opts);
4566
4566
  const query = opts?.query?.trim().toLowerCase() ?? "";
@@ -4596,7 +4596,7 @@ async function readCronRunLogEntriesPageAll(opts) {
4596
4596
  const query = opts.query?.trim().toLowerCase() ?? "";
4597
4597
  const sortDir = opts.sortDir === "asc" ? "asc" : "desc";
4598
4598
  const runsDir = path.resolve(path.dirname(path.resolve(opts.storePath)), "runs");
4599
- const jsonlFiles = (await fsPromises.readdir(runsDir, { withFileTypes: true }).catch(() => [])).filter((entry) => entry.isFile() && entry.name.endsWith(".jsonl")).map((entry) => path.join(runsDir, entry.name));
4599
+ const jsonlFiles = (await fs$1.readdir(runsDir, { withFileTypes: true }).catch(() => [])).filter((entry) => entry.isFile() && entry.name.endsWith(".jsonl")).map((entry) => path.join(runsDir, entry.name));
4600
4600
  if (jsonlFiles.length === 0) return {
4601
4601
  entries: [],
4602
4602
  total: 0,
@@ -4607,7 +4607,7 @@ async function readCronRunLogEntriesPageAll(opts) {
4607
4607
  };
4608
4608
  await Promise.all(jsonlFiles.map((f) => drainPendingWrite(f)));
4609
4609
  const filtered = filterRunLogEntries((await Promise.all(jsonlFiles.map(async (filePath) => {
4610
- return parseAllRunLogEntries(await fsPromises.readFile(filePath, "utf-8").catch(() => ""));
4610
+ return parseAllRunLogEntries(await fs$1.readFile(filePath, "utf-8").catch(() => ""));
4611
4611
  }))).flat(), {
4612
4612
  statuses,
4613
4613
  deliveryStatuses,
@@ -9836,7 +9836,7 @@ function resolveWorkspaceFilePathResultOrThrow(params) {
9836
9836
  }
9837
9837
  async function resolveWorkspaceRealPath(workspaceDir) {
9838
9838
  try {
9839
- return await fsPromises.realpath(workspaceDir);
9839
+ return await fs$1.realpath(workspaceDir);
9840
9840
  } catch {
9841
9841
  return path.resolve(workspaceDir);
9842
9842
  }
@@ -9865,7 +9865,7 @@ async function resolveAgentWorkspaceFilePath(params) {
9865
9865
  };
9866
9866
  let candidateLstat;
9867
9867
  try {
9868
- candidateLstat = await fsPromises.lstat(candidatePath);
9868
+ candidateLstat = await fs$1.lstat(candidatePath);
9869
9869
  } catch (err) {
9870
9870
  return resolveWorkspaceFilePathResultOrThrow({
9871
9871
  error: err,
@@ -9876,7 +9876,7 @@ async function resolveAgentWorkspaceFilePath(params) {
9876
9876
  if (candidateLstat.isSymbolicLink()) {
9877
9877
  let targetReal;
9878
9878
  try {
9879
- targetReal = await fsPromises.realpath(candidatePath);
9879
+ targetReal = await fs$1.realpath(candidatePath);
9880
9880
  } catch (err) {
9881
9881
  return resolveWorkspaceFilePathResultOrThrow({
9882
9882
  error: err,
@@ -9886,7 +9886,7 @@ async function resolveAgentWorkspaceFilePath(params) {
9886
9886
  }
9887
9887
  let targetStat;
9888
9888
  try {
9889
- targetStat = await fsPromises.stat(targetReal);
9889
+ targetStat = await fs$1.stat(targetReal);
9890
9890
  } catch (err) {
9891
9891
  return resolveWorkspaceFilePathResultOrThrow({
9892
9892
  error: err,
@@ -9924,13 +9924,13 @@ async function resolveAgentWorkspaceFilePath(params) {
9924
9924
  return {
9925
9925
  kind: "ready",
9926
9926
  requestPath,
9927
- ioPath: await fsPromises.realpath(candidatePath).catch(() => candidatePath),
9927
+ ioPath: await fs$1.realpath(candidatePath).catch(() => candidatePath),
9928
9928
  workspaceReal
9929
9929
  };
9930
9930
  }
9931
9931
  async function statFileSafely(filePath) {
9932
9932
  try {
9933
- const [stat, lstat] = await Promise.all([fsPromises.stat(filePath), fsPromises.lstat(filePath)]);
9933
+ const [stat, lstat] = await Promise.all([fs$1.stat(filePath), fs$1.lstat(filePath)]);
9934
9934
  if (lstat.isSymbolicLink() || !stat.isFile()) return null;
9935
9935
  if (stat.nlink > 1) return null;
9936
9936
  if (!sameFileIdentity(stat, lstat)) return null;
@@ -10024,7 +10024,7 @@ function respondAgentNotFound(respond, agentId) {
10024
10024
  async function moveToTrashBestEffort(pathname) {
10025
10025
  if (!pathname) return;
10026
10026
  try {
10027
- await fsPromises.access(pathname);
10027
+ await fs$1.access(pathname);
10028
10028
  } catch {
10029
10029
  return;
10030
10030
  }
@@ -10100,7 +10100,7 @@ const agentsHandlers = {
10100
10100
  dir: workspaceDir,
10101
10101
  ensureBootstrapFiles: !Boolean(nextConfig.agents?.defaults?.skipBootstrap)
10102
10102
  });
10103
- await fsPromises.mkdir(resolveSessionTranscriptsDirForAgent(agentId), { recursive: true });
10103
+ await fs$1.mkdir(resolveSessionTranscriptsDirForAgent(agentId), { recursive: true });
10104
10104
  await writeConfigFile(nextConfig);
10105
10105
  const safeName = sanitizeIdentityLine(rawName);
10106
10106
  const emoji = resolveOptionalStringParam(params.emoji);
@@ -10113,7 +10113,7 @@ const agentsHandlers = {
10113
10113
  ...avatar ? [`- Avatar: ${sanitizeIdentityLine(avatar)}`] : [],
10114
10114
  ""
10115
10115
  ];
10116
- await fsPromises.appendFile(identityPath, lines.join("\n"), "utf-8");
10116
+ await fs$1.appendFile(identityPath, lines.join("\n"), "utf-8");
10117
10117
  respond(true, {
10118
10118
  ok: true,
10119
10119
  agentId,
@@ -10148,9 +10148,9 @@ const agentsHandlers = {
10148
10148
  });
10149
10149
  if (avatar) {
10150
10150
  const workspace = workspaceDir ?? resolveAgentWorkspaceDir(nextConfig, agentId);
10151
- await fsPromises.mkdir(workspace, { recursive: true });
10151
+ await fs$1.mkdir(workspace, { recursive: true });
10152
10152
  const identityPath = path.join(workspace, DEFAULT_IDENTITY_FILENAME);
10153
- await fsPromises.appendFile(identityPath, `\n- Avatar: ${sanitizeIdentityLine(avatar)}\n`, "utf-8");
10153
+ await fs$1.appendFile(identityPath, `\n- Avatar: ${sanitizeIdentityLine(avatar)}\n`, "utf-8");
10154
10154
  }
10155
10155
  respond(true, {
10156
10156
  ok: true,
@@ -10274,7 +10274,7 @@ const agentsHandlers = {
10274
10274
  const resolved = resolveAgentWorkspaceFileOrRespondError(params, respond);
10275
10275
  if (!resolved) return;
10276
10276
  const { agentId, workspaceDir, name } = resolved;
10277
- await fsPromises.mkdir(workspaceDir, { recursive: true });
10277
+ await fs$1.mkdir(workspaceDir, { recursive: true });
10278
10278
  const filePath = path.join(workspaceDir, name);
10279
10279
  const resolvedPath = await resolveWorkspaceFilePathOrRespond({
10280
10280
  respond,
@@ -12593,14 +12593,14 @@ function isRollingLogFile(file) {
12593
12593
  return ROLLING_LOG_RE.test(path.basename(file));
12594
12594
  }
12595
12595
  async function resolveLogFile(file) {
12596
- if (await fsPromises.stat(file).catch(() => null)) return file;
12596
+ if (await fs$1.stat(file).catch(() => null)) return file;
12597
12597
  if (!isRollingLogFile(file)) return file;
12598
12598
  const dir = path.dirname(file);
12599
- const entries = await fsPromises.readdir(dir, { withFileTypes: true }).catch(() => null);
12599
+ const entries = await fs$1.readdir(dir, { withFileTypes: true }).catch(() => null);
12600
12600
  if (!entries) return file;
12601
12601
  return (await Promise.all(entries.filter((entry) => entry.isFile() && ROLLING_LOG_RE.test(entry.name)).map(async (entry) => {
12602
12602
  const fullPath = path.join(dir, entry.name);
12603
- const fileStat = await fsPromises.stat(fullPath).catch(() => null);
12603
+ const fileStat = await fs$1.stat(fullPath).catch(() => null);
12604
12604
  return fileStat ? {
12605
12605
  path: fullPath,
12606
12606
  mtimeMs: fileStat.mtimeMs
@@ -12608,7 +12608,7 @@ async function resolveLogFile(file) {
12608
12608
  }))).filter((entry) => Boolean(entry)).toSorted((a, b) => b.mtimeMs - a.mtimeMs)[0]?.path ?? file;
12609
12609
  }
12610
12610
  async function readLogSlice(params) {
12611
- const stat = await fsPromises.stat(params.file).catch(() => null);
12611
+ const stat = await fs$1.stat(params.file).catch(() => null);
12612
12612
  if (!stat) return {
12613
12613
  cursor: 0,
12614
12614
  size: 0,
@@ -12646,7 +12646,7 @@ async function readLogSlice(params) {
12646
12646
  truncated,
12647
12647
  reset
12648
12648
  };
12649
- const handle = await fsPromises.open(params.file, "r");
12649
+ const handle = await fs$1.open(params.file, "r");
12650
12650
  try {
12651
12651
  let prefix = "";
12652
12652
  if (start > 0) {
@@ -13628,7 +13628,7 @@ const nodeHandlers = {
13628
13628
  const p = params;
13629
13629
  const payloadJSON = typeof p.payloadJSON === "string" ? p.payloadJSON : p.payload !== void 0 ? JSON.stringify(p.payload) : null;
13630
13630
  await respondUnavailableOnThrow(respond, async () => {
13631
- const { handleNodeEvent } = await import("./server-node-events-BTTa3-DI.js");
13631
+ const { handleNodeEvent } = await import("./server-node-events-1jnvsPrM.js");
13632
13632
  const nodeId = client?.connect?.device?.id ?? client?.connect?.client?.id ?? "node";
13633
13633
  await handleNodeEvent({
13634
13634
  deps: context.deps,
@@ -16659,7 +16659,7 @@ function normalizeAgentPayload(payload) {
16659
16659
  async function startBrowserControlServerIfEnabled() {
16660
16660
  if (isTruthyEnvValue(process.env.OPENCLAW_SKIP_BROWSER_CONTROL_SERVER)) return null;
16661
16661
  const override = process.env.OPENCLAW_BROWSER_CONTROL_MODULE?.trim();
16662
- const mod = override ? await import(override) : await import("./server-Cz0R7Scf.js");
16662
+ const mod = override ? await import(override) : await import("./server-EsF-rWXM.js");
16663
16663
  const start = typeof mod.startBrowserControlServiceFromConfig === "function" ? mod.startBrowserControlServiceFromConfig : mod.startBrowserControlServerFromConfig;
16664
16664
  const stop = typeof mod.stopBrowserControlService === "function" ? mod.stopBrowserControlService : mod.stopBrowserControlServer;
16665
16665
  if (!start) return null;
@@ -16887,7 +16887,7 @@ async function resolveFileWithinRoot(rootReal, urlPath) {
16887
16887
  if (normalized.endsWith("/")) return await tryOpen(path.posix.join(rel, "index.html"));
16888
16888
  const candidate = path.join(rootReal, rel);
16889
16889
  try {
16890
- const st = await fsPromises.lstat(candidate);
16890
+ const st = await fs$1.lstat(candidate);
16891
16891
  if (st.isSymbolicLink()) return null;
16892
16892
  if (st.isDirectory()) return await tryOpen(path.posix.join(rel, "index.html"));
16893
16893
  } catch {}
@@ -16924,8 +16924,8 @@ async function resolveA2uiRoot() {
16924
16924
  for (const dir of candidates) try {
16925
16925
  const indexPath = path.join(dir, "index.html");
16926
16926
  const bundlePath = path.join(dir, "a2ui.bundle.js");
16927
- await fsPromises.stat(indexPath);
16928
- await fsPromises.stat(bundlePath);
16927
+ await fs$1.stat(indexPath);
16928
+ await fs$1.stat(bundlePath);
16929
16929
  return dir;
16930
16930
  } catch {}
16931
16931
  return null;
@@ -16934,7 +16934,7 @@ async function resolveA2uiRootReal() {
16934
16934
  if (cachedA2uiRootReal !== void 0 && (cachedA2uiRootReal !== null || Date.now() - cachedA2uiResolvedAtMs < A2UI_ROOT_RETRY_NULL_AFTER_MS)) return cachedA2uiRootReal;
16935
16935
  if (!resolvingA2uiRoot) resolvingA2uiRoot = (async () => {
16936
16936
  const root = await resolveA2uiRoot();
16937
- cachedA2uiRootReal = root ? await fsPromises.realpath(root) : null;
16937
+ cachedA2uiRootReal = root ? await fs$1.realpath(root) : null;
16938
16938
  cachedA2uiResolvedAtMs = Date.now();
16939
16939
  resolvingA2uiRoot = null;
16940
16940
  return cachedA2uiRootReal;
@@ -17155,13 +17155,13 @@ function normalizeBasePath(rawPath) {
17155
17155
  }
17156
17156
  async function prepareCanvasRoot(rootDir) {
17157
17157
  await ensureDir(rootDir);
17158
- const rootReal = await fsPromises.realpath(rootDir);
17158
+ const rootReal = await fs$1.realpath(rootDir);
17159
17159
  try {
17160
17160
  const indexPath = path.join(rootReal, "index.html");
17161
- await fsPromises.stat(indexPath);
17161
+ await fs$1.stat(indexPath);
17162
17162
  } catch {
17163
17163
  try {
17164
- await fsPromises.writeFile(path.join(rootReal, "index.html"), defaultIndexHTML(), "utf8");
17164
+ await fs$1.writeFile(path.join(rootReal, "index.html"), defaultIndexHTML(), "utf8");
17165
17165
  } catch {}
17166
17166
  }
17167
17167
  return rootReal;
@@ -20206,7 +20206,7 @@ async function resolveGatewayOwnerStatus(pid, payload, platform, port) {
20206
20206
  }
20207
20207
  async function readLockPayload(lockPath) {
20208
20208
  try {
20209
- const raw = await fsPromises.readFile(lockPath, "utf8");
20209
+ const raw = await fs$1.readFile(lockPath, "utf8");
20210
20210
  const parsed = JSON.parse(raw);
20211
20211
  if (typeof parsed.pid !== "number") return null;
20212
20212
  if (typeof parsed.createdAt !== "string") return null;
@@ -20241,11 +20241,11 @@ async function acquireGatewayLock(opts = {}) {
20241
20241
  const platform = opts.platform ?? process.platform;
20242
20242
  const port = opts.port;
20243
20243
  const { lockPath, configPath } = resolveGatewayLockPath(env);
20244
- await fsPromises.mkdir(path.dirname(lockPath), { recursive: true });
20244
+ await fs$1.mkdir(path.dirname(lockPath), { recursive: true });
20245
20245
  const startedAt = Date.now();
20246
20246
  let lastPayload = null;
20247
20247
  while (Date.now() - startedAt < timeoutMs) try {
20248
- const handle = await fsPromises.open(lockPath, "wx");
20248
+ const handle = await fs$1.open(lockPath, "wx");
20249
20249
  const startTime = platform === "linux" ? readLinuxStartTime(process.pid) : null;
20250
20250
  const payload = {
20251
20251
  pid: process.pid,
@@ -20259,7 +20259,7 @@ async function acquireGatewayLock(opts = {}) {
20259
20259
  configPath,
20260
20260
  release: async () => {
20261
20261
  await handle.close().catch(() => void 0);
20262
- await fsPromises.rm(lockPath, { force: true });
20262
+ await fs$1.rm(lockPath, { force: true });
20263
20263
  }
20264
20264
  };
20265
20265
  } catch (err) {
@@ -20268,7 +20268,7 @@ async function acquireGatewayLock(opts = {}) {
20268
20268
  const ownerPid = lastPayload?.pid;
20269
20269
  const ownerStatus = ownerPid ? await resolveGatewayOwnerStatus(ownerPid, lastPayload, platform, port) : "unknown";
20270
20270
  if (ownerStatus === "dead" && ownerPid) {
20271
- await fsPromises.rm(lockPath, { force: true });
20271
+ await fs$1.rm(lockPath, { force: true });
20272
20272
  continue;
20273
20273
  }
20274
20274
  if (ownerStatus !== "alive") {
@@ -20278,13 +20278,13 @@ async function acquireGatewayLock(opts = {}) {
20278
20278
  stale = Number.isFinite(createdAt) ? Date.now() - createdAt > staleMs : false;
20279
20279
  }
20280
20280
  if (!stale) try {
20281
- const st = await fsPromises.stat(lockPath);
20281
+ const st = await fs$1.stat(lockPath);
20282
20282
  stale = Date.now() - st.mtimeMs > staleMs;
20283
20283
  } catch {
20284
20284
  stale = false;
20285
20285
  }
20286
20286
  if (stale) {
20287
- await fsPromises.rm(lockPath, { force: true });
20287
+ await fs$1.rm(lockPath, { force: true });
20288
20288
  continue;
20289
20289
  }
20290
20290
  }
@@ -22636,7 +22636,7 @@ async function startGatewayServer(port = 18789, opts = {}) {
22636
22636
  if (!minimalTestGateway) cron.start().catch((err) => logCron.error(`failed to start: ${String(err)}`));
22637
22637
  if (!minimalTestGateway) (async () => {
22638
22638
  const { recoverPendingDeliveries } = await import("./delivery-queue-Bl-IGZt-.js").then((n) => n.n);
22639
- const { deliverOutboundPayloads } = await import("./deliver-Bh8OdZ9H.js").then((n) => n.n);
22639
+ const { deliverOutboundPayloads } = await import("./deliver-HkPDAwY2.js").then((n) => n.n);
22640
22640
  await recoverPendingDeliveries({
22641
22641
  deliver: deliverOutboundPayloads,
22642
22642
  log: log.child("delivery-recovery"),