@gaodefa/daocore 2026.5.30 → 2026.5.32

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 (1121) hide show
  1. package/dist/abort-5xSPv96j.js +277 -0
  2. package/dist/abort.runtime-0926E27Z.js +2 -0
  3. package/dist/abort.runtime.js +1 -1
  4. package/dist/account-inspect-BgzS8u-D.js +173 -0
  5. package/dist/accounts-7v5WrRCh.js +2 -0
  6. package/dist/accounts-BzO41JQx.js +107 -0
  7. package/dist/accounts-CSbmdRcc.js +107 -0
  8. package/dist/accounts-CZQ5w4JW.js +119 -0
  9. package/dist/acp-runtime-BCeSAla4.js +26 -0
  10. package/dist/acp-spawn-Czqyiryw.js +1275 -0
  11. package/dist/acp-spawn-D39EyfB9.js +2 -0
  12. package/dist/acp-stateful-target-driver-Ds-A-N-E.js +89 -0
  13. package/dist/action-kill-BdD5_Aml.js +33 -0
  14. package/dist/action-runtime-COScp8ol.js +469 -0
  15. package/dist/action-runtime-api-BgjjgLcW.js +2 -0
  16. package/dist/action-send-DfeejIBh.js +39 -0
  17. package/dist/action-spawn-DO8scagE.js +47 -0
  18. package/dist/actions-XbUKh94t.js +161 -0
  19. package/dist/actions.runtime-D_FyKsqj.js +5 -0
  20. package/dist/agent-3M5jLi8y.js +2 -0
  21. package/dist/agent-_HmdUCr4.js +3 -0
  22. package/dist/agent-command-JdyQsbkT.js +1367 -0
  23. package/dist/agent-components.runtime-BiG6LL4q.js +10 -0
  24. package/dist/agent-components.runtime.js +1 -1
  25. package/dist/agent-harness-runtime-CHrYKoTd.js +180 -0
  26. package/dist/agent-harness-task-runtime-DHQNyKub.js +140 -0
  27. package/dist/agent-runner-execution-D20QTBXr.js +1713 -0
  28. package/dist/agent-runner-utils-Bqe6xxgK.js +266 -0
  29. package/dist/agent-runner.runtime-BDNZI9xP.js +3455 -0
  30. package/dist/agent-runner.runtime.js +1 -1
  31. package/dist/agent-runtime-TYhcwEWD.js +229 -0
  32. package/dist/agent-via-gateway-Dr06Lb5b.js +463 -0
  33. package/dist/api-Bv6Yzx0U.js +639 -0
  34. package/dist/api-CKq871s7.js +134 -0
  35. package/dist/api-DX_U2wja.js +2 -0
  36. package/dist/api-U8Q33Ouw.js +6 -0
  37. package/dist/api-UYhicEhq.js +3 -0
  38. package/dist/api-yyfjBhjb.js +2 -0
  39. package/dist/apply-BaAAhGbT.js +41 -0
  40. package/dist/apply-DoPxVm4A.js +54 -0
  41. package/dist/approval-handler.runtime-BtGX8k1E.js +130 -0
  42. package/dist/assistant-B3I8-7Lv.js +291 -0
  43. package/dist/attachment-normalize-C0-A3gAr.js +225 -0
  44. package/dist/attempt-execution-B4Uh6AAn.js +558 -0
  45. package/dist/attempt-execution.runtime-CDwaTeFi.js +3 -0
  46. package/dist/attempt-execution.runtime.js +1 -1
  47. package/dist/attempt-execution.shared-LOacq8Oi.js +38 -0
  48. package/dist/attempt.prompt-helpers-DTLTH3Mn.js +475 -0
  49. package/dist/attempt.tool-run-context-CQfLOzhy.js +2094 -0
  50. package/dist/binding-routing-D1Ep8LYu.js +113 -0
  51. package/dist/binding-targets-DAx23oWo.js +121 -0
  52. package/dist/bot-Wv3X4bsa.js +7894 -0
  53. package/dist/bot-deps-Bl2rHw_I.js +747 -0
  54. package/dist/bot-deps-D5QFJ6Sp.js +2 -0
  55. package/dist/bot-message-context.runtime-CLTMWkIl.js +7 -0
  56. package/dist/bot-message-context.runtime.js +1 -1
  57. package/dist/bot-message-context.session.runtime-C7ixtg9D.js +12 -0
  58. package/dist/bot-message-context.session.runtime.js +1 -1
  59. package/dist/bot-native-commands.delivery.runtime-Dd7fg3sv.js +4 -0
  60. package/dist/bot-native-commands.delivery.runtime.js +1 -1
  61. package/dist/bot-native-commands.runtime-xxk9PH27.js +13 -0
  62. package/dist/bot-native-commands.runtime.js +1 -1
  63. package/dist/bridge-server-B2OfZKTC.js +113 -0
  64. package/dist/browser-cli-C5iosRvD.js +230 -0
  65. package/dist/browser-cli-CLz_3gcp.js +2 -0
  66. package/dist/browser-cli-actions-input-DmI7MUTC.js +473 -0
  67. package/dist/browser-cli-actions-observe-D3mxz2K_.js +81 -0
  68. package/dist/browser-cli-debug-D4ovrUvJ.js +137 -0
  69. package/dist/browser-cli-inspect-NM7kVusr.js +104 -0
  70. package/dist/browser-cli-manage--VYOZfBu.js +443 -0
  71. package/dist/browser-cli-resize-DrCL8Kq1.js +26 -0
  72. package/dist/browser-cli-shared-Cd6zdFZW.js +50 -0
  73. package/dist/browser-cli-state-CoB8ZyE6.js +337 -0
  74. package/dist/browser-control-auth-Bev4Zk62.js +2 -0
  75. package/dist/browser-profiles-BxPD8_vB.js +2 -0
  76. package/dist/browser-runtime-C07L-Zov.js +384 -0
  77. package/dist/build-CQUvEKPr.js +257 -0
  78. package/dist/build-info.json +3 -3
  79. package/dist/bundled/boot-md/handler.js +2 -2
  80. package/dist/bundled/session-memory/handler.js +1 -1
  81. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  82. package/dist/capability-cli-CgkX47xS.js +1782 -0
  83. package/dist/channel-4gVDslD_.js +653 -0
  84. package/dist/channel-6vrwZPs9.js +238 -0
  85. package/dist/channel-B9ZuUQ6v.js +562 -0
  86. package/dist/channel-BADrx_U3.js +1556 -0
  87. package/dist/channel-BGLIVapC.js +481 -0
  88. package/dist/channel-BwcQp8Rq.js +955 -0
  89. package/dist/channel-BzSKfrLf.js +740 -0
  90. package/dist/channel-C4XSENg9.js +2126 -0
  91. package/dist/channel-C7ga9fTJ.js +1777 -0
  92. package/dist/channel-C8hBwzA1.js +362 -0
  93. package/dist/channel-CCG1mfB4.js +1496 -0
  94. package/dist/channel-CKOJY4Zd.js +1134 -0
  95. package/dist/channel-CYxTzhn7.js +376 -0
  96. package/dist/channel-DDg0cxDP.js +808 -0
  97. package/dist/channel-DpsxF3Mf.js +1249 -0
  98. package/dist/channel-MXOd30fz.d.ts +427 -0
  99. package/dist/channel-actions.runtime-DJOOf7eP.js +265 -0
  100. package/dist/channel-actions.runtime.js +1 -1
  101. package/dist/channel-cl_cgDg6.js +508 -0
  102. package/dist/channel-core-DTSpGZkc.js +5 -0
  103. package/dist/channel-emJStu3a.js +867 -0
  104. package/dist/channel-inbound-le9T0BS4.js +80 -0
  105. package/dist/channel-plugin-runtime-COf6cDhp.js +998 -0
  106. package/dist/channel-runtime-LgCwu-e7.js +408 -0
  107. package/dist/channel.runtime-1b8dMgHq.js +4 -0
  108. package/dist/channel.runtime-BIZeTsuh.js +88 -0
  109. package/dist/channel.runtime-BPTDdF_t.js +1008 -0
  110. package/dist/channel.runtime-CMwMP86f.js +21009 -0
  111. package/dist/channel.runtime-CbR_S3Es.js +733 -0
  112. package/dist/channel.runtime-CoNDJV33.js +254 -0
  113. package/dist/channel.runtime-D1ve78xp.js +109 -0
  114. package/dist/channel.runtime-DAuGTOCS.js +652 -0
  115. package/dist/channel.runtime-DCHOoofn.js +2528 -0
  116. package/dist/channel.setup-BP1xL5Pf.js +1098 -0
  117. package/dist/channel.setup-ChiJ3GPS.js +10 -0
  118. package/dist/channel.setup-SmJQYInQ.js +343 -0
  119. package/dist/chat-zRdfy5a3.js +2666 -0
  120. package/dist/chrome-CKXrklba.js +1503 -0
  121. package/dist/cli/run-main.js +5 -5
  122. package/dist/cli-D8jOuVTO.js +1341 -0
  123. package/dist/cli-compaction-BLVrCsK5.js +347 -0
  124. package/dist/cli-metadata-CYvkEhJD.js +22 -0
  125. package/dist/cli-runner-BlM3bE0F.js +2 -0
  126. package/dist/cli-runner-D6RHy0cU.js +540 -0
  127. package/dist/cli-runner.runtime-BZAAFLDU.js +4 -0
  128. package/dist/cli-runner.runtime-CpX1HvG6.js +3 -0
  129. package/dist/cli-runner.runtime.js +1 -1
  130. package/dist/cli-startup-metadata.json +8 -8
  131. package/dist/client-CtRn_hQP.js +650 -0
  132. package/dist/client-adapter-BVIdEc7J.js +897 -0
  133. package/dist/client-factory-6n6tLSIi.js +9 -0
  134. package/dist/command-auth-B2r-fHTK.js +135 -0
  135. package/dist/command-handlers-Pnxu5_zT.js +1609 -0
  136. package/dist/command-registry-Ck2pwGIs.js +9 -0
  137. package/dist/command-registry-CmCmwAX7.js +4 -0
  138. package/dist/command-registry-core-Bpb8Zmai.js +110 -0
  139. package/dist/command-status.runtime-Bjq4f1lX.js +90 -0
  140. package/dist/command-status.runtime.js +1 -1
  141. package/dist/commands-acp-B7zCM6RA.js +74 -0
  142. package/dist/commands-compact.runtime-CmtzRn-a.js +10 -0
  143. package/dist/commands-compact.runtime.js +1 -1
  144. package/dist/commands-handlers.runtime-C4kTnIeK.js +6154 -0
  145. package/dist/commands-handlers.runtime.js +1 -1
  146. package/dist/commands-status-DVgiHsQ5.js +16 -0
  147. package/dist/commands-status-DlYd-7ik.js +3 -0
  148. package/dist/commands-status.runtime-DlYd-7ik.js +3 -0
  149. package/dist/commands-status.runtime.js +1 -1
  150. package/dist/commands-subagents-control.runtime-DgvtGIas.js +2 -0
  151. package/dist/commands-subagents-control.runtime-JdMGlKtk.js +3 -0
  152. package/dist/commands-subagents-control.runtime.js +1 -1
  153. package/dist/commands-system-prompt-BQyxb4tV.js +162 -0
  154. package/dist/commands-system-prompt-ByWU697p.js +2 -0
  155. package/dist/commands.runtime-CJP1VpiV.js +176 -0
  156. package/dist/commands.runtime.js +1 -1
  157. package/dist/commitments/runtime.js +1 -1
  158. package/dist/compact-DLUg6XJH.js +1141 -0
  159. package/dist/compact-_E6we35c.js +480 -0
  160. package/dist/compact.runtime-DPVrm-pW.js +12 -0
  161. package/dist/compact.runtime.js +1 -1
  162. package/dist/completion-cli-DoizagFW.js +315 -0
  163. package/dist/computer-use-CCjnsa_1.js +367 -0
  164. package/dist/config-BilJG9EC.js +373 -0
  165. package/dist/config-BxPD8_vB.js +2 -0
  166. package/dist/config-mutations-D_EXryF0.js +159 -0
  167. package/dist/context-engine-host-compat-CqmA35DL.js +2 -0
  168. package/dist/context-engine-host-compat-CueTS2PS.js +288 -0
  169. package/dist/context-engine-lifecycle-BfMiEl15.js +1274 -0
  170. package/dist/control-auth-BU7xIoX-.js +114 -0
  171. package/dist/control-service-rkbW1sH-.js +145 -0
  172. package/dist/control-ui/assets/agents-psfLxkbw.js +1008 -0
  173. package/dist/control-ui/assets/channel-config-extras-DKBnO1hS.js +2 -0
  174. package/dist/control-ui/assets/channels-DDOrwq_r.js +367 -0
  175. package/dist/control-ui/assets/cron-BgSXqasf.js +1013 -0
  176. package/dist/control-ui/assets/debug-WtFopOVs.js +97 -0
  177. package/dist/control-ui/assets/index-MvAQ2w1r.js +7370 -0
  178. package/dist/control-ui/assets/instances-BrOnPv6H.js +57 -0
  179. package/dist/control-ui/assets/logs-DaCF5a_0.js +74 -0
  180. package/dist/control-ui/assets/nodes-BfGBhTsX.js +436 -0
  181. package/dist/control-ui/assets/sessions-EYXaSnpx.js +399 -0
  182. package/dist/control-ui/assets/skills-kGP53jBT.js +314 -0
  183. package/dist/control-ui/assets/skills-shared-0VEOTMHb.js +11 -0
  184. package/dist/control-ui/index.html +1 -1
  185. package/dist/control-ui/sw.js +1 -1
  186. package/dist/conversation-binding-runtime-DUU8Cbqn.js +4 -0
  187. package/dist/conversation-runtime-DPrqAWle.js +31 -0
  188. package/dist/core-CUD6UgSq.js +282 -0
  189. package/dist/core-api-B1g3Om3O.js +5 -0
  190. package/dist/core-api-C-O6aNhF.js +2 -0
  191. package/dist/crestodian/crestodian.js +1 -1
  192. package/dist/crestodian/rescue-message.js +1 -1
  193. package/dist/crestodian-v9uXA3A2.js +55 -0
  194. package/dist/daocore-tools-C28lHB0m.js +11727 -0
  195. package/dist/delivery-BuWQ2Vps.js +1002 -0
  196. package/dist/dialogue-DSYoyGRK.js +37 -0
  197. package/dist/dir-fetch-tool-Cp6QDtGT.js +565 -0
  198. package/dist/dir-list-tool-Cgwy8SnK.js +100 -0
  199. package/dist/direct-dm-B9jtIQVB.js +64 -0
  200. package/dist/directive-handling.fast-lane-DW5n01VF.js +68 -0
  201. package/dist/directive-handling.impl-BZXGBxBu.js +2 -0
  202. package/dist/directive-handling.impl-DvmlznGE.js +818 -0
  203. package/dist/directive-handling.model-selection-CdbAe1eC.js +122 -0
  204. package/dist/directive-handling.persist.runtime-B7WHo9zw.js +263 -0
  205. package/dist/directive-handling.persist.runtime.js +1 -1
  206. package/dist/dispatch-Bysi6DFL.js +1640 -0
  207. package/dist/dispatch-acp-transcript.runtime-CrAnpqiX.js +40 -0
  208. package/dist/dispatch-acp-transcript.runtime.js +1 -1
  209. package/dist/dispatch-acp.runtime-DkcXZIbM.js +18 -0
  210. package/dist/dispatch-acp.runtime.js +1 -1
  211. package/dist/doctor-CFmGWeIn.js +6 -0
  212. package/dist/doctor-_JI7RKJk.js +2 -0
  213. package/dist/doctor-config-flow-DVXxaLTb.js +1741 -0
  214. package/dist/doctor-core-checks-BfUW_u2R.js +2 -0
  215. package/dist/doctor-core-checks-lmN1Tw4N.js +573 -0
  216. package/dist/doctor-health-ZgTh34Za.js +65 -0
  217. package/dist/doctor-health-contributions-DV0Ff5cp.js +696 -0
  218. package/dist/doctor-lint-DbYtxQxC.js +94 -0
  219. package/dist/doctor-state-integrity-CZdBuNdm.js +1231 -0
  220. package/dist/doctor-update-DpFQTsrm.js +58 -0
  221. package/dist/dynamic-tools-DWocQS_t.js +486 -0
  222. package/dist/embedded-backend-DGDv3GDw.js +579 -0
  223. package/dist/embedded-gateway-stub.runtime-mATMWU23.js +12 -0
  224. package/dist/embedded-gateway-stub.runtime.js +1 -1
  225. package/dist/exec-approvals-tk6i5Iy2.js +149 -0
  226. package/dist/extensionAPI.js +1 -1
  227. package/dist/extensions/active-memory/index.js +1 -1
  228. package/dist/extensions/admin-http-rpc/index.js +1 -1
  229. package/dist/extensions/browser/browser-bridge.js +1 -1
  230. package/dist/extensions/browser/browser-config.js +4 -4
  231. package/dist/extensions/browser/browser-control-auth.js +2 -2
  232. package/dist/extensions/browser/browser-doctor.js +2 -2
  233. package/dist/extensions/browser/browser-maintenance.js +1 -1
  234. package/dist/extensions/browser/browser-profiles.js +2 -2
  235. package/dist/extensions/browser/browser-runtime-api.js +11 -11
  236. package/dist/extensions/browser/cli-metadata.js +1 -1
  237. package/dist/extensions/browser/index.js +1 -1
  238. package/dist/extensions/browser/plugin-registration.js +1 -1
  239. package/dist/extensions/browser/register.runtime.js +4 -4
  240. package/dist/extensions/browser/runtime-api.js +13 -13
  241. package/dist/extensions/canvas/index.js +1 -1
  242. package/dist/extensions/clickclack/api.js +2 -2
  243. package/dist/extensions/clickclack/channel-plugin-api.js +1 -1
  244. package/dist/extensions/clickclack/runtime-api.js +2 -2
  245. package/dist/extensions/device-pair/api.js +1 -1
  246. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  247. package/dist/extensions/file-transfer/index.js +4 -4
  248. package/dist/extensions/imessage/api.js +2 -2
  249. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  250. package/dist/extensions/imessage/message-tool-api.d.ts +1 -1
  251. package/dist/extensions/imessage/runtime-api.js +3 -3
  252. package/dist/extensions/irc/api.js +2 -2
  253. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  254. package/dist/extensions/llm-task/index.js +1 -1
  255. package/dist/extensions/mattermost/api.js +1 -1
  256. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  257. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  258. package/dist/extensions/mattermost/policy-api.js +1 -1
  259. package/dist/extensions/mattermost/runtime-api.js +2 -2
  260. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  261. package/dist/extensions/memory-core/cli-metadata.js +1 -1
  262. package/dist/extensions/migrate-claude/apply.js +1 -1
  263. package/dist/extensions/migrate-claude/index.js +1 -1
  264. package/dist/extensions/migrate-claude/plan.js +1 -1
  265. package/dist/extensions/migrate-claude/provider.js +1 -1
  266. package/dist/extensions/migrate-claude/targets.js +1 -1
  267. package/dist/extensions/migrate-hermes/apply.js +1 -1
  268. package/dist/extensions/migrate-hermes/index.js +1 -1
  269. package/dist/extensions/migrate-hermes/model.js +1 -1
  270. package/dist/extensions/migrate-hermes/plan.js +1 -1
  271. package/dist/extensions/migrate-hermes/provider.js +1 -1
  272. package/dist/extensions/migrate-hermes/secrets.js +1 -1
  273. package/dist/extensions/migrate-hermes/targets.js +1 -1
  274. package/dist/extensions/policy/api.js +1 -1
  275. package/dist/extensions/policy/index.js +2 -2
  276. package/dist/extensions/signal/api.js +6 -6
  277. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  278. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  279. package/dist/extensions/signal/runtime-api.js +7 -7
  280. package/dist/extensions/skill-workshop/api.js +1 -1
  281. package/dist/extensions/skill-workshop/index.js +2 -2
  282. package/dist/extensions/telegram/account-inspect-api.js +1 -1
  283. package/dist/extensions/telegram/api.js +11 -11
  284. package/dist/extensions/telegram/channel-plugin-api.js +2 -2
  285. package/dist/extensions/telegram/contract-api.js +3 -3
  286. package/dist/extensions/telegram/runtime-api.js +7 -7
  287. package/dist/extensions/telegram/security-audit-contract-api.js +1 -1
  288. package/dist/extensions/telegram/setup-plugin-api.js +1 -1
  289. package/dist/extensions/telegram/test-api.js +2 -2
  290. package/dist/extensions/webhooks/api.js +1 -1
  291. package/dist/extensions/webhooks/index.js +1 -1
  292. package/dist/extensions/xai/index.js +4 -4
  293. package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
  294. package/dist/extensions/xai/speech-provider.js +1 -1
  295. package/dist/extensions/xai/test-api.js +1 -1
  296. package/dist/extensions/xai/tts.js +1 -1
  297. package/dist/extensions/xai/web-search.js +1 -1
  298. package/dist/extensions/xai/xai-oauth.js +1 -1
  299. package/dist/file-fetch-tool-BVh97aps.js +124 -0
  300. package/dist/file-write-tool-Cfb7u51o.js +127 -0
  301. package/dist/format-Bqz5xYeB.js +250 -0
  302. package/dist/format-DpuFG9c5.js +1145 -0
  303. package/dist/gateway-cli-eCkwL4uy.js +435 -0
  304. package/dist/gateway-method-runtime-BXqKYfux.js +21 -0
  305. package/dist/get-reply-Bc_T3z5w.js +4689 -0
  306. package/dist/get-reply-from-config.runtime-BKhFCEun.js +2 -0
  307. package/dist/get-reply-from-config.runtime.js +1 -1
  308. package/dist/graph-users-BiokxXwA.js +1419 -0
  309. package/dist/group-access-DBAPYc28.js +112 -0
  310. package/dist/handle-action.guild-admin-S3qgTJJ3.js +288 -0
  311. package/dist/harness-B7wBXWh0.js +61 -0
  312. package/dist/health-DdXlm-1M.js +4 -0
  313. package/dist/health-state-BbDa6gRr.js +106 -0
  314. package/dist/heartbeat-runner-CZKQeDIE.js +5 -0
  315. package/dist/heartbeat-runner.runtime-D5VTmRkB.js +4 -0
  316. package/dist/heartbeat-runner.runtime.js +1 -1
  317. package/dist/hooks-CJtypGfW.js +534 -0
  318. package/dist/inbound-direct-dm-runtime-D91V0BFn.js +2 -0
  319. package/dist/inbound-reply-dispatch-DTvJL7df.js +148 -0
  320. package/dist/index.js +1 -1
  321. package/dist/init-qWugBDhm.js +59 -0
  322. package/dist/inline-buttons-1E4EwLvT.js +40 -0
  323. package/dist/internal-events-DtxthZ8P.js +90 -0
  324. package/dist/isolated-agent-C0ZZI5QV.js +2 -0
  325. package/dist/isolated-agent-C7qWrmnX.js +1118 -0
  326. package/dist/lifecycle-Wq49oJK4.js +571 -0
  327. package/dist/list.probe-DWMHsvUW.js +449 -0
  328. package/dist/list.status-command-DSGGuDOk.js +789 -0
  329. package/dist/llm-slug-generator-Bp_C1mgK.js +78 -0
  330. package/dist/llm-slug-generator.js +1 -1
  331. package/dist/local-dispatch.runtime-Cn8pnuYP.js +9 -0
  332. package/dist/local-dispatch.runtime.js +1 -1
  333. package/dist/manager.runtime-BdEdrDpV.js +2714 -0
  334. package/dist/manager.runtime.js +1 -1
  335. package/dist/markdown-to-line-D8Y0X3f4.js +811 -0
  336. package/dist/mcp-http-Cmug_nIB.js +555 -0
  337. package/dist/mcp-http-Dxmrs9Wm.js +2 -0
  338. package/dist/media-understanding-provider-BUGZ_tGW.js +339 -0
  339. package/dist/message-actions-Bb5avCm0.js +145 -0
  340. package/dist/message-handler-7FxYBWCr.js +384 -0
  341. package/dist/message-handler-EXgLxNWG.js +1715 -0
  342. package/dist/message-handler.preflight-CtW30FUU.js +1125 -0
  343. package/dist/message-handler.process-D_tmiE76.js +1484 -0
  344. package/dist/model-FzMER7bm.js +74 -0
  345. package/dist/model-selection-bti71700.js +272 -0
  346. package/dist/models-C8i8gMx4.js +2 -0
  347. package/dist/models-CdD9KMFY.js +104 -0
  348. package/dist/models-cli-gg_kT0t3.js +256 -0
  349. package/dist/monitor-Be8nfodW.js +1657 -0
  350. package/dist/monitor-Bvxk0x5H.js +715 -0
  351. package/dist/monitor-CE97mY08.js +2788 -0
  352. package/dist/monitor-CUf3qwuD.js +60 -0
  353. package/dist/monitor-D6mKqFJ6.js +834 -0
  354. package/dist/monitor-DU7GwGnr.js +4377 -0
  355. package/dist/monitor-DhcXz9j_.js +2 -0
  356. package/dist/monitor-auth-BRcGC8Y2.js +179 -0
  357. package/dist/monitor-polling.runtime-IxrlG8Xk.js +883 -0
  358. package/dist/monitor-polling.runtime.js +1 -1
  359. package/dist/monitor-vVY3N7u5.js +1370 -0
  360. package/dist/monitor-webhook.runtime-hc4RVNDK.js +387 -0
  361. package/dist/monitor-webhook.runtime.js +1 -1
  362. package/dist/monitor.account-XphC4gzs.js +5233 -0
  363. package/dist/monitor.runtime-6xS3OjmH.js +2 -0
  364. package/dist/monitor.runtime.js +1 -1
  365. package/dist/monitor.webhook-5EHwrXWd.js +180 -0
  366. package/dist/node-cli-sessions-DOBuRxFO.js +1228 -0
  367. package/dist/openai-http-CGnGQIGW.js +824 -0
  368. package/dist/openresponses-http-BXPy59t0.js +1173 -0
  369. package/dist/operations-BvCPaweO.js +805 -0
  370. package/dist/outbound-adapter-DiSr_Bhn.js +543 -0
  371. package/dist/outbound-session-route-Cm1ZzMzO.js +45 -0
  372. package/dist/outbound.runtime-_iFVmHLo.js +2 -0
  373. package/dist/outbound.runtime.js +1 -1
  374. package/dist/pi-embedded-D5GNzI7q.js +4 -0
  375. package/dist/pi-embedded-DFFUgktH.js +3796 -0
  376. package/dist/pi-embedded.runtime-Cd4ObvwO.js +4 -0
  377. package/dist/pi-embedded.runtime.js +1 -1
  378. package/dist/pi-tools-BC8I1xvo.js +2413 -0
  379. package/dist/plan-CB-ExQ8I.js +112 -0
  380. package/dist/plan-XEE4NkGP.js +81 -0
  381. package/dist/plugin-FgCZcV6y.js +12396 -0
  382. package/dist/plugin-app-cache-key-CDrzpMz5.js +46 -0
  383. package/dist/plugin-enabled-C63xoVby.js +233 -0
  384. package/dist/plugin-registration-DmMBSR62.js +88 -0
  385. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  386. package/dist/plugin-sdk/acp-runtime-backend.js +1 -1
  387. package/dist/plugin-sdk/acp-runtime.js +2 -2
  388. package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
  389. package/dist/plugin-sdk/agent-harness-task-runtime.js +1 -1
  390. package/dist/plugin-sdk/agent-harness.js +7 -7
  391. package/dist/plugin-sdk/agent-runtime.js +2 -2
  392. package/dist/plugin-sdk/channel-core.js +2 -2
  393. package/dist/plugin-sdk/channel-inbound.js +2 -2
  394. package/dist/plugin-sdk/channel-test-helpers.js +1 -1
  395. package/dist/plugin-sdk/command-auth.js +1 -1
  396. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  397. package/dist/plugin-sdk/compat.js +1 -1
  398. package/dist/plugin-sdk/conversation-binding-runtime.js +2 -2
  399. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  400. package/dist/plugin-sdk/core.js +2 -2
  401. package/dist/plugin-sdk/direct-dm.js +1 -1
  402. package/dist/plugin-sdk/gateway-method-runtime.js +1 -1
  403. package/dist/plugin-sdk/health.js +2 -2
  404. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  405. package/dist/plugin-sdk/index.js +1 -1
  406. package/dist/plugin-sdk/mattermost.js +1 -1
  407. package/dist/plugin-sdk/plugin-test-contracts.js +2 -2
  408. package/dist/plugin-sdk/provider-test-contracts.js +4 -4
  409. package/dist/plugin-sdk/reply-runtime.js +4 -4
  410. package/dist/plugin-sdk/testing.js +2 -2
  411. package/dist/plugin-sdk/zalouser.js +1 -1
  412. package/dist/plugin-service-Dt30fEbO.js +1229 -0
  413. package/dist/plugins/runtime/index.js +4 -4
  414. package/dist/policy-CtICwdgT.js +680 -0
  415. package/dist/policy-DT-VOML-.js +138 -0
  416. package/dist/prepare.runtime-BZWbkknM.js +732 -0
  417. package/dist/prepare.runtime.js +1 -1
  418. package/dist/preview-warnings-c5wlaU-y.js +392 -0
  419. package/dist/probe-C0Gd1211.js +682 -0
  420. package/dist/probe-CM_9YKXA.js +2 -0
  421. package/dist/probe-CrkgoSu3.js +2204 -0
  422. package/dist/probe-DcbGYJMj.js +47 -0
  423. package/dist/program-DcIk29tW.js +131 -0
  424. package/dist/provider-B2h8f0Br.js +8735 -0
  425. package/dist/provider-BXVr37w8.js +32 -0
  426. package/dist/provider-CIB7u7hX.js +152 -0
  427. package/dist/provider-bvVoUDev.js +32 -0
  428. package/dist/provider-dispatcher-btaVKiyh.js +22 -0
  429. package/dist/provider-dispatcher.runtime.js +1 -1
  430. package/dist/provider-session.runtime-CFBF4pr7.js +9 -0
  431. package/dist/provider-session.runtime.js +1 -1
  432. package/dist/provider.runtime-CZfM-gk6.js +2 -0
  433. package/dist/provider.runtime.js +1 -1
  434. package/dist/public-surface-loader-BTQVJb2c.js +114 -0
  435. package/dist/pw-ai-CZwiW9VR.js +3029 -0
  436. package/dist/pw-role-snapshot-BBAmIGwb.js +333 -0
  437. package/dist/reaction-level-DBBuD-ww.js +19 -0
  438. package/dist/reaction-runtime-api-C1vrXLqZ.js +116 -0
  439. package/dist/realtime-transcription-provider-CelUuvqm.js +205 -0
  440. package/dist/register-OPqUqnP6.js +2178 -0
  441. package/dist/register.agent-DSrwwOvx.js +156 -0
  442. package/dist/register.crestodian-Xxxk2-Zl.js +24 -0
  443. package/dist/register.maintenance-CDfzLTNQ.js +83 -0
  444. package/dist/register.runtime-BVG-Dv_-.js +54 -0
  445. package/dist/register.status-health-sessions-B36GUeBl.js +282 -0
  446. package/dist/register.subclis-BHzKPsu3.js +31 -0
  447. package/dist/register.subclis-Je6qsLUH.js +3 -0
  448. package/dist/register.subclis-core-DqSQ4XoR.js +273 -0
  449. package/dist/repair-sequencing-DNO4k0Xf.js +640 -0
  450. package/dist/reply-delivery-37v9z05y.js +196 -0
  451. package/dist/reply-runtime-py2XHqw1.js +11 -0
  452. package/dist/reply.runtime-BKhFCEun.js +2 -0
  453. package/dist/reply.runtime.js +1 -1
  454. package/dist/request-CoRpTCQ-.js +54 -0
  455. package/dist/resolve-allowlist-D-vOgxSP.js +220 -0
  456. package/dist/result-fallback-classifier-Dn3Dmp9k.js +79 -0
  457. package/dist/route-DW9RJF0S.js +469 -0
  458. package/dist/route-resolution-D_0Mvu67.js +274 -0
  459. package/dist/routes-437aa83D.js +3602 -0
  460. package/dist/routes-D7LQ3tMt.js +2 -0
  461. package/dist/run-DXGJiQoW.js +1162 -0
  462. package/dist/run-attempt-_0WJ7JVY.js +7704 -0
  463. package/dist/run-command-BkhBbZq4.js +23 -0
  464. package/dist/run-command-DMG9dO72.js +2 -0
  465. package/dist/run-embedded.runtime-D525I-KH.js +4 -0
  466. package/dist/run-embedded.runtime.js +1 -1
  467. package/dist/run-execution-cli.runtime-TuyJs3wn.js +4 -0
  468. package/dist/run-execution-cli.runtime.js +1 -1
  469. package/dist/run-executor.runtime.js +1 -1
  470. package/dist/run-subagent-registry.runtime-BcGVpK9w.js +2 -0
  471. package/dist/run-subagent-registry.runtime.js +1 -1
  472. package/dist/runtime-5_JhnRj0.js +438 -0
  473. package/dist/runtime-BEfdbKzt.js +6179 -0
  474. package/dist/runtime-DtQ2yT4g.js +1287 -0
  475. package/dist/runtime-api-Bm7IDGdk.js +24 -0
  476. package/dist/runtime-api-C8uxd9Js.js +4 -0
  477. package/dist/runtime-api-CLhw7d8A.js +13 -0
  478. package/dist/runtime-api-Ccg7ngfJ.js +13 -0
  479. package/dist/runtime-api-CpQqdZYq.js +21 -0
  480. package/dist/runtime-api-JulpTdFC.js +17 -0
  481. package/dist/runtime-api-zbqtuJt-.js +3 -0
  482. package/dist/runtime-api.actions-2fHneH-M.js +3 -0
  483. package/dist/runtime-api.monitor-Bpj7QCdL.js +6 -0
  484. package/dist/runtime-api.send-DeoFOMAr.js +4 -0
  485. package/dist/runtime-api.threads-b16O0JZ4.js +2 -0
  486. package/dist/runtime-channel-CuERpYnN.js +150 -0
  487. package/dist/runtime-channel-YbtclsiZ.js +2 -0
  488. package/dist/runtime-embedded-pi.runtime-DEcqs7Yu.js +2 -0
  489. package/dist/runtime-embedded-pi.runtime.js +1 -1
  490. package/dist/sanitize-outbound-cOz4EipP.js +127 -0
  491. package/dist/sdk-setup-tools-Bur4xhiB.js +8 -0
  492. package/dist/secrets-B0P_1QcV.js +113 -0
  493. package/dist/security-audit-DRttHvfh.js +122 -0
  494. package/dist/security-audit-Dp26B_nd.js +118 -0
  495. package/dist/security-audit.runtime-DYK4iAnc.js +2 -0
  496. package/dist/security-audit.runtime.js +1 -1
  497. package/dist/selection-44C59Jt6.js +16157 -0
  498. package/dist/selection-QO-UjTkW.js +3 -0
  499. package/dist/send-C_D0mahx.js +2 -0
  500. package/dist/send-Cr-pK3Md.js +143 -0
  501. package/dist/send-DVhzeHKl.js +1631 -0
  502. package/dist/send-PmYvWFLe.js +192 -0
  503. package/dist/send.components-B2Mo6jm1.js +500 -0
  504. package/dist/send.components-BPYxo1GP.js +2 -0
  505. package/dist/send.runtime-D3JsvWwD.js +2 -0
  506. package/dist/send.runtime.js +1 -1
  507. package/dist/server-0ubKRVjg.js +24 -0
  508. package/dist/server-DfzdV9XR.js +73 -0
  509. package/dist/server-close.runtime.js +1 -1
  510. package/dist/server-context-CUWMZ_eM.js +2 -0
  511. package/dist/server-context-Cnl8idXT.js +955 -0
  512. package/dist/server-cron-D7QmsboM.js +2 -0
  513. package/dist/server-cron-mea_v_AH.js +2989 -0
  514. package/dist/server-maintenance-CzgBw90t.js +167 -0
  515. package/dist/server-methods-BQK-_CCw.js +16494 -0
  516. package/dist/server-node-events-C__xvGU1.js +596 -0
  517. package/dist/server-plugin-bootstrap-vC6fQjdM.js +70 -0
  518. package/dist/server-plugins-BfXHktel.js +432 -0
  519. package/dist/server-reload-handlers-CdagBZAE.js +714 -0
  520. package/dist/server-restart-sentinel-BO-vqR3K.js +747 -0
  521. package/dist/server-restart-sentinel-DND8yDHW.js +2 -0
  522. package/dist/server-runtime-services-Bao-oSOF.js +267 -0
  523. package/dist/server-runtime-services-D6cI6uO2.js +2 -0
  524. package/dist/server-startup-early-BDLTmiF5.js +87 -0
  525. package/dist/server-startup-plugins-q_W_iA3q.js +113 -0
  526. package/dist/server-startup-post-attach-CYKy2V3j.js +716 -0
  527. package/dist/server-ws-runtime-Da8L4ypZ.js +349 -0
  528. package/dist/server.impl-DGOSejqy.js +2586 -0
  529. package/dist/service-DlI2U-cK.js +1446 -0
  530. package/dist/session-binding-CwkYLNXf.js +2 -0
  531. package/dist/session-binding-DX-fo3c9.js +219 -0
  532. package/dist/session-kill-http-CFmTagxj.js +121 -0
  533. package/dist/session-reset-service-B25Jlagv.js +625 -0
  534. package/dist/session-route-bgMaGZRG.js +93 -0
  535. package/dist/session-status.runtime-Bs2EXyKA.js +2 -0
  536. package/dist/session-status.runtime.js +1 -1
  537. package/dist/session-subagent-reactivation.runtime-DXxAjUOk.js +2 -0
  538. package/dist/session-subagent-reactivation.runtime.js +1 -1
  539. package/dist/session-tab-registry-DacdZ4tB.js +521 -0
  540. package/dist/sessions-history-http-BVpW1ZcJ.js +430 -0
  541. package/dist/sessions.runtime-KBdCnSz6.js +2 -0
  542. package/dist/sessions.runtime.js +1 -1
  543. package/dist/setup-api-CeIlDnWx.js +29 -0
  544. package/dist/setup-core-DLbBGLsw.js +174 -0
  545. package/dist/setup-surface-B2a2VaWD.js +221 -0
  546. package/dist/setup-surface-Bx_siWyS.js +320 -0
  547. package/dist/setup-surface-Cf4YnQu2.js +405 -0
  548. package/dist/setup-surface-DTcOOfre.js +288 -0
  549. package/dist/shared-LAgU4fFs.js +121 -0
  550. package/dist/shared-client-Am1mCd-v.js +2 -0
  551. package/dist/shared-client-D3A48dlk.js +629 -0
  552. package/dist/side-question-DVTWk-tO.js +683 -0
  553. package/dist/skill-tool-dispatch.runtime-igagKDUg.js +143 -0
  554. package/dist/skill-tool-dispatch.runtime.js +1 -1
  555. package/dist/slash-state-DJji-KSx.js +2166 -0
  556. package/dist/speech-provider-Dsa05s8C.js +184 -0
  557. package/dist/src-DqgvOnta.js +4256 -0
  558. package/dist/startup-context-CWwChEn9.js +313 -0
  559. package/dist/status-CUKFkF6b.js +3 -0
  560. package/dist/status-_UeuGVi3.js +4 -0
  561. package/dist/status-all-ChigLV_X.js +573 -0
  562. package/dist/status-json-CIdP1iBJ.js +14 -0
  563. package/dist/status-json-command-BDEUrp6M.js +84 -0
  564. package/dist/status-runtime-shared-Cq4a18dI.js +283 -0
  565. package/dist/status-subagents.runtime-CAVnAL4K.js +18 -0
  566. package/dist/status-subagents.runtime.js +1 -1
  567. package/dist/status-text-D4HAPHm1.js +296 -0
  568. package/dist/status.command-8BU177X9.js +2 -0
  569. package/dist/status.command-yh7emvuM.js +420 -0
  570. package/dist/status.command.text-runtime-B8OpdGCG.js +15 -0
  571. package/dist/status.scan-BIuwlU6G.js +68 -0
  572. package/dist/status.scan-overview-r9Sk69iQ.js +444 -0
  573. package/dist/status.scan.fast-json-3nlHM3LS.js +2 -0
  574. package/dist/status.scan.fast-json-DnwGPJ0_.js +127 -0
  575. package/dist/status.scan.runtime-CgdduW2l.js +479 -0
  576. package/dist/status.scan.runtime.js +1 -1
  577. package/dist/status.update-BgFhUW7I.js +86 -0
  578. package/dist/status.update-rQL4_Irv.js +2 -0
  579. package/dist/sticker-cache-hPdFIaR8.js +206 -0
  580. package/dist/sticker-vision.runtime-CKwNUUYH.js +17 -0
  581. package/dist/sticker-vision.runtime.js +1 -1
  582. package/dist/subagent-announce-CPTinWX3.js +354 -0
  583. package/dist/subagent-announce-delivery-ohL5PocA.js +958 -0
  584. package/dist/subagent-control-BQDtHw6e.js +508 -0
  585. package/dist/subagent-hooks-BUKvlYGi.js +2 -0
  586. package/dist/subagent-hooks-CwwuJtIN.js +2 -0
  587. package/dist/subagent-hooks-D-6S1mpG.js +146 -0
  588. package/dist/subagent-hooks-DK4O9DHY.js +2 -0
  589. package/dist/subagent-hooks-DKrXETX6.js +230 -0
  590. package/dist/subagent-hooks-RtDD-o7f.js +116 -0
  591. package/dist/subagent-hooks-api-CSGGhB4Y.js +23 -0
  592. package/dist/subagent-hooks-api-Zf13FmkW.js +23 -0
  593. package/dist/subagent-hooks-api-fTY-dYum.js +22 -0
  594. package/dist/subagent-orphan-recovery-CR_zRTfz.js +352 -0
  595. package/dist/subagent-registry-BHt8-wIZ.js +2351 -0
  596. package/dist/subagent-registry-BuLz8xwh.js +3 -0
  597. package/dist/subagent-registry.runtime.js +1 -1
  598. package/dist/subagent-session-cleanup-D7ihbQFh.js +525 -0
  599. package/dist/subagent-spawn-OIztmjv_.js +1164 -0
  600. package/dist/target-id-DWzawpWq.js +107 -0
  601. package/dist/targets-B5V5WYoi.js +19 -0
  602. package/dist/targets-HIPV3dV_.js +44 -0
  603. package/dist/targets-sXOKpsPF.js +19 -0
  604. package/dist/task-registry-control.runtime.js +1 -1
  605. package/dist/telegram/token.js +1 -1
  606. package/dist/testing-a7plxbxs.js +267 -0
  607. package/dist/text-report-7eTN6lDu.js +695 -0
  608. package/dist/thread-bindings-CFgQ6p2l.js +228 -0
  609. package/dist/thread-bindings-CJgi2r1R.js +232 -0
  610. package/dist/thread-bindings-CSoJgsSu.js +8 -0
  611. package/dist/thread-bindings-DvMQHqPr.js +571 -0
  612. package/dist/thread-bindings.discord-api-Btr2o7Dq.js +187 -0
  613. package/dist/thread-bindings.manager-B2MjrNW8.js +536 -0
  614. package/dist/thread-bindings.manager-DrIh5eqv.js +2 -0
  615. package/dist/thread-lifecycle-9hfhP6NM.js +1614 -0
  616. package/dist/token-D1xw1VoL.js +134 -0
  617. package/dist/tool-DTcPPGeG.js +139 -0
  618. package/dist/tool-actions.runtime-RP-p2ohJ.js +534 -0
  619. package/dist/tool-actions.runtime.js +1 -1
  620. package/dist/tool-resolution-FQZNVA7E.js +149 -0
  621. package/dist/tools-effective-inventory-D4IsbxCS.js +204 -0
  622. package/dist/tools-invoke-http-kcbjM-Jl.js +67 -0
  623. package/dist/tools-invoke-shared-CETqKcCV.js +200 -0
  624. package/dist/tts-BMP6Xnk0.js +66 -0
  625. package/dist/tui-C36hUrre.js +2 -0
  626. package/dist/tui-DiM1ke7p.js +4709 -0
  627. package/dist/tui-backend-De30cpsu.js +256 -0
  628. package/dist/tui-cli-k2-5mPku.js +37 -0
  629. package/dist/update-check-Dq2TmP7u.js +372 -0
  630. package/dist/update-cli-CIH--yOA.js +3664 -0
  631. package/dist/update-runner-ON3AsN9h.js +2379 -0
  632. package/dist/update-startup-B1hNnHsG.js +2 -0
  633. package/dist/update-startup-DfHO6Sde.js +339 -0
  634. package/dist/vision-tools-B2EWe9pv.js +1409 -0
  635. package/dist/web-search-DPki3TB7.js +62 -0
  636. package/dist/web-search-provider.runtime-CwRj50RV.js +2 -0
  637. package/dist/web-search-provider.runtime-DvOOme-j.js +328 -0
  638. package/dist/web-search-provider.runtime.js +1 -1
  639. package/dist/xai-oauth-DtHB3Iav.js +479 -0
  640. package/dist/xai-user-agent-lpTplBOY.js +32 -0
  641. package/package.json +1 -1
  642. package/dist/abort-DI3P6TIb.js +0 -277
  643. package/dist/abort.runtime-B6Z7lDEa.js +0 -2
  644. package/dist/account-inspect-BFz7X0TX.js +0 -173
  645. package/dist/accounts-BoYYrY7x.js +0 -107
  646. package/dist/accounts-Busq29zW.js +0 -107
  647. package/dist/accounts-CuvH2tuN.js +0 -119
  648. package/dist/accounts-DkIcqvf7.js +0 -2
  649. package/dist/acp-runtime-BA8lzXzf.js +0 -26
  650. package/dist/acp-spawn-DPz2aX3A.js +0 -2
  651. package/dist/acp-spawn-DvVCsWYV.js +0 -1275
  652. package/dist/acp-stateful-target-driver-DcC76aZW.js +0 -89
  653. package/dist/action-kill-D-dVisIX.js +0 -33
  654. package/dist/action-runtime-BEiqwxDD.js +0 -469
  655. package/dist/action-runtime-api-1LzcGjcX.js +0 -2
  656. package/dist/action-send-c3CnDuPg.js +0 -39
  657. package/dist/action-spawn-Dj4kwpWs.js +0 -47
  658. package/dist/actions-qLccmQBc.js +0 -161
  659. package/dist/actions.runtime-B5vYAgNi.js +0 -5
  660. package/dist/agent-command-D6Ds198G.js +0 -1367
  661. package/dist/agent-components.runtime-xquK0B3L.js +0 -10
  662. package/dist/agent-harness-runtime-Dq1fCBOM.js +0 -180
  663. package/dist/agent-harness-task-runtime-DvSEqFkD.js +0 -140
  664. package/dist/agent-lm5ZYOFy.js +0 -3
  665. package/dist/agent-runner-execution-Dbh2pDhQ.js +0 -1713
  666. package/dist/agent-runner-utils-Di3r2T1T.js +0 -266
  667. package/dist/agent-runner.runtime-BW90EcGW.js +0 -3455
  668. package/dist/agent-runtime-BgIT5Ytc.js +0 -229
  669. package/dist/agent-via-gateway-DMMS8-hK.js +0 -463
  670. package/dist/agent-ylolD8-V.js +0 -2
  671. package/dist/api-BB4vXLtW.js +0 -2
  672. package/dist/api-CUhM3KNB.js +0 -134
  673. package/dist/api-CewRHSbT.js +0 -6
  674. package/dist/api-CfKjNJlW.js +0 -2
  675. package/dist/api-Rsnqui1u.js +0 -3
  676. package/dist/api-k7AvxwHr.js +0 -639
  677. package/dist/apply-DQ4TQNMA.js +0 -54
  678. package/dist/apply-S_75Py4Y.js +0 -41
  679. package/dist/approval-handler.runtime-Cthxrstu.js +0 -130
  680. package/dist/assistant-Cp9pGaBw.js +0 -291
  681. package/dist/attachment-normalize-5R0bLLOj.js +0 -225
  682. package/dist/attempt-execution-DuyyZYsU.js +0 -558
  683. package/dist/attempt-execution.runtime-DF2GPgNh.js +0 -3
  684. package/dist/attempt-execution.shared-CwdukA3t.js +0 -38
  685. package/dist/attempt.prompt-helpers-CUqKtIa5.js +0 -475
  686. package/dist/attempt.tool-run-context-BbN4_BYO.js +0 -2094
  687. package/dist/binding-routing-C6Ex2Blu.js +0 -113
  688. package/dist/binding-targets-BqREncSL.js +0 -121
  689. package/dist/bot-DGMEkaIJ.js +0 -7894
  690. package/dist/bot-deps-BltYjeMX.js +0 -2
  691. package/dist/bot-deps-XvGCor9f.js +0 -747
  692. package/dist/bot-message-context.runtime-kK-xvLV7.js +0 -7
  693. package/dist/bot-message-context.session.runtime-DpOIJUae.js +0 -12
  694. package/dist/bot-native-commands.delivery.runtime-D49p5Lc1.js +0 -4
  695. package/dist/bot-native-commands.runtime-8XBdSpkQ.js +0 -13
  696. package/dist/bridge-server-y_XGduPx.js +0 -113
  697. package/dist/browser-cli-B2jmmTT3.js +0 -230
  698. package/dist/browser-cli-actions-input-JQt5ZQcn.js +0 -473
  699. package/dist/browser-cli-actions-observe-CrfKh6AX.js +0 -81
  700. package/dist/browser-cli-debug-DQACWlvC.js +0 -137
  701. package/dist/browser-cli-inspect-DDnxx0Xw.js +0 -104
  702. package/dist/browser-cli-lEuOnZzs.js +0 -2
  703. package/dist/browser-cli-manage-DogmwtYt.js +0 -443
  704. package/dist/browser-cli-resize-BHuV71VZ.js +0 -26
  705. package/dist/browser-cli-shared-CidShgoF.js +0 -50
  706. package/dist/browser-cli-state-i8cCGbiQ.js +0 -337
  707. package/dist/browser-control-auth-CKfXdXWj.js +0 -2
  708. package/dist/browser-profiles-ATBTvUGh.js +0 -2
  709. package/dist/browser-runtime-KmCT6FuL.js +0 -384
  710. package/dist/build-DOOT6f62.js +0 -257
  711. package/dist/capability-cli-DwvrwB-g.js +0 -1782
  712. package/dist/channel-B-wgK1bK.js +0 -481
  713. package/dist/channel-B1e_k1P0.js +0 -867
  714. package/dist/channel-BRDfa5tc.js +0 -1777
  715. package/dist/channel-BVEO1O4p.js +0 -376
  716. package/dist/channel-BYlO5l1d.js +0 -508
  717. package/dist/channel-BdhbzWTg.d.ts +0 -427
  718. package/dist/channel-Bl0sPoNx.js +0 -653
  719. package/dist/channel-C84xtDBy.js +0 -1134
  720. package/dist/channel-CLgKq4Ds.js +0 -1556
  721. package/dist/channel-CZT0qxLh.js +0 -1249
  722. package/dist/channel-CffBHWkb.js +0 -955
  723. package/dist/channel-D34ZJvVB.js +0 -2126
  724. package/dist/channel-DcdXLo_W.js +0 -238
  725. package/dist/channel-DnK5TrXV.js +0 -362
  726. package/dist/channel-Dzj4RHY2.js +0 -740
  727. package/dist/channel-OhZzLZCj.js +0 -562
  728. package/dist/channel-actions.runtime-Cdvhqc9s.js +0 -265
  729. package/dist/channel-core-Dz9I_R4j.js +0 -5
  730. package/dist/channel-inbound-COGoV_aS.js +0 -80
  731. package/dist/channel-mP6HCIMr.js +0 -1496
  732. package/dist/channel-plugin-runtime-C0R46KeG.js +0 -998
  733. package/dist/channel-quGdgWel.js +0 -808
  734. package/dist/channel-runtime-FvPQoIF9.js +0 -408
  735. package/dist/channel.runtime-2vUz3gij.js +0 -109
  736. package/dist/channel.runtime-BZLDSNuQ.js +0 -254
  737. package/dist/channel.runtime-Bo5jO0Hj.js +0 -4
  738. package/dist/channel.runtime-CDgvrjM2.js +0 -652
  739. package/dist/channel.runtime-COf8SDFn.js +0 -88
  740. package/dist/channel.runtime-C_C1f8lu.js +0 -733
  741. package/dist/channel.runtime-CqPbsg8t.js +0 -2528
  742. package/dist/channel.runtime-DtV85Khx.js +0 -1008
  743. package/dist/channel.runtime-Spt1ukGW.js +0 -21009
  744. package/dist/channel.setup-Bc0LUQS1.js +0 -1098
  745. package/dist/channel.setup-ChTkj2hq.js +0 -343
  746. package/dist/channel.setup-CpMD9F8i.js +0 -10
  747. package/dist/chat-mUsjD5YN.js +0 -2666
  748. package/dist/chrome-u314zcbM.js +0 -1503
  749. package/dist/cli-CJMoqXrc.js +0 -1341
  750. package/dist/cli-compaction-qGYB7suI.js +0 -347
  751. package/dist/cli-metadata-BBJFpNU9.js +0 -22
  752. package/dist/cli-runner-C0kcts0I.js +0 -540
  753. package/dist/cli-runner-CTm8K6s8.js +0 -2
  754. package/dist/cli-runner.runtime-C8deL5FL.js +0 -3
  755. package/dist/cli-runner.runtime-DDAg1D0L.js +0 -4
  756. package/dist/client-CPxpgs4m.js +0 -650
  757. package/dist/client-adapter-CLlqOqfu.js +0 -897
  758. package/dist/client-factory-R7Rr2jwn.js +0 -9
  759. package/dist/command-auth-CkQP1buP.js +0 -135
  760. package/dist/command-handlers-CJEjFyMk.js +0 -1609
  761. package/dist/command-registry-BDgyOqDw.js +0 -4
  762. package/dist/command-registry-BVi5Jn1S.js +0 -9
  763. package/dist/command-registry-core-JCfsVRtz.js +0 -110
  764. package/dist/command-status.runtime-CM1JLzi6.js +0 -90
  765. package/dist/commands-acp-C1-I78U6.js +0 -74
  766. package/dist/commands-compact.runtime-DOsNavwp.js +0 -10
  767. package/dist/commands-handlers.runtime-BD1n2WGw.js +0 -6154
  768. package/dist/commands-status-DU_UTQz1.js +0 -16
  769. package/dist/commands-status-DejfTakp.js +0 -3
  770. package/dist/commands-status.runtime-DejfTakp.js +0 -3
  771. package/dist/commands-subagents-control.runtime-D7vo_2Y_.js +0 -3
  772. package/dist/commands-subagents-control.runtime-DGybTjJ6.js +0 -2
  773. package/dist/commands-system-prompt-BEBXAMea.js +0 -2
  774. package/dist/commands-system-prompt-gj3oQpQO.js +0 -162
  775. package/dist/commands.runtime-CgXX70IN.js +0 -176
  776. package/dist/compact-C41XxMDt.js +0 -480
  777. package/dist/compact-DUVAF9EC.js +0 -1141
  778. package/dist/compact.runtime-COMRg6s3.js +0 -12
  779. package/dist/completion-cli-CmEYoB9a.js +0 -315
  780. package/dist/computer-use-BwJHu1QF.js +0 -367
  781. package/dist/config-ATBTvUGh.js +0 -2
  782. package/dist/config-DlNgjF8W.js +0 -373
  783. package/dist/config-mutations-tl_OqI6d.js +0 -159
  784. package/dist/context-engine-host-compat-BNPAIK9F.js +0 -288
  785. package/dist/context-engine-host-compat-C69CK7zS.js +0 -2
  786. package/dist/context-engine-lifecycle-iQ8f5a_-.js +0 -1274
  787. package/dist/control-auth-vVxyGKxY.js +0 -114
  788. package/dist/control-service-73nj79EW.js +0 -145
  789. package/dist/control-ui/assets/agents-DdWIz8Vk.js +0 -1008
  790. package/dist/control-ui/assets/channel-config-extras-C7ELhuDi.js +0 -2
  791. package/dist/control-ui/assets/channels-Bsoj-9BS.js +0 -367
  792. package/dist/control-ui/assets/cron-BRTEw1tT.js +0 -1013
  793. package/dist/control-ui/assets/debug-EKl_F8_L.js +0 -97
  794. package/dist/control-ui/assets/index-DSbSO7ys.js +0 -7370
  795. package/dist/control-ui/assets/instances-B1AoYwI5.js +0 -57
  796. package/dist/control-ui/assets/logs-BChOznzh.js +0 -74
  797. package/dist/control-ui/assets/nodes-5yebKh9k.js +0 -436
  798. package/dist/control-ui/assets/sessions-BlDYNThc.js +0 -399
  799. package/dist/control-ui/assets/skills-shared-CNFnf7KU.js +0 -11
  800. package/dist/control-ui/assets/skills-uxTDRmLx.js +0 -314
  801. package/dist/conversation-binding-runtime-CmoTKcY1.js +0 -4
  802. package/dist/conversation-runtime-BxOHxuin.js +0 -31
  803. package/dist/core-D0Y2H55f.js +0 -282
  804. package/dist/core-api-BKlJUtDt.js +0 -5
  805. package/dist/core-api-_fiftUHn.js +0 -2
  806. package/dist/crestodian-BJifoQiR.js +0 -55
  807. package/dist/daocore-tools-BMdF8RwK.js +0 -11727
  808. package/dist/delivery-e2ci_bcX.js +0 -1002
  809. package/dist/dialogue-BXayGhnz.js +0 -37
  810. package/dist/dir-fetch-tool-Cara5mZh.js +0 -565
  811. package/dist/dir-list-tool-CQ8Bo5Ez.js +0 -100
  812. package/dist/direct-dm-CPk6Qm9D.js +0 -64
  813. package/dist/directive-handling.fast-lane-BQ9aXqk8.js +0 -68
  814. package/dist/directive-handling.impl--a5AGurq.js +0 -818
  815. package/dist/directive-handling.impl-C4JqMwle.js +0 -2
  816. package/dist/directive-handling.model-selection-pyTYMIXn.js +0 -122
  817. package/dist/directive-handling.persist.runtime-B7vWT1r9.js +0 -263
  818. package/dist/dispatch-3Ru_eGq1.js +0 -1640
  819. package/dist/dispatch-acp-transcript.runtime-CYMP-5oE.js +0 -40
  820. package/dist/dispatch-acp.runtime-BVCiklXk.js +0 -18
  821. package/dist/doctor-B8mR3Sgr.js +0 -2
  822. package/dist/doctor-BJ6DuerV.js +0 -6
  823. package/dist/doctor-config-flow-BdOGs_zn.js +0 -1741
  824. package/dist/doctor-core-checks-CDf0stz-.js +0 -2
  825. package/dist/doctor-core-checks-Cpdnu2XI.js +0 -573
  826. package/dist/doctor-health-0qv_acBu.js +0 -65
  827. package/dist/doctor-health-contributions-Db1FQgFw.js +0 -696
  828. package/dist/doctor-lint-C1g4Llgl.js +0 -94
  829. package/dist/doctor-state-integrity-C8iXFLJ7.js +0 -1231
  830. package/dist/doctor-update-CsPu6p3d.js +0 -58
  831. package/dist/dynamic-tools-YQ0z0YKH.js +0 -486
  832. package/dist/embedded-backend-S0cahIZw.js +0 -579
  833. package/dist/embedded-gateway-stub.runtime-Cjw12ALm.js +0 -12
  834. package/dist/exec-approvals-ArHHjoE-.js +0 -149
  835. package/dist/file-fetch-tool-DQpAtjX4.js +0 -124
  836. package/dist/file-write-tool-CkB0oYwe.js +0 -127
  837. package/dist/format-BUFz60TQ.js +0 -250
  838. package/dist/format-DUJUpMFQ.js +0 -1145
  839. package/dist/gateway-cli-CQo_E4Ka.js +0 -435
  840. package/dist/gateway-method-runtime-1QPgVJH7.js +0 -21
  841. package/dist/get-reply-DfUcsC-O.js +0 -4689
  842. package/dist/get-reply-from-config.runtime-C95MG73O.js +0 -2
  843. package/dist/graph-users-DPJe0fPs.js +0 -1419
  844. package/dist/group-access-DefaNJ6L.js +0 -112
  845. package/dist/handle-action.guild-admin-C1sy1kGJ.js +0 -288
  846. package/dist/harness-BgPRdmNK.js +0 -61
  847. package/dist/health-DFR9A1YV.js +0 -4
  848. package/dist/health-state-BT1WDbbs.js +0 -106
  849. package/dist/heartbeat-runner-BiYVPs25.js +0 -5
  850. package/dist/heartbeat-runner.runtime-Bmaq8WUA.js +0 -4
  851. package/dist/hooks-CNJDuJUm.js +0 -534
  852. package/dist/inbound-direct-dm-runtime-DFt58p71.js +0 -2
  853. package/dist/inbound-reply-dispatch-kgSDM8ax.js +0 -148
  854. package/dist/init-B0zO_U4r.js +0 -59
  855. package/dist/inline-buttons-B6zgQW3J.js +0 -40
  856. package/dist/internal-events-C3Q5t6hg.js +0 -90
  857. package/dist/isolated-agent-CaSU5GCJ.js +0 -2
  858. package/dist/isolated-agent-CnsD2TmP.js +0 -1118
  859. package/dist/lifecycle-i3WZDaIn.js +0 -571
  860. package/dist/list.probe-g0rUiVXW.js +0 -449
  861. package/dist/list.status-command-DG3PrmeO.js +0 -789
  862. package/dist/llm-slug-generator-CHlf69FU.js +0 -78
  863. package/dist/local-dispatch.runtime-CDeHUp_A.js +0 -9
  864. package/dist/manager.runtime-BlLMPUTq.js +0 -2714
  865. package/dist/markdown-to-line-r_mBHMdy.js +0 -811
  866. package/dist/mcp-http-C5UPIJGR.js +0 -555
  867. package/dist/mcp-http-CTy9gpfA.js +0 -2
  868. package/dist/media-understanding-provider-BT6TOuVa.js +0 -339
  869. package/dist/message-actions-BdcjjwFt.js +0 -145
  870. package/dist/message-handler-B29Tj2p2.js +0 -1715
  871. package/dist/message-handler-BhHb1FHI.js +0 -384
  872. package/dist/message-handler.preflight-ouZ_-3o8.js +0 -1125
  873. package/dist/message-handler.process-CrYiBx_F.js +0 -1484
  874. package/dist/model-CLbtocQX.js +0 -74
  875. package/dist/model-selection-BG_vU9Kl.js +0 -272
  876. package/dist/models-4KERn3ya.js +0 -104
  877. package/dist/models-BCa-ipxi.js +0 -2
  878. package/dist/models-cli-DtpGXEsf.js +0 -256
  879. package/dist/monitor-B-egsvmI.js +0 -1657
  880. package/dist/monitor-BJX9Yv7k.js +0 -2
  881. package/dist/monitor-BPrIy3pV.js +0 -715
  882. package/dist/monitor-BWknZZ7N.js +0 -4377
  883. package/dist/monitor-C3y_PtI1.js +0 -60
  884. package/dist/monitor-DCzfdqE4.js +0 -1370
  885. package/dist/monitor-P24epSwE.js +0 -2788
  886. package/dist/monitor-auth-CEG_xldE.js +0 -179
  887. package/dist/monitor-jEePJbbS.js +0 -834
  888. package/dist/monitor-polling.runtime-BzlHK11u.js +0 -883
  889. package/dist/monitor-webhook.runtime-vFEhk_Zj.js +0 -387
  890. package/dist/monitor.account-BUIfgWXg.js +0 -5233
  891. package/dist/monitor.runtime-Cp7W4fhb.js +0 -2
  892. package/dist/monitor.webhook-DzrbeR4T.js +0 -180
  893. package/dist/node-cli-sessions-CLbI14UA.js +0 -1228
  894. package/dist/openai-http-BM9BIA_g.js +0 -824
  895. package/dist/openresponses-http-CNoW9kk8.js +0 -1173
  896. package/dist/operations-DT4bsxV6.js +0 -805
  897. package/dist/outbound-adapter-CZRUOgY0.js +0 -543
  898. package/dist/outbound-session-route-DneMsGNx.js +0 -45
  899. package/dist/outbound.runtime-CHuoKJJI.js +0 -2
  900. package/dist/pi-embedded-1-rsueO_.js +0 -3796
  901. package/dist/pi-embedded-BRfDncVO.js +0 -4
  902. package/dist/pi-embedded.runtime-DEYoa6bW.js +0 -4
  903. package/dist/pi-tools-C0P3NgP5.js +0 -2413
  904. package/dist/plan-BQUkjBMY.js +0 -81
  905. package/dist/plan-CRO9_2_k.js +0 -112
  906. package/dist/plugin-BJCmWhnh.js +0 -12396
  907. package/dist/plugin-app-cache-key-CXAg0F7A.js +0 -46
  908. package/dist/plugin-enabled-D93Z9LSo.js +0 -233
  909. package/dist/plugin-registration-BBrTcZnf.js +0 -88
  910. package/dist/plugin-service-DnZEPBEA.js +0 -1229
  911. package/dist/policy-CMv5QMPG.js +0 -138
  912. package/dist/policy-CeoP4t9J.js +0 -680
  913. package/dist/prepare.runtime-DZ55JiTt.js +0 -732
  914. package/dist/preview-warnings-O08PZRxu.js +0 -392
  915. package/dist/probe-C6w3bP8X.js +0 -682
  916. package/dist/probe-Cs1_X1NA.js +0 -47
  917. package/dist/probe-Cuee_jyM.js +0 -2204
  918. package/dist/probe-DZxCnDzn.js +0 -2
  919. package/dist/program-C2dT8VHB.js +0 -131
  920. package/dist/provider-C2_vSzYh.js +0 -32
  921. package/dist/provider-DSfTDQbj.js +0 -152
  922. package/dist/provider-U8hrm9h-.js +0 -32
  923. package/dist/provider-_v910H8y.js +0 -8735
  924. package/dist/provider-dispatcher-C3kmmIEC.js +0 -22
  925. package/dist/provider-session.runtime-Mg0fx5hH.js +0 -9
  926. package/dist/provider.runtime-pSTXuHrq.js +0 -2
  927. package/dist/public-surface-loader-09t4TTue.js +0 -114
  928. package/dist/pw-ai-DjNqHV3_.js +0 -3029
  929. package/dist/pw-role-snapshot-DoGefdv7.js +0 -333
  930. package/dist/reaction-level-C8Mqxizo.js +0 -19
  931. package/dist/reaction-runtime-api-DOP6xOsm.js +0 -116
  932. package/dist/realtime-transcription-provider-BTGEXXna.js +0 -205
  933. package/dist/register-CbZPpqI3.js +0 -2178
  934. package/dist/register.agent-DrBFuPKh.js +0 -156
  935. package/dist/register.crestodian-DwTbmaK8.js +0 -24
  936. package/dist/register.maintenance-BIeoYBub.js +0 -83
  937. package/dist/register.runtime-B5V9_Dwz.js +0 -54
  938. package/dist/register.status-health-sessions-Bt261Z8-.js +0 -282
  939. package/dist/register.subclis-CJE9ISZY.js +0 -31
  940. package/dist/register.subclis-YQsKas8N.js +0 -3
  941. package/dist/register.subclis-core-CjwdGeGU.js +0 -273
  942. package/dist/repair-sequencing-C0jrL5pw.js +0 -640
  943. package/dist/reply-delivery-B28mTIpb.js +0 -196
  944. package/dist/reply-runtime-BqQX7HHw.js +0 -11
  945. package/dist/reply.runtime-C95MG73O.js +0 -2
  946. package/dist/request-BqoMvXxH.js +0 -54
  947. package/dist/resolve-allowlist-hbKKd_kq.js +0 -220
  948. package/dist/result-fallback-classifier-BrORPoxj.js +0 -79
  949. package/dist/route-HHRgSzVy.js +0 -469
  950. package/dist/route-resolution-C7bafjVc.js +0 -274
  951. package/dist/routes-86XGeo7a.js +0 -2
  952. package/dist/routes-BhVGr9ie.js +0 -3602
  953. package/dist/run-Bb5QP5JV.js +0 -1162
  954. package/dist/run-attempt-CLi0wV7j.js +0 -7704
  955. package/dist/run-command-Be6GAxiW.js +0 -2
  956. package/dist/run-command-Ds4hr3iU.js +0 -23
  957. package/dist/run-embedded.runtime-wX9ORojX.js +0 -4
  958. package/dist/run-execution-cli.runtime-BmNZVB2N.js +0 -4
  959. package/dist/run-subagent-registry.runtime-Uq5sjftu.js +0 -2
  960. package/dist/runtime-BktLQ75j.js +0 -1287
  961. package/dist/runtime-C9XdR62_.js +0 -438
  962. package/dist/runtime-CTvWDPx9.js +0 -6179
  963. package/dist/runtime-api-BojB3MUw.js +0 -21
  964. package/dist/runtime-api-C92MlAwp.js +0 -13
  965. package/dist/runtime-api-CFNZE9Xt.js +0 -13
  966. package/dist/runtime-api-Cimpgm5_.js +0 -3
  967. package/dist/runtime-api-D8qG_lUm.js +0 -17
  968. package/dist/runtime-api-DMDMnQEG.js +0 -4
  969. package/dist/runtime-api-DupQdIlE.js +0 -24
  970. package/dist/runtime-api.actions-B8i3elqu.js +0 -3
  971. package/dist/runtime-api.monitor-BntFzf_M.js +0 -6
  972. package/dist/runtime-api.send-CPlmi1jc.js +0 -4
  973. package/dist/runtime-api.threads-D-H_r_Nl.js +0 -2
  974. package/dist/runtime-channel-BGhTxnXZ.js +0 -150
  975. package/dist/runtime-channel-CPFxNapZ.js +0 -2
  976. package/dist/runtime-embedded-pi.runtime-BjnMTurB.js +0 -2
  977. package/dist/sanitize-outbound-BMUv1NeS.js +0 -127
  978. package/dist/sdk-setup-tools-Do3DkQi_.js +0 -8
  979. package/dist/secrets-B8YVPHhk.js +0 -113
  980. package/dist/security-audit-7Gg_nL4o.js +0 -122
  981. package/dist/security-audit-Bk3CREj-.js +0 -118
  982. package/dist/security-audit.runtime-BmSJrdeq.js +0 -2
  983. package/dist/selection-BFGde9-_.js +0 -3
  984. package/dist/selection-DrLFlbgG.js +0 -16157
  985. package/dist/send-4dLa-BQo.js +0 -1631
  986. package/dist/send-CV6gCwYP.js +0 -192
  987. package/dist/send-aGiK3Efu.js +0 -143
  988. package/dist/send-dB3CehAN.js +0 -2
  989. package/dist/send.components-BcG9BlkC.js +0 -2
  990. package/dist/send.components-rLjDlfYU.js +0 -500
  991. package/dist/send.runtime-D20k2MSr.js +0 -2
  992. package/dist/server-BTRx_U1s.js +0 -73
  993. package/dist/server-CY0ymhBg.js +0 -24
  994. package/dist/server-context-BxGT8wbK.js +0 -955
  995. package/dist/server-context-DYlbhAaT.js +0 -2
  996. package/dist/server-cron-BB_15lcP.js +0 -2
  997. package/dist/server-cron-CfyJX_a4.js +0 -2989
  998. package/dist/server-maintenance-BwJ3OO_l.js +0 -167
  999. package/dist/server-methods-Ck2ab6TC.js +0 -16494
  1000. package/dist/server-node-events-BdRizF-5.js +0 -596
  1001. package/dist/server-plugin-bootstrap-CPUr8NFE.js +0 -70
  1002. package/dist/server-plugins-__5AxjzH.js +0 -432
  1003. package/dist/server-reload-handlers-BMl9Fx9b.js +0 -714
  1004. package/dist/server-restart-sentinel-D11M_ZsH.js +0 -747
  1005. package/dist/server-restart-sentinel-DGptQ27c.js +0 -2
  1006. package/dist/server-runtime-services-BwtLs-8I.js +0 -2
  1007. package/dist/server-runtime-services-aJydixRu.js +0 -267
  1008. package/dist/server-startup-early-CIW_gExj.js +0 -87
  1009. package/dist/server-startup-plugins-m_P3gY4m.js +0 -113
  1010. package/dist/server-startup-post-attach-DuXQ1AXL.js +0 -716
  1011. package/dist/server-ws-runtime-mXmxB1W8.js +0 -349
  1012. package/dist/server.impl-fuV8aKSP.js +0 -2586
  1013. package/dist/service-a8cTFka4.js +0 -1446
  1014. package/dist/session-binding-BIycxo9u.js +0 -2
  1015. package/dist/session-binding-xHwQr9vM.js +0 -219
  1016. package/dist/session-kill-http-DiUZhcoN.js +0 -121
  1017. package/dist/session-reset-service-DkepDoob.js +0 -625
  1018. package/dist/session-route-Ba5u7ecb.js +0 -93
  1019. package/dist/session-status.runtime-Cb1X69Rl.js +0 -2
  1020. package/dist/session-subagent-reactivation.runtime-rbqmto4G.js +0 -2
  1021. package/dist/session-tab-registry-DSKOoJta.js +0 -521
  1022. package/dist/sessions-history-http-CWP88I_C.js +0 -430
  1023. package/dist/sessions.runtime-1q1OwLn3.js +0 -2
  1024. package/dist/setup-api-DtrOOYeP.js +0 -29
  1025. package/dist/setup-core-DMrJS6LP.js +0 -174
  1026. package/dist/setup-surface-BFPNu1qA.js +0 -405
  1027. package/dist/setup-surface-CedShqhO.js +0 -288
  1028. package/dist/setup-surface-DLOBH1Vf.js +0 -320
  1029. package/dist/setup-surface-MhCeEWSj.js +0 -221
  1030. package/dist/shared-DamL-e8D.js +0 -121
  1031. package/dist/shared-client-B48JoAsz.js +0 -2
  1032. package/dist/shared-client-BoSiDnUo.js +0 -629
  1033. package/dist/side-question-DQoQ_ETb.js +0 -683
  1034. package/dist/skill-tool-dispatch.runtime-CWLloYA8.js +0 -143
  1035. package/dist/slash-state-DrrWJQfv.js +0 -2166
  1036. package/dist/speech-provider-8Hx1uw41.js +0 -184
  1037. package/dist/src-BbUYOPwU.js +0 -4256
  1038. package/dist/startup-context-opAJAamX.js +0 -313
  1039. package/dist/status-BzYEqfpS.js +0 -3
  1040. package/dist/status-DEkjbQ1i.js +0 -4
  1041. package/dist/status-all-Ms1tbq5v.js +0 -573
  1042. package/dist/status-json-UE2-MKTi.js +0 -14
  1043. package/dist/status-json-command-m7JqlonZ.js +0 -84
  1044. package/dist/status-runtime-shared-ByKptq1l.js +0 -283
  1045. package/dist/status-subagents.runtime-DSo7ZK_Z.js +0 -18
  1046. package/dist/status-text-AyPuDzrO.js +0 -296
  1047. package/dist/status.command-CkX3w3hv.js +0 -2
  1048. package/dist/status.command-DH5UrKNz.js +0 -420
  1049. package/dist/status.command.text-runtime-4UIQj9vb.js +0 -15
  1050. package/dist/status.scan-BRv7Br3F.js +0 -68
  1051. package/dist/status.scan-overview-BcD2pLMY.js +0 -444
  1052. package/dist/status.scan.fast-json-2dm_6iq-.js +0 -127
  1053. package/dist/status.scan.fast-json-BkkA55xn.js +0 -2
  1054. package/dist/status.scan.runtime-Bfv4GvoC.js +0 -479
  1055. package/dist/status.update-BQyHDWCY.js +0 -86
  1056. package/dist/status.update-I3jq8Q9m.js +0 -2
  1057. package/dist/sticker-cache-91Tp8mLP.js +0 -206
  1058. package/dist/sticker-vision.runtime-DjleFXi5.js +0 -17
  1059. package/dist/subagent-announce-delivery-DS_2W9oZ.js +0 -958
  1060. package/dist/subagent-announce-hatA_PZ2.js +0 -354
  1061. package/dist/subagent-control-IyFIvc7T.js +0 -508
  1062. package/dist/subagent-hooks-BCj5eB0Z.js +0 -2
  1063. package/dist/subagent-hooks-BWjTBkox.js +0 -146
  1064. package/dist/subagent-hooks-CdGLK9_3.js +0 -230
  1065. package/dist/subagent-hooks-EH0tBkw9.js +0 -2
  1066. package/dist/subagent-hooks-api-BhYaXQJV.js +0 -23
  1067. package/dist/subagent-hooks-api-uGsV8Xn5.js +0 -22
  1068. package/dist/subagent-hooks-api-wfJFKIPx.js +0 -23
  1069. package/dist/subagent-hooks-l8Xd94dt.js +0 -2
  1070. package/dist/subagent-hooks-m2eHUO_d.js +0 -116
  1071. package/dist/subagent-orphan-recovery-Bq9zvX3L.js +0 -352
  1072. package/dist/subagent-registry-Bcb3zy6b.js +0 -3
  1073. package/dist/subagent-registry-CoZNTFx-.js +0 -2351
  1074. package/dist/subagent-session-cleanup--00EjDLe.js +0 -525
  1075. package/dist/subagent-spawn-ClJJkz3D.js +0 -1164
  1076. package/dist/target-id-BsZLiF3x.js +0 -107
  1077. package/dist/targets-CQMe4AZP.js +0 -44
  1078. package/dist/targets-SmL1AU-H.js +0 -19
  1079. package/dist/targets-Y-roiA47.js +0 -19
  1080. package/dist/testing-B5hNJDuF.js +0 -267
  1081. package/dist/text-report-xqi7wg86.js +0 -695
  1082. package/dist/thread-bindings-BD3eE0kK.js +0 -232
  1083. package/dist/thread-bindings-C9NNiv8K.js +0 -571
  1084. package/dist/thread-bindings-Dl4PN1vZ.js +0 -228
  1085. package/dist/thread-bindings-uK1LLAwy.js +0 -8
  1086. package/dist/thread-bindings.discord-api-BHNEUbnk.js +0 -187
  1087. package/dist/thread-bindings.manager-B0LXiH3F.js +0 -2
  1088. package/dist/thread-bindings.manager-BTlH4XMG.js +0 -536
  1089. package/dist/thread-lifecycle-DG8uyPHd.js +0 -1614
  1090. package/dist/token-BbGCANnE.js +0 -134
  1091. package/dist/tool-actions.runtime-oUUrD8HB.js +0 -534
  1092. package/dist/tool-bqg-_vYv.js +0 -139
  1093. package/dist/tool-resolution-CSZsa3kP.js +0 -149
  1094. package/dist/tools-effective-inventory-0CqFp-vq.js +0 -204
  1095. package/dist/tools-invoke-http-DhYHY0Yh.js +0 -67
  1096. package/dist/tools-invoke-shared-CbVJJUj7.js +0 -200
  1097. package/dist/tts-C2qD-ad6.js +0 -66
  1098. package/dist/tui-CzGY254f.js +0 -4709
  1099. package/dist/tui-backend-fzoeoSN0.js +0 -256
  1100. package/dist/tui-cli-B2RWb2gM.js +0 -37
  1101. package/dist/tui-dgS8hdXU.js +0 -2
  1102. package/dist/update-check-Cv1EQVBi.js +0 -372
  1103. package/dist/update-cli-BmiBDf3c.js +0 -3664
  1104. package/dist/update-runner-CM7QVX6u.js +0 -2379
  1105. package/dist/update-startup-Byh39VP6.js +0 -339
  1106. package/dist/update-startup-DdWr4m3x.js +0 -2
  1107. package/dist/vision-tools-BzoBZnIc.js +0 -1409
  1108. package/dist/web-search-DmfOd66S.js +0 -62
  1109. package/dist/web-search-provider.runtime-3C5-pODD.js +0 -328
  1110. package/dist/web-search-provider.runtime-Doh-Z9We.js +0 -2
  1111. package/dist/xai-oauth-BLvQ43hx.js +0 -479
  1112. package/dist/xai-user-agent-BdMQ_0_O.js +0 -32
  1113. /package/dist/{acp-runtime-backend-Cxo7eBHf.js → acp-runtime-backend-Cn6L41Tg.js} +0 -0
  1114. /package/dist/{channel-actions-UDeVjgGz.js → channel-actions-8G0w3eC5.js} +0 -0
  1115. /package/dist/{command-status-runtime-CoHd4Fws.js → command-status-runtime-DEkrRb2G.js} +0 -0
  1116. /package/dist/{delegate-B-2xZ77o.js → delegate-CIrV5fYx.js} +0 -0
  1117. /package/dist/{dispatch-acp-DLPkmK7K.js → dispatch-acp-DSCi-ptu.js} +0 -0
  1118. /package/dist/{heartbeat-runner-D2j6JwOI.js → heartbeat-runner-D_Iq9CmQ.js} +0 -0
  1119. /package/dist/{library-DBT0cIPP.js → library-DhnQegiK.js} +0 -0
  1120. /package/dist/{run-executor.runtime-DE4J7f4M.js → run-executor.runtime-feFJuDlS.js} +0 -0
  1121. /package/dist/{shared-xeo8Yh5n.js → shared-docD3l41.js} +0 -0
