fengming 0.3.7 → 0.3.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -0
- package/dist/abort-CCR8oZyg.js +277 -0
- package/dist/abort.runtime-eqx84NZa.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/acp-spawn-BcDyvaXh.js +2 -0
- package/dist/acp-spawn-CCtSel-_.js +1286 -0
- package/dist/acp-stateful-target-driver-B3pCvuOV.js +89 -0
- package/dist/active-tool-schema-warnings-Cf-5q5WU.js +105 -0
- package/dist/active-tool-schema-warnings-Dzt3XE-y.js +2 -0
- package/dist/agent-1M2dVE2G.js +2 -0
- package/dist/agent-DLDIbUT4.js +1825 -0
- package/dist/agent-DZi6j3o6.js +3 -0
- package/dist/agent-command-ppfDBwET.js +1435 -0
- package/dist/agent-harness-runtime-C0bo62eY.d.ts +913 -0
- package/dist/agent-harness-runtime-RkTGiliR.js +207 -0
- package/dist/agent-runner-utils-B4YeVAO_.js +267 -0
- package/dist/agent-runner.runtime-T_3tlZN1.js +3784 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-CloshyK-.d.ts +207 -0
- package/dist/agent-runtime-DZsmp1xr.js +199 -0
- package/dist/agent-tools-CET9usCz.js +2506 -0
- package/dist/agent-via-gateway-CZ0X0YkM.js +486 -0
- package/dist/agent-wait-dedupe-I81_F2tr.js +180 -0
- package/dist/agents/embedded-agent-runner/run/runtime-context-prompt.d.ts +1 -1
- package/dist/agents/embedded-agent-runner/tool-split.d.ts +1 -1
- package/dist/agents/model-catalog.runtime.d.ts +1 -1
- package/dist/api-BDB5xHYj.js +3 -0
- package/dist/api-BH7bfI5d.js +6 -0
- package/dist/api-BxJNXitd.js +2 -0
- package/dist/approval-client-helpers-CfQA9Jzh.d.ts +78 -0
- package/dist/approval-native-helpers-B2zyhxWc.d.ts +241 -0
- package/dist/approval-renderers-CMqSXyvm.d.ts +39 -0
- package/dist/assistant-Cu_Mzzgu.js +291 -0
- package/dist/attachment-normalize-Bb3v5iCC.js +213 -0
- package/dist/attempt-execution-BskbAq5I.js +584 -0
- package/dist/attempt-execution.runtime-BuT1wpNS.js +3 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt.prompt-helpers-ByKj-vQ7.js +543 -0
- package/dist/auto-reply/reply/commands-crestodian.d.ts +1 -1
- package/dist/binding-routing-EGRNvRC4.js +113 -0
- package/dist/binding-targets-B9vYS8n6.js +121 -0
- package/dist/bridge-server-DG9YtKQe.js +113 -0
- package/dist/browser-cli-B0Ou-Nbm.js +2 -0
- package/dist/browser-cli-GF25gL6M.js +230 -0
- package/dist/browser-cli-actions-input-CuER6RVe.js +522 -0
- package/dist/browser-cli-actions-observe-Dq-Zz_FA.js +81 -0
- package/dist/browser-cli-debug-7hvb49S1.js +137 -0
- package/dist/browser-cli-inspect-WU5KeWOK.js +117 -0
- package/dist/browser-cli-manage-B9D9BvSe.js +446 -0
- package/dist/browser-cli-resize-BUOusOPb.js +32 -0
- package/dist/browser-cli-shared-DmpSN-Qi.js +69 -0
- package/dist/browser-cli-state-D_YxTqRw.js +371 -0
- package/dist/browser-control-auth-Cqd1n9FA.js +2 -0
- package/dist/browser-profiles-9tQ05wYh.js +2 -0
- package/dist/browser-runtime-Bbzumoha.js +389 -0
- package/dist/build-CBXuT2K1.js +261 -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/bundled-channel-config-schema-DpdKMATU.d.ts +3168 -0
- package/dist/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/capability-cli-CiVGX7ut.js +1809 -0
- package/dist/channel-BIVwHq7P.js +2309 -0
- package/dist/channel-CiA2FVdL.d.ts +427 -0
- package/dist/channel-core-Cj9JTqeu.js +5 -0
- package/dist/channel-core-DjVpcH1C.d.ts +6 -0
- package/dist/channel-entry-contract-Bs_54m1D.d.ts +114 -0
- package/dist/channel-inbound-CdUdeQRa.js +121 -0
- package/dist/channel-inbound-iGiqx6CS.d.ts +97 -0
- package/dist/channel-message-C3QPaDUk.js +12 -0
- package/dist/channel-message-CXDjxb2U.d.ts +9 -0
- package/dist/channel-outbound-ofvvmMSK.d.ts +325 -0
- package/dist/channel-pairing-DKscOV1K.d.ts +58 -0
- package/dist/channel.runtime-VW6PW_ez.js +697 -0
- package/dist/channel.runtime.js +1 -1
- package/dist/chat-CFkQepUQ.js +3 -0
- package/dist/chat-Czh_tXM0.js +2940 -0
- package/dist/chrome-B2cq8YyH.js +1517 -0
- package/dist/cli/run-main.js +5 -5
- package/dist/cli-compaction-Dxv4nt7R.js +363 -0
- package/dist/cli-runner-CimXSTVs.js +2 -0
- package/dist/cli-runner-orCzE1Sr.js +597 -0
- package/dist/cli-runner.runtime-CsW0dXJW.js +3 -0
- package/dist/cli-runner.runtime-DgPrc1do.js +4 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +10 -12
- package/dist/command-registry-C5ooX6PF.js +4 -0
- package/dist/command-registry-DMB-HKIk.js +9 -0
- package/dist/command-registry-core-B2w_XWvn.js +114 -0
- package/dist/command-status.runtime-Bdy3Dkar.js +90 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-compact.runtime-Bk2jTQo6.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-handlers.runtime-Csw1og0U.js +6327 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-mRqmLIVz.d.ts +117 -0
- package/dist/commands-status-Dgrj_ubK.js +3 -0
- package/dist/commands-status-s32HJOpD.js +16 -0
- package/dist/commands-status.runtime-Dgrj_ubK.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-C_hnOO9l.js +2 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-CQV742Cc.js +2 -0
- package/dist/commands-system-prompt-DTfsKwK1.js +161 -0
- package/dist/commands-types-MXHhrssO.d.ts +132 -0
- package/dist/commands.runtime-akiVK67l.js +175 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/commitments/runtime.js +1 -1
- package/dist/compact-U6ZhvPtD.js +1165 -0
- package/dist/compact.runtime-36E5vKsC.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-Bf4mEw2W.js +393 -0
- package/dist/config-BJJhHN9E.js +374 -0
- package/dist/config-mutations-swLu-j_p.js +161 -0
- package/dist/config-schema-Tjner6bM.d.ts +20 -0
- package/dist/context-engine-host-compat-6fkn_daV.js +280 -0
- package/dist/context-engine-host-compat-DtAZC1bS.js +2 -0
- package/dist/context-engine-lifecycle-R__Idxi1.js +627 -0
- package/dist/control-auth-DnkI94_D.js +114 -0
- package/dist/control-service-BBsamNjq.js +40 -0
- package/dist/control-service-BGpHj7RL.js +3 -0
- package/dist/control-ui/assets/activity-B2W-IeAT.js +124 -0
- package/dist/control-ui/assets/agents-mRUyNVCz.js +1030 -0
- package/dist/control-ui/assets/channels-8QHOqBnt.js +120 -0
- package/dist/control-ui/assets/cron-H3unP_mO.js +1016 -0
- package/dist/control-ui/assets/debug-CxLsQ9vH.js +97 -0
- package/dist/control-ui/assets/index-jtIYT0Eh.js +7214 -0
- package/dist/control-ui/assets/instances-B1JQeCRb.js +57 -0
- package/dist/control-ui/assets/nodes-RGOmq_1l.js +444 -0
- package/dist/control-ui/assets/sessions-C2O-Jgpg.js +425 -0
- package/dist/control-ui/assets/skills-jyJOYA4I.js +362 -0
- package/dist/control-ui/assets/workboard-uM_kK8cQ.js +402 -0
- package/dist/control-ui/index.html +1 -1
- package/dist/control-ui/sw.js +1 -1
- package/dist/conversation-runtime-DDekWU-U.js +31 -0
- package/dist/core-Bpk-qSJH.js +284 -0
- package/dist/core-Chrz4oRB.d.ts +223 -0
- package/dist/core-api-DSpUKNVW.js +2 -0
- package/dist/core-api-hLsW03Wo.js +5 -0
- package/dist/crestodian/crestodian.js +1 -1
- package/dist/crestodian/rescue-message.d.ts +1 -1
- package/dist/crestodian/rescue-message.js +1 -1
- package/dist/crestodian-C0x7JjF-.js +55 -0
- package/dist/delegate-BArFIZ4B.d.ts +30 -0
- package/dist/deliver-BnVp3VbL.d.ts +111 -0
- package/dist/delivery-queue-BFOASdf5.d.ts +161 -0
- package/dist/delivery-queue-runtime-BFfc8AEs.d.ts +9 -0
- package/dist/dialogue-No0NvYX7.js +37 -0
- package/dist/direct-dm-C-h88JJH.d.ts +79 -0
- package/dist/directive-handling.fast-lane-DTyDKhZb.js +70 -0
- package/dist/directive-handling.impl-DMReM6tu.js +2 -0
- package/dist/directive-handling.impl-DzPouhV-.js +823 -0
- package/dist/directive-handling.model-selection-BjwTBAZJ.js +122 -0
- package/dist/directive-handling.persist.runtime-D_O1okkR.js +274 -0
- package/dist/directive-handling.persist.runtime.js +1 -1
- package/dist/dispatch-Dtl-oRuN.js +2057 -0
- package/dist/dispatch-acp-transcript.runtime-M4y0Dq74.js +40 -0
- package/dist/dispatch-acp-transcript.runtime.js +1 -1
- package/dist/dispatch-acp.runtime-B8uCIKZS.js +18 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/dispatcher-DslvaRcj.js +106 -0
- package/dist/doctor-config-flow-LU2C94af.js +1819 -0
- package/dist/doctor-core-checks-BqcjExIZ.js +666 -0
- package/dist/doctor-core-checks-Diuk8l0N.js +2 -0
- package/dist/doctor-core-checks.runtime-DbS-kMZN.js +278 -0
- package/dist/doctor-core-checks.runtime.js +1 -1
- package/dist/doctor-health-BdqHwfYE.js +65 -0
- package/dist/doctor-health-contributions-DLLTVnll.js +874 -0
- package/dist/doctor-lint-PZqkVMWf.js +95 -0
- package/dist/doctor-mRfJMSb5.js +6 -0
- package/dist/doctor-state-integrity-Cdlm-peH.js +1257 -0
- package/dist/draft-stream-controls-B7uLonbw.d.ts +159 -0
- package/dist/embedded-agent-CEpOPW6X.js +4 -0
- package/dist/embedded-agent-CNINO_M-.d.ts +5 -0
- package/dist/embedded-agent-DxwzoZkp.js +4074 -0
- package/dist/embedded-agent.runtime-DDbhA85-.js +4 -0
- package/dist/embedded-agent.runtime.js +1 -1
- package/dist/embedded-backend-ChaKCepC.js +1581 -0
- package/dist/embedded-gateway-stub.runtime-e_ZxGhcW.js +12 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/entry.d.ts +1 -1
- package/dist/extensionAPI.d.ts +2 -2
- package/dist/extensionAPI.js +1 -1
- package/dist/extensions/active-memory/index.d.ts +1 -1
- package/dist/extensions/active-memory/index.js +1 -1
- package/dist/extensions/admin-http-rpc/index.d.ts +1 -1
- package/dist/extensions/admin-http-rpc/index.js +1 -1
- package/dist/extensions/bonjour/index.d.ts +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 +12 -12
- package/dist/extensions/browser/cli-metadata.d.ts +1 -1
- package/dist/extensions/browser/cli-metadata.js +1 -1
- package/dist/extensions/browser/index.d.ts +1 -1
- package/dist/extensions/browser/index.js +1 -1
- package/dist/extensions/browser/plugin-registration.d.ts +1 -1
- package/dist/extensions/browser/plugin-registration.js +1 -1
- package/dist/extensions/browser/register.runtime.d.ts +2 -2
- package/dist/extensions/browser/register.runtime.js +4 -4
- package/dist/extensions/browser/runtime-api.d.ts +3 -3
- package/dist/extensions/browser/runtime-api.js +14 -14
- package/dist/extensions/browser/setup-api.d.ts +1 -1
- package/dist/extensions/canvas/cli-metadata.d.ts +1 -1
- package/dist/extensions/canvas/index.d.ts +1 -1
- package/dist/extensions/canvas/index.js +1 -1
- package/dist/extensions/canvas/setup-api.d.ts +1 -1
- package/dist/extensions/deepseek/api.d.ts +1 -1
- package/dist/extensions/deepseek/index.d.ts +1 -1
- package/dist/extensions/deepseek/provider-discovery.d.ts +1 -1
- package/dist/extensions/deepseek/stream.d.ts +1 -1
- package/dist/extensions/device-pair/api.d.ts +4 -4
- package/dist/extensions/device-pair/api.js +1 -1
- package/dist/extensions/device-pair/index.d.ts +1 -1
- package/dist/extensions/device-pair/notify.d.ts +1 -1
- package/dist/extensions/device-pair/pair-command-approve.js +1 -1
- package/dist/extensions/device-pair/qr-image.d.ts +1 -1
- package/dist/extensions/memory-core/api.d.ts +1 -1
- package/dist/extensions/memory-core/cli-metadata.d.ts +1 -1
- package/dist/extensions/memory-core/cli-metadata.js +1 -1
- package/dist/extensions/memory-core/index.d.ts +1 -1
- package/dist/extensions/memory-core/manager-runtime.d.ts +1 -1
- package/dist/extensions/memory-core/runtime-api.d.ts +3 -3
- package/dist/extensions/skill-workshop/api.d.ts +2 -2
- package/dist/extensions/skill-workshop/api.js +1 -1
- package/dist/extensions/skill-workshop/index.d.ts +1 -1
- package/dist/extensions/skill-workshop/index.js +2 -2
- package/dist/extensions/tavily/index.d.ts +1 -1
- package/dist/extensions/tavily/web-search-contract-api.d.ts +1 -1
- package/dist/extensions/tavily/web-search-provider.d.ts +1 -1
- package/dist/extensions/thread-ownership/api.d.ts +2 -2
- package/dist/extensions/thread-ownership/index.d.ts +1 -1
- package/dist/extensions/webhooks/api.d.ts +2 -2
- package/dist/extensions/webhooks/api.js +1 -1
- package/dist/extensions/webhooks/index.d.ts +1 -1
- package/dist/extensions/webhooks/index.js +1 -1
- package/dist/extensions/webhooks/runtime-api.d.ts +1 -1
- package/dist/extensions/workboard/api.d.ts +2 -2
- package/dist/extensions/workboard/index.d.ts +1 -1
- package/dist/extensions/workboard/index.js +1 -1
- package/dist/extensions/workboard/runtime-api.d.ts +1 -1
- package/dist/fengming-runtime-CtRd5677.d.ts +153 -0
- package/dist/fengming-tools-DBLsJfsf.js +12221 -0
- package/dist/gateway/protocol/index.d.ts +1 -1
- package/dist/gateway-cli-BgDV2HF9.js +443 -0
- package/dist/gateway-method-runtime-d9oN_XO9.js +21 -0
- package/dist/get-reply-CEMtvaTJ.js +5198 -0
- package/dist/get-reply-from-config.runtime-CE8zmX7o.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/heartbeat-runner-H8SmaKmJ.js +5 -0
- package/dist/heartbeat-runner.runtime-6hUaxEbl.js +3 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/hooks-DkEvkwzS.js +536 -0
- package/dist/host-compat-DeAq3dnI.d.ts +21 -0
- package/dist/http-registry-BDoApjTY.d.ts +23 -0
- package/dist/inbound-reply-dispatch-CIYP2OPo.d.ts +156 -0
- package/dist/inbound-reply-dispatch-geHu6oUK.js +147 -0
- package/dist/inbound-reply-dispatch-vwW5Hl-_.js +2 -0
- package/dist/index-DhOQs6M_.d.ts +1497 -0
- package/dist/index.js +1 -1
- package/dist/init-DpE_6dG4.js +59 -0
- package/dist/interactive-Cb_1f91G.d.ts +26 -0
- package/dist/isolated-agent-B_upYOOM.js +2 -0
- package/dist/isolated-agent-KH9uwWhw.js +1097 -0
- package/dist/kernel-BHnBXnm2.d.ts +241 -0
- package/dist/lifecycle-BmZwopzF.js +570 -0
- package/dist/list.probe-5kzWm9Jk.js +451 -0
- package/dist/list.probe-9zBcGGQ4.js +2 -0
- package/dist/list.status-command-DY2ifqp1.js +815 -0
- package/dist/llm-slug-generator-Bmx0I84M.js +78 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/loader-BVz75gSb.d.ts +142 -0
- package/dist/local-dispatch.runtime-CX3IOY1E.js +10 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/manager-BXGg8bfG.d.ts +409 -0
- package/dist/mcp-http-B1lnh67s.js +2 -0
- package/dist/mcp-http-CamghE-W.js +583 -0
- package/dist/media-runtime-DpykroJR.d.ts +261 -0
- package/dist/memory-core-host-engine-embeddings-N2dX5P40.d.ts +324 -0
- package/dist/memory-core-host-engine-storage-WQfkQMer.d.ts +54 -0
- package/dist/message-handler-Ca_pqGVS.js +1806 -0
- package/dist/model-catalog-BBMLIjhq.d.ts +88 -0
- package/dist/model-selection-Cq82FXLy.js +352 -0
- package/dist/models-cli-Dm_393dw.js +257 -0
- package/dist/monitor-d0eyE2k0.js +60 -0
- package/dist/monitor.account-vLQ3bKHu.js +5382 -0
- package/dist/nodes-Bunvrb33.js +1483 -0
- package/dist/nodes-edNlxb2I.js +3 -0
- package/dist/nodes-pending-DEIwVh9v.js +211 -0
- package/dist/openai-compat-errors-CvWEoG98.js +136 -0
- package/dist/openai-http-Bskdv4Tv.js +836 -0
- package/dist/openresponses-http-DxdgCxFU.js +1175 -0
- package/dist/operations-Z85LFqsT.js +805 -0
- package/dist/outbound.types-DVkbsxo8.d.ts +291 -0
- package/dist/plugin-enabled-fvhTpvYS.js +232 -0
- package/dist/plugin-entry-CunlVUw6.d.ts +47 -0
- package/dist/plugin-registration-9ovnK_Tk.js +97 -0
- package/dist/plugin-runtime-DH2ZM9P5.d.ts +117 -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 +1 -1
- package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
- package/dist/plugin-sdk/agent-harness-task-runtime.js +1 -1
- package/dist/plugin-sdk/agent-harness.js +6 -6
- package/dist/plugin-sdk/agent-runtime.js +2 -2
- package/dist/plugin-sdk/bundled-channel-config-schema-Dfn3b8sF.d.ts +3169 -0
- package/dist/plugin-sdk/bundled-channel-config-schema.d.ts +1 -1
- package/dist/plugin-sdk/channel-config-schema-legacy.d.ts +1 -1
- package/dist/plugin-sdk/channel-core.js +2 -2
- package/dist/plugin-sdk/channel-envelope.js +1 -1
- package/dist/plugin-sdk/channel-inbound-roots.js +1 -1
- package/dist/plugin-sdk/channel-inbound.js +2 -2
- package/dist/plugin-sdk/channel-location.js +1 -1
- package/dist/plugin-sdk/channel-message-runtime.js +3 -3
- package/dist/plugin-sdk/channel-message.js +2 -2
- package/dist/plugin-sdk/channel-runtime.js +0 -1
- package/dist/plugin-sdk/command-status-runtime.js +1 -1
- package/dist/plugin-sdk/compat.js +1 -1
- package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
- package/dist/plugin-sdk/conversation-runtime.js +3 -3
- package/dist/plugin-sdk/core.js +2 -2
- package/dist/plugin-sdk/discord.d.ts +1 -1
- package/dist/plugin-sdk/gateway-method-runtime.js +1 -1
- package/dist/plugin-sdk/health.js +1 -1
- package/dist/plugin-sdk/hook-runtime.js +0 -1
- package/dist/plugin-sdk/inbound-reply-dispatch.js +2 -2
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/infra-runtime.js +3 -1
- package/dist/plugin-sdk/provider-auth-api-key.js +0 -1
- package/dist/plugin-sdk/provider-stream-family.js +0 -1
- package/dist/plugin-sdk/provider-usage.js +649 -1
- package/dist/plugin-sdk/reply-runtime.js +4 -4
- package/dist/plugin-sdk/scripts/lib/plugin-sdk-doc-metadata.d.ts +122 -0
- package/dist/plugin-sdk/video-generation.js +206 -1
- package/dist/plugin-service-BdZxoKBZ.js +1249 -0
- package/dist/plugin-service-quTl5hT0.d.ts +24 -0
- package/dist/plugins/build-smoke-entry.d.ts +2 -2
- package/dist/plugins/loader.d.ts +1 -1
- package/dist/plugins/provider-discovery.runtime.d.ts +1 -1
- package/dist/plugins/provider-runtime.runtime.d.ts +1 -1
- package/dist/plugins/runtime/index.d.ts +1 -1
- package/dist/plugins/runtime/index.js +4 -4
- package/dist/plugins/tools.d.ts +1 -1
- package/dist/prepare.runtime-DFvkUqBZ.js +798 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/preview-warnings-CGzc8ccG.js +618 -0
- package/dist/program-D19g2jaa.js +131 -0
- package/dist/provider-api-key-auth-B8GgTfo8.d.ts +27 -0
- package/dist/provider-auth-result-Diw-woMA.d.ts +21 -0
- package/dist/provider-catalog-shared-hMvzzDgL.d.ts +62 -0
- package/dist/provider-dispatcher-DCTc4lG_.js +22 -0
- package/dist/provider-dispatcher.runtime.js +1 -1
- package/dist/provider-model-shared-BUCh3uCL.d.ts +143 -0
- package/dist/provider-registry-BIokPlxa.d.ts +8 -0
- package/dist/provider-registry-CyUOXHG-.d.ts +8 -0
- package/dist/provider-registry-i--H79Ao.d.ts +29 -0
- package/dist/provider-self-hosted-setup-BF8UR8wg.d.ts +74 -0
- package/dist/provider-stream-NF0XJnar.d.ts +139 -0
- package/dist/provider-stream-shared-DLwDaYed.d.ts +132 -0
- package/dist/provider-web-search-contract-fields-D61Vl5Kl.d.ts +25 -0
- package/dist/pw-ai-DYR-D7xR.js +3064 -0
- package/dist/register.agent-DwW0mQPk.js +152 -0
- package/dist/register.crestodian-BhIukKDA.js +24 -0
- package/dist/register.maintenance-DWHlvztJ.js +85 -0
- package/dist/register.subclis-Bsvdh8RI.js +3 -0
- package/dist/register.subclis-DVk0HU4k.js +31 -0
- package/dist/register.subclis-core-BK7nVvl6.js +278 -0
- package/dist/registry-hscEPAcC.d.ts +8 -0
- package/dist/registry-types-Ce-n1tuw.d.ts +392 -0
- package/dist/repair-sequencing-0-qGNSUO.js +652 -0
- package/dist/reply-payload-mCw4ZND6.d.ts +200 -0
- package/dist/reply-turn-admission-DMWNadoS.js +2056 -0
- package/dist/reply.runtime-CE8zmX7o.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/result-fallback-classifier-BZmv2ACy.js +98 -0
- package/dist/route-qQ-jYpFa.js +475 -0
- package/dist/routes-dTCmw98g.js +2 -0
- package/dist/routes-r8DRKa83.js +3701 -0
- package/dist/run-BgH7EPGH.js +1162 -0
- package/dist/run-command-DCsM-BVh.js +23 -0
- package/dist/run-command-I2ib4dwS.js +2 -0
- package/dist/run-context-CWaKUKKJ.js +66 -0
- package/dist/run-embedded.runtime-CBnDBWN0.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-DlYXI-lw.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime-DwepGrmB.js +330 -0
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-subagent-registry.runtime-CeVpoIhj.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/runtime-D2ee-rNh.js +436 -0
- package/dist/runtime-api-B99ZlkNt.d.ts +5 -0
- package/dist/runtime-api-Cta2L_Yo.js +12 -0
- package/dist/runtime-channel-LKOkML3M.js +2 -0
- package/dist/runtime-channel-UtWvrTZ5.js +148 -0
- package/dist/runtime-embedded-agent.runtime-9O2Idzyb.js +2 -0
- package/dist/runtime-embedded-agent.runtime.js +1 -1
- package/dist/runtime-forwarders-DjI8RFL5.d.ts +39 -0
- package/dist/sdk-setup-tools-B-X04pa6.js +8 -0
- package/dist/selection-B02h8Old.js +3 -0
- package/dist/selection-DEPvzrW2.js +18365 -0
- package/dist/server-CMYi8gDo.js +24 -0
- package/dist/server-Cx07rsiY.js +72 -0
- package/dist/server-close.runtime.js +1 -1
- package/dist/server-context-BIemGRt4.js +2 -0
- package/dist/server-context-CB_an9iy.js +955 -0
- package/dist/server-cron-BeyuBUjb.js +3173 -0
- package/dist/server-cron-CV7KkVeB.js +2 -0
- package/dist/server-methods-C7EnpOhB.js +497 -0
- package/dist/server-node-events-DMMzZciN.js +597 -0
- package/dist/server-plugin-bootstrap-O6MzvzL8.js +71 -0
- package/dist/server-plugins-Dwnaz9kX.js +435 -0
- package/dist/server-reload-handlers-C-6TyPvI.js +719 -0
- package/dist/server-restart-sentinel-Dc35eYgk.js +700 -0
- package/dist/server-runtime-services-DCs-gqh_.js +3 -0
- package/dist/server-runtime-services-DF2fzzVd.js +147 -0
- package/dist/server-startup-plugins-t-YeYibm.js +127 -0
- package/dist/server-startup-post-attach-CiEki-DC.js +793 -0
- package/dist/server-ws-runtime-uaUpI-e8.js +374 -0
- package/dist/server.impl-MoHjSMr5.js +2622 -0
- package/dist/session-kill-http-CYCiQpt2.js +121 -0
- package/dist/session-reset-service-BYbADY57.js +651 -0
- package/dist/session-status.runtime-8NASbeO4.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-DGeNY2Rb.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-C2eElZrt.js +551 -0
- package/dist/sessions-DXAdVXIx.js +1917 -0
- package/dist/sessions-history-http-BwK7b8OH.js +432 -0
- package/dist/sessions-patch-BYC5gvY1.js +401 -0
- package/dist/sessions-resolve-C3ORcdmo.js +180 -0
- package/dist/sessions.runtime-BijldeSY.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/snapshot-urls-C5CfP3Co.js +317 -0
- package/dist/speech-core-wWkTZPpQ.d.ts +49 -0
- package/dist/standalone-CHrieUsw.js +42 -0
- package/dist/startup-context-CZfmG8-g.js +314 -0
- package/dist/status-subagents.runtime-D2XMebiS.js +32 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-JR7IPyzZ.js +301 -0
- package/dist/stream-BJgTkLEI.d.ts +5 -0
- package/dist/subagent-announce-B9cfs_KZ.js +353 -0
- package/dist/subagent-announce-delivery-CtmEvLTS.js +1369 -0
- package/dist/subagent-control-DVqLHi9O.js +492 -0
- package/dist/subagent-hooks-D251uSvy.js +230 -0
- package/dist/subagent-hooks-api-DvdMKxsC.js +23 -0
- package/dist/subagent-hooks-uLORYChc.js +2 -0
- package/dist/subagent-registry-BW2l_oYu.js +3 -0
- package/dist/subagent-registry-BxEMHuiN.js +2627 -0
- package/dist/subagent-registry.runtime.d.ts +1 -1
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-session-cleanup-BC5wV2qQ.js +390 -0
- package/dist/system-fvgHsr2x.js +111 -0
- package/dist/talk-DU0Sod_K.js +2454 -0
- package/dist/target-id-BR2xJIkd.js +107 -0
- package/dist/task-registry-control.runtime.js +1 -1
- package/dist/thread-bindings-8XNu5U2p.js +228 -0
- package/dist/tool-Boeg0N5g.js +143 -0
- package/dist/tool-dispatch-BhLLaL2g.js +155 -0
- package/dist/tool-resolution-CzsLs-87.js +153 -0
- package/dist/tool-split-Bedy42Ms.d.ts +19 -0
- package/dist/tools-B6egHpE3.d.ts +38 -0
- package/dist/tools-effective-NXscxK8n.js +442 -0
- package/dist/tools-effective-inventory-NsGMUVo-.js +379 -0
- package/dist/tools-invoke-_sSu96Kq.js +51 -0
- package/dist/tools-invoke-http-BDhlRl-G.js +68 -0
- package/dist/tools-invoke-shared-BH-T9Bcg.js +200 -0
- package/dist/tts-runtime-C1wu3o15.d.ts +230 -0
- package/dist/tui-C733Qov0.js +2 -0
- package/dist/tui-DqbscVN5.js +3 -0
- package/dist/tui-backend-_Pn3Byj-.js +257 -0
- package/dist/tui-cli-CAiC39zd.js +40 -0
- package/dist/tui-ink-run-ChXEGj1h.js +7414 -0
- package/dist/tui-ink-run-D4mSfLHj.js +2 -0
- package/dist/types-BQw1qXGl.d.ts +7034 -0
- package/dist/types-BzMoU6-C.d.ts +111 -0
- package/dist/types-DltHmoCX.d.ts +393 -0
- package/dist/types.public-C_bVIMBl.d.ts +70 -0
- package/dist/web-fetch/runtime.d.ts +1 -1
- package/dist/webhook-targets-DW2jhddP.d.ts +99 -0
- package/dist/zod-schema.core-Cuz0lz6m.d.ts +166 -0
- package/npm-shrinkwrap.json +12861 -11889
- package/package.json +1 -1
- package/skills/batch/SKILL.md +118 -0
- package/skills/code-review/SKILL.md +107 -0
- package/skills/debug/SKILL.md +83 -0
- package/skills/loop/SKILL.md +118 -0
- package/skills/run/SKILL.md +79 -0
- package/skills/run-skill-generator/SKILL.md +179 -0
- package/skills/verify/SKILL.md +103 -0
- package/dist/abort-DGskei2p.js +0 -277
- package/dist/abort.runtime-Buq9IZxn.js +0 -2
- package/dist/acp-spawn-DC6IyYaB.js +0 -1286
- package/dist/acp-spawn-Diqb3nel.js +0 -2
- package/dist/acp-stateful-target-driver-Clhe_L8v.js +0 -89
- package/dist/active-tool-schema-warnings-BRhKkyvt.js +0 -2
- package/dist/active-tool-schema-warnings-C6N0-ce6.js +0 -105
- package/dist/agent-C5lhsEZJ.js +0 -2
- package/dist/agent-WEb757bl.js +0 -1825
- package/dist/agent-command-iLD_nsVY.js +0 -1435
- package/dist/agent-core-BeDN8Ns5.d.ts +0 -13
- package/dist/agent-harness-runtime-C89_Q-bW.d.ts +0 -913
- package/dist/agent-harness-runtime-Dfn5rik2.js +0 -207
- package/dist/agent-runner-utils-DNiuuo43.js +0 -267
- package/dist/agent-runner.runtime-CFF_qJ5V.js +0 -3784
- package/dist/agent-runtime-BkMtWXxn.js +0 -199
- package/dist/agent-runtime-HufMO_YR.d.ts +0 -207
- package/dist/agent-tools-HmaDv4ot.js +0 -2506
- package/dist/agent-via-gateway-CZQG8RYL.js +0 -486
- package/dist/agent-wait-dedupe-C3xQk2Ww.js +0 -180
- package/dist/agent-z1cs3c7n.js +0 -3
- package/dist/api-B4IMKjSe.js +0 -3
- package/dist/api-BwSbBWI8.js +0 -3
- package/dist/api-CE9In9m4.js +0 -5
- package/dist/api-ClPvYNGa.js +0 -32
- package/dist/api-CntBCaZf.js +0 -3
- package/dist/api-DBZBwTsn.js +0 -6
- package/dist/api-OCPwGOvK.js +0 -2
- package/dist/api-yYhEo7gK.js +0 -4
- package/dist/approval-client-helpers-CfdQ3-vv.d.ts +0 -78
- package/dist/approval-native-helpers-DSHPksK4.d.ts +0 -241
- package/dist/approval-renderers-BfEfwk44.d.ts +0 -39
- package/dist/assistant-v5fdOYu7.js +0 -291
- package/dist/attachment-normalize-BHAbLiL2.js +0 -213
- package/dist/attempt-execution-5w9WYbaJ.js +0 -584
- package/dist/attempt-execution.runtime-DnhOWGzr.js +0 -3
- package/dist/attempt.prompt-helpers-C4M4erF7.js +0 -543
- package/dist/binding-routing-Dpes-QF1.js +0 -113
- package/dist/binding-targets-B6H5Pd-A.js +0 -121
- package/dist/bridge-server-BCpxCRm_.js +0 -113
- package/dist/browser-cli-DMhXHopl.js +0 -230
- package/dist/browser-cli-Dy_VugK0.js +0 -2
- package/dist/browser-cli-actions-input-WMP7_lm6.js +0 -522
- package/dist/browser-cli-actions-observe-DQWAWhwU.js +0 -81
- package/dist/browser-cli-debug-CaT2ZKAx.js +0 -137
- package/dist/browser-cli-inspect-DU-LUXq1.js +0 -117
- package/dist/browser-cli-manage-DAuogqIh.js +0 -446
- package/dist/browser-cli-resize-Cz5uO_aR.js +0 -32
- package/dist/browser-cli-shared-CjPZcG3j.js +0 -69
- package/dist/browser-cli-state-CC3l77-K.js +0 -371
- package/dist/browser-control-auth-ELccIUZy.js +0 -2
- package/dist/browser-profiles-Cuy4ia6_.js +0 -2
- package/dist/browser-runtime-De-iUfME.js +0 -389
- package/dist/build-DEF8Per9.js +0 -261
- package/dist/bundled-channel-config-schema-Bte--ZlY.d.ts +0 -3168
- package/dist/capability-cli-Bydel4E7.js +0 -1809
- package/dist/channel-6SGL4R5P.js +0 -2309
- package/dist/channel-D3Q3b8J-.d.ts +0 -427
- package/dist/channel-core-Bj71kAB5.d.ts +0 -6
- package/dist/channel-core-DMvyWnHg.js +0 -5
- package/dist/channel-entry-contract-zYxRmEdf.d.ts +0 -114
- package/dist/channel-inbound-DVJzBcJ8.d.ts +0 -97
- package/dist/channel-inbound-DlCa7eJe.js +0 -121
- package/dist/channel-message-CyPGMMFB.js +0 -12
- package/dist/channel-message-Czl4cdoA.d.ts +0 -9
- package/dist/channel-outbound-BNbhmruA.d.ts +0 -325
- package/dist/channel-pairing-BiS-tSvl.d.ts +0 -58
- package/dist/channel-runtime-D8hntg7H.js +0 -7
- package/dist/channel.runtime-DxErReJR.js +0 -697
- package/dist/chat-BLA8ORQI.js +0 -3
- package/dist/chat-DWRXkuvU.js +0 -2940
- package/dist/chrome-DPwFYi-g.js +0 -1517
- package/dist/cli-compaction-YZpssARf.js +0 -363
- package/dist/cli-runner-D2OAqxu3.js +0 -597
- package/dist/cli-runner-DO4SORQf.js +0 -2
- package/dist/cli-runner.runtime-CNSIpbeT.js +0 -4
- package/dist/cli-runner.runtime-DAOYvpVQ.js +0 -3
- package/dist/command-registry-DpD0fb8D.js +0 -4
- package/dist/command-registry-core-Cl3tLG8G.js +0 -114
- package/dist/command-registry-nbP7c8RT.js +0 -9
- package/dist/command-status.runtime-BBuXTkq0.js +0 -90
- package/dist/commands-CR8MVvlD.d.ts +0 -117
- package/dist/commands-compact.runtime-BoafIjjg.js +0 -10
- package/dist/commands-handlers.runtime-D9jViG_x.js +0 -6327
- package/dist/commands-status-BqqJ7PVq.js +0 -16
- package/dist/commands-status-CMd41Vxf.js +0 -3
- package/dist/commands-status.runtime-CMd41Vxf.js +0 -3
- package/dist/commands-subagents-control.runtime-CU4I3A_n.js +0 -2
- package/dist/commands-system-prompt-CTtu1D3-.js +0 -2
- package/dist/commands-system-prompt-xswhORdM.js +0 -161
- package/dist/commands-types-B67CsqXf.d.ts +0 -132
- package/dist/commands.runtime-BUFhkrjQ.js +0 -175
- package/dist/compact-Dz_WvRkQ.js +0 -1165
- package/dist/compact.runtime-n-AKErni.js +0 -12
- package/dist/completion-cli-DJYs_L4_.js +0 -393
- package/dist/config-CFMbHJb0.js +0 -374
- package/dist/config-mutations-DCAloTKR.js +0 -161
- package/dist/config-schema-Drw1zrnG.d.ts +0 -20
- package/dist/context-engine-host-compat-4mNm1HCE.js +0 -2
- package/dist/context-engine-host-compat-BzJ7fUIn.js +0 -280
- package/dist/context-engine-lifecycle-V4PNQp6k.js +0 -627
- package/dist/control-auth-DG_cw-aN.js +0 -114
- package/dist/control-service-CurYipgK.js +0 -3
- package/dist/control-service-VyncoV7j.js +0 -40
- package/dist/control-ui/assets/activity-BvGWC_j9.js +0 -124
- package/dist/control-ui/assets/agents-XOPBFHre.js +0 -1030
- package/dist/control-ui/assets/channels-B3E6Zw4-.js +0 -120
- package/dist/control-ui/assets/cron-r1sJdAbI.js +0 -1016
- package/dist/control-ui/assets/debug-EJlC-Qxz.js +0 -97
- package/dist/control-ui/assets/index-DBWFWpqU.js +0 -7214
- package/dist/control-ui/assets/instances-DqYhTGuq.js +0 -57
- package/dist/control-ui/assets/nodes-CPozuEst.js +0 -444
- package/dist/control-ui/assets/sessions-vJlr6aBb.js +0 -425
- package/dist/control-ui/assets/skills-wNA5l4y0.js +0 -362
- package/dist/control-ui/assets/workboard-BwoP_UJU.js +0 -402
- package/dist/conversation-runtime-DgaABwHh.js +0 -31
- package/dist/core-BeBXdneV.js +0 -284
- package/dist/core-Chqb7X6l.d.ts +0 -223
- package/dist/core-api-BlK0FgBM.js +0 -2
- package/dist/core-api-pAvYk716.js +0 -5
- package/dist/crestodian-FeGTBqO1.js +0 -55
- package/dist/delegate-BjIjSU_E.d.ts +0 -30
- package/dist/deliver-CvtWN4Ey.d.ts +0 -111
- package/dist/delivery-queue-CQ-cj3KG.d.ts +0 -161
- package/dist/delivery-queue-runtime-ut7MG04m.d.ts +0 -9
- package/dist/detect-BjXPyrwn.js +0 -115
- package/dist/detect-C1xeIemQ.d.ts +0 -16
- package/dist/dialogue-BowVYhEC.js +0 -37
- package/dist/direct-dm-DoZZHpA0.d.ts +0 -79
- package/dist/directive-handling.fast-lane-hnmQ_CvD.js +0 -70
- package/dist/directive-handling.impl-Cai-CFS1.js +0 -2
- package/dist/directive-handling.impl-DY84qIfU.js +0 -823
- package/dist/directive-handling.model-selection-DASssLFQ.js +0 -122
- package/dist/directive-handling.persist.runtime-BY7tJUs2.js +0 -274
- package/dist/dispatch-D5iG5A8j.js +0 -2057
- package/dist/dispatch-acp-transcript.runtime-D3r16hbD.js +0 -40
- package/dist/dispatch-acp.runtime-CAIau5qX.js +0 -18
- package/dist/dispatcher-7-d2gw3J.js +0 -106
- package/dist/doctor-DD5YEMmf.js +0 -6
- package/dist/doctor-config-flow-CdlLHJmX.js +0 -1819
- package/dist/doctor-core-checks-6MP99TQG.js +0 -666
- package/dist/doctor-core-checks-Dm_o576z.js +0 -2
- package/dist/doctor-core-checks.runtime-B2qbKATd.js +0 -278
- package/dist/doctor-health-BKrhOv1v.js +0 -65
- package/dist/doctor-health-contributions-bIBLmw69.js +0 -874
- package/dist/doctor-lint-aOLOWli4.js +0 -95
- package/dist/doctor-state-integrity-23NQNNuo.js +0 -1257
- package/dist/draft-stream-controls-Bk1GVJ1l.d.ts +0 -159
- package/dist/embedded-agent-BeK8FhZr.d.ts +0 -5
- package/dist/embedded-agent-CNp_y7jW.js +0 -4074
- package/dist/embedded-agent-NEmNlXDR.js +0 -4
- package/dist/embedded-agent.runtime-hEby8P2s.js +0 -4
- package/dist/embedded-backend-BdbgfpBP.js +0 -1581
- package/dist/embedded-gateway-stub.runtime-ySZUA3Gy.js +0 -12
- package/dist/extensions/alibaba/fengming.plugin.json +0 -47
- package/dist/extensions/alibaba/index.d.ts +0 -12
- package/dist/extensions/alibaba/index.js +0 -13
- package/dist/extensions/alibaba/package.json +0 -15
- package/dist/extensions/alibaba/video-generation-provider.d.ts +0 -6
- package/dist/extensions/alibaba/video-generation-provider.js +0 -2
- package/dist/extensions/baichuan/fengming.plugin.json +0 -69
- package/dist/extensions/baichuan/index.d.ts +0 -11
- package/dist/extensions/baichuan/index.js +0 -45
- package/dist/extensions/baichuan/models.d.ts +0 -7
- package/dist/extensions/baichuan/models.js +0 -2
- package/dist/extensions/baichuan/onboard.d.ts +0 -5
- package/dist/extensions/baichuan/onboard.js +0 -2
- package/dist/extensions/baichuan/package.json +0 -15
- package/dist/extensions/baichuan/provider-catalog.d.ts +0 -2
- package/dist/extensions/baichuan/provider-catalog.js +0 -2
- package/dist/extensions/baichuan/provider-discovery.d.ts +0 -2
- package/dist/extensions/baichuan/provider-discovery.js +0 -5
- package/dist/extensions/byteplus/api.d.ts +0 -3
- package/dist/extensions/byteplus/api.js +0 -3
- package/dist/extensions/byteplus/fengming.plugin.json +0 -196
- package/dist/extensions/byteplus/index.d.ts +0 -12
- package/dist/extensions/byteplus/index.js +0 -85
- package/dist/extensions/byteplus/models.d.ts +0 -2
- package/dist/extensions/byteplus/models.js +0 -2
- package/dist/extensions/byteplus/package.json +0 -15
- package/dist/extensions/byteplus/provider-catalog.d.ts +0 -2
- package/dist/extensions/byteplus/provider-catalog.js +0 -2
- package/dist/extensions/byteplus/provider-discovery.d.ts +0 -5
- package/dist/extensions/byteplus/provider-discovery.js +0 -23
- package/dist/extensions/byteplus/video-generation-provider.d.ts +0 -6
- package/dist/extensions/byteplus/video-generation-provider.js +0 -2
- package/dist/extensions/longcat/fengming.plugin.json +0 -84
- package/dist/extensions/longcat/index.d.ts +0 -11
- package/dist/extensions/longcat/index.js +0 -45
- package/dist/extensions/longcat/models.d.ts +0 -7
- package/dist/extensions/longcat/models.js +0 -2
- package/dist/extensions/longcat/onboard.d.ts +0 -5
- package/dist/extensions/longcat/onboard.js +0 -2
- package/dist/extensions/longcat/package.json +0 -15
- package/dist/extensions/longcat/provider-catalog.d.ts +0 -2
- package/dist/extensions/longcat/provider-catalog.js +0 -2
- package/dist/extensions/longcat/provider-discovery.d.ts +0 -2
- package/dist/extensions/longcat/provider-discovery.js +0 -5
- package/dist/extensions/minimax/api.d.ts +0 -5
- package/dist/extensions/minimax/api.js +0 -6
- package/dist/extensions/minimax/fengming.plugin.json +0 -206
- package/dist/extensions/minimax/image-generation-provider.d.ts +0 -6
- package/dist/extensions/minimax/image-generation-provider.js +0 -2
- package/dist/extensions/minimax/index.d.ts +0 -12
- package/dist/extensions/minimax/index.js +0 -29
- package/dist/extensions/minimax/media-understanding-provider.d.ts +0 -6
- package/dist/extensions/minimax/media-understanding-provider.js +0 -2
- package/dist/extensions/minimax/model-definitions.d.ts +0 -2
- package/dist/extensions/minimax/model-definitions.js +0 -2
- package/dist/extensions/minimax/music-generation-provider.d.ts +0 -6
- package/dist/extensions/minimax/music-generation-provider.js +0 -2
- package/dist/extensions/minimax/oauth.d.ts +0 -2
- package/dist/extensions/minimax/oauth.js +0 -2
- package/dist/extensions/minimax/oauth.runtime.d.ts +0 -2
- package/dist/extensions/minimax/oauth.runtime.js +0 -2
- package/dist/extensions/minimax/onboard.d.ts +0 -2
- package/dist/extensions/minimax/onboard.js +0 -2
- package/dist/extensions/minimax/package.json +0 -15
- package/dist/extensions/minimax/provider-catalog.d.ts +0 -2
- package/dist/extensions/minimax/provider-catalog.js +0 -2
- package/dist/extensions/minimax/provider-contract-api.d.ts +0 -6
- package/dist/extensions/minimax/provider-contract-api.js +0 -77
- package/dist/extensions/minimax/provider-discovery.d.ts +0 -5
- package/dist/extensions/minimax/provider-discovery.js +0 -23
- package/dist/extensions/minimax/provider-models.d.ts +0 -2
- package/dist/extensions/minimax/provider-models.js +0 -2
- package/dist/extensions/minimax/provider-registration.d.ts +0 -7
- package/dist/extensions/minimax/provider-registration.js +0 -2
- package/dist/extensions/minimax/speech-provider.d.ts +0 -5
- package/dist/extensions/minimax/speech-provider.js +0 -2
- package/dist/extensions/minimax/tts.d.ts +0 -20
- package/dist/extensions/minimax/tts.js +0 -2
- package/dist/extensions/minimax/video-generation-provider.d.ts +0 -7
- package/dist/extensions/minimax/video-generation-provider.js +0 -2
- package/dist/extensions/minimax/web-search-contract-api.d.ts +0 -5
- package/dist/extensions/minimax/web-search-contract-api.js +0 -31
- package/dist/extensions/minimax/web-search-provider.d.ts +0 -5
- package/dist/extensions/minimax/web-search-provider.js +0 -2
- package/dist/extensions/moonshot/api.d.ts +0 -3
- package/dist/extensions/moonshot/api.js +0 -4
- package/dist/extensions/moonshot/fengming.plugin.json +0 -250
- package/dist/extensions/moonshot/index.d.ts +0 -11
- package/dist/extensions/moonshot/index.js +0 -70
- package/dist/extensions/moonshot/media-understanding-provider.d.ts +0 -6
- package/dist/extensions/moonshot/media-understanding-provider.js +0 -2
- package/dist/extensions/moonshot/onboard.d.ts +0 -2
- package/dist/extensions/moonshot/onboard.js +0 -2
- package/dist/extensions/moonshot/package.json +0 -15
- package/dist/extensions/moonshot/provider-catalog.d.ts +0 -2
- package/dist/extensions/moonshot/provider-catalog.js +0 -2
- package/dist/extensions/moonshot/provider-contract-api.d.ts +0 -5
- package/dist/extensions/moonshot/provider-contract-api.js +0 -27
- package/dist/extensions/moonshot/provider-discovery.d.ts +0 -5
- package/dist/extensions/moonshot/provider-discovery.js +0 -15
- package/dist/extensions/moonshot/web-search-contract-api.d.ts +0 -5
- package/dist/extensions/moonshot/web-search-contract-api.js +0 -29
- package/dist/extensions/moonshot/web-search-provider.d.ts +0 -5
- package/dist/extensions/moonshot/web-search-provider.js +0 -2
- package/dist/extensions/qianfan/api.d.ts +0 -3
- package/dist/extensions/qianfan/api.js +0 -3
- package/dist/extensions/qianfan/fengming.plugin.json +0 -89
- package/dist/extensions/qianfan/index.d.ts +0 -11
- package/dist/extensions/qianfan/index.js +0 -26
- package/dist/extensions/qianfan/onboard.d.ts +0 -2
- package/dist/extensions/qianfan/onboard.js +0 -2
- package/dist/extensions/qianfan/package.json +0 -15
- package/dist/extensions/qianfan/provider-catalog.d.ts +0 -2
- package/dist/extensions/qianfan/provider-catalog.js +0 -2
- package/dist/extensions/qwen/api.d.ts +0 -4
- package/dist/extensions/qwen/api.js +0 -5
- package/dist/extensions/qwen/fengming.plugin.json +0 -389
- package/dist/extensions/qwen/index.d.ts +0 -11
- package/dist/extensions/qwen/index.js +0 -202
- package/dist/extensions/qwen/media-understanding-provider.d.ts +0 -6
- package/dist/extensions/qwen/media-understanding-provider.js +0 -2
- package/dist/extensions/qwen/model-definitions.d.ts +0 -2
- package/dist/extensions/qwen/model-definitions.js +0 -2
- package/dist/extensions/qwen/models.d.ts +0 -2
- package/dist/extensions/qwen/models.js +0 -2
- package/dist/extensions/qwen/onboard.d.ts +0 -21
- package/dist/extensions/qwen/onboard.js +0 -2
- package/dist/extensions/qwen/package.json +0 -15
- package/dist/extensions/qwen/provider-catalog.d.ts +0 -2
- package/dist/extensions/qwen/provider-catalog.js +0 -2
- package/dist/extensions/qwen/stream.d.ts +0 -2
- package/dist/extensions/qwen/stream.js +0 -2
- package/dist/extensions/qwen/video-generation-provider.d.ts +0 -6
- package/dist/extensions/qwen/video-generation-provider.js +0 -2
- package/dist/extensions/sensenova/fengming.plugin.json +0 -69
- package/dist/extensions/sensenova/index.d.ts +0 -11
- package/dist/extensions/sensenova/index.js +0 -45
- package/dist/extensions/sensenova/models.d.ts +0 -7
- package/dist/extensions/sensenova/models.js +0 -2
- package/dist/extensions/sensenova/onboard.d.ts +0 -5
- package/dist/extensions/sensenova/onboard.js +0 -2
- package/dist/extensions/sensenova/package.json +0 -15
- package/dist/extensions/sensenova/provider-catalog.d.ts +0 -2
- package/dist/extensions/sensenova/provider-catalog.js +0 -2
- package/dist/extensions/sensenova/provider-discovery.d.ts +0 -2
- package/dist/extensions/sensenova/provider-discovery.js +0 -5
- package/dist/extensions/stepfun/fengming.plugin.json +0 -162
- package/dist/extensions/stepfun/index.d.ts +0 -12
- package/dist/extensions/stepfun/index.js +0 -165
- package/dist/extensions/stepfun/onboard.d.ts +0 -7
- package/dist/extensions/stepfun/onboard.js +0 -2
- package/dist/extensions/stepfun/package.json +0 -15
- package/dist/extensions/stepfun/provider-catalog.d.ts +0 -14
- package/dist/extensions/stepfun/provider-catalog.js +0 -2
- package/dist/extensions/tencent/api.d.ts +0 -3
- package/dist/extensions/tencent/api.js +0 -4
- package/dist/extensions/tencent/fengming.plugin.json +0 -105
- package/dist/extensions/tencent/index.d.ts +0 -12
- package/dist/extensions/tencent/index.js +0 -62
- package/dist/extensions/tencent/models.d.ts +0 -2
- package/dist/extensions/tencent/models.js +0 -2
- package/dist/extensions/tencent/onboard.d.ts +0 -6
- package/dist/extensions/tencent/onboard.js +0 -2
- package/dist/extensions/tencent/package.json +0 -15
- package/dist/extensions/tencent/provider-catalog.d.ts +0 -2
- package/dist/extensions/tencent/provider-catalog.js +0 -2
- package/dist/extensions/tencent/provider-discovery.d.ts +0 -5
- package/dist/extensions/tencent/provider-discovery.js +0 -14
- package/dist/extensions/tiangong/fengming.plugin.json +0 -69
- package/dist/extensions/tiangong/index.d.ts +0 -11
- package/dist/extensions/tiangong/index.js +0 -45
- package/dist/extensions/tiangong/models.d.ts +0 -7
- package/dist/extensions/tiangong/models.js +0 -2
- package/dist/extensions/tiangong/onboard.d.ts +0 -5
- package/dist/extensions/tiangong/onboard.js +0 -2
- package/dist/extensions/tiangong/package.json +0 -15
- package/dist/extensions/tiangong/provider-catalog.d.ts +0 -2
- package/dist/extensions/tiangong/provider-catalog.js +0 -2
- package/dist/extensions/tiangong/provider-discovery.d.ts +0 -2
- package/dist/extensions/tiangong/provider-discovery.js +0 -5
- package/dist/extensions/volcengine/api.d.ts +0 -12
- package/dist/extensions/volcengine/api.js +0 -4
- package/dist/extensions/volcengine/fengming.plugin.json +0 -263
- package/dist/extensions/volcengine/index.d.ts +0 -12
- package/dist/extensions/volcengine/index.js +0 -88
- package/dist/extensions/volcengine/models.d.ts +0 -2
- package/dist/extensions/volcengine/models.js +0 -2
- package/dist/extensions/volcengine/package.json +0 -15
- package/dist/extensions/volcengine/provider-catalog.d.ts +0 -2
- package/dist/extensions/volcengine/provider-catalog.js +0 -2
- package/dist/extensions/volcengine/provider-discovery.d.ts +0 -5
- package/dist/extensions/volcengine/provider-discovery.js +0 -23
- package/dist/extensions/volcengine/speech-provider.d.ts +0 -5
- package/dist/extensions/volcengine/speech-provider.js +0 -2
- package/dist/extensions/volcengine/tts.d.ts +0 -22
- package/dist/extensions/volcengine/tts.js +0 -2
- package/dist/extensions/weixin/fengming.plugin.json +0 -22
- package/dist/extensions/weixin/index.d.ts +0 -26
- package/dist/extensions/weixin/index.js +0 -862
- package/dist/extensions/weixin/package.json +0 -45
- package/dist/extensions/xiaomi/api.d.ts +0 -3
- package/dist/extensions/xiaomi/api.js +0 -3
- package/dist/extensions/xiaomi/fengming.plugin.json +0 -260
- package/dist/extensions/xiaomi/index.d.ts +0 -12
- package/dist/extensions/xiaomi/index.js +0 -284
- package/dist/extensions/xiaomi/onboard.d.ts +0 -2
- package/dist/extensions/xiaomi/onboard.js +0 -2
- package/dist/extensions/xiaomi/package.json +0 -15
- package/dist/extensions/xiaomi/provider-catalog.d.ts +0 -2
- package/dist/extensions/xiaomi/provider-catalog.js +0 -2
- package/dist/extensions/xiaomi/speech-provider.d.ts +0 -5
- package/dist/extensions/xiaomi/speech-provider.js +0 -2
- package/dist/extensions/xiaomi/stream.d.ts +0 -5
- package/dist/extensions/xiaomi/stream.js +0 -2
- package/dist/extensions/xiaomi/thinking.d.ts +0 -11
- package/dist/extensions/xiaomi/thinking.js +0 -2
- package/dist/extensions/xingchen/fengming.plugin.json +0 -69
- package/dist/extensions/xingchen/index.d.ts +0 -11
- package/dist/extensions/xingchen/index.js +0 -45
- package/dist/extensions/xingchen/models.d.ts +0 -7
- package/dist/extensions/xingchen/models.js +0 -2
- package/dist/extensions/xingchen/onboard.d.ts +0 -5
- package/dist/extensions/xingchen/onboard.js +0 -2
- package/dist/extensions/xingchen/package.json +0 -15
- package/dist/extensions/xingchen/provider-catalog.d.ts +0 -2
- package/dist/extensions/xingchen/provider-catalog.js +0 -2
- package/dist/extensions/xingchen/provider-discovery.d.ts +0 -2
- package/dist/extensions/xingchen/provider-discovery.js +0 -5
- package/dist/extensions/yi/fengming.plugin.json +0 -84
- package/dist/extensions/yi/index.d.ts +0 -11
- package/dist/extensions/yi/index.js +0 -45
- package/dist/extensions/yi/models.d.ts +0 -7
- package/dist/extensions/yi/models.js +0 -2
- package/dist/extensions/yi/onboard.d.ts +0 -5
- package/dist/extensions/yi/onboard.js +0 -2
- package/dist/extensions/yi/package.json +0 -15
- package/dist/extensions/yi/provider-catalog.d.ts +0 -2
- package/dist/extensions/yi/provider-catalog.js +0 -2
- package/dist/extensions/yi/provider-discovery.d.ts +0 -2
- package/dist/extensions/yi/provider-discovery.js +0 -5
- package/dist/extensions/zai/api.d.ts +0 -4
- package/dist/extensions/zai/api.js +0 -4
- package/dist/extensions/zai/detect.d.ts +0 -2
- package/dist/extensions/zai/detect.js +0 -2
- package/dist/extensions/zai/fengming.plugin.json +0 -377
- package/dist/extensions/zai/index.d.ts +0 -12
- package/dist/extensions/zai/index.js +0 -297
- package/dist/extensions/zai/media-understanding-provider.d.ts +0 -5
- package/dist/extensions/zai/media-understanding-provider.js +0 -2
- package/dist/extensions/zai/model-definitions.d.ts +0 -2
- package/dist/extensions/zai/model-definitions.js +0 -2
- package/dist/extensions/zai/onboard.d.ts +0 -2
- package/dist/extensions/zai/onboard.js +0 -2
- package/dist/extensions/zai/package.json +0 -15
- package/dist/extensions/zai/runtime-api.d.ts +0 -2
- package/dist/extensions/zai/runtime-api.js +0 -2
- package/dist/extensions/zhinao/fengming.plugin.json +0 -69
- package/dist/extensions/zhinao/index.d.ts +0 -11
- package/dist/extensions/zhinao/index.js +0 -45
- package/dist/extensions/zhinao/models.d.ts +0 -7
- package/dist/extensions/zhinao/models.js +0 -2
- package/dist/extensions/zhinao/onboard.d.ts +0 -5
- package/dist/extensions/zhinao/onboard.js +0 -2
- package/dist/extensions/zhinao/package.json +0 -15
- package/dist/extensions/zhinao/provider-catalog.d.ts +0 -2
- package/dist/extensions/zhinao/provider-catalog.js +0 -2
- package/dist/extensions/zhinao/provider-discovery.d.ts +0 -2
- package/dist/extensions/zhinao/provider-discovery.js +0 -5
- package/dist/fengming-runtime-0jdu_329.d.ts +0 -153
- package/dist/fengming-tools-gQkwsWYz.js +0 -12221
- package/dist/fengming.plugin-C-Kdi1_5.js +0 -130
- package/dist/fengming.plugin-CRPqMj85.js +0 -166
- package/dist/gateway-cli-BV1V43-D.js +0 -443
- package/dist/gateway-method-runtime-J2OPP_oH.js +0 -21
- package/dist/get-reply-BE8ZGJos.js +0 -5198
- package/dist/get-reply-from-config.runtime-C5wfxVI_.js +0 -2
- package/dist/heartbeat-runner-_0HlObMb.js +0 -5
- package/dist/heartbeat-runner.runtime-DvYz_4Z3.js +0 -3
- package/dist/hook-runtime-BH9moP5T.js +0 -4
- package/dist/hooks-icCwsmrQ.js +0 -536
- package/dist/host-compat-dfJvEfe7.d.ts +0 -21
- package/dist/http-registry-Buj7R-F_.d.ts +0 -23
- package/dist/image-generation-provider-hrRXkkGc.js +0 -152
- package/dist/inbound-reply-dispatch-5AYt56Yt.js +0 -147
- package/dist/inbound-reply-dispatch-B5weFW8i.js +0 -2
- package/dist/inbound-reply-dispatch-cJh4H31y.d.ts +0 -156
- package/dist/index-DbpfOFUf.d.ts +0 -1497
- package/dist/infra-runtime-3_0R8nmO.js +0 -32
- package/dist/init-BnfkYG_k.js +0 -59
- package/dist/interactive-V8NfYsTW.d.ts +0 -26
- package/dist/isolated-agent-CgH7dfOj.js +0 -1097
- package/dist/isolated-agent-dBWkiw0a.js +0 -2
- package/dist/kernel-Ds2aqAJF.d.ts +0 -241
- package/dist/kimi-web-search-provider-QJT3Ftj3.js +0 -80
- package/dist/kimi-web-search-provider.runtime-Dj3SS4T5.js +0 -307
- package/dist/kimi-web-search-provider.runtime.js +0 -1
- package/dist/lib-Dg4yjNFQ.js +0 -871
- package/dist/lifecycle-B9k7QGsS.js +0 -570
- package/dist/list.probe-CbVHFNwf.js +0 -2
- package/dist/list.probe-CxiEBmyW.js +0 -451
- package/dist/list.status-command-DE-edGgB.js +0 -815
- package/dist/llm-slug-generator-DJgq9eFd.js +0 -78
- package/dist/loader-5AqYM9PC.d.ts +0 -142
- package/dist/local-dispatch.runtime-D3F4v51B.js +0 -10
- package/dist/manager-BWf1ks-Z.d.ts +0 -409
- package/dist/mcp-http-DU7Nsg4P.js +0 -583
- package/dist/mcp-http-iZCW6Cet.js +0 -2
- package/dist/media-runtime-DZ5RpQN7.d.ts +0 -261
- package/dist/media-understanding-DEdEyoQB.d.ts +0 -46
- package/dist/media-understanding-provider-4JHrQOUE.js +0 -70
- package/dist/media-understanding-provider-BV7O82XV.js +0 -29
- package/dist/media-understanding-provider-BlPRhYkx.js +0 -69
- package/dist/media-understanding-provider-BuX8eQLj.js +0 -13
- package/dist/memory-core-host-engine-embeddings-BDu5fx8E.d.ts +0 -324
- package/dist/memory-core-host-engine-storage-CdCuH-E2.d.ts +0 -54
- package/dist/message-handler-L6QLWNVP.js +0 -1806
- package/dist/minimax-web-search-provider-_gxeEOy8.js +0 -58
- package/dist/minimax-web-search-provider.runtime-BF4mGi6U.js +0 -148
- package/dist/minimax-web-search-provider.runtime.js +0 -1
- package/dist/model-catalog-DCnRkX8f.d.ts +0 -88
- package/dist/model-definitions-B2gY43hI.d.ts +0 -34
- package/dist/model-definitions-BLOyeH5h.js +0 -73
- package/dist/model-definitions-CoByf5mT.js +0 -243
- package/dist/model-definitions-WP3OmzbS.d.ts +0 -57
- package/dist/model-selection-DhTE6GZD.js +0 -352
- package/dist/models--iAR9QkZ.js +0 -175
- package/dist/models-8ImVEkvh.js +0 -36
- package/dist/models-BIDM8htk.js +0 -48
- package/dist/models-BRgRfrcS.js +0 -36
- package/dist/models-Bib5-APc.js +0 -67
- package/dist/models-Bl67zOoe.js +0 -36
- package/dist/models-BqDDYFE3.d.ts +0 -65
- package/dist/models-BtRQoRIu.js +0 -36
- package/dist/models-BvXmOXik.js +0 -48
- package/dist/models-C-sJciOD.d.ts +0 -9
- package/dist/models-COnXPdlL.js +0 -24
- package/dist/models-CXTmk-Da.d.ts +0 -8
- package/dist/models-Cz0C_8re.js +0 -36
- package/dist/models-DbwEIt-m.d.ts +0 -15
- package/dist/models-DgXkSADi.js +0 -30
- package/dist/models-cli-Bv3y3JgQ.js +0 -257
- package/dist/monitor-BiVOsbbN.js +0 -1024
- package/dist/monitor-BumfRp1t.js +0 -60
- package/dist/monitor.account-Cd6EwtuZ.js +0 -5382
- package/dist/music-generation-provider-ZdDMiC-c.js +0 -308
- package/dist/nodes-C0f8XgD5.js +0 -1483
- package/dist/nodes-Dk4vOgg9.js +0 -3
- package/dist/nodes-pending-Cjg09MXz.js +0 -211
- package/dist/oauth-BIO69Qw0.d.ts +0 -25
- package/dist/oauth-CnO10TN2.js +0 -207
- package/dist/onboard-B3BYT5k7.js +0 -34
- package/dist/onboard-BDMNV6RE.js +0 -23
- package/dist/onboard-B_WNNy5F.d.ts +0 -6
- package/dist/onboard-BbyMaErU.js +0 -69
- package/dist/onboard-BuYPNE6j2.js +0 -23
- package/dist/onboard-C394zMnM.d.ts +0 -11
- package/dist/onboard-CHn4oVbY.js +0 -24
- package/dist/onboard-CPpVbb0O.js +0 -73
- package/dist/onboard-CWDx7Crt.js +0 -23
- package/dist/onboard-CbzkwBzu.d.ts +0 -12
- package/dist/onboard-D099qUd0.js +0 -23
- package/dist/onboard-D7dbzfHc.js +0 -23
- package/dist/onboard-DB-x0nHF.js +0 -30
- package/dist/onboard-DFVrRnxJ.js +0 -23
- package/dist/onboard-DFiqoOc2.d.ts +0 -7
- package/dist/onboard-DJaMK3rr.d.ts +0 -6
- package/dist/onboard-DMdK8D_h.js +0 -67
- package/dist/onboard-J-KL-I6m.js +0 -48
- package/dist/onboard-MIBU-Rmv.js +0 -39
- package/dist/onboard-vmGylfFe.js +0 -23
- package/dist/openai-compat-errors-Dcr5Y8bF.js +0 -136
- package/dist/openai-http-CcqspzU6.js +0 -836
- package/dist/openresponses-http-BnyYYvUF.js +0 -1175
- package/dist/operations-H2Oq0KYz.js +0 -805
- package/dist/outbound.types-BhRehecY.d.ts +0 -291
- package/dist/plugin-enabled-CEIKWKrq.js +0 -232
- package/dist/plugin-entry-CTVRRaaA.d.ts +0 -47
- package/dist/plugin-registration-BTyO5Fwt.js +0 -97
- package/dist/plugin-runtime-_XF2N_UQ.d.ts +0 -117
- package/dist/plugin-sdk/bundled-channel-config-schema-BsOWCrJT.d.ts +0 -3169
- package/dist/plugin-service-B91jVlmZ.d.ts +0 -24
- package/dist/plugin-service-CtGwVz8V.js +0 -1249
- package/dist/postinstall-inventory.json +0 -5410
- package/dist/prepare.runtime-9dlboph7.js +0 -798
- package/dist/preview-warnings-DJx4KJpC.js +0 -618
- package/dist/program-CWC-NBBB.js +0 -131
- package/dist/provider-api-key-auth-BmNcYRMl.d.ts +0 -27
- package/dist/provider-auth-api-key-CCaFiqY3.js +0 -5
- package/dist/provider-auth-result-D_E9dcVc.d.ts +0 -21
- package/dist/provider-catalog-5KZLmrDO.js +0 -11
- package/dist/provider-catalog-7P6AvDzS.js +0 -11
- package/dist/provider-catalog-B2gyTjTU.js +0 -88
- package/dist/provider-catalog-B3YBhe77.js +0 -17
- package/dist/provider-catalog-B7XEeuUm.js +0 -11
- package/dist/provider-catalog-BFGPRd9v.js +0 -17
- package/dist/provider-catalog-BLvkIMSk.d.ts +0 -6
- package/dist/provider-catalog-BPBL9mJf.d.ts +0 -5
- package/dist/provider-catalog-BRkZ6-HD.d.ts +0 -5
- package/dist/provider-catalog-Bfl_AoTZ.js +0 -142
- package/dist/provider-catalog-BpiHWHu1.js +0 -11
- package/dist/provider-catalog-C1qDLekT.d.ts +0 -5
- package/dist/provider-catalog-CKWNCfry.js +0 -11
- package/dist/provider-catalog-CUHB2pSt.d.ts +0 -7
- package/dist/provider-catalog-CWqN2j6J.d.ts +0 -5
- package/dist/provider-catalog-CZ8oYbx3.js +0 -11
- package/dist/provider-catalog-CcQ5-4ZW.d.ts +0 -6
- package/dist/provider-catalog-Cd16uZ0U.js +0 -20
- package/dist/provider-catalog-CpF2D0VK.js +0 -61
- package/dist/provider-catalog-CvXq36zW.d.ts +0 -5
- package/dist/provider-catalog-D2pgEME3.js +0 -48
- package/dist/provider-catalog-DPzcupEl.d.ts +0 -5
- package/dist/provider-catalog-DaeI606G.d.ts +0 -9
- package/dist/provider-catalog-DrOCtTb-.js +0 -11
- package/dist/provider-catalog-DwZ1J2Al.d.ts +0 -6
- package/dist/provider-catalog-Dy7IcHmS.js +0 -107
- package/dist/provider-catalog-TsZS52nq.d.ts +0 -10
- package/dist/provider-catalog-YqIFRCND.d.ts +0 -5
- package/dist/provider-catalog-Ywb5jRwG.d.ts +0 -5
- package/dist/provider-catalog-evknl1oN.js +0 -11
- package/dist/provider-catalog-l0hFpFO2.d.ts +0 -17
- package/dist/provider-catalog-shared-DsRBv0Tp.d.ts +0 -62
- package/dist/provider-dispatcher-BMy9mBJ1.js +0 -22
- package/dist/provider-model-shared-CPAfQBNs.d.ts +0 -143
- package/dist/provider-models-Diu65OcG.d.ts +0 -18
- package/dist/provider-models-LE7PlLYY.js +0 -22
- package/dist/provider-onboard-CpvXEmvz.d.ts +0 -91
- package/dist/provider-registration-DF-LkmNE.js +0 -235
- package/dist/provider-registry-D9cTPW1F.d.ts +0 -8
- package/dist/provider-registry-DI7gMKUP.d.ts +0 -8
- package/dist/provider-registry-DZtgZDkl.d.ts +0 -29
- package/dist/provider-self-hosted-setup-CoHvoyKm.d.ts +0 -74
- package/dist/provider-stream-BpXJr5Ap.d.ts +0 -139
- package/dist/provider-stream-family-Bj5aBD8w.js +0 -2
- package/dist/provider-stream-shared-BaUkhUHj.d.ts +0 -132
- package/dist/provider-usage-DFUhW2do.js +0 -651
- package/dist/provider-web-search-contract-fields-CkXzSsWu.d.ts +0 -25
- package/dist/pw-ai-9Q_dIq4B.js +0 -3064
- package/dist/register.agent-CbfrlzXB.js +0 -152
- package/dist/register.crestodian-CEg0rPfK.js +0 -24
- package/dist/register.maintenance-k9N8I4Wg.js +0 -85
- package/dist/register.subclis-CrXOeaS3.js +0 -3
- package/dist/register.subclis-DfKlni8N.js +0 -31
- package/dist/register.subclis-core-Bg4wbDsO.js +0 -278
- package/dist/registry-Bh3-P2HL.d.ts +0 -8
- package/dist/registry-types-BmEUS4d3.d.ts +0 -392
- package/dist/repair-sequencing-E4yViXG9.js +0 -652
- package/dist/reply-payload-S2mrc_Mh.d.ts +0 -200
- package/dist/reply-turn-admission-BBoPjmGB.js +0 -2056
- package/dist/reply.runtime-C5wfxVI_.js +0 -2
- package/dist/result-fallback-classifier-CX4iLD1G.js +0 -98
- package/dist/route-CifxcQZ1.js +0 -475
- package/dist/routes-B3XAOeWo.js +0 -2
- package/dist/routes-H185h3U-.js +0 -3701
- package/dist/run-CTJFbwbB.js +0 -1162
- package/dist/run-command-B7B53tYk.js +0 -23
- package/dist/run-command-BFuxRDxS.js +0 -2
- package/dist/run-context-C7im9ICg.js +0 -66
- package/dist/run-embedded.runtime-TljBTbzh.js +0 -4
- package/dist/run-execution-cli.runtime-Bt5zwx1W.js +0 -4
- package/dist/run-executor.runtime-hmbWX2Ct.js +0 -330
- package/dist/run-subagent-registry.runtime-B70X80nS.js +0 -2
- package/dist/runtime-DoKE0o7v.js +0 -436
- package/dist/runtime-api-Ca4Llbgf.js +0 -12
- package/dist/runtime-api-pa8xcEmg.d.ts +0 -5
- package/dist/runtime-channel-CFQ59svm.js +0 -148
- package/dist/runtime-channel-DRwCWGUx.js +0 -2
- package/dist/runtime-embedded-agent.runtime-DwmqKUVp.js +0 -2
- package/dist/runtime-forwarders-BMThPHg_.d.ts +0 -39
- package/dist/sdk-setup-tools-Cg_Tabrf.js +0 -8
- package/dist/selection-COhr7g82.js +0 -18365
- package/dist/selection-_G44EVqd.js +0 -3
- package/dist/send-media-BNc67G7I.js +0 -2072
- package/dist/server-5rR0RCpI.js +0 -24
- package/dist/server-context-BhiPROPA.js +0 -955
- package/dist/server-context-OShBAJZQ.js +0 -2
- package/dist/server-cron-Bkzb9edh.js +0 -3173
- package/dist/server-cron-DdR-ugiU.js +0 -2
- package/dist/server-lwtC1vaS.js +0 -72
- package/dist/server-methods-BY_ZqDFJ.js +0 -497
- package/dist/server-node-events-CLvE94AS.js +0 -597
- package/dist/server-plugin-bootstrap-cKOAH5GL.js +0 -71
- package/dist/server-plugins-CPpUykw5.js +0 -435
- package/dist/server-reload-handlers-uzt4VDZ-.js +0 -719
- package/dist/server-restart-sentinel-CpvV0t4O.js +0 -700
- package/dist/server-runtime-services-BhOHoerM.js +0 -147
- package/dist/server-runtime-services-D3Ig68nC.js +0 -3
- package/dist/server-startup-plugins-DslzKVHK.js +0 -127
- package/dist/server-startup-post-attach-DPFBTQez.js +0 -793
- package/dist/server-ws-runtime-D0zoWoiz.js +0 -374
- package/dist/server.impl-CzqLQ3qt.js +0 -2622
- package/dist/session-kill-http-D8JhwZVS.js +0 -121
- package/dist/session-reset-service-uoi7E4Xp.js +0 -651
- package/dist/session-status.runtime-CZK5IU8w.js +0 -2
- package/dist/session-subagent-reactivation.runtime-BSO00-FY.js +0 -2
- package/dist/session-tab-registry-DM9U7e3o.js +0 -551
- package/dist/sessions-B-SkIoaa.js +0 -1917
- package/dist/sessions-history-http-DCiOG4FK.js +0 -432
- package/dist/sessions-patch-DlAAvQvB.js +0 -401
- package/dist/sessions-resolve-DfMXookg.js +0 -180
- package/dist/sessions.runtime-0V2YxKxB.js +0 -2
- package/dist/snapshot-urls-Ble1-NEW.js +0 -317
- package/dist/speech-core-Bk60ZS_y.d.ts +0 -49
- package/dist/speech-provider-DQO9eZd0.js +0 -233
- package/dist/speech-provider-DnBCla4V.js +0 -171
- package/dist/speech-provider-DyYHFxT5.js +0 -227
- package/dist/standalone-9EWfcxeO.js +0 -42
- package/dist/startup-context-nti4X0_w.js +0 -314
- package/dist/status-subagents.runtime-CPZb1EF1.js +0 -32
- package/dist/status-text-C1Hf37lF.js +0 -301
- package/dist/stream-9VBt1MDs.js +0 -26
- package/dist/stream-B_3P7v7P.js +0 -86
- package/dist/stream-CXsue2-v.d.ts +0 -9
- package/dist/stream-oNBFxfKt.d.ts +0 -5
- package/dist/subagent-announce-CPjQQLy8.js +0 -353
- package/dist/subagent-announce-delivery-B6iBOicL.js +0 -1369
- package/dist/subagent-control-DP72sk-l.js +0 -492
- package/dist/subagent-hooks-B1oUIYH3.js +0 -2
- package/dist/subagent-hooks-BkGj4_xI.js +0 -230
- package/dist/subagent-hooks-api-D2mulK3S.js +0 -23
- package/dist/subagent-registry-CEKAUB5h.js +0 -3
- package/dist/subagent-registry-OUVucPAn.js +0 -2627
- package/dist/subagent-session-cleanup-Bx8d3kw0.js +0 -390
- package/dist/system-CelaP2zI.js +0 -111
- package/dist/talk-DGOI3Lu3.js +0 -2454
- package/dist/target-id-BXRG7x9x.js +0 -107
- package/dist/thinking-B8V29FhB.js +0 -35
- package/dist/thread-bindings-DpVdEPZ0.js +0 -228
- package/dist/tool-DHzDpxE4.js +0 -143
- package/dist/tool-dispatch-ClP3Rc7g.js +0 -155
- package/dist/tool-resolution-CZcLod1d.js +0 -153
- package/dist/tool-split-BhiQ8676.d.ts +0 -19
- package/dist/tools-ZvSvbsCW.d.ts +0 -38
- package/dist/tools-effective-C2mHZT-A.js +0 -442
- package/dist/tools-effective-inventory-ctnM7hc6.js +0 -379
- package/dist/tools-invoke-Ci6Rux2s.js +0 -51
- package/dist/tools-invoke-http-CJflXcJk.js +0 -68
- package/dist/tools-invoke-shared-BLu_mJEX.js +0 -200
- package/dist/tts-B2rPJPij.js +0 -83
- package/dist/tts-Gp9FI3_n.js +0 -163
- package/dist/tts-runtime-DNi1HXPF.d.ts +0 -230
- package/dist/tui-BUhfQ9vD.js +0 -3
- package/dist/tui-BhH5mvLf.js +0 -2
- package/dist/tui-backend-C_4ajTHI.js +0 -257
- package/dist/tui-cli-BhWJ-QoB.js +0 -40
- package/dist/tui-ink-run-BTWbUQGb.js +0 -7414
- package/dist/tui-ink-run-DfTdivkh.js +0 -2
- package/dist/types-B4fW3r5y.d.ts +0 -111
- package/dist/types-DI62NfFe.d.ts +0 -7034
- package/dist/types-sAih_uQb.d.ts +0 -393
- package/dist/types.public-B3MKhuo2.d.ts +0 -70
- package/dist/video-generation-B9c6a5cw.js +0 -207
- package/dist/video-generation-BgJp7UIA.d.ts +0 -224
- package/dist/video-generation-provider-BjiVjf40.js +0 -325
- package/dist/video-generation-provider-CsnQJg_h.js +0 -297
- package/dist/video-generation-provider-DtU-ZPqP.js +0 -64
- package/dist/video-generation-provider-wZ0bzv0e.js +0 -77
- package/dist/webhook-targets-Cy8e7y3g.d.ts +0 -99
- package/dist/zod-schema.core-BGLctDlK.d.ts +0 -166
- package/skills/canvas/SKILL.md +0 -78
- package/skills/clawhub/SKILL.md +0 -77
- package/skills/coding-agent/SKILL.md +0 -143
- package/skills/diagram-maker/SKILL.md +0 -53
- package/skills/diagram-maker/references/excalidraw-patterns.md +0 -85
- package/skills/diagram-maker/references/svg-template.md +0 -112
- package/skills/gemini/SKILL.md +0 -47
- package/skills/gh-issues/SKILL.md +0 -213
- package/skills/gifgrep/SKILL.md +0 -85
- package/skills/github/SKILL.md +0 -84
- package/skills/healthcheck/SKILL.md +0 -105
- package/skills/mcporter/SKILL.md +0 -61
- package/skills/meme-maker/SKILL.md +0 -42
- package/skills/meme-maker/references/templates.json +0 -358
- package/skills/meme-maker/scripts/meme.mjs +0 -398
- package/skills/model-usage/SKILL.md +0 -71
- package/skills/model-usage/references/codexbar-cli.md +0 -33
- package/skills/model-usage/scripts/model_usage.py +0 -319
- package/skills/model-usage/scripts/test_model_usage.py +0 -40
- package/skills/nano-pdf/SKILL.md +0 -38
- package/skills/node-connect/SKILL.md +0 -143
- package/skills/node-inspect-debugger/SKILL.md +0 -85
- package/skills/openai-whisper/SKILL.md +0 -38
- package/skills/openai-whisper-api/SKILL.md +0 -71
- package/skills/openai-whisper-api/scripts/transcribe.sh +0 -154
- package/skills/oracle/SKILL.md +0 -126
- package/skills/pyproject.toml +0 -10
- package/skills/python-debugpy/SKILL.md +0 -73
- package/skills/sag/SKILL.md +0 -87
- package/skills/session-logs/SKILL.md +0 -151
- package/skills/sherpa-onnx-tts/SKILL.md +0 -109
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +0 -178
- package/skills/skill-creator/SKILL.md +0 -78
- package/skills/skill-creator/license.txt +0 -202
- package/skills/skill-creator/scripts/init_skill.py +0 -378
- package/skills/skill-creator/scripts/package_skill.py +0 -139
- package/skills/skill-creator/scripts/quick_validate.py +0 -169
- package/skills/skill-creator/scripts/test_package_skill.py +0 -161
- package/skills/skill-creator/scripts/test_quick_validate.py +0 -116
- package/skills/spike/SKILL.md +0 -51
- package/skills/summarize/SKILL.md +0 -87
- package/skills/taskflow/SKILL.md +0 -149
- package/skills/taskflow/examples/inbox-triage.lobster +0 -33
- package/skills/taskflow/examples/pr-intake.lobster +0 -32
- package/skills/taskflow-inbox-triage/SKILL.md +0 -119
- package/skills/video-frames/SKILL.md +0 -46
- package/skills/video-frames/scripts/frame.sh +0 -81
- package/skills/voice-call/SKILL.md +0 -45
- package/skills/weather/SKILL.md +0 -64
- /package/dist/{acp-runtime-backend-DbchQ02o.js → acp-runtime-backend-DZ1Lnt7f.js} +0 -0
- /package/dist/{delegate-k1aptKei.js → delegate-CwhxUdeb.js} +0 -0
- /package/dist/{dispatch-acp-CD4YxPpf.js → dispatch-acp-BP4I5ZQf.js} +0 -0
- /package/dist/{exec-approvals-ByWUCFQM.js → exec-approvals-ByWUCFQM2.js} +0 -0
- /package/dist/{heartbeat-runner-CM0UZxa_.js → heartbeat-runner-CL3alQ8-.js} +0 -0
- /package/dist/{index-B0VJdRJQ.d.ts → index-B0VJdRJQ2.d.ts} +0 -0
- /package/dist/{library-CQ71yATP.js → library-CiTr_aqC.js} +0 -0
- /package/dist/{run-session-state-DbDeH-q6.js → run-session-state-BOMUtBKZ.js} +0 -0
- /package/dist/{session-subagent-reactivation-Bj91A2ms.js → session-subagent-reactivation-CH0C2I6Y.js} +0 -0
- /package/dist/{types-C4HgagiY2.d.ts → types-C4HgagiY.d.ts} +0 -0
|
@@ -1,1369 +0,0 @@
|
|
|
1
|
-
import { c as normalizeOptionalString, s as normalizeOptionalLowercaseString } from "./string-coerce-DKw2K5wM.js";
|
|
2
|
-
import { u as clampTimerTimeoutMs } from "./number-coercion-D1aDmIZp.js";
|
|
3
|
-
import { i as asOptionalRecord } from "./record-coerce-Btbek4uV.js";
|
|
4
|
-
import { _ as uniqueStrings, l as normalizeStringEntries } from "./string-normalization-B8G0vlWE.js";
|
|
5
|
-
import { n as defaultRuntime } from "./runtime-BkTkFkXs.js";
|
|
6
|
-
import { i as isCronSessionKey, r as isCronRunSessionKey } from "./session-key-utils-CdfsDYvz.js";
|
|
7
|
-
import { n as normalizeAccountId } from "./account-id-B0YIFDpA.js";
|
|
8
|
-
import { d as resolveAgentIdFromSessionKey, u as normalizeMainKey } from "./session-key-CJf5_zWs.js";
|
|
9
|
-
import { i as getRuntimeConfig } from "./io-T1CV3Z1L.js";
|
|
10
|
-
import "./config-4B-JCqw_.js";
|
|
11
|
-
import "./message-channel-core-rOsWksPZ.js";
|
|
12
|
-
import { i as normalizeMessageChannel, n as isGatewayMessageChannel, t as isDeliverableMessageChannel } from "./message-channel-normalize-CaOaCinb.js";
|
|
13
|
-
import { r as isInternalMessageChannel } from "./message-channel-DcN_7tYD.js";
|
|
14
|
-
import "./call-CLicF0UE.js";
|
|
15
|
-
import { t as getGlobalHookRunner } from "./hook-runner-global-De3loPgD.js";
|
|
16
|
-
import { i as resolveMainSessionKey } from "./main-session-BxJmPEXx.js";
|
|
17
|
-
import { h as stringifyRouteThreadId } from "./channel-route-Dvehdg4D.js";
|
|
18
|
-
import { i as mergeDeliveryContext, o as normalizeDeliveryContext } from "./delivery-context.shared-CHlZnq4E.js";
|
|
19
|
-
import { u as resolveStorePath } from "./paths-C79m3Aob.js";
|
|
20
|
-
import { t as loadSessionStore } from "./store-load-CVdafI-Y.js";
|
|
21
|
-
import { t as getLoadedChannelPluginForRead } from "./registry-loaded-read-DIN4SLls.js";
|
|
22
|
-
import "./sessions-CtMqsEs2.js";
|
|
23
|
-
import { n as isSessionWriteLockTimeoutError } from "./session-write-lock-error-D7notSUr.js";
|
|
24
|
-
import { a as INTERNAL_RUNTIME_CONTEXT_BEGIN, o as INTERNAL_RUNTIME_CONTEXT_END, s as escapeInternalRuntimeContextDelimiters } from "./internal-runtime-context-CxLegvGY.js";
|
|
25
|
-
import { t as deriveSessionChatTypeFromKey } from "./session-chat-type-shared-BmwVtAEN.js";
|
|
26
|
-
import { t as completionRequiresMessageToolDelivery } from "./completion-delivery-policy-C2s_SPfA.js";
|
|
27
|
-
import { g as resolveActiveEmbeddedRunSessionId, i as formatEmbeddedAgentQueueFailureSummary, l as isEmbeddedRunAbandoned, o as isEmbeddedAgentRunActive, p as queueEmbeddedAgentMessageWithOutcomeAsync } from "./runs-B0iD89hy.js";
|
|
28
|
-
import { r as isSilentReplyPayloadText } from "./tokens-T0RrWCee.js";
|
|
29
|
-
import { a as isAgentMediatedCompletionSourceTool, c as shouldPreserveUserFacingSessionStateForInputProvenance } from "./input-provenance-DCrP7aPH.js";
|
|
30
|
-
import { n as getSessionBindingService, s as normalizeConversationRef } from "./session-binding-service-BjjMIxQb.js";
|
|
31
|
-
import { s as isOutboundDeliveryError } from "./deliver-jDF9kjsI.js";
|
|
32
|
-
import { s as getSubagentDepthFromSessionStore } from "./subagent-capabilities-BPtXB0Jr.js";
|
|
33
|
-
import { t as basenameFromAnyPath } from "./file-name-r4prf02z.js";
|
|
34
|
-
import "./delivery-context-v_9n6y-v.js";
|
|
35
|
-
import { n as wrapPromptDataBlock } from "./sanitize-for-prompt-ByaJGDhT.js";
|
|
36
|
-
import { n as routeFromConversationRef, r as routeToDeliveryFields } from "./route-projection-Cj57ZNoN.js";
|
|
37
|
-
import { a as normalizeTargetForProvider } from "./target-normalization-CdGT-rCn.js";
|
|
38
|
-
import { r as dispatchGatewayMethodInProcess } from "./server-plugins-CPpUykw5.js";
|
|
39
|
-
import { t as resolveQueueSettings } from "./queue-Bp_sf0n7.js";
|
|
40
|
-
import { t as resolveExternalBestEffortDeliveryTarget } from "./best-effort-delivery-B8Rfs1sR.js";
|
|
41
|
-
import { t as sendMessage } from "./message-DAXqRFEs.js";
|
|
42
|
-
import { t as resolveConversationIdFromTargets } from "./conversation-id-CzrxbaE6.js";
|
|
43
|
-
//#region src/agents/generated-attachments.ts
|
|
44
|
-
function generatedAttachmentReference(attachment) {
|
|
45
|
-
return normalizeOptionalString(attachment.path ?? attachment.url ?? attachment.mediaUrl ?? attachment.filePath);
|
|
46
|
-
}
|
|
47
|
-
function mediaUrlsFromGeneratedAttachments(attachments) {
|
|
48
|
-
return uniqueStrings(attachments?.flatMap((attachment) => generatedAttachmentReference(attachment) ?? []) ?? []);
|
|
49
|
-
}
|
|
50
|
-
function nameFromGeneratedAttachment(attachment) {
|
|
51
|
-
return normalizeOptionalString(attachment.name) ?? basenameFromAnyPath(generatedAttachmentReference(attachment) ?? "");
|
|
52
|
-
}
|
|
53
|
-
function formatGeneratedAttachmentLines(attachments) {
|
|
54
|
-
if (!attachments?.length) return [];
|
|
55
|
-
const lines = ["Attachments:"];
|
|
56
|
-
for (const [index, attachment] of attachments.entries()) {
|
|
57
|
-
const parts = [`${index + 1}.`];
|
|
58
|
-
const type = normalizeOptionalString(attachment.type);
|
|
59
|
-
const name = nameFromGeneratedAttachment(attachment);
|
|
60
|
-
const mimeType = normalizeOptionalString(attachment.mimeType);
|
|
61
|
-
const path = normalizeOptionalString(attachment.path ?? attachment.filePath);
|
|
62
|
-
const url = normalizeOptionalString(attachment.url ?? attachment.mediaUrl);
|
|
63
|
-
if (type) parts.push(`type=${type}`);
|
|
64
|
-
if (name) parts.push(`name=${JSON.stringify(name)}`);
|
|
65
|
-
if (mimeType) parts.push(`mimeType=${mimeType}`);
|
|
66
|
-
if (path) parts.push(`path=${JSON.stringify(path)}`);
|
|
67
|
-
else if (url) parts.push(`mediaUrl=${JSON.stringify(url)}`);
|
|
68
|
-
lines.push(parts.join(" "));
|
|
69
|
-
}
|
|
70
|
-
return lines;
|
|
71
|
-
}
|
|
72
|
-
//#endregion
|
|
73
|
-
//#region src/agents/internal-event-contract.ts
|
|
74
|
-
const AGENT_INTERNAL_EVENT_TYPE_TASK_COMPLETION = "task_completion";
|
|
75
|
-
//#endregion
|
|
76
|
-
//#region src/agents/internal-events.ts
|
|
77
|
-
function sanitizeSingleLineField(value, fallback) {
|
|
78
|
-
return escapeInternalRuntimeContextDelimiters(value).replace(/\r?\n+/g, " ").trim() || fallback;
|
|
79
|
-
}
|
|
80
|
-
function sanitizeMultilineField(value, fallback) {
|
|
81
|
-
return escapeInternalRuntimeContextDelimiters(value).replace(/\r\n/g, "\n").trim() || fallback;
|
|
82
|
-
}
|
|
83
|
-
function formatChildResultDataBlock(value) {
|
|
84
|
-
return wrapPromptDataBlock({
|
|
85
|
-
label: "Child result",
|
|
86
|
-
text: value
|
|
87
|
-
}) || "Child result: (no output)";
|
|
88
|
-
}
|
|
89
|
-
function formatTaskCompletionEvent(event) {
|
|
90
|
-
const sessionKey = sanitizeSingleLineField(event.childSessionKey, "unknown");
|
|
91
|
-
const sessionId = sanitizeSingleLineField(event.childSessionId ?? "unknown", "unknown");
|
|
92
|
-
const announceType = sanitizeSingleLineField(event.announceType, "unknown");
|
|
93
|
-
const taskLabel = sanitizeSingleLineField(event.taskLabel, "unnamed task");
|
|
94
|
-
const statusLabel = sanitizeSingleLineField(event.statusLabel, event.status);
|
|
95
|
-
const result = formatChildResultDataBlock(event.result);
|
|
96
|
-
const attachmentLines = formatGeneratedAttachmentLines(event.attachments);
|
|
97
|
-
const lines = [
|
|
98
|
-
"[Internal task completion event]",
|
|
99
|
-
`source: ${event.source}`,
|
|
100
|
-
`session_key: ${sessionKey}`,
|
|
101
|
-
`session_id: ${sessionId}`,
|
|
102
|
-
`type: ${announceType}`,
|
|
103
|
-
`task: ${taskLabel}`,
|
|
104
|
-
`status: ${statusLabel}`,
|
|
105
|
-
"",
|
|
106
|
-
result
|
|
107
|
-
];
|
|
108
|
-
if (attachmentLines.length > 0) lines.push("", ...attachmentLines);
|
|
109
|
-
if (event.statsLine?.trim()) lines.push("", sanitizeMultilineField(event.statsLine, ""));
|
|
110
|
-
lines.push("", "Action:", sanitizeMultilineField(event.replyInstruction, ""));
|
|
111
|
-
return lines.join("\n");
|
|
112
|
-
}
|
|
113
|
-
function formatTaskCompletionEventForPlainPrompt(event) {
|
|
114
|
-
const sessionKey = sanitizeSingleLineField(event.childSessionKey, "unknown");
|
|
115
|
-
const sessionId = sanitizeSingleLineField(event.childSessionId ?? "unknown", "unknown");
|
|
116
|
-
const announceType = sanitizeSingleLineField(event.announceType, "unknown");
|
|
117
|
-
const taskLabel = sanitizeSingleLineField(event.taskLabel, "unnamed task");
|
|
118
|
-
const statusLabel = sanitizeSingleLineField(event.statusLabel, event.status);
|
|
119
|
-
const result = formatChildResultDataBlock(event.result);
|
|
120
|
-
const attachmentLines = formatGeneratedAttachmentLines(event.attachments);
|
|
121
|
-
const lines = [
|
|
122
|
-
"A background task completed. Use this result to reply to the user in your normal assistant voice.",
|
|
123
|
-
"",
|
|
124
|
-
`source: ${event.source}`,
|
|
125
|
-
`session_key: ${sessionKey}`,
|
|
126
|
-
`session_id: ${sessionId}`,
|
|
127
|
-
`type: ${announceType}`,
|
|
128
|
-
`task: ${taskLabel}`,
|
|
129
|
-
`status: ${statusLabel}`,
|
|
130
|
-
"",
|
|
131
|
-
result
|
|
132
|
-
];
|
|
133
|
-
if (attachmentLines.length > 0) lines.push("", ...attachmentLines);
|
|
134
|
-
if (event.statsLine?.trim()) lines.push("", sanitizeMultilineField(event.statsLine, ""));
|
|
135
|
-
lines.push("", "Instruction:", sanitizeMultilineField(event.replyInstruction, ""));
|
|
136
|
-
return lines.join("\n");
|
|
137
|
-
}
|
|
138
|
-
function formatAgentInternalEventsForPrompt(events) {
|
|
139
|
-
if (!events || events.length === 0) return "";
|
|
140
|
-
const blocks = events.map((event) => {
|
|
141
|
-
if (event.type === "task_completion") return formatTaskCompletionEvent(event);
|
|
142
|
-
return "";
|
|
143
|
-
}).filter((value) => value.trim().length > 0);
|
|
144
|
-
if (blocks.length === 0) return "";
|
|
145
|
-
return [
|
|
146
|
-
INTERNAL_RUNTIME_CONTEXT_BEGIN,
|
|
147
|
-
"FengMing runtime context (internal):",
|
|
148
|
-
"This context is runtime-generated, not user-authored. Keep internal details private.",
|
|
149
|
-
"",
|
|
150
|
-
blocks.join("\n\n---\n\n"),
|
|
151
|
-
INTERNAL_RUNTIME_CONTEXT_END
|
|
152
|
-
].join("\n");
|
|
153
|
-
}
|
|
154
|
-
function formatAgentInternalEventsForPlainPrompt(events) {
|
|
155
|
-
if (!events || events.length === 0) return "";
|
|
156
|
-
return events.map((event) => {
|
|
157
|
-
if (event.type === "task_completion") return formatTaskCompletionEventForPlainPrompt(event);
|
|
158
|
-
return "";
|
|
159
|
-
}).filter((value) => value.trim().length > 0).join("\n\n---\n\n");
|
|
160
|
-
}
|
|
161
|
-
//#endregion
|
|
162
|
-
//#region src/infra/outbound/source-delivery-plan.ts
|
|
163
|
-
function isMessageToolOwnedDelivery(owner) {
|
|
164
|
-
return owner === "message_tool" || owner === "message_tool_then_direct_fallback";
|
|
165
|
-
}
|
|
166
|
-
function normalizeDeliveryTarget(channel, to) {
|
|
167
|
-
const toTrimmed = to.trim();
|
|
168
|
-
return normalizeTargetForProvider(channel, toTrimmed) ?? toTrimmed;
|
|
169
|
-
}
|
|
170
|
-
const caseSensitivePrefixedTargetProviders = new Set([
|
|
171
|
-
"googlechat",
|
|
172
|
-
"mattermost",
|
|
173
|
-
"matrix"
|
|
174
|
-
]);
|
|
175
|
-
const lowercaseNormalizedPrefixedTargetProviders = new Set(["discord", "slack"]);
|
|
176
|
-
function deliveryTargetsMatch(channel, targetTo, deliveryTo) {
|
|
177
|
-
const targetToTrimmed = targetTo.trim();
|
|
178
|
-
const deliveryToTrimmed = deliveryTo.trim();
|
|
179
|
-
if (targetToTrimmed === deliveryToTrimmed) return true;
|
|
180
|
-
const targetPrefixed = targetToTrimmed.match(/^([a-z][a-z0-9_-]*):(.*)$/i);
|
|
181
|
-
const deliveryPrefixed = deliveryToTrimmed.match(/^([a-z][a-z0-9_-]*):(.*)$/i);
|
|
182
|
-
const targetKind = targetPrefixed?.[1]?.toLowerCase();
|
|
183
|
-
const deliveryKind = deliveryPrefixed?.[1]?.toLowerCase();
|
|
184
|
-
if (targetKind && targetKind === deliveryKind && [
|
|
185
|
-
"channel",
|
|
186
|
-
"conversation",
|
|
187
|
-
"group",
|
|
188
|
-
"user"
|
|
189
|
-
].includes(targetKind)) {
|
|
190
|
-
const targetId = targetPrefixed?.[2]?.trim();
|
|
191
|
-
const deliveryId = deliveryPrefixed?.[2]?.trim();
|
|
192
|
-
if (caseSensitivePrefixedTargetProviders.has(channel)) return targetId === deliveryId;
|
|
193
|
-
if (lowercaseNormalizedPrefixedTargetProviders.has(channel)) return targetId?.toLowerCase() === deliveryId?.toLowerCase();
|
|
194
|
-
}
|
|
195
|
-
return normalizeDeliveryTarget(channel, targetToTrimmed) === normalizeDeliveryTarget(channel, deliveryToTrimmed);
|
|
196
|
-
}
|
|
197
|
-
function normalizeDeliveryThreadId(threadId) {
|
|
198
|
-
return stringifyRouteThreadId(threadId)?.trim() || void 0;
|
|
199
|
-
}
|
|
200
|
-
function extractTopicThreadId(targetTo) {
|
|
201
|
-
return targetTo.match(/:topic:(\d+)$/i)?.[1];
|
|
202
|
-
}
|
|
203
|
-
function sourceDeliveryTargetsMatch(target, delivery) {
|
|
204
|
-
if (!delivery.channel || !delivery.to || !target.to) return false;
|
|
205
|
-
const channel = delivery.channel.trim().toLowerCase();
|
|
206
|
-
const provider = target.provider?.trim().toLowerCase();
|
|
207
|
-
if (provider && provider !== "message" && provider !== channel) return false;
|
|
208
|
-
if (delivery.accountId && target.accountId && target.accountId !== delivery.accountId) return false;
|
|
209
|
-
if (!deliveryTargetsMatch(channel, target.to.replace(/:topic:\d+$/, ""), delivery.to)) return false;
|
|
210
|
-
const deliveryThreadId = normalizeDeliveryThreadId(delivery.threadId);
|
|
211
|
-
const targetThreadId = normalizeDeliveryThreadId(target.threadId) ?? extractTopicThreadId(target.to);
|
|
212
|
-
if (!deliveryThreadId && !targetThreadId) return true;
|
|
213
|
-
if (deliveryThreadId && !targetThreadId) return target.threadImplicit === true && target.threadSuppressed !== true;
|
|
214
|
-
return deliveryThreadId === targetThreadId;
|
|
215
|
-
}
|
|
216
|
-
function createSourceDeliveryPlan(params) {
|
|
217
|
-
const messageToolOwnsDelivery = isMessageToolOwnedDelivery(params.owner);
|
|
218
|
-
const sourceReplyDeliveryMode = messageToolOwnsDelivery ? "message_tool_only" : void 0;
|
|
219
|
-
const directDelivery = params.directFallback ?? (params.owner === "direct_fallback" || params.owner === "message_tool_then_direct_fallback");
|
|
220
|
-
return {
|
|
221
|
-
owner: params.owner,
|
|
222
|
-
reason: params.reason,
|
|
223
|
-
target: params.target ?? {},
|
|
224
|
-
normalFinal: sourceReplyDeliveryMode === "message_tool_only" || params.owner === "none" ? "private" : "visible",
|
|
225
|
-
sourceReplyDeliveryMode,
|
|
226
|
-
messageTool: {
|
|
227
|
-
enabled: params.messageToolEnabled ?? messageToolOwnsDelivery,
|
|
228
|
-
force: params.messageToolForced ?? messageToolOwnsDelivery,
|
|
229
|
-
requireExplicitTarget: params.requireExplicitMessageTarget ?? false,
|
|
230
|
-
defaultTarget: Boolean(params.target?.channel || params.target?.to)
|
|
231
|
-
},
|
|
232
|
-
fallback: {
|
|
233
|
-
directDelivery,
|
|
234
|
-
skipWhenMessageToolSentToTarget: params.skipFallbackWhenMessageToolSentToTarget ?? params.owner === "message_tool_then_direct_fallback",
|
|
235
|
-
bestEffort: params.fallbackBestEffort ?? false
|
|
236
|
-
},
|
|
237
|
-
progress: { allowCallbacksWhenSourceDeliverySuppressed: params.allowProgressCallbacksWhenSourceDeliverySuppressed ?? false }
|
|
238
|
-
};
|
|
239
|
-
}
|
|
240
|
-
function resolveImplicitMessageToolDeliveryTarget(plan) {
|
|
241
|
-
if (!plan.target.channel || !plan.target.to) return;
|
|
242
|
-
const threadId = stringifyRouteThreadId(plan.target.threadId);
|
|
243
|
-
return {
|
|
244
|
-
tool: "message",
|
|
245
|
-
provider: plan.target.channel,
|
|
246
|
-
...plan.target.accountId ? { accountId: plan.target.accountId } : {},
|
|
247
|
-
...plan.target.to ? { to: plan.target.to } : {},
|
|
248
|
-
...threadId ? { threadId } : {}
|
|
249
|
-
};
|
|
250
|
-
}
|
|
251
|
-
function resolveSourceDeliveryOutcome(plan, params) {
|
|
252
|
-
const didSendViaMessageTool = params.didSendViaMessageTool === true;
|
|
253
|
-
const explicitTargets = params.messageToolSentTargets ?? [];
|
|
254
|
-
const sentTargets = explicitTargets.length > 0 ? explicitTargets : didSendViaMessageTool ? [resolveImplicitMessageToolDeliveryTarget(plan)].filter((target) => Boolean(target)) : [];
|
|
255
|
-
const visibleDeliveries = sentTargets.map((target) => ({
|
|
256
|
-
via: "message_tool",
|
|
257
|
-
target,
|
|
258
|
-
verifiedTarget: sourceDeliveryTargetsMatch(target, plan.target)
|
|
259
|
-
}));
|
|
260
|
-
const hasVerifiedMessageToolDelivery = visibleDeliveries.some((delivery) => didSendViaMessageTool && delivery.verifiedTarget);
|
|
261
|
-
return {
|
|
262
|
-
visibleDeliveries,
|
|
263
|
-
verifiedMessageToolDelivery: hasVerifiedMessageToolDelivery,
|
|
264
|
-
satisfiesSourceDelivery: plan.fallback.skipWhenMessageToolSentToTarget && hasVerifiedMessageToolDelivery,
|
|
265
|
-
unverifiedMessageToolDelivery: didSendViaMessageTool && sentTargets.length > 0 && !hasVerifiedMessageToolDelivery
|
|
266
|
-
};
|
|
267
|
-
}
|
|
268
|
-
//#endregion
|
|
269
|
-
//#region src/shared/agent-run-status.ts
|
|
270
|
-
const NON_TERMINAL_AGENT_RUN_STATUSES = new Set([
|
|
271
|
-
"accepted",
|
|
272
|
-
"started",
|
|
273
|
-
"in_flight"
|
|
274
|
-
]);
|
|
275
|
-
function isNonTerminalAgentRunStatus(status) {
|
|
276
|
-
return typeof status === "string" && NON_TERMINAL_AGENT_RUN_STATUSES.has(status);
|
|
277
|
-
}
|
|
278
|
-
//#endregion
|
|
279
|
-
//#region src/agents/accepted-session-spawn.ts
|
|
280
|
-
function normalizeAcceptedSessionSpawnResult(result) {
|
|
281
|
-
const details = asOptionalRecord(asOptionalRecord(result)?.details);
|
|
282
|
-
if (!details || details.status !== "accepted") return null;
|
|
283
|
-
const runId = normalizeOptionalString(details.runId);
|
|
284
|
-
const childSessionKey = normalizeOptionalString(details.childSessionKey);
|
|
285
|
-
if (!runId || !childSessionKey) return null;
|
|
286
|
-
return {
|
|
287
|
-
runId,
|
|
288
|
-
childSessionKey
|
|
289
|
-
};
|
|
290
|
-
}
|
|
291
|
-
function hasAcceptedSessionSpawn(acceptedSessionSpawns) {
|
|
292
|
-
return (acceptedSessionSpawns ?? []).some((spawn) => {
|
|
293
|
-
const record = asOptionalRecord(spawn);
|
|
294
|
-
if (!record) return false;
|
|
295
|
-
return Boolean(normalizeOptionalString(record.runId) && normalizeOptionalString(record.childSessionKey));
|
|
296
|
-
});
|
|
297
|
-
}
|
|
298
|
-
//#endregion
|
|
299
|
-
//#region src/agents/embedded-agent-runner/delivery-evidence.ts
|
|
300
|
-
function hasNonEmptyString(value) {
|
|
301
|
-
return typeof value === "string" && value.trim().length > 0;
|
|
302
|
-
}
|
|
303
|
-
function hasNonEmptyArray(value) {
|
|
304
|
-
return Array.isArray(value) && value.length > 0;
|
|
305
|
-
}
|
|
306
|
-
function hasNonEmptyStringArray(value) {
|
|
307
|
-
return Array.isArray(value) && value.some(hasNonEmptyString);
|
|
308
|
-
}
|
|
309
|
-
function collectStringValues(value, output) {
|
|
310
|
-
if (typeof value === "string" && value.trim()) {
|
|
311
|
-
output.add(value.trim());
|
|
312
|
-
return;
|
|
313
|
-
}
|
|
314
|
-
if (!Array.isArray(value)) return;
|
|
315
|
-
for (const entry of value) if (typeof entry === "string" && entry.trim()) output.add(entry.trim());
|
|
316
|
-
}
|
|
317
|
-
function collectMediaUrlsFromRecord(record, output) {
|
|
318
|
-
collectStringValues(record.mediaUrl, output);
|
|
319
|
-
collectStringValues(record.mediaUrls, output);
|
|
320
|
-
collectStringValues(record.path, output);
|
|
321
|
-
collectStringValues(record.url, output);
|
|
322
|
-
collectStringValues(record.filePath, output);
|
|
323
|
-
const attachments = record.attachments;
|
|
324
|
-
if (Array.isArray(attachments)) {
|
|
325
|
-
for (const attachment of attachments) if (attachment && typeof attachment === "object" && !Array.isArray(attachment)) collectMediaUrlsFromRecord(attachment, output);
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
function collectDeliveredMediaUrls(result) {
|
|
329
|
-
const urls = /* @__PURE__ */ new Set();
|
|
330
|
-
if (Array.isArray(result.payloads)) {
|
|
331
|
-
for (const payload of result.payloads) if (payload && typeof payload === "object" && !Array.isArray(payload)) collectMediaUrlsFromRecord(payload, urls);
|
|
332
|
-
}
|
|
333
|
-
for (const url of collectMessagingToolDeliveredMediaUrls(result)) urls.add(url);
|
|
334
|
-
return Array.from(urls);
|
|
335
|
-
}
|
|
336
|
-
function collectMessagingToolDeliveredMediaUrls(result) {
|
|
337
|
-
const urls = /* @__PURE__ */ new Set();
|
|
338
|
-
collectStringValues(result.messagingToolSentMediaUrls, urls);
|
|
339
|
-
if (Array.isArray(result.messagingToolSentTargets)) {
|
|
340
|
-
for (const target of result.messagingToolSentTargets) if (target && typeof target === "object" && !Array.isArray(target)) collectMediaUrlsFromRecord(target, urls);
|
|
341
|
-
}
|
|
342
|
-
return Array.from(urls);
|
|
343
|
-
}
|
|
344
|
-
function hasPositiveNumber(value) {
|
|
345
|
-
return typeof value === "number" && Number.isFinite(value) && value > 0;
|
|
346
|
-
}
|
|
347
|
-
function getGatewayAgentResult(response) {
|
|
348
|
-
if (!response || typeof response !== "object") return null;
|
|
349
|
-
const candidate = hasAgentDeliveryEvidenceShape(response) ? response : response.result;
|
|
350
|
-
if (!candidate || typeof candidate !== "object" || !hasAgentDeliveryEvidenceShape(candidate)) return null;
|
|
351
|
-
return candidate;
|
|
352
|
-
}
|
|
353
|
-
function hasAgentDeliveryEvidenceShape(value) {
|
|
354
|
-
return "payloads" in value || "deliveryStatus" in value || "didSendViaMessagingTool" in value || "messagingToolSentTexts" in value || "messagingToolSentMediaUrls" in value || "messagingToolSentTargets" in value || "acceptedSessionSpawns" in value || "successfulCronAdds" in value || "meta" in value;
|
|
355
|
-
}
|
|
356
|
-
function hasVisibleAgentPayload(result, options = {}) {
|
|
357
|
-
const payloads = result.payloads;
|
|
358
|
-
if (!Array.isArray(payloads)) return false;
|
|
359
|
-
return payloads.some((payload) => {
|
|
360
|
-
if (!payload || typeof payload !== "object") return false;
|
|
361
|
-
const record = payload;
|
|
362
|
-
if (options.includeErrorPayloads === false && record.isError === true) return false;
|
|
363
|
-
if (options.includeReasoningPayloads === false && record.isReasoning === true) return false;
|
|
364
|
-
return Boolean(hasNonEmptyString(record.text) || hasNonEmptyString(record.mediaUrl) || hasNonEmptyStringArray(record.mediaUrls) || record.presentation || record.interactive || record.channelData);
|
|
365
|
-
});
|
|
366
|
-
}
|
|
367
|
-
function hasMessagingToolDeliveryEvidence(result) {
|
|
368
|
-
return result.didSendViaMessagingTool === true || hasCommittedMessagingToolDeliveryEvidence(result);
|
|
369
|
-
}
|
|
370
|
-
function hasCommittedMessagingToolDeliveryEvidence(result) {
|
|
371
|
-
return hasNonEmptyStringArray(result.messagingToolSentTexts) || hasNonEmptyStringArray(result.messagingToolSentMediaUrls) || hasNonEmptyArray(result.messagingToolSentTargets);
|
|
372
|
-
}
|
|
373
|
-
function hasOutboundDeliveryEvidence(result) {
|
|
374
|
-
return hasMessagingToolDeliveryEvidence(result) || Array.isArray(result.acceptedSessionSpawns) && hasAcceptedSessionSpawn(result.acceptedSessionSpawns) || hasPositiveNumber(result.successfulCronAdds) || hasPositiveNumber(result.meta?.toolSummary?.calls);
|
|
375
|
-
}
|
|
376
|
-
function getAgentCommandDeliveryFailure(result) {
|
|
377
|
-
const status = result.deliveryStatus?.status;
|
|
378
|
-
if (status !== "failed" && status !== "partial_failed") return;
|
|
379
|
-
const message = result.deliveryStatus?.errorMessage;
|
|
380
|
-
if (hasNonEmptyString(message)) return message;
|
|
381
|
-
return status === "partial_failed" ? "agent delivery partially failed" : "agent delivery failed";
|
|
382
|
-
}
|
|
383
|
-
//#endregion
|
|
384
|
-
//#region src/infra/outbound/bound-delivery-router.ts
|
|
385
|
-
function isActiveBinding(record) {
|
|
386
|
-
return record.status === "active";
|
|
387
|
-
}
|
|
388
|
-
function resolveBindingForRequester(requester, bindings) {
|
|
389
|
-
const matchingChannelAccount = bindings.filter((entry) => {
|
|
390
|
-
const conversation = normalizeConversationRef(entry.conversation);
|
|
391
|
-
return conversation.channel === requester.channel && conversation.accountId === requester.accountId;
|
|
392
|
-
});
|
|
393
|
-
if (matchingChannelAccount.length === 0) return null;
|
|
394
|
-
const exactConversation = matchingChannelAccount.find((entry) => normalizeConversationRef(entry.conversation).conversationId === requester.conversationId);
|
|
395
|
-
if (exactConversation) return exactConversation;
|
|
396
|
-
if (matchingChannelAccount.length === 1) return matchingChannelAccount[0] ?? null;
|
|
397
|
-
return null;
|
|
398
|
-
}
|
|
399
|
-
function createBoundDeliveryRouter(service = getSessionBindingService()) {
|
|
400
|
-
return { resolveDestination: (input) => {
|
|
401
|
-
const targetSessionKey = input.targetSessionKey.trim();
|
|
402
|
-
if (!targetSessionKey) return {
|
|
403
|
-
binding: null,
|
|
404
|
-
mode: "fallback",
|
|
405
|
-
reason: "missing-target-session"
|
|
406
|
-
};
|
|
407
|
-
const activeBindings = service.listBySession(targetSessionKey).filter(isActiveBinding);
|
|
408
|
-
if (activeBindings.length === 0) return {
|
|
409
|
-
binding: null,
|
|
410
|
-
mode: "fallback",
|
|
411
|
-
reason: "no-active-binding"
|
|
412
|
-
};
|
|
413
|
-
if (!input.requester) {
|
|
414
|
-
if (input.failClosed) return {
|
|
415
|
-
binding: null,
|
|
416
|
-
mode: "fallback",
|
|
417
|
-
reason: "missing-requester"
|
|
418
|
-
};
|
|
419
|
-
if (activeBindings.length === 1) return {
|
|
420
|
-
binding: activeBindings[0] ?? null,
|
|
421
|
-
mode: "bound",
|
|
422
|
-
reason: "single-active-binding"
|
|
423
|
-
};
|
|
424
|
-
return {
|
|
425
|
-
binding: null,
|
|
426
|
-
mode: "fallback",
|
|
427
|
-
reason: "ambiguous-without-requester"
|
|
428
|
-
};
|
|
429
|
-
}
|
|
430
|
-
const requester = normalizeConversationRef(input.requester);
|
|
431
|
-
if (!requester.channel || !requester.conversationId) return {
|
|
432
|
-
binding: null,
|
|
433
|
-
mode: "fallback",
|
|
434
|
-
reason: "invalid-requester"
|
|
435
|
-
};
|
|
436
|
-
const fromRequester = resolveBindingForRequester(requester, activeBindings);
|
|
437
|
-
if (fromRequester) return {
|
|
438
|
-
binding: fromRequester,
|
|
439
|
-
mode: "bound",
|
|
440
|
-
reason: "requester-match"
|
|
441
|
-
};
|
|
442
|
-
if (activeBindings.length === 1 && !input.failClosed) return {
|
|
443
|
-
binding: activeBindings[0] ?? null,
|
|
444
|
-
mode: "bound",
|
|
445
|
-
reason: "single-active-binding-fallback"
|
|
446
|
-
};
|
|
447
|
-
return {
|
|
448
|
-
binding: null,
|
|
449
|
-
mode: "fallback",
|
|
450
|
-
reason: "no-requester-match"
|
|
451
|
-
};
|
|
452
|
-
} };
|
|
453
|
-
}
|
|
454
|
-
//#endregion
|
|
455
|
-
//#region src/agents/subagent-announce-dispatch.ts
|
|
456
|
-
function mapSteerOutcomeToDeliveryResult(outcome) {
|
|
457
|
-
if (outcome.status === "steered") return {
|
|
458
|
-
delivered: true,
|
|
459
|
-
path: "steered",
|
|
460
|
-
deliveredAt: outcome.deliveredAt,
|
|
461
|
-
enqueuedAt: outcome.enqueuedAt
|
|
462
|
-
};
|
|
463
|
-
return {
|
|
464
|
-
delivered: false,
|
|
465
|
-
path: "none"
|
|
466
|
-
};
|
|
467
|
-
}
|
|
468
|
-
async function runSubagentAnnounceDispatch(params) {
|
|
469
|
-
const phases = [];
|
|
470
|
-
const appendPhase = (phase, result) => {
|
|
471
|
-
phases.push({
|
|
472
|
-
phase,
|
|
473
|
-
delivered: result.delivered,
|
|
474
|
-
path: result.path,
|
|
475
|
-
deliveredAt: result.deliveredAt,
|
|
476
|
-
enqueuedAt: result.enqueuedAt,
|
|
477
|
-
...result.reason ? { reason: result.reason } : {},
|
|
478
|
-
error: result.error
|
|
479
|
-
});
|
|
480
|
-
};
|
|
481
|
-
const withPhases = (result) => ({
|
|
482
|
-
...result,
|
|
483
|
-
phases
|
|
484
|
-
});
|
|
485
|
-
if (params.signal?.aborted) return withPhases({
|
|
486
|
-
delivered: false,
|
|
487
|
-
path: "none"
|
|
488
|
-
});
|
|
489
|
-
if (!params.expectsCompletionMessage) {
|
|
490
|
-
const primarySteerOutcome = await params.steer();
|
|
491
|
-
const primarySteer = mapSteerOutcomeToDeliveryResult(primarySteerOutcome);
|
|
492
|
-
appendPhase("steer-primary", primarySteer);
|
|
493
|
-
if (primarySteer.delivered) return withPhases(primarySteer);
|
|
494
|
-
if (primarySteerOutcome.status === "dropped") return withPhases(primarySteer);
|
|
495
|
-
const primaryDirect = await params.direct();
|
|
496
|
-
appendPhase("direct-primary", primaryDirect);
|
|
497
|
-
return withPhases(primaryDirect);
|
|
498
|
-
}
|
|
499
|
-
const primaryDirect = await params.direct();
|
|
500
|
-
appendPhase("direct-primary", primaryDirect);
|
|
501
|
-
if (primaryDirect.delivered || primaryDirect.terminal) return withPhases(primaryDirect);
|
|
502
|
-
if (params.signal?.aborted) return withPhases(primaryDirect);
|
|
503
|
-
const fallbackSteer = mapSteerOutcomeToDeliveryResult(await params.steer());
|
|
504
|
-
appendPhase("steer-fallback", fallbackSteer);
|
|
505
|
-
if (fallbackSteer.delivered) return withPhases(fallbackSteer);
|
|
506
|
-
return withPhases(primaryDirect);
|
|
507
|
-
}
|
|
508
|
-
//#endregion
|
|
509
|
-
//#region src/agents/subagent-requester-store-key.ts
|
|
510
|
-
function resolveRequesterStoreKey(cfg, requesterSessionKey) {
|
|
511
|
-
const raw = (requesterSessionKey ?? "").trim();
|
|
512
|
-
if (!raw) return raw;
|
|
513
|
-
if (raw === "global" || raw === "unknown") return raw;
|
|
514
|
-
if (raw.startsWith("agent:")) return raw;
|
|
515
|
-
const mainKey = normalizeMainKey(cfg?.session?.mainKey);
|
|
516
|
-
if (raw === "main" || raw === mainKey) return resolveMainSessionKey(cfg);
|
|
517
|
-
return `agent:${resolveAgentIdFromSessionKey(raw)}:${raw}`;
|
|
518
|
-
}
|
|
519
|
-
//#endregion
|
|
520
|
-
//#region src/agents/subagent-announce-delivery.ts
|
|
521
|
-
const DEFAULT_SUBAGENT_ANNOUNCE_TIMEOUT_MS = 12e4;
|
|
522
|
-
let subagentAnnounceDeliveryDeps = {
|
|
523
|
-
dispatchGatewayMethodInProcess,
|
|
524
|
-
getRuntimeConfig,
|
|
525
|
-
getRequesterSessionActivity: (requesterSessionKey) => {
|
|
526
|
-
const sessionId = resolveActiveEmbeddedRunSessionId(requesterSessionKey) ?? loadRequesterSessionEntry(requesterSessionKey).entry?.sessionId;
|
|
527
|
-
return {
|
|
528
|
-
sessionId,
|
|
529
|
-
isActive: Boolean(sessionId && isEmbeddedAgentRunActive(sessionId))
|
|
530
|
-
};
|
|
531
|
-
},
|
|
532
|
-
isRequesterSessionAbandoned: (requesterSessionKey, sessionId) => isEmbeddedRunAbandoned({
|
|
533
|
-
sessionKey: requesterSessionKey,
|
|
534
|
-
sessionId
|
|
535
|
-
}),
|
|
536
|
-
queueEmbeddedAgentMessageWithOutcome: queueEmbeddedAgentMessageWithOutcomeAsync,
|
|
537
|
-
sendMessage
|
|
538
|
-
};
|
|
539
|
-
async function resolveQueueEmbeddedAgentMessageOutcome(sessionId, text, options) {
|
|
540
|
-
return await subagentAnnounceDeliveryDeps.queueEmbeddedAgentMessageWithOutcome(sessionId, text, options);
|
|
541
|
-
}
|
|
542
|
-
async function runAnnounceAgentCall(params) {
|
|
543
|
-
return await subagentAnnounceDeliveryDeps.dispatchGatewayMethodInProcess("agent", params.agentParams, {
|
|
544
|
-
expectFinal: params.expectFinal,
|
|
545
|
-
forceSyntheticClient: shouldPreserveUserFacingSessionStateForInputProvenance(params.agentParams.inputProvenance),
|
|
546
|
-
timeoutMs: params.timeoutMs
|
|
547
|
-
});
|
|
548
|
-
}
|
|
549
|
-
function formatQueueWakeFailureError(fallback, outcome) {
|
|
550
|
-
const summary = formatEmbeddedAgentQueueFailureSummary(outcome);
|
|
551
|
-
return summary ? `${fallback}: ${summary}` : fallback;
|
|
552
|
-
}
|
|
553
|
-
function resolveBoundConversationOrigin(params) {
|
|
554
|
-
const conversation = params.bindingConversation;
|
|
555
|
-
const conversationId = conversation.conversationId?.trim() ?? "";
|
|
556
|
-
const parentConversationId = conversation.parentConversationId?.trim() ?? "";
|
|
557
|
-
const requesterConversationId = params.requesterConversation?.conversationId?.trim() ?? "";
|
|
558
|
-
const requesterTo = params.requesterOrigin?.to?.trim();
|
|
559
|
-
if (conversation.channel === "matrix" && parentConversationId && requesterConversationId && parentConversationId === requesterConversationId && requesterTo) return {
|
|
560
|
-
channel: conversation.channel,
|
|
561
|
-
accountId: conversation.accountId,
|
|
562
|
-
to: requesterTo,
|
|
563
|
-
...conversationId ? { threadId: conversationId } : {}
|
|
564
|
-
};
|
|
565
|
-
const boundTarget = routeToDeliveryFields(routeFromConversationRef(conversation));
|
|
566
|
-
const inferredThreadId = boundTarget.threadId ?? (parentConversationId && parentConversationId !== conversationId ? conversationId : void 0) ?? (params.requesterOrigin?.threadId != null && params.requesterOrigin.threadId !== "" ? stringifyRouteThreadId(params.requesterOrigin.threadId) : void 0);
|
|
567
|
-
if (requesterTo && conversationId && requesterConversationId && conversationId.toLowerCase() === requesterConversationId.toLowerCase()) return {
|
|
568
|
-
channel: conversation.channel,
|
|
569
|
-
accountId: conversation.accountId,
|
|
570
|
-
to: requesterTo,
|
|
571
|
-
threadId: inferredThreadId
|
|
572
|
-
};
|
|
573
|
-
return {
|
|
574
|
-
channel: conversation.channel,
|
|
575
|
-
accountId: conversation.accountId,
|
|
576
|
-
to: boundTarget.to,
|
|
577
|
-
threadId: inferredThreadId
|
|
578
|
-
};
|
|
579
|
-
}
|
|
580
|
-
function resolveRequesterSessionActivity(requesterSessionKey) {
|
|
581
|
-
const activity = subagentAnnounceDeliveryDeps.getRequesterSessionActivity(requesterSessionKey);
|
|
582
|
-
if (activity.sessionId || activity.isActive) return activity;
|
|
583
|
-
const { entry } = loadRequesterSessionEntry(requesterSessionKey);
|
|
584
|
-
const sessionId = entry?.sessionId;
|
|
585
|
-
return {
|
|
586
|
-
sessionId,
|
|
587
|
-
isActive: Boolean(sessionId && isEmbeddedAgentRunActive(sessionId))
|
|
588
|
-
};
|
|
589
|
-
}
|
|
590
|
-
function resolveDirectAnnounceTransientRetryDelaysMs() {
|
|
591
|
-
return process.env.FENGMING_TEST_FAST === "1" ? [
|
|
592
|
-
8,
|
|
593
|
-
16,
|
|
594
|
-
32
|
|
595
|
-
] : [
|
|
596
|
-
5e3,
|
|
597
|
-
1e4,
|
|
598
|
-
2e4
|
|
599
|
-
];
|
|
600
|
-
}
|
|
601
|
-
function resolveCompactionSteerRetryDelaysMs() {
|
|
602
|
-
return process.env.FENGMING_TEST_FAST === "1" ? [
|
|
603
|
-
8,
|
|
604
|
-
16,
|
|
605
|
-
32,
|
|
606
|
-
64
|
|
607
|
-
] : [
|
|
608
|
-
1e3,
|
|
609
|
-
2e3,
|
|
610
|
-
4e3,
|
|
611
|
-
8e3
|
|
612
|
-
];
|
|
613
|
-
}
|
|
614
|
-
async function resolveActiveWakeWithRetries(sessionId, message, wakeOptions, signal) {
|
|
615
|
-
const compactionDeadlineMs = typeof wakeOptions.deliveryTimeoutMs === "number" && wakeOptions.deliveryTimeoutMs > 0 ? Date.now() + wakeOptions.deliveryTimeoutMs : void 0;
|
|
616
|
-
let currentOptions = wakeOptions;
|
|
617
|
-
const resolveRetryOptions = () => {
|
|
618
|
-
if (compactionDeadlineMs === void 0) return currentOptions;
|
|
619
|
-
const remainingDeliveryTimeoutMs = compactionDeadlineMs - Date.now();
|
|
620
|
-
if (remainingDeliveryTimeoutMs <= 0) return;
|
|
621
|
-
return {
|
|
622
|
-
...currentOptions,
|
|
623
|
-
deliveryTimeoutMs: remainingDeliveryTimeoutMs
|
|
624
|
-
};
|
|
625
|
-
};
|
|
626
|
-
let outcome = await resolveQueueEmbeddedAgentMessageOutcome(sessionId, message, currentOptions);
|
|
627
|
-
const compactionRetryDelaysMs = resolveCompactionSteerRetryDelaysMs();
|
|
628
|
-
let compactionRetryIndex = 0;
|
|
629
|
-
for (;;) {
|
|
630
|
-
if (outcome.queued || signal?.aborted) break;
|
|
631
|
-
if (outcome.reason === "transcript_commit_wait_unsupported" && currentOptions.waitForTranscriptCommit === true) {
|
|
632
|
-
const bestEffortOptions = { ...currentOptions };
|
|
633
|
-
delete bestEffortOptions.waitForTranscriptCommit;
|
|
634
|
-
currentOptions = bestEffortOptions;
|
|
635
|
-
outcome = await resolveQueueEmbeddedAgentMessageOutcome(sessionId, message, currentOptions);
|
|
636
|
-
continue;
|
|
637
|
-
}
|
|
638
|
-
if (outcome.reason === "compacting") {
|
|
639
|
-
const remainingDeliveryTimeoutMs = compactionDeadlineMs === void 0 ? void 0 : compactionDeadlineMs - Date.now();
|
|
640
|
-
if (!(remainingDeliveryTimeoutMs === void 0 ? compactionRetryIndex < compactionRetryDelaysMs.length : remainingDeliveryTimeoutMs > 0)) break;
|
|
641
|
-
const scheduledDelayMs = compactionRetryDelaysMs[Math.min(compactionRetryIndex, compactionRetryDelaysMs.length - 1)] ?? 0;
|
|
642
|
-
const delayMs = remainingDeliveryTimeoutMs === void 0 ? scheduledDelayMs : Math.min(scheduledDelayMs, remainingDeliveryTimeoutMs);
|
|
643
|
-
if (delayMs <= 0 && remainingDeliveryTimeoutMs !== void 0) break;
|
|
644
|
-
await waitForAnnounceRetryDelay(delayMs, signal);
|
|
645
|
-
if (signal?.aborted) break;
|
|
646
|
-
compactionRetryIndex += 1;
|
|
647
|
-
const retryOptions = resolveRetryOptions();
|
|
648
|
-
if (!retryOptions) break;
|
|
649
|
-
outcome = await resolveQueueEmbeddedAgentMessageOutcome(sessionId, message, retryOptions);
|
|
650
|
-
continue;
|
|
651
|
-
}
|
|
652
|
-
break;
|
|
653
|
-
}
|
|
654
|
-
return outcome;
|
|
655
|
-
}
|
|
656
|
-
function resolveSubagentAnnounceTimeoutMs(cfg) {
|
|
657
|
-
const configured = cfg.agents?.defaults?.subagents?.announceTimeoutMs;
|
|
658
|
-
return clampTimerTimeoutMs(configured) ?? DEFAULT_SUBAGENT_ANNOUNCE_TIMEOUT_MS;
|
|
659
|
-
}
|
|
660
|
-
function isInternalAnnounceRequesterSession(sessionKey) {
|
|
661
|
-
return getSubagentDepthFromSessionStore(sessionKey) >= 1 || isCronSessionKey(sessionKey);
|
|
662
|
-
}
|
|
663
|
-
function summarizeDeliveryError(error) {
|
|
664
|
-
if (error instanceof Error) return error.message || "error";
|
|
665
|
-
if (typeof error === "string") return error;
|
|
666
|
-
if (error === void 0 || error === null) return "unknown error";
|
|
667
|
-
try {
|
|
668
|
-
return JSON.stringify(error);
|
|
669
|
-
} catch {
|
|
670
|
-
return "error";
|
|
671
|
-
}
|
|
672
|
-
}
|
|
673
|
-
const TRANSIENT_ANNOUNCE_DELIVERY_ERROR_PATTERNS = [
|
|
674
|
-
/\berrorcode=unavailable\b/i,
|
|
675
|
-
/\bstatus\s*[:=]\s*"?unavailable\b/i,
|
|
676
|
-
/\bUNAVAILABLE\b/,
|
|
677
|
-
/no active .* listener/i,
|
|
678
|
-
/gateway not connected/i,
|
|
679
|
-
/gateway closed \(1006/i,
|
|
680
|
-
/gateway timeout/i,
|
|
681
|
-
/\ball models failed\b/i,
|
|
682
|
-
/\ball profiles unavailable\b/i,
|
|
683
|
-
/\boverloaded\b/i,
|
|
684
|
-
/\b(econnreset|econnrefused|etimedout|enotfound|ehostunreach|network error)\b/i
|
|
685
|
-
];
|
|
686
|
-
const PERMANENT_ANNOUNCE_DELIVERY_ERROR_PATTERNS = [
|
|
687
|
-
/unsupported channel/i,
|
|
688
|
-
/unknown channel/i,
|
|
689
|
-
/chat not found/i,
|
|
690
|
-
/user not found/i,
|
|
691
|
-
/bot.*not.*member/i,
|
|
692
|
-
/bot was blocked by the user/i,
|
|
693
|
-
/forbidden: bot was kicked/i,
|
|
694
|
-
/recipient is not a valid/i,
|
|
695
|
-
/outbound not configured for channel/i
|
|
696
|
-
];
|
|
697
|
-
function isTransientAnnounceDeliveryError(error) {
|
|
698
|
-
const message = summarizeDeliveryError(error);
|
|
699
|
-
if (!message) return false;
|
|
700
|
-
if (PERMANENT_ANNOUNCE_DELIVERY_ERROR_PATTERNS.some((re) => re.test(message))) return false;
|
|
701
|
-
return TRANSIENT_ANNOUNCE_DELIVERY_ERROR_PATTERNS.some((re) => re.test(message));
|
|
702
|
-
}
|
|
703
|
-
function isPermanentAnnounceDeliveryError(error) {
|
|
704
|
-
const message = summarizeDeliveryError(error);
|
|
705
|
-
return Boolean(message && PERMANENT_ANNOUNCE_DELIVERY_ERROR_PATTERNS.some((re) => re.test(message)));
|
|
706
|
-
}
|
|
707
|
-
function isIncompleteAnnounceAgentResultError(error) {
|
|
708
|
-
const message = summarizeDeliveryError(error);
|
|
709
|
-
return /(?:incomplete terminal response|code=incomplete_result)\b/i.test(message);
|
|
710
|
-
}
|
|
711
|
-
function isSessionWriteLockAnnounceAgentError(error) {
|
|
712
|
-
if (isSessionWriteLockTimeoutError(error)) return true;
|
|
713
|
-
const message = summarizeDeliveryError(error);
|
|
714
|
-
return /\bSessionWriteLockTimeoutError\b/.test(message) || /\bsession file locked\b/i.test(message);
|
|
715
|
-
}
|
|
716
|
-
function didVisibleSendFailAfterPartialDelivery(error) {
|
|
717
|
-
if (isOutboundDeliveryError(error) && error.sentBeforeError) return true;
|
|
718
|
-
const maybeDeliveryError = error;
|
|
719
|
-
return maybeDeliveryError.sentBeforeError === true || maybeDeliveryError.visibleReplySent === true;
|
|
720
|
-
}
|
|
721
|
-
async function waitForAnnounceRetryDelay(ms, signal) {
|
|
722
|
-
if (ms <= 0) return;
|
|
723
|
-
if (!signal) {
|
|
724
|
-
await new Promise((resolve) => setTimeout(resolve, ms));
|
|
725
|
-
return;
|
|
726
|
-
}
|
|
727
|
-
if (signal.aborted) return;
|
|
728
|
-
await new Promise((resolve) => {
|
|
729
|
-
const timer = setTimeout(() => {
|
|
730
|
-
signal.removeEventListener("abort", onAbort);
|
|
731
|
-
resolve();
|
|
732
|
-
}, ms);
|
|
733
|
-
const onAbort = () => {
|
|
734
|
-
clearTimeout(timer);
|
|
735
|
-
signal.removeEventListener("abort", onAbort);
|
|
736
|
-
resolve();
|
|
737
|
-
};
|
|
738
|
-
signal.addEventListener("abort", onAbort, { once: true });
|
|
739
|
-
});
|
|
740
|
-
}
|
|
741
|
-
async function runAnnounceDeliveryWithRetry(params) {
|
|
742
|
-
const retryDelaysMs = resolveDirectAnnounceTransientRetryDelaysMs();
|
|
743
|
-
let retryIndex = 0;
|
|
744
|
-
for (;;) {
|
|
745
|
-
if (params.signal?.aborted) throw new Error("announce delivery aborted");
|
|
746
|
-
try {
|
|
747
|
-
return await params.run();
|
|
748
|
-
} catch (err) {
|
|
749
|
-
const delayMs = retryDelaysMs[retryIndex];
|
|
750
|
-
if (delayMs == null || !isTransientAnnounceDeliveryError(err) || params.signal?.aborted) throw err;
|
|
751
|
-
const nextAttempt = retryIndex + 2;
|
|
752
|
-
const maxAttempts = retryDelaysMs.length + 1;
|
|
753
|
-
defaultRuntime.log(`[warn] Subagent announce ${params.operation} transient failure, retrying ${nextAttempt}/${maxAttempts} in ${Math.round(delayMs / 1e3)}s: ${summarizeDeliveryError(err)}`);
|
|
754
|
-
retryIndex += 1;
|
|
755
|
-
await waitForAnnounceRetryDelay(delayMs, params.signal);
|
|
756
|
-
}
|
|
757
|
-
}
|
|
758
|
-
}
|
|
759
|
-
async function resolveSubagentCompletionOrigin(params) {
|
|
760
|
-
const requesterOrigin = normalizeDeliveryContext(params.requesterOrigin);
|
|
761
|
-
const channel = normalizeOptionalLowercaseString(requesterOrigin?.channel);
|
|
762
|
-
const to = requesterOrigin?.to?.trim();
|
|
763
|
-
const accountId = normalizeAccountId(requesterOrigin?.accountId);
|
|
764
|
-
const conversationId = stringifyRouteThreadId(requesterOrigin?.threadId != null && requesterOrigin.threadId !== "" ? requesterOrigin.threadId : void 0) || resolveConversationIdFromTargets({ targets: [to] }) || "";
|
|
765
|
-
const requesterConversation = channel && conversationId ? {
|
|
766
|
-
channel,
|
|
767
|
-
accountId,
|
|
768
|
-
conversationId
|
|
769
|
-
} : void 0;
|
|
770
|
-
const router = createBoundDeliveryRouter();
|
|
771
|
-
const requesterRoute = router.resolveDestination({
|
|
772
|
-
eventKind: "task_completion",
|
|
773
|
-
targetSessionKey: params.requesterSessionKey,
|
|
774
|
-
requester: requesterConversation,
|
|
775
|
-
failClosed: true
|
|
776
|
-
});
|
|
777
|
-
if (requesterRoute.mode === "bound" && requesterRoute.binding) return mergeDeliveryContext(resolveBoundConversationOrigin({
|
|
778
|
-
bindingConversation: requesterRoute.binding.conversation,
|
|
779
|
-
requesterConversation,
|
|
780
|
-
requesterOrigin
|
|
781
|
-
}), requesterOrigin);
|
|
782
|
-
const childRoute = router.resolveDestination({
|
|
783
|
-
eventKind: "task_completion",
|
|
784
|
-
targetSessionKey: params.childSessionKey,
|
|
785
|
-
requester: requesterConversation,
|
|
786
|
-
failClosed: true
|
|
787
|
-
});
|
|
788
|
-
if (childRoute.mode === "bound" && childRoute.binding) return mergeDeliveryContext(resolveBoundConversationOrigin({
|
|
789
|
-
bindingConversation: childRoute.binding.conversation,
|
|
790
|
-
requesterConversation,
|
|
791
|
-
requesterOrigin
|
|
792
|
-
}), requesterOrigin);
|
|
793
|
-
const hookRunner = getGlobalHookRunner();
|
|
794
|
-
if (!hookRunner?.hasHooks("subagent_delivery_target")) return requesterOrigin;
|
|
795
|
-
try {
|
|
796
|
-
const hookOrigin = normalizeDeliveryContext((await hookRunner.runSubagentDeliveryTarget({
|
|
797
|
-
childSessionKey: params.childSessionKey,
|
|
798
|
-
requesterSessionKey: params.requesterSessionKey,
|
|
799
|
-
requesterOrigin,
|
|
800
|
-
childRunId: params.childRunId,
|
|
801
|
-
spawnMode: params.spawnMode,
|
|
802
|
-
expectsCompletionMessage: params.expectsCompletionMessage
|
|
803
|
-
}, {
|
|
804
|
-
runId: params.childRunId,
|
|
805
|
-
childSessionKey: params.childSessionKey,
|
|
806
|
-
requesterSessionKey: params.requesterSessionKey
|
|
807
|
-
}))?.origin);
|
|
808
|
-
if (!hookOrigin) return requesterOrigin;
|
|
809
|
-
if (hookOrigin.channel && isInternalMessageChannel(hookOrigin.channel)) return requesterOrigin;
|
|
810
|
-
return mergeDeliveryContext(hookOrigin, requesterOrigin);
|
|
811
|
-
} catch {
|
|
812
|
-
return requesterOrigin;
|
|
813
|
-
}
|
|
814
|
-
}
|
|
815
|
-
function loadRequesterSessionEntry(requesterSessionKey) {
|
|
816
|
-
const cfg = subagentAnnounceDeliveryDeps.getRuntimeConfig();
|
|
817
|
-
const canonicalKey = resolveRequesterStoreKey(cfg, requesterSessionKey);
|
|
818
|
-
const agentId = resolveAgentIdFromSessionKey(canonicalKey);
|
|
819
|
-
return {
|
|
820
|
-
cfg,
|
|
821
|
-
entry: loadSessionStore(resolveStorePath(cfg.session?.store, { agentId }))[canonicalKey],
|
|
822
|
-
canonicalKey
|
|
823
|
-
};
|
|
824
|
-
}
|
|
825
|
-
function loadSessionEntryByKey(sessionKey) {
|
|
826
|
-
const cfg = subagentAnnounceDeliveryDeps.getRuntimeConfig();
|
|
827
|
-
const agentId = resolveAgentIdFromSessionKey(sessionKey);
|
|
828
|
-
return loadSessionStore(resolveStorePath(cfg.session?.store, { agentId }))[sessionKey];
|
|
829
|
-
}
|
|
830
|
-
async function maybeSteerSubagentAnnounce(params) {
|
|
831
|
-
if (params.signal?.aborted) return { status: "none" };
|
|
832
|
-
const { cfg, entry } = loadRequesterSessionEntry(params.requesterSessionKey);
|
|
833
|
-
const canonicalKey = resolveRequesterStoreKey(cfg, params.requesterSessionKey);
|
|
834
|
-
const { sessionId, isActive } = resolveRequesterSessionActivity(canonicalKey);
|
|
835
|
-
if (subagentAnnounceDeliveryDeps.isRequesterSessionAbandoned(canonicalKey, sessionId)) return { status: "none" };
|
|
836
|
-
if (!sessionId || !isActive) return { status: "none" };
|
|
837
|
-
const queueSettings = resolveQueueSettings({
|
|
838
|
-
cfg,
|
|
839
|
-
channel: entry?.channel ?? entry?.lastChannel ?? entry?.origin?.provider,
|
|
840
|
-
sessionEntry: entry
|
|
841
|
-
});
|
|
842
|
-
const queueOptions = {
|
|
843
|
-
deliveryTimeoutMs: params.deliveryTimeoutMs,
|
|
844
|
-
steeringMode: "all",
|
|
845
|
-
...queueSettings.debounceMs !== void 0 ? { debounceMs: queueSettings.debounceMs } : {},
|
|
846
|
-
waitForTranscriptCommit: true
|
|
847
|
-
};
|
|
848
|
-
const queueOutcome = await resolveActiveWakeWithRetries(sessionId, params.steerMessage, queueOptions, params.signal);
|
|
849
|
-
if (queueOutcome.queued) return {
|
|
850
|
-
status: "steered",
|
|
851
|
-
deliveredAt: queueOutcome.deliveredAtMs,
|
|
852
|
-
enqueuedAt: queueOutcome.enqueuedAtMs
|
|
853
|
-
};
|
|
854
|
-
return { status: resolveRequesterSessionActivity(canonicalKey).isActive ? "dropped" : "none" };
|
|
855
|
-
}
|
|
856
|
-
function hasVisibleGatewayAgentPayload(response) {
|
|
857
|
-
const result = getGatewayAgentResult(response);
|
|
858
|
-
return Boolean(result && (hasVisibleAgentPayload(result) || hasMessagingToolDeliveryEvidence(result)));
|
|
859
|
-
}
|
|
860
|
-
function hasGatewayAgentMessagingToolDeliveryEvidence(response) {
|
|
861
|
-
const result = getGatewayAgentResult(response);
|
|
862
|
-
return Boolean(result && hasMessagingToolDeliveryEvidence(result));
|
|
863
|
-
}
|
|
864
|
-
function hasIntentionalSilentGatewayAgentPayload(response) {
|
|
865
|
-
const result = getGatewayAgentResult(response);
|
|
866
|
-
if (!result || !Array.isArray(result.payloads)) return false;
|
|
867
|
-
return result.payloads.some((payload) => {
|
|
868
|
-
if (!payload || typeof payload !== "object" || Array.isArray(payload)) return false;
|
|
869
|
-
const record = payload;
|
|
870
|
-
if (typeof record.text !== "string" || !isSilentReplyPayloadText(record.text, "NO_REPLY")) return false;
|
|
871
|
-
return !(record.mediaUrl || Array.isArray(record.mediaUrls) && record.mediaUrls.length > 0 || record.presentation || record.interactive || record.channelData);
|
|
872
|
-
});
|
|
873
|
-
}
|
|
874
|
-
function requiresAgentMediatedCompletionDelivery(params) {
|
|
875
|
-
return params.expectsCompletionMessage && isAgentMediatedCompletionSourceTool(params.sourceTool);
|
|
876
|
-
}
|
|
877
|
-
function collectExpectedMediaFromInternalEvents(events) {
|
|
878
|
-
if (!events?.length) return [];
|
|
879
|
-
const mediaUrls = [];
|
|
880
|
-
const seen = /* @__PURE__ */ new Set();
|
|
881
|
-
for (const event of events) {
|
|
882
|
-
const values = [...Array.isArray(event.mediaUrls) ? event.mediaUrls : [], ...mediaUrlsFromGeneratedAttachments(event.attachments)];
|
|
883
|
-
for (const value of values) {
|
|
884
|
-
const normalized = typeof value === "string" ? value.trim() : "";
|
|
885
|
-
if (!normalized || seen.has(normalized)) continue;
|
|
886
|
-
seen.add(normalized);
|
|
887
|
-
mediaUrls.push(normalized);
|
|
888
|
-
}
|
|
889
|
-
}
|
|
890
|
-
return mediaUrls;
|
|
891
|
-
}
|
|
892
|
-
function getGatewayAgentCommandDeliveryFailure(response) {
|
|
893
|
-
const result = getGatewayAgentResult(response);
|
|
894
|
-
return result ? getAgentCommandDeliveryFailure(result) : void 0;
|
|
895
|
-
}
|
|
896
|
-
function isGatewayAgentRunPending(response) {
|
|
897
|
-
if (!response || typeof response !== "object") return false;
|
|
898
|
-
const status = response.status;
|
|
899
|
-
return isNonTerminalAgentRunStatus(status);
|
|
900
|
-
}
|
|
901
|
-
function resolveGeneratedMediaCompletionLabel(params) {
|
|
902
|
-
const sourceTool = params.sourceTool?.trim();
|
|
903
|
-
if (sourceTool === "image_generate") return "image";
|
|
904
|
-
if (sourceTool === "music_generate") return "music";
|
|
905
|
-
if (sourceTool === "video_generate") return "video";
|
|
906
|
-
const announceType = params.internalEvents?.find((event) => event.type === "task_completion")?.announceType?.trim().toLowerCase();
|
|
907
|
-
if (announceType?.includes("image")) return "image";
|
|
908
|
-
if (announceType?.includes("music") || announceType?.includes("audio")) return "music";
|
|
909
|
-
if (announceType?.includes("video")) return "video";
|
|
910
|
-
return "media";
|
|
911
|
-
}
|
|
912
|
-
async function deliverGeneratedMediaCompletionDirect(params) {
|
|
913
|
-
if (!params.deliveryTarget.deliver || !params.deliveryTarget.channel || !params.deliveryTarget.to || params.mediaUrls.length === 0) return;
|
|
914
|
-
const mediaLabel = resolveGeneratedMediaCompletionLabel({
|
|
915
|
-
sourceTool: params.sourceTool,
|
|
916
|
-
internalEvents: params.internalEvents
|
|
917
|
-
});
|
|
918
|
-
const agentId = resolveAgentIdFromSessionKey(params.requesterSessionKey);
|
|
919
|
-
const idempotencyKey = `${params.directIdempotencyKey}:generated-media-direct`;
|
|
920
|
-
try {
|
|
921
|
-
await subagentAnnounceDeliveryDeps.sendMessage({
|
|
922
|
-
cfg: params.cfg,
|
|
923
|
-
channel: params.deliveryTarget.channel,
|
|
924
|
-
to: params.deliveryTarget.to,
|
|
925
|
-
accountId: params.deliveryTarget.accountId,
|
|
926
|
-
threadId: params.deliveryTarget.threadId,
|
|
927
|
-
requesterSessionKey: params.requesterSessionKey,
|
|
928
|
-
agentId,
|
|
929
|
-
content: `The generated ${mediaLabel} is ready.`,
|
|
930
|
-
mediaUrls: Array.from(params.mediaUrls),
|
|
931
|
-
idempotencyKey,
|
|
932
|
-
mirror: {
|
|
933
|
-
sessionKey: params.requesterSessionKey,
|
|
934
|
-
agentId,
|
|
935
|
-
idempotencyKey
|
|
936
|
-
}
|
|
937
|
-
});
|
|
938
|
-
return {
|
|
939
|
-
delivered: true,
|
|
940
|
-
path: "direct"
|
|
941
|
-
};
|
|
942
|
-
} catch (err) {
|
|
943
|
-
const terminal = didVisibleSendFailAfterPartialDelivery(err);
|
|
944
|
-
return {
|
|
945
|
-
delivered: false,
|
|
946
|
-
path: "direct",
|
|
947
|
-
error: `generated media direct delivery failed: ${summarizeDeliveryError(err)}`,
|
|
948
|
-
...terminal ? { terminal: true } : {}
|
|
949
|
-
};
|
|
950
|
-
}
|
|
951
|
-
}
|
|
952
|
-
function inferDeliveryTargetChatType(target) {
|
|
953
|
-
const normalizedTo = normalizeOptionalLowercaseString(target.to);
|
|
954
|
-
if (!normalizedTo) return;
|
|
955
|
-
if (normalizedTo.startsWith("dm:") || normalizedTo.startsWith("direct:") || normalizedTo.startsWith("user:") || normalizedTo.includes(":dm:") || normalizedTo.includes(":direct:")) return "direct";
|
|
956
|
-
if (normalizedTo.startsWith("channel:") || normalizedTo.startsWith("thread:")) return "channel";
|
|
957
|
-
if (normalizedTo.startsWith("group:")) return "group";
|
|
958
|
-
const channel = normalizeMessageChannel(target.channel);
|
|
959
|
-
return channel ? getLoadedChannelPluginForRead(channel)?.messaging?.inferTargetChatType?.({ to: target.to ?? "" }) : void 0;
|
|
960
|
-
}
|
|
961
|
-
function isDirectMessageDeliveryTarget(target, requesterSessionKey) {
|
|
962
|
-
if (target.threadId) return false;
|
|
963
|
-
const targetChatType = inferDeliveryTargetChatType(target);
|
|
964
|
-
if (targetChatType) return targetChatType === "direct";
|
|
965
|
-
return deriveSessionChatTypeFromKey(requesterSessionKey) === "direct";
|
|
966
|
-
}
|
|
967
|
-
function resolveTextCompletionDirectFallback(events) {
|
|
968
|
-
for (let index = (events?.length ?? 0) - 1; index >= 0; index -= 1) {
|
|
969
|
-
const event = events?.[index];
|
|
970
|
-
if (event?.type !== "task_completion" || event.source !== "subagent") continue;
|
|
971
|
-
if (event.status !== "ok") continue;
|
|
972
|
-
const result = typeof event.result === "string" ? event.result.trim() : "";
|
|
973
|
-
if (result && result !== "(no output)") return result;
|
|
974
|
-
}
|
|
975
|
-
}
|
|
976
|
-
function hasFailedSubagentNoOutputCompletion(events) {
|
|
977
|
-
return events?.some((event) => event.type === "task_completion" && event.source === "subagent" && event.status !== "ok" && event.result.trim() === "(no output)") === true;
|
|
978
|
-
}
|
|
979
|
-
async function deliverTextCompletionDirect(params) {
|
|
980
|
-
const content = resolveTextCompletionDirectFallback(params.internalEvents);
|
|
981
|
-
if (!content || !params.deliveryTarget.deliver || !params.deliveryTarget.channel || !params.deliveryTarget.to || !isDirectMessageDeliveryTarget(params.deliveryTarget, params.requesterSessionKey)) return;
|
|
982
|
-
const agentId = resolveAgentIdFromSessionKey(params.requesterSessionKey);
|
|
983
|
-
const idempotencyKey = `${params.directIdempotencyKey}:text-direct`;
|
|
984
|
-
try {
|
|
985
|
-
await subagentAnnounceDeliveryDeps.sendMessage({
|
|
986
|
-
cfg: params.cfg,
|
|
987
|
-
channel: params.deliveryTarget.channel,
|
|
988
|
-
to: params.deliveryTarget.to,
|
|
989
|
-
accountId: params.deliveryTarget.accountId,
|
|
990
|
-
threadId: params.deliveryTarget.threadId,
|
|
991
|
-
requesterSessionKey: params.requesterSessionKey,
|
|
992
|
-
agentId,
|
|
993
|
-
content,
|
|
994
|
-
idempotencyKey,
|
|
995
|
-
mirror: {
|
|
996
|
-
sessionKey: params.requesterSessionKey,
|
|
997
|
-
agentId,
|
|
998
|
-
idempotencyKey
|
|
999
|
-
}
|
|
1000
|
-
});
|
|
1001
|
-
return {
|
|
1002
|
-
delivered: true,
|
|
1003
|
-
path: "direct"
|
|
1004
|
-
};
|
|
1005
|
-
} catch (err) {
|
|
1006
|
-
return {
|
|
1007
|
-
delivered: false,
|
|
1008
|
-
path: "direct",
|
|
1009
|
-
error: `text completion direct delivery failed: ${summarizeDeliveryError(err)}`
|
|
1010
|
-
};
|
|
1011
|
-
}
|
|
1012
|
-
}
|
|
1013
|
-
function resolveGeneratedMediaDirectFallbackUrls(params) {
|
|
1014
|
-
const expected = uniqueStrings(normalizeStringEntries(params.expectedMediaUrls));
|
|
1015
|
-
const result = getGatewayAgentResult(params.announceResponse);
|
|
1016
|
-
if (!result) return expected;
|
|
1017
|
-
const delivered = new Set(params.requiresMessageToolDelivery ? collectMessagingToolDeliveredMediaUrlsForTarget(result, params.deliveryTarget) : collectAutomaticCompletionDeliveredMediaUrls({
|
|
1018
|
-
result,
|
|
1019
|
-
deliveryTarget: params.deliveryTarget,
|
|
1020
|
-
automaticDeliveryRequested: params.automaticDeliveryRequested,
|
|
1021
|
-
automaticDeliveryFailed: params.automaticDeliveryFailed === true
|
|
1022
|
-
}));
|
|
1023
|
-
return expected.filter((url) => !delivered.has(url));
|
|
1024
|
-
}
|
|
1025
|
-
function collectAutomaticCompletionDeliveredMediaUrls(params) {
|
|
1026
|
-
const urls = /* @__PURE__ */ new Set();
|
|
1027
|
-
const addUrls = (values) => {
|
|
1028
|
-
for (const value of values) if (value.trim()) urls.add(value);
|
|
1029
|
-
};
|
|
1030
|
-
if (params.automaticDeliveryRequested) {
|
|
1031
|
-
if (params.automaticDeliveryFailed) addUrls(collectPayloadOutcomeDeliveredMediaUrls(params.result, { countAmbiguousSinglePayloadFailure: true }));
|
|
1032
|
-
else if (hasPayloadDeliveryOutcomes(params.result)) addUrls(collectPayloadOutcomeDeliveredMediaUrls(params.result, { countAmbiguousSinglePayloadFailure: false }));
|
|
1033
|
-
else if (!hasSuppressedPayloadDeliveryStatus(params.result)) addUrls(collectPayloadMediaUrls(params.result));
|
|
1034
|
-
}
|
|
1035
|
-
addUrls(collectMessagingToolDeliveredMediaUrlsForTarget(params.result, params.deliveryTarget));
|
|
1036
|
-
return Array.from(urls);
|
|
1037
|
-
}
|
|
1038
|
-
function collectPayloadMediaUrls(result) {
|
|
1039
|
-
return collectDeliveredMediaUrls({ payloads: Array.isArray(result.payloads) ? result.payloads : [] });
|
|
1040
|
-
}
|
|
1041
|
-
function getPayloadDeliveryStatusRecord(result) {
|
|
1042
|
-
return result.deliveryStatus && typeof result.deliveryStatus === "object" ? result.deliveryStatus : void 0;
|
|
1043
|
-
}
|
|
1044
|
-
function hasPayloadDeliveryOutcomes(result) {
|
|
1045
|
-
return Array.isArray(getPayloadDeliveryStatusRecord(result)?.payloadOutcomes);
|
|
1046
|
-
}
|
|
1047
|
-
function hasSuppressedPayloadDeliveryStatus(result) {
|
|
1048
|
-
return normalizeOptionalLowercaseString(getPayloadDeliveryStatusRecord(result)?.status) === "suppressed";
|
|
1049
|
-
}
|
|
1050
|
-
function collectPayloadOutcomeDeliveredMediaUrls(result, options) {
|
|
1051
|
-
const payloads = Array.isArray(result.payloads) ? result.payloads : [];
|
|
1052
|
-
const deliveryStatus = getPayloadDeliveryStatusRecord(result);
|
|
1053
|
-
const payloadOutcomes = Array.isArray(deliveryStatus?.payloadOutcomes) ? deliveryStatus.payloadOutcomes : [];
|
|
1054
|
-
const urls = /* @__PURE__ */ new Set();
|
|
1055
|
-
for (const outcome of payloadOutcomes) {
|
|
1056
|
-
if (!outcome || typeof outcome !== "object" || Array.isArray(outcome)) continue;
|
|
1057
|
-
const record = outcome;
|
|
1058
|
-
const status = normalizeOptionalLowercaseString(record.status);
|
|
1059
|
-
const ambiguousSinglePayloadFailure = status === "failed" && record.sentBeforeError === true && options.countAmbiguousSinglePayloadFailure && payloadOutcomes.length === 1 && payloads.length === 1;
|
|
1060
|
-
if (status !== "sent" && !ambiguousSinglePayloadFailure) continue;
|
|
1061
|
-
const index = typeof record.index === "number" && Number.isInteger(record.index) ? record.index : void 0;
|
|
1062
|
-
const payload = index === void 0 ? void 0 : payloads[index];
|
|
1063
|
-
if (!payload) continue;
|
|
1064
|
-
for (const url of collectDeliveredMediaUrls({ payloads: [payload] })) urls.add(url);
|
|
1065
|
-
}
|
|
1066
|
-
return Array.from(urls);
|
|
1067
|
-
}
|
|
1068
|
-
function collectMessagingToolDeliveredMediaUrlsForTarget(result, deliveryTarget) {
|
|
1069
|
-
const targets = Array.isArray(result.messagingToolSentTargets) ? result.messagingToolSentTargets : [];
|
|
1070
|
-
const urls = /* @__PURE__ */ new Set();
|
|
1071
|
-
const targetedUrls = /* @__PURE__ */ new Set();
|
|
1072
|
-
for (const target of targets) {
|
|
1073
|
-
const targetMediaUrls = collectMessagingToolDeliveredMediaUrls({ messagingToolSentTargets: [target] });
|
|
1074
|
-
for (const url of targetMediaUrls) targetedUrls.add(url);
|
|
1075
|
-
if (!target || typeof target !== "object" || Array.isArray(target) || !sourceDeliveryTargetsMatch(target, deliveryTarget)) continue;
|
|
1076
|
-
for (const url of targetMediaUrls) urls.add(url);
|
|
1077
|
-
}
|
|
1078
|
-
for (const url of collectMessagingToolDeliveredMediaUrls({ messagingToolSentMediaUrls: result.messagingToolSentMediaUrls })) if (!targetedUrls.has(url)) urls.add(url);
|
|
1079
|
-
return Array.from(urls);
|
|
1080
|
-
}
|
|
1081
|
-
function stripNonDeliverableChannelForCompletionOrigin(context) {
|
|
1082
|
-
const normalized = normalizeDeliveryContext(context);
|
|
1083
|
-
if (!normalized?.channel) return normalized;
|
|
1084
|
-
const channel = normalizeMessageChannel(normalized.channel);
|
|
1085
|
-
if (!channel || isDeliverableMessageChannel(channel)) return normalized;
|
|
1086
|
-
const { channel: _channel, ...rest } = normalized;
|
|
1087
|
-
return normalizeDeliveryContext(rest);
|
|
1088
|
-
}
|
|
1089
|
-
async function sendSubagentAnnounceDirectly(params) {
|
|
1090
|
-
if (params.signal?.aborted) return {
|
|
1091
|
-
delivered: false,
|
|
1092
|
-
path: "none"
|
|
1093
|
-
};
|
|
1094
|
-
const cfg = subagentAnnounceDeliveryDeps.getRuntimeConfig();
|
|
1095
|
-
const announceTimeoutMs = resolveSubagentAnnounceTimeoutMs(cfg);
|
|
1096
|
-
const canonicalRequesterSessionKey = resolveRequesterStoreKey(cfg, params.targetRequesterSessionKey);
|
|
1097
|
-
try {
|
|
1098
|
-
const completionDirectOrigin = normalizeDeliveryContext(params.completionDirectOrigin);
|
|
1099
|
-
const directOrigin = normalizeDeliveryContext(params.directOrigin);
|
|
1100
|
-
const requesterSessionOrigin = normalizeDeliveryContext(params.requesterSessionOrigin);
|
|
1101
|
-
const externalCompletionDirectOrigin = stripNonDeliverableChannelForCompletionOrigin(completionDirectOrigin);
|
|
1102
|
-
const completionExternalFallbackOrigin = mergeDeliveryContext(directOrigin, requesterSessionOrigin);
|
|
1103
|
-
const effectiveDirectOrigin = params.expectsCompletionMessage ? mergeDeliveryContext(externalCompletionDirectOrigin, completionExternalFallbackOrigin) : directOrigin;
|
|
1104
|
-
const sessionOnlyOrigin = effectiveDirectOrigin?.channel ? effectiveDirectOrigin : requesterSessionOrigin;
|
|
1105
|
-
const requesterEntry = loadRequesterSessionEntry(params.targetRequesterSessionKey).entry;
|
|
1106
|
-
const deliveryTarget = !params.requesterIsSubagent ? resolveExternalBestEffortDeliveryTarget({
|
|
1107
|
-
channel: effectiveDirectOrigin?.channel,
|
|
1108
|
-
to: effectiveDirectOrigin?.to,
|
|
1109
|
-
accountId: effectiveDirectOrigin?.accountId,
|
|
1110
|
-
threadId: effectiveDirectOrigin?.threadId
|
|
1111
|
-
}) : { deliver: false };
|
|
1112
|
-
const normalizedSessionOnlyOriginChannel = !params.requesterIsSubagent ? normalizeMessageChannel(sessionOnlyOrigin?.channel) : void 0;
|
|
1113
|
-
const sessionOnlyOriginChannel = normalizedSessionOnlyOriginChannel && isGatewayMessageChannel(normalizedSessionOnlyOriginChannel) ? normalizedSessionOnlyOriginChannel : void 0;
|
|
1114
|
-
const sourceToolId = normalizeOptionalLowercaseString(params.sourceTool) ?? (params.expectsCompletionMessage ? "subagent_announce" : "");
|
|
1115
|
-
const isSubagentCompletion = sourceToolId === "subagent_announce";
|
|
1116
|
-
const agentMediatedCompletion = requiresAgentMediatedCompletionDelivery({
|
|
1117
|
-
expectsCompletionMessage: params.expectsCompletionMessage,
|
|
1118
|
-
sourceTool: sourceToolId
|
|
1119
|
-
});
|
|
1120
|
-
const expectedMediaUrls = collectExpectedMediaFromInternalEvents(params.internalEvents);
|
|
1121
|
-
const completionRouteRequiresMessageToolDelivery = params.expectsCompletionMessage && completionRequiresMessageToolDelivery({
|
|
1122
|
-
cfg,
|
|
1123
|
-
requesterSessionKey: params.requesterSessionKey,
|
|
1124
|
-
targetRequesterSessionKey: canonicalRequesterSessionKey,
|
|
1125
|
-
requesterEntry,
|
|
1126
|
-
directOrigin: effectiveDirectOrigin,
|
|
1127
|
-
requesterSessionOrigin
|
|
1128
|
-
});
|
|
1129
|
-
const subagentDirectMessageCompletionRequiresMessageTool = params.expectsCompletionMessage && isSubagentCompletion && deliveryTarget.deliver && isDirectMessageDeliveryTarget(deliveryTarget, canonicalRequesterSessionKey);
|
|
1130
|
-
const requiresMessageToolDelivery = completionRouteRequiresMessageToolDelivery || subagentDirectMessageCompletionRequiresMessageTool;
|
|
1131
|
-
const requesterActivity = resolveRequesterSessionActivity(canonicalRequesterSessionKey);
|
|
1132
|
-
if (params.expectsCompletionMessage && subagentAnnounceDeliveryDeps.isRequesterSessionAbandoned(canonicalRequesterSessionKey, requesterActivity.sessionId)) return {
|
|
1133
|
-
delivered: false,
|
|
1134
|
-
path: "none",
|
|
1135
|
-
reason: "requester_abandoned",
|
|
1136
|
-
error: "requester session abandoned after timeout"
|
|
1137
|
-
};
|
|
1138
|
-
let activeRequesterWakeFailed = false;
|
|
1139
|
-
const tryGeneratedMediaDirectDelivery = async (announceResponse, knownMissingMediaUrls) => {
|
|
1140
|
-
if (requesterActivity.isActive && !activeRequesterWakeFailed) return;
|
|
1141
|
-
const missingMediaUrls = knownMissingMediaUrls ?? resolveGeneratedMediaDirectFallbackUrls({
|
|
1142
|
-
expectedMediaUrls,
|
|
1143
|
-
announceResponse,
|
|
1144
|
-
requiresMessageToolDelivery,
|
|
1145
|
-
automaticDeliveryRequested: shouldDeliverAgentFinal,
|
|
1146
|
-
automaticDeliveryFailed: !requiresMessageToolDelivery && Boolean(getGatewayAgentCommandDeliveryFailure(announceResponse)),
|
|
1147
|
-
deliveryTarget
|
|
1148
|
-
});
|
|
1149
|
-
return await deliverGeneratedMediaCompletionDirect({
|
|
1150
|
-
cfg,
|
|
1151
|
-
requesterSessionKey: canonicalRequesterSessionKey,
|
|
1152
|
-
directIdempotencyKey: params.directIdempotencyKey,
|
|
1153
|
-
deliveryTarget,
|
|
1154
|
-
mediaUrls: missingMediaUrls,
|
|
1155
|
-
internalEvents: params.internalEvents,
|
|
1156
|
-
sourceTool: params.sourceTool
|
|
1157
|
-
});
|
|
1158
|
-
};
|
|
1159
|
-
const completionSourceReplyDeliveryMode = requiresMessageToolDelivery ? "message_tool_only" : void 0;
|
|
1160
|
-
const shouldDeliverAgentFinal = deliveryTarget.deliver && !requiresMessageToolDelivery;
|
|
1161
|
-
const requesterQueueSettings = resolveQueueSettings({
|
|
1162
|
-
cfg,
|
|
1163
|
-
channel: requesterEntry?.channel ?? requesterEntry?.lastChannel ?? requesterEntry?.origin?.provider ?? requesterSessionOrigin?.channel ?? directOrigin?.channel,
|
|
1164
|
-
sessionEntry: requesterEntry
|
|
1165
|
-
});
|
|
1166
|
-
if (params.expectsCompletionMessage && requesterActivity.sessionId && requesterActivity.isActive) {
|
|
1167
|
-
const wakeOptions = {
|
|
1168
|
-
deliveryTimeoutMs: announceTimeoutMs,
|
|
1169
|
-
steeringMode: "all",
|
|
1170
|
-
...completionSourceReplyDeliveryMode ? { sourceReplyDeliveryMode: completionSourceReplyDeliveryMode } : {},
|
|
1171
|
-
...requesterQueueSettings.debounceMs !== void 0 ? { debounceMs: requesterQueueSettings.debounceMs } : {},
|
|
1172
|
-
waitForTranscriptCommit: true
|
|
1173
|
-
};
|
|
1174
|
-
const wakeOutcome = await resolveActiveWakeWithRetries(requesterActivity.sessionId, params.triggerMessage, wakeOptions, params.signal);
|
|
1175
|
-
if (wakeOutcome.queued) return {
|
|
1176
|
-
delivered: true,
|
|
1177
|
-
deliveredAt: wakeOutcome.deliveredAtMs,
|
|
1178
|
-
enqueuedAt: wakeOutcome.enqueuedAtMs,
|
|
1179
|
-
path: "steered"
|
|
1180
|
-
};
|
|
1181
|
-
activeRequesterWakeFailed = true;
|
|
1182
|
-
defaultRuntime.log(`[warn] Active requester session could not be woken for subagent completion; falling back to requester-agent handoff: ${formatQueueWakeFailureError("active requester session could not be woken", wakeOutcome)}`);
|
|
1183
|
-
}
|
|
1184
|
-
if (params.expectsCompletionMessage && isCronRunSessionKey(canonicalRequesterSessionKey) && !resolveRequesterSessionActivity(canonicalRequesterSessionKey).isActive) {
|
|
1185
|
-
const generatedMediaDelivery = await tryGeneratedMediaDirectDelivery();
|
|
1186
|
-
if (generatedMediaDelivery) return generatedMediaDelivery;
|
|
1187
|
-
if (!agentMediatedCompletion) return {
|
|
1188
|
-
delivered: true,
|
|
1189
|
-
path: "none"
|
|
1190
|
-
};
|
|
1191
|
-
}
|
|
1192
|
-
if (params.signal?.aborted) return {
|
|
1193
|
-
delivered: false,
|
|
1194
|
-
path: "none"
|
|
1195
|
-
};
|
|
1196
|
-
const directAgentThreadId = shouldDeliverAgentFinal ? stringifyRouteThreadId(deliveryTarget.threadId) : sessionOnlyOriginChannel ? stringifyRouteThreadId(sessionOnlyOrigin?.threadId) : void 0;
|
|
1197
|
-
const directAgentParams = {
|
|
1198
|
-
sessionKey: canonicalRequesterSessionKey,
|
|
1199
|
-
message: params.triggerMessage,
|
|
1200
|
-
deliver: shouldDeliverAgentFinal,
|
|
1201
|
-
bestEffortDeliver: params.bestEffortDeliver,
|
|
1202
|
-
internalEvents: params.internalEvents,
|
|
1203
|
-
channel: shouldDeliverAgentFinal ? deliveryTarget.channel : sessionOnlyOriginChannel,
|
|
1204
|
-
accountId: shouldDeliverAgentFinal ? deliveryTarget.accountId : sessionOnlyOriginChannel ? sessionOnlyOrigin?.accountId : void 0,
|
|
1205
|
-
to: shouldDeliverAgentFinal ? deliveryTarget.to : sessionOnlyOriginChannel ? sessionOnlyOrigin?.to : void 0,
|
|
1206
|
-
threadId: directAgentThreadId,
|
|
1207
|
-
inputProvenance: {
|
|
1208
|
-
kind: "inter_session",
|
|
1209
|
-
sourceSessionKey: params.sourceSessionKey,
|
|
1210
|
-
sourceChannel: params.sourceChannel ?? "webchat",
|
|
1211
|
-
sourceTool: params.sourceTool ?? "subagent_announce"
|
|
1212
|
-
},
|
|
1213
|
-
...completionSourceReplyDeliveryMode ? { sourceReplyDeliveryMode: completionSourceReplyDeliveryMode } : {},
|
|
1214
|
-
idempotencyKey: params.directIdempotencyKey
|
|
1215
|
-
};
|
|
1216
|
-
let directAnnounceResponse;
|
|
1217
|
-
try {
|
|
1218
|
-
directAnnounceResponse = await runAnnounceDeliveryWithRetry({
|
|
1219
|
-
operation: params.expectsCompletionMessage ? "completion direct announce agent call" : "direct announce agent call",
|
|
1220
|
-
signal: params.signal,
|
|
1221
|
-
run: async () => await runAnnounceAgentCall({
|
|
1222
|
-
agentParams: directAgentParams,
|
|
1223
|
-
expectFinal: true,
|
|
1224
|
-
timeoutMs: announceTimeoutMs
|
|
1225
|
-
})
|
|
1226
|
-
});
|
|
1227
|
-
} catch (err) {
|
|
1228
|
-
if (isPermanentAnnounceDeliveryError(err)) throw err;
|
|
1229
|
-
if (params.expectsCompletionMessage && (shouldDeliverAgentFinal || subagentDirectMessageCompletionRequiresMessageTool) && isSubagentCompletion && isIncompleteAnnounceAgentResultError(err)) {
|
|
1230
|
-
const textDelivery = await deliverTextCompletionDirect({
|
|
1231
|
-
cfg,
|
|
1232
|
-
requesterSessionKey: canonicalRequesterSessionKey,
|
|
1233
|
-
directIdempotencyKey: params.directIdempotencyKey,
|
|
1234
|
-
deliveryTarget,
|
|
1235
|
-
internalEvents: params.internalEvents
|
|
1236
|
-
});
|
|
1237
|
-
if (textDelivery) return textDelivery;
|
|
1238
|
-
}
|
|
1239
|
-
if (activeRequesterWakeFailed && agentMediatedCompletion && expectedMediaUrls.length > 0 && isSessionWriteLockAnnounceAgentError(err)) {
|
|
1240
|
-
const generatedMediaDelivery = await tryGeneratedMediaDirectDelivery();
|
|
1241
|
-
if (generatedMediaDelivery) return generatedMediaDelivery;
|
|
1242
|
-
}
|
|
1243
|
-
throw err;
|
|
1244
|
-
}
|
|
1245
|
-
if (isGatewayAgentRunPending(directAnnounceResponse)) {
|
|
1246
|
-
if (params.expectsCompletionMessage && expectedMediaUrls.length === 0 && !requiresMessageToolDelivery) return {
|
|
1247
|
-
delivered: false,
|
|
1248
|
-
path: "direct",
|
|
1249
|
-
reason: "completion_handoff_pending",
|
|
1250
|
-
error: "completion agent handoff is still pending"
|
|
1251
|
-
};
|
|
1252
|
-
return {
|
|
1253
|
-
delivered: true,
|
|
1254
|
-
path: "direct"
|
|
1255
|
-
};
|
|
1256
|
-
}
|
|
1257
|
-
const directDeliveryFailure = shouldDeliverAgentFinal || requiresMessageToolDelivery ? getGatewayAgentCommandDeliveryFailure(directAnnounceResponse) : void 0;
|
|
1258
|
-
const missingExpectedMediaUrls = agentMediatedCompletion && expectedMediaUrls.length > 0 ? resolveGeneratedMediaDirectFallbackUrls({
|
|
1259
|
-
expectedMediaUrls,
|
|
1260
|
-
announceResponse: directAnnounceResponse,
|
|
1261
|
-
requiresMessageToolDelivery,
|
|
1262
|
-
automaticDeliveryRequested: shouldDeliverAgentFinal,
|
|
1263
|
-
automaticDeliveryFailed: !requiresMessageToolDelivery && Boolean(directDeliveryFailure),
|
|
1264
|
-
deliveryTarget
|
|
1265
|
-
}) : [];
|
|
1266
|
-
if (agentMediatedCompletion && expectedMediaUrls.length > 0 && missingExpectedMediaUrls.length > 0) {
|
|
1267
|
-
const generatedMediaDelivery = await tryGeneratedMediaDirectDelivery(directAnnounceResponse, missingExpectedMediaUrls);
|
|
1268
|
-
if (generatedMediaDelivery) return generatedMediaDelivery;
|
|
1269
|
-
return {
|
|
1270
|
-
delivered: false,
|
|
1271
|
-
path: "direct",
|
|
1272
|
-
reason: "generated_media_missing",
|
|
1273
|
-
error: "completion agent did not deliver generated media"
|
|
1274
|
-
};
|
|
1275
|
-
}
|
|
1276
|
-
if (directDeliveryFailure) return {
|
|
1277
|
-
delivered: false,
|
|
1278
|
-
path: "direct",
|
|
1279
|
-
error: directDeliveryFailure
|
|
1280
|
-
};
|
|
1281
|
-
if (params.expectsCompletionMessage && shouldDeliverAgentFinal && isSubagentCompletion && !hasVisibleGatewayAgentPayload(directAnnounceResponse) && !hasGatewayAgentMessagingToolDeliveryEvidence(directAnnounceResponse) && !hasIntentionalSilentGatewayAgentPayload(directAnnounceResponse)) {
|
|
1282
|
-
const textDelivery = await deliverTextCompletionDirect({
|
|
1283
|
-
cfg,
|
|
1284
|
-
requesterSessionKey: canonicalRequesterSessionKey,
|
|
1285
|
-
directIdempotencyKey: params.directIdempotencyKey,
|
|
1286
|
-
deliveryTarget,
|
|
1287
|
-
internalEvents: params.internalEvents
|
|
1288
|
-
});
|
|
1289
|
-
if (textDelivery) return textDelivery;
|
|
1290
|
-
if (hasFailedSubagentNoOutputCompletion(params.internalEvents)) return {
|
|
1291
|
-
delivered: false,
|
|
1292
|
-
path: "direct",
|
|
1293
|
-
reason: "visible_reply_missing",
|
|
1294
|
-
error: "completion agent did not produce a visible reply"
|
|
1295
|
-
};
|
|
1296
|
-
}
|
|
1297
|
-
if (params.expectsCompletionMessage && requiresMessageToolDelivery && !hasGatewayAgentMessagingToolDeliveryEvidence(directAnnounceResponse) && !hasIntentionalSilentGatewayAgentPayload(directAnnounceResponse)) {
|
|
1298
|
-
if (hasFailedSubagentNoOutputCompletion(params.internalEvents)) return {
|
|
1299
|
-
delivered: false,
|
|
1300
|
-
path: "direct",
|
|
1301
|
-
reason: "visible_reply_missing",
|
|
1302
|
-
error: "completion agent did not produce a visible reply"
|
|
1303
|
-
};
|
|
1304
|
-
if (subagentDirectMessageCompletionRequiresMessageTool) {
|
|
1305
|
-
const textDelivery = await deliverTextCompletionDirect({
|
|
1306
|
-
cfg,
|
|
1307
|
-
requesterSessionKey: canonicalRequesterSessionKey,
|
|
1308
|
-
directIdempotencyKey: params.directIdempotencyKey,
|
|
1309
|
-
deliveryTarget,
|
|
1310
|
-
internalEvents: params.internalEvents
|
|
1311
|
-
});
|
|
1312
|
-
if (textDelivery) return textDelivery;
|
|
1313
|
-
}
|
|
1314
|
-
return {
|
|
1315
|
-
delivered: false,
|
|
1316
|
-
path: "direct",
|
|
1317
|
-
reason: "message_tool_delivery_missing",
|
|
1318
|
-
error: "completion agent did not use the message tool for message-tool-only delivery"
|
|
1319
|
-
};
|
|
1320
|
-
}
|
|
1321
|
-
if (params.expectsCompletionMessage && shouldDeliverAgentFinal && !isSubagentCompletion && !hasVisibleGatewayAgentPayload(directAnnounceResponse)) return {
|
|
1322
|
-
delivered: false,
|
|
1323
|
-
path: "direct",
|
|
1324
|
-
reason: "visible_reply_missing",
|
|
1325
|
-
error: "completion agent did not produce a visible reply"
|
|
1326
|
-
};
|
|
1327
|
-
return {
|
|
1328
|
-
delivered: true,
|
|
1329
|
-
path: "direct"
|
|
1330
|
-
};
|
|
1331
|
-
} catch (err) {
|
|
1332
|
-
return {
|
|
1333
|
-
delivered: false,
|
|
1334
|
-
path: "direct",
|
|
1335
|
-
error: summarizeDeliveryError(err)
|
|
1336
|
-
};
|
|
1337
|
-
}
|
|
1338
|
-
}
|
|
1339
|
-
async function deliverSubagentAnnouncement(params) {
|
|
1340
|
-
return await runSubagentAnnounceDispatch({
|
|
1341
|
-
expectsCompletionMessage: params.expectsCompletionMessage,
|
|
1342
|
-
signal: params.signal,
|
|
1343
|
-
steer: async () => await maybeSteerSubagentAnnounce({
|
|
1344
|
-
deliveryTimeoutMs: resolveSubagentAnnounceTimeoutMs(subagentAnnounceDeliveryDeps.getRuntimeConfig()),
|
|
1345
|
-
requesterSessionKey: params.requesterSessionKey,
|
|
1346
|
-
steerMessage: params.steerMessage,
|
|
1347
|
-
signal: params.signal
|
|
1348
|
-
}),
|
|
1349
|
-
direct: async () => await sendSubagentAnnounceDirectly({
|
|
1350
|
-
requesterSessionKey: params.requesterSessionKey,
|
|
1351
|
-
targetRequesterSessionKey: params.targetRequesterSessionKey,
|
|
1352
|
-
triggerMessage: params.triggerMessage,
|
|
1353
|
-
internalEvents: params.internalEvents,
|
|
1354
|
-
directIdempotencyKey: params.directIdempotencyKey,
|
|
1355
|
-
completionDirectOrigin: params.completionDirectOrigin,
|
|
1356
|
-
directOrigin: params.directOrigin,
|
|
1357
|
-
requesterSessionOrigin: params.requesterSessionOrigin,
|
|
1358
|
-
sourceSessionKey: params.sourceSessionKey,
|
|
1359
|
-
sourceChannel: params.sourceChannel,
|
|
1360
|
-
sourceTool: params.sourceTool,
|
|
1361
|
-
requesterIsSubagent: params.requesterIsSubagent,
|
|
1362
|
-
expectsCompletionMessage: params.expectsCompletionMessage,
|
|
1363
|
-
signal: params.signal,
|
|
1364
|
-
bestEffortDeliver: params.bestEffortDeliver
|
|
1365
|
-
})
|
|
1366
|
-
});
|
|
1367
|
-
}
|
|
1368
|
-
//#endregion
|
|
1369
|
-
export { formatAgentInternalEventsForPlainPrompt as _, resolveSubagentAnnounceTimeoutMs as a, formatGeneratedAttachmentLines as b, hasCommittedMessagingToolDeliveryEvidence as c, hasVisibleAgentPayload as d, hasAcceptedSessionSpawn as f, resolveSourceDeliveryOutcome as g, createSourceDeliveryPlan as h, loadSessionEntryByKey as i, hasMessagingToolDeliveryEvidence as l, isNonTerminalAgentRunStatus as m, isInternalAnnounceRequesterSession as n, resolveSubagentCompletionOrigin as o, normalizeAcceptedSessionSpawnResult as p, loadRequesterSessionEntry as r, runAnnounceDeliveryWithRetry as s, deliverSubagentAnnouncement as t, hasOutboundDeliveryEvidence as u, formatAgentInternalEventsForPrompt as v, mediaUrlsFromGeneratedAttachments as x, AGENT_INTERNAL_EVENT_TYPE_TASK_COMPLETION as y };
|