@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.
- package/CHANGELOG.md +16 -0
- package/dist/.buildstamp +1 -1
- package/dist/abort-FuQvBD6U.js +201 -0
- package/dist/abort-cutoff.runtime-DhhkmUom.js +20 -0
- package/dist/abort-cutoff.runtime.js +1 -1
- package/dist/abort.runtime-B3IgkoFt.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/accounts-BPUJOLhQ.js +66 -0
- package/dist/accounts-CAneScu8.js +104 -0
- package/dist/accounts-CHR1oSF7.js +43 -0
- package/dist/accounts-CJ6NSXHe.js +2 -0
- package/dist/accounts-DIkEzenx.js +365 -0
- package/dist/accounts-DSBZWK21.js +107 -0
- package/dist/accounts.runtime-CbxAqfkd.js +2 -0
- package/dist/accounts.runtime.js +1 -1
- package/dist/acp-cli-ogRPWqZT.js +2217 -0
- package/dist/acp-spawn-8dy4yT3V.js +2 -0
- package/dist/acp-spawn-BjYzM6z-.js +1093 -0
- package/dist/acp-stateful-target-driver-BycE6-83.js +89 -0
- package/dist/action-agents-l7277wqt.js +67 -0
- package/dist/action-focus-Dl60p5pD.js +132 -0
- package/dist/action-help-DxLv4lVR.js +7 -0
- package/dist/action-info-DL9E3-WR.js +101 -0
- package/dist/action-kill-D9o9OmhF.js +33 -0
- package/dist/action-list-CHZdMgmX.js +21 -0
- package/dist/action-log-CU2gXtSM.js +30 -0
- package/dist/action-send-Bh6VyKBO.js +39 -0
- package/dist/action-spawn-CRh30i-w.js +47 -0
- package/dist/action-unfocus-DWfvqVUr.js +29 -0
- package/dist/actions.runtime-CSqrY29N.js +18 -0
- package/dist/actions.runtime-DfxS3edG.js +5 -0
- package/dist/actions.runtime.js +1 -1
- package/dist/agent-command-VhOY45sc.js +874 -0
- package/dist/agent-delivery-KWJUVuVh.js +76 -0
- package/dist/agent-harness-runtime-BMQd9IQM.js +144 -0
- package/dist/agent-rstdDGqC.js +2 -0
- package/dist/agent-runner-utils-B6emOCxL.js +239 -0
- package/dist/agent-runner.runtime-Dt9pfuFv.js +3455 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-D5sio5gj.js +18 -0
- package/dist/agents-DETbymgH.js +5 -0
- package/dist/agents-JnpGV0Mg.js +954 -0
- package/dist/agents.command-shared-DP-GYkQM.js +40 -0
- package/dist/aliases-CjpePDVQ.js +96 -0
- package/dist/aliases-Doxg0x1v.js +2 -0
- package/dist/api-3RLMm-sv.js +48 -0
- package/dist/api-BFMX7Y4G.js +139 -0
- package/dist/api-DNZZlJ9_.js +3 -0
- package/dist/api-DT7zQn5K.js +5 -0
- package/dist/api-Dg7zYoZ_.js +3 -0
- package/dist/api-cghJ3F6o.js +4 -0
- package/dist/apply-DfMBIGyY.js +508 -0
- package/dist/apply.runtime-C0oOWIW8.js +2 -0
- package/dist/apply.runtime.js +1 -1
- package/dist/approval-client-helpers-D2LpKFDf.js +82 -0
- package/dist/approval-delivery-helpers-CmhRlLZJ.js +134 -0
- package/dist/approval-gateway-resolver-BjqCdv8k.js +29 -0
- package/dist/approval-gateway-runtime-vc_h56PW.js +2 -0
- package/dist/approval-handler-runtime-CLi8o4N6.js +439 -0
- package/dist/approval-native-helpers-BJTvZT00.js +33 -0
- package/dist/approval-native-runtime-BCglJkGQ.js +729 -0
- package/dist/approval-renderers-B2Vy1H8m.js +64 -0
- package/dist/attempt-execution.runtime-BJ2ggQLO.js +509 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt-execution.shared-drVqEuBX.js +22 -0
- package/dist/attempt.prompt-helpers-CPOKGBRq.js +221 -0
- package/dist/attempt.tool-run-context-b245l8XM.js +933 -0
- package/dist/audit-DTHRJzg2.js +939 -0
- package/dist/audit-membership-runtime-BJqpONbJ.js +550 -0
- package/dist/audit.runtime-CX2MkQvJ.js +7 -0
- package/dist/audit.runtime.js +1 -1
- package/dist/auth-4Bm-1bcd.js +177 -0
- package/dist/auth-BZdTw_F-.js +56 -0
- package/dist/auth-CuwCoyT1.js +550 -0
- package/dist/auth-DIgzPDDK.js +2 -0
- package/dist/auth-order-BY3KAiKC.js +2 -0
- package/dist/auth-order-Dg56giIe.js +139 -0
- package/dist/base-url-C558HJO5.js +15 -0
- package/dist/bash-tools-CfDemvWu.js +2824 -0
- package/dist/bash-tools-Dn5gcYvt.js +3 -0
- package/dist/bash-tools.exec-runtime-dke732lC.js +829 -0
- package/dist/best-effort-delivery-DljQXVME.js +22 -0
- package/dist/binding-routing-DR_67bg0.js +85 -0
- package/dist/binding-targets-DTa463kX.js +121 -0
- package/dist/block-streaming-CSQXIKzf.js +103 -0
- package/dist/bluebubbles-Ct06wUcN.js +77 -0
- package/dist/brave-web-search-provider-CXpJbGgI.js +111 -0
- package/dist/brave-web-search-provider.runtime-wY0sclse.js +229 -0
- package/dist/brave-web-search-provider.runtime.js +1 -1
- package/dist/brave-web-search-provider.shared-CRDSDuDf.js +174 -0
- package/dist/bridge-auth-registry-BorAQxuW.js +23 -0
- package/dist/bridge-server-BjsnFWH5.js +113 -0
- package/dist/browser-control-auth-K_ABcymZ.js +2 -0
- package/dist/browser-node-runtime-Djr0LEX4.js +12 -0
- package/dist/browser-profiles-D-JVGcFQ.js +2 -0
- package/dist/browser-runtime-Dtu4pSLX.js +387 -0
- package/dist/browser-setup-tools-DOMK1dxP.js +13 -0
- package/dist/build-DIqCC9wY.js +550 -0
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +3 -3
- package/dist/bundled/session-memory/handler.js +1 -1
- package/dist/call-CBwbz0Y_.js +3 -0
- package/dist/call-CMzLsAeQ.js +331 -0
- package/dist/call-status-D_PRqurB.js +33 -0
- package/dist/call.runtime-TShzrwtE.js +2 -0
- package/dist/call.runtime.js +1 -1
- package/dist/capability-cli-eqSRFvPG.js +1401 -0
- package/dist/card-command-DgCNU0bS.js +241 -0
- package/dist/catalog-provider-BQCfbyPd.js +40 -0
- package/dist/catchup-B0RMVns9.js +300 -0
- package/dist/channel-35I4A3FQ.js +1802 -0
- package/dist/channel-B68Jn_67.js +491 -0
- package/dist/channel-BpHCHrCO.js +350 -0
- package/dist/channel-CLV2rd5J.js +1174 -0
- package/dist/channel-COt8yEeA.js +226 -0
- package/dist/channel-CQOr5HA2.js +595 -0
- package/dist/channel-CY88u47q.js +1100 -0
- package/dist/channel-Cz5FQxuV.js +1320 -0
- package/dist/channel-_FIMA_4n.js +840 -0
- package/dist/channel-core-DH_fXGdB.js +5 -0
- package/dist/channel-inbound-DsSKYRQk.js +31 -0
- package/dist/channel-kbFJLAok.js +453 -0
- package/dist/channel-plugin-runtime-1zw5fP7e.js +771 -0
- package/dist/channel-resolution-BQCJwoVA.js +39 -0
- package/dist/channel-runtime-DKTzKZrY.js +425 -0
- package/dist/channel-selection-CfVNh5Ma.js +126 -0
- package/dist/channel-selection.runtime-5JjJNFm5.js +2 -0
- package/dist/channel-selection.runtime.js +1 -1
- package/dist/channel-t7y5VhIk.js +297 -0
- package/dist/channel.runtime-BxFS1fqc.js +26 -0
- package/dist/channel.runtime-C4vTK1SO.js +576 -0
- package/dist/channel.runtime-Cb5xElcA.js +42398 -0
- package/dist/channel.runtime-Cg2IHutr.js +89 -0
- package/dist/channel.runtime-CuDcjlCH.js +4 -0
- package/dist/channel.runtime-DhuYxzU_.js +67 -0
- package/dist/channel.runtime-LtoAmHpA.js +2364 -0
- package/dist/channel.runtime-fe2tuhl7.js +430 -0
- package/dist/channel.runtime.js +1 -1
- package/dist/channel.setup-De742gXr.js +10 -0
- package/dist/channel2.runtime-D0-Q3OqX.js +109 -0
- package/dist/channel2.runtime.js +1 -1
- package/dist/channels-Dg381GJl.js +733 -0
- package/dist/channels-cli-C4Mv5lRD.js +268 -0
- package/dist/chat-DraQ_Vnc.js +2830 -0
- package/dist/chrome-NuBBXoKP.js +1430 -0
- package/dist/chrome-mcp-Bzn6x9ZE.js +2 -0
- package/dist/chrome-mcp-JcJrSyd_.js +600 -0
- package/dist/chrome.executables-B2fHBMhv.js +541 -0
- package/dist/chunk-nFZYBJd4.js +268 -0
- package/dist/clawbot-cli-BZ5Ho8RJ.js +9 -0
- package/dist/cli/daemon-cli.js +3 -3
- package/dist/cli-B8D7xwgW.js +2 -0
- package/dist/cli-BbCsXDcy.js +2 -0
- package/dist/cli-Ct2Cgbp8.js +154 -0
- package/dist/cli-D1e_2N91.js +3726 -0
- package/dist/cli-D8pyHyFi.js +72 -0
- package/dist/cli-eRz4BLSt.js +2 -0
- package/dist/cli-mD8ZWE4Y.js +219 -0
- package/dist/cli-runner-BVFPfETV.js +286 -0
- package/dist/cli-runner.runtime-CcxMMyO0.js +3 -0
- package/dist/cli-runner.runtime-MmlDBELB.js +4 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +2 -2
- package/dist/cli.runtime-CG9Epd6c.js +1261 -0
- package/dist/cli.runtime.js +1 -1
- package/dist/client-BtyYQE4I.js +713 -0
- package/dist/client-XqW1gKEi.js +138 -0
- package/dist/client-info-DeQMz3zN.js +52 -0
- package/dist/command-auth-C8YZ7xNT.js +409 -0
- package/dist/command-auth-CZjLC0A5.js +76 -0
- package/dist/command-config-resolution-C42_gG_b.js +2 -0
- package/dist/command-config-resolution-DGrpZjql.js +23 -0
- package/dist/command-config-resolution.runtime-D8PGJbcf.js +2 -0
- package/dist/command-config-resolution.runtime.js +1 -1
- package/dist/command-execution-startup-LCePq-pd.js +324 -0
- package/dist/command-gates-C1GpyUaI.js +47 -0
- package/dist/command-registry-Brd-fdF6.js +9 -0
- package/dist/command-registry-C9XhD-0z.js +4 -0
- package/dist/command-registry-core-BBFaOPyw.js +106 -0
- package/dist/command-secret-gateway-_i9GgsPE.js +528 -0
- package/dist/command-status.runtime-C-azOR6K.js +87 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-acp-cpGZ404g.js +77 -0
- package/dist/commands-compact.runtime-CXWGv2V6.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-context-DZzZWgOe.js +38 -0
- package/dist/commands-core.runtime-BqbYtFGd.js +2 -0
- package/dist/commands-core.runtime.js +1 -1
- package/dist/commands-handlers.runtime-BcIJeLbE.js +4599 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-models-BScPCL8E.js +327 -0
- package/dist/commands-reset-hooks-5uvV2mDE.js +135 -0
- package/dist/commands-status-CIyza-rp.js +16 -0
- package/dist/commands-status.runtime-CqMsNHJz.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-BVTHxVDG.js +2 -0
- package/dist/commands-subagents-control.runtime-DdiL_B5Y.js +3 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-DCmABzHv.js +158 -0
- package/dist/commands-system-prompt-DsWVuYqh.js +2 -0
- package/dist/commands.runtime-CBu1iNc5.js +167 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/compact-OC23uUnx.js +1118 -0
- package/dist/compact.runtime-BnEUkxbT.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-Dazyh2sJ.js +328 -0
- package/dist/config-BQkNdc69.js +252 -0
- package/dist/config-api-BKYSOnnY.js +2 -0
- package/dist/config-cli-DLlHp2db.js +1078 -0
- package/dist/config-compat-BIX-j6Si.js +130 -0
- package/dist/config-compat-BwlAvvWb.js +126 -0
- package/dist/config-guard-MokLrRXO.js +96 -0
- package/dist/config-runtime-EDLCUCSu.js +32 -0
- package/dist/configure-Bb8n7ry_.js +1252 -0
- package/dist/configure-_pHM_yQw.js +2 -0
- package/dist/connect-options-3xkNjdH1.js +699 -0
- package/dist/control-auth-BXNajQ4N.js +125 -0
- package/dist/control-service-89oBONRk.js +156 -0
- package/dist/control-ui/assets/agents-BQsvYsmp.js +1052 -0
- package/dist/control-ui/assets/canvas-D92UKk4C.js +269 -0
- package/dist/control-ui/assets/channels-B23D1XmP.js +463 -0
- package/dist/control-ui/assets/cron-CYzrBBv6.js +933 -0
- package/dist/control-ui/assets/debug-C8av-vpc.js +94 -0
- package/dist/control-ui/assets/index-ChL66WCS.js +6238 -0
- package/dist/control-ui/assets/index-Dq9zdUBj.css +1 -0
- package/dist/control-ui/assets/instances-qfDdYtE0.js +57 -0
- package/dist/control-ui/assets/mcp-CipBqkHK.js +373 -0
- package/dist/control-ui/assets/nodes-WP7e87Mm.js +618 -0
- package/dist/control-ui/assets/plugins-BZGJKpWs.js +273 -0
- package/dist/control-ui/assets/sessions-7NbJpVyg.js +306 -0
- package/dist/control-ui/assets/skills-hW_GTRp3.js +323 -0
- package/dist/control-ui/assets/wallet-Bga18qp4.js +285 -0
- package/dist/control-ui/index.html +2 -2
- package/dist/control-ui-nxEuCu7Y.js +1043 -0
- package/dist/conversation-id-BXdEWBuk.js +38 -0
- package/dist/conversation-id-HnQrCUJb.js +235 -0
- package/dist/conversation-runtime-DOPjHG-D.js +31 -0
- package/dist/core-BglliBki.js +275 -0
- package/dist/create-DcvM0ElD.js +80 -0
- package/dist/cron-cli-DbZllbTi.js +713 -0
- package/dist/daemon-cli-BCP6oYnN.js +12 -0
- package/dist/dashboard-74d-EIMB.js +81 -0
- package/dist/dashboard-C0aOhuxv.js +2 -0
- package/dist/ddg-client-DUe6RTVg.js +147 -0
- package/dist/ddg-search-provider-Bm0jAm4h.js +54 -0
- package/dist/delegate-0l_cL2en.js +64 -0
- package/dist/deliver-BbAfYPEn.js +3 -0
- package/dist/deliver-DmZnoo4L.js +747 -0
- package/dist/deliver-runtime-5H2EYniG.js +2 -0
- package/dist/delivery-context-DP5JLMHJ.js +40 -0
- package/dist/delivery-outbound.runtime-DQEeDEsu.js +6 -0
- package/dist/delivery-outbound.runtime.js +1 -1
- package/dist/delivery.runtime-Bi7HZGxD.js +253 -0
- package/dist/delivery.runtime.js +1 -1
- package/dist/detached-task-runtime-DlQ3fJk5.js +73 -0
- package/dist/devices-cli-BLCk402O.js +498 -0
- package/dist/diagnostics-Ccv6wIwn.js +154 -0
- package/dist/direct-dm-lEcFUgjs.js +64 -0
- package/dist/directive-handling.fast-lane-Cp4AUlKY.js +66 -0
- package/dist/directive-handling.impl-5h27Bn7L.js +703 -0
- package/dist/directive-handling.impl-XC63bDbc.js +2 -0
- package/dist/directive-handling.model-selection-D0aMABmk.js +114 -0
- package/dist/directive-handling.persist.runtime-DDNAkC4Z.js +215 -0
- package/dist/directive-handling.persist.runtime.js +1 -1
- package/dist/directive-handling.shared-DyVSHQBC.js +56 -0
- package/dist/directory-cli-CDvyD_lg.js +240 -0
- package/dist/dispatch-Dd327enz.js +1131 -0
- package/dist/dispatch-acp-6k3pJubU.js +981 -0
- package/dist/dispatch-acp-manager.runtime-B7qhOTmA.js +3 -0
- package/dist/dispatch-acp-manager.runtime.js +1 -1
- package/dist/dispatch-acp-media.runtime-Dh6QaiKm.js +4 -0
- package/dist/dispatch-acp-media.runtime.js +1 -1
- package/dist/dispatch-acp-session.runtime-DIcbAze4.js +2 -0
- package/dist/dispatch-acp-session.runtime.js +1 -1
- package/dist/dispatch-acp.runtime-25XWZDxg.js +19 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/doctor-config-flow-sE-lNSad.js +420 -0
- package/dist/doctor-config-preflight-VYCO67J4.js +63 -0
- package/dist/doctor-config-preflight-qSk2JNLg.js +2 -0
- package/dist/doctor-contract-BAsLLlR_.js +26 -0
- package/dist/doctor-device-pairing-BXDxtsmA.js +307 -0
- package/dist/doctor-gateway-daemon-flow-CHRWhGJG.js +250 -0
- package/dist/doctor-gateway-health-B04Kph1-.js +63 -0
- package/dist/doctor-health-contributions-Di1lbh4V.js +493 -0
- package/dist/doctor-health-vZ_aKkfh.js +59 -0
- package/dist/doctor-prompter-Cr1NyTHN.js +56 -0
- package/dist/doctor-sandbox-CrC9AbfL.js +194 -0
- package/dist/doctor-state-migrations-tkILPnwB.js +2 -0
- package/dist/doctor-workspace-status-CPUsFX3w.js +75 -0
- package/dist/dreaming-CeLuSaLi.js +1582 -0
- package/dist/dreaming-narrative-gKfNqC2s.js +596 -0
- package/dist/dreaming-shared-BLs-EJbE.js +21 -0
- package/dist/embedded-gateway-stub.runtime-8jv6iwO4.js +9 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/embeddings-CSeRG-6f.js +215 -0
- package/dist/embeddings-http-9k11WSE6.js +205 -0
- package/dist/entry.js +2 -2
- package/dist/exa-web-search-provider-DeSQ1lkN.js +80 -0
- package/dist/exa-web-search-provider.runtime-BHWIPnmu.js +302 -0
- package/dist/exa-web-search-provider.runtime-C84CVfco.js +2 -0
- package/dist/exa-web-search-provider.runtime.js +1 -1
- package/dist/exec-approval-forwarder.runtime-BMw0YxXn.js +3 -0
- package/dist/exec-approval-forwarder.runtime.js +1 -1
- package/dist/exec-approval-reply-BTNXbvSi.js +2 -0
- package/dist/exec-approval-reply-BVINNdDT.js +296 -0
- package/dist/exec-approval-session-target-BclZJwRq.js +176 -0
- package/dist/exec-approvals-cli-BvRs9Hvl.js +498 -0
- package/dist/exec-defaults-BzfzJhdd.js +2 -0
- package/dist/exec-defaults-DJtYK-Wg.js +67 -0
- package/dist/execute.runtime-C-v-Cnhl.js +1363 -0
- package/dist/execute.runtime.js +1 -1
- package/dist/extensionAPI.js +3 -3
- package/dist/extensions/active-memory/index.js +3 -3
- package/dist/extensions/bluebubbles/api.js +3 -3
- package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
- package/dist/extensions/brave/index.js +1 -1
- package/dist/extensions/brave/test-api.js +1 -1
- package/dist/extensions/brave/web-search-provider.js +1 -1
- package/dist/extensions/browser/browser-bridge.js +1 -1
- package/dist/extensions/browser/browser-config.js +4 -4
- package/dist/extensions/browser/browser-control-auth.js +2 -2
- package/dist/extensions/browser/browser-doctor.js +5 -5
- package/dist/extensions/browser/browser-host-inspection.js +1 -1
- package/dist/extensions/browser/browser-maintenance.js +2 -2
- package/dist/extensions/browser/browser-profiles.js +2 -2
- package/dist/extensions/browser/browser-runtime-api.js +14 -14
- package/dist/extensions/browser/index.js +1 -1
- package/dist/extensions/browser/plugin-registration.js +1 -1
- package/dist/extensions/browser/register.runtime.js +3 -3
- package/dist/extensions/browser/runtime-api.js +15 -15
- package/dist/extensions/browser/setup-api.js +2 -2
- package/dist/extensions/browser/test-support.js +1 -1
- package/dist/extensions/byteplus/index.js +1 -1
- package/dist/extensions/byteplus/video-generation-provider.js +1 -1
- package/dist/extensions/chutes/api.js +3 -3
- package/dist/extensions/chutes/index.js +4 -4
- package/dist/extensions/chutes/models.js +1 -1
- package/dist/extensions/chutes/onboard.js +2 -2
- package/dist/extensions/chutes/provider-catalog.js +1 -1
- package/dist/extensions/cloudflare-ai-gateway/api.js +1 -1
- package/dist/extensions/cloudflare-ai-gateway/catalog-provider.js +1 -1
- package/dist/extensions/cloudflare-ai-gateway/index.js +2 -2
- package/dist/extensions/comfy/image-generation-provider.js +2 -2
- package/dist/extensions/comfy/index.js +3 -3
- package/dist/extensions/comfy/music-generation-provider.js +1 -1
- package/dist/extensions/comfy/video-generation-provider.js +2 -2
- package/dist/extensions/comfy/workflow-runtime.js +1 -1
- package/dist/extensions/deepgram/index.js +1 -1
- package/dist/extensions/deepgram/realtime-transcription-provider.js +1 -1
- package/dist/extensions/deepgram/test-api.js +1 -1
- package/dist/extensions/device-pair/api.js +2 -2
- package/dist/extensions/device-pair/index.js +5 -5
- package/dist/extensions/device-pair/notify.js +1 -1
- package/dist/extensions/device-pair/pair-command-approve.js +1 -1
- package/dist/extensions/device-pair/qr-image.js +2 -2
- package/dist/extensions/duckduckgo/index.js +1 -1
- package/dist/extensions/duckduckgo/web-search-provider.js +1 -1
- package/dist/extensions/elevenlabs/config-compat.js +1 -1
- package/dist/extensions/elevenlabs/contract-api.js +2 -2
- package/dist/extensions/elevenlabs/doctor-contract.js +2 -2
- package/dist/extensions/elevenlabs/index.js +2 -2
- package/dist/extensions/elevenlabs/realtime-transcription-provider.js +1 -1
- package/dist/extensions/elevenlabs/setup-api.js +1 -1
- package/dist/extensions/elevenlabs/speech-provider.js +1 -1
- package/dist/extensions/elevenlabs/test-api.js +2 -2
- package/dist/extensions/exa/index.js +1 -1
- package/dist/extensions/exa/test-api.js +1 -1
- package/dist/extensions/exa/web-search-provider.js +1 -1
- package/dist/extensions/fal/image-generation-provider.js +1 -1
- package/dist/extensions/fal/index.js +2 -2
- package/dist/extensions/fal/test-api.js +2 -2
- package/dist/extensions/fal/video-generation-provider.js +1 -1
- package/dist/extensions/firecrawl/api.js +1 -1
- package/dist/extensions/github-copilot/api.js +1 -1
- package/dist/extensions/github-copilot/auth.js +1 -1
- package/dist/extensions/github-copilot/embeddings.js +1 -1
- package/dist/extensions/github-copilot/index.js +6 -6
- package/dist/extensions/github-copilot/login.js +1 -1
- package/dist/extensions/github-copilot/models-defaults.js +1 -1
- package/dist/extensions/github-copilot/models.js +1 -1
- package/dist/extensions/github-copilot/register.runtime.js +1 -1
- package/dist/extensions/github-copilot/replay-policy.js +1 -1
- package/dist/extensions/google-meet/index.js +5 -5
- package/dist/extensions/huggingface/api.js +3 -3
- package/dist/extensions/huggingface/index.js +2 -2
- package/dist/extensions/huggingface/models.js +1 -1
- package/dist/extensions/huggingface/onboard.js +1 -1
- package/dist/extensions/huggingface/provider-catalog.js +2 -2
- package/dist/extensions/imessage/api.js +5 -5
- package/dist/extensions/imessage/channel-plugin-api.js +1 -1
- package/dist/extensions/imessage/contract-api.js +2 -2
- package/dist/extensions/imessage/media-contract-api.js +2 -2
- package/dist/extensions/imessage/runtime-api.js +5 -5
- package/dist/extensions/imessage/test-api.js +2 -2
- package/dist/extensions/irc/api.js +2 -2
- package/dist/extensions/irc/channel-plugin-api.js +1 -1
- package/dist/extensions/kilocode/api.js +2 -2
- package/dist/extensions/kilocode/index.js +3 -3
- package/dist/extensions/kilocode/onboard.js +2 -2
- package/dist/extensions/kilocode/provider-catalog.js +1 -1
- package/dist/extensions/kilocode/provider-models.js +1 -1
- package/dist/extensions/kilocode/shared.js +1 -1
- package/dist/extensions/kimi-coding/index.js +2 -2
- package/dist/extensions/kimi-coding/stream.js +1 -1
- package/dist/extensions/line/api.js +2 -2
- package/dist/extensions/line/channel-plugin-api.js +1 -1
- package/dist/extensions/line/contract-api.js +1 -1
- package/dist/extensions/line/index.js +1 -1
- package/dist/extensions/line/runtime-api.js +7 -7
- package/dist/extensions/line/setup-api.js +1 -1
- package/dist/extensions/llm-task/index.js +1 -1
- package/dist/extensions/lmstudio/api.js +1 -1
- package/dist/extensions/lmstudio/index.js +2 -2
- package/dist/extensions/lmstudio/memory-embedding-adapter.js +1 -1
- package/dist/extensions/lmstudio/runtime-api.js +1 -1
- package/dist/extensions/lobster/runtime-api.js +1 -1
- package/dist/extensions/mattermost/api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
- package/dist/extensions/mattermost/policy-api.js +1 -1
- package/dist/extensions/mattermost/runtime-api.js +9 -9
- package/dist/extensions/mattermost/slash-route-api.js +1 -1
- package/dist/extensions/memory-core/api.js +1 -1
- package/dist/extensions/memory-core/cli-metadata.js +2 -2
- package/dist/extensions/memory-core/index.js +9 -9
- package/dist/extensions/memory-core/manager-runtime.js +1 -1
- package/dist/extensions/memory-core/runtime-api.js +4 -4
- package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
- package/dist/extensions/memory-lancedb/index.js +2 -2
- package/dist/extensions/memory-wiki/cli-metadata.js +1 -1
- package/dist/extensions/memory-wiki/index.js +1 -1
- package/dist/extensions/microsoft/index.js +1 -1
- package/dist/extensions/microsoft/speech-provider.js +1 -1
- package/dist/extensions/microsoft/test-api.js +1 -1
- package/dist/extensions/microsoft/tts.js +1 -1
- package/dist/extensions/microsoft-foundry/auth.js +1 -1
- package/dist/extensions/microsoft-foundry/cli.js +1 -1
- package/dist/extensions/microsoft-foundry/index.js +1 -1
- package/dist/extensions/microsoft-foundry/onboard.js +2 -2
- package/dist/extensions/microsoft-foundry/provider.js +1 -1
- package/dist/extensions/microsoft-foundry/runtime.js +1 -1
- package/dist/extensions/microsoft-foundry/shared-runtime.js +2 -2
- package/dist/extensions/microsoft-foundry/shared.js +1 -1
- package/dist/extensions/minimax/index.js +5 -5
- package/dist/extensions/minimax/music-generation-provider.js +1 -1
- package/dist/extensions/minimax/provider-registration.js +1 -1
- package/dist/extensions/minimax/speech-provider.js +1 -1
- package/dist/extensions/minimax/test-api.js +3 -3
- package/dist/extensions/minimax/video-generation-provider.js +1 -1
- package/dist/extensions/minimax/web-search-provider.js +1 -1
- package/dist/extensions/mistral/index.js +2 -2
- package/dist/extensions/mistral/provider-compat.js +1 -1
- package/dist/extensions/mistral/realtime-transcription-provider.js +1 -1
- package/dist/extensions/mistral/test-api.js +1 -1
- package/dist/extensions/moonshot/index.js +1 -1
- package/dist/extensions/moonshot/test-api.js +1 -1
- package/dist/extensions/moonshot/web-search-provider.js +1 -1
- package/dist/extensions/msteams/api.js +1 -1
- package/dist/extensions/msteams/channel-plugin-api.js +1 -1
- package/dist/extensions/msteams/runtime-api.js +4 -4
- package/dist/extensions/msteams/test-api.js +1 -1
- package/dist/extensions/nextcloud-talk/api.js +1 -1
- package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
- package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
- package/dist/extensions/ollama/api.js +3 -3
- package/dist/extensions/ollama/index.js +5 -5
- package/dist/extensions/ollama/runtime-api.js +1 -1
- package/dist/extensions/ollama/web-search-provider.js +1 -1
- package/dist/extensions/openai/api.js +4 -4
- package/dist/extensions/openai/base-url.js +1 -1
- package/dist/extensions/openai/image-generation-provider.js +1 -1
- package/dist/extensions/openai/index.js +8 -8
- package/dist/extensions/openai/native-web-search.js +1 -1
- package/dist/extensions/openai/openai-codex-auth-identity.js +1 -1
- package/dist/extensions/openai/openai-codex-device-code.js +1 -1
- package/dist/extensions/openai/openai-codex-provider.js +1 -1
- package/dist/extensions/openai/openai-codex-shared.js +1 -1
- package/dist/extensions/openai/openai-provider.js +1 -1
- package/dist/extensions/openai/realtime-provider-shared.js +1 -1
- package/dist/extensions/openai/realtime-transcription-provider.js +1 -1
- package/dist/extensions/openai/realtime-voice-provider.js +1 -1
- package/dist/extensions/openai/register.runtime.js +6 -6
- package/dist/extensions/openai/shared.js +1 -1
- package/dist/extensions/openai/speech-provider.js +1 -1
- package/dist/extensions/openai/test-api.js +5 -5
- package/dist/extensions/openai/transport-policy.js +1 -1
- package/dist/extensions/openai/video-generation-provider.js +1 -1
- package/dist/extensions/opencode/index.js +1 -1
- package/dist/extensions/openrouter/api.js +2 -2
- package/dist/extensions/openrouter/image-generation-provider.js +1 -1
- package/dist/extensions/openrouter/index.js +2 -2
- package/dist/extensions/openrouter/register.runtime.js +1 -1
- package/dist/extensions/openrouter/speech-provider.js +1 -1
- package/dist/extensions/openrouter/test-api.js +2 -2
- package/dist/extensions/openshell/index.js +4 -4
- package/dist/extensions/perplexity/index.js +1 -1
- package/dist/extensions/perplexity/test-api.js +1 -1
- package/dist/extensions/perplexity/web-search-provider.js +1 -1
- package/dist/extensions/phone-control/index.js +1 -1
- package/dist/extensions/runway/index.js +1 -1
- package/dist/extensions/runway/video-generation-provider.js +1 -1
- package/dist/extensions/signal/api.js +11 -11
- package/dist/extensions/signal/channel-plugin-api.js +1 -1
- package/dist/extensions/signal/contract-api.js +2 -2
- package/dist/extensions/signal/reaction-runtime-api.js +1 -1
- package/dist/extensions/signal/runtime-api.js +14 -14
- package/dist/extensions/skill-workshop/api.js +1 -1
- package/dist/extensions/skill-workshop/index.js +2 -2
- package/dist/extensions/speech-core/runtime-api.js +2 -2
- package/dist/extensions/stepfun/index.js +1 -1
- package/dist/extensions/synology-chat/api.js +1 -1
- package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
- package/dist/extensions/talk-voice/index.js +2 -2
- package/dist/extensions/tavily/index.js +2 -2
- package/dist/extensions/tavily/web-search-provider.js +1 -1
- package/dist/extensions/thread-ownership/index.js +2 -2
- package/dist/extensions/tlon/api.js +2 -2
- package/dist/extensions/tlon/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/runtime-api.js +1 -1
- package/dist/extensions/tlon/setup-api.js +2 -2
- package/dist/extensions/tlon/test-api.js +1 -1
- package/dist/extensions/together/index.js +1 -1
- package/dist/extensions/together/video-generation-provider.js +1 -1
- package/dist/extensions/twitch/api.js +1 -1
- package/dist/extensions/twitch/channel-plugin-api.js +1 -1
- package/dist/extensions/twitch/setup-plugin-api.js +1 -1
- package/dist/extensions/venice/api.js +3 -3
- package/dist/extensions/venice/index.js +4 -4
- package/dist/extensions/venice/models.js +1 -1
- package/dist/extensions/venice/onboard.js +2 -2
- package/dist/extensions/venice/provider-catalog.js +1 -1
- package/dist/extensions/voice-call/index.js +3 -3
- package/dist/extensions/voice-call/runtime-entry.js +1 -1
- package/dist/extensions/voice-call/setup-api.js +2 -2
- package/dist/extensions/vydra/image-generation-provider.js +1 -1
- package/dist/extensions/vydra/index.js +3 -3
- package/dist/extensions/vydra/shared.js +1 -1
- package/dist/extensions/vydra/speech-provider.js +1 -1
- package/dist/extensions/vydra/video-generation-provider.js +1 -1
- package/dist/extensions/xai/api.js +6 -6
- package/dist/extensions/xai/code-execution.js +2 -2
- package/dist/extensions/xai/image-generation-provider.js +1 -1
- package/dist/extensions/xai/index.js +11 -11
- package/dist/extensions/xai/model-definitions.js +1 -1
- package/dist/extensions/xai/onboard.js +1 -1
- package/dist/extensions/xai/provider-catalog.js +1 -1
- package/dist/extensions/xai/provider-models.js +1 -1
- package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
- package/dist/extensions/xai/setup-api.js +1 -1
- package/dist/extensions/xai/speech-provider.js +1 -1
- package/dist/extensions/xai/stt.js +1 -1
- package/dist/extensions/xai/test-api.js +1 -1
- package/dist/extensions/xai/tts.js +2 -2
- package/dist/extensions/xai/video-generation-provider.js +1 -1
- package/dist/extensions/xai/web-search.js +1 -1
- package/dist/extensions/xai/x-search.js +3 -3
- package/dist/extensions/zai/api.js +1 -1
- package/dist/extensions/zai/index.js +2 -2
- package/dist/extensions/zai/onboard.js +1 -1
- package/dist/extensions/zalo/api.js +3 -3
- package/dist/extensions/zalo/channel-plugin-api.js +1 -1
- package/dist/extensions/zalo/runtime-api.js +2 -2
- package/dist/extensions/zalo/setup-api.js +2 -2
- package/dist/extensions/zalouser/api.js +4 -4
- package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
- package/dist/extensions/zalouser/runtime-api.js +9 -9
- package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
- package/dist/extensions/zalouser/test-api.js +4 -4
- package/dist/fallbacks-B-hX8uqx.js +2 -0
- package/dist/fallbacks-C5ybxGTK.js +31 -0
- package/dist/fallbacks-shared-CH3k_pWW.js +111 -0
- package/dist/format-DUJSy56G.js +176 -0
- package/dist/gateway-BIOe8buh.js +115 -0
- package/dist/gateway-cli-DwcS5o3b.js +1283 -0
- package/dist/gateway-rpc-DE9eTnTH.js +14 -0
- package/dist/gateway-rpc.runtime-BYzSLXq5.js +23 -0
- package/dist/gateway-rpc.runtime.js +1 -1
- package/dist/gateway-runtime-DNBHtXEc.js +15 -0
- package/dist/gateway-status-DQ3SCRP6.js +584 -0
- package/dist/genesis-tools-B4E1Wx5r.js +9166 -0
- package/dist/genesis-tools.runtime-CvLAzIWm.js +2 -0
- package/dist/genesis-tools.runtime.js +1 -1
- package/dist/get-reply-D9iaq0Co.js +3897 -0
- package/dist/get-reply-from-config.runtime-BFrLyjaS.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/graph-users-K6q63hQH.js +1337 -0
- package/dist/guarded-json-api-BSwHtzk5.js +594 -0
- package/dist/health-BLmYYjhC.js +3 -0
- package/dist/health-jQBhWAEn.js +469 -0
- package/dist/health-route-ByzzS8xk.js +2 -0
- package/dist/health-route-CE-2wbny.js +41 -0
- package/dist/heartbeat-runner-D4-13meQ.js +5 -0
- package/dist/heartbeat-runner-DIprw7jS.js +1292 -0
- package/dist/heartbeat-runner.runtime-B_nY5Qgm.js +4 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/helpers-DEG_RuMc.js +320 -0
- package/dist/hooks-cli-DQay0wq5.js +433 -0
- package/dist/http-endpoint-helpers-Cj3QINzs.js +41 -0
- package/dist/http-headers-CxAw5CS4.js +11 -0
- package/dist/http-utils-BdoY-Nqt.js +924 -0
- package/dist/identity-DImc-ABG.js +140 -0
- package/dist/image-fallbacks-BPxIecDg.js +31 -0
- package/dist/image-fallbacks-C9f2oqy9.js +2 -0
- package/dist/image-generation-provider-D1MVlkMK.js +529 -0
- package/dist/image-generation-provider-D1xp4B37.js +228 -0
- package/dist/image-generation-provider-D78SYbpg.js +274 -0
- package/dist/image-generation-provider-KrI_cq7u.js +95 -0
- package/dist/image-generation-provider-eiDfurMp.js +157 -0
- package/dist/image-generation-provider-iM6hlpJY.js +63 -0
- package/dist/inbound-reply-dispatch-Cj041nYj.js +73 -0
- package/dist/inbound.runtime-BFDKTetv.js +3 -0
- package/dist/inbound.runtime-C9MPsVfj.js +4 -0
- package/dist/inbound.runtime.js +1 -1
- package/dist/index.js +2 -2
- package/dist/infra-runtime-D9uudHda.js +39 -0
- package/dist/init-BIbgrtP4.js +59 -0
- package/dist/install-signal-cli-DX67z7U-.js +202 -0
- package/dist/jobs-DWEXUnGc.js +734 -0
- package/dist/kimi-web-search-provider-B199pS24.js +80 -0
- package/dist/kimi-web-search-provider.runtime-DHuvlTlx.js +261 -0
- package/dist/kimi-web-search-provider.runtime-DPkmvLDS.js +2 -0
- package/dist/kimi-web-search-provider.runtime.js +1 -1
- package/dist/library-B5XEbilF.js +45 -0
- package/dist/lifecycle-Cf5XvG8O.js +229 -0
- package/dist/lifecycle-CnQRwenx.js +571 -0
- package/dist/lifecycle.runtime-CMl4KKk8.js +2 -0
- package/dist/lifecycle.runtime.js +1 -1
- package/dist/list-AHy8re_f.js +1212 -0
- package/dist/list-BTKCVZuV.js +2 -0
- package/dist/list-DGTx2Wqw.js +131 -0
- package/dist/list-YvfcGz15.js +2 -0
- package/dist/list.probe-DG5_xRHp.js +419 -0
- package/dist/live-model-switch-CuTctEKz.js +336 -0
- package/dist/llm-slug-generator-BruS9kif.js +79 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/load-config-CM6Gosov.js +35 -0
- package/dist/local-dispatch.runtime-ZYo4KwzE.js +8 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/login-3MD7cKlo.js +108 -0
- package/dist/logs-cli-OVNQM7ua.js +265 -0
- package/dist/logs-cli.runtime-BxiLcJ_M.js +2 -0
- package/dist/logs-cli.runtime.js +1 -1
- package/dist/main-session-restart-recovery-DPOV5jrb.js +206 -0
- package/dist/managed-image-attachments-6nAXGlI1.js +635 -0
- package/dist/managed-image-attachments-DilVoOYk.js +2 -0
- package/dist/manager-BtvzSKtj.js +2057 -0
- package/dist/manager-DyNLzWfD.js +2 -0
- package/dist/manager-Q2pBimx1.js +3114 -0
- package/dist/markdown-to-line-BXIakLn2.js +790 -0
- package/dist/mcp/plugin-tools-serve.js +1 -1
- package/dist/mcp-cli-lQKoKrr8.js +725 -0
- package/dist/mcp-http-Bkk3yw83.js +529 -0
- package/dist/media-contract-Bc8hq_Hg.js +49 -0
- package/dist/media-contract-api-U4NbSFNP.js +2 -0
- package/dist/media-runtime-BNkgBOI3.js +329 -0
- package/dist/memory-DwnILZlh.js +342 -0
- package/dist/memory-core-host-runtime-cli-C8dM34aV.js +9 -0
- package/dist/memory-embedding-adapter-B2PHR9-b.js +123 -0
- package/dist/message-action-runner-BKUGlEq0.js +2 -0
- package/dist/message-action-runner-CXfdJWof.js +1407 -0
- package/dist/message-actions-BPS9joyx.js +143 -0
- package/dist/message-channel-DGBKBihv.js +56 -0
- package/dist/message-gek1bdc3.js +232 -0
- package/dist/message-secret-scope-BmZJslJs.js +103 -0
- package/dist/message.gateway.runtime-B35cFF_N.js +2 -0
- package/dist/message.gateway.runtime.js +1 -1
- package/dist/method-scopes-BJj0ofY0.js +233 -0
- package/dist/minimax-web-search-provider-C79WAduN.js +53 -0
- package/dist/minimax-web-search-provider.runtime-D94jFB6v.js +2 -0
- package/dist/minimax-web-search-provider.runtime-ttvn1re5.js +140 -0
- package/dist/minimax-web-search-provider.runtime.js +1 -1
- package/dist/mock-C9dpEyJ8.js +136 -0
- package/dist/model-definitions-taVnM0qU.js +260 -0
- package/dist/model-overrides-Hnlrxnm3.js +104 -0
- package/dist/model-selection-C0kCM--d.js +213 -0
- package/dist/models-C6lJZiG_.js +569 -0
- package/dist/models-CQmyBH-d.js +760 -0
- package/dist/models-CzCQpmVW.js +157 -0
- package/dist/models-DJQoC4Xz.js +47 -0
- package/dist/models-auth-status-CUuto1-z.js +217 -0
- package/dist/models-cli-DFYsfHFi.js +271 -0
- package/dist/models-http-KluTqvju.js +92 -0
- package/dist/models.fetch-CUcQFhk9.js +518 -0
- package/dist/monitor-Amuhcll1.js +1237 -0
- package/dist/monitor-BHYjSOgh.js +671 -0
- package/dist/monitor-BNMwiGBd.js +1459 -0
- package/dist/monitor-C8QQd5Eg.js +295 -0
- package/dist/monitor-DHQTgUJC.js +1661 -0
- package/dist/monitor-DrTPiOoO.js +2 -0
- package/dist/monitor-Dupjc8yV.js +788 -0
- package/dist/monitor-auth-BGCRXS08.js +207 -0
- package/dist/monitor-processing-dLJEKLkr.js +1974 -0
- package/dist/monitor.runtime-CFCau0j2.js +2 -0
- package/dist/monitor.runtime.js +1 -1
- package/dist/monitor.webhook-rWET0HrG.js +180 -0
- package/dist/msteams-96MqCc3R.js +35 -0
- package/dist/music-generation-provider-Bilj-8Yj.js +63 -0
- package/dist/music-generation-provider-CHWj4bCX.js +170 -0
- package/dist/native-hook-relay-BFWKVZgm.js +519 -0
- package/dist/native-web-search-BVgO5cS-.js +64 -0
- package/dist/nextcloud-talk-D-FHP_4q.js +17 -0
- package/dist/node-cli-COaDl9Gb.js +2276 -0
- package/dist/nodes-cli-CdiC2uij.js +1046 -0
- package/dist/nodes-utils-Bz4wEuS8.js +84 -0
- package/dist/nodes.helpers-B4Yy3f8X.js +34 -0
- package/dist/notify-DnBLOswJ.js +315 -0
- package/dist/onboard-3Bl_PtFG.js +25 -0
- package/dist/onboard-CKxpPa1J.js +25 -0
- package/dist/onboard-CnHnAYQA.js +2 -0
- package/dist/onboard-DgcU4LaA.js +58 -0
- package/dist/onboard-Dgq86QR9.js +29 -0
- package/dist/onboard-NAMvzIMs2.js +49 -0
- package/dist/onboard-a4m7JstV.js +316 -0
- package/dist/onboard-fjFU-IEN.js +70 -0
- package/dist/onboard-helpers-CFVEw4kg.js +204 -0
- package/dist/onboard-helpers-R0vTUoOE.js +6 -0
- package/dist/onboard-interactive-D4Hr2vB6.js +24 -0
- package/dist/onboard-non-interactive-DjfjLqF7.js +635 -0
- package/dist/onboard-ppjrxdQn.js +25 -0
- package/dist/onboard-remote-0UXttO3s.js +2 -0
- package/dist/onboard-remote-BmUiJKba.js +193 -0
- package/dist/onboard-skills-855xT260.js +2 -0
- package/dist/onboard-skills-CF2ndciI.js +134 -0
- package/dist/openai-codex-auth-identity-Dxbuu2cd.js +45 -0
- package/dist/openai-codex-device-code-CEOVyUYq.js +164 -0
- package/dist/openai-codex-provider-B0mTbWAC.js +472 -0
- package/dist/openai-codex-shared-DO75K1fy.js +6 -0
- package/dist/openai-http-BU5AQc8x.js +500 -0
- package/dist/openai-provider-DUFOP6VM.js +313 -0
- package/dist/openresponses-http-D1GGTOop.js +1128 -0
- package/dist/operator-approvals-client-gp0A73Qi.js +68 -0
- package/dist/outbound-media-CYrmm6RY.js +57 -0
- package/dist/outbound-runtime-DM3TzNhA.js +5 -0
- package/dist/outbound.runtime-DHLRWzbo.js +2 -0
- package/dist/outbound.runtime.js +1 -1
- package/dist/pair-command-approve-LJICPdqB.js +44 -0
- package/dist/perplexity-web-search-provider-ONjsnI0T.js +92 -0
- package/dist/perplexity-web-search-provider.runtime-C9SpRyYz.js +324 -0
- package/dist/perplexity-web-search-provider.runtime-pVuMPAol.js +2 -0
- package/dist/perplexity-web-search-provider.runtime.js +1 -1
- package/dist/persistent-bindings.lifecycle-CEOa_phk.js +85 -0
- package/dist/persistent-bindings.lifecycle-DACYiSaR.js +2 -0
- package/dist/pi-embedded-BlOiwW3D.js +4 -0
- package/dist/pi-embedded-mC-TYW4O.js +2905 -0
- package/dist/pi-embedded-subscribe.handlers.compaction.runtime-CzPjo_JC.js +23 -0
- package/dist/pi-embedded-subscribe.handlers.compaction.runtime.js +1 -1
- package/dist/pi-embedded.runtime-DjmvqZCN.js +4 -0
- package/dist/pi-embedded.runtime.js +1 -1
- package/dist/pi-tool-definition-adapter-CwT_smG_.js +229 -0
- package/dist/pi-tools-10IsGyci.js +1057 -0
- package/dist/pi-tools.before-tool-call-CX2Ew8CP.js +433 -0
- package/dist/pi-tools.before-tool-call-V6qF1pL1.js +2 -0
- package/dist/plivo-CAlO-SXr.js +394 -0
- package/dist/plugin-DUiUdK8L.js +12195 -0
- package/dist/plugin-enabled-Md173mY1.js +140 -0
- package/dist/plugin-registration-BUZ1GI8e.js +23 -0
- package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
- package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
- package/dist/plugin-sdk/acp-runtime.js +3 -3
- package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
- package/dist/plugin-sdk/agent-harness.js +7 -7
- package/dist/plugin-sdk/agent-runtime.js +2 -2
- package/dist/plugin-sdk/approval-client-runtime.js +2 -2
- package/dist/plugin-sdk/approval-delivery-runtime.js +1 -1
- package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
- package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
- package/dist/plugin-sdk/approval-native-runtime.js +2 -2
- package/dist/plugin-sdk/approval-reply-runtime.js +2 -2
- package/dist/plugin-sdk/approval-runtime.js +7 -7
- package/dist/plugin-sdk/bluebubbles.js +2 -2
- package/dist/plugin-sdk/browser-node-runtime.js +4 -4
- package/dist/plugin-sdk/browser-setup-tools.js +3 -3
- package/dist/plugin-sdk/browser-support.js +7 -7
- package/dist/plugin-sdk/channel-core.js +2 -2
- package/dist/plugin-sdk/channel-inbound.js +3 -3
- package/dist/plugin-sdk/command-auth-native.js +1 -1
- package/dist/plugin-sdk/command-auth.js +4 -4
- package/dist/plugin-sdk/command-status-runtime.js +1 -1
- package/dist/plugin-sdk/compat.js +2 -2
- package/dist/plugin-sdk/config-runtime.js +5 -5
- package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
- package/dist/plugin-sdk/conversation-runtime.js +4 -4
- package/dist/plugin-sdk/core.js +2 -2
- package/dist/plugin-sdk/direct-dm.js +1 -1
- package/dist/plugin-sdk/gateway-runtime.js +3 -3
- package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/infra-runtime.js +4 -4
- package/dist/plugin-sdk/irc.js +2 -2
- package/dist/plugin-sdk/markdown-table-runtime.js +1 -1
- package/dist/plugin-sdk/matrix.js +1 -1
- package/dist/plugin-sdk/mattermost.js +3 -3
- package/dist/plugin-sdk/media-runtime.js +1 -1
- package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
- package/dist/plugin-sdk/memory-core.js +2 -2
- package/dist/plugin-sdk/models-provider-runtime.js +1 -1
- package/dist/plugin-sdk/msteams.js +3 -3
- package/dist/plugin-sdk/nextcloud-talk.js +2 -2
- package/dist/plugin-sdk/nostr.js +1 -1
- package/dist/plugin-sdk/outbound-runtime.js +2 -2
- package/dist/plugin-sdk/reply-chunking.js +2 -2
- package/dist/plugin-sdk/reply-dispatch-runtime.js +2 -2
- package/dist/plugin-sdk/reply-runtime.js +5 -5
- package/dist/plugin-sdk/routing.js +2 -2
- package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
- package/dist/plugin-sdk/runtime.js +2 -2
- package/dist/plugin-sdk/sandbox.js +1 -1
- package/dist/plugin-sdk/session-store-runtime.js +1 -1
- package/dist/plugin-sdk/session-visibility.js +1 -1
- package/dist/plugin-sdk/skill-commands-runtime.js +1 -1
- package/dist/plugin-sdk/src/gateway/protocol/client-info.d.ts +8 -0
- package/dist/plugin-sdk/src/gateway/protocol/schema/logs-chat.d.ts +2 -0
- package/dist/plugin-sdk/src/gateway/protocol/schema/protocol-schemas.d.ts +2 -0
- package/dist/plugin-sdk/src/gateway/server-broadcast-types.d.ts +11 -0
- package/dist/plugin-sdk/testing.js +4 -4
- package/dist/plugin-sdk/text-runtime.js +2 -2
- package/dist/plugin-sdk/tlon.js +1 -1
- package/dist/plugin-sdk/zalo.js +1 -1
- package/dist/plugin-sdk/zalouser.js +1 -1
- package/dist/plugin-service-ClKtlbqz.js +2893 -0
- package/dist/plugins/runtime/index.js +1 -1
- package/dist/policy-BxXVdy5R.js +328 -0
- package/dist/postinstall-inventory.json +732 -732
- package/dist/prepare.runtime-CgeJiFh8.js +815 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/probe--ur8kCb3.js +241 -0
- package/dist/probe-Afcq8e2r.js +2 -0
- package/dist/probe-Bh8UIug9.js +32 -0
- package/dist/probe-CY6MUE10.js +1443 -0
- package/dist/probe-Cfbju7hl.js +243 -0
- package/dist/probe-DHojHKeB.js +2 -0
- package/dist/probe-DZZtfovp.js +2205 -0
- package/dist/probe-KiWC2F6a.js +45 -0
- package/dist/probe-QqjmFXeC.js +74 -0
- package/dist/probe.runtime-BYxgJ6xl.js +2 -0
- package/dist/probe.runtime.js +1 -1
- package/dist/program-BjA_aj2i.js +111 -0
- package/dist/prompt-select-styled-D_Li5ANb.js +20 -0
- package/dist/protocol-D2Tvt0kQ.js +2479 -0
- package/dist/provider-MaVAUyxk.js +70 -0
- package/dist/provider-catalog-BATfNRJI.js +11 -0
- package/dist/provider-catalog-BqmZljQJ.js +11 -0
- package/dist/provider-catalog-DIiNG8du.js +12 -0
- package/dist/provider-catalog-aWreWBr_.js +24 -0
- package/dist/provider-catalog-k2xN6Dmi.js +26 -0
- package/dist/provider-compat-DEtCjlVO.js +37 -0
- package/dist/provider-dispatcher-BOzs2ZGG.js +2 -0
- package/dist/provider-dispatcher-CLzXvOtY.js +22 -0
- package/dist/provider-models-Dr7Yl3OU.js +119 -0
- package/dist/provider-models-LgIFG7w_.js +35 -0
- package/dist/provider-registration-Ce1hYnYT.js +218 -0
- package/dist/pw-ai-qc3NEEdy.js +2511 -0
- package/dist/pw-role-snapshot-BDIJ0VPo.js +380 -0
- package/dist/qmd-manager-B2ly9K3H.js +1921 -0
- package/dist/qr-cli-D2qc34ak.js +349 -0
- package/dist/qr-cli-r8cz7XBw.js +2 -0
- package/dist/qr-image-DNn2cBT5.js +2 -0
- package/dist/queue-BbE1ctBI.js +409 -0
- package/dist/reaction-runtime-api-DNwfR7k6.js +116 -0
- package/dist/reactions-B8Os6MyX.js +998 -0
- package/dist/read-capability-BcetMuEi.js +412 -0
- package/dist/realtime-provider-shared-RvhVjejL.js +37 -0
- package/dist/realtime-transcription-provider-BbBn8N0w.js +184 -0
- package/dist/realtime-transcription-provider-C08pMeeY.js +183 -0
- package/dist/realtime-transcription-provider-CB0qNn9C.js +184 -0
- package/dist/realtime-transcription-provider-DYOqgmgZ.js +120 -0
- package/dist/realtime-transcription-provider-ySxyV6W0.js +172 -0
- package/dist/realtime-voice-provider-ByH_v5-M.js +489 -0
- package/dist/record-shared-DVnkFx9W.js +10 -0
- package/dist/register-service-commands-BXfMmQsa.js +71 -0
- package/dist/register.agent-CUXMbAb4.js +248 -0
- package/dist/register.configure-B29Tv6Ec.js +15 -0
- package/dist/register.maintenance-ePgwbzKN.js +363 -0
- package/dist/register.message-BmgFYhw_.js +329 -0
- package/dist/register.onboard-BL8ZSfVl.js +88 -0
- package/dist/register.runtime-Z_9jSH_w.js +81 -0
- package/dist/register.runtime.js +1 -1
- package/dist/register.setup-BAQ-rre0.js +150 -0
- package/dist/register.status-health-sessions-D5CTwglK.js +1215 -0
- package/dist/register.subclis-BAzWCN2M.js +3 -0
- package/dist/register.subclis-CMhZ_wr2.js +29 -0
- package/dist/register.subclis-core-D_uA6Vtg.js +249 -0
- package/dist/replay-policy-Be3VAzMj.js +8 -0
- package/dist/reply-chunking-DsNT8-zW.js +3 -0
- package/dist/reply-dispatch-runtime-C8Tjbie9.js +13 -0
- package/dist/reply-media-paths.runtime-Sf21IJNk.js +146 -0
- package/dist/reply-media-paths.runtime-oSGMjdni.js +2 -0
- package/dist/reply-media-paths.runtime.js +1 -1
- package/dist/reply-payload-transform-DxOTphts.js +720 -0
- package/dist/reply-runtime-9GCZm66h.js +11 -0
- package/dist/reply.runtime-Ck_EqPGO.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/reset-BMP05zhP.js +84 -0
- package/dist/reset-authorization-AdwO29Il.js +34 -0
- package/dist/response-generator-BKL4tpDF.js +175 -0
- package/dist/restart-health-C8OVhvQ6.js +2 -0
- package/dist/restart-health-DdG71XEk.js +202 -0
- package/dist/root-help-_8BuPuC8.js +44 -0
- package/dist/route-reply-C4YpHgPi.js +162 -0
- package/dist/route-reply.runtime-hioDUgsc.js +2 -0
- package/dist/route-reply.runtime.js +1 -1
- package/dist/routes-BbR9Kf9O.js +3341 -0
- package/dist/routes-DSDrrbg7.js +2 -0
- package/dist/routing-CMekdi78.js +5 -0
- package/dist/rpc-B32bpIT7.js +61 -0
- package/dist/rpc-context-88y3DNdl.js +17 -0
- package/dist/rpc.runtime-BWtvlfeD.js +21 -0
- package/dist/rpc.runtime.js +1 -1
- package/dist/run-auth-profile.runtime-x8Hbrp4n.js +2 -0
- package/dist/run-auth-profile.runtime.js +1 -1
- package/dist/run-delivery.runtime-BEhoJYec.js +530 -0
- package/dist/run-delivery.runtime.js +1 -1
- package/dist/run-embedded.runtime-DtE5YonB.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-B7TsaFkb.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime-C6GU_OdI.js +277 -0
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-main-DlCyw-yJ.js +567 -0
- package/dist/run-subagent-registry.runtime-N6lG2N8U.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/run-wait-CT1ADSXM.js +135 -0
- package/dist/runtime-BMgYgoRw.js +973 -0
- package/dist/runtime-BZIHCyP6.js +9 -0
- package/dist/runtime-BfclzCOK.js +72 -0
- package/dist/runtime-C5HCPXpN.js +107 -0
- package/dist/runtime-api-BwnU0Us4.js +14 -0
- package/dist/runtime-api-CTCWdq7l.js +4 -0
- package/dist/runtime-api-DEKfCisk.js +9 -0
- package/dist/runtime-api-DuV0VsXW.js +9 -0
- package/dist/runtime-embedded-pi.runtime-BYOaO_Od.js +2 -0
- package/dist/runtime-embedded-pi.runtime.js +1 -1
- package/dist/runtime-entry-BIQCiau_.js +2769 -0
- package/dist/runtime-internal-CatNPRWm.js +2 -0
- package/dist/runtime-options-VPF2fIbl.js +275 -0
- package/dist/runtime-provider-CKxDlld3.js +21 -0
- package/dist/runtime-schema-C5kNPI-T.js +28588 -0
- package/dist/sandbox-24Qv41cI.js +3 -0
- package/dist/sandbox-Dl4VHMsp.js +1156 -0
- package/dist/sandbox-cli-DKdlzfGK.js +450 -0
- package/dist/scan-CsLHQzrX.js +2 -0
- package/dist/scan-Db3o5_vf.js +523 -0
- package/dist/secrets-cli-DRs2TyS0.js +2101 -0
- package/dist/security-cli-Ddj_11Zr.js +486 -0
- package/dist/selection-BTcDg98i.js +2 -0
- package/dist/selection-CDq8O7Fx.js +7764 -0
- package/dist/send-C3Q0rOZU.js +102 -0
- package/dist/send-CMRoV9D3.js +534 -0
- package/dist/send-DLyeTfOT.js +156 -0
- package/dist/send.runtime-11PTjSXY.js +2 -0
- package/dist/send.runtime.js +1 -1
- package/dist/server-DpmjtgBd.js +77 -0
- package/dist/server-context-BuRVihwJ.js +2 -0
- package/dist/server-context-Dxt5bPO1.js +847 -0
- package/dist/server-iR310jYD.js +13 -0
- package/dist/server-middleware-XZQHvHoT.js +120 -0
- package/dist/server-node-events-EECL-zPp.js +481 -0
- package/dist/server-plugin-bootstrap-BeyQQP6e.js +13176 -0
- package/dist/server-plugin-bootstrap-Du2JCynD.js +2 -0
- package/dist/server-restart-sentinel-D16NkJS9.js +697 -0
- package/dist/server.impl-jeGX0yfZ.js +12894 -0
- package/dist/session-DQJLw1_T.js +48 -0
- package/dist/session-envelope-BzLkljLE.js +18 -0
- package/dist/session-key-B9ng1tKQ.js +65 -0
- package/dist/session-kill-http-CrVogPTY.js +110 -0
- package/dist/session-meta-Cf_igX65.js +109 -0
- package/dist/session-override-tYPL0kPi.js +106 -0
- package/dist/session-reset-model.runtime-Bksk4sN9.js +133 -0
- package/dist/session-reset-model.runtime.js +1 -1
- package/dist/session-reset-service-Coa2y7Dc.js +497 -0
- package/dist/session-route-C__jEVZM.js +93 -0
- package/dist/session-status.runtime-DGvtIYsy.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-store-C7BvEOyw.js +126 -0
- package/dist/session-store.runtime-CTnaK0eA.js +2 -0
- package/dist/session-store.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-CpvLz2Zl.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-9PAkEJgt.js +581 -0
- package/dist/session-updates-DFsCLKMJ.js +236 -0
- package/dist/session-updates.runtime-GJ8kEPly.js +2 -0
- package/dist/session-updates.runtime.js +1 -1
- package/dist/session-utils-B1COXii1.js +1009 -0
- package/dist/session-visibility-D3BOamfE.js +147 -0
- package/dist/sessions-BNIruiEi.js +48 -0
- package/dist/sessions-B_sLzSKh.js +281 -0
- package/dist/sessions-ChHWG6bX.js +16 -0
- package/dist/sessions-helpers-BhxVyCeC.js +305 -0
- package/dist/sessions-history-http-Cat6NIOM.js +383 -0
- package/dist/sessions-patch-C2VfpT6N.js +309 -0
- package/dist/sessions-resolve-CU-TrVC5.js +174 -0
- package/dist/sessions-u8wkO5OX.js +2 -0
- package/dist/sessions.runtime-B6j-Iope.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/setup-BUlom6Vi.js +421 -0
- package/dist/setup-CcVU94hA.js +636 -0
- package/dist/setup-api-B7VRJ8uG.js +29 -0
- package/dist/setup-core-BSgdsKqw.js +393 -0
- package/dist/setup-core-BlfMhY40.js +184 -0
- package/dist/setup-core-ClqXCwnQ.js +176 -0
- package/dist/setup-core-DnkRgrw-.js +171 -0
- package/dist/setup-surface-5pyyPLuU.js +351 -0
- package/dist/setup-surface-6kf03Wwh.js +72 -0
- package/dist/setup-surface-C-CfXHbT.js +286 -0
- package/dist/setup-surface-C2ZP0qfU.js +3 -0
- package/dist/setup-surface-DKyYG10Q2.js +403 -0
- package/dist/setup-surface-DbpW4B-_.js +219 -0
- package/dist/setup.finalize-skT8Gm-r.js +547 -0
- package/dist/setup.gateway-config-CeiELioQ.js +250 -0
- package/dist/shared--LL8Q1-r.js +60 -0
- package/dist/shared-B48XWnaj.js +121 -0
- package/dist/shared-CTrgq8xV.js +217 -0
- package/dist/shared-D7wq6pQ0.js +186 -0
- package/dist/shared-DSeBkiR2.js +198 -0
- package/dist/shared-DWDavHPp.js +76 -0
- package/dist/shared-runtime-D-p9L46W.js +7 -0
- package/dist/short-term-promotion-CkPsM3JU.js +1543 -0
- package/dist/skill-commands-GmJ-uKh9.js +83 -0
- package/dist/skill-commands.runtime-B2kGq_R_.js +2 -0
- package/dist/skill-commands.runtime.js +1 -1
- package/dist/skills-snapshot.runtime-niF0JCHr.js +7 -0
- package/dist/skills-snapshot.runtime.js +1 -1
- package/dist/slash-state-D0qRQzb9.js +1911 -0
- package/dist/speech-provider-CZ0DIWHC.js +209 -0
- package/dist/speech-provider-D01WzRM7.js +216 -0
- package/dist/speech-provider-D4dWoX5q.js +395 -0
- package/dist/speech-provider-DQjPn8BG.js +170 -0
- package/dist/speech-provider-DTfG7isC.js +184 -0
- package/dist/speech-provider-DVMPFaU6.js +103 -0
- package/dist/speech-provider-Jnc9vcw3.js +209 -0
- package/dist/src-DLW1D_bM.js +3974 -0
- package/dist/stage-sandbox-media.runtime-DeLGFWqT.js +232 -0
- package/dist/stage-sandbox-media.runtime.js +1 -1
- package/dist/startup-context-DKWBYxjm.js +312 -0
- package/dist/state-migrations-DdRavjjK.js +820 -0
- package/dist/status-BGTYuDnT.js +397 -0
- package/dist/status-BYp9Gu83.js +209 -0
- package/dist/status-BqydDBcZ.js +3 -0
- package/dist/status-Bx1yRRTV.js +190 -0
- package/dist/status-C6gdYeLs.js +2 -0
- package/dist/status-Cl8Otyr4.js +62 -0
- package/dist/status-DWucT0mf.js +2 -0
- package/dist/status-all-TjyzzieW.js +498 -0
- package/dist/status-json-C6WIXSpl.js +14 -0
- package/dist/status-json-command-CgXgvQow.js +84 -0
- package/dist/status-message-D6O4-pti.js +466 -0
- package/dist/status-message.runtime-CNShQeZy.js +6 -0
- package/dist/status-message.runtime.js +1 -1
- package/dist/status-queue.runtime-K8_F9zMn.js +2 -0
- package/dist/status-queue.runtime.js +1 -1
- package/dist/status-runtime-shared-Be7bmVcF.js +257 -0
- package/dist/status-subagents.runtime-BRV0GKxR.js +18 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-BIGdXi_0.js +237 -0
- package/dist/status.gateway-connection.runtime-C1Eg5lPs.js +2 -0
- package/dist/status.gateway-connection.runtime.js +1 -1
- package/dist/status.gather-C91OSvDe.js +292 -0
- package/dist/status.gather-DOJX68XV.js +2 -0
- package/dist/status.runtime-BM4ZMHfF.js +2 -0
- package/dist/status.runtime-JhkaEpRc.js +2 -0
- package/dist/status.runtime.js +1 -1
- package/dist/status.scan-36oLz1Hh.js +65 -0
- package/dist/status.scan-overview-CsDwq0xR.js +379 -0
- package/dist/status.scan.fast-json-CS8ga0yM.js +132 -0
- package/dist/status.scan.fast-json-DYvUCNqQ.js +2 -0
- package/dist/status.summary-1hoR3rVk.js +214 -0
- package/dist/status.summary-Bl1Fw7SD.js +2 -0
- package/dist/store-3hbb4lSJ.js +4 -0
- package/dist/store-CEFH-fGo.js +910 -0
- package/dist/store.runtime-ugP7_1Zf.js +2 -0
- package/dist/store.runtime.js +1 -1
- package/dist/stream-CukCyjCc.js +664 -0
- package/dist/stream-Dj22sbqm.js +134 -0
- package/dist/stt-CRYwE4f3.js +66 -0
- package/dist/subagent-announce-Dnuw09in.js +351 -0
- package/dist/subagent-announce-delivery-cCFWE0et.js +726 -0
- package/dist/subagent-announce-output-BtmzvU1a.js +364 -0
- package/dist/subagent-capabilities-Btyd8tu0.js +251 -0
- package/dist/subagent-control-Dlc3kJMb.js +506 -0
- package/dist/subagent-control.runtime-g5fkwkOu.js +3 -0
- package/dist/subagent-control.runtime.js +1 -1
- package/dist/subagent-followup.runtime-CtU5LNEN.js +68 -0
- package/dist/subagent-followup.runtime.js +1 -1
- package/dist/subagent-orphan-recovery-kbEEIccA.js +305 -0
- package/dist/subagent-registry-B5bQOpDI.js +3 -0
- package/dist/subagent-registry-CBu4eX0s.js +1753 -0
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-spawn-DhjzC5gY.js +1005 -0
- package/dist/system-cli-A9ux7HV2.js +59 -0
- package/dist/system-prompt-DJq4MtoS.js +640 -0
- package/dist/tables-BStv8EET.js +829 -0
- package/dist/target-id-RoVbMf8U.js +107 -0
- package/dist/targets-RMCdeJGZ.js +207 -0
- package/dist/targets-cmfGv2Db.js +67 -0
- package/dist/targets.runtime-DurrSDqM.js +2 -0
- package/dist/targets.runtime.js +1 -1
- package/dist/task-executor-CtdGnYvb.js +360 -0
- package/dist/task-owner-access-C_gF3pGm.js +74 -0
- package/dist/task-registry-CFNty_H1.js +2366 -0
- package/dist/task-registry-delivery-runtime-C1c7pN3i.js +2 -0
- package/dist/task-registry-delivery-runtime-F6HIzLFD.js +3 -0
- package/dist/task-registry.maintenance-BSO3Pttk.js +2 -0
- package/dist/task-registry.maintenance-Bzw1Ot4Y.js +416 -0
- package/dist/tavily-client-DmRSbaLh.js +2 -0
- package/dist/tavily-client-DyAtAOpD.js +193 -0
- package/dist/tavily-search-provider-Bbgsl7mb.js +62 -0
- package/dist/telegram/audit.js +2 -2
- package/dist/telegram/token.js +2 -2
- package/dist/telnyx-nMo1MXA1.js +260 -0
- package/dist/testing-DLeFUMTf.js +575 -0
- package/dist/text-report-Dr4OMS_k.js +587 -0
- package/dist/text-runtime-Dd2bva2m.js +290 -0
- package/dist/tool-config-shared-DlMaBB10.js +19 -0
- package/dist/tool-policy-pipeline-0FWDoYYr.js +109 -0
- package/dist/tool-resolution-DQTRVob0.js +90 -0
- package/dist/tools-effective-inventory-GNGRMlm8.js +152 -0
- package/dist/tools-invoke-http-IeTKKDtc.js +206 -0
- package/dist/tools.runtime-DNLELnRr.js +4 -0
- package/dist/tools.runtime.js +1 -1
- package/dist/transcript-DWg4ZUcm.js +312 -0
- package/dist/transcript-resolve.runtime-xACsMpzb.js +2 -0
- package/dist/transcript-resolve.runtime.js +1 -1
- package/dist/transcript.runtime-BEXMCmRi.js +2 -0
- package/dist/transcript.runtime.js +1 -1
- package/dist/transport-policy-BzTvyOmg.js +75 -0
- package/dist/trash-EJIRdEEW.js +24 -0
- package/dist/tts-AMFKvIil.js +64 -0
- package/dist/tts-D7c_mBQr.js +183 -0
- package/dist/tui-cli-CeXEjZVR.js +4595 -0
- package/dist/twilio-Bq0EHjSs.js +609 -0
- package/dist/typing-policy-D-cwir-6.js +12 -0
- package/dist/update-cli-6cN0AU-H.js +1759 -0
- package/dist/upgrade-E9pk_ETn.js +1226 -0
- package/dist/video-generation-provider-B2ydEHoH.js +271 -0
- package/dist/video-generation-provider-BIhzvg3t.js +78 -0
- package/dist/video-generation-provider-BiGET6PL.js +187 -0
- package/dist/video-generation-provider-BvIYYRHt.js +254 -0
- package/dist/video-generation-provider-CDMIArvG.js +118 -0
- package/dist/video-generation-provider-CZc8AIXp.js +221 -0
- package/dist/video-generation-provider-DKQZcort.js +281 -0
- package/dist/video-generation-provider-DdGhJ9-8.js +287 -0
- package/dist/video-generation-provider-XpVuorb7.js +264 -0
- package/dist/video-generation-task-status-D44fagYk.js +163 -0
- package/dist/voice-mapping-Ltp5aeXQ.js +41 -0
- package/dist/wait-for-idle-before-flush-B5QDOp0b.js +5986 -0
- package/dist/web-search-gDoNQc1M.js +61 -0
- package/dist/web-search-provider-DI1P7u12.js +163 -0
- package/dist/web-search-provider.runtime-BLHcU_Q5.js +2 -0
- package/dist/web-search-provider.runtime-CExn2tm8.js +185 -0
- package/dist/web-search-provider.runtime.js +1 -1
- package/dist/webhook-shared-1XHBMLp6.js +12 -0
- package/dist/wizard-models-CLDwUX2-.js +334 -0
- package/dist/workflow-runtime-BrBSvDJz.js +485 -0
- package/dist/workspace-run-CQ9bvprq.js +70 -0
- package/dist/x-search-config-COc9ynlq.js +36 -0
- package/dist/x-search-shared-D-WVgH0q.js +75 -0
- package/dist/zalo-js-kA38HR6N.js +1157 -0
- package/package.json +1 -1
- package/dist/abort-D7Eb5Pfs.js +0 -201
- package/dist/abort-cutoff.runtime-W1jPHD1l.js +0 -20
- package/dist/abort.runtime-Uk-fNOr0.js +0 -2
- package/dist/accounts-B0U5s6Hn.js +0 -2
- package/dist/accounts-BuQEZI1m.js +0 -365
- package/dist/accounts-BxrhItqg.js +0 -107
- package/dist/accounts-CJuvMKsE.js +0 -66
- package/dist/accounts-DAo-x54e.js +0 -104
- package/dist/accounts-DoMkWpQd.js +0 -43
- package/dist/accounts.runtime-B4AMDwXM.js +0 -2
- package/dist/acp-cli-Dj3nYrtM.js +0 -2193
- package/dist/acp-spawn-DVm7VQrm.js +0 -1093
- package/dist/acp-spawn-DfcG2y_Y.js +0 -2
- package/dist/acp-stateful-target-driver-BYeTpciM.js +0 -89
- package/dist/action-agents-B9hNk5lN.js +0 -67
- package/dist/action-focus-B6pqXNJ2.js +0 -132
- package/dist/action-help-CPcU40vC.js +0 -7
- package/dist/action-info-D_yE--lC.js +0 -101
- package/dist/action-kill-BJ0225YA.js +0 -33
- package/dist/action-list-BLyN0cUw.js +0 -21
- package/dist/action-log-_sI8lmxG.js +0 -30
- package/dist/action-send-C2RZKCaN.js +0 -39
- package/dist/action-spawn-DtZrqOf-.js +0 -47
- package/dist/action-unfocus-D90uQGIM.js +0 -29
- package/dist/actions.runtime-CwqOsby1.js +0 -5
- package/dist/actions.runtime-DL7IkUaC.js +0 -18
- package/dist/agent-command-ChguXtvw.js +0 -874
- package/dist/agent-delivery-BwzZnRgC.js +0 -76
- package/dist/agent-eujROEra.js +0 -2
- package/dist/agent-harness-runtime-KWYqsYTk.js +0 -144
- package/dist/agent-runner-utils-DyLXFJim.js +0 -239
- package/dist/agent-runner.runtime-Tm2znb5I.js +0 -3455
- package/dist/agent-runtime-DYyI3OTz.js +0 -18
- package/dist/agents-CaKEB08m.js +0 -5
- package/dist/agents-D0LjQ71R.js +0 -954
- package/dist/agents.command-shared-DnntyPTT.js +0 -40
- package/dist/aliases-C1J5Hl0k.js +0 -96
- package/dist/aliases-DE2DzUaH.js +0 -2
- package/dist/api-9ms9Td4v.js +0 -3
- package/dist/api-BgtDxBwP.js +0 -5
- package/dist/api-BpBoWeil.js +0 -3
- package/dist/api-CKbGCnWb.js +0 -139
- package/dist/api-D1axzMqP.js +0 -4
- package/dist/api-j3Hir2UT.js +0 -48
- package/dist/apply-CIz-od94.js +0 -508
- package/dist/apply.runtime-CN-vA6G-.js +0 -2
- package/dist/approval-client-helpers-Dp5QM59V.js +0 -82
- package/dist/approval-delivery-helpers-BS-VOhZN.js +0 -134
- package/dist/approval-gateway-resolver-DIPFgTnx.js +0 -29
- package/dist/approval-gateway-runtime-i0yziXk2.js +0 -2
- package/dist/approval-handler-runtime-7ttgBfc_.js +0 -439
- package/dist/approval-native-helpers-DbgPq2Af.js +0 -33
- package/dist/approval-native-runtime-DT2b3zaN.js +0 -729
- package/dist/approval-renderers-CxKF90_M.js +0 -64
- package/dist/attempt-execution.runtime-CzM8MDim.js +0 -509
- package/dist/attempt-execution.shared-BeCuaCMe.js +0 -22
- package/dist/attempt.prompt-helpers-DfcGwj0J.js +0 -221
- package/dist/attempt.tool-run-context-4cCwC6FC.js +0 -933
- package/dist/audit-EYwFJUbn.js +0 -939
- package/dist/audit-membership-runtime-AIbmS8yN.js +0 -550
- package/dist/audit.runtime-OucPhZPU.js +0 -7
- package/dist/auth-BPy3ID3D.js +0 -2
- package/dist/auth-CYd5Phr-.js +0 -56
- package/dist/auth-D0kGHo1j.js +0 -177
- package/dist/auth-DTPcbxn6.js +0 -550
- package/dist/auth-order-8O0b16i_.js +0 -139
- package/dist/auth-order-CW2AQyNL.js +0 -2
- package/dist/base-url-h8Mhif7l.js +0 -15
- package/dist/bash-tools-8bn5C7K0.js +0 -2824
- package/dist/bash-tools-DZpkBFMY.js +0 -3
- package/dist/bash-tools.exec-runtime-DQVwPD43.js +0 -829
- package/dist/best-effort-delivery-B6BoLJdq.js +0 -22
- package/dist/binding-routing-BMMSo2KY.js +0 -85
- package/dist/binding-targets-Wm55iFsz.js +0 -121
- package/dist/block-streaming-CcRmZONP.js +0 -103
- package/dist/bluebubbles-Cm2jWoAr.js +0 -77
- package/dist/brave-web-search-provider-DXyLEuRX.js +0 -111
- package/dist/brave-web-search-provider.runtime-CH2Ro8gV.js +0 -229
- package/dist/brave-web-search-provider.shared-2wgQI-qy.js +0 -174
- package/dist/bridge-auth-registry-1QsmDpYF.js +0 -23
- package/dist/bridge-server-D3Mo-BM6.js +0 -113
- package/dist/browser-control-auth-BiuDMNP7.js +0 -2
- package/dist/browser-node-runtime-CrigB5UH.js +0 -12
- package/dist/browser-profiles-BJjsWlQ8.js +0 -2
- package/dist/browser-runtime-Dc5sMewB.js +0 -387
- package/dist/browser-setup-tools-CM1H6l0K.js +0 -13
- package/dist/build-8Hzi5z0_.js +0 -550
- package/dist/call-B3rCzXN7.js +0 -3
- package/dist/call-Cmd-rlC2.js +0 -331
- package/dist/call-status-tDrmri32.js +0 -33
- package/dist/call.runtime-B3Hufiov.js +0 -2
- package/dist/capability-cli-Ce3qNXsw.js +0 -1401
- package/dist/card-command-CJdI6sGe.js +0 -241
- package/dist/catalog-provider-DY1ugTDc.js +0 -40
- package/dist/catchup-CPt_Xs3R.js +0 -300
- package/dist/channel-9VLlWEI1.js +0 -350
- package/dist/channel-B-414Az-.js +0 -1100
- package/dist/channel-BEuRg3eQ.js +0 -297
- package/dist/channel-BlN_kpiT.js +0 -840
- package/dist/channel-Bz03tu1a.js +0 -1174
- package/dist/channel-C5Tp1ocZ.js +0 -595
- package/dist/channel-Cp6PItXu.js +0 -1320
- package/dist/channel-CzXZ2Wlv.js +0 -226
- package/dist/channel-DIkT4jcM.js +0 -491
- package/dist/channel-DcywMc0l.js +0 -1802
- package/dist/channel-Dt2V2WJc.js +0 -453
- package/dist/channel-core-BqZwOpId.js +0 -5
- package/dist/channel-inbound-B7Bv-zk9.js +0 -31
- package/dist/channel-plugin-runtime-D2c6-qG7.js +0 -771
- package/dist/channel-resolution-DE2qIsKy.js +0 -39
- package/dist/channel-runtime-CL6Do8kd.js +0 -425
- package/dist/channel-selection-BVycf9oD.js +0 -126
- package/dist/channel-selection.runtime-6URJ5YTl.js +0 -2
- package/dist/channel.runtime-BvuS-PzM.js +0 -2364
- package/dist/channel.runtime-CCct0AmO.js +0 -89
- package/dist/channel.runtime-CSr_Q-Ki.js +0 -26
- package/dist/channel.runtime-DC7FilE-.js +0 -576
- package/dist/channel.runtime-MbysJwT_.js +0 -42398
- package/dist/channel.runtime-RfnLhIct.js +0 -430
- package/dist/channel.runtime-klwS5eJC.js +0 -4
- package/dist/channel.runtime-srmPwBlw.js +0 -67
- package/dist/channel.setup-B2dTQgdm.js +0 -10
- package/dist/channel2.runtime-DPjdUdWe.js +0 -109
- package/dist/channels-Dv75fvTN.js +0 -733
- package/dist/channels-cli-CdOO74YS.js +0 -268
- package/dist/chat-RXBcjTu0.js +0 -2830
- package/dist/chrome-BXAOdA_f.js +0 -1430
- package/dist/chrome-mcp-BxYER6mx.js +0 -600
- package/dist/chrome-mcp-DBAP4O7j.js +0 -2
- package/dist/chrome.executables-DUG48PkZ.js +0 -541
- package/dist/chunk-CW9jTwFk.js +0 -268
- package/dist/clawbot-cli-CFMt_3zm.js +0 -9
- package/dist/cli-BPiKrd4S.js +0 -219
- package/dist/cli-BaH_mH3N.js +0 -154
- package/dist/cli-Bnlo8CdT.js +0 -2
- package/dist/cli-Bv1HNRJ5.js +0 -72
- package/dist/cli-CJjDYqsm.js +0 -3726
- package/dist/cli-D1HCyEF2.js +0 -2
- package/dist/cli-LrPyoM0F.js +0 -2
- package/dist/cli-runner-G69QIenA.js +0 -286
- package/dist/cli-runner.runtime-BLh4ORZH.js +0 -3
- package/dist/cli-runner.runtime-DboAnzrp.js +0 -4
- package/dist/cli.runtime-GlOBpTyx.js +0 -1261
- package/dist/client-ClJyHgmq.js +0 -713
- package/dist/client-PBXIhvrx.js +0 -138
- package/dist/client-info-DZtBR4jU.js +0 -49
- package/dist/command-auth-9KsVrUS6.js +0 -409
- package/dist/command-auth-D11sIoiZ.js +0 -76
- package/dist/command-config-resolution-B9-W4ET0.js +0 -2
- package/dist/command-config-resolution-Wl8868is.js +0 -23
- package/dist/command-config-resolution.runtime-CwcIQOXb.js +0 -2
- package/dist/command-execution-startup-BqLYlG3n.js +0 -324
- package/dist/command-gates-BCh2pNFa.js +0 -47
- package/dist/command-registry-B7IhcWl6.js +0 -4
- package/dist/command-registry-DPR9uz9j.js +0 -9
- package/dist/command-registry-core-B5gwwfVK.js +0 -106
- package/dist/command-secret-gateway-D2Lx9Ky-.js +0 -528
- package/dist/command-status.runtime-CDDbtrG8.js +0 -87
- package/dist/commands-acp-Bt7M70te.js +0 -77
- package/dist/commands-compact.runtime-D5D8CApN.js +0 -10
- package/dist/commands-context-ojGcHTsc.js +0 -38
- package/dist/commands-core.runtime-J-hrpY-n.js +0 -2
- package/dist/commands-handlers.runtime-DQBNyeLG.js +0 -4599
- package/dist/commands-models-83LvrT6B.js +0 -327
- package/dist/commands-reset-hooks-BJ-tN_wz.js +0 -135
- package/dist/commands-status-DWJdDC46.js +0 -16
- package/dist/commands-status.runtime-BwwPceyy.js +0 -3
- package/dist/commands-subagents-control.runtime-DJ396mVU.js +0 -3
- package/dist/commands-subagents-control.runtime-u0Q05DrT.js +0 -2
- package/dist/commands-system-prompt-B2QE_VCG.js +0 -2
- package/dist/commands-system-prompt-amkj1mZm.js +0 -158
- package/dist/commands.runtime-DtaJzRBS.js +0 -167
- package/dist/compact-D0swO4Yn.js +0 -1118
- package/dist/compact.runtime-DoEPFAkB.js +0 -12
- package/dist/completion-cli-Y2gWpjun.js +0 -328
- package/dist/config-Bt-fMiqG.js +0 -252
- package/dist/config-api-DAsbCIov.js +0 -2
- package/dist/config-cli-vQiFMkMf.js +0 -1078
- package/dist/config-compat-B5zS8b4Z.js +0 -130
- package/dist/config-compat-Bc51fcbM.js +0 -126
- package/dist/config-guard-DkhDBkW2.js +0 -96
- package/dist/config-runtime-o9UzLknt.js +0 -32
- package/dist/configure-4GGf_X5o.js +0 -1252
- package/dist/configure-DXNuDvJ5.js +0 -2
- package/dist/connect-options-D4mbwxwf.js +0 -699
- package/dist/control-auth-CW8eEClz.js +0 -125
- package/dist/control-service-v2GS08H6.js +0 -156
- package/dist/control-ui/assets/agents-BskHTW81.js +0 -1052
- package/dist/control-ui/assets/canvas-C0aRpEGd.js +0 -269
- package/dist/control-ui/assets/channels-Cou3VPB8.js +0 -463
- package/dist/control-ui/assets/cron-BTOQWH3p.js +0 -933
- package/dist/control-ui/assets/debug-DFlkgaJr.js +0 -94
- package/dist/control-ui/assets/index-BSKZQZqm.css +0 -1
- package/dist/control-ui/assets/index-yB7WOhLR.js +0 -6210
- package/dist/control-ui/assets/instances-LZGly20d.js +0 -57
- package/dist/control-ui/assets/mcp-D0PCi1zE.js +0 -373
- package/dist/control-ui/assets/nodes-BGzTN7_8.js +0 -618
- package/dist/control-ui/assets/plugins-kalk3SHa.js +0 -273
- package/dist/control-ui/assets/sessions-3I2s2QvS.js +0 -306
- package/dist/control-ui/assets/skills-CVXfvdtq.js +0 -323
- package/dist/control-ui/assets/wallet-0oCbcesL.js +0 -285
- package/dist/control-ui-969zq03L.js +0 -1043
- package/dist/conversation-id-CRePZnKh.js +0 -235
- package/dist/conversation-id-CYPpQ2b_.js +0 -38
- package/dist/conversation-runtime-CsNLbytB.js +0 -31
- package/dist/core-CE92oVKC.js +0 -275
- package/dist/create-5gsvOUrW.js +0 -80
- package/dist/cron-cli-iwMQSWts.js +0 -713
- package/dist/daemon-cli-B2_mPKtr.js +0 -12
- package/dist/dashboard-BgppT7jE.js +0 -2
- package/dist/dashboard-BvirXUKT.js +0 -81
- package/dist/ddg-client-C2_vfwll.js +0 -147
- package/dist/ddg-search-provider-B5vfg-3L.js +0 -54
- package/dist/delegate-CUa3SE1o.js +0 -64
- package/dist/deliver-B8OtkCTN.js +0 -3
- package/dist/deliver-EzzwtNdH.js +0 -747
- package/dist/deliver-runtime-CSD1urwa.js +0 -2
- package/dist/delivery-context-DWhGyo59.js +0 -40
- package/dist/delivery-outbound.runtime-CuQHxHy1.js +0 -6
- package/dist/delivery.runtime-2U6XvLON.js +0 -253
- package/dist/detached-task-runtime-CLeXceLH.js +0 -73
- package/dist/devices-cli-BhL3A8cJ.js +0 -498
- package/dist/diagnostics-CYkTN8yr.js +0 -154
- package/dist/direct-dm-B7BKDOTt.js +0 -64
- package/dist/directive-handling.fast-lane-hTmCaN4B.js +0 -66
- package/dist/directive-handling.impl-CLfhAB3s.js +0 -2
- package/dist/directive-handling.impl-DQCYdyq3.js +0 -703
- package/dist/directive-handling.model-selection-r1oi_Z5Q.js +0 -114
- package/dist/directive-handling.persist.runtime-CKVn6kNl.js +0 -215
- package/dist/directive-handling.shared-DLVXjKip.js +0 -56
- package/dist/directory-cli-Cp5qe7Tb.js +0 -240
- package/dist/dispatch-Dy7iNSXe.js +0 -1131
- package/dist/dispatch-acp-TiM2Vzfh.js +0 -981
- package/dist/dispatch-acp-manager.runtime-IOMdfbvN.js +0 -3
- package/dist/dispatch-acp-media.runtime-D8ZRAL_i.js +0 -4
- package/dist/dispatch-acp-session.runtime-BNf4E79J.js +0 -2
- package/dist/dispatch-acp.runtime-D-O-_uwA.js +0 -19
- package/dist/doctor-config-flow-REpgyGT1.js +0 -420
- package/dist/doctor-config-preflight-DCEuxKBd.js +0 -2
- package/dist/doctor-config-preflight-_gjxioW4.js +0 -63
- package/dist/doctor-contract-U3opYPeO.js +0 -26
- package/dist/doctor-device-pairing-NWw3fVhm.js +0 -307
- package/dist/doctor-gateway-daemon-flow-ciZuB3_y.js +0 -250
- package/dist/doctor-gateway-health-Clb9pKDM.js +0 -63
- package/dist/doctor-health-Dz0Uo3ey.js +0 -59
- package/dist/doctor-health-contributions-B36IgdyB.js +0 -493
- package/dist/doctor-prompter-D6cxwaM6.js +0 -56
- package/dist/doctor-sandbox-CnGh8PIF.js +0 -194
- package/dist/doctor-state-migrations-DlFzkEz6.js +0 -2
- package/dist/doctor-workspace-status-CBsmvySn.js +0 -75
- package/dist/dreaming-CzDMTkOn.js +0 -1582
- package/dist/dreaming-narrative-y806xcaM.js +0 -596
- package/dist/dreaming-shared-C4dysoA0.js +0 -21
- package/dist/embedded-gateway-stub.runtime-CHJcdIyH.js +0 -9
- package/dist/embeddings-CWCkXHbh.js +0 -215
- package/dist/embeddings-http-CdI7ktv7.js +0 -205
- package/dist/exa-web-search-provider-Duy7AQi9.js +0 -80
- package/dist/exa-web-search-provider.runtime-BFsoURiN.js +0 -302
- package/dist/exa-web-search-provider.runtime-DL0X8Ct2.js +0 -2
- package/dist/exec-approval-forwarder.runtime-DTz08HhE.js +0 -3
- package/dist/exec-approval-reply-CKpq6yzn.js +0 -296
- package/dist/exec-approval-reply-CuNQhfNe.js +0 -2
- package/dist/exec-approval-session-target-VmakwuWi.js +0 -176
- package/dist/exec-approvals-cli-D-xC3sec.js +0 -498
- package/dist/exec-defaults-BwOKAzOq.js +0 -2
- package/dist/exec-defaults-C58y025t.js +0 -67
- package/dist/execute.runtime-DOUF94B3.js +0 -1363
- package/dist/fallbacks-5pUORVnh.js +0 -31
- package/dist/fallbacks-WXR5Obc4.js +0 -2
- package/dist/fallbacks-shared-CLY3SckB.js +0 -111
- package/dist/format-Z6ci0mN3.js +0 -176
- package/dist/gateway-Bh4zysny.js +0 -115
- package/dist/gateway-cli-Cn8UyxHT.js +0 -1283
- package/dist/gateway-rpc-DWqAmWHZ.js +0 -14
- package/dist/gateway-rpc.runtime-8RQQdisU.js +0 -23
- package/dist/gateway-runtime-CqSQCYo0.js +0 -15
- package/dist/gateway-status-CRk9P_mQ.js +0 -584
- package/dist/genesis-tools-Bczkn4pa.js +0 -9166
- package/dist/genesis-tools.runtime-DybZ3Sbd.js +0 -2
- package/dist/get-reply-BFleeJ4f.js +0 -3897
- package/dist/get-reply-from-config.runtime-D3inD3tz.js +0 -2
- package/dist/graph-users-6xhmlyu_.js +0 -1337
- package/dist/guarded-json-api-BzmpX7Bh.js +0 -594
- package/dist/health-CMBrLjD5.js +0 -3
- package/dist/health-CYhGu11X.js +0 -469
- package/dist/health-route-C6jiKkgE.js +0 -41
- package/dist/health-route-C6s6ENKx.js +0 -2
- package/dist/heartbeat-runner-Dh9Xx9YU.js +0 -1292
- package/dist/heartbeat-runner-zDpniJi_.js +0 -5
- package/dist/heartbeat-runner.runtime-D4lSdsnQ.js +0 -4
- package/dist/helpers-DZTamQ-L.js +0 -320
- package/dist/hooks-cli-DWDRPcaF.js +0 -433
- package/dist/http-endpoint-helpers-BYmpbInx.js +0 -41
- package/dist/http-headers-BWJ-wWSB.js +0 -11
- package/dist/http-utils-DFEeaWER.js +0 -924
- package/dist/identity-JQch7avk.js +0 -140
- package/dist/image-fallbacks-BdpPq4o8.js +0 -2
- package/dist/image-fallbacks-GxUehr7F.js +0 -31
- package/dist/image-generation-provider-Bs8dan-F.js +0 -95
- package/dist/image-generation-provider-Ca75_MHL.js +0 -63
- package/dist/image-generation-provider-Cumlkwcm.js +0 -228
- package/dist/image-generation-provider-DAAncrN2.js +0 -529
- package/dist/image-generation-provider-LZz_eWeh.js +0 -157
- package/dist/image-generation-provider-xE4TSEUN.js +0 -274
- package/dist/inbound-reply-dispatch-DRjQ7qlQ.js +0 -73
- package/dist/inbound.runtime-B3E6TUQ-.js +0 -4
- package/dist/inbound.runtime-BsJCJ9wE.js +0 -3
- package/dist/infra-runtime-pY0nhq7P.js +0 -39
- package/dist/init-BFVKFRp9.js +0 -59
- package/dist/install-signal-cli-Aj1HHG57.js +0 -202
- package/dist/jobs-CzIiEiXa.js +0 -734
- package/dist/kimi-web-search-provider-g6k5oyqw.js +0 -80
- package/dist/kimi-web-search-provider.runtime-B5Y_iP-w.js +0 -2
- package/dist/kimi-web-search-provider.runtime-D9mGNz4w.js +0 -261
- package/dist/library-BpP85Umq.js +0 -45
- package/dist/lifecycle-C69VoOuS.js +0 -229
- package/dist/lifecycle-zC5_kLvH.js +0 -571
- package/dist/lifecycle.runtime-DN9n10Ar.js +0 -2
- package/dist/list-CZePHMYk.js +0 -2
- package/dist/list-D-39rkJG.js +0 -2
- package/dist/list-D9R6bffC.js +0 -1212
- package/dist/list-J_MIp9Cf.js +0 -131
- package/dist/list.probe-BJI7RpM4.js +0 -419
- package/dist/live-model-switch-1UTJZ5QI.js +0 -336
- package/dist/llm-slug-generator-CB-9wD87.js +0 -79
- package/dist/load-config-Cokd9aKd.js +0 -35
- package/dist/local-dispatch.runtime-DfmGw3hN.js +0 -8
- package/dist/login-Ca9f5om9.js +0 -108
- package/dist/logs-cli-Dz0aORYp.js +0 -265
- package/dist/logs-cli.runtime-DgpP6kgG.js +0 -2
- package/dist/main-session-restart-recovery-BdWx2-Ig.js +0 -206
- package/dist/managed-image-attachments-BTEZZFPC.js +0 -2
- package/dist/managed-image-attachments-BXwFe_hB.js +0 -635
- package/dist/manager-49WINgRB.js +0 -3114
- package/dist/manager-CKWINDnN.js +0 -2
- package/dist/manager-DXquZHPE.js +0 -2057
- package/dist/markdown-to-line-DuPPNWHb.js +0 -790
- package/dist/mcp-cli-BgjBxFLB.js +0 -725
- package/dist/mcp-http-CXz6iTV9.js +0 -529
- package/dist/media-contract-api-Dn7Z9fVR.js +0 -2
- package/dist/media-contract-g0U7MSOk.js +0 -49
- package/dist/media-runtime-DKL6xud8.js +0 -329
- package/dist/memory-Cvmtd7SS.js +0 -342
- package/dist/memory-core-host-runtime-cli-DZAsYda3.js +0 -9
- package/dist/memory-embedding-adapter-D58z4Hjn.js +0 -123
- package/dist/message-DqFmV6vo.js +0 -232
- package/dist/message-action-runner-B-6rT67S.js +0 -1407
- package/dist/message-action-runner-Ds9MNZPn.js +0 -2
- package/dist/message-actions-Bvs23y8w.js +0 -143
- package/dist/message-channel-bhWoqTRw.js +0 -56
- package/dist/message-secret-scope-CEVGxySq.js +0 -103
- package/dist/message.gateway.runtime-CT0DJ45B.js +0 -2
- package/dist/method-scopes-DZxEwSC9.js +0 -228
- package/dist/minimax-web-search-provider-4scwuRzS.js +0 -53
- package/dist/minimax-web-search-provider.runtime-Bc1tLmEn.js +0 -140
- package/dist/minimax-web-search-provider.runtime-DirtikTO.js +0 -2
- package/dist/mock-DjlwRj77.js +0 -136
- package/dist/model-definitions-DAfZ2fCD.js +0 -260
- package/dist/model-overrides-C47kuXVC.js +0 -104
- package/dist/model-selection-B0e0JNhN.js +0 -213
- package/dist/models-CEyQw90_.js +0 -47
- package/dist/models-CQV1b487.js +0 -760
- package/dist/models-CXOS_VP1.js +0 -157
- package/dist/models-CfTF8Fbp.js +0 -569
- package/dist/models-auth-status-CtbfpiLe.js +0 -217
- package/dist/models-cli-DKlGXayC.js +0 -271
- package/dist/models-http-DWu9XkAU.js +0 -92
- package/dist/models.fetch-BVY3QlcA.js +0 -518
- package/dist/monitor-BrQZ38sV.js +0 -1661
- package/dist/monitor-C2olcPaB.js +0 -1237
- package/dist/monitor-C32pQJf0.js +0 -788
- package/dist/monitor-DWDZx3af.js +0 -2
- package/dist/monitor-DuB8d2_N.js +0 -671
- package/dist/monitor-DwAHrb0v.js +0 -295
- package/dist/monitor-auth-ym3-n10B.js +0 -207
- package/dist/monitor-fV4pkrv-.js +0 -1459
- package/dist/monitor-processing-Cnjt-86E.js +0 -1974
- package/dist/monitor.runtime-m4hyBv5_.js +0 -2
- package/dist/monitor.webhook-DpQqy92z.js +0 -180
- package/dist/msteams-CEC38YQX.js +0 -35
- package/dist/music-generation-provider-DR8TlAd7.js +0 -63
- package/dist/music-generation-provider-UU2xosmd.js +0 -170
- package/dist/native-hook-relay-ALDxVrJR.js +0 -519
- package/dist/native-web-search-DE6wKTD7.js +0 -64
- package/dist/nextcloud-talk-D6l_ncY6.js +0 -17
- package/dist/node-cli-B4fFzsbt.js +0 -2276
- package/dist/nodes-cli-DPOCIMd6.js +0 -1046
- package/dist/nodes-utils-DXJ9uuER.js +0 -84
- package/dist/nodes.helpers-DYpGCFer.js +0 -34
- package/dist/notify-CDGsB-f1.js +0 -315
- package/dist/onboard-BAKpU8Hh2.js +0 -49
- package/dist/onboard-BPXard5r.js +0 -316
- package/dist/onboard-BhyqJz5g.js +0 -2
- package/dist/onboard-CYwvwcjK.js +0 -25
- package/dist/onboard-DEkkXwRP.js +0 -58
- package/dist/onboard-DcPiUfS6.js +0 -70
- package/dist/onboard-UUvy9YwT.js +0 -29
- package/dist/onboard-g4ijsx6R.js +0 -25
- package/dist/onboard-helpers-DD5g-FbW.js +0 -204
- package/dist/onboard-helpers-DRudISKo.js +0 -6
- package/dist/onboard-iJRhJj4E.js +0 -25
- package/dist/onboard-interactive-DxupaeWe.js +0 -24
- package/dist/onboard-non-interactive-BCIl9AIV.js +0 -635
- package/dist/onboard-remote-By9HP4eT.js +0 -193
- package/dist/onboard-remote-r9H76BMI.js +0 -2
- package/dist/onboard-skills-BbXkZVWi.js +0 -2
- package/dist/onboard-skills-Bj6v5Fc2.js +0 -134
- package/dist/openai-codex-auth-identity-DDVrnkGx.js +0 -45
- package/dist/openai-codex-device-code-vaMr3ktu.js +0 -164
- package/dist/openai-codex-provider-BgIrfq5f.js +0 -472
- package/dist/openai-codex-shared-i8zMv9Wn.js +0 -6
- package/dist/openai-http-3hSjTiC9.js +0 -500
- package/dist/openai-provider-BRJBMcdJ.js +0 -313
- package/dist/openresponses-http-DCEEmL6J.js +0 -1128
- package/dist/operator-approvals-client-gaflvETF.js +0 -68
- package/dist/outbound-media-Bh4sEXyv.js +0 -57
- package/dist/outbound-runtime-CNL02KHG.js +0 -5
- package/dist/outbound.runtime-DNeZz0qd.js +0 -2
- package/dist/pair-command-approve-DVG9ZQOz.js +0 -44
- package/dist/perplexity-web-search-provider-CIwymV16.js +0 -92
- package/dist/perplexity-web-search-provider.runtime-CIrANP8t.js +0 -324
- package/dist/perplexity-web-search-provider.runtime-GuZxipp7.js +0 -2
- package/dist/persistent-bindings.lifecycle-DO0CXQku.js +0 -2
- package/dist/persistent-bindings.lifecycle-yyMTI5wL.js +0 -85
- package/dist/pi-embedded-G_7qiYrd.js +0 -2905
- package/dist/pi-embedded-RNv_18Ql.js +0 -4
- package/dist/pi-embedded-subscribe.handlers.compaction.runtime-B0obozHf.js +0 -23
- package/dist/pi-embedded.runtime-DgLkukEn.js +0 -4
- package/dist/pi-tool-definition-adapter-CAxVoliV.js +0 -229
- package/dist/pi-tools-DLzCdu_A.js +0 -1057
- package/dist/pi-tools.before-tool-call-CXqyPFQ7.js +0 -2
- package/dist/pi-tools.before-tool-call-DgEuyrNS.js +0 -433
- package/dist/plivo-B2yZjL-u.js +0 -394
- package/dist/plugin--KkHkZKl.js +0 -12195
- package/dist/plugin-enabled-DOVricci.js +0 -140
- package/dist/plugin-registration-BsNMVImp.js +0 -23
- package/dist/plugin-service-CAdEnLLQ.js +0 -2892
- package/dist/policy-6PXLgKPZ.js +0 -328
- package/dist/prepare.runtime-asu7nymR.js +0 -815
- package/dist/probe-8nNaZ33e.js +0 -45
- package/dist/probe-BOlTfbzG.js +0 -2
- package/dist/probe-BicpMUHr.js +0 -74
- package/dist/probe-BoAfs3v0.js +0 -243
- package/dist/probe-C2UYvuU1.js +0 -1443
- package/dist/probe-D3-S54s4.js +0 -2
- package/dist/probe-D7gHyiZV.js +0 -241
- package/dist/probe-Dauysr9a.js +0 -32
- package/dist/probe-DqbaFZ8U.js +0 -2205
- package/dist/probe.runtime-D1TENrHH.js +0 -2
- package/dist/program-C_hsOWv5.js +0 -111
- package/dist/prompt-select-styled-CuuJ3YZI.js +0 -20
- package/dist/protocol-DxLbSF2J.js +0 -2477
- package/dist/provider-3GpsNTSy.js +0 -70
- package/dist/provider-catalog-BSXiLKUb.js +0 -24
- package/dist/provider-catalog-BfrRkDb6.js +0 -26
- package/dist/provider-catalog-CQOOAKUd.js +0 -11
- package/dist/provider-catalog-DuplUDCj.js +0 -12
- package/dist/provider-catalog-nmYuB55e.js +0 -11
- package/dist/provider-compat-Cmc7Dpb2.js +0 -37
- package/dist/provider-dispatcher-C98nuGtx.js +0 -2
- package/dist/provider-dispatcher-U0bjp31x.js +0 -22
- package/dist/provider-models-CQ8YMhIq.js +0 -35
- package/dist/provider-models-xoUb7pnU.js +0 -119
- package/dist/provider-registration-B5Xbkn85.js +0 -218
- package/dist/pw-ai-B0xjo-Hb.js +0 -2511
- package/dist/pw-role-snapshot-DfdV7JMN.js +0 -380
- package/dist/qmd-manager-DtShFCys.js +0 -1921
- package/dist/qr-cli-D38r9mtY.js +0 -2
- package/dist/qr-cli-Wbrc0tcy.js +0 -349
- package/dist/qr-image-BQhzr3CC.js +0 -2
- package/dist/queue-DyWzQqJh.js +0 -409
- package/dist/reaction-runtime-api-BZCWmrll.js +0 -116
- package/dist/reactions-BmhlLeFI.js +0 -998
- package/dist/read-capability-B0mVFrNe.js +0 -412
- package/dist/realtime-provider-shared-CKounRGH.js +0 -37
- package/dist/realtime-transcription-provider-BjwZyKME.js +0 -120
- package/dist/realtime-transcription-provider-CSQuayAt.js +0 -183
- package/dist/realtime-transcription-provider-Cr86v5pA.js +0 -184
- package/dist/realtime-transcription-provider-DFdWvvWN.js +0 -184
- package/dist/realtime-transcription-provider-Da6Yg9O_.js +0 -172
- package/dist/realtime-voice-provider-DP4ad0L4.js +0 -489
- package/dist/record-shared-B5MzAU-n.js +0 -10
- package/dist/register-service-commands-B2Ky9P6l.js +0 -71
- package/dist/register.agent-C9UIPMzI.js +0 -248
- package/dist/register.configure-DlvVdJGK.js +0 -15
- package/dist/register.maintenance-4q078BpS.js +0 -363
- package/dist/register.message-Dyafa7wU.js +0 -329
- package/dist/register.onboard-R4VgPeqI.js +0 -88
- package/dist/register.runtime-Eju4Gltw.js +0 -81
- package/dist/register.setup-DCnMQggx.js +0 -150
- package/dist/register.status-health-sessions-DrZEX_C3.js +0 -1215
- package/dist/register.subclis-C8MYnxZ0.js +0 -29
- package/dist/register.subclis-DXRcUQY-.js +0 -3
- package/dist/register.subclis-core-CKrFtMnT.js +0 -249
- package/dist/replay-policy-BXxBsUQj.js +0 -8
- package/dist/reply-chunking-CQ-Mda9f.js +0 -3
- package/dist/reply-dispatch-runtime-DrCMM_h6.js +0 -13
- package/dist/reply-media-paths.runtime-Dm7QsGx1.js +0 -146
- package/dist/reply-media-paths.runtime-N1vQKI2t.js +0 -2
- package/dist/reply-payload-transform-DXQFdUjX.js +0 -720
- package/dist/reply-runtime-BEbR4D-L.js +0 -11
- package/dist/reply.runtime-k1wfQvE8.js +0 -2
- package/dist/reset-PRwf7E1a.js +0 -84
- package/dist/reset-authorization-DnCXXdJm.js +0 -34
- package/dist/response-generator-CfYnwr-R.js +0 -175
- package/dist/restart-health-BjmfJCUM.js +0 -202
- package/dist/restart-health-hw909zlD.js +0 -2
- package/dist/root-help-DetBH1U3.js +0 -44
- package/dist/route-reply-DCdEIaJm.js +0 -162
- package/dist/route-reply.runtime-CCoWkbHJ.js +0 -2
- package/dist/routes-CBHvnNAn.js +0 -3341
- package/dist/routes-CM5XFUol.js +0 -2
- package/dist/routing-DB6Hmk1m.js +0 -5
- package/dist/rpc-DejtQFPW.js +0 -61
- package/dist/rpc-context-C-K-u97k.js +0 -17
- package/dist/rpc.runtime-CvFF6IfX.js +0 -21
- package/dist/run-auth-profile.runtime-CBF7l6AJ.js +0 -2
- package/dist/run-delivery.runtime-mrFGIUBn.js +0 -530
- package/dist/run-embedded.runtime-Bi_aGXZl.js +0 -4
- package/dist/run-execution-cli.runtime-CJ5bRUst.js +0 -4
- package/dist/run-executor.runtime-C2nEQ7H5.js +0 -277
- package/dist/run-main-C4eOl9O3.js +0 -567
- package/dist/run-subagent-registry.runtime-Wv4vcMON.js +0 -2
- package/dist/run-wait-J2xqMO0Y.js +0 -135
- package/dist/runtime-BWI1Yc19.js +0 -9
- package/dist/runtime-BvrYBFWw.js +0 -107
- package/dist/runtime-YN3DqmXj.js +0 -72
- package/dist/runtime-api-B7_47clB.js +0 -9
- package/dist/runtime-api-CCSSXW6u.js +0 -4
- package/dist/runtime-api-CHqMki_k.js +0 -9
- package/dist/runtime-api-FyNFEQa6.js +0 -14
- package/dist/runtime-embedded-pi.runtime-CKKAqNJ9.js +0 -2
- package/dist/runtime-entry-T6UII6Wf.js +0 -2769
- package/dist/runtime-internal-BsETZzZr.js +0 -2
- package/dist/runtime-lZ_xBQn6.js +0 -973
- package/dist/runtime-options-DYh6T1p4.js +0 -275
- package/dist/runtime-provider-C0RXuzkp.js +0 -21
- package/dist/runtime-schema-DjdB9Mgh.js +0 -28588
- package/dist/sandbox-Ctv6fRri.js +0 -3
- package/dist/sandbox-cli-DlgKqSYU.js +0 -450
- package/dist/sandbox-xqJ6gg8T.js +0 -1156
- package/dist/scan-C4AL0vV5.js +0 -2
- package/dist/scan-CiyGLsBp.js +0 -523
- package/dist/secrets-cli-BzZc1dlc.js +0 -2101
- package/dist/security-cli-D7WSpDIp.js +0 -486
- package/dist/selection-BTj1orBr.js +0 -2
- package/dist/selection-Bj9s46tI.js +0 -7764
- package/dist/send-D1BQp5zh.js +0 -102
- package/dist/send-KwF2Hkrg.js +0 -534
- package/dist/send-pMWIOnb1.js +0 -156
- package/dist/send.runtime-BY-fpUGh.js +0 -2
- package/dist/server-4wSXAqKZ.js +0 -77
- package/dist/server-CM6IcXrJ.js +0 -13
- package/dist/server-context-LGN_v6Pr.js +0 -847
- package/dist/server-context-uC_sh4Qx.js +0 -2
- package/dist/server-middleware-DlVw3WGo.js +0 -120
- package/dist/server-node-events-DRqk_sSG.js +0 -481
- package/dist/server-plugin-bootstrap-DT7hMrEB.js +0 -12989
- package/dist/server-plugin-bootstrap-DbgT8s3b.js +0 -2
- package/dist/server-restart-sentinel-DJg1jibz.js +0 -697
- package/dist/server.impl-KfCHHYM3.js +0 -12869
- package/dist/session-D4GawBOc.js +0 -48
- package/dist/session-envelope-BuDz-uci.js +0 -18
- package/dist/session-key-BDzsY9ry.js +0 -65
- package/dist/session-kill-http-BtXfgdg5.js +0 -110
- package/dist/session-meta-DSbdkLPg.js +0 -109
- package/dist/session-override-DvpYNjEy.js +0 -106
- package/dist/session-reset-model.runtime-TJuluskH.js +0 -133
- package/dist/session-reset-service-hc2O1o2q.js +0 -497
- package/dist/session-route-dSc-ZfJV.js +0 -93
- package/dist/session-status.runtime-DBOWNGE0.js +0 -2
- package/dist/session-store-CH0Ic73R.js +0 -126
- package/dist/session-store.runtime-BLzP0kKb.js +0 -2
- package/dist/session-subagent-reactivation.runtime-DLwmbVAj.js +0 -2
- package/dist/session-tab-registry-C30tFUHP.js +0 -581
- package/dist/session-updates-CNv8yQTZ.js +0 -236
- package/dist/session-updates.runtime-BI1pPG-y.js +0 -2
- package/dist/session-utils-BtcpsVXK.js +0 -1009
- package/dist/session-visibility-mu61Cazj.js +0 -147
- package/dist/sessions-BY-N1ODJ.js +0 -2
- package/dist/sessions-BaBnI48b.js +0 -48
- package/dist/sessions-DgCDR090.js +0 -16
- package/dist/sessions-DwbTRE7z.js +0 -281
- package/dist/sessions-helpers-Boau-Mgl.js +0 -305
- package/dist/sessions-history-http-JaZfsaow.js +0 -383
- package/dist/sessions-patch-CGza9U1J.js +0 -309
- package/dist/sessions-resolve-CxsMxrnz.js +0 -174
- package/dist/sessions.runtime-B-dhGJmG.js +0 -2
- package/dist/setup-Dld60Kw0.js +0 -636
- package/dist/setup-XAAowspF.js +0 -421
- package/dist/setup-api-qytGcCw9.js +0 -29
- package/dist/setup-core-4RX2I3E7.js +0 -176
- package/dist/setup-core-BDZ0GEn7.js +0 -171
- package/dist/setup-core-BagQlOhA.js +0 -184
- package/dist/setup-core-DFDx-2sA.js +0 -393
- package/dist/setup-surface-BFIZR2UD.js +0 -286
- package/dist/setup-surface-BNFYOzmc.js +0 -3
- package/dist/setup-surface-C5F8cr6e2.js +0 -403
- package/dist/setup-surface-CArOZxWv.js +0 -72
- package/dist/setup-surface-D5kQP_5C.js +0 -219
- package/dist/setup-surface-uNLwReGA.js +0 -351
- package/dist/setup.finalize-DanHcKdm.js +0 -547
- package/dist/setup.gateway-config-BfYDHl2S.js +0 -250
- package/dist/shared-CHz0sVK9.js +0 -186
- package/dist/shared-CaYwmZh_.js +0 -76
- package/dist/shared-DZLuHh9i.js +0 -121
- package/dist/shared-Doh9gWDF.js +0 -198
- package/dist/shared-IhxU1SqF.js +0 -60
- package/dist/shared-Xx-lZLWj.js +0 -217
- package/dist/shared-runtime-BtwYWnp-.js +0 -7
- package/dist/short-term-promotion-B_3UbQd-.js +0 -1543
- package/dist/skill-commands-X1-SuzeM.js +0 -83
- package/dist/skill-commands.runtime-DtDW-HM9.js +0 -2
- package/dist/skills-snapshot.runtime-CA04_tLs.js +0 -7
- package/dist/slash-state-C5V_rwuh.js +0 -1911
- package/dist/speech-provider-Bs22xK7f.js +0 -216
- package/dist/speech-provider-DH35IJrp.js +0 -395
- package/dist/speech-provider-DJhp-WGc.js +0 -170
- package/dist/speech-provider-TuMZXjYA.js +0 -209
- package/dist/speech-provider-bfFcbOuQ.js +0 -184
- package/dist/speech-provider-eDdGrCL3.js +0 -209
- package/dist/speech-provider-hFc3R_JS.js +0 -103
- package/dist/src-CbvReXTF.js +0 -3974
- package/dist/stage-sandbox-media.runtime-BBZVC4gy.js +0 -232
- package/dist/startup-context-BhbpkDRe.js +0 -312
- package/dist/state-migrations-BcK6CUBE.js +0 -820
- package/dist/status-6TVRvc0X.js +0 -2
- package/dist/status-BXUtOoXd.js +0 -190
- package/dist/status-BYxVnJ4t.js +0 -62
- package/dist/status-CASjTsed.js +0 -3
- package/dist/status-CozhtuYB.js +0 -2
- package/dist/status-DtWC4gU2.js +0 -397
- package/dist/status-all-RMu-gp_i.js +0 -498
- package/dist/status-json-C05vJFn8.js +0 -14
- package/dist/status-json-command-CM9ioz3P.js +0 -84
- package/dist/status-message-CqkaBWzr.js +0 -466
- package/dist/status-message.runtime-qXxrcsiN.js +0 -6
- package/dist/status-queue.runtime-C7PIZ71w.js +0 -2
- package/dist/status-runtime-shared-CilAS_RU.js +0 -257
- package/dist/status-subagents.runtime-_MQiX_ZF.js +0 -18
- package/dist/status-text-Cbbo5gTy.js +0 -237
- package/dist/status-xCBvRTwU.js +0 -209
- package/dist/status.gateway-connection.runtime-CpCUmiCK.js +0 -2
- package/dist/status.gather-B_e7gqcb.js +0 -2
- package/dist/status.gather-DeoHK2V7.js +0 -292
- package/dist/status.runtime-CCrtR3yP.js +0 -2
- package/dist/status.runtime-IgA-WP26.js +0 -2
- package/dist/status.scan-BywaTUGM.js +0 -65
- package/dist/status.scan-overview-Bg0PxIss.js +0 -379
- package/dist/status.scan.fast-json-Bf3f1o0d.js +0 -2
- package/dist/status.scan.fast-json-D7_WMvuZ.js +0 -132
- package/dist/status.summary-BoGDDE4X.js +0 -214
- package/dist/status.summary-b0S78Iju.js +0 -2
- package/dist/store-BXDBdpSq.js +0 -4
- package/dist/store-DOwpgFxf.js +0 -910
- package/dist/store.runtime-1QGWUWou.js +0 -2
- package/dist/stream-BsnsNxOA.js +0 -664
- package/dist/stream-DEH1-1Is.js +0 -134
- package/dist/stt-CJtlkVDc.js +0 -66
- package/dist/subagent-announce-delivery-DwS6sI24.js +0 -726
- package/dist/subagent-announce-gxWOuvuY.js +0 -351
- package/dist/subagent-announce-output-C5ButdYI.js +0 -364
- package/dist/subagent-capabilities-DIIDgPnB.js +0 -251
- package/dist/subagent-control-C-Am1OtB.js +0 -506
- package/dist/subagent-control.runtime-BK2jtN2v.js +0 -3
- package/dist/subagent-followup.runtime-DoLAbwOo.js +0 -68
- package/dist/subagent-orphan-recovery-BzDS5O1i.js +0 -305
- package/dist/subagent-registry-BIgNPHJQ.js +0 -1753
- package/dist/subagent-registry-an_oHM4b.js +0 -3
- package/dist/subagent-spawn-BKFMuv1y.js +0 -1005
- package/dist/system-cli-IAtoOtwN.js +0 -59
- package/dist/system-prompt-D-MqNnG1.js +0 -640
- package/dist/tables-Bfl7YTbb.js +0 -829
- package/dist/target-id-BbLPfw0-.js +0 -107
- package/dist/targets-DWXe3mQm.js +0 -67
- package/dist/targets-bhZeEbJG.js +0 -207
- package/dist/targets.runtime-By8N_Qv0.js +0 -2
- package/dist/task-executor-CL1pQUmi.js +0 -360
- package/dist/task-owner-access-B2tFCiT1.js +0 -74
- package/dist/task-registry-CGDnoG_A.js +0 -2366
- package/dist/task-registry-delivery-runtime-DOHFM4em.js +0 -3
- package/dist/task-registry-delivery-runtime-DSl-VyA2.js +0 -2
- package/dist/task-registry.maintenance-BJzi71wn.js +0 -416
- package/dist/task-registry.maintenance-BxKAIJuE.js +0 -2
- package/dist/tavily-client-CJtIuNuZ.js +0 -193
- package/dist/tavily-client-cnGyIHjo.js +0 -2
- package/dist/tavily-search-provider-BGV8D2VZ.js +0 -62
- package/dist/telnyx-fGTIDZqb.js +0 -260
- package/dist/testing-CqUqcJNQ.js +0 -575
- package/dist/text-report-Cky4UA35.js +0 -587
- package/dist/text-runtime-BOpYwhuR.js +0 -290
- package/dist/tool-config-shared-C0rslp8t.js +0 -19
- package/dist/tool-policy-pipeline-qhEZzHB-.js +0 -109
- package/dist/tool-resolution-CjbwGHcJ.js +0 -90
- package/dist/tools-effective-inventory-C70Ug651.js +0 -152
- package/dist/tools-invoke-http-DcRsw9EO.js +0 -206
- package/dist/tools.runtime-B-fcXtvL.js +0 -4
- package/dist/transcript-CTF8zJ2t.js +0 -312
- package/dist/transcript-resolve.runtime-C41xgFnA.js +0 -2
- package/dist/transcript.runtime-DNBFm0LS.js +0 -2
- package/dist/transport-policy-Ivm5ArSd.js +0 -75
- package/dist/trash-CVoAJSAx.js +0 -24
- package/dist/tts-B5G7JHka.js +0 -64
- package/dist/tts-CWykD0rc.js +0 -183
- package/dist/tui-cli-CNanJyFI.js +0 -4575
- package/dist/twilio-B-dBW4_4.js +0 -609
- package/dist/typing-policy-CCK9_cHb.js +0 -12
- package/dist/update-cli-D-uofyXb.js +0 -1759
- package/dist/upgrade-gspO3C-l.js +0 -1226
- package/dist/video-generation-provider-BoKNqi7G.js +0 -254
- package/dist/video-generation-provider-C2PI4-Wg.js +0 -271
- package/dist/video-generation-provider-CDTvRCSr.js +0 -287
- package/dist/video-generation-provider-CDxxol9M.js +0 -281
- package/dist/video-generation-provider-CgDT1u2M.js +0 -187
- package/dist/video-generation-provider-CtC5lXew.js +0 -78
- package/dist/video-generation-provider-DTD47wPw.js +0 -118
- package/dist/video-generation-provider-DqaWr1z8.js +0 -264
- package/dist/video-generation-provider-yuS2SQIL.js +0 -221
- package/dist/video-generation-task-status-BFReBMsX.js +0 -163
- package/dist/voice-mapping-D2aNmRet.js +0 -41
- package/dist/wait-for-idle-before-flush-BFfZxSMK.js +0 -5986
- package/dist/web-search-njsvDPGV.js +0 -61
- package/dist/web-search-provider-Bb1jo3tv.js +0 -163
- package/dist/web-search-provider.runtime-B8p_cAp6.js +0 -185
- package/dist/web-search-provider.runtime-xlnZGUCc.js +0 -2
- package/dist/webhook-shared-CZt-kRIg.js +0 -12
- package/dist/wizard-models-YsngRy_Q.js +0 -334
- package/dist/workflow-runtime-Be-w_Xn7.js +0 -485
- package/dist/workspace-run-CHsJxomp.js +0 -70
- package/dist/x-search-config-ikE_9hVQ.js +0 -36
- package/dist/x-search-shared-Cl-mTkkU.js +0 -75
- package/dist/zalo-js-D6IiDKzH.js +0 -1157
package/dist/manager-49WINgRB.js
DELETED
|
@@ -1,3114 +0,0 @@
|
|
|
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-BOpYwhuR.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-C4dysoA0.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 };
|