@@ -0,0 +1,1409 @@
1
+ import { i as emitTrustedDiagnosticEvent } from "./diagnostic-events-DPfGiEBK.js";
2
+ import { _ as buildAgentHookContextChannelFields } from "./attempt.prompt-helpers-DTLTH3Mn.js";
3
+ import { u as runBeforeToolCallHook } from "./pi-tools.before-tool-call-Cl9Ivz5u.js";
4
+ import { t as callGatewayTool } from "./gateway-Dyc7qEu3.js";
5
+ import { t as log } from "./logger-DYJ7BvAc.js";
6
+ import { t as formatApprovalDisplayPath } from "./approval-display-paths-BqRczx-P.js";
7
+ import "./agent-harness-runtime-CHrYKoTd.js";
8
+ import { n as hasNativeHookRelayInvocation, r as invokeNativeHookRelay } from "./native-hook-relay-D1fhxt1n.js";
9
+ import { t as isJsonObject } from "./protocol-oeJQu4rs.js";
10
+ import { s as formatCodexDisplayText } from "./notification-correlation-qKY_sgga.js";
11
+ import { createHash } from "node:crypto";
12
+ //#region extensions/codex/src/app-server/plugin-approval-roundtrip.ts
13
+ const DEFAULT_CODEX_APPROVAL_TIMEOUT_MS = 12e4;
14
+ const MAX_PLUGIN_APPROVAL_TITLE_LENGTH = 80;
15
+ const MAX_PLUGIN_APPROVAL_DESCRIPTION_LENGTH = 256;
16
+ async function requestPluginApproval(params) {
17
+ const timeoutMs = DEFAULT_CODEX_APPROVAL_TIMEOUT_MS;
18
+ return callGatewayTool("plugin.approval.request", { timeoutMs: 13e4 }, {
19
+ pluginId: "daocore-codex-app-server",
20
+ title: truncateForGateway(params.title, MAX_PLUGIN_APPROVAL_TITLE_LENGTH),
21
+ description: truncateForGateway(params.description, MAX_PLUGIN_APPROVAL_DESCRIPTION_LENGTH),
22
+ severity: params.severity,
23
+ toolName: params.toolName,
24
+ toolCallId: params.toolCallId,
25
+ agentId: params.paramsForRun.agentId,
26
+ sessionKey: params.paramsForRun.sessionKey,
27
+ turnSourceChannel: params.paramsForRun.messageChannel ?? params.paramsForRun.messageProvider,
28
+ turnSourceTo: params.paramsForRun.currentChannelId,
29
+ turnSourceAccountId: params.paramsForRun.agentAccountId,
30
+ turnSourceThreadId: params.paramsForRun.currentThreadTs,
31
+ timeoutMs,
32
+ twoPhase: true
33
+ }, { expectFinal: false });
34
+ }
35
+ function approvalRequestExplicitlyUnavailable(result) {
36
+ if (result === null || result === void 0 || typeof result !== "object") return false;
37
+ let descriptor;
38
+ try {
39
+ descriptor = Object.getOwnPropertyDescriptor(result, "decision");
40
+ } catch {
41
+ return false;
42
+ }
43
+ return descriptor !== void 0 && "value" in descriptor && descriptor.value === null;
44
+ }
45
+ async function waitForPluginApprovalDecision(params) {
46
+ const waitPromise = callGatewayTool("plugin.approval.waitDecision", { timeoutMs: 13e4 }, { id: params.approvalId });
47
+ if (!params.signal) return (await waitPromise)?.decision;
48
+ let onAbort;
49
+ const abortPromise = new Promise((_, reject) => {
50
+ if (params.signal.aborted) {
51
+ reject(params.signal.reason);
52
+ return;
53
+ }
54
+ onAbort = () => reject(params.signal.reason);
55
+ params.signal.addEventListener("abort", onAbort, { once: true });
56
+ });
57
+ try {
58
+ return (await Promise.race([waitPromise, abortPromise]))?.decision;
59
+ } finally {
60
+ if (onAbort) params.signal.removeEventListener("abort", onAbort);
61
+ }
62
+ }
63
+ function mapExecDecisionToOutcome(decision) {
64
+ if (decision === "allow-once") return "approved-once";
65
+ if (decision === "allow-always") return "approved-session";
66
+ if (decision === null || decision === void 0) return "unavailable";
67
+ return "denied";
68
+ }
69
+ function truncateForGateway(value, maxLength) {
70
+ return value.length <= maxLength ? value : `${value.slice(0, Math.max(0, maxLength - 3))}...`;
71
+ }
72
+ //#endregion
73
+ //#region extensions/codex/src/app-server/approval-bridge.ts
74
+ const PERMISSION_DESCRIPTION_MAX_LENGTH = 700;
75
+ const PERMISSION_SAMPLE_LIMIT = 2;
76
+ const PERMISSION_VALUE_MAX_LENGTH = 48;
77
+ const COMMAND_PREVIEW_WITH_DETAILS_MAX_LENGTH = 80;
78
+ const APPROVAL_PREVIEW_SCAN_MAX_LENGTH = 4096;
79
+ const APPROVAL_PREVIEW_OMITTED = "[preview truncated or unsafe content omitted]";
80
+ const ANSI_OSC_SEQUENCE_RE$1 = new RegExp(String.raw`(?:\u001b]|\u009d)[^\u001b\u009c\u0007]*(?:\u0007|\u001b\\|\u009c)`, "g");
81
+ const ANSI_CONTROL_SEQUENCE_RE$1 = new RegExp(String.raw`(?:\u001b\[[0-?]*[ -/]*[@-~]|\u009b[0-?]*[ -/]*[@-~]|\u001b[@-Z\\-_])`, "g");
82
+ const CONTROL_CHARACTER_RE$1 = new RegExp(String.raw`[\u0000-\u001f\u007f-\u009f]+`, "g");
83
+ const INVISIBLE_FORMATTING_CONTROL_RE$1 = new RegExp(String.raw`[\u00ad\u034f\u061c\u200b-\u200f\u202a-\u202e\u2060-\u206f\ufeff\ufe00-\ufe0f\u{e0100}-\u{e01ef}]`, "gu");
84
+ const DANGLING_TERMINAL_SEQUENCE_SUFFIX_RE$1 = new RegExp(String.raw`(?:\u001b\][^\u001b\u009c\u0007]*|\u009d[^\u001b\u009c\u0007]*|\u001b\[[0-?]*[ -/]*|\u009b[0-?]*[ -/]*|\u001b)$`);
85
+ async function handleCodexAppServerApprovalRequest(params) {
86
+ const requestParams = isJsonObject(params.requestParams) ? params.requestParams : void 0;
87
+ if (!matchesCurrentTurn(requestParams, params.threadId, params.turnId)) return;
88
+ if (!isSupportedAppServerApprovalMethod(params.method)) return unsupportedApprovalResponse();
89
+ const context = buildApprovalContext({
90
+ method: params.method,
91
+ requestParams,
92
+ paramsForRun: params.paramsForRun
93
+ });
94
+ try {
95
+ const policyOutcome = await runDaoCoreToolPolicyForApprovalRequest({
96
+ method: params.method,
97
+ requestParams,
98
+ paramsForRun: params.paramsForRun,
99
+ context,
100
+ nativeHookRelay: params.nativeHookRelay,
101
+ signal: params.signal
102
+ });
103
+ if (policyOutcome?.outcome === "denied") {
104
+ emitApprovalEvent(params.paramsForRun, {
105
+ phase: "resolved",
106
+ kind: context.kind,
107
+ status: "denied",
108
+ title: context.title,
109
+ ...context.eventDetails,
110
+ ...approvalEventScope(params.method, "denied"),
111
+ message: policyOutcome.reason
112
+ });
113
+ return buildApprovalResponse(params.method, context.requestParams, "denied");
114
+ }
115
+ const requestResult = await requestPluginApproval({
116
+ paramsForRun: params.paramsForRun,
117
+ title: context.title,
118
+ description: context.description,
119
+ severity: context.severity,
120
+ toolName: context.toolName,
121
+ toolCallId: context.itemId
122
+ });
123
+ const approvalId = requestResult?.id;
124
+ if (!approvalId) {
125
+ emitApprovalEvent(params.paramsForRun, {
126
+ phase: "resolved",
127
+ kind: context.kind,
128
+ status: "unavailable",
129
+ title: context.title,
130
+ ...context.eventDetails,
131
+ ...approvalEventScope(params.method, "denied"),
132
+ message: "Codex app-server approval route unavailable."
133
+ });
134
+ return buildApprovalResponse(params.method, context.requestParams, "denied");
135
+ }
136
+ emitApprovalEvent(params.paramsForRun, {
137
+ phase: "requested",
138
+ kind: context.kind,
139
+ status: "pending",
140
+ title: context.title,
141
+ approvalId,
142
+ approvalSlug: approvalId,
143
+ ...context.eventDetails,
144
+ message: "Codex app-server approval requested."
145
+ });
146
+ const outcome = mapExecDecisionToOutcome(approvalRequestExplicitlyUnavailable(requestResult) ? null : await waitForPluginApprovalDecision({
147
+ approvalId,
148
+ signal: params.signal
149
+ }));
150
+ emitApprovalEvent(params.paramsForRun, {
151
+ phase: "resolved",
152
+ kind: context.kind,
153
+ status: outcome === "denied" ? "denied" : outcome === "unavailable" ? "unavailable" : outcome === "cancelled" ? "failed" : "approved",
154
+ title: context.title,
155
+ approvalId,
156
+ approvalSlug: approvalId,
157
+ ...context.eventDetails,
158
+ ...approvalEventScope(params.method, outcome),
159
+ message: approvalResolutionMessage(outcome)
160
+ });
161
+ return buildApprovalResponse(params.method, context.requestParams, outcome);
162
+ } catch (error) {
163
+ const cancelled = params.signal?.aborted === true;
164
+ emitApprovalEvent(params.paramsForRun, {
165
+ phase: "resolved",
166
+ kind: context.kind,
167
+ status: cancelled ? "failed" : "unavailable",
168
+ title: context.title,
169
+ ...context.eventDetails,
170
+ ...approvalEventScope(params.method, cancelled ? "cancelled" : "denied"),
171
+ message: cancelled ? "Codex app-server approval cancelled because the run stopped." : `Codex app-server approval route failed: ${formatCodexDisplayText(formatErrorMessage(error))}`
172
+ });
173
+ return buildApprovalResponse(params.method, context.requestParams, cancelled ? "cancelled" : "denied");
174
+ }
175
+ }
176
+ function buildApprovalResponse(method, requestParams, outcome) {
177
+ if (method === "item/commandExecution/requestApproval") return { decision: commandApprovalDecision(requestParams, outcome) };
178
+ if (method === "item/fileChange/requestApproval") return { decision: fileChangeApprovalDecision(outcome) };
179
+ if (method === "item/permissions/requestApproval") {
180
+ if (outcome === "approved-session" || outcome === "approved-once") return {
181
+ permissions: requestedPermissions(requestParams),
182
+ scope: outcome === "approved-session" ? "session" : "turn"
183
+ };
184
+ return {
185
+ permissions: {},
186
+ scope: "turn"
187
+ };
188
+ }
189
+ return unsupportedApprovalResponse();
190
+ }
191
+ function matchesCurrentTurn(requestParams, threadId, turnId) {
192
+ if (!requestParams) return false;
193
+ const requestThreadId = readString$1(requestParams, "threadId") ?? readString$1(requestParams, "conversationId");
194
+ const requestTurnId = readString$1(requestParams, "turnId");
195
+ return requestThreadId === threadId && requestTurnId === turnId;
196
+ }
197
+ function buildApprovalContext(params) {
198
+ const itemId = readString$1(params.requestParams, "itemId") ?? readString$1(params.requestParams, "callId") ?? readString$1(params.requestParams, "approvalId");
199
+ const commandDetailLines = params.method === "item/commandExecution/requestApproval" ? describeCommandApprovalDetails(params.requestParams) : [];
200
+ const commandPreview = sanitizeApprovalPreview(readDisplayCommandPreview(params.requestParams), commandDetailLines.length > 0 ? COMMAND_PREVIEW_WITH_DETAILS_MAX_LENGTH : 180);
201
+ const reasonPreview = sanitizeApprovalPreview(readStringPreview(params.requestParams, "reason"), 180);
202
+ const command = commandPreview.text;
203
+ const reason = reasonPreview.text;
204
+ const kind = approvalKindForMethod(params.method);
205
+ const permissionLines = params.method === "item/permissions/requestApproval" ? describeRequestedPermissions(params.requestParams) : [];
206
+ const title = kind === "exec" ? "Codex app-server command approval" : params.method === "item/permissions/requestApproval" ? "Codex app-server permission approval" : kind === "plugin" ? "Codex app-server file approval" : "Codex app-server approval";
207
+ const subject = permissionLines[0] ?? (command ? `Command: ${formatApprovalPreviewSubject(command, commandPreview.omitted)}` : commandPreview.omitted ? `Command: ${APPROVAL_PREVIEW_OMITTED}` : reason ? `Reason: ${formatApprovalPreviewSubject(reason, reasonPreview.omitted)}` : reasonPreview.omitted ? `Reason: ${APPROVAL_PREVIEW_OMITTED}` : `Request method: ${params.method}`);
208
+ return {
209
+ kind,
210
+ title,
211
+ description: permissionLines.length > 0 ? joinDescriptionLinesWithinLimit(permissionLines, PERMISSION_DESCRIPTION_MAX_LENGTH) : [
212
+ subject,
213
+ ...commandDetailLines,
214
+ params.paramsForRun.sessionKey && `Session: ${params.paramsForRun.sessionKey}`
215
+ ].filter(Boolean).join("\n"),
216
+ severity: kind === "exec" ? "warning" : "info",
217
+ toolName: kind === "exec" ? "codex_command_approval" : params.method === "item/permissions/requestApproval" ? "codex_permission_approval" : "codex_file_approval",
218
+ itemId,
219
+ requestParams: params.requestParams,
220
+ eventDetails: {
221
+ ...itemId ? { itemId } : {},
222
+ ...command ? { command } : {},
223
+ ...commandPreview.omitted ? { commandPreviewOmitted: true } : {},
224
+ ...reason ? { reason } : {},
225
+ ...reasonPreview.omitted ? { reasonPreviewOmitted: true } : {}
226
+ }
227
+ };
228
+ }
229
+ async function runDaoCoreToolPolicyForApprovalRequest(params) {
230
+ const policyRequest = buildDaoCoreToolPolicyRequest(params.method, params.requestParams);
231
+ if (!policyRequest) return;
232
+ const cwd = readString$1(params.requestParams, "cwd") ?? params.paramsForRun.workspaceDir;
233
+ const nativeRelayOutcome = await runNativeRelayToolPolicyForApprovalRequest({
234
+ method: params.method,
235
+ requestParams: params.requestParams,
236
+ context: params.context,
237
+ policyRequest,
238
+ nativeHookRelay: params.nativeHookRelay,
239
+ cwd
240
+ });
241
+ if (nativeRelayOutcome?.blocked) return {
242
+ outcome: "denied",
243
+ reason: nativeRelayOutcome.reason
244
+ };
245
+ if (nativeRelayOutcome?.handled) return { outcome: "no-decision" };
246
+ const hookChannelId = buildAgentHookContextChannelFields({
247
+ sessionKey: params.paramsForRun.sessionKey,
248
+ messageChannel: params.paramsForRun.messageChannel,
249
+ messageProvider: params.paramsForRun.messageProvider,
250
+ currentChannelId: params.paramsForRun.currentChannelId,
251
+ messageTo: params.paramsForRun.messageTo
252
+ }).channelId;
253
+ const outcome = await runBeforeToolCallHook({
254
+ toolName: policyRequest.toolName,
255
+ params: policyRequest.params,
256
+ ...params.context.itemId ? { toolCallId: params.context.itemId } : {},
257
+ approvalMode: "report",
258
+ signal: params.signal,
259
+ ctx: {
260
+ ...params.paramsForRun.agentId ? { agentId: params.paramsForRun.agentId } : {},
261
+ ...params.paramsForRun.config ? { config: params.paramsForRun.config } : {},
262
+ ...cwd ? { cwd } : {},
263
+ ...params.paramsForRun.sessionKey ? { sessionKey: params.paramsForRun.sessionKey } : {},
264
+ ...params.paramsForRun.sessionId ? { sessionId: params.paramsForRun.sessionId } : {},
265
+ ...params.paramsForRun.runId ? { runId: params.paramsForRun.runId } : {},
266
+ ...hookChannelId ? { channelId: hookChannelId } : {}
267
+ }
268
+ });
269
+ if (outcome.blocked) return {
270
+ outcome: "denied",
271
+ reason: outcome.reason
272
+ };
273
+ if ("params" in outcome && toolPolicyParamsWereRewritten(policyRequest.params, outcome.params)) return {
274
+ outcome: "denied",
275
+ reason: "DaoCore tool policy rewrote Codex app-server approval params; refusing original request."
276
+ };
277
+ }
278
+ async function runNativeRelayToolPolicyForApprovalRequest(params) {
279
+ if (params.method !== "item/commandExecution/requestApproval" || !params.nativeHookRelay?.allowedEvents.includes("pre_tool_use")) return;
280
+ const payload = buildNativeRelayPreToolUsePayload({
281
+ requestParams: params.requestParams,
282
+ policyRequest: params.policyRequest,
283
+ context: params.context,
284
+ cwd: params.cwd
285
+ });
286
+ if (!payload) return;
287
+ if (hasNativeHookRelayInvocation({
288
+ relayId: params.nativeHookRelay.relayId,
289
+ event: "pre_tool_use",
290
+ toolUseId: params.context.itemId
291
+ })) return { handled: true };
292
+ try {
293
+ const decision = readNativeRelayPreToolUseDecision(await invokeNativeHookRelay({
294
+ provider: "codex",
295
+ relayId: params.nativeHookRelay.relayId,
296
+ event: "pre_tool_use",
297
+ rawPayload: payload
298
+ }));
299
+ if (decision.blocked) return {
300
+ handled: true,
301
+ blocked: true,
302
+ reason: decision.reason
303
+ };
304
+ return { handled: true };
305
+ } catch (error) {
306
+ return {
307
+ handled: true,
308
+ blocked: true,
309
+ reason: `DaoCore native hook relay unavailable for Codex app-server approval: ${formatCodexDisplayText(formatErrorMessage(error))}`
310
+ };
311
+ }
312
+ }
313
+ function buildNativeRelayPreToolUsePayload(params) {
314
+ const command = readString$1(params.policyRequest.params, "command");
315
+ if (!command) return;
316
+ const turnId = readString$1(params.requestParams, "turnId");
317
+ return {
318
+ hook_event_name: "PreToolUse",
319
+ daocore_approval_mode: "report",
320
+ tool_name: "exec_command",
321
+ ...params.context.itemId ? { tool_use_id: params.context.itemId } : {},
322
+ ...params.cwd ? { cwd: params.cwd } : {},
323
+ ...turnId ? { turn_id: turnId } : {},
324
+ tool_input: {
325
+ ...params.policyRequest.params,
326
+ command,
327
+ cmd: command
328
+ }
329
+ };
330
+ }
331
+ function readNativeRelayPreToolUseDecision(response) {
332
+ if (!response || response.exitCode !== 0) return {
333
+ blocked: true,
334
+ reason: sanitizeRelayDecisionReason(response?.stderr) || sanitizeRelayDecisionReason(response?.stdout) || "DaoCore native hook relay failed for Codex app-server approval."
335
+ };
336
+ const stdout = response.stdout?.trim();
337
+ if (!stdout) return { blocked: false };
338
+ const parsed = parseRelayJsonResponse(stdout);
339
+ const output = isJsonObject(parsed?.hookSpecificOutput) ? parsed.hookSpecificOutput : void 0;
340
+ if (output?.permissionDecision === "deny") return {
341
+ blocked: true,
342
+ reason: readString$1(output, "permissionDecisionReason") || "DaoCore native hook policy denied Codex app-server approval."
343
+ };
344
+ return {
345
+ blocked: true,
346
+ reason: output ? "DaoCore native hook relay returned a non-deny Codex app-server approval decision." : "DaoCore native hook relay returned an unreadable Codex app-server approval result."
347
+ };
348
+ }
349
+ function parseRelayJsonResponse(text) {
350
+ try {
351
+ const parsed = JSON.parse(text);
352
+ return isJsonObject(parsed) ? parsed : void 0;
353
+ } catch {
354
+ return;
355
+ }
356
+ }
357
+ function sanitizeRelayDecisionReason(value) {
358
+ return sanitizeApprovalPreview(value ? {
359
+ value,
360
+ clipped: false
361
+ } : void 0, 240).text;
362
+ }
363
+ function buildDaoCoreToolPolicyRequest(method, requestParams) {
364
+ if (method === "item/commandExecution/requestApproval") {
365
+ const command = readPolicyCommand(requestParams);
366
+ return {
367
+ toolName: "exec",
368
+ params: {
369
+ ...command ? { command } : {},
370
+ ...readString$1(requestParams, "cwd") ? { cwd: readString$1(requestParams, "cwd") } : {},
371
+ approval: requestParams ?? {}
372
+ }
373
+ };
374
+ }
375
+ if (method === "item/fileChange/requestApproval") return {
376
+ toolName: "apply_patch",
377
+ params: requestParams ?? {}
378
+ };
379
+ if (method === "item/permissions/requestApproval") return {
380
+ toolName: "codex_permission_approval",
381
+ params: requestParams ?? {}
382
+ };
383
+ }
384
+ function toolPolicyParamsWereRewritten(original, candidate) {
385
+ if (candidate === original) return false;
386
+ const originalText = stableJsonText(original);
387
+ const candidateText = stableJsonText(candidate);
388
+ return !candidateText || candidateText !== originalText;
389
+ }
390
+ function stableJsonText(value) {
391
+ if (value === null || typeof value === "string" || typeof value === "number" || typeof value === "boolean") return JSON.stringify(value);
392
+ if (Array.isArray(value)) {
393
+ const items = value.map((item) => stableJsonText(item));
394
+ return items.every((item) => item !== void 0) ? `[${items.join(",")}]` : void 0;
395
+ }
396
+ if (isPlainRecord(value)) {
397
+ const entries = Object.entries(value).toSorted(([left], [right]) => left.localeCompare(right)).map(([key, item]) => {
398
+ const text = stableJsonText(item);
399
+ return text === void 0 ? void 0 : `${JSON.stringify(key)}:${text}`;
400
+ });
401
+ return entries.every((entry) => entry !== void 0) ? `{${entries.join(",")}}` : void 0;
402
+ }
403
+ }
404
+ function isPlainRecord(value) {
405
+ return Boolean(value && typeof value === "object" && !Array.isArray(value));
406
+ }
407
+ function commandApprovalDecision(requestParams, outcome) {
408
+ if (outcome === "cancelled") return commandRejectionDecision(requestParams, "cancel");
409
+ if (outcome === "denied" || outcome === "unavailable") return commandRejectionDecision(requestParams, "decline");
410
+ if (outcome === "approved-session") {
411
+ if (hasAvailableDecision(requestParams, "acceptForSession")) return "acceptForSession";
412
+ const amendmentDecision = findAvailableCommandAmendmentDecision(requestParams);
413
+ if (amendmentDecision) return amendmentDecision;
414
+ }
415
+ return hasAvailableDecision(requestParams, "accept") ? "accept" : commandRejectionDecision(requestParams, "decline");
416
+ }
417
+ function fileChangeApprovalDecision(outcome) {
418
+ if (outcome === "cancelled") return "cancel";
419
+ if (outcome === "denied" || outcome === "unavailable") return "decline";
420
+ return outcome === "approved-session" ? "acceptForSession" : "accept";
421
+ }
422
+ function requestedPermissions(requestParams) {
423
+ const permissions = isJsonObject(requestParams?.permissions) ? requestParams.permissions : {};
424
+ const granted = {};
425
+ if (isJsonObject(permissions.network)) granted.network = permissions.network;
426
+ if (isJsonObject(permissions.fileSystem)) granted.fileSystem = permissions.fileSystem;
427
+ return granted;
428
+ }
429
+ function unsupportedApprovalResponse() {
430
+ return {
431
+ decision: "decline",
432
+ reason: "DaoCore codex app-server bridge does not grant native approvals yet."
433
+ };
434
+ }
435
+ function describeRequestedPermissions(requestParams) {
436
+ return describePermissionProfile(requestedPermissions(requestParams), "Permissions");
437
+ }
438
+ function describeCommandApprovalDetails(requestParams) {
439
+ const lines = [];
440
+ const additionalPermissions = isJsonObject(requestParams?.additionalPermissions) ? requestParams.additionalPermissions : void 0;
441
+ if (additionalPermissions) lines.push(...describePermissionProfile(additionalPermissions, "Additional permissions"));
442
+ const execpolicySummary = summarizeStringArray(requestParams?.proposedExecpolicyAmendment, "Proposed exec policy", sanitizePermissionScalar);
443
+ if (execpolicySummary) lines.push(execpolicySummary);
444
+ const networkAmendmentSummary = summarizeNetworkPolicyAmendments(requestParams?.proposedNetworkPolicyAmendments);
445
+ if (networkAmendmentSummary) lines.push(networkAmendmentSummary);
446
+ return lines;
447
+ }
448
+ function describePermissionProfile(permissions, label) {
449
+ const lines = [];
450
+ const kinds = [];
451
+ const risks = /* @__PURE__ */ new Set();
452
+ if (isJsonObject(permissions.network)) kinds.push("network");
453
+ if (isJsonObject(permissions.fileSystem)) kinds.push("fileSystem");
454
+ if (kinds.length > 0) lines.push(`${label}: ${kinds.join(", ")}`);
455
+ let networkSummary;
456
+ if (isJsonObject(permissions.network)) {
457
+ const summaries = [summarizeNetworkEnabledPermission(permissions.network, risks), summarizePermissionRecord(permissions.network, risks, [{
458
+ key: "allowHosts",
459
+ label: "allowHosts",
460
+ sanitize: sanitizePermissionHostValue,
461
+ risksFor: permissionHostRisks
462
+ }])].filter((summary) => Boolean(summary));
463
+ networkSummary = summaries.length > 0 ? summaries.join("; ") : void 0;
464
+ }
465
+ let fileSystemSummary;
466
+ if (isJsonObject(permissions.fileSystem)) {
467
+ const summaries = [summarizePermissionRecord(permissions.fileSystem, risks, [
468
+ {
469
+ key: "read",
470
+ label: "read",
471
+ sanitize: sanitizePermissionPathValue,
472
+ risksFor: permissionPathRisks
473
+ },
474
+ {
475
+ key: "write",
476
+ label: "write",
477
+ sanitize: sanitizePermissionPathValue,
478
+ risksFor: permissionPathRisks
479
+ },
480
+ {
481
+ key: "roots",
482
+ label: "roots",
483
+ sanitize: sanitizePermissionPathValue,
484
+ risksFor: permissionPathRisks
485
+ },
486
+ {
487
+ key: "readPaths",
488
+ label: "readPaths",
489
+ sanitize: sanitizePermissionPathValue,
490
+ risksFor: permissionPathRisks
491
+ },
492
+ {
493
+ key: "writePaths",
494
+ label: "writePaths",
495
+ sanitize: sanitizePermissionPathValue,
496
+ risksFor: permissionPathRisks
497
+ }
498
+ ]), summarizeFileSystemEntries(permissions.fileSystem, risks)].filter((summary) => Boolean(summary));
499
+ fileSystemSummary = summaries.length > 0 ? summaries.join("; ") : void 0;
500
+ }
501
+ if (risks.size > 0) lines.push(`High-risk targets: ${[...risks].join(", ")}`);
502
+ if (networkSummary) lines.push(`Network ${networkSummary}`);
503
+ if (fileSystemSummary) lines.push(`File system ${fileSystemSummary}`);
504
+ return lines;
505
+ }
506
+ function summarizeNetworkEnabledPermission(permission, risks) {
507
+ const enabled = permission.enabled;
508
+ if (typeof enabled !== "boolean") return;
509
+ if (enabled) risks.add("network access");
510
+ return `enabled: ${enabled}`;
511
+ }
512
+ function summarizeFileSystemEntries(permission, risks) {
513
+ const entries = permission.entries;
514
+ if (!Array.isArray(entries)) return;
515
+ const samples = [];
516
+ let count = 0;
517
+ for (const entry of entries) {
518
+ const item = isJsonObject(entry) ? entry : void 0;
519
+ const path = typeof item?.path === "string" ? item.path.trim() : "";
520
+ const access = typeof item?.access === "string" ? item.access.trim() : "";
521
+ if (!path || !access) continue;
522
+ count += 1;
523
+ if (access !== "none") for (const risk of permissionPathRisks(path)) risks.add(risk);
524
+ if (samples.length < PERMISSION_SAMPLE_LIMIT) samples.push(`${sanitizePermissionScalar(access)} ${sanitizePermissionPathValue(path)}`);
525
+ }
526
+ if (count === 0) return;
527
+ const remaining = count - samples.length;
528
+ const remainderSuffix = remaining > 0 ? ` (+${remaining} more)` : "";
529
+ return `entries: ${samples.join(", ")}${remainderSuffix}`;
530
+ }
531
+ function summarizePermissionRecord(permission, risks, descriptors) {
532
+ const details = [];
533
+ for (const descriptor of descriptors) {
534
+ const summary = summarizePermissionArray(permission, descriptor, risks);
535
+ if (summary) details.push(summary);
536
+ }
537
+ return details.length > 0 ? details.join("; ") : void 0;
538
+ }
539
+ function summarizePermissionArray(record, descriptor, risks) {
540
+ const values = readStringArray(record, descriptor.key);
541
+ if (values.length === 0) return;
542
+ for (const value of values) for (const risk of descriptor.risksFor(value)) risks.add(risk);
543
+ const sampleValues = values.slice(0, PERMISSION_SAMPLE_LIMIT).map(descriptor.sanitize).filter(Boolean);
544
+ if (sampleValues.length === 0) return `${descriptor.label}: ${values.length}`;
545
+ const remaining = values.length - sampleValues.length;
546
+ const remainderSuffix = remaining > 0 ? ` (+${remaining} more)` : "";
547
+ return `${descriptor.label}: ${sampleValues.join(", ")}${remainderSuffix}`;
548
+ }
549
+ function summarizeStringArray(value, label, sanitize) {
550
+ if (!Array.isArray(value)) return;
551
+ const values = value.filter((entry) => typeof entry === "string").map((entry) => sanitize(entry)).filter(Boolean);
552
+ if (values.length === 0) return;
553
+ const samples = values.slice(0, PERMISSION_SAMPLE_LIMIT);
554
+ const remaining = values.length - samples.length;
555
+ const remainderSuffix = remaining > 0 ? ` (+${remaining} more)` : "";
556
+ return `${label}: ${samples.join(", ")}${remainderSuffix}`;
557
+ }
558
+ function summarizeNetworkPolicyAmendments(value) {
559
+ if (!Array.isArray(value)) return;
560
+ const samples = [];
561
+ let count = 0;
562
+ for (const entry of value) {
563
+ const amendment = isJsonObject(entry) ? entry : void 0;
564
+ const host = typeof amendment?.host === "string" ? amendment.host : "";
565
+ const action = typeof amendment?.action === "string" ? amendment.action : "";
566
+ if (!host || !action) continue;
567
+ count += 1;
568
+ if (samples.length < PERMISSION_SAMPLE_LIMIT) samples.push(`${sanitizePermissionScalar(action)} ${sanitizePermissionHostValue(host)}`);
569
+ }
570
+ if (count === 0) return;
571
+ const remaining = count - samples.length;
572
+ const remainderSuffix = remaining > 0 ? ` (+${remaining} more)` : "";
573
+ return `Proposed network policy: ${samples.join(", ")}${remainderSuffix}`;
574
+ }
575
+ function readStringArray(record, key) {
576
+ const value = record[key];
577
+ return Array.isArray(value) ? value.map((entry) => typeof entry === "string" ? entry.trim() : "").filter(Boolean) : [];
578
+ }
579
+ function sanitizePermissionHostValue(value) {
580
+ const withoutScheme = sanitizePermissionScalar(value).toLowerCase().replace(/^[a-z][a-z0-9+.-]*:\/\//, "");
581
+ const authority = withoutScheme.split(/[/?#]/, 1)[0] ?? withoutScheme;
582
+ return truncate(authority.includes("@") ? authority.slice(authority.lastIndexOf("@") + 1) : authority, PERMISSION_VALUE_MAX_LENGTH);
583
+ }
584
+ function sanitizePermissionPathValue(value) {
585
+ return truncate(formatApprovalDisplayPath(sanitizePermissionScalar(value)), PERMISSION_VALUE_MAX_LENGTH);
586
+ }
587
+ function sanitizePermissionScalar(value) {
588
+ return sanitizeVisibleScalar(value);
589
+ }
590
+ function permissionHostRisks(value) {
591
+ const normalized = value.trim().toLowerCase();
592
+ const risks = [];
593
+ if (normalized.includes("*")) {
594
+ risks.push("wildcard hosts");
595
+ if (isPrivateNetworkHostPattern(normalized)) risks.push("private-network wildcards");
596
+ }
597
+ return risks;
598
+ }
599
+ function permissionPathRisks(value) {
600
+ const normalized = sanitizePermissionScalar(value);
601
+ const risks = [];
602
+ if (normalized === "/" || normalized === "\\" || /^[A-Za-z]:[\\/]*$/.test(normalized)) risks.push("filesystem root");
603
+ return risks;
604
+ }
605
+ function isPrivateNetworkHostPattern(value) {
606
+ const wildcardStripped = value.toLowerCase().replace(/^\*\./, "");
607
+ if (wildcardStripped === "localhost" || wildcardStripped === "local" || wildcardStripped === "internal" || wildcardStripped === "lan" || wildcardStripped === "home" || wildcardStripped === "corp" || wildcardStripped === "private" || wildcardStripped.endsWith(".local") || wildcardStripped.endsWith(".internal") || wildcardStripped.endsWith(".lan") || wildcardStripped.endsWith(".home") || wildcardStripped.endsWith(".corp") || wildcardStripped.endsWith(".private")) return true;
608
+ if (wildcardStripped.startsWith("10.") || wildcardStripped.startsWith("127.") || wildcardStripped.startsWith("192.168.") || wildcardStripped.startsWith("169.254.")) return true;
609
+ return /^172\.(1[6-9]|2\d|3[0-1])\./.test(wildcardStripped);
610
+ }
611
+ function hasAvailableDecision(requestParams, decision) {
612
+ const available = requestParams?.availableDecisions;
613
+ if (!Array.isArray(available)) return true;
614
+ return available.includes(decision);
615
+ }
616
+ function findAvailableCommandAmendmentDecision(requestParams) {
617
+ const available = requestParams?.availableDecisions;
618
+ if (!Array.isArray(available)) return;
619
+ return available.find((entry) => isJsonObject(entry) && (isJsonObject(entry.acceptWithExecpolicyAmendment) || isJsonObject(entry.applyNetworkPolicyAmendment)));
620
+ }
621
+ function commandRejectionDecision(requestParams, preferred) {
622
+ const available = requestParams?.availableDecisions;
623
+ if (!Array.isArray(available)) return preferred;
624
+ if (available.includes(preferred)) return preferred;
625
+ const alternate = preferred === "decline" ? "cancel" : "decline";
626
+ if (available.includes(alternate)) return alternate;
627
+ return preferred;
628
+ }
629
+ function approvalResolutionMessage(outcome) {
630
+ if (outcome === "approved-session") return "Codex app-server approval granted for the session.";
631
+ if (outcome === "approved-once") return "Codex app-server approval granted for this turn.";
632
+ if (outcome === "cancelled") return "Codex app-server approval cancelled.";
633
+ if (outcome === "unavailable") return "Codex app-server approval unavailable.";
634
+ return "Codex app-server approval denied.";
635
+ }
636
+ function approvalScopeForOutcome(outcome) {
637
+ return outcome === "approved-session" ? "session" : "turn";
638
+ }
639
+ function approvalEventScope(method, outcome) {
640
+ return method === "item/permissions/requestApproval" ? { scope: approvalScopeForOutcome(outcome) } : {};
641
+ }
642
+ function approvalKindForMethod(method) {
643
+ if (method.includes("commandExecution") || method.includes("execCommand")) return "exec";
644
+ if (method.includes("fileChange") || method.includes("Patch") || method.includes("permissions")) return "plugin";
645
+ return "unknown";
646
+ }
647
+ function isSupportedAppServerApprovalMethod(method) {
648
+ return method === "item/commandExecution/requestApproval" || method === "item/fileChange/requestApproval" || method === "item/permissions/requestApproval";
649
+ }
650
+ function emitApprovalEvent(params, data) {
651
+ params.onAgentEvent?.({
652
+ stream: "approval",
653
+ data
654
+ });
655
+ }
656
+ function readDisplayCommandPreview(record) {
657
+ const actionCommand = readCommandActionsPreview(record);
658
+ if (actionCommand) return actionCommand;
659
+ return readCommandPreview(record);
660
+ }
661
+ function readPolicyCommand(record) {
662
+ const command = record?.command;
663
+ if (typeof command === "string") return command;
664
+ if (Array.isArray(command) && command.every((part) => typeof part === "string")) return command.join(" ");
665
+ const actionCommands = readCommandActions(record);
666
+ if (actionCommands.length > 0) return actionCommands.join(" && ");
667
+ }
668
+ function readCommandActions(record) {
669
+ const actions = record?.commandActions;
670
+ if (!Array.isArray(actions)) return [];
671
+ return actions.map((action) => isJsonObject(action) ? readString$1(action, "command") : void 0).filter((command) => Boolean(command));
672
+ }
673
+ function readCommandActionsPreview(record) {
674
+ let source;
675
+ for (const command of readCommandActions(record)) {
676
+ source = appendPreviewPart(source, command, " && ");
677
+ if (source.clipped) break;
678
+ }
679
+ return source;
680
+ }
681
+ function readCommandPreview(record) {
682
+ const command = record?.command;
683
+ if (typeof command === "string") return previewSource(command);
684
+ if (!Array.isArray(command)) return;
685
+ let source;
686
+ for (const part of command) {
687
+ if (typeof part !== "string") return;
688
+ source = appendPreviewPart(source, part, " ");
689
+ if (source.clipped) break;
690
+ }
691
+ return source;
692
+ }
693
+ function readStringPreview(record, key) {
694
+ const value = readString$1(record, key);
695
+ return value === void 0 ? void 0 : previewSource(value);
696
+ }
697
+ function readString$1(record, key) {
698
+ const value = record?.[key];
699
+ return typeof value === "string" ? value : void 0;
700
+ }
701
+ function truncate(value, maxLength) {
702
+ return value.length <= maxLength ? value : `${value.slice(0, Math.max(0, maxLength - 3))}...`;
703
+ }
704
+ function previewSource(value) {
705
+ return {
706
+ value: value.slice(0, APPROVAL_PREVIEW_SCAN_MAX_LENGTH),
707
+ clipped: value.length > APPROVAL_PREVIEW_SCAN_MAX_LENGTH
708
+ };
709
+ }
710
+ function appendPreviewPart(source, part, separator) {
711
+ const value = `${source?.value ? `${source.value}${separator}` : ""}${part}`;
712
+ const clipped = source?.clipped === true || value.length > APPROVAL_PREVIEW_SCAN_MAX_LENGTH;
713
+ return {
714
+ value: value.slice(0, APPROVAL_PREVIEW_SCAN_MAX_LENGTH),
715
+ clipped
716
+ };
717
+ }
718
+ function sanitizeApprovalPreview(source, maxLength) {
719
+ if (!source || !source.value) return { omitted: false };
720
+ const sanitized = sanitizeVisibleScalar(source.value.replace(DANGLING_TERMINAL_SEQUENCE_SUFFIX_RE$1, ""));
721
+ if (!sanitized) return { omitted: true };
722
+ return {
723
+ text: formatCodexDisplayText(truncate(sanitized, maxLength)),
724
+ omitted: source.clipped
725
+ };
726
+ }
727
+ function sanitizeVisibleScalar(value) {
728
+ return value.replace(ANSI_OSC_SEQUENCE_RE$1, "").replace(ANSI_CONTROL_SEQUENCE_RE$1, "").replace(INVISIBLE_FORMATTING_CONTROL_RE$1, " ").replace(CONTROL_CHARACTER_RE$1, " ").replace(/\s+/g, " ").trim();
729
+ }
730
+ function formatApprovalPreviewSubject(text, omitted) {
731
+ return omitted ? `${text} ${APPROVAL_PREVIEW_OMITTED}` : text;
732
+ }
733
+ function joinDescriptionLinesWithinLimit(lines, maxLength) {
734
+ let description = "";
735
+ for (const line of lines) {
736
+ const prefix = description ? "\n" : "";
737
+ const next = `${description}${prefix}${line}`;
738
+ if (next.length <= maxLength) {
739
+ description = next;
740
+ continue;
741
+ }
742
+ const remaining = maxLength - description.length - prefix.length;
743
+ if (remaining < 3) break;
744
+ description += `${prefix}${truncate(line, remaining)}`;
745
+ break;
746
+ }
747
+ return description;
748
+ }
749
+ function formatErrorMessage(error) {
750
+ return error instanceof Error ? error.message : String(error);
751
+ }
752
+ //#endregion
753
+ //#region extensions/codex/src/app-server/dynamic-tool-diagnostics.ts
754
+ function emitDynamicToolStartedDiagnostic(params) {
755
+ emitTrustedDiagnosticEvent({
756
+ type: "tool.execution.started",
757
+ runId: params.runId,
758
+ sessionId: params.sessionId,
759
+ sessionKey: params.sessionKey,
760
+ toolName: params.call.tool,
761
+ toolCallId: params.call.callId
762
+ });
763
+ }
764
+ function emitDynamicToolErrorDiagnostic(params) {
765
+ emitTrustedDiagnosticEvent({
766
+ type: "tool.execution.error",
767
+ runId: params.runId,
768
+ sessionId: params.sessionId,
769
+ sessionKey: params.sessionKey,
770
+ toolName: params.call.tool,
771
+ toolCallId: params.call.callId,
772
+ durationMs: params.durationMs,
773
+ errorCategory: "codex_dynamic_tool_error"
774
+ });
775
+ }
776
+ function emitDynamicToolTerminalDiagnostic(params) {
777
+ const terminalType = params.response.diagnosticTerminalType ?? (params.response.success ? "completed" : "error");
778
+ if (terminalType === "completed") {
779
+ emitTrustedDiagnosticEvent({
780
+ type: "tool.execution.completed",
781
+ runId: params.runId,
782
+ sessionId: params.sessionId,
783
+ sessionKey: params.sessionKey,
784
+ toolName: params.call.tool,
785
+ toolCallId: params.call.callId,
786
+ durationMs: params.durationMs
787
+ });
788
+ return;
789
+ }
790
+ if (terminalType === "blocked") {
791
+ emitTrustedDiagnosticEvent({
792
+ type: "tool.execution.blocked",
793
+ runId: params.runId,
794
+ sessionId: params.sessionId,
795
+ sessionKey: params.sessionKey,
796
+ toolName: params.call.tool,
797
+ toolCallId: params.call.callId,
798
+ deniedReason: "plugin-before-tool-call",
799
+ reason: "Tool call blocked"
800
+ });
801
+ return;
802
+ }
803
+ emitDynamicToolErrorDiagnostic(params);
804
+ }
805
+ //#endregion
806
+ //#region extensions/codex/src/app-server/elicitation-bridge.ts
807
+ const MCP_TOOL_APPROVAL_KIND = "mcp_tool_call";
808
+ const MCP_TOOL_APPROVAL_KIND_KEY = "codex_approval_kind";
809
+ const MCP_TOOL_APPROVAL_CONNECTOR_NAME_KEY = "connector_name";
810
+ const MCP_TOOL_APPROVAL_TOOL_TITLE_KEY = "tool_title";
811
+ const MCP_TOOL_APPROVAL_TOOL_DESCRIPTION_KEY = "tool_description";
812
+ const MCP_TOOL_APPROVAL_TOOL_PARAMS_DISPLAY_KEY = "tool_params_display";
813
+ const MCP_TOOL_APPROVAL_SOURCE_KEY = "source";
814
+ const MCP_TOOL_APPROVAL_CONNECTOR_SOURCE = "connector";
815
+ const CODEX_APPS_SERVER_NAME = "codex_apps";
816
+ const COMPUTER_USE_APPROVAL_TITLE = "Computer Use approval";
817
+ const EMPTY_OBJECT_SCHEMA = {
818
+ type: "object",
819
+ properties: {}
820
+ };
821
+ const PLUGIN_APP_ID_META_KEYS = [
822
+ "app_id",
823
+ "appId",
824
+ "codex_app_id",
825
+ "codexAppId"
826
+ ];
827
+ const PLUGIN_CONNECTOR_ID_META_KEYS = ["connector_id", "connectorId"];
828
+ const PLUGIN_NAME_META_KEYS = [
829
+ "plugin_name",
830
+ "pluginName",
831
+ "codex_plugin_name",
832
+ "codexPluginName"
833
+ ];
834
+ const PLUGIN_CONFIG_KEY_META_KEYS = [
835
+ "config_key",
836
+ "configKey",
837
+ "codex_config_key"
838
+ ];
839
+ const PLUGIN_MARKETPLACE_NAME_META_KEYS = [
840
+ "marketplace_name",
841
+ "marketplaceName",
842
+ "codex_marketplace_name",
843
+ "codexMarketplaceName"
844
+ ];
845
+ const MAX_DISPLAY_PARAM_ENTRIES = 8;
846
+ const MAX_DISPLAY_PARAM_VALUE_LENGTH = 120;
847
+ const MAX_DISPLAY_VALUE_ARRAY_ITEMS = 8;
848
+ const MAX_DISPLAY_VALUE_OBJECT_KEYS = 8;
849
+ const MAX_DISPLAY_VALUE_DEPTH = 3;
850
+ const DISPLAY_TEXT_SCAN_MAX_LENGTH = 4096;
851
+ const ANSI_OSC_SEQUENCE_RE = new RegExp(String.raw`(?:\u001b]|\u009d)[^\u001b\u009c\u0007]*(?:\u0007|\u001b\\|\u009c)`, "g");
852
+ const ANSI_CONTROL_SEQUENCE_RE = new RegExp(String.raw`(?:\u001b\[[0-?]*[ -/]*[@-~]|\u009b[0-?]*[ -/]*[@-~]|\u001b[@-Z\\-_])`, "g");
853
+ const CONTROL_CHARACTER_RE = new RegExp(String.raw`[\u0000-\u001f\u007f-\u009f]+`, "g");
854
+ const INVISIBLE_FORMATTING_CONTROL_RE = new RegExp(String.raw`[\u00ad\u034f\u061c\u200b-\u200f\u202a-\u202e\u2060-\u206f\ufeff\ufe00-\ufe0f\u{e0100}-\u{e01ef}]`, "gu");
855
+ const DANGLING_TERMINAL_SEQUENCE_SUFFIX_RE = new RegExp(String.raw`(?:\u001b\][^\u001b\u009c\u0007]*|\u009d[^\u001b\u009c\u0007]*|\u001b\[[0-?]*[ -/]*|\u009b[0-?]*[ -/]*|\u001b)$`);
856
+ async function handleCodexAppServerElicitationRequest(params) {
857
+ const requestParams = isJsonObject(params.requestParams) ? params.requestParams : void 0;
858
+ if (!requestParams) return;
859
+ if (!matchesCurrentThread(requestParams, params.threadId)) return;
860
+ if (turnIdMismatches(requestParams, params.turnId)) return;
861
+ const pluginResolution = resolvePluginElicitation({
862
+ requestParams,
863
+ pluginAppPolicyContext: params.pluginAppPolicyContext
864
+ });
865
+ if (pluginResolution.kind !== "not_plugin") {
866
+ if (pluginResolution.kind === "decline") {
867
+ logPluginElicitationDecline(pluginResolution.reason, requestParams);
868
+ return declineElicitationResponse();
869
+ }
870
+ if (!hasExactTurnId(requestParams, params.turnId)) {
871
+ logPluginElicitationDecline("missing_active_turn", requestParams);
872
+ return declineElicitationResponse();
873
+ }
874
+ return buildPluginPolicyElicitationResponse(pluginResolution.entry, requestParams);
875
+ }
876
+ const approvalPrompt = readComputerUseApprovalElicitation(requestParams, params.computerUseMcpServerName) ?? readBridgeableApprovalElicitation(requestParams);
877
+ if (!approvalPrompt) return;
878
+ const outcome = await requestPluginApprovalOutcome({
879
+ paramsForRun: params.paramsForRun,
880
+ title: approvalPrompt.title,
881
+ description: approvalPrompt.description,
882
+ signal: params.signal
883
+ });
884
+ return buildElicitationResponse(approvalPrompt.requestedSchema, approvalPrompt.meta, outcome);
885
+ }
886
+ function matchesCurrentThread(requestParams, threadId) {
887
+ if (!requestParams) return false;
888
+ return readString(requestParams, "threadId") === threadId;
889
+ }
890
+ function turnIdMismatches(requestParams, turnId) {
891
+ const rawTurnId = requestParams?.turnId;
892
+ return rawTurnId !== null && rawTurnId !== void 0 && rawTurnId !== turnId;
893
+ }
894
+ function hasExactTurnId(requestParams, turnId) {
895
+ return requestParams?.turnId === turnId;
896
+ }
897
+ function resolvePluginElicitation(params) {
898
+ const requestParams = params.requestParams;
899
+ if (!requestParams) return { kind: "not_plugin" };
900
+ const meta = isJsonObject(requestParams["_meta"]) ? requestParams["_meta"] : {};
901
+ const context = params.pluginAppPolicyContext;
902
+ const entries = context ? Object.values(context.apps) : [];
903
+ const appId = readFirstString(meta, PLUGIN_APP_ID_META_KEYS) ?? readFirstString(requestParams, PLUGIN_APP_ID_META_KEYS);
904
+ const connectorId = readFirstString(meta, PLUGIN_CONNECTOR_ID_META_KEYS);
905
+ const isCodexConnectorApproval = isCodexConnectorApprovalElicitation(requestParams, meta);
906
+ if (isCodexConnectorApproval && appId && connectorId && appId !== connectorId) return {
907
+ kind: "decline",
908
+ reason: "app_id_connector_id_mismatch"
909
+ };
910
+ if (appId) {
911
+ if (!context) return {
912
+ kind: "decline",
913
+ reason: "missing_policy_context"
914
+ };
915
+ const entry = context.apps[appId];
916
+ return uniquePluginMatch(entry ? [entry] : [], "app_id");
917
+ }
918
+ if (isCodexConnectorApproval && connectorId) {
919
+ if (!context) return {
920
+ kind: "decline",
921
+ reason: "missing_policy_context"
922
+ };
923
+ const entry = context.apps[connectorId];
924
+ return uniquePluginMatch(entry ? [entry] : [], "connector_id");
925
+ }
926
+ const serverName = readString(requestParams, "serverName");
927
+ if (serverName && context) {
928
+ const matches = entries.filter((entry) => entry.mcpServerNames.includes(serverName));
929
+ if (matches.length > 0) return uniquePluginMatch(matches, "server_name");
930
+ }
931
+ const metadataResolution = resolvePluginStableMetadataMatch({
932
+ meta,
933
+ requestParams,
934
+ entries,
935
+ context
936
+ });
937
+ if (metadataResolution.kind !== "not_plugin") return metadataResolution;
938
+ if (context && hasDisplayNameOnlyPluginMatch(meta, entries)) return {
939
+ kind: "decline",
940
+ reason: "display_name_only"
941
+ };
942
+ return { kind: "not_plugin" };
943
+ }
944
+ function isCodexConnectorApprovalElicitation(requestParams, meta) {
945
+ return readString(requestParams, "serverName") === CODEX_APPS_SERVER_NAME && readString(meta, MCP_TOOL_APPROVAL_KIND_KEY) === MCP_TOOL_APPROVAL_KIND && readString(meta, MCP_TOOL_APPROVAL_SOURCE_KEY) === MCP_TOOL_APPROVAL_CONNECTOR_SOURCE;
946
+ }
947
+ function resolvePluginStableMetadataMatch(params) {
948
+ const pluginName = readFirstString(params.meta, PLUGIN_NAME_META_KEYS) ?? readFirstString(params.requestParams, PLUGIN_NAME_META_KEYS);
949
+ const configKey = readFirstString(params.meta, PLUGIN_CONFIG_KEY_META_KEYS) ?? readFirstString(params.requestParams, PLUGIN_CONFIG_KEY_META_KEYS);
950
+ const marketplaceName = readFirstString(params.meta, PLUGIN_MARKETPLACE_NAME_META_KEYS) ?? readFirstString(params.requestParams, PLUGIN_MARKETPLACE_NAME_META_KEYS);
951
+ if (!pluginName && !configKey) return { kind: "not_plugin" };
952
+ if (!params.context) return {
953
+ kind: "decline",
954
+ reason: "missing_policy_context"
955
+ };
956
+ return uniquePluginMatch(params.entries.filter((entry) => {
957
+ if (marketplaceName && entry.marketplaceName !== marketplaceName) return false;
958
+ if (pluginName && entry.pluginName !== pluginName) return false;
959
+ if (configKey && entry.configKey !== configKey) return false;
960
+ return true;
961
+ }), "metadata");
962
+ }
963
+ function uniquePluginMatch(matches, source) {
964
+ if (matches.length === 1 && matches[0]) return {
965
+ kind: "matched",
966
+ entry: matches[0]
967
+ };
968
+ return {
969
+ kind: "decline",
970
+ reason: matches.length === 0 ? `${source}_not_enabled` : `${source}_ambiguous`
971
+ };
972
+ }
973
+ function hasDisplayNameOnlyPluginMatch(meta, entries) {
974
+ const connectorName = readString(meta, MCP_TOOL_APPROVAL_CONNECTOR_NAME_KEY);
975
+ if (!connectorName) return false;
976
+ const normalized = normalizePluginIdentityText(connectorName);
977
+ return entries.some((entry) => normalizePluginIdentityText(entry.pluginName) === normalized || normalizePluginIdentityText(entry.configKey) === normalized);
978
+ }
979
+ function normalizePluginIdentityText(value) {
980
+ return value.toLowerCase().replace(/[^a-z0-9]+/g, "");
981
+ }
982
+ function buildPluginPolicyElicitationResponse(entry, requestParams) {
983
+ if (!entry.allowDestructiveActions) {
984
+ logPluginElicitationDecline("destructive_actions_disabled", requestParams);
985
+ return declineElicitationResponse();
986
+ }
987
+ if (readString(requestParams, "mode") !== "form" || !isJsonObject(requestParams.requestedSchema)) {
988
+ logPluginElicitationDecline("unsupported_schema", requestParams);
989
+ return declineElicitationResponse();
990
+ }
991
+ const meta = isJsonObject(requestParams["_meta"]) ? requestParams["_meta"] : {};
992
+ const response = buildElicitationResponse(requestParams.requestedSchema, meta, "approved-once");
993
+ if (isJsonObject(response) && response.action === "accept") return response;
994
+ logPluginElicitationDecline("unmappable_schema", requestParams);
995
+ return declineElicitationResponse();
996
+ }
997
+ function declineElicitationResponse() {
998
+ return {
999
+ action: "decline",
1000
+ content: null,
1001
+ _meta: null
1002
+ };
1003
+ }
1004
+ function logPluginElicitationDecline(reason, requestParams) {
1005
+ log.debug("codex plugin elicitation declined", {
1006
+ reason,
1007
+ serverName: readString(requestParams, "serverName"),
1008
+ mode: readString(requestParams, "mode")
1009
+ });
1010
+ }
1011
+ function readBridgeableApprovalElicitation(requestParams) {
1012
+ if (!requestParams || readString(requestParams, "mode") !== "form" || !isJsonObject(requestParams["_meta"]) || requestParams["_meta"][MCP_TOOL_APPROVAL_KIND_KEY] !== MCP_TOOL_APPROVAL_KIND || !isJsonObject(requestParams.requestedSchema)) return;
1013
+ const requestedSchema = requestParams.requestedSchema;
1014
+ if (readString(requestedSchema, "type") !== "object" || !isJsonObject(requestedSchema.properties)) return;
1015
+ const title = sanitizeDisplayText(readString(requestParams, "message") ?? "") || "Codex MCP tool approval";
1016
+ return {
1017
+ title,
1018
+ description: buildApprovalDescription({
1019
+ title,
1020
+ meta: requestParams["_meta"],
1021
+ requestedSchema,
1022
+ serverName: sanitizeOptionalDisplayText(readString(requestParams, "serverName"))
1023
+ }),
1024
+ requestedSchema,
1025
+ meta: requestParams["_meta"]
1026
+ };
1027
+ }
1028
+ function readComputerUseApprovalElicitation(requestParams, expectedServerName) {
1029
+ const serverName = readString(requestParams, "serverName");
1030
+ if (!serverName || !expectedServerName || serverName !== expectedServerName || readString(requestParams, "mode") !== "form") return;
1031
+ const requestedSchema = isJsonObject(requestParams?.requestedSchema) ? requestParams.requestedSchema : EMPTY_OBJECT_SCHEMA;
1032
+ if (readString(requestedSchema, "type") !== "object" || !isJsonObject(requestedSchema.properties)) return;
1033
+ const meta = isJsonObject(requestParams?.["_meta"]) ? requestParams["_meta"] : {};
1034
+ const title = sanitizeDisplayText(readString(requestParams, "message") ?? "") || COMPUTER_USE_APPROVAL_TITLE;
1035
+ return {
1036
+ title,
1037
+ description: buildApprovalDescription({
1038
+ title,
1039
+ meta,
1040
+ requestedSchema,
1041
+ serverName: sanitizeOptionalDisplayText(serverName)
1042
+ }),
1043
+ requestedSchema,
1044
+ meta
1045
+ };
1046
+ }
1047
+ function buildApprovalDescription(params) {
1048
+ const connectorName = sanitizeOptionalDisplayText(readString(params.meta, MCP_TOOL_APPROVAL_CONNECTOR_NAME_KEY));
1049
+ const toolTitle = sanitizeOptionalDisplayText(readString(params.meta, MCP_TOOL_APPROVAL_TOOL_TITLE_KEY));
1050
+ const toolDescription = sanitizeOptionalDisplayText(readString(params.meta, MCP_TOOL_APPROVAL_TOOL_DESCRIPTION_KEY));
1051
+ const summaryLines = [
1052
+ connectorName && `App: ${connectorName}`,
1053
+ toolTitle && `Tool: ${toolTitle}`,
1054
+ params.serverName && `MCP server: ${params.serverName}`,
1055
+ toolDescription
1056
+ ].filter((line) => Boolean(line));
1057
+ const paramLines = readDisplayParamLines(params.meta);
1058
+ const propertyLines = readPropertyDescriptionLines(params.requestedSchema);
1059
+ return [
1060
+ params.title,
1061
+ summaryLines.join("\n"),
1062
+ paramLines.length > 0 ? ["Parameters:", ...paramLines].join("\n") : "",
1063
+ propertyLines.length > 0 ? ["Fields:", ...propertyLines].join("\n") : ""
1064
+ ].filter(Boolean).join("\n\n");
1065
+ }
1066
+ function readPropertyDescriptionLines(requestedSchema) {
1067
+ const properties = isJsonObject(requestedSchema.properties) ? requestedSchema.properties : {};
1068
+ return Object.entries(properties).map(([name, value]) => {
1069
+ const schema = isJsonObject(value) ? value : void 0;
1070
+ if (!schema) return;
1071
+ const propTitle = sanitizeDisplayText(readString(schema, "title") ?? "") || sanitizeDisplayText(name) || "field";
1072
+ const description = sanitizeOptionalDisplayText(readString(schema, "description"));
1073
+ return description ? `- ${propTitle}: ${description}` : `- ${propTitle}`;
1074
+ }).filter((line) => Boolean(line));
1075
+ }
1076
+ function readDisplayParamLines(meta) {
1077
+ const displayParams = meta[MCP_TOOL_APPROVAL_TOOL_PARAMS_DISPLAY_KEY];
1078
+ if (!Array.isArray(displayParams)) return [];
1079
+ const lines = displayParams.slice(0, MAX_DISPLAY_PARAM_ENTRIES).map((entry) => {
1080
+ const param = isJsonObject(entry) ? entry : void 0;
1081
+ if (!param) return;
1082
+ const name = sanitizeOptionalDisplayText(readString(param, "display_name")) ?? sanitizeOptionalDisplayText(readString(param, "name"));
1083
+ if (!name) return;
1084
+ return `- ${name}: ${formatDisplayParamValue(param.value)}`;
1085
+ }).filter((line) => Boolean(line));
1086
+ const remaining = displayParams.length - MAX_DISPLAY_PARAM_ENTRIES;
1087
+ return remaining > 0 ? [...lines, `- Additional parameters: ${remaining} more`] : lines;
1088
+ }
1089
+ function formatDisplayParamValue(value) {
1090
+ return truncateDisplayText(sanitizeDisplayText(typeof value === "string" ? value : formatDisplayJsonValue(value ?? null)), MAX_DISPLAY_PARAM_VALUE_LENGTH);
1091
+ }
1092
+ function formatDisplayJsonValue(value, depth = MAX_DISPLAY_VALUE_DEPTH) {
1093
+ if (value === null) return "null";
1094
+ if (typeof value === "string") return JSON.stringify(truncateDisplayText(sanitizeDisplayText(value), 80));
1095
+ if (typeof value === "number" || typeof value === "boolean") return String(value);
1096
+ if (Array.isArray(value)) {
1097
+ if (depth <= 0) return "[truncated]";
1098
+ const parts = [];
1099
+ const limit = Math.min(value.length, MAX_DISPLAY_VALUE_ARRAY_ITEMS);
1100
+ for (let i = 0; i < limit; i += 1) parts.push(formatDisplayJsonValue(value[i] ?? null, depth - 1));
1101
+ if (value.length > MAX_DISPLAY_VALUE_ARRAY_ITEMS) parts.push("...");
1102
+ return `[${parts.join(",")}]`;
1103
+ }
1104
+ if (typeof value === "object") {
1105
+ if (depth <= 0) return "{truncated}";
1106
+ const parts = [];
1107
+ let count = 0;
1108
+ let truncated = false;
1109
+ for (const key in value) {
1110
+ if (!Object.prototype.hasOwnProperty.call(value, key)) continue;
1111
+ if (count >= MAX_DISPLAY_VALUE_OBJECT_KEYS) {
1112
+ truncated = true;
1113
+ break;
1114
+ }
1115
+ const safeKey = truncateDisplayText(sanitizeDisplayText(key), 80);
1116
+ parts.push(`${JSON.stringify(safeKey)}:${formatDisplayJsonValue(value[key] ?? null, depth - 1)}`);
1117
+ count += 1;
1118
+ }
1119
+ if (truncated) parts.push("...");
1120
+ return `{${parts.join(",")}}`;
1121
+ }
1122
+ return "null";
1123
+ }
1124
+ function sanitizeOptionalDisplayText(value) {
1125
+ return (value === void 0 ? "" : sanitizeDisplayText(value)) || void 0;
1126
+ }
1127
+ function sanitizeDisplayText(value) {
1128
+ const scanned = value.slice(0, DISPLAY_TEXT_SCAN_MAX_LENGTH);
1129
+ const clipped = value.length > DISPLAY_TEXT_SCAN_MAX_LENGTH;
1130
+ const sanitized = scanned.replace(ANSI_OSC_SEQUENCE_RE, "").replace(ANSI_CONTROL_SEQUENCE_RE, "").replace(DANGLING_TERMINAL_SEQUENCE_SUFFIX_RE, "").replace(INVISIBLE_FORMATTING_CONTROL_RE, " ").replace(CONTROL_CHARACTER_RE, " ").replace(/\s+/g, " ").trim();
1131
+ const escaped = sanitized ? formatCodexDisplayText(sanitized) : "";
1132
+ return clipped && escaped ? `${escaped}...` : escaped;
1133
+ }
1134
+ function truncateDisplayText(value, maxLength) {
1135
+ return value.length <= maxLength ? value : `${value.slice(0, Math.max(0, maxLength - 3))}...`;
1136
+ }
1137
+ async function requestPluginApprovalOutcome(params) {
1138
+ try {
1139
+ const requestResult = await requestPluginApproval({
1140
+ paramsForRun: params.paramsForRun,
1141
+ title: params.title,
1142
+ description: params.description,
1143
+ severity: "warning",
1144
+ toolName: "codex_mcp_tool_approval"
1145
+ });
1146
+ const approvalId = requestResult?.id;
1147
+ if (!approvalId) return "unavailable";
1148
+ return mapExecDecisionToOutcome(approvalRequestExplicitlyUnavailable(requestResult) ? null : await waitForPluginApprovalDecision({
1149
+ approvalId,
1150
+ signal: params.signal
1151
+ }));
1152
+ } catch {
1153
+ return params.signal?.aborted ? "cancelled" : "denied";
1154
+ }
1155
+ }
1156
+ function buildElicitationResponse(requestedSchema, meta, outcome) {
1157
+ if (outcome === "cancelled") return {
1158
+ action: "cancel",
1159
+ content: null,
1160
+ _meta: null
1161
+ };
1162
+ if (outcome === "denied" || outcome === "unavailable") return {
1163
+ action: "decline",
1164
+ content: null,
1165
+ _meta: null
1166
+ };
1167
+ const content = buildAcceptedContent(requestedSchema, meta, outcome);
1168
+ if (!content) {
1169
+ if (hasNoSchemaProperties(requestedSchema)) return {
1170
+ action: "accept",
1171
+ content: null,
1172
+ _meta: buildAcceptedMeta(meta, outcome)
1173
+ };
1174
+ log.warn("codex MCP approval elicitation approved without a mappable response", {
1175
+ approvalKind: meta[MCP_TOOL_APPROVAL_KIND_KEY],
1176
+ fields: Object.keys(requestedSchema.properties ?? {}),
1177
+ outcome
1178
+ });
1179
+ return {
1180
+ action: "decline",
1181
+ content: null,
1182
+ _meta: null
1183
+ };
1184
+ }
1185
+ return {
1186
+ action: "accept",
1187
+ content,
1188
+ _meta: buildAcceptedMeta(meta, outcome)
1189
+ };
1190
+ }
1191
+ function buildAcceptedContent(requestedSchema, meta, outcome) {
1192
+ const properties = isJsonObject(requestedSchema.properties) ? requestedSchema.properties : void 0;
1193
+ if (!properties) return;
1194
+ const required = Array.isArray(requestedSchema.required) ? new Set(requestedSchema.required.filter((entry) => typeof entry === "string")) : /* @__PURE__ */ new Set();
1195
+ const content = {};
1196
+ let sawApprovalField = false;
1197
+ for (const [name, value] of Object.entries(properties)) {
1198
+ const schema = isJsonObject(value) ? value : void 0;
1199
+ if (!schema) continue;
1200
+ const property = {
1201
+ name,
1202
+ schema,
1203
+ required: required.has(name)
1204
+ };
1205
+ const next = readApprovalFieldValue(property, outcome) ?? readPersistFieldValue(property, meta, outcome) ?? readFallbackFieldValue(property, outcome);
1206
+ if (next === void 0) {
1207
+ if (isApprovalField(property)) sawApprovalField = true;
1208
+ if (property.required) return;
1209
+ continue;
1210
+ }
1211
+ if (isApprovalField(property)) sawApprovalField = true;
1212
+ content[name] = next;
1213
+ }
1214
+ return sawApprovalField ? content : void 0;
1215
+ }
1216
+ function readApprovalFieldValue(property, outcome) {
1217
+ if (!isApprovalField(property)) return;
1218
+ if (readString(property.schema, "type") === "boolean") return true;
1219
+ const options = readEnumOptions(property.schema);
1220
+ if (options.length === 0) return;
1221
+ const sessionChoice = options.find((option) => isSessionApprovalOption(option));
1222
+ const acceptChoice = options.find((option) => isPositiveApprovalOption(option));
1223
+ if (outcome === "approved-session") return sessionChoice?.value ?? acceptChoice?.value;
1224
+ return acceptChoice?.value ?? sessionChoice?.value;
1225
+ }
1226
+ function readPersistFieldValue(property, meta, outcome) {
1227
+ if (!isPersistField(property) || outcome !== "approved-session") return;
1228
+ const persistHints = readPersistHints(meta);
1229
+ const options = readEnumOptions(property.schema);
1230
+ if (options.length === 0) return;
1231
+ const preferred = choosePersistHint(persistHints);
1232
+ if (preferred) return options.find((option) => option.value === preferred || option.label === preferred)?.value;
1233
+ }
1234
+ function readDefaultValue(schema) {
1235
+ return schema.default;
1236
+ }
1237
+ function readFallbackFieldValue(property, outcome) {
1238
+ if (outcome === "approved-once" && isPersistField(property)) return;
1239
+ return readDefaultValue(property.schema);
1240
+ }
1241
+ function isApprovalField(property) {
1242
+ const haystack = propertyText(property).toLowerCase();
1243
+ return /\b(approve|approval|allow|accept|decision)\b/.test(haystack);
1244
+ }
1245
+ function isPersistField(property) {
1246
+ const haystack = propertyText(property).toLowerCase();
1247
+ return /\b(persist|session|always|scope)\b/.test(haystack);
1248
+ }
1249
+ function propertyText(property) {
1250
+ return [
1251
+ property.name,
1252
+ readString(property.schema, "title"),
1253
+ readString(property.schema, "description")
1254
+ ].filter(Boolean).join(" ");
1255
+ }
1256
+ function readPersistHints(meta) {
1257
+ const raw = meta.persist;
1258
+ if (typeof raw === "string") return [raw];
1259
+ if (Array.isArray(raw)) return raw.filter((entry) => typeof entry === "string");
1260
+ return ["session", "always"];
1261
+ }
1262
+ function buildAcceptedMeta(meta, outcome) {
1263
+ if (outcome !== "approved-session") return null;
1264
+ const persist = choosePersistHint(readPersistHints(meta));
1265
+ return persist ? { persist } : null;
1266
+ }
1267
+ function choosePersistHint(persistHints) {
1268
+ if (persistHints.includes("always")) return "always";
1269
+ if (persistHints.includes("session")) return "session";
1270
+ }
1271
+ function hasNoSchemaProperties(requestedSchema) {
1272
+ const properties = isJsonObject(requestedSchema.properties) ? requestedSchema.properties : {};
1273
+ return Object.keys(properties).length === 0;
1274
+ }
1275
+ function readEnumOptions(schema) {
1276
+ if (Array.isArray(schema.enum)) {
1277
+ const values = schema.enum.filter((entry) => typeof entry === "string");
1278
+ const labels = Array.isArray(schema.enumNames) ? schema.enumNames.filter((entry) => typeof entry === "string") : [];
1279
+ return values.map((value, index) => ({
1280
+ value,
1281
+ label: labels[index] ?? value
1282
+ }));
1283
+ }
1284
+ if (Array.isArray(schema.oneOf)) return schema.oneOf.map((entry) => {
1285
+ const option = isJsonObject(entry) ? entry : void 0;
1286
+ const value = readString(option, "const");
1287
+ if (!value) return;
1288
+ return {
1289
+ value,
1290
+ label: readString(option, "title") ?? value
1291
+ };
1292
+ }).filter((entry) => Boolean(entry));
1293
+ return [];
1294
+ }
1295
+ function isPositiveApprovalOption(option) {
1296
+ const haystack = `${option.value} ${option.label}`.toLowerCase();
1297
+ return /\b(allow|approve|accept|yes|continue|proceed|true)\b/.test(haystack);
1298
+ }
1299
+ function isSessionApprovalOption(option) {
1300
+ const haystack = `${option.value} ${option.label}`.toLowerCase();
1301
+ return /\b(session|always|persistent)\b/.test(haystack) && /\b(allow|approve|accept)\b/.test(haystack);
1302
+ }
1303
+ function readString(record, key) {
1304
+ const value = record?.[key];
1305
+ return typeof value === "string" && value.trim() ? value : void 0;
1306
+ }
1307
+ function readFirstString(record, keys) {
1308
+ for (const key of keys) {
1309
+ const value = readString(record, key);
1310
+ if (value) return value;
1311
+ }
1312
+ }
1313
+ //#endregion
1314
+ //#region extensions/codex/src/app-server/native-hook-relay.ts
1315
+ const CODEX_NATIVE_HOOK_RELAY_EVENTS = [
1316
+ "pre_tool_use",
1317
+ "post_tool_use",
1318
+ "permission_request",
1319
+ "before_agent_finalize"
1320
+ ];
1321
+ const CODEX_HOOK_EVENT_BY_NATIVE_EVENT = {
1322
+ pre_tool_use: "PreToolUse",
1323
+ post_tool_use: "PostToolUse",
1324
+ permission_request: "PermissionRequest",
1325
+ before_agent_finalize: "Stop"
1326
+ };
1327
+ const CODEX_HOOK_KEY_LABEL_BY_NATIVE_EVENT = {
1328
+ pre_tool_use: "pre_tool_use",
1329
+ post_tool_use: "post_tool_use",
1330
+ permission_request: "permission_request",
1331
+ before_agent_finalize: "stop"
1332
+ };
1333
+ const CODEX_SESSION_FLAGS_HOOK_SOURCE_PATHS = ["/<session-flags>/config.toml", "<session-flags>/config.toml"];
1334
+ function buildCodexNativeHookRelayConfig(params) {
1335
+ const events = params.events?.length ? params.events : CODEX_NATIVE_HOOK_RELAY_EVENTS;
1336
+ const selectedEvents = new Set(events);
1337
+ const config = { "features.hooks": true };
1338
+ const hookState = {};
1339
+ for (const event of CODEX_NATIVE_HOOK_RELAY_EVENTS) {
1340
+ const codexEvent = CODEX_HOOK_EVENT_BY_NATIVE_EVENT[event];
1341
+ const selected = selectedEvents.has(event);
1342
+ if (!selected || !params.relay.shouldRelayEvent(event)) {
1343
+ if (selected || params.clearOmittedEvents) config[`hooks.${codexEvent}`] = [];
1344
+ if (params.clearOmittedEvents) for (const sourcePath of CODEX_SESSION_FLAGS_HOOK_SOURCE_PATHS) hookState[`${sourcePath}:${CODEX_HOOK_KEY_LABEL_BY_NATIVE_EVENT[event]}:0:0`] = { enabled: false };
1345
+ continue;
1346
+ }
1347
+ const command = params.relay.commandForEvent(event);
1348
+ const timeout = normalizeHookTimeoutSec(params.hookTimeoutSec);
1349
+ config[`hooks.${codexEvent}`] = [{ hooks: [{
1350
+ type: "command",
1351
+ command,
1352
+ timeout,
1353
+ async: false,
1354
+ statusMessage: "DaoCore native hook relay"
1355
+ }] }];
1356
+ const state = {
1357
+ enabled: true,
1358
+ trusted_hash: codexCommandHookTrustedHash({
1359
+ event,
1360
+ command,
1361
+ timeout,
1362
+ statusMessage: "DaoCore native hook relay"
1363
+ })
1364
+ };
1365
+ for (const sourcePath of CODEX_SESSION_FLAGS_HOOK_SOURCE_PATHS) hookState[`${sourcePath}:${CODEX_HOOK_KEY_LABEL_BY_NATIVE_EVENT[event]}:0:0`] = state;
1366
+ }
1367
+ config["hooks.state"] = hookState;
1368
+ return config;
1369
+ }
1370
+ function buildCodexNativeHookRelayDisabledConfig() {
1371
+ return {
1372
+ "features.hooks": false,
1373
+ "hooks.PreToolUse": [],
1374
+ "hooks.PostToolUse": [],
1375
+ "hooks.PermissionRequest": [],
1376
+ "hooks.Stop": []
1377
+ };
1378
+ }
1379
+ function normalizeHookTimeoutSec(value) {
1380
+ return typeof value === "number" && Number.isFinite(value) && value > 0 ? Math.ceil(value) : 5;
1381
+ }
1382
+ function codexCommandHookTrustedHash(params) {
1383
+ const identity = {
1384
+ event_name: CODEX_HOOK_KEY_LABEL_BY_NATIVE_EVENT[params.event],
1385
+ hooks: [{
1386
+ async: false,
1387
+ command: params.command,
1388
+ statusMessage: params.statusMessage,
1389
+ timeout: params.timeout,
1390
+ type: "command"
1391
+ }]
1392
+ };
1393
+ return `sha256:${createHash("sha256").update(JSON.stringify(sortJsonValue(identity))).digest("hex")}`;
1394
+ }
1395
+ function sortJsonValue(value) {
1396
+ if (!value || typeof value !== "object") return value;
1397
+ if (Array.isArray(value)) return value.map(sortJsonValue);
1398
+ const sorted = {};
1399
+ for (const key of Object.keys(value).toSorted()) sorted[key] = sortJsonValue(value[key]);
1400
+ return sorted;
1401
+ }
1402
+ //#endregion
1403
+ //#region extensions/codex/src/app-server/vision-tools.ts
1404
+ function filterToolsForVisionInputs(tools, params) {
1405
+ if (!params.modelHasVision || !params.hasInboundImages) return tools;
1406
+ return tools.filter((tool) => tool.name !== "image");
1407
+ }
1408
+ //#endregion
1409
+ export { handleCodexAppServerElicitationRequest as a, emitDynamicToolTerminalDiagnostic as c, buildCodexNativeHookRelayDisabledConfig as i, handleCodexAppServerApprovalRequest as l, CODEX_NATIVE_HOOK_RELAY_EVENTS as n, emitDynamicToolErrorDiagnostic as o, buildCodexNativeHookRelayConfig as r, emitDynamicToolStartedDiagnostic as s, filterToolsForVisionInputs as t };