@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,1145 @@
|
|
|
1
|
+
import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString } from "./string-coerce-DyL154ka.js";
|
|
2
|
+
import { n as normalizeAccountId } from "./account-id-B32J-iNN.js";
|
|
3
|
+
import { t as createSubsystemLogger } from "./subsystem-CppbuBPw.js";
|
|
4
|
+
import { a as parseAccessGroupAllowFromEntry, i as mergeDmAllowFromSources, n as firstDefined, r as isSenderIdAllowed } from "./allow-from-D1f7S_rf.js";
|
|
5
|
+
import { a as readChannelAllowFromStore } from "./pairing-store-D6kKcRDP.js";
|
|
6
|
+
import { t as resolveCommandAuthorization } from "./command-auth-C5BEhHxP.js";
|
|
7
|
+
import "./runtime-env-BSECk1Nm.js";
|
|
8
|
+
import "./string-coerce-runtime-DcopKqDR.js";
|
|
9
|
+
import "./routing-AC-P99jg.js";
|
|
10
|
+
import { i as markdownToIR, n as renderMarkdownWithMarkers } from "./tables-BROr40GK.js";
|
|
11
|
+
import "./conversation-runtime-BxOHxuin.js";
|
|
12
|
+
import { r as renderMarkdownIRChunksWithinLimit } from "./chunk-items-CA_C_p1k.js";
|
|
13
|
+
import { n as isAutoLinkedFileRef, t as FILE_REF_EXTENSIONS_WITH_TLD } from "./auto-linked-file-ref-kqLj-Euu.js";
|
|
14
|
+
import "./text-chunking-ObhJDe8L.js";
|
|
15
|
+
import "./security-runtime-Q5KQBgu1.js";
|
|
16
|
+
import { t as expandAllowFromWithAccessGroups } from "./access-groups-Blp1EmmC.js";
|
|
17
|
+
import "./command-auth-native-BxFgw91F.js";
|
|
18
|
+
import "./channel-inbound-COGoV_aS.js";
|
|
19
|
+
import { t as formatLocationText } from "./location-B0jdizlz.js";
|
|
20
|
+
import { t as resolveTelegramPreviewStreamMode } from "./preview-streaming-CXF2kEfd.js";
|
|
21
|
+
//#region extensions/telegram/src/outbound-params.ts
|
|
22
|
+
function parseIntegerId(value) {
|
|
23
|
+
if (!/^-?\d+$/.test(value)) return;
|
|
24
|
+
const parsed = Number.parseInt(value, 10);
|
|
25
|
+
return Number.isFinite(parsed) ? parsed : void 0;
|
|
26
|
+
}
|
|
27
|
+
function normalizeTelegramReplyToMessageId(value) {
|
|
28
|
+
if (typeof value === "number") return Number.isFinite(value) ? Math.trunc(value) : void 0;
|
|
29
|
+
if (typeof value !== "string") return;
|
|
30
|
+
const trimmed = value.trim();
|
|
31
|
+
return trimmed ? parseIntegerId(trimmed) : void 0;
|
|
32
|
+
}
|
|
33
|
+
function parseTelegramReplyToMessageId(replyToId) {
|
|
34
|
+
return normalizeTelegramReplyToMessageId(replyToId);
|
|
35
|
+
}
|
|
36
|
+
function parseTelegramThreadId(threadId) {
|
|
37
|
+
if (threadId == null) return;
|
|
38
|
+
if (typeof threadId === "number") return Number.isFinite(threadId) ? Math.trunc(threadId) : void 0;
|
|
39
|
+
const trimmed = threadId.trim();
|
|
40
|
+
if (!trimmed) return;
|
|
41
|
+
const topicMatch = /^-?\d+:topic:(\d+)$/.exec(trimmed);
|
|
42
|
+
if (topicMatch) return parseIntegerId(topicMatch[1]);
|
|
43
|
+
const scopedMatch = /^-?\d+:(-?\d+)$/.exec(trimmed);
|
|
44
|
+
return parseIntegerId(scopedMatch ? scopedMatch[1] : trimmed);
|
|
45
|
+
}
|
|
46
|
+
//#endregion
|
|
47
|
+
//#region extensions/telegram/src/bot-access.ts
|
|
48
|
+
const warnedInvalidEntries = /* @__PURE__ */ new Set();
|
|
49
|
+
const log = createSubsystemLogger("telegram/bot-access");
|
|
50
|
+
function warnInvalidAllowFromEntries(entries) {
|
|
51
|
+
if (process.env.VITEST || false) return;
|
|
52
|
+
for (const entry of entries) {
|
|
53
|
+
if (warnedInvalidEntries.has(entry)) continue;
|
|
54
|
+
warnedInvalidEntries.add(entry);
|
|
55
|
+
log.warn([
|
|
56
|
+
"Invalid allowFrom entry:",
|
|
57
|
+
JSON.stringify(entry),
|
|
58
|
+
"- allowFrom/groupAllowFrom authorization expects numeric Telegram sender user IDs only.",
|
|
59
|
+
"To allow a Telegram group or supergroup, add its negative chat ID under \"channels.telegram.groups\" instead.",
|
|
60
|
+
"If you had \"@username\" entries, re-run setup (it resolves @username to IDs) or replace them manually."
|
|
61
|
+
].join(" "));
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
const normalizeAllowFrom = (list) => {
|
|
65
|
+
const entries = (list ?? []).map((value) => normalizeOptionalString(String(value)) ?? "").filter(Boolean);
|
|
66
|
+
const hasWildcard = entries.includes("*");
|
|
67
|
+
const normalized = entries.filter((value) => value !== "*").map((value) => value.replace(/^(telegram|tg):/i, ""));
|
|
68
|
+
const invalidEntries = normalized.filter((value) => !/^\d+$/.test(value));
|
|
69
|
+
if (invalidEntries.length > 0) warnInvalidAllowFromEntries([...new Set(invalidEntries)]);
|
|
70
|
+
return {
|
|
71
|
+
entries: normalized.filter((value) => /^\d+$/.test(value)),
|
|
72
|
+
hasWildcard,
|
|
73
|
+
hasEntries: entries.length > 0,
|
|
74
|
+
invalidEntries
|
|
75
|
+
};
|
|
76
|
+
};
|
|
77
|
+
const normalizeDmAllowFromWithStore = (params) => normalizeAllowFrom(mergeDmAllowFromSources(params));
|
|
78
|
+
function resolveTelegramEffectiveDmPolicy(params) {
|
|
79
|
+
if (!params.isGroup && params.groupConfig && "dmPolicy" in params.groupConfig) return params.groupConfig.dmPolicy ?? params.dmPolicy ?? "pairing";
|
|
80
|
+
return params.dmPolicy ?? "pairing";
|
|
81
|
+
}
|
|
82
|
+
const isSenderAllowed = (params) => {
|
|
83
|
+
const { allow, senderId } = params;
|
|
84
|
+
return isSenderIdAllowed(allow, senderId, true);
|
|
85
|
+
};
|
|
86
|
+
//#endregion
|
|
87
|
+
//#region extensions/telegram/src/access-groups.ts
|
|
88
|
+
async function expandTelegramAllowFromWithAccessGroups(params) {
|
|
89
|
+
const allowFrom = (params.allowFrom ?? []).map(String);
|
|
90
|
+
const senderId = params.senderId?.trim() ?? "";
|
|
91
|
+
const expanded = params.cfg && senderId ? await expandAllowFromWithAccessGroups({
|
|
92
|
+
cfg: params.cfg,
|
|
93
|
+
allowFrom,
|
|
94
|
+
channel: "telegram",
|
|
95
|
+
accountId: params.accountId ?? "default",
|
|
96
|
+
senderId,
|
|
97
|
+
isSenderAllowed: (candidateSenderId, allowEntries) => isSenderAllowed({
|
|
98
|
+
allow: normalizeAllowFrom(allowEntries),
|
|
99
|
+
senderId: candidateSenderId
|
|
100
|
+
})
|
|
101
|
+
}) : allowFrom;
|
|
102
|
+
const originalEntries = new Set(allowFrom);
|
|
103
|
+
return expanded.some((entry) => !originalEntries.has(entry)) ? expanded.filter((entry) => parseAccessGroupAllowFromEntry(entry) == null) : expanded;
|
|
104
|
+
}
|
|
105
|
+
async function resolveTelegramDmAllow(params) {
|
|
106
|
+
const allowFrom = params.groupAllowOverride ?? params.allowFrom;
|
|
107
|
+
const expandedAllowFrom = await expandTelegramAllowFromWithAccessGroups({
|
|
108
|
+
cfg: params.cfg,
|
|
109
|
+
allowFrom,
|
|
110
|
+
accountId: params.accountId,
|
|
111
|
+
senderId: params.senderId
|
|
112
|
+
});
|
|
113
|
+
return {
|
|
114
|
+
allowFrom,
|
|
115
|
+
expandedAllowFrom,
|
|
116
|
+
effectiveAllow: normalizeDmAllowFromWithStore({
|
|
117
|
+
allowFrom: expandedAllowFrom,
|
|
118
|
+
storeAllowFrom: params.storeAllowFrom,
|
|
119
|
+
dmPolicy: params.dmPolicy
|
|
120
|
+
})
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
//#endregion
|
|
124
|
+
//#region extensions/telegram/src/bot/body-helpers.ts
|
|
125
|
+
function buildSenderName(msg) {
|
|
126
|
+
return [msg.from?.first_name, msg.from?.last_name].filter(Boolean).join(" ").trim() || msg.from?.username || void 0;
|
|
127
|
+
}
|
|
128
|
+
function resolveTelegramPrimaryMedia(msg) {
|
|
129
|
+
if (!msg) return;
|
|
130
|
+
const photo = msg.photo?.[msg.photo.length - 1];
|
|
131
|
+
if (photo) return {
|
|
132
|
+
placeholder: "<media:image>",
|
|
133
|
+
fileRef: photo
|
|
134
|
+
};
|
|
135
|
+
if (msg.video) return {
|
|
136
|
+
placeholder: "<media:video>",
|
|
137
|
+
fileRef: msg.video
|
|
138
|
+
};
|
|
139
|
+
if (msg.video_note) return {
|
|
140
|
+
placeholder: "<media:video>",
|
|
141
|
+
fileRef: msg.video_note
|
|
142
|
+
};
|
|
143
|
+
if (msg.audio) return {
|
|
144
|
+
placeholder: "<media:audio>",
|
|
145
|
+
fileRef: msg.audio
|
|
146
|
+
};
|
|
147
|
+
if (msg.voice) return {
|
|
148
|
+
placeholder: "<media:audio>",
|
|
149
|
+
fileRef: msg.voice
|
|
150
|
+
};
|
|
151
|
+
if (msg.document) return {
|
|
152
|
+
placeholder: "<media:document>",
|
|
153
|
+
fileRef: msg.document
|
|
154
|
+
};
|
|
155
|
+
if (msg.sticker) return {
|
|
156
|
+
placeholder: "<media:sticker>",
|
|
157
|
+
fileRef: msg.sticker
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
function resolveTelegramMediaPlaceholder(msg) {
|
|
161
|
+
return resolveTelegramPrimaryMedia(msg)?.placeholder;
|
|
162
|
+
}
|
|
163
|
+
function buildSenderLabel(msg, senderId) {
|
|
164
|
+
const name = buildSenderName(msg);
|
|
165
|
+
const username = msg.from?.username ? `@${msg.from.username}` : void 0;
|
|
166
|
+
let label = name;
|
|
167
|
+
if (name && username) label = `${name} (${username})`;
|
|
168
|
+
else if (!name && username) label = username;
|
|
169
|
+
const fallbackId = (senderId != null ? normalizeOptionalString(String(senderId)) : void 0) ?? (msg.from?.id != null ? String(msg.from.id) : void 0);
|
|
170
|
+
const idPart = fallbackId ? `id:${fallbackId}` : void 0;
|
|
171
|
+
if (label && idPart) return `${label} ${idPart}`;
|
|
172
|
+
if (label) return label;
|
|
173
|
+
return idPart ?? "id:unknown";
|
|
174
|
+
}
|
|
175
|
+
function isBinaryContent(text) {
|
|
176
|
+
for (let i = 0; i < text.length; i++) {
|
|
177
|
+
const code = text.charCodeAt(i);
|
|
178
|
+
if (code <= 31 && code !== 9 && code !== 10 && code !== 13) return true;
|
|
179
|
+
}
|
|
180
|
+
return false;
|
|
181
|
+
}
|
|
182
|
+
function resolveTelegramTextContent(text, caption) {
|
|
183
|
+
const raw = typeof text === "string" ? text : typeof caption === "string" ? caption : "";
|
|
184
|
+
return isBinaryContent(raw) ? "" : raw;
|
|
185
|
+
}
|
|
186
|
+
function getTelegramTextParts(msg) {
|
|
187
|
+
const text = resolveTelegramTextContent(msg.text, msg.caption);
|
|
188
|
+
return {
|
|
189
|
+
text,
|
|
190
|
+
entities: text ? msg.entities ?? msg.caption_entities ?? [] : []
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
function isTelegramMentionWordChar(char) {
|
|
194
|
+
return char != null && /[a-z0-9_]/i.test(char);
|
|
195
|
+
}
|
|
196
|
+
function hasStandaloneTelegramMention(text, mention) {
|
|
197
|
+
let startIndex = 0;
|
|
198
|
+
while (startIndex < text.length) {
|
|
199
|
+
const idx = text.indexOf(mention, startIndex);
|
|
200
|
+
if (idx === -1) return false;
|
|
201
|
+
const prev = idx > 0 ? text[idx - 1] : void 0;
|
|
202
|
+
const next = text[idx + mention.length];
|
|
203
|
+
if (!isTelegramMentionWordChar(prev) && !isTelegramMentionWordChar(next)) return true;
|
|
204
|
+
startIndex = idx + 1;
|
|
205
|
+
}
|
|
206
|
+
return false;
|
|
207
|
+
}
|
|
208
|
+
function hasBotMention(msg, botUsername) {
|
|
209
|
+
const { text, entities } = getTelegramTextParts(msg);
|
|
210
|
+
const mention = normalizeLowercaseStringOrEmpty(`@${botUsername}`);
|
|
211
|
+
if (hasStandaloneTelegramMention(normalizeLowercaseStringOrEmpty(text), mention)) return true;
|
|
212
|
+
for (const ent of entities) {
|
|
213
|
+
if (ent.type !== "mention") continue;
|
|
214
|
+
if (normalizeLowercaseStringOrEmpty(text.slice(ent.offset, ent.offset + ent.length)) === mention) return true;
|
|
215
|
+
}
|
|
216
|
+
return false;
|
|
217
|
+
}
|
|
218
|
+
function expandTextLinks(text, entities) {
|
|
219
|
+
if (!text || !entities?.length) return text;
|
|
220
|
+
const textLinks = entities.filter((entity) => entity.type === "text_link" && Boolean(entity.url)).toSorted((a, b) => b.offset - a.offset);
|
|
221
|
+
if (textLinks.length === 0) return text;
|
|
222
|
+
let result = text;
|
|
223
|
+
for (const entity of textLinks) {
|
|
224
|
+
const markdown = `[${text.slice(entity.offset, entity.offset + entity.length)}](${entity.url})`;
|
|
225
|
+
result = result.slice(0, entity.offset) + markdown + result.slice(entity.offset + entity.length);
|
|
226
|
+
}
|
|
227
|
+
return result;
|
|
228
|
+
}
|
|
229
|
+
function normalizeForwardedUserLabel(user) {
|
|
230
|
+
const name = [user.first_name, user.last_name].filter(Boolean).join(" ").trim();
|
|
231
|
+
const username = normalizeOptionalString(user.username);
|
|
232
|
+
const id = String(user.id);
|
|
233
|
+
return {
|
|
234
|
+
display: (name && username ? `${name} (@${username})` : name || (username ? `@${username}` : void 0)) || `user:${id}`,
|
|
235
|
+
name: name || void 0,
|
|
236
|
+
username,
|
|
237
|
+
id
|
|
238
|
+
};
|
|
239
|
+
}
|
|
240
|
+
function normalizeForwardedChatLabel(chat, fallbackKind) {
|
|
241
|
+
const title = normalizeOptionalString(chat.title);
|
|
242
|
+
const username = normalizeOptionalString(chat.username);
|
|
243
|
+
const id = String(chat.id);
|
|
244
|
+
return {
|
|
245
|
+
display: title || (username ? `@${username}` : void 0) || `${fallbackKind}:${id}`,
|
|
246
|
+
title,
|
|
247
|
+
username,
|
|
248
|
+
id
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
function buildForwardedContextFromUser(params) {
|
|
252
|
+
const { display, name, username, id } = normalizeForwardedUserLabel(params.user);
|
|
253
|
+
if (!display) return null;
|
|
254
|
+
return {
|
|
255
|
+
from: display,
|
|
256
|
+
date: params.date,
|
|
257
|
+
fromType: params.type,
|
|
258
|
+
fromId: id,
|
|
259
|
+
fromUsername: username,
|
|
260
|
+
fromTitle: name
|
|
261
|
+
};
|
|
262
|
+
}
|
|
263
|
+
function buildForwardedContextFromHiddenName(params) {
|
|
264
|
+
const trimmed = params.name?.trim();
|
|
265
|
+
if (!trimmed) return null;
|
|
266
|
+
return {
|
|
267
|
+
from: trimmed,
|
|
268
|
+
date: params.date,
|
|
269
|
+
fromType: params.type,
|
|
270
|
+
fromTitle: trimmed
|
|
271
|
+
};
|
|
272
|
+
}
|
|
273
|
+
function buildForwardedContextFromChat(params) {
|
|
274
|
+
const fallbackKind = params.type === "channel" ? "channel" : "chat";
|
|
275
|
+
const { display, title, username, id } = normalizeForwardedChatLabel(params.chat, fallbackKind);
|
|
276
|
+
if (!display) return null;
|
|
277
|
+
const signature = normalizeOptionalString(params.signature);
|
|
278
|
+
const from = signature ? `${display} (${signature})` : display;
|
|
279
|
+
const chatType = normalizeOptionalString(params.chat.type);
|
|
280
|
+
return {
|
|
281
|
+
from,
|
|
282
|
+
date: params.date,
|
|
283
|
+
fromType: params.type,
|
|
284
|
+
fromId: id,
|
|
285
|
+
fromUsername: username,
|
|
286
|
+
fromTitle: title,
|
|
287
|
+
fromSignature: signature,
|
|
288
|
+
fromChatType: chatType,
|
|
289
|
+
fromMessageId: params.messageId
|
|
290
|
+
};
|
|
291
|
+
}
|
|
292
|
+
function resolveForwardOrigin(origin) {
|
|
293
|
+
switch (origin.type) {
|
|
294
|
+
case "user": return buildForwardedContextFromUser({
|
|
295
|
+
user: origin.sender_user,
|
|
296
|
+
date: origin.date,
|
|
297
|
+
type: "user"
|
|
298
|
+
});
|
|
299
|
+
case "hidden_user": return buildForwardedContextFromHiddenName({
|
|
300
|
+
name: origin.sender_user_name,
|
|
301
|
+
date: origin.date,
|
|
302
|
+
type: "hidden_user"
|
|
303
|
+
});
|
|
304
|
+
case "chat": return buildForwardedContextFromChat({
|
|
305
|
+
chat: origin.sender_chat,
|
|
306
|
+
date: origin.date,
|
|
307
|
+
type: "chat",
|
|
308
|
+
signature: origin.author_signature
|
|
309
|
+
});
|
|
310
|
+
case "channel": return buildForwardedContextFromChat({
|
|
311
|
+
chat: origin.chat,
|
|
312
|
+
date: origin.date,
|
|
313
|
+
type: "channel",
|
|
314
|
+
signature: origin.author_signature,
|
|
315
|
+
messageId: origin.message_id
|
|
316
|
+
});
|
|
317
|
+
default: return null;
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
function normalizeForwardedContext(msg) {
|
|
321
|
+
if (!msg.forward_origin) return null;
|
|
322
|
+
return resolveForwardOrigin(msg.forward_origin);
|
|
323
|
+
}
|
|
324
|
+
function extractTelegramLocation(msg) {
|
|
325
|
+
const { venue, location } = msg;
|
|
326
|
+
if (venue) return {
|
|
327
|
+
latitude: venue.location.latitude,
|
|
328
|
+
longitude: venue.location.longitude,
|
|
329
|
+
accuracy: venue.location.horizontal_accuracy,
|
|
330
|
+
name: venue.title,
|
|
331
|
+
address: venue.address,
|
|
332
|
+
source: "place",
|
|
333
|
+
isLive: false
|
|
334
|
+
};
|
|
335
|
+
if (location) {
|
|
336
|
+
const isLive = typeof location.live_period === "number" && location.live_period > 0;
|
|
337
|
+
return {
|
|
338
|
+
latitude: location.latitude,
|
|
339
|
+
longitude: location.longitude,
|
|
340
|
+
accuracy: location.horizontal_accuracy,
|
|
341
|
+
source: isLive ? "live" : "pin",
|
|
342
|
+
isLive
|
|
343
|
+
};
|
|
344
|
+
}
|
|
345
|
+
return null;
|
|
346
|
+
}
|
|
347
|
+
//#endregion
|
|
348
|
+
//#region extensions/telegram/src/bot/helpers.ts
|
|
349
|
+
const TELEGRAM_GENERAL_TOPIC_ID = 1;
|
|
350
|
+
const TELEGRAM_FORUM_FLAG_CACHE_MAX_CHATS = 1024;
|
|
351
|
+
const TELEGRAM_FORUM_FLAG_CACHE_TTL_MS = 10 * 6e4;
|
|
352
|
+
const telegramForumFlagByChatId = /* @__PURE__ */ new Map();
|
|
353
|
+
function resetTelegramForumFlagCacheForTest() {
|
|
354
|
+
telegramForumFlagByChatId.clear();
|
|
355
|
+
}
|
|
356
|
+
function cacheTelegramForumFlag(chatId, isForum, nowMs = Date.now()) {
|
|
357
|
+
const cacheKey = String(chatId);
|
|
358
|
+
if (!telegramForumFlagByChatId.has(cacheKey) && telegramForumFlagByChatId.size >= TELEGRAM_FORUM_FLAG_CACHE_MAX_CHATS) {
|
|
359
|
+
const oldestKey = telegramForumFlagByChatId.keys().next().value;
|
|
360
|
+
if (oldestKey !== void 0) telegramForumFlagByChatId.delete(oldestKey);
|
|
361
|
+
}
|
|
362
|
+
telegramForumFlagByChatId.set(cacheKey, {
|
|
363
|
+
expiresAtMs: nowMs + TELEGRAM_FORUM_FLAG_CACHE_TTL_MS,
|
|
364
|
+
isForum
|
|
365
|
+
});
|
|
366
|
+
}
|
|
367
|
+
function hadUnsafeTelegramText(raw, sanitized) {
|
|
368
|
+
return typeof raw === "string" && raw.trim().length > 0 && sanitized.trim().length === 0;
|
|
369
|
+
}
|
|
370
|
+
function normalizeTelegramDmThreadReplies(value) {
|
|
371
|
+
return value === "off" || value === "inbound" || value === "always" ? value : void 0;
|
|
372
|
+
}
|
|
373
|
+
function resolveTelegramDmThreadReplies(params) {
|
|
374
|
+
return normalizeTelegramDmThreadReplies(params.directConfig?.threadReplies) ?? normalizeTelegramDmThreadReplies(params.accountConfig?.dm?.threadReplies) ?? "off";
|
|
375
|
+
}
|
|
376
|
+
function shouldUseTelegramDmThreadSession(params) {
|
|
377
|
+
if (params.dmThreadId == null) return false;
|
|
378
|
+
if (params.directConfig?.requireTopic === true || params.topicConfig) return true;
|
|
379
|
+
return resolveTelegramDmThreadReplies(params) !== "off";
|
|
380
|
+
}
|
|
381
|
+
function extractTelegramForumFlag(value) {
|
|
382
|
+
if (!value || typeof value !== "object" || !("is_forum" in value)) return;
|
|
383
|
+
const forum = value.is_forum;
|
|
384
|
+
return typeof forum === "boolean" ? forum : void 0;
|
|
385
|
+
}
|
|
386
|
+
function resolveTelegramMessageForumFlagHint(params) {
|
|
387
|
+
if (params.chatType === "supergroup" && params.isTopicMessage === true) return true;
|
|
388
|
+
return typeof params.isForum === "boolean" ? params.isForum : void 0;
|
|
389
|
+
}
|
|
390
|
+
async function resolveTelegramForumFlag(params) {
|
|
391
|
+
const forumHint = resolveTelegramMessageForumFlagHint({
|
|
392
|
+
chatType: params.chatType,
|
|
393
|
+
isForum: params.isForum,
|
|
394
|
+
isTopicMessage: params.isTopicMessage
|
|
395
|
+
});
|
|
396
|
+
if (typeof forumHint === "boolean") {
|
|
397
|
+
if (params.isGroup && params.chatType === "supergroup") cacheTelegramForumFlag(params.chatId, forumHint);
|
|
398
|
+
return forumHint;
|
|
399
|
+
}
|
|
400
|
+
if (!params.isGroup || params.chatType !== "supergroup" || !params.getChat) return false;
|
|
401
|
+
const cacheKey = String(params.chatId);
|
|
402
|
+
const nowMs = Date.now();
|
|
403
|
+
const cached = telegramForumFlagByChatId.get(cacheKey);
|
|
404
|
+
if (cached && cached.expiresAtMs > nowMs) return cached.isForum;
|
|
405
|
+
if (cached) telegramForumFlagByChatId.delete(cacheKey);
|
|
406
|
+
try {
|
|
407
|
+
const resolved = extractTelegramForumFlag(await params.getChat(params.chatId)) === true;
|
|
408
|
+
cacheTelegramForumFlag(params.chatId, resolved, nowMs);
|
|
409
|
+
return resolved;
|
|
410
|
+
} catch {
|
|
411
|
+
return false;
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
function withResolvedTelegramForumFlag(message, isForum) {
|
|
415
|
+
if (extractTelegramForumFlag(message.chat) === isForum) return message;
|
|
416
|
+
return {
|
|
417
|
+
...message,
|
|
418
|
+
chat: {
|
|
419
|
+
...message.chat,
|
|
420
|
+
is_forum: isForum
|
|
421
|
+
}
|
|
422
|
+
};
|
|
423
|
+
}
|
|
424
|
+
async function resolveTelegramGroupAllowFromContext(params) {
|
|
425
|
+
const accountId = normalizeAccountId(params.accountId);
|
|
426
|
+
const threadSpec = resolveTelegramThreadSpec({
|
|
427
|
+
isGroup: params.isGroup ?? false,
|
|
428
|
+
isForum: params.isForum,
|
|
429
|
+
messageThreadId: params.messageThreadId
|
|
430
|
+
});
|
|
431
|
+
const resolvedThreadId = threadSpec.scope === "forum" ? threadSpec.id : void 0;
|
|
432
|
+
const dmThreadId = threadSpec.scope === "dm" ? threadSpec.id : void 0;
|
|
433
|
+
const threadIdForConfig = resolvedThreadId ?? dmThreadId;
|
|
434
|
+
const storeAllowFrom = await (params.readChannelAllowFromStore ?? readChannelAllowFromStore)("telegram", process.env, accountId).catch(() => []);
|
|
435
|
+
const { groupConfig, topicConfig } = params.resolveTelegramGroupConfig(params.chatId, threadIdForConfig);
|
|
436
|
+
const groupAllowOverride = firstDefined(topicConfig?.allowFrom, groupConfig?.allowFrom);
|
|
437
|
+
return {
|
|
438
|
+
resolvedThreadId,
|
|
439
|
+
dmThreadId,
|
|
440
|
+
storeAllowFrom,
|
|
441
|
+
groupConfig,
|
|
442
|
+
topicConfig,
|
|
443
|
+
groupAllowOverride,
|
|
444
|
+
effectiveGroupAllow: normalizeAllowFrom(await expandTelegramAllowFromWithAccessGroups({
|
|
445
|
+
cfg: params.cfg,
|
|
446
|
+
allowFrom: groupAllowOverride ?? params.groupAllowFrom,
|
|
447
|
+
accountId,
|
|
448
|
+
senderId: params.senderId
|
|
449
|
+
})),
|
|
450
|
+
hasGroupAllowOverride: groupAllowOverride !== void 0
|
|
451
|
+
};
|
|
452
|
+
}
|
|
453
|
+
/**
|
|
454
|
+
* Resolve the thread ID for Telegram forum topics.
|
|
455
|
+
* For non-forum groups, returns undefined even if messageThreadId is present
|
|
456
|
+
* (reply threads in regular groups should not create separate sessions).
|
|
457
|
+
* For forum groups, returns the topic ID (or General topic ID=1 if unspecified).
|
|
458
|
+
*/
|
|
459
|
+
function resolveTelegramForumThreadId(params) {
|
|
460
|
+
if (!params.isForum) return;
|
|
461
|
+
if (params.messageThreadId == null) return TELEGRAM_GENERAL_TOPIC_ID;
|
|
462
|
+
return params.messageThreadId;
|
|
463
|
+
}
|
|
464
|
+
function resolveTelegramThreadSpec(params) {
|
|
465
|
+
if (params.isGroup) return {
|
|
466
|
+
id: resolveTelegramForumThreadId({
|
|
467
|
+
isForum: params.isForum,
|
|
468
|
+
messageThreadId: params.messageThreadId
|
|
469
|
+
}),
|
|
470
|
+
scope: params.isForum ? "forum" : "none"
|
|
471
|
+
};
|
|
472
|
+
if (params.messageThreadId == null) return { scope: "dm" };
|
|
473
|
+
return {
|
|
474
|
+
id: params.messageThreadId,
|
|
475
|
+
scope: "dm"
|
|
476
|
+
};
|
|
477
|
+
}
|
|
478
|
+
/**
|
|
479
|
+
* Build thread params for Telegram API calls (messages, media).
|
|
480
|
+
*
|
|
481
|
+
* IMPORTANT: Thread IDs behave differently based on chat type:
|
|
482
|
+
* - DMs (private chats): Include message_thread_id when present (DM topics)
|
|
483
|
+
* - Forum topics: Skip thread_id=1 (General topic), include others
|
|
484
|
+
* - Regular groups: Thread IDs are ignored by Telegram
|
|
485
|
+
*
|
|
486
|
+
* General forum topic (id=1) must be treated like a regular supergroup send:
|
|
487
|
+
* Telegram rejects sendMessage/sendMedia with message_thread_id=1 ("thread not found").
|
|
488
|
+
*
|
|
489
|
+
* @param thread - Thread specification with ID and scope
|
|
490
|
+
* @returns API params object or undefined if thread_id should be omitted
|
|
491
|
+
*/
|
|
492
|
+
function buildTelegramThreadParams(thread) {
|
|
493
|
+
if (thread?.id == null) return;
|
|
494
|
+
const normalized = Math.trunc(thread.id);
|
|
495
|
+
if (thread.scope === "dm") return normalized > 0 ? { message_thread_id: normalized } : void 0;
|
|
496
|
+
if (normalized === TELEGRAM_GENERAL_TOPIC_ID) return;
|
|
497
|
+
return { message_thread_id: normalized };
|
|
498
|
+
}
|
|
499
|
+
/**
|
|
500
|
+
* Build a Telegram routing target that keeps real topic/thread ids in-band.
|
|
501
|
+
*
|
|
502
|
+
* This is used by generic reply plumbing that may not always carry a separate
|
|
503
|
+
* `threadId` field through every hop. General forum topic stays chat-scoped
|
|
504
|
+
* because Telegram rejects `message_thread_id=1` for message sends.
|
|
505
|
+
*/
|
|
506
|
+
function buildTelegramRoutingTarget(chatId, thread) {
|
|
507
|
+
const base = `telegram:${chatId}`;
|
|
508
|
+
const messageThreadId = buildTelegramThreadParams(thread)?.message_thread_id;
|
|
509
|
+
if (typeof messageThreadId !== "number") return base;
|
|
510
|
+
return `${base}:topic:${messageThreadId}`;
|
|
511
|
+
}
|
|
512
|
+
/**
|
|
513
|
+
* Build the canonical Telegram inbound origin used by queued follow-up routing.
|
|
514
|
+
* DM thread ids remain metadata-only; real forum topics must be in-band.
|
|
515
|
+
*/
|
|
516
|
+
function buildTelegramInboundOriginTarget(chatId, thread) {
|
|
517
|
+
if (thread?.scope !== "forum") return `telegram:${chatId}`;
|
|
518
|
+
return buildTelegramRoutingTarget(chatId, thread);
|
|
519
|
+
}
|
|
520
|
+
/**
|
|
521
|
+
* Build thread params for typing indicators (sendChatAction).
|
|
522
|
+
* Empirically, General topic (id=1) needs message_thread_id for typing to appear.
|
|
523
|
+
*/
|
|
524
|
+
function buildTypingThreadParams(messageThreadId) {
|
|
525
|
+
if (messageThreadId == null) return;
|
|
526
|
+
return { message_thread_id: Math.trunc(messageThreadId) };
|
|
527
|
+
}
|
|
528
|
+
function resolveTelegramStreamMode(telegramCfg) {
|
|
529
|
+
return resolveTelegramPreviewStreamMode(telegramCfg);
|
|
530
|
+
}
|
|
531
|
+
function buildTelegramGroupPeerId(chatId, messageThreadId) {
|
|
532
|
+
return messageThreadId != null ? `${chatId}:topic:${messageThreadId}` : String(chatId);
|
|
533
|
+
}
|
|
534
|
+
/**
|
|
535
|
+
* Resolve the direct-message peer identifier for Telegram routing/session keys.
|
|
536
|
+
*
|
|
537
|
+
* In some Telegram DM deliveries (for example certain business/chat bridge flows),
|
|
538
|
+
* `chat.id` can differ from the actual sender user id. Prefer sender id when present
|
|
539
|
+
* so per-peer DM scopes isolate users correctly.
|
|
540
|
+
*/
|
|
541
|
+
function resolveTelegramDirectPeerId(params) {
|
|
542
|
+
const senderId = params.senderId != null ? normalizeOptionalString(String(params.senderId)) ?? "" : "";
|
|
543
|
+
if (senderId) return senderId;
|
|
544
|
+
return String(params.chatId);
|
|
545
|
+
}
|
|
546
|
+
function buildTelegramGroupFrom(chatId, messageThreadId) {
|
|
547
|
+
return `telegram:group:${buildTelegramGroupPeerId(chatId, messageThreadId)}`;
|
|
548
|
+
}
|
|
549
|
+
function isTelegramCommandsAllowFromConfigured(cfg) {
|
|
550
|
+
const commandsAllowFrom = cfg.commands?.allowFrom;
|
|
551
|
+
return commandsAllowFrom != null && typeof commandsAllowFrom === "object" && (Array.isArray(commandsAllowFrom.telegram) || Array.isArray(commandsAllowFrom["*"]));
|
|
552
|
+
}
|
|
553
|
+
function resolveTelegramCommandAuthorization(params) {
|
|
554
|
+
return resolveCommandAuthorization({
|
|
555
|
+
ctx: {
|
|
556
|
+
Provider: "telegram",
|
|
557
|
+
Surface: "telegram",
|
|
558
|
+
OriginatingChannel: "telegram",
|
|
559
|
+
AccountId: params.accountId,
|
|
560
|
+
ChatType: params.isGroup ? "group" : "direct",
|
|
561
|
+
From: params.isGroup ? buildTelegramGroupFrom(params.chatId, params.resolvedThreadId) : `telegram:${params.chatId}`,
|
|
562
|
+
SenderId: params.senderId || void 0,
|
|
563
|
+
SenderUsername: params.senderUsername || void 0
|
|
564
|
+
},
|
|
565
|
+
cfg: params.cfg,
|
|
566
|
+
commandAuthorized: false
|
|
567
|
+
});
|
|
568
|
+
}
|
|
569
|
+
/**
|
|
570
|
+
* Build parentPeer for forum topic binding inheritance.
|
|
571
|
+
* When a message comes from a forum topic, the peer ID includes the topic suffix
|
|
572
|
+
* (e.g., `-1001234567890:topic:99`). To allow bindings configured for the base
|
|
573
|
+
* group ID to match, we provide the parent group as `parentPeer` so the routing
|
|
574
|
+
* layer can fall back to it when the exact peer doesn't match.
|
|
575
|
+
*/
|
|
576
|
+
function buildTelegramParentPeer(params) {
|
|
577
|
+
if (!params.isGroup || params.resolvedThreadId == null) return;
|
|
578
|
+
return {
|
|
579
|
+
kind: "group",
|
|
580
|
+
id: String(params.chatId)
|
|
581
|
+
};
|
|
582
|
+
}
|
|
583
|
+
function buildGroupLabel(msg, chatId, messageThreadId) {
|
|
584
|
+
const title = msg.chat?.title;
|
|
585
|
+
const topicSuffix = messageThreadId != null ? ` topic:${messageThreadId}` : "";
|
|
586
|
+
if (title) return `${title} id:${chatId}${topicSuffix}`;
|
|
587
|
+
return `group:${chatId}${topicSuffix}`;
|
|
588
|
+
}
|
|
589
|
+
function resolveTelegramReplyId(raw) {
|
|
590
|
+
return normalizeTelegramReplyToMessageId(raw);
|
|
591
|
+
}
|
|
592
|
+
function describeReplyTarget(msg) {
|
|
593
|
+
const reply = msg.reply_to_message;
|
|
594
|
+
const externalReply = msg.external_reply;
|
|
595
|
+
const quote = msg.quote ?? externalReply?.quote;
|
|
596
|
+
const rawQuoteText = quote?.text;
|
|
597
|
+
const quoteText = resolveTelegramTextContent(rawQuoteText);
|
|
598
|
+
let body = "";
|
|
599
|
+
let kind = "reply";
|
|
600
|
+
const filteredQuoteText = hadUnsafeTelegramText(rawQuoteText, quoteText);
|
|
601
|
+
body = quoteText.trim();
|
|
602
|
+
if (body) kind = "quote";
|
|
603
|
+
const replyLike = reply ?? externalReply;
|
|
604
|
+
const rawReplyText = replyLike && typeof replyLike.text === "string" ? replyLike.text : replyLike && typeof replyLike.caption === "string" ? replyLike.caption : void 0;
|
|
605
|
+
const safeReplyText = resolveTelegramTextContent(rawReplyText);
|
|
606
|
+
const replyTextParts = replyLike && safeReplyText ? getTelegramTextParts(replyLike) : void 0;
|
|
607
|
+
let filteredReplyText = false;
|
|
608
|
+
if (!body && replyLike) {
|
|
609
|
+
const replyBody = safeReplyText.trim();
|
|
610
|
+
filteredReplyText = hadUnsafeTelegramText(rawReplyText, replyBody);
|
|
611
|
+
body = replyBody;
|
|
612
|
+
if (!body) {
|
|
613
|
+
body = resolveTelegramMediaPlaceholder(replyLike) ?? "";
|
|
614
|
+
if (!body) {
|
|
615
|
+
const locationData = extractTelegramLocation(replyLike);
|
|
616
|
+
if (locationData) body = formatLocationText(locationData);
|
|
617
|
+
}
|
|
618
|
+
}
|
|
619
|
+
}
|
|
620
|
+
if (!body && !replyLike) return null;
|
|
621
|
+
if (!body && !filteredQuoteText && !filteredReplyText) return null;
|
|
622
|
+
const senderLabel = (replyLike ? buildSenderName(replyLike) : void 0) ?? "unknown sender";
|
|
623
|
+
const source = reply ? "reply_to_message" : "external_reply";
|
|
624
|
+
const quotePosition = kind === "quote" && typeof quote?.position === "number" && Number.isFinite(quote.position) ? Math.trunc(quote.position) : void 0;
|
|
625
|
+
const quoteEntities = kind === "quote" && Array.isArray(quote?.entities) ? quote.entities : void 0;
|
|
626
|
+
const forwardedFrom = replyLike ? normalizeForwardedContext(replyLike) ?? void 0 : void 0;
|
|
627
|
+
return {
|
|
628
|
+
id: replyLike?.message_id ? String(replyLike.message_id) : void 0,
|
|
629
|
+
sender: senderLabel,
|
|
630
|
+
senderId: replyLike?.from?.id != null ? String(replyLike.from.id) : void 0,
|
|
631
|
+
senderUsername: replyLike?.from?.username ?? void 0,
|
|
632
|
+
body: body || void 0,
|
|
633
|
+
kind,
|
|
634
|
+
source,
|
|
635
|
+
quoteText: kind === "quote" ? quoteText : void 0,
|
|
636
|
+
quotePosition,
|
|
637
|
+
quoteEntities,
|
|
638
|
+
forwardedFrom,
|
|
639
|
+
quoteSourceText: replyTextParts?.text || void 0,
|
|
640
|
+
quoteSourceEntities: replyTextParts?.entities
|
|
641
|
+
};
|
|
642
|
+
}
|
|
643
|
+
//#endregion
|
|
644
|
+
//#region extensions/telegram/src/format.ts
|
|
645
|
+
function escapeTelegramHtml(text) {
|
|
646
|
+
return text.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">");
|
|
647
|
+
}
|
|
648
|
+
function escapeHtml(text) {
|
|
649
|
+
return escapeTelegramHtml(text);
|
|
650
|
+
}
|
|
651
|
+
function escapeHtmlAttr(text) {
|
|
652
|
+
return escapeHtml(text).replace(/"/g, """);
|
|
653
|
+
}
|
|
654
|
+
/**
|
|
655
|
+
* File extensions that share TLDs and commonly appear in code/documentation.
|
|
656
|
+
* These are wrapped in <code> tags to prevent Telegram from generating
|
|
657
|
+
* spurious domain registrar previews.
|
|
658
|
+
*
|
|
659
|
+
* Only includes extensions that are:
|
|
660
|
+
* 1. Commonly used as file extensions in code/docs
|
|
661
|
+
* 2. Rarely used as intentional domain references
|
|
662
|
+
*
|
|
663
|
+
* Excluded: .ai, .io, .tv, .fm (popular domain TLDs like x.ai, vercel.io, github.io)
|
|
664
|
+
*/
|
|
665
|
+
function buildTelegramLink(link, text) {
|
|
666
|
+
const href = link.href.trim();
|
|
667
|
+
if (!href) return null;
|
|
668
|
+
if (link.start === link.end) return null;
|
|
669
|
+
if (isAutoLinkedFileRef(href, text.slice(link.start, link.end))) return null;
|
|
670
|
+
const safeHref = escapeHtmlAttr(href);
|
|
671
|
+
return {
|
|
672
|
+
start: link.start,
|
|
673
|
+
end: link.end,
|
|
674
|
+
open: `<a href="${safeHref}">`,
|
|
675
|
+
close: "</a>"
|
|
676
|
+
};
|
|
677
|
+
}
|
|
678
|
+
function buildTelegramCodeBlockOpen(span) {
|
|
679
|
+
if (!span.language) return "<pre><code>";
|
|
680
|
+
return `<pre><code class="language-${escapeHtmlAttr(span.language)}">`;
|
|
681
|
+
}
|
|
682
|
+
function renderTelegramHtml(ir) {
|
|
683
|
+
return renderMarkdownWithMarkers(ir, {
|
|
684
|
+
styleMarkers: {
|
|
685
|
+
bold: {
|
|
686
|
+
open: "<b>",
|
|
687
|
+
close: "</b>"
|
|
688
|
+
},
|
|
689
|
+
italic: {
|
|
690
|
+
open: "<i>",
|
|
691
|
+
close: "</i>"
|
|
692
|
+
},
|
|
693
|
+
strikethrough: {
|
|
694
|
+
open: "<s>",
|
|
695
|
+
close: "</s>"
|
|
696
|
+
},
|
|
697
|
+
code: {
|
|
698
|
+
open: "<code>",
|
|
699
|
+
close: "</code>"
|
|
700
|
+
},
|
|
701
|
+
code_block: {
|
|
702
|
+
open: buildTelegramCodeBlockOpen,
|
|
703
|
+
close: "</code></pre>"
|
|
704
|
+
},
|
|
705
|
+
spoiler: {
|
|
706
|
+
open: "<tg-spoiler>",
|
|
707
|
+
close: "</tg-spoiler>"
|
|
708
|
+
},
|
|
709
|
+
blockquote: {
|
|
710
|
+
open: "<blockquote>",
|
|
711
|
+
close: "</blockquote>"
|
|
712
|
+
}
|
|
713
|
+
},
|
|
714
|
+
escapeText: escapeHtml,
|
|
715
|
+
buildLink: buildTelegramLink
|
|
716
|
+
});
|
|
717
|
+
}
|
|
718
|
+
function leadingWhitespaceLength(line) {
|
|
719
|
+
let length = 0;
|
|
720
|
+
while (line[length] === " " || line[length] === " ") length++;
|
|
721
|
+
return length;
|
|
722
|
+
}
|
|
723
|
+
function isTelegramBulletLine(line) {
|
|
724
|
+
return /^[ \t]*(?:[•*+-])[ \t]+\S/.test(line);
|
|
725
|
+
}
|
|
726
|
+
function isTelegramListBoundaryLine(line) {
|
|
727
|
+
return /^[ \t]*(?:\d+\.|#{1,6})[ \t]+\S/.test(line);
|
|
728
|
+
}
|
|
729
|
+
function isMarkdownIndentedCodeLine(line) {
|
|
730
|
+
return /^(?: {4}|\t)/.test(line);
|
|
731
|
+
}
|
|
732
|
+
function shouldPreserveTelegramListBoundarySpacing(previous, next) {
|
|
733
|
+
return !isMarkdownIndentedCodeLine(previous) && !isMarkdownIndentedCodeLine(next) && isTelegramBulletLine(previous) && isTelegramListBoundaryLine(next) && leadingWhitespaceLength(next) <= leadingWhitespaceLength(previous);
|
|
734
|
+
}
|
|
735
|
+
function preserveTelegramListBoundarySpacing(markdown) {
|
|
736
|
+
const lines = markdown.split("\n");
|
|
737
|
+
const out = [];
|
|
738
|
+
let inFence = false;
|
|
739
|
+
let previousLine = "";
|
|
740
|
+
for (const line of lines) {
|
|
741
|
+
const normalizedLine = line.replace(/\r$/, "");
|
|
742
|
+
const isFenceLine = /^[ \t]*(?:```|~~~)/.test(normalizedLine);
|
|
743
|
+
if (!inFence && shouldPreserveTelegramListBoundarySpacing(previousLine, normalizedLine)) out.push("");
|
|
744
|
+
out.push(line);
|
|
745
|
+
if (isFenceLine) inFence = !inFence;
|
|
746
|
+
previousLine = normalizedLine;
|
|
747
|
+
}
|
|
748
|
+
return out.join("\n");
|
|
749
|
+
}
|
|
750
|
+
function markdownToTelegramHtml(markdown, options = {}) {
|
|
751
|
+
const telegramHtml = preserveSupportedTelegramHtmlTags(renderTelegramHtml(markdownToIR(preserveTelegramListBoundarySpacing(markdown ?? ""), {
|
|
752
|
+
linkify: true,
|
|
753
|
+
enableSpoilers: true,
|
|
754
|
+
headingStyle: "none",
|
|
755
|
+
blockquotePrefix: "",
|
|
756
|
+
tableMode: options.tableMode
|
|
757
|
+
})));
|
|
758
|
+
if (options.wrapFileRefs !== false) return wrapFileReferencesInHtml(telegramHtml);
|
|
759
|
+
return telegramHtml;
|
|
760
|
+
}
|
|
761
|
+
/**
|
|
762
|
+
* Wraps standalone file references (with TLD extensions) in <code> tags.
|
|
763
|
+
* This prevents Telegram from treating them as URLs and generating
|
|
764
|
+
* irrelevant domain registrar previews.
|
|
765
|
+
*
|
|
766
|
+
* Runs AFTER markdown→HTML conversion to avoid modifying HTML attributes.
|
|
767
|
+
* Skips content inside <code>, <pre>, and <a> tags to avoid nesting issues.
|
|
768
|
+
*/
|
|
769
|
+
/** Escape regex metacharacters in a string */
|
|
770
|
+
function escapeRegex(str) {
|
|
771
|
+
return str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
772
|
+
}
|
|
773
|
+
const AUTO_LINKED_ANCHOR_PATTERN = /<a\s+href="https?:\/\/([^"]+)"[^>]*>\1<\/a>/gi;
|
|
774
|
+
const HTML_TAG_PATTERN = /(<\/?)([a-zA-Z][a-zA-Z0-9-]*)\b[^>]*?>/gi;
|
|
775
|
+
const HTML_MODE_TAG_PATTERN = /^<(\/?)([a-zA-Z][a-zA-Z0-9-]*)([^<>]*)>$/;
|
|
776
|
+
const ESCAPED_HTML_TAG_PATTERN = /<(\/?)([a-zA-Z][a-zA-Z0-9-]*)(.*?)>/g;
|
|
777
|
+
const TELEGRAM_HTML_ANCHOR_PATTERN = /<a\b[^>]*\bhref\s*=\s*(?:"([^"]*)"|'([^']*)'|([^\s>]+))[^>]*>([\s\S]*?)<\/a\s*>/gi;
|
|
778
|
+
const TELEGRAM_HTML_BREAK_PATTERN = /<br\s*\/?>/gi;
|
|
779
|
+
const TELEGRAM_HTML_ENTITY_PATTERN = /&(#x[0-9A-Fa-f]+|#\d+|amp|lt|gt|quot|apos);/g;
|
|
780
|
+
const TELEGRAM_HTML_TAG_PATTERN = /<[^>]*>/g;
|
|
781
|
+
const TELEGRAM_SIMPLE_HTML_TAGS = new Set([
|
|
782
|
+
"b",
|
|
783
|
+
"strong",
|
|
784
|
+
"i",
|
|
785
|
+
"em",
|
|
786
|
+
"u",
|
|
787
|
+
"ins",
|
|
788
|
+
"s",
|
|
789
|
+
"strike",
|
|
790
|
+
"del",
|
|
791
|
+
"code",
|
|
792
|
+
"pre",
|
|
793
|
+
"tg-spoiler",
|
|
794
|
+
"blockquote"
|
|
795
|
+
]);
|
|
796
|
+
const TELEGRAM_ATTR_HTML_TAG_PATTERNS = new Map([
|
|
797
|
+
["a", /^\s+href="[^"]+"\s*$/],
|
|
798
|
+
["span", /^\s+class="tg-spoiler"\s*$/],
|
|
799
|
+
["tg-emoji", /^\s+emoji-id="[^"]+"\s*$/],
|
|
800
|
+
["tg-time", /^\s+datetime="[^"]+"\s*$/]
|
|
801
|
+
]);
|
|
802
|
+
let fileReferencePattern;
|
|
803
|
+
let orphanedTldPattern;
|
|
804
|
+
function popLastTagName(tags, name) {
|
|
805
|
+
for (let index = tags.length - 1; index >= 0; index -= 1) if (tags[index] === name) {
|
|
806
|
+
tags.splice(index, 1);
|
|
807
|
+
return true;
|
|
808
|
+
}
|
|
809
|
+
return false;
|
|
810
|
+
}
|
|
811
|
+
function isSupportedTelegramHtmlTag(rawTag) {
|
|
812
|
+
const match = HTML_MODE_TAG_PATTERN.exec(rawTag);
|
|
813
|
+
if (!match) return false;
|
|
814
|
+
const closing = match[1] === "/";
|
|
815
|
+
const name = normalizeLowercaseStringOrEmpty(match[2]);
|
|
816
|
+
const attrs = match[3] ?? "";
|
|
817
|
+
if (TELEGRAM_SIMPLE_HTML_TAGS.has(name)) return attrs.trim() === "";
|
|
818
|
+
if (closing) return attrs.trim() === "";
|
|
819
|
+
return TELEGRAM_ATTR_HTML_TAG_PATTERNS.get(name)?.test(attrs) ?? false;
|
|
820
|
+
}
|
|
821
|
+
function preserveTelegramHtmlTag(rawTag, openTags, escapeTag) {
|
|
822
|
+
const match = HTML_MODE_TAG_PATTERN.exec(rawTag);
|
|
823
|
+
if (!match || !isSupportedTelegramHtmlTag(rawTag)) return escapeTag(rawTag);
|
|
824
|
+
const closing = match[1] === "/";
|
|
825
|
+
const tagName = normalizeLowercaseStringOrEmpty(match[2]);
|
|
826
|
+
if (closing) return popLastTagName(openTags, tagName) ? rawTag : escapeTag(rawTag);
|
|
827
|
+
openTags.push(tagName);
|
|
828
|
+
return rawTag;
|
|
829
|
+
}
|
|
830
|
+
function escapeUnsupportedTelegramHtml(text) {
|
|
831
|
+
let result = "";
|
|
832
|
+
let index = 0;
|
|
833
|
+
const openTags = [];
|
|
834
|
+
while (index < text.length) {
|
|
835
|
+
const char = text[index];
|
|
836
|
+
if (char === "&") {
|
|
837
|
+
const entityEnd = findTelegramHtmlEntityEnd(text, index);
|
|
838
|
+
if (entityEnd !== -1) {
|
|
839
|
+
result += text.slice(index, entityEnd + 1);
|
|
840
|
+
index = entityEnd + 1;
|
|
841
|
+
} else {
|
|
842
|
+
result += "&";
|
|
843
|
+
index += 1;
|
|
844
|
+
}
|
|
845
|
+
continue;
|
|
846
|
+
}
|
|
847
|
+
if (char === "<") {
|
|
848
|
+
const end = text.indexOf(">", index + 1);
|
|
849
|
+
if (end !== -1) {
|
|
850
|
+
const rawTag = text.slice(index, end + 1);
|
|
851
|
+
result += preserveTelegramHtmlTag(rawTag, openTags, escapeHtml);
|
|
852
|
+
index = end + 1;
|
|
853
|
+
} else {
|
|
854
|
+
result += "<";
|
|
855
|
+
index += 1;
|
|
856
|
+
}
|
|
857
|
+
continue;
|
|
858
|
+
}
|
|
859
|
+
if (char === ">") {
|
|
860
|
+
result += ">";
|
|
861
|
+
index += 1;
|
|
862
|
+
continue;
|
|
863
|
+
}
|
|
864
|
+
result += char;
|
|
865
|
+
index += 1;
|
|
866
|
+
}
|
|
867
|
+
return result;
|
|
868
|
+
}
|
|
869
|
+
function decodeTelegramHtmlEntity(entity, fallback) {
|
|
870
|
+
if (entity.startsWith("#x") || entity.startsWith("#X")) {
|
|
871
|
+
const codePoint = Number.parseInt(entity.slice(2), 16);
|
|
872
|
+
return Number.isInteger(codePoint) && codePoint >= 0 && codePoint <= 1114111 ? String.fromCodePoint(codePoint) : fallback;
|
|
873
|
+
}
|
|
874
|
+
if (entity.startsWith("#")) {
|
|
875
|
+
const codePoint = Number.parseInt(entity.slice(1), 10);
|
|
876
|
+
return Number.isInteger(codePoint) && codePoint >= 0 && codePoint <= 1114111 ? String.fromCodePoint(codePoint) : fallback;
|
|
877
|
+
}
|
|
878
|
+
switch (entity) {
|
|
879
|
+
case "amp": return "&";
|
|
880
|
+
case "lt": return "<";
|
|
881
|
+
case "gt": return ">";
|
|
882
|
+
case "quot": return "\"";
|
|
883
|
+
case "apos": return "'";
|
|
884
|
+
default: return fallback;
|
|
885
|
+
}
|
|
886
|
+
}
|
|
887
|
+
function decodeTelegramHtmlEntities(text) {
|
|
888
|
+
return text.replace(TELEGRAM_HTML_ENTITY_PATTERN, (match, entity) => decodeTelegramHtmlEntity(entity, match));
|
|
889
|
+
}
|
|
890
|
+
function stripTelegramHtmlForPlainText(html) {
|
|
891
|
+
return decodeTelegramHtmlEntities(html.replace(TELEGRAM_HTML_BREAK_PATTERN, "\n").replace(TELEGRAM_HTML_TAG_PATTERN, ""));
|
|
892
|
+
}
|
|
893
|
+
function encodePlainTextForTelegramHtmlStrip(text) {
|
|
894
|
+
return text.replace(/[&<>]/g, (char) => {
|
|
895
|
+
switch (char) {
|
|
896
|
+
case "&": return "&";
|
|
897
|
+
case "<": return "<";
|
|
898
|
+
case ">": return ">";
|
|
899
|
+
default: return char;
|
|
900
|
+
}
|
|
901
|
+
});
|
|
902
|
+
}
|
|
903
|
+
function telegramHtmlToPlainTextFallback(html) {
|
|
904
|
+
TELEGRAM_HTML_ANCHOR_PATTERN.lastIndex = 0;
|
|
905
|
+
return stripTelegramHtmlForPlainText(html.replace(TELEGRAM_HTML_ANCHOR_PATTERN, (_match, doubleQuotedHref, singleQuotedHref, unquotedHref, labelHtml) => {
|
|
906
|
+
const href = decodeTelegramHtmlEntities(doubleQuotedHref ?? singleQuotedHref ?? unquotedHref ?? "").trim();
|
|
907
|
+
const label = stripTelegramHtmlForPlainText(labelHtml).trim();
|
|
908
|
+
if (!href) return encodePlainTextForTelegramHtmlStrip(label);
|
|
909
|
+
return encodePlainTextForTelegramHtmlStrip(!label || label === href ? href : `${label} (${href})`);
|
|
910
|
+
}));
|
|
911
|
+
}
|
|
912
|
+
function promoteEscapedSupportedTelegramTags(text, openTags) {
|
|
913
|
+
ESCAPED_HTML_TAG_PATTERN.lastIndex = 0;
|
|
914
|
+
return text.replace(ESCAPED_HTML_TAG_PATTERN, (match, closing, name, attrs) => preserveTelegramHtmlTag(`<${closing}${name}${attrs}>`, openTags, () => match));
|
|
915
|
+
}
|
|
916
|
+
function preserveSupportedTelegramHtmlTags(html) {
|
|
917
|
+
let codeDepth = 0;
|
|
918
|
+
let preDepth = 0;
|
|
919
|
+
let result = "";
|
|
920
|
+
let lastIndex = 0;
|
|
921
|
+
const openEscapedTags = [];
|
|
922
|
+
HTML_TAG_PATTERN.lastIndex = 0;
|
|
923
|
+
let match;
|
|
924
|
+
while ((match = HTML_TAG_PATTERN.exec(html)) !== null) {
|
|
925
|
+
const tagStart = match.index;
|
|
926
|
+
const tagEnd = HTML_TAG_PATTERN.lastIndex;
|
|
927
|
+
const tagName = normalizeLowercaseStringOrEmpty(match[2]);
|
|
928
|
+
const isClosing = match[1] === "</";
|
|
929
|
+
const textBefore = html.slice(lastIndex, tagStart);
|
|
930
|
+
result += codeDepth > 0 || preDepth > 0 ? textBefore : promoteEscapedSupportedTelegramTags(textBefore, openEscapedTags);
|
|
931
|
+
if (tagName === "code") codeDepth = isClosing ? Math.max(0, codeDepth - 1) : codeDepth + 1;
|
|
932
|
+
else if (tagName === "pre") preDepth = isClosing ? Math.max(0, preDepth - 1) : preDepth + 1;
|
|
933
|
+
result += html.slice(tagStart, tagEnd);
|
|
934
|
+
lastIndex = tagEnd;
|
|
935
|
+
}
|
|
936
|
+
const remainingText = html.slice(lastIndex);
|
|
937
|
+
result += codeDepth > 0 || preDepth > 0 ? remainingText : promoteEscapedSupportedTelegramTags(remainingText, openEscapedTags);
|
|
938
|
+
return result;
|
|
939
|
+
}
|
|
940
|
+
function getFileReferencePattern() {
|
|
941
|
+
if (fileReferencePattern) return fileReferencePattern;
|
|
942
|
+
const fileExtensionsPattern = Array.from(FILE_REF_EXTENSIONS_WITH_TLD).map(escapeRegex).join("|");
|
|
943
|
+
fileReferencePattern = new RegExp(`(^|[^a-zA-Z0-9_\\-/])([a-zA-Z0-9_.\\-./]+\\.(?:${fileExtensionsPattern}))(?=$|[^a-zA-Z0-9_\\-/])`, "gi");
|
|
944
|
+
return fileReferencePattern;
|
|
945
|
+
}
|
|
946
|
+
function getOrphanedTldPattern() {
|
|
947
|
+
if (orphanedTldPattern) return orphanedTldPattern;
|
|
948
|
+
const fileExtensionsPattern = Array.from(FILE_REF_EXTENSIONS_WITH_TLD).map(escapeRegex).join("|");
|
|
949
|
+
orphanedTldPattern = new RegExp(`([^a-zA-Z0-9]|^)([A-Za-z]\\.(?:${fileExtensionsPattern}))(?=[^a-zA-Z0-9/]|$)`, "g");
|
|
950
|
+
return orphanedTldPattern;
|
|
951
|
+
}
|
|
952
|
+
function wrapStandaloneFileRef(match, prefix, filename) {
|
|
953
|
+
if (filename.startsWith("//")) return match;
|
|
954
|
+
if (/https?:\/\/$/i.test(prefix)) return match;
|
|
955
|
+
return `${prefix}<code>${escapeHtml(filename)}</code>`;
|
|
956
|
+
}
|
|
957
|
+
function wrapSegmentFileRefs(text, codeDepth, preDepth, anchorDepth) {
|
|
958
|
+
if (!text || codeDepth > 0 || preDepth > 0 || anchorDepth > 0) return text;
|
|
959
|
+
return text.replace(getFileReferencePattern(), wrapStandaloneFileRef).replace(getOrphanedTldPattern(), (match, prefix, tld) => prefix === ">" ? match : `${prefix}<code>${escapeHtml(tld)}</code>`);
|
|
960
|
+
}
|
|
961
|
+
function wrapFileReferencesInHtml(html) {
|
|
962
|
+
AUTO_LINKED_ANCHOR_PATTERN.lastIndex = 0;
|
|
963
|
+
const deLinkified = html.replace(AUTO_LINKED_ANCHOR_PATTERN, (_match, label) => {
|
|
964
|
+
if (!isAutoLinkedFileRef(`http://${label}`, label)) return _match;
|
|
965
|
+
return `<code>${escapeHtml(label)}</code>`;
|
|
966
|
+
});
|
|
967
|
+
let codeDepth = 0;
|
|
968
|
+
let preDepth = 0;
|
|
969
|
+
let anchorDepth = 0;
|
|
970
|
+
let result = "";
|
|
971
|
+
let lastIndex = 0;
|
|
972
|
+
HTML_TAG_PATTERN.lastIndex = 0;
|
|
973
|
+
let match;
|
|
974
|
+
while ((match = HTML_TAG_PATTERN.exec(deLinkified)) !== null) {
|
|
975
|
+
const tagStart = match.index;
|
|
976
|
+
const tagEnd = HTML_TAG_PATTERN.lastIndex;
|
|
977
|
+
const isClosing = match[1] === "</";
|
|
978
|
+
const tagName = normalizeLowercaseStringOrEmpty(match[2]);
|
|
979
|
+
const textBefore = deLinkified.slice(lastIndex, tagStart);
|
|
980
|
+
result += wrapSegmentFileRefs(textBefore, codeDepth, preDepth, anchorDepth);
|
|
981
|
+
if (tagName === "code") codeDepth = isClosing ? Math.max(0, codeDepth - 1) : codeDepth + 1;
|
|
982
|
+
else if (tagName === "pre") preDepth = isClosing ? Math.max(0, preDepth - 1) : preDepth + 1;
|
|
983
|
+
else if (tagName === "a") anchorDepth = isClosing ? Math.max(0, anchorDepth - 1) : anchorDepth + 1;
|
|
984
|
+
result += deLinkified.slice(tagStart, tagEnd);
|
|
985
|
+
lastIndex = tagEnd;
|
|
986
|
+
}
|
|
987
|
+
const remainingText = deLinkified.slice(lastIndex);
|
|
988
|
+
result += wrapSegmentFileRefs(remainingText, codeDepth, preDepth, anchorDepth);
|
|
989
|
+
return result;
|
|
990
|
+
}
|
|
991
|
+
function renderTelegramHtmlText(text, options = {}) {
|
|
992
|
+
if ((options.textMode ?? "markdown") === "html") return escapeUnsupportedTelegramHtml(text);
|
|
993
|
+
return markdownToTelegramHtml(text, { tableMode: options.tableMode });
|
|
994
|
+
}
|
|
995
|
+
const TELEGRAM_SELF_CLOSING_HTML_TAGS = new Set(["br"]);
|
|
996
|
+
function buildTelegramHtmlOpenPrefix(tags) {
|
|
997
|
+
return tags.map((tag) => tag.openTag).join("");
|
|
998
|
+
}
|
|
999
|
+
function buildTelegramHtmlCloseSuffix(tags) {
|
|
1000
|
+
return tags.slice().toReversed().map((tag) => tag.closeTag).join("");
|
|
1001
|
+
}
|
|
1002
|
+
function buildTelegramHtmlCloseSuffixLength(tags) {
|
|
1003
|
+
return tags.reduce((total, tag) => total + tag.closeTag.length, 0);
|
|
1004
|
+
}
|
|
1005
|
+
function findTelegramHtmlEntityEnd(text, start) {
|
|
1006
|
+
if (text[start] !== "&") return -1;
|
|
1007
|
+
let index = start + 1;
|
|
1008
|
+
if (index >= text.length) return -1;
|
|
1009
|
+
if (text[index] === "#") {
|
|
1010
|
+
index += 1;
|
|
1011
|
+
if (index >= text.length) return -1;
|
|
1012
|
+
if (text[index] === "x" || text[index] === "X") {
|
|
1013
|
+
index += 1;
|
|
1014
|
+
const hexStart = index;
|
|
1015
|
+
while (/[0-9A-Fa-f]/.test(text[index] ?? "")) index += 1;
|
|
1016
|
+
if (index === hexStart) return -1;
|
|
1017
|
+
} else {
|
|
1018
|
+
const digitStart = index;
|
|
1019
|
+
while (/[0-9]/.test(text[index] ?? "")) index += 1;
|
|
1020
|
+
if (index === digitStart) return -1;
|
|
1021
|
+
}
|
|
1022
|
+
} else {
|
|
1023
|
+
const nameStart = index;
|
|
1024
|
+
while (/[A-Za-z0-9]/.test(text[index] ?? "")) index += 1;
|
|
1025
|
+
if (index === nameStart) return -1;
|
|
1026
|
+
}
|
|
1027
|
+
return text[index] === ";" ? index : -1;
|
|
1028
|
+
}
|
|
1029
|
+
function findTelegramHtmlSafeSplitIndex(text, maxLength) {
|
|
1030
|
+
if (text.length <= maxLength) return text.length;
|
|
1031
|
+
const normalizedMaxLength = Math.max(1, Math.floor(maxLength));
|
|
1032
|
+
const lastAmpersand = text.lastIndexOf("&", normalizedMaxLength - 1);
|
|
1033
|
+
if (lastAmpersand === -1) return normalizedMaxLength;
|
|
1034
|
+
if (lastAmpersand < text.lastIndexOf(";", normalizedMaxLength - 1)) return normalizedMaxLength;
|
|
1035
|
+
const entityEnd = findTelegramHtmlEntityEnd(text, lastAmpersand);
|
|
1036
|
+
if (entityEnd === -1 || entityEnd < normalizedMaxLength) return normalizedMaxLength;
|
|
1037
|
+
return lastAmpersand;
|
|
1038
|
+
}
|
|
1039
|
+
function popTelegramHtmlTag(tags, name) {
|
|
1040
|
+
for (let index = tags.length - 1; index >= 0; index -= 1) if (tags[index]?.name === name) {
|
|
1041
|
+
tags.splice(index, 1);
|
|
1042
|
+
return;
|
|
1043
|
+
}
|
|
1044
|
+
}
|
|
1045
|
+
function splitTelegramHtmlChunks(html, limit) {
|
|
1046
|
+
if (!html) return [];
|
|
1047
|
+
const normalizedLimit = Math.max(1, Math.floor(limit));
|
|
1048
|
+
if (html.length <= normalizedLimit) return [html];
|
|
1049
|
+
const chunks = [];
|
|
1050
|
+
const openTags = [];
|
|
1051
|
+
let current = "";
|
|
1052
|
+
let chunkHasPayload = false;
|
|
1053
|
+
const resetCurrent = () => {
|
|
1054
|
+
current = buildTelegramHtmlOpenPrefix(openTags);
|
|
1055
|
+
chunkHasPayload = false;
|
|
1056
|
+
};
|
|
1057
|
+
const flushCurrent = () => {
|
|
1058
|
+
if (!chunkHasPayload) return;
|
|
1059
|
+
chunks.push(`${current}${buildTelegramHtmlCloseSuffix(openTags)}`);
|
|
1060
|
+
resetCurrent();
|
|
1061
|
+
};
|
|
1062
|
+
const appendText = (segment) => {
|
|
1063
|
+
let remaining = segment;
|
|
1064
|
+
while (remaining.length > 0) {
|
|
1065
|
+
const available = normalizedLimit - current.length - buildTelegramHtmlCloseSuffixLength(openTags);
|
|
1066
|
+
if (available <= 0) {
|
|
1067
|
+
if (!chunkHasPayload) throw new Error(`Telegram HTML chunk limit exceeded by tag overhead (limit=${normalizedLimit})`);
|
|
1068
|
+
flushCurrent();
|
|
1069
|
+
continue;
|
|
1070
|
+
}
|
|
1071
|
+
if (remaining.length <= available) {
|
|
1072
|
+
current += remaining;
|
|
1073
|
+
chunkHasPayload = true;
|
|
1074
|
+
break;
|
|
1075
|
+
}
|
|
1076
|
+
const splitAt = findTelegramHtmlSafeSplitIndex(remaining, available);
|
|
1077
|
+
if (splitAt <= 0) {
|
|
1078
|
+
if (!chunkHasPayload) throw new Error(`Telegram HTML chunk limit exceeded by leading entity (limit=${normalizedLimit})`);
|
|
1079
|
+
flushCurrent();
|
|
1080
|
+
continue;
|
|
1081
|
+
}
|
|
1082
|
+
current += remaining.slice(0, splitAt);
|
|
1083
|
+
chunkHasPayload = true;
|
|
1084
|
+
remaining = remaining.slice(splitAt);
|
|
1085
|
+
flushCurrent();
|
|
1086
|
+
}
|
|
1087
|
+
};
|
|
1088
|
+
resetCurrent();
|
|
1089
|
+
HTML_TAG_PATTERN.lastIndex = 0;
|
|
1090
|
+
let lastIndex = 0;
|
|
1091
|
+
let match;
|
|
1092
|
+
while ((match = HTML_TAG_PATTERN.exec(html)) !== null) {
|
|
1093
|
+
const tagStart = match.index;
|
|
1094
|
+
const tagEnd = HTML_TAG_PATTERN.lastIndex;
|
|
1095
|
+
appendText(html.slice(lastIndex, tagStart));
|
|
1096
|
+
const rawTag = match[0];
|
|
1097
|
+
const isClosing = match[1] === "</";
|
|
1098
|
+
const tagName = normalizeLowercaseStringOrEmpty(match[2]);
|
|
1099
|
+
const isSelfClosing = !isClosing && (TELEGRAM_SELF_CLOSING_HTML_TAGS.has(tagName) || rawTag.trimEnd().endsWith("/>"));
|
|
1100
|
+
if (!isClosing) {
|
|
1101
|
+
const nextCloseLength = isSelfClosing ? 0 : `</${tagName}>`.length;
|
|
1102
|
+
if (chunkHasPayload && current.length + rawTag.length + buildTelegramHtmlCloseSuffixLength(openTags) + nextCloseLength > normalizedLimit) flushCurrent();
|
|
1103
|
+
}
|
|
1104
|
+
current += rawTag;
|
|
1105
|
+
if (isSelfClosing) chunkHasPayload = true;
|
|
1106
|
+
if (isClosing) popTelegramHtmlTag(openTags, tagName);
|
|
1107
|
+
else if (!isSelfClosing) openTags.push({
|
|
1108
|
+
name: tagName,
|
|
1109
|
+
openTag: rawTag,
|
|
1110
|
+
closeTag: `</${tagName}>`
|
|
1111
|
+
});
|
|
1112
|
+
lastIndex = tagEnd;
|
|
1113
|
+
}
|
|
1114
|
+
appendText(html.slice(lastIndex));
|
|
1115
|
+
flushCurrent();
|
|
1116
|
+
return chunks.length > 0 ? chunks : [html];
|
|
1117
|
+
}
|
|
1118
|
+
function renderTelegramChunkHtml(ir) {
|
|
1119
|
+
return wrapFileReferencesInHtml(preserveSupportedTelegramHtmlTags(renderTelegramHtml(ir)));
|
|
1120
|
+
}
|
|
1121
|
+
function renderTelegramChunksWithinHtmlLimit(ir, limit) {
|
|
1122
|
+
return renderMarkdownIRChunksWithinLimit({
|
|
1123
|
+
ir,
|
|
1124
|
+
limit,
|
|
1125
|
+
renderChunk: renderTelegramChunkHtml,
|
|
1126
|
+
measureRendered: (html) => html.length
|
|
1127
|
+
}).map(({ source, rendered }) => ({
|
|
1128
|
+
html: rendered,
|
|
1129
|
+
text: source.text
|
|
1130
|
+
}));
|
|
1131
|
+
}
|
|
1132
|
+
function markdownToTelegramChunks(markdown, limit, options = {}) {
|
|
1133
|
+
return renderTelegramChunksWithinHtmlLimit(markdownToIR(preserveTelegramListBoundarySpacing(markdown ?? ""), {
|
|
1134
|
+
linkify: true,
|
|
1135
|
+
enableSpoilers: true,
|
|
1136
|
+
headingStyle: "none",
|
|
1137
|
+
blockquotePrefix: "",
|
|
1138
|
+
tableMode: options.tableMode
|
|
1139
|
+
}), limit);
|
|
1140
|
+
}
|
|
1141
|
+
function markdownToTelegramHtmlChunks(markdown, limit, options = {}) {
|
|
1142
|
+
return markdownToTelegramChunks(markdown, limit, options).map((chunk) => chunk.html);
|
|
1143
|
+
}
|
|
1144
|
+
//#endregion
|
|
1145
|
+
export { shouldUseTelegramDmThreadSession as A, resolveTelegramMediaPlaceholder as B, resolveTelegramForumFlag as C, resolveTelegramReplyId as D, resolveTelegramMessageForumFlagHint as E, extractTelegramLocation as F, normalizeAllowFrom as G, expandTelegramAllowFromWithAccessGroups as H, getTelegramTextParts as I, normalizeTelegramReplyToMessageId as J, normalizeDmAllowFromWithStore as K, hasBotMention as L, buildSenderLabel as M, buildSenderName as N, resolveTelegramStreamMode as O, expandTextLinks as P, isBinaryContent as R, resolveTelegramDirectPeerId as S, resolveTelegramGroupAllowFromContext as T, resolveTelegramDmAllow as U, resolveTelegramPrimaryMedia as V, isSenderAllowed as W, parseTelegramThreadId as X, parseTelegramReplyToMessageId as Y, describeReplyTarget as _, renderTelegramHtmlText as a, resetTelegramForumFlagCacheForTest as b, wrapFileReferencesInHtml as c, buildTelegramGroupPeerId as d, buildTelegramInboundOriginTarget as f, buildTypingThreadParams as g, buildTelegramThreadParams as h, markdownToTelegramHtmlChunks as i, withResolvedTelegramForumFlag as j, resolveTelegramThreadSpec as k, buildGroupLabel as l, buildTelegramRoutingTarget as m, markdownToTelegramChunks as n, splitTelegramHtmlChunks as o, buildTelegramParentPeer as p, resolveTelegramEffectiveDmPolicy as q, markdownToTelegramHtml as r, telegramHtmlToPlainTextFallback as s, escapeTelegramHtml as t, buildTelegramGroupFrom as u, extractTelegramForumFlag as v, resolveTelegramForumThreadId as w, resolveTelegramCommandAuthorization as x, isTelegramCommandsAllowFromConfigured as y, normalizeForwardedContext as z };
|