@pixelzx/genesis 2026.6.4-1 → 2026.6.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 +7 -0
- package/dist/.buildstamp +1 -1
- package/dist/abort-CcNxEsSq.js +201 -0
- package/dist/abort.runtime-DZJDSf0d.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/accounts-B7M6y8l8.js +107 -0
- package/dist/accounts-DddcYo7u.js +2 -0
- package/dist/accounts-v0Cqfnse.js +104 -0
- package/dist/acp-cli-D_2_Nim8.js +2193 -0
- package/dist/acp-spawn-BZPupfsZ.js +2 -0
- package/dist/acp-spawn-CWfIrbK7.js +1093 -0
- package/dist/acp-stateful-target-driver-DpCTjH5T.js +89 -0
- package/dist/action-agents-fjIM4rpc.js +67 -0
- package/dist/action-focus-cx1pm1ym.js +132 -0
- package/dist/action-help-DtyAnULB.js +7 -0
- package/dist/action-info-DF30-xZl.js +101 -0
- package/dist/action-kill-rsSdXzvX.js +33 -0
- package/dist/action-list-4VN835m2.js +21 -0
- package/dist/action-log-L032mq5B.js +30 -0
- package/dist/action-send-Dm62UP-n.js +39 -0
- package/dist/action-spawn-BuZHKlpL.js +47 -0
- package/dist/action-unfocus-CTIWf8WX.js +29 -0
- package/dist/actions.runtime-0ezEcm7K.js +18 -0
- package/dist/actions.runtime-DKsCTTnH.js +5 -0
- package/dist/actions.runtime.js +1 -1
- package/dist/agent-BTOBOCIw.js +2 -0
- package/dist/agent-command-C-_EFUUu.js +874 -0
- package/dist/agent-harness-runtime-Bye6j3EL.js +144 -0
- package/dist/agent-runner-utils-CX2vCMkx.js +239 -0
- package/dist/agent-runner.runtime-BBqrjZv4.js +3455 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-D1LIGcNj.js +18 -0
- package/dist/agents-CME2O1l9.js +5 -0
- package/dist/agents-DsDQvAPy.js +954 -0
- package/dist/aliases-C807OidC.js +2 -0
- package/dist/aliases-jq1ap6Dz.js +96 -0
- package/dist/api-BbxKoRkD.js +3 -0
- package/dist/api-CwJPCW9U.js +139 -0
- package/dist/api-N5Kaaq64.js +5 -0
- package/dist/approval-gateway-resolver-DIPFgTnx.js +29 -0
- package/dist/approval-gateway-runtime-i0yziXk2.js +2 -0
- package/dist/approval-handler-runtime-Cdm-10f9.js +439 -0
- package/dist/approval-native-runtime-BRjeBoqL.js +729 -0
- package/dist/attempt-execution.runtime-NFTF7Cbt.js +509 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt.prompt-helpers-DuBXv46v.js +221 -0
- package/dist/attempt.tool-run-context-Qf-tbC-C.js +933 -0
- package/dist/audit-DsDfRhB8.js +939 -0
- package/dist/audit.runtime-ComjcUGJ.js +7 -0
- package/dist/audit.runtime.js +1 -1
- package/dist/auth-BT_gqC-D.js +2 -0
- package/dist/auth-DeUz_8w8.js +383 -0
- package/dist/auth-order-DM7UkPDa.js +96 -0
- package/dist/auth-order-yS8hXrXh.js +2 -0
- package/dist/bash-tools-D0M9gBDu.js +3 -0
- package/dist/bash-tools-tnj1gSbO.js +2824 -0
- package/dist/binding-routing-C7atXiTD.js +85 -0
- package/dist/binding-targets-CCv7agx9.js +121 -0
- package/dist/bridge-server-C5O9rTJg.js +113 -0
- package/dist/browser-control-auth-GGN_kbqE.js +2 -0
- package/dist/browser-node-runtime-B-uTSVqP.js +12 -0
- package/dist/browser-profiles-Dex2eaLH.js +2 -0
- package/dist/browser-runtime-BPocB6yO.js +387 -0
- package/dist/browser-setup-tools-gHfYeDWA.js +13 -0
- package/dist/build-BqG7RkBz.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-BI4JvjcR.js +3 -0
- package/dist/call-wY43fzOF.js +331 -0
- package/dist/call.runtime-Dh61oVeL.js +2 -0
- package/dist/call.runtime.js +1 -1
- package/dist/capability-cli-BHz-2Stx.js +1401 -0
- package/dist/catchup-Be7tHJwK.js +300 -0
- package/dist/channel-B-6VmF4-.js +840 -0
- package/dist/channel-BCJccV-O.js +226 -0
- package/dist/channel-BDZqLbod.js +1100 -0
- package/dist/channel-BQDNgTea.js +1174 -0
- package/dist/channel-BwjThGwK.js +453 -0
- package/dist/channel-CPoThmda.js +595 -0
- package/dist/channel-CUT8NJ-B.js +350 -0
- package/dist/channel-C_Y7lv8v.js +491 -0
- package/dist/channel-Ck7-C-lB.js +297 -0
- package/dist/channel-DOpVjq4i.js +1802 -0
- package/dist/channel-core-QV9-eAtb.js +5 -0
- package/dist/channel-inbound-D_tebgdx.js +31 -0
- package/dist/channel-plugin-runtime-DXcBwNNM.js +771 -0
- package/dist/channel-runtime-D4ci0o4V.js +425 -0
- package/dist/channel-sAdF_zH-.js +1320 -0
- package/dist/channel.runtime-1swLIpNV.js +89 -0
- package/dist/channel.runtime-B9hljdNF.js +4 -0
- package/dist/channel.runtime-CSbR2pni.js +430 -0
- package/dist/channel.runtime-CdpqhnLO.js +2364 -0
- package/dist/channel.runtime-DOx6WROg.js +40130 -0
- package/dist/channel.runtime-H5Kb2LbC.js +109 -0
- package/dist/channel.runtime-V7boBc_e.js +576 -0
- package/dist/channel.runtime.js +1 -1
- package/dist/channel.setup-BXyeNJ2_.js +10 -0
- package/dist/channels-KU7bwUUs.js +733 -0
- package/dist/channels-cli-CTX6_5z3.js +268 -0
- package/dist/chat-C_i6Wp50.js +2830 -0
- package/dist/clawbot-cli-CLGPtbt-.js +9 -0
- package/dist/cli/daemon-cli.js +3 -3
- package/dist/cli-BhwHu1dK.js +72 -0
- package/dist/cli-CFsq8f2H.js +2 -0
- package/dist/cli-CNVlwurq.js +219 -0
- package/dist/cli-DLP8hKbi.js +2 -0
- package/dist/cli-runner-BbNBHV6v.js +286 -0
- package/dist/cli-runner.runtime-CfPaauuM.js +4 -0
- package/dist/cli-runner.runtime-MxBlCOO2.js +3 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +2 -2
- package/dist/cli.runtime-3cD-pSyn.js +1261 -0
- package/dist/cli.runtime.js +1 -1
- package/dist/client-Bl0d_7ak.js +138 -0
- package/dist/client-ClJyHgmq.js +713 -0
- package/dist/command-auth-DO32coey.js +76 -0
- package/dist/command-config-resolution-CAsa4fGg.js +2 -0
- package/dist/command-config-resolution-D6YcwuRh.js +23 -0
- package/dist/command-config-resolution.runtime-CSHDu35A.js +2 -0
- package/dist/command-config-resolution.runtime.js +1 -1
- package/dist/command-registry-BJEQrMqR.js +4 -0
- package/dist/command-registry-DI9i95nj.js +9 -0
- package/dist/command-registry-core-BpF1mggD.js +106 -0
- package/dist/command-secret-gateway-DDNHxysD.js +528 -0
- package/dist/command-status.runtime-DqYUCcEA.js +87 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-acp-C_zCJPvL.js +77 -0
- package/dist/commands-compact.runtime-B6e3kwMS.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-handlers.runtime-B0gTkAC0.js +4599 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-status-BgZ64sA8.js +16 -0
- package/dist/commands-status.runtime-JI89gIEU.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-B0hdcBxr.js +2 -0
- package/dist/commands-subagents-control.runtime-DUeSQ5j4.js +3 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-B7moUaCI.js +158 -0
- package/dist/commands-system-prompt-DTUkp9TH.js +2 -0
- package/dist/commands.runtime-BjCVVqol.js +167 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/compact-BNJH56SX.js +1118 -0
- package/dist/compact.runtime-CYI8Yi9d.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-Bb1Tk-vM.js +328 -0
- package/dist/config-DxkleHmo.js +252 -0
- package/dist/config-cli-CtaRB_f8.js +1078 -0
- package/dist/configure-Bp8WFryM.js +1252 -0
- package/dist/configure-DQ_X5zyT.js +2 -0
- package/dist/connect-options-BkWD0Wvv.js +699 -0
- package/dist/control-auth-Iqyldslx.js +125 -0
- package/dist/control-service-xIhkqyZE.js +156 -0
- package/dist/conversation-id-BZtOqHIz.js +38 -0
- package/dist/conversation-id-D1Q9qPFH.js +235 -0
- package/dist/conversation-runtime-B1QZ-DEM.js +31 -0
- package/dist/core-BdVAy0Wv.js +275 -0
- package/dist/cron-cli-BWM2kRKU.js +713 -0
- package/dist/daemon-cli-MRl5nyuF.js +12 -0
- package/dist/dashboard-BkdlJrnf.js +2 -0
- package/dist/dashboard-C9m86rHv.js +81 -0
- package/dist/delegate-BjUvKQlo.js +64 -0
- package/dist/detached-task-runtime-BAEzkNB8.js +73 -0
- package/dist/devices-cli-B1n6tl9f.js +498 -0
- package/dist/diagnostics-DZxWkW3i.js +154 -0
- package/dist/direct-dm-qw-uk31C.js +64 -0
- package/dist/dispatch-D0xiJ6Up.js +1131 -0
- package/dist/dispatch-acp-DVN58m9G.js +981 -0
- package/dist/dispatch-acp-manager.runtime-C8t1i5Wt.js +3 -0
- package/dist/dispatch-acp-manager.runtime.js +1 -1
- package/dist/dispatch-acp.runtime-FR0DUPpn.js +19 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/doctor-device-pairing-DIbiBPlL.js +307 -0
- package/dist/doctor-gateway-daemon-flow-BFjRlXvA.js +250 -0
- package/dist/doctor-gateway-health-uZrukX3c.js +63 -0
- package/dist/doctor-health-DKpg1bxM.js +59 -0
- package/dist/doctor-health-contributions-BoXX8ubw.js +493 -0
- package/dist/doctor-prompter-CLf5Uf10.js +56 -0
- package/dist/doctor-workspace-status-Cw61BbGy.js +75 -0
- package/dist/dreaming-Bk8dVfGi.js +1574 -0
- package/dist/dreaming-narrative-DGSQa-0N.js +595 -0
- package/dist/embedded-gateway-stub.runtime-sokWrs6B.js +9 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/entry.js +2 -2
- package/dist/exec-approvals-cli-CnNETs_u.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-BwNexEVP.js +31 -0
- package/dist/fallbacks-GwVAaFt5.js +2 -0
- package/dist/fallbacks-shared-DmepG9Mq.js +111 -0
- package/dist/gateway-BB4hdlYm.js +115 -0
- package/dist/gateway-cli-Bzz62NC8.js +1283 -0
- package/dist/gateway-rpc-dyJV2osv.js +14 -0
- package/dist/gateway-rpc.runtime-DYVOEv4W.js +23 -0
- package/dist/gateway-rpc.runtime.js +1 -1
- package/dist/gateway-runtime-CqSQCYo0.js +15 -0
- package/dist/gateway-status-DdCiwrPt.js +584 -0
- package/dist/genesis-tools-Bh6dAUhK.js +9166 -0
- package/dist/genesis-tools.runtime-CiIUponP.js +2 -0
- package/dist/genesis-tools.runtime.js +1 -1
- package/dist/get-reply-from-config.runtime-Cu2DcwOW.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/get-reply-qVmTjhwr.js +3897 -0
- package/dist/graph-users-kkSJYBNX.js +1337 -0
- package/dist/health-CFyVDYng.js +469 -0
- package/dist/health-Cl371mu8.js +3 -0
- package/dist/health-route-D0IspgUK.js +41 -0
- package/dist/health-route-D2tFKCLv.js +2 -0
- package/dist/heartbeat-runner-Bmi8YsXz.js +5 -0
- package/dist/heartbeat-runner-FSCWra2R.js +1292 -0
- package/dist/heartbeat-runner.runtime-QF8dg4j-.js +4 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/hooks-cli-DYoG7Dz1.js +433 -0
- package/dist/image-fallbacks-5ckuJ46I.js +31 -0
- package/dist/image-fallbacks-DYnqzK01.js +2 -0
- package/dist/inbound-reply-dispatch-D5pqDZRa.js +73 -0
- package/dist/index.js +2 -2
- package/dist/infra-runtime-D08WIqN2.js +39 -0
- package/dist/init-BCgwiSZj.js +59 -0
- package/dist/library-CP9n_7AP.js +45 -0
- package/dist/lifecycle-BYam90xH.js +229 -0
- package/dist/lifecycle-DS58sNmu.js +571 -0
- package/dist/lifecycle.runtime-DMwss7xM.js +2 -0
- package/dist/lifecycle.runtime.js +1 -1
- package/dist/list-CASc4IWz.js +131 -0
- package/dist/list-CBPrBS2u.js +1212 -0
- package/dist/list-Cf7fcqQd.js +2 -0
- package/dist/list-Dqd2QyTH.js +2 -0
- package/dist/list.probe-BWcMSWDF.js +419 -0
- package/dist/llm-slug-generator-4LADFhXT.js +79 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/load-config-DI-LDL6p.js +35 -0
- package/dist/local-dispatch.runtime-WDgraH3j.js +8 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/logs-cli-zoBIelUH.js +265 -0
- package/dist/logs-cli.runtime-DxKNxXAz.js +2 -0
- package/dist/logs-cli.runtime.js +1 -1
- package/dist/main-session-restart-recovery-DWZfkOzH.js +206 -0
- package/dist/managed-image-attachments-DLDa1aE2.js +2 -0
- package/dist/managed-image-attachments-a4v60Bk3.js +635 -0
- package/dist/manager-CfUcsSI9.js +2057 -0
- package/dist/manager-DmBBLCOg.js +2 -0
- package/dist/markdown-to-line-B0mPruD_.js +790 -0
- package/dist/mcp/plugin-tools-serve.js +1 -1
- package/dist/mcp-cli-CLL9nfvE.js +725 -0
- package/dist/mcp-http-p7GbtbMx.js +529 -0
- package/dist/memory-core-host-runtime-cli-CZNYkDoE.js +9 -0
- package/dist/message-CRyNLXch.js +232 -0
- package/dist/message-action-runner-5Y4EFpWh.js +1407 -0
- package/dist/message-action-runner-Dxv-GXkn.js +2 -0
- package/dist/message-actions-DtoR6Mr2.js +143 -0
- package/dist/message.gateway.runtime-RI4cvk_E.js +2 -0
- package/dist/message.gateway.runtime.js +1 -1
- package/dist/models-auth-status-DsheCXaS.js +201 -0
- package/dist/models-cli-CQQG1U-p.js +219 -0
- package/dist/monitor-BRRSjPQY.js +1459 -0
- package/dist/monitor-Ch-cG7Si.js +1661 -0
- package/dist/monitor-ChBhfnC-.js +788 -0
- package/dist/monitor-CsvCTpjq.js +671 -0
- package/dist/monitor-DjemBuVh.js +1237 -0
- package/dist/monitor-LyGEO-KI.js +2 -0
- package/dist/monitor-auth-DVCdDwlp.js +207 -0
- package/dist/monitor-processing-Cib3ZjUe.js +1974 -0
- package/dist/monitor.runtime-DLBFALbV.js +2 -0
- package/dist/monitor.runtime.js +1 -1
- package/dist/monitor.webhook-Dktr8JA-.js +180 -0
- package/dist/msteams-G5I2CO13.js +35 -0
- package/dist/native-hook-relay-B1ArNeG5.js +519 -0
- package/dist/nextcloud-talk-DimOAfaR.js +17 -0
- package/dist/node-cli-RIjV0id4.js +2276 -0
- package/dist/nodes-cli-Cke-B80I.js +1046 -0
- package/dist/nodes-utils-CsTqKwN9.js +84 -0
- package/dist/nodes.helpers-DYpGCFer.js +34 -0
- package/dist/notify-zBChwf0-.js +315 -0
- package/dist/onboard-D6UawRld.js +2 -0
- package/dist/onboard-DfoCtk3_.js +70 -0
- package/dist/onboard-helpers-BKQMe3RX.js +6 -0
- package/dist/onboard-helpers-BLBJlQ50.js +204 -0
- package/dist/onboard-interactive-GAbQD437.js +24 -0
- package/dist/onboard-non-interactive-Bqi-JXh3.js +635 -0
- package/dist/onboard-remote-CNpTyVws.js +193 -0
- package/dist/onboard-remote-GFp2lT6Y.js +2 -0
- package/dist/onboard-skills-BQneolfo.js +2 -0
- package/dist/onboard-skills-BipqJ48b.js +134 -0
- package/dist/openai-http-CLDWjSKC.js +500 -0
- package/dist/openresponses-http-DNvXNiw_.js +1128 -0
- package/dist/operator-approvals-client-gaflvETF.js +68 -0
- package/dist/outbound.runtime-ByVsvEri.js +2 -0
- package/dist/outbound.runtime.js +1 -1
- package/dist/pair-command-approve-Dzkubc-8.js +44 -0
- package/dist/persistent-bindings.lifecycle-BhdRK7Lp.js +2 -0
- package/dist/persistent-bindings.lifecycle-DQ0AiHuy.js +85 -0
- package/dist/pi-embedded-C789hs31.js +4 -0
- package/dist/pi-embedded-CXLkrOwv.js +2905 -0
- package/dist/pi-embedded.runtime-BaHYLgKa.js +4 -0
- package/dist/pi-embedded.runtime.js +1 -1
- package/dist/pi-tool-definition-adapter-DFutc0D4.js +229 -0
- package/dist/pi-tools-k60jrAVq.js +1057 -0
- package/dist/pi-tools.before-tool-call-CFy20GCz.js +2 -0
- package/dist/pi-tools.before-tool-call-DJmPOVfQ.js +433 -0
- package/dist/plugin-BfFuIgXQ.js +12195 -0
- package/dist/plugin-enabled-dXOUnZwX.js +140 -0
- package/dist/plugin-registration-CEAozQhV.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-BOpLQ8BU.js +2892 -0
- package/dist/plugins/runtime/index.js +1 -1
- package/dist/policy-DiIlt2yW.js +328 -0
- package/dist/postinstall-inventory.json +414 -414
- package/dist/prepare.runtime-Bd8adOy3.js +815 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/probe-BOlTfbzG.js +2 -0
- package/dist/probe-BSRvsN95.js +2205 -0
- package/dist/probe-CDfjQSnz.js +74 -0
- package/dist/probe-D7gHyiZV.js +241 -0
- package/dist/probe-DTNKTWSs.js +2 -0
- package/dist/probe-DcryDdZh.js +45 -0
- package/dist/probe-nyesoHxj.js +1443 -0
- package/dist/program-BFGavenz.js +111 -0
- package/dist/prompt-select-styled-BhY1zahx.js +20 -0
- package/dist/protocol-DxLbSF2J.js +2477 -0
- package/dist/provider-dispatcher-C-yy1D7r.js +22 -0
- package/dist/provider-dispatcher-ErSjESTP.js +2 -0
- package/dist/qr-cli-C1-oy_ho.js +349 -0
- package/dist/qr-cli-DmEs63Sb.js +2 -0
- package/dist/reaction-runtime-api-gua650a7.js +116 -0
- package/dist/reactions-R-rA7cXz.js +998 -0
- package/dist/register-service-commands-DkbqNKVB.js +71 -0
- package/dist/register.agent-C3nW9wDn.js +248 -0
- package/dist/register.configure-BzLHCu95.js +15 -0
- package/dist/register.maintenance-BHFQo4gr.js +363 -0
- package/dist/register.message-CsYRdfKi.js +329 -0
- package/dist/register.onboard-DltySQ6C.js +88 -0
- package/dist/register.runtime-6Sk1Njnp.js +81 -0
- package/dist/register.runtime.js +1 -1
- package/dist/register.setup-CDvVQJuj.js +150 -0
- package/dist/register.status-health-sessions-B8lorJ2x.js +1215 -0
- package/dist/register.subclis-BD4fuAci.js +3 -0
- package/dist/register.subclis-CbRd3F_m.js +29 -0
- package/dist/register.subclis-core-Dtq9dAjI.js +249 -0
- package/dist/reply-dispatch-runtime-DldslKSK.js +13 -0
- package/dist/reply-runtime-2EGTfk-1.js +11 -0
- package/dist/reply.runtime-OaHntzIS.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/restart-health-BjmfJCUM.js +202 -0
- package/dist/restart-health-hw909zlD.js +2 -0
- package/dist/root-help-_hHiERsR.js +44 -0
- package/dist/routes-BxCk7Pue.js +3341 -0
- package/dist/routes-C1_6oFmZ.js +2 -0
- package/dist/rpc-zRbkEo6W.js +61 -0
- package/dist/rpc.runtime-BZSYNDPa.js +21 -0
- package/dist/rpc.runtime.js +1 -1
- package/dist/run-delivery.runtime-D6YDo67d.js +530 -0
- package/dist/run-delivery.runtime.js +1 -1
- package/dist/run-embedded.runtime-BsgPrPDa.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-CggaHhrJ.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime-CKkLEr_T.js +277 -0
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-main-CJYYkV6H.js +567 -0
- package/dist/run-subagent-registry.runtime-B0sgf_oy.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/run-wait-DHizeptL.js +135 -0
- package/dist/runtime-EtV_ChXX.js +9 -0
- package/dist/runtime-api-6H864Pmt.js +9 -0
- package/dist/runtime-api-CbZqRBZQ.js +14 -0
- package/dist/runtime-api-ZxEgu8cW.js +4 -0
- package/dist/runtime-api-j9A6jYUr.js +9 -0
- package/dist/runtime-embedded-pi.runtime-BHjCPnxo.js +2 -0
- package/dist/runtime-embedded-pi.runtime.js +1 -1
- package/dist/runtime-hvRzTSAZ.js +973 -0
- package/dist/runtime-internal-C_KZYzFK.js +2 -0
- package/dist/runtime-options-BZEOCnMg.js +275 -0
- package/dist/runtime-schema-R7LWe58K.js +28576 -0
- package/dist/scan-BNDE3dSE.js +523 -0
- package/dist/scan-TG6lVEQ2.js +2 -0
- package/dist/secrets-cli-twD2FWoZ.js +2101 -0
- package/dist/security-cli-Cd1A5yhL.js +486 -0
- package/dist/selection-CqqmU0Hi.js +7764 -0
- package/dist/selection-CsM62vcz.js +2 -0
- package/dist/send-D-EgB64m.js +156 -0
- package/dist/send-DPk5hW1W.js +102 -0
- package/dist/send.runtime-3QDkKN71.js +2 -0
- package/dist/send.runtime.js +1 -1
- package/dist/server-C94r_Qff.js +77 -0
- package/dist/server-Ceiopn_v.js +13 -0
- package/dist/server-context-BFJlu5HY.js +2 -0
- package/dist/server-context-PNEqhnTM.js +847 -0
- package/dist/server-node-events-QOAWLsDC.js +481 -0
- package/dist/server-plugin-bootstrap-CgsjzB17.js +2 -0
- package/dist/server-plugin-bootstrap-Dfuf75EN.js +12728 -0
- package/dist/server-restart-sentinel-BMPqZ7Jw.js +697 -0
- package/dist/server.impl-CCoQpvB7.js +12864 -0
- package/dist/session-kill-http-oPi3ajEp.js +110 -0
- package/dist/session-reset-service-CzDd6PBK.js +497 -0
- package/dist/session-route-DUOQE8-f.js +93 -0
- package/dist/session-status.runtime-W5tlGbXw.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-yoYn1awK.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-DkeCaT-2.js +581 -0
- package/dist/session-visibility-B4CFjv43.js +147 -0
- package/dist/sessions-helpers-CDfOVWe3.js +305 -0
- package/dist/sessions-history-http-QXeTdxXM.js +383 -0
- package/dist/sessions-patch-xb4bXPwh.js +309 -0
- package/dist/sessions-resolve-BPlrW8C3.js +174 -0
- package/dist/sessions.runtime-yYJXudA9.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/setup-0Im0LL1d.js +636 -0
- package/dist/setup-api-BxwfqXN-.js +29 -0
- package/dist/setup-core-BWwXgEuM.js +171 -0
- package/dist/setup-core-DzHNbQLG.js +176 -0
- package/dist/setup-surface-BVnqDsfU.js +286 -0
- package/dist/setup-surface-BajZWmKz2.js +403 -0
- package/dist/setup-surface-rDO3YjSb.js +219 -0
- package/dist/setup.finalize-BsnPbdwc.js +547 -0
- package/dist/setup.gateway-config-BFawSWHL.js +250 -0
- package/dist/shared-52tFSlVk.js +121 -0
- package/dist/shared-C8ENgtxM.js +198 -0
- package/dist/shared-DbXvU7JV.js +76 -0
- package/dist/slash-state-CMuPwgKt.js +1911 -0
- package/dist/src-IzaHgU6a.js +3974 -0
- package/dist/startup-context-xJS8ckSG.js +312 -0
- package/dist/status-BO4LMTER.js +2 -0
- package/dist/status-BwY1tASe.js +3 -0
- package/dist/status-BxG6n-ko.js +397 -0
- package/dist/status-Co_cq2vy.js +2 -0
- package/dist/status-DKNeRGzW.js +190 -0
- package/dist/status-DzlIHiTS.js +209 -0
- package/dist/status-all-DF7qaWjo.js +498 -0
- package/dist/status-json-CgCilobT.js +14 -0
- package/dist/status-json-command-DAa78z3e.js +84 -0
- package/dist/status-runtime-shared-CRCuxXn_.js +257 -0
- package/dist/status-subagents.runtime-hUsBd4C5.js +18 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-BdbRrl1G.js +237 -0
- package/dist/status.gateway-connection.runtime-BmSTYFFO.js +2 -0
- package/dist/status.gateway-connection.runtime.js +1 -1
- package/dist/status.gather-CItmFIHS.js +292 -0
- package/dist/status.gather-qB6WOoH7.js +2 -0
- package/dist/status.runtime-ClZCgYx1.js +2 -0
- package/dist/status.runtime.js +1 -1
- package/dist/status.scan-overview-B0b0Mvng.js +379 -0
- package/dist/status.scan-xY7nUi9N.js +65 -0
- package/dist/status.scan.fast-json-BANGHOys.js +132 -0
- package/dist/status.scan.fast-json-M-DmMy2l.js +2 -0
- package/dist/status.summary-B3PlFnWw.js +2 -0
- package/dist/status.summary-adB75FOM.js +214 -0
- package/dist/subagent-announce-B4w7Mcpr.js +351 -0
- package/dist/subagent-announce-delivery-Dma0A4gL.js +726 -0
- package/dist/subagent-announce-output-sUPLcge-.js +364 -0
- package/dist/subagent-control-CxR0WRrx.js +506 -0
- package/dist/subagent-followup.runtime-XeFe_LA0.js +68 -0
- package/dist/subagent-followup.runtime.js +1 -1
- package/dist/subagent-orphan-recovery-CJPHy8JV.js +305 -0
- package/dist/subagent-registry-CjMWjRCE.js +1753 -0
- package/dist/subagent-registry-H20VxEu0.js +3 -0
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-spawn-CRM5x6cV.js +1005 -0
- package/dist/system-cli-BJ5mMirj.js +59 -0
- package/dist/targets-CUnlEj96.js +67 -0
- package/dist/task-executor-DKnEwQ6v.js +360 -0
- package/dist/task-owner-access-CfypP1Yc.js +74 -0
- package/dist/task-registry-delivery-runtime-BB6ZzpqH.js +2 -0
- package/dist/task-registry-delivery-runtime-CvHa0gv-.js +3 -0
- package/dist/task-registry-pQuAfAL9.js +2366 -0
- package/dist/task-registry.maintenance-Bfd87wEV.js +416 -0
- package/dist/task-registry.maintenance-VgfbW0yt.js +2 -0
- package/dist/telegram/token.js +1 -1
- package/dist/testing-C_mngO0u.js +575 -0
- package/dist/text-report-Ct6t3he6.js +587 -0
- package/dist/tool-resolution-C4KGgPH-.js +90 -0
- package/dist/tools-effective-inventory-Bo2QC-m8.js +152 -0
- package/dist/tools-invoke-http-CBZPFh5L.js +206 -0
- package/dist/trash-DhZow3jd.js +24 -0
- package/dist/tui-cli-BPdQPozP.js +4575 -0
- package/dist/update-cli-BRi3mVAU.js +1759 -0
- package/dist/upgrade-D9zejtCk.js +1226 -0
- package/dist/video-generation-task-status-BSBQ0_FO.js +163 -0
- package/dist/wait-for-idle-before-flush-D1dTT9th.js +5986 -0
- package/dist/wizard-models-ysyV_WWR.js +334 -0
- package/package.json +1 -1
- package/dist/abort-DaihtnYj.js +0 -201
- package/dist/abort.runtime-BUT9L_5l.js +0 -2
- package/dist/accounts-BY5wsBnV.js +0 -104
- package/dist/accounts-DGth1vsM.js +0 -107
- package/dist/accounts-Do6Ir-q3.js +0 -2
- package/dist/acp-cli-BHgjn8rh.js +0 -2193
- package/dist/acp-spawn-BAM_Jrft.js +0 -2
- package/dist/acp-spawn-DyBD_Y_t.js +0 -1093
- package/dist/acp-stateful-target-driver-DKGnfjWu.js +0 -89
- package/dist/action-agents-CzMSNQdc.js +0 -67
- package/dist/action-focus-CpjIrZFe.js +0 -132
- package/dist/action-help-BhE9UosK.js +0 -7
- package/dist/action-info-CH2j6dKT.js +0 -101
- package/dist/action-kill-CB4AnLIf.js +0 -33
- package/dist/action-list-CQ8LbzvR.js +0 -21
- package/dist/action-log-DZblh247.js +0 -30
- package/dist/action-send-DMe0B4FG.js +0 -39
- package/dist/action-spawn-CkKMESb5.js +0 -47
- package/dist/action-unfocus-DjQzPZwU.js +0 -29
- package/dist/actions.runtime-CUdRdpLB.js +0 -5
- package/dist/actions.runtime-CxRstWdN.js +0 -18
- package/dist/agent-command-Nh_kPL3z.js +0 -874
- package/dist/agent-harness-runtime-BEb7Wk1m.js +0 -144
- package/dist/agent-q6U-cKJn.js +0 -2
- package/dist/agent-runner-utils-x_qJ6xYC.js +0 -239
- package/dist/agent-runner.runtime-DRvTfUPd.js +0 -3455
- package/dist/agent-runtime-jSYYQd6f.js +0 -18
- package/dist/agents-BKOpsZXw.js +0 -5
- package/dist/agents-BY34ViPX.js +0 -954
- package/dist/aliases-CD5YlX7d.js +0 -2
- package/dist/aliases-Dq31zANx.js +0 -96
- package/dist/api-BhxN9fxJ.js +0 -139
- package/dist/api-DjL_3olO.js +0 -5
- package/dist/api-jIYND-S5.js +0 -3
- package/dist/approval-gateway-resolver-BfvdJW5s.js +0 -29
- package/dist/approval-gateway-runtime-BBf976nt.js +0 -2
- package/dist/approval-handler-runtime-Bq4p5wvg.js +0 -439
- package/dist/approval-native-runtime-IrisOZrU.js +0 -729
- package/dist/attempt-execution.runtime-BXGalt-_.js +0 -509
- package/dist/attempt.prompt-helpers-A-pc2LfL.js +0 -221
- package/dist/attempt.tool-run-context-Ukna4ck-.js +0 -933
- package/dist/audit-CVUpfDvE.js +0 -939
- package/dist/audit.runtime-CsuGXvud.js +0 -7
- package/dist/auth-CjcZyRUW.js +0 -383
- package/dist/auth-order-DIkyTpW4.js +0 -2
- package/dist/auth-order-Dpt1K1rT.js +0 -96
- package/dist/auth-sVuL2xeZ.js +0 -2
- package/dist/bash-tools-DDv0zQh9.js +0 -2824
- package/dist/bash-tools-s-QSvRmt.js +0 -3
- package/dist/binding-routing-Cz5R2kFK.js +0 -85
- package/dist/binding-targets-D4j2hdQh.js +0 -121
- package/dist/bridge-server-X8SdeAI3.js +0 -113
- package/dist/browser-control-auth-BrF3DZxC.js +0 -2
- package/dist/browser-node-runtime-BecPmKOx.js +0 -12
- package/dist/browser-profiles-BxAKEG3x.js +0 -2
- package/dist/browser-runtime-D9fTDscJ.js +0 -387
- package/dist/browser-setup-tools--AQGWGvl.js +0 -13
- package/dist/build-B0nbyXrw.js +0 -550
- package/dist/call-BvqN9kay.js +0 -3
- package/dist/call-Dk5rTl-p.js +0 -331
- package/dist/call.runtime-Bx1hKDwO.js +0 -2
- package/dist/capability-cli-286Z3Bq3.js +0 -1401
- package/dist/catchup-DyeQ6GNj.js +0 -300
- package/dist/channel-B5m01jSZ.js +0 -1802
- package/dist/channel-BE26v3WU.js +0 -840
- package/dist/channel-BS7r_Zt1.js +0 -226
- package/dist/channel-BUWCqkGh.js +0 -1320
- package/dist/channel-BhgKqvZn.js +0 -453
- package/dist/channel-Bx703sxQ.js +0 -297
- package/dist/channel-CDjlEQAM.js +0 -491
- package/dist/channel-ChrqAgRS.js +0 -595
- package/dist/channel-Crmp3BHh.js +0 -1100
- package/dist/channel-D7GdDfBl.js +0 -1174
- package/dist/channel-DqSzRIul.js +0 -350
- package/dist/channel-core-DIwclC34.js +0 -5
- package/dist/channel-inbound-DPW1gRUU.js +0 -31
- package/dist/channel-plugin-runtime-BJhRSlBI.js +0 -771
- package/dist/channel-runtime-sV_Sg0EO.js +0 -425
- package/dist/channel.runtime-4BaNapRW.js +0 -89
- package/dist/channel.runtime-Bk2w0Yzd.js +0 -2364
- package/dist/channel.runtime-Bo5_2imz.js +0 -109
- package/dist/channel.runtime-CdYWlMyL.js +0 -40130
- package/dist/channel.runtime-CrYmCmSw.js +0 -4
- package/dist/channel.runtime-D3APPhVs.js +0 -430
- package/dist/channel.runtime-DjF1Gg6N.js +0 -576
- package/dist/channel.setup-BxXrmAYb.js +0 -10
- package/dist/channels-DHcJgMnw.js +0 -733
- package/dist/channels-cli-Dnq08u4r.js +0 -268
- package/dist/chat-BGU3UVKD.js +0 -2830
- package/dist/clawbot-cli-C-rqJUW-.js +0 -9
- package/dist/cli-BlnGJbLJ.js +0 -219
- package/dist/cli-D0RU1q0-.js +0 -2
- package/dist/cli-DBw79G2t.js +0 -72
- package/dist/cli-Dul37_xp.js +0 -2
- package/dist/cli-runner-DY8BKEmu.js +0 -286
- package/dist/cli-runner.runtime-5JMuegF9.js +0 -3
- package/dist/cli-runner.runtime-DQROn9Ve.js +0 -4
- package/dist/cli.runtime-CGOUREQg.js +0 -1261
- package/dist/client-CCBN1ydB.js +0 -138
- package/dist/client-PHLyQ8il.js +0 -713
- package/dist/command-auth-79QKQZZ3.js +0 -76
- package/dist/command-config-resolution-BKAgMItc.js +0 -2
- package/dist/command-config-resolution-BUCAmCZ_.js +0 -23
- package/dist/command-config-resolution.runtime-BVtfeARM.js +0 -2
- package/dist/command-registry-CBBqTuqk.js +0 -4
- package/dist/command-registry-core-D4BBKYaw.js +0 -106
- package/dist/command-registry-nztgeSim.js +0 -9
- package/dist/command-secret-gateway-g0alGmKz.js +0 -528
- package/dist/command-status.runtime-Dw6Zj5hL.js +0 -87
- package/dist/commands-acp-De-XFc40.js +0 -77
- package/dist/commands-compact.runtime-6gixR2a8.js +0 -10
- package/dist/commands-handlers.runtime-DCmZAlRN.js +0 -4599
- package/dist/commands-status-CION7GYY.js +0 -16
- package/dist/commands-status.runtime-FBwoHftv.js +0 -3
- package/dist/commands-subagents-control.runtime-C2xgOYKM.js +0 -2
- package/dist/commands-subagents-control.runtime-CgIEblx3.js +0 -3
- package/dist/commands-system-prompt-B-jC-KV-.js +0 -158
- package/dist/commands-system-prompt-DeK5Jhy_.js +0 -2
- package/dist/commands.runtime-CHSb1kYa.js +0 -167
- package/dist/compact-Dwchggv2.js +0 -1118
- package/dist/compact.runtime-jDUYMSjR.js +0 -12
- package/dist/completion-cli-DLHh5B2t.js +0 -328
- package/dist/config-Bnb9qa1S.js +0 -252
- package/dist/config-cli-DReWqAE2.js +0 -1078
- package/dist/configure-BLNGlWh0.js +0 -1252
- package/dist/configure-nPzsEeOb.js +0 -2
- package/dist/connect-options-C9cvS-bh.js +0 -699
- package/dist/control-auth-D2-P54fW.js +0 -125
- package/dist/control-service-CqUPgxlx.js +0 -156
- package/dist/conversation-id-BAzJOKBB.js +0 -235
- package/dist/conversation-id-WJLKuyy9.js +0 -38
- package/dist/conversation-runtime-D8fK5aI0.js +0 -31
- package/dist/core-DywmHt1k.js +0 -275
- package/dist/cron-cli-CeEJRkfR.js +0 -713
- package/dist/daemon-cli-BZZOjJHx.js +0 -12
- package/dist/dashboard-C0NRxmP3.js +0 -81
- package/dist/dashboard-DqhPgQv-.js +0 -2
- package/dist/delegate-DwVbOeR5.js +0 -64
- package/dist/detached-task-runtime-DiDRj-v-.js +0 -73
- package/dist/devices-cli-BKVbpwVc.js +0 -498
- package/dist/diagnostics-gh3UN_iV.js +0 -154
- package/dist/direct-dm-CwHHUkHV.js +0 -64
- package/dist/dispatch-B5af8_1v.js +0 -1131
- package/dist/dispatch-acp-DgOnUWBl.js +0 -981
- package/dist/dispatch-acp-manager.runtime-XWNjVh_M.js +0 -3
- package/dist/dispatch-acp.runtime-BdYL_ZqM.js +0 -19
- package/dist/doctor-device-pairing-CtGzWmXB.js +0 -307
- package/dist/doctor-gateway-daemon-flow-CCBI0jL4.js +0 -250
- package/dist/doctor-gateway-health-CkjqPFDl.js +0 -63
- package/dist/doctor-health-BOhuy1vP.js +0 -59
- package/dist/doctor-health-contributions-ChEuyLAY.js +0 -493
- package/dist/doctor-prompter-9nOTFD0Q.js +0 -56
- package/dist/doctor-workspace-status-CO5Ocwlt.js +0 -75
- package/dist/dreaming-GOPEFPio.js +0 -1574
- package/dist/dreaming-narrative-DfxHaxOU.js +0 -595
- package/dist/embedded-gateway-stub.runtime-B2OWcbsK.js +0 -9
- package/dist/exec-approvals-cli-CGeFtFbB.js +0 -498
- package/dist/fallbacks-CdfWAgNP.js +0 -2
- package/dist/fallbacks-eXbQ8TBp.js +0 -31
- package/dist/fallbacks-shared-akcCu5CD.js +0 -111
- package/dist/gateway-D-dDKqwi.js +0 -115
- package/dist/gateway-cli-NlsKGnqx.js +0 -1283
- package/dist/gateway-rpc-Cxa8dVW5.js +0 -14
- package/dist/gateway-rpc.runtime-D76s-oxs.js +0 -23
- package/dist/gateway-runtime-Dhm_gLh1.js +0 -15
- package/dist/gateway-status-C_L_CdOg.js +0 -584
- package/dist/genesis-tools-rRJB3JXY.js +0 -9166
- package/dist/genesis-tools.runtime-6oKokqaA.js +0 -2
- package/dist/get-reply-BkiDsDVY.js +0 -3897
- package/dist/get-reply-from-config.runtime-CHKCcj9D.js +0 -2
- package/dist/graph-users-BnXIYyC5.js +0 -1337
- package/dist/health-ZsJNENSY.js +0 -3
- package/dist/health-osa9LOJf.js +0 -469
- package/dist/health-route-8TdKOYLp.js +0 -2
- package/dist/health-route-BdLtX2Bg.js +0 -41
- package/dist/heartbeat-runner-BCbkAprr.js +0 -1292
- package/dist/heartbeat-runner-Dc1K8S94.js +0 -5
- package/dist/heartbeat-runner.runtime-pJaAsgLY.js +0 -4
- package/dist/hooks-cli-C3ggAz0i.js +0 -433
- package/dist/image-fallbacks-CiSae-lb.js +0 -2
- package/dist/image-fallbacks-vI8KUh6N.js +0 -31
- package/dist/inbound-reply-dispatch-DLM60UDh.js +0 -73
- package/dist/infra-runtime-CrHVeejV.js +0 -39
- package/dist/init-BKeEiV2q.js +0 -59
- package/dist/library-CHB7yTo5.js +0 -45
- package/dist/lifecycle-CUULToPr.js +0 -229
- package/dist/lifecycle-DCMpTRD2.js +0 -571
- package/dist/lifecycle.runtime-CP4gRxWv.js +0 -2
- package/dist/list-0zDFAWTF.js +0 -2
- package/dist/list-BaxVHTAN.js +0 -131
- package/dist/list-CMRMgrPs.js +0 -1212
- package/dist/list-DSrBtnKI.js +0 -2
- package/dist/list.probe-BJYSCsJY.js +0 -419
- package/dist/llm-slug-generator-Bn_wrWYw.js +0 -79
- package/dist/load-config-qC2BWt8E.js +0 -35
- package/dist/local-dispatch.runtime-DyU7urGc.js +0 -8
- package/dist/logs-cli-zK71r_PE.js +0 -265
- package/dist/logs-cli.runtime-k0UtiaRP.js +0 -2
- package/dist/main-session-restart-recovery-DMT0Oj9a.js +0 -206
- package/dist/managed-image-attachments-B6XXE4--.js +0 -635
- package/dist/managed-image-attachments-BTzWoDWE.js +0 -2
- package/dist/manager-BCKuWA67.js +0 -2057
- package/dist/manager-rGwNUzMp.js +0 -2
- package/dist/markdown-to-line-DmPbXQA1.js +0 -790
- package/dist/mcp-cli-CYpPNMcE.js +0 -725
- package/dist/mcp-http-wiE81iKg.js +0 -529
- package/dist/memory-core-host-runtime-cli-BOSQRX1T.js +0 -9
- package/dist/message-CUDzVGD8.js +0 -232
- package/dist/message-action-runner-Dy0IpKa4.js +0 -1407
- package/dist/message-action-runner-KkBFzZdg.js +0 -2
- package/dist/message-actions-Dcdb5aSR.js +0 -143
- package/dist/message.gateway.runtime-D86fFO99.js +0 -2
- package/dist/models-auth-status-DkiX4s0b.js +0 -201
- package/dist/models-cli-CSUot1R3.js +0 -219
- package/dist/monitor-BA8ByMKR.js +0 -2
- package/dist/monitor-Bv1GIHW5.js +0 -1661
- package/dist/monitor-DTFY0ruF.js +0 -788
- package/dist/monitor-DXH-vNGn.js +0 -1459
- package/dist/monitor-Df5k8NGk.js +0 -671
- package/dist/monitor-Dk2YRF26.js +0 -1237
- package/dist/monitor-auth-CZOW753A.js +0 -207
- package/dist/monitor-processing-Clta8N4C.js +0 -1974
- package/dist/monitor.runtime-3ORbPT0X.js +0 -2
- package/dist/monitor.webhook-CRyTxENk.js +0 -180
- package/dist/msteams-BE0VieXF.js +0 -35
- package/dist/native-hook-relay-DAwGGuEx.js +0 -519
- package/dist/nextcloud-talk-DfYlTFsm.js +0 -17
- package/dist/node-cli-Bzyci_X_.js +0 -2276
- package/dist/nodes-cli-Er3OZkuk.js +0 -1046
- package/dist/nodes-utils-Cp8QZO8-.js +0 -84
- package/dist/nodes.helpers-CwKAAnRA.js +0 -34
- package/dist/notify-D_5n_vEJ.js +0 -315
- package/dist/onboard-BE82RudQ.js +0 -2
- package/dist/onboard-Bk4xL8X7.js +0 -70
- package/dist/onboard-helpers-D4WYa-6g.js +0 -204
- package/dist/onboard-helpers-MuFxPZg5.js +0 -6
- package/dist/onboard-interactive-0zmI-9ia.js +0 -24
- package/dist/onboard-non-interactive-DIRB95mT.js +0 -635
- package/dist/onboard-remote-7qR1knbU.js +0 -2
- package/dist/onboard-remote-CLmoySkk.js +0 -193
- package/dist/onboard-skills-C_873OK_.js +0 -134
- package/dist/onboard-skills-DrlBYc0t.js +0 -2
- package/dist/openai-http-DzCBqW6b.js +0 -500
- package/dist/openresponses-http-B2zgO5hQ.js +0 -1128
- package/dist/operator-approvals-client-mGBl4ptH.js +0 -68
- package/dist/outbound.runtime--HS-MxM_.js +0 -2
- package/dist/pair-command-approve-CCTSQKJH.js +0 -44
- package/dist/persistent-bindings.lifecycle-CnmqGsQf.js +0 -85
- package/dist/persistent-bindings.lifecycle-Dav1TX9E.js +0 -2
- package/dist/pi-embedded-BSKL8IgF.js +0 -4
- package/dist/pi-embedded-DMM8Pfp7.js +0 -2905
- package/dist/pi-embedded.runtime-Bv_roBVx.js +0 -4
- package/dist/pi-tool-definition-adapter-OrxjlSIM.js +0 -229
- package/dist/pi-tools-DD1YegeL.js +0 -1057
- package/dist/pi-tools.before-tool-call-J9ujp9Wp.js +0 -433
- package/dist/pi-tools.before-tool-call-hGEgKGZQ.js +0 -2
- package/dist/plugin-Cg3pHepG.js +0 -12195
- package/dist/plugin-enabled-wEQ8BQNw.js +0 -140
- package/dist/plugin-registration-DLcLJgqz.js +0 -23
- package/dist/plugin-service-BogBl5qk.js +0 -2892
- package/dist/policy-Bkh8Xtnb.js +0 -328
- package/dist/prepare.runtime-Cd31ie7u.js +0 -815
- package/dist/probe-9IM22Rkf.js +0 -2
- package/dist/probe-ButCyV3d.js +0 -1443
- package/dist/probe-D7QBUio1.js +0 -45
- package/dist/probe-DV6CWm0r.js +0 -74
- package/dist/probe-DkfetvwA.js +0 -2
- package/dist/probe-Dxo-LQjn.js +0 -2205
- package/dist/probe-nil3qQAV.js +0 -241
- package/dist/program-DHxyOl81.js +0 -111
- package/dist/prompt-select-styled-BSf77q2T.js +0 -20
- package/dist/protocol-C4I0nfuT.js +0 -2477
- package/dist/provider-dispatcher-CkiPxKIr.js +0 -22
- package/dist/provider-dispatcher-PmsHJlUO.js +0 -2
- package/dist/qr-cli-BHY0TO2W.js +0 -2
- package/dist/qr-cli-BbjDJSKp.js +0 -349
- package/dist/reaction-runtime-api-DOigJrbq.js +0 -116
- package/dist/reactions-CogkrjNr.js +0 -998
- package/dist/register-service-commands-IA3Nfza5.js +0 -71
- package/dist/register.agent-DD0aSYye.js +0 -248
- package/dist/register.configure-BOy4i7Ah.js +0 -15
- package/dist/register.maintenance-CUp6FEOF.js +0 -363
- package/dist/register.message-DezTIpNI.js +0 -329
- package/dist/register.onboard-Brpxl9p3.js +0 -88
- package/dist/register.runtime-BfH5rSb_.js +0 -81
- package/dist/register.setup-CIt4FVv0.js +0 -150
- package/dist/register.status-health-sessions-IbGZwSaG.js +0 -1215
- package/dist/register.subclis-BFQii-42.js +0 -29
- package/dist/register.subclis-DlYCyoMp.js +0 -3
- package/dist/register.subclis-core-DcfC_0CS.js +0 -249
- package/dist/reply-dispatch-runtime-Lu4Metex.js +0 -13
- package/dist/reply-runtime-CgPzru94.js +0 -11
- package/dist/reply.runtime-sw14BA5F.js +0 -2
- package/dist/restart-health-1MNBua3p.js +0 -202
- package/dist/restart-health-BWGpwgPv.js +0 -2
- package/dist/root-help-B3zoC2OP.js +0 -44
- package/dist/routes-BM6fbday.js +0 -3341
- package/dist/routes-pVc_QLiP.js +0 -2
- package/dist/rpc-BGOWS7nj.js +0 -61
- package/dist/rpc.runtime-Ca9K3sx8.js +0 -21
- package/dist/run-delivery.runtime-CabntI64.js +0 -530
- package/dist/run-embedded.runtime-Q7wrP6Qn.js +0 -4
- package/dist/run-execution-cli.runtime-CtRUFc-M.js +0 -4
- package/dist/run-executor.runtime-Nm38xsKA.js +0 -277
- package/dist/run-main-UT0zTwCg.js +0 -567
- package/dist/run-subagent-registry.runtime-D9_scMUr.js +0 -2
- package/dist/run-wait-B2K_6JNL.js +0 -135
- package/dist/runtime-BZ296jTK.js +0 -9
- package/dist/runtime-DnZsw7MB.js +0 -973
- package/dist/runtime-api-BL9vpbvb.js +0 -14
- package/dist/runtime-api-BbsLJB4C.js +0 -9
- package/dist/runtime-api-ChwFrQRw.js +0 -9
- package/dist/runtime-api-_fH7M3Qh.js +0 -4
- package/dist/runtime-embedded-pi.runtime-TOdW-E-2.js +0 -2
- package/dist/runtime-internal-DGwOFi_E.js +0 -2
- package/dist/runtime-options-CSPfxkb1.js +0 -275
- package/dist/runtime-schema-DtNq1-Zd.js +0 -28576
- package/dist/scan-D6gkNpKl.js +0 -523
- package/dist/scan-_9J5-5L6.js +0 -2
- package/dist/secrets-cli-DlVSRQPM.js +0 -2101
- package/dist/security-cli-DtzNOYL2.js +0 -486
- package/dist/selection-CBJZE_FL.js +0 -7764
- package/dist/selection-XsoEF2p2.js +0 -2
- package/dist/send-BAaDBRfi.js +0 -156
- package/dist/send-BB-M1afy.js +0 -102
- package/dist/send.runtime-CI_75KUP.js +0 -2
- package/dist/server-D58E1Cua.js +0 -77
- package/dist/server-D6rXK0fF.js +0 -13
- package/dist/server-context-D5AnCc1E.js +0 -2
- package/dist/server-context-bt09wrJu.js +0 -847
- package/dist/server-node-events-CUx4-7FL.js +0 -481
- package/dist/server-plugin-bootstrap-CBcQpYIR.js +0 -12708
- package/dist/server-plugin-bootstrap-CfkBsGUg.js +0 -2
- package/dist/server-restart-sentinel-ByFI_0MB.js +0 -697
- package/dist/server.impl-DzntNeH-.js +0 -12864
- package/dist/session-kill-http-9MoO6FXC.js +0 -110
- package/dist/session-reset-service-redPsOs-.js +0 -497
- package/dist/session-route-C8oB2UYs.js +0 -93
- package/dist/session-status.runtime-D3bYBPJe.js +0 -2
- package/dist/session-subagent-reactivation.runtime-aat7tUag.js +0 -2
- package/dist/session-tab-registry-CAJ_oDsb.js +0 -581
- package/dist/session-visibility-Dq88jJYB.js +0 -147
- package/dist/sessions-helpers-C8-IkqhO.js +0 -305
- package/dist/sessions-history-http-4Ftuwnes.js +0 -383
- package/dist/sessions-patch-BsyNHOaz.js +0 -309
- package/dist/sessions-resolve-gKLz2Bup.js +0 -174
- package/dist/sessions.runtime-C1W59rQY.js +0 -2
- package/dist/setup-DhvXyU_5.js +0 -636
- package/dist/setup-api-B9Y4qPgq.js +0 -29
- package/dist/setup-core-CdFQ6ZXC.js +0 -176
- package/dist/setup-core-kXUD3Kat.js +0 -171
- package/dist/setup-surface-BFL9WfBs.js +0 -219
- package/dist/setup-surface-Cxg_nSWc.js +0 -286
- package/dist/setup-surface-DbooMj782.js +0 -403
- package/dist/setup.finalize-CKxukDYi.js +0 -547
- package/dist/setup.gateway-config-BhEtXwaB.js +0 -250
- package/dist/shared-BNVKrp5y.js +0 -76
- package/dist/shared-CM3mnx7z.js +0 -198
- package/dist/shared-CfrsSVhL.js +0 -121
- package/dist/slash-state-2Z-om57Q.js +0 -1911
- package/dist/src-DAoKvK_N.js +0 -3974
- package/dist/startup-context-CtYAdYwd.js +0 -312
- package/dist/status-B2M0Imij.js +0 -3
- package/dist/status-Bd-BNmiE.js +0 -2
- package/dist/status-D6nbpHFi.js +0 -397
- package/dist/status-MByUxUGu.js +0 -209
- package/dist/status-QUjO1tkz.js +0 -2
- package/dist/status-all-DPa-BiHk.js +0 -498
- package/dist/status-erNo8YmW.js +0 -190
- package/dist/status-json-command-C9rbAyj-.js +0 -84
- package/dist/status-json-tO3CQXIQ.js +0 -14
- package/dist/status-runtime-shared-DmBB_gmT.js +0 -257
- package/dist/status-subagents.runtime-BXAZr5y0.js +0 -18
- package/dist/status-text-BCeYk0-q.js +0 -237
- package/dist/status.gateway-connection.runtime-bt35dapy.js +0 -2
- package/dist/status.gather-B9a-CEev.js +0 -292
- package/dist/status.gather-ahBLFzk6.js +0 -2
- package/dist/status.runtime-BrErwtfc.js +0 -2
- package/dist/status.scan-D2mvM4II.js +0 -65
- package/dist/status.scan-overview-uOOaqp1t.js +0 -379
- package/dist/status.scan.fast-json-C9dkN28s.js +0 -2
- package/dist/status.scan.fast-json-DY3Or8S4.js +0 -132
- package/dist/status.summary-Cf4p2BPK.js +0 -2
- package/dist/status.summary-DxfZCcNa.js +0 -214
- package/dist/subagent-announce-CyQZsAIm.js +0 -351
- package/dist/subagent-announce-delivery-CgdPNjMA.js +0 -726
- package/dist/subagent-announce-output-D1xi4Tk1.js +0 -364
- package/dist/subagent-control-D-O6I8Mt.js +0 -506
- package/dist/subagent-followup.runtime-BbA7NPAq.js +0 -68
- package/dist/subagent-orphan-recovery-C6_cmAyE.js +0 -305
- package/dist/subagent-registry-Dn_XpDh0.js +0 -1753
- package/dist/subagent-registry-DodFw3pu.js +0 -3
- package/dist/subagent-spawn-Dw5lttXp.js +0 -1005
- package/dist/system-cli-CSqO2Z4K.js +0 -59
- package/dist/targets-CMdwh9lR.js +0 -67
- package/dist/task-executor-DgZSfcBk.js +0 -360
- package/dist/task-owner-access-9c38idlo.js +0 -74
- package/dist/task-registry-Z-lBPkNj.js +0 -2366
- package/dist/task-registry-delivery-runtime-DOV4qoj4.js +0 -2
- package/dist/task-registry-delivery-runtime-EATr0C3C.js +0 -3
- package/dist/task-registry.maintenance-C1YMEwhk.js +0 -416
- package/dist/task-registry.maintenance-CBfaUWcp.js +0 -2
- package/dist/testing-CFk04o9M.js +0 -575
- package/dist/text-report-QhVG354o.js +0 -587
- package/dist/tool-resolution-D6V4tg-G.js +0 -90
- package/dist/tools-effective-inventory-DFU7yYvD.js +0 -152
- package/dist/tools-invoke-http-y6WIa3Ku.js +0 -206
- package/dist/trash-rhbwNhfQ.js +0 -24
- package/dist/tui-cli-BfxeO4YM.js +0 -4575
- package/dist/update-cli-DaN9bvPV.js +0 -1759
- package/dist/upgrade-f5dlIxir.js +0 -1226
- package/dist/video-generation-task-status-yX54iO8n.js +0 -163
- package/dist/wait-for-idle-before-flush-mZrBNr5z.js +0 -5986
- package/dist/wizard-models-D_avLyHR.js +0 -334
|
@@ -0,0 +1,939 @@
|
|
|
1
|
+
import { a as normalizeLowercaseStringOrEmpty, s as normalizeOptionalLowercaseString } from "./string-coerce-DPP_aYVc.js";
|
|
2
|
+
import { t as formatCliCommand } from "./command-format-B3Q5KD9o.js";
|
|
3
|
+
import { _ as resolveStateDir, o as resolveConfigPath } from "./paths-Bv2rGpO9.js";
|
|
4
|
+
import { o as hasConfiguredSecretInput } from "./types.secrets-BbgGt42I.js";
|
|
5
|
+
import { n as formatPermissionRemediation, r as inspectPathPermissions, t as formatPermissionDetail } from "./audit-fs-CAyAtdeX.js";
|
|
6
|
+
import { n as resolveGatewayAuth } from "./auth-resolve-CcailHTH.js";
|
|
7
|
+
import { n as asNullableRecord } from "./record-coerce-CMKPGWB_.js";
|
|
8
|
+
import { t as DEFAULT_AGENT_ID } from "./session-key-Cj8Hd5K-.js";
|
|
9
|
+
import { i as normalizeTrustedSafeBinDirs, o as listRiskyConfiguredSafeBins } from "./exec-safe-bin-trust-DMrCONj2.js";
|
|
10
|
+
import { b as resolveAgentWorkspaceDir, x as resolveDefaultAgentId } from "./agent-scope-Duyu_T59.js";
|
|
11
|
+
import { i as resolveSandboxConfigForAgent } from "./config-DrK4DM48.js";
|
|
12
|
+
import { u as isInterpreterLikeAllowlistPattern } from "./exec-approvals-allowlist-DS_mVZe-.js";
|
|
13
|
+
import { i as resolveMergedSafeBinProfileFixtures, n as listInterpreterLikeSafeBins } from "./exec-safe-bin-runtime-policy-BiPIYfgn.js";
|
|
14
|
+
import { l as loadExecApprovals } from "./exec-approvals-D46yYaX9.js";
|
|
15
|
+
import { n as collectCoreInsecureOrDangerousFlags, t as collectEnabledInsecureOrDangerousFlags } from "./dangerous-config-flags-DGW5VErB.js";
|
|
16
|
+
import { t as DEFAULT_GATEWAY_HTTP_TOOL_DENY } from "./dangerous-tools-BWe9gZ1a.js";
|
|
17
|
+
import path from "node:path";
|
|
18
|
+
import { isIP } from "node:net";
|
|
19
|
+
//#region src/security/audit-deep-code-safety.ts
|
|
20
|
+
let auditDeepModulePromise;
|
|
21
|
+
async function loadAuditDeepModule() {
|
|
22
|
+
auditDeepModulePromise ??= import("./audit.deep.runtime-MtazbyGn.js");
|
|
23
|
+
return await auditDeepModulePromise;
|
|
24
|
+
}
|
|
25
|
+
async function collectDeepCodeSafetyFindings(params) {
|
|
26
|
+
if (!params.deep) return [];
|
|
27
|
+
const auditDeep = await loadAuditDeepModule();
|
|
28
|
+
return [...await auditDeep.collectPluginsCodeSafetyFindings({
|
|
29
|
+
stateDir: params.stateDir,
|
|
30
|
+
summaryCache: params.summaryCache
|
|
31
|
+
}), ...await auditDeep.collectInstalledSkillsCodeSafetyFindings({
|
|
32
|
+
cfg: params.cfg,
|
|
33
|
+
stateDir: params.stateDir,
|
|
34
|
+
summaryCache: params.summaryCache
|
|
35
|
+
})];
|
|
36
|
+
}
|
|
37
|
+
//#endregion
|
|
38
|
+
//#region src/security/audit-deep-probe-findings.ts
|
|
39
|
+
function collectDeepProbeFindings(params) {
|
|
40
|
+
const findings = [];
|
|
41
|
+
if (params.deep?.gateway?.attempted && !params.deep.gateway.ok) findings.push({
|
|
42
|
+
checkId: "gateway.probe_failed",
|
|
43
|
+
severity: "warn",
|
|
44
|
+
title: "Gateway probe failed (deep)",
|
|
45
|
+
detail: params.deep.gateway.error ?? "gateway unreachable",
|
|
46
|
+
remediation: `Run "${formatCliCommand("genesis status --all")}" to debug connectivity/auth, then re-run "${formatCliCommand("genesis security audit --deep")}".`
|
|
47
|
+
});
|
|
48
|
+
if (params.authWarning) findings.push({
|
|
49
|
+
checkId: "gateway.probe_auth_secretref_unavailable",
|
|
50
|
+
severity: "warn",
|
|
51
|
+
title: "Gateway probe auth SecretRef is unavailable",
|
|
52
|
+
detail: params.authWarning,
|
|
53
|
+
remediation: `Set GENESIS_GATEWAY_TOKEN/GENESIS_GATEWAY_PASSWORD in this shell or resolve the external secret provider, then re-run "${formatCliCommand("genesis security audit --deep")}".`
|
|
54
|
+
});
|
|
55
|
+
return findings;
|
|
56
|
+
}
|
|
57
|
+
//#endregion
|
|
58
|
+
//#region src/security/audit-gateway-config.ts
|
|
59
|
+
function hasNonEmptyString(value) {
|
|
60
|
+
return typeof value === "string" && value.trim().length > 0;
|
|
61
|
+
}
|
|
62
|
+
function collectGatewayConfigFindings$1(cfg, sourceConfig, env, options = {}) {
|
|
63
|
+
const findings = [];
|
|
64
|
+
const bind = typeof cfg.gateway?.bind === "string" ? cfg.gateway.bind : "loopback";
|
|
65
|
+
const tailscaleMode = cfg.gateway?.tailscale?.mode ?? "off";
|
|
66
|
+
const auth = resolveGatewayAuth({
|
|
67
|
+
authConfig: cfg.gateway?.auth,
|
|
68
|
+
tailscaleMode,
|
|
69
|
+
env
|
|
70
|
+
});
|
|
71
|
+
const controlUiEnabled = cfg.gateway?.controlUi?.enabled !== false;
|
|
72
|
+
const controlUiAllowedOrigins = (cfg.gateway?.controlUi?.allowedOrigins ?? []).map((value) => value.trim()).filter(Boolean);
|
|
73
|
+
const dangerouslyAllowHostHeaderOriginFallback = cfg.gateway?.controlUi?.dangerouslyAllowHostHeaderOriginFallback === true;
|
|
74
|
+
const trustedProxies = Array.isArray(cfg.gateway?.trustedProxies) ? cfg.gateway.trustedProxies : [];
|
|
75
|
+
const hasToken = typeof auth.token === "string" && auth.token.trim().length > 0;
|
|
76
|
+
const hasPassword = typeof auth.password === "string" && auth.password.trim().length > 0;
|
|
77
|
+
const envTokenConfigured = hasNonEmptyString(env.GENESIS_GATEWAY_TOKEN);
|
|
78
|
+
const envPasswordConfigured = hasNonEmptyString(env.GENESIS_GATEWAY_PASSWORD);
|
|
79
|
+
const tokenConfiguredFromConfig = hasConfiguredSecretInput(sourceConfig.gateway?.auth?.token, sourceConfig.secrets?.defaults);
|
|
80
|
+
const passwordConfiguredFromConfig = hasConfiguredSecretInput(sourceConfig.gateway?.auth?.password, sourceConfig.secrets?.defaults);
|
|
81
|
+
const remoteTokenConfigured = hasConfiguredSecretInput(sourceConfig.gateway?.remote?.token, sourceConfig.secrets?.defaults);
|
|
82
|
+
const explicitAuthMode = sourceConfig.gateway?.auth?.mode;
|
|
83
|
+
const tokenCanWin = hasToken || envTokenConfigured || tokenConfiguredFromConfig || remoteTokenConfigured;
|
|
84
|
+
const passwordCanWin = explicitAuthMode === "password" || explicitAuthMode !== "token" && explicitAuthMode !== "none" && explicitAuthMode !== "trusted-proxy" && !tokenCanWin;
|
|
85
|
+
const tokenConfigured = tokenCanWin;
|
|
86
|
+
const passwordConfigured = hasPassword || passwordCanWin && (envPasswordConfigured || passwordConfiguredFromConfig);
|
|
87
|
+
const hasSharedSecret = explicitAuthMode === "token" ? tokenConfigured : explicitAuthMode === "password" ? passwordConfigured : explicitAuthMode === "none" || explicitAuthMode === "trusted-proxy" ? false : tokenConfigured || passwordConfigured;
|
|
88
|
+
const hasTailscaleAuth = auth.allowTailscale && tailscaleMode === "serve";
|
|
89
|
+
const hasGatewayAuth = hasSharedSecret || hasTailscaleAuth;
|
|
90
|
+
const allowRealIpFallback = cfg.gateway?.allowRealIpFallback === true;
|
|
91
|
+
const mdnsMode = cfg.discovery?.mdns?.mode ?? "minimal";
|
|
92
|
+
const gatewayToolsAllowRaw = Array.isArray(cfg.gateway?.tools?.allow) ? cfg.gateway?.tools?.allow : [];
|
|
93
|
+
const gatewayToolsAllow = new Set(gatewayToolsAllowRaw.map((v) => normalizeOptionalLowercaseString(v) ?? "").filter(Boolean));
|
|
94
|
+
const reenabledOverHttp = DEFAULT_GATEWAY_HTTP_TOOL_DENY.filter((name) => gatewayToolsAllow.has(name));
|
|
95
|
+
if (reenabledOverHttp.length > 0) {
|
|
96
|
+
const extraRisk = bind !== "loopback" || tailscaleMode === "funnel";
|
|
97
|
+
findings.push({
|
|
98
|
+
checkId: "gateway.tools_invoke_http.dangerous_allow",
|
|
99
|
+
severity: extraRisk ? "critical" : "warn",
|
|
100
|
+
title: "Gateway HTTP /tools/invoke re-enables dangerous tools",
|
|
101
|
+
detail: `gateway.tools.allow includes ${reenabledOverHttp.join(", ")} which removes them from the default HTTP deny list. This can allow remote session spawning / control-plane actions via HTTP and increases RCE blast radius if the gateway is reachable.`,
|
|
102
|
+
remediation: "Remove these entries from gateway.tools.allow (recommended). If you keep them enabled, keep gateway.bind loopback-only (or tailnet-only), restrict network exposure, and treat the gateway token/password as full-admin."
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
if (bind !== "loopback" && !hasSharedSecret && auth.mode !== "trusted-proxy") findings.push({
|
|
106
|
+
checkId: "gateway.bind_no_auth",
|
|
107
|
+
severity: "critical",
|
|
108
|
+
title: "Gateway binds beyond loopback without auth",
|
|
109
|
+
detail: `gateway.bind="${bind}" but no gateway.auth token/password is configured.`,
|
|
110
|
+
remediation: `Set gateway.auth (token recommended) or bind to loopback.`
|
|
111
|
+
});
|
|
112
|
+
if (bind === "loopback" && controlUiEnabled && trustedProxies.length === 0) findings.push({
|
|
113
|
+
checkId: "gateway.trusted_proxies_missing",
|
|
114
|
+
severity: "warn",
|
|
115
|
+
title: "Reverse proxy headers are not trusted",
|
|
116
|
+
detail: "gateway.bind is loopback and gateway.trustedProxies is empty. If you expose the Control UI through a reverse proxy, configure trusted proxies so local-client checks cannot be spoofed.",
|
|
117
|
+
remediation: "Set gateway.trustedProxies to your proxy IPs or keep the Control UI local-only."
|
|
118
|
+
});
|
|
119
|
+
if (bind === "loopback" && controlUiEnabled && !hasGatewayAuth) findings.push({
|
|
120
|
+
checkId: "gateway.loopback_no_auth",
|
|
121
|
+
severity: "critical",
|
|
122
|
+
title: "Gateway auth missing on loopback",
|
|
123
|
+
detail: "gateway.bind is loopback but no gateway auth secret is configured. If the Control UI is exposed through a reverse proxy, unauthenticated access is possible.",
|
|
124
|
+
remediation: "Set gateway.auth (token recommended) or keep the Control UI local-only."
|
|
125
|
+
});
|
|
126
|
+
if (bind !== "loopback" && controlUiEnabled && controlUiAllowedOrigins.length === 0 && !dangerouslyAllowHostHeaderOriginFallback) findings.push({
|
|
127
|
+
checkId: "gateway.control_ui.allowed_origins_required",
|
|
128
|
+
severity: "critical",
|
|
129
|
+
title: "Non-loopback Control UI missing explicit allowed origins",
|
|
130
|
+
detail: "Control UI is enabled on a non-loopback bind but gateway.controlUi.allowedOrigins is empty. Strict origin policy requires explicit allowed origins for non-loopback deployments.",
|
|
131
|
+
remediation: "Set gateway.controlUi.allowedOrigins to full trusted origins (for example https://control.example.com). If your deployment intentionally relies on Host-header origin fallback, set gateway.controlUi.dangerouslyAllowHostHeaderOriginFallback=true."
|
|
132
|
+
});
|
|
133
|
+
if (controlUiAllowedOrigins.includes("*")) {
|
|
134
|
+
const exposed = bind !== "loopback";
|
|
135
|
+
findings.push({
|
|
136
|
+
checkId: "gateway.control_ui.allowed_origins_wildcard",
|
|
137
|
+
severity: exposed ? "critical" : "warn",
|
|
138
|
+
title: "Control UI allowed origins contains wildcard",
|
|
139
|
+
detail: "gateway.controlUi.allowedOrigins includes \"*\" which means allow any browser origin for Control UI/WebChat requests. This disables origin allowlisting and should be treated as an intentional allow-all policy.",
|
|
140
|
+
remediation: "Replace wildcard origins with explicit trusted origins (for example https://control.example.com). Do not use \"*\" outside tightly controlled local testing."
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
if (dangerouslyAllowHostHeaderOriginFallback) {
|
|
144
|
+
const exposed = bind !== "loopback";
|
|
145
|
+
findings.push({
|
|
146
|
+
checkId: "gateway.control_ui.host_header_origin_fallback",
|
|
147
|
+
severity: exposed ? "critical" : "warn",
|
|
148
|
+
title: "DANGEROUS: Host-header origin fallback enabled",
|
|
149
|
+
detail: "gateway.controlUi.dangerouslyAllowHostHeaderOriginFallback=true enables Host-header origin fallback for Control UI/WebChat websocket checks and weakens DNS rebinding protections.",
|
|
150
|
+
remediation: "Disable gateway.controlUi.dangerouslyAllowHostHeaderOriginFallback and configure explicit gateway.controlUi.allowedOrigins."
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
if (allowRealIpFallback) {
|
|
154
|
+
const hasNonLoopbackTrustedProxy = trustedProxies.some((proxy) => !isStrictLoopbackTrustedProxyEntry(proxy));
|
|
155
|
+
const exposed = bind !== "loopback" || auth.mode === "trusted-proxy" && hasNonLoopbackTrustedProxy;
|
|
156
|
+
findings.push({
|
|
157
|
+
checkId: "gateway.real_ip_fallback_enabled",
|
|
158
|
+
severity: exposed ? "critical" : "warn",
|
|
159
|
+
title: "X-Real-IP fallback is enabled",
|
|
160
|
+
detail: "gateway.allowRealIpFallback=true trusts X-Real-IP when trusted proxies omit X-Forwarded-For. Misconfigured proxies that forward client-supplied X-Real-IP can spoof source IP and local-client checks.",
|
|
161
|
+
remediation: "Keep gateway.allowRealIpFallback=false (default). Only enable this when your trusted proxy always overwrites X-Real-IP and cannot provide X-Forwarded-For."
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
if (mdnsMode === "full") {
|
|
165
|
+
const exposed = bind !== "loopback";
|
|
166
|
+
findings.push({
|
|
167
|
+
checkId: "discovery.mdns_full_mode",
|
|
168
|
+
severity: exposed ? "critical" : "warn",
|
|
169
|
+
title: "mDNS full mode can leak host metadata",
|
|
170
|
+
detail: "discovery.mdns.mode=\"full\" publishes cliPath/sshPort in local-network TXT records. This can reveal usernames, filesystem layout, and management ports.",
|
|
171
|
+
remediation: "Prefer discovery.mdns.mode=\"minimal\" (recommended) or \"off\", especially when gateway.bind is not loopback."
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
if (tailscaleMode === "funnel") findings.push({
|
|
175
|
+
checkId: "gateway.tailscale_funnel",
|
|
176
|
+
severity: "critical",
|
|
177
|
+
title: "Tailscale Funnel exposure enabled",
|
|
178
|
+
detail: `gateway.tailscale.mode="funnel" exposes the Gateway publicly; keep auth strict and treat it as internet-facing.`,
|
|
179
|
+
remediation: `Prefer tailscale.mode="serve" (tailnet-only) or set tailscale.mode="off".`
|
|
180
|
+
});
|
|
181
|
+
else if (tailscaleMode === "serve") findings.push({
|
|
182
|
+
checkId: "gateway.tailscale_serve",
|
|
183
|
+
severity: "info",
|
|
184
|
+
title: "Tailscale Serve exposure enabled",
|
|
185
|
+
detail: `gateway.tailscale.mode="serve" exposes the Gateway to your tailnet (loopback behind Tailscale).`
|
|
186
|
+
});
|
|
187
|
+
if (cfg.gateway?.controlUi?.allowInsecureAuth === true) findings.push({
|
|
188
|
+
checkId: "gateway.control_ui.insecure_auth",
|
|
189
|
+
severity: "warn",
|
|
190
|
+
title: "Control UI insecure auth toggle enabled",
|
|
191
|
+
detail: "gateway.controlUi.allowInsecureAuth=true does not bypass secure context or device identity checks; only dangerouslyDisableDeviceAuth disables Control UI device identity checks.",
|
|
192
|
+
remediation: "Disable it or switch to HTTPS (Tailscale Serve) or localhost."
|
|
193
|
+
});
|
|
194
|
+
if (cfg.gateway?.controlUi?.dangerouslyDisableDeviceAuth === true) findings.push({
|
|
195
|
+
checkId: "gateway.control_ui.device_auth_disabled",
|
|
196
|
+
severity: "critical",
|
|
197
|
+
title: "DANGEROUS: Control UI device auth disabled",
|
|
198
|
+
detail: "gateway.controlUi.dangerouslyDisableDeviceAuth=true disables device identity checks for the Control UI.",
|
|
199
|
+
remediation: "Disable it unless you are in a short-lived break-glass scenario."
|
|
200
|
+
});
|
|
201
|
+
const enabledDangerousFlags = (options.collectDangerousConfigFlags ?? collectCoreInsecureOrDangerousFlags)(cfg);
|
|
202
|
+
if (enabledDangerousFlags.length > 0) findings.push({
|
|
203
|
+
checkId: "config.insecure_or_dangerous_flags",
|
|
204
|
+
severity: "warn",
|
|
205
|
+
title: "Insecure or dangerous config flags enabled",
|
|
206
|
+
detail: `Detected ${enabledDangerousFlags.length} enabled flag(s): ${enabledDangerousFlags.join(", ")}.`,
|
|
207
|
+
remediation: "Disable these flags when not actively debugging, or keep deployment scoped to trusted/local-only networks."
|
|
208
|
+
});
|
|
209
|
+
const token = typeof auth.token === "string" && auth.token.trim().length > 0 ? auth.token.trim() : null;
|
|
210
|
+
if (auth.mode === "token" && token && token.length < 24) findings.push({
|
|
211
|
+
checkId: "gateway.token_too_short",
|
|
212
|
+
severity: "warn",
|
|
213
|
+
title: "Gateway token looks short",
|
|
214
|
+
detail: `gateway auth token is ${token.length} chars; prefer a long random token.`
|
|
215
|
+
});
|
|
216
|
+
if (auth.mode === "trusted-proxy") {
|
|
217
|
+
const trustedProxies = cfg.gateway?.trustedProxies ?? [];
|
|
218
|
+
const trustedProxyConfig = cfg.gateway?.auth?.trustedProxy;
|
|
219
|
+
findings.push({
|
|
220
|
+
checkId: "gateway.trusted_proxy_auth",
|
|
221
|
+
severity: "critical",
|
|
222
|
+
title: "Trusted-proxy auth mode enabled",
|
|
223
|
+
detail: "gateway.auth.mode=\"trusted-proxy\" delegates authentication to a reverse proxy. Ensure your proxy (Pomerium, Caddy, nginx) handles auth correctly and that gateway.trustedProxies only contains IPs of your actual proxy servers.",
|
|
224
|
+
remediation: "Verify: (1) Your proxy terminates TLS and authenticates users. (2) gateway.trustedProxies is restricted to proxy IPs only. (3) Direct access to the Gateway port is blocked by firewall. See /gateway/trusted-proxy-auth for setup guidance."
|
|
225
|
+
});
|
|
226
|
+
if (trustedProxies.length === 0) findings.push({
|
|
227
|
+
checkId: "gateway.trusted_proxy_no_proxies",
|
|
228
|
+
severity: "critical",
|
|
229
|
+
title: "Trusted-proxy auth enabled but no trusted proxies configured",
|
|
230
|
+
detail: "gateway.auth.mode=\"trusted-proxy\" but gateway.trustedProxies is empty. All requests will be rejected.",
|
|
231
|
+
remediation: "Set gateway.trustedProxies to the IP(s) of your reverse proxy."
|
|
232
|
+
});
|
|
233
|
+
if (!trustedProxyConfig?.userHeader) findings.push({
|
|
234
|
+
checkId: "gateway.trusted_proxy_no_user_header",
|
|
235
|
+
severity: "critical",
|
|
236
|
+
title: "Trusted-proxy auth missing userHeader config",
|
|
237
|
+
detail: "gateway.auth.mode=\"trusted-proxy\" but gateway.auth.trustedProxy.userHeader is not configured.",
|
|
238
|
+
remediation: "Set gateway.auth.trustedProxy.userHeader to the header name your proxy uses (e.g., \"x-forwarded-user\", \"x-pomerium-claim-email\")."
|
|
239
|
+
});
|
|
240
|
+
if ((trustedProxyConfig?.allowUsers ?? []).length === 0) findings.push({
|
|
241
|
+
checkId: "gateway.trusted_proxy_no_allowlist",
|
|
242
|
+
severity: "warn",
|
|
243
|
+
title: "Trusted-proxy auth allows all authenticated users",
|
|
244
|
+
detail: "gateway.auth.trustedProxy.allowUsers is empty, so any user authenticated by your proxy can access the Gateway.",
|
|
245
|
+
remediation: "Consider setting gateway.auth.trustedProxy.allowUsers to restrict access to specific users (e.g., [\"nick@example.com\"])."
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
if (bind !== "loopback" && auth.mode !== "trusted-proxy" && !cfg.gateway?.auth?.rateLimit) findings.push({
|
|
249
|
+
checkId: "gateway.auth_no_rate_limit",
|
|
250
|
+
severity: "warn",
|
|
251
|
+
title: "No auth rate limiting configured",
|
|
252
|
+
detail: "gateway.bind is not loopback but no gateway.auth.rateLimit is configured. Without rate limiting, brute-force auth attacks are not mitigated.",
|
|
253
|
+
remediation: "Set gateway.auth.rateLimit (e.g. { maxAttempts: 10, windowMs: 60000, lockoutMs: 300000 })."
|
|
254
|
+
});
|
|
255
|
+
return findings;
|
|
256
|
+
}
|
|
257
|
+
function isStrictLoopbackTrustedProxyEntry(entry) {
|
|
258
|
+
const candidate = entry.trim();
|
|
259
|
+
if (!candidate) return false;
|
|
260
|
+
if (!candidate.includes("/")) return candidate === "127.0.0.1" || candidate.toLowerCase() === "::1";
|
|
261
|
+
const [rawIp, rawPrefix] = candidate.split("/", 2);
|
|
262
|
+
if (!rawIp || !rawPrefix) return false;
|
|
263
|
+
const ipVersion = isIP(rawIp.trim());
|
|
264
|
+
const prefix = Number.parseInt(rawPrefix.trim(), 10);
|
|
265
|
+
if (!Number.isInteger(prefix)) return false;
|
|
266
|
+
if (ipVersion === 4) return rawIp.trim() === "127.0.0.1" && prefix === 32;
|
|
267
|
+
if (ipVersion === 6) return prefix === 128 && normalizeLowercaseStringOrEmpty(rawIp) === "::1";
|
|
268
|
+
return false;
|
|
269
|
+
}
|
|
270
|
+
//#endregion
|
|
271
|
+
//#region src/security/audit.ts
|
|
272
|
+
let channelPluginsModulePromise;
|
|
273
|
+
let auditNonDeepModulePromise;
|
|
274
|
+
let auditChannelModulePromise;
|
|
275
|
+
let pluginRegistryLoaderModulePromise;
|
|
276
|
+
let pluginMetadataRegistryLoaderModulePromise;
|
|
277
|
+
let pluginAutoEnableModulePromise;
|
|
278
|
+
let channelPluginIdsModulePromise;
|
|
279
|
+
let pluginRuntimeModulePromise;
|
|
280
|
+
let gatewayProbeDepsPromise;
|
|
281
|
+
async function loadChannelPlugins() {
|
|
282
|
+
channelPluginsModulePromise ??= import("./plugins-Crok1kUp.js");
|
|
283
|
+
return await channelPluginsModulePromise;
|
|
284
|
+
}
|
|
285
|
+
async function loadAuditNonDeepModule() {
|
|
286
|
+
auditNonDeepModulePromise ??= import("./audit.nondeep.runtime-DGkP39Gd.js");
|
|
287
|
+
return await auditNonDeepModulePromise;
|
|
288
|
+
}
|
|
289
|
+
async function loadAuditChannelModule() {
|
|
290
|
+
auditChannelModulePromise ??= import("./audit-channel.collect.runtime-SRlqk3pD.js");
|
|
291
|
+
return await auditChannelModulePromise;
|
|
292
|
+
}
|
|
293
|
+
async function loadPluginRegistryLoaderModule() {
|
|
294
|
+
pluginRegistryLoaderModulePromise ??= import("./runtime-registry-loader-C5S8eE7E.js");
|
|
295
|
+
return await pluginRegistryLoaderModulePromise;
|
|
296
|
+
}
|
|
297
|
+
async function loadPluginMetadataRegistryLoaderModule() {
|
|
298
|
+
pluginMetadataRegistryLoaderModulePromise ??= import("./metadata-registry-loader-C9Z328aX.js");
|
|
299
|
+
return await pluginMetadataRegistryLoaderModulePromise;
|
|
300
|
+
}
|
|
301
|
+
async function loadPluginAutoEnableModule() {
|
|
302
|
+
pluginAutoEnableModulePromise ??= import("./plugin-auto-enable-DFAE8WQs.js");
|
|
303
|
+
return await pluginAutoEnableModulePromise;
|
|
304
|
+
}
|
|
305
|
+
async function loadChannelPluginIdsModule() {
|
|
306
|
+
channelPluginIdsModulePromise ??= import("./channel-plugin-ids-BzvPHIML.js");
|
|
307
|
+
return await channelPluginIdsModulePromise;
|
|
308
|
+
}
|
|
309
|
+
async function loadPluginRuntimeModule() {
|
|
310
|
+
pluginRuntimeModulePromise ??= import("./runtime-DltYsSfp.js");
|
|
311
|
+
return await pluginRuntimeModulePromise;
|
|
312
|
+
}
|
|
313
|
+
async function loadGatewayProbeDeps() {
|
|
314
|
+
gatewayProbeDepsPromise ??= Promise.all([
|
|
315
|
+
import("./call-BI4JvjcR.js"),
|
|
316
|
+
import("./probe-auth-IkpI5BiS.js"),
|
|
317
|
+
import("./probe-BOlTfbzG.js")
|
|
318
|
+
]).then(([callModule, probeAuthModule, probeModule]) => ({
|
|
319
|
+
buildGatewayConnectionDetails: callModule.buildGatewayConnectionDetails,
|
|
320
|
+
resolveGatewayProbeAuthSafe: probeAuthModule.resolveGatewayProbeAuthSafe,
|
|
321
|
+
resolveGatewayProbeTarget: probeAuthModule.resolveGatewayProbeTarget,
|
|
322
|
+
probeGateway: probeModule.probeGateway
|
|
323
|
+
}));
|
|
324
|
+
return await gatewayProbeDepsPromise;
|
|
325
|
+
}
|
|
326
|
+
function countBySeverity(findings) {
|
|
327
|
+
let critical = 0;
|
|
328
|
+
let warn = 0;
|
|
329
|
+
let info = 0;
|
|
330
|
+
for (const f of findings) if (f.severity === "critical") critical += 1;
|
|
331
|
+
else if (f.severity === "warn") warn += 1;
|
|
332
|
+
else info += 1;
|
|
333
|
+
return {
|
|
334
|
+
critical,
|
|
335
|
+
warn,
|
|
336
|
+
info
|
|
337
|
+
};
|
|
338
|
+
}
|
|
339
|
+
function normalizeAllowFromList(list) {
|
|
340
|
+
if (!Array.isArray(list)) return [];
|
|
341
|
+
return list.map((v) => String(v).trim()).filter(Boolean);
|
|
342
|
+
}
|
|
343
|
+
async function collectFilesystemFindings(params) {
|
|
344
|
+
const findings = [];
|
|
345
|
+
const stateDirPerms = await inspectPathPermissions(params.stateDir, {
|
|
346
|
+
env: params.env,
|
|
347
|
+
platform: params.platform,
|
|
348
|
+
exec: params.execIcacls
|
|
349
|
+
});
|
|
350
|
+
if (stateDirPerms.ok) {
|
|
351
|
+
if (stateDirPerms.isSymlink) findings.push({
|
|
352
|
+
checkId: "fs.state_dir.symlink",
|
|
353
|
+
severity: "warn",
|
|
354
|
+
title: "State dir is a symlink",
|
|
355
|
+
detail: `${params.stateDir} is a symlink; treat this as an extra trust boundary.`
|
|
356
|
+
});
|
|
357
|
+
if (stateDirPerms.worldWritable) findings.push({
|
|
358
|
+
checkId: "fs.state_dir.perms_world_writable",
|
|
359
|
+
severity: "critical",
|
|
360
|
+
title: "State dir is world-writable",
|
|
361
|
+
detail: `${formatPermissionDetail(params.stateDir, stateDirPerms)}; other users can write into your Genesis state.`,
|
|
362
|
+
remediation: formatPermissionRemediation({
|
|
363
|
+
targetPath: params.stateDir,
|
|
364
|
+
perms: stateDirPerms,
|
|
365
|
+
isDir: true,
|
|
366
|
+
posixMode: 448,
|
|
367
|
+
env: params.env
|
|
368
|
+
})
|
|
369
|
+
});
|
|
370
|
+
else if (stateDirPerms.groupWritable) findings.push({
|
|
371
|
+
checkId: "fs.state_dir.perms_group_writable",
|
|
372
|
+
severity: "warn",
|
|
373
|
+
title: "State dir is group-writable",
|
|
374
|
+
detail: `${formatPermissionDetail(params.stateDir, stateDirPerms)}; group users can write into your Genesis state.`,
|
|
375
|
+
remediation: formatPermissionRemediation({
|
|
376
|
+
targetPath: params.stateDir,
|
|
377
|
+
perms: stateDirPerms,
|
|
378
|
+
isDir: true,
|
|
379
|
+
posixMode: 448,
|
|
380
|
+
env: params.env
|
|
381
|
+
})
|
|
382
|
+
});
|
|
383
|
+
else if (stateDirPerms.groupReadable || stateDirPerms.worldReadable) findings.push({
|
|
384
|
+
checkId: "fs.state_dir.perms_readable",
|
|
385
|
+
severity: "warn",
|
|
386
|
+
title: "State dir is readable by others",
|
|
387
|
+
detail: `${formatPermissionDetail(params.stateDir, stateDirPerms)}; consider restricting to 700.`,
|
|
388
|
+
remediation: formatPermissionRemediation({
|
|
389
|
+
targetPath: params.stateDir,
|
|
390
|
+
perms: stateDirPerms,
|
|
391
|
+
isDir: true,
|
|
392
|
+
posixMode: 448,
|
|
393
|
+
env: params.env
|
|
394
|
+
})
|
|
395
|
+
});
|
|
396
|
+
}
|
|
397
|
+
const configPerms = await inspectPathPermissions(params.configPath, {
|
|
398
|
+
env: params.env,
|
|
399
|
+
platform: params.platform,
|
|
400
|
+
exec: params.execIcacls
|
|
401
|
+
});
|
|
402
|
+
if (configPerms.ok) {
|
|
403
|
+
const skipReadablePermWarnings = configPerms.isSymlink;
|
|
404
|
+
if (configPerms.isSymlink) findings.push({
|
|
405
|
+
checkId: "fs.config.symlink",
|
|
406
|
+
severity: "warn",
|
|
407
|
+
title: "Config file is a symlink",
|
|
408
|
+
detail: `${params.configPath} is a symlink; make sure you trust its target.`
|
|
409
|
+
});
|
|
410
|
+
if (configPerms.worldWritable || configPerms.groupWritable) findings.push({
|
|
411
|
+
checkId: "fs.config.perms_writable",
|
|
412
|
+
severity: "critical",
|
|
413
|
+
title: "Config file is writable by others",
|
|
414
|
+
detail: `${formatPermissionDetail(params.configPath, configPerms)}; another user could change gateway/auth/tool policies.`,
|
|
415
|
+
remediation: formatPermissionRemediation({
|
|
416
|
+
targetPath: params.configPath,
|
|
417
|
+
perms: configPerms,
|
|
418
|
+
isDir: false,
|
|
419
|
+
posixMode: 384,
|
|
420
|
+
env: params.env
|
|
421
|
+
})
|
|
422
|
+
});
|
|
423
|
+
else if (!skipReadablePermWarnings && configPerms.worldReadable) findings.push({
|
|
424
|
+
checkId: "fs.config.perms_world_readable",
|
|
425
|
+
severity: "critical",
|
|
426
|
+
title: "Config file is world-readable",
|
|
427
|
+
detail: `${formatPermissionDetail(params.configPath, configPerms)}; config can contain tokens and private settings.`,
|
|
428
|
+
remediation: formatPermissionRemediation({
|
|
429
|
+
targetPath: params.configPath,
|
|
430
|
+
perms: configPerms,
|
|
431
|
+
isDir: false,
|
|
432
|
+
posixMode: 384,
|
|
433
|
+
env: params.env
|
|
434
|
+
})
|
|
435
|
+
});
|
|
436
|
+
else if (!skipReadablePermWarnings && configPerms.groupReadable) findings.push({
|
|
437
|
+
checkId: "fs.config.perms_group_readable",
|
|
438
|
+
severity: "warn",
|
|
439
|
+
title: "Config file is group-readable",
|
|
440
|
+
detail: `${formatPermissionDetail(params.configPath, configPerms)}; config can contain tokens and private settings.`,
|
|
441
|
+
remediation: formatPermissionRemediation({
|
|
442
|
+
targetPath: params.configPath,
|
|
443
|
+
perms: configPerms,
|
|
444
|
+
isDir: false,
|
|
445
|
+
posixMode: 384,
|
|
446
|
+
env: params.env
|
|
447
|
+
})
|
|
448
|
+
});
|
|
449
|
+
}
|
|
450
|
+
return findings;
|
|
451
|
+
}
|
|
452
|
+
function collectGatewayConfigFindings(cfg, sourceConfig, env) {
|
|
453
|
+
return collectGatewayConfigFindings$1(cfg, sourceConfig, env, { collectDangerousConfigFlags: collectEnabledInsecureOrDangerousFlags });
|
|
454
|
+
}
|
|
455
|
+
async function collectPluginSecurityAuditFindings(context) {
|
|
456
|
+
const { getActivePluginRegistry } = await loadPluginRuntimeModule();
|
|
457
|
+
let collectors = getActivePluginRegistry()?.securityAuditCollectors ?? [];
|
|
458
|
+
if (collectors.length === 0) {
|
|
459
|
+
const { applyPluginAutoEnable } = await loadPluginAutoEnableModule();
|
|
460
|
+
const autoEnabled = applyPluginAutoEnable({
|
|
461
|
+
config: context.sourceConfig,
|
|
462
|
+
env: context.env
|
|
463
|
+
});
|
|
464
|
+
const requestedPluginIds = /* @__PURE__ */ new Set();
|
|
465
|
+
for (const pluginId of Object.keys(autoEnabled.autoEnabledReasons)) {
|
|
466
|
+
const normalized = pluginId.trim();
|
|
467
|
+
if (normalized) requestedPluginIds.add(normalized);
|
|
468
|
+
}
|
|
469
|
+
for (const pluginId of autoEnabled.config.plugins?.allow ?? []) {
|
|
470
|
+
if (typeof pluginId !== "string") continue;
|
|
471
|
+
const normalized = pluginId.trim();
|
|
472
|
+
if (normalized) requestedPluginIds.add(normalized);
|
|
473
|
+
}
|
|
474
|
+
for (const [pluginId, entry] of Object.entries(autoEnabled.config.plugins?.entries ?? {})) {
|
|
475
|
+
if (entry?.enabled === false) continue;
|
|
476
|
+
const normalized = pluginId.trim();
|
|
477
|
+
if (normalized) requestedPluginIds.add(normalized);
|
|
478
|
+
}
|
|
479
|
+
if (context.includeChannelSecurity && context.plugins !== void 0) {
|
|
480
|
+
const { resolveConfiguredChannelPluginIds } = await loadChannelPluginIdsModule();
|
|
481
|
+
const auditedChannelPluginIds = new Set(context.plugins.map((plugin) => plugin.id));
|
|
482
|
+
for (const pluginId of resolveConfiguredChannelPluginIds({
|
|
483
|
+
config: autoEnabled.config,
|
|
484
|
+
activationSourceConfig: context.sourceConfig,
|
|
485
|
+
workspaceDir: context.workspaceDir,
|
|
486
|
+
env: context.env
|
|
487
|
+
})) if (auditedChannelPluginIds.has(pluginId)) requestedPluginIds.delete(pluginId);
|
|
488
|
+
}
|
|
489
|
+
if (requestedPluginIds.size === 0) return [];
|
|
490
|
+
collectors = (await loadPluginMetadataRegistryLoaderModule()).loadPluginMetadataRegistrySnapshot({
|
|
491
|
+
config: autoEnabled.config,
|
|
492
|
+
activationSourceConfig: context.sourceConfig,
|
|
493
|
+
env: context.env,
|
|
494
|
+
workspaceDir: context.workspaceDir,
|
|
495
|
+
onlyPluginIds: [...requestedPluginIds]
|
|
496
|
+
}).securityAuditCollectors ?? [];
|
|
497
|
+
}
|
|
498
|
+
return (await Promise.all(collectors.map(async (entry) => {
|
|
499
|
+
try {
|
|
500
|
+
return await entry.collector({
|
|
501
|
+
config: context.cfg,
|
|
502
|
+
sourceConfig: context.sourceConfig,
|
|
503
|
+
env: context.env,
|
|
504
|
+
stateDir: context.stateDir,
|
|
505
|
+
configPath: context.configPath
|
|
506
|
+
});
|
|
507
|
+
} catch (err) {
|
|
508
|
+
return [{
|
|
509
|
+
checkId: `plugins.${entry.pluginId}.security_audit_failed`,
|
|
510
|
+
severity: "warn",
|
|
511
|
+
title: "Plugin security audit collector failed",
|
|
512
|
+
detail: `${entry.pluginId}: ${String(err)}`
|
|
513
|
+
}];
|
|
514
|
+
}
|
|
515
|
+
}))).flat();
|
|
516
|
+
}
|
|
517
|
+
function collectLoggingFindings(cfg) {
|
|
518
|
+
if (cfg.logging?.redactSensitive !== "off") return [];
|
|
519
|
+
return [{
|
|
520
|
+
checkId: "logging.redact_off",
|
|
521
|
+
severity: "warn",
|
|
522
|
+
title: "Tool summary redaction is disabled",
|
|
523
|
+
detail: `logging.redactSensitive="off" can leak secrets into logs and status output.`,
|
|
524
|
+
remediation: `Set logging.redactSensitive="tools".`
|
|
525
|
+
}];
|
|
526
|
+
}
|
|
527
|
+
function collectElevatedFindings(cfg) {
|
|
528
|
+
const findings = [];
|
|
529
|
+
const enabled = cfg.tools?.elevated?.enabled;
|
|
530
|
+
const allowFrom = cfg.tools?.elevated?.allowFrom ?? {};
|
|
531
|
+
const anyAllowFromKeys = Object.keys(allowFrom).length > 0;
|
|
532
|
+
if (enabled === false) return findings;
|
|
533
|
+
if (!anyAllowFromKeys) return findings;
|
|
534
|
+
for (const [provider, list] of Object.entries(allowFrom)) {
|
|
535
|
+
const normalized = normalizeAllowFromList(list);
|
|
536
|
+
if (normalized.includes("*")) findings.push({
|
|
537
|
+
checkId: `tools.elevated.allowFrom.${provider}.wildcard`,
|
|
538
|
+
severity: "critical",
|
|
539
|
+
title: "Elevated exec allowlist contains wildcard",
|
|
540
|
+
detail: `tools.elevated.allowFrom.${provider} includes "*" which effectively approves everyone on that channel for elevated mode.`
|
|
541
|
+
});
|
|
542
|
+
else if (normalized.length > 25) findings.push({
|
|
543
|
+
checkId: `tools.elevated.allowFrom.${provider}.large`,
|
|
544
|
+
severity: "warn",
|
|
545
|
+
title: "Elevated exec allowlist is large",
|
|
546
|
+
detail: `tools.elevated.allowFrom.${provider} has ${normalized.length} entries; consider tightening elevated access.`
|
|
547
|
+
});
|
|
548
|
+
}
|
|
549
|
+
return findings;
|
|
550
|
+
}
|
|
551
|
+
function collectExecRuntimeFindings(cfg) {
|
|
552
|
+
const findings = [];
|
|
553
|
+
const globalExecHost = cfg.tools?.exec?.host;
|
|
554
|
+
const globalStrictInlineEval = cfg.tools?.exec?.strictInlineEval === true;
|
|
555
|
+
const defaultSandboxMode = resolveSandboxConfigForAgent(cfg).mode;
|
|
556
|
+
const defaultHostIsExplicitSandbox = globalExecHost === "sandbox";
|
|
557
|
+
const approvals = loadExecApprovals();
|
|
558
|
+
if (defaultHostIsExplicitSandbox && defaultSandboxMode === "off") findings.push({
|
|
559
|
+
checkId: "tools.exec.host_sandbox_no_sandbox_defaults",
|
|
560
|
+
severity: "warn",
|
|
561
|
+
title: "Exec host is sandbox but sandbox mode is off",
|
|
562
|
+
detail: "tools.exec.host is explicitly set to sandbox while agents.defaults.sandbox.mode=off. In this mode, exec fails closed because no sandbox runtime is available.",
|
|
563
|
+
remediation: "Enable sandbox mode (`agents.defaults.sandbox.mode=\"non-main\"` or `\"all\"`) or set tools.exec.host to \"gateway\" with approvals."
|
|
564
|
+
});
|
|
565
|
+
const agents = Array.isArray(cfg.agents?.list) ? cfg.agents.list : [];
|
|
566
|
+
const riskyAgents = agents.filter((entry) => entry && typeof entry === "object" && typeof entry.id === "string" && entry.tools?.exec?.host === "sandbox" && resolveSandboxConfigForAgent(cfg, entry.id).mode === "off").map((entry) => entry.id).slice(0, 5);
|
|
567
|
+
if (riskyAgents.length > 0) findings.push({
|
|
568
|
+
checkId: "tools.exec.host_sandbox_no_sandbox_agents",
|
|
569
|
+
severity: "warn",
|
|
570
|
+
title: "Agent exec host uses sandbox while sandbox mode is off",
|
|
571
|
+
detail: `agents.list.*.tools.exec.host is set to sandbox for: ${riskyAgents.join(", ")}. With sandbox mode off, exec fails closed for those agents.`,
|
|
572
|
+
remediation: "Enable sandbox mode for these agents (`agents.list[].sandbox.mode`) or set their tools.exec.host to \"gateway\"."
|
|
573
|
+
});
|
|
574
|
+
const effectiveExecScopes = Array.from(new Map([{
|
|
575
|
+
id: DEFAULT_AGENT_ID,
|
|
576
|
+
security: cfg.tools?.exec?.security ?? "deny",
|
|
577
|
+
host: cfg.tools?.exec?.host ?? "auto"
|
|
578
|
+
}, ...agents.filter((entry) => Boolean(entry) && typeof entry === "object" && typeof entry.id === "string").map((entry) => ({
|
|
579
|
+
id: entry.id,
|
|
580
|
+
security: entry.tools?.exec?.security ?? cfg.tools?.exec?.security ?? "deny",
|
|
581
|
+
host: entry.tools?.exec?.host ?? cfg.tools?.exec?.host ?? "auto"
|
|
582
|
+
}))].map((entry) => [entry.id, entry])).values());
|
|
583
|
+
const fullExecScopes = effectiveExecScopes.filter((entry) => entry.security === "full");
|
|
584
|
+
const execEnabledScopes = effectiveExecScopes.filter((entry) => entry.security !== "deny");
|
|
585
|
+
const openExecSurfacePaths = collectOpenExecSurfacePaths(cfg);
|
|
586
|
+
if (fullExecScopes.length > 0) findings.push({
|
|
587
|
+
checkId: "tools.exec.security_full_configured",
|
|
588
|
+
severity: openExecSurfacePaths.length > 0 ? "critical" : "warn",
|
|
589
|
+
title: "Exec security=full is configured",
|
|
590
|
+
detail: `Full exec trust is enabled for: ${fullExecScopes.map((entry) => entry.id).join(", ")}.` + (openExecSurfacePaths.length > 0 ? ` Open channel access was also detected at:\n${openExecSurfacePaths.map((entry) => `- ${entry}`).join("\n")}` : ""),
|
|
591
|
+
remediation: "Prefer tools.exec.security=\"allowlist\" with ask prompts, and reserve \"full\" for tightly scoped break-glass agents only."
|
|
592
|
+
});
|
|
593
|
+
if (openExecSurfacePaths.length > 0 && execEnabledScopes.length > 0) findings.push({
|
|
594
|
+
checkId: "security.exposure.open_channels_with_exec",
|
|
595
|
+
severity: fullExecScopes.length > 0 ? "critical" : "warn",
|
|
596
|
+
title: "Open channels can reach exec-enabled agents",
|
|
597
|
+
detail: `Open DM/group access detected at:\n${openExecSurfacePaths.map((entry) => `- ${entry}`).join("\n")}\nExec-enabled scopes:\n${execEnabledScopes.map((entry) => `- ${entry.id}: security=${entry.security}, host=${entry.host}`).join("\n")}`,
|
|
598
|
+
remediation: "Tighten dmPolicy/groupPolicy to pairing or allowlist, or disable exec for agents reachable from shared/public channels."
|
|
599
|
+
});
|
|
600
|
+
const autoAllowSkillsHits = collectAutoAllowSkillsHits(approvals);
|
|
601
|
+
if (autoAllowSkillsHits.length > 0) findings.push({
|
|
602
|
+
checkId: "tools.exec.auto_allow_skills_enabled",
|
|
603
|
+
severity: "warn",
|
|
604
|
+
title: "autoAllowSkills is enabled for exec approvals",
|
|
605
|
+
detail: `Implicit skill-bin allowlisting is enabled at:\n${autoAllowSkillsHits.map((entry) => `- ${entry}`).join("\n")}\nThis widens host exec trust beyond explicit manual allowlist entries.`,
|
|
606
|
+
remediation: "Disable autoAllowSkills in exec approvals and keep manual allowlists tight when you need explicit host-exec trust."
|
|
607
|
+
});
|
|
608
|
+
const interpreterAllowlistHits = collectInterpreterAllowlistHits({
|
|
609
|
+
approvals,
|
|
610
|
+
strictInlineEvalForAgentId: (agentId) => {
|
|
611
|
+
if (!agentId || agentId === "*" || agentId === "main") return globalStrictInlineEval;
|
|
612
|
+
return agents.find((entry) => entry?.id === agentId)?.tools?.exec?.strictInlineEval === true || globalStrictInlineEval;
|
|
613
|
+
}
|
|
614
|
+
});
|
|
615
|
+
if (interpreterAllowlistHits.length > 0) findings.push({
|
|
616
|
+
checkId: "tools.exec.allowlist_interpreter_without_strict_inline_eval",
|
|
617
|
+
severity: "warn",
|
|
618
|
+
title: "Interpreter allowlist entries are missing strictInlineEval hardening",
|
|
619
|
+
detail: `Interpreter/runtime allowlist entries were found without strictInlineEval enabled:\n${interpreterAllowlistHits.map((entry) => `- ${entry}`).join("\n")}`,
|
|
620
|
+
remediation: "Set tools.exec.strictInlineEval=true (or per-agent tools.exec.strictInlineEval=true) when allowlisting interpreters like python, node, ruby, perl, php, lua, or osascript."
|
|
621
|
+
});
|
|
622
|
+
const normalizeConfiguredSafeBins = (entries) => {
|
|
623
|
+
if (!Array.isArray(entries)) return [];
|
|
624
|
+
return Array.from(new Set(entries.map((entry) => normalizeOptionalLowercaseString(entry) ?? "").filter((entry) => entry.length > 0))).toSorted();
|
|
625
|
+
};
|
|
626
|
+
const normalizeConfiguredTrustedDirs = (entries) => {
|
|
627
|
+
if (!Array.isArray(entries)) return [];
|
|
628
|
+
return normalizeTrustedSafeBinDirs(entries.filter((entry) => typeof entry === "string"));
|
|
629
|
+
};
|
|
630
|
+
const classifyRiskySafeBinTrustedDir = (entry) => {
|
|
631
|
+
const raw = entry.trim();
|
|
632
|
+
if (!raw) return null;
|
|
633
|
+
if (!path.isAbsolute(raw)) return "relative path (trust boundary depends on process cwd)";
|
|
634
|
+
const normalized = path.resolve(raw).replace(/\\/g, "/").toLowerCase();
|
|
635
|
+
if (normalized === "/tmp" || normalized.startsWith("/tmp/") || normalized === "/var/tmp" || normalized.startsWith("/var/tmp/") || normalized === "/private/tmp" || normalized.startsWith("/private/tmp/")) return "temporary directory is mutable and easy to poison";
|
|
636
|
+
if (normalized === "/usr/local/bin" || normalized === "/opt/homebrew/bin" || normalized === "/opt/local/bin" || normalized === "/home/linuxbrew/.linuxbrew/bin") return "package-manager bin directory (often user-writable)";
|
|
637
|
+
if (normalized.startsWith("/users/") || normalized.startsWith("/home/") || normalized.includes("/.local/bin")) return "home-scoped bin directory (typically user-writable)";
|
|
638
|
+
if (/^[a-z]:\/users\//.test(normalized)) return "home-scoped bin directory (typically user-writable)";
|
|
639
|
+
return null;
|
|
640
|
+
};
|
|
641
|
+
const globalExec = cfg.tools?.exec;
|
|
642
|
+
const riskyTrustedDirHits = [];
|
|
643
|
+
const collectRiskyTrustedDirHits = (scopePath, entries) => {
|
|
644
|
+
for (const entry of normalizeConfiguredTrustedDirs(entries)) {
|
|
645
|
+
const reason = classifyRiskySafeBinTrustedDir(entry);
|
|
646
|
+
if (!reason) continue;
|
|
647
|
+
riskyTrustedDirHits.push(`- ${scopePath}.safeBinTrustedDirs: ${entry} (${reason})`);
|
|
648
|
+
}
|
|
649
|
+
};
|
|
650
|
+
collectRiskyTrustedDirHits("tools.exec", globalExec?.safeBinTrustedDirs);
|
|
651
|
+
for (const entry of agents) {
|
|
652
|
+
if (!entry || typeof entry !== "object" || typeof entry.id !== "string") continue;
|
|
653
|
+
collectRiskyTrustedDirHits(`agents.list.${entry.id}.tools.exec`, entry.tools?.exec?.safeBinTrustedDirs);
|
|
654
|
+
}
|
|
655
|
+
const interpreterHits = [];
|
|
656
|
+
const riskySemanticSafeBinHits = [];
|
|
657
|
+
const globalSafeBins = normalizeConfiguredSafeBins(globalExec?.safeBins);
|
|
658
|
+
if (globalSafeBins.length > 0) {
|
|
659
|
+
const merged = resolveMergedSafeBinProfileFixtures({ global: globalExec }) ?? {};
|
|
660
|
+
const interpreters = listInterpreterLikeSafeBins(globalSafeBins).filter((bin) => !merged[bin]);
|
|
661
|
+
if (interpreters.length > 0) interpreterHits.push(`- tools.exec.safeBins: ${interpreters.join(", ")}`);
|
|
662
|
+
for (const hit of listRiskyConfiguredSafeBins(globalSafeBins)) riskySemanticSafeBinHits.push(`- tools.exec.safeBins: ${hit.bin} (${hit.warning})`);
|
|
663
|
+
}
|
|
664
|
+
for (const entry of agents) {
|
|
665
|
+
if (!entry || typeof entry !== "object" || typeof entry.id !== "string") continue;
|
|
666
|
+
const agentExec = entry.tools?.exec;
|
|
667
|
+
const agentSafeBins = normalizeConfiguredSafeBins(agentExec?.safeBins);
|
|
668
|
+
if (agentSafeBins.length === 0) continue;
|
|
669
|
+
const merged = resolveMergedSafeBinProfileFixtures({
|
|
670
|
+
global: globalExec,
|
|
671
|
+
local: agentExec
|
|
672
|
+
}) ?? {};
|
|
673
|
+
const interpreters = listInterpreterLikeSafeBins(agentSafeBins).filter((bin) => !merged[bin]);
|
|
674
|
+
if (interpreters.length === 0) {
|
|
675
|
+
for (const hit of listRiskyConfiguredSafeBins(agentSafeBins)) riskySemanticSafeBinHits.push(`- agents.list.${entry.id}.tools.exec.safeBins: ${hit.bin} (${hit.warning})`);
|
|
676
|
+
continue;
|
|
677
|
+
}
|
|
678
|
+
interpreterHits.push(`- agents.list.${entry.id}.tools.exec.safeBins: ${interpreters.join(", ")}`);
|
|
679
|
+
for (const hit of listRiskyConfiguredSafeBins(agentSafeBins)) riskySemanticSafeBinHits.push(`- agents.list.${entry.id}.tools.exec.safeBins: ${hit.bin} (${hit.warning})`);
|
|
680
|
+
}
|
|
681
|
+
if (interpreterHits.length > 0) findings.push({
|
|
682
|
+
checkId: "tools.exec.safe_bins_interpreter_unprofiled",
|
|
683
|
+
severity: "warn",
|
|
684
|
+
title: "safeBins includes interpreter/runtime binaries without explicit profiles",
|
|
685
|
+
detail: `Detected interpreter-like safeBins entries missing explicit profiles:\n${interpreterHits.join("\n")}\nThese entries can turn safeBins into a broad execution surface when used with permissive argv profiles.`,
|
|
686
|
+
remediation: "Remove interpreter/runtime bins from safeBins (prefer allowlist entries) or define hardened tools.exec.safeBinProfiles.<bin> rules."
|
|
687
|
+
});
|
|
688
|
+
if (riskySemanticSafeBinHits.length > 0) findings.push({
|
|
689
|
+
checkId: "tools.exec.safe_bins_broad_behavior",
|
|
690
|
+
severity: "warn",
|
|
691
|
+
title: "safeBins includes binaries with broader semantics than low-risk stream filters",
|
|
692
|
+
detail: `Detected risky safeBins entries:\n${riskySemanticSafeBinHits.join("\n")}\nThese tools expose semantics that do not fit the low-risk stdin-filter fast path.`,
|
|
693
|
+
remediation: "Remove these binaries from safeBins and prefer explicit allowlist entries or approval-gated execution."
|
|
694
|
+
});
|
|
695
|
+
if (riskyTrustedDirHits.length > 0) findings.push({
|
|
696
|
+
checkId: "tools.exec.safe_bin_trusted_dirs_risky",
|
|
697
|
+
severity: "warn",
|
|
698
|
+
title: "safeBinTrustedDirs includes risky mutable directories",
|
|
699
|
+
detail: `Detected risky safeBinTrustedDirs entries:\n${riskyTrustedDirHits.slice(0, 10).join("\n")}` + (riskyTrustedDirHits.length > 10 ? `\n- +${riskyTrustedDirHits.length - 10} more entries.` : ""),
|
|
700
|
+
remediation: "Prefer root-owned immutable bins, keep default trust dirs (/bin, /usr/bin), and avoid trusting temporary/home/package-manager paths unless tightly controlled."
|
|
701
|
+
});
|
|
702
|
+
return findings;
|
|
703
|
+
}
|
|
704
|
+
function collectOpenExecSurfacePaths(cfg) {
|
|
705
|
+
const channels = asNullableRecord(cfg.channels);
|
|
706
|
+
if (!channels) return [];
|
|
707
|
+
const hits = /* @__PURE__ */ new Set();
|
|
708
|
+
const seen = /* @__PURE__ */ new WeakSet();
|
|
709
|
+
const visit = (value, scope) => {
|
|
710
|
+
const record = asNullableRecord(value);
|
|
711
|
+
if (!record || seen.has(record)) return;
|
|
712
|
+
seen.add(record);
|
|
713
|
+
if (record.groupPolicy === "open") hits.add(`${scope}.groupPolicy`);
|
|
714
|
+
if (record.dmPolicy === "open") hits.add(`${scope}.dmPolicy`);
|
|
715
|
+
for (const [key, nested] of Object.entries(record)) {
|
|
716
|
+
if (key === "groups" || key === "accounts" || key === "dms") {
|
|
717
|
+
visit(nested, `${scope}.${key}`);
|
|
718
|
+
continue;
|
|
719
|
+
}
|
|
720
|
+
if (asNullableRecord(nested)) visit(nested, `${scope}.${key}`);
|
|
721
|
+
}
|
|
722
|
+
};
|
|
723
|
+
for (const [channelId, channelValue] of Object.entries(channels)) visit(channelValue, `channels.${channelId}`);
|
|
724
|
+
return Array.from(hits).toSorted();
|
|
725
|
+
}
|
|
726
|
+
function collectAutoAllowSkillsHits(approvals) {
|
|
727
|
+
const hits = [];
|
|
728
|
+
if (approvals.defaults?.autoAllowSkills === true) hits.push("defaults.autoAllowSkills");
|
|
729
|
+
for (const [agentId, agent] of Object.entries(approvals.agents ?? {})) if (agent?.autoAllowSkills === true) hits.push(`agents.${agentId}.autoAllowSkills`);
|
|
730
|
+
return hits;
|
|
731
|
+
}
|
|
732
|
+
function collectInterpreterAllowlistHits(params) {
|
|
733
|
+
const hits = [];
|
|
734
|
+
for (const [agentId, agent] of Object.entries(params.approvals.agents ?? {})) {
|
|
735
|
+
if (!agent || params.strictInlineEvalForAgentId(agentId)) continue;
|
|
736
|
+
for (const entry of agent.allowlist ?? []) {
|
|
737
|
+
if (!isInterpreterLikeAllowlistPattern(entry.pattern)) continue;
|
|
738
|
+
hits.push(`agents.${agentId}.allowlist: ${entry.pattern}`);
|
|
739
|
+
}
|
|
740
|
+
}
|
|
741
|
+
return hits;
|
|
742
|
+
}
|
|
743
|
+
async function maybeProbeGateway(params) {
|
|
744
|
+
const { buildGatewayConnectionDetails, resolveGatewayProbeAuthSafe, resolveGatewayProbeTarget } = await loadGatewayProbeDeps();
|
|
745
|
+
const url = buildGatewayConnectionDetails({ config: params.cfg }).url;
|
|
746
|
+
const probeTarget = resolveGatewayProbeTarget(params.cfg);
|
|
747
|
+
const authResolution = resolveGatewayProbeAuthSafe({
|
|
748
|
+
cfg: params.cfg,
|
|
749
|
+
env: params.env,
|
|
750
|
+
mode: probeTarget.mode,
|
|
751
|
+
explicitAuth: params.explicitAuth
|
|
752
|
+
});
|
|
753
|
+
const res = await params.probe({
|
|
754
|
+
url,
|
|
755
|
+
auth: authResolution.auth,
|
|
756
|
+
timeoutMs: params.timeoutMs
|
|
757
|
+
}).catch((err) => ({
|
|
758
|
+
ok: false,
|
|
759
|
+
url,
|
|
760
|
+
connectLatencyMs: null,
|
|
761
|
+
error: String(err),
|
|
762
|
+
close: null,
|
|
763
|
+
health: null,
|
|
764
|
+
status: null,
|
|
765
|
+
presence: null,
|
|
766
|
+
configSnapshot: null
|
|
767
|
+
}));
|
|
768
|
+
if (authResolution.warning && !res.ok) res.error = res.error ? `${res.error}; ${authResolution.warning}` : authResolution.warning;
|
|
769
|
+
return {
|
|
770
|
+
deep: { gateway: {
|
|
771
|
+
attempted: true,
|
|
772
|
+
url,
|
|
773
|
+
ok: res.ok,
|
|
774
|
+
error: res.ok ? null : res.error,
|
|
775
|
+
close: res.close ? {
|
|
776
|
+
code: res.close.code,
|
|
777
|
+
reason: res.close.reason
|
|
778
|
+
} : null
|
|
779
|
+
} },
|
|
780
|
+
authWarning: authResolution.warning
|
|
781
|
+
};
|
|
782
|
+
}
|
|
783
|
+
async function createAuditExecutionContext(opts) {
|
|
784
|
+
const cfg = opts.config;
|
|
785
|
+
const sourceConfig = opts.sourceConfig ?? opts.config;
|
|
786
|
+
const env = opts.env ?? process.env;
|
|
787
|
+
const platform = opts.platform ?? process.platform;
|
|
788
|
+
const includeFilesystem = opts.includeFilesystem !== false;
|
|
789
|
+
const includeChannelSecurity = opts.includeChannelSecurity !== false;
|
|
790
|
+
const deep = opts.deep === true;
|
|
791
|
+
const deepTimeoutMs = Math.max(250, opts.deepTimeoutMs ?? 5e3);
|
|
792
|
+
const stateDir = opts.stateDir ?? resolveStateDir(env);
|
|
793
|
+
const configPath = opts.configPath ?? resolveConfigPath(env, stateDir);
|
|
794
|
+
const workspaceDir = opts.workspaceDir ?? resolveAgentWorkspaceDir(cfg, resolveDefaultAgentId(cfg));
|
|
795
|
+
const { readConfigSnapshotForAudit } = await loadAuditNonDeepModule();
|
|
796
|
+
const configSnapshot = includeFilesystem ? opts.configSnapshot !== void 0 ? opts.configSnapshot : await readConfigSnapshotForAudit({
|
|
797
|
+
env,
|
|
798
|
+
configPath
|
|
799
|
+
}).catch(() => null) : null;
|
|
800
|
+
return {
|
|
801
|
+
cfg,
|
|
802
|
+
sourceConfig,
|
|
803
|
+
env,
|
|
804
|
+
platform,
|
|
805
|
+
includeFilesystem,
|
|
806
|
+
includeChannelSecurity,
|
|
807
|
+
deep,
|
|
808
|
+
deepTimeoutMs,
|
|
809
|
+
stateDir,
|
|
810
|
+
configPath,
|
|
811
|
+
execIcacls: opts.execIcacls,
|
|
812
|
+
execDockerRawFn: opts.execDockerRawFn,
|
|
813
|
+
probeGatewayFn: opts.probeGatewayFn,
|
|
814
|
+
plugins: opts.plugins,
|
|
815
|
+
workspaceDir,
|
|
816
|
+
configSnapshot,
|
|
817
|
+
codeSafetySummaryCache: opts.codeSafetySummaryCache ?? /* @__PURE__ */ new Map(),
|
|
818
|
+
deepProbeAuth: opts.deepProbeAuth
|
|
819
|
+
};
|
|
820
|
+
}
|
|
821
|
+
async function runSecurityAudit(opts) {
|
|
822
|
+
const findings = [];
|
|
823
|
+
const context = await createAuditExecutionContext(opts);
|
|
824
|
+
const { cfg, env, platform, stateDir, configPath } = context;
|
|
825
|
+
const auditNonDeep = await loadAuditNonDeepModule();
|
|
826
|
+
findings.push(...auditNonDeep.collectAttackSurfaceSummaryFindings(cfg));
|
|
827
|
+
findings.push(...auditNonDeep.collectSyncedFolderFindings({
|
|
828
|
+
stateDir,
|
|
829
|
+
configPath
|
|
830
|
+
}));
|
|
831
|
+
findings.push(...collectGatewayConfigFindings(cfg, context.sourceConfig, env));
|
|
832
|
+
findings.push(...await collectPluginSecurityAuditFindings(context));
|
|
833
|
+
findings.push(...collectLoggingFindings(cfg));
|
|
834
|
+
findings.push(...collectElevatedFindings(cfg));
|
|
835
|
+
findings.push(...collectExecRuntimeFindings(cfg));
|
|
836
|
+
findings.push(...auditNonDeep.collectHooksHardeningFindings(cfg, env));
|
|
837
|
+
findings.push(...auditNonDeep.collectGatewayHttpNoAuthFindings(cfg, env));
|
|
838
|
+
findings.push(...auditNonDeep.collectGatewayHttpSessionKeyOverrideFindings(cfg));
|
|
839
|
+
findings.push(...auditNonDeep.collectSandboxDockerNoopFindings(cfg));
|
|
840
|
+
findings.push(...auditNonDeep.collectSandboxDangerousConfigFindings(cfg));
|
|
841
|
+
findings.push(...auditNonDeep.collectNodeDenyCommandPatternFindings(cfg));
|
|
842
|
+
findings.push(...auditNonDeep.collectNodeDangerousAllowCommandFindings(cfg));
|
|
843
|
+
findings.push(...auditNonDeep.collectMinimalProfileOverrideFindings(cfg));
|
|
844
|
+
findings.push(...auditNonDeep.collectSecretsInConfigFindings(cfg));
|
|
845
|
+
findings.push(...auditNonDeep.collectModelHygieneFindings(cfg));
|
|
846
|
+
findings.push(...auditNonDeep.collectSmallModelRiskFindings({
|
|
847
|
+
cfg,
|
|
848
|
+
env
|
|
849
|
+
}));
|
|
850
|
+
findings.push(...auditNonDeep.collectExposureMatrixFindings(cfg));
|
|
851
|
+
findings.push(...auditNonDeep.collectLikelyMultiUserSetupFindings(cfg));
|
|
852
|
+
if (context.includeFilesystem) {
|
|
853
|
+
findings.push(...await collectFilesystemFindings({
|
|
854
|
+
stateDir,
|
|
855
|
+
configPath,
|
|
856
|
+
env,
|
|
857
|
+
platform,
|
|
858
|
+
execIcacls: context.execIcacls
|
|
859
|
+
}));
|
|
860
|
+
if (context.configSnapshot) findings.push(...await auditNonDeep.collectIncludeFilePermFindings({
|
|
861
|
+
configSnapshot: context.configSnapshot,
|
|
862
|
+
env,
|
|
863
|
+
platform,
|
|
864
|
+
execIcacls: context.execIcacls
|
|
865
|
+
}));
|
|
866
|
+
findings.push(...await auditNonDeep.collectStateDeepFilesystemFindings({
|
|
867
|
+
cfg,
|
|
868
|
+
env,
|
|
869
|
+
stateDir,
|
|
870
|
+
platform,
|
|
871
|
+
execIcacls: context.execIcacls
|
|
872
|
+
}));
|
|
873
|
+
findings.push(...await auditNonDeep.collectWorkspaceSkillSymlinkEscapeFindings({ cfg }));
|
|
874
|
+
findings.push(...await auditNonDeep.collectSandboxBrowserHashLabelFindings({ execDockerRawFn: context.execDockerRawFn }));
|
|
875
|
+
findings.push(...await auditNonDeep.collectPluginsTrustFindings({
|
|
876
|
+
cfg,
|
|
877
|
+
stateDir
|
|
878
|
+
}));
|
|
879
|
+
findings.push(...await collectDeepCodeSafetyFindings({
|
|
880
|
+
cfg,
|
|
881
|
+
stateDir,
|
|
882
|
+
deep: context.deep,
|
|
883
|
+
summaryCache: context.codeSafetySummaryCache
|
|
884
|
+
}));
|
|
885
|
+
}
|
|
886
|
+
let shouldAuditChannelSecurity = false;
|
|
887
|
+
if (context.includeChannelSecurity) if (context.plugins !== void 0) shouldAuditChannelSecurity = true;
|
|
888
|
+
else {
|
|
889
|
+
const { hasConfiguredChannelsForReadOnlyScope, resolveConfiguredChannelPluginIds } = await loadChannelPluginIdsModule();
|
|
890
|
+
shouldAuditChannelSecurity = hasConfiguredChannelsForReadOnlyScope({
|
|
891
|
+
config: cfg,
|
|
892
|
+
activationSourceConfig: context.sourceConfig,
|
|
893
|
+
workspaceDir: context.workspaceDir,
|
|
894
|
+
env
|
|
895
|
+
}) || resolveConfiguredChannelPluginIds({
|
|
896
|
+
config: cfg,
|
|
897
|
+
activationSourceConfig: context.sourceConfig,
|
|
898
|
+
workspaceDir: context.workspaceDir,
|
|
899
|
+
env
|
|
900
|
+
}).length > 0;
|
|
901
|
+
}
|
|
902
|
+
if (shouldAuditChannelSecurity) {
|
|
903
|
+
if (context.plugins === void 0) (await loadPluginRegistryLoaderModule()).ensurePluginRegistryLoaded({
|
|
904
|
+
scope: "configured-channels",
|
|
905
|
+
config: cfg,
|
|
906
|
+
activationSourceConfig: context.sourceConfig,
|
|
907
|
+
workspaceDir: context.workspaceDir,
|
|
908
|
+
env
|
|
909
|
+
});
|
|
910
|
+
const channelPlugins = context.plugins ?? (await loadChannelPlugins()).listChannelPlugins();
|
|
911
|
+
const { collectChannelSecurityFindings } = await loadAuditChannelModule();
|
|
912
|
+
findings.push(...await collectChannelSecurityFindings({
|
|
913
|
+
cfg,
|
|
914
|
+
sourceConfig: context.sourceConfig,
|
|
915
|
+
plugins: channelPlugins
|
|
916
|
+
}));
|
|
917
|
+
}
|
|
918
|
+
const deepProbeResult = context.deep ? await maybeProbeGateway({
|
|
919
|
+
cfg,
|
|
920
|
+
env,
|
|
921
|
+
timeoutMs: context.deepTimeoutMs,
|
|
922
|
+
probe: context.probeGatewayFn ?? (await loadGatewayProbeDeps()).probeGateway,
|
|
923
|
+
explicitAuth: context.deepProbeAuth
|
|
924
|
+
}) : void 0;
|
|
925
|
+
const deep = deepProbeResult?.deep;
|
|
926
|
+
findings.push(...collectDeepProbeFindings({
|
|
927
|
+
deep,
|
|
928
|
+
authWarning: deepProbeResult?.authWarning
|
|
929
|
+
}));
|
|
930
|
+
const summary = countBySeverity(findings);
|
|
931
|
+
return {
|
|
932
|
+
ts: Date.now(),
|
|
933
|
+
summary,
|
|
934
|
+
findings,
|
|
935
|
+
deep
|
|
936
|
+
};
|
|
937
|
+
}
|
|
938
|
+
//#endregion
|
|
939
|
+
export { runSecurityAudit as t };
|