@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.
Files changed (1010) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-CcNxEsSq.js +201 -0
  4. package/dist/abort.runtime-DZJDSf0d.js +2 -0
  5. package/dist/abort.runtime.js +1 -1
  6. package/dist/accounts-B7M6y8l8.js +107 -0
  7. package/dist/accounts-DddcYo7u.js +2 -0
  8. package/dist/accounts-v0Cqfnse.js +104 -0
  9. package/dist/acp-cli-D_2_Nim8.js +2193 -0
  10. package/dist/acp-spawn-BZPupfsZ.js +2 -0
  11. package/dist/acp-spawn-CWfIrbK7.js +1093 -0
  12. package/dist/acp-stateful-target-driver-DpCTjH5T.js +89 -0
  13. package/dist/action-agents-fjIM4rpc.js +67 -0
  14. package/dist/action-focus-cx1pm1ym.js +132 -0
  15. package/dist/action-help-DtyAnULB.js +7 -0
  16. package/dist/action-info-DF30-xZl.js +101 -0
  17. package/dist/action-kill-rsSdXzvX.js +33 -0
  18. package/dist/action-list-4VN835m2.js +21 -0
  19. package/dist/action-log-L032mq5B.js +30 -0
  20. package/dist/action-send-Dm62UP-n.js +39 -0
  21. package/dist/action-spawn-BuZHKlpL.js +47 -0
  22. package/dist/action-unfocus-CTIWf8WX.js +29 -0
  23. package/dist/actions.runtime-0ezEcm7K.js +18 -0
  24. package/dist/actions.runtime-DKsCTTnH.js +5 -0
  25. package/dist/actions.runtime.js +1 -1
  26. package/dist/agent-BTOBOCIw.js +2 -0
  27. package/dist/agent-command-C-_EFUUu.js +874 -0
  28. package/dist/agent-harness-runtime-Bye6j3EL.js +144 -0
  29. package/dist/agent-runner-utils-CX2vCMkx.js +239 -0
  30. package/dist/agent-runner.runtime-BBqrjZv4.js +3455 -0
  31. package/dist/agent-runner.runtime.js +1 -1
  32. package/dist/agent-runtime-D1LIGcNj.js +18 -0
  33. package/dist/agents-CME2O1l9.js +5 -0
  34. package/dist/agents-DsDQvAPy.js +954 -0
  35. package/dist/aliases-C807OidC.js +2 -0
  36. package/dist/aliases-jq1ap6Dz.js +96 -0
  37. package/dist/api-BbxKoRkD.js +3 -0
  38. package/dist/api-CwJPCW9U.js +139 -0
  39. package/dist/api-N5Kaaq64.js +5 -0
  40. package/dist/approval-gateway-resolver-DIPFgTnx.js +29 -0
  41. package/dist/approval-gateway-runtime-i0yziXk2.js +2 -0
  42. package/dist/approval-handler-runtime-Cdm-10f9.js +439 -0
  43. package/dist/approval-native-runtime-BRjeBoqL.js +729 -0
  44. package/dist/attempt-execution.runtime-NFTF7Cbt.js +509 -0
  45. package/dist/attempt-execution.runtime.js +1 -1
  46. package/dist/attempt.prompt-helpers-DuBXv46v.js +221 -0
  47. package/dist/attempt.tool-run-context-Qf-tbC-C.js +933 -0
  48. package/dist/audit-DsDfRhB8.js +939 -0
  49. package/dist/audit.runtime-ComjcUGJ.js +7 -0
  50. package/dist/audit.runtime.js +1 -1
  51. package/dist/auth-BT_gqC-D.js +2 -0
  52. package/dist/auth-DeUz_8w8.js +383 -0
  53. package/dist/auth-order-DM7UkPDa.js +96 -0
  54. package/dist/auth-order-yS8hXrXh.js +2 -0
  55. package/dist/bash-tools-D0M9gBDu.js +3 -0
  56. package/dist/bash-tools-tnj1gSbO.js +2824 -0
  57. package/dist/binding-routing-C7atXiTD.js +85 -0
  58. package/dist/binding-targets-CCv7agx9.js +121 -0
  59. package/dist/bridge-server-C5O9rTJg.js +113 -0
  60. package/dist/browser-control-auth-GGN_kbqE.js +2 -0
  61. package/dist/browser-node-runtime-B-uTSVqP.js +12 -0
  62. package/dist/browser-profiles-Dex2eaLH.js +2 -0
  63. package/dist/browser-runtime-BPocB6yO.js +387 -0
  64. package/dist/browser-setup-tools-gHfYeDWA.js +13 -0
  65. package/dist/build-BqG7RkBz.js +550 -0
  66. package/dist/build-info.json +3 -3
  67. package/dist/bundled/boot-md/handler.js +2 -2
  68. package/dist/bundled/session-memory/handler.js +1 -1
  69. package/dist/call-BI4JvjcR.js +3 -0
  70. package/dist/call-wY43fzOF.js +331 -0
  71. package/dist/call.runtime-Dh61oVeL.js +2 -0
  72. package/dist/call.runtime.js +1 -1
  73. package/dist/capability-cli-BHz-2Stx.js +1401 -0
  74. package/dist/catchup-Be7tHJwK.js +300 -0
  75. package/dist/channel-B-6VmF4-.js +840 -0
  76. package/dist/channel-BCJccV-O.js +226 -0
  77. package/dist/channel-BDZqLbod.js +1100 -0
  78. package/dist/channel-BQDNgTea.js +1174 -0
  79. package/dist/channel-BwjThGwK.js +453 -0
  80. package/dist/channel-CPoThmda.js +595 -0
  81. package/dist/channel-CUT8NJ-B.js +350 -0
  82. package/dist/channel-C_Y7lv8v.js +491 -0
  83. package/dist/channel-Ck7-C-lB.js +297 -0
  84. package/dist/channel-DOpVjq4i.js +1802 -0
  85. package/dist/channel-core-QV9-eAtb.js +5 -0
  86. package/dist/channel-inbound-D_tebgdx.js +31 -0
  87. package/dist/channel-plugin-runtime-DXcBwNNM.js +771 -0
  88. package/dist/channel-runtime-D4ci0o4V.js +425 -0
  89. package/dist/channel-sAdF_zH-.js +1320 -0
  90. package/dist/channel.runtime-1swLIpNV.js +89 -0
  91. package/dist/channel.runtime-B9hljdNF.js +4 -0
  92. package/dist/channel.runtime-CSbR2pni.js +430 -0
  93. package/dist/channel.runtime-CdpqhnLO.js +2364 -0
  94. package/dist/channel.runtime-DOx6WROg.js +40130 -0
  95. package/dist/channel.runtime-H5Kb2LbC.js +109 -0
  96. package/dist/channel.runtime-V7boBc_e.js +576 -0
  97. package/dist/channel.runtime.js +1 -1
  98. package/dist/channel.setup-BXyeNJ2_.js +10 -0
  99. package/dist/channels-KU7bwUUs.js +733 -0
  100. package/dist/channels-cli-CTX6_5z3.js +268 -0
  101. package/dist/chat-C_i6Wp50.js +2830 -0
  102. package/dist/clawbot-cli-CLGPtbt-.js +9 -0
  103. package/dist/cli/daemon-cli.js +3 -3
  104. package/dist/cli-BhwHu1dK.js +72 -0
  105. package/dist/cli-CFsq8f2H.js +2 -0
  106. package/dist/cli-CNVlwurq.js +219 -0
  107. package/dist/cli-DLP8hKbi.js +2 -0
  108. package/dist/cli-runner-BbNBHV6v.js +286 -0
  109. package/dist/cli-runner.runtime-CfPaauuM.js +4 -0
  110. package/dist/cli-runner.runtime-MxBlCOO2.js +3 -0
  111. package/dist/cli-runner.runtime.js +1 -1
  112. package/dist/cli-startup-metadata.json +2 -2
  113. package/dist/cli.runtime-3cD-pSyn.js +1261 -0
  114. package/dist/cli.runtime.js +1 -1
  115. package/dist/client-Bl0d_7ak.js +138 -0
  116. package/dist/client-ClJyHgmq.js +713 -0
  117. package/dist/command-auth-DO32coey.js +76 -0
  118. package/dist/command-config-resolution-CAsa4fGg.js +2 -0
  119. package/dist/command-config-resolution-D6YcwuRh.js +23 -0
  120. package/dist/command-config-resolution.runtime-CSHDu35A.js +2 -0
  121. package/dist/command-config-resolution.runtime.js +1 -1
  122. package/dist/command-registry-BJEQrMqR.js +4 -0
  123. package/dist/command-registry-DI9i95nj.js +9 -0
  124. package/dist/command-registry-core-BpF1mggD.js +106 -0
  125. package/dist/command-secret-gateway-DDNHxysD.js +528 -0
  126. package/dist/command-status.runtime-DqYUCcEA.js +87 -0
  127. package/dist/command-status.runtime.js +1 -1
  128. package/dist/commands-acp-C_zCJPvL.js +77 -0
  129. package/dist/commands-compact.runtime-B6e3kwMS.js +10 -0
  130. package/dist/commands-compact.runtime.js +1 -1
  131. package/dist/commands-handlers.runtime-B0gTkAC0.js +4599 -0
  132. package/dist/commands-handlers.runtime.js +1 -1
  133. package/dist/commands-status-BgZ64sA8.js +16 -0
  134. package/dist/commands-status.runtime-JI89gIEU.js +3 -0
  135. package/dist/commands-status.runtime.js +1 -1
  136. package/dist/commands-subagents-control.runtime-B0hdcBxr.js +2 -0
  137. package/dist/commands-subagents-control.runtime-DUeSQ5j4.js +3 -0
  138. package/dist/commands-subagents-control.runtime.js +1 -1
  139. package/dist/commands-system-prompt-B7moUaCI.js +158 -0
  140. package/dist/commands-system-prompt-DTUkp9TH.js +2 -0
  141. package/dist/commands.runtime-BjCVVqol.js +167 -0
  142. package/dist/commands.runtime.js +1 -1
  143. package/dist/compact-BNJH56SX.js +1118 -0
  144. package/dist/compact.runtime-CYI8Yi9d.js +12 -0
  145. package/dist/compact.runtime.js +1 -1
  146. package/dist/completion-cli-Bb1Tk-vM.js +328 -0
  147. package/dist/config-DxkleHmo.js +252 -0
  148. package/dist/config-cli-CtaRB_f8.js +1078 -0
  149. package/dist/configure-Bp8WFryM.js +1252 -0
  150. package/dist/configure-DQ_X5zyT.js +2 -0
  151. package/dist/connect-options-BkWD0Wvv.js +699 -0
  152. package/dist/control-auth-Iqyldslx.js +125 -0
  153. package/dist/control-service-xIhkqyZE.js +156 -0
  154. package/dist/conversation-id-BZtOqHIz.js +38 -0
  155. package/dist/conversation-id-D1Q9qPFH.js +235 -0
  156. package/dist/conversation-runtime-B1QZ-DEM.js +31 -0
  157. package/dist/core-BdVAy0Wv.js +275 -0
  158. package/dist/cron-cli-BWM2kRKU.js +713 -0
  159. package/dist/daemon-cli-MRl5nyuF.js +12 -0
  160. package/dist/dashboard-BkdlJrnf.js +2 -0
  161. package/dist/dashboard-C9m86rHv.js +81 -0
  162. package/dist/delegate-BjUvKQlo.js +64 -0
  163. package/dist/detached-task-runtime-BAEzkNB8.js +73 -0
  164. package/dist/devices-cli-B1n6tl9f.js +498 -0
  165. package/dist/diagnostics-DZxWkW3i.js +154 -0
  166. package/dist/direct-dm-qw-uk31C.js +64 -0
  167. package/dist/dispatch-D0xiJ6Up.js +1131 -0
  168. package/dist/dispatch-acp-DVN58m9G.js +981 -0
  169. package/dist/dispatch-acp-manager.runtime-C8t1i5Wt.js +3 -0
  170. package/dist/dispatch-acp-manager.runtime.js +1 -1
  171. package/dist/dispatch-acp.runtime-FR0DUPpn.js +19 -0
  172. package/dist/dispatch-acp.runtime.js +1 -1
  173. package/dist/doctor-device-pairing-DIbiBPlL.js +307 -0
  174. package/dist/doctor-gateway-daemon-flow-BFjRlXvA.js +250 -0
  175. package/dist/doctor-gateway-health-uZrukX3c.js +63 -0
  176. package/dist/doctor-health-DKpg1bxM.js +59 -0
  177. package/dist/doctor-health-contributions-BoXX8ubw.js +493 -0
  178. package/dist/doctor-prompter-CLf5Uf10.js +56 -0
  179. package/dist/doctor-workspace-status-Cw61BbGy.js +75 -0
  180. package/dist/dreaming-Bk8dVfGi.js +1574 -0
  181. package/dist/dreaming-narrative-DGSQa-0N.js +595 -0
  182. package/dist/embedded-gateway-stub.runtime-sokWrs6B.js +9 -0
  183. package/dist/embedded-gateway-stub.runtime.js +1 -1
  184. package/dist/entry.js +2 -2
  185. package/dist/exec-approvals-cli-CnNETs_u.js +498 -0
  186. package/dist/extensionAPI.js +1 -1
  187. package/dist/extensions/active-memory/index.js +1 -1
  188. package/dist/extensions/bluebubbles/api.js +3 -3
  189. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  190. package/dist/extensions/browser/browser-bridge.js +1 -1
  191. package/dist/extensions/browser/browser-config.js +4 -4
  192. package/dist/extensions/browser/browser-control-auth.js +2 -2
  193. package/dist/extensions/browser/browser-doctor.js +2 -2
  194. package/dist/extensions/browser/browser-maintenance.js +2 -2
  195. package/dist/extensions/browser/browser-profiles.js +2 -2
  196. package/dist/extensions/browser/browser-runtime-api.js +10 -10
  197. package/dist/extensions/browser/index.js +1 -1
  198. package/dist/extensions/browser/plugin-registration.js +1 -1
  199. package/dist/extensions/browser/register.runtime.js +3 -3
  200. package/dist/extensions/browser/runtime-api.js +11 -11
  201. package/dist/extensions/browser/test-support.js +1 -1
  202. package/dist/extensions/device-pair/api.js +1 -1
  203. package/dist/extensions/device-pair/index.js +3 -3
  204. package/dist/extensions/device-pair/notify.js +1 -1
  205. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  206. package/dist/extensions/google-meet/index.js +2 -2
  207. package/dist/extensions/imessage/api.js +3 -3
  208. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  209. package/dist/extensions/imessage/runtime-api.js +3 -3
  210. package/dist/extensions/irc/api.js +2 -2
  211. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  212. package/dist/extensions/line/api.js +2 -2
  213. package/dist/extensions/line/channel-plugin-api.js +1 -1
  214. package/dist/extensions/line/contract-api.js +1 -1
  215. package/dist/extensions/line/runtime-api.js +4 -4
  216. package/dist/extensions/line/setup-api.js +1 -1
  217. package/dist/extensions/llm-task/index.js +2 -2
  218. package/dist/extensions/lobster/index.js +3 -3
  219. package/dist/extensions/lobster/runtime-api.js +1 -1
  220. package/dist/extensions/mattermost/api.js +1 -1
  221. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  222. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  223. package/dist/extensions/mattermost/policy-api.js +1 -1
  224. package/dist/extensions/mattermost/runtime-api.js +4 -4
  225. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  226. package/dist/extensions/memory-core/api.js +1 -1
  227. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  228. package/dist/extensions/memory-core/index.js +3 -3
  229. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  230. package/dist/extensions/msteams/api.js +1 -1
  231. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  232. package/dist/extensions/msteams/runtime-api.js +3 -3
  233. package/dist/extensions/msteams/test-api.js +1 -1
  234. package/dist/extensions/nextcloud-talk/api.js +1 -1
  235. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  236. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  237. package/dist/extensions/openshell/index.js +2 -2
  238. package/dist/extensions/signal/api.js +6 -6
  239. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  240. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  241. package/dist/extensions/signal/runtime-api.js +7 -7
  242. package/dist/extensions/skill-workshop/api.js +1 -1
  243. package/dist/extensions/skill-workshop/index.js +1 -1
  244. package/dist/extensions/synology-chat/api.js +1 -1
  245. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  246. package/dist/extensions/tlon/api.js +2 -2
  247. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  248. package/dist/extensions/tlon/runtime-api.js +1 -1
  249. package/dist/extensions/tlon/test-api.js +1 -1
  250. package/dist/extensions/twitch/api.js +1 -1
  251. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  252. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  253. package/dist/extensions/zalo/api.js +3 -3
  254. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  255. package/dist/extensions/zalo/runtime-api.js +2 -2
  256. package/dist/extensions/zalo/setup-api.js +2 -2
  257. package/dist/extensions/zalouser/api.js +3 -3
  258. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  259. package/dist/extensions/zalouser/runtime-api.js +6 -6
  260. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  261. package/dist/extensions/zalouser/test-api.js +1 -1
  262. package/dist/fallbacks-BwNexEVP.js +31 -0
  263. package/dist/fallbacks-GwVAaFt5.js +2 -0
  264. package/dist/fallbacks-shared-DmepG9Mq.js +111 -0
  265. package/dist/gateway-BB4hdlYm.js +115 -0
  266. package/dist/gateway-cli-Bzz62NC8.js +1283 -0
  267. package/dist/gateway-rpc-dyJV2osv.js +14 -0
  268. package/dist/gateway-rpc.runtime-DYVOEv4W.js +23 -0
  269. package/dist/gateway-rpc.runtime.js +1 -1
  270. package/dist/gateway-runtime-CqSQCYo0.js +15 -0
  271. package/dist/gateway-status-DdCiwrPt.js +584 -0
  272. package/dist/genesis-tools-Bh6dAUhK.js +9166 -0
  273. package/dist/genesis-tools.runtime-CiIUponP.js +2 -0
  274. package/dist/genesis-tools.runtime.js +1 -1
  275. package/dist/get-reply-from-config.runtime-Cu2DcwOW.js +2 -0
  276. package/dist/get-reply-from-config.runtime.js +1 -1
  277. package/dist/get-reply-qVmTjhwr.js +3897 -0
  278. package/dist/graph-users-kkSJYBNX.js +1337 -0
  279. package/dist/health-CFyVDYng.js +469 -0
  280. package/dist/health-Cl371mu8.js +3 -0
  281. package/dist/health-route-D0IspgUK.js +41 -0
  282. package/dist/health-route-D2tFKCLv.js +2 -0
  283. package/dist/heartbeat-runner-Bmi8YsXz.js +5 -0
  284. package/dist/heartbeat-runner-FSCWra2R.js +1292 -0
  285. package/dist/heartbeat-runner.runtime-QF8dg4j-.js +4 -0
  286. package/dist/heartbeat-runner.runtime.js +1 -1
  287. package/dist/hooks-cli-DYoG7Dz1.js +433 -0
  288. package/dist/image-fallbacks-5ckuJ46I.js +31 -0
  289. package/dist/image-fallbacks-DYnqzK01.js +2 -0
  290. package/dist/inbound-reply-dispatch-D5pqDZRa.js +73 -0
  291. package/dist/index.js +2 -2
  292. package/dist/infra-runtime-D08WIqN2.js +39 -0
  293. package/dist/init-BCgwiSZj.js +59 -0
  294. package/dist/library-CP9n_7AP.js +45 -0
  295. package/dist/lifecycle-BYam90xH.js +229 -0
  296. package/dist/lifecycle-DS58sNmu.js +571 -0
  297. package/dist/lifecycle.runtime-DMwss7xM.js +2 -0
  298. package/dist/lifecycle.runtime.js +1 -1
  299. package/dist/list-CASc4IWz.js +131 -0
  300. package/dist/list-CBPrBS2u.js +1212 -0
  301. package/dist/list-Cf7fcqQd.js +2 -0
  302. package/dist/list-Dqd2QyTH.js +2 -0
  303. package/dist/list.probe-BWcMSWDF.js +419 -0
  304. package/dist/llm-slug-generator-4LADFhXT.js +79 -0
  305. package/dist/llm-slug-generator.js +1 -1
  306. package/dist/load-config-DI-LDL6p.js +35 -0
  307. package/dist/local-dispatch.runtime-WDgraH3j.js +8 -0
  308. package/dist/local-dispatch.runtime.js +1 -1
  309. package/dist/logs-cli-zoBIelUH.js +265 -0
  310. package/dist/logs-cli.runtime-DxKNxXAz.js +2 -0
  311. package/dist/logs-cli.runtime.js +1 -1
  312. package/dist/main-session-restart-recovery-DWZfkOzH.js +206 -0
  313. package/dist/managed-image-attachments-DLDa1aE2.js +2 -0
  314. package/dist/managed-image-attachments-a4v60Bk3.js +635 -0
  315. package/dist/manager-CfUcsSI9.js +2057 -0
  316. package/dist/manager-DmBBLCOg.js +2 -0
  317. package/dist/markdown-to-line-B0mPruD_.js +790 -0
  318. package/dist/mcp/plugin-tools-serve.js +1 -1
  319. package/dist/mcp-cli-CLL9nfvE.js +725 -0
  320. package/dist/mcp-http-p7GbtbMx.js +529 -0
  321. package/dist/memory-core-host-runtime-cli-CZNYkDoE.js +9 -0
  322. package/dist/message-CRyNLXch.js +232 -0
  323. package/dist/message-action-runner-5Y4EFpWh.js +1407 -0
  324. package/dist/message-action-runner-Dxv-GXkn.js +2 -0
  325. package/dist/message-actions-DtoR6Mr2.js +143 -0
  326. package/dist/message.gateway.runtime-RI4cvk_E.js +2 -0
  327. package/dist/message.gateway.runtime.js +1 -1
  328. package/dist/models-auth-status-DsheCXaS.js +201 -0
  329. package/dist/models-cli-CQQG1U-p.js +219 -0
  330. package/dist/monitor-BRRSjPQY.js +1459 -0
  331. package/dist/monitor-Ch-cG7Si.js +1661 -0
  332. package/dist/monitor-ChBhfnC-.js +788 -0
  333. package/dist/monitor-CsvCTpjq.js +671 -0
  334. package/dist/monitor-DjemBuVh.js +1237 -0
  335. package/dist/monitor-LyGEO-KI.js +2 -0
  336. package/dist/monitor-auth-DVCdDwlp.js +207 -0
  337. package/dist/monitor-processing-Cib3ZjUe.js +1974 -0
  338. package/dist/monitor.runtime-DLBFALbV.js +2 -0
  339. package/dist/monitor.runtime.js +1 -1
  340. package/dist/monitor.webhook-Dktr8JA-.js +180 -0
  341. package/dist/msteams-G5I2CO13.js +35 -0
  342. package/dist/native-hook-relay-B1ArNeG5.js +519 -0
  343. package/dist/nextcloud-talk-DimOAfaR.js +17 -0
  344. package/dist/node-cli-RIjV0id4.js +2276 -0
  345. package/dist/nodes-cli-Cke-B80I.js +1046 -0
  346. package/dist/nodes-utils-CsTqKwN9.js +84 -0
  347. package/dist/nodes.helpers-DYpGCFer.js +34 -0
  348. package/dist/notify-zBChwf0-.js +315 -0
  349. package/dist/onboard-D6UawRld.js +2 -0
  350. package/dist/onboard-DfoCtk3_.js +70 -0
  351. package/dist/onboard-helpers-BKQMe3RX.js +6 -0
  352. package/dist/onboard-helpers-BLBJlQ50.js +204 -0
  353. package/dist/onboard-interactive-GAbQD437.js +24 -0
  354. package/dist/onboard-non-interactive-Bqi-JXh3.js +635 -0
  355. package/dist/onboard-remote-CNpTyVws.js +193 -0
  356. package/dist/onboard-remote-GFp2lT6Y.js +2 -0
  357. package/dist/onboard-skills-BQneolfo.js +2 -0
  358. package/dist/onboard-skills-BipqJ48b.js +134 -0
  359. package/dist/openai-http-CLDWjSKC.js +500 -0
  360. package/dist/openresponses-http-DNvXNiw_.js +1128 -0
  361. package/dist/operator-approvals-client-gaflvETF.js +68 -0
  362. package/dist/outbound.runtime-ByVsvEri.js +2 -0
  363. package/dist/outbound.runtime.js +1 -1
  364. package/dist/pair-command-approve-Dzkubc-8.js +44 -0
  365. package/dist/persistent-bindings.lifecycle-BhdRK7Lp.js +2 -0
  366. package/dist/persistent-bindings.lifecycle-DQ0AiHuy.js +85 -0
  367. package/dist/pi-embedded-C789hs31.js +4 -0
  368. package/dist/pi-embedded-CXLkrOwv.js +2905 -0
  369. package/dist/pi-embedded.runtime-BaHYLgKa.js +4 -0
  370. package/dist/pi-embedded.runtime.js +1 -1
  371. package/dist/pi-tool-definition-adapter-DFutc0D4.js +229 -0
  372. package/dist/pi-tools-k60jrAVq.js +1057 -0
  373. package/dist/pi-tools.before-tool-call-CFy20GCz.js +2 -0
  374. package/dist/pi-tools.before-tool-call-DJmPOVfQ.js +433 -0
  375. package/dist/plugin-BfFuIgXQ.js +12195 -0
  376. package/dist/plugin-enabled-dXOUnZwX.js +140 -0
  377. package/dist/plugin-registration-CEAozQhV.js +23 -0
  378. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  379. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  380. package/dist/plugin-sdk/acp-runtime.js +2 -2
  381. package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
  382. package/dist/plugin-sdk/agent-harness.js +6 -6
  383. package/dist/plugin-sdk/agent-runtime.js +2 -2
  384. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  385. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  386. package/dist/plugin-sdk/approval-runtime.js +1 -1
  387. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  388. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  389. package/dist/plugin-sdk/browser-support.js +7 -7
  390. package/dist/plugin-sdk/channel-core.js +2 -2
  391. package/dist/plugin-sdk/channel-inbound.js +2 -2
  392. package/dist/plugin-sdk/command-auth.js +1 -1
  393. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  394. package/dist/plugin-sdk/compat.js +1 -1
  395. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  396. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  397. package/dist/plugin-sdk/core.js +2 -2
  398. package/dist/plugin-sdk/direct-dm.js +1 -1
  399. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  400. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  401. package/dist/plugin-sdk/index.js +1 -1
  402. package/dist/plugin-sdk/infra-runtime.js +2 -2
  403. package/dist/plugin-sdk/irc.js +2 -2
  404. package/dist/plugin-sdk/matrix.js +1 -1
  405. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  406. package/dist/plugin-sdk/memory-core.js +2 -2
  407. package/dist/plugin-sdk/msteams.js +2 -2
  408. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  409. package/dist/plugin-sdk/nostr.js +1 -1
  410. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  411. package/dist/plugin-sdk/reply-runtime.js +4 -4
  412. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  413. package/dist/plugin-sdk/runtime.js +2 -2
  414. package/dist/plugin-sdk/session-visibility.js +1 -1
  415. package/dist/plugin-sdk/testing.js +4 -4
  416. package/dist/plugin-sdk/tlon.js +1 -1
  417. package/dist/plugin-sdk/zalo.js +1 -1
  418. package/dist/plugin-sdk/zalouser.js +1 -1
  419. package/dist/plugin-service-BOpLQ8BU.js +2892 -0
  420. package/dist/plugins/runtime/index.js +1 -1
  421. package/dist/policy-DiIlt2yW.js +328 -0
  422. package/dist/postinstall-inventory.json +414 -414
  423. package/dist/prepare.runtime-Bd8adOy3.js +815 -0
  424. package/dist/prepare.runtime.js +1 -1
  425. package/dist/probe-BOlTfbzG.js +2 -0
  426. package/dist/probe-BSRvsN95.js +2205 -0
  427. package/dist/probe-CDfjQSnz.js +74 -0
  428. package/dist/probe-D7gHyiZV.js +241 -0
  429. package/dist/probe-DTNKTWSs.js +2 -0
  430. package/dist/probe-DcryDdZh.js +45 -0
  431. package/dist/probe-nyesoHxj.js +1443 -0
  432. package/dist/program-BFGavenz.js +111 -0
  433. package/dist/prompt-select-styled-BhY1zahx.js +20 -0
  434. package/dist/protocol-DxLbSF2J.js +2477 -0
  435. package/dist/provider-dispatcher-C-yy1D7r.js +22 -0
  436. package/dist/provider-dispatcher-ErSjESTP.js +2 -0
  437. package/dist/qr-cli-C1-oy_ho.js +349 -0
  438. package/dist/qr-cli-DmEs63Sb.js +2 -0
  439. package/dist/reaction-runtime-api-gua650a7.js +116 -0
  440. package/dist/reactions-R-rA7cXz.js +998 -0
  441. package/dist/register-service-commands-DkbqNKVB.js +71 -0
  442. package/dist/register.agent-C3nW9wDn.js +248 -0
  443. package/dist/register.configure-BzLHCu95.js +15 -0
  444. package/dist/register.maintenance-BHFQo4gr.js +363 -0
  445. package/dist/register.message-CsYRdfKi.js +329 -0
  446. package/dist/register.onboard-DltySQ6C.js +88 -0
  447. package/dist/register.runtime-6Sk1Njnp.js +81 -0
  448. package/dist/register.runtime.js +1 -1
  449. package/dist/register.setup-CDvVQJuj.js +150 -0
  450. package/dist/register.status-health-sessions-B8lorJ2x.js +1215 -0
  451. package/dist/register.subclis-BD4fuAci.js +3 -0
  452. package/dist/register.subclis-CbRd3F_m.js +29 -0
  453. package/dist/register.subclis-core-Dtq9dAjI.js +249 -0
  454. package/dist/reply-dispatch-runtime-DldslKSK.js +13 -0
  455. package/dist/reply-runtime-2EGTfk-1.js +11 -0
  456. package/dist/reply.runtime-OaHntzIS.js +2 -0
  457. package/dist/reply.runtime.js +1 -1
  458. package/dist/restart-health-BjmfJCUM.js +202 -0
  459. package/dist/restart-health-hw909zlD.js +2 -0
  460. package/dist/root-help-_hHiERsR.js +44 -0
  461. package/dist/routes-BxCk7Pue.js +3341 -0
  462. package/dist/routes-C1_6oFmZ.js +2 -0
  463. package/dist/rpc-zRbkEo6W.js +61 -0
  464. package/dist/rpc.runtime-BZSYNDPa.js +21 -0
  465. package/dist/rpc.runtime.js +1 -1
  466. package/dist/run-delivery.runtime-D6YDo67d.js +530 -0
  467. package/dist/run-delivery.runtime.js +1 -1
  468. package/dist/run-embedded.runtime-BsgPrPDa.js +4 -0
  469. package/dist/run-embedded.runtime.js +1 -1
  470. package/dist/run-execution-cli.runtime-CggaHhrJ.js +4 -0
  471. package/dist/run-execution-cli.runtime.js +1 -1
  472. package/dist/run-executor.runtime-CKkLEr_T.js +277 -0
  473. package/dist/run-executor.runtime.js +1 -1
  474. package/dist/run-main-CJYYkV6H.js +567 -0
  475. package/dist/run-subagent-registry.runtime-B0sgf_oy.js +2 -0
  476. package/dist/run-subagent-registry.runtime.js +1 -1
  477. package/dist/run-wait-DHizeptL.js +135 -0
  478. package/dist/runtime-EtV_ChXX.js +9 -0
  479. package/dist/runtime-api-6H864Pmt.js +9 -0
  480. package/dist/runtime-api-CbZqRBZQ.js +14 -0
  481. package/dist/runtime-api-ZxEgu8cW.js +4 -0
  482. package/dist/runtime-api-j9A6jYUr.js +9 -0
  483. package/dist/runtime-embedded-pi.runtime-BHjCPnxo.js +2 -0
  484. package/dist/runtime-embedded-pi.runtime.js +1 -1
  485. package/dist/runtime-hvRzTSAZ.js +973 -0
  486. package/dist/runtime-internal-C_KZYzFK.js +2 -0
  487. package/dist/runtime-options-BZEOCnMg.js +275 -0
  488. package/dist/runtime-schema-R7LWe58K.js +28576 -0
  489. package/dist/scan-BNDE3dSE.js +523 -0
  490. package/dist/scan-TG6lVEQ2.js +2 -0
  491. package/dist/secrets-cli-twD2FWoZ.js +2101 -0
  492. package/dist/security-cli-Cd1A5yhL.js +486 -0
  493. package/dist/selection-CqqmU0Hi.js +7764 -0
  494. package/dist/selection-CsM62vcz.js +2 -0
  495. package/dist/send-D-EgB64m.js +156 -0
  496. package/dist/send-DPk5hW1W.js +102 -0
  497. package/dist/send.runtime-3QDkKN71.js +2 -0
  498. package/dist/send.runtime.js +1 -1
  499. package/dist/server-C94r_Qff.js +77 -0
  500. package/dist/server-Ceiopn_v.js +13 -0
  501. package/dist/server-context-BFJlu5HY.js +2 -0
  502. package/dist/server-context-PNEqhnTM.js +847 -0
  503. package/dist/server-node-events-QOAWLsDC.js +481 -0
  504. package/dist/server-plugin-bootstrap-CgsjzB17.js +2 -0
  505. package/dist/server-plugin-bootstrap-Dfuf75EN.js +12728 -0
  506. package/dist/server-restart-sentinel-BMPqZ7Jw.js +697 -0
  507. package/dist/server.impl-CCoQpvB7.js +12864 -0
  508. package/dist/session-kill-http-oPi3ajEp.js +110 -0
  509. package/dist/session-reset-service-CzDd6PBK.js +497 -0
  510. package/dist/session-route-DUOQE8-f.js +93 -0
  511. package/dist/session-status.runtime-W5tlGbXw.js +2 -0
  512. package/dist/session-status.runtime.js +1 -1
  513. package/dist/session-subagent-reactivation.runtime-yoYn1awK.js +2 -0
  514. package/dist/session-subagent-reactivation.runtime.js +1 -1
  515. package/dist/session-tab-registry-DkeCaT-2.js +581 -0
  516. package/dist/session-visibility-B4CFjv43.js +147 -0
  517. package/dist/sessions-helpers-CDfOVWe3.js +305 -0
  518. package/dist/sessions-history-http-QXeTdxXM.js +383 -0
  519. package/dist/sessions-patch-xb4bXPwh.js +309 -0
  520. package/dist/sessions-resolve-BPlrW8C3.js +174 -0
  521. package/dist/sessions.runtime-yYJXudA9.js +2 -0
  522. package/dist/sessions.runtime.js +1 -1
  523. package/dist/setup-0Im0LL1d.js +636 -0
  524. package/dist/setup-api-BxwfqXN-.js +29 -0
  525. package/dist/setup-core-BWwXgEuM.js +171 -0
  526. package/dist/setup-core-DzHNbQLG.js +176 -0
  527. package/dist/setup-surface-BVnqDsfU.js +286 -0
  528. package/dist/setup-surface-BajZWmKz2.js +403 -0
  529. package/dist/setup-surface-rDO3YjSb.js +219 -0
  530. package/dist/setup.finalize-BsnPbdwc.js +547 -0
  531. package/dist/setup.gateway-config-BFawSWHL.js +250 -0
  532. package/dist/shared-52tFSlVk.js +121 -0
  533. package/dist/shared-C8ENgtxM.js +198 -0
  534. package/dist/shared-DbXvU7JV.js +76 -0
  535. package/dist/slash-state-CMuPwgKt.js +1911 -0
  536. package/dist/src-IzaHgU6a.js +3974 -0
  537. package/dist/startup-context-xJS8ckSG.js +312 -0
  538. package/dist/status-BO4LMTER.js +2 -0
  539. package/dist/status-BwY1tASe.js +3 -0
  540. package/dist/status-BxG6n-ko.js +397 -0
  541. package/dist/status-Co_cq2vy.js +2 -0
  542. package/dist/status-DKNeRGzW.js +190 -0
  543. package/dist/status-DzlIHiTS.js +209 -0
  544. package/dist/status-all-DF7qaWjo.js +498 -0
  545. package/dist/status-json-CgCilobT.js +14 -0
  546. package/dist/status-json-command-DAa78z3e.js +84 -0
  547. package/dist/status-runtime-shared-CRCuxXn_.js +257 -0
  548. package/dist/status-subagents.runtime-hUsBd4C5.js +18 -0
  549. package/dist/status-subagents.runtime.js +1 -1
  550. package/dist/status-text-BdbRrl1G.js +237 -0
  551. package/dist/status.gateway-connection.runtime-BmSTYFFO.js +2 -0
  552. package/dist/status.gateway-connection.runtime.js +1 -1
  553. package/dist/status.gather-CItmFIHS.js +292 -0
  554. package/dist/status.gather-qB6WOoH7.js +2 -0
  555. package/dist/status.runtime-ClZCgYx1.js +2 -0
  556. package/dist/status.runtime.js +1 -1
  557. package/dist/status.scan-overview-B0b0Mvng.js +379 -0
  558. package/dist/status.scan-xY7nUi9N.js +65 -0
  559. package/dist/status.scan.fast-json-BANGHOys.js +132 -0
  560. package/dist/status.scan.fast-json-M-DmMy2l.js +2 -0
  561. package/dist/status.summary-B3PlFnWw.js +2 -0
  562. package/dist/status.summary-adB75FOM.js +214 -0
  563. package/dist/subagent-announce-B4w7Mcpr.js +351 -0
  564. package/dist/subagent-announce-delivery-Dma0A4gL.js +726 -0
  565. package/dist/subagent-announce-output-sUPLcge-.js +364 -0
  566. package/dist/subagent-control-CxR0WRrx.js +506 -0
  567. package/dist/subagent-followup.runtime-XeFe_LA0.js +68 -0
  568. package/dist/subagent-followup.runtime.js +1 -1
  569. package/dist/subagent-orphan-recovery-CJPHy8JV.js +305 -0
  570. package/dist/subagent-registry-CjMWjRCE.js +1753 -0
  571. package/dist/subagent-registry-H20VxEu0.js +3 -0
  572. package/dist/subagent-registry.runtime.js +1 -1
  573. package/dist/subagent-spawn-CRM5x6cV.js +1005 -0
  574. package/dist/system-cli-BJ5mMirj.js +59 -0
  575. package/dist/targets-CUnlEj96.js +67 -0
  576. package/dist/task-executor-DKnEwQ6v.js +360 -0
  577. package/dist/task-owner-access-CfypP1Yc.js +74 -0
  578. package/dist/task-registry-delivery-runtime-BB6ZzpqH.js +2 -0
  579. package/dist/task-registry-delivery-runtime-CvHa0gv-.js +3 -0
  580. package/dist/task-registry-pQuAfAL9.js +2366 -0
  581. package/dist/task-registry.maintenance-Bfd87wEV.js +416 -0
  582. package/dist/task-registry.maintenance-VgfbW0yt.js +2 -0
  583. package/dist/telegram/token.js +1 -1
  584. package/dist/testing-C_mngO0u.js +575 -0
  585. package/dist/text-report-Ct6t3he6.js +587 -0
  586. package/dist/tool-resolution-C4KGgPH-.js +90 -0
  587. package/dist/tools-effective-inventory-Bo2QC-m8.js +152 -0
  588. package/dist/tools-invoke-http-CBZPFh5L.js +206 -0
  589. package/dist/trash-DhZow3jd.js +24 -0
  590. package/dist/tui-cli-BPdQPozP.js +4575 -0
  591. package/dist/update-cli-BRi3mVAU.js +1759 -0
  592. package/dist/upgrade-D9zejtCk.js +1226 -0
  593. package/dist/video-generation-task-status-BSBQ0_FO.js +163 -0
  594. package/dist/wait-for-idle-before-flush-D1dTT9th.js +5986 -0
  595. package/dist/wizard-models-ysyV_WWR.js +334 -0
  596. package/package.json +1 -1
  597. package/dist/abort-DaihtnYj.js +0 -201
  598. package/dist/abort.runtime-BUT9L_5l.js +0 -2
  599. package/dist/accounts-BY5wsBnV.js +0 -104
  600. package/dist/accounts-DGth1vsM.js +0 -107
  601. package/dist/accounts-Do6Ir-q3.js +0 -2
  602. package/dist/acp-cli-BHgjn8rh.js +0 -2193
  603. package/dist/acp-spawn-BAM_Jrft.js +0 -2
  604. package/dist/acp-spawn-DyBD_Y_t.js +0 -1093
  605. package/dist/acp-stateful-target-driver-DKGnfjWu.js +0 -89
  606. package/dist/action-agents-CzMSNQdc.js +0 -67
  607. package/dist/action-focus-CpjIrZFe.js +0 -132
  608. package/dist/action-help-BhE9UosK.js +0 -7
  609. package/dist/action-info-CH2j6dKT.js +0 -101
  610. package/dist/action-kill-CB4AnLIf.js +0 -33
  611. package/dist/action-list-CQ8LbzvR.js +0 -21
  612. package/dist/action-log-DZblh247.js +0 -30
  613. package/dist/action-send-DMe0B4FG.js +0 -39
  614. package/dist/action-spawn-CkKMESb5.js +0 -47
  615. package/dist/action-unfocus-DjQzPZwU.js +0 -29
  616. package/dist/actions.runtime-CUdRdpLB.js +0 -5
  617. package/dist/actions.runtime-CxRstWdN.js +0 -18
  618. package/dist/agent-command-Nh_kPL3z.js +0 -874
  619. package/dist/agent-harness-runtime-BEb7Wk1m.js +0 -144
  620. package/dist/agent-q6U-cKJn.js +0 -2
  621. package/dist/agent-runner-utils-x_qJ6xYC.js +0 -239
  622. package/dist/agent-runner.runtime-DRvTfUPd.js +0 -3455
  623. package/dist/agent-runtime-jSYYQd6f.js +0 -18
  624. package/dist/agents-BKOpsZXw.js +0 -5
  625. package/dist/agents-BY34ViPX.js +0 -954
  626. package/dist/aliases-CD5YlX7d.js +0 -2
  627. package/dist/aliases-Dq31zANx.js +0 -96
  628. package/dist/api-BhxN9fxJ.js +0 -139
  629. package/dist/api-DjL_3olO.js +0 -5
  630. package/dist/api-jIYND-S5.js +0 -3
  631. package/dist/approval-gateway-resolver-BfvdJW5s.js +0 -29
  632. package/dist/approval-gateway-runtime-BBf976nt.js +0 -2
  633. package/dist/approval-handler-runtime-Bq4p5wvg.js +0 -439
  634. package/dist/approval-native-runtime-IrisOZrU.js +0 -729
  635. package/dist/attempt-execution.runtime-BXGalt-_.js +0 -509
  636. package/dist/attempt.prompt-helpers-A-pc2LfL.js +0 -221
  637. package/dist/attempt.tool-run-context-Ukna4ck-.js +0 -933
  638. package/dist/audit-CVUpfDvE.js +0 -939
  639. package/dist/audit.runtime-CsuGXvud.js +0 -7
  640. package/dist/auth-CjcZyRUW.js +0 -383
  641. package/dist/auth-order-DIkyTpW4.js +0 -2
  642. package/dist/auth-order-Dpt1K1rT.js +0 -96
  643. package/dist/auth-sVuL2xeZ.js +0 -2
  644. package/dist/bash-tools-DDv0zQh9.js +0 -2824
  645. package/dist/bash-tools-s-QSvRmt.js +0 -3
  646. package/dist/binding-routing-Cz5R2kFK.js +0 -85
  647. package/dist/binding-targets-D4j2hdQh.js +0 -121
  648. package/dist/bridge-server-X8SdeAI3.js +0 -113
  649. package/dist/browser-control-auth-BrF3DZxC.js +0 -2
  650. package/dist/browser-node-runtime-BecPmKOx.js +0 -12
  651. package/dist/browser-profiles-BxAKEG3x.js +0 -2
  652. package/dist/browser-runtime-D9fTDscJ.js +0 -387
  653. package/dist/browser-setup-tools--AQGWGvl.js +0 -13
  654. package/dist/build-B0nbyXrw.js +0 -550
  655. package/dist/call-BvqN9kay.js +0 -3
  656. package/dist/call-Dk5rTl-p.js +0 -331
  657. package/dist/call.runtime-Bx1hKDwO.js +0 -2
  658. package/dist/capability-cli-286Z3Bq3.js +0 -1401
  659. package/dist/catchup-DyeQ6GNj.js +0 -300
  660. package/dist/channel-B5m01jSZ.js +0 -1802
  661. package/dist/channel-BE26v3WU.js +0 -840
  662. package/dist/channel-BS7r_Zt1.js +0 -226
  663. package/dist/channel-BUWCqkGh.js +0 -1320
  664. package/dist/channel-BhgKqvZn.js +0 -453
  665. package/dist/channel-Bx703sxQ.js +0 -297
  666. package/dist/channel-CDjlEQAM.js +0 -491
  667. package/dist/channel-ChrqAgRS.js +0 -595
  668. package/dist/channel-Crmp3BHh.js +0 -1100
  669. package/dist/channel-D7GdDfBl.js +0 -1174
  670. package/dist/channel-DqSzRIul.js +0 -350
  671. package/dist/channel-core-DIwclC34.js +0 -5
  672. package/dist/channel-inbound-DPW1gRUU.js +0 -31
  673. package/dist/channel-plugin-runtime-BJhRSlBI.js +0 -771
  674. package/dist/channel-runtime-sV_Sg0EO.js +0 -425
  675. package/dist/channel.runtime-4BaNapRW.js +0 -89
  676. package/dist/channel.runtime-Bk2w0Yzd.js +0 -2364
  677. package/dist/channel.runtime-Bo5_2imz.js +0 -109
  678. package/dist/channel.runtime-CdYWlMyL.js +0 -40130
  679. package/dist/channel.runtime-CrYmCmSw.js +0 -4
  680. package/dist/channel.runtime-D3APPhVs.js +0 -430
  681. package/dist/channel.runtime-DjF1Gg6N.js +0 -576
  682. package/dist/channel.setup-BxXrmAYb.js +0 -10
  683. package/dist/channels-DHcJgMnw.js +0 -733
  684. package/dist/channels-cli-Dnq08u4r.js +0 -268
  685. package/dist/chat-BGU3UVKD.js +0 -2830
  686. package/dist/clawbot-cli-C-rqJUW-.js +0 -9
  687. package/dist/cli-BlnGJbLJ.js +0 -219
  688. package/dist/cli-D0RU1q0-.js +0 -2
  689. package/dist/cli-DBw79G2t.js +0 -72
  690. package/dist/cli-Dul37_xp.js +0 -2
  691. package/dist/cli-runner-DY8BKEmu.js +0 -286
  692. package/dist/cli-runner.runtime-5JMuegF9.js +0 -3
  693. package/dist/cli-runner.runtime-DQROn9Ve.js +0 -4
  694. package/dist/cli.runtime-CGOUREQg.js +0 -1261
  695. package/dist/client-CCBN1ydB.js +0 -138
  696. package/dist/client-PHLyQ8il.js +0 -713
  697. package/dist/command-auth-79QKQZZ3.js +0 -76
  698. package/dist/command-config-resolution-BKAgMItc.js +0 -2
  699. package/dist/command-config-resolution-BUCAmCZ_.js +0 -23
  700. package/dist/command-config-resolution.runtime-BVtfeARM.js +0 -2
  701. package/dist/command-registry-CBBqTuqk.js +0 -4
  702. package/dist/command-registry-core-D4BBKYaw.js +0 -106
  703. package/dist/command-registry-nztgeSim.js +0 -9
  704. package/dist/command-secret-gateway-g0alGmKz.js +0 -528
  705. package/dist/command-status.runtime-Dw6Zj5hL.js +0 -87
  706. package/dist/commands-acp-De-XFc40.js +0 -77
  707. package/dist/commands-compact.runtime-6gixR2a8.js +0 -10
  708. package/dist/commands-handlers.runtime-DCmZAlRN.js +0 -4599
  709. package/dist/commands-status-CION7GYY.js +0 -16
  710. package/dist/commands-status.runtime-FBwoHftv.js +0 -3
  711. package/dist/commands-subagents-control.runtime-C2xgOYKM.js +0 -2
  712. package/dist/commands-subagents-control.runtime-CgIEblx3.js +0 -3
  713. package/dist/commands-system-prompt-B-jC-KV-.js +0 -158
  714. package/dist/commands-system-prompt-DeK5Jhy_.js +0 -2
  715. package/dist/commands.runtime-CHSb1kYa.js +0 -167
  716. package/dist/compact-Dwchggv2.js +0 -1118
  717. package/dist/compact.runtime-jDUYMSjR.js +0 -12
  718. package/dist/completion-cli-DLHh5B2t.js +0 -328
  719. package/dist/config-Bnb9qa1S.js +0 -252
  720. package/dist/config-cli-DReWqAE2.js +0 -1078
  721. package/dist/configure-BLNGlWh0.js +0 -1252
  722. package/dist/configure-nPzsEeOb.js +0 -2
  723. package/dist/connect-options-C9cvS-bh.js +0 -699
  724. package/dist/control-auth-D2-P54fW.js +0 -125
  725. package/dist/control-service-CqUPgxlx.js +0 -156
  726. package/dist/conversation-id-BAzJOKBB.js +0 -235
  727. package/dist/conversation-id-WJLKuyy9.js +0 -38
  728. package/dist/conversation-runtime-D8fK5aI0.js +0 -31
  729. package/dist/core-DywmHt1k.js +0 -275
  730. package/dist/cron-cli-CeEJRkfR.js +0 -713
  731. package/dist/daemon-cli-BZZOjJHx.js +0 -12
  732. package/dist/dashboard-C0NRxmP3.js +0 -81
  733. package/dist/dashboard-DqhPgQv-.js +0 -2
  734. package/dist/delegate-DwVbOeR5.js +0 -64
  735. package/dist/detached-task-runtime-DiDRj-v-.js +0 -73
  736. package/dist/devices-cli-BKVbpwVc.js +0 -498
  737. package/dist/diagnostics-gh3UN_iV.js +0 -154
  738. package/dist/direct-dm-CwHHUkHV.js +0 -64
  739. package/dist/dispatch-B5af8_1v.js +0 -1131
  740. package/dist/dispatch-acp-DgOnUWBl.js +0 -981
  741. package/dist/dispatch-acp-manager.runtime-XWNjVh_M.js +0 -3
  742. package/dist/dispatch-acp.runtime-BdYL_ZqM.js +0 -19
  743. package/dist/doctor-device-pairing-CtGzWmXB.js +0 -307
  744. package/dist/doctor-gateway-daemon-flow-CCBI0jL4.js +0 -250
  745. package/dist/doctor-gateway-health-CkjqPFDl.js +0 -63
  746. package/dist/doctor-health-BOhuy1vP.js +0 -59
  747. package/dist/doctor-health-contributions-ChEuyLAY.js +0 -493
  748. package/dist/doctor-prompter-9nOTFD0Q.js +0 -56
  749. package/dist/doctor-workspace-status-CO5Ocwlt.js +0 -75
  750. package/dist/dreaming-GOPEFPio.js +0 -1574
  751. package/dist/dreaming-narrative-DfxHaxOU.js +0 -595
  752. package/dist/embedded-gateway-stub.runtime-B2OWcbsK.js +0 -9
  753. package/dist/exec-approvals-cli-CGeFtFbB.js +0 -498
  754. package/dist/fallbacks-CdfWAgNP.js +0 -2
  755. package/dist/fallbacks-eXbQ8TBp.js +0 -31
  756. package/dist/fallbacks-shared-akcCu5CD.js +0 -111
  757. package/dist/gateway-D-dDKqwi.js +0 -115
  758. package/dist/gateway-cli-NlsKGnqx.js +0 -1283
  759. package/dist/gateway-rpc-Cxa8dVW5.js +0 -14
  760. package/dist/gateway-rpc.runtime-D76s-oxs.js +0 -23
  761. package/dist/gateway-runtime-Dhm_gLh1.js +0 -15
  762. package/dist/gateway-status-C_L_CdOg.js +0 -584
  763. package/dist/genesis-tools-rRJB3JXY.js +0 -9166
  764. package/dist/genesis-tools.runtime-6oKokqaA.js +0 -2
  765. package/dist/get-reply-BkiDsDVY.js +0 -3897
  766. package/dist/get-reply-from-config.runtime-CHKCcj9D.js +0 -2
  767. package/dist/graph-users-BnXIYyC5.js +0 -1337
  768. package/dist/health-ZsJNENSY.js +0 -3
  769. package/dist/health-osa9LOJf.js +0 -469
  770. package/dist/health-route-8TdKOYLp.js +0 -2
  771. package/dist/health-route-BdLtX2Bg.js +0 -41
  772. package/dist/heartbeat-runner-BCbkAprr.js +0 -1292
  773. package/dist/heartbeat-runner-Dc1K8S94.js +0 -5
  774. package/dist/heartbeat-runner.runtime-pJaAsgLY.js +0 -4
  775. package/dist/hooks-cli-C3ggAz0i.js +0 -433
  776. package/dist/image-fallbacks-CiSae-lb.js +0 -2
  777. package/dist/image-fallbacks-vI8KUh6N.js +0 -31
  778. package/dist/inbound-reply-dispatch-DLM60UDh.js +0 -73
  779. package/dist/infra-runtime-CrHVeejV.js +0 -39
  780. package/dist/init-BKeEiV2q.js +0 -59
  781. package/dist/library-CHB7yTo5.js +0 -45
  782. package/dist/lifecycle-CUULToPr.js +0 -229
  783. package/dist/lifecycle-DCMpTRD2.js +0 -571
  784. package/dist/lifecycle.runtime-CP4gRxWv.js +0 -2
  785. package/dist/list-0zDFAWTF.js +0 -2
  786. package/dist/list-BaxVHTAN.js +0 -131
  787. package/dist/list-CMRMgrPs.js +0 -1212
  788. package/dist/list-DSrBtnKI.js +0 -2
  789. package/dist/list.probe-BJYSCsJY.js +0 -419
  790. package/dist/llm-slug-generator-Bn_wrWYw.js +0 -79
  791. package/dist/load-config-qC2BWt8E.js +0 -35
  792. package/dist/local-dispatch.runtime-DyU7urGc.js +0 -8
  793. package/dist/logs-cli-zK71r_PE.js +0 -265
  794. package/dist/logs-cli.runtime-k0UtiaRP.js +0 -2
  795. package/dist/main-session-restart-recovery-DMT0Oj9a.js +0 -206
  796. package/dist/managed-image-attachments-B6XXE4--.js +0 -635
  797. package/dist/managed-image-attachments-BTzWoDWE.js +0 -2
  798. package/dist/manager-BCKuWA67.js +0 -2057
  799. package/dist/manager-rGwNUzMp.js +0 -2
  800. package/dist/markdown-to-line-DmPbXQA1.js +0 -790
  801. package/dist/mcp-cli-CYpPNMcE.js +0 -725
  802. package/dist/mcp-http-wiE81iKg.js +0 -529
  803. package/dist/memory-core-host-runtime-cli-BOSQRX1T.js +0 -9
  804. package/dist/message-CUDzVGD8.js +0 -232
  805. package/dist/message-action-runner-Dy0IpKa4.js +0 -1407
  806. package/dist/message-action-runner-KkBFzZdg.js +0 -2
  807. package/dist/message-actions-Dcdb5aSR.js +0 -143
  808. package/dist/message.gateway.runtime-D86fFO99.js +0 -2
  809. package/dist/models-auth-status-DkiX4s0b.js +0 -201
  810. package/dist/models-cli-CSUot1R3.js +0 -219
  811. package/dist/monitor-BA8ByMKR.js +0 -2
  812. package/dist/monitor-Bv1GIHW5.js +0 -1661
  813. package/dist/monitor-DTFY0ruF.js +0 -788
  814. package/dist/monitor-DXH-vNGn.js +0 -1459
  815. package/dist/monitor-Df5k8NGk.js +0 -671
  816. package/dist/monitor-Dk2YRF26.js +0 -1237
  817. package/dist/monitor-auth-CZOW753A.js +0 -207
  818. package/dist/monitor-processing-Clta8N4C.js +0 -1974
  819. package/dist/monitor.runtime-3ORbPT0X.js +0 -2
  820. package/dist/monitor.webhook-CRyTxENk.js +0 -180
  821. package/dist/msteams-BE0VieXF.js +0 -35
  822. package/dist/native-hook-relay-DAwGGuEx.js +0 -519
  823. package/dist/nextcloud-talk-DfYlTFsm.js +0 -17
  824. package/dist/node-cli-Bzyci_X_.js +0 -2276
  825. package/dist/nodes-cli-Er3OZkuk.js +0 -1046
  826. package/dist/nodes-utils-Cp8QZO8-.js +0 -84
  827. package/dist/nodes.helpers-CwKAAnRA.js +0 -34
  828. package/dist/notify-D_5n_vEJ.js +0 -315
  829. package/dist/onboard-BE82RudQ.js +0 -2
  830. package/dist/onboard-Bk4xL8X7.js +0 -70
  831. package/dist/onboard-helpers-D4WYa-6g.js +0 -204
  832. package/dist/onboard-helpers-MuFxPZg5.js +0 -6
  833. package/dist/onboard-interactive-0zmI-9ia.js +0 -24
  834. package/dist/onboard-non-interactive-DIRB95mT.js +0 -635
  835. package/dist/onboard-remote-7qR1knbU.js +0 -2
  836. package/dist/onboard-remote-CLmoySkk.js +0 -193
  837. package/dist/onboard-skills-C_873OK_.js +0 -134
  838. package/dist/onboard-skills-DrlBYc0t.js +0 -2
  839. package/dist/openai-http-DzCBqW6b.js +0 -500
  840. package/dist/openresponses-http-B2zgO5hQ.js +0 -1128
  841. package/dist/operator-approvals-client-mGBl4ptH.js +0 -68
  842. package/dist/outbound.runtime--HS-MxM_.js +0 -2
  843. package/dist/pair-command-approve-CCTSQKJH.js +0 -44
  844. package/dist/persistent-bindings.lifecycle-CnmqGsQf.js +0 -85
  845. package/dist/persistent-bindings.lifecycle-Dav1TX9E.js +0 -2
  846. package/dist/pi-embedded-BSKL8IgF.js +0 -4
  847. package/dist/pi-embedded-DMM8Pfp7.js +0 -2905
  848. package/dist/pi-embedded.runtime-Bv_roBVx.js +0 -4
  849. package/dist/pi-tool-definition-adapter-OrxjlSIM.js +0 -229
  850. package/dist/pi-tools-DD1YegeL.js +0 -1057
  851. package/dist/pi-tools.before-tool-call-J9ujp9Wp.js +0 -433
  852. package/dist/pi-tools.before-tool-call-hGEgKGZQ.js +0 -2
  853. package/dist/plugin-Cg3pHepG.js +0 -12195
  854. package/dist/plugin-enabled-wEQ8BQNw.js +0 -140
  855. package/dist/plugin-registration-DLcLJgqz.js +0 -23
  856. package/dist/plugin-service-BogBl5qk.js +0 -2892
  857. package/dist/policy-Bkh8Xtnb.js +0 -328
  858. package/dist/prepare.runtime-Cd31ie7u.js +0 -815
  859. package/dist/probe-9IM22Rkf.js +0 -2
  860. package/dist/probe-ButCyV3d.js +0 -1443
  861. package/dist/probe-D7QBUio1.js +0 -45
  862. package/dist/probe-DV6CWm0r.js +0 -74
  863. package/dist/probe-DkfetvwA.js +0 -2
  864. package/dist/probe-Dxo-LQjn.js +0 -2205
  865. package/dist/probe-nil3qQAV.js +0 -241
  866. package/dist/program-DHxyOl81.js +0 -111
  867. package/dist/prompt-select-styled-BSf77q2T.js +0 -20
  868. package/dist/protocol-C4I0nfuT.js +0 -2477
  869. package/dist/provider-dispatcher-CkiPxKIr.js +0 -22
  870. package/dist/provider-dispatcher-PmsHJlUO.js +0 -2
  871. package/dist/qr-cli-BHY0TO2W.js +0 -2
  872. package/dist/qr-cli-BbjDJSKp.js +0 -349
  873. package/dist/reaction-runtime-api-DOigJrbq.js +0 -116
  874. package/dist/reactions-CogkrjNr.js +0 -998
  875. package/dist/register-service-commands-IA3Nfza5.js +0 -71
  876. package/dist/register.agent-DD0aSYye.js +0 -248
  877. package/dist/register.configure-BOy4i7Ah.js +0 -15
  878. package/dist/register.maintenance-CUp6FEOF.js +0 -363
  879. package/dist/register.message-DezTIpNI.js +0 -329
  880. package/dist/register.onboard-Brpxl9p3.js +0 -88
  881. package/dist/register.runtime-BfH5rSb_.js +0 -81
  882. package/dist/register.setup-CIt4FVv0.js +0 -150
  883. package/dist/register.status-health-sessions-IbGZwSaG.js +0 -1215
  884. package/dist/register.subclis-BFQii-42.js +0 -29
  885. package/dist/register.subclis-DlYCyoMp.js +0 -3
  886. package/dist/register.subclis-core-DcfC_0CS.js +0 -249
  887. package/dist/reply-dispatch-runtime-Lu4Metex.js +0 -13
  888. package/dist/reply-runtime-CgPzru94.js +0 -11
  889. package/dist/reply.runtime-sw14BA5F.js +0 -2
  890. package/dist/restart-health-1MNBua3p.js +0 -202
  891. package/dist/restart-health-BWGpwgPv.js +0 -2
  892. package/dist/root-help-B3zoC2OP.js +0 -44
  893. package/dist/routes-BM6fbday.js +0 -3341
  894. package/dist/routes-pVc_QLiP.js +0 -2
  895. package/dist/rpc-BGOWS7nj.js +0 -61
  896. package/dist/rpc.runtime-Ca9K3sx8.js +0 -21
  897. package/dist/run-delivery.runtime-CabntI64.js +0 -530
  898. package/dist/run-embedded.runtime-Q7wrP6Qn.js +0 -4
  899. package/dist/run-execution-cli.runtime-CtRUFc-M.js +0 -4
  900. package/dist/run-executor.runtime-Nm38xsKA.js +0 -277
  901. package/dist/run-main-UT0zTwCg.js +0 -567
  902. package/dist/run-subagent-registry.runtime-D9_scMUr.js +0 -2
  903. package/dist/run-wait-B2K_6JNL.js +0 -135
  904. package/dist/runtime-BZ296jTK.js +0 -9
  905. package/dist/runtime-DnZsw7MB.js +0 -973
  906. package/dist/runtime-api-BL9vpbvb.js +0 -14
  907. package/dist/runtime-api-BbsLJB4C.js +0 -9
  908. package/dist/runtime-api-ChwFrQRw.js +0 -9
  909. package/dist/runtime-api-_fH7M3Qh.js +0 -4
  910. package/dist/runtime-embedded-pi.runtime-TOdW-E-2.js +0 -2
  911. package/dist/runtime-internal-DGwOFi_E.js +0 -2
  912. package/dist/runtime-options-CSPfxkb1.js +0 -275
  913. package/dist/runtime-schema-DtNq1-Zd.js +0 -28576
  914. package/dist/scan-D6gkNpKl.js +0 -523
  915. package/dist/scan-_9J5-5L6.js +0 -2
  916. package/dist/secrets-cli-DlVSRQPM.js +0 -2101
  917. package/dist/security-cli-DtzNOYL2.js +0 -486
  918. package/dist/selection-CBJZE_FL.js +0 -7764
  919. package/dist/selection-XsoEF2p2.js +0 -2
  920. package/dist/send-BAaDBRfi.js +0 -156
  921. package/dist/send-BB-M1afy.js +0 -102
  922. package/dist/send.runtime-CI_75KUP.js +0 -2
  923. package/dist/server-D58E1Cua.js +0 -77
  924. package/dist/server-D6rXK0fF.js +0 -13
  925. package/dist/server-context-D5AnCc1E.js +0 -2
  926. package/dist/server-context-bt09wrJu.js +0 -847
  927. package/dist/server-node-events-CUx4-7FL.js +0 -481
  928. package/dist/server-plugin-bootstrap-CBcQpYIR.js +0 -12708
  929. package/dist/server-plugin-bootstrap-CfkBsGUg.js +0 -2
  930. package/dist/server-restart-sentinel-ByFI_0MB.js +0 -697
  931. package/dist/server.impl-DzntNeH-.js +0 -12864
  932. package/dist/session-kill-http-9MoO6FXC.js +0 -110
  933. package/dist/session-reset-service-redPsOs-.js +0 -497
  934. package/dist/session-route-C8oB2UYs.js +0 -93
  935. package/dist/session-status.runtime-D3bYBPJe.js +0 -2
  936. package/dist/session-subagent-reactivation.runtime-aat7tUag.js +0 -2
  937. package/dist/session-tab-registry-CAJ_oDsb.js +0 -581
  938. package/dist/session-visibility-Dq88jJYB.js +0 -147
  939. package/dist/sessions-helpers-C8-IkqhO.js +0 -305
  940. package/dist/sessions-history-http-4Ftuwnes.js +0 -383
  941. package/dist/sessions-patch-BsyNHOaz.js +0 -309
  942. package/dist/sessions-resolve-gKLz2Bup.js +0 -174
  943. package/dist/sessions.runtime-C1W59rQY.js +0 -2
  944. package/dist/setup-DhvXyU_5.js +0 -636
  945. package/dist/setup-api-B9Y4qPgq.js +0 -29
  946. package/dist/setup-core-CdFQ6ZXC.js +0 -176
  947. package/dist/setup-core-kXUD3Kat.js +0 -171
  948. package/dist/setup-surface-BFL9WfBs.js +0 -219
  949. package/dist/setup-surface-Cxg_nSWc.js +0 -286
  950. package/dist/setup-surface-DbooMj782.js +0 -403
  951. package/dist/setup.finalize-CKxukDYi.js +0 -547
  952. package/dist/setup.gateway-config-BhEtXwaB.js +0 -250
  953. package/dist/shared-BNVKrp5y.js +0 -76
  954. package/dist/shared-CM3mnx7z.js +0 -198
  955. package/dist/shared-CfrsSVhL.js +0 -121
  956. package/dist/slash-state-2Z-om57Q.js +0 -1911
  957. package/dist/src-DAoKvK_N.js +0 -3974
  958. package/dist/startup-context-CtYAdYwd.js +0 -312
  959. package/dist/status-B2M0Imij.js +0 -3
  960. package/dist/status-Bd-BNmiE.js +0 -2
  961. package/dist/status-D6nbpHFi.js +0 -397
  962. package/dist/status-MByUxUGu.js +0 -209
  963. package/dist/status-QUjO1tkz.js +0 -2
  964. package/dist/status-all-DPa-BiHk.js +0 -498
  965. package/dist/status-erNo8YmW.js +0 -190
  966. package/dist/status-json-command-C9rbAyj-.js +0 -84
  967. package/dist/status-json-tO3CQXIQ.js +0 -14
  968. package/dist/status-runtime-shared-DmBB_gmT.js +0 -257
  969. package/dist/status-subagents.runtime-BXAZr5y0.js +0 -18
  970. package/dist/status-text-BCeYk0-q.js +0 -237
  971. package/dist/status.gateway-connection.runtime-bt35dapy.js +0 -2
  972. package/dist/status.gather-B9a-CEev.js +0 -292
  973. package/dist/status.gather-ahBLFzk6.js +0 -2
  974. package/dist/status.runtime-BrErwtfc.js +0 -2
  975. package/dist/status.scan-D2mvM4II.js +0 -65
  976. package/dist/status.scan-overview-uOOaqp1t.js +0 -379
  977. package/dist/status.scan.fast-json-C9dkN28s.js +0 -2
  978. package/dist/status.scan.fast-json-DY3Or8S4.js +0 -132
  979. package/dist/status.summary-Cf4p2BPK.js +0 -2
  980. package/dist/status.summary-DxfZCcNa.js +0 -214
  981. package/dist/subagent-announce-CyQZsAIm.js +0 -351
  982. package/dist/subagent-announce-delivery-CgdPNjMA.js +0 -726
  983. package/dist/subagent-announce-output-D1xi4Tk1.js +0 -364
  984. package/dist/subagent-control-D-O6I8Mt.js +0 -506
  985. package/dist/subagent-followup.runtime-BbA7NPAq.js +0 -68
  986. package/dist/subagent-orphan-recovery-C6_cmAyE.js +0 -305
  987. package/dist/subagent-registry-Dn_XpDh0.js +0 -1753
  988. package/dist/subagent-registry-DodFw3pu.js +0 -3
  989. package/dist/subagent-spawn-Dw5lttXp.js +0 -1005
  990. package/dist/system-cli-CSqO2Z4K.js +0 -59
  991. package/dist/targets-CMdwh9lR.js +0 -67
  992. package/dist/task-executor-DgZSfcBk.js +0 -360
  993. package/dist/task-owner-access-9c38idlo.js +0 -74
  994. package/dist/task-registry-Z-lBPkNj.js +0 -2366
  995. package/dist/task-registry-delivery-runtime-DOV4qoj4.js +0 -2
  996. package/dist/task-registry-delivery-runtime-EATr0C3C.js +0 -3
  997. package/dist/task-registry.maintenance-C1YMEwhk.js +0 -416
  998. package/dist/task-registry.maintenance-CBfaUWcp.js +0 -2
  999. package/dist/testing-CFk04o9M.js +0 -575
  1000. package/dist/text-report-QhVG354o.js +0 -587
  1001. package/dist/tool-resolution-D6V4tg-G.js +0 -90
  1002. package/dist/tools-effective-inventory-DFU7yYvD.js +0 -152
  1003. package/dist/tools-invoke-http-y6WIa3Ku.js +0 -206
  1004. package/dist/trash-rhbwNhfQ.js +0 -24
  1005. package/dist/tui-cli-BfxeO4YM.js +0 -4575
  1006. package/dist/update-cli-DaN9bvPV.js +0 -1759
  1007. package/dist/upgrade-f5dlIxir.js +0 -1226
  1008. package/dist/video-generation-task-status-yX54iO8n.js +0 -163
  1009. package/dist/wait-for-idle-before-flush-mZrBNr5z.js +0 -5986
  1010. 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 };