@qqbrowser/openclaw-qbot 0.10.4 → 0.10.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{agents-uUms0egI.js → agents-6IxtknW5.js} +1 -1
- package/dist/{agents.config-BkB-gDby.js → agents.config-BP_dS899.js} +1 -1
- package/dist/{agents.config-Brf_8LyQ.js → agents.config-CQVkG48F.js} +1 -1
- package/dist/{auth-choice-CCPa_U3z.js → auth-choice-Baa2-mnd.js} +1 -1
- package/dist/{auth-choice-hlkl-WTV.js → auth-choice-Cw_bwgkr.js} +1 -1
- package/dist/{banner-DEPUY9RS.js → banner-CLI1ZxLT.js} +1 -1
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +1 -1
- package/dist/bundled/session-memory/handler.js +1 -1
- package/dist/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/{channel-options-DqUyBMZF.js → channel-options-BmkYp9PQ.js} +1 -1
- package/dist/{channel-options-BbvCeuF4.js → channel-options-LL0twjcr.js} +1 -1
- package/dist/{channel-web-B7Dzfxgr.js → channel-web-DBxLlMxt.js} +1 -1
- package/dist/{channel-web-DztiTFmw.js → channel-web-DCbW654e.js} +1 -1
- package/dist/{channels-cli-B167LkN_.js → channels-cli-BDMHUXO6.js} +1 -1
- package/dist/{channels-cli-DqI5sufA.js → channels-cli-BomYL9U-.js} +1 -1
- package/dist/{cli-5w9Cs17g.js → cli-6GYOgeyE.js} +1 -1
- package/dist/{cli-odx2Ou54.js → cli-DcG2OfeS.js} +1 -1
- package/dist/{command-registry-kuOSuxH9.js → command-registry-B-1wiWIV.js} +1 -1
- package/dist/{compact-DutiJiBy.js → compact-B5m4267P.js} +6 -6
- package/dist/{compact.runtime-Cg-ayyOY.js → compact.runtime-BIprdRVY.js} +1 -1
- package/dist/{compact.runtime-CPJx43fM.js → compact.runtime-Bjmb9uWf.js} +1 -1
- package/dist/{compact.runtime-Cr0LrigW.js → compact.runtime-CC5tXNMI.js} +1 -1
- package/dist/{compact.runtime-8jjZMOn5.js → compact.runtime-CbiLGd2R.js} +1 -1
- package/dist/{completion-cli-Dk4i8AEs.js → completion-cli-BxTvZFra.js} +1 -1
- package/dist/{completion-cli-Btm1nzLM.js → completion-cli-CXSmC7Nh.js} +1 -1
- package/dist/{config-cli-C_Ep8Cqd.js → config-cli-CutpYl0W.js} +1 -1
- package/dist/{config-cli-GxgWLhZj.js → config-cli-_D9OjHjN.js} +1 -1
- package/dist/{configure-BGXAqK0_.js → configure-B7A-Gjbn.js} +1 -1
- package/dist/{configure-Bf9CYm_s.js → configure-GlFIJmRr.js} +1 -1
- package/dist/{deps-send-whatsapp.runtime-zwmhmYbD.js → deps-send-whatsapp.runtime-0CVkFH3c.js} +1 -1
- package/dist/{deps-send-whatsapp.runtime-BvP4xsTU.js → deps-send-whatsapp.runtime-CF7vGOV-.js} +1 -1
- package/dist/{deps-send-whatsapp.runtime-B0YhL8Lo.js → deps-send-whatsapp.runtime-CZWj9whB.js} +1 -1
- package/dist/{deps-send-whatsapp.runtime-DM3gFV5P.js → deps-send-whatsapp.runtime-CpRUDATB.js} +1 -1
- package/dist/{doctor-completion-Bp4r91Mj.js → doctor-completion-C5fxcbh9.js} +1 -1
- package/dist/{doctor-completion-DSlo6bQA.js → doctor-completion-CjAt0IBL.js} +1 -1
- package/dist/entry.js +1 -1
- package/dist/extensionAPI.js +1 -1
- package/dist/{gateway-cli-xHMUWDWx.js → gateway-cli-B4--4Rdp.js} +2 -2
- package/dist/{gateway-cli-C_zcjGt1.js → gateway-cli-LXL-gdmD.js} +2 -2
- package/dist/{health-vy-C49Dw.js → health-CIBrUBhW.js} +1 -1
- package/dist/{health-DWAEDZ8p.js → health-dTYbHKsD.js} +1 -1
- package/dist/{hooks-cli-DkjR_IzY.js → hooks-cli-B8zLSVkT.js} +1 -1
- package/dist/{hooks-cli-B0xRT8IB.js → hooks-cli-CQiuXLiA.js} +1 -1
- package/dist/index.js +2 -2
- package/dist/llm-slug-generator.js +1 -1
- package/dist/{models-CYk2Mf4W.js → models-DfPjqkxA.js} +1 -1
- package/dist/{models-cli-DPcl8k5z.js → models-cli-Crhj5KsH.js} +1 -1
- package/dist/{models-cli-BS5KD1m7.js → models-cli-DIeJKv20.js} +1 -1
- package/dist/{npm-resolution-BRKzOuRX.js → npm-resolution-BsQW2Kgr.js} +1 -1
- package/dist/{npm-resolution-B4ClzLA9.js → npm-resolution-wJ9PVAU8.js} +1 -1
- package/dist/{onboard-DtvFX5YS.js → onboard-CkDnD6Va.js} +2 -2
- package/dist/{onboard-DKohpAhM.js → onboard-DbFfuUgN.js} +2 -2
- package/dist/{onboard-channels-CO9FE0CA.js → onboard-channels-BW1eMy7S.js} +1 -1
- package/dist/{onboard-channels-B1Cta60W.js → onboard-channels-C0PAtk4T.js} +1 -1
- package/dist/{onboarding-CSBYu9X2.js → onboarding-DVLGoQj1.js} +1 -1
- package/dist/{onboarding-DTE81H7h.js → onboarding-enOGIWg6.js} +1 -1
- package/dist/{onboarding.finalize-Bk61Ef85.js → onboarding.finalize-BDLzh4dK.js} +1 -1
- package/dist/{onboarding.finalize-BzZq5LCu.js → onboarding.finalize-aguVHE5H.js} +1 -1
- package/dist/{pi-embedded-fKs8vr_l.js → pi-embedded-Bv3QACci.js} +6 -6
- package/dist/{pi-embedded-CSE8iTcT.js → pi-embedded-DJGgW90C.js} +6 -6
- package/dist/{plugin-registry--rKSomNR.js → plugin-registry-Cb3qsabM.js} +1 -1
- package/dist/{plugin-registry-BLopxJhs.js → plugin-registry-DgGaQJpH.js} +1 -1
- package/dist/plugin-sdk/{channel-web-kLUJoIaN.js → channel-web-B69hreZ-.js} +1 -1
- package/dist/plugin-sdk/{channel-web-BZwnvMDD.cjs → channel-web-CGYvIoB3.cjs} +1 -1
- package/dist/plugin-sdk/{channel-web-BUiDMnQM.js → channel-web-Cg7FoMmy.js} +1 -1
- package/dist/plugin-sdk/{channel-web-Dn8Qa28U.cjs → channel-web-yRiw9cOW.cjs} +1 -1
- package/dist/plugin-sdk/{compact.runtime-BtnHPGWW.cjs → compact.runtime-6EUZS-nm.cjs} +1 -1
- package/dist/plugin-sdk/{compact.runtime-PwQ5BH89.cjs → compact.runtime-BCReDZO0.cjs} +1 -1
- package/dist/plugin-sdk/{compact.runtime-CcAl_7JS.cjs → compact.runtime-BV8EhsZ-.cjs} +1 -1
- package/dist/plugin-sdk/{compact.runtime-BDSrWIc3.js → compact.runtime-BrTHTIXo.js} +1 -1
- package/dist/plugin-sdk/{compact.runtime-WzRsTof6.js → compact.runtime-C-nSnIie.js} +1 -1
- package/dist/plugin-sdk/{compact.runtime-D6zMtomh.js → compact.runtime-C1HIq_JF.js} +1 -1
- package/dist/plugin-sdk/{compact.runtime-DrbWVG3U.cjs → compact.runtime-CuU_iabG.cjs} +1 -1
- package/dist/plugin-sdk/{compact.runtime-CB04vm0D.js → compact.runtime-D64Cnn1T.js} +1 -1
- package/dist/plugin-sdk/{compact.runtime-BDZgCqEH.cjs → compact.runtime-DEsDlL2e.cjs} +1 -1
- package/dist/plugin-sdk/{compact.runtime-D4jmyLK_.js → compact.runtime-DyyEYJhk.js} +1 -1
- package/dist/plugin-sdk/{compact.runtime-DiGElRVu.cjs → compact.runtime-hD-8StlH.cjs} +1 -1
- package/dist/plugin-sdk/{compact.runtime-DpKoN-EI.js → compact.runtime-nrAibbrs.js} +1 -1
- package/dist/plugin-sdk/compat.cjs +1 -1
- package/dist/plugin-sdk/compat.js +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-D9D9oUEf.js → deps-send-whatsapp.runtime-BHSEddX6.js} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-DAq8oj_z.cjs → deps-send-whatsapp.runtime-BIcx-YKg.cjs} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-Du9woGpt.js → deps-send-whatsapp.runtime-BJqrGRfn.js} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-Bu592CgI.cjs → deps-send-whatsapp.runtime-BYitkwEt.cjs} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-CslTgnDb.cjs → deps-send-whatsapp.runtime-BZZlnkSu.cjs} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-Ck_Odtet.cjs → deps-send-whatsapp.runtime-C8CHSY5s.cjs} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-C8VavsCw.cjs → deps-send-whatsapp.runtime-Cc_K5nip.cjs} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-BIa0po8R.js → deps-send-whatsapp.runtime-CcxJ3x8i.js} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-D8utCFrm.js → deps-send-whatsapp.runtime-CtGDGABW.js} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-BjCkJL25.js → deps-send-whatsapp.runtime-DKBA8CwU.js} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-D7XufA9p.js → deps-send-whatsapp.runtime-ty7jacKq.js} +1 -1
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-Bc3Bslu5.cjs → deps-send-whatsapp.runtime-uvxKpBrR.cjs} +1 -1
- package/dist/plugin-sdk/{dispatch-B0bRcI0M.js → dispatch-3RmgaKV0.js} +6 -6
- package/dist/plugin-sdk/{dispatch-CXFmGh30.cjs → dispatch-BHwyFTwz.cjs} +6 -6
- package/dist/plugin-sdk/{dispatch-CuIxFSWG.js → dispatch-BYn5wxRI.js} +6 -6
- package/dist/plugin-sdk/{dispatch-DZFfZ37w.cjs → dispatch-C-qRxvLo.cjs} +6 -6
- package/dist/plugin-sdk/{dispatch-CXTBtHYf.cjs → dispatch-CDF-QMLO.cjs} +6 -6
- package/dist/plugin-sdk/{dispatch-BzOxEE_U.cjs → dispatch-DBHCub77.cjs} +6 -6
- package/dist/plugin-sdk/{dispatch-DgMf2rhn.cjs → dispatch-DCFiq6TV.cjs} +6 -6
- package/dist/plugin-sdk/{dispatch-BHQwp2mY.js → dispatch-Dbp8KQt5.js} +6 -6
- package/dist/plugin-sdk/{dispatch-CsZWuLFg.js → dispatch-DpHTL-Ha.js} +6 -6
- package/dist/plugin-sdk/{dispatch-DXQq-1ND.js → dispatch-t6yxQhjZ.js} +6 -6
- package/dist/plugin-sdk/index.cjs +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/irc.cjs +1 -1
- package/dist/plugin-sdk/irc.js +1 -1
- package/dist/plugin-sdk/matrix.cjs +1 -1
- package/dist/plugin-sdk/matrix.js +1 -1
- package/dist/plugin-sdk/msteams.cjs +1 -1
- package/dist/plugin-sdk/msteams.js +1 -1
- package/dist/plugin-sdk/nextcloud-talk.cjs +1 -1
- package/dist/plugin-sdk/nextcloud-talk.js +1 -1
- package/dist/plugin-sdk/{reply-9oEGfJO1.cjs → reply-DYTWptyW.cjs} +6 -6
- package/dist/plugin-sdk/{reply-D_sNAum5.js → reply-nXQ3Ihgd.js} +6 -6
- package/dist/plugin-sdk/{slash-dispatch.runtime-D6j_HvFC.cjs → slash-dispatch.runtime-BSDBCdoz.cjs} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-C0RwCFKq.js → slash-dispatch.runtime-Boj2xPW5.js} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-B60yTzIf.js → slash-dispatch.runtime-C57opycX.js} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-BERy39cs.js → slash-dispatch.runtime-C9rDQo8o.js} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-UYaTQwVq.js → slash-dispatch.runtime-CApLdZER.js} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-ASdOu8Cm.js → slash-dispatch.runtime-CG-zjxON.js} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-BuF14A03.js → slash-dispatch.runtime-CTecvuIx.js} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-_BOQ7gkd.cjs → slash-dispatch.runtime-Coe_tdLy.cjs} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-Dg9uQHNW.cjs → slash-dispatch.runtime-CrfGJt-z.cjs} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-30IYd84w.cjs → slash-dispatch.runtime-EgX-cRVC.cjs} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-Dq7mPZxr.cjs → slash-dispatch.runtime-KA6_FxIE.cjs} +1 -1
- package/dist/plugin-sdk/{slash-dispatch.runtime-34q3H9BU.cjs → slash-dispatch.runtime-XTKieQBQ.cjs} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-D0_kdCJ8.js → subagent-registry-runtime-B1Lpdh_L.js} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-BpO-8o-v.cjs → subagent-registry-runtime-BTcxp_jJ.cjs} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-DUaC-nXH.js → subagent-registry-runtime-C1W2bBCX.js} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-B4ht4jgI.js → subagent-registry-runtime-CjDQncGB.js} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-C4MYbumf.cjs → subagent-registry-runtime-CsoVFakn.cjs} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-w7CcoTLv.cjs → subagent-registry-runtime-DRUPit2H.cjs} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-_MlLeMWw.js → subagent-registry-runtime-DTlB8Q96.js} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-DfWSD7tl.js → subagent-registry-runtime-DiwikRRl.js} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-CyYJQuSQ.cjs → subagent-registry-runtime-Dj2i9GGj.cjs} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-D_dgSTbs.cjs → subagent-registry-runtime-Djshp0MC.cjs} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-UoI3lad4.js → subagent-registry-runtime-DrbVJw2f.js} +1 -1
- package/dist/plugin-sdk/{subagent-registry-runtime-CKNJbYW5.cjs → subagent-registry-runtime-IVYj5ywH.cjs} +1 -1
- package/dist/plugin-sdk/{web-BtgZE8cK.js → web-2PAf1exP.js} +1 -1
- package/dist/plugin-sdk/{web-B5xIoXe1.js → web-B6Ox6Cdv.js} +1 -1
- package/dist/plugin-sdk/{web-BEIPWO4K.cjs → web-B7WqqsC8.cjs} +1 -1
- package/dist/plugin-sdk/{web-GIWXJ0Ba.js → web-BkCy5IQ7.js} +1 -1
- package/dist/plugin-sdk/{web-BK1ARWvO.cjs → web-CJcd3JMn.cjs} +1 -1
- package/dist/plugin-sdk/{web-D2JuDaoV.js → web-CjilhIQD.js} +1 -1
- package/dist/plugin-sdk/{web-C2CF_qbv.cjs → web-CjsJxq4D.cjs} +1 -1
- package/dist/plugin-sdk/{web-BZPAL5HS.cjs → web-DCAcFf5b.cjs} +1 -1
- package/dist/plugin-sdk/{web-BiZX-XYi.cjs → web-DtH3t5Jt.cjs} +1 -1
- package/dist/plugin-sdk/{web-BhnzZsyl.js → web-g-WONVYn.js} +1 -1
- package/dist/plugin-sdk/{web-C3K1qs0u.cjs → web-iRzx1ssK.cjs} +1 -1
- package/dist/plugin-sdk/{web-CYwIRzDt.js → web-ikfo8GXI.js} +1 -1
- package/dist/plugin-sdk/whatsapp.cjs +1 -1
- package/dist/plugin-sdk/whatsapp.js +1 -1
- package/dist/{plugins-cli-fvYI7MuY.js → plugins-cli-5B5urjU7.js} +1 -1
- package/dist/{plugins-cli-D7y5Vl8l.js → plugins-cli-DaxkOvPH.js} +1 -1
- package/dist/{program-o1R0ZIeK.js → program-DJxQx1DE.js} +2 -2
- package/dist/{program-context-DMLIbH2F.js → program-context-DewOK4jD.js} +1 -1
- package/dist/{prompt-select-styled-BghrrnfB.js → prompt-select-styled-U5YlFMbC.js} +1 -1
- package/dist/{prompt-select-styled-MKdHaN69.js → prompt-select-styled-VagKVjlJ.js} +1 -1
- package/dist/{provider-auth-helpers-B24NjgT2.js → provider-auth-helpers-BEBH5krH.js} +1 -1
- package/dist/{provider-auth-helpers-1c048H9l.js → provider-auth-helpers-DKQwlJ25.js} +1 -1
- package/dist/{push-apns-BU-NR-pG.js → push-apns-CIV5yU-C.js} +1 -1
- package/dist/{push-apns-CrGncT7C.js → push-apns-DOhrdJ5p.js} +1 -1
- package/dist/{register.agent-iVmRDz9B.js → register.agent-Q_qYfTfI.js} +1 -1
- package/dist/{register.agent-CQHFkB8p.js → register.agent-Zd0TARQm.js} +1 -1
- package/dist/{register.configure-CThul7Zy.js → register.configure-A6heJkJh.js} +1 -1
- package/dist/{register.configure-q-iauQUk.js → register.configure-CWTGVxwN.js} +1 -1
- package/dist/{register.maintenance-C47agRIL.js → register.maintenance-BiqiVyJY.js} +1 -1
- package/dist/{register.maintenance-BRTx_TN-.js → register.maintenance-cKlEqSE7.js} +1 -1
- package/dist/{register.message-DsJRw5nY.js → register.message-BRfalotn.js} +1 -1
- package/dist/{register.message-Dxxzi9kt.js → register.message-CXPAYgVk.js} +1 -1
- package/dist/{register.onboard-DcNYm0dn.js → register.onboard-CiK3r6Ar.js} +1 -1
- package/dist/{register.onboard-BteLZ-mA.js → register.onboard-g_3bWGn7.js} +1 -1
- package/dist/{register.setup-C4lAwlQe.js → register.setup-BgOqtS83.js} +1 -1
- package/dist/{register.setup-CeW9lN5-.js → register.setup-BoiX_qRl.js} +1 -1
- package/dist/{register.status-health-sessions-C-JabFZz.js → register.status-health-sessions-BIo6bs1r.js} +1 -1
- package/dist/{register.status-health-sessions-CZOciUK3.js → register.status-health-sessions-BrcaSoAg.js} +1 -1
- package/dist/{register.subclis-DHFqEK6G.js → register.subclis-BmtNNMP2.js} +1 -1
- package/dist/{reply-DHtpIWpD.js → reply-HrabJs88.js} +6 -6
- package/dist/{run-main-BKA6bL5R.js → run-main-CwKNqqKj.js} +1 -1
- package/dist/{server-node-events-DECiuryL.js → server-node-events-D1Pr11u8.js} +1 -1
- package/dist/{server-node-events-DQohZYL_.js → server-node-events-DYeHOQG_.js} +1 -1
- package/dist/{slash-dispatch.runtime-BltGVp6a.js → slash-dispatch.runtime-5xQBRYan.js} +1 -1
- package/dist/{slash-dispatch.runtime-U7BSD9SC.js → slash-dispatch.runtime-BRImHx9I.js} +1 -1
- package/dist/{slash-dispatch.runtime-BRh6zgqn.js → slash-dispatch.runtime-Cq5dUL-m.js} +1 -1
- package/dist/{slash-dispatch.runtime-BQCIIXIb.js → slash-dispatch.runtime-D_A_iMTY.js} +1 -1
- package/dist/{status-CUDtNIry.js → status-DiHX2LOf.js} +1 -1
- package/dist/{status-OB55GG25.js → status-m4GFy-Px.js} +1 -1
- package/dist/{subagent-registry-runtime-B9Ism-1f.js → subagent-registry-runtime-BhMKhChi.js} +1 -1
- package/dist/{subagent-registry-runtime-D2hsQSwB.js → subagent-registry-runtime-C36kHoT7.js} +1 -1
- package/dist/{subagent-registry-runtime-CO4i2ZPd.js → subagent-registry-runtime-CrUvIBql.js} +1 -1
- package/dist/{subagent-registry-runtime-85RFObHD.js → subagent-registry-runtime-GuXOBC1H.js} +1 -1
- package/dist/{update-cli-CkgaoB8p.js → update-cli-CQGioR5x.js} +1 -1
- package/dist/{update-cli-BlZnad_S.js → update-cli-ILZhc8_8.js} +1 -1
- package/dist/{update-runner-DcWJQ3bh.js → update-runner-1UCWso86.js} +1 -1
- package/dist/{update-runner-DWHUl78B.js → update-runner-JT7_BON6.js} +1 -1
- package/dist/{web-HSA7Rhwn.js → web-C1e-LYaH.js} +1 -1
- package/dist/{web-MgNpzMvd.js → web-DWIIpcnE.js} +1 -1
- package/dist/{web-B6OLwGJa.js → web-DaJ1Z41U.js} +1 -1
- package/dist/{web-Bam5_EjB.js → web-rxfH6rmG.js} +1 -1
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
require(`./paths-Bcdg3ma0.cjs`);const e=require(`./paths-DTJRnmjZ.cjs`),t=require(`./utils-DyYoKTxM.cjs`),n=require(`./model-auth-DpNEjQJG.cjs`);require(`./target-errors-KF_DP1G0.cjs`);const r=require(`./dispatch-
|
|
1
|
+
require(`./paths-Bcdg3ma0.cjs`);const e=require(`./paths-DTJRnmjZ.cjs`),t=require(`./utils-DyYoKTxM.cjs`),n=require(`./model-auth-DpNEjQJG.cjs`);require(`./target-errors-KF_DP1G0.cjs`);const r=require(`./dispatch-DCFiq6TV.cjs`),i=require(`./send-B9v2tLcr.cjs`),a=require(`./send-BrpxP2n2.cjs`);require(`./proxy-env-Ff7zApb1.cjs`),require(`./github-copilot-token-C1O2cBqk.cjs`),require(`./send-BhnZ5pVy.cjs`),require(`./fetch-guard-BMjJW-f1.cjs`),require(`./deliver-Boy232RS.cjs`),require(`./diagnostic-w6JGu-T0.cjs`),require(`./pi-model-discovery-DKOkctWV.cjs`);const o=require(`./audio-transcription-runner-DUmzTcHM.cjs`);require(`./image-BMRCovCx.cjs`),require(`./api-key-rotation-BTa_evQP.cjs`);const s=require(`./local-roots-CB7mmD8J.cjs`);require(`./proxy-fetch-D3BHqZsY.cjs`),require(`./tokens-C08en26F.cjs`),require(`./commands-registry-Dx6LlKnd.cjs`),require(`./fetch-CZewCAvu.cjs`);const c=require(`./ir-DxgqM23f.cjs`);require(`./render-g5VlmgpF.cjs`);const l=require(`./channel-activity-fRo56EUR.cjs`),u=require(`./tables-DDX1DDVV.cjs`);require(`./send-CbNEUebW.cjs`),require(`./fetch-rm0mkPhU.cjs`),require(`./skill-commands-BXyFaY8i.cjs`),require(`./outbound-attachment-Df2WI85T.cjs`),require(`./send-CNkcME3h.cjs`);const d=require(`./active-listener-Cz63oESl.cjs`);require(`./query-expansion-DI8CBPKZ.cjs`),require(`./manager-LqG378__.cjs`);const f=require(`./outbound-DRUM1erm.cjs`),p=require(`./session-BdDZq8J2.cjs`),m=require(`./login-DJIZHdJn.cjs`);let h=require(`node:crypto`),g=require(`@whiskeysockets/baileys`);const _={initialMs:2e3,maxMs:3e4,factor:1.8,jitter:.25,maxAttempts:12};function v(e,t){let n=t??e.web?.heartbeatSeconds;return typeof n==`number`&&n>0?n:60}function y(e,n){let r=e.web?.reconnect??{},i=n??{},a={..._,...r,...i};return a.initialMs=Math.max(250,a.initialMs),a.maxMs=Math.max(a.initialMs,a.maxMs),a.factor=t.n(a.factor,1.1,10),a.jitter=t.n(a.jitter,0,1),a.maxAttempts=Math.max(0,Math.floor(a.maxAttempts)),a}function b(){return(0,h.randomUUID)()}const x=t.O(`gateway/channels/whatsapp`),S=x.child(`inbound`),C=x.child(`outbound`),ee=x.child(`heartbeat`);function w(){return setInterval(()=>{},1e6).unref(),new Promise(()=>{})}const T=r.B({ttlMs:20*6e4,maxSize:5e3});function E(e){return T.check(e)}const D=new Set([`FN`,`N`,`TEL`]);function O(e){if(!e)return{phones:[]};let t=e.split(/\r?\n/),n,r,i=[];for(let e of t){let t=e.trim();if(!t)continue;let a=t.indexOf(`:`);if(a===-1)continue;let o=t.slice(0,a).toUpperCase(),s=t.slice(a+1).trim();if(!s)continue;let c=k(o);if(!c||!D.has(c))continue;let l=A(s);if(l){if(c===`FN`&&!r){r=j(l);continue}if(c===`N`&&!n){n=j(l);continue}if(c===`TEL`){let e=M(l);e&&i.push(e)}}}return{name:r??n,phones:i}}function k(e){let[t]=e.split(`;`);if(!t)return;let n=t.split(`.`);return n[n.length-1]||void 0}function A(e){return e.replace(/\\n/gi,` `).replace(/\\,/g,`,`).replace(/\\;/g,`;`).trim()}function j(e){return e.replace(/;/g,` `).replace(/\s+/g,` `).trim()}function M(e){let t=e.trim();return t?t.toLowerCase().startsWith(`tel:`)?t.slice(4).trim():t:``}function N(e){return(0,g.normalizeMessageContent)(e)}function P(e){if(!e)return;let t=(0,g.getContentType)(e),n=t?e[t]:void 0,r=n&&typeof n==`object`&&`contextInfo`in n?n.contextInfo:void 0;if(r)return r;let i=e.extendedTextMessage?.contextInfo??e.imageMessage?.contextInfo??e.videoMessage?.contextInfo??e.documentMessage?.contextInfo??e.audioMessage?.contextInfo??e.stickerMessage?.contextInfo??e.buttonsResponseMessage?.contextInfo??e.listResponseMessage?.contextInfo??e.templateButtonReplyMessage?.contextInfo??e.interactiveResponseMessage?.contextInfo??e.buttonsMessage?.contextInfo??e.listMessage?.contextInfo;if(i)return i;for(let t of Object.values(e)){if(!t||typeof t!=`object`||!(`contextInfo`in t))continue;let e=t.contextInfo;if(e)return e}}function F(e){let t=N(e);if(!t)return;let n=[t.extendedTextMessage?.contextInfo?.mentionedJid,t.extendedTextMessage?.contextInfo?.quotedMessage?.extendedTextMessage?.contextInfo?.mentionedJid,t.imageMessage?.contextInfo?.mentionedJid,t.videoMessage?.contextInfo?.mentionedJid,t.documentMessage?.contextInfo?.mentionedJid,t.audioMessage?.contextInfo?.mentionedJid,t.stickerMessage?.contextInfo?.mentionedJid,t.buttonsResponseMessage?.contextInfo?.mentionedJid,t.listResponseMessage?.contextInfo?.mentionedJid].flatMap(e=>e??[]).filter(Boolean);if(n.length!==0)return Array.from(new Set(n))}function I(e){let t=N(e);if(!t)return;let n=(0,g.extractMessageContent)(t),r=[t,n&&n!==t?n:void 0];for(let e of r){if(!e)continue;if(typeof e.conversation==`string`&&e.conversation.trim())return e.conversation.trim();let t=e.extendedTextMessage?.text;if(t?.trim())return t.trim();let n=e.imageMessage?.caption??e.videoMessage?.caption??e.documentMessage?.caption;if(n?.trim())return n.trim()}let i=R(t)??(n&&n!==t?R(n):void 0);if(i)return i}function L(e){let t=N(e);if(t){if(t.imageMessage)return`<media:image>`;if(t.videoMessage)return`<media:video>`;if(t.audioMessage)return`<media:audio>`;if(t.documentMessage)return`<media:document>`;if(t.stickerMessage)return`<media:sticker>`}}function R(e){let t=N(e);if(!t)return;let n=t.contactMessage??void 0;if(n){let{name:e,phones:t}=z({displayName:n.displayName,vcard:n.vcard});return B(e,t)}let r=t.contactsArrayMessage?.contacts??void 0;if(!(!r||r.length===0))return V(r.map(e=>z({displayName:e.displayName,vcard:e.vcard})).map(e=>H(e.name,e.phones)).filter(e=>!!e),r.length)}function z(e){let t=(e.displayName??``).trim(),n=O(e.vcard??void 0);return{name:t||n.name,phones:n.phones}}function B(e,t){let n=H(e,t);return n?`<contact: ${n}>`:`<contact>`}function V(e,t){let n=e.map(e=>e.trim()).filter(Boolean);if(n.length===0)return`<contacts: ${t} ${t===1?`contact`:`contacts`}>`;let r=Math.max(t-n.length,0),i=r>0?` +${r} more`:``;return`<contacts: ${n.join(`, `)}${i}>`}function H(e,t){let n=[e,U(t)].filter(e=>!!e);if(n.length!==0)return n.join(`, `)}function U(e){let t=e?.map(e=>e.trim()).filter(Boolean)??[];if(t.length===0)return;let{shown:n,remaining:r}=te(t,t.length,1),[i]=n;if(i)return r===0?i:`${i} (+${r} more)`}function te(e,t,n){let r=e.slice(0,n);return{shown:r,remaining:Math.max(t-r.length,0)}}function ne(e){let t=N(e);if(!t)return null;let n=t.liveLocationMessage??void 0;if(n){let e=n.degreesLatitude,t=n.degreesLongitude;if(e!=null&&t!=null){let r=Number(e),i=Number(t);if(Number.isFinite(r)&&Number.isFinite(i))return{latitude:r,longitude:i,accuracy:n.accuracyInMeters??void 0,caption:n.caption??void 0,source:`live`,isLive:!0}}}let r=t.locationMessage??void 0;if(r){let e=r.degreesLatitude,t=r.degreesLongitude;if(e!=null&&t!=null){let n=Number(e),i=Number(t);if(Number.isFinite(n)&&Number.isFinite(i)){let e=!!r.isLive;return{latitude:n,longitude:i,accuracy:r.accuracyInMeters??void 0,name:r.name??void 0,address:r.address??void 0,caption:r.comment??void 0,source:e?`live`:r.name||r.address?`place`:`pin`,isLive:e}}}}return null}function W(e){let n=N(e);if(!n)return null;let r=P(n),a=(0,g.normalizeMessageContent)(r?.quotedMessage);if(!a)return null;let o=ne(a),s=o?i.ct(o):void 0,c=[I(a),s].filter(Boolean).join(`
|
|
2
2
|
`).trim();if(c||=L(a),!c){let e=a?(0,g.getContentType)(a):void 0;return t.R(`Quoted message missing extractable body${e?` (type ${e})`:``}`),null}let l=r?.participant??void 0,u=l?t.u(l)??l:void 0,d=u??`unknown sender`;return{id:r?.stanzaId?String(r.stanzaId):void 0,body:c,sender:d,senderJid:l,senderE164:u}}function re(e){return a.Nt({providerConfigPresent:e.providerConfigPresent,groupPolicy:e.groupPolicy,defaultGroupPolicy:e.defaultGroupPolicy})}async function ie(e){let o=n.Gi(),s=n.zs({cfg:o,accountId:e.accountId}),c=s.dmPolicy??`pairing`,l=s.allowFrom??[],u=await r.U({provider:`whatsapp`,accountId:s.accountId,dmPolicy:c}),d=l.length===0&&e.selfE164?[e.selfE164]:[],f=l.length>0?l:d,p=s.groupAllowFrom??(l.length>0?l:void 0),m=e.from===e.selfE164,h=s.selfChatMode??t.l(e.selfE164,l),g=typeof e.pairingGraceMs==`number`&&e.pairingGraceMs>0?e.pairingGraceMs:3e4,_=typeof e.connectedAtMs==`number`&&typeof e.messageTimestampMs==`number`&&e.messageTimestampMs<e.connectedAtMs-g,v=a.Mt(o),{groupPolicy:y,providerMissingFallbackApplied:b}=re({providerConfigPresent:o.channels?.whatsapp!==void 0,groupPolicy:s.groupPolicy,defaultGroupPolicy:v});a.Pt({providerMissingFallbackApplied:b,providerKey:`whatsapp`,accountId:s.accountId,log:e=>t.R(e)});let x=t.d(e.from),S=typeof e.senderE164==`string`?t.d(e.senderE164):null,C=r.G({isGroup:e.group,dmPolicy:c,groupPolicy:y,allowFrom:e.group?l:f,groupAllowFrom:p,storeAllowFrom:u,isSenderAllowed:n=>{if(n.includes(`*`))return!0;let r=new Set(n.map(e=>t.d(String(e))).filter(e=>!!e));return!e.group&&m?!0:e.group?!!(S&&r.has(S)):r.has(x)}});if(e.group&&C.decision!==`allow`)return C.reason===`groupPolicy=disabled`?t.R(`Blocked group message (groupPolicy: disabled)`):C.reason===`groupPolicy=allowlist (empty allowlist)`?t.R(`Blocked group message (groupPolicy: allowlist, no groupAllowFrom)`):t.R(`Blocked group message from ${e.senderE164??`unknown sender`} (groupPolicy: allowlist)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(!e.group){if(e.isFromMe&&!m)return t.R(`Skipping outbound DM (fromMe); no pairing reply needed.`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(C.decision===`block`&&C.reason===`dmPolicy=disabled`)return t.R(`Blocked dm (dmPolicy: disabled)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(C.decision===`pairing`&&!m){let n=e.from;return _?t.R(`Skipping pairing reply for historical DM from ${n}.`):await r.q({channel:`whatsapp`,senderId:n,senderIdLine:`Your WhatsApp phone number: ${n}`,meta:{name:(e.pushName??``).trim()||void 0},upsertPairingRequest:async({id:e,meta:t})=>await i.$({channel:`whatsapp`,id:e,accountId:s.accountId,meta:t}),onCreated:()=>{t.R(`whatsapp pairing request sender=${n} name=${e.pushName??`unknown`}`)},sendPairingReply:async t=>{await e.sock.sendMessage(e.remoteJid,{text:t})},onReplyError:e=>{t.R(`whatsapp pairing reply failed for ${n}: ${String(e)}`)}}),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId}}if(C.decision!==`allow`)return t.R(`Blocked unauthorized sender ${e.from} (dmPolicy=${c})`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId}}return{allowed:!0,shouldMarkRead:!0,isSelfChat:h,resolvedAccountId:s.accountId}}function G(e){return(0,g.normalizeMessageContent)(e)}function K(e){let t=e.imageMessage?.mimetype??e.videoMessage?.mimetype??e.documentMessage?.mimetype??e.audioMessage?.mimetype??e.stickerMessage?.mimetype??void 0;if(t)return t;if(e.audioMessage)return`audio/ogg; codecs=opus`;if(e.imageMessage)return`image/jpeg`;if(e.videoMessage)return`video/mp4`;if(e.stickerMessage)return`image/webp`}async function ae(e,n){let r=G(e.message);if(!r)return;let i=K(r),a=r.documentMessage?.fileName??void 0;if(!(!r.imageMessage&&!r.videoMessage&&!r.documentMessage&&!r.audioMessage&&!r.stickerMessage))try{return{buffer:await(0,g.downloadMediaMessage)(e,`buffer`,{},{reuploadRequest:n.updateMediaMessage,logger:n.logger}),mimetype:i,fileName:a}}catch(e){t.R(`downloadMediaMessage failed: ${String(e)}`);return}}function q(e){l.n({channel:`whatsapp`,accountId:e,direction:`outbound`})}function J(e){return typeof e==`object`&&e&&`key`in e?String(e.key?.id??`unknown`):`unknown`}function Y(e){return{sendMessage:async(n,r,i,a,o)=>{let s=t.x(n),c;if(i&&a)if(a.startsWith(`image/`))c={image:i,caption:r||void 0,mimetype:a};else if(a.startsWith(`audio/`))c={audio:i,ptt:!0,mimetype:a};else if(a.startsWith(`video/`)){let e=o?.gifPlayback;c={video:i,caption:r||void 0,mimetype:a,...e?{gifPlayback:!0}:{}}}else c={document:i,fileName:o?.fileName?.trim()||`file`,caption:r||void 0,mimetype:a};else c={text:r};let l=await e.sock.sendMessage(s,c);return q(o?.accountId??e.defaultAccountId),{messageId:J(l)}},sendPoll:async(n,r)=>{let i=t.x(n),a=await e.sock.sendMessage(i,{poll:{name:r.question,values:r.options,selectableCount:r.maxSelections??1}});return q(e.defaultAccountId),{messageId:J(a)}},sendReaction:async(n,r,i,a,o)=>{let s=t.x(n);await e.sock.sendMessage(s,{react:{text:i,key:{remoteJid:s,id:r,fromMe:a,participant:o?t.x(o):void 0}}})},sendComposingTo:async n=>{let r=t.x(n);await e.sock.sendPresenceUpdate(`composing`,r)}}}async function oe(e){let a=t.K({module:`web-inbound`}),o=t.O(`gateway/channels/whatsapp`).child(`inbound`),s=await p.t(!1,e.verbose,{authDir:e.authDir});await p.i(s);let c=Date.now(),u=null,d=new Promise(e=>{u=e}),f=e=>{if(!u)return;let t=u;u=null,t(e)};try{await s.sendPresenceUpdate(`available`),t.B()&&t.R(`Sent global 'available' presence on connect`)}catch(e){t.R(`Failed to send 'available' presence on connect: ${String(e)}`)}let m=s.user?.id,h=m?t.u(m):null,_=r.T({debounceMs:e.debounceMs??0,buildKey:e=>{let t=e.chatType===`group`?e.senderJid??e.senderE164??e.senderName??e.from:e.from;if(!t)return null;let n=e.chatType===`group`?e.chatId:e.from;return`${e.accountId}:${n}:${t}`},shouldDebounce:e.shouldDebounce,onFlush:async t=>{let n=t.at(-1);if(!n)return;if(t.length===1){await e.onMessage(n);return}let r=new Set;for(let e of t)for(let t of e.mentionedJids??[])r.add(t);let i=t.map(e=>e.body).filter(Boolean).join(`
|
|
3
3
|
`),a={...n,body:i,mentionedJids:r.size>0?Array.from(r):void 0};await e.onMessage(a)},onError:e=>{a.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)}}),v=new Map,y=300*1e3,b=s.signalRepository?.lidMapping,x=async n=>t.m(n,{authDir:e.authDir,lidLookup:b}),S=async e=>{let n=v.get(e);if(n&&n.expires>Date.now())return n;try{let t=await s.groupMetadata(e),n=(await Promise.all(t.participants?.map(async e=>await x(e.id)??e.id)??[])).filter(Boolean)??[],r={subject:t.subject,participants:n,expires:Date.now()+y};return v.set(e,r),r}catch(n){return t.R(`Failed to fetch group metadata for ${e}: ${String(n)}`),{expires:Date.now()+y}}},C=async t=>{let n=t.key?.id??void 0,r=t.key?.remoteJid;if(!r||r.endsWith(`@status`)||r.endsWith(`@broadcast`))return null;let i=(0,g.isJidGroup)(r)===!0;if(n&&E(`${e.accountId}:${r}:${n}`))return null;let a=t.key?.participant??void 0,o=i?r:await x(r);if(!o)return null;let l=i?a?await x(a):null:o,u,d;if(i){let e=await S(r);u=e.subject,d=e.participants}let f=t.messageTimestamp?Number(t.messageTimestamp)*1e3:void 0,p=await ie({accountId:e.accountId,from:o,selfE164:h,senderE164:l,group:i,pushName:t.pushName??void 0,isFromMe:!!t.key?.fromMe,messageTimestampMs:f,connectedAtMs:c,sock:{sendMessage:(e,t)=>s.sendMessage(e,t)},remoteJid:r});return p.allowed?{id:n,remoteJid:r,group:i,participantJid:a,from:o,senderE164:l,groupSubject:u,groupParticipants:d,messageTimestampMs:f,access:p}:null},ee=async n=>{let{id:r,remoteJid:i,participantJid:a,access:o}=n;if(r&&!o.isSelfChat&&e.sendReadReceipts!==!1)try{await s.readMessages([{remoteJid:i,id:r,participant:a,fromMe:!1}]),t.B()&&t.R(`Marked message ${r} as read for ${i}${a?` (participant ${a})`:``}`)}catch(e){t.R(`Failed to mark message ${r} read: ${String(e)}`)}else r&&o.isSelfChat&&t.B()&&t.R(`Self-chat mode: skipping read receipt for ${r}`)},w=async r=>{let a=ne(r.message??void 0),o=a?i.ct(a):void 0,c=I(r.message??void 0);if(o&&(c=[c,o].filter(Boolean).join(`
|
|
4
4
|
`).trim()),!c&&(c=L(r.message??void 0),!c))return null;let l=W(r.message),u,d,f;try{let t=await ae(r,s);if(t){let r=(typeof e.mediaMaxMb==`number`&&e.mediaMaxMb>0?e.mediaMaxMb:50)*1024*1024;u=(await n.kr(t.buffer,t.mimetype,`inbound`,r,t.fileName)).path,d=t.mimetype,f=t.fileName}}catch(e){t.R(`Inbound media download failed: ${String(e)}`)}return{body:c,location:a??void 0,replyContext:l,mediaPath:u,mediaType:d,mediaFileName:f}},T=async(e,n,r)=>{let i=n.remoteJid,c=async()=>{try{await s.sendPresenceUpdate(`composing`,i)}catch(e){t.R(`Presence update failed: ${String(e)}`)}},l=async e=>{await s.sendMessage(i,{text:e})},u=async e=>{await s.sendMessage(i,e)},d=n.messageTimestampMs,f=F(e.message),p=e.pushName??void 0;a.info({from:n.from,to:h??`me`,body:r.body,mediaPath:r.mediaPath,mediaType:r.mediaType,mediaFileName:r.mediaFileName,timestamp:d},`inbound message`);let g={id:n.id,from:n.from,conversationId:n.from,to:h??`me`,accountId:n.access.resolvedAccountId,body:r.body,pushName:p,timestamp:d,chatType:n.group?`group`:`direct`,chatId:n.remoteJid,senderJid:n.participantJid,senderE164:n.senderE164??void 0,senderName:p,replyToId:r.replyContext?.id,replyToBody:r.replyContext?.body,replyToSender:r.replyContext?.sender,replyToSenderJid:r.replyContext?.senderJid,replyToSenderE164:r.replyContext?.senderE164,groupSubject:n.groupSubject,groupParticipants:n.groupParticipants,mentionedJids:f??void 0,selfJid:m,selfE164:h,fromMe:!!e.key?.fromMe,location:r.location??void 0,sendComposing:c,reply:l,sendMedia:u,mediaPath:r.mediaPath,mediaType:r.mediaType,mediaFileName:r.mediaFileName};try{Promise.resolve(_.enqueue(g)).catch(e=>{a.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)})}catch(e){a.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)}},D=async t=>{if(!(t.type!==`notify`&&t.type!==`append`))for(let n of t.messages??[]){l.n({channel:`whatsapp`,accountId:e.accountId,direction:`inbound`});let r=await C(n);if(!r||(await ee(r),t.type===`append`))continue;let i=await w(n);i&&await T(n,r,i)}};s.ev.on(`messages.upsert`,D);let O=e=>{try{if(e.connection===`close`){let t=p.r(e.lastDisconnect?.error);f({status:t,isLoggedOut:t===g.DisconnectReason.loggedOut,error:e.lastDisconnect?.error})}}catch(e){a.error({error:String(e)},`connection.update handler error`),f({status:void 0,isLoggedOut:!1,error:e})}};return s.ev.on(`connection.update`,O),{close:async()=>{try{let e=s.ev,t=D,n=O;typeof e.off==`function`?(e.off(`messages.upsert`,t),e.off(`connection.update`,n)):typeof e.removeListener==`function`&&(e.removeListener(`messages.upsert`,t),e.removeListener(`connection.update`,n)),s.ws?.close()}catch(e){t.R(`Socket close failed: ${String(e)}`)}},onClose:d,signalClose:e=>{f(e??{status:void 0,isLoggedOut:!1,error:`closed`})},...Y({sock:{sendMessage:(e,t)=>s.sendMessage(e,t),sendPresenceUpdate:(e,t)=>s.sendPresenceUpdate(e,t)},defaultAccountId:e.accountId})}}function X(e,t){return{mentionRegexes:r.A(e,t),allowFrom:e.channels?.whatsapp?.allowFrom}}function Z(e,n){let r=n?{authDir:n}:void 0;return{normalizedMentions:e.mentionedJids?.length?e.mentionedJids.map(e=>t.u(e,r)??e).filter(Boolean):[],selfE164:e.selfE164??(e.selfJid?t.u(e.selfJid,r):null),selfJid:e.selfJid?e.selfJid.replace(/:\\d+/,``):null}}function Q(e,n,i){let a=e=>r.j(e),o=t.l(i.selfE164,n.allowFrom);if((e.mentionedJids?.length??0)>0&&!o)return!!(i.selfE164&&i.normalizedMentions.includes(i.selfE164)||i.selfJid&&i.normalizedMentions.includes(i.selfJid));let s=a(e.body);if(n.mentionRegexes.some(e=>e.test(s)))return!0;if(i.selfE164){let t=i.selfE164.replace(/\D/g,``);if(t){if(s.replace(/[^\d]/g,``).includes(t))return!0;let n=e.body.replace(/[\s-]/g,``);if(RegExp(`\\+?${t}`,`i`).test(n))return!0}}return!1}function se(e,t,n){let i=Z(e,n);return{wasMentioned:Q(e,t,i),details:{from:e.from,body:e.body,bodyClean:r.j(e.body),mentionedJids:e.mentionedJids??null,normalizedMentionedJids:i.normalizedMentions.length?i.normalizedMentions:null,selfJid:e.selfJid??null,selfJidBare:i.selfJid,selfE164:e.selfE164??null,resolvedSelfE164:i.selfE164}}}function ce(e,n){let r=e.allowFrom;return(Array.isArray(r)&&r.length>0?r:n?[n]:[]).filter(e=>!!(e&&e!==`*`)).map(e=>t.d(e)).filter(e=>!!e)}function le(e){let t=new Set,n=Math.max(1,e.maxItems??100),r=e=>`combined:${e.sessionKey}:${e.combinedBody}`,i=()=>{for(;t.size>n;){let e=t.values().next().value;if(!e)break;t.delete(e)}};return{rememberText:(n,a)=>{n&&(t.add(n),a.combinedBody&&a.combinedBodySessionKey&&t.add(r({sessionKey:a.combinedBodySessionKey,combinedBody:a.combinedBody})),a.logVerboseMessage&&e.logVerbose?.(`Added to echo detection set (size now: ${t.size}): ${n.substring(0,50)}...`),i())},has:e=>t.has(e),forget:e=>{t.delete(e)},buildCombinedKey:r}}function ue(t){let n=r.g({agentId:t.agentId,channel:`whatsapp`,accountId:t.route.accountId,peer:{kind:t.msg.chatType===`group`?`group`:`direct`,id:t.peerId},dmScope:t.cfg.session?.dmScope,identityLinks:t.cfg.session?.identityLinks}),i=e.gt({agentId:t.agentId,mainKey:e.ht});return{sessionKey:n,mainSessionKey:i,lastRoutePolicy:r._({sessionKey:n,mainSessionKey:i})}}async function de(t){let n=t.cfg.broadcast?.[t.peerId];if(!n||!Array.isArray(n)||n.length===0)return!1;let r=t.cfg.broadcast?.strategy||`parallel`;S.info(`Broadcasting message to ${n.length} agents (${r})`);let i=t.cfg.agents?.list?.map(t=>e.xt(t.id)),a=(i?.length??0)>0,o=t.msg.chatType===`group`?t.groupHistories.get(t.groupHistoryKey)??[]:void 0,s=async n=>{let r=e.xt(n);if(a&&!i?.includes(r))return S.warn(`Broadcast agent ${n} not found in agents.list; skipping`),!1;let s=ue({cfg:t.cfg,msg:t.msg,route:t.route,peerId:t.peerId,agentId:r}),c={...t.route,agentId:r,...s};try{return await t.processMessage(t.msg,c,t.groupHistoryKey,{groupHistory:o,suppressGroupHistoryClear:!0})}catch(e){return S.error(`Broadcast agent ${n} failed: ${p.n(e)}`),!1}};if(r===`sequential`)for(let e of n)await s(e);else await Promise.allSettled(n.map(s));return t.msg.chatType===`group`&&t.groupHistories.set(t.groupHistoryKey,[]),!0}function fe(e,t,n){let r=e;for(let e of t)r=r.replace(e,` `);if(n){let e=n.replace(/\D/g,``);if(e){let t=RegExp(`\\+?${e}`,`g`);r=r.replace(t,` `)}}return r.replace(/\s+/g,` `).trim()}function pe(e,t){let r=n.Yn({From:t,ChatType:`group`,Provider:`whatsapp`})?.id,i=e.channels?.whatsapp,a=!!(i?.groupAllowFrom?.length||i?.allowFrom?.length);return n.Wn({cfg:e,channel:`whatsapp`,groupId:r??t,hasGroupAllowFrom:a})}function me(e,t){let r=n.Yn({From:t,ChatType:`group`,Provider:`whatsapp`})?.id;return n.Gn({cfg:e,channel:`whatsapp`,groupId:r??t})}function he(t){let i=n.wt(e.s(t.cfg.session?.store,{agentId:t.agentId}))[t.sessionKey],a=me(t.cfg,t.conversationId)?`mention`:`always`;return r.o(i?.groupActivation)??a}function ge(e,n,r){for(let i of e){let e=t.d(i)??i;!e||n.has(e)||(n.add(e),r.push(e))}}function _e(e,n,r,i){if(!r||!i)return;let a=t.d(r)??r;if(!a)return;let o=e.get(n);o||(o=new Map,e.set(n,o)),o.set(a,i)}function ve(e){let{participants:n,roster:r,fallbackE164:i}=e,a=new Set,o=[];if(n?.length&&ge(n,a,o),r&&ge(r.keys(),a,o),o.length===0&&i){let e=t.d(i)??i;e&&o.push(e)}if(o.length!==0)return o.map(e=>{let t=r?.get(e);return t?`${t} (${e})`:e}).join(`, `)}function ye(e,n){let r=t.d(n.senderE164??``);return r?ce(e,n.selfE164??void 0).includes(r):!1}function be(e){let t=e.msg.senderName&&e.msg.senderE164?`${e.msg.senderName} (${e.msg.senderE164})`:e.msg.senderName??e.msg.senderE164??`Unknown`;r.h({historyMap:e.groupHistories,historyKey:e.groupHistoryKey,limit:e.groupHistoryLimit,entry:{sender:t,body:e.msg.body,timestamp:e.msg.timestamp,id:e.msg.id,senderJid:e.msg.senderJid}})}function xe(e,t){return e.logVerbose(t),be({msg:e.msg,groupHistories:e.groupHistories,groupHistoryKey:e.groupHistoryKey,groupHistoryLimit:e.groupHistoryLimit}),{shouldProcess:!1}}function Se(e){let n=pe(e.cfg,e.conversationId);if(n.allowlistEnabled&&!n.allowed)return e.logVerbose(`Skipping group message ${e.conversationId} (not in allowlist)`),{shouldProcess:!1};_e(e.groupMemberNames,e.groupHistoryKey,e.msg.senderE164,e.msg.senderName);let i=X(e.cfg,e.agentId),a=fe(e.msg.body,i.mentionRegexes,e.msg.selfE164),o=r.s(a),s=ye(e.baseMentionConfig,e.msg),c=s&&r.O(a,e.cfg);if(o.hasCommand&&!s)return xe(e,`Ignoring /activation from non-owner in group ${e.conversationId}`);let l=se(e.msg,i,e.authDir);e.replyLogger.debug({conversationId:e.conversationId,wasMentioned:l.wasMentioned,...l.details},`group mention debug`);let u=l.wasMentioned,d=he({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:e.conversationId})!==`always`,f=e.msg.selfJid?.replace(/:\\d+/,``),p=e.msg.replyToSenderJid?.replace(/:\\d+/,``),m=e.msg.selfE164?t.d(e.msg.selfE164):null,h=e.msg.replyToSenderE164?t.d(e.msg.replyToSenderE164):null,g=r.p({requireMention:d,canDetectMention:!0,wasMentioned:u,implicitMention:!!(f&&p&&f===p||m&&h&&m===h),shouldBypassMention:c});return e.msg.wasMentioned=g.effectiveWasMentioned,!c&&d&&g.shouldSkip?xe(e,`Group message stored for context (no mention detected) in ${e.conversationId}: ${e.msg.body}`):{shouldProcess:!0}}function Ce(e,t){e.add(t),t.finally(()=>{e.delete(t)})}function we(t){let r=e.s(t.cfg.session?.store,{agentId:t.storeAgentId}),i=n.Ot({storePath:r,sessionKey:t.sessionKey,deliveryContext:{channel:t.channel,to:t.to,accountId:t.accountId},ctx:t.ctx}).catch(e=>{t.warn({error:p.n(e),storePath:r,sessionKey:t.sessionKey,to:t.to},`failed updating last route`)});Ce(t.backgroundTasks,i)}function Te(e){return e.chatType===`group`?e.conversationId??e.from:e.senderE164?t.d(e.senderE164)??e.senderE164:e.from.includes(`@`)?t.u(e.from)??e.from:t.d(e.from)??e.from}function $(e,t=400){return!e||e.length<=t?e:`${e.slice(0,t)}… (truncated ${e.length-t} chars)`}function Ee(e){let t=(e instanceof Error?`${e.message}\n${e.stack??``}`:(e=>{if(e==null)return``;if(typeof e==`string`)return e;if(e instanceof Error)return`${e.message}\n${e.stack??``}`;if(typeof e==`object`)try{return JSON.stringify(e)}catch{return Object.prototype.toString.call(e)}return typeof e==`number`||typeof e==`boolean`||typeof e==`bigint`?String(e):typeof e==`symbol`?e.description??e.toString():typeof e==`function`?e.name?`[function ${e.name}]`:`[function]`:Object.prototype.toString.call(e)})(e)).toLowerCase();return t.includes(`unsupported state or unable to authenticate data`)||t.includes(`bad mac`)?t.includes(`@whiskeysockets/baileys`)||t.includes(`baileys`)||t.includes(`noise-handler`)||t.includes(`aesdecryptgcm`):!1}function De(e){if(e.isReasoning===!0)return!0;let t=e.text;return typeof t==`string`?t.trimStart().toLowerCase().startsWith(`reasoning:`):!1}async function Oe(e){let{replyResult:n,msg:r,maxMediaBytes:i,textLimit:a,replyLogger:o,connectionId:s,skipLog:l}=e,d=Date.now();if(De(n)){C.debug(`Suppressed reasoning payload to ${r.from}`);return}let m=e.tableMode??`code`,h=e.chunkMode??`length`,g=c.d(f.i(u.t(n.text||``,m)),a,h),_=n.mediaUrls?.length?n.mediaUrls:n.mediaUrl?[n.mediaUrl]:[],v=async(e,n,i=3)=>{let a;for(let o=1;o<=i;o++)try{return await e()}catch(e){a=e;let s=p.n(e),c=o===i;if(!/closed|reset|timed\s*out|disconnect/i.test(s)||c)throw e;let l=500*o;t.R(`Retrying ${n} to ${r.from} after failure (${o}/${i-1}) in ${l}ms: ${s}`),await t.y(l)}throw a};if(_.length===0&&g.length){let e=g.length;for(let[t,n]of g.entries()){let i=Date.now();if(await v(()=>r.reply(n),`text`),!l){let n=Date.now()-i;C.debug(`Sent chunk ${t+1}/${e} to ${r.from} (${n.toFixed(0)}ms)`)}}o.info({correlationId:r.id??b(),connectionId:s??null,to:r.from,from:r.to,text:$(n.text,240),mediaUrl:null,mediaSizeBytes:null,mediaKind:null,durationMs:Date.now()-d},`auto-reply sent (text)`);return}let y=[...g];for(let[n,a]of _.entries()){let l=n===0&&y.shift()||void 0;try{let n=await c.a(a,{maxBytes:i,localRoots:e.mediaLocalRoots});if(t.B()&&(t.R(`Web auto-reply media size: ${(n.buffer.length/(1024*1024)).toFixed(2)}MB`),t.R(`Web auto-reply media source: ${a} (kind ${n.kind})`)),n.kind===`image`)await v(()=>r.sendMedia({image:n.buffer,caption:l,mimetype:n.contentType}),`media:image`);else if(n.kind===`audio`)await v(()=>r.sendMedia({audio:n.buffer,ptt:!0,mimetype:n.contentType,caption:l}),`media:audio`);else if(n.kind===`video`)await v(()=>r.sendMedia({video:n.buffer,caption:l,mimetype:n.contentType}),`media:video`);else{let e=n.fileName??a.split(`/`).pop()??`file`,t=n.contentType??`application/octet-stream`;await v(()=>r.sendMedia({document:n.buffer,fileName:e,caption:l,mimetype:t}),`media:document`)}C.info(`Sent media reply to ${r.from} (${(n.buffer.length/(1024*1024)).toFixed(2)}MB)`),o.info({correlationId:r.id??b(),connectionId:s??null,to:r.from,from:r.to,text:l??null,mediaUrl:a,mediaSizeBytes:n.buffer.length,mediaKind:n.kind,durationMs:Date.now()-d},`auto-reply sent (media)`)}catch(e){if(C.error(`Failed sending web media to ${r.from}: ${p.n(e)}`),o.warn({err:e,mediaUrl:a},`failed to send web media reply`),n===0){let t=e instanceof Error?`⚠️ Media failed: ${e.message}`:`⚠️ Media failed.`,n=[y.shift()??l??``,t].filter(Boolean).join(`
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{C as e,D as t,E as n,H as r,L as i,O as a,Q as o,R as s,S as c,T as l,U as u,V as d,W as f,X as p,Y as m,Z as h,_ as g,a as _,b as v,c as y,d as b,f as x,g as S,h as ee,i as C,l as te,m as ne,p as re,s as ie,t as w,u as T,v as ae,w as oe,y as se,z as E}from"./dispatch-
|
|
1
|
+
import{C as e,D as t,E as n,H as r,L as i,O as a,Q as o,R as s,S as c,T as l,U as u,V as d,W as f,X as p,Y as m,Z as h,_ as g,a as _,b as v,c as y,d as b,f as x,g as S,h as ee,i as C,l as te,m as ne,p as re,s as ie,t as w,u as T,v as ae,w as oe,y as se,z as E}from"./dispatch-Dbp8KQt5.js";import{Mt as D,Nt as O,jt as k}from"./send-nSnb1tbm.js";import{Dt as A,Et as j,Mt as M,kt as ce,s as N}from"./paths-E9uhW4hC.js";import{$n as le,At as ue,Da as P,Gn as F,Jn as de,Kn as fe,Mt as I,Ot as pe,Sr as me,Wn as L,Zn as R,_r as z,ec as he,gr as B,qn as ge,rr as V,si as H}from"./model-auth-Ck2abiwX.js";import{B as U,C as _e,K as ve,M as ye,O as be,R as W,T as G,h as K,m as q,o as xe,p as Se,v as Ce}from"./logger-DBxM8LRL.js";import"./paths-DhSjTRMz.js";import"./proxy-env-CvaGpEr-.js";import"./github-copilot-token-ylX_gawo.js";import"./send-NrPSIll9.js";import"./fetch-guard-Cd0QnG1m.js";import{J as we,Y as Te,tt as Ee}from"./send-TWSCDee_.js";import"./deliver-CMAb6RNl.js";import"./diagnostic-BwEAey-6.js";import"./pi-model-discovery-B6lpUUqB.js";import{f as De}from"./audio-transcription-runner-BiisJezR.js";import"./image-B7X0YDRe.js";import"./api-key-rotation-Cr6OpZwI.js";import{t as Oe}from"./local-roots-BxL3VWHa.js";import"./proxy-fetch-D-VHASsi.js";import"./tokens-ItXfMr3U.js";import"./commands-registry-DGl54088.js";import"./fetch-C3LEMysf.js";import{a as ke,d as Ae,h as je,m as Me,s as Ne}from"./ir-CRdapTgs.js";import"./render-DhTJXP1U.js";import"./target-errors-BU6AeOFz.js";import{n as Pe}from"./channel-activity-D8W2cEeE.js";import{t as Fe}from"./tables-ChgQ5GDl.js";import"./send-BNXmjdAe.js";import"./fetch-muvEPeHY.js";import"./skill-commands-BOfPEFLf.js";import"./outbound-attachment-B_NLDIys.js";import"./send-kt6sVsa1.js";import{r as Ie}from"./active-listener-DdnNIOc7.js";import"./query-expansion-D6SkoS5P.js";import"./manager-CTo9iVJZ.js";import{i as Le,r as Re,t as ze}from"./outbound-CBFGkXJf.js";import{i as Be,n as J,r as Ve,t as He}from"./session-CC4PHAKJ.js";import{t as Ue}from"./login-rQMJ-Hw6.js";import{randomUUID as We}from"node:crypto";import{DisconnectReason as Ge,downloadMediaMessage as Ke,extractMessageContent as qe,getContentType as Je,isJidGroup as Ye,normalizeMessageContent as Xe}from"@whiskeysockets/baileys";const Ze={initialMs:2e3,maxMs:3e4,factor:1.8,jitter:.25,maxAttempts:12};function Qe(e,t){let n=t??e.web?.heartbeatSeconds;return typeof n==`number`&&n>0?n:60}function $e(e,t){let n=e.web?.reconnect??{},r=t??{},i={...Ze,...n,...r};return i.initialMs=Math.max(250,i.initialMs),i.maxMs=Math.max(i.initialMs,i.maxMs),i.factor=xe(i.factor,1.1,10),i.jitter=xe(i.jitter,0,1),i.maxAttempts=Math.max(0,Math.floor(i.maxAttempts)),i}function Y(){return We()}const X=be(`gateway/channels/whatsapp`),Z=X.child(`inbound`),Q=X.child(`outbound`),et=X.child(`heartbeat`);function tt(){return setInterval(()=>{},1e6).unref(),new Promise(()=>{})}const nt=s({ttlMs:20*6e4,maxSize:5e3});function rt(e){return nt.check(e)}const it=new Set([`FN`,`N`,`TEL`]);function at(e){if(!e)return{phones:[]};let t=e.split(/\r?\n/),n,r,i=[];for(let e of t){let t=e.trim();if(!t)continue;let a=t.indexOf(`:`);if(a===-1)continue;let o=t.slice(0,a).toUpperCase(),s=t.slice(a+1).trim();if(!s)continue;let c=ot(o);if(!c||!it.has(c))continue;let l=st(s);if(l){if(c===`FN`&&!r){r=ct(l);continue}if(c===`N`&&!n){n=ct(l);continue}if(c===`TEL`){let e=lt(l);e&&i.push(e)}}}return{name:r??n,phones:i}}function ot(e){let[t]=e.split(`;`);if(!t)return;let n=t.split(`.`);return n[n.length-1]||void 0}function st(e){return e.replace(/\\n/gi,` `).replace(/\\,/g,`,`).replace(/\\;/g,`;`).trim()}function ct(e){return e.replace(/;/g,` `).replace(/\s+/g,` `).trim()}function lt(e){let t=e.trim();return t?t.toLowerCase().startsWith(`tel:`)?t.slice(4).trim():t:``}function $(e){return Xe(e)}function ut(e){if(!e)return;let t=Je(e),n=t?e[t]:void 0,r=n&&typeof n==`object`&&`contextInfo`in n?n.contextInfo:void 0;if(r)return r;let i=e.extendedTextMessage?.contextInfo??e.imageMessage?.contextInfo??e.videoMessage?.contextInfo??e.documentMessage?.contextInfo??e.audioMessage?.contextInfo??e.stickerMessage?.contextInfo??e.buttonsResponseMessage?.contextInfo??e.listResponseMessage?.contextInfo??e.templateButtonReplyMessage?.contextInfo??e.interactiveResponseMessage?.contextInfo??e.buttonsMessage?.contextInfo??e.listMessage?.contextInfo;if(i)return i;for(let t of Object.values(e)){if(!t||typeof t!=`object`||!(`contextInfo`in t))continue;let e=t.contextInfo;if(e)return e}}function dt(e){let t=$(e);if(!t)return;let n=[t.extendedTextMessage?.contextInfo?.mentionedJid,t.extendedTextMessage?.contextInfo?.quotedMessage?.extendedTextMessage?.contextInfo?.mentionedJid,t.imageMessage?.contextInfo?.mentionedJid,t.videoMessage?.contextInfo?.mentionedJid,t.documentMessage?.contextInfo?.mentionedJid,t.audioMessage?.contextInfo?.mentionedJid,t.stickerMessage?.contextInfo?.mentionedJid,t.buttonsResponseMessage?.contextInfo?.mentionedJid,t.listResponseMessage?.contextInfo?.mentionedJid].flatMap(e=>e??[]).filter(Boolean);if(n.length!==0)return Array.from(new Set(n))}function ft(e){let t=$(e);if(!t)return;let n=qe(t),r=[t,n&&n!==t?n:void 0];for(let e of r){if(!e)continue;if(typeof e.conversation==`string`&&e.conversation.trim())return e.conversation.trim();let t=e.extendedTextMessage?.text;if(t?.trim())return t.trim();let n=e.imageMessage?.caption??e.videoMessage?.caption??e.documentMessage?.caption;if(n?.trim())return n.trim()}let i=mt(t)??(n&&n!==t?mt(n):void 0);if(i)return i}function pt(e){let t=$(e);if(t){if(t.imageMessage)return`<media:image>`;if(t.videoMessage)return`<media:video>`;if(t.audioMessage)return`<media:audio>`;if(t.documentMessage)return`<media:document>`;if(t.stickerMessage)return`<media:sticker>`}}function mt(e){let t=$(e);if(!t)return;let n=t.contactMessage??void 0;if(n){let{name:e,phones:t}=ht({displayName:n.displayName,vcard:n.vcard});return gt(e,t)}let r=t.contactsArrayMessage?.contacts??void 0;if(!(!r||r.length===0))return _t(r.map(e=>ht({displayName:e.displayName,vcard:e.vcard})).map(e=>vt(e.name,e.phones)).filter(e=>!!e),r.length)}function ht(e){let t=(e.displayName??``).trim(),n=at(e.vcard??void 0);return{name:t||n.name,phones:n.phones}}function gt(e,t){let n=vt(e,t);return n?`<contact: ${n}>`:`<contact>`}function _t(e,t){let n=e.map(e=>e.trim()).filter(Boolean);if(n.length===0)return`<contacts: ${t} ${t===1?`contact`:`contacts`}>`;let r=Math.max(t-n.length,0),i=r>0?` +${r} more`:``;return`<contacts: ${n.join(`, `)}${i}>`}function vt(e,t){let n=[e,yt(t)].filter(e=>!!e);if(n.length!==0)return n.join(`, `)}function yt(e){let t=e?.map(e=>e.trim()).filter(Boolean)??[];if(t.length===0)return;let{shown:n,remaining:r}=bt(t,t.length,1),[i]=n;if(i)return r===0?i:`${i} (+${r} more)`}function bt(e,t,n){let r=e.slice(0,n);return{shown:r,remaining:Math.max(t-r.length,0)}}function xt(e){let t=$(e);if(!t)return null;let n=t.liveLocationMessage??void 0;if(n){let e=n.degreesLatitude,t=n.degreesLongitude;if(e!=null&&t!=null){let r=Number(e),i=Number(t);if(Number.isFinite(r)&&Number.isFinite(i))return{latitude:r,longitude:i,accuracy:n.accuracyInMeters??void 0,caption:n.caption??void 0,source:`live`,isLive:!0}}}let r=t.locationMessage??void 0;if(r){let e=r.degreesLatitude,t=r.degreesLongitude;if(e!=null&&t!=null){let n=Number(e),i=Number(t);if(Number.isFinite(n)&&Number.isFinite(i)){let e=!!r.isLive;return{latitude:n,longitude:i,accuracy:r.accuracyInMeters??void 0,name:r.name??void 0,address:r.address??void 0,caption:r.comment??void 0,source:e?`live`:r.name||r.address?`place`:`pin`,isLive:e}}}}return null}function St(e){let t=$(e);if(!t)return null;let n=ut(t),r=Xe(n?.quotedMessage);if(!r)return null;let i=xt(r),a=i?we(i):void 0,o=[ft(r),a].filter(Boolean).join(`
|
|
2
2
|
`).trim();if(o||=pt(r),!o){let e=r?Je(r):void 0;return W(`Quoted message missing extractable body${e?` (type ${e})`:``}`),null}let s=n?.participant??void 0,c=s?q(s)??s:void 0,l=c??`unknown sender`;return{id:n?.stanzaId?String(n.stanzaId):void 0,body:o,sender:l,senderJid:s,senderE164:c}}function Ct(e){return D({providerConfigPresent:e.providerConfigPresent,groupPolicy:e.groupPolicy,defaultGroupPolicy:e.defaultGroupPolicy})}async function wt(e){let t=P(),n=L({cfg:t,accountId:e.accountId}),r=n.dmPolicy??`pairing`,i=n.allowFrom??[],a=await d({provider:`whatsapp`,accountId:n.accountId,dmPolicy:r}),o=i.length===0&&e.selfE164?[e.selfE164]:[],s=i.length>0?i:o,c=n.groupAllowFrom??(i.length>0?i:void 0),l=e.from===e.selfE164,f=n.selfChatMode??Se(e.selfE164,i),p=typeof e.pairingGraceMs==`number`&&e.pairingGraceMs>0?e.pairingGraceMs:3e4,m=typeof e.connectedAtMs==`number`&&typeof e.messageTimestampMs==`number`&&e.messageTimestampMs<e.connectedAtMs-p,h=k(t),{groupPolicy:g,providerMissingFallbackApplied:_}=Ct({providerConfigPresent:t.channels?.whatsapp!==void 0,groupPolicy:n.groupPolicy,defaultGroupPolicy:h});O({providerMissingFallbackApplied:_,providerKey:`whatsapp`,accountId:n.accountId,log:e=>W(e)});let v=K(e.from),y=typeof e.senderE164==`string`?K(e.senderE164):null,b=u({isGroup:e.group,dmPolicy:r,groupPolicy:g,allowFrom:e.group?i:s,groupAllowFrom:c,storeAllowFrom:a,isSenderAllowed:t=>{if(t.includes(`*`))return!0;let n=new Set(t.map(e=>K(String(e))).filter(e=>!!e));return!e.group&&l?!0:e.group?!!(y&&n.has(y)):n.has(v)}});if(e.group&&b.decision!==`allow`)return b.reason===`groupPolicy=disabled`?W(`Blocked group message (groupPolicy: disabled)`):b.reason===`groupPolicy=allowlist (empty allowlist)`?W(`Blocked group message (groupPolicy: allowlist, no groupAllowFrom)`):W(`Blocked group message from ${e.senderE164??`unknown sender`} (groupPolicy: allowlist)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:f,resolvedAccountId:n.accountId};if(!e.group){if(e.isFromMe&&!l)return W(`Skipping outbound DM (fromMe); no pairing reply needed.`),{allowed:!1,shouldMarkRead:!1,isSelfChat:f,resolvedAccountId:n.accountId};if(b.decision===`block`&&b.reason===`dmPolicy=disabled`)return W(`Blocked dm (dmPolicy: disabled)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:f,resolvedAccountId:n.accountId};if(b.decision===`pairing`&&!l){let t=e.from;return m?W(`Skipping pairing reply for historical DM from ${t}.`):await E({channel:`whatsapp`,senderId:t,senderIdLine:`Your WhatsApp phone number: ${t}`,meta:{name:(e.pushName??``).trim()||void 0},upsertPairingRequest:async({id:e,meta:t})=>await Ee({channel:`whatsapp`,id:e,accountId:n.accountId,meta:t}),onCreated:()=>{W(`whatsapp pairing request sender=${t} name=${e.pushName??`unknown`}`)},sendPairingReply:async t=>{await e.sock.sendMessage(e.remoteJid,{text:t})},onReplyError:e=>{W(`whatsapp pairing reply failed for ${t}: ${String(e)}`)}}),{allowed:!1,shouldMarkRead:!1,isSelfChat:f,resolvedAccountId:n.accountId}}if(b.decision!==`allow`)return W(`Blocked unauthorized sender ${e.from} (dmPolicy=${r})`),{allowed:!1,shouldMarkRead:!1,isSelfChat:f,resolvedAccountId:n.accountId}}return{allowed:!0,shouldMarkRead:!0,isSelfChat:f,resolvedAccountId:n.accountId}}function Tt(e){return Xe(e)}function Et(e){let t=e.imageMessage?.mimetype??e.videoMessage?.mimetype??e.documentMessage?.mimetype??e.audioMessage?.mimetype??e.stickerMessage?.mimetype??void 0;if(t)return t;if(e.audioMessage)return`audio/ogg; codecs=opus`;if(e.imageMessage)return`image/jpeg`;if(e.videoMessage)return`video/mp4`;if(e.stickerMessage)return`image/webp`}async function Dt(e,t){let n=Tt(e.message);if(!n)return;let r=Et(n),i=n.documentMessage?.fileName??void 0;if(!(!n.imageMessage&&!n.videoMessage&&!n.documentMessage&&!n.audioMessage&&!n.stickerMessage))try{return{buffer:await Ke(e,`buffer`,{},{reuploadRequest:t.updateMediaMessage,logger:t.logger}),mimetype:r,fileName:i}}catch(e){W(`downloadMediaMessage failed: ${String(e)}`);return}}function Ot(e){Pe({channel:`whatsapp`,accountId:e,direction:`outbound`})}function kt(e){return typeof e==`object`&&e&&`key`in e?String(e.key?.id??`unknown`):`unknown`}function At(e){return{sendMessage:async(t,n,r,i,a)=>{let o=G(t),s;if(r&&i)if(i.startsWith(`image/`))s={image:r,caption:n||void 0,mimetype:i};else if(i.startsWith(`audio/`))s={audio:r,ptt:!0,mimetype:i};else if(i.startsWith(`video/`)){let e=a?.gifPlayback;s={video:r,caption:n||void 0,mimetype:i,...e?{gifPlayback:!0}:{}}}else s={document:r,fileName:a?.fileName?.trim()||`file`,caption:n||void 0,mimetype:i};else s={text:n};let c=await e.sock.sendMessage(o,s);return Ot(a?.accountId??e.defaultAccountId),{messageId:kt(c)}},sendPoll:async(t,n)=>{let r=G(t),i=await e.sock.sendMessage(r,{poll:{name:n.question,values:n.options,selectableCount:n.maxSelections??1}});return Ot(e.defaultAccountId),{messageId:kt(i)}},sendReaction:async(t,n,r,i,a)=>{let o=G(t);await e.sock.sendMessage(o,{react:{text:r,key:{remoteJid:o,id:n,fromMe:i,participant:a?G(a):void 0}}})},sendComposingTo:async t=>{let n=G(t);await e.sock.sendPresenceUpdate(`composing`,n)}}}async function jt(e){let t=ve({module:`web-inbound`}),n=be(`gateway/channels/whatsapp`).child(`inbound`),r=await He(!1,e.verbose,{authDir:e.authDir});await Be(r);let i=Date.now(),a=null,o=new Promise(e=>{a=e}),s=e=>{if(!a)return;let t=a;a=null,t(e)};try{await r.sendPresenceUpdate(`available`),U()&&W(`Sent global 'available' presence on connect`)}catch(e){W(`Failed to send 'available' presence on connect: ${String(e)}`)}let l=r.user?.id,u=l?q(l):null,d=c({debounceMs:e.debounceMs??0,buildKey:e=>{let t=e.chatType===`group`?e.senderJid??e.senderE164??e.senderName??e.from:e.from;if(!t)return null;let n=e.chatType===`group`?e.chatId:e.from;return`${e.accountId}:${n}:${t}`},shouldDebounce:e.shouldDebounce,onFlush:async t=>{let n=t.at(-1);if(!n)return;if(t.length===1){await e.onMessage(n);return}let r=new Set;for(let e of t)for(let t of e.mentionedJids??[])r.add(t);let i=t.map(e=>e.body).filter(Boolean).join(`
|
|
3
3
|
`),a={...n,body:i,mentionedJids:r.size>0?Array.from(r):void 0};await e.onMessage(a)},onError:e=>{t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)}}),f=new Map,p=300*1e3,m=r.signalRepository?.lidMapping,h=async t=>Ce(t,{authDir:e.authDir,lidLookup:m}),g=async e=>{let t=f.get(e);if(t&&t.expires>Date.now())return t;try{let t=await r.groupMetadata(e),n=(await Promise.all(t.participants?.map(async e=>await h(e.id)??e.id)??[])).filter(Boolean)??[],i={subject:t.subject,participants:n,expires:Date.now()+p};return f.set(e,i),i}catch(t){return W(`Failed to fetch group metadata for ${e}: ${String(t)}`),{expires:Date.now()+p}}},_=async t=>{let n=t.key?.id??void 0,a=t.key?.remoteJid;if(!a||a.endsWith(`@status`)||a.endsWith(`@broadcast`))return null;let o=Ye(a)===!0;if(n&&rt(`${e.accountId}:${a}:${n}`))return null;let s=t.key?.participant??void 0,c=o?a:await h(a);if(!c)return null;let l=o?s?await h(s):null:c,d,f;if(o){let e=await g(a);d=e.subject,f=e.participants}let p=t.messageTimestamp?Number(t.messageTimestamp)*1e3:void 0,m=await wt({accountId:e.accountId,from:c,selfE164:u,senderE164:l,group:o,pushName:t.pushName??void 0,isFromMe:!!t.key?.fromMe,messageTimestampMs:p,connectedAtMs:i,sock:{sendMessage:(e,t)=>r.sendMessage(e,t)},remoteJid:a});return m.allowed?{id:n,remoteJid:a,group:o,participantJid:s,from:c,senderE164:l,groupSubject:d,groupParticipants:f,messageTimestampMs:p,access:m}:null},v=async t=>{let{id:n,remoteJid:i,participantJid:a,access:o}=t;if(n&&!o.isSelfChat&&e.sendReadReceipts!==!1)try{await r.readMessages([{remoteJid:i,id:n,participant:a,fromMe:!1}]),U()&&W(`Marked message ${n} as read for ${i}${a?` (participant ${a})`:``}`)}catch(e){W(`Failed to mark message ${n} read: ${String(e)}`)}else n&&o.isSelfChat&&U()&&W(`Self-chat mode: skipping read receipt for ${n}`)},y=async t=>{let n=xt(t.message??void 0),i=n?we(n):void 0,a=ft(t.message??void 0);if(i&&(a=[a,i].filter(Boolean).join(`
|
|
4
4
|
`).trim()),!a&&(a=pt(t.message??void 0),!a))return null;let o=St(t.message),s,c,l;try{let n=await Dt(t,r);if(n){let t=(typeof e.mediaMaxMb==`number`&&e.mediaMaxMb>0?e.mediaMaxMb:50)*1024*1024;s=(await H(n.buffer,n.mimetype,`inbound`,t,n.fileName)).path,c=n.mimetype,l=n.fileName}}catch(e){W(`Inbound media download failed: ${String(e)}`)}return{body:a,location:n??void 0,replyContext:o,mediaPath:s,mediaType:c,mediaFileName:l}},b=async(e,i,a)=>{let o=i.remoteJid,s=async()=>{try{await r.sendPresenceUpdate(`composing`,o)}catch(e){W(`Presence update failed: ${String(e)}`)}},c=async e=>{await r.sendMessage(o,{text:e})},f=async e=>{await r.sendMessage(o,e)},p=i.messageTimestampMs,m=dt(e.message),h=e.pushName??void 0;t.info({from:i.from,to:u??`me`,body:a.body,mediaPath:a.mediaPath,mediaType:a.mediaType,mediaFileName:a.mediaFileName,timestamp:p},`inbound message`);let g={id:i.id,from:i.from,conversationId:i.from,to:u??`me`,accountId:i.access.resolvedAccountId,body:a.body,pushName:h,timestamp:p,chatType:i.group?`group`:`direct`,chatId:i.remoteJid,senderJid:i.participantJid,senderE164:i.senderE164??void 0,senderName:h,replyToId:a.replyContext?.id,replyToBody:a.replyContext?.body,replyToSender:a.replyContext?.sender,replyToSenderJid:a.replyContext?.senderJid,replyToSenderE164:a.replyContext?.senderE164,groupSubject:i.groupSubject,groupParticipants:i.groupParticipants,mentionedJids:m??void 0,selfJid:l,selfE164:u,fromMe:!!e.key?.fromMe,location:a.location??void 0,sendComposing:s,reply:c,sendMedia:f,mediaPath:a.mediaPath,mediaType:a.mediaType,mediaFileName:a.mediaFileName};try{Promise.resolve(d.enqueue(g)).catch(e=>{t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)})}catch(e){t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)}},x=async t=>{if(!(t.type!==`notify`&&t.type!==`append`))for(let n of t.messages??[]){Pe({channel:`whatsapp`,accountId:e.accountId,direction:`inbound`});let r=await _(n);if(!r||(await v(r),t.type===`append`))continue;let i=await y(n);i&&await b(n,r,i)}};r.ev.on(`messages.upsert`,x);let S=e=>{try{if(e.connection===`close`){let t=Ve(e.lastDisconnect?.error);s({status:t,isLoggedOut:t===Ge.loggedOut,error:e.lastDisconnect?.error})}}catch(e){t.error({error:String(e)},`connection.update handler error`),s({status:void 0,isLoggedOut:!1,error:e})}};return r.ev.on(`connection.update`,S),{close:async()=>{try{let e=r.ev,t=x,n=S;typeof e.off==`function`?(e.off(`messages.upsert`,t),e.off(`connection.update`,n)):typeof e.removeListener==`function`&&(e.removeListener(`messages.upsert`,t),e.removeListener(`connection.update`,n)),r.ws?.close()}catch(e){W(`Socket close failed: ${String(e)}`)}},onClose:o,signalClose:e=>{s(e??{status:void 0,isLoggedOut:!1,error:`closed`})},...At({sock:{sendMessage:(e,t)=>r.sendMessage(e,t),sendPresenceUpdate:(e,t)=>r.sendPresenceUpdate(e,t)},defaultAccountId:e.accountId})}}function Mt(e,n){return{mentionRegexes:t(e,n),allowFrom:e.channels?.whatsapp?.allowFrom}}function Nt(e,t){let n=t?{authDir:t}:void 0;return{normalizedMentions:e.mentionedJids?.length?e.mentionedJids.map(e=>q(e,n)??e).filter(Boolean):[],selfE164:e.selfE164??(e.selfJid?q(e.selfJid,n):null),selfJid:e.selfJid?e.selfJid.replace(/:\\d+/,``):null}}function Pt(e,t,n){let r=e=>a(e),i=Se(n.selfE164,t.allowFrom);if((e.mentionedJids?.length??0)>0&&!i)return!!(n.selfE164&&n.normalizedMentions.includes(n.selfE164)||n.selfJid&&n.normalizedMentions.includes(n.selfJid));let o=r(e.body);if(t.mentionRegexes.some(e=>e.test(o)))return!0;if(n.selfE164){let t=n.selfE164.replace(/\D/g,``);if(t){if(o.replace(/[^\d]/g,``).includes(t))return!0;let n=e.body.replace(/[\s-]/g,``);if(RegExp(`\\+?${t}`,`i`).test(n))return!0}}return!1}function Ft(e,t,n){let r=Nt(e,n);return{wasMentioned:Pt(e,t,r),details:{from:e.from,body:e.body,bodyClean:a(e.body),mentionedJids:e.mentionedJids??null,normalizedMentionedJids:r.normalizedMentions.length?r.normalizedMentions:null,selfJid:e.selfJid??null,selfJidBare:r.selfJid,selfE164:e.selfE164??null,resolvedSelfE164:r.selfE164}}}function It(e,t){let n=e.allowFrom;return(Array.isArray(n)&&n.length>0?n:t?[t]:[]).filter(e=>!!(e&&e!==`*`)).map(e=>K(e)).filter(e=>!!e)}function Lt(e){let t=new Set,n=Math.max(1,e.maxItems??100),r=e=>`combined:${e.sessionKey}:${e.combinedBody}`,i=()=>{for(;t.size>n;){let e=t.values().next().value;if(!e)break;t.delete(e)}};return{rememberText:(n,a)=>{n&&(t.add(n),a.combinedBody&&a.combinedBodySessionKey&&t.add(r({sessionKey:a.combinedBodySessionKey,combinedBody:a.combinedBody})),a.logVerboseMessage&&e.logVerbose?.(`Added to echo detection set (size now: ${t.size}): ${n.substring(0,50)}...`),i())},has:e=>t.has(e),forget:e=>{t.delete(e)},buildCombinedKey:r}}function Rt(e){let t=re({agentId:e.agentId,channel:`whatsapp`,accountId:e.route.accountId,peer:{kind:e.msg.chatType===`group`?`group`:`direct`,id:e.peerId},dmScope:e.cfg.session?.dmScope,identityLinks:e.cfg.session?.identityLinks}),n=A({agentId:e.agentId,mainKey:j});return{sessionKey:t,mainSessionKey:n,lastRoutePolicy:ne({sessionKey:t,mainSessionKey:n})}}async function zt(e){let t=e.cfg.broadcast?.[e.peerId];if(!t||!Array.isArray(t)||t.length===0)return!1;let n=e.cfg.broadcast?.strategy||`parallel`;Z.info(`Broadcasting message to ${t.length} agents (${n})`);let r=e.cfg.agents?.list?.map(e=>M(e.id)),i=(r?.length??0)>0,a=e.msg.chatType===`group`?e.groupHistories.get(e.groupHistoryKey)??[]:void 0,o=async t=>{let n=M(t);if(i&&!r?.includes(n))return Z.warn(`Broadcast agent ${t} not found in agents.list; skipping`),!1;let o=Rt({cfg:e.cfg,msg:e.msg,route:e.route,peerId:e.peerId,agentId:n}),s={...e.route,agentId:n,...o};try{return await e.processMessage(e.msg,s,e.groupHistoryKey,{groupHistory:a,suppressGroupHistoryClear:!0})}catch(e){return Z.error(`Broadcast agent ${t} failed: ${J(e)}`),!1}};if(n===`sequential`)for(let e of t)await o(e);else await Promise.allSettled(t.map(o));return e.msg.chatType===`group`&&e.groupHistories.set(e.groupHistoryKey,[]),!0}function Bt(e,t,n){let r=e;for(let e of t)r=r.replace(e,` `);if(n){let e=n.replace(/\D/g,``);if(e){let t=RegExp(`\\+?${e}`,`g`);r=r.replace(t,` `)}}return r.replace(/\s+/g,` `).trim()}function Vt(e,t){let n=me({From:t,ChatType:`group`,Provider:`whatsapp`})?.id,r=e.channels?.whatsapp,i=!!(r?.groupAllowFrom?.length||r?.allowFrom?.length);return B({cfg:e,channel:`whatsapp`,groupId:n??t,hasGroupAllowFrom:i})}function Ht(e,t){let n=me({From:t,ChatType:`group`,Provider:`whatsapp`})?.id;return z({cfg:e,channel:`whatsapp`,groupId:n??t})}function Ut(e){let t=pe(N(e.cfg.session?.store,{agentId:e.agentId}))[e.sessionKey],n=Ht(e.cfg,e.conversationId)?`mention`:`always`;return C(t?.groupActivation)??n}function Wt(e,t,n){for(let r of e){let e=K(r)??r;!e||t.has(e)||(t.add(e),n.push(e))}}function Gt(e,t,n,r){if(!n||!r)return;let i=K(n)??n;if(!i)return;let a=e.get(t);a||(a=new Map,e.set(t,a)),a.set(i,r)}function Kt(e){let{participants:t,roster:n,fallbackE164:r}=e,i=new Set,a=[];if(t?.length&&Wt(t,i,a),n&&Wt(n.keys(),i,a),a.length===0&&r){let e=K(r)??r;e&&a.push(e)}if(a.length!==0)return a.map(e=>{let t=n?.get(e);return t?`${t} (${e})`:e}).join(`, `)}function qt(e,t){let n=K(t.senderE164??``);return n?It(e,t.selfE164??void 0).includes(n):!1}function Jt(e){let t=e.msg.senderName&&e.msg.senderE164?`${e.msg.senderName} (${e.msg.senderE164})`:e.msg.senderName??e.msg.senderE164??`Unknown`;x({historyMap:e.groupHistories,historyKey:e.groupHistoryKey,limit:e.groupHistoryLimit,entry:{sender:t,body:e.msg.body,timestamp:e.msg.timestamp,id:e.msg.id,senderJid:e.msg.senderJid}})}function Yt(e,t){return e.logVerbose(t),Jt({msg:e.msg,groupHistories:e.groupHistories,groupHistoryKey:e.groupHistoryKey,groupHistoryLimit:e.groupHistoryLimit}),{shouldProcess:!1}}function Xt(e){let t=Vt(e.cfg,e.conversationId);if(t.allowlistEnabled&&!t.allowed)return e.logVerbose(`Skipping group message ${e.conversationId} (not in allowlist)`),{shouldProcess:!1};Gt(e.groupMemberNames,e.groupHistoryKey,e.msg.senderE164,e.msg.senderName);let n=Mt(e.cfg,e.agentId),r=Bt(e.msg.body,n.mentionRegexes,e.msg.selfE164),i=_(r),a=qt(e.baseMentionConfig,e.msg),s=a&&l(r,e.cfg);if(i.hasCommand&&!a)return Yt(e,`Ignoring /activation from non-owner in group ${e.conversationId}`);let c=Ft(e.msg,n,e.authDir);e.replyLogger.debug({conversationId:e.conversationId,wasMentioned:c.wasMentioned,...c.details},`group mention debug`);let u=c.wasMentioned,d=Ut({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:e.conversationId})!==`always`,f=e.msg.selfJid?.replace(/:\\d+/,``),p=e.msg.replyToSenderJid?.replace(/:\\d+/,``),m=e.msg.selfE164?K(e.msg.selfE164):null,h=e.msg.replyToSenderE164?K(e.msg.replyToSenderE164):null,g=o({requireMention:d,canDetectMention:!0,wasMentioned:u,implicitMention:!!(f&&p&&f===p||m&&h&&m===h),shouldBypassMention:s});return e.msg.wasMentioned=g.effectiveWasMentioned,!s&&d&&g.shouldSkip?Yt(e,`Group message stored for context (no mention detected) in ${e.conversationId}: ${e.msg.body}`):{shouldProcess:!0}}function Zt(e,t){e.add(t),t.finally(()=>{e.delete(t)})}function Qt(e){let t=N(e.cfg.session?.store,{agentId:e.storeAgentId}),n=I({storePath:t,sessionKey:e.sessionKey,deliveryContext:{channel:e.channel,to:e.to,accountId:e.accountId},ctx:e.ctx}).catch(n=>{e.warn({error:J(n),storePath:t,sessionKey:e.sessionKey,to:e.to},`failed updating last route`)});Zt(e.backgroundTasks,n)}function $t(e){return e.chatType===`group`?e.conversationId??e.from:e.senderE164?K(e.senderE164)??e.senderE164:e.from.includes(`@`)?q(e.from)??e.from:K(e.from)??e.from}function en(e,t=400){return!e||e.length<=t?e:`${e.slice(0,t)}… (truncated ${e.length-t} chars)`}function tn(e){let t=(e instanceof Error?`${e.message}\n${e.stack??``}`:(e=>{if(e==null)return``;if(typeof e==`string`)return e;if(e instanceof Error)return`${e.message}\n${e.stack??``}`;if(typeof e==`object`)try{return JSON.stringify(e)}catch{return Object.prototype.toString.call(e)}return typeof e==`number`||typeof e==`boolean`||typeof e==`bigint`?String(e):typeof e==`symbol`?e.description??e.toString():typeof e==`function`?e.name?`[function ${e.name}]`:`[function]`:Object.prototype.toString.call(e)})(e)).toLowerCase();return t.includes(`unsupported state or unable to authenticate data`)||t.includes(`bad mac`)?t.includes(`@whiskeysockets/baileys`)||t.includes(`baileys`)||t.includes(`noise-handler`)||t.includes(`aesdecryptgcm`):!1}function nn(e){if(e.isReasoning===!0)return!0;let t=e.text;return typeof t==`string`?t.trimStart().toLowerCase().startsWith(`reasoning:`):!1}async function rn(e){let{replyResult:t,msg:n,maxMediaBytes:r,textLimit:i,replyLogger:a,connectionId:o,skipLog:s}=e,c=Date.now();if(nn(t)){Q.debug(`Suppressed reasoning payload to ${n.from}`);return}let l=e.tableMode??`code`,u=e.chunkMode??`length`,d=Ae(Le(Fe(t.text||``,l)),i,u),f=t.mediaUrls?.length?t.mediaUrls:t.mediaUrl?[t.mediaUrl]:[],p=async(e,t,r=3)=>{let i;for(let a=1;a<=r;a++)try{return await e()}catch(e){i=e;let o=J(e),s=a===r;if(!/closed|reset|timed\s*out|disconnect/i.test(o)||s)throw e;let c=500*a;W(`Retrying ${t} to ${n.from} after failure (${a}/${r-1}) in ${c}ms: ${o}`),await _e(c)}throw i};if(f.length===0&&d.length){let e=d.length;for(let[t,r]of d.entries()){let i=Date.now();if(await p(()=>n.reply(r),`text`),!s){let r=Date.now()-i;Q.debug(`Sent chunk ${t+1}/${e} to ${n.from} (${r.toFixed(0)}ms)`)}}a.info({correlationId:n.id??Y(),connectionId:o??null,to:n.from,from:n.to,text:en(t.text,240),mediaUrl:null,mediaSizeBytes:null,mediaKind:null,durationMs:Date.now()-c},`auto-reply sent (text)`);return}let m=[...d];for(let[t,i]of f.entries()){let s=t===0&&m.shift()||void 0;try{let t=await ke(i,{maxBytes:r,localRoots:e.mediaLocalRoots});if(U()&&(W(`Web auto-reply media size: ${(t.buffer.length/(1024*1024)).toFixed(2)}MB`),W(`Web auto-reply media source: ${i} (kind ${t.kind})`)),t.kind===`image`)await p(()=>n.sendMedia({image:t.buffer,caption:s,mimetype:t.contentType}),`media:image`);else if(t.kind===`audio`)await p(()=>n.sendMedia({audio:t.buffer,ptt:!0,mimetype:t.contentType,caption:s}),`media:audio`);else if(t.kind===`video`)await p(()=>n.sendMedia({video:t.buffer,caption:s,mimetype:t.contentType}),`media:video`);else{let e=t.fileName??i.split(`/`).pop()??`file`,r=t.contentType??`application/octet-stream`;await p(()=>n.sendMedia({document:t.buffer,fileName:e,caption:s,mimetype:r}),`media:document`)}Q.info(`Sent media reply to ${n.from} (${(t.buffer.length/(1024*1024)).toFixed(2)}MB)`),a.info({correlationId:n.id??Y(),connectionId:o??null,to:n.from,from:n.to,text:s??null,mediaUrl:i,mediaSizeBytes:t.buffer.length,mediaKind:t.kind,durationMs:Date.now()-c},`auto-reply sent (media)`)}catch(e){if(Q.error(`Failed sending web media to ${n.from}: ${J(e)}`),a.warn({err:e,mediaUrl:i},`failed to send web media reply`),t===0){let t=e instanceof Error?`⚠️ Media failed: ${e.message}`:`⚠️ Media failed.`,r=[m.shift()??s??``,t].filter(Boolean).join(`
|
|
@@ -1 +1 @@
|
|
|
1
|
-
require(`./paths-BvlJvmRS.cjs`),require(`./paths-D-ZHvue1.cjs`);const e=require(`./config-Bz83cj6j.cjs`);require(`./dispatch-
|
|
1
|
+
require(`./paths-BvlJvmRS.cjs`),require(`./paths-D-ZHvue1.cjs`);const e=require(`./config-Bz83cj6j.cjs`);require(`./dispatch-DBHCub77.cjs`),require(`./github-copilot-token-TMkfxxD2.cjs`),require(`./logger-Cpr431-m.cjs`),require(`./proxy-env-CseuAqo8.cjs`),require(`./send-BMpI8-qA.cjs`),require(`./fetch-lw-aF17e.cjs`),require(`./channel-activity-CyPElGWJ.cjs`),require(`./fetch-guard-DZbyzDxn.cjs`),require(`./local-roots-1zRRZTjI.cjs`),require(`./ir-Cb3l5jIU.cjs`),require(`./render-CzHaQB0d.cjs`),require(`./tables-Jb84nzN1.cjs`),require(`./send-BmKc-3mI.cjs`),require(`./target-errors-3m5Ys02s.cjs`),require(`./send-D-x4l6Ka.cjs`),require(`./deliver-DuJ013W5.cjs`),require(`./diagnostic-Cd-NAZu8.cjs`),require(`./pi-model-discovery-DE_oRjec.cjs`),require(`./audio-transcription-runner-8Uzqppzz.cjs`),require(`./image-B2pVbSeQ.cjs`),require(`./api-key-rotation-CZWEBz4L.cjs`),require(`./proxy-fetch-BHWRsbyA.cjs`),require(`./tokens-CctQaANK.cjs`),require(`./commands-registry-B2lkKUhm.cjs`),require(`./send-CkWbO-yn.cjs`),require(`./fetch-enwOS_u0.cjs`),require(`./skill-commands-DJmTpzxg.cjs`),require(`./outbound-attachment-BQfx5ox7.cjs`),require(`./send-Dhz5ss-W.cjs`),require(`./query-expansion-BWN9mQqH.cjs`),require(`./manager-9lvr22Qb.cjs`);const t=require(`./channel-web-CGYvIoB3.cjs`),n=require(`./outbound-ChjcG4nl.cjs`),r=require(`./session-v7OXQDfB.cjs`),i=require(`./login-BP8Lh2Gm.cjs`);exports.WA_WEB_AUTH_DIR=e.Ga,exports.createWaSocket=r.t,exports.logWebSelfId=e.qa,exports.loginWeb=i.t,exports.monitorWebChannel=t.t,exports.monitorWebInbox=t.n,exports.pickWebChannel=e.Xa,exports.sendMessageWhatsApp=n.t,exports.waitForWaConnection=r.i,exports.webAuthExists=e.no;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
require(`./paths-Bcdg3ma0.cjs`);const e=require(`./dispatch-
|
|
1
|
+
require(`./paths-Bcdg3ma0.cjs`);const e=require(`./dispatch-CDF-QMLO.cjs`),t=require(`./paths-kh9_JTNM.cjs`),n=require(`./model-auth-B24oTRJx.cjs`),r=require(`./logger-CMTXcXUA.cjs`);require(`./proxy-env-CxZAYxjP.cjs`),require(`./github-copilot-token-CCrgp2py.cjs`),require(`./send-CS_B9I2a.cjs`);const i=require(`./send-BPmPmhCh.cjs`),a=require(`./send-CI99Eisf.cjs`);require(`./deliver-OChxLqH_.cjs`),require(`./diagnostic-CdVH1WWD.cjs`),require(`./pi-model-discovery-PG9qXdpT.cjs`);const o=require(`./audio-transcription-runner-DMTbf0cc.cjs`);require(`./image-Bh7NtX1z.cjs`),require(`./fetch-guard-D7tv66no.cjs`),require(`./api-key-rotation-D-mp8nJn.cjs`);const s=require(`./local-roots-DXwF5mgW.cjs`);require(`./proxy-fetch-BRtmAK5t.cjs`),require(`./tokens-Cxzj_0O5.cjs`),require(`./commands-registry-8-eeDgnv.cjs`),require(`./fetch-ClKErpni.cjs`);const c=require(`./ir-eVfCfDc3.cjs`);require(`./render-DxBO2Blp.cjs`),require(`./target-errors-DQitDYWt.cjs`);const l=require(`./channel-activity-CaNq9wJm.cjs`),u=require(`./tables-BkZk06tL.cjs`);require(`./send-DPYU7k55.cjs`),require(`./fetch-DuZqnoLu.cjs`),require(`./skill-commands-wy7EWhtU.cjs`),require(`./outbound-attachment-nJInjwJw.cjs`),require(`./send-BqiVZwuS.cjs`);const d=require(`./active-listener-TPLpWPxm.cjs`);require(`./query-expansion-hz1FnuKQ.cjs`),require(`./manager-DvWUd-LV.cjs`);const f=require(`./outbound-DN2jGFS8.cjs`),p=require(`./session-B29f7UJ3.cjs`),m=require(`./login-CAx0X2lK.cjs`);let h=require(`node:crypto`),g=require(`@whiskeysockets/baileys`);const _={initialMs:2e3,maxMs:3e4,factor:1.8,jitter:.25,maxAttempts:12};function v(e,t){let n=t??e.web?.heartbeatSeconds;return typeof n==`number`&&n>0?n:60}function y(e,t){let n=e.web?.reconnect??{},i=t??{},a={..._,...n,...i};return a.initialMs=Math.max(250,a.initialMs),a.maxMs=Math.max(a.initialMs,a.maxMs),a.factor=r.o(a.factor,1.1,10),a.jitter=r.o(a.jitter,0,1),a.maxAttempts=Math.max(0,Math.floor(a.maxAttempts)),a}function b(){return(0,h.randomUUID)()}const x=r.O(`gateway/channels/whatsapp`),S=x.child(`inbound`),C=x.child(`outbound`),ee=x.child(`heartbeat`);function w(){return setInterval(()=>{},1e6).unref(),new Promise(()=>{})}const T=e.R({ttlMs:20*6e4,maxSize:5e3});function E(e){return T.check(e)}const D=new Set([`FN`,`N`,`TEL`]);function O(e){if(!e)return{phones:[]};let t=e.split(/\r?\n/),n,r,i=[];for(let e of t){let t=e.trim();if(!t)continue;let a=t.indexOf(`:`);if(a===-1)continue;let o=t.slice(0,a).toUpperCase(),s=t.slice(a+1).trim();if(!s)continue;let c=k(o);if(!c||!D.has(c))continue;let l=A(s);if(l){if(c===`FN`&&!r){r=j(l);continue}if(c===`N`&&!n){n=j(l);continue}if(c===`TEL`){let e=M(l);e&&i.push(e)}}}return{name:r??n,phones:i}}function k(e){let[t]=e.split(`;`);if(!t)return;let n=t.split(`.`);return n[n.length-1]||void 0}function A(e){return e.replace(/\\n/gi,` `).replace(/\\,/g,`,`).replace(/\\;/g,`;`).trim()}function j(e){return e.replace(/;/g,` `).replace(/\s+/g,` `).trim()}function M(e){let t=e.trim();return t?t.toLowerCase().startsWith(`tel:`)?t.slice(4).trim():t:``}function N(e){return(0,g.normalizeMessageContent)(e)}function P(e){if(!e)return;let t=(0,g.getContentType)(e),n=t?e[t]:void 0,r=n&&typeof n==`object`&&`contextInfo`in n?n.contextInfo:void 0;if(r)return r;let i=e.extendedTextMessage?.contextInfo??e.imageMessage?.contextInfo??e.videoMessage?.contextInfo??e.documentMessage?.contextInfo??e.audioMessage?.contextInfo??e.stickerMessage?.contextInfo??e.buttonsResponseMessage?.contextInfo??e.listResponseMessage?.contextInfo??e.templateButtonReplyMessage?.contextInfo??e.interactiveResponseMessage?.contextInfo??e.buttonsMessage?.contextInfo??e.listMessage?.contextInfo;if(i)return i;for(let t of Object.values(e)){if(!t||typeof t!=`object`||!(`contextInfo`in t))continue;let e=t.contextInfo;if(e)return e}}function F(e){let t=N(e);if(!t)return;let n=[t.extendedTextMessage?.contextInfo?.mentionedJid,t.extendedTextMessage?.contextInfo?.quotedMessage?.extendedTextMessage?.contextInfo?.mentionedJid,t.imageMessage?.contextInfo?.mentionedJid,t.videoMessage?.contextInfo?.mentionedJid,t.documentMessage?.contextInfo?.mentionedJid,t.audioMessage?.contextInfo?.mentionedJid,t.stickerMessage?.contextInfo?.mentionedJid,t.buttonsResponseMessage?.contextInfo?.mentionedJid,t.listResponseMessage?.contextInfo?.mentionedJid].flatMap(e=>e??[]).filter(Boolean);if(n.length!==0)return Array.from(new Set(n))}function I(e){let t=N(e);if(!t)return;let n=(0,g.extractMessageContent)(t),r=[t,n&&n!==t?n:void 0];for(let e of r){if(!e)continue;if(typeof e.conversation==`string`&&e.conversation.trim())return e.conversation.trim();let t=e.extendedTextMessage?.text;if(t?.trim())return t.trim();let n=e.imageMessage?.caption??e.videoMessage?.caption??e.documentMessage?.caption;if(n?.trim())return n.trim()}let i=R(t)??(n&&n!==t?R(n):void 0);if(i)return i}function L(e){let t=N(e);if(t){if(t.imageMessage)return`<media:image>`;if(t.videoMessage)return`<media:video>`;if(t.audioMessage)return`<media:audio>`;if(t.documentMessage)return`<media:document>`;if(t.stickerMessage)return`<media:sticker>`}}function R(e){let t=N(e);if(!t)return;let n=t.contactMessage??void 0;if(n){let{name:e,phones:t}=z({displayName:n.displayName,vcard:n.vcard});return B(e,t)}let r=t.contactsArrayMessage?.contacts??void 0;if(!(!r||r.length===0))return V(r.map(e=>z({displayName:e.displayName,vcard:e.vcard})).map(e=>H(e.name,e.phones)).filter(e=>!!e),r.length)}function z(e){let t=(e.displayName??``).trim(),n=O(e.vcard??void 0);return{name:t||n.name,phones:n.phones}}function B(e,t){let n=H(e,t);return n?`<contact: ${n}>`:`<contact>`}function V(e,t){let n=e.map(e=>e.trim()).filter(Boolean);if(n.length===0)return`<contacts: ${t} ${t===1?`contact`:`contacts`}>`;let r=Math.max(t-n.length,0),i=r>0?` +${r} more`:``;return`<contacts: ${n.join(`, `)}${i}>`}function H(e,t){let n=[e,U(t)].filter(e=>!!e);if(n.length!==0)return n.join(`, `)}function U(e){let t=e?.map(e=>e.trim()).filter(Boolean)??[];if(t.length===0)return;let{shown:n,remaining:r}=te(t,t.length,1),[i]=n;if(i)return r===0?i:`${i} (+${r} more)`}function te(e,t,n){let r=e.slice(0,n);return{shown:r,remaining:Math.max(t-r.length,0)}}function ne(e){let t=N(e);if(!t)return null;let n=t.liveLocationMessage??void 0;if(n){let e=n.degreesLatitude,t=n.degreesLongitude;if(e!=null&&t!=null){let r=Number(e),i=Number(t);if(Number.isFinite(r)&&Number.isFinite(i))return{latitude:r,longitude:i,accuracy:n.accuracyInMeters??void 0,caption:n.caption??void 0,source:`live`,isLive:!0}}}let r=t.locationMessage??void 0;if(r){let e=r.degreesLatitude,t=r.degreesLongitude;if(e!=null&&t!=null){let n=Number(e),i=Number(t);if(Number.isFinite(n)&&Number.isFinite(i)){let e=!!r.isLive;return{latitude:n,longitude:i,accuracy:r.accuracyInMeters??void 0,name:r.name??void 0,address:r.address??void 0,caption:r.comment??void 0,source:e?`live`:r.name||r.address?`place`:`pin`,isLive:e}}}}return null}function W(e){let t=N(e);if(!t)return null;let n=P(t),i=(0,g.normalizeMessageContent)(n?.quotedMessage);if(!i)return null;let o=ne(i),s=o?a.J(o):void 0,c=[I(i),s].filter(Boolean).join(`
|
|
2
2
|
`).trim();if(c||=L(i),!c){let e=i?(0,g.getContentType)(i):void 0;return r.R(`Quoted message missing extractable body${e?` (type ${e})`:``}`),null}let l=n?.participant??void 0,u=l?r.m(l)??l:void 0,d=u??`unknown sender`;return{id:n?.stanzaId?String(n.stanzaId):void 0,body:c,sender:d,senderJid:l,senderE164:u}}function re(e){return i.Mt({providerConfigPresent:e.providerConfigPresent,groupPolicy:e.groupPolicy,defaultGroupPolicy:e.defaultGroupPolicy})}async function ie(t){let o=n.wa(),s=n.Un({cfg:o,accountId:t.accountId}),c=s.dmPolicy??`pairing`,l=s.allowFrom??[],u=await e.H({provider:`whatsapp`,accountId:s.accountId,dmPolicy:c}),d=l.length===0&&t.selfE164?[t.selfE164]:[],f=l.length>0?l:d,p=s.groupAllowFrom??(l.length>0?l:void 0),m=t.from===t.selfE164,h=s.selfChatMode??r.p(t.selfE164,l),g=typeof t.pairingGraceMs==`number`&&t.pairingGraceMs>0?t.pairingGraceMs:3e4,_=typeof t.connectedAtMs==`number`&&typeof t.messageTimestampMs==`number`&&t.messageTimestampMs<t.connectedAtMs-g,v=i.jt(o),{groupPolicy:y,providerMissingFallbackApplied:b}=re({providerConfigPresent:o.channels?.whatsapp!==void 0,groupPolicy:s.groupPolicy,defaultGroupPolicy:v});i.Nt({providerMissingFallbackApplied:b,providerKey:`whatsapp`,accountId:s.accountId,log:e=>r.R(e)});let x=r.h(t.from),S=typeof t.senderE164==`string`?r.h(t.senderE164):null,C=e.W({isGroup:t.group,dmPolicy:c,groupPolicy:y,allowFrom:t.group?l:f,groupAllowFrom:p,storeAllowFrom:u,isSenderAllowed:e=>{if(e.includes(`*`))return!0;let n=new Set(e.map(e=>r.h(String(e))).filter(e=>!!e));return!t.group&&m?!0:t.group?!!(S&&n.has(S)):n.has(x)}});if(t.group&&C.decision!==`allow`)return C.reason===`groupPolicy=disabled`?r.R(`Blocked group message (groupPolicy: disabled)`):C.reason===`groupPolicy=allowlist (empty allowlist)`?r.R(`Blocked group message (groupPolicy: allowlist, no groupAllowFrom)`):r.R(`Blocked group message from ${t.senderE164??`unknown sender`} (groupPolicy: allowlist)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(!t.group){if(t.isFromMe&&!m)return r.R(`Skipping outbound DM (fromMe); no pairing reply needed.`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(C.decision===`block`&&C.reason===`dmPolicy=disabled`)return r.R(`Blocked dm (dmPolicy: disabled)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(C.decision===`pairing`&&!m){let n=t.from;return _?r.R(`Skipping pairing reply for historical DM from ${n}.`):await e.B({channel:`whatsapp`,senderId:n,senderIdLine:`Your WhatsApp phone number: ${n}`,meta:{name:(t.pushName??``).trim()||void 0},upsertPairingRequest:async({id:e,meta:t})=>await a.tt({channel:`whatsapp`,id:e,accountId:s.accountId,meta:t}),onCreated:()=>{r.R(`whatsapp pairing request sender=${n} name=${t.pushName??`unknown`}`)},sendPairingReply:async e=>{await t.sock.sendMessage(t.remoteJid,{text:e})},onReplyError:e=>{r.R(`whatsapp pairing reply failed for ${n}: ${String(e)}`)}}),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId}}if(C.decision!==`allow`)return r.R(`Blocked unauthorized sender ${t.from} (dmPolicy=${c})`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId}}return{allowed:!0,shouldMarkRead:!0,isSelfChat:h,resolvedAccountId:s.accountId}}function G(e){return(0,g.normalizeMessageContent)(e)}function K(e){let t=e.imageMessage?.mimetype??e.videoMessage?.mimetype??e.documentMessage?.mimetype??e.audioMessage?.mimetype??e.stickerMessage?.mimetype??void 0;if(t)return t;if(e.audioMessage)return`audio/ogg; codecs=opus`;if(e.imageMessage)return`image/jpeg`;if(e.videoMessage)return`video/mp4`;if(e.stickerMessage)return`image/webp`}async function ae(e,t){let n=G(e.message);if(!n)return;let i=K(n),a=n.documentMessage?.fileName??void 0;if(!(!n.imageMessage&&!n.videoMessage&&!n.documentMessage&&!n.audioMessage&&!n.stickerMessage))try{return{buffer:await(0,g.downloadMediaMessage)(e,`buffer`,{},{reuploadRequest:t.updateMediaMessage,logger:t.logger}),mimetype:i,fileName:a}}catch(e){r.R(`downloadMediaMessage failed: ${String(e)}`);return}}function q(e){l.n({channel:`whatsapp`,accountId:e,direction:`outbound`})}function J(e){return typeof e==`object`&&e&&`key`in e?String(e.key?.id??`unknown`):`unknown`}function Y(e){return{sendMessage:async(t,n,i,a,o)=>{let s=r.T(t),c;if(i&&a)if(a.startsWith(`image/`))c={image:i,caption:n||void 0,mimetype:a};else if(a.startsWith(`audio/`))c={audio:i,ptt:!0,mimetype:a};else if(a.startsWith(`video/`)){let e=o?.gifPlayback;c={video:i,caption:n||void 0,mimetype:a,...e?{gifPlayback:!0}:{}}}else c={document:i,fileName:o?.fileName?.trim()||`file`,caption:n||void 0,mimetype:a};else c={text:n};let l=await e.sock.sendMessage(s,c);return q(o?.accountId??e.defaultAccountId),{messageId:J(l)}},sendPoll:async(t,n)=>{let i=r.T(t),a=await e.sock.sendMessage(i,{poll:{name:n.question,values:n.options,selectableCount:n.maxSelections??1}});return q(e.defaultAccountId),{messageId:J(a)}},sendReaction:async(t,n,i,a,o)=>{let s=r.T(t);await e.sock.sendMessage(s,{react:{text:i,key:{remoteJid:s,id:n,fromMe:a,participant:o?r.T(o):void 0}}})},sendComposingTo:async t=>{let n=r.T(t);await e.sock.sendPresenceUpdate(`composing`,n)}}}async function oe(t){let i=r.K({module:`web-inbound`}),o=r.O(`gateway/channels/whatsapp`).child(`inbound`),s=await p.t(!1,t.verbose,{authDir:t.authDir});await p.i(s);let c=Date.now(),u=null,d=new Promise(e=>{u=e}),f=e=>{if(!u)return;let t=u;u=null,t(e)};try{await s.sendPresenceUpdate(`available`),r.B()&&r.R(`Sent global 'available' presence on connect`)}catch(e){r.R(`Failed to send 'available' presence on connect: ${String(e)}`)}let m=s.user?.id,h=m?r.m(m):null,_=e.C({debounceMs:t.debounceMs??0,buildKey:e=>{let t=e.chatType===`group`?e.senderJid??e.senderE164??e.senderName??e.from:e.from;if(!t)return null;let n=e.chatType===`group`?e.chatId:e.from;return`${e.accountId}:${n}:${t}`},shouldDebounce:t.shouldDebounce,onFlush:async e=>{let n=e.at(-1);if(!n)return;if(e.length===1){await t.onMessage(n);return}let r=new Set;for(let t of e)for(let e of t.mentionedJids??[])r.add(e);let i=e.map(e=>e.body).filter(Boolean).join(`
|
|
3
3
|
`),a={...n,body:i,mentionedJids:r.size>0?Array.from(r):void 0};await t.onMessage(a)},onError:e=>{i.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)}}),v=new Map,y=300*1e3,b=s.signalRepository?.lidMapping,x=async e=>r.v(e,{authDir:t.authDir,lidLookup:b}),S=async e=>{let t=v.get(e);if(t&&t.expires>Date.now())return t;try{let t=await s.groupMetadata(e),n=(await Promise.all(t.participants?.map(async e=>await x(e.id)??e.id)??[])).filter(Boolean)??[],r={subject:t.subject,participants:n,expires:Date.now()+y};return v.set(e,r),r}catch(t){return r.R(`Failed to fetch group metadata for ${e}: ${String(t)}`),{expires:Date.now()+y}}},C=async e=>{let n=e.key?.id??void 0,r=e.key?.remoteJid;if(!r||r.endsWith(`@status`)||r.endsWith(`@broadcast`))return null;let i=(0,g.isJidGroup)(r)===!0;if(n&&E(`${t.accountId}:${r}:${n}`))return null;let a=e.key?.participant??void 0,o=i?r:await x(r);if(!o)return null;let l=i?a?await x(a):null:o,u,d;if(i){let e=await S(r);u=e.subject,d=e.participants}let f=e.messageTimestamp?Number(e.messageTimestamp)*1e3:void 0,p=await ie({accountId:t.accountId,from:o,selfE164:h,senderE164:l,group:i,pushName:e.pushName??void 0,isFromMe:!!e.key?.fromMe,messageTimestampMs:f,connectedAtMs:c,sock:{sendMessage:(e,t)=>s.sendMessage(e,t)},remoteJid:r});return p.allowed?{id:n,remoteJid:r,group:i,participantJid:a,from:o,senderE164:l,groupSubject:u,groupParticipants:d,messageTimestampMs:f,access:p}:null},ee=async e=>{let{id:n,remoteJid:i,participantJid:a,access:o}=e;if(n&&!o.isSelfChat&&t.sendReadReceipts!==!1)try{await s.readMessages([{remoteJid:i,id:n,participant:a,fromMe:!1}]),r.B()&&r.R(`Marked message ${n} as read for ${i}${a?` (participant ${a})`:``}`)}catch(e){r.R(`Failed to mark message ${n} read: ${String(e)}`)}else n&&o.isSelfChat&&r.B()&&r.R(`Self-chat mode: skipping read receipt for ${n}`)},w=async e=>{let i=ne(e.message??void 0),o=i?a.J(i):void 0,c=I(e.message??void 0);if(o&&(c=[c,o].filter(Boolean).join(`
|
|
4
4
|
`).trim()),!c&&(c=L(e.message??void 0),!c))return null;let l=W(e.message),u,d,f;try{let r=await ae(e,s);if(r){let e=(typeof t.mediaMaxMb==`number`&&t.mediaMaxMb>0?t.mediaMaxMb:50)*1024*1024;u=(await n.ai(r.buffer,r.mimetype,`inbound`,e,r.fileName)).path,d=r.mimetype,f=r.fileName}}catch(e){r.R(`Inbound media download failed: ${String(e)}`)}return{body:c,location:i??void 0,replyContext:l,mediaPath:u,mediaType:d,mediaFileName:f}},T=async(e,t,n)=>{let a=t.remoteJid,c=async()=>{try{await s.sendPresenceUpdate(`composing`,a)}catch(e){r.R(`Presence update failed: ${String(e)}`)}},l=async e=>{await s.sendMessage(a,{text:e})},u=async e=>{await s.sendMessage(a,e)},d=t.messageTimestampMs,f=F(e.message),p=e.pushName??void 0;i.info({from:t.from,to:h??`me`,body:n.body,mediaPath:n.mediaPath,mediaType:n.mediaType,mediaFileName:n.mediaFileName,timestamp:d},`inbound message`);let g={id:t.id,from:t.from,conversationId:t.from,to:h??`me`,accountId:t.access.resolvedAccountId,body:n.body,pushName:p,timestamp:d,chatType:t.group?`group`:`direct`,chatId:t.remoteJid,senderJid:t.participantJid,senderE164:t.senderE164??void 0,senderName:p,replyToId:n.replyContext?.id,replyToBody:n.replyContext?.body,replyToSender:n.replyContext?.sender,replyToSenderJid:n.replyContext?.senderJid,replyToSenderE164:n.replyContext?.senderE164,groupSubject:t.groupSubject,groupParticipants:t.groupParticipants,mentionedJids:f??void 0,selfJid:m,selfE164:h,fromMe:!!e.key?.fromMe,location:n.location??void 0,sendComposing:c,reply:l,sendMedia:u,mediaPath:n.mediaPath,mediaType:n.mediaType,mediaFileName:n.mediaFileName};try{Promise.resolve(_.enqueue(g)).catch(e=>{i.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)})}catch(e){i.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)}},D=async e=>{if(!(e.type!==`notify`&&e.type!==`append`))for(let n of e.messages??[]){l.n({channel:`whatsapp`,accountId:t.accountId,direction:`inbound`});let r=await C(n);if(!r||(await ee(r),e.type===`append`))continue;let i=await w(n);i&&await T(n,r,i)}};s.ev.on(`messages.upsert`,D);let O=e=>{try{if(e.connection===`close`){let t=p.r(e.lastDisconnect?.error);f({status:t,isLoggedOut:t===g.DisconnectReason.loggedOut,error:e.lastDisconnect?.error})}}catch(e){i.error({error:String(e)},`connection.update handler error`),f({status:void 0,isLoggedOut:!1,error:e})}};return s.ev.on(`connection.update`,O),{close:async()=>{try{let e=s.ev,t=D,n=O;typeof e.off==`function`?(e.off(`messages.upsert`,t),e.off(`connection.update`,n)):typeof e.removeListener==`function`&&(e.removeListener(`messages.upsert`,t),e.removeListener(`connection.update`,n)),s.ws?.close()}catch(e){r.R(`Socket close failed: ${String(e)}`)}},onClose:d,signalClose:e=>{f(e??{status:void 0,isLoggedOut:!1,error:`closed`})},...Y({sock:{sendMessage:(e,t)=>s.sendMessage(e,t),sendPresenceUpdate:(e,t)=>s.sendPresenceUpdate(e,t)},defaultAccountId:t.accountId})}}function X(t,n){return{mentionRegexes:e.O(t,n),allowFrom:t.channels?.whatsapp?.allowFrom}}function Z(e,t){let n=t?{authDir:t}:void 0;return{normalizedMentions:e.mentionedJids?.length?e.mentionedJids.map(e=>r.m(e,n)??e).filter(Boolean):[],selfE164:e.selfE164??(e.selfJid?r.m(e.selfJid,n):null),selfJid:e.selfJid?e.selfJid.replace(/:\\d+/,``):null}}function Q(t,n,i){let a=t=>e.k(t),o=r.p(i.selfE164,n.allowFrom);if((t.mentionedJids?.length??0)>0&&!o)return!!(i.selfE164&&i.normalizedMentions.includes(i.selfE164)||i.selfJid&&i.normalizedMentions.includes(i.selfJid));let s=a(t.body);if(n.mentionRegexes.some(e=>e.test(s)))return!0;if(i.selfE164){let e=i.selfE164.replace(/\D/g,``);if(e){if(s.replace(/[^\d]/g,``).includes(e))return!0;let n=t.body.replace(/[\s-]/g,``);if(RegExp(`\\+?${e}`,`i`).test(n))return!0}}return!1}function se(t,n,r){let i=Z(t,r);return{wasMentioned:Q(t,n,i),details:{from:t.from,body:t.body,bodyClean:e.k(t.body),mentionedJids:t.mentionedJids??null,normalizedMentionedJids:i.normalizedMentions.length?i.normalizedMentions:null,selfJid:t.selfJid??null,selfJidBare:i.selfJid,selfE164:t.selfE164??null,resolvedSelfE164:i.selfE164}}}function ce(e,t){let n=e.allowFrom;return(Array.isArray(n)&&n.length>0?n:t?[t]:[]).filter(e=>!!(e&&e!==`*`)).map(e=>r.h(e)).filter(e=>!!e)}function le(e){let t=new Set,n=Math.max(1,e.maxItems??100),r=e=>`combined:${e.sessionKey}:${e.combinedBody}`,i=()=>{for(;t.size>n;){let e=t.values().next().value;if(!e)break;t.delete(e)}};return{rememberText:(n,a)=>{n&&(t.add(n),a.combinedBody&&a.combinedBodySessionKey&&t.add(r({sessionKey:a.combinedBodySessionKey,combinedBody:a.combinedBody})),a.logVerboseMessage&&e.logVerbose?.(`Added to echo detection set (size now: ${t.size}): ${n.substring(0,50)}...`),i())},has:e=>t.has(e),forget:e=>{t.delete(e)},buildCombinedKey:r}}function ue(n){let r=e.m({agentId:n.agentId,channel:`whatsapp`,accountId:n.route.accountId,peer:{kind:n.msg.chatType===`group`?`group`:`direct`,id:n.peerId},dmScope:n.cfg.session?.dmScope,identityLinks:n.cfg.session?.identityLinks}),i=t.Dt({agentId:n.agentId,mainKey:t.Et});return{sessionKey:r,mainSessionKey:i,lastRoutePolicy:e.h({sessionKey:r,mainSessionKey:i})}}async function de(e){let n=e.cfg.broadcast?.[e.peerId];if(!n||!Array.isArray(n)||n.length===0)return!1;let r=e.cfg.broadcast?.strategy||`parallel`;S.info(`Broadcasting message to ${n.length} agents (${r})`);let i=e.cfg.agents?.list?.map(e=>t.Mt(e.id)),a=(i?.length??0)>0,o=e.msg.chatType===`group`?e.groupHistories.get(e.groupHistoryKey)??[]:void 0,s=async n=>{let r=t.Mt(n);if(a&&!i?.includes(r))return S.warn(`Broadcast agent ${n} not found in agents.list; skipping`),!1;let s=ue({cfg:e.cfg,msg:e.msg,route:e.route,peerId:e.peerId,agentId:r}),c={...e.route,agentId:r,...s};try{return await e.processMessage(e.msg,c,e.groupHistoryKey,{groupHistory:o,suppressGroupHistoryClear:!0})}catch(e){return S.error(`Broadcast agent ${n} failed: ${p.n(e)}`),!1}};if(r===`sequential`)for(let e of n)await s(e);else await Promise.allSettled(n.map(s));return e.msg.chatType===`group`&&e.groupHistories.set(e.groupHistoryKey,[]),!0}function fe(e,t,n){let r=e;for(let e of t)r=r.replace(e,` `);if(n){let e=n.replace(/\D/g,``);if(e){let t=RegExp(`\\+?${e}`,`g`);r=r.replace(t,` `)}}return r.replace(/\s+/g,` `).trim()}function pe(e,t){let r=n.br({From:t,ChatType:`group`,Provider:`whatsapp`})?.id,i=e.channels?.whatsapp,a=!!(i?.groupAllowFrom?.length||i?.allowFrom?.length);return n.mr({cfg:e,channel:`whatsapp`,groupId:r??t,hasGroupAllowFrom:a})}function me(e,t){let r=n.br({From:t,ChatType:`group`,Provider:`whatsapp`})?.id;return n.hr({cfg:e,channel:`whatsapp`,groupId:r??t})}function he(r){let i=n.kt(t.s(r.cfg.session?.store,{agentId:r.agentId}))[r.sessionKey],a=me(r.cfg,r.conversationId)?`mention`:`always`;return e.i(i?.groupActivation)??a}function ge(e,t,n){for(let i of e){let e=r.h(i)??i;!e||t.has(e)||(t.add(e),n.push(e))}}function _e(e,t,n,i){if(!n||!i)return;let a=r.h(n)??n;if(!a)return;let o=e.get(t);o||(o=new Map,e.set(t,o)),o.set(a,i)}function ve(e){let{participants:t,roster:n,fallbackE164:i}=e,a=new Set,o=[];if(t?.length&&ge(t,a,o),n&&ge(n.keys(),a,o),o.length===0&&i){let e=r.h(i)??i;e&&o.push(e)}if(o.length!==0)return o.map(e=>{let t=n?.get(e);return t?`${t} (${e})`:e}).join(`, `)}function ye(e,t){let n=r.h(t.senderE164??``);return n?ce(e,t.selfE164??void 0).includes(n):!1}function be(t){let n=t.msg.senderName&&t.msg.senderE164?`${t.msg.senderName} (${t.msg.senderE164})`:t.msg.senderName??t.msg.senderE164??`Unknown`;e.p({historyMap:t.groupHistories,historyKey:t.groupHistoryKey,limit:t.groupHistoryLimit,entry:{sender:n,body:t.msg.body,timestamp:t.msg.timestamp,id:t.msg.id,senderJid:t.msg.senderJid}})}function xe(e,t){return e.logVerbose(t),be({msg:e.msg,groupHistories:e.groupHistories,groupHistoryKey:e.groupHistoryKey,groupHistoryLimit:e.groupHistoryLimit}),{shouldProcess:!1}}function Se(t){let n=pe(t.cfg,t.conversationId);if(n.allowlistEnabled&&!n.allowed)return t.logVerbose(`Skipping group message ${t.conversationId} (not in allowlist)`),{shouldProcess:!1};_e(t.groupMemberNames,t.groupHistoryKey,t.msg.senderE164,t.msg.senderName);let i=X(t.cfg,t.agentId),a=fe(t.msg.body,i.mentionRegexes,t.msg.selfE164),o=e.a(a),s=ye(t.baseMentionConfig,t.msg),c=s&&e.E(a,t.cfg);if(o.hasCommand&&!s)return xe(t,`Ignoring /activation from non-owner in group ${t.conversationId}`);let l=se(t.msg,i,t.authDir);t.replyLogger.debug({conversationId:t.conversationId,wasMentioned:l.wasMentioned,...l.details},`group mention debug`);let u=l.wasMentioned,d=he({cfg:t.cfg,agentId:t.agentId,sessionKey:t.sessionKey,conversationId:t.conversationId})!==`always`,f=t.msg.selfJid?.replace(/:\\d+/,``),p=t.msg.replyToSenderJid?.replace(/:\\d+/,``),m=t.msg.selfE164?r.h(t.msg.selfE164):null,h=t.msg.replyToSenderE164?r.h(t.msg.replyToSenderE164):null,g=e.d({requireMention:d,canDetectMention:!0,wasMentioned:u,implicitMention:!!(f&&p&&f===p||m&&h&&m===h),shouldBypassMention:c});return t.msg.wasMentioned=g.effectiveWasMentioned,!c&&d&&g.shouldSkip?xe(t,`Group message stored for context (no mention detected) in ${t.conversationId}: ${t.msg.body}`):{shouldProcess:!0}}function Ce(e,t){e.add(t),t.finally(()=>{e.delete(t)})}function we(e){let r=t.s(e.cfg.session?.store,{agentId:e.storeAgentId}),i=n.Nt({storePath:r,sessionKey:e.sessionKey,deliveryContext:{channel:e.channel,to:e.to,accountId:e.accountId},ctx:e.ctx}).catch(t=>{e.warn({error:p.n(t),storePath:r,sessionKey:e.sessionKey,to:e.to},`failed updating last route`)});Ce(e.backgroundTasks,i)}function Te(e){return e.chatType===`group`?e.conversationId??e.from:e.senderE164?r.h(e.senderE164)??e.senderE164:e.from.includes(`@`)?r.m(e.from)??e.from:r.h(e.from)??e.from}function $(e,t=400){return!e||e.length<=t?e:`${e.slice(0,t)}… (truncated ${e.length-t} chars)`}function Ee(e){let t=(e instanceof Error?`${e.message}\n${e.stack??``}`:(e=>{if(e==null)return``;if(typeof e==`string`)return e;if(e instanceof Error)return`${e.message}\n${e.stack??``}`;if(typeof e==`object`)try{return JSON.stringify(e)}catch{return Object.prototype.toString.call(e)}return typeof e==`number`||typeof e==`boolean`||typeof e==`bigint`?String(e):typeof e==`symbol`?e.description??e.toString():typeof e==`function`?e.name?`[function ${e.name}]`:`[function]`:Object.prototype.toString.call(e)})(e)).toLowerCase();return t.includes(`unsupported state or unable to authenticate data`)||t.includes(`bad mac`)?t.includes(`@whiskeysockets/baileys`)||t.includes(`baileys`)||t.includes(`noise-handler`)||t.includes(`aesdecryptgcm`):!1}function De(e){if(e.isReasoning===!0)return!0;let t=e.text;return typeof t==`string`?t.trimStart().toLowerCase().startsWith(`reasoning:`):!1}async function Oe(e){let{replyResult:t,msg:n,maxMediaBytes:i,textLimit:a,replyLogger:o,connectionId:s,skipLog:l}=e,d=Date.now();if(De(t)){C.debug(`Suppressed reasoning payload to ${n.from}`);return}let m=e.tableMode??`code`,h=e.chunkMode??`length`,g=c.d(f.i(u.t(t.text||``,m)),a,h),_=t.mediaUrls?.length?t.mediaUrls:t.mediaUrl?[t.mediaUrl]:[],v=async(e,t,i=3)=>{let a;for(let o=1;o<=i;o++)try{return await e()}catch(e){a=e;let s=p.n(e),c=o===i;if(!/closed|reset|timed\s*out|disconnect/i.test(s)||c)throw e;let l=500*o;r.R(`Retrying ${t} to ${n.from} after failure (${o}/${i-1}) in ${l}ms: ${s}`),await r.C(l)}throw a};if(_.length===0&&g.length){let e=g.length;for(let[t,r]of g.entries()){let i=Date.now();if(await v(()=>n.reply(r),`text`),!l){let r=Date.now()-i;C.debug(`Sent chunk ${t+1}/${e} to ${n.from} (${r.toFixed(0)}ms)`)}}o.info({correlationId:n.id??b(),connectionId:s??null,to:n.from,from:n.to,text:$(t.text,240),mediaUrl:null,mediaSizeBytes:null,mediaKind:null,durationMs:Date.now()-d},`auto-reply sent (text)`);return}let y=[...g];for(let[t,a]of _.entries()){let l=t===0&&y.shift()||void 0;try{let t=await c.a(a,{maxBytes:i,localRoots:e.mediaLocalRoots});if(r.B()&&(r.R(`Web auto-reply media size: ${(t.buffer.length/(1024*1024)).toFixed(2)}MB`),r.R(`Web auto-reply media source: ${a} (kind ${t.kind})`)),t.kind===`image`)await v(()=>n.sendMedia({image:t.buffer,caption:l,mimetype:t.contentType}),`media:image`);else if(t.kind===`audio`)await v(()=>n.sendMedia({audio:t.buffer,ptt:!0,mimetype:t.contentType,caption:l}),`media:audio`);else if(t.kind===`video`)await v(()=>n.sendMedia({video:t.buffer,caption:l,mimetype:t.contentType}),`media:video`);else{let e=t.fileName??a.split(`/`).pop()??`file`,r=t.contentType??`application/octet-stream`;await v(()=>n.sendMedia({document:t.buffer,fileName:e,caption:l,mimetype:r}),`media:document`)}C.info(`Sent media reply to ${n.from} (${(t.buffer.length/(1024*1024)).toFixed(2)}MB)`),o.info({correlationId:n.id??b(),connectionId:s??null,to:n.from,from:n.to,text:l??null,mediaUrl:a,mediaSizeBytes:t.buffer.length,mediaKind:t.kind,durationMs:Date.now()-d},`auto-reply sent (media)`)}catch(e){if(C.error(`Failed sending web media to ${n.from}: ${p.n(e)}`),o.warn({err:e,mediaUrl:a},`failed to send web media reply`),t===0){let t=e instanceof Error?`⚠️ Media failed: ${e.message}`:`⚠️ Media failed.`,r=[y.shift()??l??``,t].filter(Boolean).join(`
|
|
@@ -1 +1 @@
|
|
|
1
|
-
require(`./paths-Bcdg3ma0.cjs`),require(`./paths-a2-BgYPx.cjs`);const e=require(`./sessions-77BHuN_z.cjs`);require(`./logger-ElHF9OXJ.cjs`),require(`./proxy-env-BpF7ozPI.cjs`),require(`./send-BPDJGZuq.cjs`),require(`./common-DTxiFDAg.cjs`),require(`./send-Bk7yZh8L.cjs`),require(`./reply-
|
|
1
|
+
require(`./paths-Bcdg3ma0.cjs`),require(`./paths-a2-BgYPx.cjs`);const e=require(`./sessions-77BHuN_z.cjs`);require(`./logger-ElHF9OXJ.cjs`),require(`./proxy-env-BpF7ozPI.cjs`),require(`./send-BPDJGZuq.cjs`),require(`./common-DTxiFDAg.cjs`),require(`./send-Bk7yZh8L.cjs`),require(`./reply-DYTWptyW.cjs`),require(`./github-copilot-token-zskwAEpd.cjs`),require(`./send-Cji3KNtH.cjs`);const t=require(`./channel-web-yRiw9cOW.cjs`);require(`./tokens-w1Vwi8T0.cjs`),require(`./audio-transcription-runner-BQusD24E.cjs`),require(`./image-BlxKldFU.cjs`),require(`./fetch-guard-BSd97H59.cjs`),require(`./api-key-rotation-D1EASR2C.cjs`),require(`./local-roots-ClO-jEE-.cjs`),require(`./proxy-fetch-DAxwIT4d.cjs`),require(`./deliver-Dt64a7MG.cjs`),require(`./commands-registry-B2OMCa8u.cjs`),require(`./fetch-ClKErpni.cjs`),require(`./diagnostic-BYg6zAO_.cjs`),require(`./pi-model-discovery-Dqn45cDV.cjs`),require(`./ir-BjDvydb1.cjs`),require(`./render-6fCdtAr6.cjs`),require(`./send-D3KRnIve.cjs`),require(`./outbound-attachment-C4gxHQAf.cjs`),require(`./send-sXGGll-X.cjs`),require(`./channel-activity-DrA6mjVY.cjs`),require(`./tables-Bo5Ugtcv.cjs`),require(`./fetch-CJFjj_U8.cjs`),require(`./skill-commands-gpYFtY4f.cjs`),require(`./query-expansion-pY6WNc95.cjs`),require(`./manager-Dvt9ZJZE.cjs`);const n=require(`./outbound-DrkuMmNh.cjs`),r=require(`./session-DCvvlJpT.cjs`),i=require(`./login-l9yC1t5_.cjs`);exports.WA_WEB_AUTH_DIR=e.js,exports.createWaSocket=r.t,exports.logWebSelfId=e.Ns,exports.loginWeb=i.t,exports.monitorWebChannel=t.t,exports.monitorWebInbox=t.n,exports.pickWebChannel=e.Is,exports.sendMessageWhatsApp=n.t,exports.waitForWaConnection=r.i,exports.webAuthExists=e.Hs;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{gt as e,ht as t,s as n,vt as r,xt as i}from"./paths-C_0oH85Z.js";import{B as a,K as o,M as s,O as c,R as l,d as u,l as d,m as f,n as p,u as m,x as h,y as g}from"./utils-BW1LBoG1.js";import"./paths-rO4ehkyU.js";import{Ct as _,Dt as v,Fs as y,Hs as b,Is as x,Jn as S,Js as C,Ls as w,Or as T,Rs as ee,Tt as E,Un as D,Wi as O,Wn as k,Ws as A,tc as te,zs as j}from"./model-auth-PTbwmgfS.js";import"./target-errors-CzGTUq1O.js";import{A as M,B as ne,C as N,D as P,E as re,G as F,K as I,O as ie,S as ae,T as L,U as oe,V as se,W as R,X as ce,Y as z,Z as B,_ as V,b as le,d as ue,f as H,g as U,h as W,j as G,k as de,l as fe,m as pe,o as me,p as he,q as ge,r as _e,s as ve,u as ye,v as be,x as xe,y as Se}from"./dispatch-
|
|
1
|
+
import{gt as e,ht as t,s as n,vt as r,xt as i}from"./paths-C_0oH85Z.js";import{B as a,K as o,M as s,O as c,R as l,d as u,l as d,m as f,n as p,u as m,x as h,y as g}from"./utils-BW1LBoG1.js";import"./paths-rO4ehkyU.js";import{Ct as _,Dt as v,Fs as y,Hs as b,Is as x,Jn as S,Js as C,Ls as w,Or as T,Rs as ee,Tt as E,Un as D,Wi as O,Wn as k,Ws as A,tc as te,zs as j}from"./model-auth-PTbwmgfS.js";import"./target-errors-CzGTUq1O.js";import{A as M,B as ne,C as N,D as P,E as re,G as F,K as I,O as ie,S as ae,T as L,U as oe,V as se,W as R,X as ce,Y as z,Z as B,_ as V,b as le,d as ue,f as H,g as U,h as W,j as G,k as de,l as fe,m as pe,o as me,p as he,q as ge,r as _e,s as ve,u as ye,v as be,x as xe,y as Se}from"./dispatch-BYn5wxRI.js";import{$ as Ce,ct as we,lt as Te}from"./send-CzPxLKCS.js";import{Mt as Ee,Nt as De,Pt as Oe}from"./send-DU7yHCHx.js";import"./proxy-env-BJiTOL-g.js";import"./github-copilot-token-C8j8_NjX.js";import"./send-DrMiQBv_.js";import"./fetch-guard-tTXC2Y_c.js";import"./deliver-BK9ASxJW.js";import"./diagnostic-Bp5jX3d1.js";import"./pi-model-discovery-BGE30_kL.js";import{f as ke}from"./audio-transcription-runner-ujTxMm2N.js";import"./image-BTJgRuqS.js";import"./api-key-rotation-CXDviKQP.js";import{t as Ae}from"./local-roots-CpwtqAFh.js";import"./proxy-fetch-CZ1T6Erg.js";import"./tokens-BavWLeEy.js";import"./commands-registry-lbwx32D8.js";import"./fetch-B1GR6-u4.js";import{a as je,d as Me,h as Ne,m as Pe,s as Fe}from"./ir-uXI9wc5i.js";import"./render-Djx15dPh.js";import{n as Ie}from"./channel-activity-BhvPPvdj.js";import{t as Le}from"./tables-C8K6_6wb.js";import"./send-BBkJ-bu7.js";import"./fetch-BQvnpacB.js";import"./skill-commands-mBvWW-DG.js";import"./outbound-attachment-DuO8PoGV.js";import"./send-k2Q2Guzr.js";import{r as Re}from"./active-listener-C3fkMQod.js";import"./query-expansion-BDk08tp9.js";import"./manager-sFATQA_t.js";import{i as ze,r as Be,t as Ve}from"./outbound-CTuOBGBJ.js";import{i as He,n as K,r as Ue,t as We}from"./session-D_IBtk0u.js";import{t as Ge}from"./login-C4HEroqx.js";import{randomUUID as Ke}from"node:crypto";import{DisconnectReason as qe,downloadMediaMessage as Je,extractMessageContent as Ye,getContentType as Xe,isJidGroup as Ze,normalizeMessageContent as q}from"@whiskeysockets/baileys";const Qe={initialMs:2e3,maxMs:3e4,factor:1.8,jitter:.25,maxAttempts:12};function $e(e,t){let n=t??e.web?.heartbeatSeconds;return typeof n==`number`&&n>0?n:60}function et(e,t){let n=e.web?.reconnect??{},r=t??{},i={...Qe,...n,...r};return i.initialMs=Math.max(250,i.initialMs),i.maxMs=Math.max(i.initialMs,i.maxMs),i.factor=p(i.factor,1.1,10),i.jitter=p(i.jitter,0,1),i.maxAttempts=Math.max(0,Math.floor(i.maxAttempts)),i}function J(){return Ke()}const Y=c(`gateway/channels/whatsapp`),X=Y.child(`inbound`),Z=Y.child(`outbound`),tt=Y.child(`heartbeat`);function nt(){return setInterval(()=>{},1e6).unref(),new Promise(()=>{})}const rt=ne({ttlMs:20*6e4,maxSize:5e3});function it(e){return rt.check(e)}const at=new Set([`FN`,`N`,`TEL`]);function ot(e){if(!e)return{phones:[]};let t=e.split(/\r?\n/),n,r,i=[];for(let e of t){let t=e.trim();if(!t)continue;let a=t.indexOf(`:`);if(a===-1)continue;let o=t.slice(0,a).toUpperCase(),s=t.slice(a+1).trim();if(!s)continue;let c=st(o);if(!c||!at.has(c))continue;let l=ct(s);if(l){if(c===`FN`&&!r){r=lt(l);continue}if(c===`N`&&!n){n=lt(l);continue}if(c===`TEL`){let e=ut(l);e&&i.push(e)}}}return{name:r??n,phones:i}}function st(e){let[t]=e.split(`;`);if(!t)return;let n=t.split(`.`);return n[n.length-1]||void 0}function ct(e){return e.replace(/\\n/gi,` `).replace(/\\,/g,`,`).replace(/\\;/g,`;`).trim()}function lt(e){return e.replace(/;/g,` `).replace(/\s+/g,` `).trim()}function ut(e){let t=e.trim();return t?t.toLowerCase().startsWith(`tel:`)?t.slice(4).trim():t:``}function Q(e){return q(e)}function dt(e){if(!e)return;let t=Xe(e),n=t?e[t]:void 0,r=n&&typeof n==`object`&&`contextInfo`in n?n.contextInfo:void 0;if(r)return r;let i=e.extendedTextMessage?.contextInfo??e.imageMessage?.contextInfo??e.videoMessage?.contextInfo??e.documentMessage?.contextInfo??e.audioMessage?.contextInfo??e.stickerMessage?.contextInfo??e.buttonsResponseMessage?.contextInfo??e.listResponseMessage?.contextInfo??e.templateButtonReplyMessage?.contextInfo??e.interactiveResponseMessage?.contextInfo??e.buttonsMessage?.contextInfo??e.listMessage?.contextInfo;if(i)return i;for(let t of Object.values(e)){if(!t||typeof t!=`object`||!(`contextInfo`in t))continue;let e=t.contextInfo;if(e)return e}}function ft(e){let t=Q(e);if(!t)return;let n=[t.extendedTextMessage?.contextInfo?.mentionedJid,t.extendedTextMessage?.contextInfo?.quotedMessage?.extendedTextMessage?.contextInfo?.mentionedJid,t.imageMessage?.contextInfo?.mentionedJid,t.videoMessage?.contextInfo?.mentionedJid,t.documentMessage?.contextInfo?.mentionedJid,t.audioMessage?.contextInfo?.mentionedJid,t.stickerMessage?.contextInfo?.mentionedJid,t.buttonsResponseMessage?.contextInfo?.mentionedJid,t.listResponseMessage?.contextInfo?.mentionedJid].flatMap(e=>e??[]).filter(Boolean);if(n.length!==0)return Array.from(new Set(n))}function pt(e){let t=Q(e);if(!t)return;let n=Ye(t),r=[t,n&&n!==t?n:void 0];for(let e of r){if(!e)continue;if(typeof e.conversation==`string`&&e.conversation.trim())return e.conversation.trim();let t=e.extendedTextMessage?.text;if(t?.trim())return t.trim();let n=e.imageMessage?.caption??e.videoMessage?.caption??e.documentMessage?.caption;if(n?.trim())return n.trim()}let i=ht(t)??(n&&n!==t?ht(n):void 0);if(i)return i}function mt(e){let t=Q(e);if(t){if(t.imageMessage)return`<media:image>`;if(t.videoMessage)return`<media:video>`;if(t.audioMessage)return`<media:audio>`;if(t.documentMessage)return`<media:document>`;if(t.stickerMessage)return`<media:sticker>`}}function ht(e){let t=Q(e);if(!t)return;let n=t.contactMessage??void 0;if(n){let{name:e,phones:t}=gt({displayName:n.displayName,vcard:n.vcard});return _t(e,t)}let r=t.contactsArrayMessage?.contacts??void 0;if(!(!r||r.length===0))return vt(r.map(e=>gt({displayName:e.displayName,vcard:e.vcard})).map(e=>yt(e.name,e.phones)).filter(e=>!!e),r.length)}function gt(e){let t=(e.displayName??``).trim(),n=ot(e.vcard??void 0);return{name:t||n.name,phones:n.phones}}function _t(e,t){let n=yt(e,t);return n?`<contact: ${n}>`:`<contact>`}function vt(e,t){let n=e.map(e=>e.trim()).filter(Boolean);if(n.length===0)return`<contacts: ${t} ${t===1?`contact`:`contacts`}>`;let r=Math.max(t-n.length,0),i=r>0?` +${r} more`:``;return`<contacts: ${n.join(`, `)}${i}>`}function yt(e,t){let n=[e,bt(t)].filter(e=>!!e);if(n.length!==0)return n.join(`, `)}function bt(e){let t=e?.map(e=>e.trim()).filter(Boolean)??[];if(t.length===0)return;let{shown:n,remaining:r}=xt(t,t.length,1),[i]=n;if(i)return r===0?i:`${i} (+${r} more)`}function xt(e,t,n){let r=e.slice(0,n);return{shown:r,remaining:Math.max(t-r.length,0)}}function St(e){let t=Q(e);if(!t)return null;let n=t.liveLocationMessage??void 0;if(n){let e=n.degreesLatitude,t=n.degreesLongitude;if(e!=null&&t!=null){let r=Number(e),i=Number(t);if(Number.isFinite(r)&&Number.isFinite(i))return{latitude:r,longitude:i,accuracy:n.accuracyInMeters??void 0,caption:n.caption??void 0,source:`live`,isLive:!0}}}let r=t.locationMessage??void 0;if(r){let e=r.degreesLatitude,t=r.degreesLongitude;if(e!=null&&t!=null){let n=Number(e),i=Number(t);if(Number.isFinite(n)&&Number.isFinite(i)){let e=!!r.isLive;return{latitude:n,longitude:i,accuracy:r.accuracyInMeters??void 0,name:r.name??void 0,address:r.address??void 0,caption:r.comment??void 0,source:e?`live`:r.name||r.address?`place`:`pin`,isLive:e}}}}return null}function Ct(e){let t=Q(e);if(!t)return null;let n=dt(t),r=q(n?.quotedMessage);if(!r)return null;let i=St(r),a=i?we(i):void 0,o=[pt(r),a].filter(Boolean).join(`
|
|
2
2
|
`).trim();if(o||=mt(r),!o){let e=r?Xe(r):void 0;return l(`Quoted message missing extractable body${e?` (type ${e})`:``}`),null}let s=n?.participant??void 0,c=s?m(s)??s:void 0,u=c??`unknown sender`;return{id:n?.stanzaId?String(n.stanzaId):void 0,body:o,sender:u,senderJid:s,senderE164:c}}function wt(e){return De({providerConfigPresent:e.providerConfigPresent,groupPolicy:e.groupPolicy,defaultGroupPolicy:e.defaultGroupPolicy})}async function Tt(e){let t=O(),n=y({cfg:t,accountId:e.accountId}),r=n.dmPolicy??`pairing`,i=n.allowFrom??[],a=await oe({provider:`whatsapp`,accountId:n.accountId,dmPolicy:r}),o=i.length===0&&e.selfE164?[e.selfE164]:[],s=i.length>0?i:o,c=n.groupAllowFrom??(i.length>0?i:void 0),f=e.from===e.selfE164,p=n.selfChatMode??d(e.selfE164,i),m=typeof e.pairingGraceMs==`number`&&e.pairingGraceMs>0?e.pairingGraceMs:3e4,h=typeof e.connectedAtMs==`number`&&typeof e.messageTimestampMs==`number`&&e.messageTimestampMs<e.connectedAtMs-m,g=Ee(t),{groupPolicy:_,providerMissingFallbackApplied:v}=wt({providerConfigPresent:t.channels?.whatsapp!==void 0,groupPolicy:n.groupPolicy,defaultGroupPolicy:g});Oe({providerMissingFallbackApplied:v,providerKey:`whatsapp`,accountId:n.accountId,log:e=>l(e)});let b=u(e.from),x=typeof e.senderE164==`string`?u(e.senderE164):null,S=F({isGroup:e.group,dmPolicy:r,groupPolicy:_,allowFrom:e.group?i:s,groupAllowFrom:c,storeAllowFrom:a,isSenderAllowed:t=>{if(t.includes(`*`))return!0;let n=new Set(t.map(e=>u(String(e))).filter(e=>!!e));return!e.group&&f?!0:e.group?!!(x&&n.has(x)):n.has(b)}});if(e.group&&S.decision!==`allow`)return S.reason===`groupPolicy=disabled`?l(`Blocked group message (groupPolicy: disabled)`):S.reason===`groupPolicy=allowlist (empty allowlist)`?l(`Blocked group message (groupPolicy: allowlist, no groupAllowFrom)`):l(`Blocked group message from ${e.senderE164??`unknown sender`} (groupPolicy: allowlist)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:p,resolvedAccountId:n.accountId};if(!e.group){if(e.isFromMe&&!f)return l(`Skipping outbound DM (fromMe); no pairing reply needed.`),{allowed:!1,shouldMarkRead:!1,isSelfChat:p,resolvedAccountId:n.accountId};if(S.decision===`block`&&S.reason===`dmPolicy=disabled`)return l(`Blocked dm (dmPolicy: disabled)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:p,resolvedAccountId:n.accountId};if(S.decision===`pairing`&&!f){let t=e.from;return h?l(`Skipping pairing reply for historical DM from ${t}.`):await ge({channel:`whatsapp`,senderId:t,senderIdLine:`Your WhatsApp phone number: ${t}`,meta:{name:(e.pushName??``).trim()||void 0},upsertPairingRequest:async({id:e,meta:t})=>await Ce({channel:`whatsapp`,id:e,accountId:n.accountId,meta:t}),onCreated:()=>{l(`whatsapp pairing request sender=${t} name=${e.pushName??`unknown`}`)},sendPairingReply:async t=>{await e.sock.sendMessage(e.remoteJid,{text:t})},onReplyError:e=>{l(`whatsapp pairing reply failed for ${t}: ${String(e)}`)}}),{allowed:!1,shouldMarkRead:!1,isSelfChat:p,resolvedAccountId:n.accountId}}if(S.decision!==`allow`)return l(`Blocked unauthorized sender ${e.from} (dmPolicy=${r})`),{allowed:!1,shouldMarkRead:!1,isSelfChat:p,resolvedAccountId:n.accountId}}return{allowed:!0,shouldMarkRead:!0,isSelfChat:p,resolvedAccountId:n.accountId}}function Et(e){return q(e)}function Dt(e){let t=e.imageMessage?.mimetype??e.videoMessage?.mimetype??e.documentMessage?.mimetype??e.audioMessage?.mimetype??e.stickerMessage?.mimetype??void 0;if(t)return t;if(e.audioMessage)return`audio/ogg; codecs=opus`;if(e.imageMessage)return`image/jpeg`;if(e.videoMessage)return`video/mp4`;if(e.stickerMessage)return`image/webp`}async function Ot(e,t){let n=Et(e.message);if(!n)return;let r=Dt(n),i=n.documentMessage?.fileName??void 0;if(!(!n.imageMessage&&!n.videoMessage&&!n.documentMessage&&!n.audioMessage&&!n.stickerMessage))try{return{buffer:await Je(e,`buffer`,{},{reuploadRequest:t.updateMediaMessage,logger:t.logger}),mimetype:r,fileName:i}}catch(e){l(`downloadMediaMessage failed: ${String(e)}`);return}}function kt(e){Ie({channel:`whatsapp`,accountId:e,direction:`outbound`})}function At(e){return typeof e==`object`&&e&&`key`in e?String(e.key?.id??`unknown`):`unknown`}function jt(e){return{sendMessage:async(t,n,r,i,a)=>{let o=h(t),s;if(r&&i)if(i.startsWith(`image/`))s={image:r,caption:n||void 0,mimetype:i};else if(i.startsWith(`audio/`))s={audio:r,ptt:!0,mimetype:i};else if(i.startsWith(`video/`)){let e=a?.gifPlayback;s={video:r,caption:n||void 0,mimetype:i,...e?{gifPlayback:!0}:{}}}else s={document:r,fileName:a?.fileName?.trim()||`file`,caption:n||void 0,mimetype:i};else s={text:n};let c=await e.sock.sendMessage(o,s);return kt(a?.accountId??e.defaultAccountId),{messageId:At(c)}},sendPoll:async(t,n)=>{let r=h(t),i=await e.sock.sendMessage(r,{poll:{name:n.question,values:n.options,selectableCount:n.maxSelections??1}});return kt(e.defaultAccountId),{messageId:At(i)}},sendReaction:async(t,n,r,i,a)=>{let o=h(t);await e.sock.sendMessage(o,{react:{text:r,key:{remoteJid:o,id:n,fromMe:i,participant:a?h(a):void 0}}})},sendComposingTo:async t=>{let n=h(t);await e.sock.sendPresenceUpdate(`composing`,n)}}}async function Mt(e){let t=o({module:`web-inbound`}),n=c(`gateway/channels/whatsapp`).child(`inbound`),r=await We(!1,e.verbose,{authDir:e.authDir});await He(r);let i=Date.now(),s=null,u=new Promise(e=>{s=e}),d=e=>{if(!s)return;let t=s;s=null,t(e)};try{await r.sendPresenceUpdate(`available`),a()&&l(`Sent global 'available' presence on connect`)}catch(e){l(`Failed to send 'available' presence on connect: ${String(e)}`)}let p=r.user?.id,h=p?m(p):null,g=L({debounceMs:e.debounceMs??0,buildKey:e=>{let t=e.chatType===`group`?e.senderJid??e.senderE164??e.senderName??e.from:e.from;if(!t)return null;let n=e.chatType===`group`?e.chatId:e.from;return`${e.accountId}:${n}:${t}`},shouldDebounce:e.shouldDebounce,onFlush:async t=>{let n=t.at(-1);if(!n)return;if(t.length===1){await e.onMessage(n);return}let r=new Set;for(let e of t)for(let t of e.mentionedJids??[])r.add(t);let i=t.map(e=>e.body).filter(Boolean).join(`
|
|
3
3
|
`),a={...n,body:i,mentionedJids:r.size>0?Array.from(r):void 0};await e.onMessage(a)},onError:e=>{t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)}}),_=new Map,v=300*1e3,y=r.signalRepository?.lidMapping,b=async t=>f(t,{authDir:e.authDir,lidLookup:y}),x=async e=>{let t=_.get(e);if(t&&t.expires>Date.now())return t;try{let t=await r.groupMetadata(e),n=(await Promise.all(t.participants?.map(async e=>await b(e.id)??e.id)??[])).filter(Boolean)??[],i={subject:t.subject,participants:n,expires:Date.now()+v};return _.set(e,i),i}catch(t){return l(`Failed to fetch group metadata for ${e}: ${String(t)}`),{expires:Date.now()+v}}},S=async t=>{let n=t.key?.id??void 0,a=t.key?.remoteJid;if(!a||a.endsWith(`@status`)||a.endsWith(`@broadcast`))return null;let o=Ze(a)===!0;if(n&&it(`${e.accountId}:${a}:${n}`))return null;let s=t.key?.participant??void 0,c=o?a:await b(a);if(!c)return null;let l=o?s?await b(s):null:c,u,d;if(o){let e=await x(a);u=e.subject,d=e.participants}let f=t.messageTimestamp?Number(t.messageTimestamp)*1e3:void 0,p=await Tt({accountId:e.accountId,from:c,selfE164:h,senderE164:l,group:o,pushName:t.pushName??void 0,isFromMe:!!t.key?.fromMe,messageTimestampMs:f,connectedAtMs:i,sock:{sendMessage:(e,t)=>r.sendMessage(e,t)},remoteJid:a});return p.allowed?{id:n,remoteJid:a,group:o,participantJid:s,from:c,senderE164:l,groupSubject:u,groupParticipants:d,messageTimestampMs:f,access:p}:null},C=async t=>{let{id:n,remoteJid:i,participantJid:o,access:s}=t;if(n&&!s.isSelfChat&&e.sendReadReceipts!==!1)try{await r.readMessages([{remoteJid:i,id:n,participant:o,fromMe:!1}]),a()&&l(`Marked message ${n} as read for ${i}${o?` (participant ${o})`:``}`)}catch(e){l(`Failed to mark message ${n} read: ${String(e)}`)}else n&&s.isSelfChat&&a()&&l(`Self-chat mode: skipping read receipt for ${n}`)},w=async t=>{let n=St(t.message??void 0),i=n?we(n):void 0,a=pt(t.message??void 0);if(i&&(a=[a,i].filter(Boolean).join(`
|
|
4
4
|
`).trim()),!a&&(a=mt(t.message??void 0),!a))return null;let o=Ct(t.message),s,c,u;try{let n=await Ot(t,r);if(n){let t=(typeof e.mediaMaxMb==`number`&&e.mediaMaxMb>0?e.mediaMaxMb:50)*1024*1024;s=(await T(n.buffer,n.mimetype,`inbound`,t,n.fileName)).path,c=n.mimetype,u=n.fileName}}catch(e){l(`Inbound media download failed: ${String(e)}`)}return{body:a,location:n??void 0,replyContext:o,mediaPath:s,mediaType:c,mediaFileName:u}},ee=async(e,i,a)=>{let o=i.remoteJid,s=async()=>{try{await r.sendPresenceUpdate(`composing`,o)}catch(e){l(`Presence update failed: ${String(e)}`)}},c=async e=>{await r.sendMessage(o,{text:e})},u=async e=>{await r.sendMessage(o,e)},d=i.messageTimestampMs,f=ft(e.message),m=e.pushName??void 0;t.info({from:i.from,to:h??`me`,body:a.body,mediaPath:a.mediaPath,mediaType:a.mediaType,mediaFileName:a.mediaFileName,timestamp:d},`inbound message`);let _={id:i.id,from:i.from,conversationId:i.from,to:h??`me`,accountId:i.access.resolvedAccountId,body:a.body,pushName:m,timestamp:d,chatType:i.group?`group`:`direct`,chatId:i.remoteJid,senderJid:i.participantJid,senderE164:i.senderE164??void 0,senderName:m,replyToId:a.replyContext?.id,replyToBody:a.replyContext?.body,replyToSender:a.replyContext?.sender,replyToSenderJid:a.replyContext?.senderJid,replyToSenderE164:a.replyContext?.senderE164,groupSubject:i.groupSubject,groupParticipants:i.groupParticipants,mentionedJids:f??void 0,selfJid:p,selfE164:h,fromMe:!!e.key?.fromMe,location:a.location??void 0,sendComposing:s,reply:c,sendMedia:u,mediaPath:a.mediaPath,mediaType:a.mediaType,mediaFileName:a.mediaFileName};try{Promise.resolve(g.enqueue(_)).catch(e=>{t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)})}catch(e){t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)}},E=async t=>{if(!(t.type!==`notify`&&t.type!==`append`))for(let n of t.messages??[]){Ie({channel:`whatsapp`,accountId:e.accountId,direction:`inbound`});let r=await S(n);if(!r||(await C(r),t.type===`append`))continue;let i=await w(n);i&&await ee(n,r,i)}};r.ev.on(`messages.upsert`,E);let D=e=>{try{if(e.connection===`close`){let t=Ue(e.lastDisconnect?.error);d({status:t,isLoggedOut:t===qe.loggedOut,error:e.lastDisconnect?.error})}}catch(e){t.error({error:String(e)},`connection.update handler error`),d({status:void 0,isLoggedOut:!1,error:e})}};return r.ev.on(`connection.update`,D),{close:async()=>{try{let e=r.ev,t=E,n=D;typeof e.off==`function`?(e.off(`messages.upsert`,t),e.off(`connection.update`,n)):typeof e.removeListener==`function`&&(e.removeListener(`messages.upsert`,t),e.removeListener(`connection.update`,n)),r.ws?.close()}catch(e){l(`Socket close failed: ${String(e)}`)}},onClose:u,signalClose:e=>{d(e??{status:void 0,isLoggedOut:!1,error:`closed`})},...jt({sock:{sendMessage:(e,t)=>r.sendMessage(e,t),sendPresenceUpdate:(e,t)=>r.sendPresenceUpdate(e,t)},defaultAccountId:e.accountId})}}function Nt(e,t){return{mentionRegexes:M(e,t),allowFrom:e.channels?.whatsapp?.allowFrom}}function Pt(e,t){let n=t?{authDir:t}:void 0;return{normalizedMentions:e.mentionedJids?.length?e.mentionedJids.map(e=>m(e,n)??e).filter(Boolean):[],selfE164:e.selfE164??(e.selfJid?m(e.selfJid,n):null),selfJid:e.selfJid?e.selfJid.replace(/:\\d+/,``):null}}function Ft(e,t,n){let r=e=>G(e),i=d(n.selfE164,t.allowFrom);if((e.mentionedJids?.length??0)>0&&!i)return!!(n.selfE164&&n.normalizedMentions.includes(n.selfE164)||n.selfJid&&n.normalizedMentions.includes(n.selfJid));let a=r(e.body);if(t.mentionRegexes.some(e=>e.test(a)))return!0;if(n.selfE164){let t=n.selfE164.replace(/\D/g,``);if(t){if(a.replace(/[^\d]/g,``).includes(t))return!0;let n=e.body.replace(/[\s-]/g,``);if(RegExp(`\\+?${t}`,`i`).test(n))return!0}}return!1}function It(e,t,n){let r=Pt(e,n);return{wasMentioned:Ft(e,t,r),details:{from:e.from,body:e.body,bodyClean:G(e.body),mentionedJids:e.mentionedJids??null,normalizedMentionedJids:r.normalizedMentions.length?r.normalizedMentions:null,selfJid:e.selfJid??null,selfJidBare:r.selfJid,selfE164:e.selfE164??null,resolvedSelfE164:r.selfE164}}}function Lt(e,t){let n=e.allowFrom;return(Array.isArray(n)&&n.length>0?n:t?[t]:[]).filter(e=>!!(e&&e!==`*`)).map(e=>u(e)).filter(e=>!!e)}function Rt(e){let t=new Set,n=Math.max(1,e.maxItems??100),r=e=>`combined:${e.sessionKey}:${e.combinedBody}`,i=()=>{for(;t.size>n;){let e=t.values().next().value;if(!e)break;t.delete(e)}};return{rememberText:(n,a)=>{n&&(t.add(n),a.combinedBody&&a.combinedBodySessionKey&&t.add(r({sessionKey:a.combinedBodySessionKey,combinedBody:a.combinedBody})),a.logVerboseMessage&&e.logVerbose?.(`Added to echo detection set (size now: ${t.size}): ${n.substring(0,50)}...`),i())},has:e=>t.has(e),forget:e=>{t.delete(e)},buildCombinedKey:r}}function zt(n){let r=U({agentId:n.agentId,channel:`whatsapp`,accountId:n.route.accountId,peer:{kind:n.msg.chatType===`group`?`group`:`direct`,id:n.peerId},dmScope:n.cfg.session?.dmScope,identityLinks:n.cfg.session?.identityLinks}),i=e({agentId:n.agentId,mainKey:t});return{sessionKey:r,mainSessionKey:i,lastRoutePolicy:V({sessionKey:r,mainSessionKey:i})}}async function Bt(e){let t=e.cfg.broadcast?.[e.peerId];if(!t||!Array.isArray(t)||t.length===0)return!1;let n=e.cfg.broadcast?.strategy||`parallel`;X.info(`Broadcasting message to ${t.length} agents (${n})`);let r=e.cfg.agents?.list?.map(e=>i(e.id)),a=(r?.length??0)>0,o=e.msg.chatType===`group`?e.groupHistories.get(e.groupHistoryKey)??[]:void 0,s=async t=>{let n=i(t);if(a&&!r?.includes(n))return X.warn(`Broadcast agent ${t} not found in agents.list; skipping`),!1;let s=zt({cfg:e.cfg,msg:e.msg,route:e.route,peerId:e.peerId,agentId:n}),c={...e.route,agentId:n,...s};try{return await e.processMessage(e.msg,c,e.groupHistoryKey,{groupHistory:o,suppressGroupHistoryClear:!0})}catch(e){return X.error(`Broadcast agent ${t} failed: ${K(e)}`),!1}};if(n===`sequential`)for(let e of t)await s(e);else await Promise.allSettled(t.map(s));return e.msg.chatType===`group`&&e.groupHistories.set(e.groupHistoryKey,[]),!0}function Vt(e,t,n){let r=e;for(let e of t)r=r.replace(e,` `);if(n){let e=n.replace(/\D/g,``);if(e){let t=RegExp(`\\+?${e}`,`g`);r=r.replace(t,` `)}}return r.replace(/\s+/g,` `).trim()}function Ht(e,t){let n=S({From:t,ChatType:`group`,Provider:`whatsapp`})?.id,r=e.channels?.whatsapp,i=!!(r?.groupAllowFrom?.length||r?.allowFrom?.length);return D({cfg:e,channel:`whatsapp`,groupId:n??t,hasGroupAllowFrom:i})}function Ut(e,t){let n=S({From:t,ChatType:`group`,Provider:`whatsapp`})?.id;return k({cfg:e,channel:`whatsapp`,groupId:n??t})}function Wt(e){let t=_(n(e.cfg.session?.store,{agentId:e.agentId}))[e.sessionKey],r=Ut(e.cfg,e.conversationId)?`mention`:`always`;return me(t?.groupActivation)??r}function Gt(e,t,n){for(let r of e){let e=u(r)??r;!e||t.has(e)||(t.add(e),n.push(e))}}function Kt(e,t,n,r){if(!n||!r)return;let i=u(n)??n;if(!i)return;let a=e.get(t);a||(a=new Map,e.set(t,a)),a.set(i,r)}function qt(e){let{participants:t,roster:n,fallbackE164:r}=e,i=new Set,a=[];if(t?.length&&Gt(t,i,a),n&&Gt(n.keys(),i,a),a.length===0&&r){let e=u(r)??r;e&&a.push(e)}if(a.length!==0)return a.map(e=>{let t=n?.get(e);return t?`${t} (${e})`:e}).join(`, `)}function Jt(e,t){let n=u(t.senderE164??``);return n?Lt(e,t.selfE164??void 0).includes(n):!1}function Yt(e){let t=e.msg.senderName&&e.msg.senderE164?`${e.msg.senderName} (${e.msg.senderE164})`:e.msg.senderName??e.msg.senderE164??`Unknown`;W({historyMap:e.groupHistories,historyKey:e.groupHistoryKey,limit:e.groupHistoryLimit,entry:{sender:t,body:e.msg.body,timestamp:e.msg.timestamp,id:e.msg.id,senderJid:e.msg.senderJid}})}function Xt(e,t){return e.logVerbose(t),Yt({msg:e.msg,groupHistories:e.groupHistories,groupHistoryKey:e.groupHistoryKey,groupHistoryLimit:e.groupHistoryLimit}),{shouldProcess:!1}}function Zt(e){let t=Ht(e.cfg,e.conversationId);if(t.allowlistEnabled&&!t.allowed)return e.logVerbose(`Skipping group message ${e.conversationId} (not in allowlist)`),{shouldProcess:!1};Kt(e.groupMemberNames,e.groupHistoryKey,e.msg.senderE164,e.msg.senderName);let n=Nt(e.cfg,e.agentId),r=Vt(e.msg.body,n.mentionRegexes,e.msg.selfE164),i=ve(r),a=Jt(e.baseMentionConfig,e.msg),o=a&&ie(r,e.cfg);if(i.hasCommand&&!a)return Xt(e,`Ignoring /activation from non-owner in group ${e.conversationId}`);let s=It(e.msg,n,e.authDir);e.replyLogger.debug({conversationId:e.conversationId,wasMentioned:s.wasMentioned,...s.details},`group mention debug`);let c=s.wasMentioned,l=Wt({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:e.conversationId})!==`always`,d=e.msg.selfJid?.replace(/:\\d+/,``),f=e.msg.replyToSenderJid?.replace(/:\\d+/,``),p=e.msg.selfE164?u(e.msg.selfE164):null,m=e.msg.replyToSenderE164?u(e.msg.replyToSenderE164):null,h=he({requireMention:l,canDetectMention:!0,wasMentioned:c,implicitMention:!!(d&&f&&d===f||p&&m&&p===m),shouldBypassMention:o});return e.msg.wasMentioned=h.effectiveWasMentioned,!o&&l&&h.shouldSkip?Xt(e,`Group message stored for context (no mention detected) in ${e.conversationId}: ${e.msg.body}`):{shouldProcess:!0}}function Qt(e,t){e.add(t),t.finally(()=>{e.delete(t)})}function $t(e){let t=n(e.cfg.session?.store,{agentId:e.storeAgentId}),r=v({storePath:t,sessionKey:e.sessionKey,deliveryContext:{channel:e.channel,to:e.to,accountId:e.accountId},ctx:e.ctx}).catch(n=>{e.warn({error:K(n),storePath:t,sessionKey:e.sessionKey,to:e.to},`failed updating last route`)});Qt(e.backgroundTasks,r)}function en(e){return e.chatType===`group`?e.conversationId??e.from:e.senderE164?u(e.senderE164)??e.senderE164:e.from.includes(`@`)?m(e.from)??e.from:u(e.from)??e.from}function $(e,t=400){return!e||e.length<=t?e:`${e.slice(0,t)}… (truncated ${e.length-t} chars)`}function tn(e){let t=(e instanceof Error?`${e.message}\n${e.stack??``}`:(e=>{if(e==null)return``;if(typeof e==`string`)return e;if(e instanceof Error)return`${e.message}\n${e.stack??``}`;if(typeof e==`object`)try{return JSON.stringify(e)}catch{return Object.prototype.toString.call(e)}return typeof e==`number`||typeof e==`boolean`||typeof e==`bigint`?String(e):typeof e==`symbol`?e.description??e.toString():typeof e==`function`?e.name?`[function ${e.name}]`:`[function]`:Object.prototype.toString.call(e)})(e)).toLowerCase();return t.includes(`unsupported state or unable to authenticate data`)||t.includes(`bad mac`)?t.includes(`@whiskeysockets/baileys`)||t.includes(`baileys`)||t.includes(`noise-handler`)||t.includes(`aesdecryptgcm`):!1}function nn(e){if(e.isReasoning===!0)return!0;let t=e.text;return typeof t==`string`?t.trimStart().toLowerCase().startsWith(`reasoning:`):!1}async function rn(e){let{replyResult:t,msg:n,maxMediaBytes:r,textLimit:i,replyLogger:o,connectionId:s,skipLog:c}=e,u=Date.now();if(nn(t)){Z.debug(`Suppressed reasoning payload to ${n.from}`);return}let d=e.tableMode??`code`,f=e.chunkMode??`length`,p=Me(ze(Le(t.text||``,d)),i,f),m=t.mediaUrls?.length?t.mediaUrls:t.mediaUrl?[t.mediaUrl]:[],h=async(e,t,r=3)=>{let i;for(let a=1;a<=r;a++)try{return await e()}catch(e){i=e;let o=K(e),s=a===r;if(!/closed|reset|timed\s*out|disconnect/i.test(o)||s)throw e;let c=500*a;l(`Retrying ${t} to ${n.from} after failure (${a}/${r-1}) in ${c}ms: ${o}`),await g(c)}throw i};if(m.length===0&&p.length){let e=p.length;for(let[t,r]of p.entries()){let i=Date.now();if(await h(()=>n.reply(r),`text`),!c){let r=Date.now()-i;Z.debug(`Sent chunk ${t+1}/${e} to ${n.from} (${r.toFixed(0)}ms)`)}}o.info({correlationId:n.id??J(),connectionId:s??null,to:n.from,from:n.to,text:$(t.text,240),mediaUrl:null,mediaSizeBytes:null,mediaKind:null,durationMs:Date.now()-u},`auto-reply sent (text)`);return}let _=[...p];for(let[t,i]of m.entries()){let c=t===0&&_.shift()||void 0;try{let t=await je(i,{maxBytes:r,localRoots:e.mediaLocalRoots});if(a()&&(l(`Web auto-reply media size: ${(t.buffer.length/(1024*1024)).toFixed(2)}MB`),l(`Web auto-reply media source: ${i} (kind ${t.kind})`)),t.kind===`image`)await h(()=>n.sendMedia({image:t.buffer,caption:c,mimetype:t.contentType}),`media:image`);else if(t.kind===`audio`)await h(()=>n.sendMedia({audio:t.buffer,ptt:!0,mimetype:t.contentType,caption:c}),`media:audio`);else if(t.kind===`video`)await h(()=>n.sendMedia({video:t.buffer,caption:c,mimetype:t.contentType}),`media:video`);else{let e=t.fileName??i.split(`/`).pop()??`file`,r=t.contentType??`application/octet-stream`;await h(()=>n.sendMedia({document:t.buffer,fileName:e,caption:c,mimetype:r}),`media:document`)}Z.info(`Sent media reply to ${n.from} (${(t.buffer.length/(1024*1024)).toFixed(2)}MB)`),o.info({correlationId:n.id??J(),connectionId:s??null,to:n.from,from:n.to,text:c??null,mediaUrl:i,mediaSizeBytes:t.buffer.length,mediaKind:t.kind,durationMs:Date.now()-u},`auto-reply sent (media)`)}catch(e){if(Z.error(`Failed sending web media to ${n.from}: ${K(e)}`),o.warn({err:e,mediaUrl:i},`failed to send web media reply`),t===0){let t=e instanceof Error?`⚠️ Media failed: ${e.message}`:`⚠️ Media failed.`,r=[_.shift()??c??``,t].filter(Boolean).join(`
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
require(`./paths-BvlJvmRS.cjs`);const e=require(`./paths-Dbz86fcW.cjs`),t=require(`./logger-BYbgqzvt.cjs`),n=require(`./model-auth-CtK7ak-a.cjs`);require(`./proxy-env-DHDz8MfA.cjs`),require(`./send-bHb4B074.cjs`);const r=require(`./send-BqjnZN35.cjs`),i=require(`./dispatch-
|
|
1
|
+
require(`./paths-BvlJvmRS.cjs`);const e=require(`./paths-Dbz86fcW.cjs`),t=require(`./logger-BYbgqzvt.cjs`),n=require(`./model-auth-CtK7ak-a.cjs`);require(`./proxy-env-DHDz8MfA.cjs`),require(`./send-bHb4B074.cjs`);const r=require(`./send-BqjnZN35.cjs`),i=require(`./dispatch-C-qRxvLo.cjs`);require(`./tokens-BZ6Aj-ln.cjs`),require(`./deliver-2bsqoL4I.cjs`),require(`./github-copilot-token-DoHgkI2r.cjs`),require(`./fetch-guard-t1mSyjVY.cjs`);const a=require(`./send-B4NVvpDy.cjs`),o=require(`./local-roots-BpyzPZG6.cjs`),s=require(`./ir-CShH9-fp.cjs`);require(`./diagnostic-COdAHBDU.cjs`),require(`./pi-model-discovery-CP4c_Itv.cjs`);const c=require(`./audio-transcription-runner-BkT137uG.cjs`);require(`./image-3hJ0JtJ5.cjs`),require(`./api-key-rotation-BD8p16aN.cjs`),require(`./proxy-fetch-C6EcDOzJ.cjs`),require(`./commands-registry-CtK8r2v7.cjs`),require(`./fetch-CZewCAvu.cjs`),require(`./render-DxBO2Blp.cjs`),require(`./target-errors-CQImn6N9.cjs`);const l=require(`./channel-activity-DO2t79L7.cjs`),u=require(`./tables-B3gr4WUQ.cjs`);require(`./send-AmY9TNYW.cjs`),require(`./fetch-Dr7ZFnhR.cjs`),require(`./skill-commands-DBrm2Avd.cjs`),require(`./outbound-attachment-EKTCEQ0-.cjs`),require(`./send-KbdQt9bK.cjs`);const d=require(`./active-listener-B_lHSKz9.cjs`);require(`./query-expansion-DnJeCIbZ.cjs`),require(`./manager-BTcKhekj.cjs`);const f=require(`./outbound-BXIukpI-.cjs`),p=require(`./session-Br7Yd4na.cjs`),m=require(`./login-D-Sl9Acq.cjs`);let h=require(`node:crypto`),g=require(`@whiskeysockets/baileys`);const _={initialMs:2e3,maxMs:3e4,factor:1.8,jitter:.25,maxAttempts:12};function v(e,t){let n=t??e.web?.heartbeatSeconds;return typeof n==`number`&&n>0?n:60}function y(e,n){let r=e.web?.reconnect??{},i=n??{},a={..._,...r,...i};return a.initialMs=Math.max(250,a.initialMs),a.maxMs=Math.max(a.initialMs,a.maxMs),a.factor=t.o(a.factor,1.1,10),a.jitter=t.o(a.jitter,0,1),a.maxAttempts=Math.max(0,Math.floor(a.maxAttempts)),a}function b(){return(0,h.randomUUID)()}const x=t.O(`gateway/channels/whatsapp`),S=x.child(`inbound`),C=x.child(`outbound`),ee=x.child(`heartbeat`);function w(){return setInterval(()=>{},1e6).unref(),new Promise(()=>{})}const T=i.I({ttlMs:20*6e4,maxSize:5e3});function E(e){return T.check(e)}const D=new Set([`FN`,`N`,`TEL`]);function O(e){if(!e)return{phones:[]};let t=e.split(/\r?\n/),n,r,i=[];for(let e of t){let t=e.trim();if(!t)continue;let a=t.indexOf(`:`);if(a===-1)continue;let o=t.slice(0,a).toUpperCase(),s=t.slice(a+1).trim();if(!s)continue;let c=k(o);if(!c||!D.has(c))continue;let l=A(s);if(l){if(c===`FN`&&!r){r=j(l);continue}if(c===`N`&&!n){n=j(l);continue}if(c===`TEL`){let e=M(l);e&&i.push(e)}}}return{name:r??n,phones:i}}function k(e){let[t]=e.split(`;`);if(!t)return;let n=t.split(`.`);return n[n.length-1]||void 0}function A(e){return e.replace(/\\n/gi,` `).replace(/\\,/g,`,`).replace(/\\;/g,`;`).trim()}function j(e){return e.replace(/;/g,` `).replace(/\s+/g,` `).trim()}function M(e){let t=e.trim();return t?t.toLowerCase().startsWith(`tel:`)?t.slice(4).trim():t:``}function N(e){return(0,g.normalizeMessageContent)(e)}function P(e){if(!e)return;let t=(0,g.getContentType)(e),n=t?e[t]:void 0,r=n&&typeof n==`object`&&`contextInfo`in n?n.contextInfo:void 0;if(r)return r;let i=e.extendedTextMessage?.contextInfo??e.imageMessage?.contextInfo??e.videoMessage?.contextInfo??e.documentMessage?.contextInfo??e.audioMessage?.contextInfo??e.stickerMessage?.contextInfo??e.buttonsResponseMessage?.contextInfo??e.listResponseMessage?.contextInfo??e.templateButtonReplyMessage?.contextInfo??e.interactiveResponseMessage?.contextInfo??e.buttonsMessage?.contextInfo??e.listMessage?.contextInfo;if(i)return i;for(let t of Object.values(e)){if(!t||typeof t!=`object`||!(`contextInfo`in t))continue;let e=t.contextInfo;if(e)return e}}function F(e){let t=N(e);if(!t)return;let n=[t.extendedTextMessage?.contextInfo?.mentionedJid,t.extendedTextMessage?.contextInfo?.quotedMessage?.extendedTextMessage?.contextInfo?.mentionedJid,t.imageMessage?.contextInfo?.mentionedJid,t.videoMessage?.contextInfo?.mentionedJid,t.documentMessage?.contextInfo?.mentionedJid,t.audioMessage?.contextInfo?.mentionedJid,t.stickerMessage?.contextInfo?.mentionedJid,t.buttonsResponseMessage?.contextInfo?.mentionedJid,t.listResponseMessage?.contextInfo?.mentionedJid].flatMap(e=>e??[]).filter(Boolean);if(n.length!==0)return Array.from(new Set(n))}function I(e){let t=N(e);if(!t)return;let n=(0,g.extractMessageContent)(t),r=[t,n&&n!==t?n:void 0];for(let e of r){if(!e)continue;if(typeof e.conversation==`string`&&e.conversation.trim())return e.conversation.trim();let t=e.extendedTextMessage?.text;if(t?.trim())return t.trim();let n=e.imageMessage?.caption??e.videoMessage?.caption??e.documentMessage?.caption;if(n?.trim())return n.trim()}let i=R(t)??(n&&n!==t?R(n):void 0);if(i)return i}function L(e){let t=N(e);if(t){if(t.imageMessage)return`<media:image>`;if(t.videoMessage)return`<media:video>`;if(t.audioMessage)return`<media:audio>`;if(t.documentMessage)return`<media:document>`;if(t.stickerMessage)return`<media:sticker>`}}function R(e){let t=N(e);if(!t)return;let n=t.contactMessage??void 0;if(n){let{name:e,phones:t}=z({displayName:n.displayName,vcard:n.vcard});return B(e,t)}let r=t.contactsArrayMessage?.contacts??void 0;if(!(!r||r.length===0))return V(r.map(e=>z({displayName:e.displayName,vcard:e.vcard})).map(e=>H(e.name,e.phones)).filter(e=>!!e),r.length)}function z(e){let t=(e.displayName??``).trim(),n=O(e.vcard??void 0);return{name:t||n.name,phones:n.phones}}function B(e,t){let n=H(e,t);return n?`<contact: ${n}>`:`<contact>`}function V(e,t){let n=e.map(e=>e.trim()).filter(Boolean);if(n.length===0)return`<contacts: ${t} ${t===1?`contact`:`contacts`}>`;let r=Math.max(t-n.length,0),i=r>0?` +${r} more`:``;return`<contacts: ${n.join(`, `)}${i}>`}function H(e,t){let n=[e,U(t)].filter(e=>!!e);if(n.length!==0)return n.join(`, `)}function U(e){let t=e?.map(e=>e.trim()).filter(Boolean)??[];if(t.length===0)return;let{shown:n,remaining:r}=te(t,t.length,1),[i]=n;if(i)return r===0?i:`${i} (+${r} more)`}function te(e,t,n){let r=e.slice(0,n);return{shown:r,remaining:Math.max(t-r.length,0)}}function ne(e){let t=N(e);if(!t)return null;let n=t.liveLocationMessage??void 0;if(n){let e=n.degreesLatitude,t=n.degreesLongitude;if(e!=null&&t!=null){let r=Number(e),i=Number(t);if(Number.isFinite(r)&&Number.isFinite(i))return{latitude:r,longitude:i,accuracy:n.accuracyInMeters??void 0,caption:n.caption??void 0,source:`live`,isLive:!0}}}let r=t.locationMessage??void 0;if(r){let e=r.degreesLatitude,t=r.degreesLongitude;if(e!=null&&t!=null){let n=Number(e),i=Number(t);if(Number.isFinite(n)&&Number.isFinite(i)){let e=!!r.isLive;return{latitude:n,longitude:i,accuracy:r.accuracyInMeters??void 0,name:r.name??void 0,address:r.address??void 0,caption:r.comment??void 0,source:e?`live`:r.name||r.address?`place`:`pin`,isLive:e}}}}return null}function W(e){let n=N(e);if(!n)return null;let r=P(n),i=(0,g.normalizeMessageContent)(r?.quotedMessage);if(!i)return null;let o=ne(i),s=o?a.J(o):void 0,c=[I(i),s].filter(Boolean).join(`
|
|
2
2
|
`).trim();if(c||=L(i),!c){let e=i?(0,g.getContentType)(i):void 0;return t.R(`Quoted message missing extractable body${e?` (type ${e})`:``}`),null}let l=r?.participant??void 0,u=l?t.m(l)??l:void 0,d=u??`unknown sender`;return{id:r?.stanzaId?String(r.stanzaId):void 0,body:c,sender:d,senderJid:l,senderE164:u}}function re(e){return r.Pt({providerConfigPresent:e.providerConfigPresent,groupPolicy:e.groupPolicy,defaultGroupPolicy:e.defaultGroupPolicy})}async function ie(e){let o=n.Si(),s=n.js({cfg:o,accountId:e.accountId}),c=s.dmPolicy??`pairing`,l=s.allowFrom??[],u=await i.z({provider:`whatsapp`,accountId:s.accountId,dmPolicy:c}),d=l.length===0&&e.selfE164?[e.selfE164]:[],f=l.length>0?l:d,p=s.groupAllowFrom??(l.length>0?l:void 0),m=e.from===e.selfE164,h=s.selfChatMode??t.p(e.selfE164,l),g=typeof e.pairingGraceMs==`number`&&e.pairingGraceMs>0?e.pairingGraceMs:3e4,_=typeof e.connectedAtMs==`number`&&typeof e.messageTimestampMs==`number`&&e.messageTimestampMs<e.connectedAtMs-g,v=r.Nt(o),{groupPolicy:y,providerMissingFallbackApplied:b}=re({providerConfigPresent:o.channels?.whatsapp!==void 0,groupPolicy:s.groupPolicy,defaultGroupPolicy:v});r.Ft({providerMissingFallbackApplied:b,providerKey:`whatsapp`,accountId:s.accountId,log:e=>t.R(e)});let x=t.h(e.from),S=typeof e.senderE164==`string`?t.h(e.senderE164):null,C=i.V({isGroup:e.group,dmPolicy:c,groupPolicy:y,allowFrom:e.group?l:f,groupAllowFrom:p,storeAllowFrom:u,isSenderAllowed:n=>{if(n.includes(`*`))return!0;let r=new Set(n.map(e=>t.h(String(e))).filter(e=>!!e));return!e.group&&m?!0:e.group?!!(S&&r.has(S)):r.has(x)}});if(e.group&&C.decision!==`allow`)return C.reason===`groupPolicy=disabled`?t.R(`Blocked group message (groupPolicy: disabled)`):C.reason===`groupPolicy=allowlist (empty allowlist)`?t.R(`Blocked group message (groupPolicy: allowlist, no groupAllowFrom)`):t.R(`Blocked group message from ${e.senderE164??`unknown sender`} (groupPolicy: allowlist)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(!e.group){if(e.isFromMe&&!m)return t.R(`Skipping outbound DM (fromMe); no pairing reply needed.`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(C.decision===`block`&&C.reason===`dmPolicy=disabled`)return t.R(`Blocked dm (dmPolicy: disabled)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId};if(C.decision===`pairing`&&!m){let n=e.from;return _?t.R(`Skipping pairing reply for historical DM from ${n}.`):await i.p({channel:`whatsapp`,senderId:n,senderIdLine:`Your WhatsApp phone number: ${n}`,meta:{name:(e.pushName??``).trim()||void 0},upsertPairingRequest:async({id:e,meta:t})=>await a.tt({channel:`whatsapp`,id:e,accountId:s.accountId,meta:t}),onCreated:()=>{t.R(`whatsapp pairing request sender=${n} name=${e.pushName??`unknown`}`)},sendPairingReply:async t=>{await e.sock.sendMessage(e.remoteJid,{text:t})},onReplyError:e=>{t.R(`whatsapp pairing reply failed for ${n}: ${String(e)}`)}}),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId}}if(C.decision!==`allow`)return t.R(`Blocked unauthorized sender ${e.from} (dmPolicy=${c})`),{allowed:!1,shouldMarkRead:!1,isSelfChat:h,resolvedAccountId:s.accountId}}return{allowed:!0,shouldMarkRead:!0,isSelfChat:h,resolvedAccountId:s.accountId}}function G(e){return(0,g.normalizeMessageContent)(e)}function K(e){let t=e.imageMessage?.mimetype??e.videoMessage?.mimetype??e.documentMessage?.mimetype??e.audioMessage?.mimetype??e.stickerMessage?.mimetype??void 0;if(t)return t;if(e.audioMessage)return`audio/ogg; codecs=opus`;if(e.imageMessage)return`image/jpeg`;if(e.videoMessage)return`video/mp4`;if(e.stickerMessage)return`image/webp`}async function ae(e,n){let r=G(e.message);if(!r)return;let i=K(r),a=r.documentMessage?.fileName??void 0;if(!(!r.imageMessage&&!r.videoMessage&&!r.documentMessage&&!r.audioMessage&&!r.stickerMessage))try{return{buffer:await(0,g.downloadMediaMessage)(e,`buffer`,{},{reuploadRequest:n.updateMediaMessage,logger:n.logger}),mimetype:i,fileName:a}}catch(e){t.R(`downloadMediaMessage failed: ${String(e)}`);return}}function q(e){l.n({channel:`whatsapp`,accountId:e,direction:`outbound`})}function J(e){return typeof e==`object`&&e&&`key`in e?String(e.key?.id??`unknown`):`unknown`}function Y(e){return{sendMessage:async(n,r,i,a,o)=>{let s=t.T(n),c;if(i&&a)if(a.startsWith(`image/`))c={image:i,caption:r||void 0,mimetype:a};else if(a.startsWith(`audio/`))c={audio:i,ptt:!0,mimetype:a};else if(a.startsWith(`video/`)){let e=o?.gifPlayback;c={video:i,caption:r||void 0,mimetype:a,...e?{gifPlayback:!0}:{}}}else c={document:i,fileName:o?.fileName?.trim()||`file`,caption:r||void 0,mimetype:a};else c={text:r};let l=await e.sock.sendMessage(s,c);return q(o?.accountId??e.defaultAccountId),{messageId:J(l)}},sendPoll:async(n,r)=>{let i=t.T(n),a=await e.sock.sendMessage(i,{poll:{name:r.question,values:r.options,selectableCount:r.maxSelections??1}});return q(e.defaultAccountId),{messageId:J(a)}},sendReaction:async(n,r,i,a,o)=>{let s=t.T(n);await e.sock.sendMessage(s,{react:{text:i,key:{remoteJid:s,id:r,fromMe:a,participant:o?t.T(o):void 0}}})},sendComposingTo:async n=>{let r=t.T(n);await e.sock.sendPresenceUpdate(`composing`,r)}}}async function oe(e){let r=t.K({module:`web-inbound`}),o=t.O(`gateway/channels/whatsapp`).child(`inbound`),s=await p.t(!1,e.verbose,{authDir:e.authDir});await p.i(s);let c=Date.now(),u=null,d=new Promise(e=>{u=e}),f=e=>{if(!u)return;let t=u;u=null,t(e)};try{await s.sendPresenceUpdate(`available`),t.B()&&t.R(`Sent global 'available' presence on connect`)}catch(e){t.R(`Failed to send 'available' presence on connect: ${String(e)}`)}let m=s.user?.id,h=m?t.m(m):null,_=i.C({debounceMs:e.debounceMs??0,buildKey:e=>{let t=e.chatType===`group`?e.senderJid??e.senderE164??e.senderName??e.from:e.from;if(!t)return null;let n=e.chatType===`group`?e.chatId:e.from;return`${e.accountId}:${n}:${t}`},shouldDebounce:e.shouldDebounce,onFlush:async t=>{let n=t.at(-1);if(!n)return;if(t.length===1){await e.onMessage(n);return}let r=new Set;for(let e of t)for(let t of e.mentionedJids??[])r.add(t);let i=t.map(e=>e.body).filter(Boolean).join(`
|
|
3
3
|
`),a={...n,body:i,mentionedJids:r.size>0?Array.from(r):void 0};await e.onMessage(a)},onError:e=>{r.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)}}),v=new Map,y=300*1e3,b=s.signalRepository?.lidMapping,x=async n=>t.v(n,{authDir:e.authDir,lidLookup:b}),S=async e=>{let n=v.get(e);if(n&&n.expires>Date.now())return n;try{let t=await s.groupMetadata(e),n=(await Promise.all(t.participants?.map(async e=>await x(e.id)??e.id)??[])).filter(Boolean)??[],r={subject:t.subject,participants:n,expires:Date.now()+y};return v.set(e,r),r}catch(n){return t.R(`Failed to fetch group metadata for ${e}: ${String(n)}`),{expires:Date.now()+y}}},C=async t=>{let n=t.key?.id??void 0,r=t.key?.remoteJid;if(!r||r.endsWith(`@status`)||r.endsWith(`@broadcast`))return null;let i=(0,g.isJidGroup)(r)===!0;if(n&&E(`${e.accountId}:${r}:${n}`))return null;let a=t.key?.participant??void 0,o=i?r:await x(r);if(!o)return null;let l=i?a?await x(a):null:o,u,d;if(i){let e=await S(r);u=e.subject,d=e.participants}let f=t.messageTimestamp?Number(t.messageTimestamp)*1e3:void 0,p=await ie({accountId:e.accountId,from:o,selfE164:h,senderE164:l,group:i,pushName:t.pushName??void 0,isFromMe:!!t.key?.fromMe,messageTimestampMs:f,connectedAtMs:c,sock:{sendMessage:(e,t)=>s.sendMessage(e,t)},remoteJid:r});return p.allowed?{id:n,remoteJid:r,group:i,participantJid:a,from:o,senderE164:l,groupSubject:u,groupParticipants:d,messageTimestampMs:f,access:p}:null},ee=async n=>{let{id:r,remoteJid:i,participantJid:a,access:o}=n;if(r&&!o.isSelfChat&&e.sendReadReceipts!==!1)try{await s.readMessages([{remoteJid:i,id:r,participant:a,fromMe:!1}]),t.B()&&t.R(`Marked message ${r} as read for ${i}${a?` (participant ${a})`:``}`)}catch(e){t.R(`Failed to mark message ${r} read: ${String(e)}`)}else r&&o.isSelfChat&&t.B()&&t.R(`Self-chat mode: skipping read receipt for ${r}`)},w=async r=>{let i=ne(r.message??void 0),o=i?a.J(i):void 0,c=I(r.message??void 0);if(o&&(c=[c,o].filter(Boolean).join(`
|
|
4
4
|
`).trim()),!c&&(c=L(r.message??void 0),!c))return null;let l=W(r.message),u,d,f;try{let t=await ae(r,s);if(t){let r=(typeof e.mediaMaxMb==`number`&&e.mediaMaxMb>0?e.mediaMaxMb:50)*1024*1024;u=(await n.nr(t.buffer,t.mimetype,`inbound`,r,t.fileName)).path,d=t.mimetype,f=t.fileName}}catch(e){t.R(`Inbound media download failed: ${String(e)}`)}return{body:c,location:i??void 0,replyContext:l,mediaPath:u,mediaType:d,mediaFileName:f}},T=async(e,n,i)=>{let a=n.remoteJid,c=async()=>{try{await s.sendPresenceUpdate(`composing`,a)}catch(e){t.R(`Presence update failed: ${String(e)}`)}},l=async e=>{await s.sendMessage(a,{text:e})},u=async e=>{await s.sendMessage(a,e)},d=n.messageTimestampMs,f=F(e.message),p=e.pushName??void 0;r.info({from:n.from,to:h??`me`,body:i.body,mediaPath:i.mediaPath,mediaType:i.mediaType,mediaFileName:i.mediaFileName,timestamp:d},`inbound message`);let g={id:n.id,from:n.from,conversationId:n.from,to:h??`me`,accountId:n.access.resolvedAccountId,body:i.body,pushName:p,timestamp:d,chatType:n.group?`group`:`direct`,chatId:n.remoteJid,senderJid:n.participantJid,senderE164:n.senderE164??void 0,senderName:p,replyToId:i.replyContext?.id,replyToBody:i.replyContext?.body,replyToSender:i.replyContext?.sender,replyToSenderJid:i.replyContext?.senderJid,replyToSenderE164:i.replyContext?.senderE164,groupSubject:n.groupSubject,groupParticipants:n.groupParticipants,mentionedJids:f??void 0,selfJid:m,selfE164:h,fromMe:!!e.key?.fromMe,location:i.location??void 0,sendComposing:c,reply:l,sendMedia:u,mediaPath:i.mediaPath,mediaType:i.mediaType,mediaFileName:i.mediaFileName};try{Promise.resolve(_.enqueue(g)).catch(e=>{r.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)})}catch(e){r.error({error:String(e)},`failed handling inbound web message`),o.error(`Failed handling inbound web message: ${String(e)}`)}},D=async t=>{if(!(t.type!==`notify`&&t.type!==`append`))for(let n of t.messages??[]){l.n({channel:`whatsapp`,accountId:e.accountId,direction:`inbound`});let r=await C(n);if(!r||(await ee(r),t.type===`append`))continue;let i=await w(n);i&&await T(n,r,i)}};s.ev.on(`messages.upsert`,D);let O=e=>{try{if(e.connection===`close`){let t=p.r(e.lastDisconnect?.error);f({status:t,isLoggedOut:t===g.DisconnectReason.loggedOut,error:e.lastDisconnect?.error})}}catch(e){r.error({error:String(e)},`connection.update handler error`),f({status:void 0,isLoggedOut:!1,error:e})}};return s.ev.on(`connection.update`,O),{close:async()=>{try{let e=s.ev,t=D,n=O;typeof e.off==`function`?(e.off(`messages.upsert`,t),e.off(`connection.update`,n)):typeof e.removeListener==`function`&&(e.removeListener(`messages.upsert`,t),e.removeListener(`connection.update`,n)),s.ws?.close()}catch(e){t.R(`Socket close failed: ${String(e)}`)}},onClose:d,signalClose:e=>{f(e??{status:void 0,isLoggedOut:!1,error:`closed`})},...Y({sock:{sendMessage:(e,t)=>s.sendMessage(e,t),sendPresenceUpdate:(e,t)=>s.sendPresenceUpdate(e,t)},defaultAccountId:e.accountId})}}function X(e,t){return{mentionRegexes:i.ct(e,t),allowFrom:e.channels?.whatsapp?.allowFrom}}function Z(e,n){let r=n?{authDir:n}:void 0;return{normalizedMentions:e.mentionedJids?.length?e.mentionedJids.map(e=>t.m(e,r)??e).filter(Boolean):[],selfE164:e.selfE164??(e.selfJid?t.m(e.selfJid,r):null),selfJid:e.selfJid?e.selfJid.replace(/:\\d+/,``):null}}function Q(e,n,r){let a=e=>i.lt(e),o=t.p(r.selfE164,n.allowFrom);if((e.mentionedJids?.length??0)>0&&!o)return!!(r.selfE164&&r.normalizedMentions.includes(r.selfE164)||r.selfJid&&r.normalizedMentions.includes(r.selfJid));let s=a(e.body);if(n.mentionRegexes.some(e=>e.test(s)))return!0;if(r.selfE164){let t=r.selfE164.replace(/\D/g,``);if(t){if(s.replace(/[^\d]/g,``).includes(t))return!0;let n=e.body.replace(/[\s-]/g,``);if(RegExp(`\\+?${t}`,`i`).test(n))return!0}}return!1}function se(e,t,n){let r=Z(e,n);return{wasMentioned:Q(e,t,r),details:{from:e.from,body:e.body,bodyClean:i.lt(e.body),mentionedJids:e.mentionedJids??null,normalizedMentionedJids:r.normalizedMentions.length?r.normalizedMentions:null,selfJid:e.selfJid??null,selfJidBare:r.selfJid,selfE164:e.selfE164??null,resolvedSelfE164:r.selfE164}}}function ce(e,n){let r=e.allowFrom;return(Array.isArray(r)&&r.length>0?r:n?[n]:[]).filter(e=>!!(e&&e!==`*`)).map(e=>t.h(e)).filter(e=>!!e)}function le(e){let t=new Set,n=Math.max(1,e.maxItems??100),r=e=>`combined:${e.sessionKey}:${e.combinedBody}`,i=()=>{for(;t.size>n;){let e=t.values().next().value;if(!e)break;t.delete(e)}};return{rememberText:(n,a)=>{n&&(t.add(n),a.combinedBody&&a.combinedBodySessionKey&&t.add(r({sessionKey:a.combinedBodySessionKey,combinedBody:a.combinedBody})),a.logVerboseMessage&&e.logVerbose?.(`Added to echo detection set (size now: ${t.size}): ${n.substring(0,50)}...`),i())},has:e=>t.has(e),forget:e=>{t.delete(e)},buildCombinedKey:r}}function ue(t){let n=i.m({agentId:t.agentId,channel:`whatsapp`,accountId:t.route.accountId,peer:{kind:t.msg.chatType===`group`?`group`:`direct`,id:t.peerId},dmScope:t.cfg.session?.dmScope,identityLinks:t.cfg.session?.identityLinks}),r=e.wt({agentId:t.agentId,mainKey:e.Ct});return{sessionKey:n,mainSessionKey:r,lastRoutePolicy:i.h({sessionKey:n,mainSessionKey:r})}}async function de(t){let n=t.cfg.broadcast?.[t.peerId];if(!n||!Array.isArray(n)||n.length===0)return!1;let r=t.cfg.broadcast?.strategy||`parallel`;S.info(`Broadcasting message to ${n.length} agents (${r})`);let i=t.cfg.agents?.list?.map(t=>e.kt(t.id)),a=(i?.length??0)>0,o=t.msg.chatType===`group`?t.groupHistories.get(t.groupHistoryKey)??[]:void 0,s=async n=>{let r=e.kt(n);if(a&&!i?.includes(r))return S.warn(`Broadcast agent ${n} not found in agents.list; skipping`),!1;let s=ue({cfg:t.cfg,msg:t.msg,route:t.route,peerId:t.peerId,agentId:r}),c={...t.route,agentId:r,...s};try{return await t.processMessage(t.msg,c,t.groupHistoryKey,{groupHistory:o,suppressGroupHistoryClear:!0})}catch(e){return S.error(`Broadcast agent ${n} failed: ${p.n(e)}`),!1}};if(r===`sequential`)for(let e of n)await s(e);else await Promise.allSettled(n.map(s));return t.msg.chatType===`group`&&t.groupHistories.set(t.groupHistoryKey,[]),!0}function fe(e,t,n){let r=e;for(let e of t)r=r.replace(e,` `);if(n){let e=n.replace(/\D/g,``);if(e){let t=RegExp(`\\+?${e}`,`g`);r=r.replace(t,` `)}}return r.replace(/\s+/g,` `).trim()}function pe(e,t){let r=n.gn({From:t,ChatType:`group`,Provider:`whatsapp`})?.id,i=e.channels?.whatsapp,a=!!(i?.groupAllowFrom?.length||i?.allowFrom?.length);return n.uc({cfg:e,channel:`whatsapp`,groupId:r??t,hasGroupAllowFrom:a})}function me(e,t){let r=n.gn({From:t,ChatType:`group`,Provider:`whatsapp`})?.id;return n.dc({cfg:e,channel:`whatsapp`,groupId:r??t})}function he(t){let r=n.kt(e.s(t.cfg.session?.store,{agentId:t.agentId}))[t.sessionKey],a=me(t.cfg,t.conversationId)?`mention`:`always`;return i.o(r?.groupActivation)??a}function ge(e,n,r){for(let i of e){let e=t.h(i)??i;!e||n.has(e)||(n.add(e),r.push(e))}}function _e(e,n,r,i){if(!r||!i)return;let a=t.h(r)??r;if(!a)return;let o=e.get(n);o||(o=new Map,e.set(n,o)),o.set(a,i)}function ve(e){let{participants:n,roster:r,fallbackE164:i}=e,a=new Set,o=[];if(n?.length&&ge(n,a,o),r&&ge(r.keys(),a,o),o.length===0&&i){let e=t.h(i)??i;e&&o.push(e)}if(o.length!==0)return o.map(e=>{let t=r?.get(e);return t?`${t} (${e})`:e}).join(`, `)}function ye(e,n){let r=t.h(n.senderE164??``);return r?ce(e,n.selfE164??void 0).includes(r):!1}function be(e){let t=e.msg.senderName&&e.msg.senderE164?`${e.msg.senderName} (${e.msg.senderE164})`:e.msg.senderName??e.msg.senderE164??`Unknown`;i.st({historyMap:e.groupHistories,historyKey:e.groupHistoryKey,limit:e.groupHistoryLimit,entry:{sender:t,body:e.msg.body,timestamp:e.msg.timestamp,id:e.msg.id,senderJid:e.msg.senderJid}})}function xe(e,t){return e.logVerbose(t),be({msg:e.msg,groupHistories:e.groupHistories,groupHistoryKey:e.groupHistoryKey,groupHistoryLimit:e.groupHistoryLimit}),{shouldProcess:!1}}function Se(e){let n=pe(e.cfg,e.conversationId);if(n.allowlistEnabled&&!n.allowed)return e.logVerbose(`Skipping group message ${e.conversationId} (not in allowlist)`),{shouldProcess:!1};_e(e.groupMemberNames,e.groupHistoryKey,e.msg.senderE164,e.msg.senderName);let r=X(e.cfg,e.agentId),a=fe(e.msg.body,r.mentionRegexes,e.msg.selfE164),o=i.s(a),s=ye(e.baseMentionConfig,e.msg),c=s&&i.E(a,e.cfg);if(o.hasCommand&&!s)return xe(e,`Ignoring /activation from non-owner in group ${e.conversationId}`);let l=se(e.msg,r,e.authDir);e.replyLogger.debug({conversationId:e.conversationId,wasMentioned:l.wasMentioned,...l.details},`group mention debug`);let u=l.wasMentioned,d=he({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:e.conversationId})!==`always`,f=e.msg.selfJid?.replace(/:\\d+/,``),p=e.msg.replyToSenderJid?.replace(/:\\d+/,``),m=e.msg.selfE164?t.h(e.msg.selfE164):null,h=e.msg.replyToSenderE164?t.h(e.msg.replyToSenderE164):null,g=i.Z({requireMention:d,canDetectMention:!0,wasMentioned:u,implicitMention:!!(f&&p&&f===p||m&&h&&m===h),shouldBypassMention:c});return e.msg.wasMentioned=g.effectiveWasMentioned,!c&&d&&g.shouldSkip?xe(e,`Group message stored for context (no mention detected) in ${e.conversationId}: ${e.msg.body}`):{shouldProcess:!0}}function Ce(e,t){e.add(t),t.finally(()=>{e.delete(t)})}function we(t){let r=e.s(t.cfg.session?.store,{agentId:t.storeAgentId}),i=n.Nt({storePath:r,sessionKey:t.sessionKey,deliveryContext:{channel:t.channel,to:t.to,accountId:t.accountId},ctx:t.ctx}).catch(e=>{t.warn({error:p.n(e),storePath:r,sessionKey:t.sessionKey,to:t.to},`failed updating last route`)});Ce(t.backgroundTasks,i)}function Te(e){return e.chatType===`group`?e.conversationId??e.from:e.senderE164?t.h(e.senderE164)??e.senderE164:e.from.includes(`@`)?t.m(e.from)??e.from:t.h(e.from)??e.from}function $(e,t=400){return!e||e.length<=t?e:`${e.slice(0,t)}… (truncated ${e.length-t} chars)`}function Ee(e){let t=(e instanceof Error?`${e.message}\n${e.stack??``}`:(e=>{if(e==null)return``;if(typeof e==`string`)return e;if(e instanceof Error)return`${e.message}\n${e.stack??``}`;if(typeof e==`object`)try{return JSON.stringify(e)}catch{return Object.prototype.toString.call(e)}return typeof e==`number`||typeof e==`boolean`||typeof e==`bigint`?String(e):typeof e==`symbol`?e.description??e.toString():typeof e==`function`?e.name?`[function ${e.name}]`:`[function]`:Object.prototype.toString.call(e)})(e)).toLowerCase();return t.includes(`unsupported state or unable to authenticate data`)||t.includes(`bad mac`)?t.includes(`@whiskeysockets/baileys`)||t.includes(`baileys`)||t.includes(`noise-handler`)||t.includes(`aesdecryptgcm`):!1}function De(e){if(e.isReasoning===!0)return!0;let t=e.text;return typeof t==`string`?t.trimStart().toLowerCase().startsWith(`reasoning:`):!1}async function Oe(e){let{replyResult:n,msg:r,maxMediaBytes:i,textLimit:a,replyLogger:o,connectionId:c,skipLog:l}=e,d=Date.now();if(De(n)){C.debug(`Suppressed reasoning payload to ${r.from}`);return}let m=e.tableMode??`code`,h=e.chunkMode??`length`,g=s.c(f.i(u.t(n.text||``,m)),a,h),_=n.mediaUrls?.length?n.mediaUrls:n.mediaUrl?[n.mediaUrl]:[],v=async(e,n,i=3)=>{let a;for(let o=1;o<=i;o++)try{return await e()}catch(e){a=e;let s=p.n(e),c=o===i;if(!/closed|reset|timed\s*out|disconnect/i.test(s)||c)throw e;let l=500*o;t.R(`Retrying ${n} to ${r.from} after failure (${o}/${i-1}) in ${l}ms: ${s}`),await t.C(l)}throw a};if(_.length===0&&g.length){let e=g.length;for(let[t,n]of g.entries()){let i=Date.now();if(await v(()=>r.reply(n),`text`),!l){let n=Date.now()-i;C.debug(`Sent chunk ${t+1}/${e} to ${r.from} (${n.toFixed(0)}ms)`)}}o.info({correlationId:r.id??b(),connectionId:c??null,to:r.from,from:r.to,text:$(n.text,240),mediaUrl:null,mediaSizeBytes:null,mediaKind:null,durationMs:Date.now()-d},`auto-reply sent (text)`);return}let y=[...g];for(let[n,a]of _.entries()){let l=n===0&&y.shift()||void 0;try{let n=await s._(a,{maxBytes:i,localRoots:e.mediaLocalRoots});if(t.B()&&(t.R(`Web auto-reply media size: ${(n.buffer.length/(1024*1024)).toFixed(2)}MB`),t.R(`Web auto-reply media source: ${a} (kind ${n.kind})`)),n.kind===`image`)await v(()=>r.sendMedia({image:n.buffer,caption:l,mimetype:n.contentType}),`media:image`);else if(n.kind===`audio`)await v(()=>r.sendMedia({audio:n.buffer,ptt:!0,mimetype:n.contentType,caption:l}),`media:audio`);else if(n.kind===`video`)await v(()=>r.sendMedia({video:n.buffer,caption:l,mimetype:n.contentType}),`media:video`);else{let e=n.fileName??a.split(`/`).pop()??`file`,t=n.contentType??`application/octet-stream`;await v(()=>r.sendMedia({document:n.buffer,fileName:e,caption:l,mimetype:t}),`media:document`)}C.info(`Sent media reply to ${r.from} (${(n.buffer.length/(1024*1024)).toFixed(2)}MB)`),o.info({correlationId:r.id??b(),connectionId:c??null,to:r.from,from:r.to,text:l??null,mediaUrl:a,mediaSizeBytes:n.buffer.length,mediaKind:n.kind,durationMs:Date.now()-d},`auto-reply sent (media)`)}catch(e){if(C.error(`Failed sending web media to ${r.from}: ${p.n(e)}`),o.warn({err:e,mediaUrl:a},`failed to send web media reply`),n===0){let t=e instanceof Error?`⚠️ Media failed: ${e.message}`:`⚠️ Media failed.`,n=[y.shift()??l??``,t].filter(Boolean).join(`
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{Ct as e,Et as t,kt as n,s as r,wt as i}from"./paths-CAzfAyaR.js";import"./paths-BpQOWYiT.js";import{B as a,C as o,K as s,M as c,O as l,R as u,T as d,h as f,m as p,o as m,p as h,v as g}from"./logger-D0y9iaZX.js";import{As as _,At as v,Bs as y,Ds as b,Is as x,Mt as S,Os as C,Ot as w,Ps as T,Ws as E,hn as D,js as ee,ks as te,oc as O,sc as k,tr as ne,xi as A}from"./model-auth-LGcy44r-.js";import"./proxy-env-BH5JmJpH.js";import"./send-D_1MrN0Y.js";import{Ft as j,Nt as M,Pt as N}from"./send-CAz4gzKJ.js";import{B as P,C as F,D as I,E as re,I as ie,J as L,L as ae,T as R,U as z,V as B,Y as oe,Z as V,_ as H,b as U,ct as W,d as se,f as G,g as ce,h as K,it as le,l as ue,lt as de,m as fe,o as pe,p as me,q as he,r as ge,s as _e,st as ve,u as ye,v as be,w as xe,x as Se,y as Ce,z as we}from"./dispatch-
|
|
1
|
+
import{Ct as e,Et as t,kt as n,s as r,wt as i}from"./paths-CAzfAyaR.js";import"./paths-BpQOWYiT.js";import{B as a,C as o,K as s,M as c,O as l,R as u,T as d,h as f,m as p,o as m,p as h,v as g}from"./logger-D0y9iaZX.js";import{As as _,At as v,Bs as y,Ds as b,Is as x,Mt as S,Os as C,Ot as w,Ps as T,Ws as E,hn as D,js as ee,ks as te,oc as O,sc as k,tr as ne,xi as A}from"./model-auth-LGcy44r-.js";import"./proxy-env-BH5JmJpH.js";import"./send-D_1MrN0Y.js";import{Ft as j,Nt as M,Pt as N}from"./send-CAz4gzKJ.js";import{B as P,C as F,D as I,E as re,I as ie,J as L,L as ae,T as R,U as z,V as B,Y as oe,Z as V,_ as H,b as U,ct as W,d as se,f as G,g as ce,h as K,it as le,l as ue,lt as de,m as fe,o as pe,p as me,q as he,r as ge,s as _e,st as ve,u as ye,v as be,w as xe,x as Se,y as Ce,z as we}from"./dispatch-t6yxQhjZ.js";import"./tokens-_oeWgBjS.js";import"./deliver-Cwma3cEh.js";import"./github-copilot-token-Bt4PduRB.js";import"./fetch-guard-DU2iRA1J.js";import{J as Te,Y as Ee,tt as De}from"./send-BnIRPCyk.js";import{t as Oe}from"./local-roots-BEAybc8j.js";import{_ as ke,c as Ae,d as je,f as Me,i as Ne}from"./ir-C3ltd_cm.js";import"./diagnostic-CG3XOSCB.js";import"./pi-model-discovery-ODeB3o6P.js";import{f as Pe}from"./audio-transcription-runner-GgzXBu6l.js";import"./image-CQzLGNU8.js";import"./api-key-rotation-GriMf_a_.js";import"./proxy-fetch-KzLCCajM.js";import"./commands-registry-BcV7cEx8.js";import"./fetch-B1GR6-u4.js";import"./render-DhTJXP1U.js";import"./target-errors-BKiCGcH-.js";import{n as Fe}from"./channel-activity-CspJCPE5.js";import{t as Ie}from"./tables-BohCnUK-.js";import"./send-KEHkw4E8.js";import"./fetch-Doc-i_EJ.js";import"./skill-commands-ERK3EhV1.js";import"./outbound-attachment-DgtoMxV4.js";import"./send-CbdjQuEu.js";import{r as Le}from"./active-listener-CKmyyUuB.js";import"./query-expansion--XG0a9wS.js";import"./manager-DYXztYG-.js";import{i as Re,r as ze,t as Be}from"./outbound-BF06rwu-.js";import{i as Ve,n as q,r as He,t as Ue}from"./session-WtcTqmDF.js";import{t as We}from"./login-BdWAWclc.js";import{randomUUID as Ge}from"node:crypto";import{DisconnectReason as Ke,downloadMediaMessage as qe,extractMessageContent as Je,getContentType as Ye,isJidGroup as Xe,normalizeMessageContent as Ze}from"@whiskeysockets/baileys";const Qe={initialMs:2e3,maxMs:3e4,factor:1.8,jitter:.25,maxAttempts:12};function $e(e,t){let n=t??e.web?.heartbeatSeconds;return typeof n==`number`&&n>0?n:60}function et(e,t){let n=e.web?.reconnect??{},r=t??{},i={...Qe,...n,...r};return i.initialMs=Math.max(250,i.initialMs),i.maxMs=Math.max(i.initialMs,i.maxMs),i.factor=m(i.factor,1.1,10),i.jitter=m(i.jitter,0,1),i.maxAttempts=Math.max(0,Math.floor(i.maxAttempts)),i}function J(){return Ge()}const Y=l(`gateway/channels/whatsapp`),X=Y.child(`inbound`),Z=Y.child(`outbound`),tt=Y.child(`heartbeat`);function nt(){return setInterval(()=>{},1e6).unref(),new Promise(()=>{})}const rt=ie({ttlMs:20*6e4,maxSize:5e3});function it(e){return rt.check(e)}const at=new Set([`FN`,`N`,`TEL`]);function ot(e){if(!e)return{phones:[]};let t=e.split(/\r?\n/),n,r,i=[];for(let e of t){let t=e.trim();if(!t)continue;let a=t.indexOf(`:`);if(a===-1)continue;let o=t.slice(0,a).toUpperCase(),s=t.slice(a+1).trim();if(!s)continue;let c=st(o);if(!c||!at.has(c))continue;let l=ct(s);if(l){if(c===`FN`&&!r){r=lt(l);continue}if(c===`N`&&!n){n=lt(l);continue}if(c===`TEL`){let e=ut(l);e&&i.push(e)}}}return{name:r??n,phones:i}}function st(e){let[t]=e.split(`;`);if(!t)return;let n=t.split(`.`);return n[n.length-1]||void 0}function ct(e){return e.replace(/\\n/gi,` `).replace(/\\,/g,`,`).replace(/\\;/g,`;`).trim()}function lt(e){return e.replace(/;/g,` `).replace(/\s+/g,` `).trim()}function ut(e){let t=e.trim();return t?t.toLowerCase().startsWith(`tel:`)?t.slice(4).trim():t:``}function Q(e){return Ze(e)}function dt(e){if(!e)return;let t=Ye(e),n=t?e[t]:void 0,r=n&&typeof n==`object`&&`contextInfo`in n?n.contextInfo:void 0;if(r)return r;let i=e.extendedTextMessage?.contextInfo??e.imageMessage?.contextInfo??e.videoMessage?.contextInfo??e.documentMessage?.contextInfo??e.audioMessage?.contextInfo??e.stickerMessage?.contextInfo??e.buttonsResponseMessage?.contextInfo??e.listResponseMessage?.contextInfo??e.templateButtonReplyMessage?.contextInfo??e.interactiveResponseMessage?.contextInfo??e.buttonsMessage?.contextInfo??e.listMessage?.contextInfo;if(i)return i;for(let t of Object.values(e)){if(!t||typeof t!=`object`||!(`contextInfo`in t))continue;let e=t.contextInfo;if(e)return e}}function ft(e){let t=Q(e);if(!t)return;let n=[t.extendedTextMessage?.contextInfo?.mentionedJid,t.extendedTextMessage?.contextInfo?.quotedMessage?.extendedTextMessage?.contextInfo?.mentionedJid,t.imageMessage?.contextInfo?.mentionedJid,t.videoMessage?.contextInfo?.mentionedJid,t.documentMessage?.contextInfo?.mentionedJid,t.audioMessage?.contextInfo?.mentionedJid,t.stickerMessage?.contextInfo?.mentionedJid,t.buttonsResponseMessage?.contextInfo?.mentionedJid,t.listResponseMessage?.contextInfo?.mentionedJid].flatMap(e=>e??[]).filter(Boolean);if(n.length!==0)return Array.from(new Set(n))}function pt(e){let t=Q(e);if(!t)return;let n=Je(t),r=[t,n&&n!==t?n:void 0];for(let e of r){if(!e)continue;if(typeof e.conversation==`string`&&e.conversation.trim())return e.conversation.trim();let t=e.extendedTextMessage?.text;if(t?.trim())return t.trim();let n=e.imageMessage?.caption??e.videoMessage?.caption??e.documentMessage?.caption;if(n?.trim())return n.trim()}let i=ht(t)??(n&&n!==t?ht(n):void 0);if(i)return i}function mt(e){let t=Q(e);if(t){if(t.imageMessage)return`<media:image>`;if(t.videoMessage)return`<media:video>`;if(t.audioMessage)return`<media:audio>`;if(t.documentMessage)return`<media:document>`;if(t.stickerMessage)return`<media:sticker>`}}function ht(e){let t=Q(e);if(!t)return;let n=t.contactMessage??void 0;if(n){let{name:e,phones:t}=gt({displayName:n.displayName,vcard:n.vcard});return _t(e,t)}let r=t.contactsArrayMessage?.contacts??void 0;if(!(!r||r.length===0))return vt(r.map(e=>gt({displayName:e.displayName,vcard:e.vcard})).map(e=>yt(e.name,e.phones)).filter(e=>!!e),r.length)}function gt(e){let t=(e.displayName??``).trim(),n=ot(e.vcard??void 0);return{name:t||n.name,phones:n.phones}}function _t(e,t){let n=yt(e,t);return n?`<contact: ${n}>`:`<contact>`}function vt(e,t){let n=e.map(e=>e.trim()).filter(Boolean);if(n.length===0)return`<contacts: ${t} ${t===1?`contact`:`contacts`}>`;let r=Math.max(t-n.length,0),i=r>0?` +${r} more`:``;return`<contacts: ${n.join(`, `)}${i}>`}function yt(e,t){let n=[e,bt(t)].filter(e=>!!e);if(n.length!==0)return n.join(`, `)}function bt(e){let t=e?.map(e=>e.trim()).filter(Boolean)??[];if(t.length===0)return;let{shown:n,remaining:r}=xt(t,t.length,1),[i]=n;if(i)return r===0?i:`${i} (+${r} more)`}function xt(e,t,n){let r=e.slice(0,n);return{shown:r,remaining:Math.max(t-r.length,0)}}function St(e){let t=Q(e);if(!t)return null;let n=t.liveLocationMessage??void 0;if(n){let e=n.degreesLatitude,t=n.degreesLongitude;if(e!=null&&t!=null){let r=Number(e),i=Number(t);if(Number.isFinite(r)&&Number.isFinite(i))return{latitude:r,longitude:i,accuracy:n.accuracyInMeters??void 0,caption:n.caption??void 0,source:`live`,isLive:!0}}}let r=t.locationMessage??void 0;if(r){let e=r.degreesLatitude,t=r.degreesLongitude;if(e!=null&&t!=null){let n=Number(e),i=Number(t);if(Number.isFinite(n)&&Number.isFinite(i)){let e=!!r.isLive;return{latitude:n,longitude:i,accuracy:r.accuracyInMeters??void 0,name:r.name??void 0,address:r.address??void 0,caption:r.comment??void 0,source:e?`live`:r.name||r.address?`place`:`pin`,isLive:e}}}}return null}function Ct(e){let t=Q(e);if(!t)return null;let n=dt(t),r=Ze(n?.quotedMessage);if(!r)return null;let i=St(r),a=i?Te(i):void 0,o=[pt(r),a].filter(Boolean).join(`
|
|
2
2
|
`).trim();if(o||=mt(r),!o){let e=r?Ye(r):void 0;return u(`Quoted message missing extractable body${e?` (type ${e})`:``}`),null}let s=n?.participant??void 0,c=s?p(s)??s:void 0,l=c??`unknown sender`;return{id:n?.stanzaId?String(n.stanzaId):void 0,body:o,sender:l,senderJid:s,senderE164:c}}function wt(e){return N({providerConfigPresent:e.providerConfigPresent,groupPolicy:e.groupPolicy,defaultGroupPolicy:e.defaultGroupPolicy})}async function Tt(e){let t=A(),n=b({cfg:t,accountId:e.accountId}),r=n.dmPolicy??`pairing`,i=n.allowFrom??[],a=await we({provider:`whatsapp`,accountId:n.accountId,dmPolicy:r}),o=i.length===0&&e.selfE164?[e.selfE164]:[],s=i.length>0?i:o,c=n.groupAllowFrom??(i.length>0?i:void 0),l=e.from===e.selfE164,d=n.selfChatMode??h(e.selfE164,i),p=typeof e.pairingGraceMs==`number`&&e.pairingGraceMs>0?e.pairingGraceMs:3e4,m=typeof e.connectedAtMs==`number`&&typeof e.messageTimestampMs==`number`&&e.messageTimestampMs<e.connectedAtMs-p,g=M(t),{groupPolicy:_,providerMissingFallbackApplied:v}=wt({providerConfigPresent:t.channels?.whatsapp!==void 0,groupPolicy:n.groupPolicy,defaultGroupPolicy:g});j({providerMissingFallbackApplied:v,providerKey:`whatsapp`,accountId:n.accountId,log:e=>u(e)});let y=f(e.from),x=typeof e.senderE164==`string`?f(e.senderE164):null,S=B({isGroup:e.group,dmPolicy:r,groupPolicy:_,allowFrom:e.group?i:s,groupAllowFrom:c,storeAllowFrom:a,isSenderAllowed:t=>{if(t.includes(`*`))return!0;let n=new Set(t.map(e=>f(String(e))).filter(e=>!!e));return!e.group&&l?!0:e.group?!!(x&&n.has(x)):n.has(y)}});if(e.group&&S.decision!==`allow`)return S.reason===`groupPolicy=disabled`?u(`Blocked group message (groupPolicy: disabled)`):S.reason===`groupPolicy=allowlist (empty allowlist)`?u(`Blocked group message (groupPolicy: allowlist, no groupAllowFrom)`):u(`Blocked group message from ${e.senderE164??`unknown sender`} (groupPolicy: allowlist)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:d,resolvedAccountId:n.accountId};if(!e.group){if(e.isFromMe&&!l)return u(`Skipping outbound DM (fromMe); no pairing reply needed.`),{allowed:!1,shouldMarkRead:!1,isSelfChat:d,resolvedAccountId:n.accountId};if(S.decision===`block`&&S.reason===`dmPolicy=disabled`)return u(`Blocked dm (dmPolicy: disabled)`),{allowed:!1,shouldMarkRead:!1,isSelfChat:d,resolvedAccountId:n.accountId};if(S.decision===`pairing`&&!l){let t=e.from;return m?u(`Skipping pairing reply for historical DM from ${t}.`):await me({channel:`whatsapp`,senderId:t,senderIdLine:`Your WhatsApp phone number: ${t}`,meta:{name:(e.pushName??``).trim()||void 0},upsertPairingRequest:async({id:e,meta:t})=>await De({channel:`whatsapp`,id:e,accountId:n.accountId,meta:t}),onCreated:()=>{u(`whatsapp pairing request sender=${t} name=${e.pushName??`unknown`}`)},sendPairingReply:async t=>{await e.sock.sendMessage(e.remoteJid,{text:t})},onReplyError:e=>{u(`whatsapp pairing reply failed for ${t}: ${String(e)}`)}}),{allowed:!1,shouldMarkRead:!1,isSelfChat:d,resolvedAccountId:n.accountId}}if(S.decision!==`allow`)return u(`Blocked unauthorized sender ${e.from} (dmPolicy=${r})`),{allowed:!1,shouldMarkRead:!1,isSelfChat:d,resolvedAccountId:n.accountId}}return{allowed:!0,shouldMarkRead:!0,isSelfChat:d,resolvedAccountId:n.accountId}}function Et(e){return Ze(e)}function Dt(e){let t=e.imageMessage?.mimetype??e.videoMessage?.mimetype??e.documentMessage?.mimetype??e.audioMessage?.mimetype??e.stickerMessage?.mimetype??void 0;if(t)return t;if(e.audioMessage)return`audio/ogg; codecs=opus`;if(e.imageMessage)return`image/jpeg`;if(e.videoMessage)return`video/mp4`;if(e.stickerMessage)return`image/webp`}async function Ot(e,t){let n=Et(e.message);if(!n)return;let r=Dt(n),i=n.documentMessage?.fileName??void 0;if(!(!n.imageMessage&&!n.videoMessage&&!n.documentMessage&&!n.audioMessage&&!n.stickerMessage))try{return{buffer:await qe(e,`buffer`,{},{reuploadRequest:t.updateMediaMessage,logger:t.logger}),mimetype:r,fileName:i}}catch(e){u(`downloadMediaMessage failed: ${String(e)}`);return}}function kt(e){Fe({channel:`whatsapp`,accountId:e,direction:`outbound`})}function At(e){return typeof e==`object`&&e&&`key`in e?String(e.key?.id??`unknown`):`unknown`}function jt(e){return{sendMessage:async(t,n,r,i,a)=>{let o=d(t),s;if(r&&i)if(i.startsWith(`image/`))s={image:r,caption:n||void 0,mimetype:i};else if(i.startsWith(`audio/`))s={audio:r,ptt:!0,mimetype:i};else if(i.startsWith(`video/`)){let e=a?.gifPlayback;s={video:r,caption:n||void 0,mimetype:i,...e?{gifPlayback:!0}:{}}}else s={document:r,fileName:a?.fileName?.trim()||`file`,caption:n||void 0,mimetype:i};else s={text:n};let c=await e.sock.sendMessage(o,s);return kt(a?.accountId??e.defaultAccountId),{messageId:At(c)}},sendPoll:async(t,n)=>{let r=d(t),i=await e.sock.sendMessage(r,{poll:{name:n.question,values:n.options,selectableCount:n.maxSelections??1}});return kt(e.defaultAccountId),{messageId:At(i)}},sendReaction:async(t,n,r,i,a)=>{let o=d(t);await e.sock.sendMessage(o,{react:{text:r,key:{remoteJid:o,id:n,fromMe:i,participant:a?d(a):void 0}}})},sendComposingTo:async t=>{let n=d(t);await e.sock.sendPresenceUpdate(`composing`,n)}}}async function Mt(e){let t=s({module:`web-inbound`}),n=l(`gateway/channels/whatsapp`).child(`inbound`),r=await Ue(!1,e.verbose,{authDir:e.authDir});await Ve(r);let i=Date.now(),o=null,c=new Promise(e=>{o=e}),d=e=>{if(!o)return;let t=o;o=null,t(e)};try{await r.sendPresenceUpdate(`available`),a()&&u(`Sent global 'available' presence on connect`)}catch(e){u(`Failed to send 'available' presence on connect: ${String(e)}`)}let f=r.user?.id,m=f?p(f):null,h=F({debounceMs:e.debounceMs??0,buildKey:e=>{let t=e.chatType===`group`?e.senderJid??e.senderE164??e.senderName??e.from:e.from;if(!t)return null;let n=e.chatType===`group`?e.chatId:e.from;return`${e.accountId}:${n}:${t}`},shouldDebounce:e.shouldDebounce,onFlush:async t=>{let n=t.at(-1);if(!n)return;if(t.length===1){await e.onMessage(n);return}let r=new Set;for(let e of t)for(let t of e.mentionedJids??[])r.add(t);let i=t.map(e=>e.body).filter(Boolean).join(`
|
|
3
3
|
`),a={...n,body:i,mentionedJids:r.size>0?Array.from(r):void 0};await e.onMessage(a)},onError:e=>{t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)}}),_=new Map,v=300*1e3,y=r.signalRepository?.lidMapping,b=async t=>g(t,{authDir:e.authDir,lidLookup:y}),x=async e=>{let t=_.get(e);if(t&&t.expires>Date.now())return t;try{let t=await r.groupMetadata(e),n=(await Promise.all(t.participants?.map(async e=>await b(e.id)??e.id)??[])).filter(Boolean)??[],i={subject:t.subject,participants:n,expires:Date.now()+v};return _.set(e,i),i}catch(t){return u(`Failed to fetch group metadata for ${e}: ${String(t)}`),{expires:Date.now()+v}}},S=async t=>{let n=t.key?.id??void 0,a=t.key?.remoteJid;if(!a||a.endsWith(`@status`)||a.endsWith(`@broadcast`))return null;let o=Xe(a)===!0;if(n&&it(`${e.accountId}:${a}:${n}`))return null;let s=t.key?.participant??void 0,c=o?a:await b(a);if(!c)return null;let l=o?s?await b(s):null:c,u,d;if(o){let e=await x(a);u=e.subject,d=e.participants}let f=t.messageTimestamp?Number(t.messageTimestamp)*1e3:void 0,p=await Tt({accountId:e.accountId,from:c,selfE164:m,senderE164:l,group:o,pushName:t.pushName??void 0,isFromMe:!!t.key?.fromMe,messageTimestampMs:f,connectedAtMs:i,sock:{sendMessage:(e,t)=>r.sendMessage(e,t)},remoteJid:a});return p.allowed?{id:n,remoteJid:a,group:o,participantJid:s,from:c,senderE164:l,groupSubject:u,groupParticipants:d,messageTimestampMs:f,access:p}:null},C=async t=>{let{id:n,remoteJid:i,participantJid:o,access:s}=t;if(n&&!s.isSelfChat&&e.sendReadReceipts!==!1)try{await r.readMessages([{remoteJid:i,id:n,participant:o,fromMe:!1}]),a()&&u(`Marked message ${n} as read for ${i}${o?` (participant ${o})`:``}`)}catch(e){u(`Failed to mark message ${n} read: ${String(e)}`)}else n&&s.isSelfChat&&a()&&u(`Self-chat mode: skipping read receipt for ${n}`)},w=async t=>{let n=St(t.message??void 0),i=n?Te(n):void 0,a=pt(t.message??void 0);if(i&&(a=[a,i].filter(Boolean).join(`
|
|
4
4
|
`).trim()),!a&&(a=mt(t.message??void 0),!a))return null;let o=Ct(t.message),s,c,l;try{let n=await Ot(t,r);if(n){let t=(typeof e.mediaMaxMb==`number`&&e.mediaMaxMb>0?e.mediaMaxMb:50)*1024*1024;s=(await ne(n.buffer,n.mimetype,`inbound`,t,n.fileName)).path,c=n.mimetype,l=n.fileName}}catch(e){u(`Inbound media download failed: ${String(e)}`)}return{body:a,location:n??void 0,replyContext:o,mediaPath:s,mediaType:c,mediaFileName:l}},T=async(e,i,a)=>{let o=i.remoteJid,s=async()=>{try{await r.sendPresenceUpdate(`composing`,o)}catch(e){u(`Presence update failed: ${String(e)}`)}},c=async e=>{await r.sendMessage(o,{text:e})},l=async e=>{await r.sendMessage(o,e)},d=i.messageTimestampMs,p=ft(e.message),g=e.pushName??void 0;t.info({from:i.from,to:m??`me`,body:a.body,mediaPath:a.mediaPath,mediaType:a.mediaType,mediaFileName:a.mediaFileName,timestamp:d},`inbound message`);let _={id:i.id,from:i.from,conversationId:i.from,to:m??`me`,accountId:i.access.resolvedAccountId,body:a.body,pushName:g,timestamp:d,chatType:i.group?`group`:`direct`,chatId:i.remoteJid,senderJid:i.participantJid,senderE164:i.senderE164??void 0,senderName:g,replyToId:a.replyContext?.id,replyToBody:a.replyContext?.body,replyToSender:a.replyContext?.sender,replyToSenderJid:a.replyContext?.senderJid,replyToSenderE164:a.replyContext?.senderE164,groupSubject:i.groupSubject,groupParticipants:i.groupParticipants,mentionedJids:p??void 0,selfJid:f,selfE164:m,fromMe:!!e.key?.fromMe,location:a.location??void 0,sendComposing:s,reply:c,sendMedia:l,mediaPath:a.mediaPath,mediaType:a.mediaType,mediaFileName:a.mediaFileName};try{Promise.resolve(h.enqueue(_)).catch(e=>{t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)})}catch(e){t.error({error:String(e)},`failed handling inbound web message`),n.error(`Failed handling inbound web message: ${String(e)}`)}},E=async t=>{if(!(t.type!==`notify`&&t.type!==`append`))for(let n of t.messages??[]){Fe({channel:`whatsapp`,accountId:e.accountId,direction:`inbound`});let r=await S(n);if(!r||(await C(r),t.type===`append`))continue;let i=await w(n);i&&await T(n,r,i)}};r.ev.on(`messages.upsert`,E);let D=e=>{try{if(e.connection===`close`){let t=He(e.lastDisconnect?.error);d({status:t,isLoggedOut:t===Ke.loggedOut,error:e.lastDisconnect?.error})}}catch(e){t.error({error:String(e)},`connection.update handler error`),d({status:void 0,isLoggedOut:!1,error:e})}};return r.ev.on(`connection.update`,D),{close:async()=>{try{let e=r.ev,t=E,n=D;typeof e.off==`function`?(e.off(`messages.upsert`,t),e.off(`connection.update`,n)):typeof e.removeListener==`function`&&(e.removeListener(`messages.upsert`,t),e.removeListener(`connection.update`,n)),r.ws?.close()}catch(e){u(`Socket close failed: ${String(e)}`)}},onClose:c,signalClose:e=>{d(e??{status:void 0,isLoggedOut:!1,error:`closed`})},...jt({sock:{sendMessage:(e,t)=>r.sendMessage(e,t),sendPresenceUpdate:(e,t)=>r.sendPresenceUpdate(e,t)},defaultAccountId:e.accountId})}}function Nt(e,t){return{mentionRegexes:W(e,t),allowFrom:e.channels?.whatsapp?.allowFrom}}function Pt(e,t){let n=t?{authDir:t}:void 0;return{normalizedMentions:e.mentionedJids?.length?e.mentionedJids.map(e=>p(e,n)??e).filter(Boolean):[],selfE164:e.selfE164??(e.selfJid?p(e.selfJid,n):null),selfJid:e.selfJid?e.selfJid.replace(/:\\d+/,``):null}}function Ft(e,t,n){let r=e=>de(e),i=h(n.selfE164,t.allowFrom);if((e.mentionedJids?.length??0)>0&&!i)return!!(n.selfE164&&n.normalizedMentions.includes(n.selfE164)||n.selfJid&&n.normalizedMentions.includes(n.selfJid));let a=r(e.body);if(t.mentionRegexes.some(e=>e.test(a)))return!0;if(n.selfE164){let t=n.selfE164.replace(/\D/g,``);if(t){if(a.replace(/[^\d]/g,``).includes(t))return!0;let n=e.body.replace(/[\s-]/g,``);if(RegExp(`\\+?${t}`,`i`).test(n))return!0}}return!1}function It(e,t,n){let r=Pt(e,n);return{wasMentioned:Ft(e,t,r),details:{from:e.from,body:e.body,bodyClean:de(e.body),mentionedJids:e.mentionedJids??null,normalizedMentionedJids:r.normalizedMentions.length?r.normalizedMentions:null,selfJid:e.selfJid??null,selfJidBare:r.selfJid,selfE164:e.selfE164??null,resolvedSelfE164:r.selfE164}}}function Lt(e,t){let n=e.allowFrom;return(Array.isArray(n)&&n.length>0?n:t?[t]:[]).filter(e=>!!(e&&e!==`*`)).map(e=>f(e)).filter(e=>!!e)}function Rt(e){let t=new Set,n=Math.max(1,e.maxItems??100),r=e=>`combined:${e.sessionKey}:${e.combinedBody}`,i=()=>{for(;t.size>n;){let e=t.values().next().value;if(!e)break;t.delete(e)}};return{rememberText:(n,a)=>{n&&(t.add(n),a.combinedBody&&a.combinedBodySessionKey&&t.add(r({sessionKey:a.combinedBodySessionKey,combinedBody:a.combinedBody})),a.logVerboseMessage&&e.logVerbose?.(`Added to echo detection set (size now: ${t.size}): ${n.substring(0,50)}...`),i())},has:e=>t.has(e),forget:e=>{t.delete(e)},buildCombinedKey:r}}function zt(t){let n=fe({agentId:t.agentId,channel:`whatsapp`,accountId:t.route.accountId,peer:{kind:t.msg.chatType===`group`?`group`:`direct`,id:t.peerId},dmScope:t.cfg.session?.dmScope,identityLinks:t.cfg.session?.identityLinks}),r=i({agentId:t.agentId,mainKey:e});return{sessionKey:n,mainSessionKey:r,lastRoutePolicy:K({sessionKey:n,mainSessionKey:r})}}async function Bt(e){let t=e.cfg.broadcast?.[e.peerId];if(!t||!Array.isArray(t)||t.length===0)return!1;let r=e.cfg.broadcast?.strategy||`parallel`;X.info(`Broadcasting message to ${t.length} agents (${r})`);let i=e.cfg.agents?.list?.map(e=>n(e.id)),a=(i?.length??0)>0,o=e.msg.chatType===`group`?e.groupHistories.get(e.groupHistoryKey)??[]:void 0,s=async t=>{let r=n(t);if(a&&!i?.includes(r))return X.warn(`Broadcast agent ${t} not found in agents.list; skipping`),!1;let s=zt({cfg:e.cfg,msg:e.msg,route:e.route,peerId:e.peerId,agentId:r}),c={...e.route,agentId:r,...s};try{return await e.processMessage(e.msg,c,e.groupHistoryKey,{groupHistory:o,suppressGroupHistoryClear:!0})}catch(e){return X.error(`Broadcast agent ${t} failed: ${q(e)}`),!1}};if(r===`sequential`)for(let e of t)await s(e);else await Promise.allSettled(t.map(s));return e.msg.chatType===`group`&&e.groupHistories.set(e.groupHistoryKey,[]),!0}function Vt(e,t,n){let r=e;for(let e of t)r=r.replace(e,` `);if(n){let e=n.replace(/\D/g,``);if(e){let t=RegExp(`\\+?${e}`,`g`);r=r.replace(t,` `)}}return r.replace(/\s+/g,` `).trim()}function Ht(e,t){let n=D({From:t,ChatType:`group`,Provider:`whatsapp`})?.id,r=e.channels?.whatsapp,i=!!(r?.groupAllowFrom?.length||r?.allowFrom?.length);return O({cfg:e,channel:`whatsapp`,groupId:n??t,hasGroupAllowFrom:i})}function Ut(e,t){let n=D({From:t,ChatType:`group`,Provider:`whatsapp`})?.id;return k({cfg:e,channel:`whatsapp`,groupId:n??t})}function Wt(e){let t=w(r(e.cfg.session?.store,{agentId:e.agentId}))[e.sessionKey],n=Ut(e.cfg,e.conversationId)?`mention`:`always`;return pe(t?.groupActivation)??n}function Gt(e,t,n){for(let r of e){let e=f(r)??r;!e||t.has(e)||(t.add(e),n.push(e))}}function Kt(e,t,n,r){if(!n||!r)return;let i=f(n)??n;if(!i)return;let a=e.get(t);a||(a=new Map,e.set(t,a)),a.set(i,r)}function qt(e){let{participants:t,roster:n,fallbackE164:r}=e,i=new Set,a=[];if(t?.length&&Gt(t,i,a),n&&Gt(n.keys(),i,a),a.length===0&&r){let e=f(r)??r;e&&a.push(e)}if(a.length!==0)return a.map(e=>{let t=n?.get(e);return t?`${t} (${e})`:e}).join(`, `)}function Jt(e,t){let n=f(t.senderE164??``);return n?Lt(e,t.selfE164??void 0).includes(n):!1}function Yt(e){let t=e.msg.senderName&&e.msg.senderE164?`${e.msg.senderName} (${e.msg.senderE164})`:e.msg.senderName??e.msg.senderE164??`Unknown`;ve({historyMap:e.groupHistories,historyKey:e.groupHistoryKey,limit:e.groupHistoryLimit,entry:{sender:t,body:e.msg.body,timestamp:e.msg.timestamp,id:e.msg.id,senderJid:e.msg.senderJid}})}function Xt(e,t){return e.logVerbose(t),Yt({msg:e.msg,groupHistories:e.groupHistories,groupHistoryKey:e.groupHistoryKey,groupHistoryLimit:e.groupHistoryLimit}),{shouldProcess:!1}}function Zt(e){let t=Ht(e.cfg,e.conversationId);if(t.allowlistEnabled&&!t.allowed)return e.logVerbose(`Skipping group message ${e.conversationId} (not in allowlist)`),{shouldProcess:!1};Kt(e.groupMemberNames,e.groupHistoryKey,e.msg.senderE164,e.msg.senderName);let n=Nt(e.cfg,e.agentId),r=Vt(e.msg.body,n.mentionRegexes,e.msg.selfE164),i=_e(r),a=Jt(e.baseMentionConfig,e.msg),o=a&&re(r,e.cfg);if(i.hasCommand&&!a)return Xt(e,`Ignoring /activation from non-owner in group ${e.conversationId}`);let s=It(e.msg,n,e.authDir);e.replyLogger.debug({conversationId:e.conversationId,wasMentioned:s.wasMentioned,...s.details},`group mention debug`);let c=s.wasMentioned,l=Wt({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:e.conversationId})!==`always`,u=e.msg.selfJid?.replace(/:\\d+/,``),d=e.msg.replyToSenderJid?.replace(/:\\d+/,``),p=e.msg.selfE164?f(e.msg.selfE164):null,m=e.msg.replyToSenderE164?f(e.msg.replyToSenderE164):null,h=V({requireMention:l,canDetectMention:!0,wasMentioned:c,implicitMention:!!(u&&d&&u===d||p&&m&&p===m),shouldBypassMention:o});return e.msg.wasMentioned=h.effectiveWasMentioned,!o&&l&&h.shouldSkip?Xt(e,`Group message stored for context (no mention detected) in ${e.conversationId}: ${e.msg.body}`):{shouldProcess:!0}}function Qt(e,t){e.add(t),t.finally(()=>{e.delete(t)})}function $t(e){let t=r(e.cfg.session?.store,{agentId:e.storeAgentId}),n=S({storePath:t,sessionKey:e.sessionKey,deliveryContext:{channel:e.channel,to:e.to,accountId:e.accountId},ctx:e.ctx}).catch(n=>{e.warn({error:q(n),storePath:t,sessionKey:e.sessionKey,to:e.to},`failed updating last route`)});Qt(e.backgroundTasks,n)}function en(e){return e.chatType===`group`?e.conversationId??e.from:e.senderE164?f(e.senderE164)??e.senderE164:e.from.includes(`@`)?p(e.from)??e.from:f(e.from)??e.from}function $(e,t=400){return!e||e.length<=t?e:`${e.slice(0,t)}… (truncated ${e.length-t} chars)`}function tn(e){let t=(e instanceof Error?`${e.message}\n${e.stack??``}`:(e=>{if(e==null)return``;if(typeof e==`string`)return e;if(e instanceof Error)return`${e.message}\n${e.stack??``}`;if(typeof e==`object`)try{return JSON.stringify(e)}catch{return Object.prototype.toString.call(e)}return typeof e==`number`||typeof e==`boolean`||typeof e==`bigint`?String(e):typeof e==`symbol`?e.description??e.toString():typeof e==`function`?e.name?`[function ${e.name}]`:`[function]`:Object.prototype.toString.call(e)})(e)).toLowerCase();return t.includes(`unsupported state or unable to authenticate data`)||t.includes(`bad mac`)?t.includes(`@whiskeysockets/baileys`)||t.includes(`baileys`)||t.includes(`noise-handler`)||t.includes(`aesdecryptgcm`):!1}function nn(e){if(e.isReasoning===!0)return!0;let t=e.text;return typeof t==`string`?t.trimStart().toLowerCase().startsWith(`reasoning:`):!1}async function rn(e){let{replyResult:t,msg:n,maxMediaBytes:r,textLimit:i,replyLogger:s,connectionId:c,skipLog:l}=e,d=Date.now();if(nn(t)){Z.debug(`Suppressed reasoning payload to ${n.from}`);return}let f=e.tableMode??`code`,p=e.chunkMode??`length`,m=Ae(Re(Ie(t.text||``,f)),i,p),h=t.mediaUrls?.length?t.mediaUrls:t.mediaUrl?[t.mediaUrl]:[],g=async(e,t,r=3)=>{let i;for(let a=1;a<=r;a++)try{return await e()}catch(e){i=e;let s=q(e),c=a===r;if(!/closed|reset|timed\s*out|disconnect/i.test(s)||c)throw e;let l=500*a;u(`Retrying ${t} to ${n.from} after failure (${a}/${r-1}) in ${l}ms: ${s}`),await o(l)}throw i};if(h.length===0&&m.length){let e=m.length;for(let[t,r]of m.entries()){let i=Date.now();if(await g(()=>n.reply(r),`text`),!l){let r=Date.now()-i;Z.debug(`Sent chunk ${t+1}/${e} to ${n.from} (${r.toFixed(0)}ms)`)}}s.info({correlationId:n.id??J(),connectionId:c??null,to:n.from,from:n.to,text:$(t.text,240),mediaUrl:null,mediaSizeBytes:null,mediaKind:null,durationMs:Date.now()-d},`auto-reply sent (text)`);return}let _=[...m];for(let[t,i]of h.entries()){let o=t===0&&_.shift()||void 0;try{let t=await ke(i,{maxBytes:r,localRoots:e.mediaLocalRoots});if(a()&&(u(`Web auto-reply media size: ${(t.buffer.length/(1024*1024)).toFixed(2)}MB`),u(`Web auto-reply media source: ${i} (kind ${t.kind})`)),t.kind===`image`)await g(()=>n.sendMedia({image:t.buffer,caption:o,mimetype:t.contentType}),`media:image`);else if(t.kind===`audio`)await g(()=>n.sendMedia({audio:t.buffer,ptt:!0,mimetype:t.contentType,caption:o}),`media:audio`);else if(t.kind===`video`)await g(()=>n.sendMedia({video:t.buffer,caption:o,mimetype:t.contentType}),`media:video`);else{let e=t.fileName??i.split(`/`).pop()??`file`,r=t.contentType??`application/octet-stream`;await g(()=>n.sendMedia({document:t.buffer,fileName:e,caption:o,mimetype:r}),`media:document`)}Z.info(`Sent media reply to ${n.from} (${(t.buffer.length/(1024*1024)).toFixed(2)}MB)`),s.info({correlationId:n.id??J(),connectionId:c??null,to:n.from,from:n.to,text:o??null,mediaUrl:i,mediaSizeBytes:t.buffer.length,mediaKind:t.kind,durationMs:Date.now()-d},`auto-reply sent (media)`)}catch(e){if(Z.error(`Failed sending web media to ${n.from}: ${q(e)}`),s.warn({err:e,mediaUrl:i},`failed to send web media reply`),t===0){let t=e instanceof Error?`⚠️ Media failed: ${e.message}`:`⚠️ Media failed.`,r=[_.shift()??o??``,t].filter(Boolean).join(`
|