onbuzz 4.9.0 → 4.9.1
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/core/__tests__/agentScheduler.autoRecall.test.js +215 -0
- package/src/core/__tests__/agentScheduler.errorCategorisation.test.js +169 -0
- package/src/core/agentScheduler.js +182 -36
- package/src/index.js +63 -1
- package/src/interfaces/webServer.js +90 -0
- 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/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-CTztA3Xo.js +1 -0
- package/web-ui/build/static/abap-BsUhLmBp.js +1 -0
- package/web-ui/build/static/abnf-CGKV2y5s.js +1 -0
- package/web-ui/build/static/abnf-vQPGuzu_.js +1 -0
- package/web-ui/build/static/accesslog-mUZocN9d.js +1 -0
- package/web-ui/build/static/actionscript-BmCHyr7v.js +1 -0
- package/web-ui/build/static/actionscript-Cc5vZvFE.js +1 -0
- package/web-ui/build/static/ada-BHR9NMNv.js +1 -0
- package/web-ui/build/static/ada-DnxQs2b9.js +1 -0
- package/web-ui/build/static/agda-CHEWVCEZ.js +1 -0
- package/web-ui/build/static/al-C0otNZjc.js +1 -0
- package/web-ui/build/static/angelscript-Co5e7ZdR.js +1 -0
- package/web-ui/build/static/antlr4-Dkky4AXR.js +1 -0
- package/web-ui/build/static/apache-BJkYIuV-.js +1 -0
- package/web-ui/build/static/apacheconf-XLif_lM5.js +1 -0
- package/web-ui/build/static/apex-DiKnugSK.js +1 -0
- package/web-ui/build/static/apl-R5OItFx8.js +1 -0
- package/web-ui/build/static/applescript-D8uiCoXI.js +1 -0
- package/web-ui/build/static/applescript-e5KOVzz4.js +1 -0
- package/web-ui/build/static/aql-Cvy5hwR1.js +1 -0
- package/web-ui/build/static/arcade-0iAjFk8w.js +1 -0
- package/web-ui/build/static/arduino-BJeuGqAT.js +1 -0
- package/web-ui/build/static/arduino-QJJjnM1j.js +1 -0
- package/web-ui/build/static/arff-C-i_E_-B.js +1 -0
- package/web-ui/build/static/armasm-ukFQKHGn.js +1 -0
- package/web-ui/build/static/asciidoc-B49qqHJJ.js +1 -0
- package/web-ui/build/static/asciidoc-Nkm1Ylrd.js +1 -0
- package/web-ui/build/static/asm6502-CMiM3nZs.js +1 -0
- package/web-ui/build/static/asmatmel-DG9XzIBf.js +1 -0
- package/web-ui/build/static/aspectj-DjRutrRk.js +1 -0
- package/web-ui/build/static/aspnet-DCNVRVi9.js +1 -0
- package/web-ui/build/static/autohotkey-C7eyvps0.js +1 -0
- package/web-ui/build/static/autohotkey-CiaZi-WO.js +1 -0
- package/web-ui/build/static/autoit-CaKUQkux.js +1 -0
- package/web-ui/build/static/autoit-D-CUHQgt.js +1 -0
- package/web-ui/build/static/avisynth-DFP3h4zu.js +1 -0
- package/web-ui/build/static/avrasm-BqvUj3fg.js +1 -0
- package/web-ui/build/static/avro-idl-D3l0ptuQ.js +1 -0
- package/web-ui/build/static/awk-BmDxAZFj.js +1 -0
- package/web-ui/build/static/axapta-B424jrgT.js +1 -0
- package/web-ui/build/static/bash-CgAffr8Z.js +1 -0
- package/web-ui/build/static/bash-D41aILLG.js +1 -0
- package/web-ui/build/static/basic-5DFTo35K.js +1 -0
- package/web-ui/build/static/basic-BONYG7D2.js +1 -0
- package/web-ui/build/static/batch-BnaDGMwS.js +1 -0
- package/web-ui/build/static/bbcode-Daujj4hU.js +1 -0
- package/web-ui/build/static/bicep-CXidcIK5.js +1 -0
- package/web-ui/build/static/birb-CcOzsnqB.js +1 -0
- package/web-ui/build/static/bison-rq0w5JFF.js +1 -0
- package/web-ui/build/static/bnf-C4uK1dK8.js +1 -0
- package/web-ui/build/static/bnf-CvXZ9crt.js +1 -0
- package/web-ui/build/static/brainfuck-B5Ezdg2y.js +1 -0
- package/web-ui/build/static/brainfuck-BZaTfZ97.js +1 -0
- package/web-ui/build/static/brightscript-D_2WBVxt.js +1 -0
- package/web-ui/build/static/bro-BD7GT6j_.js +1 -0
- package/web-ui/build/static/bsl-Bh-qcQ3w.js +1 -0
- package/web-ui/build/static/c-DNmZz1iT.js +1 -0
- package/web-ui/build/static/c-dUrSOcB2.js +1 -0
- package/web-ui/build/static/c-like-DfzKY8Uu.js +1 -0
- package/web-ui/build/static/cal-DgrFs4te.js +1 -0
- package/web-ui/build/static/capnproto-BxFR2k8w.js +1 -0
- package/web-ui/build/static/ceylon-B2Q7BIPM.js +1 -0
- package/web-ui/build/static/cfscript-DeaR8rww.js +1 -0
- package/web-ui/build/static/chaiscript-BeBIoz6b.js +1 -0
- package/web-ui/build/static/cil-YHiHOb4c.js +1 -0
- package/web-ui/build/static/clean-BgOl_0cN.js +1 -0
- package/web-ui/build/static/clojure-BlgOza7C.js +1 -0
- package/web-ui/build/static/clojure-PlKRYx3q.js +1 -0
- package/web-ui/build/static/clojure-repl-Dv2_THNB.js +1 -0
- package/web-ui/build/static/cmake-Ccf43gsy.js +1 -0
- package/web-ui/build/static/cmake-Dah_b5tK.js +1 -0
- package/web-ui/build/static/cobol-o9YRDzXA.js +1 -0
- package/web-ui/build/static/coffeescript-DTYLvxG9.js +1 -0
- package/web-ui/build/static/coffeescript-Dm4UcexP.js +1 -0
- package/web-ui/build/static/concurnas-1OxY7nFV.js +1 -0
- package/web-ui/build/static/coq-CvJBSoWT.js +1 -0
- package/web-ui/build/static/coq-DPZunybQ.js +1 -0
- package/web-ui/build/static/cos-BBstQgB4.js +1 -0
- package/web-ui/build/static/cpp-BR1pa5Wr.js +1 -0
- package/web-ui/build/static/cpp-C-_tTuKh.js +1 -0
- package/web-ui/build/static/crmsh-BIme7ihG.js +1 -0
- package/web-ui/build/static/crystal-C2hlJxaB.js +1 -0
- package/web-ui/build/static/crystal-Ca6D0fV7.js +1 -0
- package/web-ui/build/static/csharp-DGvdwvDH.js +1 -0
- package/web-ui/build/static/csharp-DbAjVltn.js +1 -0
- package/web-ui/build/static/cshtml-DVC84JPa.js +1 -0
- package/web-ui/build/static/csp-BawtG83z.js +1 -0
- package/web-ui/build/static/csp-BlaoxdTK.js +1 -0
- package/web-ui/build/static/css-52oqss7r.js +1 -0
- package/web-ui/build/static/css-extras-BoTVw2IW.js +1 -0
- package/web-ui/build/static/csv-nXBSv5kK.js +1 -0
- package/web-ui/build/static/cypher-WuesoPm2.js +1 -0
- package/web-ui/build/static/d-BmmTjwiV.js +1 -0
- package/web-ui/build/static/d-BwHf5A8R.js +1 -0
- package/web-ui/build/static/dart-BVZTRb8b.js +1 -0
- package/web-ui/build/static/dart-CbWzIBpX.js +1 -0
- package/web-ui/build/static/dataweave-qi_fpjJR.js +1 -0
- package/web-ui/build/static/dax-BpP02TD3.js +1 -0
- package/web-ui/build/static/delphi-TK0E0gLN.js +1 -0
- package/web-ui/build/static/dhall-jyNJwUbo.js +1 -0
- package/web-ui/build/static/diff-Dbu90HZq.js +1 -0
- package/web-ui/build/static/diff-Df6ezhAq.js +1 -0
- package/web-ui/build/static/django-BDy-xiWR.js +1 -0
- package/web-ui/build/static/django-CbmnWIX9.js +1 -0
- package/web-ui/build/static/dns-D_wmKRHl.js +1 -0
- package/web-ui/build/static/dns-zone-file-_1osc1Qk.js +1 -0
- package/web-ui/build/static/docker-D62hlkjX.js +1 -0
- package/web-ui/build/static/dockerfile-DQ080zHh.js +1 -0
- package/web-ui/build/static/dos-B5mA8Wna.js +1 -0
- package/web-ui/build/static/dot-D497WUfu.js +1 -0
- package/web-ui/build/static/dsconfig-dERMCQVk.js +1 -0
- package/web-ui/build/static/dts-DC3ujcbX.js +1 -0
- package/web-ui/build/static/dust-Bhm1VBQg.js +1 -0
- package/web-ui/build/static/ebnf-1lmwK0bv.js +1 -0
- package/web-ui/build/static/ebnf-qzzqKVXL.js +1 -0
- package/web-ui/build/static/editorconfig-CCe25wQr.js +1 -0
- package/web-ui/build/static/eiffel-BFOXbwEN.js +1 -0
- package/web-ui/build/static/ejs-D94vVkGZ.js +1 -0
- package/web-ui/build/static/elixir-B2W81YV0.js +1 -0
- package/web-ui/build/static/elixir-CD1szlP_.js +1 -0
- package/web-ui/build/static/elm-BUJhR-kM.js +1 -0
- package/web-ui/build/static/elm-DwLnLHSK.js +1 -0
- package/web-ui/build/static/erb-CcokD9Fu.js +1 -0
- package/web-ui/build/static/erb-lzhmSBEV.js +1 -0
- package/web-ui/build/static/erlang-C0jnu48-.js +1 -0
- package/web-ui/build/static/erlang-CrevXBnJ.js +1 -0
- package/web-ui/build/static/erlang-repl-CNY6yNoO.js +1 -0
- package/web-ui/build/static/etlua-BMO_ICdR.js +1 -0
- package/web-ui/build/static/excel-C5PbLrVC.js +1 -0
- package/web-ui/build/static/excel-formula-CX4pOnnV.js +1 -0
- package/web-ui/build/static/factor-bW3WUpa0.js +1 -0
- package/web-ui/build/static/false-CQx6Crbr.js +1 -0
- package/web-ui/build/static/firestore-security-rules-DT5oRNdf.js +1 -0
- package/web-ui/build/static/fix-C4IWe2LI.js +1 -0
- package/web-ui/build/static/flix-hi9-cLwA.js +1 -0
- package/web-ui/build/static/flow-CkX6DAhF.js +1 -0
- package/web-ui/build/static/fortran-C4rIX-2n.js +1 -0
- package/web-ui/build/static/fortran-Dvu3q_x_.js +1 -0
- package/web-ui/build/static/fsharp-Bwa1UrRI.js +1 -0
- package/web-ui/build/static/fsharp-CvadhLcA.js +1 -0
- package/web-ui/build/static/ftl-eFEI11YV.js +1 -0
- package/web-ui/build/static/gams-BxGx7deQ.js +1 -0
- package/web-ui/build/static/gap-Dcv7bqDd.js +1 -0
- package/web-ui/build/static/gauss-CcVoF4l8.js +1 -0
- package/web-ui/build/static/gcode-B1dc5sh5.js +1 -0
- package/web-ui/build/static/gcode-D5OxRG5t.js +1 -0
- package/web-ui/build/static/gdscript-CL-EA1wk.js +1 -0
- package/web-ui/build/static/gedcom-BbXrNsr0.js +1 -0
- package/web-ui/build/static/gherkin-B2wQMbT2.js +1 -0
- package/web-ui/build/static/gherkin-CnL4Y3j1.js +1 -0
- package/web-ui/build/static/git-DpdutSM5.js +1 -0
- package/web-ui/build/static/glsl-C7sgdZCA.js +1 -0
- package/web-ui/build/static/glsl-DVaNsn1Z.js +1 -0
- package/web-ui/build/static/gml-B_NppoA4.js +1 -0
- package/web-ui/build/static/gml-DFrn75UD.js +1 -0
- package/web-ui/build/static/gn-BhTU_aTW.js +1 -0
- package/web-ui/build/static/go-DKrUPrfb.js +1 -0
- package/web-ui/build/static/go-DLAYIsJl.js +1 -0
- package/web-ui/build/static/go-module-BXY6q1Ug.js +1 -0
- package/web-ui/build/static/golo-CKxjLRpC.js +1 -0
- package/web-ui/build/static/gradle-DN8lsmJj.js +1 -0
- package/web-ui/build/static/graphql-CMb_4vdm.js +1 -0
- package/web-ui/build/static/groovy-Bhi1VPv7.js +1 -0
- package/web-ui/build/static/groovy-D3X3r3EX.js +1 -0
- package/web-ui/build/static/haml-CvOCw9lL.js +1 -0
- package/web-ui/build/static/haml-DYs0wBJO.js +1 -0
- package/web-ui/build/static/handlebars-CLnuKGPm.js +1 -0
- package/web-ui/build/static/handlebars-CYGG_M1h.js +1 -0
- package/web-ui/build/static/haskell-0Ju0XclD.js +1 -0
- package/web-ui/build/static/haskell-CL5jUHSd.js +1 -0
- package/web-ui/build/static/haxe-BghRbBtK.js +1 -0
- package/web-ui/build/static/haxe-dfL7GzPv.js +1 -0
- package/web-ui/build/static/hcl-BZP2QME-.js +1 -0
- package/web-ui/build/static/hlsl-Djp0TiCX.js +1 -0
- package/web-ui/build/static/hoon-Df5gJVqA.js +1 -0
- package/web-ui/build/static/hpkp-Cy-hjB4V.js +1 -0
- package/web-ui/build/static/hsp-CntMIMs4.js +1 -0
- package/web-ui/build/static/hsts-BNBhETNx.js +1 -0
- package/web-ui/build/static/htmlbars-VCCYaDHA.js +1 -0
- package/web-ui/build/static/http-7DbskohZ.js +1 -0
- package/web-ui/build/static/http-BT5FYFAK.js +1 -0
- package/web-ui/build/static/hy-DuGSaK_b.js +1 -0
- package/web-ui/build/static/ichigojam-CjvnJmlr.js +1 -0
- package/web-ui/build/static/icon-BsBz6XP6.js +1 -0
- package/web-ui/build/static/icu-message-format-BEpv_nip.js +1 -0
- package/web-ui/build/static/idris-DiXQdMPU.js +1 -0
- package/web-ui/build/static/iecst-C9tYEzwP.js +1 -0
- package/web-ui/build/static/ignore-DNMpCRPN.js +1 -0
- package/web-ui/build/static/index-B-r71gxO.js +1 -0
- package/web-ui/build/static/index-CTtNXVAZ.js +1217 -0
- package/web-ui/build/static/index-DkBBEGYj.css +1 -0
- package/web-ui/build/static/index-PvzceRzr.js +13 -0
- package/web-ui/build/static/inform7-D38mj1Ty.js +1 -0
- package/web-ui/build/static/inform7-SwIRbrNQ.js +1 -0
- package/web-ui/build/static/ini-B9xO6J_m.js +1 -0
- package/web-ui/build/static/ini-zcp_esam.js +1 -0
- package/web-ui/build/static/io-C-Ay4jvg.js +1 -0
- package/web-ui/build/static/irpf90-BYnkitLq.js +1 -0
- package/web-ui/build/static/isbl-BYtdwd6v.js +1 -0
- package/web-ui/build/static/j-ByZQN5E4.js +1 -0
- package/web-ui/build/static/java-BNtb6JWL.js +1 -0
- package/web-ui/build/static/java-CQZL3scW.js +1 -0
- package/web-ui/build/static/javadoc-BciMZ8jg.js +1 -0
- package/web-ui/build/static/javadoclike-07BOTXmy.js +1 -0
- package/web-ui/build/static/javascript-CViZlg1q.js +1 -0
- package/web-ui/build/static/javastacktrace-bWyAK0up.js +1 -0
- package/web-ui/build/static/jboss-cli-hz5boSGB.js +1 -0
- package/web-ui/build/static/jexl-DdIINSXT.js +1 -0
- package/web-ui/build/static/jolie-CQnDX-f0.js +1 -0
- package/web-ui/build/static/jq-BzhF0CHG.js +1 -0
- package/web-ui/build/static/js-extras-jizEtT14.js +1 -0
- package/web-ui/build/static/js-templates-Dr1BqLAt.js +1 -0
- package/web-ui/build/static/jsdoc-CI-GPi6r.js +1 -0
- package/web-ui/build/static/json-2eDPxnHO.js +1 -0
- package/web-ui/build/static/json-BBqUMOAQ.js +1 -0
- package/web-ui/build/static/json5-CeIoln-Y.js +1 -0
- package/web-ui/build/static/jsonp-DWe9tbr2.js +1 -0
- package/web-ui/build/static/jsstacktrace-aE-go9tq.js +1 -0
- package/web-ui/build/static/jsx-BTXEPQYI.js +1 -0
- package/web-ui/build/static/julia-4VeOirXa.js +1 -0
- package/web-ui/build/static/julia-Da6yHEfz.js +1 -0
- package/web-ui/build/static/julia-repl-CFrizGkE.js +1 -0
- package/web-ui/build/static/keepalived-39SDM4j5.js +1 -0
- package/web-ui/build/static/keyman-DU5yOLYr.js +1 -0
- package/web-ui/build/static/kotlin-DJoqh3HG.js +1 -0
- package/web-ui/build/static/kotlin-DsKd3r_L.js +1 -0
- package/web-ui/build/static/kumir-CO96hby4.js +1 -0
- package/web-ui/build/static/kusto-DyuMf8l-.js +1 -0
- package/web-ui/build/static/lasso-BiPmQTXQ.js +1 -0
- package/web-ui/build/static/latex-Bd1ef5fi.js +1 -0
- package/web-ui/build/static/latex-DUrYkmWb.js +1 -0
- package/web-ui/build/static/latte-BSD-hpi5.js +1 -0
- package/web-ui/build/static/ldif-1ZMSg0qI.js +1 -0
- package/web-ui/build/static/leaf-Cg0eq01F.js +1 -0
- package/web-ui/build/static/less-BKcd1_xh.js +1 -0
- package/web-ui/build/static/less-SB5bcusC.js +1 -0
- package/web-ui/build/static/lilypond-BX_kuAqT.js +1 -0
- package/web-ui/build/static/liquid-C337T5bt.js +1 -0
- package/web-ui/build/static/lisp-B_bJRelF.js +1 -0
- package/web-ui/build/static/lisp-Du04Vdmx.js +1 -0
- package/web-ui/build/static/livecodeserver-BOkA9fV6.js +1 -0
- package/web-ui/build/static/livescript-DkMTCCBM.js +1 -0
- package/web-ui/build/static/livescript-rTaLq5oP.js +1 -0
- package/web-ui/build/static/llvm-BrBlvl5p.js +1 -0
- package/web-ui/build/static/llvm-DQbygw7z.js +1 -0
- package/web-ui/build/static/log-DoAzOt8c.js +1 -0
- package/web-ui/build/static/lolcode-DnB7KhRR.js +1 -0
- package/web-ui/build/static/lsl-DpzE7F5A.js +1 -0
- package/web-ui/build/static/lua-CIceROsO.js +1 -0
- package/web-ui/build/static/lua-DhnvJuMn.js +1 -0
- package/web-ui/build/static/magma-BwjzpKxi.js +1 -0
- package/web-ui/build/static/makefile-D10Y62dl.js +1 -0
- package/web-ui/build/static/makefile-esgkquGi.js +1 -0
- package/web-ui/build/static/markdown-B-Y7Y0Nn.js +1 -0
- package/web-ui/build/static/markdown-Cv3Onm-Q.js +1 -0
- package/web-ui/build/static/markup-templating-B1-9WWYa.js +1 -0
- package/web-ui/build/static/mathematica-gSyKdw2h.js +1 -0
- package/web-ui/build/static/matlab-6i1uXuBx.js +1 -0
- package/web-ui/build/static/matlab-CqcSZ1d9.js +1 -0
- package/web-ui/build/static/maxima-Bc-OnIOQ.js +1 -0
- package/web-ui/build/static/maxscript-Bce44o6c.js +1 -0
- package/web-ui/build/static/mel-0Jk3y-vw.js +1 -0
- package/web-ui/build/static/mel-DmA_8WPg.js +1 -0
- package/web-ui/build/static/mercury-DNdP1u-O.js +1 -0
- package/web-ui/build/static/mermaid-DrLkSIIb.js +1 -0
- package/web-ui/build/static/mipsasm-BIQVs3Ff.js +1 -0
- package/web-ui/build/static/mizar-BD5ZD_Rk.js +1 -0
- package/web-ui/build/static/mizar-DThX8Mdy.js +1 -0
- package/web-ui/build/static/mojolicious-Bra-ClwJ.js +1 -0
- package/web-ui/build/static/mongodb-DirByEEg.js +1 -0
- package/web-ui/build/static/monkey-C-Pvu43G.js +1 -0
- package/web-ui/build/static/monkey-n4IFmaA7.js +1 -0
- package/web-ui/build/static/moonscript-B1DM34lp.js +1 -0
- package/web-ui/build/static/moonscript-B82JBytX.js +1 -0
- package/web-ui/build/static/n1ql-C46iq3Hh.js +1 -0
- package/web-ui/build/static/n1ql-DOs3gJQo.js +1 -0
- package/web-ui/build/static/n4js-CPYgal3G.js +1 -0
- package/web-ui/build/static/nand2tetris-hdl-BhlUIq7M.js +1 -0
- package/web-ui/build/static/naniscript-D1YZXYcf.js +1 -0
- package/web-ui/build/static/nasm-2-TtCBo4.js +1 -0
- package/web-ui/build/static/neon-BzoXMDea.js +1 -0
- package/web-ui/build/static/nevod-DW_87wHj.js +1 -0
- package/web-ui/build/static/nginx-BgieYUhk.js +1 -0
- package/web-ui/build/static/nginx-DW0RVJbs.js +1 -0
- package/web-ui/build/static/nim-BbTa7YZN.js +1 -0
- package/web-ui/build/static/nim-VdXk3QT9.js +1 -0
- package/web-ui/build/static/nix-3tNNprEI.js +1 -0
- package/web-ui/build/static/nix-BDghlfzh.js +1 -0
- package/web-ui/build/static/node-repl-BBLv3tyt.js +1 -0
- package/web-ui/build/static/nsis-DxjfnSO8.js +1 -0
- package/web-ui/build/static/nsis-FY5xiiar.js +1 -0
- package/web-ui/build/static/objectivec-CXhf_sp_.js +1 -0
- package/web-ui/build/static/objectivec-DcRKjWcd.js +1 -0
- package/web-ui/build/static/ocaml-BLRL6Zro.js +1 -0
- package/web-ui/build/static/ocaml-C4S4QQtS.js +1 -0
- package/web-ui/build/static/opencl-ruEAYetM.js +1 -0
- package/web-ui/build/static/openqasm-D6r_FwIh.js +1 -0
- package/web-ui/build/static/openscad-BEPjoj_N.js +1 -0
- package/web-ui/build/static/oxygene-A61yc5Or.js +1 -0
- package/web-ui/build/static/oz-DICidCTs.js +1 -0
- package/web-ui/build/static/parigp-MjTNwy2s.js +1 -0
- package/web-ui/build/static/parser-DmI7lg_r.js +1 -0
- package/web-ui/build/static/parser3-Bv9kXAib.js +1 -0
- package/web-ui/build/static/pascal-B23PBLTj.js +1 -0
- package/web-ui/build/static/pascaligo-CPIJtX2C.js +1 -0
- package/web-ui/build/static/pcaxis-Bsj_6x8j.js +1 -0
- package/web-ui/build/static/peoplecode-VvQbMjsD.js +1 -0
- package/web-ui/build/static/perl-Cr6Y9-hl.js +1 -0
- package/web-ui/build/static/perl-D37oTJip.js +1 -0
- package/web-ui/build/static/pf-BKHaWcGm.js +1 -0
- package/web-ui/build/static/pgsql-ChusgWw2.js +1 -0
- package/web-ui/build/static/php-3Qr4hNV1.js +1 -0
- package/web-ui/build/static/php-CgxeEh4Y.js +1 -0
- package/web-ui/build/static/php-extras-DeLqwT6H.js +1 -0
- package/web-ui/build/static/php-template-DcOJxuIf.js +1 -0
- package/web-ui/build/static/phpdoc-amFph5Ax.js +1 -0
- package/web-ui/build/static/plaintext-mqBcO1hG.js +1 -0
- package/web-ui/build/static/plsql-ioyqfxP7.js +1 -0
- package/web-ui/build/static/pony-nxjy8Qot.js +1 -0
- package/web-ui/build/static/powerquery-Ci_Fxyg8.js +1 -0
- package/web-ui/build/static/powershell-CB_GgRqr.js +1 -0
- package/web-ui/build/static/powershell-au4fYIm7.js +1 -0
- package/web-ui/build/static/processing-Bkd3f-Wz.js +1 -0
- package/web-ui/build/static/processing-PgCPZm30.js +1 -0
- package/web-ui/build/static/profile-C2GBY6C9.js +1 -0
- package/web-ui/build/static/prolog-BRjYwjIO.js +1 -0
- package/web-ui/build/static/prolog-BheGlH8Q.js +1 -0
- package/web-ui/build/static/promql-CtCmTKys.js +1 -0
- package/web-ui/build/static/properties-BpLqVZha.js +1 -0
- package/web-ui/build/static/properties-UQxavHUY.js +1 -0
- package/web-ui/build/static/protobuf-BSuul6Uw.js +1 -0
- package/web-ui/build/static/protobuf-CLRi8VTE.js +1 -0
- package/web-ui/build/static/psl-CJsJilqO.js +1 -0
- package/web-ui/build/static/pug-5BY6sdv1.js +1 -0
- package/web-ui/build/static/puppet-DBg45gHV.js +1 -0
- package/web-ui/build/static/puppet-DPANCbOj.js +1 -0
- package/web-ui/build/static/pure-Cn4p-7Bj.js +1 -0
- package/web-ui/build/static/purebasic-CoXbIzZJ.js +1 -0
- package/web-ui/build/static/purebasic-DZ_eLoUV.js +1 -0
- package/web-ui/build/static/purescript-B98GoUb_.js +1 -0
- package/web-ui/build/static/python-B-Lm1OME.js +1 -0
- package/web-ui/build/static/python-C_ApFGS1.js +1 -0
- package/web-ui/build/static/python-repl-CJW5_RON.js +1 -0
- package/web-ui/build/static/q-BB2BYhxG.js +1 -0
- package/web-ui/build/static/q-DVqo_ScG.js +1 -0
- package/web-ui/build/static/qml-Co-8g096.js +1 -0
- package/web-ui/build/static/qml-Du0WFcoy.js +1 -0
- package/web-ui/build/static/qore-C6XBzy3U.js +1 -0
- package/web-ui/build/static/qsharp-BCMklAuq.js +1 -0
- package/web-ui/build/static/r-B5CGUQwN.js +1 -0
- package/web-ui/build/static/r-Dxhot-za.js +1 -0
- package/web-ui/build/static/racket-C0dCdrKh.js +1 -0
- package/web-ui/build/static/reason-DGJ1fFJs.js +1 -0
- package/web-ui/build/static/reasonml-gt_AvBg7.js +1 -0
- package/web-ui/build/static/regex-B5iNH8MZ.js +1 -0
- package/web-ui/build/static/rego-hfPajYet.js +1 -0
- package/web-ui/build/static/renpy-BkG5aM4I.js +1 -0
- package/web-ui/build/static/rest-C4uwtrF8.js +1 -0
- package/web-ui/build/static/rib-D32ew8Y7.js +1 -0
- package/web-ui/build/static/rip-BIEbWzxe.js +1 -0
- package/web-ui/build/static/roboconf-CMN8BoHf.js +1 -0
- package/web-ui/build/static/roboconf-GVMh3ioj.js +1 -0
- package/web-ui/build/static/robotframework-CUQybJQ9.js +1 -0
- package/web-ui/build/static/routeros-DUEdLmuc.js +1 -0
- package/web-ui/build/static/rsl-BsAePIwQ.js +1 -0
- package/web-ui/build/static/ruby-CZMMjJFw.js +1 -0
- package/web-ui/build/static/ruby-WOVZyoXO.js +1 -0
- package/web-ui/build/static/ruleslanguage-xV-HszUl.js +1 -0
- package/web-ui/build/static/rust-Da9GRxLz.js +1 -0
- package/web-ui/build/static/rust-uCND428m.js +1 -0
- package/web-ui/build/static/sas-BW15NPzf.js +1 -0
- package/web-ui/build/static/sas-DCx9gext.js +1 -0
- package/web-ui/build/static/sass-BMD7eETo.js +1 -0
- package/web-ui/build/static/scala-0wnxLTlF.js +1 -0
- package/web-ui/build/static/scala-D3Hk-q5-.js +1 -0
- package/web-ui/build/static/scheme-Ci9QOUcD.js +1 -0
- package/web-ui/build/static/scheme-CtqjB_HN.js +1 -0
- package/web-ui/build/static/scilab-CnITQd23.js +1 -0
- package/web-ui/build/static/scss-DCceV6xw.js +1 -0
- package/web-ui/build/static/scss-N5EuPQOS.js +1 -0
- package/web-ui/build/static/shell-BegJTton.js +1 -0
- package/web-ui/build/static/shell-session-BHBoosfJ.js +1 -0
- package/web-ui/build/static/smali-CoHePNQf.js +1 -0
- package/web-ui/build/static/smali-D64W1f0Y.js +1 -0
- package/web-ui/build/static/smalltalk-CagI-Ky8.js +1 -0
- package/web-ui/build/static/smalltalk-DHLuWDjp.js +1 -0
- package/web-ui/build/static/smarty-CSS2XBuu.js +1 -0
- package/web-ui/build/static/sml-D8Oyp9xr.js +1 -0
- package/web-ui/build/static/sml-DvC_VDmX.js +1 -0
- package/web-ui/build/static/solidity-DVkeulrL.js +1 -0
- package/web-ui/build/static/solution-file-Bd7qWzoo.js +1 -0
- package/web-ui/build/static/soy-BRSlVWf7.js +1 -0
- package/web-ui/build/static/sparql-DNnCQmqM.js +1 -0
- package/web-ui/build/static/splunk-spl-DXCDUv2Y.js +1 -0
- package/web-ui/build/static/sqf-C_IKzP5b.js +1 -0
- package/web-ui/build/static/sqf-DBqlUGoG.js +1 -0
- package/web-ui/build/static/sql-Dt3ZutCc.js +1 -0
- package/web-ui/build/static/sql-q0UMLqb7.js +1 -0
- package/web-ui/build/static/sql_more-DAuY5p3F.js +1 -0
- package/web-ui/build/static/squirrel-CgQZeaNT.js +1 -0
- package/web-ui/build/static/stan-D5kYsid7.js +1 -0
- package/web-ui/build/static/stan-JSHToKMA.js +1 -0
- package/web-ui/build/static/stata-DRVhVjVb.js +1 -0
- package/web-ui/build/static/step21-C7h5ssgs.js +1 -0
- package/web-ui/build/static/stylus-BXIDNFUe.js +1 -0
- package/web-ui/build/static/stylus-CyMBrStz.js +1 -0
- package/web-ui/build/static/subunit-Lbpuvy4t.js +1 -0
- package/web-ui/build/static/swift-BCxWOc8n.js +1 -0
- package/web-ui/build/static/swift-B_YEL6eF.js +1 -0
- package/web-ui/build/static/systemd-_zWfs8U5.js +1 -0
- package/web-ui/build/static/t4-cs-BCiVX6dp.js +1 -0
- package/web-ui/build/static/t4-templating-CDm61rWh.js +1 -0
- package/web-ui/build/static/t4-vb-OO2oZZrL.js +1 -0
- package/web-ui/build/static/taggerscript-CkXxiITO.js +1 -0
- package/web-ui/build/static/tap-C612JPhJ.js +1 -0
- package/web-ui/build/static/tap-J-zR66jL.js +1 -0
- package/web-ui/build/static/tcl-DIGan5K8.js +1 -0
- package/web-ui/build/static/tcl-SFVWFwbb.js +1 -0
- package/web-ui/build/static/textile-D0WxA5g8.js +1 -0
- package/web-ui/build/static/thrift-jboo4tJl.js +1 -0
- package/web-ui/build/static/toml-DIK32ROb.js +1 -0
- package/web-ui/build/static/tp-Bhs1iGD3.js +1 -0
- package/web-ui/build/static/tremor-4d_juLiN.js +1 -0
- package/web-ui/build/static/tsx-hEN3qQzd.js +1 -0
- package/web-ui/build/static/tt2-WU6EuPNO.js +1 -0
- package/web-ui/build/static/turtle-CUM3xwNI.js +1 -0
- package/web-ui/build/static/twig-B9JwTKv9.js +1 -0
- package/web-ui/build/static/twig-Crv6BtK7.js +1 -0
- package/web-ui/build/static/typescript-BmabW_ur.js +1 -0
- package/web-ui/build/static/typescript-oMKx2dph.js +1 -0
- package/web-ui/build/static/typoscript-X48MNTeK.js +1 -0
- package/web-ui/build/static/unrealscript-qnu9Ogmz.js +1 -0
- package/web-ui/build/static/uorazor-BicTvjGt.js +1 -0
- package/web-ui/build/static/uri-CyRoMB-u.js +1 -0
- package/web-ui/build/static/v-BDM6ZJR7.js +1 -0
- package/web-ui/build/static/vala-BWCf7DTx.js +1 -0
- package/web-ui/build/static/vala-COL5roWV.js +1 -0
- package/web-ui/build/static/vbnet-BHPgkiip.js +1 -0
- package/web-ui/build/static/vbnet-BadWmTKs.js +1 -0
- package/web-ui/build/static/vbscript-BfUpIAaV.js +1 -0
- package/web-ui/build/static/vbscript-html-BBR6zcvV.js +1 -0
- package/web-ui/build/static/velocity-k4gGPuiP.js +1 -0
- package/web-ui/build/static/verilog-BoNroxW8.js +1 -0
- package/web-ui/build/static/verilog-C7cplLIi.js +1 -0
- package/web-ui/build/static/vhdl-BrKkx69g.js +1 -0
- package/web-ui/build/static/vhdl-CWacsAXR.js +1 -0
- package/web-ui/build/static/vim-BcdueaEC.js +1 -0
- package/web-ui/build/static/vim-BwsUolG_.js +1 -0
- package/web-ui/build/static/visual-basic-DTXlX5HN.js +1 -0
- package/web-ui/build/static/warpscript-2w0_2KsB.js +1 -0
- package/web-ui/build/static/wasm-BPaXQO-A.js +1 -0
- package/web-ui/build/static/web-idl-BoCTFQod.js +1 -0
- package/web-ui/build/static/wiki-BkkCi9wm.js +1 -0
- package/web-ui/build/static/wolfram-CvRNTaAX.js +1 -0
- package/web-ui/build/static/wren-Bz8Smtz-.js +1 -0
- package/web-ui/build/static/x86asm-BM83B0N_.js +1 -0
- package/web-ui/build/static/xeora-BjuDukl7.js +1 -0
- package/web-ui/build/static/xl-ByiuKWwm.js +1 -0
- package/web-ui/build/static/xml-Dut2p53G.js +1 -0
- package/web-ui/build/static/xml-doc-CxgwiuaA.js +1 -0
- package/web-ui/build/static/xojo-CBqUB8JI.js +1 -0
- package/web-ui/build/static/xquery-D-agM4jx.js +1 -0
- package/web-ui/build/static/xquery-DL_eetrQ.js +1 -0
- package/web-ui/build/static/yaml-DZ7HVZSe.js +1 -0
- package/web-ui/build/static/yaml-DatJAv7_.js +1 -0
- package/web-ui/build/static/yang-D0nrKE-r.js +1 -0
- package/web-ui/build/static/zephir--M2g15-k.js +1 -0
- package/web-ui/build/static/zig-CK6rUH8E.js +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
|
@@ -26,29 +26,75 @@ function makeStubApiKeyManager(initial = {}) {
|
|
|
26
26
|
function makeStubClient() {
|
|
27
27
|
return {
|
|
28
28
|
toolkits: {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
]),
|
|
29
|
+
// listToolkits no longer uses SDK methods (the SDK has no public
|
|
30
|
+
// `.list`, and `.get` drops the pagination cursor) — it goes via
|
|
31
|
+
// REST. Tests for listToolkits mock `global.fetch` instead.
|
|
33
32
|
},
|
|
34
33
|
tools: {
|
|
35
|
-
|
|
36
|
-
{ slug: 'GITHUB_CREATE_AN_ISSUE', description: 'Create issue' },
|
|
37
|
-
]),
|
|
34
|
+
// Same story — listTools uses REST.
|
|
38
35
|
execute: jest.fn().mockResolvedValue({ successful: true, data: { issueNumber: 42 } }),
|
|
39
36
|
},
|
|
37
|
+
authConfigs: {
|
|
38
|
+
// The connect path needs to look up or create an auth-config.
|
|
39
|
+
// Default: one already exists for the toolkit, so list returns it.
|
|
40
|
+
list: jest.fn().mockResolvedValue({
|
|
41
|
+
items: [{ id: 'auth-cfg-existing', toolkitSlug: 'github' }],
|
|
42
|
+
}),
|
|
43
|
+
create: jest.fn().mockResolvedValue({ id: 'auth-cfg-new' }),
|
|
44
|
+
},
|
|
40
45
|
connectedAccounts: {
|
|
41
46
|
list: jest.fn().mockResolvedValue([
|
|
42
47
|
{ id: 'conn-1', toolkitSlug: 'github', status: 'ACTIVE' },
|
|
43
48
|
{ id: 'conn-2', toolkitSlug: 'slack', status: 'INITIATED' },
|
|
44
49
|
]),
|
|
45
50
|
get: jest.fn().mockResolvedValue({ id: 'conn-1', status: 'ACTIVE' }),
|
|
46
|
-
|
|
51
|
+
// The new endpoint replacing the deprecated `initiate`.
|
|
52
|
+
link: jest.fn().mockResolvedValue({
|
|
53
|
+
id: 'conn-new',
|
|
54
|
+
redirectUrl: 'https://connect.composio.dev/link/abc',
|
|
55
|
+
}),
|
|
47
56
|
delete: jest.fn().mockResolvedValue({ success: true }),
|
|
48
57
|
},
|
|
49
58
|
};
|
|
50
59
|
}
|
|
51
60
|
|
|
61
|
+
/**
|
|
62
|
+
* Stub `global.fetch` to script REST responses, scoped to the test.
|
|
63
|
+
* Returns the spy so tests can assert calls. The returned cleanup
|
|
64
|
+
* function restores the original.
|
|
65
|
+
*
|
|
66
|
+
* Pages are consumed in order — each call to fetch returns the next
|
|
67
|
+
* page in the list, with `next_cursor` set on all but the last.
|
|
68
|
+
*/
|
|
69
|
+
function stubFetch(pagesPerPath) {
|
|
70
|
+
const original = global.fetch;
|
|
71
|
+
const calls = [];
|
|
72
|
+
// pagesPerPath: { '/api/v3.1/toolkits': [[item, item], [item, item]] }
|
|
73
|
+
const cursors = new Map(); // path → current page index
|
|
74
|
+
global.fetch = jest.fn(async (url) => {
|
|
75
|
+
const u = url instanceof URL ? url : new URL(String(url));
|
|
76
|
+
const path = u.pathname;
|
|
77
|
+
calls.push({ path, query: Object.fromEntries(u.searchParams) });
|
|
78
|
+
const pages = pagesPerPath[path];
|
|
79
|
+
if (!pages) {
|
|
80
|
+
return new Response(JSON.stringify({ error: `no stub for ${path}` }), { status: 404 });
|
|
81
|
+
}
|
|
82
|
+
const idx = cursors.get(path) || 0;
|
|
83
|
+
const items = pages[idx] || [];
|
|
84
|
+
const isLast = idx >= pages.length - 1;
|
|
85
|
+
cursors.set(path, idx + 1);
|
|
86
|
+
return new Response(JSON.stringify({
|
|
87
|
+
items,
|
|
88
|
+
next_cursor: isLast ? null : `cursor-${idx + 1}`,
|
|
89
|
+
}), { status: 200, headers: { 'content-type': 'application/json' } });
|
|
90
|
+
});
|
|
91
|
+
return {
|
|
92
|
+
fetch: global.fetch,
|
|
93
|
+
calls,
|
|
94
|
+
restore: () => { global.fetch = original; },
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
|
|
52
98
|
let savedApiKey;
|
|
53
99
|
beforeEach(() => {
|
|
54
100
|
savedApiKey = process.env.COMPOSIO_API_KEY;
|
|
@@ -148,23 +194,128 @@ describe('composioService — setApiKey + forgetApiKey', () => {
|
|
|
148
194
|
});
|
|
149
195
|
|
|
150
196
|
describe('composioService — listToolkits', () => {
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
197
|
+
// listToolkits used to call `client.toolkits.list()` — a method that
|
|
198
|
+
// doesn't actually exist on the @composio/core SDK. It silently
|
|
199
|
+
// returned `undefined`, which the normaliser converted to `[]`, so
|
|
200
|
+
// every agent saw "0 toolkits available" no matter what was enabled.
|
|
201
|
+
// The fix bypasses the SDK and calls REST directly so we can also
|
|
202
|
+
// follow cursor pagination (SDK's `toolkits.get` discards nextCursor).
|
|
203
|
+
|
|
204
|
+
test('paginates the REST endpoint until exhausted', async () => {
|
|
205
|
+
const stub = stubFetch({
|
|
206
|
+
'/api/v3.1/toolkits': [
|
|
207
|
+
[{ slug: 'github', name: 'GitHub', meta: { description: 'Repos' } },
|
|
208
|
+
{ slug: 'slack', name: 'Slack', meta: { description: 'Messaging' } }],
|
|
209
|
+
[{ slug: 'canva', name: 'Canva', meta: { description: 'Design' } }],
|
|
210
|
+
],
|
|
211
|
+
});
|
|
212
|
+
try {
|
|
213
|
+
const r = await composioService.listToolkits({ force: true });
|
|
214
|
+
expect(r.success).toBe(true);
|
|
215
|
+
expect(r.toolkits.map(t => t.slug).sort()).toEqual(['canva', 'github', 'slack']);
|
|
216
|
+
// Two REST round-trips: page 1 (no cursor) + page 2 (with cursor).
|
|
217
|
+
const toolkitCalls = stub.calls.filter(c => c.path === '/api/v3.1/toolkits');
|
|
218
|
+
expect(toolkitCalls).toHaveLength(2);
|
|
219
|
+
expect(toolkitCalls[0].query.cursor).toBeUndefined();
|
|
220
|
+
expect(toolkitCalls[1].query.cursor).toBe('cursor-1');
|
|
221
|
+
} finally { stub.restore(); }
|
|
159
222
|
});
|
|
160
223
|
|
|
161
|
-
test('
|
|
162
|
-
const
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
224
|
+
test('camelizes snake_case fields in the REST response', async () => {
|
|
225
|
+
const stub = stubFetch({
|
|
226
|
+
'/api/v3.1/toolkits': [[
|
|
227
|
+
{
|
|
228
|
+
slug: 'gh', name: 'GitHub',
|
|
229
|
+
is_local_toolkit: false,
|
|
230
|
+
auth_schemes: ['OAUTH2'],
|
|
231
|
+
composio_managed_auth_schemes: ['OAUTH2'],
|
|
232
|
+
no_auth: false,
|
|
233
|
+
meta: {
|
|
234
|
+
description: 'Code hosting',
|
|
235
|
+
tools_count: 42,
|
|
236
|
+
triggers_count: 3,
|
|
237
|
+
app_url: 'https://github.com',
|
|
238
|
+
created_at: '2024-01-01',
|
|
239
|
+
updated_at: '2024-12-31',
|
|
240
|
+
},
|
|
241
|
+
},
|
|
242
|
+
]],
|
|
243
|
+
});
|
|
244
|
+
try {
|
|
245
|
+
const r = await composioService.listToolkits({ force: true });
|
|
246
|
+
expect(r.success).toBe(true);
|
|
247
|
+
const t = r.toolkits[0];
|
|
248
|
+
expect(t.slug).toBe('gh');
|
|
249
|
+
expect(t.isLocalToolkit).toBe(false);
|
|
250
|
+
expect(t.authSchemes).toEqual(['OAUTH2']);
|
|
251
|
+
expect(t.composioManagedAuthSchemes).toEqual(['OAUTH2']);
|
|
252
|
+
expect(t.noAuth).toBe(false);
|
|
253
|
+
expect(t.meta.toolsCount).toBe(42);
|
|
254
|
+
expect(t.meta.triggersCount).toBe(3);
|
|
255
|
+
expect(t.meta.appUrl).toBe('https://github.com');
|
|
256
|
+
expect(t.meta.createdAt).toBe('2024-01-01');
|
|
257
|
+
// Top-level description alias is the only "denormalised" field — it's
|
|
258
|
+
// there so the agent UI can show toolkit summaries without diving
|
|
259
|
+
// into .meta.
|
|
260
|
+
expect(t.description).toBe('Code hosting');
|
|
261
|
+
} finally { stub.restore(); }
|
|
262
|
+
});
|
|
263
|
+
|
|
264
|
+
test('surfaces REST errors as success:false', async () => {
|
|
265
|
+
const original = global.fetch;
|
|
266
|
+
global.fetch = jest.fn(async () => new Response(
|
|
267
|
+
JSON.stringify({ error: 'rate limited' }), { status: 429 }
|
|
268
|
+
));
|
|
269
|
+
try {
|
|
270
|
+
const r = await composioService.listToolkits({ force: true });
|
|
271
|
+
expect(r.success).toBe(false);
|
|
272
|
+
expect(r.error).toMatch(/rate limited/);
|
|
273
|
+
expect(r.error).toMatch(/HTTP 429/);
|
|
274
|
+
} finally { global.fetch = original; }
|
|
275
|
+
});
|
|
276
|
+
|
|
277
|
+
test('caches the catalog for ~1 minute (avoid hammering REST in agent loops)', async () => {
|
|
278
|
+
const stub = stubFetch({
|
|
279
|
+
'/api/v3.1/toolkits': [[{ slug: 'gh', name: 'GitHub' }]],
|
|
280
|
+
});
|
|
281
|
+
try {
|
|
282
|
+
const r1 = await composioService.listToolkits({ force: true });
|
|
283
|
+
const r2 = await composioService.listToolkits();
|
|
284
|
+
expect(r1.toolkits).toHaveLength(1);
|
|
285
|
+
expect(r2.toolkits).toHaveLength(1);
|
|
286
|
+
expect(r2.cached).toBe(true);
|
|
287
|
+
// Only ONE REST call despite two listToolkits invocations.
|
|
288
|
+
expect(stub.calls.filter(c => c.path === '/api/v3.1/toolkits')).toHaveLength(1);
|
|
289
|
+
} finally { stub.restore(); }
|
|
290
|
+
});
|
|
291
|
+
|
|
292
|
+
test('key rotation drops the cache (next call hits REST with the new key)', async () => {
|
|
293
|
+
// Hand-rolled fetch stub: each call returns ONE complete (single-page)
|
|
294
|
+
// catalog response. The two listToolkits() invocations across the
|
|
295
|
+
// rotation should therefore produce two separate REST calls.
|
|
296
|
+
const responses = [
|
|
297
|
+
[{ slug: 'gh', name: 'GitHub' }],
|
|
298
|
+
[{ slug: 'sl', name: 'Slack' }],
|
|
299
|
+
];
|
|
300
|
+
const original = global.fetch;
|
|
301
|
+
const calls = [];
|
|
302
|
+
global.fetch = jest.fn(async (url) => {
|
|
303
|
+
const u = url instanceof URL ? url : new URL(String(url));
|
|
304
|
+
calls.push(u.pathname);
|
|
305
|
+
const items = responses.shift() ?? [];
|
|
306
|
+
return new Response(JSON.stringify({ items, next_cursor: null }), {
|
|
307
|
+
status: 200, headers: { 'content-type': 'application/json' },
|
|
308
|
+
});
|
|
309
|
+
});
|
|
310
|
+
try {
|
|
311
|
+
const r1 = await composioService.listToolkits({ force: true });
|
|
312
|
+
expect(r1.toolkits.map(t => t.slug)).toEqual(['gh']);
|
|
313
|
+
composioService.invalidateClientCache();
|
|
314
|
+
const r2 = await composioService.listToolkits();
|
|
315
|
+
// New REST round-trip after rotation — fresh response fires.
|
|
316
|
+
expect(r2.toolkits.map(t => t.slug)).toEqual(['sl']);
|
|
317
|
+
expect(calls.filter(p => p === '/api/v3.1/toolkits')).toHaveLength(2);
|
|
318
|
+
} finally { global.fetch = original; }
|
|
168
319
|
});
|
|
169
320
|
});
|
|
170
321
|
|
|
@@ -188,6 +339,46 @@ describe('composioService — listConnections', () => {
|
|
|
188
339
|
expect(r.connections).toHaveLength(1);
|
|
189
340
|
expect(r.connections[0].id).toBe('x');
|
|
190
341
|
});
|
|
342
|
+
|
|
343
|
+
// Regression guard for the UI crash:
|
|
344
|
+
// TypeError: (S.slug || "").toLowerCase is not a function
|
|
345
|
+
// The SDK returns `toolkit` as an OBJECT `{slug, name, ...}` (camelCased
|
|
346
|
+
// pass-through of the REST shape). The UI did `c.toolkitSlug || c.toolkit`,
|
|
347
|
+
// got the whole object as the "slug", then called `.toLowerCase()` on it
|
|
348
|
+
// and crashed. The service now always exposes a STRING `toolkitSlug` at
|
|
349
|
+
// the top level so callers never have to dig.
|
|
350
|
+
test('normalises connection.toolkit (object) → top-level toolkitSlug (string)', async () => {
|
|
351
|
+
const client = makeStubClient();
|
|
352
|
+
client.connectedAccounts.list = jest.fn().mockResolvedValue([
|
|
353
|
+
// SDK-style: toolkit is an object, no top-level toolkitSlug.
|
|
354
|
+
{ id: 'c1', toolkit: { slug: 'canva', name: 'Canva' }, status: 'INITIATED' },
|
|
355
|
+
// Snake-case-style: toolkit_slug instead of toolkitSlug.
|
|
356
|
+
{ id: 'c2', toolkit_slug: 'slack', status: 'ACTIVE' },
|
|
357
|
+
// String fallback: toolkit is a bare string.
|
|
358
|
+
{ id: 'c3', toolkit: 'github', status: 'ACTIVE' },
|
|
359
|
+
// Already-normalised: toolkitSlug already a string.
|
|
360
|
+
{ id: 'c4', toolkitSlug: 'notion', status: 'ACTIVE' },
|
|
361
|
+
]);
|
|
362
|
+
composioService._injectClientForTests(client);
|
|
363
|
+
const r = await composioService.listConnections('operator');
|
|
364
|
+
expect(r.success).toBe(true);
|
|
365
|
+
expect(r.connections).toHaveLength(4);
|
|
366
|
+
// Every connection has a string toolkitSlug — no objects sneaking through.
|
|
367
|
+
for (const c of r.connections) {
|
|
368
|
+
expect(typeof c.toolkitSlug).toBe('string');
|
|
369
|
+
}
|
|
370
|
+
expect(r.connections.map(c => c.toolkitSlug)).toEqual(['canva', 'slack', 'github', 'notion']);
|
|
371
|
+
});
|
|
372
|
+
|
|
373
|
+
test('returns empty toolkitSlug (not undefined/object) when nothing is extractable', async () => {
|
|
374
|
+
const client = makeStubClient();
|
|
375
|
+
client.connectedAccounts.list = jest.fn().mockResolvedValue([
|
|
376
|
+
{ id: 'mystery', status: 'INITIATED' }, // no toolkit field at all
|
|
377
|
+
]);
|
|
378
|
+
composioService._injectClientForTests(client);
|
|
379
|
+
const r = await composioService.listConnections('operator');
|
|
380
|
+
expect(r.connections[0].toolkitSlug).toBe('');
|
|
381
|
+
});
|
|
191
382
|
});
|
|
192
383
|
|
|
193
384
|
describe('composioService — connectionStatus', () => {
|
|
@@ -200,35 +391,186 @@ describe('composioService — connectionStatus', () => {
|
|
|
200
391
|
});
|
|
201
392
|
|
|
202
393
|
test('maps missing connection → connected:false', async () => {
|
|
394
|
+
// After the fix, connectionStatus uses .list({userId, toolkit})
|
|
395
|
+
// and filters client-side rather than calling .get(object) (which
|
|
396
|
+
// the SDK serializes to "[object Object]" in a URL path segment).
|
|
203
397
|
const client = makeStubClient();
|
|
204
|
-
client.connectedAccounts.
|
|
398
|
+
client.connectedAccounts.list = jest.fn().mockResolvedValue([]); // no connections
|
|
205
399
|
composioService._injectClientForTests(client);
|
|
206
400
|
const r = await composioService.connectionStatus('operator', 'github');
|
|
207
401
|
expect(r.connected).toBe(false);
|
|
208
402
|
expect(r.status).toBe('NOT_CONNECTED');
|
|
209
403
|
});
|
|
404
|
+
|
|
405
|
+
test('uses connectedAccounts.list (not .get) — guards against the SDK "[object Object]" path-segment bug', async () => {
|
|
406
|
+
const client = makeStubClient();
|
|
407
|
+
// If anything calls .get with an object, the SDK would barf. The
|
|
408
|
+
// fix should NEVER reach .get for status lookups.
|
|
409
|
+
client.connectedAccounts.get = jest.fn(() => {
|
|
410
|
+
throw new Error('Path parameters result in path with invalid segments: [object Object]');
|
|
411
|
+
});
|
|
412
|
+
composioService._injectClientForTests(client);
|
|
413
|
+
const r = await composioService.connectionStatus('operator', 'github');
|
|
414
|
+
expect(r.success).toBe(true);
|
|
415
|
+
expect(client.connectedAccounts.get).not.toHaveBeenCalled();
|
|
416
|
+
expect(client.connectedAccounts.list).toHaveBeenCalledWith(
|
|
417
|
+
expect.objectContaining({ userId: 'operator', toolkit: 'github' })
|
|
418
|
+
);
|
|
419
|
+
});
|
|
420
|
+
|
|
421
|
+
test('handles wrapped {items:[]} response shape from the SDK', async () => {
|
|
422
|
+
// The Composio TS SDK returns paginated wrappers; the fix
|
|
423
|
+
// normalises Array | {items} | {data} → flat Array.
|
|
424
|
+
const client = makeStubClient();
|
|
425
|
+
client.connectedAccounts.list = jest.fn().mockResolvedValue({
|
|
426
|
+
items: [{ id: 'conn-1', toolkitSlug: 'github', status: 'ACTIVE' }],
|
|
427
|
+
});
|
|
428
|
+
composioService._injectClientForTests(client);
|
|
429
|
+
const r = await composioService.connectionStatus('operator', 'github');
|
|
430
|
+
expect(r.connected).toBe(true);
|
|
431
|
+
expect(r.connectionId).toBe('conn-1');
|
|
432
|
+
});
|
|
210
433
|
});
|
|
211
434
|
|
|
212
435
|
describe('composioService — connect', () => {
|
|
213
|
-
|
|
436
|
+
// History:
|
|
437
|
+
// v0: called connectedAccounts.initiate({obj}) — wrong shape; threw
|
|
438
|
+
// "authConfigIds.0 should be a string …".
|
|
439
|
+
// v1: switched to client.toolkits.authorize(userId, slug, authConfigId)
|
|
440
|
+
// — that worked locally but Composio deprecated the endpoint it
|
|
441
|
+
// calls last (POST /connected_accounts) on 2026-05-28. Started
|
|
442
|
+
// returning 400 ConnectedAccount_BadRequest with the message
|
|
443
|
+
// "Use POST /api/v3/connected_accounts/link instead".
|
|
444
|
+
// v2 (current): replicate authorize's auth-config find-or-create
|
|
445
|
+
// flow ourselves, then finish with connectedAccounts.link()
|
|
446
|
+
// — the SDK method that maps to the new endpoint.
|
|
447
|
+
|
|
448
|
+
test('reuses an existing auth-config and calls the link endpoint', async () => {
|
|
214
449
|
const client = makeStubClient();
|
|
215
450
|
composioService._injectClientForTests(client);
|
|
216
451
|
const r = await composioService.connect('operator', 'github');
|
|
217
452
|
expect(r.success).toBe(true);
|
|
218
453
|
expect(r.connectLink).toMatch(/^https:\/\/connect\.composio\.dev/);
|
|
219
|
-
expect(r.connectionId).toBe('conn-
|
|
220
|
-
expect(
|
|
221
|
-
|
|
454
|
+
expect(r.connectionId).toBe('conn-new');
|
|
455
|
+
expect(r.authConfigId).toBe('auth-cfg-existing');
|
|
456
|
+
expect(r.usedExistingConfig).toBe(true);
|
|
457
|
+
// The deprecated path (.initiate) must NEVER be called.
|
|
458
|
+
expect(client.connectedAccounts.initiate).toBeUndefined();
|
|
459
|
+
expect(client.connectedAccounts.link).toHaveBeenCalledWith(
|
|
460
|
+
'operator', 'auth-cfg-existing', {}
|
|
461
|
+
);
|
|
462
|
+
// Didn't try to create a new one — there was already a hit.
|
|
463
|
+
expect(client.authConfigs.create).not.toHaveBeenCalled();
|
|
464
|
+
});
|
|
465
|
+
|
|
466
|
+
test('creates a managed auth-config when none exists for the toolkit', async () => {
|
|
467
|
+
const client = makeStubClient();
|
|
468
|
+
client.authConfigs.list = jest.fn().mockResolvedValue({ items: [] });
|
|
469
|
+
composioService._injectClientForTests(client);
|
|
470
|
+
const r = await composioService.connect('operator', 'canva');
|
|
471
|
+
expect(r.success).toBe(true);
|
|
472
|
+
expect(r.authConfigId).toBe('auth-cfg-new');
|
|
473
|
+
expect(r.createdConfig).toBe(true);
|
|
474
|
+
expect(client.authConfigs.create).toHaveBeenCalledWith('canva', {
|
|
475
|
+
type: 'use_composio_managed_auth',
|
|
476
|
+
name: 'canva Auth Config',
|
|
222
477
|
});
|
|
478
|
+
expect(client.connectedAccounts.link).toHaveBeenCalledWith(
|
|
479
|
+
'operator', 'auth-cfg-new', {}
|
|
480
|
+
);
|
|
481
|
+
});
|
|
482
|
+
|
|
483
|
+
test('passes through an explicit authConfigId (skips lookup + create)', async () => {
|
|
484
|
+
const client = makeStubClient();
|
|
485
|
+
composioService._injectClientForTests(client);
|
|
486
|
+
await composioService.connect('operator', 'github', { authConfigId: 'auth-cfg-explicit' });
|
|
487
|
+
expect(client.authConfigs.list).not.toHaveBeenCalled();
|
|
488
|
+
expect(client.authConfigs.create).not.toHaveBeenCalled();
|
|
489
|
+
expect(client.connectedAccounts.link).toHaveBeenCalledWith(
|
|
490
|
+
'operator', 'auth-cfg-explicit', {}
|
|
491
|
+
);
|
|
223
492
|
});
|
|
224
493
|
|
|
225
|
-
test('
|
|
494
|
+
test('forwards callbackUrl to the link options', async () => {
|
|
226
495
|
const client = makeStubClient();
|
|
227
496
|
composioService._injectClientForTests(client);
|
|
228
|
-
await composioService.connect('operator', 'github', {
|
|
229
|
-
|
|
230
|
-
userId: 'operator', toolkit: 'github', authConfigId: 'auth-cfg-xyz',
|
|
497
|
+
await composioService.connect('operator', 'github', {
|
|
498
|
+
authConfigId: 'auth-cfg-xyz', callbackUrl: 'https://app.example.com/oauth/cb',
|
|
231
499
|
});
|
|
500
|
+
expect(client.connectedAccounts.link).toHaveBeenCalledWith(
|
|
501
|
+
'operator', 'auth-cfg-xyz', { callbackUrl: 'https://app.example.com/oauth/cb' }
|
|
502
|
+
);
|
|
503
|
+
});
|
|
504
|
+
|
|
505
|
+
test('returns a clean error if the SDK is missing connectedAccounts.link', async () => {
|
|
506
|
+
const client = makeStubClient();
|
|
507
|
+
delete client.connectedAccounts.link;
|
|
508
|
+
composioService._injectClientForTests(client);
|
|
509
|
+
const r = await composioService.connect('operator', 'github');
|
|
510
|
+
expect(r.success).toBe(false);
|
|
511
|
+
expect(r.error).toMatch(/missing connectedAccounts\.link/);
|
|
512
|
+
});
|
|
513
|
+
|
|
514
|
+
test('authConfigs.create 400 → actionable "no managed-OAuth client" hint', async () => {
|
|
515
|
+
// Composio returns 400 when no managed OAuth client exists for the
|
|
516
|
+
// toolkit. The operator needs to register one in the dashboard.
|
|
517
|
+
const client = makeStubClient();
|
|
518
|
+
client.authConfigs.list = jest.fn().mockResolvedValue({ items: [] });
|
|
519
|
+
const err = new Error('No default auth config found for toolkit canva');
|
|
520
|
+
err.status = 400;
|
|
521
|
+
client.authConfigs.create = jest.fn().mockRejectedValue(err);
|
|
522
|
+
composioService._injectClientForTests(client);
|
|
523
|
+
const r = await composioService.connect('operator', 'canva');
|
|
524
|
+
expect(r.success).toBe(false);
|
|
525
|
+
expect(r.code).toBe('COMPOSIO_AUTH_CONFIG_MISSING');
|
|
526
|
+
expect(r.error).toMatch(/no managed-OAuth client/i);
|
|
527
|
+
expect(r.error).toMatch(/canva/);
|
|
528
|
+
expect(r.error).toMatch(/app\.composio\.dev/);
|
|
529
|
+
expect(r.rawError).toMatch(/No default auth config/);
|
|
530
|
+
});
|
|
531
|
+
|
|
532
|
+
test('link() "toolkit not found" → actionable slug-mismatch hint', async () => {
|
|
533
|
+
const client = makeStubClient();
|
|
534
|
+
client.connectedAccounts.link = jest.fn().mockRejectedValue(
|
|
535
|
+
new Error('ComposioToolkitNotFoundError: Toolkit with slug canva_design not found')
|
|
536
|
+
);
|
|
537
|
+
composioService._injectClientForTests(client);
|
|
538
|
+
const r = await composioService.connect('operator', 'canva_design');
|
|
539
|
+
expect(r.success).toBe(false);
|
|
540
|
+
expect(r.code).toBe('COMPOSIO_TOOLKIT_NOT_FOUND');
|
|
541
|
+
expect(r.error).toMatch(/doesn't exist in Composio's catalog/);
|
|
542
|
+
expect(r.error).toMatch(/list-toolkits/);
|
|
543
|
+
});
|
|
544
|
+
|
|
545
|
+
test('unrelated SDK errors pass through unchanged with authConfigId attached', async () => {
|
|
546
|
+
const client = makeStubClient();
|
|
547
|
+
client.connectedAccounts.link = jest.fn().mockRejectedValue(new Error('rate limit hit'));
|
|
548
|
+
composioService._injectClientForTests(client);
|
|
549
|
+
const r = await composioService.connect('operator', 'github');
|
|
550
|
+
expect(r.success).toBe(false);
|
|
551
|
+
expect(r.code).toBeUndefined();
|
|
552
|
+
expect(r.error).toMatch(/rate limit hit/);
|
|
553
|
+
// We still know which auth-config we were trying to link — surface
|
|
554
|
+
// it so the operator can debug.
|
|
555
|
+
expect(r.authConfigId).toBe('auth-cfg-existing');
|
|
556
|
+
});
|
|
557
|
+
});
|
|
558
|
+
|
|
559
|
+
describe('composioService — _normalizeListResult', () => {
|
|
560
|
+
test('returns plain arrays unchanged', () => {
|
|
561
|
+
expect(composioService._normalizeListResult([1, 2, 3])).toEqual([1, 2, 3]);
|
|
562
|
+
expect(composioService._normalizeListResult([])).toEqual([]);
|
|
563
|
+
});
|
|
564
|
+
test('unwraps {items}, {data}, {results} shapes', () => {
|
|
565
|
+
expect(composioService._normalizeListResult({ items: [1] })).toEqual([1]);
|
|
566
|
+
expect(composioService._normalizeListResult({ data: [2] })).toEqual([2]);
|
|
567
|
+
expect(composioService._normalizeListResult({ results: [3] })).toEqual([3]);
|
|
568
|
+
});
|
|
569
|
+
test('non-list-shaped / falsy inputs → []', () => {
|
|
570
|
+
expect(composioService._normalizeListResult(null)).toEqual([]);
|
|
571
|
+
expect(composioService._normalizeListResult(undefined)).toEqual([]);
|
|
572
|
+
expect(composioService._normalizeListResult('string')).toEqual([]);
|
|
573
|
+
expect(composioService._normalizeListResult({ unknown: true })).toEqual([]);
|
|
232
574
|
});
|
|
233
575
|
});
|
|
234
576
|
|
|
@@ -241,12 +583,17 @@ describe('composioService — disconnect', () => {
|
|
|
241
583
|
expect(client.connectedAccounts.delete).toHaveBeenCalledWith('conn-1');
|
|
242
584
|
});
|
|
243
585
|
|
|
244
|
-
test('disconnect by {userId, toolkitSlug} looks up the id
|
|
586
|
+
test('disconnect by {userId, toolkitSlug} looks up the id via .list (not .get)', async () => {
|
|
587
|
+
// The lookup now uses .list({userId, toolkit}) + client-side
|
|
588
|
+
// filter — same fix as connectionStatus to avoid the SDK
|
|
589
|
+
// "[object Object]" path-segment trap.
|
|
245
590
|
const client = makeStubClient();
|
|
246
591
|
composioService._injectClientForTests(client);
|
|
247
592
|
const r = await composioService.disconnect({ userId: 'operator', toolkitSlug: 'github' });
|
|
248
593
|
expect(r.success).toBe(true);
|
|
249
|
-
expect(client.connectedAccounts.
|
|
594
|
+
expect(client.connectedAccounts.list).toHaveBeenCalledWith(
|
|
595
|
+
expect.objectContaining({ userId: 'operator', toolkit: 'github' })
|
|
596
|
+
);
|
|
250
597
|
expect(client.connectedAccounts.delete).toHaveBeenCalledWith('conn-1');
|
|
251
598
|
});
|
|
252
599
|
|
|
@@ -259,7 +606,7 @@ describe('composioService — disconnect', () => {
|
|
|
259
606
|
|
|
260
607
|
test('handles missing connection cleanly when looking up by toolkit', async () => {
|
|
261
608
|
const client = makeStubClient();
|
|
262
|
-
client.connectedAccounts.
|
|
609
|
+
client.connectedAccounts.list = jest.fn().mockResolvedValue([]); // no connections
|
|
263
610
|
composioService._injectClientForTests(client);
|
|
264
611
|
const r = await composioService.disconnect({ userId: 'operator', toolkitSlug: 'github' });
|
|
265
612
|
expect(r.success).toBe(false);
|
|
@@ -268,20 +615,55 @@ describe('composioService — disconnect', () => {
|
|
|
268
615
|
});
|
|
269
616
|
|
|
270
617
|
describe('composioService — listTools', () => {
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
618
|
+
// Same story as listToolkits — the SDK's `client.tools.list` is
|
|
619
|
+
// internal-only; the public `tools.get(userId, filter)` wraps results
|
|
620
|
+
// in the LLM provider's format (function-calling shape) and strips
|
|
621
|
+
// toolkitSlug/displayName. We need the raw catalog shape, so we call
|
|
622
|
+
// REST directly.
|
|
623
|
+
|
|
624
|
+
test('forwards toolkit_slugs + user_id to REST', async () => {
|
|
625
|
+
const stub = stubFetch({
|
|
626
|
+
'/api/v3.1/tools': [[
|
|
627
|
+
{ slug: 'GITHUB_CREATE_AN_ISSUE', display_name: 'Create Issue',
|
|
628
|
+
description: 'Create issue', input_parameters: { type: 'object' },
|
|
629
|
+
toolkit: { slug: 'github' } },
|
|
630
|
+
]],
|
|
631
|
+
});
|
|
632
|
+
try {
|
|
633
|
+
const r = await composioService.listTools('github', 'operator');
|
|
634
|
+
expect(r.success).toBe(true);
|
|
635
|
+
expect(r.tools).toHaveLength(1);
|
|
636
|
+
expect(r.tools[0].slug).toBe('GITHUB_CREATE_AN_ISSUE');
|
|
637
|
+
expect(r.tools[0].displayName).toBe('Create Issue');
|
|
638
|
+
expect(r.tools[0].toolkitSlug).toBe('github');
|
|
639
|
+
// input_parameters → camelCase + aliases for legacy callers.
|
|
640
|
+
expect(r.tools[0].inputParameters).toEqual({ type: 'object' });
|
|
641
|
+
expect(r.tools[0].input).toEqual({ type: 'object' });
|
|
642
|
+
expect(r.tools[0].parameters).toEqual({ type: 'object' });
|
|
643
|
+
const call = stub.calls.find(c => c.path === '/api/v3.1/tools');
|
|
644
|
+
expect(call.query.toolkit_slugs).toBe('github');
|
|
645
|
+
expect(call.query.user_id).toBe('operator');
|
|
646
|
+
} finally { stub.restore(); }
|
|
278
647
|
});
|
|
279
648
|
|
|
280
|
-
test('omits
|
|
281
|
-
const
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
649
|
+
test('omits user_id from the REST query when not provided', async () => {
|
|
650
|
+
const stub = stubFetch({
|
|
651
|
+
'/api/v3.1/tools': [[
|
|
652
|
+
{ slug: 'X', toolkit: { slug: 'github' } },
|
|
653
|
+
]],
|
|
654
|
+
});
|
|
655
|
+
try {
|
|
656
|
+
await composioService.listTools('github');
|
|
657
|
+
const call = stub.calls.find(c => c.path === '/api/v3.1/tools');
|
|
658
|
+
expect(call.query.toolkit_slugs).toBe('github');
|
|
659
|
+
expect(call.query.user_id).toBeUndefined();
|
|
660
|
+
} finally { stub.restore(); }
|
|
661
|
+
});
|
|
662
|
+
|
|
663
|
+
test('rejects empty toolkitSlug with a clean error', async () => {
|
|
664
|
+
const r = await composioService.listTools('');
|
|
665
|
+
expect(r.success).toBe(false);
|
|
666
|
+
expect(r.error).toMatch(/toolkitSlug is required/);
|
|
285
667
|
});
|
|
286
668
|
});
|
|
287
669
|
|
|
@@ -559,6 +559,97 @@ describe('error fan-out vs watch-gating', () => {
|
|
|
559
559
|
expect(sent).toBeDefined();
|
|
560
560
|
});
|
|
561
561
|
|
|
562
|
+
test('agent_error dedup: identical errors within the window only send once', async () => {
|
|
563
|
+
const svc = makeService();
|
|
564
|
+
const bot = await connected(svc);
|
|
565
|
+
await bot.simulateMessage(userMsg(111, '/start'));
|
|
566
|
+
|
|
567
|
+
const payload = { type: 'agent_error', agentId: 'a1', agentName: 'Cody', message: 'boom' };
|
|
568
|
+
await svc._handleBroadcastEvent(payload);
|
|
569
|
+
await svc._handleBroadcastEvent(payload);
|
|
570
|
+
await svc._handleBroadcastEvent(payload);
|
|
571
|
+
await svc._handleBroadcastEvent(payload);
|
|
572
|
+
|
|
573
|
+
const errorMessages = bot.calls.sendMessage.filter(c => c.text.includes('Agent Error'));
|
|
574
|
+
// Only the first one should have made it through; the next three are
|
|
575
|
+
// counted but suppressed.
|
|
576
|
+
expect(errorMessages).toHaveLength(1);
|
|
577
|
+
// Dedup state confirms three were absorbed.
|
|
578
|
+
const entry = [...svc._errorBroadcastDedup.values()][0];
|
|
579
|
+
expect(entry?.count).toBe(4);
|
|
580
|
+
});
|
|
581
|
+
|
|
582
|
+
test('agent_error dedup: different agents do NOT collide', async () => {
|
|
583
|
+
const svc = makeService();
|
|
584
|
+
const bot = await connected(svc);
|
|
585
|
+
await bot.simulateMessage(userMsg(111, '/start'));
|
|
586
|
+
|
|
587
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a1', agentName: 'Cody', message: 'same' });
|
|
588
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a2', agentName: 'Carol', message: 'same' });
|
|
589
|
+
|
|
590
|
+
const errorMessages = bot.calls.sendMessage.filter(c => c.text.includes('Agent Error'));
|
|
591
|
+
expect(errorMessages).toHaveLength(2);
|
|
592
|
+
});
|
|
593
|
+
|
|
594
|
+
test('agent_error dedup: textual variations of same error coalesce', async () => {
|
|
595
|
+
const svc = makeService();
|
|
596
|
+
const bot = await connected(svc);
|
|
597
|
+
await bot.simulateMessage(userMsg(111, '/start'));
|
|
598
|
+
|
|
599
|
+
// Same error, formatted slightly differently — should dedup.
|
|
600
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a1', message: 'Connection refused' });
|
|
601
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a1', message: 'connection refused' });
|
|
602
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a1', message: ' Connection refused ' });
|
|
603
|
+
|
|
604
|
+
const errorMessages = bot.calls.sendMessage.filter(c => c.text.includes('Agent Error'));
|
|
605
|
+
expect(errorMessages).toHaveLength(1);
|
|
606
|
+
});
|
|
607
|
+
|
|
608
|
+
test('agent_error dedup: window close emits a "still happening" summary when count > 1', async () => {
|
|
609
|
+
jest.useFakeTimers();
|
|
610
|
+
try {
|
|
611
|
+
const svc = makeService();
|
|
612
|
+
const bot = await connected(svc);
|
|
613
|
+
await bot.simulateMessage(userMsg(111, '/start'));
|
|
614
|
+
|
|
615
|
+
// First fires immediately, plus two suppressed.
|
|
616
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a1', agentName: 'Cody', message: 'boom' });
|
|
617
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a1', agentName: 'Cody', message: 'boom' });
|
|
618
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a1', agentName: 'Cody', message: 'boom' });
|
|
619
|
+
|
|
620
|
+
// Advance past the 5-minute dedup window.
|
|
621
|
+
jest.advanceTimersByTime(5 * 60 * 1000 + 100);
|
|
622
|
+
// Let the timer callback's microtasks resolve.
|
|
623
|
+
await Promise.resolve();
|
|
624
|
+
await Promise.resolve();
|
|
625
|
+
|
|
626
|
+
const summary = bot.calls.sendMessage.find(c => c.text.includes('still happening'));
|
|
627
|
+
expect(summary).toBeDefined();
|
|
628
|
+
expect(summary.text).toMatch(/2 more/);
|
|
629
|
+
} finally {
|
|
630
|
+
jest.useRealTimers();
|
|
631
|
+
}
|
|
632
|
+
});
|
|
633
|
+
|
|
634
|
+
test('agent_error dedup: a single error does NOT trigger a summary', async () => {
|
|
635
|
+
jest.useFakeTimers();
|
|
636
|
+
try {
|
|
637
|
+
const svc = makeService();
|
|
638
|
+
const bot = await connected(svc);
|
|
639
|
+
await bot.simulateMessage(userMsg(111, '/start'));
|
|
640
|
+
|
|
641
|
+
await svc._handleBroadcastEvent({ type: 'agent_error', agentId: 'a1', message: 'one-off' });
|
|
642
|
+
jest.advanceTimersByTime(5 * 60 * 1000 + 100);
|
|
643
|
+
await Promise.resolve();
|
|
644
|
+
|
|
645
|
+
// The original message went out. No follow-up summary.
|
|
646
|
+
const summary = bot.calls.sendMessage.find(c => c.text.includes('still happening'));
|
|
647
|
+
expect(summary).toBeUndefined();
|
|
648
|
+
} finally {
|
|
649
|
+
jest.useRealTimers();
|
|
650
|
+
}
|
|
651
|
+
});
|
|
652
|
+
|
|
562
653
|
test('execution_stopped does NOT relay unless /watch is on', async () => {
|
|
563
654
|
const svc = makeService();
|
|
564
655
|
const bot = await connected(svc);
|