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
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* memoryTool tests for the new semantic-search + backfill-embeddings
|
|
3
|
+
* actions, plus the async indexer hooks fired by add/update/append/delete.
|
|
4
|
+
*
|
|
5
|
+
* Pins:
|
|
6
|
+
* - semantic-search with embeddings DISABLED falls back to substring
|
|
7
|
+
* via memoryService.searchMemories (so the action is always callable).
|
|
8
|
+
* - semantic-search with embeddings ENABLED routes through the indexer
|
|
9
|
+
* and hydrates results via readMemory (live content, not snapshot).
|
|
10
|
+
* - add/update/append fire an async indexer.indexOne (best-effort —
|
|
11
|
+
* errors don't break the memory write).
|
|
12
|
+
* - delete fires an async indexer.deleteOne.
|
|
13
|
+
* - backfill-embeddings calls indexer.backfill with the full memory set.
|
|
14
|
+
* - When the underlying indexer signals an error, semantic-search
|
|
15
|
+
* returns { success: false, error } but doesn't throw.
|
|
16
|
+
*
|
|
17
|
+
* Mocks: memoryService (per the existing memoryTool.test.js pattern),
|
|
18
|
+
* plus an injected `aiService` whose `getEmbeddingService` returns a
|
|
19
|
+
* stub. The MemoryIndexer module is also mocked so we can assert the
|
|
20
|
+
* exact calls without depending on the real Indexer's internals.
|
|
21
|
+
*/
|
|
22
|
+
|
|
23
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
24
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
25
|
+
|
|
26
|
+
// ──── mocks ────────────────────────────────────────────────────────
|
|
27
|
+
|
|
28
|
+
const mockMemoryService = {
|
|
29
|
+
initialize: jest.fn().mockResolvedValue(undefined),
|
|
30
|
+
addMemory: jest.fn(),
|
|
31
|
+
updateMemory: jest.fn(),
|
|
32
|
+
appendToMemory: jest.fn(),
|
|
33
|
+
deleteMemory: jest.fn(),
|
|
34
|
+
listMemories: jest.fn(),
|
|
35
|
+
readMemory: jest.fn(),
|
|
36
|
+
searchMemories: jest.fn(),
|
|
37
|
+
getMemoryStats: jest.fn(),
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
jest.unstable_mockModule('../../services/memoryService.js', () => ({
|
|
41
|
+
getMemoryService: jest.fn(() => mockMemoryService),
|
|
42
|
+
PLAN_TITLE_PREFIX: 'plan/',
|
|
43
|
+
}));
|
|
44
|
+
|
|
45
|
+
// Stub the MemoryIndexer module — we want to assert exactly which
|
|
46
|
+
// methods the tool calls without depending on the real indexer's
|
|
47
|
+
// embedding pipeline (the real indexer has its own dedicated tests).
|
|
48
|
+
const mockIndexerInstance = {
|
|
49
|
+
isEnabled: true,
|
|
50
|
+
indexOne: jest.fn().mockResolvedValue({ indexed: true }),
|
|
51
|
+
deleteOne: jest.fn().mockResolvedValue({ deleted: true }),
|
|
52
|
+
indexMany: jest.fn().mockResolvedValue({ indexed: 0, skipped: 0, failed: 0 }),
|
|
53
|
+
backfill: jest.fn().mockResolvedValue({ ok: true, indexed: 3, skipped: 0, failed: 0 }),
|
|
54
|
+
search: jest.fn().mockResolvedValue({ enabled: true, hits: [] }),
|
|
55
|
+
};
|
|
56
|
+
const MockMemoryIndexer = jest.fn(() => mockIndexerInstance);
|
|
57
|
+
|
|
58
|
+
jest.unstable_mockModule('../../services/embeddings/indexers/memoryIndexer.js', () => ({
|
|
59
|
+
MemoryIndexer: MockMemoryIndexer,
|
|
60
|
+
memoryToText: () => '',
|
|
61
|
+
}));
|
|
62
|
+
|
|
63
|
+
const { default: MemoryTool } = await import('../memoryTool.js');
|
|
64
|
+
|
|
65
|
+
// ──── helpers ──────────────────────────────────────────────────────
|
|
66
|
+
|
|
67
|
+
function makeTool({ embeddingsEnabled = true, embeddingService = null } = {}) {
|
|
68
|
+
const logger = createMockLogger();
|
|
69
|
+
const tool = new MemoryTool({}, logger);
|
|
70
|
+
// Reset indexer mock state per test
|
|
71
|
+
mockIndexerInstance.isEnabled = embeddingsEnabled;
|
|
72
|
+
mockIndexerInstance.indexOne.mockClear();
|
|
73
|
+
mockIndexerInstance.deleteOne.mockClear();
|
|
74
|
+
mockIndexerInstance.indexMany.mockClear();
|
|
75
|
+
mockIndexerInstance.backfill.mockClear();
|
|
76
|
+
mockIndexerInstance.search.mockClear();
|
|
77
|
+
MockMemoryIndexer.mockClear();
|
|
78
|
+
// Reset memoryService calls
|
|
79
|
+
for (const fn of Object.values(mockMemoryService)) {
|
|
80
|
+
if (typeof fn?.mockClear === 'function') fn.mockClear();
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
// Attach aiService stub so the tool can find the indexer.
|
|
84
|
+
if (embeddingService !== null) {
|
|
85
|
+
tool.aiService = { getEmbeddingService: () => embeddingService };
|
|
86
|
+
} else {
|
|
87
|
+
tool.aiService = { getEmbeddingService: () => ({ isEnabled: embeddingsEnabled }) };
|
|
88
|
+
}
|
|
89
|
+
// Reset the lazy cache so isEnabled flips between tests.
|
|
90
|
+
tool._memoryIndexer = null;
|
|
91
|
+
return tool;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
const context = { agentId: 'a1' };
|
|
95
|
+
|
|
96
|
+
// ──── async hook tests ────────────────────────────────────────────
|
|
97
|
+
|
|
98
|
+
describe('memoryTool — async indexer hooks', () => {
|
|
99
|
+
test('add fires indexOne with the memory just written', async () => {
|
|
100
|
+
const tool = makeTool();
|
|
101
|
+
const memory = { id: 'm1', title: 'A', content: 'B', createdAt: '2026-05-26T00:00:00Z' };
|
|
102
|
+
mockMemoryService.addMemory.mockResolvedValue(memory);
|
|
103
|
+
|
|
104
|
+
await tool.execute(
|
|
105
|
+
{ actions: [{ type: 'add', title: 'A', content: 'B' }] },
|
|
106
|
+
context,
|
|
107
|
+
);
|
|
108
|
+
|
|
109
|
+
// The fire-and-forget call is awaited inside the test by flushing microtasks.
|
|
110
|
+
await Promise.resolve();
|
|
111
|
+
expect(mockIndexerInstance.indexOne).toHaveBeenCalledWith('a1', memory);
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
test('update fires indexOne with the updated memory', async () => {
|
|
115
|
+
const tool = makeTool();
|
|
116
|
+
const updated = { id: 'm1', title: 'A', content: 'B-new' };
|
|
117
|
+
mockMemoryService.updateMemory.mockResolvedValue(updated);
|
|
118
|
+
|
|
119
|
+
await tool.execute(
|
|
120
|
+
{ actions: [{ type: 'update', id: 'm1', content: 'B-new' }] },
|
|
121
|
+
context,
|
|
122
|
+
);
|
|
123
|
+
|
|
124
|
+
await Promise.resolve();
|
|
125
|
+
expect(mockIndexerInstance.indexOne).toHaveBeenCalledWith('a1', updated);
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
test('append fires indexOne with the grown memory', async () => {
|
|
129
|
+
const tool = makeTool();
|
|
130
|
+
const appended = { id: 'm1', title: 'A', content: 'old\nnew' };
|
|
131
|
+
mockMemoryService.appendToMemory.mockResolvedValue(appended);
|
|
132
|
+
|
|
133
|
+
await tool.execute(
|
|
134
|
+
{ actions: [{ type: 'append', id: 'm1', content: 'new' }] },
|
|
135
|
+
context,
|
|
136
|
+
);
|
|
137
|
+
|
|
138
|
+
await Promise.resolve();
|
|
139
|
+
expect(mockIndexerInstance.indexOne).toHaveBeenCalledWith('a1', appended);
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
test('delete fires deleteOne with the memory id', async () => {
|
|
143
|
+
const tool = makeTool();
|
|
144
|
+
mockMemoryService.deleteMemory.mockResolvedValue(true);
|
|
145
|
+
|
|
146
|
+
await tool.execute(
|
|
147
|
+
{ actions: [{ type: 'delete', id: 'm1' }] },
|
|
148
|
+
context,
|
|
149
|
+
);
|
|
150
|
+
|
|
151
|
+
await Promise.resolve();
|
|
152
|
+
expect(mockIndexerInstance.deleteOne).toHaveBeenCalledWith('a1', 'm1');
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
test('failed memory write does NOT fire indexer', async () => {
|
|
156
|
+
const tool = makeTool();
|
|
157
|
+
mockMemoryService.deleteMemory.mockResolvedValue(false); // not found
|
|
158
|
+
|
|
159
|
+
await tool.execute(
|
|
160
|
+
{ actions: [{ type: 'delete', id: 'missing' }] },
|
|
161
|
+
context,
|
|
162
|
+
);
|
|
163
|
+
|
|
164
|
+
await Promise.resolve();
|
|
165
|
+
expect(mockIndexerInstance.deleteOne).not.toHaveBeenCalled();
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
test('disabled indexer → no async calls (no waste)', async () => {
|
|
169
|
+
const tool = makeTool({ embeddingsEnabled: false });
|
|
170
|
+
mockMemoryService.addMemory.mockResolvedValue({ id: 'm1', title: 'A', content: 'B' });
|
|
171
|
+
|
|
172
|
+
await tool.execute(
|
|
173
|
+
{ actions: [{ type: 'add', title: 'A', content: 'B' }] },
|
|
174
|
+
context,
|
|
175
|
+
);
|
|
176
|
+
|
|
177
|
+
await Promise.resolve();
|
|
178
|
+
expect(mockIndexerInstance.indexOne).not.toHaveBeenCalled();
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
test('indexer error does NOT break the memory write response', async () => {
|
|
182
|
+
const tool = makeTool();
|
|
183
|
+
mockMemoryService.addMemory.mockResolvedValue({ id: 'm1', title: 'A', content: 'B' });
|
|
184
|
+
mockIndexerInstance.indexOne.mockRejectedValueOnce(new Error('boom'));
|
|
185
|
+
|
|
186
|
+
const result = await tool.execute(
|
|
187
|
+
{ actions: [{ type: 'add', title: 'A', content: 'B' }] },
|
|
188
|
+
context,
|
|
189
|
+
);
|
|
190
|
+
|
|
191
|
+
expect(result.success).toBe(true);
|
|
192
|
+
// Wait a microtask for the catch handler to fire so no
|
|
193
|
+
// unhandled-rejection is in flight when the test ends.
|
|
194
|
+
await Promise.resolve();
|
|
195
|
+
await Promise.resolve();
|
|
196
|
+
});
|
|
197
|
+
});
|
|
198
|
+
|
|
199
|
+
// ──── semantic-search tests ───────────────────────────────────────
|
|
200
|
+
|
|
201
|
+
describe('memoryTool — semantic-search action', () => {
|
|
202
|
+
// customValidateParameters is the canonical entry point for the
|
|
203
|
+
// tool-framework validation gate (BaseTool wires it up). Test the
|
|
204
|
+
// validation contract there; execute() itself is intentionally forgiving
|
|
205
|
+
// and falls back to defaults for invalid optional params (topK).
|
|
206
|
+
test('validation: query is required for semantic-search', () => {
|
|
207
|
+
const tool = makeTool();
|
|
208
|
+
const v = tool.customValidateParameters({ actions: [{ type: 'semantic-search' }] });
|
|
209
|
+
expect(v.valid).toBe(false);
|
|
210
|
+
expect(v.errors.join(' ')).toMatch(/query.*semantic-search/i);
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
test('validation: topK must be a positive integer if supplied', () => {
|
|
214
|
+
const tool = makeTool();
|
|
215
|
+
const bad = tool.customValidateParameters({
|
|
216
|
+
actions: [{ type: 'semantic-search', query: 'q', topK: -1 }],
|
|
217
|
+
});
|
|
218
|
+
expect(bad.valid).toBe(false);
|
|
219
|
+
expect(bad.errors.join(' ')).toMatch(/topK/i);
|
|
220
|
+
|
|
221
|
+
const alsoBad = tool.customValidateParameters({
|
|
222
|
+
actions: [{ type: 'semantic-search', query: 'q', topK: 0.5 }],
|
|
223
|
+
});
|
|
224
|
+
expect(alsoBad.valid).toBe(false);
|
|
225
|
+
|
|
226
|
+
const good = tool.customValidateParameters({
|
|
227
|
+
actions: [{ type: 'semantic-search', query: 'q', topK: 5 }],
|
|
228
|
+
});
|
|
229
|
+
expect(good.valid).toBe(true);
|
|
230
|
+
});
|
|
231
|
+
|
|
232
|
+
test('execute(): invalid topK falls back to default 10 (forgiving)', async () => {
|
|
233
|
+
const tool = makeTool();
|
|
234
|
+
mockIndexerInstance.search.mockResolvedValue({ enabled: true, hits: [] });
|
|
235
|
+
|
|
236
|
+
await tool.execute(
|
|
237
|
+
{ actions: [{ type: 'semantic-search', query: 'q', topK: -1 }] },
|
|
238
|
+
context,
|
|
239
|
+
);
|
|
240
|
+
|
|
241
|
+
expect(mockIndexerInstance.search).toHaveBeenCalledWith('a1', 'q', { topK: 10, hybrid: true });
|
|
242
|
+
});
|
|
243
|
+
|
|
244
|
+
test('embeddings DISABLED → falls back to substring search', async () => {
|
|
245
|
+
const tool = makeTool({ embeddingsEnabled: false });
|
|
246
|
+
mockMemoryService.searchMemories.mockResolvedValue([{ id: 'm1', title: 'hit' }]);
|
|
247
|
+
|
|
248
|
+
const r = await tool.execute(
|
|
249
|
+
{ actions: [{ type: 'semantic-search', query: 'hit' }] },
|
|
250
|
+
context,
|
|
251
|
+
);
|
|
252
|
+
|
|
253
|
+
expect(mockIndexerInstance.search).not.toHaveBeenCalled();
|
|
254
|
+
expect(mockMemoryService.searchMemories).toHaveBeenCalledWith('a1', 'hit');
|
|
255
|
+
expect(r.action).toBe('semantic-search');
|
|
256
|
+
expect(r.mode).toBe('substring-fallback');
|
|
257
|
+
expect(r.results).toHaveLength(1);
|
|
258
|
+
});
|
|
259
|
+
|
|
260
|
+
test('embeddings ENABLED → routes through indexer + hydrates via readMemory', async () => {
|
|
261
|
+
const tool = makeTool();
|
|
262
|
+
mockIndexerInstance.search.mockResolvedValue({
|
|
263
|
+
enabled: true,
|
|
264
|
+
hits: [
|
|
265
|
+
{ id: 'm1', score: 0.9, metadata: { title: 'snap-title', text: 'snap' } },
|
|
266
|
+
{ id: 'm2', score: 0.4, metadata: { title: 'other', text: 'snap2' } },
|
|
267
|
+
],
|
|
268
|
+
});
|
|
269
|
+
mockMemoryService.readMemory
|
|
270
|
+
.mockResolvedValueOnce({ id: 'm1', title: 'fresh-title', content: 'live' })
|
|
271
|
+
.mockResolvedValueOnce({ id: 'm2', title: 'fresh-other', content: 'live2' });
|
|
272
|
+
|
|
273
|
+
const r = await tool.execute(
|
|
274
|
+
{ actions: [{ type: 'semantic-search', query: 'something', topK: 3 }] },
|
|
275
|
+
context,
|
|
276
|
+
);
|
|
277
|
+
|
|
278
|
+
expect(mockIndexerInstance.search).toHaveBeenCalledWith('a1', 'something', { topK: 3, hybrid: true });
|
|
279
|
+
expect(r.action).toBe('semantic-search');
|
|
280
|
+
expect(r.mode).toBe('hybrid');
|
|
281
|
+
expect(r.results).toHaveLength(2);
|
|
282
|
+
expect(r.results[0]).toMatchObject({ id: 'm1', title: 'fresh-title', score: 0.9 });
|
|
283
|
+
expect(r.results[1]).toMatchObject({ id: 'm2', title: 'fresh-other', score: 0.4 });
|
|
284
|
+
});
|
|
285
|
+
|
|
286
|
+
test('hybrid:false forwarded to indexer', async () => {
|
|
287
|
+
const tool = makeTool();
|
|
288
|
+
mockIndexerInstance.search.mockResolvedValue({ enabled: true, hits: [] });
|
|
289
|
+
|
|
290
|
+
await tool.execute(
|
|
291
|
+
{ actions: [{ type: 'semantic-search', query: 'q', hybrid: false }] },
|
|
292
|
+
context,
|
|
293
|
+
);
|
|
294
|
+
|
|
295
|
+
expect(mockIndexerInstance.search).toHaveBeenCalledWith('a1', 'q', { topK: 10, hybrid: false });
|
|
296
|
+
});
|
|
297
|
+
|
|
298
|
+
test('missing memory in store: marked as missing in result', async () => {
|
|
299
|
+
const tool = makeTool();
|
|
300
|
+
mockIndexerInstance.search.mockResolvedValue({
|
|
301
|
+
enabled: true,
|
|
302
|
+
hits: [{ id: 'gone', score: 0.5, metadata: { title: 'stale' } }],
|
|
303
|
+
});
|
|
304
|
+
mockMemoryService.readMemory.mockResolvedValue(null);
|
|
305
|
+
|
|
306
|
+
const r = await tool.execute(
|
|
307
|
+
{ actions: [{ type: 'semantic-search', query: 'q' }] },
|
|
308
|
+
context,
|
|
309
|
+
);
|
|
310
|
+
|
|
311
|
+
expect(r.results[0]).toMatchObject({ id: 'gone', missing: true });
|
|
312
|
+
});
|
|
313
|
+
|
|
314
|
+
test('indexer signals error → success:false, error surfaces in result', async () => {
|
|
315
|
+
const tool = makeTool();
|
|
316
|
+
mockIndexerInstance.search.mockResolvedValue({ enabled: true, hits: [], error: 'rate-limited' });
|
|
317
|
+
|
|
318
|
+
const r = await tool.execute(
|
|
319
|
+
{ actions: [{ type: 'semantic-search', query: 'q' }] },
|
|
320
|
+
context,
|
|
321
|
+
);
|
|
322
|
+
|
|
323
|
+
expect(r.success).toBe(false);
|
|
324
|
+
expect(r.error).toBe('rate-limited');
|
|
325
|
+
});
|
|
326
|
+
});
|
|
327
|
+
|
|
328
|
+
// ──── backfill-embeddings ─────────────────────────────────────────
|
|
329
|
+
|
|
330
|
+
describe('memoryTool — backfill-embeddings action', () => {
|
|
331
|
+
test('embeddings DISABLED → clean error message', async () => {
|
|
332
|
+
const tool = makeTool({ embeddingsEnabled: false });
|
|
333
|
+
const r = await tool.execute(
|
|
334
|
+
{ actions: [{ type: 'backfill-embeddings' }] },
|
|
335
|
+
context,
|
|
336
|
+
);
|
|
337
|
+
expect(r.success).toBe(false);
|
|
338
|
+
expect(r.message).toMatch(/not enabled/i);
|
|
339
|
+
expect(mockIndexerInstance.backfill).not.toHaveBeenCalled();
|
|
340
|
+
});
|
|
341
|
+
|
|
342
|
+
test('embeddings ENABLED → walks listMemories(\'full\') and calls indexer.backfill', async () => {
|
|
343
|
+
const tool = makeTool();
|
|
344
|
+
mockMemoryService.listMemories.mockResolvedValue({
|
|
345
|
+
count: 3,
|
|
346
|
+
grouped: {
|
|
347
|
+
'2026-05-25': [{ id: 'm1', title: 'a' }, { id: 'm2', title: 'b' }],
|
|
348
|
+
'2026-05-24': [{ id: 'm3', title: 'c' }],
|
|
349
|
+
},
|
|
350
|
+
});
|
|
351
|
+
|
|
352
|
+
const r = await tool.execute(
|
|
353
|
+
{ actions: [{ type: 'backfill-embeddings' }] },
|
|
354
|
+
context,
|
|
355
|
+
);
|
|
356
|
+
|
|
357
|
+
expect(mockMemoryService.listMemories).toHaveBeenCalledWith('a1', 'full');
|
|
358
|
+
expect(mockIndexerInstance.backfill).toHaveBeenCalledWith(
|
|
359
|
+
'a1',
|
|
360
|
+
expect.arrayContaining([
|
|
361
|
+
expect.objectContaining({ id: 'm1' }),
|
|
362
|
+
expect.objectContaining({ id: 'm2' }),
|
|
363
|
+
expect.objectContaining({ id: 'm3' }),
|
|
364
|
+
]),
|
|
365
|
+
);
|
|
366
|
+
expect(r.success).toBe(true);
|
|
367
|
+
expect(r.indexed).toBe(3);
|
|
368
|
+
});
|
|
369
|
+
|
|
370
|
+
test('reports skipped + failed counts from indexer', async () => {
|
|
371
|
+
const tool = makeTool();
|
|
372
|
+
mockMemoryService.listMemories.mockResolvedValue({
|
|
373
|
+
count: 2,
|
|
374
|
+
grouped: { '2026-05-25': [{ id: 'm1' }, { id: 'm2' }] },
|
|
375
|
+
});
|
|
376
|
+
mockIndexerInstance.backfill.mockResolvedValue({
|
|
377
|
+
ok: true, indexed: 1, skipped: 1, failed: 0,
|
|
378
|
+
});
|
|
379
|
+
|
|
380
|
+
const r = await tool.execute(
|
|
381
|
+
{ actions: [{ type: 'backfill-embeddings' }] },
|
|
382
|
+
context,
|
|
383
|
+
);
|
|
384
|
+
|
|
385
|
+
expect(r.indexed).toBe(1);
|
|
386
|
+
expect(r.skipped).toBe(1);
|
|
387
|
+
expect(r.message).toMatch(/skipped 1/);
|
|
388
|
+
});
|
|
389
|
+
|
|
390
|
+
test('indexer failure surfaces in result', async () => {
|
|
391
|
+
const tool = makeTool();
|
|
392
|
+
mockMemoryService.listMemories.mockResolvedValue({ count: 1, grouped: {} });
|
|
393
|
+
mockIndexerInstance.backfill.mockResolvedValue({
|
|
394
|
+
ok: false, reason: 'disabled',
|
|
395
|
+
});
|
|
396
|
+
|
|
397
|
+
const r = await tool.execute(
|
|
398
|
+
{ actions: [{ type: 'backfill-embeddings' }] },
|
|
399
|
+
context,
|
|
400
|
+
);
|
|
401
|
+
|
|
402
|
+
expect(r.success).toBe(false);
|
|
403
|
+
expect(r.message).toMatch(/disabled/);
|
|
404
|
+
});
|
|
405
|
+
});
|
|
@@ -0,0 +1,293 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* memoryTool team-pool tests (Phase 6c).
|
|
3
|
+
*
|
|
4
|
+
* Pins the publish / search / unpublish action contracts and the ACL
|
|
5
|
+
* boundary (StateManager.getTeam lookup → membership check).
|
|
6
|
+
*
|
|
7
|
+
* Pins:
|
|
8
|
+
* - publish-to-team: ACL refuses non-member; copies an existing
|
|
9
|
+
* personal memory into the team's pool via indexer.publishToTeam.
|
|
10
|
+
* - search-team: ACL refuses non-member; forwards to indexer.searchTeam.
|
|
11
|
+
* - unpublish-from-team: ACL refuses non-member; forwards to
|
|
12
|
+
* indexer.unpublishFromTeam.
|
|
13
|
+
* - Without StateManager attached, all team actions fail cleanly
|
|
14
|
+
* (defaulting open would be a privacy bug).
|
|
15
|
+
* - Validation: publish needs id + teamId; search-team needs teamId + query.
|
|
16
|
+
* - Memory-not-found on publish surfaces a useful error.
|
|
17
|
+
* - Disabled embeddings → clean error, no indexer call.
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
import { jest, describe, test, expect, beforeEach } from '@jest/globals';
|
|
21
|
+
import { createMockLogger } from '../../__test-utils__/mockFactories.js';
|
|
22
|
+
|
|
23
|
+
const mockMemoryService = {
|
|
24
|
+
initialize: jest.fn().mockResolvedValue(undefined),
|
|
25
|
+
addMemory: jest.fn(),
|
|
26
|
+
updateMemory: jest.fn(),
|
|
27
|
+
appendToMemory: jest.fn(),
|
|
28
|
+
deleteMemory: jest.fn(),
|
|
29
|
+
listMemories: jest.fn(),
|
|
30
|
+
readMemory: jest.fn(),
|
|
31
|
+
searchMemories: jest.fn(),
|
|
32
|
+
getMemoryStats: jest.fn(),
|
|
33
|
+
};
|
|
34
|
+
jest.unstable_mockModule('../../services/memoryService.js', () => ({
|
|
35
|
+
getMemoryService: jest.fn(() => mockMemoryService),
|
|
36
|
+
PLAN_TITLE_PREFIX: 'plan/',
|
|
37
|
+
}));
|
|
38
|
+
|
|
39
|
+
const mockIndexerInstance = {
|
|
40
|
+
isEnabled: true,
|
|
41
|
+
indexOne: jest.fn().mockResolvedValue({ indexed: true }),
|
|
42
|
+
deleteOne: jest.fn().mockResolvedValue({ deleted: true }),
|
|
43
|
+
indexMany: jest.fn(),
|
|
44
|
+
backfill: jest.fn(),
|
|
45
|
+
search: jest.fn().mockResolvedValue({ enabled: true, hits: [] }),
|
|
46
|
+
publishToTeam: jest.fn().mockResolvedValue({ indexed: true }),
|
|
47
|
+
unpublishFromTeam: jest.fn().mockResolvedValue({ deleted: true }),
|
|
48
|
+
searchTeam: jest.fn().mockResolvedValue({ enabled: true, hits: [] }),
|
|
49
|
+
teamStats: jest.fn().mockResolvedValue({ count: 0, enabled: true }),
|
|
50
|
+
};
|
|
51
|
+
jest.unstable_mockModule('../../services/embeddings/indexers/memoryIndexer.js', () => ({
|
|
52
|
+
MemoryIndexer: jest.fn(() => mockIndexerInstance),
|
|
53
|
+
memoryToText: () => '',
|
|
54
|
+
}));
|
|
55
|
+
|
|
56
|
+
jest.unstable_mockModule('../../services/embeddings/indexers/reminisceIndexer.js', () => ({
|
|
57
|
+
ReminisceIndexer: jest.fn(() => ({ isEnabled: false })),
|
|
58
|
+
messageToText: () => '',
|
|
59
|
+
estimateMessageTokens: () => 0,
|
|
60
|
+
}));
|
|
61
|
+
|
|
62
|
+
const { default: MemoryTool } = await import('../memoryTool.js');
|
|
63
|
+
|
|
64
|
+
function makeTool({
|
|
65
|
+
embeddingsEnabled = true,
|
|
66
|
+
team = { id: 'team-A', name: 'Team Alpha', memberAgentIds: ['agent-self', 'agent-other'] },
|
|
67
|
+
withStateManager = true,
|
|
68
|
+
} = {}) {
|
|
69
|
+
const tool = new MemoryTool({}, createMockLogger());
|
|
70
|
+
mockIndexerInstance.isEnabled = embeddingsEnabled;
|
|
71
|
+
for (const fn of Object.values(mockIndexerInstance)) {
|
|
72
|
+
if (typeof fn?.mockClear === 'function') fn.mockClear();
|
|
73
|
+
}
|
|
74
|
+
for (const fn of Object.values(mockMemoryService)) {
|
|
75
|
+
if (typeof fn?.mockClear === 'function') fn.mockClear();
|
|
76
|
+
}
|
|
77
|
+
tool.aiService = { getEmbeddingService: () => ({ isEnabled: embeddingsEnabled }) };
|
|
78
|
+
tool._memoryIndexer = null;
|
|
79
|
+
if (withStateManager) {
|
|
80
|
+
const stateManager = {
|
|
81
|
+
getTeam: jest.fn(async (id) => (team && team.id === id ? team : null)),
|
|
82
|
+
};
|
|
83
|
+
tool.setStateManager(stateManager);
|
|
84
|
+
return { tool, stateManager };
|
|
85
|
+
}
|
|
86
|
+
return { tool, stateManager: null };
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const context = { agentId: 'agent-self' };
|
|
90
|
+
|
|
91
|
+
// ─── validation ─────────────────────────────────────────────────────
|
|
92
|
+
|
|
93
|
+
describe('memoryTool — team-pool validation', () => {
|
|
94
|
+
test('publish-to-team requires both id and teamId', () => {
|
|
95
|
+
const { tool } = makeTool();
|
|
96
|
+
const v1 = tool.customValidateParameters({ actions: [{ type: 'publish-to-team', teamId: 'team-A' }] });
|
|
97
|
+
const v2 = tool.customValidateParameters({ actions: [{ type: 'publish-to-team', id: 'mem-1' }] });
|
|
98
|
+
const v3 = tool.customValidateParameters({ actions: [{ type: 'publish-to-team', id: 'mem-1', teamId: 'team-A' }] });
|
|
99
|
+
expect(v1.valid).toBe(false);
|
|
100
|
+
expect(v2.valid).toBe(false);
|
|
101
|
+
expect(v3.valid).toBe(true);
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
test('search-team requires teamId and query', () => {
|
|
105
|
+
const { tool } = makeTool();
|
|
106
|
+
expect(tool.customValidateParameters({ actions: [{ type: 'search-team', query: 'q' }] }).valid).toBe(false);
|
|
107
|
+
expect(tool.customValidateParameters({ actions: [{ type: 'search-team', teamId: 'team-A' }] }).valid).toBe(false);
|
|
108
|
+
expect(tool.customValidateParameters({ actions: [{ type: 'search-team', teamId: 'team-A', query: 'q' }] }).valid).toBe(true);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
test('unpublish-from-team requires id and teamId', () => {
|
|
112
|
+
const { tool } = makeTool();
|
|
113
|
+
expect(tool.customValidateParameters({ actions: [{ type: 'unpublish-from-team', id: 'mem-1' }] }).valid).toBe(false);
|
|
114
|
+
expect(tool.customValidateParameters({ actions: [{ type: 'unpublish-from-team', teamId: 'team-A' }] }).valid).toBe(false);
|
|
115
|
+
expect(tool.customValidateParameters({ actions: [{ type: 'unpublish-from-team', id: 'mem-1', teamId: 'team-A' }] }).valid).toBe(true);
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
// ─── ACL ────────────────────────────────────────────────────────────
|
|
120
|
+
|
|
121
|
+
describe('memoryTool — team-pool ACL', () => {
|
|
122
|
+
test('non-member refused on publish-to-team', async () => {
|
|
123
|
+
const { tool } = makeTool({
|
|
124
|
+
team: { id: 'team-A', name: 'Team Alpha', memberAgentIds: ['agent-other'] }, // self not in
|
|
125
|
+
});
|
|
126
|
+
const r = await tool.execute(
|
|
127
|
+
{ actions: [{ type: 'publish-to-team', id: 'mem-1', teamId: 'team-A' }] },
|
|
128
|
+
context,
|
|
129
|
+
);
|
|
130
|
+
expect(r.success).toBe(false);
|
|
131
|
+
expect(r.error).toMatch(/Access denied/i);
|
|
132
|
+
expect(mockIndexerInstance.publishToTeam).not.toHaveBeenCalled();
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
test('non-member refused on search-team', async () => {
|
|
136
|
+
const { tool } = makeTool({
|
|
137
|
+
team: { id: 'team-A', memberAgentIds: [] },
|
|
138
|
+
});
|
|
139
|
+
const r = await tool.execute(
|
|
140
|
+
{ actions: [{ type: 'search-team', teamId: 'team-A', query: 'q' }] },
|
|
141
|
+
context,
|
|
142
|
+
);
|
|
143
|
+
expect(r.success).toBe(false);
|
|
144
|
+
expect(r.error).toMatch(/Access denied/i);
|
|
145
|
+
expect(mockIndexerInstance.searchTeam).not.toHaveBeenCalled();
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
test('non-member refused on unpublish-from-team', async () => {
|
|
149
|
+
const { tool } = makeTool({
|
|
150
|
+
team: { id: 'team-A', memberAgentIds: ['agent-other'] },
|
|
151
|
+
});
|
|
152
|
+
const r = await tool.execute(
|
|
153
|
+
{ actions: [{ type: 'unpublish-from-team', teamId: 'team-A', id: 'mem-1' }] },
|
|
154
|
+
context,
|
|
155
|
+
);
|
|
156
|
+
expect(r.success).toBe(false);
|
|
157
|
+
expect(r.error).toMatch(/Access denied/i);
|
|
158
|
+
expect(mockIndexerInstance.unpublishFromTeam).not.toHaveBeenCalled();
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
test('unknown team → clean error', async () => {
|
|
162
|
+
const { tool } = makeTool({ team: null });
|
|
163
|
+
const r = await tool.execute(
|
|
164
|
+
{ actions: [{ type: 'publish-to-team', id: 'mem-1', teamId: 'team-unknown' }] },
|
|
165
|
+
context,
|
|
166
|
+
);
|
|
167
|
+
expect(r.success).toBe(false);
|
|
168
|
+
expect(r.error).toMatch(/Team not found/);
|
|
169
|
+
});
|
|
170
|
+
|
|
171
|
+
test('without StateManager attached, ALL team actions refuse (no default-open)', async () => {
|
|
172
|
+
const { tool } = makeTool({ withStateManager: false });
|
|
173
|
+
const r1 = await tool.execute(
|
|
174
|
+
{ actions: [{ type: 'publish-to-team', id: 'mem-1', teamId: 'team-A' }] },
|
|
175
|
+
context,
|
|
176
|
+
);
|
|
177
|
+
const r2 = await tool.execute(
|
|
178
|
+
{ actions: [{ type: 'search-team', teamId: 'team-A', query: 'q' }] },
|
|
179
|
+
context,
|
|
180
|
+
);
|
|
181
|
+
expect(r1.success).toBe(false);
|
|
182
|
+
expect(r1.error).toMatch(/StateManager/);
|
|
183
|
+
expect(r2.success).toBe(false);
|
|
184
|
+
expect(r2.error).toMatch(/StateManager/);
|
|
185
|
+
});
|
|
186
|
+
});
|
|
187
|
+
|
|
188
|
+
// ─── happy paths ────────────────────────────────────────────────────
|
|
189
|
+
|
|
190
|
+
describe('memoryTool — team-pool happy paths', () => {
|
|
191
|
+
test('publish-to-team: reads memory from agent\'s pool, calls indexer.publishToTeam with publishedBy', async () => {
|
|
192
|
+
const { tool } = makeTool();
|
|
193
|
+
const memory = { id: 'mem-1', title: 'Shared note', content: 'useful', createdAt: '2026-05-26T00:00:00Z' };
|
|
194
|
+
mockMemoryService.readMemory.mockResolvedValue(memory);
|
|
195
|
+
|
|
196
|
+
const r = await tool.execute(
|
|
197
|
+
{ actions: [{ type: 'publish-to-team', id: 'mem-1', teamId: 'team-A' }] },
|
|
198
|
+
context,
|
|
199
|
+
);
|
|
200
|
+
|
|
201
|
+
expect(mockMemoryService.readMemory).toHaveBeenCalledWith('agent-self', 'mem-1');
|
|
202
|
+
expect(mockIndexerInstance.publishToTeam).toHaveBeenCalledWith('team-A', memory, 'agent-self');
|
|
203
|
+
expect(r.success).toBe(true);
|
|
204
|
+
expect(r.action).toBe('publish-to-team');
|
|
205
|
+
expect(r.teamId).toBe('team-A');
|
|
206
|
+
expect(r.teamName).toBe('Team Alpha');
|
|
207
|
+
expect(r.message).toMatch(/Published/);
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
test('publish-to-team: memory not found → clean error, no indexer call', async () => {
|
|
211
|
+
const { tool } = makeTool();
|
|
212
|
+
mockMemoryService.readMemory.mockResolvedValue(null);
|
|
213
|
+
const r = await tool.execute(
|
|
214
|
+
{ actions: [{ type: 'publish-to-team', id: 'missing', teamId: 'team-A' }] },
|
|
215
|
+
context,
|
|
216
|
+
);
|
|
217
|
+
expect(r.success).toBe(false);
|
|
218
|
+
expect(r.error).toMatch(/not found/i);
|
|
219
|
+
expect(mockIndexerInstance.publishToTeam).not.toHaveBeenCalled();
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
test('search-team: forwards query + topK + hybrid to indexer', async () => {
|
|
223
|
+
const { tool } = makeTool();
|
|
224
|
+
mockIndexerInstance.searchTeam.mockResolvedValue({
|
|
225
|
+
enabled: true,
|
|
226
|
+
hits: [
|
|
227
|
+
{ id: 'mem-1', score: 0.9, metadata: { title: 'team note', publishedBy: 'agent-other' } },
|
|
228
|
+
],
|
|
229
|
+
});
|
|
230
|
+
|
|
231
|
+
const r = await tool.execute(
|
|
232
|
+
{ actions: [{ type: 'search-team', teamId: 'team-A', query: 'docker tips', topK: 3, hybrid: false }] },
|
|
233
|
+
context,
|
|
234
|
+
);
|
|
235
|
+
|
|
236
|
+
expect(mockIndexerInstance.searchTeam).toHaveBeenCalledWith(
|
|
237
|
+
'team-A', 'docker tips', { topK: 3, hybrid: false },
|
|
238
|
+
);
|
|
239
|
+
expect(r.success).toBe(true);
|
|
240
|
+
expect(r.results).toHaveLength(1);
|
|
241
|
+
expect(r.mode).toBe('semantic');
|
|
242
|
+
});
|
|
243
|
+
|
|
244
|
+
test('unpublish-from-team: forwards to indexer.unpublishFromTeam', async () => {
|
|
245
|
+
const { tool } = makeTool();
|
|
246
|
+
const r = await tool.execute(
|
|
247
|
+
{ actions: [{ type: 'unpublish-from-team', id: 'mem-1', teamId: 'team-A' }] },
|
|
248
|
+
context,
|
|
249
|
+
);
|
|
250
|
+
expect(mockIndexerInstance.unpublishFromTeam).toHaveBeenCalledWith('team-A', 'mem-1');
|
|
251
|
+
expect(r.success).toBe(true);
|
|
252
|
+
expect(r.action).toBe('unpublish-from-team');
|
|
253
|
+
});
|
|
254
|
+
|
|
255
|
+
test('indexer error surfaces in the result without throwing', async () => {
|
|
256
|
+
const { tool } = makeTool();
|
|
257
|
+
mockMemoryService.readMemory.mockResolvedValue({ id: 'mem-1', title: 't', content: 'c' });
|
|
258
|
+
mockIndexerInstance.publishToTeam.mockResolvedValue({ indexed: false, reason: 'error', error: 'rate-limited' });
|
|
259
|
+
|
|
260
|
+
const r = await tool.execute(
|
|
261
|
+
{ actions: [{ type: 'publish-to-team', id: 'mem-1', teamId: 'team-A' }] },
|
|
262
|
+
context,
|
|
263
|
+
);
|
|
264
|
+
|
|
265
|
+
expect(r.success).toBe(false);
|
|
266
|
+
expect(r.error).toBe('rate-limited');
|
|
267
|
+
});
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
// ─── disabled embeddings ────────────────────────────────────────────
|
|
271
|
+
|
|
272
|
+
describe('memoryTool — team-pool when embeddings disabled', () => {
|
|
273
|
+
test('publish-to-team: clean error, no ACL check (no point checking when no storage)', async () => {
|
|
274
|
+
const { tool, stateManager } = makeTool({ embeddingsEnabled: false });
|
|
275
|
+
const r = await tool.execute(
|
|
276
|
+
{ actions: [{ type: 'publish-to-team', id: 'mem-1', teamId: 'team-A' }] },
|
|
277
|
+
context,
|
|
278
|
+
);
|
|
279
|
+
expect(r.success).toBe(false);
|
|
280
|
+
expect(r.message).toMatch(/not enabled/i);
|
|
281
|
+
expect(stateManager.getTeam).not.toHaveBeenCalled();
|
|
282
|
+
});
|
|
283
|
+
|
|
284
|
+
test('search-team: clean error', async () => {
|
|
285
|
+
const { tool } = makeTool({ embeddingsEnabled: false });
|
|
286
|
+
const r = await tool.execute(
|
|
287
|
+
{ actions: [{ type: 'search-team', teamId: 'team-A', query: 'q' }] },
|
|
288
|
+
context,
|
|
289
|
+
);
|
|
290
|
+
expect(r.success).toBe(false);
|
|
291
|
+
expect(r.message).toMatch(/not enabled/i);
|
|
292
|
+
});
|
|
293
|
+
});
|