squidclaw 3.0.3 → 3.0.4
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/dist/{audio-preflight-BTYxAJjy.js → audio-preflight-BKgdc7dS.js} +4 -4
- package/dist/{audio-preflight-Dkl6Z32z.js → audio-preflight-DpCWFB4z.js} +4 -4
- package/dist/{audio-transcription-runner-Gi_h5HEE.js → audio-transcription-runner-B2BdTEps.js} +1 -1
- package/dist/{audio-transcription-runner-DBkDgluo.js → audio-transcription-runner-BnbdYMDl.js} +1 -1
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +6 -6
- package/dist/bundled/session-memory/handler.js +6 -6
- package/dist/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/{chrome-CAd6FQEn.js → chrome-BQDCalPp.js} +8 -8
- package/dist/{chrome-pBkBuWci.js → chrome-CjxCwFA9.js} +8 -8
- package/dist/{command-registry-CvgCFxfY.js → command-registry-CxiSVXru.js} +6 -6
- package/dist/{completion-cli-BGM1V6EN.js → completion-cli-s0fxD0OE.js} +2 -2
- package/dist/{completion-cli-OrgUDc2S.js → completion-cli-slzdOlRV.js} +1 -1
- package/dist/{config-cli-DbBvjvpS.js → config-cli-C0mk9eRl.js} +1 -1
- package/dist/{config-cli-uIP4r17f.js → config-cli-DhHEA_Nc.js} +1 -1
- package/dist/{configure-BGvoAfbs.js → configure-CeLdVVyh.js} +8 -1
- package/dist/{configure-BOsTXjBw.js → configure-FRd92XZ8.js} +8 -1
- package/dist/{deliver-DBXe-ZmL.js → deliver-D-f6Wa3i.js} +1 -1
- package/dist/{deliver-BJuiq0GS.js → deliver-aL8yOYS1.js} +1 -1
- package/dist/{deliver-runtime-DHKcNQzq.js → deliver-runtime-ChVR6sR3.js} +3 -3
- package/dist/{deliver-runtime-GlnBJNCj.js → deliver-runtime-_egya0QZ.js} +3 -3
- package/dist/{deps-send-whatsapp.runtime-DdxKewuy.js → deps-send-whatsapp.runtime-CZj97m5A.js} +7 -7
- package/dist/{deps-send-whatsapp.runtime-CslTuV47.js → deps-send-whatsapp.runtime-CiG6xd2e.js} +7 -7
- package/dist/{doctor-completion-42wcUATu.js → doctor-completion-I-WDZUs1.js} +1 -1
- package/dist/{doctor-completion-D6RGDBD5.js → doctor-completion-mnJOkoQ_.js} +1 -1
- package/dist/entry.js +2 -2
- package/dist/extensionAPI.js +6 -6
- package/dist/{gateway-cli-CG3mshpO.js → gateway-cli-B5rTNvd7.js} +1 -1
- package/dist/{gateway-cli-BbPfLLT6.js → gateway-cli-BHfkbI0u.js} +1 -1
- package/dist/{image-j_UomzVG.js → image-C-C7hQ26.js} +1 -1
- package/dist/{image-sRW3RpTY.js → image-DKZCmkET.js} +1 -1
- package/dist/{image-runtime-BNh3IfMj.js → image-runtime-D7n4dID4.js} +3 -3
- package/dist/{image-runtime-SUtf9jqh.js → image-runtime-poRypm-b.js} +3 -3
- package/dist/index.js +1 -1
- package/dist/llm-slug-generator.js +6 -6
- package/dist/{onboard-ChxvwUze.js → onboard-BP2Cr_Xy.js} +1 -1
- package/dist/{onboard-1KfKwvMR.js → onboard-CCJCvPgf.js} +1 -1
- package/dist/{onboarding-D6kMb3yv.js → onboarding-D5G87dvM.js} +1 -1
- package/dist/{onboarding-DuUMPrqA.js → onboarding-D7CIbxzd.js} +1 -1
- package/dist/{onboarding.finalize-KTOhO1-l.js → onboarding.finalize-B1MmYTFV.js} +4 -4
- package/dist/{onboarding.finalize-bphDUwZy.js → onboarding.finalize-Cxzl-fYU.js} +3 -3
- package/dist/{pi-embedded-BP2UlUm_.js → pi-embedded-CHzwPt6X.js} +24 -24
- package/dist/{pi-embedded-BGz_qdCc.js → pi-embedded-MktS4l8v.js} +24 -24
- package/dist/{pi-embedded-helpers-CmLnmKlb.js → pi-embedded-helpers-Bse_QhEf.js} +3 -3
- package/dist/{pi-embedded-helpers-BruaFB5l.js → pi-embedded-helpers-DYWYzEOC.js} +3 -3
- package/dist/plugin-sdk/accounts-BNuRM3rG.js +288 -0
- package/dist/plugin-sdk/accounts-CGTYP7Rh.js +46 -0
- package/dist/plugin-sdk/accounts-CcS9IAhD.js +35 -0
- package/dist/plugin-sdk/{accounts-YTdQYQFr.js → accounts-CxUSDHsT.js} +3 -3
- package/dist/plugin-sdk/{accounts-h__dTrLK.js → accounts-PSzw-z3S.js} +2 -2
- package/dist/plugin-sdk/{accounts-DghIDNk2.js → accounts-kr-Gz1hk.js} +2 -2
- package/dist/plugin-sdk/{active-listener-_PRYjtJv.js → active-listener-BQNrTcR3.js} +2 -2
- package/dist/plugin-sdk/active-listener-CTsLn1AX.js +50 -0
- package/dist/plugin-sdk/{api-key-rotation-mVDSAkKQ.js → api-key-rotation-Bhck7wki.js} +2 -2
- package/dist/plugin-sdk/api-key-rotation-DE4gr5YM.js +181 -0
- package/dist/plugin-sdk/audio-preflight-CRGLqp-g.js +69 -0
- package/dist/plugin-sdk/{audio-preflight-BZlQM-qX.js → audio-preflight-_xgGaeho.js} +26 -26
- package/dist/plugin-sdk/{audio-transcription-runner-CrYTX8py.js → audio-transcription-runner-Dwc0Eh-B.js} +11 -11
- package/dist/plugin-sdk/audio-transcription-runner-RXsskMMk.js +2176 -0
- package/dist/plugin-sdk/audit-membership-runtime-B9b-zRwg.js +58 -0
- package/dist/plugin-sdk/{audit-membership-runtime-Xl20kCBe.js → audit-membership-runtime-DHQDvH4u.js} +2 -2
- package/dist/plugin-sdk/{channel-activity-gwxRn4wF.js → channel-activity-XajEg_DL.js} +3 -3
- package/dist/plugin-sdk/channel-activity-gPvD1D7S.js +94 -0
- package/dist/plugin-sdk/{channel-web-1WF-Nabe.js → channel-web-KtqCp4mz.js} +18 -18
- package/dist/plugin-sdk/channel-web-LGl1zPJt.js +2256 -0
- package/dist/plugin-sdk/chrome-9Y_LcUg1.js +2415 -0
- package/dist/plugin-sdk/{chrome-BXbYwXRH.js → chrome-diV5m81I.js} +6 -6
- package/dist/plugin-sdk/commands-registry-CcdEPxVg.js +1125 -0
- package/dist/plugin-sdk/{commands-registry-0w-aZenK.js → commands-registry-DwZAJuut.js} +4 -4
- package/dist/plugin-sdk/{common-DBOCt6Yv.js → common-CqnO92P8.js} +2 -2
- package/dist/plugin-sdk/config-CrQ5bCrw.js +17912 -0
- package/dist/plugin-sdk/{config-pRtEoVyZ.js → config-DYbtdrsT.js} +7 -7
- package/dist/plugin-sdk/deliver-D3xr5AkB.js +1694 -0
- package/dist/plugin-sdk/{deliver-FjlJrtZk.js → deliver-DG_7Uagn.js} +10 -10
- package/dist/plugin-sdk/deliver-runtime-B79ZQu69.js +32 -0
- package/dist/plugin-sdk/deliver-runtime-BdTC7uKE.js +32 -0
- package/dist/plugin-sdk/deps-send-discord.runtime-BOQZIqC8.js +23 -0
- package/dist/plugin-sdk/deps-send-discord.runtime-CObCNMt3.js +23 -0
- package/dist/plugin-sdk/deps-send-imessage.runtime-CuHOc9Ka.js +22 -0
- package/dist/plugin-sdk/deps-send-imessage.runtime-DlWgi2DH.js +22 -0
- package/dist/plugin-sdk/deps-send-signal.runtime-Cz7FT8J8.js +21 -0
- package/dist/plugin-sdk/deps-send-signal.runtime-iPynghkE.js +21 -0
- package/dist/plugin-sdk/deps-send-slack.runtime-D4vDoRsg.js +19 -0
- package/dist/plugin-sdk/deps-send-slack.runtime-DNTbE5jS.js +19 -0
- package/dist/plugin-sdk/deps-send-telegram.runtime-7CR-xtCF.js +24 -0
- package/dist/plugin-sdk/deps-send-telegram.runtime-DjTVED_m.js +24 -0
- package/dist/plugin-sdk/deps-send-whatsapp.runtime-CRWOIKRC.js +57 -0
- package/dist/plugin-sdk/deps-send-whatsapp.runtime-bUi8kghi.js +57 -0
- package/dist/plugin-sdk/diagnostic-BXkLYs_9.js +319 -0
- package/dist/plugin-sdk/{diagnostic-Dt2i3afe.js → diagnostic-CT7v_kM2.js} +2 -2
- package/dist/plugin-sdk/{errors-CgRPdp3o.js → errors-9oVz7reJ.js} +1 -1
- package/dist/plugin-sdk/errors-B8oJXuCF.js +54 -0
- package/dist/plugin-sdk/fetch-guard-C55uvn27.js +156 -0
- package/dist/plugin-sdk/{fetch-guard-DyPZh8r2.js → fetch-guard-Or5BCq0E.js} +2 -2
- package/dist/plugin-sdk/{fs-safe-DqCO1D4C.js → fs-safe-DFbwq9CS.js} +3 -3
- package/dist/plugin-sdk/fs-safe-Dqmpk-Fr.js +352 -0
- package/dist/plugin-sdk/image-3xW7IJdq.js +2310 -0
- package/dist/plugin-sdk/image-ops-BjK2qZZn.js +584 -0
- package/dist/plugin-sdk/{image-ops-sw0uZ0GN.js → image-ops-CMsocOob.js} +2 -2
- package/dist/plugin-sdk/image-runtime-CZZJJqcW.js +25 -0
- package/dist/plugin-sdk/image-runtime-Cjz368oj.js +25 -0
- package/dist/plugin-sdk/{image-CQ9TZ9vq.js → image-rycGCqJO.js} +6 -6
- package/dist/plugin-sdk/index.js +50 -50
- package/dist/plugin-sdk/ir-CS7uuQhN.js +1296 -0
- package/dist/plugin-sdk/{ir-BVZ5kUMb.js → ir-DihI2SIz.js} +7 -7
- package/dist/plugin-sdk/{local-roots-fO3ZgW3G.js → local-roots-1xVosTZ4.js} +4 -4
- package/dist/plugin-sdk/local-roots-DmOKwiNW.js +186 -0
- package/dist/plugin-sdk/{logger-DIb2cGHp.js → logger-Bg4vIUJn.js} +2 -2
- package/dist/plugin-sdk/logger-DDdrdbDu.js +1163 -0
- package/dist/plugin-sdk/login-BSEeU27Y.js +57 -0
- package/dist/plugin-sdk/{login-Dg5cxB_3.js → login-YhFrVUWo.js} +4 -4
- package/dist/plugin-sdk/login-qr-BwWJsDSj.js +320 -0
- package/dist/plugin-sdk/{login-qr-C3Vn30cq.js → login-qr-SpUTuwYv.js} +5 -5
- package/dist/plugin-sdk/manager-DiXPCubI.js +3917 -0
- package/dist/plugin-sdk/{manager-BR-TwWTH.js → manager-DrzOPeMD.js} +8 -8
- package/dist/plugin-sdk/manager-runtime-CF55pBNe.js +15 -0
- package/dist/plugin-sdk/manager-runtime-Ct0m9UJC.js +15 -0
- package/dist/plugin-sdk/mattermost.js +3 -3
- package/dist/plugin-sdk/{outbound-1a3Z_QJ2.js → outbound-Cc4cUn9K.js} +5 -5
- package/dist/plugin-sdk/outbound-attachment-BoFx05zw.js +19 -0
- package/dist/plugin-sdk/{outbound-attachment-BTQjD4YE.js → outbound-attachment-Dtp3hQgc.js} +2 -2
- package/dist/plugin-sdk/outbound-cpqK1GFe.js +212 -0
- package/dist/plugin-sdk/{path-alias-guards-TnxupPQC.js → path-alias-guards-DA0MhfkG.js} +1 -1
- package/dist/plugin-sdk/path-alias-guards-gBhrAn14.js +43 -0
- package/dist/plugin-sdk/paths-C6W4VHoa.js +166 -0
- package/dist/plugin-sdk/{paths-B7_75Pdr.js → paths-CP67O8eN.js} +1 -1
- package/dist/plugin-sdk/{pi-embedded-helpers-DZRNadD8.js → pi-embedded-helpers-BDJ_4Plh.js} +16 -16
- package/dist/plugin-sdk/pi-embedded-helpers-C-B9B6Sp.js +9627 -0
- package/dist/plugin-sdk/pi-model-discovery-BGEeoPzN.js +134 -0
- package/dist/plugin-sdk/{pi-model-discovery-DGh6xekX.js → pi-model-discovery-Mk0GTDJl.js} +1 -1
- package/dist/plugin-sdk/pi-model-discovery-runtime-BHZ_Htob.js +8 -0
- package/dist/plugin-sdk/pi-model-discovery-runtime-BrwtJHPU.js +8 -0
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-ByN_xThw.js +354 -0
- package/dist/plugin-sdk/{pi-tools.before-tool-call.runtime-BZ9XgG_x.js → pi-tools.before-tool-call.runtime-DV72wTDb.js} +4 -4
- package/dist/plugin-sdk/plugins-D5cdn70e.js +864 -0
- package/dist/plugin-sdk/{plugins-B8pWVYug.js → plugins-DSs2-fnK.js} +4 -4
- package/dist/plugin-sdk/{proxy-env-BOlkiW1-.js → proxy-env-Ib4-LUh-.js} +1 -1
- package/dist/plugin-sdk/{proxy-fetch-Dt5BedH8.js → proxy-fetch-Cf3IUSDw.js} +1 -1
- package/dist/plugin-sdk/proxy-fetch-ZPEvp58f.js +38 -0
- package/dist/plugin-sdk/pw-ai-C_QOIuin.js +1938 -0
- package/dist/plugin-sdk/{pw-ai-C17A1o4w.js → pw-ai-DIx2wpkY.js} +9 -9
- package/dist/plugin-sdk/qmd-manager-6bozlfFg.js +1448 -0
- package/dist/plugin-sdk/{qmd-manager-Bei6TaFq.js → qmd-manager-Ov9ElEfG.js} +7 -7
- package/dist/plugin-sdk/{query-expansion-POz2za8a.js → query-expansion-CzjwW461.js} +4 -4
- package/dist/plugin-sdk/query-expansion-eeVz_aEm.js +1011 -0
- package/dist/plugin-sdk/{redact-9WsNyb7S.js → redact-BoNEjbpF.js} +1 -1
- package/dist/plugin-sdk/redact-DfACyt0X.js +319 -0
- package/dist/plugin-sdk/reply-CQUX_haM.js +98828 -0
- package/dist/plugin-sdk/{reply-BFbijn6_.js → reply-CWWUd_JS.js} +73 -73
- package/dist/plugin-sdk/{resolve-outbound-target-B9iFEh0y.js → resolve-outbound-target-BOkvxZtM.js} +2 -2
- package/dist/plugin-sdk/resolve-outbound-target-Dbz0O8cR.js +40 -0
- package/dist/plugin-sdk/run-with-concurrency-5DMu9szx.js +1994 -0
- package/dist/plugin-sdk/{run-with-concurrency-DmTrN5JG.js → run-with-concurrency-kVooFCVo.js} +1 -1
- package/dist/plugin-sdk/runtime-whatsapp-login.runtime-DitS0I1z.js +10 -0
- package/dist/plugin-sdk/runtime-whatsapp-login.runtime-OthrtsLL.js +10 -0
- package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-CYCr6A3v.js +19 -0
- package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-Q2HL0zL3.js +19 -0
- package/dist/plugin-sdk/send-BACEu1Un.js +414 -0
- package/dist/plugin-sdk/{send-BGZo6HW1.js → send-BP1fSEBR.js} +5 -5
- package/dist/plugin-sdk/send-BU4OoR7u.js +2587 -0
- package/dist/plugin-sdk/{send-BqkUDZed.js → send-BeLBlAsQ.js} +13 -13
- package/dist/plugin-sdk/{send-BisREGBZ.js → send-D9CSOGul.js} +6 -6
- package/dist/plugin-sdk/{send-D6_nNvi0.js → send-DLKxJJYV.js} +8 -8
- package/dist/plugin-sdk/send-DbxOJ_BC.js +3135 -0
- package/dist/plugin-sdk/{send-Dj7XEcZN.js → send-XZ6IXCtL.js} +7 -7
- package/dist/plugin-sdk/send-n932vjT5.js +540 -0
- package/dist/plugin-sdk/send-uCPS53j8.js +503 -0
- package/dist/plugin-sdk/session-DenDKR_-.js +169 -0
- package/dist/plugin-sdk/{session-D4KDs7Hq.js → session-DtLUYWvY.js} +3 -3
- package/dist/plugin-sdk/skill-commands-BK1KDKmS.js +342 -0
- package/dist/plugin-sdk/{skill-commands-D_xeseiI.js → skill-commands-Bv7EZypt.js} +4 -4
- package/dist/plugin-sdk/{skills-Bs2b3JfV.js → skills-BzXN4uev.js} +6 -6
- package/dist/plugin-sdk/skills-D4am-zkO.js +1428 -0
- package/dist/plugin-sdk/slash-commands.runtime-Bx1K1iqP.js +13 -0
- package/dist/plugin-sdk/slash-commands.runtime-DWfFqMZw.js +13 -0
- package/dist/plugin-sdk/slash-dispatch.runtime-DVn338JI.js +52 -0
- package/dist/plugin-sdk/slash-dispatch.runtime-pnWH5AjM.js +52 -0
- package/dist/plugin-sdk/slash-skill-commands.runtime-Dbi_YzPO.js +16 -0
- package/dist/plugin-sdk/slash-skill-commands.runtime-DxvNWv_E.js +16 -0
- package/dist/plugin-sdk/ssrf-2WBi1Tzx.js +202 -0
- package/dist/plugin-sdk/store-BKDMuvyn.js +81 -0
- package/dist/plugin-sdk/{store-B7ESm9_L.js → store-DnJhFFW5.js} +2 -2
- package/dist/plugin-sdk/subagent-registry-runtime-FhP0l-Rw.js +52 -0
- package/dist/plugin-sdk/subagent-registry-runtime-hH9ADku1.js +52 -0
- package/dist/plugin-sdk/{tables-1vhBJPK_.js → tables-CpmqssLF.js} +1 -1
- package/dist/plugin-sdk/tables-CrDYcv_b.js +55 -0
- package/dist/plugin-sdk/target-errors-aOwE-MIU.js +195 -0
- package/dist/plugin-sdk/{thinking-DjaClmzi.js → thinking-1UCPuD9d.js} +7 -7
- package/dist/plugin-sdk/thinking-D41FMh9T.js +1206 -0
- package/dist/plugin-sdk/{tokens-CLE20fRI.js → tokens-CTIYTLWu.js} +1 -1
- package/dist/plugin-sdk/tokens-DAL_5WHL.js +52 -0
- package/dist/plugin-sdk/{tool-images-B95xcwiR.js → tool-images-CWc54lpI.js} +2 -2
- package/dist/plugin-sdk/tool-images-RX4QTMnt.js +274 -0
- package/dist/plugin-sdk/web-AtEy-48y.js +56 -0
- package/dist/plugin-sdk/web-DjKONHqF.js +56 -0
- package/dist/plugin-sdk/{whatsapp-actions-BYpcWkTN.js → whatsapp-actions-BF6ih4Gi.js} +17 -17
- package/dist/plugin-sdk/whatsapp-actions-DEZcm_CZ.js +80 -0
- package/dist/plugin-sdk/whatsapp.js +50 -50
- package/dist/{program-xNEHPhT8.js → program-2J-jgdfk.js} +2 -2
- package/dist/{program-context-J_FyEsaS.js → program-context-SjYSWx_N.js} +8 -8
- package/dist/{prompt-select-styled-B1LjjgQ0.js → prompt-select-styled-Baiu3mAU.js} +1 -1
- package/dist/{prompt-select-styled-BRiogP_P.js → prompt-select-styled-DPnVmH8f.js} +1 -1
- package/dist/{pw-ai-7kHgUGj0.js → pw-ai-BwRP3TWc.js} +1 -1
- package/dist/{pw-ai-BmGrTicP.js → pw-ai-zFPBSxaL.js} +1 -1
- package/dist/{register.configure-DezZ4Q1p.js → register.configure-Ao1K2uze.js} +1 -1
- package/dist/{register.configure-C4p9ad2q.js → register.configure-CCkfhF-7.js} +1 -1
- package/dist/{register.maintenance-CzMKTC2a.js → register.maintenance-DMbs8w2m.js} +4 -4
- package/dist/{register.maintenance-CTvFmkAm.js → register.maintenance-pLpE2oF-.js} +5 -5
- package/dist/{register.onboard-C39xhpv1.js → register.onboard-Cb8xLIye.js} +2 -2
- package/dist/{register.onboard-DZt2kSAg.js → register.onboard-IMrHOeW_.js} +2 -2
- package/dist/{register.setup-04L_8wfA.js → register.setup-CX8IUmew.js} +2 -2
- package/dist/{register.setup-DWctFmOd.js → register.setup-DU7IDzAv.js} +2 -2
- package/dist/{register.subclis-C3TphbCF.js → register.subclis-BIbL6FBV.js} +3 -3
- package/dist/{run-main-7tknx04F.js → run-main-CpDZPsC_.js} +5 -5
- package/dist/{slash-dispatch.runtime-BL3qA1O3.js → slash-dispatch.runtime-DkcAYuyK.js} +6 -6
- package/dist/{slash-dispatch.runtime-Dh2L_3Tg.js → slash-dispatch.runtime-DuJRl-LD.js} +6 -6
- package/dist/{subagent-registry-runtime-MtjBCcgn.js → subagent-registry-runtime-BlRAnw80.js} +6 -6
- package/dist/{subagent-registry-runtime-BRNDawlJ.js → subagent-registry-runtime-COygB9b1.js} +6 -6
- package/dist/{update-cli-0UiUaT3q.js → update-cli-BwhvSo1R.js} +5 -5
- package/dist/{update-cli-C-uyQcFS.js → update-cli-TQEfxhWF.js} +4 -4
- package/dist/{web-D1ZoRVB0.js → web-DddJa7ZT.js} +6 -6
- package/dist/{web-B7kbCskR.js → web-DyCuTR9b.js} +6 -6
- package/package.json +7 -7
- package/dist/plugin-sdk/deliver-runtime-DEzvpBW1.js +0 -32
- package/dist/plugin-sdk/deps-send-discord.runtime-Bhusa_Hi.js +0 -23
- package/dist/plugin-sdk/deps-send-imessage.runtime-bmakPm5f.js +0 -22
- package/dist/plugin-sdk/deps-send-signal.runtime-n00sfFto.js +0 -21
- package/dist/plugin-sdk/deps-send-slack.runtime-BvM3Z-Mr.js +0 -19
- package/dist/plugin-sdk/deps-send-telegram.runtime-CPuMkcmo.js +0 -24
- package/dist/plugin-sdk/deps-send-whatsapp.runtime-BzO6S-KX.js +0 -57
- package/dist/plugin-sdk/image-runtime-17_mTqsy.js +0 -25
- package/dist/plugin-sdk/manager-runtime-CvI9wF8N.js +0 -15
- package/dist/plugin-sdk/pi-model-discovery-runtime-DjjBdPYt.js +0 -8
- package/dist/plugin-sdk/runtime-whatsapp-login.runtime-DzhkSmLi.js +0 -10
- package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-DyILWezU.js +0 -19
- package/dist/plugin-sdk/slash-commands.runtime-CUb5sqqf.js +0 -13
- package/dist/plugin-sdk/slash-dispatch.runtime-DCB6bGjB.js +0 -52
- package/dist/plugin-sdk/slash-skill-commands.runtime-BqEweE4K.js +0 -16
- package/dist/plugin-sdk/subagent-registry-runtime-CCUW4SbM.js +0 -52
- package/dist/plugin-sdk/web-DeRmHQ4_.js +0 -56
|
@@ -0,0 +1,1011 @@
|
|
|
1
|
+
import { t as runTasksWithConcurrency } from "./run-with-concurrency-5DMu9szx.js";
|
|
2
|
+
import { a as createSubsystemLogger } from "./logger-DDdrdbDu.js";
|
|
3
|
+
import { o as resolveSessionTranscriptsDirForAgent } from "./paths-C6W4VHoa.js";
|
|
4
|
+
import { t as redactSensitiveText } from "./redact-BoNEjbpF.js";
|
|
5
|
+
import { createRequire } from "node:module";
|
|
6
|
+
import fs from "node:fs";
|
|
7
|
+
import path from "node:path";
|
|
8
|
+
import fs$1 from "node:fs/promises";
|
|
9
|
+
import crypto from "node:crypto";
|
|
10
|
+
|
|
11
|
+
//#region src/memory/fs-utils.ts
|
|
12
|
+
function isFileMissingError(err) {
|
|
13
|
+
return Boolean(err && typeof err === "object" && "code" in err && err.code === "ENOENT");
|
|
14
|
+
}
|
|
15
|
+
async function statRegularFile(absPath) {
|
|
16
|
+
let stat;
|
|
17
|
+
try {
|
|
18
|
+
stat = await fs$1.lstat(absPath);
|
|
19
|
+
} catch (err) {
|
|
20
|
+
if (isFileMissingError(err)) return { missing: true };
|
|
21
|
+
throw err;
|
|
22
|
+
}
|
|
23
|
+
if (stat.isSymbolicLink() || !stat.isFile()) throw new Error("path required");
|
|
24
|
+
return {
|
|
25
|
+
missing: false,
|
|
26
|
+
stat
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
//#endregion
|
|
31
|
+
//#region src/memory/internal.ts
|
|
32
|
+
function ensureDir(dir) {
|
|
33
|
+
try {
|
|
34
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
35
|
+
} catch {}
|
|
36
|
+
return dir;
|
|
37
|
+
}
|
|
38
|
+
function normalizeRelPath(value) {
|
|
39
|
+
return value.trim().replace(/^[./]+/, "").replace(/\\/g, "/");
|
|
40
|
+
}
|
|
41
|
+
function normalizeExtraMemoryPaths(workspaceDir, extraPaths) {
|
|
42
|
+
if (!extraPaths?.length) return [];
|
|
43
|
+
const resolved = extraPaths.map((value) => value.trim()).filter(Boolean).map((value) => path.isAbsolute(value) ? path.resolve(value) : path.resolve(workspaceDir, value));
|
|
44
|
+
return Array.from(new Set(resolved));
|
|
45
|
+
}
|
|
46
|
+
function isMemoryPath(relPath) {
|
|
47
|
+
const normalized = normalizeRelPath(relPath);
|
|
48
|
+
if (!normalized) return false;
|
|
49
|
+
if (normalized === "MEMORY.md" || normalized === "memory.md") return true;
|
|
50
|
+
return normalized.startsWith("memory/");
|
|
51
|
+
}
|
|
52
|
+
async function walkDir(dir, files) {
|
|
53
|
+
const entries = await fs$1.readdir(dir, { withFileTypes: true });
|
|
54
|
+
for (const entry of entries) {
|
|
55
|
+
const full = path.join(dir, entry.name);
|
|
56
|
+
if (entry.isSymbolicLink()) continue;
|
|
57
|
+
if (entry.isDirectory()) {
|
|
58
|
+
await walkDir(full, files);
|
|
59
|
+
continue;
|
|
60
|
+
}
|
|
61
|
+
if (!entry.isFile()) continue;
|
|
62
|
+
if (!entry.name.endsWith(".md")) continue;
|
|
63
|
+
files.push(full);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
async function listMemoryFiles(workspaceDir, extraPaths) {
|
|
67
|
+
const result = [];
|
|
68
|
+
const memoryFile = path.join(workspaceDir, "MEMORY.md");
|
|
69
|
+
const altMemoryFile = path.join(workspaceDir, "memory.md");
|
|
70
|
+
const memoryDir = path.join(workspaceDir, "memory");
|
|
71
|
+
const addMarkdownFile = async (absPath) => {
|
|
72
|
+
try {
|
|
73
|
+
const stat = await fs$1.lstat(absPath);
|
|
74
|
+
if (stat.isSymbolicLink() || !stat.isFile()) return;
|
|
75
|
+
if (!absPath.endsWith(".md")) return;
|
|
76
|
+
result.push(absPath);
|
|
77
|
+
} catch {}
|
|
78
|
+
};
|
|
79
|
+
await addMarkdownFile(memoryFile);
|
|
80
|
+
await addMarkdownFile(altMemoryFile);
|
|
81
|
+
try {
|
|
82
|
+
const dirStat = await fs$1.lstat(memoryDir);
|
|
83
|
+
if (!dirStat.isSymbolicLink() && dirStat.isDirectory()) await walkDir(memoryDir, result);
|
|
84
|
+
} catch {}
|
|
85
|
+
const normalizedExtraPaths = normalizeExtraMemoryPaths(workspaceDir, extraPaths);
|
|
86
|
+
if (normalizedExtraPaths.length > 0) for (const inputPath of normalizedExtraPaths) try {
|
|
87
|
+
const stat = await fs$1.lstat(inputPath);
|
|
88
|
+
if (stat.isSymbolicLink()) continue;
|
|
89
|
+
if (stat.isDirectory()) {
|
|
90
|
+
await walkDir(inputPath, result);
|
|
91
|
+
continue;
|
|
92
|
+
}
|
|
93
|
+
if (stat.isFile() && inputPath.endsWith(".md")) result.push(inputPath);
|
|
94
|
+
} catch {}
|
|
95
|
+
if (result.length <= 1) return result;
|
|
96
|
+
const seen = /* @__PURE__ */ new Set();
|
|
97
|
+
const deduped = [];
|
|
98
|
+
for (const entry of result) {
|
|
99
|
+
let key = entry;
|
|
100
|
+
try {
|
|
101
|
+
key = await fs$1.realpath(entry);
|
|
102
|
+
} catch {}
|
|
103
|
+
if (seen.has(key)) continue;
|
|
104
|
+
seen.add(key);
|
|
105
|
+
deduped.push(entry);
|
|
106
|
+
}
|
|
107
|
+
return deduped;
|
|
108
|
+
}
|
|
109
|
+
function hashText(value) {
|
|
110
|
+
return crypto.createHash("sha256").update(value).digest("hex");
|
|
111
|
+
}
|
|
112
|
+
async function buildFileEntry(absPath, workspaceDir) {
|
|
113
|
+
let stat;
|
|
114
|
+
try {
|
|
115
|
+
stat = await fs$1.stat(absPath);
|
|
116
|
+
} catch (err) {
|
|
117
|
+
if (isFileMissingError(err)) return null;
|
|
118
|
+
throw err;
|
|
119
|
+
}
|
|
120
|
+
let content;
|
|
121
|
+
try {
|
|
122
|
+
content = await fs$1.readFile(absPath, "utf-8");
|
|
123
|
+
} catch (err) {
|
|
124
|
+
if (isFileMissingError(err)) return null;
|
|
125
|
+
throw err;
|
|
126
|
+
}
|
|
127
|
+
const hash = hashText(content);
|
|
128
|
+
return {
|
|
129
|
+
path: path.relative(workspaceDir, absPath).replace(/\\/g, "/"),
|
|
130
|
+
absPath,
|
|
131
|
+
mtimeMs: stat.mtimeMs,
|
|
132
|
+
size: stat.size,
|
|
133
|
+
hash
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
function chunkMarkdown(content, chunking) {
|
|
137
|
+
const lines = content.split("\n");
|
|
138
|
+
if (lines.length === 0) return [];
|
|
139
|
+
const maxChars = Math.max(32, chunking.tokens * 4);
|
|
140
|
+
const overlapChars = Math.max(0, chunking.overlap * 4);
|
|
141
|
+
const chunks = [];
|
|
142
|
+
let current = [];
|
|
143
|
+
let currentChars = 0;
|
|
144
|
+
const flush = () => {
|
|
145
|
+
if (current.length === 0) return;
|
|
146
|
+
const firstEntry = current[0];
|
|
147
|
+
const lastEntry = current[current.length - 1];
|
|
148
|
+
if (!firstEntry || !lastEntry) return;
|
|
149
|
+
const text = current.map((entry) => entry.line).join("\n");
|
|
150
|
+
const startLine = firstEntry.lineNo;
|
|
151
|
+
const endLine = lastEntry.lineNo;
|
|
152
|
+
chunks.push({
|
|
153
|
+
startLine,
|
|
154
|
+
endLine,
|
|
155
|
+
text,
|
|
156
|
+
hash: hashText(text)
|
|
157
|
+
});
|
|
158
|
+
};
|
|
159
|
+
const carryOverlap = () => {
|
|
160
|
+
if (overlapChars <= 0 || current.length === 0) {
|
|
161
|
+
current = [];
|
|
162
|
+
currentChars = 0;
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
let acc = 0;
|
|
166
|
+
const kept = [];
|
|
167
|
+
for (let i = current.length - 1; i >= 0; i -= 1) {
|
|
168
|
+
const entry = current[i];
|
|
169
|
+
if (!entry) continue;
|
|
170
|
+
acc += entry.line.length + 1;
|
|
171
|
+
kept.unshift(entry);
|
|
172
|
+
if (acc >= overlapChars) break;
|
|
173
|
+
}
|
|
174
|
+
current = kept;
|
|
175
|
+
currentChars = kept.reduce((sum, entry) => sum + entry.line.length + 1, 0);
|
|
176
|
+
};
|
|
177
|
+
for (let i = 0; i < lines.length; i += 1) {
|
|
178
|
+
const line = lines[i] ?? "";
|
|
179
|
+
const lineNo = i + 1;
|
|
180
|
+
const segments = [];
|
|
181
|
+
if (line.length === 0) segments.push("");
|
|
182
|
+
else for (let start = 0; start < line.length; start += maxChars) segments.push(line.slice(start, start + maxChars));
|
|
183
|
+
for (const segment of segments) {
|
|
184
|
+
const lineSize = segment.length + 1;
|
|
185
|
+
if (currentChars + lineSize > maxChars && current.length > 0) {
|
|
186
|
+
flush();
|
|
187
|
+
carryOverlap();
|
|
188
|
+
}
|
|
189
|
+
current.push({
|
|
190
|
+
line: segment,
|
|
191
|
+
lineNo
|
|
192
|
+
});
|
|
193
|
+
currentChars += lineSize;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
flush();
|
|
197
|
+
return chunks;
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Remap chunk startLine/endLine from content-relative positions to original
|
|
201
|
+
* source file positions using a lineMap. Each entry in lineMap gives the
|
|
202
|
+
* 1-indexed source line for the corresponding 0-indexed content line.
|
|
203
|
+
*
|
|
204
|
+
* This is used for session JSONL files where buildSessionEntry() flattens
|
|
205
|
+
* messages into a plain-text string before chunking. Without remapping the
|
|
206
|
+
* stored line numbers would reference positions in the flattened text rather
|
|
207
|
+
* than the original JSONL file.
|
|
208
|
+
*/
|
|
209
|
+
function remapChunkLines(chunks, lineMap) {
|
|
210
|
+
if (!lineMap || lineMap.length === 0) return;
|
|
211
|
+
for (const chunk of chunks) {
|
|
212
|
+
chunk.startLine = lineMap[chunk.startLine - 1] ?? chunk.startLine;
|
|
213
|
+
chunk.endLine = lineMap[chunk.endLine - 1] ?? chunk.endLine;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
function parseEmbedding(raw) {
|
|
217
|
+
try {
|
|
218
|
+
const parsed = JSON.parse(raw);
|
|
219
|
+
return Array.isArray(parsed) ? parsed : [];
|
|
220
|
+
} catch {
|
|
221
|
+
return [];
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
function cosineSimilarity(a, b) {
|
|
225
|
+
if (a.length === 0 || b.length === 0) return 0;
|
|
226
|
+
const len = Math.min(a.length, b.length);
|
|
227
|
+
let dot = 0;
|
|
228
|
+
let normA = 0;
|
|
229
|
+
let normB = 0;
|
|
230
|
+
for (let i = 0; i < len; i += 1) {
|
|
231
|
+
const av = a[i] ?? 0;
|
|
232
|
+
const bv = b[i] ?? 0;
|
|
233
|
+
dot += av * bv;
|
|
234
|
+
normA += av * av;
|
|
235
|
+
normB += bv * bv;
|
|
236
|
+
}
|
|
237
|
+
if (normA === 0 || normB === 0) return 0;
|
|
238
|
+
return dot / (Math.sqrt(normA) * Math.sqrt(normB));
|
|
239
|
+
}
|
|
240
|
+
async function runWithConcurrency(tasks, limit) {
|
|
241
|
+
const { results, firstError, hasError } = await runTasksWithConcurrency({
|
|
242
|
+
tasks,
|
|
243
|
+
limit,
|
|
244
|
+
errorMode: "stop"
|
|
245
|
+
});
|
|
246
|
+
if (hasError) throw firstError;
|
|
247
|
+
return results;
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
//#endregion
|
|
251
|
+
//#region src/memory/session-files.ts
|
|
252
|
+
const log = createSubsystemLogger("memory");
|
|
253
|
+
async function listSessionFilesForAgent(agentId) {
|
|
254
|
+
const dir = resolveSessionTranscriptsDirForAgent(agentId);
|
|
255
|
+
try {
|
|
256
|
+
return (await fs$1.readdir(dir, { withFileTypes: true })).filter((entry) => entry.isFile()).map((entry) => entry.name).filter((name) => name.endsWith(".jsonl")).map((name) => path.join(dir, name));
|
|
257
|
+
} catch {
|
|
258
|
+
return [];
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
function sessionPathForFile(absPath) {
|
|
262
|
+
return path.join("sessions", path.basename(absPath)).replace(/\\/g, "/");
|
|
263
|
+
}
|
|
264
|
+
function normalizeSessionText(value) {
|
|
265
|
+
return value.replace(/\s*\n+\s*/g, " ").replace(/\s+/g, " ").trim();
|
|
266
|
+
}
|
|
267
|
+
function extractSessionText(content) {
|
|
268
|
+
if (typeof content === "string") {
|
|
269
|
+
const normalized = normalizeSessionText(content);
|
|
270
|
+
return normalized ? normalized : null;
|
|
271
|
+
}
|
|
272
|
+
if (!Array.isArray(content)) return null;
|
|
273
|
+
const parts = [];
|
|
274
|
+
for (const block of content) {
|
|
275
|
+
if (!block || typeof block !== "object") continue;
|
|
276
|
+
const record = block;
|
|
277
|
+
if (record.type !== "text" || typeof record.text !== "string") continue;
|
|
278
|
+
const normalized = normalizeSessionText(record.text);
|
|
279
|
+
if (normalized) parts.push(normalized);
|
|
280
|
+
}
|
|
281
|
+
if (parts.length === 0) return null;
|
|
282
|
+
return parts.join(" ");
|
|
283
|
+
}
|
|
284
|
+
async function buildSessionEntry(absPath) {
|
|
285
|
+
try {
|
|
286
|
+
const stat = await fs$1.stat(absPath);
|
|
287
|
+
const lines = (await fs$1.readFile(absPath, "utf-8")).split("\n");
|
|
288
|
+
const collected = [];
|
|
289
|
+
const lineMap = [];
|
|
290
|
+
for (let jsonlIdx = 0; jsonlIdx < lines.length; jsonlIdx++) {
|
|
291
|
+
const line = lines[jsonlIdx];
|
|
292
|
+
if (!line.trim()) continue;
|
|
293
|
+
let record;
|
|
294
|
+
try {
|
|
295
|
+
record = JSON.parse(line);
|
|
296
|
+
} catch {
|
|
297
|
+
continue;
|
|
298
|
+
}
|
|
299
|
+
if (!record || typeof record !== "object" || record.type !== "message") continue;
|
|
300
|
+
const message = record.message;
|
|
301
|
+
if (!message || typeof message.role !== "string") continue;
|
|
302
|
+
if (message.role !== "user" && message.role !== "assistant") continue;
|
|
303
|
+
const text = extractSessionText(message.content);
|
|
304
|
+
if (!text) continue;
|
|
305
|
+
const safe = redactSensitiveText(text, { mode: "tools" });
|
|
306
|
+
const label = message.role === "user" ? "User" : "Assistant";
|
|
307
|
+
collected.push(`${label}: ${safe}`);
|
|
308
|
+
lineMap.push(jsonlIdx + 1);
|
|
309
|
+
}
|
|
310
|
+
const content = collected.join("\n");
|
|
311
|
+
return {
|
|
312
|
+
path: sessionPathForFile(absPath),
|
|
313
|
+
absPath,
|
|
314
|
+
mtimeMs: stat.mtimeMs,
|
|
315
|
+
size: stat.size,
|
|
316
|
+
hash: hashText(content + "\n" + lineMap.join(",")),
|
|
317
|
+
content,
|
|
318
|
+
lineMap
|
|
319
|
+
};
|
|
320
|
+
} catch (err) {
|
|
321
|
+
log.debug(`Failed reading session file ${absPath}: ${String(err)}`);
|
|
322
|
+
return null;
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
//#endregion
|
|
327
|
+
//#region src/infra/warning-filter.ts
|
|
328
|
+
const warningFilterKey = Symbol.for("squidclaw.warning-filter");
|
|
329
|
+
function shouldIgnoreWarning(warning) {
|
|
330
|
+
if (warning.code === "DEP0040" && warning.message?.includes("punycode")) return true;
|
|
331
|
+
if (warning.code === "DEP0060" && warning.message?.includes("util._extend")) return true;
|
|
332
|
+
if (warning.name === "ExperimentalWarning" && warning.message?.includes("SQLite is an experimental feature")) return true;
|
|
333
|
+
return false;
|
|
334
|
+
}
|
|
335
|
+
function normalizeWarningArgs(args) {
|
|
336
|
+
const warningArg = args[0];
|
|
337
|
+
const secondArg = args[1];
|
|
338
|
+
const thirdArg = args[2];
|
|
339
|
+
let name;
|
|
340
|
+
let code;
|
|
341
|
+
let message;
|
|
342
|
+
if (warningArg instanceof Error) {
|
|
343
|
+
name = warningArg.name;
|
|
344
|
+
message = warningArg.message;
|
|
345
|
+
code = warningArg.code;
|
|
346
|
+
} else if (typeof warningArg === "string") message = warningArg;
|
|
347
|
+
if (secondArg && typeof secondArg === "object" && !Array.isArray(secondArg)) {
|
|
348
|
+
const options = secondArg;
|
|
349
|
+
if (typeof options.type === "string") name = options.type;
|
|
350
|
+
if (typeof options.code === "string") code = options.code;
|
|
351
|
+
} else {
|
|
352
|
+
if (typeof secondArg === "string") name = secondArg;
|
|
353
|
+
if (typeof thirdArg === "string") code = thirdArg;
|
|
354
|
+
}
|
|
355
|
+
return {
|
|
356
|
+
name,
|
|
357
|
+
code,
|
|
358
|
+
message
|
|
359
|
+
};
|
|
360
|
+
}
|
|
361
|
+
function installProcessWarningFilter() {
|
|
362
|
+
const globalState = globalThis;
|
|
363
|
+
if (globalState[warningFilterKey]?.installed) return;
|
|
364
|
+
const originalEmitWarning = process.emitWarning.bind(process);
|
|
365
|
+
const wrappedEmitWarning = ((...args) => {
|
|
366
|
+
if (shouldIgnoreWarning(normalizeWarningArgs(args))) return;
|
|
367
|
+
return Reflect.apply(originalEmitWarning, process, args);
|
|
368
|
+
});
|
|
369
|
+
process.emitWarning = wrappedEmitWarning;
|
|
370
|
+
globalState[warningFilterKey] = { installed: true };
|
|
371
|
+
}
|
|
372
|
+
|
|
373
|
+
//#endregion
|
|
374
|
+
//#region src/memory/sqlite.ts
|
|
375
|
+
const require = createRequire(import.meta.url);
|
|
376
|
+
function requireNodeSqlite() {
|
|
377
|
+
installProcessWarningFilter();
|
|
378
|
+
try {
|
|
379
|
+
return require("node:sqlite");
|
|
380
|
+
} catch (err) {
|
|
381
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
382
|
+
throw new Error(`SQLite support is unavailable in this Node runtime (missing node:sqlite). ${message}`, { cause: err });
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
|
|
386
|
+
//#endregion
|
|
387
|
+
//#region src/memory/query-expansion.ts
|
|
388
|
+
/**
|
|
389
|
+
* Query expansion for FTS-only search mode.
|
|
390
|
+
*
|
|
391
|
+
* When no embedding provider is available, we fall back to FTS (full-text search).
|
|
392
|
+
* FTS works best with specific keywords, but users often ask conversational queries
|
|
393
|
+
* like "that thing we discussed yesterday" or "之前讨论的那个方案".
|
|
394
|
+
*
|
|
395
|
+
* This module extracts meaningful keywords from such queries to improve FTS results.
|
|
396
|
+
*/
|
|
397
|
+
const STOP_WORDS_EN = new Set([
|
|
398
|
+
"a",
|
|
399
|
+
"an",
|
|
400
|
+
"the",
|
|
401
|
+
"this",
|
|
402
|
+
"that",
|
|
403
|
+
"these",
|
|
404
|
+
"those",
|
|
405
|
+
"i",
|
|
406
|
+
"me",
|
|
407
|
+
"my",
|
|
408
|
+
"we",
|
|
409
|
+
"our",
|
|
410
|
+
"you",
|
|
411
|
+
"your",
|
|
412
|
+
"he",
|
|
413
|
+
"she",
|
|
414
|
+
"it",
|
|
415
|
+
"they",
|
|
416
|
+
"them",
|
|
417
|
+
"is",
|
|
418
|
+
"are",
|
|
419
|
+
"was",
|
|
420
|
+
"were",
|
|
421
|
+
"be",
|
|
422
|
+
"been",
|
|
423
|
+
"being",
|
|
424
|
+
"have",
|
|
425
|
+
"has",
|
|
426
|
+
"had",
|
|
427
|
+
"do",
|
|
428
|
+
"does",
|
|
429
|
+
"did",
|
|
430
|
+
"will",
|
|
431
|
+
"would",
|
|
432
|
+
"could",
|
|
433
|
+
"should",
|
|
434
|
+
"can",
|
|
435
|
+
"may",
|
|
436
|
+
"might",
|
|
437
|
+
"in",
|
|
438
|
+
"on",
|
|
439
|
+
"at",
|
|
440
|
+
"to",
|
|
441
|
+
"for",
|
|
442
|
+
"of",
|
|
443
|
+
"with",
|
|
444
|
+
"by",
|
|
445
|
+
"from",
|
|
446
|
+
"about",
|
|
447
|
+
"into",
|
|
448
|
+
"through",
|
|
449
|
+
"during",
|
|
450
|
+
"before",
|
|
451
|
+
"after",
|
|
452
|
+
"above",
|
|
453
|
+
"below",
|
|
454
|
+
"between",
|
|
455
|
+
"under",
|
|
456
|
+
"over",
|
|
457
|
+
"and",
|
|
458
|
+
"or",
|
|
459
|
+
"but",
|
|
460
|
+
"if",
|
|
461
|
+
"then",
|
|
462
|
+
"because",
|
|
463
|
+
"as",
|
|
464
|
+
"while",
|
|
465
|
+
"when",
|
|
466
|
+
"where",
|
|
467
|
+
"what",
|
|
468
|
+
"which",
|
|
469
|
+
"who",
|
|
470
|
+
"how",
|
|
471
|
+
"why",
|
|
472
|
+
"yesterday",
|
|
473
|
+
"today",
|
|
474
|
+
"tomorrow",
|
|
475
|
+
"earlier",
|
|
476
|
+
"later",
|
|
477
|
+
"recently",
|
|
478
|
+
"before",
|
|
479
|
+
"ago",
|
|
480
|
+
"just",
|
|
481
|
+
"now",
|
|
482
|
+
"thing",
|
|
483
|
+
"things",
|
|
484
|
+
"stuff",
|
|
485
|
+
"something",
|
|
486
|
+
"anything",
|
|
487
|
+
"everything",
|
|
488
|
+
"nothing",
|
|
489
|
+
"please",
|
|
490
|
+
"help",
|
|
491
|
+
"find",
|
|
492
|
+
"show",
|
|
493
|
+
"get",
|
|
494
|
+
"tell",
|
|
495
|
+
"give"
|
|
496
|
+
]);
|
|
497
|
+
const STOP_WORDS_ES = new Set([
|
|
498
|
+
"el",
|
|
499
|
+
"la",
|
|
500
|
+
"los",
|
|
501
|
+
"las",
|
|
502
|
+
"un",
|
|
503
|
+
"una",
|
|
504
|
+
"unos",
|
|
505
|
+
"unas",
|
|
506
|
+
"este",
|
|
507
|
+
"esta",
|
|
508
|
+
"ese",
|
|
509
|
+
"esa",
|
|
510
|
+
"yo",
|
|
511
|
+
"me",
|
|
512
|
+
"mi",
|
|
513
|
+
"nosotros",
|
|
514
|
+
"nosotras",
|
|
515
|
+
"tu",
|
|
516
|
+
"tus",
|
|
517
|
+
"usted",
|
|
518
|
+
"ustedes",
|
|
519
|
+
"ellos",
|
|
520
|
+
"ellas",
|
|
521
|
+
"de",
|
|
522
|
+
"del",
|
|
523
|
+
"a",
|
|
524
|
+
"en",
|
|
525
|
+
"con",
|
|
526
|
+
"por",
|
|
527
|
+
"para",
|
|
528
|
+
"sobre",
|
|
529
|
+
"entre",
|
|
530
|
+
"y",
|
|
531
|
+
"o",
|
|
532
|
+
"pero",
|
|
533
|
+
"si",
|
|
534
|
+
"porque",
|
|
535
|
+
"como",
|
|
536
|
+
"es",
|
|
537
|
+
"son",
|
|
538
|
+
"fue",
|
|
539
|
+
"fueron",
|
|
540
|
+
"ser",
|
|
541
|
+
"estar",
|
|
542
|
+
"haber",
|
|
543
|
+
"tener",
|
|
544
|
+
"hacer",
|
|
545
|
+
"ayer",
|
|
546
|
+
"hoy",
|
|
547
|
+
"mañana",
|
|
548
|
+
"antes",
|
|
549
|
+
"despues",
|
|
550
|
+
"después",
|
|
551
|
+
"ahora",
|
|
552
|
+
"recientemente",
|
|
553
|
+
"que",
|
|
554
|
+
"qué",
|
|
555
|
+
"cómo",
|
|
556
|
+
"cuando",
|
|
557
|
+
"cuándo",
|
|
558
|
+
"donde",
|
|
559
|
+
"dónde",
|
|
560
|
+
"porqué",
|
|
561
|
+
"favor",
|
|
562
|
+
"ayuda"
|
|
563
|
+
]);
|
|
564
|
+
const STOP_WORDS_PT = new Set([
|
|
565
|
+
"o",
|
|
566
|
+
"a",
|
|
567
|
+
"os",
|
|
568
|
+
"as",
|
|
569
|
+
"um",
|
|
570
|
+
"uma",
|
|
571
|
+
"uns",
|
|
572
|
+
"umas",
|
|
573
|
+
"este",
|
|
574
|
+
"esta",
|
|
575
|
+
"esse",
|
|
576
|
+
"essa",
|
|
577
|
+
"eu",
|
|
578
|
+
"me",
|
|
579
|
+
"meu",
|
|
580
|
+
"minha",
|
|
581
|
+
"nos",
|
|
582
|
+
"nós",
|
|
583
|
+
"você",
|
|
584
|
+
"vocês",
|
|
585
|
+
"ele",
|
|
586
|
+
"ela",
|
|
587
|
+
"eles",
|
|
588
|
+
"elas",
|
|
589
|
+
"de",
|
|
590
|
+
"do",
|
|
591
|
+
"da",
|
|
592
|
+
"em",
|
|
593
|
+
"com",
|
|
594
|
+
"por",
|
|
595
|
+
"para",
|
|
596
|
+
"sobre",
|
|
597
|
+
"entre",
|
|
598
|
+
"e",
|
|
599
|
+
"ou",
|
|
600
|
+
"mas",
|
|
601
|
+
"se",
|
|
602
|
+
"porque",
|
|
603
|
+
"como",
|
|
604
|
+
"é",
|
|
605
|
+
"são",
|
|
606
|
+
"foi",
|
|
607
|
+
"foram",
|
|
608
|
+
"ser",
|
|
609
|
+
"estar",
|
|
610
|
+
"ter",
|
|
611
|
+
"fazer",
|
|
612
|
+
"ontem",
|
|
613
|
+
"hoje",
|
|
614
|
+
"amanhã",
|
|
615
|
+
"antes",
|
|
616
|
+
"depois",
|
|
617
|
+
"agora",
|
|
618
|
+
"recentemente",
|
|
619
|
+
"que",
|
|
620
|
+
"quê",
|
|
621
|
+
"quando",
|
|
622
|
+
"onde",
|
|
623
|
+
"porquê",
|
|
624
|
+
"favor",
|
|
625
|
+
"ajuda"
|
|
626
|
+
]);
|
|
627
|
+
const STOP_WORDS_AR = new Set([
|
|
628
|
+
"ال",
|
|
629
|
+
"و",
|
|
630
|
+
"أو",
|
|
631
|
+
"لكن",
|
|
632
|
+
"ثم",
|
|
633
|
+
"بل",
|
|
634
|
+
"أنا",
|
|
635
|
+
"نحن",
|
|
636
|
+
"هو",
|
|
637
|
+
"هي",
|
|
638
|
+
"هم",
|
|
639
|
+
"هذا",
|
|
640
|
+
"هذه",
|
|
641
|
+
"ذلك",
|
|
642
|
+
"تلك",
|
|
643
|
+
"هنا",
|
|
644
|
+
"هناك",
|
|
645
|
+
"من",
|
|
646
|
+
"إلى",
|
|
647
|
+
"الى",
|
|
648
|
+
"في",
|
|
649
|
+
"على",
|
|
650
|
+
"عن",
|
|
651
|
+
"مع",
|
|
652
|
+
"بين",
|
|
653
|
+
"ل",
|
|
654
|
+
"ب",
|
|
655
|
+
"ك",
|
|
656
|
+
"كان",
|
|
657
|
+
"كانت",
|
|
658
|
+
"يكون",
|
|
659
|
+
"تكون",
|
|
660
|
+
"صار",
|
|
661
|
+
"أصبح",
|
|
662
|
+
"يمكن",
|
|
663
|
+
"ممكن",
|
|
664
|
+
"بالأمس",
|
|
665
|
+
"امس",
|
|
666
|
+
"اليوم",
|
|
667
|
+
"غدا",
|
|
668
|
+
"الآن",
|
|
669
|
+
"قبل",
|
|
670
|
+
"بعد",
|
|
671
|
+
"مؤخرا",
|
|
672
|
+
"لماذا",
|
|
673
|
+
"كيف",
|
|
674
|
+
"ماذا",
|
|
675
|
+
"متى",
|
|
676
|
+
"أين",
|
|
677
|
+
"هل",
|
|
678
|
+
"من فضلك",
|
|
679
|
+
"فضلا",
|
|
680
|
+
"ساعد"
|
|
681
|
+
]);
|
|
682
|
+
const STOP_WORDS_KO = new Set([
|
|
683
|
+
"은",
|
|
684
|
+
"는",
|
|
685
|
+
"이",
|
|
686
|
+
"가",
|
|
687
|
+
"을",
|
|
688
|
+
"를",
|
|
689
|
+
"의",
|
|
690
|
+
"에",
|
|
691
|
+
"에서",
|
|
692
|
+
"로",
|
|
693
|
+
"으로",
|
|
694
|
+
"와",
|
|
695
|
+
"과",
|
|
696
|
+
"도",
|
|
697
|
+
"만",
|
|
698
|
+
"까지",
|
|
699
|
+
"부터",
|
|
700
|
+
"한테",
|
|
701
|
+
"에게",
|
|
702
|
+
"께",
|
|
703
|
+
"처럼",
|
|
704
|
+
"같이",
|
|
705
|
+
"보다",
|
|
706
|
+
"마다",
|
|
707
|
+
"밖에",
|
|
708
|
+
"대로",
|
|
709
|
+
"나",
|
|
710
|
+
"나는",
|
|
711
|
+
"내가",
|
|
712
|
+
"나를",
|
|
713
|
+
"너",
|
|
714
|
+
"우리",
|
|
715
|
+
"저",
|
|
716
|
+
"저희",
|
|
717
|
+
"그",
|
|
718
|
+
"그녀",
|
|
719
|
+
"그들",
|
|
720
|
+
"이것",
|
|
721
|
+
"저것",
|
|
722
|
+
"그것",
|
|
723
|
+
"여기",
|
|
724
|
+
"저기",
|
|
725
|
+
"거기",
|
|
726
|
+
"있다",
|
|
727
|
+
"없다",
|
|
728
|
+
"하다",
|
|
729
|
+
"되다",
|
|
730
|
+
"이다",
|
|
731
|
+
"아니다",
|
|
732
|
+
"보다",
|
|
733
|
+
"주다",
|
|
734
|
+
"오다",
|
|
735
|
+
"가다",
|
|
736
|
+
"것",
|
|
737
|
+
"거",
|
|
738
|
+
"등",
|
|
739
|
+
"수",
|
|
740
|
+
"때",
|
|
741
|
+
"곳",
|
|
742
|
+
"중",
|
|
743
|
+
"분",
|
|
744
|
+
"잘",
|
|
745
|
+
"더",
|
|
746
|
+
"또",
|
|
747
|
+
"매우",
|
|
748
|
+
"정말",
|
|
749
|
+
"아주",
|
|
750
|
+
"많이",
|
|
751
|
+
"너무",
|
|
752
|
+
"좀",
|
|
753
|
+
"그리고",
|
|
754
|
+
"하지만",
|
|
755
|
+
"그래서",
|
|
756
|
+
"그런데",
|
|
757
|
+
"그러나",
|
|
758
|
+
"또는",
|
|
759
|
+
"그러면",
|
|
760
|
+
"왜",
|
|
761
|
+
"어떻게",
|
|
762
|
+
"뭐",
|
|
763
|
+
"언제",
|
|
764
|
+
"어디",
|
|
765
|
+
"누구",
|
|
766
|
+
"무엇",
|
|
767
|
+
"어떤",
|
|
768
|
+
"어제",
|
|
769
|
+
"오늘",
|
|
770
|
+
"내일",
|
|
771
|
+
"최근",
|
|
772
|
+
"지금",
|
|
773
|
+
"아까",
|
|
774
|
+
"나중",
|
|
775
|
+
"전에",
|
|
776
|
+
"제발",
|
|
777
|
+
"부탁"
|
|
778
|
+
]);
|
|
779
|
+
const KO_TRAILING_PARTICLES = [
|
|
780
|
+
"에서",
|
|
781
|
+
"으로",
|
|
782
|
+
"에게",
|
|
783
|
+
"한테",
|
|
784
|
+
"처럼",
|
|
785
|
+
"같이",
|
|
786
|
+
"보다",
|
|
787
|
+
"까지",
|
|
788
|
+
"부터",
|
|
789
|
+
"마다",
|
|
790
|
+
"밖에",
|
|
791
|
+
"대로",
|
|
792
|
+
"은",
|
|
793
|
+
"는",
|
|
794
|
+
"이",
|
|
795
|
+
"가",
|
|
796
|
+
"을",
|
|
797
|
+
"를",
|
|
798
|
+
"의",
|
|
799
|
+
"에",
|
|
800
|
+
"로",
|
|
801
|
+
"와",
|
|
802
|
+
"과",
|
|
803
|
+
"도",
|
|
804
|
+
"만"
|
|
805
|
+
].toSorted((a, b) => b.length - a.length);
|
|
806
|
+
function stripKoreanTrailingParticle(token) {
|
|
807
|
+
for (const particle of KO_TRAILING_PARTICLES) if (token.length > particle.length && token.endsWith(particle)) return token.slice(0, -particle.length);
|
|
808
|
+
return null;
|
|
809
|
+
}
|
|
810
|
+
function isUsefulKoreanStem(stem) {
|
|
811
|
+
if (/[\uac00-\ud7af]/.test(stem)) return stem.length >= 2;
|
|
812
|
+
return /^[a-z0-9_]+$/i.test(stem);
|
|
813
|
+
}
|
|
814
|
+
const STOP_WORDS_JA = new Set([
|
|
815
|
+
"これ",
|
|
816
|
+
"それ",
|
|
817
|
+
"あれ",
|
|
818
|
+
"この",
|
|
819
|
+
"その",
|
|
820
|
+
"あの",
|
|
821
|
+
"ここ",
|
|
822
|
+
"そこ",
|
|
823
|
+
"あそこ",
|
|
824
|
+
"する",
|
|
825
|
+
"した",
|
|
826
|
+
"して",
|
|
827
|
+
"です",
|
|
828
|
+
"ます",
|
|
829
|
+
"いる",
|
|
830
|
+
"ある",
|
|
831
|
+
"なる",
|
|
832
|
+
"できる",
|
|
833
|
+
"の",
|
|
834
|
+
"こと",
|
|
835
|
+
"もの",
|
|
836
|
+
"ため",
|
|
837
|
+
"そして",
|
|
838
|
+
"しかし",
|
|
839
|
+
"また",
|
|
840
|
+
"でも",
|
|
841
|
+
"から",
|
|
842
|
+
"まで",
|
|
843
|
+
"より",
|
|
844
|
+
"だけ",
|
|
845
|
+
"なぜ",
|
|
846
|
+
"どう",
|
|
847
|
+
"何",
|
|
848
|
+
"いつ",
|
|
849
|
+
"どこ",
|
|
850
|
+
"誰",
|
|
851
|
+
"どれ",
|
|
852
|
+
"昨日",
|
|
853
|
+
"今日",
|
|
854
|
+
"明日",
|
|
855
|
+
"最近",
|
|
856
|
+
"今",
|
|
857
|
+
"さっき",
|
|
858
|
+
"前",
|
|
859
|
+
"後"
|
|
860
|
+
]);
|
|
861
|
+
const STOP_WORDS_ZH = new Set([
|
|
862
|
+
"我",
|
|
863
|
+
"我们",
|
|
864
|
+
"你",
|
|
865
|
+
"你们",
|
|
866
|
+
"他",
|
|
867
|
+
"她",
|
|
868
|
+
"它",
|
|
869
|
+
"他们",
|
|
870
|
+
"这",
|
|
871
|
+
"那",
|
|
872
|
+
"这个",
|
|
873
|
+
"那个",
|
|
874
|
+
"这些",
|
|
875
|
+
"那些",
|
|
876
|
+
"的",
|
|
877
|
+
"了",
|
|
878
|
+
"着",
|
|
879
|
+
"过",
|
|
880
|
+
"得",
|
|
881
|
+
"地",
|
|
882
|
+
"吗",
|
|
883
|
+
"呢",
|
|
884
|
+
"吧",
|
|
885
|
+
"啊",
|
|
886
|
+
"呀",
|
|
887
|
+
"嘛",
|
|
888
|
+
"啦",
|
|
889
|
+
"是",
|
|
890
|
+
"有",
|
|
891
|
+
"在",
|
|
892
|
+
"被",
|
|
893
|
+
"把",
|
|
894
|
+
"给",
|
|
895
|
+
"让",
|
|
896
|
+
"用",
|
|
897
|
+
"到",
|
|
898
|
+
"去",
|
|
899
|
+
"来",
|
|
900
|
+
"做",
|
|
901
|
+
"说",
|
|
902
|
+
"看",
|
|
903
|
+
"找",
|
|
904
|
+
"想",
|
|
905
|
+
"要",
|
|
906
|
+
"能",
|
|
907
|
+
"会",
|
|
908
|
+
"可以",
|
|
909
|
+
"和",
|
|
910
|
+
"与",
|
|
911
|
+
"或",
|
|
912
|
+
"但",
|
|
913
|
+
"但是",
|
|
914
|
+
"因为",
|
|
915
|
+
"所以",
|
|
916
|
+
"如果",
|
|
917
|
+
"虽然",
|
|
918
|
+
"而",
|
|
919
|
+
"也",
|
|
920
|
+
"都",
|
|
921
|
+
"就",
|
|
922
|
+
"还",
|
|
923
|
+
"又",
|
|
924
|
+
"再",
|
|
925
|
+
"才",
|
|
926
|
+
"只",
|
|
927
|
+
"之前",
|
|
928
|
+
"以前",
|
|
929
|
+
"之后",
|
|
930
|
+
"以后",
|
|
931
|
+
"刚才",
|
|
932
|
+
"现在",
|
|
933
|
+
"昨天",
|
|
934
|
+
"今天",
|
|
935
|
+
"明天",
|
|
936
|
+
"最近",
|
|
937
|
+
"东西",
|
|
938
|
+
"事情",
|
|
939
|
+
"事",
|
|
940
|
+
"什么",
|
|
941
|
+
"哪个",
|
|
942
|
+
"哪些",
|
|
943
|
+
"怎么",
|
|
944
|
+
"为什么",
|
|
945
|
+
"多少",
|
|
946
|
+
"请",
|
|
947
|
+
"帮",
|
|
948
|
+
"帮忙",
|
|
949
|
+
"告诉"
|
|
950
|
+
]);
|
|
951
|
+
/**
|
|
952
|
+
* Check if a token looks like a meaningful keyword.
|
|
953
|
+
* Returns false for short tokens, numbers-only, etc.
|
|
954
|
+
*/
|
|
955
|
+
function isValidKeyword(token) {
|
|
956
|
+
if (!token || token.length === 0) return false;
|
|
957
|
+
if (/^[a-zA-Z]+$/.test(token) && token.length < 3) return false;
|
|
958
|
+
if (/^\d+$/.test(token)) return false;
|
|
959
|
+
if (/^[\p{P}\p{S}]+$/u.test(token)) return false;
|
|
960
|
+
return true;
|
|
961
|
+
}
|
|
962
|
+
/**
|
|
963
|
+
* Simple tokenizer that handles English, Chinese, Korean, and Japanese text.
|
|
964
|
+
* For Chinese, we do character-based splitting since we don't have a proper segmenter.
|
|
965
|
+
* For English, we split on whitespace and punctuation.
|
|
966
|
+
*/
|
|
967
|
+
function tokenize(text) {
|
|
968
|
+
const tokens = [];
|
|
969
|
+
const segments = text.toLowerCase().trim().split(/[\s\p{P}]+/u).filter(Boolean);
|
|
970
|
+
for (const segment of segments) if (/[\u3040-\u30ff]/.test(segment)) {
|
|
971
|
+
const jpParts = segment.match(/[a-z0-9_]+|[\u30a0-\u30ffー]+|[\u4e00-\u9fff]+|[\u3040-\u309f]{2,}/g) ?? [];
|
|
972
|
+
for (const part of jpParts) if (/^[\u4e00-\u9fff]+$/.test(part)) {
|
|
973
|
+
tokens.push(part);
|
|
974
|
+
for (let i = 0; i < part.length - 1; i++) tokens.push(part[i] + part[i + 1]);
|
|
975
|
+
} else tokens.push(part);
|
|
976
|
+
} else if (/[\u4e00-\u9fff]/.test(segment)) {
|
|
977
|
+
const chars = Array.from(segment).filter((c) => /[\u4e00-\u9fff]/.test(c));
|
|
978
|
+
tokens.push(...chars);
|
|
979
|
+
for (let i = 0; i < chars.length - 1; i++) tokens.push(chars[i] + chars[i + 1]);
|
|
980
|
+
} else if (/[\uac00-\ud7af\u3131-\u3163]/.test(segment)) {
|
|
981
|
+
const stem = stripKoreanTrailingParticle(segment);
|
|
982
|
+
const stemIsStopWord = stem !== null && STOP_WORDS_KO.has(stem);
|
|
983
|
+
if (!STOP_WORDS_KO.has(segment) && !stemIsStopWord) tokens.push(segment);
|
|
984
|
+
if (stem && !STOP_WORDS_KO.has(stem) && isUsefulKoreanStem(stem)) tokens.push(stem);
|
|
985
|
+
} else tokens.push(segment);
|
|
986
|
+
return tokens;
|
|
987
|
+
}
|
|
988
|
+
/**
|
|
989
|
+
* Extract keywords from a conversational query for FTS search.
|
|
990
|
+
*
|
|
991
|
+
* Examples:
|
|
992
|
+
* - "that thing we discussed about the API" → ["discussed", "API"]
|
|
993
|
+
* - "之前讨论的那个方案" → ["讨论", "方案"]
|
|
994
|
+
* - "what was the solution for the bug" → ["solution", "bug"]
|
|
995
|
+
*/
|
|
996
|
+
function extractKeywords(query) {
|
|
997
|
+
const tokens = tokenize(query);
|
|
998
|
+
const keywords = [];
|
|
999
|
+
const seen = /* @__PURE__ */ new Set();
|
|
1000
|
+
for (const token of tokens) {
|
|
1001
|
+
if (STOP_WORDS_EN.has(token) || STOP_WORDS_ES.has(token) || STOP_WORDS_PT.has(token) || STOP_WORDS_AR.has(token) || STOP_WORDS_ZH.has(token) || STOP_WORDS_KO.has(token) || STOP_WORDS_JA.has(token)) continue;
|
|
1002
|
+
if (!isValidKeyword(token)) continue;
|
|
1003
|
+
if (seen.has(token)) continue;
|
|
1004
|
+
seen.add(token);
|
|
1005
|
+
keywords.push(token);
|
|
1006
|
+
}
|
|
1007
|
+
return keywords;
|
|
1008
|
+
}
|
|
1009
|
+
|
|
1010
|
+
//#endregion
|
|
1011
|
+
export { isFileMissingError as _, sessionPathForFile as a, cosineSimilarity as c, isMemoryPath as d, listMemoryFiles as f, runWithConcurrency as g, remapChunkLines as h, listSessionFilesForAgent as i, ensureDir as l, parseEmbedding as m, requireNodeSqlite as n, buildFileEntry as o, normalizeExtraMemoryPaths as p, buildSessionEntry as r, chunkMarkdown as s, extractKeywords as t, hashText as u, statRegularFile as v };
|