@gaodefa/daocore 2026.5.29 → 2026.5.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/abort-DI3P6TIb.js +277 -0
- package/dist/abort.runtime-B6Z7lDEa.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/account-inspect-BFz7X0TX.js +173 -0
- package/dist/accounts-BoYYrY7x.js +107 -0
- package/dist/accounts-Busq29zW.js +107 -0
- package/dist/accounts-CuvH2tuN.js +119 -0
- package/dist/accounts-DkIcqvf7.js +2 -0
- package/dist/acp-runtime-BA8lzXzf.js +26 -0
- package/dist/acp-spawn-DPz2aX3A.js +2 -0
- package/dist/acp-spawn-DvVCsWYV.js +1275 -0
- package/dist/acp-stateful-target-driver-DcC76aZW.js +89 -0
- package/dist/action-kill-D-dVisIX.js +33 -0
- package/dist/action-runtime-BEiqwxDD.js +469 -0
- package/dist/action-runtime-api-1LzcGjcX.js +2 -0
- package/dist/action-send-c3CnDuPg.js +39 -0
- package/dist/action-spawn-Dj4kwpWs.js +47 -0
- package/dist/actions-qLccmQBc.js +161 -0
- package/dist/actions.runtime-B5vYAgNi.js +5 -0
- package/dist/agent-command-D6Ds198G.js +1367 -0
- package/dist/agent-components.runtime-xquK0B3L.js +10 -0
- package/dist/agent-components.runtime.js +1 -1
- package/dist/agent-harness-runtime-Dq1fCBOM.js +180 -0
- package/dist/agent-harness-task-runtime-DvSEqFkD.js +140 -0
- package/dist/agent-lm5ZYOFy.js +3 -0
- package/dist/agent-runner-execution-Dbh2pDhQ.js +1713 -0
- package/dist/agent-runner-utils-Di3r2T1T.js +266 -0
- package/dist/agent-runner.runtime-BW90EcGW.js +3455 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-BgIT5Ytc.js +229 -0
- package/dist/agent-via-gateway-DMMS8-hK.js +463 -0
- package/dist/agent-ylolD8-V.js +2 -0
- package/dist/api-BB4vXLtW.js +2 -0
- package/dist/api-CUhM3KNB.js +134 -0
- package/dist/api-CewRHSbT.js +6 -0
- package/dist/api-CfKjNJlW.js +2 -0
- package/dist/api-Rsnqui1u.js +3 -0
- package/dist/api-k7AvxwHr.js +639 -0
- package/dist/apply-DQ4TQNMA.js +54 -0
- package/dist/apply-S_75Py4Y.js +41 -0
- package/dist/approval-handler.runtime-Cthxrstu.js +130 -0
- package/dist/assistant-Cp9pGaBw.js +291 -0
- package/dist/attachment-normalize-5R0bLLOj.js +225 -0
- package/dist/attempt-execution-DuyyZYsU.js +558 -0
- package/dist/attempt-execution.runtime-DF2GPgNh.js +3 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt-execution.shared-CwdukA3t.js +38 -0
- package/dist/attempt.prompt-helpers-CUqKtIa5.js +475 -0
- package/dist/attempt.tool-run-context-BbN4_BYO.js +2094 -0
- package/dist/binding-routing-C6Ex2Blu.js +113 -0
- package/dist/binding-targets-BqREncSL.js +121 -0
- package/dist/bot-DGMEkaIJ.js +7894 -0
- package/dist/bot-deps-BltYjeMX.js +2 -0
- package/dist/bot-deps-XvGCor9f.js +747 -0
- package/dist/bot-message-context.runtime-kK-xvLV7.js +7 -0
- package/dist/bot-message-context.runtime.js +1 -1
- package/dist/bot-message-context.session.runtime-DpOIJUae.js +12 -0
- package/dist/bot-message-context.session.runtime.js +1 -1
- package/dist/bot-native-commands.delivery.runtime-D49p5Lc1.js +4 -0
- package/dist/bot-native-commands.delivery.runtime.js +1 -1
- package/dist/bot-native-commands.runtime-8XBdSpkQ.js +13 -0
- package/dist/bot-native-commands.runtime.js +1 -1
- package/dist/bridge-server-y_XGduPx.js +113 -0
- package/dist/browser-cli-B2jmmTT3.js +230 -0
- package/dist/browser-cli-actions-input-JQt5ZQcn.js +473 -0
- package/dist/browser-cli-actions-observe-CrfKh6AX.js +81 -0
- package/dist/browser-cli-debug-DQACWlvC.js +137 -0
- package/dist/browser-cli-inspect-DDnxx0Xw.js +104 -0
- package/dist/browser-cli-lEuOnZzs.js +2 -0
- package/dist/browser-cli-manage-DogmwtYt.js +443 -0
- package/dist/browser-cli-resize-BHuV71VZ.js +26 -0
- package/dist/browser-cli-shared-CidShgoF.js +50 -0
- package/dist/browser-cli-state-i8cCGbiQ.js +337 -0
- package/dist/browser-control-auth-CKfXdXWj.js +2 -0
- package/dist/browser-profiles-ATBTvUGh.js +2 -0
- package/dist/browser-runtime-KmCT6FuL.js +384 -0
- package/dist/build-DOOT6f62.js +257 -0
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +2 -2
- package/dist/bundled/session-memory/handler.js +1 -1
- package/dist/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/capability-cli-DwvrwB-g.js +1782 -0
- package/dist/channel-B-wgK1bK.js +481 -0
- package/dist/channel-B1e_k1P0.js +867 -0
- package/dist/channel-BRDfa5tc.js +1777 -0
- package/dist/channel-BVEO1O4p.js +376 -0
- package/dist/channel-BYlO5l1d.js +508 -0
- package/dist/channel-Bl0sPoNx.js +653 -0
- package/dist/channel-C84xtDBy.js +1134 -0
- package/dist/channel-CLgKq4Ds.js +1556 -0
- package/dist/channel-CZT0qxLh.js +1249 -0
- package/dist/channel-CffBHWkb.js +955 -0
- package/dist/channel-D34ZJvVB.js +2126 -0
- package/dist/channel-DcdXLo_W.js +238 -0
- package/dist/channel-DnK5TrXV.js +362 -0
- package/dist/channel-Dzj4RHY2.js +740 -0
- package/dist/channel-OhZzLZCj.js +562 -0
- package/dist/channel-actions.runtime-Cdvhqc9s.js +265 -0
- package/dist/channel-actions.runtime.js +1 -1
- package/dist/channel-core-Dz9I_R4j.js +5 -0
- package/dist/channel-inbound-COGoV_aS.js +80 -0
- package/dist/channel-mP6HCIMr.js +1496 -0
- package/dist/channel-plugin-runtime-C0R46KeG.js +998 -0
- package/dist/channel-quGdgWel.js +808 -0
- package/dist/channel-runtime-FvPQoIF9.js +408 -0
- package/dist/channel.runtime-2vUz3gij.js +109 -0
- package/dist/channel.runtime-BZLDSNuQ.js +254 -0
- package/dist/channel.runtime-Bo5jO0Hj.js +4 -0
- package/dist/channel.runtime-CDgvrjM2.js +652 -0
- package/dist/channel.runtime-COf8SDFn.js +88 -0
- package/dist/channel.runtime-C_C1f8lu.js +733 -0
- package/dist/channel.runtime-CqPbsg8t.js +2528 -0
- package/dist/channel.runtime-DtV85Khx.js +1008 -0
- package/dist/channel.runtime-Spt1ukGW.js +21009 -0
- package/dist/channel.setup-Bc0LUQS1.js +1098 -0
- package/dist/channel.setup-ChTkj2hq.js +343 -0
- package/dist/channel.setup-CpMD9F8i.js +10 -0
- package/dist/chat-mUsjD5YN.js +2666 -0
- package/dist/chrome-u314zcbM.js +1503 -0
- package/dist/cli/run-main.js +5 -5
- package/dist/cli-CJMoqXrc.js +1341 -0
- package/dist/cli-compaction-qGYB7suI.js +347 -0
- package/dist/cli-metadata-BBJFpNU9.js +22 -0
- package/dist/cli-runner-C0kcts0I.js +540 -0
- package/dist/cli-runner-CTm8K6s8.js +2 -0
- package/dist/cli-runner.runtime-C8deL5FL.js +3 -0
- package/dist/cli-runner.runtime-DDAg1D0L.js +4 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +8 -8
- package/dist/client-CPxpgs4m.js +650 -0
- package/dist/client-adapter-CLlqOqfu.js +897 -0
- package/dist/client-factory-R7Rr2jwn.js +9 -0
- package/dist/command-auth-CkQP1buP.js +135 -0
- package/dist/command-handlers-CJEjFyMk.js +1609 -0
- package/dist/command-registry-BDgyOqDw.js +4 -0
- package/dist/command-registry-BVi5Jn1S.js +9 -0
- package/dist/command-registry-core-JCfsVRtz.js +110 -0
- package/dist/command-status.runtime-CM1JLzi6.js +90 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-acp-C1-I78U6.js +74 -0
- package/dist/commands-compact.runtime-DOsNavwp.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-handlers.runtime-BD1n2WGw.js +6154 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-status-DU_UTQz1.js +16 -0
- package/dist/commands-status-DejfTakp.js +3 -0
- package/dist/commands-status.runtime-DejfTakp.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-D7vo_2Y_.js +3 -0
- package/dist/commands-subagents-control.runtime-DGybTjJ6.js +2 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-BEBXAMea.js +2 -0
- package/dist/commands-system-prompt-gj3oQpQO.js +162 -0
- package/dist/commands.runtime-CgXX70IN.js +176 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/commitments/runtime.js +1 -1
- package/dist/compact-C41XxMDt.js +480 -0
- package/dist/compact-DUVAF9EC.js +1141 -0
- package/dist/compact.runtime-COMRg6s3.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-CmEYoB9a.js +315 -0
- package/dist/computer-use-BwJHu1QF.js +367 -0
- package/dist/config-ATBTvUGh.js +2 -0
- package/dist/config-DlNgjF8W.js +373 -0
- package/dist/config-mutations-tl_OqI6d.js +159 -0
- package/dist/context-engine-host-compat-BNPAIK9F.js +288 -0
- package/dist/context-engine-host-compat-C69CK7zS.js +2 -0
- package/dist/context-engine-lifecycle-iQ8f5a_-.js +1274 -0
- package/dist/control-auth-vVxyGKxY.js +114 -0
- package/dist/control-service-73nj79EW.js +145 -0
- package/dist/control-ui/assets/agents-DdWIz8Vk.js +1008 -0
- package/dist/control-ui/assets/channel-config-extras-C7ELhuDi.js +2 -0
- package/dist/control-ui/assets/channels-Bsoj-9BS.js +367 -0
- package/dist/control-ui/assets/cron-BRTEw1tT.js +1013 -0
- package/dist/control-ui/assets/debug-EKl_F8_L.js +97 -0
- package/dist/control-ui/assets/index-DSbSO7ys.js +7370 -0
- package/dist/control-ui/assets/instances-B1AoYwI5.js +57 -0
- package/dist/control-ui/assets/logs-BChOznzh.js +74 -0
- package/dist/control-ui/assets/nodes-5yebKh9k.js +436 -0
- package/dist/control-ui/assets/sessions-BlDYNThc.js +399 -0
- package/dist/control-ui/assets/skills-shared-CNFnf7KU.js +11 -0
- package/dist/control-ui/assets/skills-uxTDRmLx.js +314 -0
- package/dist/control-ui/index.html +1 -1
- package/dist/control-ui/sw.js +1 -1
- package/dist/conversation-binding-runtime-CmoTKcY1.js +4 -0
- package/dist/conversation-runtime-BxOHxuin.js +31 -0
- package/dist/core-D0Y2H55f.js +282 -0
- package/dist/core-api-BKlJUtDt.js +5 -0
- package/dist/core-api-_fiftUHn.js +2 -0
- package/dist/crestodian/crestodian.js +1 -1
- package/dist/crestodian/rescue-message.js +1 -1
- package/dist/crestodian-BJifoQiR.js +55 -0
- package/dist/daocore-tools-BMdF8RwK.js +11727 -0
- package/dist/delivery-e2ci_bcX.js +1002 -0
- package/dist/dialogue-BXayGhnz.js +37 -0
- package/dist/dir-fetch-tool-Cara5mZh.js +565 -0
- package/dist/dir-list-tool-CQ8Bo5Ez.js +100 -0
- package/dist/direct-dm-CPk6Qm9D.js +64 -0
- package/dist/directive-handling.fast-lane-BQ9aXqk8.js +68 -0
- package/dist/directive-handling.impl--a5AGurq.js +818 -0
- package/dist/directive-handling.impl-C4JqMwle.js +2 -0
- package/dist/directive-handling.model-selection-pyTYMIXn.js +122 -0
- package/dist/directive-handling.persist.runtime-B7vWT1r9.js +263 -0
- package/dist/directive-handling.persist.runtime.js +1 -1
- package/dist/dispatch-3Ru_eGq1.js +1640 -0
- package/dist/dispatch-acp-transcript.runtime-CYMP-5oE.js +40 -0
- package/dist/dispatch-acp-transcript.runtime.js +1 -1
- package/dist/dispatch-acp.runtime-BVCiklXk.js +18 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/doctor-B8mR3Sgr.js +2 -0
- package/dist/doctor-BJ6DuerV.js +6 -0
- package/dist/doctor-config-flow-BdOGs_zn.js +1741 -0
- package/dist/doctor-core-checks-CDf0stz-.js +2 -0
- package/dist/doctor-core-checks-Cpdnu2XI.js +573 -0
- package/dist/doctor-health-0qv_acBu.js +65 -0
- package/dist/doctor-health-contributions-Db1FQgFw.js +696 -0
- package/dist/doctor-lint-C1g4Llgl.js +94 -0
- package/dist/doctor-state-integrity-C8iXFLJ7.js +1231 -0
- package/dist/doctor-update-CsPu6p3d.js +58 -0
- package/dist/dynamic-tools-YQ0z0YKH.js +486 -0
- package/dist/embedded-backend-S0cahIZw.js +579 -0
- package/dist/embedded-gateway-stub.runtime-Cjw12ALm.js +12 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/exec-approvals-ArHHjoE-.js +149 -0
- package/dist/extensionAPI.js +1 -1
- package/dist/extensions/active-memory/index.js +1 -1
- package/dist/extensions/admin-http-rpc/index.js +1 -1
- package/dist/extensions/browser/browser-bridge.js +1 -1
- package/dist/extensions/browser/browser-config.js +4 -4
- package/dist/extensions/browser/browser-control-auth.js +2 -2
- package/dist/extensions/browser/browser-doctor.js +2 -2
- package/dist/extensions/browser/browser-maintenance.js +1 -1
- package/dist/extensions/browser/browser-profiles.js +2 -2
- package/dist/extensions/browser/browser-runtime-api.js +11 -11
- package/dist/extensions/browser/cli-metadata.js +1 -1
- package/dist/extensions/browser/index.js +1 -1
- package/dist/extensions/browser/plugin-registration.js +1 -1
- package/dist/extensions/browser/register.runtime.js +4 -4
- package/dist/extensions/browser/runtime-api.js +13 -13
- package/dist/extensions/canvas/index.js +1 -1
- package/dist/extensions/clickclack/api.js +2 -2
- package/dist/extensions/clickclack/channel-plugin-api.js +1 -1
- package/dist/extensions/clickclack/runtime-api.js +2 -2
- package/dist/extensions/device-pair/api.js +1 -1
- package/dist/extensions/device-pair/pair-command-approve.js +1 -1
- package/dist/extensions/file-transfer/index.js +4 -4
- package/dist/extensions/imessage/api.js +2 -2
- package/dist/extensions/imessage/channel-plugin-api.js +1 -1
- package/dist/extensions/imessage/message-tool-api.d.ts +1 -1
- package/dist/extensions/imessage/runtime-api.js +3 -3
- package/dist/extensions/irc/api.js +2 -2
- package/dist/extensions/irc/channel-plugin-api.js +1 -1
- package/dist/extensions/llm-task/index.js +1 -1
- package/dist/extensions/mattermost/api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
- package/dist/extensions/mattermost/policy-api.js +1 -1
- package/dist/extensions/mattermost/runtime-api.js +2 -2
- package/dist/extensions/mattermost/slash-route-api.js +1 -1
- package/dist/extensions/memory-core/cli-metadata.js +1 -1
- package/dist/extensions/migrate-claude/apply.js +1 -1
- package/dist/extensions/migrate-claude/index.js +1 -1
- package/dist/extensions/migrate-claude/plan.js +1 -1
- package/dist/extensions/migrate-claude/provider.js +1 -1
- package/dist/extensions/migrate-claude/targets.js +1 -1
- package/dist/extensions/migrate-hermes/apply.js +1 -1
- package/dist/extensions/migrate-hermes/index.js +1 -1
- package/dist/extensions/migrate-hermes/model.js +1 -1
- package/dist/extensions/migrate-hermes/plan.js +1 -1
- package/dist/extensions/migrate-hermes/provider.js +1 -1
- package/dist/extensions/migrate-hermes/secrets.js +1 -1
- package/dist/extensions/migrate-hermes/targets.js +1 -1
- package/dist/extensions/policy/api.js +1 -1
- package/dist/extensions/policy/index.js +2 -2
- package/dist/extensions/signal/api.js +6 -6
- package/dist/extensions/signal/channel-plugin-api.js +1 -1
- package/dist/extensions/signal/reaction-runtime-api.js +1 -1
- package/dist/extensions/signal/runtime-api.js +7 -7
- package/dist/extensions/skill-workshop/api.js +1 -1
- package/dist/extensions/skill-workshop/index.js +2 -2
- package/dist/extensions/telegram/account-inspect-api.js +1 -1
- package/dist/extensions/telegram/api.js +11 -11
- package/dist/extensions/telegram/channel-plugin-api.js +2 -2
- package/dist/extensions/telegram/contract-api.js +3 -3
- package/dist/extensions/telegram/runtime-api.js +7 -7
- package/dist/extensions/telegram/security-audit-contract-api.js +1 -1
- package/dist/extensions/telegram/setup-plugin-api.js +1 -1
- package/dist/extensions/telegram/test-api.js +2 -2
- package/dist/extensions/webhooks/api.js +1 -1
- package/dist/extensions/webhooks/index.js +1 -1
- package/dist/extensions/xai/index.js +4 -4
- package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
- package/dist/extensions/xai/speech-provider.js +1 -1
- package/dist/extensions/xai/test-api.js +1 -1
- package/dist/extensions/xai/tts.js +1 -1
- package/dist/extensions/xai/web-search.js +1 -1
- package/dist/extensions/xai/xai-oauth.js +1 -1
- package/dist/file-fetch-tool-DQpAtjX4.js +124 -0
- package/dist/file-write-tool-CkB0oYwe.js +127 -0
- package/dist/format-DUJUpMFQ.js +1145 -0
- package/dist/gateway-cli-CQo_E4Ka.js +435 -0
- package/dist/gateway-method-runtime-1QPgVJH7.js +21 -0
- package/dist/get-reply-DfUcsC-O.js +4689 -0
- package/dist/get-reply-from-config.runtime-C95MG73O.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/graph-users-DPJe0fPs.js +1419 -0
- package/dist/group-access-DefaNJ6L.js +112 -0
- package/dist/handle-action.guild-admin-C1sy1kGJ.js +288 -0
- package/dist/harness-BgPRdmNK.js +61 -0
- package/dist/health-DFR9A1YV.js +4 -0
- package/dist/heartbeat-runner-BiYVPs25.js +5 -0
- package/dist/heartbeat-runner.runtime-Bmaq8WUA.js +4 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/hooks-CNJDuJUm.js +534 -0
- package/dist/inbound-direct-dm-runtime-DFt58p71.js +2 -0
- package/dist/inbound-reply-dispatch-kgSDM8ax.js +148 -0
- package/dist/index.js +1 -1
- package/dist/init-B0zO_U4r.js +59 -0
- package/dist/inline-buttons-B6zgQW3J.js +40 -0
- package/dist/internal-events-C3Q5t6hg.js +90 -0
- package/dist/isolated-agent-CaSU5GCJ.js +2 -0
- package/dist/isolated-agent-CnsD2TmP.js +1118 -0
- package/dist/lifecycle-i3WZDaIn.js +571 -0
- package/dist/list.probe-g0rUiVXW.js +449 -0
- package/dist/list.status-command-DG3PrmeO.js +789 -0
- package/dist/llm-slug-generator-CHlf69FU.js +78 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/local-dispatch.runtime-CDeHUp_A.js +9 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/manager.runtime-BlLMPUTq.js +2714 -0
- package/dist/manager.runtime.js +1 -1
- package/dist/markdown-to-line-r_mBHMdy.js +811 -0
- package/dist/mcp-http-C5UPIJGR.js +555 -0
- package/dist/mcp-http-CTy9gpfA.js +2 -0
- package/dist/media-understanding-provider-BT6TOuVa.js +339 -0
- package/dist/message-actions-BdcjjwFt.js +145 -0
- package/dist/message-handler-B29Tj2p2.js +1715 -0
- package/dist/message-handler-BhHb1FHI.js +384 -0
- package/dist/message-handler.preflight-ouZ_-3o8.js +1125 -0
- package/dist/message-handler.process-CrYiBx_F.js +1484 -0
- package/dist/model-CLbtocQX.js +74 -0
- package/dist/model-selection-BG_vU9Kl.js +272 -0
- package/dist/models-4KERn3ya.js +104 -0
- package/dist/models-BCa-ipxi.js +2 -0
- package/dist/models-cli-DtpGXEsf.js +256 -0
- package/dist/monitor-B-egsvmI.js +1657 -0
- package/dist/monitor-BJX9Yv7k.js +2 -0
- package/dist/monitor-BPrIy3pV.js +715 -0
- package/dist/monitor-BWknZZ7N.js +4377 -0
- package/dist/monitor-C3y_PtI1.js +60 -0
- package/dist/monitor-DCzfdqE4.js +1370 -0
- package/dist/monitor-P24epSwE.js +2788 -0
- package/dist/monitor-auth-CEG_xldE.js +179 -0
- package/dist/monitor-jEePJbbS.js +834 -0
- package/dist/monitor-polling.runtime-BzlHK11u.js +883 -0
- package/dist/monitor-polling.runtime.js +1 -1
- package/dist/monitor-webhook.runtime-vFEhk_Zj.js +387 -0
- package/dist/monitor-webhook.runtime.js +1 -1
- package/dist/monitor.account-BUIfgWXg.js +5233 -0
- package/dist/monitor.runtime-Cp7W4fhb.js +2 -0
- package/dist/monitor.runtime.js +1 -1
- package/dist/monitor.webhook-DzrbeR4T.js +180 -0
- package/dist/node-cli-sessions-CLbI14UA.js +1228 -0
- package/dist/openai-http-BM9BIA_g.js +824 -0
- package/dist/openresponses-http-CNoW9kk8.js +1173 -0
- package/dist/operations-DT4bsxV6.js +805 -0
- package/dist/outbound-adapter-CZRUOgY0.js +543 -0
- package/dist/outbound-session-route-DneMsGNx.js +45 -0
- package/dist/outbound.runtime-CHuoKJJI.js +2 -0
- package/dist/outbound.runtime.js +1 -1
- package/dist/pi-embedded-1-rsueO_.js +3796 -0
- package/dist/pi-embedded-BRfDncVO.js +4 -0
- package/dist/pi-embedded.runtime-DEYoa6bW.js +4 -0
- package/dist/pi-embedded.runtime.js +1 -1
- package/dist/pi-tools-C0P3NgP5.js +2413 -0
- package/dist/plan-BQUkjBMY.js +81 -0
- package/dist/plan-CRO9_2_k.js +112 -0
- package/dist/plugin-BJCmWhnh.js +12396 -0
- package/dist/plugin-app-cache-key-CXAg0F7A.js +46 -0
- package/dist/plugin-enabled-D93Z9LSo.js +233 -0
- package/dist/plugin-registration-BBrTcZnf.js +88 -0
- package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
- package/dist/plugin-sdk/acp-runtime-backend.js +1 -1
- package/dist/plugin-sdk/acp-runtime.js +2 -2
- package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
- package/dist/plugin-sdk/agent-harness-task-runtime.js +1 -1
- package/dist/plugin-sdk/agent-harness.js +7 -7
- package/dist/plugin-sdk/agent-runtime.js +2 -2
- package/dist/plugin-sdk/channel-core.js +2 -2
- package/dist/plugin-sdk/channel-inbound.js +2 -2
- package/dist/plugin-sdk/channel-test-helpers.js +1 -1
- package/dist/plugin-sdk/command-auth.js +1 -1
- package/dist/plugin-sdk/command-status-runtime.js +1 -1
- package/dist/plugin-sdk/compat.js +1 -1
- package/dist/plugin-sdk/conversation-binding-runtime.js +2 -2
- package/dist/plugin-sdk/conversation-runtime.js +3 -3
- package/dist/plugin-sdk/core.js +2 -2
- package/dist/plugin-sdk/direct-dm.js +1 -1
- package/dist/plugin-sdk/gateway-method-runtime.js +1 -1
- package/dist/plugin-sdk/health.js +2 -2
- package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/mattermost.js +1 -1
- package/dist/plugin-sdk/plugin-test-contracts.js +2 -2
- package/dist/plugin-sdk/provider-test-contracts.js +4 -4
- package/dist/plugin-sdk/reply-runtime.js +4 -4
- package/dist/plugin-sdk/testing.js +2 -2
- package/dist/plugin-sdk/zalouser.js +1 -1
- package/dist/plugin-service-DnZEPBEA.js +1229 -0
- package/dist/plugins/runtime/index.js +4 -4
- package/dist/policy-CMv5QMPG.js +138 -0
- package/dist/policy-CeoP4t9J.js +680 -0
- package/dist/prepare.runtime-DZ55JiTt.js +732 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/preview-warnings-O08PZRxu.js +392 -0
- package/dist/probe-C6w3bP8X.js +682 -0
- package/dist/probe-Cs1_X1NA.js +47 -0
- package/dist/probe-Cuee_jyM.js +2204 -0
- package/dist/probe-DZxCnDzn.js +2 -0
- package/dist/program-C2dT8VHB.js +131 -0
- package/dist/provider-C2_vSzYh.js +32 -0
- package/dist/provider-DSfTDQbj.js +152 -0
- package/dist/provider-U8hrm9h-.js +32 -0
- package/dist/provider-_v910H8y.js +8735 -0
- package/dist/provider-dispatcher-C3kmmIEC.js +22 -0
- package/dist/provider-dispatcher.runtime.js +1 -1
- package/dist/provider-session.runtime-Mg0fx5hH.js +9 -0
- package/dist/provider-session.runtime.js +1 -1
- package/dist/provider.runtime-pSTXuHrq.js +2 -0
- package/dist/provider.runtime.js +1 -1
- package/dist/public-surface-loader-09t4TTue.js +114 -0
- package/dist/pw-ai-DjNqHV3_.js +3029 -0
- package/dist/pw-role-snapshot-DoGefdv7.js +333 -0
- package/dist/reaction-level-C8Mqxizo.js +19 -0
- package/dist/reaction-runtime-api-DOP6xOsm.js +116 -0
- package/dist/realtime-transcription-provider-BTGEXXna.js +205 -0
- package/dist/register-CbZPpqI3.js +2178 -0
- package/dist/register.agent-DrBFuPKh.js +156 -0
- package/dist/register.crestodian-DwTbmaK8.js +24 -0
- package/dist/register.maintenance-BIeoYBub.js +83 -0
- package/dist/register.runtime-B5V9_Dwz.js +54 -0
- package/dist/register.subclis-CJE9ISZY.js +31 -0
- package/dist/register.subclis-YQsKas8N.js +3 -0
- package/dist/register.subclis-core-CjwdGeGU.js +273 -0
- package/dist/repair-sequencing-C0jrL5pw.js +640 -0
- package/dist/reply-delivery-B28mTIpb.js +196 -0
- package/dist/reply-runtime-BqQX7HHw.js +11 -0
- package/dist/reply.runtime-C95MG73O.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/request-BqoMvXxH.js +54 -0
- package/dist/resolve-allowlist-hbKKd_kq.js +220 -0
- package/dist/result-fallback-classifier-BrORPoxj.js +79 -0
- package/dist/route-HHRgSzVy.js +469 -0
- package/dist/route-resolution-C7bafjVc.js +274 -0
- package/dist/routes-86XGeo7a.js +2 -0
- package/dist/routes-BhVGr9ie.js +3602 -0
- package/dist/run-Bb5QP5JV.js +1162 -0
- package/dist/run-attempt-CLi0wV7j.js +7704 -0
- package/dist/run-command-Be6GAxiW.js +2 -0
- package/dist/run-command-Ds4hr3iU.js +23 -0
- package/dist/run-embedded.runtime-wX9ORojX.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-BmNZVB2N.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-subagent-registry.runtime-Uq5sjftu.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/runtime-BktLQ75j.js +1287 -0
- package/dist/runtime-C9XdR62_.js +438 -0
- package/dist/runtime-CTvWDPx9.js +6179 -0
- package/dist/runtime-api-BojB3MUw.js +21 -0
- package/dist/runtime-api-C92MlAwp.js +13 -0
- package/dist/runtime-api-CFNZE9Xt.js +13 -0
- package/dist/runtime-api-Cimpgm5_.js +3 -0
- package/dist/runtime-api-D8qG_lUm.js +17 -0
- package/dist/runtime-api-DMDMnQEG.js +4 -0
- package/dist/runtime-api-DupQdIlE.js +24 -0
- package/dist/runtime-api.actions-B8i3elqu.js +3 -0
- package/dist/runtime-api.monitor-BntFzf_M.js +6 -0
- package/dist/runtime-api.send-CPlmi1jc.js +4 -0
- package/dist/runtime-api.threads-D-H_r_Nl.js +2 -0
- package/dist/runtime-channel-BGhTxnXZ.js +150 -0
- package/dist/runtime-channel-CPFxNapZ.js +2 -0
- package/dist/runtime-embedded-pi.runtime-BjnMTurB.js +2 -0
- package/dist/runtime-embedded-pi.runtime.js +1 -1
- package/dist/sanitize-outbound-BMUv1NeS.js +127 -0
- package/dist/sdk-setup-tools-Do3DkQi_.js +8 -0
- package/dist/secrets-B8YVPHhk.js +113 -0
- package/dist/security-audit-7Gg_nL4o.js +122 -0
- package/dist/security-audit-Bk3CREj-.js +118 -0
- package/dist/security-audit.runtime-BmSJrdeq.js +2 -0
- package/dist/security-audit.runtime.js +1 -1
- package/dist/selection-BFGde9-_.js +3 -0
- package/dist/selection-DrLFlbgG.js +16157 -0
- package/dist/send-4dLa-BQo.js +1631 -0
- package/dist/send-CV6gCwYP.js +192 -0
- package/dist/send-aGiK3Efu.js +143 -0
- package/dist/send-dB3CehAN.js +2 -0
- package/dist/send.components-BcG9BlkC.js +2 -0
- package/dist/send.components-rLjDlfYU.js +500 -0
- package/dist/send.runtime-D20k2MSr.js +2 -0
- package/dist/send.runtime.js +1 -1
- package/dist/server-BTRx_U1s.js +73 -0
- package/dist/server-CY0ymhBg.js +24 -0
- package/dist/server-close.runtime.js +1 -1
- package/dist/server-context-BxGT8wbK.js +955 -0
- package/dist/server-context-DYlbhAaT.js +2 -0
- package/dist/server-cron-BB_15lcP.js +2 -0
- package/dist/server-cron-CfyJX_a4.js +2989 -0
- package/dist/server-methods-Ck2ab6TC.js +16494 -0
- package/dist/server-node-events-BdRizF-5.js +596 -0
- package/dist/server-plugin-bootstrap-CPUr8NFE.js +70 -0
- package/dist/server-plugins-__5AxjzH.js +432 -0
- package/dist/server-reload-handlers-BMl9Fx9b.js +714 -0
- package/dist/server-restart-sentinel-D11M_ZsH.js +747 -0
- package/dist/server-restart-sentinel-DGptQ27c.js +2 -0
- package/dist/server-runtime-services-BwtLs-8I.js +2 -0
- package/dist/server-runtime-services-aJydixRu.js +267 -0
- package/dist/server-startup-plugins-m_P3gY4m.js +113 -0
- package/dist/server-startup-post-attach-DuXQ1AXL.js +716 -0
- package/dist/server-ws-runtime-mXmxB1W8.js +349 -0
- package/dist/server.impl-fuV8aKSP.js +2586 -0
- package/dist/service-a8cTFka4.js +1446 -0
- package/dist/session-binding-BIycxo9u.js +2 -0
- package/dist/session-binding-xHwQr9vM.js +219 -0
- package/dist/session-kill-http-DiUZhcoN.js +121 -0
- package/dist/session-reset-service-DkepDoob.js +625 -0
- package/dist/session-route-Ba5u7ecb.js +93 -0
- package/dist/session-status.runtime-Cb1X69Rl.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-rbqmto4G.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-DSKOoJta.js +521 -0
- package/dist/sessions-history-http-CWP88I_C.js +430 -0
- package/dist/sessions.runtime-1q1OwLn3.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/setup-api-DtrOOYeP.js +29 -0
- package/dist/setup-core-DMrJS6LP.js +174 -0
- package/dist/setup-surface-BFPNu1qA.js +405 -0
- package/dist/setup-surface-CedShqhO.js +288 -0
- package/dist/setup-surface-DLOBH1Vf.js +320 -0
- package/dist/setup-surface-MhCeEWSj.js +221 -0
- package/dist/shared-DamL-e8D.js +121 -0
- package/dist/shared-client-B48JoAsz.js +2 -0
- package/dist/shared-client-BoSiDnUo.js +629 -0
- package/dist/side-question-DQoQ_ETb.js +683 -0
- package/dist/skill-tool-dispatch.runtime-CWLloYA8.js +143 -0
- package/dist/skill-tool-dispatch.runtime.js +1 -1
- package/dist/slash-state-DrrWJQfv.js +2166 -0
- package/dist/speech-provider-8Hx1uw41.js +184 -0
- package/dist/src-BbUYOPwU.js +4256 -0
- package/dist/startup-context-opAJAamX.js +313 -0
- package/dist/status-subagents.runtime-DSo7ZK_Z.js +18 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-AyPuDzrO.js +296 -0
- package/dist/sticker-cache-91Tp8mLP.js +206 -0
- package/dist/sticker-vision.runtime-DjleFXi5.js +17 -0
- package/dist/sticker-vision.runtime.js +1 -1
- package/dist/subagent-announce-delivery-DS_2W9oZ.js +958 -0
- package/dist/subagent-announce-hatA_PZ2.js +354 -0
- package/dist/subagent-control-IyFIvc7T.js +508 -0
- package/dist/subagent-hooks-BCj5eB0Z.js +2 -0
- package/dist/subagent-hooks-BWjTBkox.js +146 -0
- package/dist/subagent-hooks-CdGLK9_3.js +230 -0
- package/dist/subagent-hooks-EH0tBkw9.js +2 -0
- package/dist/subagent-hooks-api-BhYaXQJV.js +23 -0
- package/dist/subagent-hooks-api-uGsV8Xn5.js +22 -0
- package/dist/subagent-hooks-api-wfJFKIPx.js +23 -0
- package/dist/subagent-hooks-l8Xd94dt.js +2 -0
- package/dist/subagent-hooks-m2eHUO_d.js +116 -0
- package/dist/subagent-orphan-recovery-Bq9zvX3L.js +352 -0
- package/dist/subagent-registry-Bcb3zy6b.js +3 -0
- package/dist/subagent-registry-CoZNTFx-.js +2351 -0
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-session-cleanup--00EjDLe.js +525 -0
- package/dist/subagent-spawn-ClJJkz3D.js +1164 -0
- package/dist/target-id-BsZLiF3x.js +107 -0
- package/dist/targets-CQMe4AZP.js +44 -0
- package/dist/targets-SmL1AU-H.js +19 -0
- package/dist/targets-Y-roiA47.js +19 -0
- package/dist/task-registry-control.runtime.js +1 -1
- package/dist/telegram/token.js +1 -1
- package/dist/testing-B5hNJDuF.js +267 -0
- package/dist/thread-bindings-BD3eE0kK.js +232 -0
- package/dist/thread-bindings-C9NNiv8K.js +571 -0
- package/dist/thread-bindings-Dl4PN1vZ.js +228 -0
- package/dist/thread-bindings-uK1LLAwy.js +8 -0
- package/dist/thread-bindings.discord-api-BHNEUbnk.js +187 -0
- package/dist/thread-bindings.manager-B0LXiH3F.js +2 -0
- package/dist/thread-bindings.manager-BTlH4XMG.js +536 -0
- package/dist/thread-lifecycle-DG8uyPHd.js +1614 -0
- package/dist/token-BbGCANnE.js +134 -0
- package/dist/tool-actions.runtime-oUUrD8HB.js +534 -0
- package/dist/tool-actions.runtime.js +1 -1
- package/dist/tool-bqg-_vYv.js +139 -0
- package/dist/tool-resolution-CSZsa3kP.js +149 -0
- package/dist/tools-effective-inventory-0CqFp-vq.js +204 -0
- package/dist/tools-invoke-http-DhYHY0Yh.js +67 -0
- package/dist/tools-invoke-shared-CbVJJUj7.js +200 -0
- package/dist/tts-C2qD-ad6.js +66 -0
- package/dist/tui-CzGY254f.js +4709 -0
- package/dist/tui-backend-fzoeoSN0.js +256 -0
- package/dist/tui-cli-B2RWb2gM.js +37 -0
- package/dist/tui-dgS8hdXU.js +2 -0
- package/dist/update-cli-BmiBDf3c.js +3664 -0
- package/dist/update-runner-CM7QVX6u.js +2379 -0
- package/dist/vision-tools-BzoBZnIc.js +1409 -0
- package/dist/web-search-DmfOd66S.js +62 -0
- package/dist/web-search-provider.runtime-3C5-pODD.js +328 -0
- package/dist/web-search-provider.runtime-Doh-Z9We.js +2 -0
- package/dist/web-search-provider.runtime.js +1 -1
- package/dist/xai-oauth-BLvQ43hx.js +479 -0
- package/dist/xai-user-agent-BdMQ_0_O.js +32 -0
- package/package.json +1 -1
- package/dist/abort-DeEb_wKd.js +0 -277
- package/dist/abort.runtime-CoYXQGPK.js +0 -2
- package/dist/account-inspect-D_06-CYS.js +0 -173
- package/dist/accounts-BCTqtj4Y.js +0 -107
- package/dist/accounts-BudLl8P2.js +0 -107
- package/dist/accounts-CUReBDA0.js +0 -2
- package/dist/accounts-PCioSzzr.js +0 -119
- package/dist/acp-runtime-B2t9_BHD.js +0 -26
- package/dist/acp-spawn-0x4Iiu1o.js +0 -2
- package/dist/acp-spawn-B2Ghe0jJ.js +0 -1275
- package/dist/acp-stateful-target-driver-C4VgcSyz.js +0 -89
- package/dist/action-kill-ClYsXEz7.js +0 -33
- package/dist/action-runtime-DrLPkNvU.js +0 -469
- package/dist/action-runtime-api-BqSflr9q.js +0 -2
- package/dist/action-send-CIy9cziD.js +0 -39
- package/dist/action-spawn-BjV6lFnX.js +0 -47
- package/dist/actions-D-QH7wq5.js +0 -161
- package/dist/actions.runtime-hzDtXQGU.js +0 -5
- package/dist/agent-Bb1DTBgv.js +0 -3
- package/dist/agent-Cnqj258q.js +0 -2
- package/dist/agent-command-BRx6ZNgJ.js +0 -1367
- package/dist/agent-components.runtime-D-g6xXJ0.js +0 -10
- package/dist/agent-harness-runtime-dKUQFuOc.js +0 -180
- package/dist/agent-harness-task-runtime-v2crUm3i.js +0 -140
- package/dist/agent-runner-execution-AOzdxvWR.js +0 -1713
- package/dist/agent-runner-utils-Byv50B4Z.js +0 -266
- package/dist/agent-runner.runtime-hhgRE0Z-.js +0 -3455
- package/dist/agent-runtime-BHmh3i0o.js +0 -229
- package/dist/agent-via-gateway-DnCqaK4a.js +0 -463
- package/dist/api-Bzyb8sFU.js +0 -3
- package/dist/api-CIEDFXZs.js +0 -2
- package/dist/api-D_dTQAu8.js +0 -2
- package/dist/api-DilBjZ9Q.js +0 -6
- package/dist/api-E5zoQMmh.js +0 -134
- package/dist/api-OJZug8gQ.js +0 -639
- package/dist/apply-C0eV5T0O.js +0 -41
- package/dist/apply-alsYvxLE.js +0 -54
- package/dist/approval-handler.runtime-C6jqZXSN.js +0 -130
- package/dist/assistant-DDXnAAB5.js +0 -291
- package/dist/attachment-normalize-Cv-_4DWU.js +0 -225
- package/dist/attempt-execution-DECEU59r.js +0 -558
- package/dist/attempt-execution.runtime-kasMxuER.js +0 -3
- package/dist/attempt-execution.shared-ClUxk52p.js +0 -38
- package/dist/attempt.prompt-helpers-Bxlv9VSu.js +0 -475
- package/dist/attempt.tool-run-context-CplQWX6g.js +0 -2094
- package/dist/binding-routing-0Obpp-Ij.js +0 -113
- package/dist/binding-targets-CZHQaZL4.js +0 -121
- package/dist/bot-BPbQ0840.js +0 -7894
- package/dist/bot-deps-Cs1M9USs.js +0 -2
- package/dist/bot-deps-xAcaOtTZ.js +0 -747
- package/dist/bot-message-context.runtime-Bji78Cbn.js +0 -7
- package/dist/bot-message-context.session.runtime-C3dyOIYH.js +0 -12
- package/dist/bot-native-commands.delivery.runtime-WshH99fy.js +0 -4
- package/dist/bot-native-commands.runtime-C1L364gU.js +0 -13
- package/dist/bridge-server-DPlM8_Lk.js +0 -113
- package/dist/browser-cli-DFNQE98N.js +0 -230
- package/dist/browser-cli-Drb5E5--.js +0 -2
- package/dist/browser-cli-actions-input-Dx-1OXmE.js +0 -473
- package/dist/browser-cli-actions-observe-BMDfE7xU.js +0 -81
- package/dist/browser-cli-debug-nu7Ih09g.js +0 -137
- package/dist/browser-cli-inspect-D5X2wohg.js +0 -104
- package/dist/browser-cli-manage-DkzYwph4.js +0 -443
- package/dist/browser-cli-resize-B30Avedl.js +0 -26
- package/dist/browser-cli-shared-cMgQoQzF.js +0 -50
- package/dist/browser-cli-state-CQLDvDy7.js +0 -337
- package/dist/browser-control-auth-D7ArmHUt.js +0 -2
- package/dist/browser-profiles-B39SIZNb.js +0 -2
- package/dist/browser-runtime-DUbSAOOS.js +0 -384
- package/dist/build-D25KqC92.js +0 -257
- package/dist/capability-cli-CuyXrlAB.js +0 -1782
- package/dist/channel-0N3YGMGg.js +0 -1496
- package/dist/channel-1UyKoLyp.js +0 -481
- package/dist/channel-BG87pSEW.js +0 -740
- package/dist/channel-BPGSaZW7.js +0 -1249
- package/dist/channel-BQMPh1J_.js +0 -376
- package/dist/channel-Bd_8V6zn.js +0 -1134
- package/dist/channel-BtBjh_ij.js +0 -362
- package/dist/channel-CpFBlVH6.js +0 -562
- package/dist/channel-CwuTrIrF.js +0 -508
- package/dist/channel-Cxl4sJA-.js +0 -1777
- package/dist/channel-D-VfU4Z2.js +0 -2126
- package/dist/channel-D9q8aYrN.js +0 -867
- package/dist/channel-DKSvVvZh.js +0 -238
- package/dist/channel-DvoFfWLx.js +0 -808
- package/dist/channel-GktTcGHm.js +0 -955
- package/dist/channel-actions.runtime-CKcRA0GW.js +0 -265
- package/dist/channel-core-nm8s1qFZ.js +0 -5
- package/dist/channel-d3t2ESlE.js +0 -653
- package/dist/channel-inbound-DKz40dq-.js +0 -80
- package/dist/channel-plugin-runtime-DKIGZWfW.js +0 -998
- package/dist/channel-runtime-Bh8_GY12.js +0 -408
- package/dist/channel-yQ8jCOb9.js +0 -1556
- package/dist/channel.runtime-BG4mM5cQ.js +0 -652
- package/dist/channel.runtime-BS6PyFFa.js +0 -1008
- package/dist/channel.runtime-CE_xECqN.js +0 -88
- package/dist/channel.runtime-Cd1Sw8U4.js +0 -254
- package/dist/channel.runtime-DIq3XOEe.js +0 -733
- package/dist/channel.runtime-Dy1cx35I.js +0 -21009
- package/dist/channel.runtime-NyIMjLnP.js +0 -109
- package/dist/channel.runtime-Zx5mfE2V.js +0 -4
- package/dist/channel.runtime-rJRibGfN.js +0 -2528
- package/dist/channel.setup--4ACadmF.js +0 -10
- package/dist/channel.setup-DzwqIlo3.js +0 -1098
- package/dist/channel.setup-FKYSJwXR.js +0 -343
- package/dist/chat-CKxSm7r1.js +0 -2666
- package/dist/chrome-rMubJwRG.js +0 -1503
- package/dist/cli-CbTod55I.js +0 -1341
- package/dist/cli-compaction-BbHgjJyW.js +0 -347
- package/dist/cli-metadata-DkOWLC_p.js +0 -22
- package/dist/cli-runner-Cwzv_RKf.js +0 -540
- package/dist/cli-runner-DdnUsgPl.js +0 -2
- package/dist/cli-runner.runtime-BlrSgbEW.js +0 -3
- package/dist/cli-runner.runtime-D8kVfvFH.js +0 -4
- package/dist/client-ClvxsWgL.js +0 -650
- package/dist/client-adapter-CsrIIjK1.js +0 -897
- package/dist/client-factory-DAYClhwm.js +0 -9
- package/dist/command-auth-CCha2ofd.js +0 -135
- package/dist/command-handlers-DCWJzHyB.js +0 -1609
- package/dist/command-registry-BIf61QNz.js +0 -9
- package/dist/command-registry-DJROBy4h.js +0 -4
- package/dist/command-registry-core-BQOWqi6S.js +0 -110
- package/dist/command-status.runtime-D88CUglL.js +0 -90
- package/dist/commands-acp-B-8dHX4Z.js +0 -74
- package/dist/commands-compact.runtime-ComX5mUk.js +0 -10
- package/dist/commands-handlers.runtime-DR3wjXHX.js +0 -6154
- package/dist/commands-status-CDyGrwsI.js +0 -3
- package/dist/commands-status-DV-i_ZIK.js +0 -16
- package/dist/commands-status.runtime-CDyGrwsI.js +0 -3
- package/dist/commands-subagents-control.runtime-B029cXAS.js +0 -3
- package/dist/commands-subagents-control.runtime-DR8Qspe0.js +0 -2
- package/dist/commands-system-prompt-C10ctsG3.js +0 -162
- package/dist/commands-system-prompt-DQlRWwnk.js +0 -2
- package/dist/commands.runtime-BYmIAuN0.js +0 -176
- package/dist/compact-14Ljaaeu.js +0 -480
- package/dist/compact-B--ovdkx.js +0 -1141
- package/dist/compact.runtime-E0Idf2Dq.js +0 -12
- package/dist/completion-cli-DMvvQGSk.js +0 -315
- package/dist/computer-use-CcLwX5SR.js +0 -367
- package/dist/config-B39SIZNb.js +0 -2
- package/dist/config-D4rsGOyV.js +0 -373
- package/dist/config-mutations-CsI3YJu7.js +0 -159
- package/dist/context-engine-host-compat-BZpDFiMJ.js +0 -2
- package/dist/context-engine-host-compat-runUdES5.js +0 -288
- package/dist/context-engine-lifecycle-D6odtNrn.js +0 -1274
- package/dist/control-auth-BPGpPtfz.js +0 -114
- package/dist/control-service-C-OmdPCe.js +0 -145
- package/dist/control-ui/assets/agents-GeyOHPuW.js +0 -1008
- package/dist/control-ui/assets/channel-config-extras-D7en6iUg.js +0 -2
- package/dist/control-ui/assets/channels-DkEyr1w5.js +0 -367
- package/dist/control-ui/assets/cron-C-wThQ1Q.js +0 -1013
- package/dist/control-ui/assets/debug-83AFRtIX.js +0 -97
- package/dist/control-ui/assets/index-CiGEhMOA.js +0 -7370
- package/dist/control-ui/assets/instances-CVl0t-1h.js +0 -57
- package/dist/control-ui/assets/logs-eybVEXxg.js +0 -74
- package/dist/control-ui/assets/nodes-C_A7eoU2.js +0 -436
- package/dist/control-ui/assets/sessions-Cq4Nc69u.js +0 -399
- package/dist/control-ui/assets/skills-ZN6hroIh.js +0 -314
- package/dist/control-ui/assets/skills-shared-DIWGwmdC.js +0 -11
- package/dist/conversation-binding-runtime-C2U1JElL.js +0 -4
- package/dist/conversation-runtime-NmIUd3Zu.js +0 -31
- package/dist/core-DGKJP1dm.js +0 -282
- package/dist/core-api-1fA4sNeC.js +0 -5
- package/dist/core-api-BY822Quq.js +0 -2
- package/dist/crestodian-Bp-NXiBC.js +0 -55
- package/dist/daocore-tools-Defpam0j.js +0 -11727
- package/dist/delivery-CEdVAUGB.js +0 -1002
- package/dist/dialogue-CZ69INPq.js +0 -37
- package/dist/dir-fetch-tool-BCicHhQE.js +0 -565
- package/dist/dir-list-tool-Cv_WktsJ.js +0 -100
- package/dist/direct-dm-Bz89rM8x.js +0 -64
- package/dist/directive-handling.fast-lane-DDnbcc5S.js +0 -68
- package/dist/directive-handling.impl-B0H52Ymr.js +0 -818
- package/dist/directive-handling.impl-CgKpwEW-.js +0 -2
- package/dist/directive-handling.model-selection-_cXAr0vt.js +0 -122
- package/dist/directive-handling.persist.runtime-Dw0mfzXT.js +0 -263
- package/dist/dispatch-C3AeYvyP.js +0 -1640
- package/dist/dispatch-acp-transcript.runtime-CP8pqBwS.js +0 -40
- package/dist/dispatch-acp.runtime-Cdap-AZI.js +0 -18
- package/dist/doctor-BZwVH97p.js +0 -2
- package/dist/doctor-BfkGBii1.js +0 -6
- package/dist/doctor-config-flow-D3JASGDt.js +0 -1741
- package/dist/doctor-core-checks-DH5AIT0Q.js +0 -573
- package/dist/doctor-core-checks-DiNu7VSh.js +0 -2
- package/dist/doctor-health-BDIJ-Nro.js +0 -65
- package/dist/doctor-health-contributions-BgmF7w8X.js +0 -696
- package/dist/doctor-lint-uIxkMUSO.js +0 -94
- package/dist/doctor-state-integrity-ws1b_BGk.js +0 -1231
- package/dist/doctor-update-Cx4CqxaX.js +0 -58
- package/dist/dynamic-tools-DiqOxhJh.js +0 -486
- package/dist/embedded-backend-C634irMl.js +0 -579
- package/dist/embedded-gateway-stub.runtime-CCfrTOeN.js +0 -12
- package/dist/exec-approvals-D85KThSg.js +0 -149
- package/dist/file-fetch-tool-BERaGYCT.js +0 -124
- package/dist/file-write-tool-BjHrMyfe.js +0 -127
- package/dist/format-DE9PuPg1.js +0 -1145
- package/dist/gateway-cli-B5hjhbUy.js +0 -435
- package/dist/gateway-method-runtime-Bu0E9Eki.js +0 -21
- package/dist/get-reply-6PtPz9hv.js +0 -4689
- package/dist/get-reply-from-config.runtime-CwprvhoR.js +0 -2
- package/dist/graph-users-DUp1kgnS.js +0 -1419
- package/dist/group-access-D5GBQ3w6.js +0 -112
- package/dist/handle-action.guild-admin-CA0Y-buD.js +0 -288
- package/dist/harness-B5nOFVfm.js +0 -61
- package/dist/health-D5heIDj3.js +0 -4
- package/dist/heartbeat-runner-BzFkIFHh.js +0 -5
- package/dist/heartbeat-runner.runtime-p6H1_xMV.js +0 -4
- package/dist/hooks-BvTyQ14X.js +0 -534
- package/dist/inbound-direct-dm-runtime-DwiDXi8L.js +0 -2
- package/dist/inbound-reply-dispatch-YoDUOC6C.js +0 -148
- package/dist/init-CPtcV5Xu.js +0 -59
- package/dist/inline-buttons-DeD5d42c.js +0 -40
- package/dist/internal-events-DEb50Sw3.js +0 -90
- package/dist/isolated-agent-CcxFFZ-Z.js +0 -1118
- package/dist/isolated-agent-CpHzq5qr.js +0 -2
- package/dist/lifecycle-DNel-oMe.js +0 -571
- package/dist/list.probe-DCa3N25d.js +0 -449
- package/dist/list.status-command-CyeAJmZW.js +0 -789
- package/dist/llm-slug-generator-CyqTY37Z.js +0 -78
- package/dist/local-dispatch.runtime-nE39kFIP.js +0 -9
- package/dist/manager.runtime-CpAPB8D5.js +0 -2714
- package/dist/markdown-to-line-Ci6TRmoZ.js +0 -811
- package/dist/mcp-http-BR0vmxFL.js +0 -2
- package/dist/mcp-http-C0oniA8h.js +0 -555
- package/dist/media-understanding-provider-BwA0XqC3.js +0 -339
- package/dist/message-actions-C9C_Ngkd.js +0 -145
- package/dist/message-handler-CUUKPC5n.js +0 -384
- package/dist/message-handler-xRTfIXWV.js +0 -1715
- package/dist/message-handler.preflight-Ch2Q7V3M.js +0 -1125
- package/dist/message-handler.process-HM3mK93q.js +0 -1484
- package/dist/model-CB8Ex5xS.js +0 -74
- package/dist/model-selection-2s0Dinux.js +0 -272
- package/dist/models-Cn-6DJ41.js +0 -2
- package/dist/models-CzszJD__.js +0 -104
- package/dist/models-cli-CbhElnA5.js +0 -256
- package/dist/monitor-7aprTsMV.js +0 -715
- package/dist/monitor-BuVhqwDS.js +0 -1370
- package/dist/monitor-C4H_YkgY.js +0 -2
- package/dist/monitor-CPQsMxgv.js +0 -1657
- package/dist/monitor-Ce0V1PiR.js +0 -4377
- package/dist/monitor-D0bcGJWI.js +0 -60
- package/dist/monitor-DEjlJqzh.js +0 -834
- package/dist/monitor-auth-DjJZsjgV.js +0 -179
- package/dist/monitor-ikSYagv3.js +0 -2788
- package/dist/monitor-polling.runtime-D7yEflMM.js +0 -883
- package/dist/monitor-webhook.runtime-CIZt-biI.js +0 -387
- package/dist/monitor.account-C2sMOBCS.js +0 -5233
- package/dist/monitor.runtime-BAi6zmcn.js +0 -2
- package/dist/monitor.webhook-BcjpfRCX.js +0 -180
- package/dist/node-cli-sessions-CIhkJRU4.js +0 -1228
- package/dist/openai-http-Dj21RwSj.js +0 -824
- package/dist/openresponses-http-COnnr1ox.js +0 -1173
- package/dist/operations-H3vUh0lM.js +0 -805
- package/dist/outbound-adapter-WLtWE7wv.js +0 -543
- package/dist/outbound-session-route-CZtd64EH.js +0 -45
- package/dist/outbound.runtime-D98P0sN1.js +0 -2
- package/dist/pi-embedded-BWJzd4mK.js +0 -4
- package/dist/pi-embedded-DeNsSqQQ.js +0 -3796
- package/dist/pi-embedded.runtime-CZnNwFpc.js +0 -4
- package/dist/pi-tools-CNHSpjBa.js +0 -2413
- package/dist/plan-B0reFFlM.js +0 -81
- package/dist/plan-CrfF-TH8.js +0 -112
- package/dist/plugin-DI_8eYOe.js +0 -12396
- package/dist/plugin-app-cache-key-WaTUD3e-.js +0 -46
- package/dist/plugin-enabled-aWLXgGGi.js +0 -233
- package/dist/plugin-registration-ByjRIVJm.js +0 -88
- package/dist/plugin-service-VQm_241d.js +0 -1229
- package/dist/policy-BmJH-swe.js +0 -680
- package/dist/policy-DE-bO1zn.js +0 -138
- package/dist/prepare.runtime-bSj3-res.js +0 -732
- package/dist/preview-warnings-CbuGYsF9.js +0 -392
- package/dist/probe-C_rWg7_m.js +0 -682
- package/dist/probe-CagOFfx6.js +0 -2
- package/dist/probe-thX1HqOh.js +0 -2204
- package/dist/probe-zU6B6gFt.js +0 -47
- package/dist/program-BtVdH743.js +0 -131
- package/dist/provider-CDoD7tO0.js +0 -8735
- package/dist/provider-CK1gMdJ2.js +0 -32
- package/dist/provider-DJqr9djy.js +0 -32
- package/dist/provider-DsOJp5bK.js +0 -152
- package/dist/provider-dispatcher-UNQ-LSx9.js +0 -22
- package/dist/provider-session.runtime-DMrkMb4x.js +0 -9
- package/dist/provider.runtime-C2-t3zm8.js +0 -2
- package/dist/public-surface-loader-hTeyyHcd.js +0 -114
- package/dist/pw-ai-BaL3eVYx.js +0 -3029
- package/dist/pw-role-snapshot-DKeBqhN1.js +0 -333
- package/dist/reaction-level-BV2potsD.js +0 -19
- package/dist/reaction-runtime-api-CCBxgM10.js +0 -116
- package/dist/realtime-transcription-provider-CHYtIXZm.js +0 -205
- package/dist/register-BJf28G9B.js +0 -2178
- package/dist/register.agent-oXAHwNQv.js +0 -156
- package/dist/register.crestodian-CQ0sqdV2.js +0 -24
- package/dist/register.maintenance-CylVRs5M.js +0 -83
- package/dist/register.runtime-CcDgwy0X.js +0 -54
- package/dist/register.subclis-CpBYNw2X.js +0 -3
- package/dist/register.subclis-N2CvieOL.js +0 -31
- package/dist/register.subclis-core-BHaGvbzg.js +0 -273
- package/dist/repair-sequencing-EBBnBdIB.js +0 -640
- package/dist/reply-delivery-BLoPALlI.js +0 -196
- package/dist/reply-runtime-D4asNTSa.js +0 -11
- package/dist/reply.runtime-CwprvhoR.js +0 -2
- package/dist/request-DlWPRUDt.js +0 -54
- package/dist/resolve-allowlist-BukQf58x.js +0 -220
- package/dist/result-fallback-classifier-DyHFnqfV.js +0 -79
- package/dist/route-BMf4keN5.js +0 -469
- package/dist/route-resolution-DWNi1QAu.js +0 -274
- package/dist/routes-C20LC8c4.js +0 -3602
- package/dist/routes-CkK7Vv_m.js +0 -2
- package/dist/run-KDF_AEza.js +0 -1162
- package/dist/run-attempt-JHYCfonU.js +0 -7704
- package/dist/run-command-3PVihYIy.js +0 -2
- package/dist/run-command-QHAXnyKY.js +0 -23
- package/dist/run-embedded.runtime-BJw-2vss.js +0 -4
- package/dist/run-execution-cli.runtime-GHClMn2g.js +0 -4
- package/dist/run-subagent-registry.runtime-BLLMrhtE.js +0 -2
- package/dist/runtime-C2u-dC1r.js +0 -1287
- package/dist/runtime-ClyfkDWT.js +0 -6179
- package/dist/runtime-WXCarlPc.js +0 -438
- package/dist/runtime-api-3QhGLpZf.js +0 -13
- package/dist/runtime-api-DRAu3mjv.js +0 -4
- package/dist/runtime-api-JE07pOem.js +0 -13
- package/dist/runtime-api-JuKylHvw.js +0 -24
- package/dist/runtime-api-bcbk4yax.js +0 -21
- package/dist/runtime-api-dDe9U2_V.js +0 -17
- package/dist/runtime-api-uMexLqGS.js +0 -3
- package/dist/runtime-api.actions-Bo7TLDFl.js +0 -3
- package/dist/runtime-api.monitor-7q78L1Em.js +0 -6
- package/dist/runtime-api.send-Bf9RR4nV.js +0 -4
- package/dist/runtime-api.threads-Dj2QuhHj.js +0 -2
- package/dist/runtime-channel-k1C0Satl.js +0 -2
- package/dist/runtime-channel-qt9t0J-J.js +0 -150
- package/dist/runtime-embedded-pi.runtime-BPB9NlTS.js +0 -2
- package/dist/sanitize-outbound-BLH_SQvg.js +0 -127
- package/dist/sdk-setup-tools-BshlBPau.js +0 -8
- package/dist/secrets-CsHXv7d3.js +0 -113
- package/dist/security-audit-CUXBQXNX.js +0 -122
- package/dist/security-audit-CzdXbRma.js +0 -118
- package/dist/security-audit.runtime-Ca0FMFJG.js +0 -2
- package/dist/selection-BmvQJlSD.js +0 -3
- package/dist/selection-BplDXc9w.js +0 -16157
- package/dist/send--qFg8a9v.js +0 -1631
- package/dist/send-BPdryPPA.js +0 -192
- package/dist/send-Bl4YaRkS.js +0 -143
- package/dist/send-Ccm7RMXC.js +0 -2
- package/dist/send.components-c3OUPSmR.js +0 -2
- package/dist/send.components-rhQJYoXs.js +0 -500
- package/dist/send.runtime-dfUkAp5d.js +0 -2
- package/dist/server-DRhyTMLe.js +0 -73
- package/dist/server-Dv4BzjGn.js +0 -24
- package/dist/server-context-4HRJy2vp.js +0 -955
- package/dist/server-context-DlxYb1G5.js +0 -2
- package/dist/server-cron-Bt8Pkc3i.js +0 -2989
- package/dist/server-cron-CtNWsa4Z.js +0 -2
- package/dist/server-methods-rye_okUW.js +0 -16494
- package/dist/server-node-events-C1yZ5a1u.js +0 -596
- package/dist/server-plugin-bootstrap-DUMyVtlP.js +0 -70
- package/dist/server-plugins-B5ZWWkRE.js +0 -432
- package/dist/server-reload-handlers-CTnMXNjT.js +0 -714
- package/dist/server-restart-sentinel-CAYxtwmY.js +0 -747
- package/dist/server-restart-sentinel-DqrtSIvy.js +0 -2
- package/dist/server-runtime-services-CuptQTe5.js +0 -2
- package/dist/server-runtime-services-aaS2IiW3.js +0 -267
- package/dist/server-startup-plugins-D0ymJgQT.js +0 -113
- package/dist/server-startup-post-attach-DlrN2uyt.js +0 -716
- package/dist/server-ws-runtime-CdpLbv4o.js +0 -349
- package/dist/server.impl-Cb4qcMTg.js +0 -2586
- package/dist/service-qxvDlMQE.js +0 -1446
- package/dist/session-binding-6bLobLHL.js +0 -219
- package/dist/session-binding-Bm6fCpoY.js +0 -2
- package/dist/session-kill-http-B6WjVo8V.js +0 -121
- package/dist/session-reset-service-GUVIhxp4.js +0 -625
- package/dist/session-route-BcRDnvzG.js +0 -93
- package/dist/session-status.runtime-BcjOunV4.js +0 -2
- package/dist/session-subagent-reactivation.runtime-BSmk_KYn.js +0 -2
- package/dist/session-tab-registry-BBYzbSOu.js +0 -521
- package/dist/sessions-history-http-bLJJfgLm.js +0 -430
- package/dist/sessions.runtime-DNRtQzCk.js +0 -2
- package/dist/setup-api-CcolVVJs.js +0 -29
- package/dist/setup-core-eJD18F3B.js +0 -174
- package/dist/setup-surface-B75C2Qtz.js +0 -221
- package/dist/setup-surface-CFuPfVHp.js +0 -405
- package/dist/setup-surface-Dyy-Mzyz.js +0 -288
- package/dist/setup-surface-ZsVF_g8W.js +0 -320
- package/dist/shared-BkCNrcLX.js +0 -121
- package/dist/shared-client-B7zqC9p2.js +0 -2
- package/dist/shared-client-yXjKgZBz.js +0 -629
- package/dist/side-question-DU3gESCb.js +0 -683
- package/dist/skill-tool-dispatch.runtime-CPBuqyvk.js +0 -143
- package/dist/slash-state-Do3bAahA.js +0 -2166
- package/dist/speech-provider-Bg9los3C.js +0 -184
- package/dist/src-D7LzUctH.js +0 -4256
- package/dist/startup-context-CCF2gIOl.js +0 -313
- package/dist/status-subagents.runtime-DX5FTymp.js +0 -18
- package/dist/status-text-B-1u5dSV.js +0 -296
- package/dist/sticker-cache-DwpU_9RJ.js +0 -206
- package/dist/sticker-vision.runtime-Bbldi_YL.js +0 -17
- package/dist/subagent-announce-BCo0VHVL.js +0 -354
- package/dist/subagent-announce-delivery-JcnuDN_N.js +0 -958
- package/dist/subagent-control-BzbA3Suz.js +0 -508
- package/dist/subagent-hooks-BIGZQWrG.js +0 -2
- package/dist/subagent-hooks-Bj4qYZfv.js +0 -230
- package/dist/subagent-hooks-C-rvhVBv.js +0 -2
- package/dist/subagent-hooks-P01_AFl5.js +0 -116
- package/dist/subagent-hooks-VEfak8nl.js +0 -2
- package/dist/subagent-hooks-api-BPnSxxN4.js +0 -23
- package/dist/subagent-hooks-api-DwIAvMoS.js +0 -22
- package/dist/subagent-hooks-api-kgyR9FOb.js +0 -23
- package/dist/subagent-hooks-oED56wqq.js +0 -146
- package/dist/subagent-orphan-recovery-D79ZzwKN.js +0 -352
- package/dist/subagent-registry-D0soBT5j.js +0 -2351
- package/dist/subagent-registry-DRJDkmty.js +0 -3
- package/dist/subagent-session-cleanup-9eAO1aJe.js +0 -525
- package/dist/subagent-spawn-D80vbogm.js +0 -1164
- package/dist/target-id-COLv5LsJ.js +0 -107
- package/dist/targets-CDW5IQ6a.js +0 -44
- package/dist/targets-Ci6O1ZdP.js +0 -19
- package/dist/targets-CsaWFBg1.js +0 -19
- package/dist/testing-BoJit-h1.js +0 -267
- package/dist/thread-bindings-CGCvw0KT.js +0 -571
- package/dist/thread-bindings-ClCTNacX.js +0 -228
- package/dist/thread-bindings-DRb7BMZ6.js +0 -8
- package/dist/thread-bindings-Xc6smav0.js +0 -232
- package/dist/thread-bindings.discord-api-DC467oeF.js +0 -187
- package/dist/thread-bindings.manager-C_mpTDIZ.js +0 -536
- package/dist/thread-bindings.manager-DkCRs612.js +0 -2
- package/dist/thread-lifecycle-DpqCXlx9.js +0 -1614
- package/dist/token-CI6HjbTA.js +0 -134
- package/dist/tool-BMe7hjBK.js +0 -139
- package/dist/tool-actions.runtime-D-h5PI_m.js +0 -534
- package/dist/tool-resolution-CnLx0CHe.js +0 -149
- package/dist/tools-effective-inventory-BR6MUMtE.js +0 -204
- package/dist/tools-invoke-http-CTTs2yMT.js +0 -67
- package/dist/tools-invoke-shared-9B1EjXWf.js +0 -200
- package/dist/tts-eGOviZ5c.js +0 -66
- package/dist/tui-Bw0HqKd7.js +0 -4709
- package/dist/tui-CIZJnPzj.js +0 -2
- package/dist/tui-backend-BJ_r7tcF.js +0 -256
- package/dist/tui-cli-BaSMBpuA.js +0 -37
- package/dist/update-cli-zuCybGNR.js +0 -3664
- package/dist/update-runner-Dek2BHmQ.js +0 -2379
- package/dist/vision-tools-1ps0BEE5.js +0 -1409
- package/dist/web-search-B7EziZXE.js +0 -62
- package/dist/web-search-provider.runtime-DGTCvGch.js +0 -328
- package/dist/web-search-provider.runtime-DWL5t39M.js +0 -2
- package/dist/xai-oauth-CRtsj2Gs.js +0 -479
- package/dist/xai-user-agent-Dndwzw2S.js +0 -32
- /package/dist/{acp-runtime-backend-DSDBcyh9.js → acp-runtime-backend-Cxo7eBHf.js} +0 -0
- /package/dist/{channel-actions-FV66JqtI.js → channel-actions-UDeVjgGz.js} +0 -0
- /package/dist/{command-status-runtime-BRWKSoG7.js → command-status-runtime-CoHd4Fws.js} +0 -0
- /package/dist/{delegate-DGqKhwB4.js → delegate-B-2xZ77o.js} +0 -0
- /package/dist/{dispatch-acp-Ceoxja_Z.js → dispatch-acp-DLPkmK7K.js} +0 -0
- /package/dist/{heartbeat-runner-CJHvr5pG.js → heartbeat-runner-D2j6JwOI.js} +0 -0
- /package/dist/{library-Bq3aDek_.js → library-DBT0cIPP.js} +0 -0
- /package/dist/{run-executor.runtime-DNJhGPbA.js → run-executor.runtime-DE4J7f4M.js} +0 -0
- /package/dist/{shared-CYxmRpq1.js → shared-xeo8Yh5n.js} +0 -0
|
@@ -0,0 +1,1409 @@
|
|
|
1
|
+
import { i as emitTrustedDiagnosticEvent } from "./diagnostic-events-DPfGiEBK.js";
|
|
2
|
+
import { _ as buildAgentHookContextChannelFields } from "./attempt.prompt-helpers-CUqKtIa5.js";
|
|
3
|
+
import { u as runBeforeToolCallHook } from "./pi-tools.before-tool-call-Cl9Ivz5u.js";
|
|
4
|
+
import { t as callGatewayTool } from "./gateway-Dyc7qEu3.js";
|
|
5
|
+
import { t as log } from "./logger-DYJ7BvAc.js";
|
|
6
|
+
import { t as formatApprovalDisplayPath } from "./approval-display-paths-BqRczx-P.js";
|
|
7
|
+
import "./agent-harness-runtime-Dq1fCBOM.js";
|
|
8
|
+
import { n as hasNativeHookRelayInvocation, r as invokeNativeHookRelay } from "./native-hook-relay-D1fhxt1n.js";
|
|
9
|
+
import { t as isJsonObject } from "./protocol-oeJQu4rs.js";
|
|
10
|
+
import { s as formatCodexDisplayText } from "./notification-correlation-qKY_sgga.js";
|
|
11
|
+
import { createHash } from "node:crypto";
|
|
12
|
+
//#region extensions/codex/src/app-server/plugin-approval-roundtrip.ts
|
|
13
|
+
const DEFAULT_CODEX_APPROVAL_TIMEOUT_MS = 12e4;
|
|
14
|
+
const MAX_PLUGIN_APPROVAL_TITLE_LENGTH = 80;
|
|
15
|
+
const MAX_PLUGIN_APPROVAL_DESCRIPTION_LENGTH = 256;
|
|
16
|
+
async function requestPluginApproval(params) {
|
|
17
|
+
const timeoutMs = DEFAULT_CODEX_APPROVAL_TIMEOUT_MS;
|
|
18
|
+
return callGatewayTool("plugin.approval.request", { timeoutMs: 13e4 }, {
|
|
19
|
+
pluginId: "daocore-codex-app-server",
|
|
20
|
+
title: truncateForGateway(params.title, MAX_PLUGIN_APPROVAL_TITLE_LENGTH),
|
|
21
|
+
description: truncateForGateway(params.description, MAX_PLUGIN_APPROVAL_DESCRIPTION_LENGTH),
|
|
22
|
+
severity: params.severity,
|
|
23
|
+
toolName: params.toolName,
|
|
24
|
+
toolCallId: params.toolCallId,
|
|
25
|
+
agentId: params.paramsForRun.agentId,
|
|
26
|
+
sessionKey: params.paramsForRun.sessionKey,
|
|
27
|
+
turnSourceChannel: params.paramsForRun.messageChannel ?? params.paramsForRun.messageProvider,
|
|
28
|
+
turnSourceTo: params.paramsForRun.currentChannelId,
|
|
29
|
+
turnSourceAccountId: params.paramsForRun.agentAccountId,
|
|
30
|
+
turnSourceThreadId: params.paramsForRun.currentThreadTs,
|
|
31
|
+
timeoutMs,
|
|
32
|
+
twoPhase: true
|
|
33
|
+
}, { expectFinal: false });
|
|
34
|
+
}
|
|
35
|
+
function approvalRequestExplicitlyUnavailable(result) {
|
|
36
|
+
if (result === null || result === void 0 || typeof result !== "object") return false;
|
|
37
|
+
let descriptor;
|
|
38
|
+
try {
|
|
39
|
+
descriptor = Object.getOwnPropertyDescriptor(result, "decision");
|
|
40
|
+
} catch {
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
return descriptor !== void 0 && "value" in descriptor && descriptor.value === null;
|
|
44
|
+
}
|
|
45
|
+
async function waitForPluginApprovalDecision(params) {
|
|
46
|
+
const waitPromise = callGatewayTool("plugin.approval.waitDecision", { timeoutMs: 13e4 }, { id: params.approvalId });
|
|
47
|
+
if (!params.signal) return (await waitPromise)?.decision;
|
|
48
|
+
let onAbort;
|
|
49
|
+
const abortPromise = new Promise((_, reject) => {
|
|
50
|
+
if (params.signal.aborted) {
|
|
51
|
+
reject(params.signal.reason);
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
onAbort = () => reject(params.signal.reason);
|
|
55
|
+
params.signal.addEventListener("abort", onAbort, { once: true });
|
|
56
|
+
});
|
|
57
|
+
try {
|
|
58
|
+
return (await Promise.race([waitPromise, abortPromise]))?.decision;
|
|
59
|
+
} finally {
|
|
60
|
+
if (onAbort) params.signal.removeEventListener("abort", onAbort);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
function mapExecDecisionToOutcome(decision) {
|
|
64
|
+
if (decision === "allow-once") return "approved-once";
|
|
65
|
+
if (decision === "allow-always") return "approved-session";
|
|
66
|
+
if (decision === null || decision === void 0) return "unavailable";
|
|
67
|
+
return "denied";
|
|
68
|
+
}
|
|
69
|
+
function truncateForGateway(value, maxLength) {
|
|
70
|
+
return value.length <= maxLength ? value : `${value.slice(0, Math.max(0, maxLength - 3))}...`;
|
|
71
|
+
}
|
|
72
|
+
//#endregion
|
|
73
|
+
//#region extensions/codex/src/app-server/approval-bridge.ts
|
|
74
|
+
const PERMISSION_DESCRIPTION_MAX_LENGTH = 700;
|
|
75
|
+
const PERMISSION_SAMPLE_LIMIT = 2;
|
|
76
|
+
const PERMISSION_VALUE_MAX_LENGTH = 48;
|
|
77
|
+
const COMMAND_PREVIEW_WITH_DETAILS_MAX_LENGTH = 80;
|
|
78
|
+
const APPROVAL_PREVIEW_SCAN_MAX_LENGTH = 4096;
|
|
79
|
+
const APPROVAL_PREVIEW_OMITTED = "[preview truncated or unsafe content omitted]";
|
|
80
|
+
const ANSI_OSC_SEQUENCE_RE$1 = new RegExp(String.raw`(?:\u001b]|\u009d)[^\u001b\u009c\u0007]*(?:\u0007|\u001b\\|\u009c)`, "g");
|
|
81
|
+
const ANSI_CONTROL_SEQUENCE_RE$1 = new RegExp(String.raw`(?:\u001b\[[0-?]*[ -/]*[@-~]|\u009b[0-?]*[ -/]*[@-~]|\u001b[@-Z\\-_])`, "g");
|
|
82
|
+
const CONTROL_CHARACTER_RE$1 = new RegExp(String.raw`[\u0000-\u001f\u007f-\u009f]+`, "g");
|
|
83
|
+
const INVISIBLE_FORMATTING_CONTROL_RE$1 = new RegExp(String.raw`[\u00ad\u034f\u061c\u200b-\u200f\u202a-\u202e\u2060-\u206f\ufeff\ufe00-\ufe0f\u{e0100}-\u{e01ef}]`, "gu");
|
|
84
|
+
const DANGLING_TERMINAL_SEQUENCE_SUFFIX_RE$1 = new RegExp(String.raw`(?:\u001b\][^\u001b\u009c\u0007]*|\u009d[^\u001b\u009c\u0007]*|\u001b\[[0-?]*[ -/]*|\u009b[0-?]*[ -/]*|\u001b)$`);
|
|
85
|
+
async function handleCodexAppServerApprovalRequest(params) {
|
|
86
|
+
const requestParams = isJsonObject(params.requestParams) ? params.requestParams : void 0;
|
|
87
|
+
if (!matchesCurrentTurn(requestParams, params.threadId, params.turnId)) return;
|
|
88
|
+
if (!isSupportedAppServerApprovalMethod(params.method)) return unsupportedApprovalResponse();
|
|
89
|
+
const context = buildApprovalContext({
|
|
90
|
+
method: params.method,
|
|
91
|
+
requestParams,
|
|
92
|
+
paramsForRun: params.paramsForRun
|
|
93
|
+
});
|
|
94
|
+
try {
|
|
95
|
+
const policyOutcome = await runDaoCoreToolPolicyForApprovalRequest({
|
|
96
|
+
method: params.method,
|
|
97
|
+
requestParams,
|
|
98
|
+
paramsForRun: params.paramsForRun,
|
|
99
|
+
context,
|
|
100
|
+
nativeHookRelay: params.nativeHookRelay,
|
|
101
|
+
signal: params.signal
|
|
102
|
+
});
|
|
103
|
+
if (policyOutcome?.outcome === "denied") {
|
|
104
|
+
emitApprovalEvent(params.paramsForRun, {
|
|
105
|
+
phase: "resolved",
|
|
106
|
+
kind: context.kind,
|
|
107
|
+
status: "denied",
|
|
108
|
+
title: context.title,
|
|
109
|
+
...context.eventDetails,
|
|
110
|
+
...approvalEventScope(params.method, "denied"),
|
|
111
|
+
message: policyOutcome.reason
|
|
112
|
+
});
|
|
113
|
+
return buildApprovalResponse(params.method, context.requestParams, "denied");
|
|
114
|
+
}
|
|
115
|
+
const requestResult = await requestPluginApproval({
|
|
116
|
+
paramsForRun: params.paramsForRun,
|
|
117
|
+
title: context.title,
|
|
118
|
+
description: context.description,
|
|
119
|
+
severity: context.severity,
|
|
120
|
+
toolName: context.toolName,
|
|
121
|
+
toolCallId: context.itemId
|
|
122
|
+
});
|
|
123
|
+
const approvalId = requestResult?.id;
|
|
124
|
+
if (!approvalId) {
|
|
125
|
+
emitApprovalEvent(params.paramsForRun, {
|
|
126
|
+
phase: "resolved",
|
|
127
|
+
kind: context.kind,
|
|
128
|
+
status: "unavailable",
|
|
129
|
+
title: context.title,
|
|
130
|
+
...context.eventDetails,
|
|
131
|
+
...approvalEventScope(params.method, "denied"),
|
|
132
|
+
message: "Codex app-server approval route unavailable."
|
|
133
|
+
});
|
|
134
|
+
return buildApprovalResponse(params.method, context.requestParams, "denied");
|
|
135
|
+
}
|
|
136
|
+
emitApprovalEvent(params.paramsForRun, {
|
|
137
|
+
phase: "requested",
|
|
138
|
+
kind: context.kind,
|
|
139
|
+
status: "pending",
|
|
140
|
+
title: context.title,
|
|
141
|
+
approvalId,
|
|
142
|
+
approvalSlug: approvalId,
|
|
143
|
+
...context.eventDetails,
|
|
144
|
+
message: "Codex app-server approval requested."
|
|
145
|
+
});
|
|
146
|
+
const outcome = mapExecDecisionToOutcome(approvalRequestExplicitlyUnavailable(requestResult) ? null : await waitForPluginApprovalDecision({
|
|
147
|
+
approvalId,
|
|
148
|
+
signal: params.signal
|
|
149
|
+
}));
|
|
150
|
+
emitApprovalEvent(params.paramsForRun, {
|
|
151
|
+
phase: "resolved",
|
|
152
|
+
kind: context.kind,
|
|
153
|
+
status: outcome === "denied" ? "denied" : outcome === "unavailable" ? "unavailable" : outcome === "cancelled" ? "failed" : "approved",
|
|
154
|
+
title: context.title,
|
|
155
|
+
approvalId,
|
|
156
|
+
approvalSlug: approvalId,
|
|
157
|
+
...context.eventDetails,
|
|
158
|
+
...approvalEventScope(params.method, outcome),
|
|
159
|
+
message: approvalResolutionMessage(outcome)
|
|
160
|
+
});
|
|
161
|
+
return buildApprovalResponse(params.method, context.requestParams, outcome);
|
|
162
|
+
} catch (error) {
|
|
163
|
+
const cancelled = params.signal?.aborted === true;
|
|
164
|
+
emitApprovalEvent(params.paramsForRun, {
|
|
165
|
+
phase: "resolved",
|
|
166
|
+
kind: context.kind,
|
|
167
|
+
status: cancelled ? "failed" : "unavailable",
|
|
168
|
+
title: context.title,
|
|
169
|
+
...context.eventDetails,
|
|
170
|
+
...approvalEventScope(params.method, cancelled ? "cancelled" : "denied"),
|
|
171
|
+
message: cancelled ? "Codex app-server approval cancelled because the run stopped." : `Codex app-server approval route failed: ${formatCodexDisplayText(formatErrorMessage(error))}`
|
|
172
|
+
});
|
|
173
|
+
return buildApprovalResponse(params.method, context.requestParams, cancelled ? "cancelled" : "denied");
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
function buildApprovalResponse(method, requestParams, outcome) {
|
|
177
|
+
if (method === "item/commandExecution/requestApproval") return { decision: commandApprovalDecision(requestParams, outcome) };
|
|
178
|
+
if (method === "item/fileChange/requestApproval") return { decision: fileChangeApprovalDecision(outcome) };
|
|
179
|
+
if (method === "item/permissions/requestApproval") {
|
|
180
|
+
if (outcome === "approved-session" || outcome === "approved-once") return {
|
|
181
|
+
permissions: requestedPermissions(requestParams),
|
|
182
|
+
scope: outcome === "approved-session" ? "session" : "turn"
|
|
183
|
+
};
|
|
184
|
+
return {
|
|
185
|
+
permissions: {},
|
|
186
|
+
scope: "turn"
|
|
187
|
+
};
|
|
188
|
+
}
|
|
189
|
+
return unsupportedApprovalResponse();
|
|
190
|
+
}
|
|
191
|
+
function matchesCurrentTurn(requestParams, threadId, turnId) {
|
|
192
|
+
if (!requestParams) return false;
|
|
193
|
+
const requestThreadId = readString$1(requestParams, "threadId") ?? readString$1(requestParams, "conversationId");
|
|
194
|
+
const requestTurnId = readString$1(requestParams, "turnId");
|
|
195
|
+
return requestThreadId === threadId && requestTurnId === turnId;
|
|
196
|
+
}
|
|
197
|
+
function buildApprovalContext(params) {
|
|
198
|
+
const itemId = readString$1(params.requestParams, "itemId") ?? readString$1(params.requestParams, "callId") ?? readString$1(params.requestParams, "approvalId");
|
|
199
|
+
const commandDetailLines = params.method === "item/commandExecution/requestApproval" ? describeCommandApprovalDetails(params.requestParams) : [];
|
|
200
|
+
const commandPreview = sanitizeApprovalPreview(readDisplayCommandPreview(params.requestParams), commandDetailLines.length > 0 ? COMMAND_PREVIEW_WITH_DETAILS_MAX_LENGTH : 180);
|
|
201
|
+
const reasonPreview = sanitizeApprovalPreview(readStringPreview(params.requestParams, "reason"), 180);
|
|
202
|
+
const command = commandPreview.text;
|
|
203
|
+
const reason = reasonPreview.text;
|
|
204
|
+
const kind = approvalKindForMethod(params.method);
|
|
205
|
+
const permissionLines = params.method === "item/permissions/requestApproval" ? describeRequestedPermissions(params.requestParams) : [];
|
|
206
|
+
const title = kind === "exec" ? "Codex app-server command approval" : params.method === "item/permissions/requestApproval" ? "Codex app-server permission approval" : kind === "plugin" ? "Codex app-server file approval" : "Codex app-server approval";
|
|
207
|
+
const subject = permissionLines[0] ?? (command ? `Command: ${formatApprovalPreviewSubject(command, commandPreview.omitted)}` : commandPreview.omitted ? `Command: ${APPROVAL_PREVIEW_OMITTED}` : reason ? `Reason: ${formatApprovalPreviewSubject(reason, reasonPreview.omitted)}` : reasonPreview.omitted ? `Reason: ${APPROVAL_PREVIEW_OMITTED}` : `Request method: ${params.method}`);
|
|
208
|
+
return {
|
|
209
|
+
kind,
|
|
210
|
+
title,
|
|
211
|
+
description: permissionLines.length > 0 ? joinDescriptionLinesWithinLimit(permissionLines, PERMISSION_DESCRIPTION_MAX_LENGTH) : [
|
|
212
|
+
subject,
|
|
213
|
+
...commandDetailLines,
|
|
214
|
+
params.paramsForRun.sessionKey && `Session: ${params.paramsForRun.sessionKey}`
|
|
215
|
+
].filter(Boolean).join("\n"),
|
|
216
|
+
severity: kind === "exec" ? "warning" : "info",
|
|
217
|
+
toolName: kind === "exec" ? "codex_command_approval" : params.method === "item/permissions/requestApproval" ? "codex_permission_approval" : "codex_file_approval",
|
|
218
|
+
itemId,
|
|
219
|
+
requestParams: params.requestParams,
|
|
220
|
+
eventDetails: {
|
|
221
|
+
...itemId ? { itemId } : {},
|
|
222
|
+
...command ? { command } : {},
|
|
223
|
+
...commandPreview.omitted ? { commandPreviewOmitted: true } : {},
|
|
224
|
+
...reason ? { reason } : {},
|
|
225
|
+
...reasonPreview.omitted ? { reasonPreviewOmitted: true } : {}
|
|
226
|
+
}
|
|
227
|
+
};
|
|
228
|
+
}
|
|
229
|
+
async function runDaoCoreToolPolicyForApprovalRequest(params) {
|
|
230
|
+
const policyRequest = buildDaoCoreToolPolicyRequest(params.method, params.requestParams);
|
|
231
|
+
if (!policyRequest) return;
|
|
232
|
+
const cwd = readString$1(params.requestParams, "cwd") ?? params.paramsForRun.workspaceDir;
|
|
233
|
+
const nativeRelayOutcome = await runNativeRelayToolPolicyForApprovalRequest({
|
|
234
|
+
method: params.method,
|
|
235
|
+
requestParams: params.requestParams,
|
|
236
|
+
context: params.context,
|
|
237
|
+
policyRequest,
|
|
238
|
+
nativeHookRelay: params.nativeHookRelay,
|
|
239
|
+
cwd
|
|
240
|
+
});
|
|
241
|
+
if (nativeRelayOutcome?.blocked) return {
|
|
242
|
+
outcome: "denied",
|
|
243
|
+
reason: nativeRelayOutcome.reason
|
|
244
|
+
};
|
|
245
|
+
if (nativeRelayOutcome?.handled) return { outcome: "no-decision" };
|
|
246
|
+
const hookChannelId = buildAgentHookContextChannelFields({
|
|
247
|
+
sessionKey: params.paramsForRun.sessionKey,
|
|
248
|
+
messageChannel: params.paramsForRun.messageChannel,
|
|
249
|
+
messageProvider: params.paramsForRun.messageProvider,
|
|
250
|
+
currentChannelId: params.paramsForRun.currentChannelId,
|
|
251
|
+
messageTo: params.paramsForRun.messageTo
|
|
252
|
+
}).channelId;
|
|
253
|
+
const outcome = await runBeforeToolCallHook({
|
|
254
|
+
toolName: policyRequest.toolName,
|
|
255
|
+
params: policyRequest.params,
|
|
256
|
+
...params.context.itemId ? { toolCallId: params.context.itemId } : {},
|
|
257
|
+
approvalMode: "report",
|
|
258
|
+
signal: params.signal,
|
|
259
|
+
ctx: {
|
|
260
|
+
...params.paramsForRun.agentId ? { agentId: params.paramsForRun.agentId } : {},
|
|
261
|
+
...params.paramsForRun.config ? { config: params.paramsForRun.config } : {},
|
|
262
|
+
...cwd ? { cwd } : {},
|
|
263
|
+
...params.paramsForRun.sessionKey ? { sessionKey: params.paramsForRun.sessionKey } : {},
|
|
264
|
+
...params.paramsForRun.sessionId ? { sessionId: params.paramsForRun.sessionId } : {},
|
|
265
|
+
...params.paramsForRun.runId ? { runId: params.paramsForRun.runId } : {},
|
|
266
|
+
...hookChannelId ? { channelId: hookChannelId } : {}
|
|
267
|
+
}
|
|
268
|
+
});
|
|
269
|
+
if (outcome.blocked) return {
|
|
270
|
+
outcome: "denied",
|
|
271
|
+
reason: outcome.reason
|
|
272
|
+
};
|
|
273
|
+
if ("params" in outcome && toolPolicyParamsWereRewritten(policyRequest.params, outcome.params)) return {
|
|
274
|
+
outcome: "denied",
|
|
275
|
+
reason: "DaoCore tool policy rewrote Codex app-server approval params; refusing original request."
|
|
276
|
+
};
|
|
277
|
+
}
|
|
278
|
+
async function runNativeRelayToolPolicyForApprovalRequest(params) {
|
|
279
|
+
if (params.method !== "item/commandExecution/requestApproval" || !params.nativeHookRelay?.allowedEvents.includes("pre_tool_use")) return;
|
|
280
|
+
const payload = buildNativeRelayPreToolUsePayload({
|
|
281
|
+
requestParams: params.requestParams,
|
|
282
|
+
policyRequest: params.policyRequest,
|
|
283
|
+
context: params.context,
|
|
284
|
+
cwd: params.cwd
|
|
285
|
+
});
|
|
286
|
+
if (!payload) return;
|
|
287
|
+
if (hasNativeHookRelayInvocation({
|
|
288
|
+
relayId: params.nativeHookRelay.relayId,
|
|
289
|
+
event: "pre_tool_use",
|
|
290
|
+
toolUseId: params.context.itemId
|
|
291
|
+
})) return { handled: true };
|
|
292
|
+
try {
|
|
293
|
+
const decision = readNativeRelayPreToolUseDecision(await invokeNativeHookRelay({
|
|
294
|
+
provider: "codex",
|
|
295
|
+
relayId: params.nativeHookRelay.relayId,
|
|
296
|
+
event: "pre_tool_use",
|
|
297
|
+
rawPayload: payload
|
|
298
|
+
}));
|
|
299
|
+
if (decision.blocked) return {
|
|
300
|
+
handled: true,
|
|
301
|
+
blocked: true,
|
|
302
|
+
reason: decision.reason
|
|
303
|
+
};
|
|
304
|
+
return { handled: true };
|
|
305
|
+
} catch (error) {
|
|
306
|
+
return {
|
|
307
|
+
handled: true,
|
|
308
|
+
blocked: true,
|
|
309
|
+
reason: `DaoCore native hook relay unavailable for Codex app-server approval: ${formatCodexDisplayText(formatErrorMessage(error))}`
|
|
310
|
+
};
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
function buildNativeRelayPreToolUsePayload(params) {
|
|
314
|
+
const command = readString$1(params.policyRequest.params, "command");
|
|
315
|
+
if (!command) return;
|
|
316
|
+
const turnId = readString$1(params.requestParams, "turnId");
|
|
317
|
+
return {
|
|
318
|
+
hook_event_name: "PreToolUse",
|
|
319
|
+
daocore_approval_mode: "report",
|
|
320
|
+
tool_name: "exec_command",
|
|
321
|
+
...params.context.itemId ? { tool_use_id: params.context.itemId } : {},
|
|
322
|
+
...params.cwd ? { cwd: params.cwd } : {},
|
|
323
|
+
...turnId ? { turn_id: turnId } : {},
|
|
324
|
+
tool_input: {
|
|
325
|
+
...params.policyRequest.params,
|
|
326
|
+
command,
|
|
327
|
+
cmd: command
|
|
328
|
+
}
|
|
329
|
+
};
|
|
330
|
+
}
|
|
331
|
+
function readNativeRelayPreToolUseDecision(response) {
|
|
332
|
+
if (!response || response.exitCode !== 0) return {
|
|
333
|
+
blocked: true,
|
|
334
|
+
reason: sanitizeRelayDecisionReason(response?.stderr) || sanitizeRelayDecisionReason(response?.stdout) || "DaoCore native hook relay failed for Codex app-server approval."
|
|
335
|
+
};
|
|
336
|
+
const stdout = response.stdout?.trim();
|
|
337
|
+
if (!stdout) return { blocked: false };
|
|
338
|
+
const parsed = parseRelayJsonResponse(stdout);
|
|
339
|
+
const output = isJsonObject(parsed?.hookSpecificOutput) ? parsed.hookSpecificOutput : void 0;
|
|
340
|
+
if (output?.permissionDecision === "deny") return {
|
|
341
|
+
blocked: true,
|
|
342
|
+
reason: readString$1(output, "permissionDecisionReason") || "DaoCore native hook policy denied Codex app-server approval."
|
|
343
|
+
};
|
|
344
|
+
return {
|
|
345
|
+
blocked: true,
|
|
346
|
+
reason: output ? "DaoCore native hook relay returned a non-deny Codex app-server approval decision." : "DaoCore native hook relay returned an unreadable Codex app-server approval result."
|
|
347
|
+
};
|
|
348
|
+
}
|
|
349
|
+
function parseRelayJsonResponse(text) {
|
|
350
|
+
try {
|
|
351
|
+
const parsed = JSON.parse(text);
|
|
352
|
+
return isJsonObject(parsed) ? parsed : void 0;
|
|
353
|
+
} catch {
|
|
354
|
+
return;
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
function sanitizeRelayDecisionReason(value) {
|
|
358
|
+
return sanitizeApprovalPreview(value ? {
|
|
359
|
+
value,
|
|
360
|
+
clipped: false
|
|
361
|
+
} : void 0, 240).text;
|
|
362
|
+
}
|
|
363
|
+
function buildDaoCoreToolPolicyRequest(method, requestParams) {
|
|
364
|
+
if (method === "item/commandExecution/requestApproval") {
|
|
365
|
+
const command = readPolicyCommand(requestParams);
|
|
366
|
+
return {
|
|
367
|
+
toolName: "exec",
|
|
368
|
+
params: {
|
|
369
|
+
...command ? { command } : {},
|
|
370
|
+
...readString$1(requestParams, "cwd") ? { cwd: readString$1(requestParams, "cwd") } : {},
|
|
371
|
+
approval: requestParams ?? {}
|
|
372
|
+
}
|
|
373
|
+
};
|
|
374
|
+
}
|
|
375
|
+
if (method === "item/fileChange/requestApproval") return {
|
|
376
|
+
toolName: "apply_patch",
|
|
377
|
+
params: requestParams ?? {}
|
|
378
|
+
};
|
|
379
|
+
if (method === "item/permissions/requestApproval") return {
|
|
380
|
+
toolName: "codex_permission_approval",
|
|
381
|
+
params: requestParams ?? {}
|
|
382
|
+
};
|
|
383
|
+
}
|
|
384
|
+
function toolPolicyParamsWereRewritten(original, candidate) {
|
|
385
|
+
if (candidate === original) return false;
|
|
386
|
+
const originalText = stableJsonText(original);
|
|
387
|
+
const candidateText = stableJsonText(candidate);
|
|
388
|
+
return !candidateText || candidateText !== originalText;
|
|
389
|
+
}
|
|
390
|
+
function stableJsonText(value) {
|
|
391
|
+
if (value === null || typeof value === "string" || typeof value === "number" || typeof value === "boolean") return JSON.stringify(value);
|
|
392
|
+
if (Array.isArray(value)) {
|
|
393
|
+
const items = value.map((item) => stableJsonText(item));
|
|
394
|
+
return items.every((item) => item !== void 0) ? `[${items.join(",")}]` : void 0;
|
|
395
|
+
}
|
|
396
|
+
if (isPlainRecord(value)) {
|
|
397
|
+
const entries = Object.entries(value).toSorted(([left], [right]) => left.localeCompare(right)).map(([key, item]) => {
|
|
398
|
+
const text = stableJsonText(item);
|
|
399
|
+
return text === void 0 ? void 0 : `${JSON.stringify(key)}:${text}`;
|
|
400
|
+
});
|
|
401
|
+
return entries.every((entry) => entry !== void 0) ? `{${entries.join(",")}}` : void 0;
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
function isPlainRecord(value) {
|
|
405
|
+
return Boolean(value && typeof value === "object" && !Array.isArray(value));
|
|
406
|
+
}
|
|
407
|
+
function commandApprovalDecision(requestParams, outcome) {
|
|
408
|
+
if (outcome === "cancelled") return commandRejectionDecision(requestParams, "cancel");
|
|
409
|
+
if (outcome === "denied" || outcome === "unavailable") return commandRejectionDecision(requestParams, "decline");
|
|
410
|
+
if (outcome === "approved-session") {
|
|
411
|
+
if (hasAvailableDecision(requestParams, "acceptForSession")) return "acceptForSession";
|
|
412
|
+
const amendmentDecision = findAvailableCommandAmendmentDecision(requestParams);
|
|
413
|
+
if (amendmentDecision) return amendmentDecision;
|
|
414
|
+
}
|
|
415
|
+
return hasAvailableDecision(requestParams, "accept") ? "accept" : commandRejectionDecision(requestParams, "decline");
|
|
416
|
+
}
|
|
417
|
+
function fileChangeApprovalDecision(outcome) {
|
|
418
|
+
if (outcome === "cancelled") return "cancel";
|
|
419
|
+
if (outcome === "denied" || outcome === "unavailable") return "decline";
|
|
420
|
+
return outcome === "approved-session" ? "acceptForSession" : "accept";
|
|
421
|
+
}
|
|
422
|
+
function requestedPermissions(requestParams) {
|
|
423
|
+
const permissions = isJsonObject(requestParams?.permissions) ? requestParams.permissions : {};
|
|
424
|
+
const granted = {};
|
|
425
|
+
if (isJsonObject(permissions.network)) granted.network = permissions.network;
|
|
426
|
+
if (isJsonObject(permissions.fileSystem)) granted.fileSystem = permissions.fileSystem;
|
|
427
|
+
return granted;
|
|
428
|
+
}
|
|
429
|
+
function unsupportedApprovalResponse() {
|
|
430
|
+
return {
|
|
431
|
+
decision: "decline",
|
|
432
|
+
reason: "DaoCore codex app-server bridge does not grant native approvals yet."
|
|
433
|
+
};
|
|
434
|
+
}
|
|
435
|
+
function describeRequestedPermissions(requestParams) {
|
|
436
|
+
return describePermissionProfile(requestedPermissions(requestParams), "Permissions");
|
|
437
|
+
}
|
|
438
|
+
function describeCommandApprovalDetails(requestParams) {
|
|
439
|
+
const lines = [];
|
|
440
|
+
const additionalPermissions = isJsonObject(requestParams?.additionalPermissions) ? requestParams.additionalPermissions : void 0;
|
|
441
|
+
if (additionalPermissions) lines.push(...describePermissionProfile(additionalPermissions, "Additional permissions"));
|
|
442
|
+
const execpolicySummary = summarizeStringArray(requestParams?.proposedExecpolicyAmendment, "Proposed exec policy", sanitizePermissionScalar);
|
|
443
|
+
if (execpolicySummary) lines.push(execpolicySummary);
|
|
444
|
+
const networkAmendmentSummary = summarizeNetworkPolicyAmendments(requestParams?.proposedNetworkPolicyAmendments);
|
|
445
|
+
if (networkAmendmentSummary) lines.push(networkAmendmentSummary);
|
|
446
|
+
return lines;
|
|
447
|
+
}
|
|
448
|
+
function describePermissionProfile(permissions, label) {
|
|
449
|
+
const lines = [];
|
|
450
|
+
const kinds = [];
|
|
451
|
+
const risks = /* @__PURE__ */ new Set();
|
|
452
|
+
if (isJsonObject(permissions.network)) kinds.push("network");
|
|
453
|
+
if (isJsonObject(permissions.fileSystem)) kinds.push("fileSystem");
|
|
454
|
+
if (kinds.length > 0) lines.push(`${label}: ${kinds.join(", ")}`);
|
|
455
|
+
let networkSummary;
|
|
456
|
+
if (isJsonObject(permissions.network)) {
|
|
457
|
+
const summaries = [summarizeNetworkEnabledPermission(permissions.network, risks), summarizePermissionRecord(permissions.network, risks, [{
|
|
458
|
+
key: "allowHosts",
|
|
459
|
+
label: "allowHosts",
|
|
460
|
+
sanitize: sanitizePermissionHostValue,
|
|
461
|
+
risksFor: permissionHostRisks
|
|
462
|
+
}])].filter((summary) => Boolean(summary));
|
|
463
|
+
networkSummary = summaries.length > 0 ? summaries.join("; ") : void 0;
|
|
464
|
+
}
|
|
465
|
+
let fileSystemSummary;
|
|
466
|
+
if (isJsonObject(permissions.fileSystem)) {
|
|
467
|
+
const summaries = [summarizePermissionRecord(permissions.fileSystem, risks, [
|
|
468
|
+
{
|
|
469
|
+
key: "read",
|
|
470
|
+
label: "read",
|
|
471
|
+
sanitize: sanitizePermissionPathValue,
|
|
472
|
+
risksFor: permissionPathRisks
|
|
473
|
+
},
|
|
474
|
+
{
|
|
475
|
+
key: "write",
|
|
476
|
+
label: "write",
|
|
477
|
+
sanitize: sanitizePermissionPathValue,
|
|
478
|
+
risksFor: permissionPathRisks
|
|
479
|
+
},
|
|
480
|
+
{
|
|
481
|
+
key: "roots",
|
|
482
|
+
label: "roots",
|
|
483
|
+
sanitize: sanitizePermissionPathValue,
|
|
484
|
+
risksFor: permissionPathRisks
|
|
485
|
+
},
|
|
486
|
+
{
|
|
487
|
+
key: "readPaths",
|
|
488
|
+
label: "readPaths",
|
|
489
|
+
sanitize: sanitizePermissionPathValue,
|
|
490
|
+
risksFor: permissionPathRisks
|
|
491
|
+
},
|
|
492
|
+
{
|
|
493
|
+
key: "writePaths",
|
|
494
|
+
label: "writePaths",
|
|
495
|
+
sanitize: sanitizePermissionPathValue,
|
|
496
|
+
risksFor: permissionPathRisks
|
|
497
|
+
}
|
|
498
|
+
]), summarizeFileSystemEntries(permissions.fileSystem, risks)].filter((summary) => Boolean(summary));
|
|
499
|
+
fileSystemSummary = summaries.length > 0 ? summaries.join("; ") : void 0;
|
|
500
|
+
}
|
|
501
|
+
if (risks.size > 0) lines.push(`High-risk targets: ${[...risks].join(", ")}`);
|
|
502
|
+
if (networkSummary) lines.push(`Network ${networkSummary}`);
|
|
503
|
+
if (fileSystemSummary) lines.push(`File system ${fileSystemSummary}`);
|
|
504
|
+
return lines;
|
|
505
|
+
}
|
|
506
|
+
function summarizeNetworkEnabledPermission(permission, risks) {
|
|
507
|
+
const enabled = permission.enabled;
|
|
508
|
+
if (typeof enabled !== "boolean") return;
|
|
509
|
+
if (enabled) risks.add("network access");
|
|
510
|
+
return `enabled: ${enabled}`;
|
|
511
|
+
}
|
|
512
|
+
function summarizeFileSystemEntries(permission, risks) {
|
|
513
|
+
const entries = permission.entries;
|
|
514
|
+
if (!Array.isArray(entries)) return;
|
|
515
|
+
const samples = [];
|
|
516
|
+
let count = 0;
|
|
517
|
+
for (const entry of entries) {
|
|
518
|
+
const item = isJsonObject(entry) ? entry : void 0;
|
|
519
|
+
const path = typeof item?.path === "string" ? item.path.trim() : "";
|
|
520
|
+
const access = typeof item?.access === "string" ? item.access.trim() : "";
|
|
521
|
+
if (!path || !access) continue;
|
|
522
|
+
count += 1;
|
|
523
|
+
if (access !== "none") for (const risk of permissionPathRisks(path)) risks.add(risk);
|
|
524
|
+
if (samples.length < PERMISSION_SAMPLE_LIMIT) samples.push(`${sanitizePermissionScalar(access)} ${sanitizePermissionPathValue(path)}`);
|
|
525
|
+
}
|
|
526
|
+
if (count === 0) return;
|
|
527
|
+
const remaining = count - samples.length;
|
|
528
|
+
const remainderSuffix = remaining > 0 ? ` (+${remaining} more)` : "";
|
|
529
|
+
return `entries: ${samples.join(", ")}${remainderSuffix}`;
|
|
530
|
+
}
|
|
531
|
+
function summarizePermissionRecord(permission, risks, descriptors) {
|
|
532
|
+
const details = [];
|
|
533
|
+
for (const descriptor of descriptors) {
|
|
534
|
+
const summary = summarizePermissionArray(permission, descriptor, risks);
|
|
535
|
+
if (summary) details.push(summary);
|
|
536
|
+
}
|
|
537
|
+
return details.length > 0 ? details.join("; ") : void 0;
|
|
538
|
+
}
|
|
539
|
+
function summarizePermissionArray(record, descriptor, risks) {
|
|
540
|
+
const values = readStringArray(record, descriptor.key);
|
|
541
|
+
if (values.length === 0) return;
|
|
542
|
+
for (const value of values) for (const risk of descriptor.risksFor(value)) risks.add(risk);
|
|
543
|
+
const sampleValues = values.slice(0, PERMISSION_SAMPLE_LIMIT).map(descriptor.sanitize).filter(Boolean);
|
|
544
|
+
if (sampleValues.length === 0) return `${descriptor.label}: ${values.length}`;
|
|
545
|
+
const remaining = values.length - sampleValues.length;
|
|
546
|
+
const remainderSuffix = remaining > 0 ? ` (+${remaining} more)` : "";
|
|
547
|
+
return `${descriptor.label}: ${sampleValues.join(", ")}${remainderSuffix}`;
|
|
548
|
+
}
|
|
549
|
+
function summarizeStringArray(value, label, sanitize) {
|
|
550
|
+
if (!Array.isArray(value)) return;
|
|
551
|
+
const values = value.filter((entry) => typeof entry === "string").map((entry) => sanitize(entry)).filter(Boolean);
|
|
552
|
+
if (values.length === 0) return;
|
|
553
|
+
const samples = values.slice(0, PERMISSION_SAMPLE_LIMIT);
|
|
554
|
+
const remaining = values.length - samples.length;
|
|
555
|
+
const remainderSuffix = remaining > 0 ? ` (+${remaining} more)` : "";
|
|
556
|
+
return `${label}: ${samples.join(", ")}${remainderSuffix}`;
|
|
557
|
+
}
|
|
558
|
+
function summarizeNetworkPolicyAmendments(value) {
|
|
559
|
+
if (!Array.isArray(value)) return;
|
|
560
|
+
const samples = [];
|
|
561
|
+
let count = 0;
|
|
562
|
+
for (const entry of value) {
|
|
563
|
+
const amendment = isJsonObject(entry) ? entry : void 0;
|
|
564
|
+
const host = typeof amendment?.host === "string" ? amendment.host : "";
|
|
565
|
+
const action = typeof amendment?.action === "string" ? amendment.action : "";
|
|
566
|
+
if (!host || !action) continue;
|
|
567
|
+
count += 1;
|
|
568
|
+
if (samples.length < PERMISSION_SAMPLE_LIMIT) samples.push(`${sanitizePermissionScalar(action)} ${sanitizePermissionHostValue(host)}`);
|
|
569
|
+
}
|
|
570
|
+
if (count === 0) return;
|
|
571
|
+
const remaining = count - samples.length;
|
|
572
|
+
const remainderSuffix = remaining > 0 ? ` (+${remaining} more)` : "";
|
|
573
|
+
return `Proposed network policy: ${samples.join(", ")}${remainderSuffix}`;
|
|
574
|
+
}
|
|
575
|
+
function readStringArray(record, key) {
|
|
576
|
+
const value = record[key];
|
|
577
|
+
return Array.isArray(value) ? value.map((entry) => typeof entry === "string" ? entry.trim() : "").filter(Boolean) : [];
|
|
578
|
+
}
|
|
579
|
+
function sanitizePermissionHostValue(value) {
|
|
580
|
+
const withoutScheme = sanitizePermissionScalar(value).toLowerCase().replace(/^[a-z][a-z0-9+.-]*:\/\//, "");
|
|
581
|
+
const authority = withoutScheme.split(/[/?#]/, 1)[0] ?? withoutScheme;
|
|
582
|
+
return truncate(authority.includes("@") ? authority.slice(authority.lastIndexOf("@") + 1) : authority, PERMISSION_VALUE_MAX_LENGTH);
|
|
583
|
+
}
|
|
584
|
+
function sanitizePermissionPathValue(value) {
|
|
585
|
+
return truncate(formatApprovalDisplayPath(sanitizePermissionScalar(value)), PERMISSION_VALUE_MAX_LENGTH);
|
|
586
|
+
}
|
|
587
|
+
function sanitizePermissionScalar(value) {
|
|
588
|
+
return sanitizeVisibleScalar(value);
|
|
589
|
+
}
|
|
590
|
+
function permissionHostRisks(value) {
|
|
591
|
+
const normalized = value.trim().toLowerCase();
|
|
592
|
+
const risks = [];
|
|
593
|
+
if (normalized.includes("*")) {
|
|
594
|
+
risks.push("wildcard hosts");
|
|
595
|
+
if (isPrivateNetworkHostPattern(normalized)) risks.push("private-network wildcards");
|
|
596
|
+
}
|
|
597
|
+
return risks;
|
|
598
|
+
}
|
|
599
|
+
function permissionPathRisks(value) {
|
|
600
|
+
const normalized = sanitizePermissionScalar(value);
|
|
601
|
+
const risks = [];
|
|
602
|
+
if (normalized === "/" || normalized === "\\" || /^[A-Za-z]:[\\/]*$/.test(normalized)) risks.push("filesystem root");
|
|
603
|
+
return risks;
|
|
604
|
+
}
|
|
605
|
+
function isPrivateNetworkHostPattern(value) {
|
|
606
|
+
const wildcardStripped = value.toLowerCase().replace(/^\*\./, "");
|
|
607
|
+
if (wildcardStripped === "localhost" || wildcardStripped === "local" || wildcardStripped === "internal" || wildcardStripped === "lan" || wildcardStripped === "home" || wildcardStripped === "corp" || wildcardStripped === "private" || wildcardStripped.endsWith(".local") || wildcardStripped.endsWith(".internal") || wildcardStripped.endsWith(".lan") || wildcardStripped.endsWith(".home") || wildcardStripped.endsWith(".corp") || wildcardStripped.endsWith(".private")) return true;
|
|
608
|
+
if (wildcardStripped.startsWith("10.") || wildcardStripped.startsWith("127.") || wildcardStripped.startsWith("192.168.") || wildcardStripped.startsWith("169.254.")) return true;
|
|
609
|
+
return /^172\.(1[6-9]|2\d|3[0-1])\./.test(wildcardStripped);
|
|
610
|
+
}
|
|
611
|
+
function hasAvailableDecision(requestParams, decision) {
|
|
612
|
+
const available = requestParams?.availableDecisions;
|
|
613
|
+
if (!Array.isArray(available)) return true;
|
|
614
|
+
return available.includes(decision);
|
|
615
|
+
}
|
|
616
|
+
function findAvailableCommandAmendmentDecision(requestParams) {
|
|
617
|
+
const available = requestParams?.availableDecisions;
|
|
618
|
+
if (!Array.isArray(available)) return;
|
|
619
|
+
return available.find((entry) => isJsonObject(entry) && (isJsonObject(entry.acceptWithExecpolicyAmendment) || isJsonObject(entry.applyNetworkPolicyAmendment)));
|
|
620
|
+
}
|
|
621
|
+
function commandRejectionDecision(requestParams, preferred) {
|
|
622
|
+
const available = requestParams?.availableDecisions;
|
|
623
|
+
if (!Array.isArray(available)) return preferred;
|
|
624
|
+
if (available.includes(preferred)) return preferred;
|
|
625
|
+
const alternate = preferred === "decline" ? "cancel" : "decline";
|
|
626
|
+
if (available.includes(alternate)) return alternate;
|
|
627
|
+
return preferred;
|
|
628
|
+
}
|
|
629
|
+
function approvalResolutionMessage(outcome) {
|
|
630
|
+
if (outcome === "approved-session") return "Codex app-server approval granted for the session.";
|
|
631
|
+
if (outcome === "approved-once") return "Codex app-server approval granted for this turn.";
|
|
632
|
+
if (outcome === "cancelled") return "Codex app-server approval cancelled.";
|
|
633
|
+
if (outcome === "unavailable") return "Codex app-server approval unavailable.";
|
|
634
|
+
return "Codex app-server approval denied.";
|
|
635
|
+
}
|
|
636
|
+
function approvalScopeForOutcome(outcome) {
|
|
637
|
+
return outcome === "approved-session" ? "session" : "turn";
|
|
638
|
+
}
|
|
639
|
+
function approvalEventScope(method, outcome) {
|
|
640
|
+
return method === "item/permissions/requestApproval" ? { scope: approvalScopeForOutcome(outcome) } : {};
|
|
641
|
+
}
|
|
642
|
+
function approvalKindForMethod(method) {
|
|
643
|
+
if (method.includes("commandExecution") || method.includes("execCommand")) return "exec";
|
|
644
|
+
if (method.includes("fileChange") || method.includes("Patch") || method.includes("permissions")) return "plugin";
|
|
645
|
+
return "unknown";
|
|
646
|
+
}
|
|
647
|
+
function isSupportedAppServerApprovalMethod(method) {
|
|
648
|
+
return method === "item/commandExecution/requestApproval" || method === "item/fileChange/requestApproval" || method === "item/permissions/requestApproval";
|
|
649
|
+
}
|
|
650
|
+
function emitApprovalEvent(params, data) {
|
|
651
|
+
params.onAgentEvent?.({
|
|
652
|
+
stream: "approval",
|
|
653
|
+
data
|
|
654
|
+
});
|
|
655
|
+
}
|
|
656
|
+
function readDisplayCommandPreview(record) {
|
|
657
|
+
const actionCommand = readCommandActionsPreview(record);
|
|
658
|
+
if (actionCommand) return actionCommand;
|
|
659
|
+
return readCommandPreview(record);
|
|
660
|
+
}
|
|
661
|
+
function readPolicyCommand(record) {
|
|
662
|
+
const command = record?.command;
|
|
663
|
+
if (typeof command === "string") return command;
|
|
664
|
+
if (Array.isArray(command) && command.every((part) => typeof part === "string")) return command.join(" ");
|
|
665
|
+
const actionCommands = readCommandActions(record);
|
|
666
|
+
if (actionCommands.length > 0) return actionCommands.join(" && ");
|
|
667
|
+
}
|
|
668
|
+
function readCommandActions(record) {
|
|
669
|
+
const actions = record?.commandActions;
|
|
670
|
+
if (!Array.isArray(actions)) return [];
|
|
671
|
+
return actions.map((action) => isJsonObject(action) ? readString$1(action, "command") : void 0).filter((command) => Boolean(command));
|
|
672
|
+
}
|
|
673
|
+
function readCommandActionsPreview(record) {
|
|
674
|
+
let source;
|
|
675
|
+
for (const command of readCommandActions(record)) {
|
|
676
|
+
source = appendPreviewPart(source, command, " && ");
|
|
677
|
+
if (source.clipped) break;
|
|
678
|
+
}
|
|
679
|
+
return source;
|
|
680
|
+
}
|
|
681
|
+
function readCommandPreview(record) {
|
|
682
|
+
const command = record?.command;
|
|
683
|
+
if (typeof command === "string") return previewSource(command);
|
|
684
|
+
if (!Array.isArray(command)) return;
|
|
685
|
+
let source;
|
|
686
|
+
for (const part of command) {
|
|
687
|
+
if (typeof part !== "string") return;
|
|
688
|
+
source = appendPreviewPart(source, part, " ");
|
|
689
|
+
if (source.clipped) break;
|
|
690
|
+
}
|
|
691
|
+
return source;
|
|
692
|
+
}
|
|
693
|
+
function readStringPreview(record, key) {
|
|
694
|
+
const value = readString$1(record, key);
|
|
695
|
+
return value === void 0 ? void 0 : previewSource(value);
|
|
696
|
+
}
|
|
697
|
+
function readString$1(record, key) {
|
|
698
|
+
const value = record?.[key];
|
|
699
|
+
return typeof value === "string" ? value : void 0;
|
|
700
|
+
}
|
|
701
|
+
function truncate(value, maxLength) {
|
|
702
|
+
return value.length <= maxLength ? value : `${value.slice(0, Math.max(0, maxLength - 3))}...`;
|
|
703
|
+
}
|
|
704
|
+
function previewSource(value) {
|
|
705
|
+
return {
|
|
706
|
+
value: value.slice(0, APPROVAL_PREVIEW_SCAN_MAX_LENGTH),
|
|
707
|
+
clipped: value.length > APPROVAL_PREVIEW_SCAN_MAX_LENGTH
|
|
708
|
+
};
|
|
709
|
+
}
|
|
710
|
+
function appendPreviewPart(source, part, separator) {
|
|
711
|
+
const value = `${source?.value ? `${source.value}${separator}` : ""}${part}`;
|
|
712
|
+
const clipped = source?.clipped === true || value.length > APPROVAL_PREVIEW_SCAN_MAX_LENGTH;
|
|
713
|
+
return {
|
|
714
|
+
value: value.slice(0, APPROVAL_PREVIEW_SCAN_MAX_LENGTH),
|
|
715
|
+
clipped
|
|
716
|
+
};
|
|
717
|
+
}
|
|
718
|
+
function sanitizeApprovalPreview(source, maxLength) {
|
|
719
|
+
if (!source || !source.value) return { omitted: false };
|
|
720
|
+
const sanitized = sanitizeVisibleScalar(source.value.replace(DANGLING_TERMINAL_SEQUENCE_SUFFIX_RE$1, ""));
|
|
721
|
+
if (!sanitized) return { omitted: true };
|
|
722
|
+
return {
|
|
723
|
+
text: formatCodexDisplayText(truncate(sanitized, maxLength)),
|
|
724
|
+
omitted: source.clipped
|
|
725
|
+
};
|
|
726
|
+
}
|
|
727
|
+
function sanitizeVisibleScalar(value) {
|
|
728
|
+
return value.replace(ANSI_OSC_SEQUENCE_RE$1, "").replace(ANSI_CONTROL_SEQUENCE_RE$1, "").replace(INVISIBLE_FORMATTING_CONTROL_RE$1, " ").replace(CONTROL_CHARACTER_RE$1, " ").replace(/\s+/g, " ").trim();
|
|
729
|
+
}
|
|
730
|
+
function formatApprovalPreviewSubject(text, omitted) {
|
|
731
|
+
return omitted ? `${text} ${APPROVAL_PREVIEW_OMITTED}` : text;
|
|
732
|
+
}
|
|
733
|
+
function joinDescriptionLinesWithinLimit(lines, maxLength) {
|
|
734
|
+
let description = "";
|
|
735
|
+
for (const line of lines) {
|
|
736
|
+
const prefix = description ? "\n" : "";
|
|
737
|
+
const next = `${description}${prefix}${line}`;
|
|
738
|
+
if (next.length <= maxLength) {
|
|
739
|
+
description = next;
|
|
740
|
+
continue;
|
|
741
|
+
}
|
|
742
|
+
const remaining = maxLength - description.length - prefix.length;
|
|
743
|
+
if (remaining < 3) break;
|
|
744
|
+
description += `${prefix}${truncate(line, remaining)}`;
|
|
745
|
+
break;
|
|
746
|
+
}
|
|
747
|
+
return description;
|
|
748
|
+
}
|
|
749
|
+
function formatErrorMessage(error) {
|
|
750
|
+
return error instanceof Error ? error.message : String(error);
|
|
751
|
+
}
|
|
752
|
+
//#endregion
|
|
753
|
+
//#region extensions/codex/src/app-server/dynamic-tool-diagnostics.ts
|
|
754
|
+
function emitDynamicToolStartedDiagnostic(params) {
|
|
755
|
+
emitTrustedDiagnosticEvent({
|
|
756
|
+
type: "tool.execution.started",
|
|
757
|
+
runId: params.runId,
|
|
758
|
+
sessionId: params.sessionId,
|
|
759
|
+
sessionKey: params.sessionKey,
|
|
760
|
+
toolName: params.call.tool,
|
|
761
|
+
toolCallId: params.call.callId
|
|
762
|
+
});
|
|
763
|
+
}
|
|
764
|
+
function emitDynamicToolErrorDiagnostic(params) {
|
|
765
|
+
emitTrustedDiagnosticEvent({
|
|
766
|
+
type: "tool.execution.error",
|
|
767
|
+
runId: params.runId,
|
|
768
|
+
sessionId: params.sessionId,
|
|
769
|
+
sessionKey: params.sessionKey,
|
|
770
|
+
toolName: params.call.tool,
|
|
771
|
+
toolCallId: params.call.callId,
|
|
772
|
+
durationMs: params.durationMs,
|
|
773
|
+
errorCategory: "codex_dynamic_tool_error"
|
|
774
|
+
});
|
|
775
|
+
}
|
|
776
|
+
function emitDynamicToolTerminalDiagnostic(params) {
|
|
777
|
+
const terminalType = params.response.diagnosticTerminalType ?? (params.response.success ? "completed" : "error");
|
|
778
|
+
if (terminalType === "completed") {
|
|
779
|
+
emitTrustedDiagnosticEvent({
|
|
780
|
+
type: "tool.execution.completed",
|
|
781
|
+
runId: params.runId,
|
|
782
|
+
sessionId: params.sessionId,
|
|
783
|
+
sessionKey: params.sessionKey,
|
|
784
|
+
toolName: params.call.tool,
|
|
785
|
+
toolCallId: params.call.callId,
|
|
786
|
+
durationMs: params.durationMs
|
|
787
|
+
});
|
|
788
|
+
return;
|
|
789
|
+
}
|
|
790
|
+
if (terminalType === "blocked") {
|
|
791
|
+
emitTrustedDiagnosticEvent({
|
|
792
|
+
type: "tool.execution.blocked",
|
|
793
|
+
runId: params.runId,
|
|
794
|
+
sessionId: params.sessionId,
|
|
795
|
+
sessionKey: params.sessionKey,
|
|
796
|
+
toolName: params.call.tool,
|
|
797
|
+
toolCallId: params.call.callId,
|
|
798
|
+
deniedReason: "plugin-before-tool-call",
|
|
799
|
+
reason: "Tool call blocked"
|
|
800
|
+
});
|
|
801
|
+
return;
|
|
802
|
+
}
|
|
803
|
+
emitDynamicToolErrorDiagnostic(params);
|
|
804
|
+
}
|
|
805
|
+
//#endregion
|
|
806
|
+
//#region extensions/codex/src/app-server/elicitation-bridge.ts
|
|
807
|
+
const MCP_TOOL_APPROVAL_KIND = "mcp_tool_call";
|
|
808
|
+
const MCP_TOOL_APPROVAL_KIND_KEY = "codex_approval_kind";
|
|
809
|
+
const MCP_TOOL_APPROVAL_CONNECTOR_NAME_KEY = "connector_name";
|
|
810
|
+
const MCP_TOOL_APPROVAL_TOOL_TITLE_KEY = "tool_title";
|
|
811
|
+
const MCP_TOOL_APPROVAL_TOOL_DESCRIPTION_KEY = "tool_description";
|
|
812
|
+
const MCP_TOOL_APPROVAL_TOOL_PARAMS_DISPLAY_KEY = "tool_params_display";
|
|
813
|
+
const MCP_TOOL_APPROVAL_SOURCE_KEY = "source";
|
|
814
|
+
const MCP_TOOL_APPROVAL_CONNECTOR_SOURCE = "connector";
|
|
815
|
+
const CODEX_APPS_SERVER_NAME = "codex_apps";
|
|
816
|
+
const COMPUTER_USE_APPROVAL_TITLE = "Computer Use approval";
|
|
817
|
+
const EMPTY_OBJECT_SCHEMA = {
|
|
818
|
+
type: "object",
|
|
819
|
+
properties: {}
|
|
820
|
+
};
|
|
821
|
+
const PLUGIN_APP_ID_META_KEYS = [
|
|
822
|
+
"app_id",
|
|
823
|
+
"appId",
|
|
824
|
+
"codex_app_id",
|
|
825
|
+
"codexAppId"
|
|
826
|
+
];
|
|
827
|
+
const PLUGIN_CONNECTOR_ID_META_KEYS = ["connector_id", "connectorId"];
|
|
828
|
+
const PLUGIN_NAME_META_KEYS = [
|
|
829
|
+
"plugin_name",
|
|
830
|
+
"pluginName",
|
|
831
|
+
"codex_plugin_name",
|
|
832
|
+
"codexPluginName"
|
|
833
|
+
];
|
|
834
|
+
const PLUGIN_CONFIG_KEY_META_KEYS = [
|
|
835
|
+
"config_key",
|
|
836
|
+
"configKey",
|
|
837
|
+
"codex_config_key"
|
|
838
|
+
];
|
|
839
|
+
const PLUGIN_MARKETPLACE_NAME_META_KEYS = [
|
|
840
|
+
"marketplace_name",
|
|
841
|
+
"marketplaceName",
|
|
842
|
+
"codex_marketplace_name",
|
|
843
|
+
"codexMarketplaceName"
|
|
844
|
+
];
|
|
845
|
+
const MAX_DISPLAY_PARAM_ENTRIES = 8;
|
|
846
|
+
const MAX_DISPLAY_PARAM_VALUE_LENGTH = 120;
|
|
847
|
+
const MAX_DISPLAY_VALUE_ARRAY_ITEMS = 8;
|
|
848
|
+
const MAX_DISPLAY_VALUE_OBJECT_KEYS = 8;
|
|
849
|
+
const MAX_DISPLAY_VALUE_DEPTH = 3;
|
|
850
|
+
const DISPLAY_TEXT_SCAN_MAX_LENGTH = 4096;
|
|
851
|
+
const ANSI_OSC_SEQUENCE_RE = new RegExp(String.raw`(?:\u001b]|\u009d)[^\u001b\u009c\u0007]*(?:\u0007|\u001b\\|\u009c)`, "g");
|
|
852
|
+
const ANSI_CONTROL_SEQUENCE_RE = new RegExp(String.raw`(?:\u001b\[[0-?]*[ -/]*[@-~]|\u009b[0-?]*[ -/]*[@-~]|\u001b[@-Z\\-_])`, "g");
|
|
853
|
+
const CONTROL_CHARACTER_RE = new RegExp(String.raw`[\u0000-\u001f\u007f-\u009f]+`, "g");
|
|
854
|
+
const INVISIBLE_FORMATTING_CONTROL_RE = new RegExp(String.raw`[\u00ad\u034f\u061c\u200b-\u200f\u202a-\u202e\u2060-\u206f\ufeff\ufe00-\ufe0f\u{e0100}-\u{e01ef}]`, "gu");
|
|
855
|
+
const DANGLING_TERMINAL_SEQUENCE_SUFFIX_RE = new RegExp(String.raw`(?:\u001b\][^\u001b\u009c\u0007]*|\u009d[^\u001b\u009c\u0007]*|\u001b\[[0-?]*[ -/]*|\u009b[0-?]*[ -/]*|\u001b)$`);
|
|
856
|
+
async function handleCodexAppServerElicitationRequest(params) {
|
|
857
|
+
const requestParams = isJsonObject(params.requestParams) ? params.requestParams : void 0;
|
|
858
|
+
if (!requestParams) return;
|
|
859
|
+
if (!matchesCurrentThread(requestParams, params.threadId)) return;
|
|
860
|
+
if (turnIdMismatches(requestParams, params.turnId)) return;
|
|
861
|
+
const pluginResolution = resolvePluginElicitation({
|
|
862
|
+
requestParams,
|
|
863
|
+
pluginAppPolicyContext: params.pluginAppPolicyContext
|
|
864
|
+
});
|
|
865
|
+
if (pluginResolution.kind !== "not_plugin") {
|
|
866
|
+
if (pluginResolution.kind === "decline") {
|
|
867
|
+
logPluginElicitationDecline(pluginResolution.reason, requestParams);
|
|
868
|
+
return declineElicitationResponse();
|
|
869
|
+
}
|
|
870
|
+
if (!hasExactTurnId(requestParams, params.turnId)) {
|
|
871
|
+
logPluginElicitationDecline("missing_active_turn", requestParams);
|
|
872
|
+
return declineElicitationResponse();
|
|
873
|
+
}
|
|
874
|
+
return buildPluginPolicyElicitationResponse(pluginResolution.entry, requestParams);
|
|
875
|
+
}
|
|
876
|
+
const approvalPrompt = readComputerUseApprovalElicitation(requestParams, params.computerUseMcpServerName) ?? readBridgeableApprovalElicitation(requestParams);
|
|
877
|
+
if (!approvalPrompt) return;
|
|
878
|
+
const outcome = await requestPluginApprovalOutcome({
|
|
879
|
+
paramsForRun: params.paramsForRun,
|
|
880
|
+
title: approvalPrompt.title,
|
|
881
|
+
description: approvalPrompt.description,
|
|
882
|
+
signal: params.signal
|
|
883
|
+
});
|
|
884
|
+
return buildElicitationResponse(approvalPrompt.requestedSchema, approvalPrompt.meta, outcome);
|
|
885
|
+
}
|
|
886
|
+
function matchesCurrentThread(requestParams, threadId) {
|
|
887
|
+
if (!requestParams) return false;
|
|
888
|
+
return readString(requestParams, "threadId") === threadId;
|
|
889
|
+
}
|
|
890
|
+
function turnIdMismatches(requestParams, turnId) {
|
|
891
|
+
const rawTurnId = requestParams?.turnId;
|
|
892
|
+
return rawTurnId !== null && rawTurnId !== void 0 && rawTurnId !== turnId;
|
|
893
|
+
}
|
|
894
|
+
function hasExactTurnId(requestParams, turnId) {
|
|
895
|
+
return requestParams?.turnId === turnId;
|
|
896
|
+
}
|
|
897
|
+
function resolvePluginElicitation(params) {
|
|
898
|
+
const requestParams = params.requestParams;
|
|
899
|
+
if (!requestParams) return { kind: "not_plugin" };
|
|
900
|
+
const meta = isJsonObject(requestParams["_meta"]) ? requestParams["_meta"] : {};
|
|
901
|
+
const context = params.pluginAppPolicyContext;
|
|
902
|
+
const entries = context ? Object.values(context.apps) : [];
|
|
903
|
+
const appId = readFirstString(meta, PLUGIN_APP_ID_META_KEYS) ?? readFirstString(requestParams, PLUGIN_APP_ID_META_KEYS);
|
|
904
|
+
const connectorId = readFirstString(meta, PLUGIN_CONNECTOR_ID_META_KEYS);
|
|
905
|
+
const isCodexConnectorApproval = isCodexConnectorApprovalElicitation(requestParams, meta);
|
|
906
|
+
if (isCodexConnectorApproval && appId && connectorId && appId !== connectorId) return {
|
|
907
|
+
kind: "decline",
|
|
908
|
+
reason: "app_id_connector_id_mismatch"
|
|
909
|
+
};
|
|
910
|
+
if (appId) {
|
|
911
|
+
if (!context) return {
|
|
912
|
+
kind: "decline",
|
|
913
|
+
reason: "missing_policy_context"
|
|
914
|
+
};
|
|
915
|
+
const entry = context.apps[appId];
|
|
916
|
+
return uniquePluginMatch(entry ? [entry] : [], "app_id");
|
|
917
|
+
}
|
|
918
|
+
if (isCodexConnectorApproval && connectorId) {
|
|
919
|
+
if (!context) return {
|
|
920
|
+
kind: "decline",
|
|
921
|
+
reason: "missing_policy_context"
|
|
922
|
+
};
|
|
923
|
+
const entry = context.apps[connectorId];
|
|
924
|
+
return uniquePluginMatch(entry ? [entry] : [], "connector_id");
|
|
925
|
+
}
|
|
926
|
+
const serverName = readString(requestParams, "serverName");
|
|
927
|
+
if (serverName && context) {
|
|
928
|
+
const matches = entries.filter((entry) => entry.mcpServerNames.includes(serverName));
|
|
929
|
+
if (matches.length > 0) return uniquePluginMatch(matches, "server_name");
|
|
930
|
+
}
|
|
931
|
+
const metadataResolution = resolvePluginStableMetadataMatch({
|
|
932
|
+
meta,
|
|
933
|
+
requestParams,
|
|
934
|
+
entries,
|
|
935
|
+
context
|
|
936
|
+
});
|
|
937
|
+
if (metadataResolution.kind !== "not_plugin") return metadataResolution;
|
|
938
|
+
if (context && hasDisplayNameOnlyPluginMatch(meta, entries)) return {
|
|
939
|
+
kind: "decline",
|
|
940
|
+
reason: "display_name_only"
|
|
941
|
+
};
|
|
942
|
+
return { kind: "not_plugin" };
|
|
943
|
+
}
|
|
944
|
+
function isCodexConnectorApprovalElicitation(requestParams, meta) {
|
|
945
|
+
return readString(requestParams, "serverName") === CODEX_APPS_SERVER_NAME && readString(meta, MCP_TOOL_APPROVAL_KIND_KEY) === MCP_TOOL_APPROVAL_KIND && readString(meta, MCP_TOOL_APPROVAL_SOURCE_KEY) === MCP_TOOL_APPROVAL_CONNECTOR_SOURCE;
|
|
946
|
+
}
|
|
947
|
+
function resolvePluginStableMetadataMatch(params) {
|
|
948
|
+
const pluginName = readFirstString(params.meta, PLUGIN_NAME_META_KEYS) ?? readFirstString(params.requestParams, PLUGIN_NAME_META_KEYS);
|
|
949
|
+
const configKey = readFirstString(params.meta, PLUGIN_CONFIG_KEY_META_KEYS) ?? readFirstString(params.requestParams, PLUGIN_CONFIG_KEY_META_KEYS);
|
|
950
|
+
const marketplaceName = readFirstString(params.meta, PLUGIN_MARKETPLACE_NAME_META_KEYS) ?? readFirstString(params.requestParams, PLUGIN_MARKETPLACE_NAME_META_KEYS);
|
|
951
|
+
if (!pluginName && !configKey) return { kind: "not_plugin" };
|
|
952
|
+
if (!params.context) return {
|
|
953
|
+
kind: "decline",
|
|
954
|
+
reason: "missing_policy_context"
|
|
955
|
+
};
|
|
956
|
+
return uniquePluginMatch(params.entries.filter((entry) => {
|
|
957
|
+
if (marketplaceName && entry.marketplaceName !== marketplaceName) return false;
|
|
958
|
+
if (pluginName && entry.pluginName !== pluginName) return false;
|
|
959
|
+
if (configKey && entry.configKey !== configKey) return false;
|
|
960
|
+
return true;
|
|
961
|
+
}), "metadata");
|
|
962
|
+
}
|
|
963
|
+
function uniquePluginMatch(matches, source) {
|
|
964
|
+
if (matches.length === 1 && matches[0]) return {
|
|
965
|
+
kind: "matched",
|
|
966
|
+
entry: matches[0]
|
|
967
|
+
};
|
|
968
|
+
return {
|
|
969
|
+
kind: "decline",
|
|
970
|
+
reason: matches.length === 0 ? `${source}_not_enabled` : `${source}_ambiguous`
|
|
971
|
+
};
|
|
972
|
+
}
|
|
973
|
+
function hasDisplayNameOnlyPluginMatch(meta, entries) {
|
|
974
|
+
const connectorName = readString(meta, MCP_TOOL_APPROVAL_CONNECTOR_NAME_KEY);
|
|
975
|
+
if (!connectorName) return false;
|
|
976
|
+
const normalized = normalizePluginIdentityText(connectorName);
|
|
977
|
+
return entries.some((entry) => normalizePluginIdentityText(entry.pluginName) === normalized || normalizePluginIdentityText(entry.configKey) === normalized);
|
|
978
|
+
}
|
|
979
|
+
function normalizePluginIdentityText(value) {
|
|
980
|
+
return value.toLowerCase().replace(/[^a-z0-9]+/g, "");
|
|
981
|
+
}
|
|
982
|
+
function buildPluginPolicyElicitationResponse(entry, requestParams) {
|
|
983
|
+
if (!entry.allowDestructiveActions) {
|
|
984
|
+
logPluginElicitationDecline("destructive_actions_disabled", requestParams);
|
|
985
|
+
return declineElicitationResponse();
|
|
986
|
+
}
|
|
987
|
+
if (readString(requestParams, "mode") !== "form" || !isJsonObject(requestParams.requestedSchema)) {
|
|
988
|
+
logPluginElicitationDecline("unsupported_schema", requestParams);
|
|
989
|
+
return declineElicitationResponse();
|
|
990
|
+
}
|
|
991
|
+
const meta = isJsonObject(requestParams["_meta"]) ? requestParams["_meta"] : {};
|
|
992
|
+
const response = buildElicitationResponse(requestParams.requestedSchema, meta, "approved-once");
|
|
993
|
+
if (isJsonObject(response) && response.action === "accept") return response;
|
|
994
|
+
logPluginElicitationDecline("unmappable_schema", requestParams);
|
|
995
|
+
return declineElicitationResponse();
|
|
996
|
+
}
|
|
997
|
+
function declineElicitationResponse() {
|
|
998
|
+
return {
|
|
999
|
+
action: "decline",
|
|
1000
|
+
content: null,
|
|
1001
|
+
_meta: null
|
|
1002
|
+
};
|
|
1003
|
+
}
|
|
1004
|
+
function logPluginElicitationDecline(reason, requestParams) {
|
|
1005
|
+
log.debug("codex plugin elicitation declined", {
|
|
1006
|
+
reason,
|
|
1007
|
+
serverName: readString(requestParams, "serverName"),
|
|
1008
|
+
mode: readString(requestParams, "mode")
|
|
1009
|
+
});
|
|
1010
|
+
}
|
|
1011
|
+
function readBridgeableApprovalElicitation(requestParams) {
|
|
1012
|
+
if (!requestParams || readString(requestParams, "mode") !== "form" || !isJsonObject(requestParams["_meta"]) || requestParams["_meta"][MCP_TOOL_APPROVAL_KIND_KEY] !== MCP_TOOL_APPROVAL_KIND || !isJsonObject(requestParams.requestedSchema)) return;
|
|
1013
|
+
const requestedSchema = requestParams.requestedSchema;
|
|
1014
|
+
if (readString(requestedSchema, "type") !== "object" || !isJsonObject(requestedSchema.properties)) return;
|
|
1015
|
+
const title = sanitizeDisplayText(readString(requestParams, "message") ?? "") || "Codex MCP tool approval";
|
|
1016
|
+
return {
|
|
1017
|
+
title,
|
|
1018
|
+
description: buildApprovalDescription({
|
|
1019
|
+
title,
|
|
1020
|
+
meta: requestParams["_meta"],
|
|
1021
|
+
requestedSchema,
|
|
1022
|
+
serverName: sanitizeOptionalDisplayText(readString(requestParams, "serverName"))
|
|
1023
|
+
}),
|
|
1024
|
+
requestedSchema,
|
|
1025
|
+
meta: requestParams["_meta"]
|
|
1026
|
+
};
|
|
1027
|
+
}
|
|
1028
|
+
function readComputerUseApprovalElicitation(requestParams, expectedServerName) {
|
|
1029
|
+
const serverName = readString(requestParams, "serverName");
|
|
1030
|
+
if (!serverName || !expectedServerName || serverName !== expectedServerName || readString(requestParams, "mode") !== "form") return;
|
|
1031
|
+
const requestedSchema = isJsonObject(requestParams?.requestedSchema) ? requestParams.requestedSchema : EMPTY_OBJECT_SCHEMA;
|
|
1032
|
+
if (readString(requestedSchema, "type") !== "object" || !isJsonObject(requestedSchema.properties)) return;
|
|
1033
|
+
const meta = isJsonObject(requestParams?.["_meta"]) ? requestParams["_meta"] : {};
|
|
1034
|
+
const title = sanitizeDisplayText(readString(requestParams, "message") ?? "") || COMPUTER_USE_APPROVAL_TITLE;
|
|
1035
|
+
return {
|
|
1036
|
+
title,
|
|
1037
|
+
description: buildApprovalDescription({
|
|
1038
|
+
title,
|
|
1039
|
+
meta,
|
|
1040
|
+
requestedSchema,
|
|
1041
|
+
serverName: sanitizeOptionalDisplayText(serverName)
|
|
1042
|
+
}),
|
|
1043
|
+
requestedSchema,
|
|
1044
|
+
meta
|
|
1045
|
+
};
|
|
1046
|
+
}
|
|
1047
|
+
function buildApprovalDescription(params) {
|
|
1048
|
+
const connectorName = sanitizeOptionalDisplayText(readString(params.meta, MCP_TOOL_APPROVAL_CONNECTOR_NAME_KEY));
|
|
1049
|
+
const toolTitle = sanitizeOptionalDisplayText(readString(params.meta, MCP_TOOL_APPROVAL_TOOL_TITLE_KEY));
|
|
1050
|
+
const toolDescription = sanitizeOptionalDisplayText(readString(params.meta, MCP_TOOL_APPROVAL_TOOL_DESCRIPTION_KEY));
|
|
1051
|
+
const summaryLines = [
|
|
1052
|
+
connectorName && `App: ${connectorName}`,
|
|
1053
|
+
toolTitle && `Tool: ${toolTitle}`,
|
|
1054
|
+
params.serverName && `MCP server: ${params.serverName}`,
|
|
1055
|
+
toolDescription
|
|
1056
|
+
].filter((line) => Boolean(line));
|
|
1057
|
+
const paramLines = readDisplayParamLines(params.meta);
|
|
1058
|
+
const propertyLines = readPropertyDescriptionLines(params.requestedSchema);
|
|
1059
|
+
return [
|
|
1060
|
+
params.title,
|
|
1061
|
+
summaryLines.join("\n"),
|
|
1062
|
+
paramLines.length > 0 ? ["Parameters:", ...paramLines].join("\n") : "",
|
|
1063
|
+
propertyLines.length > 0 ? ["Fields:", ...propertyLines].join("\n") : ""
|
|
1064
|
+
].filter(Boolean).join("\n\n");
|
|
1065
|
+
}
|
|
1066
|
+
function readPropertyDescriptionLines(requestedSchema) {
|
|
1067
|
+
const properties = isJsonObject(requestedSchema.properties) ? requestedSchema.properties : {};
|
|
1068
|
+
return Object.entries(properties).map(([name, value]) => {
|
|
1069
|
+
const schema = isJsonObject(value) ? value : void 0;
|
|
1070
|
+
if (!schema) return;
|
|
1071
|
+
const propTitle = sanitizeDisplayText(readString(schema, "title") ?? "") || sanitizeDisplayText(name) || "field";
|
|
1072
|
+
const description = sanitizeOptionalDisplayText(readString(schema, "description"));
|
|
1073
|
+
return description ? `- ${propTitle}: ${description}` : `- ${propTitle}`;
|
|
1074
|
+
}).filter((line) => Boolean(line));
|
|
1075
|
+
}
|
|
1076
|
+
function readDisplayParamLines(meta) {
|
|
1077
|
+
const displayParams = meta[MCP_TOOL_APPROVAL_TOOL_PARAMS_DISPLAY_KEY];
|
|
1078
|
+
if (!Array.isArray(displayParams)) return [];
|
|
1079
|
+
const lines = displayParams.slice(0, MAX_DISPLAY_PARAM_ENTRIES).map((entry) => {
|
|
1080
|
+
const param = isJsonObject(entry) ? entry : void 0;
|
|
1081
|
+
if (!param) return;
|
|
1082
|
+
const name = sanitizeOptionalDisplayText(readString(param, "display_name")) ?? sanitizeOptionalDisplayText(readString(param, "name"));
|
|
1083
|
+
if (!name) return;
|
|
1084
|
+
return `- ${name}: ${formatDisplayParamValue(param.value)}`;
|
|
1085
|
+
}).filter((line) => Boolean(line));
|
|
1086
|
+
const remaining = displayParams.length - MAX_DISPLAY_PARAM_ENTRIES;
|
|
1087
|
+
return remaining > 0 ? [...lines, `- Additional parameters: ${remaining} more`] : lines;
|
|
1088
|
+
}
|
|
1089
|
+
function formatDisplayParamValue(value) {
|
|
1090
|
+
return truncateDisplayText(sanitizeDisplayText(typeof value === "string" ? value : formatDisplayJsonValue(value ?? null)), MAX_DISPLAY_PARAM_VALUE_LENGTH);
|
|
1091
|
+
}
|
|
1092
|
+
function formatDisplayJsonValue(value, depth = MAX_DISPLAY_VALUE_DEPTH) {
|
|
1093
|
+
if (value === null) return "null";
|
|
1094
|
+
if (typeof value === "string") return JSON.stringify(truncateDisplayText(sanitizeDisplayText(value), 80));
|
|
1095
|
+
if (typeof value === "number" || typeof value === "boolean") return String(value);
|
|
1096
|
+
if (Array.isArray(value)) {
|
|
1097
|
+
if (depth <= 0) return "[truncated]";
|
|
1098
|
+
const parts = [];
|
|
1099
|
+
const limit = Math.min(value.length, MAX_DISPLAY_VALUE_ARRAY_ITEMS);
|
|
1100
|
+
for (let i = 0; i < limit; i += 1) parts.push(formatDisplayJsonValue(value[i] ?? null, depth - 1));
|
|
1101
|
+
if (value.length > MAX_DISPLAY_VALUE_ARRAY_ITEMS) parts.push("...");
|
|
1102
|
+
return `[${parts.join(",")}]`;
|
|
1103
|
+
}
|
|
1104
|
+
if (typeof value === "object") {
|
|
1105
|
+
if (depth <= 0) return "{truncated}";
|
|
1106
|
+
const parts = [];
|
|
1107
|
+
let count = 0;
|
|
1108
|
+
let truncated = false;
|
|
1109
|
+
for (const key in value) {
|
|
1110
|
+
if (!Object.prototype.hasOwnProperty.call(value, key)) continue;
|
|
1111
|
+
if (count >= MAX_DISPLAY_VALUE_OBJECT_KEYS) {
|
|
1112
|
+
truncated = true;
|
|
1113
|
+
break;
|
|
1114
|
+
}
|
|
1115
|
+
const safeKey = truncateDisplayText(sanitizeDisplayText(key), 80);
|
|
1116
|
+
parts.push(`${JSON.stringify(safeKey)}:${formatDisplayJsonValue(value[key] ?? null, depth - 1)}`);
|
|
1117
|
+
count += 1;
|
|
1118
|
+
}
|
|
1119
|
+
if (truncated) parts.push("...");
|
|
1120
|
+
return `{${parts.join(",")}}`;
|
|
1121
|
+
}
|
|
1122
|
+
return "null";
|
|
1123
|
+
}
|
|
1124
|
+
function sanitizeOptionalDisplayText(value) {
|
|
1125
|
+
return (value === void 0 ? "" : sanitizeDisplayText(value)) || void 0;
|
|
1126
|
+
}
|
|
1127
|
+
function sanitizeDisplayText(value) {
|
|
1128
|
+
const scanned = value.slice(0, DISPLAY_TEXT_SCAN_MAX_LENGTH);
|
|
1129
|
+
const clipped = value.length > DISPLAY_TEXT_SCAN_MAX_LENGTH;
|
|
1130
|
+
const sanitized = scanned.replace(ANSI_OSC_SEQUENCE_RE, "").replace(ANSI_CONTROL_SEQUENCE_RE, "").replace(DANGLING_TERMINAL_SEQUENCE_SUFFIX_RE, "").replace(INVISIBLE_FORMATTING_CONTROL_RE, " ").replace(CONTROL_CHARACTER_RE, " ").replace(/\s+/g, " ").trim();
|
|
1131
|
+
const escaped = sanitized ? formatCodexDisplayText(sanitized) : "";
|
|
1132
|
+
return clipped && escaped ? `${escaped}...` : escaped;
|
|
1133
|
+
}
|
|
1134
|
+
function truncateDisplayText(value, maxLength) {
|
|
1135
|
+
return value.length <= maxLength ? value : `${value.slice(0, Math.max(0, maxLength - 3))}...`;
|
|
1136
|
+
}
|
|
1137
|
+
async function requestPluginApprovalOutcome(params) {
|
|
1138
|
+
try {
|
|
1139
|
+
const requestResult = await requestPluginApproval({
|
|
1140
|
+
paramsForRun: params.paramsForRun,
|
|
1141
|
+
title: params.title,
|
|
1142
|
+
description: params.description,
|
|
1143
|
+
severity: "warning",
|
|
1144
|
+
toolName: "codex_mcp_tool_approval"
|
|
1145
|
+
});
|
|
1146
|
+
const approvalId = requestResult?.id;
|
|
1147
|
+
if (!approvalId) return "unavailable";
|
|
1148
|
+
return mapExecDecisionToOutcome(approvalRequestExplicitlyUnavailable(requestResult) ? null : await waitForPluginApprovalDecision({
|
|
1149
|
+
approvalId,
|
|
1150
|
+
signal: params.signal
|
|
1151
|
+
}));
|
|
1152
|
+
} catch {
|
|
1153
|
+
return params.signal?.aborted ? "cancelled" : "denied";
|
|
1154
|
+
}
|
|
1155
|
+
}
|
|
1156
|
+
function buildElicitationResponse(requestedSchema, meta, outcome) {
|
|
1157
|
+
if (outcome === "cancelled") return {
|
|
1158
|
+
action: "cancel",
|
|
1159
|
+
content: null,
|
|
1160
|
+
_meta: null
|
|
1161
|
+
};
|
|
1162
|
+
if (outcome === "denied" || outcome === "unavailable") return {
|
|
1163
|
+
action: "decline",
|
|
1164
|
+
content: null,
|
|
1165
|
+
_meta: null
|
|
1166
|
+
};
|
|
1167
|
+
const content = buildAcceptedContent(requestedSchema, meta, outcome);
|
|
1168
|
+
if (!content) {
|
|
1169
|
+
if (hasNoSchemaProperties(requestedSchema)) return {
|
|
1170
|
+
action: "accept",
|
|
1171
|
+
content: null,
|
|
1172
|
+
_meta: buildAcceptedMeta(meta, outcome)
|
|
1173
|
+
};
|
|
1174
|
+
log.warn("codex MCP approval elicitation approved without a mappable response", {
|
|
1175
|
+
approvalKind: meta[MCP_TOOL_APPROVAL_KIND_KEY],
|
|
1176
|
+
fields: Object.keys(requestedSchema.properties ?? {}),
|
|
1177
|
+
outcome
|
|
1178
|
+
});
|
|
1179
|
+
return {
|
|
1180
|
+
action: "decline",
|
|
1181
|
+
content: null,
|
|
1182
|
+
_meta: null
|
|
1183
|
+
};
|
|
1184
|
+
}
|
|
1185
|
+
return {
|
|
1186
|
+
action: "accept",
|
|
1187
|
+
content,
|
|
1188
|
+
_meta: buildAcceptedMeta(meta, outcome)
|
|
1189
|
+
};
|
|
1190
|
+
}
|
|
1191
|
+
function buildAcceptedContent(requestedSchema, meta, outcome) {
|
|
1192
|
+
const properties = isJsonObject(requestedSchema.properties) ? requestedSchema.properties : void 0;
|
|
1193
|
+
if (!properties) return;
|
|
1194
|
+
const required = Array.isArray(requestedSchema.required) ? new Set(requestedSchema.required.filter((entry) => typeof entry === "string")) : /* @__PURE__ */ new Set();
|
|
1195
|
+
const content = {};
|
|
1196
|
+
let sawApprovalField = false;
|
|
1197
|
+
for (const [name, value] of Object.entries(properties)) {
|
|
1198
|
+
const schema = isJsonObject(value) ? value : void 0;
|
|
1199
|
+
if (!schema) continue;
|
|
1200
|
+
const property = {
|
|
1201
|
+
name,
|
|
1202
|
+
schema,
|
|
1203
|
+
required: required.has(name)
|
|
1204
|
+
};
|
|
1205
|
+
const next = readApprovalFieldValue(property, outcome) ?? readPersistFieldValue(property, meta, outcome) ?? readFallbackFieldValue(property, outcome);
|
|
1206
|
+
if (next === void 0) {
|
|
1207
|
+
if (isApprovalField(property)) sawApprovalField = true;
|
|
1208
|
+
if (property.required) return;
|
|
1209
|
+
continue;
|
|
1210
|
+
}
|
|
1211
|
+
if (isApprovalField(property)) sawApprovalField = true;
|
|
1212
|
+
content[name] = next;
|
|
1213
|
+
}
|
|
1214
|
+
return sawApprovalField ? content : void 0;
|
|
1215
|
+
}
|
|
1216
|
+
function readApprovalFieldValue(property, outcome) {
|
|
1217
|
+
if (!isApprovalField(property)) return;
|
|
1218
|
+
if (readString(property.schema, "type") === "boolean") return true;
|
|
1219
|
+
const options = readEnumOptions(property.schema);
|
|
1220
|
+
if (options.length === 0) return;
|
|
1221
|
+
const sessionChoice = options.find((option) => isSessionApprovalOption(option));
|
|
1222
|
+
const acceptChoice = options.find((option) => isPositiveApprovalOption(option));
|
|
1223
|
+
if (outcome === "approved-session") return sessionChoice?.value ?? acceptChoice?.value;
|
|
1224
|
+
return acceptChoice?.value ?? sessionChoice?.value;
|
|
1225
|
+
}
|
|
1226
|
+
function readPersistFieldValue(property, meta, outcome) {
|
|
1227
|
+
if (!isPersistField(property) || outcome !== "approved-session") return;
|
|
1228
|
+
const persistHints = readPersistHints(meta);
|
|
1229
|
+
const options = readEnumOptions(property.schema);
|
|
1230
|
+
if (options.length === 0) return;
|
|
1231
|
+
const preferred = choosePersistHint(persistHints);
|
|
1232
|
+
if (preferred) return options.find((option) => option.value === preferred || option.label === preferred)?.value;
|
|
1233
|
+
}
|
|
1234
|
+
function readDefaultValue(schema) {
|
|
1235
|
+
return schema.default;
|
|
1236
|
+
}
|
|
1237
|
+
function readFallbackFieldValue(property, outcome) {
|
|
1238
|
+
if (outcome === "approved-once" && isPersistField(property)) return;
|
|
1239
|
+
return readDefaultValue(property.schema);
|
|
1240
|
+
}
|
|
1241
|
+
function isApprovalField(property) {
|
|
1242
|
+
const haystack = propertyText(property).toLowerCase();
|
|
1243
|
+
return /\b(approve|approval|allow|accept|decision)\b/.test(haystack);
|
|
1244
|
+
}
|
|
1245
|
+
function isPersistField(property) {
|
|
1246
|
+
const haystack = propertyText(property).toLowerCase();
|
|
1247
|
+
return /\b(persist|session|always|scope)\b/.test(haystack);
|
|
1248
|
+
}
|
|
1249
|
+
function propertyText(property) {
|
|
1250
|
+
return [
|
|
1251
|
+
property.name,
|
|
1252
|
+
readString(property.schema, "title"),
|
|
1253
|
+
readString(property.schema, "description")
|
|
1254
|
+
].filter(Boolean).join(" ");
|
|
1255
|
+
}
|
|
1256
|
+
function readPersistHints(meta) {
|
|
1257
|
+
const raw = meta.persist;
|
|
1258
|
+
if (typeof raw === "string") return [raw];
|
|
1259
|
+
if (Array.isArray(raw)) return raw.filter((entry) => typeof entry === "string");
|
|
1260
|
+
return ["session", "always"];
|
|
1261
|
+
}
|
|
1262
|
+
function buildAcceptedMeta(meta, outcome) {
|
|
1263
|
+
if (outcome !== "approved-session") return null;
|
|
1264
|
+
const persist = choosePersistHint(readPersistHints(meta));
|
|
1265
|
+
return persist ? { persist } : null;
|
|
1266
|
+
}
|
|
1267
|
+
function choosePersistHint(persistHints) {
|
|
1268
|
+
if (persistHints.includes("always")) return "always";
|
|
1269
|
+
if (persistHints.includes("session")) return "session";
|
|
1270
|
+
}
|
|
1271
|
+
function hasNoSchemaProperties(requestedSchema) {
|
|
1272
|
+
const properties = isJsonObject(requestedSchema.properties) ? requestedSchema.properties : {};
|
|
1273
|
+
return Object.keys(properties).length === 0;
|
|
1274
|
+
}
|
|
1275
|
+
function readEnumOptions(schema) {
|
|
1276
|
+
if (Array.isArray(schema.enum)) {
|
|
1277
|
+
const values = schema.enum.filter((entry) => typeof entry === "string");
|
|
1278
|
+
const labels = Array.isArray(schema.enumNames) ? schema.enumNames.filter((entry) => typeof entry === "string") : [];
|
|
1279
|
+
return values.map((value, index) => ({
|
|
1280
|
+
value,
|
|
1281
|
+
label: labels[index] ?? value
|
|
1282
|
+
}));
|
|
1283
|
+
}
|
|
1284
|
+
if (Array.isArray(schema.oneOf)) return schema.oneOf.map((entry) => {
|
|
1285
|
+
const option = isJsonObject(entry) ? entry : void 0;
|
|
1286
|
+
const value = readString(option, "const");
|
|
1287
|
+
if (!value) return;
|
|
1288
|
+
return {
|
|
1289
|
+
value,
|
|
1290
|
+
label: readString(option, "title") ?? value
|
|
1291
|
+
};
|
|
1292
|
+
}).filter((entry) => Boolean(entry));
|
|
1293
|
+
return [];
|
|
1294
|
+
}
|
|
1295
|
+
function isPositiveApprovalOption(option) {
|
|
1296
|
+
const haystack = `${option.value} ${option.label}`.toLowerCase();
|
|
1297
|
+
return /\b(allow|approve|accept|yes|continue|proceed|true)\b/.test(haystack);
|
|
1298
|
+
}
|
|
1299
|
+
function isSessionApprovalOption(option) {
|
|
1300
|
+
const haystack = `${option.value} ${option.label}`.toLowerCase();
|
|
1301
|
+
return /\b(session|always|persistent)\b/.test(haystack) && /\b(allow|approve|accept)\b/.test(haystack);
|
|
1302
|
+
}
|
|
1303
|
+
function readString(record, key) {
|
|
1304
|
+
const value = record?.[key];
|
|
1305
|
+
return typeof value === "string" && value.trim() ? value : void 0;
|
|
1306
|
+
}
|
|
1307
|
+
function readFirstString(record, keys) {
|
|
1308
|
+
for (const key of keys) {
|
|
1309
|
+
const value = readString(record, key);
|
|
1310
|
+
if (value) return value;
|
|
1311
|
+
}
|
|
1312
|
+
}
|
|
1313
|
+
//#endregion
|
|
1314
|
+
//#region extensions/codex/src/app-server/native-hook-relay.ts
|
|
1315
|
+
const CODEX_NATIVE_HOOK_RELAY_EVENTS = [
|
|
1316
|
+
"pre_tool_use",
|
|
1317
|
+
"post_tool_use",
|
|
1318
|
+
"permission_request",
|
|
1319
|
+
"before_agent_finalize"
|
|
1320
|
+
];
|
|
1321
|
+
const CODEX_HOOK_EVENT_BY_NATIVE_EVENT = {
|
|
1322
|
+
pre_tool_use: "PreToolUse",
|
|
1323
|
+
post_tool_use: "PostToolUse",
|
|
1324
|
+
permission_request: "PermissionRequest",
|
|
1325
|
+
before_agent_finalize: "Stop"
|
|
1326
|
+
};
|
|
1327
|
+
const CODEX_HOOK_KEY_LABEL_BY_NATIVE_EVENT = {
|
|
1328
|
+
pre_tool_use: "pre_tool_use",
|
|
1329
|
+
post_tool_use: "post_tool_use",
|
|
1330
|
+
permission_request: "permission_request",
|
|
1331
|
+
before_agent_finalize: "stop"
|
|
1332
|
+
};
|
|
1333
|
+
const CODEX_SESSION_FLAGS_HOOK_SOURCE_PATHS = ["/<session-flags>/config.toml", "<session-flags>/config.toml"];
|
|
1334
|
+
function buildCodexNativeHookRelayConfig(params) {
|
|
1335
|
+
const events = params.events?.length ? params.events : CODEX_NATIVE_HOOK_RELAY_EVENTS;
|
|
1336
|
+
const selectedEvents = new Set(events);
|
|
1337
|
+
const config = { "features.hooks": true };
|
|
1338
|
+
const hookState = {};
|
|
1339
|
+
for (const event of CODEX_NATIVE_HOOK_RELAY_EVENTS) {
|
|
1340
|
+
const codexEvent = CODEX_HOOK_EVENT_BY_NATIVE_EVENT[event];
|
|
1341
|
+
const selected = selectedEvents.has(event);
|
|
1342
|
+
if (!selected || !params.relay.shouldRelayEvent(event)) {
|
|
1343
|
+
if (selected || params.clearOmittedEvents) config[`hooks.${codexEvent}`] = [];
|
|
1344
|
+
if (params.clearOmittedEvents) for (const sourcePath of CODEX_SESSION_FLAGS_HOOK_SOURCE_PATHS) hookState[`${sourcePath}:${CODEX_HOOK_KEY_LABEL_BY_NATIVE_EVENT[event]}:0:0`] = { enabled: false };
|
|
1345
|
+
continue;
|
|
1346
|
+
}
|
|
1347
|
+
const command = params.relay.commandForEvent(event);
|
|
1348
|
+
const timeout = normalizeHookTimeoutSec(params.hookTimeoutSec);
|
|
1349
|
+
config[`hooks.${codexEvent}`] = [{ hooks: [{
|
|
1350
|
+
type: "command",
|
|
1351
|
+
command,
|
|
1352
|
+
timeout,
|
|
1353
|
+
async: false,
|
|
1354
|
+
statusMessage: "DaoCore native hook relay"
|
|
1355
|
+
}] }];
|
|
1356
|
+
const state = {
|
|
1357
|
+
enabled: true,
|
|
1358
|
+
trusted_hash: codexCommandHookTrustedHash({
|
|
1359
|
+
event,
|
|
1360
|
+
command,
|
|
1361
|
+
timeout,
|
|
1362
|
+
statusMessage: "DaoCore native hook relay"
|
|
1363
|
+
})
|
|
1364
|
+
};
|
|
1365
|
+
for (const sourcePath of CODEX_SESSION_FLAGS_HOOK_SOURCE_PATHS) hookState[`${sourcePath}:${CODEX_HOOK_KEY_LABEL_BY_NATIVE_EVENT[event]}:0:0`] = state;
|
|
1366
|
+
}
|
|
1367
|
+
config["hooks.state"] = hookState;
|
|
1368
|
+
return config;
|
|
1369
|
+
}
|
|
1370
|
+
function buildCodexNativeHookRelayDisabledConfig() {
|
|
1371
|
+
return {
|
|
1372
|
+
"features.hooks": false,
|
|
1373
|
+
"hooks.PreToolUse": [],
|
|
1374
|
+
"hooks.PostToolUse": [],
|
|
1375
|
+
"hooks.PermissionRequest": [],
|
|
1376
|
+
"hooks.Stop": []
|
|
1377
|
+
};
|
|
1378
|
+
}
|
|
1379
|
+
function normalizeHookTimeoutSec(value) {
|
|
1380
|
+
return typeof value === "number" && Number.isFinite(value) && value > 0 ? Math.ceil(value) : 5;
|
|
1381
|
+
}
|
|
1382
|
+
function codexCommandHookTrustedHash(params) {
|
|
1383
|
+
const identity = {
|
|
1384
|
+
event_name: CODEX_HOOK_KEY_LABEL_BY_NATIVE_EVENT[params.event],
|
|
1385
|
+
hooks: [{
|
|
1386
|
+
async: false,
|
|
1387
|
+
command: params.command,
|
|
1388
|
+
statusMessage: params.statusMessage,
|
|
1389
|
+
timeout: params.timeout,
|
|
1390
|
+
type: "command"
|
|
1391
|
+
}]
|
|
1392
|
+
};
|
|
1393
|
+
return `sha256:${createHash("sha256").update(JSON.stringify(sortJsonValue(identity))).digest("hex")}`;
|
|
1394
|
+
}
|
|
1395
|
+
function sortJsonValue(value) {
|
|
1396
|
+
if (!value || typeof value !== "object") return value;
|
|
1397
|
+
if (Array.isArray(value)) return value.map(sortJsonValue);
|
|
1398
|
+
const sorted = {};
|
|
1399
|
+
for (const key of Object.keys(value).toSorted()) sorted[key] = sortJsonValue(value[key]);
|
|
1400
|
+
return sorted;
|
|
1401
|
+
}
|
|
1402
|
+
//#endregion
|
|
1403
|
+
//#region extensions/codex/src/app-server/vision-tools.ts
|
|
1404
|
+
function filterToolsForVisionInputs(tools, params) {
|
|
1405
|
+
if (!params.modelHasVision || !params.hasInboundImages) return tools;
|
|
1406
|
+
return tools.filter((tool) => tool.name !== "image");
|
|
1407
|
+
}
|
|
1408
|
+
//#endregion
|
|
1409
|
+
export { handleCodexAppServerElicitationRequest as a, emitDynamicToolTerminalDiagnostic as c, buildCodexNativeHookRelayDisabledConfig as i, handleCodexAppServerApprovalRequest as l, CODEX_NATIVE_HOOK_RELAY_EVENTS as n, emitDynamicToolErrorDiagnostic as o, buildCodexNativeHookRelayConfig as r, emitDynamicToolStartedDiagnostic as s, filterToolsForVisionInputs as t };
|