@pixelzx/genesis 2026.6.4 → 2026.6.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +18 -0
- package/dist/.buildstamp +1 -1
- package/dist/abort-CcNxEsSq.js +201 -0
- package/dist/abort.runtime-DZJDSf0d.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/accounts-B7M6y8l8.js +107 -0
- package/dist/accounts-DddcYo7u.js +2 -0
- package/dist/accounts-v0Cqfnse.js +104 -0
- package/dist/acp-cli-D_2_Nim8.js +2193 -0
- package/dist/acp-spawn-BZPupfsZ.js +2 -0
- package/dist/acp-spawn-CWfIrbK7.js +1093 -0
- package/dist/acp-stateful-target-driver-DpCTjH5T.js +89 -0
- package/dist/action-agents-fjIM4rpc.js +67 -0
- package/dist/action-focus-cx1pm1ym.js +132 -0
- package/dist/action-help-DtyAnULB.js +7 -0
- package/dist/action-info-DF30-xZl.js +101 -0
- package/dist/action-kill-rsSdXzvX.js +33 -0
- package/dist/action-list-4VN835m2.js +21 -0
- package/dist/action-log-L032mq5B.js +30 -0
- package/dist/action-send-Dm62UP-n.js +39 -0
- package/dist/action-spawn-BuZHKlpL.js +47 -0
- package/dist/action-unfocus-CTIWf8WX.js +29 -0
- package/dist/actions.runtime-0ezEcm7K.js +18 -0
- package/dist/actions.runtime-DKsCTTnH.js +5 -0
- package/dist/actions.runtime.js +1 -1
- package/dist/agent-BTOBOCIw.js +2 -0
- package/dist/agent-command-C-_EFUUu.js +874 -0
- package/dist/agent-harness-runtime-Bye6j3EL.js +144 -0
- package/dist/agent-runner-utils-CX2vCMkx.js +239 -0
- package/dist/agent-runner.runtime-BBqrjZv4.js +3455 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-D1LIGcNj.js +18 -0
- package/dist/agents-CME2O1l9.js +5 -0
- package/dist/agents-DsDQvAPy.js +954 -0
- package/dist/aliases-C807OidC.js +2 -0
- package/dist/aliases-jq1ap6Dz.js +96 -0
- package/dist/api-BbxKoRkD.js +3 -0
- package/dist/api-CwJPCW9U.js +139 -0
- package/dist/api-N5Kaaq64.js +5 -0
- package/dist/approval-gateway-resolver-DIPFgTnx.js +29 -0
- package/dist/approval-gateway-runtime-i0yziXk2.js +2 -0
- package/dist/approval-handler-runtime-Cdm-10f9.js +439 -0
- package/dist/approval-native-runtime-BRjeBoqL.js +729 -0
- package/dist/attempt-execution.runtime-NFTF7Cbt.js +509 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt.prompt-helpers-DuBXv46v.js +221 -0
- package/dist/attempt.tool-run-context-Qf-tbC-C.js +933 -0
- package/dist/audit-DsDfRhB8.js +939 -0
- package/dist/audit.runtime-ComjcUGJ.js +7 -0
- package/dist/audit.runtime.js +1 -1
- package/dist/auth-BT_gqC-D.js +2 -0
- package/dist/auth-DeUz_8w8.js +383 -0
- package/dist/auth-order-DM7UkPDa.js +96 -0
- package/dist/auth-order-yS8hXrXh.js +2 -0
- package/dist/bash-tools-D0M9gBDu.js +3 -0
- package/dist/bash-tools-tnj1gSbO.js +2824 -0
- package/dist/binding-routing-C7atXiTD.js +85 -0
- package/dist/binding-targets-CCv7agx9.js +121 -0
- package/dist/bridge-server-C5O9rTJg.js +113 -0
- package/dist/browser-control-auth-GGN_kbqE.js +2 -0
- package/dist/browser-node-runtime-B-uTSVqP.js +12 -0
- package/dist/browser-profiles-Dex2eaLH.js +2 -0
- package/dist/browser-runtime-BPocB6yO.js +387 -0
- package/dist/browser-setup-tools-gHfYeDWA.js +13 -0
- package/dist/build-BqG7RkBz.js +550 -0
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +2 -2
- package/dist/bundled/session-memory/handler.js +1 -1
- package/dist/call-BI4JvjcR.js +3 -0
- package/dist/call-wY43fzOF.js +331 -0
- package/dist/call.runtime-Dh61oVeL.js +2 -0
- package/dist/call.runtime.js +1 -1
- package/dist/capability-cli-BHz-2Stx.js +1401 -0
- package/dist/catchup-Be7tHJwK.js +300 -0
- package/dist/channel-B-6VmF4-.js +840 -0
- package/dist/channel-BCJccV-O.js +226 -0
- package/dist/channel-BDZqLbod.js +1100 -0
- package/dist/channel-BQDNgTea.js +1174 -0
- package/dist/channel-BwjThGwK.js +453 -0
- package/dist/channel-CPoThmda.js +595 -0
- package/dist/channel-CUT8NJ-B.js +350 -0
- package/dist/channel-C_Y7lv8v.js +491 -0
- package/dist/channel-Ck7-C-lB.js +297 -0
- package/dist/channel-DOpVjq4i.js +1802 -0
- package/dist/channel-core-QV9-eAtb.js +5 -0
- package/dist/channel-inbound-D_tebgdx.js +31 -0
- package/dist/channel-plugin-runtime-DXcBwNNM.js +771 -0
- package/dist/channel-runtime-D4ci0o4V.js +425 -0
- package/dist/channel-sAdF_zH-.js +1320 -0
- package/dist/channel.runtime-1swLIpNV.js +89 -0
- package/dist/channel.runtime-B9hljdNF.js +4 -0
- package/dist/channel.runtime-CSbR2pni.js +430 -0
- package/dist/channel.runtime-CdpqhnLO.js +2364 -0
- package/dist/channel.runtime-DOx6WROg.js +40130 -0
- package/dist/channel.runtime-H5Kb2LbC.js +109 -0
- package/dist/channel.runtime-V7boBc_e.js +576 -0
- package/dist/channel.runtime.js +1 -1
- package/dist/channel.setup-BXyeNJ2_.js +10 -0
- package/dist/channels-KU7bwUUs.js +733 -0
- package/dist/channels-cli-CTX6_5z3.js +268 -0
- package/dist/chat-C_i6Wp50.js +2830 -0
- package/dist/clawbot-cli-CLGPtbt-.js +9 -0
- package/dist/cli/daemon-cli.js +3 -3
- package/dist/cli-BhwHu1dK.js +72 -0
- package/dist/cli-CFsq8f2H.js +2 -0
- package/dist/cli-CNVlwurq.js +219 -0
- package/dist/cli-DLP8hKbi.js +2 -0
- package/dist/cli-runner-BbNBHV6v.js +286 -0
- package/dist/cli-runner.runtime-CfPaauuM.js +4 -0
- package/dist/cli-runner.runtime-MxBlCOO2.js +3 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +2 -2
- package/dist/cli.runtime-3cD-pSyn.js +1261 -0
- package/dist/cli.runtime.js +1 -1
- package/dist/client-Bl0d_7ak.js +138 -0
- package/dist/client-ClJyHgmq.js +713 -0
- package/dist/command-auth-DO32coey.js +76 -0
- package/dist/command-config-resolution-CAsa4fGg.js +2 -0
- package/dist/command-config-resolution-D6YcwuRh.js +23 -0
- package/dist/command-config-resolution.runtime-CSHDu35A.js +2 -0
- package/dist/command-config-resolution.runtime.js +1 -1
- package/dist/command-registry-BJEQrMqR.js +4 -0
- package/dist/command-registry-DI9i95nj.js +9 -0
- package/dist/command-registry-core-BpF1mggD.js +106 -0
- package/dist/command-secret-gateway-DDNHxysD.js +528 -0
- package/dist/command-status.runtime-DqYUCcEA.js +87 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-acp-C_zCJPvL.js +77 -0
- package/dist/commands-compact.runtime-B6e3kwMS.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-handlers.runtime-B0gTkAC0.js +4599 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-status-BgZ64sA8.js +16 -0
- package/dist/commands-status.runtime-JI89gIEU.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-B0hdcBxr.js +2 -0
- package/dist/commands-subagents-control.runtime-DUeSQ5j4.js +3 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-B7moUaCI.js +158 -0
- package/dist/commands-system-prompt-DTUkp9TH.js +2 -0
- package/dist/commands.runtime-BjCVVqol.js +167 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/compact-BNJH56SX.js +1118 -0
- package/dist/compact.runtime-CYI8Yi9d.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-Bb1Tk-vM.js +328 -0
- package/dist/config-DxkleHmo.js +252 -0
- package/dist/config-cli-CtaRB_f8.js +1078 -0
- package/dist/configure-Bp8WFryM.js +1252 -0
- package/dist/configure-DQ_X5zyT.js +2 -0
- package/dist/connect-options-BkWD0Wvv.js +699 -0
- package/dist/control-auth-Iqyldslx.js +125 -0
- package/dist/control-service-xIhkqyZE.js +156 -0
- package/dist/control-ui/assets/agents-Dh_TAFxm.js +1052 -0
- package/dist/control-ui/assets/canvas-BBkF0c_Z.js +269 -0
- package/dist/control-ui/assets/channel-config-extras-CNdHdere.js +2 -0
- package/dist/control-ui/assets/channels-DxBxgFLI.js +463 -0
- package/dist/control-ui/assets/cron-DI85RTUE.js +933 -0
- package/dist/control-ui/assets/de-ona0Q7Bc.js +2 -0
- package/dist/control-ui/assets/debug-DnDu2pj9.js +94 -0
- package/dist/control-ui/assets/es-Dn-oNRUH.js +2 -0
- package/dist/control-ui/assets/format-BvrOTETl.js +9 -0
- package/dist/control-ui/assets/fr-DXJ2RnNl.js +2 -0
- package/dist/control-ui/assets/i18n-BiXTtoQW.js +3 -0
- package/dist/control-ui/assets/id-BWsRmAR3.js +2 -0
- package/dist/control-ui/assets/index-YAwpI05T.js +6366 -0
- package/dist/control-ui/assets/instances-CRNiJVGJ.js +57 -0
- package/dist/control-ui/assets/ja-JP-BUkQN13S.js +2 -0
- package/dist/control-ui/assets/ko-Q_K13wyH.js +2 -0
- package/dist/control-ui/assets/logs-CzRlG5kP.js +74 -0
- package/dist/control-ui/assets/mcp-CAYQSRMs.js +373 -0
- package/dist/control-ui/assets/nodes-92SUclba.js +618 -0
- package/dist/control-ui/assets/pl-WlhlBCqd.js +2 -0
- package/dist/control-ui/assets/plugins-TwSBb6p5.js +273 -0
- package/dist/control-ui/assets/pt-BR-CVchspYo.js +2 -0
- package/dist/control-ui/assets/sessions-CHmx5D2H.js +306 -0
- package/dist/control-ui/assets/skills-C-34EOwN.js +323 -0
- package/dist/control-ui/assets/skills-shared-BbxW-wNm.js +11 -0
- package/dist/control-ui/assets/th-C4FUN3Mq.js +2 -0
- package/dist/control-ui/assets/tr-CoySBXqw.js +2 -0
- package/dist/control-ui/assets/uk-C-mkZs9j.js +2 -0
- package/dist/control-ui/assets/wallet-DjjoYuDY.js +285 -0
- package/dist/control-ui/assets/zh-CN-B7HXiLrY.js +2 -0
- package/dist/control-ui/assets/zh-TW-CKLRstBM.js +2 -0
- package/dist/control-ui/index.html +3 -3
- package/dist/conversation-id-BZtOqHIz.js +38 -0
- package/dist/conversation-id-D1Q9qPFH.js +235 -0
- package/dist/conversation-runtime-B1QZ-DEM.js +31 -0
- package/dist/core-BdVAy0Wv.js +275 -0
- package/dist/cron-cli-BWM2kRKU.js +713 -0
- package/dist/daemon-cli-MRl5nyuF.js +12 -0
- package/dist/dashboard-BkdlJrnf.js +2 -0
- package/dist/dashboard-C9m86rHv.js +81 -0
- package/dist/delegate-BjUvKQlo.js +64 -0
- package/dist/detached-task-runtime-BAEzkNB8.js +73 -0
- package/dist/devices-cli-B1n6tl9f.js +498 -0
- package/dist/diagnostics-DZxWkW3i.js +154 -0
- package/dist/direct-dm-qw-uk31C.js +64 -0
- package/dist/dispatch-D0xiJ6Up.js +1131 -0
- package/dist/dispatch-acp-DVN58m9G.js +981 -0
- package/dist/dispatch-acp-manager.runtime-C8t1i5Wt.js +3 -0
- package/dist/dispatch-acp-manager.runtime.js +1 -1
- package/dist/dispatch-acp.runtime-FR0DUPpn.js +19 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/doctor-device-pairing-DIbiBPlL.js +307 -0
- package/dist/doctor-gateway-daemon-flow-BFjRlXvA.js +250 -0
- package/dist/doctor-gateway-health-uZrukX3c.js +63 -0
- package/dist/doctor-health-DKpg1bxM.js +59 -0
- package/dist/doctor-health-contributions-BoXX8ubw.js +493 -0
- package/dist/doctor-prompter-CLf5Uf10.js +56 -0
- package/dist/doctor-workspace-status-Cw61BbGy.js +75 -0
- package/dist/dreaming-Bk8dVfGi.js +1574 -0
- package/dist/dreaming-narrative-DGSQa-0N.js +595 -0
- package/dist/embedded-gateway-stub.runtime-sokWrs6B.js +9 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/entry.js +2 -2
- package/dist/exec-approvals-cli-CnNETs_u.js +498 -0
- package/dist/extensionAPI.js +1 -1
- package/dist/extensions/active-memory/index.js +1 -1
- package/dist/extensions/bluebubbles/api.js +3 -3
- package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
- package/dist/extensions/browser/browser-bridge.js +1 -1
- package/dist/extensions/browser/browser-config.js +4 -4
- package/dist/extensions/browser/browser-control-auth.js +2 -2
- package/dist/extensions/browser/browser-doctor.js +2 -2
- package/dist/extensions/browser/browser-maintenance.js +2 -2
- package/dist/extensions/browser/browser-profiles.js +2 -2
- package/dist/extensions/browser/browser-runtime-api.js +10 -10
- package/dist/extensions/browser/index.js +1 -1
- package/dist/extensions/browser/plugin-registration.js +1 -1
- package/dist/extensions/browser/register.runtime.js +3 -3
- package/dist/extensions/browser/runtime-api.js +11 -11
- package/dist/extensions/browser/test-support.js +1 -1
- package/dist/extensions/device-pair/api.js +1 -1
- package/dist/extensions/device-pair/index.js +3 -3
- package/dist/extensions/device-pair/notify.js +1 -1
- package/dist/extensions/device-pair/pair-command-approve.js +1 -1
- package/dist/extensions/google-meet/index.js +2 -2
- package/dist/extensions/imessage/api.js +3 -3
- package/dist/extensions/imessage/channel-plugin-api.js +1 -1
- package/dist/extensions/imessage/runtime-api.js +3 -3
- package/dist/extensions/irc/api.js +2 -2
- package/dist/extensions/irc/channel-plugin-api.js +1 -1
- package/dist/extensions/line/api.js +2 -2
- package/dist/extensions/line/channel-plugin-api.js +1 -1
- package/dist/extensions/line/contract-api.js +1 -1
- package/dist/extensions/line/runtime-api.js +4 -4
- package/dist/extensions/line/setup-api.js +1 -1
- package/dist/extensions/llm-task/index.js +2 -2
- package/dist/extensions/lobster/index.js +3 -3
- package/dist/extensions/lobster/runtime-api.js +1 -1
- package/dist/extensions/mattermost/api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
- package/dist/extensions/mattermost/policy-api.js +1 -1
- package/dist/extensions/mattermost/runtime-api.js +4 -4
- package/dist/extensions/mattermost/slash-route-api.js +1 -1
- package/dist/extensions/memory-core/api.js +1 -1
- package/dist/extensions/memory-core/cli-metadata.js +2 -2
- package/dist/extensions/memory-core/index.js +3 -3
- package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
- package/dist/extensions/msteams/api.js +1 -1
- package/dist/extensions/msteams/channel-plugin-api.js +1 -1
- package/dist/extensions/msteams/runtime-api.js +3 -3
- package/dist/extensions/msteams/test-api.js +1 -1
- package/dist/extensions/nextcloud-talk/api.js +1 -1
- package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
- package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
- package/dist/extensions/openshell/index.js +2 -2
- package/dist/extensions/signal/api.js +6 -6
- package/dist/extensions/signal/channel-plugin-api.js +1 -1
- package/dist/extensions/signal/reaction-runtime-api.js +1 -1
- package/dist/extensions/signal/runtime-api.js +7 -7
- package/dist/extensions/skill-workshop/api.js +1 -1
- package/dist/extensions/skill-workshop/index.js +1 -1
- package/dist/extensions/synology-chat/api.js +1 -1
- package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/api.js +2 -2
- package/dist/extensions/tlon/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/runtime-api.js +1 -1
- package/dist/extensions/tlon/test-api.js +1 -1
- package/dist/extensions/twitch/api.js +1 -1
- package/dist/extensions/twitch/channel-plugin-api.js +1 -1
- package/dist/extensions/twitch/setup-plugin-api.js +1 -1
- package/dist/extensions/zalo/api.js +3 -3
- package/dist/extensions/zalo/channel-plugin-api.js +1 -1
- package/dist/extensions/zalo/runtime-api.js +2 -2
- package/dist/extensions/zalo/setup-api.js +2 -2
- package/dist/extensions/zalouser/api.js +3 -3
- package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
- package/dist/extensions/zalouser/runtime-api.js +6 -6
- package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
- package/dist/extensions/zalouser/test-api.js +1 -1
- package/dist/fallbacks-BwNexEVP.js +31 -0
- package/dist/fallbacks-GwVAaFt5.js +2 -0
- package/dist/fallbacks-shared-DmepG9Mq.js +111 -0
- package/dist/gateway-BB4hdlYm.js +115 -0
- package/dist/gateway-cli-Bzz62NC8.js +1283 -0
- package/dist/gateway-rpc-dyJV2osv.js +14 -0
- package/dist/gateway-rpc.runtime-DYVOEv4W.js +23 -0
- package/dist/gateway-rpc.runtime.js +1 -1
- package/dist/gateway-runtime-CqSQCYo0.js +15 -0
- package/dist/gateway-status-DdCiwrPt.js +584 -0
- package/dist/genesis-tools-Bh6dAUhK.js +9166 -0
- package/dist/genesis-tools.runtime-CiIUponP.js +2 -0
- package/dist/genesis-tools.runtime.js +1 -1
- package/dist/get-reply-from-config.runtime-Cu2DcwOW.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/get-reply-qVmTjhwr.js +3897 -0
- package/dist/graph-users-kkSJYBNX.js +1337 -0
- package/dist/health-CFyVDYng.js +469 -0
- package/dist/health-Cl371mu8.js +3 -0
- package/dist/health-route-D0IspgUK.js +41 -0
- package/dist/health-route-D2tFKCLv.js +2 -0
- package/dist/heartbeat-runner-Bmi8YsXz.js +5 -0
- package/dist/heartbeat-runner-FSCWra2R.js +1292 -0
- package/dist/heartbeat-runner.runtime-QF8dg4j-.js +4 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/hooks-cli-DYoG7Dz1.js +433 -0
- package/dist/image-fallbacks-5ckuJ46I.js +31 -0
- package/dist/image-fallbacks-DYnqzK01.js +2 -0
- package/dist/inbound-reply-dispatch-D5pqDZRa.js +73 -0
- package/dist/index.js +2 -2
- package/dist/infra-runtime-D08WIqN2.js +39 -0
- package/dist/init-BCgwiSZj.js +59 -0
- package/dist/library-CP9n_7AP.js +45 -0
- package/dist/lifecycle-BYam90xH.js +229 -0
- package/dist/lifecycle-DS58sNmu.js +571 -0
- package/dist/lifecycle.runtime-DMwss7xM.js +2 -0
- package/dist/lifecycle.runtime.js +1 -1
- package/dist/list-CASc4IWz.js +131 -0
- package/dist/list-CBPrBS2u.js +1212 -0
- package/dist/list-Cf7fcqQd.js +2 -0
- package/dist/list-Dqd2QyTH.js +2 -0
- package/dist/list.probe-BWcMSWDF.js +419 -0
- package/dist/llm-slug-generator-4LADFhXT.js +79 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/load-config-DI-LDL6p.js +35 -0
- package/dist/local-dispatch.runtime-WDgraH3j.js +8 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/logs-cli-zoBIelUH.js +265 -0
- package/dist/logs-cli.runtime-DxKNxXAz.js +2 -0
- package/dist/logs-cli.runtime.js +1 -1
- package/dist/main-session-restart-recovery-DWZfkOzH.js +206 -0
- package/dist/managed-image-attachments-DLDa1aE2.js +2 -0
- package/dist/managed-image-attachments-a4v60Bk3.js +635 -0
- package/dist/manager-CfUcsSI9.js +2057 -0
- package/dist/manager-DmBBLCOg.js +2 -0
- package/dist/markdown-to-line-B0mPruD_.js +790 -0
- package/dist/mcp/plugin-tools-serve.js +1 -1
- package/dist/mcp-cli-CLL9nfvE.js +725 -0
- package/dist/mcp-http-p7GbtbMx.js +529 -0
- package/dist/memory-core-host-runtime-cli-CZNYkDoE.js +9 -0
- package/dist/message-CRyNLXch.js +232 -0
- package/dist/message-action-runner-5Y4EFpWh.js +1407 -0
- package/dist/message-action-runner-Dxv-GXkn.js +2 -0
- package/dist/message-actions-DtoR6Mr2.js +143 -0
- package/dist/message.gateway.runtime-RI4cvk_E.js +2 -0
- package/dist/message.gateway.runtime.js +1 -1
- package/dist/models-auth-status-DsheCXaS.js +201 -0
- package/dist/models-cli-CQQG1U-p.js +219 -0
- package/dist/monitor-BRRSjPQY.js +1459 -0
- package/dist/monitor-Ch-cG7Si.js +1661 -0
- package/dist/monitor-ChBhfnC-.js +788 -0
- package/dist/monitor-CsvCTpjq.js +671 -0
- package/dist/monitor-DjemBuVh.js +1237 -0
- package/dist/monitor-LyGEO-KI.js +2 -0
- package/dist/monitor-auth-DVCdDwlp.js +207 -0
- package/dist/monitor-processing-Cib3ZjUe.js +1974 -0
- package/dist/monitor.runtime-DLBFALbV.js +2 -0
- package/dist/monitor.runtime.js +1 -1
- package/dist/monitor.webhook-Dktr8JA-.js +180 -0
- package/dist/msteams-G5I2CO13.js +35 -0
- package/dist/native-hook-relay-B1ArNeG5.js +519 -0
- package/dist/nextcloud-talk-DimOAfaR.js +17 -0
- package/dist/node-cli-RIjV0id4.js +2276 -0
- package/dist/nodes-cli-Cke-B80I.js +1046 -0
- package/dist/nodes-utils-CsTqKwN9.js +84 -0
- package/dist/nodes.helpers-DYpGCFer.js +34 -0
- package/dist/notify-zBChwf0-.js +315 -0
- package/dist/onboard-D6UawRld.js +2 -0
- package/dist/onboard-DfoCtk3_.js +70 -0
- package/dist/onboard-helpers-BKQMe3RX.js +6 -0
- package/dist/onboard-helpers-BLBJlQ50.js +204 -0
- package/dist/onboard-interactive-GAbQD437.js +24 -0
- package/dist/onboard-non-interactive-Bqi-JXh3.js +635 -0
- package/dist/onboard-remote-CNpTyVws.js +193 -0
- package/dist/onboard-remote-GFp2lT6Y.js +2 -0
- package/dist/onboard-skills-BQneolfo.js +2 -0
- package/dist/onboard-skills-BipqJ48b.js +134 -0
- package/dist/openai-http-CLDWjSKC.js +500 -0
- package/dist/openresponses-http-DNvXNiw_.js +1128 -0
- package/dist/operator-approvals-client-gaflvETF.js +68 -0
- package/dist/outbound.runtime-ByVsvEri.js +2 -0
- package/dist/outbound.runtime.js +1 -1
- package/dist/pair-command-approve-Dzkubc-8.js +44 -0
- package/dist/persistent-bindings.lifecycle-BhdRK7Lp.js +2 -0
- package/dist/persistent-bindings.lifecycle-DQ0AiHuy.js +85 -0
- package/dist/pi-embedded-C789hs31.js +4 -0
- package/dist/pi-embedded-CXLkrOwv.js +2905 -0
- package/dist/pi-embedded.runtime-BaHYLgKa.js +4 -0
- package/dist/pi-embedded.runtime.js +1 -1
- package/dist/pi-tool-definition-adapter-DFutc0D4.js +229 -0
- package/dist/pi-tools-k60jrAVq.js +1057 -0
- package/dist/pi-tools.before-tool-call-CFy20GCz.js +2 -0
- package/dist/pi-tools.before-tool-call-DJmPOVfQ.js +433 -0
- package/dist/plugin-BfFuIgXQ.js +12195 -0
- package/dist/plugin-enabled-dXOUnZwX.js +140 -0
- package/dist/plugin-registration-CEAozQhV.js +23 -0
- package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
- package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
- package/dist/plugin-sdk/acp-runtime.js +2 -2
- package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
- package/dist/plugin-sdk/agent-harness.js +6 -6
- package/dist/plugin-sdk/agent-runtime.js +2 -2
- package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
- package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
- package/dist/plugin-sdk/approval-runtime.js +1 -1
- package/dist/plugin-sdk/browser-node-runtime.js +4 -4
- package/dist/plugin-sdk/browser-setup-tools.js +3 -3
- package/dist/plugin-sdk/browser-support.js +7 -7
- package/dist/plugin-sdk/channel-core.js +2 -2
- package/dist/plugin-sdk/channel-inbound.js +2 -2
- package/dist/plugin-sdk/command-auth.js +1 -1
- package/dist/plugin-sdk/command-status-runtime.js +1 -1
- package/dist/plugin-sdk/compat.js +1 -1
- package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
- package/dist/plugin-sdk/conversation-runtime.js +3 -3
- package/dist/plugin-sdk/core.js +2 -2
- package/dist/plugin-sdk/direct-dm.js +1 -1
- package/dist/plugin-sdk/gateway-runtime.js +3 -3
- package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/infra-runtime.js +2 -2
- package/dist/plugin-sdk/irc.js +2 -2
- package/dist/plugin-sdk/matrix.js +1 -1
- package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
- package/dist/plugin-sdk/memory-core.js +2 -2
- package/dist/plugin-sdk/msteams.js +2 -2
- package/dist/plugin-sdk/nextcloud-talk.js +2 -2
- package/dist/plugin-sdk/nostr.js +1 -1
- package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
- package/dist/plugin-sdk/reply-runtime.js +4 -4
- package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
- package/dist/plugin-sdk/runtime.js +2 -2
- package/dist/plugin-sdk/session-visibility.js +1 -1
- package/dist/plugin-sdk/testing.js +4 -4
- package/dist/plugin-sdk/tlon.js +1 -1
- package/dist/plugin-sdk/zalo.js +1 -1
- package/dist/plugin-sdk/zalouser.js +1 -1
- package/dist/plugin-service-BOpLQ8BU.js +2892 -0
- package/dist/plugins/runtime/index.js +1 -1
- package/dist/policy-DiIlt2yW.js +328 -0
- package/dist/postinstall-inventory.json +445 -445
- package/dist/prepare.runtime-Bd8adOy3.js +815 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/probe-BOlTfbzG.js +2 -0
- package/dist/probe-BSRvsN95.js +2205 -0
- package/dist/probe-CDfjQSnz.js +74 -0
- package/dist/probe-D7gHyiZV.js +241 -0
- package/dist/probe-DTNKTWSs.js +2 -0
- package/dist/probe-DcryDdZh.js +45 -0
- package/dist/probe-nyesoHxj.js +1443 -0
- package/dist/program-BFGavenz.js +111 -0
- package/dist/prompt-select-styled-BhY1zahx.js +20 -0
- package/dist/protocol-DxLbSF2J.js +2477 -0
- package/dist/provider-dispatcher-C-yy1D7r.js +22 -0
- package/dist/provider-dispatcher-ErSjESTP.js +2 -0
- package/dist/qr-cli-C1-oy_ho.js +349 -0
- package/dist/qr-cli-DmEs63Sb.js +2 -0
- package/dist/reaction-runtime-api-gua650a7.js +116 -0
- package/dist/reactions-R-rA7cXz.js +998 -0
- package/dist/register-service-commands-DkbqNKVB.js +71 -0
- package/dist/register.agent-C3nW9wDn.js +248 -0
- package/dist/register.configure-BzLHCu95.js +15 -0
- package/dist/register.maintenance-BHFQo4gr.js +363 -0
- package/dist/register.message-CsYRdfKi.js +329 -0
- package/dist/register.onboard-DltySQ6C.js +88 -0
- package/dist/register.runtime-6Sk1Njnp.js +81 -0
- package/dist/register.runtime.js +1 -1
- package/dist/register.setup-CDvVQJuj.js +150 -0
- package/dist/register.status-health-sessions-B8lorJ2x.js +1215 -0
- package/dist/register.subclis-BD4fuAci.js +3 -0
- package/dist/register.subclis-CbRd3F_m.js +29 -0
- package/dist/register.subclis-core-Dtq9dAjI.js +249 -0
- package/dist/reply-dispatch-runtime-DldslKSK.js +13 -0
- package/dist/reply-runtime-2EGTfk-1.js +11 -0
- package/dist/reply.runtime-OaHntzIS.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/restart-health-BjmfJCUM.js +202 -0
- package/dist/restart-health-hw909zlD.js +2 -0
- package/dist/root-help-_hHiERsR.js +44 -0
- package/dist/routes-BxCk7Pue.js +3341 -0
- package/dist/routes-C1_6oFmZ.js +2 -0
- package/dist/rpc-zRbkEo6W.js +61 -0
- package/dist/rpc.runtime-BZSYNDPa.js +21 -0
- package/dist/rpc.runtime.js +1 -1
- package/dist/run-delivery.runtime-D6YDo67d.js +530 -0
- package/dist/run-delivery.runtime.js +1 -1
- package/dist/run-embedded.runtime-BsgPrPDa.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-CggaHhrJ.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime-CKkLEr_T.js +277 -0
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-main-CJYYkV6H.js +567 -0
- package/dist/run-subagent-registry.runtime-B0sgf_oy.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/run-wait-DHizeptL.js +135 -0
- package/dist/runtime-EtV_ChXX.js +9 -0
- package/dist/runtime-api-6H864Pmt.js +9 -0
- package/dist/runtime-api-CbZqRBZQ.js +14 -0
- package/dist/runtime-api-ZxEgu8cW.js +4 -0
- package/dist/runtime-api-j9A6jYUr.js +9 -0
- package/dist/runtime-embedded-pi.runtime-BHjCPnxo.js +2 -0
- package/dist/runtime-embedded-pi.runtime.js +1 -1
- package/dist/runtime-hvRzTSAZ.js +973 -0
- package/dist/runtime-internal-C_KZYzFK.js +2 -0
- package/dist/runtime-options-BZEOCnMg.js +275 -0
- package/dist/runtime-schema-R7LWe58K.js +28576 -0
- package/dist/scan-BNDE3dSE.js +523 -0
- package/dist/scan-TG6lVEQ2.js +2 -0
- package/dist/secrets-cli-twD2FWoZ.js +2101 -0
- package/dist/security-cli-Cd1A5yhL.js +486 -0
- package/dist/selection-CqqmU0Hi.js +7764 -0
- package/dist/selection-CsM62vcz.js +2 -0
- package/dist/send-D-EgB64m.js +156 -0
- package/dist/send-DPk5hW1W.js +102 -0
- package/dist/send.runtime-3QDkKN71.js +2 -0
- package/dist/send.runtime.js +1 -1
- package/dist/server-C94r_Qff.js +77 -0
- package/dist/server-Ceiopn_v.js +13 -0
- package/dist/server-context-BFJlu5HY.js +2 -0
- package/dist/server-context-PNEqhnTM.js +847 -0
- package/dist/server-node-events-QOAWLsDC.js +481 -0
- package/dist/server-plugin-bootstrap-CgsjzB17.js +2 -0
- package/dist/server-plugin-bootstrap-Dfuf75EN.js +12728 -0
- package/dist/server-restart-sentinel-BMPqZ7Jw.js +697 -0
- package/dist/server.impl-CCoQpvB7.js +12864 -0
- package/dist/session-kill-http-oPi3ajEp.js +110 -0
- package/dist/session-reset-service-CzDd6PBK.js +497 -0
- package/dist/session-route-DUOQE8-f.js +93 -0
- package/dist/session-status.runtime-W5tlGbXw.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-yoYn1awK.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-DkeCaT-2.js +581 -0
- package/dist/session-visibility-B4CFjv43.js +147 -0
- package/dist/sessions-helpers-CDfOVWe3.js +305 -0
- package/dist/sessions-history-http-QXeTdxXM.js +383 -0
- package/dist/sessions-patch-xb4bXPwh.js +309 -0
- package/dist/sessions-resolve-BPlrW8C3.js +174 -0
- package/dist/sessions.runtime-yYJXudA9.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/setup-0Im0LL1d.js +636 -0
- package/dist/setup-api-BxwfqXN-.js +29 -0
- package/dist/setup-core-BWwXgEuM.js +171 -0
- package/dist/setup-core-DzHNbQLG.js +176 -0
- package/dist/setup-surface-BVnqDsfU.js +286 -0
- package/dist/setup-surface-BajZWmKz2.js +403 -0
- package/dist/setup-surface-rDO3YjSb.js +219 -0
- package/dist/setup.finalize-BsnPbdwc.js +547 -0
- package/dist/setup.gateway-config-BFawSWHL.js +250 -0
- package/dist/shared-52tFSlVk.js +121 -0
- package/dist/shared-C8ENgtxM.js +198 -0
- package/dist/shared-DbXvU7JV.js +76 -0
- package/dist/slash-state-CMuPwgKt.js +1911 -0
- package/dist/src-IzaHgU6a.js +3974 -0
- package/dist/startup-context-xJS8ckSG.js +312 -0
- package/dist/status-BO4LMTER.js +2 -0
- package/dist/status-BwY1tASe.js +3 -0
- package/dist/status-BxG6n-ko.js +397 -0
- package/dist/status-Co_cq2vy.js +2 -0
- package/dist/status-DKNeRGzW.js +190 -0
- package/dist/status-DzlIHiTS.js +209 -0
- package/dist/status-all-DF7qaWjo.js +498 -0
- package/dist/status-json-CgCilobT.js +14 -0
- package/dist/status-json-command-DAa78z3e.js +84 -0
- package/dist/status-runtime-shared-CRCuxXn_.js +257 -0
- package/dist/status-subagents.runtime-hUsBd4C5.js +18 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-BdbRrl1G.js +237 -0
- package/dist/status.gateway-connection.runtime-BmSTYFFO.js +2 -0
- package/dist/status.gateway-connection.runtime.js +1 -1
- package/dist/status.gather-CItmFIHS.js +292 -0
- package/dist/status.gather-qB6WOoH7.js +2 -0
- package/dist/status.runtime-ClZCgYx1.js +2 -0
- package/dist/status.runtime.js +1 -1
- package/dist/status.scan-overview-B0b0Mvng.js +379 -0
- package/dist/status.scan-xY7nUi9N.js +65 -0
- package/dist/status.scan.fast-json-BANGHOys.js +132 -0
- package/dist/status.scan.fast-json-M-DmMy2l.js +2 -0
- package/dist/status.summary-B3PlFnWw.js +2 -0
- package/dist/status.summary-adB75FOM.js +214 -0
- package/dist/subagent-announce-B4w7Mcpr.js +351 -0
- package/dist/subagent-announce-delivery-Dma0A4gL.js +726 -0
- package/dist/subagent-announce-output-sUPLcge-.js +364 -0
- package/dist/subagent-control-CxR0WRrx.js +506 -0
- package/dist/subagent-followup.runtime-XeFe_LA0.js +68 -0
- package/dist/subagent-followup.runtime.js +1 -1
- package/dist/subagent-orphan-recovery-CJPHy8JV.js +305 -0
- package/dist/subagent-registry-CjMWjRCE.js +1753 -0
- package/dist/subagent-registry-H20VxEu0.js +3 -0
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-spawn-CRM5x6cV.js +1005 -0
- package/dist/system-cli-BJ5mMirj.js +59 -0
- package/dist/targets-CUnlEj96.js +67 -0
- package/dist/task-executor-DKnEwQ6v.js +360 -0
- package/dist/task-owner-access-CfypP1Yc.js +74 -0
- package/dist/task-registry-delivery-runtime-BB6ZzpqH.js +2 -0
- package/dist/task-registry-delivery-runtime-CvHa0gv-.js +3 -0
- package/dist/task-registry-pQuAfAL9.js +2366 -0
- package/dist/task-registry.maintenance-Bfd87wEV.js +416 -0
- package/dist/task-registry.maintenance-VgfbW0yt.js +2 -0
- package/dist/telegram/token.js +1 -1
- package/dist/testing-C_mngO0u.js +575 -0
- package/dist/text-report-Ct6t3he6.js +587 -0
- package/dist/tool-resolution-C4KGgPH-.js +90 -0
- package/dist/tools-effective-inventory-Bo2QC-m8.js +152 -0
- package/dist/tools-invoke-http-CBZPFh5L.js +206 -0
- package/dist/trash-DhZow3jd.js +24 -0
- package/dist/tui-cli-BPdQPozP.js +4575 -0
- package/dist/update-cli-BRi3mVAU.js +1759 -0
- package/dist/upgrade-D9zejtCk.js +1226 -0
- package/dist/video-generation-task-status-BSBQ0_FO.js +163 -0
- package/dist/wait-for-idle-before-flush-D1dTT9th.js +5986 -0
- package/dist/wizard-models-ysyV_WWR.js +334 -0
- package/package.json +1 -1
- package/dist/abort-DaihtnYj.js +0 -201
- package/dist/abort.runtime-BUT9L_5l.js +0 -2
- package/dist/accounts-BY5wsBnV.js +0 -104
- package/dist/accounts-DGth1vsM.js +0 -107
- package/dist/accounts-Do6Ir-q3.js +0 -2
- package/dist/acp-cli-BHgjn8rh.js +0 -2193
- package/dist/acp-spawn-BAM_Jrft.js +0 -2
- package/dist/acp-spawn-DyBD_Y_t.js +0 -1093
- package/dist/acp-stateful-target-driver-DKGnfjWu.js +0 -89
- package/dist/action-agents-CzMSNQdc.js +0 -67
- package/dist/action-focus-CpjIrZFe.js +0 -132
- package/dist/action-help-BhE9UosK.js +0 -7
- package/dist/action-info-CH2j6dKT.js +0 -101
- package/dist/action-kill-CB4AnLIf.js +0 -33
- package/dist/action-list-CQ8LbzvR.js +0 -21
- package/dist/action-log-DZblh247.js +0 -30
- package/dist/action-send-DMe0B4FG.js +0 -39
- package/dist/action-spawn-CkKMESb5.js +0 -47
- package/dist/action-unfocus-DjQzPZwU.js +0 -29
- package/dist/actions.runtime-CUdRdpLB.js +0 -5
- package/dist/actions.runtime-CxRstWdN.js +0 -18
- package/dist/agent-command-Nh_kPL3z.js +0 -874
- package/dist/agent-harness-runtime-BEb7Wk1m.js +0 -144
- package/dist/agent-q6U-cKJn.js +0 -2
- package/dist/agent-runner-utils-x_qJ6xYC.js +0 -239
- package/dist/agent-runner.runtime-DRvTfUPd.js +0 -3455
- package/dist/agent-runtime-jSYYQd6f.js +0 -18
- package/dist/agents-BKOpsZXw.js +0 -5
- package/dist/agents-BY34ViPX.js +0 -954
- package/dist/aliases-CD5YlX7d.js +0 -2
- package/dist/aliases-Dq31zANx.js +0 -96
- package/dist/api-BhxN9fxJ.js +0 -139
- package/dist/api-DjL_3olO.js +0 -5
- package/dist/api-jIYND-S5.js +0 -3
- package/dist/approval-gateway-resolver-BfvdJW5s.js +0 -29
- package/dist/approval-gateway-runtime-BBf976nt.js +0 -2
- package/dist/approval-handler-runtime-Bq4p5wvg.js +0 -439
- package/dist/approval-native-runtime-IrisOZrU.js +0 -729
- package/dist/attempt-execution.runtime-BXGalt-_.js +0 -509
- package/dist/attempt.prompt-helpers-A-pc2LfL.js +0 -221
- package/dist/attempt.tool-run-context-Ukna4ck-.js +0 -933
- package/dist/audit-CVUpfDvE.js +0 -939
- package/dist/audit.runtime-CsuGXvud.js +0 -7
- package/dist/auth-CjcZyRUW.js +0 -383
- package/dist/auth-order-DIkyTpW4.js +0 -2
- package/dist/auth-order-Dpt1K1rT.js +0 -96
- package/dist/auth-sVuL2xeZ.js +0 -2
- package/dist/bash-tools-DDv0zQh9.js +0 -2824
- package/dist/bash-tools-s-QSvRmt.js +0 -3
- package/dist/binding-routing-Cz5R2kFK.js +0 -85
- package/dist/binding-targets-D4j2hdQh.js +0 -121
- package/dist/bridge-server-X8SdeAI3.js +0 -113
- package/dist/browser-control-auth-BrF3DZxC.js +0 -2
- package/dist/browser-node-runtime-BecPmKOx.js +0 -12
- package/dist/browser-profiles-BxAKEG3x.js +0 -2
- package/dist/browser-runtime-D9fTDscJ.js +0 -387
- package/dist/browser-setup-tools--AQGWGvl.js +0 -13
- package/dist/build-B0nbyXrw.js +0 -550
- package/dist/call-BvqN9kay.js +0 -3
- package/dist/call-Dk5rTl-p.js +0 -331
- package/dist/call.runtime-Bx1hKDwO.js +0 -2
- package/dist/capability-cli-286Z3Bq3.js +0 -1401
- package/dist/catchup-DyeQ6GNj.js +0 -300
- package/dist/channel-B5m01jSZ.js +0 -1802
- package/dist/channel-BE26v3WU.js +0 -840
- package/dist/channel-BS7r_Zt1.js +0 -226
- package/dist/channel-BUWCqkGh.js +0 -1320
- package/dist/channel-BhgKqvZn.js +0 -453
- package/dist/channel-Bx703sxQ.js +0 -297
- package/dist/channel-CDjlEQAM.js +0 -491
- package/dist/channel-ChrqAgRS.js +0 -595
- package/dist/channel-Crmp3BHh.js +0 -1100
- package/dist/channel-D7GdDfBl.js +0 -1174
- package/dist/channel-DqSzRIul.js +0 -350
- package/dist/channel-core-DIwclC34.js +0 -5
- package/dist/channel-inbound-DPW1gRUU.js +0 -31
- package/dist/channel-plugin-runtime-BJhRSlBI.js +0 -771
- package/dist/channel-runtime-sV_Sg0EO.js +0 -425
- package/dist/channel.runtime-4BaNapRW.js +0 -89
- package/dist/channel.runtime-Bk2w0Yzd.js +0 -2364
- package/dist/channel.runtime-Bo5_2imz.js +0 -109
- package/dist/channel.runtime-CdYWlMyL.js +0 -40130
- package/dist/channel.runtime-CrYmCmSw.js +0 -4
- package/dist/channel.runtime-D3APPhVs.js +0 -430
- package/dist/channel.runtime-DjF1Gg6N.js +0 -576
- package/dist/channel.setup-BxXrmAYb.js +0 -10
- package/dist/channels-DHcJgMnw.js +0 -733
- package/dist/channels-cli-Dnq08u4r.js +0 -268
- package/dist/chat-BGU3UVKD.js +0 -2830
- package/dist/clawbot-cli-C-rqJUW-.js +0 -9
- package/dist/cli-BlnGJbLJ.js +0 -219
- package/dist/cli-D0RU1q0-.js +0 -2
- package/dist/cli-DBw79G2t.js +0 -72
- package/dist/cli-Dul37_xp.js +0 -2
- package/dist/cli-runner-DY8BKEmu.js +0 -286
- package/dist/cli-runner.runtime-5JMuegF9.js +0 -3
- package/dist/cli-runner.runtime-DQROn9Ve.js +0 -4
- package/dist/cli.runtime-CGOUREQg.js +0 -1261
- package/dist/client-CCBN1ydB.js +0 -138
- package/dist/client-PHLyQ8il.js +0 -713
- package/dist/command-auth-79QKQZZ3.js +0 -76
- package/dist/command-config-resolution-BKAgMItc.js +0 -2
- package/dist/command-config-resolution-BUCAmCZ_.js +0 -23
- package/dist/command-config-resolution.runtime-BVtfeARM.js +0 -2
- package/dist/command-registry-C9axn0de.js +0 -4
- package/dist/command-registry-DkcFlIyM.js +0 -9
- package/dist/command-registry-core-DEDRtJmS.js +0 -106
- package/dist/command-secret-gateway-g0alGmKz.js +0 -528
- package/dist/command-status.runtime-Dw6Zj5hL.js +0 -87
- package/dist/commands-acp-De-XFc40.js +0 -77
- package/dist/commands-compact.runtime-6gixR2a8.js +0 -10
- package/dist/commands-handlers.runtime-DCmZAlRN.js +0 -4599
- package/dist/commands-status-CION7GYY.js +0 -16
- package/dist/commands-status.runtime-FBwoHftv.js +0 -3
- package/dist/commands-subagents-control.runtime-C2xgOYKM.js +0 -2
- package/dist/commands-subagents-control.runtime-CgIEblx3.js +0 -3
- package/dist/commands-system-prompt-B-jC-KV-.js +0 -158
- package/dist/commands-system-prompt-DeK5Jhy_.js +0 -2
- package/dist/commands.runtime-CHSb1kYa.js +0 -167
- package/dist/compact-Dwchggv2.js +0 -1118
- package/dist/compact.runtime-jDUYMSjR.js +0 -12
- package/dist/completion-cli-DGiZcg4E.js +0 -328
- package/dist/config-Bnb9qa1S.js +0 -252
- package/dist/config-cli-BuZ5RUhD.js +0 -1078
- package/dist/configure-BLNGlWh0.js +0 -1252
- package/dist/configure-nPzsEeOb.js +0 -2
- package/dist/connect-options-C9cvS-bh.js +0 -699
- package/dist/control-auth-D2-P54fW.js +0 -125
- package/dist/control-service-CqUPgxlx.js +0 -156
- package/dist/control-ui/assets/agents-CA3uz9sP.js +0 -1052
- package/dist/control-ui/assets/canvas-D0sLy568.js +0 -269
- package/dist/control-ui/assets/channel-config-extras-CWzNTLS-.js +0 -2
- package/dist/control-ui/assets/channels-DXgjbWts.js +0 -463
- package/dist/control-ui/assets/cron-D-rffMH6.js +0 -933
- package/dist/control-ui/assets/de-l9FbKtxt.js +0 -2
- package/dist/control-ui/assets/debug-Vf_bLYLB.js +0 -94
- package/dist/control-ui/assets/es-CC-t9AUQ.js +0 -2
- package/dist/control-ui/assets/format-BL-FisEP.js +0 -9
- package/dist/control-ui/assets/fr-DZKceqST.js +0 -2
- package/dist/control-ui/assets/i18n-DFH8x0DD.js +0 -3
- package/dist/control-ui/assets/id-D93YKkrM.js +0 -2
- package/dist/control-ui/assets/index-lWAwAXYo.js +0 -6366
- package/dist/control-ui/assets/instances-BmzzTloa.js +0 -57
- package/dist/control-ui/assets/ja-JP-DoPdk5L_.js +0 -2
- package/dist/control-ui/assets/ko-8TeOGGHm.js +0 -2
- package/dist/control-ui/assets/logs-BjPSImvD.js +0 -74
- package/dist/control-ui/assets/mcp-CQGmuKdR.js +0 -281
- package/dist/control-ui/assets/nodes-CDhqPGsD.js +0 -618
- package/dist/control-ui/assets/pl-BSP1Y3tH.js +0 -2
- package/dist/control-ui/assets/plugins-D4fXQx07.js +0 -273
- package/dist/control-ui/assets/pt-BR-D4-81_zm.js +0 -2
- package/dist/control-ui/assets/sessions-DzjXl7P7.js +0 -306
- package/dist/control-ui/assets/skills-BTQrLVPj.js +0 -323
- package/dist/control-ui/assets/skills-shared-CX4mwYFK.js +0 -11
- package/dist/control-ui/assets/th-DrnubOIu.js +0 -2
- package/dist/control-ui/assets/tr-BMyrj0eZ.js +0 -2
- package/dist/control-ui/assets/uk-CZhU3bHK.js +0 -2
- package/dist/control-ui/assets/wallet-DPb6whuj.js +0 -285
- package/dist/control-ui/assets/zh-CN-CH12jxSw.js +0 -2
- package/dist/control-ui/assets/zh-TW-CaTySceX.js +0 -2
- package/dist/conversation-id-BAzJOKBB.js +0 -235
- package/dist/conversation-id-WJLKuyy9.js +0 -38
- package/dist/conversation-runtime-D8fK5aI0.js +0 -31
- package/dist/core-DywmHt1k.js +0 -275
- package/dist/cron-cli-CeEJRkfR.js +0 -713
- package/dist/daemon-cli-BZZOjJHx.js +0 -12
- package/dist/dashboard-C0NRxmP3.js +0 -81
- package/dist/dashboard-DqhPgQv-.js +0 -2
- package/dist/delegate-DwVbOeR5.js +0 -64
- package/dist/detached-task-runtime-DiDRj-v-.js +0 -73
- package/dist/devices-cli-BKVbpwVc.js +0 -498
- package/dist/diagnostics-gh3UN_iV.js +0 -154
- package/dist/direct-dm-CwHHUkHV.js +0 -64
- package/dist/dispatch-B5af8_1v.js +0 -1131
- package/dist/dispatch-acp-DgOnUWBl.js +0 -981
- package/dist/dispatch-acp-manager.runtime-XWNjVh_M.js +0 -3
- package/dist/dispatch-acp.runtime-BdYL_ZqM.js +0 -19
- package/dist/doctor-device-pairing-CtGzWmXB.js +0 -307
- package/dist/doctor-gateway-daemon-flow-CCBI0jL4.js +0 -250
- package/dist/doctor-gateway-health-CkjqPFDl.js +0 -63
- package/dist/doctor-health-BOhuy1vP.js +0 -59
- package/dist/doctor-health-contributions-ChEuyLAY.js +0 -493
- package/dist/doctor-prompter-9nOTFD0Q.js +0 -56
- package/dist/doctor-workspace-status-CO5Ocwlt.js +0 -75
- package/dist/dreaming-GOPEFPio.js +0 -1574
- package/dist/dreaming-narrative-DfxHaxOU.js +0 -595
- package/dist/embedded-gateway-stub.runtime-B2OWcbsK.js +0 -9
- package/dist/exec-approvals-cli-CGeFtFbB.js +0 -498
- package/dist/fallbacks-CdfWAgNP.js +0 -2
- package/dist/fallbacks-eXbQ8TBp.js +0 -31
- package/dist/fallbacks-shared-akcCu5CD.js +0 -111
- package/dist/gateway-D-dDKqwi.js +0 -115
- package/dist/gateway-cli-DBS06Da8.js +0 -1283
- package/dist/gateway-rpc-Cxa8dVW5.js +0 -14
- package/dist/gateway-rpc.runtime-D76s-oxs.js +0 -23
- package/dist/gateway-runtime-Dhm_gLh1.js +0 -15
- package/dist/gateway-status-C_L_CdOg.js +0 -584
- package/dist/genesis-tools-rRJB3JXY.js +0 -9166
- package/dist/genesis-tools.runtime-6oKokqaA.js +0 -2
- package/dist/get-reply-BkiDsDVY.js +0 -3897
- package/dist/get-reply-from-config.runtime-CHKCcj9D.js +0 -2
- package/dist/graph-users-BnXIYyC5.js +0 -1337
- package/dist/health-ZsJNENSY.js +0 -3
- package/dist/health-osa9LOJf.js +0 -469
- package/dist/health-route-8TdKOYLp.js +0 -2
- package/dist/health-route-BdLtX2Bg.js +0 -41
- package/dist/heartbeat-runner-BCbkAprr.js +0 -1292
- package/dist/heartbeat-runner-Dc1K8S94.js +0 -5
- package/dist/heartbeat-runner.runtime-pJaAsgLY.js +0 -4
- package/dist/hooks-cli-C3ggAz0i.js +0 -433
- package/dist/image-fallbacks-CiSae-lb.js +0 -2
- package/dist/image-fallbacks-vI8KUh6N.js +0 -31
- package/dist/inbound-reply-dispatch-DLM60UDh.js +0 -73
- package/dist/infra-runtime-CrHVeejV.js +0 -39
- package/dist/init-BKeEiV2q.js +0 -59
- package/dist/library-CHB7yTo5.js +0 -45
- package/dist/lifecycle-CUULToPr.js +0 -229
- package/dist/lifecycle-DCMpTRD2.js +0 -571
- package/dist/lifecycle.runtime-CP4gRxWv.js +0 -2
- package/dist/list-0zDFAWTF.js +0 -2
- package/dist/list-BaxVHTAN.js +0 -131
- package/dist/list-CMRMgrPs.js +0 -1212
- package/dist/list-DSrBtnKI.js +0 -2
- package/dist/list.probe-BJYSCsJY.js +0 -419
- package/dist/llm-slug-generator-Bn_wrWYw.js +0 -79
- package/dist/load-config-qC2BWt8E.js +0 -35
- package/dist/local-dispatch.runtime-DyU7urGc.js +0 -8
- package/dist/logs-cli-zK71r_PE.js +0 -265
- package/dist/logs-cli.runtime-k0UtiaRP.js +0 -2
- package/dist/main-session-restart-recovery-DMT0Oj9a.js +0 -206
- package/dist/managed-image-attachments-B6XXE4--.js +0 -635
- package/dist/managed-image-attachments-BTzWoDWE.js +0 -2
- package/dist/manager-BCKuWA67.js +0 -2057
- package/dist/manager-rGwNUzMp.js +0 -2
- package/dist/markdown-to-line-DmPbXQA1.js +0 -790
- package/dist/mcp-cli-CYpPNMcE.js +0 -725
- package/dist/mcp-http-wiE81iKg.js +0 -529
- package/dist/memory-core-host-runtime-cli-BOSQRX1T.js +0 -9
- package/dist/message-CUDzVGD8.js +0 -232
- package/dist/message-action-runner-Dy0IpKa4.js +0 -1407
- package/dist/message-action-runner-KkBFzZdg.js +0 -2
- package/dist/message-actions-Dcdb5aSR.js +0 -143
- package/dist/message.gateway.runtime-D86fFO99.js +0 -2
- package/dist/models-auth-status-DkiX4s0b.js +0 -201
- package/dist/models-cli-CSUot1R3.js +0 -219
- package/dist/monitor-BA8ByMKR.js +0 -2
- package/dist/monitor-Bv1GIHW5.js +0 -1661
- package/dist/monitor-DTFY0ruF.js +0 -788
- package/dist/monitor-DXH-vNGn.js +0 -1459
- package/dist/monitor-Df5k8NGk.js +0 -671
- package/dist/monitor-Dk2YRF26.js +0 -1237
- package/dist/monitor-auth-CZOW753A.js +0 -207
- package/dist/monitor-processing-Clta8N4C.js +0 -1974
- package/dist/monitor.runtime-3ORbPT0X.js +0 -2
- package/dist/monitor.webhook-CRyTxENk.js +0 -180
- package/dist/msteams-BE0VieXF.js +0 -35
- package/dist/native-hook-relay-DAwGGuEx.js +0 -519
- package/dist/nextcloud-talk-DfYlTFsm.js +0 -17
- package/dist/node-cli-Bzyci_X_.js +0 -2276
- package/dist/nodes-cli-Er3OZkuk.js +0 -1046
- package/dist/nodes-utils-Cp8QZO8-.js +0 -84
- package/dist/nodes.helpers-CwKAAnRA.js +0 -34
- package/dist/notify-D_5n_vEJ.js +0 -315
- package/dist/onboard-BE82RudQ.js +0 -2
- package/dist/onboard-Bk4xL8X7.js +0 -70
- package/dist/onboard-helpers-D4WYa-6g.js +0 -204
- package/dist/onboard-helpers-MuFxPZg5.js +0 -6
- package/dist/onboard-interactive-0zmI-9ia.js +0 -24
- package/dist/onboard-non-interactive-DIRB95mT.js +0 -635
- package/dist/onboard-remote-7qR1knbU.js +0 -2
- package/dist/onboard-remote-CLmoySkk.js +0 -193
- package/dist/onboard-skills-C_873OK_.js +0 -134
- package/dist/onboard-skills-DrlBYc0t.js +0 -2
- package/dist/openai-http-DzCBqW6b.js +0 -500
- package/dist/openresponses-http-B2zgO5hQ.js +0 -1128
- package/dist/operator-approvals-client-mGBl4ptH.js +0 -68
- package/dist/outbound.runtime--HS-MxM_.js +0 -2
- package/dist/pair-command-approve-CCTSQKJH.js +0 -44
- package/dist/persistent-bindings.lifecycle-CnmqGsQf.js +0 -85
- package/dist/persistent-bindings.lifecycle-Dav1TX9E.js +0 -2
- package/dist/pi-embedded-BSKL8IgF.js +0 -4
- package/dist/pi-embedded-DMM8Pfp7.js +0 -2905
- package/dist/pi-embedded.runtime-Bv_roBVx.js +0 -4
- package/dist/pi-tool-definition-adapter-OrxjlSIM.js +0 -229
- package/dist/pi-tools-DD1YegeL.js +0 -1057
- package/dist/pi-tools.before-tool-call-J9ujp9Wp.js +0 -433
- package/dist/pi-tools.before-tool-call-hGEgKGZQ.js +0 -2
- package/dist/plugin-Cg3pHepG.js +0 -12195
- package/dist/plugin-enabled-wEQ8BQNw.js +0 -140
- package/dist/plugin-registration-DLcLJgqz.js +0 -23
- package/dist/plugin-service-BogBl5qk.js +0 -2892
- package/dist/policy-Bkh8Xtnb.js +0 -328
- package/dist/prepare.runtime-Cd31ie7u.js +0 -815
- package/dist/probe-9IM22Rkf.js +0 -2
- package/dist/probe-ButCyV3d.js +0 -1443
- package/dist/probe-D7QBUio1.js +0 -45
- package/dist/probe-DV6CWm0r.js +0 -74
- package/dist/probe-DkfetvwA.js +0 -2
- package/dist/probe-Dxo-LQjn.js +0 -2205
- package/dist/probe-nil3qQAV.js +0 -241
- package/dist/program-AcjZFtZQ.js +0 -111
- package/dist/prompt-select-styled-BSf77q2T.js +0 -20
- package/dist/protocol-C4I0nfuT.js +0 -2477
- package/dist/provider-dispatcher-CkiPxKIr.js +0 -22
- package/dist/provider-dispatcher-PmsHJlUO.js +0 -2
- package/dist/qr-cli-BHY0TO2W.js +0 -2
- package/dist/qr-cli-BbjDJSKp.js +0 -349
- package/dist/reaction-runtime-api-DOigJrbq.js +0 -116
- package/dist/reactions-CogkrjNr.js +0 -998
- package/dist/register-service-commands-IA3Nfza5.js +0 -71
- package/dist/register.agent-DD0aSYye.js +0 -248
- package/dist/register.configure-BOy4i7Ah.js +0 -15
- package/dist/register.maintenance-CUp6FEOF.js +0 -363
- package/dist/register.message-DezTIpNI.js +0 -329
- package/dist/register.onboard-Brpxl9p3.js +0 -88
- package/dist/register.runtime-BfH5rSb_.js +0 -81
- package/dist/register.setup-CIt4FVv0.js +0 -150
- package/dist/register.status-health-sessions-IbGZwSaG.js +0 -1215
- package/dist/register.subclis-B1H4fYxP.js +0 -29
- package/dist/register.subclis-D-_xtNVs.js +0 -3
- package/dist/register.subclis-core-CkJelRU8.js +0 -249
- package/dist/reply-dispatch-runtime-Lu4Metex.js +0 -13
- package/dist/reply-runtime-CgPzru94.js +0 -11
- package/dist/reply.runtime-sw14BA5F.js +0 -2
- package/dist/restart-health-1MNBua3p.js +0 -202
- package/dist/restart-health-BWGpwgPv.js +0 -2
- package/dist/root-help-B3zoC2OP.js +0 -44
- package/dist/routes-BM6fbday.js +0 -3341
- package/dist/routes-pVc_QLiP.js +0 -2
- package/dist/rpc-BGOWS7nj.js +0 -61
- package/dist/rpc.runtime-Ca9K3sx8.js +0 -21
- package/dist/run-delivery.runtime-CabntI64.js +0 -530
- package/dist/run-embedded.runtime-Q7wrP6Qn.js +0 -4
- package/dist/run-execution-cli.runtime-CtRUFc-M.js +0 -4
- package/dist/run-executor.runtime-Nm38xsKA.js +0 -277
- package/dist/run-main-kE0nFgvK.js +0 -567
- package/dist/run-subagent-registry.runtime-D9_scMUr.js +0 -2
- package/dist/run-wait-B2K_6JNL.js +0 -135
- package/dist/runtime-BZ296jTK.js +0 -9
- package/dist/runtime-DnZsw7MB.js +0 -973
- package/dist/runtime-api-BL9vpbvb.js +0 -14
- package/dist/runtime-api-BbsLJB4C.js +0 -9
- package/dist/runtime-api-ChwFrQRw.js +0 -9
- package/dist/runtime-api-_fH7M3Qh.js +0 -4
- package/dist/runtime-embedded-pi.runtime-TOdW-E-2.js +0 -2
- package/dist/runtime-internal-DGwOFi_E.js +0 -2
- package/dist/runtime-options-CSPfxkb1.js +0 -275
- package/dist/runtime-schema-CMRvOPkk.js +0 -28576
- package/dist/scan-D6gkNpKl.js +0 -523
- package/dist/scan-_9J5-5L6.js +0 -2
- package/dist/secrets-cli-DlVSRQPM.js +0 -2101
- package/dist/security-cli-DtzNOYL2.js +0 -486
- package/dist/selection-CBJZE_FL.js +0 -7764
- package/dist/selection-XsoEF2p2.js +0 -2
- package/dist/send-BAaDBRfi.js +0 -156
- package/dist/send-BB-M1afy.js +0 -102
- package/dist/send.runtime-CI_75KUP.js +0 -2
- package/dist/server-B_BiVYFv.js +0 -13
- package/dist/server-D58E1Cua.js +0 -77
- package/dist/server-context-D5AnCc1E.js +0 -2
- package/dist/server-context-bt09wrJu.js +0 -847
- package/dist/server-node-events-CUx4-7FL.js +0 -481
- package/dist/server-plugin-bootstrap-CU5P500z.js +0 -12708
- package/dist/server-plugin-bootstrap-CXm9xWXR.js +0 -2
- package/dist/server-restart-sentinel-ByFI_0MB.js +0 -697
- package/dist/server.impl-BBBEDK9u.js +0 -12864
- package/dist/session-kill-http-9MoO6FXC.js +0 -110
- package/dist/session-reset-service-redPsOs-.js +0 -497
- package/dist/session-route-C8oB2UYs.js +0 -93
- package/dist/session-status.runtime-D3bYBPJe.js +0 -2
- package/dist/session-subagent-reactivation.runtime-aat7tUag.js +0 -2
- package/dist/session-tab-registry-CAJ_oDsb.js +0 -581
- package/dist/session-visibility-Dq88jJYB.js +0 -147
- package/dist/sessions-helpers-C8-IkqhO.js +0 -305
- package/dist/sessions-history-http-4Ftuwnes.js +0 -383
- package/dist/sessions-patch-BsyNHOaz.js +0 -309
- package/dist/sessions-resolve-gKLz2Bup.js +0 -174
- package/dist/sessions.runtime-C1W59rQY.js +0 -2
- package/dist/setup-DhvXyU_5.js +0 -636
- package/dist/setup-api-B9Y4qPgq.js +0 -29
- package/dist/setup-core-CdFQ6ZXC.js +0 -176
- package/dist/setup-core-kXUD3Kat.js +0 -171
- package/dist/setup-surface-BFL9WfBs.js +0 -219
- package/dist/setup-surface-Cxg_nSWc.js +0 -286
- package/dist/setup-surface-DbooMj782.js +0 -403
- package/dist/setup.finalize-CKxukDYi.js +0 -547
- package/dist/setup.gateway-config-BhEtXwaB.js +0 -250
- package/dist/shared-BNVKrp5y.js +0 -76
- package/dist/shared-CM3mnx7z.js +0 -198
- package/dist/shared-CfrsSVhL.js +0 -121
- package/dist/slash-state-2Z-om57Q.js +0 -1911
- package/dist/src-DAoKvK_N.js +0 -3974
- package/dist/startup-context-CtYAdYwd.js +0 -312
- package/dist/status-B2M0Imij.js +0 -3
- package/dist/status-Bd-BNmiE.js +0 -2
- package/dist/status-D6nbpHFi.js +0 -397
- package/dist/status-MByUxUGu.js +0 -209
- package/dist/status-QUjO1tkz.js +0 -2
- package/dist/status-all-DPa-BiHk.js +0 -498
- package/dist/status-erNo8YmW.js +0 -190
- package/dist/status-json-command-C9rbAyj-.js +0 -84
- package/dist/status-json-tO3CQXIQ.js +0 -14
- package/dist/status-runtime-shared-DmBB_gmT.js +0 -257
- package/dist/status-subagents.runtime-BXAZr5y0.js +0 -18
- package/dist/status-text-BCeYk0-q.js +0 -237
- package/dist/status.gateway-connection.runtime-bt35dapy.js +0 -2
- package/dist/status.gather-B9a-CEev.js +0 -292
- package/dist/status.gather-ahBLFzk6.js +0 -2
- package/dist/status.runtime-BrErwtfc.js +0 -2
- package/dist/status.scan-D2mvM4II.js +0 -65
- package/dist/status.scan-overview-uOOaqp1t.js +0 -379
- package/dist/status.scan.fast-json-C9dkN28s.js +0 -2
- package/dist/status.scan.fast-json-DY3Or8S4.js +0 -132
- package/dist/status.summary-Cf4p2BPK.js +0 -2
- package/dist/status.summary-DxfZCcNa.js +0 -214
- package/dist/subagent-announce-CyQZsAIm.js +0 -351
- package/dist/subagent-announce-delivery-CgdPNjMA.js +0 -726
- package/dist/subagent-announce-output-D1xi4Tk1.js +0 -364
- package/dist/subagent-control-D-O6I8Mt.js +0 -506
- package/dist/subagent-followup.runtime-BbA7NPAq.js +0 -68
- package/dist/subagent-orphan-recovery-C6_cmAyE.js +0 -305
- package/dist/subagent-registry-Dn_XpDh0.js +0 -1753
- package/dist/subagent-registry-DodFw3pu.js +0 -3
- package/dist/subagent-spawn-Dw5lttXp.js +0 -1005
- package/dist/system-cli-CSqO2Z4K.js +0 -59
- package/dist/targets-CMdwh9lR.js +0 -67
- package/dist/task-executor-DgZSfcBk.js +0 -360
- package/dist/task-owner-access-9c38idlo.js +0 -74
- package/dist/task-registry-Z-lBPkNj.js +0 -2366
- package/dist/task-registry-delivery-runtime-DOV4qoj4.js +0 -2
- package/dist/task-registry-delivery-runtime-EATr0C3C.js +0 -3
- package/dist/task-registry.maintenance-C1YMEwhk.js +0 -416
- package/dist/task-registry.maintenance-CBfaUWcp.js +0 -2
- package/dist/testing-CFk04o9M.js +0 -575
- package/dist/text-report-QhVG354o.js +0 -587
- package/dist/tool-resolution-D6V4tg-G.js +0 -90
- package/dist/tools-effective-inventory-DFU7yYvD.js +0 -152
- package/dist/tools-invoke-http-y6WIa3Ku.js +0 -206
- package/dist/trash-rhbwNhfQ.js +0 -24
- package/dist/tui-cli-BfxeO4YM.js +0 -4575
- package/dist/update-cli-DaN9bvPV.js +0 -1759
- package/dist/upgrade-f5dlIxir.js +0 -1226
- package/dist/video-generation-task-status-yX54iO8n.js +0 -163
- package/dist/wait-for-idle-before-flush-mZrBNr5z.js +0 -5986
- package/dist/wizard-models-D_avLyHR.js +0 -334
package/dist/probe-ButCyV3d.js
DELETED
|
@@ -1,1443 +0,0 @@
|
|
|
1
|
-
import { i as formatErrorMessage } from "./errors-CufR9eHH.js";
|
|
2
|
-
import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString } from "./string-coerce-DPP_aYVc.js";
|
|
3
|
-
import { l as normalizeResolvedSecretInputString, o as hasConfiguredSecretInput, u as normalizeSecretInputString } from "./types.secrets-BbgGt42I.js";
|
|
4
|
-
import { n as asNullableRecord, o as readStringField } from "./record-coerce-CMKPGWB_.js";
|
|
5
|
-
import { n as normalizeAccountId } from "./account-id-CTXHUezn.js";
|
|
6
|
-
import { t as parseFiniteNumber } from "./parse-finite-number-BbGMkOzg.js";
|
|
7
|
-
import { n as fetchWithRuntimeDispatcherOrMockedGlobal } from "./runtime-fetch-CjFFOx0G.js";
|
|
8
|
-
import { c as isBlockedHostnameOrIp } from "./ssrf-FLmnjVdI.js";
|
|
9
|
-
import { n as fetchWithSsrFGuard } from "./fetch-guard-CHbFjcDr.js";
|
|
10
|
-
import { a as resolveChannelStreamingChunkMode } from "./channel-streaming-DxgwytRB.js";
|
|
11
|
-
import "./text-runtime-DuYzmNnc.js";
|
|
12
|
-
import { s as resolveMergedAccountConfig, t as createAccountListHelpers } from "./account-helpers-Cy1bqB4c.js";
|
|
13
|
-
import "./error-runtime-QklRpjU7.js";
|
|
14
|
-
import { a as resolveServicePrefixedAllowTarget, c as resolveServicePrefixedTarget, i as parseChatTargetPrefixesOrThrow, r as parseChatAllowTargetPrefixes } from "./chat-target-prefixes-DyGJC4uI.js";
|
|
15
|
-
import { r as isAllowedParsedChatSender } from "./allow-from-CTKDZXpF.js";
|
|
16
|
-
import "./channel-targets-C7WuY6li.js";
|
|
17
|
-
import { t as resolveRequestUrl } from "./request-url-CKTOW_gC.js";
|
|
18
|
-
import "./infra-runtime-CrHVeejV.js";
|
|
19
|
-
import "./ssrf-runtime-CetK5Qy_.js";
|
|
20
|
-
import "./account-resolution-D0lCF0uW.js";
|
|
21
|
-
import "./runtime-fetch-BdhtYVDY.js";
|
|
22
|
-
import "./secret-input-DioGhv6r.js";
|
|
23
|
-
import { t as getBlueBubblesRuntime } from "./runtime-BklcyJNZ.js";
|
|
24
|
-
//#region extensions/bluebubbles/src/types.ts
|
|
25
|
-
const DEFAULT_TIMEOUT_MS$1 = 1e4;
|
|
26
|
-
/**
|
|
27
|
-
* Default timeout for outbound message sends via `/api/v1/message/text` and
|
|
28
|
-
* the `createNewChatWithMessage` flow. Larger than `DEFAULT_TIMEOUT_MS` because
|
|
29
|
-
* Private API iMessage sends on macOS 26 (Tahoe) can stall for 60+ seconds
|
|
30
|
-
* inside the iMessage framework. Callers can override per-call via
|
|
31
|
-
* `opts.timeoutMs` or per-account via `channels.bluebubbles.sendTimeoutMs`.
|
|
32
|
-
* (#67486)
|
|
33
|
-
*/
|
|
34
|
-
const DEFAULT_SEND_TIMEOUT_MS = 3e4;
|
|
35
|
-
function normalizeBlueBubblesServerUrl(raw) {
|
|
36
|
-
const trimmed = raw.trim();
|
|
37
|
-
if (!trimmed) throw new Error("BlueBubbles serverUrl is required");
|
|
38
|
-
return (/^https?:\/\//i.test(trimmed) ? trimmed : `http://${trimmed}`).replace(/\/+$/, "");
|
|
39
|
-
}
|
|
40
|
-
let _fetchGuard = fetchWithSsrFGuard;
|
|
41
|
-
async function blueBubblesFetchWithTimeout(url, init, timeoutMs = DEFAULT_TIMEOUT_MS$1, ssrfPolicy) {
|
|
42
|
-
if (ssrfPolicy !== void 0) {
|
|
43
|
-
const { response, release } = await _fetchGuard({
|
|
44
|
-
url,
|
|
45
|
-
init,
|
|
46
|
-
timeoutMs,
|
|
47
|
-
policy: ssrfPolicy,
|
|
48
|
-
auditContext: "bluebubbles-api"
|
|
49
|
-
});
|
|
50
|
-
const isNullBody = response.status === 101 || response.status === 204 || response.status === 205 || response.status === 304;
|
|
51
|
-
try {
|
|
52
|
-
const bodyBytes = isNullBody ? null : await response.arrayBuffer();
|
|
53
|
-
return new Response(bodyBytes, {
|
|
54
|
-
status: response.status,
|
|
55
|
-
headers: response.headers
|
|
56
|
-
});
|
|
57
|
-
} finally {
|
|
58
|
-
await release();
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
const { dispatcher: _dispatcher, ...safeInit } = init ?? {};
|
|
62
|
-
const controller = new AbortController();
|
|
63
|
-
const timer = setTimeout(() => controller.abort(), timeoutMs);
|
|
64
|
-
try {
|
|
65
|
-
return await fetchWithRuntimeDispatcherOrMockedGlobal(url, {
|
|
66
|
-
...safeInit,
|
|
67
|
-
signal: controller.signal
|
|
68
|
-
});
|
|
69
|
-
} finally {
|
|
70
|
-
clearTimeout(timer);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
//#endregion
|
|
74
|
-
//#region extensions/bluebubbles/src/accounts-normalization.ts
|
|
75
|
-
function asRecord$1(value) {
|
|
76
|
-
return value && typeof value === "object" && !Array.isArray(value) ? value : null;
|
|
77
|
-
}
|
|
78
|
-
function normalizeBlueBubblesPrivateNetworkAliases(config) {
|
|
79
|
-
const record = asRecord$1(config);
|
|
80
|
-
if (!record) return config;
|
|
81
|
-
const network = asRecord$1(record.network);
|
|
82
|
-
const canonicalValue = typeof network?.dangerouslyAllowPrivateNetwork === "boolean" ? network.dangerouslyAllowPrivateNetwork : typeof network?.allowPrivateNetwork === "boolean" ? network.allowPrivateNetwork : typeof record.dangerouslyAllowPrivateNetwork === "boolean" ? record.dangerouslyAllowPrivateNetwork : typeof record.allowPrivateNetwork === "boolean" ? record.allowPrivateNetwork : void 0;
|
|
83
|
-
if (canonicalValue === void 0) return config;
|
|
84
|
-
const { allowPrivateNetwork: _legacyFlatAllow, dangerouslyAllowPrivateNetwork: _legacyFlatDanger, ...rest } = record;
|
|
85
|
-
const { allowPrivateNetwork: _legacyNetworkAllow, dangerouslyAllowPrivateNetwork: _legacyNetworkDanger, ...restNetwork } = network ?? {};
|
|
86
|
-
return {
|
|
87
|
-
...rest,
|
|
88
|
-
network: {
|
|
89
|
-
...restNetwork,
|
|
90
|
-
dangerouslyAllowPrivateNetwork: canonicalValue
|
|
91
|
-
}
|
|
92
|
-
};
|
|
93
|
-
}
|
|
94
|
-
function normalizeBlueBubblesAccountsMap(accounts) {
|
|
95
|
-
if (!accounts) return;
|
|
96
|
-
return Object.fromEntries(Object.entries(accounts).map(([accountKey, accountConfig]) => [accountKey, normalizeBlueBubblesPrivateNetworkAliases(accountConfig)]));
|
|
97
|
-
}
|
|
98
|
-
function resolveBlueBubblesPrivateNetworkConfigValue$1(config) {
|
|
99
|
-
const record = asRecord$1(config);
|
|
100
|
-
if (!record) return;
|
|
101
|
-
const network = asRecord$1(record.network);
|
|
102
|
-
if (typeof network?.dangerouslyAllowPrivateNetwork === "boolean") return network.dangerouslyAllowPrivateNetwork;
|
|
103
|
-
if (typeof network?.allowPrivateNetwork === "boolean") return network.allowPrivateNetwork;
|
|
104
|
-
if (typeof record.dangerouslyAllowPrivateNetwork === "boolean") return record.dangerouslyAllowPrivateNetwork;
|
|
105
|
-
if (typeof record.allowPrivateNetwork === "boolean") return record.allowPrivateNetwork;
|
|
106
|
-
}
|
|
107
|
-
function resolveBlueBubblesEffectiveAllowPrivateNetworkFromConfig(params) {
|
|
108
|
-
const configuredValue = resolveBlueBubblesPrivateNetworkConfigValue$1(params.config);
|
|
109
|
-
if (configuredValue !== void 0) return configuredValue;
|
|
110
|
-
if (!params.baseUrl) return false;
|
|
111
|
-
try {
|
|
112
|
-
const hostname = new URL(normalizeBlueBubblesServerUrl(params.baseUrl)).hostname.trim();
|
|
113
|
-
return Boolean(hostname) && isBlockedHostnameOrIp(hostname);
|
|
114
|
-
} catch {
|
|
115
|
-
return false;
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
//#endregion
|
|
119
|
-
//#region extensions/bluebubbles/src/accounts.ts
|
|
120
|
-
const { listAccountIds: listBlueBubblesAccountIds, resolveDefaultAccountId: resolveDefaultBlueBubblesAccountId } = createAccountListHelpers("bluebubbles");
|
|
121
|
-
function mergeBlueBubblesAccountConfig(cfg, accountId) {
|
|
122
|
-
const merged = resolveMergedAccountConfig({
|
|
123
|
-
channelConfig: normalizeBlueBubblesPrivateNetworkAliases(cfg.channels?.bluebubbles),
|
|
124
|
-
accounts: normalizeBlueBubblesAccountsMap(cfg.channels?.bluebubbles?.accounts),
|
|
125
|
-
accountId,
|
|
126
|
-
omitKeys: ["defaultAccount"],
|
|
127
|
-
normalizeAccountId,
|
|
128
|
-
nestedObjectKeys: ["network", "catchup"]
|
|
129
|
-
});
|
|
130
|
-
return {
|
|
131
|
-
...merged,
|
|
132
|
-
chunkMode: resolveChannelStreamingChunkMode(merged) ?? merged.chunkMode ?? "length"
|
|
133
|
-
};
|
|
134
|
-
}
|
|
135
|
-
function resolveBlueBubblesAccount(params) {
|
|
136
|
-
const accountId = normalizeAccountId(params.accountId ?? resolveDefaultBlueBubblesAccountId(params.cfg));
|
|
137
|
-
const baseEnabled = params.cfg.channels?.bluebubbles?.enabled;
|
|
138
|
-
const merged = mergeBlueBubblesAccountConfig(params.cfg, accountId);
|
|
139
|
-
const accountEnabled = merged.enabled !== false;
|
|
140
|
-
const serverUrl = normalizeSecretInputString(merged.serverUrl);
|
|
141
|
-
normalizeSecretInputString(merged.password);
|
|
142
|
-
const configured = Boolean(serverUrl && hasConfiguredSecretInput(merged.password));
|
|
143
|
-
const baseUrl = serverUrl ? normalizeBlueBubblesServerUrl(serverUrl) : void 0;
|
|
144
|
-
return {
|
|
145
|
-
accountId,
|
|
146
|
-
enabled: baseEnabled !== false && accountEnabled,
|
|
147
|
-
name: normalizeOptionalString(merged.name),
|
|
148
|
-
config: merged,
|
|
149
|
-
configured,
|
|
150
|
-
baseUrl
|
|
151
|
-
};
|
|
152
|
-
}
|
|
153
|
-
function resolveBlueBubblesPrivateNetworkConfigValue(config) {
|
|
154
|
-
return resolveBlueBubblesPrivateNetworkConfigValue$1(config);
|
|
155
|
-
}
|
|
156
|
-
function resolveBlueBubblesEffectiveAllowPrivateNetwork(params) {
|
|
157
|
-
return resolveBlueBubblesEffectiveAllowPrivateNetworkFromConfig(params);
|
|
158
|
-
}
|
|
159
|
-
//#endregion
|
|
160
|
-
//#region extensions/bluebubbles/src/account-resolve.ts
|
|
161
|
-
function resolveBlueBubblesServerAccount(params) {
|
|
162
|
-
const account = resolveBlueBubblesAccount({
|
|
163
|
-
cfg: params.cfg ?? {},
|
|
164
|
-
accountId: params.accountId
|
|
165
|
-
});
|
|
166
|
-
const baseUrl = normalizeResolvedSecretInputString({
|
|
167
|
-
value: params.serverUrl,
|
|
168
|
-
path: "channels.bluebubbles.serverUrl"
|
|
169
|
-
}) || normalizeResolvedSecretInputString({
|
|
170
|
-
value: account.config.serverUrl,
|
|
171
|
-
path: `channels.bluebubbles.accounts.${account.accountId}.serverUrl`
|
|
172
|
-
});
|
|
173
|
-
const password = normalizeResolvedSecretInputString({
|
|
174
|
-
value: params.password,
|
|
175
|
-
path: "channels.bluebubbles.password"
|
|
176
|
-
}) || normalizeResolvedSecretInputString({
|
|
177
|
-
value: account.config.password,
|
|
178
|
-
path: `channels.bluebubbles.accounts.${account.accountId}.password`
|
|
179
|
-
});
|
|
180
|
-
if (!baseUrl) throw new Error("BlueBubbles serverUrl is required");
|
|
181
|
-
if (!password) throw new Error("BlueBubbles password is required");
|
|
182
|
-
const rawSendTimeoutMs = account.config.sendTimeoutMs;
|
|
183
|
-
const sendTimeoutMs = typeof rawSendTimeoutMs === "number" && Number.isInteger(rawSendTimeoutMs) && rawSendTimeoutMs > 0 ? rawSendTimeoutMs : void 0;
|
|
184
|
-
return {
|
|
185
|
-
baseUrl,
|
|
186
|
-
password,
|
|
187
|
-
accountId: account.accountId,
|
|
188
|
-
allowPrivateNetwork: resolveBlueBubblesEffectiveAllowPrivateNetwork({
|
|
189
|
-
baseUrl,
|
|
190
|
-
config: account.config
|
|
191
|
-
}),
|
|
192
|
-
allowPrivateNetworkConfig: resolveBlueBubblesPrivateNetworkConfigValue(account.config),
|
|
193
|
-
sendTimeoutMs
|
|
194
|
-
};
|
|
195
|
-
}
|
|
196
|
-
//#endregion
|
|
197
|
-
//#region extensions/bluebubbles/src/targets.ts
|
|
198
|
-
const CHAT_ID_PREFIXES = [
|
|
199
|
-
"chat_id:",
|
|
200
|
-
"chatid:",
|
|
201
|
-
"chat:"
|
|
202
|
-
];
|
|
203
|
-
const CHAT_GUID_PREFIXES = [
|
|
204
|
-
"chat_guid:",
|
|
205
|
-
"chatguid:",
|
|
206
|
-
"guid:"
|
|
207
|
-
];
|
|
208
|
-
const CHAT_IDENTIFIER_PREFIXES = [
|
|
209
|
-
"chat_identifier:",
|
|
210
|
-
"chatidentifier:",
|
|
211
|
-
"chatident:"
|
|
212
|
-
];
|
|
213
|
-
const SERVICE_PREFIXES = [
|
|
214
|
-
{
|
|
215
|
-
prefix: "imessage:",
|
|
216
|
-
service: "imessage"
|
|
217
|
-
},
|
|
218
|
-
{
|
|
219
|
-
prefix: "sms:",
|
|
220
|
-
service: "sms"
|
|
221
|
-
},
|
|
222
|
-
{
|
|
223
|
-
prefix: "auto:",
|
|
224
|
-
service: "auto"
|
|
225
|
-
}
|
|
226
|
-
];
|
|
227
|
-
const CHAT_IDENTIFIER_UUID_RE = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;
|
|
228
|
-
const CHAT_IDENTIFIER_HEX_RE = /^[0-9a-f]{24,64}$/i;
|
|
229
|
-
function parseRawChatGuid(value) {
|
|
230
|
-
const trimmed = normalizeOptionalString(value);
|
|
231
|
-
if (!trimmed) return null;
|
|
232
|
-
const parts = trimmed.split(";");
|
|
233
|
-
if (parts.length !== 3) return null;
|
|
234
|
-
const service = normalizeOptionalString(parts[0]);
|
|
235
|
-
const separator = normalizeOptionalString(parts[1]);
|
|
236
|
-
const identifier = normalizeOptionalString(parts[2]);
|
|
237
|
-
if (!service || !identifier) return null;
|
|
238
|
-
if (separator !== "+" && separator !== "-") return null;
|
|
239
|
-
return `${service};${separator};${identifier}`;
|
|
240
|
-
}
|
|
241
|
-
function stripPrefix(value, prefix) {
|
|
242
|
-
return value.slice(prefix.length).trim();
|
|
243
|
-
}
|
|
244
|
-
function stripBlueBubblesPrefix(value) {
|
|
245
|
-
const trimmed = normalizeOptionalString(value) ?? "";
|
|
246
|
-
if (!trimmed) return "";
|
|
247
|
-
if (!normalizeLowercaseStringOrEmpty(trimmed).startsWith("bluebubbles:")) return trimmed;
|
|
248
|
-
return trimmed.slice(12).trim();
|
|
249
|
-
}
|
|
250
|
-
function looksLikeRawChatIdentifier(value) {
|
|
251
|
-
const trimmed = normalizeOptionalString(value);
|
|
252
|
-
if (!trimmed) return false;
|
|
253
|
-
if (/^chat\d+$/i.test(trimmed)) return true;
|
|
254
|
-
return CHAT_IDENTIFIER_UUID_RE.test(trimmed) || CHAT_IDENTIFIER_HEX_RE.test(trimmed);
|
|
255
|
-
}
|
|
256
|
-
function parseGroupTarget(params) {
|
|
257
|
-
if (!params.lower.startsWith("group:")) return null;
|
|
258
|
-
const value = stripPrefix(params.trimmed, "group:");
|
|
259
|
-
const chatId = Number.parseInt(value, 10);
|
|
260
|
-
if (Number.isFinite(chatId)) return {
|
|
261
|
-
kind: "chat_id",
|
|
262
|
-
chatId
|
|
263
|
-
};
|
|
264
|
-
if (value) return {
|
|
265
|
-
kind: "chat_guid",
|
|
266
|
-
chatGuid: value
|
|
267
|
-
};
|
|
268
|
-
if (params.requireValue) throw new Error("group target is required");
|
|
269
|
-
return null;
|
|
270
|
-
}
|
|
271
|
-
function parseRawChatIdentifierTarget(trimmed) {
|
|
272
|
-
if (/^chat\d+$/i.test(trimmed)) return {
|
|
273
|
-
kind: "chat_identifier",
|
|
274
|
-
chatIdentifier: trimmed
|
|
275
|
-
};
|
|
276
|
-
if (looksLikeRawChatIdentifier(trimmed)) return {
|
|
277
|
-
kind: "chat_identifier",
|
|
278
|
-
chatIdentifier: trimmed
|
|
279
|
-
};
|
|
280
|
-
return null;
|
|
281
|
-
}
|
|
282
|
-
function normalizeBlueBubblesHandle(raw) {
|
|
283
|
-
const trimmed = raw.trim();
|
|
284
|
-
if (!trimmed) return "";
|
|
285
|
-
const lowered = normalizeLowercaseStringOrEmpty(trimmed);
|
|
286
|
-
if (lowered.startsWith("imessage:")) return normalizeBlueBubblesHandle(trimmed.slice(9));
|
|
287
|
-
if (lowered.startsWith("sms:")) return normalizeBlueBubblesHandle(trimmed.slice(4));
|
|
288
|
-
if (lowered.startsWith("auto:")) return normalizeBlueBubblesHandle(trimmed.slice(5));
|
|
289
|
-
if (trimmed.includes("@")) return normalizeLowercaseStringOrEmpty(trimmed);
|
|
290
|
-
return trimmed.replace(/\s+/g, "");
|
|
291
|
-
}
|
|
292
|
-
/**
|
|
293
|
-
* Extracts the handle from a chat_guid if it's a DM (1:1 chat).
|
|
294
|
-
* BlueBubbles chat_guid format for DM: "service;-;handle" (e.g., "iMessage;-;+19257864429")
|
|
295
|
-
* Group chat format: "service;+;groupId" (has "+" instead of "-")
|
|
296
|
-
*/
|
|
297
|
-
function extractHandleFromChatGuid(chatGuid) {
|
|
298
|
-
const parts = chatGuid.split(";");
|
|
299
|
-
if (parts.length === 3 && parts[1] === "-") {
|
|
300
|
-
const handle = normalizeOptionalString(parts[2]);
|
|
301
|
-
if (handle) return normalizeBlueBubblesHandle(handle);
|
|
302
|
-
}
|
|
303
|
-
return null;
|
|
304
|
-
}
|
|
305
|
-
function normalizeBlueBubblesMessagingTarget(raw) {
|
|
306
|
-
let trimmed = raw.trim();
|
|
307
|
-
if (!trimmed) return;
|
|
308
|
-
trimmed = stripBlueBubblesPrefix(trimmed);
|
|
309
|
-
if (!trimmed) return;
|
|
310
|
-
try {
|
|
311
|
-
const parsed = parseBlueBubblesTarget(trimmed);
|
|
312
|
-
if (parsed.kind === "chat_id") return `chat_id:${parsed.chatId}`;
|
|
313
|
-
if (parsed.kind === "chat_guid") {
|
|
314
|
-
const handle = extractHandleFromChatGuid(parsed.chatGuid);
|
|
315
|
-
if (handle) return handle;
|
|
316
|
-
return `chat_guid:${parsed.chatGuid}`;
|
|
317
|
-
}
|
|
318
|
-
if (parsed.kind === "chat_identifier") return `chat_identifier:${parsed.chatIdentifier}`;
|
|
319
|
-
const handle = normalizeBlueBubblesHandle(parsed.to);
|
|
320
|
-
if (!handle) return;
|
|
321
|
-
return parsed.service === "auto" ? handle : `${parsed.service}:${handle}`;
|
|
322
|
-
} catch {
|
|
323
|
-
return trimmed;
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
function looksLikeBlueBubblesTargetId(raw, normalized) {
|
|
327
|
-
const trimmed = raw.trim();
|
|
328
|
-
if (!trimmed) return false;
|
|
329
|
-
const candidate = stripBlueBubblesPrefix(trimmed);
|
|
330
|
-
if (!candidate) return false;
|
|
331
|
-
if (parseRawChatGuid(candidate)) return true;
|
|
332
|
-
const lowered = normalizeLowercaseStringOrEmpty(candidate);
|
|
333
|
-
if (/^(imessage|sms|auto):/.test(lowered)) return true;
|
|
334
|
-
if (/^(chat_id|chatid|chat|chat_guid|chatguid|guid|chat_identifier|chatidentifier|chatident|group):/.test(lowered)) return true;
|
|
335
|
-
if (/^chat\d+$/i.test(candidate)) return true;
|
|
336
|
-
if (looksLikeRawChatIdentifier(candidate)) return true;
|
|
337
|
-
if (candidate.includes("@")) return true;
|
|
338
|
-
const digitsOnly = candidate.replace(/[\s().-]/g, "");
|
|
339
|
-
if (/^\+?\d{3,}$/.test(digitsOnly)) return true;
|
|
340
|
-
if (normalized) {
|
|
341
|
-
const normalizedTrimmed = normalizeOptionalString(normalized);
|
|
342
|
-
if (!normalizedTrimmed) return false;
|
|
343
|
-
const normalizedLower = normalizeLowercaseStringOrEmpty(normalizedTrimmed);
|
|
344
|
-
if (/^(imessage|sms|auto):/.test(normalizedLower) || /^(chat_id|chat_guid|chat_identifier):/.test(normalizedLower)) return true;
|
|
345
|
-
}
|
|
346
|
-
return false;
|
|
347
|
-
}
|
|
348
|
-
function looksLikeBlueBubblesExplicitTargetId(raw, normalized) {
|
|
349
|
-
const trimmed = raw.trim();
|
|
350
|
-
if (!trimmed) return false;
|
|
351
|
-
const candidate = stripBlueBubblesPrefix(trimmed);
|
|
352
|
-
if (!candidate) return false;
|
|
353
|
-
const lowered = normalizeLowercaseStringOrEmpty(candidate);
|
|
354
|
-
if (/^(imessage|sms|auto):/.test(lowered)) return true;
|
|
355
|
-
if (/^(chat_id|chatid|chat|chat_guid|chatguid|guid|chat_identifier|chatidentifier|chatident|group):/.test(lowered)) return true;
|
|
356
|
-
if (parseRawChatGuid(candidate) || looksLikeRawChatIdentifier(candidate)) return true;
|
|
357
|
-
if (normalized) {
|
|
358
|
-
const normalizedTrimmed = normalized.trim();
|
|
359
|
-
if (!normalizedTrimmed) return false;
|
|
360
|
-
const normalizedLower = normalizeLowercaseStringOrEmpty(normalizedTrimmed);
|
|
361
|
-
if (/^(imessage|sms|auto):/.test(normalizedLower) || /^(chat_id|chat_guid|chat_identifier):/.test(normalizedLower)) return true;
|
|
362
|
-
}
|
|
363
|
-
return false;
|
|
364
|
-
}
|
|
365
|
-
function inferBlueBubblesTargetChatType(raw) {
|
|
366
|
-
try {
|
|
367
|
-
const parsed = parseBlueBubblesTarget(raw);
|
|
368
|
-
if (parsed.kind === "handle") return "direct";
|
|
369
|
-
if (parsed.kind === "chat_guid") return parsed.chatGuid.includes(";+;") ? "group" : "direct";
|
|
370
|
-
if (parsed.kind === "chat_id" || parsed.kind === "chat_identifier") return "group";
|
|
371
|
-
} catch {
|
|
372
|
-
return;
|
|
373
|
-
}
|
|
374
|
-
}
|
|
375
|
-
function parseBlueBubblesTarget(raw) {
|
|
376
|
-
const trimmed = stripBlueBubblesPrefix(raw);
|
|
377
|
-
if (!trimmed) throw new Error("BlueBubbles target is required");
|
|
378
|
-
const lower = normalizeLowercaseStringOrEmpty(trimmed);
|
|
379
|
-
const servicePrefixed = resolveServicePrefixedTarget({
|
|
380
|
-
trimmed,
|
|
381
|
-
lower,
|
|
382
|
-
servicePrefixes: SERVICE_PREFIXES,
|
|
383
|
-
isChatTarget: (remainderLower) => CHAT_ID_PREFIXES.some((p) => remainderLower.startsWith(p)) || CHAT_GUID_PREFIXES.some((p) => remainderLower.startsWith(p)) || CHAT_IDENTIFIER_PREFIXES.some((p) => remainderLower.startsWith(p)) || remainderLower.startsWith("group:"),
|
|
384
|
-
parseTarget: parseBlueBubblesTarget
|
|
385
|
-
});
|
|
386
|
-
if (servicePrefixed) return servicePrefixed;
|
|
387
|
-
const chatTarget = parseChatTargetPrefixesOrThrow({
|
|
388
|
-
trimmed,
|
|
389
|
-
lower,
|
|
390
|
-
chatIdPrefixes: CHAT_ID_PREFIXES,
|
|
391
|
-
chatGuidPrefixes: CHAT_GUID_PREFIXES,
|
|
392
|
-
chatIdentifierPrefixes: CHAT_IDENTIFIER_PREFIXES
|
|
393
|
-
});
|
|
394
|
-
if (chatTarget) return chatTarget;
|
|
395
|
-
const groupTarget = parseGroupTarget({
|
|
396
|
-
trimmed,
|
|
397
|
-
lower,
|
|
398
|
-
requireValue: true
|
|
399
|
-
});
|
|
400
|
-
if (groupTarget) return groupTarget;
|
|
401
|
-
const rawChatGuid = parseRawChatGuid(trimmed);
|
|
402
|
-
if (rawChatGuid) return {
|
|
403
|
-
kind: "chat_guid",
|
|
404
|
-
chatGuid: rawChatGuid
|
|
405
|
-
};
|
|
406
|
-
const rawChatIdentifierTarget = parseRawChatIdentifierTarget(trimmed);
|
|
407
|
-
if (rawChatIdentifierTarget) return rawChatIdentifierTarget;
|
|
408
|
-
return {
|
|
409
|
-
kind: "handle",
|
|
410
|
-
to: trimmed,
|
|
411
|
-
service: "auto"
|
|
412
|
-
};
|
|
413
|
-
}
|
|
414
|
-
function parseBlueBubblesAllowTarget(raw) {
|
|
415
|
-
const trimmed = normalizeOptionalString(raw) ?? "";
|
|
416
|
-
if (!trimmed) return {
|
|
417
|
-
kind: "handle",
|
|
418
|
-
handle: ""
|
|
419
|
-
};
|
|
420
|
-
const lower = normalizeLowercaseStringOrEmpty(trimmed);
|
|
421
|
-
const servicePrefixed = resolveServicePrefixedAllowTarget({
|
|
422
|
-
trimmed,
|
|
423
|
-
lower,
|
|
424
|
-
servicePrefixes: SERVICE_PREFIXES,
|
|
425
|
-
parseAllowTarget: parseBlueBubblesAllowTarget
|
|
426
|
-
});
|
|
427
|
-
if (servicePrefixed) return servicePrefixed;
|
|
428
|
-
const chatTarget = parseChatAllowTargetPrefixes({
|
|
429
|
-
trimmed,
|
|
430
|
-
lower,
|
|
431
|
-
chatIdPrefixes: CHAT_ID_PREFIXES,
|
|
432
|
-
chatGuidPrefixes: CHAT_GUID_PREFIXES,
|
|
433
|
-
chatIdentifierPrefixes: CHAT_IDENTIFIER_PREFIXES
|
|
434
|
-
});
|
|
435
|
-
if (chatTarget) return chatTarget;
|
|
436
|
-
const groupTarget = parseGroupTarget({
|
|
437
|
-
trimmed,
|
|
438
|
-
lower,
|
|
439
|
-
requireValue: false
|
|
440
|
-
});
|
|
441
|
-
if (groupTarget) return groupTarget;
|
|
442
|
-
const rawChatIdentifierTarget = parseRawChatIdentifierTarget(trimmed);
|
|
443
|
-
if (rawChatIdentifierTarget) return rawChatIdentifierTarget;
|
|
444
|
-
return {
|
|
445
|
-
kind: "handle",
|
|
446
|
-
handle: normalizeBlueBubblesHandle(trimmed)
|
|
447
|
-
};
|
|
448
|
-
}
|
|
449
|
-
function isAllowedBlueBubblesSender(params) {
|
|
450
|
-
return isAllowedParsedChatSender({
|
|
451
|
-
allowFrom: params.allowFrom,
|
|
452
|
-
sender: params.sender,
|
|
453
|
-
chatId: params.chatId,
|
|
454
|
-
chatGuid: params.chatGuid,
|
|
455
|
-
chatIdentifier: params.chatIdentifier,
|
|
456
|
-
normalizeSender: normalizeBlueBubblesHandle,
|
|
457
|
-
parseAllowTarget: parseBlueBubblesAllowTarget
|
|
458
|
-
});
|
|
459
|
-
}
|
|
460
|
-
function formatBlueBubblesChatTarget(params) {
|
|
461
|
-
if (params.chatId && Number.isFinite(params.chatId)) return `chat_id:${params.chatId}`;
|
|
462
|
-
const guid = normalizeOptionalString(params.chatGuid);
|
|
463
|
-
if (guid) return `chat_guid:${guid}`;
|
|
464
|
-
const identifier = normalizeOptionalString(params.chatIdentifier);
|
|
465
|
-
if (identifier) return `chat_identifier:${identifier}`;
|
|
466
|
-
return "";
|
|
467
|
-
}
|
|
468
|
-
//#endregion
|
|
469
|
-
//#region extensions/bluebubbles/src/monitor-normalize.ts
|
|
470
|
-
const asRecord = asNullableRecord;
|
|
471
|
-
const readString = readStringField;
|
|
472
|
-
function readNumber(record, key) {
|
|
473
|
-
if (!record) return;
|
|
474
|
-
const value = record[key];
|
|
475
|
-
return typeof value === "number" && Number.isFinite(value) ? value : void 0;
|
|
476
|
-
}
|
|
477
|
-
function readBoolean(record, key) {
|
|
478
|
-
if (!record) return;
|
|
479
|
-
const value = record[key];
|
|
480
|
-
return typeof value === "boolean" ? value : void 0;
|
|
481
|
-
}
|
|
482
|
-
function readNumberLike(record, key) {
|
|
483
|
-
if (!record) return;
|
|
484
|
-
return parseFiniteNumber(record[key]);
|
|
485
|
-
}
|
|
486
|
-
function extractAttachments(message) {
|
|
487
|
-
const raw = message["attachments"];
|
|
488
|
-
if (!Array.isArray(raw)) return [];
|
|
489
|
-
const out = [];
|
|
490
|
-
for (const entry of raw) {
|
|
491
|
-
const record = asRecord(entry);
|
|
492
|
-
if (!record) continue;
|
|
493
|
-
out.push({
|
|
494
|
-
guid: readString(record, "guid"),
|
|
495
|
-
uti: readString(record, "uti"),
|
|
496
|
-
mimeType: readString(record, "mimeType") ?? readString(record, "mime_type"),
|
|
497
|
-
transferName: readString(record, "transferName") ?? readString(record, "transfer_name"),
|
|
498
|
-
totalBytes: readNumberLike(record, "totalBytes") ?? readNumberLike(record, "total_bytes"),
|
|
499
|
-
height: readNumberLike(record, "height"),
|
|
500
|
-
width: readNumberLike(record, "width"),
|
|
501
|
-
originalROWID: readNumberLike(record, "originalROWID") ?? readNumberLike(record, "rowid")
|
|
502
|
-
});
|
|
503
|
-
}
|
|
504
|
-
return out;
|
|
505
|
-
}
|
|
506
|
-
function buildAttachmentPlaceholder(attachments) {
|
|
507
|
-
if (attachments.length === 0) return "";
|
|
508
|
-
const mimeTypes = attachments.map((entry) => entry.mimeType ?? "");
|
|
509
|
-
const allImages = mimeTypes.every((entry) => entry.startsWith("image/"));
|
|
510
|
-
const allVideos = mimeTypes.every((entry) => entry.startsWith("video/"));
|
|
511
|
-
const allAudio = mimeTypes.every((entry) => entry.startsWith("audio/"));
|
|
512
|
-
const tag = allImages ? "<media:image>" : allVideos ? "<media:video>" : allAudio ? "<media:audio>" : "<media:attachment>";
|
|
513
|
-
const label = allImages ? "image" : allVideos ? "video" : allAudio ? "audio" : "file";
|
|
514
|
-
const suffix = attachments.length === 1 ? label : `${label}s`;
|
|
515
|
-
return `${tag} (${attachments.length} ${suffix})`;
|
|
516
|
-
}
|
|
517
|
-
function buildMessagePlaceholder(message) {
|
|
518
|
-
const attachmentPlaceholder = buildAttachmentPlaceholder(message.attachments ?? []);
|
|
519
|
-
if (attachmentPlaceholder) return attachmentPlaceholder;
|
|
520
|
-
if (message.balloonBundleId) return "<media:sticker>";
|
|
521
|
-
return "";
|
|
522
|
-
}
|
|
523
|
-
function formatReplyTag(message) {
|
|
524
|
-
const rawId = message.replyToShortId || message.replyToId;
|
|
525
|
-
if (!rawId) return null;
|
|
526
|
-
return `[[reply_to:${rawId}]]`;
|
|
527
|
-
}
|
|
528
|
-
function extractReplyMetadata(message) {
|
|
529
|
-
const replyRecord = asRecord(message["replyTo"] ?? message["reply_to"] ?? message["replyToMessage"] ?? message["reply_to_message"] ?? message["repliedMessage"] ?? message["quotedMessage"] ?? message["associatedMessage"] ?? message["reply"]);
|
|
530
|
-
const replyHandle = asRecord(replyRecord?.["handle"]) ?? asRecord(replyRecord?.["sender"]) ?? null;
|
|
531
|
-
const replySenderRaw = readString(replyHandle, "address") ?? readString(replyHandle, "handle") ?? readString(replyHandle, "id") ?? readString(replyRecord, "senderId") ?? readString(replyRecord, "sender") ?? readString(replyRecord, "from");
|
|
532
|
-
const normalizedSender = replySenderRaw ? normalizeBlueBubblesHandle(replySenderRaw) || replySenderRaw.trim() : void 0;
|
|
533
|
-
const replyToBody = readString(replyRecord, "text") ?? readString(replyRecord, "body") ?? readString(replyRecord, "message") ?? readString(replyRecord, "subject") ?? void 0;
|
|
534
|
-
const directReplyId = readString(message, "replyToMessageGuid") ?? readString(message, "replyToGuid") ?? readString(message, "replyGuid") ?? readString(message, "selectedMessageGuid") ?? readString(message, "selectedMessageId") ?? readString(message, "replyToMessageId") ?? readString(message, "replyId") ?? readString(replyRecord, "guid") ?? readString(replyRecord, "id") ?? readString(replyRecord, "messageId");
|
|
535
|
-
const associatedType = readNumberLike(message, "associatedMessageType") ?? readNumberLike(message, "associated_message_type");
|
|
536
|
-
const associatedGuid = readString(message, "associatedMessageGuid") ?? readString(message, "associated_message_guid") ?? readString(message, "associatedMessageId");
|
|
537
|
-
const isReactionAssociation = typeof associatedType === "number" && REACTION_TYPE_MAP.has(associatedType);
|
|
538
|
-
const replyToId = directReplyId ?? (!isReactionAssociation ? associatedGuid : void 0);
|
|
539
|
-
const threadOriginatorGuid = readString(message, "threadOriginatorGuid");
|
|
540
|
-
const messageGuid = readString(message, "guid");
|
|
541
|
-
return {
|
|
542
|
-
replyToId: normalizeOptionalString(replyToId ?? (!replyToId && threadOriginatorGuid && threadOriginatorGuid !== messageGuid ? threadOriginatorGuid : void 0)),
|
|
543
|
-
replyToBody: normalizeOptionalString(replyToBody),
|
|
544
|
-
replyToSender: normalizedSender || void 0
|
|
545
|
-
};
|
|
546
|
-
}
|
|
547
|
-
function readFirstChatRecord(message) {
|
|
548
|
-
const chats = message["chats"];
|
|
549
|
-
if (!Array.isArray(chats) || chats.length === 0) return null;
|
|
550
|
-
const first = chats[0];
|
|
551
|
-
return asRecord(first);
|
|
552
|
-
}
|
|
553
|
-
function readParticipantEntries(record) {
|
|
554
|
-
if (!record) return;
|
|
555
|
-
const participants = record["participants"];
|
|
556
|
-
if (Array.isArray(participants)) return participants;
|
|
557
|
-
const handles = record["handles"];
|
|
558
|
-
if (Array.isArray(handles)) return handles;
|
|
559
|
-
const participantHandles = record["participantHandles"];
|
|
560
|
-
if (Array.isArray(participantHandles)) return participantHandles;
|
|
561
|
-
}
|
|
562
|
-
function extractSenderInfo(message) {
|
|
563
|
-
const handleValue = message.handle ?? message.sender;
|
|
564
|
-
const handle = asRecord(handleValue) ?? (typeof handleValue === "string" ? { address: handleValue } : null);
|
|
565
|
-
const senderId = (readString(handle, "address") ?? readString(handle, "handle") ?? readString(handle, "id") ?? readString(message, "senderId") ?? readString(message, "sender") ?? readString(message, "from") ?? "").trim();
|
|
566
|
-
const senderName = readString(handle, "displayName") ?? readString(handle, "name") ?? readString(message, "senderName") ?? void 0;
|
|
567
|
-
return {
|
|
568
|
-
senderId,
|
|
569
|
-
senderIdExplicit: Boolean(senderId),
|
|
570
|
-
senderName
|
|
571
|
-
};
|
|
572
|
-
}
|
|
573
|
-
function extractChatContext(message) {
|
|
574
|
-
const chat = asRecord(message.chat) ?? asRecord(message.conversation) ?? null;
|
|
575
|
-
const chatFromList = readFirstChatRecord(message);
|
|
576
|
-
const chatGuid = readString(message, "chatGuid") ?? readString(message, "chat_guid") ?? readString(chat, "chatGuid") ?? readString(chat, "chat_guid") ?? readString(chat, "guid") ?? readString(chatFromList, "chatGuid") ?? readString(chatFromList, "chat_guid") ?? readString(chatFromList, "guid");
|
|
577
|
-
const chatIdentifier = readString(message, "chatIdentifier") ?? readString(message, "chat_identifier") ?? readString(chat, "chatIdentifier") ?? readString(chat, "chat_identifier") ?? readString(chat, "identifier") ?? readString(chatFromList, "chatIdentifier") ?? readString(chatFromList, "chat_identifier") ?? readString(chatFromList, "identifier") ?? extractChatIdentifierFromChatGuid(chatGuid);
|
|
578
|
-
const chatId = readNumberLike(message, "chatId") ?? readNumberLike(message, "chat_id") ?? readNumberLike(chat, "chatId") ?? readNumberLike(chat, "chat_id") ?? readNumberLike(chat, "id") ?? readNumberLike(chatFromList, "chatId") ?? readNumberLike(chatFromList, "chat_id") ?? readNumberLike(chatFromList, "id");
|
|
579
|
-
const chatName = readString(message, "chatName") ?? readString(chat, "displayName") ?? readString(chat, "name") ?? readString(chatFromList, "displayName") ?? readString(chatFromList, "name") ?? void 0;
|
|
580
|
-
const participants = readParticipantEntries(chat) ?? readParticipantEntries(message) ?? readParticipantEntries(chatFromList) ?? [];
|
|
581
|
-
const participantsCount = participants.length;
|
|
582
|
-
const groupFromChatGuid = resolveGroupFlagFromChatGuid(chatGuid);
|
|
583
|
-
const explicitIsGroup = readBoolean(message, "isGroup") ?? readBoolean(message, "is_group") ?? readBoolean(chat, "isGroup") ?? readBoolean(message, "group");
|
|
584
|
-
return {
|
|
585
|
-
chatGuid,
|
|
586
|
-
chatIdentifier,
|
|
587
|
-
chatId,
|
|
588
|
-
chatName,
|
|
589
|
-
isGroup: typeof groupFromChatGuid === "boolean" ? groupFromChatGuid : explicitIsGroup ?? participantsCount > 2,
|
|
590
|
-
participants
|
|
591
|
-
};
|
|
592
|
-
}
|
|
593
|
-
function normalizeParticipantEntry(entry) {
|
|
594
|
-
if (typeof entry === "string" || typeof entry === "number") {
|
|
595
|
-
const raw = String(entry).trim();
|
|
596
|
-
if (!raw) return null;
|
|
597
|
-
const normalized = normalizeBlueBubblesHandle(raw) || raw;
|
|
598
|
-
return normalized ? { id: normalized } : null;
|
|
599
|
-
}
|
|
600
|
-
const record = asRecord(entry);
|
|
601
|
-
if (!record) return null;
|
|
602
|
-
const nestedHandle = asRecord(record["handle"]) ?? asRecord(record["sender"]) ?? asRecord(record["contact"]) ?? null;
|
|
603
|
-
const idRaw = readString(record, "address") ?? readString(record, "handle") ?? readString(record, "id") ?? readString(record, "phoneNumber") ?? readString(record, "phone_number") ?? readString(record, "email") ?? readString(nestedHandle, "address") ?? readString(nestedHandle, "handle") ?? readString(nestedHandle, "id");
|
|
604
|
-
const nameRaw = readString(record, "displayName") ?? readString(record, "name") ?? readString(record, "title") ?? readString(nestedHandle, "displayName") ?? readString(nestedHandle, "name");
|
|
605
|
-
const normalizedId = idRaw ? normalizeBlueBubblesHandle(idRaw) || idRaw.trim() : "";
|
|
606
|
-
if (!normalizedId) return null;
|
|
607
|
-
return {
|
|
608
|
-
id: normalizedId,
|
|
609
|
-
name: normalizeOptionalString(nameRaw)
|
|
610
|
-
};
|
|
611
|
-
}
|
|
612
|
-
function normalizeParticipantList(raw) {
|
|
613
|
-
const entries = Array.isArray(raw) ? raw : readParticipantEntries(asRecord(raw)) ?? [];
|
|
614
|
-
if (entries.length === 0) return [];
|
|
615
|
-
const seen = /* @__PURE__ */ new Set();
|
|
616
|
-
const output = [];
|
|
617
|
-
for (const entry of entries) {
|
|
618
|
-
const normalized = normalizeParticipantEntry(entry);
|
|
619
|
-
if (!normalized?.id) continue;
|
|
620
|
-
const key = normalizeLowercaseStringOrEmpty(normalized.id);
|
|
621
|
-
if (seen.has(key)) continue;
|
|
622
|
-
seen.add(key);
|
|
623
|
-
output.push(normalized);
|
|
624
|
-
}
|
|
625
|
-
return output;
|
|
626
|
-
}
|
|
627
|
-
function formatGroupMembers(params) {
|
|
628
|
-
const seen = /* @__PURE__ */ new Set();
|
|
629
|
-
const ordered = [];
|
|
630
|
-
for (const entry of params.participants ?? []) {
|
|
631
|
-
if (!entry?.id) continue;
|
|
632
|
-
const key = normalizeLowercaseStringOrEmpty(entry.id);
|
|
633
|
-
if (seen.has(key)) continue;
|
|
634
|
-
seen.add(key);
|
|
635
|
-
ordered.push(entry);
|
|
636
|
-
}
|
|
637
|
-
if (ordered.length === 0 && params.fallback?.id) ordered.push(params.fallback);
|
|
638
|
-
if (ordered.length === 0) return;
|
|
639
|
-
return ordered.map((entry) => entry.name ? `${entry.name} (${entry.id})` : entry.id).join(", ");
|
|
640
|
-
}
|
|
641
|
-
function resolveGroupFlagFromChatGuid(chatGuid) {
|
|
642
|
-
const guid = chatGuid?.trim();
|
|
643
|
-
if (!guid) return;
|
|
644
|
-
const parts = guid.split(";");
|
|
645
|
-
if (parts.length >= 3) {
|
|
646
|
-
if (parts[1] === "+") return true;
|
|
647
|
-
if (parts[1] === "-") return false;
|
|
648
|
-
}
|
|
649
|
-
if (guid.includes(";+;")) return true;
|
|
650
|
-
if (guid.includes(";-;")) return false;
|
|
651
|
-
}
|
|
652
|
-
function extractChatIdentifierFromChatGuid(chatGuid) {
|
|
653
|
-
const guid = chatGuid?.trim();
|
|
654
|
-
if (!guid) return;
|
|
655
|
-
const parts = guid.split(";");
|
|
656
|
-
if (parts.length < 3) return;
|
|
657
|
-
return parts[2]?.trim() || void 0;
|
|
658
|
-
}
|
|
659
|
-
function formatGroupAllowlistEntry(params) {
|
|
660
|
-
const guid = params.chatGuid?.trim();
|
|
661
|
-
if (guid) return `chat_guid:${guid}`;
|
|
662
|
-
const chatId = params.chatId;
|
|
663
|
-
if (typeof chatId === "number" && Number.isFinite(chatId)) return `chat_id:${chatId}`;
|
|
664
|
-
const identifier = params.chatIdentifier?.trim();
|
|
665
|
-
if (identifier) return `chat_identifier:${identifier}`;
|
|
666
|
-
return null;
|
|
667
|
-
}
|
|
668
|
-
const REACTION_TYPE_MAP = new Map([
|
|
669
|
-
[2e3, {
|
|
670
|
-
emoji: "❤️",
|
|
671
|
-
action: "added"
|
|
672
|
-
}],
|
|
673
|
-
[2001, {
|
|
674
|
-
emoji: "👍",
|
|
675
|
-
action: "added"
|
|
676
|
-
}],
|
|
677
|
-
[2002, {
|
|
678
|
-
emoji: "👎",
|
|
679
|
-
action: "added"
|
|
680
|
-
}],
|
|
681
|
-
[2003, {
|
|
682
|
-
emoji: "😂",
|
|
683
|
-
action: "added"
|
|
684
|
-
}],
|
|
685
|
-
[2004, {
|
|
686
|
-
emoji: "‼️",
|
|
687
|
-
action: "added"
|
|
688
|
-
}],
|
|
689
|
-
[2005, {
|
|
690
|
-
emoji: "❓",
|
|
691
|
-
action: "added"
|
|
692
|
-
}],
|
|
693
|
-
[3e3, {
|
|
694
|
-
emoji: "❤️",
|
|
695
|
-
action: "removed"
|
|
696
|
-
}],
|
|
697
|
-
[3001, {
|
|
698
|
-
emoji: "👍",
|
|
699
|
-
action: "removed"
|
|
700
|
-
}],
|
|
701
|
-
[3002, {
|
|
702
|
-
emoji: "👎",
|
|
703
|
-
action: "removed"
|
|
704
|
-
}],
|
|
705
|
-
[3003, {
|
|
706
|
-
emoji: "😂",
|
|
707
|
-
action: "removed"
|
|
708
|
-
}],
|
|
709
|
-
[3004, {
|
|
710
|
-
emoji: "‼️",
|
|
711
|
-
action: "removed"
|
|
712
|
-
}],
|
|
713
|
-
[3005, {
|
|
714
|
-
emoji: "❓",
|
|
715
|
-
action: "removed"
|
|
716
|
-
}]
|
|
717
|
-
]);
|
|
718
|
-
const TAPBACK_TEXT_MAP = new Map([
|
|
719
|
-
["loved", {
|
|
720
|
-
emoji: "❤️",
|
|
721
|
-
action: "added"
|
|
722
|
-
}],
|
|
723
|
-
["liked", {
|
|
724
|
-
emoji: "👍",
|
|
725
|
-
action: "added"
|
|
726
|
-
}],
|
|
727
|
-
["disliked", {
|
|
728
|
-
emoji: "👎",
|
|
729
|
-
action: "added"
|
|
730
|
-
}],
|
|
731
|
-
["laughed at", {
|
|
732
|
-
emoji: "😂",
|
|
733
|
-
action: "added"
|
|
734
|
-
}],
|
|
735
|
-
["emphasized", {
|
|
736
|
-
emoji: "‼️",
|
|
737
|
-
action: "added"
|
|
738
|
-
}],
|
|
739
|
-
["questioned", {
|
|
740
|
-
emoji: "❓",
|
|
741
|
-
action: "added"
|
|
742
|
-
}],
|
|
743
|
-
["removed a heart from", {
|
|
744
|
-
emoji: "❤️",
|
|
745
|
-
action: "removed"
|
|
746
|
-
}],
|
|
747
|
-
["removed a like from", {
|
|
748
|
-
emoji: "👍",
|
|
749
|
-
action: "removed"
|
|
750
|
-
}],
|
|
751
|
-
["removed a dislike from", {
|
|
752
|
-
emoji: "👎",
|
|
753
|
-
action: "removed"
|
|
754
|
-
}],
|
|
755
|
-
["removed a laugh from", {
|
|
756
|
-
emoji: "😂",
|
|
757
|
-
action: "removed"
|
|
758
|
-
}],
|
|
759
|
-
["removed an emphasis from", {
|
|
760
|
-
emoji: "‼️",
|
|
761
|
-
action: "removed"
|
|
762
|
-
}],
|
|
763
|
-
["removed a question from", {
|
|
764
|
-
emoji: "❓",
|
|
765
|
-
action: "removed"
|
|
766
|
-
}]
|
|
767
|
-
]);
|
|
768
|
-
const TAPBACK_EMOJI_REGEX = /(?:\p{Regional_Indicator}{2})|(?:[0-9#*]\uFE0F?\u20E3)|(?:\p{Extended_Pictographic}(?:\uFE0F|\uFE0E)?(?:\p{Emoji_Modifier})?(?:\u200D\p{Extended_Pictographic}(?:\uFE0F|\uFE0E)?(?:\p{Emoji_Modifier})?)*)/u;
|
|
769
|
-
function extractFirstEmoji(text) {
|
|
770
|
-
const match = text.match(TAPBACK_EMOJI_REGEX);
|
|
771
|
-
return match ? match[0] : null;
|
|
772
|
-
}
|
|
773
|
-
function extractQuotedTapbackText(text) {
|
|
774
|
-
const match = text.match(/[“"]([^”"]+)[”"]/s);
|
|
775
|
-
return match ? match[1] : null;
|
|
776
|
-
}
|
|
777
|
-
function isTapbackAssociatedType(type) {
|
|
778
|
-
return typeof type === "number" && Number.isFinite(type) && type >= 2e3 && type < 4e3;
|
|
779
|
-
}
|
|
780
|
-
function resolveTapbackActionHint(type) {
|
|
781
|
-
if (typeof type !== "number" || !Number.isFinite(type)) return;
|
|
782
|
-
if (type >= 3e3 && type < 4e3) return "removed";
|
|
783
|
-
if (type >= 2e3 && type < 3e3) return "added";
|
|
784
|
-
}
|
|
785
|
-
function resolveTapbackContext(message) {
|
|
786
|
-
const associatedType = message.associatedMessageType;
|
|
787
|
-
const hasTapbackType = isTapbackAssociatedType(associatedType);
|
|
788
|
-
const hasTapbackMarker = Boolean(message.associatedMessageEmoji) || Boolean(message.isTapback);
|
|
789
|
-
if (!hasTapbackType && !hasTapbackMarker) return null;
|
|
790
|
-
const replyToId = normalizeOptionalString(message.associatedMessageGuid) ?? normalizeOptionalString(message.replyToId);
|
|
791
|
-
const actionHint = resolveTapbackActionHint(associatedType);
|
|
792
|
-
return {
|
|
793
|
-
emojiHint: message.associatedMessageEmoji?.trim() || REACTION_TYPE_MAP.get(associatedType ?? -1)?.emoji,
|
|
794
|
-
actionHint,
|
|
795
|
-
replyToId
|
|
796
|
-
};
|
|
797
|
-
}
|
|
798
|
-
function parseTapbackText(params) {
|
|
799
|
-
const trimmed = params.text.trim();
|
|
800
|
-
const lower = normalizeLowercaseStringOrEmpty(trimmed);
|
|
801
|
-
if (!trimmed) return null;
|
|
802
|
-
const parseLeadingReactionAction = (prefix, defaultAction) => {
|
|
803
|
-
if (!lower.startsWith(prefix)) return null;
|
|
804
|
-
const emoji = extractFirstEmoji(trimmed) ?? params.emojiHint;
|
|
805
|
-
if (!emoji) return null;
|
|
806
|
-
const quotedText = extractQuotedTapbackText(trimmed);
|
|
807
|
-
if (params.requireQuoted && !quotedText) return null;
|
|
808
|
-
const fallback = trimmed.slice(prefix.length).trim();
|
|
809
|
-
return {
|
|
810
|
-
emoji,
|
|
811
|
-
action: params.actionHint ?? defaultAction,
|
|
812
|
-
quotedText: quotedText ?? fallback
|
|
813
|
-
};
|
|
814
|
-
};
|
|
815
|
-
for (const [pattern, { emoji, action }] of TAPBACK_TEXT_MAP) if (lower.startsWith(pattern)) {
|
|
816
|
-
const afterPattern = trimmed.slice(pattern.length).trim();
|
|
817
|
-
if (params.requireQuoted) {
|
|
818
|
-
const strictMatch = afterPattern.match(/^[“"](.+)[”"]$/s);
|
|
819
|
-
if (!strictMatch) return null;
|
|
820
|
-
return {
|
|
821
|
-
emoji,
|
|
822
|
-
action,
|
|
823
|
-
quotedText: strictMatch[1]
|
|
824
|
-
};
|
|
825
|
-
}
|
|
826
|
-
return {
|
|
827
|
-
emoji,
|
|
828
|
-
action,
|
|
829
|
-
quotedText: extractQuotedTapbackText(afterPattern) ?? extractQuotedTapbackText(trimmed) ?? afterPattern
|
|
830
|
-
};
|
|
831
|
-
}
|
|
832
|
-
const reacted = parseLeadingReactionAction("reacted", "added");
|
|
833
|
-
if (reacted) return reacted;
|
|
834
|
-
const removed = parseLeadingReactionAction("removed", "removed");
|
|
835
|
-
if (removed) return removed;
|
|
836
|
-
return null;
|
|
837
|
-
}
|
|
838
|
-
function extractMessagePayload(payload) {
|
|
839
|
-
const parseRecord = (value) => {
|
|
840
|
-
const record = asRecord(value);
|
|
841
|
-
if (record) return record;
|
|
842
|
-
if (Array.isArray(value)) {
|
|
843
|
-
for (const entry of value) {
|
|
844
|
-
const parsedEntry = parseRecord(entry);
|
|
845
|
-
if (parsedEntry) return parsedEntry;
|
|
846
|
-
}
|
|
847
|
-
return null;
|
|
848
|
-
}
|
|
849
|
-
if (typeof value !== "string") return null;
|
|
850
|
-
const trimmed = value.trim();
|
|
851
|
-
if (!trimmed) return null;
|
|
852
|
-
try {
|
|
853
|
-
return parseRecord(JSON.parse(trimmed));
|
|
854
|
-
} catch {
|
|
855
|
-
return null;
|
|
856
|
-
}
|
|
857
|
-
};
|
|
858
|
-
const data = parseRecord(payload.data ?? payload.payload ?? payload.event);
|
|
859
|
-
const message = parseRecord(payload.message ?? data?.message ?? data);
|
|
860
|
-
if (message) return message;
|
|
861
|
-
return null;
|
|
862
|
-
}
|
|
863
|
-
function normalizeWebhookMessage(payload, options) {
|
|
864
|
-
const message = extractMessagePayload(payload);
|
|
865
|
-
if (!message) return null;
|
|
866
|
-
const text = readString(message, "text") ?? readString(message, "body") ?? readString(message, "subject") ?? "";
|
|
867
|
-
const { senderId, senderIdExplicit, senderName } = extractSenderInfo(message);
|
|
868
|
-
const { chatGuid, chatIdentifier, chatId, chatName, isGroup, participants } = extractChatContext(message);
|
|
869
|
-
const normalizedParticipants = normalizeParticipantList(participants);
|
|
870
|
-
const fromMe = readBoolean(message, "isFromMe") ?? readBoolean(message, "is_from_me");
|
|
871
|
-
const messageId = readString(message, "guid") ?? readString(message, "id") ?? readString(message, "messageId") ?? void 0;
|
|
872
|
-
const balloonBundleId = readString(message, "balloonBundleId");
|
|
873
|
-
const associatedMessageGuid = readString(message, "associatedMessageGuid") ?? readString(message, "associated_message_guid") ?? readString(message, "associatedMessageId") ?? void 0;
|
|
874
|
-
const associatedMessageType = readNumberLike(message, "associatedMessageType") ?? readNumberLike(message, "associated_message_type");
|
|
875
|
-
const associatedMessageEmoji = readString(message, "associatedMessageEmoji") ?? readString(message, "associated_message_emoji") ?? readString(message, "reactionEmoji") ?? readString(message, "reaction_emoji") ?? void 0;
|
|
876
|
-
const isTapback = readBoolean(message, "isTapback") ?? readBoolean(message, "is_tapback") ?? readBoolean(message, "tapback") ?? void 0;
|
|
877
|
-
const timestampRaw = readNumber(message, "date") ?? readNumber(message, "dateCreated") ?? readNumber(message, "timestamp");
|
|
878
|
-
const timestamp = typeof timestampRaw === "number" ? timestampRaw > 0xe8d4a51000 ? timestampRaw : timestampRaw * 1e3 : void 0;
|
|
879
|
-
const senderFallbackFromChatGuid = !senderIdExplicit && !isGroup && chatGuid ? extractHandleFromChatGuid(chatGuid) : null;
|
|
880
|
-
const normalizedSender = normalizeBlueBubblesHandle(senderId || senderFallbackFromChatGuid || "");
|
|
881
|
-
if (!normalizedSender) return null;
|
|
882
|
-
const replyMetadata = extractReplyMetadata(message);
|
|
883
|
-
return {
|
|
884
|
-
text,
|
|
885
|
-
senderId: normalizedSender,
|
|
886
|
-
senderIdExplicit,
|
|
887
|
-
senderName,
|
|
888
|
-
messageId,
|
|
889
|
-
timestamp,
|
|
890
|
-
isGroup,
|
|
891
|
-
chatId,
|
|
892
|
-
chatGuid,
|
|
893
|
-
chatIdentifier,
|
|
894
|
-
chatName,
|
|
895
|
-
fromMe,
|
|
896
|
-
attachments: extractAttachments(message),
|
|
897
|
-
balloonBundleId,
|
|
898
|
-
associatedMessageGuid,
|
|
899
|
-
associatedMessageType,
|
|
900
|
-
associatedMessageEmoji,
|
|
901
|
-
isTapback,
|
|
902
|
-
participants: normalizedParticipants,
|
|
903
|
-
replyToId: replyMetadata.replyToId,
|
|
904
|
-
replyToBody: replyMetadata.replyToBody,
|
|
905
|
-
replyToSender: replyMetadata.replyToSender,
|
|
906
|
-
eventType: options?.eventType
|
|
907
|
-
};
|
|
908
|
-
}
|
|
909
|
-
function normalizeWebhookReaction(payload) {
|
|
910
|
-
const message = extractMessagePayload(payload);
|
|
911
|
-
if (!message) return null;
|
|
912
|
-
const associatedGuid = readString(message, "associatedMessageGuid") ?? readString(message, "associated_message_guid") ?? readString(message, "associatedMessageId");
|
|
913
|
-
const associatedType = readNumberLike(message, "associatedMessageType") ?? readNumberLike(message, "associated_message_type");
|
|
914
|
-
if (!associatedGuid || associatedType === void 0) return null;
|
|
915
|
-
const mapping = REACTION_TYPE_MAP.get(associatedType);
|
|
916
|
-
const emoji = ((readString(message, "associatedMessageEmoji") ?? readString(message, "associated_message_emoji") ?? readString(message, "reactionEmoji") ?? readString(message, "reaction_emoji"))?.trim() || mapping?.emoji) ?? `reaction:${associatedType}`;
|
|
917
|
-
const action = mapping?.action ?? resolveTapbackActionHint(associatedType) ?? "added";
|
|
918
|
-
const { senderId, senderIdExplicit, senderName } = extractSenderInfo(message);
|
|
919
|
-
const { chatGuid, chatIdentifier, chatId, chatName, isGroup } = extractChatContext(message);
|
|
920
|
-
const fromMe = readBoolean(message, "isFromMe") ?? readBoolean(message, "is_from_me");
|
|
921
|
-
const timestampRaw = readNumberLike(message, "date") ?? readNumberLike(message, "dateCreated") ?? readNumberLike(message, "timestamp");
|
|
922
|
-
const timestamp = typeof timestampRaw === "number" ? timestampRaw > 0xe8d4a51000 ? timestampRaw : timestampRaw * 1e3 : void 0;
|
|
923
|
-
const senderFallbackFromChatGuid = !senderIdExplicit && !isGroup && chatGuid ? extractHandleFromChatGuid(chatGuid) : null;
|
|
924
|
-
const normalizedSender = normalizeBlueBubblesHandle(senderId || senderFallbackFromChatGuid || "");
|
|
925
|
-
if (!normalizedSender) return null;
|
|
926
|
-
return {
|
|
927
|
-
action,
|
|
928
|
-
emoji,
|
|
929
|
-
senderId: normalizedSender,
|
|
930
|
-
senderIdExplicit,
|
|
931
|
-
senderName,
|
|
932
|
-
messageId: associatedGuid,
|
|
933
|
-
timestamp,
|
|
934
|
-
isGroup,
|
|
935
|
-
chatId,
|
|
936
|
-
chatGuid,
|
|
937
|
-
chatIdentifier,
|
|
938
|
-
chatName,
|
|
939
|
-
fromMe
|
|
940
|
-
};
|
|
941
|
-
}
|
|
942
|
-
//#endregion
|
|
943
|
-
//#region extensions/bluebubbles/src/multipart.ts
|
|
944
|
-
function concatUint8Arrays(parts) {
|
|
945
|
-
const totalLength = parts.reduce((acc, part) => acc + part.length, 0);
|
|
946
|
-
const body = new Uint8Array(totalLength);
|
|
947
|
-
let offset = 0;
|
|
948
|
-
for (const part of parts) {
|
|
949
|
-
body.set(part, offset);
|
|
950
|
-
offset += part.length;
|
|
951
|
-
}
|
|
952
|
-
return body;
|
|
953
|
-
}
|
|
954
|
-
async function postMultipartFormData(params) {
|
|
955
|
-
const body = Buffer.from(concatUint8Arrays(params.parts));
|
|
956
|
-
const headers = {};
|
|
957
|
-
if (params.extraHeaders) new Headers(params.extraHeaders).forEach((value, key) => {
|
|
958
|
-
headers[key] = value;
|
|
959
|
-
});
|
|
960
|
-
headers["Content-Type"] = `multipart/form-data; boundary=${params.boundary}`;
|
|
961
|
-
return await blueBubblesFetchWithTimeout(params.url, {
|
|
962
|
-
method: "POST",
|
|
963
|
-
headers,
|
|
964
|
-
body
|
|
965
|
-
}, params.timeoutMs, params.ssrfPolicy);
|
|
966
|
-
}
|
|
967
|
-
async function assertMultipartActionOk(response, action) {
|
|
968
|
-
if (response.ok) return;
|
|
969
|
-
const errorText = await response.text().catch(() => "");
|
|
970
|
-
throw new Error(`BlueBubbles ${action} failed (${response.status}): ${errorText || "unknown"}`);
|
|
971
|
-
}
|
|
972
|
-
//#endregion
|
|
973
|
-
//#region extensions/bluebubbles/src/client.ts
|
|
974
|
-
const DEFAULT_TIMEOUT_MS = 1e4;
|
|
975
|
-
const DEFAULT_ATTACHMENT_MAX_BYTES = 8 * 1024 * 1024;
|
|
976
|
-
const DEFAULT_MULTIPART_TIMEOUT_MS = 6e4;
|
|
977
|
-
function blueBubblesQueryStringAuth(password) {
|
|
978
|
-
return {
|
|
979
|
-
id: "query-string",
|
|
980
|
-
decorate({ url }) {
|
|
981
|
-
url.searchParams.set("password", password);
|
|
982
|
-
}
|
|
983
|
-
};
|
|
984
|
-
}
|
|
985
|
-
function safeExtractHostname(baseUrl) {
|
|
986
|
-
try {
|
|
987
|
-
return new URL(normalizeBlueBubblesServerUrl(baseUrl)).hostname.trim() || void 0;
|
|
988
|
-
} catch {
|
|
989
|
-
return;
|
|
990
|
-
}
|
|
991
|
-
}
|
|
992
|
-
/**
|
|
993
|
-
* Resolve the BB client's SSRF policy at construction time. Three modes —
|
|
994
|
-
* all of which go through `fetchWithSsrFGuard`; we never hand back a policy
|
|
995
|
-
* that skips the guard:
|
|
996
|
-
*
|
|
997
|
-
* 1. `{ allowPrivateNetwork: true }` — user explicitly opted in
|
|
998
|
-
* (`network.dangerouslyAllowPrivateNetwork: true`). Private/loopback
|
|
999
|
-
* addresses are permitted for this client.
|
|
1000
|
-
*
|
|
1001
|
-
* 2. `{ allowedHostnames: [trustedHostname] }` — narrow allowlist. Applied
|
|
1002
|
-
* when we have a parseable hostname AND the user has not explicitly
|
|
1003
|
-
* opted out (or the hostname isn't private anyway). This is the case
|
|
1004
|
-
* that closes #34749, #57181, #59722, #60715 for self-hosted BB on
|
|
1005
|
-
* private/localhost addresses without requiring a full opt-in.
|
|
1006
|
-
*
|
|
1007
|
-
* 3. `{}` — guarded with the default-deny policy. Applied when we can't
|
|
1008
|
-
* produce a valid allowlist (opt-out on a private hostname, or an
|
|
1009
|
-
* unparseable baseUrl). Previously returned `undefined` and skipped
|
|
1010
|
-
* the guard entirely, which was an SSRF bypass when a user explicitly
|
|
1011
|
-
* opted out of private-network access. Aisle #68234 found this.
|
|
1012
|
-
*
|
|
1013
|
-
* Prior to this helper, the logic lived inline in `attachments.ts` and was
|
|
1014
|
-
* inconsistently replicated across 15+ callsites. Resolving once ensures
|
|
1015
|
-
* every request from a client instance uses the same policy.
|
|
1016
|
-
*/
|
|
1017
|
-
function resolveBlueBubblesClientSsrfPolicy(params) {
|
|
1018
|
-
const trustedHostname = safeExtractHostname(params.baseUrl);
|
|
1019
|
-
const trustedHostnameIsPrivate = trustedHostname ? isBlockedHostnameOrIp(trustedHostname) : false;
|
|
1020
|
-
if (params.allowPrivateNetwork) return {
|
|
1021
|
-
ssrfPolicy: { allowPrivateNetwork: true },
|
|
1022
|
-
trustedHostname,
|
|
1023
|
-
trustedHostnameIsPrivate
|
|
1024
|
-
};
|
|
1025
|
-
if (trustedHostname && (params.allowPrivateNetworkConfig !== false || !trustedHostnameIsPrivate)) return {
|
|
1026
|
-
ssrfPolicy: { allowedHostnames: [trustedHostname] },
|
|
1027
|
-
trustedHostname,
|
|
1028
|
-
trustedHostnameIsPrivate
|
|
1029
|
-
};
|
|
1030
|
-
return {
|
|
1031
|
-
ssrfPolicy: {},
|
|
1032
|
-
trustedHostname,
|
|
1033
|
-
trustedHostnameIsPrivate
|
|
1034
|
-
};
|
|
1035
|
-
}
|
|
1036
|
-
function readMediaFetchErrorCode(error) {
|
|
1037
|
-
if (!error || typeof error !== "object") return;
|
|
1038
|
-
const code = error.code;
|
|
1039
|
-
return code === "max_bytes" || code === "http_error" || code === "fetch_failed" ? code : void 0;
|
|
1040
|
-
}
|
|
1041
|
-
var BlueBubblesClient = class {
|
|
1042
|
-
constructor(params) {
|
|
1043
|
-
this.accountId = params.accountId;
|
|
1044
|
-
this.baseUrl = params.baseUrl;
|
|
1045
|
-
this.password = params.password;
|
|
1046
|
-
this.ssrfPolicy = params.ssrfPolicy;
|
|
1047
|
-
this.trustedHostname = params.trustedHostname;
|
|
1048
|
-
this.trustedHostnameIsPrivate = params.trustedHostnameIsPrivate;
|
|
1049
|
-
this.defaultTimeoutMs = params.defaultTimeoutMs;
|
|
1050
|
-
this.authStrategy = params.authStrategy;
|
|
1051
|
-
}
|
|
1052
|
-
/**
|
|
1053
|
-
* Read the resolved SSRF policy for this client. Exposed primarily for tests
|
|
1054
|
-
* and diagnostics; production code should never need to inspect it.
|
|
1055
|
-
*/
|
|
1056
|
-
getSsrfPolicy() {
|
|
1057
|
-
return this.ssrfPolicy;
|
|
1058
|
-
}
|
|
1059
|
-
buildAuthorizedRequest(params) {
|
|
1060
|
-
const normalized = normalizeBlueBubblesServerUrl(this.baseUrl);
|
|
1061
|
-
const url = new URL(params.path, `${normalized}/`);
|
|
1062
|
-
const init = {
|
|
1063
|
-
...params.init,
|
|
1064
|
-
method: params.method
|
|
1065
|
-
};
|
|
1066
|
-
this.authStrategy.decorate({
|
|
1067
|
-
url,
|
|
1068
|
-
init
|
|
1069
|
-
});
|
|
1070
|
-
return {
|
|
1071
|
-
url: url.toString(),
|
|
1072
|
-
init
|
|
1073
|
-
};
|
|
1074
|
-
}
|
|
1075
|
-
/**
|
|
1076
|
-
* Core request method. All typed operations on the client route through
|
|
1077
|
-
* this method, which handles auth decoration, SSRF policy, and timeout.
|
|
1078
|
-
*/
|
|
1079
|
-
async request(params) {
|
|
1080
|
-
const init = {};
|
|
1081
|
-
if (params.headers) init.headers = { ...params.headers };
|
|
1082
|
-
if (params.body !== void 0) {
|
|
1083
|
-
init.headers = {
|
|
1084
|
-
"Content-Type": "application/json",
|
|
1085
|
-
...init.headers
|
|
1086
|
-
};
|
|
1087
|
-
init.body = JSON.stringify(params.body);
|
|
1088
|
-
}
|
|
1089
|
-
const prepared = this.buildAuthorizedRequest({
|
|
1090
|
-
path: params.path,
|
|
1091
|
-
method: params.method,
|
|
1092
|
-
init
|
|
1093
|
-
});
|
|
1094
|
-
return await blueBubblesFetchWithTimeout(prepared.url, prepared.init, params.timeoutMs ?? this.defaultTimeoutMs, this.ssrfPolicy);
|
|
1095
|
-
}
|
|
1096
|
-
/**
|
|
1097
|
-
* JSON request helper. Returns both the response (for status/headers) and
|
|
1098
|
-
* parsed body (null on non-ok or parse failure — callers check both).
|
|
1099
|
-
*/
|
|
1100
|
-
async requestJson(params) {
|
|
1101
|
-
const response = await this.request(params);
|
|
1102
|
-
if (!response.ok) return {
|
|
1103
|
-
response,
|
|
1104
|
-
data: null
|
|
1105
|
-
};
|
|
1106
|
-
return {
|
|
1107
|
-
response,
|
|
1108
|
-
data: await response.json().catch(() => null)
|
|
1109
|
-
};
|
|
1110
|
-
}
|
|
1111
|
-
/**
|
|
1112
|
-
* Multipart POST (attachment send, group icon set). The caller supplies the
|
|
1113
|
-
* boundary and body parts; the client handles URL construction, auth, and
|
|
1114
|
-
* SSRF policy. Timeout defaults to 60s because uploads can be large.
|
|
1115
|
-
*
|
|
1116
|
-
* Auth-decorated headers from `prepared.init` are forwarded via `extraHeaders`
|
|
1117
|
-
* so header-auth strategies keep working on multipart paths. (Greptile #68234 P1)
|
|
1118
|
-
*/
|
|
1119
|
-
async requestMultipart(params) {
|
|
1120
|
-
const prepared = this.buildAuthorizedRequest({
|
|
1121
|
-
path: params.path,
|
|
1122
|
-
method: "POST",
|
|
1123
|
-
init: {}
|
|
1124
|
-
});
|
|
1125
|
-
return await postMultipartFormData({
|
|
1126
|
-
url: prepared.url,
|
|
1127
|
-
boundary: params.boundary,
|
|
1128
|
-
parts: params.parts,
|
|
1129
|
-
timeoutMs: params.timeoutMs ?? DEFAULT_MULTIPART_TIMEOUT_MS,
|
|
1130
|
-
ssrfPolicy: this.ssrfPolicy,
|
|
1131
|
-
extraHeaders: prepared.init.headers
|
|
1132
|
-
});
|
|
1133
|
-
}
|
|
1134
|
-
/** GET /api/v1/ping — health check. Raw response for status inspection. */
|
|
1135
|
-
async ping(params = {}) {
|
|
1136
|
-
return await this.request({
|
|
1137
|
-
method: "GET",
|
|
1138
|
-
path: "/api/v1/ping",
|
|
1139
|
-
timeoutMs: params.timeoutMs
|
|
1140
|
-
});
|
|
1141
|
-
}
|
|
1142
|
-
/** GET /api/v1/server/info — server/OS/Private-API metadata. */
|
|
1143
|
-
async getServerInfo(params = {}) {
|
|
1144
|
-
return await this.request({
|
|
1145
|
-
method: "GET",
|
|
1146
|
-
path: "/api/v1/server/info",
|
|
1147
|
-
timeoutMs: params.timeoutMs
|
|
1148
|
-
});
|
|
1149
|
-
}
|
|
1150
|
-
/**
|
|
1151
|
-
* POST /api/v1/message/react. Uses the same SSRF policy as every other
|
|
1152
|
-
* operation on this client — closing the gap where `reactions.ts` passed
|
|
1153
|
-
* `{}` (always guarded, always blocks private IPs) while other callsites
|
|
1154
|
-
* used mode-aware policies.
|
|
1155
|
-
*/
|
|
1156
|
-
async react(params) {
|
|
1157
|
-
return await this.request({
|
|
1158
|
-
method: "POST",
|
|
1159
|
-
path: "/api/v1/message/react",
|
|
1160
|
-
body: {
|
|
1161
|
-
chatGuid: params.chatGuid,
|
|
1162
|
-
selectedMessageGuid: params.selectedMessageGuid,
|
|
1163
|
-
reaction: params.reaction,
|
|
1164
|
-
partIndex: typeof params.partIndex === "number" ? params.partIndex : 0
|
|
1165
|
-
},
|
|
1166
|
-
timeoutMs: params.timeoutMs
|
|
1167
|
-
});
|
|
1168
|
-
}
|
|
1169
|
-
/**
|
|
1170
|
-
* GET /api/v1/message/{guid} to read attachment metadata. BlueBubbles may
|
|
1171
|
-
* fire `new-message` before attachment indexing completes, so this re-reads
|
|
1172
|
-
* after a delay. (#65430, #67437)
|
|
1173
|
-
*/
|
|
1174
|
-
async getMessageAttachments(params) {
|
|
1175
|
-
const { response, data } = await this.requestJson({
|
|
1176
|
-
method: "GET",
|
|
1177
|
-
path: `/api/v1/message/${encodeURIComponent(params.messageGuid)}`,
|
|
1178
|
-
timeoutMs: params.timeoutMs
|
|
1179
|
-
});
|
|
1180
|
-
if (!response.ok || typeof data !== "object" || data === null) return [];
|
|
1181
|
-
const inner = data.data;
|
|
1182
|
-
if (typeof inner !== "object" || inner === null) return [];
|
|
1183
|
-
return extractAttachments(inner);
|
|
1184
|
-
}
|
|
1185
|
-
/**
|
|
1186
|
-
* Download an attachment via the channel media fetcher. Unlike the legacy
|
|
1187
|
-
* helper, the SSRF policy is threaded to BOTH `fetchRemoteMedia` AND the
|
|
1188
|
-
* `fetchImpl` callback — closing #34749 where the callback silently fell
|
|
1189
|
-
* back to the unguarded fetch path regardless of the outer policy.
|
|
1190
|
-
*
|
|
1191
|
-
* Note: the actual SSRF check still happens upstream in `fetchRemoteMedia`.
|
|
1192
|
-
* Passing `ssrfPolicy` to `blueBubblesFetchWithTimeout` in the callback
|
|
1193
|
-
* keeps it in the guarded path if the host needs re-validation (e.g. on a
|
|
1194
|
-
* BB Server that issues 302 redirects to a different host).
|
|
1195
|
-
*/
|
|
1196
|
-
async downloadAttachment(params) {
|
|
1197
|
-
const guid = params.attachment.guid?.trim();
|
|
1198
|
-
if (!guid) throw new Error("BlueBubbles attachment guid is required");
|
|
1199
|
-
const maxBytes = typeof params.maxBytes === "number" ? params.maxBytes : DEFAULT_ATTACHMENT_MAX_BYTES;
|
|
1200
|
-
const prepared = this.buildAuthorizedRequest({
|
|
1201
|
-
path: `/api/v1/attachment/${encodeURIComponent(guid)}/download`,
|
|
1202
|
-
method: "GET",
|
|
1203
|
-
init: {}
|
|
1204
|
-
});
|
|
1205
|
-
const clientSsrfPolicy = this.ssrfPolicy;
|
|
1206
|
-
const effectiveTimeoutMs = params.timeoutMs ?? this.defaultTimeoutMs;
|
|
1207
|
-
const preparedHeaders = prepared.init.headers;
|
|
1208
|
-
try {
|
|
1209
|
-
const fetched = await getBlueBubblesRuntime().channel.media.fetchRemoteMedia({
|
|
1210
|
-
url: prepared.url,
|
|
1211
|
-
filePathHint: params.attachment.transferName ?? params.attachment.guid ?? "attachment",
|
|
1212
|
-
maxBytes,
|
|
1213
|
-
ssrfPolicy: clientSsrfPolicy,
|
|
1214
|
-
fetchImpl: async (input, init) => {
|
|
1215
|
-
const mergedHeaders = new Headers(preparedHeaders);
|
|
1216
|
-
if (init?.headers) new Headers(init.headers).forEach((value, key) => mergedHeaders.set(key, value));
|
|
1217
|
-
return await blueBubblesFetchWithTimeout(resolveRequestUrl(input), {
|
|
1218
|
-
...init,
|
|
1219
|
-
method: init?.method ?? "GET",
|
|
1220
|
-
headers: mergedHeaders
|
|
1221
|
-
}, effectiveTimeoutMs, clientSsrfPolicy);
|
|
1222
|
-
}
|
|
1223
|
-
});
|
|
1224
|
-
return {
|
|
1225
|
-
buffer: new Uint8Array(fetched.buffer),
|
|
1226
|
-
contentType: fetched.contentType ?? params.attachment.mimeType ?? void 0
|
|
1227
|
-
};
|
|
1228
|
-
} catch (error) {
|
|
1229
|
-
if (readMediaFetchErrorCode(error) === "max_bytes") throw new Error(`BlueBubbles attachment too large (limit ${maxBytes} bytes)`, { cause: error });
|
|
1230
|
-
throw new Error(`BlueBubbles attachment download failed: ${formatErrorMessage(error)}`, { cause: error });
|
|
1231
|
-
}
|
|
1232
|
-
}
|
|
1233
|
-
};
|
|
1234
|
-
const clientFingerprints = /* @__PURE__ */ new Map();
|
|
1235
|
-
function buildClientFingerprint(params) {
|
|
1236
|
-
return JSON.stringify({
|
|
1237
|
-
baseUrl: params.baseUrl,
|
|
1238
|
-
password: params.password,
|
|
1239
|
-
authStrategyId: params.authStrategyId,
|
|
1240
|
-
allowPrivateNetwork: params.allowPrivateNetwork,
|
|
1241
|
-
allowPrivateNetworkConfig: params.allowPrivateNetworkConfig ?? null
|
|
1242
|
-
});
|
|
1243
|
-
}
|
|
1244
|
-
/**
|
|
1245
|
-
* Get or create a `BlueBubblesClient` for one BB account. The client is cached
|
|
1246
|
-
* by `accountId` — the next call with the same account AND same {baseUrl,
|
|
1247
|
-
* password} returns the existing instance. Password or URL change rebuilds.
|
|
1248
|
-
* Call `invalidateBlueBubblesClient(accountId)` from account config reload
|
|
1249
|
-
* paths to evict explicitly.
|
|
1250
|
-
*/
|
|
1251
|
-
function createBlueBubblesClient(opts = {}) {
|
|
1252
|
-
const resolved = resolveBlueBubblesServerAccount({
|
|
1253
|
-
cfg: opts.cfg,
|
|
1254
|
-
accountId: opts.accountId,
|
|
1255
|
-
serverUrl: opts.serverUrl,
|
|
1256
|
-
password: opts.password
|
|
1257
|
-
});
|
|
1258
|
-
const cacheKey = resolved.accountId || "default";
|
|
1259
|
-
const authStrategy = (opts.authStrategy ?? blueBubblesQueryStringAuth)(resolved.password);
|
|
1260
|
-
const fingerprint = buildClientFingerprint({
|
|
1261
|
-
baseUrl: resolved.baseUrl,
|
|
1262
|
-
password: resolved.password,
|
|
1263
|
-
authStrategyId: authStrategy.id,
|
|
1264
|
-
allowPrivateNetwork: resolved.allowPrivateNetwork,
|
|
1265
|
-
allowPrivateNetworkConfig: resolved.allowPrivateNetworkConfig
|
|
1266
|
-
});
|
|
1267
|
-
const cached = clientFingerprints.get(cacheKey);
|
|
1268
|
-
if (cached && cached.fingerprint === fingerprint) return cached.client;
|
|
1269
|
-
const policyResult = resolveBlueBubblesClientSsrfPolicy({
|
|
1270
|
-
baseUrl: resolved.baseUrl,
|
|
1271
|
-
allowPrivateNetwork: resolved.allowPrivateNetwork,
|
|
1272
|
-
allowPrivateNetworkConfig: resolved.allowPrivateNetworkConfig
|
|
1273
|
-
});
|
|
1274
|
-
const client = new BlueBubblesClient({
|
|
1275
|
-
accountId: cacheKey,
|
|
1276
|
-
baseUrl: resolved.baseUrl,
|
|
1277
|
-
password: resolved.password,
|
|
1278
|
-
ssrfPolicy: policyResult.ssrfPolicy,
|
|
1279
|
-
trustedHostname: policyResult.trustedHostname,
|
|
1280
|
-
trustedHostnameIsPrivate: policyResult.trustedHostnameIsPrivate,
|
|
1281
|
-
defaultTimeoutMs: opts.timeoutMs ?? DEFAULT_TIMEOUT_MS,
|
|
1282
|
-
authStrategy
|
|
1283
|
-
});
|
|
1284
|
-
clientFingerprints.set(cacheKey, {
|
|
1285
|
-
client,
|
|
1286
|
-
fingerprint
|
|
1287
|
-
});
|
|
1288
|
-
return client;
|
|
1289
|
-
}
|
|
1290
|
-
/**
|
|
1291
|
-
* Build a BlueBubblesClient from a pre-resolved `{baseUrl, password,
|
|
1292
|
-
* allowPrivateNetwork}` tuple, skipping the account/config resolution path.
|
|
1293
|
-
*
|
|
1294
|
-
* Used by low-level helpers (`probe.ts`, `catchup.ts`, `history.ts`, etc.)
|
|
1295
|
-
* that are called with the resolved tuple rather than a full config bag.
|
|
1296
|
-
* Migrated callers pass their existing booleans straight through — the
|
|
1297
|
-
* three-mode policy resolution then runs exactly once here.
|
|
1298
|
-
*
|
|
1299
|
-
* Uncached — intended for short-lived callsites. Prefer `createBlueBubblesClient`
|
|
1300
|
-
* when a `cfg` + `accountId` are available.
|
|
1301
|
-
*/
|
|
1302
|
-
function createBlueBubblesClientFromParts(params) {
|
|
1303
|
-
const policyResult = resolveBlueBubblesClientSsrfPolicy({
|
|
1304
|
-
baseUrl: params.baseUrl,
|
|
1305
|
-
allowPrivateNetwork: params.allowPrivateNetwork,
|
|
1306
|
-
allowPrivateNetworkConfig: params.allowPrivateNetworkConfig
|
|
1307
|
-
});
|
|
1308
|
-
const authFactory = params.authStrategy ?? blueBubblesQueryStringAuth;
|
|
1309
|
-
return new BlueBubblesClient({
|
|
1310
|
-
accountId: params.accountId || "default",
|
|
1311
|
-
baseUrl: params.baseUrl,
|
|
1312
|
-
password: params.password,
|
|
1313
|
-
ssrfPolicy: policyResult.ssrfPolicy,
|
|
1314
|
-
trustedHostname: policyResult.trustedHostname,
|
|
1315
|
-
trustedHostnameIsPrivate: policyResult.trustedHostnameIsPrivate,
|
|
1316
|
-
defaultTimeoutMs: params.timeoutMs ?? DEFAULT_TIMEOUT_MS,
|
|
1317
|
-
authStrategy: authFactory(params.password)
|
|
1318
|
-
});
|
|
1319
|
-
}
|
|
1320
|
-
//#endregion
|
|
1321
|
-
//#region extensions/bluebubbles/src/probe.ts
|
|
1322
|
-
/** Cache server info by account ID to avoid repeated API calls.
|
|
1323
|
-
* Size-capped to prevent unbounded growth (#4948). */
|
|
1324
|
-
const MAX_SERVER_INFO_CACHE_SIZE = 64;
|
|
1325
|
-
const serverInfoCache = /* @__PURE__ */ new Map();
|
|
1326
|
-
const CACHE_TTL_MS = 600 * 1e3;
|
|
1327
|
-
/**
|
|
1328
|
-
* Fetch server info from BlueBubbles API and cache it.
|
|
1329
|
-
* Returns cached result if available and not expired.
|
|
1330
|
-
*/
|
|
1331
|
-
async function fetchBlueBubblesServerInfo(params) {
|
|
1332
|
-
const baseUrl = normalizeSecretInputString(params.baseUrl);
|
|
1333
|
-
const password = normalizeSecretInputString(params.password);
|
|
1334
|
-
if (!baseUrl || !password) return null;
|
|
1335
|
-
const cacheKey = normalizeOptionalString(params.accountId) || "default";
|
|
1336
|
-
const cached = serverInfoCache.get(cacheKey);
|
|
1337
|
-
if (cached && cached.expires > Date.now()) return cached.info;
|
|
1338
|
-
const client = createBlueBubblesClientFromParts({
|
|
1339
|
-
baseUrl,
|
|
1340
|
-
password,
|
|
1341
|
-
allowPrivateNetwork: params.allowPrivateNetwork === true,
|
|
1342
|
-
timeoutMs: params.timeoutMs ?? 5e3
|
|
1343
|
-
});
|
|
1344
|
-
try {
|
|
1345
|
-
const res = await client.getServerInfo({ timeoutMs: params.timeoutMs ?? 5e3 });
|
|
1346
|
-
if (!res.ok) return null;
|
|
1347
|
-
const data = (await res.json().catch(() => null))?.data;
|
|
1348
|
-
if (data) {
|
|
1349
|
-
serverInfoCache.set(cacheKey, {
|
|
1350
|
-
info: data,
|
|
1351
|
-
expires: Date.now() + CACHE_TTL_MS
|
|
1352
|
-
});
|
|
1353
|
-
if (serverInfoCache.size > MAX_SERVER_INFO_CACHE_SIZE) {
|
|
1354
|
-
const oldest = serverInfoCache.keys().next().value;
|
|
1355
|
-
if (oldest !== void 0) serverInfoCache.delete(oldest);
|
|
1356
|
-
}
|
|
1357
|
-
}
|
|
1358
|
-
return data ?? null;
|
|
1359
|
-
} catch {
|
|
1360
|
-
return null;
|
|
1361
|
-
}
|
|
1362
|
-
}
|
|
1363
|
-
/**
|
|
1364
|
-
* Get cached server info synchronously (for use in describeMessageTool).
|
|
1365
|
-
* Returns null if not cached or expired.
|
|
1366
|
-
*/
|
|
1367
|
-
function getCachedBlueBubblesServerInfo(accountId) {
|
|
1368
|
-
const cacheKey = normalizeOptionalString(accountId) || "default";
|
|
1369
|
-
const cached = serverInfoCache.get(cacheKey);
|
|
1370
|
-
if (cached && cached.expires > Date.now()) return cached.info;
|
|
1371
|
-
return null;
|
|
1372
|
-
}
|
|
1373
|
-
/**
|
|
1374
|
-
* Read cached private API capability for a BlueBubbles account.
|
|
1375
|
-
* Returns null when capability is unknown (for example, before first probe).
|
|
1376
|
-
*/
|
|
1377
|
-
function getCachedBlueBubblesPrivateApiStatus(accountId) {
|
|
1378
|
-
const info = getCachedBlueBubblesServerInfo(accountId);
|
|
1379
|
-
if (!info || typeof info.private_api !== "boolean") return null;
|
|
1380
|
-
return info.private_api;
|
|
1381
|
-
}
|
|
1382
|
-
function isBlueBubblesPrivateApiStatusEnabled(status) {
|
|
1383
|
-
return status === true;
|
|
1384
|
-
}
|
|
1385
|
-
function isBlueBubblesPrivateApiEnabled(accountId) {
|
|
1386
|
-
return isBlueBubblesPrivateApiStatusEnabled(getCachedBlueBubblesPrivateApiStatus(accountId));
|
|
1387
|
-
}
|
|
1388
|
-
/**
|
|
1389
|
-
* Parse macOS version string (e.g., "15.0.1" or "26.0") into major version number.
|
|
1390
|
-
*/
|
|
1391
|
-
function parseMacOSMajorVersion(version) {
|
|
1392
|
-
if (!version) return null;
|
|
1393
|
-
const match = /^(\d+)/.exec(version.trim());
|
|
1394
|
-
return match ? Number.parseInt(match[1], 10) : null;
|
|
1395
|
-
}
|
|
1396
|
-
/**
|
|
1397
|
-
* Check if the cached server info indicates macOS 26 or higher.
|
|
1398
|
-
* Returns false if no cached info is available (fail open for action listing).
|
|
1399
|
-
*/
|
|
1400
|
-
function isMacOS26OrHigher(accountId) {
|
|
1401
|
-
const info = getCachedBlueBubblesServerInfo(accountId);
|
|
1402
|
-
if (!info?.os_version) return false;
|
|
1403
|
-
const major = parseMacOSMajorVersion(info.os_version);
|
|
1404
|
-
return major !== null && major >= 26;
|
|
1405
|
-
}
|
|
1406
|
-
async function probeBlueBubbles(params) {
|
|
1407
|
-
const baseUrl = normalizeSecretInputString(params.baseUrl);
|
|
1408
|
-
const password = normalizeSecretInputString(params.password);
|
|
1409
|
-
if (!baseUrl) return {
|
|
1410
|
-
ok: false,
|
|
1411
|
-
error: "serverUrl not configured"
|
|
1412
|
-
};
|
|
1413
|
-
if (!password) return {
|
|
1414
|
-
ok: false,
|
|
1415
|
-
error: "password not configured"
|
|
1416
|
-
};
|
|
1417
|
-
const client = createBlueBubblesClientFromParts({
|
|
1418
|
-
baseUrl,
|
|
1419
|
-
password,
|
|
1420
|
-
allowPrivateNetwork: params.allowPrivateNetwork === true,
|
|
1421
|
-
timeoutMs: params.timeoutMs
|
|
1422
|
-
});
|
|
1423
|
-
try {
|
|
1424
|
-
const res = await client.ping({ timeoutMs: params.timeoutMs });
|
|
1425
|
-
if (!res.ok) return {
|
|
1426
|
-
ok: false,
|
|
1427
|
-
status: res.status,
|
|
1428
|
-
error: `HTTP ${res.status}`
|
|
1429
|
-
};
|
|
1430
|
-
return {
|
|
1431
|
-
ok: true,
|
|
1432
|
-
status: res.status
|
|
1433
|
-
};
|
|
1434
|
-
} catch (err) {
|
|
1435
|
-
return {
|
|
1436
|
-
ok: false,
|
|
1437
|
-
status: null,
|
|
1438
|
-
error: formatErrorMessage(err)
|
|
1439
|
-
};
|
|
1440
|
-
}
|
|
1441
|
-
}
|
|
1442
|
-
//#endregion
|
|
1443
|
-
export { parseBlueBubblesTarget as A, inferBlueBubblesTargetChatType as C, normalizeBlueBubblesHandle as D, looksLikeBlueBubblesTargetId as E, resolveDefaultBlueBubblesAccountId as F, DEFAULT_SEND_TIMEOUT_MS as I, normalizeBlueBubblesServerUrl as L, listBlueBubblesAccountIds as M, resolveBlueBubblesAccount as N, normalizeBlueBubblesMessagingTarget as O, resolveBlueBubblesEffectiveAllowPrivateNetwork as P, formatBlueBubblesChatTarget as S, looksLikeBlueBubblesExplicitTargetId as T, normalizeWebhookReaction as _, isMacOS26OrHigher as a, resolveTapbackContext as b, createBlueBubblesClientFromParts as c, buildMessagePlaceholder as d, formatGroupAllowlistEntry as f, normalizeWebhookMessage as g, normalizeParticipantList as h, isBlueBubblesPrivateApiStatusEnabled as i, resolveBlueBubblesServerAccount as j, parseBlueBubblesAllowTarget as k, assertMultipartActionOk as l, formatReplyTag as m, getCachedBlueBubblesPrivateApiStatus as n, probeBlueBubbles as o, formatGroupMembers as p, isBlueBubblesPrivateApiEnabled as r, createBlueBubblesClient as s, fetchBlueBubblesServerInfo as t, asRecord as u, parseTapbackText as v, isAllowedBlueBubblesSender as w, extractHandleFromChatGuid as x, resolveGroupFlagFromChatGuid as y };
|