@pixelzx/genesis 2026.5.5-2 → 2026.5.5-3

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 (1017) hide show
  1. package/CHANGELOG.md +1 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-Yw60gQ-C.js +201 -0
  4. package/dist/abort.runtime-DYQuut_O.js +2 -0
  5. package/dist/abort.runtime.js +1 -1
  6. package/dist/accounts-BSCHGPHp.js +107 -0
  7. package/dist/accounts-Bb0FqxV2.js +104 -0
  8. package/dist/accounts-BjGgx8lz.js +2 -0
  9. package/dist/acp-cli-emMnOaiO.js +2193 -0
  10. package/dist/acp-spawn-BmyUZuJX.js +1093 -0
  11. package/dist/acp-spawn-DPF5zmnN.js +2 -0
  12. package/dist/acp-stateful-target-driver-CJ4JyIHf.js +89 -0
  13. package/dist/action-agents-D1tXt8Kj.js +67 -0
  14. package/dist/action-focus-Bk6AJsNH.js +132 -0
  15. package/dist/action-help-4nFSAuVo.js +7 -0
  16. package/dist/action-info-D-byoefn.js +101 -0
  17. package/dist/action-kill-Bo-NwBVR.js +33 -0
  18. package/dist/action-list-lAa4rlzN.js +21 -0
  19. package/dist/action-log-BasoUC3L.js +30 -0
  20. package/dist/action-send-DwLkiz4x.js +39 -0
  21. package/dist/action-spawn-C70_iR8d.js +47 -0
  22. package/dist/action-unfocus-dUVMx5Fh.js +29 -0
  23. package/dist/actions.runtime-BdSo6rN8.js +18 -0
  24. package/dist/actions.runtime-BvY67XKu.js +5 -0
  25. package/dist/actions.runtime.js +1 -1
  26. package/dist/agent-DDBv3Vgl.js +2 -0
  27. package/dist/agent-command-DC7I_88W.js +874 -0
  28. package/dist/agent-harness-runtime-TA6YH7Ud.js +144 -0
  29. package/dist/agent-runner-utils-CMe-JIDq.js +239 -0
  30. package/dist/agent-runner.runtime-le6AmJRw.js +3455 -0
  31. package/dist/agent-runner.runtime.js +1 -1
  32. package/dist/agent-runtime-CONy4fDD.js +18 -0
  33. package/dist/agents-BlbOM4XW.js +953 -0
  34. package/dist/agents-Byj8CDAP.js +5 -0
  35. package/dist/aliases-C3Ks5x38.js +2 -0
  36. package/dist/aliases-CxBcx9gF.js +96 -0
  37. package/dist/api-CLoj7nYH.js +3 -0
  38. package/dist/api-DZiRkVPk.js +5 -0
  39. package/dist/api-_Y4nIHNo.js +139 -0
  40. package/dist/approval-gateway-resolver-Ba_2kb3B.js +29 -0
  41. package/dist/approval-gateway-runtime-7VMivk0A.js +2 -0
  42. package/dist/approval-handler-runtime-Bh0onoHD.js +439 -0
  43. package/dist/approval-native-runtime-IYFyT8Hf.js +729 -0
  44. package/dist/attempt-execution.runtime-CpL2tsYd.js +509 -0
  45. package/dist/attempt-execution.runtime.js +1 -1
  46. package/dist/attempt.prompt-helpers-Gx9nGKbW.js +221 -0
  47. package/dist/attempt.tool-run-context-BmuljBMs.js +933 -0
  48. package/dist/audit-CsjqOEVE.js +939 -0
  49. package/dist/audit.runtime-BybEaYH4.js +7 -0
  50. package/dist/audit.runtime.js +1 -1
  51. package/dist/auth-BFbLz2gx.js +383 -0
  52. package/dist/auth-DdoNShRm.js +2 -0
  53. package/dist/auth-order-CtO2WQTH.js +2 -0
  54. package/dist/auth-order-zXIiW-Cn.js +96 -0
  55. package/dist/bash-tools-CnDYSbnX.js +2824 -0
  56. package/dist/bash-tools-DiOcKaak.js +3 -0
  57. package/dist/binding-routing-E9Gh_NqO.js +85 -0
  58. package/dist/binding-targets-C5PbBaZ6.js +121 -0
  59. package/dist/bridge-server-DragdaQD.js +113 -0
  60. package/dist/browser-control-auth-D_M31xJ1.js +2 -0
  61. package/dist/browser-node-runtime-Bgu82luB.js +12 -0
  62. package/dist/browser-profiles-C3ffkgOt.js +2 -0
  63. package/dist/browser-runtime-D84IBo4A.js +387 -0
  64. package/dist/browser-setup-tools-VC7rGCyn.js +13 -0
  65. package/dist/build-DeGDX_pJ.js +550 -0
  66. package/dist/build-info.json +3 -3
  67. package/dist/bundled/boot-md/handler.js +2 -2
  68. package/dist/bundled/session-memory/handler.js +1 -1
  69. package/dist/call-CbvF41H8.js +3 -0
  70. package/dist/call-DuDGOVT1.js +331 -0
  71. package/dist/call.runtime-DztWXjMr.js +2 -0
  72. package/dist/call.runtime.js +1 -1
  73. package/dist/capability-cli-DoJLi3eS.js +1401 -0
  74. package/dist/catchup-Dk-5hIwm.js +300 -0
  75. package/dist/channel-BJ9iEC4Y.js +595 -0
  76. package/dist/channel-BdvsbgZE.js +453 -0
  77. package/dist/channel-Bu-7KaIx.js +1802 -0
  78. package/dist/channel-C9vQNMK1.js +350 -0
  79. package/dist/channel-CZoVAZyW.js +491 -0
  80. package/dist/channel-Cr2KTwyo.js +840 -0
  81. package/dist/channel-DCeC6AEQ.js +297 -0
  82. package/dist/channel-DOGp2TfT.js +1320 -0
  83. package/dist/channel-Dfq1lxxI.js +226 -0
  84. package/dist/channel-core-DiltAzdr.js +5 -0
  85. package/dist/channel-hZDaTBpm.js +1100 -0
  86. package/dist/channel-inbound-DvOS-Z1s.js +31 -0
  87. package/dist/channel-plugin-runtime-PFRHQ61T.js +771 -0
  88. package/dist/channel-runtime-BAjxIEfQ.js +425 -0
  89. package/dist/channel-szBwbQZB.js +1174 -0
  90. package/dist/channel.runtime-B1Ry35gt.js +89 -0
  91. package/dist/channel.runtime-BNp6GxaQ.js +34702 -0
  92. package/dist/channel.runtime-BfjvNvbj.js +2364 -0
  93. package/dist/channel.runtime-BlGn4QYV.js +4 -0
  94. package/dist/channel.runtime-D7bv5rJl.js +576 -0
  95. package/dist/channel.runtime-DQ5gSgeW.js +109 -0
  96. package/dist/channel.runtime-IxClQMdT.js +430 -0
  97. package/dist/channel.setup-BsfyGPgV.js +10 -0
  98. package/dist/channels-Dn2VHRmZ.js +733 -0
  99. package/dist/channels-cli-l4xjPvDv.js +268 -0
  100. package/dist/chat-zUeX8mQw.js +2758 -0
  101. package/dist/clawbot-cli-C3BFdHJB.js +9 -0
  102. package/dist/cli/daemon-cli.js +4 -4
  103. package/dist/cli-BTnpFsj1.js +2 -0
  104. package/dist/cli-CAFQ6Cwy.js +72 -0
  105. package/dist/cli-CiqIbwtg.js +219 -0
  106. package/dist/cli-DL1ppK38.js +2 -0
  107. package/dist/cli-runner-DO6lEPJr.js +286 -0
  108. package/dist/cli-runner.runtime-B-Ic4DyC.js +3 -0
  109. package/dist/cli-runner.runtime-C4cAORcg.js +4 -0
  110. package/dist/cli-runner.runtime.js +1 -1
  111. package/dist/cli-startup-metadata.json +2 -2
  112. package/dist/cli.runtime-CYHctHVS.js +1261 -0
  113. package/dist/cli.runtime.js +1 -1
  114. package/dist/client-Bb_miREU.js +138 -0
  115. package/dist/client-CrPccv7a.js +713 -0
  116. package/dist/command-auth-B7P-1IeA.js +76 -0
  117. package/dist/command-config-resolution-BB-SsCob.js +23 -0
  118. package/dist/command-config-resolution-DMKYb0Kh.js +2 -0
  119. package/dist/command-config-resolution.runtime-Coeaa9lz.js +2 -0
  120. package/dist/command-config-resolution.runtime.js +1 -1
  121. package/dist/command-registry-B2JzWHqy.js +9 -0
  122. package/dist/command-registry-CNUpJUp8.js +4 -0
  123. package/dist/command-registry-core-BLap9aka.js +101 -0
  124. package/dist/command-secret-gateway-ChRXthnT.js +528 -0
  125. package/dist/command-status.runtime-D8VWyC3v.js +87 -0
  126. package/dist/command-status.runtime.js +1 -1
  127. package/dist/commands-acp-QLk1cU5f.js +77 -0
  128. package/dist/commands-compact.runtime-BIHG2RSY.js +10 -0
  129. package/dist/commands-compact.runtime.js +1 -1
  130. package/dist/commands-handlers.runtime-DjimbxSJ.js +4597 -0
  131. package/dist/commands-handlers.runtime.js +1 -1
  132. package/dist/commands-status-DiIQSYSt.js +16 -0
  133. package/dist/commands-status.runtime-DBRxICN6.js +3 -0
  134. package/dist/commands-status.runtime.js +1 -1
  135. package/dist/commands-subagents-control.runtime-BmqXiKHu.js +3 -0
  136. package/dist/commands-subagents-control.runtime-CVQSOd8H.js +2 -0
  137. package/dist/commands-subagents-control.runtime.js +1 -1
  138. package/dist/commands-system-prompt-2qwZc3xL.js +158 -0
  139. package/dist/commands-system-prompt-Clnn_Gct.js +2 -0
  140. package/dist/commands.runtime-DAqpiDPr.js +166 -0
  141. package/dist/commands.runtime.js +1 -1
  142. package/dist/compact-DqOkQZYr.js +1118 -0
  143. package/dist/compact.runtime-CC_l29j4.js +12 -0
  144. package/dist/compact.runtime.js +1 -1
  145. package/dist/completion-cli-DZFJPSiF.js +328 -0
  146. package/dist/config-D9XEe0Cd.js +251 -0
  147. package/dist/config-cli-DVDwIjKr.js +1078 -0
  148. package/dist/configure-39oQUHuK.js +1245 -0
  149. package/dist/configure-BGD8tViZ.js +2 -0
  150. package/dist/connect-options-Fpky6zuL.js +699 -0
  151. package/dist/control-auth-BlqH4IVx.js +125 -0
  152. package/dist/control-service-CaqDohiY.js +156 -0
  153. package/dist/conversation-id-BH9GFVB2.js +235 -0
  154. package/dist/conversation-id-UdIegcf4.js +38 -0
  155. package/dist/conversation-runtime-Bao0kIPf.js +31 -0
  156. package/dist/core-DXUh5Xbm.js +275 -0
  157. package/dist/cron-cli-B1mxHnGP.js +713 -0
  158. package/dist/daemon-cli-CaHBNwMy.js +12 -0
  159. package/dist/daemon-install-BBwOxf1q.js +64 -0
  160. package/dist/delegate-7G7R4C-C.js +64 -0
  161. package/dist/detached-task-runtime-BMdSrcuz.js +73 -0
  162. package/dist/devices-cli-DnEQH3R2.js +496 -0
  163. package/dist/diagnostics-C8VwSDtU.js +154 -0
  164. package/dist/direct-dm-BSEkIiOe.js +64 -0
  165. package/dist/dispatch-1gv6It-6.js +1131 -0
  166. package/dist/dispatch-acp-hbhR9aHr.js +981 -0
  167. package/dist/dispatch-acp-manager.runtime-BXQbK1cO.js +3 -0
  168. package/dist/dispatch-acp-manager.runtime.js +1 -1
  169. package/dist/dispatch-acp.runtime-Dhx090J2.js +19 -0
  170. package/dist/dispatch-acp.runtime.js +1 -1
  171. package/dist/doctor-device-pairing-1gf3tk3g.js +307 -0
  172. package/dist/doctor-gateway-daemon-flow-LEnN6pL-.js +250 -0
  173. package/dist/doctor-gateway-health-DwxLkTV4.js +60 -0
  174. package/dist/doctor-gateway-services-BhqUOY_e.js +316 -0
  175. package/dist/doctor-health-CdJkaUYf.js +59 -0
  176. package/dist/doctor-health-contributions-BaTnIzCT.js +486 -0
  177. package/dist/doctor-prompter-BZTb5rOn.js +56 -0
  178. package/dist/doctor-workspace-status-DnBARoPa.js +75 -0
  179. package/dist/dreaming-BAGFdUxh.js +1574 -0
  180. package/dist/dreaming-narrative-XoOfVb0x.js +595 -0
  181. package/dist/embedded-gateway-stub.runtime-xwZ-M7Ei.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-CWVWSMk-.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-BKA5XrxA.js +31 -0
  262. package/dist/fallbacks-QvezaDAr.js +2 -0
  263. package/dist/fallbacks-shared-DS-qTOLR.js +111 -0
  264. package/dist/gateway-C0YHaLXO.js +115 -0
  265. package/dist/gateway-cli-DJBCD8J5.js +1325 -0
  266. package/dist/gateway-rpc-CmJXd4SU.js +14 -0
  267. package/dist/gateway-rpc.runtime-C9Fs2mSx.js +23 -0
  268. package/dist/gateway-rpc.runtime.js +1 -1
  269. package/dist/gateway-runtime-Bm2_MhFn.js +15 -0
  270. package/dist/gateway-status-DXKMKFtB.js +584 -0
  271. package/dist/genesis-tools-AolFZ-0I.js +8999 -0
  272. package/dist/genesis-tools.runtime-CBWXJqzw.js +2 -0
  273. package/dist/genesis-tools.runtime.js +1 -1
  274. package/dist/get-reply-BpxjHQBp.js +3879 -0
  275. package/dist/get-reply-from-config.runtime-DJKEqLSi.js +2 -0
  276. package/dist/get-reply-from-config.runtime.js +1 -1
  277. package/dist/graph-users-D2Q5UTGQ.js +1337 -0
  278. package/dist/health-BNKpuAPB.js +469 -0
  279. package/dist/health-BkxZfKx8.js +3 -0
  280. package/dist/heartbeat-runner-Bdu2q6k3.js +5 -0
  281. package/dist/heartbeat-runner-C0B-c-fv.js +1292 -0
  282. package/dist/heartbeat-runner.runtime-Cic23eNy.js +4 -0
  283. package/dist/heartbeat-runner.runtime.js +1 -1
  284. package/dist/hooks-cli-BfCr2In5.js +433 -0
  285. package/dist/image-fallbacks-Dgy-LmDo.js +2 -0
  286. package/dist/image-fallbacks-RlfTqOne.js +31 -0
  287. package/dist/inbound-reply-dispatch-D4KJHWLG.js +73 -0
  288. package/dist/index.js +2 -2
  289. package/dist/infra-runtime-BTJv3KK8.js +39 -0
  290. package/dist/init-q4INH9uv.js +59 -0
  291. package/dist/install-BT4BNeMX.js +190 -0
  292. package/dist/install.runtime-BnqPyIyn.js +2 -0
  293. package/dist/launchd-BM_37PLv.js +698 -0
  294. package/dist/library-DGd4UZKC.js +45 -0
  295. package/dist/lifecycle-B_RLw4uY.js +229 -0
  296. package/dist/lifecycle-Bw01evSl.js +571 -0
  297. package/dist/lifecycle-core-CTjCo-k0.js +422 -0
  298. package/dist/lifecycle.runtime-BxpD2Ol7.js +2 -0
  299. package/dist/lifecycle.runtime.js +1 -1
  300. package/dist/list-BXa4zUF-.js +2 -0
  301. package/dist/list-BugTSXmQ.js +131 -0
  302. package/dist/list-CgC_rsta.js +1201 -0
  303. package/dist/list-D2sk1YPs.js +2 -0
  304. package/dist/list.probe-C6zfgLdG.js +419 -0
  305. package/dist/llm-slug-generator-DsWJvqNx.js +79 -0
  306. package/dist/llm-slug-generator.js +1 -1
  307. package/dist/load-config-D6ZKPY7I.js +35 -0
  308. package/dist/local-dispatch.runtime-MWMxyZKj.js +8 -0
  309. package/dist/local-dispatch.runtime.js +1 -1
  310. package/dist/logs-cli-Dn-8jl3z.js +265 -0
  311. package/dist/logs-cli.runtime-DwsccWUJ.js +2 -0
  312. package/dist/logs-cli.runtime.js +1 -1
  313. package/dist/main-session-restart-recovery-6Uh4W8ZJ.js +206 -0
  314. package/dist/managed-image-attachments-DHawPS1-.js +2 -0
  315. package/dist/managed-image-attachments-DjtxwZ9o.js +635 -0
  316. package/dist/manager-D0tkR46e.js +2057 -0
  317. package/dist/manager-g_P1RDky.js +2 -0
  318. package/dist/markdown-to-line-7AxR7QFo.js +790 -0
  319. package/dist/mcp/plugin-tools-serve.js +1 -1
  320. package/dist/mcp-cli-Cw2XQMOA.js +725 -0
  321. package/dist/mcp-http-DFKqya8U.js +529 -0
  322. package/dist/memory-core-host-runtime-cli-DaAsOXiU.js +9 -0
  323. package/dist/message-BDCG7eWj.js +232 -0
  324. package/dist/message-action-runner-6C7kXcC9.js +2 -0
  325. package/dist/message-action-runner-C2P3efhU.js +1407 -0
  326. package/dist/message-actions-BWQWt5gT.js +143 -0
  327. package/dist/message.gateway.runtime-BXChuYAf.js +2 -0
  328. package/dist/message.gateway.runtime.js +1 -1
  329. package/dist/models-auth-status-B8lnM1PS.js +201 -0
  330. package/dist/models-cli-DbUA18AN.js +219 -0
  331. package/dist/monitor-BEJe2ceJ.js +1237 -0
  332. package/dist/monitor-BO9i6U5R.js +1459 -0
  333. package/dist/monitor-BZLrxL_x.js +1661 -0
  334. package/dist/monitor-CDDxHGlD.js +788 -0
  335. package/dist/monitor-D779kLc0.js +671 -0
  336. package/dist/monitor-V5ZNCrQL.js +2 -0
  337. package/dist/monitor-auth-D2rCHNgr.js +207 -0
  338. package/dist/monitor-processing-BLbsNFVv.js +1974 -0
  339. package/dist/monitor.runtime-RrusGXVO.js +2 -0
  340. package/dist/monitor.runtime.js +1 -1
  341. package/dist/monitor.webhook-B0DuBNWa.js +180 -0
  342. package/dist/msteams-hh9nwLlZ.js +35 -0
  343. package/dist/native-hook-relay-BygYZoeR.js +519 -0
  344. package/dist/nextcloud-talk-AadRCqXn.js +17 -0
  345. package/dist/node-cli-FF1zz0JU.js +2506 -0
  346. package/dist/node-service-f8mmgM5L.js +68 -0
  347. package/dist/nodes-cli-tQ5dpecZ.js +1046 -0
  348. package/dist/nodes-utils-BfpGcUca.js +84 -0
  349. package/dist/nodes.helpers-CMXxavTs.js +34 -0
  350. package/dist/notify-DaNP5Zyh.js +315 -0
  351. package/dist/onboard-B9hx80Dm.js +632 -0
  352. package/dist/onboard-helpers-BlPrFJHK.js +204 -0
  353. package/dist/onboard-helpers-kL8mgUkl.js +6 -0
  354. package/dist/onboard-remote-ByHuQd1m.js +193 -0
  355. package/dist/onboard-remote-CRPXcrWy.js +2 -0
  356. package/dist/onboard-skills-ChtyNRCd.js +2 -0
  357. package/dist/onboard-skills-DROlYXya.js +134 -0
  358. package/dist/openai-http-2An5HAJU.js +500 -0
  359. package/dist/openresponses-http-DpbJXZP4.js +1128 -0
  360. package/dist/operator-approvals-client-BoN_VmkB.js +68 -0
  361. package/dist/outbound.runtime-D_aebUn6.js +2 -0
  362. package/dist/outbound.runtime.js +1 -1
  363. package/dist/pair-command-approve-i-1VECJx.js +44 -0
  364. package/dist/persistent-bindings.lifecycle-eZyKQ1D8.js +85 -0
  365. package/dist/persistent-bindings.lifecycle-mxY73TJR.js +2 -0
  366. package/dist/pi-embedded-0fErjTQ7.js +2905 -0
  367. package/dist/pi-embedded-Bc1jC2x0.js +4 -0
  368. package/dist/pi-embedded.runtime-Bn_RZ5z8.js +4 -0
  369. package/dist/pi-embedded.runtime.js +1 -1
  370. package/dist/pi-tool-definition-adapter-thh7LO1t.js +217 -0
  371. package/dist/pi-tools-BtlLDovQ.js +1057 -0
  372. package/dist/pi-tools.before-tool-call-BJ_X8Dq3.js +2 -0
  373. package/dist/pi-tools.before-tool-call-DdPCGWCs.js +433 -0
  374. package/dist/plugin-CdHHk4Xn.js +12195 -0
  375. package/dist/plugin-enabled-DybhbjKQ.js +140 -0
  376. package/dist/plugin-registration-Bgwpsokw.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-ClhrJfT3.js +2890 -0
  419. package/dist/plugins/runtime/index.js +1 -1
  420. package/dist/policy-CoqHgREn.js +328 -0
  421. package/dist/postinstall-inventory.json +418 -418
  422. package/dist/prepare.runtime-CawO_32K.js +815 -0
  423. package/dist/prepare.runtime.js +1 -1
  424. package/dist/probe-BP3QS65i.js +74 -0
  425. package/dist/probe-BdCXAH_u.js +2 -0
  426. package/dist/probe-Cv5tXOMP.js +2205 -0
  427. package/dist/probe-D-D_1oc4.js +241 -0
  428. package/dist/probe-DO-gll0g.js +2 -0
  429. package/dist/probe-T6c0F73q.js +45 -0
  430. package/dist/probe-dxji7IxZ.js +1443 -0
  431. package/dist/program-GMPfHt5E.js +111 -0
  432. package/dist/prompt-select-styled-BvuJNEJG.js +20 -0
  433. package/dist/protocol-Batc2DmY.js +2234 -0
  434. package/dist/provider-dispatcher-CGYoOdKf.js +2 -0
  435. package/dist/provider-dispatcher-iTEDM88F.js +22 -0
  436. package/dist/qr-cli-6IxenO1C.js +349 -0
  437. package/dist/qr-cli-D63piSog.js +2 -0
  438. package/dist/reaction-runtime-api-DgwRXTz2.js +116 -0
  439. package/dist/reactions-Dnh7t4Zl.js +998 -0
  440. package/dist/register-service-commands-D7w01SKL.js +71 -0
  441. package/dist/register.agent-j1Eno4xr.js +248 -0
  442. package/dist/register.configure-ubwxTkGt.js +15 -0
  443. package/dist/register.maintenance-B7FuM_ZW.js +438 -0
  444. package/dist/register.message-QR3u9rBl.js +329 -0
  445. package/dist/register.onboard-Bdcf_lH0.js +81 -0
  446. package/dist/register.runtime-QDduc4yj.js +81 -0
  447. package/dist/register.runtime.js +1 -1
  448. package/dist/register.setup-DzVV6tdQ.js +150 -0
  449. package/dist/register.status-health-sessions-Brw3VcxG.js +1215 -0
  450. package/dist/register.subclis-B8qDbqPl.js +29 -0
  451. package/dist/register.subclis-DdoN3nZi.js +3 -0
  452. package/dist/register.subclis-core-CWHmnIoe.js +249 -0
  453. package/dist/reply-dispatch-runtime-BVLvCeJ0.js +13 -0
  454. package/dist/reply-runtime-BXkvfLv_.js +11 -0
  455. package/dist/reply.runtime-BTkpxI5R.js +2 -0
  456. package/dist/reply.runtime.js +1 -1
  457. package/dist/restart-health-6cjrRBpF.js +202 -0
  458. package/dist/restart-health-b6Qw43Tj.js +2 -0
  459. package/dist/root-help-DDa1oEtT.js +44 -0
  460. package/dist/routes-CoCMty69.js +2 -0
  461. package/dist/routes-D9uC_Zdy.js +3341 -0
  462. package/dist/rpc-DpLGM3FH.js +61 -0
  463. package/dist/rpc.runtime-B27EA5A0.js +21 -0
  464. package/dist/rpc.runtime.js +1 -1
  465. package/dist/run-delivery.runtime-OmILefLX.js +530 -0
  466. package/dist/run-delivery.runtime.js +1 -1
  467. package/dist/run-embedded.runtime-Dc43u_Z7.js +4 -0
  468. package/dist/run-embedded.runtime.js +1 -1
  469. package/dist/run-execution-cli.runtime-DL5w7Ac8.js +4 -0
  470. package/dist/run-execution-cli.runtime.js +1 -1
  471. package/dist/run-executor.runtime-Bzwt0zP-.js +277 -0
  472. package/dist/run-executor.runtime.js +1 -1
  473. package/dist/run-main-BLD1wTLU.js +516 -0
  474. package/dist/run-subagent-registry.runtime-CddCeg6W.js +2 -0
  475. package/dist/run-subagent-registry.runtime.js +1 -1
  476. package/dist/run-wait-D4Gxuyru.js +135 -0
  477. package/dist/runtime-8BuIPrSY.js +973 -0
  478. package/dist/runtime-Co8r21pw.js +9 -0
  479. package/dist/runtime-api-BG0XWkir.js +4 -0
  480. package/dist/runtime-api-BjBzlgns.js +9 -0
  481. package/dist/runtime-api-DlYbbA-n.js +14 -0
  482. package/dist/runtime-api-faT33SE2.js +9 -0
  483. package/dist/runtime-embedded-pi.runtime-QdJ7K4t0.js +2 -0
  484. package/dist/runtime-embedded-pi.runtime.js +1 -1
  485. package/dist/runtime-internal-C0xc_Zhf.js +2 -0
  486. package/dist/runtime-options-DLv7ygkO.js +275 -0
  487. package/dist/runtime-schema-CQK5R5Pl.js +27780 -0
  488. package/dist/scan-Yz6DoQn5.js +523 -0
  489. package/dist/scan-k38hL_6o.js +2 -0
  490. package/dist/secrets-cli-Bjvr0bOw.js +2101 -0
  491. package/dist/security-cli-C2gkMFcB.js +486 -0
  492. package/dist/selection-DC8EXnRg.js +7736 -0
  493. package/dist/selection-DmSFI5k4.js +2 -0
  494. package/dist/send-CT6EfHrc.js +102 -0
  495. package/dist/send-_ANvjE_C.js +156 -0
  496. package/dist/send.runtime-COIjG4BV.js +2 -0
  497. package/dist/send.runtime.js +1 -1
  498. package/dist/server-COkv9Si4.js +13 -0
  499. package/dist/server-DHLQZJL8.js +77 -0
  500. package/dist/server-context-6jnr-aAw.js +2 -0
  501. package/dist/server-context-DK1QsdLh.js +847 -0
  502. package/dist/server-node-events-q8H0odkq.js +481 -0
  503. package/dist/server-plugin-bootstrap-Bw4a88yA.js +2 -0
  504. package/dist/server-plugin-bootstrap-By_w9ngt.js +11333 -0
  505. package/dist/server-restart-sentinel-CGLYF3mk.js +697 -0
  506. package/dist/server.impl-8j4SImks.js +12735 -0
  507. package/dist/service-CNjb_qXC.js +2 -0
  508. package/dist/service-CyR3mZIU.js +120 -0
  509. package/dist/service-audit-DIL0OiMa.js +260 -0
  510. package/dist/service-audit-pwloDggS.js +2 -0
  511. package/dist/session-kill-http-Dek5w0Ee.js +110 -0
  512. package/dist/session-reset-service-B_9Ps0kr.js +471 -0
  513. package/dist/session-route-Cr6vOd9_.js +93 -0
  514. package/dist/session-status.runtime-C_x1MHH5.js +2 -0
  515. package/dist/session-status.runtime.js +1 -1
  516. package/dist/session-subagent-reactivation.runtime-BKWuNild.js +2 -0
  517. package/dist/session-subagent-reactivation.runtime.js +1 -1
  518. package/dist/session-tab-registry-C08V5jx6.js +491 -0
  519. package/dist/session-visibility-D4j8hN_B.js +147 -0
  520. package/dist/sessions-helpers-DmUVRk16.js +304 -0
  521. package/dist/sessions-history-http-DN3KzEnX.js +383 -0
  522. package/dist/sessions-patch-BPtlF0Lu.js +309 -0
  523. package/dist/sessions-resolve-D6KPfG_4.js +174 -0
  524. package/dist/sessions.runtime-DGL1-G20.js +2 -0
  525. package/dist/sessions.runtime.js +1 -1
  526. package/dist/setup-CkYiQoP0.js +495 -0
  527. package/dist/setup-api-CUGYqGNT.js +29 -0
  528. package/dist/setup-core-BmplfubJ.js +171 -0
  529. package/dist/setup-core-C5ddWpfy.js +176 -0
  530. package/dist/setup-surface-2JmEfowI.js +219 -0
  531. package/dist/setup-surface-BzHQx_GD.js +403 -0
  532. package/dist/setup-surface-DOH6kc6w.js +286 -0
  533. package/dist/setup.finalize-Ci2HBkDq.js +539 -0
  534. package/dist/setup.gateway-config-CyG_Fzaa.js +250 -0
  535. package/dist/shared-BItUH43s.js +121 -0
  536. package/dist/shared-D7diJkX6.js +198 -0
  537. package/dist/shared-DJU_HCJ1.js +76 -0
  538. package/dist/slash-state-C4YD-tLz.js +1911 -0
  539. package/dist/src-8HdytGc7.js +3974 -0
  540. package/dist/startup-context-CfcCyUU0.js +312 -0
  541. package/dist/status-B94yciC9.js +397 -0
  542. package/dist/status-BUkUYtFm.js +190 -0
  543. package/dist/status-BsHC-0MV.js +2 -0
  544. package/dist/status-D4jNATg0.js +209 -0
  545. package/dist/status-U8ut-X2Q.js +2 -0
  546. package/dist/status-all-CIzsXQnV.js +498 -0
  547. package/dist/status-json-alPkfWTd.js +14 -0
  548. package/dist/status-json-command-CAkzWzw7.js +84 -0
  549. package/dist/status-jxNdVQVZ.js +3 -0
  550. package/dist/status-runtime-shared-BSsA48i9.js +257 -0
  551. package/dist/status-subagents.runtime-hIKg6PXV.js +18 -0
  552. package/dist/status-subagents.runtime.js +1 -1
  553. package/dist/status-text-BmLJrLth.js +237 -0
  554. package/dist/status.gateway-connection.runtime-Dr7HJ1wZ.js +2 -0
  555. package/dist/status.gateway-connection.runtime.js +1 -1
  556. package/dist/status.gather-DFY0T97g.js +2 -0
  557. package/dist/status.gather-e6sfNh8I.js +292 -0
  558. package/dist/status.runtime-DBvapXQS.js +2 -0
  559. package/dist/status.runtime.js +1 -1
  560. package/dist/status.scan-DSpkE-Q-.js +65 -0
  561. package/dist/status.scan-overview-Dr72bkbi.js +379 -0
  562. package/dist/status.scan.fast-json-C7k_m46S.js +2 -0
  563. package/dist/status.scan.fast-json-KHh7R3wX.js +132 -0
  564. package/dist/status.summary-C4r9lkCH.js +214 -0
  565. package/dist/status.summary-D0EJwkmX.js +2 -0
  566. package/dist/subagent-announce-Bu5-8O3P.js +351 -0
  567. package/dist/subagent-announce-delivery-4hk9P48s.js +726 -0
  568. package/dist/subagent-announce-output-Csyi1-Kz.js +364 -0
  569. package/dist/subagent-control-DAeNsV_G.js +506 -0
  570. package/dist/subagent-followup.runtime-Bch92LIq.js +68 -0
  571. package/dist/subagent-followup.runtime.js +1 -1
  572. package/dist/subagent-orphan-recovery-mNzyr1b-.js +305 -0
  573. package/dist/subagent-registry-BMjQxBxi.js +3 -0
  574. package/dist/subagent-registry-D4DFKQCL.js +1753 -0
  575. package/dist/subagent-registry.runtime.js +1 -1
  576. package/dist/subagent-spawn-C13uUm47.js +1005 -0
  577. package/dist/system-cli-BU6GhJxG.js +59 -0
  578. package/dist/targets-eYkepVzz.js +67 -0
  579. package/dist/task-executor-DzJLcm4D.js +360 -0
  580. package/dist/task-owner-access-DW9EbhjP.js +74 -0
  581. package/dist/task-registry-DBJkAtFF.js +2366 -0
  582. package/dist/task-registry-delivery-runtime-BdkPeGC1.js +2 -0
  583. package/dist/task-registry-delivery-runtime-Ov88LGnv.js +3 -0
  584. package/dist/task-registry.maintenance-BU6Z4V_9.js +416 -0
  585. package/dist/task-registry.maintenance-sEo6eYdx.js +2 -0
  586. package/dist/telegram/token.js +1 -1
  587. package/dist/testing-B2jHeQft.js +575 -0
  588. package/dist/text-report-HYrgZP8-.js +587 -0
  589. package/dist/tool-resolution-BZxaDOKg.js +90 -0
  590. package/dist/tools-effective-inventory-BCvCprpD.js +152 -0
  591. package/dist/tools-invoke-http-Dt1rsx4a.js +206 -0
  592. package/dist/trash-F4tvjrKS.js +24 -0
  593. package/dist/tui-cli-DlQ1oejy.js +4575 -0
  594. package/dist/update-cli-DHMdwQWA.js +1759 -0
  595. package/dist/upgrade-UR-EI5pO.js +1226 -0
  596. package/dist/video-generation-task-status-qtHrIZLt.js +163 -0
  597. package/dist/wait-for-idle-before-flush-CYB_61O0.js +5986 -0
  598. package/dist/wizard-models-BKqMCaCm.js +161 -0
  599. package/package.json +1 -1
  600. package/dist/abort-BHSttDhY.js +0 -201
  601. package/dist/abort.runtime-VJ9lFsZS.js +0 -2
  602. package/dist/accounts-BNvagEOQ.js +0 -104
  603. package/dist/accounts-CPIuzenz.js +0 -107
  604. package/dist/accounts-r08DQWhZ.js +0 -2
  605. package/dist/acp-cli-i0L-eRs9.js +0 -2193
  606. package/dist/acp-spawn-CHzVLe9q.js +0 -1093
  607. package/dist/acp-spawn-CqvxDuBq.js +0 -2
  608. package/dist/acp-stateful-target-driver-CWRLc_NP.js +0 -89
  609. package/dist/action-agents-SNCscX_-.js +0 -67
  610. package/dist/action-focus-B2s0PF2E.js +0 -132
  611. package/dist/action-help-CXKbyaZ7.js +0 -7
  612. package/dist/action-info-B3IDKxWu.js +0 -101
  613. package/dist/action-kill-idGvCNhT.js +0 -33
  614. package/dist/action-list-Di7gO3qL.js +0 -21
  615. package/dist/action-log-BCsz-gFi.js +0 -30
  616. package/dist/action-send-DLsdZnVc.js +0 -39
  617. package/dist/action-spawn-DhKEOdL0.js +0 -47
  618. package/dist/action-unfocus-Dh7ti5UP.js +0 -29
  619. package/dist/actions.runtime-BPf03SN3.js +0 -18
  620. package/dist/actions.runtime-CJg_lweh.js +0 -5
  621. package/dist/agent-C3PLvvws.js +0 -2
  622. package/dist/agent-command-UroeNrV4.js +0 -874
  623. package/dist/agent-harness-runtime-MXvI9FlJ.js +0 -144
  624. package/dist/agent-runner-utils-CaVgLZrf.js +0 -239
  625. package/dist/agent-runner.runtime-Csqm3m09.js +0 -3455
  626. package/dist/agent-runtime-B9nUYDUz.js +0 -18
  627. package/dist/agents-BP4p-1q2.js +0 -5
  628. package/dist/agents-CDiXfrfc.js +0 -953
  629. package/dist/aliases-BBCtCq2A.js +0 -96
  630. package/dist/aliases-DrFtFq1p.js +0 -2
  631. package/dist/api-BH0oEwR1.js +0 -5
  632. package/dist/api-D-4gHdrl.js +0 -139
  633. package/dist/api-DE6RYTxv.js +0 -3
  634. package/dist/approval-gateway-resolver-URpDQMld.js +0 -29
  635. package/dist/approval-gateway-runtime-B087BMms.js +0 -2
  636. package/dist/approval-handler-runtime-BEl3ua8-.js +0 -439
  637. package/dist/approval-native-runtime-ghjYGufu.js +0 -729
  638. package/dist/attempt-execution.runtime-PCTFYqLh.js +0 -509
  639. package/dist/attempt.prompt-helpers-CkWEozQ2.js +0 -221
  640. package/dist/attempt.tool-run-context-DbqVgXFk.js +0 -933
  641. package/dist/audit-Lb1yNEwg.js +0 -939
  642. package/dist/audit.runtime-DOnixKE_.js +0 -7
  643. package/dist/auth-BrlJ7NM9.js +0 -2
  644. package/dist/auth-CJoP7Yst.js +0 -383
  645. package/dist/auth-order-D0KFgBib.js +0 -96
  646. package/dist/auth-order-_xlUHzCg.js +0 -2
  647. package/dist/bash-tools-BEVEHCl9.js +0 -2824
  648. package/dist/bash-tools-DJ0D8Wr5.js +0 -3
  649. package/dist/binding-routing-IfKqPcfO.js +0 -85
  650. package/dist/binding-targets-2huR0hTX.js +0 -121
  651. package/dist/bridge-server-D8Y8Fzdz.js +0 -113
  652. package/dist/browser-control-auth-Q6UpVLEj.js +0 -2
  653. package/dist/browser-node-runtime-C9KvsOyx.js +0 -12
  654. package/dist/browser-profiles-DFcwiMEf.js +0 -2
  655. package/dist/browser-runtime-sbZ3hKg6.js +0 -387
  656. package/dist/browser-setup-tools-CP4BkZ9z.js +0 -13
  657. package/dist/build-DzHX2LrH.js +0 -550
  658. package/dist/call-ORivR4Db.js +0 -331
  659. package/dist/call-qzfm6lro.js +0 -3
  660. package/dist/call.runtime-BkzJe07B.js +0 -2
  661. package/dist/capability-cli-BDCvm93o.js +0 -1401
  662. package/dist/catchup-CjZa2PrP.js +0 -300
  663. package/dist/channel-B3UAL9Pk.js +0 -840
  664. package/dist/channel-B5L9LJBF.js +0 -453
  665. package/dist/channel-BGXl6A-E.js +0 -297
  666. package/dist/channel-BNUblayu.js +0 -1320
  667. package/dist/channel-Bej-TN7f.js +0 -491
  668. package/dist/channel-BzOKSC4e.js +0 -350
  669. package/dist/channel-CY2xEOzR.js +0 -1802
  670. package/dist/channel-D2kKLWUA.js +0 -226
  671. package/dist/channel-DcjCe46M.js +0 -1100
  672. package/dist/channel-GqA96nmt.js +0 -595
  673. package/dist/channel-YI2aIJFQ.js +0 -1174
  674. package/dist/channel-core-DqPUhmTt.js +0 -5
  675. package/dist/channel-inbound-CzgMd2Xi.js +0 -31
  676. package/dist/channel-plugin-runtime-DI5uUbxx.js +0 -771
  677. package/dist/channel-runtime-BJqKQitD.js +0 -425
  678. package/dist/channel.runtime-BBn9mgbB.js +0 -89
  679. package/dist/channel.runtime-Bhj1b9gQ.js +0 -34702
  680. package/dist/channel.runtime-BzOVx90Z.js +0 -576
  681. package/dist/channel.runtime-CQkLKWlq.js +0 -109
  682. package/dist/channel.runtime-D8qT4A1x.js +0 -4
  683. package/dist/channel.runtime-DjK9Re1w.js +0 -2364
  684. package/dist/channel.runtime-tWwM8hFw.js +0 -430
  685. package/dist/channel.setup-gaiRZ-r8.js +0 -10
  686. package/dist/channels-BXIl3hBo.js +0 -733
  687. package/dist/channels-cli-CrmBqaul.js +0 -268
  688. package/dist/chat-C42usv-F.js +0 -2758
  689. package/dist/clawbot-cli-BGYO_ymZ.js +0 -9
  690. package/dist/cli-BbD25CFK.js +0 -2
  691. package/dist/cli-CYD4Wfcq.js +0 -219
  692. package/dist/cli-D-6ycHAw.js +0 -72
  693. package/dist/cli-DX4CK-bw.js +0 -2
  694. package/dist/cli-runner-C5_PBTxm.js +0 -286
  695. package/dist/cli-runner.runtime-DE7RpQ27.js +0 -3
  696. package/dist/cli-runner.runtime-ueVMICzY.js +0 -4
  697. package/dist/cli.runtime-DSO8Vfrh.js +0 -1261
  698. package/dist/client-BKro32pr.js +0 -138
  699. package/dist/client-Vx7pseEY.js +0 -713
  700. package/dist/command-auth-CvFUTCCJ.js +0 -76
  701. package/dist/command-config-resolution-BnW1XGnW.js +0 -23
  702. package/dist/command-config-resolution-BrlfYyiN.js +0 -2
  703. package/dist/command-config-resolution.runtime-DYMr8J0t.js +0 -2
  704. package/dist/command-registry-Bi9thw1b.js +0 -9
  705. package/dist/command-registry-D__zH4Fg.js +0 -4
  706. package/dist/command-registry-core-DQoNFQZT.js +0 -101
  707. package/dist/command-secret-gateway-B27Zpgo9.js +0 -528
  708. package/dist/command-status.runtime-fERQMzeI.js +0 -87
  709. package/dist/commands-acp-BmORmf3-.js +0 -77
  710. package/dist/commands-compact.runtime-BUaXIw-I.js +0 -10
  711. package/dist/commands-handlers.runtime-BxbkeuTc.js +0 -4597
  712. package/dist/commands-status-4OW5sqmg.js +0 -16
  713. package/dist/commands-status.runtime-Cl7nJp_7.js +0 -3
  714. package/dist/commands-subagents-control.runtime-BR4qBGkk.js +0 -2
  715. package/dist/commands-subagents-control.runtime-C8ufgKPI.js +0 -3
  716. package/dist/commands-system-prompt-BsimvjJt.js +0 -158
  717. package/dist/commands-system-prompt-CKrY0h7P.js +0 -2
  718. package/dist/commands.runtime-BHsDdaEU.js +0 -166
  719. package/dist/compact-BHYLQst3.js +0 -1118
  720. package/dist/compact.runtime-7-tZRdgw.js +0 -12
  721. package/dist/completion-cli-1sAiSIYc.js +0 -328
  722. package/dist/config-BZ3FuFjH.js +0 -251
  723. package/dist/config-cli-B_dNq5hD.js +0 -1078
  724. package/dist/configure-BOvmX2NJ.js +0 -2
  725. package/dist/configure-DR9NYN9e.js +0 -1245
  726. package/dist/connect-options-DlmPTyhG.js +0 -699
  727. package/dist/control-auth-C_zNiV10.js +0 -125
  728. package/dist/control-service-B1TL51jf.js +0 -156
  729. package/dist/conversation-id-B3lLiTfF.js +0 -235
  730. package/dist/conversation-id-DORmTZm_.js +0 -38
  731. package/dist/conversation-runtime-DDxZZZXE.js +0 -31
  732. package/dist/core-DbPzffGG.js +0 -275
  733. package/dist/cron-cli-AoH4jhFt.js +0 -713
  734. package/dist/daemon-cli-BOJdM3wT.js +0 -12
  735. package/dist/daemon-install-D8HPES4u.js +0 -64
  736. package/dist/delegate-Dmdda3kT.js +0 -64
  737. package/dist/detached-task-runtime-BB5az34R.js +0 -73
  738. package/dist/devices-cli-Cy9DF-DP.js +0 -496
  739. package/dist/diagnostics-CTE0TWR1.js +0 -154
  740. package/dist/direct-dm-9jzadx9u.js +0 -64
  741. package/dist/dispatch-DU7cqfv6.js +0 -1131
  742. package/dist/dispatch-acp-Cu_nUtKg.js +0 -981
  743. package/dist/dispatch-acp-manager.runtime-8MOQ5BRn.js +0 -3
  744. package/dist/dispatch-acp.runtime-DatcHNJq.js +0 -19
  745. package/dist/doctor-device-pairing-Qm-r7mwu.js +0 -307
  746. package/dist/doctor-gateway-daemon-flow-BN2uGhFJ.js +0 -250
  747. package/dist/doctor-gateway-health-CD7Vzth9.js +0 -60
  748. package/dist/doctor-gateway-services-CIypZgv_.js +0 -316
  749. package/dist/doctor-health-ByjG3620.js +0 -59
  750. package/dist/doctor-health-contributions-CxNByg_i.js +0 -486
  751. package/dist/doctor-prompter-BYIoKiZ8.js +0 -56
  752. package/dist/doctor-workspace-status-DL2fRPoT.js +0 -75
  753. package/dist/dreaming-CCctNgkQ.js +0 -1574
  754. package/dist/dreaming-narrative-BPtXKc2-.js +0 -595
  755. package/dist/embedded-gateway-stub.runtime-Hi36BeCq.js +0 -9
  756. package/dist/exec-approvals-cli-DyslUWtQ.js +0 -498
  757. package/dist/fallbacks-B3xZC-ms.js +0 -2
  758. package/dist/fallbacks-CWDz-tSa.js +0 -31
  759. package/dist/fallbacks-shared-BlZBjxHL.js +0 -111
  760. package/dist/gateway-NYBkUx5r.js +0 -115
  761. package/dist/gateway-cli-E5gYA0U1.js +0 -1325
  762. package/dist/gateway-rpc-BrG5Lkfm.js +0 -14
  763. package/dist/gateway-rpc.runtime-BrTGchr9.js +0 -23
  764. package/dist/gateway-runtime-DctMRv_p.js +0 -15
  765. package/dist/gateway-status-B6ol1agz.js +0 -584
  766. package/dist/genesis-tools-D_ah3Zek.js +0 -8999
  767. package/dist/genesis-tools.runtime-Cy7aTWEN.js +0 -2
  768. package/dist/get-reply-BvVkxYum.js +0 -3879
  769. package/dist/get-reply-from-config.runtime-DR3yiK1R.js +0 -2
  770. package/dist/graph-users-yBNugoFz.js +0 -1337
  771. package/dist/health-D_wk2s7j.js +0 -3
  772. package/dist/health-MRnjOx-_.js +0 -469
  773. package/dist/heartbeat-runner-NuhhYnxs.js +0 -5
  774. package/dist/heartbeat-runner-Y4NeUV3L.js +0 -1292
  775. package/dist/heartbeat-runner.runtime-eGfKtcpP.js +0 -4
  776. package/dist/hooks-cli-CtfN2vc-.js +0 -433
  777. package/dist/image-fallbacks-CgeDMYZo.js +0 -2
  778. package/dist/image-fallbacks-CzQ85Eo8.js +0 -31
  779. package/dist/inbound-reply-dispatch-jVlLaSqn.js +0 -73
  780. package/dist/infra-runtime-D2Pqjk-r.js +0 -39
  781. package/dist/init-D_MTYqrw.js +0 -59
  782. package/dist/install-X7wgrwQ1.js +0 -190
  783. package/dist/install.runtime-C4wO4Nr9.js +0 -2
  784. package/dist/launchd-lFgfiDrN.js +0 -688
  785. package/dist/library-DIykYIWD.js +0 -45
  786. package/dist/lifecycle-BNuFzffC.js +0 -571
  787. package/dist/lifecycle-IWN9qlwo.js +0 -229
  788. package/dist/lifecycle-core-CFv5qkS8.js +0 -422
  789. package/dist/lifecycle.runtime-9oo2JCI2.js +0 -2
  790. package/dist/list-BZ3mMSpA.js +0 -2
  791. package/dist/list-CzQs_k0U.js +0 -131
  792. package/dist/list-CzTJTFOH.js +0 -1201
  793. package/dist/list-qDXsgKhB.js +0 -2
  794. package/dist/list.probe-EOZR6ueo.js +0 -419
  795. package/dist/llm-slug-generator-DzWIx0nh.js +0 -79
  796. package/dist/load-config-C_8uUnXU.js +0 -35
  797. package/dist/local-dispatch.runtime-DLd10Xb1.js +0 -8
  798. package/dist/logs-cli-mnOTmC9R.js +0 -265
  799. package/dist/logs-cli.runtime-BvP3aise.js +0 -2
  800. package/dist/main-session-restart-recovery-D7Vxmu7e.js +0 -206
  801. package/dist/managed-image-attachments-BB5u0Zq8.js +0 -2
  802. package/dist/managed-image-attachments-BeRGNdL9.js +0 -635
  803. package/dist/manager-BhNWV4EC.js +0 -2
  804. package/dist/manager-CbZ9ncZs.js +0 -2057
  805. package/dist/markdown-to-line-DyB8w7ef.js +0 -790
  806. package/dist/mcp-cli-CWzLBrDF.js +0 -725
  807. package/dist/mcp-http-1jD7LE0a.js +0 -529
  808. package/dist/memory-core-host-runtime-cli-P80xoEfr.js +0 -9
  809. package/dist/message-BAhd_1ud.js +0 -232
  810. package/dist/message-action-runner-CH2jjT21.js +0 -1407
  811. package/dist/message-action-runner-DW7z_bMx.js +0 -2
  812. package/dist/message-actions-BjBGSsJB.js +0 -143
  813. package/dist/message.gateway.runtime-sUc85g7X.js +0 -2
  814. package/dist/models-auth-status-D6lrM56M.js +0 -201
  815. package/dist/models-cli-CmnbAk2M.js +0 -219
  816. package/dist/monitor-AyGe8vyk.js +0 -1237
  817. package/dist/monitor-DQuy2kx-.js +0 -671
  818. package/dist/monitor-DmtJiX5o.js +0 -788
  819. package/dist/monitor-GB8lcnal.js +0 -1459
  820. package/dist/monitor-IuVjATac.js +0 -1661
  821. package/dist/monitor-auth-rF7mr3Cm.js +0 -207
  822. package/dist/monitor-bnOvJyLN.js +0 -2
  823. package/dist/monitor-processing-B1ewr2qF.js +0 -1974
  824. package/dist/monitor.runtime-BrUD5_VN.js +0 -2
  825. package/dist/monitor.webhook-BvJG6Xbh.js +0 -180
  826. package/dist/msteams-DUDRy3xt.js +0 -35
  827. package/dist/native-hook-relay-CTpTLgCA.js +0 -519
  828. package/dist/nextcloud-talk-BH2uWRZ2.js +0 -17
  829. package/dist/node-cli-AWE1ZFfV.js +0 -2506
  830. package/dist/node-service-DCI-s3Mm.js +0 -68
  831. package/dist/nodes-cli-B7IWCrYq.js +0 -1046
  832. package/dist/nodes-utils-Dg2hrC3z.js +0 -84
  833. package/dist/nodes.helpers-CkJO5i0d.js +0 -34
  834. package/dist/notify-bsxfkOWp.js +0 -315
  835. package/dist/onboard-BQaZtwIU.js +0 -632
  836. package/dist/onboard-helpers-Cc2AnoIU.js +0 -6
  837. package/dist/onboard-helpers-DIxfEXNM.js +0 -204
  838. package/dist/onboard-remote-CYhQbOXH.js +0 -2
  839. package/dist/onboard-remote-DrH3yVxE.js +0 -193
  840. package/dist/onboard-skills-DCI3hVXa.js +0 -134
  841. package/dist/onboard-skills-i4KuFzS4.js +0 -2
  842. package/dist/openai-http-D_7Nk3iN.js +0 -500
  843. package/dist/openresponses-http-BITxvD4V.js +0 -1128
  844. package/dist/operator-approvals-client-C0t_-2xC.js +0 -68
  845. package/dist/outbound.runtime-C8_lBQcx.js +0 -2
  846. package/dist/pair-command-approve-D3s1W5go.js +0 -44
  847. package/dist/persistent-bindings.lifecycle-CCR6khHJ.js +0 -85
  848. package/dist/persistent-bindings.lifecycle-Dgoo5bpE.js +0 -2
  849. package/dist/pi-embedded-C2l80M7j.js +0 -4
  850. package/dist/pi-embedded-DMHGJgoQ.js +0 -2905
  851. package/dist/pi-embedded.runtime-fA0EsIue.js +0 -4
  852. package/dist/pi-tool-definition-adapter-B4hSYdYX.js +0 -217
  853. package/dist/pi-tools-YCHBvJG0.js +0 -1057
  854. package/dist/pi-tools.before-tool-call-BsyruRs4.js +0 -433
  855. package/dist/pi-tools.before-tool-call-D1maRTbl.js +0 -2
  856. package/dist/plugin-DmBZwzWQ.js +0 -12195
  857. package/dist/plugin-enabled-rr_Y1Kwh.js +0 -140
  858. package/dist/plugin-registration-J1JWqMZg.js +0 -23
  859. package/dist/plugin-service-CPY8FSW2.js +0 -2890
  860. package/dist/policy-DDUw681i.js +0 -328
  861. package/dist/prepare.runtime-BfnpyhHB.js +0 -815
  862. package/dist/probe-CCdD6_vN.js +0 -1443
  863. package/dist/probe-CakOsrSu.js +0 -241
  864. package/dist/probe-Ctrcd_Q7.js +0 -2205
  865. package/dist/probe-D9IFIte1.js +0 -2
  866. package/dist/probe-DXMI0QlZ.js +0 -74
  867. package/dist/probe-KtX2HjXM.js +0 -45
  868. package/dist/probe-OcOYm1bj.js +0 -2
  869. package/dist/program-DxZA1yAX.js +0 -111
  870. package/dist/prompt-select-styled-CATG4Xp5.js +0 -20
  871. package/dist/protocol-C40iRm9c.js +0 -2234
  872. package/dist/provider-dispatcher-BZp3Stzr.js +0 -2
  873. package/dist/provider-dispatcher-JJxN7BDL.js +0 -22
  874. package/dist/qr-cli-IMKzycXh.js +0 -349
  875. package/dist/qr-cli-W8X3Ha5T.js +0 -2
  876. package/dist/reaction-runtime-api-D7i4oMn9.js +0 -116
  877. package/dist/reactions-D9eRHeXM.js +0 -998
  878. package/dist/register-service-commands-D37K4_BJ.js +0 -71
  879. package/dist/register.agent-p1q6ZWSs.js +0 -248
  880. package/dist/register.configure-tgXCoIHv.js +0 -15
  881. package/dist/register.maintenance-BtBgu8zC.js +0 -438
  882. package/dist/register.message-B5msOUKt.js +0 -329
  883. package/dist/register.onboard-BO11PDUs.js +0 -81
  884. package/dist/register.runtime-D8XvwfoZ.js +0 -81
  885. package/dist/register.setup-Ba19XSJi.js +0 -150
  886. package/dist/register.status-health-sessions-Bne0mmgw.js +0 -1215
  887. package/dist/register.subclis--mdYCZZM.js +0 -3
  888. package/dist/register.subclis-_kuyreQm.js +0 -29
  889. package/dist/register.subclis-core-UkVTqwB1.js +0 -249
  890. package/dist/reply-dispatch-runtime-DcxOLr7n.js +0 -13
  891. package/dist/reply-runtime-B4VQJnqi.js +0 -11
  892. package/dist/reply.runtime-B990ty9C.js +0 -2
  893. package/dist/restart-health-BWUPc4R-.js +0 -202
  894. package/dist/restart-health-CWvsjHVN.js +0 -2
  895. package/dist/root-help-D9aeVXNr.js +0 -44
  896. package/dist/routes-BSmEgP46.js +0 -2
  897. package/dist/routes-Z67chkN5.js +0 -3341
  898. package/dist/rpc-CBQZvJME.js +0 -61
  899. package/dist/rpc.runtime-ClhNVRer.js +0 -21
  900. package/dist/run-delivery.runtime-Bj566BTH.js +0 -530
  901. package/dist/run-embedded.runtime-DuB-mQh2.js +0 -4
  902. package/dist/run-execution-cli.runtime-Oy4FGfj5.js +0 -4
  903. package/dist/run-executor.runtime-B7-lfFh3.js +0 -277
  904. package/dist/run-main-1Fvwazhp.js +0 -516
  905. package/dist/run-subagent-registry.runtime-Bx9Wga3d.js +0 -2
  906. package/dist/run-wait-C-VgbefQ.js +0 -135
  907. package/dist/runtime-BV7JmOaE.js +0 -9
  908. package/dist/runtime-D7npxl4G.js +0 -973
  909. package/dist/runtime-api-BkVIoPU9.js +0 -4
  910. package/dist/runtime-api-CdhgyHMB.js +0 -9
  911. package/dist/runtime-api-CmlBBCCY.js +0 -9
  912. package/dist/runtime-api-DnhXPE_z.js +0 -14
  913. package/dist/runtime-embedded-pi.runtime-DpKqDUrl.js +0 -2
  914. package/dist/runtime-internal-Bu1n9i4P.js +0 -2
  915. package/dist/runtime-options-CN4g8VJE.js +0 -275
  916. package/dist/runtime-schema-Jjsquqvq.js +0 -27780
  917. package/dist/scan-C8jthyct.js +0 -523
  918. package/dist/scan-DEd4q4aN.js +0 -2
  919. package/dist/secrets-cli-iBL8NBAq.js +0 -2101
  920. package/dist/security-cli-CzYBRa4n.js +0 -486
  921. package/dist/selection-BOalx5uy.js +0 -2
  922. package/dist/selection-BZFVKdFz.js +0 -7736
  923. package/dist/send-C4mKkkWW.js +0 -156
  924. package/dist/send-C_36w3lb.js +0 -102
  925. package/dist/send.runtime-vJT5TzDj.js +0 -2
  926. package/dist/server-BTmWWR_9.js +0 -13
  927. package/dist/server-CBQVrNY0.js +0 -77
  928. package/dist/server-context-Dq2VA7I4.js +0 -2
  929. package/dist/server-context-O_WUP8OV.js +0 -847
  930. package/dist/server-node-events-B8PLg0eQ.js +0 -481
  931. package/dist/server-plugin-bootstrap-ChIvqLMw.js +0 -2
  932. package/dist/server-plugin-bootstrap-Rbxd2g6a.js +0 -11333
  933. package/dist/server-restart-sentinel-BCd6AqrQ.js +0 -697
  934. package/dist/server.impl-CEOWGKN5.js +0 -12735
  935. package/dist/service-ChLFBF7Q.js +0 -120
  936. package/dist/service-XI052xiT.js +0 -2
  937. package/dist/service-audit-BFxGImYM.js +0 -254
  938. package/dist/service-audit-cqHyD5gB.js +0 -2
  939. package/dist/session-kill-http-ChCr5CQ3.js +0 -110
  940. package/dist/session-reset-service-DsYIDYdh.js +0 -471
  941. package/dist/session-route-rem428sJ.js +0 -93
  942. package/dist/session-status.runtime-CFmGwoCm.js +0 -2
  943. package/dist/session-subagent-reactivation.runtime-DLkpnURC.js +0 -2
  944. package/dist/session-tab-registry-DWyzIez5.js +0 -491
  945. package/dist/session-visibility-CJocpWP0.js +0 -147
  946. package/dist/sessions-helpers-CMf9gVTZ.js +0 -304
  947. package/dist/sessions-history-http-C5iZkW8x.js +0 -383
  948. package/dist/sessions-patch-2sBcHc9a.js +0 -309
  949. package/dist/sessions-resolve-D1hmolC-.js +0 -174
  950. package/dist/sessions.runtime-DMPmzLE0.js +0 -2
  951. package/dist/setup-D1ekkhVk.js +0 -495
  952. package/dist/setup-api-DilgjV01.js +0 -29
  953. package/dist/setup-core-CFAiauCt.js +0 -171
  954. package/dist/setup-core-RgJfQc-C.js +0 -176
  955. package/dist/setup-surface-C0l9bHY3.js +0 -286
  956. package/dist/setup-surface-CfcFHZln.js +0 -403
  957. package/dist/setup-surface-CyDRXq_1.js +0 -219
  958. package/dist/setup.finalize-JPqhcPh5.js +0 -539
  959. package/dist/setup.gateway-config-Df6Jm4vX.js +0 -250
  960. package/dist/shared-3gP_6DZV.js +0 -76
  961. package/dist/shared-C9fN-WCy.js +0 -198
  962. package/dist/shared-Cz9c46Aj.js +0 -121
  963. package/dist/slash-state-C7nXXf23.js +0 -1911
  964. package/dist/src-LnF0REtW.js +0 -3974
  965. package/dist/startup-context-CxTy7OzN.js +0 -312
  966. package/dist/status-4n9xL7HY.js +0 -2
  967. package/dist/status-B4kD5cCF.js +0 -2
  968. package/dist/status-CARBoVql.js +0 -209
  969. package/dist/status-COK71LP_.js +0 -3
  970. package/dist/status-DxcqzXtf.js +0 -397
  971. package/dist/status-all-r7zyk41X.js +0 -498
  972. package/dist/status-f2DLmjOF.js +0 -190
  973. package/dist/status-json-C_wESP21.js +0 -14
  974. package/dist/status-json-command-C6w9ZAHp.js +0 -84
  975. package/dist/status-runtime-shared-Bq_SUJpC.js +0 -257
  976. package/dist/status-subagents.runtime-03fp3eBE.js +0 -18
  977. package/dist/status-text-CNvz374U.js +0 -237
  978. package/dist/status.gateway-connection.runtime-zjQmormq.js +0 -2
  979. package/dist/status.gather-BhjoJVEs.js +0 -2
  980. package/dist/status.gather-zdywRvBb.js +0 -292
  981. package/dist/status.runtime-DB31ZRnK.js +0 -2
  982. package/dist/status.scan-DjhdTOWP.js +0 -65
  983. package/dist/status.scan-overview-BYxTBsOw.js +0 -379
  984. package/dist/status.scan.fast-json-Dz0JcORG.js +0 -2
  985. package/dist/status.scan.fast-json-FroEIZ9d.js +0 -132
  986. package/dist/status.summary-3UVa_X5B.js +0 -214
  987. package/dist/status.summary-BGzGsyZB.js +0 -2
  988. package/dist/subagent-announce-BvRFZ87M.js +0 -351
  989. package/dist/subagent-announce-delivery-QvuOM46S.js +0 -726
  990. package/dist/subagent-announce-output-fOtzkOiP.js +0 -364
  991. package/dist/subagent-control-DwnzmG6T.js +0 -506
  992. package/dist/subagent-followup.runtime-DxR1eP_x.js +0 -68
  993. package/dist/subagent-orphan-recovery-CiBbDxX3.js +0 -305
  994. package/dist/subagent-registry-D5FrT_tn.js +0 -3
  995. package/dist/subagent-registry-DbPekx8d.js +0 -1753
  996. package/dist/subagent-spawn-W-bTaU9l.js +0 -1005
  997. package/dist/system-cli-B443uVHG.js +0 -59
  998. package/dist/targets-3Lcm8HoL.js +0 -67
  999. package/dist/task-executor-B5e9_Hmt.js +0 -360
  1000. package/dist/task-owner-access-CIEssJ78.js +0 -74
  1001. package/dist/task-registry-M1bHrFvP.js +0 -2366
  1002. package/dist/task-registry-delivery-runtime-CiHBC7sJ.js +0 -3
  1003. package/dist/task-registry-delivery-runtime-M4O7ffju.js +0 -2
  1004. package/dist/task-registry.maintenance-BURvMU0r.js +0 -2
  1005. package/dist/task-registry.maintenance-CgrLoBqi.js +0 -416
  1006. package/dist/testing-CRy_6-wt.js +0 -575
  1007. package/dist/text-report-B3-4Dvfb.js +0 -587
  1008. package/dist/tool-resolution-C52y5Qtc.js +0 -90
  1009. package/dist/tools-effective-inventory-WlIlqM7G.js +0 -152
  1010. package/dist/tools-invoke-http-B04Rc8tG.js +0 -206
  1011. package/dist/trash-BV5Gcx3a.js +0 -24
  1012. package/dist/tui-cli-DMZ07qRK.js +0 -4575
  1013. package/dist/update-cli-DeBm7b4g.js +0 -1759
  1014. package/dist/upgrade-C9ke1SCc.js +0 -1226
  1015. package/dist/video-generation-task-status-I3jvAjUL.js +0 -163
  1016. package/dist/wait-for-idle-before-flush-BZhF2ejZ.js +0 -5986
  1017. package/dist/wizard-models-CMKeAr_M.js +0 -161
