squidclaw 3.3.3 → 3.3.6

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 (422) hide show
  1. package/dist/{accounts-BH9Qo1sQ.js → accounts-BK8I0Svb.js} +7 -7
  2. package/dist/{accounts-Cuwg9Tan.js → accounts-DeqNOvBo.js} +1 -1
  3. package/dist/{accounts-B1RxFghM.js → accounts-KzgPbLHP.js} +1 -1
  4. package/dist/{acp-cli-BC9OAf3z.js → acp-cli-BDUN_3hr.js} +8 -8
  5. package/dist/{agent-scope-CfsErfyG.js → agent-scope-DipdnGE4.js} +17 -17
  6. package/dist/{agents-CCBxQ9aq.js → agents-Dp7Z49KS.js} +14 -14
  7. package/dist/{agents.config-BLyNI6Wo.js → agents.config-BiYGJTBo.js} +2 -2
  8. package/dist/{api-key-rotation-D8zY84vq.js → api-key-rotation-ijs2sHFd.js} +1 -1
  9. package/dist/{audio-preflight-D2V9uUvO.js → audio-preflight-BdE85axf.js} +34 -34
  10. package/dist/{audio-transcription-runner-Caxzri8M.js → audio-transcription-runner-t9ywC3Mg.js} +23 -23
  11. package/dist/{audit-C-YgUaul.js → audit-DLLdL6Gd.js} +29 -29
  12. package/dist/{auth-BLnmRBQV.js → auth-CgVB2OQr.js} +1 -1
  13. package/dist/{auth-choice-gdt59E8k.js → auth-choice-BJBbpLg9.js} +13 -13
  14. package/dist/{auth-choice-BtLMBliK.js → auth-choice-DFMaBDZ1.js} +11 -11
  15. package/dist/{auth-choice.apply-helpers-CjGIIfKh.js → auth-choice.apply-helpers-C-L13mHO.js} +1 -1
  16. package/dist/{auth-profiles-ByQNLJzP.js → auth-profiles-BiJk4pUv.js} +16 -16
  17. package/dist/{auth-token-Gu6sWtZS.js → auth-token-B3--XmAN.js} +1 -1
  18. package/dist/{banner-C9hwqM49.js → banner-BR76eqqR.js} +2 -2
  19. package/dist/{bonjour-discovery-Bh8Ao0vC.js → bonjour-discovery-B_XMK5ai.js} +1 -1
  20. package/dist/{browser-cli-CGjcwRKx.js → browser-cli-B45YlTHC.js} +12 -12
  21. package/dist/build-info.json +3 -3
  22. package/dist/{call-BPIaCRGe.js → call-G7vZ_wCI.js} +10 -10
  23. package/dist/{channel-account-context-DJ3rHgVO.js → channel-account-context-CQ6rCiGI.js} +5 -5
  24. package/dist/{channel-activity-CNDuTc8D.js → channel-activity-CGBzdEGf.js} +1 -1
  25. package/dist/{channel-options-D0gk9W37.js → channel-options-CAVwZvHb.js} +3 -3
  26. package/dist/{channel-selection-DAoy4Z1P.js → channel-selection-D_NFb2hE.js} +1 -1
  27. package/dist/{channel-web-Duua4ZPa.js → channel-web-CmwN58t5.js} +17 -17
  28. package/dist/{channels-cli-D15lUa6m.js → channels-cli-BvI7PrnS.js} +93 -93
  29. package/dist/{channels-status-issues-DPzsKH4n.js → channels-status-issues-B87XQLLd.js} +1 -1
  30. package/dist/{chrome-Bs3-hdWP.js → chrome-fM6BTTNA.js} +4 -4
  31. package/dist/{clawbot-cli-ClfRwHPU.js → clawbot-cli-jwxDns9G.js} +11 -11
  32. package/dist/cli/daemon-cli.js +1 -1
  33. package/dist/{cli-zfxNQ-Jj.js → cli-IgnHd9vV.js} +73 -73
  34. package/dist/{client-DFgW99bv.js → client-X5m1ssRl.js} +2 -2
  35. package/dist/{command-registry-okNPqigX.js → command-registry-D-1yrjO5.js} +11 -11
  36. package/dist/{command-secret-targets-Blzote2A.js → command-secret-targets-DElQTuoe.js} +4 -4
  37. package/dist/{commands-Bn-GGRiA.js → commands-Di_crduW.js} +1 -1
  38. package/dist/{commands-registry-DOyhmv7L.js → commands-registry-CvlKGwPE.js} +3 -3
  39. package/dist/{completion-cli-C_kX-zqx.js → completion-cli-DDG6rQHB.js} +13 -13
  40. package/dist/{completion-cli-DMPoKYSD.js → completion-cli-YquOT8ke.js} +1 -1
  41. package/dist/{config-cli-KQxg7BTe.js → config-cli-BIaTdZ_7.js} +7 -7
  42. package/dist/{config-guard-CTKbpGkQ.js → config-guard-CDl-VzWM.js} +3 -3
  43. package/dist/{config-validation-xBuowa-r.js → config-validation-BAFa1Cym.js} +3 -3
  44. package/dist/{configure-B3Nlvr4W.js → configure-BXLSTN8m.js} +17 -17
  45. package/dist/{control-ui-assets-d6VtDSeo.js → control-ui-assets-BYEy341x.js} +1 -1
  46. package/dist/{cron-cli-i7RdrGzx.js → cron-cli-DeHX-jJX.js} +11 -11
  47. package/dist/{daemon-cli-Ot9TBJ_l.js → daemon-cli-Cc8upFpL.js} +15 -15
  48. package/dist/{daemon-install-CbPLNiIP.js → daemon-install-Chxlu9Kv.js} +4 -4
  49. package/dist/{daemon-install-helpers-CZDVO_MU.js → daemon-install-helpers-CJtiW2RE.js} +11 -11
  50. package/dist/{deliver-DYffOszC.js → deliver-CyR05tXq.js} +7 -7
  51. package/dist/deliver-runtime-BY48Cyf6.js +61 -0
  52. package/dist/deps-send-discord.runtime-CiS_YGKd.js +36 -0
  53. package/dist/deps-send-imessage.runtime-h5CDiZZu.js +35 -0
  54. package/dist/deps-send-signal.runtime-C9s3Y1Zu.js +34 -0
  55. package/dist/deps-send-slack.runtime-Dqb-9qwc.js +32 -0
  56. package/dist/{deps-send-telegram.runtime-C7I8qHRq.js → deps-send-telegram.runtime-aNU8_XlK.js} +16 -16
  57. package/dist/deps-send-whatsapp.runtime-0tUP9kuA.js +119 -0
  58. package/dist/{devices-cli-CEW04UTp.js → devices-cli-DVV5P4ZJ.js} +8 -8
  59. package/dist/{diagnostic-CT4BKCiT.js → diagnostic-Du3b17ba.js} +1 -1
  60. package/dist/{diagnostics-m7hHHbuE.js → diagnostics--O6mo6KH.js} +5 -5
  61. package/dist/{directory-cli-4K5ehIEb.js → directory-cli-DaE3Quiv.js} +7 -7
  62. package/dist/{dns-cli-Cwgde6km.js → dns-cli-waaEVY0o.js} +5 -5
  63. package/dist/{dock-0fXeq35m.js → dock-gKJjfuaV.js} +4 -4
  64. package/dist/{docs-cli-BpZtes_j.js → docs-cli--gGxz79Z.js} +4 -4
  65. package/dist/{doctor-completion-Dzzgvaw-.js → doctor-completion-B63lREru.js} +2 -2
  66. package/dist/{doctor-completion-D6js0phx.js → doctor-completion-CoKUBmAB.js} +1 -1
  67. package/dist/{doctor-config-flow-CjyicsHv.js → doctor-config-flow-BtioG6ZI.js} +15 -15
  68. package/dist/{enable-DMJvBRPK.js → enable-Cbwq508X.js} +1 -1
  69. package/dist/entry.js +2 -2
  70. package/dist/{exec-approvals-allowlist--CDwsotI.js → exec-approvals-allowlist-Bl6dLcC4.js} +1 -1
  71. package/dist/{exec-approvals-cli-Bni7tZhv.js → exec-approvals-cli-_eztu6zG.js} +16 -16
  72. package/dist/{exec-safe-bin-runtime-policy-BOmyNeKa.js → exec-safe-bin-runtime-policy-CYHAJAOy.js} +2 -2
  73. package/dist/{fetch-CODl9dwL.js → fetch-BWLAZtR0.js} +3 -3
  74. package/dist/{fetch-guard-C9XQ9W19.js → fetch-guard-aHbB2ECM.js} +1 -1
  75. package/dist/{fs-safe-BPQ-per2.js → fs-safe-DPYj7h8A.js} +24 -24
  76. package/dist/{gateway-cli-C_bDC15s.js → gateway-cli-BP1USKKw.js} +153 -153
  77. package/dist/{gateway-cli-DZSjLGTJ.js → gateway-cli-CIhENRqY.js} +1 -1
  78. package/dist/{gateway-rpc-mBKSbosL.js → gateway-rpc-CyI4qv4e.js} +1 -1
  79. package/dist/{health-L85P9rRI.js → health-CxqVSgKj.js} +11 -11
  80. package/dist/{hooks-cli-JUGj7_IF.js → hooks-cli-C-8A82OA.js} +81 -81
  81. package/dist/{hooks-status-BlgSVDvN.js → hooks-status-DMFBAUq8.js} +1 -1
  82. package/dist/{image-C3rClBur.js → image-Czt09HO2.js} +5 -5
  83. package/dist/{image-ops-LFsSCTyI.js → image-ops-B2uuLIGD.js} +10 -10
  84. package/dist/image-runtime-C_sKgCPT.js +55 -0
  85. package/dist/index.js +1 -1
  86. package/dist/{inspect-CzsXBsew.js → inspect-4c1uL0x5.js} +4 -4
  87. package/dist/{install-safe-path-DqI19VEv.js → install-safe-path-3muwy3fu.js} +25 -25
  88. package/dist/{installs-P-pYAJm1.js → installs-BiQDtPF0.js} +9 -9
  89. package/dist/{ipv4-Bx85fwxr.js → ipv4-B1l08IQ5.js} +1 -1
  90. package/dist/{ir-CLdz27UA.js → ir-Cg5iUcsz.js} +8 -8
  91. package/dist/{issue-format-DzzpkEKh.js → issue-format-NbalyyoF.js} +1 -1
  92. package/dist/{json-files-rR19q30D.js → json-files-CuJjdF_0.js} +8 -8
  93. package/dist/{lifecycle-core-DAOEq9od.js → lifecycle-core-BDDTVhGJ.js} +5 -5
  94. package/dist/{login-B6agIh-B.js → login-BtteffgM.js} +3 -3
  95. package/dist/{login-qr-eRvH4Sfc.js → login-qr-CL3cPNm6.js} +6 -6
  96. package/dist/{logs-cli-DjsOTLd0.js → logs-cli-_68C9pAz.js} +9 -9
  97. package/dist/{manager-CFg5CNjB.js → manager-D-epQZzu.js} +14 -14
  98. package/dist/{manager-runtime-BucyWusE.js → manager-runtime-dxiaLn0X.js} +9 -9
  99. package/dist/{manifest-registry-1ACGW3OR.js → manifest-registry-7kwtbCH-.js} +1 -1
  100. package/dist/{memory-cli-K8RTw22V.js → memory-cli-DdlNObR_.js} +12 -12
  101. package/dist/{model-D3QKHUD9.js → model-CLOEFgm1.js} +2 -2
  102. package/dist/{model-catalog-INp1o1zX.js → model-catalog-cPBfdmCZ.js} +3 -3
  103. package/dist/{model-picker-DNBHh9Px.js → model-picker-k5b4kcsx.js} +4 -4
  104. package/dist/{models-BpPghvyy.js → models-Bf5dNlFg.js} +17 -17
  105. package/dist/{models-cli-DotYKjDq.js → models-cli-DHlY3RwP.js} +78 -78
  106. package/dist/{models-config-BNIPxtHv.js → models-config-C7GR26HJ.js} +6 -6
  107. package/dist/{net-QB4dfP4-.js → net-CggAM2eK.js} +2 -2
  108. package/dist/{node-cli-tuLexrKG.js → node-cli-CF6bOApq.js} +33 -33
  109. package/dist/{node-command-policy-X4KnAuD8.js → node-command-policy--2bsadiu.js} +1 -1
  110. package/dist/{node-service-OVe0_CIs.js → node-service-Z0JprJda.js} +1 -1
  111. package/dist/{nodes-cli-BtHrRe7o.js → nodes-cli-DdF0Apr8.js} +16 -16
  112. package/dist/{nodes-screen-CKhKFccI.js → nodes-screen-Cihyp_1V.js} +7 -7
  113. package/dist/{npm-pack-install-Dn3FiWXB.js → npm-pack-install-B887us7R.js} +18 -18
  114. package/dist/{npm-resolution-BTi5J55i.js → npm-resolution-2sjQlpdP.js} +4 -4
  115. package/dist/{onboard-qnQqEy5h.js → onboard-BYwFqDe-.js} +1 -1
  116. package/dist/{onboard-channels-CUpUBnOj.js → onboard-channels-Bw372mQX.js} +21 -21
  117. package/dist/{onboard-custom-DIM8V39k.js → onboard-custom-XW3Q4ERz.js} +4 -4
  118. package/dist/{onboard-CaDp4p48.js → onboard-gmbrf0mc.js} +6 -6
  119. package/dist/{onboard-helpers-D10-c0nt.js → onboard-helpers-DfWsh9P_.js} +10 -10
  120. package/dist/{onboard-hooks-DW4qt57e.js → onboard-hooks-7zSvhf8S.js} +4 -4
  121. package/dist/{onboard-remote-PNWR1AHo.js → onboard-remote-qJCXQTPO.js} +4 -4
  122. package/dist/{onboard-skills-DRzcoNmr.js → onboard-skills-DFMLJn-8.js} +4 -4
  123. package/dist/{onboarding-mo7rwJC-.js → onboarding-C7eyvBep.js} +1 -1
  124. package/dist/{onboarding-D1z3JAaB.js → onboarding-OrcdwciM.js} +14 -14
  125. package/dist/{onboarding.finalize-CWzwBDG8.js → onboarding.finalize-Bf3EExjS.js} +142 -145
  126. package/dist/{onboarding.finalize-D8igsmtY.js → onboarding.finalize-DZBXbwYe.js} +55 -58
  127. package/dist/{onboarding.gateway-config-BzzDFZhl.js → onboarding.gateway-config-CeOavTRn.js} +18 -18
  128. package/dist/{onboarding.secret-input-ajPT5cjy.js → onboarding.secret-input-h4sXfwga.js} +1 -1
  129. package/dist/{openai-model-default-lBZZvWbf.js → openai-model-default-BIEWI0T4.js} +2 -2
  130. package/dist/{outbound-yJzuZMJK.js → outbound-DrmXuI1w.js} +3 -3
  131. package/dist/{outbound-attachment-BRjY-xU5.js → outbound-attachment-ELXt01nc.js} +2 -2
  132. package/dist/{pairing-cli-BHW9JIfG.js → pairing-cli-BPn6V6ca.js} +8 -8
  133. package/dist/{pairing-labels-DGiyVpfH.js → pairing-labels-ieaV5SBV.js} +1 -1
  134. package/dist/{pairing-store-BWvzmAq8.js → pairing-store-BNRzMsGf.js} +3 -3
  135. package/dist/{path-alias-guards-DeOVetT7.js → path-alias-guards-vfYYQFIg.js} +3 -3
  136. package/dist/{path-safety-D7CjFQvf.js → path-safety-C95DzArw.js} +1 -1
  137. package/dist/{paths-D6mnO6Ni.js → paths-DfuVHiHu.js} +9 -9
  138. package/dist/{pi-embedded-helpers-13zhzo1T.js → pi-embedded-helpers-DQHj960w.js} +6 -6
  139. package/dist/{pi-model-discovery-Cj7zDFgN.js → pi-model-discovery-D4t0ZFCY.js} +1 -1
  140. package/dist/{pi-model-discovery-runtime-CylBYw6s.js → pi-model-discovery-runtime-SKeRi7Gx.js} +5 -5
  141. package/dist/{pi-tools.before-tool-call.runtime-CEWBYhqI.js → pi-tools.before-tool-call.runtime-DjzR6iNJ.js} +5 -5
  142. package/dist/{pi-tools.policy-Bhg8uG0h.js → pi-tools.policy-DgElG9m2.js} +5 -5
  143. package/dist/{plugin-auto-enable-D_3GnV1a.js → plugin-auto-enable-BLhZ9NWX.js} +3 -3
  144. package/dist/{plugin-registry-CY6rt9xp.js → plugin-registry-BgKtjZBZ.js} +3 -3
  145. package/dist/plugin-sdk/{accounts-BhCAa-05.js → accounts-BLOLIF6Q.js} +2 -2
  146. package/dist/plugin-sdk/accounts-BXFDqY90.js +288 -0
  147. package/dist/plugin-sdk/{accounts-DKXGC2Vu.js → accounts-BvzvDHNx.js} +3 -3
  148. package/dist/plugin-sdk/{accounts-BChIl5as.js → accounts-ByCKM_Y3.js} +2 -2
  149. package/dist/plugin-sdk/accounts-DU7Js54-.js +46 -0
  150. package/dist/plugin-sdk/accounts-DxiB_4z4.js +35 -0
  151. package/dist/plugin-sdk/{active-listener-TTbK9PGk.js → active-listener-Ccj2fSCa.js} +2 -2
  152. package/dist/plugin-sdk/active-listener-DRKcesNb.js +50 -0
  153. package/dist/plugin-sdk/{api-key-rotation-BqhYVBBK.js → api-key-rotation-0Xm0okk5.js} +2 -2
  154. package/dist/plugin-sdk/api-key-rotation-k1ZNheUH.js +181 -0
  155. package/dist/plugin-sdk/{audio-preflight-DAf0ptAM.js → audio-preflight-B_pcDw8d.js} +26 -26
  156. package/dist/plugin-sdk/audio-preflight-Be1sKsob.js +69 -0
  157. package/dist/plugin-sdk/audio-transcription-runner-jhHyCc_7.js +2176 -0
  158. package/dist/plugin-sdk/{audio-transcription-runner-CBASOlbc.js → audio-transcription-runner-u6tijzUS.js} +11 -11
  159. package/dist/plugin-sdk/audit-membership-runtime-B9b-zRwg.js +58 -0
  160. package/dist/plugin-sdk/{audit-membership-runtime-Xl20kCBe.js → audit-membership-runtime-DHQDvH4u.js} +2 -2
  161. package/dist/plugin-sdk/{channel-activity-95JVLzNY.js → channel-activity-BVUdxSNs.js} +3 -3
  162. package/dist/plugin-sdk/channel-activity-Bq1Y9RiB.js +94 -0
  163. package/dist/plugin-sdk/channel-web-AsdjtnvN.js +2256 -0
  164. package/dist/plugin-sdk/{channel-web-DCkC6Ydu.js → channel-web-BX2s-JXF.js} +18 -18
  165. package/dist/plugin-sdk/{chrome-BlXpNOQu.js → chrome-6EkqVcyR.js} +6 -6
  166. package/dist/plugin-sdk/chrome-DOnBMnlx.js +2415 -0
  167. package/dist/plugin-sdk/{commands-registry-C9y_w3eW.js → commands-registry-CDHo6SSs.js} +4 -4
  168. package/dist/plugin-sdk/commands-registry-D0py59pz.js +1125 -0
  169. package/dist/plugin-sdk/{common-CEwMUbms.js → common-Emz6EPQM.js} +2 -2
  170. package/dist/plugin-sdk/config-B16xKqSo.js +17912 -0
  171. package/dist/plugin-sdk/{config-sMifxgre.js → config-CMjn_DSB.js} +7 -7
  172. package/dist/plugin-sdk/deliver-BqXXtIuw.js +1694 -0
  173. package/dist/plugin-sdk/{deliver-2zt3NeFA.js → deliver-Cz6GluMN.js} +10 -10
  174. package/dist/plugin-sdk/deliver-runtime-CjCJkoFM.js +32 -0
  175. package/dist/plugin-sdk/deliver-runtime-D0xZkt8n.js +32 -0
  176. package/dist/plugin-sdk/deps-send-discord.runtime-BM6ppx2Q.js +23 -0
  177. package/dist/plugin-sdk/deps-send-discord.runtime-C4AEwjGl.js +23 -0
  178. package/dist/plugin-sdk/deps-send-imessage.runtime-3w5PhXGu.js +22 -0
  179. package/dist/plugin-sdk/deps-send-imessage.runtime-DCdEe-_E.js +22 -0
  180. package/dist/plugin-sdk/deps-send-signal.runtime-BNO6SPmR.js +21 -0
  181. package/dist/plugin-sdk/deps-send-signal.runtime-yH9cQl3_.js +21 -0
  182. package/dist/plugin-sdk/deps-send-slack.runtime-BChVBURL.js +19 -0
  183. package/dist/plugin-sdk/deps-send-slack.runtime-Bh4gw-L5.js +19 -0
  184. package/dist/plugin-sdk/deps-send-telegram.runtime-C_CtsWgt.js +24 -0
  185. package/dist/plugin-sdk/deps-send-telegram.runtime-DyCorUw2.js +24 -0
  186. package/dist/plugin-sdk/deps-send-whatsapp.runtime-BF4vx9Ho.js +57 -0
  187. package/dist/plugin-sdk/deps-send-whatsapp.runtime-DoOYrpKa.js +57 -0
  188. package/dist/plugin-sdk/diagnostic-DUbajFSl.js +319 -0
  189. package/dist/plugin-sdk/{diagnostic-CU_mni6m.js → diagnostic-DhO2TqL_.js} +2 -2
  190. package/dist/plugin-sdk/discord.js +6 -6
  191. package/dist/plugin-sdk/{errors-CgRPdp3o.js → errors-9oVz7reJ.js} +1 -1
  192. package/dist/plugin-sdk/errors-B8oJXuCF.js +54 -0
  193. package/dist/plugin-sdk/{fetch-guard-BxMLJbqt.js → fetch-guard-CGQ35-A_.js} +2 -2
  194. package/dist/plugin-sdk/fetch-guard-Cgyq6Jv9.js +156 -0
  195. package/dist/plugin-sdk/{fs-safe-5aQcM_qM.js → fs-safe-B26UxJny.js} +3 -3
  196. package/dist/plugin-sdk/fs-safe-BW1ypSDS.js +352 -0
  197. package/dist/plugin-sdk/image-BPXnvxYL.js +2310 -0
  198. package/dist/plugin-sdk/{image-BJXV9IMV.js → image-DPgEp54d.js} +6 -6
  199. package/dist/plugin-sdk/image-ops-BBY2fn9x.js +584 -0
  200. package/dist/plugin-sdk/{image-ops-DovJMvdf.js → image-ops-CbKrfi-N.js} +2 -2
  201. package/dist/plugin-sdk/image-runtime-DN6PHT8G.js +25 -0
  202. package/dist/plugin-sdk/image-runtime-S-TzaJpg.js +25 -0
  203. package/dist/plugin-sdk/index.js +50 -50
  204. package/dist/plugin-sdk/{ir-DE2ewdq5.js → ir-4JdLS2Hz.js} +7 -7
  205. package/dist/plugin-sdk/ir-BJsqyZfm.js +1296 -0
  206. package/dist/plugin-sdk/local-roots-C1ETRlaC.js +186 -0
  207. package/dist/plugin-sdk/{local-roots-CIwDgpY2.js → local-roots-T6lXDGzr.js} +4 -4
  208. package/dist/plugin-sdk/{logger-DIb2cGHp.js → logger-Bg4vIUJn.js} +2 -2
  209. package/dist/plugin-sdk/logger-DDdrdbDu.js +1163 -0
  210. package/dist/plugin-sdk/{login-CLIcsAVy.js → login-BNCjks0C.js} +4 -4
  211. package/dist/plugin-sdk/login-DtS9DDnV.js +57 -0
  212. package/dist/plugin-sdk/login-qr-B9YeeJ37.js +320 -0
  213. package/dist/plugin-sdk/{login-qr-BlxjA0vQ.js → login-qr-CTjNgxhl.js} +5 -5
  214. package/dist/plugin-sdk/{manager-CpAGPHeX.js → manager-D__CoDGL.js} +8 -8
  215. package/dist/plugin-sdk/manager-Dn7j3n0d.js +3917 -0
  216. package/dist/plugin-sdk/manager-runtime-B9aBGLrF.js +15 -0
  217. package/dist/plugin-sdk/manager-runtime-UK1-iA2B.js +15 -0
  218. package/dist/plugin-sdk/mattermost.js +3 -3
  219. package/dist/plugin-sdk/outbound-B8ca8vE3.js +212 -0
  220. package/dist/plugin-sdk/{outbound-DDpRevO_.js → outbound-DTQ-9Cjw.js} +5 -5
  221. package/dist/plugin-sdk/outbound-attachment-BppFIMQa.js +19 -0
  222. package/dist/plugin-sdk/{outbound-attachment-CVavq5II.js → outbound-attachment-CdHX9v0q.js} +2 -2
  223. package/dist/plugin-sdk/{path-alias-guards-BfpU4lAT.js → path-alias-guards-BX-3FprC.js} +1 -1
  224. package/dist/plugin-sdk/path-alias-guards-DSCFtpsd.js +43 -0
  225. package/dist/plugin-sdk/{paths-CK3lTJYw.js → paths-BQHqKGA8.js} +1 -1
  226. package/dist/plugin-sdk/paths-CjFcHB_C.js +166 -0
  227. package/dist/plugin-sdk/{pi-embedded-helpers-Cb_h9zSJ.js → pi-embedded-helpers-B7nmCbf7.js} +16 -16
  228. package/dist/plugin-sdk/pi-embedded-helpers-BeYjP1MW.js +9627 -0
  229. package/dist/plugin-sdk/pi-model-discovery-B_qCKuSW.js +134 -0
  230. package/dist/plugin-sdk/{pi-model-discovery-B3B3R7L9.js → pi-model-discovery-DyDwYiK3.js} +1 -1
  231. package/dist/plugin-sdk/pi-model-discovery-runtime-CN6ZaL0W.js +8 -0
  232. package/dist/plugin-sdk/pi-model-discovery-runtime-CZNiNFlm.js +8 -0
  233. package/dist/plugin-sdk/{pi-tools.before-tool-call.runtime-DivpBAM0.js → pi-tools.before-tool-call.runtime-D_f6TDo7.js} +4 -4
  234. package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-cZdrrV27.js +354 -0
  235. package/dist/plugin-sdk/{plugins-BlTrm4bw.js → plugins-BSPvol4w.js} +4 -4
  236. package/dist/plugin-sdk/plugins-rivB8KaQ.js +864 -0
  237. package/dist/plugin-sdk/{proxy-env-Cdh-OQYk.js → proxy-env-D-iVYTBk.js} +1 -1
  238. package/dist/plugin-sdk/{proxy-fetch-Dt5BedH8.js → proxy-fetch-Cf3IUSDw.js} +1 -1
  239. package/dist/plugin-sdk/proxy-fetch-ZPEvp58f.js +38 -0
  240. package/dist/plugin-sdk/{pw-ai-DEDRpMlY.js → pw-ai-BO445UDA.js} +9 -9
  241. package/dist/plugin-sdk/pw-ai-qaWZD0yx.js +1938 -0
  242. package/dist/plugin-sdk/{qmd-manager-Ct9rtJjd.js → qmd-manager-81ezWnIN.js} +7 -7
  243. package/dist/plugin-sdk/qmd-manager-izn0N9V3.js +1448 -0
  244. package/dist/plugin-sdk/{query-expansion-OdwWuN1S.js → query-expansion-C1Nx0XAb.js} +5 -5
  245. package/dist/plugin-sdk/query-expansion-DxTmIU4K.js +1011 -0
  246. package/dist/plugin-sdk/{redact-9WsNyb7S.js → redact-BoNEjbpF.js} +1 -1
  247. package/dist/plugin-sdk/redact-DfACyt0X.js +319 -0
  248. package/dist/plugin-sdk/{reply-wZhosbPd.js → reply-DJ3rbbnv.js} +73 -73
  249. package/dist/plugin-sdk/reply-DNSpho0-.js +98763 -0
  250. package/dist/plugin-sdk/{resolve-outbound-target-BJmCIkW_.js → resolve-outbound-target-DtQd8TzZ.js} +2 -2
  251. package/dist/plugin-sdk/resolve-outbound-target-YiPIGXVN.js +40 -0
  252. package/dist/plugin-sdk/{run-with-concurrency-EUEKeAa8.js → run-with-concurrency-CYcPpb5E.js} +1 -1
  253. package/dist/plugin-sdk/run-with-concurrency-vfuRiXdY.js +2023 -0
  254. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-BgwMJs4X.js +10 -0
  255. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-ai8hcGi_.js +10 -0
  256. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-BzvoaI1G.js +19 -0
  257. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-Y7maoii7.js +19 -0
  258. package/dist/plugin-sdk/{send-Drs4JqVD.js → send-B9GVkvTk.js} +5 -5
  259. package/dist/plugin-sdk/{send-BMWyVUhm.js → send-BPEn9L0o.js} +13 -13
  260. package/dist/plugin-sdk/send-BSD6Pkrk.js +414 -0
  261. package/dist/plugin-sdk/send-C4KxEJe1.js +503 -0
  262. package/dist/plugin-sdk/{send-0C4KdD-T.js → send-CGjI0pJn.js} +7 -7
  263. package/dist/plugin-sdk/{send-oo6mQbab.js → send-CZ6HDwDu.js} +8 -8
  264. package/dist/plugin-sdk/send-D3XVKGvq.js +540 -0
  265. package/dist/plugin-sdk/{send-BGWGV_mz.js → send-D6nUI0S3.js} +6 -6
  266. package/dist/plugin-sdk/send-DFrnRiWm.js +3135 -0
  267. package/dist/plugin-sdk/send-Dh1f5xjE.js +2587 -0
  268. package/dist/plugin-sdk/{session-CXVARKFK.js → session-Bwjlseuf.js} +3 -3
  269. package/dist/plugin-sdk/session-D5c0BIEo.js +169 -0
  270. package/dist/plugin-sdk/{skill-commands-CoqGFLfM.js → skill-commands-BpB2Oe8e.js} +4 -4
  271. package/dist/plugin-sdk/skill-commands-CnqkEfhS.js +342 -0
  272. package/dist/plugin-sdk/{skills-di-5uS9y.js → skills-CaQpr1kx.js} +6 -6
  273. package/dist/plugin-sdk/skills-DSbDUvmU.js +1428 -0
  274. package/dist/plugin-sdk/slash-commands.runtime-BH06o3dH.js +13 -0
  275. package/dist/plugin-sdk/slash-commands.runtime-Dbtq7ppF.js +13 -0
  276. package/dist/plugin-sdk/slash-dispatch.runtime-BhAks953.js +52 -0
  277. package/dist/plugin-sdk/slash-dispatch.runtime-BotYesgY.js +52 -0
  278. package/dist/plugin-sdk/slash-skill-commands.runtime-CzPvxiUD.js +16 -0
  279. package/dist/plugin-sdk/slash-skill-commands.runtime-QGNWVO9S.js +16 -0
  280. package/dist/plugin-sdk/ssrf-DvsjfpC2.js +202 -0
  281. package/dist/plugin-sdk/store-DG90hxe6.js +81 -0
  282. package/dist/plugin-sdk/{store-Dn_E3uaN.js → store-K6C7eOpg.js} +2 -2
  283. package/dist/plugin-sdk/subagent-registry-runtime-BbcgUYOO.js +52 -0
  284. package/dist/plugin-sdk/subagent-registry-runtime-Db83OZ3_.js +52 -0
  285. package/dist/plugin-sdk/{tables-_e9wMygc.js → tables-CeWt6UjS.js} +1 -1
  286. package/dist/plugin-sdk/tables-DNlQ8oQ3.js +55 -0
  287. package/dist/{target-errors-C_rnMuJ2.js → plugin-sdk/target-errors-BlVYPwVC.js} +4 -4
  288. package/dist/plugin-sdk/thinking-DT2ZR60x.js +1206 -0
  289. package/dist/plugin-sdk/{thinking-Cih_nxDY.js → thinking-gpcjIDQZ.js} +7 -7
  290. package/dist/plugin-sdk/{tokens-CLE20fRI.js → tokens-CTIYTLWu.js} +1 -1
  291. package/dist/plugin-sdk/tokens-DAL_5WHL.js +52 -0
  292. package/dist/plugin-sdk/{tool-images-D6a1Ua4p.js → tool-images-DroS1EaM.js} +2 -2
  293. package/dist/plugin-sdk/tool-images-l3TE_qXt.js +274 -0
  294. package/dist/plugin-sdk/web-42d5VBZj.js +56 -0
  295. package/dist/plugin-sdk/web-DZ7nBzZy.js +56 -0
  296. package/dist/plugin-sdk/{whatsapp-actions-UAnHjKbE.js → whatsapp-actions-CbzdjX4B.js} +17 -17
  297. package/dist/plugin-sdk/whatsapp-actions-DR2aYq5f.js +80 -0
  298. package/dist/plugin-sdk/whatsapp.js +50 -50
  299. package/dist/{plugins-DFPxMLnR.js → plugins-DuLOFZmO.js} +2 -2
  300. package/dist/{plugins-cli-Bfq4OJMG.js → plugins-cli-CKr9IyQL.js} +83 -83
  301. package/dist/{ports-DMeUt80n.js → ports-0jLyYbvQ.js} +2 -2
  302. package/dist/{ports-BzfeaNjw.js → ports-Be82TlEg.js} +1 -1
  303. package/dist/{program-Crlu6-Fd.js → program-D5HYdN0q.js} +81 -81
  304. package/dist/{program-context-BUiGRFn1.js → program-context-CWU-LWnL.js} +6 -6
  305. package/dist/{prompt-select-styled-DPnXlfvv.js → prompt-select-styled-C_C2Ae8a.js} +40 -40
  306. package/dist/{prompt-select-styled-BeIW1IXq.js → prompt-select-styled-CjkK2AWX.js} +1 -1
  307. package/dist/{provider-auth-helpers-C_1HJDfj.js → provider-auth-helpers-DG7hKvxV.js} +5 -5
  308. package/dist/{proxy-env-CNlcVWhf.js → proxy-env-D16ubrT6.js} +1 -1
  309. package/dist/{push-apns-C4uEslA7.js → push-apns-BZeUZhYN.js} +5 -5
  310. package/dist/{pw-ai-Dg9fGMve.js → pw-ai-BrmQq6dp.js} +18 -18
  311. package/dist/{qmd-manager-D4nXiiAn.js → qmd-manager-CToc7FPg.js} +20 -20
  312. package/dist/{qr-cli-CN6kEeE-.js → qr-cli-23hgWtLn.js} +2 -2
  313. package/dist/{query-expansion-C0HUJbRn.js → query-expansion-DI9INxTg.js} +12 -12
  314. package/dist/{redact-snapshot-CiS6G7vm.js → redact-snapshot-B8W0RynI.js} +1 -1
  315. package/dist/{register.agent-BMr61y_S.js → register.agent-C9tZejQm.js} +94 -94
  316. package/dist/register.configure-DJj2p4b3.js +165 -0
  317. package/dist/{register.maintenance-BETLfpr3.js → register.maintenance-BnT8sF7e.js} +4 -4
  318. package/dist/{register.maintenance-DWquSvC1.js → register.maintenance-CVWvM_w8.js} +95 -95
  319. package/dist/{register.message-CqqQmFqh.js → register.message-DexwH4xh.js} +74 -74
  320. package/dist/{register.onboard-FYANtcb-.js → register.onboard-B68iwPcU.js} +2 -2
  321. package/dist/{register.onboard-CJqPKqea.js → register.onboard-Bx2xxYE0.js} +18 -18
  322. package/dist/{register.setup-DzAgPerh.js → register.setup-BgRFFdoH.js} +21 -21
  323. package/dist/{register.setup-_38deeF2.js → register.setup-DkztcYGa.js} +2 -2
  324. package/dist/{register.status-health-sessions-CHCnEwLO.js → register.status-health-sessions-CmNMtNSk.js} +88 -88
  325. package/dist/{register.subclis-DX9OFUYu.js → register.subclis-Bb6WLUhM.js} +31 -31
  326. package/dist/{rpc-DFxhwitx.js → rpc-BquITS9w.js} +1 -1
  327. package/dist/{run-main-BjSdMh29.js → run-main-CApmG6CS.js} +93 -93
  328. package/dist/{runtime-By5SpbLU.js → runtime-_Vk5eISV.js} +3 -3
  329. package/dist/{runtime-config-collectors-B104qPur.js → runtime-config-collectors-wQYiGNzB.js} +1 -1
  330. package/dist/{runtime-whatsapp-login.runtime-B4XQqxLZ.js → runtime-whatsapp-login.runtime-Cf3JhAPA.js} +7 -7
  331. package/dist/{runtime-whatsapp-outbound.runtime-CTfBy0k0.js → runtime-whatsapp-outbound.runtime-bw4l8Cm5.js} +15 -15
  332. package/dist/{sandbox-DaQ1ruwH.js → sandbox-CbGxVENW.js} +18 -18
  333. package/dist/{sandbox-cli-BzmKYlDs.js → sandbox-cli-WvgvhVoi.js} +25 -25
  334. package/dist/{secrets-cli-C2iidz4Q.js → secrets-cli-BJFHNFFa.js} +11 -11
  335. package/dist/{security-cli-D3PfmNhS.js → security-cli-BVezJLE_.js} +42 -42
  336. package/dist/{send-BWMSp9_W.js → send-Bu3eP6CW.js} +4 -4
  337. package/dist/{send-BdZJcfei.js → send-C2ol3xJd.js} +8 -8
  338. package/dist/{send-DHmaiFb3.js → send-Cj7csKER.js} +6 -6
  339. package/dist/{send-BcCUXoKV.js → send-D8WRsTcF.js} +5 -5
  340. package/dist/{send-BbUl6LvV.js → send-DynShEUL.js} +11 -11
  341. package/dist/{server-BThRQKrb.js → server-TkeA4LLX.js} +20 -20
  342. package/dist/{server-context-D9dHt5TX.js → server-context-C56AfkmJ.js} +12 -12
  343. package/dist/{server-lifecycle-DwoqIphm.js → server-lifecycle-CUR6g-z-.js} +2 -2
  344. package/dist/{server-middleware-i-VrGsvO.js → server-middleware-Dxlv5GU2.js} +1 -1
  345. package/dist/{server-node-events-67QUoOob.js → server-node-events-EsqtDPMI.js} +74 -74
  346. package/dist/{service-B5T42CWZ.js → service-DSqxS6_D.js} +15 -15
  347. package/dist/{session-eXSdl5mb.js → session-D0jodcgT.js} +1 -1
  348. package/dist/{session-utils-PIpg5nvE.js → session-utils-CZALjD6h.js} +6 -6
  349. package/dist/{sessions-CDicf15r.js → sessions-BLTjLVQT.js} +4 -4
  350. package/dist/{sessions-A97O0F1f.js → sessions-gTKLgF0i.js} +15 -15
  351. package/dist/{shared-CJet4A6J.js → shared-4aGIUkwm.js} +3 -3
  352. package/dist/{shared-By6_qr_R.js → shared-D5DTxBPH.js} +1 -1
  353. package/dist/{skill-commands-DBT6aOGs.js → skill-commands-CigVnmMu.js} +5 -5
  354. package/dist/{skill-scanner--QKHR8U0.js → skill-scanner-CvS725eQ.js} +6 -6
  355. package/dist/{skills-EwyaIyKC.js → skills-C85azDXm.js} +3 -3
  356. package/dist/{skills-cli-CblUgygP.js → skills-cli-B2fk0u1F.js} +5 -5
  357. package/dist/{skills-install-Bg63KYLo.js → skills-install-_Qv7iwIj.js} +6 -6
  358. package/dist/{skills-status-Bv8Xt7Lc.js → skills-status-DkO7rxE8.js} +1 -1
  359. package/dist/{slash-commands.runtime-BueY2Beh.js → slash-commands.runtime-CF70sEb6.js} +11 -11
  360. package/dist/slash-dispatch.runtime-BpDcu-GU.js +114 -0
  361. package/dist/{slash-skill-commands.runtime-ByvvwWOf.js → slash-skill-commands.runtime-6s4Ap-WA.js} +15 -15
  362. package/dist/{squidclaw-root-JXyRbQLJ.js → squidclaw-root-BQfLymzj.js} +8 -8
  363. package/dist/{status-Doe6Z9h6.js → status-yDvMiWJC.js} +27 -27
  364. package/dist/{status.update-BGIm6we4.js → status.update-CiLU9RPF.js} +2 -2
  365. package/dist/{store-BTkIx401.js → store-BEIcnlgx.js} +5 -5
  366. package/dist/{subagent-registry-o5rZt_4e.js → subagent-registry-BE1B0_sO.js} +149 -149
  367. package/dist/subagent-registry-runtime-DNx1w9Cr.js +114 -0
  368. package/dist/{system-cli-BGFIr82s.js → system-cli-DAKISNim.js} +9 -9
  369. package/dist/{system-run-command-BqoUyRkT.js → system-run-command-BOHXAwW8.js} +1 -1
  370. package/dist/{systemd-B86VePXs.js → systemd-Cj2cX_ZP.js} +9 -9
  371. package/dist/{systemd-hints-BmFWZu_j.js → systemd-hints-46PqJfaq.js} +6 -6
  372. package/dist/{systemd-linger-w7fvBU-1.js → systemd-linger-6Jd9K5p2.js} +1 -1
  373. package/dist/{tables-Cw6nUurn.js → tables-DOgKzkCQ.js} +1 -1
  374. package/dist/{tailnet-QKMSnz19.js → tailnet-BlV0IR7G.js} +1 -1
  375. package/dist/target-errors-CRQlPF1u.js +195 -0
  376. package/dist/{tool-images-D6mmxuWS.js → tool-images-CyzWvDUu.js} +1 -1
  377. package/dist/{tui-BxsFozJB.js → tui-DN34soFB.js} +6 -6
  378. package/dist/{tui-cli-Bf1E1ENY.js → tui-cli-CG0r8wIF.js} +32 -32
  379. package/dist/{update-BhRrb6BI.js → update-1JhjCqjy.js} +3 -3
  380. package/dist/{update-cli-Bh_QpVMZ.js → update-cli-DoKsKvCz.js} +4 -4
  381. package/dist/{update-cli-yUlN0mCs.js → update-cli-VQSBFHlu.js} +104 -104
  382. package/dist/{update-runner-DCLBBKeT.js → update-runner-EXHdNkfq.js} +16 -16
  383. package/dist/web-DfVBXj7E.js +118 -0
  384. package/dist/{webhooks-cli-BCqXOihQ.js → webhooks-cli-CJpcVOhV.js} +6 -6
  385. package/dist/{whatsapp-actions-I7z57XJA.js → whatsapp-actions-BYzAF3jo.js} +17 -17
  386. package/dist/{with-timeout-CX0CGi5G.js → with-timeout-D8mIrgj5.js} +3 -3
  387. package/dist/{workspace-BbO-M3Jv.js → workspace-D5vNjk5G.js} +1 -1
  388. package/dist/{workspace-dirs-DJbX0g4E.js → workspace-dirs-CKrd0E4k.js} +1 -1
  389. package/dist/{wsl-CsGe5QCP.js → wsl-CvQfS6aU.js} +2 -2
  390. package/extensions/googlechat/node_modules/.bin/squidclaw +2 -2
  391. package/extensions/memory-core/node_modules/.bin/squidclaw +2 -2
  392. package/package.json +1 -1
  393. package/dist/deliver-runtime-CCCnLu1l.js +0 -61
  394. package/dist/deps-send-discord.runtime-C1qYROSU.js +0 -36
  395. package/dist/deps-send-imessage.runtime-Dz14pqUt.js +0 -35
  396. package/dist/deps-send-signal.runtime-BxlxMy_x.js +0 -34
  397. package/dist/deps-send-slack.runtime-BoIAdT0Z.js +0 -32
  398. package/dist/deps-send-whatsapp.runtime-NrQGDJy9.js +0 -119
  399. package/dist/image-runtime-BawEM2qj.js +0 -55
  400. package/dist/plugin-sdk/deliver-runtime-Dx0Sg-lg.js +0 -32
  401. package/dist/plugin-sdk/deps-send-discord.runtime-bKwjojX0.js +0 -23
  402. package/dist/plugin-sdk/deps-send-imessage.runtime-DcxfdKGE.js +0 -22
  403. package/dist/plugin-sdk/deps-send-signal.runtime-79rGat6V.js +0 -21
  404. package/dist/plugin-sdk/deps-send-slack.runtime-DfMO701H.js +0 -19
  405. package/dist/plugin-sdk/deps-send-telegram.runtime-Bnjwm6SU.js +0 -24
  406. package/dist/plugin-sdk/deps-send-whatsapp.runtime-CS50_Jgh.js +0 -57
  407. package/dist/plugin-sdk/image-runtime-f-WKB3Bx.js +0 -25
  408. package/dist/plugin-sdk/manager-runtime-DAKJEbuY.js +0 -15
  409. package/dist/plugin-sdk/pi-model-discovery-runtime-Bm4bHwpO.js +0 -8
  410. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-D74eZbH7.js +0 -10
  411. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-BidSddX5.js +0 -19
  412. package/dist/plugin-sdk/slash-commands.runtime-CseiMacz.js +0 -13
  413. package/dist/plugin-sdk/slash-dispatch.runtime-88gX6CLk.js +0 -52
  414. package/dist/plugin-sdk/slash-skill-commands.runtime-BNrQNIZ7.js +0 -16
  415. package/dist/plugin-sdk/subagent-registry-runtime-Cv8RHTjT.js +0 -52
  416. package/dist/plugin-sdk/web-C4tTN9Xu.js +0 -56
  417. package/dist/register.configure-7_PUrx8F.js +0 -165
  418. package/dist/slash-dispatch.runtime-B3gbmyOu.js +0 -114
  419. package/dist/subagent-registry-runtime-C0GbHEOo.js +0 -114
  420. package/dist/web-1FVB4fsI.js +0 -118
  421. package/extensions/diagnostics-otel/node_modules/.bin/acorn +0 -21
  422. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv +0 -21
