@pixelzx/genesis 2026.5.3-5 → 2026.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -0
- package/dist/.buildstamp +1 -1
- package/dist/abort-t5XiT6Yl.js +201 -0
- package/dist/abort.runtime-C_xk0DkL.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/accounts-B7yDKwxi.js +104 -0
- package/dist/accounts-CS7VL356.js +107 -0
- package/dist/accounts-XvHcAtMf.js +2 -0
- package/dist/acp-cli-B5H0nvID.js +2193 -0
- package/dist/acp-spawn-BRTMqPlq.js +2 -0
- package/dist/acp-spawn-Dsw3dzWY.js +1093 -0
- package/dist/acp-stateful-target-driver-BYhkJnyh.js +89 -0
- package/dist/action-agents-Ca9kTFvv.js +67 -0
- package/dist/action-focus-D4pT0hra.js +132 -0
- package/dist/action-help-DMzMxFEQ.js +7 -0
- package/dist/action-info-Dzn_fn6G.js +101 -0
- package/dist/action-kill-2AQuhnLy.js +33 -0
- package/dist/action-list-DI1M2pKU.js +21 -0
- package/dist/action-log-BVKGgOki.js +30 -0
- package/dist/action-send-CZ2wciMW.js +39 -0
- package/dist/action-spawn-BdclQLrK.js +47 -0
- package/dist/action-unfocus-DfQuRf8d.js +29 -0
- package/dist/actions.runtime-B2-oz_B6.js +5 -0
- package/dist/actions.runtime-BoUxrcw3.js +18 -0
- package/dist/actions.runtime.js +1 -1
- package/dist/agent-CnQ3yCIw.js +2 -0
- package/dist/agent-command-C4H_9c2N.js +874 -0
- package/dist/agent-harness-runtime-D2oXzgyL.js +144 -0
- package/dist/agent-runner-utils-CWgPcOYn.js +239 -0
- package/dist/agent-runner.runtime-DvK-HQhq.js +3455 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-BDslXtCf.js +18 -0
- package/dist/agents-4T7YaeKy.js +953 -0
- package/dist/agents-C_Gty_RK.js +5 -0
- package/dist/aliases-BkVpehd-.js +96 -0
- package/dist/aliases-DWkJWJ5A.js +2 -0
- package/dist/api-CgW6fcU2.js +3 -0
- package/dist/api-DYPaGKUj.js +5 -0
- package/dist/api-DdoV90Cn.js +139 -0
- package/dist/approval-gateway-resolver-Ba_2kb3B.js +29 -0
- package/dist/approval-gateway-runtime-7VMivk0A.js +2 -0
- package/dist/approval-handler-runtime-DUDpOwG7.js +439 -0
- package/dist/approval-native-runtime-KkmX9gwQ.js +729 -0
- package/dist/attempt-execution.runtime-CQkeVpDx.js +509 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt.prompt-helpers-MoT6VaD0.js +221 -0
- package/dist/attempt.tool-run-context-B53GhX-d.js +933 -0
- package/dist/audit-CvHcVVb-.js +939 -0
- package/dist/audit.runtime-C7n442Rc.js +7 -0
- package/dist/audit.runtime.js +1 -1
- package/dist/auth-CAnSldtM.js +2 -0
- package/dist/auth-Czf_o5iE.js +383 -0
- package/dist/auth-order-Cu9Vj7lA.js +96 -0
- package/dist/auth-order-q1IFw7L3.js +2 -0
- package/dist/bash-tools-BS4TrA4X.js +2824 -0
- package/dist/bash-tools-DbHYuk8O.js +3 -0
- package/dist/binding-routing-CnNQE65Q.js +85 -0
- package/dist/binding-targets-DW0ScIRI.js +121 -0
- package/dist/bridge-server-BGS08n2f.js +113 -0
- package/dist/browser-control-auth-DMlQOsyN.js +2 -0
- package/dist/browser-node-runtime-CF32scUO.js +12 -0
- package/dist/browser-profiles-CmER65eh.js +2 -0
- package/dist/browser-runtime-D73M9fg3.js +387 -0
- package/dist/browser-setup-tools-Cr0UI1rf.js +13 -0
- package/dist/build-BL7WirDF.js +550 -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/call-Ckws4Nlw.js +3 -0
- package/dist/call-DkGNVvLy.js +331 -0
- package/dist/call.runtime-DfLBtAIr.js +2 -0
- package/dist/call.runtime.js +1 -1
- package/dist/capability-cli-tSqSJf2o.js +1401 -0
- package/dist/catchup-Dp2L1RcY.js +300 -0
- package/dist/channel-BIFp1GJd.js +1320 -0
- package/dist/channel-BZMzoXhw.js +840 -0
- package/dist/channel-BtPZ0i4g.js +297 -0
- package/dist/channel-DDd7xwLG.js +226 -0
- package/dist/channel-DLezQPqR.js +350 -0
- package/dist/channel-DcYHXn_7.js +1100 -0
- package/dist/channel-DzKtLfJj.js +1802 -0
- package/dist/channel-LlY18tI5.js +595 -0
- package/dist/channel-NjZviHcJ.js +1174 -0
- package/dist/channel-core-Cg1mFpva.js +5 -0
- package/dist/channel-inbound-CZpi-vp5.js +31 -0
- package/dist/channel-pDXIWFS4.js +453 -0
- package/dist/channel-plugin-runtime-DHl81Ror.js +771 -0
- package/dist/channel-runtime-CtYrrwow.js +425 -0
- package/dist/channel-wMkGGyIY.js +491 -0
- package/dist/channel.runtime-B1n0hvUI.js +430 -0
- package/dist/channel.runtime-B9iR26l_.js +576 -0
- package/dist/channel.runtime-C8eBQk67.js +4 -0
- package/dist/channel.runtime-Db8g8JCg.js +89 -0
- package/dist/channel.runtime-DfRfisV2.js +34702 -0
- package/dist/channel.runtime-gPdBMu3V.js +109 -0
- package/dist/channel.runtime-rG9pJ5NO.js +2364 -0
- package/dist/channel.runtime.js +1 -1
- package/dist/channel.setup-CWblUOhD.js +10 -0
- package/dist/channels-B4dYRKsI.js +733 -0
- package/dist/channels-cli-GMAOUYU3.js +268 -0
- package/dist/chat-D2XaZNiP.js +2758 -0
- package/dist/clawbot-cli-CSmdcIMT.js +9 -0
- package/dist/cli/daemon-cli.js +3 -3
- package/dist/cli-2u5IZTMS.js +219 -0
- package/dist/cli-Bk8uXnyc.js +72 -0
- package/dist/cli-DBfw9jCz.js +2 -0
- package/dist/cli-runner-BEqvX1ky.js +286 -0
- package/dist/cli-runner.runtime-BIUcUGDa.js +4 -0
- package/dist/cli-runner.runtime-D2u3Yw0W.js +3 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +2 -2
- package/dist/cli-waH8839u.js +2 -0
- package/dist/cli.runtime-mKvJpLwI.js +1261 -0
- package/dist/cli.runtime.js +1 -1
- package/dist/client-CKizOsGp.js +138 -0
- package/dist/client-CrPccv7a.js +713 -0
- package/dist/command-auth-DPkjKHdv.js +76 -0
- package/dist/command-config-resolution-BTjtnAp2.js +2 -0
- package/dist/command-config-resolution-Be3KZA_l.js +23 -0
- package/dist/command-config-resolution.runtime-DXgL8cm7.js +2 -0
- package/dist/command-config-resolution.runtime.js +1 -1
- package/dist/command-registry-BL1Z4Cen.js +4 -0
- package/dist/command-registry-BMePAw9w.js +9 -0
- package/dist/command-registry-core-CAay55-n.js +104 -0
- package/dist/command-secret-gateway-jj1Qmk9L.js +528 -0
- package/dist/command-status.runtime-BVcCm9_0.js +87 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-acp-COdUW69f.js +77 -0
- package/dist/commands-compact.runtime-C0Fedews.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-handlers.runtime-BXVM3PWG.js +4597 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-status-DaApOLoQ.js +16 -0
- package/dist/commands-status.runtime-CxSjrKne.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-BEfW44br.js +2 -0
- package/dist/commands-subagents-control.runtime-DB3AROHI.js +3 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-CCrUy7xq.js +158 -0
- package/dist/commands-system-prompt-CN56TtaC.js +2 -0
- package/dist/commands.runtime-Bee6dM3V.js +166 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/compact-7YtEe1kG.js +1118 -0
- package/dist/compact.runtime-4gW_cs7D.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-COv-r8_h.js +313 -0
- package/dist/config-DSsLlg8J.js +251 -0
- package/dist/config-cli-C9oGe9gl.js +1078 -0
- package/dist/configure-Bfy9tVmS.js +2 -0
- package/dist/configure-DpIFRaAD.js +1245 -0
- package/dist/connect-options-CPixzqP_.js +699 -0
- package/dist/control-auth-L7U2ivRJ.js +125 -0
- package/dist/control-service-CbUz8qU5.js +156 -0
- package/dist/conversation-id-BroDIGeT.js +38 -0
- package/dist/conversation-id-CuVi0tWe.js +235 -0
- package/dist/conversation-runtime-weaahZQN.js +31 -0
- package/dist/core-PXv1nsc-.js +275 -0
- package/dist/cron-cli-DZNSQBuA.js +713 -0
- package/dist/daemon-cli-C_9CNoZA.js +12 -0
- package/dist/delegate-B8wh-jjf.js +64 -0
- package/dist/detached-task-runtime-BTq-jIGw.js +73 -0
- package/dist/devices-cli-C_amY-AS.js +496 -0
- package/dist/diagnostics-Bw-fd0ug.js +154 -0
- package/dist/direct-dm-Dvqjch3O.js +64 -0
- package/dist/dispatch-DHPQS49Q.js +1131 -0
- package/dist/dispatch-acp-manager.runtime-y-oykPUz.js +3 -0
- package/dist/dispatch-acp-manager.runtime.js +1 -1
- package/dist/dispatch-acp-taSuJD5W.js +981 -0
- package/dist/dispatch-acp.runtime-DgyaFFNX.js +19 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/doctor-device-pairing-rxwogzYF.js +307 -0
- package/dist/doctor-gateway-daemon-flow-Dm4wxnTt.js +250 -0
- package/dist/doctor-gateway-health-wJVW5xUW.js +60 -0
- package/dist/doctor-health-DaodspKU.js +59 -0
- package/dist/doctor-health-contributions-CBVyN6ju.js +486 -0
- package/dist/doctor-prompter-vO6LPeXZ.js +56 -0
- package/dist/doctor-workspace-status-BnXA04-6.js +75 -0
- package/dist/dreaming-1RLie1iF.js +1574 -0
- package/dist/dreaming-narrative-BRtTdpbt.js +595 -0
- package/dist/embedded-gateway-stub.runtime-GMix51Tf.js +9 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/entry.js +2 -2
- package/dist/exec-approvals-cli-R6jgupQH.js +498 -0
- package/dist/extensionAPI.js +1 -1
- package/dist/extensions/active-memory/index.js +1 -1
- package/dist/extensions/bluebubbles/api.js +3 -3
- package/dist/extensions/bluebubbles/channel-plugin-api.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 +2 -2
- package/dist/extensions/browser/browser-profiles.js +2 -2
- package/dist/extensions/browser/browser-runtime-api.js +10 -10
- package/dist/extensions/browser/index.js +1 -1
- package/dist/extensions/browser/plugin-registration.js +1 -1
- package/dist/extensions/browser/register.runtime.js +3 -3
- package/dist/extensions/browser/runtime-api.js +11 -11
- package/dist/extensions/browser/test-support.js +1 -1
- package/dist/extensions/device-pair/api.js +1 -1
- package/dist/extensions/device-pair/index.js +3 -3
- package/dist/extensions/device-pair/notify.js +1 -1
- package/dist/extensions/device-pair/pair-command-approve.js +1 -1
- package/dist/extensions/google-meet/index.js +2 -2
- package/dist/extensions/imessage/api.js +3 -3
- package/dist/extensions/imessage/channel-plugin-api.js +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/line/api.js +2 -2
- package/dist/extensions/line/channel-plugin-api.js +1 -1
- package/dist/extensions/line/contract-api.js +1 -1
- package/dist/extensions/line/runtime-api.js +4 -4
- package/dist/extensions/line/setup-api.js +1 -1
- package/dist/extensions/llm-task/index.js +2 -2
- package/dist/extensions/lobster/index.js +3 -3
- package/dist/extensions/lobster/runtime-api.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 +4 -4
- package/dist/extensions/mattermost/slash-route-api.js +1 -1
- package/dist/extensions/memory-core/api.js +1 -1
- package/dist/extensions/memory-core/cli-metadata.js +2 -2
- package/dist/extensions/memory-core/index.js +3 -3
- package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
- package/dist/extensions/msteams/api.js +1 -1
- package/dist/extensions/msteams/channel-plugin-api.js +1 -1
- package/dist/extensions/msteams/runtime-api.js +3 -3
- package/dist/extensions/msteams/test-api.js +1 -1
- package/dist/extensions/nextcloud-talk/api.js +1 -1
- package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
- package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
- package/dist/extensions/openshell/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 +1 -1
- package/dist/extensions/synology-chat/api.js +1 -1
- package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/api.js +2 -2
- package/dist/extensions/tlon/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/runtime-api.js +1 -1
- package/dist/extensions/tlon/test-api.js +1 -1
- package/dist/extensions/twitch/api.js +1 -1
- package/dist/extensions/twitch/channel-plugin-api.js +1 -1
- package/dist/extensions/twitch/setup-plugin-api.js +1 -1
- package/dist/extensions/zalo/api.js +3 -3
- package/dist/extensions/zalo/channel-plugin-api.js +1 -1
- package/dist/extensions/zalo/runtime-api.js +2 -2
- package/dist/extensions/zalo/setup-api.js +2 -2
- package/dist/extensions/zalouser/api.js +3 -3
- package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
- package/dist/extensions/zalouser/runtime-api.js +6 -6
- package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
- package/dist/extensions/zalouser/test-api.js +1 -1
- package/dist/fallbacks-Cckv3nng.js +2 -0
- package/dist/fallbacks-Y_nNY8_a.js +31 -0
- package/dist/fallbacks-shared-DZiG1Gr_.js +111 -0
- package/dist/gateway-CDfn0J87.js +115 -0
- package/dist/gateway-cli-D197U6l0.js +1325 -0
- package/dist/gateway-rpc-Bomz8HKq.js +14 -0
- package/dist/gateway-rpc.runtime-597tksmo.js +23 -0
- package/dist/gateway-rpc.runtime.js +1 -1
- package/dist/gateway-runtime-Bm2_MhFn.js +15 -0
- package/dist/gateway-status-Cr4UJKUx.js +584 -0
- package/dist/genesis-tools-DCRaVVjY.js +8999 -0
- package/dist/genesis-tools.runtime-idgd5fjy.js +2 -0
- package/dist/genesis-tools.runtime.js +1 -1
- package/dist/get-reply-BF_7bR5f.js +3879 -0
- package/dist/get-reply-from-config.runtime-DEq5XM_s.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/graph-users-Bhlw-_4i.js +1337 -0
- package/dist/health-9ifMvGZN.js +3 -0
- package/dist/health-CzOJa6SX.js +469 -0
- package/dist/heartbeat-runner-B2Tkbj5e.js +5 -0
- package/dist/heartbeat-runner-B63G8dbO.js +1292 -0
- package/dist/heartbeat-runner.runtime-QJ_2AMjN.js +4 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/hooks-cli-ZWI1iJnh.js +433 -0
- package/dist/image-fallbacks-BpTfBvbi.js +2 -0
- package/dist/image-fallbacks-DpVwnB41.js +31 -0
- package/dist/inbound-reply-dispatch-mKybIcNA.js +73 -0
- package/dist/index.js +2 -2
- package/dist/infra-runtime-CvwvzUfM.js +39 -0
- package/dist/init-CWeM0DfJ.js +59 -0
- package/dist/library-ClQalZ3x.js +45 -0
- package/dist/lifecycle-CgV7Cgt-.js +571 -0
- package/dist/lifecycle-DVWaxj-A.js +229 -0
- package/dist/lifecycle.runtime-DErLwVJ_.js +2 -0
- package/dist/lifecycle.runtime.js +1 -1
- package/dist/list-5RIS3LMG.js +2 -0
- package/dist/list-BNesYDN2.js +2 -0
- package/dist/list-Dk1hCKis.js +1201 -0
- package/dist/list-eUjt_6__.js +131 -0
- package/dist/list.probe-C51ceJSY.js +419 -0
- package/dist/llm-slug-generator-D64IMUoy.js +79 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/load-config-Ccss2uTi.js +35 -0
- package/dist/local-dispatch.runtime-u7Ir1N07.js +8 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/logs-cli-BYHTboPa.js +265 -0
- package/dist/logs-cli.runtime-CQwNptr-.js +2 -0
- package/dist/logs-cli.runtime.js +1 -1
- package/dist/main-session-restart-recovery-CA9bvC1W.js +206 -0
- package/dist/managed-image-attachments-B_gpkI1u.js +635 -0
- package/dist/managed-image-attachments-C0Y6nAP2.js +2 -0
- package/dist/manager-DZGFArgz.js +2 -0
- package/dist/manager-Df8TC4rX.js +2057 -0
- package/dist/markdown-to-line-xXLdnzcE.js +790 -0
- package/dist/mcp/plugin-tools-serve.js +1 -1
- package/dist/mcp-cli-B50W9Pkc.js +725 -0
- package/dist/mcp-http-BiUGVpJ4.js +529 -0
- package/dist/memory-core-host-runtime-cli-UgLo6ezC.js +9 -0
- package/dist/message-C95gttLd.js +232 -0
- package/dist/message-action-runner-0KAp6ccG.js +1407 -0
- package/dist/message-action-runner-BSUDvECO.js +2 -0
- package/dist/message-actions-Be4Ob151.js +143 -0
- package/dist/message.gateway.runtime-DMMRMIln.js +2 -0
- package/dist/message.gateway.runtime.js +1 -1
- package/dist/models-auth-status-DhYxBz7G.js +201 -0
- package/dist/models-cli-C2prinXb.js +219 -0
- package/dist/monitor-BEI21vNQ.js +1661 -0
- package/dist/monitor-BUgTAJvZ.js +1237 -0
- package/dist/monitor-BdJRIhi1.js +2 -0
- package/dist/monitor-C7wuttQJ.js +1459 -0
- package/dist/monitor-DMumiWnt.js +788 -0
- package/dist/monitor-IQo2ExmV.js +671 -0
- package/dist/monitor-auth-DW0lvfm3.js +207 -0
- package/dist/monitor-processing-DTrsRdyz.js +1974 -0
- package/dist/monitor.runtime-DwqyCQcb.js +2 -0
- package/dist/monitor.runtime.js +1 -1
- package/dist/monitor.webhook-D11nrUh9.js +180 -0
- package/dist/msteams-DO-PW98M.js +35 -0
- package/dist/native-hook-relay-CNZrcPIw.js +519 -0
- package/dist/nextcloud-talk-BeYFnATY.js +17 -0
- package/dist/node-cli-BFrdTPdH.js +2506 -0
- package/dist/nodes-cli-B3Wj_MvP.js +1046 -0
- package/dist/nodes-utils-AsgrCa7K.js +84 -0
- package/dist/nodes.helpers-CMXxavTs.js +34 -0
- package/dist/notify-CNS0kRWM.js +315 -0
- package/dist/onboard-D4ehf66t.js +632 -0
- package/dist/onboard-helpers-DWxdMyCs.js +6 -0
- package/dist/onboard-helpers-o78s0lR1.js +204 -0
- package/dist/onboard-remote-Cc1XlRzr.js +193 -0
- package/dist/onboard-remote-D8THwo3P.js +2 -0
- package/dist/onboard-skills-B2VoCq7v.js +134 -0
- package/dist/onboard-skills-DtOgSJZo.js +2 -0
- package/dist/openai-http-DKQZWsqY.js +500 -0
- package/dist/openresponses-http-C4kol41X.js +1128 -0
- package/dist/operator-approvals-client-BoN_VmkB.js +68 -0
- package/dist/outbound.runtime-D-L8FN8E.js +2 -0
- package/dist/outbound.runtime.js +1 -1
- package/dist/pair-command-approve-DMeQ6uD4.js +44 -0
- package/dist/persistent-bindings.lifecycle-O-RnoTW4.js +2 -0
- package/dist/persistent-bindings.lifecycle-bptWQEFT.js +85 -0
- package/dist/pi-embedded-BM79sXqb.js +2905 -0
- package/dist/pi-embedded-BUDWcDt8.js +4 -0
- package/dist/pi-embedded.runtime-D53bCPOr.js +4 -0
- package/dist/pi-embedded.runtime.js +1 -1
- package/dist/pi-tool-definition-adapter-DdYQtumi.js +217 -0
- package/dist/pi-tools-ihbjTP0K.js +1057 -0
- package/dist/pi-tools.before-tool-call-DrEqr96j.js +433 -0
- package/dist/pi-tools.before-tool-call-VB9YEPOv.js +2 -0
- package/dist/plugin-DwNULpmw.js +12195 -0
- package/dist/plugin-enabled-DbO9GyRJ.js +140 -0
- package/dist/plugin-registration-Du6hgUkp.js +23 -0
- package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
- package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
- package/dist/plugin-sdk/acp-runtime.js +2 -2
- package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
- package/dist/plugin-sdk/agent-harness.js +6 -6
- package/dist/plugin-sdk/agent-runtime.js +2 -2
- package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
- package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
- package/dist/plugin-sdk/approval-runtime.js +1 -1
- package/dist/plugin-sdk/browser-node-runtime.js +4 -4
- package/dist/plugin-sdk/browser-setup-tools.js +3 -3
- package/dist/plugin-sdk/browser-support.js +7 -7
- package/dist/plugin-sdk/channel-core.js +2 -2
- package/dist/plugin-sdk/channel-inbound.js +2 -2
- 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 +1 -1
- 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-runtime.js +3 -3
- package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/infra-runtime.js +2 -2
- package/dist/plugin-sdk/irc.js +2 -2
- package/dist/plugin-sdk/matrix.js +1 -1
- package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
- package/dist/plugin-sdk/memory-core.js +2 -2
- package/dist/plugin-sdk/msteams.js +2 -2
- package/dist/plugin-sdk/nextcloud-talk.js +2 -2
- package/dist/plugin-sdk/nostr.js +1 -1
- package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
- package/dist/plugin-sdk/reply-runtime.js +4 -4
- package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
- package/dist/plugin-sdk/runtime.js +2 -2
- package/dist/plugin-sdk/session-visibility.js +1 -1
- package/dist/plugin-sdk/testing.js +4 -4
- package/dist/plugin-sdk/tlon.js +1 -1
- package/dist/plugin-sdk/zalo.js +1 -1
- package/dist/plugin-sdk/zalouser.js +1 -1
- package/dist/plugin-service-DcSnRF5x.js +2890 -0
- package/dist/plugins/runtime/index.js +1 -1
- package/dist/policy-uc224usV.js +328 -0
- package/dist/postinstall-inventory.json +407 -407
- package/dist/prepare.runtime-BPA6jMiM.js +815 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/probe-5ToseFjd.js +1443 -0
- package/dist/probe-BdCXAH_u.js +2 -0
- package/dist/probe-ByVoZEdq.js +45 -0
- package/dist/probe-D-D_1oc4.js +241 -0
- package/dist/probe-D6s_1Z5k.js +2 -0
- package/dist/probe-DIMAmSsO.js +74 -0
- package/dist/probe-DYuL-s4A.js +2205 -0
- package/dist/program-DDTWTh6g.js +111 -0
- package/dist/prompt-select-styled-kf1dPqNa.js +20 -0
- package/dist/protocol-Batc2DmY.js +2234 -0
- package/dist/provider-dispatcher-DdUqCa6H.js +2 -0
- package/dist/provider-dispatcher-uioW38XW.js +22 -0
- package/dist/qr-cli-B1WUe8Eb.js +2 -0
- package/dist/qr-cli-DmPti3xe.js +349 -0
- package/dist/reaction-runtime-api-5G3e9J0C.js +116 -0
- package/dist/reactions-x7VH-B95.js +998 -0
- package/dist/register-service-commands-DcW5qPTu.js +71 -0
- package/dist/register.agent-Dtj4HC7R.js +248 -0
- package/dist/register.configure-CJHb84Ce.js +15 -0
- package/dist/register.maintenance-BUkPfMcX.js +438 -0
- package/dist/register.message-DGFpyYBl.js +329 -0
- package/dist/register.onboard-D3v3xIfF.js +81 -0
- package/dist/register.runtime-DI4QxYdj.js +81 -0
- package/dist/register.runtime.js +1 -1
- package/dist/register.setup-CXTyuIFM.js +150 -0
- package/dist/register.status-health-sessions-CYUnRi97.js +1215 -0
- package/dist/register.subclis-DKMVrwRc.js +3 -0
- package/dist/register.subclis-NWRi2XKp.js +29 -0
- package/dist/register.subclis-core-De6qmQkr.js +243 -0
- package/dist/reply-dispatch-runtime-B8_j6pJi.js +13 -0
- package/dist/reply-runtime-DGHQDC9d.js +11 -0
- package/dist/reply.runtime-BCfqw2Co.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/restart-health-6cjrRBpF.js +202 -0
- package/dist/restart-health-b6Qw43Tj.js +2 -0
- package/dist/root-help-BTIH_eUe.js +44 -0
- package/dist/routes-C3J2GfHR.js +3341 -0
- package/dist/routes-SMmfW6k8.js +2 -0
- package/dist/rpc-DQbAcIKu.js +61 -0
- package/dist/rpc.runtime-Q3qyofLf.js +21 -0
- package/dist/rpc.runtime.js +1 -1
- package/dist/run-delivery.runtime-BsLouK3f.js +530 -0
- package/dist/run-delivery.runtime.js +1 -1
- package/dist/run-embedded.runtime-CXd0oZQP.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-D-MKbq8r.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime-Cz0I8mDt.js +277 -0
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-main-CkXBTQut.js +516 -0
- package/dist/run-subagent-registry.runtime-Cyb8amrH.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/run-wait-KlS0pdIK.js +135 -0
- package/dist/runtime-3niXLiFY.js +9 -0
- package/dist/runtime-api-B79e2jL2.js +4 -0
- package/dist/runtime-api-CM2c2bSC.js +9 -0
- package/dist/runtime-api-CnOFFN5q.js +14 -0
- package/dist/runtime-api-TnwM-EZH.js +9 -0
- package/dist/runtime-embedded-pi.runtime-9csGjukF.js +2 -0
- package/dist/runtime-embedded-pi.runtime.js +1 -1
- package/dist/runtime-internal-CQX4Zehn.js +2 -0
- package/dist/runtime-options-C0qP2VlT.js +275 -0
- package/dist/runtime-schema-DanWbDoL.js +27780 -0
- package/dist/runtime-vycfMfew.js +973 -0
- package/dist/scan-Bs5zROOQ.js +2 -0
- package/dist/scan-CP2zJb_w.js +523 -0
- package/dist/secrets-cli-YFTlIMmq.js +2101 -0
- package/dist/security-cli-B2WBRU9C.js +486 -0
- package/dist/selection-DSZGsU6m.js +2 -0
- package/dist/selection-hUGDnCgX.js +7736 -0
- package/dist/send-B3Ygb3r3.js +156 -0
- package/dist/send-DMwqnu6K.js +102 -0
- package/dist/send.runtime-D86atcfW.js +2 -0
- package/dist/send.runtime.js +1 -1
- package/dist/server-4gQCBM3M.js +77 -0
- package/dist/server-CK9eCPCG.js +13 -0
- package/dist/server-context-ih3GaGaI.js +847 -0
- package/dist/server-context-kZ_QADic.js +2 -0
- package/dist/server-node-events-CMlHOIKa.js +481 -0
- package/dist/server-plugin-bootstrap-B0XitldT.js +11333 -0
- package/dist/server-plugin-bootstrap-CHlVF8XB.js +2 -0
- package/dist/server-restart-sentinel-TpXCoiYX.js +697 -0
- package/dist/server.impl-B6at3Orl.js +12734 -0
- package/dist/session-kill-http-DvYp5h-j.js +110 -0
- package/dist/session-reset-service-C9rIVqF7.js +471 -0
- package/dist/session-route-FaMcEc7I.js +93 -0
- package/dist/session-status.runtime-BfPn8qA8.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-C1fGNaiM.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-BDK2AlxL.js +491 -0
- package/dist/session-visibility-BkrL2kFF.js +147 -0
- package/dist/sessions-helpers-YOu_5tl0.js +304 -0
- package/dist/sessions-history-http-DxNaoDfb.js +383 -0
- package/dist/sessions-patch-BPtlF0Lu.js +309 -0
- package/dist/sessions-resolve-B2rpvSka.js +174 -0
- package/dist/sessions.runtime-DEk_x65_.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/setup-DZJZF2R6.js +495 -0
- package/dist/setup-api-BkYWhB-B.js +29 -0
- package/dist/setup-core-BXBabSEx.js +171 -0
- package/dist/setup-core-eahC1DXh.js +176 -0
- package/dist/setup-surface-BEf8reey.js +286 -0
- package/dist/setup-surface-DAOKJ-ai.js +219 -0
- package/dist/setup-surface-b6gu0S8l.js +403 -0
- package/dist/setup.finalize-DXUCLT5O.js +539 -0
- package/dist/setup.gateway-config-BH4xbjcX.js +250 -0
- package/dist/shared-BhHdyXun.js +198 -0
- package/dist/shared-CKv38qsN.js +121 -0
- package/dist/shared-DUw9Q4Lf.js +76 -0
- package/dist/slash-state-BQgmhum1.js +1911 -0
- package/dist/src-C1B3uJMu.js +3974 -0
- package/dist/startup-context-DTpThe3H.js +312 -0
- package/dist/status-63GZxfe4.js +2 -0
- package/dist/status-C6qTe-QQ.js +397 -0
- package/dist/status-CSIGAUly.js +190 -0
- package/dist/status-DOW91Kcx.js +2 -0
- package/dist/status-all-7hqTcvxr.js +498 -0
- package/dist/status-json-CUzzv8An.js +14 -0
- package/dist/status-json-command-DwWlqvoV.js +84 -0
- package/dist/status-p4yx6E3C.js +209 -0
- package/dist/status-runtime-shared-yrzbsOR8.js +257 -0
- package/dist/status-subagents.runtime-CuRGoNNn.js +18 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-BrcRsCFE.js +237 -0
- package/dist/status-zV1BflCE.js +3 -0
- package/dist/status.gateway-connection.runtime-BKd4Zivg.js +2 -0
- package/dist/status.gateway-connection.runtime.js +1 -1
- package/dist/status.gather-B7WlHpIR.js +292 -0
- package/dist/status.gather-Ccewg4ce.js +2 -0
- package/dist/status.runtime-BFru2C4v.js +2 -0
- package/dist/status.runtime.js +1 -1
- package/dist/status.scan-mEKnAmP3.js +65 -0
- package/dist/status.scan-overview-B0qQVJd0.js +379 -0
- package/dist/status.scan.fast-json-CsU-fWhj.js +132 -0
- package/dist/status.scan.fast-json-tEc36TAC.js +2 -0
- package/dist/status.summary-Bvgry977.js +214 -0
- package/dist/status.summary-DRolowE_.js +2 -0
- package/dist/subagent-announce-Bhe55Ktf.js +351 -0
- package/dist/subagent-announce-delivery-NDBIRwuZ.js +726 -0
- package/dist/subagent-announce-output-DsmGO7Oi.js +364 -0
- package/dist/subagent-control-Bn8n-535.js +506 -0
- package/dist/subagent-followup.runtime-C7s-lOGN.js +68 -0
- package/dist/subagent-followup.runtime.js +1 -1
- package/dist/subagent-orphan-recovery-CJEhSvFZ.js +305 -0
- package/dist/subagent-registry-BgQA8eP1.js +1753 -0
- package/dist/subagent-registry-DAm-N9-O.js +3 -0
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-spawn-EXtecXVT.js +1005 -0
- package/dist/system-cli-CFS_PN8R.js +59 -0
- package/dist/targets-BXWH2MfM.js +67 -0
- package/dist/task-executor-DfugjJEq.js +360 -0
- package/dist/task-owner-access-CSwIy-v-.js +74 -0
- package/dist/task-registry-B-kQGKt_.js +2366 -0
- package/dist/task-registry-delivery-runtime-DD1_7xUF.js +3 -0
- package/dist/task-registry-delivery-runtime-DIsasFa1.js +2 -0
- package/dist/task-registry.maintenance-CxAx195T.js +2 -0
- package/dist/task-registry.maintenance-DIFuNnzy.js +416 -0
- package/dist/telegram/token.js +1 -1
- package/dist/testing-C7oUBiZL.js +575 -0
- package/dist/text-report-hYiQ_Kcv.js +587 -0
- package/dist/tool-resolution-CnnOHyxg.js +90 -0
- package/dist/tools-effective-inventory-DqYXIS6R.js +152 -0
- package/dist/tools-invoke-http-zop5qWa_.js +206 -0
- package/dist/trash-DZRlsk_R.js +24 -0
- package/dist/tui-cli-2cKXF0J8.js +4575 -0
- package/dist/update-cli-DP1KXasM.js +1759 -0
- package/dist/upgrade-DPFxH2YB.js +1226 -0
- package/dist/video-generation-task-status-BEgeadFu.js +163 -0
- package/dist/wait-for-idle-before-flush-CmSNfAco.js +5986 -0
- package/dist/wizard-models-BJGn0RnU.js +161 -0
- package/package.json +1 -1
- package/dist/abort-ca8hDmJr.js +0 -201
- package/dist/abort.runtime-BrChEuUS.js +0 -2
- package/dist/accounts-C1ECKXaw.js +0 -107
- package/dist/accounts-DH8HU_Fu.js +0 -104
- package/dist/accounts-DWQpG06j.js +0 -2
- package/dist/acp-cli-BLpWVnc7.js +0 -2193
- package/dist/acp-spawn-D1p6b1gk.js +0 -2
- package/dist/acp-spawn-qoyl9NiU.js +0 -1093
- package/dist/acp-stateful-target-driver-NL9txhIM.js +0 -89
- package/dist/action-agents-C729fJ_P.js +0 -67
- package/dist/action-focus-53k9XP4K.js +0 -132
- package/dist/action-help-bIJZBYLz.js +0 -7
- package/dist/action-info-BBzvYFX_.js +0 -101
- package/dist/action-kill-C4fa3E9I.js +0 -33
- package/dist/action-list-BEiIbwP1.js +0 -21
- package/dist/action-log-Cq7RLW2T.js +0 -30
- package/dist/action-send-DyiHgRwh.js +0 -39
- package/dist/action-spawn-CEZfDvXU.js +0 -47
- package/dist/action-unfocus-CpAw3JOi.js +0 -29
- package/dist/actions.runtime-BKEwPyo7.js +0 -18
- package/dist/actions.runtime-Bp0UusIf.js +0 -5
- package/dist/agent-C2hwJefQ.js +0 -2
- package/dist/agent-command-BAAeGRql.js +0 -874
- package/dist/agent-harness-runtime-Czrx53YL.js +0 -144
- package/dist/agent-runner-utils-DzShckNa.js +0 -239
- package/dist/agent-runner.runtime-d_EtNxBK.js +0 -3455
- package/dist/agent-runtime-DNgz7AOP.js +0 -18
- package/dist/agents-CZmpon7q.js +0 -5
- package/dist/agents-Cs9je_gQ.js +0 -953
- package/dist/aliases-CZemdpTj.js +0 -2
- package/dist/aliases-KefnmoaT.js +0 -96
- package/dist/api-CO05iXNH.js +0 -139
- package/dist/api-CyjlApHT.js +0 -3
- package/dist/api-DArm1ECd.js +0 -5
- package/dist/approval-gateway-resolver-URpDQMld.js +0 -29
- package/dist/approval-gateway-runtime-B087BMms.js +0 -2
- package/dist/approval-handler-runtime-BgRQnG4g.js +0 -439
- package/dist/approval-native-runtime-DAsraihr.js +0 -729
- package/dist/attempt-execution.runtime-D_FGkDQz.js +0 -509
- package/dist/attempt.prompt-helpers-CDzDUi1C.js +0 -221
- package/dist/attempt.tool-run-context-DitxaTPJ.js +0 -933
- package/dist/audit-Bq8vlxok.js +0 -939
- package/dist/audit.runtime-CU42yh1v.js +0 -7
- package/dist/auth-CQfwC-AH.js +0 -383
- package/dist/auth-DyWcaG4X.js +0 -2
- package/dist/auth-order-C3zGI0s9.js +0 -96
- package/dist/auth-order-XQ9ZGPd9.js +0 -2
- package/dist/bash-tools-BBRtIa6j.js +0 -2824
- package/dist/bash-tools-BI0d1TdC.js +0 -3
- package/dist/binding-routing-Cvm5c1IV.js +0 -85
- package/dist/binding-targets-DSs4NXbd.js +0 -121
- package/dist/bridge-server-CwWzSgv8.js +0 -113
- package/dist/browser-control-auth-y1f-9HRI.js +0 -2
- package/dist/browser-node-runtime-3UAeP8a6.js +0 -12
- package/dist/browser-profiles-BzzxphNW.js +0 -2
- package/dist/browser-runtime-jj11LR-E.js +0 -387
- package/dist/browser-setup-tools-CFB52yQc.js +0 -13
- package/dist/build-TlobwpQW.js +0 -550
- package/dist/call-Bx8lENb2.js +0 -3
- package/dist/call-jYRpeAWm.js +0 -331
- package/dist/call.runtime-BRluUZbD.js +0 -2
- package/dist/capability-cli-Iyj9Zi3g.js +0 -1401
- package/dist/catchup-CtxTwzY8.js +0 -300
- package/dist/channel-BJKHBfnq.js +0 -491
- package/dist/channel-BNNnYzwK.js +0 -1100
- package/dist/channel-BXS-Hd8p.js +0 -226
- package/dist/channel-C4XWpowe.js +0 -1174
- package/dist/channel-CJQdQgPr.js +0 -840
- package/dist/channel-C_zWAu4D.js +0 -595
- package/dist/channel-CtGzrF-K.js +0 -1802
- package/dist/channel-O9DE4IIq.js +0 -350
- package/dist/channel-WHUOtJme.js +0 -297
- package/dist/channel-WoDWDxqx.js +0 -1320
- package/dist/channel-core-BJjq9SOq.js +0 -5
- package/dist/channel-inbound-DLs-YfUs.js +0 -31
- package/dist/channel-plugin-runtime-CMG8ac2K.js +0 -771
- package/dist/channel-runtime-4UjeDmDI.js +0 -425
- package/dist/channel-ys2FFqi1.js +0 -453
- package/dist/channel.runtime-B38Ky3R9.js +0 -109
- package/dist/channel.runtime-Bl8WYZvF.js +0 -576
- package/dist/channel.runtime-D3kAsCsR.js +0 -89
- package/dist/channel.runtime-DEQ-anMf.js +0 -2364
- package/dist/channel.runtime-DG-EUnSC.js +0 -4
- package/dist/channel.runtime-IfV1Md6p.js +0 -430
- package/dist/channel.runtime-w1tHjTOa.js +0 -34702
- package/dist/channel.setup-dXwiMlyi.js +0 -10
- package/dist/channels-B2G1Y-iD.js +0 -733
- package/dist/channels-cli-YintLKAt.js +0 -268
- package/dist/chat-DdKbu8CA.js +0 -2758
- package/dist/clawbot-cli-CnHERFYk.js +0 -9
- package/dist/cli-CSNAd6Sz.js +0 -72
- package/dist/cli-CdRioBfN.js +0 -2
- package/dist/cli-DMPwqYqc.js +0 -219
- package/dist/cli-ctyAqh0j.js +0 -2
- package/dist/cli-runner-CNlk7xmx.js +0 -286
- package/dist/cli-runner.runtime-BK4sQk1m.js +0 -3
- package/dist/cli-runner.runtime-BT8ZZn-R.js +0 -4
- package/dist/cli.runtime-DU7swpBI.js +0 -1261
- package/dist/client-CQdcTPUf.js +0 -138
- package/dist/client-Vx7pseEY.js +0 -713
- package/dist/command-auth-DkJWb2HE.js +0 -76
- package/dist/command-config-resolution-CIRWRfR8.js +0 -23
- package/dist/command-config-resolution-DYZWj6Zm.js +0 -2
- package/dist/command-config-resolution.runtime-CUtVJOf0.js +0 -2
- package/dist/command-registry-CHy5EH0v.js +0 -4
- package/dist/command-registry-CyKgELQP.js +0 -9
- package/dist/command-registry-core-DQeRIuot.js +0 -104
- package/dist/command-secret-gateway-BNnWdAlq.js +0 -528
- package/dist/command-status.runtime-CKgimR6Y.js +0 -87
- package/dist/commands-acp-DSm97O5v.js +0 -77
- package/dist/commands-compact.runtime-BXhP6WJ6.js +0 -10
- package/dist/commands-handlers.runtime-FzK-n0L8.js +0 -4597
- package/dist/commands-status-BQnB5OSX.js +0 -16
- package/dist/commands-status.runtime-B6GcfEDm.js +0 -3
- package/dist/commands-subagents-control.runtime-CByd528A.js +0 -2
- package/dist/commands-subagents-control.runtime-CqI4LMYa.js +0 -3
- package/dist/commands-system-prompt-BD_LeeZk.js +0 -2
- package/dist/commands-system-prompt-C2Md_Ia1.js +0 -158
- package/dist/commands.runtime-CwiPf7Cc.js +0 -166
- package/dist/compact-B_4bMVpw.js +0 -1118
- package/dist/compact.runtime-BhRqiBXG.js +0 -12
- package/dist/completion-cli-D07hGGMI.js +0 -313
- package/dist/config-B1lvYOd7.js +0 -251
- package/dist/config-cli-BgepNwob.js +0 -1078
- package/dist/configure-CEfl0ORM.js +0 -2
- package/dist/configure-TsykzQqM.js +0 -1245
- package/dist/connect-options-zqTIEl6K.js +0 -699
- package/dist/control-auth-CNa_KHpo.js +0 -125
- package/dist/control-service-CZl5wFdZ.js +0 -156
- package/dist/conversation-id-BLY9ffjm.js +0 -38
- package/dist/conversation-id-DVeOM5Jh.js +0 -235
- package/dist/conversation-runtime-gJt7AAg2.js +0 -31
- package/dist/core-BtmNtOpS.js +0 -275
- package/dist/cron-cli-s9SF4__G.js +0 -713
- package/dist/daemon-cli-TCubZfI_.js +0 -12
- package/dist/delegate-DyITI93V.js +0 -64
- package/dist/detached-task-runtime-CTUQj84i.js +0 -73
- package/dist/devices-cli-SXcLjGmh.js +0 -496
- package/dist/diagnostics-waSemGnZ.js +0 -154
- package/dist/direct-dm-CiSjkmkL.js +0 -64
- package/dist/dispatch-BnQSIx2G.js +0 -1131
- package/dist/dispatch-acp-CaNQyl2L.js +0 -981
- package/dist/dispatch-acp-manager.runtime-DJK1eHYX.js +0 -3
- package/dist/dispatch-acp.runtime-Bl5cvtX4.js +0 -19
- package/dist/doctor-device-pairing-DBhEA-8G.js +0 -307
- package/dist/doctor-gateway-daemon-flow-Ds47Er3Y.js +0 -250
- package/dist/doctor-gateway-health-EWwTw5JR.js +0 -60
- package/dist/doctor-health-C6muRn7t.js +0 -59
- package/dist/doctor-health-contributions-B984415a.js +0 -486
- package/dist/doctor-prompter-BpOi4ndi.js +0 -56
- package/dist/doctor-workspace-status-CiEWZXrx.js +0 -75
- package/dist/dreaming-DFPenC85.js +0 -1574
- package/dist/dreaming-narrative-6A27_Gft.js +0 -595
- package/dist/embedded-gateway-stub.runtime-UVgfXZzk.js +0 -9
- package/dist/exec-approvals-cli-Cc_GG9ZT.js +0 -498
- package/dist/fallbacks-DX4YcmAx.js +0 -2
- package/dist/fallbacks-inTaaG-m.js +0 -31
- package/dist/fallbacks-shared-ow1la-U2.js +0 -111
- package/dist/gateway-D4iWwu3_.js +0 -115
- package/dist/gateway-cli-D6j0Aj3R.js +0 -1325
- package/dist/gateway-rpc-Dd_x2GX5.js +0 -14
- package/dist/gateway-rpc.runtime-Btnvsv-7.js +0 -23
- package/dist/gateway-runtime-DctMRv_p.js +0 -15
- package/dist/gateway-status-DJCtvUVn.js +0 -584
- package/dist/genesis-tools-CvMcpUvH.js +0 -8999
- package/dist/genesis-tools.runtime-Ch3NDEDq.js +0 -2
- package/dist/get-reply-Cm39MCyU.js +0 -3879
- package/dist/get-reply-from-config.runtime-CSqCYatb.js +0 -2
- package/dist/graph-users-BJxYqA3A.js +0 -1337
- package/dist/health-C14jIilQ.js +0 -469
- package/dist/health-C6yJSCMc.js +0 -3
- package/dist/heartbeat-runner-C6-gFnyC.js +0 -5
- package/dist/heartbeat-runner-yUYjgzIM.js +0 -1292
- package/dist/heartbeat-runner.runtime-DZzyrUNB.js +0 -4
- package/dist/hooks-cli-CCRaHheu.js +0 -433
- package/dist/image-fallbacks-BH9qLbBG.js +0 -31
- package/dist/image-fallbacks-DUOPO1ic.js +0 -2
- package/dist/inbound-reply-dispatch-DPf_IrbV.js +0 -73
- package/dist/infra-runtime-CLND6LJ0.js +0 -39
- package/dist/init-CzWob-9v.js +0 -59
- package/dist/library-C0a9Bz2M.js +0 -45
- package/dist/lifecycle-B_B_jt3r.js +0 -571
- package/dist/lifecycle-DuqKKZop.js +0 -229
- package/dist/lifecycle.runtime-DoosWTnK.js +0 -2
- package/dist/list-Bly8XeOF.js +0 -2
- package/dist/list-C5HvtbwZ.js +0 -2
- package/dist/list-CHIiamt1.js +0 -131
- package/dist/list-CMmJiacX.js +0 -1201
- package/dist/list.probe-kmHRFlrP.js +0 -419
- package/dist/llm-slug-generator-C3u6Ptgq.js +0 -79
- package/dist/load-config-CXvIGI7N.js +0 -35
- package/dist/local-dispatch.runtime-BNQF4rqW.js +0 -8
- package/dist/logs-cli-DEy1GPk2.js +0 -265
- package/dist/logs-cli.runtime-jWShKzQC.js +0 -2
- package/dist/main-session-restart-recovery-CzfY6Cd8.js +0 -206
- package/dist/managed-image-attachments-BGPKA7Mn.js +0 -2
- package/dist/managed-image-attachments-CTrq9ym-.js +0 -635
- package/dist/manager-C_ZGa9x8.js +0 -2057
- package/dist/manager-DIHLRzYF.js +0 -2
- package/dist/markdown-to-line-CRbbXtJK.js +0 -790
- package/dist/mcp-cli-FMJb3T4k.js +0 -725
- package/dist/mcp-http-b6UMoE_J.js +0 -529
- package/dist/memory-core-host-runtime-cli-CquxELNj.js +0 -9
- package/dist/message-CmjuvIFf.js +0 -232
- package/dist/message-action-runner-CiY3rhqt.js +0 -1407
- package/dist/message-action-runner-Do4P0h5i.js +0 -2
- package/dist/message-actions-BYREqFJA.js +0 -143
- package/dist/message.gateway.runtime-gkoWzaYV.js +0 -2
- package/dist/models-auth-status-B_Pcr0tl.js +0 -201
- package/dist/models-cli-BZSuW2gw.js +0 -219
- package/dist/monitor-22LY8y6z.js +0 -788
- package/dist/monitor-BZdf_CEm.js +0 -1237
- package/dist/monitor-CTVDlTs2.js +0 -671
- package/dist/monitor-Cfv-KGAl.js +0 -1661
- package/dist/monitor-DuA69-8E.js +0 -2
- package/dist/monitor-auth-BNDlfcw7.js +0 -207
- package/dist/monitor-cmWeDVxf.js +0 -1459
- package/dist/monitor-processing-D9Xcsagt.js +0 -1974
- package/dist/monitor.runtime-zWvcbNim.js +0 -2
- package/dist/monitor.webhook-BYWQa5lY.js +0 -180
- package/dist/msteams-n9HDT4O-.js +0 -35
- package/dist/native-hook-relay-CKyIfLOm.js +0 -519
- package/dist/nextcloud-talk-BuJVVP0J.js +0 -17
- package/dist/node-cli-DBK2TIEH.js +0 -2506
- package/dist/nodes-cli-D5Y1_ZVD.js +0 -1046
- package/dist/nodes-utils-C6IKaTjm.js +0 -84
- package/dist/nodes.helpers-CkJO5i0d.js +0 -34
- package/dist/notify-v0zoiI-O.js +0 -315
- package/dist/onboard-BCaLBJor.js +0 -632
- package/dist/onboard-helpers-Ba7ES7kB.js +0 -204
- package/dist/onboard-helpers-D5qdyBIj.js +0 -6
- package/dist/onboard-remote-BaHm_VrY.js +0 -2
- package/dist/onboard-remote-DbGAo_Ad.js +0 -193
- package/dist/onboard-skills-BA7c4li1.js +0 -2
- package/dist/onboard-skills-upyHp6T9.js +0 -134
- package/dist/openai-http-DwCqhEcX.js +0 -500
- package/dist/openresponses-http-tJr67vC1.js +0 -1128
- package/dist/operator-approvals-client-C0t_-2xC.js +0 -68
- package/dist/outbound.runtime-nXA4k1xA.js +0 -2
- package/dist/pair-command-approve-G5y-rKn9.js +0 -44
- package/dist/persistent-bindings.lifecycle-C56aKBVc.js +0 -2
- package/dist/persistent-bindings.lifecycle-CfBqvz9L.js +0 -85
- package/dist/pi-embedded-B1wvxHXL.js +0 -2905
- package/dist/pi-embedded-DmDb-oUB.js +0 -4
- package/dist/pi-embedded.runtime-D5xqw9Ko.js +0 -4
- package/dist/pi-tool-definition-adapter-CAxlo-Va.js +0 -217
- package/dist/pi-tools-C69yvznf.js +0 -1057
- package/dist/pi-tools.before-tool-call-BDeCmoAy.js +0 -2
- package/dist/pi-tools.before-tool-call-DG7VVNBn.js +0 -433
- package/dist/plugin-B9Ld0CUs.js +0 -12195
- package/dist/plugin-enabled-BguUplCN.js +0 -140
- package/dist/plugin-registration-DPBnSoak.js +0 -23
- package/dist/plugin-service-CdNFnRyN.js +0 -2890
- package/dist/policy-DgfegT_Y.js +0 -328
- package/dist/prepare.runtime-C_sRmuFC.js +0 -815
- package/dist/probe-8vb_Ssot.js +0 -45
- package/dist/probe-BjmKFiz1.js +0 -2205
- package/dist/probe-CVlOo8Hr.js +0 -74
- package/dist/probe-CakOsrSu.js +0 -241
- package/dist/probe-CbOoVumf.js +0 -2
- package/dist/probe-D6yFcZpK.js +0 -1443
- package/dist/probe-OcOYm1bj.js +0 -2
- package/dist/program-BJnTb7UE.js +0 -111
- package/dist/prompt-select-styled-C8kGHNpY.js +0 -20
- package/dist/protocol-C40iRm9c.js +0 -2234
- package/dist/provider-dispatcher-BIOPYzb9.js +0 -2
- package/dist/provider-dispatcher-CpwviX0O.js +0 -22
- package/dist/qr-cli-CJXKCj0L.js +0 -2
- package/dist/qr-cli-kSU9X-N0.js +0 -349
- package/dist/reaction-runtime-api-3XFmruJA.js +0 -116
- package/dist/reactions-By-nqZC6.js +0 -998
- package/dist/register-service-commands-fwB-T6mW.js +0 -71
- package/dist/register.agent-CpScU3CV.js +0 -248
- package/dist/register.configure-DpD3_BCK.js +0 -15
- package/dist/register.maintenance-ByoQXpk9.js +0 -438
- package/dist/register.message-BTXNOZMD.js +0 -329
- package/dist/register.onboard-B83CAOYy.js +0 -81
- package/dist/register.runtime-Doz01zcH.js +0 -81
- package/dist/register.setup-BKI5rwWy.js +0 -150
- package/dist/register.status-health-sessions-DRPszDQ-.js +0 -1215
- package/dist/register.subclis-DeXklyQL.js +0 -3
- package/dist/register.subclis-YkmoZoxl.js +0 -29
- package/dist/register.subclis-core-BPo4hV1Q.js +0 -243
- package/dist/reply-dispatch-runtime-DjIuN_dr.js +0 -13
- package/dist/reply-runtime-5TFidLR3.js +0 -11
- package/dist/reply.runtime-6d1e0INl.js +0 -2
- package/dist/restart-health-BWUPc4R-.js +0 -202
- package/dist/restart-health-CWvsjHVN.js +0 -2
- package/dist/root-help-D2YiFpS6.js +0 -44
- package/dist/routes-BdYdVpe7.js +0 -3341
- package/dist/routes-jYoN_qOU.js +0 -2
- package/dist/rpc-5tMjebZH.js +0 -61
- package/dist/rpc.runtime-BzAHjcm4.js +0 -21
- package/dist/run-delivery.runtime-qZIB76oE.js +0 -530
- package/dist/run-embedded.runtime-nHunVmCv.js +0 -4
- package/dist/run-execution-cli.runtime-CMT7La6D.js +0 -4
- package/dist/run-executor.runtime-BG6SDi3f.js +0 -277
- package/dist/run-main-CNf_LLX7.js +0 -516
- package/dist/run-subagent-registry.runtime-D0RcqcJr.js +0 -2
- package/dist/run-wait--kou3jZ7.js +0 -135
- package/dist/runtime-BvxkGJm2.js +0 -9
- package/dist/runtime-DgQ5oUKq.js +0 -973
- package/dist/runtime-api-6SzMK-FZ.js +0 -4
- package/dist/runtime-api-BAMrcB-5.js +0 -9
- package/dist/runtime-api-DLSrxS5O.js +0 -9
- package/dist/runtime-api-DsPleWQg.js +0 -14
- package/dist/runtime-embedded-pi.runtime-eyjaJfAz.js +0 -2
- package/dist/runtime-internal-BTfGDlHi.js +0 -2
- package/dist/runtime-options-B5_eZxMV.js +0 -275
- package/dist/runtime-schema-BB3QzGXJ.js +0 -27780
- package/dist/scan-D0fsxqed.js +0 -2
- package/dist/scan-DrjjN66Z.js +0 -523
- package/dist/secrets-cli-B7-qbfn-.js +0 -2101
- package/dist/security-cli-CYTPgL67.js +0 -486
- package/dist/selection-DEAdLh1Q.js +0 -2
- package/dist/selection-zPPyzfBX.js +0 -7736
- package/dist/send-CYKfZTCJ.js +0 -156
- package/dist/send-Di1tRwJD.js +0 -102
- package/dist/send.runtime-Bw22DBkL.js +0 -2
- package/dist/server-BIF5dPI_.js +0 -13
- package/dist/server-BJK0Q4xw.js +0 -77
- package/dist/server-context-CiVVCQNp.js +0 -847
- package/dist/server-context-DXvk5Tdy.js +0 -2
- package/dist/server-node-events-CdZP3Kok.js +0 -481
- package/dist/server-plugin-bootstrap-Di15EOt4.js +0 -11333
- package/dist/server-plugin-bootstrap-dboO44LL.js +0 -2
- package/dist/server-restart-sentinel-BWiOzljY.js +0 -697
- package/dist/server.impl-Ph8YCQpT.js +0 -12734
- package/dist/session-kill-http-B_J1fJ4-.js +0 -110
- package/dist/session-reset-service-DPgw70iw.js +0 -471
- package/dist/session-route-B0h6MEyB.js +0 -93
- package/dist/session-status.runtime-DCvgI1pG.js +0 -2
- package/dist/session-subagent-reactivation.runtime-BgsCnI-h.js +0 -2
- package/dist/session-tab-registry-FyN6CWh5.js +0 -491
- package/dist/session-visibility-CZjMA1SL.js +0 -147
- package/dist/sessions-helpers-B3W7MdIb.js +0 -304
- package/dist/sessions-history-http-Bw5J6HQ-.js +0 -383
- package/dist/sessions-patch-2sBcHc9a.js +0 -309
- package/dist/sessions-resolve-C-VZh_56.js +0 -174
- package/dist/sessions.runtime-cLuc67tJ.js +0 -2
- package/dist/setup-FW8xH-S-.js +0 -495
- package/dist/setup-api-Culp0Usf.js +0 -29
- package/dist/setup-core-CaTBS6Tz.js +0 -171
- package/dist/setup-core-youmXvW_.js +0 -176
- package/dist/setup-surface-BeMn-9hU.js +0 -403
- package/dist/setup-surface-CUd-s0wh.js +0 -286
- package/dist/setup-surface-DtscjAY3.js +0 -219
- package/dist/setup.finalize-BWyA4f4q.js +0 -539
- package/dist/setup.gateway-config-CvzMdftA.js +0 -250
- package/dist/shared-B3Pz1Xcr.js +0 -121
- package/dist/shared-Bc3x3THS.js +0 -76
- package/dist/shared-CxbLx0Ww.js +0 -198
- package/dist/slash-state-XfeMEeuI.js +0 -1911
- package/dist/src-BiDxQvtV.js +0 -3974
- package/dist/startup-context-CXQi-7YB.js +0 -312
- package/dist/status-Ch3bm70K.js +0 -2
- package/dist/status-CiQSxvY-.js +0 -3
- package/dist/status-DY0DlWlw.js +0 -190
- package/dist/status-DjdByQv-.js +0 -209
- package/dist/status-MT62_Jgw.js +0 -2
- package/dist/status-all-BD2viQD9.js +0 -498
- package/dist/status-json-CWS2oYON.js +0 -14
- package/dist/status-json-command-B6lZefoe.js +0 -84
- package/dist/status-pujDHwRb.js +0 -397
- package/dist/status-runtime-shared-Bu9Zhd7x.js +0 -257
- package/dist/status-subagents.runtime-B4UXD0lL.js +0 -18
- package/dist/status-text-myqmk4OL.js +0 -237
- package/dist/status.gateway-connection.runtime-B0Iwl2iZ.js +0 -2
- package/dist/status.gather-C51Ja0wP.js +0 -292
- package/dist/status.gather-DQ7WZp3H.js +0 -2
- package/dist/status.runtime-Cxyb3wHZ.js +0 -2
- package/dist/status.scan-C1aqDsy2.js +0 -65
- package/dist/status.scan-overview-BerlJz2l.js +0 -379
- package/dist/status.scan.fast-json-BXY82vu2.js +0 -2
- package/dist/status.scan.fast-json-DJqgEbzZ.js +0 -132
- package/dist/status.summary-CCdLUph8.js +0 -214
- package/dist/status.summary-CHAn0_FS.js +0 -2
- package/dist/subagent-announce-D4jG75Ub.js +0 -351
- package/dist/subagent-announce-delivery-BkQYzDcy.js +0 -726
- package/dist/subagent-announce-output-C3pkuu-t.js +0 -364
- package/dist/subagent-control-DVVK8du2.js +0 -506
- package/dist/subagent-followup.runtime-CdeweG-S.js +0 -68
- package/dist/subagent-orphan-recovery-ZQanOHb4.js +0 -305
- package/dist/subagent-registry-BcPa3ho0.js +0 -3
- package/dist/subagent-registry-hJUso5eL.js +0 -1753
- package/dist/subagent-spawn-DTaeQc9q.js +0 -1005
- package/dist/system-cli-CT8VaSDY.js +0 -59
- package/dist/targets-BPdSjnQH.js +0 -67
- package/dist/task-executor-B62Qzfi-.js +0 -360
- package/dist/task-owner-access-BBMrMOlN.js +0 -74
- package/dist/task-registry-BD-ew2bT.js +0 -2366
- package/dist/task-registry-delivery-runtime-B2WyGY0d.js +0 -3
- package/dist/task-registry-delivery-runtime-MFJszOHI.js +0 -2
- package/dist/task-registry.maintenance-0D2Yxl49.js +0 -416
- package/dist/task-registry.maintenance-OPlfB5W9.js +0 -2
- package/dist/testing-DmxZ16UC.js +0 -575
- package/dist/text-report-BwIpU54R.js +0 -587
- package/dist/tool-resolution-vn72hwMo.js +0 -90
- package/dist/tools-effective-inventory-DII_pOSr.js +0 -152
- package/dist/tools-invoke-http-DdthGR52.js +0 -206
- package/dist/trash-BVZu6rU7.js +0 -24
- package/dist/tui-cli-Bz51WCAi.js +0 -4575
- package/dist/update-cli-DkH8vHQP.js +0 -1759
- package/dist/upgrade-Dvj8K4WB.js +0 -1226
- package/dist/video-generation-task-status-CHYB_IeZ.js +0 -163
- package/dist/wait-for-idle-before-flush-DJMxeE2X.js +0 -5986
- package/dist/wizard-models-BNQQ7fvr.js +0 -161
|
@@ -0,0 +1,2506 @@
|
|
|
1
|
+
import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString, o as normalizeNullableString } from "./string-coerce-C1IzJjqi.js";
|
|
2
|
+
import { n as defaultRuntime } from "./runtime-CQ7eH0le.js";
|
|
3
|
+
import { t as formatDocsLink } from "./links-DmsJCU7L.js";
|
|
4
|
+
import { r as theme, t as colorize } from "./theme-BrRleVfL.js";
|
|
5
|
+
import { t as formatCliCommand } from "./command-format-DAeUlu7u.js";
|
|
6
|
+
import { c as sanitizeSystemRunEnvOverrides, o as sanitizeHostExecEnv, t as inspectHostExecEnvOverrides } from "./host-env-security-Bin-AhM4.js";
|
|
7
|
+
import { _ as resolveNodeSystemdServiceName, g as resolveNodeLaunchAgentLabel, u as formatNodeServiceDescription, v as resolveNodeWindowsTaskName } from "./paths-Dk_PxD7g.js";
|
|
8
|
+
import { a as resolveNodeProgramArguments, n as resolveDaemonInstallRuntimeInputs, r as resolveDaemonNodeBinDir, t as emitDaemonInstallRuntimeWarning } from "./daemon-install-plan.shared-BQxPrU7X.js";
|
|
9
|
+
import { n as VERSION } from "./version-BoqlEm3e.js";
|
|
10
|
+
import { s as buildNodeServiceEnvironment } from "./runtime-paths-CYF3ghl0.js";
|
|
11
|
+
import { r as isGatewayDaemonRuntime, t as DEFAULT_GATEWAY_DAEMON_RUNTIME } from "./daemon-runtime-BFK5T_3J.js";
|
|
12
|
+
import { a as logWarn } from "./logger-DxTAquCB.js";
|
|
13
|
+
import { t as sameFileIdentity } from "./file-identity-DBd-elc3.js";
|
|
14
|
+
import { a as loadConfig } from "./io-h8M_Z0Lj.js";
|
|
15
|
+
import { c as normalizeAgentId } from "./session-key-EpIbK3Oz.js";
|
|
16
|
+
import { A as unwrapKnownShellMultiplexerInvocation, L as unwrapKnownDispatchWrapperInvocation, N as resolveInlineCommandMatch, O as isShellWrapperInvocation, P as extractEnvAssignmentKeysFromDispatchWrappers, R as normalizeExecutableToken, S as POSIX_SHELL_WRAPPERS, d as resolveApprovalAuditCandidatePath, j as POSIX_INLINE_COMMAND_FLAGS, k as resolveShellWrapperTransportArgv, p as resolveCommandResolutionFromArgv, y as resolveExecutableFromPathEnv } from "./exec-safe-bin-trust-D3m9TQoQ.js";
|
|
17
|
+
import { d as resolveRuntimeStatusColor, h as installDaemonServiceAndEmit, n as createDaemonInstallActionContext, p as buildDaemonServiceSnapshot, r as failIfNixDaemonInstallMode, t as createCliStatusTextStyles } from "./shared-BdZN5DvO.js";
|
|
18
|
+
import { n as buildPlatformServiceStartHints, r as formatRuntimeStatus, t as buildPlatformRuntimeLogHints } from "./runtime-hints-U-UR-C6L.js";
|
|
19
|
+
import { t as parsePort } from "./parse-port-OVyfw_Ty.js";
|
|
20
|
+
import "./config-B3ZoZd5V.js";
|
|
21
|
+
import { t as GatewayClient } from "./client-CrPccv7a.js";
|
|
22
|
+
import { n as loadOrCreateDeviceIdentity } from "./device-identity-CqT162U8.js";
|
|
23
|
+
import { i as GATEWAY_CLIENT_NAMES, r as GATEWAY_CLIENT_MODES } from "./client-info-CfESmEX1.js";
|
|
24
|
+
import { i as runServiceUninstall, r as runServiceStop, t as runServiceRestart } from "./lifecycle-core-BpdZi2zv.js";
|
|
25
|
+
import { i as NODE_SYSTEM_RUN_COMMANDS, n as NODE_EXEC_APPROVALS_COMMANDS } from "./node-commands-gl3_egiE.js";
|
|
26
|
+
import { a as getActivePluginRegistry } from "./runtime-Sn8KleIb.js";
|
|
27
|
+
import { t as getMachineDisplayName } from "./machine-name-C0HO_9mJ.js";
|
|
28
|
+
import { t as splitShellArgs } from "./shell-argv-CYZYGBfB.js";
|
|
29
|
+
import { _ as resolvePlannedSegmentArgv, c as describeInterpreterInlineEval, d as analyzeArgvCommand, l as detectInterpreterInlineEvalArgv, n as evaluateShellAllowlist, t as evaluateExecAllowlist } from "./exec-approvals-allowlist-BNwpLnkv.js";
|
|
30
|
+
import { r as resolveExecSafeBinRuntimePolicy, t as isInterpreterLikeSafeBin } from "./exec-safe-bin-runtime-policy-9WKan9iE.js";
|
|
31
|
+
import { C as requiresExecApproval, E as resolveExecApprovals, M as requestJsonlSocket, a as addDurableCommandApproval, b as recordAllowlistMatchesUse, d as mergeExecApprovalsSocketDefaults, j as saveExecApprovals, o as ensureExecApprovals, p as normalizeExecApprovals, s as hasDurableExecApproval, v as persistAllowAlwaysPatterns, y as readExecApprovalsSnapshot } from "./exec-approvals-BD-zKkI1.js";
|
|
32
|
+
import { t as resolveGatewayConnectionAuth } from "./connection-auth-ClOE-Fdq.js";
|
|
33
|
+
import { t as formatHelpExamples } from "./help-format-DM-hbV3N.js";
|
|
34
|
+
import { n as resolveSystemRunCommandRequest, s as normalizeSystemRunApprovalPlan, t as formatExecCommand } from "./system-run-command-DpmKt0vV.js";
|
|
35
|
+
import { t as ensureGenesisCliOnPath } from "./path-env-4eKek7HW.js";
|
|
36
|
+
import { n as loadNodeHostConfig, r as saveNodeHostConfig, t as ensureNodeHostConfig } from "./config-2LFRVjdy.js";
|
|
37
|
+
import { t as resolveNodeService } from "./node-service-CijQCPXW.js";
|
|
38
|
+
import fs from "node:fs";
|
|
39
|
+
import path from "node:path";
|
|
40
|
+
import { spawn, spawnSync } from "node:child_process";
|
|
41
|
+
import crypto from "node:crypto";
|
|
42
|
+
//#region src/infra/exec-host.ts
|
|
43
|
+
async function requestExecHostViaSocket(params) {
|
|
44
|
+
const { socketPath, token, request } = params;
|
|
45
|
+
if (!socketPath || !token) return null;
|
|
46
|
+
const timeoutMs = params.timeoutMs ?? 2e4;
|
|
47
|
+
const requestJson = JSON.stringify(request);
|
|
48
|
+
const nonce = crypto.randomBytes(16).toString("hex");
|
|
49
|
+
const ts = Date.now();
|
|
50
|
+
const hmac = crypto.createHmac("sha256", token).update(`${nonce}:${ts}:${requestJson}`).digest("hex");
|
|
51
|
+
return await requestJsonlSocket({
|
|
52
|
+
socketPath,
|
|
53
|
+
requestLine: JSON.stringify({
|
|
54
|
+
type: "exec",
|
|
55
|
+
id: crypto.randomUUID(),
|
|
56
|
+
nonce,
|
|
57
|
+
ts,
|
|
58
|
+
hmac,
|
|
59
|
+
requestJson
|
|
60
|
+
}),
|
|
61
|
+
timeoutMs,
|
|
62
|
+
accept: (value) => {
|
|
63
|
+
const msg = value;
|
|
64
|
+
if (msg?.type !== "exec-res") return;
|
|
65
|
+
if (msg.ok === true && msg.payload) return {
|
|
66
|
+
ok: true,
|
|
67
|
+
payload: msg.payload
|
|
68
|
+
};
|
|
69
|
+
if (msg.ok === false && msg.error) return {
|
|
70
|
+
ok: false,
|
|
71
|
+
error: msg.error
|
|
72
|
+
};
|
|
73
|
+
return null;
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
//#endregion
|
|
78
|
+
//#region src/node-host/exec-policy.ts
|
|
79
|
+
function resolveExecApprovalDecision(value) {
|
|
80
|
+
if (value === "allow-once" || value === "allow-always") return value;
|
|
81
|
+
return null;
|
|
82
|
+
}
|
|
83
|
+
function formatSystemRunAllowlistMissMessage(params) {
|
|
84
|
+
if (params?.windowsShellWrapperBlocked) return "SYSTEM_RUN_DENIED: allowlist miss (Windows shell wrappers like cmd.exe /c require approval; approve once/always or run with --ask on-miss|always)";
|
|
85
|
+
if (params?.shellWrapperBlocked) return "SYSTEM_RUN_DENIED: allowlist miss (shell wrappers like sh/bash/zsh -c require approval; approve once/always or run with --ask on-miss|always)";
|
|
86
|
+
return "SYSTEM_RUN_DENIED: allowlist miss";
|
|
87
|
+
}
|
|
88
|
+
function evaluateSystemRunPolicy(params) {
|
|
89
|
+
const windowsShellWrapperBlocked = params.security === "allowlist" && params.shellWrapperInvocation && params.isWindows && params.cmdInvocation;
|
|
90
|
+
const shellWrapperBlocked = windowsShellWrapperBlocked;
|
|
91
|
+
const analysisOk = shellWrapperBlocked ? false : params.analysisOk;
|
|
92
|
+
const allowlistSatisfied = shellWrapperBlocked ? false : params.allowlistSatisfied;
|
|
93
|
+
const approvedByAsk = params.approvalDecision !== null || params.approved === true;
|
|
94
|
+
if (params.security === "deny") return {
|
|
95
|
+
allowed: false,
|
|
96
|
+
eventReason: "security=deny",
|
|
97
|
+
errorMessage: "SYSTEM_RUN_DISABLED: security=deny",
|
|
98
|
+
analysisOk,
|
|
99
|
+
allowlistSatisfied,
|
|
100
|
+
shellWrapperBlocked,
|
|
101
|
+
windowsShellWrapperBlocked,
|
|
102
|
+
requiresAsk: false,
|
|
103
|
+
approvalDecision: params.approvalDecision,
|
|
104
|
+
approvedByAsk
|
|
105
|
+
};
|
|
106
|
+
const requiresAsk = requiresExecApproval({
|
|
107
|
+
ask: params.ask,
|
|
108
|
+
security: params.security,
|
|
109
|
+
analysisOk,
|
|
110
|
+
allowlistSatisfied,
|
|
111
|
+
durableApprovalSatisfied: params.durableApprovalSatisfied
|
|
112
|
+
});
|
|
113
|
+
if (requiresAsk && !approvedByAsk) return {
|
|
114
|
+
allowed: false,
|
|
115
|
+
eventReason: "approval-required",
|
|
116
|
+
errorMessage: "SYSTEM_RUN_DENIED: approval required",
|
|
117
|
+
analysisOk,
|
|
118
|
+
allowlistSatisfied,
|
|
119
|
+
shellWrapperBlocked,
|
|
120
|
+
windowsShellWrapperBlocked,
|
|
121
|
+
requiresAsk,
|
|
122
|
+
approvalDecision: params.approvalDecision,
|
|
123
|
+
approvedByAsk
|
|
124
|
+
};
|
|
125
|
+
if (params.security === "allowlist" && (!analysisOk || !allowlistSatisfied) && !approvedByAsk) {
|
|
126
|
+
if (params.durableApprovalSatisfied) return {
|
|
127
|
+
allowed: true,
|
|
128
|
+
analysisOk,
|
|
129
|
+
allowlistSatisfied,
|
|
130
|
+
shellWrapperBlocked,
|
|
131
|
+
windowsShellWrapperBlocked,
|
|
132
|
+
requiresAsk,
|
|
133
|
+
approvalDecision: params.approvalDecision,
|
|
134
|
+
approvedByAsk
|
|
135
|
+
};
|
|
136
|
+
return {
|
|
137
|
+
allowed: false,
|
|
138
|
+
eventReason: "allowlist-miss",
|
|
139
|
+
errorMessage: formatSystemRunAllowlistMissMessage({
|
|
140
|
+
shellWrapperBlocked,
|
|
141
|
+
windowsShellWrapperBlocked
|
|
142
|
+
}),
|
|
143
|
+
analysisOk,
|
|
144
|
+
allowlistSatisfied,
|
|
145
|
+
shellWrapperBlocked,
|
|
146
|
+
windowsShellWrapperBlocked,
|
|
147
|
+
requiresAsk,
|
|
148
|
+
approvalDecision: params.approvalDecision,
|
|
149
|
+
approvedByAsk
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
return {
|
|
153
|
+
allowed: true,
|
|
154
|
+
analysisOk,
|
|
155
|
+
allowlistSatisfied,
|
|
156
|
+
shellWrapperBlocked,
|
|
157
|
+
windowsShellWrapperBlocked,
|
|
158
|
+
requiresAsk,
|
|
159
|
+
approvalDecision: params.approvalDecision,
|
|
160
|
+
approvedByAsk
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
//#endregion
|
|
164
|
+
//#region src/node-host/invoke-system-run-allowlist.ts
|
|
165
|
+
function evaluateSystemRunAllowlist(params) {
|
|
166
|
+
if (params.shellCommand) {
|
|
167
|
+
const allowlistEval = evaluateShellAllowlist({
|
|
168
|
+
command: params.shellCommand,
|
|
169
|
+
allowlist: params.approvals.allowlist,
|
|
170
|
+
safeBins: params.safeBins,
|
|
171
|
+
safeBinProfiles: params.safeBinProfiles,
|
|
172
|
+
cwd: params.cwd,
|
|
173
|
+
env: params.env,
|
|
174
|
+
trustedSafeBinDirs: params.trustedSafeBinDirs,
|
|
175
|
+
skillBins: params.skillBins,
|
|
176
|
+
autoAllowSkills: params.autoAllowSkills,
|
|
177
|
+
platform: process.platform
|
|
178
|
+
});
|
|
179
|
+
return {
|
|
180
|
+
analysisOk: allowlistEval.analysisOk,
|
|
181
|
+
allowlistMatches: allowlistEval.allowlistMatches,
|
|
182
|
+
allowlistSatisfied: params.security === "allowlist" && allowlistEval.analysisOk ? allowlistEval.allowlistSatisfied : false,
|
|
183
|
+
segments: allowlistEval.segments,
|
|
184
|
+
segmentAllowlistEntries: allowlistEval.segmentAllowlistEntries
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
const analysis = analyzeArgvCommand({
|
|
188
|
+
argv: params.argv,
|
|
189
|
+
cwd: params.cwd,
|
|
190
|
+
env: params.env
|
|
191
|
+
});
|
|
192
|
+
const allowlistEval = evaluateExecAllowlist({
|
|
193
|
+
analysis,
|
|
194
|
+
allowlist: params.approvals.allowlist,
|
|
195
|
+
safeBins: params.safeBins,
|
|
196
|
+
safeBinProfiles: params.safeBinProfiles,
|
|
197
|
+
cwd: params.cwd,
|
|
198
|
+
trustedSafeBinDirs: params.trustedSafeBinDirs,
|
|
199
|
+
skillBins: params.skillBins,
|
|
200
|
+
autoAllowSkills: params.autoAllowSkills
|
|
201
|
+
});
|
|
202
|
+
return {
|
|
203
|
+
analysisOk: analysis.ok,
|
|
204
|
+
allowlistMatches: allowlistEval.allowlistMatches,
|
|
205
|
+
allowlistSatisfied: params.security === "allowlist" && analysis.ok ? allowlistEval.allowlistSatisfied : false,
|
|
206
|
+
segments: analysis.segments,
|
|
207
|
+
segmentAllowlistEntries: allowlistEval.segmentAllowlistEntries
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
function resolvePlannedAllowlistArgv(params) {
|
|
211
|
+
if (params.security !== "allowlist" || params.policy.approvedByAsk || params.shellCommand || !params.policy.analysisOk || !params.policy.allowlistSatisfied || params.segments.length !== 1) return;
|
|
212
|
+
const plannedAllowlistArgv = resolvePlannedSegmentArgv(params.segments[0]);
|
|
213
|
+
return plannedAllowlistArgv && plannedAllowlistArgv.length > 0 ? plannedAllowlistArgv : null;
|
|
214
|
+
}
|
|
215
|
+
function resolveSystemRunExecArgv(params) {
|
|
216
|
+
let execArgv = params.plannedAllowlistArgv ?? params.argv;
|
|
217
|
+
if (params.security === "allowlist" && params.isWindows && !params.policy.approvedByAsk && params.shellCommand && params.policy.analysisOk && params.policy.allowlistSatisfied && params.segments.length === 1 && params.segments[0]?.argv.length > 0) execArgv = params.segments[0].argv;
|
|
218
|
+
return execArgv;
|
|
219
|
+
}
|
|
220
|
+
function applyOutputTruncation(result) {
|
|
221
|
+
if (!result.truncated) return;
|
|
222
|
+
const suffix = "... (truncated)";
|
|
223
|
+
if (result.stderr.trim().length > 0) result.stderr = `${result.stderr}\n${suffix}`;
|
|
224
|
+
else result.stdout = `${result.stdout}\n${suffix}`;
|
|
225
|
+
}
|
|
226
|
+
//#endregion
|
|
227
|
+
//#region src/node-host/invoke-system-run-plan.ts
|
|
228
|
+
const MUTABLE_ARGV1_INTERPRETER_PATTERNS = [
|
|
229
|
+
/^(?:node|nodejs)$/,
|
|
230
|
+
/^perl$/,
|
|
231
|
+
/^php$/,
|
|
232
|
+
/^python(?:\d+(?:\.\d+)*)?$/,
|
|
233
|
+
/^ruby$/
|
|
234
|
+
];
|
|
235
|
+
const GENERIC_MUTABLE_SCRIPT_RUNNERS = new Set([
|
|
236
|
+
"esno",
|
|
237
|
+
"jiti",
|
|
238
|
+
"ts-node",
|
|
239
|
+
"ts-node-esm",
|
|
240
|
+
"tsx",
|
|
241
|
+
"vite-node"
|
|
242
|
+
]);
|
|
243
|
+
const OPAQUE_MUTABLE_SCRIPT_RUNNERS = new Set(["busybox", "toybox"]);
|
|
244
|
+
const BUN_SUBCOMMANDS = new Set([
|
|
245
|
+
"add",
|
|
246
|
+
"audit",
|
|
247
|
+
"completions",
|
|
248
|
+
"create",
|
|
249
|
+
"exec",
|
|
250
|
+
"help",
|
|
251
|
+
"init",
|
|
252
|
+
"install",
|
|
253
|
+
"link",
|
|
254
|
+
"outdated",
|
|
255
|
+
"patch",
|
|
256
|
+
"pm",
|
|
257
|
+
"publish",
|
|
258
|
+
"remove",
|
|
259
|
+
"repl",
|
|
260
|
+
"run",
|
|
261
|
+
"test",
|
|
262
|
+
"unlink",
|
|
263
|
+
"update",
|
|
264
|
+
"upgrade",
|
|
265
|
+
"x"
|
|
266
|
+
]);
|
|
267
|
+
const BUN_OPTIONS_WITH_VALUE = new Set([
|
|
268
|
+
"--backend",
|
|
269
|
+
"--bunfig",
|
|
270
|
+
"--conditions",
|
|
271
|
+
"--config",
|
|
272
|
+
"--console-depth",
|
|
273
|
+
"--cwd",
|
|
274
|
+
"--define",
|
|
275
|
+
"--elide-lines",
|
|
276
|
+
"--env-file",
|
|
277
|
+
"--extension-order",
|
|
278
|
+
"--filter",
|
|
279
|
+
"--hot",
|
|
280
|
+
"--inspect",
|
|
281
|
+
"--inspect-brk",
|
|
282
|
+
"--inspect-wait",
|
|
283
|
+
"--install",
|
|
284
|
+
"--jsx-factory",
|
|
285
|
+
"--jsx-fragment",
|
|
286
|
+
"--jsx-import-source",
|
|
287
|
+
"--loader",
|
|
288
|
+
"--origin",
|
|
289
|
+
"--port",
|
|
290
|
+
"--preload",
|
|
291
|
+
"--smol",
|
|
292
|
+
"--tsconfig-override",
|
|
293
|
+
"-c",
|
|
294
|
+
"-e",
|
|
295
|
+
"-p",
|
|
296
|
+
"-r"
|
|
297
|
+
]);
|
|
298
|
+
const DENO_RUN_OPTIONS_WITH_VALUE = new Set([
|
|
299
|
+
"--cached-only",
|
|
300
|
+
"--cert",
|
|
301
|
+
"--config",
|
|
302
|
+
"--env-file",
|
|
303
|
+
"--ext",
|
|
304
|
+
"--harmony-import-attributes",
|
|
305
|
+
"--import-map",
|
|
306
|
+
"--inspect",
|
|
307
|
+
"--inspect-brk",
|
|
308
|
+
"--inspect-wait",
|
|
309
|
+
"--location",
|
|
310
|
+
"--log-level",
|
|
311
|
+
"--lock",
|
|
312
|
+
"--node-modules-dir",
|
|
313
|
+
"--no-check",
|
|
314
|
+
"--preload",
|
|
315
|
+
"--reload",
|
|
316
|
+
"--seed",
|
|
317
|
+
"--strace-ops",
|
|
318
|
+
"--unstable-bare-node-builtins",
|
|
319
|
+
"--v8-flags",
|
|
320
|
+
"--watch",
|
|
321
|
+
"--watch-exclude",
|
|
322
|
+
"-L"
|
|
323
|
+
]);
|
|
324
|
+
const NODE_OPTIONS_WITH_FILE_VALUE = new Set([
|
|
325
|
+
"-r",
|
|
326
|
+
"--experimental-loader",
|
|
327
|
+
"--import",
|
|
328
|
+
"--loader",
|
|
329
|
+
"--require"
|
|
330
|
+
]);
|
|
331
|
+
const RUBY_UNSAFE_APPROVAL_FLAGS = new Set([
|
|
332
|
+
"-I",
|
|
333
|
+
"-r",
|
|
334
|
+
"--require"
|
|
335
|
+
]);
|
|
336
|
+
const PERL_UNSAFE_APPROVAL_FLAGS = new Set([
|
|
337
|
+
"-I",
|
|
338
|
+
"-M",
|
|
339
|
+
"-m"
|
|
340
|
+
]);
|
|
341
|
+
function normalizeOptionFlag(token) {
|
|
342
|
+
return normalizeLowercaseStringOrEmpty(token.split("=", 1)[0]);
|
|
343
|
+
}
|
|
344
|
+
function readTrimmedArgToken(argv, index) {
|
|
345
|
+
return normalizeNullableString(argv[index]) ?? "";
|
|
346
|
+
}
|
|
347
|
+
const POSIX_SHELL_OPTIONS_WITH_VALUE = new Set([
|
|
348
|
+
"--init-file",
|
|
349
|
+
"--rcfile",
|
|
350
|
+
"--startup-script",
|
|
351
|
+
"-o"
|
|
352
|
+
]);
|
|
353
|
+
const NPM_EXEC_OPTIONS_WITH_VALUE = new Set([
|
|
354
|
+
"--cache",
|
|
355
|
+
"--package",
|
|
356
|
+
"--prefix",
|
|
357
|
+
"--script-shell",
|
|
358
|
+
"--userconfig",
|
|
359
|
+
"--workspace",
|
|
360
|
+
"-p",
|
|
361
|
+
"-w"
|
|
362
|
+
]);
|
|
363
|
+
const NPM_EXEC_FLAG_OPTIONS = new Set([
|
|
364
|
+
"--no",
|
|
365
|
+
"--quiet",
|
|
366
|
+
"--ws",
|
|
367
|
+
"--workspaces",
|
|
368
|
+
"--yes",
|
|
369
|
+
"-q",
|
|
370
|
+
"-y"
|
|
371
|
+
]);
|
|
372
|
+
const PNPM_OPTIONS_WITH_VALUE = new Set([
|
|
373
|
+
"--config",
|
|
374
|
+
"--dir",
|
|
375
|
+
"--filter",
|
|
376
|
+
"--reporter",
|
|
377
|
+
"--stream",
|
|
378
|
+
"--test-pattern",
|
|
379
|
+
"--workspace-concurrency",
|
|
380
|
+
"-C"
|
|
381
|
+
]);
|
|
382
|
+
const PNPM_FLAG_OPTIONS = new Set([
|
|
383
|
+
"--aggregate-output",
|
|
384
|
+
"--color",
|
|
385
|
+
"--parallel",
|
|
386
|
+
"--recursive",
|
|
387
|
+
"--silent",
|
|
388
|
+
"--workspace-root",
|
|
389
|
+
"-r",
|
|
390
|
+
"-s",
|
|
391
|
+
"-w"
|
|
392
|
+
]);
|
|
393
|
+
const PNPM_DLX_OPTIONS_WITH_VALUE = new Set([
|
|
394
|
+
"--allow-build",
|
|
395
|
+
"--package",
|
|
396
|
+
"-p"
|
|
397
|
+
]);
|
|
398
|
+
function pathComponentsFromRootSync(targetPath) {
|
|
399
|
+
const absolute = path.resolve(targetPath);
|
|
400
|
+
const parts = [];
|
|
401
|
+
let cursor = absolute;
|
|
402
|
+
while (true) {
|
|
403
|
+
parts.unshift(cursor);
|
|
404
|
+
const parent = path.dirname(cursor);
|
|
405
|
+
if (parent === cursor) return parts;
|
|
406
|
+
cursor = parent;
|
|
407
|
+
}
|
|
408
|
+
}
|
|
409
|
+
function isOwnedByCurrentProcessSync(candidate) {
|
|
410
|
+
if (process.platform === "win32" || typeof process.getuid !== "function") return false;
|
|
411
|
+
try {
|
|
412
|
+
return fs.statSync(candidate).uid === process.getuid();
|
|
413
|
+
} catch {
|
|
414
|
+
return false;
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
function isMutableByCurrentProcessSync(candidate) {
|
|
418
|
+
try {
|
|
419
|
+
fs.accessSync(candidate, fs.constants.W_OK);
|
|
420
|
+
return true;
|
|
421
|
+
} catch {
|
|
422
|
+
return isOwnedByCurrentProcessSync(candidate);
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
function hasMutableSymlinkPathComponentSync(targetPath) {
|
|
426
|
+
for (const component of pathComponentsFromRootSync(targetPath)) try {
|
|
427
|
+
if (!fs.lstatSync(component).isSymbolicLink()) continue;
|
|
428
|
+
if (isMutableByCurrentProcessSync(path.dirname(component))) return true;
|
|
429
|
+
} catch {
|
|
430
|
+
return true;
|
|
431
|
+
}
|
|
432
|
+
return false;
|
|
433
|
+
}
|
|
434
|
+
function pathLooksMutableForShellPayloadSync(targetPath) {
|
|
435
|
+
if (isMutableByCurrentProcessSync(targetPath) || isMutableByCurrentProcessSync(path.dirname(targetPath)) || hasMutableSymlinkPathComponentSync(targetPath)) return true;
|
|
436
|
+
let realPath;
|
|
437
|
+
try {
|
|
438
|
+
realPath = fs.realpathSync(targetPath);
|
|
439
|
+
} catch {
|
|
440
|
+
return true;
|
|
441
|
+
}
|
|
442
|
+
return isMutableByCurrentProcessSync(realPath) || isMutableByCurrentProcessSync(path.dirname(realPath)) || hasMutableSymlinkPathComponentSync(realPath);
|
|
443
|
+
}
|
|
444
|
+
function shouldPinExecutableForApproval(params) {
|
|
445
|
+
if (params.shellCommand !== null) return false;
|
|
446
|
+
return (params.wrapperChain?.length ?? 0) === 0;
|
|
447
|
+
}
|
|
448
|
+
function hashFileContentsSync(filePath) {
|
|
449
|
+
return crypto.createHash("sha256").update(fs.readFileSync(filePath)).digest("hex");
|
|
450
|
+
}
|
|
451
|
+
function looksLikePathToken(token) {
|
|
452
|
+
return token.startsWith(".") || token.startsWith("/") || token.startsWith("\\") || token.includes("/") || token.includes("\\") || path.extname(token).length > 0;
|
|
453
|
+
}
|
|
454
|
+
function resolvesToExistingFileSync(rawOperand, cwd) {
|
|
455
|
+
if (!rawOperand) return false;
|
|
456
|
+
try {
|
|
457
|
+
return fs.statSync(path.resolve(cwd ?? process.cwd(), rawOperand)).isFile();
|
|
458
|
+
} catch {
|
|
459
|
+
return false;
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
function isKnownBinaryExecutableHeader(buffer) {
|
|
463
|
+
if (buffer.length >= 4 && buffer.subarray(0, 4).equals(Buffer.from([
|
|
464
|
+
127,
|
|
465
|
+
69,
|
|
466
|
+
76,
|
|
467
|
+
70
|
|
468
|
+
]))) return true;
|
|
469
|
+
if (buffer.length >= 4 && (buffer.subarray(0, 4).equals(Buffer.from([
|
|
470
|
+
254,
|
|
471
|
+
237,
|
|
472
|
+
250,
|
|
473
|
+
206
|
|
474
|
+
])) || buffer.subarray(0, 4).equals(Buffer.from([
|
|
475
|
+
206,
|
|
476
|
+
250,
|
|
477
|
+
237,
|
|
478
|
+
254
|
|
479
|
+
])) || buffer.subarray(0, 4).equals(Buffer.from([
|
|
480
|
+
254,
|
|
481
|
+
237,
|
|
482
|
+
250,
|
|
483
|
+
207
|
|
484
|
+
])) || buffer.subarray(0, 4).equals(Buffer.from([
|
|
485
|
+
207,
|
|
486
|
+
250,
|
|
487
|
+
237,
|
|
488
|
+
254
|
|
489
|
+
])) || buffer.subarray(0, 4).equals(Buffer.from([
|
|
490
|
+
202,
|
|
491
|
+
254,
|
|
492
|
+
186,
|
|
493
|
+
190
|
|
494
|
+
])) || buffer.subarray(0, 4).equals(Buffer.from([
|
|
495
|
+
190,
|
|
496
|
+
186,
|
|
497
|
+
254,
|
|
498
|
+
202
|
|
499
|
+
])) || buffer.subarray(0, 4).equals(Buffer.from([
|
|
500
|
+
202,
|
|
501
|
+
254,
|
|
502
|
+
186,
|
|
503
|
+
191
|
|
504
|
+
])) || buffer.subarray(0, 4).equals(Buffer.from([
|
|
505
|
+
191,
|
|
506
|
+
186,
|
|
507
|
+
254,
|
|
508
|
+
202
|
|
509
|
+
])))) return true;
|
|
510
|
+
if (buffer.length < 64 || !buffer.subarray(0, 2).equals(Buffer.from([77, 90]))) return false;
|
|
511
|
+
const peOffset = buffer.readUInt32LE(60);
|
|
512
|
+
return peOffset >= 0 && peOffset <= buffer.length - 4 && buffer.subarray(peOffset, peOffset + 4).equals(Buffer.from([
|
|
513
|
+
80,
|
|
514
|
+
69,
|
|
515
|
+
0,
|
|
516
|
+
0
|
|
517
|
+
]));
|
|
518
|
+
}
|
|
519
|
+
function isLikelyScriptLikePathSync(targetPath) {
|
|
520
|
+
let stat;
|
|
521
|
+
try {
|
|
522
|
+
stat = fs.statSync(targetPath);
|
|
523
|
+
} catch {
|
|
524
|
+
return true;
|
|
525
|
+
}
|
|
526
|
+
if (!stat.isFile()) return true;
|
|
527
|
+
let header;
|
|
528
|
+
try {
|
|
529
|
+
const fd = fs.openSync(targetPath, "r");
|
|
530
|
+
try {
|
|
531
|
+
header = Buffer.alloc(1024);
|
|
532
|
+
const bytesRead = fs.readSync(fd, header, 0, header.length, 0);
|
|
533
|
+
header = header.subarray(0, bytesRead);
|
|
534
|
+
} finally {
|
|
535
|
+
fs.closeSync(fd);
|
|
536
|
+
}
|
|
537
|
+
} catch {
|
|
538
|
+
return true;
|
|
539
|
+
}
|
|
540
|
+
if (header.length === 0) return true;
|
|
541
|
+
if (header.subarray(0, 2).equals(Buffer.from("#!"))) return true;
|
|
542
|
+
if (isKnownBinaryExecutableHeader(header)) return false;
|
|
543
|
+
return true;
|
|
544
|
+
}
|
|
545
|
+
function unwrapArgvForMutableOperand(argv) {
|
|
546
|
+
let current = argv;
|
|
547
|
+
let baseIndex = 0;
|
|
548
|
+
let opaqueMultiplexerSeen = false;
|
|
549
|
+
while (true) {
|
|
550
|
+
const dispatchUnwrap = unwrapKnownDispatchWrapperInvocation(current);
|
|
551
|
+
if (dispatchUnwrap.kind === "unwrapped") {
|
|
552
|
+
baseIndex += current.length - dispatchUnwrap.argv.length;
|
|
553
|
+
current = dispatchUnwrap.argv;
|
|
554
|
+
continue;
|
|
555
|
+
}
|
|
556
|
+
const shellMultiplexerUnwrap = unwrapKnownShellMultiplexerInvocation(current);
|
|
557
|
+
if (shellMultiplexerUnwrap.kind === "unwrapped") {
|
|
558
|
+
if (OPAQUE_MUTABLE_SCRIPT_RUNNERS.has(shellMultiplexerUnwrap.wrapper)) opaqueMultiplexerSeen = true;
|
|
559
|
+
baseIndex += current.length - shellMultiplexerUnwrap.argv.length;
|
|
560
|
+
current = shellMultiplexerUnwrap.argv;
|
|
561
|
+
continue;
|
|
562
|
+
}
|
|
563
|
+
const packageManagerUnwrap = unwrapKnownPackageManagerExecInvocation(current);
|
|
564
|
+
if (packageManagerUnwrap) {
|
|
565
|
+
baseIndex += current.length - packageManagerUnwrap.length;
|
|
566
|
+
current = packageManagerUnwrap;
|
|
567
|
+
continue;
|
|
568
|
+
}
|
|
569
|
+
return {
|
|
570
|
+
argv: current,
|
|
571
|
+
baseIndex,
|
|
572
|
+
opaqueMultiplexerSeen
|
|
573
|
+
};
|
|
574
|
+
}
|
|
575
|
+
}
|
|
576
|
+
function unwrapKnownPackageManagerExecInvocation(argv) {
|
|
577
|
+
switch (normalizePackageManagerExecToken(argv[0] ?? "")) {
|
|
578
|
+
case "npm": return unwrapNpmExecInvocation(argv);
|
|
579
|
+
case "npx":
|
|
580
|
+
case "bunx": return unwrapDirectPackageExecInvocation(argv);
|
|
581
|
+
case "pnpm": return unwrapPnpmExecInvocation(argv);
|
|
582
|
+
default: return null;
|
|
583
|
+
}
|
|
584
|
+
}
|
|
585
|
+
function normalizePackageManagerExecToken(token) {
|
|
586
|
+
const normalized = normalizeExecutableToken(token);
|
|
587
|
+
if (!normalized) return normalized;
|
|
588
|
+
return normalized.replace(/\.(?:c|m)?js$/i, "");
|
|
589
|
+
}
|
|
590
|
+
function unwrapPnpmExecInvocation(argv) {
|
|
591
|
+
let idx = 1;
|
|
592
|
+
while (idx < argv.length) {
|
|
593
|
+
const token = readTrimmedArgToken(argv, idx);
|
|
594
|
+
if (!token) {
|
|
595
|
+
idx += 1;
|
|
596
|
+
continue;
|
|
597
|
+
}
|
|
598
|
+
if (token === "--") {
|
|
599
|
+
idx += 1;
|
|
600
|
+
continue;
|
|
601
|
+
}
|
|
602
|
+
if (!token.startsWith("-")) {
|
|
603
|
+
if (token === "exec") {
|
|
604
|
+
if (idx + 1 >= argv.length) return null;
|
|
605
|
+
const tail = argv.slice(idx + 1);
|
|
606
|
+
return tail[0] === "--" ? tail.length > 1 ? tail.slice(1) : null : tail;
|
|
607
|
+
}
|
|
608
|
+
if (token === "dlx") return unwrapPnpmDlxInvocation(argv.slice(idx + 1));
|
|
609
|
+
if (token === "node") {
|
|
610
|
+
const tail = argv.slice(idx + 1);
|
|
611
|
+
return ["node", ...tail[0] === "--" ? tail.slice(1) : tail];
|
|
612
|
+
}
|
|
613
|
+
return null;
|
|
614
|
+
}
|
|
615
|
+
const flag = normalizeOptionFlag(token);
|
|
616
|
+
if (PNPM_OPTIONS_WITH_VALUE.has(flag) || PNPM_DLX_OPTIONS_WITH_VALUE.has(flag)) {
|
|
617
|
+
idx += token.includes("=") ? 1 : 2;
|
|
618
|
+
continue;
|
|
619
|
+
}
|
|
620
|
+
if (PNPM_FLAG_OPTIONS.has(flag)) {
|
|
621
|
+
idx += 1;
|
|
622
|
+
continue;
|
|
623
|
+
}
|
|
624
|
+
return null;
|
|
625
|
+
}
|
|
626
|
+
return null;
|
|
627
|
+
}
|
|
628
|
+
function unwrapPnpmDlxInvocation(argv) {
|
|
629
|
+
let idx = 0;
|
|
630
|
+
while (idx < argv.length) {
|
|
631
|
+
const token = readTrimmedArgToken(argv, idx);
|
|
632
|
+
if (!token) {
|
|
633
|
+
idx += 1;
|
|
634
|
+
continue;
|
|
635
|
+
}
|
|
636
|
+
if (token === "--") {
|
|
637
|
+
const tail = argv.slice(idx + 1);
|
|
638
|
+
return tail.length > 0 ? tail : null;
|
|
639
|
+
}
|
|
640
|
+
if (!token.startsWith("-")) return argv.slice(idx);
|
|
641
|
+
const flag = normalizeOptionFlag(token);
|
|
642
|
+
if (flag === "-c" || flag === "--shell-mode") return null;
|
|
643
|
+
if (PNPM_OPTIONS_WITH_VALUE.has(flag) || PNPM_DLX_OPTIONS_WITH_VALUE.has(flag)) {
|
|
644
|
+
idx += token.includes("=") ? 1 : 2;
|
|
645
|
+
continue;
|
|
646
|
+
}
|
|
647
|
+
if (PNPM_FLAG_OPTIONS.has(flag)) {
|
|
648
|
+
idx += 1;
|
|
649
|
+
continue;
|
|
650
|
+
}
|
|
651
|
+
return null;
|
|
652
|
+
}
|
|
653
|
+
return null;
|
|
654
|
+
}
|
|
655
|
+
function unwrapDirectPackageExecInvocation(argv) {
|
|
656
|
+
let idx = 1;
|
|
657
|
+
while (idx < argv.length) {
|
|
658
|
+
const token = readTrimmedArgToken(argv, idx);
|
|
659
|
+
if (!token) {
|
|
660
|
+
idx += 1;
|
|
661
|
+
continue;
|
|
662
|
+
}
|
|
663
|
+
if (!token.startsWith("-")) return argv.slice(idx);
|
|
664
|
+
const flag = normalizeOptionFlag(token);
|
|
665
|
+
if (flag === "-c" || flag === "--call") return null;
|
|
666
|
+
if (NPM_EXEC_OPTIONS_WITH_VALUE.has(flag)) {
|
|
667
|
+
idx += token.includes("=") ? 1 : 2;
|
|
668
|
+
continue;
|
|
669
|
+
}
|
|
670
|
+
if (NPM_EXEC_FLAG_OPTIONS.has(flag)) {
|
|
671
|
+
idx += 1;
|
|
672
|
+
continue;
|
|
673
|
+
}
|
|
674
|
+
return null;
|
|
675
|
+
}
|
|
676
|
+
return null;
|
|
677
|
+
}
|
|
678
|
+
function unwrapNpmExecInvocation(argv) {
|
|
679
|
+
let idx = 1;
|
|
680
|
+
while (idx < argv.length) {
|
|
681
|
+
const token = readTrimmedArgToken(argv, idx);
|
|
682
|
+
if (!token) {
|
|
683
|
+
idx += 1;
|
|
684
|
+
continue;
|
|
685
|
+
}
|
|
686
|
+
if (!token.startsWith("-")) {
|
|
687
|
+
if (token !== "exec") return null;
|
|
688
|
+
idx += 1;
|
|
689
|
+
break;
|
|
690
|
+
}
|
|
691
|
+
if ((token === "-C" || token === "--prefix" || token === "--userconfig") && !token.includes("=")) {
|
|
692
|
+
idx += 2;
|
|
693
|
+
continue;
|
|
694
|
+
}
|
|
695
|
+
idx += 1;
|
|
696
|
+
}
|
|
697
|
+
if (idx >= argv.length) return null;
|
|
698
|
+
const tail = argv.slice(idx);
|
|
699
|
+
if (tail[0] === "--") return tail.length > 1 ? tail.slice(1) : null;
|
|
700
|
+
return unwrapDirectPackageExecInvocation(["npx", ...tail]);
|
|
701
|
+
}
|
|
702
|
+
function resolvePosixShellScriptOperandIndex(argv) {
|
|
703
|
+
if (resolveInlineCommandMatch(argv, POSIX_INLINE_COMMAND_FLAGS, { allowCombinedC: true }).valueTokenIndex !== null) return null;
|
|
704
|
+
let afterDoubleDash = false;
|
|
705
|
+
for (let i = 1; i < argv.length; i += 1) {
|
|
706
|
+
const token = readTrimmedArgToken(argv, i);
|
|
707
|
+
if (!token) continue;
|
|
708
|
+
if (token === "-") return null;
|
|
709
|
+
if (!afterDoubleDash && token === "--") {
|
|
710
|
+
afterDoubleDash = true;
|
|
711
|
+
continue;
|
|
712
|
+
}
|
|
713
|
+
if (!afterDoubleDash && token === "-s") return null;
|
|
714
|
+
if (!afterDoubleDash && token.startsWith("-")) {
|
|
715
|
+
const flag = normalizeOptionFlag(token);
|
|
716
|
+
if (POSIX_SHELL_OPTIONS_WITH_VALUE.has(flag)) {
|
|
717
|
+
if (!token.includes("=")) i += 1;
|
|
718
|
+
continue;
|
|
719
|
+
}
|
|
720
|
+
continue;
|
|
721
|
+
}
|
|
722
|
+
return i;
|
|
723
|
+
}
|
|
724
|
+
return null;
|
|
725
|
+
}
|
|
726
|
+
function resolveOptionFilteredFileOperandIndex(params) {
|
|
727
|
+
let afterDoubleDash = false;
|
|
728
|
+
for (let i = params.startIndex; i < params.argv.length; i += 1) {
|
|
729
|
+
const token = readTrimmedArgToken(params.argv, i);
|
|
730
|
+
if (!token) continue;
|
|
731
|
+
if (afterDoubleDash) return resolvesToExistingFileSync(token, params.cwd) ? i : null;
|
|
732
|
+
if (token === "--") {
|
|
733
|
+
afterDoubleDash = true;
|
|
734
|
+
continue;
|
|
735
|
+
}
|
|
736
|
+
if (token === "-") return null;
|
|
737
|
+
if (token.startsWith("-")) {
|
|
738
|
+
if (!token.includes("=") && params.optionsWithValue?.has(token)) i += 1;
|
|
739
|
+
continue;
|
|
740
|
+
}
|
|
741
|
+
return resolvesToExistingFileSync(token, params.cwd) ? i : null;
|
|
742
|
+
}
|
|
743
|
+
return null;
|
|
744
|
+
}
|
|
745
|
+
function resolveOptionFilteredPositionalIndex(params) {
|
|
746
|
+
let afterDoubleDash = false;
|
|
747
|
+
for (let i = params.startIndex; i < params.argv.length; i += 1) {
|
|
748
|
+
const token = readTrimmedArgToken(params.argv, i);
|
|
749
|
+
if (!token) continue;
|
|
750
|
+
if (afterDoubleDash) return i;
|
|
751
|
+
if (token === "--") {
|
|
752
|
+
afterDoubleDash = true;
|
|
753
|
+
continue;
|
|
754
|
+
}
|
|
755
|
+
if (token === "-") return null;
|
|
756
|
+
if (token.startsWith("-")) {
|
|
757
|
+
if (!token.includes("=") && params.optionsWithValue?.has(token)) i += 1;
|
|
758
|
+
continue;
|
|
759
|
+
}
|
|
760
|
+
return i;
|
|
761
|
+
}
|
|
762
|
+
return null;
|
|
763
|
+
}
|
|
764
|
+
function collectExistingFileOperandIndexes(params) {
|
|
765
|
+
let afterDoubleDash = false;
|
|
766
|
+
const hits = [];
|
|
767
|
+
for (let i = params.startIndex; i < params.argv.length; i += 1) {
|
|
768
|
+
const token = readTrimmedArgToken(params.argv, i);
|
|
769
|
+
if (!token) continue;
|
|
770
|
+
if (afterDoubleDash) {
|
|
771
|
+
if (resolvesToExistingFileSync(token, params.cwd)) hits.push(i);
|
|
772
|
+
continue;
|
|
773
|
+
}
|
|
774
|
+
if (token === "--") {
|
|
775
|
+
afterDoubleDash = true;
|
|
776
|
+
continue;
|
|
777
|
+
}
|
|
778
|
+
if (token === "-") return {
|
|
779
|
+
hits: [],
|
|
780
|
+
sawOptionValueFile: false
|
|
781
|
+
};
|
|
782
|
+
if (token.startsWith("-")) {
|
|
783
|
+
const [flag, inlineValue] = token.split("=", 2);
|
|
784
|
+
if (params.optionsWithFileValue?.has(normalizeLowercaseStringOrEmpty(flag))) {
|
|
785
|
+
if (inlineValue && resolvesToExistingFileSync(inlineValue, params.cwd)) {
|
|
786
|
+
hits.push(i);
|
|
787
|
+
return {
|
|
788
|
+
hits,
|
|
789
|
+
sawOptionValueFile: true
|
|
790
|
+
};
|
|
791
|
+
}
|
|
792
|
+
const nextToken = readTrimmedArgToken(params.argv, i + 1);
|
|
793
|
+
if (!inlineValue && nextToken && resolvesToExistingFileSync(nextToken, params.cwd)) {
|
|
794
|
+
hits.push(i + 1);
|
|
795
|
+
return {
|
|
796
|
+
hits,
|
|
797
|
+
sawOptionValueFile: true
|
|
798
|
+
};
|
|
799
|
+
}
|
|
800
|
+
}
|
|
801
|
+
continue;
|
|
802
|
+
}
|
|
803
|
+
if (resolvesToExistingFileSync(token, params.cwd)) hits.push(i);
|
|
804
|
+
}
|
|
805
|
+
return {
|
|
806
|
+
hits,
|
|
807
|
+
sawOptionValueFile: false
|
|
808
|
+
};
|
|
809
|
+
}
|
|
810
|
+
function resolveGenericInterpreterScriptOperandIndex(params) {
|
|
811
|
+
const collection = collectExistingFileOperandIndexes({
|
|
812
|
+
argv: params.argv,
|
|
813
|
+
startIndex: 1,
|
|
814
|
+
cwd: params.cwd,
|
|
815
|
+
optionsWithFileValue: params.optionsWithFileValue
|
|
816
|
+
});
|
|
817
|
+
if (collection.sawOptionValueFile) return null;
|
|
818
|
+
return collection.hits.length === 1 ? collection.hits[0] : null;
|
|
819
|
+
}
|
|
820
|
+
function resolveBunScriptOperandIndex(params) {
|
|
821
|
+
const directIndex = resolveOptionFilteredPositionalIndex({
|
|
822
|
+
argv: params.argv,
|
|
823
|
+
startIndex: 1,
|
|
824
|
+
optionsWithValue: BUN_OPTIONS_WITH_VALUE
|
|
825
|
+
});
|
|
826
|
+
if (directIndex === null) return null;
|
|
827
|
+
const directToken = readTrimmedArgToken(params.argv, directIndex);
|
|
828
|
+
if (directToken === "run") return resolveOptionFilteredFileOperandIndex({
|
|
829
|
+
argv: params.argv,
|
|
830
|
+
startIndex: directIndex + 1,
|
|
831
|
+
cwd: params.cwd,
|
|
832
|
+
optionsWithValue: BUN_OPTIONS_WITH_VALUE
|
|
833
|
+
});
|
|
834
|
+
if (BUN_SUBCOMMANDS.has(directToken)) return null;
|
|
835
|
+
if (!looksLikePathToken(directToken)) return null;
|
|
836
|
+
return directIndex;
|
|
837
|
+
}
|
|
838
|
+
function resolveDenoRunScriptOperandIndex(params) {
|
|
839
|
+
if (readTrimmedArgToken(params.argv, 1) !== "run") return null;
|
|
840
|
+
return resolveOptionFilteredFileOperandIndex({
|
|
841
|
+
argv: params.argv,
|
|
842
|
+
startIndex: 2,
|
|
843
|
+
cwd: params.cwd,
|
|
844
|
+
optionsWithValue: DENO_RUN_OPTIONS_WITH_VALUE
|
|
845
|
+
});
|
|
846
|
+
}
|
|
847
|
+
function hasRubyUnsafeApprovalFlag(argv) {
|
|
848
|
+
let afterDoubleDash = false;
|
|
849
|
+
for (let i = 1; i < argv.length; i += 1) {
|
|
850
|
+
const token = readTrimmedArgToken(argv, i);
|
|
851
|
+
if (!token) continue;
|
|
852
|
+
if (afterDoubleDash) return false;
|
|
853
|
+
if (token === "--") {
|
|
854
|
+
afterDoubleDash = true;
|
|
855
|
+
continue;
|
|
856
|
+
}
|
|
857
|
+
if (token === "-I" || token === "-r") return true;
|
|
858
|
+
if (token.startsWith("-I") || token.startsWith("-r")) return true;
|
|
859
|
+
if (RUBY_UNSAFE_APPROVAL_FLAGS.has(normalizeLowercaseStringOrEmpty(token))) return true;
|
|
860
|
+
}
|
|
861
|
+
return false;
|
|
862
|
+
}
|
|
863
|
+
function hasPerlUnsafeApprovalFlag(argv) {
|
|
864
|
+
let afterDoubleDash = false;
|
|
865
|
+
for (let i = 1; i < argv.length; i += 1) {
|
|
866
|
+
const token = readTrimmedArgToken(argv, i);
|
|
867
|
+
if (!token) continue;
|
|
868
|
+
if (afterDoubleDash) return false;
|
|
869
|
+
if (token === "--") {
|
|
870
|
+
afterDoubleDash = true;
|
|
871
|
+
continue;
|
|
872
|
+
}
|
|
873
|
+
if (token === "-I" || token === "-M" || token === "-m") return true;
|
|
874
|
+
if (token.startsWith("-I") || token.startsWith("-M") || token.startsWith("-m")) return true;
|
|
875
|
+
if (PERL_UNSAFE_APPROVAL_FLAGS.has(token)) return true;
|
|
876
|
+
}
|
|
877
|
+
return false;
|
|
878
|
+
}
|
|
879
|
+
function isMutableScriptRunner(executable) {
|
|
880
|
+
return GENERIC_MUTABLE_SCRIPT_RUNNERS.has(executable) || OPAQUE_MUTABLE_SCRIPT_RUNNERS.has(executable) || isInterpreterLikeSafeBin(executable);
|
|
881
|
+
}
|
|
882
|
+
function resolveMutableFileOperandIndex(argv, cwd) {
|
|
883
|
+
const unwrapped = unwrapArgvForMutableOperand(argv);
|
|
884
|
+
const executable = normalizeExecutableToken(unwrapped.argv[0] ?? "");
|
|
885
|
+
if (!executable) return null;
|
|
886
|
+
if (unwrapped.opaqueMultiplexerSeen || OPAQUE_MUTABLE_SCRIPT_RUNNERS.has(executable)) return null;
|
|
887
|
+
if (POSIX_SHELL_WRAPPERS.has(executable)) {
|
|
888
|
+
const shellIndex = resolvePosixShellScriptOperandIndex(unwrapped.argv);
|
|
889
|
+
return shellIndex === null ? null : unwrapped.baseIndex + shellIndex;
|
|
890
|
+
}
|
|
891
|
+
if (MUTABLE_ARGV1_INTERPRETER_PATTERNS.some((pattern) => pattern.test(executable))) {
|
|
892
|
+
const operand = readTrimmedArgToken(unwrapped.argv, 1);
|
|
893
|
+
if (operand && operand !== "-" && !operand.startsWith("-")) return unwrapped.baseIndex + 1;
|
|
894
|
+
}
|
|
895
|
+
if (executable === "bun") {
|
|
896
|
+
const bunIndex = resolveBunScriptOperandIndex({
|
|
897
|
+
argv: unwrapped.argv,
|
|
898
|
+
cwd
|
|
899
|
+
});
|
|
900
|
+
if (bunIndex !== null) return unwrapped.baseIndex + bunIndex;
|
|
901
|
+
}
|
|
902
|
+
if (executable === "deno") {
|
|
903
|
+
const denoIndex = resolveDenoRunScriptOperandIndex({
|
|
904
|
+
argv: unwrapped.argv,
|
|
905
|
+
cwd
|
|
906
|
+
});
|
|
907
|
+
if (denoIndex !== null) return unwrapped.baseIndex + denoIndex;
|
|
908
|
+
}
|
|
909
|
+
if (executable === "ruby" && hasRubyUnsafeApprovalFlag(unwrapped.argv)) return null;
|
|
910
|
+
if (executable === "perl" && hasPerlUnsafeApprovalFlag(unwrapped.argv)) return null;
|
|
911
|
+
if (!isMutableScriptRunner(executable)) return null;
|
|
912
|
+
const genericIndex = resolveGenericInterpreterScriptOperandIndex({
|
|
913
|
+
argv: unwrapped.argv,
|
|
914
|
+
cwd,
|
|
915
|
+
optionsWithFileValue: executable === "node" || executable === "nodejs" ? NODE_OPTIONS_WITH_FILE_VALUE : void 0
|
|
916
|
+
});
|
|
917
|
+
return genericIndex === null ? null : unwrapped.baseIndex + genericIndex;
|
|
918
|
+
}
|
|
919
|
+
function shellPayloadNeedsStableBinding(shellCommand, cwd) {
|
|
920
|
+
const argv = splitShellArgs(shellCommand);
|
|
921
|
+
if (!argv || argv.length === 0) return false;
|
|
922
|
+
const snapshot = resolveMutableFileOperandSnapshotSync({
|
|
923
|
+
argv,
|
|
924
|
+
cwd,
|
|
925
|
+
shellCommand: null
|
|
926
|
+
});
|
|
927
|
+
if (!snapshot.ok) return true;
|
|
928
|
+
if (snapshot.snapshot) return true;
|
|
929
|
+
const firstToken = readTrimmedArgToken(argv, 0);
|
|
930
|
+
if (!resolvesToExistingFileSync(firstToken, cwd)) return false;
|
|
931
|
+
if (!path.isAbsolute(firstToken)) return true;
|
|
932
|
+
const resolvedPath = path.resolve(cwd ?? process.cwd(), firstToken);
|
|
933
|
+
if (pathLooksMutableForShellPayloadSync(resolvedPath)) return true;
|
|
934
|
+
return isLikelyScriptLikePathSync(resolvedPath);
|
|
935
|
+
}
|
|
936
|
+
function requiresStableInterpreterApprovalBindingWithShellCommand(params) {
|
|
937
|
+
const unwrapped = unwrapArgvForMutableOperand(params.argv);
|
|
938
|
+
if (unwrapped.opaqueMultiplexerSeen) return true;
|
|
939
|
+
if (params.shellCommand !== null) return shellPayloadNeedsStableBinding(params.shellCommand, params.cwd);
|
|
940
|
+
if (pnpmDlxInvocationNeedsFailClosedBinding(params.argv, params.cwd)) return true;
|
|
941
|
+
const executable = normalizeExecutableToken(unwrapped.argv[0] ?? "");
|
|
942
|
+
if (!executable) return false;
|
|
943
|
+
if (POSIX_SHELL_WRAPPERS.has(executable)) return false;
|
|
944
|
+
return isMutableScriptRunner(executable);
|
|
945
|
+
}
|
|
946
|
+
function pnpmDlxInvocationNeedsFailClosedBinding(argv, cwd) {
|
|
947
|
+
if (normalizePackageManagerExecToken(argv[0] ?? "") !== "pnpm") return false;
|
|
948
|
+
let idx = 1;
|
|
949
|
+
while (idx < argv.length) {
|
|
950
|
+
const token = readTrimmedArgToken(argv, idx);
|
|
951
|
+
if (!token) {
|
|
952
|
+
idx += 1;
|
|
953
|
+
continue;
|
|
954
|
+
}
|
|
955
|
+
if (token === "--") {
|
|
956
|
+
idx += 1;
|
|
957
|
+
continue;
|
|
958
|
+
}
|
|
959
|
+
if (!token.startsWith("-")) {
|
|
960
|
+
if (token !== "dlx") return false;
|
|
961
|
+
return pnpmDlxTailNeedsFailClosedBinding(argv.slice(idx + 1), cwd);
|
|
962
|
+
}
|
|
963
|
+
const flag = normalizeOptionFlag(token);
|
|
964
|
+
if (PNPM_OPTIONS_WITH_VALUE.has(flag) || PNPM_DLX_OPTIONS_WITH_VALUE.has(flag)) {
|
|
965
|
+
idx += token.includes("=") ? 1 : 2;
|
|
966
|
+
continue;
|
|
967
|
+
}
|
|
968
|
+
if (PNPM_FLAG_OPTIONS.has(flag)) {
|
|
969
|
+
idx += 1;
|
|
970
|
+
continue;
|
|
971
|
+
}
|
|
972
|
+
return true;
|
|
973
|
+
}
|
|
974
|
+
return false;
|
|
975
|
+
}
|
|
976
|
+
function pnpmDlxTailNeedsFailClosedBinding(argv, cwd) {
|
|
977
|
+
let idx = 0;
|
|
978
|
+
while (idx < argv.length) {
|
|
979
|
+
const token = readTrimmedArgToken(argv, idx);
|
|
980
|
+
if (!token) {
|
|
981
|
+
idx += 1;
|
|
982
|
+
continue;
|
|
983
|
+
}
|
|
984
|
+
if (token === "--") return pnpmDlxTailMayNeedStableBinding(argv.slice(idx + 1), cwd);
|
|
985
|
+
if (!token.startsWith("-")) return pnpmDlxTailMayNeedStableBinding(argv.slice(idx), cwd);
|
|
986
|
+
const flag = normalizeOptionFlag(token);
|
|
987
|
+
if (flag === "-c" || flag === "--shell-mode") return false;
|
|
988
|
+
if (PNPM_OPTIONS_WITH_VALUE.has(flag) || PNPM_DLX_OPTIONS_WITH_VALUE.has(flag)) {
|
|
989
|
+
idx += token.includes("=") ? 1 : 2;
|
|
990
|
+
continue;
|
|
991
|
+
}
|
|
992
|
+
if (PNPM_FLAG_OPTIONS.has(flag)) {
|
|
993
|
+
idx += 1;
|
|
994
|
+
continue;
|
|
995
|
+
}
|
|
996
|
+
return true;
|
|
997
|
+
}
|
|
998
|
+
return true;
|
|
999
|
+
}
|
|
1000
|
+
function pnpmDlxTailMayNeedStableBinding(argv, cwd) {
|
|
1001
|
+
const snapshot = resolveMutableFileOperandSnapshotSync({
|
|
1002
|
+
argv,
|
|
1003
|
+
cwd,
|
|
1004
|
+
shellCommand: null
|
|
1005
|
+
});
|
|
1006
|
+
return snapshot.ok && snapshot.snapshot !== null;
|
|
1007
|
+
}
|
|
1008
|
+
function resolveMutableFileOperandSnapshotSync(params) {
|
|
1009
|
+
const argvIndex = resolveMutableFileOperandIndex(params.argv, params.cwd);
|
|
1010
|
+
if (argvIndex === null) {
|
|
1011
|
+
if (requiresStableInterpreterApprovalBindingWithShellCommand({
|
|
1012
|
+
argv: params.argv,
|
|
1013
|
+
shellCommand: params.shellCommand,
|
|
1014
|
+
cwd: params.cwd
|
|
1015
|
+
})) return {
|
|
1016
|
+
ok: false,
|
|
1017
|
+
message: "SYSTEM_RUN_DENIED: approval cannot safely bind this interpreter/runtime command"
|
|
1018
|
+
};
|
|
1019
|
+
return {
|
|
1020
|
+
ok: true,
|
|
1021
|
+
snapshot: null
|
|
1022
|
+
};
|
|
1023
|
+
}
|
|
1024
|
+
const rawOperand = readTrimmedArgToken(params.argv, argvIndex);
|
|
1025
|
+
if (!rawOperand) return {
|
|
1026
|
+
ok: false,
|
|
1027
|
+
message: "SYSTEM_RUN_DENIED: approval requires a stable script operand"
|
|
1028
|
+
};
|
|
1029
|
+
const resolvedPath = path.resolve(params.cwd ?? process.cwd(), rawOperand);
|
|
1030
|
+
let realPath;
|
|
1031
|
+
let stat;
|
|
1032
|
+
try {
|
|
1033
|
+
realPath = fs.realpathSync(resolvedPath);
|
|
1034
|
+
stat = fs.statSync(realPath);
|
|
1035
|
+
} catch {
|
|
1036
|
+
return {
|
|
1037
|
+
ok: false,
|
|
1038
|
+
message: "SYSTEM_RUN_DENIED: approval requires an existing script operand"
|
|
1039
|
+
};
|
|
1040
|
+
}
|
|
1041
|
+
if (!stat.isFile()) return {
|
|
1042
|
+
ok: false,
|
|
1043
|
+
message: "SYSTEM_RUN_DENIED: approval requires a file script operand"
|
|
1044
|
+
};
|
|
1045
|
+
return {
|
|
1046
|
+
ok: true,
|
|
1047
|
+
snapshot: {
|
|
1048
|
+
argvIndex,
|
|
1049
|
+
path: realPath,
|
|
1050
|
+
sha256: hashFileContentsSync(realPath)
|
|
1051
|
+
}
|
|
1052
|
+
};
|
|
1053
|
+
}
|
|
1054
|
+
function resolveCanonicalApprovalCwdSync(cwd) {
|
|
1055
|
+
const requestedCwd = path.resolve(cwd);
|
|
1056
|
+
let cwdLstat;
|
|
1057
|
+
let cwdStat;
|
|
1058
|
+
let cwdReal;
|
|
1059
|
+
let cwdRealStat;
|
|
1060
|
+
try {
|
|
1061
|
+
cwdLstat = fs.lstatSync(requestedCwd);
|
|
1062
|
+
cwdStat = fs.statSync(requestedCwd);
|
|
1063
|
+
cwdReal = fs.realpathSync(requestedCwd);
|
|
1064
|
+
cwdRealStat = fs.statSync(cwdReal);
|
|
1065
|
+
} catch {
|
|
1066
|
+
return {
|
|
1067
|
+
ok: false,
|
|
1068
|
+
message: "SYSTEM_RUN_DENIED: approval requires an existing canonical cwd"
|
|
1069
|
+
};
|
|
1070
|
+
}
|
|
1071
|
+
if (!cwdStat.isDirectory()) return {
|
|
1072
|
+
ok: false,
|
|
1073
|
+
message: "SYSTEM_RUN_DENIED: approval requires cwd to be a directory"
|
|
1074
|
+
};
|
|
1075
|
+
if (hasMutableSymlinkPathComponentSync(requestedCwd)) return {
|
|
1076
|
+
ok: false,
|
|
1077
|
+
message: "SYSTEM_RUN_DENIED: approval requires canonical cwd (no symlink path components)"
|
|
1078
|
+
};
|
|
1079
|
+
if (cwdLstat.isSymbolicLink()) return {
|
|
1080
|
+
ok: false,
|
|
1081
|
+
message: "SYSTEM_RUN_DENIED: approval requires canonical cwd (no symlink cwd)"
|
|
1082
|
+
};
|
|
1083
|
+
if (!sameFileIdentity(cwdStat, cwdLstat) || !sameFileIdentity(cwdStat, cwdRealStat) || !sameFileIdentity(cwdLstat, cwdRealStat)) return {
|
|
1084
|
+
ok: false,
|
|
1085
|
+
message: "SYSTEM_RUN_DENIED: approval cwd identity mismatch"
|
|
1086
|
+
};
|
|
1087
|
+
return {
|
|
1088
|
+
ok: true,
|
|
1089
|
+
snapshot: {
|
|
1090
|
+
cwd: cwdReal,
|
|
1091
|
+
stat: cwdStat
|
|
1092
|
+
}
|
|
1093
|
+
};
|
|
1094
|
+
}
|
|
1095
|
+
function revalidateApprovedCwdSnapshot(params) {
|
|
1096
|
+
const current = resolveCanonicalApprovalCwdSync(params.snapshot.cwd);
|
|
1097
|
+
if (!current.ok) return false;
|
|
1098
|
+
return sameFileIdentity(params.snapshot.stat, current.snapshot.stat);
|
|
1099
|
+
}
|
|
1100
|
+
function revalidateApprovedMutableFileOperand(params) {
|
|
1101
|
+
const operand = params.argv[params.snapshot.argvIndex]?.trim();
|
|
1102
|
+
if (!operand) return false;
|
|
1103
|
+
const resolvedPath = path.resolve(params.cwd ?? process.cwd(), operand);
|
|
1104
|
+
let realPath;
|
|
1105
|
+
try {
|
|
1106
|
+
realPath = fs.realpathSync(resolvedPath);
|
|
1107
|
+
} catch {
|
|
1108
|
+
return false;
|
|
1109
|
+
}
|
|
1110
|
+
if (realPath !== params.snapshot.path) return false;
|
|
1111
|
+
try {
|
|
1112
|
+
return hashFileContentsSync(realPath) === params.snapshot.sha256;
|
|
1113
|
+
} catch {
|
|
1114
|
+
return false;
|
|
1115
|
+
}
|
|
1116
|
+
}
|
|
1117
|
+
function hardenApprovedExecutionPaths(params) {
|
|
1118
|
+
if (!params.approvedByAsk) return {
|
|
1119
|
+
ok: true,
|
|
1120
|
+
argv: params.argv,
|
|
1121
|
+
argvChanged: false,
|
|
1122
|
+
cwd: params.cwd,
|
|
1123
|
+
approvedCwdSnapshot: void 0
|
|
1124
|
+
};
|
|
1125
|
+
let hardenedCwd = params.cwd;
|
|
1126
|
+
let approvedCwdSnapshot;
|
|
1127
|
+
if (hardenedCwd) {
|
|
1128
|
+
const canonicalCwd = resolveCanonicalApprovalCwdSync(hardenedCwd);
|
|
1129
|
+
if (!canonicalCwd.ok) return canonicalCwd;
|
|
1130
|
+
hardenedCwd = canonicalCwd.snapshot.cwd;
|
|
1131
|
+
approvedCwdSnapshot = canonicalCwd.snapshot;
|
|
1132
|
+
}
|
|
1133
|
+
if (params.argv.length === 0) return {
|
|
1134
|
+
ok: true,
|
|
1135
|
+
argv: params.argv,
|
|
1136
|
+
argvChanged: false,
|
|
1137
|
+
cwd: hardenedCwd,
|
|
1138
|
+
approvedCwdSnapshot
|
|
1139
|
+
};
|
|
1140
|
+
const resolution = resolveCommandResolutionFromArgv(params.argv, hardenedCwd);
|
|
1141
|
+
if (!shouldPinExecutableForApproval({
|
|
1142
|
+
shellCommand: params.shellCommand,
|
|
1143
|
+
wrapperChain: resolution?.wrapperChain
|
|
1144
|
+
})) return {
|
|
1145
|
+
ok: true,
|
|
1146
|
+
argv: params.argv,
|
|
1147
|
+
argvChanged: false,
|
|
1148
|
+
cwd: hardenedCwd,
|
|
1149
|
+
approvedCwdSnapshot
|
|
1150
|
+
};
|
|
1151
|
+
const pinnedExecutable = resolution?.execution.resolvedRealPath ?? resolution?.execution.resolvedPath;
|
|
1152
|
+
if (!pinnedExecutable) return {
|
|
1153
|
+
ok: false,
|
|
1154
|
+
message: "SYSTEM_RUN_DENIED: approval requires a stable executable path"
|
|
1155
|
+
};
|
|
1156
|
+
if (pinnedExecutable === params.argv[0]) return {
|
|
1157
|
+
ok: true,
|
|
1158
|
+
argv: params.argv,
|
|
1159
|
+
argvChanged: false,
|
|
1160
|
+
cwd: hardenedCwd,
|
|
1161
|
+
approvedCwdSnapshot
|
|
1162
|
+
};
|
|
1163
|
+
const argv = [...params.argv];
|
|
1164
|
+
argv[0] = pinnedExecutable;
|
|
1165
|
+
return {
|
|
1166
|
+
ok: true,
|
|
1167
|
+
argv,
|
|
1168
|
+
argvChanged: true,
|
|
1169
|
+
cwd: hardenedCwd,
|
|
1170
|
+
approvedCwdSnapshot
|
|
1171
|
+
};
|
|
1172
|
+
}
|
|
1173
|
+
function buildSystemRunApprovalPlan(params) {
|
|
1174
|
+
const command = resolveSystemRunCommandRequest({
|
|
1175
|
+
command: params.command,
|
|
1176
|
+
rawCommand: params.rawCommand
|
|
1177
|
+
});
|
|
1178
|
+
if (!command.ok) return {
|
|
1179
|
+
ok: false,
|
|
1180
|
+
message: command.message
|
|
1181
|
+
};
|
|
1182
|
+
if (command.argv.length === 0) return {
|
|
1183
|
+
ok: false,
|
|
1184
|
+
message: "command required"
|
|
1185
|
+
};
|
|
1186
|
+
const hardening = hardenApprovedExecutionPaths({
|
|
1187
|
+
approvedByAsk: true,
|
|
1188
|
+
argv: command.argv,
|
|
1189
|
+
shellCommand: command.shellPayload,
|
|
1190
|
+
cwd: normalizeNullableString(params.cwd) ?? void 0
|
|
1191
|
+
});
|
|
1192
|
+
if (!hardening.ok) return {
|
|
1193
|
+
ok: false,
|
|
1194
|
+
message: hardening.message
|
|
1195
|
+
};
|
|
1196
|
+
const commandText = formatExecCommand(hardening.argv);
|
|
1197
|
+
const commandPreview = command.previewText?.trim() && command.previewText.trim() !== commandText ? command.previewText.trim() : null;
|
|
1198
|
+
const mutableFileOperand = resolveMutableFileOperandSnapshotSync({
|
|
1199
|
+
argv: hardening.argv,
|
|
1200
|
+
cwd: hardening.cwd,
|
|
1201
|
+
shellCommand: command.shellPayload
|
|
1202
|
+
});
|
|
1203
|
+
if (!mutableFileOperand.ok) return {
|
|
1204
|
+
ok: false,
|
|
1205
|
+
message: mutableFileOperand.message
|
|
1206
|
+
};
|
|
1207
|
+
return {
|
|
1208
|
+
ok: true,
|
|
1209
|
+
plan: {
|
|
1210
|
+
argv: hardening.argv,
|
|
1211
|
+
cwd: hardening.cwd ?? null,
|
|
1212
|
+
commandText,
|
|
1213
|
+
commandPreview,
|
|
1214
|
+
agentId: normalizeNullableString(params.agentId),
|
|
1215
|
+
sessionKey: normalizeNullableString(params.sessionKey),
|
|
1216
|
+
mutableFileOperand: mutableFileOperand.snapshot ?? void 0
|
|
1217
|
+
}
|
|
1218
|
+
};
|
|
1219
|
+
}
|
|
1220
|
+
//#endregion
|
|
1221
|
+
//#region src/node-host/invoke-system-run.ts
|
|
1222
|
+
const safeBinTrustedDirWarningCache = /* @__PURE__ */ new Set();
|
|
1223
|
+
const APPROVAL_CWD_DRIFT_DENIED_MESSAGE = "SYSTEM_RUN_DENIED: approval cwd changed before execution";
|
|
1224
|
+
const APPROVAL_SCRIPT_OPERAND_BINDING_DENIED_MESSAGE = "SYSTEM_RUN_DENIED: approval missing script operand binding";
|
|
1225
|
+
const APPROVAL_SCRIPT_OPERAND_DRIFT_DENIED_MESSAGE = "SYSTEM_RUN_DENIED: approval script operand changed before execution";
|
|
1226
|
+
function warnWritableTrustedDirOnce(message) {
|
|
1227
|
+
if (safeBinTrustedDirWarningCache.has(message)) return;
|
|
1228
|
+
safeBinTrustedDirWarningCache.add(message);
|
|
1229
|
+
logWarn(message);
|
|
1230
|
+
}
|
|
1231
|
+
function normalizeDeniedReason(reason) {
|
|
1232
|
+
switch (reason) {
|
|
1233
|
+
case "security=deny":
|
|
1234
|
+
case "approval-required":
|
|
1235
|
+
case "allowlist-miss":
|
|
1236
|
+
case "execution-plan-miss":
|
|
1237
|
+
case "companion-unavailable":
|
|
1238
|
+
case "permission:screenRecording": return reason;
|
|
1239
|
+
default: return "approval-required";
|
|
1240
|
+
}
|
|
1241
|
+
}
|
|
1242
|
+
function resolveAgentExecConfig(cfg, agentId) {
|
|
1243
|
+
if (!agentId) return;
|
|
1244
|
+
const normalizedAgentId = normalizeAgentId(agentId);
|
|
1245
|
+
return (cfg.agents?.list?.find((candidate) => candidate !== null && typeof candidate === "object" && normalizeAgentId(candidate.id) === normalizedAgentId))?.tools?.exec;
|
|
1246
|
+
}
|
|
1247
|
+
async function loadSystemRunConfig(opts) {
|
|
1248
|
+
if (opts.loadConfig) return opts.loadConfig();
|
|
1249
|
+
const { loadConfig } = await import("./config-D1ooXKCx.js");
|
|
1250
|
+
return loadConfig();
|
|
1251
|
+
}
|
|
1252
|
+
async function sendSystemRunDenied(opts, execution, params) {
|
|
1253
|
+
await opts.sendNodeEvent(opts.client, "exec.denied", opts.buildExecEventPayload({
|
|
1254
|
+
sessionKey: execution.sessionKey,
|
|
1255
|
+
runId: execution.runId,
|
|
1256
|
+
host: "node",
|
|
1257
|
+
command: execution.commandText,
|
|
1258
|
+
reason: params.reason,
|
|
1259
|
+
suppressNotifyOnExit: execution.suppressNotifyOnExit
|
|
1260
|
+
}));
|
|
1261
|
+
await opts.sendInvokeResult({
|
|
1262
|
+
ok: false,
|
|
1263
|
+
error: {
|
|
1264
|
+
code: "UNAVAILABLE",
|
|
1265
|
+
message: params.message
|
|
1266
|
+
}
|
|
1267
|
+
});
|
|
1268
|
+
}
|
|
1269
|
+
async function sendSystemRunCompleted(opts, execution, result, payloadJSON) {
|
|
1270
|
+
await opts.sendExecFinishedEvent({
|
|
1271
|
+
sessionKey: execution.sessionKey,
|
|
1272
|
+
runId: execution.runId,
|
|
1273
|
+
commandText: execution.commandText,
|
|
1274
|
+
result,
|
|
1275
|
+
suppressNotifyOnExit: execution.suppressNotifyOnExit
|
|
1276
|
+
});
|
|
1277
|
+
await opts.sendInvokeResult({
|
|
1278
|
+
ok: true,
|
|
1279
|
+
payloadJSON
|
|
1280
|
+
});
|
|
1281
|
+
}
|
|
1282
|
+
async function parseSystemRunPhase(opts) {
|
|
1283
|
+
const command = resolveSystemRunCommandRequest({
|
|
1284
|
+
command: opts.params.command,
|
|
1285
|
+
rawCommand: opts.params.rawCommand
|
|
1286
|
+
});
|
|
1287
|
+
if (!command.ok) {
|
|
1288
|
+
await opts.sendInvokeResult({
|
|
1289
|
+
ok: false,
|
|
1290
|
+
error: {
|
|
1291
|
+
code: "INVALID_REQUEST",
|
|
1292
|
+
message: command.message
|
|
1293
|
+
}
|
|
1294
|
+
});
|
|
1295
|
+
return null;
|
|
1296
|
+
}
|
|
1297
|
+
if (command.argv.length === 0) {
|
|
1298
|
+
await opts.sendInvokeResult({
|
|
1299
|
+
ok: false,
|
|
1300
|
+
error: {
|
|
1301
|
+
code: "INVALID_REQUEST",
|
|
1302
|
+
message: "command required"
|
|
1303
|
+
}
|
|
1304
|
+
});
|
|
1305
|
+
return null;
|
|
1306
|
+
}
|
|
1307
|
+
const shellPayload = command.shellPayload;
|
|
1308
|
+
const shellWrapperInvocation = isShellWrapperInvocation(command.argv);
|
|
1309
|
+
const commandText = command.commandText;
|
|
1310
|
+
const approvalPlan = opts.params.systemRunPlan === void 0 ? null : normalizeSystemRunApprovalPlan(opts.params.systemRunPlan);
|
|
1311
|
+
if (opts.params.systemRunPlan !== void 0 && !approvalPlan) {
|
|
1312
|
+
await opts.sendInvokeResult({
|
|
1313
|
+
ok: false,
|
|
1314
|
+
error: {
|
|
1315
|
+
code: "INVALID_REQUEST",
|
|
1316
|
+
message: "systemRunPlan invalid"
|
|
1317
|
+
}
|
|
1318
|
+
});
|
|
1319
|
+
return null;
|
|
1320
|
+
}
|
|
1321
|
+
const agentId = normalizeOptionalString(opts.params.agentId);
|
|
1322
|
+
const sessionKey = normalizeOptionalString(opts.params.sessionKey) ?? "node";
|
|
1323
|
+
const runId = normalizeOptionalString(opts.params.runId) ?? crypto.randomUUID();
|
|
1324
|
+
const suppressNotifyOnExit = opts.params.suppressNotifyOnExit === true;
|
|
1325
|
+
const envAssignmentKeys = extractEnvAssignmentKeysFromDispatchWrappers(command.argv);
|
|
1326
|
+
const envAssignmentDiagnostics = inspectHostExecEnvOverrides({
|
|
1327
|
+
overrides: envAssignmentKeys.length > 0 ? Object.fromEntries(envAssignmentKeys.map((key) => [key, "1"])) : void 0,
|
|
1328
|
+
blockPathOverrides: true
|
|
1329
|
+
});
|
|
1330
|
+
if (envAssignmentDiagnostics.rejectedOverrideBlockedKeys.length > 0) {
|
|
1331
|
+
await opts.sendInvokeResult({
|
|
1332
|
+
ok: false,
|
|
1333
|
+
error: {
|
|
1334
|
+
code: "INVALID_REQUEST",
|
|
1335
|
+
message: `SYSTEM_RUN_DENIED: command env assignment rejected (blocked env assignment keys: ${envAssignmentDiagnostics.rejectedOverrideBlockedKeys.join(", ")})`
|
|
1336
|
+
}
|
|
1337
|
+
});
|
|
1338
|
+
return null;
|
|
1339
|
+
}
|
|
1340
|
+
const envOverrideDiagnostics = inspectHostExecEnvOverrides({
|
|
1341
|
+
overrides: opts.params.env ?? void 0,
|
|
1342
|
+
blockPathOverrides: true
|
|
1343
|
+
});
|
|
1344
|
+
if (envOverrideDiagnostics.rejectedOverrideBlockedKeys.length > 0 || envOverrideDiagnostics.rejectedOverrideInvalidKeys.length > 0) {
|
|
1345
|
+
const details = [];
|
|
1346
|
+
if (envOverrideDiagnostics.rejectedOverrideBlockedKeys.length > 0) details.push(`blocked override keys: ${envOverrideDiagnostics.rejectedOverrideBlockedKeys.join(", ")}`);
|
|
1347
|
+
if (envOverrideDiagnostics.rejectedOverrideInvalidKeys.length > 0) details.push(`invalid non-portable override keys: ${envOverrideDiagnostics.rejectedOverrideInvalidKeys.join(", ")}`);
|
|
1348
|
+
await opts.sendInvokeResult({
|
|
1349
|
+
ok: false,
|
|
1350
|
+
error: {
|
|
1351
|
+
code: "INVALID_REQUEST",
|
|
1352
|
+
message: `SYSTEM_RUN_DENIED: environment override rejected (${details.join("; ")})`
|
|
1353
|
+
}
|
|
1354
|
+
});
|
|
1355
|
+
return null;
|
|
1356
|
+
}
|
|
1357
|
+
const envOverrides = sanitizeSystemRunEnvOverrides({
|
|
1358
|
+
overrides: opts.params.env ?? void 0,
|
|
1359
|
+
shellWrapper: shellWrapperInvocation
|
|
1360
|
+
});
|
|
1361
|
+
return {
|
|
1362
|
+
argv: command.argv,
|
|
1363
|
+
shellPayload,
|
|
1364
|
+
shellWrapperInvocation,
|
|
1365
|
+
commandText,
|
|
1366
|
+
commandPreview: command.previewText,
|
|
1367
|
+
approvalPlan,
|
|
1368
|
+
agentId,
|
|
1369
|
+
sessionKey,
|
|
1370
|
+
runId,
|
|
1371
|
+
execution: {
|
|
1372
|
+
sessionKey,
|
|
1373
|
+
runId,
|
|
1374
|
+
commandText,
|
|
1375
|
+
suppressNotifyOnExit
|
|
1376
|
+
},
|
|
1377
|
+
approvalDecision: resolveExecApprovalDecision(opts.params.approvalDecision),
|
|
1378
|
+
envOverrides,
|
|
1379
|
+
env: opts.sanitizeEnv(envOverrides),
|
|
1380
|
+
cwd: normalizeOptionalString(opts.params.cwd),
|
|
1381
|
+
timeoutMs: opts.params.timeoutMs ?? void 0,
|
|
1382
|
+
needsScreenRecording: opts.params.needsScreenRecording === true,
|
|
1383
|
+
approved: opts.params.approved === true,
|
|
1384
|
+
suppressNotifyOnExit
|
|
1385
|
+
};
|
|
1386
|
+
}
|
|
1387
|
+
async function evaluateSystemRunPolicyPhase(opts, parsed) {
|
|
1388
|
+
const cfg = await loadSystemRunConfig(opts);
|
|
1389
|
+
const agentExec = resolveAgentExecConfig(cfg, parsed.agentId);
|
|
1390
|
+
const configuredSecurity = opts.resolveExecSecurity(agentExec?.security ?? cfg.tools?.exec?.security);
|
|
1391
|
+
const configuredAsk = opts.resolveExecAsk(agentExec?.ask ?? cfg.tools?.exec?.ask);
|
|
1392
|
+
const approvals = resolveExecApprovals(parsed.agentId, {
|
|
1393
|
+
security: configuredSecurity,
|
|
1394
|
+
ask: configuredAsk
|
|
1395
|
+
});
|
|
1396
|
+
const security = approvals.agent.security;
|
|
1397
|
+
const ask = approvals.agent.ask;
|
|
1398
|
+
const autoAllowSkills = approvals.agent.autoAllowSkills;
|
|
1399
|
+
const { safeBins, safeBinProfiles, trustedSafeBinDirs } = resolveExecSafeBinRuntimePolicy({
|
|
1400
|
+
global: cfg.tools?.exec,
|
|
1401
|
+
local: agentExec,
|
|
1402
|
+
onWarning: warnWritableTrustedDirOnce
|
|
1403
|
+
});
|
|
1404
|
+
const bins = autoAllowSkills ? await opts.skillBins.current() : [];
|
|
1405
|
+
let { analysisOk, allowlistMatches, allowlistSatisfied, segments, segmentAllowlistEntries } = evaluateSystemRunAllowlist({
|
|
1406
|
+
shellCommand: parsed.shellPayload,
|
|
1407
|
+
argv: parsed.argv,
|
|
1408
|
+
approvals,
|
|
1409
|
+
security,
|
|
1410
|
+
safeBins,
|
|
1411
|
+
safeBinProfiles,
|
|
1412
|
+
trustedSafeBinDirs,
|
|
1413
|
+
cwd: parsed.cwd,
|
|
1414
|
+
env: parsed.env,
|
|
1415
|
+
skillBins: bins,
|
|
1416
|
+
autoAllowSkills
|
|
1417
|
+
});
|
|
1418
|
+
const strictInlineEval = agentExec?.strictInlineEval === true || cfg.tools?.exec?.strictInlineEval === true;
|
|
1419
|
+
const inlineEvalHit = strictInlineEval ? segments.map((segment) => detectInterpreterInlineEvalArgv(segment.resolution?.effectiveArgv ?? segment.argv)).find((entry) => entry !== null) ?? null : null;
|
|
1420
|
+
const isWindows = process.platform === "win32";
|
|
1421
|
+
const cmdDetectionArgv = resolveShellWrapperTransportArgv(parsed.argv) ?? parsed.argv;
|
|
1422
|
+
const cmdInvocation = opts.isCmdExeInvocation(cmdDetectionArgv);
|
|
1423
|
+
const durableApprovalSatisfied = hasDurableExecApproval({
|
|
1424
|
+
analysisOk,
|
|
1425
|
+
segmentAllowlistEntries,
|
|
1426
|
+
allowlist: approvals.allowlist,
|
|
1427
|
+
commandText: parsed.commandText
|
|
1428
|
+
});
|
|
1429
|
+
const inlineEvalExecutableTrusted = inlineEvalHit !== null && segmentAllowlistEntries.some((entry) => entry?.source === "allow-always");
|
|
1430
|
+
const policy = evaluateSystemRunPolicy({
|
|
1431
|
+
security,
|
|
1432
|
+
ask,
|
|
1433
|
+
analysisOk,
|
|
1434
|
+
allowlistSatisfied,
|
|
1435
|
+
durableApprovalSatisfied: durableApprovalSatisfied || inlineEvalExecutableTrusted,
|
|
1436
|
+
approvalDecision: parsed.approvalDecision,
|
|
1437
|
+
approved: parsed.approved,
|
|
1438
|
+
isWindows,
|
|
1439
|
+
cmdInvocation,
|
|
1440
|
+
shellWrapperInvocation: parsed.shellPayload !== null
|
|
1441
|
+
});
|
|
1442
|
+
analysisOk = policy.analysisOk;
|
|
1443
|
+
allowlistSatisfied = policy.allowlistSatisfied;
|
|
1444
|
+
if (inlineEvalHit !== null && !policy.approvedByAsk && (policy.allowed ? true : policy.eventReason !== "security=deny")) {
|
|
1445
|
+
await sendSystemRunDenied(opts, parsed.execution, {
|
|
1446
|
+
reason: "approval-required",
|
|
1447
|
+
message: `SYSTEM_RUN_DENIED: approval required (${describeInterpreterInlineEval(inlineEvalHit)} requires explicit approval in strictInlineEval mode)`
|
|
1448
|
+
});
|
|
1449
|
+
return null;
|
|
1450
|
+
}
|
|
1451
|
+
if (!policy.allowed) {
|
|
1452
|
+
await sendSystemRunDenied(opts, parsed.execution, {
|
|
1453
|
+
reason: policy.eventReason,
|
|
1454
|
+
message: policy.errorMessage
|
|
1455
|
+
});
|
|
1456
|
+
return null;
|
|
1457
|
+
}
|
|
1458
|
+
if (policy.shellWrapperBlocked && !policy.approvedByAsk && !durableApprovalSatisfied) {
|
|
1459
|
+
await sendSystemRunDenied(opts, parsed.execution, {
|
|
1460
|
+
reason: "approval-required",
|
|
1461
|
+
message: "SYSTEM_RUN_DENIED: approval required"
|
|
1462
|
+
});
|
|
1463
|
+
return null;
|
|
1464
|
+
}
|
|
1465
|
+
const hardenedPaths = hardenApprovedExecutionPaths({
|
|
1466
|
+
approvedByAsk: policy.approvedByAsk,
|
|
1467
|
+
argv: parsed.argv,
|
|
1468
|
+
shellCommand: parsed.shellPayload,
|
|
1469
|
+
cwd: parsed.cwd
|
|
1470
|
+
});
|
|
1471
|
+
if (!hardenedPaths.ok) {
|
|
1472
|
+
await sendSystemRunDenied(opts, parsed.execution, {
|
|
1473
|
+
reason: "approval-required",
|
|
1474
|
+
message: hardenedPaths.message
|
|
1475
|
+
});
|
|
1476
|
+
return null;
|
|
1477
|
+
}
|
|
1478
|
+
const approvedCwdSnapshot = policy.approvedByAsk ? hardenedPaths.approvedCwdSnapshot : void 0;
|
|
1479
|
+
if (policy.approvedByAsk && hardenedPaths.cwd && !approvedCwdSnapshot) {
|
|
1480
|
+
await sendSystemRunDenied(opts, parsed.execution, {
|
|
1481
|
+
reason: "approval-required",
|
|
1482
|
+
message: APPROVAL_CWD_DRIFT_DENIED_MESSAGE
|
|
1483
|
+
});
|
|
1484
|
+
return null;
|
|
1485
|
+
}
|
|
1486
|
+
const plannedAllowlistArgv = resolvePlannedAllowlistArgv({
|
|
1487
|
+
security,
|
|
1488
|
+
shellCommand: parsed.shellPayload,
|
|
1489
|
+
policy,
|
|
1490
|
+
segments
|
|
1491
|
+
});
|
|
1492
|
+
if (plannedAllowlistArgv === null) {
|
|
1493
|
+
await sendSystemRunDenied(opts, parsed.execution, {
|
|
1494
|
+
reason: "execution-plan-miss",
|
|
1495
|
+
message: "SYSTEM_RUN_DENIED: execution plan mismatch"
|
|
1496
|
+
});
|
|
1497
|
+
return null;
|
|
1498
|
+
}
|
|
1499
|
+
return {
|
|
1500
|
+
...parsed,
|
|
1501
|
+
argv: hardenedPaths.argv,
|
|
1502
|
+
cwd: hardenedPaths.cwd,
|
|
1503
|
+
approvals,
|
|
1504
|
+
security,
|
|
1505
|
+
policy,
|
|
1506
|
+
durableApprovalSatisfied,
|
|
1507
|
+
strictInlineEval,
|
|
1508
|
+
inlineEvalHit,
|
|
1509
|
+
allowlistMatches,
|
|
1510
|
+
analysisOk,
|
|
1511
|
+
allowlistSatisfied,
|
|
1512
|
+
segments,
|
|
1513
|
+
plannedAllowlistArgv: plannedAllowlistArgv ?? void 0,
|
|
1514
|
+
isWindows,
|
|
1515
|
+
approvedCwdSnapshot
|
|
1516
|
+
};
|
|
1517
|
+
}
|
|
1518
|
+
async function executeSystemRunPhase(opts, phase) {
|
|
1519
|
+
if (phase.approvedCwdSnapshot && !revalidateApprovedCwdSnapshot({ snapshot: phase.approvedCwdSnapshot })) {
|
|
1520
|
+
logWarn(`security: system.run approval cwd drift blocked (runId=${phase.runId})`);
|
|
1521
|
+
await sendSystemRunDenied(opts, phase.execution, {
|
|
1522
|
+
reason: "approval-required",
|
|
1523
|
+
message: APPROVAL_CWD_DRIFT_DENIED_MESSAGE
|
|
1524
|
+
});
|
|
1525
|
+
return;
|
|
1526
|
+
}
|
|
1527
|
+
const expectedMutableFileOperand = phase.approvalPlan ? resolveMutableFileOperandSnapshotSync({
|
|
1528
|
+
argv: phase.argv,
|
|
1529
|
+
cwd: phase.cwd,
|
|
1530
|
+
shellCommand: phase.shellPayload
|
|
1531
|
+
}) : null;
|
|
1532
|
+
if (expectedMutableFileOperand && !expectedMutableFileOperand.ok) {
|
|
1533
|
+
logWarn(`security: system.run approval script binding blocked (runId=${phase.runId})`);
|
|
1534
|
+
await sendSystemRunDenied(opts, phase.execution, {
|
|
1535
|
+
reason: "approval-required",
|
|
1536
|
+
message: expectedMutableFileOperand.message
|
|
1537
|
+
});
|
|
1538
|
+
return;
|
|
1539
|
+
}
|
|
1540
|
+
if (expectedMutableFileOperand?.snapshot && !phase.approvalPlan?.mutableFileOperand) {
|
|
1541
|
+
logWarn(`security: system.run approval script binding missing (runId=${phase.runId})`);
|
|
1542
|
+
await sendSystemRunDenied(opts, phase.execution, {
|
|
1543
|
+
reason: "approval-required",
|
|
1544
|
+
message: APPROVAL_SCRIPT_OPERAND_BINDING_DENIED_MESSAGE
|
|
1545
|
+
});
|
|
1546
|
+
return;
|
|
1547
|
+
}
|
|
1548
|
+
if (phase.approvalPlan?.mutableFileOperand && !revalidateApprovedMutableFileOperand({
|
|
1549
|
+
snapshot: phase.approvalPlan.mutableFileOperand,
|
|
1550
|
+
argv: phase.argv,
|
|
1551
|
+
cwd: phase.cwd
|
|
1552
|
+
})) {
|
|
1553
|
+
logWarn(`security: system.run approval script drift blocked (runId=${phase.runId})`);
|
|
1554
|
+
await sendSystemRunDenied(opts, phase.execution, {
|
|
1555
|
+
reason: "approval-required",
|
|
1556
|
+
message: APPROVAL_SCRIPT_OPERAND_DRIFT_DENIED_MESSAGE
|
|
1557
|
+
});
|
|
1558
|
+
return;
|
|
1559
|
+
}
|
|
1560
|
+
if (opts.preferMacAppExecHost) {
|
|
1561
|
+
const execRequest = {
|
|
1562
|
+
command: phase.plannedAllowlistArgv ?? phase.argv,
|
|
1563
|
+
rawCommand: phase.commandText || null,
|
|
1564
|
+
cwd: phase.cwd ?? null,
|
|
1565
|
+
env: phase.envOverrides ?? null,
|
|
1566
|
+
timeoutMs: phase.timeoutMs ?? null,
|
|
1567
|
+
needsScreenRecording: phase.needsScreenRecording,
|
|
1568
|
+
agentId: phase.agentId ?? null,
|
|
1569
|
+
sessionKey: phase.sessionKey ?? null,
|
|
1570
|
+
approvalDecision: phase.approvalDecision
|
|
1571
|
+
};
|
|
1572
|
+
const response = await opts.runViaMacAppExecHost({
|
|
1573
|
+
approvals: phase.approvals,
|
|
1574
|
+
request: execRequest
|
|
1575
|
+
});
|
|
1576
|
+
if (!response) {
|
|
1577
|
+
if (opts.execHostEnforced || !opts.execHostFallbackAllowed) {
|
|
1578
|
+
await sendSystemRunDenied(opts, phase.execution, {
|
|
1579
|
+
reason: "companion-unavailable",
|
|
1580
|
+
message: "COMPANION_APP_UNAVAILABLE: macOS app exec host unreachable"
|
|
1581
|
+
});
|
|
1582
|
+
return;
|
|
1583
|
+
}
|
|
1584
|
+
} else if (!response.ok) {
|
|
1585
|
+
await sendSystemRunDenied(opts, phase.execution, {
|
|
1586
|
+
reason: normalizeDeniedReason(response.error.reason),
|
|
1587
|
+
message: response.error.message
|
|
1588
|
+
});
|
|
1589
|
+
return;
|
|
1590
|
+
} else {
|
|
1591
|
+
const result = response.payload;
|
|
1592
|
+
await sendSystemRunCompleted(opts, phase.execution, result, JSON.stringify(result));
|
|
1593
|
+
return;
|
|
1594
|
+
}
|
|
1595
|
+
}
|
|
1596
|
+
if (phase.policy.approvalDecision === "allow-always" && phase.inlineEvalHit === null) {
|
|
1597
|
+
if ((phase.policy.analysisOk ? persistAllowAlwaysPatterns({
|
|
1598
|
+
approvals: phase.approvals.file,
|
|
1599
|
+
agentId: phase.agentId,
|
|
1600
|
+
segments: phase.segments,
|
|
1601
|
+
cwd: phase.cwd,
|
|
1602
|
+
env: phase.env,
|
|
1603
|
+
platform: process.platform,
|
|
1604
|
+
strictInlineEval: phase.strictInlineEval
|
|
1605
|
+
}) : []).length === 0) addDurableCommandApproval(phase.approvals.file, phase.agentId, phase.commandText);
|
|
1606
|
+
}
|
|
1607
|
+
recordAllowlistMatchesUse({
|
|
1608
|
+
approvals: phase.approvals.file,
|
|
1609
|
+
agentId: phase.agentId,
|
|
1610
|
+
matches: phase.allowlistMatches,
|
|
1611
|
+
command: phase.commandText,
|
|
1612
|
+
resolvedPath: resolveApprovalAuditCandidatePath(phase.segments[0]?.resolution ?? null, phase.cwd)
|
|
1613
|
+
});
|
|
1614
|
+
if (phase.needsScreenRecording) {
|
|
1615
|
+
await sendSystemRunDenied(opts, phase.execution, {
|
|
1616
|
+
reason: "permission:screenRecording",
|
|
1617
|
+
message: "PERMISSION_MISSING: screenRecording"
|
|
1618
|
+
});
|
|
1619
|
+
return;
|
|
1620
|
+
}
|
|
1621
|
+
const execArgv = resolveSystemRunExecArgv({
|
|
1622
|
+
plannedAllowlistArgv: phase.plannedAllowlistArgv,
|
|
1623
|
+
argv: phase.argv,
|
|
1624
|
+
security: phase.security,
|
|
1625
|
+
isWindows: phase.isWindows,
|
|
1626
|
+
policy: phase.policy,
|
|
1627
|
+
shellCommand: phase.shellPayload,
|
|
1628
|
+
segments: phase.segments
|
|
1629
|
+
});
|
|
1630
|
+
const result = await opts.runCommand(execArgv, phase.cwd, phase.env, phase.timeoutMs);
|
|
1631
|
+
applyOutputTruncation(result);
|
|
1632
|
+
await sendSystemRunCompleted(opts, phase.execution, result, JSON.stringify({
|
|
1633
|
+
exitCode: result.exitCode,
|
|
1634
|
+
timedOut: result.timedOut,
|
|
1635
|
+
success: result.success,
|
|
1636
|
+
stdout: result.stdout,
|
|
1637
|
+
stderr: result.stderr,
|
|
1638
|
+
error: result.error ?? null
|
|
1639
|
+
}));
|
|
1640
|
+
}
|
|
1641
|
+
async function handleSystemRunInvoke(opts) {
|
|
1642
|
+
const parsed = await parseSystemRunPhase(opts);
|
|
1643
|
+
if (!parsed) return;
|
|
1644
|
+
const policyPhase = await evaluateSystemRunPolicyPhase(opts, parsed);
|
|
1645
|
+
if (!policyPhase) return;
|
|
1646
|
+
await executeSystemRunPhase(opts, policyPhase);
|
|
1647
|
+
}
|
|
1648
|
+
//#endregion
|
|
1649
|
+
//#region src/node-host/plugin-node-host.ts
|
|
1650
|
+
let pluginRegistryLoaderModulePromise;
|
|
1651
|
+
async function loadPluginRegistryLoaderModule() {
|
|
1652
|
+
pluginRegistryLoaderModulePromise ??= import("./runtime-registry-loader-Vc33wEpr.js");
|
|
1653
|
+
return await pluginRegistryLoaderModulePromise;
|
|
1654
|
+
}
|
|
1655
|
+
async function ensureNodeHostPluginRegistry(params) {
|
|
1656
|
+
(await loadPluginRegistryLoaderModule()).ensurePluginRegistryLoaded({
|
|
1657
|
+
scope: "all",
|
|
1658
|
+
config: params.config,
|
|
1659
|
+
activationSourceConfig: params.config,
|
|
1660
|
+
env: params.env
|
|
1661
|
+
});
|
|
1662
|
+
}
|
|
1663
|
+
function listRegisteredNodeHostCapsAndCommands() {
|
|
1664
|
+
const registry = getActivePluginRegistry();
|
|
1665
|
+
const caps = /* @__PURE__ */ new Set();
|
|
1666
|
+
const commands = /* @__PURE__ */ new Set();
|
|
1667
|
+
for (const entry of registry?.nodeHostCommands ?? []) {
|
|
1668
|
+
if (entry.command.cap) caps.add(entry.command.cap);
|
|
1669
|
+
commands.add(entry.command.command);
|
|
1670
|
+
}
|
|
1671
|
+
return {
|
|
1672
|
+
caps: [...caps].toSorted((left, right) => left.localeCompare(right)),
|
|
1673
|
+
commands: [...commands].toSorted((left, right) => left.localeCompare(right))
|
|
1674
|
+
};
|
|
1675
|
+
}
|
|
1676
|
+
async function invokeRegisteredNodeHostCommand(command, paramsJSON) {
|
|
1677
|
+
const match = (getActivePluginRegistry()?.nodeHostCommands ?? []).find((entry) => entry.command.command === command);
|
|
1678
|
+
if (!match) return null;
|
|
1679
|
+
return await match.command.handle(paramsJSON);
|
|
1680
|
+
}
|
|
1681
|
+
//#endregion
|
|
1682
|
+
//#region src/node-host/invoke.ts
|
|
1683
|
+
const OUTPUT_CAP = 2e5;
|
|
1684
|
+
const OUTPUT_EVENT_TAIL = 2e4;
|
|
1685
|
+
const DEFAULT_NODE_PATH$1 = "/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin";
|
|
1686
|
+
const WINDOWS_CODEPAGE_ENCODING_MAP = {
|
|
1687
|
+
65001: "utf-8",
|
|
1688
|
+
54936: "gb18030",
|
|
1689
|
+
936: "gbk",
|
|
1690
|
+
950: "big5",
|
|
1691
|
+
932: "shift_jis",
|
|
1692
|
+
949: "euc-kr",
|
|
1693
|
+
1252: "windows-1252"
|
|
1694
|
+
};
|
|
1695
|
+
let cachedWindowsConsoleEncoding;
|
|
1696
|
+
const execHostEnforced = normalizeLowercaseStringOrEmpty(process.env.GENESIS_NODE_EXEC_HOST ?? "") === "app";
|
|
1697
|
+
const execHostFallbackAllowed = normalizeLowercaseStringOrEmpty(process.env.GENESIS_NODE_EXEC_FALLBACK ?? "") !== "0";
|
|
1698
|
+
const preferMacAppExecHost = process.platform === "darwin" && execHostEnforced;
|
|
1699
|
+
function resolveExecSecurity(value) {
|
|
1700
|
+
return value === "deny" || value === "allowlist" || value === "full" ? value : "allowlist";
|
|
1701
|
+
}
|
|
1702
|
+
function isCmdExeInvocation(argv) {
|
|
1703
|
+
const token = argv[0]?.trim();
|
|
1704
|
+
if (!token) return false;
|
|
1705
|
+
const base = normalizeLowercaseStringOrEmpty(path.win32.basename(token));
|
|
1706
|
+
return base === "cmd.exe" || base === "cmd";
|
|
1707
|
+
}
|
|
1708
|
+
function resolveExecAsk(value) {
|
|
1709
|
+
return value === "off" || value === "on-miss" || value === "always" ? value : "on-miss";
|
|
1710
|
+
}
|
|
1711
|
+
function sanitizeEnv(overrides) {
|
|
1712
|
+
return sanitizeHostExecEnv({
|
|
1713
|
+
overrides,
|
|
1714
|
+
blockPathOverrides: true
|
|
1715
|
+
});
|
|
1716
|
+
}
|
|
1717
|
+
function truncateOutput(raw, maxChars) {
|
|
1718
|
+
if (raw.length <= maxChars) return {
|
|
1719
|
+
text: raw,
|
|
1720
|
+
truncated: false
|
|
1721
|
+
};
|
|
1722
|
+
return {
|
|
1723
|
+
text: `... (truncated) ${raw.slice(raw.length - maxChars)}`,
|
|
1724
|
+
truncated: true
|
|
1725
|
+
};
|
|
1726
|
+
}
|
|
1727
|
+
function parseWindowsCodePage(raw) {
|
|
1728
|
+
if (!raw) return null;
|
|
1729
|
+
const match = raw.match(/\b(\d{3,5})\b/);
|
|
1730
|
+
if (!match?.[1]) return null;
|
|
1731
|
+
const codePage = Number.parseInt(match[1], 10);
|
|
1732
|
+
if (!Number.isFinite(codePage) || codePage <= 0) return null;
|
|
1733
|
+
return codePage;
|
|
1734
|
+
}
|
|
1735
|
+
function resolveWindowsConsoleEncoding() {
|
|
1736
|
+
if (process.platform !== "win32") return null;
|
|
1737
|
+
if (cachedWindowsConsoleEncoding !== void 0) return cachedWindowsConsoleEncoding;
|
|
1738
|
+
try {
|
|
1739
|
+
const result = spawnSync("cmd.exe", [
|
|
1740
|
+
"/d",
|
|
1741
|
+
"/s",
|
|
1742
|
+
"/c",
|
|
1743
|
+
"chcp"
|
|
1744
|
+
], {
|
|
1745
|
+
windowsHide: true,
|
|
1746
|
+
encoding: "utf8",
|
|
1747
|
+
stdio: [
|
|
1748
|
+
"ignore",
|
|
1749
|
+
"pipe",
|
|
1750
|
+
"pipe"
|
|
1751
|
+
]
|
|
1752
|
+
});
|
|
1753
|
+
const codePage = parseWindowsCodePage(`${result.stdout ?? ""}\n${result.stderr ?? ""}`);
|
|
1754
|
+
cachedWindowsConsoleEncoding = codePage !== null ? WINDOWS_CODEPAGE_ENCODING_MAP[codePage] ?? null : null;
|
|
1755
|
+
} catch {
|
|
1756
|
+
cachedWindowsConsoleEncoding = null;
|
|
1757
|
+
}
|
|
1758
|
+
return cachedWindowsConsoleEncoding;
|
|
1759
|
+
}
|
|
1760
|
+
function decodeCapturedOutputBuffer(params) {
|
|
1761
|
+
const utf8 = params.buffer.toString("utf8");
|
|
1762
|
+
if ((params.platform ?? process.platform) !== "win32") return utf8;
|
|
1763
|
+
const encoding = params.windowsEncoding ?? resolveWindowsConsoleEncoding();
|
|
1764
|
+
if (!encoding || normalizeLowercaseStringOrEmpty(encoding) === "utf-8") return utf8;
|
|
1765
|
+
try {
|
|
1766
|
+
return new TextDecoder(encoding).decode(params.buffer);
|
|
1767
|
+
} catch {
|
|
1768
|
+
return utf8;
|
|
1769
|
+
}
|
|
1770
|
+
}
|
|
1771
|
+
function redactExecApprovals(file) {
|
|
1772
|
+
const socketPath = file.socket?.path?.trim();
|
|
1773
|
+
return {
|
|
1774
|
+
...file,
|
|
1775
|
+
socket: socketPath ? { path: socketPath } : void 0
|
|
1776
|
+
};
|
|
1777
|
+
}
|
|
1778
|
+
function requireExecApprovalsBaseHash(params, snapshot) {
|
|
1779
|
+
if (!snapshot.exists) return;
|
|
1780
|
+
if (!snapshot.hash) throw new Error("INVALID_REQUEST: exec approvals base hash unavailable; reload and retry");
|
|
1781
|
+
const baseHash = typeof params.baseHash === "string" ? params.baseHash.trim() : "";
|
|
1782
|
+
if (!baseHash) throw new Error("INVALID_REQUEST: exec approvals base hash required; reload and retry");
|
|
1783
|
+
if (baseHash !== snapshot.hash) throw new Error("INVALID_REQUEST: exec approvals changed; reload and retry");
|
|
1784
|
+
}
|
|
1785
|
+
async function runCommand(argv, cwd, env, timeoutMs) {
|
|
1786
|
+
return await new Promise((resolve) => {
|
|
1787
|
+
const stdoutChunks = [];
|
|
1788
|
+
const stderrChunks = [];
|
|
1789
|
+
let outputLen = 0;
|
|
1790
|
+
let truncated = false;
|
|
1791
|
+
let timedOut = false;
|
|
1792
|
+
let settled = false;
|
|
1793
|
+
const windowsEncoding = resolveWindowsConsoleEncoding();
|
|
1794
|
+
const child = spawn(argv[0], argv.slice(1), {
|
|
1795
|
+
cwd,
|
|
1796
|
+
env,
|
|
1797
|
+
stdio: [
|
|
1798
|
+
"ignore",
|
|
1799
|
+
"pipe",
|
|
1800
|
+
"pipe"
|
|
1801
|
+
],
|
|
1802
|
+
windowsHide: true
|
|
1803
|
+
});
|
|
1804
|
+
const onChunk = (chunk, target) => {
|
|
1805
|
+
if (outputLen >= OUTPUT_CAP) {
|
|
1806
|
+
truncated = true;
|
|
1807
|
+
return;
|
|
1808
|
+
}
|
|
1809
|
+
const remaining = OUTPUT_CAP - outputLen;
|
|
1810
|
+
const slice = chunk.length > remaining ? chunk.subarray(0, remaining) : chunk;
|
|
1811
|
+
outputLen += slice.length;
|
|
1812
|
+
if (target === "stdout") stdoutChunks.push(slice);
|
|
1813
|
+
else stderrChunks.push(slice);
|
|
1814
|
+
if (chunk.length > remaining) truncated = true;
|
|
1815
|
+
};
|
|
1816
|
+
child.stdout?.on("data", (chunk) => onChunk(chunk, "stdout"));
|
|
1817
|
+
child.stderr?.on("data", (chunk) => onChunk(chunk, "stderr"));
|
|
1818
|
+
let timer;
|
|
1819
|
+
if (timeoutMs && timeoutMs > 0) timer = setTimeout(() => {
|
|
1820
|
+
timedOut = true;
|
|
1821
|
+
try {
|
|
1822
|
+
child.kill("SIGKILL");
|
|
1823
|
+
} catch {}
|
|
1824
|
+
}, timeoutMs);
|
|
1825
|
+
const finalize = (exitCode, error) => {
|
|
1826
|
+
if (settled) return;
|
|
1827
|
+
settled = true;
|
|
1828
|
+
if (timer) clearTimeout(timer);
|
|
1829
|
+
const stdout = decodeCapturedOutputBuffer({
|
|
1830
|
+
buffer: Buffer.concat(stdoutChunks),
|
|
1831
|
+
windowsEncoding
|
|
1832
|
+
});
|
|
1833
|
+
const stderr = decodeCapturedOutputBuffer({
|
|
1834
|
+
buffer: Buffer.concat(stderrChunks),
|
|
1835
|
+
windowsEncoding
|
|
1836
|
+
});
|
|
1837
|
+
resolve({
|
|
1838
|
+
exitCode,
|
|
1839
|
+
timedOut,
|
|
1840
|
+
success: exitCode === 0 && !timedOut && !error,
|
|
1841
|
+
stdout,
|
|
1842
|
+
stderr,
|
|
1843
|
+
error: error ?? null,
|
|
1844
|
+
truncated
|
|
1845
|
+
});
|
|
1846
|
+
};
|
|
1847
|
+
child.on("error", (err) => {
|
|
1848
|
+
finalize(void 0, err.message);
|
|
1849
|
+
});
|
|
1850
|
+
child.on("exit", (code) => {
|
|
1851
|
+
finalize(code === null ? void 0 : code, null);
|
|
1852
|
+
});
|
|
1853
|
+
});
|
|
1854
|
+
}
|
|
1855
|
+
function resolveEnvPath(env) {
|
|
1856
|
+
return (env?.PATH ?? env?.Path ?? process.env.PATH ?? process.env.Path ?? DEFAULT_NODE_PATH$1).split(path.delimiter).filter(Boolean);
|
|
1857
|
+
}
|
|
1858
|
+
function resolveExecutable(bin, env) {
|
|
1859
|
+
if (bin.includes("/") || bin.includes("\\")) return null;
|
|
1860
|
+
const extensions = process.platform === "win32" ? (process.env.PATHEXT ?? process.env.PathExt ?? ".EXE;.CMD;.BAT;.COM").split(";").map((ext) => normalizeLowercaseStringOrEmpty(ext)) : [""];
|
|
1861
|
+
for (const dir of resolveEnvPath(env)) for (const ext of extensions) {
|
|
1862
|
+
const candidate = path.join(dir, bin + ext);
|
|
1863
|
+
if (fs.existsSync(candidate)) return candidate;
|
|
1864
|
+
}
|
|
1865
|
+
return null;
|
|
1866
|
+
}
|
|
1867
|
+
async function handleSystemWhich(params, env) {
|
|
1868
|
+
const bins = params.bins.map((bin) => bin.trim()).filter(Boolean);
|
|
1869
|
+
const found = {};
|
|
1870
|
+
for (const bin of bins) {
|
|
1871
|
+
const path = resolveExecutable(bin, env);
|
|
1872
|
+
if (path) found[bin] = path;
|
|
1873
|
+
}
|
|
1874
|
+
return { bins: found };
|
|
1875
|
+
}
|
|
1876
|
+
function buildExecEventPayload(payload) {
|
|
1877
|
+
if (!payload.output) return payload;
|
|
1878
|
+
const trimmed = payload.output.trim();
|
|
1879
|
+
if (!trimmed) return payload;
|
|
1880
|
+
const { text } = truncateOutput(trimmed, OUTPUT_EVENT_TAIL);
|
|
1881
|
+
return {
|
|
1882
|
+
...payload,
|
|
1883
|
+
output: text
|
|
1884
|
+
};
|
|
1885
|
+
}
|
|
1886
|
+
async function sendExecFinishedEvent(params) {
|
|
1887
|
+
const combined = [
|
|
1888
|
+
params.result.stdout,
|
|
1889
|
+
params.result.stderr,
|
|
1890
|
+
params.result.error
|
|
1891
|
+
].filter(Boolean).join("\n");
|
|
1892
|
+
await sendNodeEvent(params.client, "exec.finished", buildExecEventPayload({
|
|
1893
|
+
sessionKey: params.sessionKey,
|
|
1894
|
+
runId: params.runId,
|
|
1895
|
+
host: "node",
|
|
1896
|
+
command: params.commandText,
|
|
1897
|
+
exitCode: params.result.exitCode ?? void 0,
|
|
1898
|
+
timedOut: params.result.timedOut,
|
|
1899
|
+
success: params.result.success,
|
|
1900
|
+
output: combined,
|
|
1901
|
+
suppressNotifyOnExit: params.suppressNotifyOnExit
|
|
1902
|
+
}));
|
|
1903
|
+
}
|
|
1904
|
+
async function runViaMacAppExecHost(params) {
|
|
1905
|
+
const { approvals, request } = params;
|
|
1906
|
+
return await requestExecHostViaSocket({
|
|
1907
|
+
socketPath: approvals.socketPath,
|
|
1908
|
+
token: approvals.token,
|
|
1909
|
+
request
|
|
1910
|
+
});
|
|
1911
|
+
}
|
|
1912
|
+
async function sendJsonPayloadResult(client, frame, payload) {
|
|
1913
|
+
await sendInvokeResult(client, frame, {
|
|
1914
|
+
ok: true,
|
|
1915
|
+
payloadJSON: JSON.stringify(payload)
|
|
1916
|
+
});
|
|
1917
|
+
}
|
|
1918
|
+
async function sendRawPayloadResult(client, frame, payloadJSON) {
|
|
1919
|
+
await sendInvokeResult(client, frame, {
|
|
1920
|
+
ok: true,
|
|
1921
|
+
payloadJSON
|
|
1922
|
+
});
|
|
1923
|
+
}
|
|
1924
|
+
async function sendErrorResult(client, frame, code, message) {
|
|
1925
|
+
await sendInvokeResult(client, frame, {
|
|
1926
|
+
ok: false,
|
|
1927
|
+
error: {
|
|
1928
|
+
code,
|
|
1929
|
+
message
|
|
1930
|
+
}
|
|
1931
|
+
});
|
|
1932
|
+
}
|
|
1933
|
+
async function sendInvalidRequestResult(client, frame, err) {
|
|
1934
|
+
await sendErrorResult(client, frame, "INVALID_REQUEST", String(err));
|
|
1935
|
+
}
|
|
1936
|
+
async function handleInvoke(frame, client, skillBins) {
|
|
1937
|
+
const command = frame.command ?? "";
|
|
1938
|
+
if (command === "system.execApprovals.get") {
|
|
1939
|
+
try {
|
|
1940
|
+
ensureExecApprovals();
|
|
1941
|
+
const snapshot = readExecApprovalsSnapshot();
|
|
1942
|
+
await sendJsonPayloadResult(client, frame, {
|
|
1943
|
+
path: snapshot.path,
|
|
1944
|
+
exists: snapshot.exists,
|
|
1945
|
+
hash: snapshot.hash,
|
|
1946
|
+
file: redactExecApprovals(snapshot.file)
|
|
1947
|
+
});
|
|
1948
|
+
} catch (err) {
|
|
1949
|
+
const message = String(err);
|
|
1950
|
+
await sendErrorResult(client, frame, normalizeLowercaseStringOrEmpty(message).includes("timed out") ? "TIMEOUT" : "INVALID_REQUEST", message);
|
|
1951
|
+
}
|
|
1952
|
+
return;
|
|
1953
|
+
}
|
|
1954
|
+
if (command === "system.execApprovals.set") {
|
|
1955
|
+
try {
|
|
1956
|
+
const params = decodeParams(frame.paramsJSON);
|
|
1957
|
+
if (!params.file || typeof params.file !== "object") throw new Error("INVALID_REQUEST: exec approvals file required");
|
|
1958
|
+
ensureExecApprovals();
|
|
1959
|
+
const snapshot = readExecApprovalsSnapshot();
|
|
1960
|
+
requireExecApprovalsBaseHash(params, snapshot);
|
|
1961
|
+
saveExecApprovals(mergeExecApprovalsSocketDefaults({
|
|
1962
|
+
normalized: normalizeExecApprovals(params.file),
|
|
1963
|
+
current: snapshot.file
|
|
1964
|
+
}));
|
|
1965
|
+
const nextSnapshot = readExecApprovalsSnapshot();
|
|
1966
|
+
await sendJsonPayloadResult(client, frame, {
|
|
1967
|
+
path: nextSnapshot.path,
|
|
1968
|
+
exists: nextSnapshot.exists,
|
|
1969
|
+
hash: nextSnapshot.hash,
|
|
1970
|
+
file: redactExecApprovals(nextSnapshot.file)
|
|
1971
|
+
});
|
|
1972
|
+
} catch (err) {
|
|
1973
|
+
await sendInvalidRequestResult(client, frame, err);
|
|
1974
|
+
}
|
|
1975
|
+
return;
|
|
1976
|
+
}
|
|
1977
|
+
if (command === "system.which") {
|
|
1978
|
+
try {
|
|
1979
|
+
const params = decodeParams(frame.paramsJSON);
|
|
1980
|
+
if (!Array.isArray(params.bins)) throw new Error("INVALID_REQUEST: bins required");
|
|
1981
|
+
await sendJsonPayloadResult(client, frame, await handleSystemWhich(params, sanitizeEnv(void 0)));
|
|
1982
|
+
} catch (err) {
|
|
1983
|
+
await sendInvalidRequestResult(client, frame, err);
|
|
1984
|
+
}
|
|
1985
|
+
return;
|
|
1986
|
+
}
|
|
1987
|
+
try {
|
|
1988
|
+
const pluginNodeHostResult = await invokeRegisteredNodeHostCommand(command, frame.paramsJSON);
|
|
1989
|
+
if (pluginNodeHostResult !== null) {
|
|
1990
|
+
await sendRawPayloadResult(client, frame, pluginNodeHostResult);
|
|
1991
|
+
return;
|
|
1992
|
+
}
|
|
1993
|
+
} catch (err) {
|
|
1994
|
+
await sendInvalidRequestResult(client, frame, err);
|
|
1995
|
+
return;
|
|
1996
|
+
}
|
|
1997
|
+
if (command === "system.run.prepare") {
|
|
1998
|
+
try {
|
|
1999
|
+
const prepared = buildSystemRunApprovalPlan(decodeParams(frame.paramsJSON));
|
|
2000
|
+
if (!prepared.ok) {
|
|
2001
|
+
await sendErrorResult(client, frame, "INVALID_REQUEST", prepared.message);
|
|
2002
|
+
return;
|
|
2003
|
+
}
|
|
2004
|
+
await sendJsonPayloadResult(client, frame, { plan: prepared.plan });
|
|
2005
|
+
} catch (err) {
|
|
2006
|
+
await sendInvalidRequestResult(client, frame, err);
|
|
2007
|
+
}
|
|
2008
|
+
return;
|
|
2009
|
+
}
|
|
2010
|
+
if (command !== "system.run") {
|
|
2011
|
+
await sendErrorResult(client, frame, "UNAVAILABLE", "command not supported");
|
|
2012
|
+
return;
|
|
2013
|
+
}
|
|
2014
|
+
let params;
|
|
2015
|
+
try {
|
|
2016
|
+
params = decodeParams(frame.paramsJSON);
|
|
2017
|
+
} catch (err) {
|
|
2018
|
+
await sendInvalidRequestResult(client, frame, err);
|
|
2019
|
+
return;
|
|
2020
|
+
}
|
|
2021
|
+
if (!Array.isArray(params.command) || params.command.length === 0) {
|
|
2022
|
+
await sendErrorResult(client, frame, "INVALID_REQUEST", "command required");
|
|
2023
|
+
return;
|
|
2024
|
+
}
|
|
2025
|
+
await handleSystemRunInvoke({
|
|
2026
|
+
client,
|
|
2027
|
+
params,
|
|
2028
|
+
skillBins,
|
|
2029
|
+
execHostEnforced,
|
|
2030
|
+
execHostFallbackAllowed,
|
|
2031
|
+
resolveExecSecurity,
|
|
2032
|
+
resolveExecAsk,
|
|
2033
|
+
isCmdExeInvocation,
|
|
2034
|
+
sanitizeEnv,
|
|
2035
|
+
runCommand,
|
|
2036
|
+
runViaMacAppExecHost,
|
|
2037
|
+
sendNodeEvent,
|
|
2038
|
+
buildExecEventPayload,
|
|
2039
|
+
sendInvokeResult: async (result) => {
|
|
2040
|
+
await sendInvokeResult(client, frame, result);
|
|
2041
|
+
},
|
|
2042
|
+
sendExecFinishedEvent: async ({ sessionKey, runId, commandText, result }) => {
|
|
2043
|
+
await sendExecFinishedEvent({
|
|
2044
|
+
client,
|
|
2045
|
+
sessionKey,
|
|
2046
|
+
runId,
|
|
2047
|
+
commandText,
|
|
2048
|
+
result
|
|
2049
|
+
});
|
|
2050
|
+
},
|
|
2051
|
+
preferMacAppExecHost
|
|
2052
|
+
});
|
|
2053
|
+
}
|
|
2054
|
+
function decodeParams(raw) {
|
|
2055
|
+
if (!raw) throw new Error("INVALID_REQUEST: paramsJSON required");
|
|
2056
|
+
return JSON.parse(raw);
|
|
2057
|
+
}
|
|
2058
|
+
function coerceNodeInvokePayload(payload) {
|
|
2059
|
+
if (!payload || typeof payload !== "object") return null;
|
|
2060
|
+
const obj = payload;
|
|
2061
|
+
const id = typeof obj.id === "string" ? obj.id.trim() : "";
|
|
2062
|
+
const nodeId = typeof obj.nodeId === "string" ? obj.nodeId.trim() : "";
|
|
2063
|
+
const command = typeof obj.command === "string" ? obj.command.trim() : "";
|
|
2064
|
+
if (!id || !nodeId || !command) return null;
|
|
2065
|
+
return {
|
|
2066
|
+
id,
|
|
2067
|
+
nodeId,
|
|
2068
|
+
command,
|
|
2069
|
+
paramsJSON: typeof obj.paramsJSON === "string" ? obj.paramsJSON : obj.params !== void 0 ? JSON.stringify(obj.params) : null,
|
|
2070
|
+
timeoutMs: typeof obj.timeoutMs === "number" ? obj.timeoutMs : null,
|
|
2071
|
+
idempotencyKey: typeof obj.idempotencyKey === "string" ? obj.idempotencyKey : null
|
|
2072
|
+
};
|
|
2073
|
+
}
|
|
2074
|
+
async function sendInvokeResult(client, frame, result) {
|
|
2075
|
+
try {
|
|
2076
|
+
await client.request("node.invoke.result", buildNodeInvokeResultParams(frame, result));
|
|
2077
|
+
} catch {}
|
|
2078
|
+
}
|
|
2079
|
+
function buildNodeInvokeResultParams(frame, result) {
|
|
2080
|
+
const params = {
|
|
2081
|
+
id: frame.id,
|
|
2082
|
+
nodeId: frame.nodeId,
|
|
2083
|
+
ok: result.ok
|
|
2084
|
+
};
|
|
2085
|
+
if (result.payload !== void 0) params.payload = result.payload;
|
|
2086
|
+
if (typeof result.payloadJSON === "string") params.payloadJSON = result.payloadJSON;
|
|
2087
|
+
if (result.error) params.error = result.error;
|
|
2088
|
+
return params;
|
|
2089
|
+
}
|
|
2090
|
+
async function sendNodeEvent(client, event, payload) {
|
|
2091
|
+
try {
|
|
2092
|
+
await client.request("node.event", {
|
|
2093
|
+
event,
|
|
2094
|
+
payloadJSON: payload ? JSON.stringify(payload) : null
|
|
2095
|
+
});
|
|
2096
|
+
} catch {}
|
|
2097
|
+
}
|
|
2098
|
+
//#endregion
|
|
2099
|
+
//#region src/node-host/runner.ts
|
|
2100
|
+
const DEFAULT_NODE_PATH = "/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin";
|
|
2101
|
+
function writeStderrLine(message) {
|
|
2102
|
+
process.stderr.write(`${message}\n`);
|
|
2103
|
+
}
|
|
2104
|
+
function resolveExecutablePathFromEnv(bin, pathEnv) {
|
|
2105
|
+
if (bin.includes("/") || bin.includes("\\")) return null;
|
|
2106
|
+
return resolveExecutableFromPathEnv(bin, pathEnv) ?? null;
|
|
2107
|
+
}
|
|
2108
|
+
function resolveSkillBinTrustEntries(bins, pathEnv) {
|
|
2109
|
+
const trustEntries = [];
|
|
2110
|
+
const seen = /* @__PURE__ */ new Set();
|
|
2111
|
+
for (const bin of bins) {
|
|
2112
|
+
const name = bin.trim();
|
|
2113
|
+
if (!name) continue;
|
|
2114
|
+
const resolvedPath = resolveExecutablePathFromEnv(name, pathEnv);
|
|
2115
|
+
if (!resolvedPath) continue;
|
|
2116
|
+
const key = `${name}\u0000${resolvedPath}`;
|
|
2117
|
+
if (seen.has(key)) continue;
|
|
2118
|
+
seen.add(key);
|
|
2119
|
+
trustEntries.push({
|
|
2120
|
+
name,
|
|
2121
|
+
resolvedPath
|
|
2122
|
+
});
|
|
2123
|
+
}
|
|
2124
|
+
return trustEntries.toSorted((left, right) => left.name.localeCompare(right.name) || left.resolvedPath.localeCompare(right.resolvedPath));
|
|
2125
|
+
}
|
|
2126
|
+
var SkillBinsCache = class {
|
|
2127
|
+
constructor(fetch, pathEnv) {
|
|
2128
|
+
this.bins = [];
|
|
2129
|
+
this.lastRefresh = 0;
|
|
2130
|
+
this.ttlMs = 9e4;
|
|
2131
|
+
this.fetch = fetch;
|
|
2132
|
+
this.pathEnv = pathEnv;
|
|
2133
|
+
}
|
|
2134
|
+
async current(force = false) {
|
|
2135
|
+
if (force || Date.now() - this.lastRefresh > this.ttlMs) await this.refresh();
|
|
2136
|
+
return this.bins;
|
|
2137
|
+
}
|
|
2138
|
+
async refresh() {
|
|
2139
|
+
try {
|
|
2140
|
+
const bins = await this.fetch();
|
|
2141
|
+
this.bins = resolveSkillBinTrustEntries(bins, this.pathEnv);
|
|
2142
|
+
this.lastRefresh = Date.now();
|
|
2143
|
+
} catch {
|
|
2144
|
+
if (!this.lastRefresh) this.bins = [];
|
|
2145
|
+
}
|
|
2146
|
+
}
|
|
2147
|
+
};
|
|
2148
|
+
function ensureNodePathEnv() {
|
|
2149
|
+
ensureGenesisCliOnPath({ pathEnv: process.env.PATH ?? "" });
|
|
2150
|
+
const current = process.env.PATH ?? "";
|
|
2151
|
+
if (current.trim()) return current;
|
|
2152
|
+
process.env.PATH = DEFAULT_NODE_PATH;
|
|
2153
|
+
return DEFAULT_NODE_PATH;
|
|
2154
|
+
}
|
|
2155
|
+
async function resolveNodeHostGatewayCredentials(params) {
|
|
2156
|
+
return await resolveGatewayConnectionAuth({
|
|
2157
|
+
config: (params.config.gateway?.mode === "remote" ? "remote" : "local") === "local" ? buildNodeHostLocalAuthConfig(params.config) : params.config,
|
|
2158
|
+
env: params.env,
|
|
2159
|
+
localTokenPrecedence: "env-first",
|
|
2160
|
+
localPasswordPrecedence: "env-first",
|
|
2161
|
+
remoteTokenPrecedence: "env-first",
|
|
2162
|
+
remotePasswordPrecedence: "env-first"
|
|
2163
|
+
});
|
|
2164
|
+
}
|
|
2165
|
+
function buildNodeHostLocalAuthConfig(config) {
|
|
2166
|
+
if (!config.gateway?.remote?.token && !config.gateway?.remote?.password) return config;
|
|
2167
|
+
const nextConfig = structuredClone(config);
|
|
2168
|
+
if (nextConfig.gateway?.remote) {
|
|
2169
|
+
nextConfig.gateway.remote.token = void 0;
|
|
2170
|
+
nextConfig.gateway.remote.password = void 0;
|
|
2171
|
+
}
|
|
2172
|
+
return nextConfig;
|
|
2173
|
+
}
|
|
2174
|
+
async function runNodeHost(opts) {
|
|
2175
|
+
const config = await ensureNodeHostConfig();
|
|
2176
|
+
const nodeId = opts.nodeId?.trim() || config.nodeId;
|
|
2177
|
+
if (nodeId !== config.nodeId) config.nodeId = nodeId;
|
|
2178
|
+
const displayName = opts.displayName?.trim() || config.displayName || await getMachineDisplayName();
|
|
2179
|
+
config.displayName = displayName;
|
|
2180
|
+
const gateway = {
|
|
2181
|
+
host: opts.gatewayHost,
|
|
2182
|
+
port: opts.gatewayPort,
|
|
2183
|
+
tls: opts.gatewayTls ?? loadConfig().gateway?.tls?.enabled ?? false,
|
|
2184
|
+
tlsFingerprint: opts.gatewayTlsFingerprint
|
|
2185
|
+
};
|
|
2186
|
+
config.gateway = gateway;
|
|
2187
|
+
await saveNodeHostConfig(config);
|
|
2188
|
+
const cfg = loadConfig();
|
|
2189
|
+
await ensureNodeHostPluginRegistry({
|
|
2190
|
+
config: cfg,
|
|
2191
|
+
env: process.env
|
|
2192
|
+
});
|
|
2193
|
+
const pluginNodeHost = listRegisteredNodeHostCapsAndCommands();
|
|
2194
|
+
const { token, password } = await resolveNodeHostGatewayCredentials({
|
|
2195
|
+
config: cfg,
|
|
2196
|
+
env: process.env
|
|
2197
|
+
});
|
|
2198
|
+
const host = gateway.host ?? "127.0.0.1";
|
|
2199
|
+
const port = gateway.port ?? 18789;
|
|
2200
|
+
const url = `${gateway.tls ? "wss" : "ws"}://${host}:${port}`;
|
|
2201
|
+
const pathEnv = ensureNodePathEnv();
|
|
2202
|
+
const client = new GatewayClient({
|
|
2203
|
+
url,
|
|
2204
|
+
token: token || void 0,
|
|
2205
|
+
password: password || void 0,
|
|
2206
|
+
instanceId: nodeId,
|
|
2207
|
+
clientName: GATEWAY_CLIENT_NAMES.NODE_HOST,
|
|
2208
|
+
clientDisplayName: displayName,
|
|
2209
|
+
clientVersion: VERSION,
|
|
2210
|
+
platform: process.platform,
|
|
2211
|
+
mode: GATEWAY_CLIENT_MODES.NODE,
|
|
2212
|
+
role: "node",
|
|
2213
|
+
scopes: [],
|
|
2214
|
+
caps: ["system", ...pluginNodeHost.caps],
|
|
2215
|
+
commands: [
|
|
2216
|
+
...NODE_SYSTEM_RUN_COMMANDS,
|
|
2217
|
+
...NODE_EXEC_APPROVALS_COMMANDS,
|
|
2218
|
+
...pluginNodeHost.commands
|
|
2219
|
+
],
|
|
2220
|
+
pathEnv,
|
|
2221
|
+
permissions: void 0,
|
|
2222
|
+
deviceIdentity: loadOrCreateDeviceIdentity(),
|
|
2223
|
+
tlsFingerprint: gateway.tlsFingerprint,
|
|
2224
|
+
onEvent: (evt) => {
|
|
2225
|
+
if (evt.event !== "node.invoke.request") return;
|
|
2226
|
+
const payload = coerceNodeInvokePayload(evt.payload);
|
|
2227
|
+
if (!payload) return;
|
|
2228
|
+
handleInvoke(payload, client, skillBins);
|
|
2229
|
+
},
|
|
2230
|
+
onConnectError: (err) => {
|
|
2231
|
+
writeStderrLine(`node host gateway connect failed: ${err.message}`);
|
|
2232
|
+
},
|
|
2233
|
+
onClose: (code, reason) => {
|
|
2234
|
+
writeStderrLine(`node host gateway closed (${code}): ${reason}`);
|
|
2235
|
+
}
|
|
2236
|
+
});
|
|
2237
|
+
const skillBins = new SkillBinsCache(async () => {
|
|
2238
|
+
const res = await client.request("skills.bins", {});
|
|
2239
|
+
return Array.isArray(res?.bins) ? res.bins.map((bin) => String(bin)) : [];
|
|
2240
|
+
}, pathEnv);
|
|
2241
|
+
client.start();
|
|
2242
|
+
await new Promise(() => {});
|
|
2243
|
+
}
|
|
2244
|
+
//#endregion
|
|
2245
|
+
//#region src/commands/node-daemon-install-helpers.ts
|
|
2246
|
+
async function buildNodeInstallPlan(params) {
|
|
2247
|
+
const { devMode, nodePath } = await resolveDaemonInstallRuntimeInputs({
|
|
2248
|
+
env: params.env,
|
|
2249
|
+
runtime: params.runtime,
|
|
2250
|
+
devMode: params.devMode,
|
|
2251
|
+
nodePath: params.nodePath
|
|
2252
|
+
});
|
|
2253
|
+
const { programArguments, workingDirectory } = await resolveNodeProgramArguments({
|
|
2254
|
+
host: params.host,
|
|
2255
|
+
port: params.port,
|
|
2256
|
+
tls: params.tls,
|
|
2257
|
+
tlsFingerprint: params.tlsFingerprint,
|
|
2258
|
+
nodeId: params.nodeId,
|
|
2259
|
+
displayName: params.displayName,
|
|
2260
|
+
dev: devMode,
|
|
2261
|
+
runtime: params.runtime,
|
|
2262
|
+
nodePath
|
|
2263
|
+
});
|
|
2264
|
+
await emitDaemonInstallRuntimeWarning({
|
|
2265
|
+
env: params.env,
|
|
2266
|
+
runtime: params.runtime,
|
|
2267
|
+
programArguments,
|
|
2268
|
+
warn: params.warn,
|
|
2269
|
+
title: "Node daemon runtime"
|
|
2270
|
+
});
|
|
2271
|
+
const environment = buildNodeServiceEnvironment({
|
|
2272
|
+
env: params.env,
|
|
2273
|
+
extraPathDirs: resolveDaemonNodeBinDir(nodePath)
|
|
2274
|
+
});
|
|
2275
|
+
return {
|
|
2276
|
+
programArguments,
|
|
2277
|
+
workingDirectory,
|
|
2278
|
+
environment,
|
|
2279
|
+
description: formatNodeServiceDescription({ version: environment.GENESIS_SERVICE_VERSION })
|
|
2280
|
+
};
|
|
2281
|
+
}
|
|
2282
|
+
//#endregion
|
|
2283
|
+
//#region src/commands/node-daemon-runtime.ts
|
|
2284
|
+
const DEFAULT_NODE_DAEMON_RUNTIME = DEFAULT_GATEWAY_DAEMON_RUNTIME;
|
|
2285
|
+
function isNodeDaemonRuntime(value) {
|
|
2286
|
+
return isGatewayDaemonRuntime(value);
|
|
2287
|
+
}
|
|
2288
|
+
//#endregion
|
|
2289
|
+
//#region src/cli/node-cli/daemon.ts
|
|
2290
|
+
function renderNodeServiceStartHints() {
|
|
2291
|
+
return buildPlatformServiceStartHints({
|
|
2292
|
+
installCommand: formatCliCommand("genesis node install"),
|
|
2293
|
+
startCommand: formatCliCommand("genesis node start"),
|
|
2294
|
+
launchAgentPlistPath: `~/Library/LaunchAgents/${resolveNodeLaunchAgentLabel()}.plist`,
|
|
2295
|
+
systemdServiceName: resolveNodeSystemdServiceName(),
|
|
2296
|
+
windowsTaskName: resolveNodeWindowsTaskName()
|
|
2297
|
+
});
|
|
2298
|
+
}
|
|
2299
|
+
function buildNodeRuntimeHints(env = process.env) {
|
|
2300
|
+
return buildPlatformRuntimeLogHints({
|
|
2301
|
+
env,
|
|
2302
|
+
systemdServiceName: resolveNodeSystemdServiceName(),
|
|
2303
|
+
windowsTaskName: resolveNodeWindowsTaskName()
|
|
2304
|
+
});
|
|
2305
|
+
}
|
|
2306
|
+
function resolveNodeDefaults(opts, config) {
|
|
2307
|
+
const host = normalizeOptionalString(opts.host) || config?.gateway?.host || "127.0.0.1";
|
|
2308
|
+
const portOverride = parsePort(opts.port);
|
|
2309
|
+
if (opts.port !== void 0 && portOverride === null) return {
|
|
2310
|
+
host,
|
|
2311
|
+
port: null
|
|
2312
|
+
};
|
|
2313
|
+
return {
|
|
2314
|
+
host,
|
|
2315
|
+
port: portOverride ?? config?.gateway?.port ?? 18789
|
|
2316
|
+
};
|
|
2317
|
+
}
|
|
2318
|
+
async function runNodeDaemonInstall(opts) {
|
|
2319
|
+
const { json, stdout, warnings, emit, fail } = createDaemonInstallActionContext(opts.json);
|
|
2320
|
+
if (failIfNixDaemonInstallMode(fail)) return;
|
|
2321
|
+
const config = await loadNodeHostConfig();
|
|
2322
|
+
const { host, port } = resolveNodeDefaults(opts, config);
|
|
2323
|
+
if (!Number.isFinite(port ?? NaN) || (port ?? 0) <= 0) {
|
|
2324
|
+
fail("Invalid port");
|
|
2325
|
+
return;
|
|
2326
|
+
}
|
|
2327
|
+
const runtimeRaw = opts.runtime ? opts.runtime : DEFAULT_NODE_DAEMON_RUNTIME;
|
|
2328
|
+
if (!isNodeDaemonRuntime(runtimeRaw)) {
|
|
2329
|
+
fail("Invalid --runtime (use \"node\" or \"bun\")");
|
|
2330
|
+
return;
|
|
2331
|
+
}
|
|
2332
|
+
const service = resolveNodeService();
|
|
2333
|
+
let loaded = false;
|
|
2334
|
+
try {
|
|
2335
|
+
loaded = await service.isLoaded({ env: process.env });
|
|
2336
|
+
} catch (err) {
|
|
2337
|
+
fail(`Node service check failed: ${String(err)}`);
|
|
2338
|
+
return;
|
|
2339
|
+
}
|
|
2340
|
+
if (loaded && !opts.force) {
|
|
2341
|
+
emit({
|
|
2342
|
+
ok: true,
|
|
2343
|
+
result: "already-installed",
|
|
2344
|
+
message: `Node service already ${service.loadedText}.`,
|
|
2345
|
+
service: buildDaemonServiceSnapshot(service, loaded),
|
|
2346
|
+
warnings: warnings.length ? warnings : void 0
|
|
2347
|
+
});
|
|
2348
|
+
if (!json) {
|
|
2349
|
+
defaultRuntime.log(`Node service already ${service.loadedText}.`);
|
|
2350
|
+
defaultRuntime.log(`Reinstall with: ${formatCliCommand("genesis node install --force")}`);
|
|
2351
|
+
}
|
|
2352
|
+
return;
|
|
2353
|
+
}
|
|
2354
|
+
const tlsFingerprint = normalizeOptionalString(opts.tlsFingerprint) || config?.gateway?.tlsFingerprint;
|
|
2355
|
+
const tls = Boolean(opts.tls) || Boolean(tlsFingerprint) || Boolean(config?.gateway?.tls);
|
|
2356
|
+
const { programArguments, workingDirectory, environment, description } = await buildNodeInstallPlan({
|
|
2357
|
+
env: process.env,
|
|
2358
|
+
host,
|
|
2359
|
+
port: port ?? 18789,
|
|
2360
|
+
tls,
|
|
2361
|
+
tlsFingerprint: tlsFingerprint || void 0,
|
|
2362
|
+
nodeId: opts.nodeId,
|
|
2363
|
+
displayName: opts.displayName,
|
|
2364
|
+
runtime: runtimeRaw,
|
|
2365
|
+
warn: (message) => {
|
|
2366
|
+
if (json) warnings.push(message);
|
|
2367
|
+
else defaultRuntime.log(message);
|
|
2368
|
+
}
|
|
2369
|
+
});
|
|
2370
|
+
await installDaemonServiceAndEmit({
|
|
2371
|
+
serviceNoun: "Node",
|
|
2372
|
+
service,
|
|
2373
|
+
warnings,
|
|
2374
|
+
emit,
|
|
2375
|
+
fail,
|
|
2376
|
+
install: async () => {
|
|
2377
|
+
await service.install({
|
|
2378
|
+
env: process.env,
|
|
2379
|
+
stdout,
|
|
2380
|
+
programArguments,
|
|
2381
|
+
workingDirectory,
|
|
2382
|
+
environment,
|
|
2383
|
+
description
|
|
2384
|
+
});
|
|
2385
|
+
}
|
|
2386
|
+
});
|
|
2387
|
+
}
|
|
2388
|
+
async function runNodeDaemonUninstall(opts = {}) {
|
|
2389
|
+
return await runServiceUninstall({
|
|
2390
|
+
serviceNoun: "Node",
|
|
2391
|
+
service: resolveNodeService(),
|
|
2392
|
+
opts,
|
|
2393
|
+
stopBeforeUninstall: false,
|
|
2394
|
+
assertNotLoadedAfterUninstall: false
|
|
2395
|
+
});
|
|
2396
|
+
}
|
|
2397
|
+
async function runNodeDaemonRestart(opts = {}) {
|
|
2398
|
+
await runServiceRestart({
|
|
2399
|
+
serviceNoun: "Node",
|
|
2400
|
+
service: resolveNodeService(),
|
|
2401
|
+
renderStartHints: renderNodeServiceStartHints,
|
|
2402
|
+
opts
|
|
2403
|
+
});
|
|
2404
|
+
}
|
|
2405
|
+
async function runNodeDaemonStop(opts = {}) {
|
|
2406
|
+
return await runServiceStop({
|
|
2407
|
+
serviceNoun: "Node",
|
|
2408
|
+
service: resolveNodeService(),
|
|
2409
|
+
opts
|
|
2410
|
+
});
|
|
2411
|
+
}
|
|
2412
|
+
async function runNodeDaemonStatus(opts = {}) {
|
|
2413
|
+
const json = Boolean(opts.json);
|
|
2414
|
+
const service = resolveNodeService();
|
|
2415
|
+
const [loaded, command, runtime] = await Promise.all([
|
|
2416
|
+
service.isLoaded({ env: process.env }).catch(() => false),
|
|
2417
|
+
service.readCommand(process.env).catch(() => null),
|
|
2418
|
+
service.readRuntime(process.env).catch((err) => ({
|
|
2419
|
+
status: "unknown",
|
|
2420
|
+
detail: String(err)
|
|
2421
|
+
}))
|
|
2422
|
+
]);
|
|
2423
|
+
const payload = { service: {
|
|
2424
|
+
...buildDaemonServiceSnapshot(service, loaded),
|
|
2425
|
+
command,
|
|
2426
|
+
runtime
|
|
2427
|
+
} };
|
|
2428
|
+
if (json) {
|
|
2429
|
+
defaultRuntime.writeJson(payload);
|
|
2430
|
+
return;
|
|
2431
|
+
}
|
|
2432
|
+
const { rich, label, accent, infoText, okText, warnText, errorText } = createCliStatusTextStyles();
|
|
2433
|
+
const serviceStatus = loaded ? okText(service.loadedText) : warnText(service.notLoadedText);
|
|
2434
|
+
defaultRuntime.log(`${label("Service:")} ${accent(service.label)} (${serviceStatus})`);
|
|
2435
|
+
if (command?.programArguments?.length) defaultRuntime.log(`${label("Command:")} ${infoText(command.programArguments.join(" "))}`);
|
|
2436
|
+
if (command?.sourcePath) defaultRuntime.log(`${label("Service file:")} ${infoText(command.sourcePath)}`);
|
|
2437
|
+
if (command?.workingDirectory) defaultRuntime.log(`${label("Working dir:")} ${infoText(command.workingDirectory)}`);
|
|
2438
|
+
const runtimeLine = formatRuntimeStatus(runtime);
|
|
2439
|
+
if (runtimeLine) {
|
|
2440
|
+
const runtimeColor = resolveRuntimeStatusColor(runtime?.status);
|
|
2441
|
+
defaultRuntime.log(`${label("Runtime:")} ${colorize(rich, runtimeColor, runtimeLine)}`);
|
|
2442
|
+
}
|
|
2443
|
+
if (!loaded) {
|
|
2444
|
+
defaultRuntime.log("");
|
|
2445
|
+
for (const hint of renderNodeServiceStartHints()) defaultRuntime.log(`${warnText("Start with:")} ${infoText(hint)}`);
|
|
2446
|
+
return;
|
|
2447
|
+
}
|
|
2448
|
+
const baseEnv = {
|
|
2449
|
+
...process.env,
|
|
2450
|
+
...command?.environment ?? void 0
|
|
2451
|
+
};
|
|
2452
|
+
const hintEnv = {
|
|
2453
|
+
...baseEnv,
|
|
2454
|
+
GENESIS_LOG_PREFIX: baseEnv.GENESIS_LOG_PREFIX ?? "node"
|
|
2455
|
+
};
|
|
2456
|
+
if (runtime?.missingUnit) {
|
|
2457
|
+
defaultRuntime.error(errorText("Service unit not found."));
|
|
2458
|
+
for (const hint of buildNodeRuntimeHints(hintEnv)) defaultRuntime.error(errorText(hint));
|
|
2459
|
+
return;
|
|
2460
|
+
}
|
|
2461
|
+
if (runtime?.status === "stopped") {
|
|
2462
|
+
defaultRuntime.error(errorText("Service is loaded but not running."));
|
|
2463
|
+
for (const hint of buildNodeRuntimeHints(hintEnv)) defaultRuntime.error(errorText(hint));
|
|
2464
|
+
}
|
|
2465
|
+
}
|
|
2466
|
+
//#endregion
|
|
2467
|
+
//#region src/cli/node-cli/register.ts
|
|
2468
|
+
function parsePortWithFallback(value, fallback) {
|
|
2469
|
+
return parsePort(value) ?? fallback;
|
|
2470
|
+
}
|
|
2471
|
+
function registerNodeCli(program) {
|
|
2472
|
+
const node = program.command("node").description("Run and manage the headless node host service").addHelpText("after", () => `\n${theme.heading("Examples:")}\n${formatHelpExamples([
|
|
2473
|
+
["genesis node run --host 127.0.0.1 --port 18789", "Run the node host in the foreground."],
|
|
2474
|
+
["genesis node status", "Check node host service status."],
|
|
2475
|
+
["genesis node install", "Install the node host service."],
|
|
2476
|
+
["genesis node restart", "Restart the installed node host service."]
|
|
2477
|
+
])}\n\n${theme.muted("Docs:")} ${formatDocsLink("/cli/node", "docs.genesis.ai/cli/node")}\n`);
|
|
2478
|
+
node.command("run").description("Run the headless node host (foreground)").option("--host <host>", "Gateway host").option("--port <port>", "Gateway port").option("--tls", "Use TLS for the gateway connection", false).option("--tls-fingerprint <sha256>", "Expected TLS certificate fingerprint (sha256)").option("--node-id <id>", "Override node id (clears pairing token)").option("--display-name <name>", "Override node display name").action(async (opts) => {
|
|
2479
|
+
const existing = await loadNodeHostConfig();
|
|
2480
|
+
await runNodeHost({
|
|
2481
|
+
gatewayHost: normalizeOptionalString(opts.host) || existing?.gateway?.host || "127.0.0.1",
|
|
2482
|
+
gatewayPort: parsePortWithFallback(opts.port, existing?.gateway?.port ?? 18789),
|
|
2483
|
+
gatewayTls: Boolean(opts.tls) || Boolean(opts.tlsFingerprint),
|
|
2484
|
+
gatewayTlsFingerprint: opts.tlsFingerprint,
|
|
2485
|
+
nodeId: opts.nodeId,
|
|
2486
|
+
displayName: opts.displayName
|
|
2487
|
+
});
|
|
2488
|
+
});
|
|
2489
|
+
node.command("status").description("Show node host status").option("--json", "Output JSON", false).action(async (opts) => {
|
|
2490
|
+
await runNodeDaemonStatus(opts);
|
|
2491
|
+
});
|
|
2492
|
+
node.command("install").description("Install the node host service (launchd/systemd/schtasks)").option("--host <host>", "Gateway host").option("--port <port>", "Gateway port").option("--tls", "Use TLS for the gateway connection", false).option("--tls-fingerprint <sha256>", "Expected TLS certificate fingerprint (sha256)").option("--node-id <id>", "Override node id (clears pairing token)").option("--display-name <name>", "Override node display name").option("--runtime <runtime>", "Service runtime (node|bun). Default: node").option("--force", "Reinstall/overwrite if already installed", false).option("--json", "Output JSON", false).action(async (opts) => {
|
|
2493
|
+
await runNodeDaemonInstall(opts);
|
|
2494
|
+
});
|
|
2495
|
+
node.command("uninstall").description("Uninstall the node host service (launchd/systemd/schtasks)").option("--json", "Output JSON", false).action(async (opts) => {
|
|
2496
|
+
await runNodeDaemonUninstall(opts);
|
|
2497
|
+
});
|
|
2498
|
+
node.command("stop").description("Stop the node host service (launchd/systemd/schtasks)").option("--json", "Output JSON", false).action(async (opts) => {
|
|
2499
|
+
await runNodeDaemonStop(opts);
|
|
2500
|
+
});
|
|
2501
|
+
node.command("restart").description("Restart the node host service (launchd/systemd/schtasks)").option("--json", "Output JSON", false).action(async (opts) => {
|
|
2502
|
+
await runNodeDaemonRestart(opts);
|
|
2503
|
+
});
|
|
2504
|
+
}
|
|
2505
|
+
//#endregion
|
|
2506
|
+
export { registerNodeCli };
|