@pixelzx/genesis 2026.5.3-5 → 2026.5.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (996) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-t5XiT6Yl.js +201 -0
  4. package/dist/abort.runtime-C_xk0DkL.js +2 -0
  5. package/dist/abort.runtime.js +1 -1
  6. package/dist/accounts-B7yDKwxi.js +104 -0
  7. package/dist/accounts-CS7VL356.js +107 -0
  8. package/dist/accounts-XvHcAtMf.js +2 -0
  9. package/dist/acp-cli-B5H0nvID.js +2193 -0
  10. package/dist/acp-spawn-BRTMqPlq.js +2 -0
  11. package/dist/acp-spawn-Dsw3dzWY.js +1093 -0
  12. package/dist/acp-stateful-target-driver-BYhkJnyh.js +89 -0
  13. package/dist/action-agents-Ca9kTFvv.js +67 -0
  14. package/dist/action-focus-D4pT0hra.js +132 -0
  15. package/dist/action-help-DMzMxFEQ.js +7 -0
  16. package/dist/action-info-Dzn_fn6G.js +101 -0
  17. package/dist/action-kill-2AQuhnLy.js +33 -0
  18. package/dist/action-list-DI1M2pKU.js +21 -0
  19. package/dist/action-log-BVKGgOki.js +30 -0
  20. package/dist/action-send-CZ2wciMW.js +39 -0
  21. package/dist/action-spawn-BdclQLrK.js +47 -0
  22. package/dist/action-unfocus-DfQuRf8d.js +29 -0
  23. package/dist/actions.runtime-B2-oz_B6.js +5 -0
  24. package/dist/actions.runtime-BoUxrcw3.js +18 -0
  25. package/dist/actions.runtime.js +1 -1
  26. package/dist/agent-CnQ3yCIw.js +2 -0
  27. package/dist/agent-command-C4H_9c2N.js +874 -0
  28. package/dist/agent-harness-runtime-D2oXzgyL.js +144 -0
  29. package/dist/agent-runner-utils-CWgPcOYn.js +239 -0
  30. package/dist/agent-runner.runtime-DvK-HQhq.js +3455 -0
  31. package/dist/agent-runner.runtime.js +1 -1
  32. package/dist/agent-runtime-BDslXtCf.js +18 -0
  33. package/dist/agents-4T7YaeKy.js +953 -0
  34. package/dist/agents-C_Gty_RK.js +5 -0
  35. package/dist/aliases-BkVpehd-.js +96 -0
  36. package/dist/aliases-DWkJWJ5A.js +2 -0
  37. package/dist/api-CgW6fcU2.js +3 -0
  38. package/dist/api-DYPaGKUj.js +5 -0
  39. package/dist/api-DdoV90Cn.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-DUDpOwG7.js +439 -0
  43. package/dist/approval-native-runtime-KkmX9gwQ.js +729 -0
  44. package/dist/attempt-execution.runtime-CQkeVpDx.js +509 -0
  45. package/dist/attempt-execution.runtime.js +1 -1
  46. package/dist/attempt.prompt-helpers-MoT6VaD0.js +221 -0
  47. package/dist/attempt.tool-run-context-B53GhX-d.js +933 -0
  48. package/dist/audit-CvHcVVb-.js +939 -0
  49. package/dist/audit.runtime-C7n442Rc.js +7 -0
  50. package/dist/audit.runtime.js +1 -1
  51. package/dist/auth-CAnSldtM.js +2 -0
  52. package/dist/auth-Czf_o5iE.js +383 -0
  53. package/dist/auth-order-Cu9Vj7lA.js +96 -0
  54. package/dist/auth-order-q1IFw7L3.js +2 -0
  55. package/dist/bash-tools-BS4TrA4X.js +2824 -0
  56. package/dist/bash-tools-DbHYuk8O.js +3 -0
  57. package/dist/binding-routing-CnNQE65Q.js +85 -0
  58. package/dist/binding-targets-DW0ScIRI.js +121 -0
  59. package/dist/bridge-server-BGS08n2f.js +113 -0
  60. package/dist/browser-control-auth-DMlQOsyN.js +2 -0
  61. package/dist/browser-node-runtime-CF32scUO.js +12 -0
  62. package/dist/browser-profiles-CmER65eh.js +2 -0
  63. package/dist/browser-runtime-D73M9fg3.js +387 -0
  64. package/dist/browser-setup-tools-Cr0UI1rf.js +13 -0
  65. package/dist/build-BL7WirDF.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-Ckws4Nlw.js +3 -0
  70. package/dist/call-DkGNVvLy.js +331 -0
  71. package/dist/call.runtime-DfLBtAIr.js +2 -0
  72. package/dist/call.runtime.js +1 -1
  73. package/dist/capability-cli-tSqSJf2o.js +1401 -0
  74. package/dist/catchup-Dp2L1RcY.js +300 -0
  75. package/dist/channel-BIFp1GJd.js +1320 -0
  76. package/dist/channel-BZMzoXhw.js +840 -0
  77. package/dist/channel-BtPZ0i4g.js +297 -0
  78. package/dist/channel-DDd7xwLG.js +226 -0
  79. package/dist/channel-DLezQPqR.js +350 -0
  80. package/dist/channel-DcYHXn_7.js +1100 -0
  81. package/dist/channel-DzKtLfJj.js +1802 -0
  82. package/dist/channel-LlY18tI5.js +595 -0
  83. package/dist/channel-NjZviHcJ.js +1174 -0
  84. package/dist/channel-core-Cg1mFpva.js +5 -0
  85. package/dist/channel-inbound-CZpi-vp5.js +31 -0
  86. package/dist/channel-pDXIWFS4.js +453 -0
  87. package/dist/channel-plugin-runtime-DHl81Ror.js +771 -0
  88. package/dist/channel-runtime-CtYrrwow.js +425 -0
  89. package/dist/channel-wMkGGyIY.js +491 -0
  90. package/dist/channel.runtime-B1n0hvUI.js +430 -0
  91. package/dist/channel.runtime-B9iR26l_.js +576 -0
  92. package/dist/channel.runtime-C8eBQk67.js +4 -0
  93. package/dist/channel.runtime-Db8g8JCg.js +89 -0
  94. package/dist/channel.runtime-DfRfisV2.js +34702 -0
  95. package/dist/channel.runtime-gPdBMu3V.js +109 -0
  96. package/dist/channel.runtime-rG9pJ5NO.js +2364 -0
  97. package/dist/channel.runtime.js +1 -1
  98. package/dist/channel.setup-CWblUOhD.js +10 -0
  99. package/dist/channels-B4dYRKsI.js +733 -0
  100. package/dist/channels-cli-GMAOUYU3.js +268 -0
  101. package/dist/chat-D2XaZNiP.js +2758 -0
  102. package/dist/clawbot-cli-CSmdcIMT.js +9 -0
  103. package/dist/cli/daemon-cli.js +3 -3
  104. package/dist/cli-2u5IZTMS.js +219 -0
  105. package/dist/cli-Bk8uXnyc.js +72 -0
  106. package/dist/cli-DBfw9jCz.js +2 -0
  107. package/dist/cli-runner-BEqvX1ky.js +286 -0
  108. package/dist/cli-runner.runtime-BIUcUGDa.js +4 -0
  109. package/dist/cli-runner.runtime-D2u3Yw0W.js +3 -0
  110. package/dist/cli-runner.runtime.js +1 -1
  111. package/dist/cli-startup-metadata.json +2 -2
  112. package/dist/cli-waH8839u.js +2 -0
  113. package/dist/cli.runtime-mKvJpLwI.js +1261 -0
  114. package/dist/cli.runtime.js +1 -1
  115. package/dist/client-CKizOsGp.js +138 -0
  116. package/dist/client-CrPccv7a.js +713 -0
  117. package/dist/command-auth-DPkjKHdv.js +76 -0
  118. package/dist/command-config-resolution-BTjtnAp2.js +2 -0
  119. package/dist/command-config-resolution-Be3KZA_l.js +23 -0
  120. package/dist/command-config-resolution.runtime-DXgL8cm7.js +2 -0
  121. package/dist/command-config-resolution.runtime.js +1 -1
  122. package/dist/command-registry-BL1Z4Cen.js +4 -0
  123. package/dist/command-registry-BMePAw9w.js +9 -0
  124. package/dist/command-registry-core-CAay55-n.js +104 -0
  125. package/dist/command-secret-gateway-jj1Qmk9L.js +528 -0
  126. package/dist/command-status.runtime-BVcCm9_0.js +87 -0
  127. package/dist/command-status.runtime.js +1 -1
  128. package/dist/commands-acp-COdUW69f.js +77 -0
  129. package/dist/commands-compact.runtime-C0Fedews.js +10 -0
  130. package/dist/commands-compact.runtime.js +1 -1
  131. package/dist/commands-handlers.runtime-BXVM3PWG.js +4597 -0
  132. package/dist/commands-handlers.runtime.js +1 -1
  133. package/dist/commands-status-DaApOLoQ.js +16 -0
  134. package/dist/commands-status.runtime-CxSjrKne.js +3 -0
  135. package/dist/commands-status.runtime.js +1 -1
  136. package/dist/commands-subagents-control.runtime-BEfW44br.js +2 -0
  137. package/dist/commands-subagents-control.runtime-DB3AROHI.js +3 -0
  138. package/dist/commands-subagents-control.runtime.js +1 -1
  139. package/dist/commands-system-prompt-CCrUy7xq.js +158 -0
  140. package/dist/commands-system-prompt-CN56TtaC.js +2 -0
  141. package/dist/commands.runtime-Bee6dM3V.js +166 -0
  142. package/dist/commands.runtime.js +1 -1
  143. package/dist/compact-7YtEe1kG.js +1118 -0
  144. package/dist/compact.runtime-4gW_cs7D.js +12 -0
  145. package/dist/compact.runtime.js +1 -1
  146. package/dist/completion-cli-COv-r8_h.js +313 -0
  147. package/dist/config-DSsLlg8J.js +251 -0
  148. package/dist/config-cli-C9oGe9gl.js +1078 -0
  149. package/dist/configure-Bfy9tVmS.js +2 -0
  150. package/dist/configure-DpIFRaAD.js +1245 -0
  151. package/dist/connect-options-CPixzqP_.js +699 -0
  152. package/dist/control-auth-L7U2ivRJ.js +125 -0
  153. package/dist/control-service-CbUz8qU5.js +156 -0
  154. package/dist/conversation-id-BroDIGeT.js +38 -0
  155. package/dist/conversation-id-CuVi0tWe.js +235 -0
  156. package/dist/conversation-runtime-weaahZQN.js +31 -0
  157. package/dist/core-PXv1nsc-.js +275 -0
  158. package/dist/cron-cli-DZNSQBuA.js +713 -0
  159. package/dist/daemon-cli-C_9CNoZA.js +12 -0
  160. package/dist/delegate-B8wh-jjf.js +64 -0
  161. package/dist/detached-task-runtime-BTq-jIGw.js +73 -0
  162. package/dist/devices-cli-C_amY-AS.js +496 -0
  163. package/dist/diagnostics-Bw-fd0ug.js +154 -0
  164. package/dist/direct-dm-Dvqjch3O.js +64 -0
  165. package/dist/dispatch-DHPQS49Q.js +1131 -0
  166. package/dist/dispatch-acp-manager.runtime-y-oykPUz.js +3 -0
  167. package/dist/dispatch-acp-manager.runtime.js +1 -1
  168. package/dist/dispatch-acp-taSuJD5W.js +981 -0
  169. package/dist/dispatch-acp.runtime-DgyaFFNX.js +19 -0
  170. package/dist/dispatch-acp.runtime.js +1 -1
  171. package/dist/doctor-device-pairing-rxwogzYF.js +307 -0
  172. package/dist/doctor-gateway-daemon-flow-Dm4wxnTt.js +250 -0
  173. package/dist/doctor-gateway-health-wJVW5xUW.js +60 -0
  174. package/dist/doctor-health-DaodspKU.js +59 -0
  175. package/dist/doctor-health-contributions-CBVyN6ju.js +486 -0
  176. package/dist/doctor-prompter-vO6LPeXZ.js +56 -0
  177. package/dist/doctor-workspace-status-BnXA04-6.js +75 -0
  178. package/dist/dreaming-1RLie1iF.js +1574 -0
  179. package/dist/dreaming-narrative-BRtTdpbt.js +595 -0
  180. package/dist/embedded-gateway-stub.runtime-GMix51Tf.js +9 -0
  181. package/dist/embedded-gateway-stub.runtime.js +1 -1
  182. package/dist/entry.js +2 -2
  183. package/dist/exec-approvals-cli-R6jgupQH.js +498 -0
  184. package/dist/extensionAPI.js +1 -1
  185. package/dist/extensions/active-memory/index.js +1 -1
  186. package/dist/extensions/bluebubbles/api.js +3 -3
  187. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  188. package/dist/extensions/browser/browser-bridge.js +1 -1
  189. package/dist/extensions/browser/browser-config.js +4 -4
  190. package/dist/extensions/browser/browser-control-auth.js +2 -2
  191. package/dist/extensions/browser/browser-doctor.js +2 -2
  192. package/dist/extensions/browser/browser-maintenance.js +2 -2
  193. package/dist/extensions/browser/browser-profiles.js +2 -2
  194. package/dist/extensions/browser/browser-runtime-api.js +10 -10
  195. package/dist/extensions/browser/index.js +1 -1
  196. package/dist/extensions/browser/plugin-registration.js +1 -1
  197. package/dist/extensions/browser/register.runtime.js +3 -3
  198. package/dist/extensions/browser/runtime-api.js +11 -11
  199. package/dist/extensions/browser/test-support.js +1 -1
  200. package/dist/extensions/device-pair/api.js +1 -1
  201. package/dist/extensions/device-pair/index.js +3 -3
  202. package/dist/extensions/device-pair/notify.js +1 -1
  203. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  204. package/dist/extensions/google-meet/index.js +2 -2
  205. package/dist/extensions/imessage/api.js +3 -3
  206. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  207. package/dist/extensions/imessage/runtime-api.js +3 -3
  208. package/dist/extensions/irc/api.js +2 -2
  209. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  210. package/dist/extensions/line/api.js +2 -2
  211. package/dist/extensions/line/channel-plugin-api.js +1 -1
  212. package/dist/extensions/line/contract-api.js +1 -1
  213. package/dist/extensions/line/runtime-api.js +4 -4
  214. package/dist/extensions/line/setup-api.js +1 -1
  215. package/dist/extensions/llm-task/index.js +2 -2
  216. package/dist/extensions/lobster/index.js +3 -3
  217. package/dist/extensions/lobster/runtime-api.js +1 -1
  218. package/dist/extensions/mattermost/api.js +1 -1
  219. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  220. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  221. package/dist/extensions/mattermost/policy-api.js +1 -1
  222. package/dist/extensions/mattermost/runtime-api.js +4 -4
  223. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  224. package/dist/extensions/memory-core/api.js +1 -1
  225. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  226. package/dist/extensions/memory-core/index.js +3 -3
  227. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  228. package/dist/extensions/msteams/api.js +1 -1
  229. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  230. package/dist/extensions/msteams/runtime-api.js +3 -3
  231. package/dist/extensions/msteams/test-api.js +1 -1
  232. package/dist/extensions/nextcloud-talk/api.js +1 -1
  233. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  234. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  235. package/dist/extensions/openshell/index.js +2 -2
  236. package/dist/extensions/signal/api.js +6 -6
  237. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  238. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  239. package/dist/extensions/signal/runtime-api.js +7 -7
  240. package/dist/extensions/skill-workshop/api.js +1 -1
  241. package/dist/extensions/skill-workshop/index.js +1 -1
  242. package/dist/extensions/synology-chat/api.js +1 -1
  243. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  244. package/dist/extensions/tlon/api.js +2 -2
  245. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  246. package/dist/extensions/tlon/runtime-api.js +1 -1
  247. package/dist/extensions/tlon/test-api.js +1 -1
  248. package/dist/extensions/twitch/api.js +1 -1
  249. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  250. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  251. package/dist/extensions/zalo/api.js +3 -3
  252. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  253. package/dist/extensions/zalo/runtime-api.js +2 -2
  254. package/dist/extensions/zalo/setup-api.js +2 -2
  255. package/dist/extensions/zalouser/api.js +3 -3
  256. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  257. package/dist/extensions/zalouser/runtime-api.js +6 -6
  258. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  259. package/dist/extensions/zalouser/test-api.js +1 -1
  260. package/dist/fallbacks-Cckv3nng.js +2 -0
  261. package/dist/fallbacks-Y_nNY8_a.js +31 -0
  262. package/dist/fallbacks-shared-DZiG1Gr_.js +111 -0
  263. package/dist/gateway-CDfn0J87.js +115 -0
  264. package/dist/gateway-cli-D197U6l0.js +1325 -0
  265. package/dist/gateway-rpc-Bomz8HKq.js +14 -0
  266. package/dist/gateway-rpc.runtime-597tksmo.js +23 -0
  267. package/dist/gateway-rpc.runtime.js +1 -1
  268. package/dist/gateway-runtime-Bm2_MhFn.js +15 -0
  269. package/dist/gateway-status-Cr4UJKUx.js +584 -0
  270. package/dist/genesis-tools-DCRaVVjY.js +8999 -0
  271. package/dist/genesis-tools.runtime-idgd5fjy.js +2 -0
  272. package/dist/genesis-tools.runtime.js +1 -1
  273. package/dist/get-reply-BF_7bR5f.js +3879 -0
  274. package/dist/get-reply-from-config.runtime-DEq5XM_s.js +2 -0
  275. package/dist/get-reply-from-config.runtime.js +1 -1
  276. package/dist/graph-users-Bhlw-_4i.js +1337 -0
  277. package/dist/health-9ifMvGZN.js +3 -0
  278. package/dist/health-CzOJa6SX.js +469 -0
  279. package/dist/heartbeat-runner-B2Tkbj5e.js +5 -0
  280. package/dist/heartbeat-runner-B63G8dbO.js +1292 -0
  281. package/dist/heartbeat-runner.runtime-QJ_2AMjN.js +4 -0
  282. package/dist/heartbeat-runner.runtime.js +1 -1
  283. package/dist/hooks-cli-ZWI1iJnh.js +433 -0
  284. package/dist/image-fallbacks-BpTfBvbi.js +2 -0
  285. package/dist/image-fallbacks-DpVwnB41.js +31 -0
  286. package/dist/inbound-reply-dispatch-mKybIcNA.js +73 -0
  287. package/dist/index.js +2 -2
  288. package/dist/infra-runtime-CvwvzUfM.js +39 -0
  289. package/dist/init-CWeM0DfJ.js +59 -0
  290. package/dist/library-ClQalZ3x.js +45 -0
  291. package/dist/lifecycle-CgV7Cgt-.js +571 -0
  292. package/dist/lifecycle-DVWaxj-A.js +229 -0
  293. package/dist/lifecycle.runtime-DErLwVJ_.js +2 -0
  294. package/dist/lifecycle.runtime.js +1 -1
  295. package/dist/list-5RIS3LMG.js +2 -0
  296. package/dist/list-BNesYDN2.js +2 -0
  297. package/dist/list-Dk1hCKis.js +1201 -0
  298. package/dist/list-eUjt_6__.js +131 -0
  299. package/dist/list.probe-C51ceJSY.js +419 -0
  300. package/dist/llm-slug-generator-D64IMUoy.js +79 -0
  301. package/dist/llm-slug-generator.js +1 -1
  302. package/dist/load-config-Ccss2uTi.js +35 -0
  303. package/dist/local-dispatch.runtime-u7Ir1N07.js +8 -0
  304. package/dist/local-dispatch.runtime.js +1 -1
  305. package/dist/logs-cli-BYHTboPa.js +265 -0
  306. package/dist/logs-cli.runtime-CQwNptr-.js +2 -0
  307. package/dist/logs-cli.runtime.js +1 -1
  308. package/dist/main-session-restart-recovery-CA9bvC1W.js +206 -0
  309. package/dist/managed-image-attachments-B_gpkI1u.js +635 -0
  310. package/dist/managed-image-attachments-C0Y6nAP2.js +2 -0
  311. package/dist/manager-DZGFArgz.js +2 -0
  312. package/dist/manager-Df8TC4rX.js +2057 -0
  313. package/dist/markdown-to-line-xXLdnzcE.js +790 -0
  314. package/dist/mcp/plugin-tools-serve.js +1 -1
  315. package/dist/mcp-cli-B50W9Pkc.js +725 -0
  316. package/dist/mcp-http-BiUGVpJ4.js +529 -0
  317. package/dist/memory-core-host-runtime-cli-UgLo6ezC.js +9 -0
  318. package/dist/message-C95gttLd.js +232 -0
  319. package/dist/message-action-runner-0KAp6ccG.js +1407 -0
  320. package/dist/message-action-runner-BSUDvECO.js +2 -0
  321. package/dist/message-actions-Be4Ob151.js +143 -0
  322. package/dist/message.gateway.runtime-DMMRMIln.js +2 -0
  323. package/dist/message.gateway.runtime.js +1 -1
  324. package/dist/models-auth-status-DhYxBz7G.js +201 -0
  325. package/dist/models-cli-C2prinXb.js +219 -0
  326. package/dist/monitor-BEI21vNQ.js +1661 -0
  327. package/dist/monitor-BUgTAJvZ.js +1237 -0
  328. package/dist/monitor-BdJRIhi1.js +2 -0
  329. package/dist/monitor-C7wuttQJ.js +1459 -0
  330. package/dist/monitor-DMumiWnt.js +788 -0
  331. package/dist/monitor-IQo2ExmV.js +671 -0
  332. package/dist/monitor-auth-DW0lvfm3.js +207 -0
  333. package/dist/monitor-processing-DTrsRdyz.js +1974 -0
  334. package/dist/monitor.runtime-DwqyCQcb.js +2 -0
  335. package/dist/monitor.runtime.js +1 -1
  336. package/dist/monitor.webhook-D11nrUh9.js +180 -0
  337. package/dist/msteams-DO-PW98M.js +35 -0
  338. package/dist/native-hook-relay-CNZrcPIw.js +519 -0
  339. package/dist/nextcloud-talk-BeYFnATY.js +17 -0
  340. package/dist/node-cli-BFrdTPdH.js +2506 -0
  341. package/dist/nodes-cli-B3Wj_MvP.js +1046 -0
  342. package/dist/nodes-utils-AsgrCa7K.js +84 -0
  343. package/dist/nodes.helpers-CMXxavTs.js +34 -0
  344. package/dist/notify-CNS0kRWM.js +315 -0
  345. package/dist/onboard-D4ehf66t.js +632 -0
  346. package/dist/onboard-helpers-DWxdMyCs.js +6 -0
  347. package/dist/onboard-helpers-o78s0lR1.js +204 -0
  348. package/dist/onboard-remote-Cc1XlRzr.js +193 -0
  349. package/dist/onboard-remote-D8THwo3P.js +2 -0
  350. package/dist/onboard-skills-B2VoCq7v.js +134 -0
  351. package/dist/onboard-skills-DtOgSJZo.js +2 -0
  352. package/dist/openai-http-DKQZWsqY.js +500 -0
  353. package/dist/openresponses-http-C4kol41X.js +1128 -0
  354. package/dist/operator-approvals-client-BoN_VmkB.js +68 -0
  355. package/dist/outbound.runtime-D-L8FN8E.js +2 -0
  356. package/dist/outbound.runtime.js +1 -1
  357. package/dist/pair-command-approve-DMeQ6uD4.js +44 -0
  358. package/dist/persistent-bindings.lifecycle-O-RnoTW4.js +2 -0
  359. package/dist/persistent-bindings.lifecycle-bptWQEFT.js +85 -0
  360. package/dist/pi-embedded-BM79sXqb.js +2905 -0
  361. package/dist/pi-embedded-BUDWcDt8.js +4 -0
  362. package/dist/pi-embedded.runtime-D53bCPOr.js +4 -0
  363. package/dist/pi-embedded.runtime.js +1 -1
  364. package/dist/pi-tool-definition-adapter-DdYQtumi.js +217 -0
  365. package/dist/pi-tools-ihbjTP0K.js +1057 -0
  366. package/dist/pi-tools.before-tool-call-DrEqr96j.js +433 -0
  367. package/dist/pi-tools.before-tool-call-VB9YEPOv.js +2 -0
  368. package/dist/plugin-DwNULpmw.js +12195 -0
  369. package/dist/plugin-enabled-DbO9GyRJ.js +140 -0
  370. package/dist/plugin-registration-Du6hgUkp.js +23 -0
  371. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  372. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  373. package/dist/plugin-sdk/acp-runtime.js +2 -2
  374. package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
  375. package/dist/plugin-sdk/agent-harness.js +6 -6
  376. package/dist/plugin-sdk/agent-runtime.js +2 -2
  377. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  378. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  379. package/dist/plugin-sdk/approval-runtime.js +1 -1
  380. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  381. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  382. package/dist/plugin-sdk/browser-support.js +7 -7
  383. package/dist/plugin-sdk/channel-core.js +2 -2
  384. package/dist/plugin-sdk/channel-inbound.js +2 -2
  385. package/dist/plugin-sdk/command-auth.js +1 -1
  386. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  387. package/dist/plugin-sdk/compat.js +1 -1
  388. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  389. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  390. package/dist/plugin-sdk/core.js +2 -2
  391. package/dist/plugin-sdk/direct-dm.js +1 -1
  392. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  393. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  394. package/dist/plugin-sdk/index.js +1 -1
  395. package/dist/plugin-sdk/infra-runtime.js +2 -2
  396. package/dist/plugin-sdk/irc.js +2 -2
  397. package/dist/plugin-sdk/matrix.js +1 -1
  398. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  399. package/dist/plugin-sdk/memory-core.js +2 -2
  400. package/dist/plugin-sdk/msteams.js +2 -2
  401. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  402. package/dist/plugin-sdk/nostr.js +1 -1
  403. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  404. package/dist/plugin-sdk/reply-runtime.js +4 -4
  405. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  406. package/dist/plugin-sdk/runtime.js +2 -2
  407. package/dist/plugin-sdk/session-visibility.js +1 -1
  408. package/dist/plugin-sdk/testing.js +4 -4
  409. package/dist/plugin-sdk/tlon.js +1 -1
  410. package/dist/plugin-sdk/zalo.js +1 -1
  411. package/dist/plugin-sdk/zalouser.js +1 -1
  412. package/dist/plugin-service-DcSnRF5x.js +2890 -0
  413. package/dist/plugins/runtime/index.js +1 -1
  414. package/dist/policy-uc224usV.js +328 -0
  415. package/dist/postinstall-inventory.json +407 -407
  416. package/dist/prepare.runtime-BPA6jMiM.js +815 -0
  417. package/dist/prepare.runtime.js +1 -1
  418. package/dist/probe-5ToseFjd.js +1443 -0
  419. package/dist/probe-BdCXAH_u.js +2 -0
  420. package/dist/probe-ByVoZEdq.js +45 -0
  421. package/dist/probe-D-D_1oc4.js +241 -0
  422. package/dist/probe-D6s_1Z5k.js +2 -0
  423. package/dist/probe-DIMAmSsO.js +74 -0
  424. package/dist/probe-DYuL-s4A.js +2205 -0
  425. package/dist/program-DDTWTh6g.js +111 -0
  426. package/dist/prompt-select-styled-kf1dPqNa.js +20 -0
  427. package/dist/protocol-Batc2DmY.js +2234 -0
  428. package/dist/provider-dispatcher-DdUqCa6H.js +2 -0
  429. package/dist/provider-dispatcher-uioW38XW.js +22 -0
  430. package/dist/qr-cli-B1WUe8Eb.js +2 -0
  431. package/dist/qr-cli-DmPti3xe.js +349 -0
  432. package/dist/reaction-runtime-api-5G3e9J0C.js +116 -0
  433. package/dist/reactions-x7VH-B95.js +998 -0
  434. package/dist/register-service-commands-DcW5qPTu.js +71 -0
  435. package/dist/register.agent-Dtj4HC7R.js +248 -0
  436. package/dist/register.configure-CJHb84Ce.js +15 -0
  437. package/dist/register.maintenance-BUkPfMcX.js +438 -0
  438. package/dist/register.message-DGFpyYBl.js +329 -0
  439. package/dist/register.onboard-D3v3xIfF.js +81 -0
  440. package/dist/register.runtime-DI4QxYdj.js +81 -0
  441. package/dist/register.runtime.js +1 -1
  442. package/dist/register.setup-CXTyuIFM.js +150 -0
  443. package/dist/register.status-health-sessions-CYUnRi97.js +1215 -0
  444. package/dist/register.subclis-DKMVrwRc.js +3 -0
  445. package/dist/register.subclis-NWRi2XKp.js +29 -0
  446. package/dist/register.subclis-core-De6qmQkr.js +243 -0
  447. package/dist/reply-dispatch-runtime-B8_j6pJi.js +13 -0
  448. package/dist/reply-runtime-DGHQDC9d.js +11 -0
  449. package/dist/reply.runtime-BCfqw2Co.js +2 -0
  450. package/dist/reply.runtime.js +1 -1
  451. package/dist/restart-health-6cjrRBpF.js +202 -0
  452. package/dist/restart-health-b6Qw43Tj.js +2 -0
  453. package/dist/root-help-BTIH_eUe.js +44 -0
  454. package/dist/routes-C3J2GfHR.js +3341 -0
  455. package/dist/routes-SMmfW6k8.js +2 -0
  456. package/dist/rpc-DQbAcIKu.js +61 -0
  457. package/dist/rpc.runtime-Q3qyofLf.js +21 -0
  458. package/dist/rpc.runtime.js +1 -1
  459. package/dist/run-delivery.runtime-BsLouK3f.js +530 -0
  460. package/dist/run-delivery.runtime.js +1 -1
  461. package/dist/run-embedded.runtime-CXd0oZQP.js +4 -0
  462. package/dist/run-embedded.runtime.js +1 -1
  463. package/dist/run-execution-cli.runtime-D-MKbq8r.js +4 -0
  464. package/dist/run-execution-cli.runtime.js +1 -1
  465. package/dist/run-executor.runtime-Cz0I8mDt.js +277 -0
  466. package/dist/run-executor.runtime.js +1 -1
  467. package/dist/run-main-CkXBTQut.js +516 -0
  468. package/dist/run-subagent-registry.runtime-Cyb8amrH.js +2 -0
  469. package/dist/run-subagent-registry.runtime.js +1 -1
  470. package/dist/run-wait-KlS0pdIK.js +135 -0
  471. package/dist/runtime-3niXLiFY.js +9 -0
  472. package/dist/runtime-api-B79e2jL2.js +4 -0
  473. package/dist/runtime-api-CM2c2bSC.js +9 -0
  474. package/dist/runtime-api-CnOFFN5q.js +14 -0
  475. package/dist/runtime-api-TnwM-EZH.js +9 -0
  476. package/dist/runtime-embedded-pi.runtime-9csGjukF.js +2 -0
  477. package/dist/runtime-embedded-pi.runtime.js +1 -1
  478. package/dist/runtime-internal-CQX4Zehn.js +2 -0
  479. package/dist/runtime-options-C0qP2VlT.js +275 -0
  480. package/dist/runtime-schema-DanWbDoL.js +27780 -0
  481. package/dist/runtime-vycfMfew.js +973 -0
  482. package/dist/scan-Bs5zROOQ.js +2 -0
  483. package/dist/scan-CP2zJb_w.js +523 -0
  484. package/dist/secrets-cli-YFTlIMmq.js +2101 -0
  485. package/dist/security-cli-B2WBRU9C.js +486 -0
  486. package/dist/selection-DSZGsU6m.js +2 -0
  487. package/dist/selection-hUGDnCgX.js +7736 -0
  488. package/dist/send-B3Ygb3r3.js +156 -0
  489. package/dist/send-DMwqnu6K.js +102 -0
  490. package/dist/send.runtime-D86atcfW.js +2 -0
  491. package/dist/send.runtime.js +1 -1
  492. package/dist/server-4gQCBM3M.js +77 -0
  493. package/dist/server-CK9eCPCG.js +13 -0
  494. package/dist/server-context-ih3GaGaI.js +847 -0
  495. package/dist/server-context-kZ_QADic.js +2 -0
  496. package/dist/server-node-events-CMlHOIKa.js +481 -0
  497. package/dist/server-plugin-bootstrap-B0XitldT.js +11333 -0
  498. package/dist/server-plugin-bootstrap-CHlVF8XB.js +2 -0
  499. package/dist/server-restart-sentinel-TpXCoiYX.js +697 -0
  500. package/dist/server.impl-B6at3Orl.js +12734 -0
  501. package/dist/session-kill-http-DvYp5h-j.js +110 -0
  502. package/dist/session-reset-service-C9rIVqF7.js +471 -0
  503. package/dist/session-route-FaMcEc7I.js +93 -0
  504. package/dist/session-status.runtime-BfPn8qA8.js +2 -0
  505. package/dist/session-status.runtime.js +1 -1
  506. package/dist/session-subagent-reactivation.runtime-C1fGNaiM.js +2 -0
  507. package/dist/session-subagent-reactivation.runtime.js +1 -1
  508. package/dist/session-tab-registry-BDK2AlxL.js +491 -0
  509. package/dist/session-visibility-BkrL2kFF.js +147 -0
  510. package/dist/sessions-helpers-YOu_5tl0.js +304 -0
  511. package/dist/sessions-history-http-DxNaoDfb.js +383 -0
  512. package/dist/sessions-patch-BPtlF0Lu.js +309 -0
  513. package/dist/sessions-resolve-B2rpvSka.js +174 -0
  514. package/dist/sessions.runtime-DEk_x65_.js +2 -0
  515. package/dist/sessions.runtime.js +1 -1
  516. package/dist/setup-DZJZF2R6.js +495 -0
  517. package/dist/setup-api-BkYWhB-B.js +29 -0
  518. package/dist/setup-core-BXBabSEx.js +171 -0
  519. package/dist/setup-core-eahC1DXh.js +176 -0
  520. package/dist/setup-surface-BEf8reey.js +286 -0
  521. package/dist/setup-surface-DAOKJ-ai.js +219 -0
  522. package/dist/setup-surface-b6gu0S8l.js +403 -0
  523. package/dist/setup.finalize-DXUCLT5O.js +539 -0
  524. package/dist/setup.gateway-config-BH4xbjcX.js +250 -0
  525. package/dist/shared-BhHdyXun.js +198 -0
  526. package/dist/shared-CKv38qsN.js +121 -0
  527. package/dist/shared-DUw9Q4Lf.js +76 -0
  528. package/dist/slash-state-BQgmhum1.js +1911 -0
  529. package/dist/src-C1B3uJMu.js +3974 -0
  530. package/dist/startup-context-DTpThe3H.js +312 -0
  531. package/dist/status-63GZxfe4.js +2 -0
  532. package/dist/status-C6qTe-QQ.js +397 -0
  533. package/dist/status-CSIGAUly.js +190 -0
  534. package/dist/status-DOW91Kcx.js +2 -0
  535. package/dist/status-all-7hqTcvxr.js +498 -0
  536. package/dist/status-json-CUzzv8An.js +14 -0
  537. package/dist/status-json-command-DwWlqvoV.js +84 -0
  538. package/dist/status-p4yx6E3C.js +209 -0
  539. package/dist/status-runtime-shared-yrzbsOR8.js +257 -0
  540. package/dist/status-subagents.runtime-CuRGoNNn.js +18 -0
  541. package/dist/status-subagents.runtime.js +1 -1
  542. package/dist/status-text-BrcRsCFE.js +237 -0
  543. package/dist/status-zV1BflCE.js +3 -0
  544. package/dist/status.gateway-connection.runtime-BKd4Zivg.js +2 -0
  545. package/dist/status.gateway-connection.runtime.js +1 -1
  546. package/dist/status.gather-B7WlHpIR.js +292 -0
  547. package/dist/status.gather-Ccewg4ce.js +2 -0
  548. package/dist/status.runtime-BFru2C4v.js +2 -0
  549. package/dist/status.runtime.js +1 -1
  550. package/dist/status.scan-mEKnAmP3.js +65 -0
  551. package/dist/status.scan-overview-B0qQVJd0.js +379 -0
  552. package/dist/status.scan.fast-json-CsU-fWhj.js +132 -0
  553. package/dist/status.scan.fast-json-tEc36TAC.js +2 -0
  554. package/dist/status.summary-Bvgry977.js +214 -0
  555. package/dist/status.summary-DRolowE_.js +2 -0
  556. package/dist/subagent-announce-Bhe55Ktf.js +351 -0
  557. package/dist/subagent-announce-delivery-NDBIRwuZ.js +726 -0
  558. package/dist/subagent-announce-output-DsmGO7Oi.js +364 -0
  559. package/dist/subagent-control-Bn8n-535.js +506 -0
  560. package/dist/subagent-followup.runtime-C7s-lOGN.js +68 -0
  561. package/dist/subagent-followup.runtime.js +1 -1
  562. package/dist/subagent-orphan-recovery-CJEhSvFZ.js +305 -0
  563. package/dist/subagent-registry-BgQA8eP1.js +1753 -0
  564. package/dist/subagent-registry-DAm-N9-O.js +3 -0
  565. package/dist/subagent-registry.runtime.js +1 -1
  566. package/dist/subagent-spawn-EXtecXVT.js +1005 -0
  567. package/dist/system-cli-CFS_PN8R.js +59 -0
  568. package/dist/targets-BXWH2MfM.js +67 -0
  569. package/dist/task-executor-DfugjJEq.js +360 -0
  570. package/dist/task-owner-access-CSwIy-v-.js +74 -0
  571. package/dist/task-registry-B-kQGKt_.js +2366 -0
  572. package/dist/task-registry-delivery-runtime-DD1_7xUF.js +3 -0
  573. package/dist/task-registry-delivery-runtime-DIsasFa1.js +2 -0
  574. package/dist/task-registry.maintenance-CxAx195T.js +2 -0
  575. package/dist/task-registry.maintenance-DIFuNnzy.js +416 -0
  576. package/dist/telegram/token.js +1 -1
  577. package/dist/testing-C7oUBiZL.js +575 -0
  578. package/dist/text-report-hYiQ_Kcv.js +587 -0
  579. package/dist/tool-resolution-CnnOHyxg.js +90 -0
  580. package/dist/tools-effective-inventory-DqYXIS6R.js +152 -0
  581. package/dist/tools-invoke-http-zop5qWa_.js +206 -0
  582. package/dist/trash-DZRlsk_R.js +24 -0
  583. package/dist/tui-cli-2cKXF0J8.js +4575 -0
  584. package/dist/update-cli-DP1KXasM.js +1759 -0
  585. package/dist/upgrade-DPFxH2YB.js +1226 -0
  586. package/dist/video-generation-task-status-BEgeadFu.js +163 -0
  587. package/dist/wait-for-idle-before-flush-CmSNfAco.js +5986 -0
  588. package/dist/wizard-models-BJGn0RnU.js +161 -0
  589. package/package.json +1 -1
  590. package/dist/abort-ca8hDmJr.js +0 -201
  591. package/dist/abort.runtime-BrChEuUS.js +0 -2
  592. package/dist/accounts-C1ECKXaw.js +0 -107
  593. package/dist/accounts-DH8HU_Fu.js +0 -104
  594. package/dist/accounts-DWQpG06j.js +0 -2
  595. package/dist/acp-cli-BLpWVnc7.js +0 -2193
  596. package/dist/acp-spawn-D1p6b1gk.js +0 -2
  597. package/dist/acp-spawn-qoyl9NiU.js +0 -1093
  598. package/dist/acp-stateful-target-driver-NL9txhIM.js +0 -89
  599. package/dist/action-agents-C729fJ_P.js +0 -67
  600. package/dist/action-focus-53k9XP4K.js +0 -132
  601. package/dist/action-help-bIJZBYLz.js +0 -7
  602. package/dist/action-info-BBzvYFX_.js +0 -101
  603. package/dist/action-kill-C4fa3E9I.js +0 -33
  604. package/dist/action-list-BEiIbwP1.js +0 -21
  605. package/dist/action-log-Cq7RLW2T.js +0 -30
  606. package/dist/action-send-DyiHgRwh.js +0 -39
  607. package/dist/action-spawn-CEZfDvXU.js +0 -47
  608. package/dist/action-unfocus-CpAw3JOi.js +0 -29
  609. package/dist/actions.runtime-BKEwPyo7.js +0 -18
  610. package/dist/actions.runtime-Bp0UusIf.js +0 -5
  611. package/dist/agent-C2hwJefQ.js +0 -2
  612. package/dist/agent-command-BAAeGRql.js +0 -874
  613. package/dist/agent-harness-runtime-Czrx53YL.js +0 -144
  614. package/dist/agent-runner-utils-DzShckNa.js +0 -239
  615. package/dist/agent-runner.runtime-d_EtNxBK.js +0 -3455
  616. package/dist/agent-runtime-DNgz7AOP.js +0 -18
  617. package/dist/agents-CZmpon7q.js +0 -5
  618. package/dist/agents-Cs9je_gQ.js +0 -953
  619. package/dist/aliases-CZemdpTj.js +0 -2
  620. package/dist/aliases-KefnmoaT.js +0 -96
  621. package/dist/api-CO05iXNH.js +0 -139
  622. package/dist/api-CyjlApHT.js +0 -3
  623. package/dist/api-DArm1ECd.js +0 -5
  624. package/dist/approval-gateway-resolver-URpDQMld.js +0 -29
  625. package/dist/approval-gateway-runtime-B087BMms.js +0 -2
  626. package/dist/approval-handler-runtime-BgRQnG4g.js +0 -439
  627. package/dist/approval-native-runtime-DAsraihr.js +0 -729
  628. package/dist/attempt-execution.runtime-D_FGkDQz.js +0 -509
  629. package/dist/attempt.prompt-helpers-CDzDUi1C.js +0 -221
  630. package/dist/attempt.tool-run-context-DitxaTPJ.js +0 -933
  631. package/dist/audit-Bq8vlxok.js +0 -939
  632. package/dist/audit.runtime-CU42yh1v.js +0 -7
  633. package/dist/auth-CQfwC-AH.js +0 -383
  634. package/dist/auth-DyWcaG4X.js +0 -2
  635. package/dist/auth-order-C3zGI0s9.js +0 -96
  636. package/dist/auth-order-XQ9ZGPd9.js +0 -2
  637. package/dist/bash-tools-BBRtIa6j.js +0 -2824
  638. package/dist/bash-tools-BI0d1TdC.js +0 -3
  639. package/dist/binding-routing-Cvm5c1IV.js +0 -85
  640. package/dist/binding-targets-DSs4NXbd.js +0 -121
  641. package/dist/bridge-server-CwWzSgv8.js +0 -113
  642. package/dist/browser-control-auth-y1f-9HRI.js +0 -2
  643. package/dist/browser-node-runtime-3UAeP8a6.js +0 -12
  644. package/dist/browser-profiles-BzzxphNW.js +0 -2
  645. package/dist/browser-runtime-jj11LR-E.js +0 -387
  646. package/dist/browser-setup-tools-CFB52yQc.js +0 -13
  647. package/dist/build-TlobwpQW.js +0 -550
  648. package/dist/call-Bx8lENb2.js +0 -3
  649. package/dist/call-jYRpeAWm.js +0 -331
  650. package/dist/call.runtime-BRluUZbD.js +0 -2
  651. package/dist/capability-cli-Iyj9Zi3g.js +0 -1401
  652. package/dist/catchup-CtxTwzY8.js +0 -300
  653. package/dist/channel-BJKHBfnq.js +0 -491
  654. package/dist/channel-BNNnYzwK.js +0 -1100
  655. package/dist/channel-BXS-Hd8p.js +0 -226
  656. package/dist/channel-C4XWpowe.js +0 -1174
  657. package/dist/channel-CJQdQgPr.js +0 -840
  658. package/dist/channel-C_zWAu4D.js +0 -595
  659. package/dist/channel-CtGzrF-K.js +0 -1802
  660. package/dist/channel-O9DE4IIq.js +0 -350
  661. package/dist/channel-WHUOtJme.js +0 -297
  662. package/dist/channel-WoDWDxqx.js +0 -1320
  663. package/dist/channel-core-BJjq9SOq.js +0 -5
  664. package/dist/channel-inbound-DLs-YfUs.js +0 -31
  665. package/dist/channel-plugin-runtime-CMG8ac2K.js +0 -771
  666. package/dist/channel-runtime-4UjeDmDI.js +0 -425
  667. package/dist/channel-ys2FFqi1.js +0 -453
  668. package/dist/channel.runtime-B38Ky3R9.js +0 -109
  669. package/dist/channel.runtime-Bl8WYZvF.js +0 -576
  670. package/dist/channel.runtime-D3kAsCsR.js +0 -89
  671. package/dist/channel.runtime-DEQ-anMf.js +0 -2364
  672. package/dist/channel.runtime-DG-EUnSC.js +0 -4
  673. package/dist/channel.runtime-IfV1Md6p.js +0 -430
  674. package/dist/channel.runtime-w1tHjTOa.js +0 -34702
  675. package/dist/channel.setup-dXwiMlyi.js +0 -10
  676. package/dist/channels-B2G1Y-iD.js +0 -733
  677. package/dist/channels-cli-YintLKAt.js +0 -268
  678. package/dist/chat-DdKbu8CA.js +0 -2758
  679. package/dist/clawbot-cli-CnHERFYk.js +0 -9
  680. package/dist/cli-CSNAd6Sz.js +0 -72
  681. package/dist/cli-CdRioBfN.js +0 -2
  682. package/dist/cli-DMPwqYqc.js +0 -219
  683. package/dist/cli-ctyAqh0j.js +0 -2
  684. package/dist/cli-runner-CNlk7xmx.js +0 -286
  685. package/dist/cli-runner.runtime-BK4sQk1m.js +0 -3
  686. package/dist/cli-runner.runtime-BT8ZZn-R.js +0 -4
  687. package/dist/cli.runtime-DU7swpBI.js +0 -1261
  688. package/dist/client-CQdcTPUf.js +0 -138
  689. package/dist/client-Vx7pseEY.js +0 -713
  690. package/dist/command-auth-DkJWb2HE.js +0 -76
  691. package/dist/command-config-resolution-CIRWRfR8.js +0 -23
  692. package/dist/command-config-resolution-DYZWj6Zm.js +0 -2
  693. package/dist/command-config-resolution.runtime-CUtVJOf0.js +0 -2
  694. package/dist/command-registry-CHy5EH0v.js +0 -4
  695. package/dist/command-registry-CyKgELQP.js +0 -9
  696. package/dist/command-registry-core-DQeRIuot.js +0 -104
  697. package/dist/command-secret-gateway-BNnWdAlq.js +0 -528
  698. package/dist/command-status.runtime-CKgimR6Y.js +0 -87
  699. package/dist/commands-acp-DSm97O5v.js +0 -77
  700. package/dist/commands-compact.runtime-BXhP6WJ6.js +0 -10
  701. package/dist/commands-handlers.runtime-FzK-n0L8.js +0 -4597
  702. package/dist/commands-status-BQnB5OSX.js +0 -16
  703. package/dist/commands-status.runtime-B6GcfEDm.js +0 -3
  704. package/dist/commands-subagents-control.runtime-CByd528A.js +0 -2
  705. package/dist/commands-subagents-control.runtime-CqI4LMYa.js +0 -3
  706. package/dist/commands-system-prompt-BD_LeeZk.js +0 -2
  707. package/dist/commands-system-prompt-C2Md_Ia1.js +0 -158
  708. package/dist/commands.runtime-CwiPf7Cc.js +0 -166
  709. package/dist/compact-B_4bMVpw.js +0 -1118
  710. package/dist/compact.runtime-BhRqiBXG.js +0 -12
  711. package/dist/completion-cli-D07hGGMI.js +0 -313
  712. package/dist/config-B1lvYOd7.js +0 -251
  713. package/dist/config-cli-BgepNwob.js +0 -1078
  714. package/dist/configure-CEfl0ORM.js +0 -2
  715. package/dist/configure-TsykzQqM.js +0 -1245
  716. package/dist/connect-options-zqTIEl6K.js +0 -699
  717. package/dist/control-auth-CNa_KHpo.js +0 -125
  718. package/dist/control-service-CZl5wFdZ.js +0 -156
  719. package/dist/conversation-id-BLY9ffjm.js +0 -38
  720. package/dist/conversation-id-DVeOM5Jh.js +0 -235
  721. package/dist/conversation-runtime-gJt7AAg2.js +0 -31
  722. package/dist/core-BtmNtOpS.js +0 -275
  723. package/dist/cron-cli-s9SF4__G.js +0 -713
  724. package/dist/daemon-cli-TCubZfI_.js +0 -12
  725. package/dist/delegate-DyITI93V.js +0 -64
  726. package/dist/detached-task-runtime-CTUQj84i.js +0 -73
  727. package/dist/devices-cli-SXcLjGmh.js +0 -496
  728. package/dist/diagnostics-waSemGnZ.js +0 -154
  729. package/dist/direct-dm-CiSjkmkL.js +0 -64
  730. package/dist/dispatch-BnQSIx2G.js +0 -1131
  731. package/dist/dispatch-acp-CaNQyl2L.js +0 -981
  732. package/dist/dispatch-acp-manager.runtime-DJK1eHYX.js +0 -3
  733. package/dist/dispatch-acp.runtime-Bl5cvtX4.js +0 -19
  734. package/dist/doctor-device-pairing-DBhEA-8G.js +0 -307
  735. package/dist/doctor-gateway-daemon-flow-Ds47Er3Y.js +0 -250
  736. package/dist/doctor-gateway-health-EWwTw5JR.js +0 -60
  737. package/dist/doctor-health-C6muRn7t.js +0 -59
  738. package/dist/doctor-health-contributions-B984415a.js +0 -486
  739. package/dist/doctor-prompter-BpOi4ndi.js +0 -56
  740. package/dist/doctor-workspace-status-CiEWZXrx.js +0 -75
  741. package/dist/dreaming-DFPenC85.js +0 -1574
  742. package/dist/dreaming-narrative-6A27_Gft.js +0 -595
  743. package/dist/embedded-gateway-stub.runtime-UVgfXZzk.js +0 -9
  744. package/dist/exec-approvals-cli-Cc_GG9ZT.js +0 -498
  745. package/dist/fallbacks-DX4YcmAx.js +0 -2
  746. package/dist/fallbacks-inTaaG-m.js +0 -31
  747. package/dist/fallbacks-shared-ow1la-U2.js +0 -111
  748. package/dist/gateway-D4iWwu3_.js +0 -115
  749. package/dist/gateway-cli-D6j0Aj3R.js +0 -1325
  750. package/dist/gateway-rpc-Dd_x2GX5.js +0 -14
  751. package/dist/gateway-rpc.runtime-Btnvsv-7.js +0 -23
  752. package/dist/gateway-runtime-DctMRv_p.js +0 -15
  753. package/dist/gateway-status-DJCtvUVn.js +0 -584
  754. package/dist/genesis-tools-CvMcpUvH.js +0 -8999
  755. package/dist/genesis-tools.runtime-Ch3NDEDq.js +0 -2
  756. package/dist/get-reply-Cm39MCyU.js +0 -3879
  757. package/dist/get-reply-from-config.runtime-CSqCYatb.js +0 -2
  758. package/dist/graph-users-BJxYqA3A.js +0 -1337
  759. package/dist/health-C14jIilQ.js +0 -469
  760. package/dist/health-C6yJSCMc.js +0 -3
  761. package/dist/heartbeat-runner-C6-gFnyC.js +0 -5
  762. package/dist/heartbeat-runner-yUYjgzIM.js +0 -1292
  763. package/dist/heartbeat-runner.runtime-DZzyrUNB.js +0 -4
  764. package/dist/hooks-cli-CCRaHheu.js +0 -433
  765. package/dist/image-fallbacks-BH9qLbBG.js +0 -31
  766. package/dist/image-fallbacks-DUOPO1ic.js +0 -2
  767. package/dist/inbound-reply-dispatch-DPf_IrbV.js +0 -73
  768. package/dist/infra-runtime-CLND6LJ0.js +0 -39
  769. package/dist/init-CzWob-9v.js +0 -59
  770. package/dist/library-C0a9Bz2M.js +0 -45
  771. package/dist/lifecycle-B_B_jt3r.js +0 -571
  772. package/dist/lifecycle-DuqKKZop.js +0 -229
  773. package/dist/lifecycle.runtime-DoosWTnK.js +0 -2
  774. package/dist/list-Bly8XeOF.js +0 -2
  775. package/dist/list-C5HvtbwZ.js +0 -2
  776. package/dist/list-CHIiamt1.js +0 -131
  777. package/dist/list-CMmJiacX.js +0 -1201
  778. package/dist/list.probe-kmHRFlrP.js +0 -419
  779. package/dist/llm-slug-generator-C3u6Ptgq.js +0 -79
  780. package/dist/load-config-CXvIGI7N.js +0 -35
  781. package/dist/local-dispatch.runtime-BNQF4rqW.js +0 -8
  782. package/dist/logs-cli-DEy1GPk2.js +0 -265
  783. package/dist/logs-cli.runtime-jWShKzQC.js +0 -2
  784. package/dist/main-session-restart-recovery-CzfY6Cd8.js +0 -206
  785. package/dist/managed-image-attachments-BGPKA7Mn.js +0 -2
  786. package/dist/managed-image-attachments-CTrq9ym-.js +0 -635
  787. package/dist/manager-C_ZGa9x8.js +0 -2057
  788. package/dist/manager-DIHLRzYF.js +0 -2
  789. package/dist/markdown-to-line-CRbbXtJK.js +0 -790
  790. package/dist/mcp-cli-FMJb3T4k.js +0 -725
  791. package/dist/mcp-http-b6UMoE_J.js +0 -529
  792. package/dist/memory-core-host-runtime-cli-CquxELNj.js +0 -9
  793. package/dist/message-CmjuvIFf.js +0 -232
  794. package/dist/message-action-runner-CiY3rhqt.js +0 -1407
  795. package/dist/message-action-runner-Do4P0h5i.js +0 -2
  796. package/dist/message-actions-BYREqFJA.js +0 -143
  797. package/dist/message.gateway.runtime-gkoWzaYV.js +0 -2
  798. package/dist/models-auth-status-B_Pcr0tl.js +0 -201
  799. package/dist/models-cli-BZSuW2gw.js +0 -219
  800. package/dist/monitor-22LY8y6z.js +0 -788
  801. package/dist/monitor-BZdf_CEm.js +0 -1237
  802. package/dist/monitor-CTVDlTs2.js +0 -671
  803. package/dist/monitor-Cfv-KGAl.js +0 -1661
  804. package/dist/monitor-DuA69-8E.js +0 -2
  805. package/dist/monitor-auth-BNDlfcw7.js +0 -207
  806. package/dist/monitor-cmWeDVxf.js +0 -1459
  807. package/dist/monitor-processing-D9Xcsagt.js +0 -1974
  808. package/dist/monitor.runtime-zWvcbNim.js +0 -2
  809. package/dist/monitor.webhook-BYWQa5lY.js +0 -180
  810. package/dist/msteams-n9HDT4O-.js +0 -35
  811. package/dist/native-hook-relay-CKyIfLOm.js +0 -519
  812. package/dist/nextcloud-talk-BuJVVP0J.js +0 -17
  813. package/dist/node-cli-DBK2TIEH.js +0 -2506
  814. package/dist/nodes-cli-D5Y1_ZVD.js +0 -1046
  815. package/dist/nodes-utils-C6IKaTjm.js +0 -84
  816. package/dist/nodes.helpers-CkJO5i0d.js +0 -34
  817. package/dist/notify-v0zoiI-O.js +0 -315
  818. package/dist/onboard-BCaLBJor.js +0 -632
  819. package/dist/onboard-helpers-Ba7ES7kB.js +0 -204
  820. package/dist/onboard-helpers-D5qdyBIj.js +0 -6
  821. package/dist/onboard-remote-BaHm_VrY.js +0 -2
  822. package/dist/onboard-remote-DbGAo_Ad.js +0 -193
  823. package/dist/onboard-skills-BA7c4li1.js +0 -2
  824. package/dist/onboard-skills-upyHp6T9.js +0 -134
  825. package/dist/openai-http-DwCqhEcX.js +0 -500
  826. package/dist/openresponses-http-tJr67vC1.js +0 -1128
  827. package/dist/operator-approvals-client-C0t_-2xC.js +0 -68
  828. package/dist/outbound.runtime-nXA4k1xA.js +0 -2
  829. package/dist/pair-command-approve-G5y-rKn9.js +0 -44
  830. package/dist/persistent-bindings.lifecycle-C56aKBVc.js +0 -2
  831. package/dist/persistent-bindings.lifecycle-CfBqvz9L.js +0 -85
  832. package/dist/pi-embedded-B1wvxHXL.js +0 -2905
  833. package/dist/pi-embedded-DmDb-oUB.js +0 -4
  834. package/dist/pi-embedded.runtime-D5xqw9Ko.js +0 -4
  835. package/dist/pi-tool-definition-adapter-CAxlo-Va.js +0 -217
  836. package/dist/pi-tools-C69yvznf.js +0 -1057
  837. package/dist/pi-tools.before-tool-call-BDeCmoAy.js +0 -2
  838. package/dist/pi-tools.before-tool-call-DG7VVNBn.js +0 -433
  839. package/dist/plugin-B9Ld0CUs.js +0 -12195
  840. package/dist/plugin-enabled-BguUplCN.js +0 -140
  841. package/dist/plugin-registration-DPBnSoak.js +0 -23
  842. package/dist/plugin-service-CdNFnRyN.js +0 -2890
  843. package/dist/policy-DgfegT_Y.js +0 -328
  844. package/dist/prepare.runtime-C_sRmuFC.js +0 -815
  845. package/dist/probe-8vb_Ssot.js +0 -45
  846. package/dist/probe-BjmKFiz1.js +0 -2205
  847. package/dist/probe-CVlOo8Hr.js +0 -74
  848. package/dist/probe-CakOsrSu.js +0 -241
  849. package/dist/probe-CbOoVumf.js +0 -2
  850. package/dist/probe-D6yFcZpK.js +0 -1443
  851. package/dist/probe-OcOYm1bj.js +0 -2
  852. package/dist/program-BJnTb7UE.js +0 -111
  853. package/dist/prompt-select-styled-C8kGHNpY.js +0 -20
  854. package/dist/protocol-C40iRm9c.js +0 -2234
  855. package/dist/provider-dispatcher-BIOPYzb9.js +0 -2
  856. package/dist/provider-dispatcher-CpwviX0O.js +0 -22
  857. package/dist/qr-cli-CJXKCj0L.js +0 -2
  858. package/dist/qr-cli-kSU9X-N0.js +0 -349
  859. package/dist/reaction-runtime-api-3XFmruJA.js +0 -116
  860. package/dist/reactions-By-nqZC6.js +0 -998
  861. package/dist/register-service-commands-fwB-T6mW.js +0 -71
  862. package/dist/register.agent-CpScU3CV.js +0 -248
  863. package/dist/register.configure-DpD3_BCK.js +0 -15
  864. package/dist/register.maintenance-ByoQXpk9.js +0 -438
  865. package/dist/register.message-BTXNOZMD.js +0 -329
  866. package/dist/register.onboard-B83CAOYy.js +0 -81
  867. package/dist/register.runtime-Doz01zcH.js +0 -81
  868. package/dist/register.setup-BKI5rwWy.js +0 -150
  869. package/dist/register.status-health-sessions-DRPszDQ-.js +0 -1215
  870. package/dist/register.subclis-DeXklyQL.js +0 -3
  871. package/dist/register.subclis-YkmoZoxl.js +0 -29
  872. package/dist/register.subclis-core-BPo4hV1Q.js +0 -243
  873. package/dist/reply-dispatch-runtime-DjIuN_dr.js +0 -13
  874. package/dist/reply-runtime-5TFidLR3.js +0 -11
  875. package/dist/reply.runtime-6d1e0INl.js +0 -2
  876. package/dist/restart-health-BWUPc4R-.js +0 -202
  877. package/dist/restart-health-CWvsjHVN.js +0 -2
  878. package/dist/root-help-D2YiFpS6.js +0 -44
  879. package/dist/routes-BdYdVpe7.js +0 -3341
  880. package/dist/routes-jYoN_qOU.js +0 -2
  881. package/dist/rpc-5tMjebZH.js +0 -61
  882. package/dist/rpc.runtime-BzAHjcm4.js +0 -21
  883. package/dist/run-delivery.runtime-qZIB76oE.js +0 -530
  884. package/dist/run-embedded.runtime-nHunVmCv.js +0 -4
  885. package/dist/run-execution-cli.runtime-CMT7La6D.js +0 -4
  886. package/dist/run-executor.runtime-BG6SDi3f.js +0 -277
  887. package/dist/run-main-CNf_LLX7.js +0 -516
  888. package/dist/run-subagent-registry.runtime-D0RcqcJr.js +0 -2
  889. package/dist/run-wait--kou3jZ7.js +0 -135
  890. package/dist/runtime-BvxkGJm2.js +0 -9
  891. package/dist/runtime-DgQ5oUKq.js +0 -973
  892. package/dist/runtime-api-6SzMK-FZ.js +0 -4
  893. package/dist/runtime-api-BAMrcB-5.js +0 -9
  894. package/dist/runtime-api-DLSrxS5O.js +0 -9
  895. package/dist/runtime-api-DsPleWQg.js +0 -14
  896. package/dist/runtime-embedded-pi.runtime-eyjaJfAz.js +0 -2
  897. package/dist/runtime-internal-BTfGDlHi.js +0 -2
  898. package/dist/runtime-options-B5_eZxMV.js +0 -275
  899. package/dist/runtime-schema-BB3QzGXJ.js +0 -27780
  900. package/dist/scan-D0fsxqed.js +0 -2
  901. package/dist/scan-DrjjN66Z.js +0 -523
  902. package/dist/secrets-cli-B7-qbfn-.js +0 -2101
  903. package/dist/security-cli-CYTPgL67.js +0 -486
  904. package/dist/selection-DEAdLh1Q.js +0 -2
  905. package/dist/selection-zPPyzfBX.js +0 -7736
  906. package/dist/send-CYKfZTCJ.js +0 -156
  907. package/dist/send-Di1tRwJD.js +0 -102
  908. package/dist/send.runtime-Bw22DBkL.js +0 -2
  909. package/dist/server-BIF5dPI_.js +0 -13
  910. package/dist/server-BJK0Q4xw.js +0 -77
  911. package/dist/server-context-CiVVCQNp.js +0 -847
  912. package/dist/server-context-DXvk5Tdy.js +0 -2
  913. package/dist/server-node-events-CdZP3Kok.js +0 -481
  914. package/dist/server-plugin-bootstrap-Di15EOt4.js +0 -11333
  915. package/dist/server-plugin-bootstrap-dboO44LL.js +0 -2
  916. package/dist/server-restart-sentinel-BWiOzljY.js +0 -697
  917. package/dist/server.impl-Ph8YCQpT.js +0 -12734
  918. package/dist/session-kill-http-B_J1fJ4-.js +0 -110
  919. package/dist/session-reset-service-DPgw70iw.js +0 -471
  920. package/dist/session-route-B0h6MEyB.js +0 -93
  921. package/dist/session-status.runtime-DCvgI1pG.js +0 -2
  922. package/dist/session-subagent-reactivation.runtime-BgsCnI-h.js +0 -2
  923. package/dist/session-tab-registry-FyN6CWh5.js +0 -491
  924. package/dist/session-visibility-CZjMA1SL.js +0 -147
  925. package/dist/sessions-helpers-B3W7MdIb.js +0 -304
  926. package/dist/sessions-history-http-Bw5J6HQ-.js +0 -383
  927. package/dist/sessions-patch-2sBcHc9a.js +0 -309
  928. package/dist/sessions-resolve-C-VZh_56.js +0 -174
  929. package/dist/sessions.runtime-cLuc67tJ.js +0 -2
  930. package/dist/setup-FW8xH-S-.js +0 -495
  931. package/dist/setup-api-Culp0Usf.js +0 -29
  932. package/dist/setup-core-CaTBS6Tz.js +0 -171
  933. package/dist/setup-core-youmXvW_.js +0 -176
  934. package/dist/setup-surface-BeMn-9hU.js +0 -403
  935. package/dist/setup-surface-CUd-s0wh.js +0 -286
  936. package/dist/setup-surface-DtscjAY3.js +0 -219
  937. package/dist/setup.finalize-BWyA4f4q.js +0 -539
  938. package/dist/setup.gateway-config-CvzMdftA.js +0 -250
  939. package/dist/shared-B3Pz1Xcr.js +0 -121
  940. package/dist/shared-Bc3x3THS.js +0 -76
  941. package/dist/shared-CxbLx0Ww.js +0 -198
  942. package/dist/slash-state-XfeMEeuI.js +0 -1911
  943. package/dist/src-BiDxQvtV.js +0 -3974
  944. package/dist/startup-context-CXQi-7YB.js +0 -312
  945. package/dist/status-Ch3bm70K.js +0 -2
  946. package/dist/status-CiQSxvY-.js +0 -3
  947. package/dist/status-DY0DlWlw.js +0 -190
  948. package/dist/status-DjdByQv-.js +0 -209
  949. package/dist/status-MT62_Jgw.js +0 -2
  950. package/dist/status-all-BD2viQD9.js +0 -498
  951. package/dist/status-json-CWS2oYON.js +0 -14
  952. package/dist/status-json-command-B6lZefoe.js +0 -84
  953. package/dist/status-pujDHwRb.js +0 -397
  954. package/dist/status-runtime-shared-Bu9Zhd7x.js +0 -257
  955. package/dist/status-subagents.runtime-B4UXD0lL.js +0 -18
  956. package/dist/status-text-myqmk4OL.js +0 -237
  957. package/dist/status.gateway-connection.runtime-B0Iwl2iZ.js +0 -2
  958. package/dist/status.gather-C51Ja0wP.js +0 -292
  959. package/dist/status.gather-DQ7WZp3H.js +0 -2
  960. package/dist/status.runtime-Cxyb3wHZ.js +0 -2
  961. package/dist/status.scan-C1aqDsy2.js +0 -65
  962. package/dist/status.scan-overview-BerlJz2l.js +0 -379
  963. package/dist/status.scan.fast-json-BXY82vu2.js +0 -2
  964. package/dist/status.scan.fast-json-DJqgEbzZ.js +0 -132
  965. package/dist/status.summary-CCdLUph8.js +0 -214
  966. package/dist/status.summary-CHAn0_FS.js +0 -2
  967. package/dist/subagent-announce-D4jG75Ub.js +0 -351
  968. package/dist/subagent-announce-delivery-BkQYzDcy.js +0 -726
  969. package/dist/subagent-announce-output-C3pkuu-t.js +0 -364
  970. package/dist/subagent-control-DVVK8du2.js +0 -506
  971. package/dist/subagent-followup.runtime-CdeweG-S.js +0 -68
  972. package/dist/subagent-orphan-recovery-ZQanOHb4.js +0 -305
  973. package/dist/subagent-registry-BcPa3ho0.js +0 -3
  974. package/dist/subagent-registry-hJUso5eL.js +0 -1753
  975. package/dist/subagent-spawn-DTaeQc9q.js +0 -1005
  976. package/dist/system-cli-CT8VaSDY.js +0 -59
  977. package/dist/targets-BPdSjnQH.js +0 -67
  978. package/dist/task-executor-B62Qzfi-.js +0 -360
  979. package/dist/task-owner-access-BBMrMOlN.js +0 -74
  980. package/dist/task-registry-BD-ew2bT.js +0 -2366
  981. package/dist/task-registry-delivery-runtime-B2WyGY0d.js +0 -3
  982. package/dist/task-registry-delivery-runtime-MFJszOHI.js +0 -2
  983. package/dist/task-registry.maintenance-0D2Yxl49.js +0 -416
  984. package/dist/task-registry.maintenance-OPlfB5W9.js +0 -2
  985. package/dist/testing-DmxZ16UC.js +0 -575
  986. package/dist/text-report-BwIpU54R.js +0 -587
  987. package/dist/tool-resolution-vn72hwMo.js +0 -90
  988. package/dist/tools-effective-inventory-DII_pOSr.js +0 -152
  989. package/dist/tools-invoke-http-DdthGR52.js +0 -206
  990. package/dist/trash-BVZu6rU7.js +0 -24
  991. package/dist/tui-cli-Bz51WCAi.js +0 -4575
  992. package/dist/update-cli-DkH8vHQP.js +0 -1759
  993. package/dist/upgrade-Dvj8K4WB.js +0 -1226
  994. package/dist/video-generation-task-status-CHYB_IeZ.js +0 -163
  995. package/dist/wait-for-idle-before-flush-DJMxeE2X.js +0 -5986
  996. package/dist/wizard-models-BNQQ7fvr.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-DGhyL8hG.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-3A_JCcKp.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-Vc33wEpr.js");
295
+ return await pluginRegistryLoaderModulePromise;
296
+ }
297
+ async function loadPluginMetadataRegistryLoaderModule() {
298
+ pluginMetadataRegistryLoaderModulePromise ??= import("./metadata-registry-loader-GRi5Rm2Z.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-Ckws4Nlw.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 };