@@ -2,11 +2,11 @@ import { p as theme } from "./globals-BrhVUl-N.js";
2
2
  import "./paths-CHIu6D1E.js";
3
3
  import { d as defaultRuntime } from "./subsystem-Bw5n50gj.js";
4
4
  import "./boolean-DtWR5bt3.js";
5
- import { z as loadConfig } from "./auth-profiles-ByQNLJzP.js";
5
+ import { z as loadConfig } from "./auth-profiles-BiJk4pUv.js";
6
6
  import { t as formatCliCommand } from "./command-format-D8-lYArk.js";
7
- import "./agent-scope-CfsErfyG.js";
7
+ import "./agent-scope-DipdnGE4.js";
8
8
  import "./utils-D6vohX1h.js";
9
- import "./squidclaw-root-JXyRbQLJ.js";
9
+ import "./squidclaw-root-BQfLymzj.js";
10
10
  import "./logger-DL3N22PJ.js";
11
11
  import "./exec-TSiqsZw1.js";
12
12
  import "./registry-BXcl3IkC.js";
@@ -14,12 +14,12 @@ import "./github-copilot-token-CxitgiZA.js";
14
14
  import "./host-env-security-lcjXF83D.js";
15
15
  import "./version-3so140Zi.js";
16
16
  import "./env-vars-mSSOl7Rv.js";
