@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,955 +0,0 @@
|
|
|
1
|
-
import { c as normalizeOptionalString } from "./string-coerce-DyL154ka.js";
|
|
2
|
-
import { i as getRuntimeConfig } from "./io-Ct2JqgbR.js";
|
|
3
|
-
import { s as getRuntimeConfigSourceSnapshot } from "./runtime-snapshot-DgdkBEdP.js";
|
|
4
|
-
import { d as isPrivateNetworkAllowedByPolicy } from "./ssrf-BNF8aODC.js";
|
|
5
|
-
import "./string-coerce-runtime-DcopKqDR.js";
|
|
6
|
-
import { C as BrowserTabNotFoundError, E as toBrowserErrorResponse, F as resolveCdpReachabilityTimeouts, H as DEFAULT_BROWSER_LOCAL_CDP_READY_TIMEOUT_MS, I as usesFastLoopbackCdpProbeClass, P as PROFILE_ATTACH_RETRY_TIMEOUT_MS, a as fetchOk, b as BrowserProfileUnavailableError, f as redactCdpUrl, i as fetchJson, j as CHROME_MCP_ATTACH_READY_WINDOW_MS, l as normalizeCdpHttpBaseForJsonEndpoints, m as withAllowedHostname, n as assertCdpEndpointAllowed, t as appendCdpPath, w as BrowserTargetAmbiguousError, x as BrowserResetUnsupportedError, y as BrowserProfileNotFoundError } from "./cdp.helpers-Dc4Aa7R9.js";
|
|
7
|
-
import { i as resolveProfile, n as resolveBrowserConfig } from "./config-D4rsGOyV.js";
|
|
8
|
-
import "./config-B39SIZNb.js";
|
|
9
|
-
import { t as movePathToTrash } from "./trash-CBCzn4Yn.js";
|
|
10
|
-
import { g as listChromeMcpTabs } from "./chrome-mcp-5e65bt26.js";
|
|
11
|
-
import { E as withBrowserNavigationPolicy, S as assertBrowserNavigationAllowed, T as requiresInspectableBrowserNavigationRedirectsForUrl, a as resolveDaoCoreUserDataDir, b as resolveBrowserNavigationProxyMode, c as formatChromeCdpDiagnostic, d as createTargetViaCdp, i as launchDaoCoreChrome, n as isChromeCdpReady, o as stopDaoCoreChrome, p as normalizeCdpWsUrl, r as isChromeReachable, s as diagnoseChromeCdp, w as assertBrowserNavigationResultAllowed, x as InvalidBrowserNavigationUrlError } from "./chrome-rMubJwRG.js";
|
|
12
|
-
import { n as getPwAiModule, r as getBrowserProfileCapabilities, t as resolveTargetIdFromTabs } from "./target-id-COLv5LsJ.js";
|
|
13
|
-
import { t as isSelectableCdpBrowserTarget } from "./cdp-target-filter-CaIsrb0G.js";
|
|
14
|
-
import fs from "node:fs";
|
|
15
|
-
//#region extensions/browser/src/browser/config-refresh-source.ts
|
|
16
|
-
function loadBrowserConfigForRuntimeRefresh() {
|
|
17
|
-
return getRuntimeConfigSourceSnapshot() ?? getRuntimeConfig();
|
|
18
|
-
}
|
|
19
|
-
//#endregion
|
|
20
|
-
//#region extensions/browser/src/browser/cdp-reachability-policy.ts
|
|
21
|
-
function withCdpHostnameAllowed(profile, ssrfPolicy) {
|
|
22
|
-
if (!ssrfPolicy || !profile.cdpHost) return ssrfPolicy;
|
|
23
|
-
if (isPrivateNetworkAllowedByPolicy(ssrfPolicy)) return ssrfPolicy;
|
|
24
|
-
return withAllowedHostname(ssrfPolicy, profile.cdpHost);
|
|
25
|
-
}
|
|
26
|
-
function resolveCdpReachabilityPolicy(profile, ssrfPolicy) {
|
|
27
|
-
if (!getBrowserProfileCapabilities(profile).isRemote && profile.cdpIsLoopback && profile.driver === "daocore") return;
|
|
28
|
-
return withCdpHostnameAllowed(profile, ssrfPolicy);
|
|
29
|
-
}
|
|
30
|
-
const resolveCdpControlPolicy = resolveCdpReachabilityPolicy;
|
|
31
|
-
//#endregion
|
|
32
|
-
//#region extensions/browser/src/browser/resolved-config-refresh.ts
|
|
33
|
-
function changedProfileInvariants(current, next) {
|
|
34
|
-
const changed = [];
|
|
35
|
-
const currentUsesLocalManagedLaunch = current.driver === "daocore" && !current.attachOnly && current.cdpIsLoopback;
|
|
36
|
-
const nextUsesLocalManagedLaunch = next.driver === "daocore" && !next.attachOnly && next.cdpIsLoopback;
|
|
37
|
-
if (current.cdpUrl !== next.cdpUrl) changed.push("cdpUrl");
|
|
38
|
-
if (current.cdpPort !== next.cdpPort) changed.push("cdpPort");
|
|
39
|
-
if (current.driver !== next.driver) changed.push("driver");
|
|
40
|
-
if (currentUsesLocalManagedLaunch && nextUsesLocalManagedLaunch && current.headless !== next.headless) changed.push("headless");
|
|
41
|
-
if (currentUsesLocalManagedLaunch && nextUsesLocalManagedLaunch && current.executablePath !== next.executablePath) changed.push("executablePath");
|
|
42
|
-
if (current.attachOnly !== next.attachOnly) changed.push("attachOnly");
|
|
43
|
-
if (current.cdpIsLoopback !== next.cdpIsLoopback) changed.push("cdpIsLoopback");
|
|
44
|
-
if ((current.userDataDir ?? "") !== (next.userDataDir ?? "")) changed.push("userDataDir");
|
|
45
|
-
return changed;
|
|
46
|
-
}
|
|
47
|
-
function applyResolvedConfig(current, freshResolved) {
|
|
48
|
-
current.resolved = {
|
|
49
|
-
...freshResolved,
|
|
50
|
-
evaluateEnabled: current.resolved.evaluateEnabled
|
|
51
|
-
};
|
|
52
|
-
for (const [name, runtime] of current.profiles) {
|
|
53
|
-
const nextProfile = resolveProfile(freshResolved, name);
|
|
54
|
-
if (nextProfile) {
|
|
55
|
-
const changed = changedProfileInvariants(runtime.profile, nextProfile);
|
|
56
|
-
if (changed.length > 0) {
|
|
57
|
-
runtime.reconcile = {
|
|
58
|
-
previousProfile: runtime.profile,
|
|
59
|
-
reason: `profile invariants changed: ${changed.join(", ")}`
|
|
60
|
-
};
|
|
61
|
-
runtime.lastTargetId = null;
|
|
62
|
-
}
|
|
63
|
-
runtime.profile = nextProfile;
|
|
64
|
-
continue;
|
|
65
|
-
}
|
|
66
|
-
runtime.reconcile = {
|
|
67
|
-
previousProfile: runtime.profile,
|
|
68
|
-
reason: "profile removed from config"
|
|
69
|
-
};
|
|
70
|
-
runtime.lastTargetId = null;
|
|
71
|
-
if (!runtime.running) current.profiles.delete(name);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
function refreshResolvedBrowserConfigFromDisk(params) {
|
|
75
|
-
if (!params.refreshConfigFromDisk) return;
|
|
76
|
-
const cfg = loadBrowserConfigForRuntimeRefresh();
|
|
77
|
-
const freshResolved = resolveBrowserConfig(cfg.browser, cfg);
|
|
78
|
-
applyResolvedConfig(params.current, freshResolved);
|
|
79
|
-
}
|
|
80
|
-
function resolveBrowserProfileWithHotReload(params) {
|
|
81
|
-
refreshResolvedBrowserConfigFromDisk({
|
|
82
|
-
current: params.current,
|
|
83
|
-
refreshConfigFromDisk: params.refreshConfigFromDisk,
|
|
84
|
-
mode: "cached"
|
|
85
|
-
});
|
|
86
|
-
let profile = resolveProfile(params.current.resolved, params.name);
|
|
87
|
-
if (profile) return profile;
|
|
88
|
-
refreshResolvedBrowserConfigFromDisk({
|
|
89
|
-
current: params.current,
|
|
90
|
-
refreshConfigFromDisk: params.refreshConfigFromDisk,
|
|
91
|
-
mode: "fresh"
|
|
92
|
-
});
|
|
93
|
-
profile = resolveProfile(params.current.resolved, params.name);
|
|
94
|
-
return profile;
|
|
95
|
-
}
|
|
96
|
-
//#endregion
|
|
97
|
-
//#region extensions/browser/src/browser/chrome-mcp.runtime.ts
|
|
98
|
-
async function getChromeMcpModule() {
|
|
99
|
-
return await import("./chrome-mcp-t4jCw9ZG.js");
|
|
100
|
-
}
|
|
101
|
-
//#endregion
|
|
102
|
-
//#region extensions/browser/src/browser/server-context.constants.ts
|
|
103
|
-
const OPEN_TAB_DISCOVERY_WINDOW_MS = 2e3;
|
|
104
|
-
const CDP_READY_AFTER_LAUNCH_WINDOW_MS = DEFAULT_BROWSER_LOCAL_CDP_READY_TIMEOUT_MS;
|
|
105
|
-
//#endregion
|
|
106
|
-
//#region extensions/browser/src/browser/server-context.lifecycle.ts
|
|
107
|
-
function resolveIdleProfileStopOutcome(profile) {
|
|
108
|
-
const capabilities = getBrowserProfileCapabilities(profile);
|
|
109
|
-
if (profile.attachOnly || capabilities.isRemote) return {
|
|
110
|
-
stopped: true,
|
|
111
|
-
closePlaywright: true
|
|
112
|
-
};
|
|
113
|
-
return {
|
|
114
|
-
stopped: false,
|
|
115
|
-
closePlaywright: false
|
|
116
|
-
};
|
|
117
|
-
}
|
|
118
|
-
async function closePlaywrightBrowserConnectionForProfile(cdpUrl) {
|
|
119
|
-
try {
|
|
120
|
-
await (await getPwAiModule({ mode: "soft" }))?.closePlaywrightBrowserConnection(cdpUrl ? { cdpUrl } : void 0);
|
|
121
|
-
} catch {}
|
|
122
|
-
}
|
|
123
|
-
//#endregion
|
|
124
|
-
//#region extensions/browser/src/browser/server-context.availability.ts
|
|
125
|
-
const MANAGED_LAUNCH_FAILURE_THRESHOLD = 3;
|
|
126
|
-
const MANAGED_LAUNCH_COOLDOWN_BASE_MS = 3e4;
|
|
127
|
-
const MANAGED_LAUNCH_COOLDOWN_MAX_MS = 5 * 6e4;
|
|
128
|
-
function launchOptionsForEnsure(options) {
|
|
129
|
-
return typeof options?.headless === "boolean" ? { headlessOverride: options.headless } : void 0;
|
|
130
|
-
}
|
|
131
|
-
function ensureOptionsKey(options) {
|
|
132
|
-
return typeof options?.headless === "boolean" ? `headless:${options.headless}` : "default";
|
|
133
|
-
}
|
|
134
|
-
function formatLocalPortOwnershipHint(profile) {
|
|
135
|
-
const resetHint = `If DaoCore should own this local profile, run action=reset-profile profile=${profile.name} to stop the conflicting process.`;
|
|
136
|
-
if (!profile.cdpIsLoopback) return resetHint;
|
|
137
|
-
return `${resetHint} If this port is an externally managed CDP service such as Browserless, set browser.profiles.${profile.name}.attachOnly=true so DaoCore attaches without trying to manage the local process. For Browserless Docker, set EXTERNAL to the same WebSocket endpoint DaoCore can reach via browser.profiles.<name>.cdpUrl.`;
|
|
138
|
-
}
|
|
139
|
-
function normalizeFailureMessage(err) {
|
|
140
|
-
return (err instanceof Error ? err.message : String(err)).trim() || "unknown browser launch failure";
|
|
141
|
-
}
|
|
142
|
-
function resetManagedLaunchFailure(profileState) {
|
|
143
|
-
profileState.managedLaunchFailure = void 0;
|
|
144
|
-
}
|
|
145
|
-
function recordManagedLaunchFailure(profileState, err) {
|
|
146
|
-
const consecutiveFailures = (profileState.managedLaunchFailure?.consecutiveFailures ?? 0) + 1;
|
|
147
|
-
const exponent = Math.max(0, consecutiveFailures - MANAGED_LAUNCH_FAILURE_THRESHOLD);
|
|
148
|
-
const cooldownMs = consecutiveFailures >= MANAGED_LAUNCH_FAILURE_THRESHOLD ? Math.min(MANAGED_LAUNCH_COOLDOWN_MAX_MS, MANAGED_LAUNCH_COOLDOWN_BASE_MS * 2 ** exponent) : 0;
|
|
149
|
-
const now = Date.now();
|
|
150
|
-
profileState.managedLaunchFailure = {
|
|
151
|
-
consecutiveFailures,
|
|
152
|
-
lastFailureAt: now,
|
|
153
|
-
...cooldownMs > 0 ? { cooldownUntil: now + cooldownMs } : {},
|
|
154
|
-
lastError: normalizeFailureMessage(err)
|
|
155
|
-
};
|
|
156
|
-
}
|
|
157
|
-
function assertManagedLaunchNotCoolingDown(profileName, profileState) {
|
|
158
|
-
const failure = profileState.managedLaunchFailure;
|
|
159
|
-
if (!failure || failure.consecutiveFailures < MANAGED_LAUNCH_FAILURE_THRESHOLD) return;
|
|
160
|
-
const remainingMs = (failure.cooldownUntil ?? 0) - Date.now();
|
|
161
|
-
if (remainingMs <= 0) return;
|
|
162
|
-
const retrySeconds = Math.max(1, Math.ceil(remainingMs / 1e3));
|
|
163
|
-
throw new BrowserProfileUnavailableError(`Browser launch for profile "${profileName}" is cooling down after ${failure.consecutiveFailures} consecutive managed Chrome launch failures. Retry in ${retrySeconds}s after fixing Chrome startup, or set browser.enabled=false if the browser tool is not needed. Last error: ${failure.lastError}`);
|
|
164
|
-
}
|
|
165
|
-
function createProfileAvailability({ opts, profile, state, getProfileState, setProfileRunning }) {
|
|
166
|
-
const redactedProfileCdpUrl = redactCdpUrl(profile.cdpUrl) ?? profile.cdpUrl;
|
|
167
|
-
const capabilities = getBrowserProfileCapabilities(profile);
|
|
168
|
-
const resolveTimeouts = (timeoutMs) => resolveCdpReachabilityTimeouts({
|
|
169
|
-
profileIsLoopback: profile.cdpIsLoopback,
|
|
170
|
-
attachOnly: profile.attachOnly,
|
|
171
|
-
timeoutMs,
|
|
172
|
-
remoteHttpTimeoutMs: state().resolved.remoteCdpTimeoutMs,
|
|
173
|
-
remoteHandshakeTimeoutMs: state().resolved.remoteCdpHandshakeTimeoutMs
|
|
174
|
-
});
|
|
175
|
-
const getCdpReachabilityPolicy = () => resolveCdpReachabilityPolicy(profile, state().resolved.ssrfPolicy);
|
|
176
|
-
const isReachable = async (timeoutMs, options) => {
|
|
177
|
-
if (capabilities.usesChromeMcp) {
|
|
178
|
-
const { listChromeMcpTabs } = await getChromeMcpModule();
|
|
179
|
-
const callOptions = {};
|
|
180
|
-
if (timeoutMs != null) callOptions.timeoutMs = timeoutMs;
|
|
181
|
-
if (options?.ephemeral) callOptions.ephemeral = true;
|
|
182
|
-
if (options?.signal) callOptions.signal = options.signal;
|
|
183
|
-
await listChromeMcpTabs(profile.name, profile, callOptions);
|
|
184
|
-
return true;
|
|
185
|
-
}
|
|
186
|
-
const { httpTimeoutMs, wsTimeoutMs } = resolveTimeouts(timeoutMs);
|
|
187
|
-
return await isChromeCdpReady(profile.cdpUrl, httpTimeoutMs, wsTimeoutMs, getCdpReachabilityPolicy());
|
|
188
|
-
};
|
|
189
|
-
const isTransportAvailable = async (timeoutMs) => {
|
|
190
|
-
if (capabilities.usesChromeMcp) {
|
|
191
|
-
const { ensureChromeMcpAvailable } = await getChromeMcpModule();
|
|
192
|
-
await ensureChromeMcpAvailable(profile.name, profile, {
|
|
193
|
-
ephemeral: true,
|
|
194
|
-
timeoutMs
|
|
195
|
-
});
|
|
196
|
-
return true;
|
|
197
|
-
}
|
|
198
|
-
return await isReachable(timeoutMs);
|
|
199
|
-
};
|
|
200
|
-
const isHttpReachable = async (timeoutMs) => {
|
|
201
|
-
if (capabilities.usesChromeMcp) return await isTransportAvailable(timeoutMs);
|
|
202
|
-
const { httpTimeoutMs } = resolveTimeouts(timeoutMs);
|
|
203
|
-
return await isChromeReachable(profile.cdpUrl, httpTimeoutMs, getCdpReachabilityPolicy());
|
|
204
|
-
};
|
|
205
|
-
const describeCdpFailure = async (timeoutMs) => {
|
|
206
|
-
const { httpTimeoutMs, wsTimeoutMs } = resolveTimeouts(timeoutMs);
|
|
207
|
-
return formatChromeCdpDiagnostic(await diagnoseChromeCdp(profile.cdpUrl, httpTimeoutMs, wsTimeoutMs, getCdpReachabilityPolicy()));
|
|
208
|
-
};
|
|
209
|
-
const attachRunning = (running) => {
|
|
210
|
-
setProfileRunning(running);
|
|
211
|
-
running.proc.on("exit", () => {
|
|
212
|
-
if (!opts.getState()) return;
|
|
213
|
-
if (getProfileState().running?.pid === running.pid) setProfileRunning(null);
|
|
214
|
-
});
|
|
215
|
-
};
|
|
216
|
-
const formatChromeMcpAttachFailure = (lastError) => {
|
|
217
|
-
const detail = lastError instanceof Error ? ` Last error: ${lastError.message}` : "";
|
|
218
|
-
const message = lastError instanceof Error ? lastError.message : "";
|
|
219
|
-
if (message.includes("DevToolsActivePort") || message.includes("Could not connect to Chrome")) return `Chrome MCP existing-session attach for profile "${profile.name}" could not connect to Chrome. Enable remote debugging in the browser inspect page, keep the browser open, approve the attach prompt, and retry. If you do not need your signed-in browser session, use the managed "daocore" profile instead.` + detail;
|
|
220
|
-
return `Chrome MCP existing-session attach for profile "${profile.name}" timed out waiting for tabs to become available. Approve the browser attach prompt, keep the browser open, and retry.${detail}`;
|
|
221
|
-
};
|
|
222
|
-
const reconcileProfileRuntime = async () => {
|
|
223
|
-
const profileState = getProfileState();
|
|
224
|
-
const reconcile = profileState.reconcile;
|
|
225
|
-
if (!reconcile) return;
|
|
226
|
-
profileState.reconcile = null;
|
|
227
|
-
profileState.lastTargetId = null;
|
|
228
|
-
const previousProfile = reconcile.previousProfile;
|
|
229
|
-
resetManagedLaunchFailure(profileState);
|
|
230
|
-
if (profileState.running) {
|
|
231
|
-
await stopDaoCoreChrome(profileState.running).catch(() => {});
|
|
232
|
-
setProfileRunning(null);
|
|
233
|
-
}
|
|
234
|
-
if (getBrowserProfileCapabilities(previousProfile).usesChromeMcp) {
|
|
235
|
-
const { closeChromeMcpSession } = await getChromeMcpModule();
|
|
236
|
-
await closeChromeMcpSession(previousProfile.name).catch(() => false);
|
|
237
|
-
}
|
|
238
|
-
await closePlaywrightBrowserConnectionForProfile(previousProfile.cdpUrl);
|
|
239
|
-
if (previousProfile.cdpUrl !== profile.cdpUrl) await closePlaywrightBrowserConnectionForProfile(profile.cdpUrl);
|
|
240
|
-
};
|
|
241
|
-
const waitForCdpReadyAfterLaunch = async () => {
|
|
242
|
-
const deadlineMs = Date.now() + (state().resolved.localCdpReadyTimeoutMs ?? CDP_READY_AFTER_LAUNCH_WINDOW_MS);
|
|
243
|
-
while (Date.now() < deadlineMs) {
|
|
244
|
-
const remainingMs = Math.max(0, deadlineMs - Date.now());
|
|
245
|
-
if (await isReachable(Math.max(75, Math.min(250, remainingMs)))) return;
|
|
246
|
-
await new Promise((r) => setTimeout(r, 100));
|
|
247
|
-
}
|
|
248
|
-
throw new Error(`Chrome CDP websocket for profile "${profile.name}" is not reachable after start. ${await describeCdpFailure(250)}`);
|
|
249
|
-
};
|
|
250
|
-
const waitForChromeMcpReadyAfterAttach = async () => {
|
|
251
|
-
const deadlineMs = Date.now() + CHROME_MCP_ATTACH_READY_WINDOW_MS;
|
|
252
|
-
let lastError;
|
|
253
|
-
while (Date.now() < deadlineMs) {
|
|
254
|
-
try {
|
|
255
|
-
const { listChromeMcpTabs } = await getChromeMcpModule();
|
|
256
|
-
await listChromeMcpTabs(profile.name, profile);
|
|
257
|
-
return;
|
|
258
|
-
} catch (err) {
|
|
259
|
-
lastError = err;
|
|
260
|
-
}
|
|
261
|
-
await new Promise((r) => setTimeout(r, 200));
|
|
262
|
-
}
|
|
263
|
-
throw new BrowserProfileUnavailableError(formatChromeMcpAttachFailure(lastError));
|
|
264
|
-
};
|
|
265
|
-
const launchManagedChrome = async (profileState, current, launchOptions) => {
|
|
266
|
-
assertManagedLaunchNotCoolingDown(profile.name, profileState);
|
|
267
|
-
try {
|
|
268
|
-
return await launchDaoCoreChrome(current.resolved, profile, launchOptions);
|
|
269
|
-
} catch (err) {
|
|
270
|
-
recordManagedLaunchFailure(profileState, err);
|
|
271
|
-
throw err;
|
|
272
|
-
}
|
|
273
|
-
};
|
|
274
|
-
const ensureBrowserAvailableOnce = async (options) => {
|
|
275
|
-
await reconcileProfileRuntime();
|
|
276
|
-
if (capabilities.usesChromeMcp) {
|
|
277
|
-
if (profile.userDataDir && !fs.existsSync(profile.userDataDir)) throw new BrowserProfileUnavailableError(`Browser user data directory not found for profile "${profile.name}": ${profile.userDataDir}`);
|
|
278
|
-
const { ensureChromeMcpAvailable } = await getChromeMcpModule();
|
|
279
|
-
await ensureChromeMcpAvailable(profile.name, profile);
|
|
280
|
-
await waitForChromeMcpReadyAfterAttach();
|
|
281
|
-
return;
|
|
282
|
-
}
|
|
283
|
-
const current = state();
|
|
284
|
-
const remoteCdp = capabilities.isRemote;
|
|
285
|
-
const attachOnly = profile.attachOnly;
|
|
286
|
-
const profileState = getProfileState();
|
|
287
|
-
const httpReachable = await isHttpReachable();
|
|
288
|
-
const launchOptions = launchOptionsForEnsure(options);
|
|
289
|
-
if (!httpReachable) {
|
|
290
|
-
if ((attachOnly || remoteCdp) && opts.onEnsureAttachTarget) {
|
|
291
|
-
await opts.onEnsureAttachTarget(profile);
|
|
292
|
-
if (await isHttpReachable(1200)) return;
|
|
293
|
-
}
|
|
294
|
-
if (!attachOnly && !remoteCdp && profile.cdpIsLoopback && !profileState.running) {
|
|
295
|
-
if (await isHttpReachable(1200) && await isReachable(1200)) {
|
|
296
|
-
resetManagedLaunchFailure(profileState);
|
|
297
|
-
return;
|
|
298
|
-
}
|
|
299
|
-
}
|
|
300
|
-
if (attachOnly || remoteCdp) throw new BrowserProfileUnavailableError(remoteCdp ? `Remote CDP for profile "${profile.name}" is not reachable at ${redactedProfileCdpUrl}.` : `Browser attachOnly is enabled and profile "${profile.name}" is not running.`);
|
|
301
|
-
const launched = await launchManagedChrome(profileState, current, launchOptions);
|
|
302
|
-
attachRunning(launched);
|
|
303
|
-
try {
|
|
304
|
-
await waitForCdpReadyAfterLaunch();
|
|
305
|
-
resetManagedLaunchFailure(profileState);
|
|
306
|
-
} catch (err) {
|
|
307
|
-
await stopDaoCoreChrome(launched).catch(() => {});
|
|
308
|
-
setProfileRunning(null);
|
|
309
|
-
recordManagedLaunchFailure(profileState, err);
|
|
310
|
-
throw err;
|
|
311
|
-
}
|
|
312
|
-
return;
|
|
313
|
-
}
|
|
314
|
-
if (await isReachable()) {
|
|
315
|
-
resetManagedLaunchFailure(profileState);
|
|
316
|
-
return;
|
|
317
|
-
}
|
|
318
|
-
if (attachOnly || remoteCdp) {
|
|
319
|
-
if (opts.onEnsureAttachTarget) {
|
|
320
|
-
await opts.onEnsureAttachTarget(profile);
|
|
321
|
-
if (await isReachable(1200)) return;
|
|
322
|
-
}
|
|
323
|
-
if (remoteCdp && await isReachable(1200)) return;
|
|
324
|
-
const detail = await describeCdpFailure(PROFILE_ATTACH_RETRY_TIMEOUT_MS);
|
|
325
|
-
throw new BrowserProfileUnavailableError(remoteCdp ? `Remote CDP websocket for profile "${profile.name}" is not reachable. ${detail}` : `Browser attachOnly is enabled and CDP websocket for profile "${profile.name}" is not reachable. ${detail}`);
|
|
326
|
-
}
|
|
327
|
-
if (!profileState.running) {
|
|
328
|
-
const detail = await describeCdpFailure(PROFILE_ATTACH_RETRY_TIMEOUT_MS);
|
|
329
|
-
throw new BrowserProfileUnavailableError(`Port ${profile.cdpPort} is in use for profile "${profile.name}" but not by daocore. ${formatLocalPortOwnershipHint(profile)} ${detail}`);
|
|
330
|
-
}
|
|
331
|
-
await stopDaoCoreChrome(profileState.running);
|
|
332
|
-
setProfileRunning(null);
|
|
333
|
-
attachRunning(await launchManagedChrome(profileState, current, launchOptions));
|
|
334
|
-
if (!await isReachable(600)) {
|
|
335
|
-
const err = /* @__PURE__ */ new Error(`Chrome CDP websocket for profile "${profile.name}" is not reachable after restart. ${await describeCdpFailure(600)}`);
|
|
336
|
-
recordManagedLaunchFailure(profileState, err);
|
|
337
|
-
throw err;
|
|
338
|
-
}
|
|
339
|
-
resetManagedLaunchFailure(profileState);
|
|
340
|
-
};
|
|
341
|
-
const ensureBrowserAvailable = async (options) => {
|
|
342
|
-
const key = ensureOptionsKey(options);
|
|
343
|
-
const profileState = getProfileState();
|
|
344
|
-
for (;;) {
|
|
345
|
-
const current = profileState.ensureBrowserAvailable;
|
|
346
|
-
if (!current) break;
|
|
347
|
-
if (current.key === key) return current.promise;
|
|
348
|
-
await current.promise.catch(() => {});
|
|
349
|
-
}
|
|
350
|
-
const promise = ensureBrowserAvailableOnce(options).finally(() => {
|
|
351
|
-
if (profileState.ensureBrowserAvailable?.promise === promise) profileState.ensureBrowserAvailable = null;
|
|
352
|
-
});
|
|
353
|
-
profileState.ensureBrowserAvailable = {
|
|
354
|
-
key,
|
|
355
|
-
promise
|
|
356
|
-
};
|
|
357
|
-
return promise;
|
|
358
|
-
};
|
|
359
|
-
const stopRunningBrowser = async () => {
|
|
360
|
-
await reconcileProfileRuntime();
|
|
361
|
-
if (capabilities.usesChromeMcp) {
|
|
362
|
-
const { closeChromeMcpSession } = await getChromeMcpModule();
|
|
363
|
-
return { stopped: await closeChromeMcpSession(profile.name) };
|
|
364
|
-
}
|
|
365
|
-
const profileState = getProfileState();
|
|
366
|
-
resetManagedLaunchFailure(profileState);
|
|
367
|
-
if (!profileState.running) {
|
|
368
|
-
const idleStop = resolveIdleProfileStopOutcome(profile);
|
|
369
|
-
if (idleStop.closePlaywright) await closePlaywrightBrowserConnectionForProfile(profile.cdpUrl);
|
|
370
|
-
return { stopped: idleStop.stopped };
|
|
371
|
-
}
|
|
372
|
-
await stopDaoCoreChrome(profileState.running);
|
|
373
|
-
setProfileRunning(null);
|
|
374
|
-
return { stopped: true };
|
|
375
|
-
};
|
|
376
|
-
return {
|
|
377
|
-
isHttpReachable,
|
|
378
|
-
isTransportAvailable,
|
|
379
|
-
isReachable,
|
|
380
|
-
ensureBrowserAvailable,
|
|
381
|
-
stopRunningBrowser
|
|
382
|
-
};
|
|
383
|
-
}
|
|
384
|
-
//#endregion
|
|
385
|
-
//#region extensions/browser/src/browser/server-context.reset.ts
|
|
386
|
-
function createProfileResetOps({ profile, getProfileState, stopRunningBrowser, isHttpReachable, resolveDaoCoreUserDataDir }) {
|
|
387
|
-
const capabilities = getBrowserProfileCapabilities(profile);
|
|
388
|
-
const resetProfile = async () => {
|
|
389
|
-
if (!capabilities.supportsReset) throw new BrowserResetUnsupportedError(`reset-profile is only supported for local profiles (profile "${profile.name}" is remote).`);
|
|
390
|
-
const userDataDir = resolveDaoCoreUserDataDir(profile.name);
|
|
391
|
-
const profileState = getProfileState();
|
|
392
|
-
profileState.managedLaunchFailure = void 0;
|
|
393
|
-
profileState.ensureBrowserAvailable = null;
|
|
394
|
-
if (await isHttpReachable(300) && !profileState.running) await closePlaywrightBrowserConnectionForProfile(profile.cdpUrl);
|
|
395
|
-
if (profileState.running) await stopRunningBrowser();
|
|
396
|
-
await closePlaywrightBrowserConnectionForProfile(profile.cdpUrl);
|
|
397
|
-
if (!fs.existsSync(userDataDir)) return {
|
|
398
|
-
moved: false,
|
|
399
|
-
from: userDataDir
|
|
400
|
-
};
|
|
401
|
-
return {
|
|
402
|
-
moved: true,
|
|
403
|
-
from: userDataDir,
|
|
404
|
-
to: await movePathToTrash(userDataDir)
|
|
405
|
-
};
|
|
406
|
-
};
|
|
407
|
-
return { resetProfile };
|
|
408
|
-
}
|
|
409
|
-
//#endregion
|
|
410
|
-
//#region extensions/browser/src/browser/server-context.selection.ts
|
|
411
|
-
function createProfileSelectionOps({ profile, getProfileState, getCdpControlPolicy, ensureBrowserAvailable, listTabs, openTab }) {
|
|
412
|
-
const cdpHttpBase = normalizeCdpHttpBaseForJsonEndpoints(profile.cdpUrl);
|
|
413
|
-
const capabilities = getBrowserProfileCapabilities(profile);
|
|
414
|
-
const ensureTabAvailable = async (targetId) => {
|
|
415
|
-
await ensureBrowserAvailable();
|
|
416
|
-
const profileState = getProfileState();
|
|
417
|
-
if ((await listTabs()).length === 0) await openTab("about:blank");
|
|
418
|
-
const tabs = await listTabs();
|
|
419
|
-
const candidates = capabilities.supportsPerTabWs ? tabs.filter((t) => Boolean(t.wsUrl)) : tabs;
|
|
420
|
-
const resolveById = (raw) => {
|
|
421
|
-
const resolved = resolveTargetIdFromTabs(raw, candidates);
|
|
422
|
-
if (!resolved.ok) {
|
|
423
|
-
if (resolved.reason === "ambiguous") return "AMBIGUOUS";
|
|
424
|
-
return null;
|
|
425
|
-
}
|
|
426
|
-
return candidates.find((t) => t.targetId === resolved.targetId) ?? null;
|
|
427
|
-
};
|
|
428
|
-
const pickDefault = () => {
|
|
429
|
-
const last = normalizeOptionalString(profileState.lastTargetId) ?? "";
|
|
430
|
-
const lastResolved = last ? resolveById(last) : null;
|
|
431
|
-
if (lastResolved && lastResolved !== "AMBIGUOUS") return lastResolved;
|
|
432
|
-
return candidates.find((t) => (t.type ?? "page") === "page") ?? candidates.at(0) ?? null;
|
|
433
|
-
};
|
|
434
|
-
const chosen = targetId ? resolveById(targetId) : pickDefault();
|
|
435
|
-
if (chosen === "AMBIGUOUS") throw new BrowserTargetAmbiguousError();
|
|
436
|
-
if (!chosen) throw new BrowserTabNotFoundError(targetId ? { input: targetId } : void 0);
|
|
437
|
-
profileState.lastTargetId = chosen.targetId;
|
|
438
|
-
return chosen;
|
|
439
|
-
};
|
|
440
|
-
const resolveTargetIdOrThrow = async (targetId) => {
|
|
441
|
-
const resolved = resolveTargetIdFromTabs(targetId, await listTabs());
|
|
442
|
-
if (!resolved.ok) {
|
|
443
|
-
if (resolved.reason === "ambiguous") throw new BrowserTargetAmbiguousError();
|
|
444
|
-
throw new BrowserTabNotFoundError({ input: targetId });
|
|
445
|
-
}
|
|
446
|
-
return resolved.targetId;
|
|
447
|
-
};
|
|
448
|
-
const focusTab = async (targetId) => {
|
|
449
|
-
const resolvedTargetId = await resolveTargetIdOrThrow(targetId);
|
|
450
|
-
if (capabilities.usesChromeMcp) {
|
|
451
|
-
const { focusChromeMcpTab } = await getChromeMcpModule();
|
|
452
|
-
await focusChromeMcpTab(profile.name, resolvedTargetId, profile);
|
|
453
|
-
const profileState = getProfileState();
|
|
454
|
-
profileState.lastTargetId = resolvedTargetId;
|
|
455
|
-
return;
|
|
456
|
-
}
|
|
457
|
-
if (capabilities.usesPersistentPlaywright) {
|
|
458
|
-
const focusPageByTargetIdViaPlaywright = (await getPwAiModule({ mode: "strict" }))?.focusPageByTargetIdViaPlaywright;
|
|
459
|
-
if (typeof focusPageByTargetIdViaPlaywright === "function") {
|
|
460
|
-
await focusPageByTargetIdViaPlaywright({
|
|
461
|
-
cdpUrl: profile.cdpUrl,
|
|
462
|
-
targetId: resolvedTargetId,
|
|
463
|
-
ssrfPolicy: getCdpControlPolicy()
|
|
464
|
-
});
|
|
465
|
-
const profileState = getProfileState();
|
|
466
|
-
profileState.lastTargetId = resolvedTargetId;
|
|
467
|
-
return;
|
|
468
|
-
}
|
|
469
|
-
}
|
|
470
|
-
await fetchOk(appendCdpPath(cdpHttpBase, `/json/activate/${resolvedTargetId}`), void 0, void 0, getCdpControlPolicy());
|
|
471
|
-
const profileState = getProfileState();
|
|
472
|
-
profileState.lastTargetId = resolvedTargetId;
|
|
473
|
-
};
|
|
474
|
-
const closeTab = async (targetId) => {
|
|
475
|
-
const resolvedTargetId = await resolveTargetIdOrThrow(targetId);
|
|
476
|
-
if (capabilities.usesChromeMcp) {
|
|
477
|
-
const { closeChromeMcpTab } = await getChromeMcpModule();
|
|
478
|
-
await closeChromeMcpTab(profile.name, resolvedTargetId, profile);
|
|
479
|
-
return;
|
|
480
|
-
}
|
|
481
|
-
if (capabilities.usesPersistentPlaywright) {
|
|
482
|
-
const closePageByTargetIdViaPlaywright = (await getPwAiModule({ mode: "strict" }))?.closePageByTargetIdViaPlaywright;
|
|
483
|
-
if (typeof closePageByTargetIdViaPlaywright === "function") {
|
|
484
|
-
await closePageByTargetIdViaPlaywright({
|
|
485
|
-
cdpUrl: profile.cdpUrl,
|
|
486
|
-
targetId: resolvedTargetId,
|
|
487
|
-
ssrfPolicy: getCdpControlPolicy()
|
|
488
|
-
});
|
|
489
|
-
return;
|
|
490
|
-
}
|
|
491
|
-
}
|
|
492
|
-
await fetchOk(appendCdpPath(cdpHttpBase, `/json/close/${resolvedTargetId}`), void 0, void 0, getCdpControlPolicy());
|
|
493
|
-
};
|
|
494
|
-
return {
|
|
495
|
-
ensureTabAvailable,
|
|
496
|
-
focusTab,
|
|
497
|
-
closeTab
|
|
498
|
-
};
|
|
499
|
-
}
|
|
500
|
-
//#endregion
|
|
501
|
-
//#region extensions/browser/src/browser/server-context.tab-ops.ts
|
|
502
|
-
/**
|
|
503
|
-
* Normalize a CDP WebSocket URL to use the correct base URL.
|
|
504
|
-
*/
|
|
505
|
-
function normalizeWsUrl(raw, cdpBaseUrl) {
|
|
506
|
-
if (!raw) return;
|
|
507
|
-
try {
|
|
508
|
-
return normalizeCdpWsUrl(raw, cdpBaseUrl);
|
|
509
|
-
} catch {
|
|
510
|
-
return raw;
|
|
511
|
-
}
|
|
512
|
-
}
|
|
513
|
-
const TAB_LABEL_PATTERN = /^[A-Za-z0-9_.:-]{1,64}$/;
|
|
514
|
-
function normalizeTabLabel(label) {
|
|
515
|
-
const trimmed = label.trim();
|
|
516
|
-
if (!TAB_LABEL_PATTERN.test(trimmed)) throw new Error("tab label must be 1-64 chars and use only letters, numbers, _, ., :, or -");
|
|
517
|
-
return trimmed;
|
|
518
|
-
}
|
|
519
|
-
function getTabAliasState(profileState) {
|
|
520
|
-
profileState.tabAliases ??= {
|
|
521
|
-
nextTabNumber: 1,
|
|
522
|
-
byTargetId: {}
|
|
523
|
-
};
|
|
524
|
-
return profileState.tabAliases;
|
|
525
|
-
}
|
|
526
|
-
function assignTabAlias(params) {
|
|
527
|
-
const aliases = getTabAliasState(params.profileState);
|
|
528
|
-
let entry = aliases.byTargetId[params.tab.targetId];
|
|
529
|
-
if (!entry) {
|
|
530
|
-
entry = { tabId: `t${aliases.nextTabNumber}` };
|
|
531
|
-
aliases.nextTabNumber += 1;
|
|
532
|
-
aliases.byTargetId[params.tab.targetId] = entry;
|
|
533
|
-
}
|
|
534
|
-
if (params.label) {
|
|
535
|
-
const label = normalizeTabLabel(params.label);
|
|
536
|
-
for (const [targetId, current] of Object.entries(aliases.byTargetId)) if (targetId !== params.tab.targetId && current.label === label) delete current.label;
|
|
537
|
-
entry.label = label;
|
|
538
|
-
}
|
|
539
|
-
entry.url = params.tab.url;
|
|
540
|
-
const labelFields = entry.label ? { label: entry.label } : {};
|
|
541
|
-
return {
|
|
542
|
-
...params.tab,
|
|
543
|
-
suggestedTargetId: entry.label ?? entry.tabId,
|
|
544
|
-
tabId: entry.tabId,
|
|
545
|
-
...labelFields
|
|
546
|
-
};
|
|
547
|
-
}
|
|
548
|
-
function isConfidentReplacement(params) {
|
|
549
|
-
const staleUrl = params.staleEntry.url?.trim();
|
|
550
|
-
const tabUrl = params.tab.url?.trim();
|
|
551
|
-
if (staleUrl && tabUrl && staleUrl === tabUrl) return true;
|
|
552
|
-
return params.staleCount === 1 && params.newCandidateCount === 1;
|
|
553
|
-
}
|
|
554
|
-
function assignTabAliases(profileState, tabs) {
|
|
555
|
-
const aliases = getTabAliasState(profileState);
|
|
556
|
-
const liveTargetIds = new Set(tabs.map((tab) => tab.targetId));
|
|
557
|
-
const staleEntries = Object.entries(aliases.byTargetId).filter(([targetId]) => !liveTargetIds.has(targetId));
|
|
558
|
-
const newCandidates = tabs.filter((tab) => !aliases.byTargetId[tab.targetId]);
|
|
559
|
-
const claimedTargetIds = /* @__PURE__ */ new Set();
|
|
560
|
-
for (const [oldTargetId, staleEntry] of staleEntries) {
|
|
561
|
-
const candidate = newCandidates.find((tab) => !claimedTargetIds.has(tab.targetId) && isConfidentReplacement({
|
|
562
|
-
staleEntry,
|
|
563
|
-
tab,
|
|
564
|
-
staleCount: staleEntries.length,
|
|
565
|
-
newCandidateCount: newCandidates.length
|
|
566
|
-
}));
|
|
567
|
-
if (!candidate) continue;
|
|
568
|
-
aliases.byTargetId[candidate.targetId] = staleEntry;
|
|
569
|
-
delete aliases.byTargetId[oldTargetId];
|
|
570
|
-
claimedTargetIds.add(candidate.targetId);
|
|
571
|
-
if (profileState.lastTargetId === oldTargetId) profileState.lastTargetId = candidate.targetId;
|
|
572
|
-
}
|
|
573
|
-
for (const targetId of Object.keys(aliases.byTargetId)) if (!liveTargetIds.has(targetId)) delete aliases.byTargetId[targetId];
|
|
574
|
-
return tabs.map((tab) => assignTabAlias({
|
|
575
|
-
profileState,
|
|
576
|
-
tab
|
|
577
|
-
}));
|
|
578
|
-
}
|
|
579
|
-
function createProfileTabOps({ profile, state, getProfileState }) {
|
|
580
|
-
const cdpHttpBase = normalizeCdpHttpBaseForJsonEndpoints(profile.cdpUrl);
|
|
581
|
-
const capabilities = getBrowserProfileCapabilities(profile);
|
|
582
|
-
const getCdpControlPolicy = () => resolveCdpControlPolicy(profile, state().resolved.ssrfPolicy);
|
|
583
|
-
const getNavigationPolicy = () => withBrowserNavigationPolicy(state().resolved.ssrfPolicy, { browserProxyMode: resolveBrowserNavigationProxyMode({
|
|
584
|
-
resolved: state().resolved,
|
|
585
|
-
profile
|
|
586
|
-
}) });
|
|
587
|
-
const getRemoteCdpActionTimeouts = () => {
|
|
588
|
-
if (profile.cdpIsLoopback && !profile.attachOnly) return;
|
|
589
|
-
const resolved = state().resolved;
|
|
590
|
-
return {
|
|
591
|
-
httpTimeoutMs: resolved.remoteCdpTimeoutMs,
|
|
592
|
-
handshakeTimeoutMs: resolved.remoteCdpHandshakeTimeoutMs
|
|
593
|
-
};
|
|
594
|
-
};
|
|
595
|
-
const readTabs = async () => {
|
|
596
|
-
if (capabilities.usesChromeMcp) {
|
|
597
|
-
const { listChromeMcpTabs } = await getChromeMcpModule();
|
|
598
|
-
return await listChromeMcpTabs(profile.name, profile);
|
|
599
|
-
}
|
|
600
|
-
if (capabilities.usesPersistentPlaywright) {
|
|
601
|
-
const listPagesViaPlaywright = (await getPwAiModule({ mode: "strict" }))?.listPagesViaPlaywright;
|
|
602
|
-
if (typeof listPagesViaPlaywright === "function") {
|
|
603
|
-
const ssrfPolicy = getCdpControlPolicy();
|
|
604
|
-
await assertCdpEndpointAllowed(profile.cdpUrl, ssrfPolicy);
|
|
605
|
-
return (await listPagesViaPlaywright({
|
|
606
|
-
cdpUrl: profile.cdpUrl,
|
|
607
|
-
ssrfPolicy
|
|
608
|
-
})).filter(isSelectableCdpBrowserTarget).map((p) => ({
|
|
609
|
-
targetId: p.targetId,
|
|
610
|
-
title: p.title,
|
|
611
|
-
url: p.url,
|
|
612
|
-
type: p.type
|
|
613
|
-
}));
|
|
614
|
-
}
|
|
615
|
-
}
|
|
616
|
-
return (await fetchJson(appendCdpPath(cdpHttpBase, "/json/list"), void 0, void 0, getCdpControlPolicy())).map((t) => ({
|
|
617
|
-
targetId: t.id ?? "",
|
|
618
|
-
title: t.title ?? "",
|
|
619
|
-
url: t.url ?? "",
|
|
620
|
-
wsUrl: normalizeWsUrl(t.webSocketDebuggerUrl, profile.cdpUrl),
|
|
621
|
-
type: t.type
|
|
622
|
-
})).filter((t) => Boolean(t.targetId) && isSelectableCdpBrowserTarget(t));
|
|
623
|
-
};
|
|
624
|
-
const listTabs = async () => {
|
|
625
|
-
const tabs = await readTabs();
|
|
626
|
-
return assignTabAliases(getProfileState(), tabs);
|
|
627
|
-
};
|
|
628
|
-
const enforceManagedTabLimit = async (keepTargetId) => {
|
|
629
|
-
const profileState = getProfileState();
|
|
630
|
-
if (!capabilities.supportsManagedTabLimit || state().resolved.attachOnly || !profileState.running) return;
|
|
631
|
-
const pageTabs = await listTabs().then((tabs) => tabs.filter((tab) => (tab.type ?? "page") === "page")).catch(() => []);
|
|
632
|
-
if (pageTabs.length <= 8) return;
|
|
633
|
-
const candidates = pageTabs.filter((tab) => tab.targetId !== keepTargetId);
|
|
634
|
-
const excessCount = pageTabs.length - 8;
|
|
635
|
-
for (const tab of candidates.slice(0, excessCount)) fetchOk(appendCdpPath(cdpHttpBase, `/json/close/${tab.targetId}`), void 0, void 0, getCdpControlPolicy()).catch(() => {});
|
|
636
|
-
};
|
|
637
|
-
const triggerManagedTabLimit = (keepTargetId) => {
|
|
638
|
-
enforceManagedTabLimit(keepTargetId).catch(() => {});
|
|
639
|
-
};
|
|
640
|
-
const openTab = async (url, opts) => {
|
|
641
|
-
const ssrfPolicyOpts = getNavigationPolicy();
|
|
642
|
-
if (capabilities.usesChromeMcp) {
|
|
643
|
-
await assertBrowserNavigationAllowed({
|
|
644
|
-
url,
|
|
645
|
-
...ssrfPolicyOpts
|
|
646
|
-
});
|
|
647
|
-
const { openChromeMcpTab } = await getChromeMcpModule();
|
|
648
|
-
const page = await openChromeMcpTab(profile.name, url, profile);
|
|
649
|
-
const profileState = getProfileState();
|
|
650
|
-
profileState.lastTargetId = page.targetId;
|
|
651
|
-
await assertBrowserNavigationResultAllowed({
|
|
652
|
-
url: page.url,
|
|
653
|
-
...ssrfPolicyOpts
|
|
654
|
-
});
|
|
655
|
-
return assignTabAlias({
|
|
656
|
-
profileState,
|
|
657
|
-
tab: page,
|
|
658
|
-
label: opts?.label
|
|
659
|
-
});
|
|
660
|
-
}
|
|
661
|
-
if (capabilities.usesPersistentPlaywright) {
|
|
662
|
-
const createPageViaPlaywright = (await getPwAiModule({ mode: "strict" }))?.createPageViaPlaywright;
|
|
663
|
-
if (typeof createPageViaPlaywright === "function") {
|
|
664
|
-
const page = await createPageViaPlaywright({
|
|
665
|
-
cdpUrl: profile.cdpUrl,
|
|
666
|
-
url,
|
|
667
|
-
...ssrfPolicyOpts
|
|
668
|
-
});
|
|
669
|
-
const profileState = getProfileState();
|
|
670
|
-
profileState.lastTargetId = page.targetId;
|
|
671
|
-
triggerManagedTabLimit(page.targetId);
|
|
672
|
-
return assignTabAlias({
|
|
673
|
-
profileState,
|
|
674
|
-
label: opts?.label,
|
|
675
|
-
tab: {
|
|
676
|
-
targetId: page.targetId,
|
|
677
|
-
title: page.title,
|
|
678
|
-
url: page.url,
|
|
679
|
-
type: page.type
|
|
680
|
-
}
|
|
681
|
-
});
|
|
682
|
-
}
|
|
683
|
-
}
|
|
684
|
-
if (requiresInspectableBrowserNavigationRedirectsForUrl(url, state().resolved.ssrfPolicy)) throw new InvalidBrowserNavigationUrlError("Navigation blocked: strict browser SSRF policy requires Playwright-backed redirect-hop inspection");
|
|
685
|
-
await assertBrowserNavigationAllowed({
|
|
686
|
-
url,
|
|
687
|
-
...ssrfPolicyOpts
|
|
688
|
-
});
|
|
689
|
-
const cdpActionTimeouts = getRemoteCdpActionTimeouts();
|
|
690
|
-
const createTargetOpts = {
|
|
691
|
-
cdpUrl: profile.cdpUrl,
|
|
692
|
-
url,
|
|
693
|
-
ssrfPolicy: getCdpControlPolicy()
|
|
694
|
-
};
|
|
695
|
-
if (cdpActionTimeouts) createTargetOpts.timeouts = cdpActionTimeouts;
|
|
696
|
-
const createdViaCdp = await createTargetViaCdp(createTargetOpts).then((r) => r.targetId).catch(() => null);
|
|
697
|
-
if (createdViaCdp) {
|
|
698
|
-
const profileState = getProfileState();
|
|
699
|
-
profileState.lastTargetId = createdViaCdp;
|
|
700
|
-
const deadline = Date.now() + OPEN_TAB_DISCOVERY_WINDOW_MS;
|
|
701
|
-
while (Date.now() < deadline) {
|
|
702
|
-
const found = (await listTabs().catch(() => [])).find((t) => t.targetId === createdViaCdp);
|
|
703
|
-
if (found) {
|
|
704
|
-
await assertBrowserNavigationResultAllowed({
|
|
705
|
-
url: found.url,
|
|
706
|
-
...ssrfPolicyOpts
|
|
707
|
-
});
|
|
708
|
-
triggerManagedTabLimit(found.targetId);
|
|
709
|
-
return assignTabAlias({
|
|
710
|
-
profileState,
|
|
711
|
-
tab: found,
|
|
712
|
-
label: opts?.label
|
|
713
|
-
});
|
|
714
|
-
}
|
|
715
|
-
await new Promise((r) => setTimeout(r, 100));
|
|
716
|
-
}
|
|
717
|
-
triggerManagedTabLimit(createdViaCdp);
|
|
718
|
-
return assignTabAlias({
|
|
719
|
-
profileState,
|
|
720
|
-
tab: {
|
|
721
|
-
targetId: createdViaCdp,
|
|
722
|
-
title: "",
|
|
723
|
-
url,
|
|
724
|
-
type: "page"
|
|
725
|
-
},
|
|
726
|
-
label: opts?.label
|
|
727
|
-
});
|
|
728
|
-
}
|
|
729
|
-
const encoded = encodeURIComponent(url);
|
|
730
|
-
const endpointUrl = new URL(appendCdpPath(cdpHttpBase, "/json/new"));
|
|
731
|
-
const endpoint = endpointUrl.search ? (() => {
|
|
732
|
-
endpointUrl.searchParams.set("url", url);
|
|
733
|
-
return endpointUrl.toString();
|
|
734
|
-
})() : `${endpointUrl.toString()}?${encoded}`;
|
|
735
|
-
const created = await fetchJson(endpoint, cdpActionTimeouts?.httpTimeoutMs ?? 1500, { method: "PUT" }, getCdpControlPolicy()).catch(async (err) => {
|
|
736
|
-
if (String(err).includes("HTTP 405")) return await fetchJson(endpoint, cdpActionTimeouts?.httpTimeoutMs ?? 1500, void 0, getCdpControlPolicy());
|
|
737
|
-
throw err;
|
|
738
|
-
});
|
|
739
|
-
if (!created.id) throw new Error("Failed to open tab (missing id)");
|
|
740
|
-
const profileState = getProfileState();
|
|
741
|
-
profileState.lastTargetId = created.id;
|
|
742
|
-
const resolvedUrl = created.url ?? url;
|
|
743
|
-
await assertBrowserNavigationResultAllowed({
|
|
744
|
-
url: resolvedUrl,
|
|
745
|
-
...ssrfPolicyOpts
|
|
746
|
-
});
|
|
747
|
-
triggerManagedTabLimit(created.id);
|
|
748
|
-
return assignTabAlias({
|
|
749
|
-
profileState,
|
|
750
|
-
label: opts?.label,
|
|
751
|
-
tab: {
|
|
752
|
-
targetId: created.id,
|
|
753
|
-
title: created.title ?? "",
|
|
754
|
-
url: resolvedUrl,
|
|
755
|
-
wsUrl: normalizeWsUrl(created.webSocketDebuggerUrl, profile.cdpUrl),
|
|
756
|
-
type: created.type
|
|
757
|
-
}
|
|
758
|
-
});
|
|
759
|
-
};
|
|
760
|
-
const labelTab = async (targetId, label) => {
|
|
761
|
-
const normalizedLabel = normalizeTabLabel(label);
|
|
762
|
-
const tabs = await listTabs();
|
|
763
|
-
const resolved = resolveTargetIdFromTabs(targetId, tabs);
|
|
764
|
-
if (!resolved.ok) {
|
|
765
|
-
if (resolved.reason === "ambiguous") throw new BrowserTargetAmbiguousError();
|
|
766
|
-
throw new BrowserTabNotFoundError({ input: targetId });
|
|
767
|
-
}
|
|
768
|
-
const tab = tabs.find((candidate) => candidate.targetId === resolved.targetId);
|
|
769
|
-
if (!tab) throw new BrowserTabNotFoundError({ input: targetId });
|
|
770
|
-
return assignTabAlias({
|
|
771
|
-
profileState: getProfileState(),
|
|
772
|
-
tab,
|
|
773
|
-
label: normalizedLabel
|
|
774
|
-
});
|
|
775
|
-
};
|
|
776
|
-
return {
|
|
777
|
-
listTabs,
|
|
778
|
-
openTab,
|
|
779
|
-
labelTab
|
|
780
|
-
};
|
|
781
|
-
}
|
|
782
|
-
//#endregion
|
|
783
|
-
//#region extensions/browser/src/browser/server-context.ts
|
|
784
|
-
function listKnownProfileNames(state) {
|
|
785
|
-
const names = new Set(Object.keys(state.resolved.profiles));
|
|
786
|
-
for (const name of state.profiles.keys()) names.add(name);
|
|
787
|
-
return [...names];
|
|
788
|
-
}
|
|
789
|
-
/**
|
|
790
|
-
* Create a profile-scoped context for browser operations.
|
|
791
|
-
*/
|
|
792
|
-
function createProfileContext(opts, profile) {
|
|
793
|
-
const state = () => {
|
|
794
|
-
const current = opts.getState();
|
|
795
|
-
if (!current) throw new Error("Browser server not started");
|
|
796
|
-
return current;
|
|
797
|
-
};
|
|
798
|
-
const getProfileState = () => {
|
|
799
|
-
const current = state();
|
|
800
|
-
let profileState = current.profiles.get(profile.name);
|
|
801
|
-
if (!profileState) {
|
|
802
|
-
profileState = {
|
|
803
|
-
profile,
|
|
804
|
-
running: null,
|
|
805
|
-
lastTargetId: null,
|
|
806
|
-
reconcile: null
|
|
807
|
-
};
|
|
808
|
-
current.profiles.set(profile.name, profileState);
|
|
809
|
-
}
|
|
810
|
-
return profileState;
|
|
811
|
-
};
|
|
812
|
-
const setProfileRunning = (running) => {
|
|
813
|
-
const profileState = getProfileState();
|
|
814
|
-
profileState.running = running;
|
|
815
|
-
};
|
|
816
|
-
const { listTabs, openTab, labelTab } = createProfileTabOps({
|
|
817
|
-
profile,
|
|
818
|
-
state,
|
|
819
|
-
getProfileState
|
|
820
|
-
});
|
|
821
|
-
const { ensureBrowserAvailable, isHttpReachable, isTransportAvailable, isReachable, stopRunningBrowser } = createProfileAvailability({
|
|
822
|
-
opts,
|
|
823
|
-
profile,
|
|
824
|
-
state,
|
|
825
|
-
getProfileState,
|
|
826
|
-
setProfileRunning
|
|
827
|
-
});
|
|
828
|
-
const { ensureTabAvailable, focusTab, closeTab } = createProfileSelectionOps({
|
|
829
|
-
profile,
|
|
830
|
-
getProfileState,
|
|
831
|
-
getCdpControlPolicy: () => resolveCdpControlPolicy(profile, state().resolved.ssrfPolicy),
|
|
832
|
-
ensureBrowserAvailable,
|
|
833
|
-
listTabs,
|
|
834
|
-
openTab
|
|
835
|
-
});
|
|
836
|
-
const { resetProfile } = createProfileResetOps({
|
|
837
|
-
profile,
|
|
838
|
-
getProfileState,
|
|
839
|
-
stopRunningBrowser,
|
|
840
|
-
isHttpReachable,
|
|
841
|
-
resolveDaoCoreUserDataDir
|
|
842
|
-
});
|
|
843
|
-
return {
|
|
844
|
-
profile,
|
|
845
|
-
ensureBrowserAvailable,
|
|
846
|
-
ensureTabAvailable,
|
|
847
|
-
isHttpReachable,
|
|
848
|
-
isTransportAvailable,
|
|
849
|
-
isReachable,
|
|
850
|
-
listTabs,
|
|
851
|
-
openTab,
|
|
852
|
-
labelTab,
|
|
853
|
-
focusTab,
|
|
854
|
-
closeTab,
|
|
855
|
-
stopRunningBrowser,
|
|
856
|
-
resetProfile
|
|
857
|
-
};
|
|
858
|
-
}
|
|
859
|
-
function createBrowserRouteContext(opts) {
|
|
860
|
-
const refreshConfigFromDisk = opts.refreshConfigFromDisk === true;
|
|
861
|
-
const state = () => {
|
|
862
|
-
const current = opts.getState();
|
|
863
|
-
if (!current) throw new Error("Browser server not started");
|
|
864
|
-
return current;
|
|
865
|
-
};
|
|
866
|
-
const forProfile = (profileName) => {
|
|
867
|
-
const current = state();
|
|
868
|
-
const name = profileName ?? current.resolved.defaultProfile;
|
|
869
|
-
const profile = resolveBrowserProfileWithHotReload({
|
|
870
|
-
current,
|
|
871
|
-
refreshConfigFromDisk,
|
|
872
|
-
name
|
|
873
|
-
});
|
|
874
|
-
if (!profile) throw new BrowserProfileNotFoundError(`Profile "${name}" not found. Available profiles: ${Object.keys(current.resolved.profiles).join(", ") || "(none)"}`);
|
|
875
|
-
return createProfileContext(opts, profile);
|
|
876
|
-
};
|
|
877
|
-
const listProfiles = async () => {
|
|
878
|
-
const current = state();
|
|
879
|
-
refreshResolvedBrowserConfigFromDisk({
|
|
880
|
-
current,
|
|
881
|
-
refreshConfigFromDisk,
|
|
882
|
-
mode: "cached"
|
|
883
|
-
});
|
|
884
|
-
const result = [];
|
|
885
|
-
for (const name of listKnownProfileNames(current)) {
|
|
886
|
-
const profileState = current.profiles.get(name);
|
|
887
|
-
const profile = resolveProfile(current.resolved, name) ?? profileState?.profile;
|
|
888
|
-
if (!profile) continue;
|
|
889
|
-
const capabilities = getBrowserProfileCapabilities(profile);
|
|
890
|
-
let tabCount = 0;
|
|
891
|
-
let running = false;
|
|
892
|
-
const profileCtx = createProfileContext(opts, profile);
|
|
893
|
-
if (capabilities.usesChromeMcp) try {
|
|
894
|
-
running = await profileCtx.isTransportAvailable(300);
|
|
895
|
-
if (running) tabCount = (await listChromeMcpTabs(profile.name, profile, { ephemeral: true }).catch(() => [])).filter((t) => t.type === "page").length;
|
|
896
|
-
} catch {}
|
|
897
|
-
else if (profileState?.running) {
|
|
898
|
-
running = true;
|
|
899
|
-
try {
|
|
900
|
-
tabCount = (await profileCtx.listTabs()).filter((t) => t.type === "page").length;
|
|
901
|
-
} catch {}
|
|
902
|
-
} else try {
|
|
903
|
-
const probeTimeoutMs = usesFastLoopbackCdpProbeClass({
|
|
904
|
-
profileIsLoopback: profile.cdpIsLoopback,
|
|
905
|
-
attachOnly: profile.attachOnly
|
|
906
|
-
}) ? 200 : current.resolved.remoteCdpTimeoutMs;
|
|
907
|
-
if (await isChromeReachable(profile.cdpUrl, probeTimeoutMs, resolveCdpReachabilityPolicy(profile, current.resolved.ssrfPolicy))) {
|
|
908
|
-
running = true;
|
|
909
|
-
tabCount = (await profileCtx.listTabs().catch(() => [])).filter((t) => t.type === "page").length;
|
|
910
|
-
}
|
|
911
|
-
} catch {}
|
|
912
|
-
result.push({
|
|
913
|
-
name,
|
|
914
|
-
transport: capabilities.usesChromeMcp ? "chrome-mcp" : "cdp",
|
|
915
|
-
cdpPort: capabilities.usesChromeMcp ? null : profile.cdpPort,
|
|
916
|
-
cdpUrl: capabilities.usesChromeMcp ? null : redactCdpUrl(profile.cdpUrl) ?? null,
|
|
917
|
-
color: profile.color,
|
|
918
|
-
driver: profile.driver,
|
|
919
|
-
running,
|
|
920
|
-
tabCount,
|
|
921
|
-
isDefault: name === current.resolved.defaultProfile,
|
|
922
|
-
isRemote: !profile.cdpIsLoopback,
|
|
923
|
-
missingFromConfig: !(name in current.resolved.profiles) || void 0,
|
|
924
|
-
reconcileReason: profileState?.reconcile?.reason ?? null
|
|
925
|
-
});
|
|
926
|
-
}
|
|
927
|
-
return result;
|
|
928
|
-
};
|
|
929
|
-
const getDefaultContext = () => forProfile();
|
|
930
|
-
const mapTabError = (err) => {
|
|
931
|
-
const browserMapped = toBrowserErrorResponse(err);
|
|
932
|
-
if (browserMapped) return browserMapped;
|
|
933
|
-
return null;
|
|
934
|
-
};
|
|
935
|
-
return {
|
|
936
|
-
state,
|
|
937
|
-
forProfile,
|
|
938
|
-
listProfiles,
|
|
939
|
-
ensureBrowserAvailable: () => getDefaultContext().ensureBrowserAvailable(),
|
|
940
|
-
ensureTabAvailable: (targetId) => getDefaultContext().ensureTabAvailable(targetId),
|
|
941
|
-
isHttpReachable: (timeoutMs) => getDefaultContext().isHttpReachable(timeoutMs),
|
|
942
|
-
isTransportAvailable: (timeoutMs) => getDefaultContext().isTransportAvailable(timeoutMs),
|
|
943
|
-
isReachable: (timeoutMs, options) => getDefaultContext().isReachable(timeoutMs, options),
|
|
944
|
-
listTabs: () => getDefaultContext().listTabs(),
|
|
945
|
-
openTab: (url, opts) => getDefaultContext().openTab(url, opts),
|
|
946
|
-
labelTab: (targetId, label) => getDefaultContext().labelTab(targetId, label),
|
|
947
|
-
focusTab: (targetId) => getDefaultContext().focusTab(targetId),
|
|
948
|
-
closeTab: (targetId) => getDefaultContext().closeTab(targetId),
|
|
949
|
-
stopRunningBrowser: () => getDefaultContext().stopRunningBrowser(),
|
|
950
|
-
resetProfile: () => getDefaultContext().resetProfile(),
|
|
951
|
-
mapTabError
|
|
952
|
-
};
|
|
953
|
-
}
|
|
954
|
-
//#endregion
|
|
955
|
-
export { listKnownProfileNames as n, loadBrowserConfigForRuntimeRefresh as r, createBrowserRouteContext as t };
|