onbuzz 4.9.0 → 4.9.5
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/package.json +1 -1
- package/scripts/verify/azure-custom-embeddings.mjs +152 -0
- package/scripts/verify/azure-embeddings.mjs +146 -0
- package/scripts/verify/composio-toolkits.mjs +453 -0
- package/scripts/verify/local-embeddings.mjs +171 -0
- package/scripts/verify/openai-embeddings.mjs +140 -0
- package/src/__test-utils__/mockFactories.js +2 -0
- package/src/core/__tests__/agentPool.test.js +22 -2
- package/src/core/__tests__/agentScheduler.autoRecall.test.js +215 -0
- package/src/core/__tests__/agentScheduler.errorCategorisation.test.js +169 -0
- package/src/core/agentPool.js +60 -48
- package/src/core/agentScheduler.js +182 -36
- package/src/core/orchestrator.js +14 -13
- package/src/index.js +63 -1
- package/src/interfaces/__tests__/bulkAgentRoute.test.js +74 -3
- package/src/interfaces/webServer.js +101 -9
- package/src/services/__tests__/aiService.core.test.js +420 -0
- package/src/services/__tests__/aiService.embed.test.js +172 -0
- package/src/services/__tests__/apiKeyManager.getEmbeddingApiKey.test.js +86 -0
- package/src/services/__tests__/composioService.test.js +429 -47
- package/src/services/__tests__/telegramService.test.js +91 -0
- package/src/services/aiService.js +137 -0
- package/src/services/apiKeyManager.js +28 -0
- package/src/services/composioService.js +375 -24
- package/src/services/embeddings/__tests__/autoRecall.test.js +237 -0
- package/src/services/embeddings/__tests__/azureCustomProvider.test.js +232 -0
- package/src/services/embeddings/__tests__/cloudProviders.test.js +339 -0
- package/src/services/embeddings/__tests__/embeddingService.test.js +417 -0
- package/src/services/embeddings/__tests__/embeddingsConfig.test.js +182 -0
- package/src/services/embeddings/__tests__/inMemoryJsonStore.test.js +207 -0
- package/src/services/embeddings/__tests__/localProvider.test.js +263 -0
- package/src/services/embeddings/__tests__/providerInterface.test.js +209 -0
- package/src/services/embeddings/autoRecall.js +219 -0
- package/src/services/embeddings/embeddingService.js +452 -0
- package/src/services/embeddings/embeddingsConfig.js +203 -0
- package/src/services/embeddings/indexers/__tests__/agentIndexer.test.js +232 -0
- package/src/services/embeddings/indexers/__tests__/composioIndexer.test.js +265 -0
- package/src/services/embeddings/indexers/__tests__/memoryIndexer.test.js +418 -0
- package/src/services/embeddings/indexers/__tests__/reminisceIndexer.test.js +357 -0
- package/src/services/embeddings/indexers/__tests__/skillsIndexer.test.js +145 -0
- package/src/services/embeddings/indexers/__tests__/taskIndexer.test.js +146 -0
- package/src/services/embeddings/indexers/agentIndexer.js +249 -0
- package/src/services/embeddings/indexers/composioIndexer.js +279 -0
- package/src/services/embeddings/indexers/memoryIndexer.js +358 -0
- package/src/services/embeddings/indexers/reminisceIndexer.js +370 -0
- package/src/services/embeddings/indexers/skillsIndexer.js +154 -0
- package/src/services/embeddings/indexers/taskIndexer.js +155 -0
- package/src/services/embeddings/providerInterface.js +206 -0
- package/src/services/embeddings/providers/azureCustomProvider.js +154 -0
- package/src/services/embeddings/providers/azureProvider.js +122 -0
- package/src/services/embeddings/providers/cloudHttpTransport.js +205 -0
- package/src/services/embeddings/providers/localProvider.js +287 -0
- package/src/services/embeddings/providers/openaiProvider.js +101 -0
- package/src/services/embeddings/utilities/__tests__/textChunker.test.js +217 -0
- package/src/services/embeddings/utilities/textChunker.js +290 -0
- package/src/services/embeddings/vectorStore/__tests__/scoring.test.js +189 -0
- package/src/services/embeddings/vectorStore/inMemoryJsonStore.js +356 -0
- package/src/services/embeddings/vectorStore/scoring.js +128 -0
- package/src/services/embeddings/vectorStore/storeContractTests.js +179 -0
- package/src/services/embeddings/vectorStore/storeInterface.js +91 -0
- package/src/services/telegramService.js +140 -1
- package/src/tools/__tests__/agentCommunicationTool.findAgent.test.js +226 -0
- package/src/tools/__tests__/agentCommunicationTool.test.js +17 -2
- package/src/tools/__tests__/baseTool.test.js +14 -10
- package/src/tools/__tests__/cloneDetectionTool.test.js +430 -0
- package/src/tools/__tests__/composioTool.findAction.test.js +448 -0
- package/src/tools/__tests__/composioTool.test.js +254 -23
- package/src/tools/__tests__/dependencyResolverTool.test.js +567 -0
- package/src/tools/__tests__/docxTool.test.js +449 -0
- package/src/tools/__tests__/excelTool.test.js +486 -0
- package/src/tools/__tests__/importAnalyzerTool.test.js +368 -0
- package/src/tools/__tests__/memoryTool.forgetStale.test.js +272 -0
- package/src/tools/__tests__/memoryTool.reminisceSemanticSearch.test.js +301 -0
- package/src/tools/__tests__/memoryTool.semanticSearch.test.js +405 -0
- package/src/tools/__tests__/memoryTool.teamPool.test.js +293 -0
- package/src/tools/__tests__/openaiFunctionSchemas.validity.test.js +268 -0
- package/src/tools/__tests__/pdfTool.test.js +457 -0
- package/src/tools/__tests__/skillsTool.search.test.js +164 -0
- package/src/tools/__tests__/taskManagerTool.search.test.js +143 -0
- package/src/tools/agentCommunicationTool.js +120 -5
- package/src/tools/composioTool.js +373 -63
- package/src/tools/memoryTool.js +634 -5
- package/src/tools/office/pres/archetypes/_helpers.js +92 -0
- package/src/tools/office/pres/archetypes/agenda.js +61 -0
- package/src/tools/office/pres/archetypes/hero.js +69 -0
- package/src/tools/office/pres/backgrounds/geometric.js +74 -0
- package/src/tools/office/pres/backgrounds/gradient.js +38 -0
- package/src/tools/office/pres/backgrounds/grid.js +35 -0
- package/src/tools/office/pres/backgrounds/index.js +36 -0
- package/src/tools/office/pres/backgrounds/mesh.js +68 -0
- package/src/tools/office/pres/backgrounds/noise.js +27 -0
- package/src/tools/office/pres/backgrounds/solid.js +10 -0
- package/src/tools/office/pres/charts/index.js +119 -0
- package/src/tools/office/pres/grid.js +136 -0
- package/src/tools/office/pres/palettes.js +179 -0
- package/src/tools/office/pres/shapes.js +83 -0
- package/src/tools/office/pres/themes/data-heavy.js +79 -0
- package/src/tools/office/pres/themes/editorial-warm.js +73 -0
- package/src/tools/office/pres/themes/index.js +82 -0
- package/src/tools/office/pres/themes/tech-bold.js +70 -0
- package/src/tools/office/pres/typography.js +113 -0
- package/src/tools/openaiFunctionSchemas.js +796 -6
- package/src/tools/skillsTool.js +123 -0
- package/src/tools/taskManagerTool.js +115 -2
- package/src/tools/webTool.js +28 -1
- package/src/utilities/toolConstants.js +3 -1
- package/web-ui/build/index.html +2 -2
- package/web-ui/build/static/1c-CIpm7shn.js +2 -0
- package/web-ui/build/static/1c-CIpm7shn.js.map +1 -0
- package/web-ui/build/static/abap-DBqpy5Rd.js +2 -0
- package/web-ui/build/static/abap-DBqpy5Rd.js.map +1 -0
- package/web-ui/build/static/abnf-TXlZT8oe.js +2 -0
- package/web-ui/build/static/abnf-TXlZT8oe.js.map +1 -0
- package/web-ui/build/static/abnf-VOiW2_Fx.js +2 -0
- package/web-ui/build/static/abnf-VOiW2_Fx.js.map +1 -0
- package/web-ui/build/static/accesslog-BSNmQBv3.js +2 -0
- package/web-ui/build/static/accesslog-BSNmQBv3.js.map +1 -0
- package/web-ui/build/static/actionscript-Dq35khD2.js +2 -0
- package/web-ui/build/static/actionscript-Dq35khD2.js.map +1 -0
- package/web-ui/build/static/actionscript-DuxfQF-c.js +2 -0
- package/web-ui/build/static/actionscript-DuxfQF-c.js.map +1 -0
- package/web-ui/build/static/ada-BQ46lWsD.js +2 -0
- package/web-ui/build/static/ada-BQ46lWsD.js.map +1 -0
- package/web-ui/build/static/ada-PdXENdDu.js +2 -0
- package/web-ui/build/static/ada-PdXENdDu.js.map +1 -0
- package/web-ui/build/static/agda-DfAAbwlx.js +2 -0
- package/web-ui/build/static/agda-DfAAbwlx.js.map +1 -0
- package/web-ui/build/static/al-B8dI936P.js +2 -0
- package/web-ui/build/static/al-B8dI936P.js.map +1 -0
- package/web-ui/build/static/angelscript-D4Z4grcp.js +2 -0
- package/web-ui/build/static/angelscript-D4Z4grcp.js.map +1 -0
- package/web-ui/build/static/antlr4-C2f8x2BV.js +2 -0
- package/web-ui/build/static/antlr4-C2f8x2BV.js.map +1 -0
- package/web-ui/build/static/apache-CxPbh_0d.js +2 -0
- package/web-ui/build/static/apache-CxPbh_0d.js.map +1 -0
- package/web-ui/build/static/apacheconf-9fgKnbLm.js +2 -0
- package/web-ui/build/static/apacheconf-9fgKnbLm.js.map +1 -0
- package/web-ui/build/static/apex-__u-yxdt.js +2 -0
- package/web-ui/build/static/apex-__u-yxdt.js.map +1 -0
- package/web-ui/build/static/apl-DqligRjI.js +2 -0
- package/web-ui/build/static/apl-DqligRjI.js.map +1 -0
- package/web-ui/build/static/applescript-COZDncPC.js +2 -0
- package/web-ui/build/static/applescript-COZDncPC.js.map +1 -0
- package/web-ui/build/static/applescript-YisSEGnB.js +2 -0
- package/web-ui/build/static/applescript-YisSEGnB.js.map +1 -0
- package/web-ui/build/static/aql--9-8wgAR.js +2 -0
- package/web-ui/build/static/aql--9-8wgAR.js.map +1 -0
- package/web-ui/build/static/arcade-BoValZ1N.js +2 -0
- package/web-ui/build/static/arcade-BoValZ1N.js.map +1 -0
- package/web-ui/build/static/arduino-DZgyIfjl.js +2 -0
- package/web-ui/build/static/arduino-DZgyIfjl.js.map +1 -0
- package/web-ui/build/static/arduino-_4XXVmRx.js +2 -0
- package/web-ui/build/static/arduino-_4XXVmRx.js.map +1 -0
- package/web-ui/build/static/arff-XLfFOPyc.js +2 -0
- package/web-ui/build/static/arff-XLfFOPyc.js.map +1 -0
- package/web-ui/build/static/armasm-DlTklUG-.js +2 -0
- package/web-ui/build/static/armasm-DlTklUG-.js.map +1 -0
- package/web-ui/build/static/asciidoc-B31SDMIN.js +2 -0
- package/web-ui/build/static/asciidoc-B31SDMIN.js.map +1 -0
- package/web-ui/build/static/asciidoc-DUcGIImU.js +2 -0
- package/web-ui/build/static/asciidoc-DUcGIImU.js.map +1 -0
- package/web-ui/build/static/asm6502-DdjUXZ6e.js +2 -0
- package/web-ui/build/static/asm6502-DdjUXZ6e.js.map +1 -0
- package/web-ui/build/static/asmatmel-CvWt4f8C.js +2 -0
- package/web-ui/build/static/asmatmel-CvWt4f8C.js.map +1 -0
- package/web-ui/build/static/aspectj-CFwdMf-U.js +2 -0
- package/web-ui/build/static/aspectj-CFwdMf-U.js.map +1 -0
- package/web-ui/build/static/aspnet-CfYQ8SNz.js +2 -0
- package/web-ui/build/static/aspnet-CfYQ8SNz.js.map +1 -0
- package/web-ui/build/static/autohotkey-CXhLBgkD.js +2 -0
- package/web-ui/build/static/autohotkey-CXhLBgkD.js.map +1 -0
- package/web-ui/build/static/autohotkey-CYJ9BOZI.js +2 -0
- package/web-ui/build/static/autohotkey-CYJ9BOZI.js.map +1 -0
- package/web-ui/build/static/autoit-CjmI0wwD.js +2 -0
- package/web-ui/build/static/autoit-CjmI0wwD.js.map +1 -0
- package/web-ui/build/static/autoit-Dj5JXCB3.js +2 -0
- package/web-ui/build/static/autoit-Dj5JXCB3.js.map +1 -0
- package/web-ui/build/static/avisynth-BnyufzQA.js +2 -0
- package/web-ui/build/static/avisynth-BnyufzQA.js.map +1 -0
- package/web-ui/build/static/avrasm-D4PIKv9E.js +2 -0
- package/web-ui/build/static/avrasm-D4PIKv9E.js.map +1 -0
- package/web-ui/build/static/avro-idl-C3AkqmgB.js +2 -0
- package/web-ui/build/static/avro-idl-C3AkqmgB.js.map +1 -0
- package/web-ui/build/static/awk-BB8BVO9i.js +2 -0
- package/web-ui/build/static/awk-BB8BVO9i.js.map +1 -0
- package/web-ui/build/static/axapta-Zll9Z4A6.js +2 -0
- package/web-ui/build/static/axapta-Zll9Z4A6.js.map +1 -0
- package/web-ui/build/static/bash-B1LFDhgZ.js +2 -0
- package/web-ui/build/static/bash-B1LFDhgZ.js.map +1 -0
- package/web-ui/build/static/bash-BTJtjmje.js +2 -0
- package/web-ui/build/static/bash-BTJtjmje.js.map +1 -0
- package/web-ui/build/static/basic-CMgPvOTI.js +2 -0
- package/web-ui/build/static/basic-CMgPvOTI.js.map +1 -0
- package/web-ui/build/static/basic-C_w5ZVEg.js +2 -0
- package/web-ui/build/static/basic-C_w5ZVEg.js.map +1 -0
- package/web-ui/build/static/batch-BIrbrTOZ.js +2 -0
- package/web-ui/build/static/batch-BIrbrTOZ.js.map +1 -0
- package/web-ui/build/static/bbcode-DuUQ4DGC.js +2 -0
- package/web-ui/build/static/bbcode-DuUQ4DGC.js.map +1 -0
- package/web-ui/build/static/bicep-BtaG00oR.js +2 -0
- package/web-ui/build/static/bicep-BtaG00oR.js.map +1 -0
- package/web-ui/build/static/birb-DQgjFFr1.js +2 -0
- package/web-ui/build/static/birb-DQgjFFr1.js.map +1 -0
- package/web-ui/build/static/bison-BWN8dVUp.js +2 -0
- package/web-ui/build/static/bison-BWN8dVUp.js.map +1 -0
- package/web-ui/build/static/bnf-BixCQf8N.js +2 -0
- package/web-ui/build/static/bnf-BixCQf8N.js.map +1 -0
- package/web-ui/build/static/bnf-Bx295kt-.js +2 -0
- package/web-ui/build/static/bnf-Bx295kt-.js.map +1 -0
- package/web-ui/build/static/brainfuck-CCpVMS45.js +2 -0
- package/web-ui/build/static/brainfuck-CCpVMS45.js.map +1 -0
- package/web-ui/build/static/brainfuck-WLKJsSb0.js +2 -0
- package/web-ui/build/static/brainfuck-WLKJsSb0.js.map +1 -0
- package/web-ui/build/static/brightscript-UGk2L60W.js +2 -0
- package/web-ui/build/static/brightscript-UGk2L60W.js.map +1 -0
- package/web-ui/build/static/bro-DPa6sSlI.js +2 -0
- package/web-ui/build/static/bro-DPa6sSlI.js.map +1 -0
- package/web-ui/build/static/bsl-CDMrddDS.js +2 -0
- package/web-ui/build/static/bsl-CDMrddDS.js.map +1 -0
- package/web-ui/build/static/c-CJPUroiU.js +2 -0
- package/web-ui/build/static/c-CJPUroiU.js.map +1 -0
- package/web-ui/build/static/c-CmH5-LjX.js +2 -0
- package/web-ui/build/static/c-CmH5-LjX.js.map +1 -0
- package/web-ui/build/static/c-like-V_7qczFJ.js +2 -0
- package/web-ui/build/static/c-like-V_7qczFJ.js.map +1 -0
- package/web-ui/build/static/cal-bdOar0fR.js +2 -0
- package/web-ui/build/static/cal-bdOar0fR.js.map +1 -0
- package/web-ui/build/static/capnproto-CSmci_Te.js +2 -0
- package/web-ui/build/static/capnproto-CSmci_Te.js.map +1 -0
- package/web-ui/build/static/ceylon-COlIhkuy.js +2 -0
- package/web-ui/build/static/ceylon-COlIhkuy.js.map +1 -0
- package/web-ui/build/static/cfscript-A6OntVpf.js +2 -0
- package/web-ui/build/static/cfscript-A6OntVpf.js.map +1 -0
- package/web-ui/build/static/chaiscript-DtLWRNbp.js +2 -0
- package/web-ui/build/static/chaiscript-DtLWRNbp.js.map +1 -0
- package/web-ui/build/static/cil-DD-Z-fCN.js +2 -0
- package/web-ui/build/static/cil-DD-Z-fCN.js.map +1 -0
- package/web-ui/build/static/clean-Dux_Z84d.js +2 -0
- package/web-ui/build/static/clean-Dux_Z84d.js.map +1 -0
- package/web-ui/build/static/clojure-DAPaEkJL.js +2 -0
- package/web-ui/build/static/clojure-DAPaEkJL.js.map +1 -0
- package/web-ui/build/static/clojure-lTIxdM9O.js +2 -0
- package/web-ui/build/static/clojure-lTIxdM9O.js.map +1 -0
- package/web-ui/build/static/clojure-repl-BDWbyPCU.js +2 -0
- package/web-ui/build/static/clojure-repl-BDWbyPCU.js.map +1 -0
- package/web-ui/build/static/cmake-BTK0LQrD.js +2 -0
- package/web-ui/build/static/cmake-BTK0LQrD.js.map +1 -0
- package/web-ui/build/static/cmake-BcVpMOnC.js +2 -0
- package/web-ui/build/static/cmake-BcVpMOnC.js.map +1 -0
- package/web-ui/build/static/cobol-CHsv5b6-.js +2 -0
- package/web-ui/build/static/cobol-CHsv5b6-.js.map +1 -0
- package/web-ui/build/static/coffeescript-BPftFkE7.js +2 -0
- package/web-ui/build/static/coffeescript-BPftFkE7.js.map +1 -0
- package/web-ui/build/static/coffeescript-D0Z-OkWl.js +2 -0
- package/web-ui/build/static/coffeescript-D0Z-OkWl.js.map +1 -0
- package/web-ui/build/static/concurnas-9YcJnnqq.js +2 -0
- package/web-ui/build/static/concurnas-9YcJnnqq.js.map +1 -0
- package/web-ui/build/static/coq-BKVhllQO.js +2 -0
- package/web-ui/build/static/coq-BKVhllQO.js.map +1 -0
- package/web-ui/build/static/coq-DwBAg-6x.js +2 -0
- package/web-ui/build/static/coq-DwBAg-6x.js.map +1 -0
- package/web-ui/build/static/cos-C-Txu5CP.js +2 -0
- package/web-ui/build/static/cos-C-Txu5CP.js.map +1 -0
- package/web-ui/build/static/cpp-CppTC4jm.js +2 -0
- package/web-ui/build/static/cpp-CppTC4jm.js.map +1 -0
- package/web-ui/build/static/cpp-Dy7jOU4N.js +2 -0
- package/web-ui/build/static/cpp-Dy7jOU4N.js.map +1 -0
- package/web-ui/build/static/crmsh-BQngf7Ng.js +2 -0
- package/web-ui/build/static/crmsh-BQngf7Ng.js.map +1 -0
- package/web-ui/build/static/crystal-BEFleb5m.js +2 -0
- package/web-ui/build/static/crystal-BEFleb5m.js.map +1 -0
- package/web-ui/build/static/crystal-DJPAS1vy.js +2 -0
- package/web-ui/build/static/crystal-DJPAS1vy.js.map +1 -0
- package/web-ui/build/static/csharp-BkQukbu6.js +2 -0
- package/web-ui/build/static/csharp-BkQukbu6.js.map +1 -0
- package/web-ui/build/static/csharp-DWkraGep.js +2 -0
- package/web-ui/build/static/csharp-DWkraGep.js.map +1 -0
- package/web-ui/build/static/cshtml-Ccx08w50.js +2 -0
- package/web-ui/build/static/cshtml-Ccx08w50.js.map +1 -0
- package/web-ui/build/static/csp-CbUd0SJo.js +2 -0
- package/web-ui/build/static/csp-CbUd0SJo.js.map +1 -0
- package/web-ui/build/static/csp-DtS2Zwct.js +2 -0
- package/web-ui/build/static/csp-DtS2Zwct.js.map +1 -0
- package/web-ui/build/static/css-extras-BtLoos6t.js +2 -0
- package/web-ui/build/static/css-extras-BtLoos6t.js.map +1 -0
- package/web-ui/build/static/css-zlIj9LtT.js +2 -0
- package/web-ui/build/static/css-zlIj9LtT.js.map +1 -0
- package/web-ui/build/static/csv-0amG-9P9.js +2 -0
- package/web-ui/build/static/csv-0amG-9P9.js.map +1 -0
- package/web-ui/build/static/cypher-Do6MEL8D.js +2 -0
- package/web-ui/build/static/cypher-Do6MEL8D.js.map +1 -0
- package/web-ui/build/static/d-DDUT_KUS.js +2 -0
- package/web-ui/build/static/d-DDUT_KUS.js.map +1 -0
- package/web-ui/build/static/d-oyjoRzYI.js +2 -0
- package/web-ui/build/static/d-oyjoRzYI.js.map +1 -0
- package/web-ui/build/static/dart-0NlmTUZz.js +2 -0
- package/web-ui/build/static/dart-0NlmTUZz.js.map +1 -0
- package/web-ui/build/static/dart-DQ2t9-_f.js +2 -0
- package/web-ui/build/static/dart-DQ2t9-_f.js.map +1 -0
- package/web-ui/build/static/dataweave-DQS6Uln-.js +2 -0
- package/web-ui/build/static/dataweave-DQS6Uln-.js.map +1 -0
- package/web-ui/build/static/dax-Dc5laACD.js +2 -0
- package/web-ui/build/static/dax-Dc5laACD.js.map +1 -0
- package/web-ui/build/static/delphi-C-uad4Bo.js +2 -0
- package/web-ui/build/static/delphi-C-uad4Bo.js.map +1 -0
- package/web-ui/build/static/dhall-D5z449D-.js +2 -0
- package/web-ui/build/static/dhall-D5z449D-.js.map +1 -0
- package/web-ui/build/static/diff-DFErjB-8.js +2 -0
- package/web-ui/build/static/diff-DFErjB-8.js.map +1 -0
- package/web-ui/build/static/diff-DJ4_gfn5.js +2 -0
- package/web-ui/build/static/diff-DJ4_gfn5.js.map +1 -0
- package/web-ui/build/static/django-D42lI1SF.js +2 -0
- package/web-ui/build/static/django-D42lI1SF.js.map +1 -0
- package/web-ui/build/static/django-PXna6Qk0.js +2 -0
- package/web-ui/build/static/django-PXna6Qk0.js.map +1 -0
- package/web-ui/build/static/dns-bDedmWP4.js +2 -0
- package/web-ui/build/static/dns-bDedmWP4.js.map +1 -0
- package/web-ui/build/static/dns-zone-file-DpeO9UQ1.js +2 -0
- package/web-ui/build/static/dns-zone-file-DpeO9UQ1.js.map +1 -0
- package/web-ui/build/static/docker-BGUXiao0.js +2 -0
- package/web-ui/build/static/docker-BGUXiao0.js.map +1 -0
- package/web-ui/build/static/dockerfile-D911e_23.js +2 -0
- package/web-ui/build/static/dockerfile-D911e_23.js.map +1 -0
- package/web-ui/build/static/dos-kbqt3v5W.js +2 -0
- package/web-ui/build/static/dos-kbqt3v5W.js.map +1 -0
- package/web-ui/build/static/dot-DfSY07Ac.js +2 -0
- package/web-ui/build/static/dot-DfSY07Ac.js.map +1 -0
- package/web-ui/build/static/dsconfig-Dy0ZRn6b.js +2 -0
- package/web-ui/build/static/dsconfig-Dy0ZRn6b.js.map +1 -0
- package/web-ui/build/static/dts-4a9AuMc9.js +2 -0
- package/web-ui/build/static/dts-4a9AuMc9.js.map +1 -0
- package/web-ui/build/static/dust-nSmIpmBl.js +2 -0
- package/web-ui/build/static/dust-nSmIpmBl.js.map +1 -0
- package/web-ui/build/static/ebnf-Dl61OLfn.js +2 -0
- package/web-ui/build/static/ebnf-Dl61OLfn.js.map +1 -0
- package/web-ui/build/static/ebnf-r1dTiMcM.js +2 -0
- package/web-ui/build/static/ebnf-r1dTiMcM.js.map +1 -0
- package/web-ui/build/static/editorconfig-DSVQs8Qi.js +2 -0
- package/web-ui/build/static/editorconfig-DSVQs8Qi.js.map +1 -0
- package/web-ui/build/static/eiffel-zWvBF2FG.js +2 -0
- package/web-ui/build/static/eiffel-zWvBF2FG.js.map +1 -0
- package/web-ui/build/static/ejs-CvF1F43V.js +2 -0
- package/web-ui/build/static/ejs-CvF1F43V.js.map +1 -0
- package/web-ui/build/static/elixir-By0PNv1t.js +2 -0
- package/web-ui/build/static/elixir-By0PNv1t.js.map +1 -0
- package/web-ui/build/static/elixir-C2kidgKi.js +2 -0
- package/web-ui/build/static/elixir-C2kidgKi.js.map +1 -0
- package/web-ui/build/static/elm-BRV1W15w.js +2 -0
- package/web-ui/build/static/elm-BRV1W15w.js.map +1 -0
- package/web-ui/build/static/elm-C6rIpY6q.js +2 -0
- package/web-ui/build/static/elm-C6rIpY6q.js.map +1 -0
- package/web-ui/build/static/erb-Bo_R_kGH.js +2 -0
- package/web-ui/build/static/erb-Bo_R_kGH.js.map +1 -0
- package/web-ui/build/static/erb-C9uVcg2H.js +2 -0
- package/web-ui/build/static/erb-C9uVcg2H.js.map +1 -0
- package/web-ui/build/static/erlang-C4oS26rK.js +2 -0
- package/web-ui/build/static/erlang-C4oS26rK.js.map +1 -0
- package/web-ui/build/static/erlang-Cu46BVZa.js +2 -0
- package/web-ui/build/static/erlang-Cu46BVZa.js.map +1 -0
- package/web-ui/build/static/erlang-repl-D_hzvhxl.js +2 -0
- package/web-ui/build/static/erlang-repl-D_hzvhxl.js.map +1 -0
- package/web-ui/build/static/etlua-DsErG4wp.js +2 -0
- package/web-ui/build/static/etlua-DsErG4wp.js.map +1 -0
- package/web-ui/build/static/excel-ZAJk5dGI.js +2 -0
- package/web-ui/build/static/excel-ZAJk5dGI.js.map +1 -0
- package/web-ui/build/static/excel-formula-DW8-YMdi.js +2 -0
- package/web-ui/build/static/excel-formula-DW8-YMdi.js.map +1 -0
- package/web-ui/build/static/factor-DSfJeM1U.js +2 -0
- package/web-ui/build/static/factor-DSfJeM1U.js.map +1 -0
- package/web-ui/build/static/false-Ck8_pYxP.js +2 -0
- package/web-ui/build/static/false-Ck8_pYxP.js.map +1 -0
- package/web-ui/build/static/firestore-security-rules-cwPaJeut.js +2 -0
- package/web-ui/build/static/firestore-security-rules-cwPaJeut.js.map +1 -0
- package/web-ui/build/static/fix-B-kJBCTZ.js +2 -0
- package/web-ui/build/static/fix-B-kJBCTZ.js.map +1 -0
- package/web-ui/build/static/flix-BLXQR7-g.js +2 -0
- package/web-ui/build/static/flix-BLXQR7-g.js.map +1 -0
- package/web-ui/build/static/flow-DAFZKfh5.js +2 -0
- package/web-ui/build/static/flow-DAFZKfh5.js.map +1 -0
- package/web-ui/build/static/fortran-CjfHb4sQ.js +2 -0
- package/web-ui/build/static/fortran-CjfHb4sQ.js.map +1 -0
- package/web-ui/build/static/fortran-rg0v5sfs.js +2 -0
- package/web-ui/build/static/fortran-rg0v5sfs.js.map +1 -0
- package/web-ui/build/static/fsharp-Cw_y8ivr.js +2 -0
- package/web-ui/build/static/fsharp-Cw_y8ivr.js.map +1 -0
- package/web-ui/build/static/fsharp-DoS9x40u.js +2 -0
- package/web-ui/build/static/fsharp-DoS9x40u.js.map +1 -0
- package/web-ui/build/static/ftl-BgVZToXe.js +2 -0
- package/web-ui/build/static/ftl-BgVZToXe.js.map +1 -0
- package/web-ui/build/static/gams-mQlW1aqI.js +2 -0
- package/web-ui/build/static/gams-mQlW1aqI.js.map +1 -0
- package/web-ui/build/static/gap-BhhOmuZx.js +2 -0
- package/web-ui/build/static/gap-BhhOmuZx.js.map +1 -0
- package/web-ui/build/static/gauss-CWTTiMHQ.js +2 -0
- package/web-ui/build/static/gauss-CWTTiMHQ.js.map +1 -0
- package/web-ui/build/static/gcode-DSdI6esx.js +2 -0
- package/web-ui/build/static/gcode-DSdI6esx.js.map +1 -0
- package/web-ui/build/static/gcode-DZdLCEOD.js +2 -0
- package/web-ui/build/static/gcode-DZdLCEOD.js.map +1 -0
- package/web-ui/build/static/gdscript-CXMNWw3T.js +2 -0
- package/web-ui/build/static/gdscript-CXMNWw3T.js.map +1 -0
- package/web-ui/build/static/gedcom-4YF1FOSh.js +2 -0
- package/web-ui/build/static/gedcom-4YF1FOSh.js.map +1 -0
- package/web-ui/build/static/gherkin-BMQFawSL.js +2 -0
- package/web-ui/build/static/gherkin-BMQFawSL.js.map +1 -0
- package/web-ui/build/static/gherkin-C7nJqwFS.js +2 -0
- package/web-ui/build/static/gherkin-C7nJqwFS.js.map +1 -0
- package/web-ui/build/static/git-4dp8IYy4.js +2 -0
- package/web-ui/build/static/git-4dp8IYy4.js.map +1 -0
- package/web-ui/build/static/glsl-MT76EqZn.js +2 -0
- package/web-ui/build/static/glsl-MT76EqZn.js.map +1 -0
- package/web-ui/build/static/glsl-lwlZCOED.js +2 -0
- package/web-ui/build/static/glsl-lwlZCOED.js.map +1 -0
- package/web-ui/build/static/gml-CA0T984v.js +2 -0
- package/web-ui/build/static/gml-CA0T984v.js.map +1 -0
- package/web-ui/build/static/gml-CD0_-yFm.js +2 -0
- package/web-ui/build/static/gml-CD0_-yFm.js.map +1 -0
- package/web-ui/build/static/gn-Dh04M47n.js +2 -0
- package/web-ui/build/static/gn-Dh04M47n.js.map +1 -0
- package/web-ui/build/static/go-CZYK4Qan.js +2 -0
- package/web-ui/build/static/go-CZYK4Qan.js.map +1 -0
- package/web-ui/build/static/go-DyrXmVfB.js +2 -0
- package/web-ui/build/static/go-DyrXmVfB.js.map +1 -0
- package/web-ui/build/static/go-module-CMr5OO5S.js +2 -0
- package/web-ui/build/static/go-module-CMr5OO5S.js.map +1 -0
- package/web-ui/build/static/golo-9Hg7PwY5.js +2 -0
- package/web-ui/build/static/golo-9Hg7PwY5.js.map +1 -0
- package/web-ui/build/static/gradle-CI3T5ObH.js +2 -0
- package/web-ui/build/static/gradle-CI3T5ObH.js.map +1 -0
- package/web-ui/build/static/graphql-Bc0RfLW3.js +2 -0
- package/web-ui/build/static/graphql-Bc0RfLW3.js.map +1 -0
- package/web-ui/build/static/groovy-Bp9-Xs0j.js +2 -0
- package/web-ui/build/static/groovy-Bp9-Xs0j.js.map +1 -0
- package/web-ui/build/static/groovy-DzoCGAMV.js +2 -0
- package/web-ui/build/static/groovy-DzoCGAMV.js.map +1 -0
- package/web-ui/build/static/haml-C8-n-jnl.js +2 -0
- package/web-ui/build/static/haml-C8-n-jnl.js.map +1 -0
- package/web-ui/build/static/haml-DSFJxmci.js +2 -0
- package/web-ui/build/static/haml-DSFJxmci.js.map +1 -0
- package/web-ui/build/static/handlebars-B2CwDX3A.js +2 -0
- package/web-ui/build/static/handlebars-B2CwDX3A.js.map +1 -0
- package/web-ui/build/static/handlebars-CAjGQQv2.js +2 -0
- package/web-ui/build/static/handlebars-CAjGQQv2.js.map +1 -0
- package/web-ui/build/static/haskell-CLagAxDb.js +2 -0
- package/web-ui/build/static/haskell-CLagAxDb.js.map +1 -0
- package/web-ui/build/static/haskell-fxWEuOKL.js +2 -0
- package/web-ui/build/static/haskell-fxWEuOKL.js.map +1 -0
- package/web-ui/build/static/haxe-B9TM6-tR.js +2 -0
- package/web-ui/build/static/haxe-B9TM6-tR.js.map +1 -0
- package/web-ui/build/static/haxe-CjeFoF4j.js +2 -0
- package/web-ui/build/static/haxe-CjeFoF4j.js.map +1 -0
- package/web-ui/build/static/hcl-BT3AZvOV.js +2 -0
- package/web-ui/build/static/hcl-BT3AZvOV.js.map +1 -0
- package/web-ui/build/static/hlsl-qz07iv54.js +2 -0
- package/web-ui/build/static/hlsl-qz07iv54.js.map +1 -0
- package/web-ui/build/static/hoon-C8FKTQX3.js +2 -0
- package/web-ui/build/static/hoon-C8FKTQX3.js.map +1 -0
- package/web-ui/build/static/hpkp-ix5goVCw.js +2 -0
- package/web-ui/build/static/hpkp-ix5goVCw.js.map +1 -0
- package/web-ui/build/static/hsp-BYDtnG2g.js +2 -0
- package/web-ui/build/static/hsp-BYDtnG2g.js.map +1 -0
- package/web-ui/build/static/hsts-ClosJMSa.js +2 -0
- package/web-ui/build/static/hsts-ClosJMSa.js.map +1 -0
- package/web-ui/build/static/htmlbars-BXImnN9K.js +2 -0
- package/web-ui/build/static/htmlbars-BXImnN9K.js.map +1 -0
- package/web-ui/build/static/http-CzzGk8xH.js +2 -0
- package/web-ui/build/static/http-CzzGk8xH.js.map +1 -0
- package/web-ui/build/static/http-DIlu-tZe.js +2 -0
- package/web-ui/build/static/http-DIlu-tZe.js.map +1 -0
- package/web-ui/build/static/hy-DZHDd2Bi.js +2 -0
- package/web-ui/build/static/hy-DZHDd2Bi.js.map +1 -0
- package/web-ui/build/static/ichigojam-C9kzRIxq.js +2 -0
- package/web-ui/build/static/ichigojam-C9kzRIxq.js.map +1 -0
- package/web-ui/build/static/icon-BsrFa7_X.js +2 -0
- package/web-ui/build/static/icon-BsrFa7_X.js.map +1 -0
- package/web-ui/build/static/icu-message-format-CdeOu5cb.js +2 -0
- package/web-ui/build/static/icu-message-format-CdeOu5cb.js.map +1 -0
- package/web-ui/build/static/idris-D4eczid6.js +2 -0
- package/web-ui/build/static/idris-D4eczid6.js.map +1 -0
- package/web-ui/build/static/iecst-gOGAv1LA.js +2 -0
- package/web-ui/build/static/iecst-gOGAv1LA.js.map +1 -0
- package/web-ui/build/static/ignore-nL7hcdCE.js +2 -0
- package/web-ui/build/static/ignore-nL7hcdCE.js.map +1 -0
- package/web-ui/build/static/index-B15_bH1N.js +14 -0
- package/web-ui/build/static/index-B15_bH1N.js.map +1 -0
- package/web-ui/build/static/index-C815RTER.js +2 -0
- package/web-ui/build/static/index-C815RTER.js.map +1 -0
- package/web-ui/build/static/index-DkBBEGYj.css +1 -0
- package/web-ui/build/static/index-IiLN4TYi.js +1218 -0
- package/web-ui/build/static/index-IiLN4TYi.js.map +1 -0
- package/web-ui/build/static/inform7-BxDbc5x0.js +2 -0
- package/web-ui/build/static/inform7-BxDbc5x0.js.map +1 -0
- package/web-ui/build/static/inform7-g_C3iOfK.js +2 -0
- package/web-ui/build/static/inform7-g_C3iOfK.js.map +1 -0
- package/web-ui/build/static/ini--rbRrGfs.js +2 -0
- package/web-ui/build/static/ini--rbRrGfs.js.map +1 -0
- package/web-ui/build/static/ini-CSHh2zXc.js +2 -0
- package/web-ui/build/static/ini-CSHh2zXc.js.map +1 -0
- package/web-ui/build/static/io-CQXcamS9.js +2 -0
- package/web-ui/build/static/io-CQXcamS9.js.map +1 -0
- package/web-ui/build/static/irpf90-D2DBkrMI.js +2 -0
- package/web-ui/build/static/irpf90-D2DBkrMI.js.map +1 -0
- package/web-ui/build/static/isbl--Cxu2CWM.js +2 -0
- package/web-ui/build/static/isbl--Cxu2CWM.js.map +1 -0
- package/web-ui/build/static/j-2U8E41Rw.js +2 -0
- package/web-ui/build/static/j-2U8E41Rw.js.map +1 -0
- package/web-ui/build/static/java-DUQzhSXV.js +2 -0
- package/web-ui/build/static/java-DUQzhSXV.js.map +1 -0
- package/web-ui/build/static/java-L0SsRY11.js +2 -0
- package/web-ui/build/static/java-L0SsRY11.js.map +1 -0
- package/web-ui/build/static/javadoc-CVZDXOvi.js +2 -0
- package/web-ui/build/static/javadoc-CVZDXOvi.js.map +1 -0
- package/web-ui/build/static/javadoclike-C5XMZepF.js +2 -0
- package/web-ui/build/static/javadoclike-C5XMZepF.js.map +1 -0
- package/web-ui/build/static/javascript-ZQEeSwY1.js +2 -0
- package/web-ui/build/static/javascript-ZQEeSwY1.js.map +1 -0
- package/web-ui/build/static/javastacktrace-DsvCLH7a.js +2 -0
- package/web-ui/build/static/javastacktrace-DsvCLH7a.js.map +1 -0
- package/web-ui/build/static/jboss-cli-xwXeVrRr.js +2 -0
- package/web-ui/build/static/jboss-cli-xwXeVrRr.js.map +1 -0
- package/web-ui/build/static/jexl-DExBM7qK.js +2 -0
- package/web-ui/build/static/jexl-DExBM7qK.js.map +1 -0
- package/web-ui/build/static/jolie-CDrN1Lqh.js +2 -0
- package/web-ui/build/static/jolie-CDrN1Lqh.js.map +1 -0
- package/web-ui/build/static/jq-CMBw7_3n.js +2 -0
- package/web-ui/build/static/jq-CMBw7_3n.js.map +1 -0
- package/web-ui/build/static/js-extras-Cx-8eLF3.js +2 -0
- package/web-ui/build/static/js-extras-Cx-8eLF3.js.map +1 -0
- package/web-ui/build/static/js-templates-DAK0zDGe.js +2 -0
- package/web-ui/build/static/js-templates-DAK0zDGe.js.map +1 -0
- package/web-ui/build/static/jsdoc-B3I00IeG.js +2 -0
- package/web-ui/build/static/jsdoc-B3I00IeG.js.map +1 -0
- package/web-ui/build/static/json-BbfdII2P.js +2 -0
- package/web-ui/build/static/json-BbfdII2P.js.map +1 -0
- package/web-ui/build/static/json-DEBgQxEV.js +2 -0
- package/web-ui/build/static/json-DEBgQxEV.js.map +1 -0
- package/web-ui/build/static/json5-CtMIsJlC.js +2 -0
- package/web-ui/build/static/json5-CtMIsJlC.js.map +1 -0
- package/web-ui/build/static/jsonp-CX02fw5t.js +2 -0
- package/web-ui/build/static/jsonp-CX02fw5t.js.map +1 -0
- package/web-ui/build/static/jsstacktrace-kIldCuN9.js +2 -0
- package/web-ui/build/static/jsstacktrace-kIldCuN9.js.map +1 -0
- package/web-ui/build/static/jsx-D84iNd9p.js +2 -0
- package/web-ui/build/static/jsx-D84iNd9p.js.map +1 -0
- package/web-ui/build/static/julia-BaV0z0o7.js +2 -0
- package/web-ui/build/static/julia-BaV0z0o7.js.map +1 -0
- package/web-ui/build/static/julia-BtW5RdF_.js +2 -0
- package/web-ui/build/static/julia-BtW5RdF_.js.map +1 -0
- package/web-ui/build/static/julia-repl-BDOEyGFA.js +2 -0
- package/web-ui/build/static/julia-repl-BDOEyGFA.js.map +1 -0
- package/web-ui/build/static/keepalived-BKzC-ADN.js +2 -0
- package/web-ui/build/static/keepalived-BKzC-ADN.js.map +1 -0
- package/web-ui/build/static/keyman-CwwP1hqt.js +2 -0
- package/web-ui/build/static/keyman-CwwP1hqt.js.map +1 -0
- package/web-ui/build/static/kotlin-CLtNc6Sn.js +2 -0
- package/web-ui/build/static/kotlin-CLtNc6Sn.js.map +1 -0
- package/web-ui/build/static/kotlin-DWASsf8h.js +2 -0
- package/web-ui/build/static/kotlin-DWASsf8h.js.map +1 -0
- package/web-ui/build/static/kumir--QhA564W.js +2 -0
- package/web-ui/build/static/kumir--QhA564W.js.map +1 -0
- package/web-ui/build/static/kusto-Ces5HWV6.js +2 -0
- package/web-ui/build/static/kusto-Ces5HWV6.js.map +1 -0
- package/web-ui/build/static/lasso-BJ87w261.js +2 -0
- package/web-ui/build/static/lasso-BJ87w261.js.map +1 -0
- package/web-ui/build/static/latex-C0bgnRCf.js +2 -0
- package/web-ui/build/static/latex-C0bgnRCf.js.map +1 -0
- package/web-ui/build/static/latex-PANiTK21.js +2 -0
- package/web-ui/build/static/latex-PANiTK21.js.map +1 -0
- package/web-ui/build/static/latte-9BDz3uRL.js +2 -0
- package/web-ui/build/static/latte-9BDz3uRL.js.map +1 -0
- package/web-ui/build/static/ldif-BHo6ndJ1.js +2 -0
- package/web-ui/build/static/ldif-BHo6ndJ1.js.map +1 -0
- package/web-ui/build/static/leaf-B5dV-UOa.js +2 -0
- package/web-ui/build/static/leaf-B5dV-UOa.js.map +1 -0
- package/web-ui/build/static/less-89fqjBJb.js +2 -0
- package/web-ui/build/static/less-89fqjBJb.js.map +1 -0
- package/web-ui/build/static/less-DlmNqMO1.js +2 -0
- package/web-ui/build/static/less-DlmNqMO1.js.map +1 -0
- package/web-ui/build/static/lilypond-B1eMxZ7B.js +2 -0
- package/web-ui/build/static/lilypond-B1eMxZ7B.js.map +1 -0
- package/web-ui/build/static/liquid-D0j3hlqg.js +2 -0
- package/web-ui/build/static/liquid-D0j3hlqg.js.map +1 -0
- package/web-ui/build/static/lisp-C0MfYYAm.js +2 -0
- package/web-ui/build/static/lisp-C0MfYYAm.js.map +1 -0
- package/web-ui/build/static/lisp-DxTllZ7S.js +2 -0
- package/web-ui/build/static/lisp-DxTllZ7S.js.map +1 -0
- package/web-ui/build/static/livecodeserver-CL0AxwTq.js +2 -0
- package/web-ui/build/static/livecodeserver-CL0AxwTq.js.map +1 -0
- package/web-ui/build/static/livescript-BpnJRxga.js +2 -0
- package/web-ui/build/static/livescript-BpnJRxga.js.map +1 -0
- package/web-ui/build/static/livescript-DiQA36W0.js +2 -0
- package/web-ui/build/static/livescript-DiQA36W0.js.map +1 -0
- package/web-ui/build/static/llvm-BBIO8sDr.js +2 -0
- package/web-ui/build/static/llvm-BBIO8sDr.js.map +1 -0
- package/web-ui/build/static/llvm-DBXyvQ52.js +2 -0
- package/web-ui/build/static/llvm-DBXyvQ52.js.map +1 -0
- package/web-ui/build/static/log-BtAGPrP-.js +2 -0
- package/web-ui/build/static/log-BtAGPrP-.js.map +1 -0
- package/web-ui/build/static/lolcode-Cv3CvHHo.js +2 -0
- package/web-ui/build/static/lolcode-Cv3CvHHo.js.map +1 -0
- package/web-ui/build/static/lsl-DwkvlPUk.js +2 -0
- package/web-ui/build/static/lsl-DwkvlPUk.js.map +1 -0
- package/web-ui/build/static/lua-BM0GbQlH.js +2 -0
- package/web-ui/build/static/lua-BM0GbQlH.js.map +1 -0
- package/web-ui/build/static/lua-BOAz7yk0.js +2 -0
- package/web-ui/build/static/lua-BOAz7yk0.js.map +1 -0
- package/web-ui/build/static/magma-DQgZpBi_.js +2 -0
- package/web-ui/build/static/magma-DQgZpBi_.js.map +1 -0
- package/web-ui/build/static/makefile-BKZ7Ibln.js +2 -0
- package/web-ui/build/static/makefile-BKZ7Ibln.js.map +1 -0
- package/web-ui/build/static/makefile-C8xNgup3.js +2 -0
- package/web-ui/build/static/makefile-C8xNgup3.js.map +1 -0
- package/web-ui/build/static/markdown-Cu39K-hf.js +2 -0
- package/web-ui/build/static/markdown-Cu39K-hf.js.map +1 -0
- package/web-ui/build/static/markdown-CyC9S81y.js +2 -0
- package/web-ui/build/static/markdown-CyC9S81y.js.map +1 -0
- package/web-ui/build/static/marketplaceInstall-DbaC5Wr0.js +1 -0
- package/web-ui/build/static/marketplaceInstall-DbaC5Wr0.js.map +1 -0
- package/web-ui/build/static/markup-templating-CIYH1zwp.js +2 -0
- package/web-ui/build/static/markup-templating-CIYH1zwp.js.map +1 -0
- package/web-ui/build/static/mathematica-DR8RSuM9.js +2 -0
- package/web-ui/build/static/mathematica-DR8RSuM9.js.map +1 -0
- package/web-ui/build/static/matlab-C9_Pkzbf.js +2 -0
- package/web-ui/build/static/matlab-C9_Pkzbf.js.map +1 -0
- package/web-ui/build/static/matlab-CRDLV9Ki.js +2 -0
- package/web-ui/build/static/matlab-CRDLV9Ki.js.map +1 -0
- package/web-ui/build/static/maxima-70CQOlh2.js +2 -0
- package/web-ui/build/static/maxima-70CQOlh2.js.map +1 -0
- package/web-ui/build/static/maxscript-D16KkYNm.js +2 -0
- package/web-ui/build/static/maxscript-D16KkYNm.js.map +1 -0
- package/web-ui/build/static/mel-Bo-Ahkcy.js +2 -0
- package/web-ui/build/static/mel-Bo-Ahkcy.js.map +1 -0
- package/web-ui/build/static/mel-CzulN66X.js +2 -0
- package/web-ui/build/static/mel-CzulN66X.js.map +1 -0
- package/web-ui/build/static/mercury-CqOSLEXP.js +2 -0
- package/web-ui/build/static/mercury-CqOSLEXP.js.map +1 -0
- package/web-ui/build/static/mermaid-CvOaY0F4.js +2 -0
- package/web-ui/build/static/mermaid-CvOaY0F4.js.map +1 -0
- package/web-ui/build/static/mipsasm-0psAI1hM.js +2 -0
- package/web-ui/build/static/mipsasm-0psAI1hM.js.map +1 -0
- package/web-ui/build/static/mizar-BovA_dNn.js +2 -0
- package/web-ui/build/static/mizar-BovA_dNn.js.map +1 -0
- package/web-ui/build/static/mizar-CnVs3Nqs.js +2 -0
- package/web-ui/build/static/mizar-CnVs3Nqs.js.map +1 -0
- package/web-ui/build/static/mojolicious-BMs37GlG.js +2 -0
- package/web-ui/build/static/mojolicious-BMs37GlG.js.map +1 -0
- package/web-ui/build/static/mongodb-z5W_cS5R.js +2 -0
- package/web-ui/build/static/mongodb-z5W_cS5R.js.map +1 -0
- package/web-ui/build/static/monkey-H7dyyLcY.js +2 -0
- package/web-ui/build/static/monkey-H7dyyLcY.js.map +1 -0
- package/web-ui/build/static/monkey-mkTdxTam.js +2 -0
- package/web-ui/build/static/monkey-mkTdxTam.js.map +1 -0
- package/web-ui/build/static/moonscript-1f12E4O7.js +2 -0
- package/web-ui/build/static/moonscript-1f12E4O7.js.map +1 -0
- package/web-ui/build/static/moonscript-7FbSxMJH.js +2 -0
- package/web-ui/build/static/moonscript-7FbSxMJH.js.map +1 -0
- package/web-ui/build/static/n1ql-CFP6A6Lb.js +2 -0
- package/web-ui/build/static/n1ql-CFP6A6Lb.js.map +1 -0
- package/web-ui/build/static/n1ql-DHya7cxv.js +2 -0
- package/web-ui/build/static/n1ql-DHya7cxv.js.map +1 -0
- package/web-ui/build/static/n4js-CbbVrMVe.js +2 -0
- package/web-ui/build/static/n4js-CbbVrMVe.js.map +1 -0
- package/web-ui/build/static/nand2tetris-hdl-CzjgdK9W.js +2 -0
- package/web-ui/build/static/nand2tetris-hdl-CzjgdK9W.js.map +1 -0
- package/web-ui/build/static/naniscript-BdHIB3jP.js +2 -0
- package/web-ui/build/static/naniscript-BdHIB3jP.js.map +1 -0
- package/web-ui/build/static/nasm-CfEMiuK6.js +2 -0
- package/web-ui/build/static/nasm-CfEMiuK6.js.map +1 -0
- package/web-ui/build/static/neon-DKF7r6hJ.js +2 -0
- package/web-ui/build/static/neon-DKF7r6hJ.js.map +1 -0
- package/web-ui/build/static/nevod-CK1CAYpV.js +2 -0
- package/web-ui/build/static/nevod-CK1CAYpV.js.map +1 -0
- package/web-ui/build/static/nginx-8SbW6yHh.js +2 -0
- package/web-ui/build/static/nginx-8SbW6yHh.js.map +1 -0
- package/web-ui/build/static/nginx-BFl8BlZE.js +2 -0
- package/web-ui/build/static/nginx-BFl8BlZE.js.map +1 -0
- package/web-ui/build/static/nim-BEx_qix_.js +2 -0
- package/web-ui/build/static/nim-BEx_qix_.js.map +1 -0
- package/web-ui/build/static/nim-ZvQmiNqU.js +2 -0
- package/web-ui/build/static/nim-ZvQmiNqU.js.map +1 -0
- package/web-ui/build/static/nix-CXejwsna.js +2 -0
- package/web-ui/build/static/nix-CXejwsna.js.map +1 -0
- package/web-ui/build/static/nix-v8PgnR3h.js +2 -0
- package/web-ui/build/static/nix-v8PgnR3h.js.map +1 -0
- package/web-ui/build/static/node-repl-BHzyAKA1.js +2 -0
- package/web-ui/build/static/node-repl-BHzyAKA1.js.map +1 -0
- package/web-ui/build/static/nsis-Ch8daNjK.js +2 -0
- package/web-ui/build/static/nsis-Ch8daNjK.js.map +1 -0
- package/web-ui/build/static/nsis-DJy73n46.js +2 -0
- package/web-ui/build/static/nsis-DJy73n46.js.map +1 -0
- package/web-ui/build/static/objectivec-BHpZPLqD.js +2 -0
- package/web-ui/build/static/objectivec-BHpZPLqD.js.map +1 -0
- package/web-ui/build/static/objectivec-OieC5E_X.js +2 -0
- package/web-ui/build/static/objectivec-OieC5E_X.js.map +1 -0
- package/web-ui/build/static/ocaml-BBvwrtTP.js +2 -0
- package/web-ui/build/static/ocaml-BBvwrtTP.js.map +1 -0
- package/web-ui/build/static/ocaml-BlRyYLb7.js +2 -0
- package/web-ui/build/static/ocaml-BlRyYLb7.js.map +1 -0
- package/web-ui/build/static/opencl-D_vX3DrV.js +2 -0
- package/web-ui/build/static/opencl-D_vX3DrV.js.map +1 -0
- package/web-ui/build/static/openqasm-C9bgrYq1.js +2 -0
- package/web-ui/build/static/openqasm-C9bgrYq1.js.map +1 -0
- package/web-ui/build/static/openscad-DZfHG8xW.js +2 -0
- package/web-ui/build/static/openscad-DZfHG8xW.js.map +1 -0
- package/web-ui/build/static/oxygene-7kAs8yyB.js +2 -0
- package/web-ui/build/static/oxygene-7kAs8yyB.js.map +1 -0
- package/web-ui/build/static/oz-CABqR-Bn.js +2 -0
- package/web-ui/build/static/oz-CABqR-Bn.js.map +1 -0
- package/web-ui/build/static/parigp-DGHQOD89.js +2 -0
- package/web-ui/build/static/parigp-DGHQOD89.js.map +1 -0
- package/web-ui/build/static/parser-Ck1tkxce.js +2 -0
- package/web-ui/build/static/parser-Ck1tkxce.js.map +1 -0
- package/web-ui/build/static/parser3-C5jkraN1.js +2 -0
- package/web-ui/build/static/parser3-C5jkraN1.js.map +1 -0
- package/web-ui/build/static/pascal-lRk2BkiB.js +2 -0
- package/web-ui/build/static/pascal-lRk2BkiB.js.map +1 -0
- package/web-ui/build/static/pascaligo-DC8aCCBu.js +2 -0
- package/web-ui/build/static/pascaligo-DC8aCCBu.js.map +1 -0
- package/web-ui/build/static/pcaxis-DfslNj4b.js +2 -0
- package/web-ui/build/static/pcaxis-DfslNj4b.js.map +1 -0
- package/web-ui/build/static/peoplecode-RbMGdlOP.js +2 -0
- package/web-ui/build/static/peoplecode-RbMGdlOP.js.map +1 -0
- package/web-ui/build/static/perl-Bs3Ci1bk.js +2 -0
- package/web-ui/build/static/perl-Bs3Ci1bk.js.map +1 -0
- package/web-ui/build/static/perl-M6Lw613Z.js +2 -0
- package/web-ui/build/static/perl-M6Lw613Z.js.map +1 -0
- package/web-ui/build/static/pf-C45yVlhs.js +2 -0
- package/web-ui/build/static/pf-C45yVlhs.js.map +1 -0
- package/web-ui/build/static/pgsql-DYSyMJrO.js +2 -0
- package/web-ui/build/static/pgsql-DYSyMJrO.js.map +1 -0
- package/web-ui/build/static/php-DEMV1kCF.js +2 -0
- package/web-ui/build/static/php-DEMV1kCF.js.map +1 -0
- package/web-ui/build/static/php-DGDWhG5A.js +2 -0
- package/web-ui/build/static/php-DGDWhG5A.js.map +1 -0
- package/web-ui/build/static/php-extras-Byfe123j.js +2 -0
- package/web-ui/build/static/php-extras-Byfe123j.js.map +1 -0
- package/web-ui/build/static/php-template-BwBb349I.js +2 -0
- package/web-ui/build/static/php-template-BwBb349I.js.map +1 -0
- package/web-ui/build/static/phpdoc-CWhOFdWQ.js +2 -0
- package/web-ui/build/static/phpdoc-CWhOFdWQ.js.map +1 -0
- package/web-ui/build/static/plaintext-d4aBEEHw.js +2 -0
- package/web-ui/build/static/plaintext-d4aBEEHw.js.map +1 -0
- package/web-ui/build/static/plsql-CjX7DS38.js +2 -0
- package/web-ui/build/static/plsql-CjX7DS38.js.map +1 -0
- package/web-ui/build/static/pony-DGezKXsP.js +2 -0
- package/web-ui/build/static/pony-DGezKXsP.js.map +1 -0
- package/web-ui/build/static/powerquery-DSstxtQD.js +2 -0
- package/web-ui/build/static/powerquery-DSstxtQD.js.map +1 -0
- package/web-ui/build/static/powershell-Co6SPuTl.js +2 -0
- package/web-ui/build/static/powershell-Co6SPuTl.js.map +1 -0
- package/web-ui/build/static/powershell-I5-zjgkk.js +2 -0
- package/web-ui/build/static/powershell-I5-zjgkk.js.map +1 -0
- package/web-ui/build/static/processing-5GchLNs7.js +2 -0
- package/web-ui/build/static/processing-5GchLNs7.js.map +1 -0
- package/web-ui/build/static/processing-B0MN8Jo0.js +2 -0
- package/web-ui/build/static/processing-B0MN8Jo0.js.map +1 -0
- package/web-ui/build/static/profile-CU-JmDRP.js +2 -0
- package/web-ui/build/static/profile-CU-JmDRP.js.map +1 -0
- package/web-ui/build/static/prolog-CI8qvS4z.js +2 -0
- package/web-ui/build/static/prolog-CI8qvS4z.js.map +1 -0
- package/web-ui/build/static/prolog-o58OQ7w4.js +2 -0
- package/web-ui/build/static/prolog-o58OQ7w4.js.map +1 -0
- package/web-ui/build/static/promql-BVlm2eql.js +2 -0
- package/web-ui/build/static/promql-BVlm2eql.js.map +1 -0
- package/web-ui/build/static/properties-BxsLN08g.js +2 -0
- package/web-ui/build/static/properties-BxsLN08g.js.map +1 -0
- package/web-ui/build/static/properties-D-iOZfHY.js +2 -0
- package/web-ui/build/static/properties-D-iOZfHY.js.map +1 -0
- package/web-ui/build/static/protobuf-BfNNCyK6.js +2 -0
- package/web-ui/build/static/protobuf-BfNNCyK6.js.map +1 -0
- package/web-ui/build/static/protobuf-CECkfCqD.js +2 -0
- package/web-ui/build/static/protobuf-CECkfCqD.js.map +1 -0
- package/web-ui/build/static/psl-C6G804-b.js +2 -0
- package/web-ui/build/static/psl-C6G804-b.js.map +1 -0
- package/web-ui/build/static/pug-D6TQlTbg.js +2 -0
- package/web-ui/build/static/pug-D6TQlTbg.js.map +1 -0
- package/web-ui/build/static/puppet-87tzJYG8.js +2 -0
- package/web-ui/build/static/puppet-87tzJYG8.js.map +1 -0
- package/web-ui/build/static/puppet-JUKEwT8a.js +2 -0
- package/web-ui/build/static/puppet-JUKEwT8a.js.map +1 -0
- package/web-ui/build/static/pure-CrZNBHOi.js +2 -0
- package/web-ui/build/static/pure-CrZNBHOi.js.map +1 -0
- package/web-ui/build/static/purebasic-Cz13-1Ao.js +2 -0
- package/web-ui/build/static/purebasic-Cz13-1Ao.js.map +1 -0
- package/web-ui/build/static/purebasic-DyPM-f4H.js +2 -0
- package/web-ui/build/static/purebasic-DyPM-f4H.js.map +1 -0
- package/web-ui/build/static/purescript-Cq7y7q4B.js +2 -0
- package/web-ui/build/static/purescript-Cq7y7q4B.js.map +1 -0
- package/web-ui/build/static/python-BQrfu0dg.js +2 -0
- package/web-ui/build/static/python-BQrfu0dg.js.map +1 -0
- package/web-ui/build/static/python-CryTMY_J.js +2 -0
- package/web-ui/build/static/python-CryTMY_J.js.map +1 -0
- package/web-ui/build/static/python-repl-Cgzoym4R.js +2 -0
- package/web-ui/build/static/python-repl-Cgzoym4R.js.map +1 -0
- package/web-ui/build/static/q-CTBw1y99.js +2 -0
- package/web-ui/build/static/q-CTBw1y99.js.map +1 -0
- package/web-ui/build/static/q-o5VHwM5O.js +2 -0
- package/web-ui/build/static/q-o5VHwM5O.js.map +1 -0
- package/web-ui/build/static/qml-BZ5Dujlm.js +2 -0
- package/web-ui/build/static/qml-BZ5Dujlm.js.map +1 -0
- package/web-ui/build/static/qml-bwTojd06.js +2 -0
- package/web-ui/build/static/qml-bwTojd06.js.map +1 -0
- package/web-ui/build/static/qore-DB0hAhRh.js +2 -0
- package/web-ui/build/static/qore-DB0hAhRh.js.map +1 -0
- package/web-ui/build/static/qsharp-pGsUv_li.js +2 -0
- package/web-ui/build/static/qsharp-pGsUv_li.js.map +1 -0
- package/web-ui/build/static/r-BNGT0Nm9.js +2 -0
- package/web-ui/build/static/r-BNGT0Nm9.js.map +1 -0
- package/web-ui/build/static/r-C99T4Q9p.js +2 -0
- package/web-ui/build/static/r-C99T4Q9p.js.map +1 -0
- package/web-ui/build/static/racket-Hs9K9zq4.js +2 -0
- package/web-ui/build/static/racket-Hs9K9zq4.js.map +1 -0
- package/web-ui/build/static/reason-C-VueyBD.js +2 -0
- package/web-ui/build/static/reason-C-VueyBD.js.map +1 -0
- package/web-ui/build/static/reasonml-BUoE9oYn.js +2 -0
- package/web-ui/build/static/reasonml-BUoE9oYn.js.map +1 -0
- package/web-ui/build/static/regex-CK73qB0r.js +2 -0
- package/web-ui/build/static/regex-CK73qB0r.js.map +1 -0
- package/web-ui/build/static/rego-CxQjmFPr.js +2 -0
- package/web-ui/build/static/rego-CxQjmFPr.js.map +1 -0
- package/web-ui/build/static/renpy-Cr1Gbicf.js +2 -0
- package/web-ui/build/static/renpy-Cr1Gbicf.js.map +1 -0
- package/web-ui/build/static/rest-BKWi3OUB.js +2 -0
- package/web-ui/build/static/rest-BKWi3OUB.js.map +1 -0
- package/web-ui/build/static/rib-CGqMhYUv.js +2 -0
- package/web-ui/build/static/rib-CGqMhYUv.js.map +1 -0
- package/web-ui/build/static/rip-DenqLVuo.js +2 -0
- package/web-ui/build/static/rip-DenqLVuo.js.map +1 -0
- package/web-ui/build/static/roboconf--zQnZ0JC.js +2 -0
- package/web-ui/build/static/roboconf--zQnZ0JC.js.map +1 -0
- package/web-ui/build/static/roboconf-Drarux-e.js +2 -0
- package/web-ui/build/static/roboconf-Drarux-e.js.map +1 -0
- package/web-ui/build/static/robotframework-RBkYSfyi.js +2 -0
- package/web-ui/build/static/robotframework-RBkYSfyi.js.map +1 -0
- package/web-ui/build/static/routeros-BAYRNhYp.js +2 -0
- package/web-ui/build/static/routeros-BAYRNhYp.js.map +1 -0
- package/web-ui/build/static/rsl-DDdn2Hzy.js +2 -0
- package/web-ui/build/static/rsl-DDdn2Hzy.js.map +1 -0
- package/web-ui/build/static/ruby-CAcvY9jI.js +2 -0
- package/web-ui/build/static/ruby-CAcvY9jI.js.map +1 -0
- package/web-ui/build/static/ruby-vkcMNqGk.js +2 -0
- package/web-ui/build/static/ruby-vkcMNqGk.js.map +1 -0
- package/web-ui/build/static/ruleslanguage-BhuYTCjQ.js +2 -0
- package/web-ui/build/static/ruleslanguage-BhuYTCjQ.js.map +1 -0
- package/web-ui/build/static/rust-AzzF5BWp.js +2 -0
- package/web-ui/build/static/rust-AzzF5BWp.js.map +1 -0
- package/web-ui/build/static/rust-DFZxtMIp.js +2 -0
- package/web-ui/build/static/rust-DFZxtMIp.js.map +1 -0
- package/web-ui/build/static/sas-CGkSG2T9.js +2 -0
- package/web-ui/build/static/sas-CGkSG2T9.js.map +1 -0
- package/web-ui/build/static/sas-DqAH0see.js +2 -0
- package/web-ui/build/static/sas-DqAH0see.js.map +1 -0
- package/web-ui/build/static/sass-BjM0qxhA.js +2 -0
- package/web-ui/build/static/sass-BjM0qxhA.js.map +1 -0
- package/web-ui/build/static/scala-DItUn-9a.js +2 -0
- package/web-ui/build/static/scala-DItUn-9a.js.map +1 -0
- package/web-ui/build/static/scala-zuuyF0Er.js +2 -0
- package/web-ui/build/static/scala-zuuyF0Er.js.map +1 -0
- package/web-ui/build/static/scheme-DKfO0gOU.js +2 -0
- package/web-ui/build/static/scheme-DKfO0gOU.js.map +1 -0
- package/web-ui/build/static/scheme-pRLVEqo1.js +2 -0
- package/web-ui/build/static/scheme-pRLVEqo1.js.map +1 -0
- package/web-ui/build/static/scilab-BqQrlb5a.js +2 -0
- package/web-ui/build/static/scilab-BqQrlb5a.js.map +1 -0
- package/web-ui/build/static/scss-BMoEK0ig.js +2 -0
- package/web-ui/build/static/scss-BMoEK0ig.js.map +1 -0
- package/web-ui/build/static/scss-DDjKPoAB.js +2 -0
- package/web-ui/build/static/scss-DDjKPoAB.js.map +1 -0
- package/web-ui/build/static/shell-B01DgGnY.js +2 -0
- package/web-ui/build/static/shell-B01DgGnY.js.map +1 -0
- package/web-ui/build/static/shell-session-DmuFLD2t.js +2 -0
- package/web-ui/build/static/shell-session-DmuFLD2t.js.map +1 -0
- package/web-ui/build/static/smali-CPqq7iEg.js +2 -0
- package/web-ui/build/static/smali-CPqq7iEg.js.map +1 -0
- package/web-ui/build/static/smali-DhmulrJu.js +2 -0
- package/web-ui/build/static/smali-DhmulrJu.js.map +1 -0
- package/web-ui/build/static/smalltalk-DKxDKYVL.js +2 -0
- package/web-ui/build/static/smalltalk-DKxDKYVL.js.map +1 -0
- package/web-ui/build/static/smalltalk-DkLDOhCp.js +2 -0
- package/web-ui/build/static/smalltalk-DkLDOhCp.js.map +1 -0
- package/web-ui/build/static/smarty-Bpgsi0_R.js +2 -0
- package/web-ui/build/static/smarty-Bpgsi0_R.js.map +1 -0
- package/web-ui/build/static/sml-Cl3EPfMb.js +2 -0
- package/web-ui/build/static/sml-Cl3EPfMb.js.map +1 -0
- package/web-ui/build/static/sml-DOp65UEb.js +2 -0
- package/web-ui/build/static/sml-DOp65UEb.js.map +1 -0
- package/web-ui/build/static/solidity-DD_PwAzV.js +2 -0
- package/web-ui/build/static/solidity-DD_PwAzV.js.map +1 -0
- package/web-ui/build/static/solution-file-Bjzk2dBD.js +2 -0
- package/web-ui/build/static/solution-file-Bjzk2dBD.js.map +1 -0
- package/web-ui/build/static/soy-CU8egJa_.js +2 -0
- package/web-ui/build/static/soy-CU8egJa_.js.map +1 -0
- package/web-ui/build/static/sparql-C1hzUXhd.js +2 -0
- package/web-ui/build/static/sparql-C1hzUXhd.js.map +1 -0
- package/web-ui/build/static/splunk-spl-BzKBNAQP.js +2 -0
- package/web-ui/build/static/splunk-spl-BzKBNAQP.js.map +1 -0
- package/web-ui/build/static/sqf-B6lBlmdd.js +2 -0
- package/web-ui/build/static/sqf-B6lBlmdd.js.map +1 -0
- package/web-ui/build/static/sqf-BomYwO5b.js +2 -0
- package/web-ui/build/static/sqf-BomYwO5b.js.map +1 -0
- package/web-ui/build/static/sql-BdrSmYBW.js +2 -0
- package/web-ui/build/static/sql-BdrSmYBW.js.map +1 -0
- package/web-ui/build/static/sql-u5733t-n.js +2 -0
- package/web-ui/build/static/sql-u5733t-n.js.map +1 -0
- package/web-ui/build/static/sql_more-aFM_W8QJ.js +2 -0
- package/web-ui/build/static/sql_more-aFM_W8QJ.js.map +1 -0
- package/web-ui/build/static/squirrel-qRSJPf2v.js +2 -0
- package/web-ui/build/static/squirrel-qRSJPf2v.js.map +1 -0
- package/web-ui/build/static/stan-BozeUjzp.js +2 -0
- package/web-ui/build/static/stan-BozeUjzp.js.map +1 -0
- package/web-ui/build/static/stan-sT3iTLKa.js +2 -0
- package/web-ui/build/static/stan-sT3iTLKa.js.map +1 -0
- package/web-ui/build/static/stata-AmJHQ8fb.js +2 -0
- package/web-ui/build/static/stata-AmJHQ8fb.js.map +1 -0
- package/web-ui/build/static/step21-WDxFoTVu.js +2 -0
- package/web-ui/build/static/step21-WDxFoTVu.js.map +1 -0
- package/web-ui/build/static/stylus-b77rkBy4.js +2 -0
- package/web-ui/build/static/stylus-b77rkBy4.js.map +1 -0
- package/web-ui/build/static/stylus-wpomMVgS.js +2 -0
- package/web-ui/build/static/stylus-wpomMVgS.js.map +1 -0
- package/web-ui/build/static/subunit-CSb9sUbJ.js +2 -0
- package/web-ui/build/static/subunit-CSb9sUbJ.js.map +1 -0
- package/web-ui/build/static/swift-DyHdt1zr.js +2 -0
- package/web-ui/build/static/swift-DyHdt1zr.js.map +1 -0
- package/web-ui/build/static/swift-YkfxV2ZU.js +2 -0
- package/web-ui/build/static/swift-YkfxV2ZU.js.map +1 -0
- package/web-ui/build/static/systemd-DQWwUg35.js +2 -0
- package/web-ui/build/static/systemd-DQWwUg35.js.map +1 -0
- package/web-ui/build/static/t4-cs-QJUNCMK-.js +2 -0
- package/web-ui/build/static/t4-cs-QJUNCMK-.js.map +1 -0
- package/web-ui/build/static/t4-templating-GknC7kb9.js +2 -0
- package/web-ui/build/static/t4-templating-GknC7kb9.js.map +1 -0
- package/web-ui/build/static/t4-vb-D0RiOa-r.js +2 -0
- package/web-ui/build/static/t4-vb-D0RiOa-r.js.map +1 -0
- package/web-ui/build/static/taggerscript-Dsk8vD8t.js +2 -0
- package/web-ui/build/static/taggerscript-Dsk8vD8t.js.map +1 -0
- package/web-ui/build/static/tap-CWJE8qW6.js +2 -0
- package/web-ui/build/static/tap-CWJE8qW6.js.map +1 -0
- package/web-ui/build/static/tap-DRwooymT.js +2 -0
- package/web-ui/build/static/tap-DRwooymT.js.map +1 -0
- package/web-ui/build/static/tcl-DuQnwBEU.js +2 -0
- package/web-ui/build/static/tcl-DuQnwBEU.js.map +1 -0
- package/web-ui/build/static/tcl-NfboZe2L.js +2 -0
- package/web-ui/build/static/tcl-NfboZe2L.js.map +1 -0
- package/web-ui/build/static/textile-DdnXB7-Z.js +2 -0
- package/web-ui/build/static/textile-DdnXB7-Z.js.map +1 -0
- package/web-ui/build/static/thrift-DAcfarhX.js +2 -0
- package/web-ui/build/static/thrift-DAcfarhX.js.map +1 -0
- package/web-ui/build/static/toml-BPMZW5gD.js +2 -0
- package/web-ui/build/static/toml-BPMZW5gD.js.map +1 -0
- package/web-ui/build/static/tp-wseu1AuK.js +2 -0
- package/web-ui/build/static/tp-wseu1AuK.js.map +1 -0
- package/web-ui/build/static/tremor-DOWGR3Hc.js +2 -0
- package/web-ui/build/static/tremor-DOWGR3Hc.js.map +1 -0
- package/web-ui/build/static/tsx-DTMxJB4X.js +2 -0
- package/web-ui/build/static/tsx-DTMxJB4X.js.map +1 -0
- package/web-ui/build/static/tt2-Bf2Tnirp.js +2 -0
- package/web-ui/build/static/tt2-Bf2Tnirp.js.map +1 -0
- package/web-ui/build/static/turtle-BhU0VBtX.js +2 -0
- package/web-ui/build/static/turtle-BhU0VBtX.js.map +1 -0
- package/web-ui/build/static/twig-DPX7sYiW.js +2 -0
- package/web-ui/build/static/twig-DPX7sYiW.js.map +1 -0
- package/web-ui/build/static/twig-f_-CWDtl.js +2 -0
- package/web-ui/build/static/twig-f_-CWDtl.js.map +1 -0
- package/web-ui/build/static/typescript-BnVRooHZ.js +2 -0
- package/web-ui/build/static/typescript-BnVRooHZ.js.map +1 -0
- package/web-ui/build/static/typescript-EgvSJu-W.js +2 -0
- package/web-ui/build/static/typescript-EgvSJu-W.js.map +1 -0
- package/web-ui/build/static/typoscript-BpAaN1nU.js +2 -0
- package/web-ui/build/static/typoscript-BpAaN1nU.js.map +1 -0
- package/web-ui/build/static/unrealscript-WWvqaneW.js +2 -0
- package/web-ui/build/static/unrealscript-WWvqaneW.js.map +1 -0
- package/web-ui/build/static/uorazor-cnvtwiFh.js +2 -0
- package/web-ui/build/static/uorazor-cnvtwiFh.js.map +1 -0
- package/web-ui/build/static/uri-D_Fd898v.js +2 -0
- package/web-ui/build/static/uri-D_Fd898v.js.map +1 -0
- package/web-ui/build/static/v-CKCam4h4.js +2 -0
- package/web-ui/build/static/v-CKCam4h4.js.map +1 -0
- package/web-ui/build/static/vala-C0VK-b_J.js +2 -0
- package/web-ui/build/static/vala-C0VK-b_J.js.map +1 -0
- package/web-ui/build/static/vala-CygG7oXk.js +2 -0
- package/web-ui/build/static/vala-CygG7oXk.js.map +1 -0
- package/web-ui/build/static/vbnet-DLB3ZgHN.js +2 -0
- package/web-ui/build/static/vbnet-DLB3ZgHN.js.map +1 -0
- package/web-ui/build/static/vbnet-XYd1CidF.js +2 -0
- package/web-ui/build/static/vbnet-XYd1CidF.js.map +1 -0
- package/web-ui/build/static/vbscript-BUJ7wCl4.js +2 -0
- package/web-ui/build/static/vbscript-BUJ7wCl4.js.map +1 -0
- package/web-ui/build/static/vbscript-html-CGZZQd3d.js +2 -0
- package/web-ui/build/static/vbscript-html-CGZZQd3d.js.map +1 -0
- package/web-ui/build/static/velocity-BI88prHC.js +2 -0
- package/web-ui/build/static/velocity-BI88prHC.js.map +1 -0
- package/web-ui/build/static/verilog-C6cJ7gLo.js +2 -0
- package/web-ui/build/static/verilog-C6cJ7gLo.js.map +1 -0
- package/web-ui/build/static/verilog-CkwPGDMc.js +2 -0
- package/web-ui/build/static/verilog-CkwPGDMc.js.map +1 -0
- package/web-ui/build/static/vhdl-BWBfYNR2.js +2 -0
- package/web-ui/build/static/vhdl-BWBfYNR2.js.map +1 -0
- package/web-ui/build/static/vhdl-DMOoYFN9.js +2 -0
- package/web-ui/build/static/vhdl-DMOoYFN9.js.map +1 -0
- package/web-ui/build/static/vim-BPI46sA-.js +2 -0
- package/web-ui/build/static/vim-BPI46sA-.js.map +1 -0
- package/web-ui/build/static/vim-z8H9TeZR.js +2 -0
- package/web-ui/build/static/vim-z8H9TeZR.js.map +1 -0
- package/web-ui/build/static/visual-basic-XHRO453m.js +2 -0
- package/web-ui/build/static/visual-basic-XHRO453m.js.map +1 -0
- package/web-ui/build/static/warpscript-Dgge4GVE.js +2 -0
- package/web-ui/build/static/warpscript-Dgge4GVE.js.map +1 -0
- package/web-ui/build/static/wasm-BWdxxmDB.js +2 -0
- package/web-ui/build/static/wasm-BWdxxmDB.js.map +1 -0
- package/web-ui/build/static/web-idl-wJ4WTyQx.js +2 -0
- package/web-ui/build/static/web-idl-wJ4WTyQx.js.map +1 -0
- package/web-ui/build/static/wiki-HZvh9MJY.js +2 -0
- package/web-ui/build/static/wiki-HZvh9MJY.js.map +1 -0
- package/web-ui/build/static/wolfram-0U-HY4fj.js +2 -0
- package/web-ui/build/static/wolfram-0U-HY4fj.js.map +1 -0
- package/web-ui/build/static/wren-DTuuCGsO.js +2 -0
- package/web-ui/build/static/wren-DTuuCGsO.js.map +1 -0
- package/web-ui/build/static/x86asm-Cyouys5Y.js +2 -0
- package/web-ui/build/static/x86asm-Cyouys5Y.js.map +1 -0
- package/web-ui/build/static/xeora-Bfprf6QN.js +2 -0
- package/web-ui/build/static/xeora-Bfprf6QN.js.map +1 -0
- package/web-ui/build/static/xl-iEjcLSmo.js +2 -0
- package/web-ui/build/static/xl-iEjcLSmo.js.map +1 -0
- package/web-ui/build/static/xml-baLdEBkR.js +2 -0
- package/web-ui/build/static/xml-baLdEBkR.js.map +1 -0
- package/web-ui/build/static/xml-doc-Dz3wIFGg.js +2 -0
- package/web-ui/build/static/xml-doc-Dz3wIFGg.js.map +1 -0
- package/web-ui/build/static/xojo-y-RVOi7x.js +2 -0
- package/web-ui/build/static/xojo-y-RVOi7x.js.map +1 -0
- package/web-ui/build/static/xquery-4EwOlgJq.js +2 -0
- package/web-ui/build/static/xquery-4EwOlgJq.js.map +1 -0
- package/web-ui/build/static/xquery-Cg0k7MhG.js +2 -0
- package/web-ui/build/static/xquery-Cg0k7MhG.js.map +1 -0
- package/web-ui/build/static/yaml-B3Sd2Jss.js +2 -0
- package/web-ui/build/static/yaml-B3Sd2Jss.js.map +1 -0
- package/web-ui/build/static/yaml-CNz_miqE.js +2 -0
- package/web-ui/build/static/yaml-CNz_miqE.js.map +1 -0
- package/web-ui/build/static/yang-R8voLtAp.js +2 -0
- package/web-ui/build/static/yang-R8voLtAp.js.map +1 -0
- package/web-ui/build/static/zephir-CtzmCDt5.js +2 -0
- package/web-ui/build/static/zephir-CtzmCDt5.js.map +1 -0
- package/web-ui/build/static/zig-BPxomPEr.js +2 -0
- package/web-ui/build/static/zig-BPxomPEr.js.map +1 -0
- package/web-ui/build/static/1c-BoCdC5pC.js +0 -1
- package/web-ui/build/static/abap-D7A92M1K.js +0 -1
- package/web-ui/build/static/abnf-DIcpJ99N.js +0 -1
- package/web-ui/build/static/abnf-d4I9yABN.js +0 -1
- package/web-ui/build/static/accesslog-D_Ksv5Fi.js +0 -1
- package/web-ui/build/static/actionscript-CMJI1an7.js +0 -1
- package/web-ui/build/static/actionscript-CNcWu4a1.js +0 -1
- package/web-ui/build/static/ada-BIqOBKro.js +0 -1
- package/web-ui/build/static/ada-BaTkJMdz.js +0 -1
- package/web-ui/build/static/agda-DmRdGgvt.js +0 -1
- package/web-ui/build/static/al-g8BvIfOt.js +0 -1
- package/web-ui/build/static/angelscript-BGxc0B7l.js +0 -1
- package/web-ui/build/static/antlr4-Da7ff6-m.js +0 -1
- package/web-ui/build/static/apache-Bibp-dVJ.js +0 -1
- package/web-ui/build/static/apacheconf-VzeL8tYb.js +0 -1
- package/web-ui/build/static/apex-DUaOCea3.js +0 -1
- package/web-ui/build/static/apl-BpwvFE2V.js +0 -1
- package/web-ui/build/static/applescript-5YKSWwV1.js +0 -1
- package/web-ui/build/static/applescript-BHqj5bpe.js +0 -1
- package/web-ui/build/static/aql-B0Wx_3hH.js +0 -1
- package/web-ui/build/static/arcade-CR8KkII1.js +0 -1
- package/web-ui/build/static/arduino-CYx5u85C.js +0 -1
- package/web-ui/build/static/arduino-ClVU2zro.js +0 -1
- package/web-ui/build/static/arff-kutIH4CC.js +0 -1
- package/web-ui/build/static/armasm-DBm1lGrc.js +0 -1
- package/web-ui/build/static/asciidoc-Cl02VMGf.js +0 -1
- package/web-ui/build/static/asciidoc-MMFYRqre.js +0 -1
- package/web-ui/build/static/asm6502-DPVMGaHn.js +0 -1
- package/web-ui/build/static/asmatmel-Dz4vtZ11.js +0 -1
- package/web-ui/build/static/aspectj-BZidGBlr.js +0 -1
- package/web-ui/build/static/aspnet-C2mo9iee.js +0 -1
- package/web-ui/build/static/autohotkey-Bx83oFMW.js +0 -1
- package/web-ui/build/static/autohotkey-DciFl6K5.js +0 -1
- package/web-ui/build/static/autoit-TVKWI5bu.js +0 -1
- package/web-ui/build/static/autoit-oORW7mrd.js +0 -1
- package/web-ui/build/static/avisynth-D_5uOtxP.js +0 -1
- package/web-ui/build/static/avrasm-D22JmbLm.js +0 -1
- package/web-ui/build/static/avro-idl-CtTuANGZ.js +0 -1
- package/web-ui/build/static/awk-Bnez22eR.js +0 -1
- package/web-ui/build/static/axapta-eqcr7C2-.js +0 -1
- package/web-ui/build/static/bash-D3XWHCZZ.js +0 -1
- package/web-ui/build/static/bash-px0MqVxE.js +0 -1
- package/web-ui/build/static/basic-BWOdgKLg.js +0 -1
- package/web-ui/build/static/basic-C7PK4wVg.js +0 -1
- package/web-ui/build/static/batch-CFeuSY9D.js +0 -1
- package/web-ui/build/static/bbcode-CRC0UNOS.js +0 -1
- package/web-ui/build/static/bicep-C18w8d6Z.js +0 -1
- package/web-ui/build/static/birb-DPiF4fwX.js +0 -1
- package/web-ui/build/static/bison-C1RWPaLl.js +0 -1
- package/web-ui/build/static/bnf-BelSXhsr.js +0 -1
- package/web-ui/build/static/bnf-D_m4SZuc.js +0 -1
- package/web-ui/build/static/brainfuck-Ci7P0POq.js +0 -1
- package/web-ui/build/static/brainfuck-DIrW6_96.js +0 -1
- package/web-ui/build/static/brightscript-4XgpA0OQ.js +0 -1
- package/web-ui/build/static/bro-4kAMStb2.js +0 -1
- package/web-ui/build/static/bsl-CleVjH1I.js +0 -1
- package/web-ui/build/static/c-Ct3AAwH6.js +0 -1
- package/web-ui/build/static/c-EiJrAzIQ.js +0 -1
- package/web-ui/build/static/c-like-B361rHmz.js +0 -1
- package/web-ui/build/static/cal-BZ3Pr4JI.js +0 -1
- package/web-ui/build/static/capnproto-LmwOdJJp.js +0 -1
- package/web-ui/build/static/ceylon-CKAfIFzx.js +0 -1
- package/web-ui/build/static/cfscript-Cms4z16U.js +0 -1
- package/web-ui/build/static/chaiscript-DKxRiUyN.js +0 -1
- package/web-ui/build/static/cil-C6rGhwce.js +0 -1
- package/web-ui/build/static/clean-DmpXs6RN.js +0 -1
- package/web-ui/build/static/clojure-DRYxiF9s.js +0 -1
- package/web-ui/build/static/clojure-DTjXEJCq.js +0 -1
- package/web-ui/build/static/clojure-repl-C1qlAUnK.js +0 -1
- package/web-ui/build/static/cmake-DtUokafC.js +0 -1
- package/web-ui/build/static/cmake-_WqF1fG8.js +0 -1
- package/web-ui/build/static/cobol-D2Q0IMuT.js +0 -1
- package/web-ui/build/static/coffeescript-MRThzdTU.js +0 -1
- package/web-ui/build/static/coffeescript-OHOpkJvb.js +0 -1
- package/web-ui/build/static/concurnas-CVGat9IA.js +0 -1
- package/web-ui/build/static/coq-CB_bM4lt.js +0 -1
- package/web-ui/build/static/coq-WNK38Cqz.js +0 -1
- package/web-ui/build/static/cos-CNa5GVxa.js +0 -1
- package/web-ui/build/static/cpp-D-9lHx0_.js +0 -1
- package/web-ui/build/static/cpp-DRvL1yaA.js +0 -1
- package/web-ui/build/static/crmsh-evnPMxnd.js +0 -1
- package/web-ui/build/static/crystal-RGhNrgnC.js +0 -1
- package/web-ui/build/static/crystal-yrBjXjEh.js +0 -1
- package/web-ui/build/static/csharp-Dr7sLtl1.js +0 -1
- package/web-ui/build/static/csharp-zNVQxjuC.js +0 -1
- package/web-ui/build/static/cshtml-CoiK-7Bu.js +0 -1
- package/web-ui/build/static/csp-Bhgq86EB.js +0 -1
- package/web-ui/build/static/csp-C20UcGAL.js +0 -1
- package/web-ui/build/static/css-D1vlrRV2.js +0 -1
- package/web-ui/build/static/css-extras-DVSAYMbv.js +0 -1
- package/web-ui/build/static/csv-BgR9D8jG.js +0 -1
- package/web-ui/build/static/cypher-Dxehyj6Y.js +0 -1
- package/web-ui/build/static/d-B-Se39n2.js +0 -1
- package/web-ui/build/static/d-Cr4d56op.js +0 -1
- package/web-ui/build/static/dart-BBqlOFkR.js +0 -1
- package/web-ui/build/static/dart-GRD7MWem.js +0 -1
- package/web-ui/build/static/dataweave-BK-Tahkw.js +0 -1
- package/web-ui/build/static/dax-pTr9GVoe.js +0 -1
- package/web-ui/build/static/delphi-CbwSNmp4.js +0 -1
- package/web-ui/build/static/dhall-CuFqRXr6.js +0 -1
- package/web-ui/build/static/diff-CK8Fq88e.js +0 -1
- package/web-ui/build/static/diff-CWbUTU-C.js +0 -1
- package/web-ui/build/static/django-DWaEPdP6.js +0 -1
- package/web-ui/build/static/django-TkEFpAOO.js +0 -1
- package/web-ui/build/static/dns-DKpFJlA0.js +0 -1
- package/web-ui/build/static/dns-zone-file-BIsmZEMf.js +0 -1
- package/web-ui/build/static/docker-DUavAYf7.js +0 -1
- package/web-ui/build/static/dockerfile-YnavjTIo.js +0 -1
- package/web-ui/build/static/dos-Dv3Qr-Oo.js +0 -1
- package/web-ui/build/static/dot-BtIPbx7t.js +0 -1
- package/web-ui/build/static/dsconfig-CEgd9-kI.js +0 -1
- package/web-ui/build/static/dts-BztZn8T6.js +0 -1
- package/web-ui/build/static/dust-B-527Hc0.js +0 -1
- package/web-ui/build/static/ebnf-CH_nnNi5.js +0 -1
- package/web-ui/build/static/ebnf-CuBjcj0j.js +0 -1
- package/web-ui/build/static/editorconfig-CA9KaQ0w.js +0 -1
- package/web-ui/build/static/eiffel-DVYJwwQw.js +0 -1
- package/web-ui/build/static/ejs-C2LKgDYE.js +0 -1
- package/web-ui/build/static/elixir-DVXGkbnw.js +0 -1
- package/web-ui/build/static/elixir-meJ_qqx4.js +0 -1
- package/web-ui/build/static/elm-C5sYS5Cb.js +0 -1
- package/web-ui/build/static/elm-Dj443pWY.js +0 -1
- package/web-ui/build/static/erb-CAj5yksQ.js +0 -1
- package/web-ui/build/static/erb-CcUB2tMd.js +0 -1
- package/web-ui/build/static/erlang-JusKooAX.js +0 -1
- package/web-ui/build/static/erlang-repl-wYgxDX5h.js +0 -1
- package/web-ui/build/static/erlang-sn-PsrSf.js +0 -1
- package/web-ui/build/static/etlua-ChDwUxz6.js +0 -1
- package/web-ui/build/static/excel-BJux1m2h.js +0 -1
- package/web-ui/build/static/excel-formula-i5ByFxAu.js +0 -1
- package/web-ui/build/static/factor-CTutAp6r.js +0 -1
- package/web-ui/build/static/false-DQz_zYVV.js +0 -1
- package/web-ui/build/static/firestore-security-rules-DRGBNXh2.js +0 -1
- package/web-ui/build/static/fix-DeSUhixI.js +0 -1
- package/web-ui/build/static/flix-BKTJVua_.js +0 -1
- package/web-ui/build/static/flow-BpcZsNuo.js +0 -1
- package/web-ui/build/static/fortran-BZIKfBPW.js +0 -1
- package/web-ui/build/static/fortran-BdezWEh5.js +0 -1
- package/web-ui/build/static/fsharp-1Gpt8wZo.js +0 -1
- package/web-ui/build/static/fsharp-CMyiqXUW.js +0 -1
- package/web-ui/build/static/ftl-D9bBJMhV.js +0 -1
- package/web-ui/build/static/gams-DL57wTHN.js +0 -1
- package/web-ui/build/static/gap-DN4Uo9cF.js +0 -1
- package/web-ui/build/static/gauss-DTa1H0QR.js +0 -1
- package/web-ui/build/static/gcode-U5GhqE37.js +0 -1
- package/web-ui/build/static/gcode-s-E37fb4.js +0 -1
- package/web-ui/build/static/gdscript-DkjgGcDv.js +0 -1
- package/web-ui/build/static/gedcom-BbjSSId3.js +0 -1
- package/web-ui/build/static/gherkin-BwIzGx7J.js +0 -1
- package/web-ui/build/static/gherkin-C97W_9I9.js +0 -1
- package/web-ui/build/static/git-DO8dnOip.js +0 -1
- package/web-ui/build/static/glsl-B_4UD4-O.js +0 -1
- package/web-ui/build/static/glsl-CGSjLy2x.js +0 -1
- package/web-ui/build/static/gml-BiITg8HI.js +0 -1
- package/web-ui/build/static/gml-DInGU66p.js +0 -1
- package/web-ui/build/static/gn--m2IH4i3.js +0 -1
- package/web-ui/build/static/go-DOK7GAd-.js +0 -1
- package/web-ui/build/static/go-bof0B9jK.js +0 -1
- package/web-ui/build/static/go-module-CPIVqmnL.js +0 -1
- package/web-ui/build/static/golo-jgy07E43.js +0 -1
- package/web-ui/build/static/gradle-BISOF0nH.js +0 -1
- package/web-ui/build/static/graphql-FqlbDLTL.js +0 -1
- package/web-ui/build/static/groovy-BM0ZyW4a.js +0 -1
- package/web-ui/build/static/groovy-oUdbfbZY.js +0 -1
- package/web-ui/build/static/haml-C8Qg-VO5.js +0 -1
- package/web-ui/build/static/haml-Dse28pB_.js +0 -1
- package/web-ui/build/static/handlebars-CWT7WazY.js +0 -1
- package/web-ui/build/static/handlebars-Ow3joqOm.js +0 -1
- package/web-ui/build/static/haskell-BfraeRhd.js +0 -1
- package/web-ui/build/static/haskell-EhcU7sbn.js +0 -1
- package/web-ui/build/static/haxe-B8tUoExu.js +0 -1
- package/web-ui/build/static/haxe-D9WQHhTh.js +0 -1
- package/web-ui/build/static/hcl-CG3GCouf.js +0 -1
- package/web-ui/build/static/hlsl-CSWRMQ3m.js +0 -1
- package/web-ui/build/static/hoon-Cj0JdbFY.js +0 -1
- package/web-ui/build/static/hpkp-CmjdXbgl.js +0 -1
- package/web-ui/build/static/hsp-VaFZ7Rlv.js +0 -1
- package/web-ui/build/static/hsts-CkJ6UPzY.js +0 -1
- package/web-ui/build/static/htmlbars-pfHjYqd2.js +0 -1
- package/web-ui/build/static/http-2LA-qivJ.js +0 -1
- package/web-ui/build/static/http-CQ_5JSsj.js +0 -1
- package/web-ui/build/static/hy-C-Dll2MQ.js +0 -1
- package/web-ui/build/static/ichigojam-DecRewwq.js +0 -1
- package/web-ui/build/static/icon-CdnU9zPA.js +0 -1
- package/web-ui/build/static/icu-message-format-CUQtjk6Q.js +0 -1
- package/web-ui/build/static/idris-CRMftLq6.js +0 -1
- package/web-ui/build/static/iecst-CXhHqz1P.js +0 -1
- package/web-ui/build/static/ignore-_emqIx7v.js +0 -1
- package/web-ui/build/static/index-BBHrMvg7.js +0 -1216
- package/web-ui/build/static/index-ChkZR_aE.js +0 -13
- package/web-ui/build/static/index-DU4GNSOf.js +0 -1
- package/web-ui/build/static/index-_z8JjNrI.css +0 -1
- package/web-ui/build/static/inform7-CbqlFoFE.js +0 -1
- package/web-ui/build/static/inform7-TxZViMJ9.js +0 -1
- package/web-ui/build/static/ini-D1sHtm5e.js +0 -1
- package/web-ui/build/static/ini-DnqB7pfX.js +0 -1
- package/web-ui/build/static/io-MnQK1mM-.js +0 -1
- package/web-ui/build/static/irpf90-BRaAenqx.js +0 -1
- package/web-ui/build/static/isbl-kubGT4rM.js +0 -1
- package/web-ui/build/static/j-BIz9wT9q.js +0 -1
- package/web-ui/build/static/java-CbQmsHSK.js +0 -1
- package/web-ui/build/static/java-v1B9fNL2.js +0 -1
- package/web-ui/build/static/javadoc-TB1OtWS7.js +0 -1
- package/web-ui/build/static/javadoclike-BBQPwDAU.js +0 -1
- package/web-ui/build/static/javascript-DzNVL5l_.js +0 -1
- package/web-ui/build/static/javastacktrace-BduOgG1e.js +0 -1
- package/web-ui/build/static/jboss-cli-BcqzI366.js +0 -1
- package/web-ui/build/static/jexl-Boyapidr.js +0 -1
- package/web-ui/build/static/jolie-hEbkNpsb.js +0 -1
- package/web-ui/build/static/jq-ZyEE6oGU.js +0 -1
- package/web-ui/build/static/js-extras-CXOzvlL7.js +0 -1
- package/web-ui/build/static/js-templates-CkHsm5px.js +0 -1
- package/web-ui/build/static/jsdoc-Uk3hj8z2.js +0 -1
- package/web-ui/build/static/json-BFi9igjd.js +0 -1
- package/web-ui/build/static/json-LI9wtNaG.js +0 -1
- package/web-ui/build/static/json5-PwjNByuN.js +0 -1
- package/web-ui/build/static/jsonp-DpfGuNSW.js +0 -1
- package/web-ui/build/static/jsstacktrace-DhOP2AhS.js +0 -1
- package/web-ui/build/static/jsx-DmWoDk8F.js +0 -1
- package/web-ui/build/static/julia-DBC5h81N.js +0 -1
- package/web-ui/build/static/julia-Dh9sV3LX.js +0 -1
- package/web-ui/build/static/julia-repl-BYyDp1f4.js +0 -1
- package/web-ui/build/static/keepalived-BTxjrZMV.js +0 -1
- package/web-ui/build/static/keyman-IYiyCDCU.js +0 -1
- package/web-ui/build/static/kotlin-C0PBuzvy.js +0 -1
- package/web-ui/build/static/kotlin-LWYZUK_T.js +0 -1
- package/web-ui/build/static/kumir-CQIbnv9I.js +0 -1
- package/web-ui/build/static/kusto-DA7pQ-Rb.js +0 -1
- package/web-ui/build/static/lasso-CrHySbnC.js +0 -1
- package/web-ui/build/static/latex-CLSOFXG4.js +0 -1
- package/web-ui/build/static/latex-DYknD4Dx.js +0 -1
- package/web-ui/build/static/latte-4QvZcKVw.js +0 -1
- package/web-ui/build/static/ldif-Dr96BfRx.js +0 -1
- package/web-ui/build/static/leaf-C9qL2Qde.js +0 -1
- package/web-ui/build/static/less-DpoID9ZJ.js +0 -1
- package/web-ui/build/static/less-wO8QO0XW.js +0 -1
- package/web-ui/build/static/lilypond-CNp4Kb1P.js +0 -1
- package/web-ui/build/static/liquid-DLULQdgV.js +0 -1
- package/web-ui/build/static/lisp-CrVo-Llt.js +0 -1
- package/web-ui/build/static/lisp-QIAoXzmW.js +0 -1
- package/web-ui/build/static/livecodeserver-DrehOgbf.js +0 -1
- package/web-ui/build/static/livescript-Cm2Yp34x.js +0 -1
- package/web-ui/build/static/livescript-mVYzlrko.js +0 -1
- package/web-ui/build/static/llvm-D6KsQJjh.js +0 -1
- package/web-ui/build/static/llvm-DhIp1o-1.js +0 -1
- package/web-ui/build/static/log-Sj3ocpgB.js +0 -1
- package/web-ui/build/static/lolcode-BSeGnWYG.js +0 -1
- package/web-ui/build/static/lsl-DwgUIp0U.js +0 -1
- package/web-ui/build/static/lua-B7Ot0Oou.js +0 -1
- package/web-ui/build/static/lua-zydwn5-S.js +0 -1
- package/web-ui/build/static/magma-Dgfy2Qny.js +0 -1
- package/web-ui/build/static/makefile-CSjtzdcw.js +0 -1
- package/web-ui/build/static/makefile-DrnEneus.js +0 -1
- package/web-ui/build/static/markdown-D9Ke3tYA.js +0 -1
- package/web-ui/build/static/markdown-DmwKuI2Y.js +0 -1
- package/web-ui/build/static/markup-templating-CikqfHT9.js +0 -1
- package/web-ui/build/static/mathematica-OC0imzI5.js +0 -1
- package/web-ui/build/static/matlab-BlPcqzRw.js +0 -1
- package/web-ui/build/static/matlab-C1iteCkE.js +0 -1
- package/web-ui/build/static/maxima-DecbOh0Y.js +0 -1
- package/web-ui/build/static/maxscript-80cPuIOA.js +0 -1
- package/web-ui/build/static/mel-NI7ysGX2.js +0 -1
- package/web-ui/build/static/mel-r03p1eJo.js +0 -1
- package/web-ui/build/static/mercury-BdNZw6ZU.js +0 -1
- package/web-ui/build/static/mermaid-C1LB7zMJ.js +0 -1
- package/web-ui/build/static/mipsasm-BnZ0cdht.js +0 -1
- package/web-ui/build/static/mizar-BGPNX3WQ.js +0 -1
- package/web-ui/build/static/mizar-CswPcmcG.js +0 -1
- package/web-ui/build/static/mojolicious-rRtgy8Or.js +0 -1
- package/web-ui/build/static/mongodb-CJU0oeix.js +0 -1
- package/web-ui/build/static/monkey-Bj0HaV5-.js +0 -1
- package/web-ui/build/static/monkey-JRYuMIYc.js +0 -1
- package/web-ui/build/static/moonscript-i7e8bkxZ.js +0 -1
- package/web-ui/build/static/moonscript-ldoM156V.js +0 -1
- package/web-ui/build/static/n1ql-C0xs8qWA.js +0 -1
- package/web-ui/build/static/n1ql-DlC-GlVq.js +0 -1
- package/web-ui/build/static/n4js-mIwtIanO.js +0 -1
- package/web-ui/build/static/nand2tetris-hdl-mfHIYPZD.js +0 -1
- package/web-ui/build/static/naniscript-DiDayxx1.js +0 -1
- package/web-ui/build/static/nasm-7uf2nfNC.js +0 -1
- package/web-ui/build/static/neon-BKgOgIAL.js +0 -1
- package/web-ui/build/static/nevod-BlujoQ5k.js +0 -1
- package/web-ui/build/static/nginx-Bb57ubp_.js +0 -1
- package/web-ui/build/static/nginx-DmLU0URp.js +0 -1
- package/web-ui/build/static/nim-CmnPRTHF.js +0 -1
- package/web-ui/build/static/nim-DOReB32c.js +0 -1
- package/web-ui/build/static/nix-BDMn1sgi.js +0 -1
- package/web-ui/build/static/nix-LTHuFEfQ.js +0 -1
- package/web-ui/build/static/node-repl-dxwu8SWp.js +0 -1
- package/web-ui/build/static/nsis-CKD0KqBT.js +0 -1
- package/web-ui/build/static/nsis-IlSwBUak.js +0 -1
- package/web-ui/build/static/objectivec-D4Lo30HV.js +0 -1
- package/web-ui/build/static/objectivec-zmGGqvoM.js +0 -1
- package/web-ui/build/static/ocaml-2uzfqAr8.js +0 -1
- package/web-ui/build/static/ocaml-wF6lV9H4.js +0 -1
- package/web-ui/build/static/opencl-B82Xjnw5.js +0 -1
- package/web-ui/build/static/openqasm-VzVaHpAP.js +0 -1
- package/web-ui/build/static/openscad-B-qK1VfW.js +0 -1
- package/web-ui/build/static/oxygene-BNTVgbsA.js +0 -1
- package/web-ui/build/static/oz-5ZfXBXQY.js +0 -1
- package/web-ui/build/static/parigp-S8JhoJoz.js +0 -1
- package/web-ui/build/static/parser-BZPtbLcv.js +0 -1
- package/web-ui/build/static/parser3-BZRLDHuv.js +0 -1
- package/web-ui/build/static/pascal-GKzqT2Ku.js +0 -1
- package/web-ui/build/static/pascaligo-DnbFz_mr.js +0 -1
- package/web-ui/build/static/pcaxis-DiRsos26.js +0 -1
- package/web-ui/build/static/peoplecode-CMDLbqGB.js +0 -1
- package/web-ui/build/static/perl-BOnBAciC.js +0 -1
- package/web-ui/build/static/perl-fMVLgVTb.js +0 -1
- package/web-ui/build/static/pf-z6xsHHPS.js +0 -1
- package/web-ui/build/static/pgsql-5jHAyGJf.js +0 -1
- package/web-ui/build/static/php-CbG6Jq36.js +0 -1
- package/web-ui/build/static/php-D9yyh70o.js +0 -1
- package/web-ui/build/static/php-extras-CQKSwnMo.js +0 -1
- package/web-ui/build/static/php-template-Ch4UQhUx.js +0 -1
- package/web-ui/build/static/phpdoc-Be7TYcGQ.js +0 -1
- package/web-ui/build/static/plaintext-BsYjBqDy.js +0 -1
- package/web-ui/build/static/plsql-Dc4ePipN.js +0 -1
- package/web-ui/build/static/pony-Cen7DtWb.js +0 -1
- package/web-ui/build/static/powerquery-BIOJ1eUE.js +0 -1
- package/web-ui/build/static/powershell-CbEjJpj7.js +0 -1
- package/web-ui/build/static/powershell-DlceT0ds.js +0 -1
- package/web-ui/build/static/processing-C9GaKPU-.js +0 -1
- package/web-ui/build/static/processing-CTPA3QIV.js +0 -1
- package/web-ui/build/static/profile-CHjz016L.js +0 -1
- package/web-ui/build/static/prolog-BK0g5F4c.js +0 -1
- package/web-ui/build/static/prolog-DrrwUODp.js +0 -1
- package/web-ui/build/static/promql-DftRCUlR.js +0 -1
- package/web-ui/build/static/properties-B122hwLT.js +0 -1
- package/web-ui/build/static/properties-C0m3XIaN.js +0 -1
- package/web-ui/build/static/protobuf-CanIoKel.js +0 -1
- package/web-ui/build/static/protobuf-WvDgzNtD.js +0 -1
- package/web-ui/build/static/psl-JsKwhg_r.js +0 -1
- package/web-ui/build/static/pug-DoQaiAyU.js +0 -1
- package/web-ui/build/static/puppet-CoRftQQB.js +0 -1
- package/web-ui/build/static/puppet-DHgjsvQ8.js +0 -1
- package/web-ui/build/static/pure-BgZIQeOr.js +0 -1
- package/web-ui/build/static/purebasic-BRYfIFBb.js +0 -1
- package/web-ui/build/static/purebasic-DxXSa8gN.js +0 -1
- package/web-ui/build/static/purescript-ChvJvUnk.js +0 -1
- package/web-ui/build/static/python-DqhW0V3z.js +0 -1
- package/web-ui/build/static/python-Dz2FyIQx.js +0 -1
- package/web-ui/build/static/python-repl-Cl3mEb2H.js +0 -1
- package/web-ui/build/static/q-Bg4mQWXp.js +0 -1
- package/web-ui/build/static/q-DwaQK_1p.js +0 -1
- package/web-ui/build/static/qml-D1-fdJvp.js +0 -1
- package/web-ui/build/static/qml-DFsoiY0T.js +0 -1
- package/web-ui/build/static/qore-DdEtFSV5.js +0 -1
- package/web-ui/build/static/qsharp-B_A0OUBX.js +0 -1
- package/web-ui/build/static/r-C3M2HrKx.js +0 -1
- package/web-ui/build/static/r-_EUAt74Q.js +0 -1
- package/web-ui/build/static/racket-B3uAs3VE.js +0 -1
- package/web-ui/build/static/reason-CyAzPvNW.js +0 -1
- package/web-ui/build/static/reasonml-iEzx6ejF.js +0 -1
- package/web-ui/build/static/regex-suWqSnRa.js +0 -1
- package/web-ui/build/static/rego-QeDW60Lx.js +0 -1
- package/web-ui/build/static/renpy-03fEqIYK.js +0 -1
- package/web-ui/build/static/rest-BRJIE-UZ.js +0 -1
- package/web-ui/build/static/rib-DOI_C8C9.js +0 -1
- package/web-ui/build/static/rip-BaEBdknp.js +0 -1
- package/web-ui/build/static/roboconf-DC8IQe4Z.js +0 -1
- package/web-ui/build/static/roboconf-jTu2wKoD.js +0 -1
- package/web-ui/build/static/robotframework-BFp2sQG2.js +0 -1
- package/web-ui/build/static/routeros-Br-GCWs7.js +0 -1
- package/web-ui/build/static/rsl-BpWeUJqw.js +0 -1
- package/web-ui/build/static/ruby-C3nnVoGq.js +0 -1
- package/web-ui/build/static/ruby-DD90V5PL.js +0 -1
- package/web-ui/build/static/ruleslanguage-BflyDdqj.js +0 -1
- package/web-ui/build/static/rust-DtiFFJtC.js +0 -1
- package/web-ui/build/static/rust-uJHZCfXQ.js +0 -1
- package/web-ui/build/static/sas-DUr8rIBf.js +0 -1
- package/web-ui/build/static/sas-POH3vAEy.js +0 -1
- package/web-ui/build/static/sass-D1oLbZQ0.js +0 -1
- package/web-ui/build/static/scala-CDtrRn0l.js +0 -1
- package/web-ui/build/static/scala-VCIKIldH.js +0 -1
- package/web-ui/build/static/scheme-CAWHx2Oj.js +0 -1
- package/web-ui/build/static/scheme-DzKv24tn.js +0 -1
- package/web-ui/build/static/scilab-DuxpEvzV.js +0 -1
- package/web-ui/build/static/scss-BKd4Y-UF.js +0 -1
- package/web-ui/build/static/scss-BpqUKxry.js +0 -1
- package/web-ui/build/static/shell-session-CglnRr2l.js +0 -1
- package/web-ui/build/static/shell-u-Y3PKLQ.js +0 -1
- package/web-ui/build/static/smali-D308KWif.js +0 -1
- package/web-ui/build/static/smali-DYT-jHPu.js +0 -1
- package/web-ui/build/static/smalltalk-BLYA-Ag1.js +0 -1
- package/web-ui/build/static/smalltalk-BdMVmgN0.js +0 -1
- package/web-ui/build/static/smarty-DUYgBrje.js +0 -1
- package/web-ui/build/static/sml-EEhIaAvM.js +0 -1
- package/web-ui/build/static/sml-bQ27koeV.js +0 -1
- package/web-ui/build/static/solidity-U7x7-dFr.js +0 -1
- package/web-ui/build/static/solution-file-Cr03jaqW.js +0 -1
- package/web-ui/build/static/soy-lnGOhaRM.js +0 -1
- package/web-ui/build/static/sparql-BRm44B1P.js +0 -1
- package/web-ui/build/static/splunk-spl-DdrdBOQJ.js +0 -1
- package/web-ui/build/static/sqf-CDtvZjid.js +0 -1
- package/web-ui/build/static/sqf-wr3PtKhW.js +0 -1
- package/web-ui/build/static/sql-B1-8AkNe.js +0 -1
- package/web-ui/build/static/sql-zWEK1lPB.js +0 -1
- package/web-ui/build/static/sql_more-Ck0DuSs3.js +0 -1
- package/web-ui/build/static/squirrel-CfQEIe5h.js +0 -1
- package/web-ui/build/static/stan-BM1Wilpj.js +0 -1
- package/web-ui/build/static/stan-DFPCSU1l.js +0 -1
- package/web-ui/build/static/stata-BJ-qKfEg.js +0 -1
- package/web-ui/build/static/step21-fPKcuR3s.js +0 -1
- package/web-ui/build/static/stylus-BhqK2C03.js +0 -1
- package/web-ui/build/static/stylus-BxloRYSO.js +0 -1
- package/web-ui/build/static/subunit-CueM7bOY.js +0 -1
- package/web-ui/build/static/swift-CPgZZ0ja.js +0 -1
- package/web-ui/build/static/swift-CsEMsJ7g.js +0 -1
- package/web-ui/build/static/systemd-B1Wwkby4.js +0 -1
- package/web-ui/build/static/t4-cs-CL3Ca0dW.js +0 -1
- package/web-ui/build/static/t4-templating-BoV5iKxA.js +0 -1
- package/web-ui/build/static/t4-vb-BKXXzk5n.js +0 -1
- package/web-ui/build/static/taggerscript-aJQMdfVb.js +0 -1
- package/web-ui/build/static/tap-BBfQFbbW.js +0 -1
- package/web-ui/build/static/tap-CmCrAtSH.js +0 -1
- package/web-ui/build/static/tcl-B8xfoxf8.js +0 -1
- package/web-ui/build/static/tcl-CPzoU-PX.js +0 -1
- package/web-ui/build/static/textile-B99mXtsV.js +0 -1
- package/web-ui/build/static/thrift-Cd40Ii7J.js +0 -1
- package/web-ui/build/static/toml-DV5wxyQS.js +0 -1
- package/web-ui/build/static/tp-o2VorAT6.js +0 -1
- package/web-ui/build/static/tremor-Cs0K_i4_.js +0 -1
- package/web-ui/build/static/tsx-KG-mQur8.js +0 -1
- package/web-ui/build/static/tt2-M3GHOvjN.js +0 -1
- package/web-ui/build/static/turtle-D6o0UODZ.js +0 -1
- package/web-ui/build/static/twig-D7LOxPkH.js +0 -1
- package/web-ui/build/static/twig-SHSTj-jA.js +0 -1
- package/web-ui/build/static/typescript-BeIk_BLV.js +0 -1
- package/web-ui/build/static/typescript-Btz-ypJW.js +0 -1
- package/web-ui/build/static/typoscript-7jDBTKMM.js +0 -1
- package/web-ui/build/static/unrealscript-f2f2MAJa.js +0 -1
- package/web-ui/build/static/uorazor-c5VZAS6K.js +0 -1
- package/web-ui/build/static/uri-DY2cDkq-.js +0 -1
- package/web-ui/build/static/v-6ffK7TKq.js +0 -1
- package/web-ui/build/static/vala-BgOkjEeg.js +0 -1
- package/web-ui/build/static/vala-BvuDZGU_.js +0 -1
- package/web-ui/build/static/vbnet-Bdh9clH3.js +0 -1
- package/web-ui/build/static/vbnet-CDpcSndL.js +0 -1
- package/web-ui/build/static/vbscript-dH3gn1bx.js +0 -1
- package/web-ui/build/static/vbscript-html-a_tIfb0-.js +0 -1
- package/web-ui/build/static/velocity-DGDKyukB.js +0 -1
- package/web-ui/build/static/verilog-CtJaE20M.js +0 -1
- package/web-ui/build/static/verilog-CvdiugJe.js +0 -1
- package/web-ui/build/static/vhdl-CN1nxPYJ.js +0 -1
- package/web-ui/build/static/vhdl-JtjHb_oM.js +0 -1
- package/web-ui/build/static/vim-DBRKYGcU.js +0 -1
- package/web-ui/build/static/vim-DQiU261H.js +0 -1
- package/web-ui/build/static/visual-basic-D_daebxW.js +0 -1
- package/web-ui/build/static/warpscript-B4PIoyZp.js +0 -1
- package/web-ui/build/static/wasm-D6_O5K2p.js +0 -1
- package/web-ui/build/static/web-idl-D7BDrII0.js +0 -1
- package/web-ui/build/static/wiki-D-bqO098.js +0 -1
- package/web-ui/build/static/wolfram-NnogXigM.js +0 -1
- package/web-ui/build/static/wren-DwgJaCDU.js +0 -1
- package/web-ui/build/static/x86asm-B9-C3MH5.js +0 -1
- package/web-ui/build/static/xeora-wudvnBkY.js +0 -1
- package/web-ui/build/static/xl-BeBZDETk.js +0 -1
- package/web-ui/build/static/xml-DgNmhWin.js +0 -1
- package/web-ui/build/static/xml-doc-B2RShOT5.js +0 -1
- package/web-ui/build/static/xojo-C0HF7CVl.js +0 -1
- package/web-ui/build/static/xquery-CMss7jIw.js +0 -1
- package/web-ui/build/static/xquery-Dy1YImWg.js +0 -1
- package/web-ui/build/static/yaml--7oDAAKr.js +0 -1
- package/web-ui/build/static/yaml-1-HThDJz.js +0 -1
- package/web-ui/build/static/yang-CxleyLxS.js +0 -1
- package/web-ui/build/static/zephir-B7LMkND2.js +0 -1
- package/web-ui/build/static/zig-DST87v3k.js +0 -1
package/src/tools/memoryTool.js
CHANGED
|
@@ -19,6 +19,8 @@
|
|
|
19
19
|
|
|
20
20
|
import { BaseTool } from './baseTool.js';
|
|
21
21
|
import { getMemoryService, PLAN_TITLE_PREFIX } from '../services/memoryService.js';
|
|
22
|
+
import { MemoryIndexer } from '../services/embeddings/indexers/memoryIndexer.js';
|
|
23
|
+
import { ReminisceIndexer } from '../services/embeddings/indexers/reminisceIndexer.js';
|
|
22
24
|
|
|
23
25
|
/**
|
|
24
26
|
* True if the given memory title is a "working plan" — those are
|
|
@@ -402,7 +404,7 @@ BEST PRACTICES:
|
|
|
402
404
|
*/
|
|
403
405
|
customValidateParameters(params) {
|
|
404
406
|
const errors = [];
|
|
405
|
-
const validActions = ['add', 'update', 'append', 'delete', 'list', 'read', 'search', 'stats', 'reminisce'];
|
|
407
|
+
const validActions = ['add', 'update', 'append', 'delete', 'list', 'read', 'search', 'semantic-search', 'backfill-embeddings', 'reminisce-backfill-embeddings', 'forget-stale', 'publish-to-team', 'search-team', 'unpublish-from-team', 'stats', 'reminisce'];
|
|
406
408
|
|
|
407
409
|
// Normalize to the canonical actions[] shape and validate every action.
|
|
408
410
|
// Accepts both the canonical plural `{actions: [{type, ...}]}` and the
|
|
@@ -450,6 +452,33 @@ BEST PRACTICES:
|
|
|
450
452
|
case 'search':
|
|
451
453
|
if (!a.query) errors.push(`${tag}query is required for search`);
|
|
452
454
|
break;
|
|
455
|
+
case 'semantic-search':
|
|
456
|
+
if (!a.query) errors.push(`${tag}query is required for semantic-search`);
|
|
457
|
+
if (a.topK != null && (!Number.isInteger(a.topK) || a.topK <= 0)) {
|
|
458
|
+
errors.push(`${tag}topK must be a positive integer when provided`);
|
|
459
|
+
}
|
|
460
|
+
break;
|
|
461
|
+
case 'forget-stale':
|
|
462
|
+
if (a.ageDays != null && (!Number.isFinite(a.ageDays) || a.ageDays <= 0)) {
|
|
463
|
+
errors.push(`${tag}ageDays must be a positive number when provided`);
|
|
464
|
+
}
|
|
465
|
+
break;
|
|
466
|
+
case 'publish-to-team':
|
|
467
|
+
if (!a.id) errors.push(`${tag}id is required for publish-to-team (the memory id to publish)`);
|
|
468
|
+
if (!a.teamId) errors.push(`${tag}teamId is required for publish-to-team`);
|
|
469
|
+
break;
|
|
470
|
+
case 'search-team':
|
|
471
|
+
if (!a.teamId) errors.push(`${tag}teamId is required for search-team`);
|
|
472
|
+
if (!a.query) errors.push(`${tag}query is required for search-team`);
|
|
473
|
+
if (a.topK != null && (!Number.isInteger(a.topK) || a.topK <= 0)) {
|
|
474
|
+
errors.push(`${tag}topK must be a positive integer when provided`);
|
|
475
|
+
}
|
|
476
|
+
break;
|
|
477
|
+
case 'unpublish-from-team':
|
|
478
|
+
if (!a.id) errors.push(`${tag}id is required for unpublish-from-team`);
|
|
479
|
+
if (!a.teamId) errors.push(`${tag}teamId is required for unpublish-from-team`);
|
|
480
|
+
break;
|
|
481
|
+
// backfill-embeddings has no required params (re-indexes everything).
|
|
453
482
|
}
|
|
454
483
|
// Length limits (per-action).
|
|
455
484
|
if (a.title && a.title.length > 200) errors.push(`${tag}title cannot exceed 200 characters`);
|
|
@@ -565,9 +594,16 @@ BEST PRACTICES:
|
|
|
565
594
|
case 'delete': return await this._executeDelete(memoryService, agentId, legacyParams);
|
|
566
595
|
case 'list': return await this._executeList(memoryService, agentId, legacyParams);
|
|
567
596
|
case 'read': return await this._executeRead(memoryService, agentId, legacyParams);
|
|
568
|
-
case 'search':
|
|
569
|
-
case '
|
|
570
|
-
case '
|
|
597
|
+
case 'search': return await this._executeSearch(memoryService, agentId, legacyParams);
|
|
598
|
+
case 'semantic-search': return await this._executeSemanticSearch(memoryService, agentId, legacyParams);
|
|
599
|
+
case 'backfill-embeddings': return await this._executeBackfillEmbeddings(memoryService, agentId);
|
|
600
|
+
case 'reminisce-backfill-embeddings': return await this._executeReminisceBackfill(agentId, context);
|
|
601
|
+
case 'forget-stale': return await this._executeForgetStale(memoryService, agentId, legacyParams);
|
|
602
|
+
case 'publish-to-team': return await this._executePublishToTeam(memoryService, agentId, legacyParams);
|
|
603
|
+
case 'search-team': return await this._executeSearchTeam(agentId, legacyParams);
|
|
604
|
+
case 'unpublish-from-team': return await this._executeUnpublishFromTeam(agentId, legacyParams);
|
|
605
|
+
case 'stats': return await this._executeStats(memoryService, agentId);
|
|
606
|
+
case 'reminisce': return await this._executeReminisce(agentId, legacyParams, context);
|
|
571
607
|
default:
|
|
572
608
|
throw new Error(`Unknown memory action: ${type}`);
|
|
573
609
|
}
|
|
@@ -592,6 +628,11 @@ BEST PRACTICES:
|
|
|
592
628
|
expiration: params.expiration
|
|
593
629
|
});
|
|
594
630
|
|
|
631
|
+
// Fire-and-forget index update. Best-effort by design — the indexer's
|
|
632
|
+
// public surface swallows errors and returns a result, but we don't
|
|
633
|
+
// even await it so memory writes never wait on the embedding service.
|
|
634
|
+
this._asyncIndexMemory(agentId, memory);
|
|
635
|
+
|
|
595
636
|
return {
|
|
596
637
|
success: true,
|
|
597
638
|
action: 'add',
|
|
@@ -630,6 +671,9 @@ BEST PRACTICES:
|
|
|
630
671
|
};
|
|
631
672
|
}
|
|
632
673
|
|
|
674
|
+
// Re-index after content change. Fire-and-forget.
|
|
675
|
+
this._asyncIndexMemory(agentId, memory);
|
|
676
|
+
|
|
633
677
|
return {
|
|
634
678
|
success: true,
|
|
635
679
|
action: 'update',
|
|
@@ -667,6 +711,9 @@ BEST PRACTICES:
|
|
|
667
711
|
};
|
|
668
712
|
}
|
|
669
713
|
|
|
714
|
+
// Re-index after content grew. Fire-and-forget.
|
|
715
|
+
this._asyncIndexMemory(agentId, memory);
|
|
716
|
+
|
|
670
717
|
return {
|
|
671
718
|
success: true,
|
|
672
719
|
action: 'append',
|
|
@@ -696,6 +743,9 @@ BEST PRACTICES:
|
|
|
696
743
|
};
|
|
697
744
|
}
|
|
698
745
|
|
|
746
|
+
// Drop the corresponding vector from the index. Fire-and-forget.
|
|
747
|
+
this._asyncRemoveFromIndex(agentId, params.id);
|
|
748
|
+
|
|
699
749
|
return {
|
|
700
750
|
success: true,
|
|
701
751
|
action: 'delete',
|
|
@@ -795,6 +845,577 @@ BEST PRACTICES:
|
|
|
795
845
|
};
|
|
796
846
|
}
|
|
797
847
|
|
|
848
|
+
/**
|
|
849
|
+
* Execute SEMANTIC-SEARCH action — embeddings-backed retrieval over
|
|
850
|
+
* the agent's memory. Falls back to substring search when embeddings
|
|
851
|
+
* are disabled, so the action is always safe to call regardless of
|
|
852
|
+
* configuration. Hybrid mode (semantic + substring via RRF) is the
|
|
853
|
+
* default — preserves exact-match precision while adding paraphrase
|
|
854
|
+
* recall.
|
|
855
|
+
*
|
|
856
|
+
* Params: { query, topK?=10, hybrid?=true }
|
|
857
|
+
*/
|
|
858
|
+
async _executeSemanticSearch(memoryService, agentId, params) {
|
|
859
|
+
const topK = Number.isInteger(params.topK) && params.topK > 0 ? params.topK : 10;
|
|
860
|
+
const hybrid = params.hybrid !== false;
|
|
861
|
+
|
|
862
|
+
const indexer = this._getMemoryIndexer();
|
|
863
|
+
if (!indexer || !indexer.isEnabled) {
|
|
864
|
+
// Graceful fallback: when the user hasn't enabled embeddings yet,
|
|
865
|
+
// return substring results so the action is still useful (and the
|
|
866
|
+
// agent doesn't need to branch on config).
|
|
867
|
+
const results = await memoryService.searchMemories(agentId, params.query);
|
|
868
|
+
return {
|
|
869
|
+
success: true,
|
|
870
|
+
action: 'semantic-search',
|
|
871
|
+
mode: 'substring-fallback',
|
|
872
|
+
query: params.query,
|
|
873
|
+
results,
|
|
874
|
+
message: results.length === 0
|
|
875
|
+
? `Embeddings disabled; substring search found no matches for "${params.query}"`
|
|
876
|
+
: `Embeddings disabled; substring search found ${results.length} memories`,
|
|
877
|
+
};
|
|
878
|
+
}
|
|
879
|
+
|
|
880
|
+
const { hits, error } = await indexer.search(agentId, params.query, { topK, hybrid });
|
|
881
|
+
|
|
882
|
+
// Hydrate hits → full memory objects via memoryService.readMemory.
|
|
883
|
+
// The indexer returns vector-store metadata (title/text) which is a
|
|
884
|
+
// snapshot — fetching live ensures we surface the current content
|
|
885
|
+
// (in case it was updated since the last index sync).
|
|
886
|
+
const hydrated = [];
|
|
887
|
+
for (const h of hits) {
|
|
888
|
+
// eslint-disable-next-line no-await-in-loop
|
|
889
|
+
const mem = await memoryService.readMemory(agentId, h.id);
|
|
890
|
+
if (mem) hydrated.push({ ...mem, score: h.score });
|
|
891
|
+
else hydrated.push({ id: h.id, score: h.score, missing: true, ...h.metadata });
|
|
892
|
+
}
|
|
893
|
+
|
|
894
|
+
return {
|
|
895
|
+
success: !error,
|
|
896
|
+
action: 'semantic-search',
|
|
897
|
+
mode: hybrid ? 'hybrid' : 'semantic',
|
|
898
|
+
query: params.query,
|
|
899
|
+
topK,
|
|
900
|
+
results: hydrated,
|
|
901
|
+
...(error ? { error } : {}),
|
|
902
|
+
message: error
|
|
903
|
+
? `Semantic search failed: ${error}`
|
|
904
|
+
: hydrated.length === 0
|
|
905
|
+
? `No memories matched "${params.query}"`
|
|
906
|
+
: `Found ${hydrated.length} memories ranked by similarity to "${params.query}"`,
|
|
907
|
+
};
|
|
908
|
+
}
|
|
909
|
+
|
|
910
|
+
/**
|
|
911
|
+
* Execute BACKFILL-EMBEDDINGS action — drop the agent's memory index
|
|
912
|
+
* and rebuild it from scratch. Use after enabling embeddings for the
|
|
913
|
+
* first time, after switching providers/models, or whenever the index
|
|
914
|
+
* is suspected stale. Idempotent.
|
|
915
|
+
*/
|
|
916
|
+
async _executeBackfillEmbeddings(memoryService, agentId) {
|
|
917
|
+
const indexer = this._getMemoryIndexer();
|
|
918
|
+
if (!indexer || !indexer.isEnabled) {
|
|
919
|
+
return {
|
|
920
|
+
success: false,
|
|
921
|
+
action: 'backfill-embeddings',
|
|
922
|
+
message: 'Embeddings are not enabled — nothing to backfill. Enable a provider in Settings → Embeddings first.',
|
|
923
|
+
};
|
|
924
|
+
}
|
|
925
|
+
|
|
926
|
+
// Pull every memory for this agent. memoryService.listMemories at
|
|
927
|
+
// 'full' detail returns the full content blob per memory.
|
|
928
|
+
const listing = await memoryService.listMemories(agentId, 'full');
|
|
929
|
+
// listMemories returns { count, grouped }. The 'full' shape gives
|
|
930
|
+
// us per-bucket arrays of memory objects. Flatten + filter.
|
|
931
|
+
const memories = [];
|
|
932
|
+
for (const bucket of Object.values(listing.grouped || {})) {
|
|
933
|
+
for (const m of bucket || []) if (m?.id) memories.push(m);
|
|
934
|
+
}
|
|
935
|
+
|
|
936
|
+
const result = await indexer.backfill(agentId, memories);
|
|
937
|
+
return {
|
|
938
|
+
success: result.ok !== false,
|
|
939
|
+
action: 'backfill-embeddings',
|
|
940
|
+
indexed: result.indexed || 0,
|
|
941
|
+
skipped: result.skipped || 0,
|
|
942
|
+
failed: result.failed || 0,
|
|
943
|
+
...(result.error ? { error: result.error } : {}),
|
|
944
|
+
message: result.ok === false
|
|
945
|
+
? `Backfill failed: ${result.reason || result.error || 'unknown'}`
|
|
946
|
+
: `Re-indexed ${result.indexed || 0} memories for agent ${agentId}` +
|
|
947
|
+
(result.skipped ? ` (skipped ${result.skipped} with no text)` : '') +
|
|
948
|
+
(result.failed ? ` (failed ${result.failed})` : ''),
|
|
949
|
+
};
|
|
950
|
+
}
|
|
951
|
+
|
|
952
|
+
/**
|
|
953
|
+
* Execute FORGET-STALE action — delete memories older than `ageDays`.
|
|
954
|
+
*
|
|
955
|
+
* FadeMem-style soft pruning (arXiv 2601.18642): unbounded memory
|
|
956
|
+
* growth is the real long-term problem. The right answer is graceful
|
|
957
|
+
* decay of unused old memories so the index stays signal-rich.
|
|
958
|
+
*
|
|
959
|
+
* Defaults are conservative — `ageDays=90`, plan/* memories skipped.
|
|
960
|
+
* Pass `dryRun: true` to preview what would be removed. The cascade
|
|
961
|
+
* to the vector index is automatic (memoryService.deleteMemory fires
|
|
962
|
+
* the indexer's deleteOne via _asyncRemoveFromIndex).
|
|
963
|
+
*
|
|
964
|
+
* Params: { ageDays?=90, dryRun?=false, includePlans?=false }
|
|
965
|
+
* @private
|
|
966
|
+
*/
|
|
967
|
+
async _executeForgetStale(memoryService, agentId, params) {
|
|
968
|
+
const ageDays = Number.isFinite(params.ageDays) && params.ageDays > 0 ? params.ageDays : 90;
|
|
969
|
+
const dryRun = !!params.dryRun;
|
|
970
|
+
const includePlans = !!params.includePlans;
|
|
971
|
+
const cutoffMs = Date.now() - ageDays * 24 * 60 * 60 * 1000;
|
|
972
|
+
|
|
973
|
+
// Walk the full memory list. Use 'descriptions' detail — enough to
|
|
974
|
+
// decide what's stale without pulling huge content blobs.
|
|
975
|
+
const listing = await memoryService.listMemories(agentId, 'full');
|
|
976
|
+
const candidates = [];
|
|
977
|
+
for (const bucket of Object.values(listing.grouped || {})) {
|
|
978
|
+
for (const m of bucket || []) {
|
|
979
|
+
if (!m?.id || !m?.createdAt) continue;
|
|
980
|
+
const createdMs = Date.parse(m.createdAt);
|
|
981
|
+
if (!Number.isFinite(createdMs) || createdMs > cutoffMs) continue;
|
|
982
|
+
// Skip plan/* memories unless explicitly included — they're the
|
|
983
|
+
// agent's active working plan, not stale notes.
|
|
984
|
+
if (!includePlans && isPlanTitle(m.title)) continue;
|
|
985
|
+
candidates.push({
|
|
986
|
+
id: m.id,
|
|
987
|
+
title: m.title,
|
|
988
|
+
createdAt: m.createdAt,
|
|
989
|
+
ageDays: Math.round((Date.now() - createdMs) / (24 * 60 * 60 * 1000)),
|
|
990
|
+
});
|
|
991
|
+
}
|
|
992
|
+
}
|
|
993
|
+
|
|
994
|
+
if (dryRun) {
|
|
995
|
+
return {
|
|
996
|
+
success: true,
|
|
997
|
+
action: 'forget-stale',
|
|
998
|
+
dryRun: true,
|
|
999
|
+
thresholdDays: ageDays,
|
|
1000
|
+
candidates,
|
|
1001
|
+
count: candidates.length,
|
|
1002
|
+
message: candidates.length === 0
|
|
1003
|
+
? `No memories older than ${ageDays} days.`
|
|
1004
|
+
: `Would forget ${candidates.length} memories older than ${ageDays} days. Pass dryRun:false to apply.`,
|
|
1005
|
+
};
|
|
1006
|
+
}
|
|
1007
|
+
|
|
1008
|
+
let forgotten = 0;
|
|
1009
|
+
let failed = 0;
|
|
1010
|
+
for (const c of candidates) {
|
|
1011
|
+
try {
|
|
1012
|
+
const ok = await memoryService.deleteMemory(agentId, c.id);
|
|
1013
|
+
if (ok) forgotten++;
|
|
1014
|
+
else failed++;
|
|
1015
|
+
} catch (err) {
|
|
1016
|
+
this.logger?.warn?.('[memoryTool] forget-stale: delete failed', { id: c.id, error: err?.message });
|
|
1017
|
+
failed++;
|
|
1018
|
+
}
|
|
1019
|
+
}
|
|
1020
|
+
|
|
1021
|
+
return {
|
|
1022
|
+
success: failed === 0,
|
|
1023
|
+
action: 'forget-stale',
|
|
1024
|
+
thresholdDays: ageDays,
|
|
1025
|
+
forgotten,
|
|
1026
|
+
failed,
|
|
1027
|
+
message: forgotten === 0 && failed === 0
|
|
1028
|
+
? `No memories older than ${ageDays} days.`
|
|
1029
|
+
: `Forgot ${forgotten} memories older than ${ageDays} days` +
|
|
1030
|
+
(failed ? `, ${failed} deletions failed` : '') + '.',
|
|
1031
|
+
};
|
|
1032
|
+
}
|
|
1033
|
+
|
|
1034
|
+
// ──────────────────────────────────────────────────────────────────
|
|
1035
|
+
// Phase 6c — Team-pool memory (the explicit publish channel)
|
|
1036
|
+
//
|
|
1037
|
+
// Answers the design Q1: per-agent memory stays private by default;
|
|
1038
|
+
// teams are an explicit, ACL-gated sharing surface. Lit-aligned with
|
|
1039
|
+
// arXiv 2505.18279 "Collaborative Memory" (dual-tier private + shared
|
|
1040
|
+
// with read/write policies). Pattern matches Mem0's multi-level
|
|
1041
|
+
// scoping (user_id / agent_id / app_id) — we use Loxia's existing
|
|
1042
|
+
// Teams primitive as the natural sharing boundary.
|
|
1043
|
+
//
|
|
1044
|
+
// ACL: agent must be a member of the team. Membership is read from
|
|
1045
|
+
// stateManager.getTeam(teamId).memberAgentIds — the authoritative
|
|
1046
|
+
// source. We refuse rather than warn so accidental cross-team leaks
|
|
1047
|
+
// are impossible. The check is encapsulated in `_assertTeamMember`.
|
|
1048
|
+
// ──────────────────────────────────────────────────────────────────
|
|
1049
|
+
|
|
1050
|
+
/**
|
|
1051
|
+
* Allow callers to inject a StateManager so ACL lookups can resolve
|
|
1052
|
+
* team membership. Mirrors the platformControl pattern. Without it,
|
|
1053
|
+
* team-scoped actions all fail with a clean error rather than
|
|
1054
|
+
* defaulting open.
|
|
1055
|
+
*/
|
|
1056
|
+
setStateManager(stateManager) {
|
|
1057
|
+
this.stateManager = stateManager;
|
|
1058
|
+
this.logger?.info?.(`[memory] StateManager ${stateManager ? 'attached' : 'detached'}`);
|
|
1059
|
+
}
|
|
1060
|
+
|
|
1061
|
+
/**
|
|
1062
|
+
* Read-only ACL: throws an Error with a user-facing message if the
|
|
1063
|
+
* agent isn't a member of the team. Use inside team-scoped handlers
|
|
1064
|
+
* to gate writes and reads alike.
|
|
1065
|
+
* @private
|
|
1066
|
+
*/
|
|
1067
|
+
async _assertTeamMember(agentId, teamId) {
|
|
1068
|
+
if (!this.stateManager?.getTeam) {
|
|
1069
|
+
throw new Error('Team-scoped memory actions require a StateManager. None is attached.');
|
|
1070
|
+
}
|
|
1071
|
+
const team = await this.stateManager.getTeam(teamId);
|
|
1072
|
+
if (!team) {
|
|
1073
|
+
throw new Error(`Team not found: ${teamId}`);
|
|
1074
|
+
}
|
|
1075
|
+
const members = Array.isArray(team.memberAgentIds) ? team.memberAgentIds : [];
|
|
1076
|
+
if (!members.includes(agentId)) {
|
|
1077
|
+
throw new Error(
|
|
1078
|
+
`Access denied: agent ${agentId} is not a member of team ${teamId}. ` +
|
|
1079
|
+
`Ask a team admin to add you via platformcontrol.add-team-member.`,
|
|
1080
|
+
);
|
|
1081
|
+
}
|
|
1082
|
+
return team;
|
|
1083
|
+
}
|
|
1084
|
+
|
|
1085
|
+
/**
|
|
1086
|
+
* Publish an existing per-agent memory to a team's shared pool. The
|
|
1087
|
+
* memory itself stays in the agent's own pool — `publish` copies its
|
|
1088
|
+
* content into the team's vector index with `publishedBy` metadata.
|
|
1089
|
+
*
|
|
1090
|
+
* Params: { id, teamId }
|
|
1091
|
+
* @private
|
|
1092
|
+
*/
|
|
1093
|
+
async _executePublishToTeam(memoryService, agentId, params) {
|
|
1094
|
+
const indexer = this._getMemoryIndexer();
|
|
1095
|
+
if (!indexer || !indexer.isEnabled) {
|
|
1096
|
+
return {
|
|
1097
|
+
success: false,
|
|
1098
|
+
action: 'publish-to-team',
|
|
1099
|
+
message: 'Embeddings are not enabled. Team-pool memory requires a configured embedding provider — enable one in Settings → Embeddings first.',
|
|
1100
|
+
};
|
|
1101
|
+
}
|
|
1102
|
+
|
|
1103
|
+
let team;
|
|
1104
|
+
try { team = await this._assertTeamMember(agentId, params.teamId); }
|
|
1105
|
+
catch (err) {
|
|
1106
|
+
return { success: false, action: 'publish-to-team', error: err.message };
|
|
1107
|
+
}
|
|
1108
|
+
|
|
1109
|
+
const memory = await memoryService.readMemory(agentId, params.id);
|
|
1110
|
+
if (!memory) {
|
|
1111
|
+
return {
|
|
1112
|
+
success: false,
|
|
1113
|
+
action: 'publish-to-team',
|
|
1114
|
+
error: `Memory not found in your pool: ${params.id}. publish-to-team copies an existing personal memory into the team pool.`,
|
|
1115
|
+
};
|
|
1116
|
+
}
|
|
1117
|
+
|
|
1118
|
+
const result = await indexer.publishToTeam(params.teamId, memory, agentId);
|
|
1119
|
+
return {
|
|
1120
|
+
success: result.indexed === true,
|
|
1121
|
+
action: 'publish-to-team',
|
|
1122
|
+
teamId: params.teamId,
|
|
1123
|
+
teamName: team?.name || params.teamId,
|
|
1124
|
+
memoryId: memory.id,
|
|
1125
|
+
...(result.error ? { error: result.error } : {}),
|
|
1126
|
+
message: result.indexed
|
|
1127
|
+
? `Published "${memory.title}" to team "${team?.name || params.teamId}".`
|
|
1128
|
+
: `Publish failed: ${result.reason || result.error || 'unknown'}`,
|
|
1129
|
+
};
|
|
1130
|
+
}
|
|
1131
|
+
|
|
1132
|
+
/**
|
|
1133
|
+
* Semantic (or hybrid) search over a team's shared memory pool.
|
|
1134
|
+
* Requires team membership — otherwise no read.
|
|
1135
|
+
*
|
|
1136
|
+
* Params: { teamId, query, topK?=10, hybrid?=true }
|
|
1137
|
+
* @private
|
|
1138
|
+
*/
|
|
1139
|
+
async _executeSearchTeam(agentId, params) {
|
|
1140
|
+
const indexer = this._getMemoryIndexer();
|
|
1141
|
+
if (!indexer || !indexer.isEnabled) {
|
|
1142
|
+
return {
|
|
1143
|
+
success: false,
|
|
1144
|
+
action: 'search-team',
|
|
1145
|
+
message: 'Embeddings are not enabled. Team-pool memory requires a configured embedding provider.',
|
|
1146
|
+
};
|
|
1147
|
+
}
|
|
1148
|
+
|
|
1149
|
+
let team;
|
|
1150
|
+
try { team = await this._assertTeamMember(agentId, params.teamId); }
|
|
1151
|
+
catch (err) {
|
|
1152
|
+
return { success: false, action: 'search-team', error: err.message };
|
|
1153
|
+
}
|
|
1154
|
+
|
|
1155
|
+
const topK = Number.isInteger(params.topK) && params.topK > 0 ? params.topK : 10;
|
|
1156
|
+
const hybrid = params.hybrid !== false;
|
|
1157
|
+
const { hits, error } = await indexer.searchTeam(params.teamId, params.query, { topK, hybrid });
|
|
1158
|
+
return {
|
|
1159
|
+
success: !error,
|
|
1160
|
+
action: 'search-team',
|
|
1161
|
+
teamId: params.teamId,
|
|
1162
|
+
teamName: team?.name || params.teamId,
|
|
1163
|
+
query: params.query,
|
|
1164
|
+
mode: hybrid ? 'hybrid' : 'semantic',
|
|
1165
|
+
topK,
|
|
1166
|
+
results: hits,
|
|
1167
|
+
...(error ? { error } : {}),
|
|
1168
|
+
message: error
|
|
1169
|
+
? `Team search failed: ${error}`
|
|
1170
|
+
: hits.length === 0
|
|
1171
|
+
? `No memories matched "${params.query}" in team "${team?.name || params.teamId}".`
|
|
1172
|
+
: `Found ${hits.length} team memories ranked by similarity to "${params.query}".`,
|
|
1173
|
+
};
|
|
1174
|
+
}
|
|
1175
|
+
|
|
1176
|
+
/**
|
|
1177
|
+
* Remove a memory from a team pool. Any team member can unpublish
|
|
1178
|
+
* (no per-author restriction at this layer — keeps the ACL surface
|
|
1179
|
+
* simple; if richer policies are needed later, layer them here).
|
|
1180
|
+
*
|
|
1181
|
+
* Params: { teamId, id }
|
|
1182
|
+
* @private
|
|
1183
|
+
*/
|
|
1184
|
+
async _executeUnpublishFromTeam(agentId, params) {
|
|
1185
|
+
const indexer = this._getMemoryIndexer();
|
|
1186
|
+
if (!indexer || !indexer.isEnabled) {
|
|
1187
|
+
return {
|
|
1188
|
+
success: false,
|
|
1189
|
+
action: 'unpublish-from-team',
|
|
1190
|
+
message: 'Embeddings are not enabled. Team-pool memory requires a configured embedding provider.',
|
|
1191
|
+
};
|
|
1192
|
+
}
|
|
1193
|
+
|
|
1194
|
+
let team;
|
|
1195
|
+
try { team = await this._assertTeamMember(agentId, params.teamId); }
|
|
1196
|
+
catch (err) {
|
|
1197
|
+
return { success: false, action: 'unpublish-from-team', error: err.message };
|
|
1198
|
+
}
|
|
1199
|
+
|
|
1200
|
+
const result = await indexer.unpublishFromTeam(params.teamId, params.id);
|
|
1201
|
+
return {
|
|
1202
|
+
success: result.deleted === true,
|
|
1203
|
+
action: 'unpublish-from-team',
|
|
1204
|
+
teamId: params.teamId,
|
|
1205
|
+
teamName: team?.name || params.teamId,
|
|
1206
|
+
memoryId: params.id,
|
|
1207
|
+
...(result.error ? { error: result.error } : {}),
|
|
1208
|
+
message: result.deleted
|
|
1209
|
+
? `Removed memory ${params.id} from team "${team?.name || params.teamId}".`
|
|
1210
|
+
: `Unpublish failed: ${result.reason || result.error || 'unknown'}`,
|
|
1211
|
+
};
|
|
1212
|
+
}
|
|
1213
|
+
|
|
1214
|
+
/**
|
|
1215
|
+
* Lazy accessor for the per-tool MemoryIndexer.
|
|
1216
|
+
*
|
|
1217
|
+
* Why lazy: the EmbeddingService is attached to aiService AFTER
|
|
1218
|
+
* tools are constructed. Pulling it on first use lets us avoid
|
|
1219
|
+
* construction-time ordering pain.
|
|
1220
|
+
*
|
|
1221
|
+
* Returns null when no embedding service is available (cloud-only
|
|
1222
|
+
* deploys without local provider, brand-new installs, etc.). Callers
|
|
1223
|
+
* MUST check `indexer.isEnabled` before relying on it — the indexer
|
|
1224
|
+
* is a thin shim that itself checks the service's enabled flag.
|
|
1225
|
+
*
|
|
1226
|
+
* @private
|
|
1227
|
+
* @returns {import('../services/embeddings/indexers/memoryIndexer.js').MemoryIndexer | null}
|
|
1228
|
+
*/
|
|
1229
|
+
_getMemoryIndexer() {
|
|
1230
|
+
if (this._memoryIndexer) return this._memoryIndexer;
|
|
1231
|
+
const svc = this.aiService?.getEmbeddingService?.();
|
|
1232
|
+
if (!svc) return null;
|
|
1233
|
+
this._memoryIndexer = new MemoryIndexer({ embeddingService: svc, logger: this.logger });
|
|
1234
|
+
return this._memoryIndexer;
|
|
1235
|
+
}
|
|
1236
|
+
|
|
1237
|
+
/**
|
|
1238
|
+
* Fire-and-forget memory index update. Errors are logged inside the
|
|
1239
|
+
* indexer; we additionally swallow any thrown error here so a runtime
|
|
1240
|
+
* surprise (broken provider, full disk) NEVER affects the memory write.
|
|
1241
|
+
* @private
|
|
1242
|
+
*/
|
|
1243
|
+
_asyncIndexMemory(agentId, memory) {
|
|
1244
|
+
const indexer = this._getMemoryIndexer();
|
|
1245
|
+
if (!indexer || !indexer.isEnabled) return;
|
|
1246
|
+
// Don't await — the result is consumed only via the indexer's own
|
|
1247
|
+
// log. We bury the promise with .catch() so Node doesn't crash on
|
|
1248
|
+
// unhandled rejection if something exotic blows up.
|
|
1249
|
+
indexer.indexOne(agentId, memory).catch(err => {
|
|
1250
|
+
this.logger?.warn?.('[memoryTool] async index failed', { agentId, id: memory?.id, error: err?.message });
|
|
1251
|
+
});
|
|
1252
|
+
}
|
|
1253
|
+
|
|
1254
|
+
/**
|
|
1255
|
+
* Fire-and-forget removal from the index after a delete.
|
|
1256
|
+
* @private
|
|
1257
|
+
*/
|
|
1258
|
+
_asyncRemoveFromIndex(agentId, memoryId) {
|
|
1259
|
+
const indexer = this._getMemoryIndexer();
|
|
1260
|
+
if (!indexer || !indexer.isEnabled) return;
|
|
1261
|
+
indexer.deleteOne(agentId, memoryId).catch(err => {
|
|
1262
|
+
this.logger?.warn?.('[memoryTool] async deleteFromIndex failed', { agentId, id: memoryId, error: err?.message });
|
|
1263
|
+
});
|
|
1264
|
+
}
|
|
1265
|
+
|
|
1266
|
+
/**
|
|
1267
|
+
* Lazy accessor for the per-tool ReminisceIndexer. Same lifetime model
|
|
1268
|
+
* as `_getMemoryIndexer`: cached on the tool instance after first use.
|
|
1269
|
+
* Returns null when the embedding service isn't attached.
|
|
1270
|
+
*
|
|
1271
|
+
* @private
|
|
1272
|
+
* @returns {import('../services/embeddings/indexers/reminisceIndexer.js').ReminisceIndexer | null}
|
|
1273
|
+
*/
|
|
1274
|
+
_getReminisceIndexer() {
|
|
1275
|
+
if (this._reminisceIndexer) return this._reminisceIndexer;
|
|
1276
|
+
const svc = this.aiService?.getEmbeddingService?.();
|
|
1277
|
+
if (!svc) return null;
|
|
1278
|
+
this._reminisceIndexer = new ReminisceIndexer({ embeddingService: svc, logger: this.logger });
|
|
1279
|
+
return this._reminisceIndexer;
|
|
1280
|
+
}
|
|
1281
|
+
|
|
1282
|
+
/**
|
|
1283
|
+
* Reminisce semantic-search handler. Routes through the
|
|
1284
|
+
* ReminisceIndexer; falls back to the existing substring-based
|
|
1285
|
+
* `reminisce.search` when embeddings aren't configured.
|
|
1286
|
+
*
|
|
1287
|
+
* Params: { query, topK?=10, hybrid?=true }
|
|
1288
|
+
* @private
|
|
1289
|
+
*/
|
|
1290
|
+
async _executeReminisceSemanticSearch(agentId, params, context) {
|
|
1291
|
+
const query = typeof params.query === 'string' ? params.query.trim() : '';
|
|
1292
|
+
if (!query) {
|
|
1293
|
+
return {
|
|
1294
|
+
success: false,
|
|
1295
|
+
action: 'reminisce',
|
|
1296
|
+
mode: 'semantic-search',
|
|
1297
|
+
error: 'query is required for reminisce semantic-search',
|
|
1298
|
+
};
|
|
1299
|
+
}
|
|
1300
|
+
const topK = Number.isInteger(params.topK) && params.topK > 0 ? params.topK : 10;
|
|
1301
|
+
const hybrid = params.hybrid !== false;
|
|
1302
|
+
|
|
1303
|
+
const indexer = this._getReminisceIndexer();
|
|
1304
|
+
if (!indexer || !indexer.isEnabled) {
|
|
1305
|
+
// Graceful fallback to the existing substring path so the action
|
|
1306
|
+
// remains useful when embeddings are off. Mirrors memoryTool's
|
|
1307
|
+
// semantic-search fallback shape for consistency.
|
|
1308
|
+
const fb = await this._executeReminisce(agentId, { ...params, mode: 'search' }, context);
|
|
1309
|
+
return {
|
|
1310
|
+
...fb,
|
|
1311
|
+
mode: 'semantic-search',
|
|
1312
|
+
modeUsed: 'substring-fallback',
|
|
1313
|
+
message: 'Embeddings disabled; returned substring search results instead.',
|
|
1314
|
+
};
|
|
1315
|
+
}
|
|
1316
|
+
|
|
1317
|
+
// Run the vector search.
|
|
1318
|
+
const { hits, error } = await indexer.search(agentId, query, { topK, hybrid });
|
|
1319
|
+
|
|
1320
|
+
// Hydrate scored messageIds back to full messages from the archive,
|
|
1321
|
+
// so the agent sees `role`, `content`, `createdAt`, etc. — the same
|
|
1322
|
+
// shape it gets from `reminisce.search`.
|
|
1323
|
+
const agentPool = context?.agentPool;
|
|
1324
|
+
let messages = null;
|
|
1325
|
+
if (agentPool?.getAgent) {
|
|
1326
|
+
const agent = await agentPool.getAgent(agentId);
|
|
1327
|
+
messages = Array.isArray(agent?.conversations?.full?.messages) ? agent.conversations.full.messages : null;
|
|
1328
|
+
}
|
|
1329
|
+
const byId = new Map((messages || []).map(m => [m?.id, m]));
|
|
1330
|
+
const hydrated = hits.map(h => {
|
|
1331
|
+
const m = byId.get(h.messageId);
|
|
1332
|
+
const base = {
|
|
1333
|
+
messageId: h.messageId,
|
|
1334
|
+
score: h.score,
|
|
1335
|
+
chunkIndex: h.chunkIndex,
|
|
1336
|
+
// Default to the index-snapshot text when the live message has
|
|
1337
|
+
// gone missing (rare — only if archive was pruned).
|
|
1338
|
+
snippet: h.chunkText,
|
|
1339
|
+
};
|
|
1340
|
+
if (!m) return { ...base, missing: true };
|
|
1341
|
+
return {
|
|
1342
|
+
...base,
|
|
1343
|
+
role: m.role || 'unknown',
|
|
1344
|
+
at: m.createdAt || m.timestamp || null,
|
|
1345
|
+
content: typeof m.content === 'string' ? m.content : '',
|
|
1346
|
+
};
|
|
1347
|
+
});
|
|
1348
|
+
|
|
1349
|
+
return {
|
|
1350
|
+
success: !error,
|
|
1351
|
+
action: 'reminisce',
|
|
1352
|
+
mode: 'semantic-search',
|
|
1353
|
+
modeUsed: hybrid ? 'hybrid' : 'semantic',
|
|
1354
|
+
query,
|
|
1355
|
+
topK,
|
|
1356
|
+
result: {
|
|
1357
|
+
hits: hydrated,
|
|
1358
|
+
...(error ? { error } : {}),
|
|
1359
|
+
},
|
|
1360
|
+
message: error
|
|
1361
|
+
? `Reminisce semantic search failed: ${error}`
|
|
1362
|
+
: hydrated.length === 0
|
|
1363
|
+
? `No archived messages matched "${query}"`
|
|
1364
|
+
: `Found ${hydrated.length} archived messages ranked by similarity to "${query}"`,
|
|
1365
|
+
};
|
|
1366
|
+
}
|
|
1367
|
+
|
|
1368
|
+
/**
|
|
1369
|
+
* Drop the agent's reminisce index and rebuild from the full
|
|
1370
|
+
* conversation archive. Use after first enabling embeddings, or after
|
|
1371
|
+
* switching provider/model. Idempotent.
|
|
1372
|
+
*
|
|
1373
|
+
* NOTE: this is the canonical entry point for keeping reminisce
|
|
1374
|
+
* semantic-search current today. Auto-indexing on new archive writes
|
|
1375
|
+
* is a planned follow-up; until then, re-run this periodically (or
|
|
1376
|
+
* via a scheduled task) to pick up the latest messages.
|
|
1377
|
+
*
|
|
1378
|
+
* @private
|
|
1379
|
+
*/
|
|
1380
|
+
async _executeReminisceBackfill(agentId, context) {
|
|
1381
|
+
const indexer = this._getReminisceIndexer();
|
|
1382
|
+
if (!indexer || !indexer.isEnabled) {
|
|
1383
|
+
return {
|
|
1384
|
+
success: false,
|
|
1385
|
+
action: 'reminisce-backfill-embeddings',
|
|
1386
|
+
message: 'Embeddings are not enabled — nothing to backfill. Enable a provider in Settings → Embeddings first.',
|
|
1387
|
+
};
|
|
1388
|
+
}
|
|
1389
|
+
|
|
1390
|
+
const agentPool = context?.agentPool;
|
|
1391
|
+
if (!agentPool?.getAgent) {
|
|
1392
|
+
return {
|
|
1393
|
+
success: false,
|
|
1394
|
+
action: 'reminisce-backfill-embeddings',
|
|
1395
|
+
error: 'agentPool is not available on the tool context; cannot read conversation archive',
|
|
1396
|
+
};
|
|
1397
|
+
}
|
|
1398
|
+
const agent = await agentPool.getAgent(agentId);
|
|
1399
|
+
const messages = Array.isArray(agent?.conversations?.full?.messages) ? agent.conversations.full.messages : [];
|
|
1400
|
+
|
|
1401
|
+
const result = await indexer.backfill(agentId, messages);
|
|
1402
|
+
return {
|
|
1403
|
+
success: result.ok !== false && !result.error,
|
|
1404
|
+
action: 'reminisce-backfill-embeddings',
|
|
1405
|
+
indexedMessages: result.indexedMessages || 0,
|
|
1406
|
+
indexedChunks: result.indexedChunks || 0,
|
|
1407
|
+
skipped: result.skipped || 0,
|
|
1408
|
+
failed: result.failed || 0,
|
|
1409
|
+
...(result.error ? { error: result.error } : {}),
|
|
1410
|
+
message: result.ok === false
|
|
1411
|
+
? `Reminisce backfill failed: ${result.reason || result.error || 'unknown'}`
|
|
1412
|
+
: `Re-indexed ${result.indexedMessages || 0} messages` +
|
|
1413
|
+
(result.indexedChunks ? ` (${result.indexedChunks} chunks)` : '') +
|
|
1414
|
+
(result.skipped ? `, skipped ${result.skipped}` : '') +
|
|
1415
|
+
(result.failed ? `, failed ${result.failed}` : ''),
|
|
1416
|
+
};
|
|
1417
|
+
}
|
|
1418
|
+
|
|
798
1419
|
/**
|
|
799
1420
|
* Execute STATS action
|
|
800
1421
|
*/
|
|
@@ -832,7 +1453,7 @@ BEST PRACTICES:
|
|
|
832
1453
|
*/
|
|
833
1454
|
async _executeReminisce(agentId, params, context) {
|
|
834
1455
|
const mode = typeof params.mode === 'string' ? params.mode : '';
|
|
835
|
-
const validModes = ['overview', 'range', 'search', 'around', 'byTool', 'read'];
|
|
1456
|
+
const validModes = ['overview', 'range', 'search', 'semantic-search', 'around', 'byTool', 'read'];
|
|
836
1457
|
if (!validModes.includes(mode)) {
|
|
837
1458
|
return {
|
|
838
1459
|
success: false,
|
|
@@ -841,6 +1462,14 @@ BEST PRACTICES:
|
|
|
841
1462
|
};
|
|
842
1463
|
}
|
|
843
1464
|
|
|
1465
|
+
// Semantic-search has a different shape than the other modes — it
|
|
1466
|
+
// routes through the ReminisceIndexer (vector store) rather than the
|
|
1467
|
+
// conversation-query helpers. Falls back to substring `search` when
|
|
1468
|
+
// embeddings are disabled so the action is always callable.
|
|
1469
|
+
if (mode === 'semantic-search') {
|
|
1470
|
+
return await this._executeReminisceSemanticSearch(agentId, params, context);
|
|
1471
|
+
}
|
|
1472
|
+
|
|
844
1473
|
const agentPool = context?.agentPool;
|
|
845
1474
|
if (!agentPool?.getAgent) {
|
|
846
1475
|
return {
|