17
- import "./manifest-registry-1ACGW3OR.js";
18
- import { r as normalizeChannelId } from "./plugins-DFPxMLnR.js";
19
- import "./accounts-BH9Qo1sQ.js";
17
+ import "./manifest-registry-7kwtbCH-.js";
18
+ import { r as normalizeChannelId } from "./plugins-DuLOFZmO.js";
19
+ import "./accounts-BK8I0Svb.js";
20
20
  import "./logging-CcxUDNcI.js";
21
- import { d as listPairingChannels, f as notifyPairingApproved, n as approveChannelPairingCode, r as listChannelPairingRequests } from "./pairing-store-BWvzmAq8.js";
22
- import { t as resolvePairingIdLabel } from "./pairing-labels-DGiyVpfH.js";
21
+ import { d as listPairingChannels, f as notifyPairingApproved, n as approveChannelPairingCode, r as listChannelPairingRequests } from "./pairing-store-BNRzMsGf.js";
22
+ import { t as resolvePairingIdLabel } from "./pairing-labels-ieaV5SBV.js";
23
23
  import { t as formatDocsLink } from "./links-Dye6HsRG.js";
24
24
  import { t as renderTable } from "./table-DbDCX_6t.js";
25
25
 
@@ -1,4 +1,4 @@
1
- import { u as getPairingAdapter } from "./pairing-store-BWvzmAq8.js";
1
+ import { u as getPairingAdapter } from "./pairing-store-BNRzMsGf.js";
2
2
 
