@pixelzx/genesis 2026.6.6-1 → 2026.6.7

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 (1890) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-FuQvBD6U.js +201 -0
  4. package/dist/abort-cutoff.runtime-DhhkmUom.js +20 -0
  5. package/dist/abort-cutoff.runtime.js +1 -1
  6. package/dist/abort.runtime-B3IgkoFt.js +2 -0
  7. package/dist/abort.runtime.js +1 -1
  8. package/dist/accounts-BPUJOLhQ.js +66 -0
  9. package/dist/accounts-CAneScu8.js +104 -0
  10. package/dist/accounts-CHR1oSF7.js +43 -0
  11. package/dist/accounts-CJ6NSXHe.js +2 -0
  12. package/dist/accounts-DIkEzenx.js +365 -0
  13. package/dist/accounts-DSBZWK21.js +107 -0
  14. package/dist/accounts.runtime-CbxAqfkd.js +2 -0
  15. package/dist/accounts.runtime.js +1 -1
  16. package/dist/acp-cli-ogRPWqZT.js +2217 -0
  17. package/dist/acp-spawn-8dy4yT3V.js +2 -0
  18. package/dist/acp-spawn-BjYzM6z-.js +1093 -0
  19. package/dist/acp-stateful-target-driver-BycE6-83.js +89 -0
  20. package/dist/action-agents-l7277wqt.js +67 -0
  21. package/dist/action-focus-Dl60p5pD.js +132 -0
  22. package/dist/action-help-DxLv4lVR.js +7 -0
  23. package/dist/action-info-DL9E3-WR.js +101 -0
  24. package/dist/action-kill-D9o9OmhF.js +33 -0
  25. package/dist/action-list-CHZdMgmX.js +21 -0
  26. package/dist/action-log-CU2gXtSM.js +30 -0
  27. package/dist/action-send-Bh6VyKBO.js +39 -0
  28. package/dist/action-spawn-CRh30i-w.js +47 -0
  29. package/dist/action-unfocus-DWfvqVUr.js +29 -0
  30. package/dist/actions.runtime-CSqrY29N.js +18 -0
  31. package/dist/actions.runtime-DfxS3edG.js +5 -0
  32. package/dist/actions.runtime.js +1 -1
  33. package/dist/agent-command-VhOY45sc.js +874 -0
  34. package/dist/agent-delivery-KWJUVuVh.js +76 -0
  35. package/dist/agent-harness-runtime-BMQd9IQM.js +144 -0
  36. package/dist/agent-rstdDGqC.js +2 -0
  37. package/dist/agent-runner-utils-B6emOCxL.js +239 -0
  38. package/dist/agent-runner.runtime-Dt9pfuFv.js +3455 -0
  39. package/dist/agent-runner.runtime.js +1 -1
  40. package/dist/agent-runtime-D5sio5gj.js +18 -0
  41. package/dist/agents-DETbymgH.js +5 -0
  42. package/dist/agents-JnpGV0Mg.js +954 -0
  43. package/dist/agents.command-shared-DP-GYkQM.js +40 -0
  44. package/dist/aliases-CjpePDVQ.js +96 -0
  45. package/dist/aliases-Doxg0x1v.js +2 -0
  46. package/dist/api-3RLMm-sv.js +48 -0
  47. package/dist/api-BFMX7Y4G.js +139 -0
  48. package/dist/api-DNZZlJ9_.js +3 -0
  49. package/dist/api-DT7zQn5K.js +5 -0
  50. package/dist/api-Dg7zYoZ_.js +3 -0
  51. package/dist/api-cghJ3F6o.js +4 -0
  52. package/dist/apply-DfMBIGyY.js +508 -0
  53. package/dist/apply.runtime-C0oOWIW8.js +2 -0
  54. package/dist/apply.runtime.js +1 -1
  55. package/dist/approval-client-helpers-D2LpKFDf.js +82 -0
  56. package/dist/approval-delivery-helpers-CmhRlLZJ.js +134 -0
  57. package/dist/approval-gateway-resolver-BjqCdv8k.js +29 -0
  58. package/dist/approval-gateway-runtime-vc_h56PW.js +2 -0
  59. package/dist/approval-handler-runtime-CLi8o4N6.js +439 -0
  60. package/dist/approval-native-helpers-BJTvZT00.js +33 -0
  61. package/dist/approval-native-runtime-BCglJkGQ.js +729 -0
  62. package/dist/approval-renderers-B2Vy1H8m.js +64 -0
  63. package/dist/attempt-execution.runtime-BJ2ggQLO.js +509 -0
  64. package/dist/attempt-execution.runtime.js +1 -1
  65. package/dist/attempt-execution.shared-drVqEuBX.js +22 -0
  66. package/dist/attempt.prompt-helpers-CPOKGBRq.js +221 -0
  67. package/dist/attempt.tool-run-context-b245l8XM.js +933 -0
  68. package/dist/audit-DTHRJzg2.js +939 -0
  69. package/dist/audit-membership-runtime-BJqpONbJ.js +550 -0
  70. package/dist/audit.runtime-CX2MkQvJ.js +7 -0
  71. package/dist/audit.runtime.js +1 -1
  72. package/dist/auth-4Bm-1bcd.js +177 -0
  73. package/dist/auth-BZdTw_F-.js +56 -0
  74. package/dist/auth-CuwCoyT1.js +550 -0
  75. package/dist/auth-DIgzPDDK.js +2 -0
  76. package/dist/auth-order-BY3KAiKC.js +2 -0
  77. package/dist/auth-order-Dg56giIe.js +139 -0
  78. package/dist/base-url-C558HJO5.js +15 -0
  79. package/dist/bash-tools-CfDemvWu.js +2824 -0
  80. package/dist/bash-tools-Dn5gcYvt.js +3 -0
  81. package/dist/bash-tools.exec-runtime-dke732lC.js +829 -0
  82. package/dist/best-effort-delivery-DljQXVME.js +22 -0
  83. package/dist/binding-routing-DR_67bg0.js +85 -0
  84. package/dist/binding-targets-DTa463kX.js +121 -0
  85. package/dist/block-streaming-CSQXIKzf.js +103 -0
  86. package/dist/bluebubbles-Ct06wUcN.js +77 -0
  87. package/dist/brave-web-search-provider-CXpJbGgI.js +111 -0
  88. package/dist/brave-web-search-provider.runtime-wY0sclse.js +229 -0
  89. package/dist/brave-web-search-provider.runtime.js +1 -1
  90. package/dist/brave-web-search-provider.shared-CRDSDuDf.js +174 -0
  91. package/dist/bridge-auth-registry-BorAQxuW.js +23 -0
  92. package/dist/bridge-server-BjsnFWH5.js +113 -0
  93. package/dist/browser-control-auth-K_ABcymZ.js +2 -0
  94. package/dist/browser-node-runtime-Djr0LEX4.js +12 -0
  95. package/dist/browser-profiles-D-JVGcFQ.js +2 -0
  96. package/dist/browser-runtime-Dtu4pSLX.js +387 -0
  97. package/dist/browser-setup-tools-DOMK1dxP.js +13 -0
  98. package/dist/build-DIqCC9wY.js +550 -0
  99. package/dist/build-info.json +3 -3
  100. package/dist/bundled/boot-md/handler.js +3 -3
  101. package/dist/bundled/session-memory/handler.js +1 -1
  102. package/dist/call-CBwbz0Y_.js +3 -0
  103. package/dist/call-CMzLsAeQ.js +331 -0
  104. package/dist/call-status-D_PRqurB.js +33 -0
  105. package/dist/call.runtime-TShzrwtE.js +2 -0
  106. package/dist/call.runtime.js +1 -1
  107. package/dist/capability-cli-eqSRFvPG.js +1401 -0
  108. package/dist/card-command-DgCNU0bS.js +241 -0
  109. package/dist/catalog-provider-BQCfbyPd.js +40 -0
  110. package/dist/catchup-B0RMVns9.js +300 -0
  111. package/dist/channel-35I4A3FQ.js +1802 -0
  112. package/dist/channel-B68Jn_67.js +491 -0
  113. package/dist/channel-BpHCHrCO.js +350 -0
  114. package/dist/channel-CLV2rd5J.js +1174 -0
  115. package/dist/channel-COt8yEeA.js +226 -0
  116. package/dist/channel-CQOr5HA2.js +595 -0
  117. package/dist/channel-CY88u47q.js +1100 -0
  118. package/dist/channel-Cz5FQxuV.js +1320 -0
  119. package/dist/channel-_FIMA_4n.js +840 -0
  120. package/dist/channel-core-DH_fXGdB.js +5 -0
  121. package/dist/channel-inbound-DsSKYRQk.js +31 -0
  122. package/dist/channel-kbFJLAok.js +453 -0
  123. package/dist/channel-plugin-runtime-1zw5fP7e.js +771 -0
  124. package/dist/channel-resolution-BQCJwoVA.js +39 -0
  125. package/dist/channel-runtime-DKTzKZrY.js +425 -0
  126. package/dist/channel-selection-CfVNh5Ma.js +126 -0
  127. package/dist/channel-selection.runtime-5JjJNFm5.js +2 -0
  128. package/dist/channel-selection.runtime.js +1 -1
  129. package/dist/channel-t7y5VhIk.js +297 -0
  130. package/dist/channel.runtime-BxFS1fqc.js +26 -0
  131. package/dist/channel.runtime-C4vTK1SO.js +576 -0
  132. package/dist/channel.runtime-Cb5xElcA.js +42398 -0
  133. package/dist/channel.runtime-Cg2IHutr.js +89 -0
  134. package/dist/channel.runtime-CuDcjlCH.js +4 -0
  135. package/dist/channel.runtime-DhuYxzU_.js +67 -0
  136. package/dist/channel.runtime-LtoAmHpA.js +2364 -0
  137. package/dist/channel.runtime-fe2tuhl7.js +430 -0
  138. package/dist/channel.runtime.js +1 -1
  139. package/dist/channel.setup-De742gXr.js +10 -0
  140. package/dist/channel2.runtime-D0-Q3OqX.js +109 -0
  141. package/dist/channel2.runtime.js +1 -1
  142. package/dist/channels-Dg381GJl.js +733 -0
  143. package/dist/channels-cli-C4Mv5lRD.js +268 -0
  144. package/dist/chat-DraQ_Vnc.js +2830 -0
  145. package/dist/chrome-NuBBXoKP.js +1430 -0
  146. package/dist/chrome-mcp-Bzn6x9ZE.js +2 -0
  147. package/dist/chrome-mcp-JcJrSyd_.js +600 -0
  148. package/dist/chrome.executables-B2fHBMhv.js +541 -0
  149. package/dist/chunk-nFZYBJd4.js +268 -0
  150. package/dist/clawbot-cli-BZ5Ho8RJ.js +9 -0
  151. package/dist/cli/daemon-cli.js +3 -3
  152. package/dist/cli-B8D7xwgW.js +2 -0
  153. package/dist/cli-BbCsXDcy.js +2 -0
  154. package/dist/cli-Ct2Cgbp8.js +154 -0
  155. package/dist/cli-D1e_2N91.js +3726 -0
  156. package/dist/cli-D8pyHyFi.js +72 -0
  157. package/dist/cli-eRz4BLSt.js +2 -0
  158. package/dist/cli-mD8ZWE4Y.js +219 -0
  159. package/dist/cli-runner-BVFPfETV.js +286 -0
  160. package/dist/cli-runner.runtime-CcxMMyO0.js +3 -0
  161. package/dist/cli-runner.runtime-MmlDBELB.js +4 -0
  162. package/dist/cli-runner.runtime.js +1 -1
  163. package/dist/cli-startup-metadata.json +2 -2
  164. package/dist/cli.runtime-CG9Epd6c.js +1261 -0
  165. package/dist/cli.runtime.js +1 -1
  166. package/dist/client-BtyYQE4I.js +713 -0
  167. package/dist/client-XqW1gKEi.js +138 -0
  168. package/dist/client-info-DeQMz3zN.js +52 -0
  169. package/dist/command-auth-C8YZ7xNT.js +409 -0
  170. package/dist/command-auth-CZjLC0A5.js +76 -0
  171. package/dist/command-config-resolution-C42_gG_b.js +2 -0
  172. package/dist/command-config-resolution-DGrpZjql.js +23 -0
  173. package/dist/command-config-resolution.runtime-D8PGJbcf.js +2 -0
  174. package/dist/command-config-resolution.runtime.js +1 -1
  175. package/dist/command-execution-startup-LCePq-pd.js +324 -0
  176. package/dist/command-gates-C1GpyUaI.js +47 -0
  177. package/dist/command-registry-Brd-fdF6.js +9 -0
  178. package/dist/command-registry-C9XhD-0z.js +4 -0
  179. package/dist/command-registry-core-BBFaOPyw.js +106 -0
  180. package/dist/command-secret-gateway-_i9GgsPE.js +528 -0
  181. package/dist/command-status.runtime-C-azOR6K.js +87 -0
  182. package/dist/command-status.runtime.js +1 -1
  183. package/dist/commands-acp-cpGZ404g.js +77 -0
  184. package/dist/commands-compact.runtime-CXWGv2V6.js +10 -0
  185. package/dist/commands-compact.runtime.js +1 -1
  186. package/dist/commands-context-DZzZWgOe.js +38 -0
  187. package/dist/commands-core.runtime-BqbYtFGd.js +2 -0
  188. package/dist/commands-core.runtime.js +1 -1
  189. package/dist/commands-handlers.runtime-BcIJeLbE.js +4599 -0
  190. package/dist/commands-handlers.runtime.js +1 -1
  191. package/dist/commands-models-BScPCL8E.js +327 -0
  192. package/dist/commands-reset-hooks-5uvV2mDE.js +135 -0
  193. package/dist/commands-status-CIyza-rp.js +16 -0
  194. package/dist/commands-status.runtime-CqMsNHJz.js +3 -0
  195. package/dist/commands-status.runtime.js +1 -1
  196. package/dist/commands-subagents-control.runtime-BVTHxVDG.js +2 -0
  197. package/dist/commands-subagents-control.runtime-DdiL_B5Y.js +3 -0
  198. package/dist/commands-subagents-control.runtime.js +1 -1
  199. package/dist/commands-system-prompt-DCmABzHv.js +158 -0
  200. package/dist/commands-system-prompt-DsWVuYqh.js +2 -0
  201. package/dist/commands.runtime-CBu1iNc5.js +167 -0
  202. package/dist/commands.runtime.js +1 -1
  203. package/dist/compact-OC23uUnx.js +1118 -0
  204. package/dist/compact.runtime-BnEUkxbT.js +12 -0
  205. package/dist/compact.runtime.js +1 -1
  206. package/dist/completion-cli-Dazyh2sJ.js +328 -0
  207. package/dist/config-BQkNdc69.js +252 -0
  208. package/dist/config-api-BKYSOnnY.js +2 -0
  209. package/dist/config-cli-DLlHp2db.js +1078 -0
  210. package/dist/config-compat-BIX-j6Si.js +130 -0
  211. package/dist/config-compat-BwlAvvWb.js +126 -0
  212. package/dist/config-guard-MokLrRXO.js +96 -0
  213. package/dist/config-runtime-EDLCUCSu.js +32 -0
  214. package/dist/configure-Bb8n7ry_.js +1252 -0
  215. package/dist/configure-_pHM_yQw.js +2 -0
  216. package/dist/connect-options-3xkNjdH1.js +699 -0
  217. package/dist/control-auth-BXNajQ4N.js +125 -0
  218. package/dist/control-service-89oBONRk.js +156 -0
  219. package/dist/control-ui/assets/agents-BQsvYsmp.js +1052 -0
  220. package/dist/control-ui/assets/canvas-D92UKk4C.js +269 -0
  221. package/dist/control-ui/assets/channels-B23D1XmP.js +463 -0
  222. package/dist/control-ui/assets/cron-CYzrBBv6.js +933 -0
  223. package/dist/control-ui/assets/debug-C8av-vpc.js +94 -0
  224. package/dist/control-ui/assets/index-ChL66WCS.js +6238 -0
  225. package/dist/control-ui/assets/index-Dq9zdUBj.css +1 -0
  226. package/dist/control-ui/assets/instances-qfDdYtE0.js +57 -0
  227. package/dist/control-ui/assets/mcp-CipBqkHK.js +373 -0
  228. package/dist/control-ui/assets/nodes-WP7e87Mm.js +618 -0
  229. package/dist/control-ui/assets/plugins-BZGJKpWs.js +273 -0
  230. package/dist/control-ui/assets/sessions-7NbJpVyg.js +306 -0
  231. package/dist/control-ui/assets/skills-hW_GTRp3.js +323 -0
  232. package/dist/control-ui/assets/wallet-Bga18qp4.js +285 -0
  233. package/dist/control-ui/index.html +2 -2
  234. package/dist/control-ui-nxEuCu7Y.js +1043 -0
  235. package/dist/conversation-id-BXdEWBuk.js +38 -0
  236. package/dist/conversation-id-HnQrCUJb.js +235 -0
  237. package/dist/conversation-runtime-DOPjHG-D.js +31 -0
  238. package/dist/core-BglliBki.js +275 -0
  239. package/dist/create-DcvM0ElD.js +80 -0
  240. package/dist/cron-cli-DbZllbTi.js +713 -0
  241. package/dist/daemon-cli-BCP6oYnN.js +12 -0
  242. package/dist/dashboard-74d-EIMB.js +81 -0
  243. package/dist/dashboard-C0aOhuxv.js +2 -0
  244. package/dist/ddg-client-DUe6RTVg.js +147 -0
  245. package/dist/ddg-search-provider-Bm0jAm4h.js +54 -0
  246. package/dist/delegate-0l_cL2en.js +64 -0
  247. package/dist/deliver-BbAfYPEn.js +3 -0
  248. package/dist/deliver-DmZnoo4L.js +747 -0
  249. package/dist/deliver-runtime-5H2EYniG.js +2 -0
  250. package/dist/delivery-context-DP5JLMHJ.js +40 -0
  251. package/dist/delivery-outbound.runtime-DQEeDEsu.js +6 -0
  252. package/dist/delivery-outbound.runtime.js +1 -1
  253. package/dist/delivery.runtime-Bi7HZGxD.js +253 -0
  254. package/dist/delivery.runtime.js +1 -1
  255. package/dist/detached-task-runtime-DlQ3fJk5.js +73 -0
  256. package/dist/devices-cli-BLCk402O.js +498 -0
  257. package/dist/diagnostics-Ccv6wIwn.js +154 -0
  258. package/dist/direct-dm-lEcFUgjs.js +64 -0
  259. package/dist/directive-handling.fast-lane-Cp4AUlKY.js +66 -0
  260. package/dist/directive-handling.impl-5h27Bn7L.js +703 -0
  261. package/dist/directive-handling.impl-XC63bDbc.js +2 -0
  262. package/dist/directive-handling.model-selection-D0aMABmk.js +114 -0
  263. package/dist/directive-handling.persist.runtime-DDNAkC4Z.js +215 -0
  264. package/dist/directive-handling.persist.runtime.js +1 -1
  265. package/dist/directive-handling.shared-DyVSHQBC.js +56 -0
  266. package/dist/directory-cli-CDvyD_lg.js +240 -0
  267. package/dist/dispatch-Dd327enz.js +1131 -0
  268. package/dist/dispatch-acp-6k3pJubU.js +981 -0
  269. package/dist/dispatch-acp-manager.runtime-B7qhOTmA.js +3 -0
  270. package/dist/dispatch-acp-manager.runtime.js +1 -1
  271. package/dist/dispatch-acp-media.runtime-Dh6QaiKm.js +4 -0
  272. package/dist/dispatch-acp-media.runtime.js +1 -1
  273. package/dist/dispatch-acp-session.runtime-DIcbAze4.js +2 -0
  274. package/dist/dispatch-acp-session.runtime.js +1 -1
  275. package/dist/dispatch-acp.runtime-25XWZDxg.js +19 -0
  276. package/dist/dispatch-acp.runtime.js +1 -1
  277. package/dist/doctor-config-flow-sE-lNSad.js +420 -0
  278. package/dist/doctor-config-preflight-VYCO67J4.js +63 -0
  279. package/dist/doctor-config-preflight-qSk2JNLg.js +2 -0
  280. package/dist/doctor-contract-BAsLLlR_.js +26 -0
  281. package/dist/doctor-device-pairing-BXDxtsmA.js +307 -0
  282. package/dist/doctor-gateway-daemon-flow-CHRWhGJG.js +250 -0
  283. package/dist/doctor-gateway-health-B04Kph1-.js +63 -0
  284. package/dist/doctor-health-contributions-Di1lbh4V.js +493 -0
  285. package/dist/doctor-health-vZ_aKkfh.js +59 -0
  286. package/dist/doctor-prompter-Cr1NyTHN.js +56 -0
  287. package/dist/doctor-sandbox-CrC9AbfL.js +194 -0
  288. package/dist/doctor-state-migrations-tkILPnwB.js +2 -0
  289. package/dist/doctor-workspace-status-CPUsFX3w.js +75 -0
  290. package/dist/dreaming-CeLuSaLi.js +1582 -0
  291. package/dist/dreaming-narrative-gKfNqC2s.js +596 -0
  292. package/dist/dreaming-shared-BLs-EJbE.js +21 -0
  293. package/dist/embedded-gateway-stub.runtime-8jv6iwO4.js +9 -0
  294. package/dist/embedded-gateway-stub.runtime.js +1 -1
  295. package/dist/embeddings-CSeRG-6f.js +215 -0
  296. package/dist/embeddings-http-9k11WSE6.js +205 -0
  297. package/dist/entry.js +2 -2
  298. package/dist/exa-web-search-provider-DeSQ1lkN.js +80 -0
  299. package/dist/exa-web-search-provider.runtime-BHWIPnmu.js +302 -0
  300. package/dist/exa-web-search-provider.runtime-C84CVfco.js +2 -0
  301. package/dist/exa-web-search-provider.runtime.js +1 -1
  302. package/dist/exec-approval-forwarder.runtime-BMw0YxXn.js +3 -0
  303. package/dist/exec-approval-forwarder.runtime.js +1 -1
  304. package/dist/exec-approval-reply-BTNXbvSi.js +2 -0
  305. package/dist/exec-approval-reply-BVINNdDT.js +296 -0
  306. package/dist/exec-approval-session-target-BclZJwRq.js +176 -0
  307. package/dist/exec-approvals-cli-BvRs9Hvl.js +498 -0
  308. package/dist/exec-defaults-BzfzJhdd.js +2 -0
  309. package/dist/exec-defaults-DJtYK-Wg.js +67 -0
  310. package/dist/execute.runtime-C-v-Cnhl.js +1363 -0
  311. package/dist/execute.runtime.js +1 -1
  312. package/dist/extensionAPI.js +3 -3
  313. package/dist/extensions/active-memory/index.js +3 -3
  314. package/dist/extensions/bluebubbles/api.js +3 -3
  315. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  316. package/dist/extensions/brave/index.js +1 -1
  317. package/dist/extensions/brave/test-api.js +1 -1
  318. package/dist/extensions/brave/web-search-provider.js +1 -1
  319. package/dist/extensions/browser/browser-bridge.js +1 -1
  320. package/dist/extensions/browser/browser-config.js +4 -4
  321. package/dist/extensions/browser/browser-control-auth.js +2 -2
  322. package/dist/extensions/browser/browser-doctor.js +5 -5
  323. package/dist/extensions/browser/browser-host-inspection.js +1 -1
  324. package/dist/extensions/browser/browser-maintenance.js +2 -2
  325. package/dist/extensions/browser/browser-profiles.js +2 -2
  326. package/dist/extensions/browser/browser-runtime-api.js +14 -14
  327. package/dist/extensions/browser/index.js +1 -1
  328. package/dist/extensions/browser/plugin-registration.js +1 -1
  329. package/dist/extensions/browser/register.runtime.js +3 -3
  330. package/dist/extensions/browser/runtime-api.js +15 -15
  331. package/dist/extensions/browser/setup-api.js +2 -2
  332. package/dist/extensions/browser/test-support.js +1 -1
  333. package/dist/extensions/byteplus/index.js +1 -1
  334. package/dist/extensions/byteplus/video-generation-provider.js +1 -1
  335. package/dist/extensions/chutes/api.js +3 -3
  336. package/dist/extensions/chutes/index.js +4 -4
  337. package/dist/extensions/chutes/models.js +1 -1
  338. package/dist/extensions/chutes/onboard.js +2 -2
  339. package/dist/extensions/chutes/provider-catalog.js +1 -1
  340. package/dist/extensions/cloudflare-ai-gateway/api.js +1 -1
  341. package/dist/extensions/cloudflare-ai-gateway/catalog-provider.js +1 -1
  342. package/dist/extensions/cloudflare-ai-gateway/index.js +2 -2
  343. package/dist/extensions/comfy/image-generation-provider.js +2 -2
  344. package/dist/extensions/comfy/index.js +3 -3
  345. package/dist/extensions/comfy/music-generation-provider.js +1 -1
  346. package/dist/extensions/comfy/video-generation-provider.js +2 -2
  347. package/dist/extensions/comfy/workflow-runtime.js +1 -1
  348. package/dist/extensions/deepgram/index.js +1 -1
  349. package/dist/extensions/deepgram/realtime-transcription-provider.js +1 -1
  350. package/dist/extensions/deepgram/test-api.js +1 -1
  351. package/dist/extensions/device-pair/api.js +2 -2
  352. package/dist/extensions/device-pair/index.js +5 -5
  353. package/dist/extensions/device-pair/notify.js +1 -1
  354. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  355. package/dist/extensions/device-pair/qr-image.js +2 -2
  356. package/dist/extensions/duckduckgo/index.js +1 -1
  357. package/dist/extensions/duckduckgo/web-search-provider.js +1 -1
  358. package/dist/extensions/elevenlabs/config-compat.js +1 -1
  359. package/dist/extensions/elevenlabs/contract-api.js +2 -2
  360. package/dist/extensions/elevenlabs/doctor-contract.js +2 -2
  361. package/dist/extensions/elevenlabs/index.js +2 -2
  362. package/dist/extensions/elevenlabs/realtime-transcription-provider.js +1 -1
  363. package/dist/extensions/elevenlabs/setup-api.js +1 -1
  364. package/dist/extensions/elevenlabs/speech-provider.js +1 -1
  365. package/dist/extensions/elevenlabs/test-api.js +2 -2
  366. package/dist/extensions/exa/index.js +1 -1
  367. package/dist/extensions/exa/test-api.js +1 -1
  368. package/dist/extensions/exa/web-search-provider.js +1 -1
  369. package/dist/extensions/fal/image-generation-provider.js +1 -1
  370. package/dist/extensions/fal/index.js +2 -2
  371. package/dist/extensions/fal/test-api.js +2 -2
  372. package/dist/extensions/fal/video-generation-provider.js +1 -1
  373. package/dist/extensions/firecrawl/api.js +1 -1
  374. package/dist/extensions/github-copilot/api.js +1 -1
  375. package/dist/extensions/github-copilot/auth.js +1 -1
  376. package/dist/extensions/github-copilot/embeddings.js +1 -1
  377. package/dist/extensions/github-copilot/index.js +6 -6
  378. package/dist/extensions/github-copilot/login.js +1 -1
  379. package/dist/extensions/github-copilot/models-defaults.js +1 -1
  380. package/dist/extensions/github-copilot/models.js +1 -1
  381. package/dist/extensions/github-copilot/register.runtime.js +1 -1
  382. package/dist/extensions/github-copilot/replay-policy.js +1 -1
  383. package/dist/extensions/google-meet/index.js +5 -5
  384. package/dist/extensions/huggingface/api.js +3 -3
  385. package/dist/extensions/huggingface/index.js +2 -2
  386. package/dist/extensions/huggingface/models.js +1 -1
  387. package/dist/extensions/huggingface/onboard.js +1 -1
  388. package/dist/extensions/huggingface/provider-catalog.js +2 -2
  389. package/dist/extensions/imessage/api.js +5 -5
  390. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  391. package/dist/extensions/imessage/contract-api.js +2 -2
  392. package/dist/extensions/imessage/media-contract-api.js +2 -2
  393. package/dist/extensions/imessage/runtime-api.js +5 -5
  394. package/dist/extensions/imessage/test-api.js +2 -2
  395. package/dist/extensions/irc/api.js +2 -2
  396. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  397. package/dist/extensions/kilocode/api.js +2 -2
  398. package/dist/extensions/kilocode/index.js +3 -3
  399. package/dist/extensions/kilocode/onboard.js +2 -2
  400. package/dist/extensions/kilocode/provider-catalog.js +1 -1
  401. package/dist/extensions/kilocode/provider-models.js +1 -1
  402. package/dist/extensions/kilocode/shared.js +1 -1
  403. package/dist/extensions/kimi-coding/index.js +2 -2
  404. package/dist/extensions/kimi-coding/stream.js +1 -1
  405. package/dist/extensions/line/api.js +2 -2
  406. package/dist/extensions/line/channel-plugin-api.js +1 -1
  407. package/dist/extensions/line/contract-api.js +1 -1
  408. package/dist/extensions/line/index.js +1 -1
  409. package/dist/extensions/line/runtime-api.js +7 -7
  410. package/dist/extensions/line/setup-api.js +1 -1
  411. package/dist/extensions/llm-task/index.js +1 -1
  412. package/dist/extensions/lmstudio/api.js +1 -1
  413. package/dist/extensions/lmstudio/index.js +2 -2
  414. package/dist/extensions/lmstudio/memory-embedding-adapter.js +1 -1
  415. package/dist/extensions/lmstudio/runtime-api.js +1 -1
  416. package/dist/extensions/lobster/runtime-api.js +1 -1
  417. package/dist/extensions/mattermost/api.js +1 -1
  418. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  419. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  420. package/dist/extensions/mattermost/policy-api.js +1 -1
  421. package/dist/extensions/mattermost/runtime-api.js +9 -9
  422. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  423. package/dist/extensions/memory-core/api.js +1 -1
  424. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  425. package/dist/extensions/memory-core/index.js +9 -9
  426. package/dist/extensions/memory-core/manager-runtime.js +1 -1
  427. package/dist/extensions/memory-core/runtime-api.js +4 -4
  428. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  429. package/dist/extensions/memory-lancedb/index.js +2 -2
  430. package/dist/extensions/memory-wiki/cli-metadata.js +1 -1
  431. package/dist/extensions/memory-wiki/index.js +1 -1
  432. package/dist/extensions/microsoft/index.js +1 -1
  433. package/dist/extensions/microsoft/speech-provider.js +1 -1
  434. package/dist/extensions/microsoft/test-api.js +1 -1
  435. package/dist/extensions/microsoft/tts.js +1 -1
  436. package/dist/extensions/microsoft-foundry/auth.js +1 -1
  437. package/dist/extensions/microsoft-foundry/cli.js +1 -1
  438. package/dist/extensions/microsoft-foundry/index.js +1 -1
  439. package/dist/extensions/microsoft-foundry/onboard.js +2 -2
  440. package/dist/extensions/microsoft-foundry/provider.js +1 -1
  441. package/dist/extensions/microsoft-foundry/runtime.js +1 -1
  442. package/dist/extensions/microsoft-foundry/shared-runtime.js +2 -2
  443. package/dist/extensions/microsoft-foundry/shared.js +1 -1
  444. package/dist/extensions/minimax/index.js +5 -5
  445. package/dist/extensions/minimax/music-generation-provider.js +1 -1
  446. package/dist/extensions/minimax/provider-registration.js +1 -1
  447. package/dist/extensions/minimax/speech-provider.js +1 -1
  448. package/dist/extensions/minimax/test-api.js +3 -3
  449. package/dist/extensions/minimax/video-generation-provider.js +1 -1
  450. package/dist/extensions/minimax/web-search-provider.js +1 -1
  451. package/dist/extensions/mistral/index.js +2 -2
  452. package/dist/extensions/mistral/provider-compat.js +1 -1
  453. package/dist/extensions/mistral/realtime-transcription-provider.js +1 -1
  454. package/dist/extensions/mistral/test-api.js +1 -1
  455. package/dist/extensions/moonshot/index.js +1 -1
  456. package/dist/extensions/moonshot/test-api.js +1 -1
  457. package/dist/extensions/moonshot/web-search-provider.js +1 -1
  458. package/dist/extensions/msteams/api.js +1 -1
  459. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  460. package/dist/extensions/msteams/runtime-api.js +4 -4
  461. package/dist/extensions/msteams/test-api.js +1 -1
  462. package/dist/extensions/nextcloud-talk/api.js +1 -1
  463. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  464. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  465. package/dist/extensions/ollama/api.js +3 -3
  466. package/dist/extensions/ollama/index.js +5 -5
  467. package/dist/extensions/ollama/runtime-api.js +1 -1
  468. package/dist/extensions/ollama/web-search-provider.js +1 -1
  469. package/dist/extensions/openai/api.js +4 -4
  470. package/dist/extensions/openai/base-url.js +1 -1
  471. package/dist/extensions/openai/image-generation-provider.js +1 -1
  472. package/dist/extensions/openai/index.js +8 -8
  473. package/dist/extensions/openai/native-web-search.js +1 -1
  474. package/dist/extensions/openai/openai-codex-auth-identity.js +1 -1
  475. package/dist/extensions/openai/openai-codex-device-code.js +1 -1
  476. package/dist/extensions/openai/openai-codex-provider.js +1 -1
  477. package/dist/extensions/openai/openai-codex-shared.js +1 -1
  478. package/dist/extensions/openai/openai-provider.js +1 -1
  479. package/dist/extensions/openai/realtime-provider-shared.js +1 -1
  480. package/dist/extensions/openai/realtime-transcription-provider.js +1 -1
  481. package/dist/extensions/openai/realtime-voice-provider.js +1 -1
  482. package/dist/extensions/openai/register.runtime.js +6 -6
  483. package/dist/extensions/openai/shared.js +1 -1
  484. package/dist/extensions/openai/speech-provider.js +1 -1
  485. package/dist/extensions/openai/test-api.js +5 -5
  486. package/dist/extensions/openai/transport-policy.js +1 -1
  487. package/dist/extensions/openai/video-generation-provider.js +1 -1
  488. package/dist/extensions/opencode/index.js +1 -1
  489. package/dist/extensions/openrouter/api.js +2 -2
  490. package/dist/extensions/openrouter/image-generation-provider.js +1 -1
  491. package/dist/extensions/openrouter/index.js +2 -2
  492. package/dist/extensions/openrouter/register.runtime.js +1 -1
  493. package/dist/extensions/openrouter/speech-provider.js +1 -1
  494. package/dist/extensions/openrouter/test-api.js +2 -2
  495. package/dist/extensions/openshell/index.js +4 -4
  496. package/dist/extensions/perplexity/index.js +1 -1
  497. package/dist/extensions/perplexity/test-api.js +1 -1
  498. package/dist/extensions/perplexity/web-search-provider.js +1 -1
  499. package/dist/extensions/phone-control/index.js +1 -1
  500. package/dist/extensions/runway/index.js +1 -1
  501. package/dist/extensions/runway/video-generation-provider.js +1 -1
  502. package/dist/extensions/signal/api.js +11 -11
  503. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  504. package/dist/extensions/signal/contract-api.js +2 -2
  505. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  506. package/dist/extensions/signal/runtime-api.js +14 -14
  507. package/dist/extensions/skill-workshop/api.js +1 -1
  508. package/dist/extensions/skill-workshop/index.js +2 -2
  509. package/dist/extensions/speech-core/runtime-api.js +2 -2
  510. package/dist/extensions/stepfun/index.js +1 -1
  511. package/dist/extensions/synology-chat/api.js +1 -1
  512. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  513. package/dist/extensions/talk-voice/index.js +2 -2
  514. package/dist/extensions/tavily/index.js +2 -2
  515. package/dist/extensions/tavily/web-search-provider.js +1 -1
  516. package/dist/extensions/thread-ownership/index.js +2 -2
  517. package/dist/extensions/tlon/api.js +2 -2
  518. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  519. package/dist/extensions/tlon/runtime-api.js +1 -1
  520. package/dist/extensions/tlon/setup-api.js +2 -2
  521. package/dist/extensions/tlon/test-api.js +1 -1
  522. package/dist/extensions/together/index.js +1 -1
  523. package/dist/extensions/together/video-generation-provider.js +1 -1
  524. package/dist/extensions/twitch/api.js +1 -1
  525. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  526. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  527. package/dist/extensions/venice/api.js +3 -3
  528. package/dist/extensions/venice/index.js +4 -4
  529. package/dist/extensions/venice/models.js +1 -1
  530. package/dist/extensions/venice/onboard.js +2 -2
  531. package/dist/extensions/venice/provider-catalog.js +1 -1
  532. package/dist/extensions/voice-call/index.js +3 -3
  533. package/dist/extensions/voice-call/runtime-entry.js +1 -1
  534. package/dist/extensions/voice-call/setup-api.js +2 -2
  535. package/dist/extensions/vydra/image-generation-provider.js +1 -1
  536. package/dist/extensions/vydra/index.js +3 -3
  537. package/dist/extensions/vydra/shared.js +1 -1
  538. package/dist/extensions/vydra/speech-provider.js +1 -1
  539. package/dist/extensions/vydra/video-generation-provider.js +1 -1
  540. package/dist/extensions/xai/api.js +6 -6
  541. package/dist/extensions/xai/code-execution.js +2 -2
  542. package/dist/extensions/xai/image-generation-provider.js +1 -1
  543. package/dist/extensions/xai/index.js +11 -11
  544. package/dist/extensions/xai/model-definitions.js +1 -1
  545. package/dist/extensions/xai/onboard.js +1 -1
  546. package/dist/extensions/xai/provider-catalog.js +1 -1
  547. package/dist/extensions/xai/provider-models.js +1 -1
  548. package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
  549. package/dist/extensions/xai/setup-api.js +1 -1
  550. package/dist/extensions/xai/speech-provider.js +1 -1
  551. package/dist/extensions/xai/stt.js +1 -1
  552. package/dist/extensions/xai/test-api.js +1 -1
  553. package/dist/extensions/xai/tts.js +2 -2
  554. package/dist/extensions/xai/video-generation-provider.js +1 -1
  555. package/dist/extensions/xai/web-search.js +1 -1
  556. package/dist/extensions/xai/x-search.js +3 -3
  557. package/dist/extensions/zai/api.js +1 -1
  558. package/dist/extensions/zai/index.js +2 -2
  559. package/dist/extensions/zai/onboard.js +1 -1
  560. package/dist/extensions/zalo/api.js +3 -3
  561. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  562. package/dist/extensions/zalo/runtime-api.js +2 -2
  563. package/dist/extensions/zalo/setup-api.js +2 -2
  564. package/dist/extensions/zalouser/api.js +4 -4
  565. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  566. package/dist/extensions/zalouser/runtime-api.js +9 -9
  567. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  568. package/dist/extensions/zalouser/test-api.js +4 -4
  569. package/dist/fallbacks-B-hX8uqx.js +2 -0
  570. package/dist/fallbacks-C5ybxGTK.js +31 -0
  571. package/dist/fallbacks-shared-CH3k_pWW.js +111 -0
  572. package/dist/format-DUJSy56G.js +176 -0
  573. package/dist/gateway-BIOe8buh.js +115 -0
  574. package/dist/gateway-cli-DwcS5o3b.js +1283 -0
  575. package/dist/gateway-rpc-DE9eTnTH.js +14 -0
  576. package/dist/gateway-rpc.runtime-BYzSLXq5.js +23 -0
  577. package/dist/gateway-rpc.runtime.js +1 -1
  578. package/dist/gateway-runtime-DNBHtXEc.js +15 -0
  579. package/dist/gateway-status-DQ3SCRP6.js +584 -0
  580. package/dist/genesis-tools-B4E1Wx5r.js +9166 -0
  581. package/dist/genesis-tools.runtime-CvLAzIWm.js +2 -0
  582. package/dist/genesis-tools.runtime.js +1 -1
  583. package/dist/get-reply-D9iaq0Co.js +3897 -0
  584. package/dist/get-reply-from-config.runtime-BFrLyjaS.js +2 -0
  585. package/dist/get-reply-from-config.runtime.js +1 -1
  586. package/dist/graph-users-K6q63hQH.js +1337 -0
  587. package/dist/guarded-json-api-BSwHtzk5.js +594 -0
  588. package/dist/health-BLmYYjhC.js +3 -0
  589. package/dist/health-jQBhWAEn.js +469 -0
  590. package/dist/health-route-ByzzS8xk.js +2 -0
  591. package/dist/health-route-CE-2wbny.js +41 -0
  592. package/dist/heartbeat-runner-D4-13meQ.js +5 -0
  593. package/dist/heartbeat-runner-DIprw7jS.js +1292 -0
  594. package/dist/heartbeat-runner.runtime-B_nY5Qgm.js +4 -0
  595. package/dist/heartbeat-runner.runtime.js +1 -1
  596. package/dist/helpers-DEG_RuMc.js +320 -0
  597. package/dist/hooks-cli-DQay0wq5.js +433 -0
  598. package/dist/http-endpoint-helpers-Cj3QINzs.js +41 -0
  599. package/dist/http-headers-CxAw5CS4.js +11 -0
  600. package/dist/http-utils-BdoY-Nqt.js +924 -0
  601. package/dist/identity-DImc-ABG.js +140 -0
  602. package/dist/image-fallbacks-BPxIecDg.js +31 -0
  603. package/dist/image-fallbacks-C9f2oqy9.js +2 -0
  604. package/dist/image-generation-provider-D1MVlkMK.js +529 -0
  605. package/dist/image-generation-provider-D1xp4B37.js +228 -0
  606. package/dist/image-generation-provider-D78SYbpg.js +274 -0
  607. package/dist/image-generation-provider-KrI_cq7u.js +95 -0
  608. package/dist/image-generation-provider-eiDfurMp.js +157 -0
  609. package/dist/image-generation-provider-iM6hlpJY.js +63 -0
  610. package/dist/inbound-reply-dispatch-Cj041nYj.js +73 -0
  611. package/dist/inbound.runtime-BFDKTetv.js +3 -0
  612. package/dist/inbound.runtime-C9MPsVfj.js +4 -0
  613. package/dist/inbound.runtime.js +1 -1
  614. package/dist/index.js +2 -2
  615. package/dist/infra-runtime-D9uudHda.js +39 -0
  616. package/dist/init-BIbgrtP4.js +59 -0
  617. package/dist/install-signal-cli-DX67z7U-.js +202 -0
  618. package/dist/jobs-DWEXUnGc.js +734 -0
  619. package/dist/kimi-web-search-provider-B199pS24.js +80 -0
  620. package/dist/kimi-web-search-provider.runtime-DHuvlTlx.js +261 -0
  621. package/dist/kimi-web-search-provider.runtime-DPkmvLDS.js +2 -0
  622. package/dist/kimi-web-search-provider.runtime.js +1 -1
  623. package/dist/library-B5XEbilF.js +45 -0
  624. package/dist/lifecycle-Cf5XvG8O.js +229 -0
  625. package/dist/lifecycle-CnQRwenx.js +571 -0
  626. package/dist/lifecycle.runtime-CMl4KKk8.js +2 -0
  627. package/dist/lifecycle.runtime.js +1 -1
  628. package/dist/list-AHy8re_f.js +1212 -0
  629. package/dist/list-BTKCVZuV.js +2 -0
  630. package/dist/list-DGTx2Wqw.js +131 -0
  631. package/dist/list-YvfcGz15.js +2 -0
  632. package/dist/list.probe-DG5_xRHp.js +419 -0
  633. package/dist/live-model-switch-CuTctEKz.js +336 -0
  634. package/dist/llm-slug-generator-BruS9kif.js +79 -0
  635. package/dist/llm-slug-generator.js +1 -1
  636. package/dist/load-config-CM6Gosov.js +35 -0
  637. package/dist/local-dispatch.runtime-ZYo4KwzE.js +8 -0
  638. package/dist/local-dispatch.runtime.js +1 -1
  639. package/dist/login-3MD7cKlo.js +108 -0
  640. package/dist/logs-cli-OVNQM7ua.js +265 -0
  641. package/dist/logs-cli.runtime-BxiLcJ_M.js +2 -0
  642. package/dist/logs-cli.runtime.js +1 -1
  643. package/dist/main-session-restart-recovery-DPOV5jrb.js +206 -0
  644. package/dist/managed-image-attachments-6nAXGlI1.js +635 -0
  645. package/dist/managed-image-attachments-DilVoOYk.js +2 -0
  646. package/dist/manager-BtvzSKtj.js +2057 -0
  647. package/dist/manager-DyNLzWfD.js +2 -0
  648. package/dist/manager-Q2pBimx1.js +3114 -0
  649. package/dist/markdown-to-line-BXIakLn2.js +790 -0
  650. package/dist/mcp/plugin-tools-serve.js +1 -1
  651. package/dist/mcp-cli-lQKoKrr8.js +725 -0
  652. package/dist/mcp-http-Bkk3yw83.js +529 -0
  653. package/dist/media-contract-Bc8hq_Hg.js +49 -0
  654. package/dist/media-contract-api-U4NbSFNP.js +2 -0
  655. package/dist/media-runtime-BNkgBOI3.js +329 -0
  656. package/dist/memory-DwnILZlh.js +342 -0
  657. package/dist/memory-core-host-runtime-cli-C8dM34aV.js +9 -0
  658. package/dist/memory-embedding-adapter-B2PHR9-b.js +123 -0
  659. package/dist/message-action-runner-BKUGlEq0.js +2 -0
  660. package/dist/message-action-runner-CXfdJWof.js +1407 -0
  661. package/dist/message-actions-BPS9joyx.js +143 -0
  662. package/dist/message-channel-DGBKBihv.js +56 -0
  663. package/dist/message-gek1bdc3.js +232 -0
  664. package/dist/message-secret-scope-BmZJslJs.js +103 -0
  665. package/dist/message.gateway.runtime-B35cFF_N.js +2 -0
  666. package/dist/message.gateway.runtime.js +1 -1
  667. package/dist/method-scopes-BJj0ofY0.js +233 -0
  668. package/dist/minimax-web-search-provider-C79WAduN.js +53 -0
  669. package/dist/minimax-web-search-provider.runtime-D94jFB6v.js +2 -0
  670. package/dist/minimax-web-search-provider.runtime-ttvn1re5.js +140 -0
  671. package/dist/minimax-web-search-provider.runtime.js +1 -1
  672. package/dist/mock-C9dpEyJ8.js +136 -0
  673. package/dist/model-definitions-taVnM0qU.js +260 -0
  674. package/dist/model-overrides-Hnlrxnm3.js +104 -0
  675. package/dist/model-selection-C0kCM--d.js +213 -0
  676. package/dist/models-C6lJZiG_.js +569 -0
  677. package/dist/models-CQmyBH-d.js +760 -0
  678. package/dist/models-CzCQpmVW.js +157 -0
  679. package/dist/models-DJQoC4Xz.js +47 -0
  680. package/dist/models-auth-status-CUuto1-z.js +217 -0
  681. package/dist/models-cli-DFYsfHFi.js +271 -0
  682. package/dist/models-http-KluTqvju.js +92 -0
  683. package/dist/models.fetch-CUcQFhk9.js +518 -0
  684. package/dist/monitor-Amuhcll1.js +1237 -0
  685. package/dist/monitor-BHYjSOgh.js +671 -0
  686. package/dist/monitor-BNMwiGBd.js +1459 -0
  687. package/dist/monitor-C8QQd5Eg.js +295 -0
  688. package/dist/monitor-DHQTgUJC.js +1661 -0
  689. package/dist/monitor-DrTPiOoO.js +2 -0
  690. package/dist/monitor-Dupjc8yV.js +788 -0
  691. package/dist/monitor-auth-BGCRXS08.js +207 -0
  692. package/dist/monitor-processing-dLJEKLkr.js +1974 -0
  693. package/dist/monitor.runtime-CFCau0j2.js +2 -0
  694. package/dist/monitor.runtime.js +1 -1
  695. package/dist/monitor.webhook-rWET0HrG.js +180 -0
  696. package/dist/msteams-96MqCc3R.js +35 -0
  697. package/dist/music-generation-provider-Bilj-8Yj.js +63 -0
  698. package/dist/music-generation-provider-CHWj4bCX.js +170 -0
  699. package/dist/native-hook-relay-BFWKVZgm.js +519 -0
  700. package/dist/native-web-search-BVgO5cS-.js +64 -0
  701. package/dist/nextcloud-talk-D-FHP_4q.js +17 -0
  702. package/dist/node-cli-COaDl9Gb.js +2276 -0
  703. package/dist/nodes-cli-CdiC2uij.js +1046 -0
  704. package/dist/nodes-utils-Bz4wEuS8.js +84 -0
  705. package/dist/nodes.helpers-B4Yy3f8X.js +34 -0
  706. package/dist/notify-DnBLOswJ.js +315 -0
  707. package/dist/onboard-3Bl_PtFG.js +25 -0
  708. package/dist/onboard-CKxpPa1J.js +25 -0
  709. package/dist/onboard-CnHnAYQA.js +2 -0
  710. package/dist/onboard-DgcU4LaA.js +58 -0
  711. package/dist/onboard-Dgq86QR9.js +29 -0
  712. package/dist/onboard-NAMvzIMs2.js +49 -0
  713. package/dist/onboard-a4m7JstV.js +316 -0
  714. package/dist/onboard-fjFU-IEN.js +70 -0
  715. package/dist/onboard-helpers-CFVEw4kg.js +204 -0
  716. package/dist/onboard-helpers-R0vTUoOE.js +6 -0
  717. package/dist/onboard-interactive-D4Hr2vB6.js +24 -0
  718. package/dist/onboard-non-interactive-DjfjLqF7.js +635 -0
  719. package/dist/onboard-ppjrxdQn.js +25 -0
  720. package/dist/onboard-remote-0UXttO3s.js +2 -0
  721. package/dist/onboard-remote-BmUiJKba.js +193 -0
  722. package/dist/onboard-skills-855xT260.js +2 -0
  723. package/dist/onboard-skills-CF2ndciI.js +134 -0
  724. package/dist/openai-codex-auth-identity-Dxbuu2cd.js +45 -0
  725. package/dist/openai-codex-device-code-CEOVyUYq.js +164 -0
  726. package/dist/openai-codex-provider-B0mTbWAC.js +472 -0
  727. package/dist/openai-codex-shared-DO75K1fy.js +6 -0
  728. package/dist/openai-http-BU5AQc8x.js +500 -0
  729. package/dist/openai-provider-DUFOP6VM.js +313 -0
  730. package/dist/openresponses-http-D1GGTOop.js +1128 -0
  731. package/dist/operator-approvals-client-gp0A73Qi.js +68 -0
  732. package/dist/outbound-media-CYrmm6RY.js +57 -0
  733. package/dist/outbound-runtime-DM3TzNhA.js +5 -0
  734. package/dist/outbound.runtime-DHLRWzbo.js +2 -0
  735. package/dist/outbound.runtime.js +1 -1
  736. package/dist/pair-command-approve-LJICPdqB.js +44 -0
  737. package/dist/perplexity-web-search-provider-ONjsnI0T.js +92 -0
  738. package/dist/perplexity-web-search-provider.runtime-C9SpRyYz.js +324 -0
  739. package/dist/perplexity-web-search-provider.runtime-pVuMPAol.js +2 -0
  740. package/dist/perplexity-web-search-provider.runtime.js +1 -1
  741. package/dist/persistent-bindings.lifecycle-CEOa_phk.js +85 -0
  742. package/dist/persistent-bindings.lifecycle-DACYiSaR.js +2 -0
  743. package/dist/pi-embedded-BlOiwW3D.js +4 -0
  744. package/dist/pi-embedded-mC-TYW4O.js +2905 -0
  745. package/dist/pi-embedded-subscribe.handlers.compaction.runtime-CzPjo_JC.js +23 -0
  746. package/dist/pi-embedded-subscribe.handlers.compaction.runtime.js +1 -1
  747. package/dist/pi-embedded.runtime-DjmvqZCN.js +4 -0
  748. package/dist/pi-embedded.runtime.js +1 -1
  749. package/dist/pi-tool-definition-adapter-CwT_smG_.js +229 -0
  750. package/dist/pi-tools-10IsGyci.js +1057 -0
  751. package/dist/pi-tools.before-tool-call-CX2Ew8CP.js +433 -0
  752. package/dist/pi-tools.before-tool-call-V6qF1pL1.js +2 -0
  753. package/dist/plivo-CAlO-SXr.js +394 -0
  754. package/dist/plugin-DUiUdK8L.js +12195 -0
  755. package/dist/plugin-enabled-Md173mY1.js +140 -0
  756. package/dist/plugin-registration-BUZ1GI8e.js +23 -0
  757. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  758. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  759. package/dist/plugin-sdk/acp-runtime.js +3 -3
  760. package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
  761. package/dist/plugin-sdk/agent-harness.js +7 -7
  762. package/dist/plugin-sdk/agent-runtime.js +2 -2
  763. package/dist/plugin-sdk/approval-client-runtime.js +2 -2
  764. package/dist/plugin-sdk/approval-delivery-runtime.js +1 -1
  765. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  766. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  767. package/dist/plugin-sdk/approval-native-runtime.js +2 -2
  768. package/dist/plugin-sdk/approval-reply-runtime.js +2 -2
  769. package/dist/plugin-sdk/approval-runtime.js +7 -7
  770. package/dist/plugin-sdk/bluebubbles.js +2 -2
  771. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  772. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  773. package/dist/plugin-sdk/browser-support.js +7 -7
  774. package/dist/plugin-sdk/channel-core.js +2 -2
  775. package/dist/plugin-sdk/channel-inbound.js +3 -3
  776. package/dist/plugin-sdk/command-auth-native.js +1 -1
  777. package/dist/plugin-sdk/command-auth.js +4 -4
  778. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  779. package/dist/plugin-sdk/compat.js +2 -2
  780. package/dist/plugin-sdk/config-runtime.js +5 -5
  781. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  782. package/dist/plugin-sdk/conversation-runtime.js +4 -4
  783. package/dist/plugin-sdk/core.js +2 -2
  784. package/dist/plugin-sdk/direct-dm.js +1 -1
  785. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  786. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  787. package/dist/plugin-sdk/index.js +1 -1
  788. package/dist/plugin-sdk/infra-runtime.js +4 -4
  789. package/dist/plugin-sdk/irc.js +2 -2
  790. package/dist/plugin-sdk/markdown-table-runtime.js +1 -1
  791. package/dist/plugin-sdk/matrix.js +1 -1
  792. package/dist/plugin-sdk/mattermost.js +3 -3
  793. package/dist/plugin-sdk/media-runtime.js +1 -1
  794. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  795. package/dist/plugin-sdk/memory-core.js +2 -2
  796. package/dist/plugin-sdk/models-provider-runtime.js +1 -1
  797. package/dist/plugin-sdk/msteams.js +3 -3
  798. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  799. package/dist/plugin-sdk/nostr.js +1 -1
  800. package/dist/plugin-sdk/outbound-runtime.js +2 -2
  801. package/dist/plugin-sdk/reply-chunking.js +2 -2
  802. package/dist/plugin-sdk/reply-dispatch-runtime.js +2 -2
  803. package/dist/plugin-sdk/reply-runtime.js +5 -5
  804. package/dist/plugin-sdk/routing.js +2 -2
  805. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  806. package/dist/plugin-sdk/runtime.js +2 -2
  807. package/dist/plugin-sdk/sandbox.js +1 -1
  808. package/dist/plugin-sdk/session-store-runtime.js +1 -1
  809. package/dist/plugin-sdk/session-visibility.js +1 -1
  810. package/dist/plugin-sdk/skill-commands-runtime.js +1 -1
  811. package/dist/plugin-sdk/src/gateway/protocol/client-info.d.ts +8 -0
  812. package/dist/plugin-sdk/src/gateway/protocol/schema/logs-chat.d.ts +2 -0
  813. package/dist/plugin-sdk/src/gateway/protocol/schema/protocol-schemas.d.ts +2 -0
  814. package/dist/plugin-sdk/src/gateway/server-broadcast-types.d.ts +11 -0
  815. package/dist/plugin-sdk/testing.js +4 -4
  816. package/dist/plugin-sdk/text-runtime.js +2 -2
  817. package/dist/plugin-sdk/tlon.js +1 -1
  818. package/dist/plugin-sdk/zalo.js +1 -1
  819. package/dist/plugin-sdk/zalouser.js +1 -1
  820. package/dist/plugin-service-ClKtlbqz.js +2893 -0
  821. package/dist/plugins/runtime/index.js +1 -1
  822. package/dist/policy-BxXVdy5R.js +328 -0
  823. package/dist/postinstall-inventory.json +732 -732
  824. package/dist/prepare.runtime-CgeJiFh8.js +815 -0
  825. package/dist/prepare.runtime.js +1 -1
  826. package/dist/probe--ur8kCb3.js +241 -0
  827. package/dist/probe-Afcq8e2r.js +2 -0
  828. package/dist/probe-Bh8UIug9.js +32 -0
  829. package/dist/probe-CY6MUE10.js +1443 -0
  830. package/dist/probe-Cfbju7hl.js +243 -0
  831. package/dist/probe-DHojHKeB.js +2 -0
  832. package/dist/probe-DZZtfovp.js +2205 -0
  833. package/dist/probe-KiWC2F6a.js +45 -0
  834. package/dist/probe-QqjmFXeC.js +74 -0
  835. package/dist/probe.runtime-BYxgJ6xl.js +2 -0
  836. package/dist/probe.runtime.js +1 -1
  837. package/dist/program-BjA_aj2i.js +111 -0
  838. package/dist/prompt-select-styled-D_Li5ANb.js +20 -0
  839. package/dist/protocol-D2Tvt0kQ.js +2479 -0
  840. package/dist/provider-MaVAUyxk.js +70 -0
  841. package/dist/provider-catalog-BATfNRJI.js +11 -0
  842. package/dist/provider-catalog-BqmZljQJ.js +11 -0
  843. package/dist/provider-catalog-DIiNG8du.js +12 -0
  844. package/dist/provider-catalog-aWreWBr_.js +24 -0
  845. package/dist/provider-catalog-k2xN6Dmi.js +26 -0
  846. package/dist/provider-compat-DEtCjlVO.js +37 -0
  847. package/dist/provider-dispatcher-BOzs2ZGG.js +2 -0
  848. package/dist/provider-dispatcher-CLzXvOtY.js +22 -0
  849. package/dist/provider-models-Dr7Yl3OU.js +119 -0
  850. package/dist/provider-models-LgIFG7w_.js +35 -0
  851. package/dist/provider-registration-Ce1hYnYT.js +218 -0
  852. package/dist/pw-ai-qc3NEEdy.js +2511 -0
  853. package/dist/pw-role-snapshot-BDIJ0VPo.js +380 -0
  854. package/dist/qmd-manager-B2ly9K3H.js +1921 -0
  855. package/dist/qr-cli-D2qc34ak.js +349 -0
  856. package/dist/qr-cli-r8cz7XBw.js +2 -0
  857. package/dist/qr-image-DNn2cBT5.js +2 -0
  858. package/dist/queue-BbE1ctBI.js +409 -0
  859. package/dist/reaction-runtime-api-DNwfR7k6.js +116 -0
  860. package/dist/reactions-B8Os6MyX.js +998 -0
  861. package/dist/read-capability-BcetMuEi.js +412 -0
  862. package/dist/realtime-provider-shared-RvhVjejL.js +37 -0
  863. package/dist/realtime-transcription-provider-BbBn8N0w.js +184 -0
  864. package/dist/realtime-transcription-provider-C08pMeeY.js +183 -0
  865. package/dist/realtime-transcription-provider-CB0qNn9C.js +184 -0
  866. package/dist/realtime-transcription-provider-DYOqgmgZ.js +120 -0
  867. package/dist/realtime-transcription-provider-ySxyV6W0.js +172 -0
  868. package/dist/realtime-voice-provider-ByH_v5-M.js +489 -0
  869. package/dist/record-shared-DVnkFx9W.js +10 -0
  870. package/dist/register-service-commands-BXfMmQsa.js +71 -0
  871. package/dist/register.agent-CUXMbAb4.js +248 -0
  872. package/dist/register.configure-B29Tv6Ec.js +15 -0
  873. package/dist/register.maintenance-ePgwbzKN.js +363 -0
  874. package/dist/register.message-BmgFYhw_.js +329 -0
  875. package/dist/register.onboard-BL8ZSfVl.js +88 -0
  876. package/dist/register.runtime-Z_9jSH_w.js +81 -0
  877. package/dist/register.runtime.js +1 -1
  878. package/dist/register.setup-BAQ-rre0.js +150 -0
  879. package/dist/register.status-health-sessions-D5CTwglK.js +1215 -0
  880. package/dist/register.subclis-BAzWCN2M.js +3 -0
  881. package/dist/register.subclis-CMhZ_wr2.js +29 -0
  882. package/dist/register.subclis-core-D_uA6Vtg.js +249 -0
  883. package/dist/replay-policy-Be3VAzMj.js +8 -0
  884. package/dist/reply-chunking-DsNT8-zW.js +3 -0
  885. package/dist/reply-dispatch-runtime-C8Tjbie9.js +13 -0
  886. package/dist/reply-media-paths.runtime-Sf21IJNk.js +146 -0
  887. package/dist/reply-media-paths.runtime-oSGMjdni.js +2 -0
  888. package/dist/reply-media-paths.runtime.js +1 -1
  889. package/dist/reply-payload-transform-DxOTphts.js +720 -0
  890. package/dist/reply-runtime-9GCZm66h.js +11 -0
  891. package/dist/reply.runtime-Ck_EqPGO.js +2 -0
  892. package/dist/reply.runtime.js +1 -1
  893. package/dist/reset-BMP05zhP.js +84 -0
  894. package/dist/reset-authorization-AdwO29Il.js +34 -0
  895. package/dist/response-generator-BKL4tpDF.js +175 -0
  896. package/dist/restart-health-C8OVhvQ6.js +2 -0
  897. package/dist/restart-health-DdG71XEk.js +202 -0
  898. package/dist/root-help-_8BuPuC8.js +44 -0
  899. package/dist/route-reply-C4YpHgPi.js +162 -0
  900. package/dist/route-reply.runtime-hioDUgsc.js +2 -0
  901. package/dist/route-reply.runtime.js +1 -1
  902. package/dist/routes-BbR9Kf9O.js +3341 -0
  903. package/dist/routes-DSDrrbg7.js +2 -0
  904. package/dist/routing-CMekdi78.js +5 -0
  905. package/dist/rpc-B32bpIT7.js +61 -0
  906. package/dist/rpc-context-88y3DNdl.js +17 -0
  907. package/dist/rpc.runtime-BWtvlfeD.js +21 -0
  908. package/dist/rpc.runtime.js +1 -1
  909. package/dist/run-auth-profile.runtime-x8Hbrp4n.js +2 -0
  910. package/dist/run-auth-profile.runtime.js +1 -1
  911. package/dist/run-delivery.runtime-BEhoJYec.js +530 -0
  912. package/dist/run-delivery.runtime.js +1 -1
  913. package/dist/run-embedded.runtime-DtE5YonB.js +4 -0
  914. package/dist/run-embedded.runtime.js +1 -1
  915. package/dist/run-execution-cli.runtime-B7TsaFkb.js +4 -0
  916. package/dist/run-execution-cli.runtime.js +1 -1
  917. package/dist/run-executor.runtime-C6GU_OdI.js +277 -0
  918. package/dist/run-executor.runtime.js +1 -1
  919. package/dist/run-main-DlCyw-yJ.js +567 -0
  920. package/dist/run-subagent-registry.runtime-N6lG2N8U.js +2 -0
  921. package/dist/run-subagent-registry.runtime.js +1 -1
  922. package/dist/run-wait-CT1ADSXM.js +135 -0
  923. package/dist/runtime-BMgYgoRw.js +973 -0
  924. package/dist/runtime-BZIHCyP6.js +9 -0
  925. package/dist/runtime-BfclzCOK.js +72 -0
  926. package/dist/runtime-C5HCPXpN.js +107 -0
  927. package/dist/runtime-api-BwnU0Us4.js +14 -0
  928. package/dist/runtime-api-CTCWdq7l.js +4 -0
  929. package/dist/runtime-api-DEKfCisk.js +9 -0
  930. package/dist/runtime-api-DuV0VsXW.js +9 -0
  931. package/dist/runtime-embedded-pi.runtime-BYOaO_Od.js +2 -0
  932. package/dist/runtime-embedded-pi.runtime.js +1 -1
  933. package/dist/runtime-entry-BIQCiau_.js +2769 -0
  934. package/dist/runtime-internal-CatNPRWm.js +2 -0
  935. package/dist/runtime-options-VPF2fIbl.js +275 -0
  936. package/dist/runtime-provider-CKxDlld3.js +21 -0
  937. package/dist/runtime-schema-C5kNPI-T.js +28588 -0
  938. package/dist/sandbox-24Qv41cI.js +3 -0
  939. package/dist/sandbox-Dl4VHMsp.js +1156 -0
  940. package/dist/sandbox-cli-DKdlzfGK.js +450 -0
  941. package/dist/scan-CsLHQzrX.js +2 -0
  942. package/dist/scan-Db3o5_vf.js +523 -0
  943. package/dist/secrets-cli-DRs2TyS0.js +2101 -0
  944. package/dist/security-cli-Ddj_11Zr.js +486 -0
  945. package/dist/selection-BTcDg98i.js +2 -0
  946. package/dist/selection-CDq8O7Fx.js +7764 -0
  947. package/dist/send-C3Q0rOZU.js +102 -0
  948. package/dist/send-CMRoV9D3.js +534 -0
  949. package/dist/send-DLyeTfOT.js +156 -0
  950. package/dist/send.runtime-11PTjSXY.js +2 -0
  951. package/dist/send.runtime.js +1 -1
  952. package/dist/server-DpmjtgBd.js +77 -0
  953. package/dist/server-context-BuRVihwJ.js +2 -0
  954. package/dist/server-context-Dxt5bPO1.js +847 -0
  955. package/dist/server-iR310jYD.js +13 -0
  956. package/dist/server-middleware-XZQHvHoT.js +120 -0
  957. package/dist/server-node-events-EECL-zPp.js +481 -0
  958. package/dist/server-plugin-bootstrap-BeyQQP6e.js +13176 -0
  959. package/dist/server-plugin-bootstrap-Du2JCynD.js +2 -0
  960. package/dist/server-restart-sentinel-D16NkJS9.js +697 -0
  961. package/dist/server.impl-jeGX0yfZ.js +12894 -0
  962. package/dist/session-DQJLw1_T.js +48 -0
  963. package/dist/session-envelope-BzLkljLE.js +18 -0
  964. package/dist/session-key-B9ng1tKQ.js +65 -0
  965. package/dist/session-kill-http-CrVogPTY.js +110 -0
  966. package/dist/session-meta-Cf_igX65.js +109 -0
  967. package/dist/session-override-tYPL0kPi.js +106 -0
  968. package/dist/session-reset-model.runtime-Bksk4sN9.js +133 -0
  969. package/dist/session-reset-model.runtime.js +1 -1
  970. package/dist/session-reset-service-Coa2y7Dc.js +497 -0
  971. package/dist/session-route-C__jEVZM.js +93 -0
  972. package/dist/session-status.runtime-DGvtIYsy.js +2 -0
  973. package/dist/session-status.runtime.js +1 -1
  974. package/dist/session-store-C7BvEOyw.js +126 -0
  975. package/dist/session-store.runtime-CTnaK0eA.js +2 -0
  976. package/dist/session-store.runtime.js +1 -1
  977. package/dist/session-subagent-reactivation.runtime-CpvLz2Zl.js +2 -0
  978. package/dist/session-subagent-reactivation.runtime.js +1 -1
  979. package/dist/session-tab-registry-9PAkEJgt.js +581 -0
  980. package/dist/session-updates-DFsCLKMJ.js +236 -0
  981. package/dist/session-updates.runtime-GJ8kEPly.js +2 -0
  982. package/dist/session-updates.runtime.js +1 -1
  983. package/dist/session-utils-B1COXii1.js +1009 -0
  984. package/dist/session-visibility-D3BOamfE.js +147 -0
  985. package/dist/sessions-BNIruiEi.js +48 -0
  986. package/dist/sessions-B_sLzSKh.js +281 -0
  987. package/dist/sessions-ChHWG6bX.js +16 -0
  988. package/dist/sessions-helpers-BhxVyCeC.js +305 -0
  989. package/dist/sessions-history-http-Cat6NIOM.js +383 -0
  990. package/dist/sessions-patch-C2VfpT6N.js +309 -0
  991. package/dist/sessions-resolve-CU-TrVC5.js +174 -0
  992. package/dist/sessions-u8wkO5OX.js +2 -0
  993. package/dist/sessions.runtime-B6j-Iope.js +2 -0
  994. package/dist/sessions.runtime.js +1 -1
  995. package/dist/setup-BUlom6Vi.js +421 -0
  996. package/dist/setup-CcVU94hA.js +636 -0
  997. package/dist/setup-api-B7VRJ8uG.js +29 -0
  998. package/dist/setup-core-BSgdsKqw.js +393 -0
  999. package/dist/setup-core-BlfMhY40.js +184 -0
  1000. package/dist/setup-core-ClqXCwnQ.js +176 -0
  1001. package/dist/setup-core-DnkRgrw-.js +171 -0
  1002. package/dist/setup-surface-5pyyPLuU.js +351 -0
  1003. package/dist/setup-surface-6kf03Wwh.js +72 -0
  1004. package/dist/setup-surface-C-CfXHbT.js +286 -0
  1005. package/dist/setup-surface-C2ZP0qfU.js +3 -0
  1006. package/dist/setup-surface-DKyYG10Q2.js +403 -0
  1007. package/dist/setup-surface-DbpW4B-_.js +219 -0
  1008. package/dist/setup.finalize-skT8Gm-r.js +547 -0
  1009. package/dist/setup.gateway-config-CeiELioQ.js +250 -0
  1010. package/dist/shared--LL8Q1-r.js +60 -0
  1011. package/dist/shared-B48XWnaj.js +121 -0
  1012. package/dist/shared-CTrgq8xV.js +217 -0
  1013. package/dist/shared-D7wq6pQ0.js +186 -0
  1014. package/dist/shared-DSeBkiR2.js +198 -0
  1015. package/dist/shared-DWDavHPp.js +76 -0
  1016. package/dist/shared-runtime-D-p9L46W.js +7 -0
  1017. package/dist/short-term-promotion-CkPsM3JU.js +1543 -0
  1018. package/dist/skill-commands-GmJ-uKh9.js +83 -0
  1019. package/dist/skill-commands.runtime-B2kGq_R_.js +2 -0
  1020. package/dist/skill-commands.runtime.js +1 -1
  1021. package/dist/skills-snapshot.runtime-niF0JCHr.js +7 -0
  1022. package/dist/skills-snapshot.runtime.js +1 -1
  1023. package/dist/slash-state-D0qRQzb9.js +1911 -0
  1024. package/dist/speech-provider-CZ0DIWHC.js +209 -0
  1025. package/dist/speech-provider-D01WzRM7.js +216 -0
  1026. package/dist/speech-provider-D4dWoX5q.js +395 -0
  1027. package/dist/speech-provider-DQjPn8BG.js +170 -0
  1028. package/dist/speech-provider-DTfG7isC.js +184 -0
  1029. package/dist/speech-provider-DVMPFaU6.js +103 -0
  1030. package/dist/speech-provider-Jnc9vcw3.js +209 -0
  1031. package/dist/src-DLW1D_bM.js +3974 -0
  1032. package/dist/stage-sandbox-media.runtime-DeLGFWqT.js +232 -0
  1033. package/dist/stage-sandbox-media.runtime.js +1 -1
  1034. package/dist/startup-context-DKWBYxjm.js +312 -0
  1035. package/dist/state-migrations-DdRavjjK.js +820 -0
  1036. package/dist/status-BGTYuDnT.js +397 -0
  1037. package/dist/status-BYp9Gu83.js +209 -0
  1038. package/dist/status-BqydDBcZ.js +3 -0
  1039. package/dist/status-Bx1yRRTV.js +190 -0
  1040. package/dist/status-C6gdYeLs.js +2 -0
  1041. package/dist/status-Cl8Otyr4.js +62 -0
  1042. package/dist/status-DWucT0mf.js +2 -0
  1043. package/dist/status-all-TjyzzieW.js +498 -0
  1044. package/dist/status-json-C6WIXSpl.js +14 -0
  1045. package/dist/status-json-command-CgXgvQow.js +84 -0
  1046. package/dist/status-message-D6O4-pti.js +466 -0
  1047. package/dist/status-message.runtime-CNShQeZy.js +6 -0
  1048. package/dist/status-message.runtime.js +1 -1
  1049. package/dist/status-queue.runtime-K8_F9zMn.js +2 -0
  1050. package/dist/status-queue.runtime.js +1 -1
  1051. package/dist/status-runtime-shared-Be7bmVcF.js +257 -0
  1052. package/dist/status-subagents.runtime-BRV0GKxR.js +18 -0
  1053. package/dist/status-subagents.runtime.js +1 -1
  1054. package/dist/status-text-BIGdXi_0.js +237 -0
  1055. package/dist/status.gateway-connection.runtime-C1Eg5lPs.js +2 -0
  1056. package/dist/status.gateway-connection.runtime.js +1 -1
  1057. package/dist/status.gather-C91OSvDe.js +292 -0
  1058. package/dist/status.gather-DOJX68XV.js +2 -0
  1059. package/dist/status.runtime-BM4ZMHfF.js +2 -0
  1060. package/dist/status.runtime-JhkaEpRc.js +2 -0
  1061. package/dist/status.runtime.js +1 -1
  1062. package/dist/status.scan-36oLz1Hh.js +65 -0
  1063. package/dist/status.scan-overview-CsDwq0xR.js +379 -0
  1064. package/dist/status.scan.fast-json-CS8ga0yM.js +132 -0
  1065. package/dist/status.scan.fast-json-DYvUCNqQ.js +2 -0
  1066. package/dist/status.summary-1hoR3rVk.js +214 -0
  1067. package/dist/status.summary-Bl1Fw7SD.js +2 -0
  1068. package/dist/store-3hbb4lSJ.js +4 -0
  1069. package/dist/store-CEFH-fGo.js +910 -0
  1070. package/dist/store.runtime-ugP7_1Zf.js +2 -0
  1071. package/dist/store.runtime.js +1 -1
  1072. package/dist/stream-CukCyjCc.js +664 -0
  1073. package/dist/stream-Dj22sbqm.js +134 -0
  1074. package/dist/stt-CRYwE4f3.js +66 -0
  1075. package/dist/subagent-announce-Dnuw09in.js +351 -0
  1076. package/dist/subagent-announce-delivery-cCFWE0et.js +726 -0
  1077. package/dist/subagent-announce-output-BtmzvU1a.js +364 -0
  1078. package/dist/subagent-capabilities-Btyd8tu0.js +251 -0
  1079. package/dist/subagent-control-Dlc3kJMb.js +506 -0
  1080. package/dist/subagent-control.runtime-g5fkwkOu.js +3 -0
  1081. package/dist/subagent-control.runtime.js +1 -1
  1082. package/dist/subagent-followup.runtime-CtU5LNEN.js +68 -0
  1083. package/dist/subagent-followup.runtime.js +1 -1
  1084. package/dist/subagent-orphan-recovery-kbEEIccA.js +305 -0
  1085. package/dist/subagent-registry-B5bQOpDI.js +3 -0
  1086. package/dist/subagent-registry-CBu4eX0s.js +1753 -0
  1087. package/dist/subagent-registry.runtime.js +1 -1
  1088. package/dist/subagent-spawn-DhjzC5gY.js +1005 -0
  1089. package/dist/system-cli-A9ux7HV2.js +59 -0
  1090. package/dist/system-prompt-DJq4MtoS.js +640 -0
  1091. package/dist/tables-BStv8EET.js +829 -0
  1092. package/dist/target-id-RoVbMf8U.js +107 -0
  1093. package/dist/targets-RMCdeJGZ.js +207 -0
  1094. package/dist/targets-cmfGv2Db.js +67 -0
  1095. package/dist/targets.runtime-DurrSDqM.js +2 -0
  1096. package/dist/targets.runtime.js +1 -1
  1097. package/dist/task-executor-CtdGnYvb.js +360 -0
  1098. package/dist/task-owner-access-C_gF3pGm.js +74 -0
  1099. package/dist/task-registry-CFNty_H1.js +2366 -0
  1100. package/dist/task-registry-delivery-runtime-C1c7pN3i.js +2 -0
  1101. package/dist/task-registry-delivery-runtime-F6HIzLFD.js +3 -0
  1102. package/dist/task-registry.maintenance-BSO3Pttk.js +2 -0
  1103. package/dist/task-registry.maintenance-Bzw1Ot4Y.js +416 -0
  1104. package/dist/tavily-client-DmRSbaLh.js +2 -0
  1105. package/dist/tavily-client-DyAtAOpD.js +193 -0
  1106. package/dist/tavily-search-provider-Bbgsl7mb.js +62 -0
  1107. package/dist/telegram/audit.js +2 -2
  1108. package/dist/telegram/token.js +2 -2
  1109. package/dist/telnyx-nMo1MXA1.js +260 -0
  1110. package/dist/testing-DLeFUMTf.js +575 -0
  1111. package/dist/text-report-Dr4OMS_k.js +587 -0
  1112. package/dist/text-runtime-Dd2bva2m.js +290 -0
  1113. package/dist/tool-config-shared-DlMaBB10.js +19 -0
  1114. package/dist/tool-policy-pipeline-0FWDoYYr.js +109 -0
  1115. package/dist/tool-resolution-DQTRVob0.js +90 -0
  1116. package/dist/tools-effective-inventory-GNGRMlm8.js +152 -0
  1117. package/dist/tools-invoke-http-IeTKKDtc.js +206 -0
  1118. package/dist/tools.runtime-DNLELnRr.js +4 -0
  1119. package/dist/tools.runtime.js +1 -1
  1120. package/dist/transcript-DWg4ZUcm.js +312 -0
  1121. package/dist/transcript-resolve.runtime-xACsMpzb.js +2 -0
  1122. package/dist/transcript-resolve.runtime.js +1 -1
  1123. package/dist/transcript.runtime-BEXMCmRi.js +2 -0
  1124. package/dist/transcript.runtime.js +1 -1
  1125. package/dist/transport-policy-BzTvyOmg.js +75 -0
  1126. package/dist/trash-EJIRdEEW.js +24 -0
  1127. package/dist/tts-AMFKvIil.js +64 -0
  1128. package/dist/tts-D7c_mBQr.js +183 -0
  1129. package/dist/tui-cli-CeXEjZVR.js +4595 -0
  1130. package/dist/twilio-Bq0EHjSs.js +609 -0
  1131. package/dist/typing-policy-D-cwir-6.js +12 -0
  1132. package/dist/update-cli-6cN0AU-H.js +1759 -0
  1133. package/dist/upgrade-E9pk_ETn.js +1226 -0
  1134. package/dist/video-generation-provider-B2ydEHoH.js +271 -0
  1135. package/dist/video-generation-provider-BIhzvg3t.js +78 -0
  1136. package/dist/video-generation-provider-BiGET6PL.js +187 -0
  1137. package/dist/video-generation-provider-BvIYYRHt.js +254 -0
  1138. package/dist/video-generation-provider-CDMIArvG.js +118 -0
  1139. package/dist/video-generation-provider-CZc8AIXp.js +221 -0
  1140. package/dist/video-generation-provider-DKQZcort.js +281 -0
  1141. package/dist/video-generation-provider-DdGhJ9-8.js +287 -0
  1142. package/dist/video-generation-provider-XpVuorb7.js +264 -0
  1143. package/dist/video-generation-task-status-D44fagYk.js +163 -0
  1144. package/dist/voice-mapping-Ltp5aeXQ.js +41 -0
  1145. package/dist/wait-for-idle-before-flush-B5QDOp0b.js +5986 -0
  1146. package/dist/web-search-gDoNQc1M.js +61 -0
  1147. package/dist/web-search-provider-DI1P7u12.js +163 -0
  1148. package/dist/web-search-provider.runtime-BLHcU_Q5.js +2 -0
  1149. package/dist/web-search-provider.runtime-CExn2tm8.js +185 -0
  1150. package/dist/web-search-provider.runtime.js +1 -1
  1151. package/dist/webhook-shared-1XHBMLp6.js +12 -0
  1152. package/dist/wizard-models-CLDwUX2-.js +334 -0
  1153. package/dist/workflow-runtime-BrBSvDJz.js +485 -0
  1154. package/dist/workspace-run-CQ9bvprq.js +70 -0
  1155. package/dist/x-search-config-COc9ynlq.js +36 -0
  1156. package/dist/x-search-shared-D-WVgH0q.js +75 -0
  1157. package/dist/zalo-js-kA38HR6N.js +1157 -0
  1158. package/package.json +1 -1
  1159. package/dist/abort-D7Eb5Pfs.js +0 -201
  1160. package/dist/abort-cutoff.runtime-W1jPHD1l.js +0 -20
  1161. package/dist/abort.runtime-Uk-fNOr0.js +0 -2
  1162. package/dist/accounts-B0U5s6Hn.js +0 -2
  1163. package/dist/accounts-BuQEZI1m.js +0 -365
  1164. package/dist/accounts-BxrhItqg.js +0 -107
  1165. package/dist/accounts-CJuvMKsE.js +0 -66
  1166. package/dist/accounts-DAo-x54e.js +0 -104
  1167. package/dist/accounts-DoMkWpQd.js +0 -43
  1168. package/dist/accounts.runtime-B4AMDwXM.js +0 -2
  1169. package/dist/acp-cli-Dj3nYrtM.js +0 -2193
  1170. package/dist/acp-spawn-DVm7VQrm.js +0 -1093
  1171. package/dist/acp-spawn-DfcG2y_Y.js +0 -2
  1172. package/dist/acp-stateful-target-driver-BYeTpciM.js +0 -89
  1173. package/dist/action-agents-B9hNk5lN.js +0 -67
  1174. package/dist/action-focus-B6pqXNJ2.js +0 -132
  1175. package/dist/action-help-CPcU40vC.js +0 -7
  1176. package/dist/action-info-D_yE--lC.js +0 -101
  1177. package/dist/action-kill-BJ0225YA.js +0 -33
  1178. package/dist/action-list-BLyN0cUw.js +0 -21
  1179. package/dist/action-log-_sI8lmxG.js +0 -30
  1180. package/dist/action-send-C2RZKCaN.js +0 -39
  1181. package/dist/action-spawn-DtZrqOf-.js +0 -47
  1182. package/dist/action-unfocus-D90uQGIM.js +0 -29
  1183. package/dist/actions.runtime-CwqOsby1.js +0 -5
  1184. package/dist/actions.runtime-DL7IkUaC.js +0 -18
  1185. package/dist/agent-command-ChguXtvw.js +0 -874
  1186. package/dist/agent-delivery-BwzZnRgC.js +0 -76
  1187. package/dist/agent-eujROEra.js +0 -2
  1188. package/dist/agent-harness-runtime-KWYqsYTk.js +0 -144
  1189. package/dist/agent-runner-utils-DyLXFJim.js +0 -239
  1190. package/dist/agent-runner.runtime-Tm2znb5I.js +0 -3455
  1191. package/dist/agent-runtime-DYyI3OTz.js +0 -18
  1192. package/dist/agents-CaKEB08m.js +0 -5
  1193. package/dist/agents-D0LjQ71R.js +0 -954
  1194. package/dist/agents.command-shared-DnntyPTT.js +0 -40
  1195. package/dist/aliases-C1J5Hl0k.js +0 -96
  1196. package/dist/aliases-DE2DzUaH.js +0 -2
  1197. package/dist/api-9ms9Td4v.js +0 -3
  1198. package/dist/api-BgtDxBwP.js +0 -5
  1199. package/dist/api-BpBoWeil.js +0 -3
  1200. package/dist/api-CKbGCnWb.js +0 -139
  1201. package/dist/api-D1axzMqP.js +0 -4
  1202. package/dist/api-j3Hir2UT.js +0 -48
  1203. package/dist/apply-CIz-od94.js +0 -508
  1204. package/dist/apply.runtime-CN-vA6G-.js +0 -2
  1205. package/dist/approval-client-helpers-Dp5QM59V.js +0 -82
  1206. package/dist/approval-delivery-helpers-BS-VOhZN.js +0 -134
  1207. package/dist/approval-gateway-resolver-DIPFgTnx.js +0 -29
  1208. package/dist/approval-gateway-runtime-i0yziXk2.js +0 -2
  1209. package/dist/approval-handler-runtime-7ttgBfc_.js +0 -439
  1210. package/dist/approval-native-helpers-DbgPq2Af.js +0 -33
  1211. package/dist/approval-native-runtime-DT2b3zaN.js +0 -729
  1212. package/dist/approval-renderers-CxKF90_M.js +0 -64
  1213. package/dist/attempt-execution.runtime-CzM8MDim.js +0 -509
  1214. package/dist/attempt-execution.shared-BeCuaCMe.js +0 -22
  1215. package/dist/attempt.prompt-helpers-DfcGwj0J.js +0 -221
  1216. package/dist/attempt.tool-run-context-4cCwC6FC.js +0 -933
  1217. package/dist/audit-EYwFJUbn.js +0 -939
  1218. package/dist/audit-membership-runtime-AIbmS8yN.js +0 -550
  1219. package/dist/audit.runtime-OucPhZPU.js +0 -7
  1220. package/dist/auth-BPy3ID3D.js +0 -2
  1221. package/dist/auth-CYd5Phr-.js +0 -56
  1222. package/dist/auth-D0kGHo1j.js +0 -177
  1223. package/dist/auth-DTPcbxn6.js +0 -550
  1224. package/dist/auth-order-8O0b16i_.js +0 -139
  1225. package/dist/auth-order-CW2AQyNL.js +0 -2
  1226. package/dist/base-url-h8Mhif7l.js +0 -15
  1227. package/dist/bash-tools-8bn5C7K0.js +0 -2824
  1228. package/dist/bash-tools-DZpkBFMY.js +0 -3
  1229. package/dist/bash-tools.exec-runtime-DQVwPD43.js +0 -829
  1230. package/dist/best-effort-delivery-B6BoLJdq.js +0 -22
  1231. package/dist/binding-routing-BMMSo2KY.js +0 -85
  1232. package/dist/binding-targets-Wm55iFsz.js +0 -121
  1233. package/dist/block-streaming-CcRmZONP.js +0 -103
  1234. package/dist/bluebubbles-Cm2jWoAr.js +0 -77
  1235. package/dist/brave-web-search-provider-DXyLEuRX.js +0 -111
  1236. package/dist/brave-web-search-provider.runtime-CH2Ro8gV.js +0 -229
  1237. package/dist/brave-web-search-provider.shared-2wgQI-qy.js +0 -174
  1238. package/dist/bridge-auth-registry-1QsmDpYF.js +0 -23
  1239. package/dist/bridge-server-D3Mo-BM6.js +0 -113
  1240. package/dist/browser-control-auth-BiuDMNP7.js +0 -2
  1241. package/dist/browser-node-runtime-CrigB5UH.js +0 -12
  1242. package/dist/browser-profiles-BJjsWlQ8.js +0 -2
  1243. package/dist/browser-runtime-Dc5sMewB.js +0 -387
  1244. package/dist/browser-setup-tools-CM1H6l0K.js +0 -13
  1245. package/dist/build-8Hzi5z0_.js +0 -550
  1246. package/dist/call-B3rCzXN7.js +0 -3
  1247. package/dist/call-Cmd-rlC2.js +0 -331
  1248. package/dist/call-status-tDrmri32.js +0 -33
  1249. package/dist/call.runtime-B3Hufiov.js +0 -2
  1250. package/dist/capability-cli-Ce3qNXsw.js +0 -1401
  1251. package/dist/card-command-CJdI6sGe.js +0 -241
  1252. package/dist/catalog-provider-DY1ugTDc.js +0 -40
  1253. package/dist/catchup-CPt_Xs3R.js +0 -300
  1254. package/dist/channel-9VLlWEI1.js +0 -350
  1255. package/dist/channel-B-414Az-.js +0 -1100
  1256. package/dist/channel-BEuRg3eQ.js +0 -297
  1257. package/dist/channel-BlN_kpiT.js +0 -840
  1258. package/dist/channel-Bz03tu1a.js +0 -1174
  1259. package/dist/channel-C5Tp1ocZ.js +0 -595
  1260. package/dist/channel-Cp6PItXu.js +0 -1320
  1261. package/dist/channel-CzXZ2Wlv.js +0 -226
  1262. package/dist/channel-DIkT4jcM.js +0 -491
  1263. package/dist/channel-DcywMc0l.js +0 -1802
  1264. package/dist/channel-Dt2V2WJc.js +0 -453
  1265. package/dist/channel-core-BqZwOpId.js +0 -5
  1266. package/dist/channel-inbound-B7Bv-zk9.js +0 -31
  1267. package/dist/channel-plugin-runtime-D2c6-qG7.js +0 -771
  1268. package/dist/channel-resolution-DE2qIsKy.js +0 -39
  1269. package/dist/channel-runtime-CL6Do8kd.js +0 -425
  1270. package/dist/channel-selection-BVycf9oD.js +0 -126
  1271. package/dist/channel-selection.runtime-6URJ5YTl.js +0 -2
  1272. package/dist/channel.runtime-BvuS-PzM.js +0 -2364
  1273. package/dist/channel.runtime-CCct0AmO.js +0 -89
  1274. package/dist/channel.runtime-CSr_Q-Ki.js +0 -26
  1275. package/dist/channel.runtime-DC7FilE-.js +0 -576
  1276. package/dist/channel.runtime-MbysJwT_.js +0 -42398
  1277. package/dist/channel.runtime-RfnLhIct.js +0 -430
  1278. package/dist/channel.runtime-klwS5eJC.js +0 -4
  1279. package/dist/channel.runtime-srmPwBlw.js +0 -67
  1280. package/dist/channel.setup-B2dTQgdm.js +0 -10
  1281. package/dist/channel2.runtime-DPjdUdWe.js +0 -109
  1282. package/dist/channels-Dv75fvTN.js +0 -733
  1283. package/dist/channels-cli-CdOO74YS.js +0 -268
  1284. package/dist/chat-RXBcjTu0.js +0 -2830
  1285. package/dist/chrome-BXAOdA_f.js +0 -1430
  1286. package/dist/chrome-mcp-BxYER6mx.js +0 -600
  1287. package/dist/chrome-mcp-DBAP4O7j.js +0 -2
  1288. package/dist/chrome.executables-DUG48PkZ.js +0 -541
  1289. package/dist/chunk-CW9jTwFk.js +0 -268
  1290. package/dist/clawbot-cli-CFMt_3zm.js +0 -9
  1291. package/dist/cli-BPiKrd4S.js +0 -219
  1292. package/dist/cli-BaH_mH3N.js +0 -154
  1293. package/dist/cli-Bnlo8CdT.js +0 -2
  1294. package/dist/cli-Bv1HNRJ5.js +0 -72
  1295. package/dist/cli-CJjDYqsm.js +0 -3726
  1296. package/dist/cli-D1HCyEF2.js +0 -2
  1297. package/dist/cli-LrPyoM0F.js +0 -2
  1298. package/dist/cli-runner-G69QIenA.js +0 -286
  1299. package/dist/cli-runner.runtime-BLh4ORZH.js +0 -3
  1300. package/dist/cli-runner.runtime-DboAnzrp.js +0 -4
  1301. package/dist/cli.runtime-GlOBpTyx.js +0 -1261
  1302. package/dist/client-ClJyHgmq.js +0 -713
  1303. package/dist/client-PBXIhvrx.js +0 -138
  1304. package/dist/client-info-DZtBR4jU.js +0 -49
  1305. package/dist/command-auth-9KsVrUS6.js +0 -409
  1306. package/dist/command-auth-D11sIoiZ.js +0 -76
  1307. package/dist/command-config-resolution-B9-W4ET0.js +0 -2
  1308. package/dist/command-config-resolution-Wl8868is.js +0 -23
  1309. package/dist/command-config-resolution.runtime-CwcIQOXb.js +0 -2
  1310. package/dist/command-execution-startup-BqLYlG3n.js +0 -324
  1311. package/dist/command-gates-BCh2pNFa.js +0 -47
  1312. package/dist/command-registry-B7IhcWl6.js +0 -4
  1313. package/dist/command-registry-DPR9uz9j.js +0 -9
  1314. package/dist/command-registry-core-B5gwwfVK.js +0 -106
  1315. package/dist/command-secret-gateway-D2Lx9Ky-.js +0 -528
  1316. package/dist/command-status.runtime-CDDbtrG8.js +0 -87
  1317. package/dist/commands-acp-Bt7M70te.js +0 -77
  1318. package/dist/commands-compact.runtime-D5D8CApN.js +0 -10
  1319. package/dist/commands-context-ojGcHTsc.js +0 -38
  1320. package/dist/commands-core.runtime-J-hrpY-n.js +0 -2
  1321. package/dist/commands-handlers.runtime-DQBNyeLG.js +0 -4599
  1322. package/dist/commands-models-83LvrT6B.js +0 -327
  1323. package/dist/commands-reset-hooks-BJ-tN_wz.js +0 -135
  1324. package/dist/commands-status-DWJdDC46.js +0 -16
  1325. package/dist/commands-status.runtime-BwwPceyy.js +0 -3
  1326. package/dist/commands-subagents-control.runtime-DJ396mVU.js +0 -3
  1327. package/dist/commands-subagents-control.runtime-u0Q05DrT.js +0 -2
  1328. package/dist/commands-system-prompt-B2QE_VCG.js +0 -2
  1329. package/dist/commands-system-prompt-amkj1mZm.js +0 -158
  1330. package/dist/commands.runtime-DtaJzRBS.js +0 -167
  1331. package/dist/compact-D0swO4Yn.js +0 -1118
  1332. package/dist/compact.runtime-DoEPFAkB.js +0 -12
  1333. package/dist/completion-cli-Y2gWpjun.js +0 -328
  1334. package/dist/config-Bt-fMiqG.js +0 -252
  1335. package/dist/config-api-DAsbCIov.js +0 -2
  1336. package/dist/config-cli-vQiFMkMf.js +0 -1078
  1337. package/dist/config-compat-B5zS8b4Z.js +0 -130
  1338. package/dist/config-compat-Bc51fcbM.js +0 -126
  1339. package/dist/config-guard-DkhDBkW2.js +0 -96
  1340. package/dist/config-runtime-o9UzLknt.js +0 -32
  1341. package/dist/configure-4GGf_X5o.js +0 -1252
  1342. package/dist/configure-DXNuDvJ5.js +0 -2
  1343. package/dist/connect-options-D4mbwxwf.js +0 -699
  1344. package/dist/control-auth-CW8eEClz.js +0 -125
  1345. package/dist/control-service-v2GS08H6.js +0 -156
  1346. package/dist/control-ui/assets/agents-BskHTW81.js +0 -1052
  1347. package/dist/control-ui/assets/canvas-C0aRpEGd.js +0 -269
  1348. package/dist/control-ui/assets/channels-Cou3VPB8.js +0 -463
  1349. package/dist/control-ui/assets/cron-BTOQWH3p.js +0 -933
  1350. package/dist/control-ui/assets/debug-DFlkgaJr.js +0 -94
  1351. package/dist/control-ui/assets/index-BSKZQZqm.css +0 -1
  1352. package/dist/control-ui/assets/index-yB7WOhLR.js +0 -6210
  1353. package/dist/control-ui/assets/instances-LZGly20d.js +0 -57
  1354. package/dist/control-ui/assets/mcp-D0PCi1zE.js +0 -373
  1355. package/dist/control-ui/assets/nodes-BGzTN7_8.js +0 -618
  1356. package/dist/control-ui/assets/plugins-kalk3SHa.js +0 -273
  1357. package/dist/control-ui/assets/sessions-3I2s2QvS.js +0 -306
  1358. package/dist/control-ui/assets/skills-CVXfvdtq.js +0 -323
  1359. package/dist/control-ui/assets/wallet-0oCbcesL.js +0 -285
  1360. package/dist/control-ui-969zq03L.js +0 -1043
  1361. package/dist/conversation-id-CRePZnKh.js +0 -235
  1362. package/dist/conversation-id-CYPpQ2b_.js +0 -38
  1363. package/dist/conversation-runtime-CsNLbytB.js +0 -31
  1364. package/dist/core-CE92oVKC.js +0 -275
  1365. package/dist/create-5gsvOUrW.js +0 -80
  1366. package/dist/cron-cli-iwMQSWts.js +0 -713
  1367. package/dist/daemon-cli-B2_mPKtr.js +0 -12
  1368. package/dist/dashboard-BgppT7jE.js +0 -2
  1369. package/dist/dashboard-BvirXUKT.js +0 -81
  1370. package/dist/ddg-client-C2_vfwll.js +0 -147
  1371. package/dist/ddg-search-provider-B5vfg-3L.js +0 -54
  1372. package/dist/delegate-CUa3SE1o.js +0 -64
  1373. package/dist/deliver-B8OtkCTN.js +0 -3
  1374. package/dist/deliver-EzzwtNdH.js +0 -747
  1375. package/dist/deliver-runtime-CSD1urwa.js +0 -2
  1376. package/dist/delivery-context-DWhGyo59.js +0 -40
  1377. package/dist/delivery-outbound.runtime-CuQHxHy1.js +0 -6
  1378. package/dist/delivery.runtime-2U6XvLON.js +0 -253
  1379. package/dist/detached-task-runtime-CLeXceLH.js +0 -73
  1380. package/dist/devices-cli-BhL3A8cJ.js +0 -498
  1381. package/dist/diagnostics-CYkTN8yr.js +0 -154
  1382. package/dist/direct-dm-B7BKDOTt.js +0 -64
  1383. package/dist/directive-handling.fast-lane-hTmCaN4B.js +0 -66
  1384. package/dist/directive-handling.impl-CLfhAB3s.js +0 -2
  1385. package/dist/directive-handling.impl-DQCYdyq3.js +0 -703
  1386. package/dist/directive-handling.model-selection-r1oi_Z5Q.js +0 -114
  1387. package/dist/directive-handling.persist.runtime-CKVn6kNl.js +0 -215
  1388. package/dist/directive-handling.shared-DLVXjKip.js +0 -56
  1389. package/dist/directory-cli-Cp5qe7Tb.js +0 -240
  1390. package/dist/dispatch-Dy7iNSXe.js +0 -1131
  1391. package/dist/dispatch-acp-TiM2Vzfh.js +0 -981
  1392. package/dist/dispatch-acp-manager.runtime-IOMdfbvN.js +0 -3
  1393. package/dist/dispatch-acp-media.runtime-D8ZRAL_i.js +0 -4
  1394. package/dist/dispatch-acp-session.runtime-BNf4E79J.js +0 -2
  1395. package/dist/dispatch-acp.runtime-D-O-_uwA.js +0 -19
  1396. package/dist/doctor-config-flow-REpgyGT1.js +0 -420
  1397. package/dist/doctor-config-preflight-DCEuxKBd.js +0 -2
  1398. package/dist/doctor-config-preflight-_gjxioW4.js +0 -63
  1399. package/dist/doctor-contract-U3opYPeO.js +0 -26
  1400. package/dist/doctor-device-pairing-NWw3fVhm.js +0 -307
  1401. package/dist/doctor-gateway-daemon-flow-ciZuB3_y.js +0 -250
  1402. package/dist/doctor-gateway-health-Clb9pKDM.js +0 -63
  1403. package/dist/doctor-health-Dz0Uo3ey.js +0 -59
  1404. package/dist/doctor-health-contributions-B36IgdyB.js +0 -493
  1405. package/dist/doctor-prompter-D6cxwaM6.js +0 -56
  1406. package/dist/doctor-sandbox-CnGh8PIF.js +0 -194
  1407. package/dist/doctor-state-migrations-DlFzkEz6.js +0 -2
  1408. package/dist/doctor-workspace-status-CBsmvySn.js +0 -75
  1409. package/dist/dreaming-CzDMTkOn.js +0 -1582
  1410. package/dist/dreaming-narrative-y806xcaM.js +0 -596
  1411. package/dist/dreaming-shared-C4dysoA0.js +0 -21
  1412. package/dist/embedded-gateway-stub.runtime-CHJcdIyH.js +0 -9
  1413. package/dist/embeddings-CWCkXHbh.js +0 -215
  1414. package/dist/embeddings-http-CdI7ktv7.js +0 -205
  1415. package/dist/exa-web-search-provider-Duy7AQi9.js +0 -80
  1416. package/dist/exa-web-search-provider.runtime-BFsoURiN.js +0 -302
  1417. package/dist/exa-web-search-provider.runtime-DL0X8Ct2.js +0 -2
  1418. package/dist/exec-approval-forwarder.runtime-DTz08HhE.js +0 -3
  1419. package/dist/exec-approval-reply-CKpq6yzn.js +0 -296
  1420. package/dist/exec-approval-reply-CuNQhfNe.js +0 -2
  1421. package/dist/exec-approval-session-target-VmakwuWi.js +0 -176
  1422. package/dist/exec-approvals-cli-D-xC3sec.js +0 -498
  1423. package/dist/exec-defaults-BwOKAzOq.js +0 -2
  1424. package/dist/exec-defaults-C58y025t.js +0 -67
  1425. package/dist/execute.runtime-DOUF94B3.js +0 -1363
  1426. package/dist/fallbacks-5pUORVnh.js +0 -31
  1427. package/dist/fallbacks-WXR5Obc4.js +0 -2
  1428. package/dist/fallbacks-shared-CLY3SckB.js +0 -111
  1429. package/dist/format-Z6ci0mN3.js +0 -176
  1430. package/dist/gateway-Bh4zysny.js +0 -115
  1431. package/dist/gateway-cli-Cn8UyxHT.js +0 -1283
  1432. package/dist/gateway-rpc-DWqAmWHZ.js +0 -14
  1433. package/dist/gateway-rpc.runtime-8RQQdisU.js +0 -23
  1434. package/dist/gateway-runtime-CqSQCYo0.js +0 -15
  1435. package/dist/gateway-status-CRk9P_mQ.js +0 -584
  1436. package/dist/genesis-tools-Bczkn4pa.js +0 -9166
  1437. package/dist/genesis-tools.runtime-DybZ3Sbd.js +0 -2
  1438. package/dist/get-reply-BFleeJ4f.js +0 -3897
  1439. package/dist/get-reply-from-config.runtime-D3inD3tz.js +0 -2
  1440. package/dist/graph-users-6xhmlyu_.js +0 -1337
  1441. package/dist/guarded-json-api-BzmpX7Bh.js +0 -594
  1442. package/dist/health-CMBrLjD5.js +0 -3
  1443. package/dist/health-CYhGu11X.js +0 -469
  1444. package/dist/health-route-C6jiKkgE.js +0 -41
  1445. package/dist/health-route-C6s6ENKx.js +0 -2
  1446. package/dist/heartbeat-runner-Dh9Xx9YU.js +0 -1292
  1447. package/dist/heartbeat-runner-zDpniJi_.js +0 -5
  1448. package/dist/heartbeat-runner.runtime-D4lSdsnQ.js +0 -4
  1449. package/dist/helpers-DZTamQ-L.js +0 -320
  1450. package/dist/hooks-cli-DWDRPcaF.js +0 -433
  1451. package/dist/http-endpoint-helpers-BYmpbInx.js +0 -41
  1452. package/dist/http-headers-BWJ-wWSB.js +0 -11
  1453. package/dist/http-utils-DFEeaWER.js +0 -924
  1454. package/dist/identity-JQch7avk.js +0 -140
  1455. package/dist/image-fallbacks-BdpPq4o8.js +0 -2
  1456. package/dist/image-fallbacks-GxUehr7F.js +0 -31
  1457. package/dist/image-generation-provider-Bs8dan-F.js +0 -95
  1458. package/dist/image-generation-provider-Ca75_MHL.js +0 -63
  1459. package/dist/image-generation-provider-Cumlkwcm.js +0 -228
  1460. package/dist/image-generation-provider-DAAncrN2.js +0 -529
  1461. package/dist/image-generation-provider-LZz_eWeh.js +0 -157
  1462. package/dist/image-generation-provider-xE4TSEUN.js +0 -274
  1463. package/dist/inbound-reply-dispatch-DRjQ7qlQ.js +0 -73
  1464. package/dist/inbound.runtime-B3E6TUQ-.js +0 -4
  1465. package/dist/inbound.runtime-BsJCJ9wE.js +0 -3
  1466. package/dist/infra-runtime-pY0nhq7P.js +0 -39
  1467. package/dist/init-BFVKFRp9.js +0 -59
  1468. package/dist/install-signal-cli-Aj1HHG57.js +0 -202
  1469. package/dist/jobs-CzIiEiXa.js +0 -734
  1470. package/dist/kimi-web-search-provider-g6k5oyqw.js +0 -80
  1471. package/dist/kimi-web-search-provider.runtime-B5Y_iP-w.js +0 -2
  1472. package/dist/kimi-web-search-provider.runtime-D9mGNz4w.js +0 -261
  1473. package/dist/library-BpP85Umq.js +0 -45
  1474. package/dist/lifecycle-C69VoOuS.js +0 -229
  1475. package/dist/lifecycle-zC5_kLvH.js +0 -571
  1476. package/dist/lifecycle.runtime-DN9n10Ar.js +0 -2
  1477. package/dist/list-CZePHMYk.js +0 -2
  1478. package/dist/list-D-39rkJG.js +0 -2
  1479. package/dist/list-D9R6bffC.js +0 -1212
  1480. package/dist/list-J_MIp9Cf.js +0 -131
  1481. package/dist/list.probe-BJI7RpM4.js +0 -419
  1482. package/dist/live-model-switch-1UTJZ5QI.js +0 -336
  1483. package/dist/llm-slug-generator-CB-9wD87.js +0 -79
  1484. package/dist/load-config-Cokd9aKd.js +0 -35
  1485. package/dist/local-dispatch.runtime-DfmGw3hN.js +0 -8
  1486. package/dist/login-Ca9f5om9.js +0 -108
  1487. package/dist/logs-cli-Dz0aORYp.js +0 -265
  1488. package/dist/logs-cli.runtime-DgpP6kgG.js +0 -2
  1489. package/dist/main-session-restart-recovery-BdWx2-Ig.js +0 -206
  1490. package/dist/managed-image-attachments-BTEZZFPC.js +0 -2
  1491. package/dist/managed-image-attachments-BXwFe_hB.js +0 -635
  1492. package/dist/manager-49WINgRB.js +0 -3114
  1493. package/dist/manager-CKWINDnN.js +0 -2
  1494. package/dist/manager-DXquZHPE.js +0 -2057
  1495. package/dist/markdown-to-line-DuPPNWHb.js +0 -790
  1496. package/dist/mcp-cli-BgjBxFLB.js +0 -725
  1497. package/dist/mcp-http-CXz6iTV9.js +0 -529
  1498. package/dist/media-contract-api-Dn7Z9fVR.js +0 -2
  1499. package/dist/media-contract-g0U7MSOk.js +0 -49
  1500. package/dist/media-runtime-DKL6xud8.js +0 -329
  1501. package/dist/memory-Cvmtd7SS.js +0 -342
  1502. package/dist/memory-core-host-runtime-cli-DZAsYda3.js +0 -9
  1503. package/dist/memory-embedding-adapter-D58z4Hjn.js +0 -123
  1504. package/dist/message-DqFmV6vo.js +0 -232
  1505. package/dist/message-action-runner-B-6rT67S.js +0 -1407
  1506. package/dist/message-action-runner-Ds9MNZPn.js +0 -2
  1507. package/dist/message-actions-Bvs23y8w.js +0 -143
  1508. package/dist/message-channel-bhWoqTRw.js +0 -56
  1509. package/dist/message-secret-scope-CEVGxySq.js +0 -103
  1510. package/dist/message.gateway.runtime-CT0DJ45B.js +0 -2
  1511. package/dist/method-scopes-DZxEwSC9.js +0 -228
  1512. package/dist/minimax-web-search-provider-4scwuRzS.js +0 -53
  1513. package/dist/minimax-web-search-provider.runtime-Bc1tLmEn.js +0 -140
  1514. package/dist/minimax-web-search-provider.runtime-DirtikTO.js +0 -2
  1515. package/dist/mock-DjlwRj77.js +0 -136
  1516. package/dist/model-definitions-DAfZ2fCD.js +0 -260
  1517. package/dist/model-overrides-C47kuXVC.js +0 -104
  1518. package/dist/model-selection-B0e0JNhN.js +0 -213
  1519. package/dist/models-CEyQw90_.js +0 -47
  1520. package/dist/models-CQV1b487.js +0 -760
  1521. package/dist/models-CXOS_VP1.js +0 -157
  1522. package/dist/models-CfTF8Fbp.js +0 -569
  1523. package/dist/models-auth-status-CtbfpiLe.js +0 -217
  1524. package/dist/models-cli-DKlGXayC.js +0 -271
  1525. package/dist/models-http-DWu9XkAU.js +0 -92
  1526. package/dist/models.fetch-BVY3QlcA.js +0 -518
  1527. package/dist/monitor-BrQZ38sV.js +0 -1661
  1528. package/dist/monitor-C2olcPaB.js +0 -1237
  1529. package/dist/monitor-C32pQJf0.js +0 -788
  1530. package/dist/monitor-DWDZx3af.js +0 -2
  1531. package/dist/monitor-DuB8d2_N.js +0 -671
  1532. package/dist/monitor-DwAHrb0v.js +0 -295
  1533. package/dist/monitor-auth-ym3-n10B.js +0 -207
  1534. package/dist/monitor-fV4pkrv-.js +0 -1459
  1535. package/dist/monitor-processing-Cnjt-86E.js +0 -1974
  1536. package/dist/monitor.runtime-m4hyBv5_.js +0 -2
  1537. package/dist/monitor.webhook-DpQqy92z.js +0 -180
  1538. package/dist/msteams-CEC38YQX.js +0 -35
  1539. package/dist/music-generation-provider-DR8TlAd7.js +0 -63
  1540. package/dist/music-generation-provider-UU2xosmd.js +0 -170
  1541. package/dist/native-hook-relay-ALDxVrJR.js +0 -519
  1542. package/dist/native-web-search-DE6wKTD7.js +0 -64
  1543. package/dist/nextcloud-talk-D6l_ncY6.js +0 -17
  1544. package/dist/node-cli-B4fFzsbt.js +0 -2276
  1545. package/dist/nodes-cli-DPOCIMd6.js +0 -1046
  1546. package/dist/nodes-utils-DXJ9uuER.js +0 -84
  1547. package/dist/nodes.helpers-DYpGCFer.js +0 -34
  1548. package/dist/notify-CDGsB-f1.js +0 -315
  1549. package/dist/onboard-BAKpU8Hh2.js +0 -49
  1550. package/dist/onboard-BPXard5r.js +0 -316
  1551. package/dist/onboard-BhyqJz5g.js +0 -2
  1552. package/dist/onboard-CYwvwcjK.js +0 -25
  1553. package/dist/onboard-DEkkXwRP.js +0 -58
  1554. package/dist/onboard-DcPiUfS6.js +0 -70
  1555. package/dist/onboard-UUvy9YwT.js +0 -29
  1556. package/dist/onboard-g4ijsx6R.js +0 -25
  1557. package/dist/onboard-helpers-DD5g-FbW.js +0 -204
  1558. package/dist/onboard-helpers-DRudISKo.js +0 -6
  1559. package/dist/onboard-iJRhJj4E.js +0 -25
  1560. package/dist/onboard-interactive-DxupaeWe.js +0 -24
  1561. package/dist/onboard-non-interactive-BCIl9AIV.js +0 -635
  1562. package/dist/onboard-remote-By9HP4eT.js +0 -193
  1563. package/dist/onboard-remote-r9H76BMI.js +0 -2
  1564. package/dist/onboard-skills-BbXkZVWi.js +0 -2
  1565. package/dist/onboard-skills-Bj6v5Fc2.js +0 -134
  1566. package/dist/openai-codex-auth-identity-DDVrnkGx.js +0 -45
  1567. package/dist/openai-codex-device-code-vaMr3ktu.js +0 -164
  1568. package/dist/openai-codex-provider-BgIrfq5f.js +0 -472
  1569. package/dist/openai-codex-shared-i8zMv9Wn.js +0 -6
  1570. package/dist/openai-http-3hSjTiC9.js +0 -500
  1571. package/dist/openai-provider-BRJBMcdJ.js +0 -313
  1572. package/dist/openresponses-http-DCEEmL6J.js +0 -1128
  1573. package/dist/operator-approvals-client-gaflvETF.js +0 -68
  1574. package/dist/outbound-media-Bh4sEXyv.js +0 -57
  1575. package/dist/outbound-runtime-CNL02KHG.js +0 -5
  1576. package/dist/outbound.runtime-DNeZz0qd.js +0 -2
  1577. package/dist/pair-command-approve-DVG9ZQOz.js +0 -44
  1578. package/dist/perplexity-web-search-provider-CIwymV16.js +0 -92
  1579. package/dist/perplexity-web-search-provider.runtime-CIrANP8t.js +0 -324
  1580. package/dist/perplexity-web-search-provider.runtime-GuZxipp7.js +0 -2
  1581. package/dist/persistent-bindings.lifecycle-DO0CXQku.js +0 -2
  1582. package/dist/persistent-bindings.lifecycle-yyMTI5wL.js +0 -85
  1583. package/dist/pi-embedded-G_7qiYrd.js +0 -2905
  1584. package/dist/pi-embedded-RNv_18Ql.js +0 -4
  1585. package/dist/pi-embedded-subscribe.handlers.compaction.runtime-B0obozHf.js +0 -23
  1586. package/dist/pi-embedded.runtime-DgLkukEn.js +0 -4
  1587. package/dist/pi-tool-definition-adapter-CAxVoliV.js +0 -229
  1588. package/dist/pi-tools-DLzCdu_A.js +0 -1057
  1589. package/dist/pi-tools.before-tool-call-CXqyPFQ7.js +0 -2
  1590. package/dist/pi-tools.before-tool-call-DgEuyrNS.js +0 -433
  1591. package/dist/plivo-B2yZjL-u.js +0 -394
  1592. package/dist/plugin--KkHkZKl.js +0 -12195
  1593. package/dist/plugin-enabled-DOVricci.js +0 -140
  1594. package/dist/plugin-registration-BsNMVImp.js +0 -23
  1595. package/dist/plugin-service-CAdEnLLQ.js +0 -2892
  1596. package/dist/policy-6PXLgKPZ.js +0 -328
  1597. package/dist/prepare.runtime-asu7nymR.js +0 -815
  1598. package/dist/probe-8nNaZ33e.js +0 -45
  1599. package/dist/probe-BOlTfbzG.js +0 -2
  1600. package/dist/probe-BicpMUHr.js +0 -74
  1601. package/dist/probe-BoAfs3v0.js +0 -243
  1602. package/dist/probe-C2UYvuU1.js +0 -1443
  1603. package/dist/probe-D3-S54s4.js +0 -2
  1604. package/dist/probe-D7gHyiZV.js +0 -241
  1605. package/dist/probe-Dauysr9a.js +0 -32
  1606. package/dist/probe-DqbaFZ8U.js +0 -2205
  1607. package/dist/probe.runtime-D1TENrHH.js +0 -2
  1608. package/dist/program-C_hsOWv5.js +0 -111
  1609. package/dist/prompt-select-styled-CuuJ3YZI.js +0 -20
  1610. package/dist/protocol-DxLbSF2J.js +0 -2477
  1611. package/dist/provider-3GpsNTSy.js +0 -70
  1612. package/dist/provider-catalog-BSXiLKUb.js +0 -24
  1613. package/dist/provider-catalog-BfrRkDb6.js +0 -26
  1614. package/dist/provider-catalog-CQOOAKUd.js +0 -11
  1615. package/dist/provider-catalog-DuplUDCj.js +0 -12
  1616. package/dist/provider-catalog-nmYuB55e.js +0 -11
  1617. package/dist/provider-compat-Cmc7Dpb2.js +0 -37
  1618. package/dist/provider-dispatcher-C98nuGtx.js +0 -2
  1619. package/dist/provider-dispatcher-U0bjp31x.js +0 -22
  1620. package/dist/provider-models-CQ8YMhIq.js +0 -35
  1621. package/dist/provider-models-xoUb7pnU.js +0 -119
  1622. package/dist/provider-registration-B5Xbkn85.js +0 -218
  1623. package/dist/pw-ai-B0xjo-Hb.js +0 -2511
  1624. package/dist/pw-role-snapshot-DfdV7JMN.js +0 -380
  1625. package/dist/qmd-manager-DtShFCys.js +0 -1921
  1626. package/dist/qr-cli-D38r9mtY.js +0 -2
  1627. package/dist/qr-cli-Wbrc0tcy.js +0 -349
  1628. package/dist/qr-image-BQhzr3CC.js +0 -2
  1629. package/dist/queue-DyWzQqJh.js +0 -409
  1630. package/dist/reaction-runtime-api-BZCWmrll.js +0 -116
  1631. package/dist/reactions-BmhlLeFI.js +0 -998
  1632. package/dist/read-capability-B0mVFrNe.js +0 -412
  1633. package/dist/realtime-provider-shared-CKounRGH.js +0 -37
  1634. package/dist/realtime-transcription-provider-BjwZyKME.js +0 -120
  1635. package/dist/realtime-transcription-provider-CSQuayAt.js +0 -183
  1636. package/dist/realtime-transcription-provider-Cr86v5pA.js +0 -184
  1637. package/dist/realtime-transcription-provider-DFdWvvWN.js +0 -184
  1638. package/dist/realtime-transcription-provider-Da6Yg9O_.js +0 -172
  1639. package/dist/realtime-voice-provider-DP4ad0L4.js +0 -489
  1640. package/dist/record-shared-B5MzAU-n.js +0 -10
  1641. package/dist/register-service-commands-B2Ky9P6l.js +0 -71
  1642. package/dist/register.agent-C9UIPMzI.js +0 -248
  1643. package/dist/register.configure-DlvVdJGK.js +0 -15
  1644. package/dist/register.maintenance-4q078BpS.js +0 -363
  1645. package/dist/register.message-Dyafa7wU.js +0 -329
  1646. package/dist/register.onboard-R4VgPeqI.js +0 -88
  1647. package/dist/register.runtime-Eju4Gltw.js +0 -81
  1648. package/dist/register.setup-DCnMQggx.js +0 -150
  1649. package/dist/register.status-health-sessions-DrZEX_C3.js +0 -1215
  1650. package/dist/register.subclis-C8MYnxZ0.js +0 -29
  1651. package/dist/register.subclis-DXRcUQY-.js +0 -3
  1652. package/dist/register.subclis-core-CKrFtMnT.js +0 -249
  1653. package/dist/replay-policy-BXxBsUQj.js +0 -8
  1654. package/dist/reply-chunking-CQ-Mda9f.js +0 -3
  1655. package/dist/reply-dispatch-runtime-DrCMM_h6.js +0 -13
  1656. package/dist/reply-media-paths.runtime-Dm7QsGx1.js +0 -146
  1657. package/dist/reply-media-paths.runtime-N1vQKI2t.js +0 -2
  1658. package/dist/reply-payload-transform-DXQFdUjX.js +0 -720
  1659. package/dist/reply-runtime-BEbR4D-L.js +0 -11
  1660. package/dist/reply.runtime-k1wfQvE8.js +0 -2
  1661. package/dist/reset-PRwf7E1a.js +0 -84
  1662. package/dist/reset-authorization-DnCXXdJm.js +0 -34
  1663. package/dist/response-generator-CfYnwr-R.js +0 -175
  1664. package/dist/restart-health-BjmfJCUM.js +0 -202
  1665. package/dist/restart-health-hw909zlD.js +0 -2
  1666. package/dist/root-help-DetBH1U3.js +0 -44
  1667. package/dist/route-reply-DCdEIaJm.js +0 -162
  1668. package/dist/route-reply.runtime-CCoWkbHJ.js +0 -2
  1669. package/dist/routes-CBHvnNAn.js +0 -3341
  1670. package/dist/routes-CM5XFUol.js +0 -2
  1671. package/dist/routing-DB6Hmk1m.js +0 -5
  1672. package/dist/rpc-DejtQFPW.js +0 -61
  1673. package/dist/rpc-context-C-K-u97k.js +0 -17
  1674. package/dist/rpc.runtime-CvFF6IfX.js +0 -21
  1675. package/dist/run-auth-profile.runtime-CBF7l6AJ.js +0 -2
  1676. package/dist/run-delivery.runtime-mrFGIUBn.js +0 -530
  1677. package/dist/run-embedded.runtime-Bi_aGXZl.js +0 -4
  1678. package/dist/run-execution-cli.runtime-CJ5bRUst.js +0 -4
  1679. package/dist/run-executor.runtime-C2nEQ7H5.js +0 -277
  1680. package/dist/run-main-C4eOl9O3.js +0 -567
  1681. package/dist/run-subagent-registry.runtime-Wv4vcMON.js +0 -2
  1682. package/dist/run-wait-J2xqMO0Y.js +0 -135
  1683. package/dist/runtime-BWI1Yc19.js +0 -9
  1684. package/dist/runtime-BvrYBFWw.js +0 -107
  1685. package/dist/runtime-YN3DqmXj.js +0 -72
  1686. package/dist/runtime-api-B7_47clB.js +0 -9
  1687. package/dist/runtime-api-CCSSXW6u.js +0 -4
  1688. package/dist/runtime-api-CHqMki_k.js +0 -9
  1689. package/dist/runtime-api-FyNFEQa6.js +0 -14
  1690. package/dist/runtime-embedded-pi.runtime-CKKAqNJ9.js +0 -2
  1691. package/dist/runtime-entry-T6UII6Wf.js +0 -2769
  1692. package/dist/runtime-internal-BsETZzZr.js +0 -2
  1693. package/dist/runtime-lZ_xBQn6.js +0 -973
  1694. package/dist/runtime-options-DYh6T1p4.js +0 -275
  1695. package/dist/runtime-provider-C0RXuzkp.js +0 -21
  1696. package/dist/runtime-schema-DjdB9Mgh.js +0 -28588
  1697. package/dist/sandbox-Ctv6fRri.js +0 -3
  1698. package/dist/sandbox-cli-DlgKqSYU.js +0 -450
  1699. package/dist/sandbox-xqJ6gg8T.js +0 -1156
  1700. package/dist/scan-C4AL0vV5.js +0 -2
  1701. package/dist/scan-CiyGLsBp.js +0 -523
  1702. package/dist/secrets-cli-BzZc1dlc.js +0 -2101
  1703. package/dist/security-cli-D7WSpDIp.js +0 -486
  1704. package/dist/selection-BTj1orBr.js +0 -2
  1705. package/dist/selection-Bj9s46tI.js +0 -7764
  1706. package/dist/send-D1BQp5zh.js +0 -102
  1707. package/dist/send-KwF2Hkrg.js +0 -534
  1708. package/dist/send-pMWIOnb1.js +0 -156
  1709. package/dist/send.runtime-BY-fpUGh.js +0 -2
  1710. package/dist/server-4wSXAqKZ.js +0 -77
  1711. package/dist/server-CM6IcXrJ.js +0 -13
  1712. package/dist/server-context-LGN_v6Pr.js +0 -847
  1713. package/dist/server-context-uC_sh4Qx.js +0 -2
  1714. package/dist/server-middleware-DlVw3WGo.js +0 -120
  1715. package/dist/server-node-events-DRqk_sSG.js +0 -481
  1716. package/dist/server-plugin-bootstrap-DT7hMrEB.js +0 -12989
  1717. package/dist/server-plugin-bootstrap-DbgT8s3b.js +0 -2
  1718. package/dist/server-restart-sentinel-DJg1jibz.js +0 -697
  1719. package/dist/server.impl-KfCHHYM3.js +0 -12869
  1720. package/dist/session-D4GawBOc.js +0 -48
  1721. package/dist/session-envelope-BuDz-uci.js +0 -18
  1722. package/dist/session-key-BDzsY9ry.js +0 -65
  1723. package/dist/session-kill-http-BtXfgdg5.js +0 -110
  1724. package/dist/session-meta-DSbdkLPg.js +0 -109
  1725. package/dist/session-override-DvpYNjEy.js +0 -106
  1726. package/dist/session-reset-model.runtime-TJuluskH.js +0 -133
  1727. package/dist/session-reset-service-hc2O1o2q.js +0 -497
  1728. package/dist/session-route-dSc-ZfJV.js +0 -93
  1729. package/dist/session-status.runtime-DBOWNGE0.js +0 -2
  1730. package/dist/session-store-CH0Ic73R.js +0 -126
  1731. package/dist/session-store.runtime-BLzP0kKb.js +0 -2
  1732. package/dist/session-subagent-reactivation.runtime-DLwmbVAj.js +0 -2
  1733. package/dist/session-tab-registry-C30tFUHP.js +0 -581
  1734. package/dist/session-updates-CNv8yQTZ.js +0 -236
  1735. package/dist/session-updates.runtime-BI1pPG-y.js +0 -2
  1736. package/dist/session-utils-BtcpsVXK.js +0 -1009
  1737. package/dist/session-visibility-mu61Cazj.js +0 -147
  1738. package/dist/sessions-BY-N1ODJ.js +0 -2
  1739. package/dist/sessions-BaBnI48b.js +0 -48
  1740. package/dist/sessions-DgCDR090.js +0 -16
  1741. package/dist/sessions-DwbTRE7z.js +0 -281
  1742. package/dist/sessions-helpers-Boau-Mgl.js +0 -305
  1743. package/dist/sessions-history-http-JaZfsaow.js +0 -383
  1744. package/dist/sessions-patch-CGza9U1J.js +0 -309
  1745. package/dist/sessions-resolve-CxsMxrnz.js +0 -174
  1746. package/dist/sessions.runtime-B-dhGJmG.js +0 -2
  1747. package/dist/setup-Dld60Kw0.js +0 -636
  1748. package/dist/setup-XAAowspF.js +0 -421
  1749. package/dist/setup-api-qytGcCw9.js +0 -29
  1750. package/dist/setup-core-4RX2I3E7.js +0 -176
  1751. package/dist/setup-core-BDZ0GEn7.js +0 -171
  1752. package/dist/setup-core-BagQlOhA.js +0 -184
  1753. package/dist/setup-core-DFDx-2sA.js +0 -393
  1754. package/dist/setup-surface-BFIZR2UD.js +0 -286
  1755. package/dist/setup-surface-BNFYOzmc.js +0 -3
  1756. package/dist/setup-surface-C5F8cr6e2.js +0 -403
  1757. package/dist/setup-surface-CArOZxWv.js +0 -72
  1758. package/dist/setup-surface-D5kQP_5C.js +0 -219
  1759. package/dist/setup-surface-uNLwReGA.js +0 -351
  1760. package/dist/setup.finalize-DanHcKdm.js +0 -547
  1761. package/dist/setup.gateway-config-BfYDHl2S.js +0 -250
  1762. package/dist/shared-CHz0sVK9.js +0 -186
  1763. package/dist/shared-CaYwmZh_.js +0 -76
  1764. package/dist/shared-DZLuHh9i.js +0 -121
  1765. package/dist/shared-Doh9gWDF.js +0 -198
  1766. package/dist/shared-IhxU1SqF.js +0 -60
  1767. package/dist/shared-Xx-lZLWj.js +0 -217
  1768. package/dist/shared-runtime-BtwYWnp-.js +0 -7
  1769. package/dist/short-term-promotion-B_3UbQd-.js +0 -1543
  1770. package/dist/skill-commands-X1-SuzeM.js +0 -83
  1771. package/dist/skill-commands.runtime-DtDW-HM9.js +0 -2
  1772. package/dist/skills-snapshot.runtime-CA04_tLs.js +0 -7
  1773. package/dist/slash-state-C5V_rwuh.js +0 -1911
  1774. package/dist/speech-provider-Bs22xK7f.js +0 -216
  1775. package/dist/speech-provider-DH35IJrp.js +0 -395
  1776. package/dist/speech-provider-DJhp-WGc.js +0 -170
  1777. package/dist/speech-provider-TuMZXjYA.js +0 -209
  1778. package/dist/speech-provider-bfFcbOuQ.js +0 -184
  1779. package/dist/speech-provider-eDdGrCL3.js +0 -209
  1780. package/dist/speech-provider-hFc3R_JS.js +0 -103
  1781. package/dist/src-CbvReXTF.js +0 -3974
  1782. package/dist/stage-sandbox-media.runtime-BBZVC4gy.js +0 -232
  1783. package/dist/startup-context-BhbpkDRe.js +0 -312
  1784. package/dist/state-migrations-BcK6CUBE.js +0 -820
  1785. package/dist/status-6TVRvc0X.js +0 -2
  1786. package/dist/status-BXUtOoXd.js +0 -190
  1787. package/dist/status-BYxVnJ4t.js +0 -62
  1788. package/dist/status-CASjTsed.js +0 -3
  1789. package/dist/status-CozhtuYB.js +0 -2
  1790. package/dist/status-DtWC4gU2.js +0 -397
  1791. package/dist/status-all-RMu-gp_i.js +0 -498
  1792. package/dist/status-json-C05vJFn8.js +0 -14
  1793. package/dist/status-json-command-CM9ioz3P.js +0 -84
  1794. package/dist/status-message-CqkaBWzr.js +0 -466
  1795. package/dist/status-message.runtime-qXxrcsiN.js +0 -6
  1796. package/dist/status-queue.runtime-C7PIZ71w.js +0 -2
  1797. package/dist/status-runtime-shared-CilAS_RU.js +0 -257
  1798. package/dist/status-subagents.runtime-_MQiX_ZF.js +0 -18
  1799. package/dist/status-text-Cbbo5gTy.js +0 -237
  1800. package/dist/status-xCBvRTwU.js +0 -209
  1801. package/dist/status.gateway-connection.runtime-CpCUmiCK.js +0 -2
  1802. package/dist/status.gather-B_e7gqcb.js +0 -2
  1803. package/dist/status.gather-DeoHK2V7.js +0 -292
  1804. package/dist/status.runtime-CCrtR3yP.js +0 -2
  1805. package/dist/status.runtime-IgA-WP26.js +0 -2
  1806. package/dist/status.scan-BywaTUGM.js +0 -65
  1807. package/dist/status.scan-overview-Bg0PxIss.js +0 -379
  1808. package/dist/status.scan.fast-json-Bf3f1o0d.js +0 -2
  1809. package/dist/status.scan.fast-json-D7_WMvuZ.js +0 -132
  1810. package/dist/status.summary-BoGDDE4X.js +0 -214
  1811. package/dist/status.summary-b0S78Iju.js +0 -2
  1812. package/dist/store-BXDBdpSq.js +0 -4
  1813. package/dist/store-DOwpgFxf.js +0 -910
  1814. package/dist/store.runtime-1QGWUWou.js +0 -2
  1815. package/dist/stream-BsnsNxOA.js +0 -664
  1816. package/dist/stream-DEH1-1Is.js +0 -134
  1817. package/dist/stt-CJtlkVDc.js +0 -66
  1818. package/dist/subagent-announce-delivery-DwS6sI24.js +0 -726
  1819. package/dist/subagent-announce-gxWOuvuY.js +0 -351
  1820. package/dist/subagent-announce-output-C5ButdYI.js +0 -364
  1821. package/dist/subagent-capabilities-DIIDgPnB.js +0 -251
  1822. package/dist/subagent-control-C-Am1OtB.js +0 -506
  1823. package/dist/subagent-control.runtime-BK2jtN2v.js +0 -3
  1824. package/dist/subagent-followup.runtime-DoLAbwOo.js +0 -68
  1825. package/dist/subagent-orphan-recovery-BzDS5O1i.js +0 -305
  1826. package/dist/subagent-registry-BIgNPHJQ.js +0 -1753
  1827. package/dist/subagent-registry-an_oHM4b.js +0 -3
  1828. package/dist/subagent-spawn-BKFMuv1y.js +0 -1005
  1829. package/dist/system-cli-IAtoOtwN.js +0 -59
  1830. package/dist/system-prompt-D-MqNnG1.js +0 -640
  1831. package/dist/tables-Bfl7YTbb.js +0 -829
  1832. package/dist/target-id-BbLPfw0-.js +0 -107
  1833. package/dist/targets-DWXe3mQm.js +0 -67
  1834. package/dist/targets-bhZeEbJG.js +0 -207
  1835. package/dist/targets.runtime-By8N_Qv0.js +0 -2
  1836. package/dist/task-executor-CL1pQUmi.js +0 -360
  1837. package/dist/task-owner-access-B2tFCiT1.js +0 -74
  1838. package/dist/task-registry-CGDnoG_A.js +0 -2366
  1839. package/dist/task-registry-delivery-runtime-DOHFM4em.js +0 -3
  1840. package/dist/task-registry-delivery-runtime-DSl-VyA2.js +0 -2
  1841. package/dist/task-registry.maintenance-BJzi71wn.js +0 -416
  1842. package/dist/task-registry.maintenance-BxKAIJuE.js +0 -2
  1843. package/dist/tavily-client-CJtIuNuZ.js +0 -193
  1844. package/dist/tavily-client-cnGyIHjo.js +0 -2
  1845. package/dist/tavily-search-provider-BGV8D2VZ.js +0 -62
  1846. package/dist/telnyx-fGTIDZqb.js +0 -260
  1847. package/dist/testing-CqUqcJNQ.js +0 -575
  1848. package/dist/text-report-Cky4UA35.js +0 -587
  1849. package/dist/text-runtime-BOpYwhuR.js +0 -290
  1850. package/dist/tool-config-shared-C0rslp8t.js +0 -19
  1851. package/dist/tool-policy-pipeline-qhEZzHB-.js +0 -109
  1852. package/dist/tool-resolution-CjbwGHcJ.js +0 -90
  1853. package/dist/tools-effective-inventory-C70Ug651.js +0 -152
  1854. package/dist/tools-invoke-http-DcRsw9EO.js +0 -206
  1855. package/dist/tools.runtime-B-fcXtvL.js +0 -4
  1856. package/dist/transcript-CTF8zJ2t.js +0 -312
  1857. package/dist/transcript-resolve.runtime-C41xgFnA.js +0 -2
  1858. package/dist/transcript.runtime-DNBFm0LS.js +0 -2
  1859. package/dist/transport-policy-Ivm5ArSd.js +0 -75
  1860. package/dist/trash-CVoAJSAx.js +0 -24
  1861. package/dist/tts-B5G7JHka.js +0 -64
  1862. package/dist/tts-CWykD0rc.js +0 -183
  1863. package/dist/tui-cli-CNanJyFI.js +0 -4575
  1864. package/dist/twilio-B-dBW4_4.js +0 -609
  1865. package/dist/typing-policy-CCK9_cHb.js +0 -12
  1866. package/dist/update-cli-D-uofyXb.js +0 -1759
  1867. package/dist/upgrade-gspO3C-l.js +0 -1226
  1868. package/dist/video-generation-provider-BoKNqi7G.js +0 -254
  1869. package/dist/video-generation-provider-C2PI4-Wg.js +0 -271
  1870. package/dist/video-generation-provider-CDTvRCSr.js +0 -287
  1871. package/dist/video-generation-provider-CDxxol9M.js +0 -281
  1872. package/dist/video-generation-provider-CgDT1u2M.js +0 -187
  1873. package/dist/video-generation-provider-CtC5lXew.js +0 -78
  1874. package/dist/video-generation-provider-DTD47wPw.js +0 -118
  1875. package/dist/video-generation-provider-DqaWr1z8.js +0 -264
  1876. package/dist/video-generation-provider-yuS2SQIL.js +0 -221
  1877. package/dist/video-generation-task-status-BFReBMsX.js +0 -163
  1878. package/dist/voice-mapping-D2aNmRet.js +0 -41
  1879. package/dist/wait-for-idle-before-flush-BFfZxSMK.js +0 -5986
  1880. package/dist/web-search-njsvDPGV.js +0 -61
  1881. package/dist/web-search-provider-Bb1jo3tv.js +0 -163
  1882. package/dist/web-search-provider.runtime-B8p_cAp6.js +0 -185
  1883. package/dist/web-search-provider.runtime-xlnZGUCc.js +0 -2
  1884. package/dist/webhook-shared-CZt-kRIg.js +0 -12
  1885. package/dist/wizard-models-YsngRy_Q.js +0 -334
  1886. package/dist/workflow-runtime-Be-w_Xn7.js +0 -485
  1887. package/dist/workspace-run-CHsJxomp.js +0 -70
  1888. package/dist/x-search-config-ikE_9hVQ.js +0 -36
  1889. package/dist/x-search-shared-Cl-mTkkU.js +0 -75
  1890. package/dist/zalo-js-D6IiDKzH.js +0 -1157
