@qqbrowser/openclaw-qbot 0.0.127 → 0.0.129
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/account-lookup-CW-_CL7y.js +1 -1
- package/dist/acp-cli-01SGjPGi.js +1 -1
- package/dist/acp-cli-uxN405XG.js +1 -1
- package/dist/active-listener-BZ6loNaF.js +1 -1
- package/dist/active-listener-D8VOdVx3.js +1 -1
- package/dist/active-listener-DB5mhDuO.js +1 -1
- package/dist/active-listener-DeKRt_UV.js +1 -1
- package/dist/agent-scope-DAWJwFfl.js +1 -1
- package/dist/agent-scope-DXZc3eNT.js +1 -1
- package/dist/agents-BMh3ZeoB.js +1 -1
- package/dist/agents.config-B-0lZSmb.js +1 -1
- package/dist/agents.config-BDEN2Eph.js +1 -1
- package/dist/allow-from-B6dI7oz8.js +1 -1
- package/dist/allow-from-DEeVIPKS.js +1 -1
- package/dist/api-BeG0ObSq.js +1 -1
- package/dist/api-Dx8x1KTs.js +1 -1
- package/dist/api-key-rotation-C_MG2y1D.js +1 -1
- package/dist/api-key-rotation-D8WsZ43x.js +1 -1
- package/dist/api-key-rotation-DYYvcqSG.js +1 -1
- package/dist/api-key-rotation-dNu0GxPN.js +1 -1
- package/dist/arg-split-BOqSMBuf.js +1 -1
- package/dist/arg-split-DE5RqDHq.js +1 -1
- package/dist/audio-preflight--K4-eUVY.js +1 -1
- package/dist/audio-preflight-BKIm58PG.js +1 -1
- package/dist/audio-preflight-CAfi10dl.js +1 -1
- package/dist/audio-preflight-Xm0NL5JA.js +1 -1
- package/dist/audio-transcription-runner-BJNP7vB8.js +1 -1
- package/dist/audio-transcription-runner-BUsb6cqv.js +1 -1
- package/dist/audio-transcription-runner-C_31Yoq0.js +1 -1
- package/dist/audio-transcription-runner-CjKLRVPo.js +1 -1
- package/dist/audit-7DFnKINd.js +1 -1
- package/dist/audit-B6LsW3Ai.js +1 -1
- package/dist/audit-membership-runtime-BpRsMj5-.js +1 -1
- package/dist/audit-membership-runtime-BsfLZNBj.js +1 -1
- package/dist/audit-membership-runtime-DRHirRmx.js +1 -1
- package/dist/audit-membership-runtime-g0dEWJTp.js +1 -1
- package/dist/audit-membership-runtime-kdyToskD.js +1 -1
- package/dist/auth-choice-BNd2SNjJ.js +1 -1
- package/dist/auth-choice-C3aUWXx9.js +1 -1
- package/dist/auth-choice-DViEjgMg.js +1 -1
- package/dist/auth-choice-edozMf7r.js +1 -1
- package/dist/auth-choice-options-B3WQyS7I.js +1 -1
- package/dist/auth-choice-options-Dw14noox.js +1 -1
- package/dist/auth-choice-prompt-uegl56cf.js +1 -1
- package/dist/auth-choice-prompt-xYj13czb.js +1 -1
- package/dist/auth-choice.apply-helpers-CNLYnRxx.js +1 -1
- package/dist/auth-choice.apply-helpers-DCe5nTyP.js +1 -1
- package/dist/auth-profiles-BhXA8Jy2.js +1 -1
- package/dist/auth-token-C75IOb_K.js +1 -1
- package/dist/auth-token-CzgZf-ta.js +1 -1
- package/dist/banner-mIDEloRy.js +1 -1
- package/dist/bonjour-discovery-CpvzLjyB.js +1 -1
- package/dist/bonjour-discovery-wsh3Si1Q.js +1 -1
- package/dist/boolean-Ch3DfXPy.js +1 -1
- package/dist/boolean-D15s2V33.js +1 -1
- package/dist/boolean-DypnRoRK.js +1 -1
- package/dist/brew-COcDl8CB.js +1 -1
- package/dist/brew-DDPm_HfE.js +1 -1
- package/dist/browser-cli-BjzNbvF9.js +1 -1
- package/dist/browser-cli-CgHkgtgV.js +1 -1
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +1 -1
- package/dist/bundled/bootstrap-extra-files/handler.js +1 -1
- package/dist/bundled/command-logger/handler.js +1 -1
- package/dist/bundled/session-memory/handler.js +1 -1
- package/dist/call-BA3O_Qpl.js +1 -1
- package/dist/call-BQT0zCgv.js +1 -1
- package/dist/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/channel-account-context-BMPAMZEv.js +1 -1
- package/dist/channel-account-context-DAcarnqW.js +1 -1
- package/dist/channel-activity-B04WbrrK.js +1 -1
- package/dist/channel-activity-BPRCQpI6.js +1 -1
- package/dist/channel-activity-D2VTmenR.js +1 -1
- package/dist/channel-activity-DHY5wAyl.js +1 -1
- package/dist/channel-activity-DYpm-0Cz.js +1 -1
- package/dist/channel-options-BYmHreMn.js +1 -1
- package/dist/channel-options-Cbv7VETu.js +1 -1
- package/dist/channel-selection-Ddyykqxv.js +1 -1
- package/dist/channel-selection-oRONo9z3.js +1 -1
- package/dist/channel-web-CK4RqVCH.js +1 -1
- package/dist/channel-web-Xw89Exy3.js +1 -1
- package/dist/channels/plugins/actions/discord.js +1 -1
- package/dist/channels/plugins/actions/signal.js +1 -1
- package/dist/channels/plugins/actions/telegram.js +1 -1
- package/dist/channels/plugins/agent-tools/whatsapp-login.js +1 -1
- package/dist/channels-cli-D2y5Xk5i.js +1 -1
- package/dist/channels-cli-cwFjBXcP.js +1 -1
- package/dist/channels-status-issues-8eFrGKyf.js +1 -1
- package/dist/channels-status-issues-PRgOT90w.js +1 -1
- package/dist/chat-envelope-Bznn2SoS.js +1 -1
- package/dist/chat-envelope-HVpKusFc.js +1 -1
- package/dist/clack-prompter-DBPdGdqp.js +1 -1
- package/dist/clack-prompter-Dq0aY6iM.js +1 -1
- package/dist/clawbot-cli-BwG1-8A9.js +1 -1
- package/dist/clawbot-cli-CaNu5A0G.js +1 -1
- package/dist/cleanup-utils-BWm70DoD.js +1 -1
- package/dist/cleanup-utils-D-RhEX6F.js +1 -1
- package/dist/cli-CQKA38bc.js +1 -1
- package/dist/cli-i7P4bYBg.js +1 -1
- package/dist/cli-utils-BY7dLMFy.js +1 -1
- package/dist/cli-utils-BleB1eys.js +1 -1
- package/dist/clipboard-Bk8cviBt.js +1 -1
- package/dist/clipboard-CKT_VIkG.js +1 -1
- package/dist/cmd-argv-BBT5l8AV.js +1 -1
- package/dist/cmd-argv-Bh-KpaZ0.js +1 -1
- package/dist/command-format-BbDT1tlm.js +1 -1
- package/dist/command-format-CLxIPuLR.js +1 -1
- package/dist/command-options-BpOUDl2S.js +1 -1
- package/dist/command-options-Bq5nQxz6.js +1 -1
- package/dist/command-poll-backoff-BZLHYB2k.js +1 -1
- package/dist/command-poll-backoff-Cww_r-24.js +1 -1
- package/dist/command-poll-backoff-Df6cOQrX.js +1 -1
- package/dist/command-poll-backoff-endAPdwn.js +1 -1
- package/dist/command-registry-BYk36N_R.js +1 -1
- package/dist/command-secret-targets-BBTiqQKa.js +1 -1
- package/dist/command-secret-targets-KM3OecbM.js +1 -1
- package/dist/commands-CGpM84iR.js +1 -1
- package/dist/commands-Dy7duWlt.js +1 -1
- package/dist/commands-registry-B3FI6TSl.js +1 -1
- package/dist/commands-registry-CxDVU5s9.js +1 -1
- package/dist/commands-registry-Dn2uuNuy.js +1 -1
- package/dist/commands-registry-Du79fdAL.js +1 -1
- package/dist/compact-CuBCVnVS.js +1 -1
- package/dist/completion-cli-CRNTbZlR.js +1 -1
- package/dist/completion-cli-DbGDCoiM.js +1 -1
- package/dist/config-BqW5S1xL.js +1 -1
- package/dist/config-DAQjvwZw.js +1 -1
- package/dist/config-cli-D_coAWd9.js +1 -1
- package/dist/config-cli-EKXoNzLf.js +1 -1
- package/dist/config-guard-U0wlYLUN.js +1 -1
- package/dist/config-guard-XayIkveC.js +1 -1
- package/dist/config-validation-B0nN9egx.js +1 -1
- package/dist/config-validation-CAHnpjrk.js +1 -1
- package/dist/configure-DNnQRKy8.js +1 -1
- package/dist/configure-NCNskZPe.js +1 -1
- package/dist/connection-auth-BcPbGyxw.js +1 -1
- package/dist/connection-auth-DZ-3Svr_.js +1 -1
- package/dist/context-window-guard-7crlatf9.js +1 -1
- package/dist/context-window-guard-CPChk363.js +1 -1
- package/dist/control-ui/apple-touch-icon.png +0 -0
- package/dist/control-ui/assets/de-DuUYLvt1.js +1 -0
- package/dist/control-ui/assets/es-DHtyqUQZ.js +1 -0
- package/dist/control-ui/assets/index-CYbiPp9k.js +8383 -0
- package/dist/control-ui/assets/index-C_GaJ8wS.css +1 -0
- package/dist/control-ui/assets/pt-BR-D2dJb9G8.js +1 -0
- package/dist/control-ui/assets/zh-CN-BgJ8_lE3.js +1 -0
- package/dist/control-ui/assets/zh-TW-cW5xB87I.js +1 -0
- package/dist/control-ui/favicon-32.png +0 -0
- package/dist/control-ui/favicon.ico +0 -0
- package/dist/control-ui/favicon.svg +22 -0
- package/dist/control-ui/index.html +17 -0
- package/dist/control-ui-assets-BIa0GGDg.js +1 -1
- package/dist/control-ui-assets-CTHGGgaX.js +1 -1
- package/dist/cron-cli-Cro66JtU.js +1 -1
- package/dist/cron-cli-DIeBukvk.js +1 -1
- package/dist/daemon-cli-Cw_fxNgE.js +1 -1
- package/dist/daemon-cli-DQsKS3pT.js +1 -1
- package/dist/daemon-cli.js +1 -1
- package/dist/daemon-install-C_DmJEkV.js +1 -1
- package/dist/daemon-install-D1DacLbM.js +1 -1
- package/dist/daemon-install-plan.shared-BSDdwWjB.js +1 -1
- package/dist/daemon-install-plan.shared-Dx3DBXCG.js +1 -1
- package/dist/daemon-runtime-DHiDbRuC.js +1 -1
- package/dist/daemon-runtime-VcpeBRJV.js +1 -1
- package/dist/dangerous-name-matching-BOmvAibz.js +1 -1
- package/dist/dangerous-name-matching-DtllRqBD.js +1 -1
- package/dist/dangerous-tools-CFRYQJ6V.js +1 -1
- package/dist/dangerous-tools-oYCu5wfC.js +1 -1
- package/dist/deliver-2c-EsQ_W.js +1 -1
- package/dist/deliver-BudDnEIb.js +1 -1
- package/dist/deliver-COKdxPmA.js +1 -1
- package/dist/deliver-DHP2vHKB.js +1 -1
- package/dist/delivery-queue-CKbauSFq.js +1 -1
- package/dist/delivery-queue-nkPJu0fY.js +1 -1
- package/dist/device-pairing-4eDo43Kk.js +1 -1
- package/dist/device-pairing-B7ZXiXp3.js +1 -1
- package/dist/devices-cli-BXUIb_UN.js +1 -1
- package/dist/devices-cli-D7PkbnHO.js +1 -1
- package/dist/diagnostic-Bzd5vlKH.js +1 -1
- package/dist/diagnostic-CFmHdXHP.js +1 -1
- package/dist/diagnostic-CW_Jv5UM.js +1 -1
- package/dist/diagnostic-Dza7-pMC.js +1 -1
- package/dist/diagnostics-BgbeL9KE.js +1 -1
- package/dist/diagnostics-Cdctg9K_.js +1 -1
- package/dist/directory-cli-CxeuNJcC.js +1 -1
- package/dist/directory-cli-DFlYCB5L.js +1 -1
- package/dist/dns-cli-BDbHznhi.js +1 -1
- package/dist/dns-cli-OuwliJ60.js +1 -1
- package/dist/docs-cli-Cdw9Iz9a.js +1 -1
- package/dist/docs-cli-ClD2UyX1.js +1 -1
- package/dist/doctor-completion-BSOX-LSq.js +1 -1
- package/dist/doctor-completion-DXqdpdlo.js +1 -1
- package/dist/doctor-config-flow-DHB8N7tT.js +1 -1
- package/dist/doctor-config-flow-MjfHBDlw.js +1 -1
- package/dist/enable-DVuqWT2a.js +1 -1
- package/dist/enable-DWaSH1HY.js +1 -1
- package/dist/entry-status-CCwwKO43.js +1 -1
- package/dist/entry-status-CoXkbJcX.js +1 -1
- package/dist/entry.js +1 -1
- package/dist/env-D7wNuBx1.js +1 -1
- package/dist/env-overrides-DHtB4kK3.js +1 -1
- package/dist/env-overrides-DXJbFrwI.js +1 -1
- package/dist/errors-6SQWM9dj.js +1 -1
- package/dist/errors-Bunti32V.js +1 -1
- package/dist/exec-B3eleY5O.js +1 -1
- package/dist/exec-DHqLtFYt.js +1 -1
- package/dist/exec-approvals-BXO9Cezj.js +1 -1
- package/dist/exec-approvals-BpBNEy6i.js +1 -1
- package/dist/exec-approvals-allowlist-BKFaHvA5.js +1 -1
- package/dist/exec-approvals-allowlist-DBh9Pm77.js +1 -1
- package/dist/exec-approvals-cli-0neCwpk-.js +1 -1
- package/dist/exec-approvals-cli-BuHSw09B.js +1 -1
- package/dist/exec-safe-bin-runtime-policy-Ck3GO5AB.js +1 -1
- package/dist/exec-safe-bin-runtime-policy-D2WexijZ.js +1 -1
- package/dist/fetch-BI3CnKE3.js +1 -1
- package/dist/fetch-BJT3BrkJ.js +1 -1
- package/dist/fetch-Bn0mWg6a.js +1 -1
- package/dist/fetch-CY5G3PDq.js +1 -1
- package/dist/fetch-Ce-scEU-.js +1 -1
- package/dist/fetch-D0rZDHKO.js +1 -1
- package/dist/fetch-DHo17YmK.js +1 -1
- package/dist/fetch-Dh-apy46.js +1 -1
- package/dist/fetch-Dikjvc5M.js +1 -1
- package/dist/fetch-DsjPfQlp.js +1 -1
- package/dist/fetch-_g8lZ8K8.js +1 -1
- package/dist/fetch-guard-BaRbr_V6.js +1 -1
- package/dist/fetch-guard-BmNIhXP-.js +1 -1
- package/dist/fetch-guard-ChVqc0HF.js +1 -1
- package/dist/fetch-guard-Cji70DJW.js +1 -1
- package/dist/fetch-hy0JKSsm.js +1 -1
- package/dist/fetch-timeout-CdYxWG9w.js +1 -1
- package/dist/fetch-timeout-Cj8_oAls.js +1 -1
- package/dist/fetch-timeout-DoOI_izT.js +1 -1
- package/dist/fetch-timeout-u8g99Ax0.js +1 -1
- package/dist/fetch-xT2jRpqs.js +1 -1
- package/dist/format-Bn1bwJKX.js +1 -1
- package/dist/format-Ce7I7s-k.js +1 -1
- package/dist/format-duration-C8AzNqKh.js +1 -1
- package/dist/format-duration-D5AMtmHa.js +1 -1
- package/dist/format-relative-B9pSIdGe.js +1 -1
- package/dist/format-relative-DkMjYy7z.js +1 -1
- package/dist/frontmatter-BkZkwkVO.js +1 -1
- package/dist/frontmatter-C7mzDNxd.js +1 -1
- package/dist/frontmatter-CzpfPBFl.js +1 -1
- package/dist/gateway-cli-Bj-BYgGN.js +1 -1
- package/dist/gateway-cli-DP65otLl.js +1 -1
- package/dist/gateway-install-token-BIqlEgy0.js +1 -1
- package/dist/gateway-install-token-CtUJl3A3.js +1 -1
- package/dist/gateway-rpc-DJHjmEZz.js +1 -1
- package/dist/gateway-rpc-XRAMeV67.js +1 -1
- package/dist/github-copilot-token-C79yeDKS.js +1 -1
- package/dist/github-copilot-token-DGYAlOmV.js +1 -1
- package/dist/github-copilot-token-DePP-lIf.js +1 -1
- package/dist/github-copilot-token-wm6mbypz.js +1 -1
- package/dist/gmail-setup-utils-CYOH3zzx.js +1 -1
- package/dist/gmail-setup-utils-S-MyEGuj.js +1 -1
- package/dist/group-access-BHKVOhrj.js +1 -1
- package/dist/group-access-D2DOYMfr.js +1 -1
- package/dist/health-Bedsiigi.js +1 -1
- package/dist/health-Cy_CvKbX.js +1 -1
- package/dist/health-format-B1nj3Wfn.js +1 -1
- package/dist/health-format-VBr6LEpt.js +1 -1
- package/dist/heartbeat-visibility-BQ_esv2m.js +1 -1
- package/dist/heartbeat-visibility-q74UdY8O.js +1 -1
- package/dist/help-format-B4aEI7V9.js +1 -1
- package/dist/help-format-BRbF_INg.js +1 -1
- package/dist/helpers-COz1ghcB.js +1 -1
- package/dist/helpers-Cp8gcO6u.js +1 -1
- package/dist/hooks-cli-DrnH2iDk.js +1 -1
- package/dist/hooks-cli-DvfZKyZl.js +1 -1
- package/dist/hooks-status-BHt-Xvh4.js +1 -1
- package/dist/hooks-status-CRJ4J0ZW.js +1 -1
- package/dist/image-BJC11A7e.js +1 -1
- package/dist/image-BKPxWO_2.js +1 -1
- package/dist/image-Ba-mOMMV.js +1 -1
- package/dist/image-D-R3N1it.js +1 -1
- package/dist/index.js +1 -1
- package/dist/inspect-BKV-I1UE.js +1 -1
- package/dist/inspect-z59cgmYc.js +1 -1
- package/dist/install-safe-path-C6kc_8NW.js +1 -1
- package/dist/install-safe-path-iesxijn2.js +1 -1
- package/dist/installs-BNeI_oML.js +1 -1
- package/dist/installs-C1xQLuby.js +1 -1
- package/dist/ipv4-BXZDlz5C.js +1 -1
- package/dist/ipv4-BnPLbv6y.js +1 -1
- package/dist/ir-BYCrFFZ9.js +1 -1
- package/dist/ir-CH7YvSi9.js +1 -1
- package/dist/ir-CSysIkNU.js +1 -1
- package/dist/ir-CZdZsdnI.js +1 -1
- package/dist/is-main-DG5ueqhF.js +1 -1
- package/dist/issue-format-CpTuk_rQ.js +1 -1
- package/dist/issue-format-kj7FXHhi.js +1 -1
- package/dist/kill-tree-DBJW8_Q-.js +1 -1
- package/dist/lifecycle-core-B72WHNHV.js +1 -1
- package/dist/lifecycle-core-dhkH_Nux.js +1 -1
- package/dist/line/accounts.js +1 -1
- package/dist/line/send.js +1 -1
- package/dist/line/template-messages.js +1 -1
- package/dist/links-CBnmRP9D.js +1 -1
- package/dist/links-CySwdMcF.js +1 -1
- package/dist/llm-slug-generator.js +1 -1
- package/dist/load-options-BsOW74dp.js +1 -1
- package/dist/load-options-C7dLuybp.js +1 -1
- package/dist/load-options-DV4j6Aqb.js +1 -1
- package/dist/load-options-Dwt0CeEg.js +1 -1
- package/dist/local-roots-Dxioh0C2.js +1 -1
- package/dist/logger-5W0OocJW.js +1 -1
- package/dist/logger-Bl8URnrW.js +1 -1
- package/dist/logger-DwWqfo66.js +1 -1
- package/dist/logger-kQAOe3qp.js +1 -1
- package/dist/logging-Dz4Qg6th.js +1 -1
- package/dist/logging-KiJmOmw4.js +1 -1
- package/dist/login-BMZxDYaU.js +1 -1
- package/dist/login-BdzP8F8J.js +1 -1
- package/dist/login-BzU0cMck.js +1 -1
- package/dist/login-Cb1A6qwM.js +1 -1
- package/dist/login-qr-BgsmAwKm.js +1 -1
- package/dist/login-qr-Bux8gWTO.js +1 -1
- package/dist/login-qr-COr_25Hx.js +1 -1
- package/dist/login-qr-CxBPOOAK.js +1 -1
- package/dist/login-qr-DnQm7bM4.js +1 -1
- package/dist/logs-cli-BM2XCmrH.js +1 -1
- package/dist/logs-cli-HKhyxaUs.js +1 -1
- package/dist/manager-B6zZuJEB.js +1 -1
- package/dist/manager-BwrZfep3.js +1 -1
- package/dist/manager-C5SBozw4.js +1 -1
- package/dist/manager-CjihRbGa.js +1 -1
- package/dist/memory-cli-CnruTL1h.js +1 -1
- package/dist/memory-cli-DHvscp7X.js +1 -1
- package/dist/model-catalog-BLdaFmIo.js +1 -1
- package/dist/model-catalog-vNCcsy4h.js +1 -1
- package/dist/model-param-b-B0r2cPDw.js +1 -1
- package/dist/model-param-b-BqIr5rY5.js +1 -1
- package/dist/model-picker-BaeW3tiV.js +1 -1
- package/dist/model-picker-DN0czUYS.js +1 -1
- package/dist/model-selection-C2QwHmXT.js +1 -1
- package/dist/model-selection-I1ctjFOB.js +1 -1
- package/dist/model-selection-qkByRv5A.js +1 -1
- package/dist/models-UTdl0vXO.js +1 -1
- package/dist/models-cli-QRONP7EL.js +1 -1
- package/dist/models-cli-vRoB_gfX.js +1 -1
- package/dist/models-config-CWIlroKT.js +1 -1
- package/dist/models-config-DN2Q51fC.js +1 -1
- package/dist/mutable-allowlist-detectors-C4rNVag8.js +1 -1
- package/dist/mutable-allowlist-detectors-CL0qe54J.js +1 -1
- package/dist/node-cli-2-E4-83G.js +1 -1
- package/dist/node-cli-DUI7Zctj.js +1 -1
- package/dist/node-command-policy-Bbmnc16l.js +1 -1
- package/dist/node-command-policy-DgkwfoCs.js +1 -1
- package/dist/node-commands-8GBOiktk.js +1 -1
- package/dist/node-commands-DdkziOTx.js +1 -1
- package/dist/node-resolve-B3BJbmQX.js +1 -1
- package/dist/node-resolve-DLZf3-1V.js +1 -1
- package/dist/node-service-BRfrNp8l.js +1 -1
- package/dist/node-service-C0bl7jcZ.js +1 -1
- package/dist/node-shell-dXp4vk-i.js +1 -1
- package/dist/nodes-cli-DU13-dCL.js +1 -1
- package/dist/nodes-cli-rPeIRj_f.js +1 -1
- package/dist/nodes-screen-C7-5RrbN.js +1 -1
- package/dist/note-D4GAwgha.js +1 -1
- package/dist/note-Dp-d_utk.js +1 -1
- package/dist/npm-pack-install-B23L-AtF.js +1 -1
- package/dist/npm-pack-install-C0te3Oap.js +1 -1
- package/dist/npm-resolution-BCXCw93f.js +1 -1
- package/dist/npm-resolution-Cmm82lui.js +1 -1
- package/dist/oauth-env-DAamJ1oz.js +1 -1
- package/dist/oauth-env-DSLBTWb1.js +1 -1
- package/dist/oauth-tls-preflight-BSBRDIfC.js +1 -1
- package/dist/oauth-tls-preflight-ByNjbUR5.js +1 -1
- package/dist/ollama-setup-CKt3tF-S.js +1 -1
- package/dist/ollama-setup-I8lghdX1.js +1 -1
- package/dist/onboard-B3WSjKCu.js +1 -1
- package/dist/onboard-C65vdb94.js +1 -1
- package/dist/onboard-channels-9CmG3Jgn.js +1 -1
- package/dist/onboard-channels-CV1AK9jY.js +1 -1
- package/dist/onboard-config-B7U20YRw.js +1 -1
- package/dist/onboard-config-DS9dUv8M.js +1 -1
- package/dist/onboard-custom-CwHYUB0T.js +1 -1
- package/dist/onboard-custom-uwufXtQf.js +1 -1
- package/dist/onboard-helpers-CGJLUoxR.js +1 -1
- package/dist/onboard-helpers-DbpWQoiB.js +1 -1
- package/dist/onboard-hooks-CERzXObm.js +1 -1
- package/dist/onboard-hooks-gQ3sxBNi.js +1 -1
- package/dist/onboard-provider-auth-flags-CqbipO7D.js +1 -1
- package/dist/onboard-provider-auth-flags-Dvwzdz37.js +1 -1
- package/dist/onboard-remote-BeDZ_gbH.js +1 -1
- package/dist/onboard-remote-KTUx-3G1.js +1 -1
- package/dist/onboard-search-f2tJD4hg.js +1 -1
- package/dist/onboard-search-fslKKhyg.js +1 -1
- package/dist/onboard-skills-BoS_oVdm.js +1 -1
- package/dist/onboard-skills-C4omGWoD.js +1 -1
- package/dist/onboarding-B8icigkk.js +1 -1
- package/dist/onboarding-BJRqNsZ8.js +1 -1
- package/dist/onboarding.finalize-D0qISqn-.js +1 -1
- package/dist/onboarding.finalize-Ds9NwPBL.js +1 -1
- package/dist/onboarding.gateway-config-F8n_QFUR.js +1 -1
- package/dist/onboarding.gateway-config-eno73eHw.js +1 -1
- package/dist/onboarding.secret-input-B6fzeucQ.js +1 -1
- package/dist/onboarding.secret-input-CBuD3c32.js +1 -1
- package/dist/openai-codex-model-default-Df2T3foI.js +1 -1
- package/dist/openai-codex-model-default-DtIeKJm0.js +1 -1
- package/dist/openai-model-default-DIE55yBt.js +1 -1
- package/dist/openai-model-default-sqvWk4kB.js +1 -1
- package/dist/openclaw-exec-env-BWbOu_YC.js +1 -1
- package/dist/openclaw-root-CnsBf6ZU.js +1 -1
- package/dist/openclaw-root-D_0Q6--h.js +1 -1
- package/dist/outbound-B88MLJN3.js +1 -1
- package/dist/outbound-C-4qToKv.js +1 -1
- package/dist/outbound-CSk4oF0g.js +1 -1
- package/dist/outbound-DKMI_4xm.js +1 -1
- package/dist/outbound-attachment-BOax42-M.js +1 -1
- package/dist/outbound-attachment-DBNxdLYh.js +1 -1
- package/dist/outbound-attachment-DVjJQ3V6.js +1 -1
- package/dist/outbound-attachment-aZWcoZ-N.js +1 -1
- package/dist/pairing-cli-Cby6Ww8F.js +1 -1
- package/dist/pairing-cli-DiJb_a0V.js +1 -1
- package/dist/pairing-labels-BP1h0iHy.js +1 -1
- package/dist/pairing-labels-ryOnuOFA.js +1 -1
- package/dist/pairing-store-Bv4KSELv.js +1 -1
- package/dist/pairing-store-CjTPxq0X.js +1 -1
- package/dist/pairing-token-CKX1ds78.js +1 -1
- package/dist/pairing-token-CX0SUJsB.js +1 -1
- package/dist/parse-duration-XTjMKl8s.js +1 -1
- package/dist/parse-finite-number-DqzUM-_s.js +1 -1
- package/dist/parse-finite-number-dBmDLLKL.js +1 -1
- package/dist/parse-log-line-CsYLg7Qu.js +1 -1
- package/dist/parse-log-line-NV-cipB_.js +1 -1
- package/dist/parse-port-Bv1Y9Wk5.js +1 -1
- package/dist/parse-port-JVwkxcZ8.js +1 -1
- package/dist/parse-timeout-DWSGfCkQ.js +1 -1
- package/dist/parse-timeout-Dx4QnVzo.js +1 -1
- package/dist/path-alias-guards-kY_ZbWs-.js +1 -1
- package/dist/path-alias-guards-mvyLCPlN.js +1 -1
- package/dist/path-env-BPd1Yd-i.js +1 -1
- package/dist/path-env-emdAQejM.js +1 -1
- package/dist/path-safety-BukYK8Kd.js +1 -1
- package/dist/path-safety-DaaMJFdt.js +1 -1
- package/dist/paths-B4IRk3wi.js +1 -1
- package/dist/paths-BfjJY2VL.js +1 -1
- package/dist/paths-BjD3T_xq.js +1 -1
- package/dist/paths-BpQOWYiT.js +1 -1
- package/dist/paths-CChBdtE8.js +1 -1
- package/dist/paths-CrCoPIVK.js +1 -1
- package/dist/paths-piJASC5k.js +1 -1
- package/dist/paths-yLEk_25I.js +1 -1
- package/dist/pi-embedded-ZEWNj7P5.js +1 -1
- package/dist/pi-embedded-bqE4EmdD.js +1 -1
- package/dist/pi-model-discovery-6myCPEJE.js +1 -1
- package/dist/pi-model-discovery-AiV9h8k6.js +1 -1
- package/dist/pi-model-discovery-BzqdozHB.js +1 -1
- package/dist/pi-model-discovery-C8YBu6D4.js +1 -1
- package/dist/pi-tools.before-tool-call.runtime-CPAJMO7J.js +1 -1
- package/dist/pi-tools.before-tool-call.runtime-CYmLHod0.js +1 -1
- package/dist/pi-tools.before-tool-call.runtime-CfVqI0Ng.js +1 -1
- package/dist/pi-tools.before-tool-call.runtime-D9FlPJ_v.js +1 -1
- package/dist/pi-tools.policy-CeSKHaKa.js +1 -1
- package/dist/plugin-auto-enable-Cp7L8ko8.js +1 -1
- package/dist/plugin-auto-enable-DCOxqfDQ.js +1 -1
- package/dist/plugin-install-plan-BobX0y9S.js +1 -1
- package/dist/plugin-install-plan-NvDGp0d8.js +1 -1
- package/dist/plugin-registry-Fg000e4I.js +1 -1
- package/dist/plugin-registry-fm5tDUbE.js +1 -1
- package/dist/plugin-sdk/account-id.cjs +1 -1
- package/dist/plugin-sdk/account-id.js +1 -1
- package/dist/plugin-sdk/acpx.cjs +1 -1
- package/dist/plugin-sdk/acpx.js +1 -1
- package/dist/plugin-sdk/active-listener-BFeaYGID.js +1 -1
- package/dist/plugin-sdk/active-listener-BszCM2Au.cjs +1 -1
- package/dist/plugin-sdk/active-listener-CIcleJgU.cjs +1 -1
- package/dist/plugin-sdk/active-listener-Cqgd7xVh.cjs +1 -1
- package/dist/plugin-sdk/active-listener-D578zEtk.cjs +1 -1
- package/dist/plugin-sdk/active-listener-D6gGPLq-.js +1 -1
- package/dist/plugin-sdk/active-listener-DKSZRn4x.cjs +1 -1
- package/dist/plugin-sdk/active-listener-DNO10F1L.js +1 -1
- package/dist/plugin-sdk/active-listener-DQq07Aar.js +1 -1
- package/dist/plugin-sdk/active-listener-Dle_kYqb.js +1 -1
- package/dist/plugin-sdk/active-listener-DmJcHkMC.js +1 -1
- package/dist/plugin-sdk/active-listener-UmFpcYFY.cjs +1 -1
- package/dist/plugin-sdk/api-key-rotation-39TRXDEA.cjs +1 -1
- package/dist/plugin-sdk/api-key-rotation-7qlqJ_ou.js +1 -1
- package/dist/plugin-sdk/api-key-rotation-BY7fLi9z.js +1 -1
- package/dist/plugin-sdk/api-key-rotation-CF9_CKS-.cjs +1 -1
- package/dist/plugin-sdk/api-key-rotation-CWylhFOt.cjs +1 -1
- package/dist/plugin-sdk/api-key-rotation-ClZmonv2.js +1 -1
- package/dist/plugin-sdk/api-key-rotation-CmesQWXP.cjs +1 -1
- package/dist/plugin-sdk/api-key-rotation-Cs6II2__.js +1 -1
- package/dist/plugin-sdk/api-key-rotation-CxaiMcI1.js +1 -1
- package/dist/plugin-sdk/api-key-rotation-D5cfmg7E.cjs +1 -1
- package/dist/plugin-sdk/api-key-rotation-DkP7KnSm.cjs +1 -1
- package/dist/plugin-sdk/api-key-rotation-mDqgBFMG.js +1 -1
- package/dist/plugin-sdk/audio-preflight-B-HrF5Oc.js +1 -1
- package/dist/plugin-sdk/audio-preflight-B2MGeSoT.js +1 -1
- package/dist/plugin-sdk/audio-preflight-BVjiz_Qk.cjs +1 -1
- package/dist/plugin-sdk/audio-preflight-Behqe7F3.cjs +1 -1
- package/dist/plugin-sdk/audio-preflight-C0ncOCbK.cjs +1 -1
- package/dist/plugin-sdk/audio-preflight-C1o1n-KK.js +1 -1
- package/dist/plugin-sdk/audio-preflight-CzLYTZ5P.cjs +1 -1
- package/dist/plugin-sdk/audio-preflight-DDiBwIB9.js +1 -1
- package/dist/plugin-sdk/audio-preflight-DQyh-XSn.cjs +1 -1
- package/dist/plugin-sdk/audio-preflight-WH9WDR81.cjs +1 -1
- package/dist/plugin-sdk/audio-preflight-ZPLO3G1S.js +1 -1
- package/dist/plugin-sdk/audio-preflight-s3BAID12.js +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-2-ZQ5Md-.cjs +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-BO7T_SzP.cjs +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-CRYJlAeP.js +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-CmW24oVR.js +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-CmYuWS0_.cjs +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-CslXJs5c.js +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-DE1tKTQV.cjs +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-DZR84B28.js +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-DoR-NOcV.cjs +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-IE4olXkd.cjs +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-YiDQM_Rb.js +1 -1
- package/dist/plugin-sdk/audio-transcription-runner-kAVM4YFR.js +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-7LqcvqFo.js +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-BQFUzFc0.cjs +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-BYtdDX9G.cjs +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-BzEtBUX6.cjs +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-CBUmGrl4.js +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-ChlVgt2y.js +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-DLRX7LR0.js +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-DbJW5X3L.cjs +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-Du9LAxDa.cjs +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-DylNnj1m.js +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-voi5sPwF.js +1 -1
- package/dist/plugin-sdk/audit-membership-runtime-yWYvSpgZ.cjs +1 -1
- package/dist/plugin-sdk/bluebubbles.cjs +1 -1
- package/dist/plugin-sdk/bluebubbles.js +1 -1
- package/dist/plugin-sdk/channel-activity-Bed876M5.js +1 -1
- package/dist/plugin-sdk/channel-activity-Bu8tAmGa.cjs +1 -1
- package/dist/plugin-sdk/channel-activity-C01Im_o1.js +1 -1
- package/dist/plugin-sdk/channel-activity-CIycjzUC.js +1 -1
- package/dist/plugin-sdk/channel-activity-Cdkn3O_i.js +1 -1
- package/dist/plugin-sdk/channel-activity-Cia2G3v5.js +1 -1
- package/dist/plugin-sdk/channel-activity-D6d2wU8H.cjs +1 -1
- package/dist/plugin-sdk/channel-activity-DNv7JLBx.cjs +1 -1
- package/dist/plugin-sdk/channel-activity-Df3DfYyZ.cjs +1 -1
- package/dist/plugin-sdk/channel-activity-Rut-HCfT.cjs +1 -1
- package/dist/plugin-sdk/channel-activity-mffNSQrX.cjs +1 -1
- package/dist/plugin-sdk/channel-activity-qjwFifkE.js +1 -1
- package/dist/plugin-sdk/channel-web-Ces_xx2T.js +1 -1
- package/dist/plugin-sdk/channel-web-CsmEnYD8.cjs +1 -1
- package/dist/plugin-sdk/channel-web-DtzNv49H.cjs +1 -1
- package/dist/plugin-sdk/channel-web-VEZVrMYU.js +1 -1
- package/dist/plugin-sdk/command-poll-backoff-4910Mpwp.js +1 -1
- package/dist/plugin-sdk/command-poll-backoff-BLJZzV5W.cjs +1 -1
- package/dist/plugin-sdk/command-poll-backoff-CUNcN0dv.cjs +1 -1
- package/dist/plugin-sdk/command-poll-backoff-Cww_r-24.js +1 -1
- package/dist/plugin-sdk/command-poll-backoff-D0lJhquZ.js +1 -1
- package/dist/plugin-sdk/command-poll-backoff-Glwt3wHa.cjs +1 -1
- package/dist/plugin-sdk/commands-registry-33H8WYTk.cjs +1 -1
- package/dist/plugin-sdk/commands-registry-BGdm1KdC.js +1 -1
- package/dist/plugin-sdk/commands-registry-BgV9i-bj.cjs +1 -1
- package/dist/plugin-sdk/commands-registry-BifdCfty.cjs +1 -1
- package/dist/plugin-sdk/commands-registry-CJLBIIIp.js +1 -1
- package/dist/plugin-sdk/commands-registry-CWK9ARbc.js +1 -1
- package/dist/plugin-sdk/commands-registry-CfVD1h8L.cjs +1 -1
- package/dist/plugin-sdk/commands-registry-CpG4pxrA.js +1 -1
- package/dist/plugin-sdk/commands-registry-D-AnIQWz.cjs +1 -1
- package/dist/plugin-sdk/commands-registry-DBI4cPqT.cjs +1 -1
- package/dist/plugin-sdk/commands-registry-DOBe9cWq.js +1 -1
- package/dist/plugin-sdk/commands-registry-DqemUyiv.js +1 -1
- package/dist/plugin-sdk/common-CEe87dmX.js +1 -1
- package/dist/plugin-sdk/common-CjMKHm2Z.cjs +1 -1
- package/dist/plugin-sdk/compat.cjs +1 -1
- package/dist/plugin-sdk/compat.js +1 -1
- package/dist/plugin-sdk/config-DT_csBcZ.cjs +1 -1
- package/dist/plugin-sdk/config-LR8GH3Ws.js +1 -1
- package/dist/plugin-sdk/copilot-proxy.cjs +1 -1
- package/dist/plugin-sdk/copilot-proxy.js +1 -1
- package/dist/plugin-sdk/core.cjs +1 -1
- package/dist/plugin-sdk/core.js +1 -1
- package/dist/plugin-sdk/deliver-AORlkcbD.cjs +1 -1
- package/dist/plugin-sdk/deliver-BiBFW5fm.cjs +1 -1
- package/dist/plugin-sdk/deliver-BpqEPwLO.cjs +1 -1
- package/dist/plugin-sdk/deliver-BvC6aUKM.js +1 -1
- package/dist/plugin-sdk/deliver-CT0AIuK1.cjs +1 -1
- package/dist/plugin-sdk/deliver-CmddcjtG.cjs +1 -1
- package/dist/plugin-sdk/deliver-DFz5N1Eh.js +1 -1
- package/dist/plugin-sdk/deliver-DcJWpoqf.cjs +1 -1
- package/dist/plugin-sdk/deliver-ILim6ANU.js +1 -1
- package/dist/plugin-sdk/deliver-QgxW9IxV.js +1 -1
- package/dist/plugin-sdk/deliver-cT-Q8v0h.js +1 -1
- package/dist/plugin-sdk/deliver-cu_NQTmb.js +1 -1
- package/dist/plugin-sdk/device-pair.cjs +1 -1
- package/dist/plugin-sdk/device-pair.js +1 -1
- package/dist/plugin-sdk/diagnostic-BCyE1aYH.cjs +1 -1
- package/dist/plugin-sdk/diagnostic-BFea3l_a.js +1 -1
- package/dist/plugin-sdk/diagnostic-BvR96WdC.js +1 -1
- package/dist/plugin-sdk/diagnostic-C0xDsk89.cjs +1 -1
- package/dist/plugin-sdk/diagnostic-CEPhLgsW.cjs +1 -1
- package/dist/plugin-sdk/diagnostic-CbLwUqTE.cjs +1 -1
- package/dist/plugin-sdk/diagnostic-CbfxoqI_.cjs +1 -1
- package/dist/plugin-sdk/diagnostic-DDwUPG1m.js +1 -1
- package/dist/plugin-sdk/diagnostic-DS_mKKOu.js +1 -1
- package/dist/plugin-sdk/diagnostic-DYpehqHU.cjs +1 -1
- package/dist/plugin-sdk/diagnostic-DkncnZ3G.js +1 -1
- package/dist/plugin-sdk/diagnostic-Dz8HPEDe.js +1 -1
- package/dist/plugin-sdk/diagnostics-otel.cjs +1 -1
- package/dist/plugin-sdk/diagnostics-otel.js +1 -1
- package/dist/plugin-sdk/diffs.cjs +1 -1
- package/dist/plugin-sdk/diffs.js +1 -1
- package/dist/plugin-sdk/discord.cjs +1 -1
- package/dist/plugin-sdk/discord.js +1 -1
- package/dist/plugin-sdk/dispatch-6m3206FH.js +1 -1
- package/dist/plugin-sdk/dispatch-BYZNaz0n.cjs +1 -1
- package/dist/plugin-sdk/dispatch-BahZCe-D.js +1 -1
- package/dist/plugin-sdk/dispatch-Bi3yeWxb.cjs +1 -1
- package/dist/plugin-sdk/dispatch-BjB_TqWy.cjs +1 -1
- package/dist/plugin-sdk/dispatch-CNR186B3.js +1 -1
- package/dist/plugin-sdk/dispatch-CStT30wi.cjs +1 -1
- package/dist/plugin-sdk/dispatch-CdZAW9dg.cjs +1 -1
- package/dist/plugin-sdk/dispatch-Ewg2Jgw9.js +1 -1
- package/dist/plugin-sdk/dispatch-HRTsdeCV.js +1 -1
- package/dist/plugin-sdk/feishu.cjs +1 -1
- package/dist/plugin-sdk/feishu.js +1 -1
- package/dist/plugin-sdk/fetch-7Iq9POda.js +1 -1
- package/dist/plugin-sdk/fetch-B1GR6-u4.js +1 -1
- package/dist/plugin-sdk/fetch-B27H-XCf.js +1 -1
- package/dist/plugin-sdk/fetch-BMYDLRWo.js +1 -1
- package/dist/plugin-sdk/fetch-BN9y3kTg.cjs +1 -1
- package/dist/plugin-sdk/fetch-BVEVk5YF.js +1 -1
- package/dist/plugin-sdk/fetch-BY6lVRlY.cjs +1 -1
- package/dist/plugin-sdk/fetch-Bi8krAaT.cjs +1 -1
- package/dist/plugin-sdk/fetch-BjXhwqrE.cjs +1 -1
- package/dist/plugin-sdk/fetch-BtZY623f.js +1 -1
- package/dist/plugin-sdk/fetch-C-HRWp5R.js +1 -1
- package/dist/plugin-sdk/fetch-C3LEMysf.js +1 -1
- package/dist/plugin-sdk/fetch-CCLWsYaQ.js +1 -1
- package/dist/plugin-sdk/fetch-CZewCAvu.cjs +1 -1
- package/dist/plugin-sdk/fetch-ClKErpni.cjs +1 -1
- package/dist/plugin-sdk/fetch-DBRI0sKI.js +1 -1
- package/dist/plugin-sdk/fetch-DQxuOB8o.cjs +1 -1
- package/dist/plugin-sdk/fetch-DUMEaqum.cjs +1 -1
- package/dist/plugin-sdk/fetch-DpwR_cJU.cjs +1 -1
- package/dist/plugin-sdk/fetch-J0IzopiJ.js +1 -1
- package/dist/plugin-sdk/fetch-guard-D8TdhTHU.js +1 -1
- package/dist/plugin-sdk/fetch-guard-DC_pFJEy.js +1 -1
- package/dist/plugin-sdk/fetch-guard-DDkd30BG.js +1 -1
- package/dist/plugin-sdk/fetch-guard-DELiFG5g.js +1 -1
- package/dist/plugin-sdk/fetch-guard-DIYjBRpq.cjs +1 -1
- package/dist/plugin-sdk/fetch-guard-DPVfELS7.js +1 -1
- package/dist/plugin-sdk/fetch-guard-Dpz6CnJY.cjs +1 -1
- package/dist/plugin-sdk/fetch-guard-DqNKwgHP.cjs +1 -1
- package/dist/plugin-sdk/fetch-guard-DqTxZ3G8.cjs +1 -1
- package/dist/plugin-sdk/fetch-guard-EoAitPe9.cjs +1 -1
- package/dist/plugin-sdk/fetch-guard-qfU6iTvp.js +1 -1
- package/dist/plugin-sdk/fetch-guard-u2Dt6P9i.cjs +1 -1
- package/dist/plugin-sdk/fetch-lw-aF17e.cjs +1 -1
- package/dist/plugin-sdk/fetch-timeout-6oZsqWxA.js +1 -1
- package/dist/plugin-sdk/fetch-timeout-BygUD0rd.cjs +1 -1
- package/dist/plugin-sdk/fetch-timeout-CLw1U7VS.js +1 -1
- package/dist/plugin-sdk/fetch-timeout-CX1w-9p4.cjs +1 -1
- package/dist/plugin-sdk/fetch-timeout-Coc9xyC3.cjs +1 -1
- package/dist/plugin-sdk/fetch-timeout-Cz6GuU_c.js +1 -1
- package/dist/plugin-sdk/fetch-timeout-DC8T2JCr.js +1 -1
- package/dist/plugin-sdk/fetch-timeout-DFDmks9T.cjs +1 -1
- package/dist/plugin-sdk/fetch-timeout-DkYpp08Q.js +1 -1
- package/dist/plugin-sdk/github-copilot-token-BHdMLLqf.cjs +1 -1
- package/dist/plugin-sdk/github-copilot-token-Bt4PduRB.js +1 -1
- package/dist/plugin-sdk/github-copilot-token-C1O2cBqk.cjs +1 -1
- package/dist/plugin-sdk/github-copilot-token-C1hiDugd.js +1 -1
- package/dist/plugin-sdk/github-copilot-token-C8j8_NjX.js +1 -1
- package/dist/plugin-sdk/github-copilot-token-CCrgp2py.cjs +1 -1
- package/dist/plugin-sdk/github-copilot-token-DoHgkI2r.cjs +1 -1
- package/dist/plugin-sdk/github-copilot-token-N8vnLZPw.js +1 -1
- package/dist/plugin-sdk/github-copilot-token-TMkfxxD2.cjs +1 -1
- package/dist/plugin-sdk/github-copilot-token-vKAKX6iE.js +1 -1
- package/dist/plugin-sdk/github-copilot-token-ylX_gawo.js +1 -1
- package/dist/plugin-sdk/github-copilot-token-zskwAEpd.cjs +1 -1
- package/dist/plugin-sdk/google-gemini-cli-auth.cjs +1 -1
- package/dist/plugin-sdk/google-gemini-cli-auth.js +1 -1
- package/dist/plugin-sdk/googlechat.cjs +1 -1
- package/dist/plugin-sdk/googlechat.js +1 -1
- package/dist/plugin-sdk/image-0OHO98b9.cjs +1 -1
- package/dist/plugin-sdk/image-B9SLKAOs.cjs +1 -1
- package/dist/plugin-sdk/image-BVnZq5Y4.js +1 -1
- package/dist/plugin-sdk/image-CKLAyhco.js +1 -1
- package/dist/plugin-sdk/image-DUHEJeBF.js +1 -1
- package/dist/plugin-sdk/image-DngxW2Nh.cjs +1 -1
- package/dist/plugin-sdk/image-DrPh2689.cjs +1 -1
- package/dist/plugin-sdk/image-ISWO0Dwt.js +1 -1
- package/dist/plugin-sdk/image-KfZYW6Lh.cjs +1 -1
- package/dist/plugin-sdk/image-YVlw68CK.js +1 -1
- package/dist/plugin-sdk/image-gehqJnV6.js +1 -1
- package/dist/plugin-sdk/image-jUYo-0eT.cjs +1 -1
- package/dist/plugin-sdk/imessage.cjs +1 -1
- package/dist/plugin-sdk/imessage.js +1 -1
- package/dist/plugin-sdk/index.cjs +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/ir-78toXVqC.cjs +1 -1
- package/dist/plugin-sdk/ir-A_TqKaXP.cjs +1 -1
- package/dist/plugin-sdk/ir-B0_rUT7m.js +1 -1
- package/dist/plugin-sdk/ir-B7agH4cQ.cjs +1 -1
- package/dist/plugin-sdk/ir-B9ap_YNW.cjs +1 -1
- package/dist/plugin-sdk/ir-BxKSHYao.cjs +1 -1
- package/dist/plugin-sdk/ir-BzZArF6l.js +1 -1
- package/dist/plugin-sdk/ir-CpkEWZD6.js +1 -1
- package/dist/plugin-sdk/ir-D4Dz-giw.cjs +1 -1
- package/dist/plugin-sdk/ir-DJ08DSkk.js +1 -1
- package/dist/plugin-sdk/ir-L2vhtuGx.js +1 -1
- package/dist/plugin-sdk/ir-ntSck5Kp.js +1 -1
- package/dist/plugin-sdk/irc.cjs +1 -1
- package/dist/plugin-sdk/irc.js +1 -1
- package/dist/plugin-sdk/keyed-async-queue.cjs +1 -1
- package/dist/plugin-sdk/keyed-async-queue.js +1 -1
- package/dist/plugin-sdk/line.cjs +1 -1
- package/dist/plugin-sdk/line.js +1 -1
- package/dist/plugin-sdk/llm-task.cjs +1 -1
- package/dist/plugin-sdk/llm-task.js +1 -1
- package/dist/plugin-sdk/load-options-B9Ss5YOO.js +1 -1
- package/dist/plugin-sdk/load-options-BOfn6Zgo.cjs +1 -1
- package/dist/plugin-sdk/load-options-BXvm8HVv.js +1 -1
- package/dist/plugin-sdk/load-options-Bb7u8yZz.cjs +1 -1
- package/dist/plugin-sdk/load-options-BcSg1ODN.js +1 -1
- package/dist/plugin-sdk/load-options-NqnXJ-Nh.cjs +1 -1
- package/dist/plugin-sdk/lobster.cjs +1 -1
- package/dist/plugin-sdk/lobster.js +1 -1
- package/dist/plugin-sdk/local-roots-B0zm186S.js +1 -1
- package/dist/plugin-sdk/local-roots-B4Uy4kG3.cjs +1 -1
- package/dist/plugin-sdk/local-roots-CM1R1Ncr.cjs +1 -1
- package/dist/plugin-sdk/local-roots-CW78ZeZV.js +1 -1
- package/dist/plugin-sdk/local-roots-CnsaE7a_.js +1 -1
- package/dist/plugin-sdk/local-roots-D1k-fAlE.cjs +1 -1
- package/dist/plugin-sdk/local-roots-DQ_vfJPK.js +1 -1
- package/dist/plugin-sdk/local-roots-DYlB1au6.cjs +1 -1
- package/dist/plugin-sdk/local-roots-H4-t0qG_.js +1 -1
- package/dist/plugin-sdk/local-roots-SCyeUfM3.cjs +1 -1
- package/dist/plugin-sdk/local-roots-l4PqCmiU.js +1 -1
- package/dist/plugin-sdk/local-roots-xHoEq1Fq.cjs +1 -1
- package/dist/plugin-sdk/logger-6O6OsYBL.cjs +1 -1
- package/dist/plugin-sdk/logger-BlddiV_d.cjs +1 -1
- package/dist/plugin-sdk/logger-Bm93ZKOk.cjs +1 -1
- package/dist/plugin-sdk/logger-BtrWb0dj.js +1 -1
- package/dist/plugin-sdk/logger-C210xuWx.js +1 -1
- package/dist/plugin-sdk/logger-DJGHvDbX.js +1 -1
- package/dist/plugin-sdk/logger-DPlqYkRm.cjs +1 -1
- package/dist/plugin-sdk/logger-DUYnS-W3.cjs +1 -1
- package/dist/plugin-sdk/logger-DwWqfo66.js +1 -1
- package/dist/plugin-sdk/logger-vBDTZWl3.js +1 -1
- package/dist/plugin-sdk/login-BN1TsFp4.cjs +1 -1
- package/dist/plugin-sdk/login-BXUtcSnB.cjs +1 -1
- package/dist/plugin-sdk/login-BoMH2iJT.js +1 -1
- package/dist/plugin-sdk/login-BtT7yRJO.js +1 -1
- package/dist/plugin-sdk/login-COzybMRK.js +1 -1
- package/dist/plugin-sdk/login-Cw1jFbel.cjs +1 -1
- package/dist/plugin-sdk/login-DEmpr5YK.js +1 -1
- package/dist/plugin-sdk/login-Dln00cFs.cjs +1 -1
- package/dist/plugin-sdk/login-S2Fe5n5K.cjs +1 -1
- package/dist/plugin-sdk/login-TieaF0ts.cjs +1 -1
- package/dist/plugin-sdk/login-ZQK4uJLw.js +1 -1
- package/dist/plugin-sdk/login-fKxJv0_F.js +1 -1
- package/dist/plugin-sdk/login-qr-1ilmySGx.js +1 -1
- package/dist/plugin-sdk/login-qr-B0ZSZaNI.js +1 -1
- package/dist/plugin-sdk/login-qr-B2P2Ky4j.js +1 -1
- package/dist/plugin-sdk/login-qr-B2U87iU8.js +1 -1
- package/dist/plugin-sdk/login-qr-B4x_eWI_.js +1 -1
- package/dist/plugin-sdk/login-qr-BIaJB24t.cjs +1 -1
- package/dist/plugin-sdk/login-qr-BMl5Beq2.cjs +1 -1
- package/dist/plugin-sdk/login-qr-Bkm3QorK.cjs +1 -1
- package/dist/plugin-sdk/login-qr-ClL8FMAJ.cjs +1 -1
- package/dist/plugin-sdk/login-qr-DFVK1lg-.js +1 -1
- package/dist/plugin-sdk/login-qr-DhieI9fL.cjs +1 -1
- package/dist/plugin-sdk/login-qr-DyQT1QnE.cjs +1 -1
- package/dist/plugin-sdk/manager-0tvX3Z_N.cjs +1 -1
- package/dist/plugin-sdk/manager-8uylP7PH.cjs +1 -1
- package/dist/plugin-sdk/manager-B6hWglXe.js +1 -1
- package/dist/plugin-sdk/manager-BGoKN9ur.js +1 -1
- package/dist/plugin-sdk/manager-BRP1lzb6.js +1 -1
- package/dist/plugin-sdk/manager-BeLNhsXC.cjs +1 -1
- package/dist/plugin-sdk/manager-BnytMgmq.js +1 -1
- package/dist/plugin-sdk/manager-BoMQeM1I.cjs +1 -1
- package/dist/plugin-sdk/manager-CYZY9vcM.js +1 -1
- package/dist/plugin-sdk/manager-DCDy2V1U.cjs +1 -1
- package/dist/plugin-sdk/manager-DE7sDip8.cjs +1 -1
- package/dist/plugin-sdk/manager-PwgQZNK1.js +1 -1
- package/dist/plugin-sdk/matrix.cjs +1 -1
- package/dist/plugin-sdk/matrix.js +1 -1
- package/dist/plugin-sdk/mattermost.cjs +1 -1
- package/dist/plugin-sdk/mattermost.js +1 -1
- package/dist/plugin-sdk/memory-core.cjs +1 -1
- package/dist/plugin-sdk/memory-core.js +1 -1
- package/dist/plugin-sdk/minimax-portal-auth.cjs +1 -1
- package/dist/plugin-sdk/minimax-portal-auth.js +1 -1
- package/dist/plugin-sdk/model-auth-BgS7ynQw.cjs +1 -1
- package/dist/plugin-sdk/model-auth-CKlA2xRB.cjs +1 -1
- package/dist/plugin-sdk/model-auth-CLnFIqcf.cjs +1 -1
- package/dist/plugin-sdk/model-auth-D7YupJDS.js +1 -1
- package/dist/plugin-sdk/model-auth-eNVBeC-B.js +1 -1
- package/dist/plugin-sdk/model-auth-fJrNIbke.cjs +1 -1
- package/dist/plugin-sdk/model-auth-g6eGgTwR.js +1 -1
- package/dist/plugin-sdk/model-auth-wcxJptQX.js +1 -1
- package/dist/plugin-sdk/model-selection-4ExiFkaW.js +1 -1
- package/dist/plugin-sdk/model-selection-CZY_x2-a.cjs +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/nostr.cjs +1 -1
- package/dist/plugin-sdk/nostr.js +1 -1
- package/dist/plugin-sdk/outbound-2VVSR_d4.js +1 -1
- package/dist/plugin-sdk/outbound-B03BQa7T.cjs +1 -1
- package/dist/plugin-sdk/outbound-BE8CJ9c_.js +1 -1
- package/dist/plugin-sdk/outbound-BWtGs0dn.cjs +1 -1
- package/dist/plugin-sdk/outbound-BrD0UsX0.js +1 -1
- package/dist/plugin-sdk/outbound-Bvu4LbQx.js +1 -1
- package/dist/plugin-sdk/outbound-C5rNt-8z.cjs +1 -1
- package/dist/plugin-sdk/outbound-C6BJCoYf.cjs +1 -1
- package/dist/plugin-sdk/outbound-Cgc0JJtB.js +1 -1
- package/dist/plugin-sdk/outbound-DAHIkpiA.cjs +1 -1
- package/dist/plugin-sdk/outbound-DnO_udAm.cjs +1 -1
- package/dist/plugin-sdk/outbound-UAHsCNyW.js +1 -1
- package/dist/plugin-sdk/outbound-attachment-0QahtSQB.cjs +1 -1
- package/dist/plugin-sdk/outbound-attachment-8qvAj1MK.js +1 -1
- package/dist/plugin-sdk/outbound-attachment-B6SJy_CG.js +1 -1
- package/dist/plugin-sdk/outbound-attachment-BVdSGifg.js +1 -1
- package/dist/plugin-sdk/outbound-attachment-C-QqSQ79.cjs +1 -1
- package/dist/plugin-sdk/outbound-attachment-CYGrnygD.cjs +1 -1
- package/dist/plugin-sdk/outbound-attachment-CtA5eBgj.cjs +1 -1
- package/dist/plugin-sdk/outbound-attachment-D8Ng5uVX.cjs +1 -1
- package/dist/plugin-sdk/outbound-attachment-DS0S0NLK.js +1 -1
- package/dist/plugin-sdk/outbound-attachment-Ds2XsjQl.js +1 -1
- package/dist/plugin-sdk/outbound-attachment-acB4qID1.js +1 -1
- package/dist/plugin-sdk/outbound-attachment-x4Q2SVIA.cjs +1 -1
- package/dist/plugin-sdk/paths-BPlgbwrb.cjs +1 -1
- package/dist/plugin-sdk/paths-Bcdg3ma0.cjs +1 -1
- package/dist/plugin-sdk/paths-BpQOWYiT.js +1 -1
- package/dist/plugin-sdk/paths-BvlJvmRS.cjs +1 -1
- package/dist/plugin-sdk/paths-CIcxeNL-.cjs +1 -1
- package/dist/plugin-sdk/paths-CXgWvWAM.js +1 -1
- package/dist/plugin-sdk/paths-Chp3zwtq.cjs +1 -1
- package/dist/plugin-sdk/paths-CnHSNSeR.js +1 -1
- package/dist/plugin-sdk/paths-Cqca1YmF.cjs +1 -1
- package/dist/plugin-sdk/paths-CtrEseGU.js +1 -1
- package/dist/plugin-sdk/paths-D55o_j8-.js +1 -1
- package/dist/plugin-sdk/paths-D90l3h_o.cjs +1 -1
- package/dist/plugin-sdk/paths-DaRoqzBQ.js +1 -1
- package/dist/plugin-sdk/paths-Dd7r1qlB.cjs +1 -1
- package/dist/plugin-sdk/paths-DhSjTRMz.js +1 -1
- package/dist/plugin-sdk/paths-Do0djuaj.js +1 -1
- package/dist/plugin-sdk/paths-J4JUiRsa.js +1 -1
- package/dist/plugin-sdk/paths-cBAF6Bj0.js +1 -1
- package/dist/plugin-sdk/paths-piJASC5k.js +1 -1
- package/dist/plugin-sdk/paths-rO4ehkyU.js +1 -1
- package/dist/plugin-sdk/pi-model-discovery--UcCzdQg.js +1 -1
- package/dist/plugin-sdk/pi-model-discovery-Bi4dKtW0.cjs +1 -1
- package/dist/plugin-sdk/pi-model-discovery-CCK2Ppj9.js +1 -1
- package/dist/plugin-sdk/pi-model-discovery-CRSZ0OFi.js +1 -1
- package/dist/plugin-sdk/pi-model-discovery-Cx_r4FGY.js +1 -1
- package/dist/plugin-sdk/pi-model-discovery-D3JQMjAa.cjs +1 -1
- package/dist/plugin-sdk/pi-model-discovery-DN1RHetG.cjs +1 -1
- package/dist/plugin-sdk/pi-model-discovery-DVFSU0-f.cjs +1 -1
- package/dist/plugin-sdk/pi-model-discovery-DWMAAhA-.cjs +1 -1
- package/dist/plugin-sdk/pi-model-discovery-DYOHzCjs.js +1 -1
- package/dist/plugin-sdk/pi-model-discovery-DdSVvbQ5.cjs +1 -1
- package/dist/plugin-sdk/pi-model-discovery-DejkxBol.js +1 -1
- package/dist/plugin-sdk/pi-model-discovery-SmVAFMj_.cjs +1 -1
- package/dist/plugin-sdk/pi-model-discovery-ma8st1Ek.js +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-B2WodYBY.cjs +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-BC114tUb.js +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-BF6jP1nM.js +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-Beg-U7Z-.cjs +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-BkEYsSLL.js +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-C21sWtkh.js +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-CKkgBGIj.cjs +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-CNun__L-.js +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-Clulhv2X.cjs +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-DvwL5in9.cjs +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-FnzjmZqP.js +1 -1
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-Rq5y0QJ2.cjs +1 -1
- package/dist/plugin-sdk/polls-BuaJuIpV.cjs +1 -1
- package/dist/plugin-sdk/polls-CBAGZuJ6.js +1 -1
- package/dist/plugin-sdk/polls-CSKMbBIS.js +1 -1
- package/dist/plugin-sdk/polls-D0wY0FvT.cjs +1 -1
- package/dist/plugin-sdk/polls-PGxiE05J.js +1 -1
- package/dist/plugin-sdk/polls-yWqSCEP0.cjs +1 -1
- package/dist/plugin-sdk/proxy-env-B765haXA.js +1 -1
- package/dist/plugin-sdk/proxy-env-Bcl14j2_.cjs +1 -1
- package/dist/plugin-sdk/proxy-env-BlrHtJWH.js +1 -1
- package/dist/plugin-sdk/proxy-env-D48qBPAr.cjs +1 -1
- package/dist/plugin-sdk/proxy-env-DGzNnnJh.js +1 -1
- package/dist/plugin-sdk/proxy-env-DQoJjkWE.cjs +1 -1
- package/dist/plugin-sdk/proxy-env-DWw9TnOj.cjs +1 -1
- package/dist/plugin-sdk/proxy-env-MEjSyzTr.js +1 -1
- package/dist/plugin-sdk/proxy-env-a590sPAz.cjs +1 -1
- package/dist/plugin-sdk/proxy-env-k93igu7v.cjs +1 -1
- package/dist/plugin-sdk/proxy-env-m9eG3uZN.js +1 -1
- package/dist/plugin-sdk/proxy-env-t6hcaFqC.js +1 -1
- package/dist/plugin-sdk/proxy-fetch-B9aXJVe-.js +1 -1
- package/dist/plugin-sdk/proxy-fetch-BaA3JYgW.cjs +1 -1
- package/dist/plugin-sdk/proxy-fetch-BwXFVsHE.cjs +1 -1
- package/dist/plugin-sdk/proxy-fetch-BzcKzknk.cjs +1 -1
- package/dist/plugin-sdk/proxy-fetch-CYVChsKE.js +1 -1
- package/dist/plugin-sdk/proxy-fetch-ClOb2LUH.js +1 -1
- package/dist/plugin-sdk/proxy-fetch-DH7VIiBH.cjs +1 -1
- package/dist/plugin-sdk/proxy-fetch-DPOhfrou.cjs +1 -1
- package/dist/plugin-sdk/proxy-fetch-DXt2R_Z5.js +1 -1
- package/dist/plugin-sdk/proxy-fetch-Del551nu.js +1 -1
- package/dist/plugin-sdk/proxy-fetch-YCVHz7Rl.js +1 -1
- package/dist/plugin-sdk/proxy-fetch-qbrYAz8k.cjs +1 -1
- package/dist/plugin-sdk/pw-ai-3piACPqP.cjs +1 -1
- package/dist/plugin-sdk/pw-ai-8dajXBkZ.js +1 -1
- package/dist/plugin-sdk/pw-ai-B7mrBDW5.js +1 -1
- package/dist/plugin-sdk/pw-ai-BLD7x-3a.js +1 -1
- package/dist/plugin-sdk/pw-ai-BYmANcaC.cjs +1 -1
- package/dist/plugin-sdk/pw-ai-C1rVW06B.cjs +1 -1
- package/dist/plugin-sdk/pw-ai-CCDvaBUm.cjs +1 -1
- package/dist/plugin-sdk/pw-ai-CVYUOcKM.js +1 -1
- package/dist/plugin-sdk/pw-ai-DBg5CCXp.cjs +1 -1
- package/dist/plugin-sdk/pw-ai-DY11CCd3.cjs +1 -1
- package/dist/plugin-sdk/pw-ai-Kf2RyA25.js +1 -1
- package/dist/plugin-sdk/pw-ai-f5yF3n3t.js +1 -1
- package/dist/plugin-sdk/qmd-manager-B3xNbdye.cjs +1 -1
- package/dist/plugin-sdk/qmd-manager-BMyDNBPi.js +1 -1
- package/dist/plugin-sdk/qmd-manager-BZhiv_zq.cjs +1 -1
- package/dist/plugin-sdk/qmd-manager-C3uVDbhW.js +1 -1
- package/dist/plugin-sdk/qmd-manager-CW46NrS-.cjs +1 -1
- package/dist/plugin-sdk/qmd-manager-C_e04BNg.js +1 -1
- package/dist/plugin-sdk/qmd-manager-CczVoslK.cjs +1 -1
- package/dist/plugin-sdk/qmd-manager-CzLKqPmR.js +1 -1
- package/dist/plugin-sdk/qmd-manager-DFh8b5N-.cjs +1 -1
- package/dist/plugin-sdk/qmd-manager-DXLfZZMI.js +1 -1
- package/dist/plugin-sdk/qmd-manager-FL9fAfNo.cjs +1 -1
- package/dist/plugin-sdk/qmd-manager-fWxbGqzk.js +1 -1
- package/dist/plugin-sdk/query-expansion-0zYzKrrd.cjs +1 -1
- package/dist/plugin-sdk/query-expansion-BYSjmpkV.cjs +1 -1
- package/dist/plugin-sdk/query-expansion-CAboqtWr.js +1 -1
- package/dist/plugin-sdk/query-expansion-C_DnhmUy.js +1 -1
- package/dist/plugin-sdk/query-expansion-Cb2vnF6y.js +1 -1
- package/dist/plugin-sdk/query-expansion-DCeqywxh.cjs +1 -1
- package/dist/plugin-sdk/query-expansion-DF4LMxRQ.js +1 -1
- package/dist/plugin-sdk/query-expansion-DKJkqmNM.cjs +1 -1
- package/dist/plugin-sdk/query-expansion-DO2CFW4z.cjs +1 -1
- package/dist/plugin-sdk/query-expansion-DyCDaZbL.js +1 -1
- package/dist/plugin-sdk/query-expansion-cpXCyoDy.cjs +1 -1
- package/dist/plugin-sdk/query-expansion-r_iXkNzt.js +1 -1
- package/dist/plugin-sdk/qwen-portal-auth.cjs +1 -1
- package/dist/plugin-sdk/qwen-portal-auth.js +1 -1
- package/dist/plugin-sdk/render-6fCdtAr6.cjs +1 -1
- package/dist/plugin-sdk/render-CBsnn-2A.js +1 -1
- package/dist/plugin-sdk/render-CzHaQB0d.cjs +1 -1
- package/dist/plugin-sdk/render-DGmfCIRG.js +1 -1
- package/dist/plugin-sdk/render-DhTJXP1U.js +1 -1
- package/dist/plugin-sdk/render-Djx15dPh.js +1 -1
- package/dist/plugin-sdk/render-DxBO2Blp.cjs +1 -1
- package/dist/plugin-sdk/render-g5VlmgpF.cjs +1 -1
- package/dist/plugin-sdk/reply-BrHB7v5V.cjs +1 -1
- package/dist/plugin-sdk/reply-Clex4c2R.js +1 -1
- package/dist/plugin-sdk/resolve-outbound-target-BHLQMMp-.cjs +1 -1
- package/dist/plugin-sdk/resolve-outbound-target-Cvz2WXAk.cjs +1 -1
- package/dist/plugin-sdk/resolve-outbound-target-DDqGniMw.js +1 -1
- package/dist/plugin-sdk/resolve-outbound-target-DEpmpEep.js +1 -1
- package/dist/plugin-sdk/send--HeMLLzj.js +1 -1
- package/dist/plugin-sdk/send-2IhtEEzb.js +1 -1
- package/dist/plugin-sdk/send-9tPLnqkc.js +1 -1
- package/dist/plugin-sdk/send-B-exJfkg.js +1 -1
- package/dist/plugin-sdk/send-B4kzPtcN.js +1 -1
- package/dist/plugin-sdk/send-BCSkdYN6.cjs +1 -1
- package/dist/plugin-sdk/send-BEmZxBcF.js +1 -1
- package/dist/plugin-sdk/send-BHvZIrbJ.cjs +1 -1
- package/dist/plugin-sdk/send-BLbCBxeF.js +1 -1
- package/dist/plugin-sdk/send-BOkABdQu.cjs +1 -1
- package/dist/plugin-sdk/send-BPNd63Qs.js +1 -1
- package/dist/plugin-sdk/send-BVAm6Zbr.cjs +1 -1
- package/dist/plugin-sdk/send-B_619b3s.js +1 -1
- package/dist/plugin-sdk/send-BcuylzbX.js +1 -1
- package/dist/plugin-sdk/send-BdFvK9Wc2.js +1 -1
- package/dist/plugin-sdk/send-Bh-J7XWZ.cjs +1 -1
- package/dist/plugin-sdk/send-BkREPc90.cjs +1 -1
- package/dist/plugin-sdk/send-Bp4f-KJu.cjs +1 -1
- package/dist/plugin-sdk/send-BtF36kYb.js +1 -1
- package/dist/plugin-sdk/send-C6S8tkTA.cjs +1 -1
- package/dist/plugin-sdk/send-CDQF_izk.js +1 -1
- package/dist/plugin-sdk/send-CF3qas-K.js +1 -1
- package/dist/plugin-sdk/send-CFKQX2Wo.js +1 -1
- package/dist/plugin-sdk/send-CIP1u5a-.js +1 -1
- package/dist/plugin-sdk/send-CIxh7PV0.cjs +1 -1
- package/dist/plugin-sdk/send-CJJdcDHX.js +1 -1
- package/dist/plugin-sdk/send-COtvydDt.cjs +1 -1
- package/dist/plugin-sdk/send-CPwh7tRu.js +1 -1
- package/dist/plugin-sdk/send-CRnIqXN9.cjs +1 -1
- package/dist/plugin-sdk/send-CSqipUeV.cjs +1 -1
- package/dist/plugin-sdk/send-Chfe8tPY.js +1 -1
- package/dist/plugin-sdk/send-ClMvdjfg.js +1 -1
- package/dist/plugin-sdk/send-CmoJSYhT.js +1 -1
- package/dist/plugin-sdk/send-Cs5jSTw0.cjs +1 -1
- package/dist/plugin-sdk/send-D-6Et_9H.js +1 -1
- package/dist/plugin-sdk/send-D13uFnzH.cjs +1 -1
- package/dist/plugin-sdk/send-D3eT0F4N.cjs +1 -1
- package/dist/plugin-sdk/send-DAtg_VHa.js +1 -1
- package/dist/plugin-sdk/send-DCF59ijQ.cjs +1 -1
- package/dist/plugin-sdk/send-DN2xic3w.cjs +1 -1
- package/dist/plugin-sdk/send-DOjSTB6D.cjs +1 -1
- package/dist/plugin-sdk/send-DavwL7cF.js +1 -1
- package/dist/plugin-sdk/send-Dbmn1rgD.cjs +1 -1
- package/dist/plugin-sdk/send-DhfDqcwc.cjs +1 -1
- package/dist/plugin-sdk/send-DsDCrJWq.js +1 -1
- package/dist/plugin-sdk/send-DyR5Lpl-.js +1 -1
- package/dist/plugin-sdk/send-DyzuwDjE.js +1 -1
- package/dist/plugin-sdk/send-GtphEa1b.cjs +1 -1
- package/dist/plugin-sdk/send-HZNY_u3L.cjs +1 -1
- package/dist/plugin-sdk/send-IM-76QZu.js +1 -1
- package/dist/plugin-sdk/send-IqcgAO8b.cjs +1 -1
- package/dist/plugin-sdk/send-OQcuL9tP.js +1 -1
- package/dist/plugin-sdk/send-_92aOzWU.cjs +1 -1
- package/dist/plugin-sdk/send-h_kE-cAK.js +1 -1
- package/dist/plugin-sdk/send-jOMdGt0L.cjs +1 -1
- package/dist/plugin-sdk/send-mZ_d-t_3.cjs +1 -1
- package/dist/plugin-sdk/send-puyUta4_.cjs +1 -1
- package/dist/plugin-sdk/send-t5U34FhY.cjs +1 -1
- package/dist/plugin-sdk/send-tvw8j-Se.cjs +1 -1
- package/dist/plugin-sdk/send-z1vaCgF3.cjs +1 -1
- package/dist/plugin-sdk/session--K1m5v7m.js +1 -1
- package/dist/plugin-sdk/session-B1DJ45om.js +1 -1
- package/dist/plugin-sdk/session-B80NWO1m.js +1 -1
- package/dist/plugin-sdk/session-BKPBr445.js +1 -1
- package/dist/plugin-sdk/session-BQLjsBwL.cjs +1 -1
- package/dist/plugin-sdk/session-BZHltxdM.js +1 -1
- package/dist/plugin-sdk/session-Bt5yI-VW.cjs +1 -1
- package/dist/plugin-sdk/session-CC1GqwiM.cjs +1 -1
- package/dist/plugin-sdk/session-C_yqyp3P.cjs +1 -1
- package/dist/plugin-sdk/session-ClISxvtJ.js +1 -1
- package/dist/plugin-sdk/session-D4nn-nXX.cjs +1 -1
- package/dist/plugin-sdk/session-DOA4CJgj.cjs +1 -1
- package/dist/plugin-sdk/sessions-BwTjGneU.js +1 -1
- package/dist/plugin-sdk/sessions-CJbvfO6m.cjs +1 -1
- package/dist/plugin-sdk/signal.cjs +1 -1
- package/dist/plugin-sdk/signal.js +1 -1
- package/dist/plugin-sdk/skill-commands-5WGHyr3h.cjs +1 -1
- package/dist/plugin-sdk/skill-commands-BZlF3g3o.js +1 -1
- package/dist/plugin-sdk/skill-commands-BmBQSmNH.js +1 -1
- package/dist/plugin-sdk/skill-commands-CD4GQXTR.cjs +1 -1
- package/dist/plugin-sdk/skill-commands-CGOPOT-r.js +1 -1
- package/dist/plugin-sdk/skill-commands-CM9ziCQY.cjs +1 -1
- package/dist/plugin-sdk/skill-commands-CVsU5rEy.js +1 -1
- package/dist/plugin-sdk/skill-commands-DNPxE-kc.cjs +1 -1
- package/dist/plugin-sdk/skill-commands-DcgKCVDt.js +1 -1
- package/dist/plugin-sdk/skill-commands-IAwkVeOe.js +1 -1
- package/dist/plugin-sdk/skill-commands-ZyLkXbR_.cjs +1 -1
- package/dist/plugin-sdk/skill-commands-xJWQthd5.cjs +1 -1
- package/dist/plugin-sdk/slack.cjs +1 -1
- package/dist/plugin-sdk/slack.js +1 -1
- package/dist/plugin-sdk/synology-chat.cjs +1 -1
- package/dist/plugin-sdk/synology-chat.js +1 -1
- package/dist/plugin-sdk/tables-BZUVdTR-.cjs +1 -1
- package/dist/plugin-sdk/tables-Bbodvj_s.cjs +1 -1
- package/dist/plugin-sdk/tables-C5b2CtNw.cjs +1 -1
- package/dist/plugin-sdk/tables-C6TX2QvW.js +1 -1
- package/dist/plugin-sdk/tables-Cz5osenc.js +1 -1
- package/dist/plugin-sdk/tables-DBSeZ07-.cjs +1 -1
- package/dist/plugin-sdk/tables-DLSXY2-Q.js +1 -1
- package/dist/plugin-sdk/tables-DQad-z2Z.cjs +1 -1
- package/dist/plugin-sdk/tables-DYuLwL1d.js +1 -1
- package/dist/plugin-sdk/tables-D_J655yN.js +1 -1
- package/dist/plugin-sdk/tables-_vqK8P0T.js +1 -1
- package/dist/plugin-sdk/tables-bSgb8OzP.cjs +1 -1
- package/dist/plugin-sdk/target-errors-B-mJ4s4b.cjs +1 -1
- package/dist/plugin-sdk/target-errors-BAHAHc8f.js +1 -1
- package/dist/plugin-sdk/target-errors-BKruhz8r.js +1 -1
- package/dist/plugin-sdk/target-errors-BbQBR5da.js +1 -1
- package/dist/plugin-sdk/target-errors-BjgLCOTm.cjs +1 -1
- package/dist/plugin-sdk/target-errors-CQbFkOae.js +1 -1
- package/dist/plugin-sdk/target-errors-C_HYvghh.cjs +1 -1
- package/dist/plugin-sdk/target-errors-CaaKhU6m.js +1 -1
- package/dist/plugin-sdk/target-errors-QWTCk98R.cjs +1 -1
- package/dist/plugin-sdk/target-errors-oh0u5K2w.cjs +1 -1
- package/dist/plugin-sdk/targets-BSc11Uk8.cjs +1 -1
- package/dist/plugin-sdk/targets-BSkiizml.js +1 -1
- package/dist/plugin-sdk/targets-CBI0xqve.cjs +1 -1
- package/dist/plugin-sdk/targets-CL5fYQi7.js +1 -1
- package/dist/plugin-sdk/targets-CUZWrFrm.cjs +1 -1
- package/dist/plugin-sdk/targets-CVEYTFPQ.js +1 -1
- package/dist/plugin-sdk/targets-Co2R6K14.cjs +1 -1
- package/dist/plugin-sdk/targets-CrkJkzil.js +1 -1
- package/dist/plugin-sdk/targets-D-m7SV9x.cjs +1 -1
- package/dist/plugin-sdk/targets-D8HTxbo4.js +1 -1
- package/dist/plugin-sdk/targets-DcGNB9nk.cjs +1 -1
- package/dist/plugin-sdk/targets-Dn9gDiEw.js +1 -1
- package/dist/plugin-sdk/targets-X28mff4s.cjs +1 -1
- package/dist/plugin-sdk/targets-uycXZ8vQ.js +1 -1
- package/dist/plugin-sdk/telegram.cjs +1 -1
- package/dist/plugin-sdk/telegram.js +1 -1
- package/dist/plugin-sdk/test-utils.cjs +1 -1
- package/dist/plugin-sdk/test-utils.js +1 -1
- package/dist/plugin-sdk/tlon.cjs +1 -1
- package/dist/plugin-sdk/tlon.js +1 -1
- package/dist/plugin-sdk/tokens-AAdZjj0M.js +1 -1
- package/dist/plugin-sdk/tokens-B20KNIDD.js +1 -1
- package/dist/plugin-sdk/tokens-B8ys7Q2e.js +1 -1
- package/dist/plugin-sdk/tokens-BPc1fcZ3.js +1 -1
- package/dist/plugin-sdk/tokens-BqABmXSe.js +1 -1
- package/dist/plugin-sdk/tokens-CXsPDJTr.cjs +1 -1
- package/dist/plugin-sdk/tokens-CnB4dJmp.cjs +1 -1
- package/dist/plugin-sdk/tokens-CytSl1X8.cjs +1 -1
- package/dist/plugin-sdk/tokens-DgPZk2Uu.js +1 -1
- package/dist/plugin-sdk/tokens-Dq2wDF3_.cjs +1 -1
- package/dist/plugin-sdk/tokens-DtrljGtQ.cjs +1 -1
- package/dist/plugin-sdk/tokens-g5KWvWhD.cjs +1 -1
- package/dist/plugin-sdk/twitch.cjs +1 -1
- package/dist/plugin-sdk/twitch.js +1 -1
- package/dist/plugin-sdk/utils-BJtJR72k.js +1 -1
- package/dist/plugin-sdk/utils-PPIvU9qw.cjs +1 -1
- package/dist/plugin-sdk/voice-call.cjs +1 -1
- package/dist/plugin-sdk/voice-call.js +1 -1
- package/dist/plugin-sdk/web-B4A8zBP9.cjs +1 -1
- package/dist/plugin-sdk/web-BKKx3jqf.cjs +1 -1
- package/dist/plugin-sdk/web-BTBgpaEi.js +1 -1
- package/dist/plugin-sdk/web-BfjArU7g.js +1 -1
- package/dist/plugin-sdk/web-C7KhecaH.cjs +1 -1
- package/dist/plugin-sdk/web-CFMrBQv7.js +1 -1
- package/dist/plugin-sdk/web-CS0AvKLx.js +1 -1
- package/dist/plugin-sdk/web-EfgEjg15.cjs +1 -1
- package/dist/plugin-sdk/weixin.cjs +1 -1
- package/dist/plugin-sdk/weixin.js +1 -1
- package/dist/plugin-sdk/whatsapp-actions-6N2LIWVD.js +1 -1
- package/dist/plugin-sdk/whatsapp-actions-BGEghean.js +1 -1
- package/dist/plugin-sdk/whatsapp-actions-BP_fSzB9.cjs +1 -1
- package/dist/plugin-sdk/whatsapp-actions-BSx6-Onq.cjs +1 -1
- package/dist/plugin-sdk/whatsapp-actions-BZAMGDn8.cjs +1 -1
- package/dist/plugin-sdk/whatsapp-actions-BvZMduqd.js +1 -1
- package/dist/plugin-sdk/whatsapp-actions-CDUbwNdp.cjs +1 -1
- package/dist/plugin-sdk/whatsapp-actions-DNVIKnqz.cjs +1 -1
- package/dist/plugin-sdk/whatsapp-actions-DTVbVkOo.js +1 -1
- package/dist/plugin-sdk/whatsapp-actions-DjMYqpSS.js +1 -1
- package/dist/plugin-sdk/whatsapp-actions-P1DVqKhD.cjs +1 -1
- package/dist/plugin-sdk/whatsapp-actions-shElOKKX.js +1 -1
- package/dist/plugin-sdk/whatsapp.cjs +1 -1
- package/dist/plugin-sdk/whatsapp.js +1 -1
- package/dist/plugin-sdk/zalo.cjs +1 -1
- package/dist/plugin-sdk/zalo.js +1 -1
- package/dist/plugin-sdk/zalouser.cjs +1 -1
- package/dist/plugin-sdk/zalouser.js +1 -1
- package/dist/plugins-CYLrFT4h.js +1 -1
- package/dist/plugins-DNlgeTTc.js +1 -1
- package/dist/plugins-cli-BiV4FaGs.js +1 -1
- package/dist/plugins-cli-C0PLRxT0.js +1 -1
- package/dist/polls-BIVz6a4F.js +1 -1
- package/dist/polls-Bh5wc9-6.js +1 -1
- package/dist/polls-C_XSFz3d.js +1 -1
- package/dist/polls-DKJOFSzJ.js +1 -1
- package/dist/ports-Bjc9q__g.js +1 -1
- package/dist/ports-Di2_MOUb.js +1 -1
- package/dist/probe-auth-9RrZOStc.js +1 -1
- package/dist/probe-auth-Cg6SAov9.js +1 -1
- package/dist/profile-utils-CWmra1aY.js +1 -1
- package/dist/program-CI--7377.js +1 -1
- package/dist/program-context-CH9p6anW.js +1 -1
- package/dist/program-context-Cu8fVR-O.js +1 -1
- package/dist/progress-LNttnI-y.js +1 -1
- package/dist/progress-d1m2sqR1.js +1 -1
- package/dist/prompt-select-styled-CbTtKeIC.js +1 -1
- package/dist/prompt-select-styled-sYEl0gMg.js +1 -1
- package/dist/prompt-style-BThRSQJR.js +1 -1
- package/dist/prompt-style-CXKekIBY.js +1 -1
- package/dist/prompts-CMzglboN.js +1 -1
- package/dist/prompts-wv-lfVrJ.js +1 -1
- package/dist/provider-auth-helpers-C3OaF218.js +1 -1
- package/dist/provider-auth-helpers-CZyb7LUg.js +1 -1
- package/dist/provider-env-vars-D8p6Ohpj.js +1 -1
- package/dist/provider-env-vars-Dt0Q29Su.js +1 -1
- package/dist/proxy-env-BNhTHkd_.js +1 -1
- package/dist/proxy-env-DcmW_urA.js +1 -1
- package/dist/proxy-env-DrC3TIGh.js +1 -1
- package/dist/proxy-env-FJr5nlvs.js +1 -1
- package/dist/proxy-fetch-BADsUK4d.js +1 -1
- package/dist/proxy-fetch-BZ9O8Dvj.js +1 -1
- package/dist/proxy-fetch-DnjU1fEB.js +1 -1
- package/dist/proxy-fetch-gWETR3cl.js +1 -1
- package/dist/push-apns-kySzOiJr.js +1 -1
- package/dist/push-apns-tM6G9LLm.js +1 -1
- package/dist/pw-ai-B7YMA_4Q.js +1 -1
- package/dist/pw-ai-C7peCONw.js +1 -1
- package/dist/pw-ai-CojtT9WR.js +1 -1
- package/dist/pw-ai-DWJWFzTA.js +1 -1
- package/dist/qmd-manager-C_e04BNg.js +1 -1
- package/dist/qmd-manager-DSQ_mDCl.js +1 -1
- package/dist/qmd-manager-DcBYbt_V.js +1 -1
- package/dist/qmd-manager-NLI0R6kp.js +1 -1
- package/dist/qr-cli-DUR7oW0_.js +1 -1
- package/dist/qr-cli-kb3ygh9I.js +1 -1
- package/dist/query-expansion-0OxEb1Io.js +1 -1
- package/dist/query-expansion-BUUx_oWg.js +1 -1
- package/dist/query-expansion-r_iXkNzt.js +1 -1
- package/dist/reaction-level-DVPHL14p.js +1 -1
- package/dist/reaction-message-id-BEEe7X3D.js +1 -1
- package/dist/read-only-account-inspect-DEnPVHTo.js +1 -1
- package/dist/redact-3_CiXMY6.js +1 -1
- package/dist/redact-CnRxK70G.js +1 -1
- package/dist/register.agent-BwmE1VD-.js +1 -1
- package/dist/register.agent-D1hQi_68.js +1 -1
- package/dist/register.backup-8s5jgnHQ.js +1 -1
- package/dist/register.backup-CAiwLaIW.js +1 -1
- package/dist/register.configure-BsTw4XfK.js +1 -1
- package/dist/register.configure-DxR84Ot6.js +1 -1
- package/dist/register.maintenance-3nzWAo_a.js +1 -1
- package/dist/register.maintenance-DxKGQ9Jo.js +1 -1
- package/dist/register.message-Bk1pHVSK.js +1 -1
- package/dist/register.message-PcFtBR0-.js +1 -1
- package/dist/register.onboard-AWxbhU7j.js +1 -1
- package/dist/register.onboard-BTOZN8ro.js +1 -1
- package/dist/register.setup-B-e1qIbc.js +1 -1
- package/dist/register.setup-CweJJdt8.js +1 -1
- package/dist/register.status-health-sessions-B1R_nl6P.js +1 -1
- package/dist/register.status-health-sessions-CWNLXpAn.js +1 -1
- package/dist/register.subclis-C0VQ_HfZ.js +1 -1
- package/dist/registry-BptzrW8D.js +1 -1
- package/dist/registry-hFAtCSWG.js +1 -1
- package/dist/render-BXEUPIHe.js +1 -1
- package/dist/render-CBsnn-2A.js +1 -1
- package/dist/render-D8OWO2hT.js +1 -1
- package/dist/render-DrrPmnMI.js +1 -1
- package/dist/reply-r9KtzgpM.js +1 -1
- package/dist/restart-CTfuVGfA.js +1 -1
- package/dist/rpc-BQXfCyCw.js +1 -1
- package/dist/rpc-CcrILVsV.js +1 -1
- package/dist/run-main-CuQQyoU3.js +1 -1
- package/dist/runtime-BlsMYeaw.js +1 -1
- package/dist/runtime-DLxfCs7F.js +1 -1
- package/dist/runtime-guard-DFYBaYZS.js +1 -1
- package/dist/runtime-guard-DX2Ie4ri.js +1 -1
- package/dist/runtime-status-CqFBmdRd.js +1 -1
- package/dist/runtime-status-DszMjvJK.js +1 -1
- package/dist/runtime-web-tools-BWv0X5qp.js +1 -1
- package/dist/runtime-web-tools-CCIXUISf.js +1 -1
- package/dist/sandbox-cli-CxluKLFV.js +1 -1
- package/dist/sandbox-cli-xCX6FV4Z.js +1 -1
- package/dist/scan-paths-C13EseXp.js +1 -1
- package/dist/scan-paths-CWtvWW40.js +1 -1
- package/dist/search-manager-KMRzwyPH.js +1 -1
- package/dist/secret-file-C7JffiM_.js +1 -1
- package/dist/secret-file-D60EFEOe.js +1 -1
- package/dist/secret-file-DuWm26jS.js +1 -1
- package/dist/secrets-cli-Be6OBr6Q.js +1 -1
- package/dist/secrets-cli-DmDZiX17.js +1 -1
- package/dist/secure-random-D7JQgiK-.js +1 -1
- package/dist/security-cli-CllLwpQ-.js +1 -1
- package/dist/security-cli-DcA9keUK.js +1 -1
- package/dist/send-8rJCpsDu.js +1 -1
- package/dist/send-BJjoLBo3.js +1 -1
- package/dist/send-BOxuQt9L.js +1 -1
- package/dist/send-BPfl_1It.js +1 -1
- package/dist/send-BdS6jUBa.js +1 -1
- package/dist/send-BeZJ1zbp.js +1 -1
- package/dist/send-BkZ8dWQV2.js +1 -1
- package/dist/send-CDAeI9xB2.js +1 -1
- package/dist/send-CgeRzkWS.js +1 -1
- package/dist/send-CiTZ4p2t.js +1 -1
- package/dist/send-D0y-r_hg2.js +1 -1
- package/dist/send-DIw8ExHc.js +1 -1
- package/dist/send-DRm6AFp-.js +1 -1
- package/dist/send-DS5Quwb7.js +1 -1
- package/dist/send-DVmPgxm7.js +1 -1
- package/dist/send-Ds5sy22D.js +1 -1
- package/dist/send-DvGzdoKK.js +1 -1
- package/dist/send-OVet2uKx.js +1 -1
- package/dist/send-YPQFx-fV.js +1 -1
- package/dist/send-e2ppdA_R.js +1 -1
- package/dist/server-Dzqb5Tau.js +1 -1
- package/dist/server-node-events-B2irOUJ_.js +1 -1
- package/dist/server-node-events-DSr6P0VG.js +1 -1
- package/dist/server-w7sUBJEA.js +1 -1
- package/dist/service-BtB9epJk.js +1 -1
- package/dist/service-DZ9EbS15.js +1 -1
- package/dist/session-BYYOduc1.js +1 -1
- package/dist/session-B_qrXLsR.js +1 -1
- package/dist/session-Be0RV2V1.js +1 -1
- package/dist/session-bk3gFwO4.js +1 -1
- package/dist/session-cost-usage-BgqKixv0.js +1 -1
- package/dist/session-cost-usage-CHtVgnE8.js +1 -1
- package/dist/session-key-C7F_iqYg.js +1 -1
- package/dist/session-key-D3P0tf5P.js +1 -1
- package/dist/session-utils-CrR0wD3W.js +1 -1
- package/dist/sessions-BvTGb3rW.js +1 -1
- package/dist/shared-9x5sqYRb.js +1 -1
- package/dist/shared-BKWhOp64.js +1 -1
- package/dist/shared-BV-hfJ3h.js +1 -1
- package/dist/skill-commands-C59b8Yso.js +1 -1
- package/dist/skill-commands-CqIEajsA.js +1 -1
- package/dist/skill-commands-F5NFH0NR.js +1 -1
- package/dist/skill-commands-O39uSj-k.js +1 -1
- package/dist/skill-scanner-CUUF3Fvo.js +1 -1
- package/dist/skill-scanner-CkxXNioD.js +1 -1
- package/dist/skills-CKTicUKS.js +1 -1
- package/dist/skills-DHbOKEGc.js +1 -1
- package/dist/skills-cli-CZD1Ng18.js +1 -1
- package/dist/skills-cli-nj0w4fe0.js +1 -1
- package/dist/skills-install-D0I6c17J.js +1 -1
- package/dist/skills-install-XHpqMBWl.js +1 -1
- package/dist/skills-status-BWIugRCz.js +1 -1
- package/dist/skills-status-DswSl5aD.js +1 -1
- package/dist/sqlite-CILF3z9U.js +1 -1
- package/dist/stagger-DmFYysrJ.js +1 -1
- package/dist/stagger-DxzgG2jd.js +1 -1
- package/dist/status-DKB9gdSp.js +1 -1
- package/dist/status-DgRrUxyg.js +1 -1
- package/dist/status-YZD9V9xi.js +1 -1
- package/dist/status-isxcm8Xz.js +1 -1
- package/dist/status.update-B_8Gumuc.js +1 -1
- package/dist/status.update-Cf2e-l9d.js +1 -1
- package/dist/string-normalization-BrUPaXaM.js +1 -1
- package/dist/string-normalization-DJT5zuUF.js +1 -1
- package/dist/subsystem-BLbY429l.js +1 -1
- package/dist/subsystem-Bc2XrjUz.js +1 -1
- package/dist/subsystem-C5XF2Fy5.js +1 -1
- package/dist/system-cli-CRs3TOTw.js +1 -1
- package/dist/system-cli-GyoLZQpj.js +1 -1
- package/dist/system-run-command-DCzdgYyb.js +1 -1
- package/dist/system-run-command-FCk9hSMO.js +1 -1
- package/dist/systemd-D7odsu4K.js +1 -1
- package/dist/systemd-DbevZh65.js +1 -1
- package/dist/systemd-hints-lXpMy-kY.js +1 -1
- package/dist/systemd-hints-x1lJAOxS.js +1 -1
- package/dist/systemd-linger-C2MJD6KG.js +1 -1
- package/dist/systemd-linger-cWKbFNpu.js +1 -1
- package/dist/table-CR7TFMew.js +1 -1
- package/dist/table-CY440fI1.js +1 -1
- package/dist/tables-3Rjt6nwZ.js +1 -1
- package/dist/tables-B9wFKQvT.js +1 -1
- package/dist/tables-D1pcaye7.js +1 -1
- package/dist/tables-h7y1Jhf4.js +1 -1
- package/dist/target-errors-CUQcIty1.js +1 -1
- package/dist/target-errors-D55sWZ4E.js +1 -1
- package/dist/target-errors-DH0aw-m5.js +1 -1
- package/dist/target-errors-LuLROpta.js +1 -1
- package/dist/targets-4EaxWBal.js +1 -1
- package/dist/targets-BJTo7bqu.js +1 -1
- package/dist/targets-BYVMrXDf.js +1 -1
- package/dist/targets-Bq6rS6-Z.js +1 -1
- package/dist/targets-CL5fYQi7.js +1 -1
- package/dist/targets-fozeWOOg.js +1 -1
- package/dist/targets-m_41k_Mv.js +1 -1
- package/dist/telegram/audit.js +1 -1
- package/dist/text-format-CvrvBBre.js +1 -1
- package/dist/text-format-DEWK6oCT.js +1 -1
- package/dist/token-DnTmiyJu.js +1 -1
- package/dist/tokens-B2fq-rL6.js +1 -1
- package/dist/tokens-CL2fSjGl.js +1 -1
- package/dist/tokens-DRM8vzJx.js +1 -1
- package/dist/tokens-XGbQGn67.js +1 -1
- package/dist/tool-display-DJDtttQg.js +1 -1
- package/dist/tool-display-DjuSUUbH.js +1 -1
- package/dist/tui-CqEb9hrT.js +1 -1
- package/dist/tui-DdZ8SpNW.js +1 -1
- package/dist/tui-cli-Bj0okLCf.js +1 -1
- package/dist/tui-cli-CYvBshyB.js +1 -1
- package/dist/types.secrets-C-5U96pc.js +1 -1
- package/dist/types.secrets-D4tbc3Wq.js +1 -1
- package/dist/update-BGrxUIyz.js +1 -1
- package/dist/update-CwTy5DPl.js +1 -1
- package/dist/update-cli-lciKU8_L.js +1 -1
- package/dist/update-cli-xb0jHjE8.js +1 -1
- package/dist/update-runner-8Hto6X-M.js +1 -1
- package/dist/update-runner-LVJcy569.js +1 -1
- package/dist/usage-format-BWD8FJFL.js +1 -1
- package/dist/usage-format-yPwal8Iz.js +1 -1
- package/dist/utils-CGdo13HV.js +1 -1
- package/dist/utils-D3t-vPka.js +1 -1
- package/dist/utils-R-mFyVJi.js +1 -1
- package/dist/utils-UGOV_184.js +1 -1
- package/dist/version-q3SkUw2K.js +1 -1
- package/dist/warning-filter.js +1 -1
- package/dist/web-Bfz_qlYe.js +1 -1
- package/dist/web-ClbIohhf.js +1 -1
- package/dist/webhooks-cli-DKfKihmJ.js +1 -1
- package/dist/webhooks-cli-LU2ADRQp.js +1 -1
- package/dist/whatsapp-actions-1TJ8dlv0.js +1 -1
- package/dist/whatsapp-actions-CuDiuPGa.js +1 -1
- package/dist/whatsapp-actions-DkLDOIk1.js +1 -1
- package/dist/whatsapp-actions-EnduXWui.js +1 -1
- package/dist/widearea-dns-BDx7vkV2.js +1 -1
- package/dist/widearea-dns-BFjqKXu_.js +1 -1
- package/dist/windows-spawn-7oINn5ao.js +1 -1
- package/dist/windows-spawn-AB7ItGAE.js +1 -1
- package/dist/with-timeout-WveKxvFV.js +1 -1
- package/dist/with-timeout-c1CzdShT.js +1 -1
- package/dist/workspace-B0ZQeHXg.js +1 -1
- package/dist/workspace-C45T1Cxg.js +1 -1
- package/dist/workspace-dirs-A8Vib9_B.js +1 -1
- package/dist/workspace-dirs-BhF1Dzxt.js +1 -1
- package/dist/workspace-xNEpaJvu.js +1 -1
- package/dist/wsl-DHxB2Ew_.js +1 -1
- package/dist/wsl-Ok7GaSJ6.js +1 -1
- package/extensions/memory-core/index.js +1 -0
- package/extensions/memory-core/package.json +1 -1
- package/extensions/openclaw-telemetry-galileo-embedded/index.js +4 -0
- package/extensions/openclaw-telemetry-galileo-embedded/package.json +2 -2
- package/extensions/openclaw-telemetry-galileo-embedded/src/service.js +13 -0
- package/extensions/openclaw-weixin/index.js +1 -0
- package/extensions/openclaw-weixin/package.json +3 -3
- package/extensions/openclaw-weixin/src/api/api.js +1 -0
- package/extensions/openclaw-weixin/src/api/config-cache.js +1 -0
- package/extensions/openclaw-weixin/src/api/session-guard.js +1 -0
- package/extensions/openclaw-weixin/src/api/types.js +1 -0
- package/extensions/openclaw-weixin/src/auth/accounts.js +1 -0
- package/extensions/openclaw-weixin/src/auth/login-qr.js +11 -0
- package/extensions/openclaw-weixin/src/auth/pairing.js +1 -0
- package/extensions/openclaw-weixin/src/cdn/aes-ecb.js +1 -0
- package/extensions/openclaw-weixin/src/cdn/cdn-upload.js +1 -0
- package/extensions/openclaw-weixin/src/cdn/cdn-url.js +1 -0
- package/extensions/openclaw-weixin/src/cdn/pic-decrypt.js +1 -0
- package/extensions/openclaw-weixin/src/cdn/upload.js +1 -0
- package/extensions/openclaw-weixin/src/channel.js +6 -0
- package/extensions/openclaw-weixin/src/config/config-schema.js +1 -0
- package/extensions/openclaw-weixin/src/log-upload.js +4 -0
- package/extensions/openclaw-weixin/src/media/media-download.js +1 -0
- package/extensions/openclaw-weixin/src/media/mime.js +1 -0
- package/extensions/openclaw-weixin/src/media/silk-transcode.js +1 -0
- package/extensions/openclaw-weixin/src/messaging/debug-mode.js +1 -0
- package/extensions/openclaw-weixin/src/messaging/error-notice.js +1 -0
- package/extensions/openclaw-weixin/src/messaging/inbound.js +2 -0
- package/extensions/openclaw-weixin/src/messaging/process-message.js +3 -0
- package/extensions/openclaw-weixin/src/messaging/send-media.js +1 -0
- package/extensions/openclaw-weixin/src/messaging/send.js +1 -0
- package/extensions/openclaw-weixin/src/messaging/slash-commands.js +2 -0
- package/extensions/openclaw-weixin/src/monitor/monitor.js +1 -0
- package/extensions/openclaw-weixin/src/runtime.js +1 -0
- package/extensions/openclaw-weixin/src/storage/state-dir.js +1 -0
- package/extensions/openclaw-weixin/src/storage/sync-buf.js +1 -0
- package/extensions/openclaw-weixin/src/util/logger.js +2 -0
- package/extensions/openclaw-weixin/src/util/random.js +1 -0
- package/extensions/openclaw-weixin/src/util/redact.js +1 -0
- package/extensions/qbagent-mcp-server-x5uselocal-node/index.js +1 -0
- package/extensions/qbagent-mcp-server-x5uselocal-node/package.json +1 -1
- package/extensions/qbagent-mcp-server-x5uselocal-node/src/browser-use-tool.js +1 -0
- package/extensions/qbagent-mcp-server-x5uselocal-node/src/server.js +1 -0
- package/extensions/qbagent-mcp-server-x5uselocal-node/src/tools.js +1 -0
- package/extensions/qbagent-mcp-server-x5uselocal-node/src/websocket-manager.js +1 -0
- package/package.json +1 -1
- package/extensions/memory-core/index.ts +0 -38
- package/extensions/openclaw-telemetry-galileo-embedded/index.ts +0 -663
- package/extensions/openclaw-telemetry-galileo-embedded/src/service.ts +0 -1590
- package/extensions/openclaw-weixin/index.ts +0 -26
- package/extensions/openclaw-weixin/src/api/api.ts +0 -238
- package/extensions/openclaw-weixin/src/api/config-cache.ts +0 -79
- package/extensions/openclaw-weixin/src/api/session-guard.ts +0 -58
- package/extensions/openclaw-weixin/src/api/types.ts +0 -222
- package/extensions/openclaw-weixin/src/auth/accounts.ts +0 -363
- package/extensions/openclaw-weixin/src/auth/login-qr.ts +0 -344
- package/extensions/openclaw-weixin/src/auth/pairing.ts +0 -120
- package/extensions/openclaw-weixin/src/cdn/aes-ecb.ts +0 -21
- package/extensions/openclaw-weixin/src/cdn/cdn-upload.ts +0 -75
- package/extensions/openclaw-weixin/src/cdn/cdn-url.ts +0 -17
- package/extensions/openclaw-weixin/src/cdn/pic-decrypt.ts +0 -85
- package/extensions/openclaw-weixin/src/cdn/upload.ts +0 -154
- package/extensions/openclaw-weixin/src/channel.ts +0 -483
- package/extensions/openclaw-weixin/src/config/config-schema.ts +0 -21
- package/extensions/openclaw-weixin/src/log-upload.ts +0 -129
- package/extensions/openclaw-weixin/src/media/media-download.ts +0 -138
- package/extensions/openclaw-weixin/src/media/mime.ts +0 -76
- package/extensions/openclaw-weixin/src/media/silk-transcode.ts +0 -74
- package/extensions/openclaw-weixin/src/messaging/debug-mode.ts +0 -68
- package/extensions/openclaw-weixin/src/messaging/error-notice.ts +0 -36
- package/extensions/openclaw-weixin/src/messaging/inbound.ts +0 -283
- package/extensions/openclaw-weixin/src/messaging/process-message.ts +0 -488
- package/extensions/openclaw-weixin/src/messaging/send-media.ts +0 -76
- package/extensions/openclaw-weixin/src/messaging/send.ts +0 -267
- package/extensions/openclaw-weixin/src/messaging/slash-commands.ts +0 -105
- package/extensions/openclaw-weixin/src/monitor/monitor.ts +0 -225
- package/extensions/openclaw-weixin/src/runtime.ts +0 -67
- package/extensions/openclaw-weixin/src/storage/state-dir.ts +0 -11
- package/extensions/openclaw-weixin/src/storage/sync-buf.ts +0 -79
- package/extensions/openclaw-weixin/src/util/logger.ts +0 -146
- package/extensions/openclaw-weixin/src/util/random.ts +0 -17
- package/extensions/openclaw-weixin/src/util/redact.ts +0 -57
- package/extensions/openclaw-weixin/src/vendor.d.ts +0 -21
- package/extensions/qbagent-mcp-server-x5uselocal-node/index.ts +0 -140
- package/extensions/qbagent-mcp-server-x5uselocal-node/src/browser-use-tool.ts +0 -157
- package/extensions/qbagent-mcp-server-x5uselocal-node/src/server.ts +0 -135
- package/extensions/qbagent-mcp-server-x5uselocal-node/src/tools.ts +0 -205
- package/extensions/qbagent-mcp-server-x5uselocal-node/src/websocket-manager.ts +0 -351
|
@@ -2,4 +2,4 @@ import{Ct as e,Et as t,kt as n,s as r,wt as i}from"./paths-piJASC5k.js";import".
|
|
|
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(`
|
|
5
|
-
`);r&&(Z.warn(`Media skipped; sent text-only to ${n.from}`),await n.reply(r))}}}for(let e of _)await n.reply(e)}function an(e){if(!e.msg.id)return;let t=e.cfg.channels?.whatsapp?.ackReaction,n=(t?.emoji??``).trim(),r=t?.direct??!0,i=t?.group??`mentions`,a=e.msg.conversationId??e.msg.from,o=e.msg.chatType===`group`?Wt({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:a}):null;U({emoji:n,isDirect:e.msg.chatType===`direct`,isGroup:e.msg.chatType===`group`,directEnabled:r,groupMode:i,wasMentioned:e.msg.wasMentioned===!0,groupActivated:o===`always`})&&(e.info({chatId:e.msg.chatId,messageId:e.msg.id,emoji:n},`sending ack reaction`),ze(e.msg.chatId,e.msg.id,n,{verbose:e.verbose,fromMe:!1,participant:e.msg.senderJid,accountId:e.accountId}).catch(t=>{e.warn({error:q(t),chatId:e.msg.chatId,messageId:e.msg.id},`failed to send ack reaction`),u(`WhatsApp ack reaction failed for chat ${e.msg.chatId}: ${q(t)}`)}))}function on(e){return e.replyToBody?`[Replying to ${e.replyToSender??`unknown sender`}${e.replyToId?` id:${e.replyToId}`:``}]\n${e.replyToBody}\n[/Replying]`:null}function sn(e){let{cfg:t,msg:n,agentId:r,previousTimestamp:i,envelope:a}=e,o=oe(t,r,{configured:t.channels?.whatsapp?.messagePrefix,hasAllowFrom:(t.channels?.whatsapp?.allowFrom?.length??0)>0}),s=o?`${o} `:``,c=on(n),l=`${s}${n.body}${c?`\n\n${c}`:``}`;return R({channel:`WhatsApp`,from:n.chatType===`group`?n.from:n.from?.replace(/^whatsapp:/,``),timestamp:n.timestamp,body:l,chatType:n.chatType,sender:{name:n.senderName,e164:n.senderE164,id:n.senderJid},previousTimestamp:i,envelope:a,fromMe:n.fromMe})}async function cn(e){let t=e.cfg.commands?.useAccessGroups!==!1;if(!t)return!0;let n=e.msg.chatType===`group`,r=f(n?e.msg.senderE164??``:e.msg.senderE164??e.msg.from??``);if(!r)return!1;let i=b({cfg:e.cfg,accountId:e.msg.accountId}),a=i.dmPolicy??`pairing`,o=i.groupPolicy??`allowlist`,s=i.allowFrom??[],c=i.groupAllowFrom??(s.length>0?s:void 0),l=n?[]:await we({provider:`whatsapp`,accountId:e.msg.accountId,dmPolicy:a});return P({isGroup:n,dmPolicy:a,groupPolicy:o,allowFrom:s.length>0?s:e.msg.selfE164?[e.msg.selfE164]:[],groupAllowFrom:c,storeAllowFrom:l,isSenderAllowed:e=>e.includes(`*`)?!0:e.map(e=>f(String(e))).filter(e=>!!e).includes(r),command:{useAccessGroups:t,allowTextCommands:!0,hasControlCommand:!0}}).commandAuthorized}function ln(e){let t=b({cfg:e.cfg,accountId:e.msg.accountId});return z({dmScope:e.cfg.session?.dmScope,allowFrom:t.allowFrom,normalizeEntry:e=>f(e)})}async function un(e){let t=e.msg.conversationId??e.msg.from,{storePath:n,envelopeOptions:r,previousTimestamp:i}=ue({cfg:e.cfg,agentId:e.route.agentId,sessionKey:e.route.sessionKey}),o=sn({cfg:e.cfg,msg:e.msg,agentId:e.route.agentId,previousTimestamp:i,envelope:r}),s=!1;if(e.msg.chatType===`group`){let n=e.groupHistory??e.groupHistories.get(e.groupHistoryKey)??[];n.length>0&&(o=le({entries:n.map(e=>({sender:e.sender,body:e.body,timestamp:e.timestamp})),currentMessage:o,excludeLast:!1,formatEntry:e=>R({channel:`WhatsApp`,from:t,timestamp:e.timestamp,body:e.body,chatType:`group`,senderLabel:e.sender,envelope:r})})),s=!(e.suppressGroupHistoryClear??!1)}let c=e.buildCombinedEchoKey({sessionKey:e.route.sessionKey,combinedBody:o});if(e.echoHas(c))return u(`Skipping auto-reply: detected echo for combined message`),e.echoForget(c),!1;an({cfg:e.cfg,msg:e.msg,agentId:e.route.agentId,sessionKey:e.route.sessionKey,conversationId:t,verbose:e.verbose,accountId:e.route.accountId,info:e.replyLogger.info.bind(e.replyLogger),warn:e.replyLogger.warn.bind(e.replyLogger)});let l=e.msg.id??J();e.replyLogger.info({connectionId:e.connectionId,correlationId:l,from:e.msg.chatType===`group`?t:e.msg.from,to:e.msg.to,body:$(o,240),mediaType:e.msg.mediaType??null,mediaPath:e.msg.mediaPath??null},`inbound web message`);let d=e.msg.chatType===`group`?t:e.msg.from,m=e.msg.mediaType?`, ${e.msg.mediaType}`:``;X.info(`Inbound message ${d} -> ${e.msg.to} (${e.msg.chatType}${m}, ${o.length} chars)`),a()&&X.debug(`Inbound body: ${$(o,400)}`);let h=e.msg.chatType===`group`?void 0:e.msg.senderE164?f(e.msg.senderE164):e.msg.from.includes(`@`)?p(e.msg.from):f(e.msg.from),g=e.maxMediaTextChunkLimit??Me(e.cfg,`whatsapp`),_=je(e.cfg,`whatsapp`,e.route.accountId),y=Ne({cfg:e.cfg,channel:`whatsapp`,accountId:e.route.accountId}),b=Oe(e.cfg,e.route.agentId),x=!1,S=!1,C=I(e.msg.body,e.cfg)?await cn({cfg:e.cfg,msg:e.msg}):void 0,w=e.cfg.messages?.responsePrefix,{onModelSelected:T,...E}=he({cfg:e.cfg,agentId:e.route.agentId,channel:`whatsapp`,accountId:e.route.accountId}),D=e.msg.chatType!==`group`&&!!e.msg.selfE164&&f(e.msg.from)===f(e.msg.selfE164??``),ee=E.responsePrefix??(w===void 0&&D?L(e.cfg,e.route.agentId):void 0),te=e.msg.chatType===`group`?(e.groupHistory??e.groupHistories.get(e.groupHistoryKey)??[]).map(e=>({sender:e.sender,body:e.body,timestamp:e.timestamp})):void 0,O=ae({Body:o,BodyForAgent:e.msg.body,InboundHistory:te,RawBody:e.msg.body,CommandBody:e.msg.body,From:e.msg.from,To:e.msg.to,SessionKey:e.route.sessionKey,AccountId:e.route.accountId,MessageSid:e.msg.id,ReplyToId:e.msg.replyToId,ReplyToBody:e.msg.replyToBody,ReplyToSender:e.msg.replyToSender,MediaPath:e.msg.mediaPath,MediaUrl:e.msg.mediaUrl,MediaType:e.msg.mediaType,ChatType:e.msg.chatType,ConversationLabel:e.msg.chatType===`group`?t:e.msg.from,GroupSubject:e.msg.groupSubject,GroupMembers:qt({participants:e.msg.groupParticipants,roster:e.groupMemberNames.get(e.groupHistoryKey),fallbackE164:e.msg.senderE164}),SenderName:e.msg.senderName,SenderId:e.msg.senderJid?.trim()||e.msg.senderE164,SenderE164:e.msg.senderE164,CommandAuthorized:C,WasMentioned:e.msg.wasMentioned,...e.msg.location?Ee(e.msg.location):{},Provider:`whatsapp`,Surface:`whatsapp`,OriginatingChannel:`whatsapp`,OriginatingTo:e.msg.from}),k=ln({cfg:e.cfg,msg:e.msg}),ne=!k||k===h,A=H({route:e.route,sessionKey:e.route.sessionKey});h&&A===e.route.mainSessionKey&&ne?$t({cfg:e.cfg,backgroundTasks:e.backgroundTasks,storeAgentId:e.route.agentId,sessionKey:e.route.mainSessionKey,channel:`whatsapp`,to:h,accountId:e.route.accountId,ctx:O,warn:e.replyLogger.warn.bind(e.replyLogger)}):h&&A===e.route.mainSessionKey&&k&&u(`Skipping main-session last route update for ${h} (pinned owner ${k})`);let j=v({storePath:n,sessionKey:e.route.sessionKey,ctx:O}).catch(t=>{e.replyLogger.warn({error:q(t),storePath:n,sessionKey:e.route.sessionKey},`failed updating session meta`)});Qt(e.backgroundTasks,j);let{queuedFinal:M}=await Se({ctx:O,cfg:e.cfg,replyResolver:e.replyResolver,dispatcherOptions:{...E,responsePrefix:ee,onHeartbeatStrip:()=>{x||(x=!0,u(`Stripped stray HEARTBEAT_OK token from web reply`))},deliver:async(n,r)=>{if(r.kind!==`final`)return;await rn({replyResult:n,msg:e.msg,mediaLocalRoots:b,maxMediaBytes:e.maxMediaBytes,textLimit:g,chunkMode:_,replyLogger:e.replyLogger,connectionId:e.connectionId,skipLog:!1,tableMode:y}),S=!0;let i=n.text?!0:void 0;e.rememberSentText(n.text,{combinedBody:o,combinedBodySessionKey:e.route.sessionKey,logVerboseMessage:i});let s=e.msg.chatType===`group`?t:e.msg.from??`unknown`,c=!!(n.mediaUrl||n.mediaUrls?.length);if(Z.info(`Auto-replied to ${s}${c?` (media)`:``}`),a()){let e=n.text==null?`<media>`:$(n.text,400);Z.debug(`Reply body: ${e}${c?` (media)`:``}`)}},onError:(n,r)=>{let i=r.kind===`tool`?`tool update`:r.kind===`block`?`block update`:`auto-reply`;Z.error(`Failed sending web ${i} to ${e.msg.from??t}: ${q(n)}`)},onReplyStart:e.msg.sendComposing},replyOptions:{disableBlockStreaming:!0,onModelSelected:T}});return M?(s&&e.groupHistories.set(e.groupHistoryKey,[]),S):(s&&e.groupHistories.set(e.groupHistoryKey,[]),u(`Skipping auto-reply: silent token or no text/media returned from resolver`),!1)}function dn(e){let n=async(t,n,r,i)=>un({cfg:e.cfg,msg:t,route:n,groupHistoryKey:r,groupHistories:e.groupHistories,groupMemberNames:e.groupMemberNames,connectionId:e.connectionId,verbose:e.verbose,maxMediaBytes:e.maxMediaBytes,replyResolver:e.replyResolver,replyLogger:e.replyLogger,backgroundTasks:e.backgroundTasks,rememberSentText:e.echoTracker.rememberText,echoHas:e.echoTracker.has,echoForget:e.echoTracker.forget,buildCombinedEchoKey:e.echoTracker.buildCombinedKey,groupHistory:i?.groupHistory,suppressGroupHistoryClear:i?.suppressGroupHistoryClear});return async r=>{let i=r.conversationId??r.from,a=en(r),o=ce({cfg:A(),channel:`whatsapp`,accountId:r.accountId,peer:{kind:r.chatType===`group`?`group`:`direct`,id:a}}),s=r.chatType===`group`?t({channel:`whatsapp`,accountId:o.accountId,peerKind:`group`,peerId:a}):o.sessionKey;if(r.from===r.to&&u(`📱 Same-phone mode detected (from === to: ${r.from})`),e.echoTracker.has(r.body)){u(`Skipping auto-reply: detected echo (message matches recently sent text)`),e.echoTracker.forget(r.body);return}if(r.chatType===`group`){let t={From:r.from,To:r.to,SessionKey:o.sessionKey,AccountId:o.accountId,ChatType:r.chatType,ConversationLabel:i,GroupSubject:r.groupSubject,SenderName:r.senderName,SenderId:r.senderJid?.trim()||r.senderE164,SenderE164:r.senderE164,Provider:`whatsapp`,Surface:`whatsapp`,OriginatingChannel:`whatsapp`,OriginatingTo:i};if($t({cfg:e.cfg,backgroundTasks:e.backgroundTasks,storeAgentId:o.agentId,sessionKey:o.sessionKey,channel:`whatsapp`,to:i,accountId:o.accountId,ctx:t,warn:e.replyLogger.warn.bind(e.replyLogger)}),!Zt({cfg:e.cfg,msg:r,conversationId:i,groupHistoryKey:s,agentId:o.agentId,sessionKey:o.sessionKey,baseMentionConfig:e.baseMentionConfig,authDir:e.account.authDir,groupHistories:e.groupHistories,groupHistoryLimit:e.groupHistoryLimit,groupMemberNames:e.groupMemberNames,logVerbose:u,replyLogger:e.replyLogger}).shouldProcess)return}else !r.senderE164&&a&&a.startsWith(`+`)&&(r.senderE164=f(a)??r.senderE164);await Bt({cfg:e.cfg,msg:r,peerId:a,route:o,groupHistoryKey:s,groupHistories:e.groupHistories,processMessage:n})||await n(r,o,s)}}function fn(e){return e===440}async function pn(e,t=Mt,n=!0,r=ge,i=c,a,o={}){let l=J(),d=s({module:`web-auto-reply`,runId:l}),f=s({module:`web-heartbeat`,runId:l}),p=s({module:`web-reconnect`,runId:l}),m={running:!0,connected:!1,reconnectAttempts:0,lastConnectedAt:null,lastDisconnect:null,lastMessageAt:null,lastEventAt:null,lastError:null},h=()=>{o.statusSink?.({...m,lastDisconnect:m.lastDisconnect?{...m.lastDisconnect}:null})};h();let g=A(),v=b({cfg:g,accountId:o.accountId}),y={...g,channels:{...g.channels,whatsapp:{...g.channels?.whatsapp,ackReaction:v.ackReaction,messagePrefix:v.messagePrefix,allowFrom:v.allowFrom,groupAllowFrom:v.groupAllowFrom,groupPolicy:v.groupPolicy,textChunkLimit:v.textChunkLimit,chunkMode:v.chunkMode,mediaMaxMb:v.mediaMaxMb,blockStreaming:v.blockStreaming,groups:v.groups}}},S=C(v),w=$e(y,o.heartbeatSeconds),T=et(y,o.reconnect),D=Nt(y),ee=y.channels?.whatsapp?.accounts?.[o.accountId??``]?.historyLimit??y.channels?.whatsapp?.historyLimit??y.messages?.groupChat?.historyLimit??50,te=new Map,O=new Map,k=Rt({maxItems:100,logVerbose:u}),ne=o.sleep??((e,t)=>G(e,t??a)),j=()=>a?.aborted===!0,M=a&&new Promise(e=>a.addEventListener(`abort`,()=>e(`aborted`),{once:!0})),N=process.getMaxListeners?.()??10;process.setMaxListeners&&N<50&&process.setMaxListeners(50);let P=!1,F=()=>{P=!0};process.once(`SIGINT`,F);let I=0;for(;!j();){let s=J(),c=Date.now(),l=null,g=null,b=null,C=0,A=null,N=o.messageTimeoutMs??1800*1e3,ie=o.watchdogCheckMs??60*1e3,L=new Set,ae=dn({cfg:y,verbose:e,connectionId:s,maxMediaBytes:S,groupHistoryLimit:ee,groupHistories:te,groupMemberNames:O,echoTracker:k,backgroundTasks:L,replyResolver:r??ge,replyLogger:d,baseMentionConfig:D,account:v}),R=xe({cfg:y,channel:`whatsapp`}),z=await(t??Mt)({verbose:e,accountId:v.accountId,authDir:v.authDir,mediaMaxMb:v.mediaMaxMb,sendReadReceipts:v.sendReadReceipts,debounceMs:R,shouldDebounce:e=>e.mediaPath||e.mediaType||e.location||e.replyToId||e.replyToBody?!1:!re(e.body,y),onMessage:async e=>{C+=1,b=Date.now(),m.lastMessageAt=b,m.lastEventAt=b,h(),await ae(e)}});Object.assign(m,ye()),m.lastError=null,h();let{e164:B}=x(v.authDir),oe=ce({cfg:y,channel:`whatsapp`,accountId:v.accountId});be(`WhatsApp gateway connected${B?` as ${B}`:``}.`,{sessionKey:oe.sessionKey}),Le(v.accountId,z),A=Pe(e=>{if(!tn(e))return!1;let t=q(e);return p.warn({connectionId:s,error:t},`web reconnect: unhandled rejection from WhatsApp socket; forcing reconnect`),z.signalClose?.({status:499,isLoggedOut:!1,error:e}),!0});let V=async()=>{Le(v.accountId,null),A&&=(A(),null),l&&clearInterval(l),g&&clearInterval(g),L.size>0&&(await Promise.allSettled(L),L.clear());try{await z.close()}catch(e){u(`Socket close failed: ${q(e)}`)}};if(n&&(l=setInterval(()=>{let e=_(v.authDir),t=b?Math.floor((Date.now()-b)/6e4):null,n={connectionId:s,reconnectAttempts:I,messagesHandled:C,lastMessageAt:b,authAgeMs:e,uptimeMs:Date.now()-c,...t!==null&&t>30?{minutesSinceLastMessage:t}:{}};t&&t>30?f.warn(n,`⚠️ web gateway heartbeat - no messages in 30+ minutes`):f.info(n,`web gateway heartbeat`)},w*1e3),g=setInterval(()=>{if(!b)return;let e=Date.now()-b;if(e<=N)return;let t=Math.floor(e/6e4);f.warn({connectionId:s,minutesSinceLastMessage:t,lastMessageAt:new Date(b),messagesHandled:C},`Message timeout detected - forcing reconnect`),tt.warn(`No messages received in ${t}m - restarting connection`),V().catch(e=>{u(`Close listener failed: ${q(e)}`)}),z.signalClose?.({status:499,isLoggedOut:!1,error:`watchdog-timeout`})},ie)),Y.info(`Listening for personal WhatsApp inbound messages.`),(process.stdout.isTTY||process.stderr.isTTY)&&Y.raw(`Ctrl+C to stop.`),!n){await V(),process.removeListener(`SIGINT`,F);return}let H=await Promise.race([z.onClose?.catch(e=>(p.error({error:q(e)},`listener.onClose rejected`),{status:500,isLoggedOut:!1,error:e}))??nt(),M??nt()]);if(Date.now()-c>w*1e3&&(I=0),m.reconnectAttempts=I,h(),j()||P||H===`aborted`){await V();break}let U=(typeof H==`object`&&H&&`status`in H?H.status:void 0)??`unknown`,W=typeof H==`object`&&H&&`isLoggedOut`in H&&H.isLoggedOut,G=q(H);if(m.connected=!1,m.lastEventAt=Date.now(),m.lastDisconnect={at:m.lastEventAt,status:typeof U==`number`?U:void 0,error:G,loggedOut:!!W},m.lastError=G,m.reconnectAttempts=I,h(),p.info({connectionId:s,status:U,loggedOut:W,reconnectAttempts:I,error:G},`web reconnect: connection closed`),be(`WhatsApp gateway disconnected (status ${U??`unknown`})`,{sessionKey:oe.sessionKey}),W){i.error(`WhatsApp session logged out. Run \`${E(`openclaw channels login --channel web`)}\` to relink.`),await V();break}if(fn(U)){p.warn({connectionId:s,status:U,error:G},`web reconnect: non-retryable close status; stopping monitor`),i.error(`WhatsApp Web connection closed (status ${U}: session conflict). Resolve conflicting WhatsApp Web sessions, then relink with \`${E(`openclaw channels login --channel web`)}\`. Stopping web monitoring.`),await V();break}if(I+=1,m.reconnectAttempts=I,h(),T.maxAttempts>0&&I>=T.maxAttempts){p.warn({connectionId:s,status:U,reconnectAttempts:I,maxAttempts:T.maxAttempts},`web reconnect: max attempts reached; continuing in degraded mode`),i.error(`WhatsApp Web reconnect: max attempts reached (${I}/${T.maxAttempts}). Stopping web monitoring.`),await V();break}let K=se(T,I);p.info({connectionId:s,status:U,reconnectAttempts:I,maxAttempts:T.maxAttempts||`unlimited`,delayMs:K},`web reconnect: scheduling retry`),i.error(`WhatsApp Web connection closed (status ${U}). Retry ${I}/${T.maxAttempts||`∞`} in ${Ce(K)}… (${G})`),await V();try{await ne(K,a)}catch{break}}m.running=!1,m.connected=!1,m.lastEventAt=Date.now(),h(),process.removeListener(`SIGINT`,F)}export{te as WA_WEB_AUTH_DIR,Ue as createWaSocket,ee as logWebSelfId,We as loginWeb,pn as monitorWebChannel,Mt as monitorWebInbox,T as pickWebChannel,Be as sendMessageWhatsApp,Ve as waitForWaConnection,y as webAuthExists};
|
|
5
|
+
`);r&&(Z.warn(`Media skipped; sent text-only to ${n.from}`),await n.reply(r))}}}for(let e of _)await n.reply(e)}function an(e){if(!e.msg.id)return;let t=e.cfg.channels?.whatsapp?.ackReaction,n=(t?.emoji??``).trim(),r=t?.direct??!0,i=t?.group??`mentions`,a=e.msg.conversationId??e.msg.from,o=e.msg.chatType===`group`?Wt({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:a}):null;U({emoji:n,isDirect:e.msg.chatType===`direct`,isGroup:e.msg.chatType===`group`,directEnabled:r,groupMode:i,wasMentioned:e.msg.wasMentioned===!0,groupActivated:o===`always`})&&(e.info({chatId:e.msg.chatId,messageId:e.msg.id,emoji:n},`sending ack reaction`),ze(e.msg.chatId,e.msg.id,n,{verbose:e.verbose,fromMe:!1,participant:e.msg.senderJid,accountId:e.accountId}).catch(t=>{e.warn({error:q(t),chatId:e.msg.chatId,messageId:e.msg.id},`failed to send ack reaction`),u(`WhatsApp ack reaction failed for chat ${e.msg.chatId}: ${q(t)}`)}))}function on(e){return e.replyToBody?`[Replying to ${e.replyToSender??`unknown sender`}${e.replyToId?` id:${e.replyToId}`:``}]\n${e.replyToBody}\n[/Replying]`:null}function sn(e){let{cfg:t,msg:n,agentId:r,previousTimestamp:i,envelope:a}=e,o=oe(t,r,{configured:t.channels?.whatsapp?.messagePrefix,hasAllowFrom:(t.channels?.whatsapp?.allowFrom?.length??0)>0}),s=o?`${o} `:``,c=on(n),l=`${s}${n.body}${c?`\n\n${c}`:``}`;return R({channel:`WhatsApp`,from:n.chatType===`group`?n.from:n.from?.replace(/^whatsapp:/,``),timestamp:n.timestamp,body:l,chatType:n.chatType,sender:{name:n.senderName,e164:n.senderE164,id:n.senderJid},previousTimestamp:i,envelope:a,fromMe:n.fromMe})}async function cn(e){let t=e.cfg.commands?.useAccessGroups!==!1;if(!t)return!0;let n=e.msg.chatType===`group`,r=f(n?e.msg.senderE164??``:e.msg.senderE164??e.msg.from??``);if(!r)return!1;let i=b({cfg:e.cfg,accountId:e.msg.accountId}),a=i.dmPolicy??`pairing`,o=i.groupPolicy??`allowlist`,s=i.allowFrom??[],c=i.groupAllowFrom??(s.length>0?s:void 0),l=n?[]:await we({provider:`whatsapp`,accountId:e.msg.accountId,dmPolicy:a});return P({isGroup:n,dmPolicy:a,groupPolicy:o,allowFrom:s.length>0?s:e.msg.selfE164?[e.msg.selfE164]:[],groupAllowFrom:c,storeAllowFrom:l,isSenderAllowed:e=>e.includes(`*`)?!0:e.map(e=>f(String(e))).filter(e=>!!e).includes(r),command:{useAccessGroups:t,allowTextCommands:!0,hasControlCommand:!0}}).commandAuthorized}function ln(e){let t=b({cfg:e.cfg,accountId:e.msg.accountId});return z({dmScope:e.cfg.session?.dmScope,allowFrom:t.allowFrom,normalizeEntry:e=>f(e)})}async function un(e){let t=e.msg.conversationId??e.msg.from,{storePath:n,envelopeOptions:r,previousTimestamp:i}=ue({cfg:e.cfg,agentId:e.route.agentId,sessionKey:e.route.sessionKey}),o=sn({cfg:e.cfg,msg:e.msg,agentId:e.route.agentId,previousTimestamp:i,envelope:r}),s=!1;if(e.msg.chatType===`group`){let n=e.groupHistory??e.groupHistories.get(e.groupHistoryKey)??[];n.length>0&&(o=le({entries:n.map(e=>({sender:e.sender,body:e.body,timestamp:e.timestamp})),currentMessage:o,excludeLast:!1,formatEntry:e=>R({channel:`WhatsApp`,from:t,timestamp:e.timestamp,body:e.body,chatType:`group`,senderLabel:e.sender,envelope:r})})),s=!(e.suppressGroupHistoryClear??!1)}let c=e.buildCombinedEchoKey({sessionKey:e.route.sessionKey,combinedBody:o});if(e.echoHas(c))return u(`Skipping auto-reply: detected echo for combined message`),e.echoForget(c),!1;an({cfg:e.cfg,msg:e.msg,agentId:e.route.agentId,sessionKey:e.route.sessionKey,conversationId:t,verbose:e.verbose,accountId:e.route.accountId,info:e.replyLogger.info.bind(e.replyLogger),warn:e.replyLogger.warn.bind(e.replyLogger)});let l=e.msg.id??J();e.replyLogger.info({connectionId:e.connectionId,correlationId:l,from:e.msg.chatType===`group`?t:e.msg.from,to:e.msg.to,body:$(o,240),mediaType:e.msg.mediaType??null,mediaPath:e.msg.mediaPath??null},`inbound web message`);let d=e.msg.chatType===`group`?t:e.msg.from,m=e.msg.mediaType?`, ${e.msg.mediaType}`:``;X.info(`Inbound message ${d} -> ${e.msg.to} (${e.msg.chatType}${m}, ${o.length} chars)`),a()&&X.debug(`Inbound body: ${$(o,400)}`);let h=e.msg.chatType===`group`?void 0:e.msg.senderE164?f(e.msg.senderE164):e.msg.from.includes(`@`)?p(e.msg.from):f(e.msg.from),g=e.maxMediaTextChunkLimit??Me(e.cfg,`whatsapp`),_=je(e.cfg,`whatsapp`,e.route.accountId),y=Ne({cfg:e.cfg,channel:`whatsapp`,accountId:e.route.accountId}),b=Oe(e.cfg,e.route.agentId),x=!1,S=!1,C=I(e.msg.body,e.cfg)?await cn({cfg:e.cfg,msg:e.msg}):void 0,w=e.cfg.messages?.responsePrefix,{onModelSelected:T,...E}=he({cfg:e.cfg,agentId:e.route.agentId,channel:`whatsapp`,accountId:e.route.accountId}),D=e.msg.chatType!==`group`&&!!e.msg.selfE164&&f(e.msg.from)===f(e.msg.selfE164??``),ee=E.responsePrefix??(w===void 0&&D?L(e.cfg,e.route.agentId):void 0),te=e.msg.chatType===`group`?(e.groupHistory??e.groupHistories.get(e.groupHistoryKey)??[]).map(e=>({sender:e.sender,body:e.body,timestamp:e.timestamp})):void 0,O=ae({Body:o,BodyForAgent:e.msg.body,InboundHistory:te,RawBody:e.msg.body,CommandBody:e.msg.body,From:e.msg.from,To:e.msg.to,SessionKey:e.route.sessionKey,AccountId:e.route.accountId,MessageSid:e.msg.id,ReplyToId:e.msg.replyToId,ReplyToBody:e.msg.replyToBody,ReplyToSender:e.msg.replyToSender,MediaPath:e.msg.mediaPath,MediaUrl:e.msg.mediaUrl,MediaType:e.msg.mediaType,ChatType:e.msg.chatType,ConversationLabel:e.msg.chatType===`group`?t:e.msg.from,GroupSubject:e.msg.groupSubject,GroupMembers:qt({participants:e.msg.groupParticipants,roster:e.groupMemberNames.get(e.groupHistoryKey),fallbackE164:e.msg.senderE164}),SenderName:e.msg.senderName,SenderId:e.msg.senderJid?.trim()||e.msg.senderE164,SenderE164:e.msg.senderE164,CommandAuthorized:C,WasMentioned:e.msg.wasMentioned,...e.msg.location?Ee(e.msg.location):{},Provider:`whatsapp`,Surface:`whatsapp`,OriginatingChannel:`whatsapp`,OriginatingTo:e.msg.from}),k=ln({cfg:e.cfg,msg:e.msg}),ne=!k||k===h,A=H({route:e.route,sessionKey:e.route.sessionKey});h&&A===e.route.mainSessionKey&&ne?$t({cfg:e.cfg,backgroundTasks:e.backgroundTasks,storeAgentId:e.route.agentId,sessionKey:e.route.mainSessionKey,channel:`whatsapp`,to:h,accountId:e.route.accountId,ctx:O,warn:e.replyLogger.warn.bind(e.replyLogger)}):h&&A===e.route.mainSessionKey&&k&&u(`Skipping main-session last route update for ${h} (pinned owner ${k})`);let j=v({storePath:n,sessionKey:e.route.sessionKey,ctx:O}).catch(t=>{e.replyLogger.warn({error:q(t),storePath:n,sessionKey:e.route.sessionKey},`failed updating session meta`)});Qt(e.backgroundTasks,j);let{queuedFinal:M}=await Se({ctx:O,cfg:e.cfg,replyResolver:e.replyResolver,dispatcherOptions:{...E,responsePrefix:ee,onHeartbeatStrip:()=>{x||(x=!0,u(`Stripped stray HEARTBEAT_OK token from web reply`))},deliver:async(n,r)=>{if(r.kind!==`final`)return;await rn({replyResult:n,msg:e.msg,mediaLocalRoots:b,maxMediaBytes:e.maxMediaBytes,textLimit:g,chunkMode:_,replyLogger:e.replyLogger,connectionId:e.connectionId,skipLog:!1,tableMode:y}),S=!0;let i=n.text?!0:void 0;e.rememberSentText(n.text,{combinedBody:o,combinedBodySessionKey:e.route.sessionKey,logVerboseMessage:i});let s=e.msg.chatType===`group`?t:e.msg.from??`unknown`,c=!!(n.mediaUrl||n.mediaUrls?.length);if(Z.info(`Auto-replied to ${s}${c?` (media)`:``}`),a()){let e=n.text==null?`<media>`:$(n.text,400);Z.debug(`Reply body: ${e}${c?` (media)`:``}`)}},onError:(n,r)=>{let i=r.kind===`tool`?`tool update`:r.kind===`block`?`block update`:`auto-reply`;Z.error(`Failed sending web ${i} to ${e.msg.from??t}: ${q(n)}`)},onReplyStart:e.msg.sendComposing},replyOptions:{disableBlockStreaming:!0,onModelSelected:T}});return M?(s&&e.groupHistories.set(e.groupHistoryKey,[]),S):(s&&e.groupHistories.set(e.groupHistoryKey,[]),u(`Skipping auto-reply: silent token or no text/media returned from resolver`),!1)}function dn(e){let n=async(t,n,r,i)=>un({cfg:e.cfg,msg:t,route:n,groupHistoryKey:r,groupHistories:e.groupHistories,groupMemberNames:e.groupMemberNames,connectionId:e.connectionId,verbose:e.verbose,maxMediaBytes:e.maxMediaBytes,replyResolver:e.replyResolver,replyLogger:e.replyLogger,backgroundTasks:e.backgroundTasks,rememberSentText:e.echoTracker.rememberText,echoHas:e.echoTracker.has,echoForget:e.echoTracker.forget,buildCombinedEchoKey:e.echoTracker.buildCombinedKey,groupHistory:i?.groupHistory,suppressGroupHistoryClear:i?.suppressGroupHistoryClear});return async r=>{let i=r.conversationId??r.from,a=en(r),o=ce({cfg:A(),channel:`whatsapp`,accountId:r.accountId,peer:{kind:r.chatType===`group`?`group`:`direct`,id:a}}),s=r.chatType===`group`?t({channel:`whatsapp`,accountId:o.accountId,peerKind:`group`,peerId:a}):o.sessionKey;if(r.from===r.to&&u(`📱 Same-phone mode detected (from === to: ${r.from})`),e.echoTracker.has(r.body)){u(`Skipping auto-reply: detected echo (message matches recently sent text)`),e.echoTracker.forget(r.body);return}if(r.chatType===`group`){let t={From:r.from,To:r.to,SessionKey:o.sessionKey,AccountId:o.accountId,ChatType:r.chatType,ConversationLabel:i,GroupSubject:r.groupSubject,SenderName:r.senderName,SenderId:r.senderJid?.trim()||r.senderE164,SenderE164:r.senderE164,Provider:`whatsapp`,Surface:`whatsapp`,OriginatingChannel:`whatsapp`,OriginatingTo:i};if($t({cfg:e.cfg,backgroundTasks:e.backgroundTasks,storeAgentId:o.agentId,sessionKey:o.sessionKey,channel:`whatsapp`,to:i,accountId:o.accountId,ctx:t,warn:e.replyLogger.warn.bind(e.replyLogger)}),!Zt({cfg:e.cfg,msg:r,conversationId:i,groupHistoryKey:s,agentId:o.agentId,sessionKey:o.sessionKey,baseMentionConfig:e.baseMentionConfig,authDir:e.account.authDir,groupHistories:e.groupHistories,groupHistoryLimit:e.groupHistoryLimit,groupMemberNames:e.groupMemberNames,logVerbose:u,replyLogger:e.replyLogger}).shouldProcess)return}else !r.senderE164&&a&&a.startsWith(`+`)&&(r.senderE164=f(a)??r.senderE164);await Bt({cfg:e.cfg,msg:r,peerId:a,route:o,groupHistoryKey:s,groupHistories:e.groupHistories,processMessage:n})||await n(r,o,s)}}function fn(e){return e===440}async function pn(e,t=Mt,n=!0,r=ge,i=c,a,o={}){let l=J(),d=s({module:`web-auto-reply`,runId:l}),f=s({module:`web-heartbeat`,runId:l}),p=s({module:`web-reconnect`,runId:l}),m={running:!0,connected:!1,reconnectAttempts:0,lastConnectedAt:null,lastDisconnect:null,lastMessageAt:null,lastEventAt:null,lastError:null},h=()=>{o.statusSink?.({...m,lastDisconnect:m.lastDisconnect?{...m.lastDisconnect}:null})};h();let g=A(),v=b({cfg:g,accountId:o.accountId}),y={...g,channels:{...g.channels,whatsapp:{...g.channels?.whatsapp,ackReaction:v.ackReaction,messagePrefix:v.messagePrefix,allowFrom:v.allowFrom,groupAllowFrom:v.groupAllowFrom,groupPolicy:v.groupPolicy,textChunkLimit:v.textChunkLimit,chunkMode:v.chunkMode,mediaMaxMb:v.mediaMaxMb,blockStreaming:v.blockStreaming,groups:v.groups}}},S=C(v),w=$e(y,o.heartbeatSeconds),T=et(y,o.reconnect),D=Nt(y),ee=y.channels?.whatsapp?.accounts?.[o.accountId??``]?.historyLimit??y.channels?.whatsapp?.historyLimit??y.messages?.groupChat?.historyLimit??50,te=new Map,O=new Map,k=Rt({maxItems:100,logVerbose:u}),ne=o.sleep??((e,t)=>G(e,t??a)),j=()=>a?.aborted===!0,M=a&&new Promise(e=>a.addEventListener(`abort`,()=>e(`aborted`),{once:!0})),N=process.getMaxListeners?.()??10;process.setMaxListeners&&N<50&&process.setMaxListeners(50);let P=!1,F=()=>{P=!0};process.once(`SIGINT`,F);let I=0;for(;!j();){let s=J(),c=Date.now(),l=null,g=null,b=null,C=0,A=null,N=o.messageTimeoutMs??1800*1e3,ie=o.watchdogCheckMs??60*1e3,L=new Set,ae=dn({cfg:y,verbose:e,connectionId:s,maxMediaBytes:S,groupHistoryLimit:ee,groupHistories:te,groupMemberNames:O,echoTracker:k,backgroundTasks:L,replyResolver:r??ge,replyLogger:d,baseMentionConfig:D,account:v}),R=xe({cfg:y,channel:`whatsapp`}),z=await(t??Mt)({verbose:e,accountId:v.accountId,authDir:v.authDir,mediaMaxMb:v.mediaMaxMb,sendReadReceipts:v.sendReadReceipts,debounceMs:R,shouldDebounce:e=>e.mediaPath||e.mediaType||e.location||e.replyToId||e.replyToBody?!1:!re(e.body,y),onMessage:async e=>{C+=1,b=Date.now(),m.lastMessageAt=b,m.lastEventAt=b,h(),await ae(e)}});Object.assign(m,ye()),m.lastError=null,h();let{e164:B}=x(v.authDir),oe=ce({cfg:y,channel:`whatsapp`,accountId:v.accountId});be(`WhatsApp gateway connected${B?` as ${B}`:``}.`,{sessionKey:oe.sessionKey}),Le(v.accountId,z),A=Pe(e=>{if(!tn(e))return!1;let t=q(e);return p.warn({connectionId:s,error:t},`web reconnect: unhandled rejection from WhatsApp socket; forcing reconnect`),z.signalClose?.({status:499,isLoggedOut:!1,error:e}),!0});let V=async()=>{Le(v.accountId,null),A&&=(A(),null),l&&clearInterval(l),g&&clearInterval(g),L.size>0&&(await Promise.allSettled(L),L.clear());try{await z.close()}catch(e){u(`Socket close failed: ${q(e)}`)}};if(n&&(l=setInterval(()=>{let e=_(v.authDir),t=b?Math.floor((Date.now()-b)/6e4):null,n={connectionId:s,reconnectAttempts:I,messagesHandled:C,lastMessageAt:b,authAgeMs:e,uptimeMs:Date.now()-c,...t!==null&&t>30?{minutesSinceLastMessage:t}:{}};t&&t>30?f.warn(n,`⚠️ web gateway heartbeat - no messages in 30+ minutes`):f.info(n,`web gateway heartbeat`)},w*1e3),g=setInterval(()=>{if(!b)return;let e=Date.now()-b;if(e<=N)return;let t=Math.floor(e/6e4);f.warn({connectionId:s,minutesSinceLastMessage:t,lastMessageAt:new Date(b),messagesHandled:C},`Message timeout detected - forcing reconnect`),tt.warn(`No messages received in ${t}m - restarting connection`),V().catch(e=>{u(`Close listener failed: ${q(e)}`)}),z.signalClose?.({status:499,isLoggedOut:!1,error:`watchdog-timeout`})},ie)),Y.info(`Listening for personal WhatsApp inbound messages.`),(process.stdout.isTTY||process.stderr.isTTY)&&Y.raw(`Ctrl+C to stop.`),!n){await V(),process.removeListener(`SIGINT`,F);return}let H=await Promise.race([z.onClose?.catch(e=>(p.error({error:q(e)},`listener.onClose rejected`),{status:500,isLoggedOut:!1,error:e}))??nt(),M??nt()]);if(Date.now()-c>w*1e3&&(I=0),m.reconnectAttempts=I,h(),j()||P||H===`aborted`){await V();break}let U=(typeof H==`object`&&H&&`status`in H?H.status:void 0)??`unknown`,W=typeof H==`object`&&H&&`isLoggedOut`in H&&H.isLoggedOut,G=q(H);if(m.connected=!1,m.lastEventAt=Date.now(),m.lastDisconnect={at:m.lastEventAt,status:typeof U==`number`?U:void 0,error:G,loggedOut:!!W},m.lastError=G,m.reconnectAttempts=I,h(),p.info({connectionId:s,status:U,loggedOut:W,reconnectAttempts:I,error:G},`web reconnect: connection closed`),be(`WhatsApp gateway disconnected (status ${U??`unknown`})`,{sessionKey:oe.sessionKey}),W){i.error(`WhatsApp session logged out. Run \`${E(`openclaw channels login --channel web`)}\` to relink.`),await V();break}if(fn(U)){p.warn({connectionId:s,status:U,error:G},`web reconnect: non-retryable close status; stopping monitor`),i.error(`WhatsApp Web connection closed (status ${U}: session conflict). Resolve conflicting WhatsApp Web sessions, then relink with \`${E(`openclaw channels login --channel web`)}\`. Stopping web monitoring.`),await V();break}if(I+=1,m.reconnectAttempts=I,h(),T.maxAttempts>0&&I>=T.maxAttempts){p.warn({connectionId:s,status:U,reconnectAttempts:I,maxAttempts:T.maxAttempts},`web reconnect: max attempts reached; continuing in degraded mode`),i.error(`WhatsApp Web reconnect: max attempts reached (${I}/${T.maxAttempts}). Stopping web monitoring.`),await V();break}let K=se(T,I);p.info({connectionId:s,status:U,reconnectAttempts:I,maxAttempts:T.maxAttempts||`unlimited`,delayMs:K},`web reconnect: scheduling retry`),i.error(`WhatsApp Web connection closed (status ${U}). Retry ${I}/${T.maxAttempts||`∞`} in ${Ce(K)}… (${G})`),await V();try{await ne(K,a)}catch{break}}m.running=!1,m.connected=!1,m.lastEventAt=Date.now(),h(),process.removeListener(`SIGINT`,F)}export{te as WA_WEB_AUTH_DIR,Ue as createWaSocket,ee as logWebSelfId,We as loginWeb,pn as monitorWebChannel,Mt as monitorWebInbox,T as pickWebChannel,Be as sendMessageWhatsApp,Ve as waitForWaConnection,y as webAuthExists};
|
|
@@ -2,4 +2,4 @@ require(`./paths-BvlJvmRS.cjs`);const e=require(`./paths-Chp3zwtq.cjs`),t=requir
|
|
|
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(`
|
|
5
|
-
`);n&&(C.warn(`Media skipped; sent text-only to ${r.from}`),await r.reply(n))}}}for(let e of y)await r.reply(e)}function ke(e){if(!e.msg.id)return;let n=e.cfg.channels?.whatsapp?.ackReaction,r=(n?.emoji??``).trim(),a=n?.direct??!0,o=n?.group??`mentions`,s=e.msg.conversationId??e.msg.from,c=e.msg.chatType===`group`?he({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:s}):null;i.b({emoji:r,isDirect:e.msg.chatType===`direct`,isGroup:e.msg.chatType===`group`,directEnabled:a,groupMode:o,wasMentioned:e.msg.wasMentioned===!0,groupActivated:c===`always`})&&(e.info({chatId:e.msg.chatId,messageId:e.msg.id,emoji:r},`sending ack reaction`),f.r(e.msg.chatId,e.msg.id,r,{verbose:e.verbose,fromMe:!1,participant:e.msg.senderJid,accountId:e.accountId}).catch(n=>{e.warn({error:p.n(n),chatId:e.msg.chatId,messageId:e.msg.id},`failed to send ack reaction`),t.R(`WhatsApp ack reaction failed for chat ${e.msg.chatId}: ${p.n(n)}`)}))}function Ae(e){return e.replyToBody?`[Replying to ${e.replyToSender??`unknown sender`}${e.replyToId?` id:${e.replyToId}`:``}]\n${e.replyToBody}\n[/Replying]`:null}function je(e){let{cfg:t,msg:n,agentId:r,previousTimestamp:a,envelope:o}=e,s=i.Y(t,r,{configured:t.channels?.whatsapp?.messagePrefix,hasAllowFrom:(t.channels?.whatsapp?.allowFrom?.length??0)>0}),c=s?`${s} `:``,l=Ae(n),u=`${c}${n.body}${l?`\n\n${l}`:``}`;return i.T({channel:`WhatsApp`,from:n.chatType===`group`?n.from:n.from?.replace(/^whatsapp:/,``),timestamp:n.timestamp,body:u,chatType:n.chatType,sender:{name:n.senderName,e164:n.senderE164,id:n.senderJid},previousTimestamp:a,envelope:o,fromMe:n.fromMe})}async function Me(e){let r=e.cfg.commands?.useAccessGroups!==!1;if(!r)return!0;let a=e.msg.chatType===`group`,o=t.h(a?e.msg.senderE164??``:e.msg.senderE164??e.msg.from??``);if(!o)return!1;let s=n.js({cfg:e.cfg,accountId:e.msg.accountId}),c=s.dmPolicy??`pairing`,l=s.groupPolicy??`allowlist`,u=s.allowFrom??[],d=s.groupAllowFrom??(u.length>0?u:void 0),f=a?[]:await i.z({provider:`whatsapp`,accountId:e.msg.accountId,dmPolicy:c});return i.B({isGroup:a,dmPolicy:c,groupPolicy:l,allowFrom:u.length>0?u:e.msg.selfE164?[e.msg.selfE164]:[],groupAllowFrom:d,storeAllowFrom:f,isSenderAllowed:e=>e.includes(`*`)?!0:e.map(e=>t.h(String(e))).filter(e=>!!e).includes(o),command:{useAccessGroups:r,allowTextCommands:!0,hasControlCommand:!0}}).commandAuthorized}function Ne(e){let r=n.js({cfg:e.cfg,accountId:e.msg.accountId});return i.U({dmScope:e.cfg.session?.dmScope,allowFrom:r.allowFrom,normalizeEntry:e=>t.h(e)})}async function Pe(e){let r=e.msg.conversationId??e.msg.from,{storePath:c,envelopeOptions:l,previousTimestamp:u}=i.l({cfg:e.cfg,agentId:e.route.agentId,sessionKey:e.route.sessionKey}),d=je({cfg:e.cfg,msg:e.msg,agentId:e.route.agentId,previousTimestamp:u,envelope:l}),f=!1;if(e.msg.chatType===`group`){let t=e.groupHistory??e.groupHistories.get(e.groupHistoryKey)??[];t.length>0&&(d=i.it({entries:t.map(e=>({sender:e.sender,body:e.body,timestamp:e.timestamp})),currentMessage:d,excludeLast:!1,formatEntry:e=>i.T({channel:`WhatsApp`,from:r,timestamp:e.timestamp,body:e.body,chatType:`group`,senderLabel:e.sender,envelope:l})})),f=!(e.suppressGroupHistoryClear??!1)}let m=e.buildCombinedEchoKey({sessionKey:e.route.sessionKey,combinedBody:d});if(e.echoHas(m))return t.R(`Skipping auto-reply: detected echo for combined message`),e.echoForget(m),!1;ke({cfg:e.cfg,msg:e.msg,agentId:e.route.agentId,sessionKey:e.route.sessionKey,conversationId:r,verbose:e.verbose,accountId:e.route.accountId,info:e.replyLogger.info.bind(e.replyLogger),warn:e.replyLogger.warn.bind(e.replyLogger)});let h=e.msg.id??b();e.replyLogger.info({connectionId:e.connectionId,correlationId:h,from:e.msg.chatType===`group`?r:e.msg.from,to:e.msg.to,body:$(d,240),mediaType:e.msg.mediaType??null,mediaPath:e.msg.mediaPath??null},`inbound web message`);let g=e.msg.chatType===`group`?r:e.msg.from,_=e.msg.mediaType?`, ${e.msg.mediaType}`:``;S.info(`Inbound message ${g} -> ${e.msg.to} (${e.msg.chatType}${_}, ${d.length} chars)`),t.B()&&S.debug(`Inbound body: ${$(d,400)}`);let v=e.msg.chatType===`group`?void 0:e.msg.senderE164?t.h(e.msg.senderE164):e.msg.from.includes(`@`)?t.m(e.msg.from):t.h(e.msg.from),y=e.maxMediaTextChunkLimit??s.f(e.cfg,`whatsapp`),x=s.d(e.cfg,`whatsapp`,e.route.accountId),ee=s.i({cfg:e.cfg,channel:`whatsapp`,accountId:e.route.accountId}),w=o.t(e.cfg,e.route.agentId),T=!1,E=!1,D=i.D(e.msg.body,e.cfg)?await Me({cfg:e.cfg,msg:e.msg}):void 0,O=e.cfg.messages?.responsePrefix,{onModelSelected:k,...A}=i.q({cfg:e.cfg,agentId:e.route.agentId,channel:`whatsapp`,accountId:e.route.accountId}),j=e.msg.chatType!==`group`&&!!e.msg.selfE164&&t.h(e.msg.from)===t.h(e.msg.selfE164??``),M=A.responsePrefix??(O===void 0&&j?i.J(e.cfg,e.route.agentId):void 0),N=e.msg.chatType===`group`?(e.groupHistory??e.groupHistories.get(e.groupHistoryKey)??[]).map(e=>({sender:e.sender,body:e.body,timestamp:e.timestamp})):void 0,P=i.L({Body:d,BodyForAgent:e.msg.body,InboundHistory:N,RawBody:e.msg.body,CommandBody:e.msg.body,From:e.msg.from,To:e.msg.to,SessionKey:e.route.sessionKey,AccountId:e.route.accountId,MessageSid:e.msg.id,ReplyToId:e.msg.replyToId,ReplyToBody:e.msg.replyToBody,ReplyToSender:e.msg.replyToSender,MediaPath:e.msg.mediaPath,MediaUrl:e.msg.mediaUrl,MediaType:e.msg.mediaType,ChatType:e.msg.chatType,ConversationLabel:e.msg.chatType===`group`?r:e.msg.from,GroupSubject:e.msg.groupSubject,GroupMembers:ve({participants:e.msg.groupParticipants,roster:e.groupMemberNames.get(e.groupHistoryKey),fallbackE164:e.msg.senderE164}),SenderName:e.msg.senderName,SenderId:e.msg.senderJid?.trim()||e.msg.senderE164,SenderE164:e.msg.senderE164,CommandAuthorized:D,WasMentioned:e.msg.wasMentioned,...e.msg.location?a.Y(e.msg.location):{},Provider:`whatsapp`,Surface:`whatsapp`,OriginatingChannel:`whatsapp`,OriginatingTo:e.msg.from}),F=Ne({cfg:e.cfg,msg:e.msg}),I=!F||F===v,L=i._({route:e.route,sessionKey:e.route.sessionKey});v&&L===e.route.mainSessionKey&&I?we({cfg:e.cfg,backgroundTasks:e.backgroundTasks,storeAgentId:e.route.agentId,sessionKey:e.route.mainSessionKey,channel:`whatsapp`,to:v,accountId:e.route.accountId,ctx:P,warn:e.replyLogger.warn.bind(e.replyLogger)}):v&&L===e.route.mainSessionKey&&F&&t.R(`Skipping main-session last route update for ${v} (pinned owner ${F})`);let R=n.jt({storePath:c,sessionKey:e.route.sessionKey,ctx:P}).catch(t=>{e.replyLogger.warn({error:p.n(t),storePath:c,sessionKey:e.route.sessionKey},`failed updating session meta`)});Ce(e.backgroundTasks,R);let{queuedFinal:z}=await i.x({ctx:P,cfg:e.cfg,replyResolver:e.replyResolver,dispatcherOptions:{...A,responsePrefix:M,onHeartbeatStrip:()=>{T||(T=!0,t.R(`Stripped stray HEARTBEAT_OK token from web reply`))},deliver:async(n,i)=>{if(i.kind!==`final`)return;await Oe({replyResult:n,msg:e.msg,mediaLocalRoots:w,maxMediaBytes:e.maxMediaBytes,textLimit:y,chunkMode:x,replyLogger:e.replyLogger,connectionId:e.connectionId,skipLog:!1,tableMode:ee}),E=!0;let a=n.text?!0:void 0;e.rememberSentText(n.text,{combinedBody:d,combinedBodySessionKey:e.route.sessionKey,logVerboseMessage:a});let o=e.msg.chatType===`group`?r:e.msg.from??`unknown`,s=!!(n.mediaUrl||n.mediaUrls?.length);if(C.info(`Auto-replied to ${o}${s?` (media)`:``}`),t.B()){let e=n.text==null?`<media>`:$(n.text,400);C.debug(`Reply body: ${e}${s?` (media)`:``}`)}},onError:(t,n)=>{let i=n.kind===`tool`?`tool update`:n.kind===`block`?`block update`:`auto-reply`;C.error(`Failed sending web ${i} to ${e.msg.from??r}: ${p.n(t)}`)},onReplyStart:e.msg.sendComposing},replyOptions:{disableBlockStreaming:!0,onModelSelected:k}});return z?(f&&e.groupHistories.set(e.groupHistoryKey,[]),E):(f&&e.groupHistories.set(e.groupHistoryKey,[]),t.R(`Skipping auto-reply: silent token or no text/media returned from resolver`),!1)}function Fe(r){let a=async(e,t,n,i)=>Pe({cfg:r.cfg,msg:e,route:t,groupHistoryKey:n,groupHistories:r.groupHistories,groupMemberNames:r.groupMemberNames,connectionId:r.connectionId,verbose:r.verbose,maxMediaBytes:r.maxMediaBytes,replyResolver:r.replyResolver,replyLogger:r.replyLogger,backgroundTasks:r.backgroundTasks,rememberSentText:r.echoTracker.rememberText,echoHas:r.echoTracker.has,echoForget:r.echoTracker.forget,buildCombinedEchoKey:r.echoTracker.buildCombinedKey,groupHistory:i?.groupHistory,suppressGroupHistoryClear:i?.suppressGroupHistoryClear});return async o=>{let s=o.conversationId??o.from,c=Te(o),l=i.g({cfg:n.Si(),channel:`whatsapp`,accountId:o.accountId,peer:{kind:o.chatType===`group`?`group`:`direct`,id:c}}),u=o.chatType===`group`?e.Et({channel:`whatsapp`,accountId:l.accountId,peerKind:`group`,peerId:c}):l.sessionKey;if(o.from===o.to&&t.R(`📱 Same-phone mode detected (from === to: ${o.from})`),r.echoTracker.has(o.body)){t.R(`Skipping auto-reply: detected echo (message matches recently sent text)`),r.echoTracker.forget(o.body);return}if(o.chatType===`group`){let e={From:o.from,To:o.to,SessionKey:l.sessionKey,AccountId:l.accountId,ChatType:o.chatType,ConversationLabel:s,GroupSubject:o.groupSubject,SenderName:o.senderName,SenderId:o.senderJid?.trim()||o.senderE164,SenderE164:o.senderE164,Provider:`whatsapp`,Surface:`whatsapp`,OriginatingChannel:`whatsapp`,OriginatingTo:s};if(we({cfg:r.cfg,backgroundTasks:r.backgroundTasks,storeAgentId:l.agentId,sessionKey:l.sessionKey,channel:`whatsapp`,to:s,accountId:l.accountId,ctx:e,warn:r.replyLogger.warn.bind(r.replyLogger)}),!Se({cfg:r.cfg,msg:o,conversationId:s,groupHistoryKey:u,agentId:l.agentId,sessionKey:l.sessionKey,baseMentionConfig:r.baseMentionConfig,authDir:r.account.authDir,groupHistories:r.groupHistories,groupHistoryLimit:r.groupHistoryLimit,groupMemberNames:r.groupMemberNames,logVerbose:t.R,replyLogger:r.replyLogger}).shouldProcess)return}else !o.senderE164&&c&&c.startsWith(`+`)&&(o.senderE164=t.h(c)??o.senderE164);await de({cfg:r.cfg,msg:o,peerId:c,route:l,groupHistoryKey:u,groupHistories:r.groupHistories,processMessage:a})||await a(o,l,u)}}function Ie(e){return e===440}async function Le(e,r=oe,a=!0,o=i.r,s=t.M,l,u={}){let f=b(),m=t.K({module:`web-auto-reply`,runId:f}),h=t.K({module:`web-heartbeat`,runId:f}),g=t.K({module:`web-reconnect`,runId:f}),_={running:!0,connected:!1,reconnectAttempts:0,lastConnectedAt:null,lastDisconnect:null,lastMessageAt:null,lastEventAt:null,lastError:null},S=()=>{u.statusSink?.({..._,lastDisconnect:_.lastDisconnect?{..._.lastDisconnect}:null})};S();let C=n.Si(),T=n.js({cfg:C,accountId:u.accountId}),E={...C,channels:{...C.channels,whatsapp:{...C.channels?.whatsapp,ackReaction:T.ackReaction,messagePrefix:T.messagePrefix,allowFrom:T.allowFrom,groupAllowFrom:T.groupAllowFrom,groupPolicy:T.groupPolicy,textChunkLimit:T.textChunkLimit,chunkMode:T.chunkMode,mediaMaxMb:T.mediaMaxMb,blockStreaming:T.blockStreaming,groups:T.groups}}},D=n.Ms(T),O=v(E,u.heartbeatSeconds),k=y(E,u.reconnect),A=X(E),j=E.channels?.whatsapp?.accounts?.[u.accountId??``]?.historyLimit??E.channels?.whatsapp?.historyLimit??E.messages?.groupChat?.historyLimit??50,M=new Map,N=new Map,P=le({maxItems:100,logVerbose:t.R}),F=u.sleep??((e,t)=>i.f(e,t??l)),I=()=>l?.aborted===!0,L=l&&new Promise(e=>l.addEventListener(`abort`,()=>e(`aborted`),{once:!0})),R=process.getMaxListeners?.()??10;process.setMaxListeners&&R<50&&process.setMaxListeners(50);let z=!1,B=()=>{z=!0};process.once(`SIGINT`,B);let V=0;for(;!I();){let f=b(),v=Date.now(),y=null,C=null,R=null,H=0,U=null,te=u.messageTimeoutMs??1800*1e3,ne=u.watchdogCheckMs??60*1e3,W=new Set,re=Fe({cfg:E,verbose:e,connectionId:f,maxMediaBytes:D,groupHistoryLimit:j,groupHistories:M,groupMemberNames:N,echoTracker:P,backgroundTasks:W,replyResolver:o??i.r,replyLogger:m,baseMentionConfig:A,account:T}),ie=i.w({cfg:E,channel:`whatsapp`}),G=await(r??oe)({verbose:e,accountId:T.accountId,authDir:T.authDir,mediaMaxMb:T.mediaMaxMb,sendReadReceipts:T.sendReadReceipts,debounceMs:ie,shouldDebounce:e=>e.mediaPath||e.mediaType||e.location||e.replyToId||e.replyToBody?!1:!i.E(e.body,E),onMessage:async e=>{H+=1,R=Date.now(),_.lastMessageAt=R,_.lastEventAt=R,S(),await re(e)}});Object.assign(_,i.u()),_.lastError=null,S();let{e164:K}=n.Bs(T.authDir),ae=i.g({cfg:E,channel:`whatsapp`,accountId:T.accountId});i.v(`WhatsApp gateway connected${K?` as ${K}`:``}.`,{sessionKey:ae.sessionKey}),d.r(T.accountId,G),U=c.f(e=>{if(!Ee(e))return!1;let t=p.n(e);return g.warn({connectionId:f,error:t},`web reconnect: unhandled rejection from WhatsApp socket; forcing reconnect`),G.signalClose?.({status:499,isLoggedOut:!1,error:e}),!0});let q=async()=>{d.r(T.accountId,null),U&&=(U(),null),y&&clearInterval(y),C&&clearInterval(C),W.size>0&&(await Promise.allSettled(W),W.clear());try{await G.close()}catch(e){t.R(`Socket close failed: ${p.n(e)}`)}};if(a&&(y=setInterval(()=>{let e=n.Ps(T.authDir),t=R?Math.floor((Date.now()-R)/6e4):null,r={connectionId:f,reconnectAttempts:V,messagesHandled:H,lastMessageAt:R,authAgeMs:e,uptimeMs:Date.now()-v,...t!==null&&t>30?{minutesSinceLastMessage:t}:{}};t&&t>30?h.warn(r,`⚠️ web gateway heartbeat - no messages in 30+ minutes`):h.info(r,`web gateway heartbeat`)},O*1e3),C=setInterval(()=>{if(!R)return;let e=Date.now()-R;if(e<=te)return;let n=Math.floor(e/6e4);h.warn({connectionId:f,minutesSinceLastMessage:n,lastMessageAt:new Date(R),messagesHandled:H},`Message timeout detected - forcing reconnect`),ee.warn(`No messages received in ${n}m - restarting connection`),q().catch(e=>{t.R(`Close listener failed: ${p.n(e)}`)}),G.signalClose?.({status:499,isLoggedOut:!1,error:`watchdog-timeout`})},ne)),x.info(`Listening for personal WhatsApp inbound messages.`),(process.stdout.isTTY||process.stderr.isTTY)&&x.raw(`Ctrl+C to stop.`),!a){await q(),process.removeListener(`SIGINT`,B);return}let J=await Promise.race([G.onClose?.catch(e=>(g.error({error:p.n(e)},`listener.onClose rejected`),{status:500,isLoggedOut:!1,error:e}))??w(),L??w()]);if(Date.now()-v>O*1e3&&(V=0),_.reconnectAttempts=V,S(),I()||z||J===`aborted`){await q();break}let Y=(typeof J==`object`&&J&&`status`in J?J.status:void 0)??`unknown`,X=typeof J==`object`&&J&&`isLoggedOut`in J&&J.isLoggedOut,Z=p.n(J);if(_.connected=!1,_.lastEventAt=Date.now(),_.lastDisconnect={at:_.lastEventAt,status:typeof Y==`number`?Y:void 0,error:Z,loggedOut:!!X},_.lastError=Z,_.reconnectAttempts=V,S(),g.info({connectionId:f,status:Y,loggedOut:X,reconnectAttempts:V,error:Z},`web reconnect: connection closed`),i.v(`WhatsApp gateway disconnected (status ${Y??`unknown`})`,{sessionKey:ae.sessionKey}),X){s.error(`WhatsApp session logged out. Run \`${n.Js(`openclaw channels login --channel web`)}\` to relink.`),await q();break}if(Ie(Y)){g.warn({connectionId:f,status:Y,error:Z},`web reconnect: non-retryable close status; stopping monitor`),s.error(`WhatsApp Web connection closed (status ${Y}: session conflict). Resolve conflicting WhatsApp Web sessions, then relink with \`${n.Js(`openclaw channels login --channel web`)}\`. Stopping web monitoring.`),await q();break}if(V+=1,_.reconnectAttempts=V,S(),k.maxAttempts>0&&V>=k.maxAttempts){g.warn({connectionId:f,status:Y,reconnectAttempts:V,maxAttempts:k.maxAttempts},`web reconnect: max attempts reached; continuing in degraded mode`),s.error(`WhatsApp Web reconnect: max attempts reached (${V}/${k.maxAttempts}). Stopping web monitoring.`),await q();break}let Q=i.d(k,V);g.info({connectionId:f,status:Y,reconnectAttempts:V,maxAttempts:k.maxAttempts||`unlimited`,delayMs:Q},`web reconnect: scheduling retry`),s.error(`WhatsApp Web connection closed (status ${Y}). Retry ${V}/${k.maxAttempts||`∞`} in ${i.y(Q)}… (${Z})`),await q();try{await F(Q,l)}catch{break}}_.running=!1,_.connected=!1,_.lastEventAt=Date.now(),S(),process.removeListener(`SIGINT`,B)}exports.WA_WEB_AUTH_DIR=n.Ns,exports.createWaSocket=p.t,exports.logWebSelfId=n.Fs,exports.loginWeb=m.t,exports.monitorWebChannel=Le,exports.monitorWebInbox=oe,exports.pickWebChannel=n.Rs,exports.sendMessageWhatsApp=f.t,exports.waitForWaConnection=p.i,exports.webAuthExists=n.Ws;
|
|
5
|
+
`);n&&(C.warn(`Media skipped; sent text-only to ${r.from}`),await r.reply(n))}}}for(let e of y)await r.reply(e)}function ke(e){if(!e.msg.id)return;let n=e.cfg.channels?.whatsapp?.ackReaction,r=(n?.emoji??``).trim(),a=n?.direct??!0,o=n?.group??`mentions`,s=e.msg.conversationId??e.msg.from,c=e.msg.chatType===`group`?he({cfg:e.cfg,agentId:e.agentId,sessionKey:e.sessionKey,conversationId:s}):null;i.b({emoji:r,isDirect:e.msg.chatType===`direct`,isGroup:e.msg.chatType===`group`,directEnabled:a,groupMode:o,wasMentioned:e.msg.wasMentioned===!0,groupActivated:c===`always`})&&(e.info({chatId:e.msg.chatId,messageId:e.msg.id,emoji:r},`sending ack reaction`),f.r(e.msg.chatId,e.msg.id,r,{verbose:e.verbose,fromMe:!1,participant:e.msg.senderJid,accountId:e.accountId}).catch(n=>{e.warn({error:p.n(n),chatId:e.msg.chatId,messageId:e.msg.id},`failed to send ack reaction`),t.R(`WhatsApp ack reaction failed for chat ${e.msg.chatId}: ${p.n(n)}`)}))}function Ae(e){return e.replyToBody?`[Replying to ${e.replyToSender??`unknown sender`}${e.replyToId?` id:${e.replyToId}`:``}]\n${e.replyToBody}\n[/Replying]`:null}function je(e){let{cfg:t,msg:n,agentId:r,previousTimestamp:a,envelope:o}=e,s=i.Y(t,r,{configured:t.channels?.whatsapp?.messagePrefix,hasAllowFrom:(t.channels?.whatsapp?.allowFrom?.length??0)>0}),c=s?`${s} `:``,l=Ae(n),u=`${c}${n.body}${l?`\n\n${l}`:``}`;return i.T({channel:`WhatsApp`,from:n.chatType===`group`?n.from:n.from?.replace(/^whatsapp:/,``),timestamp:n.timestamp,body:u,chatType:n.chatType,sender:{name:n.senderName,e164:n.senderE164,id:n.senderJid},previousTimestamp:a,envelope:o,fromMe:n.fromMe})}async function Me(e){let r=e.cfg.commands?.useAccessGroups!==!1;if(!r)return!0;let a=e.msg.chatType===`group`,o=t.h(a?e.msg.senderE164??``:e.msg.senderE164??e.msg.from??``);if(!o)return!1;let s=n.js({cfg:e.cfg,accountId:e.msg.accountId}),c=s.dmPolicy??`pairing`,l=s.groupPolicy??`allowlist`,u=s.allowFrom??[],d=s.groupAllowFrom??(u.length>0?u:void 0),f=a?[]:await i.z({provider:`whatsapp`,accountId:e.msg.accountId,dmPolicy:c});return i.B({isGroup:a,dmPolicy:c,groupPolicy:l,allowFrom:u.length>0?u:e.msg.selfE164?[e.msg.selfE164]:[],groupAllowFrom:d,storeAllowFrom:f,isSenderAllowed:e=>e.includes(`*`)?!0:e.map(e=>t.h(String(e))).filter(e=>!!e).includes(o),command:{useAccessGroups:r,allowTextCommands:!0,hasControlCommand:!0}}).commandAuthorized}function Ne(e){let r=n.js({cfg:e.cfg,accountId:e.msg.accountId});return i.U({dmScope:e.cfg.session?.dmScope,allowFrom:r.allowFrom,normalizeEntry:e=>t.h(e)})}async function Pe(e){let r=e.msg.conversationId??e.msg.from,{storePath:c,envelopeOptions:l,previousTimestamp:u}=i.l({cfg:e.cfg,agentId:e.route.agentId,sessionKey:e.route.sessionKey}),d=je({cfg:e.cfg,msg:e.msg,agentId:e.route.agentId,previousTimestamp:u,envelope:l}),f=!1;if(e.msg.chatType===`group`){let t=e.groupHistory??e.groupHistories.get(e.groupHistoryKey)??[];t.length>0&&(d=i.it({entries:t.map(e=>({sender:e.sender,body:e.body,timestamp:e.timestamp})),currentMessage:d,excludeLast:!1,formatEntry:e=>i.T({channel:`WhatsApp`,from:r,timestamp:e.timestamp,body:e.body,chatType:`group`,senderLabel:e.sender,envelope:l})})),f=!(e.suppressGroupHistoryClear??!1)}let m=e.buildCombinedEchoKey({sessionKey:e.route.sessionKey,combinedBody:d});if(e.echoHas(m))return t.R(`Skipping auto-reply: detected echo for combined message`),e.echoForget(m),!1;ke({cfg:e.cfg,msg:e.msg,agentId:e.route.agentId,sessionKey:e.route.sessionKey,conversationId:r,verbose:e.verbose,accountId:e.route.accountId,info:e.replyLogger.info.bind(e.replyLogger),warn:e.replyLogger.warn.bind(e.replyLogger)});let h=e.msg.id??b();e.replyLogger.info({connectionId:e.connectionId,correlationId:h,from:e.msg.chatType===`group`?r:e.msg.from,to:e.msg.to,body:$(d,240),mediaType:e.msg.mediaType??null,mediaPath:e.msg.mediaPath??null},`inbound web message`);let g=e.msg.chatType===`group`?r:e.msg.from,_=e.msg.mediaType?`, ${e.msg.mediaType}`:``;S.info(`Inbound message ${g} -> ${e.msg.to} (${e.msg.chatType}${_}, ${d.length} chars)`),t.B()&&S.debug(`Inbound body: ${$(d,400)}`);let v=e.msg.chatType===`group`?void 0:e.msg.senderE164?t.h(e.msg.senderE164):e.msg.from.includes(`@`)?t.m(e.msg.from):t.h(e.msg.from),y=e.maxMediaTextChunkLimit??s.f(e.cfg,`whatsapp`),x=s.d(e.cfg,`whatsapp`,e.route.accountId),ee=s.i({cfg:e.cfg,channel:`whatsapp`,accountId:e.route.accountId}),w=o.t(e.cfg,e.route.agentId),T=!1,E=!1,D=i.D(e.msg.body,e.cfg)?await Me({cfg:e.cfg,msg:e.msg}):void 0,O=e.cfg.messages?.responsePrefix,{onModelSelected:k,...A}=i.q({cfg:e.cfg,agentId:e.route.agentId,channel:`whatsapp`,accountId:e.route.accountId}),j=e.msg.chatType!==`group`&&!!e.msg.selfE164&&t.h(e.msg.from)===t.h(e.msg.selfE164??``),M=A.responsePrefix??(O===void 0&&j?i.J(e.cfg,e.route.agentId):void 0),N=e.msg.chatType===`group`?(e.groupHistory??e.groupHistories.get(e.groupHistoryKey)??[]).map(e=>({sender:e.sender,body:e.body,timestamp:e.timestamp})):void 0,P=i.L({Body:d,BodyForAgent:e.msg.body,InboundHistory:N,RawBody:e.msg.body,CommandBody:e.msg.body,From:e.msg.from,To:e.msg.to,SessionKey:e.route.sessionKey,AccountId:e.route.accountId,MessageSid:e.msg.id,ReplyToId:e.msg.replyToId,ReplyToBody:e.msg.replyToBody,ReplyToSender:e.msg.replyToSender,MediaPath:e.msg.mediaPath,MediaUrl:e.msg.mediaUrl,MediaType:e.msg.mediaType,ChatType:e.msg.chatType,ConversationLabel:e.msg.chatType===`group`?r:e.msg.from,GroupSubject:e.msg.groupSubject,GroupMembers:ve({participants:e.msg.groupParticipants,roster:e.groupMemberNames.get(e.groupHistoryKey),fallbackE164:e.msg.senderE164}),SenderName:e.msg.senderName,SenderId:e.msg.senderJid?.trim()||e.msg.senderE164,SenderE164:e.msg.senderE164,CommandAuthorized:D,WasMentioned:e.msg.wasMentioned,...e.msg.location?a.Y(e.msg.location):{},Provider:`whatsapp`,Surface:`whatsapp`,OriginatingChannel:`whatsapp`,OriginatingTo:e.msg.from}),F=Ne({cfg:e.cfg,msg:e.msg}),I=!F||F===v,L=i._({route:e.route,sessionKey:e.route.sessionKey});v&&L===e.route.mainSessionKey&&I?we({cfg:e.cfg,backgroundTasks:e.backgroundTasks,storeAgentId:e.route.agentId,sessionKey:e.route.mainSessionKey,channel:`whatsapp`,to:v,accountId:e.route.accountId,ctx:P,warn:e.replyLogger.warn.bind(e.replyLogger)}):v&&L===e.route.mainSessionKey&&F&&t.R(`Skipping main-session last route update for ${v} (pinned owner ${F})`);let R=n.jt({storePath:c,sessionKey:e.route.sessionKey,ctx:P}).catch(t=>{e.replyLogger.warn({error:p.n(t),storePath:c,sessionKey:e.route.sessionKey},`failed updating session meta`)});Ce(e.backgroundTasks,R);let{queuedFinal:z}=await i.x({ctx:P,cfg:e.cfg,replyResolver:e.replyResolver,dispatcherOptions:{...A,responsePrefix:M,onHeartbeatStrip:()=>{T||(T=!0,t.R(`Stripped stray HEARTBEAT_OK token from web reply`))},deliver:async(n,i)=>{if(i.kind!==`final`)return;await Oe({replyResult:n,msg:e.msg,mediaLocalRoots:w,maxMediaBytes:e.maxMediaBytes,textLimit:y,chunkMode:x,replyLogger:e.replyLogger,connectionId:e.connectionId,skipLog:!1,tableMode:ee}),E=!0;let a=n.text?!0:void 0;e.rememberSentText(n.text,{combinedBody:d,combinedBodySessionKey:e.route.sessionKey,logVerboseMessage:a});let o=e.msg.chatType===`group`?r:e.msg.from??`unknown`,s=!!(n.mediaUrl||n.mediaUrls?.length);if(C.info(`Auto-replied to ${o}${s?` (media)`:``}`),t.B()){let e=n.text==null?`<media>`:$(n.text,400);C.debug(`Reply body: ${e}${s?` (media)`:``}`)}},onError:(t,n)=>{let i=n.kind===`tool`?`tool update`:n.kind===`block`?`block update`:`auto-reply`;C.error(`Failed sending web ${i} to ${e.msg.from??r}: ${p.n(t)}`)},onReplyStart:e.msg.sendComposing},replyOptions:{disableBlockStreaming:!0,onModelSelected:k}});return z?(f&&e.groupHistories.set(e.groupHistoryKey,[]),E):(f&&e.groupHistories.set(e.groupHistoryKey,[]),t.R(`Skipping auto-reply: silent token or no text/media returned from resolver`),!1)}function Fe(r){let a=async(e,t,n,i)=>Pe({cfg:r.cfg,msg:e,route:t,groupHistoryKey:n,groupHistories:r.groupHistories,groupMemberNames:r.groupMemberNames,connectionId:r.connectionId,verbose:r.verbose,maxMediaBytes:r.maxMediaBytes,replyResolver:r.replyResolver,replyLogger:r.replyLogger,backgroundTasks:r.backgroundTasks,rememberSentText:r.echoTracker.rememberText,echoHas:r.echoTracker.has,echoForget:r.echoTracker.forget,buildCombinedEchoKey:r.echoTracker.buildCombinedKey,groupHistory:i?.groupHistory,suppressGroupHistoryClear:i?.suppressGroupHistoryClear});return async o=>{let s=o.conversationId??o.from,c=Te(o),l=i.g({cfg:n.Si(),channel:`whatsapp`,accountId:o.accountId,peer:{kind:o.chatType===`group`?`group`:`direct`,id:c}}),u=o.chatType===`group`?e.Et({channel:`whatsapp`,accountId:l.accountId,peerKind:`group`,peerId:c}):l.sessionKey;if(o.from===o.to&&t.R(`📱 Same-phone mode detected (from === to: ${o.from})`),r.echoTracker.has(o.body)){t.R(`Skipping auto-reply: detected echo (message matches recently sent text)`),r.echoTracker.forget(o.body);return}if(o.chatType===`group`){let e={From:o.from,To:o.to,SessionKey:l.sessionKey,AccountId:l.accountId,ChatType:o.chatType,ConversationLabel:s,GroupSubject:o.groupSubject,SenderName:o.senderName,SenderId:o.senderJid?.trim()||o.senderE164,SenderE164:o.senderE164,Provider:`whatsapp`,Surface:`whatsapp`,OriginatingChannel:`whatsapp`,OriginatingTo:s};if(we({cfg:r.cfg,backgroundTasks:r.backgroundTasks,storeAgentId:l.agentId,sessionKey:l.sessionKey,channel:`whatsapp`,to:s,accountId:l.accountId,ctx:e,warn:r.replyLogger.warn.bind(r.replyLogger)}),!Se({cfg:r.cfg,msg:o,conversationId:s,groupHistoryKey:u,agentId:l.agentId,sessionKey:l.sessionKey,baseMentionConfig:r.baseMentionConfig,authDir:r.account.authDir,groupHistories:r.groupHistories,groupHistoryLimit:r.groupHistoryLimit,groupMemberNames:r.groupMemberNames,logVerbose:t.R,replyLogger:r.replyLogger}).shouldProcess)return}else !o.senderE164&&c&&c.startsWith(`+`)&&(o.senderE164=t.h(c)??o.senderE164);await de({cfg:r.cfg,msg:o,peerId:c,route:l,groupHistoryKey:u,groupHistories:r.groupHistories,processMessage:a})||await a(o,l,u)}}function Ie(e){return e===440}async function Le(e,r=oe,a=!0,o=i.r,s=t.M,l,u={}){let f=b(),m=t.K({module:`web-auto-reply`,runId:f}),h=t.K({module:`web-heartbeat`,runId:f}),g=t.K({module:`web-reconnect`,runId:f}),_={running:!0,connected:!1,reconnectAttempts:0,lastConnectedAt:null,lastDisconnect:null,lastMessageAt:null,lastEventAt:null,lastError:null},S=()=>{u.statusSink?.({..._,lastDisconnect:_.lastDisconnect?{..._.lastDisconnect}:null})};S();let C=n.Si(),T=n.js({cfg:C,accountId:u.accountId}),E={...C,channels:{...C.channels,whatsapp:{...C.channels?.whatsapp,ackReaction:T.ackReaction,messagePrefix:T.messagePrefix,allowFrom:T.allowFrom,groupAllowFrom:T.groupAllowFrom,groupPolicy:T.groupPolicy,textChunkLimit:T.textChunkLimit,chunkMode:T.chunkMode,mediaMaxMb:T.mediaMaxMb,blockStreaming:T.blockStreaming,groups:T.groups}}},D=n.Ms(T),O=v(E,u.heartbeatSeconds),k=y(E,u.reconnect),A=X(E),j=E.channels?.whatsapp?.accounts?.[u.accountId??``]?.historyLimit??E.channels?.whatsapp?.historyLimit??E.messages?.groupChat?.historyLimit??50,M=new Map,N=new Map,P=le({maxItems:100,logVerbose:t.R}),F=u.sleep??((e,t)=>i.f(e,t??l)),I=()=>l?.aborted===!0,L=l&&new Promise(e=>l.addEventListener(`abort`,()=>e(`aborted`),{once:!0})),R=process.getMaxListeners?.()??10;process.setMaxListeners&&R<50&&process.setMaxListeners(50);let z=!1,B=()=>{z=!0};process.once(`SIGINT`,B);let V=0;for(;!I();){let f=b(),v=Date.now(),y=null,C=null,R=null,H=0,U=null,te=u.messageTimeoutMs??1800*1e3,ne=u.watchdogCheckMs??60*1e3,W=new Set,re=Fe({cfg:E,verbose:e,connectionId:f,maxMediaBytes:D,groupHistoryLimit:j,groupHistories:M,groupMemberNames:N,echoTracker:P,backgroundTasks:W,replyResolver:o??i.r,replyLogger:m,baseMentionConfig:A,account:T}),ie=i.w({cfg:E,channel:`whatsapp`}),G=await(r??oe)({verbose:e,accountId:T.accountId,authDir:T.authDir,mediaMaxMb:T.mediaMaxMb,sendReadReceipts:T.sendReadReceipts,debounceMs:ie,shouldDebounce:e=>e.mediaPath||e.mediaType||e.location||e.replyToId||e.replyToBody?!1:!i.E(e.body,E),onMessage:async e=>{H+=1,R=Date.now(),_.lastMessageAt=R,_.lastEventAt=R,S(),await re(e)}});Object.assign(_,i.u()),_.lastError=null,S();let{e164:K}=n.Bs(T.authDir),ae=i.g({cfg:E,channel:`whatsapp`,accountId:T.accountId});i.v(`WhatsApp gateway connected${K?` as ${K}`:``}.`,{sessionKey:ae.sessionKey}),d.r(T.accountId,G),U=c.f(e=>{if(!Ee(e))return!1;let t=p.n(e);return g.warn({connectionId:f,error:t},`web reconnect: unhandled rejection from WhatsApp socket; forcing reconnect`),G.signalClose?.({status:499,isLoggedOut:!1,error:e}),!0});let q=async()=>{d.r(T.accountId,null),U&&=(U(),null),y&&clearInterval(y),C&&clearInterval(C),W.size>0&&(await Promise.allSettled(W),W.clear());try{await G.close()}catch(e){t.R(`Socket close failed: ${p.n(e)}`)}};if(a&&(y=setInterval(()=>{let e=n.Ps(T.authDir),t=R?Math.floor((Date.now()-R)/6e4):null,r={connectionId:f,reconnectAttempts:V,messagesHandled:H,lastMessageAt:R,authAgeMs:e,uptimeMs:Date.now()-v,...t!==null&&t>30?{minutesSinceLastMessage:t}:{}};t&&t>30?h.warn(r,`⚠️ web gateway heartbeat - no messages in 30+ minutes`):h.info(r,`web gateway heartbeat`)},O*1e3),C=setInterval(()=>{if(!R)return;let e=Date.now()-R;if(e<=te)return;let n=Math.floor(e/6e4);h.warn({connectionId:f,minutesSinceLastMessage:n,lastMessageAt:new Date(R),messagesHandled:H},`Message timeout detected - forcing reconnect`),ee.warn(`No messages received in ${n}m - restarting connection`),q().catch(e=>{t.R(`Close listener failed: ${p.n(e)}`)}),G.signalClose?.({status:499,isLoggedOut:!1,error:`watchdog-timeout`})},ne)),x.info(`Listening for personal WhatsApp inbound messages.`),(process.stdout.isTTY||process.stderr.isTTY)&&x.raw(`Ctrl+C to stop.`),!a){await q(),process.removeListener(`SIGINT`,B);return}let J=await Promise.race([G.onClose?.catch(e=>(g.error({error:p.n(e)},`listener.onClose rejected`),{status:500,isLoggedOut:!1,error:e}))??w(),L??w()]);if(Date.now()-v>O*1e3&&(V=0),_.reconnectAttempts=V,S(),I()||z||J===`aborted`){await q();break}let Y=(typeof J==`object`&&J&&`status`in J?J.status:void 0)??`unknown`,X=typeof J==`object`&&J&&`isLoggedOut`in J&&J.isLoggedOut,Z=p.n(J);if(_.connected=!1,_.lastEventAt=Date.now(),_.lastDisconnect={at:_.lastEventAt,status:typeof Y==`number`?Y:void 0,error:Z,loggedOut:!!X},_.lastError=Z,_.reconnectAttempts=V,S(),g.info({connectionId:f,status:Y,loggedOut:X,reconnectAttempts:V,error:Z},`web reconnect: connection closed`),i.v(`WhatsApp gateway disconnected (status ${Y??`unknown`})`,{sessionKey:ae.sessionKey}),X){s.error(`WhatsApp session logged out. Run \`${n.Js(`openclaw channels login --channel web`)}\` to relink.`),await q();break}if(Ie(Y)){g.warn({connectionId:f,status:Y,error:Z},`web reconnect: non-retryable close status; stopping monitor`),s.error(`WhatsApp Web connection closed (status ${Y}: session conflict). Resolve conflicting WhatsApp Web sessions, then relink with \`${n.Js(`openclaw channels login --channel web`)}\`. Stopping web monitoring.`),await q();break}if(V+=1,_.reconnectAttempts=V,S(),k.maxAttempts>0&&V>=k.maxAttempts){g.warn({connectionId:f,status:Y,reconnectAttempts:V,maxAttempts:k.maxAttempts},`web reconnect: max attempts reached; continuing in degraded mode`),s.error(`WhatsApp Web reconnect: max attempts reached (${V}/${k.maxAttempts}). Stopping web monitoring.`),await q();break}let Q=i.d(k,V);g.info({connectionId:f,status:Y,reconnectAttempts:V,maxAttempts:k.maxAttempts||`unlimited`,delayMs:Q},`web reconnect: scheduling retry`),s.error(`WhatsApp Web connection closed (status ${Y}). Retry ${V}/${k.maxAttempts||`∞`} in ${i.y(Q)}… (${Z})`),await q();try{await F(Q,l)}catch{break}}_.running=!1,_.connected=!1,_.lastEventAt=Date.now(),S(),process.removeListener(`SIGINT`,B)}exports.WA_WEB_AUTH_DIR=n.Ns,exports.createWaSocket=p.t,exports.logWebSelfId=n.Fs,exports.loginWeb=m.t,exports.monitorWebChannel=Le,exports.monitorWebInbox=oe,exports.pickWebChannel=n.Rs,exports.sendMessageWhatsApp=f.t,exports.waitForWaConnection=p.i,exports.webAuthExists=n.Ws;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});var e=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,r=Object.getOwnPropertyNames,i=Object.getPrototypeOf,a=Object.prototype.hasOwnProperty,o=(e,i,o,s)=>{if(i&&typeof i==`object`||typeof i==`function`)for(var c=r(i),l=0,u=c.length,d;l<u;l++)d=c[l],!a.call(e,d)&&d!==o&&t(e,d,{get:(e=>i[e]).bind(null,d),enumerable:!(s=n(i,d))||s.enumerable});return e},s=(n,r,a)=>(a=n==null?{}:e(i(n)),o(r||!n||!n.__esModule?t(a,`default`,{value:n,enumerable:!0}):a,n));let c=require(`zod`),l=require(`node:path`);l=s(l);let u=require(`node:fs`);u=s(u);let d=require(`node:os`);d=s(d);let f=require(`node:fs/promises`);f=s(f);let p=require(`chalk`);p=s(p);let m=require(`tslog`),h=require(`json5`);h=s(h);let g=require(`node:url`);const _=/[;&|`$<>]/,v=/[\r\n]/,ee=/["']/,te=/^[A-Za-z0-9._+-]+$/;function ne(e){return e.startsWith(`.`)||e.startsWith(`~`)||e.includes(`/`)||e.includes(`\\`)?!0:/^[A-Za-z]:[\\/]/.test(e)}function y(e){if(!e)return!1;let t=e.trim();return!t||t.includes(`\0`)||v.test(t)||_.test(t)||ee.test(t)?!1:ne(t)?!0:t.startsWith(`-`)?!1:te.test(t)}const re=/^(?:[^~]|~0|~1)*$/,ie=/^[A-Za-z0-9][A-Za-z0-9._:/-]{0,255}$/;function ae(e){return e===`value`?!0:e.startsWith(`/`)?e.slice(1).split(`/`).every(e=>re.test(e)):!1}function oe(e){if(!ie.test(e))return{ok:!1,reason:`pattern`};for(let t of e.split(`/`))if(t===`.`||t===`..`)return{ok:!1,reason:`traversal-segment`};return{ok:!0}}function se(e){return oe(e).ok}function ce(){return[`Exec secret reference id must match /^[A-Za-z0-9][A-Za-z0-9._:/-]{0,255}$/`,`and must not include "." or ".." path segments`,`(example: "vault/openai/api-key").`].join(` `)}const le=[`openai-completions`,`openai-responses`,`openai-codex-responses`,`anthropic-messages`,`google-generative-ai`,`github-copilot`,`bedrock-converse-stream`,`ollama`],ue=c.z.union([c.z.literal(`allow`),c.z.literal(`deny`)]),de=c.z.union([c.z.literal(`direct`),c.z.literal(`group`),c.z.literal(`channel`),c.z.literal(`dm`)]).optional();function fe(){return c.z.object({default:ue.optional(),rules:c.z.array(c.z.object({action:ue,match:c.z.object({channel:c.z.string().optional(),chatType:de,keyPrefix:c.z.string().optional(),rawKeyPrefix:c.z.string().optional()}).strict().optional()}).strict()).optional()}).strict().optional()}const b=c.z.registry(),x=/^[A-Z][A-Z0-9_]{0,127}$/,S=/^[a-z][a-z0-9_-]{0,63}$/,pe=/^[A-Za-z]:[\\/]/,me=/^\\\\[^\\]+\\[^\\]+/;function he(e){return l.default.isAbsolute(e)||pe.test(e)||me.test(e)}const ge=c.z.object({source:c.z.literal(`env`),provider:c.z.string().regex(S,`Secret reference provider must match /^[a-z][a-z0-9_-]{0,63}$/ (example: "default").`),id:c.z.string().regex(x,`Env secret reference id must match /^[A-Z][A-Z0-9_]{0,127}$/ (example: "OPENAI_API_KEY").`)}).strict(),_e=c.z.object({source:c.z.literal(`file`),provider:c.z.string().regex(S,`Secret reference provider must match /^[a-z][a-z0-9_-]{0,63}$/ (example: "default").`),id:c.z.string().refine(ae,`File secret reference id must be an absolute JSON pointer (example: "/providers/openai/apiKey"), or "value" for singleValue mode.`)}).strict(),ve=c.z.object({source:c.z.literal(`exec`),provider:c.z.string().regex(S,`Secret reference provider must match /^[a-z][a-z0-9_-]{0,63}$/ (example: "default").`),id:c.z.string().refine(se,ce())}).strict(),ye=c.z.discriminatedUnion(`source`,[ge,_e,ve]),C=c.z.union([c.z.string(),ye]),be=c.z.object({source:c.z.literal(`env`),allowlist:c.z.array(c.z.string().regex(x)).max(256).optional()}).strict(),xe=c.z.object({source:c.z.literal(`file`),path:c.z.string().min(1),mode:c.z.union([c.z.literal(`singleValue`),c.z.literal(`json`)]).optional(),timeoutMs:c.z.number().int().positive().max(12e4).optional(),maxBytes:c.z.number().int().positive().max(20*1024*1024).optional()}).strict(),Se=c.z.object({source:c.z.literal(`exec`),command:c.z.string().min(1).refine(e=>y(e),`secrets.providers.*.command is unsafe.`).refine(e=>he(e),`secrets.providers.*.command must be an absolute path.`),args:c.z.array(c.z.string().max(1024)).max(128).optional(),timeoutMs:c.z.number().int().positive().max(12e4).optional(),noOutputTimeoutMs:c.z.number().int().positive().max(12e4).optional(),maxOutputBytes:c.z.number().int().positive().max(20*1024*1024).optional(),jsonOnly:c.z.boolean().optional(),env:c.z.record(c.z.string(),c.z.string()).optional(),passEnv:c.z.array(c.z.string().regex(x)).max(128).optional(),trustedDirs:c.z.array(c.z.string().min(1).refine(e=>he(e),`trustedDirs entries must be absolute paths.`)).max(64).optional(),allowInsecurePath:c.z.boolean().optional(),allowSymlinkCommand:c.z.boolean().optional()}).strict(),Ce=c.z.discriminatedUnion(`source`,[be,xe,Se]);c.z.object({providers:c.z.object({}).catchall(Ce).optional(),defaults:c.z.object({env:c.z.string().regex(S).optional(),file:c.z.string().regex(S).optional(),exec:c.z.string().regex(S).optional()}).strict().optional(),resolution:c.z.object({maxProviderConcurrency:c.z.number().int().positive().max(16).optional(),maxRefsPerProvider:c.z.number().int().positive().max(4096).optional(),maxBatchBytes:c.z.number().int().positive().max(5*1024*1024).optional()}).strict().optional()}).strict().optional();const we=c.z.enum(le),Te=c.z.object({supportsStore:c.z.boolean().optional(),supportsDeveloperRole:c.z.boolean().optional(),supportsReasoningEffort:c.z.boolean().optional(),supportsUsageInStreaming:c.z.boolean().optional(),supportsTools:c.z.boolean().optional(),supportsStrictMode:c.z.boolean().optional(),maxTokensField:c.z.union([c.z.literal(`max_completion_tokens`),c.z.literal(`max_tokens`)]).optional(),thinkingFormat:c.z.union([c.z.literal(`openai`),c.z.literal(`zai`),c.z.literal(`qwen`)]).optional(),requiresToolResultName:c.z.boolean().optional(),requiresAssistantAfterToolResult:c.z.boolean().optional(),requiresThinkingAsText:c.z.boolean().optional(),requiresMistralToolIds:c.z.boolean().optional(),requiresOpenAiAnthropicToolPayload:c.z.boolean().optional()}).strict().optional(),Ee=c.z.object({id:c.z.string().min(1),name:c.z.string().min(1),api:we.optional(),reasoning:c.z.boolean().optional(),input:c.z.array(c.z.union([c.z.literal(`text`),c.z.literal(`image`)])).optional(),cost:c.z.object({input:c.z.number().optional(),output:c.z.number().optional(),cacheRead:c.z.number().optional(),cacheWrite:c.z.number().optional()}).strict().optional(),contextWindow:c.z.number().positive().optional(),maxTokens:c.z.number().positive().optional(),headers:c.z.record(c.z.string(),c.z.string()).optional(),compat:Te}).strict(),De=c.z.object({baseUrl:c.z.string().min(1),apiKey:C.optional().register(b),auth:c.z.union([c.z.literal(`api-key`),c.z.literal(`aws-sdk`),c.z.literal(`oauth`),c.z.literal(`token`)]).optional(),api:we.optional(),injectNumCtxForOpenAICompat:c.z.boolean().optional(),headers:c.z.record(c.z.string(),C.register(b)).optional(),authHeader:c.z.boolean().optional(),models:c.z.array(Ee)}).strict(),Oe=c.z.object({enabled:c.z.boolean().optional(),region:c.z.string().optional(),providerFilter:c.z.array(c.z.string()).optional(),refreshInterval:c.z.number().int().nonnegative().optional(),defaultContextWindow:c.z.number().int().positive().optional(),defaultMaxTokens:c.z.number().int().positive().optional()}).strict().optional();c.z.object({mode:c.z.union([c.z.literal(`merge`),c.z.literal(`replace`)]).optional(),providers:c.z.record(c.z.string(),De).optional(),bedrockDiscovery:Oe}).strict().optional(),c.z.object({mentionPatterns:c.z.array(c.z.string()).optional(),historyLimit:c.z.number().int().positive().optional()}).strict().optional();const ke=c.z.object({historyLimit:c.z.number().int().min(0).optional()}).strict();c.z.object({name:c.z.string().optional(),theme:c.z.string().optional(),emoji:c.z.string().optional(),avatar:c.z.string().optional()}).strict().optional();const w=c.z.union([c.z.literal(`steer`),c.z.literal(`followup`),c.z.literal(`collect`),c.z.literal(`steer-backlog`),c.z.literal(`steer+backlog`),c.z.literal(`queue`),c.z.literal(`interrupt`)]),Ae=c.z.union([c.z.literal(`old`),c.z.literal(`new`),c.z.literal(`summarize`)]);c.z.union([c.z.literal(`off`),c.z.literal(`first`),c.z.literal(`all`)]),c.z.union([c.z.literal(`never`),c.z.literal(`instant`),c.z.literal(`thinking`),c.z.literal(`message`)]),c.z.enum([`open`,`disabled`,`allowlist`]),c.z.enum([`pairing`,`allowlist`,`open`,`disabled`]);const je=c.z.object({minChars:c.z.number().int().positive().optional(),maxChars:c.z.number().int().positive().optional(),idleMs:c.z.number().int().nonnegative().optional()}).strict();c.z.number().int().min(0).optional(),c.z.number().int().min(0).optional(),c.z.record(c.z.string(),ke.optional()).optional(),c.z.number().int().positive().optional(),c.z.enum([`length`,`newline`]).optional(),c.z.boolean().optional(),je.optional(),c.z.string().optional(),c.z.number().positive().optional(),c.z.object({minChars:c.z.number().int().positive().optional(),maxChars:c.z.number().int().positive().optional(),breakPreference:c.z.union([c.z.literal(`paragraph`),c.z.literal(`newline`),c.z.literal(`sentence`)]).optional()}).strict();const Me=c.z.enum([`off`,`bullets`,`code`]);c.z.object({tables:Me.optional()}).strict().optional();const Ne=c.z.enum([`elevenlabs`,`openai`,`edge`]),Pe=c.z.enum([`final`,`all`]),Fe=c.z.enum([`off`,`always`,`inbound`,`tagged`]);c.z.object({auto:Fe.optional(),enabled:c.z.boolean().optional(),mode:Pe.optional(),provider:Ne.optional(),summaryModel:c.z.string().optional(),modelOverrides:c.z.object({enabled:c.z.boolean().optional(),allowText:c.z.boolean().optional(),allowProvider:c.z.boolean().optional(),allowVoice:c.z.boolean().optional(),allowModelId:c.z.boolean().optional(),allowVoiceSettings:c.z.boolean().optional(),allowNormalization:c.z.boolean().optional(),allowSeed:c.z.boolean().optional()}).strict().optional(),elevenlabs:c.z.object({apiKey:C.optional().register(b),baseUrl:c.z.string().optional(),voiceId:c.z.string().optional(),modelId:c.z.string().optional(),seed:c.z.number().int().min(0).max(4294967295).optional(),applyTextNormalization:c.z.enum([`auto`,`on`,`off`]).optional(),languageCode:c.z.string().optional(),voiceSettings:c.z.object({stability:c.z.number().min(0).max(1).optional(),similarityBoost:c.z.number().min(0).max(1).optional(),style:c.z.number().min(0).max(1).optional(),useSpeakerBoost:c.z.boolean().optional(),speed:c.z.number().min(.5).max(2).optional()}).strict().optional()}).strict().optional(),openai:c.z.object({apiKey:C.optional().register(b),baseUrl:c.z.string().optional(),model:c.z.string().optional(),voice:c.z.string().optional(),speed:c.z.number().min(.25).max(4).optional(),instructions:c.z.string().optional()}).strict().optional(),edge:c.z.object({enabled:c.z.boolean().optional(),voice:c.z.string().optional(),lang:c.z.string().optional(),outputFormat:c.z.string().optional(),pitch:c.z.string().optional(),rate:c.z.string().optional(),volume:c.z.string().optional(),saveSubtitles:c.z.boolean().optional(),proxy:c.z.string().optional(),timeoutMs:c.z.number().int().min(1e3).max(12e4).optional()}).strict().optional(),prefsPath:c.z.string().optional(),maxTextLength:c.z.number().int().min(1).optional(),timeoutMs:c.z.number().int().min(1e3).max(12e4).optional()}).strict().optional(),c.z.object({mode:c.z.union([c.z.literal(`off`),c.z.literal(`natural`),c.z.literal(`custom`)]).optional(),minMs:c.z.number().int().nonnegative().optional(),maxMs:c.z.number().int().nonnegative().optional()}).strict();const T=c.z.object({noOutputTimeoutMs:c.z.number().int().min(1e3).optional(),noOutputTimeoutRatio:c.z.number().min(.05).max(.95).optional(),minMs:c.z.number().int().min(1e3).optional(),maxMs:c.z.number().int().min(1e3).optional()}).strict().optional();c.z.object({command:c.z.string(),args:c.z.array(c.z.string()).optional(),output:c.z.union([c.z.literal(`json`),c.z.literal(`text`),c.z.literal(`jsonl`)]).optional(),resumeOutput:c.z.union([c.z.literal(`json`),c.z.literal(`text`),c.z.literal(`jsonl`)]).optional(),input:c.z.union([c.z.literal(`arg`),c.z.literal(`stdin`)]).optional(),maxPromptArgChars:c.z.number().int().positive().optional(),env:c.z.record(c.z.string(),c.z.string()).optional(),clearEnv:c.z.array(c.z.string()).optional(),modelArg:c.z.string().optional(),modelAliases:c.z.record(c.z.string(),c.z.string()).optional(),sessionArg:c.z.string().optional(),sessionArgs:c.z.array(c.z.string()).optional(),resumeArgs:c.z.array(c.z.string()).optional(),sessionMode:c.z.union([c.z.literal(`always`),c.z.literal(`existing`),c.z.literal(`none`)]).optional(),sessionIdFields:c.z.array(c.z.string()).optional(),systemPromptArg:c.z.string().optional(),systemPromptMode:c.z.union([c.z.literal(`append`),c.z.literal(`replace`)]).optional(),systemPromptWhen:c.z.union([c.z.literal(`first`),c.z.literal(`always`),c.z.literal(`never`)]).optional(),imageArg:c.z.string().optional(),imageMode:c.z.union([c.z.literal(`repeat`),c.z.literal(`list`)]).optional(),serialize:c.z.boolean().optional(),reliability:c.z.object({watchdog:c.z.object({fresh:T,resume:T}).strict().optional()}).strict().optional()}).strict(),c.z.enum([`thread`,`top-level`]),c.z.object({attempts:c.z.number().int().min(1).optional(),minDelayMs:c.z.number().int().min(0).optional(),maxDelayMs:c.z.number().int().min(0).optional(),jitter:c.z.number().min(0).max(1).optional()}).strict().optional();const Ie=c.z.object({whatsapp:w.optional(),telegram:w.optional(),discord:w.optional(),irc:w.optional(),slack:w.optional(),mattermost:w.optional(),signal:w.optional(),imessage:w.optional(),msteams:w.optional(),webchat:w.optional()}).strict().optional(),Le=c.z.record(c.z.string(),c.z.number().int().nonnegative()).optional();c.z.object({mode:w.optional(),byChannel:Ie,debounceMs:c.z.number().int().nonnegative().optional(),debounceMsByChannel:Le,cap:c.z.number().int().positive().optional(),drop:Ae.optional()}).strict().optional(),c.z.object({debounceMs:c.z.number().int().nonnegative().optional(),byChannel:Le}).strict().optional(),c.z.object({command:c.z.array(c.z.string()).superRefine((e,t)=>{let n=e[0];y(n)||t.addIssue({code:c.z.ZodIssueCode.custom,path:[0],message:`expected safe executable name or path`})}),timeoutSeconds:c.z.number().int().positive().optional()}).strict().optional(),c.z.string().regex(/^#?[0-9a-fA-F]{6}$/,`expected hex color (RRGGBB)`),c.z.string().refine(y,`expected safe executable name or path`);const Re=fe(),ze=c.z.array(c.z.union([c.z.literal(`image`),c.z.literal(`audio`),c.z.literal(`video`)])).optional(),Be=c.z.object({mode:c.z.union([c.z.literal(`first`),c.z.literal(`all`)]).optional(),maxAttachments:c.z.number().int().positive().optional(),prefer:c.z.union([c.z.literal(`first`),c.z.literal(`last`),c.z.literal(`path`),c.z.literal(`url`)]).optional()}).strict().optional(),Ve=c.z.object({detectLanguage:c.z.boolean().optional(),punctuate:c.z.boolean().optional(),smartFormat:c.z.boolean().optional()}).strict().optional(),He=c.z.union([c.z.string(),c.z.number(),c.z.boolean()]),Ue=c.z.record(c.z.string(),c.z.record(c.z.string(),He)).optional(),We={prompt:c.z.string().optional(),timeoutSeconds:c.z.number().int().positive().optional(),language:c.z.string().optional(),providerOptions:Ue,deepgram:Ve,baseUrl:c.z.string().optional(),headers:c.z.record(c.z.string(),c.z.string()).optional()},Ge=c.z.object({provider:c.z.string().optional(),model:c.z.string().optional(),capabilities:ze,type:c.z.union([c.z.literal(`provider`),c.z.literal(`cli`)]).optional(),command:c.z.string().optional(),args:c.z.array(c.z.string()).optional(),maxChars:c.z.number().int().positive().optional(),maxBytes:c.z.number().int().positive().optional(),...We,profile:c.z.string().optional(),preferredProfile:c.z.string().optional()}).strict().optional(),E=c.z.object({enabled:c.z.boolean().optional(),scope:Re,maxBytes:c.z.number().int().positive().optional(),maxChars:c.z.number().int().positive().optional(),...We,attachments:Be,models:c.z.array(Ge).optional(),echoTranscript:c.z.boolean().optional(),echoFormat:c.z.string().optional()}).strict().optional();c.z.object({models:c.z.array(Ge).optional(),concurrency:c.z.number().int().positive().optional(),image:E.optional(),audio:E.optional(),video:E.optional()}).strict().optional();const Ke=c.z.object({type:c.z.literal(`cli`).optional(),command:c.z.string().min(1),args:c.z.array(c.z.string()).optional(),timeoutSeconds:c.z.number().int().positive().optional()}).strict();c.z.object({enabled:c.z.boolean().optional(),scope:Re,maxLinks:c.z.number().int().positive().optional(),timeoutSeconds:c.z.number().int().positive().optional(),models:c.z.array(Ke).optional()}).strict().optional();const qe=c.z.union([c.z.boolean(),c.z.literal(`auto`)]);c.z.object({native:qe.optional(),nativeSkills:qe.optional()}).strict().optional();const Je=c.z.union([c.z.string(),c.z.number()]);c.z.array(Je).optional();function Ye(e){let t=e;return typeof t.toJSONSchema==`function`?{schema:t.toJSONSchema({target:`draft-07`,unrepresentable:`any`})}:{schema:{type:`object`,additionalProperties:!0}}}function Xe(e){let t,n=!1,r=async()=>{if(!n){n=!0;try{await e.onTick()}finally{n=!1}}};return{tick:r,start:()=>{e.intervalMs<=0||t||(t=setInterval(()=>{r()},e.intervalMs))},stop:()=>{t&&(clearInterval(t),t=void 0,n=!1)},isRunning:()=>t!==void 0}}function Ze(e){let t=typeof e.maxConsecutiveFailures==`number`&&e.maxConsecutiveFailures>0?Math.floor(e.maxConsecutiveFailures):void 0,n=0,r=!1,i=()=>e.isSealed()||r?!0:e.shouldBlock?.()===!0;return{run:async a=>{if(i())return`skipped`;try{return await a(),n=0,`started`}catch(i){if(n+=1,e.onStartError?.(i),e.rethrowOnError)throw i;return t&&n>=t?(r=!0,e.onTrip?.(),`tripped`):`failed`}},reset:()=>{n=0,r=!1},isTripped:()=>r}}function Qe(e){let t=e.stop,n=e.keepaliveIntervalMs??3e3,r=Math.max(1,e.maxConsecutiveFailures??2),i=e.maxDurationMs??6e4,a=!1,o=!1,s,c=Ze({isSealed:()=>o,onStartError:e.onStartError,maxConsecutiveFailures:r,onTrip:()=>{u.stop()}}),l=async()=>{await c.run(()=>e.start())},u=Xe({intervalMs:n,onTick:l}),d=()=>{i<=0||(f(),s=setTimeout(()=>{o||(console.warn(`[typing] TTL exceeded (${i}ms), auto-stopping typing indicator`),m())},i))},f=()=>{s&&=(clearTimeout(s),void 0)},p=async()=>{o||(a=!1,c.reset(),u.stop(),f(),await l(),!c.isTripped()&&(u.start(),d()))},m=()=>{o=!0,u.stop(),f(),!(!t||a)&&(a=!0,t().catch(t=>(e.onStopError??e.onStartError)(t)))};return{onReplyStart:p,onIdle:m,onCleanup:m}}const D=`/tmp/qbotclaw`,$e=u.default.constants.W_OK|u.default.constants.X_OK;function et(e,t){return typeof e==`object`&&!!e&&`code`in e&&e.code===t}function tt(e={}){let t=e.accessSync??u.default.accessSync,n=e.chmodSync??u.default.chmodSync,r=e.lstatSync??u.default.lstatSync,i=e.mkdirSync??u.default.mkdirSync,a=e.warn??(e=>console.warn(e)),o=e.getuid??(()=>{try{return typeof process.getuid==`function`?process.getuid():void 0}catch{return}}),s=e.tmpdir??d.default.tmpdir,c=o(),f=e=>c===void 0?!0:!(typeof e.uid==`number`&&e.uid!==c||typeof e.mode==`number`&&e.mode&18),p=()=>{let e=s(),t=c===void 0?`qbotclaw`:`qbotclaw-${c}`;return l.default.join(e,t)},m=e=>e.isDirectory()&&!e.isSymbolicLink()&&f(e),h=e=>{try{return m(r(e))?(t(e,$e),`available`):`invalid`}catch(e){return et(e,`ENOENT`)?`missing`:`invalid`}},g=e=>{try{let t=r(e);return!t.isDirectory()||t.isSymbolicLink()||c!==void 0&&typeof t.uid==`number`&&t.uid!==c||typeof t.mode!=`number`||!(t.mode&18)?!1:(n(e,448),a(`[openclaw] tightened permissions on temp dir: ${e}`),h(e)===`available`)}catch{return!1}},_=()=>{let e=p(),t=h(e);if(t===`available`)return e;if(t===`invalid`){if(g(e))return e;throw Error(`Unsafe fallback OpenClaw temp dir: ${e}`)}try{i(e,{recursive:!0,mode:448}),n(e,448)}catch{throw Error(`Unable to create fallback OpenClaw temp dir: ${e}`)}if(h(e)!==`available`&&!g(e))throw Error(`Unsafe fallback OpenClaw temp dir: ${e}`);return e},v=h(D);if(v===`available`)return D;if(v===`invalid`)return g(`/tmp/qbotclaw`)?D:_();try{return t(`/tmp`,$e),i(D,{recursive:!0,mode:448}),n(D,448),h(`/tmp/qbotclaw`)!==`available`&&!g(`/tmp/qbotclaw`)?_():D}catch{return _()}}function nt(e){return{success:!1,error:{issues:[{path:[],message:e}]}}}function rt(){return{safeParse(e){return e===void 0?{success:!0,data:void 0}:!e||typeof e!=`object`||Array.isArray(e)?nt(`expected config object`):Object.keys(e).length>0?nt(`config must be empty`):{success:!0,data:e}},jsonSchema:{type:`object`,additionalProperties:!1,properties:{}}}}const it=new Set([`__proto__`,`prototype`,`constructor`]);function at(e){return it.has(e)}const O=`default`,ot=/^[a-z0-9][a-z0-9_-]{0,63}$/i,st=/[^a-z0-9_-]+/g,ct=/^-+/,lt=/-+$/,ut=new Map,k=new Map;function dt(e){return ot.test(e)?e.toLowerCase():e.toLowerCase().replace(st,`-`).replace(ct,``).replace(lt,``).slice(0,64)}function ft(e){let t=dt(e);if(!(!t||at(t)))return t}function pt(e){let t=(e??``).trim();if(!t)return O;let n=ut.get(t);if(n)return n;let r=ft(t)||`default`;return ht(ut,t,r),r}function mt(e){let t=(e??``).trim();if(!t)return;if(k.has(t))return k.get(t);let n=ft(t)||void 0;return ht(k,t,n),n}function ht(e,t,n){if(e.set(t,n),e.size<=512)return;let r=e.keys().next();r.done||e.delete(r.value)}function gt(e){let t=e;return t=t.replace(/\*\*(.+?)\*\*/g,`$1`),t=t.replace(/__(.+?)__/g,`$1`),t=t.replace(/(?<!\*)\*(?!\*)(.+?)(?<!\*)\*(?!\*)/g,`$1`),t=t.replace(/(?<!_)_(?!_)(.+?)(?<!_)_(?!_)/g,`$1`),t=t.replace(/~~(.+?)~~/g,`$1`),t=t.replace(/^#{1,6}\s+(.+)$/gm,`$1`),t=t.replace(/^>\s?(.*)$/gm,`$1`),t=t.replace(/^[-*_]{3,}$/gm,``),t=t.replace(/`([^`]+)`/g,`$1`),t=t.replace(/\n{3,}/g,`
|
|
2
2
|
|
|
3
|
-
`),t=t.trim(),t}function _t(e){return Number.isInteger(e)&&e>0}function vt(e){if(process.platform!==`linux`)return!1;try{return u.default.readFileSync(`/proc/${e}/status`,`utf8`).match(/^State:\s+(\S)/m)?.[1]===`Z`}catch{return!1}}function yt(e){if(!_t(e))return!1;try{process.kill(e,0)}catch{return!1}return!vt(e)}function bt(e){let t=process,n=t[e];if(n)return n;let r=new Map;return t[e]=r,r}const A=bt(Symbol.for(`openclaw.fileLockHeldLocks`));function xt(e,t){let n=Math.min(e.maxTimeout,Math.max(e.minTimeout,e.minTimeout*e.factor**t)),r=e.randomize?1+Math.random():1;return Math.min(e.maxTimeout,Math.round(n*r))}async function St(e){try{let t=await f.default.readFile(e,`utf8`),n=JSON.parse(t);return typeof n.pid!=`number`||typeof n.createdAt!=`string`?null:{pid:n.pid,createdAt:n.createdAt}}catch{return null}}async function Ct(e){let t=l.default.resolve(e),n=l.default.dirname(t);await f.default.mkdir(n,{recursive:!0});try{let e=await f.default.realpath(n);return l.default.join(e,l.default.basename(t))}catch{return t}}async function wt(e,t){let n=await St(e);if(n?.pid&&!yt(n.pid))return!0;if(n?.createdAt){let e=Date.parse(n.createdAt);if(!Number.isFinite(e)||Date.now()-e>t)return!0}try{let n=await f.default.stat(e);return Date.now()-n.mtimeMs>t}catch{return!0}}async function Tt(e){let t=A.get(e);t&&(--t.count,!(t.count>0)&&(A.delete(e),await t.handle.close().catch(()=>void 0),await f.default.rm(t.lockPath,{force:!0}).catch(()=>void 0)))}async function Et(e,t){let n=await Ct(e),r=`${n}.lock`,i=A.get(n);if(i)return i.count+=1,{lockPath:r,release:()=>Tt(n)};let a=Math.max(1,t.retries.retries+1);for(let e=0;e<a;e+=1)try{let e=await f.default.open(r,`wx`);return await e.writeFile(JSON.stringify({pid:process.pid,createdAt:new Date().toISOString()},null,2),`utf8`),A.set(n,{count:1,handle:e,lockPath:r}),{lockPath:r,release:()=>Tt(n)}}catch(n){if(n.code!==`EEXIST`)throw n;if(await wt(r,t.stale)){await f.default.rm(r,{force:!0}).catch(()=>void 0);continue}if(e>=a-1)break;await new Promise(n=>setTimeout(n,xt(t.retries,e)))}throw Error(`file lock timeout for ${n}`)}async function Dt(e,t,n){let r=await Et(e,t);try{return await n()}finally{await r.release()}}function Ot(e){let t=e.dmPolicy===`allowlist`?[]:e.storeAllowFrom??[];return[...e.allowFrom??[],...t].map(e=>String(e).trim()).filter(Boolean)}function kt(e){return((Array.isArray(e.groupAllowFrom)&&e.groupAllowFrom.length>0?e.groupAllowFrom:void 0)||(e.fallbackToAllowFrom===!1?[]:e.allowFrom??[])).map(e=>String(e).trim()).filter(Boolean)}const At=new Set([`--dev`,`--no-color`]),jt=new Set([`--profile`,`--log-level`]);function Mt(e){return!e||e===`--`?!1:e.startsWith(`-`)?/^-\d+(?:\.\d+)?$/.test(e):!0}function Nt(e,t){let n=e[t];return n?At.has(n)||n.startsWith(`--profile=`)||n.startsWith(`--log-level=`)?1:jt.has(n)?Mt(e[t+1])?2:1:0:0}function Pt(e,t=2){return Ft(e,t,{skipRootOptions:!0})}function Ft(e,t,n){let r=e.slice(2),i=[];for(let e=0;e<r.length;e+=1){let a=r[e];if(a){if(a===`--`)break;if(n.skipRootOptions){let t=Nt(r,e);if(t>0){e+=t-1;continue}}if(!a.startsWith(`-`)&&(i.push(a),i.length>=t))break}}return i}function j(e){return e?.trim()||void 0}function It(e=process.env,t=d.default.homedir){let n=Lt(e,t);return n?l.default.resolve(n):void 0}function Lt(e,t){let n=j(e.OPENCLAW_HOME);if(n){if(n===`~`||n.startsWith(`~/`)||n.startsWith(`~\\`)){let r=j(e.HOME)??j(e.USERPROFILE)??Rt(t);return r?n.replace(/^~(?=$|[\\/])/,r):void 0}return n}return j(e.HOME)||j(e.USERPROFILE)||Rt(t)}function Rt(e){try{return j(e())}catch{return}}function M(e=process.env,t=d.default.homedir){return It(e,t)??l.default.resolve(process.cwd())}function zt(e,t){if(!e.startsWith(`~`))return e;let n=j(t?.home)??It(t?.env??process.env,t?.homedir??d.default.homedir);return n?e.replace(/^~(?=$|[\\/])/,n):e}function Bt(e=process.env){return e.OPENCLAW_NIX_MODE===`1`}Bt();const Vt=[`.clawdbot`,`.moldbot`,`.moltbot`],N=`.openclaw-qbot.json`,P=[`openclaw.json`,`clawdbot.json`,`moldbot.json`,`moltbot.json`];function Ht(){return M(process.env,d.default.homedir)}function F(e){return()=>M(e,d.default.homedir)}function Ut(e=Ht){return Vt.map(t=>l.default.join(e(),t))}function Wt(e=Ht){return l.default.join(e(),`.qbotclaw`)}function I(e=process.env,t=F(e)){let n=()=>M(e,t),r=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(r)return L(r,e,n);let i=Wt(n);if(e.OPENCLAW_TEST_FAST===`1`)return i;let a=Ut(n);return u.default.existsSync(i)?i:a.find(e=>{try{return u.default.existsSync(e)}catch{return!1}})||i}function L(e,t=process.env,n=F(t)){let r=e.trim();if(!r)return r;if(r.startsWith(`~`)){let e=zt(r,{home:M(t,n),env:t,homedir:n});return l.default.resolve(e)}return l.default.resolve(r)}I();function Gt(e=process.env,t=I(e,F(e))){let n=e.OPENCLAW_CONFIG_PATH?.trim()||e.CLAWDBOT_CONFIG_PATH?.trim();return n?L(n,e,F(e)):l.default.join(t,N)}function Kt(e=process.env,t=F(e)){return e.OPENCLAW_TEST_FAST===`1`?Gt(e,I(e,t)):Jt(e,t).find(e=>{try{return u.default.existsSync(e)}catch{return!1}})||Gt(e,I(e,t))}function qt(e=process.env,t=I(e,F(e)),n=F(e)){let r=e.OPENCLAW_CONFIG_PATH?.trim();if(r)return L(r,e,n);if(e.OPENCLAW_TEST_FAST===`1`)return l.default.join(t,N);let i=e.OPENCLAW_STATE_DIR?.trim(),a=[l.default.join(t,N),...P.map(e=>l.default.join(t,e))].find(e=>{try{return u.default.existsSync(e)}catch{return!1}});if(a)return a;if(i)return l.default.join(t,N);let o=I(e,n);return l.default.resolve(t)===l.default.resolve(o)?Kt(e,n):l.default.join(t,N)}Kt();function Jt(e=process.env,t=F(e)){let n=()=>M(e,t),r=e.OPENCLAW_CONFIG_PATH?.trim()||e.CLAWDBOT_CONFIG_PATH?.trim();if(r)return[L(r,e,n)];let i=[],a=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(a){let t=L(a,e,n);i.push(l.default.join(t,N)),i.push(...P.map(e=>l.default.join(t,e)))}let o=[Wt(n),...Ut(n)];for(let e of o)i.push(l.default.join(e,N)),i.push(...P.map(t=>l.default.join(e,t)));return i}function Yt(e=process.env,t=I(e,F(e))){let n=e.OPENCLAW_OAUTH_DIR?.trim();return n?L(n,e,F(e)):l.default.join(t,`credentials`)}function Xt(){let e=qt();try{if(!u.default.existsSync(e))return;let t=u.default.readFileSync(e,`utf-8`),n=h.default.parse(t)?.logging;return!n||typeof n!=`object`||Array.isArray(n)?void 0:n}catch{return}}const Zt=[`silent`,`fatal`,`error`,`warn`,`info`,`debug`,`trace`];function Qt(e){if(typeof e!=`string`)return;let t=e.trim();return Zt.includes(t)?t:void 0}function $t(e,t=`info`){return Qt(e)??t}function R(e){return{fatal:0,error:1,warn:2,info:3,debug:4,trace:5,silent:1/0}[e]}const z={cachedLogger:null,cachedSettings:null,cachedConsoleSettings:null,overrideSettings:null,invalidEnvLogLevelValue:null,consolePatched:!1,forceConsoleToStderr:!1,consoleTimestampPrefix:!1,consoleSubsystemFilter:null,resolvingConsoleSettings:!1,streamErrorHandlersInstalled:!1,rawConsole:null};function en(){let e=process.env.OPENCLAW_LOG_LEVEL,t=typeof e==`string`?e.trim():``;if(!t){z.invalidEnvLogLevelValue=null;return}let n=Qt(t);if(n)return z.invalidEnvLogLevelValue=null,n;z.invalidEnvLogLevelValue!==t&&(z.invalidEnvLogLevelValue=t,process.stderr.write(`[openclaw] Ignoring invalid OPENCLAW_LOG_LEVEL="${t}" (allowed: ${Zt.join(`|`)}).\n`))}function tn(e){let t=process.getBuiltinModule;if(typeof t!=`function`)return null;try{let n=t(`module`),r=typeof n.createRequire==`function`?n.createRequire:null;return r?r(e):null}catch{return null}}function nn(e){try{return new Intl.DateTimeFormat(`en`,{timeZone:e}),!0}catch{return!1}}function B(e,t){let n=t??process.env.TZ,r=n&&nn(n)?n:Intl.DateTimeFormat().resolvedOptions().timeZone,i=new Intl.DateTimeFormat(`en`,{timeZone:r,year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,hour12:!1,fractionalSecondDigits:3,timeZoneName:`longOffset`}),a=Object.fromEntries(i.formatToParts(e).map(e=>[e.type,e.value])),o=a.timeZoneName??`GMT`,s=o===`GMT`?`+00:00`:o.slice(3);return`${a.year}-${a.month}-${a.day}T${a.hour}:${a.minute}:${a.second}.${a.fractionalSecond}${s}`}const V=tt();l.default.join(V,`qbotclaw.log`);const H=`qbotclaw`,U=`.log`,rn=500*1024*1024,an=tn(require(`url`).pathToFileURL(__filename).href),W=new Set;function on(e=process.argv){let[t,n]=Pt(e,2);return t===`config`&&n===`validate`}function sn(e,t){e.attachTransport(e=>{if(W.has(t))try{t(e)}catch{}})}function cn(e){return process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_FILE_LOG!==`1`&&!e&&!z.overrideSettings}function ln(){let e=en();if(cn(e))return{level:`silent`,file:yn(),maxFileBytes:rn};let t=z.overrideSettings??Xt();if(!t&&!on())try{t=(an?.(`../config/config.js`))?.loadConfig?.().logging}catch{t=void 0}let n=process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_FILE_LOG!==`1`?`silent`:`info`,r=$t(t?.level,n);return{level:e??r,file:t?.file??yn(),maxFileBytes:pn(t?.maxFileBytes)}}function un(e,t){return e?e.level!==t.level||e.file!==t.file||e.maxFileBytes!==t.maxFileBytes:!0}function dn(e){let t=z.cachedSettings??ln();return z.cachedSettings||=t,t.level===`silent`?!1:R(e)<=R(t.level)}function fn(e){let t=new m.Logger({name:`openclaw`,minLevel:R(e.level),type:`hidden`});if(e.level===`silent`){for(let e of W)sn(t,e);return t}u.default.mkdirSync(l.default.dirname(e.file),{recursive:!0}),bn(e.file)&&xn(l.default.dirname(e.file));let n=mn(e.file),r=!1;t.attachTransport(t=>{try{let i=B(t.date??new Date),a=`${JSON.stringify({...t,time:i})}\n`,o=Buffer.byteLength(a,`utf8`),s=n+o;if(s>e.maxFileBytes){if(!r){r=!0;let t=JSON.stringify({time:B(new Date),level:`warn`,subsystem:`logging`,message:`log file size cap reached; suppressing writes file=${e.file} maxFileBytes=${e.maxFileBytes}`});hn(e.file,`${t}\n`),process.stderr.write(`[openclaw] log file size cap reached; suppressing writes file=${e.file} maxFileBytes=${e.maxFileBytes}\n`)}return}hn(e.file,a)&&(n=s)}catch{}});for(let e of W)sn(t,e);return t}function pn(e){return typeof e==`number`&&Number.isFinite(e)&&e>0?Math.floor(e):rn}function mn(e){try{return u.default.statSync(e).size}catch{return 0}}function hn(e,t){try{return u.default.appendFileSync(e,t,{encoding:`utf8`}),!0}catch{return!1}}function gn(){let e=ln(),t=z.cachedLogger,n=z.cachedSettings;return(!t||un(n,e))&&(z.cachedLogger=fn(e),z.cachedSettings=e),z.cachedLogger}function _n(e,t){let n=gn(),r=t?.level?R(t.level):void 0,i=e?JSON.stringify(e):void 0;return n.getSubLogger({name:i,minLevel:r,prefix:e?[i??``]:[]})}function vn(e){return`${e.getFullYear()}-${String(e.getMonth()+1).padStart(2,`0`)}-${String(e.getDate()).padStart(2,`0`)}`}function yn(){let e=vn(new Date);return l.default.join(V,`${H}-${e}${U}`)}function bn(e){let t=l.default.basename(e);return t.startsWith(`${H}-`)&&t.endsWith(U)&&t.length===`${H}-YYYY-MM-DD${U}`.length}function xn(e){try{let t=u.default.readdirSync(e,{withFileTypes:!0}),n=Date.now()-864e5;for(let r of t){if(!r.isFile()||!r.name.startsWith(`${H}-`)||!r.name.endsWith(U))continue;let t=l.default.join(e,r.name);try{u.default.statSync(t).mtimeMs<n&&u.default.rmSync(t,{force:!0})}catch{}}}catch{}}const G={accent:`#FF5A2D`,accentBright:`#FF7A3D`,accentDim:`#D14A22`,info:`#FF8A5B`,success:`#2FBF71`,warn:`#FFB020`,error:`#E23D2D`,muted:`#8B7F77`},Sn=typeof process.env.FORCE_COLOR==`string`&&process.env.FORCE_COLOR.trim().length>0&&process.env.FORCE_COLOR.trim()!==`0`,Cn=process.env.NO_COLOR&&!Sn?new p.Chalk({level:0}):p.default,K=e=>Cn.hex(e),q={accent:K(G.accent),accentBright:K(G.accentBright),accentDim:K(G.accentDim),info:K(G.info),success:K(G.success),warn:K(G.warn),error:K(G.error),muted:K(G.muted),heading:Cn.bold.hex(G.accent),command:K(G.accentBright),option:K(G.warn)};function J(){return!1}q.success,q.warn,q.info,q.error;function wn(e=process.env){return e.VITEST!==`true`||e.OPENCLAW_TEST_RUNTIME_LOG===`1`?!0:typeof console.log.mock==`object`}function Tn(){return{log:(...e)=>{wn()&&console.log(...e)},error:(...e)=>{console.error(...e)}}}({...Tn()}),typeof Intl<`u`&&`Segmenter`in Intl&&new Intl.Segmenter(void 0,{granularity:`grapheme`});const En=tn(require(`url`).pathToFileURL(__filename).href);let Dn=()=>{try{return(En?.(`../config/config.js`))?.loadConfig?.().logging}catch{return}};function On(e){return J()?`debug`:!e&&process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_CONSOLE!==`1`?`silent`:$t(e,`info`)}function kn(e){return e===`compact`||e===`json`||e===`pretty`?e:process.stdout.isTTY?`pretty`:`compact`}function An(){let e=en();if(process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_CONSOLE!==`1`&&!J()&&!e&&!z.overrideSettings)return{level:`silent`,style:kn(void 0)};let t=z.overrideSettings??Xt();if(!t)if(z.resolvingConsoleSettings)t=void 0;else{z.resolvingConsoleSettings=!0;try{t=Dn()}finally{z.resolvingConsoleSettings=!1}}return{level:e??On(t?.consoleLevel),style:kn(t?.consoleStyle)}}function jn(e,t){return e?e.level!==t.level||e.style!==t.style:!0}function Mn(){let e=An(),t=z.cachedConsoleSettings;return(!t||jn(t,e))&&(z.cachedConsoleSettings=e),z.cachedConsoleSettings}function Nn(e){let t=z.consoleSubsystemFilter;return!t||t.length===0?!0:t.some(t=>e===t||e.startsWith(`${t}/`))}function Y(e){let t=new Date;return e===`pretty`?`${String(t.getHours()).padStart(2,`0`)}:${String(t.getMinutes()).padStart(2,`0`)}:${String(t.getSeconds()).padStart(2,`0`)}`:B(t)}function Pn(e,t){return t.level===`silent`?!1:R(e)<=R(t.level)}(()=>{let e=process.getBuiltinModule;if(typeof e!=`function`)return null;try{let t=e(`util`);return typeof t.inspect==`function`?t.inspect:null}catch{return null}})();function Fn(){let e=(process.env.TERM??``).toLowerCase();return process.env.COLORTERM||process.env.TERM_PROGRAM?!0:e.length>0&&e!==`dumb`}function In(){let e=typeof process.env.FORCE_COLOR==`string`&&process.env.FORCE_COLOR.trim().length>0&&process.env.FORCE_COLOR.trim()!==`0`;return process.env.NO_COLOR&&!e?new p.Chalk({level:0}):process.stdout.isTTY||process.stderr.isTTY||Fn()?new p.Chalk({level:1}):new p.Chalk({level:0})}const Ln=[`cyan`,`green`,`yellow`,`blue`,`magenta`,`red`],Rn={"gmail-watcher":`blue`},zn=[`gateway`,`channels`,`providers`],Bn=new Set([`telegram`,`whatsapp`,`discord`,`irc`,`googlechat`,`slack`,`signal`,`imessage`]);function Vn(e,t){let n=Rn[t];if(n)return e[n];let r=0;for(let e=0;e<t.length;e+=1)r=r*31+t.charCodeAt(e)|0;return e[Ln[Math.abs(r)%Ln.length]]}function Hn(e){let t=e.split(`/`).filter(Boolean),n=t.join(`/`)||e;for(;t.length>0&&zn.includes(t[0]);)t.shift();return t.length===0?n:Bn.has(t[0])?t[0]:t.length>2?t.slice(-2).join(`/`):t.join(`/`)}function Un(e,t){if(!t)return e;if(e.startsWith(`[`)){let n=e.indexOf(`]`);if(n>1&&e.slice(1,n).toLowerCase()===t.toLowerCase()){let t=n+1;for(;e[t]===` `;)t+=1;return e.slice(t)}}if(e.slice(0,t.length).toLowerCase()!==t.toLowerCase())return e;let n=e.slice(t.length,t.length+1);if(n!==`:`&&n!==` `)return e;let r=t.length;for(;e[r]===` `;)r+=1;for(e[r]===`:`&&(r+=1);e[r]===` `;)r+=1;return e.slice(r)}function Wn(e){let t=e.style===`json`?e.subsystem:Hn(e.subsystem);if(e.style===`json`)return JSON.stringify({time:Y(`json`),level:e.level,subsystem:t,message:e.message,...e.meta});let n=In(),r=`[${t}]`,i=Vn(n,t),a=e.level===`error`||e.level===`fatal`?n.red:e.level===`warn`?n.yellow:e.level===`debug`||e.level===`trace`?n.gray:n.cyan,o=Un(e.message,t);return`${[e.style===`pretty`?n.gray(Y(`pretty`)):z.consoleTimestampPrefix?n.gray(Y(e.style)):``,i(r)].filter(Boolean).join(` `)} ${a(o)}`}function Gn(e,t){let n=process.platform===`win32`&&process.env.GITHUB_ACTIONS===`true`?t.replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g,`?`).replace(/[\uD800-\uDFFF]/g,`?`):t,r=z.rawConsole??console;z.forceConsoleToStderr||e===`error`||e===`fatal`?(r.error??console.error)(n):e===`warn`?(r.warn??console.warn)(n):(r.log??console.log)(n)}function Kn(e){return J()||e.level===`error`||e.level===`fatal`||!(e.subsystem===`agent/embedded`||e.subsystem.startsWith(`agent/embedded/`)||e.subsystem===`model-fallback`||e.subsystem.startsWith(`model-fallback/`))?!1:(typeof e.meta?.runId==`string`?e.meta.runId:typeof e.meta?.sessionId==`string`?e.meta.sessionId:void 0)?.startsWith(`probe-`)?!0:/(sessionId|runId)=probe-/.test(e.message)}function qn(e,t,n,r){if(t===`silent`)return;let i=e[t];typeof i==`function`&&(r&&Object.keys(r).length>0?i.call(e,r,n):i.call(e,n))}function Jn(e){let t=null,n=()=>(t||=_n({subsystem:e}),t),r=(t,r,i)=>{let a=Mn(),o=Pn(t,{level:a.level})&&Nn(e),s=dn(t);if(!o&&!s)return;let c,l=i;if(i&&Object.keys(i).length>0){let{consoleMessage:e,...t}=i;typeof e==`string`&&(c=e),l=Object.keys(t).length>0?t:void 0}if(s&&qn(n(),t,r,l),!o)return;let u=c??r;Kn({level:t,subsystem:e,message:u,meta:l})||Gn(t,Wn({level:t,subsystem:e,message:a.style===`json`?r:u,style:a.style,meta:l}))},i=t=>Pn(t,{level:Mn().level})&&Nn(e),a=e=>dn(e);return{subsystem:e,isEnabled:(e,t=`any`)=>t===`console`?i(e):t===`file`?a(e):i(e)||a(e),trace:(e,t)=>r(`trace`,e,t),debug:(e,t)=>r(`debug`,e,t),info:(e,t)=>r(`info`,e,t),warn:(e,t)=>r(`warn`,e,t),error:(e,t)=>r(`error`,e,t),fatal:(e,t)=>r(`fatal`,e,t),raw:t=>{if(a(`info`)&&qn(n(),`info`,t,{raw:!0}),i(`info`)){if(Kn({level:`info`,subsystem:e,message:t}))return;Gn(`info`,t)}},child:t=>Jn(`${e}/${t}`)}}const Yn=globalThis;Yn.__openclaw_internal_hook_handlers__??=new Map;function Xn(e){if(!e)return``;let t=e.trim();if(!t)return t;if(t.startsWith(`~`)){let e=zt(t,{home:M(process.env,d.default.homedir),env:process.env,homedir:d.default.homedir});return l.default.resolve(e)}return l.default.resolve(t)}function Zn(e=process.env,t=d.default.homedir){let n=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(n)return Xn(n);let r=l.default.join(M(e,t),`.qbotclaw`);try{if(u.default.existsSync(r))return r}catch{}return r}Zn();function Qn(){return{plugins:[],tools:[],hooks:[],typedHooks:[],channels:[],providers:[],gatewayHandlers:{},httpRoutes:[],cliRegistrars:[],services:[],commands:[],diagnostics:[]}}const X=Symbol.for(`openclaw.pluginRegistryState`);(()=>{let e=globalThis;return e[X]||(e[X]={registry:Qn(),key:null,version:0}),e[X]})();function Z(e,t){function n(t){let n=t.channels?.[e],r=mt(typeof n?.defaultAccount==`string`?n.defaultAccount:void 0);if(r&&i(t).some(e=>pt(e)===r))return r}function r(n){let r=n.channels?.[e]?.accounts;if(!r||typeof r!=`object`)return[];let i=Object.keys(r).filter(Boolean),a=t?.normalizeAccountId;return a?[...new Set(i.map(e=>a(e)).filter(Boolean))]:i}function i(e){let t=r(e);return t.length===0?[O]:t.toSorted((e,t)=>e.localeCompare(t))}function a(e){let t=n(e);if(t)return t;let r=i(e);return r.includes(`default`)?O:r[0]??`default`}return{listConfiguredAccountIds:r,listAccountIds:i,resolveDefaultAccountId:a}}const{listAccountIds:$n,resolveDefaultAccountId:er}=Z(`discord`),{listAccountIds:tr,resolveDefaultAccountId:nr}=Z(`imessage`);function Q(e){return(e??[]).map(e=>String(e).trim()).filter(Boolean)}function rr(){return l.default.join(Yt(),`whatsapp`,O)}rr();const{listConfiguredAccountIds:ir,listAccountIds:ar,resolveDefaultAccountId:or}=Z(`whatsapp`),{listAccountIds:sr,resolveDefaultAccountId:cr}=Z(`slack`);Object.freeze({allowFinalSymlinkForUnlink:!1,allowFinalHardlinkForUnlink:!1}),Object.freeze({allowFinalSymlinkForUnlink:!0,allowFinalHardlinkForUnlink:!0}),l.default.resolve(l.default.dirname((0,g.fileURLToPath)(require(`url`).pathToFileURL(__filename).href)),`../../docs/reference/templates`);function lr(e=process.env,t=d.default.homedir){let n=Zn(e,t),r=e.OPENCLAW_PROFILE?.trim();return r&&r.toLowerCase()!==`default`?l.default.join(n,`workspace-${r}`):l.default.join(n,`workspace`)}lr();function ur(e){if(e.groupPolicy===`disabled`)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`disabled`};if(e.groupPolicy===`allowlist`){if(e.requireMatchInput&&!e.hasMatchInput)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`missing_match_input`};if(!e.allowlistConfigured)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`empty_allowlist`};if(!e.allowlistMatched)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`not_allowlisted`}}return{allowed:!0,groupPolicy:e.groupPolicy,reason:`allowed`}}function dr(e){let t=Array.isArray(e.allowFrom)?e.allowFrom:void 0,n=Array.isArray(e.groupAllowFrom)?e.groupAllowFrom:void 0;return{effectiveAllowFrom:Q(Ot({allowFrom:t,storeAllowFrom:Array.isArray(e.storeAllowFrom)?e.storeAllowFrom:void 0,dmPolicy:e.dmPolicy??void 0})),effectiveGroupAllowFrom:Q(kt({allowFrom:t,groupAllowFrom:n,fallbackToAllowFrom:e.groupAllowFromFallbackToAllowFrom??void 0}))}}const $={GROUP_POLICY_ALLOWED:`group_policy_allowed`,GROUP_POLICY_DISABLED:`group_policy_disabled`,GROUP_POLICY_EMPTY_ALLOWLIST:`group_policy_empty_allowlist`,GROUP_POLICY_NOT_ALLOWLISTED:`group_policy_not_allowlisted`,DM_POLICY_OPEN:`dm_policy_open`,DM_POLICY_DISABLED:`dm_policy_disabled`,DM_POLICY_ALLOWLISTED:`dm_policy_allowlisted`,DM_POLICY_PAIRING_REQUIRED:`dm_policy_pairing_required`,DM_POLICY_NOT_ALLOWLISTED:`dm_policy_not_allowlisted`};function fr(e){let t=e.dmPolicy??`pairing`,n=e.groupPolicy===`open`||e.groupPolicy===`disabled`?e.groupPolicy:`allowlist`,r=Q(e.effectiveAllowFrom),i=Q(e.effectiveGroupAllowFrom);if(e.isGroup){let t=ur({groupPolicy:n,allowlistConfigured:i.length>0,allowlistMatched:e.isSenderAllowed(i)});if(!t.allowed){if(t.reason===`disabled`)return{decision:`block`,reasonCode:$.GROUP_POLICY_DISABLED,reason:`groupPolicy=disabled`};if(t.reason===`empty_allowlist`)return{decision:`block`,reasonCode:$.GROUP_POLICY_EMPTY_ALLOWLIST,reason:`groupPolicy=allowlist (empty allowlist)`};if(t.reason===`not_allowlisted`)return{decision:`block`,reasonCode:$.GROUP_POLICY_NOT_ALLOWLISTED,reason:`groupPolicy=allowlist (not allowlisted)`}}return{decision:`allow`,reasonCode:$.GROUP_POLICY_ALLOWED,reason:`groupPolicy=${n}`}}return t===`disabled`?{decision:`block`,reasonCode:$.DM_POLICY_DISABLED,reason:`dmPolicy=disabled`}:t===`open`?{decision:`allow`,reasonCode:$.DM_POLICY_OPEN,reason:`dmPolicy=open`}:e.isSenderAllowed(r)?{decision:`allow`,reasonCode:$.DM_POLICY_ALLOWLISTED,reason:`dmPolicy=${t} (allowlisted)`}:t===`pairing`?{decision:`pairing`,reasonCode:$.DM_POLICY_PAIRING_REQUIRED,reason:`dmPolicy=pairing (not allowlisted)`}:{decision:`block`,reasonCode:$.DM_POLICY_NOT_ALLOWLISTED,reason:`dmPolicy=${t} (not allowlisted)`}}function pr(e){let{effectiveAllowFrom:t,effectiveGroupAllowFrom:n}=dr({allowFrom:e.allowFrom,groupAllowFrom:e.groupAllowFrom,storeAllowFrom:e.storeAllowFrom,dmPolicy:e.dmPolicy,groupAllowFromFallbackToAllowFrom:e.groupAllowFromFallbackToAllowFrom});return{...fr({isGroup:e.isGroup,dmPolicy:e.dmPolicy,groupPolicy:e.groupPolicy,effectiveAllowFrom:t,effectiveGroupAllowFrom:n,isSenderAllowed:e.isSenderAllowed}),effectiveAllowFrom:t,effectiveGroupAllowFrom:n}}function mr(e){return e.isGroup?`allowed`:e.dmPolicy===`disabled`?`disabled`:e.dmPolicy!==`open`&&!e.senderAllowedForCommands?`unauthorized`:`allowed`}async function hr(e){return gr({...e,shouldComputeCommandAuthorized:e.runtime.shouldComputeCommandAuthorized,resolveCommandAuthorizedFromAuthorizers:e.runtime.resolveCommandAuthorizedFromAuthorizers})}async function gr(e){let t=e.shouldComputeCommandAuthorized(e.rawBody,e.cfg),n=!e.isGroup&&e.dmPolicy!==`allowlist`&&(e.dmPolicy!==`open`||t)?await e.readAllowFromStore().catch(()=>[]):[],r=pr({isGroup:e.isGroup,dmPolicy:e.dmPolicy,groupPolicy:`allowlist`,allowFrom:e.configuredAllowFrom,groupAllowFrom:e.configuredGroupAllowFrom??[],storeAllowFrom:n,isSenderAllowed:t=>e.isSenderAllowed(e.senderId,t)}),i=r.effectiveAllowFrom,a=r.effectiveGroupAllowFrom,o=e.cfg.commands?.useAccessGroups!==!1,s=e.isSenderAllowed(e.senderId,e.isGroup?a:i),c=e.isSenderAllowed(e.senderId,i),l=e.isSenderAllowed(e.senderId,a);return{shouldComputeAuth:t,effectiveAllowFrom:i,effectiveGroupAllowFrom:a,senderAllowedForCommands:s,commandAuthorized:t?e.resolveCommandAuthorizedFromAuthorizers({useAccessGroups:o,authorizers:[{configured:i.length>0,allowed:c},{configured:a.length>0,allowed:l}]}):void 0}}exports.DEFAULT_ACCOUNT_ID=O,exports.buildChannelConfigSchema=Ye,exports.createTypingCallbacks=Qe,exports.emptyPluginConfigSchema=rt,exports.normalizeAccountId=pt,exports.resolveDirectDmAuthorizationOutcome=mr,exports.resolvePreferredOpenClawTmpDir=tt,exports.resolveSenderCommandAuthorizationWithRuntime=hr,exports.stripMarkdown=gt,exports.withFileLock=Dt;
|
|
3
|
+
`),t=t.trim(),t}function _t(e){return Number.isInteger(e)&&e>0}function vt(e){if(process.platform!==`linux`)return!1;try{return u.default.readFileSync(`/proc/${e}/status`,`utf8`).match(/^State:\s+(\S)/m)?.[1]===`Z`}catch{return!1}}function yt(e){if(!_t(e))return!1;try{process.kill(e,0)}catch{return!1}return!vt(e)}function bt(e){let t=process,n=t[e];if(n)return n;let r=new Map;return t[e]=r,r}const A=bt(Symbol.for(`openclaw.fileLockHeldLocks`));function xt(e,t){let n=Math.min(e.maxTimeout,Math.max(e.minTimeout,e.minTimeout*e.factor**t)),r=e.randomize?1+Math.random():1;return Math.min(e.maxTimeout,Math.round(n*r))}async function St(e){try{let t=await f.default.readFile(e,`utf8`),n=JSON.parse(t);return typeof n.pid!=`number`||typeof n.createdAt!=`string`?null:{pid:n.pid,createdAt:n.createdAt}}catch{return null}}async function Ct(e){let t=l.default.resolve(e),n=l.default.dirname(t);await f.default.mkdir(n,{recursive:!0});try{let e=await f.default.realpath(n);return l.default.join(e,l.default.basename(t))}catch{return t}}async function wt(e,t){let n=await St(e);if(n?.pid&&!yt(n.pid))return!0;if(n?.createdAt){let e=Date.parse(n.createdAt);if(!Number.isFinite(e)||Date.now()-e>t)return!0}try{let n=await f.default.stat(e);return Date.now()-n.mtimeMs>t}catch{return!0}}async function Tt(e){let t=A.get(e);t&&(--t.count,!(t.count>0)&&(A.delete(e),await t.handle.close().catch(()=>void 0),await f.default.rm(t.lockPath,{force:!0}).catch(()=>void 0)))}async function Et(e,t){let n=await Ct(e),r=`${n}.lock`,i=A.get(n);if(i)return i.count+=1,{lockPath:r,release:()=>Tt(n)};let a=Math.max(1,t.retries.retries+1);for(let e=0;e<a;e+=1)try{let e=await f.default.open(r,`wx`);return await e.writeFile(JSON.stringify({pid:process.pid,createdAt:new Date().toISOString()},null,2),`utf8`),A.set(n,{count:1,handle:e,lockPath:r}),{lockPath:r,release:()=>Tt(n)}}catch(n){if(n.code!==`EEXIST`)throw n;if(await wt(r,t.stale)){await f.default.rm(r,{force:!0}).catch(()=>void 0);continue}if(e>=a-1)break;await new Promise(n=>setTimeout(n,xt(t.retries,e)))}throw Error(`file lock timeout for ${n}`)}async function Dt(e,t,n){let r=await Et(e,t);try{return await n()}finally{await r.release()}}function Ot(e){let t=e.dmPolicy===`allowlist`?[]:e.storeAllowFrom??[];return[...e.allowFrom??[],...t].map(e=>String(e).trim()).filter(Boolean)}function kt(e){return((Array.isArray(e.groupAllowFrom)&&e.groupAllowFrom.length>0?e.groupAllowFrom:void 0)||(e.fallbackToAllowFrom===!1?[]:e.allowFrom??[])).map(e=>String(e).trim()).filter(Boolean)}const At=new Set([`--dev`,`--no-color`]),jt=new Set([`--profile`,`--log-level`]);function Mt(e){return!e||e===`--`?!1:e.startsWith(`-`)?/^-\d+(?:\.\d+)?$/.test(e):!0}function Nt(e,t){let n=e[t];return n?At.has(n)||n.startsWith(`--profile=`)||n.startsWith(`--log-level=`)?1:jt.has(n)?Mt(e[t+1])?2:1:0:0}function Pt(e,t=2){return Ft(e,t,{skipRootOptions:!0})}function Ft(e,t,n){let r=e.slice(2),i=[];for(let e=0;e<r.length;e+=1){let a=r[e];if(a){if(a===`--`)break;if(n.skipRootOptions){let t=Nt(r,e);if(t>0){e+=t-1;continue}}if(!a.startsWith(`-`)&&(i.push(a),i.length>=t))break}}return i}function j(e){return e?.trim()||void 0}function It(e=process.env,t=d.default.homedir){let n=Lt(e,t);return n?l.default.resolve(n):void 0}function Lt(e,t){let n=j(e.OPENCLAW_HOME);if(n){if(n===`~`||n.startsWith(`~/`)||n.startsWith(`~\\`)){let r=j(e.HOME)??j(e.USERPROFILE)??Rt(t);return r?n.replace(/^~(?=$|[\\/])/,r):void 0}return n}return j(e.HOME)||j(e.USERPROFILE)||Rt(t)}function Rt(e){try{return j(e())}catch{return}}function M(e=process.env,t=d.default.homedir){return It(e,t)??l.default.resolve(process.cwd())}function zt(e,t){if(!e.startsWith(`~`))return e;let n=j(t?.home)??It(t?.env??process.env,t?.homedir??d.default.homedir);return n?e.replace(/^~(?=$|[\\/])/,n):e}function Bt(e=process.env){return e.OPENCLAW_NIX_MODE===`1`}Bt();const Vt=[`.clawdbot`,`.moldbot`,`.moltbot`],N=`.openclaw-qbot.json`,P=[`openclaw.json`,`clawdbot.json`,`moldbot.json`,`moltbot.json`];function Ht(){return M(process.env,d.default.homedir)}function F(e){return()=>M(e,d.default.homedir)}function Ut(e=Ht){return Vt.map(t=>l.default.join(e(),t))}function Wt(e=Ht){return l.default.join(e(),`.qbotclaw`)}function I(e=process.env,t=F(e)){let n=()=>M(e,t),r=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(r)return L(r,e,n);let i=Wt(n);if(e.OPENCLAW_TEST_FAST===`1`)return i;let a=Ut(n);return u.default.existsSync(i)?i:a.find(e=>{try{return u.default.existsSync(e)}catch{return!1}})||i}function L(e,t=process.env,n=F(t)){let r=e.trim();if(!r)return r;if(r.startsWith(`~`)){let e=zt(r,{home:M(t,n),env:t,homedir:n});return l.default.resolve(e)}return l.default.resolve(r)}I();function Gt(e=process.env,t=I(e,F(e))){let n=e.OPENCLAW_CONFIG_PATH?.trim()||e.CLAWDBOT_CONFIG_PATH?.trim();return n?L(n,e,F(e)):l.default.join(t,N)}function Kt(e=process.env,t=F(e)){return e.OPENCLAW_TEST_FAST===`1`?Gt(e,I(e,t)):Jt(e,t).find(e=>{try{return u.default.existsSync(e)}catch{return!1}})||Gt(e,I(e,t))}function qt(e=process.env,t=I(e,F(e)),n=F(e)){let r=e.OPENCLAW_CONFIG_PATH?.trim();if(r)return L(r,e,n);if(e.OPENCLAW_TEST_FAST===`1`)return l.default.join(t,N);let i=e.OPENCLAW_STATE_DIR?.trim(),a=[l.default.join(t,N),...P.map(e=>l.default.join(t,e))].find(e=>{try{return u.default.existsSync(e)}catch{return!1}});if(a)return a;if(i)return l.default.join(t,N);let o=I(e,n);return l.default.resolve(t)===l.default.resolve(o)?Kt(e,n):l.default.join(t,N)}Kt();function Jt(e=process.env,t=F(e)){let n=()=>M(e,t),r=e.OPENCLAW_CONFIG_PATH?.trim()||e.CLAWDBOT_CONFIG_PATH?.trim();if(r)return[L(r,e,n)];let i=[],a=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(a){let t=L(a,e,n);i.push(l.default.join(t,N)),i.push(...P.map(e=>l.default.join(t,e)))}let o=[Wt(n),...Ut(n)];for(let e of o)i.push(l.default.join(e,N)),i.push(...P.map(t=>l.default.join(e,t)));return i}function Yt(e=process.env,t=I(e,F(e))){let n=e.OPENCLAW_OAUTH_DIR?.trim();return n?L(n,e,F(e)):l.default.join(t,`credentials`)}function Xt(){let e=qt();try{if(!u.default.existsSync(e))return;let t=u.default.readFileSync(e,`utf-8`),n=h.default.parse(t)?.logging;return!n||typeof n!=`object`||Array.isArray(n)?void 0:n}catch{return}}const Zt=[`silent`,`fatal`,`error`,`warn`,`info`,`debug`,`trace`];function Qt(e){if(typeof e!=`string`)return;let t=e.trim();return Zt.includes(t)?t:void 0}function $t(e,t=`info`){return Qt(e)??t}function R(e){return{fatal:0,error:1,warn:2,info:3,debug:4,trace:5,silent:1/0}[e]}const z={cachedLogger:null,cachedSettings:null,cachedConsoleSettings:null,overrideSettings:null,invalidEnvLogLevelValue:null,consolePatched:!1,forceConsoleToStderr:!1,consoleTimestampPrefix:!1,consoleSubsystemFilter:null,resolvingConsoleSettings:!1,streamErrorHandlersInstalled:!1,rawConsole:null};function en(){let e=process.env.OPENCLAW_LOG_LEVEL,t=typeof e==`string`?e.trim():``;if(!t){z.invalidEnvLogLevelValue=null;return}let n=Qt(t);if(n)return z.invalidEnvLogLevelValue=null,n;z.invalidEnvLogLevelValue!==t&&(z.invalidEnvLogLevelValue=t,process.stderr.write(`[openclaw] Ignoring invalid OPENCLAW_LOG_LEVEL="${t}" (allowed: ${Zt.join(`|`)}).\n`))}function tn(e){let t=process.getBuiltinModule;if(typeof t!=`function`)return null;try{let n=t(`module`),r=typeof n.createRequire==`function`?n.createRequire:null;return r?r(e):null}catch{return null}}function nn(e){try{return new Intl.DateTimeFormat(`en`,{timeZone:e}),!0}catch{return!1}}function B(e,t){let n=t??process.env.TZ,r=n&&nn(n)?n:Intl.DateTimeFormat().resolvedOptions().timeZone,i=new Intl.DateTimeFormat(`en`,{timeZone:r,year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,hour12:!1,fractionalSecondDigits:3,timeZoneName:`longOffset`}),a=Object.fromEntries(i.formatToParts(e).map(e=>[e.type,e.value])),o=a.timeZoneName??`GMT`,s=o===`GMT`?`+00:00`:o.slice(3);return`${a.year}-${a.month}-${a.day}T${a.hour}:${a.minute}:${a.second}.${a.fractionalSecond}${s}`}const V=tt();l.default.join(V,`qbotclaw.log`);const H=`qbotclaw`,U=`.log`,rn=500*1024*1024,an=tn(require(`url`).pathToFileURL(__filename).href),W=new Set;function on(e=process.argv){let[t,n]=Pt(e,2);return t===`config`&&n===`validate`}function sn(e,t){e.attachTransport(e=>{if(W.has(t))try{t(e)}catch{}})}function cn(e){return process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_FILE_LOG!==`1`&&!e&&!z.overrideSettings}function ln(){let e=en();if(cn(e))return{level:`silent`,file:yn(),maxFileBytes:rn};let t=z.overrideSettings??Xt();if(!t&&!on())try{t=(an?.(`../config/config.js`))?.loadConfig?.().logging}catch{t=void 0}let n=process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_FILE_LOG!==`1`?`silent`:`info`,r=$t(t?.level,n);return{level:e??r,file:t?.file??yn(),maxFileBytes:pn(t?.maxFileBytes)}}function un(e,t){return e?e.level!==t.level||e.file!==t.file||e.maxFileBytes!==t.maxFileBytes:!0}function dn(e){let t=z.cachedSettings??ln();return z.cachedSettings||=t,t.level===`silent`?!1:R(e)<=R(t.level)}function fn(e){let t=new m.Logger({name:`openclaw`,minLevel:R(e.level),type:`hidden`});if(e.level===`silent`){for(let e of W)sn(t,e);return t}u.default.mkdirSync(l.default.dirname(e.file),{recursive:!0}),bn(e.file)&&xn(l.default.dirname(e.file));let n=mn(e.file),r=!1;t.attachTransport(t=>{try{let i=B(t.date??new Date),a=`${JSON.stringify({...t,time:i})}\n`,o=Buffer.byteLength(a,`utf8`),s=n+o;if(s>e.maxFileBytes){if(!r){r=!0;let t=JSON.stringify({time:B(new Date),level:`warn`,subsystem:`logging`,message:`log file size cap reached; suppressing writes file=${e.file} maxFileBytes=${e.maxFileBytes}`});hn(e.file,`${t}\n`),process.stderr.write(`[openclaw] log file size cap reached; suppressing writes file=${e.file} maxFileBytes=${e.maxFileBytes}\n`)}return}hn(e.file,a)&&(n=s)}catch{}});for(let e of W)sn(t,e);return t}function pn(e){return typeof e==`number`&&Number.isFinite(e)&&e>0?Math.floor(e):rn}function mn(e){try{return u.default.statSync(e).size}catch{return 0}}function hn(e,t){try{return u.default.appendFileSync(e,t,{encoding:`utf8`}),!0}catch{return!1}}function gn(){let e=ln(),t=z.cachedLogger,n=z.cachedSettings;return(!t||un(n,e))&&(z.cachedLogger=fn(e),z.cachedSettings=e),z.cachedLogger}function _n(e,t){let n=gn(),r=t?.level?R(t.level):void 0,i=e?JSON.stringify(e):void 0;return n.getSubLogger({name:i,minLevel:r,prefix:e?[i??``]:[]})}function vn(e){return`${e.getFullYear()}-${String(e.getMonth()+1).padStart(2,`0`)}-${String(e.getDate()).padStart(2,`0`)}`}function yn(){let e=vn(new Date);return l.default.join(V,`${H}-${e}${U}`)}function bn(e){let t=l.default.basename(e);return t.startsWith(`${H}-`)&&t.endsWith(U)&&t.length===`${H}-YYYY-MM-DD${U}`.length}function xn(e){try{let t=u.default.readdirSync(e,{withFileTypes:!0}),n=Date.now()-864e5;for(let r of t){if(!r.isFile()||!r.name.startsWith(`${H}-`)||!r.name.endsWith(U))continue;let t=l.default.join(e,r.name);try{u.default.statSync(t).mtimeMs<n&&u.default.rmSync(t,{force:!0})}catch{}}}catch{}}const G={accent:`#FF5A2D`,accentBright:`#FF7A3D`,accentDim:`#D14A22`,info:`#FF8A5B`,success:`#2FBF71`,warn:`#FFB020`,error:`#E23D2D`,muted:`#8B7F77`},Sn=typeof process.env.FORCE_COLOR==`string`&&process.env.FORCE_COLOR.trim().length>0&&process.env.FORCE_COLOR.trim()!==`0`,Cn=process.env.NO_COLOR&&!Sn?new p.Chalk({level:0}):p.default,K=e=>Cn.hex(e),q={accent:K(G.accent),accentBright:K(G.accentBright),accentDim:K(G.accentDim),info:K(G.info),success:K(G.success),warn:K(G.warn),error:K(G.error),muted:K(G.muted),heading:Cn.bold.hex(G.accent),command:K(G.accentBright),option:K(G.warn)};function J(){return!1}q.success,q.warn,q.info,q.error;function wn(e=process.env){return e.VITEST!==`true`||e.OPENCLAW_TEST_RUNTIME_LOG===`1`?!0:typeof console.log.mock==`object`}function Tn(){return{log:(...e)=>{wn()&&console.log(...e)},error:(...e)=>{console.error(...e)}}}({...Tn()}),typeof Intl<`u`&&`Segmenter`in Intl&&new Intl.Segmenter(void 0,{granularity:`grapheme`});const En=tn(require(`url`).pathToFileURL(__filename).href);let Dn=()=>{try{return(En?.(`../config/config.js`))?.loadConfig?.().logging}catch{return}};function On(e){return J()?`debug`:!e&&process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_CONSOLE!==`1`?`silent`:$t(e,`info`)}function kn(e){return e===`compact`||e===`json`||e===`pretty`?e:process.stdout.isTTY?`pretty`:`compact`}function An(){let e=en();if(process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_CONSOLE!==`1`&&!J()&&!e&&!z.overrideSettings)return{level:`silent`,style:kn(void 0)};let t=z.overrideSettings??Xt();if(!t)if(z.resolvingConsoleSettings)t=void 0;else{z.resolvingConsoleSettings=!0;try{t=Dn()}finally{z.resolvingConsoleSettings=!1}}return{level:e??On(t?.consoleLevel),style:kn(t?.consoleStyle)}}function jn(e,t){return e?e.level!==t.level||e.style!==t.style:!0}function Mn(){let e=An(),t=z.cachedConsoleSettings;return(!t||jn(t,e))&&(z.cachedConsoleSettings=e),z.cachedConsoleSettings}function Nn(e){let t=z.consoleSubsystemFilter;return!t||t.length===0?!0:t.some(t=>e===t||e.startsWith(`${t}/`))}function Y(e){let t=new Date;return e===`pretty`?`${String(t.getHours()).padStart(2,`0`)}:${String(t.getMinutes()).padStart(2,`0`)}:${String(t.getSeconds()).padStart(2,`0`)}`:B(t)}function Pn(e,t){return t.level===`silent`?!1:R(e)<=R(t.level)}(()=>{let e=process.getBuiltinModule;if(typeof e!=`function`)return null;try{let t=e(`util`);return typeof t.inspect==`function`?t.inspect:null}catch{return null}})();function Fn(){let e=(process.env.TERM??``).toLowerCase();return process.env.COLORTERM||process.env.TERM_PROGRAM?!0:e.length>0&&e!==`dumb`}function In(){let e=typeof process.env.FORCE_COLOR==`string`&&process.env.FORCE_COLOR.trim().length>0&&process.env.FORCE_COLOR.trim()!==`0`;return process.env.NO_COLOR&&!e?new p.Chalk({level:0}):process.stdout.isTTY||process.stderr.isTTY||Fn()?new p.Chalk({level:1}):new p.Chalk({level:0})}const Ln=[`cyan`,`green`,`yellow`,`blue`,`magenta`,`red`],Rn={"gmail-watcher":`blue`},zn=[`gateway`,`channels`,`providers`],Bn=new Set([`telegram`,`whatsapp`,`discord`,`irc`,`googlechat`,`slack`,`signal`,`imessage`]);function Vn(e,t){let n=Rn[t];if(n)return e[n];let r=0;for(let e=0;e<t.length;e+=1)r=r*31+t.charCodeAt(e)|0;return e[Ln[Math.abs(r)%Ln.length]]}function Hn(e){let t=e.split(`/`).filter(Boolean),n=t.join(`/`)||e;for(;t.length>0&&zn.includes(t[0]);)t.shift();return t.length===0?n:Bn.has(t[0])?t[0]:t.length>2?t.slice(-2).join(`/`):t.join(`/`)}function Un(e,t){if(!t)return e;if(e.startsWith(`[`)){let n=e.indexOf(`]`);if(n>1&&e.slice(1,n).toLowerCase()===t.toLowerCase()){let t=n+1;for(;e[t]===` `;)t+=1;return e.slice(t)}}if(e.slice(0,t.length).toLowerCase()!==t.toLowerCase())return e;let n=e.slice(t.length,t.length+1);if(n!==`:`&&n!==` `)return e;let r=t.length;for(;e[r]===` `;)r+=1;for(e[r]===`:`&&(r+=1);e[r]===` `;)r+=1;return e.slice(r)}function Wn(e){let t=e.style===`json`?e.subsystem:Hn(e.subsystem);if(e.style===`json`)return JSON.stringify({time:Y(`json`),level:e.level,subsystem:t,message:e.message,...e.meta});let n=In(),r=`[${t}]`,i=Vn(n,t),a=e.level===`error`||e.level===`fatal`?n.red:e.level===`warn`?n.yellow:e.level===`debug`||e.level===`trace`?n.gray:n.cyan,o=Un(e.message,t);return`${[e.style===`pretty`?n.gray(Y(`pretty`)):z.consoleTimestampPrefix?n.gray(Y(e.style)):``,i(r)].filter(Boolean).join(` `)} ${a(o)}`}function Gn(e,t){let n=process.platform===`win32`&&process.env.GITHUB_ACTIONS===`true`?t.replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g,`?`).replace(/[\uD800-\uDFFF]/g,`?`):t,r=z.rawConsole??console;z.forceConsoleToStderr||e===`error`||e===`fatal`?(r.error??console.error)(n):e===`warn`?(r.warn??console.warn)(n):(r.log??console.log)(n)}function Kn(e){return J()||e.level===`error`||e.level===`fatal`||!(e.subsystem===`agent/embedded`||e.subsystem.startsWith(`agent/embedded/`)||e.subsystem===`model-fallback`||e.subsystem.startsWith(`model-fallback/`))?!1:(typeof e.meta?.runId==`string`?e.meta.runId:typeof e.meta?.sessionId==`string`?e.meta.sessionId:void 0)?.startsWith(`probe-`)?!0:/(sessionId|runId)=probe-/.test(e.message)}function qn(e,t,n,r){if(t===`silent`)return;let i=e[t];typeof i==`function`&&(r&&Object.keys(r).length>0?i.call(e,r,n):i.call(e,n))}function Jn(e){let t=null,n=()=>(t||=_n({subsystem:e}),t),r=(t,r,i)=>{let a=Mn(),o=Pn(t,{level:a.level})&&Nn(e),s=dn(t);if(!o&&!s)return;let c,l=i;if(i&&Object.keys(i).length>0){let{consoleMessage:e,...t}=i;typeof e==`string`&&(c=e),l=Object.keys(t).length>0?t:void 0}if(s&&qn(n(),t,r,l),!o)return;let u=c??r;Kn({level:t,subsystem:e,message:u,meta:l})||Gn(t,Wn({level:t,subsystem:e,message:a.style===`json`?r:u,style:a.style,meta:l}))},i=t=>Pn(t,{level:Mn().level})&&Nn(e),a=e=>dn(e);return{subsystem:e,isEnabled:(e,t=`any`)=>t===`console`?i(e):t===`file`?a(e):i(e)||a(e),trace:(e,t)=>r(`trace`,e,t),debug:(e,t)=>r(`debug`,e,t),info:(e,t)=>r(`info`,e,t),warn:(e,t)=>r(`warn`,e,t),error:(e,t)=>r(`error`,e,t),fatal:(e,t)=>r(`fatal`,e,t),raw:t=>{if(a(`info`)&&qn(n(),`info`,t,{raw:!0}),i(`info`)){if(Kn({level:`info`,subsystem:e,message:t}))return;Gn(`info`,t)}},child:t=>Jn(`${e}/${t}`)}}const Yn=globalThis;Yn.__openclaw_internal_hook_handlers__??=new Map;function Xn(e){if(!e)return``;let t=e.trim();if(!t)return t;if(t.startsWith(`~`)){let e=zt(t,{home:M(process.env,d.default.homedir),env:process.env,homedir:d.default.homedir});return l.default.resolve(e)}return l.default.resolve(t)}function Zn(e=process.env,t=d.default.homedir){let n=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(n)return Xn(n);let r=l.default.join(M(e,t),`.qbotclaw`);try{if(u.default.existsSync(r))return r}catch{}return r}Zn();function Qn(){return{plugins:[],tools:[],hooks:[],typedHooks:[],channels:[],providers:[],gatewayHandlers:{},httpRoutes:[],cliRegistrars:[],services:[],commands:[],diagnostics:[]}}const X=Symbol.for(`openclaw.pluginRegistryState`);(()=>{let e=globalThis;return e[X]||(e[X]={registry:Qn(),key:null,version:0}),e[X]})();function Z(e,t){function n(t){let n=t.channels?.[e],r=mt(typeof n?.defaultAccount==`string`?n.defaultAccount:void 0);if(r&&i(t).some(e=>pt(e)===r))return r}function r(n){let r=n.channels?.[e]?.accounts;if(!r||typeof r!=`object`)return[];let i=Object.keys(r).filter(Boolean),a=t?.normalizeAccountId;return a?[...new Set(i.map(e=>a(e)).filter(Boolean))]:i}function i(e){let t=r(e);return t.length===0?[O]:t.toSorted((e,t)=>e.localeCompare(t))}function a(e){let t=n(e);if(t)return t;let r=i(e);return r.includes(`default`)?O:r[0]??`default`}return{listConfiguredAccountIds:r,listAccountIds:i,resolveDefaultAccountId:a}}const{listAccountIds:$n,resolveDefaultAccountId:er}=Z(`discord`),{listAccountIds:tr,resolveDefaultAccountId:nr}=Z(`imessage`);function Q(e){return(e??[]).map(e=>String(e).trim()).filter(Boolean)}function rr(){return l.default.join(Yt(),`whatsapp`,O)}rr();const{listConfiguredAccountIds:ir,listAccountIds:ar,resolveDefaultAccountId:or}=Z(`whatsapp`),{listAccountIds:sr,resolveDefaultAccountId:cr}=Z(`slack`);Object.freeze({allowFinalSymlinkForUnlink:!1,allowFinalHardlinkForUnlink:!1}),Object.freeze({allowFinalSymlinkForUnlink:!0,allowFinalHardlinkForUnlink:!0}),l.default.resolve(l.default.dirname((0,g.fileURLToPath)(require(`url`).pathToFileURL(__filename).href)),`../../docs/reference/templates`);function lr(e=process.env,t=d.default.homedir){let n=Zn(e,t),r=e.OPENCLAW_PROFILE?.trim();return r&&r.toLowerCase()!==`default`?l.default.join(n,`workspace-${r}`):l.default.join(n,`workspace`)}lr();function ur(e){if(e.groupPolicy===`disabled`)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`disabled`};if(e.groupPolicy===`allowlist`){if(e.requireMatchInput&&!e.hasMatchInput)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`missing_match_input`};if(!e.allowlistConfigured)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`empty_allowlist`};if(!e.allowlistMatched)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`not_allowlisted`}}return{allowed:!0,groupPolicy:e.groupPolicy,reason:`allowed`}}function dr(e){let t=Array.isArray(e.allowFrom)?e.allowFrom:void 0,n=Array.isArray(e.groupAllowFrom)?e.groupAllowFrom:void 0;return{effectiveAllowFrom:Q(Ot({allowFrom:t,storeAllowFrom:Array.isArray(e.storeAllowFrom)?e.storeAllowFrom:void 0,dmPolicy:e.dmPolicy??void 0})),effectiveGroupAllowFrom:Q(kt({allowFrom:t,groupAllowFrom:n,fallbackToAllowFrom:e.groupAllowFromFallbackToAllowFrom??void 0}))}}const $={GROUP_POLICY_ALLOWED:`group_policy_allowed`,GROUP_POLICY_DISABLED:`group_policy_disabled`,GROUP_POLICY_EMPTY_ALLOWLIST:`group_policy_empty_allowlist`,GROUP_POLICY_NOT_ALLOWLISTED:`group_policy_not_allowlisted`,DM_POLICY_OPEN:`dm_policy_open`,DM_POLICY_DISABLED:`dm_policy_disabled`,DM_POLICY_ALLOWLISTED:`dm_policy_allowlisted`,DM_POLICY_PAIRING_REQUIRED:`dm_policy_pairing_required`,DM_POLICY_NOT_ALLOWLISTED:`dm_policy_not_allowlisted`};function fr(e){let t=e.dmPolicy??`pairing`,n=e.groupPolicy===`open`||e.groupPolicy===`disabled`?e.groupPolicy:`allowlist`,r=Q(e.effectiveAllowFrom),i=Q(e.effectiveGroupAllowFrom);if(e.isGroup){let t=ur({groupPolicy:n,allowlistConfigured:i.length>0,allowlistMatched:e.isSenderAllowed(i)});if(!t.allowed){if(t.reason===`disabled`)return{decision:`block`,reasonCode:$.GROUP_POLICY_DISABLED,reason:`groupPolicy=disabled`};if(t.reason===`empty_allowlist`)return{decision:`block`,reasonCode:$.GROUP_POLICY_EMPTY_ALLOWLIST,reason:`groupPolicy=allowlist (empty allowlist)`};if(t.reason===`not_allowlisted`)return{decision:`block`,reasonCode:$.GROUP_POLICY_NOT_ALLOWLISTED,reason:`groupPolicy=allowlist (not allowlisted)`}}return{decision:`allow`,reasonCode:$.GROUP_POLICY_ALLOWED,reason:`groupPolicy=${n}`}}return t===`disabled`?{decision:`block`,reasonCode:$.DM_POLICY_DISABLED,reason:`dmPolicy=disabled`}:t===`open`?{decision:`allow`,reasonCode:$.DM_POLICY_OPEN,reason:`dmPolicy=open`}:e.isSenderAllowed(r)?{decision:`allow`,reasonCode:$.DM_POLICY_ALLOWLISTED,reason:`dmPolicy=${t} (allowlisted)`}:t===`pairing`?{decision:`pairing`,reasonCode:$.DM_POLICY_PAIRING_REQUIRED,reason:`dmPolicy=pairing (not allowlisted)`}:{decision:`block`,reasonCode:$.DM_POLICY_NOT_ALLOWLISTED,reason:`dmPolicy=${t} (not allowlisted)`}}function pr(e){let{effectiveAllowFrom:t,effectiveGroupAllowFrom:n}=dr({allowFrom:e.allowFrom,groupAllowFrom:e.groupAllowFrom,storeAllowFrom:e.storeAllowFrom,dmPolicy:e.dmPolicy,groupAllowFromFallbackToAllowFrom:e.groupAllowFromFallbackToAllowFrom});return{...fr({isGroup:e.isGroup,dmPolicy:e.dmPolicy,groupPolicy:e.groupPolicy,effectiveAllowFrom:t,effectiveGroupAllowFrom:n,isSenderAllowed:e.isSenderAllowed}),effectiveAllowFrom:t,effectiveGroupAllowFrom:n}}function mr(e){return e.isGroup?`allowed`:e.dmPolicy===`disabled`?`disabled`:e.dmPolicy!==`open`&&!e.senderAllowedForCommands?`unauthorized`:`allowed`}async function hr(e){return gr({...e,shouldComputeCommandAuthorized:e.runtime.shouldComputeCommandAuthorized,resolveCommandAuthorizedFromAuthorizers:e.runtime.resolveCommandAuthorizedFromAuthorizers})}async function gr(e){let t=e.shouldComputeCommandAuthorized(e.rawBody,e.cfg),n=!e.isGroup&&e.dmPolicy!==`allowlist`&&(e.dmPolicy!==`open`||t)?await e.readAllowFromStore().catch(()=>[]):[],r=pr({isGroup:e.isGroup,dmPolicy:e.dmPolicy,groupPolicy:`allowlist`,allowFrom:e.configuredAllowFrom,groupAllowFrom:e.configuredGroupAllowFrom??[],storeAllowFrom:n,isSenderAllowed:t=>e.isSenderAllowed(e.senderId,t)}),i=r.effectiveAllowFrom,a=r.effectiveGroupAllowFrom,o=e.cfg.commands?.useAccessGroups!==!1,s=e.isSenderAllowed(e.senderId,e.isGroup?a:i),c=e.isSenderAllowed(e.senderId,i),l=e.isSenderAllowed(e.senderId,a);return{shouldComputeAuth:t,effectiveAllowFrom:i,effectiveGroupAllowFrom:a,senderAllowedForCommands:s,commandAuthorized:t?e.resolveCommandAuthorizedFromAuthorizers({useAccessGroups:o,authorizers:[{configured:i.length>0,allowed:c},{configured:a.length>0,allowed:l}]}):void 0}}exports.DEFAULT_ACCOUNT_ID=O,exports.buildChannelConfigSchema=Ye,exports.createTypingCallbacks=Qe,exports.emptyPluginConfigSchema=rt,exports.normalizeAccountId=pt,exports.resolveDirectDmAuthorizationOutcome=mr,exports.resolvePreferredOpenClawTmpDir=tt,exports.resolveSenderCommandAuthorizationWithRuntime=hr,exports.stripMarkdown=gt,exports.withFileLock=Dt;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import{z as e}from"zod";import t from"node:path";import n from"node:fs";import r from"node:os";import i from"node:fs/promises";import a,{Chalk as o}from"chalk";import{Logger as s}from"tslog";import c from"json5";import{fileURLToPath as l}from"node:url";const u=/[;&|`$<>]/,d=/[\r\n]/,f=/["']/,p=/^[A-Za-z0-9._+-]+$/;function m(e){return e.startsWith(`.`)||e.startsWith(`~`)||e.includes(`/`)||e.includes(`\\`)?!0:/^[A-Za-z]:[\\/]/.test(e)}function h(e){if(!e)return!1;let t=e.trim();return!t||t.includes(`\0`)||d.test(t)||u.test(t)||f.test(t)?!1:m(t)?!0:t.startsWith(`-`)?!1:p.test(t)}const g=/^(?:[^~]|~0|~1)*$/,_=/^[A-Za-z0-9][A-Za-z0-9._:/-]{0,255}$/;function v(e){return e===`value`?!0:e.startsWith(`/`)?e.slice(1).split(`/`).every(e=>g.test(e)):!1}function ee(e){if(!_.test(e))return{ok:!1,reason:`pattern`};for(let t of e.split(`/`))if(t===`.`||t===`..`)return{ok:!1,reason:`traversal-segment`};return{ok:!0}}function te(e){return ee(e).ok}function ne(){return[`Exec secret reference id must match /^[A-Za-z0-9][A-Za-z0-9._:/-]{0,255}$/`,`and must not include "." or ".." path segments`,`(example: "vault/openai/api-key").`].join(` `)}const re=[`openai-completions`,`openai-responses`,`openai-codex-responses`,`anthropic-messages`,`google-generative-ai`,`github-copilot`,`bedrock-converse-stream`,`ollama`],ie=e.union([e.literal(`allow`),e.literal(`deny`)]),ae=e.union([e.literal(`direct`),e.literal(`group`),e.literal(`channel`),e.literal(`dm`)]).optional();function oe(){return e.object({default:ie.optional(),rules:e.array(e.object({action:ie,match:e.object({channel:e.string().optional(),chatType:ae,keyPrefix:e.string().optional(),rawKeyPrefix:e.string().optional()}).strict().optional()}).strict()).optional()}).strict().optional()}const y=e.registry(),b=/^[A-Z][A-Z0-9_]{0,127}$/,x=/^[a-z][a-z0-9_-]{0,63}$/,se=/^[A-Za-z]:[\\/]/,ce=/^\\\\[^\\]+\\[^\\]+/;function le(e){return t.isAbsolute(e)||se.test(e)||ce.test(e)}const ue=e.object({source:e.literal(`env`),provider:e.string().regex(x,`Secret reference provider must match /^[a-z][a-z0-9_-]{0,63}$/ (example: "default").`),id:e.string().regex(b,`Env secret reference id must match /^[A-Z][A-Z0-9_]{0,127}$/ (example: "OPENAI_API_KEY").`)}).strict(),de=e.object({source:e.literal(`file`),provider:e.string().regex(x,`Secret reference provider must match /^[a-z][a-z0-9_-]{0,63}$/ (example: "default").`),id:e.string().refine(v,`File secret reference id must be an absolute JSON pointer (example: "/providers/openai/apiKey"), or "value" for singleValue mode.`)}).strict(),fe=e.object({source:e.literal(`exec`),provider:e.string().regex(x,`Secret reference provider must match /^[a-z][a-z0-9_-]{0,63}$/ (example: "default").`),id:e.string().refine(te,ne())}).strict(),pe=e.discriminatedUnion(`source`,[ue,de,fe]),S=e.union([e.string(),pe]),me=e.object({source:e.literal(`env`),allowlist:e.array(e.string().regex(b)).max(256).optional()}).strict(),he=e.object({source:e.literal(`file`),path:e.string().min(1),mode:e.union([e.literal(`singleValue`),e.literal(`json`)]).optional(),timeoutMs:e.number().int().positive().max(12e4).optional(),maxBytes:e.number().int().positive().max(20*1024*1024).optional()}).strict(),ge=e.object({source:e.literal(`exec`),command:e.string().min(1).refine(e=>h(e),`secrets.providers.*.command is unsafe.`).refine(e=>le(e),`secrets.providers.*.command must be an absolute path.`),args:e.array(e.string().max(1024)).max(128).optional(),timeoutMs:e.number().int().positive().max(12e4).optional(),noOutputTimeoutMs:e.number().int().positive().max(12e4).optional(),maxOutputBytes:e.number().int().positive().max(20*1024*1024).optional(),jsonOnly:e.boolean().optional(),env:e.record(e.string(),e.string()).optional(),passEnv:e.array(e.string().regex(b)).max(128).optional(),trustedDirs:e.array(e.string().min(1).refine(e=>le(e),`trustedDirs entries must be absolute paths.`)).max(64).optional(),allowInsecurePath:e.boolean().optional(),allowSymlinkCommand:e.boolean().optional()}).strict(),_e=e.discriminatedUnion(`source`,[me,he,ge]);e.object({providers:e.object({}).catchall(_e).optional(),defaults:e.object({env:e.string().regex(x).optional(),file:e.string().regex(x).optional(),exec:e.string().regex(x).optional()}).strict().optional(),resolution:e.object({maxProviderConcurrency:e.number().int().positive().max(16).optional(),maxRefsPerProvider:e.number().int().positive().max(4096).optional(),maxBatchBytes:e.number().int().positive().max(5*1024*1024).optional()}).strict().optional()}).strict().optional();const ve=e.enum(re),ye=e.object({supportsStore:e.boolean().optional(),supportsDeveloperRole:e.boolean().optional(),supportsReasoningEffort:e.boolean().optional(),supportsUsageInStreaming:e.boolean().optional(),supportsTools:e.boolean().optional(),supportsStrictMode:e.boolean().optional(),maxTokensField:e.union([e.literal(`max_completion_tokens`),e.literal(`max_tokens`)]).optional(),thinkingFormat:e.union([e.literal(`openai`),e.literal(`zai`),e.literal(`qwen`)]).optional(),requiresToolResultName:e.boolean().optional(),requiresAssistantAfterToolResult:e.boolean().optional(),requiresThinkingAsText:e.boolean().optional(),requiresMistralToolIds:e.boolean().optional(),requiresOpenAiAnthropicToolPayload:e.boolean().optional()}).strict().optional(),be=e.object({id:e.string().min(1),name:e.string().min(1),api:ve.optional(),reasoning:e.boolean().optional(),input:e.array(e.union([e.literal(`text`),e.literal(`image`)])).optional(),cost:e.object({input:e.number().optional(),output:e.number().optional(),cacheRead:e.number().optional(),cacheWrite:e.number().optional()}).strict().optional(),contextWindow:e.number().positive().optional(),maxTokens:e.number().positive().optional(),headers:e.record(e.string(),e.string()).optional(),compat:ye}).strict(),xe=e.object({baseUrl:e.string().min(1),apiKey:S.optional().register(y),auth:e.union([e.literal(`api-key`),e.literal(`aws-sdk`),e.literal(`oauth`),e.literal(`token`)]).optional(),api:ve.optional(),injectNumCtxForOpenAICompat:e.boolean().optional(),headers:e.record(e.string(),S.register(y)).optional(),authHeader:e.boolean().optional(),models:e.array(be)}).strict(),Se=e.object({enabled:e.boolean().optional(),region:e.string().optional(),providerFilter:e.array(e.string()).optional(),refreshInterval:e.number().int().nonnegative().optional(),defaultContextWindow:e.number().int().positive().optional(),defaultMaxTokens:e.number().int().positive().optional()}).strict().optional();e.object({mode:e.union([e.literal(`merge`),e.literal(`replace`)]).optional(),providers:e.record(e.string(),xe).optional(),bedrockDiscovery:Se}).strict().optional(),e.object({mentionPatterns:e.array(e.string()).optional(),historyLimit:e.number().int().positive().optional()}).strict().optional();const Ce=e.object({historyLimit:e.number().int().min(0).optional()}).strict();e.object({name:e.string().optional(),theme:e.string().optional(),emoji:e.string().optional(),avatar:e.string().optional()}).strict().optional();const C=e.union([e.literal(`steer`),e.literal(`followup`),e.literal(`collect`),e.literal(`steer-backlog`),e.literal(`steer+backlog`),e.literal(`queue`),e.literal(`interrupt`)]),we=e.union([e.literal(`old`),e.literal(`new`),e.literal(`summarize`)]);e.union([e.literal(`off`),e.literal(`first`),e.literal(`all`)]),e.union([e.literal(`never`),e.literal(`instant`),e.literal(`thinking`),e.literal(`message`)]),e.enum([`open`,`disabled`,`allowlist`]),e.enum([`pairing`,`allowlist`,`open`,`disabled`]);const Te=e.object({minChars:e.number().int().positive().optional(),maxChars:e.number().int().positive().optional(),idleMs:e.number().int().nonnegative().optional()}).strict();e.number().int().min(0).optional(),e.number().int().min(0).optional(),e.record(e.string(),Ce.optional()).optional(),e.number().int().positive().optional(),e.enum([`length`,`newline`]).optional(),e.boolean().optional(),Te.optional(),e.string().optional(),e.number().positive().optional(),e.object({minChars:e.number().int().positive().optional(),maxChars:e.number().int().positive().optional(),breakPreference:e.union([e.literal(`paragraph`),e.literal(`newline`),e.literal(`sentence`)]).optional()}).strict();const Ee=e.enum([`off`,`bullets`,`code`]);e.object({tables:Ee.optional()}).strict().optional();const De=e.enum([`elevenlabs`,`openai`,`edge`]),Oe=e.enum([`final`,`all`]),ke=e.enum([`off`,`always`,`inbound`,`tagged`]);e.object({auto:ke.optional(),enabled:e.boolean().optional(),mode:Oe.optional(),provider:De.optional(),summaryModel:e.string().optional(),modelOverrides:e.object({enabled:e.boolean().optional(),allowText:e.boolean().optional(),allowProvider:e.boolean().optional(),allowVoice:e.boolean().optional(),allowModelId:e.boolean().optional(),allowVoiceSettings:e.boolean().optional(),allowNormalization:e.boolean().optional(),allowSeed:e.boolean().optional()}).strict().optional(),elevenlabs:e.object({apiKey:S.optional().register(y),baseUrl:e.string().optional(),voiceId:e.string().optional(),modelId:e.string().optional(),seed:e.number().int().min(0).max(4294967295).optional(),applyTextNormalization:e.enum([`auto`,`on`,`off`]).optional(),languageCode:e.string().optional(),voiceSettings:e.object({stability:e.number().min(0).max(1).optional(),similarityBoost:e.number().min(0).max(1).optional(),style:e.number().min(0).max(1).optional(),useSpeakerBoost:e.boolean().optional(),speed:e.number().min(.5).max(2).optional()}).strict().optional()}).strict().optional(),openai:e.object({apiKey:S.optional().register(y),baseUrl:e.string().optional(),model:e.string().optional(),voice:e.string().optional(),speed:e.number().min(.25).max(4).optional(),instructions:e.string().optional()}).strict().optional(),edge:e.object({enabled:e.boolean().optional(),voice:e.string().optional(),lang:e.string().optional(),outputFormat:e.string().optional(),pitch:e.string().optional(),rate:e.string().optional(),volume:e.string().optional(),saveSubtitles:e.boolean().optional(),proxy:e.string().optional(),timeoutMs:e.number().int().min(1e3).max(12e4).optional()}).strict().optional(),prefsPath:e.string().optional(),maxTextLength:e.number().int().min(1).optional(),timeoutMs:e.number().int().min(1e3).max(12e4).optional()}).strict().optional(),e.object({mode:e.union([e.literal(`off`),e.literal(`natural`),e.literal(`custom`)]).optional(),minMs:e.number().int().nonnegative().optional(),maxMs:e.number().int().nonnegative().optional()}).strict();const Ae=e.object({noOutputTimeoutMs:e.number().int().min(1e3).optional(),noOutputTimeoutRatio:e.number().min(.05).max(.95).optional(),minMs:e.number().int().min(1e3).optional(),maxMs:e.number().int().min(1e3).optional()}).strict().optional();e.object({command:e.string(),args:e.array(e.string()).optional(),output:e.union([e.literal(`json`),e.literal(`text`),e.literal(`jsonl`)]).optional(),resumeOutput:e.union([e.literal(`json`),e.literal(`text`),e.literal(`jsonl`)]).optional(),input:e.union([e.literal(`arg`),e.literal(`stdin`)]).optional(),maxPromptArgChars:e.number().int().positive().optional(),env:e.record(e.string(),e.string()).optional(),clearEnv:e.array(e.string()).optional(),modelArg:e.string().optional(),modelAliases:e.record(e.string(),e.string()).optional(),sessionArg:e.string().optional(),sessionArgs:e.array(e.string()).optional(),resumeArgs:e.array(e.string()).optional(),sessionMode:e.union([e.literal(`always`),e.literal(`existing`),e.literal(`none`)]).optional(),sessionIdFields:e.array(e.string()).optional(),systemPromptArg:e.string().optional(),systemPromptMode:e.union([e.literal(`append`),e.literal(`replace`)]).optional(),systemPromptWhen:e.union([e.literal(`first`),e.literal(`always`),e.literal(`never`)]).optional(),imageArg:e.string().optional(),imageMode:e.union([e.literal(`repeat`),e.literal(`list`)]).optional(),serialize:e.boolean().optional(),reliability:e.object({watchdog:e.object({fresh:Ae,resume:Ae}).strict().optional()}).strict().optional()}).strict(),e.enum([`thread`,`top-level`]),e.object({attempts:e.number().int().min(1).optional(),minDelayMs:e.number().int().min(0).optional(),maxDelayMs:e.number().int().min(0).optional(),jitter:e.number().min(0).max(1).optional()}).strict().optional();const je=e.object({whatsapp:C.optional(),telegram:C.optional(),discord:C.optional(),irc:C.optional(),slack:C.optional(),mattermost:C.optional(),signal:C.optional(),imessage:C.optional(),msteams:C.optional(),webchat:C.optional()}).strict().optional(),Me=e.record(e.string(),e.number().int().nonnegative()).optional();e.object({mode:C.optional(),byChannel:je,debounceMs:e.number().int().nonnegative().optional(),debounceMsByChannel:Me,cap:e.number().int().positive().optional(),drop:we.optional()}).strict().optional(),e.object({debounceMs:e.number().int().nonnegative().optional(),byChannel:Me}).strict().optional(),e.object({command:e.array(e.string()).superRefine((t,n)=>{let r=t[0];h(r)||n.addIssue({code:e.ZodIssueCode.custom,path:[0],message:`expected safe executable name or path`})}),timeoutSeconds:e.number().int().positive().optional()}).strict().optional(),e.string().regex(/^#?[0-9a-fA-F]{6}$/,`expected hex color (RRGGBB)`),e.string().refine(h,`expected safe executable name or path`);const Ne=oe(),Pe=e.array(e.union([e.literal(`image`),e.literal(`audio`),e.literal(`video`)])).optional(),Fe=e.object({mode:e.union([e.literal(`first`),e.literal(`all`)]).optional(),maxAttachments:e.number().int().positive().optional(),prefer:e.union([e.literal(`first`),e.literal(`last`),e.literal(`path`),e.literal(`url`)]).optional()}).strict().optional(),Ie=e.object({detectLanguage:e.boolean().optional(),punctuate:e.boolean().optional(),smartFormat:e.boolean().optional()}).strict().optional(),Le=e.union([e.string(),e.number(),e.boolean()]),Re=e.record(e.string(),e.record(e.string(),Le)).optional(),ze={prompt:e.string().optional(),timeoutSeconds:e.number().int().positive().optional(),language:e.string().optional(),providerOptions:Re,deepgram:Ie,baseUrl:e.string().optional(),headers:e.record(e.string(),e.string()).optional()},Be=e.object({provider:e.string().optional(),model:e.string().optional(),capabilities:Pe,type:e.union([e.literal(`provider`),e.literal(`cli`)]).optional(),command:e.string().optional(),args:e.array(e.string()).optional(),maxChars:e.number().int().positive().optional(),maxBytes:e.number().int().positive().optional(),...ze,profile:e.string().optional(),preferredProfile:e.string().optional()}).strict().optional(),w=e.object({enabled:e.boolean().optional(),scope:Ne,maxBytes:e.number().int().positive().optional(),maxChars:e.number().int().positive().optional(),...ze,attachments:Fe,models:e.array(Be).optional(),echoTranscript:e.boolean().optional(),echoFormat:e.string().optional()}).strict().optional();e.object({models:e.array(Be).optional(),concurrency:e.number().int().positive().optional(),image:w.optional(),audio:w.optional(),video:w.optional()}).strict().optional();const Ve=e.object({type:e.literal(`cli`).optional(),command:e.string().min(1),args:e.array(e.string()).optional(),timeoutSeconds:e.number().int().positive().optional()}).strict();e.object({enabled:e.boolean().optional(),scope:Ne,maxLinks:e.number().int().positive().optional(),timeoutSeconds:e.number().int().positive().optional(),models:e.array(Ve).optional()}).strict().optional();const T=e.union([e.boolean(),e.literal(`auto`)]);e.object({native:T.optional(),nativeSkills:T.optional()}).strict().optional();const He=e.union([e.string(),e.number()]);e.array(He).optional();function Ue(e){let t=e;return typeof t.toJSONSchema==`function`?{schema:t.toJSONSchema({target:`draft-07`,unrepresentable:`any`})}:{schema:{type:`object`,additionalProperties:!0}}}function We(e){let t,n=!1,r=async()=>{if(!n){n=!0;try{await e.onTick()}finally{n=!1}}};return{tick:r,start:()=>{e.intervalMs<=0||t||(t=setInterval(()=>{r()},e.intervalMs))},stop:()=>{t&&(clearInterval(t),t=void 0,n=!1)},isRunning:()=>t!==void 0}}function Ge(e){let t=typeof e.maxConsecutiveFailures==`number`&&e.maxConsecutiveFailures>0?Math.floor(e.maxConsecutiveFailures):void 0,n=0,r=!1,i=()=>e.isSealed()||r?!0:e.shouldBlock?.()===!0;return{run:async a=>{if(i())return`skipped`;try{return await a(),n=0,`started`}catch(i){if(n+=1,e.onStartError?.(i),e.rethrowOnError)throw i;return t&&n>=t?(r=!0,e.onTrip?.(),`tripped`):`failed`}},reset:()=>{n=0,r=!1},isTripped:()=>r}}function Ke(e){let t=e.stop,n=e.keepaliveIntervalMs??3e3,r=Math.max(1,e.maxConsecutiveFailures??2),i=e.maxDurationMs??6e4,a=!1,o=!1,s,c=Ge({isSealed:()=>o,onStartError:e.onStartError,maxConsecutiveFailures:r,onTrip:()=>{u.stop()}}),l=async()=>{await c.run(()=>e.start())},u=We({intervalMs:n,onTick:l}),d=()=>{i<=0||(f(),s=setTimeout(()=>{o||(console.warn(`[typing] TTL exceeded (${i}ms), auto-stopping typing indicator`),m())},i))},f=()=>{s&&=(clearTimeout(s),void 0)},p=async()=>{o||(a=!1,c.reset(),u.stop(),f(),await l(),!c.isTripped()&&(u.start(),d()))},m=()=>{o=!0,u.stop(),f(),!(!t||a)&&(a=!0,t().catch(t=>(e.onStopError??e.onStartError)(t)))};return{onReplyStart:p,onIdle:m,onCleanup:m}}const E=`/tmp/qbotclaw`,qe=n.constants.W_OK|n.constants.X_OK;function Je(e,t){return typeof e==`object`&&!!e&&`code`in e&&e.code===t}function Ye(e={}){let i=e.accessSync??n.accessSync,a=e.chmodSync??n.chmodSync,o=e.lstatSync??n.lstatSync,s=e.mkdirSync??n.mkdirSync,c=e.warn??(e=>console.warn(e)),l=e.getuid??(()=>{try{return typeof process.getuid==`function`?process.getuid():void 0}catch{return}}),u=e.tmpdir??r.tmpdir,d=l(),f=e=>d===void 0?!0:!(typeof e.uid==`number`&&e.uid!==d||typeof e.mode==`number`&&e.mode&18),p=()=>{let e=u(),n=d===void 0?`qbotclaw`:`qbotclaw-${d}`;return t.join(e,n)},m=e=>e.isDirectory()&&!e.isSymbolicLink()&&f(e),h=e=>{try{return m(o(e))?(i(e,qe),`available`):`invalid`}catch(e){return Je(e,`ENOENT`)?`missing`:`invalid`}},g=e=>{try{let t=o(e);return!t.isDirectory()||t.isSymbolicLink()||d!==void 0&&typeof t.uid==`number`&&t.uid!==d||typeof t.mode!=`number`||!(t.mode&18)?!1:(a(e,448),c(`[openclaw] tightened permissions on temp dir: ${e}`),h(e)===`available`)}catch{return!1}},_=()=>{let e=p(),t=h(e);if(t===`available`)return e;if(t===`invalid`){if(g(e))return e;throw Error(`Unsafe fallback OpenClaw temp dir: ${e}`)}try{s(e,{recursive:!0,mode:448}),a(e,448)}catch{throw Error(`Unable to create fallback OpenClaw temp dir: ${e}`)}if(h(e)!==`available`&&!g(e))throw Error(`Unsafe fallback OpenClaw temp dir: ${e}`);return e},v=h(E);if(v===`available`)return E;if(v===`invalid`)return g(`/tmp/qbotclaw`)?E:_();try{return i(`/tmp`,qe),s(E,{recursive:!0,mode:448}),a(E,448),h(`/tmp/qbotclaw`)!==`available`&&!g(`/tmp/qbotclaw`)?_():E}catch{return _()}}function Xe(e){return{success:!1,error:{issues:[{path:[],message:e}]}}}function Ze(){return{safeParse(e){return e===void 0?{success:!0,data:void 0}:!e||typeof e!=`object`||Array.isArray(e)?Xe(`expected config object`):Object.keys(e).length>0?Xe(`config must be empty`):{success:!0,data:e}},jsonSchema:{type:`object`,additionalProperties:!1,properties:{}}}}const Qe=new Set([`__proto__`,`prototype`,`constructor`]);function $e(e){return Qe.has(e)}const D=`default`,et=/^[a-z0-9][a-z0-9_-]{0,63}$/i,tt=/[^a-z0-9_-]+/g,nt=/^-+/,rt=/-+$/,it=new Map,O=new Map;function at(e){return et.test(e)?e.toLowerCase():e.toLowerCase().replace(tt,`-`).replace(nt,``).replace(rt,``).slice(0,64)}function ot(e){let t=at(e);if(!(!t||$e(t)))return t}function st(e){let t=(e??``).trim();if(!t)return D;let n=it.get(t);if(n)return n;let r=ot(t)||`default`;return lt(it,t,r),r}function ct(e){let t=(e??``).trim();if(!t)return;if(O.has(t))return O.get(t);let n=ot(t)||void 0;return lt(O,t,n),n}function lt(e,t,n){if(e.set(t,n),e.size<=512)return;let r=e.keys().next();r.done||e.delete(r.value)}function ut(e){let t=e;return t=t.replace(/\*\*(.+?)\*\*/g,`$1`),t=t.replace(/__(.+?)__/g,`$1`),t=t.replace(/(?<!\*)\*(?!\*)(.+?)(?<!\*)\*(?!\*)/g,`$1`),t=t.replace(/(?<!_)_(?!_)(.+?)(?<!_)_(?!_)/g,`$1`),t=t.replace(/~~(.+?)~~/g,`$1`),t=t.replace(/^#{1,6}\s+(.+)$/gm,`$1`),t=t.replace(/^>\s?(.*)$/gm,`$1`),t=t.replace(/^[-*_]{3,}$/gm,``),t=t.replace(/`([^`]+)`/g,`$1`),t=t.replace(/\n{3,}/g,`
|
|
2
2
|
|
|
3
|
-
`),t=t.trim(),t}function dt(e){return Number.isInteger(e)&&e>0}function ft(e){if(process.platform!==`linux`)return!1;try{return n.readFileSync(`/proc/${e}/status`,`utf8`).match(/^State:\s+(\S)/m)?.[1]===`Z`}catch{return!1}}function pt(e){if(!dt(e))return!1;try{process.kill(e,0)}catch{return!1}return!ft(e)}function mt(e){let t=process,n=t[e];if(n)return n;let r=new Map;return t[e]=r,r}const k=mt(Symbol.for(`openclaw.fileLockHeldLocks`));function ht(e,t){let n=Math.min(e.maxTimeout,Math.max(e.minTimeout,e.minTimeout*e.factor**t)),r=e.randomize?1+Math.random():1;return Math.min(e.maxTimeout,Math.round(n*r))}async function gt(e){try{let t=await i.readFile(e,`utf8`),n=JSON.parse(t);return typeof n.pid!=`number`||typeof n.createdAt!=`string`?null:{pid:n.pid,createdAt:n.createdAt}}catch{return null}}async function _t(e){let n=t.resolve(e),r=t.dirname(n);await i.mkdir(r,{recursive:!0});try{let e=await i.realpath(r);return t.join(e,t.basename(n))}catch{return n}}async function vt(e,t){let n=await gt(e);if(n?.pid&&!pt(n.pid))return!0;if(n?.createdAt){let e=Date.parse(n.createdAt);if(!Number.isFinite(e)||Date.now()-e>t)return!0}try{let n=await i.stat(e);return Date.now()-n.mtimeMs>t}catch{return!0}}async function yt(e){let t=k.get(e);t&&(--t.count,!(t.count>0)&&(k.delete(e),await t.handle.close().catch(()=>void 0),await i.rm(t.lockPath,{force:!0}).catch(()=>void 0)))}async function bt(e,t){let n=await _t(e),r=`${n}.lock`,a=k.get(n);if(a)return a.count+=1,{lockPath:r,release:()=>yt(n)};let o=Math.max(1,t.retries.retries+1);for(let e=0;e<o;e+=1)try{let e=await i.open(r,`wx`);return await e.writeFile(JSON.stringify({pid:process.pid,createdAt:new Date().toISOString()},null,2),`utf8`),k.set(n,{count:1,handle:e,lockPath:r}),{lockPath:r,release:()=>yt(n)}}catch(n){if(n.code!==`EEXIST`)throw n;if(await vt(r,t.stale)){await i.rm(r,{force:!0}).catch(()=>void 0);continue}if(e>=o-1)break;await new Promise(n=>setTimeout(n,ht(t.retries,e)))}throw Error(`file lock timeout for ${n}`)}async function xt(e,t,n){let r=await bt(e,t);try{return await n()}finally{await r.release()}}function St(e){let t=e.dmPolicy===`allowlist`?[]:e.storeAllowFrom??[];return[...e.allowFrom??[],...t].map(e=>String(e).trim()).filter(Boolean)}function Ct(e){return((Array.isArray(e.groupAllowFrom)&&e.groupAllowFrom.length>0?e.groupAllowFrom:void 0)||(e.fallbackToAllowFrom===!1?[]:e.allowFrom??[])).map(e=>String(e).trim()).filter(Boolean)}const wt=new Set([`--dev`,`--no-color`]),Tt=new Set([`--profile`,`--log-level`]);function Et(e){return!e||e===`--`?!1:e.startsWith(`-`)?/^-\d+(?:\.\d+)?$/.test(e):!0}function Dt(e,t){let n=e[t];return n?wt.has(n)||n.startsWith(`--profile=`)||n.startsWith(`--log-level=`)?1:Tt.has(n)?Et(e[t+1])?2:1:0:0}function Ot(e,t=2){return kt(e,t,{skipRootOptions:!0})}function kt(e,t,n){let r=e.slice(2),i=[];for(let e=0;e<r.length;e+=1){let a=r[e];if(a){if(a===`--`)break;if(n.skipRootOptions){let t=Dt(r,e);if(t>0){e+=t-1;continue}}if(!a.startsWith(`-`)&&(i.push(a),i.length>=t))break}}return i}function A(e){return e?.trim()||void 0}function At(e=process.env,n=r.homedir){let i=jt(e,n);return i?t.resolve(i):void 0}function jt(e,t){let n=A(e.OPENCLAW_HOME);if(n){if(n===`~`||n.startsWith(`~/`)||n.startsWith(`~\\`)){let r=A(e.HOME)??A(e.USERPROFILE)??Mt(t);return r?n.replace(/^~(?=$|[\\/])/,r):void 0}return n}return A(e.HOME)||A(e.USERPROFILE)||Mt(t)}function Mt(e){try{return A(e())}catch{return}}function j(e=process.env,n=r.homedir){return At(e,n)??t.resolve(process.cwd())}function Nt(e,t){if(!e.startsWith(`~`))return e;let n=A(t?.home)??At(t?.env??process.env,t?.homedir??r.homedir);return n?e.replace(/^~(?=$|[\\/])/,n):e}function Pt(e=process.env){return e.OPENCLAW_NIX_MODE===`1`}Pt();const Ft=[`.clawdbot`,`.moldbot`,`.moltbot`],M=`.openclaw-qbot.json`,N=[`openclaw.json`,`clawdbot.json`,`moldbot.json`,`moltbot.json`];function It(){return j(process.env,r.homedir)}function P(e){return()=>j(e,r.homedir)}function F(e=It){return Ft.map(n=>t.join(e(),n))}function Lt(e=It){return t.join(e(),`.qbotclaw`)}function I(e=process.env,t=P(e)){let r=()=>j(e,t),i=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(i)return L(i,e,r);let a=Lt(r);if(e.OPENCLAW_TEST_FAST===`1`)return a;let o=F(r);return n.existsSync(a)?a:o.find(e=>{try{return n.existsSync(e)}catch{return!1}})||a}function L(e,n=process.env,r=P(n)){let i=e.trim();if(!i)return i;if(i.startsWith(`~`)){let e=Nt(i,{home:j(n,r),env:n,homedir:r});return t.resolve(e)}return t.resolve(i)}I();function Rt(e=process.env,n=I(e,P(e))){let r=e.OPENCLAW_CONFIG_PATH?.trim()||e.CLAWDBOT_CONFIG_PATH?.trim();return r?L(r,e,P(e)):t.join(n,M)}function zt(e=process.env,t=P(e)){return e.OPENCLAW_TEST_FAST===`1`?Rt(e,I(e,t)):Vt(e,t).find(e=>{try{return n.existsSync(e)}catch{return!1}})||Rt(e,I(e,t))}function Bt(e=process.env,r=I(e,P(e)),i=P(e)){let a=e.OPENCLAW_CONFIG_PATH?.trim();if(a)return L(a,e,i);if(e.OPENCLAW_TEST_FAST===`1`)return t.join(r,M);let o=e.OPENCLAW_STATE_DIR?.trim(),s=[t.join(r,M),...N.map(e=>t.join(r,e))].find(e=>{try{return n.existsSync(e)}catch{return!1}});if(s)return s;if(o)return t.join(r,M);let c=I(e,i);return t.resolve(r)===t.resolve(c)?zt(e,i):t.join(r,M)}zt();function Vt(e=process.env,n=P(e)){let r=()=>j(e,n),i=e.OPENCLAW_CONFIG_PATH?.trim()||e.CLAWDBOT_CONFIG_PATH?.trim();if(i)return[L(i,e,r)];let a=[],o=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(o){let n=L(o,e,r);a.push(t.join(n,M)),a.push(...N.map(e=>t.join(n,e)))}let s=[Lt(r),...F(r)];for(let e of s)a.push(t.join(e,M)),a.push(...N.map(n=>t.join(e,n)));return a}function Ht(e=process.env,n=I(e,P(e))){let r=e.OPENCLAW_OAUTH_DIR?.trim();return r?L(r,e,P(e)):t.join(n,`credentials`)}function Ut(){let e=Bt();try{if(!n.existsSync(e))return;let t=n.readFileSync(e,`utf-8`),r=c.parse(t)?.logging;return!r||typeof r!=`object`||Array.isArray(r)?void 0:r}catch{return}}const Wt=[`silent`,`fatal`,`error`,`warn`,`info`,`debug`,`trace`];function Gt(e){if(typeof e!=`string`)return;let t=e.trim();return Wt.includes(t)?t:void 0}function Kt(e,t=`info`){return Gt(e)??t}function R(e){return{fatal:0,error:1,warn:2,info:3,debug:4,trace:5,silent:1/0}[e]}const z={cachedLogger:null,cachedSettings:null,cachedConsoleSettings:null,overrideSettings:null,invalidEnvLogLevelValue:null,consolePatched:!1,forceConsoleToStderr:!1,consoleTimestampPrefix:!1,consoleSubsystemFilter:null,resolvingConsoleSettings:!1,streamErrorHandlersInstalled:!1,rawConsole:null};function qt(){let e=process.env.OPENCLAW_LOG_LEVEL,t=typeof e==`string`?e.trim():``;if(!t){z.invalidEnvLogLevelValue=null;return}let n=Gt(t);if(n)return z.invalidEnvLogLevelValue=null,n;z.invalidEnvLogLevelValue!==t&&(z.invalidEnvLogLevelValue=t,process.stderr.write(`[openclaw] Ignoring invalid OPENCLAW_LOG_LEVEL="${t}" (allowed: ${Wt.join(`|`)}).\n`))}function Jt(e){let t=process.getBuiltinModule;if(typeof t!=`function`)return null;try{let n=t(`module`),r=typeof n.createRequire==`function`?n.createRequire:null;return r?r(e):null}catch{return null}}function Yt(e){try{return new Intl.DateTimeFormat(`en`,{timeZone:e}),!0}catch{return!1}}function B(e,t){let n=t??process.env.TZ,r=n&&Yt(n)?n:Intl.DateTimeFormat().resolvedOptions().timeZone,i=new Intl.DateTimeFormat(`en`,{timeZone:r,year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,hour12:!1,fractionalSecondDigits:3,timeZoneName:`longOffset`}),a=Object.fromEntries(i.formatToParts(e).map(e=>[e.type,e.value])),o=a.timeZoneName??`GMT`,s=o===`GMT`?`+00:00`:o.slice(3);return`${a.year}-${a.month}-${a.day}T${a.hour}:${a.minute}:${a.second}.${a.fractionalSecond}${s}`}const Xt=Ye();t.join(Xt,`qbotclaw.log`);const V=`qbotclaw`,H=`.log`,Zt=500*1024*1024,Qt=Jt(import.meta.url),U=new Set;function $t(e=process.argv){let[t,n]=Ot(e,2);return t===`config`&&n===`validate`}function en(e,t){e.attachTransport(e=>{if(U.has(t))try{t(e)}catch{}})}function tn(e){return process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_FILE_LOG!==`1`&&!e&&!z.overrideSettings}function nn(){let e=qt();if(tn(e))return{level:`silent`,file:pn(),maxFileBytes:Zt};let t=z.overrideSettings??Ut();if(!t&&!$t())try{t=(Qt?.(`../config/config.js`))?.loadConfig?.().logging}catch{t=void 0}let n=process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_FILE_LOG!==`1`?`silent`:`info`,r=Kt(t?.level,n);return{level:e??r,file:t?.file??pn(),maxFileBytes:sn(t?.maxFileBytes)}}function rn(e,t){return e?e.level!==t.level||e.file!==t.file||e.maxFileBytes!==t.maxFileBytes:!0}function an(e){let t=z.cachedSettings??nn();return z.cachedSettings||=t,t.level===`silent`?!1:R(e)<=R(t.level)}function on(e){let r=new s({name:`openclaw`,minLevel:R(e.level),type:`hidden`});if(e.level===`silent`){for(let e of U)en(r,e);return r}n.mkdirSync(t.dirname(e.file),{recursive:!0}),mn(e.file)&&hn(t.dirname(e.file));let i=cn(e.file),a=!1;r.attachTransport(t=>{try{let n=B(t.date??new Date),r=`${JSON.stringify({...t,time:n})}\n`,o=Buffer.byteLength(r,`utf8`),s=i+o;if(s>e.maxFileBytes){if(!a){a=!0;let t=JSON.stringify({time:B(new Date),level:`warn`,subsystem:`logging`,message:`log file size cap reached; suppressing writes file=${e.file} maxFileBytes=${e.maxFileBytes}`});ln(e.file,`${t}\n`),process.stderr.write(`[openclaw] log file size cap reached; suppressing writes file=${e.file} maxFileBytes=${e.maxFileBytes}\n`)}return}ln(e.file,r)&&(i=s)}catch{}});for(let e of U)en(r,e);return r}function sn(e){return typeof e==`number`&&Number.isFinite(e)&&e>0?Math.floor(e):Zt}function cn(e){try{return n.statSync(e).size}catch{return 0}}function ln(e,t){try{return n.appendFileSync(e,t,{encoding:`utf8`}),!0}catch{return!1}}function un(){let e=nn(),t=z.cachedLogger,n=z.cachedSettings;return(!t||rn(n,e))&&(z.cachedLogger=on(e),z.cachedSettings=e),z.cachedLogger}function dn(e,t){let n=un(),r=t?.level?R(t.level):void 0,i=e?JSON.stringify(e):void 0;return n.getSubLogger({name:i,minLevel:r,prefix:e?[i??``]:[]})}function fn(e){return`${e.getFullYear()}-${String(e.getMonth()+1).padStart(2,`0`)}-${String(e.getDate()).padStart(2,`0`)}`}function pn(){let e=fn(new Date);return t.join(Xt,`${V}-${e}${H}`)}function mn(e){let n=t.basename(e);return n.startsWith(`${V}-`)&&n.endsWith(H)&&n.length===`${V}-YYYY-MM-DD${H}`.length}function hn(e){try{let r=n.readdirSync(e,{withFileTypes:!0}),i=Date.now()-864e5;for(let a of r){if(!a.isFile()||!a.name.startsWith(`${V}-`)||!a.name.endsWith(H))continue;let r=t.join(e,a.name);try{n.statSync(r).mtimeMs<i&&n.rmSync(r,{force:!0})}catch{}}}catch{}}const W={accent:`#FF5A2D`,accentBright:`#FF7A3D`,accentDim:`#D14A22`,info:`#FF8A5B`,success:`#2FBF71`,warn:`#FFB020`,error:`#E23D2D`,muted:`#8B7F77`},gn=typeof process.env.FORCE_COLOR==`string`&&process.env.FORCE_COLOR.trim().length>0&&process.env.FORCE_COLOR.trim()!==`0`,_n=process.env.NO_COLOR&&!gn?new o({level:0}):a,G=e=>_n.hex(e),K={accent:G(W.accent),accentBright:G(W.accentBright),accentDim:G(W.accentDim),info:G(W.info),success:G(W.success),warn:G(W.warn),error:G(W.error),muted:G(W.muted),heading:_n.bold.hex(W.accent),command:G(W.accentBright),option:G(W.warn)};function q(){return!1}K.success,K.warn,K.info,K.error;function vn(e=process.env){return e.VITEST!==`true`||e.OPENCLAW_TEST_RUNTIME_LOG===`1`?!0:typeof console.log.mock==`object`}function yn(){return{log:(...e)=>{vn()&&console.log(...e)},error:(...e)=>{console.error(...e)}}}({...yn()}),typeof Intl<`u`&&`Segmenter`in Intl&&new Intl.Segmenter(void 0,{granularity:`grapheme`});const bn=Jt(import.meta.url);let xn=()=>{try{return(bn?.(`../config/config.js`))?.loadConfig?.().logging}catch{return}};function Sn(e){return q()?`debug`:!e&&process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_CONSOLE!==`1`?`silent`:Kt(e,`info`)}function Cn(e){return e===`compact`||e===`json`||e===`pretty`?e:process.stdout.isTTY?`pretty`:`compact`}function wn(){let e=qt();if(process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_CONSOLE!==`1`&&!q()&&!e&&!z.overrideSettings)return{level:`silent`,style:Cn(void 0)};let t=z.overrideSettings??Ut();if(!t)if(z.resolvingConsoleSettings)t=void 0;else{z.resolvingConsoleSettings=!0;try{t=xn()}finally{z.resolvingConsoleSettings=!1}}return{level:e??Sn(t?.consoleLevel),style:Cn(t?.consoleStyle)}}function Tn(e,t){return e?e.level!==t.level||e.style!==t.style:!0}function En(){let e=wn(),t=z.cachedConsoleSettings;return(!t||Tn(t,e))&&(z.cachedConsoleSettings=e),z.cachedConsoleSettings}function Dn(e){let t=z.consoleSubsystemFilter;return!t||t.length===0?!0:t.some(t=>e===t||e.startsWith(`${t}/`))}function J(e){let t=new Date;return e===`pretty`?`${String(t.getHours()).padStart(2,`0`)}:${String(t.getMinutes()).padStart(2,`0`)}:${String(t.getSeconds()).padStart(2,`0`)}`:B(t)}function Y(e,t){return t.level===`silent`?!1:R(e)<=R(t.level)}(()=>{let e=process.getBuiltinModule;if(typeof e!=`function`)return null;try{let t=e(`util`);return typeof t.inspect==`function`?t.inspect:null}catch{return null}})();function On(){let e=(process.env.TERM??``).toLowerCase();return process.env.COLORTERM||process.env.TERM_PROGRAM?!0:e.length>0&&e!==`dumb`}function kn(){let e=typeof process.env.FORCE_COLOR==`string`&&process.env.FORCE_COLOR.trim().length>0&&process.env.FORCE_COLOR.trim()!==`0`;return process.env.NO_COLOR&&!e?new o({level:0}):process.stdout.isTTY||process.stderr.isTTY||On()?new o({level:1}):new o({level:0})}const An=[`cyan`,`green`,`yellow`,`blue`,`magenta`,`red`],jn={"gmail-watcher":`blue`},Mn=[`gateway`,`channels`,`providers`],Nn=new Set([`telegram`,`whatsapp`,`discord`,`irc`,`googlechat`,`slack`,`signal`,`imessage`]);function Pn(e,t){let n=jn[t];if(n)return e[n];let r=0;for(let e=0;e<t.length;e+=1)r=r*31+t.charCodeAt(e)|0;return e[An[Math.abs(r)%An.length]]}function Fn(e){let t=e.split(`/`).filter(Boolean),n=t.join(`/`)||e;for(;t.length>0&&Mn.includes(t[0]);)t.shift();return t.length===0?n:Nn.has(t[0])?t[0]:t.length>2?t.slice(-2).join(`/`):t.join(`/`)}function In(e,t){if(!t)return e;if(e.startsWith(`[`)){let n=e.indexOf(`]`);if(n>1&&e.slice(1,n).toLowerCase()===t.toLowerCase()){let t=n+1;for(;e[t]===` `;)t+=1;return e.slice(t)}}if(e.slice(0,t.length).toLowerCase()!==t.toLowerCase())return e;let n=e.slice(t.length,t.length+1);if(n!==`:`&&n!==` `)return e;let r=t.length;for(;e[r]===` `;)r+=1;for(e[r]===`:`&&(r+=1);e[r]===` `;)r+=1;return e.slice(r)}function Ln(e){let t=e.style===`json`?e.subsystem:Fn(e.subsystem);if(e.style===`json`)return JSON.stringify({time:J(`json`),level:e.level,subsystem:t,message:e.message,...e.meta});let n=kn(),r=`[${t}]`,i=Pn(n,t),a=e.level===`error`||e.level===`fatal`?n.red:e.level===`warn`?n.yellow:e.level===`debug`||e.level===`trace`?n.gray:n.cyan,o=In(e.message,t);return`${[e.style===`pretty`?n.gray(J(`pretty`)):z.consoleTimestampPrefix?n.gray(J(e.style)):``,i(r)].filter(Boolean).join(` `)} ${a(o)}`}function Rn(e,t){let n=process.platform===`win32`&&process.env.GITHUB_ACTIONS===`true`?t.replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g,`?`).replace(/[\uD800-\uDFFF]/g,`?`):t,r=z.rawConsole??console;z.forceConsoleToStderr||e===`error`||e===`fatal`?(r.error??console.error)(n):e===`warn`?(r.warn??console.warn)(n):(r.log??console.log)(n)}function zn(e){return q()||e.level===`error`||e.level===`fatal`||!(e.subsystem===`agent/embedded`||e.subsystem.startsWith(`agent/embedded/`)||e.subsystem===`model-fallback`||e.subsystem.startsWith(`model-fallback/`))?!1:(typeof e.meta?.runId==`string`?e.meta.runId:typeof e.meta?.sessionId==`string`?e.meta.sessionId:void 0)?.startsWith(`probe-`)?!0:/(sessionId|runId)=probe-/.test(e.message)}function Bn(e,t,n,r){if(t===`silent`)return;let i=e[t];typeof i==`function`&&(r&&Object.keys(r).length>0?i.call(e,r,n):i.call(e,n))}function Vn(e){let t=null,n=()=>(t||=dn({subsystem:e}),t),r=(t,r,i)=>{let a=En(),o=Y(t,{level:a.level})&&Dn(e),s=an(t);if(!o&&!s)return;let c,l=i;if(i&&Object.keys(i).length>0){let{consoleMessage:e,...t}=i;typeof e==`string`&&(c=e),l=Object.keys(t).length>0?t:void 0}if(s&&Bn(n(),t,r,l),!o)return;let u=c??r;zn({level:t,subsystem:e,message:u,meta:l})||Rn(t,Ln({level:t,subsystem:e,message:a.style===`json`?r:u,style:a.style,meta:l}))},i=t=>Y(t,{level:En().level})&&Dn(e),a=e=>an(e);return{subsystem:e,isEnabled:(e,t=`any`)=>t===`console`?i(e):t===`file`?a(e):i(e)||a(e),trace:(e,t)=>r(`trace`,e,t),debug:(e,t)=>r(`debug`,e,t),info:(e,t)=>r(`info`,e,t),warn:(e,t)=>r(`warn`,e,t),error:(e,t)=>r(`error`,e,t),fatal:(e,t)=>r(`fatal`,e,t),raw:t=>{if(a(`info`)&&Bn(n(),`info`,t,{raw:!0}),i(`info`)){if(zn({level:`info`,subsystem:e,message:t}))return;Rn(`info`,t)}},child:t=>Vn(`${e}/${t}`)}}const Hn=globalThis;Hn.__openclaw_internal_hook_handlers__??=new Map;function Un(e){if(!e)return``;let n=e.trim();if(!n)return n;if(n.startsWith(`~`)){let e=Nt(n,{home:j(process.env,r.homedir),env:process.env,homedir:r.homedir});return t.resolve(e)}return t.resolve(n)}function Wn(e=process.env,i=r.homedir){let a=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(a)return Un(a);let o=t.join(j(e,i),`.qbotclaw`);try{if(n.existsSync(o))return o}catch{}return o}Wn();function Gn(){return{plugins:[],tools:[],hooks:[],typedHooks:[],channels:[],providers:[],gatewayHandlers:{},httpRoutes:[],cliRegistrars:[],services:[],commands:[],diagnostics:[]}}const X=Symbol.for(`openclaw.pluginRegistryState`);(()=>{let e=globalThis;return e[X]||(e[X]={registry:Gn(),key:null,version:0}),e[X]})();function Z(e,t){function n(t){let n=t.channels?.[e],r=ct(typeof n?.defaultAccount==`string`?n.defaultAccount:void 0);if(r&&i(t).some(e=>st(e)===r))return r}function r(n){let r=n.channels?.[e]?.accounts;if(!r||typeof r!=`object`)return[];let i=Object.keys(r).filter(Boolean),a=t?.normalizeAccountId;return a?[...new Set(i.map(e=>a(e)).filter(Boolean))]:i}function i(e){let t=r(e);return t.length===0?[D]:t.toSorted((e,t)=>e.localeCompare(t))}function a(e){let t=n(e);if(t)return t;let r=i(e);return r.includes(`default`)?D:r[0]??`default`}return{listConfiguredAccountIds:r,listAccountIds:i,resolveDefaultAccountId:a}}const{listAccountIds:Kn,resolveDefaultAccountId:qn}=Z(`discord`),{listAccountIds:Jn,resolveDefaultAccountId:Yn}=Z(`imessage`);function Q(e){return(e??[]).map(e=>String(e).trim()).filter(Boolean)}function Xn(){return t.join(Ht(),`whatsapp`,D)}Xn();const{listConfiguredAccountIds:Zn,listAccountIds:Qn,resolveDefaultAccountId:$n}=Z(`whatsapp`),{listAccountIds:er,resolveDefaultAccountId:tr}=Z(`slack`);Object.freeze({allowFinalSymlinkForUnlink:!1,allowFinalHardlinkForUnlink:!1}),Object.freeze({allowFinalSymlinkForUnlink:!0,allowFinalHardlinkForUnlink:!0}),t.resolve(t.dirname(l(import.meta.url)),`../../docs/reference/templates`);function nr(e=process.env,n=r.homedir){let i=Wn(e,n),a=e.OPENCLAW_PROFILE?.trim();return a&&a.toLowerCase()!==`default`?t.join(i,`workspace-${a}`):t.join(i,`workspace`)}nr();function rr(e){if(e.groupPolicy===`disabled`)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`disabled`};if(e.groupPolicy===`allowlist`){if(e.requireMatchInput&&!e.hasMatchInput)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`missing_match_input`};if(!e.allowlistConfigured)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`empty_allowlist`};if(!e.allowlistMatched)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`not_allowlisted`}}return{allowed:!0,groupPolicy:e.groupPolicy,reason:`allowed`}}function ir(e){let t=Array.isArray(e.allowFrom)?e.allowFrom:void 0,n=Array.isArray(e.groupAllowFrom)?e.groupAllowFrom:void 0;return{effectiveAllowFrom:Q(St({allowFrom:t,storeAllowFrom:Array.isArray(e.storeAllowFrom)?e.storeAllowFrom:void 0,dmPolicy:e.dmPolicy??void 0})),effectiveGroupAllowFrom:Q(Ct({allowFrom:t,groupAllowFrom:n,fallbackToAllowFrom:e.groupAllowFromFallbackToAllowFrom??void 0}))}}const $={GROUP_POLICY_ALLOWED:`group_policy_allowed`,GROUP_POLICY_DISABLED:`group_policy_disabled`,GROUP_POLICY_EMPTY_ALLOWLIST:`group_policy_empty_allowlist`,GROUP_POLICY_NOT_ALLOWLISTED:`group_policy_not_allowlisted`,DM_POLICY_OPEN:`dm_policy_open`,DM_POLICY_DISABLED:`dm_policy_disabled`,DM_POLICY_ALLOWLISTED:`dm_policy_allowlisted`,DM_POLICY_PAIRING_REQUIRED:`dm_policy_pairing_required`,DM_POLICY_NOT_ALLOWLISTED:`dm_policy_not_allowlisted`};function ar(e){let t=e.dmPolicy??`pairing`,n=e.groupPolicy===`open`||e.groupPolicy===`disabled`?e.groupPolicy:`allowlist`,r=Q(e.effectiveAllowFrom),i=Q(e.effectiveGroupAllowFrom);if(e.isGroup){let t=rr({groupPolicy:n,allowlistConfigured:i.length>0,allowlistMatched:e.isSenderAllowed(i)});if(!t.allowed){if(t.reason===`disabled`)return{decision:`block`,reasonCode:$.GROUP_POLICY_DISABLED,reason:`groupPolicy=disabled`};if(t.reason===`empty_allowlist`)return{decision:`block`,reasonCode:$.GROUP_POLICY_EMPTY_ALLOWLIST,reason:`groupPolicy=allowlist (empty allowlist)`};if(t.reason===`not_allowlisted`)return{decision:`block`,reasonCode:$.GROUP_POLICY_NOT_ALLOWLISTED,reason:`groupPolicy=allowlist (not allowlisted)`}}return{decision:`allow`,reasonCode:$.GROUP_POLICY_ALLOWED,reason:`groupPolicy=${n}`}}return t===`disabled`?{decision:`block`,reasonCode:$.DM_POLICY_DISABLED,reason:`dmPolicy=disabled`}:t===`open`?{decision:`allow`,reasonCode:$.DM_POLICY_OPEN,reason:`dmPolicy=open`}:e.isSenderAllowed(r)?{decision:`allow`,reasonCode:$.DM_POLICY_ALLOWLISTED,reason:`dmPolicy=${t} (allowlisted)`}:t===`pairing`?{decision:`pairing`,reasonCode:$.DM_POLICY_PAIRING_REQUIRED,reason:`dmPolicy=pairing (not allowlisted)`}:{decision:`block`,reasonCode:$.DM_POLICY_NOT_ALLOWLISTED,reason:`dmPolicy=${t} (not allowlisted)`}}function or(e){let{effectiveAllowFrom:t,effectiveGroupAllowFrom:n}=ir({allowFrom:e.allowFrom,groupAllowFrom:e.groupAllowFrom,storeAllowFrom:e.storeAllowFrom,dmPolicy:e.dmPolicy,groupAllowFromFallbackToAllowFrom:e.groupAllowFromFallbackToAllowFrom});return{...ar({isGroup:e.isGroup,dmPolicy:e.dmPolicy,groupPolicy:e.groupPolicy,effectiveAllowFrom:t,effectiveGroupAllowFrom:n,isSenderAllowed:e.isSenderAllowed}),effectiveAllowFrom:t,effectiveGroupAllowFrom:n}}function sr(e){return e.isGroup?`allowed`:e.dmPolicy===`disabled`?`disabled`:e.dmPolicy!==`open`&&!e.senderAllowedForCommands?`unauthorized`:`allowed`}async function cr(e){return lr({...e,shouldComputeCommandAuthorized:e.runtime.shouldComputeCommandAuthorized,resolveCommandAuthorizedFromAuthorizers:e.runtime.resolveCommandAuthorizedFromAuthorizers})}async function lr(e){let t=e.shouldComputeCommandAuthorized(e.rawBody,e.cfg),n=!e.isGroup&&e.dmPolicy!==`allowlist`&&(e.dmPolicy!==`open`||t)?await e.readAllowFromStore().catch(()=>[]):[],r=or({isGroup:e.isGroup,dmPolicy:e.dmPolicy,groupPolicy:`allowlist`,allowFrom:e.configuredAllowFrom,groupAllowFrom:e.configuredGroupAllowFrom??[],storeAllowFrom:n,isSenderAllowed:t=>e.isSenderAllowed(e.senderId,t)}),i=r.effectiveAllowFrom,a=r.effectiveGroupAllowFrom,o=e.cfg.commands?.useAccessGroups!==!1,s=e.isSenderAllowed(e.senderId,e.isGroup?a:i),c=e.isSenderAllowed(e.senderId,i),l=e.isSenderAllowed(e.senderId,a);return{shouldComputeAuth:t,effectiveAllowFrom:i,effectiveGroupAllowFrom:a,senderAllowedForCommands:s,commandAuthorized:t?e.resolveCommandAuthorizedFromAuthorizers({useAccessGroups:o,authorizers:[{configured:i.length>0,allowed:c},{configured:a.length>0,allowed:l}]}):void 0}}export{D as DEFAULT_ACCOUNT_ID,Ue as buildChannelConfigSchema,Ke as createTypingCallbacks,Ze as emptyPluginConfigSchema,st as normalizeAccountId,sr as resolveDirectDmAuthorizationOutcome,Ye as resolvePreferredOpenClawTmpDir,cr as resolveSenderCommandAuthorizationWithRuntime,ut as stripMarkdown,xt as withFileLock};
|
|
3
|
+
`),t=t.trim(),t}function dt(e){return Number.isInteger(e)&&e>0}function ft(e){if(process.platform!==`linux`)return!1;try{return n.readFileSync(`/proc/${e}/status`,`utf8`).match(/^State:\s+(\S)/m)?.[1]===`Z`}catch{return!1}}function pt(e){if(!dt(e))return!1;try{process.kill(e,0)}catch{return!1}return!ft(e)}function mt(e){let t=process,n=t[e];if(n)return n;let r=new Map;return t[e]=r,r}const k=mt(Symbol.for(`openclaw.fileLockHeldLocks`));function ht(e,t){let n=Math.min(e.maxTimeout,Math.max(e.minTimeout,e.minTimeout*e.factor**t)),r=e.randomize?1+Math.random():1;return Math.min(e.maxTimeout,Math.round(n*r))}async function gt(e){try{let t=await i.readFile(e,`utf8`),n=JSON.parse(t);return typeof n.pid!=`number`||typeof n.createdAt!=`string`?null:{pid:n.pid,createdAt:n.createdAt}}catch{return null}}async function _t(e){let n=t.resolve(e),r=t.dirname(n);await i.mkdir(r,{recursive:!0});try{let e=await i.realpath(r);return t.join(e,t.basename(n))}catch{return n}}async function vt(e,t){let n=await gt(e);if(n?.pid&&!pt(n.pid))return!0;if(n?.createdAt){let e=Date.parse(n.createdAt);if(!Number.isFinite(e)||Date.now()-e>t)return!0}try{let n=await i.stat(e);return Date.now()-n.mtimeMs>t}catch{return!0}}async function yt(e){let t=k.get(e);t&&(--t.count,!(t.count>0)&&(k.delete(e),await t.handle.close().catch(()=>void 0),await i.rm(t.lockPath,{force:!0}).catch(()=>void 0)))}async function bt(e,t){let n=await _t(e),r=`${n}.lock`,a=k.get(n);if(a)return a.count+=1,{lockPath:r,release:()=>yt(n)};let o=Math.max(1,t.retries.retries+1);for(let e=0;e<o;e+=1)try{let e=await i.open(r,`wx`);return await e.writeFile(JSON.stringify({pid:process.pid,createdAt:new Date().toISOString()},null,2),`utf8`),k.set(n,{count:1,handle:e,lockPath:r}),{lockPath:r,release:()=>yt(n)}}catch(n){if(n.code!==`EEXIST`)throw n;if(await vt(r,t.stale)){await i.rm(r,{force:!0}).catch(()=>void 0);continue}if(e>=o-1)break;await new Promise(n=>setTimeout(n,ht(t.retries,e)))}throw Error(`file lock timeout for ${n}`)}async function xt(e,t,n){let r=await bt(e,t);try{return await n()}finally{await r.release()}}function St(e){let t=e.dmPolicy===`allowlist`?[]:e.storeAllowFrom??[];return[...e.allowFrom??[],...t].map(e=>String(e).trim()).filter(Boolean)}function Ct(e){return((Array.isArray(e.groupAllowFrom)&&e.groupAllowFrom.length>0?e.groupAllowFrom:void 0)||(e.fallbackToAllowFrom===!1?[]:e.allowFrom??[])).map(e=>String(e).trim()).filter(Boolean)}const wt=new Set([`--dev`,`--no-color`]),Tt=new Set([`--profile`,`--log-level`]);function Et(e){return!e||e===`--`?!1:e.startsWith(`-`)?/^-\d+(?:\.\d+)?$/.test(e):!0}function Dt(e,t){let n=e[t];return n?wt.has(n)||n.startsWith(`--profile=`)||n.startsWith(`--log-level=`)?1:Tt.has(n)?Et(e[t+1])?2:1:0:0}function Ot(e,t=2){return kt(e,t,{skipRootOptions:!0})}function kt(e,t,n){let r=e.slice(2),i=[];for(let e=0;e<r.length;e+=1){let a=r[e];if(a){if(a===`--`)break;if(n.skipRootOptions){let t=Dt(r,e);if(t>0){e+=t-1;continue}}if(!a.startsWith(`-`)&&(i.push(a),i.length>=t))break}}return i}function A(e){return e?.trim()||void 0}function At(e=process.env,n=r.homedir){let i=jt(e,n);return i?t.resolve(i):void 0}function jt(e,t){let n=A(e.OPENCLAW_HOME);if(n){if(n===`~`||n.startsWith(`~/`)||n.startsWith(`~\\`)){let r=A(e.HOME)??A(e.USERPROFILE)??Mt(t);return r?n.replace(/^~(?=$|[\\/])/,r):void 0}return n}return A(e.HOME)||A(e.USERPROFILE)||Mt(t)}function Mt(e){try{return A(e())}catch{return}}function j(e=process.env,n=r.homedir){return At(e,n)??t.resolve(process.cwd())}function Nt(e,t){if(!e.startsWith(`~`))return e;let n=A(t?.home)??At(t?.env??process.env,t?.homedir??r.homedir);return n?e.replace(/^~(?=$|[\\/])/,n):e}function Pt(e=process.env){return e.OPENCLAW_NIX_MODE===`1`}Pt();const Ft=[`.clawdbot`,`.moldbot`,`.moltbot`],M=`.openclaw-qbot.json`,N=[`openclaw.json`,`clawdbot.json`,`moldbot.json`,`moltbot.json`];function It(){return j(process.env,r.homedir)}function P(e){return()=>j(e,r.homedir)}function F(e=It){return Ft.map(n=>t.join(e(),n))}function Lt(e=It){return t.join(e(),`.qbotclaw`)}function I(e=process.env,t=P(e)){let r=()=>j(e,t),i=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(i)return L(i,e,r);let a=Lt(r);if(e.OPENCLAW_TEST_FAST===`1`)return a;let o=F(r);return n.existsSync(a)?a:o.find(e=>{try{return n.existsSync(e)}catch{return!1}})||a}function L(e,n=process.env,r=P(n)){let i=e.trim();if(!i)return i;if(i.startsWith(`~`)){let e=Nt(i,{home:j(n,r),env:n,homedir:r});return t.resolve(e)}return t.resolve(i)}I();function Rt(e=process.env,n=I(e,P(e))){let r=e.OPENCLAW_CONFIG_PATH?.trim()||e.CLAWDBOT_CONFIG_PATH?.trim();return r?L(r,e,P(e)):t.join(n,M)}function zt(e=process.env,t=P(e)){return e.OPENCLAW_TEST_FAST===`1`?Rt(e,I(e,t)):Vt(e,t).find(e=>{try{return n.existsSync(e)}catch{return!1}})||Rt(e,I(e,t))}function Bt(e=process.env,r=I(e,P(e)),i=P(e)){let a=e.OPENCLAW_CONFIG_PATH?.trim();if(a)return L(a,e,i);if(e.OPENCLAW_TEST_FAST===`1`)return t.join(r,M);let o=e.OPENCLAW_STATE_DIR?.trim(),s=[t.join(r,M),...N.map(e=>t.join(r,e))].find(e=>{try{return n.existsSync(e)}catch{return!1}});if(s)return s;if(o)return t.join(r,M);let c=I(e,i);return t.resolve(r)===t.resolve(c)?zt(e,i):t.join(r,M)}zt();function Vt(e=process.env,n=P(e)){let r=()=>j(e,n),i=e.OPENCLAW_CONFIG_PATH?.trim()||e.CLAWDBOT_CONFIG_PATH?.trim();if(i)return[L(i,e,r)];let a=[],o=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(o){let n=L(o,e,r);a.push(t.join(n,M)),a.push(...N.map(e=>t.join(n,e)))}let s=[Lt(r),...F(r)];for(let e of s)a.push(t.join(e,M)),a.push(...N.map(n=>t.join(e,n)));return a}function Ht(e=process.env,n=I(e,P(e))){let r=e.OPENCLAW_OAUTH_DIR?.trim();return r?L(r,e,P(e)):t.join(n,`credentials`)}function Ut(){let e=Bt();try{if(!n.existsSync(e))return;let t=n.readFileSync(e,`utf-8`),r=c.parse(t)?.logging;return!r||typeof r!=`object`||Array.isArray(r)?void 0:r}catch{return}}const Wt=[`silent`,`fatal`,`error`,`warn`,`info`,`debug`,`trace`];function Gt(e){if(typeof e!=`string`)return;let t=e.trim();return Wt.includes(t)?t:void 0}function Kt(e,t=`info`){return Gt(e)??t}function R(e){return{fatal:0,error:1,warn:2,info:3,debug:4,trace:5,silent:1/0}[e]}const z={cachedLogger:null,cachedSettings:null,cachedConsoleSettings:null,overrideSettings:null,invalidEnvLogLevelValue:null,consolePatched:!1,forceConsoleToStderr:!1,consoleTimestampPrefix:!1,consoleSubsystemFilter:null,resolvingConsoleSettings:!1,streamErrorHandlersInstalled:!1,rawConsole:null};function qt(){let e=process.env.OPENCLAW_LOG_LEVEL,t=typeof e==`string`?e.trim():``;if(!t){z.invalidEnvLogLevelValue=null;return}let n=Gt(t);if(n)return z.invalidEnvLogLevelValue=null,n;z.invalidEnvLogLevelValue!==t&&(z.invalidEnvLogLevelValue=t,process.stderr.write(`[openclaw] Ignoring invalid OPENCLAW_LOG_LEVEL="${t}" (allowed: ${Wt.join(`|`)}).\n`))}function Jt(e){let t=process.getBuiltinModule;if(typeof t!=`function`)return null;try{let n=t(`module`),r=typeof n.createRequire==`function`?n.createRequire:null;return r?r(e):null}catch{return null}}function Yt(e){try{return new Intl.DateTimeFormat(`en`,{timeZone:e}),!0}catch{return!1}}function B(e,t){let n=t??process.env.TZ,r=n&&Yt(n)?n:Intl.DateTimeFormat().resolvedOptions().timeZone,i=new Intl.DateTimeFormat(`en`,{timeZone:r,year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,hour12:!1,fractionalSecondDigits:3,timeZoneName:`longOffset`}),a=Object.fromEntries(i.formatToParts(e).map(e=>[e.type,e.value])),o=a.timeZoneName??`GMT`,s=o===`GMT`?`+00:00`:o.slice(3);return`${a.year}-${a.month}-${a.day}T${a.hour}:${a.minute}:${a.second}.${a.fractionalSecond}${s}`}const Xt=Ye();t.join(Xt,`qbotclaw.log`);const V=`qbotclaw`,H=`.log`,Zt=500*1024*1024,Qt=Jt(import.meta.url),U=new Set;function $t(e=process.argv){let[t,n]=Ot(e,2);return t===`config`&&n===`validate`}function en(e,t){e.attachTransport(e=>{if(U.has(t))try{t(e)}catch{}})}function tn(e){return process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_FILE_LOG!==`1`&&!e&&!z.overrideSettings}function nn(){let e=qt();if(tn(e))return{level:`silent`,file:pn(),maxFileBytes:Zt};let t=z.overrideSettings??Ut();if(!t&&!$t())try{t=(Qt?.(`../config/config.js`))?.loadConfig?.().logging}catch{t=void 0}let n=process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_FILE_LOG!==`1`?`silent`:`info`,r=Kt(t?.level,n);return{level:e??r,file:t?.file??pn(),maxFileBytes:sn(t?.maxFileBytes)}}function rn(e,t){return e?e.level!==t.level||e.file!==t.file||e.maxFileBytes!==t.maxFileBytes:!0}function an(e){let t=z.cachedSettings??nn();return z.cachedSettings||=t,t.level===`silent`?!1:R(e)<=R(t.level)}function on(e){let r=new s({name:`openclaw`,minLevel:R(e.level),type:`hidden`});if(e.level===`silent`){for(let e of U)en(r,e);return r}n.mkdirSync(t.dirname(e.file),{recursive:!0}),mn(e.file)&&hn(t.dirname(e.file));let i=cn(e.file),a=!1;r.attachTransport(t=>{try{let n=B(t.date??new Date),r=`${JSON.stringify({...t,time:n})}\n`,o=Buffer.byteLength(r,`utf8`),s=i+o;if(s>e.maxFileBytes){if(!a){a=!0;let t=JSON.stringify({time:B(new Date),level:`warn`,subsystem:`logging`,message:`log file size cap reached; suppressing writes file=${e.file} maxFileBytes=${e.maxFileBytes}`});ln(e.file,`${t}\n`),process.stderr.write(`[openclaw] log file size cap reached; suppressing writes file=${e.file} maxFileBytes=${e.maxFileBytes}\n`)}return}ln(e.file,r)&&(i=s)}catch{}});for(let e of U)en(r,e);return r}function sn(e){return typeof e==`number`&&Number.isFinite(e)&&e>0?Math.floor(e):Zt}function cn(e){try{return n.statSync(e).size}catch{return 0}}function ln(e,t){try{return n.appendFileSync(e,t,{encoding:`utf8`}),!0}catch{return!1}}function un(){let e=nn(),t=z.cachedLogger,n=z.cachedSettings;return(!t||rn(n,e))&&(z.cachedLogger=on(e),z.cachedSettings=e),z.cachedLogger}function dn(e,t){let n=un(),r=t?.level?R(t.level):void 0,i=e?JSON.stringify(e):void 0;return n.getSubLogger({name:i,minLevel:r,prefix:e?[i??``]:[]})}function fn(e){return`${e.getFullYear()}-${String(e.getMonth()+1).padStart(2,`0`)}-${String(e.getDate()).padStart(2,`0`)}`}function pn(){let e=fn(new Date);return t.join(Xt,`${V}-${e}${H}`)}function mn(e){let n=t.basename(e);return n.startsWith(`${V}-`)&&n.endsWith(H)&&n.length===`${V}-YYYY-MM-DD${H}`.length}function hn(e){try{let r=n.readdirSync(e,{withFileTypes:!0}),i=Date.now()-864e5;for(let a of r){if(!a.isFile()||!a.name.startsWith(`${V}-`)||!a.name.endsWith(H))continue;let r=t.join(e,a.name);try{n.statSync(r).mtimeMs<i&&n.rmSync(r,{force:!0})}catch{}}}catch{}}const W={accent:`#FF5A2D`,accentBright:`#FF7A3D`,accentDim:`#D14A22`,info:`#FF8A5B`,success:`#2FBF71`,warn:`#FFB020`,error:`#E23D2D`,muted:`#8B7F77`},gn=typeof process.env.FORCE_COLOR==`string`&&process.env.FORCE_COLOR.trim().length>0&&process.env.FORCE_COLOR.trim()!==`0`,_n=process.env.NO_COLOR&&!gn?new o({level:0}):a,G=e=>_n.hex(e),K={accent:G(W.accent),accentBright:G(W.accentBright),accentDim:G(W.accentDim),info:G(W.info),success:G(W.success),warn:G(W.warn),error:G(W.error),muted:G(W.muted),heading:_n.bold.hex(W.accent),command:G(W.accentBright),option:G(W.warn)};function q(){return!1}K.success,K.warn,K.info,K.error;function vn(e=process.env){return e.VITEST!==`true`||e.OPENCLAW_TEST_RUNTIME_LOG===`1`?!0:typeof console.log.mock==`object`}function yn(){return{log:(...e)=>{vn()&&console.log(...e)},error:(...e)=>{console.error(...e)}}}({...yn()}),typeof Intl<`u`&&`Segmenter`in Intl&&new Intl.Segmenter(void 0,{granularity:`grapheme`});const bn=Jt(import.meta.url);let xn=()=>{try{return(bn?.(`../config/config.js`))?.loadConfig?.().logging}catch{return}};function Sn(e){return q()?`debug`:!e&&process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_CONSOLE!==`1`?`silent`:Kt(e,`info`)}function Cn(e){return e===`compact`||e===`json`||e===`pretty`?e:process.stdout.isTTY?`pretty`:`compact`}function wn(){let e=qt();if(process.env.VITEST===`true`&&process.env.OPENCLAW_TEST_CONSOLE!==`1`&&!q()&&!e&&!z.overrideSettings)return{level:`silent`,style:Cn(void 0)};let t=z.overrideSettings??Ut();if(!t)if(z.resolvingConsoleSettings)t=void 0;else{z.resolvingConsoleSettings=!0;try{t=xn()}finally{z.resolvingConsoleSettings=!1}}return{level:e??Sn(t?.consoleLevel),style:Cn(t?.consoleStyle)}}function Tn(e,t){return e?e.level!==t.level||e.style!==t.style:!0}function En(){let e=wn(),t=z.cachedConsoleSettings;return(!t||Tn(t,e))&&(z.cachedConsoleSettings=e),z.cachedConsoleSettings}function Dn(e){let t=z.consoleSubsystemFilter;return!t||t.length===0?!0:t.some(t=>e===t||e.startsWith(`${t}/`))}function J(e){let t=new Date;return e===`pretty`?`${String(t.getHours()).padStart(2,`0`)}:${String(t.getMinutes()).padStart(2,`0`)}:${String(t.getSeconds()).padStart(2,`0`)}`:B(t)}function Y(e,t){return t.level===`silent`?!1:R(e)<=R(t.level)}(()=>{let e=process.getBuiltinModule;if(typeof e!=`function`)return null;try{let t=e(`util`);return typeof t.inspect==`function`?t.inspect:null}catch{return null}})();function On(){let e=(process.env.TERM??``).toLowerCase();return process.env.COLORTERM||process.env.TERM_PROGRAM?!0:e.length>0&&e!==`dumb`}function kn(){let e=typeof process.env.FORCE_COLOR==`string`&&process.env.FORCE_COLOR.trim().length>0&&process.env.FORCE_COLOR.trim()!==`0`;return process.env.NO_COLOR&&!e?new o({level:0}):process.stdout.isTTY||process.stderr.isTTY||On()?new o({level:1}):new o({level:0})}const An=[`cyan`,`green`,`yellow`,`blue`,`magenta`,`red`],jn={"gmail-watcher":`blue`},Mn=[`gateway`,`channels`,`providers`],Nn=new Set([`telegram`,`whatsapp`,`discord`,`irc`,`googlechat`,`slack`,`signal`,`imessage`]);function Pn(e,t){let n=jn[t];if(n)return e[n];let r=0;for(let e=0;e<t.length;e+=1)r=r*31+t.charCodeAt(e)|0;return e[An[Math.abs(r)%An.length]]}function Fn(e){let t=e.split(`/`).filter(Boolean),n=t.join(`/`)||e;for(;t.length>0&&Mn.includes(t[0]);)t.shift();return t.length===0?n:Nn.has(t[0])?t[0]:t.length>2?t.slice(-2).join(`/`):t.join(`/`)}function In(e,t){if(!t)return e;if(e.startsWith(`[`)){let n=e.indexOf(`]`);if(n>1&&e.slice(1,n).toLowerCase()===t.toLowerCase()){let t=n+1;for(;e[t]===` `;)t+=1;return e.slice(t)}}if(e.slice(0,t.length).toLowerCase()!==t.toLowerCase())return e;let n=e.slice(t.length,t.length+1);if(n!==`:`&&n!==` `)return e;let r=t.length;for(;e[r]===` `;)r+=1;for(e[r]===`:`&&(r+=1);e[r]===` `;)r+=1;return e.slice(r)}function Ln(e){let t=e.style===`json`?e.subsystem:Fn(e.subsystem);if(e.style===`json`)return JSON.stringify({time:J(`json`),level:e.level,subsystem:t,message:e.message,...e.meta});let n=kn(),r=`[${t}]`,i=Pn(n,t),a=e.level===`error`||e.level===`fatal`?n.red:e.level===`warn`?n.yellow:e.level===`debug`||e.level===`trace`?n.gray:n.cyan,o=In(e.message,t);return`${[e.style===`pretty`?n.gray(J(`pretty`)):z.consoleTimestampPrefix?n.gray(J(e.style)):``,i(r)].filter(Boolean).join(` `)} ${a(o)}`}function Rn(e,t){let n=process.platform===`win32`&&process.env.GITHUB_ACTIONS===`true`?t.replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g,`?`).replace(/[\uD800-\uDFFF]/g,`?`):t,r=z.rawConsole??console;z.forceConsoleToStderr||e===`error`||e===`fatal`?(r.error??console.error)(n):e===`warn`?(r.warn??console.warn)(n):(r.log??console.log)(n)}function zn(e){return q()||e.level===`error`||e.level===`fatal`||!(e.subsystem===`agent/embedded`||e.subsystem.startsWith(`agent/embedded/`)||e.subsystem===`model-fallback`||e.subsystem.startsWith(`model-fallback/`))?!1:(typeof e.meta?.runId==`string`?e.meta.runId:typeof e.meta?.sessionId==`string`?e.meta.sessionId:void 0)?.startsWith(`probe-`)?!0:/(sessionId|runId)=probe-/.test(e.message)}function Bn(e,t,n,r){if(t===`silent`)return;let i=e[t];typeof i==`function`&&(r&&Object.keys(r).length>0?i.call(e,r,n):i.call(e,n))}function Vn(e){let t=null,n=()=>(t||=dn({subsystem:e}),t),r=(t,r,i)=>{let a=En(),o=Y(t,{level:a.level})&&Dn(e),s=an(t);if(!o&&!s)return;let c,l=i;if(i&&Object.keys(i).length>0){let{consoleMessage:e,...t}=i;typeof e==`string`&&(c=e),l=Object.keys(t).length>0?t:void 0}if(s&&Bn(n(),t,r,l),!o)return;let u=c??r;zn({level:t,subsystem:e,message:u,meta:l})||Rn(t,Ln({level:t,subsystem:e,message:a.style===`json`?r:u,style:a.style,meta:l}))},i=t=>Y(t,{level:En().level})&&Dn(e),a=e=>an(e);return{subsystem:e,isEnabled:(e,t=`any`)=>t===`console`?i(e):t===`file`?a(e):i(e)||a(e),trace:(e,t)=>r(`trace`,e,t),debug:(e,t)=>r(`debug`,e,t),info:(e,t)=>r(`info`,e,t),warn:(e,t)=>r(`warn`,e,t),error:(e,t)=>r(`error`,e,t),fatal:(e,t)=>r(`fatal`,e,t),raw:t=>{if(a(`info`)&&Bn(n(),`info`,t,{raw:!0}),i(`info`)){if(zn({level:`info`,subsystem:e,message:t}))return;Rn(`info`,t)}},child:t=>Vn(`${e}/${t}`)}}const Hn=globalThis;Hn.__openclaw_internal_hook_handlers__??=new Map;function Un(e){if(!e)return``;let n=e.trim();if(!n)return n;if(n.startsWith(`~`)){let e=Nt(n,{home:j(process.env,r.homedir),env:process.env,homedir:r.homedir});return t.resolve(e)}return t.resolve(n)}function Wn(e=process.env,i=r.homedir){let a=e.OPENCLAW_STATE_DIR?.trim()||e.CLAWDBOT_STATE_DIR?.trim();if(a)return Un(a);let o=t.join(j(e,i),`.qbotclaw`);try{if(n.existsSync(o))return o}catch{}return o}Wn();function Gn(){return{plugins:[],tools:[],hooks:[],typedHooks:[],channels:[],providers:[],gatewayHandlers:{},httpRoutes:[],cliRegistrars:[],services:[],commands:[],diagnostics:[]}}const X=Symbol.for(`openclaw.pluginRegistryState`);(()=>{let e=globalThis;return e[X]||(e[X]={registry:Gn(),key:null,version:0}),e[X]})();function Z(e,t){function n(t){let n=t.channels?.[e],r=ct(typeof n?.defaultAccount==`string`?n.defaultAccount:void 0);if(r&&i(t).some(e=>st(e)===r))return r}function r(n){let r=n.channels?.[e]?.accounts;if(!r||typeof r!=`object`)return[];let i=Object.keys(r).filter(Boolean),a=t?.normalizeAccountId;return a?[...new Set(i.map(e=>a(e)).filter(Boolean))]:i}function i(e){let t=r(e);return t.length===0?[D]:t.toSorted((e,t)=>e.localeCompare(t))}function a(e){let t=n(e);if(t)return t;let r=i(e);return r.includes(`default`)?D:r[0]??`default`}return{listConfiguredAccountIds:r,listAccountIds:i,resolveDefaultAccountId:a}}const{listAccountIds:Kn,resolveDefaultAccountId:qn}=Z(`discord`),{listAccountIds:Jn,resolveDefaultAccountId:Yn}=Z(`imessage`);function Q(e){return(e??[]).map(e=>String(e).trim()).filter(Boolean)}function Xn(){return t.join(Ht(),`whatsapp`,D)}Xn();const{listConfiguredAccountIds:Zn,listAccountIds:Qn,resolveDefaultAccountId:$n}=Z(`whatsapp`),{listAccountIds:er,resolveDefaultAccountId:tr}=Z(`slack`);Object.freeze({allowFinalSymlinkForUnlink:!1,allowFinalHardlinkForUnlink:!1}),Object.freeze({allowFinalSymlinkForUnlink:!0,allowFinalHardlinkForUnlink:!0}),t.resolve(t.dirname(l(import.meta.url)),`../../docs/reference/templates`);function nr(e=process.env,n=r.homedir){let i=Wn(e,n),a=e.OPENCLAW_PROFILE?.trim();return a&&a.toLowerCase()!==`default`?t.join(i,`workspace-${a}`):t.join(i,`workspace`)}nr();function rr(e){if(e.groupPolicy===`disabled`)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`disabled`};if(e.groupPolicy===`allowlist`){if(e.requireMatchInput&&!e.hasMatchInput)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`missing_match_input`};if(!e.allowlistConfigured)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`empty_allowlist`};if(!e.allowlistMatched)return{allowed:!1,groupPolicy:e.groupPolicy,reason:`not_allowlisted`}}return{allowed:!0,groupPolicy:e.groupPolicy,reason:`allowed`}}function ir(e){let t=Array.isArray(e.allowFrom)?e.allowFrom:void 0,n=Array.isArray(e.groupAllowFrom)?e.groupAllowFrom:void 0;return{effectiveAllowFrom:Q(St({allowFrom:t,storeAllowFrom:Array.isArray(e.storeAllowFrom)?e.storeAllowFrom:void 0,dmPolicy:e.dmPolicy??void 0})),effectiveGroupAllowFrom:Q(Ct({allowFrom:t,groupAllowFrom:n,fallbackToAllowFrom:e.groupAllowFromFallbackToAllowFrom??void 0}))}}const $={GROUP_POLICY_ALLOWED:`group_policy_allowed`,GROUP_POLICY_DISABLED:`group_policy_disabled`,GROUP_POLICY_EMPTY_ALLOWLIST:`group_policy_empty_allowlist`,GROUP_POLICY_NOT_ALLOWLISTED:`group_policy_not_allowlisted`,DM_POLICY_OPEN:`dm_policy_open`,DM_POLICY_DISABLED:`dm_policy_disabled`,DM_POLICY_ALLOWLISTED:`dm_policy_allowlisted`,DM_POLICY_PAIRING_REQUIRED:`dm_policy_pairing_required`,DM_POLICY_NOT_ALLOWLISTED:`dm_policy_not_allowlisted`};function ar(e){let t=e.dmPolicy??`pairing`,n=e.groupPolicy===`open`||e.groupPolicy===`disabled`?e.groupPolicy:`allowlist`,r=Q(e.effectiveAllowFrom),i=Q(e.effectiveGroupAllowFrom);if(e.isGroup){let t=rr({groupPolicy:n,allowlistConfigured:i.length>0,allowlistMatched:e.isSenderAllowed(i)});if(!t.allowed){if(t.reason===`disabled`)return{decision:`block`,reasonCode:$.GROUP_POLICY_DISABLED,reason:`groupPolicy=disabled`};if(t.reason===`empty_allowlist`)return{decision:`block`,reasonCode:$.GROUP_POLICY_EMPTY_ALLOWLIST,reason:`groupPolicy=allowlist (empty allowlist)`};if(t.reason===`not_allowlisted`)return{decision:`block`,reasonCode:$.GROUP_POLICY_NOT_ALLOWLISTED,reason:`groupPolicy=allowlist (not allowlisted)`}}return{decision:`allow`,reasonCode:$.GROUP_POLICY_ALLOWED,reason:`groupPolicy=${n}`}}return t===`disabled`?{decision:`block`,reasonCode:$.DM_POLICY_DISABLED,reason:`dmPolicy=disabled`}:t===`open`?{decision:`allow`,reasonCode:$.DM_POLICY_OPEN,reason:`dmPolicy=open`}:e.isSenderAllowed(r)?{decision:`allow`,reasonCode:$.DM_POLICY_ALLOWLISTED,reason:`dmPolicy=${t} (allowlisted)`}:t===`pairing`?{decision:`pairing`,reasonCode:$.DM_POLICY_PAIRING_REQUIRED,reason:`dmPolicy=pairing (not allowlisted)`}:{decision:`block`,reasonCode:$.DM_POLICY_NOT_ALLOWLISTED,reason:`dmPolicy=${t} (not allowlisted)`}}function or(e){let{effectiveAllowFrom:t,effectiveGroupAllowFrom:n}=ir({allowFrom:e.allowFrom,groupAllowFrom:e.groupAllowFrom,storeAllowFrom:e.storeAllowFrom,dmPolicy:e.dmPolicy,groupAllowFromFallbackToAllowFrom:e.groupAllowFromFallbackToAllowFrom});return{...ar({isGroup:e.isGroup,dmPolicy:e.dmPolicy,groupPolicy:e.groupPolicy,effectiveAllowFrom:t,effectiveGroupAllowFrom:n,isSenderAllowed:e.isSenderAllowed}),effectiveAllowFrom:t,effectiveGroupAllowFrom:n}}function sr(e){return e.isGroup?`allowed`:e.dmPolicy===`disabled`?`disabled`:e.dmPolicy!==`open`&&!e.senderAllowedForCommands?`unauthorized`:`allowed`}async function cr(e){return lr({...e,shouldComputeCommandAuthorized:e.runtime.shouldComputeCommandAuthorized,resolveCommandAuthorizedFromAuthorizers:e.runtime.resolveCommandAuthorizedFromAuthorizers})}async function lr(e){let t=e.shouldComputeCommandAuthorized(e.rawBody,e.cfg),n=!e.isGroup&&e.dmPolicy!==`allowlist`&&(e.dmPolicy!==`open`||t)?await e.readAllowFromStore().catch(()=>[]):[],r=or({isGroup:e.isGroup,dmPolicy:e.dmPolicy,groupPolicy:`allowlist`,allowFrom:e.configuredAllowFrom,groupAllowFrom:e.configuredGroupAllowFrom??[],storeAllowFrom:n,isSenderAllowed:t=>e.isSenderAllowed(e.senderId,t)}),i=r.effectiveAllowFrom,a=r.effectiveGroupAllowFrom,o=e.cfg.commands?.useAccessGroups!==!1,s=e.isSenderAllowed(e.senderId,e.isGroup?a:i),c=e.isSenderAllowed(e.senderId,i),l=e.isSenderAllowed(e.senderId,a);return{shouldComputeAuth:t,effectiveAllowFrom:i,effectiveGroupAllowFrom:a,senderAllowedForCommands:s,commandAuthorized:t?e.resolveCommandAuthorizedFromAuthorizers({useAccessGroups:o,authorizers:[{configured:i.length>0,allowed:c},{configured:a.length>0,allowed:l}]}):void 0}}export{D as DEFAULT_ACCOUNT_ID,Ue as buildChannelConfigSchema,Ke as createTypingCallbacks,Ze as emptyPluginConfigSchema,st as normalizeAccountId,sr as resolveDirectDmAuthorizationOutcome,Ye as resolvePreferredOpenClawTmpDir,cr as resolveSenderCommandAuthorizationWithRuntime,ut as stripMarkdown,xt as withFileLock};
|