@gaodefa/daocore 2026.5.29 → 2026.5.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/abort-DI3P6TIb.js +277 -0
- package/dist/abort.runtime-B6Z7lDEa.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/account-inspect-BFz7X0TX.js +173 -0
- package/dist/accounts-BoYYrY7x.js +107 -0
- package/dist/accounts-Busq29zW.js +107 -0
- package/dist/accounts-CuvH2tuN.js +119 -0
- package/dist/accounts-DkIcqvf7.js +2 -0
- package/dist/acp-runtime-BA8lzXzf.js +26 -0
- package/dist/acp-spawn-DPz2aX3A.js +2 -0
- package/dist/acp-spawn-DvVCsWYV.js +1275 -0
- package/dist/acp-stateful-target-driver-DcC76aZW.js +89 -0
- package/dist/action-kill-D-dVisIX.js +33 -0
- package/dist/action-runtime-BEiqwxDD.js +469 -0
- package/dist/action-runtime-api-1LzcGjcX.js +2 -0
- package/dist/action-send-c3CnDuPg.js +39 -0
- package/dist/action-spawn-Dj4kwpWs.js +47 -0
- package/dist/actions-qLccmQBc.js +161 -0
- package/dist/actions.runtime-B5vYAgNi.js +5 -0
- package/dist/agent-command-D6Ds198G.js +1367 -0
- package/dist/agent-components.runtime-xquK0B3L.js +10 -0
- package/dist/agent-components.runtime.js +1 -1
- package/dist/agent-harness-runtime-Dq1fCBOM.js +180 -0
- package/dist/agent-harness-task-runtime-DvSEqFkD.js +140 -0
- package/dist/agent-lm5ZYOFy.js +3 -0
- package/dist/agent-runner-execution-Dbh2pDhQ.js +1713 -0
- package/dist/agent-runner-utils-Di3r2T1T.js +266 -0
- package/dist/agent-runner.runtime-BW90EcGW.js +3455 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-BgIT5Ytc.js +229 -0
- package/dist/agent-via-gateway-DMMS8-hK.js +463 -0
- package/dist/agent-ylolD8-V.js +2 -0
- package/dist/api-BB4vXLtW.js +2 -0
- package/dist/api-CUhM3KNB.js +134 -0
- package/dist/api-CewRHSbT.js +6 -0
- package/dist/api-CfKjNJlW.js +2 -0
- package/dist/api-Rsnqui1u.js +3 -0
- package/dist/api-k7AvxwHr.js +639 -0
- package/dist/apply-DQ4TQNMA.js +54 -0
- package/dist/apply-S_75Py4Y.js +41 -0
- package/dist/approval-handler.runtime-Cthxrstu.js +130 -0
- package/dist/assistant-Cp9pGaBw.js +291 -0
- package/dist/attachment-normalize-5R0bLLOj.js +225 -0
- package/dist/attempt-execution-DuyyZYsU.js +558 -0
- package/dist/attempt-execution.runtime-DF2GPgNh.js +3 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt-execution.shared-CwdukA3t.js +38 -0
- package/dist/attempt.prompt-helpers-CUqKtIa5.js +475 -0
- package/dist/attempt.tool-run-context-BbN4_BYO.js +2094 -0
- package/dist/binding-routing-C6Ex2Blu.js +113 -0
- package/dist/binding-targets-BqREncSL.js +121 -0
- package/dist/bot-DGMEkaIJ.js +7894 -0
- package/dist/bot-deps-BltYjeMX.js +2 -0
- package/dist/bot-deps-XvGCor9f.js +747 -0
- package/dist/bot-message-context.runtime-kK-xvLV7.js +7 -0
- package/dist/bot-message-context.runtime.js +1 -1
- package/dist/bot-message-context.session.runtime-DpOIJUae.js +12 -0
- package/dist/bot-message-context.session.runtime.js +1 -1
- package/dist/bot-native-commands.delivery.runtime-D49p5Lc1.js +4 -0
- package/dist/bot-native-commands.delivery.runtime.js +1 -1
- package/dist/bot-native-commands.runtime-8XBdSpkQ.js +13 -0
- package/dist/bot-native-commands.runtime.js +1 -1
- package/dist/bridge-server-y_XGduPx.js +113 -0
- package/dist/browser-cli-B2jmmTT3.js +230 -0
- package/dist/browser-cli-actions-input-JQt5ZQcn.js +473 -0
- package/dist/browser-cli-actions-observe-CrfKh6AX.js +81 -0
- package/dist/browser-cli-debug-DQACWlvC.js +137 -0
- package/dist/browser-cli-inspect-DDnxx0Xw.js +104 -0
- package/dist/browser-cli-lEuOnZzs.js +2 -0
- package/dist/browser-cli-manage-DogmwtYt.js +443 -0
- package/dist/browser-cli-resize-BHuV71VZ.js +26 -0
- package/dist/browser-cli-shared-CidShgoF.js +50 -0
- package/dist/browser-cli-state-i8cCGbiQ.js +337 -0
- package/dist/browser-control-auth-CKfXdXWj.js +2 -0
- package/dist/browser-profiles-ATBTvUGh.js +2 -0
- package/dist/browser-runtime-KmCT6FuL.js +384 -0
- package/dist/build-DOOT6f62.js +257 -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/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/capability-cli-DwvrwB-g.js +1782 -0
- package/dist/channel-B-wgK1bK.js +481 -0
- package/dist/channel-B1e_k1P0.js +867 -0
- package/dist/channel-BRDfa5tc.js +1777 -0
- package/dist/channel-BVEO1O4p.js +376 -0
- package/dist/channel-BYlO5l1d.js +508 -0
- package/dist/channel-Bl0sPoNx.js +653 -0
- package/dist/channel-C84xtDBy.js +1134 -0
- package/dist/channel-CLgKq4Ds.js +1556 -0
- package/dist/channel-CZT0qxLh.js +1249 -0
- package/dist/channel-CffBHWkb.js +955 -0
- package/dist/channel-D34ZJvVB.js +2126 -0
- package/dist/channel-DcdXLo_W.js +238 -0
- package/dist/channel-DnK5TrXV.js +362 -0
- package/dist/channel-Dzj4RHY2.js +740 -0
- package/dist/channel-OhZzLZCj.js +562 -0
- package/dist/channel-actions.runtime-Cdvhqc9s.js +265 -0
- package/dist/channel-actions.runtime.js +1 -1
- package/dist/channel-core-Dz9I_R4j.js +5 -0
- package/dist/channel-inbound-COGoV_aS.js +80 -0
- package/dist/channel-mP6HCIMr.js +1496 -0
- package/dist/channel-plugin-runtime-C0R46KeG.js +998 -0
- package/dist/channel-quGdgWel.js +808 -0
- package/dist/channel-runtime-FvPQoIF9.js +408 -0
- package/dist/channel.runtime-2vUz3gij.js +109 -0
- package/dist/channel.runtime-BZLDSNuQ.js +254 -0
- package/dist/channel.runtime-Bo5jO0Hj.js +4 -0
- package/dist/channel.runtime-CDgvrjM2.js +652 -0
- package/dist/channel.runtime-COf8SDFn.js +88 -0
- package/dist/channel.runtime-C_C1f8lu.js +733 -0
- package/dist/channel.runtime-CqPbsg8t.js +2528 -0
- package/dist/channel.runtime-DtV85Khx.js +1008 -0
- package/dist/channel.runtime-Spt1ukGW.js +21009 -0
- package/dist/channel.setup-Bc0LUQS1.js +1098 -0
- package/dist/channel.setup-ChTkj2hq.js +343 -0
- package/dist/channel.setup-CpMD9F8i.js +10 -0
- package/dist/chat-mUsjD5YN.js +2666 -0
- package/dist/chrome-u314zcbM.js +1503 -0
- package/dist/cli/run-main.js +5 -5
- package/dist/cli-CJMoqXrc.js +1341 -0
- package/dist/cli-compaction-qGYB7suI.js +347 -0
- package/dist/cli-metadata-BBJFpNU9.js +22 -0
- package/dist/cli-runner-C0kcts0I.js +540 -0
- package/dist/cli-runner-CTm8K6s8.js +2 -0
- package/dist/cli-runner.runtime-C8deL5FL.js +3 -0
- package/dist/cli-runner.runtime-DDAg1D0L.js +4 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +8 -8
- package/dist/client-CPxpgs4m.js +650 -0
- package/dist/client-adapter-CLlqOqfu.js +897 -0
- package/dist/client-factory-R7Rr2jwn.js +9 -0
- package/dist/command-auth-CkQP1buP.js +135 -0
- package/dist/command-handlers-CJEjFyMk.js +1609 -0
- package/dist/command-registry-BDgyOqDw.js +4 -0
- package/dist/command-registry-BVi5Jn1S.js +9 -0
- package/dist/command-registry-core-JCfsVRtz.js +110 -0
- package/dist/command-status.runtime-CM1JLzi6.js +90 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-acp-C1-I78U6.js +74 -0
- package/dist/commands-compact.runtime-DOsNavwp.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-handlers.runtime-BD1n2WGw.js +6154 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-status-DU_UTQz1.js +16 -0
- package/dist/commands-status-DejfTakp.js +3 -0
- package/dist/commands-status.runtime-DejfTakp.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-D7vo_2Y_.js +3 -0
- package/dist/commands-subagents-control.runtime-DGybTjJ6.js +2 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-BEBXAMea.js +2 -0
- package/dist/commands-system-prompt-gj3oQpQO.js +162 -0
- package/dist/commands.runtime-CgXX70IN.js +176 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/commitments/runtime.js +1 -1
- package/dist/compact-C41XxMDt.js +480 -0
- package/dist/compact-DUVAF9EC.js +1141 -0
- package/dist/compact.runtime-COMRg6s3.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-CmEYoB9a.js +315 -0
- package/dist/computer-use-BwJHu1QF.js +367 -0
- package/dist/config-ATBTvUGh.js +2 -0
- package/dist/config-DlNgjF8W.js +373 -0
- package/dist/config-mutations-tl_OqI6d.js +159 -0
- package/dist/context-engine-host-compat-BNPAIK9F.js +288 -0
- package/dist/context-engine-host-compat-C69CK7zS.js +2 -0
- package/dist/context-engine-lifecycle-iQ8f5a_-.js +1274 -0
- package/dist/control-auth-vVxyGKxY.js +114 -0
- package/dist/control-service-73nj79EW.js +145 -0
- package/dist/control-ui/assets/agents-DdWIz8Vk.js +1008 -0
- package/dist/control-ui/assets/channel-config-extras-C7ELhuDi.js +2 -0
- package/dist/control-ui/assets/channels-Bsoj-9BS.js +367 -0
- package/dist/control-ui/assets/cron-BRTEw1tT.js +1013 -0
- package/dist/control-ui/assets/debug-EKl_F8_L.js +97 -0
- package/dist/control-ui/assets/index-DSbSO7ys.js +7370 -0
- package/dist/control-ui/assets/instances-B1AoYwI5.js +57 -0
- package/dist/control-ui/assets/logs-BChOznzh.js +74 -0
- package/dist/control-ui/assets/nodes-5yebKh9k.js +436 -0
- package/dist/control-ui/assets/sessions-BlDYNThc.js +399 -0
- package/dist/control-ui/assets/skills-shared-CNFnf7KU.js +11 -0
- package/dist/control-ui/assets/skills-uxTDRmLx.js +314 -0
- package/dist/control-ui/index.html +1 -1
- package/dist/control-ui/sw.js +1 -1
- package/dist/conversation-binding-runtime-CmoTKcY1.js +4 -0
- package/dist/conversation-runtime-BxOHxuin.js +31 -0
- package/dist/core-D0Y2H55f.js +282 -0
- package/dist/core-api-BKlJUtDt.js +5 -0
- package/dist/core-api-_fiftUHn.js +2 -0
- package/dist/crestodian/crestodian.js +1 -1
- package/dist/crestodian/rescue-message.js +1 -1
- package/dist/crestodian-BJifoQiR.js +55 -0
- package/dist/daocore-tools-BMdF8RwK.js +11727 -0
- package/dist/delivery-e2ci_bcX.js +1002 -0
- package/dist/dialogue-BXayGhnz.js +37 -0
- package/dist/dir-fetch-tool-Cara5mZh.js +565 -0
- package/dist/dir-list-tool-CQ8Bo5Ez.js +100 -0
- package/dist/direct-dm-CPk6Qm9D.js +64 -0
- package/dist/directive-handling.fast-lane-BQ9aXqk8.js +68 -0
- package/dist/directive-handling.impl--a5AGurq.js +818 -0
- package/dist/directive-handling.impl-C4JqMwle.js +2 -0
- package/dist/directive-handling.model-selection-pyTYMIXn.js +122 -0
- package/dist/directive-handling.persist.runtime-B7vWT1r9.js +263 -0
- package/dist/directive-handling.persist.runtime.js +1 -1
- package/dist/dispatch-3Ru_eGq1.js +1640 -0
- package/dist/dispatch-acp-transcript.runtime-CYMP-5oE.js +40 -0
- package/dist/dispatch-acp-transcript.runtime.js +1 -1
- package/dist/dispatch-acp.runtime-BVCiklXk.js +18 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/doctor-B8mR3Sgr.js +2 -0
- package/dist/doctor-BJ6DuerV.js +6 -0
- package/dist/doctor-config-flow-BdOGs_zn.js +1741 -0
- package/dist/doctor-core-checks-CDf0stz-.js +2 -0
- package/dist/doctor-core-checks-Cpdnu2XI.js +573 -0
- package/dist/doctor-health-0qv_acBu.js +65 -0
- package/dist/doctor-health-contributions-Db1FQgFw.js +696 -0
- package/dist/doctor-lint-C1g4Llgl.js +94 -0
- package/dist/doctor-state-integrity-C8iXFLJ7.js +1231 -0
- package/dist/doctor-update-CsPu6p3d.js +58 -0
- package/dist/dynamic-tools-YQ0z0YKH.js +486 -0
- package/dist/embedded-backend-S0cahIZw.js +579 -0
- package/dist/embedded-gateway-stub.runtime-Cjw12ALm.js +12 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/exec-approvals-ArHHjoE-.js +149 -0
- package/dist/extensionAPI.js +1 -1
- package/dist/extensions/active-memory/index.js +1 -1
- package/dist/extensions/admin-http-rpc/index.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 +1 -1
- package/dist/extensions/browser/browser-profiles.js +2 -2
- package/dist/extensions/browser/browser-runtime-api.js +11 -11
- package/dist/extensions/browser/cli-metadata.js +1 -1
- package/dist/extensions/browser/index.js +1 -1
- package/dist/extensions/browser/plugin-registration.js +1 -1
- package/dist/extensions/browser/register.runtime.js +4 -4
- package/dist/extensions/browser/runtime-api.js +13 -13
- package/dist/extensions/canvas/index.js +1 -1
- package/dist/extensions/clickclack/api.js +2 -2
- package/dist/extensions/clickclack/channel-plugin-api.js +1 -1
- package/dist/extensions/clickclack/runtime-api.js +2 -2
- package/dist/extensions/device-pair/api.js +1 -1
- package/dist/extensions/device-pair/pair-command-approve.js +1 -1
- package/dist/extensions/file-transfer/index.js +4 -4
- package/dist/extensions/imessage/api.js +2 -2
- package/dist/extensions/imessage/channel-plugin-api.js +1 -1
- package/dist/extensions/imessage/message-tool-api.d.ts +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/llm-task/index.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 +2 -2
- package/dist/extensions/mattermost/slash-route-api.js +1 -1
- package/dist/extensions/memory-core/cli-metadata.js +1 -1
- package/dist/extensions/migrate-claude/apply.js +1 -1
- package/dist/extensions/migrate-claude/index.js +1 -1
- package/dist/extensions/migrate-claude/plan.js +1 -1
- package/dist/extensions/migrate-claude/provider.js +1 -1
- package/dist/extensions/migrate-claude/targets.js +1 -1
- package/dist/extensions/migrate-hermes/apply.js +1 -1
- package/dist/extensions/migrate-hermes/index.js +1 -1
- package/dist/extensions/migrate-hermes/model.js +1 -1
- package/dist/extensions/migrate-hermes/plan.js +1 -1
- package/dist/extensions/migrate-hermes/provider.js +1 -1
- package/dist/extensions/migrate-hermes/secrets.js +1 -1
- package/dist/extensions/migrate-hermes/targets.js +1 -1
- package/dist/extensions/policy/api.js +1 -1
- package/dist/extensions/policy/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 +2 -2
- package/dist/extensions/telegram/account-inspect-api.js +1 -1
- package/dist/extensions/telegram/api.js +11 -11
- package/dist/extensions/telegram/channel-plugin-api.js +2 -2
- package/dist/extensions/telegram/contract-api.js +3 -3
- package/dist/extensions/telegram/runtime-api.js +7 -7
- package/dist/extensions/telegram/security-audit-contract-api.js +1 -1
- package/dist/extensions/telegram/setup-plugin-api.js +1 -1
- package/dist/extensions/telegram/test-api.js +2 -2
- package/dist/extensions/webhooks/api.js +1 -1
- package/dist/extensions/webhooks/index.js +1 -1
- package/dist/extensions/xai/index.js +4 -4
- package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
- package/dist/extensions/xai/speech-provider.js +1 -1
- package/dist/extensions/xai/test-api.js +1 -1
- package/dist/extensions/xai/tts.js +1 -1
- package/dist/extensions/xai/web-search.js +1 -1
- package/dist/extensions/xai/xai-oauth.js +1 -1
- package/dist/file-fetch-tool-DQpAtjX4.js +124 -0
- package/dist/file-write-tool-CkB0oYwe.js +127 -0
- package/dist/format-DUJUpMFQ.js +1145 -0
- package/dist/gateway-cli-CQo_E4Ka.js +435 -0
- package/dist/gateway-method-runtime-1QPgVJH7.js +21 -0
- package/dist/get-reply-DfUcsC-O.js +4689 -0
- package/dist/get-reply-from-config.runtime-C95MG73O.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/graph-users-DPJe0fPs.js +1419 -0
- package/dist/group-access-DefaNJ6L.js +112 -0
- package/dist/handle-action.guild-admin-C1sy1kGJ.js +288 -0
- package/dist/harness-BgPRdmNK.js +61 -0
- package/dist/health-DFR9A1YV.js +4 -0
- package/dist/heartbeat-runner-BiYVPs25.js +5 -0
- package/dist/heartbeat-runner.runtime-Bmaq8WUA.js +4 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/hooks-CNJDuJUm.js +534 -0
- package/dist/inbound-direct-dm-runtime-DFt58p71.js +2 -0
- package/dist/inbound-reply-dispatch-kgSDM8ax.js +148 -0
- package/dist/index.js +1 -1
- package/dist/init-B0zO_U4r.js +59 -0
- package/dist/inline-buttons-B6zgQW3J.js +40 -0
- package/dist/internal-events-C3Q5t6hg.js +90 -0
- package/dist/isolated-agent-CaSU5GCJ.js +2 -0
- package/dist/isolated-agent-CnsD2TmP.js +1118 -0
- package/dist/lifecycle-i3WZDaIn.js +571 -0
- package/dist/list.probe-g0rUiVXW.js +449 -0
- package/dist/list.status-command-DG3PrmeO.js +789 -0
- package/dist/llm-slug-generator-CHlf69FU.js +78 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/local-dispatch.runtime-CDeHUp_A.js +9 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/manager.runtime-BlLMPUTq.js +2714 -0
- package/dist/manager.runtime.js +1 -1
- package/dist/markdown-to-line-r_mBHMdy.js +811 -0
- package/dist/mcp-http-C5UPIJGR.js +555 -0
- package/dist/mcp-http-CTy9gpfA.js +2 -0
- package/dist/media-understanding-provider-BT6TOuVa.js +339 -0
- package/dist/message-actions-BdcjjwFt.js +145 -0
- package/dist/message-handler-B29Tj2p2.js +1715 -0
- package/dist/message-handler-BhHb1FHI.js +384 -0
- package/dist/message-handler.preflight-ouZ_-3o8.js +1125 -0
- package/dist/message-handler.process-CrYiBx_F.js +1484 -0
- package/dist/model-CLbtocQX.js +74 -0
- package/dist/model-selection-BG_vU9Kl.js +272 -0
- package/dist/models-4KERn3ya.js +104 -0
- package/dist/models-BCa-ipxi.js +2 -0
- package/dist/models-cli-DtpGXEsf.js +256 -0
- package/dist/monitor-B-egsvmI.js +1657 -0
- package/dist/monitor-BJX9Yv7k.js +2 -0
- package/dist/monitor-BPrIy3pV.js +715 -0
- package/dist/monitor-BWknZZ7N.js +4377 -0
- package/dist/monitor-C3y_PtI1.js +60 -0
- package/dist/monitor-DCzfdqE4.js +1370 -0
- package/dist/monitor-P24epSwE.js +2788 -0
- package/dist/monitor-auth-CEG_xldE.js +179 -0
- package/dist/monitor-jEePJbbS.js +834 -0
- package/dist/monitor-polling.runtime-BzlHK11u.js +883 -0
- package/dist/monitor-polling.runtime.js +1 -1
- package/dist/monitor-webhook.runtime-vFEhk_Zj.js +387 -0
- package/dist/monitor-webhook.runtime.js +1 -1
- package/dist/monitor.account-BUIfgWXg.js +5233 -0
- package/dist/monitor.runtime-Cp7W4fhb.js +2 -0
- package/dist/monitor.runtime.js +1 -1
- package/dist/monitor.webhook-DzrbeR4T.js +180 -0
- package/dist/node-cli-sessions-CLbI14UA.js +1228 -0
- package/dist/openai-http-BM9BIA_g.js +824 -0
- package/dist/openresponses-http-CNoW9kk8.js +1173 -0
- package/dist/operations-DT4bsxV6.js +805 -0
- package/dist/outbound-adapter-CZRUOgY0.js +543 -0
- package/dist/outbound-session-route-DneMsGNx.js +45 -0
- package/dist/outbound.runtime-CHuoKJJI.js +2 -0
- package/dist/outbound.runtime.js +1 -1
- package/dist/pi-embedded-1-rsueO_.js +3796 -0
- package/dist/pi-embedded-BRfDncVO.js +4 -0
- package/dist/pi-embedded.runtime-DEYoa6bW.js +4 -0
- package/dist/pi-embedded.runtime.js +1 -1
- package/dist/pi-tools-C0P3NgP5.js +2413 -0
- package/dist/plan-BQUkjBMY.js +81 -0
- package/dist/plan-CRO9_2_k.js +112 -0
- package/dist/plugin-BJCmWhnh.js +12396 -0
- package/dist/plugin-app-cache-key-CXAg0F7A.js +46 -0
- package/dist/plugin-enabled-D93Z9LSo.js +233 -0
- package/dist/plugin-registration-BBrTcZnf.js +88 -0
- package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
- package/dist/plugin-sdk/acp-runtime-backend.js +1 -1
- package/dist/plugin-sdk/acp-runtime.js +2 -2
- package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
- package/dist/plugin-sdk/agent-harness-task-runtime.js +1 -1
- package/dist/plugin-sdk/agent-harness.js +7 -7
- package/dist/plugin-sdk/agent-runtime.js +2 -2
- package/dist/plugin-sdk/channel-core.js +2 -2
- package/dist/plugin-sdk/channel-inbound.js +2 -2
- package/dist/plugin-sdk/channel-test-helpers.js +1 -1
- 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 +2 -2
- 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-method-runtime.js +1 -1
- package/dist/plugin-sdk/health.js +2 -2
- package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/mattermost.js +1 -1
- package/dist/plugin-sdk/plugin-test-contracts.js +2 -2
- package/dist/plugin-sdk/provider-test-contracts.js +4 -4
- package/dist/plugin-sdk/reply-runtime.js +4 -4
- package/dist/plugin-sdk/testing.js +2 -2
- package/dist/plugin-sdk/zalouser.js +1 -1
- package/dist/plugin-service-DnZEPBEA.js +1229 -0
- package/dist/plugins/runtime/index.js +4 -4
- package/dist/policy-CMv5QMPG.js +138 -0
- package/dist/policy-CeoP4t9J.js +680 -0
- package/dist/prepare.runtime-DZ55JiTt.js +732 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/preview-warnings-O08PZRxu.js +392 -0
- package/dist/probe-C6w3bP8X.js +682 -0
- package/dist/probe-Cs1_X1NA.js +47 -0
- package/dist/probe-Cuee_jyM.js +2204 -0
- package/dist/probe-DZxCnDzn.js +2 -0
- package/dist/program-C2dT8VHB.js +131 -0
- package/dist/provider-C2_vSzYh.js +32 -0
- package/dist/provider-DSfTDQbj.js +152 -0
- package/dist/provider-U8hrm9h-.js +32 -0
- package/dist/provider-_v910H8y.js +8735 -0
- package/dist/provider-dispatcher-C3kmmIEC.js +22 -0
- package/dist/provider-dispatcher.runtime.js +1 -1
- package/dist/provider-session.runtime-Mg0fx5hH.js +9 -0
- package/dist/provider-session.runtime.js +1 -1
- package/dist/provider.runtime-pSTXuHrq.js +2 -0
- package/dist/provider.runtime.js +1 -1
- package/dist/public-surface-loader-09t4TTue.js +114 -0
- package/dist/pw-ai-DjNqHV3_.js +3029 -0
- package/dist/pw-role-snapshot-DoGefdv7.js +333 -0
- package/dist/reaction-level-C8Mqxizo.js +19 -0
- package/dist/reaction-runtime-api-DOP6xOsm.js +116 -0
- package/dist/realtime-transcription-provider-BTGEXXna.js +205 -0
- package/dist/register-CbZPpqI3.js +2178 -0
- package/dist/register.agent-DrBFuPKh.js +156 -0
- package/dist/register.crestodian-DwTbmaK8.js +24 -0
- package/dist/register.maintenance-BIeoYBub.js +83 -0
- package/dist/register.runtime-B5V9_Dwz.js +54 -0
- package/dist/register.subclis-CJE9ISZY.js +31 -0
- package/dist/register.subclis-YQsKas8N.js +3 -0
- package/dist/register.subclis-core-CjwdGeGU.js +273 -0
- package/dist/repair-sequencing-C0jrL5pw.js +640 -0
- package/dist/reply-delivery-B28mTIpb.js +196 -0
- package/dist/reply-runtime-BqQX7HHw.js +11 -0
- package/dist/reply.runtime-C95MG73O.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/request-BqoMvXxH.js +54 -0
- package/dist/resolve-allowlist-hbKKd_kq.js +220 -0
- package/dist/result-fallback-classifier-BrORPoxj.js +79 -0
- package/dist/route-HHRgSzVy.js +469 -0
- package/dist/route-resolution-C7bafjVc.js +274 -0
- package/dist/routes-86XGeo7a.js +2 -0
- package/dist/routes-BhVGr9ie.js +3602 -0
- package/dist/run-Bb5QP5JV.js +1162 -0
- package/dist/run-attempt-CLi0wV7j.js +7704 -0
- package/dist/run-command-Be6GAxiW.js +2 -0
- package/dist/run-command-Ds4hr3iU.js +23 -0
- package/dist/run-embedded.runtime-wX9ORojX.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-BmNZVB2N.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-subagent-registry.runtime-Uq5sjftu.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/runtime-BktLQ75j.js +1287 -0
- package/dist/runtime-C9XdR62_.js +438 -0
- package/dist/runtime-CTvWDPx9.js +6179 -0
- package/dist/runtime-api-BojB3MUw.js +21 -0
- package/dist/runtime-api-C92MlAwp.js +13 -0
- package/dist/runtime-api-CFNZE9Xt.js +13 -0
- package/dist/runtime-api-Cimpgm5_.js +3 -0
- package/dist/runtime-api-D8qG_lUm.js +17 -0
- package/dist/runtime-api-DMDMnQEG.js +4 -0
- package/dist/runtime-api-DupQdIlE.js +24 -0
- package/dist/runtime-api.actions-B8i3elqu.js +3 -0
- package/dist/runtime-api.monitor-BntFzf_M.js +6 -0
- package/dist/runtime-api.send-CPlmi1jc.js +4 -0
- package/dist/runtime-api.threads-D-H_r_Nl.js +2 -0
- package/dist/runtime-channel-BGhTxnXZ.js +150 -0
- package/dist/runtime-channel-CPFxNapZ.js +2 -0
- package/dist/runtime-embedded-pi.runtime-BjnMTurB.js +2 -0
- package/dist/runtime-embedded-pi.runtime.js +1 -1
- package/dist/sanitize-outbound-BMUv1NeS.js +127 -0
- package/dist/sdk-setup-tools-Do3DkQi_.js +8 -0
- package/dist/secrets-B8YVPHhk.js +113 -0
- package/dist/security-audit-7Gg_nL4o.js +122 -0
- package/dist/security-audit-Bk3CREj-.js +118 -0
- package/dist/security-audit.runtime-BmSJrdeq.js +2 -0
- package/dist/security-audit.runtime.js +1 -1
- package/dist/selection-BFGde9-_.js +3 -0
- package/dist/selection-DrLFlbgG.js +16157 -0
- package/dist/send-4dLa-BQo.js +1631 -0
- package/dist/send-CV6gCwYP.js +192 -0
- package/dist/send-aGiK3Efu.js +143 -0
- package/dist/send-dB3CehAN.js +2 -0
- package/dist/send.components-BcG9BlkC.js +2 -0
- package/dist/send.components-rLjDlfYU.js +500 -0
- package/dist/send.runtime-D20k2MSr.js +2 -0
- package/dist/send.runtime.js +1 -1
- package/dist/server-BTRx_U1s.js +73 -0
- package/dist/server-CY0ymhBg.js +24 -0
- package/dist/server-close.runtime.js +1 -1
- package/dist/server-context-BxGT8wbK.js +955 -0
- package/dist/server-context-DYlbhAaT.js +2 -0
- package/dist/server-cron-BB_15lcP.js +2 -0
- package/dist/server-cron-CfyJX_a4.js +2989 -0
- package/dist/server-methods-Ck2ab6TC.js +16494 -0
- package/dist/server-node-events-BdRizF-5.js +596 -0
- package/dist/server-plugin-bootstrap-CPUr8NFE.js +70 -0
- package/dist/server-plugins-__5AxjzH.js +432 -0
- package/dist/server-reload-handlers-BMl9Fx9b.js +714 -0
- package/dist/server-restart-sentinel-D11M_ZsH.js +747 -0
- package/dist/server-restart-sentinel-DGptQ27c.js +2 -0
- package/dist/server-runtime-services-BwtLs-8I.js +2 -0
- package/dist/server-runtime-services-aJydixRu.js +267 -0
- package/dist/server-startup-plugins-m_P3gY4m.js +113 -0
- package/dist/server-startup-post-attach-DuXQ1AXL.js +716 -0
- package/dist/server-ws-runtime-mXmxB1W8.js +349 -0
- package/dist/server.impl-fuV8aKSP.js +2586 -0
- package/dist/service-a8cTFka4.js +1446 -0
- package/dist/session-binding-BIycxo9u.js +2 -0
- package/dist/session-binding-xHwQr9vM.js +219 -0
- package/dist/session-kill-http-DiUZhcoN.js +121 -0
- package/dist/session-reset-service-DkepDoob.js +625 -0
- package/dist/session-route-Ba5u7ecb.js +93 -0
- package/dist/session-status.runtime-Cb1X69Rl.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-rbqmto4G.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-DSKOoJta.js +521 -0
- package/dist/sessions-history-http-CWP88I_C.js +430 -0
- package/dist/sessions.runtime-1q1OwLn3.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/setup-api-DtrOOYeP.js +29 -0
- package/dist/setup-core-DMrJS6LP.js +174 -0
- package/dist/setup-surface-BFPNu1qA.js +405 -0
- package/dist/setup-surface-CedShqhO.js +288 -0
- package/dist/setup-surface-DLOBH1Vf.js +320 -0
- package/dist/setup-surface-MhCeEWSj.js +221 -0
- package/dist/shared-DamL-e8D.js +121 -0
- package/dist/shared-client-B48JoAsz.js +2 -0
- package/dist/shared-client-BoSiDnUo.js +629 -0
- package/dist/side-question-DQoQ_ETb.js +683 -0
- package/dist/skill-tool-dispatch.runtime-CWLloYA8.js +143 -0
- package/dist/skill-tool-dispatch.runtime.js +1 -1
- package/dist/slash-state-DrrWJQfv.js +2166 -0
- package/dist/speech-provider-8Hx1uw41.js +184 -0
- package/dist/src-BbUYOPwU.js +4256 -0
- package/dist/startup-context-opAJAamX.js +313 -0
- package/dist/status-subagents.runtime-DSo7ZK_Z.js +18 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-AyPuDzrO.js +296 -0
- package/dist/sticker-cache-91Tp8mLP.js +206 -0
- package/dist/sticker-vision.runtime-DjleFXi5.js +17 -0
- package/dist/sticker-vision.runtime.js +1 -1
- package/dist/subagent-announce-delivery-DS_2W9oZ.js +958 -0
- package/dist/subagent-announce-hatA_PZ2.js +354 -0
- package/dist/subagent-control-IyFIvc7T.js +508 -0
- package/dist/subagent-hooks-BCj5eB0Z.js +2 -0
- package/dist/subagent-hooks-BWjTBkox.js +146 -0
- package/dist/subagent-hooks-CdGLK9_3.js +230 -0
- package/dist/subagent-hooks-EH0tBkw9.js +2 -0
- package/dist/subagent-hooks-api-BhYaXQJV.js +23 -0
- package/dist/subagent-hooks-api-uGsV8Xn5.js +22 -0
- package/dist/subagent-hooks-api-wfJFKIPx.js +23 -0
- package/dist/subagent-hooks-l8Xd94dt.js +2 -0
- package/dist/subagent-hooks-m2eHUO_d.js +116 -0
- package/dist/subagent-orphan-recovery-Bq9zvX3L.js +352 -0
- package/dist/subagent-registry-Bcb3zy6b.js +3 -0
- package/dist/subagent-registry-CoZNTFx-.js +2351 -0
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-session-cleanup--00EjDLe.js +525 -0
- package/dist/subagent-spawn-ClJJkz3D.js +1164 -0
- package/dist/target-id-BsZLiF3x.js +107 -0
- package/dist/targets-CQMe4AZP.js +44 -0
- package/dist/targets-SmL1AU-H.js +19 -0
- package/dist/targets-Y-roiA47.js +19 -0
- package/dist/task-registry-control.runtime.js +1 -1
- package/dist/telegram/token.js +1 -1
- package/dist/testing-B5hNJDuF.js +267 -0
- package/dist/thread-bindings-BD3eE0kK.js +232 -0
- package/dist/thread-bindings-C9NNiv8K.js +571 -0
- package/dist/thread-bindings-Dl4PN1vZ.js +228 -0
- package/dist/thread-bindings-uK1LLAwy.js +8 -0
- package/dist/thread-bindings.discord-api-BHNEUbnk.js +187 -0
- package/dist/thread-bindings.manager-B0LXiH3F.js +2 -0
- package/dist/thread-bindings.manager-BTlH4XMG.js +536 -0
- package/dist/thread-lifecycle-DG8uyPHd.js +1614 -0
- package/dist/token-BbGCANnE.js +134 -0
- package/dist/tool-actions.runtime-oUUrD8HB.js +534 -0
- package/dist/tool-actions.runtime.js +1 -1
- package/dist/tool-bqg-_vYv.js +139 -0
- package/dist/tool-resolution-CSZsa3kP.js +149 -0
- package/dist/tools-effective-inventory-0CqFp-vq.js +204 -0
- package/dist/tools-invoke-http-DhYHY0Yh.js +67 -0
- package/dist/tools-invoke-shared-CbVJJUj7.js +200 -0
- package/dist/tts-C2qD-ad6.js +66 -0
- package/dist/tui-CzGY254f.js +4709 -0
- package/dist/tui-backend-fzoeoSN0.js +256 -0
- package/dist/tui-cli-B2RWb2gM.js +37 -0
- package/dist/tui-dgS8hdXU.js +2 -0
- package/dist/update-cli-BmiBDf3c.js +3664 -0
- package/dist/update-runner-CM7QVX6u.js +2379 -0
- package/dist/vision-tools-BzoBZnIc.js +1409 -0
- package/dist/web-search-DmfOd66S.js +62 -0
- package/dist/web-search-provider.runtime-3C5-pODD.js +328 -0
- package/dist/web-search-provider.runtime-Doh-Z9We.js +2 -0
- package/dist/web-search-provider.runtime.js +1 -1
- package/dist/xai-oauth-BLvQ43hx.js +479 -0
- package/dist/xai-user-agent-BdMQ_0_O.js +32 -0
- package/package.json +1 -1
- package/dist/abort-DeEb_wKd.js +0 -277
- package/dist/abort.runtime-CoYXQGPK.js +0 -2
- package/dist/account-inspect-D_06-CYS.js +0 -173
- package/dist/accounts-BCTqtj4Y.js +0 -107
- package/dist/accounts-BudLl8P2.js +0 -107
- package/dist/accounts-CUReBDA0.js +0 -2
- package/dist/accounts-PCioSzzr.js +0 -119
- package/dist/acp-runtime-B2t9_BHD.js +0 -26
- package/dist/acp-spawn-0x4Iiu1o.js +0 -2
- package/dist/acp-spawn-B2Ghe0jJ.js +0 -1275
- package/dist/acp-stateful-target-driver-C4VgcSyz.js +0 -89
- package/dist/action-kill-ClYsXEz7.js +0 -33
- package/dist/action-runtime-DrLPkNvU.js +0 -469
- package/dist/action-runtime-api-BqSflr9q.js +0 -2
- package/dist/action-send-CIy9cziD.js +0 -39
- package/dist/action-spawn-BjV6lFnX.js +0 -47
- package/dist/actions-D-QH7wq5.js +0 -161
- package/dist/actions.runtime-hzDtXQGU.js +0 -5
- package/dist/agent-Bb1DTBgv.js +0 -3
- package/dist/agent-Cnqj258q.js +0 -2
- package/dist/agent-command-BRx6ZNgJ.js +0 -1367
- package/dist/agent-components.runtime-D-g6xXJ0.js +0 -10
- package/dist/agent-harness-runtime-dKUQFuOc.js +0 -180
- package/dist/agent-harness-task-runtime-v2crUm3i.js +0 -140
- package/dist/agent-runner-execution-AOzdxvWR.js +0 -1713
- package/dist/agent-runner-utils-Byv50B4Z.js +0 -266
- package/dist/agent-runner.runtime-hhgRE0Z-.js +0 -3455
- package/dist/agent-runtime-BHmh3i0o.js +0 -229
- package/dist/agent-via-gateway-DnCqaK4a.js +0 -463
- package/dist/api-Bzyb8sFU.js +0 -3
- package/dist/api-CIEDFXZs.js +0 -2
- package/dist/api-D_dTQAu8.js +0 -2
- package/dist/api-DilBjZ9Q.js +0 -6
- package/dist/api-E5zoQMmh.js +0 -134
- package/dist/api-OJZug8gQ.js +0 -639
- package/dist/apply-C0eV5T0O.js +0 -41
- package/dist/apply-alsYvxLE.js +0 -54
- package/dist/approval-handler.runtime-C6jqZXSN.js +0 -130
- package/dist/assistant-DDXnAAB5.js +0 -291
- package/dist/attachment-normalize-Cv-_4DWU.js +0 -225
- package/dist/attempt-execution-DECEU59r.js +0 -558
- package/dist/attempt-execution.runtime-kasMxuER.js +0 -3
- package/dist/attempt-execution.shared-ClUxk52p.js +0 -38
- package/dist/attempt.prompt-helpers-Bxlv9VSu.js +0 -475
- package/dist/attempt.tool-run-context-CplQWX6g.js +0 -2094
- package/dist/binding-routing-0Obpp-Ij.js +0 -113
- package/dist/binding-targets-CZHQaZL4.js +0 -121
- package/dist/bot-BPbQ0840.js +0 -7894
- package/dist/bot-deps-Cs1M9USs.js +0 -2
- package/dist/bot-deps-xAcaOtTZ.js +0 -747
- package/dist/bot-message-context.runtime-Bji78Cbn.js +0 -7
- package/dist/bot-message-context.session.runtime-C3dyOIYH.js +0 -12
- package/dist/bot-native-commands.delivery.runtime-WshH99fy.js +0 -4
- package/dist/bot-native-commands.runtime-C1L364gU.js +0 -13
- package/dist/bridge-server-DPlM8_Lk.js +0 -113
- package/dist/browser-cli-DFNQE98N.js +0 -230
- package/dist/browser-cli-Drb5E5--.js +0 -2
- package/dist/browser-cli-actions-input-Dx-1OXmE.js +0 -473
- package/dist/browser-cli-actions-observe-BMDfE7xU.js +0 -81
- package/dist/browser-cli-debug-nu7Ih09g.js +0 -137
- package/dist/browser-cli-inspect-D5X2wohg.js +0 -104
- package/dist/browser-cli-manage-DkzYwph4.js +0 -443
- package/dist/browser-cli-resize-B30Avedl.js +0 -26
- package/dist/browser-cli-shared-cMgQoQzF.js +0 -50
- package/dist/browser-cli-state-CQLDvDy7.js +0 -337
- package/dist/browser-control-auth-D7ArmHUt.js +0 -2
- package/dist/browser-profiles-B39SIZNb.js +0 -2
- package/dist/browser-runtime-DUbSAOOS.js +0 -384
- package/dist/build-D25KqC92.js +0 -257
- package/dist/capability-cli-CuyXrlAB.js +0 -1782
- package/dist/channel-0N3YGMGg.js +0 -1496
- package/dist/channel-1UyKoLyp.js +0 -481
- package/dist/channel-BG87pSEW.js +0 -740
- package/dist/channel-BPGSaZW7.js +0 -1249
- package/dist/channel-BQMPh1J_.js +0 -376
- package/dist/channel-Bd_8V6zn.js +0 -1134
- package/dist/channel-BtBjh_ij.js +0 -362
- package/dist/channel-CpFBlVH6.js +0 -562
- package/dist/channel-CwuTrIrF.js +0 -508
- package/dist/channel-Cxl4sJA-.js +0 -1777
- package/dist/channel-D-VfU4Z2.js +0 -2126
- package/dist/channel-D9q8aYrN.js +0 -867
- package/dist/channel-DKSvVvZh.js +0 -238
- package/dist/channel-DvoFfWLx.js +0 -808
- package/dist/channel-GktTcGHm.js +0 -955
- package/dist/channel-actions.runtime-CKcRA0GW.js +0 -265
- package/dist/channel-core-nm8s1qFZ.js +0 -5
- package/dist/channel-d3t2ESlE.js +0 -653
- package/dist/channel-inbound-DKz40dq-.js +0 -80
- package/dist/channel-plugin-runtime-DKIGZWfW.js +0 -998
- package/dist/channel-runtime-Bh8_GY12.js +0 -408
- package/dist/channel-yQ8jCOb9.js +0 -1556
- package/dist/channel.runtime-BG4mM5cQ.js +0 -652
- package/dist/channel.runtime-BS6PyFFa.js +0 -1008
- package/dist/channel.runtime-CE_xECqN.js +0 -88
- package/dist/channel.runtime-Cd1Sw8U4.js +0 -254
- package/dist/channel.runtime-DIq3XOEe.js +0 -733
- package/dist/channel.runtime-Dy1cx35I.js +0 -21009
- package/dist/channel.runtime-NyIMjLnP.js +0 -109
- package/dist/channel.runtime-Zx5mfE2V.js +0 -4
- package/dist/channel.runtime-rJRibGfN.js +0 -2528
- package/dist/channel.setup--4ACadmF.js +0 -10
- package/dist/channel.setup-DzwqIlo3.js +0 -1098
- package/dist/channel.setup-FKYSJwXR.js +0 -343
- package/dist/chat-CKxSm7r1.js +0 -2666
- package/dist/chrome-rMubJwRG.js +0 -1503
- package/dist/cli-CbTod55I.js +0 -1341
- package/dist/cli-compaction-BbHgjJyW.js +0 -347
- package/dist/cli-metadata-DkOWLC_p.js +0 -22
- package/dist/cli-runner-Cwzv_RKf.js +0 -540
- package/dist/cli-runner-DdnUsgPl.js +0 -2
- package/dist/cli-runner.runtime-BlrSgbEW.js +0 -3
- package/dist/cli-runner.runtime-D8kVfvFH.js +0 -4
- package/dist/client-ClvxsWgL.js +0 -650
- package/dist/client-adapter-CsrIIjK1.js +0 -897
- package/dist/client-factory-DAYClhwm.js +0 -9
- package/dist/command-auth-CCha2ofd.js +0 -135
- package/dist/command-handlers-DCWJzHyB.js +0 -1609
- package/dist/command-registry-BIf61QNz.js +0 -9
- package/dist/command-registry-DJROBy4h.js +0 -4
- package/dist/command-registry-core-BQOWqi6S.js +0 -110
- package/dist/command-status.runtime-D88CUglL.js +0 -90
- package/dist/commands-acp-B-8dHX4Z.js +0 -74
- package/dist/commands-compact.runtime-ComX5mUk.js +0 -10
- package/dist/commands-handlers.runtime-DR3wjXHX.js +0 -6154
- package/dist/commands-status-CDyGrwsI.js +0 -3
- package/dist/commands-status-DV-i_ZIK.js +0 -16
- package/dist/commands-status.runtime-CDyGrwsI.js +0 -3
- package/dist/commands-subagents-control.runtime-B029cXAS.js +0 -3
- package/dist/commands-subagents-control.runtime-DR8Qspe0.js +0 -2
- package/dist/commands-system-prompt-C10ctsG3.js +0 -162
- package/dist/commands-system-prompt-DQlRWwnk.js +0 -2
- package/dist/commands.runtime-BYmIAuN0.js +0 -176
- package/dist/compact-14Ljaaeu.js +0 -480
- package/dist/compact-B--ovdkx.js +0 -1141
- package/dist/compact.runtime-E0Idf2Dq.js +0 -12
- package/dist/completion-cli-DMvvQGSk.js +0 -315
- package/dist/computer-use-CcLwX5SR.js +0 -367
- package/dist/config-B39SIZNb.js +0 -2
- package/dist/config-D4rsGOyV.js +0 -373
- package/dist/config-mutations-CsI3YJu7.js +0 -159
- package/dist/context-engine-host-compat-BZpDFiMJ.js +0 -2
- package/dist/context-engine-host-compat-runUdES5.js +0 -288
- package/dist/context-engine-lifecycle-D6odtNrn.js +0 -1274
- package/dist/control-auth-BPGpPtfz.js +0 -114
- package/dist/control-service-C-OmdPCe.js +0 -145
- package/dist/control-ui/assets/agents-GeyOHPuW.js +0 -1008
- package/dist/control-ui/assets/channel-config-extras-D7en6iUg.js +0 -2
- package/dist/control-ui/assets/channels-DkEyr1w5.js +0 -367
- package/dist/control-ui/assets/cron-C-wThQ1Q.js +0 -1013
- package/dist/control-ui/assets/debug-83AFRtIX.js +0 -97
- package/dist/control-ui/assets/index-CiGEhMOA.js +0 -7370
- package/dist/control-ui/assets/instances-CVl0t-1h.js +0 -57
- package/dist/control-ui/assets/logs-eybVEXxg.js +0 -74
- package/dist/control-ui/assets/nodes-C_A7eoU2.js +0 -436
- package/dist/control-ui/assets/sessions-Cq4Nc69u.js +0 -399
- package/dist/control-ui/assets/skills-ZN6hroIh.js +0 -314
- package/dist/control-ui/assets/skills-shared-DIWGwmdC.js +0 -11
- package/dist/conversation-binding-runtime-C2U1JElL.js +0 -4
- package/dist/conversation-runtime-NmIUd3Zu.js +0 -31
- package/dist/core-DGKJP1dm.js +0 -282
- package/dist/core-api-1fA4sNeC.js +0 -5
- package/dist/core-api-BY822Quq.js +0 -2
- package/dist/crestodian-Bp-NXiBC.js +0 -55
- package/dist/daocore-tools-Defpam0j.js +0 -11727
- package/dist/delivery-CEdVAUGB.js +0 -1002
- package/dist/dialogue-CZ69INPq.js +0 -37
- package/dist/dir-fetch-tool-BCicHhQE.js +0 -565
- package/dist/dir-list-tool-Cv_WktsJ.js +0 -100
- package/dist/direct-dm-Bz89rM8x.js +0 -64
- package/dist/directive-handling.fast-lane-DDnbcc5S.js +0 -68
- package/dist/directive-handling.impl-B0H52Ymr.js +0 -818
- package/dist/directive-handling.impl-CgKpwEW-.js +0 -2
- package/dist/directive-handling.model-selection-_cXAr0vt.js +0 -122
- package/dist/directive-handling.persist.runtime-Dw0mfzXT.js +0 -263
- package/dist/dispatch-C3AeYvyP.js +0 -1640
- package/dist/dispatch-acp-transcript.runtime-CP8pqBwS.js +0 -40
- package/dist/dispatch-acp.runtime-Cdap-AZI.js +0 -18
- package/dist/doctor-BZwVH97p.js +0 -2
- package/dist/doctor-BfkGBii1.js +0 -6
- package/dist/doctor-config-flow-D3JASGDt.js +0 -1741
- package/dist/doctor-core-checks-DH5AIT0Q.js +0 -573
- package/dist/doctor-core-checks-DiNu7VSh.js +0 -2
- package/dist/doctor-health-BDIJ-Nro.js +0 -65
- package/dist/doctor-health-contributions-BgmF7w8X.js +0 -696
- package/dist/doctor-lint-uIxkMUSO.js +0 -94
- package/dist/doctor-state-integrity-ws1b_BGk.js +0 -1231
- package/dist/doctor-update-Cx4CqxaX.js +0 -58
- package/dist/dynamic-tools-DiqOxhJh.js +0 -486
- package/dist/embedded-backend-C634irMl.js +0 -579
- package/dist/embedded-gateway-stub.runtime-CCfrTOeN.js +0 -12
- package/dist/exec-approvals-D85KThSg.js +0 -149
- package/dist/file-fetch-tool-BERaGYCT.js +0 -124
- package/dist/file-write-tool-BjHrMyfe.js +0 -127
- package/dist/format-DE9PuPg1.js +0 -1145
- package/dist/gateway-cli-B5hjhbUy.js +0 -435
- package/dist/gateway-method-runtime-Bu0E9Eki.js +0 -21
- package/dist/get-reply-6PtPz9hv.js +0 -4689
- package/dist/get-reply-from-config.runtime-CwprvhoR.js +0 -2
- package/dist/graph-users-DUp1kgnS.js +0 -1419
- package/dist/group-access-D5GBQ3w6.js +0 -112
- package/dist/handle-action.guild-admin-CA0Y-buD.js +0 -288
- package/dist/harness-B5nOFVfm.js +0 -61
- package/dist/health-D5heIDj3.js +0 -4
- package/dist/heartbeat-runner-BzFkIFHh.js +0 -5
- package/dist/heartbeat-runner.runtime-p6H1_xMV.js +0 -4
- package/dist/hooks-BvTyQ14X.js +0 -534
- package/dist/inbound-direct-dm-runtime-DwiDXi8L.js +0 -2
- package/dist/inbound-reply-dispatch-YoDUOC6C.js +0 -148
- package/dist/init-CPtcV5Xu.js +0 -59
- package/dist/inline-buttons-DeD5d42c.js +0 -40
- package/dist/internal-events-DEb50Sw3.js +0 -90
- package/dist/isolated-agent-CcxFFZ-Z.js +0 -1118
- package/dist/isolated-agent-CpHzq5qr.js +0 -2
- package/dist/lifecycle-DNel-oMe.js +0 -571
- package/dist/list.probe-DCa3N25d.js +0 -449
- package/dist/list.status-command-CyeAJmZW.js +0 -789
- package/dist/llm-slug-generator-CyqTY37Z.js +0 -78
- package/dist/local-dispatch.runtime-nE39kFIP.js +0 -9
- package/dist/manager.runtime-CpAPB8D5.js +0 -2714
- package/dist/markdown-to-line-Ci6TRmoZ.js +0 -811
- package/dist/mcp-http-BR0vmxFL.js +0 -2
- package/dist/mcp-http-C0oniA8h.js +0 -555
- package/dist/media-understanding-provider-BwA0XqC3.js +0 -339
- package/dist/message-actions-C9C_Ngkd.js +0 -145
- package/dist/message-handler-CUUKPC5n.js +0 -384
- package/dist/message-handler-xRTfIXWV.js +0 -1715
- package/dist/message-handler.preflight-Ch2Q7V3M.js +0 -1125
- package/dist/message-handler.process-HM3mK93q.js +0 -1484
- package/dist/model-CB8Ex5xS.js +0 -74
- package/dist/model-selection-2s0Dinux.js +0 -272
- package/dist/models-Cn-6DJ41.js +0 -2
- package/dist/models-CzszJD__.js +0 -104
- package/dist/models-cli-CbhElnA5.js +0 -256
- package/dist/monitor-7aprTsMV.js +0 -715
- package/dist/monitor-BuVhqwDS.js +0 -1370
- package/dist/monitor-C4H_YkgY.js +0 -2
- package/dist/monitor-CPQsMxgv.js +0 -1657
- package/dist/monitor-Ce0V1PiR.js +0 -4377
- package/dist/monitor-D0bcGJWI.js +0 -60
- package/dist/monitor-DEjlJqzh.js +0 -834
- package/dist/monitor-auth-DjJZsjgV.js +0 -179
- package/dist/monitor-ikSYagv3.js +0 -2788
- package/dist/monitor-polling.runtime-D7yEflMM.js +0 -883
- package/dist/monitor-webhook.runtime-CIZt-biI.js +0 -387
- package/dist/monitor.account-C2sMOBCS.js +0 -5233
- package/dist/monitor.runtime-BAi6zmcn.js +0 -2
- package/dist/monitor.webhook-BcjpfRCX.js +0 -180
- package/dist/node-cli-sessions-CIhkJRU4.js +0 -1228
- package/dist/openai-http-Dj21RwSj.js +0 -824
- package/dist/openresponses-http-COnnr1ox.js +0 -1173
- package/dist/operations-H3vUh0lM.js +0 -805
- package/dist/outbound-adapter-WLtWE7wv.js +0 -543
- package/dist/outbound-session-route-CZtd64EH.js +0 -45
- package/dist/outbound.runtime-D98P0sN1.js +0 -2
- package/dist/pi-embedded-BWJzd4mK.js +0 -4
- package/dist/pi-embedded-DeNsSqQQ.js +0 -3796
- package/dist/pi-embedded.runtime-CZnNwFpc.js +0 -4
- package/dist/pi-tools-CNHSpjBa.js +0 -2413
- package/dist/plan-B0reFFlM.js +0 -81
- package/dist/plan-CrfF-TH8.js +0 -112
- package/dist/plugin-DI_8eYOe.js +0 -12396
- package/dist/plugin-app-cache-key-WaTUD3e-.js +0 -46
- package/dist/plugin-enabled-aWLXgGGi.js +0 -233
- package/dist/plugin-registration-ByjRIVJm.js +0 -88
- package/dist/plugin-service-VQm_241d.js +0 -1229
- package/dist/policy-BmJH-swe.js +0 -680
- package/dist/policy-DE-bO1zn.js +0 -138
- package/dist/prepare.runtime-bSj3-res.js +0 -732
- package/dist/preview-warnings-CbuGYsF9.js +0 -392
- package/dist/probe-C_rWg7_m.js +0 -682
- package/dist/probe-CagOFfx6.js +0 -2
- package/dist/probe-thX1HqOh.js +0 -2204
- package/dist/probe-zU6B6gFt.js +0 -47
- package/dist/program-BtVdH743.js +0 -131
- package/dist/provider-CDoD7tO0.js +0 -8735
- package/dist/provider-CK1gMdJ2.js +0 -32
- package/dist/provider-DJqr9djy.js +0 -32
- package/dist/provider-DsOJp5bK.js +0 -152
- package/dist/provider-dispatcher-UNQ-LSx9.js +0 -22
- package/dist/provider-session.runtime-DMrkMb4x.js +0 -9
- package/dist/provider.runtime-C2-t3zm8.js +0 -2
- package/dist/public-surface-loader-hTeyyHcd.js +0 -114
- package/dist/pw-ai-BaL3eVYx.js +0 -3029
- package/dist/pw-role-snapshot-DKeBqhN1.js +0 -333
- package/dist/reaction-level-BV2potsD.js +0 -19
- package/dist/reaction-runtime-api-CCBxgM10.js +0 -116
- package/dist/realtime-transcription-provider-CHYtIXZm.js +0 -205
- package/dist/register-BJf28G9B.js +0 -2178
- package/dist/register.agent-oXAHwNQv.js +0 -156
- package/dist/register.crestodian-CQ0sqdV2.js +0 -24
- package/dist/register.maintenance-CylVRs5M.js +0 -83
- package/dist/register.runtime-CcDgwy0X.js +0 -54
- package/dist/register.subclis-CpBYNw2X.js +0 -3
- package/dist/register.subclis-N2CvieOL.js +0 -31
- package/dist/register.subclis-core-BHaGvbzg.js +0 -273
- package/dist/repair-sequencing-EBBnBdIB.js +0 -640
- package/dist/reply-delivery-BLoPALlI.js +0 -196
- package/dist/reply-runtime-D4asNTSa.js +0 -11
- package/dist/reply.runtime-CwprvhoR.js +0 -2
- package/dist/request-DlWPRUDt.js +0 -54
- package/dist/resolve-allowlist-BukQf58x.js +0 -220
- package/dist/result-fallback-classifier-DyHFnqfV.js +0 -79
- package/dist/route-BMf4keN5.js +0 -469
- package/dist/route-resolution-DWNi1QAu.js +0 -274
- package/dist/routes-C20LC8c4.js +0 -3602
- package/dist/routes-CkK7Vv_m.js +0 -2
- package/dist/run-KDF_AEza.js +0 -1162
- package/dist/run-attempt-JHYCfonU.js +0 -7704
- package/dist/run-command-3PVihYIy.js +0 -2
- package/dist/run-command-QHAXnyKY.js +0 -23
- package/dist/run-embedded.runtime-BJw-2vss.js +0 -4
- package/dist/run-execution-cli.runtime-GHClMn2g.js +0 -4
- package/dist/run-subagent-registry.runtime-BLLMrhtE.js +0 -2
- package/dist/runtime-C2u-dC1r.js +0 -1287
- package/dist/runtime-ClyfkDWT.js +0 -6179
- package/dist/runtime-WXCarlPc.js +0 -438
- package/dist/runtime-api-3QhGLpZf.js +0 -13
- package/dist/runtime-api-DRAu3mjv.js +0 -4
- package/dist/runtime-api-JE07pOem.js +0 -13
- package/dist/runtime-api-JuKylHvw.js +0 -24
- package/dist/runtime-api-bcbk4yax.js +0 -21
- package/dist/runtime-api-dDe9U2_V.js +0 -17
- package/dist/runtime-api-uMexLqGS.js +0 -3
- package/dist/runtime-api.actions-Bo7TLDFl.js +0 -3
- package/dist/runtime-api.monitor-7q78L1Em.js +0 -6
- package/dist/runtime-api.send-Bf9RR4nV.js +0 -4
- package/dist/runtime-api.threads-Dj2QuhHj.js +0 -2
- package/dist/runtime-channel-k1C0Satl.js +0 -2
- package/dist/runtime-channel-qt9t0J-J.js +0 -150
- package/dist/runtime-embedded-pi.runtime-BPB9NlTS.js +0 -2
- package/dist/sanitize-outbound-BLH_SQvg.js +0 -127
- package/dist/sdk-setup-tools-BshlBPau.js +0 -8
- package/dist/secrets-CsHXv7d3.js +0 -113
- package/dist/security-audit-CUXBQXNX.js +0 -122
- package/dist/security-audit-CzdXbRma.js +0 -118
- package/dist/security-audit.runtime-Ca0FMFJG.js +0 -2
- package/dist/selection-BmvQJlSD.js +0 -3
- package/dist/selection-BplDXc9w.js +0 -16157
- package/dist/send--qFg8a9v.js +0 -1631
- package/dist/send-BPdryPPA.js +0 -192
- package/dist/send-Bl4YaRkS.js +0 -143
- package/dist/send-Ccm7RMXC.js +0 -2
- package/dist/send.components-c3OUPSmR.js +0 -2
- package/dist/send.components-rhQJYoXs.js +0 -500
- package/dist/send.runtime-dfUkAp5d.js +0 -2
- package/dist/server-DRhyTMLe.js +0 -73
- package/dist/server-Dv4BzjGn.js +0 -24
- package/dist/server-context-4HRJy2vp.js +0 -955
- package/dist/server-context-DlxYb1G5.js +0 -2
- package/dist/server-cron-Bt8Pkc3i.js +0 -2989
- package/dist/server-cron-CtNWsa4Z.js +0 -2
- package/dist/server-methods-rye_okUW.js +0 -16494
- package/dist/server-node-events-C1yZ5a1u.js +0 -596
- package/dist/server-plugin-bootstrap-DUMyVtlP.js +0 -70
- package/dist/server-plugins-B5ZWWkRE.js +0 -432
- package/dist/server-reload-handlers-CTnMXNjT.js +0 -714
- package/dist/server-restart-sentinel-CAYxtwmY.js +0 -747
- package/dist/server-restart-sentinel-DqrtSIvy.js +0 -2
- package/dist/server-runtime-services-CuptQTe5.js +0 -2
- package/dist/server-runtime-services-aaS2IiW3.js +0 -267
- package/dist/server-startup-plugins-D0ymJgQT.js +0 -113
- package/dist/server-startup-post-attach-DlrN2uyt.js +0 -716
- package/dist/server-ws-runtime-CdpLbv4o.js +0 -349
- package/dist/server.impl-Cb4qcMTg.js +0 -2586
- package/dist/service-qxvDlMQE.js +0 -1446
- package/dist/session-binding-6bLobLHL.js +0 -219
- package/dist/session-binding-Bm6fCpoY.js +0 -2
- package/dist/session-kill-http-B6WjVo8V.js +0 -121
- package/dist/session-reset-service-GUVIhxp4.js +0 -625
- package/dist/session-route-BcRDnvzG.js +0 -93
- package/dist/session-status.runtime-BcjOunV4.js +0 -2
- package/dist/session-subagent-reactivation.runtime-BSmk_KYn.js +0 -2
- package/dist/session-tab-registry-BBYzbSOu.js +0 -521
- package/dist/sessions-history-http-bLJJfgLm.js +0 -430
- package/dist/sessions.runtime-DNRtQzCk.js +0 -2
- package/dist/setup-api-CcolVVJs.js +0 -29
- package/dist/setup-core-eJD18F3B.js +0 -174
- package/dist/setup-surface-B75C2Qtz.js +0 -221
- package/dist/setup-surface-CFuPfVHp.js +0 -405
- package/dist/setup-surface-Dyy-Mzyz.js +0 -288
- package/dist/setup-surface-ZsVF_g8W.js +0 -320
- package/dist/shared-BkCNrcLX.js +0 -121
- package/dist/shared-client-B7zqC9p2.js +0 -2
- package/dist/shared-client-yXjKgZBz.js +0 -629
- package/dist/side-question-DU3gESCb.js +0 -683
- package/dist/skill-tool-dispatch.runtime-CPBuqyvk.js +0 -143
- package/dist/slash-state-Do3bAahA.js +0 -2166
- package/dist/speech-provider-Bg9los3C.js +0 -184
- package/dist/src-D7LzUctH.js +0 -4256
- package/dist/startup-context-CCF2gIOl.js +0 -313
- package/dist/status-subagents.runtime-DX5FTymp.js +0 -18
- package/dist/status-text-B-1u5dSV.js +0 -296
- package/dist/sticker-cache-DwpU_9RJ.js +0 -206
- package/dist/sticker-vision.runtime-Bbldi_YL.js +0 -17
- package/dist/subagent-announce-BCo0VHVL.js +0 -354
- package/dist/subagent-announce-delivery-JcnuDN_N.js +0 -958
- package/dist/subagent-control-BzbA3Suz.js +0 -508
- package/dist/subagent-hooks-BIGZQWrG.js +0 -2
- package/dist/subagent-hooks-Bj4qYZfv.js +0 -230
- package/dist/subagent-hooks-C-rvhVBv.js +0 -2
- package/dist/subagent-hooks-P01_AFl5.js +0 -116
- package/dist/subagent-hooks-VEfak8nl.js +0 -2
- package/dist/subagent-hooks-api-BPnSxxN4.js +0 -23
- package/dist/subagent-hooks-api-DwIAvMoS.js +0 -22
- package/dist/subagent-hooks-api-kgyR9FOb.js +0 -23
- package/dist/subagent-hooks-oED56wqq.js +0 -146
- package/dist/subagent-orphan-recovery-D79ZzwKN.js +0 -352
- package/dist/subagent-registry-D0soBT5j.js +0 -2351
- package/dist/subagent-registry-DRJDkmty.js +0 -3
- package/dist/subagent-session-cleanup-9eAO1aJe.js +0 -525
- package/dist/subagent-spawn-D80vbogm.js +0 -1164
- package/dist/target-id-COLv5LsJ.js +0 -107
- package/dist/targets-CDW5IQ6a.js +0 -44
- package/dist/targets-Ci6O1ZdP.js +0 -19
- package/dist/targets-CsaWFBg1.js +0 -19
- package/dist/testing-BoJit-h1.js +0 -267
- package/dist/thread-bindings-CGCvw0KT.js +0 -571
- package/dist/thread-bindings-ClCTNacX.js +0 -228
- package/dist/thread-bindings-DRb7BMZ6.js +0 -8
- package/dist/thread-bindings-Xc6smav0.js +0 -232
- package/dist/thread-bindings.discord-api-DC467oeF.js +0 -187
- package/dist/thread-bindings.manager-C_mpTDIZ.js +0 -536
- package/dist/thread-bindings.manager-DkCRs612.js +0 -2
- package/dist/thread-lifecycle-DpqCXlx9.js +0 -1614
- package/dist/token-CI6HjbTA.js +0 -134
- package/dist/tool-BMe7hjBK.js +0 -139
- package/dist/tool-actions.runtime-D-h5PI_m.js +0 -534
- package/dist/tool-resolution-CnLx0CHe.js +0 -149
- package/dist/tools-effective-inventory-BR6MUMtE.js +0 -204
- package/dist/tools-invoke-http-CTTs2yMT.js +0 -67
- package/dist/tools-invoke-shared-9B1EjXWf.js +0 -200
- package/dist/tts-eGOviZ5c.js +0 -66
- package/dist/tui-Bw0HqKd7.js +0 -4709
- package/dist/tui-CIZJnPzj.js +0 -2
- package/dist/tui-backend-BJ_r7tcF.js +0 -256
- package/dist/tui-cli-BaSMBpuA.js +0 -37
- package/dist/update-cli-zuCybGNR.js +0 -3664
- package/dist/update-runner-Dek2BHmQ.js +0 -2379
- package/dist/vision-tools-1ps0BEE5.js +0 -1409
- package/dist/web-search-B7EziZXE.js +0 -62
- package/dist/web-search-provider.runtime-DGTCvGch.js +0 -328
- package/dist/web-search-provider.runtime-DWL5t39M.js +0 -2
- package/dist/xai-oauth-CRtsj2Gs.js +0 -479
- package/dist/xai-user-agent-Dndwzw2S.js +0 -32
- /package/dist/{acp-runtime-backend-DSDBcyh9.js → acp-runtime-backend-Cxo7eBHf.js} +0 -0
- /package/dist/{channel-actions-FV66JqtI.js → channel-actions-UDeVjgGz.js} +0 -0
- /package/dist/{command-status-runtime-BRWKSoG7.js → command-status-runtime-CoHd4Fws.js} +0 -0
- /package/dist/{delegate-DGqKhwB4.js → delegate-B-2xZ77o.js} +0 -0
- /package/dist/{dispatch-acp-Ceoxja_Z.js → dispatch-acp-DLPkmK7K.js} +0 -0
- /package/dist/{heartbeat-runner-CJHvr5pG.js → heartbeat-runner-D2j6JwOI.js} +0 -0
- /package/dist/{library-Bq3aDek_.js → library-DBT0cIPP.js} +0 -0
- /package/dist/{run-executor.runtime-DNJhGPbA.js → run-executor.runtime-DE4J7f4M.js} +0 -0
- /package/dist/{shared-CYxmRpq1.js → shared-xeo8Yh5n.js} +0 -0
|
@@ -0,0 +1,1631 @@
|
|
|
1
|
+
import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString, s as normalizeOptionalLowercaseString } from "./string-coerce-DyL154ka.js";
|
|
2
|
+
import { s as redactSensitiveText } from "./redact-BjrmHGQ6.js";
|
|
3
|
+
import { a as formatUncaughtError, i as formatErrorMessage } from "./errors-D_oyTIw2.js";
|
|
4
|
+
import { t as isDiagnosticFlagEnabled } from "./diagnostic-flags-BbmySUrJ.js";
|
|
5
|
+
import { i as replaceFileAtomicSync } from "./replace-file-DJ-yT_Qm.js";
|
|
6
|
+
import { r as logVerbose } from "./globals-DhGeOA1P.js";
|
|
7
|
+
import { t as createSubsystemLogger } from "./subsystem-CppbuBPw.js";
|
|
8
|
+
import { d as readConfigFileSnapshotForWrite } from "./io-Ct2JqgbR.js";
|
|
9
|
+
import { i as replaceConfigFile } from "./mutate-DSZiMIjv.js";
|
|
10
|
+
import { u as resolveStorePath } from "./paths-8MFrTNIB.js";
|
|
11
|
+
import { c as kindFromMime, s as isGifMedia } from "./mime-DppuT-pZ.js";
|
|
12
|
+
import { i as saveCronStore, r as resolveCronStorePath, t as loadCronStore } from "./store-jjhplGXD.js";
|
|
13
|
+
import { c as getImageMetadata, n as probeVideoDimensions } from "./media-services-C8kJ1LwP.js";
|
|
14
|
+
import { t as loadWebMedia } from "./web-media-9RxiGagW.js";
|
|
15
|
+
import { n as normalizePollInput } from "./polls-C-v11_tu.js";
|
|
16
|
+
import { r as makeProxyFetch } from "./proxy-fetch-Bpht0qpc.js";
|
|
17
|
+
import { t as buildOutboundMediaLoadOptions } from "./load-options-LnfEFXDj.js";
|
|
18
|
+
import { o as normalizeTelegramApiRoot, r as resolveTelegramTransport } from "./fetch-CBRkqVBE.js";
|
|
19
|
+
import "./error-runtime--zM-GsR-.js";
|
|
20
|
+
import "./runtime-env-BSECk1Nm.js";
|
|
21
|
+
import "./string-coerce-runtime-DcopKqDR.js";
|
|
22
|
+
import { a as isRecoverableTelegramNetworkError, c as isTelegramMisdirectedRequestError, d as isTelegramServerError, f as tagTelegramNetworkError, o as isSafeToRetrySendError, r as resolveTelegramRequestTimeoutMs, u as isTelegramRateLimitError } from "./request-timeouts-CQOVTeCu.js";
|
|
23
|
+
import { t as resolveMarkdownTableMode } from "./markdown-tables-BEjHxS3n.js";
|
|
24
|
+
import { n as recordChannelActivity } from "./channel-activity-eMQlJ3BE.js";
|
|
25
|
+
import { r as isVoiceCompatibleAudio } from "./audio-CVFIRHpA.js";
|
|
26
|
+
import { t as requireRuntimeConfig } from "./plugin-config-runtime-BhkqZ7bA.js";
|
|
27
|
+
import "./config-mutation-CwZjp067.js";
|
|
28
|
+
import "./cron-store-runtime--UiQy5DN.js";
|
|
29
|
+
import "./web-media-CRJx89eu.js";
|
|
30
|
+
import { n as createChannelApiRetryRunner } from "./retry-policy-NbhM9vPP.js";
|
|
31
|
+
import "./ssrf-runtime-Gwgbj2qf.js";
|
|
32
|
+
import "./media-runtime-CPXTkSQr.js";
|
|
33
|
+
import "./security-runtime-Q5KQBgu1.js";
|
|
34
|
+
import "./logging-core-w_rP2qMe.js";
|
|
35
|
+
import "./markdown-table-runtime-CGhR5c0i.js";
|
|
36
|
+
import "./session-store-runtime-BZIAo9w7.js";
|
|
37
|
+
import "./retry-runtime-BObvpQE1.js";
|
|
38
|
+
import { o as resolveTelegramAccount } from "./accounts-CuvH2tuN.js";
|
|
39
|
+
import { i as parseTelegramTarget, n as normalizeTelegramChatId, r as normalizeTelegramLookupTarget } from "./targets-D0gFWyUZ.js";
|
|
40
|
+
import { J as normalizeTelegramReplyToMessageId, a as renderTelegramHtmlText, g as buildTypingThreadParams, h as buildTelegramThreadParams, o as splitTelegramHtmlChunks, s as telegramHtmlToPlainTextFallback } from "./format-DUJUpMFQ.js";
|
|
41
|
+
import fs from "node:fs";
|
|
42
|
+
import * as grammy from "grammy";
|
|
43
|
+
import { Bot, Bot as Bot$1, HttpError } from "grammy";
|
|
44
|
+
import { sequentialize } from "@grammyjs/runner";
|
|
45
|
+
import { apiThrottler } from "@grammyjs/transformer-throttler";
|
|
46
|
+
//#region extensions/telegram/src/account-throttler.ts
|
|
47
|
+
var GroupFairQueue = class {
|
|
48
|
+
constructor() {
|
|
49
|
+
this.lanes = /* @__PURE__ */ new Map();
|
|
50
|
+
this.laneOrder = [];
|
|
51
|
+
this.nextLaneIndex = 0;
|
|
52
|
+
this.running = false;
|
|
53
|
+
}
|
|
54
|
+
enqueue(laneKey, run) {
|
|
55
|
+
return new Promise((resolve, reject) => {
|
|
56
|
+
const request = {
|
|
57
|
+
run,
|
|
58
|
+
resolve,
|
|
59
|
+
reject
|
|
60
|
+
};
|
|
61
|
+
const existing = this.lanes.get(laneKey);
|
|
62
|
+
if (existing) existing.push(request);
|
|
63
|
+
else {
|
|
64
|
+
this.lanes.set(laneKey, [request]);
|
|
65
|
+
this.laneOrder.push(laneKey);
|
|
66
|
+
}
|
|
67
|
+
this.start();
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
start() {
|
|
71
|
+
if (this.running) return;
|
|
72
|
+
this.running = true;
|
|
73
|
+
this.drain();
|
|
74
|
+
}
|
|
75
|
+
async drain() {
|
|
76
|
+
try {
|
|
77
|
+
while (true) {
|
|
78
|
+
const request = this.takeNext();
|
|
79
|
+
if (!request) return;
|
|
80
|
+
try {
|
|
81
|
+
request.resolve(await request.run());
|
|
82
|
+
} catch (err) {
|
|
83
|
+
request.reject(err);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
} finally {
|
|
87
|
+
this.running = false;
|
|
88
|
+
if (this.laneOrder.length > 0) this.start();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
takeNext() {
|
|
92
|
+
for (let scanned = 0; scanned < this.laneOrder.length; scanned += 1) {
|
|
93
|
+
this.nextLaneIndex %= this.laneOrder.length;
|
|
94
|
+
const laneKey = this.laneOrder[this.nextLaneIndex];
|
|
95
|
+
const queue = this.lanes.get(laneKey);
|
|
96
|
+
if (!queue || queue.length === 0) {
|
|
97
|
+
this.lanes.delete(laneKey);
|
|
98
|
+
this.laneOrder.splice(this.nextLaneIndex, 1);
|
|
99
|
+
if (this.laneOrder.length === 0) {
|
|
100
|
+
this.nextLaneIndex = 0;
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
continue;
|
|
104
|
+
}
|
|
105
|
+
const request = queue.shift();
|
|
106
|
+
this.nextLaneIndex += 1;
|
|
107
|
+
return request;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
const throttlerByToken = /* @__PURE__ */ new Map();
|
|
112
|
+
function readNumericId(value) {
|
|
113
|
+
if (typeof value === "number") return Number.isFinite(value) ? Math.trunc(value) : void 0;
|
|
114
|
+
if (typeof value !== "string") return;
|
|
115
|
+
const numeric = Number(value.trim());
|
|
116
|
+
return Number.isFinite(numeric) ? Math.trunc(numeric) : void 0;
|
|
117
|
+
}
|
|
118
|
+
function readPayload(payload) {
|
|
119
|
+
return payload && typeof payload === "object" ? payload : void 0;
|
|
120
|
+
}
|
|
121
|
+
function resolveGroupChatKey(payload) {
|
|
122
|
+
const chatId = readNumericId(payload.chat_id);
|
|
123
|
+
return chatId !== void 0 && chatId < 0 ? String(chatId) : void 0;
|
|
124
|
+
}
|
|
125
|
+
function resolveForumLaneKey(payload) {
|
|
126
|
+
const threadId = readNumericId(payload.message_thread_id);
|
|
127
|
+
if (threadId !== void 0) return `topic:${threadId}`;
|
|
128
|
+
const directTopicId = readNumericId(payload.direct_messages_topic_id);
|
|
129
|
+
if (directTopicId !== void 0) return `direct-topic:${directTopicId}`;
|
|
130
|
+
const messageId = readNumericId(payload.message_id);
|
|
131
|
+
if (messageId !== void 0) return `message:${messageId}`;
|
|
132
|
+
return "main";
|
|
133
|
+
}
|
|
134
|
+
function createTelegramAccountThrottler(createThrottler = apiThrottler) {
|
|
135
|
+
const baseThrottler = createThrottler();
|
|
136
|
+
const fairQueuesByChat = /* @__PURE__ */ new Map();
|
|
137
|
+
return (prev, method, payload, signal) => {
|
|
138
|
+
const apiPayload = readPayload(payload);
|
|
139
|
+
const groupChatKey = apiPayload ? resolveGroupChatKey(apiPayload) : void 0;
|
|
140
|
+
if (!apiPayload || !groupChatKey) return baseThrottler(prev, method, payload, signal);
|
|
141
|
+
let fairQueue = fairQueuesByChat.get(groupChatKey);
|
|
142
|
+
if (!fairQueue) {
|
|
143
|
+
fairQueue = new GroupFairQueue();
|
|
144
|
+
fairQueuesByChat.set(groupChatKey, fairQueue);
|
|
145
|
+
}
|
|
146
|
+
const laneKey = resolveForumLaneKey(apiPayload);
|
|
147
|
+
return fairQueue.enqueue(laneKey, () => baseThrottler(prev, method, payload, signal));
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
function getOrCreateAccountThrottler(token, createThrottler = apiThrottler) {
|
|
151
|
+
let throttler = throttlerByToken.get(token);
|
|
152
|
+
if (!throttler) {
|
|
153
|
+
throttler = createTelegramAccountThrottler(createThrottler);
|
|
154
|
+
throttlerByToken.set(token, throttler);
|
|
155
|
+
}
|
|
156
|
+
return throttler;
|
|
157
|
+
}
|
|
158
|
+
//#endregion
|
|
159
|
+
//#region extensions/telegram/src/api-logging.ts
|
|
160
|
+
const fallbackLogger = createSubsystemLogger("telegram/api");
|
|
161
|
+
function resolveTelegramApiLogger(runtime, logger) {
|
|
162
|
+
if (logger) return logger;
|
|
163
|
+
if (runtime?.error) return runtime.error;
|
|
164
|
+
return (message) => fallbackLogger.error(message);
|
|
165
|
+
}
|
|
166
|
+
async function withTelegramApiErrorLogging({ operation, fn, runtime, logger, shouldLog }) {
|
|
167
|
+
try {
|
|
168
|
+
return await fn();
|
|
169
|
+
} catch (err) {
|
|
170
|
+
if (!shouldLog || shouldLog(err)) {
|
|
171
|
+
const errText = formatErrorMessage(err);
|
|
172
|
+
resolveTelegramApiLogger(runtime, logger)(`telegram ${operation} failed: ${errText}`);
|
|
173
|
+
}
|
|
174
|
+
throw err;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
function splitTelegramCaption(text) {
|
|
178
|
+
const trimmed = text?.trim() ?? "";
|
|
179
|
+
if (!trimmed) return {
|
|
180
|
+
caption: void 0,
|
|
181
|
+
followUpText: void 0
|
|
182
|
+
};
|
|
183
|
+
if (trimmed.length > 1024) return {
|
|
184
|
+
caption: void 0,
|
|
185
|
+
followUpText: trimmed
|
|
186
|
+
};
|
|
187
|
+
return {
|
|
188
|
+
caption: trimmed,
|
|
189
|
+
followUpText: void 0
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
//#endregion
|
|
193
|
+
//#region extensions/telegram/src/client-fetch.ts
|
|
194
|
+
function asTelegramClientFetch(fetchImpl) {
|
|
195
|
+
return fetchImpl;
|
|
196
|
+
}
|
|
197
|
+
function asTelegramCompatFetch(fetchImpl) {
|
|
198
|
+
return fetchImpl;
|
|
199
|
+
}
|
|
200
|
+
function isTelegramAbortSignalLike(value) {
|
|
201
|
+
return typeof value === "object" && value !== null && "aborted" in value && typeof value.aborted === "boolean" && typeof value.addEventListener === "function" && typeof value.removeEventListener === "function";
|
|
202
|
+
}
|
|
203
|
+
function readRequestUrl(input) {
|
|
204
|
+
if (typeof input === "string") return input;
|
|
205
|
+
if (input instanceof URL) return input.toString();
|
|
206
|
+
if (input instanceof Request) return input.url;
|
|
207
|
+
return null;
|
|
208
|
+
}
|
|
209
|
+
function extractTelegramApiMethod(input) {
|
|
210
|
+
const url = readRequestUrl(input);
|
|
211
|
+
if (!url) return null;
|
|
212
|
+
try {
|
|
213
|
+
const segments = new URL(url).pathname.split("/").filter(Boolean);
|
|
214
|
+
return normalizeOptionalLowercaseString(segments.length > 0 ? segments.at(-1) ?? null : null) ?? null;
|
|
215
|
+
} catch {
|
|
216
|
+
return null;
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
const TELEGRAM_TIMEOUT_FALLBACK_METHODS = new Set([
|
|
220
|
+
"deletemycommands",
|
|
221
|
+
"deletewebhook",
|
|
222
|
+
"getme",
|
|
223
|
+
"sendchataction",
|
|
224
|
+
"setmycommands",
|
|
225
|
+
"setwebhook"
|
|
226
|
+
]);
|
|
227
|
+
function shouldRetryTimedOutTelegramControlRequest(method) {
|
|
228
|
+
return method !== null && TELEGRAM_TIMEOUT_FALLBACK_METHODS.has(method);
|
|
229
|
+
}
|
|
230
|
+
function resolveTelegramClientTimeoutSeconds(params) {
|
|
231
|
+
const { value, minimum } = params;
|
|
232
|
+
if (typeof value !== "number" || !Number.isFinite(value)) return;
|
|
233
|
+
const configured = Math.max(1, Math.floor(value));
|
|
234
|
+
if (typeof minimum !== "number" || !Number.isFinite(minimum)) return configured;
|
|
235
|
+
return Math.max(configured, Math.max(1, Math.floor(minimum)));
|
|
236
|
+
}
|
|
237
|
+
function resolveTelegramClientTimeoutMinimumSeconds(values) {
|
|
238
|
+
let minimum;
|
|
239
|
+
for (const value of values) {
|
|
240
|
+
if (typeof value !== "number" || !Number.isFinite(value)) continue;
|
|
241
|
+
const normalized = Math.max(1, Math.ceil(value));
|
|
242
|
+
minimum = minimum === void 0 ? normalized : Math.max(minimum, normalized);
|
|
243
|
+
}
|
|
244
|
+
return minimum;
|
|
245
|
+
}
|
|
246
|
+
function resolveTelegramOutboundClientTimeoutFloorSeconds(timeoutSeconds) {
|
|
247
|
+
const timeoutMs = resolveTelegramRequestTimeoutMs("sendmessage", timeoutSeconds);
|
|
248
|
+
return timeoutMs === void 0 ? void 0 : timeoutMs / 1e3;
|
|
249
|
+
}
|
|
250
|
+
function createTelegramClientFetch(params) {
|
|
251
|
+
if (!params.fetchImpl && !params.shutdownSignal) return;
|
|
252
|
+
const callFetch = asTelegramCompatFetch(params.fetchImpl ?? asTelegramClientFetch(globalThis.fetch));
|
|
253
|
+
const wrappedFetch = async (input, init) => {
|
|
254
|
+
const method = extractTelegramApiMethod(input);
|
|
255
|
+
const requestTimeoutMs = resolveTelegramRequestTimeoutMs(method, params.timeoutSeconds);
|
|
256
|
+
const shutdownSignal = isTelegramAbortSignalLike(params.shutdownSignal) ? params.shutdownSignal : void 0;
|
|
257
|
+
const requestSignal = isTelegramAbortSignalLike(init?.signal) ? init.signal : void 0;
|
|
258
|
+
const canForceTransportFallback = (reason) => !shutdownSignal?.aborted && !requestSignal?.aborted && params.transport?.forceFallback?.(reason) === true;
|
|
259
|
+
const runFetch = async () => {
|
|
260
|
+
const controller = new AbortController();
|
|
261
|
+
const abortWith = (signal) => controller.abort(signal.reason);
|
|
262
|
+
const onShutdown = () => {
|
|
263
|
+
if (shutdownSignal) abortWith(shutdownSignal);
|
|
264
|
+
};
|
|
265
|
+
let requestTimeout;
|
|
266
|
+
let onRequestAbort;
|
|
267
|
+
let requestTimedOut = false;
|
|
268
|
+
const timeoutError = requestTimeoutMs !== void 0 ? /* @__PURE__ */ new Error(`Telegram ${method} timed out after ${requestTimeoutMs}ms`) : void 0;
|
|
269
|
+
if (shutdownSignal?.aborted) abortWith(shutdownSignal);
|
|
270
|
+
else if (shutdownSignal) shutdownSignal.addEventListener("abort", onShutdown, { once: true });
|
|
271
|
+
if (requestSignal) if (requestSignal.aborted) abortWith(requestSignal);
|
|
272
|
+
else {
|
|
273
|
+
onRequestAbort = () => abortWith(requestSignal);
|
|
274
|
+
requestSignal.addEventListener("abort", onRequestAbort);
|
|
275
|
+
}
|
|
276
|
+
if (requestTimeoutMs && timeoutError) {
|
|
277
|
+
requestTimeout = setTimeout(() => {
|
|
278
|
+
requestTimedOut = true;
|
|
279
|
+
controller.abort(timeoutError);
|
|
280
|
+
}, requestTimeoutMs);
|
|
281
|
+
requestTimeout.unref?.();
|
|
282
|
+
}
|
|
283
|
+
try {
|
|
284
|
+
return await callFetch(input, {
|
|
285
|
+
...init,
|
|
286
|
+
signal: controller.signal
|
|
287
|
+
});
|
|
288
|
+
} catch (err) {
|
|
289
|
+
if (requestTimedOut && timeoutError) throw timeoutError;
|
|
290
|
+
throw err;
|
|
291
|
+
} finally {
|
|
292
|
+
if (requestTimeout) clearTimeout(requestTimeout);
|
|
293
|
+
shutdownSignal?.removeEventListener("abort", onShutdown);
|
|
294
|
+
if (requestSignal && onRequestAbort) requestSignal.removeEventListener("abort", onRequestAbort);
|
|
295
|
+
}
|
|
296
|
+
};
|
|
297
|
+
try {
|
|
298
|
+
const response = await runFetch();
|
|
299
|
+
if (response.status === 421 && canForceTransportFallback("misdirected-request")) return await runFetch();
|
|
300
|
+
return response;
|
|
301
|
+
} catch (err) {
|
|
302
|
+
if (requestTimeoutMs && shouldRetryTimedOutTelegramControlRequest(method) && canForceTransportFallback("request-timeout")) return await runFetch();
|
|
303
|
+
if (isTelegramMisdirectedRequestError(err) && canForceTransportFallback("misdirected-request")) return await runFetch();
|
|
304
|
+
throw err;
|
|
305
|
+
}
|
|
306
|
+
};
|
|
307
|
+
return (input, init) => {
|
|
308
|
+
return Promise.resolve(wrappedFetch(input, init)).catch((err) => {
|
|
309
|
+
try {
|
|
310
|
+
tagTelegramNetworkError(err, {
|
|
311
|
+
method: extractTelegramApiMethod(input),
|
|
312
|
+
url: readRequestUrl(input)
|
|
313
|
+
});
|
|
314
|
+
} catch {}
|
|
315
|
+
throw err;
|
|
316
|
+
});
|
|
317
|
+
};
|
|
318
|
+
}
|
|
319
|
+
//#endregion
|
|
320
|
+
//#region extensions/telegram/src/inline-keyboard.ts
|
|
321
|
+
function toInlineKeyboardButton(button) {
|
|
322
|
+
if (!button?.text) return;
|
|
323
|
+
if (button.url) return button.style ? {
|
|
324
|
+
text: button.text,
|
|
325
|
+
url: button.url,
|
|
326
|
+
style: button.style
|
|
327
|
+
} : {
|
|
328
|
+
text: button.text,
|
|
329
|
+
url: button.url
|
|
330
|
+
};
|
|
331
|
+
if (button.callback_data) return button.style ? {
|
|
332
|
+
text: button.text,
|
|
333
|
+
callback_data: button.callback_data,
|
|
334
|
+
style: button.style
|
|
335
|
+
} : {
|
|
336
|
+
text: button.text,
|
|
337
|
+
callback_data: button.callback_data
|
|
338
|
+
};
|
|
339
|
+
if (button.web_app?.url) return button.style ? {
|
|
340
|
+
text: button.text,
|
|
341
|
+
web_app: { url: button.web_app.url },
|
|
342
|
+
style: button.style
|
|
343
|
+
} : {
|
|
344
|
+
text: button.text,
|
|
345
|
+
web_app: { url: button.web_app.url }
|
|
346
|
+
};
|
|
347
|
+
}
|
|
348
|
+
function buildInlineKeyboard(buttons) {
|
|
349
|
+
if (!buttons?.length) return;
|
|
350
|
+
const rows = buttons.map((row) => row.map(toInlineKeyboardButton).filter((button) => Boolean(button))).filter((row) => row.length > 0);
|
|
351
|
+
if (rows.length === 0) return;
|
|
352
|
+
return { inline_keyboard: rows };
|
|
353
|
+
}
|
|
354
|
+
//#endregion
|
|
355
|
+
//#region extensions/telegram/src/reply-parameters.ts
|
|
356
|
+
function resolveTelegramSendThreadSpec(params) {
|
|
357
|
+
const messageThreadId = params.messageThreadId != null ? params.messageThreadId : params.targetMessageThreadId;
|
|
358
|
+
if (messageThreadId == null) return;
|
|
359
|
+
return {
|
|
360
|
+
id: messageThreadId,
|
|
361
|
+
scope: params.chatType === "direct" ? "dm" : "forum"
|
|
362
|
+
};
|
|
363
|
+
}
|
|
364
|
+
function buildTelegramThreadReplyParams(opts) {
|
|
365
|
+
const params = {};
|
|
366
|
+
const threadParams = buildTelegramThreadParams(opts?.thread);
|
|
367
|
+
if (threadParams) params.message_thread_id = threadParams.message_thread_id;
|
|
368
|
+
const replyToMessageId = normalizeTelegramReplyToMessageId(opts?.replyToMessageId);
|
|
369
|
+
if (replyToMessageId == null) return params;
|
|
370
|
+
const defaultQuoteMessageId = opts?.useReplyIdAsQuoteSource === true ? replyToMessageId : void 0;
|
|
371
|
+
const replyQuoteTextRaw = normalizeTelegramReplyToMessageId(opts?.replyQuoteMessageId ?? defaultQuoteMessageId) === replyToMessageId ? opts?.replyQuoteText : void 0;
|
|
372
|
+
const replyQuoteText = replyQuoteTextRaw?.trim() ? replyQuoteTextRaw : void 0;
|
|
373
|
+
if (!replyQuoteText) {
|
|
374
|
+
params.reply_to_message_id = replyToMessageId;
|
|
375
|
+
params.allow_sending_without_reply = true;
|
|
376
|
+
return params;
|
|
377
|
+
}
|
|
378
|
+
const replyParameters = {
|
|
379
|
+
message_id: replyToMessageId,
|
|
380
|
+
quote: replyQuoteText,
|
|
381
|
+
allow_sending_without_reply: true
|
|
382
|
+
};
|
|
383
|
+
if (typeof opts?.replyQuotePosition === "number" && Number.isFinite(opts.replyQuotePosition)) replyParameters.quote_position = Math.trunc(opts.replyQuotePosition);
|
|
384
|
+
if (Array.isArray(opts?.replyQuoteEntities) && opts.replyQuoteEntities.length > 0) replyParameters.quote_entities = opts.replyQuoteEntities;
|
|
385
|
+
params.reply_parameters = replyParameters;
|
|
386
|
+
return params;
|
|
387
|
+
}
|
|
388
|
+
function buildTelegramSendParams(opts) {
|
|
389
|
+
const params = { ...buildTelegramThreadReplyParams(opts) };
|
|
390
|
+
if (opts?.silent === true) params.disable_notification = true;
|
|
391
|
+
return params;
|
|
392
|
+
}
|
|
393
|
+
function getTelegramNativeQuoteReplyMessageId(params) {
|
|
394
|
+
const replyParameters = params?.reply_parameters;
|
|
395
|
+
if (!replyParameters || typeof replyParameters !== "object") return;
|
|
396
|
+
const messageId = replyParameters.message_id;
|
|
397
|
+
return typeof messageId === "number" && Number.isFinite(messageId) ? messageId : void 0;
|
|
398
|
+
}
|
|
399
|
+
function removeTelegramNativeQuoteParam(params) {
|
|
400
|
+
if (!params) return {};
|
|
401
|
+
const replyMessageId = getTelegramNativeQuoteReplyMessageId(params);
|
|
402
|
+
const { reply_parameters: _ignored, ...rest } = params;
|
|
403
|
+
if (replyMessageId != null) {
|
|
404
|
+
rest.reply_to_message_id = replyMessageId;
|
|
405
|
+
rest.allow_sending_without_reply = true;
|
|
406
|
+
}
|
|
407
|
+
return rest;
|
|
408
|
+
}
|
|
409
|
+
//#endregion
|
|
410
|
+
//#region extensions/telegram/src/sent-message-cache.ts
|
|
411
|
+
const TTL_MS = 1440 * 60 * 1e3;
|
|
412
|
+
const TELEGRAM_SENT_MESSAGES_STATE_KEY = Symbol.for("daocore.telegramSentMessagesState");
|
|
413
|
+
function getSentMessageState() {
|
|
414
|
+
const globalStore = globalThis;
|
|
415
|
+
const existing = globalStore[TELEGRAM_SENT_MESSAGES_STATE_KEY];
|
|
416
|
+
if (existing) return existing;
|
|
417
|
+
const state = { bucketsByPath: /* @__PURE__ */ new Map() };
|
|
418
|
+
globalStore[TELEGRAM_SENT_MESSAGES_STATE_KEY] = state;
|
|
419
|
+
return state;
|
|
420
|
+
}
|
|
421
|
+
function createSentMessageStore() {
|
|
422
|
+
return /* @__PURE__ */ new Map();
|
|
423
|
+
}
|
|
424
|
+
function resolveSentMessageStorePath(cfg) {
|
|
425
|
+
return `${resolveStorePath(cfg?.session?.store)}.telegram-sent-messages.json`;
|
|
426
|
+
}
|
|
427
|
+
function cleanupExpired(store, scopeKey, entry, now) {
|
|
428
|
+
for (const [id, timestamp] of entry) if (now - timestamp > TTL_MS) entry.delete(id);
|
|
429
|
+
if (entry.size === 0) store.delete(scopeKey);
|
|
430
|
+
}
|
|
431
|
+
function readPersistedSentMessages(filePath) {
|
|
432
|
+
if (!fs.existsSync(filePath)) return createSentMessageStore();
|
|
433
|
+
try {
|
|
434
|
+
const raw = fs.readFileSync(filePath, "utf-8");
|
|
435
|
+
const parsed = JSON.parse(raw);
|
|
436
|
+
const now = Date.now();
|
|
437
|
+
const store = createSentMessageStore();
|
|
438
|
+
for (const [chatId, entry] of Object.entries(parsed)) {
|
|
439
|
+
const messages = /* @__PURE__ */ new Map();
|
|
440
|
+
for (const [messageId, timestamp] of Object.entries(entry)) if (typeof timestamp === "number" && Number.isFinite(timestamp) && now - timestamp <= TTL_MS) messages.set(messageId, timestamp);
|
|
441
|
+
if (messages.size > 0) store.set(chatId, messages);
|
|
442
|
+
}
|
|
443
|
+
return store;
|
|
444
|
+
} catch (error) {
|
|
445
|
+
logVerbose(`telegram: failed to read sent-message cache: ${String(error)}`);
|
|
446
|
+
return createSentMessageStore();
|
|
447
|
+
}
|
|
448
|
+
}
|
|
449
|
+
function getSentMessageBucket(cfg) {
|
|
450
|
+
const state = getSentMessageState();
|
|
451
|
+
const persistedPath = resolveSentMessageStorePath(cfg);
|
|
452
|
+
const existing = state.bucketsByPath.get(persistedPath);
|
|
453
|
+
if (existing) return existing;
|
|
454
|
+
const bucket = {
|
|
455
|
+
persistedPath,
|
|
456
|
+
store: readPersistedSentMessages(persistedPath)
|
|
457
|
+
};
|
|
458
|
+
state.bucketsByPath.set(persistedPath, bucket);
|
|
459
|
+
return bucket;
|
|
460
|
+
}
|
|
461
|
+
function getSentMessages(cfg) {
|
|
462
|
+
return getSentMessageBucket(cfg).store;
|
|
463
|
+
}
|
|
464
|
+
function persistSentMessages(bucket) {
|
|
465
|
+
const { store, persistedPath } = bucket;
|
|
466
|
+
const now = Date.now();
|
|
467
|
+
const serialized = {};
|
|
468
|
+
for (const [chatId, entry] of store) {
|
|
469
|
+
cleanupExpired(store, chatId, entry, now);
|
|
470
|
+
if (entry.size > 0) serialized[chatId] = Object.fromEntries(entry);
|
|
471
|
+
}
|
|
472
|
+
if (Object.keys(serialized).length === 0) {
|
|
473
|
+
fs.rmSync(persistedPath, { force: true });
|
|
474
|
+
return;
|
|
475
|
+
}
|
|
476
|
+
replaceFileAtomicSync({
|
|
477
|
+
filePath: persistedPath,
|
|
478
|
+
content: JSON.stringify(serialized),
|
|
479
|
+
tempPrefix: ".telegram-sent-message-cache"
|
|
480
|
+
});
|
|
481
|
+
}
|
|
482
|
+
function recordSentMessage(chatId, messageId, cfg) {
|
|
483
|
+
const scopeKey = String(chatId);
|
|
484
|
+
const idKey = String(messageId);
|
|
485
|
+
const now = Date.now();
|
|
486
|
+
const bucket = getSentMessageBucket(cfg);
|
|
487
|
+
const { store } = bucket;
|
|
488
|
+
let entry = store.get(scopeKey);
|
|
489
|
+
if (!entry) {
|
|
490
|
+
entry = /* @__PURE__ */ new Map();
|
|
491
|
+
store.set(scopeKey, entry);
|
|
492
|
+
}
|
|
493
|
+
entry.set(idKey, now);
|
|
494
|
+
if (entry.size > 100) cleanupExpired(store, scopeKey, entry, now);
|
|
495
|
+
try {
|
|
496
|
+
persistSentMessages(bucket);
|
|
497
|
+
} catch (error) {
|
|
498
|
+
logVerbose(`telegram: failed to persist sent-message cache: ${String(error)}`);
|
|
499
|
+
}
|
|
500
|
+
}
|
|
501
|
+
function wasSentByBot(chatId, messageId, cfg) {
|
|
502
|
+
const scopeKey = String(chatId);
|
|
503
|
+
const idKey = String(messageId);
|
|
504
|
+
const store = getSentMessages(cfg);
|
|
505
|
+
const entry = store.get(scopeKey);
|
|
506
|
+
if (!entry) return false;
|
|
507
|
+
cleanupExpired(store, scopeKey, entry, Date.now());
|
|
508
|
+
return entry.has(idKey);
|
|
509
|
+
}
|
|
510
|
+
//#endregion
|
|
511
|
+
//#region extensions/telegram/src/target-writeback.ts
|
|
512
|
+
const writebackLogger = createSubsystemLogger("telegram/target-writeback");
|
|
513
|
+
const TELEGRAM_ADMIN_SCOPE = "operator.admin";
|
|
514
|
+
function asObjectRecord(value) {
|
|
515
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) return null;
|
|
516
|
+
return value;
|
|
517
|
+
}
|
|
518
|
+
function normalizeTelegramLookupTargetForMatch(raw) {
|
|
519
|
+
const normalized = normalizeTelegramLookupTarget(raw);
|
|
520
|
+
if (!normalized) return;
|
|
521
|
+
return normalized.startsWith("@") ? normalizeLowercaseStringOrEmpty(normalized) : normalized;
|
|
522
|
+
}
|
|
523
|
+
function normalizeTelegramTargetForMatch(raw) {
|
|
524
|
+
const parsed = parseTelegramTarget(raw);
|
|
525
|
+
const normalized = normalizeTelegramLookupTargetForMatch(parsed.chatId);
|
|
526
|
+
if (!normalized) return;
|
|
527
|
+
return `${normalized}|${parsed.messageThreadId == null ? "" : String(parsed.messageThreadId)}`;
|
|
528
|
+
}
|
|
529
|
+
function buildResolvedTelegramTarget(params) {
|
|
530
|
+
const { raw, parsed, resolvedChatId } = params;
|
|
531
|
+
if (parsed.messageThreadId == null) return resolvedChatId;
|
|
532
|
+
return raw.includes(":topic:") ? `${resolvedChatId}:topic:${parsed.messageThreadId}` : `${resolvedChatId}:${parsed.messageThreadId}`;
|
|
533
|
+
}
|
|
534
|
+
function resolveLegacyRewrite(params) {
|
|
535
|
+
const parsed = parseTelegramTarget(params.raw);
|
|
536
|
+
if (normalizeTelegramChatId(parsed.chatId)) return null;
|
|
537
|
+
const normalized = normalizeTelegramLookupTargetForMatch(parsed.chatId);
|
|
538
|
+
if (!normalized) return null;
|
|
539
|
+
return {
|
|
540
|
+
matchKey: `${normalized}|${parsed.messageThreadId == null ? "" : String(parsed.messageThreadId)}`,
|
|
541
|
+
resolvedTarget: buildResolvedTelegramTarget({
|
|
542
|
+
raw: params.raw,
|
|
543
|
+
parsed,
|
|
544
|
+
resolvedChatId: params.resolvedChatId
|
|
545
|
+
})
|
|
546
|
+
};
|
|
547
|
+
}
|
|
548
|
+
function rewriteTargetIfMatch(params) {
|
|
549
|
+
if (typeof params.rawValue !== "string" && typeof params.rawValue !== "number") return null;
|
|
550
|
+
const value = normalizeOptionalString(String(params.rawValue)) ?? "";
|
|
551
|
+
if (!value) return null;
|
|
552
|
+
if (normalizeTelegramTargetForMatch(value) !== params.matchKey) return null;
|
|
553
|
+
return params.resolvedTarget;
|
|
554
|
+
}
|
|
555
|
+
function replaceTelegramDefaultToTargets(params) {
|
|
556
|
+
let changed = false;
|
|
557
|
+
const telegram = asObjectRecord(params.cfg.channels?.telegram);
|
|
558
|
+
if (!telegram) return changed;
|
|
559
|
+
const maybeReplace = (holder, key) => {
|
|
560
|
+
const nextTarget = rewriteTargetIfMatch({
|
|
561
|
+
rawValue: holder[key],
|
|
562
|
+
matchKey: params.matchKey,
|
|
563
|
+
resolvedTarget: params.resolvedTarget
|
|
564
|
+
});
|
|
565
|
+
if (!nextTarget) return;
|
|
566
|
+
holder[key] = nextTarget;
|
|
567
|
+
changed = true;
|
|
568
|
+
};
|
|
569
|
+
maybeReplace(telegram, "defaultTo");
|
|
570
|
+
const accounts = asObjectRecord(telegram.accounts);
|
|
571
|
+
if (!accounts) return changed;
|
|
572
|
+
for (const accountId of Object.keys(accounts)) {
|
|
573
|
+
const account = asObjectRecord(accounts[accountId]);
|
|
574
|
+
if (!account) continue;
|
|
575
|
+
maybeReplace(account, "defaultTo");
|
|
576
|
+
}
|
|
577
|
+
return changed;
|
|
578
|
+
}
|
|
579
|
+
async function maybePersistResolvedTelegramTarget(params) {
|
|
580
|
+
const raw = params.rawTarget.trim();
|
|
581
|
+
if (!raw) return;
|
|
582
|
+
const rewrite = resolveLegacyRewrite({
|
|
583
|
+
raw,
|
|
584
|
+
resolvedChatId: params.resolvedChatId
|
|
585
|
+
});
|
|
586
|
+
if (!rewrite) return;
|
|
587
|
+
const { matchKey, resolvedTarget } = rewrite;
|
|
588
|
+
if (Array.isArray(params.gatewayClientScopes) && !params.gatewayClientScopes.includes(TELEGRAM_ADMIN_SCOPE)) {
|
|
589
|
+
writebackLogger.warn(`skipping Telegram target writeback for ${raw} because gateway caller is missing ${TELEGRAM_ADMIN_SCOPE}`);
|
|
590
|
+
return;
|
|
591
|
+
}
|
|
592
|
+
try {
|
|
593
|
+
const { snapshot, writeOptions } = await readConfigFileSnapshotForWrite();
|
|
594
|
+
const nextConfig = structuredClone(snapshot.config ?? {});
|
|
595
|
+
if (replaceTelegramDefaultToTargets({
|
|
596
|
+
cfg: nextConfig,
|
|
597
|
+
matchKey,
|
|
598
|
+
resolvedTarget
|
|
599
|
+
})) {
|
|
600
|
+
await replaceConfigFile({
|
|
601
|
+
nextConfig,
|
|
602
|
+
snapshot,
|
|
603
|
+
writeOptions,
|
|
604
|
+
afterWrite: { mode: "auto" }
|
|
605
|
+
});
|
|
606
|
+
if (params.verbose) writebackLogger.warn(`resolved Telegram defaultTo target ${raw} -> ${resolvedTarget}`);
|
|
607
|
+
}
|
|
608
|
+
} catch (err) {
|
|
609
|
+
if (params.verbose) writebackLogger.warn(`failed to persist Telegram defaultTo target ${raw}: ${String(err)}`);
|
|
610
|
+
}
|
|
611
|
+
try {
|
|
612
|
+
const storePath = resolveCronStorePath(params.cfg.cron?.store);
|
|
613
|
+
const store = await loadCronStore(storePath);
|
|
614
|
+
let cronChanged = false;
|
|
615
|
+
for (const job of store.jobs) {
|
|
616
|
+
if (job.delivery?.channel !== "telegram") continue;
|
|
617
|
+
const nextTarget = rewriteTargetIfMatch({
|
|
618
|
+
rawValue: job.delivery.to,
|
|
619
|
+
matchKey,
|
|
620
|
+
resolvedTarget
|
|
621
|
+
});
|
|
622
|
+
if (!nextTarget) continue;
|
|
623
|
+
job.delivery.to = nextTarget;
|
|
624
|
+
cronChanged = true;
|
|
625
|
+
}
|
|
626
|
+
if (cronChanged) {
|
|
627
|
+
await saveCronStore(storePath, store);
|
|
628
|
+
if (params.verbose) writebackLogger.warn(`resolved Telegram cron delivery target ${raw} -> ${resolvedTarget}`);
|
|
629
|
+
}
|
|
630
|
+
} catch (err) {
|
|
631
|
+
if (params.verbose) writebackLogger.warn(`failed to persist Telegram cron target ${raw}: ${String(err)}`);
|
|
632
|
+
}
|
|
633
|
+
}
|
|
634
|
+
//#endregion
|
|
635
|
+
//#region extensions/telegram/src/voice.ts
|
|
636
|
+
function resolveTelegramVoiceDecision(opts) {
|
|
637
|
+
if (!opts.wantsVoice) return { useVoice: false };
|
|
638
|
+
if (isVoiceCompatibleAudio(opts)) return { useVoice: true };
|
|
639
|
+
return {
|
|
640
|
+
useVoice: false,
|
|
641
|
+
reason: `media is ${opts.contentType ?? "unknown"} (${opts.fileName ?? "unknown"})`
|
|
642
|
+
};
|
|
643
|
+
}
|
|
644
|
+
function resolveTelegramVoiceSend(opts) {
|
|
645
|
+
const decision = resolveTelegramVoiceDecision(opts);
|
|
646
|
+
if (decision.reason && opts.logFallback) opts.logFallback(`Telegram voice requested but ${decision.reason}; sending as audio file instead.`);
|
|
647
|
+
return { useVoice: decision.useVoice };
|
|
648
|
+
}
|
|
649
|
+
//#endregion
|
|
650
|
+
//#region extensions/telegram/src/send.ts
|
|
651
|
+
const InputFileCtor = grammy.InputFile;
|
|
652
|
+
const MAX_TELEGRAM_PHOTO_DIMENSION_SUM = 1e4;
|
|
653
|
+
const MAX_TELEGRAM_PHOTO_ASPECT_RATIO = 20;
|
|
654
|
+
function resolveTelegramMessageIdOrThrow(result, context) {
|
|
655
|
+
if (typeof result?.message_id === "number" && Number.isFinite(result.message_id)) return Math.trunc(result.message_id);
|
|
656
|
+
throw new Error(`Telegram ${context} returned no message_id`);
|
|
657
|
+
}
|
|
658
|
+
function splitTelegramPlainTextChunks(text, limit) {
|
|
659
|
+
if (!text) return [];
|
|
660
|
+
const normalizedLimit = Math.max(1, Math.floor(limit));
|
|
661
|
+
const chunks = [];
|
|
662
|
+
for (let start = 0; start < text.length; start += normalizedLimit) chunks.push(text.slice(start, start + normalizedLimit));
|
|
663
|
+
return chunks;
|
|
664
|
+
}
|
|
665
|
+
function splitTelegramPlainTextFallback(text, chunkCount, limit) {
|
|
666
|
+
if (!text) return [];
|
|
667
|
+
const normalizedLimit = Math.max(1, Math.floor(limit));
|
|
668
|
+
const fixedChunks = splitTelegramPlainTextChunks(text, normalizedLimit);
|
|
669
|
+
if (chunkCount <= 1 || fixedChunks.length >= chunkCount) return fixedChunks;
|
|
670
|
+
const chunks = [];
|
|
671
|
+
let offset = 0;
|
|
672
|
+
for (let index = 0; index < chunkCount; index += 1) {
|
|
673
|
+
const remainingChars = text.length - offset;
|
|
674
|
+
const remainingChunks = chunkCount - index;
|
|
675
|
+
const nextChunkLength = remainingChunks === 1 ? remainingChars : Math.min(normalizedLimit, Math.ceil(remainingChars / remainingChunks));
|
|
676
|
+
chunks.push(text.slice(offset, offset + nextChunkLength));
|
|
677
|
+
offset += nextChunkLength;
|
|
678
|
+
}
|
|
679
|
+
return chunks;
|
|
680
|
+
}
|
|
681
|
+
function logTelegramOutboundSendOk(params) {
|
|
682
|
+
const parts = [
|
|
683
|
+
"telegram outbound send ok",
|
|
684
|
+
`accountId=${params.accountId}`,
|
|
685
|
+
`chatId=${params.chatId}`,
|
|
686
|
+
`messageId=${params.messageId}`,
|
|
687
|
+
`operation=${params.operation}`
|
|
688
|
+
];
|
|
689
|
+
if (params.deliveryKind) parts.push(`deliveryKind=${params.deliveryKind}`);
|
|
690
|
+
if (typeof params.messageThreadId === "number") parts.push(`threadId=${params.messageThreadId}`);
|
|
691
|
+
if (typeof params.replyToMessageId === "number") parts.push(`replyToMessageId=${params.replyToMessageId}`);
|
|
692
|
+
if (params.silent === true) parts.push("silent=true");
|
|
693
|
+
if (typeof params.chunkCount === "number") parts.push(`chunkCount=${params.chunkCount}`);
|
|
694
|
+
sendLogger.info(parts.join(" "));
|
|
695
|
+
}
|
|
696
|
+
const PARSE_ERR_RE = /can't parse entities|parse entities|find end of the entity/i;
|
|
697
|
+
const MESSAGE_NOT_MODIFIED_RE = /400:\s*Bad Request:\s*message is not modified|MESSAGE_NOT_MODIFIED/i;
|
|
698
|
+
const MESSAGE_DELETE_NOOP_RE = /message to delete not found|message can't be deleted|MESSAGE_ID_INVALID|MESSAGE_DELETE_FORBIDDEN/i;
|
|
699
|
+
const CHAT_NOT_FOUND_RE = /400: Bad Request: chat not found/i;
|
|
700
|
+
const sendLogger = createSubsystemLogger("telegram/send");
|
|
701
|
+
const diagLogger = createSubsystemLogger("telegram/diagnostic");
|
|
702
|
+
const telegramClientOptionsCache = /* @__PURE__ */ new Map();
|
|
703
|
+
const MAX_TELEGRAM_CLIENT_OPTIONS_CACHE_SIZE = 64;
|
|
704
|
+
function resetTelegramClientOptionsCacheForTests() {
|
|
705
|
+
telegramClientOptionsCache.clear();
|
|
706
|
+
}
|
|
707
|
+
function createTelegramHttpLogger(cfg) {
|
|
708
|
+
if (!isDiagnosticFlagEnabled("telegram.http", cfg)) return () => {};
|
|
709
|
+
return (label, err) => {
|
|
710
|
+
if (!(err instanceof HttpError)) return;
|
|
711
|
+
const detail = redactSensitiveText(formatUncaughtError(err.error ?? err));
|
|
712
|
+
diagLogger.warn(`telegram http error (${label}): ${detail}`);
|
|
713
|
+
};
|
|
714
|
+
}
|
|
715
|
+
function shouldUseTelegramClientOptionsCache() {
|
|
716
|
+
return !process.env.VITEST && true;
|
|
717
|
+
}
|
|
718
|
+
function buildTelegramClientOptionsCacheKey(params) {
|
|
719
|
+
const proxyKey = params.account.config.proxy?.trim() ?? "";
|
|
720
|
+
const autoSelectFamily = params.account.config.network?.autoSelectFamily;
|
|
721
|
+
const autoSelectFamilyKey = typeof autoSelectFamily === "boolean" ? String(autoSelectFamily) : "default";
|
|
722
|
+
const dnsResultOrderKey = params.account.config.network?.dnsResultOrder ?? "default";
|
|
723
|
+
const apiRootKey = params.account.config.apiRoot?.trim() ?? "";
|
|
724
|
+
const timeoutSecondsKey = typeof params.timeoutSeconds === "number" ? String(params.timeoutSeconds) : "default";
|
|
725
|
+
return `${params.account.accountId}::${proxyKey}::${autoSelectFamilyKey}::${dnsResultOrderKey}::${apiRootKey}::${timeoutSecondsKey}`;
|
|
726
|
+
}
|
|
727
|
+
function setCachedTelegramClientOptions(cacheKey, clientOptions) {
|
|
728
|
+
telegramClientOptionsCache.set(cacheKey, clientOptions);
|
|
729
|
+
if (telegramClientOptionsCache.size > MAX_TELEGRAM_CLIENT_OPTIONS_CACHE_SIZE) {
|
|
730
|
+
const oldestKey = telegramClientOptionsCache.keys().next().value;
|
|
731
|
+
if (oldestKey !== void 0) telegramClientOptionsCache.delete(oldestKey);
|
|
732
|
+
}
|
|
733
|
+
return clientOptions;
|
|
734
|
+
}
|
|
735
|
+
function resolveTelegramClientOptions(account) {
|
|
736
|
+
const timeoutSeconds = typeof account.config.timeoutSeconds === "number" && Number.isFinite(account.config.timeoutSeconds) ? Math.max(1, Math.floor(account.config.timeoutSeconds)) : void 0;
|
|
737
|
+
const cacheKey = shouldUseTelegramClientOptionsCache() ? buildTelegramClientOptionsCacheKey({
|
|
738
|
+
account,
|
|
739
|
+
timeoutSeconds
|
|
740
|
+
}) : null;
|
|
741
|
+
if (cacheKey && telegramClientOptionsCache.has(cacheKey)) return telegramClientOptionsCache.get(cacheKey);
|
|
742
|
+
const proxyUrl = normalizeOptionalString(account.config.proxy);
|
|
743
|
+
const proxyFetch = proxyUrl ? makeProxyFetch(proxyUrl) : void 0;
|
|
744
|
+
const apiRoot = normalizeOptionalString(account.config.apiRoot);
|
|
745
|
+
const normalizedApiRoot = apiRoot ? normalizeTelegramApiRoot(apiRoot) : void 0;
|
|
746
|
+
const transport = resolveTelegramTransport(proxyFetch, { network: account.config.network });
|
|
747
|
+
const fetchImpl = createTelegramClientFetch({
|
|
748
|
+
fetchImpl: asTelegramClientFetch(transport.fetch),
|
|
749
|
+
timeoutSeconds,
|
|
750
|
+
transport
|
|
751
|
+
});
|
|
752
|
+
const clientOptions = fetchImpl || timeoutSeconds || normalizedApiRoot ? {
|
|
753
|
+
...fetchImpl ? { fetch: asTelegramClientFetch(fetchImpl) } : {},
|
|
754
|
+
...timeoutSeconds ? { timeoutSeconds } : {},
|
|
755
|
+
...normalizedApiRoot ? { apiRoot: normalizedApiRoot } : {}
|
|
756
|
+
} : void 0;
|
|
757
|
+
if (cacheKey) return setCachedTelegramClientOptions(cacheKey, clientOptions);
|
|
758
|
+
return clientOptions;
|
|
759
|
+
}
|
|
760
|
+
function resolveToken(explicit, params) {
|
|
761
|
+
if (explicit?.trim()) return explicit.trim();
|
|
762
|
+
if (!params.token) throw new Error(`Telegram bot token missing for account "${params.accountId}" (set channels.telegram.accounts.${params.accountId}.botToken/tokenFile or TELEGRAM_BOT_TOKEN for default).`);
|
|
763
|
+
return params.token.trim();
|
|
764
|
+
}
|
|
765
|
+
async function resolveChatId(to, params) {
|
|
766
|
+
const numericChatId = normalizeTelegramChatId(to);
|
|
767
|
+
if (numericChatId) return numericChatId;
|
|
768
|
+
const lookupTarget = normalizeTelegramLookupTarget(to);
|
|
769
|
+
const getChat = params.api.getChat;
|
|
770
|
+
if (!lookupTarget || typeof getChat !== "function") throw new Error("Telegram recipient must be a numeric chat ID");
|
|
771
|
+
try {
|
|
772
|
+
const chat = await getChat.call(params.api, lookupTarget);
|
|
773
|
+
const resolved = normalizeTelegramChatId(String(chat?.id ?? ""));
|
|
774
|
+
if (!resolved) throw new Error(`resolved chat id is not numeric (${String(chat?.id ?? "")})`);
|
|
775
|
+
if (params.verbose) sendLogger.warn(`telegram recipient ${lookupTarget} resolved to numeric chat id ${resolved}`);
|
|
776
|
+
return resolved;
|
|
777
|
+
} catch (err) {
|
|
778
|
+
const detail = formatErrorMessage(err);
|
|
779
|
+
throw new Error(`Telegram recipient ${lookupTarget} could not be resolved to a numeric chat ID (${detail})`, { cause: err });
|
|
780
|
+
}
|
|
781
|
+
}
|
|
782
|
+
async function resolveAndPersistChatId(params) {
|
|
783
|
+
const chatId = await resolveChatId(params.lookupTarget, {
|
|
784
|
+
api: params.api,
|
|
785
|
+
verbose: params.verbose
|
|
786
|
+
});
|
|
787
|
+
await maybePersistResolvedTelegramTarget({
|
|
788
|
+
cfg: params.cfg,
|
|
789
|
+
rawTarget: params.persistTarget,
|
|
790
|
+
resolvedChatId: chatId,
|
|
791
|
+
verbose: params.verbose,
|
|
792
|
+
gatewayClientScopes: params.gatewayClientScopes
|
|
793
|
+
});
|
|
794
|
+
return chatId;
|
|
795
|
+
}
|
|
796
|
+
function normalizeMessageId(raw) {
|
|
797
|
+
if (typeof raw === "number" && Number.isFinite(raw)) return Math.trunc(raw);
|
|
798
|
+
if (typeof raw === "string") {
|
|
799
|
+
const value = raw.trim();
|
|
800
|
+
if (!value) throw new Error("Message id is required for Telegram actions");
|
|
801
|
+
const parsed = Number.parseInt(value, 10);
|
|
802
|
+
if (Number.isFinite(parsed)) return parsed;
|
|
803
|
+
}
|
|
804
|
+
throw new Error("Message id is required for Telegram actions");
|
|
805
|
+
}
|
|
806
|
+
function isTelegramMessageNotModifiedError(err) {
|
|
807
|
+
return MESSAGE_NOT_MODIFIED_RE.test(formatErrorMessage(err));
|
|
808
|
+
}
|
|
809
|
+
function isTelegramMessageDeleteNoopError(err) {
|
|
810
|
+
return MESSAGE_DELETE_NOOP_RE.test(formatErrorMessage(err));
|
|
811
|
+
}
|
|
812
|
+
function isTelegramHtmlParseError(err) {
|
|
813
|
+
return PARSE_ERR_RE.test(formatErrorMessage(err));
|
|
814
|
+
}
|
|
815
|
+
async function withTelegramHtmlParseFallback(params) {
|
|
816
|
+
try {
|
|
817
|
+
return await params.requestHtml(params.label);
|
|
818
|
+
} catch (err) {
|
|
819
|
+
if (!isTelegramHtmlParseError(err)) throw err;
|
|
820
|
+
if (params.verbose) sendLogger.warn(`telegram ${params.label} failed with HTML parse error, retrying as plain text: ${formatErrorMessage(err)}`);
|
|
821
|
+
return await params.requestPlain(`${params.label}-plain`);
|
|
822
|
+
}
|
|
823
|
+
}
|
|
824
|
+
function resolveTelegramApiContext(opts) {
|
|
825
|
+
const cfg = requireRuntimeConfig(opts.cfg, "Telegram API context");
|
|
826
|
+
const account = resolveTelegramAccount({
|
|
827
|
+
cfg,
|
|
828
|
+
accountId: opts.accountId
|
|
829
|
+
});
|
|
830
|
+
const token = resolveToken(opts.token, account);
|
|
831
|
+
const client = resolveTelegramClientOptions(account);
|
|
832
|
+
let api;
|
|
833
|
+
if (opts.api) api = opts.api;
|
|
834
|
+
else {
|
|
835
|
+
const bot = new Bot(token, client ? { client } : void 0);
|
|
836
|
+
bot.api.config.use(getOrCreateAccountThrottler(token));
|
|
837
|
+
api = bot.api;
|
|
838
|
+
}
|
|
839
|
+
return {
|
|
840
|
+
cfg,
|
|
841
|
+
account,
|
|
842
|
+
api
|
|
843
|
+
};
|
|
844
|
+
}
|
|
845
|
+
function createTelegramRequestWithDiag(params) {
|
|
846
|
+
const request = createChannelApiRetryRunner({
|
|
847
|
+
retry: params.retry,
|
|
848
|
+
configRetry: params.account.config.retry,
|
|
849
|
+
verbose: params.verbose,
|
|
850
|
+
...params.shouldRetry ? { shouldRetry: params.shouldRetry } : {},
|
|
851
|
+
...params.strictShouldRetry ? { strictShouldRetry: true } : {}
|
|
852
|
+
});
|
|
853
|
+
const logHttpError = createTelegramHttpLogger(params.cfg);
|
|
854
|
+
return (fn, label, options) => {
|
|
855
|
+
const runRequest = () => request(fn, label);
|
|
856
|
+
return (params.useApiErrorLogging === false ? runRequest() : withTelegramApiErrorLogging({
|
|
857
|
+
operation: label ?? "request",
|
|
858
|
+
fn: runRequest,
|
|
859
|
+
...options?.shouldLog ? { shouldLog: options.shouldLog } : {}
|
|
860
|
+
})).catch((err) => {
|
|
861
|
+
logHttpError(label ?? "request", err);
|
|
862
|
+
throw err;
|
|
863
|
+
});
|
|
864
|
+
};
|
|
865
|
+
}
|
|
866
|
+
function wrapTelegramChatNotFoundError(err, params) {
|
|
867
|
+
const errorMsg = formatErrorMessage(err);
|
|
868
|
+
if (/403.*(bot.*not.*member|bot.*blocked|bot.*kicked)/i.test(errorMsg)) return new Error([
|
|
869
|
+
`Telegram send failed: bot is not a member of the chat, was blocked, or was kicked (chat_id=${params.chatId}).`,
|
|
870
|
+
`Telegram API said: ${errorMsg}.`,
|
|
871
|
+
"Fix: Add the bot to the channel/group, or ensure it has not been removed/blocked/kicked by the user.",
|
|
872
|
+
`Input was: ${JSON.stringify(params.input)}.`
|
|
873
|
+
].join(" "));
|
|
874
|
+
if (!CHAT_NOT_FOUND_RE.test(errorMsg)) return err;
|
|
875
|
+
return new Error([
|
|
876
|
+
`Telegram send failed: chat not found (chat_id=${params.chatId}).`,
|
|
877
|
+
"Likely: bot not started in DM, bot removed from group/channel, group migrated (new -100… id), or wrong bot token.",
|
|
878
|
+
`Input was: ${JSON.stringify(params.input)}.`
|
|
879
|
+
].join(" "));
|
|
880
|
+
}
|
|
881
|
+
function createRequestWithChatNotFound(params) {
|
|
882
|
+
return async (fn, label) => params.requestWithDiag(fn, label).catch((err) => {
|
|
883
|
+
throw wrapTelegramChatNotFoundError(err, {
|
|
884
|
+
chatId: params.chatId,
|
|
885
|
+
input: params.input
|
|
886
|
+
});
|
|
887
|
+
});
|
|
888
|
+
}
|
|
889
|
+
function createTelegramNonIdempotentRequestWithDiag(params) {
|
|
890
|
+
return createTelegramRequestWithDiag({
|
|
891
|
+
cfg: params.cfg,
|
|
892
|
+
account: params.account,
|
|
893
|
+
retry: params.retry,
|
|
894
|
+
verbose: params.verbose,
|
|
895
|
+
useApiErrorLogging: params.useApiErrorLogging,
|
|
896
|
+
shouldRetry: (err) => isSafeToRetrySendError(err) || isTelegramRateLimitError(err),
|
|
897
|
+
strictShouldRetry: true
|
|
898
|
+
});
|
|
899
|
+
}
|
|
900
|
+
async function sendMessageTelegram(to, text, opts) {
|
|
901
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
902
|
+
const target = parseTelegramTarget(to);
|
|
903
|
+
const chatId = await resolveAndPersistChatId({
|
|
904
|
+
cfg,
|
|
905
|
+
api,
|
|
906
|
+
lookupTarget: target.chatId,
|
|
907
|
+
persistTarget: to,
|
|
908
|
+
verbose: opts.verbose,
|
|
909
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
910
|
+
});
|
|
911
|
+
const mediaUrl = opts.mediaUrl?.trim();
|
|
912
|
+
const mediaMaxBytes = opts.maxBytes ?? (typeof account.config.mediaMaxMb === "number" ? account.config.mediaMaxMb : 100) * 1024 * 1024;
|
|
913
|
+
const replyMarkup = buildInlineKeyboard(opts.buttons);
|
|
914
|
+
const threadParams = buildTelegramThreadReplyParams({
|
|
915
|
+
thread: resolveTelegramSendThreadSpec({
|
|
916
|
+
targetMessageThreadId: target.messageThreadId,
|
|
917
|
+
messageThreadId: opts.messageThreadId,
|
|
918
|
+
chatType: target.chatType
|
|
919
|
+
}),
|
|
920
|
+
replyToMessageId: opts.replyToMessageId,
|
|
921
|
+
replyQuoteText: opts.quoteText,
|
|
922
|
+
useReplyIdAsQuoteSource: true
|
|
923
|
+
});
|
|
924
|
+
const hasThreadParams = Object.keys(threadParams).length > 0;
|
|
925
|
+
const requestWithChatNotFound = createRequestWithChatNotFound({
|
|
926
|
+
requestWithDiag: createTelegramNonIdempotentRequestWithDiag({
|
|
927
|
+
cfg,
|
|
928
|
+
account,
|
|
929
|
+
retry: opts.retry,
|
|
930
|
+
verbose: opts.verbose
|
|
931
|
+
}),
|
|
932
|
+
chatId,
|
|
933
|
+
input: to
|
|
934
|
+
});
|
|
935
|
+
const textMode = opts.textMode ?? "markdown";
|
|
936
|
+
const tableMode = resolveMarkdownTableMode({
|
|
937
|
+
cfg,
|
|
938
|
+
channel: "telegram",
|
|
939
|
+
accountId: account.accountId
|
|
940
|
+
});
|
|
941
|
+
const renderHtmlText = (value) => renderTelegramHtmlText(value, {
|
|
942
|
+
textMode,
|
|
943
|
+
tableMode
|
|
944
|
+
});
|
|
945
|
+
const linkPreviewOptions = account.config.linkPreview ?? true ? void 0 : { is_disabled: true };
|
|
946
|
+
const sendTelegramTextChunk = async (chunk, params) => {
|
|
947
|
+
const baseParams = params ? { ...params } : {};
|
|
948
|
+
if (linkPreviewOptions) baseParams.link_preview_options = linkPreviewOptions;
|
|
949
|
+
const plainParams = {
|
|
950
|
+
...baseParams,
|
|
951
|
+
...opts.silent === true ? { disable_notification: true } : {}
|
|
952
|
+
};
|
|
953
|
+
const hasPlainParams = Object.keys(plainParams).length > 0;
|
|
954
|
+
const requestPlain = (label) => requestWithChatNotFound(() => hasPlainParams ? api.sendMessage(chatId, chunk.plainText, plainParams) : api.sendMessage(chatId, chunk.plainText), label);
|
|
955
|
+
return {
|
|
956
|
+
result: !chunk.htmlText ? await requestPlain("message") : await withTelegramHtmlParseFallback({
|
|
957
|
+
label: "message",
|
|
958
|
+
verbose: opts.verbose,
|
|
959
|
+
requestHtml: (label) => requestWithChatNotFound(() => api.sendMessage(chatId, chunk.htmlText ?? chunk.plainText, {
|
|
960
|
+
parse_mode: "HTML",
|
|
961
|
+
...plainParams
|
|
962
|
+
}), label),
|
|
963
|
+
requestPlain
|
|
964
|
+
}),
|
|
965
|
+
acceptedParams: params
|
|
966
|
+
};
|
|
967
|
+
};
|
|
968
|
+
const buildTextParams = (isLastChunk) => hasThreadParams || isLastChunk && replyMarkup ? {
|
|
969
|
+
...threadParams,
|
|
970
|
+
...isLastChunk && replyMarkup ? { reply_markup: replyMarkup } : {}
|
|
971
|
+
} : void 0;
|
|
972
|
+
const sendTelegramTextChunks = async (chunks, context) => {
|
|
973
|
+
let lastMessageId = "";
|
|
974
|
+
let lastChatId = chatId;
|
|
975
|
+
let lastAcceptedParams;
|
|
976
|
+
let sentChunkCount = 0;
|
|
977
|
+
for (let index = 0; index < chunks.length; index += 1) {
|
|
978
|
+
const chunk = chunks[index];
|
|
979
|
+
if (!chunk) continue;
|
|
980
|
+
const { result: res, acceptedParams } = await sendTelegramTextChunk(chunk, buildTextParams(index === chunks.length - 1));
|
|
981
|
+
const messageId = resolveTelegramMessageIdOrThrow(res, context);
|
|
982
|
+
recordSentMessage(chatId, messageId, cfg);
|
|
983
|
+
lastMessageId = String(messageId);
|
|
984
|
+
lastChatId = String(res?.chat?.id ?? chatId);
|
|
985
|
+
lastAcceptedParams = acceptedParams;
|
|
986
|
+
sentChunkCount += 1;
|
|
987
|
+
}
|
|
988
|
+
if (lastMessageId) logTelegramOutboundSendOk({
|
|
989
|
+
accountId: account.accountId,
|
|
990
|
+
chatId: lastChatId,
|
|
991
|
+
messageId: lastMessageId,
|
|
992
|
+
operation: "sendMessage",
|
|
993
|
+
deliveryKind: "text",
|
|
994
|
+
messageThreadId: lastAcceptedParams?.message_thread_id,
|
|
995
|
+
replyToMessageId: opts.replyToMessageId,
|
|
996
|
+
silent: opts.silent,
|
|
997
|
+
chunkCount: sentChunkCount
|
|
998
|
+
});
|
|
999
|
+
return {
|
|
1000
|
+
messageId: lastMessageId,
|
|
1001
|
+
chatId: lastChatId
|
|
1002
|
+
};
|
|
1003
|
+
};
|
|
1004
|
+
const buildChunkedTextPlan = (rawText, context) => {
|
|
1005
|
+
const htmlText = renderHtmlText(rawText);
|
|
1006
|
+
const fallbackText = opts.plainText ?? (textMode === "html" ? telegramHtmlToPlainTextFallback(htmlText) : rawText);
|
|
1007
|
+
let htmlChunks;
|
|
1008
|
+
try {
|
|
1009
|
+
htmlChunks = splitTelegramHtmlChunks(htmlText, 4e3);
|
|
1010
|
+
} catch (error) {
|
|
1011
|
+
logVerbose(`telegram ${context} failed HTML chunk planning, retrying as plain text: ${formatErrorMessage(error)}`);
|
|
1012
|
+
return splitTelegramPlainTextChunks(fallbackText, 4e3).map((plainText) => ({ plainText }));
|
|
1013
|
+
}
|
|
1014
|
+
const fixedPlainTextChunks = splitTelegramPlainTextChunks(fallbackText, 4e3);
|
|
1015
|
+
if (fixedPlainTextChunks.length > htmlChunks.length) {
|
|
1016
|
+
logVerbose(`telegram ${context} plain-text fallback needs more chunks than HTML; sending plain text`);
|
|
1017
|
+
return fixedPlainTextChunks.map((plainText) => ({ plainText }));
|
|
1018
|
+
}
|
|
1019
|
+
const plainTextChunks = splitTelegramPlainTextFallback(fallbackText, htmlChunks.length, 4e3);
|
|
1020
|
+
return htmlChunks.map((htmlText, index) => ({
|
|
1021
|
+
htmlText,
|
|
1022
|
+
plainText: plainTextChunks[index] ?? htmlText
|
|
1023
|
+
}));
|
|
1024
|
+
};
|
|
1025
|
+
const sendChunkedText = async (rawText, context) => await sendTelegramTextChunks(buildChunkedTextPlan(rawText, context), context);
|
|
1026
|
+
async function shouldSendTelegramImageAsPhoto(buffer) {
|
|
1027
|
+
try {
|
|
1028
|
+
const metadata = await getImageMetadata(buffer);
|
|
1029
|
+
const width = metadata?.width;
|
|
1030
|
+
const height = metadata?.height;
|
|
1031
|
+
if (typeof width !== "number" || typeof height !== "number") {
|
|
1032
|
+
sendLogger.warn("Photo dimensions are unavailable. Sending as document instead.");
|
|
1033
|
+
return false;
|
|
1034
|
+
}
|
|
1035
|
+
const shorterSide = Math.min(width, height);
|
|
1036
|
+
const longerSide = Math.max(width, height);
|
|
1037
|
+
if (!(width + height <= MAX_TELEGRAM_PHOTO_DIMENSION_SUM && shorterSide > 0 && longerSide <= shorterSide * MAX_TELEGRAM_PHOTO_ASPECT_RATIO)) {
|
|
1038
|
+
sendLogger.warn(`Photo dimensions (${width}x${height}) are not valid for Telegram photos. Sending as document instead.`);
|
|
1039
|
+
return false;
|
|
1040
|
+
}
|
|
1041
|
+
return true;
|
|
1042
|
+
} catch (err) {
|
|
1043
|
+
sendLogger.warn(`Failed to validate photo dimensions: ${formatErrorMessage(err)}. Sending as document instead.`);
|
|
1044
|
+
return false;
|
|
1045
|
+
}
|
|
1046
|
+
}
|
|
1047
|
+
if (mediaUrl) {
|
|
1048
|
+
const media = await loadWebMedia(mediaUrl, buildOutboundMediaLoadOptions({
|
|
1049
|
+
maxBytes: mediaMaxBytes,
|
|
1050
|
+
mediaLocalRoots: opts.mediaLocalRoots,
|
|
1051
|
+
mediaReadFile: opts.mediaReadFile,
|
|
1052
|
+
optimizeImages: opts.forceDocument ? false : void 0
|
|
1053
|
+
}));
|
|
1054
|
+
const kind = kindFromMime(media.contentType ?? void 0);
|
|
1055
|
+
const isGif = isGifMedia({
|
|
1056
|
+
contentType: media.contentType,
|
|
1057
|
+
fileName: media.fileName
|
|
1058
|
+
});
|
|
1059
|
+
let sendImageAsPhoto = true;
|
|
1060
|
+
const deliveryKind = opts.forceDocument === true && (kind === "image" || kind === "video") ? "document" : kind;
|
|
1061
|
+
if (deliveryKind === "image" && !isGif) sendImageAsPhoto = await shouldSendTelegramImageAsPhoto(media.buffer);
|
|
1062
|
+
const isVideoNote = deliveryKind === "video" && opts.asVideoNote === true;
|
|
1063
|
+
const fileName = media.fileName ?? (isGif ? "animation.gif" : inferFilename(kind ?? "document")) ?? "file";
|
|
1064
|
+
const file = new InputFileCtor(media.buffer, fileName);
|
|
1065
|
+
let caption;
|
|
1066
|
+
let followUpText;
|
|
1067
|
+
if (isVideoNote) {
|
|
1068
|
+
caption = void 0;
|
|
1069
|
+
followUpText = text.trim() ? text : void 0;
|
|
1070
|
+
} else {
|
|
1071
|
+
const split = splitTelegramCaption(text);
|
|
1072
|
+
caption = split.caption;
|
|
1073
|
+
followUpText = split.followUpText;
|
|
1074
|
+
}
|
|
1075
|
+
const htmlCaption = caption ? renderHtmlText(caption) : void 0;
|
|
1076
|
+
const needsSeparateText = Boolean(followUpText);
|
|
1077
|
+
const baseMediaParams = {
|
|
1078
|
+
...hasThreadParams ? threadParams : {},
|
|
1079
|
+
...!needsSeparateText && replyMarkup ? { reply_markup: replyMarkup } : {}
|
|
1080
|
+
};
|
|
1081
|
+
const videoDimensions = deliveryKind === "video" && !isVideoNote ? await probeVideoDimensions(media.buffer) : void 0;
|
|
1082
|
+
const mediaParams = {
|
|
1083
|
+
...htmlCaption ? {
|
|
1084
|
+
caption: htmlCaption,
|
|
1085
|
+
parse_mode: "HTML"
|
|
1086
|
+
} : {},
|
|
1087
|
+
...baseMediaParams,
|
|
1088
|
+
...opts.silent === true ? { disable_notification: true } : {},
|
|
1089
|
+
...videoDimensions ? {
|
|
1090
|
+
width: videoDimensions.width,
|
|
1091
|
+
height: videoDimensions.height
|
|
1092
|
+
} : {}
|
|
1093
|
+
};
|
|
1094
|
+
const sendMedia = async (label, sender) => await requestWithChatNotFound(() => sender(mediaParams), label);
|
|
1095
|
+
const mediaSender = (() => {
|
|
1096
|
+
if (isGif && deliveryKind !== "document") return {
|
|
1097
|
+
label: "animation",
|
|
1098
|
+
sender: (effectiveParams) => api.sendAnimation(chatId, file, effectiveParams)
|
|
1099
|
+
};
|
|
1100
|
+
if (deliveryKind === "image" && !isGif && sendImageAsPhoto) return {
|
|
1101
|
+
label: "photo",
|
|
1102
|
+
sender: (effectiveParams) => api.sendPhoto(chatId, file, effectiveParams)
|
|
1103
|
+
};
|
|
1104
|
+
if (deliveryKind === "video") {
|
|
1105
|
+
if (isVideoNote) return {
|
|
1106
|
+
label: "video_note",
|
|
1107
|
+
sender: (effectiveParams) => api.sendVideoNote(chatId, file, effectiveParams)
|
|
1108
|
+
};
|
|
1109
|
+
return {
|
|
1110
|
+
label: "video",
|
|
1111
|
+
sender: (effectiveParams) => api.sendVideo(chatId, file, effectiveParams)
|
|
1112
|
+
};
|
|
1113
|
+
}
|
|
1114
|
+
if (kind === "audio") {
|
|
1115
|
+
const { useVoice } = resolveTelegramVoiceSend({
|
|
1116
|
+
wantsVoice: opts.asVoice === true,
|
|
1117
|
+
contentType: media.contentType,
|
|
1118
|
+
fileName,
|
|
1119
|
+
logFallback: logVerbose
|
|
1120
|
+
});
|
|
1121
|
+
if (useVoice) return {
|
|
1122
|
+
label: "voice",
|
|
1123
|
+
sender: (effectiveParams) => api.sendVoice(chatId, file, effectiveParams)
|
|
1124
|
+
};
|
|
1125
|
+
return {
|
|
1126
|
+
label: "audio",
|
|
1127
|
+
sender: (effectiveParams) => api.sendAudio(chatId, file, effectiveParams)
|
|
1128
|
+
};
|
|
1129
|
+
}
|
|
1130
|
+
return {
|
|
1131
|
+
label: "document",
|
|
1132
|
+
sender: (effectiveParams) => api.sendDocument(chatId, file, opts.forceDocument ? {
|
|
1133
|
+
...effectiveParams,
|
|
1134
|
+
disable_content_type_detection: true
|
|
1135
|
+
} : effectiveParams)
|
|
1136
|
+
};
|
|
1137
|
+
})();
|
|
1138
|
+
const result = await sendMedia(mediaSender.label, mediaSender.sender);
|
|
1139
|
+
const mediaMessageId = resolveTelegramMessageIdOrThrow(result, "media send");
|
|
1140
|
+
const resolvedChatId = String(result?.chat?.id ?? chatId);
|
|
1141
|
+
recordSentMessage(chatId, mediaMessageId, cfg);
|
|
1142
|
+
logTelegramOutboundSendOk({
|
|
1143
|
+
accountId: account.accountId,
|
|
1144
|
+
chatId: resolvedChatId,
|
|
1145
|
+
messageId: String(mediaMessageId),
|
|
1146
|
+
operation: `send${mediaSender.label.split("_").map((part) => part.charAt(0).toUpperCase() + part.slice(1)).join("")}`,
|
|
1147
|
+
deliveryKind: mediaSender.label,
|
|
1148
|
+
messageThreadId: mediaParams.message_thread_id,
|
|
1149
|
+
replyToMessageId: opts.replyToMessageId,
|
|
1150
|
+
silent: opts.silent
|
|
1151
|
+
});
|
|
1152
|
+
recordChannelActivity({
|
|
1153
|
+
channel: "telegram",
|
|
1154
|
+
accountId: account.accountId,
|
|
1155
|
+
direction: "outbound"
|
|
1156
|
+
});
|
|
1157
|
+
if (needsSeparateText && followUpText) return {
|
|
1158
|
+
messageId: (await sendChunkedText(followUpText, "text follow-up send")).messageId,
|
|
1159
|
+
chatId: resolvedChatId
|
|
1160
|
+
};
|
|
1161
|
+
return {
|
|
1162
|
+
messageId: String(mediaMessageId),
|
|
1163
|
+
chatId: resolvedChatId
|
|
1164
|
+
};
|
|
1165
|
+
}
|
|
1166
|
+
if (!text || !text.trim()) throw new Error("Message must be non-empty for Telegram sends");
|
|
1167
|
+
const textResult = await sendChunkedText(text, "text send");
|
|
1168
|
+
recordChannelActivity({
|
|
1169
|
+
channel: "telegram",
|
|
1170
|
+
accountId: account.accountId,
|
|
1171
|
+
direction: "outbound"
|
|
1172
|
+
});
|
|
1173
|
+
return textResult;
|
|
1174
|
+
}
|
|
1175
|
+
async function sendTypingTelegram(to, opts) {
|
|
1176
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1177
|
+
const target = parseTelegramTarget(to);
|
|
1178
|
+
const chatId = await resolveAndPersistChatId({
|
|
1179
|
+
cfg,
|
|
1180
|
+
api,
|
|
1181
|
+
lookupTarget: target.chatId,
|
|
1182
|
+
persistTarget: to,
|
|
1183
|
+
verbose: opts.verbose
|
|
1184
|
+
});
|
|
1185
|
+
const requestWithDiag = createTelegramRequestWithDiag({
|
|
1186
|
+
cfg,
|
|
1187
|
+
account,
|
|
1188
|
+
retry: opts.retry,
|
|
1189
|
+
verbose: opts.verbose,
|
|
1190
|
+
shouldRetry: (err) => isRecoverableTelegramNetworkError(err, { context: "send" })
|
|
1191
|
+
});
|
|
1192
|
+
const threadParams = buildTypingThreadParams(target.messageThreadId ?? opts.messageThreadId);
|
|
1193
|
+
await requestWithDiag(() => api.sendChatAction(chatId, "typing", threadParams), "typing");
|
|
1194
|
+
return { ok: true };
|
|
1195
|
+
}
|
|
1196
|
+
async function reactMessageTelegram(chatIdInput, messageIdInput, emoji, opts) {
|
|
1197
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1198
|
+
const rawTarget = String(chatIdInput);
|
|
1199
|
+
const chatId = await resolveAndPersistChatId({
|
|
1200
|
+
cfg,
|
|
1201
|
+
api,
|
|
1202
|
+
lookupTarget: rawTarget,
|
|
1203
|
+
persistTarget: rawTarget,
|
|
1204
|
+
verbose: opts.verbose,
|
|
1205
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1206
|
+
});
|
|
1207
|
+
const messageId = normalizeMessageId(messageIdInput);
|
|
1208
|
+
const requestWithDiag = createTelegramRequestWithDiag({
|
|
1209
|
+
cfg,
|
|
1210
|
+
account,
|
|
1211
|
+
retry: opts.retry,
|
|
1212
|
+
verbose: opts.verbose,
|
|
1213
|
+
shouldRetry: (err) => isRecoverableTelegramNetworkError(err, { context: "send" })
|
|
1214
|
+
});
|
|
1215
|
+
const remove = opts.remove === true;
|
|
1216
|
+
const trimmedEmoji = emoji.trim();
|
|
1217
|
+
const reactions = remove || !trimmedEmoji ? [] : [{
|
|
1218
|
+
type: "emoji",
|
|
1219
|
+
emoji: trimmedEmoji
|
|
1220
|
+
}];
|
|
1221
|
+
if (typeof api.setMessageReaction !== "function") throw new Error("Telegram reactions are unavailable in this bot API.");
|
|
1222
|
+
try {
|
|
1223
|
+
await requestWithDiag(() => api.setMessageReaction(chatId, messageId, reactions), "reaction");
|
|
1224
|
+
} catch (err) {
|
|
1225
|
+
const msg = formatErrorMessage(err);
|
|
1226
|
+
if (/REACTION_INVALID/i.test(msg)) return {
|
|
1227
|
+
ok: false,
|
|
1228
|
+
warning: `Reaction unavailable: ${trimmedEmoji}`
|
|
1229
|
+
};
|
|
1230
|
+
throw err;
|
|
1231
|
+
}
|
|
1232
|
+
return { ok: true };
|
|
1233
|
+
}
|
|
1234
|
+
async function deleteMessageTelegram(chatIdInput, messageIdInput, opts) {
|
|
1235
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1236
|
+
const rawTarget = String(chatIdInput);
|
|
1237
|
+
const chatId = await resolveAndPersistChatId({
|
|
1238
|
+
cfg,
|
|
1239
|
+
api,
|
|
1240
|
+
lookupTarget: rawTarget,
|
|
1241
|
+
persistTarget: rawTarget,
|
|
1242
|
+
verbose: opts.verbose,
|
|
1243
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1244
|
+
});
|
|
1245
|
+
const messageId = normalizeMessageId(messageIdInput);
|
|
1246
|
+
const requestWithDiag = createTelegramRequestWithDiag({
|
|
1247
|
+
cfg,
|
|
1248
|
+
account,
|
|
1249
|
+
retry: opts.retry,
|
|
1250
|
+
verbose: opts.verbose,
|
|
1251
|
+
shouldRetry: (err) => isRecoverableTelegramNetworkError(err, { context: "send" })
|
|
1252
|
+
});
|
|
1253
|
+
try {
|
|
1254
|
+
await requestWithDiag(() => api.deleteMessage(chatId, messageId), "deleteMessage", { shouldLog: (err) => !isTelegramMessageDeleteNoopError(err) });
|
|
1255
|
+
} catch (err) {
|
|
1256
|
+
if (!isTelegramMessageDeleteNoopError(err)) throw err;
|
|
1257
|
+
const detail = formatErrorMessage(err);
|
|
1258
|
+
logVerbose(`[telegram] Delete skipped for message ${messageId} in chat ${chatId}: ${detail}`);
|
|
1259
|
+
return {
|
|
1260
|
+
ok: false,
|
|
1261
|
+
warning: `Message ${messageId} was not deleted: ${detail}`
|
|
1262
|
+
};
|
|
1263
|
+
}
|
|
1264
|
+
logVerbose(`[telegram] Deleted message ${messageId} from chat ${chatId}`);
|
|
1265
|
+
return { ok: true };
|
|
1266
|
+
}
|
|
1267
|
+
async function pinMessageTelegram(chatIdInput, messageIdInput, opts) {
|
|
1268
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1269
|
+
const rawTarget = String(chatIdInput);
|
|
1270
|
+
const chatId = await resolveAndPersistChatId({
|
|
1271
|
+
cfg,
|
|
1272
|
+
api,
|
|
1273
|
+
lookupTarget: rawTarget,
|
|
1274
|
+
persistTarget: rawTarget,
|
|
1275
|
+
verbose: opts.verbose,
|
|
1276
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1277
|
+
});
|
|
1278
|
+
const messageId = normalizeMessageId(messageIdInput);
|
|
1279
|
+
await createTelegramRequestWithDiag({
|
|
1280
|
+
cfg,
|
|
1281
|
+
account,
|
|
1282
|
+
retry: opts.retry,
|
|
1283
|
+
verbose: opts.verbose
|
|
1284
|
+
})(() => api.pinChatMessage(chatId, messageId, { disable_notification: opts.notify !== true }), "pinChatMessage");
|
|
1285
|
+
logVerbose(`[telegram] Pinned message ${messageId} in chat ${chatId}`);
|
|
1286
|
+
return {
|
|
1287
|
+
ok: true,
|
|
1288
|
+
messageId: String(messageId),
|
|
1289
|
+
chatId
|
|
1290
|
+
};
|
|
1291
|
+
}
|
|
1292
|
+
async function unpinMessageTelegram(chatIdInput, messageIdInput, opts) {
|
|
1293
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1294
|
+
const rawTarget = String(chatIdInput);
|
|
1295
|
+
const chatId = await resolveAndPersistChatId({
|
|
1296
|
+
cfg,
|
|
1297
|
+
api,
|
|
1298
|
+
lookupTarget: rawTarget,
|
|
1299
|
+
persistTarget: rawTarget,
|
|
1300
|
+
verbose: opts.verbose,
|
|
1301
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1302
|
+
});
|
|
1303
|
+
const messageId = messageIdInput === void 0 ? void 0 : normalizeMessageId(messageIdInput);
|
|
1304
|
+
await createTelegramRequestWithDiag({
|
|
1305
|
+
cfg,
|
|
1306
|
+
account,
|
|
1307
|
+
retry: opts.retry,
|
|
1308
|
+
verbose: opts.verbose
|
|
1309
|
+
})(() => api.unpinChatMessage(chatId, messageId), "unpinChatMessage");
|
|
1310
|
+
logVerbose(`[telegram] Unpinned ${messageId != null ? `message ${messageId}` : "active message"} in chat ${chatId}`);
|
|
1311
|
+
return {
|
|
1312
|
+
ok: true,
|
|
1313
|
+
chatId,
|
|
1314
|
+
...messageId != null ? { messageId: String(messageId) } : {}
|
|
1315
|
+
};
|
|
1316
|
+
}
|
|
1317
|
+
async function editForumTopicTelegram(chatIdInput, messageThreadIdInput, opts) {
|
|
1318
|
+
const nameProvided = opts.name !== void 0;
|
|
1319
|
+
const trimmedName = opts.name?.trim();
|
|
1320
|
+
if (nameProvided && !trimmedName) throw new Error("Telegram forum topic name is required");
|
|
1321
|
+
if (trimmedName && trimmedName.length > 128) throw new Error("Telegram forum topic name must be 128 characters or fewer");
|
|
1322
|
+
const iconProvided = opts.iconCustomEmojiId !== void 0;
|
|
1323
|
+
const trimmedIconCustomEmojiId = opts.iconCustomEmojiId?.trim();
|
|
1324
|
+
if (iconProvided && !trimmedIconCustomEmojiId) throw new Error("Telegram forum topic icon custom emoji ID is required");
|
|
1325
|
+
if (!trimmedName && !trimmedIconCustomEmojiId) throw new Error("Telegram forum topic update requires a name or iconCustomEmojiId");
|
|
1326
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1327
|
+
const rawTarget = String(chatIdInput);
|
|
1328
|
+
const chatId = await resolveAndPersistChatId({
|
|
1329
|
+
cfg,
|
|
1330
|
+
api,
|
|
1331
|
+
lookupTarget: parseTelegramTarget(rawTarget).chatId,
|
|
1332
|
+
persistTarget: rawTarget,
|
|
1333
|
+
verbose: opts.verbose,
|
|
1334
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1335
|
+
});
|
|
1336
|
+
const messageThreadId = normalizeMessageId(messageThreadIdInput);
|
|
1337
|
+
const requestWithDiag = createTelegramRequestWithDiag({
|
|
1338
|
+
cfg,
|
|
1339
|
+
account,
|
|
1340
|
+
retry: opts.retry,
|
|
1341
|
+
verbose: opts.verbose
|
|
1342
|
+
});
|
|
1343
|
+
const payload = {
|
|
1344
|
+
...trimmedName ? { name: trimmedName } : {},
|
|
1345
|
+
...trimmedIconCustomEmojiId ? { icon_custom_emoji_id: trimmedIconCustomEmojiId } : {}
|
|
1346
|
+
};
|
|
1347
|
+
await requestWithDiag(() => api.editForumTopic(chatId, messageThreadId, payload), "editForumTopic");
|
|
1348
|
+
logVerbose(`[telegram] Edited forum topic ${messageThreadId} in chat ${chatId}`);
|
|
1349
|
+
return {
|
|
1350
|
+
ok: true,
|
|
1351
|
+
chatId,
|
|
1352
|
+
messageThreadId,
|
|
1353
|
+
...trimmedName ? { name: trimmedName } : {},
|
|
1354
|
+
...trimmedIconCustomEmojiId ? { iconCustomEmojiId: trimmedIconCustomEmojiId } : {}
|
|
1355
|
+
};
|
|
1356
|
+
}
|
|
1357
|
+
async function renameForumTopicTelegram(chatIdInput, messageThreadIdInput, name, opts) {
|
|
1358
|
+
const result = await editForumTopicTelegram(chatIdInput, messageThreadIdInput, {
|
|
1359
|
+
...opts,
|
|
1360
|
+
name
|
|
1361
|
+
});
|
|
1362
|
+
return {
|
|
1363
|
+
ok: true,
|
|
1364
|
+
chatId: result.chatId,
|
|
1365
|
+
messageThreadId: result.messageThreadId,
|
|
1366
|
+
name: result.name ?? name.trim()
|
|
1367
|
+
};
|
|
1368
|
+
}
|
|
1369
|
+
async function editMessageReplyMarkupTelegram(chatIdInput, messageIdInput, buttons, opts) {
|
|
1370
|
+
const { cfg, account, api } = resolveTelegramApiContext({
|
|
1371
|
+
...opts,
|
|
1372
|
+
cfg: opts.cfg
|
|
1373
|
+
});
|
|
1374
|
+
const rawTarget = String(chatIdInput);
|
|
1375
|
+
const chatId = await resolveAndPersistChatId({
|
|
1376
|
+
cfg,
|
|
1377
|
+
api,
|
|
1378
|
+
lookupTarget: rawTarget,
|
|
1379
|
+
persistTarget: rawTarget,
|
|
1380
|
+
verbose: opts.verbose,
|
|
1381
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1382
|
+
});
|
|
1383
|
+
const messageId = normalizeMessageId(messageIdInput);
|
|
1384
|
+
const requestWithDiag = createTelegramRequestWithDiag({
|
|
1385
|
+
cfg,
|
|
1386
|
+
account,
|
|
1387
|
+
retry: opts.retry,
|
|
1388
|
+
verbose: opts.verbose
|
|
1389
|
+
});
|
|
1390
|
+
const replyMarkup = buildInlineKeyboard(buttons) ?? { inline_keyboard: [] };
|
|
1391
|
+
try {
|
|
1392
|
+
await requestWithDiag(() => api.editMessageReplyMarkup(chatId, messageId, { reply_markup: replyMarkup }), "editMessageReplyMarkup", { shouldLog: (err) => !isTelegramMessageNotModifiedError(err) });
|
|
1393
|
+
} catch (err) {
|
|
1394
|
+
if (!isTelegramMessageNotModifiedError(err)) throw err;
|
|
1395
|
+
}
|
|
1396
|
+
logVerbose(`[telegram] Edited reply markup for message ${messageId} in chat ${chatId}`);
|
|
1397
|
+
return {
|
|
1398
|
+
ok: true,
|
|
1399
|
+
messageId: String(messageId),
|
|
1400
|
+
chatId
|
|
1401
|
+
};
|
|
1402
|
+
}
|
|
1403
|
+
async function editMessageTelegram(chatIdInput, messageIdInput, text, opts) {
|
|
1404
|
+
const { cfg, account, api } = resolveTelegramApiContext({
|
|
1405
|
+
...opts,
|
|
1406
|
+
cfg: opts.cfg
|
|
1407
|
+
});
|
|
1408
|
+
const rawTarget = String(chatIdInput);
|
|
1409
|
+
const chatId = await resolveAndPersistChatId({
|
|
1410
|
+
cfg,
|
|
1411
|
+
api,
|
|
1412
|
+
lookupTarget: rawTarget,
|
|
1413
|
+
persistTarget: rawTarget,
|
|
1414
|
+
verbose: opts.verbose,
|
|
1415
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1416
|
+
});
|
|
1417
|
+
const messageId = normalizeMessageId(messageIdInput);
|
|
1418
|
+
const requestWithDiag = createTelegramRequestWithDiag({
|
|
1419
|
+
cfg,
|
|
1420
|
+
account,
|
|
1421
|
+
retry: opts.retry,
|
|
1422
|
+
verbose: opts.verbose,
|
|
1423
|
+
shouldRetry: (err) => isRecoverableTelegramNetworkError(err, { allowMessageMatch: true }) || isTelegramServerError(err)
|
|
1424
|
+
});
|
|
1425
|
+
const requestWithEditShouldLog = (fn, label, shouldLog) => requestWithDiag(fn, label, shouldLog ? { shouldLog } : void 0);
|
|
1426
|
+
const textMode = opts.textMode ?? "markdown";
|
|
1427
|
+
const htmlText = renderTelegramHtmlText(text, {
|
|
1428
|
+
textMode,
|
|
1429
|
+
tableMode: resolveMarkdownTableMode({
|
|
1430
|
+
cfg,
|
|
1431
|
+
channel: "telegram",
|
|
1432
|
+
accountId: account.accountId
|
|
1433
|
+
})
|
|
1434
|
+
});
|
|
1435
|
+
const plainText = textMode === "html" ? telegramHtmlToPlainTextFallback(htmlText) : text;
|
|
1436
|
+
const shouldTouchButtons = opts.buttons !== void 0;
|
|
1437
|
+
const builtKeyboard = shouldTouchButtons ? buildInlineKeyboard(opts.buttons) : void 0;
|
|
1438
|
+
const replyMarkup = shouldTouchButtons ? builtKeyboard ?? { inline_keyboard: [] } : void 0;
|
|
1439
|
+
const editParams = { parse_mode: "HTML" };
|
|
1440
|
+
if (opts.linkPreview === false) editParams.link_preview_options = { is_disabled: true };
|
|
1441
|
+
if (replyMarkup !== void 0) editParams.reply_markup = replyMarkup;
|
|
1442
|
+
const plainParams = {};
|
|
1443
|
+
if (opts.linkPreview === false) plainParams.link_preview_options = { is_disabled: true };
|
|
1444
|
+
if (replyMarkup !== void 0) plainParams.reply_markup = replyMarkup;
|
|
1445
|
+
try {
|
|
1446
|
+
await withTelegramHtmlParseFallback({
|
|
1447
|
+
label: "editMessage",
|
|
1448
|
+
verbose: opts.verbose,
|
|
1449
|
+
requestHtml: (retryLabel) => requestWithEditShouldLog(() => api.editMessageText(chatId, messageId, htmlText, editParams), retryLabel, (err) => !isTelegramMessageNotModifiedError(err)),
|
|
1450
|
+
requestPlain: (retryLabel) => requestWithEditShouldLog(() => Object.keys(plainParams).length > 0 ? api.editMessageText(chatId, messageId, plainText, plainParams) : api.editMessageText(chatId, messageId, plainText), retryLabel, (plainErr) => !isTelegramMessageNotModifiedError(plainErr))
|
|
1451
|
+
});
|
|
1452
|
+
} catch (err) {
|
|
1453
|
+
if (isTelegramMessageNotModifiedError(err)) {} else throw err;
|
|
1454
|
+
}
|
|
1455
|
+
logVerbose(`[telegram] Edited message ${messageId} in chat ${chatId}`);
|
|
1456
|
+
return {
|
|
1457
|
+
ok: true,
|
|
1458
|
+
messageId: String(messageId),
|
|
1459
|
+
chatId
|
|
1460
|
+
};
|
|
1461
|
+
}
|
|
1462
|
+
function inferFilename(kind) {
|
|
1463
|
+
switch (kind) {
|
|
1464
|
+
case "image": return "image.jpg";
|
|
1465
|
+
case "video": return "video.mp4";
|
|
1466
|
+
case "audio": return "audio.ogg";
|
|
1467
|
+
default: return "file.bin";
|
|
1468
|
+
}
|
|
1469
|
+
}
|
|
1470
|
+
/**
|
|
1471
|
+
* Send a sticker to a Telegram chat by file_id.
|
|
1472
|
+
* @param to - Chat ID or username (e.g., "123456789" or "@username")
|
|
1473
|
+
* @param fileId - Telegram file_id of the sticker to send
|
|
1474
|
+
* @param opts - Optional configuration
|
|
1475
|
+
*/
|
|
1476
|
+
async function sendStickerTelegram(to, fileId, opts) {
|
|
1477
|
+
if (!fileId?.trim()) throw new Error("Telegram sticker file_id is required");
|
|
1478
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1479
|
+
const target = parseTelegramTarget(to);
|
|
1480
|
+
const chatId = await resolveAndPersistChatId({
|
|
1481
|
+
cfg,
|
|
1482
|
+
api,
|
|
1483
|
+
lookupTarget: target.chatId,
|
|
1484
|
+
persistTarget: to,
|
|
1485
|
+
verbose: opts.verbose,
|
|
1486
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1487
|
+
});
|
|
1488
|
+
const threadParams = buildTelegramThreadReplyParams({
|
|
1489
|
+
thread: resolveTelegramSendThreadSpec({
|
|
1490
|
+
targetMessageThreadId: target.messageThreadId,
|
|
1491
|
+
messageThreadId: opts.messageThreadId,
|
|
1492
|
+
chatType: target.chatType
|
|
1493
|
+
}),
|
|
1494
|
+
replyToMessageId: opts.replyToMessageId
|
|
1495
|
+
});
|
|
1496
|
+
const hasThreadParams = Object.keys(threadParams).length > 0;
|
|
1497
|
+
const requestWithChatNotFound = createRequestWithChatNotFound({
|
|
1498
|
+
requestWithDiag: createTelegramNonIdempotentRequestWithDiag({
|
|
1499
|
+
cfg,
|
|
1500
|
+
account,
|
|
1501
|
+
retry: opts.retry,
|
|
1502
|
+
verbose: opts.verbose,
|
|
1503
|
+
useApiErrorLogging: false
|
|
1504
|
+
}),
|
|
1505
|
+
chatId,
|
|
1506
|
+
input: to
|
|
1507
|
+
});
|
|
1508
|
+
const stickerParams = hasThreadParams ? threadParams : void 0;
|
|
1509
|
+
const result = await requestWithChatNotFound(() => api.sendSticker(chatId, fileId.trim(), stickerParams), "sticker");
|
|
1510
|
+
const messageId = resolveTelegramMessageIdOrThrow(result, "sticker send");
|
|
1511
|
+
const resolvedChatId = String(result?.chat?.id ?? chatId);
|
|
1512
|
+
recordSentMessage(chatId, messageId, opts.cfg);
|
|
1513
|
+
recordChannelActivity({
|
|
1514
|
+
channel: "telegram",
|
|
1515
|
+
accountId: account.accountId,
|
|
1516
|
+
direction: "outbound"
|
|
1517
|
+
});
|
|
1518
|
+
return {
|
|
1519
|
+
messageId: String(messageId),
|
|
1520
|
+
chatId: resolvedChatId
|
|
1521
|
+
};
|
|
1522
|
+
}
|
|
1523
|
+
/**
|
|
1524
|
+
* Send a poll to a Telegram chat.
|
|
1525
|
+
* @param to - Chat ID or username (e.g., "123456789" or "@username")
|
|
1526
|
+
* @param poll - Poll input with question, options, maxSelections, and optional durationHours
|
|
1527
|
+
* @param opts - Optional configuration
|
|
1528
|
+
*/
|
|
1529
|
+
async function sendPollTelegram(to, poll, opts) {
|
|
1530
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1531
|
+
const target = parseTelegramTarget(to);
|
|
1532
|
+
const chatId = await resolveAndPersistChatId({
|
|
1533
|
+
cfg,
|
|
1534
|
+
api,
|
|
1535
|
+
lookupTarget: target.chatId,
|
|
1536
|
+
persistTarget: to,
|
|
1537
|
+
verbose: opts.verbose,
|
|
1538
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1539
|
+
});
|
|
1540
|
+
const normalizedPoll = normalizePollInput(poll, { maxOptions: 10 });
|
|
1541
|
+
const threadParams = buildTelegramThreadReplyParams({
|
|
1542
|
+
thread: resolveTelegramSendThreadSpec({
|
|
1543
|
+
targetMessageThreadId: target.messageThreadId,
|
|
1544
|
+
messageThreadId: opts.messageThreadId,
|
|
1545
|
+
chatType: target.chatType
|
|
1546
|
+
}),
|
|
1547
|
+
replyToMessageId: opts.replyToMessageId
|
|
1548
|
+
});
|
|
1549
|
+
const pollOptions = normalizedPoll.options;
|
|
1550
|
+
const requestWithChatNotFound = createRequestWithChatNotFound({
|
|
1551
|
+
requestWithDiag: createTelegramNonIdempotentRequestWithDiag({
|
|
1552
|
+
cfg,
|
|
1553
|
+
account,
|
|
1554
|
+
retry: opts.retry,
|
|
1555
|
+
verbose: opts.verbose
|
|
1556
|
+
}),
|
|
1557
|
+
chatId,
|
|
1558
|
+
input: to
|
|
1559
|
+
});
|
|
1560
|
+
const durationSeconds = normalizedPoll.durationSeconds;
|
|
1561
|
+
if (durationSeconds === void 0 && normalizedPoll.durationHours !== void 0) throw new Error("Telegram poll durationHours is not supported. Use durationSeconds (5-600) instead.");
|
|
1562
|
+
if (durationSeconds !== void 0 && (durationSeconds < 5 || durationSeconds > 600)) throw new Error("Telegram poll durationSeconds must be between 5 and 600");
|
|
1563
|
+
const pollParams = {
|
|
1564
|
+
allows_multiple_answers: normalizedPoll.maxSelections > 1,
|
|
1565
|
+
is_anonymous: opts.isAnonymous ?? true,
|
|
1566
|
+
...durationSeconds !== void 0 ? { open_period: durationSeconds } : {},
|
|
1567
|
+
...Object.keys(threadParams).length > 0 ? threadParams : {},
|
|
1568
|
+
...opts.silent === true ? { disable_notification: true } : {}
|
|
1569
|
+
};
|
|
1570
|
+
const result = await requestWithChatNotFound(() => api.sendPoll(chatId, normalizedPoll.question, pollOptions, pollParams), "poll");
|
|
1571
|
+
const messageId = resolveTelegramMessageIdOrThrow(result, "poll send");
|
|
1572
|
+
const resolvedChatId = String(result?.chat?.id ?? chatId);
|
|
1573
|
+
const pollId = result?.poll?.id;
|
|
1574
|
+
recordSentMessage(chatId, messageId, opts.cfg);
|
|
1575
|
+
recordChannelActivity({
|
|
1576
|
+
channel: "telegram",
|
|
1577
|
+
accountId: account.accountId,
|
|
1578
|
+
direction: "outbound"
|
|
1579
|
+
});
|
|
1580
|
+
return {
|
|
1581
|
+
messageId: String(messageId),
|
|
1582
|
+
chatId: resolvedChatId,
|
|
1583
|
+
pollId
|
|
1584
|
+
};
|
|
1585
|
+
}
|
|
1586
|
+
/**
|
|
1587
|
+
* Create a forum topic in a Telegram supergroup.
|
|
1588
|
+
* Requires the bot to have `can_manage_topics` permission.
|
|
1589
|
+
*
|
|
1590
|
+
* @param chatId - Supergroup chat ID
|
|
1591
|
+
* @param name - Topic name (1-128 characters)
|
|
1592
|
+
* @param opts - Optional configuration
|
|
1593
|
+
*/
|
|
1594
|
+
async function createForumTopicTelegram(chatId, name, opts) {
|
|
1595
|
+
if (!name?.trim()) throw new Error("Forum topic name is required");
|
|
1596
|
+
const trimmedName = name.trim();
|
|
1597
|
+
if (trimmedName.length > 128) throw new Error("Forum topic name must be 128 characters or fewer");
|
|
1598
|
+
const { cfg, account, api } = resolveTelegramApiContext(opts);
|
|
1599
|
+
const normalizedChatId = await resolveAndPersistChatId({
|
|
1600
|
+
cfg,
|
|
1601
|
+
api,
|
|
1602
|
+
lookupTarget: parseTelegramTarget(chatId).chatId,
|
|
1603
|
+
persistTarget: chatId,
|
|
1604
|
+
verbose: opts.verbose,
|
|
1605
|
+
gatewayClientScopes: opts.gatewayClientScopes
|
|
1606
|
+
});
|
|
1607
|
+
const requestWithDiag = createTelegramNonIdempotentRequestWithDiag({
|
|
1608
|
+
cfg,
|
|
1609
|
+
account,
|
|
1610
|
+
retry: opts.retry,
|
|
1611
|
+
verbose: opts.verbose
|
|
1612
|
+
});
|
|
1613
|
+
const extra = {};
|
|
1614
|
+
if (opts.iconColor != null) extra.icon_color = opts.iconColor;
|
|
1615
|
+
if (opts.iconCustomEmojiId?.trim()) extra.icon_custom_emoji_id = opts.iconCustomEmojiId.trim();
|
|
1616
|
+
const hasExtra = Object.keys(extra).length > 0;
|
|
1617
|
+
const result = await requestWithDiag(() => api.createForumTopic(normalizedChatId, trimmedName, hasExtra ? extra : void 0), "createForumTopic");
|
|
1618
|
+
const topicId = result.message_thread_id;
|
|
1619
|
+
recordChannelActivity({
|
|
1620
|
+
channel: "telegram",
|
|
1621
|
+
accountId: account.accountId,
|
|
1622
|
+
direction: "outbound"
|
|
1623
|
+
});
|
|
1624
|
+
return {
|
|
1625
|
+
topicId,
|
|
1626
|
+
name: result.name ?? trimmedName,
|
|
1627
|
+
chatId: normalizedChatId
|
|
1628
|
+
};
|
|
1629
|
+
}
|
|
1630
|
+
//#endregion
|
|
1631
|
+
export { Bot$1 as A, createTelegramClientFetch as C, splitTelegramCaption as D, resolveTelegramOutboundClientTimeoutFloorSeconds as E, sequentialize as M, withTelegramApiErrorLogging as O, asTelegramClientFetch as S, resolveTelegramClientTimeoutSeconds as T, wasSentByBot as _, editMessageTelegram as a, removeTelegramNativeQuoteParam as b, renameForumTopicTelegram as c, sendPollTelegram as d, sendStickerTelegram as f, recordSentMessage as g, resolveTelegramVoiceSend as h, editMessageReplyMarkupTelegram as i, apiThrottler as j, getOrCreateAccountThrottler as k, resetTelegramClientOptionsCacheForTests as l, unpinMessageTelegram as m, deleteMessageTelegram as n, pinMessageTelegram as o, sendTypingTelegram as p, editForumTopicTelegram as r, reactMessageTelegram as s, createForumTopicTelegram as t, sendMessageTelegram as u, buildTelegramSendParams as v, resolveTelegramClientTimeoutMinimumSeconds as w, buildInlineKeyboard as x, getTelegramNativeQuoteReplyMessageId as y };
|