@@ -0,0 +1,2366 @@
1
+ import { i as formatErrorMessage } from "./errors-CufR9eHH.js";
2
+ import { c as normalizeOptionalString } from "./string-coerce-DPP_aYVc.js";
3
+ import { t as createSubsystemLogger } from "./subsystem-CNq69MoE.js";
4
+ import { _ as resolveStateDir } from "./paths-Bv2rGpO9.js";
5
+ import { s as parseAgentSessionKey } from "./session-key-utils-DDwuwYKT.js";
6
+ import { s as isDeliverableMessageChannel } from "./message-channel-DGBKBihv.js";
7
+ import { i as normalizeDeliveryContext } from "./delivery-context.shared-XCrZuuA_.js";
8
+ import { l as onAgentEvent } from "./agent-events-ZcJylLt0.js";
9
+ import { t as requireNodeSqlite } from "./node-sqlite-D08uVR9r.js";
10
+ import { n as requestHeartbeatNow } from "./heartbeat-wake-Dc5GUgv8.js";
11
+ import { i as enqueueSystemEvent } from "./system-events-_jEHE6Qp.js";
12
+ import { a as sanitizeTaskStatusText, i as formatTaskStatusTitleText } from "./task-status-DPdgYJLA.js";
13
+ import { createRequire } from "node:module";
14
+ import { chmodSync, existsSync, mkdirSync } from "node:fs";
15
+ import path from "node:path";
16
+ import os from "node:os";
17
+ import crypto from "node:crypto";
18
+ import { isMainThread, threadId } from "node:worker_threads";
19
+ //#region src/tasks/task-executor-policy.ts
20
+ function isTerminalTaskStatus(status) {
21
+ return status === "succeeded" || status === "failed" || status === "timed_out" || status === "cancelled" || status === "lost";
22
+ }
23
+ function resolveTaskDisplayTitle(task) {
24
+ return formatTaskStatusTitleText(task.label?.trim() || (task.runtime === "acp" ? "ACP background task" : task.runtime === "subagent" ? "Subagent task" : task.task.trim() || "Background task"));
25
+ }
26
+ function resolveTaskRunLabel(task) {
27
+ return task.runId ? ` (run ${task.runId.slice(0, 8)})` : "";
28
+ }
29
+ function formatTaskTerminalMessage(task) {
30
+ const title = resolveTaskDisplayTitle(task);
31
+ const runLabel = resolveTaskRunLabel(task);
32
+ const summary = sanitizeTaskStatusText(task.terminalSummary, { errorContext: task.status !== "succeeded" || task.terminalOutcome === "blocked" });
33
+ if (task.status === "succeeded") {
34
+ if (task.terminalOutcome === "blocked") return summary ? `Background task blocked: ${title}${runLabel}. ${summary}` : `Background task blocked: ${title}${runLabel}.`;
35
+ return summary ? `Background task done: ${title}${runLabel}. ${summary}` : `Background task done: ${title}${runLabel}.`;
36
+ }
37
+ if (task.status === "timed_out") return `Background task timed out: ${title}${runLabel}.`;
38
+ if (task.status === "lost") {
39
+ const error = sanitizeTaskStatusText(task.error, { errorContext: true });
40
+ const fallbackSummary = sanitizeTaskStatusText(task.terminalSummary, { errorContext: true });
41
+ return `Background task lost: ${title}${runLabel}. ${error || fallbackSummary || "Backing session disappeared."}`;
42
+ }
43
+ if (task.status === "cancelled") return `Background task cancelled: ${title}${runLabel}.`;
44
+ const error = sanitizeTaskStatusText(task.error, { errorContext: true });
45
+ const fallbackSummary = sanitizeTaskStatusText(task.terminalSummary, { errorContext: true });
46
+ return error ? `Background task failed: ${title}${runLabel}. ${error}` : fallbackSummary ? `Background task failed: ${title}${runLabel}. ${fallbackSummary}` : `Background task failed: ${title}${runLabel}.`;
47
+ }
48
+ function formatTaskBlockedFollowupMessage(task) {
49
+ if (task.status !== "succeeded" || task.terminalOutcome !== "blocked") return null;
50
+ return `Task needs follow-up: ${resolveTaskDisplayTitle(task)}${resolveTaskRunLabel(task)}. ${sanitizeTaskStatusText(task.terminalSummary, { errorContext: true }) || "Task is blocked and needs follow-up."}`;
51
+ }
52
+ function formatTaskStateChangeMessage(task, event) {
53
+ const title = resolveTaskDisplayTitle(task);
54
+ if (event.kind === "running") return `Background task started: ${title}.`;
55
+ if (event.kind === "progress") {
56
+ const summary = sanitizeTaskStatusText(event.summary);
57
+ return summary ? `Background task update: ${title}. ${summary}` : null;
58
+ }
59
+ return null;
60
+ }
61
+ function shouldAutoDeliverTaskTerminalUpdate(task) {
62
+ if (task.notifyPolicy === "silent") return false;
63
+ if (task.runtime === "subagent" && task.status !== "cancelled") return false;
64
+ if (!isTerminalTaskStatus(task.status)) return false;
65
+ return task.deliveryStatus === "pending";
66
+ }
67
+ function shouldAutoDeliverTaskStateChange(task) {
68
+ return task.notifyPolicy === "state_changes" && task.deliveryStatus === "pending" && !isTerminalTaskStatus(task.status);
69
+ }
70
+ function shouldSuppressDuplicateTerminalDelivery(params) {
71
+ if (params.task.runtime !== "acp" || !params.task.runId?.trim()) return false;
72
+ return Boolean(params.preferredTaskId && params.preferredTaskId !== params.task.taskId);
73
+ }
74
+ //#endregion
75
+ //#region src/tasks/task-registry.paths.ts
76
+ function resolveTaskStateDir(env = process.env) {
77
+ if (env.GENESIS_STATE_DIR?.trim()) return resolveStateDir(env);
78
+ if (env.VITEST || env.NODE_ENV === "test") {
79
+ const workerIdRaw = env.VITEST_WORKER_ID ?? env.VITEST_POOL_ID ?? "";
80
+ const workerId = Number.parseInt(workerIdRaw, 10);
81
+ const shardSuffix = Number.isFinite(workerId) ? `${process.pid}-${workerId}` : isMainThread ? String(process.pid) : `${process.pid}-${threadId}`;
82
+ return path.join(os.tmpdir(), "genesis-test-state", shardSuffix);
83
+ }
84
+ return resolveStateDir(env);
85
+ }
86
+ function resolveTaskRegistryDir(env = process.env) {
87
+ return path.join(resolveTaskStateDir(env), "tasks");
88
+ }
89
+ function resolveTaskRegistrySqlitePath(env = process.env) {
90
+ return path.join(resolveTaskRegistryDir(env), "runs.sqlite");
91
+ }
92
+ //#endregion
93
+ //#region src/tasks/task-flow-registry.paths.ts
94
+ function resolveTaskFlowRegistryDir(env = process.env) {
95
+ return path.join(resolveTaskStateDir(env), "flows");
96
+ }
97
+ function resolveTaskFlowRegistrySqlitePath(env = process.env) {
98
+ return path.join(resolveTaskFlowRegistryDir(env), "registry.sqlite");
99
+ }
100
+ //#endregion
101
+ //#region src/tasks/task-flow-registry.store.sqlite.ts
102
+ let cachedDatabase$1 = null;
103
+ const FLOW_REGISTRY_DIR_MODE = 448;
104
+ const FLOW_REGISTRY_FILE_MODE = 384;
105
+ const FLOW_REGISTRY_SIDECAR_SUFFIXES = [
106
+ "",
107
+ "-shm",
108
+ "-wal"
109
+ ];
110
+ function normalizeNumber$1(value) {
111
+ if (typeof value === "bigint") return Number(value);
112
+ return typeof value === "number" ? value : void 0;
113
+ }
114
+ function serializeJson$1(value) {
115
+ return value === void 0 ? null : JSON.stringify(value);
116
+ }
117
+ function parseJsonValue$1(raw) {
118
+ if (!raw?.trim()) return;
119
+ try {
120
+ return JSON.parse(raw);
121
+ } catch {
122
+ return;
123
+ }
124
+ }
125
+ function rowToSyncMode(row) {
126
+ if (row.sync_mode === "task_mirrored" || row.sync_mode === "managed") return row.sync_mode;
127
+ return row.shape === "single_task" ? "task_mirrored" : "managed";
128
+ }
129
+ function rowToFlowRecord(row) {
130
+ const endedAt = normalizeNumber$1(row.ended_at);
131
+ const cancelRequestedAt = normalizeNumber$1(row.cancel_requested_at);
132
+ const requesterOrigin = parseJsonValue$1(row.requester_origin_json);
133
+ const stateJson = parseJsonValue$1(row.state_json);
134
+ const waitJson = parseJsonValue$1(row.wait_json);
135
+ return {
136
+ flowId: row.flow_id,
137
+ syncMode: rowToSyncMode(row),
138
+ ownerKey: row.owner_key,
139
+ ...requesterOrigin ? { requesterOrigin } : {},
140
+ ...row.controller_id ? { controllerId: row.controller_id } : {},
141
+ revision: normalizeNumber$1(row.revision) ?? 0,
142
+ status: row.status,
143
+ notifyPolicy: row.notify_policy,
144
+ goal: row.goal,
145
+ ...row.current_step ? { currentStep: row.current_step } : {},
146
+ ...row.blocked_task_id ? { blockedTaskId: row.blocked_task_id } : {},
147
+ ...row.blocked_summary ? { blockedSummary: row.blocked_summary } : {},
148
+ ...stateJson !== void 0 ? { stateJson } : {},
149
+ ...waitJson !== void 0 ? { waitJson } : {},
150
+ ...cancelRequestedAt != null ? { cancelRequestedAt } : {},
151
+ createdAt: normalizeNumber$1(row.created_at) ?? 0,
152
+ updatedAt: normalizeNumber$1(row.updated_at) ?? 0,
153
+ ...endedAt != null ? { endedAt } : {}
154
+ };
155
+ }
156
+ function bindFlowRecord(record) {
157
+ return {
158
+ flow_id: record.flowId,
159
+ sync_mode: record.syncMode,
160
+ owner_key: record.ownerKey,
161
+ requester_origin_json: serializeJson$1(record.requesterOrigin),
162
+ controller_id: record.controllerId ?? null,
163
+ revision: record.revision,
164
+ status: record.status,
165
+ notify_policy: record.notifyPolicy,
166
+ goal: record.goal,
167
+ current_step: record.currentStep ?? null,
168
+ blocked_task_id: record.blockedTaskId ?? null,
169
+ blocked_summary: record.blockedSummary ?? null,
170
+ state_json: serializeJson$1(record.stateJson),
171
+ wait_json: serializeJson$1(record.waitJson),
172
+ cancel_requested_at: record.cancelRequestedAt ?? null,
173
+ created_at: record.createdAt,
174
+ updated_at: record.updatedAt,
175
+ ended_at: record.endedAt ?? null
176
+ };
177
+ }
178
+ function createStatements$1(db) {
179
+ return {
180
+ selectAll: db.prepare(`
181
+ SELECT
182
+ flow_id,
183
+ sync_mode,
184
+ shape,
185
+ owner_key,
186
+ requester_origin_json,
187
+ controller_id,
188
+ revision,
189
+ status,
190
+ notify_policy,
191
+ goal,
192
+ current_step,
193
+ blocked_task_id,
194
+ blocked_summary,
195
+ state_json,
196
+ wait_json,
197
+ cancel_requested_at,
198
+ created_at,
199
+ updated_at,
200
+ ended_at
201
+ FROM flow_runs
202
+ ORDER BY created_at ASC, flow_id ASC
203
+ `),
204
+ upsertRow: db.prepare(`
205
+ INSERT INTO flow_runs (
206
+ flow_id,
207
+ sync_mode,
208
+ owner_key,
209
+ requester_origin_json,
210
+ controller_id,
211
+ revision,
212
+ status,
213
+ notify_policy,
214
+ goal,
215
+ current_step,
216
+ blocked_task_id,
217
+ blocked_summary,
218
+ state_json,
219
+ wait_json,
220
+ cancel_requested_at,
221
+ created_at,
222
+ updated_at,
223
+ ended_at
224
+ ) VALUES (
225
+ @flow_id,
226
+ @sync_mode,
227
+ @owner_key,
228
+ @requester_origin_json,
229
+ @controller_id,
230
+ @revision,
231
+ @status,
232
+ @notify_policy,
233
+ @goal,
234
+ @current_step,
235
+ @blocked_task_id,
236
+ @blocked_summary,
237
+ @state_json,
238
+ @wait_json,
239
+ @cancel_requested_at,
240
+ @created_at,
241
+ @updated_at,
242
+ @ended_at
243
+ )
244
+ ON CONFLICT(flow_id) DO UPDATE SET
245
+ sync_mode = excluded.sync_mode,
246
+ owner_key = excluded.owner_key,
247
+ requester_origin_json = excluded.requester_origin_json,
248
+ controller_id = excluded.controller_id,
249
+ revision = excluded.revision,
250
+ status = excluded.status,
251
+ notify_policy = excluded.notify_policy,
252
+ goal = excluded.goal,
253
+ current_step = excluded.current_step,
254
+ blocked_task_id = excluded.blocked_task_id,
255
+ blocked_summary = excluded.blocked_summary,
256
+ state_json = excluded.state_json,
257
+ wait_json = excluded.wait_json,
258
+ cancel_requested_at = excluded.cancel_requested_at,
259
+ created_at = excluded.created_at,
260
+ updated_at = excluded.updated_at,
261
+ ended_at = excluded.ended_at
262
+ `),
263
+ deleteRow: db.prepare(`DELETE FROM flow_runs WHERE flow_id = ?`),
264
+ clearRows: db.prepare(`DELETE FROM flow_runs`)
265
+ };
266
+ }
267
+ function hasFlowRunsColumn(db, columnName) {
268
+ return db.prepare(`PRAGMA table_info(flow_runs)`).all().some((row) => row.name === columnName);
269
+ }
270
+ function ensureSchema$1(db) {
271
+ db.exec(`
272
+ CREATE TABLE IF NOT EXISTS flow_runs (
273
+ flow_id TEXT PRIMARY KEY,
274
+ shape TEXT,
275
+ sync_mode TEXT NOT NULL DEFAULT 'managed',
276
+ owner_key TEXT NOT NULL,
277
+ requester_origin_json TEXT,
278
+ controller_id TEXT,
279
+ revision INTEGER NOT NULL DEFAULT 0,
280
+ status TEXT NOT NULL,
281
+ notify_policy TEXT NOT NULL,
282
+ goal TEXT NOT NULL,
283
+ current_step TEXT,
284
+ blocked_task_id TEXT,
285
+ blocked_summary TEXT,
286
+ state_json TEXT,
287
+ wait_json TEXT,
288
+ cancel_requested_at INTEGER,
289
+ created_at INTEGER NOT NULL,
290
+ updated_at INTEGER NOT NULL,
291
+ ended_at INTEGER
292
+ );
293
+ `);
294
+ if (!hasFlowRunsColumn(db, "owner_key") && hasFlowRunsColumn(db, "owner_session_key")) {
295
+ db.exec(`ALTER TABLE flow_runs ADD COLUMN owner_key TEXT;`);
296
+ db.exec(`
297
+ UPDATE flow_runs
298
+ SET owner_key = owner_session_key
299
+ WHERE owner_key IS NULL
300
+ `);
301
+ }
302
+ if (!hasFlowRunsColumn(db, "shape")) db.exec(`ALTER TABLE flow_runs ADD COLUMN shape TEXT;`);
303
+ if (!hasFlowRunsColumn(db, "sync_mode")) {
304
+ db.exec(`ALTER TABLE flow_runs ADD COLUMN sync_mode TEXT;`);
305
+ if (hasFlowRunsColumn(db, "shape")) db.exec(`
306
+ UPDATE flow_runs
307
+ SET sync_mode = CASE
308
+ WHEN shape = 'single_task' THEN 'task_mirrored'
309
+ ELSE 'managed'
310
+ END
311
+ WHERE sync_mode IS NULL
312
+ `);
313
+ else db.exec(`
314
+ UPDATE flow_runs
315
+ SET sync_mode = 'managed'
316
+ WHERE sync_mode IS NULL
317
+ `);
318
+ }
319
+ if (!hasFlowRunsColumn(db, "controller_id")) db.exec(`ALTER TABLE flow_runs ADD COLUMN controller_id TEXT;`);
320
+ db.exec(`
321
+ UPDATE flow_runs
322
+ SET controller_id = 'core/legacy-restored'
323
+ WHERE sync_mode = 'managed'
324
+ AND (controller_id IS NULL OR trim(controller_id) = '')
325
+ `);
326
+ if (!hasFlowRunsColumn(db, "revision")) {
327
+ db.exec(`ALTER TABLE flow_runs ADD COLUMN revision INTEGER;`);
328
+ db.exec(`
329
+ UPDATE flow_runs
330
+ SET revision = 0
331
+ WHERE revision IS NULL
332
+ `);
333
+ }
334
+ if (!hasFlowRunsColumn(db, "blocked_task_id")) db.exec(`ALTER TABLE flow_runs ADD COLUMN blocked_task_id TEXT;`);
335
+ if (!hasFlowRunsColumn(db, "blocked_summary")) db.exec(`ALTER TABLE flow_runs ADD COLUMN blocked_summary TEXT;`);
336
+ if (!hasFlowRunsColumn(db, "state_json")) db.exec(`ALTER TABLE flow_runs ADD COLUMN state_json TEXT;`);
337
+ if (!hasFlowRunsColumn(db, "wait_json")) db.exec(`ALTER TABLE flow_runs ADD COLUMN wait_json TEXT;`);
338
+ if (!hasFlowRunsColumn(db, "cancel_requested_at")) db.exec(`ALTER TABLE flow_runs ADD COLUMN cancel_requested_at INTEGER;`);
339
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_flow_runs_status ON flow_runs(status);`);
340
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_flow_runs_owner_key ON flow_runs(owner_key);`);
341
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_flow_runs_updated_at ON flow_runs(updated_at);`);
342
+ }
343
+ function ensureFlowRegistryPermissions(pathname) {
344
+ const dir = resolveTaskFlowRegistryDir(process.env);
345
+ mkdirSync(dir, {
346
+ recursive: true,
347
+ mode: FLOW_REGISTRY_DIR_MODE
348
+ });
349
+ chmodSync(dir, FLOW_REGISTRY_DIR_MODE);
350
+ for (const suffix of FLOW_REGISTRY_SIDECAR_SUFFIXES) {
351
+ const candidate = `${pathname}${suffix}`;
352
+ if (!existsSync(candidate)) continue;
353
+ chmodSync(candidate, FLOW_REGISTRY_FILE_MODE);
354
+ }
355
+ }
356
+ function openFlowRegistryDatabase() {
357
+ const pathname = resolveTaskFlowRegistrySqlitePath(process.env);
358
+ if (cachedDatabase$1 && cachedDatabase$1.path === pathname) return cachedDatabase$1;
359
+ if (cachedDatabase$1) {
360
+ cachedDatabase$1.db.close();
361
+ cachedDatabase$1 = null;
362
+ }
363
+ ensureFlowRegistryPermissions(pathname);
364
+ const { DatabaseSync } = requireNodeSqlite();
365
+ const db = new DatabaseSync(pathname);
366
+ db.exec(`PRAGMA journal_mode = WAL;`);
367
+ db.exec(`PRAGMA synchronous = NORMAL;`);
368
+ db.exec(`PRAGMA busy_timeout = 5000;`);
369
+ ensureSchema$1(db);
370
+ ensureFlowRegistryPermissions(pathname);
371
+ cachedDatabase$1 = {
372
+ db,
373
+ path: pathname,
374
+ statements: createStatements$1(db)
375
+ };
376
+ return cachedDatabase$1;
377
+ }
378
+ function withWriteTransaction$1(write) {
379
+ const { db, path, statements } = openFlowRegistryDatabase();
380
+ db.exec("BEGIN IMMEDIATE");
381
+ try {
382
+ write(statements);
383
+ db.exec("COMMIT");
384
+ ensureFlowRegistryPermissions(path);
385
+ } catch (error) {
386
+ db.exec("ROLLBACK");
387
+ throw error;
388
+ }
389
+ }
390
+ function loadTaskFlowRegistryStateFromSqlite() {
391
+ const { statements } = openFlowRegistryDatabase();
392
+ const rows = statements.selectAll.all();
393
+ return { flows: new Map(rows.map((row) => [row.flow_id, rowToFlowRecord(row)])) };
394
+ }
395
+ function saveTaskFlowRegistryStateToSqlite(snapshot) {
396
+ withWriteTransaction$1((statements) => {
397
+ statements.clearRows.run();
398
+ for (const flow of snapshot.flows.values()) statements.upsertRow.run(bindFlowRecord(flow));
399
+ });
400
+ }
401
+ function upsertTaskFlowRegistryRecordToSqlite(flow) {
402
+ const store = openFlowRegistryDatabase();
403
+ store.statements.upsertRow.run(bindFlowRecord(flow));
404
+ ensureFlowRegistryPermissions(store.path);
405
+ }
406
+ function deleteTaskFlowRegistryRecordFromSqlite(flowId) {
407
+ const store = openFlowRegistryDatabase();
408
+ store.statements.deleteRow.run(flowId);
409
+ ensureFlowRegistryPermissions(store.path);
410
+ }
411
+ function closeTaskFlowRegistrySqliteStore() {
412
+ if (!cachedDatabase$1) return;
413
+ cachedDatabase$1.db.close();
414
+ cachedDatabase$1 = null;
415
+ }
416
+ let configuredFlowRegistryStore = {
417
+ loadSnapshot: loadTaskFlowRegistryStateFromSqlite,
418
+ saveSnapshot: saveTaskFlowRegistryStateToSqlite,
419
+ upsertFlow: upsertTaskFlowRegistryRecordToSqlite,
420
+ deleteFlow: deleteTaskFlowRegistryRecordFromSqlite,
421
+ close: closeTaskFlowRegistrySqliteStore
422
+ };
423
+ let configuredFlowRegistryObservers = null;
424
+ function getTaskFlowRegistryStore() {
425
+ return configuredFlowRegistryStore;
426
+ }
427
+ function getTaskFlowRegistryObservers() {
428
+ return configuredFlowRegistryObservers;
429
+ }
430
+ //#endregion
431
+ //#region src/tasks/task-flow-registry.ts
432
+ const log$1 = createSubsystemLogger("tasks/task-flow-registry");
433
+ const flows = /* @__PURE__ */ new Map();
434
+ let restoreAttempted$1 = false;
435
+ let restoreFailureMessage = null;
436
+ function cloneStructuredValue(value) {
437
+ if (value === void 0) return;
438
+ return structuredClone(value);
439
+ }
440
+ function cloneFlowRecord(record) {
441
+ return {
442
+ ...record,
443
+ ...record.requesterOrigin ? { requesterOrigin: cloneStructuredValue(record.requesterOrigin) } : {},
444
+ ...record.stateJson !== void 0 ? { stateJson: cloneStructuredValue(record.stateJson) } : {},
445
+ ...record.waitJson !== void 0 ? { waitJson: cloneStructuredValue(record.waitJson) } : {}
446
+ };
447
+ }
448
+ function normalizeRestoredFlowRecord(record) {
449
+ const syncMode = record.syncMode === "task_mirrored" ? "task_mirrored" : "managed";
450
+ const controllerId = syncMode === "managed" ? normalizeOptionalString(record.controllerId) ?? "core/legacy-restored" : void 0;
451
+ return {
452
+ ...record,
453
+ syncMode,
454
+ ownerKey: assertFlowOwnerKey(record.ownerKey),
455
+ ...record.requesterOrigin ? { requesterOrigin: cloneStructuredValue(record.requesterOrigin) } : {},
456
+ ...controllerId ? { controllerId } : {},
457
+ currentStep: normalizeOptionalString(record.currentStep),
458
+ blockedTaskId: normalizeOptionalString(record.blockedTaskId),
459
+ blockedSummary: normalizeOptionalString(record.blockedSummary),
460
+ ...record.stateJson !== void 0 ? { stateJson: cloneStructuredValue(record.stateJson) } : {},
461
+ ...record.waitJson !== void 0 ? { waitJson: cloneStructuredValue(record.waitJson) } : {},
462
+ revision: Math.max(0, record.revision),
463
+ cancelRequestedAt: record.cancelRequestedAt ?? void 0,
464
+ endedAt: record.endedAt ?? void 0
465
+ };
466
+ }
467
+ function snapshotFlowRecords(source) {
468
+ return [...source.values()].map((record) => cloneFlowRecord(record));
469
+ }
470
+ function emitFlowRegistryObserverEvent(createEvent) {
471
+ const observers = getTaskFlowRegistryObservers();
472
+ if (!observers?.onEvent) return;
473
+ try {
474
+ observers.onEvent(createEvent());
475
+ } catch {}
476
+ }
477
+ function ensureNotifyPolicy$1(notifyPolicy) {
478
+ return notifyPolicy ?? "done_only";
479
+ }
480
+ function normalizeJsonBlob(value) {
481
+ return value === void 0 ? void 0 : cloneStructuredValue(value);
482
+ }
483
+ function assertFlowOwnerKey(ownerKey) {
484
+ const normalized = normalizeOptionalString(ownerKey);
485
+ if (!normalized) throw new Error("Flow ownerKey is required.");
486
+ return normalized;
487
+ }
488
+ function assertControllerId(controllerId) {
489
+ const normalized = normalizeOptionalString(controllerId);
490
+ if (!normalized) throw new Error("Managed flow controllerId is required.");
491
+ return normalized;
492
+ }
493
+ function resolveFlowBlockedSummary(task) {
494
+ if (task.status !== "succeeded" || task.terminalOutcome !== "blocked") return;
495
+ return normalizeOptionalString(task.terminalSummary) ?? normalizeOptionalString(task.progressSummary);
496
+ }
497
+ function deriveTaskFlowStatusFromTask(task) {
498
+ if (task.status === "queued") return "queued";
499
+ if (task.status === "running") return "running";
500
+ if (task.status === "succeeded") return task.terminalOutcome === "blocked" ? "blocked" : "succeeded";
501
+ if (task.status === "cancelled") return "cancelled";
502
+ if (task.status === "lost") return "lost";
503
+ return "failed";
504
+ }
505
+ function ensureFlowRegistryReady() {
506
+ if (restoreAttempted$1) return;
507
+ restoreAttempted$1 = true;
508
+ try {
509
+ const restored = getTaskFlowRegistryStore().loadSnapshot();
510
+ flows.clear();
511
+ for (const [flowId, flow] of restored.flows) flows.set(flowId, normalizeRestoredFlowRecord(flow));
512
+ restoreFailureMessage = null;
513
+ } catch (error) {
514
+ flows.clear();
515
+ restoreFailureMessage = formatErrorMessage(error);
516
+ log$1.warn("Failed to restore task-flow registry", { error });
517
+ return;
518
+ }
519
+ emitFlowRegistryObserverEvent(() => ({
520
+ kind: "restored",
521
+ flows: snapshotFlowRecords(flows)
522
+ }));
523
+ }
524
+ function getTaskFlowRegistryRestoreFailure() {
525
+ ensureFlowRegistryReady();
526
+ return restoreFailureMessage;
527
+ }
528
+ function persistFlowRegistry() {
529
+ getTaskFlowRegistryStore().saveSnapshot({ flows: new Map(snapshotFlowRecords(flows).map((flow) => [flow.flowId, flow])) });
530
+ }
531
+ function persistFlowUpsert(flow) {
532
+ const store = getTaskFlowRegistryStore();
533
+ if (store.upsertFlow) {
534
+ store.upsertFlow(cloneFlowRecord(flow));
535
+ return;
536
+ }
537
+ persistFlowRegistry();
538
+ }
539
+ function persistFlowDelete(flowId) {
540
+ const store = getTaskFlowRegistryStore();
541
+ if (store.deleteFlow) {
542
+ store.deleteFlow(flowId);
543
+ return;
544
+ }
545
+ persistFlowRegistry();
546
+ }
547
+ function buildFlowRecord(params) {
548
+ const now = params.createdAt ?? Date.now();
549
+ const syncMode = params.syncMode ?? "managed";
550
+ const controllerId = syncMode === "managed" ? assertControllerId(params.controllerId) : void 0;
551
+ return {
552
+ flowId: crypto.randomUUID(),
553
+ syncMode,
554
+ ownerKey: assertFlowOwnerKey(params.ownerKey),
555
+ ...params.requesterOrigin ? { requesterOrigin: cloneStructuredValue(params.requesterOrigin) } : {},
556
+ ...controllerId ? { controllerId } : {},
557
+ revision: Math.max(0, params.revision ?? 0),
558
+ status: params.status ?? "queued",
559
+ notifyPolicy: ensureNotifyPolicy$1(params.notifyPolicy),
560
+ goal: params.goal,
561
+ currentStep: normalizeOptionalString(params.currentStep),
562
+ blockedTaskId: normalizeOptionalString(params.blockedTaskId),
563
+ blockedSummary: normalizeOptionalString(params.blockedSummary),
564
+ ...normalizeJsonBlob(params.stateJson) !== void 0 ? { stateJson: normalizeJsonBlob(params.stateJson) } : {},
565
+ ...normalizeJsonBlob(params.waitJson) !== void 0 ? { waitJson: normalizeJsonBlob(params.waitJson) } : {},
566
+ ...params.cancelRequestedAt != null ? { cancelRequestedAt: params.cancelRequestedAt } : {},
567
+ createdAt: now,
568
+ updatedAt: params.updatedAt ?? now,
569
+ ...params.endedAt != null ? { endedAt: params.endedAt } : {}
570
+ };
571
+ }
572
+ function applyFlowPatch(current, patch) {
573
+ const controllerId = patch.controllerId === void 0 ? current.controllerId : normalizeOptionalString(patch.controllerId);
574
+ if (current.syncMode === "managed") assertControllerId(controllerId);
575
+ return {
576
+ ...current,
577
+ ...patch.status ? { status: patch.status } : {},
578
+ ...patch.notifyPolicy ? { notifyPolicy: patch.notifyPolicy } : {},
579
+ ...patch.goal ? { goal: patch.goal } : {},
580
+ controllerId,
581
+ currentStep: patch.currentStep === void 0 ? current.currentStep : normalizeOptionalString(patch.currentStep),
582
+ blockedTaskId: patch.blockedTaskId === void 0 ? current.blockedTaskId : normalizeOptionalString(patch.blockedTaskId),
583
+ blockedSummary: patch.blockedSummary === void 0 ? current.blockedSummary : normalizeOptionalString(patch.blockedSummary),
584
+ stateJson: patch.stateJson === void 0 ? current.stateJson : normalizeJsonBlob(patch.stateJson),
585
+ waitJson: patch.waitJson === void 0 ? current.waitJson : normalizeJsonBlob(patch.waitJson),
586
+ cancelRequestedAt: patch.cancelRequestedAt === void 0 ? current.cancelRequestedAt : patch.cancelRequestedAt ?? void 0,
587
+ revision: current.revision + 1,
588
+ updatedAt: patch.updatedAt ?? Date.now(),
589
+ endedAt: patch.endedAt === void 0 ? current.endedAt : patch.endedAt ?? void 0
590
+ };
591
+ }
592
+ function writeFlowRecord(next, previous) {
593
+ flows.set(next.flowId, next);
594
+ persistFlowUpsert(next);
595
+ emitFlowRegistryObserverEvent(() => ({
596
+ kind: "upserted",
597
+ flow: cloneFlowRecord(next),
598
+ ...previous ? { previous: cloneFlowRecord(previous) } : {}
599
+ }));
600
+ return cloneFlowRecord(next);
601
+ }
602
+ function createFlowRecord(params) {
603
+ ensureFlowRegistryReady();
604
+ return writeFlowRecord(buildFlowRecord(params));
605
+ }
606
+ function createManagedTaskFlow(params) {
607
+ return createFlowRecord({
608
+ ...params,
609
+ syncMode: "managed",
610
+ controllerId: assertControllerId(params.controllerId)
611
+ });
612
+ }
613
+ function createTaskFlowForTask(params) {
614
+ const terminalFlowStatus = deriveTaskFlowStatusFromTask(params.task);
615
+ const endedAt = terminalFlowStatus === "succeeded" || terminalFlowStatus === "blocked" || terminalFlowStatus === "failed" || terminalFlowStatus === "cancelled" || terminalFlowStatus === "lost" ? params.task.endedAt ?? params.task.lastEventAt ?? params.task.createdAt : void 0;
616
+ return createFlowRecord({
617
+ syncMode: "task_mirrored",
618
+ ownerKey: params.task.ownerKey,
619
+ requesterOrigin: params.requesterOrigin,
620
+ status: terminalFlowStatus,
621
+ notifyPolicy: params.task.notifyPolicy,
622
+ goal: normalizeOptionalString(params.task.label) ?? (params.task.task.trim() || "Background task"),
623
+ blockedTaskId: terminalFlowStatus === "blocked" ? normalizeOptionalString(params.task.taskId) : void 0,
624
+ blockedSummary: resolveFlowBlockedSummary(params.task),
625
+ createdAt: params.task.createdAt,
626
+ updatedAt: params.task.lastEventAt ?? params.task.createdAt,
627
+ ...endedAt !== void 0 ? { endedAt } : {}
628
+ });
629
+ }
630
+ function updateFlowRecordByIdUnchecked(flowId, patch) {
631
+ ensureFlowRegistryReady();
632
+ const current = flows.get(flowId);
633
+ if (!current) return null;
634
+ return writeFlowRecord(applyFlowPatch(current, patch), current);
635
+ }
636
+ function updateFlowRecordByIdExpectedRevision(params) {
637
+ ensureFlowRegistryReady();
638
+ const current = flows.get(params.flowId);
639
+ if (!current) return {
640
+ applied: false,
641
+ reason: "not_found"
642
+ };
643
+ if (current.revision !== params.expectedRevision) return {
644
+ applied: false,
645
+ reason: "revision_conflict",
646
+ current: cloneFlowRecord(current)
647
+ };
648
+ return {
649
+ applied: true,
650
+ flow: writeFlowRecord(applyFlowPatch(current, params.patch), current)
651
+ };
652
+ }
653
+ function setFlowWaiting(params) {
654
+ return updateFlowRecordByIdExpectedRevision({
655
+ flowId: params.flowId,
656
+ expectedRevision: params.expectedRevision,
657
+ patch: {
658
+ status: normalizeOptionalString(params.blockedTaskId) || normalizeOptionalString(params.blockedSummary) ? "blocked" : "waiting",
659
+ currentStep: params.currentStep,
660
+ stateJson: params.stateJson,
661
+ waitJson: params.waitJson,
662
+ blockedTaskId: params.blockedTaskId,
663
+ blockedSummary: params.blockedSummary,
664
+ endedAt: null,
665
+ updatedAt: params.updatedAt
666
+ }
667
+ });
668
+ }
669
+ function resumeFlow(params) {
670
+ return updateFlowRecordByIdExpectedRevision({
671
+ flowId: params.flowId,
672
+ expectedRevision: params.expectedRevision,
673
+ patch: {
674
+ status: params.status ?? "queued",
675
+ currentStep: params.currentStep,
676
+ stateJson: params.stateJson,
677
+ waitJson: null,
678
+ blockedTaskId: null,
679
+ blockedSummary: null,
680
+ endedAt: null,
681
+ updatedAt: params.updatedAt
682
+ }
683
+ });
684
+ }
685
+ function finishFlow(params) {
686
+ const endedAt = params.endedAt ?? params.updatedAt ?? Date.now();
687
+ return updateFlowRecordByIdExpectedRevision({
688
+ flowId: params.flowId,
689
+ expectedRevision: params.expectedRevision,
690
+ patch: {
691
+ status: "succeeded",
692
+ currentStep: params.currentStep,
693
+ stateJson: params.stateJson,
694
+ waitJson: null,
695
+ blockedTaskId: null,
696
+ blockedSummary: null,
697
+ endedAt,
698
+ updatedAt: params.updatedAt ?? endedAt
699
+ }
700
+ });
701
+ }
702
+ function failFlow(params) {
703
+ const endedAt = params.endedAt ?? params.updatedAt ?? Date.now();
704
+ return updateFlowRecordByIdExpectedRevision({
705
+ flowId: params.flowId,
706
+ expectedRevision: params.expectedRevision,
707
+ patch: {
708
+ status: "failed",
709
+ currentStep: params.currentStep,
710
+ stateJson: params.stateJson,
711
+ waitJson: null,
712
+ blockedTaskId: params.blockedTaskId,
713
+ blockedSummary: params.blockedSummary,
714
+ endedAt,
715
+ updatedAt: params.updatedAt ?? endedAt
716
+ }
717
+ });
718
+ }
719
+ function requestFlowCancel(params) {
720
+ return updateFlowRecordByIdExpectedRevision({
721
+ flowId: params.flowId,
722
+ expectedRevision: params.expectedRevision,
723
+ patch: {
724
+ cancelRequestedAt: params.cancelRequestedAt ?? params.updatedAt ?? Date.now(),
725
+ updatedAt: params.updatedAt
726
+ }
727
+ });
728
+ }
729
+ function syncFlowFromTask(task) {
730
+ const flowId = task.parentFlowId?.trim();
731
+ if (!flowId) return null;
732
+ const flow = getTaskFlowById(flowId);
733
+ if (!flow) return null;
734
+ if (flow.syncMode !== "task_mirrored") return flow;
735
+ const terminalFlowStatus = deriveTaskFlowStatusFromTask(task);
736
+ const isTerminal = terminalFlowStatus === "succeeded" || terminalFlowStatus === "blocked" || terminalFlowStatus === "failed" || terminalFlowStatus === "cancelled" || terminalFlowStatus === "lost";
737
+ return updateFlowRecordByIdUnchecked(flowId, {
738
+ status: terminalFlowStatus,
739
+ notifyPolicy: task.notifyPolicy,
740
+ goal: normalizeOptionalString(task.label) ?? (task.task.trim() || "Background task"),
741
+ blockedTaskId: terminalFlowStatus === "blocked" ? task.taskId.trim() || null : null,
742
+ blockedSummary: terminalFlowStatus === "blocked" ? resolveFlowBlockedSummary(task) ?? null : null,
743
+ waitJson: null,
744
+ updatedAt: task.lastEventAt ?? Date.now(),
745
+ ...isTerminal ? { endedAt: task.endedAt ?? task.lastEventAt ?? Date.now() } : { endedAt: null }
746
+ });
747
+ }
748
+ function getTaskFlowById(flowId) {
749
+ ensureFlowRegistryReady();
750
+ const flow = flows.get(flowId);
751
+ return flow ? cloneFlowRecord(flow) : void 0;
752
+ }
753
+ function listTaskFlowsForOwnerKey(ownerKey) {
754
+ ensureFlowRegistryReady();
755
+ const normalizedOwnerKey = ownerKey.trim();
756
+ if (!normalizedOwnerKey) return [];
757
+ return [...flows.values()].filter((flow) => flow.ownerKey.trim() === normalizedOwnerKey).map((flow) => cloneFlowRecord(flow)).toSorted((left, right) => right.createdAt - left.createdAt);
758
+ }
759
+ function findLatestTaskFlowForOwnerKey(ownerKey) {
760
+ const flow = listTaskFlowsForOwnerKey(ownerKey)[0];
761
+ return flow ? cloneFlowRecord(flow) : void 0;
762
+ }
763
+ function resolveTaskFlowForLookupToken(token) {
764
+ const lookup = token.trim();
765
+ if (!lookup) return;
766
+ return getTaskFlowById(lookup) ?? findLatestTaskFlowForOwnerKey(lookup);
767
+ }
768
+ function listTaskFlowRecords() {
769
+ ensureFlowRegistryReady();
770
+ return [...flows.values()].map((flow) => cloneFlowRecord(flow)).toSorted((left, right) => right.createdAt - left.createdAt);
771
+ }
772
+ function deleteTaskFlowRecordById(flowId) {
773
+ ensureFlowRegistryReady();
774
+ const current = flows.get(flowId);
775
+ if (!current) return false;
776
+ flows.delete(flowId);
777
+ persistFlowDelete(flowId);
778
+ emitFlowRegistryObserverEvent(() => ({
779
+ kind: "deleted",
780
+ flowId,
781
+ previous: cloneFlowRecord(current)
782
+ }));
783
+ return true;
784
+ }
785
+ //#endregion
786
+ //#region src/tasks/task-registry.store.sqlite.ts
787
+ let cachedDatabase = null;
788
+ const TASK_REGISTRY_DIR_MODE = 448;
789
+ const TASK_REGISTRY_FILE_MODE = 384;
790
+ const TASK_REGISTRY_SIDECAR_SUFFIXES = [
791
+ "",
792
+ "-shm",
793
+ "-wal"
794
+ ];
795
+ function normalizeNumber(value) {
796
+ if (typeof value === "bigint") return Number(value);
797
+ return typeof value === "number" ? value : void 0;
798
+ }
799
+ function serializeJson(value) {
800
+ return value == null ? null : JSON.stringify(value);
801
+ }
802
+ function parseJsonValue(raw) {
803
+ if (!raw?.trim()) return;
804
+ try {
805
+ return JSON.parse(raw);
806
+ } catch {
807
+ return;
808
+ }
809
+ }
810
+ function rowToTaskRecord(row) {
811
+ const startedAt = normalizeNumber(row.started_at);
812
+ const endedAt = normalizeNumber(row.ended_at);
813
+ const lastEventAt = normalizeNumber(row.last_event_at);
814
+ const cleanupAfter = normalizeNumber(row.cleanup_after);
815
+ const requesterSessionKey = row.scope_kind === "system" ? "" : row.requester_session_key?.trim() || row.owner_key;
816
+ return {
817
+ taskId: row.task_id,
818
+ runtime: row.runtime,
819
+ ...row.task_kind ? { taskKind: row.task_kind } : {},
820
+ ...row.source_id ? { sourceId: row.source_id } : {},
821
+ requesterSessionKey,
822
+ ownerKey: row.owner_key,
823
+ scopeKind: row.scope_kind,
824
+ ...row.child_session_key ? { childSessionKey: row.child_session_key } : {},
825
+ ...row.parent_flow_id ? { parentFlowId: row.parent_flow_id } : {},
826
+ ...row.parent_task_id ? { parentTaskId: row.parent_task_id } : {},
827
+ ...row.agent_id ? { agentId: row.agent_id } : {},
828
+ ...row.run_id ? { runId: row.run_id } : {},
829
+ ...row.label ? { label: row.label } : {},
830
+ task: row.task,
831
+ status: row.status,
832
+ deliveryStatus: row.delivery_status,
833
+ notifyPolicy: row.notify_policy,
834
+ createdAt: normalizeNumber(row.created_at) ?? 0,
835
+ ...startedAt != null ? { startedAt } : {},
836
+ ...endedAt != null ? { endedAt } : {},
837
+ ...lastEventAt != null ? { lastEventAt } : {},
838
+ ...cleanupAfter != null ? { cleanupAfter } : {},
839
+ ...row.error ? { error: row.error } : {},
840
+ ...row.progress_summary ? { progressSummary: row.progress_summary } : {},
841
+ ...row.terminal_summary ? { terminalSummary: row.terminal_summary } : {},
842
+ ...row.terminal_outcome ? { terminalOutcome: row.terminal_outcome } : {}
843
+ };
844
+ }
845
+ function rowToTaskDeliveryState(row) {
846
+ const requesterOrigin = parseJsonValue(row.requester_origin_json);
847
+ const lastNotifiedEventAt = normalizeNumber(row.last_notified_event_at);
848
+ return {
849
+ taskId: row.task_id,
850
+ ...requesterOrigin ? { requesterOrigin } : {},
851
+ ...lastNotifiedEventAt != null ? { lastNotifiedEventAt } : {}
852
+ };
853
+ }
854
+ function bindTaskRecordBase(record) {
855
+ return {
856
+ task_id: record.taskId,
857
+ runtime: record.runtime,
858
+ task_kind: record.taskKind ?? null,
859
+ source_id: record.sourceId ?? null,
860
+ requester_session_key: record.scopeKind === "system" ? "" : record.requesterSessionKey,
861
+ owner_key: record.ownerKey,
862
+ scope_kind: record.scopeKind,
863
+ child_session_key: record.childSessionKey ?? null,
864
+ parent_flow_id: record.parentFlowId ?? null,
865
+ parent_task_id: record.parentTaskId ?? null,
866
+ agent_id: record.agentId ?? null,
867
+ run_id: record.runId ?? null,
868
+ label: record.label ?? null,
869
+ task: record.task,
870
+ status: record.status,
871
+ delivery_status: record.deliveryStatus,
872
+ notify_policy: record.notifyPolicy,
873
+ created_at: record.createdAt,
874
+ started_at: record.startedAt ?? null,
875
+ ended_at: record.endedAt ?? null,
876
+ last_event_at: record.lastEventAt ?? null,
877
+ cleanup_after: record.cleanupAfter ?? null,
878
+ error: record.error ?? null,
879
+ progress_summary: record.progressSummary ?? null,
880
+ terminal_summary: record.terminalSummary ?? null,
881
+ terminal_outcome: record.terminalOutcome ?? null
882
+ };
883
+ }
884
+ function bindTaskDeliveryState(state) {
885
+ return {
886
+ task_id: state.taskId,
887
+ requester_origin_json: serializeJson(state.requesterOrigin),
888
+ last_notified_event_at: state.lastNotifiedEventAt ?? null
889
+ };
890
+ }
891
+ function createStatements(db) {
892
+ return {
893
+ selectAll: db.prepare(`
894
+ SELECT
895
+ task_id,
896
+ runtime,
897
+ task_kind,
898
+ source_id,
899
+ requester_session_key,
900
+ owner_key,
901
+ scope_kind,
902
+ child_session_key,
903
+ parent_flow_id,
904
+ parent_task_id,
905
+ agent_id,
906
+ run_id,
907
+ label,
908
+ task,
909
+ status,
910
+ delivery_status,
911
+ notify_policy,
912
+ created_at,
913
+ started_at,
914
+ ended_at,
915
+ last_event_at,
916
+ cleanup_after,
917
+ error,
918
+ progress_summary,
919
+ terminal_summary,
920
+ terminal_outcome
921
+ FROM task_runs
922
+ ORDER BY created_at ASC, task_id ASC
923
+ `),
924
+ selectAllDeliveryStates: db.prepare(`
925
+ SELECT
926
+ task_id,
927
+ requester_origin_json,
928
+ last_notified_event_at
929
+ FROM task_delivery_state
930
+ ORDER BY task_id ASC
931
+ `),
932
+ upsertRow: db.prepare(`
933
+ INSERT INTO task_runs (
934
+ task_id,
935
+ runtime,
936
+ task_kind,
937
+ source_id,
938
+ requester_session_key,
939
+ owner_key,
940
+ scope_kind,
941
+ child_session_key,
942
+ parent_flow_id,
943
+ parent_task_id,
944
+ agent_id,
945
+ run_id,
946
+ label,
947
+ task,
948
+ status,
949
+ delivery_status,
950
+ notify_policy,
951
+ created_at,
952
+ started_at,
953
+ ended_at,
954
+ last_event_at,
955
+ cleanup_after,
956
+ error,
957
+ progress_summary,
958
+ terminal_summary,
959
+ terminal_outcome
960
+ ) VALUES (
961
+ @task_id,
962
+ @runtime,
963
+ @task_kind,
964
+ @source_id,
965
+ @requester_session_key,
966
+ @owner_key,
967
+ @scope_kind,
968
+ @child_session_key,
969
+ @parent_flow_id,
970
+ @parent_task_id,
971
+ @agent_id,
972
+ @run_id,
973
+ @label,
974
+ @task,
975
+ @status,
976
+ @delivery_status,
977
+ @notify_policy,
978
+ @created_at,
979
+ @started_at,
980
+ @ended_at,
981
+ @last_event_at,
982
+ @cleanup_after,
983
+ @error,
984
+ @progress_summary,
985
+ @terminal_summary,
986
+ @terminal_outcome
987
+ )
988
+ ON CONFLICT(task_id) DO UPDATE SET
989
+ runtime = excluded.runtime,
990
+ task_kind = excluded.task_kind,
991
+ source_id = excluded.source_id,
992
+ requester_session_key = excluded.requester_session_key,
993
+ owner_key = excluded.owner_key,
994
+ scope_kind = excluded.scope_kind,
995
+ child_session_key = excluded.child_session_key,
996
+ parent_flow_id = excluded.parent_flow_id,
997
+ parent_task_id = excluded.parent_task_id,
998
+ agent_id = excluded.agent_id,
999
+ run_id = excluded.run_id,
1000
+ label = excluded.label,
1001
+ task = excluded.task,
1002
+ status = excluded.status,
1003
+ delivery_status = excluded.delivery_status,
1004
+ notify_policy = excluded.notify_policy,
1005
+ created_at = excluded.created_at,
1006
+ started_at = excluded.started_at,
1007
+ ended_at = excluded.ended_at,
1008
+ last_event_at = excluded.last_event_at,
1009
+ cleanup_after = excluded.cleanup_after,
1010
+ error = excluded.error,
1011
+ progress_summary = excluded.progress_summary,
1012
+ terminal_summary = excluded.terminal_summary,
1013
+ terminal_outcome = excluded.terminal_outcome
1014
+ `),
1015
+ replaceDeliveryState: db.prepare(`
1016
+ INSERT OR REPLACE INTO task_delivery_state (
1017
+ task_id,
1018
+ requester_origin_json,
1019
+ last_notified_event_at
1020
+ ) VALUES (
1021
+ @task_id,
1022
+ @requester_origin_json,
1023
+ @last_notified_event_at
1024
+ )
1025
+ `),
1026
+ deleteRow: db.prepare(`DELETE FROM task_runs WHERE task_id = ?`),
1027
+ deleteDeliveryState: db.prepare(`DELETE FROM task_delivery_state WHERE task_id = ?`),
1028
+ clearRows: db.prepare(`DELETE FROM task_runs`),
1029
+ clearDeliveryStates: db.prepare(`DELETE FROM task_delivery_state`)
1030
+ };
1031
+ }
1032
+ function hasTaskRunsColumn(db, columnName) {
1033
+ return db.prepare(`PRAGMA table_info(task_runs)`).all().some((row) => row.name === columnName);
1034
+ }
1035
+ function migrateLegacyOwnerColumns(db) {
1036
+ if (!hasTaskRunsColumn(db, "owner_key")) db.exec(`ALTER TABLE task_runs ADD COLUMN owner_key TEXT;`);
1037
+ if (!hasTaskRunsColumn(db, "requester_session_key")) db.exec(`ALTER TABLE task_runs ADD COLUMN requester_session_key TEXT;`);
1038
+ if (!hasTaskRunsColumn(db, "scope_kind")) db.exec(`ALTER TABLE task_runs ADD COLUMN scope_kind TEXT NOT NULL DEFAULT 'session';`);
1039
+ if (hasTaskRunsColumn(db, "requester_session_key")) db.exec(`
1040
+ UPDATE task_runs
1041
+ SET owner_key = requester_session_key
1042
+ WHERE owner_key IS NULL
1043
+ `);
1044
+ db.exec(`
1045
+ UPDATE task_runs
1046
+ SET owner_key = CASE
1047
+ WHEN trim(COALESCE(owner_key, '')) <> '' THEN trim(owner_key)
1048
+ ELSE 'system:' || runtime || ':' || COALESCE(NULLIF(source_id, ''), task_id)
1049
+ END
1050
+ `);
1051
+ db.exec(`
1052
+ UPDATE task_runs
1053
+ SET scope_kind = CASE
1054
+ WHEN scope_kind = 'system' THEN 'system'
1055
+ WHEN owner_key LIKE 'system:%' THEN 'system'
1056
+ ELSE 'session'
1057
+ END
1058
+ `);
1059
+ db.exec(`
1060
+ UPDATE task_runs
1061
+ SET requester_session_key = CASE
1062
+ WHEN scope_kind = 'system' THEN ''
1063
+ WHEN trim(COALESCE(requester_session_key, '')) <> '' THEN trim(requester_session_key)
1064
+ ELSE owner_key
1065
+ END
1066
+ `);
1067
+ }
1068
+ function ensureSchema(db) {
1069
+ db.exec(`
1070
+ CREATE TABLE IF NOT EXISTS task_runs (
1071
+ task_id TEXT PRIMARY KEY,
1072
+ runtime TEXT NOT NULL,
1073
+ task_kind TEXT,
1074
+ source_id TEXT,
1075
+ requester_session_key TEXT,
1076
+ owner_key TEXT NOT NULL,
1077
+ scope_kind TEXT NOT NULL,
1078
+ child_session_key TEXT,
1079
+ parent_flow_id TEXT,
1080
+ parent_task_id TEXT,
1081
+ agent_id TEXT,
1082
+ run_id TEXT,
1083
+ label TEXT,
1084
+ task TEXT NOT NULL,
1085
+ status TEXT NOT NULL,
1086
+ delivery_status TEXT NOT NULL,
1087
+ notify_policy TEXT NOT NULL,
1088
+ created_at INTEGER NOT NULL,
1089
+ started_at INTEGER,
1090
+ ended_at INTEGER,
1091
+ last_event_at INTEGER,
1092
+ cleanup_after INTEGER,
1093
+ error TEXT,
1094
+ progress_summary TEXT,
1095
+ terminal_summary TEXT,
1096
+ terminal_outcome TEXT
1097
+ );
1098
+ `);
1099
+ migrateLegacyOwnerColumns(db);
1100
+ if (!hasTaskRunsColumn(db, "task_kind")) db.exec(`ALTER TABLE task_runs ADD COLUMN task_kind TEXT;`);
1101
+ if (!hasTaskRunsColumn(db, "parent_flow_id")) db.exec(`ALTER TABLE task_runs ADD COLUMN parent_flow_id TEXT;`);
1102
+ db.exec(`
1103
+ CREATE TABLE IF NOT EXISTS task_delivery_state (
1104
+ task_id TEXT PRIMARY KEY,
1105
+ requester_origin_json TEXT,
1106
+ last_notified_event_at INTEGER
1107
+ );
1108
+ `);
1109
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_task_runs_run_id ON task_runs(run_id);`);
1110
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_task_runs_status ON task_runs(status);`);
1111
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_task_runs_runtime_status ON task_runs(runtime, status);`);
1112
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_task_runs_cleanup_after ON task_runs(cleanup_after);`);
1113
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_task_runs_last_event_at ON task_runs(last_event_at);`);
1114
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_task_runs_owner_key ON task_runs(owner_key);`);
1115
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_task_runs_parent_flow_id ON task_runs(parent_flow_id);`);
1116
+ db.exec(`CREATE INDEX IF NOT EXISTS idx_task_runs_child_session_key ON task_runs(child_session_key);`);
1117
+ }
1118
+ function ensureTaskRegistryPermissions(pathname) {
1119
+ const dir = resolveTaskRegistryDir(process.env);
1120
+ mkdirSync(dir, {
1121
+ recursive: true,
1122
+ mode: TASK_REGISTRY_DIR_MODE
1123
+ });
1124
+ chmodSync(dir, TASK_REGISTRY_DIR_MODE);
1125
+ for (const suffix of TASK_REGISTRY_SIDECAR_SUFFIXES) {
1126
+ const candidate = `${pathname}${suffix}`;
1127
+ if (!existsSync(candidate)) continue;
1128
+ chmodSync(candidate, TASK_REGISTRY_FILE_MODE);
1129
+ }
1130
+ }
1131
+ function openTaskRegistryDatabase() {
1132
+ const pathname = resolveTaskRegistrySqlitePath(process.env);
1133
+ if (cachedDatabase && cachedDatabase.path === pathname) return cachedDatabase;
1134
+ if (cachedDatabase) {
1135
+ cachedDatabase.db.close();
1136
+ cachedDatabase = null;
1137
+ }
1138
+ ensureTaskRegistryPermissions(pathname);
1139
+ const { DatabaseSync } = requireNodeSqlite();
1140
+ const db = new DatabaseSync(pathname);
1141
+ db.exec(`PRAGMA journal_mode = WAL;`);
1142
+ db.exec(`PRAGMA synchronous = NORMAL;`);
1143
+ db.exec(`PRAGMA busy_timeout = 5000;`);
1144
+ ensureSchema(db);
1145
+ ensureTaskRegistryPermissions(pathname);
1146
+ cachedDatabase = {
1147
+ db,
1148
+ path: pathname,
1149
+ statements: createStatements(db)
1150
+ };
1151
+ return cachedDatabase;
1152
+ }
1153
+ function withWriteTransaction(write) {
1154
+ const { db, path, statements } = openTaskRegistryDatabase();
1155
+ db.exec("BEGIN IMMEDIATE");
1156
+ try {
1157
+ write(statements);
1158
+ db.exec("COMMIT");
1159
+ ensureTaskRegistryPermissions(path);
1160
+ } catch (error) {
1161
+ db.exec("ROLLBACK");
1162
+ throw error;
1163
+ }
1164
+ }
1165
+ function loadTaskRegistryStateFromSqlite() {
1166
+ const { statements } = openTaskRegistryDatabase();
1167
+ const taskRows = statements.selectAll.all();
1168
+ const deliveryRows = statements.selectAllDeliveryStates.all();
1169
+ return {
1170
+ tasks: new Map(taskRows.map((row) => [row.task_id, rowToTaskRecord(row)])),
1171
+ deliveryStates: new Map(deliveryRows.map((row) => [row.task_id, rowToTaskDeliveryState(row)]))
1172
+ };
1173
+ }
1174
+ function saveTaskRegistryStateToSqlite(snapshot) {
1175
+ withWriteTransaction((statements) => {
1176
+ statements.clearDeliveryStates.run();
1177
+ statements.clearRows.run();
1178
+ for (const task of snapshot.tasks.values()) statements.upsertRow.run(bindTaskRecordBase(task));
1179
+ for (const state of snapshot.deliveryStates.values()) statements.replaceDeliveryState.run(bindTaskDeliveryState(state));
1180
+ });
1181
+ }
1182
+ function upsertTaskRegistryRecordToSqlite(task) {
1183
+ openTaskRegistryDatabase().statements.upsertRow.run(bindTaskRecordBase(task));
1184
+ }
1185
+ function upsertTaskWithDeliveryStateToSqlite(params) {
1186
+ withWriteTransaction((statements) => {
1187
+ statements.upsertRow.run(bindTaskRecordBase(params.task));
1188
+ if (params.deliveryState) statements.replaceDeliveryState.run(bindTaskDeliveryState(params.deliveryState));
1189
+ else statements.deleteDeliveryState.run(params.task.taskId);
1190
+ });
1191
+ }
1192
+ function deleteTaskRegistryRecordFromSqlite(taskId) {
1193
+ const store = openTaskRegistryDatabase();
1194
+ store.statements.deleteRow.run(taskId);
1195
+ store.statements.deleteDeliveryState.run(taskId);
1196
+ }
1197
+ function deleteTaskAndDeliveryStateFromSqlite(taskId) {
1198
+ withWriteTransaction((statements) => {
1199
+ statements.deleteRow.run(taskId);
1200
+ statements.deleteDeliveryState.run(taskId);
1201
+ });
1202
+ }
1203
+ function upsertTaskDeliveryStateToSqlite(state) {
1204
+ openTaskRegistryDatabase().statements.replaceDeliveryState.run(bindTaskDeliveryState(state));
1205
+ }
1206
+ function deleteTaskDeliveryStateFromSqlite(taskId) {
1207
+ openTaskRegistryDatabase().statements.deleteDeliveryState.run(taskId);
1208
+ }
1209
+ function closeTaskRegistrySqliteStore() {
1210
+ if (!cachedDatabase) return;
1211
+ cachedDatabase.db.close();
1212
+ cachedDatabase = null;
1213
+ }
1214
+ let configuredTaskRegistryStore = {
1215
+ loadSnapshot: loadTaskRegistryStateFromSqlite,
1216
+ saveSnapshot: saveTaskRegistryStateToSqlite,
1217
+ upsertTaskWithDeliveryState: upsertTaskWithDeliveryStateToSqlite,
1218
+ upsertTask: upsertTaskRegistryRecordToSqlite,
1219
+ deleteTaskWithDeliveryState: deleteTaskAndDeliveryStateFromSqlite,
1220
+ deleteTask: deleteTaskRegistryRecordFromSqlite,
1221
+ upsertDeliveryState: upsertTaskDeliveryStateToSqlite,
1222
+ deleteDeliveryState: deleteTaskDeliveryStateFromSqlite,
1223
+ close: closeTaskRegistrySqliteStore
1224
+ };
1225
+ let configuredTaskRegistryObservers = null;
1226
+ function getTaskRegistryStore() {
1227
+ return configuredTaskRegistryStore;
1228
+ }
1229
+ function getTaskRegistryObservers() {
1230
+ return configuredTaskRegistryObservers;
1231
+ }
1232
+ //#endregion
1233
+ //#region src/tasks/task-registry.ts
1234
+ const log = createSubsystemLogger("tasks/registry");
1235
+ const DEFAULT_TASK_RETENTION_MS = 10080 * 6e4;
1236
+ const tasks = /* @__PURE__ */ new Map();
1237
+ const taskDeliveryStates = /* @__PURE__ */ new Map();
1238
+ const taskIdsByRunId = /* @__PURE__ */ new Map();
1239
+ const taskIdsByOwnerKey = /* @__PURE__ */ new Map();
1240
+ const taskIdsByParentFlowId = /* @__PURE__ */ new Map();
1241
+ const taskIdsByRelatedSessionKey = /* @__PURE__ */ new Map();
1242
+ const tasksWithPendingDelivery = /* @__PURE__ */ new Set();
1243
+ let listenerStarted = false;
1244
+ let restoreAttempted = false;
1245
+ const TASK_REGISTRY_DELIVERY_RUNTIME_OVERRIDE_KEY = Symbol.for("genesis.taskRegistry.deliveryRuntimeOverride");
1246
+ const TASK_REGISTRY_CONTROL_RUNTIME_OVERRIDE_KEY = Symbol.for("genesis.taskRegistry.controlRuntimeOverride");
1247
+ const require = createRequire(import.meta.url);
1248
+ const TASK_REGISTRY_CONTROL_RUNTIME_CANDIDATES = ["./task-registry-control.runtime.js", "./task-registry-control.runtime.ts"];
1249
+ let deliveryRuntimePromise = null;
1250
+ let controlRuntimePromise = null;
1251
+ var ParentFlowLinkError = class extends Error {
1252
+ constructor(code, message, details) {
1253
+ super(message);
1254
+ this.code = code;
1255
+ this.details = details;
1256
+ this.name = "ParentFlowLinkError";
1257
+ }
1258
+ };
1259
+ function isParentFlowLinkError(error) {
1260
+ return error instanceof ParentFlowLinkError;
1261
+ }
1262
+ function isActiveTaskStatus(status) {
1263
+ return status === "queued" || status === "running";
1264
+ }
1265
+ function isTerminalFlowStatus(status) {
1266
+ return status === "succeeded" || status === "failed" || status === "cancelled" || status === "lost";
1267
+ }
1268
+ function assertTaskOwner(params) {
1269
+ if (!params.ownerKey.trim() && params.scopeKind !== "system") throw new Error("Task ownerKey is required.");
1270
+ }
1271
+ function assertParentFlowLinkAllowed(params) {
1272
+ const flowId = params.parentFlowId?.trim();
1273
+ if (!flowId) return;
1274
+ if (params.scopeKind !== "session") throw new ParentFlowLinkError("scope_kind_not_session", "Only session-scoped tasks can link to flows.", { flowId });
1275
+ const flow = getTaskFlowById(flowId);
1276
+ if (!flow) throw new ParentFlowLinkError("parent_flow_not_found", `Parent flow not found: ${flowId}`, { flowId });
1277
+ if (normalizeOptionalString(flow.ownerKey) !== normalizeOptionalString(params.ownerKey)) throw new ParentFlowLinkError("owner_key_mismatch", "Task ownerKey must match parent flow ownerKey.", { flowId });
1278
+ if (flow.cancelRequestedAt != null) throw new ParentFlowLinkError("cancel_requested", "Parent flow cancellation has already been requested.", {
1279
+ flowId,
1280
+ status: flow.status
1281
+ });
1282
+ if (isTerminalFlowStatus(flow.status)) throw new ParentFlowLinkError("terminal", `Parent flow is already ${flow.status}.`, {
1283
+ flowId,
1284
+ status: flow.status
1285
+ });
1286
+ }
1287
+ function cloneTaskRecord(record) {
1288
+ return { ...record };
1289
+ }
1290
+ function cloneTaskDeliveryState(state) {
1291
+ return {
1292
+ ...state,
1293
+ ...state.requesterOrigin ? { requesterOrigin: { ...state.requesterOrigin } } : {}
1294
+ };
1295
+ }
1296
+ function snapshotTaskRecords(source) {
1297
+ return [...source.values()].map((record) => cloneTaskRecord(record));
1298
+ }
1299
+ function emitTaskRegistryObserverEvent(createEvent) {
1300
+ const observers = getTaskRegistryObservers();
1301
+ if (!observers?.onEvent) return;
1302
+ try {
1303
+ observers.onEvent(createEvent());
1304
+ } catch (error) {
1305
+ log.warn("Task registry observer failed", {
1306
+ event: "task-registry",
1307
+ error
1308
+ });
1309
+ }
1310
+ }
1311
+ function persistTaskUpsert(task) {
1312
+ const store = getTaskRegistryStore();
1313
+ const deliveryState = taskDeliveryStates.get(task.taskId);
1314
+ if (store.upsertTaskWithDeliveryState) {
1315
+ store.upsertTaskWithDeliveryState({
1316
+ task,
1317
+ ...deliveryState ? { deliveryState } : {}
1318
+ });
1319
+ return;
1320
+ }
1321
+ if (store.upsertTask) {
1322
+ store.upsertTask(task);
1323
+ return;
1324
+ }
1325
+ store.saveSnapshot({
1326
+ tasks,
1327
+ deliveryStates: taskDeliveryStates
1328
+ });
1329
+ }
1330
+ function persistTaskDelete(taskId) {
1331
+ const store = getTaskRegistryStore();
1332
+ if (store.deleteTaskWithDeliveryState) {
1333
+ store.deleteTaskWithDeliveryState(taskId);
1334
+ return;
1335
+ }
1336
+ if (store.deleteTask) {
1337
+ store.deleteTask(taskId);
1338
+ return;
1339
+ }
1340
+ store.saveSnapshot({
1341
+ tasks,
1342
+ deliveryStates: taskDeliveryStates
1343
+ });
1344
+ }
1345
+ function persistTaskDeliveryStateUpsert(state) {
1346
+ const store = getTaskRegistryStore();
1347
+ if (store.upsertDeliveryState) {
1348
+ store.upsertDeliveryState(state);
1349
+ return;
1350
+ }
1351
+ store.saveSnapshot({
1352
+ tasks,
1353
+ deliveryStates: taskDeliveryStates
1354
+ });
1355
+ }
1356
+ function persistTaskDeliveryStateDelete(taskId) {
1357
+ const store = getTaskRegistryStore();
1358
+ if (store.deleteDeliveryState) {
1359
+ store.deleteDeliveryState(taskId);
1360
+ return;
1361
+ }
1362
+ store.saveSnapshot({
1363
+ tasks,
1364
+ deliveryStates: taskDeliveryStates
1365
+ });
1366
+ }
1367
+ function ensureDeliveryStatus(params) {
1368
+ if (params.scopeKind === "system") return "not_applicable";
1369
+ return params.ownerKey.trim() ? "pending" : "parent_missing";
1370
+ }
1371
+ function ensureNotifyPolicy(params) {
1372
+ if (params.notifyPolicy) return params.notifyPolicy;
1373
+ return (params.deliveryStatus ?? ensureDeliveryStatus({
1374
+ ownerKey: params.ownerKey,
1375
+ scopeKind: params.scopeKind
1376
+ })) === "not_applicable" ? "silent" : "done_only";
1377
+ }
1378
+ function resolveTaskScopeKind(params) {
1379
+ if (params.scopeKind) return params.scopeKind;
1380
+ return params.requesterSessionKey.trim() ? "session" : "system";
1381
+ }
1382
+ function resolveTaskRequesterSessionKey(params) {
1383
+ const requesterSessionKey = params.requesterSessionKey?.trim();
1384
+ if (requesterSessionKey) return requesterSessionKey;
1385
+ if (params.scopeKind === "system") return "";
1386
+ return params.ownerKey?.trim() ?? "";
1387
+ }
1388
+ function resolveTaskOwnerKey(params) {
1389
+ return params.ownerKey?.trim() || params.requesterSessionKey.trim();
1390
+ }
1391
+ function normalizeTaskSummary(value) {
1392
+ return value?.replace(/\s+/g, " ").trim() || void 0;
1393
+ }
1394
+ function normalizeTaskStatus(value) {
1395
+ return value === "running" || value === "queued" || value === "succeeded" || value === "failed" || value === "timed_out" || value === "cancelled" || value === "lost" ? value : "queued";
1396
+ }
1397
+ function normalizeTaskTerminalOutcome(value) {
1398
+ return value === "succeeded" || value === "blocked" ? value : void 0;
1399
+ }
1400
+ function resolveTaskTerminalOutcome(params) {
1401
+ const normalized = normalizeTaskTerminalOutcome(params.terminalOutcome);
1402
+ if (normalized) return normalized;
1403
+ return params.status === "succeeded" ? "succeeded" : void 0;
1404
+ }
1405
+ function appendTaskEvent(event) {
1406
+ const summary = normalizeTaskSummary(event.summary);
1407
+ return {
1408
+ at: event.at,
1409
+ kind: event.kind,
1410
+ ...summary ? { summary } : {}
1411
+ };
1412
+ }
1413
+ function loadTaskRegistryDeliveryRuntime() {
1414
+ const deliveryRuntimeOverride = globalThis[TASK_REGISTRY_DELIVERY_RUNTIME_OVERRIDE_KEY];
1415
+ if (deliveryRuntimeOverride) return Promise.resolve(deliveryRuntimeOverride);
1416
+ deliveryRuntimePromise ??= import("./task-registry-delivery-runtime-F6HIzLFD.js");
1417
+ return deliveryRuntimePromise;
1418
+ }
1419
+ function loadTaskRegistryControlRuntime() {
1420
+ const controlRuntimeOverride = globalThis[TASK_REGISTRY_CONTROL_RUNTIME_OVERRIDE_KEY];
1421
+ if (controlRuntimeOverride) return Promise.resolve(controlRuntimeOverride);
1422
+ controlRuntimePromise ??= Promise.resolve().then(() => {
1423
+ for (const candidate of TASK_REGISTRY_CONTROL_RUNTIME_CANDIDATES) try {
1424
+ return require(candidate);
1425
+ } catch {}
1426
+ throw new Error("Failed to load task registry control runtime.");
1427
+ });
1428
+ return controlRuntimePromise;
1429
+ }
1430
+ function addRunIdIndex(taskId, runId) {
1431
+ const trimmed = runId?.trim();
1432
+ if (!trimmed) return;
1433
+ let ids = taskIdsByRunId.get(trimmed);
1434
+ if (!ids) {
1435
+ ids = /* @__PURE__ */ new Set();
1436
+ taskIdsByRunId.set(trimmed, ids);
1437
+ }
1438
+ ids.add(taskId);
1439
+ }
1440
+ function addIndexedKey(index, key, taskId) {
1441
+ let ids = index.get(key);
1442
+ if (!ids) {
1443
+ ids = /* @__PURE__ */ new Set();
1444
+ index.set(key, ids);
1445
+ }
1446
+ ids.add(taskId);
1447
+ }
1448
+ function deleteIndexedKey(index, key, taskId) {
1449
+ const ids = index.get(key);
1450
+ if (!ids) return;
1451
+ ids.delete(taskId);
1452
+ if (ids.size === 0) index.delete(key);
1453
+ }
1454
+ function getTaskRelatedSessionIndexKeys(task) {
1455
+ return [...new Set([normalizeOptionalString(task.ownerKey), normalizeOptionalString(task.childSessionKey)].filter(Boolean))];
1456
+ }
1457
+ function addOwnerKeyIndex(taskId, task) {
1458
+ const key = normalizeOptionalString(task.ownerKey);
1459
+ if (!key) return;
1460
+ addIndexedKey(taskIdsByOwnerKey, key, taskId);
1461
+ }
1462
+ function deleteOwnerKeyIndex(taskId, task) {
1463
+ const key = normalizeOptionalString(task.ownerKey);
1464
+ if (!key) return;
1465
+ deleteIndexedKey(taskIdsByOwnerKey, key, taskId);
1466
+ }
1467
+ function addParentFlowIdIndex(taskId, task) {
1468
+ const key = task.parentFlowId?.trim();
1469
+ if (!key) return;
1470
+ addIndexedKey(taskIdsByParentFlowId, key, taskId);
1471
+ }
1472
+ function deleteParentFlowIdIndex(taskId, task) {
1473
+ const key = task.parentFlowId?.trim();
1474
+ if (!key) return;
1475
+ deleteIndexedKey(taskIdsByParentFlowId, key, taskId);
1476
+ }
1477
+ function addRelatedSessionKeyIndex(taskId, task) {
1478
+ for (const sessionKey of getTaskRelatedSessionIndexKeys(task)) addIndexedKey(taskIdsByRelatedSessionKey, sessionKey, taskId);
1479
+ }
1480
+ function deleteRelatedSessionKeyIndex(taskId, task) {
1481
+ for (const sessionKey of getTaskRelatedSessionIndexKeys(task)) deleteIndexedKey(taskIdsByRelatedSessionKey, sessionKey, taskId);
1482
+ }
1483
+ function rebuildRunIdIndex() {
1484
+ taskIdsByRunId.clear();
1485
+ for (const [taskId, task] of tasks.entries()) addRunIdIndex(taskId, task.runId);
1486
+ }
1487
+ function rebuildOwnerKeyIndex() {
1488
+ taskIdsByOwnerKey.clear();
1489
+ for (const [taskId, task] of tasks.entries()) addOwnerKeyIndex(taskId, task);
1490
+ }
1491
+ function rebuildParentFlowIdIndex() {
1492
+ taskIdsByParentFlowId.clear();
1493
+ for (const [taskId, task] of tasks.entries()) addParentFlowIdIndex(taskId, task);
1494
+ }
1495
+ function rebuildRelatedSessionKeyIndex() {
1496
+ taskIdsByRelatedSessionKey.clear();
1497
+ for (const [taskId, task] of tasks.entries()) addRelatedSessionKeyIndex(taskId, task);
1498
+ }
1499
+ function getTasksByRunId(runId) {
1500
+ const ids = taskIdsByRunId.get(runId.trim());
1501
+ if (!ids || ids.size === 0) return [];
1502
+ return [...ids].map((taskId) => tasks.get(taskId)).filter((task) => Boolean(task));
1503
+ }
1504
+ function taskRunScopeKey(task) {
1505
+ return [
1506
+ task.runtime,
1507
+ task.scopeKind,
1508
+ normalizeOptionalString(task.ownerKey) ?? "",
1509
+ normalizeOptionalString(task.childSessionKey) ?? ""
1510
+ ].join("\0");
1511
+ }
1512
+ function getTasksByRunScope(params) {
1513
+ const matches = getTasksByRunId(params.runId).filter((task) => !params.runtime || task.runtime === params.runtime);
1514
+ const sessionKey = normalizeOptionalString(params.sessionKey);
1515
+ if (sessionKey) {
1516
+ const childMatches = matches.filter((task) => normalizeOptionalString(task.childSessionKey) === sessionKey);
1517
+ if (childMatches.length > 0) return childMatches;
1518
+ return matches.filter((task) => task.scopeKind === "session" && normalizeOptionalString(task.ownerKey) === sessionKey);
1519
+ }
1520
+ return new Set(matches.map((task) => taskRunScopeKey(task))).size <= 1 ? matches : [];
1521
+ }
1522
+ function getPeerTasksForDelivery(task) {
1523
+ if (!task.runId?.trim()) return [];
1524
+ return getTasksByRunId(task.runId).filter((candidate) => candidate.runtime === task.runtime && candidate.scopeKind === task.scopeKind && (normalizeOptionalString(candidate.ownerKey) ?? "") === (normalizeOptionalString(task.ownerKey) ?? "") && (normalizeOptionalString(candidate.childSessionKey) ?? "") === (normalizeOptionalString(task.childSessionKey) ?? ""));
1525
+ }
1526
+ function taskLookupPriority(task) {
1527
+ return task.runtime === "cli" ? 1 : 0;
1528
+ }
1529
+ function pickPreferredRunIdTask(matches) {
1530
+ return [...matches].toSorted((left, right) => {
1531
+ const priorityDiff = taskLookupPriority(left) - taskLookupPriority(right);
1532
+ if (priorityDiff !== 0) return priorityDiff;
1533
+ return left.createdAt - right.createdAt;
1534
+ })[0];
1535
+ }
1536
+ function compareTasksNewestFirst(left, right) {
1537
+ const createdAtDiff = right.createdAt - left.createdAt;
1538
+ if (createdAtDiff !== 0) return createdAtDiff;
1539
+ return (right.insertionIndex ?? 0) - (left.insertionIndex ?? 0);
1540
+ }
1541
+ function findExistingTaskForCreate(params) {
1542
+ const runId = params.runId?.trim();
1543
+ const runScopeMatches = runId ? getTasksByRunId(runId).filter((task) => task.runtime === params.runtime && task.scopeKind === params.scopeKind && (normalizeOptionalString(task.ownerKey) ?? "") === (normalizeOptionalString(params.ownerKey) ?? "") && (normalizeOptionalString(task.childSessionKey) ?? "") === (normalizeOptionalString(params.childSessionKey) ?? "") && (normalizeOptionalString(task.parentFlowId) ?? "") === (normalizeOptionalString(params.parentFlowId) ?? "")) : [];
1544
+ const exact = runId ? runScopeMatches.find((task) => (normalizeOptionalString(task.label) ?? "") === (normalizeOptionalString(params.label) ?? "") && (normalizeOptionalString(task.task) ?? "") === (normalizeOptionalString(params.task) ?? "")) : void 0;
1545
+ if (exact) return exact;
1546
+ if (!runId || params.runtime !== "acp") return;
1547
+ if (runScopeMatches.length === 0) return;
1548
+ return pickPreferredRunIdTask(runScopeMatches);
1549
+ }
1550
+ function mergeExistingTaskForCreate(existing, params) {
1551
+ const patch = {};
1552
+ const requesterOrigin = normalizeDeliveryContext(params.requesterOrigin);
1553
+ const currentDeliveryState = taskDeliveryStates.get(existing.taskId);
1554
+ if (requesterOrigin && !currentDeliveryState?.requesterOrigin) upsertTaskDeliveryState({
1555
+ taskId: existing.taskId,
1556
+ requesterOrigin,
1557
+ lastNotifiedEventAt: currentDeliveryState?.lastNotifiedEventAt
1558
+ });
1559
+ if (params.sourceId?.trim() && !existing.sourceId?.trim()) patch.sourceId = params.sourceId.trim();
1560
+ if (params.taskKind?.trim() && !existing.taskKind?.trim()) patch.taskKind = params.taskKind.trim();
1561
+ if (params.parentFlowId?.trim() && !existing.parentFlowId?.trim()) {
1562
+ assertParentFlowLinkAllowed({
1563
+ ownerKey: existing.ownerKey,
1564
+ scopeKind: existing.scopeKind,
1565
+ parentFlowId: params.parentFlowId
1566
+ });
1567
+ patch.parentFlowId = params.parentFlowId.trim();
1568
+ }
1569
+ if (params.parentTaskId?.trim() && !existing.parentTaskId?.trim()) patch.parentTaskId = params.parentTaskId.trim();
1570
+ if (params.agentId?.trim() && !existing.agentId?.trim()) patch.agentId = params.agentId.trim();
1571
+ const nextLabel = params.label?.trim();
1572
+ if (params.preferMetadata) {
1573
+ if (nextLabel && (normalizeOptionalString(existing.label) ?? "") !== nextLabel) patch.label = nextLabel;
1574
+ const nextTask = params.task.trim();
1575
+ if (nextTask && (normalizeOptionalString(existing.task) ?? "") !== nextTask) patch.task = nextTask;
1576
+ } else if (nextLabel && !existing.label?.trim()) patch.label = nextLabel;
1577
+ if (params.deliveryStatus === "pending" && existing.deliveryStatus !== "delivered") patch.deliveryStatus = "pending";
1578
+ const notifyPolicy = ensureNotifyPolicy({
1579
+ notifyPolicy: params.notifyPolicy,
1580
+ deliveryStatus: params.deliveryStatus,
1581
+ ownerKey: existing.ownerKey,
1582
+ scopeKind: existing.scopeKind
1583
+ });
1584
+ if (notifyPolicy !== existing.notifyPolicy && existing.notifyPolicy === "silent") patch.notifyPolicy = notifyPolicy;
1585
+ if (Object.keys(patch).length === 0) return cloneTaskRecord(existing);
1586
+ return updateTask(existing.taskId, patch) ?? cloneTaskRecord(existing);
1587
+ }
1588
+ function taskTerminalDeliveryIdempotencyKey(task) {
1589
+ const outcome = task.status === "succeeded" ? task.terminalOutcome ?? "default" : "default";
1590
+ return `task-terminal:${task.taskId}:${task.status}:${outcome}`;
1591
+ }
1592
+ function resolveTaskStateChangeIdempotencyKey(params) {
1593
+ if (params.owner.flowId) return `flow-event:${params.owner.flowId}:${params.task.taskId}:${params.latestEvent.at}:${params.latestEvent.kind}`;
1594
+ return `task-event:${params.task.taskId}:${params.latestEvent.at}:${params.latestEvent.kind}`;
1595
+ }
1596
+ function resolveTaskTerminalIdempotencyKey(task) {
1597
+ const owner = resolveTaskDeliveryOwner(task);
1598
+ if (owner.flowId) {
1599
+ const outcome = task.status === "succeeded" ? task.terminalOutcome ?? "default" : "default";
1600
+ return `flow-terminal:${owner.flowId}:${task.taskId}:${task.status}:${outcome}`;
1601
+ }
1602
+ return taskTerminalDeliveryIdempotencyKey(task);
1603
+ }
1604
+ function getLinkedFlowForDelivery(task) {
1605
+ const flowId = task.parentFlowId?.trim();
1606
+ if (!flowId || task.scopeKind !== "session") return;
1607
+ const flow = getTaskFlowById(flowId);
1608
+ if (!flow) return;
1609
+ if (normalizeOptionalString(flow.ownerKey) !== normalizeOptionalString(task.ownerKey)) return;
1610
+ return flow;
1611
+ }
1612
+ function resolveTaskDeliveryOwner(task) {
1613
+ const flow = getLinkedFlowForDelivery(task);
1614
+ if (flow) return {
1615
+ sessionKey: flow.ownerKey.trim(),
1616
+ requesterOrigin: normalizeDeliveryContext(flow.requesterOrigin ?? taskDeliveryStates.get(task.taskId)?.requesterOrigin),
1617
+ flowId: flow.flowId
1618
+ };
1619
+ if (task.scopeKind !== "session") return {};
1620
+ return {
1621
+ sessionKey: task.ownerKey.trim(),
1622
+ requesterOrigin: normalizeDeliveryContext(taskDeliveryStates.get(task.taskId)?.requesterOrigin)
1623
+ };
1624
+ }
1625
+ function syncManagedFlowCancellationFromTask(task) {
1626
+ const flowId = task.parentFlowId?.trim();
1627
+ if (!flowId) return;
1628
+ let flow = getTaskFlowById(flowId);
1629
+ if (!flow || flow.syncMode !== "managed" || flow.cancelRequestedAt == null || isTerminalFlowStatus(flow.status)) return;
1630
+ if (listTasksForFlowId(flowId).some((candidate) => isActiveTaskStatus(candidate.status))) return;
1631
+ const endedAt = task.endedAt ?? task.lastEventAt ?? Date.now();
1632
+ for (let attempt = 0; attempt < 2; attempt += 1) {
1633
+ const result = updateFlowRecordByIdExpectedRevision({
1634
+ flowId,
1635
+ expectedRevision: flow.revision,
1636
+ patch: {
1637
+ status: "cancelled",
1638
+ blockedTaskId: null,
1639
+ blockedSummary: null,
1640
+ waitJson: null,
1641
+ endedAt,
1642
+ updatedAt: endedAt
1643
+ }
1644
+ });
1645
+ if (result.applied || result.reason === "not_found") return;
1646
+ flow = result.current;
1647
+ if (!flow || flow.syncMode !== "managed" || flow.cancelRequestedAt == null || isTerminalFlowStatus(flow.status)) return;
1648
+ if (listTasksForFlowId(flowId).some((candidate) => isActiveTaskStatus(candidate.status))) return;
1649
+ }
1650
+ }
1651
+ function restoreTaskRegistryOnce() {
1652
+ if (restoreAttempted) return;
1653
+ restoreAttempted = true;
1654
+ try {
1655
+ const restored = getTaskRegistryStore().loadSnapshot();
1656
+ if (restored.tasks.size === 0 && restored.deliveryStates.size === 0) return;
1657
+ for (const [taskId, task] of restored.tasks.entries()) tasks.set(taskId, task);
1658
+ for (const [taskId, state] of restored.deliveryStates.entries()) taskDeliveryStates.set(taskId, state);
1659
+ rebuildRunIdIndex();
1660
+ rebuildOwnerKeyIndex();
1661
+ rebuildParentFlowIdIndex();
1662
+ rebuildRelatedSessionKeyIndex();
1663
+ emitTaskRegistryObserverEvent(() => ({
1664
+ kind: "restored",
1665
+ tasks: snapshotTaskRecords(tasks)
1666
+ }));
1667
+ } catch (error) {
1668
+ log.warn("Failed to restore task registry", { error });
1669
+ }
1670
+ }
1671
+ function ensureTaskRegistryReady() {
1672
+ restoreTaskRegistryOnce();
1673
+ ensureListener();
1674
+ }
1675
+ function updateTask(taskId, patch) {
1676
+ const current = tasks.get(taskId);
1677
+ if (!current) return null;
1678
+ const next = {
1679
+ ...current,
1680
+ ...patch
1681
+ };
1682
+ if (isTerminalTaskStatus(next.status) && typeof next.cleanupAfter !== "number") next.cleanupAfter = (next.endedAt ?? next.lastEventAt ?? Date.now()) + DEFAULT_TASK_RETENTION_MS;
1683
+ const sessionIndexChanged = normalizeOptionalString(current.ownerKey) !== normalizeOptionalString(next.ownerKey) || normalizeOptionalString(current.childSessionKey) !== normalizeOptionalString(next.childSessionKey);
1684
+ const parentFlowIndexChanged = current.parentFlowId?.trim() !== next.parentFlowId?.trim();
1685
+ tasks.set(taskId, next);
1686
+ if (patch.runId && patch.runId !== current.runId) rebuildRunIdIndex();
1687
+ if (sessionIndexChanged) {
1688
+ deleteOwnerKeyIndex(taskId, current);
1689
+ addOwnerKeyIndex(taskId, next);
1690
+ deleteRelatedSessionKeyIndex(taskId, current);
1691
+ addRelatedSessionKeyIndex(taskId, next);
1692
+ }
1693
+ if (parentFlowIndexChanged) {
1694
+ deleteParentFlowIdIndex(taskId, current);
1695
+ addParentFlowIdIndex(taskId, next);
1696
+ }
1697
+ persistTaskUpsert(next);
1698
+ try {
1699
+ syncFlowFromTask(next);
1700
+ } catch (error) {
1701
+ log.warn("Failed to sync parent flow from task update", {
1702
+ taskId,
1703
+ flowId: next.parentFlowId,
1704
+ error
1705
+ });
1706
+ }
1707
+ try {
1708
+ syncManagedFlowCancellationFromTask(next);
1709
+ } catch (error) {
1710
+ log.warn("Failed to finalize managed flow cancellation from task update", {
1711
+ taskId,
1712
+ flowId: next.parentFlowId,
1713
+ error
1714
+ });
1715
+ }
1716
+ emitTaskRegistryObserverEvent(() => ({
1717
+ kind: "upserted",
1718
+ task: cloneTaskRecord(next),
1719
+ previous: cloneTaskRecord(current)
1720
+ }));
1721
+ return cloneTaskRecord(next);
1722
+ }
1723
+ function upsertTaskDeliveryState(state) {
1724
+ const current = taskDeliveryStates.get(state.taskId);
1725
+ const next = {
1726
+ taskId: state.taskId,
1727
+ ...state.requesterOrigin ? { requesterOrigin: normalizeDeliveryContext(state.requesterOrigin) } : {},
1728
+ ...state.lastNotifiedEventAt != null ? { lastNotifiedEventAt: state.lastNotifiedEventAt } : {}
1729
+ };
1730
+ if (!next.requesterOrigin && typeof next.lastNotifiedEventAt !== "number" && !current) return cloneTaskDeliveryState({ taskId: state.taskId });
1731
+ taskDeliveryStates.set(state.taskId, next);
1732
+ persistTaskDeliveryStateUpsert(next);
1733
+ return cloneTaskDeliveryState(next);
1734
+ }
1735
+ function getTaskDeliveryState(taskId) {
1736
+ const state = taskDeliveryStates.get(taskId);
1737
+ return state ? cloneTaskDeliveryState(state) : void 0;
1738
+ }
1739
+ function canDeliverTaskToRequesterOrigin(task) {
1740
+ const origin = resolveTaskDeliveryOwner(task).requesterOrigin;
1741
+ const channel = origin?.channel?.trim();
1742
+ const to = origin?.to?.trim();
1743
+ return Boolean(channel && to && isDeliverableMessageChannel(channel));
1744
+ }
1745
+ function resolveMissingOwnerDeliveryStatus(task) {
1746
+ return task.scopeKind === "system" ? "not_applicable" : "parent_missing";
1747
+ }
1748
+ function queueTaskSystemEvent(task, text) {
1749
+ const owner = resolveTaskDeliveryOwner(task);
1750
+ const ownerKey = owner.sessionKey?.trim();
1751
+ if (!ownerKey) return false;
1752
+ enqueueSystemEvent(text, {
1753
+ sessionKey: ownerKey,
1754
+ contextKey: `task:${task.taskId}`,
1755
+ deliveryContext: owner.requesterOrigin
1756
+ });
1757
+ requestHeartbeatNow({
1758
+ reason: "background-task",
1759
+ sessionKey: ownerKey
1760
+ });
1761
+ return true;
1762
+ }
1763
+ function queueBlockedTaskFollowup(task) {
1764
+ const followupText = formatTaskBlockedFollowupMessage(task);
1765
+ if (!followupText) return false;
1766
+ const owner = resolveTaskDeliveryOwner(task);
1767
+ const ownerKey = owner.sessionKey?.trim();
1768
+ if (!ownerKey) return false;
1769
+ enqueueSystemEvent(followupText, {
1770
+ sessionKey: ownerKey,
1771
+ contextKey: `task:${task.taskId}:blocked-followup`,
1772
+ deliveryContext: owner.requesterOrigin
1773
+ });
1774
+ requestHeartbeatNow({
1775
+ reason: "background-task-blocked",
1776
+ sessionKey: ownerKey
1777
+ });
1778
+ return true;
1779
+ }
1780
+ async function maybeDeliverTaskTerminalUpdate(taskId) {
1781
+ ensureTaskRegistryReady();
1782
+ const current = tasks.get(taskId);
1783
+ if (!current || !shouldAutoDeliverTaskTerminalUpdate(current)) return current ? cloneTaskRecord(current) : null;
1784
+ if (tasksWithPendingDelivery.has(taskId)) return cloneTaskRecord(current);
1785
+ tasksWithPendingDelivery.add(taskId);
1786
+ try {
1787
+ const latest = tasks.get(taskId);
1788
+ if (!latest || !shouldAutoDeliverTaskTerminalUpdate(latest)) return latest ? cloneTaskRecord(latest) : null;
1789
+ if (shouldSuppressDuplicateTerminalDelivery({
1790
+ task: latest,
1791
+ preferredTaskId: (latest.runId ? pickPreferredRunIdTask(getPeerTasksForDelivery(latest)) : void 0)?.taskId
1792
+ })) return updateTask(taskId, {
1793
+ deliveryStatus: "not_applicable",
1794
+ lastEventAt: Date.now()
1795
+ });
1796
+ const owner = resolveTaskDeliveryOwner(latest);
1797
+ const ownerSessionKey = owner.sessionKey?.trim();
1798
+ if (!ownerSessionKey) return updateTask(taskId, {
1799
+ deliveryStatus: resolveMissingOwnerDeliveryStatus(latest),
1800
+ lastEventAt: Date.now()
1801
+ });
1802
+ const eventText = formatTaskTerminalMessage(latest);
1803
+ if (!canDeliverTaskToRequesterOrigin(latest)) try {
1804
+ queueTaskSystemEvent(latest, eventText);
1805
+ if (latest.terminalOutcome === "blocked") queueBlockedTaskFollowup(latest);
1806
+ return updateTask(taskId, {
1807
+ deliveryStatus: "session_queued",
1808
+ lastEventAt: Date.now()
1809
+ });
1810
+ } catch (error) {
1811
+ log.warn("Failed to queue background task session delivery", {
1812
+ taskId,
1813
+ ownerKey: latest.ownerKey,
1814
+ error
1815
+ });
1816
+ return updateTask(taskId, {
1817
+ deliveryStatus: "failed",
1818
+ lastEventAt: Date.now()
1819
+ });
1820
+ }
1821
+ try {
1822
+ const { sendMessage } = await loadTaskRegistryDeliveryRuntime();
1823
+ const requesterAgentId = parseAgentSessionKey(ownerSessionKey)?.agentId;
1824
+ const idempotencyKey = resolveTaskTerminalIdempotencyKey(latest);
1825
+ await sendMessage({
1826
+ channel: owner.requesterOrigin?.channel,
1827
+ to: owner.requesterOrigin?.to ?? "",
1828
+ accountId: owner.requesterOrigin?.accountId,
1829
+ threadId: owner.requesterOrigin?.threadId,
1830
+ content: eventText,
1831
+ agentId: requesterAgentId,
1832
+ idempotencyKey,
1833
+ mirror: {
1834
+ sessionKey: ownerSessionKey,
1835
+ agentId: requesterAgentId,
1836
+ idempotencyKey
1837
+ }
1838
+ });
1839
+ if (latest.terminalOutcome === "blocked") queueBlockedTaskFollowup(latest);
1840
+ return updateTask(taskId, {
1841
+ deliveryStatus: "delivered",
1842
+ lastEventAt: Date.now()
1843
+ });
1844
+ } catch (error) {
1845
+ log.warn("Failed to deliver background task update", {
1846
+ taskId,
1847
+ ownerKey: ownerSessionKey,
1848
+ requesterOrigin: owner.requesterOrigin,
1849
+ error
1850
+ });
1851
+ try {
1852
+ queueTaskSystemEvent(latest, eventText);
1853
+ if (latest.terminalOutcome === "blocked") queueBlockedTaskFollowup(latest);
1854
+ } catch (fallbackError) {
1855
+ log.warn("Failed to queue background task fallback event", {
1856
+ taskId,
1857
+ ownerKey: latest.ownerKey,
1858
+ error: fallbackError
1859
+ });
1860
+ }
1861
+ return updateTask(taskId, {
1862
+ deliveryStatus: "failed",
1863
+ lastEventAt: Date.now()
1864
+ });
1865
+ }
1866
+ } finally {
1867
+ tasksWithPendingDelivery.delete(taskId);
1868
+ }
1869
+ }
1870
+ async function maybeDeliverTaskStateChangeUpdate(taskId, latestEvent) {
1871
+ ensureTaskRegistryReady();
1872
+ const current = tasks.get(taskId);
1873
+ if (!current || !shouldAutoDeliverTaskStateChange(current)) return current ? cloneTaskRecord(current) : null;
1874
+ const deliveryState = getTaskDeliveryState(taskId);
1875
+ if (!latestEvent || (deliveryState?.lastNotifiedEventAt ?? 0) >= latestEvent.at) return cloneTaskRecord(current);
1876
+ const eventText = formatTaskStateChangeMessage(current, latestEvent);
1877
+ if (!eventText) return cloneTaskRecord(current);
1878
+ try {
1879
+ const owner = resolveTaskDeliveryOwner(current);
1880
+ const ownerSessionKey = owner.sessionKey?.trim();
1881
+ if (!ownerSessionKey) return updateTask(taskId, {
1882
+ deliveryStatus: resolveMissingOwnerDeliveryStatus(current),
1883
+ lastEventAt: Date.now()
1884
+ });
1885
+ if (!canDeliverTaskToRequesterOrigin(current)) {
1886
+ queueTaskSystemEvent(current, eventText);
1887
+ upsertTaskDeliveryState({
1888
+ taskId,
1889
+ requesterOrigin: deliveryState?.requesterOrigin,
1890
+ lastNotifiedEventAt: latestEvent.at
1891
+ });
1892
+ return updateTask(taskId, { lastEventAt: Date.now() });
1893
+ }
1894
+ const { sendMessage } = await loadTaskRegistryDeliveryRuntime();
1895
+ const requesterAgentId = parseAgentSessionKey(ownerSessionKey)?.agentId;
1896
+ const idempotencyKey = resolveTaskStateChangeIdempotencyKey({
1897
+ task: current,
1898
+ latestEvent,
1899
+ owner
1900
+ });
1901
+ await sendMessage({
1902
+ channel: owner.requesterOrigin?.channel,
1903
+ to: owner.requesterOrigin?.to ?? "",
1904
+ accountId: owner.requesterOrigin?.accountId,
1905
+ threadId: owner.requesterOrigin?.threadId,
1906
+ content: eventText,
1907
+ agentId: requesterAgentId,
1908
+ idempotencyKey,
1909
+ mirror: {
1910
+ sessionKey: ownerSessionKey,
1911
+ agentId: requesterAgentId,
1912
+ idempotencyKey
1913
+ }
1914
+ });
1915
+ upsertTaskDeliveryState({
1916
+ taskId,
1917
+ requesterOrigin: deliveryState?.requesterOrigin,
1918
+ lastNotifiedEventAt: latestEvent.at
1919
+ });
1920
+ return updateTask(taskId, { lastEventAt: Date.now() });
1921
+ } catch (error) {
1922
+ log.warn("Failed to deliver background task state change", {
1923
+ taskId,
1924
+ ownerKey: current.ownerKey,
1925
+ error
1926
+ });
1927
+ return cloneTaskRecord(current);
1928
+ }
1929
+ }
1930
+ function setTaskCleanupAfterById(params) {
1931
+ ensureTaskRegistryReady();
1932
+ return updateTask(params.taskId, { cleanupAfter: params.cleanupAfter });
1933
+ }
1934
+ function markTaskTerminalById(params) {
1935
+ ensureTaskRegistryReady();
1936
+ return updateTask(params.taskId, {
1937
+ status: params.status,
1938
+ endedAt: params.endedAt,
1939
+ lastEventAt: params.lastEventAt ?? params.endedAt,
1940
+ ...params.error !== void 0 ? { error: params.error } : {},
1941
+ ...params.terminalSummary !== void 0 ? { terminalSummary: normalizeTaskSummary(params.terminalSummary) } : {},
1942
+ ...params.terminalOutcome !== void 0 ? { terminalOutcome: resolveTaskTerminalOutcome({
1943
+ status: params.status,
1944
+ terminalOutcome: params.terminalOutcome
1945
+ }) } : {}
1946
+ });
1947
+ }
1948
+ function markTaskLostById(params) {
1949
+ ensureTaskRegistryReady();
1950
+ return updateTask(params.taskId, {
1951
+ status: "lost",
1952
+ endedAt: params.endedAt,
1953
+ lastEventAt: params.lastEventAt ?? params.endedAt,
1954
+ ...params.error !== void 0 ? { error: params.error } : {},
1955
+ ...params.cleanupAfter !== void 0 ? { cleanupAfter: params.cleanupAfter } : {}
1956
+ });
1957
+ }
1958
+ function updateTasksByRunId(params) {
1959
+ const matches = getTasksByRunScope(params);
1960
+ if (matches.length === 0) return [];
1961
+ const updated = [];
1962
+ for (const match of matches) {
1963
+ const task = updateTask(match.taskId, params.patch);
1964
+ if (task) updated.push(task);
1965
+ }
1966
+ return updated;
1967
+ }
1968
+ function ensureListener() {
1969
+ if (listenerStarted) return;
1970
+ listenerStarted = true;
1971
+ onAgentEvent((evt) => {
1972
+ restoreTaskRegistryOnce();
1973
+ const scopedTasks = getTasksByRunScope({
1974
+ runId: evt.runId,
1975
+ sessionKey: evt.sessionKey
1976
+ });
1977
+ if (scopedTasks.length === 0) return;
1978
+ const now = evt.ts || Date.now();
1979
+ for (const current of scopedTasks) {
1980
+ if (isTerminalTaskStatus(current.status)) continue;
1981
+ const patch = { lastEventAt: now };
1982
+ if (evt.stream === "lifecycle") {
1983
+ const phase = typeof evt.data?.phase === "string" ? evt.data.phase : void 0;
1984
+ const startedAt = typeof evt.data?.startedAt === "number" ? evt.data.startedAt : current.startedAt;
1985
+ const endedAt = typeof evt.data?.endedAt === "number" ? evt.data.endedAt : void 0;
1986
+ if (startedAt) patch.startedAt = startedAt;
1987
+ if (phase === "start") patch.status = "running";
1988
+ else if (phase === "end") {
1989
+ patch.status = evt.data?.aborted === true ? "timed_out" : "succeeded";
1990
+ patch.endedAt = endedAt ?? now;
1991
+ } else if (phase === "error") {
1992
+ patch.status = "failed";
1993
+ patch.endedAt = endedAt ?? now;
1994
+ patch.error = typeof evt.data?.error === "string" ? evt.data.error : current.error;
1995
+ }
1996
+ } else if (evt.stream === "error") patch.error = typeof evt.data?.error === "string" ? evt.data.error : current.error;
1997
+ const stateChangeEvent = patch.status && patch.status !== current.status ? appendTaskEvent({
1998
+ at: now,
1999
+ kind: patch.status,
2000
+ summary: patch.status === "failed" ? patch.error ?? current.error : patch.status === "succeeded" ? current.terminalSummary : void 0
2001
+ }) : void 0;
2002
+ if (updateTask(current.taskId, patch)) {
2003
+ maybeDeliverTaskStateChangeUpdate(current.taskId, stateChangeEvent);
2004
+ maybeDeliverTaskTerminalUpdate(current.taskId);
2005
+ }
2006
+ }
2007
+ });
2008
+ }
2009
+ function createTaskRecord(params) {
2010
+ ensureTaskRegistryReady();
2011
+ const requesterSessionKey = resolveTaskRequesterSessionKey(params);
2012
+ const scopeKind = resolveTaskScopeKind({
2013
+ scopeKind: params.scopeKind,
2014
+ requesterSessionKey
2015
+ });
2016
+ const ownerKey = resolveTaskOwnerKey({
2017
+ requesterSessionKey,
2018
+ ownerKey: params.ownerKey
2019
+ });
2020
+ assertTaskOwner({
2021
+ ownerKey,
2022
+ scopeKind
2023
+ });
2024
+ assertParentFlowLinkAllowed({
2025
+ ownerKey,
2026
+ scopeKind,
2027
+ parentFlowId: params.parentFlowId
2028
+ });
2029
+ const existing = findExistingTaskForCreate({
2030
+ runtime: params.runtime,
2031
+ ownerKey,
2032
+ scopeKind,
2033
+ childSessionKey: params.childSessionKey,
2034
+ parentFlowId: params.parentFlowId,
2035
+ runId: params.runId,
2036
+ label: params.label,
2037
+ task: params.task
2038
+ });
2039
+ if (existing) return mergeExistingTaskForCreate(existing, params);
2040
+ const now = Date.now();
2041
+ const taskId = crypto.randomUUID();
2042
+ const status = normalizeTaskStatus(params.status);
2043
+ const deliveryStatus = params.deliveryStatus ?? ensureDeliveryStatus({
2044
+ ownerKey,
2045
+ scopeKind
2046
+ });
2047
+ const notifyPolicy = ensureNotifyPolicy({
2048
+ notifyPolicy: params.notifyPolicy,
2049
+ deliveryStatus,
2050
+ ownerKey,
2051
+ scopeKind
2052
+ });
2053
+ const lastEventAt = params.lastEventAt ?? params.startedAt ?? now;
2054
+ const record = {
2055
+ taskId,
2056
+ runtime: params.runtime,
2057
+ taskKind: normalizeOptionalString(params.taskKind),
2058
+ sourceId: normalizeOptionalString(params.sourceId),
2059
+ requesterSessionKey,
2060
+ ownerKey,
2061
+ scopeKind,
2062
+ childSessionKey: params.childSessionKey,
2063
+ parentFlowId: normalizeOptionalString(params.parentFlowId),
2064
+ parentTaskId: normalizeOptionalString(params.parentTaskId),
2065
+ agentId: normalizeOptionalString(params.agentId),
2066
+ runId: normalizeOptionalString(params.runId),
2067
+ label: normalizeOptionalString(params.label),
2068
+ task: params.task,
2069
+ status,
2070
+ deliveryStatus,
2071
+ notifyPolicy,
2072
+ createdAt: now,
2073
+ startedAt: params.startedAt,
2074
+ lastEventAt,
2075
+ cleanupAfter: params.cleanupAfter,
2076
+ progressSummary: normalizeTaskSummary(params.progressSummary),
2077
+ terminalSummary: normalizeTaskSummary(params.terminalSummary),
2078
+ terminalOutcome: resolveTaskTerminalOutcome({
2079
+ status,
2080
+ terminalOutcome: params.terminalOutcome
2081
+ })
2082
+ };
2083
+ if (isTerminalTaskStatus(record.status) && typeof record.cleanupAfter !== "number") record.cleanupAfter = (record.endedAt ?? record.lastEventAt ?? record.createdAt) + DEFAULT_TASK_RETENTION_MS;
2084
+ tasks.set(taskId, record);
2085
+ upsertTaskDeliveryState({
2086
+ taskId,
2087
+ requesterOrigin: normalizeDeliveryContext(params.requesterOrigin)
2088
+ });
2089
+ addRunIdIndex(taskId, record.runId);
2090
+ addOwnerKeyIndex(taskId, record);
2091
+ addParentFlowIdIndex(taskId, record);
2092
+ addRelatedSessionKeyIndex(taskId, record);
2093
+ persistTaskUpsert(record);
2094
+ try {
2095
+ syncFlowFromTask(record);
2096
+ } catch (error) {
2097
+ log.warn("Failed to sync parent flow from task create", {
2098
+ taskId: record.taskId,
2099
+ flowId: record.parentFlowId,
2100
+ error
2101
+ });
2102
+ }
2103
+ emitTaskRegistryObserverEvent(() => ({
2104
+ kind: "upserted",
2105
+ task: cloneTaskRecord(record)
2106
+ }));
2107
+ if (isTerminalTaskStatus(record.status)) maybeDeliverTaskTerminalUpdate(taskId);
2108
+ return cloneTaskRecord(record);
2109
+ }
2110
+ function updateTaskStateByRunId(params) {
2111
+ ensureTaskRegistryReady();
2112
+ const matches = getTasksByRunScope(params);
2113
+ if (matches.length === 0) return [];
2114
+ const updated = [];
2115
+ for (const current of matches) {
2116
+ const patch = {};
2117
+ const nextStatus = params.status ? normalizeTaskStatus(params.status) : current.status;
2118
+ const eventAt = params.lastEventAt ?? params.endedAt ?? Date.now();
2119
+ if (params.status) patch.status = normalizeTaskStatus(params.status);
2120
+ if (params.startedAt != null) patch.startedAt = params.startedAt;
2121
+ if (params.endedAt != null) patch.endedAt = params.endedAt;
2122
+ if (params.lastEventAt != null) patch.lastEventAt = params.lastEventAt;
2123
+ if (params.error !== void 0) patch.error = params.error;
2124
+ if (params.progressSummary !== void 0) patch.progressSummary = normalizeTaskSummary(params.progressSummary);
2125
+ if (params.terminalSummary !== void 0) patch.terminalSummary = normalizeTaskSummary(params.terminalSummary);
2126
+ if (params.terminalOutcome !== void 0) patch.terminalOutcome = resolveTaskTerminalOutcome({
2127
+ status: nextStatus,
2128
+ terminalOutcome: params.terminalOutcome
2129
+ });
2130
+ const eventSummary = normalizeTaskSummary(params.eventSummary) ?? (nextStatus === "failed" ? normalizeTaskSummary(params.error ?? current.error) : nextStatus === "succeeded" ? normalizeTaskSummary(params.terminalSummary ?? current.terminalSummary) : void 0);
2131
+ const nextEvent = params.status && params.status !== current.status || Boolean(normalizeTaskSummary(params.eventSummary)) ? appendTaskEvent({
2132
+ at: eventAt,
2133
+ kind: params.status && normalizeTaskStatus(params.status) !== current.status ? normalizeTaskStatus(params.status) : "progress",
2134
+ summary: eventSummary
2135
+ }) : void 0;
2136
+ const task = updateTask(current.taskId, patch);
2137
+ if (task) {
2138
+ updated.push(task);
2139
+ maybeDeliverTaskStateChangeUpdate(task.taskId, nextEvent);
2140
+ maybeDeliverTaskTerminalUpdate(task.taskId);
2141
+ }
2142
+ }
2143
+ return updated;
2144
+ }
2145
+ function updateTaskDeliveryByRunId(params) {
2146
+ ensureTaskRegistryReady();
2147
+ return updateTasksByRunId({
2148
+ runId: params.runId,
2149
+ runtime: params.runtime,
2150
+ sessionKey: params.sessionKey,
2151
+ patch: { deliveryStatus: params.deliveryStatus }
2152
+ });
2153
+ }
2154
+ function markTaskRunningByRunId(params) {
2155
+ return updateTaskStateByRunId({
2156
+ runId: params.runId,
2157
+ runtime: params.runtime,
2158
+ sessionKey: params.sessionKey,
2159
+ status: "running",
2160
+ startedAt: params.startedAt,
2161
+ lastEventAt: params.lastEventAt,
2162
+ progressSummary: params.progressSummary,
2163
+ eventSummary: params.eventSummary
2164
+ });
2165
+ }
2166
+ function recordTaskProgressByRunId(params) {
2167
+ return updateTaskStateByRunId({
2168
+ runId: params.runId,
2169
+ runtime: params.runtime,
2170
+ sessionKey: params.sessionKey,
2171
+ lastEventAt: params.lastEventAt,
2172
+ progressSummary: params.progressSummary,
2173
+ eventSummary: params.eventSummary
2174
+ });
2175
+ }
2176
+ function markTaskTerminalByRunId(params) {
2177
+ return updateTaskStateByRunId({
2178
+ runId: params.runId,
2179
+ runtime: params.runtime,
2180
+ sessionKey: params.sessionKey,
2181
+ status: params.status,
2182
+ startedAt: params.startedAt,
2183
+ endedAt: params.endedAt,
2184
+ lastEventAt: params.lastEventAt,
2185
+ error: params.error,
2186
+ progressSummary: params.progressSummary,
2187
+ terminalSummary: params.terminalSummary,
2188
+ terminalOutcome: params.terminalOutcome
2189
+ });
2190
+ }
2191
+ function setTaskRunDeliveryStatusByRunId(params) {
2192
+ return updateTaskDeliveryByRunId(params);
2193
+ }
2194
+ function updateTaskNotifyPolicyById(params) {
2195
+ ensureTaskRegistryReady();
2196
+ return updateTask(params.taskId, {
2197
+ notifyPolicy: params.notifyPolicy,
2198
+ lastEventAt: Date.now()
2199
+ });
2200
+ }
2201
+ function linkTaskToFlowById(params) {
2202
+ ensureTaskRegistryReady();
2203
+ const flowId = params.flowId.trim();
2204
+ if (!flowId) return null;
2205
+ const current = tasks.get(params.taskId);
2206
+ if (!current) return null;
2207
+ if (current.parentFlowId?.trim()) return cloneTaskRecord(current);
2208
+ assertParentFlowLinkAllowed({
2209
+ ownerKey: current.ownerKey,
2210
+ scopeKind: current.scopeKind,
2211
+ parentFlowId: flowId
2212
+ });
2213
+ return updateTask(params.taskId, { parentFlowId: flowId });
2214
+ }
2215
+ async function cancelTaskById(params) {
2216
+ ensureTaskRegistryReady();
2217
+ const task = tasks.get(params.taskId.trim());
2218
+ if (!task) return {
2219
+ found: false,
2220
+ cancelled: false,
2221
+ reason: "Task not found."
2222
+ };
2223
+ if (task.status === "succeeded" || task.status === "failed" || task.status === "timed_out" || task.status === "lost" || task.status === "cancelled") return {
2224
+ found: true,
2225
+ cancelled: false,
2226
+ reason: "Task is already terminal.",
2227
+ task: cloneTaskRecord(task)
2228
+ };
2229
+ const childSessionKey = task.childSessionKey?.trim();
2230
+ try {
2231
+ if (task.runtime !== "cli") {
2232
+ if (!childSessionKey) return {
2233
+ found: true,
2234
+ cancelled: false,
2235
+ reason: "Task has no cancellable child session.",
2236
+ task: cloneTaskRecord(task)
2237
+ };
2238
+ if (task.runtime === "acp") {
2239
+ const { getAcpSessionManager } = await loadTaskRegistryControlRuntime();
2240
+ await getAcpSessionManager().cancelSession({
2241
+ cfg: params.cfg,
2242
+ sessionKey: childSessionKey,
2243
+ reason: "task-cancel"
2244
+ });
2245
+ } else if (task.runtime === "subagent") {
2246
+ const { killSubagentRunAdmin } = await loadTaskRegistryControlRuntime();
2247
+ const result = await killSubagentRunAdmin({
2248
+ cfg: params.cfg,
2249
+ sessionKey: childSessionKey
2250
+ });
2251
+ if (!result.found || !result.killed) return {
2252
+ found: true,
2253
+ cancelled: false,
2254
+ reason: result.found ? "Subagent was not running." : "Subagent task not found.",
2255
+ task: cloneTaskRecord(task)
2256
+ };
2257
+ } else return {
2258
+ found: true,
2259
+ cancelled: false,
2260
+ reason: "Task runtime does not support cancellation yet.",
2261
+ task: cloneTaskRecord(task)
2262
+ };
2263
+ }
2264
+ const updated = updateTask(task.taskId, {
2265
+ status: "cancelled",
2266
+ endedAt: Date.now(),
2267
+ lastEventAt: Date.now(),
2268
+ error: "Cancelled by operator."
2269
+ });
2270
+ if (updated) maybeDeliverTaskTerminalUpdate(updated.taskId);
2271
+ return {
2272
+ found: true,
2273
+ cancelled: true,
2274
+ task: updated ?? cloneTaskRecord(task)
2275
+ };
2276
+ } catch (error) {
2277
+ return {
2278
+ found: true,
2279
+ cancelled: false,
2280
+ reason: formatErrorMessage(error),
2281
+ task: cloneTaskRecord(task)
2282
+ };
2283
+ }
2284
+ }
2285
+ function listTaskRecords() {
2286
+ ensureTaskRegistryReady();
2287
+ return [...tasks.values()].map((task, insertionIndex) => Object.assign({}, cloneTaskRecord(task), { insertionIndex })).toSorted(compareTasksNewestFirst).map(({ insertionIndex: _, ...task }) => task);
2288
+ }
2289
+ function getTaskById(taskId) {
2290
+ ensureTaskRegistryReady();
2291
+ const task = tasks.get(taskId.trim());
2292
+ return task ? cloneTaskRecord(task) : void 0;
2293
+ }
2294
+ function findTaskByRunId(runId) {
2295
+ ensureTaskRegistryReady();
2296
+ const task = pickPreferredRunIdTask(getTasksByRunId(runId));
2297
+ return task ? cloneTaskRecord(task) : void 0;
2298
+ }
2299
+ function listTasksFromIndex(index, key) {
2300
+ const ids = index.get(key);
2301
+ if (!ids || ids.size === 0) return [];
2302
+ return [...ids].map((taskId, insertionIndex) => {
2303
+ const task = tasks.get(taskId);
2304
+ return task ? Object.assign({}, cloneTaskRecord(task), { insertionIndex }) : null;
2305
+ }).filter((task) => Boolean(task)).toSorted(compareTasksNewestFirst).map(({ insertionIndex: _, ...task }) => task);
2306
+ }
2307
+ function listTasksForSessionKey(sessionKey) {
2308
+ ensureTaskRegistryReady();
2309
+ const key = normalizeOptionalString(sessionKey);
2310
+ if (!key) return [];
2311
+ return listTasksFromIndex(taskIdsByRelatedSessionKey, key);
2312
+ }
2313
+ function listTasksForAgentId(agentId) {
2314
+ ensureTaskRegistryReady();
2315
+ const lookup = agentId.trim();
2316
+ if (!lookup) return [];
2317
+ return snapshotTaskRecords(tasks).filter((task) => task.agentId?.trim() === lookup).toSorted(compareTasksNewestFirst);
2318
+ }
2319
+ function listTasksForOwnerKey(ownerKey) {
2320
+ ensureTaskRegistryReady();
2321
+ const key = normalizeOptionalString(ownerKey);
2322
+ if (!key) return [];
2323
+ return listTasksFromIndex(taskIdsByOwnerKey, key);
2324
+ }
2325
+ function listTasksForFlowId(flowId) {
2326
+ ensureTaskRegistryReady();
2327
+ const key = flowId.trim();
2328
+ if (!key) return [];
2329
+ return listTasksFromIndex(taskIdsByParentFlowId, key);
2330
+ }
2331
+ function findLatestTaskForRelatedSessionKey(sessionKey) {
2332
+ const task = listTasksForRelatedSessionKey(sessionKey)[0];
2333
+ return task ? cloneTaskRecord(task) : void 0;
2334
+ }
2335
+ function listTasksForRelatedSessionKey(sessionKey) {
2336
+ ensureTaskRegistryReady();
2337
+ const key = normalizeOptionalString(sessionKey);
2338
+ if (!key) return [];
2339
+ return listTasksFromIndex(taskIdsByRelatedSessionKey, key);
2340
+ }
2341
+ function resolveTaskForLookupToken(token) {
2342
+ const lookup = token.trim();
2343
+ if (!lookup) return;
2344
+ return getTaskById(lookup) ?? findTaskByRunId(lookup) ?? findLatestTaskForRelatedSessionKey(lookup);
2345
+ }
2346
+ function deleteTaskRecordById(taskId) {
2347
+ ensureTaskRegistryReady();
2348
+ const current = tasks.get(taskId);
2349
+ if (!current) return false;
2350
+ deleteOwnerKeyIndex(taskId, current);
2351
+ deleteParentFlowIdIndex(taskId, current);
2352
+ deleteRelatedSessionKeyIndex(taskId, current);
2353
+ tasks.delete(taskId);
2354
+ taskDeliveryStates.delete(taskId);
2355
+ rebuildRunIdIndex();
2356
+ persistTaskDelete(taskId);
2357
+ persistTaskDeliveryStateDelete(taskId);
2358
+ emitTaskRegistryObserverEvent(() => ({
2359
+ kind: "deleted",
2360
+ taskId: current.taskId,
2361
+ previous: cloneTaskRecord(current)
2362
+ }));
2363
+ return true;
2364
+ }
2365
+ //#endregion
2366
+ export { finishFlow as A, setTaskRunDeliveryStatusByRunId as C, deleteTaskFlowRecordById as D, createTaskFlowForTask as E, requestFlowCancel as F, resolveTaskFlowForLookupToken as I, resumeFlow as L, getTaskFlowRegistryRestoreFailure as M, listTaskFlowRecords as N, failFlow as O, listTaskFlowsForOwnerKey as P, setFlowWaiting as R, setTaskCleanupAfterById as S, createManagedTaskFlow as T, markTaskTerminalById as _, findTaskByRunId as a, recordTaskProgressByRunId as b, linkTaskToFlowById as c, listTasksForFlowId as d, listTasksForOwnerKey as f, markTaskRunningByRunId as g, markTaskLostById as h, ensureTaskRegistryReady as i, getTaskFlowById as j, findLatestTaskFlowForOwnerKey as k, listTaskRecords as l, listTasksForSessionKey as m, createTaskRecord as n, getTaskById as o, listTasksForRelatedSessionKey as p, deleteTaskRecordById as r, isParentFlowLinkError as s, cancelTaskById as t, listTasksForAgentId as u, markTaskTerminalByRunId as v, updateTaskNotifyPolicyById as w, resolveTaskForLookupToken as x, maybeDeliverTaskTerminalUpdate as y, updateFlowRecordByIdExpectedRevision as z };