@pixelzx/genesis 2026.6.13-beta.3 → 2026.6.13

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 (1009) hide show
  1. package/dist/.buildstamp +1 -1
  2. package/dist/abort-CUEXCdsZ.js +201 -0
  3. package/dist/abort.runtime-pbOgDldP.js +2 -0
  4. package/dist/abort.runtime.js +1 -1
  5. package/dist/accounts-BtjI3Z72.js +2 -0
  6. package/dist/accounts-CgGxrOwS.js +107 -0
  7. package/dist/accounts-Ddm5_DS5.js +104 -0
  8. package/dist/acp-cli-Llxb5ymk.js +2217 -0
  9. package/dist/acp-spawn-BTb-KXxB.js +1093 -0
  10. package/dist/acp-spawn-DHriTNXb.js +2 -0
  11. package/dist/acp-stateful-target-driver-DBVhWBrt.js +89 -0
  12. package/dist/action-agents-CGlVq0bn.js +67 -0
  13. package/dist/action-focus-X9cJX3UC.js +132 -0
  14. package/dist/action-help-D1M6mIWb.js +7 -0
  15. package/dist/action-info-fCoEt-Rn.js +101 -0
  16. package/dist/action-kill-DP4EEnxt.js +33 -0
  17. package/dist/action-list-CcjpvN9N.js +21 -0
  18. package/dist/action-log-YUvfBfxP.js +30 -0
  19. package/dist/action-send-B92BNjlE.js +39 -0
  20. package/dist/action-spawn-CTVbxHB8.js +47 -0
  21. package/dist/action-unfocus-CCvrRtpz.js +29 -0
  22. package/dist/actions.runtime-CoSzf-df.js +5 -0
  23. package/dist/actions.runtime-DcqD6Le-.js +18 -0
  24. package/dist/actions.runtime.js +1 -1
  25. package/dist/agent-CQEBS9pS.js +2 -0
  26. package/dist/agent-command-KS0kk4R_.js +874 -0
  27. package/dist/agent-harness-runtime-DpgQTWHS.js +144 -0
  28. package/dist/agent-runner-utils-Bfjw1bSj.js +239 -0
  29. package/dist/agent-runner.runtime-BmWGZi8Z.js +3455 -0
  30. package/dist/agent-runner.runtime.js +1 -1
  31. package/dist/agent-runtime-Cju2h7Dd.js +18 -0
  32. package/dist/agents-6HPmn29e.js +5 -0
  33. package/dist/agents-ZkvxBcii.js +954 -0
  34. package/dist/aliases-BpgQEAi2.js +2 -0
  35. package/dist/aliases-CK0aIskI.js +96 -0
  36. package/dist/api-BxjlJBf7.js +3 -0
  37. package/dist/api-CalF94xg.js +5 -0
  38. package/dist/api-D_GKjzfN.js +139 -0
  39. package/dist/approval-gateway-resolver-Dxycea4Z.js +29 -0
  40. package/dist/approval-gateway-runtime-D3X-ZiqD.js +2 -0
  41. package/dist/approval-handler-runtime-CRqE_cXp.js +439 -0
  42. package/dist/approval-native-runtime-zR041zyJ.js +729 -0
  43. package/dist/attempt-execution.runtime-1Wa08yf1.js +509 -0
  44. package/dist/attempt-execution.runtime.js +1 -1
  45. package/dist/attempt.prompt-helpers-z-6VGwRW.js +221 -0
  46. package/dist/attempt.tool-run-context-C70C_cPM.js +933 -0
  47. package/dist/audit-DfIX2KwE.js +939 -0
  48. package/dist/audit.runtime-BNH37U5T.js +7 -0
  49. package/dist/audit.runtime.js +1 -1
  50. package/dist/auth-DkcLHjkF.js +2 -0
  51. package/dist/auth-order-B9P_KybB.js +2 -0
  52. package/dist/auth-order-ozs0zLmu.js +139 -0
  53. package/dist/auth-vKHIBjC8.js +550 -0
  54. package/dist/bash-tools-CLGCvCUP.js +2824 -0
  55. package/dist/bash-tools-CaBEBURe.js +3 -0
  56. package/dist/binding-routing-D4HA2ved.js +85 -0
  57. package/dist/binding-targets-DA9ecVsr.js +121 -0
  58. package/dist/bridge-server-gnPeACBa.js +113 -0
  59. package/dist/browser-control-auth-CM8pNt8J.js +2 -0
  60. package/dist/browser-node-runtime-C-mstNpu.js +12 -0
  61. package/dist/browser-profiles-Dg-k95aL.js +2 -0
  62. package/dist/browser-runtime-DirlsYmK.js +387 -0
  63. package/dist/browser-setup-tools-BXWUuJ6m.js +13 -0
  64. package/dist/build-CijTB8Fi.js +550 -0
  65. package/dist/build-info.json +3 -3
  66. package/dist/bundled/boot-md/handler.js +2 -2
  67. package/dist/bundled/session-memory/handler.js +1 -1
  68. package/dist/call-85RWmQAH.js +3 -0
  69. package/dist/call-CL7Keh1p.js +331 -0
  70. package/dist/call.runtime-xbzyWzEi.js +2 -0
  71. package/dist/call.runtime.js +1 -1
  72. package/dist/capability-cli-DLY0EugY.js +1401 -0
  73. package/dist/catchup-pqyBQ6UZ.js +300 -0
  74. package/dist/channel-B-_yLOuX.js +1320 -0
  75. package/dist/channel-BMRnqh3W.js +840 -0
  76. package/dist/channel-BrrfXNkf.js +297 -0
  77. package/dist/channel-C1VXF6vY.js +595 -0
  78. package/dist/channel-C6MisWnA.js +350 -0
  79. package/dist/channel-C7Y0GD7W.js +1100 -0
  80. package/dist/channel-C9Kr__RL.js +226 -0
  81. package/dist/channel-CJFK3uRJ.js +1802 -0
  82. package/dist/channel-Crm7UunT.js +453 -0
  83. package/dist/channel-M5ZFW6rv.js +491 -0
  84. package/dist/channel-VL7FJNyb.js +1174 -0
  85. package/dist/channel-core-DB2nzAkT.js +5 -0
  86. package/dist/channel-inbound-CATPKMen.js +31 -0
  87. package/dist/channel-plugin-runtime-DhEHiW41.js +771 -0
  88. package/dist/channel-runtime-CE1xTvWZ.js +425 -0
  89. package/dist/channel.runtime-3APLcE-1.js +42398 -0
  90. package/dist/channel.runtime-B8slMR61.js +89 -0
  91. package/dist/channel.runtime-BKjTINZH.js +4 -0
  92. package/dist/channel.runtime-DHfGxcjG.js +2364 -0
  93. package/dist/channel.runtime-DVnkA8AL.js +576 -0
  94. package/dist/channel.runtime-DaFfPWdI.js +430 -0
  95. package/dist/channel.setup-C3Ag76tq.js +10 -0
  96. package/dist/channel2.runtime-DUB2QEK1.js +109 -0
  97. package/dist/channel2.runtime.js +1 -1
  98. package/dist/channels-CBvXY2t_.js +733 -0
  99. package/dist/channels-cli-CkoeG5y5.js +268 -0
  100. package/dist/chat-DbvGOpf-.js +2830 -0
  101. package/dist/clawbot-cli-CLuaKcyW.js +9 -0
  102. package/dist/cli/daemon-cli.js +3 -3
  103. package/dist/cli-B5Ub8Cgn.js +2 -0
  104. package/dist/cli-BDH4ZbeI.js +2 -0
  105. package/dist/cli-CWOy2CsV.js +219 -0
  106. package/dist/cli-DyG2YLBa.js +72 -0
  107. package/dist/cli-runner-D8mL6FWu.js +286 -0
  108. package/dist/cli-runner.runtime-BCrZn2CL.js +4 -0
  109. package/dist/cli-runner.runtime-ChQ6WYTw.js +3 -0
  110. package/dist/cli-runner.runtime.js +1 -1
  111. package/dist/cli-startup-metadata.json +2 -2
  112. package/dist/cli.runtime-c5SW-DVR.js +1261 -0
  113. package/dist/cli.runtime.js +1 -1
  114. package/dist/client-BdWZGAKV.js +713 -0
  115. package/dist/client-G9bp9IBR.js +138 -0
  116. package/dist/command-auth-C6emi1Rr.js +76 -0
  117. package/dist/command-config-resolution-CY8Uap6U.js +2 -0
  118. package/dist/command-config-resolution-Dkkd_zz7.js +23 -0
  119. package/dist/command-config-resolution.runtime-B03wRV-i.js +2 -0
  120. package/dist/command-config-resolution.runtime.js +1 -1
  121. package/dist/command-registry-BdXEbnVK.js +9 -0
  122. package/dist/command-registry-BwJ8YzAH.js +4 -0
  123. package/dist/command-registry-core-X1IeFtlC.js +106 -0
  124. package/dist/command-secret-gateway-BxGIG8ny.js +528 -0
  125. package/dist/command-status.runtime-5QfAs_4U.js +87 -0
  126. package/dist/command-status.runtime.js +1 -1
  127. package/dist/commands-acp-15kfWcgC.js +77 -0
  128. package/dist/commands-compact.runtime-GdDN_EbV.js +10 -0
  129. package/dist/commands-compact.runtime.js +1 -1
  130. package/dist/commands-handlers.runtime-Cb8uy-yp.js +4599 -0
  131. package/dist/commands-handlers.runtime.js +1 -1
  132. package/dist/commands-status-BfvtgMfw.js +16 -0
  133. package/dist/commands-status.runtime-C4UOWuC1.js +3 -0
  134. package/dist/commands-status.runtime.js +1 -1
  135. package/dist/commands-subagents-control.runtime-CU9SGNdt.js +3 -0
  136. package/dist/commands-subagents-control.runtime-DnTa6bzF.js +2 -0
  137. package/dist/commands-subagents-control.runtime.js +1 -1
  138. package/dist/commands-system-prompt-B1VTjT7j.js +2 -0
  139. package/dist/commands-system-prompt-BpBKEr8Y.js +158 -0
  140. package/dist/commands.runtime-Dpj2M0X6.js +167 -0
  141. package/dist/commands.runtime.js +1 -1
  142. package/dist/compact-CW1IbeBL.js +1118 -0
  143. package/dist/compact.runtime-BML0MjKx.js +12 -0
  144. package/dist/compact.runtime.js +1 -1
  145. package/dist/completion-cli-DfjmvVEd.js +328 -0
  146. package/dist/config-Cs1RBMvI.js +252 -0
  147. package/dist/config-cli-B4sSTkyr.js +1078 -0
  148. package/dist/configure-DR8rchLE.js +1252 -0
  149. package/dist/configure-arK50J-8.js +2 -0
  150. package/dist/connect-options-eEG6omnx.js +699 -0
  151. package/dist/control-auth-D6O4ILiF.js +125 -0
  152. package/dist/control-service-DtnOpS8v.js +156 -0
  153. package/dist/conversation-id-CF4M7Rh_.js +38 -0
  154. package/dist/conversation-id-lrCRurjf.js +235 -0
  155. package/dist/conversation-runtime-CmrgJq5s.js +31 -0
  156. package/dist/core-cFPca6I1.js +275 -0
  157. package/dist/cron-cli-BZw_Pb_X.js +713 -0
  158. package/dist/daemon-cli-CBs3tlnX.js +12 -0
  159. package/dist/dashboard-DOnBYDVr.js +2 -0
  160. package/dist/dashboard-Xsq0BOfY.js +81 -0
  161. package/dist/delegate-YTxameSy.js +64 -0
  162. package/dist/detached-task-runtime-DG_5Cqxs.js +73 -0
  163. package/dist/devices-cli-DkhwpYb8.js +498 -0
  164. package/dist/diagnostics-C_w66y4V.js +154 -0
  165. package/dist/direct-dm-DIod6mar.js +64 -0
  166. package/dist/dispatch-BDQe80zG.js +1131 -0
  167. package/dist/dispatch-acp-jOkMwRPa.js +981 -0
  168. package/dist/dispatch-acp-manager.runtime-Cys6AkDd.js +3 -0
  169. package/dist/dispatch-acp-manager.runtime.js +1 -1
  170. package/dist/dispatch-acp.runtime-BCFY7UOj.js +19 -0
  171. package/dist/dispatch-acp.runtime.js +1 -1
  172. package/dist/doctor-device-pairing-CpGyVqbv.js +307 -0
  173. package/dist/doctor-gateway-daemon-flow-Dt447a03.js +250 -0
  174. package/dist/doctor-gateway-health-BOgr3ZTP.js +63 -0
  175. package/dist/doctor-health-CM9WRrKn.js +59 -0
  176. package/dist/doctor-health-contributions-Dp96BnoL.js +493 -0
  177. package/dist/doctor-prompter-DSrAf0qq.js +56 -0
  178. package/dist/doctor-workspace-status-BcV9YZTP.js +75 -0
  179. package/dist/dreaming-DzWUr8i3.js +1582 -0
  180. package/dist/dreaming-narrative-BFfAvouy.js +596 -0
  181. package/dist/embedded-gateway-stub.runtime-BwG8b1xF.js +9 -0
  182. package/dist/embedded-gateway-stub.runtime.js +1 -1
  183. package/dist/entry.js +2 -2
  184. package/dist/exec-approvals-cli-WT6PMw5I.js +498 -0
  185. package/dist/extensionAPI.js +1 -1
  186. package/dist/extensions/active-memory/index.js +1 -1
  187. package/dist/extensions/bluebubbles/api.js +3 -3
  188. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  189. package/dist/extensions/browser/browser-bridge.js +1 -1
  190. package/dist/extensions/browser/browser-config.js +4 -4
  191. package/dist/extensions/browser/browser-control-auth.js +2 -2
  192. package/dist/extensions/browser/browser-doctor.js +2 -2
  193. package/dist/extensions/browser/browser-maintenance.js +2 -2
  194. package/dist/extensions/browser/browser-profiles.js +2 -2
  195. package/dist/extensions/browser/browser-runtime-api.js +10 -10
  196. package/dist/extensions/browser/index.js +1 -1
  197. package/dist/extensions/browser/plugin-registration.js +1 -1
  198. package/dist/extensions/browser/register.runtime.js +3 -3
  199. package/dist/extensions/browser/runtime-api.js +11 -11
  200. package/dist/extensions/browser/test-support.js +1 -1
  201. package/dist/extensions/device-pair/api.js +1 -1
  202. package/dist/extensions/device-pair/index.js +3 -3
  203. package/dist/extensions/device-pair/notify.js +1 -1
  204. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  205. package/dist/extensions/google-meet/index.js +2 -2
  206. package/dist/extensions/imessage/api.js +3 -3
  207. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  208. package/dist/extensions/imessage/runtime-api.js +3 -3
  209. package/dist/extensions/irc/api.js +2 -2
  210. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  211. package/dist/extensions/line/api.js +2 -2
  212. package/dist/extensions/line/channel-plugin-api.js +1 -1
  213. package/dist/extensions/line/contract-api.js +1 -1
  214. package/dist/extensions/line/runtime-api.js +4 -4
  215. package/dist/extensions/line/setup-api.js +1 -1
  216. package/dist/extensions/llm-task/index.js +2 -2
  217. package/dist/extensions/lobster/index.js +3 -3
  218. package/dist/extensions/lobster/runtime-api.js +1 -1
  219. package/dist/extensions/mattermost/api.js +1 -1
  220. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  221. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  222. package/dist/extensions/mattermost/policy-api.js +1 -1
  223. package/dist/extensions/mattermost/runtime-api.js +4 -4
  224. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  225. package/dist/extensions/memory-core/api.js +1 -1
  226. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  227. package/dist/extensions/memory-core/index.js +3 -3
  228. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  229. package/dist/extensions/msteams/api.js +1 -1
  230. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  231. package/dist/extensions/msteams/runtime-api.js +3 -3
  232. package/dist/extensions/msteams/test-api.js +1 -1
  233. package/dist/extensions/nextcloud-talk/api.js +1 -1
  234. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  235. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  236. package/dist/extensions/openshell/index.js +2 -2
  237. package/dist/extensions/signal/api.js +6 -6
  238. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  239. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  240. package/dist/extensions/signal/runtime-api.js +7 -7
  241. package/dist/extensions/skill-workshop/api.js +1 -1
  242. package/dist/extensions/skill-workshop/index.js +1 -1
  243. package/dist/extensions/synology-chat/api.js +1 -1
  244. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  245. package/dist/extensions/tlon/api.js +2 -2
  246. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  247. package/dist/extensions/tlon/runtime-api.js +1 -1
  248. package/dist/extensions/tlon/test-api.js +1 -1
  249. package/dist/extensions/twitch/api.js +1 -1
  250. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  251. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  252. package/dist/extensions/zalo/api.js +3 -3
  253. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  254. package/dist/extensions/zalo/runtime-api.js +2 -2
  255. package/dist/extensions/zalo/setup-api.js +2 -2
  256. package/dist/extensions/zalouser/api.js +3 -3
  257. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  258. package/dist/extensions/zalouser/runtime-api.js +6 -6
  259. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  260. package/dist/extensions/zalouser/test-api.js +1 -1
  261. package/dist/fallbacks-BVWn3y-0.js +31 -0
  262. package/dist/fallbacks-Dw_bkoWB.js +2 -0
  263. package/dist/fallbacks-shared-BEsBzsm3.js +111 -0
  264. package/dist/gateway-cli-BUxyZoGn.js +1283 -0
  265. package/dist/gateway-p2LteXL8.js +115 -0
  266. package/dist/gateway-rpc-D8q7ZQDi.js +14 -0
  267. package/dist/gateway-rpc.runtime-D_0TNej1.js +23 -0
  268. package/dist/gateway-rpc.runtime.js +1 -1
  269. package/dist/gateway-runtime-DYUdOqYz.js +15 -0
  270. package/dist/gateway-status-ZBWKhThd.js +584 -0
  271. package/dist/genesis-tools-oUxtX0O2.js +9166 -0
  272. package/dist/genesis-tools.runtime-Cx-FIdJQ.js +2 -0
  273. package/dist/genesis-tools.runtime.js +1 -1
  274. package/dist/get-reply-BPIG7KcY.js +3897 -0
  275. package/dist/get-reply-from-config.runtime-CnHudoiv.js +2 -0
  276. package/dist/get-reply-from-config.runtime.js +1 -1
  277. package/dist/graph-users-DwHoVTRw.js +1337 -0
  278. package/dist/health-B2JkLr-g.js +3 -0
  279. package/dist/health-Db30zfNX.js +469 -0
  280. package/dist/health-route--Oa3RIgW.js +2 -0
  281. package/dist/health-route-CUCmtqv5.js +41 -0
  282. package/dist/heartbeat-runner-BZp7aZ2w.js +5 -0
  283. package/dist/heartbeat-runner-C1VMkjRh.js +1292 -0
  284. package/dist/heartbeat-runner.runtime-ChAITmTa.js +4 -0
  285. package/dist/heartbeat-runner.runtime.js +1 -1
  286. package/dist/hooks-cli-NPBiUXrV.js +433 -0
  287. package/dist/image-fallbacks-CgnkUGl-.js +31 -0
  288. package/dist/image-fallbacks-CkcfrgGr.js +2 -0
  289. package/dist/inbound-reply-dispatch-DatqwKdH.js +73 -0
  290. package/dist/index.js +2 -2
  291. package/dist/infra-runtime-DF5DBM7E.js +39 -0
  292. package/dist/init-H9ZKfvws.js +59 -0
  293. package/dist/library-B7YkN7SI.js +45 -0
  294. package/dist/lifecycle-BclPLGGp.js +229 -0
  295. package/dist/lifecycle-C_3bV3nu.js +571 -0
  296. package/dist/lifecycle.runtime-WNsFm3uq.js +2 -0
  297. package/dist/lifecycle.runtime.js +1 -1
  298. package/dist/list-C4LkHj9E.js +2 -0
  299. package/dist/list-Co85YbCS.js +2 -0
  300. package/dist/list-D8pfqTNx.js +131 -0
  301. package/dist/list-oJMN_3OD.js +1212 -0
  302. package/dist/list.probe-DZjGof7G.js +419 -0
  303. package/dist/llm-slug-generator-knfnn0mT.js +79 -0
  304. package/dist/llm-slug-generator.js +1 -1
  305. package/dist/load-config-BPbDzvCY.js +35 -0
  306. package/dist/local-dispatch.runtime-BtylNF8x.js +8 -0
  307. package/dist/local-dispatch.runtime.js +1 -1
  308. package/dist/logs-cli-BWGb1in_.js +265 -0
  309. package/dist/logs-cli.runtime-DBp3UCcP.js +2 -0
  310. package/dist/logs-cli.runtime.js +1 -1
  311. package/dist/main-session-restart-recovery-BJt-saEI.js +206 -0
  312. package/dist/managed-image-attachments-BuO0SCpc.js +635 -0
  313. package/dist/managed-image-attachments-C4QYz3yC.js +2 -0
  314. package/dist/manager-C0c4DxXa.js +2 -0
  315. package/dist/manager-DmLckyN1.js +2057 -0
  316. package/dist/markdown-to-line-BVs9RDRe.js +790 -0
  317. package/dist/mcp/plugin-tools-serve.js +1 -1
  318. package/dist/mcp-cli-Cq3kJYFy.js +725 -0
  319. package/dist/mcp-http-C8sBBMH1.js +529 -0
  320. package/dist/memory-core-host-runtime-cli-DYW7bPF_.js +9 -0
  321. package/dist/message-Bec0oyM4.js +232 -0
  322. package/dist/message-action-runner-BIvqB_FI.js +2 -0
  323. package/dist/message-action-runner-D66_Fo-V.js +1407 -0
  324. package/dist/message-actions-BJs-Awr8.js +143 -0
  325. package/dist/message.gateway.runtime-BxKiFLPu.js +2 -0
  326. package/dist/message.gateway.runtime.js +1 -1
  327. package/dist/models-auth-status-BKHvtTwP.js +217 -0
  328. package/dist/models-cli-CoqcvJz5.js +271 -0
  329. package/dist/monitor-BO_gZrgs.js +1459 -0
  330. package/dist/monitor-C_4tbG4E.js +671 -0
  331. package/dist/monitor-DVTKLiFb.js +2 -0
  332. package/dist/monitor-P35vmooh.js +1237 -0
  333. package/dist/monitor-auth-DkTEAzy7.js +207 -0
  334. package/dist/monitor-gaiYvZ-I.js +788 -0
  335. package/dist/monitor-processing-BpjusT5o.js +1974 -0
  336. package/dist/monitor-uCqIYno8.js +1661 -0
  337. package/dist/monitor.runtime-CbMSQBgz.js +2 -0
  338. package/dist/monitor.runtime.js +1 -1
  339. package/dist/monitor.webhook-z4zhNHYy.js +180 -0
  340. package/dist/msteams-ChjqyPxy.js +35 -0
  341. package/dist/native-hook-relay-hOpMhOTR.js +519 -0
  342. package/dist/nextcloud-talk-BfJltkau.js +17 -0
  343. package/dist/node-cli-NXEXoWYg.js +2276 -0
  344. package/dist/nodes-cli-Dlq3ORXy.js +1046 -0
  345. package/dist/nodes-utils-o8KC_0Ci.js +84 -0
  346. package/dist/nodes.helpers-B2jPrnEd.js +34 -0
  347. package/dist/notify-VSv6I2dB.js +315 -0
  348. package/dist/onboard-I72X1v1y.js +70 -0
  349. package/dist/onboard-WRT3rbQo.js +2 -0
  350. package/dist/onboard-helpers-BnbqaUN2.js +6 -0
  351. package/dist/onboard-helpers-Kt5u4yMJ.js +204 -0
  352. package/dist/onboard-interactive-CIhTNhiD.js +24 -0
  353. package/dist/onboard-non-interactive-Hk6vLQCB.js +635 -0
  354. package/dist/onboard-remote-CQo_tQNa.js +193 -0
  355. package/dist/onboard-remote-DyRv7tdE.js +2 -0
  356. package/dist/onboard-skills-BRv5-6Ke.js +2 -0
  357. package/dist/onboard-skills-CeXPYTFg.js +134 -0
  358. package/dist/openai-http-kgzRj9Fg.js +500 -0
  359. package/dist/openresponses-http-DnJSiUa4.js +1128 -0
  360. package/dist/operator-approvals-client-B8dLxxFu.js +68 -0
  361. package/dist/outbound.runtime-CDrYtbmY.js +2 -0
  362. package/dist/outbound.runtime.js +1 -1
  363. package/dist/pair-command-approve-CFU4_I15.js +44 -0
  364. package/dist/persistent-bindings.lifecycle-5_yxfyfG.js +85 -0
  365. package/dist/persistent-bindings.lifecycle-DtFnl1yI.js +2 -0
  366. package/dist/pi-embedded-DPKqHoG9.js +2905 -0
  367. package/dist/pi-embedded-YM1PXjPH.js +4 -0
  368. package/dist/pi-embedded.runtime-FRv5dWIr.js +4 -0
  369. package/dist/pi-embedded.runtime.js +1 -1
  370. package/dist/pi-tool-definition-adapter-DAVcmPPg.js +229 -0
  371. package/dist/pi-tools-pgCF9tvm.js +1057 -0
  372. package/dist/pi-tools.before-tool-call-Blvjro7X.js +2 -0
  373. package/dist/pi-tools.before-tool-call-CMEGGnv-.js +433 -0
  374. package/dist/plugin-DoJ_IM72.js +12195 -0
  375. package/dist/plugin-enabled-C9PNEsMB.js +140 -0
  376. package/dist/plugin-registration-CPGTZRDF.js +23 -0
  377. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  378. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  379. package/dist/plugin-sdk/acp-runtime.js +2 -2
  380. package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
  381. package/dist/plugin-sdk/agent-harness.js +6 -6
  382. package/dist/plugin-sdk/agent-runtime.js +2 -2
  383. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  384. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  385. package/dist/plugin-sdk/approval-runtime.js +1 -1
  386. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  387. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  388. package/dist/plugin-sdk/browser-support.js +7 -7
  389. package/dist/plugin-sdk/channel-core.js +2 -2
  390. package/dist/plugin-sdk/channel-inbound.js +2 -2
  391. package/dist/plugin-sdk/command-auth.js +1 -1
  392. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  393. package/dist/plugin-sdk/compat.js +1 -1
  394. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  395. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  396. package/dist/plugin-sdk/core.js +2 -2
  397. package/dist/plugin-sdk/direct-dm.js +1 -1
  398. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  399. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  400. package/dist/plugin-sdk/index.js +1 -1
  401. package/dist/plugin-sdk/infra-runtime.js +2 -2
  402. package/dist/plugin-sdk/irc.js +2 -2
  403. package/dist/plugin-sdk/matrix.js +1 -1
  404. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  405. package/dist/plugin-sdk/memory-core.js +2 -2
  406. package/dist/plugin-sdk/msteams.js +2 -2
  407. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  408. package/dist/plugin-sdk/nostr.js +1 -1
  409. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  410. package/dist/plugin-sdk/reply-runtime.js +4 -4
  411. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  412. package/dist/plugin-sdk/runtime.js +2 -2
  413. package/dist/plugin-sdk/session-visibility.js +1 -1
  414. package/dist/plugin-sdk/testing.js +4 -4
  415. package/dist/plugin-sdk/tlon.js +1 -1
  416. package/dist/plugin-sdk/zalo.js +1 -1
  417. package/dist/plugin-sdk/zalouser.js +1 -1
  418. package/dist/plugin-service-c09KhFRA.js +2893 -0
  419. package/dist/plugins/runtime/index.js +1 -1
  420. package/dist/policy-DxSwu86T.js +328 -0
  421. package/dist/postinstall-inventory.json +414 -414
  422. package/dist/prepare.runtime-BIEQIV8L.js +815 -0
  423. package/dist/prepare.runtime.js +1 -1
  424. package/dist/probe-6HwDlk5s.js +2 -0
  425. package/dist/probe-BbvEHYyJ.js +2 -0
  426. package/dist/probe-COR7fP_v.js +2205 -0
  427. package/dist/probe-DE9JjGqN.js +241 -0
  428. package/dist/probe-DLS0a8fK.js +74 -0
  429. package/dist/probe-D_l_otos.js +45 -0
  430. package/dist/probe-ZtUbt8f-.js +1443 -0
  431. package/dist/program-DfQvGH1d.js +111 -0
  432. package/dist/prompt-select-styled-DM6haaKV.js +20 -0
  433. package/dist/protocol-CqddCqi8.js +2479 -0
  434. package/dist/provider-dispatcher-BR6UQE4t.js +22 -0
  435. package/dist/provider-dispatcher-CbwCRQ43.js +2 -0
  436. package/dist/qr-cli-D51XKVJW.js +349 -0
  437. package/dist/qr-cli-i4TjyLtW.js +2 -0
  438. package/dist/reaction-runtime-api-DDV-gubE.js +116 -0
  439. package/dist/reactions-BvXn-qBP.js +998 -0
  440. package/dist/register-service-commands-B6ZQumi9.js +71 -0
  441. package/dist/register.agent-CtzP54VE.js +248 -0
  442. package/dist/register.configure-BLcph6ME.js +15 -0
  443. package/dist/register.maintenance-CPYg-yEz.js +363 -0
  444. package/dist/register.message-CficlkIg.js +329 -0
  445. package/dist/register.onboard-1xQPe7tH.js +88 -0
  446. package/dist/register.runtime-CCeTiEB_.js +81 -0
  447. package/dist/register.runtime.js +1 -1
  448. package/dist/register.setup-DAoIkDtN.js +150 -0
  449. package/dist/register.status-health-sessions-0WKthgEo.js +1215 -0
  450. package/dist/register.subclis-DLvpHAI3.js +29 -0
  451. package/dist/register.subclis-JxfqEla5.js +3 -0
  452. package/dist/register.subclis-core-DuiCves5.js +249 -0
  453. package/dist/reply-dispatch-runtime-C9_ukgcR.js +13 -0
  454. package/dist/reply-runtime-OPe17s80.js +11 -0
  455. package/dist/reply.runtime-DDlQ67N1.js +2 -0
  456. package/dist/reply.runtime.js +1 -1
  457. package/dist/restart-health-CL-01acN.js +202 -0
  458. package/dist/restart-health-YEV65VfM.js +2 -0
  459. package/dist/root-help-BJQSVoY8.js +44 -0
  460. package/dist/routes-BmkmbLoX.js +3341 -0
  461. package/dist/routes-Bnind2jW.js +2 -0
  462. package/dist/rpc-DY2jvCMf.js +61 -0
  463. package/dist/rpc.runtime-ChyBZELh.js +21 -0
  464. package/dist/rpc.runtime.js +1 -1
  465. package/dist/run-delivery.runtime-Dz-12Zd4.js +530 -0
  466. package/dist/run-delivery.runtime.js +1 -1
  467. package/dist/run-embedded.runtime-BpU5lMNC.js +4 -0
  468. package/dist/run-embedded.runtime.js +1 -1
  469. package/dist/run-execution-cli.runtime-DAFehfXH.js +4 -0
  470. package/dist/run-execution-cli.runtime.js +1 -1
  471. package/dist/run-executor.runtime-rpu8onA8.js +277 -0
  472. package/dist/run-executor.runtime.js +1 -1
  473. package/dist/run-main-C_inhxnF.js +567 -0
  474. package/dist/run-subagent-registry.runtime-B6k7yCGg.js +2 -0
  475. package/dist/run-subagent-registry.runtime.js +1 -1
  476. package/dist/run-wait-CFzlGkj_.js +135 -0
  477. package/dist/runtime-Dhl_rNom.js +9 -0
  478. package/dist/runtime-OHV6waIC.js +973 -0
  479. package/dist/runtime-api-BWNiBA3c.js +9 -0
  480. package/dist/runtime-api-BfIyvgB_.js +14 -0
  481. package/dist/runtime-api-D424hB_J.js +4 -0
  482. package/dist/runtime-api-DtKgDipG.js +9 -0
  483. package/dist/runtime-embedded-pi.runtime-DFWGcHwZ.js +2 -0
  484. package/dist/runtime-embedded-pi.runtime.js +1 -1
  485. package/dist/runtime-internal-CaCnQ02a.js +2 -0
  486. package/dist/runtime-options-D4BvjWB8.js +275 -0
  487. package/dist/runtime-schema-pjSPEOAs.js +28588 -0
  488. package/dist/scan--Q_WB1Hw.js +2 -0
  489. package/dist/scan-B62XQB6F.js +523 -0
  490. package/dist/secrets-cli-BGEY6lbE.js +2101 -0
  491. package/dist/security-cli-Dcjib0xt.js +486 -0
  492. package/dist/selection-DnBlD3ri.js +7764 -0
  493. package/dist/selection-DtFOwoyl.js +2 -0
  494. package/dist/send-DQ2jC-kR.js +156 -0
  495. package/dist/send-DqkSZeSs.js +102 -0
  496. package/dist/send.runtime-np7_gr25.js +2 -0
  497. package/dist/send.runtime.js +1 -1
  498. package/dist/server-CDV_YyCz.js +77 -0
  499. package/dist/server-Dyzhwdln.js +13 -0
  500. package/dist/server-context-C1If0B6s.js +2 -0
  501. package/dist/server-context-DwGUOfrl.js +847 -0
  502. package/dist/server-node-events-DUpSxyRf.js +481 -0
  503. package/dist/server-plugin-bootstrap-CFpMAmvv.js +2 -0
  504. package/dist/server-plugin-bootstrap-D86uxpDr.js +13176 -0
  505. package/dist/server-restart-sentinel-CKsgDiab.js +697 -0
  506. package/dist/server.impl-BYjxobzs.js +12894 -0
  507. package/dist/session-kill-http-phKXyTTy.js +110 -0
  508. package/dist/session-reset-service-CwvaVami.js +497 -0
  509. package/dist/session-route-BTgIfE1c.js +93 -0
  510. package/dist/session-status.runtime-ChCTEeUR.js +2 -0
  511. package/dist/session-status.runtime.js +1 -1
  512. package/dist/session-subagent-reactivation.runtime-BpZtYfkl.js +2 -0
  513. package/dist/session-subagent-reactivation.runtime.js +1 -1
  514. package/dist/session-tab-registry-BqpCfcjM.js +581 -0
  515. package/dist/session-visibility-CedNChjb.js +147 -0
  516. package/dist/sessions-helpers-Drc1RiQe.js +305 -0
  517. package/dist/sessions-history-http-B3R_-kZs.js +383 -0
  518. package/dist/sessions-patch-DxL9yDsS.js +309 -0
  519. package/dist/sessions-resolve-BGCm2THO.js +174 -0
  520. package/dist/sessions.runtime-BiIsLfCP.js +2 -0
  521. package/dist/sessions.runtime.js +1 -1
  522. package/dist/setup-Cz1lcHMi.js +636 -0
  523. package/dist/setup-api-C_6auH7A.js +29 -0
  524. package/dist/setup-core-BcqeRlfc.js +171 -0
  525. package/dist/setup-core-BfpSQ1D1.js +176 -0
  526. package/dist/setup-surface-BI4jBqI52.js +403 -0
  527. package/dist/setup-surface-DIuPs4Hz.js +219 -0
  528. package/dist/setup-surface-ncxzGn0K.js +286 -0
  529. package/dist/setup.finalize-_eGrewCd.js +547 -0
  530. package/dist/setup.gateway-config-mG-DCNXx.js +250 -0
  531. package/dist/shared-BJcmJyRx.js +198 -0
  532. package/dist/shared-C2dlYHIW.js +76 -0
  533. package/dist/shared-C_hL6o63.js +121 -0
  534. package/dist/slash-state-CzVTgrEK.js +1911 -0
  535. package/dist/src-CDovn7A6.js +3974 -0
  536. package/dist/startup-context-Ck87weqi.js +312 -0
  537. package/dist/status-48dYtpoR.js +397 -0
  538. package/dist/status-CE7dpR6j.js +3 -0
  539. package/dist/status-CJoIf5CR.js +209 -0
  540. package/dist/status-D1Biv4_a.js +2 -0
  541. package/dist/status-DGJGZyGO.js +2 -0
  542. package/dist/status-all-2bHb-vgG.js +498 -0
  543. package/dist/status-dw3o_qPe.js +190 -0
  544. package/dist/status-json-Bxacm8Qn.js +14 -0
  545. package/dist/status-json-command-DF2B2_V3.js +84 -0
  546. package/dist/status-runtime-shared-BA95v5iK.js +257 -0
  547. package/dist/status-subagents.runtime-DPc9mqPe.js +18 -0
  548. package/dist/status-subagents.runtime.js +1 -1
  549. package/dist/status-text-BP3KeCtU.js +237 -0
  550. package/dist/status.gateway-connection.runtime-CrsJrehG.js +2 -0
  551. package/dist/status.gateway-connection.runtime.js +1 -1
  552. package/dist/status.gather-BCK6tC0P.js +292 -0
  553. package/dist/status.gather-DW_bdDUs.js +2 -0
  554. package/dist/status.runtime-DWTaiT7K.js +2 -0
  555. package/dist/status.runtime.js +1 -1
  556. package/dist/status.scan-CD7orpWm.js +65 -0
  557. package/dist/status.scan-overview-BnY_9pPZ.js +379 -0
  558. package/dist/status.scan.fast-json-CLKyp_FZ.js +132 -0
  559. package/dist/status.scan.fast-json-D9-5RUQW.js +2 -0
  560. package/dist/status.summary-3kMOvohJ.js +2 -0
  561. package/dist/status.summary-CBGC6YG3.js +214 -0
  562. package/dist/subagent-announce-delivery-DgJVgXOr.js +726 -0
  563. package/dist/subagent-announce-output-CP427cvY.js +364 -0
  564. package/dist/subagent-announce-zjeNVFwd.js +351 -0
  565. package/dist/subagent-control-mN0oIWjm.js +506 -0
  566. package/dist/subagent-followup.runtime-BPQyuQoe.js +68 -0
  567. package/dist/subagent-followup.runtime.js +1 -1
  568. package/dist/subagent-orphan-recovery-BBkBb0Nh.js +305 -0
  569. package/dist/subagent-registry-BZkG7d3G.js +3 -0
  570. package/dist/subagent-registry-C2eAtERw.js +1753 -0
  571. package/dist/subagent-registry.runtime.js +1 -1
  572. package/dist/subagent-spawn-BHDR5zLE.js +1005 -0
  573. package/dist/system-cli-DapxyBIC.js +59 -0
  574. package/dist/targets-gkyN5pq8.js +67 -0
  575. package/dist/task-executor-McS2BJQg.js +360 -0
  576. package/dist/task-owner-access-Cp_o7LQs.js +74 -0
  577. package/dist/task-registry-Bc22zUFJ.js +2366 -0
  578. package/dist/task-registry-delivery-runtime-FGvxeA51.js +3 -0
  579. package/dist/task-registry-delivery-runtime-kjDlxgnl.js +2 -0
  580. package/dist/task-registry.maintenance-CdawPjmw.js +416 -0
  581. package/dist/task-registry.maintenance-D_uzodyG.js +2 -0
  582. package/dist/telegram/token.js +1 -1
  583. package/dist/testing-A7m9v7qS.js +575 -0
  584. package/dist/text-report-CSDchBUA.js +587 -0
  585. package/dist/tool-resolution-CMwLa1lc.js +90 -0
  586. package/dist/tools-effective-inventory-CXM5GV6s.js +152 -0
  587. package/dist/tools-invoke-http-qItYoiC6.js +206 -0
  588. package/dist/trash-B00EIdks.js +24 -0
  589. package/dist/tui-cli-BbHQkFbp.js +4595 -0
  590. package/dist/update-cli-hHkP1wu2.js +1759 -0
  591. package/dist/upgrade-Tmp-2Squ.js +1226 -0
  592. package/dist/video-generation-task-status-BWWBuC1d.js +163 -0
  593. package/dist/wait-for-idle-before-flush-CJcOqYwe.js +5986 -0
  594. package/dist/wizard-models-CsM6dV5g.js +334 -0
  595. package/package.json +1 -1
  596. package/dist/abort-Cngo_sE6.js +0 -201
  597. package/dist/abort.runtime-l03tKy6q.js +0 -2
  598. package/dist/accounts-D5dnjCYz.js +0 -104
  599. package/dist/accounts-DJVB8Dzg.js +0 -107
  600. package/dist/accounts-I2j8KUfU.js +0 -2
  601. package/dist/acp-cli-CVXcm2Uf.js +0 -2217
  602. package/dist/acp-spawn-BF1zb7_s.js +0 -2
  603. package/dist/acp-spawn-CCcWxuoD.js +0 -1093
  604. package/dist/acp-stateful-target-driver-CLTnT3_3.js +0 -89
  605. package/dist/action-agents-hVUqBNdo.js +0 -67
  606. package/dist/action-focus-8xIhNSsO.js +0 -132
  607. package/dist/action-help-BGvrhiaU.js +0 -7
  608. package/dist/action-info-DOI0dCt_.js +0 -101
  609. package/dist/action-kill-KvzLsRue.js +0 -33
  610. package/dist/action-list-L4kdOLkV.js +0 -21
  611. package/dist/action-log-xyFooSSU.js +0 -30
  612. package/dist/action-send-za_v6IfP.js +0 -39
  613. package/dist/action-spawn-CqMlG6rs.js +0 -47
  614. package/dist/action-unfocus-4viCl85L.js +0 -29
  615. package/dist/actions.runtime-BQnRcY0z.js +0 -18
  616. package/dist/actions.runtime-DAsDM3FC.js +0 -5
  617. package/dist/agent-BAcZ_9MS.js +0 -2
  618. package/dist/agent-command-CThfmSfK.js +0 -874
  619. package/dist/agent-harness-runtime-DQWpmoRH.js +0 -144
  620. package/dist/agent-runner-utils-BgI3qeCs.js +0 -239
  621. package/dist/agent-runner.runtime-C-6mqnGR.js +0 -3455
  622. package/dist/agent-runtime-DIWgC8MC.js +0 -18
  623. package/dist/agents-BAWL0dPv.js +0 -5
  624. package/dist/agents-CtrLQf-J.js +0 -954
  625. package/dist/aliases-Cd330u5w.js +0 -2
  626. package/dist/aliases-D9gd4KZs.js +0 -96
  627. package/dist/api-6P3OWTH5.js +0 -5
  628. package/dist/api-DpXopE7P.js +0 -3
  629. package/dist/api-oOooMZhP.js +0 -139
  630. package/dist/approval-gateway-resolver-BjqCdv8k.js +0 -29
  631. package/dist/approval-gateway-runtime-vc_h56PW.js +0 -2
  632. package/dist/approval-handler-runtime-CyvEyKDy.js +0 -439
  633. package/dist/approval-native-runtime-BIKGBkwL.js +0 -729
  634. package/dist/attempt-execution.runtime-CCvoOmmC.js +0 -509
  635. package/dist/attempt.prompt-helpers-BQ-1KYxC.js +0 -221
  636. package/dist/attempt.tool-run-context-Cxbblhky.js +0 -933
  637. package/dist/audit-Bo8UTCyc.js +0 -939
  638. package/dist/audit.runtime-CPxgYz9W.js +0 -7
  639. package/dist/auth-4FzYl8sz.js +0 -550
  640. package/dist/auth-Bj3QjORN.js +0 -2
  641. package/dist/auth-order-BVHFh3Fe.js +0 -139
  642. package/dist/auth-order-CiBq-B8C.js +0 -2
  643. package/dist/bash-tools-Csgatugk.js +0 -3
  644. package/dist/bash-tools-D5Qgrlkj.js +0 -2824
  645. package/dist/binding-routing-Cr2BJdII.js +0 -85
  646. package/dist/binding-targets-Du0vm2-F.js +0 -121
  647. package/dist/bridge-server-Cpvt4nNc.js +0 -113
  648. package/dist/browser-control-auth-DsUqVw9Y.js +0 -2
  649. package/dist/browser-node-runtime-CuGRBA2N.js +0 -12
  650. package/dist/browser-profiles-FqYFsUPt.js +0 -2
  651. package/dist/browser-runtime-C_MYMBwN.js +0 -387
  652. package/dist/browser-setup-tools-75eBLdGG.js +0 -13
  653. package/dist/build--GUIQMqV.js +0 -550
  654. package/dist/call-Cwg6CEat.js +0 -331
  655. package/dist/call-hnk56UiT.js +0 -3
  656. package/dist/call.runtime-C8KSEM5A.js +0 -2
  657. package/dist/capability-cli-ly3sH38y.js +0 -1401
  658. package/dist/catchup-DNRHXY1y.js +0 -300
  659. package/dist/channel-3WhZIXYU.js +0 -1100
  660. package/dist/channel-Ad3bImu-.js +0 -226
  661. package/dist/channel-BNY1gK9J.js +0 -1320
  662. package/dist/channel-BetO9AUJ.js +0 -595
  663. package/dist/channel-C2IaZUYL.js +0 -350
  664. package/dist/channel-C8jmE7N2.js +0 -297
  665. package/dist/channel-CDElDIH4.js +0 -453
  666. package/dist/channel-DHZhJnt4.js +0 -1174
  667. package/dist/channel-DJbljYq-.js +0 -840
  668. package/dist/channel-Dd3R7L4E.js +0 -1802
  669. package/dist/channel-Dpdizjhh.js +0 -491
  670. package/dist/channel-core-ByqezGK-.js +0 -5
  671. package/dist/channel-inbound-CfC-5Hqh.js +0 -31
  672. package/dist/channel-plugin-runtime-B-FoOCHe.js +0 -771
  673. package/dist/channel-runtime-CTz-Npx2.js +0 -425
  674. package/dist/channel.runtime-BO17VYXq.js +0 -430
  675. package/dist/channel.runtime-BOIxt4yC.js +0 -4
  676. package/dist/channel.runtime-BhxyxvkT.js +0 -576
  677. package/dist/channel.runtime-DTqynpub.js +0 -42398
  678. package/dist/channel.runtime-DU698Mtp.js +0 -2364
  679. package/dist/channel.runtime-Dfq_FjtT.js +0 -89
  680. package/dist/channel.setup-Cklnh2gh.js +0 -10
  681. package/dist/channel2.runtime-ClW7cdHK.js +0 -109
  682. package/dist/channels-CP6Kp445.js +0 -733
  683. package/dist/channels-cli-DaJwTe-V.js +0 -268
  684. package/dist/chat-ov9pIV1w.js +0 -2830
  685. package/dist/clawbot-cli-BRy4Hm77.js +0 -9
  686. package/dist/cli-BPwABYWL.js +0 -2
  687. package/dist/cli-BsSw7UYX.js +0 -72
  688. package/dist/cli-DM1LzJBx.js +0 -219
  689. package/dist/cli-DPAPYa_s.js +0 -2
  690. package/dist/cli-runner-END8ND2M.js +0 -286
  691. package/dist/cli-runner.runtime-C69OSvpN.js +0 -4
  692. package/dist/cli-runner.runtime-DZi9acPF.js +0 -3
  693. package/dist/cli.runtime-CAl2BRM8.js +0 -1261
  694. package/dist/client-BtyYQE4I.js +0 -713
  695. package/dist/client-DwOhUvZq.js +0 -138
  696. package/dist/command-auth-BC4dzkDE.js +0 -76
  697. package/dist/command-config-resolution-Bu94VaHH.js +0 -2
  698. package/dist/command-config-resolution-CDIZsyXz.js +0 -23
  699. package/dist/command-config-resolution.runtime-D6U--833.js +0 -2
  700. package/dist/command-registry-CP6Flbyr.js +0 -4
  701. package/dist/command-registry-DyA5n5Y2.js +0 -9
  702. package/dist/command-registry-core-D6wfuVBH.js +0 -106
  703. package/dist/command-secret-gateway-U8oc85O3.js +0 -528
  704. package/dist/command-status.runtime-BlV8RkuN.js +0 -87
  705. package/dist/commands-acp-DogyhRxV.js +0 -77
  706. package/dist/commands-compact.runtime-C9CwEQ9d.js +0 -10
  707. package/dist/commands-handlers.runtime-BKVTB3af.js +0 -4599
  708. package/dist/commands-status-Ck7yAveR.js +0 -16
  709. package/dist/commands-status.runtime-C64rfIgv.js +0 -3
  710. package/dist/commands-subagents-control.runtime-BQ9IJ-PN.js +0 -2
  711. package/dist/commands-subagents-control.runtime-DzuYqXYM.js +0 -3
  712. package/dist/commands-system-prompt-DrO5Ktab.js +0 -158
  713. package/dist/commands-system-prompt-OZnWRUU4.js +0 -2
  714. package/dist/commands.runtime-Cz5m7UHd.js +0 -167
  715. package/dist/compact-Bm6Ue8PM.js +0 -1118
  716. package/dist/compact.runtime-DUnPpPlz.js +0 -12
  717. package/dist/completion-cli-CQV8Edld.js +0 -328
  718. package/dist/config-CvQPjE0Q.js +0 -252
  719. package/dist/config-cli-hPAERXVD.js +0 -1078
  720. package/dist/configure-CNDv9ji5.js +0 -1252
  721. package/dist/configure-Dw-YeOYz.js +0 -2
  722. package/dist/connect-options-5yQEkag7.js +0 -699
  723. package/dist/control-auth-BZ3jwW_b.js +0 -125
  724. package/dist/control-service-CVq5rWGF.js +0 -156
  725. package/dist/conversation-id-B7oXZBrx.js +0 -235
  726. package/dist/conversation-id-DEFcpkdn.js +0 -38
  727. package/dist/conversation-runtime-Di95kTti.js +0 -31
  728. package/dist/core-BbuI1nb2.js +0 -275
  729. package/dist/cron-cli-UIR4I5Eo.js +0 -713
  730. package/dist/daemon-cli-BqTT84vc.js +0 -12
  731. package/dist/dashboard-DORB5lWl.js +0 -81
  732. package/dist/dashboard-iCpchE4h.js +0 -2
  733. package/dist/delegate-DKyLT2Oh.js +0 -64
  734. package/dist/detached-task-runtime-B3Y6ddy3.js +0 -73
  735. package/dist/devices-cli-Cyiv4_7A.js +0 -498
  736. package/dist/diagnostics-BMdHyN8V.js +0 -154
  737. package/dist/direct-dm-CgMzHsLT.js +0 -64
  738. package/dist/dispatch-DIRZA2cy.js +0 -1131
  739. package/dist/dispatch-acp-1zk6S0I_.js +0 -981
  740. package/dist/dispatch-acp-manager.runtime-C7yW8oCJ.js +0 -3
  741. package/dist/dispatch-acp.runtime-CTRthZvU.js +0 -19
  742. package/dist/doctor-device-pairing-CNyJpHYP.js +0 -307
  743. package/dist/doctor-gateway-daemon-flow-BeOcm1lk.js +0 -250
  744. package/dist/doctor-gateway-health-DHGy54St.js +0 -63
  745. package/dist/doctor-health-D8Zx1Kxy.js +0 -59
  746. package/dist/doctor-health-contributions-fMT-eUkx.js +0 -493
  747. package/dist/doctor-prompter-Cr1NyTHN.js +0 -56
  748. package/dist/doctor-workspace-status-af2Bd95y.js +0 -75
  749. package/dist/dreaming-BNV8bPzi.js +0 -1582
  750. package/dist/dreaming-narrative-DrIvIgwX.js +0 -596
  751. package/dist/embedded-gateway-stub.runtime-CB0tG8-G.js +0 -9
  752. package/dist/exec-approvals-cli-1ipccPsH.js +0 -498
  753. package/dist/fallbacks-BZsnJYQ9.js +0 -2
  754. package/dist/fallbacks-DEDU9fM9.js +0 -31
  755. package/dist/fallbacks-shared-Bi9LfHSP.js +0 -111
  756. package/dist/gateway-cli-DhMqYIPl.js +0 -1283
  757. package/dist/gateway-rpc-DPTkm_sv.js +0 -14
  758. package/dist/gateway-rpc.runtime-BVlT2xPp.js +0 -23
  759. package/dist/gateway-runtime-DNBHtXEc.js +0 -15
  760. package/dist/gateway-status-C-vkewIw.js +0 -584
  761. package/dist/gateway-tRBsGvCm.js +0 -115
  762. package/dist/genesis-tools-5NSdlOTl.js +0 -9166
  763. package/dist/genesis-tools.runtime-AZkoDSZn.js +0 -2
  764. package/dist/get-reply-CyMVoBga.js +0 -3897
  765. package/dist/get-reply-from-config.runtime-DWfXY6kp.js +0 -2
  766. package/dist/graph-users-CeE20CJr.js +0 -1337
  767. package/dist/health-C-yFJe9m.js +0 -469
  768. package/dist/health-D5WYplmn.js +0 -3
  769. package/dist/health-route-C_njQhJj.js +0 -41
  770. package/dist/health-route-otTelRS8.js +0 -2
  771. package/dist/heartbeat-runner-9IsW8Xo7.js +0 -1292
  772. package/dist/heartbeat-runner-CUhmhWre.js +0 -5
  773. package/dist/heartbeat-runner.runtime-D-jqThKI.js +0 -4
  774. package/dist/hooks-cli-g0yKwqEG.js +0 -433
  775. package/dist/image-fallbacks-BZBfLjnm.js +0 -2
  776. package/dist/image-fallbacks-DauDOGEM.js +0 -31
  777. package/dist/inbound-reply-dispatch-2dA1_zqi.js +0 -73
  778. package/dist/infra-runtime-B7wP6gFI.js +0 -39
  779. package/dist/init-CbE2VqbJ.js +0 -59
  780. package/dist/library-BPRe1zEN.js +0 -45
  781. package/dist/lifecycle-29UzYVEZ.js +0 -229
  782. package/dist/lifecycle-BCpBPa5D.js +0 -571
  783. package/dist/lifecycle.runtime-3cCF_4AU.js +0 -2
  784. package/dist/list-B9lCYvDl.js +0 -1212
  785. package/dist/list-CV1Woixl.js +0 -2
  786. package/dist/list-D0yDvc4W.js +0 -2
  787. package/dist/list-DKY6QJ2V.js +0 -131
  788. package/dist/list.probe-BXvTngHv.js +0 -419
  789. package/dist/llm-slug-generator-DFEyGish.js +0 -79
  790. package/dist/load-config-Cw7kShkf.js +0 -35
  791. package/dist/local-dispatch.runtime-C8_YEk3p.js +0 -8
  792. package/dist/logs-cli-BrAFUk9w.js +0 -265
  793. package/dist/logs-cli.runtime-CUmu5b1C.js +0 -2
  794. package/dist/main-session-restart-recovery-DsRbypTW.js +0 -206
  795. package/dist/managed-image-attachments-BjaVhVEa.js +0 -2
  796. package/dist/managed-image-attachments-Cqy3EaEE.js +0 -635
  797. package/dist/manager-Cro57kFq.js +0 -2057
  798. package/dist/manager-DzFdCc4J.js +0 -2
  799. package/dist/markdown-to-line-BZuI0r-M.js +0 -790
  800. package/dist/mcp-cli-0WTvaoIg.js +0 -725
  801. package/dist/mcp-http-CeMRRWUu.js +0 -529
  802. package/dist/memory-core-host-runtime-cli-bOlGS396.js +0 -9
  803. package/dist/message-C7RIxkrZ.js +0 -232
  804. package/dist/message-action-runner-a01PfbVY.js +0 -1407
  805. package/dist/message-action-runner-bvmUIIVf.js +0 -2
  806. package/dist/message-actions-DjS0VVCy.js +0 -143
  807. package/dist/message.gateway.runtime-nt-TPAqA.js +0 -2
  808. package/dist/models-auth-status-BS_caq_x.js +0 -217
  809. package/dist/models-cli-DUrC7-c6.js +0 -271
  810. package/dist/monitor-BZNZ1ygG.js +0 -2
  811. package/dist/monitor-BlZsUodW.js +0 -788
  812. package/dist/monitor-CO_t3tSA.js +0 -1237
  813. package/dist/monitor-CexHU09e.js +0 -1661
  814. package/dist/monitor-DBFGvWm8.js +0 -671
  815. package/dist/monitor-auth-WUJo8zX5.js +0 -207
  816. package/dist/monitor-fK0HzOeR.js +0 -1459
  817. package/dist/monitor-processing-v0Oqdm83.js +0 -1974
  818. package/dist/monitor.runtime-B4COiD9M.js +0 -2
  819. package/dist/monitor.webhook-BrXwPWIb.js +0 -180
  820. package/dist/msteams-C0lsusC7.js +0 -35
  821. package/dist/native-hook-relay-DxLDo0kf.js +0 -519
  822. package/dist/nextcloud-talk-CDxdDhEa.js +0 -17
  823. package/dist/node-cli-BNQi7BfE.js +0 -2276
  824. package/dist/nodes-cli-Dfsc0scS.js +0 -1046
  825. package/dist/nodes-utils-CetwNv8w.js +0 -84
  826. package/dist/nodes.helpers-B4Yy3f8X.js +0 -34
  827. package/dist/notify-Bg4ukXOy.js +0 -315
  828. package/dist/onboard-BlzYtu39.js +0 -70
  829. package/dist/onboard-DZqeGCuM.js +0 -2
  830. package/dist/onboard-helpers-CFVEw4kg.js +0 -204
  831. package/dist/onboard-helpers-R0vTUoOE.js +0 -6
  832. package/dist/onboard-interactive-CTiy9p3b.js +0 -24
  833. package/dist/onboard-non-interactive-SC-UFDrb.js +0 -635
  834. package/dist/onboard-remote-0UXttO3s.js +0 -2
  835. package/dist/onboard-remote-BmUiJKba.js +0 -193
  836. package/dist/onboard-skills-855xT260.js +0 -2
  837. package/dist/onboard-skills-CF2ndciI.js +0 -134
  838. package/dist/openai-http-CE7y7YiI.js +0 -500
  839. package/dist/openresponses-http-DK86gsJO.js +0 -1128
  840. package/dist/operator-approvals-client-gp0A73Qi.js +0 -68
  841. package/dist/outbound.runtime-DP8BPmuN.js +0 -2
  842. package/dist/pair-command-approve-BtOQZGwa.js +0 -44
  843. package/dist/persistent-bindings.lifecycle-B0AshYYA.js +0 -2
  844. package/dist/persistent-bindings.lifecycle-DvTYe8mB.js +0 -85
  845. package/dist/pi-embedded-Be4Onpze.js +0 -4
  846. package/dist/pi-embedded-CGy7Dtnw.js +0 -2905
  847. package/dist/pi-embedded.runtime-BWPKSg0B.js +0 -4
  848. package/dist/pi-tool-definition-adapter-Jf9zETiY.js +0 -229
  849. package/dist/pi-tools-BQA19P3-.js +0 -1057
  850. package/dist/pi-tools.before-tool-call-Cz_axNf5.js +0 -2
  851. package/dist/pi-tools.before-tool-call-DCG_FnG8.js +0 -433
  852. package/dist/plugin-PXgxA053.js +0 -12195
  853. package/dist/plugin-enabled-sOFPFfw1.js +0 -140
  854. package/dist/plugin-registration-OrraXjhN.js +0 -23
  855. package/dist/plugin-service-CD-TC2TU.js +0 -2893
  856. package/dist/policy-Bu7soiqW.js +0 -328
  857. package/dist/prepare.runtime-CVPtWq-3.js +0 -815
  858. package/dist/probe--ur8kCb3.js +0 -241
  859. package/dist/probe-Afcq8e2r.js +0 -2
  860. package/dist/probe-B1Dp2K5f.js +0 -74
  861. package/dist/probe-CQxc5e0e.js +0 -1443
  862. package/dist/probe-D7acsevr.js +0 -45
  863. package/dist/probe-DC5E8AK5.js +0 -2
  864. package/dist/probe-HDLJLw4c.js +0 -2205
  865. package/dist/program-CmLQupJ3.js +0 -111
  866. package/dist/prompt-select-styled-DWw74syc.js +0 -20
  867. package/dist/protocol-D2Tvt0kQ.js +0 -2479
  868. package/dist/provider-dispatcher-CLjWHk-J.js +0 -2
  869. package/dist/provider-dispatcher-Cmgqznex.js +0 -22
  870. package/dist/qr-cli-BpSufxl3.js +0 -349
  871. package/dist/qr-cli-CNlU9tQo.js +0 -2
  872. package/dist/reaction-runtime-api-CgscWHaw.js +0 -116
  873. package/dist/reactions-CUuxlTLk.js +0 -998
  874. package/dist/register-service-commands-CVw_0FOU.js +0 -71
  875. package/dist/register.agent-D83zxSDT.js +0 -248
  876. package/dist/register.configure-CHoOiqzO.js +0 -15
  877. package/dist/register.maintenance-CV8Y0-GO.js +0 -363
  878. package/dist/register.message-B0eHsfLQ.js +0 -329
  879. package/dist/register.onboard-CbIO5sFl.js +0 -88
  880. package/dist/register.runtime-DDACHKw5.js +0 -81
  881. package/dist/register.setup-BrDiZ87w.js +0 -150
  882. package/dist/register.status-health-sessions-3PB3gA8Z.js +0 -1215
  883. package/dist/register.subclis-CaXmqTjH.js +0 -3
  884. package/dist/register.subclis-DXHaFVAj.js +0 -29
  885. package/dist/register.subclis-core-oPBkaD2j.js +0 -249
  886. package/dist/reply-dispatch-runtime-s8iIcsY4.js +0 -13
  887. package/dist/reply-runtime-CdbXuP0k.js +0 -11
  888. package/dist/reply.runtime-B8O4Za3t.js +0 -2
  889. package/dist/restart-health-C8OVhvQ6.js +0 -2
  890. package/dist/restart-health-DdG71XEk.js +0 -202
  891. package/dist/root-help-Dat5PidP.js +0 -44
  892. package/dist/routes--OomJzMJ.js +0 -2
  893. package/dist/routes-C9ddA05X.js +0 -3341
  894. package/dist/rpc-hYySaHuW.js +0 -61
  895. package/dist/rpc.runtime-xFzxQvGM.js +0 -21
  896. package/dist/run-delivery.runtime-pD6AAEFj.js +0 -530
  897. package/dist/run-embedded.runtime-BGCrB5dE.js +0 -4
  898. package/dist/run-execution-cli.runtime-Cm0qb1Jx.js +0 -4
  899. package/dist/run-executor.runtime-DmGdXgNE.js +0 -277
  900. package/dist/run-main-BhKIYDDS.js +0 -567
  901. package/dist/run-subagent-registry.runtime-BrCnLsaJ.js +0 -2
  902. package/dist/run-wait-V95b_owe.js +0 -135
  903. package/dist/runtime-BPcw5wKu.js +0 -973
  904. package/dist/runtime-CVtzoEXz.js +0 -9
  905. package/dist/runtime-api-C7SvtCrz.js +0 -4
  906. package/dist/runtime-api-D7kMb4r-.js +0 -9
  907. package/dist/runtime-api-GmwL5agC.js +0 -9
  908. package/dist/runtime-api-NZdHXq65.js +0 -14
  909. package/dist/runtime-embedded-pi.runtime-CiFf7LLh.js +0 -2
  910. package/dist/runtime-internal-9DTzq40y.js +0 -2
  911. package/dist/runtime-options-BABByM27.js +0 -275
  912. package/dist/runtime-schema-CQFcWgw7.js +0 -28588
  913. package/dist/scan-C-7SLtpq.js +0 -523
  914. package/dist/scan-DW5OMHlc.js +0 -2
  915. package/dist/secrets-cli-BWgJDRGu.js +0 -2101
  916. package/dist/security-cli-CVScUBAh.js +0 -486
  917. package/dist/selection-BJhGK0Gg.js +0 -2
  918. package/dist/selection-C8GY4Sin.js +0 -7764
  919. package/dist/send-CH0zRgEY.js +0 -102
  920. package/dist/send-gStK80j4.js +0 -156
  921. package/dist/send.runtime-D5GAmGpy.js +0 -2
  922. package/dist/server-BamjooS9.js +0 -77
  923. package/dist/server-DOlUxe29.js +0 -13
  924. package/dist/server-context-BHGn60Nv.js +0 -2
  925. package/dist/server-context-D0DCL0Yr.js +0 -847
  926. package/dist/server-node-events-CKfJMKY6.js +0 -481
  927. package/dist/server-plugin-bootstrap-CgdqnkvH.js +0 -13176
  928. package/dist/server-plugin-bootstrap-Dqa8MSb3.js +0 -2
  929. package/dist/server-restart-sentinel-D5NKTQlr.js +0 -697
  930. package/dist/server.impl-CaBpcCte.js +0 -12894
  931. package/dist/session-kill-http-Dkyu6aeK.js +0 -110
  932. package/dist/session-reset-service-bUkkZbtS.js +0 -497
  933. package/dist/session-route-osDI35ex.js +0 -93
  934. package/dist/session-status.runtime-XUwfwKYy.js +0 -2
  935. package/dist/session-subagent-reactivation.runtime-DIrxFxhQ.js +0 -2
  936. package/dist/session-tab-registry-DMcC2sO-.js +0 -581
  937. package/dist/session-visibility-BE4lf4vj.js +0 -147
  938. package/dist/sessions-helpers-qYgG99le.js +0 -305
  939. package/dist/sessions-history-http-B6Tw9U6o.js +0 -383
  940. package/dist/sessions-patch-C2VfpT6N.js +0 -309
  941. package/dist/sessions-resolve-Dgj16ung.js +0 -174
  942. package/dist/sessions.runtime-De075L9O.js +0 -2
  943. package/dist/setup-IZ8-o496.js +0 -636
  944. package/dist/setup-api-Brg9D0Et.js +0 -29
  945. package/dist/setup-core-DBNJOXUe.js +0 -176
  946. package/dist/setup-core-YMlDym-t.js +0 -171
  947. package/dist/setup-surface-B8zw_Iry.js +0 -286
  948. package/dist/setup-surface-DiER1ybG2.js +0 -403
  949. package/dist/setup-surface-ZQJE1d97.js +0 -219
  950. package/dist/setup.finalize-DV7-ttFc.js +0 -547
  951. package/dist/setup.gateway-config-CeiELioQ.js +0 -250
  952. package/dist/shared-BddlhgtM.js +0 -198
  953. package/dist/shared-C9Fg93Nk.js +0 -76
  954. package/dist/shared-rY0Q3SUO.js +0 -121
  955. package/dist/slash-state-BXsMm6Ug.js +0 -1911
  956. package/dist/src-2iJPePTa.js +0 -3974
  957. package/dist/startup-context-L7eFlMGe.js +0 -312
  958. package/dist/status-2mHKLi_8.js +0 -2
  959. package/dist/status-4QVSRSC2.js +0 -3
  960. package/dist/status-Bpg8pFBH.js +0 -2
  961. package/dist/status-CYWc74qO.js +0 -397
  962. package/dist/status-EKvbpCYq.js +0 -190
  963. package/dist/status-all-vTJtEeTs.js +0 -498
  964. package/dist/status-json-82GOaBg2.js +0 -14
  965. package/dist/status-json-command-DE1OsrKi.js +0 -84
  966. package/dist/status-okdvu7xW.js +0 -209
  967. package/dist/status-runtime-shared--i8Snuyb.js +0 -257
  968. package/dist/status-subagents.runtime-D9r3_cd8.js +0 -18
  969. package/dist/status-text-Csq9CBHh.js +0 -237
  970. package/dist/status.gateway-connection.runtime-D4Z7cUpS.js +0 -2
  971. package/dist/status.gather-DjPsPYjd.js +0 -2
  972. package/dist/status.gather-GYO4n_GF.js +0 -292
  973. package/dist/status.runtime-BnkekTYc.js +0 -2
  974. package/dist/status.scan-CGZs2gNK.js +0 -65
  975. package/dist/status.scan-overview-CvMmc4_9.js +0 -379
  976. package/dist/status.scan.fast-json-BuLGkMEu.js +0 -132
  977. package/dist/status.scan.fast-json-DbPM0LbX.js +0 -2
  978. package/dist/status.summary-DNjIEj7M.js +0 -214
  979. package/dist/status.summary-thyeq75l.js +0 -2
  980. package/dist/subagent-announce-BXNGQkca.js +0 -351
  981. package/dist/subagent-announce-delivery-CssdaIK0.js +0 -726
  982. package/dist/subagent-announce-output-DK4zF_4-.js +0 -364
  983. package/dist/subagent-control-8V6C3iHm.js +0 -506
  984. package/dist/subagent-followup.runtime-DiBrlbMB.js +0 -68
  985. package/dist/subagent-orphan-recovery-DF-RlZbs.js +0 -305
  986. package/dist/subagent-registry-B7roWOkp.js +0 -1753
  987. package/dist/subagent-registry-C0Vew-3L.js +0 -3
  988. package/dist/subagent-spawn-DO4jFMOF.js +0 -1005
  989. package/dist/system-cli-CxuvHMmE.js +0 -59
  990. package/dist/targets-BrIxxqDm.js +0 -67
  991. package/dist/task-executor-B3GpI_R_.js +0 -360
  992. package/dist/task-owner-access-oQnQP_b3.js +0 -74
  993. package/dist/task-registry-EHbmFqsi.js +0 -2366
  994. package/dist/task-registry-delivery-runtime-DkQoAcL3.js +0 -3
  995. package/dist/task-registry-delivery-runtime-XqEQlx86.js +0 -2
  996. package/dist/task-registry.maintenance-BpI-YUOA.js +0 -2
  997. package/dist/task-registry.maintenance-D6WzGM5R.js +0 -416
  998. package/dist/testing-CY7YdvFP.js +0 -575
  999. package/dist/text-report-Cu-Drg33.js +0 -587
  1000. package/dist/tool-resolution-BIa_L_eS.js +0 -90
  1001. package/dist/tools-effective-inventory-DdF_gXu6.js +0 -152
  1002. package/dist/tools-invoke-http-Dhrho-XH.js +0 -206
  1003. package/dist/trash-DDT5xMIb.js +0 -24
  1004. package/dist/tui-cli-DqAyUsXV.js +0 -4595
  1005. package/dist/update-cli-DzUvmsG8.js +0 -1759
  1006. package/dist/upgrade-CXPGf4xq.js +0 -1226
  1007. package/dist/video-generation-task-status-Ccbv5_ls.js +0 -163
  1008. package/dist/wait-for-idle-before-flush-_1jKR3ID.js +0 -5986
  1009. package/dist/wizard-models-CQwA3L3M.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-Z-tPC4mW.js";
