@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
|
@@ -1,1228 +0,0 @@
|
|
|
1
|
-
import { i as formatErrorMessage } from "./errors-D_oyTIw2.js";
|
|
2
|
-
import { n as resolvePreferredDaoCoreTmpDir } from "./tmp-daocore-dir-kDRsiZXM.js";
|
|
3
|
-
import { a as resolveWindowsSpawnProgram, r as materializeWindowsSpawnProgram } from "./windows-spawn-B76fGM3V.js";
|
|
4
|
-
import "./temp-path-CKL9wgHJ.js";
|
|
5
|
-
import "./agent-harness-runtime-dKUQFuOc.js";
|
|
6
|
-
import { a as isCodexFastServiceTier, l as resolveCodexAppServerRuntimeOptions, r as codexSandboxPolicyForTurn } from "./config-vVEQHNjq.js";
|
|
7
|
-
import { t as isJsonObject } from "./protocol-oeJQu4rs.js";
|
|
8
|
-
import { i as readCodexAppServerBinding, n as isCodexAppServerNativeAuthProfile, o as writeCodexAppServerBinding, r as normalizeCodexAppServerBindingModelProvider, t as clearCodexAppServerBinding } from "./session-binding-6bLobLHL.js";
|
|
9
|
-
import { n as CODEX_CONTROL_METHODS } from "./request-DlWPRUDt.js";
|
|
10
|
-
import { i as readCodexNotificationTurnId, r as readCodexNotificationThreadId, s as formatCodexDisplayText } from "./notification-correlation-qKY_sgga.js";
|
|
11
|
-
import { a as getSharedCodexAppServerClient, u as resolveCodexAppServerAuthProfileIdForAgent } from "./shared-client-yXjKgZBz.js";
|
|
12
|
-
import { n as resolveCodexNativeSandboxBlock } from "./sandbox-guard-DUeCOAh6.js";
|
|
13
|
-
import process from "node:process";
|
|
14
|
-
import { fileURLToPath } from "node:url";
|
|
15
|
-
import path from "node:path";
|
|
16
|
-
import fs from "node:fs/promises";
|
|
17
|
-
import os from "node:os";
|
|
18
|
-
import { spawn } from "node:child_process";
|
|
19
|
-
//#region extensions/codex/src/conversation-binding-data.ts
|
|
20
|
-
const BINDING_DATA_VERSION = 1;
|
|
21
|
-
function createCodexConversationBindingData(params) {
|
|
22
|
-
const agentDir = params.agentDir?.trim();
|
|
23
|
-
return {
|
|
24
|
-
kind: "codex-app-server-session",
|
|
25
|
-
version: BINDING_DATA_VERSION,
|
|
26
|
-
sessionFile: params.sessionFile,
|
|
27
|
-
workspaceDir: params.workspaceDir,
|
|
28
|
-
...agentDir ? { agentDir } : {}
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
function createCodexCliNodeConversationBindingData(params) {
|
|
32
|
-
const cwd = params.cwd?.trim();
|
|
33
|
-
return {
|
|
34
|
-
kind: "codex-cli-node-session",
|
|
35
|
-
version: BINDING_DATA_VERSION,
|
|
36
|
-
nodeId: params.nodeId,
|
|
37
|
-
sessionId: params.sessionId,
|
|
38
|
-
...cwd ? { cwd } : {}
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
function readCodexConversationBindingData(binding) {
|
|
42
|
-
const data = binding?.data;
|
|
43
|
-
if (!data || typeof data !== "object" || Array.isArray(data)) return;
|
|
44
|
-
return readCodexConversationBindingDataRecord(data);
|
|
45
|
-
}
|
|
46
|
-
function readCodexConversationBindingDataRecord(data) {
|
|
47
|
-
if (data.kind === "codex-cli-node-session") {
|
|
48
|
-
if (data.version !== BINDING_DATA_VERSION || typeof data.nodeId !== "string" || !data.nodeId.trim() || typeof data.sessionId !== "string" || !data.sessionId.trim()) return;
|
|
49
|
-
return {
|
|
50
|
-
kind: "codex-cli-node-session",
|
|
51
|
-
version: BINDING_DATA_VERSION,
|
|
52
|
-
nodeId: data.nodeId.trim(),
|
|
53
|
-
sessionId: data.sessionId.trim(),
|
|
54
|
-
cwd: typeof data.cwd === "string" && data.cwd.trim() ? data.cwd.trim() : void 0
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
if (data.kind !== "codex-app-server-session") return;
|
|
58
|
-
if (data.version !== BINDING_DATA_VERSION || typeof data.sessionFile !== "string" || !data.sessionFile.trim()) return;
|
|
59
|
-
return {
|
|
60
|
-
kind: "codex-app-server-session",
|
|
61
|
-
version: BINDING_DATA_VERSION,
|
|
62
|
-
sessionFile: data.sessionFile,
|
|
63
|
-
workspaceDir: typeof data.workspaceDir === "string" && data.workspaceDir.trim() ? data.workspaceDir : process.cwd(),
|
|
64
|
-
agentDir: typeof data.agentDir === "string" && data.agentDir.trim() ? data.agentDir : void 0
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
function resolveCodexDefaultWorkspaceDir(pluginConfig) {
|
|
68
|
-
return readString$1(readRecord$1(readRecord$1(pluginConfig)?.appServer), "defaultWorkspaceDir") ?? process.cwd();
|
|
69
|
-
}
|
|
70
|
-
function readRecord$1(value) {
|
|
71
|
-
return value && typeof value === "object" && !Array.isArray(value) ? value : void 0;
|
|
72
|
-
}
|
|
73
|
-
function readString$1(record, key) {
|
|
74
|
-
const value = record?.[key];
|
|
75
|
-
return typeof value === "string" && value.trim() ? value.trim() : void 0;
|
|
76
|
-
}
|
|
77
|
-
//#endregion
|
|
78
|
-
//#region extensions/codex/src/conversation-control.ts
|
|
79
|
-
const CODEX_CONVERSATION_CONTROL_STATE = Symbol.for("daocore.codex.conversationControl");
|
|
80
|
-
function getActiveTurns() {
|
|
81
|
-
const globalState = globalThis;
|
|
82
|
-
globalState[CODEX_CONVERSATION_CONTROL_STATE] ??= /* @__PURE__ */ new Map();
|
|
83
|
-
return globalState[CODEX_CONVERSATION_CONTROL_STATE];
|
|
84
|
-
}
|
|
85
|
-
function trackCodexConversationActiveTurn(active) {
|
|
86
|
-
const activeTurns = getActiveTurns();
|
|
87
|
-
activeTurns.set(active.sessionFile, active);
|
|
88
|
-
return () => {
|
|
89
|
-
if (activeTurns.get(active.sessionFile)?.turnId === active.turnId) activeTurns.delete(active.sessionFile);
|
|
90
|
-
};
|
|
91
|
-
}
|
|
92
|
-
function readCodexConversationActiveTurn(sessionFile) {
|
|
93
|
-
return getActiveTurns().get(sessionFile);
|
|
94
|
-
}
|
|
95
|
-
async function stopCodexConversationTurn(params) {
|
|
96
|
-
const active = readCodexConversationActiveTurn(params.sessionFile);
|
|
97
|
-
if (!active) return {
|
|
98
|
-
stopped: false,
|
|
99
|
-
message: "No active Codex run to stop."
|
|
100
|
-
};
|
|
101
|
-
const runtime = resolveCodexAppServerRuntimeOptions({ pluginConfig: params.pluginConfig });
|
|
102
|
-
const lookup = buildBindingLookup(params);
|
|
103
|
-
const binding = await readCodexAppServerBinding(params.sessionFile, lookup);
|
|
104
|
-
await (await getSharedCodexAppServerClient({
|
|
105
|
-
startOptions: runtime.start,
|
|
106
|
-
timeoutMs: runtime.requestTimeoutMs,
|
|
107
|
-
authProfileId: binding?.authProfileId,
|
|
108
|
-
...lookup
|
|
109
|
-
})).request("turn/interrupt", {
|
|
110
|
-
threadId: active.threadId,
|
|
111
|
-
turnId: active.turnId
|
|
112
|
-
}, { timeoutMs: runtime.requestTimeoutMs });
|
|
113
|
-
return {
|
|
114
|
-
stopped: true,
|
|
115
|
-
message: "Codex stop requested."
|
|
116
|
-
};
|
|
117
|
-
}
|
|
118
|
-
async function steerCodexConversationTurn(params) {
|
|
119
|
-
const active = readCodexConversationActiveTurn(params.sessionFile);
|
|
120
|
-
const text = params.message.trim();
|
|
121
|
-
if (!text) return {
|
|
122
|
-
steered: false,
|
|
123
|
-
message: "Usage: /codex steer <message>"
|
|
124
|
-
};
|
|
125
|
-
if (!active) return {
|
|
126
|
-
steered: false,
|
|
127
|
-
message: "No active Codex run to steer."
|
|
128
|
-
};
|
|
129
|
-
const runtime = resolveCodexAppServerRuntimeOptions({ pluginConfig: params.pluginConfig });
|
|
130
|
-
const lookup = buildBindingLookup(params);
|
|
131
|
-
const binding = await readCodexAppServerBinding(params.sessionFile, lookup);
|
|
132
|
-
await (await getSharedCodexAppServerClient({
|
|
133
|
-
startOptions: runtime.start,
|
|
134
|
-
timeoutMs: runtime.requestTimeoutMs,
|
|
135
|
-
authProfileId: binding?.authProfileId,
|
|
136
|
-
...lookup
|
|
137
|
-
})).request("turn/steer", {
|
|
138
|
-
threadId: active.threadId,
|
|
139
|
-
expectedTurnId: active.turnId,
|
|
140
|
-
input: [{
|
|
141
|
-
type: "text",
|
|
142
|
-
text,
|
|
143
|
-
text_elements: []
|
|
144
|
-
}]
|
|
145
|
-
}, { timeoutMs: runtime.requestTimeoutMs });
|
|
146
|
-
return {
|
|
147
|
-
steered: true,
|
|
148
|
-
message: "Sent steer message to Codex."
|
|
149
|
-
};
|
|
150
|
-
}
|
|
151
|
-
async function setCodexConversationModel(params) {
|
|
152
|
-
const model = params.model.trim();
|
|
153
|
-
if (!model) return "Usage: /codex model <model>";
|
|
154
|
-
const lookup = buildBindingLookup(params);
|
|
155
|
-
const binding = await requireThreadBinding(params.sessionFile, lookup);
|
|
156
|
-
const runtime = resolveCodexAppServerRuntimeOptions({ pluginConfig: params.pluginConfig });
|
|
157
|
-
const response = await resumeThreadWithOverrides({
|
|
158
|
-
pluginConfig: params.pluginConfig,
|
|
159
|
-
threadId: binding.threadId,
|
|
160
|
-
authProfileId: binding.authProfileId,
|
|
161
|
-
...lookup,
|
|
162
|
-
model
|
|
163
|
-
});
|
|
164
|
-
await writeCodexAppServerBinding(params.sessionFile, {
|
|
165
|
-
...binding,
|
|
166
|
-
cwd: response.thread.cwd ?? binding.cwd,
|
|
167
|
-
model: response.model ?? model,
|
|
168
|
-
modelProvider: response.modelProvider ?? binding.modelProvider,
|
|
169
|
-
approvalPolicy: binding.approvalPolicy,
|
|
170
|
-
sandbox: binding.sandbox,
|
|
171
|
-
serviceTier: binding.serviceTier ?? runtime.serviceTier
|
|
172
|
-
}, lookup);
|
|
173
|
-
return `Codex model set to ${formatCodexDisplayText(response.model ?? model)}.`;
|
|
174
|
-
}
|
|
175
|
-
async function setCodexConversationFastMode(params) {
|
|
176
|
-
const lookup = buildBindingLookup(params);
|
|
177
|
-
const binding = await requireThreadBinding(params.sessionFile, lookup);
|
|
178
|
-
if (params.enabled == null) return `Codex fast mode: ${isCodexFastServiceTier(binding.serviceTier) ? "on" : "off"}.`;
|
|
179
|
-
const serviceTier = params.enabled ? "priority" : "flex";
|
|
180
|
-
await writeCodexAppServerBinding(params.sessionFile, {
|
|
181
|
-
...binding,
|
|
182
|
-
serviceTier
|
|
183
|
-
}, lookup);
|
|
184
|
-
return `Codex fast mode ${params.enabled ? "enabled" : "disabled"}.`;
|
|
185
|
-
}
|
|
186
|
-
async function setCodexConversationPermissions(params) {
|
|
187
|
-
const lookup = buildBindingLookup(params);
|
|
188
|
-
const binding = await requireThreadBinding(params.sessionFile, lookup);
|
|
189
|
-
if (!params.mode) return `Codex permissions: ${formatPermissionsMode(binding)}.`;
|
|
190
|
-
const policy = permissionsForMode(params.mode);
|
|
191
|
-
await writeCodexAppServerBinding(params.sessionFile, {
|
|
192
|
-
...binding,
|
|
193
|
-
approvalPolicy: policy.approvalPolicy,
|
|
194
|
-
sandbox: policy.sandbox
|
|
195
|
-
}, lookup);
|
|
196
|
-
return `Codex permissions set to ${params.mode === "yolo" ? "full access" : "default"}.`;
|
|
197
|
-
}
|
|
198
|
-
function parseCodexFastModeArg(arg) {
|
|
199
|
-
const normalized = arg?.trim().toLowerCase();
|
|
200
|
-
if (!normalized || normalized === "status") return;
|
|
201
|
-
if (normalized === "on" || normalized === "true" || normalized === "fast") return true;
|
|
202
|
-
if (normalized === "off" || normalized === "false" || normalized === "flex") return false;
|
|
203
|
-
}
|
|
204
|
-
function parseCodexPermissionsModeArg(arg) {
|
|
205
|
-
const normalized = arg?.trim().toLowerCase();
|
|
206
|
-
if (!normalized || normalized === "status") return;
|
|
207
|
-
if (normalized === "yolo" || normalized === "full" || normalized === "full-access") return "yolo";
|
|
208
|
-
if (normalized === "default" || normalized === "guardian") return "default";
|
|
209
|
-
}
|
|
210
|
-
function formatPermissionsMode(binding) {
|
|
211
|
-
return binding.approvalPolicy === "never" && binding.sandbox === "danger-full-access" ? "full access" : "default";
|
|
212
|
-
}
|
|
213
|
-
async function requireThreadBinding(sessionFile, lookup = {}) {
|
|
214
|
-
const binding = await readCodexAppServerBinding(sessionFile, lookup);
|
|
215
|
-
if (!binding?.threadId) throw new Error("No Codex thread is attached to this DaoCore session yet.");
|
|
216
|
-
return binding;
|
|
217
|
-
}
|
|
218
|
-
async function resumeThreadWithOverrides(params) {
|
|
219
|
-
const runtime = resolveCodexAppServerRuntimeOptions({ pluginConfig: params.pluginConfig });
|
|
220
|
-
return await (await getSharedCodexAppServerClient({
|
|
221
|
-
startOptions: runtime.start,
|
|
222
|
-
timeoutMs: runtime.requestTimeoutMs,
|
|
223
|
-
authProfileId: params.authProfileId,
|
|
224
|
-
...buildBindingLookup(params)
|
|
225
|
-
})).request(CODEX_CONTROL_METHODS.resumeThread, {
|
|
226
|
-
threadId: params.threadId,
|
|
227
|
-
...params.model ? { model: params.model } : {},
|
|
228
|
-
approvalPolicy: params.approvalPolicy ?? runtime.approvalPolicy,
|
|
229
|
-
sandbox: params.sandbox ?? runtime.sandbox,
|
|
230
|
-
approvalsReviewer: runtime.approvalsReviewer,
|
|
231
|
-
...params.serviceTier ? { serviceTier: params.serviceTier } : {},
|
|
232
|
-
persistExtendedHistory: true
|
|
233
|
-
}, { timeoutMs: runtime.requestTimeoutMs });
|
|
234
|
-
}
|
|
235
|
-
function buildBindingLookup(params) {
|
|
236
|
-
const agentDir = params.agentDir?.trim();
|
|
237
|
-
return {
|
|
238
|
-
...agentDir ? { agentDir } : {},
|
|
239
|
-
...params.config ? { config: params.config } : {}
|
|
240
|
-
};
|
|
241
|
-
}
|
|
242
|
-
function permissionsForMode(mode) {
|
|
243
|
-
return mode === "yolo" ? {
|
|
244
|
-
approvalPolicy: "never",
|
|
245
|
-
sandbox: "danger-full-access"
|
|
246
|
-
} : {
|
|
247
|
-
approvalPolicy: "on-request",
|
|
248
|
-
sandbox: "workspace-write"
|
|
249
|
-
};
|
|
250
|
-
}
|
|
251
|
-
//#endregion
|
|
252
|
-
//#region extensions/codex/src/conversation-turn-collector.ts
|
|
253
|
-
const MAX_PENDING_NOTIFICATIONS_PER_TURN = 100;
|
|
254
|
-
function createCodexConversationTurnCollector(threadId) {
|
|
255
|
-
let turnId;
|
|
256
|
-
let completed = false;
|
|
257
|
-
let failedError;
|
|
258
|
-
let timeout;
|
|
259
|
-
const assistantTextByItem = /* @__PURE__ */ new Map();
|
|
260
|
-
const assistantOrder = [];
|
|
261
|
-
const pendingNotificationsByTurnId = /* @__PURE__ */ new Map();
|
|
262
|
-
let resolveCompletion;
|
|
263
|
-
let rejectCompletion;
|
|
264
|
-
const rememberItem = (itemId) => {
|
|
265
|
-
if (!assistantOrder.includes(itemId)) assistantOrder.push(itemId);
|
|
266
|
-
};
|
|
267
|
-
const collectReplyText = () => {
|
|
268
|
-
return assistantOrder.map((itemId) => assistantTextByItem.get(itemId)?.trim()).filter((text) => Boolean(text)).at(-1) ?? "";
|
|
269
|
-
};
|
|
270
|
-
const clearWaitState = () => {
|
|
271
|
-
if (timeout) {
|
|
272
|
-
clearTimeout(timeout);
|
|
273
|
-
timeout = void 0;
|
|
274
|
-
}
|
|
275
|
-
resolveCompletion = void 0;
|
|
276
|
-
rejectCompletion = void 0;
|
|
277
|
-
};
|
|
278
|
-
const finish = () => {
|
|
279
|
-
if (completed) return;
|
|
280
|
-
completed = true;
|
|
281
|
-
if (failedError) rejectCompletion?.(new Error(failedError));
|
|
282
|
-
else resolveCompletion?.({ replyText: collectReplyText() });
|
|
283
|
-
clearWaitState();
|
|
284
|
-
};
|
|
285
|
-
const handleNotification = (notification) => {
|
|
286
|
-
const params = isJsonObject(notification.params) ? notification.params : void 0;
|
|
287
|
-
if (!params || readCodexNotificationThreadId(params) !== threadId) return;
|
|
288
|
-
if (!turnId) {
|
|
289
|
-
const pendingTurnId = readNotificationTurnId(params);
|
|
290
|
-
if (pendingTurnId) {
|
|
291
|
-
const pending = pendingNotificationsByTurnId.get(pendingTurnId) ?? [];
|
|
292
|
-
if (pending.length < MAX_PENDING_NOTIFICATIONS_PER_TURN) {
|
|
293
|
-
pending.push(notification);
|
|
294
|
-
pendingNotificationsByTurnId.set(pendingTurnId, pending);
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
return;
|
|
298
|
-
}
|
|
299
|
-
if (!isNotificationForTurn(params, threadId, turnId)) return;
|
|
300
|
-
if (notification.method === "item/agentMessage/delta") {
|
|
301
|
-
const itemId = readString(params, "itemId") ?? readString(params, "id") ?? "assistant";
|
|
302
|
-
const delta = readTextString(params, "delta");
|
|
303
|
-
if (!delta) return;
|
|
304
|
-
rememberItem(itemId);
|
|
305
|
-
assistantTextByItem.set(itemId, `${assistantTextByItem.get(itemId) ?? ""}${delta}`);
|
|
306
|
-
return;
|
|
307
|
-
}
|
|
308
|
-
if (notification.method === "item/completed") {
|
|
309
|
-
const item = isJsonObject(params.item) ? params.item : void 0;
|
|
310
|
-
if (item?.type === "agentMessage") {
|
|
311
|
-
const itemId = readString(item, "id") ?? readString(params, "itemId") ?? "assistant";
|
|
312
|
-
const text = readTextString(item, "text");
|
|
313
|
-
if (text) {
|
|
314
|
-
rememberItem(itemId);
|
|
315
|
-
assistantTextByItem.set(itemId, text);
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
return;
|
|
319
|
-
}
|
|
320
|
-
if (notification.method === "turn/completed") {
|
|
321
|
-
const turn = isJsonObject(params.turn) ? params.turn : void 0;
|
|
322
|
-
if (readString(turn, "status") === "failed") failedError = readString(readRecord(turn?.error), "message") ?? "codex app-server turn failed";
|
|
323
|
-
const items = Array.isArray(turn?.items) ? turn.items : [];
|
|
324
|
-
for (const item of items) {
|
|
325
|
-
if (!isJsonObject(item) || item.type !== "agentMessage") continue;
|
|
326
|
-
const itemId = readString(item, "id") ?? `assistant-${assistantOrder.length + 1}`;
|
|
327
|
-
const text = readTextString(item, "text");
|
|
328
|
-
if (text) {
|
|
329
|
-
rememberItem(itemId);
|
|
330
|
-
assistantTextByItem.set(itemId, text);
|
|
331
|
-
}
|
|
332
|
-
}
|
|
333
|
-
finish();
|
|
334
|
-
}
|
|
335
|
-
};
|
|
336
|
-
return {
|
|
337
|
-
setTurnId(nextTurnId) {
|
|
338
|
-
turnId = nextTurnId;
|
|
339
|
-
const pending = pendingNotificationsByTurnId.get(nextTurnId) ?? [];
|
|
340
|
-
pendingNotificationsByTurnId.clear();
|
|
341
|
-
for (const notification of pending) handleNotification(notification);
|
|
342
|
-
},
|
|
343
|
-
handleNotification,
|
|
344
|
-
wait(params) {
|
|
345
|
-
if (completed) return failedError ? Promise.reject(new Error(failedError)) : Promise.resolve({ replyText: collectReplyText() });
|
|
346
|
-
return new Promise((resolve, reject) => {
|
|
347
|
-
resolveCompletion = resolve;
|
|
348
|
-
rejectCompletion = reject;
|
|
349
|
-
timeout = setTimeout(() => {
|
|
350
|
-
completed = true;
|
|
351
|
-
reject(/* @__PURE__ */ new Error("codex app-server bound turn timed out"));
|
|
352
|
-
clearWaitState();
|
|
353
|
-
}, Math.max(100, params.timeoutMs));
|
|
354
|
-
timeout.unref?.();
|
|
355
|
-
});
|
|
356
|
-
}
|
|
357
|
-
};
|
|
358
|
-
}
|
|
359
|
-
function isNotificationForTurn(params, threadId, turnId) {
|
|
360
|
-
if (readCodexNotificationThreadId(params) !== threadId) return false;
|
|
361
|
-
if (!turnId) return true;
|
|
362
|
-
const directTurnId = readString(params, "turnId");
|
|
363
|
-
if (directTurnId) return directTurnId === turnId;
|
|
364
|
-
return readString(isJsonObject(params.turn) ? params.turn : void 0, "id") === turnId;
|
|
365
|
-
}
|
|
366
|
-
function readNotificationTurnId(params) {
|
|
367
|
-
return readCodexNotificationTurnId(params);
|
|
368
|
-
}
|
|
369
|
-
function readRecord(value) {
|
|
370
|
-
return value && typeof value === "object" && !Array.isArray(value) ? value : void 0;
|
|
371
|
-
}
|
|
372
|
-
function readString(record, key) {
|
|
373
|
-
const value = record?.[key];
|
|
374
|
-
return typeof value === "string" && value.trim() ? value.trim() : void 0;
|
|
375
|
-
}
|
|
376
|
-
function readTextString(record, key) {
|
|
377
|
-
const value = record?.[key];
|
|
378
|
-
return typeof value === "string" && value.length > 0 ? value : void 0;
|
|
379
|
-
}
|
|
380
|
-
//#endregion
|
|
381
|
-
//#region extensions/codex/src/conversation-turn-input.ts
|
|
382
|
-
const IMAGE_EXTENSIONS = new Set([
|
|
383
|
-
".avif",
|
|
384
|
-
".gif",
|
|
385
|
-
".jpeg",
|
|
386
|
-
".jpg",
|
|
387
|
-
".png",
|
|
388
|
-
".webp"
|
|
389
|
-
]);
|
|
390
|
-
function buildCodexConversationTurnInput(params) {
|
|
391
|
-
return [{
|
|
392
|
-
type: "text",
|
|
393
|
-
text: params.prompt,
|
|
394
|
-
text_elements: []
|
|
395
|
-
}, ...extractInboundMedia(params.event).map(toCodexImageInput).filter((item) => item !== void 0)];
|
|
396
|
-
}
|
|
397
|
-
function extractInboundMedia(event) {
|
|
398
|
-
const metadata = event.metadata ?? {};
|
|
399
|
-
const paths = readStringArray(metadata.mediaPaths).concat(readStringArray(metadata.mediaPath));
|
|
400
|
-
const urls = readStringArray(metadata.mediaUrls).concat(readStringArray(metadata.mediaUrl));
|
|
401
|
-
const mimeTypes = readStringArray(metadata.mediaTypes).concat(readStringArray(metadata.mediaType));
|
|
402
|
-
const count = Math.max(paths.length, urls.length, mimeTypes.length);
|
|
403
|
-
const media = [];
|
|
404
|
-
for (let index = 0; index < count; index += 1) media.push({
|
|
405
|
-
path: paths[index],
|
|
406
|
-
url: urls[index],
|
|
407
|
-
mimeType: mimeTypes[index] ?? mimeTypes[0]
|
|
408
|
-
});
|
|
409
|
-
return media;
|
|
410
|
-
}
|
|
411
|
-
function toCodexImageInput(media) {
|
|
412
|
-
if (!isImageMedia(media)) return;
|
|
413
|
-
const localPath = media.path ?? readLocalMediaPath(media.url);
|
|
414
|
-
if (localPath) {
|
|
415
|
-
const normalized = normalizeFileUrl(localPath);
|
|
416
|
-
return normalized ? {
|
|
417
|
-
type: "localImage",
|
|
418
|
-
path: normalized
|
|
419
|
-
} : void 0;
|
|
420
|
-
}
|
|
421
|
-
return media.url ? {
|
|
422
|
-
type: "image",
|
|
423
|
-
url: media.url
|
|
424
|
-
} : void 0;
|
|
425
|
-
}
|
|
426
|
-
function isImageMedia(media) {
|
|
427
|
-
if (media.mimeType?.toLowerCase().startsWith("image/")) return true;
|
|
428
|
-
const candidate = media.path ?? media.url;
|
|
429
|
-
if (!candidate) return false;
|
|
430
|
-
return IMAGE_EXTENSIONS.has(path.extname(candidate.split(/[?#]/, 1)[0] ?? "").toLowerCase());
|
|
431
|
-
}
|
|
432
|
-
function normalizeFileUrl(value) {
|
|
433
|
-
if (!value.startsWith("file://")) return value;
|
|
434
|
-
try {
|
|
435
|
-
return fileURLToPath(value);
|
|
436
|
-
} catch {
|
|
437
|
-
return;
|
|
438
|
-
}
|
|
439
|
-
}
|
|
440
|
-
function readLocalMediaPath(value) {
|
|
441
|
-
if (!value) return;
|
|
442
|
-
if (value.startsWith("file://")) return value;
|
|
443
|
-
if (value.startsWith("//")) return;
|
|
444
|
-
if (path.isAbsolute(value) || path.win32.isAbsolute(value)) return value;
|
|
445
|
-
return /^[a-z][a-z0-9+.-]*:/i.test(value) ? void 0 : value;
|
|
446
|
-
}
|
|
447
|
-
function readStringArray(value) {
|
|
448
|
-
if (typeof value === "string" && value.trim()) return [value.trim()];
|
|
449
|
-
if (!Array.isArray(value)) return [];
|
|
450
|
-
return value.map((entry) => typeof entry === "string" ? entry.trim() : "").filter(Boolean);
|
|
451
|
-
}
|
|
452
|
-
//#endregion
|
|
453
|
-
//#region extensions/codex/src/conversation-binding.ts
|
|
454
|
-
const DEFAULT_BOUND_TURN_TIMEOUT_MS = 20 * 6e4;
|
|
455
|
-
const CODEX_CONVERSATION_GLOBAL_STATE = Symbol.for("daocore.codex.conversationBinding");
|
|
456
|
-
function getGlobalState() {
|
|
457
|
-
const globalState = globalThis;
|
|
458
|
-
globalState[CODEX_CONVERSATION_GLOBAL_STATE] ??= { queues: /* @__PURE__ */ new Map() };
|
|
459
|
-
return globalState[CODEX_CONVERSATION_GLOBAL_STATE];
|
|
460
|
-
}
|
|
461
|
-
async function startCodexConversationThread(params) {
|
|
462
|
-
const workspaceDir = params.workspaceDir?.trim() || resolveCodexDefaultWorkspaceDir(params.pluginConfig);
|
|
463
|
-
const agentDir = params.agentDir?.trim();
|
|
464
|
-
const agentLookup = buildAgentLookup({
|
|
465
|
-
agentDir,
|
|
466
|
-
config: params.config
|
|
467
|
-
});
|
|
468
|
-
const existingBinding = await readCodexAppServerBinding(params.sessionFile, { ...agentLookup });
|
|
469
|
-
const authProfileId = resolveCodexAppServerAuthProfileIdForAgent({
|
|
470
|
-
authProfileId: params.authProfileId ?? existingBinding?.authProfileId,
|
|
471
|
-
...agentLookup
|
|
472
|
-
});
|
|
473
|
-
if (params.threadId?.trim()) await attachExistingThread({
|
|
474
|
-
pluginConfig: params.pluginConfig,
|
|
475
|
-
sessionFile: params.sessionFile,
|
|
476
|
-
threadId: params.threadId.trim(),
|
|
477
|
-
workspaceDir,
|
|
478
|
-
...agentDir ? { agentDir } : {},
|
|
479
|
-
model: params.model,
|
|
480
|
-
modelProvider: params.modelProvider,
|
|
481
|
-
authProfileId,
|
|
482
|
-
approvalPolicy: params.approvalPolicy,
|
|
483
|
-
sandbox: params.sandbox,
|
|
484
|
-
serviceTier: params.serviceTier,
|
|
485
|
-
config: params.config
|
|
486
|
-
});
|
|
487
|
-
else await createThread({
|
|
488
|
-
pluginConfig: params.pluginConfig,
|
|
489
|
-
sessionFile: params.sessionFile,
|
|
490
|
-
workspaceDir,
|
|
491
|
-
...agentDir ? { agentDir } : {},
|
|
492
|
-
model: params.model,
|
|
493
|
-
modelProvider: params.modelProvider,
|
|
494
|
-
authProfileId,
|
|
495
|
-
approvalPolicy: params.approvalPolicy,
|
|
496
|
-
sandbox: params.sandbox,
|
|
497
|
-
serviceTier: params.serviceTier,
|
|
498
|
-
config: params.config
|
|
499
|
-
});
|
|
500
|
-
return createCodexConversationBindingData({
|
|
501
|
-
sessionFile: params.sessionFile,
|
|
502
|
-
workspaceDir,
|
|
503
|
-
...agentDir ? { agentDir } : {}
|
|
504
|
-
});
|
|
505
|
-
}
|
|
506
|
-
async function handleCodexConversationInboundClaim(event, ctx, options = {}) {
|
|
507
|
-
const data = readCodexConversationBindingData(ctx.pluginBinding);
|
|
508
|
-
if (!data) return;
|
|
509
|
-
if (event.commandAuthorized !== true) return { handled: true };
|
|
510
|
-
const prompt = event.bodyForAgent?.trim() || event.content?.trim() || "";
|
|
511
|
-
if (!prompt) return { handled: true };
|
|
512
|
-
const sandboxBlock = resolveCodexNativeSandboxBlock({
|
|
513
|
-
config: options.config,
|
|
514
|
-
sessionKey: event.sessionKey ?? ctx.sessionKey,
|
|
515
|
-
surface: data.kind === "codex-cli-node-session" ? "Codex CLI node conversation binding" : "Codex app-server conversation binding"
|
|
516
|
-
});
|
|
517
|
-
if (sandboxBlock) return {
|
|
518
|
-
handled: true,
|
|
519
|
-
reply: { text: sandboxBlock }
|
|
520
|
-
};
|
|
521
|
-
if (data.kind === "codex-cli-node-session") {
|
|
522
|
-
const resume = options.resumeCodexCliSessionOnNode;
|
|
523
|
-
if (!resume) return {
|
|
524
|
-
handled: true,
|
|
525
|
-
reply: { text: "Codex CLI node binding is unavailable because Gateway node runtime is not attached." }
|
|
526
|
-
};
|
|
527
|
-
try {
|
|
528
|
-
return {
|
|
529
|
-
handled: true,
|
|
530
|
-
reply: (await enqueueBoundTurn(`${data.nodeId}:${data.sessionId}`, async () => {
|
|
531
|
-
return { reply: { text: (await resume({
|
|
532
|
-
nodeId: data.nodeId,
|
|
533
|
-
sessionId: data.sessionId,
|
|
534
|
-
prompt,
|
|
535
|
-
cwd: data.cwd,
|
|
536
|
-
timeoutMs: options.timeoutMs
|
|
537
|
-
})).text.trim() || "Codex completed without a text reply." } };
|
|
538
|
-
})).reply
|
|
539
|
-
};
|
|
540
|
-
} catch (error) {
|
|
541
|
-
return {
|
|
542
|
-
handled: true,
|
|
543
|
-
reply: { text: `Codex CLI node turn failed: ${formatCodexDisplayText(formatErrorMessage(error))}` }
|
|
544
|
-
};
|
|
545
|
-
}
|
|
546
|
-
}
|
|
547
|
-
try {
|
|
548
|
-
return {
|
|
549
|
-
handled: true,
|
|
550
|
-
reply: (await enqueueBoundTurn(data.sessionFile, () => runBoundTurnWithMissingThreadRecovery({
|
|
551
|
-
data,
|
|
552
|
-
prompt,
|
|
553
|
-
event,
|
|
554
|
-
pluginConfig: options.pluginConfig,
|
|
555
|
-
timeoutMs: options.timeoutMs
|
|
556
|
-
}))).reply
|
|
557
|
-
};
|
|
558
|
-
} catch (error) {
|
|
559
|
-
return {
|
|
560
|
-
handled: true,
|
|
561
|
-
reply: { text: `Codex app-server turn failed: ${formatCodexDisplayText(formatErrorMessage(error))}` }
|
|
562
|
-
};
|
|
563
|
-
}
|
|
564
|
-
}
|
|
565
|
-
async function handleCodexConversationBindingResolved(event) {
|
|
566
|
-
if (event.status !== "denied") return;
|
|
567
|
-
const data = readCodexConversationBindingDataRecord(event.request.data ?? {});
|
|
568
|
-
if (!data || data.kind !== "codex-app-server-session") return;
|
|
569
|
-
await clearCodexAppServerBinding(data.sessionFile);
|
|
570
|
-
}
|
|
571
|
-
async function attachExistingThread(params) {
|
|
572
|
-
const runtime = resolveCodexAppServerRuntimeOptions({ pluginConfig: params.pluginConfig });
|
|
573
|
-
const agentLookup = buildAgentLookup({
|
|
574
|
-
agentDir: params.agentDir,
|
|
575
|
-
config: params.config
|
|
576
|
-
});
|
|
577
|
-
const modelProvider = resolveThreadRequestModelProvider({
|
|
578
|
-
authProfileId: params.authProfileId,
|
|
579
|
-
modelProvider: params.modelProvider,
|
|
580
|
-
...agentLookup
|
|
581
|
-
});
|
|
582
|
-
const response = await (await getSharedCodexAppServerClient({
|
|
583
|
-
startOptions: runtime.start,
|
|
584
|
-
timeoutMs: runtime.requestTimeoutMs,
|
|
585
|
-
authProfileId: params.authProfileId,
|
|
586
|
-
...agentLookup
|
|
587
|
-
})).request(CODEX_CONTROL_METHODS.resumeThread, {
|
|
588
|
-
threadId: params.threadId,
|
|
589
|
-
...params.model ? { model: params.model } : {},
|
|
590
|
-
...modelProvider ? { modelProvider } : {},
|
|
591
|
-
approvalPolicy: params.approvalPolicy ?? runtime.approvalPolicy,
|
|
592
|
-
approvalsReviewer: runtime.approvalsReviewer,
|
|
593
|
-
sandbox: params.sandbox ?? runtime.sandbox,
|
|
594
|
-
...params.serviceTier ?? runtime.serviceTier ? { serviceTier: params.serviceTier ?? runtime.serviceTier } : {},
|
|
595
|
-
persistExtendedHistory: true
|
|
596
|
-
}, { timeoutMs: runtime.requestTimeoutMs });
|
|
597
|
-
const thread = response.thread;
|
|
598
|
-
const runtimeApprovalPolicy = typeof runtime.approvalPolicy === "string" ? runtime.approvalPolicy : void 0;
|
|
599
|
-
await writeCodexAppServerBinding(params.sessionFile, {
|
|
600
|
-
threadId: thread.id,
|
|
601
|
-
cwd: thread.cwd ?? params.workspaceDir,
|
|
602
|
-
authProfileId: params.authProfileId,
|
|
603
|
-
model: response.model ?? params.model,
|
|
604
|
-
modelProvider: normalizeCodexAppServerBindingModelProvider({
|
|
605
|
-
authProfileId: params.authProfileId,
|
|
606
|
-
modelProvider: response.modelProvider ?? params.modelProvider,
|
|
607
|
-
...agentLookup
|
|
608
|
-
}),
|
|
609
|
-
approvalPolicy: params.approvalPolicy ?? runtimeApprovalPolicy,
|
|
610
|
-
sandbox: params.sandbox ?? runtime.sandbox,
|
|
611
|
-
serviceTier: params.serviceTier ?? runtime.serviceTier
|
|
612
|
-
}, { ...agentLookup });
|
|
613
|
-
}
|
|
614
|
-
async function createThread(params) {
|
|
615
|
-
const runtime = resolveCodexAppServerRuntimeOptions({ pluginConfig: params.pluginConfig });
|
|
616
|
-
const agentLookup = buildAgentLookup({
|
|
617
|
-
agentDir: params.agentDir,
|
|
618
|
-
config: params.config
|
|
619
|
-
});
|
|
620
|
-
const modelProvider = resolveThreadRequestModelProvider({
|
|
621
|
-
authProfileId: params.authProfileId,
|
|
622
|
-
modelProvider: params.modelProvider,
|
|
623
|
-
...agentLookup
|
|
624
|
-
});
|
|
625
|
-
const response = await (await getSharedCodexAppServerClient({
|
|
626
|
-
startOptions: runtime.start,
|
|
627
|
-
timeoutMs: runtime.requestTimeoutMs,
|
|
628
|
-
authProfileId: params.authProfileId,
|
|
629
|
-
...agentLookup
|
|
630
|
-
})).request("thread/start", {
|
|
631
|
-
cwd: params.workspaceDir,
|
|
632
|
-
...params.model ? { model: params.model } : {},
|
|
633
|
-
...modelProvider ? { modelProvider } : {},
|
|
634
|
-
approvalPolicy: params.approvalPolicy ?? runtime.approvalPolicy,
|
|
635
|
-
approvalsReviewer: runtime.approvalsReviewer,
|
|
636
|
-
sandbox: params.sandbox ?? runtime.sandbox,
|
|
637
|
-
...params.serviceTier ?? runtime.serviceTier ? { serviceTier: params.serviceTier ?? runtime.serviceTier } : {},
|
|
638
|
-
developerInstructions: "This Codex thread is bound to an DaoCore conversation. Answer normally; DaoCore will deliver your final response back to the conversation.",
|
|
639
|
-
experimentalRawEvents: true,
|
|
640
|
-
persistExtendedHistory: true
|
|
641
|
-
}, { timeoutMs: runtime.requestTimeoutMs });
|
|
642
|
-
const runtimeApprovalPolicy = typeof runtime.approvalPolicy === "string" ? runtime.approvalPolicy : void 0;
|
|
643
|
-
await writeCodexAppServerBinding(params.sessionFile, {
|
|
644
|
-
threadId: response.thread.id,
|
|
645
|
-
cwd: response.thread.cwd ?? params.workspaceDir,
|
|
646
|
-
authProfileId: params.authProfileId,
|
|
647
|
-
model: response.model ?? params.model,
|
|
648
|
-
modelProvider: normalizeCodexAppServerBindingModelProvider({
|
|
649
|
-
authProfileId: params.authProfileId,
|
|
650
|
-
modelProvider: response.modelProvider ?? params.modelProvider,
|
|
651
|
-
...agentLookup
|
|
652
|
-
}),
|
|
653
|
-
approvalPolicy: params.approvalPolicy ?? runtimeApprovalPolicy,
|
|
654
|
-
sandbox: params.sandbox ?? runtime.sandbox,
|
|
655
|
-
serviceTier: params.serviceTier ?? runtime.serviceTier
|
|
656
|
-
}, { ...agentLookup });
|
|
657
|
-
}
|
|
658
|
-
async function runBoundTurn(params) {
|
|
659
|
-
const runtime = resolveCodexAppServerRuntimeOptions({ pluginConfig: params.pluginConfig });
|
|
660
|
-
const agentLookup = buildAgentLookup({ agentDir: params.data.agentDir });
|
|
661
|
-
const binding = await readCodexAppServerBinding(params.data.sessionFile, agentLookup);
|
|
662
|
-
const threadId = binding?.threadId;
|
|
663
|
-
if (!threadId) throw new Error("bound Codex conversation has no thread binding");
|
|
664
|
-
const client = await getSharedCodexAppServerClient({
|
|
665
|
-
startOptions: runtime.start,
|
|
666
|
-
timeoutMs: runtime.requestTimeoutMs,
|
|
667
|
-
authProfileId: binding.authProfileId,
|
|
668
|
-
...agentLookup
|
|
669
|
-
});
|
|
670
|
-
const collector = createCodexConversationTurnCollector(threadId);
|
|
671
|
-
const notificationCleanup = client.addNotificationHandler((notification) => collector.handleNotification(notification));
|
|
672
|
-
const requestCleanup = client.addRequestHandler(async (request) => {
|
|
673
|
-
if (request.method === "item/tool/call") return {
|
|
674
|
-
contentItems: [{
|
|
675
|
-
type: "inputText",
|
|
676
|
-
text: "DaoCore native Codex conversation binding does not expose dynamic DaoCore tools yet."
|
|
677
|
-
}],
|
|
678
|
-
success: false
|
|
679
|
-
};
|
|
680
|
-
if (request.method === "item/commandExecution/requestApproval" || request.method === "item/fileChange/requestApproval") return {
|
|
681
|
-
decision: "decline",
|
|
682
|
-
reason: "DaoCore native Codex conversation binding cannot route interactive approvals yet; use the Codex harness or explicit /acp spawn codex for that workflow."
|
|
683
|
-
};
|
|
684
|
-
if (request.method === "item/permissions/requestApproval") return {
|
|
685
|
-
permissions: {},
|
|
686
|
-
scope: "turn"
|
|
687
|
-
};
|
|
688
|
-
if (request.method.includes("requestApproval")) return {
|
|
689
|
-
decision: "decline",
|
|
690
|
-
reason: "DaoCore native Codex conversation binding cannot route interactive approvals yet; use the Codex harness or explicit /acp spawn codex for that workflow."
|
|
691
|
-
};
|
|
692
|
-
});
|
|
693
|
-
try {
|
|
694
|
-
const turnId = (await client.request("turn/start", {
|
|
695
|
-
threadId,
|
|
696
|
-
input: buildCodexConversationTurnInput({
|
|
697
|
-
prompt: params.prompt,
|
|
698
|
-
event: params.event
|
|
699
|
-
}),
|
|
700
|
-
cwd: binding.cwd || params.data.workspaceDir,
|
|
701
|
-
approvalPolicy: binding.approvalPolicy ?? runtime.approvalPolicy,
|
|
702
|
-
approvalsReviewer: runtime.approvalsReviewer,
|
|
703
|
-
sandboxPolicy: codexSandboxPolicyForTurn(binding.sandbox ?? runtime.sandbox, binding.cwd || params.data.workspaceDir),
|
|
704
|
-
...binding.model ? { model: binding.model } : {},
|
|
705
|
-
...binding.serviceTier ?? runtime.serviceTier ? { serviceTier: binding.serviceTier ?? runtime.serviceTier } : {}
|
|
706
|
-
}, { timeoutMs: runtime.requestTimeoutMs })).turn.id;
|
|
707
|
-
const activeCleanup = trackCodexConversationActiveTurn({
|
|
708
|
-
sessionFile: params.data.sessionFile,
|
|
709
|
-
threadId,
|
|
710
|
-
turnId
|
|
711
|
-
});
|
|
712
|
-
collector.setTurnId(turnId);
|
|
713
|
-
return { reply: { text: (await collector.wait({ timeoutMs: params.timeoutMs ?? DEFAULT_BOUND_TURN_TIMEOUT_MS }).finally(activeCleanup)).replyText.trim() || "Codex completed without a text reply." } };
|
|
714
|
-
} finally {
|
|
715
|
-
notificationCleanup();
|
|
716
|
-
requestCleanup();
|
|
717
|
-
}
|
|
718
|
-
}
|
|
719
|
-
async function runBoundTurnWithMissingThreadRecovery(params) {
|
|
720
|
-
try {
|
|
721
|
-
return await runBoundTurn(params);
|
|
722
|
-
} catch (error) {
|
|
723
|
-
if (!isCodexThreadNotFoundError(error)) throw error;
|
|
724
|
-
const agentLookup = buildAgentLookup({ agentDir: params.data.agentDir });
|
|
725
|
-
const binding = await readCodexAppServerBinding(params.data.sessionFile, agentLookup);
|
|
726
|
-
await startCodexConversationThread({
|
|
727
|
-
pluginConfig: params.pluginConfig,
|
|
728
|
-
sessionFile: params.data.sessionFile,
|
|
729
|
-
workspaceDir: binding?.cwd || params.data.workspaceDir,
|
|
730
|
-
...agentLookup,
|
|
731
|
-
model: binding?.model,
|
|
732
|
-
modelProvider: binding?.modelProvider,
|
|
733
|
-
authProfileId: binding?.authProfileId,
|
|
734
|
-
approvalPolicy: binding?.approvalPolicy,
|
|
735
|
-
sandbox: binding?.sandbox,
|
|
736
|
-
serviceTier: binding?.serviceTier
|
|
737
|
-
});
|
|
738
|
-
return await runBoundTurn(params);
|
|
739
|
-
}
|
|
740
|
-
}
|
|
741
|
-
function isCodexThreadNotFoundError(error) {
|
|
742
|
-
return /\bthread not found:/iu.test(formatErrorMessage(error));
|
|
743
|
-
}
|
|
744
|
-
function enqueueBoundTurn(key, run) {
|
|
745
|
-
const state = getGlobalState();
|
|
746
|
-
const next = (state.queues.get(key) ?? Promise.resolve()).then(run, run);
|
|
747
|
-
const queued = next.then(() => void 0, () => void 0);
|
|
748
|
-
state.queues.set(key, queued);
|
|
749
|
-
next.finally(() => {
|
|
750
|
-
if (state.queues.get(key) === queued) state.queues.delete(key);
|
|
751
|
-
}).catch(() => void 0);
|
|
752
|
-
return next;
|
|
753
|
-
}
|
|
754
|
-
function resolveThreadRequestModelProvider(params) {
|
|
755
|
-
const modelProvider = params.modelProvider?.trim();
|
|
756
|
-
if (!modelProvider || modelProvider.toLowerCase() === "codex") return;
|
|
757
|
-
if (isCodexAppServerNativeAuthProfile(params) && (modelProvider.toLowerCase() === "openai" || modelProvider.toLowerCase() === "openai-codex")) return;
|
|
758
|
-
return modelProvider.toLowerCase() === "openai-codex" ? "openai" : modelProvider;
|
|
759
|
-
}
|
|
760
|
-
function buildAgentLookup(params) {
|
|
761
|
-
const agentDir = params.agentDir?.trim();
|
|
762
|
-
return {
|
|
763
|
-
...agentDir ? { agentDir } : {},
|
|
764
|
-
...params.config ? { config: params.config } : {}
|
|
765
|
-
};
|
|
766
|
-
}
|
|
767
|
-
//#endregion
|
|
768
|
-
//#region extensions/codex/src/node-cli-sessions.ts
|
|
769
|
-
const CODEX_CLI_SESSIONS_LIST_COMMAND = "codex.cli.sessions.list";
|
|
770
|
-
const CODEX_CLI_SESSION_RESUME_COMMAND = "codex.cli.session.resume";
|
|
771
|
-
const DEFAULT_SESSION_LIMIT = 10;
|
|
772
|
-
const MAX_SESSION_LIMIT = 50;
|
|
773
|
-
const DEFAULT_RESUME_TIMEOUT_MS = 20 * 6e4;
|
|
774
|
-
const SESSION_ID_PATTERN = /^[A-Za-z0-9._:-]{1,128}$/;
|
|
775
|
-
const activeResumeSessions = /* @__PURE__ */ new Set();
|
|
776
|
-
const DEFAULT_RESUME_SPAWN_RUNTIME = {
|
|
777
|
-
platform: process.platform,
|
|
778
|
-
env: process.env,
|
|
779
|
-
execPath: process.execPath
|
|
780
|
-
};
|
|
781
|
-
function createCodexCliSessionNodeHostCommands() {
|
|
782
|
-
return [{
|
|
783
|
-
command: CODEX_CLI_SESSIONS_LIST_COMMAND,
|
|
784
|
-
cap: "codex-cli-sessions",
|
|
785
|
-
handle: listLocalCodexCliSessions
|
|
786
|
-
}, {
|
|
787
|
-
command: CODEX_CLI_SESSION_RESUME_COMMAND,
|
|
788
|
-
cap: "codex-cli-sessions",
|
|
789
|
-
dangerous: true,
|
|
790
|
-
handle: resumeLocalCodexCliSession
|
|
791
|
-
}];
|
|
792
|
-
}
|
|
793
|
-
function createCodexCliSessionNodeInvokePolicies() {
|
|
794
|
-
return [{
|
|
795
|
-
commands: [CODEX_CLI_SESSIONS_LIST_COMMAND],
|
|
796
|
-
defaultPlatforms: [
|
|
797
|
-
"macos",
|
|
798
|
-
"linux",
|
|
799
|
-
"windows"
|
|
800
|
-
],
|
|
801
|
-
handle: (ctx) => ctx.invokeNode()
|
|
802
|
-
}, {
|
|
803
|
-
commands: [CODEX_CLI_SESSION_RESUME_COMMAND],
|
|
804
|
-
dangerous: true,
|
|
805
|
-
handle: (ctx) => ctx.invokeNode()
|
|
806
|
-
}];
|
|
807
|
-
}
|
|
808
|
-
async function listCodexCliSessionsOnNode(params) {
|
|
809
|
-
const node = await resolveCodexCliNode({
|
|
810
|
-
runtime: params.runtime,
|
|
811
|
-
requestedNode: params.requestedNode,
|
|
812
|
-
command: CODEX_CLI_SESSIONS_LIST_COMMAND
|
|
813
|
-
});
|
|
814
|
-
return {
|
|
815
|
-
node,
|
|
816
|
-
result: parseCodexCliSessionsListResult(await params.runtime.nodes.invoke({
|
|
817
|
-
nodeId: readNodeId(node),
|
|
818
|
-
command: CODEX_CLI_SESSIONS_LIST_COMMAND,
|
|
819
|
-
params: {
|
|
820
|
-
limit: params.limit,
|
|
821
|
-
filter: params.filter
|
|
822
|
-
},
|
|
823
|
-
timeoutMs: 15e3
|
|
824
|
-
}))
|
|
825
|
-
};
|
|
826
|
-
}
|
|
827
|
-
async function resolveCodexCliSessionForBindingOnNode(params) {
|
|
828
|
-
const listing = await listCodexCliSessionsOnNode({
|
|
829
|
-
runtime: params.runtime,
|
|
830
|
-
requestedNode: params.requestedNode,
|
|
831
|
-
filter: params.sessionId,
|
|
832
|
-
limit: MAX_SESSION_LIMIT
|
|
833
|
-
});
|
|
834
|
-
if (!listing.node.commands?.includes("codex.cli.session.resume")) throw new Error(`Node ${formatNodeLabel(listing.node)} does not expose ${CODEX_CLI_SESSION_RESUME_COMMAND}.`);
|
|
835
|
-
return {
|
|
836
|
-
node: listing.node,
|
|
837
|
-
session: listing.result.sessions.find((session) => session.sessionId === params.sessionId)
|
|
838
|
-
};
|
|
839
|
-
}
|
|
840
|
-
async function resumeCodexCliSessionOnNode(params) {
|
|
841
|
-
const payload = unwrapNodeInvokePayload(await params.runtime.nodes.invoke({
|
|
842
|
-
nodeId: params.nodeId,
|
|
843
|
-
command: CODEX_CLI_SESSION_RESUME_COMMAND,
|
|
844
|
-
params: {
|
|
845
|
-
sessionId: params.sessionId,
|
|
846
|
-
prompt: params.prompt,
|
|
847
|
-
cwd: params.cwd,
|
|
848
|
-
timeoutMs: params.timeoutMs
|
|
849
|
-
},
|
|
850
|
-
timeoutMs: (params.timeoutMs ?? DEFAULT_RESUME_TIMEOUT_MS) + 5e3
|
|
851
|
-
}));
|
|
852
|
-
if (!isRecord(payload) || payload.ok !== true || typeof payload.text !== "string") throw new Error("Codex CLI resume returned an invalid payload.");
|
|
853
|
-
return {
|
|
854
|
-
ok: true,
|
|
855
|
-
sessionId: typeof payload.sessionId === "string" ? payload.sessionId : params.sessionId,
|
|
856
|
-
text: payload.text
|
|
857
|
-
};
|
|
858
|
-
}
|
|
859
|
-
function formatCodexCliSessions(params) {
|
|
860
|
-
if (params.result.sessions.length === 0) return `No Codex CLI sessions returned from ${formatCodexDisplayText(formatNodeLabel(params.node))}.`;
|
|
861
|
-
return [`Codex CLI sessions on ${formatCodexDisplayText(formatNodeLabel(params.node))}:`, ...params.result.sessions.map((session) => {
|
|
862
|
-
const details = [session.cwd, session.updatedAt].filter((value) => Boolean(value));
|
|
863
|
-
return `- ${formatCodexDisplayText(session.sessionId)}${session.lastMessage ? ` - ${formatCodexDisplayText(session.lastMessage)}` : ""}${details.length > 0 ? ` (${details.map(formatCodexDisplayText).join(", ")})` : ""}\n Bind: /codex resume ${formatCodexDisplayText(session.sessionId)} --host ${formatCodexDisplayText(readNodeId(params.node))} --bind here`;
|
|
864
|
-
})].join("\n");
|
|
865
|
-
}
|
|
866
|
-
async function listLocalCodexCliSessions(paramsJSON) {
|
|
867
|
-
const params = readRecordParam(paramsJSON);
|
|
868
|
-
const limit = normalizeLimit(params.limit);
|
|
869
|
-
const filter = typeof params.filter === "string" ? params.filter.trim().toLowerCase() : "";
|
|
870
|
-
const codexHome = resolveCodexHome();
|
|
871
|
-
const summaries = await readHistorySessions(codexHome);
|
|
872
|
-
await hydrateSessionFiles(codexHome, summaries);
|
|
873
|
-
await hydrateSessionsFromSessionFiles(codexHome, summaries);
|
|
874
|
-
const sessions = [...summaries.values()].filter((session) => {
|
|
875
|
-
if (!filter) return true;
|
|
876
|
-
return [
|
|
877
|
-
session.sessionId,
|
|
878
|
-
session.cwd,
|
|
879
|
-
session.lastMessage
|
|
880
|
-
].some((value) => value?.toLowerCase().includes(filter));
|
|
881
|
-
}).toSorted((a, b) => compareOptionalStringsDesc(a.updatedAt, b.updatedAt)).slice(0, limit);
|
|
882
|
-
return JSON.stringify({
|
|
883
|
-
sessions,
|
|
884
|
-
codexHome
|
|
885
|
-
});
|
|
886
|
-
}
|
|
887
|
-
async function resumeLocalCodexCliSession(paramsJSON) {
|
|
888
|
-
const params = readRecordParam(paramsJSON);
|
|
889
|
-
const sessionId = typeof params.sessionId === "string" ? params.sessionId.trim() : "";
|
|
890
|
-
const prompt = typeof params.prompt === "string" ? params.prompt.trim() : "";
|
|
891
|
-
if (!sessionId || !SESSION_ID_PATTERN.test(sessionId)) throw new Error("Missing or invalid Codex CLI session id.");
|
|
892
|
-
if (!prompt) throw new Error("Missing Codex CLI prompt.");
|
|
893
|
-
if (activeResumeSessions.has(sessionId)) throw new Error(`Codex CLI session ${sessionId} already has an active resume turn.`);
|
|
894
|
-
activeResumeSessions.add(sessionId);
|
|
895
|
-
try {
|
|
896
|
-
const text = await runCodexExecResume({
|
|
897
|
-
sessionId,
|
|
898
|
-
prompt,
|
|
899
|
-
cwd: typeof params.cwd === "string" && params.cwd.trim() ? params.cwd.trim() : void 0,
|
|
900
|
-
timeoutMs: normalizeTimeoutMs(params.timeoutMs)
|
|
901
|
-
});
|
|
902
|
-
return JSON.stringify({
|
|
903
|
-
ok: true,
|
|
904
|
-
sessionId,
|
|
905
|
-
text: text.trim() || "Codex completed without a text reply."
|
|
906
|
-
});
|
|
907
|
-
} finally {
|
|
908
|
-
activeResumeSessions.delete(sessionId);
|
|
909
|
-
}
|
|
910
|
-
}
|
|
911
|
-
async function runCodexExecResume(params) {
|
|
912
|
-
const outputPath = path.join(await fs.mkdtemp(path.join(resolvePreferredDaoCoreTmpDir(), "daocore-codex-cli-")), "last-message.txt");
|
|
913
|
-
try {
|
|
914
|
-
const invocation = resolveCodexCliResumeSpawnInvocation([
|
|
915
|
-
"exec",
|
|
916
|
-
"resume",
|
|
917
|
-
"--skip-git-repo-check",
|
|
918
|
-
"--output-last-message",
|
|
919
|
-
outputPath,
|
|
920
|
-
params.sessionId,
|
|
921
|
-
"-"
|
|
922
|
-
], {
|
|
923
|
-
platform: process.platform,
|
|
924
|
-
env: process.env,
|
|
925
|
-
execPath: process.execPath
|
|
926
|
-
});
|
|
927
|
-
const child = spawn(invocation.command, invocation.args, {
|
|
928
|
-
cwd: params.cwd || process.cwd(),
|
|
929
|
-
stdio: [
|
|
930
|
-
"pipe",
|
|
931
|
-
"pipe",
|
|
932
|
-
"pipe"
|
|
933
|
-
],
|
|
934
|
-
env: process.env,
|
|
935
|
-
shell: invocation.shell,
|
|
936
|
-
windowsHide: invocation.windowsHide
|
|
937
|
-
});
|
|
938
|
-
const stdout = [];
|
|
939
|
-
const stderr = [];
|
|
940
|
-
let timedOut = false;
|
|
941
|
-
let forceKillTimeout;
|
|
942
|
-
const timeout = setTimeout(() => {
|
|
943
|
-
timedOut = true;
|
|
944
|
-
child.kill("SIGTERM");
|
|
945
|
-
forceKillTimeout = setTimeout(() => child.kill("SIGKILL"), 2e3);
|
|
946
|
-
forceKillTimeout.unref?.();
|
|
947
|
-
}, params.timeoutMs);
|
|
948
|
-
child.stdout.on("data", (chunk) => stdout.push(chunk));
|
|
949
|
-
child.stderr.on("data", (chunk) => stderr.push(chunk));
|
|
950
|
-
child.stdin.end(params.prompt);
|
|
951
|
-
const exitCode = await new Promise((resolve, reject) => {
|
|
952
|
-
child.on("error", reject);
|
|
953
|
-
child.on("exit", (code) => resolve(code));
|
|
954
|
-
}).finally(() => {
|
|
955
|
-
clearTimeout(timeout);
|
|
956
|
-
if (forceKillTimeout) clearTimeout(forceKillTimeout);
|
|
957
|
-
});
|
|
958
|
-
if (timedOut) throw new Error(`codex exec resume timed out after ${String(params.timeoutMs)}ms`);
|
|
959
|
-
if (exitCode !== 0) {
|
|
960
|
-
const message = Buffer.concat(stderr).toString("utf8").trim() || Buffer.concat(stdout).toString("utf8").trim() || `codex exec resume exited with code ${String(exitCode)}`;
|
|
961
|
-
throw new Error(message);
|
|
962
|
-
}
|
|
963
|
-
return await fs.readFile(outputPath, "utf8");
|
|
964
|
-
} finally {
|
|
965
|
-
await fs.rm(path.dirname(outputPath), {
|
|
966
|
-
recursive: true,
|
|
967
|
-
force: true
|
|
968
|
-
});
|
|
969
|
-
}
|
|
970
|
-
}
|
|
971
|
-
function resolveCodexCliResumeSpawnInvocation(args, runtime = DEFAULT_RESUME_SPAWN_RUNTIME) {
|
|
972
|
-
const resolved = materializeWindowsSpawnProgram(resolveWindowsSpawnProgram({
|
|
973
|
-
command: "codex",
|
|
974
|
-
platform: runtime.platform,
|
|
975
|
-
env: runtime.env,
|
|
976
|
-
execPath: runtime.execPath,
|
|
977
|
-
packageName: "@openai/codex"
|
|
978
|
-
}), args);
|
|
979
|
-
return {
|
|
980
|
-
command: resolved.command,
|
|
981
|
-
args: resolved.argv,
|
|
982
|
-
shell: resolved.shell,
|
|
983
|
-
windowsHide: resolved.windowsHide
|
|
984
|
-
};
|
|
985
|
-
}
|
|
986
|
-
async function readHistorySessions(codexHome) {
|
|
987
|
-
const summaries = /* @__PURE__ */ new Map();
|
|
988
|
-
const content = await readFileIfExists(path.join(codexHome, "history.jsonl"));
|
|
989
|
-
if (!content) return summaries;
|
|
990
|
-
for (const line of content.split(/\r?\n/u)) {
|
|
991
|
-
const trimmed = line.trim();
|
|
992
|
-
if (!trimmed) continue;
|
|
993
|
-
let parsed;
|
|
994
|
-
try {
|
|
995
|
-
parsed = JSON.parse(trimmed);
|
|
996
|
-
} catch {
|
|
997
|
-
continue;
|
|
998
|
-
}
|
|
999
|
-
if (!isRecord(parsed) || typeof parsed.session_id !== "string") continue;
|
|
1000
|
-
const sessionId = parsed.session_id.trim();
|
|
1001
|
-
if (!sessionId) continue;
|
|
1002
|
-
const entry = summaries.get(sessionId) ?? {
|
|
1003
|
-
sessionId,
|
|
1004
|
-
messageCount: 0
|
|
1005
|
-
};
|
|
1006
|
-
entry.messageCount += 1;
|
|
1007
|
-
if (typeof parsed.text === "string" && parsed.text.trim()) entry.lastMessage = truncateText(parsed.text.trim(), 140);
|
|
1008
|
-
if (typeof parsed.ts === "number" && Number.isFinite(parsed.ts)) entry.updatedAt = (/* @__PURE__ */ new Date(parsed.ts * 1e3)).toISOString();
|
|
1009
|
-
summaries.set(sessionId, entry);
|
|
1010
|
-
}
|
|
1011
|
-
return summaries;
|
|
1012
|
-
}
|
|
1013
|
-
async function hydrateSessionFiles(codexHome, summaries) {
|
|
1014
|
-
if (summaries.size === 0) return;
|
|
1015
|
-
const files = await findSessionFiles(path.join(codexHome, "sessions"), 4);
|
|
1016
|
-
const pending = new Set(summaries.keys());
|
|
1017
|
-
for (const file of files) {
|
|
1018
|
-
const basename = path.basename(file);
|
|
1019
|
-
const sessionId = [...pending].find((id) => basename.includes(id));
|
|
1020
|
-
if (!sessionId) continue;
|
|
1021
|
-
const entry = summaries.get(sessionId);
|
|
1022
|
-
if (!entry) continue;
|
|
1023
|
-
entry.sessionFile = file;
|
|
1024
|
-
const cwd = readSessionMetaCwd(await readFirstLine(file) ?? "");
|
|
1025
|
-
if (cwd) entry.cwd = cwd;
|
|
1026
|
-
pending.delete(sessionId);
|
|
1027
|
-
if (pending.size === 0) return;
|
|
1028
|
-
}
|
|
1029
|
-
}
|
|
1030
|
-
async function hydrateSessionsFromSessionFiles(codexHome, summaries) {
|
|
1031
|
-
const files = await findSessionFiles(path.join(codexHome, "sessions"), 4);
|
|
1032
|
-
for (const file of files) {
|
|
1033
|
-
const summary = await readSessionFileSummary(file);
|
|
1034
|
-
if (!summary) continue;
|
|
1035
|
-
const existing = summaries.get(summary.sessionId);
|
|
1036
|
-
summaries.set(summary.sessionId, {
|
|
1037
|
-
...summary,
|
|
1038
|
-
...existing,
|
|
1039
|
-
cwd: existing?.cwd ?? summary.cwd,
|
|
1040
|
-
sessionFile: existing?.sessionFile ?? summary.sessionFile,
|
|
1041
|
-
updatedAt: existing?.updatedAt ?? summary.updatedAt,
|
|
1042
|
-
lastMessage: existing?.lastMessage ?? summary.lastMessage,
|
|
1043
|
-
messageCount: existing?.messageCount ?? summary.messageCount
|
|
1044
|
-
});
|
|
1045
|
-
}
|
|
1046
|
-
}
|
|
1047
|
-
async function readSessionFileSummary(file) {
|
|
1048
|
-
const content = await readFileIfExists(file);
|
|
1049
|
-
if (!content) return null;
|
|
1050
|
-
let sessionId = "";
|
|
1051
|
-
let cwd;
|
|
1052
|
-
let updatedAt;
|
|
1053
|
-
let lastMessage;
|
|
1054
|
-
let messageCount = 0;
|
|
1055
|
-
for (const line of content.split(/\r?\n/u)) {
|
|
1056
|
-
const trimmed = line.trim();
|
|
1057
|
-
if (!trimmed) continue;
|
|
1058
|
-
let parsed;
|
|
1059
|
-
try {
|
|
1060
|
-
parsed = JSON.parse(trimmed);
|
|
1061
|
-
} catch {
|
|
1062
|
-
continue;
|
|
1063
|
-
}
|
|
1064
|
-
if (!isRecord(parsed)) continue;
|
|
1065
|
-
if (typeof parsed.timestamp === "string" && parsed.timestamp.trim()) updatedAt = parsed.timestamp.trim();
|
|
1066
|
-
if (parsed.type === "session_meta" && isRecord(parsed.payload)) {
|
|
1067
|
-
if (typeof parsed.payload.id === "string" && parsed.payload.id.trim()) sessionId = parsed.payload.id.trim();
|
|
1068
|
-
if (typeof parsed.payload.cwd === "string" && parsed.payload.cwd.trim()) cwd = parsed.payload.cwd.trim();
|
|
1069
|
-
continue;
|
|
1070
|
-
}
|
|
1071
|
-
const messageText = readResponseItemMessageText(parsed);
|
|
1072
|
-
if (messageText) {
|
|
1073
|
-
messageCount += 1;
|
|
1074
|
-
lastMessage = truncateText(messageText, 140);
|
|
1075
|
-
}
|
|
1076
|
-
}
|
|
1077
|
-
if (!sessionId) sessionId = readSessionIdFromFilename(file) ?? "";
|
|
1078
|
-
if (!sessionId) return null;
|
|
1079
|
-
return {
|
|
1080
|
-
sessionId,
|
|
1081
|
-
updatedAt: updatedAt ?? await readFileMtimeIso(file),
|
|
1082
|
-
lastMessage,
|
|
1083
|
-
cwd,
|
|
1084
|
-
sessionFile: file,
|
|
1085
|
-
messageCount
|
|
1086
|
-
};
|
|
1087
|
-
}
|
|
1088
|
-
async function findSessionFiles(dir, maxDepth) {
|
|
1089
|
-
if (maxDepth < 0) return [];
|
|
1090
|
-
let entries;
|
|
1091
|
-
try {
|
|
1092
|
-
entries = await fs.readdir(dir, { withFileTypes: true });
|
|
1093
|
-
} catch {
|
|
1094
|
-
return [];
|
|
1095
|
-
}
|
|
1096
|
-
const files = [];
|
|
1097
|
-
for (const entry of entries) {
|
|
1098
|
-
const entryPath = path.join(dir, entry.name);
|
|
1099
|
-
if (entry.isDirectory()) files.push(...await findSessionFiles(entryPath, maxDepth - 1));
|
|
1100
|
-
else if (entry.isFile() && entry.name.endsWith(".jsonl")) files.push(entryPath);
|
|
1101
|
-
}
|
|
1102
|
-
return files;
|
|
1103
|
-
}
|
|
1104
|
-
function readSessionMetaCwd(line) {
|
|
1105
|
-
try {
|
|
1106
|
-
const parsed = JSON.parse(line);
|
|
1107
|
-
if (!isRecord(parsed) || parsed.type !== "session_meta" || !isRecord(parsed.payload)) return;
|
|
1108
|
-
return typeof parsed.payload.cwd === "string" && parsed.payload.cwd.trim() ? parsed.payload.cwd.trim() : void 0;
|
|
1109
|
-
} catch {
|
|
1110
|
-
return;
|
|
1111
|
-
}
|
|
1112
|
-
}
|
|
1113
|
-
function readResponseItemMessageText(parsed) {
|
|
1114
|
-
if (parsed.type !== "response_item" || !isRecord(parsed.payload)) return;
|
|
1115
|
-
if (parsed.payload.type !== "message") return;
|
|
1116
|
-
if ((typeof parsed.payload.role === "string" ? parsed.payload.role : "") !== "user") return;
|
|
1117
|
-
const parts = (Array.isArray(parsed.payload.content) ? parsed.payload.content : []).flatMap((entry) => {
|
|
1118
|
-
if (!isRecord(entry)) return [];
|
|
1119
|
-
const text = typeof entry.text === "string" ? entry.text : typeof entry.input_text === "string" ? entry.input_text : void 0;
|
|
1120
|
-
return text?.trim() ? [text.trim()] : [];
|
|
1121
|
-
});
|
|
1122
|
-
return parts.length > 0 ? parts.join(" ") : void 0;
|
|
1123
|
-
}
|
|
1124
|
-
function readSessionIdFromFilename(file) {
|
|
1125
|
-
return path.basename(file).match(/[0-9a-f]{8}-[0-9a-f-]{27,}/iu)?.[0];
|
|
1126
|
-
}
|
|
1127
|
-
async function resolveCodexCliNode(params) {
|
|
1128
|
-
const list = await params.runtime.nodes.list(params.requestedNode ? void 0 : { connected: true });
|
|
1129
|
-
const requested = params.requestedNode?.trim();
|
|
1130
|
-
const candidates = list.nodes.filter((node) => {
|
|
1131
|
-
if (requested) return [
|
|
1132
|
-
node.nodeId,
|
|
1133
|
-
node.displayName,
|
|
1134
|
-
node.remoteIp
|
|
1135
|
-
].some((value) => value === requested);
|
|
1136
|
-
return node.connected === true && node.commands?.includes(params.command);
|
|
1137
|
-
});
|
|
1138
|
-
if (candidates.length === 0) throw new Error(requested ? `Codex CLI node ${requested} was not found.` : "No connected node exposes Codex CLI session commands.");
|
|
1139
|
-
const usable = candidates.filter((node) => node.commands?.includes(params.command));
|
|
1140
|
-
if (usable.length === 0) throw new Error(`Node ${requested ?? "candidate"} does not expose ${params.command}.`);
|
|
1141
|
-
if (usable.length > 1) throw new Error("Multiple Codex CLI-capable nodes connected. Pass --host <node-id>.");
|
|
1142
|
-
return usable[0];
|
|
1143
|
-
}
|
|
1144
|
-
function parseCodexCliSessionsListResult(raw) {
|
|
1145
|
-
const payload = unwrapNodeInvokePayload(raw);
|
|
1146
|
-
if (!isRecord(payload) || !Array.isArray(payload.sessions)) throw new Error("Codex CLI session list returned an invalid payload.");
|
|
1147
|
-
return {
|
|
1148
|
-
codexHome: typeof payload.codexHome === "string" ? payload.codexHome : "",
|
|
1149
|
-
sessions: payload.sessions.flatMap((entry) => {
|
|
1150
|
-
if (!isRecord(entry) || typeof entry.sessionId !== "string") return [];
|
|
1151
|
-
return [{
|
|
1152
|
-
sessionId: entry.sessionId,
|
|
1153
|
-
updatedAt: typeof entry.updatedAt === "string" ? entry.updatedAt : void 0,
|
|
1154
|
-
lastMessage: typeof entry.lastMessage === "string" ? entry.lastMessage : void 0,
|
|
1155
|
-
cwd: typeof entry.cwd === "string" ? entry.cwd : void 0,
|
|
1156
|
-
sessionFile: typeof entry.sessionFile === "string" ? entry.sessionFile : void 0,
|
|
1157
|
-
messageCount: typeof entry.messageCount === "number" && Number.isFinite(entry.messageCount) ? entry.messageCount : 0
|
|
1158
|
-
}];
|
|
1159
|
-
})
|
|
1160
|
-
};
|
|
1161
|
-
}
|
|
1162
|
-
function unwrapNodeInvokePayload(raw) {
|
|
1163
|
-
const record = isRecord(raw) ? raw : {};
|
|
1164
|
-
if (typeof record.payloadJSON === "string" && record.payloadJSON.trim()) try {
|
|
1165
|
-
return JSON.parse(record.payloadJSON);
|
|
1166
|
-
} catch (error) {
|
|
1167
|
-
throw new Error("Codex CLI node command returned malformed payloadJSON.", { cause: error });
|
|
1168
|
-
}
|
|
1169
|
-
if ("payload" in record) return record.payload;
|
|
1170
|
-
return raw;
|
|
1171
|
-
}
|
|
1172
|
-
function readRecordParam(paramsJSON) {
|
|
1173
|
-
if (!paramsJSON?.trim()) return {};
|
|
1174
|
-
try {
|
|
1175
|
-
const parsed = JSON.parse(paramsJSON);
|
|
1176
|
-
return isRecord(parsed) ? parsed : {};
|
|
1177
|
-
} catch {
|
|
1178
|
-
return {};
|
|
1179
|
-
}
|
|
1180
|
-
}
|
|
1181
|
-
function resolveCodexHome() {
|
|
1182
|
-
return process.env.CODEX_HOME?.trim() || path.join(os.homedir(), ".codex");
|
|
1183
|
-
}
|
|
1184
|
-
async function readFileIfExists(file) {
|
|
1185
|
-
try {
|
|
1186
|
-
return await fs.readFile(file, "utf8");
|
|
1187
|
-
} catch {
|
|
1188
|
-
return;
|
|
1189
|
-
}
|
|
1190
|
-
}
|
|
1191
|
-
async function readFirstLine(file) {
|
|
1192
|
-
return (await readFileIfExists(file))?.split(/\r?\n/u)[0];
|
|
1193
|
-
}
|
|
1194
|
-
async function readFileMtimeIso(file) {
|
|
1195
|
-
try {
|
|
1196
|
-
return (await fs.stat(file)).mtime.toISOString();
|
|
1197
|
-
} catch {
|
|
1198
|
-
return;
|
|
1199
|
-
}
|
|
1200
|
-
}
|
|
1201
|
-
function normalizeLimit(value) {
|
|
1202
|
-
return typeof value === "number" && Number.isFinite(value) ? Math.min(MAX_SESSION_LIMIT, Math.max(1, Math.floor(value))) : DEFAULT_SESSION_LIMIT;
|
|
1203
|
-
}
|
|
1204
|
-
function normalizeTimeoutMs(value) {
|
|
1205
|
-
return typeof value === "number" && Number.isFinite(value) && value > 0 ? Math.min(60 * 6e4, Math.floor(value)) : DEFAULT_RESUME_TIMEOUT_MS;
|
|
1206
|
-
}
|
|
1207
|
-
function truncateText(value, max) {
|
|
1208
|
-
return value.length > max ? `${value.slice(0, max - 3)}...` : value;
|
|
1209
|
-
}
|
|
1210
|
-
function compareOptionalStringsDesc(a, b) {
|
|
1211
|
-
return (b ?? "").localeCompare(a ?? "");
|
|
1212
|
-
}
|
|
1213
|
-
function readNodeId(node) {
|
|
1214
|
-
if (!node.nodeId) throw new Error("Codex CLI node did not include a node id.");
|
|
1215
|
-
return node.nodeId;
|
|
1216
|
-
}
|
|
1217
|
-
function formatNodeLabel(node) {
|
|
1218
|
-
return [
|
|
1219
|
-
node.displayName,
|
|
1220
|
-
node.nodeId,
|
|
1221
|
-
node.remoteIp
|
|
1222
|
-
].filter(Boolean).join(" / ") || "node";
|
|
1223
|
-
}
|
|
1224
|
-
function isRecord(value) {
|
|
1225
|
-
return Boolean(value && typeof value === "object" && !Array.isArray(value));
|
|
1226
|
-
}
|
|
1227
|
-
//#endregion
|
|
1228
|
-
export { steerCodexConversationTurn as _, resolveCodexCliSessionForBindingOnNode as a, readCodexConversationBindingData as b, handleCodexConversationInboundClaim as c, parseCodexFastModeArg as d, parseCodexPermissionsModeArg as f, setCodexConversationPermissions as g, setCodexConversationModel as h, listCodexCliSessionsOnNode as i, startCodexConversationThread as l, setCodexConversationFastMode as m, createCodexCliSessionNodeInvokePolicies as n, resumeCodexCliSessionOnNode as o, readCodexConversationActiveTurn as p, formatCodexCliSessions as r, handleCodexConversationBindingResolved as s, createCodexCliSessionNodeHostCommands as t, formatPermissionsMode as u, stopCodexConversationTurn as v, resolveCodexDefaultWorkspaceDir as x, createCodexCliNodeConversationBindingData as y };
|