3
3
  //#region src/pairing/pairing-labels.ts
4
4
  function resolvePairingIdLabel(channel) {
@@ -1,9 +1,9 @@
1
1
  import { g as resolveStateDir, m as resolveOAuthDir, y as resolveRequiredHomeDir } from "./paths-CHIu6D1E.js";
2
- import { cr as withFileLock$1 } from "./auth-profiles-ByQNLJzP.js";
2
+ import { cr as withFileLock$1 } from "./auth-profiles-BiJk4pUv.js";
3
3
  import { g as DEFAULT_ACCOUNT_ID } from "./session-key-k6urs9r-.js";
4
4
  import { y as safeParseJson } from "./utils-D6vohX1h.js";
5
- import { n as listChannelPlugins, t as getChannelPlugin } from "./plugins-DFPxMLnR.js";
6
- import { r as writeJsonAtomic } from "./json-files-rR19q30D.js";
5
+ import { n as listChannelPlugins, t as getChannelPlugin } from "./plugins-DuLOFZmO.js";
6
+ import { r as writeJsonAtomic } from "./json-files-CuJjdF_0.js";
7
7
  import os from "node:os";
8
8
  import path from "node:path";
9
9
  import fs from "node:fs";
@@ -1,13 +1,13 @@
1
- import { c as BOUNDARY_PATH_ALIAS_POLICIES, f as isNotFoundPathError, l as resolveBoundaryPath } from "./squidclaw-root-JXyRbQLJ.js";
1
+ import { c as BOUNDARY_PATH_ALIAS_POLICIES, f as isNotFoundPathError, l as resolveBoundaryPath } from "./squidclaw-root-BQfLymzj.js";
2
2
  import os from "node:os";
3
- import fsPromises from "node:fs/promises";
3
+ import fs from "node:fs/promises";
4
4
 
5
5
  //#region src/infra/hardlink-guards.ts
6
6
  async function assertNoHardlinkedFinalPath(params) {
7
7
  if (params.allowFinalHardlinkForUnlink) return;
8
8
  let stat;
9
9
  try {
10
- stat = await fsPromises.stat(params.filePath);
10
+ stat = await fs.stat(params.filePath);
11
11
  } catch (err) {
12
12
  if (isNotFoundPathError(err)) return;
13
13
  throw err;
@@ -1,4 +1,4 @@
1
- import { p as isPathInside } from "./squidclaw-root-JXyRbQLJ.js";
1
+ import { p as isPathInside } from "./squidclaw-root-BQfLymzj.js";
2
2
  import path from "node:path";
3
3
 
4
4
  //#region src/infra/path-safety.ts
@@ -1,8 +1,8 @@
1
1
  import { k as resolvePreferredSquidClawTmpDir } from "./globals-BrhVUl-N.js";
2
- import { f as isNotFoundPathError, p as isPathInside } from "./squidclaw-root-JXyRbQLJ.js";
3
- import { i as openFileWithinRoot, t as SafeOpenError } from "./fs-safe-BPQ-per2.js";
2
+ import { f as isNotFoundPathError, p as isPathInside } from "./squidclaw-root-BQfLymzj.js";
3
+ import { i as openFileWithinRoot, t as SafeOpenError } from "./fs-safe-DPYj7h8A.js";
4
4
  import path from "node:path";
5
- import fsPromises from "node:fs/promises";
5
+ import fs from "node:fs/promises";
6
6
 
7
7
  //#region src/browser/form-fields.ts
8
8
  const DEFAULT_FILL_FIELD_TYPE = "text";
@@ -44,28 +44,28 @@ function invalidPath(scopeLabel) {
44
44
  }
45
45
  async function resolveRealPathIfExists(targetPath) {
46
46
  try {
47
- return await fsPromises.realpath(targetPath);
47
+ return await fs.realpath(targetPath);
48
48
  } catch {
49
49
  return;
50
50
  }
51
51
  }
52
52
  async function resolveTrustedRootRealPath(rootDir) {
53
53
  try {
54
- const rootLstat = await fsPromises.lstat(rootDir);
54
+ const rootLstat = await fs.lstat(rootDir);
55
55
  if (!rootLstat.isDirectory() || rootLstat.isSymbolicLink()) return;
56
- return await fsPromises.realpath(rootDir);
56
+ return await fs.realpath(rootDir);
57
57
  } catch {
58
58
  return;
59
59
  }
60
60
  }
61
61
  async function validateCanonicalPathWithinRoot(params) {
62
62
  try {
63
- const candidateLstat = await fsPromises.lstat(params.candidatePath);
63
+ const candidateLstat = await fs.lstat(params.candidatePath);
64
64
  if (candidateLstat.isSymbolicLink()) return "invalid";
65
65
  if (params.expect === "directory" && !candidateLstat.isDirectory()) return "invalid";
66
66
  if (params.expect === "file" && !candidateLstat.isFile()) return "invalid";
67
67
  if (params.expect === "file" && candidateLstat.nlink > 1) return "invalid";
68
- const candidateRealPath = await fsPromises.realpath(params.candidatePath);
68
+ const candidateRealPath = await fs.realpath(params.candidatePath);
69
69
  return isPathInside(params.rootRealPath, candidateRealPath) ? "ok" : "invalid";
70
70
  } catch (err) {
71
71
  return isNotFoundPathError(err) ? "not-found" : "invalid";
@@ -143,7 +143,7 @@ async function resolveCheckedPathsWithinRoot(params) {
143
143
  };
144
144
  if (!rootRealPath || !raw || !path.isAbsolute(raw)) return lexicalPathResult;
145
145
  try {
146
- const resolvedExistingPath = await fsPromises.realpath(raw);
146
+ const resolvedExistingPath = await fs.realpath(raw);
147
147
  const relativePath = path.relative(rootRealPath, resolvedExistingPath);
148
148
  if (!isInRoot(relativePath)) return lexicalPathResult;
149
149
  return {
@@ -1,10 +1,10 @@
1
1
  import { t as createSubsystemLogger } from "./subsystem-Bw5n50gj.js";
2
2
  import { T as truncateUtf16Safe } from "./utils-D6vohX1h.js";
3
- import { s as formatSandboxToolPolicyBlockedMessage } from "./sandbox-DaQ1ruwH.js";
4
- import { t as sanitizeContentBlocksImages } from "./tool-images-D6mmxuWS.js";
3
+ import { s as formatSandboxToolPolicyBlockedMessage } from "./sandbox-CbGxVENW.js";
4
+ import { t as sanitizeContentBlocksImages } from "./tool-images-CyzWvDUu.js";
5
5
  import { s as normalizeThinkLevel } from "./thinking-CrcT589P.js";
6
6
  import path from "node:path";
7
- import fsPromises from "node:fs/promises";
7
+ import fs from "node:fs/promises";
8
8
  import { createHash } from "node:crypto";
9
9
 
10
10
  //#region src/agents/pi-embedded-helpers/bootstrap.ts
@@ -108,10 +108,10 @@ function clampToBudget(content, budget) {
108
108
  async function ensureSessionHeader(params) {
109
109
  const file = params.sessionFile;
110
110
  try {
111
- await fsPromises.stat(file);
111
+ await fs.stat(file);
112
112
  return;
113
113
  } catch {}
114
- await fsPromises.mkdir(path.dirname(file), { recursive: true });
114
+ await fs.mkdir(path.dirname(file), { recursive: true });
115
115
  const entry = {
116
116
  type: "session",
117
117
  version: 2,
@@ -119,7 +119,7 @@ async function ensureSessionHeader(params) {
119
119
  timestamp: (/* @__PURE__ */ new Date()).toISOString(),
120
120
  cwd: params.cwd
121
121
  };
122
- await fsPromises.writeFile(file, `${JSON.stringify(entry)}\n`, "utf-8");
122
+ await fs.writeFile(file, `${JSON.stringify(entry)}\n`, "utf-8");
123
123
  }
124
124
  function buildBootstrapContextFiles(files, opts) {
125
125
  const maxChars = opts?.maxChars ?? DEFAULT_BOOTSTRAP_MAX_CHARS;
@@ -1,5 +1,5 @@
1
1
  import { t as __exportAll } from "./rolldown-runtime-Cbj13DAv.js";
2
- import { Sr as normalizeProviderId, er as ensureAuthProfileStore } from "./auth-profiles-ByQNLJzP.js";
2
+ import { Sr as normalizeProviderId, er as ensureAuthProfileStore } from "./auth-profiles-BiJk4pUv.js";
3
3
  import path from "node:path";
4
4
  import fs from "node:fs";
5
5
  import * as PiCodingAgent from "@mariozechner/pi-coding-agent";
@@ -2,10 +2,10 @@ import "./globals-BrhVUl-N.js";
2
2
  import "./paths-CHIu6D1E.js";
3
3
  import "./subsystem-Bw5n50gj.js";
4
4
  import "./boolean-DtWR5bt3.js";
5
- import "./auth-profiles-ByQNLJzP.js";
6
- import "./agent-scope-CfsErfyG.js";
5
+ import "./auth-profiles-BiJk4pUv.js";
6
+ import "./agent-scope-DipdnGE4.js";
7
7
  import "./utils-D6vohX1h.js";
8
- import "./squidclaw-root-JXyRbQLJ.js";
8
+ import "./squidclaw-root-BQfLymzj.js";
9
9
  import "./logger-DL3N22PJ.js";
10
10
  import "./exec-TSiqsZw1.js";
11
11
  import "./registry-BXcl3IkC.js";
@@ -13,7 +13,7 @@ import "./github-copilot-token-CxitgiZA.js";
13
13
  import "./host-env-security-lcjXF83D.js";
14
14
  import "./version-3so140Zi.js";
15
15
  import "./env-vars-mSSOl7Rv.js";
16
- import "./manifest-registry-1ACGW3OR.js";
17
- import { n as discoverModels, t as discoverAuthStorage } from "./pi-model-discovery-Cj7zDFgN.js";
16
+ import "./manifest-registry-7kwtbCH-.js";
17
+ import { n as discoverModels, t as discoverAuthStorage } from "./pi-model-discovery-D4t0ZFCY.js";
18
18
 
19
19
  export { discoverAuthStorage, discoverModels };
@@ -2,10 +2,10 @@ import "./globals-BrhVUl-N.js";
2
2
  import "./paths-CHIu6D1E.js";
3
3
  import { t as createSubsystemLogger } from "./subsystem-Bw5n50gj.js";
4
4
  import "./boolean-DtWR5bt3.js";
5
- import "./auth-profiles-ByQNLJzP.js";
6
- import "./agent-scope-CfsErfyG.js";
5
+ import "./auth-profiles-BiJk4pUv.js";
6
+ import "./agent-scope-DipdnGE4.js";
7
7
  import { E as isPlainObject } from "./utils-D6vohX1h.js";
8
- import "./squidclaw-root-JXyRbQLJ.js";
8
+ import "./squidclaw-root-BQfLymzj.js";
9
9
  import "./logger-DL3N22PJ.js";
10
10
  import "./exec-TSiqsZw1.js";
11
11
  import "./registry-BXcl3IkC.js";
@@ -13,8 +13,8 @@ import "./github-copilot-token-CxitgiZA.js";
13
13
  import "./host-env-security-lcjXF83D.js";
14
14
  import "./version-3so140Zi.js";
15
15
  import "./env-vars-mSSOl7Rv.js";
16
- import "./manifest-registry-1ACGW3OR.js";
17
- import { h as getDiagnosticSessionState, s as logToolLoopAction } from "./diagnostic-CT4BKCiT.js";
16
+ import "./manifest-registry-7kwtbCH-.js";
17
+ import { h as getDiagnosticSessionState, s as logToolLoopAction } from "./diagnostic-Du3b17ba.js";
18
18
  import { createHash } from "node:crypto";
19
19
 
20
20
  //#region src/agents/tool-loop-detection.ts
@@ -1,10 +1,10 @@
1
- import { Vn as DEFAULT_SUBAGENT_MAX_SPAWN_DEPTH } from "./auth-profiles-ByQNLJzP.js";
2
- import { i as resolveAgentConfig } from "./agent-scope-CfsErfyG.js";
1
+ import { Vn as DEFAULT_SUBAGENT_MAX_SPAWN_DEPTH } from "./auth-profiles-BiJk4pUv.js";
2
+ import { i as resolveAgentConfig } from "./agent-scope-DipdnGE4.js";
3
3
  import { D as resolveThreadParentSessionKey, c as normalizeAgentId, u as resolveAgentIdFromSessionKey } from "./session-key-k6urs9r-.js";
4
- import { l as normalizeStringEntries, o as resolveChannelGroupToolsPolicy, t as getChannelDock } from "./dock-0fXeq35m.js";
4
+ import { l as normalizeStringEntries, o as resolveChannelGroupToolsPolicy, t as getChannelDock } from "./dock-gKJjfuaV.js";
5
5
  import { l as normalizeMessageChannel } from "./message-channel-DqvtYF2o.js";
6
- import { S as normalizeToolName, T as matchesAnyGlobPattern, w as compileGlobPatterns, x as expandToolGroups } from "./sandbox-DaQ1ruwH.js";
7
- import { i as readChannelAllowFromStore } from "./pairing-store-BWvzmAq8.js";
6
+ import { S as normalizeToolName, T as matchesAnyGlobPattern, w as compileGlobPatterns, x as expandToolGroups } from "./sandbox-CbGxVENW.js";
7
+ import { i as readChannelAllowFromStore } from "./pairing-store-BNRzMsGf.js";
8
8
  import { i as resolveGroupAllowFromSources, r as mergeDmAllowFromSources } from "./allow-from-DzfdGdp7.js";
9
9
 
10
10
  //#region src/channels/command-gating.ts
@@ -1,9 +1,9 @@
1
- import { Sr as normalizeProviderId } from "./auth-profiles-ByQNLJzP.js";
1
+ import { Sr as normalizeProviderId } from "./auth-profiles-BiJk4pUv.js";
2
2
  import { t as CONFIG_DIR, u as isRecord, v as resolveUserPath } from "./utils-D6vohX1h.js";
3
3
  import { a as getChatChannelMeta, l as normalizeChatChannelId, o as listChatChannels } from "./registry-BXcl3IkC.js";
4
4
  import { n as MANIFEST_KEY } from "./legacy-names-Q0o_2ITh.js";
5
- import { n as loadPluginManifestRegistry, r as discoverSquidClawPlugins } from "./manifest-registry-1ACGW3OR.js";
6
- import { t as hasAnyWhatsAppAuth } from "./accounts-BH9Qo1sQ.js";
5
+ import { n as loadPluginManifestRegistry, r as discoverSquidClawPlugins } from "./manifest-registry-7kwtbCH-.js";
6
+ import { t as hasAnyWhatsAppAuth } from "./accounts-BK8I0Svb.js";
7
7
  import path from "node:path";
8
8
  import fs from "node:fs";
9
9
 
@@ -1,9 +1,9 @@
1
1
  import { t as __exportAll } from "./rolldown-runtime-Cbj13DAv.js";
2
2
  import { t as createSubsystemLogger } from "./subsystem-Bw5n50gj.js";
3
- import { z as loadConfig } from "./auth-profiles-ByQNLJzP.js";
4
- import { d as resolveDefaultAgentId, u as resolveAgentWorkspaceDir } from "./agent-scope-CfsErfyG.js";
3
+ import { z as loadConfig } from "./auth-profiles-BiJk4pUv.js";
4
+ import { d as resolveDefaultAgentId, u as resolveAgentWorkspaceDir } from "./agent-scope-DipdnGE4.js";
5
5
  import { u as getActivePluginRegistry } from "./registry-BXcl3IkC.js";
6
- import { b as loadSquidClawPlugins } from "./subagent-registry-o5rZt_4e.js";
6
+ import { b as loadSquidClawPlugins } from "./subagent-registry-BE1B0_sO.js";
7
7
 
8
8
  //#region src/cli/plugin-registry.ts
9
9
  var plugin_registry_exports = /* @__PURE__ */ __exportAll({ ensurePluginRegistryLoaded: () => ensurePluginRegistryLoaded });
@@ -1,5 +1,5 @@
1
- import { ot as normalizeAccountId } from "./run-with-concurrency-EUEKeAa8.js";
2
- import { v as resolveAccountEntry, y as createAccountListHelpers } from "./accounts-DKXGC2Vu.js";
1
+ import { ot as normalizeAccountId } from "./run-with-concurrency-CYcPpb5E.js";
2
+ import { v as resolveAccountEntry, y as createAccountListHelpers } from "./accounts-BvzvDHNx.js";
3
3
 
4
4
  //#region src/imessage/accounts.ts
5
5
  const { listAccountIds, resolveDefaultAccountId } = createAccountListHelpers("imessage");
@@ -0,0 +1,288 @@
1
+ import { at as DEFAULT_ACCOUNT_ID, ot as normalizeAccountId, st as normalizeOptionalAccountId } from "./run-with-concurrency-vfuRiXdY.js";
2
+ import { o as resolveOAuthDir } from "./paths-8xF5kDne.js";
3
+ import { Pr as formatCliCommand } from "./config-B16xKqSo.js";
4
+ import { B as success, E as resolveUserPath, G as getChildLogger, I as info, c as defaultRuntime, x as jidToE164 } from "./logger-DDdrdbDu.js";
5
+ import fs from "node:fs";
6
+ import path from "node:path";
7
+ import fs$1 from "node:fs/promises";
8
+
9
+ //#region src/channels/plugins/account-helpers.ts
10
+ function createAccountListHelpers(channelKey) {
11
+ function resolveConfiguredDefaultAccountId(cfg) {
12
+ const channel = cfg.channels?.[channelKey];
13
+ const preferred = normalizeOptionalAccountId(typeof channel?.defaultAccount === "string" ? channel.defaultAccount : void 0);
14
+ if (!preferred) return;
15
+ if (listAccountIds(cfg).some((id) => normalizeAccountId(id) === preferred)) return preferred;
16
+ }
17
+ function listConfiguredAccountIds(cfg) {
18
+ const accounts = (cfg.channels?.[channelKey])?.accounts;
19
+ if (!accounts || typeof accounts !== "object") return [];
20
+ return Object.keys(accounts).filter(Boolean);
21
+ }
22
+ function listAccountIds(cfg) {
23
+ const ids = listConfiguredAccountIds(cfg);
24
+ if (ids.length === 0) return [DEFAULT_ACCOUNT_ID];
25
+ return ids.toSorted((a, b) => a.localeCompare(b));
26
+ }
27
+ function resolveDefaultAccountId(cfg) {
28
+ const preferred = resolveConfiguredDefaultAccountId(cfg);
29
+ if (preferred) return preferred;
30
+ const ids = listAccountIds(cfg);
31
+ if (ids.includes(DEFAULT_ACCOUNT_ID)) return DEFAULT_ACCOUNT_ID;
32
+ return ids[0] ?? DEFAULT_ACCOUNT_ID;
33
+ }
34
+ return {
35
+ listConfiguredAccountIds,
36
+ listAccountIds,
37
+ resolveDefaultAccountId
38
+ };
39
+ }
40
+
41
+ //#endregion
42
+ //#region src/routing/account-lookup.ts
43
+ function resolveAccountEntry(accounts, accountId) {
44
+ if (!accounts || typeof accounts !== "object") return;
45
+ if (Object.hasOwn(accounts, accountId)) return accounts[accountId];
46
+ const normalized = accountId.toLowerCase();
47
+ const matchKey = Object.keys(accounts).find((key) => key.toLowerCase() === normalized);
48
+ return matchKey ? accounts[matchKey] : void 0;
49
+ }
50
+
51
+ //#endregion
52
+ //#region src/web/auth-store.ts
53
+ function resolveDefaultWebAuthDir() {
54
+ return path.join(resolveOAuthDir(), "whatsapp", DEFAULT_ACCOUNT_ID);
55
+ }
56
+ const WA_WEB_AUTH_DIR = resolveDefaultWebAuthDir();
57
+ function resolveWebCredsPath(authDir) {
58
+ return path.join(authDir, "creds.json");
59
+ }
60
+ function resolveWebCredsBackupPath(authDir) {
61
+ return path.join(authDir, "creds.json.bak");
62
+ }
63
+ function hasWebCredsSync(authDir) {
64
+ try {
65
+ const stats = fs.statSync(resolveWebCredsPath(authDir));
66
+ return stats.isFile() && stats.size > 1;
67
+ } catch {
68
+ return false;
69
+ }
70
+ }
71
+ function readCredsJsonRaw(filePath) {
72
+ try {
73
+ if (!fs.existsSync(filePath)) return null;
74
+ const stats = fs.statSync(filePath);
75
+ if (!stats.isFile() || stats.size <= 1) return null;
76
+ return fs.readFileSync(filePath, "utf-8");
77
+ } catch {
78
+ return null;
79
+ }
80
+ }
81
+ function maybeRestoreCredsFromBackup(authDir) {
82
+ const logger = getChildLogger({ module: "web-session" });
83
+ try {
84
+ const credsPath = resolveWebCredsPath(authDir);
85
+ const backupPath = resolveWebCredsBackupPath(authDir);
86
+ const raw = readCredsJsonRaw(credsPath);
87
+ if (raw) {
88
+ JSON.parse(raw);
89
+ return;
90
+ }
91
+ const backupRaw = readCredsJsonRaw(backupPath);
92
+ if (!backupRaw) return;
93
+ JSON.parse(backupRaw);
94
+ fs.copyFileSync(backupPath, credsPath);
95
+ try {
96
+ fs.chmodSync(credsPath, 384);
97
+ } catch {}
98
+ logger.warn({ credsPath }, "restored corrupted WhatsApp creds.json from backup");
99
+ } catch {}
100
+ }
101
+ async function webAuthExists(authDir = resolveDefaultWebAuthDir()) {
102
+ const resolvedAuthDir = resolveUserPath(authDir);
103
+ maybeRestoreCredsFromBackup(resolvedAuthDir);
104
+ const credsPath = resolveWebCredsPath(resolvedAuthDir);
105
+ try {
106
+ await fs$1.access(resolvedAuthDir);
107
+ } catch {
108
+ return false;
109
+ }
110
+ try {
111
+ const stats = await fs$1.stat(credsPath);
112
+ if (!stats.isFile() || stats.size <= 1) return false;
113
+ const raw = await fs$1.readFile(credsPath, "utf-8");
114
+ JSON.parse(raw);
115
+ return true;
116
+ } catch {
117
+ return false;
118
+ }
119
+ }
120
+ async function clearLegacyBaileysAuthState(authDir) {
121
+ const entries = await fs$1.readdir(authDir, { withFileTypes: true });
122
+ const shouldDelete = (name) => {
123
+ if (name === "oauth.json") return false;
124
+ if (name === "creds.json" || name === "creds.json.bak") return true;
125
+ if (!name.endsWith(".json")) return false;
126
+ return /^(app-state-sync|session|sender-key|pre-key)-/.test(name);
127
+ };
128
+ await Promise.all(entries.map(async (entry) => {
129
+ if (!entry.isFile()) return;
130
+ if (!shouldDelete(entry.name)) return;
131
+ await fs$1.rm(path.join(authDir, entry.name), { force: true });
132
+ }));
133
+ }
134
+ async function logoutWeb(params) {
135
+ const runtime = params.runtime ?? defaultRuntime;
136
+ const resolvedAuthDir = resolveUserPath(params.authDir ?? resolveDefaultWebAuthDir());
137
+ if (!await webAuthExists(resolvedAuthDir)) {
138
+ runtime.log(info("No WhatsApp Web session found; nothing to delete."));
139
+ return false;
140
+ }
141
+ if (params.isLegacyAuthDir) await clearLegacyBaileysAuthState(resolvedAuthDir);
142
+ else await fs$1.rm(resolvedAuthDir, {
143
+ recursive: true,
144
+ force: true
145
+ });
146
+ runtime.log(success("Cleared WhatsApp Web credentials."));
147
+ return true;
148
+ }
149
+ function readWebSelfId(authDir = resolveDefaultWebAuthDir()) {
150
+ try {
151
+ const credsPath = resolveWebCredsPath(resolveUserPath(authDir));
152
+ if (!fs.existsSync(credsPath)) return {
153
+ e164: null,
154
+ jid: null
155
+ };
156
+ const raw = fs.readFileSync(credsPath, "utf-8");
157
+ const jid = JSON.parse(raw)?.me?.id ?? null;
158
+ return {
159
+ e164: jid ? jidToE164(jid, { authDir }) : null,
160
+ jid
161
+ };
162
+ } catch {
163
+ return {
164
+ e164: null,
165
+ jid: null
166
+ };
167
+ }
168
+ }
169
+ /**
170
+ * Return the age (in milliseconds) of the cached WhatsApp web auth state, or null when missing.
171
+ * Helpful for heartbeats/observability to spot stale credentials.
172
+ */
173
+ function getWebAuthAgeMs(authDir = resolveDefaultWebAuthDir()) {
174
+ try {
175
+ const stats = fs.statSync(resolveWebCredsPath(resolveUserPath(authDir)));
176
+ return Date.now() - stats.mtimeMs;
177
+ } catch {
178
+ return null;
179
+ }
180
+ }
181
+ function logWebSelfId(authDir = resolveDefaultWebAuthDir(), runtime = defaultRuntime, includeChannelPrefix = false) {
182
+ const { e164, jid } = readWebSelfId(authDir);
183
+ const details = e164 || jid ? `${e164 ?? "unknown"}${jid ? ` (jid ${jid})` : ""}` : "unknown";
184
+ const prefix = includeChannelPrefix ? "Web Channel: " : "";
185
+ runtime.log(info(`${prefix}${details}`));
186
+ }
187
+ async function pickWebChannel(pref, authDir = resolveDefaultWebAuthDir()) {
188
+ const choice = pref === "auto" ? "web" : pref;
189
+ if (!await webAuthExists(authDir)) throw new Error(`No WhatsApp Web session found. Run \`${formatCliCommand("squidclaw channels login --channel whatsapp --verbose")}\` to link.`);
190
+ return choice;
191
+ }
192
+
193
+ //#endregion
194
+ //#region src/web/accounts.ts
195
+ const { listConfiguredAccountIds, listAccountIds, resolveDefaultAccountId } = createAccountListHelpers("whatsapp");
196
+ const listWhatsAppAccountIds = listAccountIds;
197
+ const resolveDefaultWhatsAppAccountId = resolveDefaultAccountId;
198
+ function listWhatsAppAuthDirs(cfg) {
199
+ const oauthDir = resolveOAuthDir();
200
+ const whatsappDir = path.join(oauthDir, "whatsapp");
201
+ const authDirs = new Set([oauthDir, path.join(whatsappDir, DEFAULT_ACCOUNT_ID)]);
202
+ const accountIds = listConfiguredAccountIds(cfg);
203
+ for (const accountId of accountIds) authDirs.add(resolveWhatsAppAuthDir({
204
+ cfg,
205
+ accountId
206
+ }).authDir);
207
+ try {
208
+ const entries = fs.readdirSync(whatsappDir, { withFileTypes: true });
209
+ for (const entry of entries) {
210
+ if (!entry.isDirectory()) continue;
211
+ authDirs.add(path.join(whatsappDir, entry.name));
212
+ }
213
+ } catch {}
214
+ return Array.from(authDirs);
215
+ }
216
+ function hasAnyWhatsAppAuth(cfg) {
217
+ return listWhatsAppAuthDirs(cfg).some((authDir) => hasWebCredsSync(authDir));
218
+ }
219
+ function resolveAccountConfig(cfg, accountId) {
220
+ return resolveAccountEntry(cfg.channels?.whatsapp?.accounts, accountId);
221
+ }
222
+ function resolveDefaultAuthDir(accountId) {
223
+ return path.join(resolveOAuthDir(), "whatsapp", normalizeAccountId(accountId));
224
+ }
225
+ function resolveLegacyAuthDir() {
226
+ return resolveOAuthDir();
227
+ }
228
+ function legacyAuthExists(authDir) {
229
+ try {
230
+ return fs.existsSync(path.join(authDir, "creds.json"));
231
+ } catch {
232
+ return false;
233
+ }
234
+ }
235
+ function resolveWhatsAppAuthDir(params) {
236
+ const accountId = params.accountId.trim() || DEFAULT_ACCOUNT_ID;
237
+ const configured = resolveAccountConfig(params.cfg, accountId)?.authDir?.trim();
238
+ if (configured) return {
239
+ authDir: resolveUserPath(configured),
240
+ isLegacy: false
241
+ };
242
+ const defaultDir = resolveDefaultAuthDir(accountId);
243
+ if (accountId === DEFAULT_ACCOUNT_ID) {
244
+ const legacyDir = resolveLegacyAuthDir();
245
+ if (legacyAuthExists(legacyDir) && !legacyAuthExists(defaultDir)) return {
246
+ authDir: legacyDir,
247
+ isLegacy: true
248
+ };
249
+ }
250
+ return {
251
+ authDir: defaultDir,
252
+ isLegacy: false
253
+ };
254
+ }
255
+ function resolveWhatsAppAccount(params) {
256
+ const rootCfg = params.cfg.channels?.whatsapp;
257
+ const accountId = params.accountId?.trim() || resolveDefaultWhatsAppAccountId(params.cfg);
258
+ const accountCfg = resolveAccountConfig(params.cfg, accountId);
259
+ const enabled = accountCfg?.enabled !== false;
260
+ const { authDir, isLegacy } = resolveWhatsAppAuthDir({
261
+ cfg: params.cfg,
262
+ accountId
263
+ });
264
+ return {
265
+ accountId,
266
+ name: accountCfg?.name?.trim() || void 0,
267
+ enabled,
268
+ sendReadReceipts: accountCfg?.sendReadReceipts ?? rootCfg?.sendReadReceipts ?? true,
269
+ messagePrefix: accountCfg?.messagePrefix ?? rootCfg?.messagePrefix ?? params.cfg.messages?.messagePrefix,
270
+ authDir,
271
+ isLegacyAuthDir: isLegacy,
272
+ selfChatMode: accountCfg?.selfChatMode ?? rootCfg?.selfChatMode,
273
+ dmPolicy: accountCfg?.dmPolicy ?? rootCfg?.dmPolicy,
274
+ allowFrom: accountCfg?.allowFrom ?? rootCfg?.allowFrom,
275
+ groupAllowFrom: accountCfg?.groupAllowFrom ?? rootCfg?.groupAllowFrom,
276
+ groupPolicy: accountCfg?.groupPolicy ?? rootCfg?.groupPolicy,
277
+ textChunkLimit: accountCfg?.textChunkLimit ?? rootCfg?.textChunkLimit,
278
+ chunkMode: accountCfg?.chunkMode ?? rootCfg?.chunkMode,
279
+ mediaMaxMb: accountCfg?.mediaMaxMb ?? rootCfg?.mediaMaxMb,
280
+ blockStreaming: accountCfg?.blockStreaming ?? rootCfg?.blockStreaming,
281
+ ackReaction: accountCfg?.ackReaction ?? rootCfg?.ackReaction,
282
+ groups: accountCfg?.groups ?? rootCfg?.groups,
283
+ debounceMs: accountCfg?.debounceMs ?? rootCfg?.debounceMs
284
+ };
285
+ }
286
+
287
+ //#endregion
288
+ export { webAuthExists as _, resolveWhatsAppAuthDir as a, logWebSelfId as c, pickWebChannel as d, readCredsJsonRaw as f, resolveWebCredsPath as g, resolveWebCredsBackupPath as h, resolveWhatsAppAccount as i, logoutWeb as l, resolveDefaultWebAuthDir as m, listWhatsAppAccountIds as n, WA_WEB_AUTH_DIR as o, readWebSelfId as p, resolveDefaultWhatsAppAccountId as r, getWebAuthAgeMs as s, hasAnyWhatsAppAuth as t, maybeRestoreCredsFromBackup as u, resolveAccountEntry as v, createAccountListHelpers as y };
@@ -1,6 +1,6 @@
1
- import { at as DEFAULT_ACCOUNT_ID, ot as normalizeAccountId, st as normalizeOptionalAccountId } from "./run-with-concurrency-EUEKeAa8.js";
2
- import { Tr as formatCliCommand } from "./config-sMifxgre.js";
3
- import { B as success, G as getChildLogger, I as info, j as defaultRuntime, m as jidToE164, y as resolveUserPath } from "./logger-DIb2cGHp.js";
1
+ import { at as DEFAULT_ACCOUNT_ID, ot as normalizeAccountId, st as normalizeOptionalAccountId } from "./run-with-concurrency-CYcPpb5E.js";
2
+ import { Tr as formatCliCommand } from "./config-CMjn_DSB.js";
3
+ import { B as success, G as getChildLogger, I as info, j as defaultRuntime, m as jidToE164, y as resolveUserPath } from "./logger-Bg4vIUJn.js";
4
4
  import { o as resolveOAuthDir } from "./paths-Duwviem_.js";
5
5
  import path from "node:path";
6
6
  import fs from "node:fs";
@@ -1,5 +1,5 @@
1
- import { ot as normalizeAccountId } from "./run-with-concurrency-EUEKeAa8.js";
2
- import { v as resolveAccountEntry, y as createAccountListHelpers } from "./accounts-DKXGC2Vu.js";
1
+ import { ot as normalizeAccountId } from "./run-with-concurrency-CYcPpb5E.js";
2
+ import { v as resolveAccountEntry, y as createAccountListHelpers } from "./accounts-BvzvDHNx.js";
3
3
 
4
4
  //#region src/signal/accounts.ts
5
5
  const { listAccountIds, resolveDefaultAccountId } = createAccountListHelpers("signal");
@@ -0,0 +1,46 @@
1
+ import { ot as normalizeAccountId } from "./run-with-concurrency-vfuRiXdY.js";
2
+ import { v as resolveAccountEntry, y as createAccountListHelpers } from "./accounts-BXFDqY90.js";
3
+
4
+ //#region src/signal/accounts.ts
5
+ const { listAccountIds, resolveDefaultAccountId } = createAccountListHelpers("signal");
6
+ const listSignalAccountIds = listAccountIds;
7
+ const resolveDefaultSignalAccountId = resolveDefaultAccountId;
8
+ function resolveAccountConfig(cfg, accountId) {
9
+ return resolveAccountEntry(cfg.channels?.signal?.accounts, accountId);
10
+ }
11
+ function mergeSignalAccountConfig(cfg, accountId) {
12
+ const { accounts: _ignored, ...base } = cfg.channels?.signal ?? {};
13
+ const account = resolveAccountConfig(cfg, accountId) ?? {};
14
+ return {
15
+ ...base,
16
+ ...account
17
+ };
18
+ }
19
+ function resolveSignalAccount(params) {
20
+ const accountId = normalizeAccountId(params.accountId);
21
+ const baseEnabled = params.cfg.channels?.signal?.enabled !== false;
22
+ const merged = mergeSignalAccountConfig(params.cfg, accountId);
23
+ const accountEnabled = merged.enabled !== false;
24
+ const enabled = baseEnabled && accountEnabled;
25
+ const host = merged.httpHost?.trim() || "127.0.0.1";
26
+ const port = merged.httpPort ?? 8080;
27
+ const baseUrl = merged.httpUrl?.trim() || `http://${host}:${port}`;
28
+ const configured = Boolean(merged.account?.trim() || merged.httpUrl?.trim() || merged.cliPath?.trim() || merged.httpHost?.trim() || typeof merged.httpPort === "number" || typeof merged.autoStart === "boolean");
29
+ return {
30
+ accountId,
31
+ enabled,
32
+ name: merged.name?.trim() || void 0,
33
+ baseUrl,
34
+ configured,
35
+ config: merged
36
+ };
37
+ }
38
+ function listEnabledSignalAccounts(cfg) {
39
+ return listSignalAccountIds(cfg).map((accountId) => resolveSignalAccount({
40
+ cfg,
41
+ accountId
42
+ })).filter((account) => account.enabled);
43
+ }
44
+
45
+ //#endregion
46
+ export { resolveSignalAccount as i, listSignalAccountIds as n, resolveDefaultSignalAccountId as r, listEnabledSignalAccounts as t };