@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,3114 @@
1
+ import { i as formatErrorMessage } from "./errors-CufR9eHH.js";
2
+ import { a as normalizeLowercaseStringOrEmpty } from "./string-coerce-DPP_aYVc.js";
3
+ import { b as truncateUtf16Safe, m as resolveUserPath } from "./utils-CWrkFsp0.js";
4
+ import { t as createSubsystemLogger } from "./subsystem-CNq69MoE.js";
5
+ import { n as resolveGlobalSingleton } from "./global-singleton-DSEXPThW.js";
6
+ import { t as getProviderEnvVars } from "./provider-env-vars-DDxo5bUJ.js";
7
+ import { b as resolveAgentWorkspaceDir, y as resolveAgentDir } from "./agent-scope-Duyu_T59.js";
8
+ import { l as resolveSessionTranscriptsDirForAgent } from "./paths-CV1IubzZ.js";
9
+ import { n as onSessionTranscriptUpdate } from "./transcript-events-NZm-Lpzi.js";
10
+ import { t as extractKeywords } from "./query-expansion-D4dvpQMx.js";
11
+ import { i as getMemoryMultimodalExtensions, r as classifyMemoryMultimodalPath, t as buildCaseInsensitiveExtensionGlob } from "./multimodal-aWcUe4hC.js";
12
+ import { t as resolveMemorySearchConfig } from "./memory-search-BhOGz_Nf.js";
13
+ import "./text-runtime-Dd2bva2m.js";
14
+ import "./error-runtime-QklRpjU7.js";
15
+ import { a as ensureDir, c as listMemoryFiles, d as remapChunkLines, f as runWithConcurrency, h as hasNonTextEmbeddingParts, i as cosineSimilarity, l as normalizeExtraMemoryPaths, n as buildMultimodalChunkForIndexing, o as hashText, p as isFileMissingError, r as chunkMarkdown, t as buildFileEntry, u as parseEmbedding } from "./internal-0e7dt0ee.js";
16
+ import { r as readMemoryFile } from "./backend-config-COiFxgN3.js";
17
+ import { n as listMemoryEmbeddingProviders, r as listRegisteredMemoryEmbeddingProviderAdapters, t as getMemoryEmbeddingProvider } from "./memory-embedding-provider-runtime-BrNSQyAH.js";
18
+ import { D as createLocalEmbeddingProvider, E as DEFAULT_LOCAL_MODEL, u as enforceEmbeddingMaxInputTokens } from "./engine-embeddings-Bj9pHLjs.js";
19
+ import "./memory-core-host-engine-embeddings-CyjiA3sq.js";
20
+ import "./memory-core-host-engine-foundation-D0eaGBb1.js";
21
+ import { c as buildSessionEntry, l as listSessionFilesForAgent, p as sessionPathForFile } from "./engine-qmd-DH6SllqJ.js";
22
+ import "./memory-core-host-engine-qmd-DeMr2Cy9.js";
23
+ import { n as loadSqliteVecExtension, r as ensureMemoryIndexSchema, t as requireNodeSqlite } from "./engine-storage-cayA7Ctz.js";
24
+ import "./memory-core-host-engine-storage-S0YYfV_L.js";
25
+ import "./provider-env-vars-B5IFNPCJ.js";
26
+ import "./dreaming-shared-BLs-EJbE.js";
27
+ import fs from "node:fs";
28
+ import path from "node:path";
29
+ import fs$1 from "node:fs/promises";
30
+ import { randomUUID } from "node:crypto";
31
+ import chokidar from "chokidar";
32
+ //#region extensions/memory-core/src/memory/provider-adapter-registration.ts
33
+ function filterUnregisteredMemoryEmbeddingProviderAdapters(params) {
34
+ const existingIds = new Set(params.registeredAdapters.map((adapter) => adapter.id));
35
+ return params.builtinAdapters.filter((adapter) => !existingIds.has(adapter.id));
36
+ }
37
+ //#endregion
38
+ //#region extensions/memory-core/src/memory/provider-adapters.ts
39
+ const NODE_LLAMA_CPP_RUNTIME_PACKAGE = "node-llama-cpp";
40
+ const NODE_LLAMA_CPP_INSTALL_SPEC = `${NODE_LLAMA_CPP_RUNTIME_PACKAGE}@3.18.1`;
41
+ function isNodeLlamaCppMissing(err) {
42
+ if (!(err instanceof Error)) return false;
43
+ return err.code === "ERR_MODULE_NOT_FOUND" && err.message.includes(NODE_LLAMA_CPP_RUNTIME_PACKAGE);
44
+ }
45
+ function listRemoteEmbeddingSetupHints() {
46
+ try {
47
+ return listMemoryEmbeddingProviders().filter((adapter) => adapter.transport === "remote" && typeof adapter.autoSelectPriority === "number").toSorted((a, b) => (a.autoSelectPriority ?? 0) - (b.autoSelectPriority ?? 0)).map((adapter) => `Or set agents.defaults.memorySearch.provider = "${adapter.id}" (remote).`);
48
+ } catch {
49
+ return [];
50
+ }
51
+ }
52
+ function formatLocalSetupError(err) {
53
+ const detail = formatErrorMessage(err);
54
+ const missing = isNodeLlamaCppMissing(err);
55
+ return [
56
+ "Local embeddings unavailable.",
57
+ missing ? "Reason: optional dependency node-llama-cpp is missing (or failed to install)." : detail ? `Reason: ${detail}` : void 0,
58
+ missing && detail ? `Detail: ${detail}` : null,
59
+ "To enable local embeddings:",
60
+ "1) Use Node 24 (recommended for installs/updates; Node 22 LTS, currently 22.14+, remains supported)",
61
+ missing ? `2) Install optional local embedding runtime next to Genesis: npm i -g ${NODE_LLAMA_CPP_INSTALL_SPEC}` : null,
62
+ `3) If you use pnpm: pnpm approve-builds (select ${NODE_LLAMA_CPP_RUNTIME_PACKAGE}), then pnpm rebuild ${NODE_LLAMA_CPP_RUNTIME_PACKAGE}`,
63
+ ...listRemoteEmbeddingSetupHints()
64
+ ].filter(Boolean).join("\n");
65
+ }
66
+ function canAutoSelectLocal(modelPath) {
67
+ const trimmed = modelPath?.trim();
68
+ if (!trimmed) return false;
69
+ if (/^(hf:|https?:)/i.test(trimmed)) return false;
70
+ const resolved = resolveUserPath(trimmed);
71
+ try {
72
+ return fs.statSync(resolved).isFile();
73
+ } catch {
74
+ return false;
75
+ }
76
+ }
77
+ const builtinMemoryEmbeddingProviderAdapters = [{
78
+ id: "local",
79
+ defaultModel: DEFAULT_LOCAL_MODEL,
80
+ transport: "local",
81
+ autoSelectPriority: 10,
82
+ formatSetupError: formatLocalSetupError,
83
+ shouldContinueAutoSelection: () => true,
84
+ create: async (options) => {
85
+ const provider = await createLocalEmbeddingProvider({
86
+ ...options,
87
+ provider: "local",
88
+ fallback: "none"
89
+ });
90
+ return {
91
+ provider,
92
+ runtime: {
93
+ id: "local",
94
+ cacheKeyData: {
95
+ provider: "local",
96
+ model: provider.model
97
+ }
98
+ }
99
+ };
100
+ }
101
+ }];
102
+ function getBuiltinMemoryEmbeddingProviderAdapter(id) {
103
+ return listMemoryEmbeddingProviders().find((adapter) => adapter.id === id);
104
+ }
105
+ function registerBuiltInMemoryEmbeddingProviders(register) {
106
+ for (const adapter of filterUnregisteredMemoryEmbeddingProviderAdapters({
107
+ builtinAdapters: builtinMemoryEmbeddingProviderAdapters,
108
+ registeredAdapters: listRegisteredMemoryEmbeddingProviderAdapters()
109
+ })) register.registerMemoryEmbeddingProvider(adapter);
110
+ }
111
+ function getBuiltinMemoryEmbeddingProviderDoctorMetadata(providerId) {
112
+ const adapter = getBuiltinMemoryEmbeddingProviderAdapter(providerId);
113
+ if (!adapter) return null;
114
+ const authProviderId = adapter.authProviderId ?? adapter.id;
115
+ return {
116
+ providerId: adapter.id,
117
+ authProviderId,
118
+ envVars: getProviderEnvVars(authProviderId),
119
+ transport: adapter.transport === "local" ? "local" : "remote",
120
+ autoSelectPriority: adapter.autoSelectPriority
121
+ };
122
+ }
123
+ function listBuiltinAutoSelectMemoryEmbeddingProviderDoctorMetadata() {
124
+ return listMemoryEmbeddingProviders().filter((adapter) => typeof adapter.autoSelectPriority === "number").toSorted((a, b) => (a.autoSelectPriority ?? 0) - (b.autoSelectPriority ?? 0)).map((adapter) => {
125
+ const authProviderId = adapter.authProviderId ?? adapter.id;
126
+ return {
127
+ providerId: adapter.id,
128
+ authProviderId,
129
+ envVars: getProviderEnvVars(authProviderId),
130
+ transport: adapter.transport === "local" ? "local" : "remote",
131
+ autoSelectPriority: adapter.autoSelectPriority
132
+ };
133
+ });
134
+ }
135
+ //#endregion
136
+ //#region extensions/memory-core/src/memory/embeddings.ts
137
+ function formatProviderError(adapter, err) {
138
+ return adapter.formatSetupError?.(err) ?? formatErrorMessage(err);
139
+ }
140
+ function shouldContinueAutoSelection(adapter, err) {
141
+ return adapter.shouldContinueAutoSelection?.(err) ?? false;
142
+ }
143
+ function getAdapter(id, config) {
144
+ const adapter = getMemoryEmbeddingProvider(id, config);
145
+ if (!adapter) throw new Error(`Unknown memory embedding provider: ${id}`);
146
+ return adapter;
147
+ }
148
+ function listAutoSelectAdapters(options) {
149
+ return listMemoryEmbeddingProviders(options.config).filter((adapter) => typeof adapter.autoSelectPriority === "number").filter((adapter) => adapter.id === "local" ? canAutoSelectLocal(options.local?.modelPath) : true).toSorted((a, b) => (a.autoSelectPriority ?? Number.MAX_SAFE_INTEGER) - (b.autoSelectPriority ?? Number.MAX_SAFE_INTEGER));
150
+ }
151
+ function resolveProviderModel(adapter, requestedModel) {
152
+ const trimmed = requestedModel.trim();
153
+ if (trimmed) return trimmed;
154
+ return adapter.defaultModel ?? "";
155
+ }
156
+ function resolveEmbeddingProviderFallbackModel(providerId, fallbackSourceModel, config) {
157
+ return getMemoryEmbeddingProvider(providerId, config)?.defaultModel ?? fallbackSourceModel;
158
+ }
159
+ async function createWithAdapter(adapter, options) {
160
+ const result = await adapter.create({
161
+ ...options,
162
+ model: resolveProviderModel(adapter, options.model)
163
+ });
164
+ return {
165
+ provider: result.provider,
166
+ requestedProvider: options.provider,
167
+ runtime: result.runtime
168
+ };
169
+ }
170
+ async function createEmbeddingProvider(options) {
171
+ if (options.provider === "auto") {
172
+ const reasons = [];
173
+ for (const adapter of listAutoSelectAdapters(options)) try {
174
+ return {
175
+ ...await createWithAdapter(adapter, {
176
+ ...options,
177
+ provider: adapter.id
178
+ }),
179
+ requestedProvider: "auto"
180
+ };
181
+ } catch (err) {
182
+ const message = formatProviderError(adapter, err);
183
+ if (shouldContinueAutoSelection(adapter, err)) {
184
+ reasons.push(message);
185
+ continue;
186
+ }
187
+ const wrapped = new Error(message);
188
+ wrapped.cause = err;
189
+ throw wrapped;
190
+ }
191
+ return {
192
+ provider: null,
193
+ requestedProvider: "auto",
194
+ providerUnavailableReason: reasons.length > 0 ? reasons.join("\n\n") : "No embeddings provider available."
195
+ };
196
+ }
197
+ const primaryAdapter = getAdapter(options.provider, options.config);
198
+ try {
199
+ return await createWithAdapter(primaryAdapter, options);
200
+ } catch (primaryErr) {
201
+ const reason = formatProviderError(primaryAdapter, primaryErr);
202
+ if (options.fallback && options.fallback !== "none" && options.fallback !== options.provider) {
203
+ const fallbackAdapter = getAdapter(options.fallback, options.config);
204
+ try {
205
+ return {
206
+ ...await createWithAdapter(fallbackAdapter, {
207
+ ...options,
208
+ provider: options.fallback
209
+ }),
210
+ requestedProvider: options.provider,
211
+ fallbackFrom: options.provider,
212
+ fallbackReason: reason
213
+ };
214
+ } catch (fallbackErr) {
215
+ const fallbackReason = formatProviderError(fallbackAdapter, fallbackErr);
216
+ const wrapped = /* @__PURE__ */ new Error(`${reason}\n\nFallback to ${options.fallback} failed: ${fallbackReason}`);
217
+ wrapped.cause = primaryErr;
218
+ throw wrapped;
219
+ }
220
+ }
221
+ const wrapped = new Error(reason);
222
+ wrapped.cause = primaryErr;
223
+ throw wrapped;
224
+ }
225
+ }
226
+ //#endregion
227
+ //#region extensions/memory-core/src/memory/mmr.ts
228
+ const DEFAULT_MMR_CONFIG = {
229
+ enabled: false,
230
+ lambda: .7
231
+ };
232
+ /**
233
+ * Regex matching CJK-family characters that lack whitespace word boundaries:
234
+ * - CJK Unified Ideographs (Chinese hanzi, Japanese kanji, Korean hanja)
235
+ * - CJK Extension A
236
+ * - Hiragana & Katakana (Japanese)
237
+ * - Hangul Syllables & Jamo (Korean)
238
+ */
239
+ const CJK_RE = /[\u3040-\u309f\u30a0-\u30ff\u3400-\u4dbf\u4e00-\u9fff\uac00-\ud7af\u1100-\u11ff]/;
240
+ /**
241
+ * Tokenize text for Jaccard similarity computation.
242
+ * Extracts alphanumeric tokens, CJK-family characters (unigrams),
243
+ * and consecutive CJK character pairs (bigrams).
244
+ *
245
+ * Bigrams are only created from characters that are adjacent in the
246
+ * original text, so mixed content like "我喜欢hello你好" will NOT
247
+ * produce the spurious bigram "欢你".
248
+ */
249
+ function tokenize(text) {
250
+ const lower = normalizeLowercaseStringOrEmpty(text);
251
+ const ascii = lower.match(/[a-z0-9_]+/g) ?? [];
252
+ const chars = Array.from(lower);
253
+ const cjkData = [];
254
+ for (let i = 0; i < chars.length; i++) if (CJK_RE.test(chars[i])) cjkData.push({
255
+ char: chars[i],
256
+ index: i
257
+ });
258
+ const bigrams = [];
259
+ for (let i = 0; i < cjkData.length - 1; i++) if (cjkData[i + 1].index === cjkData[i].index + 1) bigrams.push(cjkData[i].char + cjkData[i + 1].char);
260
+ const unigrams = cjkData.map((d) => d.char);
261
+ return new Set([
262
+ ...ascii,
263
+ ...bigrams,
264
+ ...unigrams
265
+ ]);
266
+ }
267
+ /**
268
+ * Compute Jaccard similarity between two token sets.
269
+ * Returns a value in [0, 1] where 1 means identical sets.
270
+ */
271
+ function jaccardSimilarity(setA, setB) {
272
+ if (setA.size === 0 && setB.size === 0) return 1;
273
+ if (setA.size === 0 || setB.size === 0) return 0;
274
+ let intersectionSize = 0;
275
+ const smaller = setA.size <= setB.size ? setA : setB;
276
+ const larger = setA.size <= setB.size ? setB : setA;
277
+ for (const token of smaller) if (larger.has(token)) intersectionSize++;
278
+ const unionSize = setA.size + setB.size - intersectionSize;
279
+ return unionSize === 0 ? 0 : intersectionSize / unionSize;
280
+ }
281
+ /**
282
+ * Compute the maximum similarity between an item and all selected items.
283
+ */
284
+ function maxSimilarityToSelected(item, selectedItems, tokenCache) {
285
+ if (selectedItems.length === 0) return 0;
286
+ let maxSim = 0;
287
+ const itemTokens = tokenCache.get(item.id) ?? tokenize(item.content);
288
+ for (const selected of selectedItems) {
289
+ const sim = jaccardSimilarity(itemTokens, tokenCache.get(selected.id) ?? tokenize(selected.content));
290
+ if (sim > maxSim) maxSim = sim;
291
+ }
292
+ return maxSim;
293
+ }
294
+ /**
295
+ * Compute MMR score for a candidate item.
296
+ * MMR = λ * relevance - (1-λ) * max_similarity_to_selected
297
+ */
298
+ function computeMMRScore(relevance, maxSimilarity, lambda) {
299
+ return lambda * relevance - (1 - lambda) * maxSimilarity;
300
+ }
301
+ /**
302
+ * Re-rank items using Maximal Marginal Relevance (MMR).
303
+ *
304
+ * The algorithm iteratively selects items that balance relevance with diversity:
305
+ * 1. Start with the highest-scoring item
306
+ * 2. For each remaining slot, select the item that maximizes the MMR score
307
+ * 3. MMR score = λ * relevance - (1-λ) * max_similarity_to_already_selected
308
+ *
309
+ * @param items - Items to re-rank, must have score and content
310
+ * @param config - MMR configuration (lambda, enabled)
311
+ * @returns Re-ranked items in MMR order
312
+ */
313
+ function mmrRerank(items, config = {}) {
314
+ const { enabled = DEFAULT_MMR_CONFIG.enabled, lambda = DEFAULT_MMR_CONFIG.lambda } = config;
315
+ if (!enabled || items.length <= 1) return [...items];
316
+ const clampedLambda = Math.max(0, Math.min(1, lambda));
317
+ if (clampedLambda === 1) return [...items].toSorted((a, b) => b.score - a.score);
318
+ const tokenCache = /* @__PURE__ */ new Map();
319
+ for (const item of items) tokenCache.set(item.id, tokenize(item.content));
320
+ const maxScore = Math.max(...items.map((i) => i.score));
321
+ const minScore = Math.min(...items.map((i) => i.score));
322
+ const scoreRange = maxScore - minScore;
323
+ const normalizeScore = (score) => {
324
+ if (scoreRange === 0) return 1;
325
+ return (score - minScore) / scoreRange;
326
+ };
327
+ const selected = [];
328
+ const remaining = new Set(items);
329
+ while (remaining.size > 0) {
330
+ let bestItem = null;
331
+ let bestMMRScore = -Infinity;
332
+ for (const candidate of remaining) {
333
+ const mmrScore = computeMMRScore(normalizeScore(candidate.score), maxSimilarityToSelected(candidate, selected, tokenCache), clampedLambda);
334
+ if (mmrScore > bestMMRScore || mmrScore === bestMMRScore && candidate.score > (bestItem?.score ?? -Infinity)) {
335
+ bestMMRScore = mmrScore;
336
+ bestItem = candidate;
337
+ }
338
+ }
339
+ if (bestItem) {
340
+ selected.push(bestItem);
341
+ remaining.delete(bestItem);
342
+ } else break;
343
+ }
344
+ return selected;
345
+ }
346
+ /**
347
+ * Apply MMR re-ranking to hybrid search results.
348
+ * Adapts the generic MMR function to work with the hybrid search result format.
349
+ */
350
+ function applyMMRToHybridResults(results, config = {}) {
351
+ if (results.length === 0) return results;
352
+ const itemById = /* @__PURE__ */ new Map();
353
+ return mmrRerank(results.map((r, index) => {
354
+ const id = `${r.path}:${r.startLine}:${index}`;
355
+ itemById.set(id, r);
356
+ return {
357
+ id,
358
+ score: r.score,
359
+ content: r.snippet
360
+ };
361
+ }), config).map((item) => itemById.get(item.id));
362
+ }
363
+ //#endregion
364
+ //#region extensions/memory-core/src/memory/temporal-decay.ts
365
+ const DEFAULT_TEMPORAL_DECAY_CONFIG = {
366
+ enabled: false,
367
+ halfLifeDays: 30
368
+ };
369
+ const DAY_MS = 1440 * 60 * 1e3;
370
+ const DATED_MEMORY_PATH_RE = /(?:^|\/)memory\/(\d{4})-(\d{2})-(\d{2})\.md$/;
371
+ function toDecayLambda(halfLifeDays) {
372
+ if (!Number.isFinite(halfLifeDays) || halfLifeDays <= 0) return 0;
373
+ return Math.LN2 / halfLifeDays;
374
+ }
375
+ function calculateTemporalDecayMultiplier(params) {
376
+ const lambda = toDecayLambda(params.halfLifeDays);
377
+ const clampedAge = Math.max(0, params.ageInDays);
378
+ if (lambda <= 0 || !Number.isFinite(clampedAge)) return 1;
379
+ return Math.exp(-lambda * clampedAge);
380
+ }
381
+ function applyTemporalDecayToScore(params) {
382
+ return params.score * calculateTemporalDecayMultiplier(params);
383
+ }
384
+ function parseMemoryDateFromPath(filePath) {
385
+ const normalized = filePath.replaceAll("\\", "/").replace(/^\.\//, "");
386
+ const match = DATED_MEMORY_PATH_RE.exec(normalized);
387
+ if (!match) return null;
388
+ const year = Number(match[1]);
389
+ const month = Number(match[2]);
390
+ const day = Number(match[3]);
391
+ if (!Number.isInteger(year) || !Number.isInteger(month) || !Number.isInteger(day)) return null;
392
+ const timestamp = Date.UTC(year, month - 1, day);
393
+ const parsed = new Date(timestamp);
394
+ if (parsed.getUTCFullYear() !== year || parsed.getUTCMonth() !== month - 1 || parsed.getUTCDate() !== day) return null;
395
+ return parsed;
396
+ }
397
+ function isEvergreenMemoryPath(filePath) {
398
+ const normalized = filePath.replaceAll("\\", "/").replace(/^\.\//, "");
399
+ if (normalized === "MEMORY.md") return true;
400
+ if (!normalized.startsWith("memory/")) return false;
401
+ return !DATED_MEMORY_PATH_RE.test(normalized);
402
+ }
403
+ async function extractTimestamp(params) {
404
+ const fromPath = parseMemoryDateFromPath(params.filePath);
405
+ if (fromPath) return fromPath;
406
+ if (params.source === "memory" && isEvergreenMemoryPath(params.filePath)) return null;
407
+ if (!params.workspaceDir) return null;
408
+ const absolutePath = path.isAbsolute(params.filePath) ? params.filePath : path.resolve(params.workspaceDir, params.filePath);
409
+ try {
410
+ const stat = await fs$1.stat(absolutePath);
411
+ if (!Number.isFinite(stat.mtimeMs)) return null;
412
+ return new Date(stat.mtimeMs);
413
+ } catch {
414
+ return null;
415
+ }
416
+ }
417
+ function ageInDaysFromTimestamp(timestamp, nowMs) {
418
+ return Math.max(0, nowMs - timestamp.getTime()) / DAY_MS;
419
+ }
420
+ async function applyTemporalDecayToHybridResults(params) {
421
+ const config = {
422
+ ...DEFAULT_TEMPORAL_DECAY_CONFIG,
423
+ ...params.temporalDecay
424
+ };
425
+ if (!config.enabled) return [...params.results];
426
+ const nowMs = params.nowMs ?? Date.now();
427
+ const timestampPromiseCache = /* @__PURE__ */ new Map();
428
+ return Promise.all(params.results.map(async (entry) => {
429
+ const cacheKey = `${entry.source}:${entry.path}`;
430
+ let timestampPromise = timestampPromiseCache.get(cacheKey);
431
+ if (!timestampPromise) {
432
+ timestampPromise = extractTimestamp({
433
+ filePath: entry.path,
434
+ source: entry.source,
435
+ workspaceDir: params.workspaceDir
436
+ });
437
+ timestampPromiseCache.set(cacheKey, timestampPromise);
438
+ }
439
+ const timestamp = await timestampPromise;
440
+ if (!timestamp) return entry;
441
+ const decayedScore = applyTemporalDecayToScore({
442
+ score: entry.score,
443
+ ageInDays: ageInDaysFromTimestamp(timestamp, nowMs),
444
+ halfLifeDays: config.halfLifeDays
445
+ });
446
+ return {
447
+ ...entry,
448
+ score: decayedScore
449
+ };
450
+ }));
451
+ }
452
+ //#endregion
453
+ //#region extensions/memory-core/src/memory/hybrid.ts
454
+ function buildFtsQuery(raw) {
455
+ const tokens = raw.match(/[\p{L}\p{N}_]+/gu)?.map((t) => t.trim()).filter(Boolean) ?? [];
456
+ if (tokens.length === 0) return null;
457
+ return tokens.map((t) => `"${t.replaceAll("\"", "")}"`).join(" AND ");
458
+ }
459
+ function bm25RankToScore(rank) {
460
+ if (!Number.isFinite(rank)) return 1 / 1e3;
461
+ if (rank < 0) {
462
+ const relevance = -rank;
463
+ return relevance / (1 + relevance);
464
+ }
465
+ return 1 / (1 + rank);
466
+ }
467
+ async function mergeHybridResults(params) {
468
+ const byId = /* @__PURE__ */ new Map();
469
+ for (const r of params.vector) byId.set(r.id, {
470
+ id: r.id,
471
+ path: r.path,
472
+ startLine: r.startLine,
473
+ endLine: r.endLine,
474
+ source: r.source,
475
+ snippet: r.snippet,
476
+ vectorScore: r.vectorScore,
477
+ textScore: 0
478
+ });
479
+ for (const r of params.keyword) {
480
+ const existing = byId.get(r.id);
481
+ if (existing) {
482
+ existing.textScore = r.textScore;
483
+ if (r.snippet && r.snippet.length > 0) existing.snippet = r.snippet;
484
+ } else byId.set(r.id, {
485
+ id: r.id,
486
+ path: r.path,
487
+ startLine: r.startLine,
488
+ endLine: r.endLine,
489
+ source: r.source,
490
+ snippet: r.snippet,
491
+ vectorScore: 0,
492
+ textScore: r.textScore
493
+ });
494
+ }
495
+ const sorted = (await applyTemporalDecayToHybridResults({
496
+ results: Array.from(byId.values()).map((entry) => {
497
+ const score = params.vectorWeight * entry.vectorScore + params.textWeight * entry.textScore;
498
+ return {
499
+ path: entry.path,
500
+ startLine: entry.startLine,
501
+ endLine: entry.endLine,
502
+ score,
503
+ vectorScore: entry.vectorScore,
504
+ textScore: entry.textScore,
505
+ snippet: entry.snippet,
506
+ source: entry.source
507
+ };
508
+ }),
509
+ temporalDecay: {
510
+ ...DEFAULT_TEMPORAL_DECAY_CONFIG,
511
+ ...params.temporalDecay
512
+ },
513
+ workspaceDir: params.workspaceDir,
514
+ nowMs: params.nowMs
515
+ })).toSorted((a, b) => b.score - a.score);
516
+ const mmrConfig = {
517
+ ...DEFAULT_MMR_CONFIG,
518
+ ...params.mmr
519
+ };
520
+ if (mmrConfig.enabled) return applyMMRToHybridResults(sorted, mmrConfig);
521
+ return sorted;
522
+ }
523
+ //#endregion
524
+ //#region extensions/memory-core/src/memory/manager-async-state.ts
525
+ function startAsyncSearchSync(params) {
526
+ if (!params.enabled || !params.dirty && !params.sessionsDirty) return;
527
+ params.sync({ reason: "search" }).catch((err) => {
528
+ params.onError(err);
529
+ });
530
+ }
531
+ async function awaitPendingManagerWork(params) {
532
+ if (params.pendingSync) try {
533
+ await params.pendingSync;
534
+ } catch {}
535
+ if (params.pendingProviderInit) try {
536
+ await params.pendingProviderInit;
537
+ } catch {}
538
+ }
539
+ function resetMemoryBatchFailureState(state) {
540
+ return {
541
+ ...state,
542
+ count: 0,
543
+ lastError: void 0,
544
+ lastProvider: void 0
545
+ };
546
+ }
547
+ function recordMemoryBatchFailure(state, params) {
548
+ if (!state.enabled) return state;
549
+ const increment = params.forceDisable ? 2 : Math.max(1, params.attempts ?? 1);
550
+ const count = state.count + increment;
551
+ return {
552
+ enabled: !(params.forceDisable || count >= 2),
553
+ count,
554
+ lastError: params.message,
555
+ lastProvider: params.provider
556
+ };
557
+ }
558
+ //#endregion
559
+ //#region extensions/memory-core/src/memory/manager-cache.ts
560
+ function resolveSingletonManagedCache(cacheKey) {
561
+ const resolved = resolveGlobalSingleton(cacheKey, () => ({
562
+ cache: /* @__PURE__ */ new Map(),
563
+ pending: /* @__PURE__ */ new Map()
564
+ }));
565
+ if (typeof resolved === "object" && resolved !== null && resolved.cache instanceof Map && resolved.pending instanceof Map) return resolved;
566
+ const repaired = {
567
+ cache: /* @__PURE__ */ new Map(),
568
+ pending: /* @__PURE__ */ new Map()
569
+ };
570
+ globalThis[cacheKey] = repaired;
571
+ return repaired;
572
+ }
573
+ async function getOrCreateManagedCacheEntry(params) {
574
+ if (params.bypassCache) return await params.create();
575
+ const existing = params.cache.get(params.key);
576
+ if (existing) return existing;
577
+ const pending = params.pending.get(params.key);
578
+ if (pending) return pending;
579
+ const createPromise = (async () => {
580
+ const refreshed = params.cache.get(params.key);
581
+ if (refreshed) return refreshed;
582
+ const entry = await params.create();
583
+ params.cache.set(params.key, entry);
584
+ return entry;
585
+ })();
586
+ params.pending.set(params.key, createPromise);
587
+ try {
588
+ return await createPromise;
589
+ } finally {
590
+ if (params.pending.get(params.key) === createPromise) params.pending.delete(params.key);
591
+ }
592
+ }
593
+ async function closeManagedCacheEntries(params) {
594
+ const pending = Array.from(params.pending.values());
595
+ if (pending.length > 0) await Promise.allSettled(pending);
596
+ const entries = Array.from(params.cache.values());
597
+ params.cache.clear();
598
+ for (const entry of entries) {
599
+ if (typeof entry.close !== "function") continue;
600
+ try {
601
+ await entry.close();
602
+ } catch (err) {
603
+ params.onCloseError?.(err);
604
+ }
605
+ }
606
+ }
607
+ //#endregion
608
+ //#region extensions/memory-core/src/memory/manager-embedding-cache.ts
609
+ function loadMemoryEmbeddingCache(params) {
610
+ const provider = params.provider;
611
+ if (!params.enabled || !provider || !params.providerKey || params.hashes.length === 0) return /* @__PURE__ */ new Map();
612
+ const unique = [];
613
+ const seen = /* @__PURE__ */ new Set();
614
+ for (const hash of params.hashes) {
615
+ if (!hash || seen.has(hash)) continue;
616
+ seen.add(hash);
617
+ unique.push(hash);
618
+ }
619
+ if (unique.length === 0) return /* @__PURE__ */ new Map();
620
+ const tableName = params.tableName ?? "embedding_cache";
621
+ const out = /* @__PURE__ */ new Map();
622
+ const baseParams = [
623
+ provider.id,
624
+ provider.model,
625
+ params.providerKey
626
+ ];
627
+ const batchSize = 400;
628
+ for (let start = 0; start < unique.length; start += batchSize) {
629
+ const batch = unique.slice(start, start + batchSize);
630
+ const placeholders = batch.map(() => "?").join(", ");
631
+ const rows = params.db.prepare(`SELECT hash, embedding FROM ${tableName}\n WHERE provider = ? AND model = ? AND provider_key = ? AND hash IN (${placeholders})`).all(...baseParams, ...batch);
632
+ for (const row of rows) out.set(row.hash, parseEmbedding(row.embedding));
633
+ }
634
+ return out;
635
+ }
636
+ function upsertMemoryEmbeddingCache(params) {
637
+ const provider = params.provider;
638
+ if (!params.enabled || !provider || !params.providerKey || params.entries.length === 0) return;
639
+ const tableName = params.tableName ?? "embedding_cache";
640
+ const now = params.now ?? Date.now();
641
+ const stmt = params.db.prepare(`INSERT INTO ${tableName} (provider, model, provider_key, hash, embedding, dims, updated_at)\n VALUES (?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT(provider, model, provider_key, hash) DO UPDATE SET\n embedding=excluded.embedding,\n dims=excluded.dims,\n updated_at=excluded.updated_at`);
642
+ for (const entry of params.entries) {
643
+ const embedding = entry.embedding ?? [];
644
+ stmt.run(provider.id, provider.model, params.providerKey, entry.hash, JSON.stringify(embedding), embedding.length, now);
645
+ }
646
+ }
647
+ function collectMemoryCachedEmbeddings(params) {
648
+ const embeddings = Array.from({ length: params.chunks.length }, () => []);
649
+ const missing = [];
650
+ for (let index = 0; index < params.chunks.length; index += 1) {
651
+ const chunk = params.chunks[index];
652
+ const hit = chunk?.hash ? params.cached.get(chunk.hash) : void 0;
653
+ if (hit && hit.length > 0) embeddings[index] = hit;
654
+ else if (chunk) missing.push({
655
+ index,
656
+ chunk
657
+ });
658
+ }
659
+ return {
660
+ embeddings,
661
+ missing
662
+ };
663
+ }
664
+ //#endregion
665
+ //#region extensions/memory-core/src/memory/manager-embedding-policy.ts
666
+ function estimateUtf8Bytes(text) {
667
+ if (!text) return 0;
668
+ return Buffer.byteLength(text, "utf8");
669
+ }
670
+ function estimateStructuredEmbeddingInputBytes(input) {
671
+ if (!input.parts?.length) return estimateUtf8Bytes(input.text);
672
+ let total = 0;
673
+ for (const part of input.parts) if (part.type === "text") total += estimateUtf8Bytes(part.text);
674
+ else {
675
+ total += estimateUtf8Bytes(part.mimeType);
676
+ total += estimateUtf8Bytes(part.data);
677
+ }
678
+ return total;
679
+ }
680
+ function filterNonEmptyMemoryChunks(chunks) {
681
+ return chunks.filter((chunk) => chunk.text.trim().length > 0);
682
+ }
683
+ function buildMemoryEmbeddingBatches(chunks, maxTokens) {
684
+ const batches = [];
685
+ let current = [];
686
+ let currentTokens = 0;
687
+ for (const chunk of chunks) {
688
+ const estimate = chunk.embeddingInput ? estimateStructuredEmbeddingInputBytes(chunk.embeddingInput) : estimateUtf8Bytes(chunk.text);
689
+ if (current.length > 0 && currentTokens + estimate > maxTokens) {
690
+ batches.push(current);
691
+ current = [];
692
+ currentTokens = 0;
693
+ }
694
+ if (current.length === 0 && estimate > maxTokens) {
695
+ batches.push([chunk]);
696
+ continue;
697
+ }
698
+ current.push(chunk);
699
+ currentTokens += estimate;
700
+ }
701
+ if (current.length > 0) batches.push(current);
702
+ return batches;
703
+ }
704
+ function isRetryableMemoryEmbeddingError(message) {
705
+ return /(rate[_ ]limit|too many requests|429|resource has been exhausted|5\d\d|cloudflare|tokens per day)/i.test(message);
706
+ }
707
+ function resolveMemoryEmbeddingRetryDelay(delayMs, randomValue, maxDelayMs) {
708
+ return Math.min(maxDelayMs, Math.round(delayMs * (1 + randomValue * .2)));
709
+ }
710
+ async function runMemoryEmbeddingRetryLoop(params) {
711
+ let attempt = 0;
712
+ let delayMs = params.baseDelayMs;
713
+ while (true) try {
714
+ return await params.run();
715
+ } catch (err) {
716
+ const message = formatErrorMessage(err);
717
+ if (!params.isRetryable(message) || attempt >= params.maxAttempts) throw err;
718
+ await params.waitForRetry(delayMs);
719
+ delayMs *= 2;
720
+ attempt += 1;
721
+ }
722
+ }
723
+ function buildTextEmbeddingInputs(chunks) {
724
+ return chunks.map((chunk) => chunk.embeddingInput ?? { text: chunk.text });
725
+ }
726
+ //#endregion
727
+ //#region extensions/memory-core/src/memory/manager-fts-state.ts
728
+ function deleteMemoryFtsRows(params) {
729
+ const tableName = params.tableName ?? "chunks_fts";
730
+ if (params.currentModel) {
731
+ params.db.prepare(`DELETE FROM ${tableName} WHERE path = ? AND source = ? AND model = ?`).run(params.path, params.source, params.currentModel);
732
+ return;
733
+ }
734
+ params.db.prepare(`DELETE FROM ${tableName} WHERE path = ? AND source = ?`).run(params.path, params.source);
735
+ }
736
+ //#endregion
737
+ //#region extensions/memory-core/src/memory/manager-atomic-reindex.ts
738
+ async function moveMemoryIndexFiles(sourceBase, targetBase) {
739
+ for (const suffix of [
740
+ "",
741
+ "-wal",
742
+ "-shm"
743
+ ]) {
744
+ const source = `${sourceBase}${suffix}`;
745
+ const target = `${targetBase}${suffix}`;
746
+ try {
747
+ await fs$1.rename(source, target);
748
+ } catch (err) {
749
+ if (err.code !== "ENOENT") throw err;
750
+ }
751
+ }
752
+ }
753
+ async function removeMemoryIndexFiles(basePath) {
754
+ await Promise.all([
755
+ "",
756
+ "-wal",
757
+ "-shm"
758
+ ].map((suffix) => fs$1.rm(`${basePath}${suffix}`, { force: true })));
759
+ }
760
+ async function swapMemoryIndexFiles(targetPath, tempPath) {
761
+ const backupPath = `${targetPath}.backup-${randomUUID()}`;
762
+ await moveMemoryIndexFiles(targetPath, backupPath);
763
+ try {
764
+ await moveMemoryIndexFiles(tempPath, targetPath);
765
+ } catch (err) {
766
+ await moveMemoryIndexFiles(backupPath, targetPath);
767
+ throw err;
768
+ }
769
+ await removeMemoryIndexFiles(backupPath);
770
+ }
771
+ async function runMemoryAtomicReindex(params) {
772
+ try {
773
+ const result = await params.build();
774
+ await swapMemoryIndexFiles(params.targetPath, params.tempPath);
775
+ return result;
776
+ } catch (err) {
777
+ await removeMemoryIndexFiles(params.tempPath);
778
+ throw err;
779
+ }
780
+ }
781
+ //#endregion
782
+ //#region extensions/memory-core/src/memory/manager-db.ts
783
+ function openMemoryDatabaseAtPath(dbPath, allowExtension) {
784
+ ensureDir(path.dirname(dbPath));
785
+ const { DatabaseSync } = requireNodeSqlite();
786
+ const db = new DatabaseSync(dbPath, { allowExtension });
787
+ db.exec("PRAGMA busy_timeout = 5000");
788
+ return db;
789
+ }
790
+ //#endregion
791
+ //#region extensions/memory-core/src/memory/manager-provider-state.ts
792
+ function resolveMemoryPrimaryProviderRequest(params) {
793
+ return {
794
+ provider: params.settings.provider,
795
+ model: params.settings.model,
796
+ remote: params.settings.remote,
797
+ outputDimensionality: params.settings.outputDimensionality,
798
+ fallback: params.settings.fallback,
799
+ local: params.settings.local
800
+ };
801
+ }
802
+ function resolveMemoryProviderState(result) {
803
+ return {
804
+ provider: result.provider,
805
+ fallbackFrom: result.fallbackFrom,
806
+ fallbackReason: result.fallbackReason,
807
+ providerUnavailableReason: result.providerUnavailableReason,
808
+ providerRuntime: result.runtime
809
+ };
810
+ }
811
+ function applyMemoryFallbackProviderState(params) {
812
+ return {
813
+ ...params.current,
814
+ fallbackFrom: params.fallbackFrom,
815
+ fallbackReason: params.reason,
816
+ provider: params.result.provider,
817
+ providerRuntime: params.result.runtime
818
+ };
819
+ }
820
+ function resolveMemoryFallbackProviderRequest(params) {
821
+ const fallback = params.settings.fallback;
822
+ if (!fallback || fallback === "none" || !params.currentProviderId || fallback === params.currentProviderId) return null;
823
+ return {
824
+ provider: fallback,
825
+ model: resolveEmbeddingProviderFallbackModel(fallback, params.settings.model, params.cfg),
826
+ remote: params.settings.remote,
827
+ outputDimensionality: params.settings.outputDimensionality,
828
+ fallback: "none",
829
+ local: params.settings.local
830
+ };
831
+ }
832
+ //#endregion
833
+ //#region extensions/memory-core/src/memory/manager-reindex-state.ts
834
+ function resolveConfiguredSourcesForMeta(sources) {
835
+ const normalized = Array.from(sources).filter((source) => source === "memory" || source === "sessions").toSorted();
836
+ return normalized.length > 0 ? normalized : ["memory"];
837
+ }
838
+ function normalizeMetaSources(meta) {
839
+ if (!Array.isArray(meta.sources)) return ["memory"];
840
+ const normalized = Array.from(new Set(meta.sources.filter((source) => source === "memory" || source === "sessions"))).toSorted();
841
+ return normalized.length > 0 ? normalized : ["memory"];
842
+ }
843
+ function configuredMetaSourcesDiffer(params) {
844
+ const metaSources = normalizeMetaSources(params.meta);
845
+ if (metaSources.length !== params.configuredSources.length) return true;
846
+ return metaSources.some((source, index) => source !== params.configuredSources[index]);
847
+ }
848
+ function resolveConfiguredScopeHash(params) {
849
+ const extraPaths = normalizeExtraMemoryPaths(params.workspaceDir, params.extraPaths).map((value) => value.replace(/\\/g, "/")).toSorted();
850
+ return hashText(JSON.stringify({
851
+ extraPaths,
852
+ multimodal: {
853
+ enabled: params.multimodal.enabled,
854
+ modalities: [...params.multimodal.modalities].toSorted(),
855
+ maxFileBytes: params.multimodal.maxFileBytes
856
+ }
857
+ }));
858
+ }
859
+ function shouldRunFullMemoryReindex(params) {
860
+ const { meta } = params;
861
+ return !meta || (params.provider ? meta.model !== params.provider.model : meta.model !== "fts-only") || (params.provider ? meta.provider !== params.provider.id : meta.provider !== "none") || meta.providerKey !== params.providerKey || configuredMetaSourcesDiffer({
862
+ meta,
863
+ configuredSources: params.configuredSources
864
+ }) || meta.scopeHash !== params.configuredScopeHash || meta.chunkTokens !== params.chunkTokens || meta.chunkOverlap !== params.chunkOverlap || params.vectorReady && !meta.vectorDims || (meta.ftsTokenizer ?? "unicode61") !== params.ftsTokenizer;
865
+ }
866
+ //#endregion
867
+ //#region extensions/memory-core/src/memory/manager-session-reindex.ts
868
+ function shouldSyncSessionsForReindex(params) {
869
+ if (!params.hasSessionSource) return false;
870
+ if (params.sync?.sessionFiles?.some((sessionFile) => sessionFile.trim().length > 0)) return true;
871
+ if (params.sync?.force) return true;
872
+ if (params.needsFullReindex) return true;
873
+ const reason = params.sync?.reason;
874
+ if (reason === "session-start" || reason === "watch") return false;
875
+ return params.sessionsDirty && params.dirtySessionFileCount > 0;
876
+ }
877
+ //#endregion
878
+ //#region extensions/memory-core/src/memory/manager-session-sync-state.ts
879
+ function resolveMemorySessionSyncPlan(params) {
880
+ const activePaths = params.targetSessionFiles ? null : new Set(params.files.map((file) => params.sessionPathForFile(file)));
881
+ const existingRows = activePaths === null ? null : params.existingRows ?? [];
882
+ return {
883
+ activePaths,
884
+ existingRows,
885
+ existingHashes: existingRows ? new Map(existingRows.map((row) => [row.path, row.hash])) : null,
886
+ indexAll: params.needsFullReindex || Boolean(params.targetSessionFiles) || params.sessionsDirtyFiles.size === 0
887
+ };
888
+ }
889
+ //#endregion
890
+ //#region extensions/memory-core/src/memory/manager-source-state.ts
891
+ const MEMORY_SOURCE_FILE_STATE_SQL = `SELECT path, hash FROM files WHERE source = ?`;
892
+ const MEMORY_SOURCE_FILE_HASH_SQL = `SELECT hash FROM files WHERE path = ? AND source = ?`;
893
+ function loadMemorySourceFileState(params) {
894
+ const normalizedRows = params.db.prepare(MEMORY_SOURCE_FILE_STATE_SQL).all(params.source) ?? [];
895
+ return {
896
+ rows: normalizedRows,
897
+ hashes: new Map(normalizedRows.map((row) => [row.path, row.hash]))
898
+ };
899
+ }
900
+ function resolveMemorySourceExistingHash(params) {
901
+ if (params.existingHashes) return params.existingHashes.get(params.path);
902
+ return params.db.prepare(MEMORY_SOURCE_FILE_HASH_SQL).get(params.path, params.source)?.hash;
903
+ }
904
+ //#endregion
905
+ //#region extensions/memory-core/src/memory/manager-targeted-sync.ts
906
+ function clearMemorySyncedSessionFiles(params) {
907
+ if (!params.targetSessionFiles) params.sessionsDirtyFiles.clear();
908
+ else for (const targetSessionFile of params.targetSessionFiles) params.sessionsDirtyFiles.delete(targetSessionFile);
909
+ return params.sessionsDirtyFiles.size > 0;
910
+ }
911
+ async function runMemoryTargetedSessionSync(params) {
912
+ if (!params.hasSessionSource || !params.targetSessionFiles) return {
913
+ handled: false,
914
+ sessionsDirty: params.sessionsDirtyFiles.size > 0
915
+ };
916
+ try {
917
+ await params.syncSessionFiles({
918
+ needsFullReindex: false,
919
+ targetSessionFiles: Array.from(params.targetSessionFiles),
920
+ progress: params.progress
921
+ });
922
+ return {
923
+ handled: true,
924
+ sessionsDirty: clearMemorySyncedSessionFiles({
925
+ sessionsDirtyFiles: params.sessionsDirtyFiles,
926
+ targetSessionFiles: params.targetSessionFiles
927
+ })
928
+ };
929
+ } catch (err) {
930
+ const reason = formatErrorMessage(err);
931
+ if (!(params.shouldFallbackOnError(reason) && await params.activateFallbackProvider(reason))) throw err;
932
+ const reindexParams = {
933
+ reason: params.reason,
934
+ force: true,
935
+ progress: params.progress
936
+ };
937
+ if (params.useUnsafeReindex) await params.runUnsafeReindex(reindexParams);
938
+ else await params.runSafeReindex(reindexParams);
939
+ return {
940
+ handled: true,
941
+ sessionsDirty: params.sessionsDirtyFiles.size > 0
942
+ };
943
+ }
944
+ }
945
+ //#endregion
946
+ //#region extensions/memory-core/src/memory/manager-sync-ops.ts
947
+ const META_KEY = "memory_index_meta_v1";
948
+ const VECTOR_TABLE$2 = "chunks_vec";
949
+ const FTS_TABLE$2 = "chunks_fts";
950
+ const EMBEDDING_CACHE_TABLE$2 = "embedding_cache";
951
+ const SESSION_DIRTY_DEBOUNCE_MS = 5e3;
952
+ const SESSION_DELTA_READ_CHUNK_BYTES = 64 * 1024;
953
+ const VECTOR_LOAD_TIMEOUT_MS = 3e4;
954
+ const IGNORED_MEMORY_WATCH_DIR_NAMES = new Set([
955
+ ".git",
956
+ "node_modules",
957
+ ".pnpm-store",
958
+ ".venv",
959
+ "venv",
960
+ ".tox",
961
+ "__pycache__"
962
+ ]);
963
+ const log$3 = createSubsystemLogger("memory");
964
+ function shouldIgnoreMemoryWatchPath(watchPath, stats, multimodalSettings) {
965
+ const normalized = path.normalize(watchPath);
966
+ if (normalized.split(path.sep).map((segment) => normalizeLowercaseStringOrEmpty(segment)).some((segment) => IGNORED_MEMORY_WATCH_DIR_NAMES.has(segment))) return true;
967
+ if (stats?.isDirectory?.()) return false;
968
+ const extension = normalizeLowercaseStringOrEmpty(path.extname(normalized));
969
+ if (extension.length === 0 || extension === ".md") return false;
970
+ if (!multimodalSettings) return true;
971
+ return classifyMemoryMultimodalPath(normalized, multimodalSettings) === null;
972
+ }
973
+ function runDetachedMemorySync(sync, reason) {
974
+ sync().catch((err) => {
975
+ log$3.warn(`memory sync failed (${reason}): ${String(err)}`);
976
+ });
977
+ }
978
+ var MemoryManagerSyncOps = class {
979
+ constructor() {
980
+ this.provider = null;
981
+ this.sources = /* @__PURE__ */ new Set();
982
+ this.providerKey = null;
983
+ this.fts = {
984
+ enabled: false,
985
+ available: false
986
+ };
987
+ this.vectorReady = null;
988
+ this.watcher = null;
989
+ this.watchTimer = null;
990
+ this.sessionWatchTimer = null;
991
+ this.sessionUnsubscribe = null;
992
+ this.intervalTimer = null;
993
+ this.closed = false;
994
+ this.dirty = false;
995
+ this.sessionsDirty = false;
996
+ this.sessionsDirtyFiles = /* @__PURE__ */ new Set();
997
+ this.sessionPendingFiles = /* @__PURE__ */ new Set();
998
+ this.sessionDeltas = /* @__PURE__ */ new Map();
999
+ this.vectorDegradedWriteWarningShown = false;
1000
+ this.lastMetaSerialized = null;
1001
+ }
1002
+ resetVectorState() {
1003
+ this.vectorReady = null;
1004
+ this.vector.available = null;
1005
+ this.vector.loadError = void 0;
1006
+ this.vector.dims = void 0;
1007
+ this.vectorDegradedWriteWarningShown = false;
1008
+ }
1009
+ async ensureVectorReady(dimensions) {
1010
+ if (!this.vector.enabled) return false;
1011
+ if (!this.vectorReady) this.vectorReady = this.withTimeout(this.loadVectorExtension(), VECTOR_LOAD_TIMEOUT_MS, `sqlite-vec load timed out after ${Math.round(VECTOR_LOAD_TIMEOUT_MS / 1e3)}s`);
1012
+ let ready = false;
1013
+ try {
1014
+ ready = await this.vectorReady || false;
1015
+ } catch (err) {
1016
+ const message = formatErrorMessage(err);
1017
+ this.vector.available = false;
1018
+ this.vector.loadError = message;
1019
+ this.vectorReady = null;
1020
+ log$3.warn(`sqlite-vec unavailable: ${message}`);
1021
+ return false;
1022
+ }
1023
+ if (ready && typeof dimensions === "number" && dimensions > 0) this.ensureVectorTable(dimensions);
1024
+ return ready;
1025
+ }
1026
+ async loadVectorExtension() {
1027
+ if (this.vector.available !== null) return this.vector.available;
1028
+ if (!this.vector.enabled) {
1029
+ this.vector.available = false;
1030
+ return false;
1031
+ }
1032
+ try {
1033
+ const resolvedPath = this.vector.extensionPath?.trim() ? resolveUserPath(this.vector.extensionPath) : void 0;
1034
+ const loaded = await loadSqliteVecExtension({
1035
+ db: this.db,
1036
+ extensionPath: resolvedPath
1037
+ });
1038
+ if (!loaded.ok) throw new Error(loaded.error ?? "unknown sqlite-vec load error");
1039
+ this.vector.extensionPath = loaded.extensionPath;
1040
+ this.vector.available = true;
1041
+ return true;
1042
+ } catch (err) {
1043
+ const message = formatErrorMessage(err);
1044
+ this.vector.available = false;
1045
+ this.vector.loadError = message;
1046
+ log$3.warn(`sqlite-vec unavailable: ${message}`);
1047
+ return false;
1048
+ }
1049
+ }
1050
+ ensureVectorTable(dimensions) {
1051
+ if (this.vector.dims === dimensions) return;
1052
+ if (this.vector.dims && this.vector.dims !== dimensions) this.dropVectorTable();
1053
+ this.db.exec(`CREATE VIRTUAL TABLE IF NOT EXISTS ${VECTOR_TABLE$2} USING vec0(\n id TEXT PRIMARY KEY,\n embedding FLOAT[${dimensions}]\n)`);
1054
+ this.vector.dims = dimensions;
1055
+ }
1056
+ dropVectorTable() {
1057
+ try {
1058
+ this.db.exec(`DROP TABLE IF EXISTS ${VECTOR_TABLE$2}`);
1059
+ } catch (err) {
1060
+ const message = formatErrorMessage(err);
1061
+ log$3.debug(`Failed to drop ${VECTOR_TABLE$2}: ${message}`);
1062
+ }
1063
+ }
1064
+ buildSourceFilter(alias, sourcesOverride) {
1065
+ const sources = sourcesOverride ?? Array.from(this.sources);
1066
+ if (sources.length === 0) return {
1067
+ sql: "",
1068
+ params: []
1069
+ };
1070
+ return {
1071
+ sql: ` AND ${alias ? `${alias}.source` : "source"} IN (${sources.map(() => "?").join(", ")})`,
1072
+ params: sources
1073
+ };
1074
+ }
1075
+ openDatabase() {
1076
+ return openMemoryDatabaseAtPath(resolveUserPath(this.settings.store.path), this.settings.store.vector.enabled);
1077
+ }
1078
+ seedEmbeddingCache(sourceDb) {
1079
+ if (!this.cache.enabled) return;
1080
+ try {
1081
+ const rows = sourceDb.prepare(`SELECT provider, model, provider_key, hash, embedding, dims, updated_at FROM ${EMBEDDING_CACHE_TABLE$2}`).all();
1082
+ if (!rows.length) return;
1083
+ const insert = this.db.prepare(`INSERT INTO ${EMBEDDING_CACHE_TABLE$2} (provider, model, provider_key, hash, embedding, dims, updated_at)
1084
+ VALUES (?, ?, ?, ?, ?, ?, ?)
1085
+ ON CONFLICT(provider, model, provider_key, hash) DO UPDATE SET
1086
+ embedding=excluded.embedding,
1087
+ dims=excluded.dims,
1088
+ updated_at=excluded.updated_at`);
1089
+ this.db.exec("BEGIN");
1090
+ for (const row of rows) insert.run(row.provider, row.model, row.provider_key, row.hash, row.embedding, row.dims, row.updated_at);
1091
+ this.db.exec("COMMIT");
1092
+ } catch (err) {
1093
+ try {
1094
+ this.db.exec("ROLLBACK");
1095
+ } catch {}
1096
+ throw err;
1097
+ }
1098
+ }
1099
+ ensureSchema() {
1100
+ const result = ensureMemoryIndexSchema({
1101
+ db: this.db,
1102
+ embeddingCacheTable: EMBEDDING_CACHE_TABLE$2,
1103
+ cacheEnabled: this.cache.enabled,
1104
+ ftsTable: FTS_TABLE$2,
1105
+ ftsEnabled: this.fts.enabled,
1106
+ ftsTokenizer: this.settings.store.fts.tokenizer
1107
+ });
1108
+ this.fts.available = result.ftsAvailable;
1109
+ if (result.ftsError) {
1110
+ this.fts.loadError = result.ftsError;
1111
+ if (this.fts.enabled) log$3.warn(`fts unavailable: ${result.ftsError}`);
1112
+ }
1113
+ }
1114
+ ensureWatcher() {
1115
+ if (!this.sources.has("memory") || !this.settings.sync.watch || this.watcher) return;
1116
+ const watchPaths = new Set([path.join(this.workspaceDir, "MEMORY.md"), path.join(this.workspaceDir, "memory")]);
1117
+ const additionalPaths = normalizeExtraMemoryPaths(this.workspaceDir, this.settings.extraPaths);
1118
+ for (const entry of additionalPaths) try {
1119
+ const stat = fs.lstatSync(entry);
1120
+ if (stat.isSymbolicLink()) continue;
1121
+ if (stat.isDirectory()) {
1122
+ watchPaths.add(path.join(entry, "**", "*.md"));
1123
+ if (this.settings.multimodal.enabled) for (const modality of this.settings.multimodal.modalities) for (const extension of getMemoryMultimodalExtensions(modality)) watchPaths.add(path.join(entry, "**", buildCaseInsensitiveExtensionGlob(extension)));
1124
+ continue;
1125
+ }
1126
+ if (stat.isFile() && (normalizeLowercaseStringOrEmpty(entry).endsWith(".md") || classifyMemoryMultimodalPath(entry, this.settings.multimodal) !== null)) watchPaths.add(entry);
1127
+ } catch {}
1128
+ this.watcher = chokidar.watch(Array.from(watchPaths), {
1129
+ ignoreInitial: true,
1130
+ ignored: (watchPath, stats) => shouldIgnoreMemoryWatchPath(watchPath, stats, this.settings.multimodal),
1131
+ awaitWriteFinish: {
1132
+ stabilityThreshold: this.settings.sync.watchDebounceMs,
1133
+ pollInterval: 100
1134
+ }
1135
+ });
1136
+ const markDirty = () => {
1137
+ this.dirty = true;
1138
+ this.scheduleWatchSync();
1139
+ };
1140
+ this.watcher.on("add", markDirty);
1141
+ this.watcher.on("change", markDirty);
1142
+ this.watcher.on("unlink", markDirty);
1143
+ }
1144
+ ensureSessionListener() {
1145
+ if (!this.sources.has("sessions") || this.sessionUnsubscribe) return;
1146
+ this.sessionUnsubscribe = onSessionTranscriptUpdate((update) => {
1147
+ if (this.closed) return;
1148
+ const sessionFile = update.sessionFile;
1149
+ if (!this.isSessionFileForAgent(sessionFile)) return;
1150
+ this.scheduleSessionDirty(sessionFile);
1151
+ });
1152
+ }
1153
+ scheduleSessionDirty(sessionFile) {
1154
+ this.sessionPendingFiles.add(sessionFile);
1155
+ if (this.sessionWatchTimer) return;
1156
+ this.sessionWatchTimer = setTimeout(() => {
1157
+ this.sessionWatchTimer = null;
1158
+ this.processSessionDeltaBatch().catch((err) => {
1159
+ log$3.warn(`memory session delta failed: ${String(err)}`);
1160
+ });
1161
+ }, SESSION_DIRTY_DEBOUNCE_MS);
1162
+ }
1163
+ async processSessionDeltaBatch() {
1164
+ if (this.sessionPendingFiles.size === 0) return;
1165
+ const pending = Array.from(this.sessionPendingFiles);
1166
+ this.sessionPendingFiles.clear();
1167
+ let shouldSync = false;
1168
+ for (const sessionFile of pending) {
1169
+ const delta = await this.updateSessionDelta(sessionFile);
1170
+ if (!delta) continue;
1171
+ const bytesThreshold = delta.deltaBytes;
1172
+ const messagesThreshold = delta.deltaMessages;
1173
+ const bytesHit = bytesThreshold <= 0 ? delta.pendingBytes > 0 : delta.pendingBytes >= bytesThreshold;
1174
+ const messagesHit = messagesThreshold <= 0 ? delta.pendingMessages > 0 : delta.pendingMessages >= messagesThreshold;
1175
+ if (!bytesHit && !messagesHit) continue;
1176
+ this.sessionsDirtyFiles.add(sessionFile);
1177
+ this.sessionsDirty = true;
1178
+ delta.pendingBytes = bytesThreshold > 0 ? Math.max(0, delta.pendingBytes - bytesThreshold) : 0;
1179
+ delta.pendingMessages = messagesThreshold > 0 ? Math.max(0, delta.pendingMessages - messagesThreshold) : 0;
1180
+ shouldSync = true;
1181
+ }
1182
+ if (shouldSync) this.sync({ reason: "session-delta" }).catch((err) => {
1183
+ log$3.warn(`memory sync failed (session-delta): ${String(err)}`);
1184
+ });
1185
+ }
1186
+ async updateSessionDelta(sessionFile) {
1187
+ const thresholds = this.settings.sync.sessions;
1188
+ if (!thresholds) return null;
1189
+ let stat;
1190
+ try {
1191
+ stat = await fs$1.stat(sessionFile);
1192
+ } catch {
1193
+ return null;
1194
+ }
1195
+ const size = stat.size;
1196
+ let state = this.sessionDeltas.get(sessionFile);
1197
+ if (!state) {
1198
+ state = {
1199
+ lastSize: 0,
1200
+ pendingBytes: 0,
1201
+ pendingMessages: 0
1202
+ };
1203
+ this.sessionDeltas.set(sessionFile, state);
1204
+ }
1205
+ const deltaBytes = Math.max(0, size - state.lastSize);
1206
+ if (deltaBytes === 0 && size === state.lastSize) return {
1207
+ deltaBytes: thresholds.deltaBytes,
1208
+ deltaMessages: thresholds.deltaMessages,
1209
+ pendingBytes: state.pendingBytes,
1210
+ pendingMessages: state.pendingMessages
1211
+ };
1212
+ if (size < state.lastSize) {
1213
+ state.lastSize = size;
1214
+ state.pendingBytes += size;
1215
+ if (thresholds.deltaMessages > 0 && (thresholds.deltaBytes <= 0 || state.pendingBytes < thresholds.deltaBytes)) state.pendingMessages += await this.countNewlines(sessionFile, 0, size);
1216
+ } else {
1217
+ state.pendingBytes += deltaBytes;
1218
+ if (thresholds.deltaMessages > 0 && (thresholds.deltaBytes <= 0 || state.pendingBytes < thresholds.deltaBytes)) state.pendingMessages += await this.countNewlines(sessionFile, state.lastSize, size);
1219
+ state.lastSize = size;
1220
+ }
1221
+ this.sessionDeltas.set(sessionFile, state);
1222
+ return {
1223
+ deltaBytes: thresholds.deltaBytes,
1224
+ deltaMessages: thresholds.deltaMessages,
1225
+ pendingBytes: state.pendingBytes,
1226
+ pendingMessages: state.pendingMessages
1227
+ };
1228
+ }
1229
+ async countNewlines(absPath, start, end) {
1230
+ if (end <= start) return 0;
1231
+ let handle;
1232
+ try {
1233
+ handle = await fs$1.open(absPath, "r");
1234
+ } catch (err) {
1235
+ if (isFileMissingError(err)) return 0;
1236
+ throw err;
1237
+ }
1238
+ try {
1239
+ let offset = start;
1240
+ let count = 0;
1241
+ const buffer = Buffer.alloc(SESSION_DELTA_READ_CHUNK_BYTES);
1242
+ while (offset < end) {
1243
+ const toRead = Math.min(buffer.length, end - offset);
1244
+ const { bytesRead } = await handle.read(buffer, 0, toRead, offset);
1245
+ if (bytesRead <= 0) break;
1246
+ for (let i = 0; i < bytesRead; i += 1) if (buffer[i] === 10) count += 1;
1247
+ offset += bytesRead;
1248
+ }
1249
+ return count;
1250
+ } finally {
1251
+ await handle.close();
1252
+ }
1253
+ }
1254
+ resetSessionDelta(absPath, size) {
1255
+ const state = this.sessionDeltas.get(absPath);
1256
+ if (!state) return;
1257
+ state.lastSize = size;
1258
+ state.pendingBytes = 0;
1259
+ state.pendingMessages = 0;
1260
+ }
1261
+ isSessionFileForAgent(sessionFile) {
1262
+ if (!sessionFile) return false;
1263
+ const sessionsDir = resolveSessionTranscriptsDirForAgent(this.agentId);
1264
+ const resolvedFile = path.resolve(sessionFile);
1265
+ const resolvedDir = path.resolve(sessionsDir);
1266
+ return resolvedFile.startsWith(`${resolvedDir}${path.sep}`);
1267
+ }
1268
+ normalizeTargetSessionFiles(sessionFiles) {
1269
+ if (!sessionFiles || sessionFiles.length === 0) return null;
1270
+ const normalized = /* @__PURE__ */ new Set();
1271
+ for (const sessionFile of sessionFiles) {
1272
+ const trimmed = sessionFile.trim();
1273
+ if (!trimmed) continue;
1274
+ const resolved = path.resolve(trimmed);
1275
+ if (this.isSessionFileForAgent(resolved)) normalized.add(resolved);
1276
+ }
1277
+ return normalized.size > 0 ? normalized : null;
1278
+ }
1279
+ ensureIntervalSync() {
1280
+ const minutes = this.settings.sync.intervalMinutes;
1281
+ if (!minutes || minutes <= 0 || this.intervalTimer) return;
1282
+ const ms = minutes * 60 * 1e3;
1283
+ this.intervalTimer = setInterval(() => {
1284
+ runDetachedMemorySync(() => this.sync({ reason: "interval" }), "interval");
1285
+ }, ms);
1286
+ }
1287
+ scheduleWatchSync() {
1288
+ if (!this.sources.has("memory") || !this.settings.sync.watch) return;
1289
+ if (this.watchTimer) clearTimeout(this.watchTimer);
1290
+ this.watchTimer = setTimeout(() => {
1291
+ this.watchTimer = null;
1292
+ runDetachedMemorySync(() => this.sync({ reason: "watch" }), "watch");
1293
+ }, this.settings.sync.watchDebounceMs);
1294
+ }
1295
+ shouldSyncSessions(params, needsFullReindex = false) {
1296
+ return shouldSyncSessionsForReindex({
1297
+ hasSessionSource: this.sources.has("sessions"),
1298
+ sessionsDirty: this.sessionsDirty,
1299
+ dirtySessionFileCount: this.sessionsDirtyFiles.size,
1300
+ sync: params,
1301
+ needsFullReindex
1302
+ });
1303
+ }
1304
+ async syncMemoryFiles(params) {
1305
+ const deleteFileByPathAndSource = this.db.prepare(`DELETE FROM files WHERE path = ? AND source = ?`);
1306
+ const deleteChunksByPathAndSource = this.db.prepare(`DELETE FROM chunks WHERE path = ? AND source = ?`);
1307
+ const deleteVectorRowsByPathAndSource = this.vector.enabled && this.vector.available ? this.db.prepare(`DELETE FROM ${VECTOR_TABLE$2} WHERE id IN (SELECT id FROM chunks WHERE path = ? AND source = ?)`) : null;
1308
+ const deleteFtsRowsByPathAndSource = this.fts.enabled && this.fts.available ? this.db.prepare(`DELETE FROM ${FTS_TABLE$2} WHERE path = ? AND source = ?`) : null;
1309
+ const fileEntries = (await runWithConcurrency((await listMemoryFiles(this.workspaceDir, this.settings.extraPaths, this.settings.multimodal)).map((file) => async () => await buildFileEntry(file, this.workspaceDir, this.settings.multimodal)), this.getIndexConcurrency())).filter((entry) => entry !== null);
1310
+ log$3.debug("memory sync: indexing memory files", {
1311
+ files: fileEntries.length,
1312
+ needsFullReindex: params.needsFullReindex,
1313
+ batch: this.batch.enabled,
1314
+ concurrency: this.getIndexConcurrency()
1315
+ });
1316
+ const existingState = loadMemorySourceFileState({
1317
+ db: this.db,
1318
+ source: "memory"
1319
+ });
1320
+ const existingRows = existingState.rows;
1321
+ const existingHashes = existingState.hashes;
1322
+ const activePaths = new Set(fileEntries.map((entry) => entry.path));
1323
+ if (params.progress) {
1324
+ params.progress.total += fileEntries.length;
1325
+ params.progress.report({
1326
+ completed: params.progress.completed,
1327
+ total: params.progress.total,
1328
+ label: this.batch.enabled ? "Indexing memory files (batch)..." : "Indexing memory files…"
1329
+ });
1330
+ }
1331
+ await runWithConcurrency(fileEntries.map((entry) => async () => {
1332
+ if (!params.needsFullReindex && existingHashes.get(entry.path) === entry.hash) {
1333
+ if (params.progress) {
1334
+ params.progress.completed += 1;
1335
+ params.progress.report({
1336
+ completed: params.progress.completed,
1337
+ total: params.progress.total
1338
+ });
1339
+ }
1340
+ return;
1341
+ }
1342
+ await this.indexFile(entry, { source: "memory" });
1343
+ if (params.progress) {
1344
+ params.progress.completed += 1;
1345
+ params.progress.report({
1346
+ completed: params.progress.completed,
1347
+ total: params.progress.total
1348
+ });
1349
+ }
1350
+ }), this.getIndexConcurrency());
1351
+ for (const stale of existingRows) {
1352
+ if (activePaths.has(stale.path)) continue;
1353
+ deleteFileByPathAndSource.run(stale.path, "memory");
1354
+ if (deleteVectorRowsByPathAndSource) try {
1355
+ deleteVectorRowsByPathAndSource.run(stale.path, "memory");
1356
+ } catch {}
1357
+ deleteChunksByPathAndSource.run(stale.path, "memory");
1358
+ if (deleteFtsRowsByPathAndSource) try {
1359
+ deleteFtsRowsByPathAndSource.run(stale.path, "memory");
1360
+ } catch {}
1361
+ }
1362
+ }
1363
+ async syncSessionFiles(params) {
1364
+ const deleteFileByPathAndSource = this.db.prepare(`DELETE FROM files WHERE path = ? AND source = ?`);
1365
+ const deleteChunksByPathAndSource = this.db.prepare(`DELETE FROM chunks WHERE path = ? AND source = ?`);
1366
+ const deleteVectorRowsByPathAndSource = this.vector.enabled && this.vector.available ? this.db.prepare(`DELETE FROM ${VECTOR_TABLE$2} WHERE id IN (SELECT id FROM chunks WHERE path = ? AND source = ?)`) : null;
1367
+ const deleteFtsRowsByPathSourceAndModel = this.fts.enabled && this.fts.available ? this.db.prepare(`DELETE FROM ${FTS_TABLE$2} WHERE path = ? AND source = ? AND model = ?`) : null;
1368
+ const targetSessionFiles = params.needsFullReindex ? null : this.normalizeTargetSessionFiles(params.targetSessionFiles);
1369
+ const files = targetSessionFiles ? Array.from(targetSessionFiles) : await listSessionFilesForAgent(this.agentId);
1370
+ const { activePaths, existingRows, existingHashes, indexAll } = resolveMemorySessionSyncPlan({
1371
+ needsFullReindex: params.needsFullReindex,
1372
+ files,
1373
+ targetSessionFiles,
1374
+ sessionsDirtyFiles: this.sessionsDirtyFiles,
1375
+ existingRows: targetSessionFiles ? null : loadMemorySourceFileState({
1376
+ db: this.db,
1377
+ source: "sessions"
1378
+ }).rows,
1379
+ sessionPathForFile
1380
+ });
1381
+ log$3.debug("memory sync: indexing session files", {
1382
+ files: files.length,
1383
+ indexAll,
1384
+ dirtyFiles: this.sessionsDirtyFiles.size,
1385
+ targetedFiles: targetSessionFiles?.size ?? 0,
1386
+ batch: this.batch.enabled,
1387
+ concurrency: this.getIndexConcurrency()
1388
+ });
1389
+ if (params.progress) {
1390
+ params.progress.total += files.length;
1391
+ params.progress.report({
1392
+ completed: params.progress.completed,
1393
+ total: params.progress.total,
1394
+ label: this.batch.enabled ? "Indexing session files (batch)..." : "Indexing session files…"
1395
+ });
1396
+ }
1397
+ await runWithConcurrency(files.map((absPath) => async () => {
1398
+ if (!indexAll && !this.sessionsDirtyFiles.has(absPath)) {
1399
+ if (params.progress) {
1400
+ params.progress.completed += 1;
1401
+ params.progress.report({
1402
+ completed: params.progress.completed,
1403
+ total: params.progress.total
1404
+ });
1405
+ }
1406
+ return;
1407
+ }
1408
+ const entry = await buildSessionEntry(absPath);
1409
+ if (!entry) {
1410
+ if (params.progress) {
1411
+ params.progress.completed += 1;
1412
+ params.progress.report({
1413
+ completed: params.progress.completed,
1414
+ total: params.progress.total
1415
+ });
1416
+ }
1417
+ return;
1418
+ }
1419
+ const existingHash = resolveMemorySourceExistingHash({
1420
+ db: this.db,
1421
+ source: "sessions",
1422
+ path: entry.path,
1423
+ existingHashes
1424
+ });
1425
+ if (!params.needsFullReindex && existingHash === entry.hash) {
1426
+ if (params.progress) {
1427
+ params.progress.completed += 1;
1428
+ params.progress.report({
1429
+ completed: params.progress.completed,
1430
+ total: params.progress.total
1431
+ });
1432
+ }
1433
+ this.resetSessionDelta(absPath, entry.size);
1434
+ return;
1435
+ }
1436
+ await this.indexFile(entry, {
1437
+ source: "sessions",
1438
+ content: entry.content
1439
+ });
1440
+ this.resetSessionDelta(absPath, entry.size);
1441
+ if (params.progress) {
1442
+ params.progress.completed += 1;
1443
+ params.progress.report({
1444
+ completed: params.progress.completed,
1445
+ total: params.progress.total
1446
+ });
1447
+ }
1448
+ }), this.getIndexConcurrency());
1449
+ if (activePaths === null) return;
1450
+ for (const stale of existingRows ?? []) {
1451
+ if (activePaths.has(stale.path)) continue;
1452
+ deleteFileByPathAndSource.run(stale.path, "sessions");
1453
+ if (deleteVectorRowsByPathAndSource) try {
1454
+ deleteVectorRowsByPathAndSource.run(stale.path, "sessions");
1455
+ } catch {}
1456
+ deleteChunksByPathAndSource.run(stale.path, "sessions");
1457
+ if (deleteFtsRowsByPathSourceAndModel) try {
1458
+ deleteFtsRowsByPathSourceAndModel.run(stale.path, "sessions", this.provider?.model ?? "fts-only");
1459
+ } catch {}
1460
+ }
1461
+ }
1462
+ createSyncProgress(onProgress) {
1463
+ const state = {
1464
+ completed: 0,
1465
+ total: 0,
1466
+ label: void 0,
1467
+ report: (update) => {
1468
+ if (update.label) state.label = update.label;
1469
+ const label = update.total > 0 && state.label ? `${state.label} ${update.completed}/${update.total}` : state.label;
1470
+ onProgress({
1471
+ completed: update.completed,
1472
+ total: update.total,
1473
+ label
1474
+ });
1475
+ }
1476
+ };
1477
+ return state;
1478
+ }
1479
+ async runSync(params) {
1480
+ const progress = params?.progress ? this.createSyncProgress(params.progress) : void 0;
1481
+ if (progress) progress.report({
1482
+ completed: progress.completed,
1483
+ total: progress.total,
1484
+ label: "Loading vector extension…"
1485
+ });
1486
+ const vectorReady = await this.ensureVectorReady();
1487
+ const meta = this.readMeta();
1488
+ const configuredSources = resolveConfiguredSourcesForMeta(this.sources);
1489
+ const configuredScopeHash = resolveConfiguredScopeHash({
1490
+ workspaceDir: this.workspaceDir,
1491
+ extraPaths: this.settings.extraPaths,
1492
+ multimodal: {
1493
+ enabled: this.settings.multimodal.enabled,
1494
+ modalities: this.settings.multimodal.modalities,
1495
+ maxFileBytes: this.settings.multimodal.maxFileBytes
1496
+ }
1497
+ });
1498
+ const targetSessionFiles = this.normalizeTargetSessionFiles(params?.sessionFiles);
1499
+ const hasTargetSessionFiles = targetSessionFiles !== null;
1500
+ const targetedSessionSync = await runMemoryTargetedSessionSync({
1501
+ hasSessionSource: this.sources.has("sessions"),
1502
+ targetSessionFiles,
1503
+ reason: params?.reason,
1504
+ progress: progress ?? void 0,
1505
+ useUnsafeReindex: process.env.GENESIS_TEST_FAST === "1" && process.env.GENESIS_TEST_MEMORY_UNSAFE_REINDEX === "1",
1506
+ sessionsDirtyFiles: this.sessionsDirtyFiles,
1507
+ syncSessionFiles: async (targetedParams) => {
1508
+ await this.syncSessionFiles(targetedParams);
1509
+ },
1510
+ shouldFallbackOnError: (message) => this.shouldFallbackOnError(message),
1511
+ activateFallbackProvider: async (reason) => await this.activateFallbackProvider(reason),
1512
+ runSafeReindex: async (reindexParams) => {
1513
+ await this.runSafeReindex(reindexParams);
1514
+ },
1515
+ runUnsafeReindex: async (reindexParams) => {
1516
+ await this.runUnsafeReindex(reindexParams);
1517
+ }
1518
+ });
1519
+ if (targetedSessionSync.handled) {
1520
+ this.sessionsDirty = targetedSessionSync.sessionsDirty;
1521
+ return;
1522
+ }
1523
+ const needsFullReindex = params?.force && !hasTargetSessionFiles || shouldRunFullMemoryReindex({
1524
+ meta,
1525
+ provider: this.provider ? {
1526
+ id: this.provider.id,
1527
+ model: this.provider.model
1528
+ } : null,
1529
+ providerKey: this.providerKey ?? void 0,
1530
+ configuredSources,
1531
+ configuredScopeHash,
1532
+ chunkTokens: this.settings.chunking.tokens,
1533
+ chunkOverlap: this.settings.chunking.overlap,
1534
+ vectorReady,
1535
+ ftsTokenizer: this.settings.store.fts.tokenizer
1536
+ });
1537
+ try {
1538
+ if (needsFullReindex) {
1539
+ if (process.env.GENESIS_TEST_FAST === "1" && process.env.GENESIS_TEST_MEMORY_UNSAFE_REINDEX === "1") await this.runUnsafeReindex({
1540
+ reason: params?.reason,
1541
+ force: params?.force,
1542
+ progress: progress ?? void 0
1543
+ });
1544
+ else await this.runSafeReindex({
1545
+ reason: params?.reason,
1546
+ force: params?.force,
1547
+ progress: progress ?? void 0
1548
+ });
1549
+ return;
1550
+ }
1551
+ const shouldSyncMemory = this.sources.has("memory") && (!hasTargetSessionFiles && params?.force || needsFullReindex || this.dirty);
1552
+ const shouldSyncSessions = this.shouldSyncSessions(params, needsFullReindex);
1553
+ if (shouldSyncMemory) {
1554
+ await this.syncMemoryFiles({
1555
+ needsFullReindex,
1556
+ progress: progress ?? void 0
1557
+ });
1558
+ this.dirty = false;
1559
+ }
1560
+ if (shouldSyncSessions) {
1561
+ await this.syncSessionFiles({
1562
+ needsFullReindex,
1563
+ targetSessionFiles: targetSessionFiles ? Array.from(targetSessionFiles) : void 0,
1564
+ progress: progress ?? void 0
1565
+ });
1566
+ this.sessionsDirty = false;
1567
+ this.sessionsDirtyFiles.clear();
1568
+ } else if (this.sessionsDirtyFiles.size > 0) this.sessionsDirty = true;
1569
+ else this.sessionsDirty = false;
1570
+ } catch (err) {
1571
+ const reason = formatErrorMessage(err);
1572
+ if (this.shouldFallbackOnError(reason) && await this.activateFallbackProvider(reason)) {
1573
+ await this.runSafeReindex({
1574
+ reason: params?.reason ?? "fallback",
1575
+ force: true,
1576
+ progress: progress ?? void 0
1577
+ });
1578
+ return;
1579
+ }
1580
+ throw err;
1581
+ }
1582
+ }
1583
+ shouldFallbackOnError(message) {
1584
+ return /embedding|embeddings|batch/i.test(message);
1585
+ }
1586
+ resolveBatchConfig() {
1587
+ const batch = this.settings.remote?.batch;
1588
+ return {
1589
+ enabled: Boolean(batch?.enabled && this.provider && this.providerRuntime?.batchEmbed),
1590
+ wait: batch?.wait ?? true,
1591
+ concurrency: Math.max(1, batch?.concurrency ?? 2),
1592
+ pollIntervalMs: batch?.pollIntervalMs ?? 2e3,
1593
+ timeoutMs: (batch?.timeoutMinutes ?? 60) * 60 * 1e3
1594
+ };
1595
+ }
1596
+ async activateFallbackProvider(reason) {
1597
+ const fallbackRequest = resolveMemoryFallbackProviderRequest({
1598
+ cfg: this.cfg,
1599
+ settings: this.settings,
1600
+ currentProviderId: this.provider?.id ?? null
1601
+ });
1602
+ if (!fallbackRequest || !this.provider) return false;
1603
+ if (this.fallbackFrom) return false;
1604
+ const fallbackFrom = this.provider.id;
1605
+ const fallbackResult = await createEmbeddingProvider({
1606
+ config: this.cfg,
1607
+ agentDir: resolveAgentDir(this.cfg, this.agentId),
1608
+ ...fallbackRequest
1609
+ });
1610
+ const fallbackState = applyMemoryFallbackProviderState({
1611
+ current: {
1612
+ provider: this.provider,
1613
+ fallbackFrom: this.fallbackFrom,
1614
+ fallbackReason: this.fallbackReason,
1615
+ providerUnavailableReason: void 0,
1616
+ providerRuntime: this.providerRuntime
1617
+ },
1618
+ fallbackFrom,
1619
+ reason,
1620
+ result: fallbackResult
1621
+ });
1622
+ this.fallbackFrom = fallbackState.fallbackFrom;
1623
+ this.fallbackReason = fallbackState.fallbackReason;
1624
+ this.provider = fallbackState.provider;
1625
+ this.providerRuntime = fallbackState.providerRuntime;
1626
+ this.providerKey = this.computeProviderKey();
1627
+ this.batch = this.resolveBatchConfig();
1628
+ log$3.warn(`memory embeddings: switched to fallback provider (${fallbackRequest.provider})`, { reason });
1629
+ return true;
1630
+ }
1631
+ async runSafeReindex(params) {
1632
+ const dbPath = resolveUserPath(this.settings.store.path);
1633
+ const tempDbPath = `${dbPath}.tmp-${randomUUID()}`;
1634
+ const tempDb = openMemoryDatabaseAtPath(tempDbPath, this.settings.store.vector.enabled);
1635
+ const originalDb = this.db;
1636
+ let originalDbClosed = false;
1637
+ const originalState = {
1638
+ ftsAvailable: this.fts.available,
1639
+ ftsError: this.fts.loadError,
1640
+ vectorAvailable: this.vector.available,
1641
+ vectorLoadError: this.vector.loadError,
1642
+ vectorDims: this.vector.dims,
1643
+ vectorDegradedWriteWarningShown: this.vectorDegradedWriteWarningShown,
1644
+ vectorReady: this.vectorReady
1645
+ };
1646
+ const restoreOriginalState = () => {
1647
+ if (originalDbClosed) this.db = openMemoryDatabaseAtPath(dbPath, this.settings.store.vector.enabled);
1648
+ else this.db = originalDb;
1649
+ this.fts.available = originalState.ftsAvailable;
1650
+ this.fts.loadError = originalState.ftsError;
1651
+ this.vector.available = originalDbClosed ? null : originalState.vectorAvailable;
1652
+ this.vector.loadError = originalState.vectorLoadError;
1653
+ this.vector.dims = originalState.vectorDims;
1654
+ this.vectorDegradedWriteWarningShown = originalState.vectorDegradedWriteWarningShown;
1655
+ this.vectorReady = originalDbClosed ? null : originalState.vectorReady;
1656
+ };
1657
+ this.db = tempDb;
1658
+ this.resetVectorState();
1659
+ this.fts.available = false;
1660
+ this.fts.loadError = void 0;
1661
+ this.ensureSchema();
1662
+ let nextMeta = null;
1663
+ try {
1664
+ nextMeta = await runMemoryAtomicReindex({
1665
+ targetPath: dbPath,
1666
+ tempPath: tempDbPath,
1667
+ build: async () => {
1668
+ this.seedEmbeddingCache(originalDb);
1669
+ const shouldSyncMemory = this.sources.has("memory");
1670
+ const shouldSyncSessions = this.shouldSyncSessions({
1671
+ reason: params.reason,
1672
+ force: params.force
1673
+ }, true);
1674
+ if (shouldSyncMemory) {
1675
+ await this.syncMemoryFiles({
1676
+ needsFullReindex: true,
1677
+ progress: params.progress
1678
+ });
1679
+ this.dirty = false;
1680
+ }
1681
+ if (shouldSyncSessions) {
1682
+ await this.syncSessionFiles({
1683
+ needsFullReindex: true,
1684
+ progress: params.progress
1685
+ });
1686
+ this.sessionsDirty = false;
1687
+ this.sessionsDirtyFiles.clear();
1688
+ } else if (this.sessionsDirtyFiles.size > 0) this.sessionsDirty = true;
1689
+ else this.sessionsDirty = false;
1690
+ const meta = {
1691
+ model: this.provider?.model ?? "fts-only",
1692
+ provider: this.provider?.id ?? "none",
1693
+ providerKey: this.providerKey,
1694
+ sources: resolveConfiguredSourcesForMeta(this.sources),
1695
+ scopeHash: resolveConfiguredScopeHash({
1696
+ workspaceDir: this.workspaceDir,
1697
+ extraPaths: this.settings.extraPaths,
1698
+ multimodal: {
1699
+ enabled: this.settings.multimodal.enabled,
1700
+ modalities: this.settings.multimodal.modalities,
1701
+ maxFileBytes: this.settings.multimodal.maxFileBytes
1702
+ }
1703
+ }),
1704
+ chunkTokens: this.settings.chunking.tokens,
1705
+ chunkOverlap: this.settings.chunking.overlap,
1706
+ ftsTokenizer: this.settings.store.fts.tokenizer
1707
+ };
1708
+ if (this.vector.available && this.vector.dims) meta.vectorDims = this.vector.dims;
1709
+ this.writeMeta(meta);
1710
+ this.pruneEmbeddingCacheIfNeeded?.();
1711
+ this.db.close();
1712
+ originalDb.close();
1713
+ originalDbClosed = true;
1714
+ return meta;
1715
+ }
1716
+ });
1717
+ this.db = openMemoryDatabaseAtPath(dbPath, this.settings.store.vector.enabled);
1718
+ this.resetVectorState();
1719
+ this.ensureSchema();
1720
+ this.vector.dims = nextMeta?.vectorDims;
1721
+ } catch (err) {
1722
+ try {
1723
+ this.db.close();
1724
+ } catch {}
1725
+ restoreOriginalState();
1726
+ throw err;
1727
+ }
1728
+ }
1729
+ async runUnsafeReindex(params) {
1730
+ this.resetIndex();
1731
+ const shouldSyncMemory = this.sources.has("memory");
1732
+ const shouldSyncSessions = this.shouldSyncSessions({
1733
+ reason: params.reason,
1734
+ force: params.force
1735
+ }, true);
1736
+ if (shouldSyncMemory) {
1737
+ await this.syncMemoryFiles({
1738
+ needsFullReindex: true,
1739
+ progress: params.progress
1740
+ });
1741
+ this.dirty = false;
1742
+ }
1743
+ if (shouldSyncSessions) {
1744
+ await this.syncSessionFiles({
1745
+ needsFullReindex: true,
1746
+ progress: params.progress
1747
+ });
1748
+ this.sessionsDirty = false;
1749
+ this.sessionsDirtyFiles.clear();
1750
+ } else if (this.sessionsDirtyFiles.size > 0) this.sessionsDirty = true;
1751
+ else this.sessionsDirty = false;
1752
+ const nextMeta = {
1753
+ model: this.provider?.model ?? "fts-only",
1754
+ provider: this.provider?.id ?? "none",
1755
+ providerKey: this.providerKey,
1756
+ sources: resolveConfiguredSourcesForMeta(this.sources),
1757
+ scopeHash: resolveConfiguredScopeHash({
1758
+ workspaceDir: this.workspaceDir,
1759
+ extraPaths: this.settings.extraPaths,
1760
+ multimodal: {
1761
+ enabled: this.settings.multimodal.enabled,
1762
+ modalities: this.settings.multimodal.modalities,
1763
+ maxFileBytes: this.settings.multimodal.maxFileBytes
1764
+ }
1765
+ }),
1766
+ chunkTokens: this.settings.chunking.tokens,
1767
+ chunkOverlap: this.settings.chunking.overlap,
1768
+ ftsTokenizer: this.settings.store.fts.tokenizer
1769
+ };
1770
+ if (this.vector.available && this.vector.dims) nextMeta.vectorDims = this.vector.dims;
1771
+ this.writeMeta(nextMeta);
1772
+ this.pruneEmbeddingCacheIfNeeded?.();
1773
+ }
1774
+ resetIndex() {
1775
+ this.db.exec(`DELETE FROM files`);
1776
+ this.db.exec(`DELETE FROM chunks`);
1777
+ if (this.fts.enabled && this.fts.available) try {
1778
+ this.db.exec(`DROP TABLE IF EXISTS ${FTS_TABLE$2}`);
1779
+ } catch {}
1780
+ this.ensureSchema();
1781
+ this.dropVectorTable();
1782
+ this.vector.dims = void 0;
1783
+ this.sessionsDirtyFiles.clear();
1784
+ }
1785
+ readMeta() {
1786
+ const row = this.db.prepare(`SELECT value FROM meta WHERE key = ?`).get(META_KEY);
1787
+ if (!row?.value) {
1788
+ this.lastMetaSerialized = null;
1789
+ return null;
1790
+ }
1791
+ try {
1792
+ const parsed = JSON.parse(row.value);
1793
+ this.lastMetaSerialized = row.value;
1794
+ return parsed;
1795
+ } catch {
1796
+ this.lastMetaSerialized = null;
1797
+ return null;
1798
+ }
1799
+ }
1800
+ writeMeta(meta) {
1801
+ const value = JSON.stringify(meta);
1802
+ if (this.lastMetaSerialized === value) return;
1803
+ this.db.prepare(`INSERT INTO meta (key, value) VALUES (?, ?) ON CONFLICT(key) DO UPDATE SET value=excluded.value`).run(META_KEY, value);
1804
+ this.lastMetaSerialized = value;
1805
+ }
1806
+ };
1807
+ //#endregion
1808
+ //#region extensions/memory-core/src/memory/manager-vector-warning.ts
1809
+ function logMemoryVectorDegradedWrite(params) {
1810
+ if (!params.vectorEnabled || params.vectorReady || params.chunkCount <= 0 || params.warningShown) return params.warningShown;
1811
+ const errDetail = params.loadError ? `: ${params.loadError}` : "";
1812
+ params.warn(`chunks_vec not updated — sqlite-vec unavailable${errDetail}. Vector recall degraded. Further duplicate warnings suppressed.`);
1813
+ return true;
1814
+ }
1815
+ //#endregion
1816
+ //#region extensions/memory-core/src/memory/manager-vector-write.ts
1817
+ const vectorToBlob$1 = (embedding) => Buffer.from(new Float32Array(embedding).buffer);
1818
+ function replaceMemoryVectorRow(params) {
1819
+ const tableName = params.tableName ?? "chunks_vec";
1820
+ try {
1821
+ params.db.prepare(`DELETE FROM ${tableName} WHERE id = ?`).run(params.id);
1822
+ } catch {}
1823
+ params.db.prepare(`INSERT INTO ${tableName} (id, embedding) VALUES (?, ?)`).run(params.id, vectorToBlob$1(params.embedding));
1824
+ }
1825
+ //#endregion
1826
+ //#region extensions/memory-core/src/memory/manager-embedding-ops.ts
1827
+ const VECTOR_TABLE$1 = "chunks_vec";
1828
+ const FTS_TABLE$1 = "chunks_fts";
1829
+ const EMBEDDING_CACHE_TABLE$1 = "embedding_cache";
1830
+ const EMBEDDING_BATCH_MAX_TOKENS = 8e3;
1831
+ const EMBEDDING_INDEX_CONCURRENCY = 4;
1832
+ const EMBEDDING_RETRY_MAX_ATTEMPTS = 3;
1833
+ const EMBEDDING_RETRY_BASE_DELAY_MS = 500;
1834
+ const EMBEDDING_RETRY_MAX_DELAY_MS = 8e3;
1835
+ const EMBEDDING_QUERY_TIMEOUT_REMOTE_MS = 6e4;
1836
+ const EMBEDDING_QUERY_TIMEOUT_LOCAL_MS = 5 * 6e4;
1837
+ const EMBEDDING_BATCH_TIMEOUT_REMOTE_MS = 2 * 6e4;
1838
+ const EMBEDDING_BATCH_TIMEOUT_LOCAL_MS = 10 * 6e4;
1839
+ const log$2 = createSubsystemLogger("memory");
1840
+ var MemoryManagerEmbeddingOps = class extends MemoryManagerSyncOps {
1841
+ pruneEmbeddingCacheIfNeeded() {
1842
+ if (!this.cache.enabled) return;
1843
+ const max = this.cache.maxEntries;
1844
+ if (!max || max <= 0) return;
1845
+ const count = this.db.prepare(`SELECT COUNT(*) as c FROM ${EMBEDDING_CACHE_TABLE$1}`).get()?.c ?? 0;
1846
+ if (count <= max) return;
1847
+ const excess = count - max;
1848
+ this.db.prepare(`DELETE FROM ${EMBEDDING_CACHE_TABLE$1}\n WHERE rowid IN (\n SELECT rowid FROM ${EMBEDDING_CACHE_TABLE$1}\n ORDER BY updated_at ASC\n LIMIT ?\n )`).run(excess);
1849
+ }
1850
+ async embedChunksInBatches(chunks) {
1851
+ if (chunks.length === 0) return [];
1852
+ const { embeddings, missing } = this.collectCachedEmbeddings(chunks);
1853
+ if (missing.length === 0) return embeddings;
1854
+ const batches = buildMemoryEmbeddingBatches(missing.map((m) => m.chunk), EMBEDDING_BATCH_MAX_TOKENS);
1855
+ const toCache = [];
1856
+ const provider = this.provider;
1857
+ if (!provider) throw new Error("Cannot embed batch in FTS-only mode (no embedding provider)");
1858
+ let cursor = 0;
1859
+ for (const batch of batches) {
1860
+ const inputs = buildTextEmbeddingInputs(batch);
1861
+ const hasStructuredInputs = inputs.some((input) => hasNonTextEmbeddingParts(input));
1862
+ if (hasStructuredInputs && !provider.embedBatchInputs) throw new Error(`Embedding provider "${provider.id}" does not support multimodal memory inputs.`);
1863
+ const batchEmbeddings = hasStructuredInputs ? await this.embedBatchInputsWithRetry(inputs) : await this.embedBatchWithRetry(batch.map((chunk) => chunk.text));
1864
+ for (let i = 0; i < batch.length; i += 1) {
1865
+ const item = missing[cursor + i];
1866
+ const embedding = batchEmbeddings[i] ?? [];
1867
+ if (item) {
1868
+ embeddings[item.index] = embedding;
1869
+ toCache.push({
1870
+ hash: item.chunk.hash,
1871
+ embedding
1872
+ });
1873
+ }
1874
+ }
1875
+ cursor += batch.length;
1876
+ }
1877
+ upsertMemoryEmbeddingCache({
1878
+ db: this.db,
1879
+ enabled: this.cache.enabled,
1880
+ provider: this.provider,
1881
+ providerKey: this.providerKey,
1882
+ entries: toCache,
1883
+ tableName: EMBEDDING_CACHE_TABLE$1
1884
+ });
1885
+ return embeddings;
1886
+ }
1887
+ computeProviderKey() {
1888
+ if (!this.provider) return hashText(JSON.stringify({
1889
+ provider: "none",
1890
+ model: "fts-only"
1891
+ }));
1892
+ if (this.providerRuntime?.cacheKeyData) return hashText(JSON.stringify(this.providerRuntime.cacheKeyData));
1893
+ return hashText(JSON.stringify({
1894
+ provider: this.provider.id,
1895
+ model: this.provider.model
1896
+ }));
1897
+ }
1898
+ buildBatchDebug(source, chunks) {
1899
+ return (message, data) => log$2.debug(message, data ? {
1900
+ ...data,
1901
+ source,
1902
+ chunks: chunks.length
1903
+ } : {
1904
+ source,
1905
+ chunks: chunks.length
1906
+ });
1907
+ }
1908
+ async embedChunksWithBatch(chunks, _entry, source) {
1909
+ const provider = this.provider;
1910
+ const batchEmbed = this.providerRuntime?.batchEmbed;
1911
+ if (!provider || !batchEmbed) return this.embedChunksInBatches(chunks);
1912
+ if (chunks.length === 0) return [];
1913
+ const { embeddings, missing } = this.collectCachedEmbeddings(chunks);
1914
+ if (missing.length === 0) return embeddings;
1915
+ const missingChunks = missing.map((item) => item.chunk);
1916
+ const batchResult = await this.runBatchWithFallback({
1917
+ provider: provider.id,
1918
+ run: async () => await batchEmbed({
1919
+ agentId: this.agentId,
1920
+ chunks: missingChunks,
1921
+ wait: this.batch.wait,
1922
+ concurrency: this.batch.concurrency,
1923
+ pollIntervalMs: this.batch.pollIntervalMs,
1924
+ timeoutMs: this.batch.timeoutMs,
1925
+ debug: this.buildBatchDebug(source, chunks)
1926
+ }),
1927
+ fallback: async () => await this.embedChunksInBatches(chunks)
1928
+ });
1929
+ if (!batchResult) return this.embedChunksInBatches(chunks);
1930
+ const toCache = [];
1931
+ for (let index = 0; index < missing.length; index += 1) {
1932
+ const item = missing[index];
1933
+ const embedding = batchResult[index] ?? [];
1934
+ if (!item) continue;
1935
+ embeddings[item.index] = embedding;
1936
+ toCache.push({
1937
+ hash: item.chunk.hash,
1938
+ embedding
1939
+ });
1940
+ }
1941
+ upsertMemoryEmbeddingCache({
1942
+ db: this.db,
1943
+ enabled: this.cache.enabled,
1944
+ provider,
1945
+ providerKey: this.providerKey,
1946
+ entries: toCache,
1947
+ tableName: EMBEDDING_CACHE_TABLE$1
1948
+ });
1949
+ return embeddings;
1950
+ }
1951
+ collectCachedEmbeddings(chunks) {
1952
+ return collectMemoryCachedEmbeddings({
1953
+ chunks,
1954
+ cached: loadMemoryEmbeddingCache({
1955
+ db: this.db,
1956
+ enabled: this.cache.enabled,
1957
+ provider: this.provider,
1958
+ providerKey: this.providerKey,
1959
+ hashes: chunks.map((chunk) => chunk.hash),
1960
+ tableName: EMBEDDING_CACHE_TABLE$1
1961
+ })
1962
+ });
1963
+ }
1964
+ async embedBatchWithRetry(texts) {
1965
+ if (texts.length === 0) return [];
1966
+ const provider = this.provider;
1967
+ if (!provider) throw new Error("Cannot embed batch in FTS-only mode (no embedding provider)");
1968
+ return await runMemoryEmbeddingRetryLoop({
1969
+ run: async () => {
1970
+ const timeoutMs = this.resolveEmbeddingTimeout("batch");
1971
+ log$2.debug("memory embeddings: batch start", {
1972
+ provider: provider.id,
1973
+ items: texts.length,
1974
+ timeoutMs
1975
+ });
1976
+ return await this.withTimeout(provider.embedBatch(texts), timeoutMs, `memory embeddings batch timed out after ${Math.round(timeoutMs / 1e3)}s`);
1977
+ },
1978
+ isRetryable: isRetryableMemoryEmbeddingError,
1979
+ waitForRetry: async (delayMs) => {
1980
+ await this.waitForEmbeddingRetry(delayMs, "retrying");
1981
+ },
1982
+ maxAttempts: EMBEDDING_RETRY_MAX_ATTEMPTS,
1983
+ baseDelayMs: EMBEDDING_RETRY_BASE_DELAY_MS
1984
+ });
1985
+ }
1986
+ async embedBatchInputsWithRetry(inputs) {
1987
+ if (inputs.length === 0) return [];
1988
+ const provider = this.provider;
1989
+ const embedBatchInputs = provider?.embedBatchInputs;
1990
+ if (!embedBatchInputs) return await this.embedBatchWithRetry(inputs.map((input) => input.text));
1991
+ return await runMemoryEmbeddingRetryLoop({
1992
+ run: async () => {
1993
+ const timeoutMs = this.resolveEmbeddingTimeout("batch");
1994
+ log$2.debug("memory embeddings: structured batch start", {
1995
+ provider: provider.id,
1996
+ items: inputs.length,
1997
+ timeoutMs
1998
+ });
1999
+ return await this.withTimeout(embedBatchInputs(inputs), timeoutMs, `memory embeddings batch timed out after ${Math.round(timeoutMs / 1e3)}s`);
2000
+ },
2001
+ isRetryable: isRetryableMemoryEmbeddingError,
2002
+ waitForRetry: async (delayMs) => {
2003
+ await this.waitForEmbeddingRetry(delayMs, "retrying structured batch");
2004
+ },
2005
+ maxAttempts: EMBEDDING_RETRY_MAX_ATTEMPTS,
2006
+ baseDelayMs: EMBEDDING_RETRY_BASE_DELAY_MS
2007
+ });
2008
+ }
2009
+ async waitForEmbeddingRetry(delayMs, action) {
2010
+ const waitMs = resolveMemoryEmbeddingRetryDelay(delayMs, Math.random(), EMBEDDING_RETRY_MAX_DELAY_MS);
2011
+ log$2.warn(`memory embeddings rate limited; ${action} in ${waitMs}ms`);
2012
+ await new Promise((resolve) => setTimeout(resolve, waitMs));
2013
+ }
2014
+ resolveEmbeddingTimeout(kind) {
2015
+ const isLocal = this.provider?.id === "local";
2016
+ if (kind === "query") return isLocal ? EMBEDDING_QUERY_TIMEOUT_LOCAL_MS : EMBEDDING_QUERY_TIMEOUT_REMOTE_MS;
2017
+ return isLocal ? EMBEDDING_BATCH_TIMEOUT_LOCAL_MS : EMBEDDING_BATCH_TIMEOUT_REMOTE_MS;
2018
+ }
2019
+ async embedQueryWithTimeout(text) {
2020
+ if (!this.provider) throw new Error("Cannot embed query in FTS-only mode (no embedding provider)");
2021
+ const timeoutMs = this.resolveEmbeddingTimeout("query");
2022
+ log$2.debug("memory embeddings: query start", {
2023
+ provider: this.provider.id,
2024
+ timeoutMs
2025
+ });
2026
+ return await this.withTimeout(this.provider.embedQuery(text), timeoutMs, `memory embeddings query timed out after ${Math.round(timeoutMs / 1e3)}s`);
2027
+ }
2028
+ async withTimeout(promise, timeoutMs, message) {
2029
+ if (!Number.isFinite(timeoutMs) || timeoutMs <= 0) return await promise;
2030
+ let timer = null;
2031
+ const timeoutPromise = new Promise((_, reject) => {
2032
+ timer = setTimeout(() => reject(new Error(message)), timeoutMs);
2033
+ });
2034
+ try {
2035
+ return await Promise.race([promise, timeoutPromise]);
2036
+ } finally {
2037
+ if (timer) clearTimeout(timer);
2038
+ }
2039
+ }
2040
+ async withBatchFailureLock(fn) {
2041
+ let release;
2042
+ const wait = this.batchFailureLock;
2043
+ this.batchFailureLock = new Promise((resolve) => {
2044
+ release = resolve;
2045
+ });
2046
+ await wait;
2047
+ try {
2048
+ return await fn();
2049
+ } finally {
2050
+ release();
2051
+ }
2052
+ }
2053
+ async resetBatchFailureCount() {
2054
+ await this.withBatchFailureLock(async () => {
2055
+ if (this.batchFailureCount > 0) log$2.debug("memory embeddings: batch recovered; resetting failure count");
2056
+ const nextState = resetMemoryBatchFailureState({
2057
+ enabled: this.batch.enabled,
2058
+ count: this.batchFailureCount,
2059
+ lastError: this.batchFailureLastError,
2060
+ lastProvider: this.batchFailureLastProvider
2061
+ });
2062
+ this.batch.enabled = nextState.enabled;
2063
+ this.batchFailureCount = nextState.count;
2064
+ this.batchFailureLastError = nextState.lastError;
2065
+ this.batchFailureLastProvider = nextState.lastProvider;
2066
+ });
2067
+ }
2068
+ async recordBatchFailure(params) {
2069
+ return await this.withBatchFailureLock(async () => {
2070
+ if (!this.batch.enabled) return {
2071
+ disabled: true,
2072
+ count: this.batchFailureCount
2073
+ };
2074
+ const nextState = recordMemoryBatchFailure({
2075
+ enabled: this.batch.enabled,
2076
+ count: this.batchFailureCount,
2077
+ lastError: this.batchFailureLastError,
2078
+ lastProvider: this.batchFailureLastProvider
2079
+ }, params);
2080
+ this.batch.enabled = nextState.enabled;
2081
+ this.batchFailureCount = nextState.count;
2082
+ this.batchFailureLastError = nextState.lastError;
2083
+ this.batchFailureLastProvider = nextState.lastProvider;
2084
+ return {
2085
+ disabled: !nextState.enabled,
2086
+ count: nextState.count
2087
+ };
2088
+ });
2089
+ }
2090
+ isBatchTimeoutError(message) {
2091
+ return /timed out|timeout/i.test(message);
2092
+ }
2093
+ async runBatchWithTimeoutRetry(params) {
2094
+ try {
2095
+ return await params.run();
2096
+ } catch (err) {
2097
+ const message = formatErrorMessage(err);
2098
+ if (this.isBatchTimeoutError(message)) {
2099
+ log$2.warn(`memory embeddings: ${params.provider} batch timed out; retrying once`);
2100
+ try {
2101
+ return await params.run();
2102
+ } catch (retryErr) {
2103
+ retryErr.batchAttempts = 2;
2104
+ throw retryErr;
2105
+ }
2106
+ }
2107
+ throw err;
2108
+ }
2109
+ }
2110
+ async runBatchWithFallback(params) {
2111
+ if (!this.batch.enabled) return await params.fallback();
2112
+ try {
2113
+ const result = await this.runBatchWithTimeoutRetry({
2114
+ provider: params.provider,
2115
+ run: params.run
2116
+ });
2117
+ await this.resetBatchFailureCount();
2118
+ return result;
2119
+ } catch (err) {
2120
+ const message = formatErrorMessage(err);
2121
+ const attempts = err.batchAttempts ?? 1;
2122
+ const forceDisable = /asyncBatchEmbedContent not available/i.test(message);
2123
+ const failure = await this.recordBatchFailure({
2124
+ provider: params.provider,
2125
+ message,
2126
+ attempts,
2127
+ forceDisable
2128
+ });
2129
+ const suffix = failure.disabled ? "disabling batch" : "keeping batch enabled";
2130
+ log$2.warn(`memory embeddings: ${params.provider} batch failed (${failure.count}/2); ${suffix}; falling back to non-batch embeddings: ${message}`);
2131
+ return await params.fallback();
2132
+ }
2133
+ }
2134
+ getIndexConcurrency() {
2135
+ return this.batch.enabled ? this.batch.concurrency : EMBEDDING_INDEX_CONCURRENCY;
2136
+ }
2137
+ clearIndexedFileData(pathname, source) {
2138
+ if (this.vector.enabled) try {
2139
+ this.db.prepare(`DELETE FROM ${VECTOR_TABLE$1} WHERE id IN (SELECT id FROM chunks WHERE path = ? AND source = ?)`).run(pathname, source);
2140
+ } catch {}
2141
+ if (this.fts.enabled && this.fts.available) try {
2142
+ deleteMemoryFtsRows({
2143
+ db: this.db,
2144
+ tableName: FTS_TABLE$1,
2145
+ path: pathname,
2146
+ source,
2147
+ currentModel: this.provider?.model
2148
+ });
2149
+ } catch {}
2150
+ this.db.prepare(`DELETE FROM chunks WHERE path = ? AND source = ?`).run(pathname, source);
2151
+ }
2152
+ upsertFileRecord(entry, source) {
2153
+ this.db.prepare(`INSERT INTO files (path, source, hash, mtime, size) VALUES (?, ?, ?, ?, ?)
2154
+ ON CONFLICT(path) DO UPDATE SET
2155
+ source=excluded.source,
2156
+ hash=excluded.hash,
2157
+ mtime=excluded.mtime,
2158
+ size=excluded.size`).run(entry.path, source, entry.hash, entry.mtimeMs, entry.size);
2159
+ }
2160
+ deleteFileRecord(pathname, source) {
2161
+ this.db.prepare(`DELETE FROM files WHERE path = ? AND source = ?`).run(pathname, source);
2162
+ }
2163
+ /**
2164
+ * Write chunks (and optional embeddings) for a file into the index.
2165
+ * Handles both the chunks table, the vector table, and the FTS table.
2166
+ * Pass an empty embeddings array to skip vector writes (FTS-only mode).
2167
+ */
2168
+ writeChunks(entry, source, model, chunks, embeddings, vectorReady) {
2169
+ const now = Date.now();
2170
+ this.clearIndexedFileData(entry.path, source);
2171
+ for (let i = 0; i < chunks.length; i++) {
2172
+ const chunk = chunks[i];
2173
+ const embedding = embeddings[i] ?? [];
2174
+ const id = hashText(`${source}:${entry.path}:${chunk.startLine}:${chunk.endLine}:${chunk.hash}:${model}`);
2175
+ this.db.prepare(`INSERT INTO chunks (id, path, source, start_line, end_line, hash, model, text, embedding, updated_at)
2176
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
2177
+ ON CONFLICT(id) DO UPDATE SET
2178
+ hash=excluded.hash,
2179
+ model=excluded.model,
2180
+ text=excluded.text,
2181
+ embedding=excluded.embedding,
2182
+ updated_at=excluded.updated_at`).run(id, entry.path, source, chunk.startLine, chunk.endLine, chunk.hash, model, chunk.text, JSON.stringify(embedding), now);
2183
+ if (vectorReady && embedding.length > 0) replaceMemoryVectorRow({
2184
+ db: this.db,
2185
+ tableName: VECTOR_TABLE$1,
2186
+ id,
2187
+ embedding
2188
+ });
2189
+ if (this.fts.enabled && this.fts.available) this.db.prepare(`INSERT INTO ${FTS_TABLE$1} (text, id, path, source, model, start_line, end_line)\n VALUES (?, ?, ?, ?, ?, ?, ?)`).run(chunk.text, id, entry.path, source, model, chunk.startLine, chunk.endLine);
2190
+ }
2191
+ this.vectorDegradedWriteWarningShown = logMemoryVectorDegradedWrite({
2192
+ vectorEnabled: this.vector.enabled,
2193
+ vectorReady,
2194
+ chunkCount: chunks.length,
2195
+ warningShown: this.vectorDegradedWriteWarningShown,
2196
+ loadError: this.vector.loadError,
2197
+ warn: (message) => log$2.warn(message)
2198
+ });
2199
+ this.upsertFileRecord(entry, source);
2200
+ }
2201
+ async indexFile(entry, options) {
2202
+ if (!this.provider) {
2203
+ if ("kind" in entry && entry.kind === "multimodal") return;
2204
+ const chunks = filterNonEmptyMemoryChunks(chunkMarkdown(options.content ?? await fs$1.readFile(entry.absPath, "utf-8"), this.settings.chunking));
2205
+ if (options.source === "sessions" && "lineMap" in entry) remapChunkLines(chunks, entry.lineMap);
2206
+ this.writeChunks(entry, options.source, "fts-only", chunks, [], false);
2207
+ return;
2208
+ }
2209
+ let chunks;
2210
+ let structuredInputBytes;
2211
+ if ("kind" in entry && entry.kind === "multimodal") {
2212
+ if (!this.provider) {
2213
+ log$2.debug("Skipping multimodal indexing in FTS-only mode", {
2214
+ path: entry.path,
2215
+ source: options.source
2216
+ });
2217
+ this.clearIndexedFileData(entry.path, options.source);
2218
+ this.upsertFileRecord(entry, options.source);
2219
+ return;
2220
+ }
2221
+ const multimodalChunk = await buildMultimodalChunkForIndexing(entry);
2222
+ if (!multimodalChunk) {
2223
+ this.clearIndexedFileData(entry.path, options.source);
2224
+ this.deleteFileRecord(entry.path, options.source);
2225
+ return;
2226
+ }
2227
+ structuredInputBytes = multimodalChunk.structuredInputBytes;
2228
+ chunks = [multimodalChunk.chunk];
2229
+ } else {
2230
+ const baseChunks = filterNonEmptyMemoryChunks(chunkMarkdown(options.content ?? await fs$1.readFile(entry.absPath, "utf-8"), this.settings.chunking));
2231
+ chunks = this.provider ? enforceEmbeddingMaxInputTokens(this.provider, baseChunks, EMBEDDING_BATCH_MAX_TOKENS) : baseChunks;
2232
+ if (options.source === "sessions" && "lineMap" in entry) remapChunkLines(chunks, entry.lineMap);
2233
+ }
2234
+ if (!this.provider) {
2235
+ this.writeChunks(entry, options.source, "fts-only", chunks, [], false);
2236
+ return;
2237
+ }
2238
+ let embeddings;
2239
+ try {
2240
+ embeddings = this.batch.enabled ? await this.embedChunksWithBatch(chunks, entry, options.source) : await this.embedChunksInBatches(chunks);
2241
+ } catch (err) {
2242
+ const message = formatErrorMessage(err);
2243
+ if ("kind" in entry && entry.kind === "multimodal" && /(413|payload too large|request too large|input too large|too many tokens|input limit|request size)/i.test(message)) {
2244
+ log$2.warn("memory embeddings: skipping multimodal file rejected as too large", {
2245
+ path: entry.path,
2246
+ bytes: structuredInputBytes,
2247
+ provider: this.provider.id,
2248
+ model: this.provider.model,
2249
+ error: message
2250
+ });
2251
+ this.clearIndexedFileData(entry.path, options.source);
2252
+ this.upsertFileRecord(entry, options.source);
2253
+ return;
2254
+ }
2255
+ throw err;
2256
+ }
2257
+ const sample = embeddings.find((embedding) => embedding.length > 0);
2258
+ const vectorReady = sample ? await this.ensureVectorReady(sample.length) : false;
2259
+ this.writeChunks(entry, options.source, this.provider.model, chunks, embeddings, vectorReady);
2260
+ }
2261
+ };
2262
+ //#endregion
2263
+ //#region extensions/memory-core/src/memory/manager-search-preflight.ts
2264
+ function resolveMemorySearchPreflight(params) {
2265
+ const normalizedQuery = params.query.trim();
2266
+ if (!normalizedQuery) return {
2267
+ normalizedQuery,
2268
+ shouldInitializeProvider: false,
2269
+ shouldSearch: false
2270
+ };
2271
+ if (!params.hasIndexedContent) return {
2272
+ normalizedQuery,
2273
+ shouldInitializeProvider: false,
2274
+ shouldSearch: false
2275
+ };
2276
+ return {
2277
+ normalizedQuery,
2278
+ shouldInitializeProvider: true,
2279
+ shouldSearch: true
2280
+ };
2281
+ }
2282
+ //#endregion
2283
+ //#region extensions/memory-core/src/memory/manager-search.ts
2284
+ const vectorToBlob = (embedding) => Buffer.from(new Float32Array(embedding).buffer);
2285
+ const FTS_QUERY_TOKEN_RE = /[\p{L}\p{N}_]+/gu;
2286
+ const SHORT_CJK_TRIGRAM_RE = /[\u3040-\u30ff\u3400-\u9fff\uac00-\ud7af\u3131-\u3163]/u;
2287
+ const VECTOR_KNN_OVERSAMPLE_FACTOR = 8;
2288
+ function normalizeSearchTokens(raw) {
2289
+ return raw.match(FTS_QUERY_TOKEN_RE)?.map((token) => token.trim().toLowerCase()).filter(Boolean) ?? [];
2290
+ }
2291
+ function scoreFallbackKeywordResult(params) {
2292
+ const queryTokens = [...new Set(normalizeSearchTokens(params.query))];
2293
+ if (queryTokens.length === 0) return params.ftsScore;
2294
+ const textTokens = normalizeSearchTokens(params.text);
2295
+ const textTokenSet = new Set(textTokens);
2296
+ const pathLower = params.path.toLowerCase();
2297
+ const overlap = queryTokens.filter((token) => textTokenSet.has(token)).length;
2298
+ const uniqueQueryOverlap = overlap / Math.max(new Set(queryTokens).size, 1);
2299
+ const density = overlap / Math.max(textTokenSet.size, 1);
2300
+ const pathBoost = queryTokens.reduce((score, token) => score + (pathLower.includes(token) ? .18 : 0), 0);
2301
+ const textLengthBoost = Math.min(params.text.length / 160, .18);
2302
+ const lexicalBoost = uniqueQueryOverlap * .45 + density * .2 + pathBoost + textLengthBoost;
2303
+ return Math.min(1, params.ftsScore + lexicalBoost);
2304
+ }
2305
+ function escapeLikePattern(term) {
2306
+ return term.replaceAll("\\", "\\\\").replaceAll("%", "\\%").replaceAll("_", "\\_");
2307
+ }
2308
+ function buildMatchQueryFromTerms(terms) {
2309
+ if (terms.length === 0) return null;
2310
+ return terms.map((term) => `"${term.replaceAll("\"", "")}"`).join(" AND ");
2311
+ }
2312
+ function readCount(row) {
2313
+ if (typeof row?.count === "bigint") return Number(row.count);
2314
+ if (typeof row?.count === "number") return row.count;
2315
+ return 0;
2316
+ }
2317
+ function planKeywordSearch(params) {
2318
+ if (params.ftsTokenizer !== "trigram") return {
2319
+ matchQuery: params.buildFtsQuery(params.query),
2320
+ substringTerms: []
2321
+ };
2322
+ const tokens = params.query.match(FTS_QUERY_TOKEN_RE)?.map((token) => token.trim()).filter(Boolean) ?? [];
2323
+ if (tokens.length === 0) return {
2324
+ matchQuery: null,
2325
+ substringTerms: []
2326
+ };
2327
+ const matchTerms = [];
2328
+ const substringTerms = [];
2329
+ for (const token of tokens) {
2330
+ if (SHORT_CJK_TRIGRAM_RE.test(token) && Array.from(token).length < 3) {
2331
+ substringTerms.push(token);
2332
+ continue;
2333
+ }
2334
+ matchTerms.push(token);
2335
+ }
2336
+ return {
2337
+ matchQuery: buildMatchQueryFromTerms(matchTerms),
2338
+ substringTerms
2339
+ };
2340
+ }
2341
+ async function searchVector(params) {
2342
+ if (params.queryVec.length === 0 || params.limit <= 0) return [];
2343
+ if (await params.ensureVectorReady(params.queryVec.length)) {
2344
+ const qBlob = vectorToBlob(params.queryVec);
2345
+ const runVectorQuery = (candidateLimit) => params.db.prepare(`SELECT c.id, c.path, c.start_line, c.end_line, c.text,
2346
+ c.source,
2347
+ vec_distance_cosine(v.embedding, ?) AS dist
2348
+ FROM ${params.vectorTable} v\n JOIN chunks c ON c.id = v.id\n WHERE v.embedding MATCH ? AND k = ? AND c.model = ?${params.sourceFilterVec.sql}\n ORDER BY dist ASC\n LIMIT ?`).all(qBlob, qBlob, candidateLimit, params.providerModel, ...params.sourceFilterVec.params, params.limit);
2349
+ const candidateLimit = params.limit * VECTOR_KNN_OVERSAMPLE_FACTOR;
2350
+ let rows = runVectorQuery(candidateLimit);
2351
+ if (rows.length < params.limit) {
2352
+ if (readCount(params.db.prepare(`SELECT COUNT(*) AS count FROM chunks c WHERE c.model = ?${params.sourceFilterVec.sql}`).get(params.providerModel, ...params.sourceFilterVec.params)) > rows.length) {
2353
+ const vectorCount = readCount(params.db.prepare(`SELECT COUNT(*) AS count FROM ${params.vectorTable}`).get());
2354
+ if (vectorCount > candidateLimit) rows = runVectorQuery(vectorCount);
2355
+ }
2356
+ }
2357
+ return rows.map((row) => ({
2358
+ id: row.id,
2359
+ path: row.path,
2360
+ startLine: row.start_line,
2361
+ endLine: row.end_line,
2362
+ score: 1 - row.dist,
2363
+ snippet: truncateUtf16Safe(row.text, params.snippetMaxChars),
2364
+ source: row.source
2365
+ }));
2366
+ }
2367
+ return listChunks({
2368
+ db: params.db,
2369
+ providerModel: params.providerModel,
2370
+ sourceFilter: params.sourceFilterChunks
2371
+ }).map((chunk) => ({
2372
+ chunk,
2373
+ score: cosineSimilarity(params.queryVec, chunk.embedding)
2374
+ })).filter((entry) => Number.isFinite(entry.score)).toSorted((a, b) => b.score - a.score).slice(0, params.limit).map((entry) => ({
2375
+ id: entry.chunk.id,
2376
+ path: entry.chunk.path,
2377
+ startLine: entry.chunk.startLine,
2378
+ endLine: entry.chunk.endLine,
2379
+ score: entry.score,
2380
+ snippet: truncateUtf16Safe(entry.chunk.text, params.snippetMaxChars),
2381
+ source: entry.chunk.source
2382
+ }));
2383
+ }
2384
+ function listChunks(params) {
2385
+ return params.db.prepare(`SELECT id, path, start_line, end_line, text, embedding, source
2386
+ FROM chunks
2387
+ WHERE model = ?${params.sourceFilter.sql}`).all(params.providerModel, ...params.sourceFilter.params).map((row) => ({
2388
+ id: row.id,
2389
+ path: row.path,
2390
+ startLine: row.start_line,
2391
+ endLine: row.end_line,
2392
+ text: row.text,
2393
+ embedding: parseEmbedding(row.embedding),
2394
+ source: row.source
2395
+ }));
2396
+ }
2397
+ async function searchKeyword(params) {
2398
+ if (params.limit <= 0) return [];
2399
+ const plan = planKeywordSearch({
2400
+ query: params.query,
2401
+ ftsTokenizer: params.ftsTokenizer,
2402
+ buildFtsQuery: params.buildFtsQuery
2403
+ });
2404
+ if (!plan.matchQuery && plan.substringTerms.length === 0) return [];
2405
+ const modelClause = params.providerModel ? " AND model = ?" : "";
2406
+ const modelParams = params.providerModel ? [params.providerModel] : [];
2407
+ const substringClause = plan.substringTerms.map(() => " AND text LIKE ? ESCAPE '\\'").join("");
2408
+ const substringParams = plan.substringTerms.map((term) => `%${escapeLikePattern(term)}%`);
2409
+ const whereClause = plan.matchQuery ? `${params.ftsTable} MATCH ?${substringClause}${modelClause}${params.sourceFilter.sql}` : `1=1${substringClause}${modelClause}${params.sourceFilter.sql}`;
2410
+ const queryParams = [
2411
+ ...plan.matchQuery ? [plan.matchQuery] : [],
2412
+ ...substringParams,
2413
+ ...modelParams,
2414
+ ...params.sourceFilter.params,
2415
+ params.limit
2416
+ ];
2417
+ const rankExpression = plan.matchQuery ? `bm25(${params.ftsTable})` : "0";
2418
+ return params.db.prepare(`SELECT id, path, source, start_line, end_line, text,\n ${rankExpression} AS rank\n FROM ${params.ftsTable}\n WHERE ${whereClause}\n ORDER BY rank ASC\n LIMIT ?`).all(...queryParams).map((row) => {
2419
+ const textScore = plan.matchQuery ? params.bm25RankToScore(row.rank) : 1;
2420
+ const score = params.boostFallbackRanking ? scoreFallbackKeywordResult({
2421
+ query: params.query,
2422
+ path: row.path,
2423
+ text: row.text,
2424
+ ftsScore: textScore
2425
+ }) : textScore;
2426
+ return {
2427
+ id: row.id,
2428
+ path: row.path,
2429
+ startLine: row.start_line,
2430
+ endLine: row.end_line,
2431
+ score,
2432
+ textScore,
2433
+ snippet: truncateUtf16Safe(row.text, params.snippetMaxChars),
2434
+ source: row.source
2435
+ };
2436
+ });
2437
+ }
2438
+ //#endregion
2439
+ //#region extensions/memory-core/src/memory/manager-status-state.ts
2440
+ const MEMORY_STATUS_AGGREGATE_SQL = "SELECT 'files' AS kind, source, COUNT(*) as c FROM files WHERE 1=1__FILTER__ GROUP BY source\nUNION ALL\nSELECT 'chunks' AS kind, source, COUNT(*) as c FROM chunks WHERE 1=1__FILTER__ GROUP BY source";
2441
+ function resolveInitialMemoryDirty(params) {
2442
+ return params.hasMemorySource && (params.statusOnly ? !params.hasIndexedMeta : true);
2443
+ }
2444
+ function resolveStatusProviderInfo(params) {
2445
+ if (params.provider) return {
2446
+ provider: params.provider.id,
2447
+ model: params.provider.model,
2448
+ searchMode: "hybrid"
2449
+ };
2450
+ if (params.providerInitialized) return {
2451
+ provider: "none",
2452
+ model: void 0,
2453
+ searchMode: "fts-only"
2454
+ };
2455
+ return {
2456
+ provider: params.requestedProvider,
2457
+ model: params.configuredModel || void 0,
2458
+ searchMode: "hybrid"
2459
+ };
2460
+ }
2461
+ function collectMemoryStatusAggregate(params) {
2462
+ const sources = Array.from(params.sources);
2463
+ const bySource = /* @__PURE__ */ new Map();
2464
+ for (const source of sources) bySource.set(source, {
2465
+ files: 0,
2466
+ chunks: 0
2467
+ });
2468
+ const sourceFilterSql = params.sourceFilterSql ?? "";
2469
+ const sourceFilterParams = params.sourceFilterParams ?? [];
2470
+ const aggregateRows = params.db.prepare(MEMORY_STATUS_AGGREGATE_SQL.replaceAll("__FILTER__", sourceFilterSql)).all(...sourceFilterParams, ...sourceFilterParams);
2471
+ let files = 0;
2472
+ let chunks = 0;
2473
+ for (const row of aggregateRows) {
2474
+ const count = row.c ?? 0;
2475
+ const entry = bySource.get(row.source) ?? {
2476
+ files: 0,
2477
+ chunks: 0
2478
+ };
2479
+ if (row.kind === "files") {
2480
+ entry.files = count;
2481
+ files += count;
2482
+ } else {
2483
+ entry.chunks = count;
2484
+ chunks += count;
2485
+ }
2486
+ bySource.set(row.source, entry);
2487
+ }
2488
+ return {
2489
+ files,
2490
+ chunks,
2491
+ sourceCounts: sources.map((source) => Object.assign({ source }, bySource.get(source)))
2492
+ };
2493
+ }
2494
+ //#endregion
2495
+ //#region extensions/memory-core/src/memory/manager-sync-control.ts
2496
+ const log$1 = createSubsystemLogger("memory");
2497
+ function isMemoryReadonlyDbError(err) {
2498
+ const readonlyPattern = /attempt to write a readonly database|database is read-only|SQLITE_READONLY/i;
2499
+ const messages = /* @__PURE__ */ new Set();
2500
+ const pushValue = (value) => {
2501
+ if (typeof value !== "string") return;
2502
+ const normalized = value.trim();
2503
+ if (!normalized) return;
2504
+ messages.add(normalized);
2505
+ };
2506
+ pushValue(formatErrorMessage(err));
2507
+ if (err && typeof err === "object") {
2508
+ const record = err;
2509
+ pushValue(record.message);
2510
+ pushValue(record.code);
2511
+ pushValue(record.name);
2512
+ if (record.cause && typeof record.cause === "object") {
2513
+ const cause = record.cause;
2514
+ pushValue(cause.message);
2515
+ pushValue(cause.code);
2516
+ pushValue(cause.name);
2517
+ }
2518
+ }
2519
+ return [...messages].some((value) => readonlyPattern.test(value));
2520
+ }
2521
+ function extractMemoryErrorReason(err) {
2522
+ if (err instanceof Error && err.message.trim()) return err.message;
2523
+ if (err && typeof err === "object") {
2524
+ const record = err;
2525
+ if (typeof record.message === "string" && record.message.trim()) return record.message;
2526
+ if (typeof record.code === "string" && record.code.trim()) return record.code;
2527
+ }
2528
+ return String(err);
2529
+ }
2530
+ async function runMemorySyncWithReadonlyRecovery(state, params) {
2531
+ try {
2532
+ await state.runSync(params);
2533
+ return;
2534
+ } catch (err) {
2535
+ if (!isMemoryReadonlyDbError(err) || state.closed) throw err;
2536
+ const reason = extractMemoryErrorReason(err);
2537
+ state.readonlyRecoveryAttempts += 1;
2538
+ state.readonlyRecoveryLastError = reason;
2539
+ log$1.warn(`memory sync readonly handle detected; reopening sqlite connection`, { reason });
2540
+ try {
2541
+ state.db.close();
2542
+ } catch {}
2543
+ const previousVectorDims = state.vector.dims;
2544
+ state.db = state.openDatabase();
2545
+ state.resetVectorState();
2546
+ state.ensureSchema();
2547
+ const meta = state.readMeta();
2548
+ state.vector.dims = meta?.vectorDims ?? previousVectorDims;
2549
+ try {
2550
+ await state.runSync(params);
2551
+ state.readonlyRecoverySuccesses += 1;
2552
+ } catch (retryErr) {
2553
+ state.readonlyRecoveryFailures += 1;
2554
+ throw retryErr;
2555
+ }
2556
+ }
2557
+ }
2558
+ function enqueueMemoryTargetedSessionSync(state, sessionFiles) {
2559
+ const queuedSessionFiles = state.getQueuedSessionFiles();
2560
+ for (const sessionFile of sessionFiles ?? []) {
2561
+ const trimmed = sessionFile.trim();
2562
+ if (trimmed) queuedSessionFiles.add(trimmed);
2563
+ }
2564
+ if (queuedSessionFiles.size === 0) return state.getSyncing() ?? Promise.resolve();
2565
+ if (!state.getQueuedSessionSync()) state.setQueuedSessionSync((async () => {
2566
+ try {
2567
+ await state.getSyncing()?.catch(() => void 0);
2568
+ while (!state.isClosed() && state.getQueuedSessionFiles().size > 0) {
2569
+ const pendingSessionFiles = Array.from(state.getQueuedSessionFiles());
2570
+ state.getQueuedSessionFiles().clear();
2571
+ await state.sync({
2572
+ reason: "queued-session-files",
2573
+ sessionFiles: pendingSessionFiles
2574
+ });
2575
+ }
2576
+ } finally {
2577
+ state.setQueuedSessionSync(null);
2578
+ }
2579
+ })());
2580
+ return state.getQueuedSessionSync() ?? Promise.resolve();
2581
+ }
2582
+ //#endregion
2583
+ //#region extensions/memory-core/src/memory/manager.ts
2584
+ const SNIPPET_MAX_CHARS = 700;
2585
+ const VECTOR_TABLE = "chunks_vec";
2586
+ const FTS_TABLE = "chunks_fts";
2587
+ const EMBEDDING_CACHE_TABLE = "embedding_cache";
2588
+ const MEMORY_INDEX_MANAGER_CACHE_KEY = Symbol.for("genesis.memoryIndexManagerCache");
2589
+ const log = createSubsystemLogger("memory");
2590
+ const { cache: INDEX_CACHE, pending: INDEX_CACHE_PENDING } = resolveSingletonManagedCache(MEMORY_INDEX_MANAGER_CACHE_KEY);
2591
+ async function closeAllMemoryIndexManagers() {
2592
+ await closeManagedCacheEntries({
2593
+ cache: INDEX_CACHE,
2594
+ pending: INDEX_CACHE_PENDING,
2595
+ onCloseError: (err) => {
2596
+ log.warn(`failed to close memory index manager: ${String(err)}`);
2597
+ }
2598
+ });
2599
+ }
2600
+ var MemoryIndexManager = class MemoryIndexManager extends MemoryManagerEmbeddingOps {
2601
+ static async loadProviderResult(params) {
2602
+ return await createEmbeddingProvider({
2603
+ config: params.cfg,
2604
+ agentDir: resolveAgentDir(params.cfg, params.agentId),
2605
+ ...resolveMemoryPrimaryProviderRequest({ settings: params.settings })
2606
+ });
2607
+ }
2608
+ static async get(params) {
2609
+ const { cfg, agentId } = params;
2610
+ const settings = resolveMemorySearchConfig(cfg, agentId);
2611
+ if (!settings) return null;
2612
+ const workspaceDir = resolveAgentWorkspaceDir(cfg, agentId);
2613
+ const purpose = params.purpose === "status" ? "status" : "default";
2614
+ const key = `${agentId}:${workspaceDir}:${JSON.stringify(settings)}:${purpose}`;
2615
+ return await getOrCreateManagedCacheEntry({
2616
+ cache: INDEX_CACHE,
2617
+ pending: INDEX_CACHE_PENDING,
2618
+ key,
2619
+ bypassCache: params.purpose === "status",
2620
+ create: async () => new MemoryIndexManager({
2621
+ cacheKey: key,
2622
+ cfg,
2623
+ agentId,
2624
+ workspaceDir,
2625
+ settings,
2626
+ purpose: params.purpose
2627
+ })
2628
+ });
2629
+ }
2630
+ constructor(params) {
2631
+ super();
2632
+ this.providerInitPromise = null;
2633
+ this.providerInitialized = false;
2634
+ this.batchFailureCount = 0;
2635
+ this.batchFailureLock = Promise.resolve();
2636
+ this.vectorReady = null;
2637
+ this.watcher = null;
2638
+ this.watchTimer = null;
2639
+ this.sessionWatchTimer = null;
2640
+ this.sessionUnsubscribe = null;
2641
+ this.intervalTimer = null;
2642
+ this.closed = false;
2643
+ this.dirty = false;
2644
+ this.sessionsDirty = false;
2645
+ this.sessionsDirtyFiles = /* @__PURE__ */ new Set();
2646
+ this.sessionPendingFiles = /* @__PURE__ */ new Set();
2647
+ this.sessionDeltas = /* @__PURE__ */ new Map();
2648
+ this.sessionWarm = /* @__PURE__ */ new Set();
2649
+ this.syncing = null;
2650
+ this.queuedSessionFiles = /* @__PURE__ */ new Set();
2651
+ this.queuedSessionSync = null;
2652
+ this.readonlyRecoveryAttempts = 0;
2653
+ this.readonlyRecoverySuccesses = 0;
2654
+ this.readonlyRecoveryFailures = 0;
2655
+ this.cacheKey = params.cacheKey;
2656
+ this.cfg = params.cfg;
2657
+ this.agentId = params.agentId;
2658
+ this.workspaceDir = params.workspaceDir;
2659
+ this.settings = params.settings;
2660
+ this.provider = null;
2661
+ this.requestedProvider = params.settings.provider;
2662
+ if (params.providerResult) this.applyProviderResult(params.providerResult);
2663
+ this.sources = new Set(params.settings.sources);
2664
+ this.db = this.openDatabase();
2665
+ this.providerKey = this.computeProviderKey();
2666
+ this.cache = {
2667
+ enabled: params.settings.cache.enabled,
2668
+ maxEntries: params.settings.cache.maxEntries
2669
+ };
2670
+ this.fts = {
2671
+ enabled: params.settings.query.hybrid.enabled,
2672
+ available: false
2673
+ };
2674
+ this.ensureSchema();
2675
+ this.vector = {
2676
+ enabled: params.settings.store.vector.enabled,
2677
+ available: null,
2678
+ extensionPath: params.settings.store.vector.extensionPath
2679
+ };
2680
+ const meta = this.readMeta();
2681
+ if (meta?.vectorDims) this.vector.dims = meta.vectorDims;
2682
+ const statusOnly = params.purpose === "status";
2683
+ if (!statusOnly) {
2684
+ this.ensureWatcher();
2685
+ this.ensureSessionListener();
2686
+ this.ensureIntervalSync();
2687
+ }
2688
+ this.dirty = resolveInitialMemoryDirty({
2689
+ hasMemorySource: this.sources.has("memory"),
2690
+ statusOnly,
2691
+ hasIndexedMeta: Boolean(meta)
2692
+ });
2693
+ this.batch = this.resolveBatchConfig();
2694
+ }
2695
+ applyProviderResult(providerResult) {
2696
+ const providerState = resolveMemoryProviderState(providerResult);
2697
+ this.provider = providerState.provider;
2698
+ this.fallbackFrom = providerState.fallbackFrom;
2699
+ this.fallbackReason = providerState.fallbackReason;
2700
+ this.providerUnavailableReason = providerState.providerUnavailableReason;
2701
+ this.providerRuntime = providerState.providerRuntime;
2702
+ this.providerInitialized = true;
2703
+ }
2704
+ async ensureProviderInitialized() {
2705
+ if (this.providerInitialized) return;
2706
+ if (!this.providerInitPromise) this.providerInitPromise = (async () => {
2707
+ const providerResult = await MemoryIndexManager.loadProviderResult({
2708
+ cfg: this.cfg,
2709
+ agentId: this.agentId,
2710
+ settings: this.settings
2711
+ });
2712
+ this.applyProviderResult(providerResult);
2713
+ this.providerKey = this.computeProviderKey();
2714
+ this.batch = this.resolveBatchConfig();
2715
+ })();
2716
+ try {
2717
+ await this.providerInitPromise;
2718
+ } finally {
2719
+ if (this.providerInitialized) this.providerInitPromise = null;
2720
+ }
2721
+ }
2722
+ async warmSession(sessionKey) {
2723
+ if (!this.settings.sync.onSessionStart) return;
2724
+ const key = sessionKey?.trim() || "";
2725
+ if (key && this.sessionWarm.has(key)) return;
2726
+ this.sync({ reason: "session-start" }).catch((err) => {
2727
+ log.warn(`memory sync failed (session-start): ${String(err)}`);
2728
+ });
2729
+ if (key) this.sessionWarm.add(key);
2730
+ }
2731
+ async search(query, opts) {
2732
+ opts?.onDebug?.({ backend: "builtin" });
2733
+ let hasIndexedContent = this.hasIndexedContent();
2734
+ if (!hasIndexedContent) {
2735
+ try {
2736
+ await this.sync({
2737
+ reason: "search",
2738
+ force: true
2739
+ });
2740
+ } catch (err) {
2741
+ log.warn(`memory sync failed (search-bootstrap): ${String(err)}`);
2742
+ }
2743
+ hasIndexedContent = this.hasIndexedContent();
2744
+ }
2745
+ const preflight = resolveMemorySearchPreflight({
2746
+ query,
2747
+ hasIndexedContent
2748
+ });
2749
+ if (!preflight.shouldSearch) return [];
2750
+ const cleaned = preflight.normalizedQuery;
2751
+ this.warmSession(opts?.sessionKey);
2752
+ startAsyncSearchSync({
2753
+ enabled: this.settings.sync.onSearch,
2754
+ dirty: this.dirty,
2755
+ sessionsDirty: this.sessionsDirty,
2756
+ sync: async (params) => await this.sync(params),
2757
+ onError: (err) => {
2758
+ log.warn(`memory sync failed (search): ${String(err)}`);
2759
+ }
2760
+ });
2761
+ if (preflight.shouldInitializeProvider) await this.ensureProviderInitialized();
2762
+ const minScore = opts?.minScore ?? this.settings.query.minScore;
2763
+ const maxResults = opts?.maxResults ?? this.settings.query.maxResults;
2764
+ const searchSources = opts?.sources && opts.sources.length > 0 ? [...new Set(opts.sources)].filter((s) => this.sources.has(s)) : void 0;
2765
+ if (opts?.sources && opts.sources.length > 0 && (!searchSources || searchSources.length === 0)) return [];
2766
+ const sourceFilterList = searchSources ?? [...this.sources];
2767
+ const hybrid = this.settings.query.hybrid;
2768
+ const candidates = Math.min(200, Math.max(1, Math.floor(maxResults * hybrid.candidateMultiplier)));
2769
+ if (!this.provider) {
2770
+ if (!this.fts.enabled || !this.fts.available) {
2771
+ log.warn("memory search: no provider and FTS unavailable");
2772
+ return [];
2773
+ }
2774
+ const fullQueryResults = await this.searchKeyword(cleaned, candidates, { boostFallbackRanking: true }, sourceFilterList).catch(() => []);
2775
+ const resultSets = fullQueryResults.length > 0 ? [fullQueryResults] : await Promise.all((() => {
2776
+ const keywords = extractKeywords(cleaned, { ftsTokenizer: this.settings.store.fts.tokenizer });
2777
+ return (keywords.length > 0 ? keywords : [cleaned]).map((term) => this.searchKeyword(term, candidates, { boostFallbackRanking: true }, sourceFilterList).catch(() => []));
2778
+ })());
2779
+ const seenIds = /* @__PURE__ */ new Map();
2780
+ for (const results of resultSets) for (const result of results) {
2781
+ const existing = seenIds.get(result.id);
2782
+ if (!existing || result.score > existing.score) seenIds.set(result.id, result);
2783
+ }
2784
+ const sorted = (await applyTemporalDecayToHybridResults({
2785
+ results: [...seenIds.values()],
2786
+ temporalDecay: hybrid.temporalDecay,
2787
+ workspaceDir: this.workspaceDir
2788
+ })).toSorted((a, b) => b.score - a.score);
2789
+ return this.selectScoredResults(sorted, maxResults, minScore, 0);
2790
+ }
2791
+ const keywordResults = hybrid.enabled && this.fts.enabled && this.fts.available ? await this.searchKeyword(cleaned, candidates, void 0, sourceFilterList).catch(() => []) : [];
2792
+ const queryVec = await this.embedQueryWithTimeout(cleaned);
2793
+ const vectorResults = queryVec.some((v) => v !== 0) ? await this.searchVector(queryVec, candidates, sourceFilterList).catch(() => []) : [];
2794
+ if (!hybrid.enabled || !this.fts.enabled || !this.fts.available) return vectorResults.filter((entry) => entry.score >= minScore).slice(0, maxResults);
2795
+ const merged = await this.mergeHybridResults({
2796
+ vector: vectorResults,
2797
+ keyword: keywordResults,
2798
+ vectorWeight: hybrid.vectorWeight,
2799
+ textWeight: hybrid.textWeight,
2800
+ mmr: hybrid.mmr,
2801
+ temporalDecay: hybrid.temporalDecay
2802
+ });
2803
+ const strict = merged.filter((entry) => entry.score >= minScore);
2804
+ if (strict.length > 0 || keywordResults.length === 0) return strict.slice(0, maxResults);
2805
+ const relaxedMinScore = Math.min(minScore, hybrid.textWeight);
2806
+ const keywordKeys = new Set(keywordResults.map((entry) => `${entry.source}:${entry.path}:${entry.startLine}:${entry.endLine}`));
2807
+ return this.selectScoredResults(merged.filter((entry) => keywordKeys.has(`${entry.source}:${entry.path}:${entry.startLine}:${entry.endLine}`)), maxResults, minScore, relaxedMinScore);
2808
+ }
2809
+ selectScoredResults(results, maxResults, minScore, relaxedMinScore = minScore) {
2810
+ const strict = results.filter((entry) => entry.score >= minScore);
2811
+ if (strict.length > 0) return strict.slice(0, maxResults);
2812
+ return results.filter((entry) => entry.score >= relaxedMinScore).slice(0, maxResults);
2813
+ }
2814
+ hasIndexedContent() {
2815
+ if (this.db.prepare(`SELECT 1 as found FROM chunks LIMIT 1`).get()?.found === 1) return true;
2816
+ if (!this.fts.enabled || !this.fts.available) return false;
2817
+ return this.db.prepare(`SELECT 1 as found FROM ${FTS_TABLE} LIMIT 1`).get()?.found === 1;
2818
+ }
2819
+ async searchVector(queryVec, limit, sourceFilterList) {
2820
+ if (!this.provider) return [];
2821
+ return (await searchVector({
2822
+ db: this.db,
2823
+ vectorTable: VECTOR_TABLE,
2824
+ providerModel: this.provider.model,
2825
+ queryVec,
2826
+ limit,
2827
+ snippetMaxChars: SNIPPET_MAX_CHARS,
2828
+ ensureVectorReady: async (dimensions) => await this.ensureVectorReady(dimensions),
2829
+ sourceFilterVec: this.buildSourceFilter("c", sourceFilterList),
2830
+ sourceFilterChunks: this.buildSourceFilter(void 0, sourceFilterList)
2831
+ })).map((entry) => entry);
2832
+ }
2833
+ buildFtsQuery(raw) {
2834
+ return buildFtsQuery(raw);
2835
+ }
2836
+ async searchKeyword(query, limit, options, sourceFilterList) {
2837
+ if (!this.fts.enabled || !this.fts.available) return [];
2838
+ const sourceFilter = this.buildSourceFilter(void 0, sourceFilterList);
2839
+ const providerModel = this.provider?.model;
2840
+ return (await searchKeyword({
2841
+ db: this.db,
2842
+ ftsTable: FTS_TABLE,
2843
+ providerModel,
2844
+ query,
2845
+ ftsTokenizer: this.settings.store.fts.tokenizer,
2846
+ limit,
2847
+ snippetMaxChars: SNIPPET_MAX_CHARS,
2848
+ sourceFilter,
2849
+ buildFtsQuery: (raw) => this.buildFtsQuery(raw),
2850
+ bm25RankToScore,
2851
+ boostFallbackRanking: options?.boostFallbackRanking
2852
+ })).map((entry) => entry);
2853
+ }
2854
+ mergeHybridResults(params) {
2855
+ return mergeHybridResults({
2856
+ vector: params.vector.map((r) => ({
2857
+ id: r.id,
2858
+ path: r.path,
2859
+ startLine: r.startLine,
2860
+ endLine: r.endLine,
2861
+ source: r.source,
2862
+ snippet: r.snippet,
2863
+ vectorScore: r.score
2864
+ })),
2865
+ keyword: params.keyword.map((r) => ({
2866
+ id: r.id,
2867
+ path: r.path,
2868
+ startLine: r.startLine,
2869
+ endLine: r.endLine,
2870
+ source: r.source,
2871
+ snippet: r.snippet,
2872
+ textScore: r.textScore
2873
+ })),
2874
+ vectorWeight: params.vectorWeight,
2875
+ textWeight: params.textWeight,
2876
+ mmr: params.mmr,
2877
+ temporalDecay: params.temporalDecay,
2878
+ workspaceDir: this.workspaceDir
2879
+ }).then((entries) => entries.map((entry) => entry));
2880
+ }
2881
+ async sync(params) {
2882
+ if (this.closed) return;
2883
+ await this.ensureProviderInitialized();
2884
+ if (this.syncing) {
2885
+ if (params?.sessionFiles?.some((sessionFile) => sessionFile.trim().length > 0)) return this.enqueueTargetedSessionSync(params.sessionFiles);
2886
+ return this.syncing;
2887
+ }
2888
+ this.syncing = this.runSyncWithReadonlyRecovery(params).finally(() => {
2889
+ this.syncing = null;
2890
+ });
2891
+ return this.syncing ?? Promise.resolve();
2892
+ }
2893
+ enqueueTargetedSessionSync(sessionFiles) {
2894
+ return enqueueMemoryTargetedSessionSync({
2895
+ isClosed: () => this.closed,
2896
+ getSyncing: () => this.syncing,
2897
+ getQueuedSessionFiles: () => this.queuedSessionFiles,
2898
+ getQueuedSessionSync: () => this.queuedSessionSync,
2899
+ setQueuedSessionSync: (value) => {
2900
+ this.queuedSessionSync = value;
2901
+ },
2902
+ sync: async (params) => await this.sync(params)
2903
+ }, sessionFiles);
2904
+ }
2905
+ isReadonlyDbError(err) {
2906
+ return isMemoryReadonlyDbError(err);
2907
+ }
2908
+ extractErrorReason(err) {
2909
+ return extractMemoryErrorReason(err);
2910
+ }
2911
+ async runSyncWithReadonlyRecovery(params) {
2912
+ const getClosed = () => this.closed;
2913
+ const getDb = () => this.db;
2914
+ const setDb = (value) => {
2915
+ this.db = value;
2916
+ };
2917
+ const getReadonlyRecoveryAttempts = () => this.readonlyRecoveryAttempts;
2918
+ const setReadonlyRecoveryAttempts = (value) => {
2919
+ this.readonlyRecoveryAttempts = value;
2920
+ };
2921
+ const getReadonlyRecoverySuccesses = () => this.readonlyRecoverySuccesses;
2922
+ const setReadonlyRecoverySuccesses = (value) => {
2923
+ this.readonlyRecoverySuccesses = value;
2924
+ };
2925
+ const getReadonlyRecoveryFailures = () => this.readonlyRecoveryFailures;
2926
+ const setReadonlyRecoveryFailures = (value) => {
2927
+ this.readonlyRecoveryFailures = value;
2928
+ };
2929
+ const getReadonlyRecoveryLastError = () => this.readonlyRecoveryLastError;
2930
+ const setReadonlyRecoveryLastError = (value) => {
2931
+ this.readonlyRecoveryLastError = value;
2932
+ };
2933
+ await runMemorySyncWithReadonlyRecovery({
2934
+ get closed() {
2935
+ return getClosed();
2936
+ },
2937
+ get db() {
2938
+ return getDb();
2939
+ },
2940
+ set db(value) {
2941
+ setDb(value);
2942
+ },
2943
+ vector: this.vector,
2944
+ get readonlyRecoveryAttempts() {
2945
+ return getReadonlyRecoveryAttempts();
2946
+ },
2947
+ set readonlyRecoveryAttempts(value) {
2948
+ setReadonlyRecoveryAttempts(value);
2949
+ },
2950
+ get readonlyRecoverySuccesses() {
2951
+ return getReadonlyRecoverySuccesses();
2952
+ },
2953
+ set readonlyRecoverySuccesses(value) {
2954
+ setReadonlyRecoverySuccesses(value);
2955
+ },
2956
+ get readonlyRecoveryFailures() {
2957
+ return getReadonlyRecoveryFailures();
2958
+ },
2959
+ set readonlyRecoveryFailures(value) {
2960
+ setReadonlyRecoveryFailures(value);
2961
+ },
2962
+ get readonlyRecoveryLastError() {
2963
+ return getReadonlyRecoveryLastError();
2964
+ },
2965
+ set readonlyRecoveryLastError(value) {
2966
+ setReadonlyRecoveryLastError(value);
2967
+ },
2968
+ runSync: (nextParams) => this.runSync(nextParams),
2969
+ openDatabase: () => this.openDatabase(),
2970
+ resetVectorState: () => this.resetVectorState(),
2971
+ ensureSchema: () => this.ensureSchema(),
2972
+ readMeta: () => this.readMeta() ?? void 0
2973
+ }, params);
2974
+ }
2975
+ async readFile(params) {
2976
+ return await readMemoryFile({
2977
+ workspaceDir: this.workspaceDir,
2978
+ extraPaths: this.settings.extraPaths,
2979
+ relPath: params.relPath,
2980
+ from: params.from,
2981
+ lines: params.lines
2982
+ });
2983
+ }
2984
+ status() {
2985
+ const sourceFilter = this.buildSourceFilter();
2986
+ const aggregateState = collectMemoryStatusAggregate({
2987
+ db: { prepare: (sql) => ({ all: (...args) => this.db.prepare(sql).all(...args) }) },
2988
+ sources: this.sources,
2989
+ sourceFilterSql: sourceFilter.sql,
2990
+ sourceFilterParams: sourceFilter.params
2991
+ });
2992
+ const providerInfo = resolveStatusProviderInfo({
2993
+ provider: this.provider,
2994
+ providerInitialized: this.providerInitialized,
2995
+ requestedProvider: this.requestedProvider,
2996
+ configuredModel: this.settings.model || void 0
2997
+ });
2998
+ return {
2999
+ backend: "builtin",
3000
+ files: aggregateState.files,
3001
+ chunks: aggregateState.chunks,
3002
+ dirty: this.dirty || this.sessionsDirty,
3003
+ workspaceDir: this.workspaceDir,
3004
+ dbPath: this.settings.store.path,
3005
+ provider: providerInfo.provider,
3006
+ model: providerInfo.model,
3007
+ requestedProvider: this.requestedProvider,
3008
+ sources: Array.from(this.sources),
3009
+ extraPaths: this.settings.extraPaths,
3010
+ sourceCounts: aggregateState.sourceCounts,
3011
+ cache: this.cache.enabled ? {
3012
+ enabled: true,
3013
+ entries: this.db.prepare(`SELECT COUNT(*) as c FROM ${EMBEDDING_CACHE_TABLE}`).get()?.c ?? 0,
3014
+ maxEntries: this.cache.maxEntries
3015
+ } : {
3016
+ enabled: false,
3017
+ maxEntries: this.cache.maxEntries
3018
+ },
3019
+ fts: {
3020
+ enabled: this.fts.enabled,
3021
+ available: this.fts.available,
3022
+ error: this.fts.loadError
3023
+ },
3024
+ fallback: this.fallbackReason ? {
3025
+ from: this.fallbackFrom ?? "local",
3026
+ reason: this.fallbackReason
3027
+ } : void 0,
3028
+ vector: {
3029
+ enabled: this.vector.enabled,
3030
+ available: this.vector.available ?? void 0,
3031
+ extensionPath: this.vector.extensionPath,
3032
+ loadError: this.vector.loadError,
3033
+ dims: this.vector.dims
3034
+ },
3035
+ batch: {
3036
+ enabled: this.batch.enabled,
3037
+ failures: this.batchFailureCount,
3038
+ limit: 2,
3039
+ wait: this.batch.wait,
3040
+ concurrency: this.batch.concurrency,
3041
+ pollIntervalMs: this.batch.pollIntervalMs,
3042
+ timeoutMs: this.batch.timeoutMs,
3043
+ lastError: this.batchFailureLastError,
3044
+ lastProvider: this.batchFailureLastProvider
3045
+ },
3046
+ custom: {
3047
+ searchMode: providerInfo.searchMode,
3048
+ providerUnavailableReason: this.providerUnavailableReason,
3049
+ readonlyRecovery: {
3050
+ attempts: this.readonlyRecoveryAttempts,
3051
+ successes: this.readonlyRecoverySuccesses,
3052
+ failures: this.readonlyRecoveryFailures,
3053
+ lastError: this.readonlyRecoveryLastError
3054
+ }
3055
+ }
3056
+ };
3057
+ }
3058
+ async probeVectorAvailability() {
3059
+ if (!this.vector.enabled) return false;
3060
+ await this.ensureProviderInitialized();
3061
+ if (!this.provider) return false;
3062
+ return this.ensureVectorReady();
3063
+ }
3064
+ async probeEmbeddingAvailability() {
3065
+ await this.ensureProviderInitialized();
3066
+ if (!this.provider) return {
3067
+ ok: false,
3068
+ error: this.providerUnavailableReason ?? "No embedding provider available (FTS-only mode)"
3069
+ };
3070
+ try {
3071
+ await this.embedBatchWithRetry(["ping"]);
3072
+ return { ok: true };
3073
+ } catch (err) {
3074
+ return {
3075
+ ok: false,
3076
+ error: formatErrorMessage(err)
3077
+ };
3078
+ }
3079
+ }
3080
+ async close() {
3081
+ if (this.closed) return;
3082
+ this.closed = true;
3083
+ const pendingSync = this.syncing;
3084
+ const pendingProviderInit = this.providerInitPromise;
3085
+ if (this.watchTimer) {
3086
+ clearTimeout(this.watchTimer);
3087
+ this.watchTimer = null;
3088
+ }
3089
+ if (this.sessionWatchTimer) {
3090
+ clearTimeout(this.sessionWatchTimer);
3091
+ this.sessionWatchTimer = null;
3092
+ }
3093
+ if (this.intervalTimer) {
3094
+ clearInterval(this.intervalTimer);
3095
+ this.intervalTimer = null;
3096
+ }
3097
+ if (this.watcher) {
3098
+ await this.watcher.close();
3099
+ this.watcher = null;
3100
+ }
3101
+ if (this.sessionUnsubscribe) {
3102
+ this.sessionUnsubscribe();
3103
+ this.sessionUnsubscribe = null;
3104
+ }
3105
+ await awaitPendingManagerWork({
3106
+ pendingSync,
3107
+ pendingProviderInit
3108
+ });
3109
+ this.db.close();
3110
+ INDEX_CACHE.delete(this.cacheKey);
3111
+ }
3112
+ };
3113
+ //#endregion
3114
+ export { listBuiltinAutoSelectMemoryEmbeddingProviderDoctorMetadata as a, getBuiltinMemoryEmbeddingProviderDoctorMetadata as i, closeAllMemoryIndexManagers as n, registerBuiltInMemoryEmbeddingProviders as o, createEmbeddingProvider as r, MemoryIndexManager as t };