@@ -0,0 +1,939 @@
1
+ import { a as normalizeLowercaseStringOrEmpty, s as normalizeOptionalLowercaseString } from "./string-coerce-C1IzJjqi.js";
2
+ import { t as formatCliCommand } from "./command-format-DAeUlu7u.js";
3
+ import { _ as resolveStateDir, o as resolveConfigPath } from "./paths-DmR9mjUX.js";
4
+ import { o as hasConfiguredSecretInput } from "./types.secrets-ews2W8BF.js";
5
+ import { n as formatPermissionRemediation, r as inspectPathPermissions, t as formatPermissionDetail } from "./audit-fs-DT2deLue.js";
6
+ import { n as resolveGatewayAuth } from "./auth-resolve-f2JHwWZP.js";
7
+ import { n as asNullableRecord } from "./record-coerce-BpObaVhi.js";
8
+ import { t as DEFAULT_AGENT_ID } from "./session-key-EpIbK3Oz.js";
9
+ import { i as normalizeTrustedSafeBinDirs, o as listRiskyConfiguredSafeBins } from "./exec-safe-bin-trust-D3m9TQoQ.js";
10
+ import { b as resolveAgentWorkspaceDir, x as resolveDefaultAgentId } from "./agent-scope-CDjZLqNk.js";
11
+ import { i as resolveSandboxConfigForAgent } from "./config-BT5PfloK.js";
12
+ import { u as isInterpreterLikeAllowlistPattern } from "./exec-approvals-allowlist-BNwpLnkv.js";
13
+ import { i as resolveMergedSafeBinProfileFixtures, n as listInterpreterLikeSafeBins } from "./exec-safe-bin-runtime-policy-9WKan9iE.js";
14
+ import { l as loadExecApprovals } from "./exec-approvals-BD-zKkI1.js";
15
+ import { n as collectCoreInsecureOrDangerousFlags, t as collectEnabledInsecureOrDangerousFlags } from "./dangerous-config-flags-B01qK43f.js";
16
+ import { t as DEFAULT_GATEWAY_HTTP_TOOL_DENY } from "./dangerous-tools-BMgFJtEM.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-COBioB9E.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-wj1AjcUK.js");
283
+ return await channelPluginsModulePromise;
284
+ }
285
+ async function loadAuditNonDeepModule() {
286
+ auditNonDeepModulePromise ??= import("./audit.nondeep.runtime-Bk_5xOjT.js");
287
+ return await auditNonDeepModulePromise;
288
+ }
289
+ async function loadAuditChannelModule() {
290
+ auditChannelModulePromise ??= import("./audit-channel.collect.runtime-mOZS6ZDn.js");
291
+ return await auditChannelModulePromise;
292
+ }
293
+ async function loadPluginRegistryLoaderModule() {
294
+ pluginRegistryLoaderModulePromise ??= import("./runtime-registry-loader-CGNT5-qz.js");
295
+ return await pluginRegistryLoaderModulePromise;
296
+ }
297
+ async function loadPluginMetadataRegistryLoaderModule() {
298
+ pluginMetadataRegistryLoaderModulePromise ??= import("./metadata-registry-loader-BO5ga4BG.js");
299
+ return await pluginMetadataRegistryLoaderModulePromise;
300
+ }
301
+ async function loadPluginAutoEnableModule() {
302
+ pluginAutoEnableModulePromise ??= import("./plugin-auto-enable-m_VfiN5b.js");
303
+ return await pluginAutoEnableModulePromise;
304
+ }
305
+ async function loadChannelPluginIdsModule() {
306
+ channelPluginIdsModulePromise ??= import("./channel-plugin-ids-6IEiYZv1.js");
307
+ return await channelPluginIdsModulePromise;
308
+ }
309
+ async function loadPluginRuntimeModule() {
310
+ pluginRuntimeModulePromise ??= import("./runtime-CpUYCHmq.js");
311
+ return await pluginRuntimeModulePromise;
312
+ }
313
+ async function loadGatewayProbeDeps() {
314
+ gatewayProbeDepsPromise ??= Promise.all([
315
+ import("./call-CbvF41H8.js"),
316
+ import("./probe-auth-Cj-QBrHA.js"),
317
+ import("./probe-BdCXAH_u.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 };