16
+ import { t as DEFAULT_GATEWAY_HTTP_TOOL_DENY } from "./dangerous-tools-BDX3RLrZ.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-CK1UP6ML.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-BKFHGH3i.js");
283
+ return await channelPluginsModulePromise;
284
+ }
285
+ async function loadAuditNonDeepModule() {
286
+ auditNonDeepModulePromise ??= import("./audit.nondeep.runtime-CkofW_mp.js");
287
+ return await auditNonDeepModulePromise;
288
+ }
289
+ async function loadAuditChannelModule() {
290
+ auditChannelModulePromise ??= import("./audit-channel.collect.runtime-BLRcA2yd.js");
291
+ return await auditChannelModulePromise;
292
+ }
293
+ async function loadPluginRegistryLoaderModule() {
294
+ pluginRegistryLoaderModulePromise ??= import("./runtime-registry-loader-SjgVlCN_.js");
295
+ return await pluginRegistryLoaderModulePromise;
296
+ }
297
+ async function loadPluginMetadataRegistryLoaderModule() {
298
+ pluginMetadataRegistryLoaderModulePromise ??= import("./metadata-registry-loader-UarIvXUC.js");
299
+ return await pluginMetadataRegistryLoaderModulePromise;
300
+ }
301
+ async function loadPluginAutoEnableModule() {
302
+ pluginAutoEnableModulePromise ??= import("./plugin-auto-enable-Dpvl0iUT.js");
303
+ return await pluginAutoEnableModulePromise;
304
+ }
305
+ async function loadChannelPluginIdsModule() {
306
+ channelPluginIdsModulePromise ??= import("./channel-plugin-ids-PsmfZyzR.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-85RWmQAH.js"),
316
+ import("./probe-auth-DWFOln5q.js"),
317
+ import("./probe-6HwDlk5s.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 };