onbuzz 3.9.2 → 3.9.6
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/push-image.sh +43 -0
- package/scripts/setup-acr.sh +65 -0
- package/src/__tests__/resolvePreferredModel.test.js +153 -0
- package/src/index.js +36 -16
- package/src/interfaces/__tests__/authRoutes.test.js +211 -139
- package/src/interfaces/__tests__/remoteSessionAuth.test.js +262 -0
- package/src/interfaces/webServer.js +135 -4
- package/src/services/aiService.js +3 -3
- package/src/tools/videoTool.js +21 -17
- package/web-ui/build/index.html +2 -2
- package/web-ui/build/static/1c-BU43ZrVw.js +1 -0
- package/web-ui/build/static/abap-AoL-lRFD.js +1 -0
- package/web-ui/build/static/abnf-96OFWMCD.js +1 -0
- package/web-ui/build/static/abnf-C41Cofd6.js +1 -0
- package/web-ui/build/static/accesslog-BcnAo7ES.js +1 -0
- package/web-ui/build/static/actionscript-BFOz5mA2.js +1 -0
- package/web-ui/build/static/actionscript-DJGQt8u5.js +1 -0
- package/web-ui/build/static/ada-CwKeODqT.js +1 -0
- package/web-ui/build/static/ada-DchU8VGZ.js +1 -0
- package/web-ui/build/static/agda-BiNn9WvW.js +1 -0
- package/web-ui/build/static/al-BV88nGgg.js +1 -0
- package/web-ui/build/static/angelscript-COMetbQf.js +1 -0
- package/web-ui/build/static/antlr4-DcxHPzCP.js +1 -0
- package/web-ui/build/static/apache-DBeh3rw8.js +1 -0
- package/web-ui/build/static/apacheconf-CMIBfQ9p.js +1 -0
- package/web-ui/build/static/apex-Cs5QQM6z.js +1 -0
- package/web-ui/build/static/apl-Dx-K9gOV.js +1 -0
- package/web-ui/build/static/applescript--9cY-_M0.js +1 -0
- package/web-ui/build/static/applescript-BcsYpX4C.js +1 -0
- package/web-ui/build/static/aql-B6_wZJ19.js +1 -0
- package/web-ui/build/static/arcade-ML5yo01k.js +1 -0
- package/web-ui/build/static/arduino-CXGPdWdX.js +1 -0
- package/web-ui/build/static/arduino-Dg8nk7Ia.js +1 -0
- package/web-ui/build/static/arff-gVSLqgST.js +1 -0
- package/web-ui/build/static/armasm-DAsE4rEm.js +1 -0
- package/web-ui/build/static/asciidoc-C5znngFU.js +1 -0
- package/web-ui/build/static/asciidoc-DYALRNYZ.js +1 -0
- package/web-ui/build/static/asm6502-DDgAH1tv.js +1 -0
- package/web-ui/build/static/asmatmel-DOphTD2l.js +1 -0
- package/web-ui/build/static/aspectj-CulZkr51.js +1 -0
- package/web-ui/build/static/aspnet-CNX6-Mkw.js +1 -0
- package/web-ui/build/static/autohotkey-D0vVKqB7.js +1 -0
- package/web-ui/build/static/autohotkey-DDYXV6Yq.js +1 -0
- package/web-ui/build/static/autoit-CxUJueRz.js +1 -0
- package/web-ui/build/static/autoit-D9JFllVP.js +1 -0
- package/web-ui/build/static/avisynth-BenZbKzO.js +1 -0
- package/web-ui/build/static/avrasm-uYahqQ8h.js +1 -0
- package/web-ui/build/static/avro-idl-CfbM7gLn.js +1 -0
- package/web-ui/build/static/awk-Ca723U04.js +1 -0
- package/web-ui/build/static/axapta-Bd89lJnD.js +1 -0
- package/web-ui/build/static/bash-9j3v2pHC.js +1 -0
- package/web-ui/build/static/bash-D3FWVCYG.js +1 -0
- package/web-ui/build/static/basic-DdNa7MnE.js +1 -0
- package/web-ui/build/static/basic-E4QxjXCY.js +1 -0
- package/web-ui/build/static/batch-CfCADUvD.js +1 -0
- package/web-ui/build/static/bbcode-WshNX5WN.js +1 -0
- package/web-ui/build/static/bicep-D8FjRewr.js +1 -0
- package/web-ui/build/static/birb-88EdZvI2.js +1 -0
- package/web-ui/build/static/bison-D_FuD8Pc.js +1 -0
- package/web-ui/build/static/bnf-CbP5W98L.js +1 -0
- package/web-ui/build/static/bnf-Cml6OuCd.js +1 -0
- package/web-ui/build/static/brainfuck-BAX8RtaB.js +1 -0
- package/web-ui/build/static/brainfuck-C6aQP1EH.js +1 -0
- package/web-ui/build/static/brightscript-CQvzUDkK.js +1 -0
- package/web-ui/build/static/bro-D1TUGEOB.js +1 -0
- package/web-ui/build/static/bsl-Cz666_jX.js +1 -0
- package/web-ui/build/static/c-Br3hSof9.js +1 -0
- package/web-ui/build/static/c-CnhEGx2K.js +1 -0
- package/web-ui/build/static/c-like-8ph3qbGh.js +1 -0
- package/web-ui/build/static/cal-IgRtvJyR.js +1 -0
- package/web-ui/build/static/capnproto-Brw1rI-t.js +1 -0
- package/web-ui/build/static/ceylon-DZhLRlUy.js +1 -0
- package/web-ui/build/static/cfscript-DQGyJKwK.js +1 -0
- package/web-ui/build/static/chaiscript-C4OGz_un.js +1 -0
- package/web-ui/build/static/cil-DicjcGqk.js +1 -0
- package/web-ui/build/static/clean-DALZvuMV.js +1 -0
- package/web-ui/build/static/clojure-DPpZu94_.js +1 -0
- package/web-ui/build/static/clojure-Wr_wuwna.js +1 -0
- package/web-ui/build/static/clojure-repl-BDrvmjMJ.js +1 -0
- package/web-ui/build/static/cmake-B14DY3nI.js +1 -0
- package/web-ui/build/static/cmake-SYFQC59q.js +1 -0
- package/web-ui/build/static/cobol-abUH09OX.js +1 -0
- package/web-ui/build/static/coffeescript-Bky52ZtC.js +1 -0
- package/web-ui/build/static/coffeescript-zCTO0lvd.js +1 -0
- package/web-ui/build/static/concurnas-CU2vlX2t.js +1 -0
- package/web-ui/build/static/coq-CtQeoOxK.js +1 -0
- package/web-ui/build/static/coq-U_ekdUOC.js +1 -0
- package/web-ui/build/static/cos-I1RAZGcd.js +1 -0
- package/web-ui/build/static/cpp-CBgfByvO.js +1 -0
- package/web-ui/build/static/cpp-DOgzX9Fr.js +1 -0
- package/web-ui/build/static/crmsh-C564oTI3.js +1 -0
- package/web-ui/build/static/crystal-BAkf0Lyu.js +1 -0
- package/web-ui/build/static/crystal-S6p_ZP8F.js +1 -0
- package/web-ui/build/static/csharp-4Eckg4RD.js +1 -0
- package/web-ui/build/static/csharp-BbncLZi-.js +1 -0
- package/web-ui/build/static/cshtml-3CAfDEZr.js +1 -0
- package/web-ui/build/static/csp-B1uCSPSv.js +1 -0
- package/web-ui/build/static/csp-DMRqPioi.js +1 -0
- package/web-ui/build/static/css-BGUkWLMn.js +1 -0
- package/web-ui/build/static/css-extras-BvWk25Qq.js +1 -0
- package/web-ui/build/static/csv-B4b2Q5_f.js +1 -0
- package/web-ui/build/static/cypher-poGwJkDD.js +1 -0
- package/web-ui/build/static/d-DMSHgHAy.js +1 -0
- package/web-ui/build/static/d-cV9sHfbC.js +1 -0
- package/web-ui/build/static/dart-CAw4osRs.js +1 -0
- package/web-ui/build/static/dart-DNd3kAhv.js +1 -0
- package/web-ui/build/static/dataweave-DrBaourx.js +1 -0
- package/web-ui/build/static/dax-BrZwLORG.js +1 -0
- package/web-ui/build/static/delphi-Ct4aE4aH.js +1 -0
- package/web-ui/build/static/dhall-BYoLaIQB.js +1 -0
- package/web-ui/build/static/diff-CnmWuCgJ.js +1 -0
- package/web-ui/build/static/diff-zrcvdd0a.js +1 -0
- package/web-ui/build/static/django-C-oZ7YKd.js +1 -0
- package/web-ui/build/static/django-JpRfMOZ2.js +1 -0
- package/web-ui/build/static/dns-DsSuoCT5.js +1 -0
- package/web-ui/build/static/dns-zone-file-DGrpD-sD.js +1 -0
- package/web-ui/build/static/docker-BIfKAgOO.js +1 -0
- package/web-ui/build/static/dockerfile-pDKCRsua.js +1 -0
- package/web-ui/build/static/dos-tuNLH04p.js +1 -0
- package/web-ui/build/static/dot-ByjtD8Iw.js +1 -0
- package/web-ui/build/static/dsconfig-BCjL4yBF.js +1 -0
- package/web-ui/build/static/dts-DOYzn60p.js +1 -0
- package/web-ui/build/static/dust-CPf1De2a.js +1 -0
- package/web-ui/build/static/ebnf-BqPpYQsv.js +1 -0
- package/web-ui/build/static/ebnf-DtowFnom.js +1 -0
- package/web-ui/build/static/editorconfig-ByGC7lfc.js +1 -0
- package/web-ui/build/static/eiffel-ql_YAW83.js +1 -0
- package/web-ui/build/static/ejs-CEIk0b1t.js +1 -0
- package/web-ui/build/static/elixir-5cZo1rKW.js +1 -0
- package/web-ui/build/static/elixir-kLu8Siuw.js +1 -0
- package/web-ui/build/static/elm-CFEXRK2g.js +1 -0
- package/web-ui/build/static/elm-O7LEJa6N.js +1 -0
- package/web-ui/build/static/erb-CMspOWfC.js +1 -0
- package/web-ui/build/static/erb-DmVFtWWQ.js +1 -0
- package/web-ui/build/static/erlang-CNS4Vy5W.js +1 -0
- package/web-ui/build/static/erlang-DS3YMI6f.js +1 -0
- package/web-ui/build/static/erlang-repl-COpdqM-k.js +1 -0
- package/web-ui/build/static/etlua-BaywXnJ4.js +1 -0
- package/web-ui/build/static/excel-DbD_vagJ.js +1 -0
- package/web-ui/build/static/excel-formula-DvX9phaD.js +1 -0
- package/web-ui/build/static/factor-Dmyoo9jr.js +1 -0
- package/web-ui/build/static/false-CFFZ5oF1.js +1 -0
- package/web-ui/build/static/firestore-security-rules-6gF61FL7.js +1 -0
- package/web-ui/build/static/fix-DqD23dpu.js +1 -0
- package/web-ui/build/static/flix-ByG_SwOl.js +1 -0
- package/web-ui/build/static/flow-_rIgWtyE.js +1 -0
- package/web-ui/build/static/fortran-BxMeEQFu.js +1 -0
- package/web-ui/build/static/fortran-JYN66CoM.js +1 -0
- package/web-ui/build/static/fsharp-DUIudRus.js +1 -0
- package/web-ui/build/static/fsharp-dwrir66Q.js +1 -0
- package/web-ui/build/static/ftl-DE2kycMu.js +1 -0
- package/web-ui/build/static/gams-BdaFBkUq.js +1 -0
- package/web-ui/build/static/gap-DG6uTKtq.js +1 -0
- package/web-ui/build/static/gauss-CdZRpgQN.js +1 -0
- package/web-ui/build/static/gcode-BCwsx3FN.js +1 -0
- package/web-ui/build/static/gcode-DqOLuGTU.js +1 -0
- package/web-ui/build/static/gdscript-CQsGMP79.js +1 -0
- package/web-ui/build/static/gedcom-DjiaJO4h.js +1 -0
- package/web-ui/build/static/gherkin-DKQrzpoe.js +1 -0
- package/web-ui/build/static/gherkin-MN1tGQ_p.js +1 -0
- package/web-ui/build/static/git-BV33OtmB.js +1 -0
- package/web-ui/build/static/glsl-BrKcS_A_.js +1 -0
- package/web-ui/build/static/glsl-zNpiyDT0.js +1 -0
- package/web-ui/build/static/gml-B42QqZwd.js +1 -0
- package/web-ui/build/static/gml-wLSDMYgV.js +1 -0
- package/web-ui/build/static/gn-Bh6e2j59.js +1 -0
- package/web-ui/build/static/go-BcV51Gep.js +1 -0
- package/web-ui/build/static/go-DoEsEvyO.js +1 -0
- package/web-ui/build/static/go-module-CPiCVk-t.js +1 -0
- package/web-ui/build/static/golo-Dm6Qh0rv.js +1 -0
- package/web-ui/build/static/gradle-Bq5SCTs-.js +1 -0
- package/web-ui/build/static/graphql-BMKmdCzB.js +1 -0
- package/web-ui/build/static/groovy-BUPY3Q3Q.js +1 -0
- package/web-ui/build/static/groovy-DJ1fIXgB.js +1 -0
- package/web-ui/build/static/haml-CzbX1nD7.js +1 -0
- package/web-ui/build/static/haml-vci5GS4H.js +1 -0
- package/web-ui/build/static/handlebars-DDKzQGIO.js +1 -0
- package/web-ui/build/static/handlebars-DUBBysQz.js +1 -0
- package/web-ui/build/static/haskell-Becgtpfw.js +1 -0
- package/web-ui/build/static/haskell-DzmxROXt.js +1 -0
- package/web-ui/build/static/haxe-Dn6vv5Ho.js +1 -0
- package/web-ui/build/static/haxe-N5We1g-1.js +1 -0
- package/web-ui/build/static/hcl-aU8RXzqH.js +1 -0
- package/web-ui/build/static/hlsl-DnxH7wd4.js +1 -0
- package/web-ui/build/static/hoon-DxQk5J8Y.js +1 -0
- package/web-ui/build/static/hpkp-CXTY4okp.js +1 -0
- package/web-ui/build/static/hsp-ChPgc1iH.js +1 -0
- package/web-ui/build/static/hsts-DhqErzSD.js +1 -0
- package/web-ui/build/static/htmlbars-C1RX3QEK.js +1 -0
- package/web-ui/build/static/http-CdQuhyze.js +1 -0
- package/web-ui/build/static/http-DIfbUO-8.js +1 -0
- package/web-ui/build/static/hy-CtuvNSVL.js +1 -0
- package/web-ui/build/static/ichigojam-Dhb1oxgM.js +1 -0
- package/web-ui/build/static/icon-18yeuSqY.js +1 -0
- package/web-ui/build/static/icu-message-format-BtING76I.js +1 -0
- package/web-ui/build/static/idris-BpXksRPQ.js +1 -0
- package/web-ui/build/static/iecst-DxsuKh-u.js +1 -0
- package/web-ui/build/static/ignore-LFUqEXDc.js +1 -0
- package/web-ui/build/static/index-BwNJoEC1.css +1 -0
- package/web-ui/build/static/index-CNhxse_k.js +831 -0
- package/web-ui/build/static/index-DTSROa9m.js +13 -0
- package/web-ui/build/static/index-Dn1rYKSW.js +1 -0
- package/web-ui/build/static/inform7-CMWs3Icc.js +1 -0
- package/web-ui/build/static/inform7-IKJ-i25v.js +1 -0
- package/web-ui/build/static/ini-BKx9RlYa.js +1 -0
- package/web-ui/build/static/ini-OuIKSh9I.js +1 -0
- package/web-ui/build/static/io-DsdrD9ck.js +1 -0
- package/web-ui/build/static/irpf90-D8RwjO-X.js +1 -0
- package/web-ui/build/static/isbl-B19anZ4P.js +1 -0
- package/web-ui/build/static/j-cS0ZhHxg.js +1 -0
- package/web-ui/build/static/java-BArfyDLP.js +1 -0
- package/web-ui/build/static/java-CVssvoho.js +1 -0
- package/web-ui/build/static/javadoc-BbYTABTG.js +1 -0
- package/web-ui/build/static/javadoclike-reViVmsX.js +1 -0
- package/web-ui/build/static/javascript-C8BGzZvz.js +1 -0
- package/web-ui/build/static/javastacktrace-DgQT1sKr.js +1 -0
- package/web-ui/build/static/jboss-cli-CXzftW3Q.js +1 -0
- package/web-ui/build/static/jexl-DfYeVq7m.js +1 -0
- package/web-ui/build/static/jolie-BR1u31Sa.js +1 -0
- package/web-ui/build/static/jq-C1FEtJ5S.js +1 -0
- package/web-ui/build/static/js-extras-BRujBZgr.js +1 -0
- package/web-ui/build/static/js-templates-CgsCAf95.js +1 -0
- package/web-ui/build/static/jsdoc-BAN_COOq.js +1 -0
- package/web-ui/build/static/json-CO83p783.js +1 -0
- package/web-ui/build/static/json-D_vV4rAm.js +1 -0
- package/web-ui/build/static/json5-DBDJJEbn.js +1 -0
- package/web-ui/build/static/jsonp-b6P9-KKS.js +1 -0
- package/web-ui/build/static/jsstacktrace-BgPNj9Kj.js +1 -0
- package/web-ui/build/static/jsx-Co4GcrAm.js +1 -0
- package/web-ui/build/static/julia-B9omll60.js +1 -0
- package/web-ui/build/static/julia-BHDCyM-i.js +1 -0
- package/web-ui/build/static/julia-repl-C7Eb4bgJ.js +1 -0
- package/web-ui/build/static/keepalived-Dzp76shL.js +1 -0
- package/web-ui/build/static/keyman-DNvXbNCF.js +1 -0
- package/web-ui/build/static/kotlin-eb0_7isz.js +1 -0
- package/web-ui/build/static/kotlin-i_bUq7c5.js +1 -0
- package/web-ui/build/static/kumir-bzILNJNt.js +1 -0
- package/web-ui/build/static/kusto-DkykNNg-.js +1 -0
- package/web-ui/build/static/lasso-Cqgl3L5V.js +1 -0
- package/web-ui/build/static/latex-BK2d4H00.js +1 -0
- package/web-ui/build/static/latex-CCY9RWja.js +1 -0
- package/web-ui/build/static/latte--1mLyI-m.js +1 -0
- package/web-ui/build/static/ldif-CKpl0obl.js +1 -0
- package/web-ui/build/static/leaf-Cylh6k2i.js +1 -0
- package/web-ui/build/static/less-BF2V9-r1.js +1 -0
- package/web-ui/build/static/less-DZnIlP4J.js +1 -0
- package/web-ui/build/static/lilypond-Q-51NK9a.js +1 -0
- package/web-ui/build/static/liquid-BtFjuu34.js +1 -0
- package/web-ui/build/static/lisp-BTSZLEXC.js +1 -0
- package/web-ui/build/static/lisp-mBPUREKp.js +1 -0
- package/web-ui/build/static/livecodeserver-X2MkrtIh.js +1 -0
- package/web-ui/build/static/livescript-BCGPODju.js +1 -0
- package/web-ui/build/static/livescript-CSRilU12.js +1 -0
- package/web-ui/build/static/llvm-BrA-OPc0.js +1 -0
- package/web-ui/build/static/llvm-CX47EYi9.js +1 -0
- package/web-ui/build/static/log-UmKn5LCr.js +1 -0
- package/web-ui/build/static/lolcode-CzokJ_7T.js +1 -0
- package/web-ui/build/static/lsl-zawAQf0T.js +1 -0
- package/web-ui/build/static/lua-AzLMAnp_.js +1 -0
- package/web-ui/build/static/lua-BCYatl_B.js +1 -0
- package/web-ui/build/static/magma-Vk_HAjNd.js +1 -0
- package/web-ui/build/static/makefile-CBhQfnCA.js +1 -0
- package/web-ui/build/static/makefile-CqmpfcQv.js +1 -0
- package/web-ui/build/static/markdown-DEeiASnV.js +1 -0
- package/web-ui/build/static/markdown-MMAcC-4P.js +1 -0
- package/web-ui/build/static/markup-templating-BIcrJ22L.js +1 -0
- package/web-ui/build/static/mathematica-B0zDtahh.js +1 -0
- package/web-ui/build/static/matlab-BfcWtjh0.js +1 -0
- package/web-ui/build/static/matlab-CzvSbe8w.js +1 -0
- package/web-ui/build/static/maxima-D_OOwDHQ.js +1 -0
- package/web-ui/build/static/maxscript-B0UQqykR.js +1 -0
- package/web-ui/build/static/mel-5BfrTNON.js +1 -0
- package/web-ui/build/static/mel-DVL_6rnq.js +1 -0
- package/web-ui/build/static/mercury-CaNr8hHX.js +1 -0
- package/web-ui/build/static/mermaid-CqSXXPCa.js +1 -0
- package/web-ui/build/static/mipsasm-KebNef0S.js +1 -0
- package/web-ui/build/static/mizar-87NmyJPg.js +1 -0
- package/web-ui/build/static/mizar-Bh-iPnnJ.js +1 -0
- package/web-ui/build/static/mojolicious-RdAGGOBG.js +1 -0
- package/web-ui/build/static/mongodb-D-3TyeHe.js +1 -0
- package/web-ui/build/static/monkey-CBl0NH_G.js +1 -0
- package/web-ui/build/static/monkey-_lVf4ZFO.js +1 -0
- package/web-ui/build/static/moonscript-BWoLiJse.js +1 -0
- package/web-ui/build/static/moonscript-DvK6XosR.js +1 -0
- package/web-ui/build/static/n1ql-BHaHIJwU.js +1 -0
- package/web-ui/build/static/n1ql-DHG6la1y.js +1 -0
- package/web-ui/build/static/n4js-BnEnODnl.js +1 -0
- package/web-ui/build/static/nand2tetris-hdl-Bx_Sdku7.js +1 -0
- package/web-ui/build/static/naniscript-C9LlE8Sm.js +1 -0
- package/web-ui/build/static/nasm-C2RqJeMj.js +1 -0
- package/web-ui/build/static/neon-Htd-1WHg.js +1 -0
- package/web-ui/build/static/nevod-xEEcHJ6H.js +1 -0
- package/web-ui/build/static/nginx-DHZ2TmrY.js +1 -0
- package/web-ui/build/static/nginx-fVaFLr6L.js +1 -0
- package/web-ui/build/static/nim-C0kLUnOo.js +1 -0
- package/web-ui/build/static/nim-D2t9WTJG.js +1 -0
- package/web-ui/build/static/nix-BgS9-fG3.js +1 -0
- package/web-ui/build/static/nix-CJ-ZtUjs.js +1 -0
- package/web-ui/build/static/node-repl-BqDf1Wqa.js +1 -0
- package/web-ui/build/static/nsis-BcbMIXXt.js +1 -0
- package/web-ui/build/static/nsis-Clmq9ubM.js +1 -0
- package/web-ui/build/static/objectivec-CQCJHkDn.js +1 -0
- package/web-ui/build/static/objectivec-l-L7sw2F.js +1 -0
- package/web-ui/build/static/ocaml-CLhfFI9J.js +1 -0
- package/web-ui/build/static/ocaml-CVZbp5Q6.js +1 -0
- package/web-ui/build/static/opencl-FaoxED_5.js +1 -0
- package/web-ui/build/static/openqasm-DowdIaHJ.js +1 -0
- package/web-ui/build/static/openscad-CuV43J87.js +1 -0
- package/web-ui/build/static/oxygene-DFl_S4Mo.js +1 -0
- package/web-ui/build/static/oz-CrZEGs03.js +1 -0
- package/web-ui/build/static/parigp-CgI9msS-.js +1 -0
- package/web-ui/build/static/parser-nTYAMRRR.js +1 -0
- package/web-ui/build/static/parser3-B-s7V2NG.js +1 -0
- package/web-ui/build/static/pascal-DxyFzkBI.js +1 -0
- package/web-ui/build/static/pascaligo-pTESG7CK.js +1 -0
- package/web-ui/build/static/pcaxis-B2X2sY8s.js +1 -0
- package/web-ui/build/static/peoplecode-D3dixWRI.js +1 -0
- package/web-ui/build/static/perl-DzF9wk2I.js +1 -0
- package/web-ui/build/static/perl-r6iIkk3J.js +1 -0
- package/web-ui/build/static/pf-BHt68zPf.js +1 -0
- package/web-ui/build/static/pgsql-DrWBN0mn.js +1 -0
- package/web-ui/build/static/php-B9P0S_Yv.js +1 -0
- package/web-ui/build/static/php-Dq2u1evi.js +1 -0
- package/web-ui/build/static/php-extras-GhxZmNQn.js +1 -0
- package/web-ui/build/static/php-template-wduD2F6a.js +1 -0
- package/web-ui/build/static/phpdoc-S6AgvZj9.js +1 -0
- package/web-ui/build/static/plaintext-CkefHWd1.js +1 -0
- package/web-ui/build/static/plsql-ChhnkKyq.js +1 -0
- package/web-ui/build/static/pony-Ci4oRl2L.js +1 -0
- package/web-ui/build/static/powerquery-htr17QYt.js +1 -0
- package/web-ui/build/static/powershell-BjdbtsWh.js +1 -0
- package/web-ui/build/static/powershell-CfTH6v8E.js +1 -0
- package/web-ui/build/static/processing-CyhVXfth.js +1 -0
- package/web-ui/build/static/processing-DRd0DN-1.js +1 -0
- package/web-ui/build/static/profile-CzLbiRVw.js +1 -0
- package/web-ui/build/static/prolog-C9Bd3AiH.js +1 -0
- package/web-ui/build/static/prolog-SNjuNM01.js +1 -0
- package/web-ui/build/static/promql-w_4MRJZ5.js +1 -0
- package/web-ui/build/static/properties-Bu21gd8n.js +1 -0
- package/web-ui/build/static/properties-CxUTIgqR.js +1 -0
- package/web-ui/build/static/protobuf-Dw_RQ_nq.js +1 -0
- package/web-ui/build/static/protobuf-I-uLxCyW.js +1 -0
- package/web-ui/build/static/psl-60y7CGad.js +1 -0
- package/web-ui/build/static/pug-6TwxG97U.js +1 -0
- package/web-ui/build/static/puppet-DsB7SV7C.js +1 -0
- package/web-ui/build/static/puppet-xYMQTgSK.js +1 -0
- package/web-ui/build/static/pure-B-46644a.js +1 -0
- package/web-ui/build/static/purebasic-C2jTmxCp.js +1 -0
- package/web-ui/build/static/purebasic-DB1qz_79.js +1 -0
- package/web-ui/build/static/purescript-C7X1Jhpv.js +1 -0
- package/web-ui/build/static/python-DdZkdREO.js +1 -0
- package/web-ui/build/static/python-g-3ev0jp.js +1 -0
- package/web-ui/build/static/python-repl-Ba3YgabT.js +1 -0
- package/web-ui/build/static/q-4Xd1x0tI.js +1 -0
- package/web-ui/build/static/q-CFLewr3P.js +1 -0
- package/web-ui/build/static/qml-D1wL69-t.js +1 -0
- package/web-ui/build/static/qml-o0TpTomi.js +1 -0
- package/web-ui/build/static/qore-Bu32uyvk.js +1 -0
- package/web-ui/build/static/qsharp-BlenDeSE.js +1 -0
- package/web-ui/build/static/r-x-9dl4d1.js +1 -0
- package/web-ui/build/static/r-xEFM_Z9P.js +1 -0
- package/web-ui/build/static/racket-B6M0zyVn.js +1 -0
- package/web-ui/build/static/reason-B_YmUFeb.js +1 -0
- package/web-ui/build/static/reasonml-DqV3O6jw.js +1 -0
- package/web-ui/build/static/regex-RpvIR1UC.js +1 -0
- package/web-ui/build/static/rego-DLBfnzDz.js +1 -0
- package/web-ui/build/static/renpy-BPyvMyYV.js +1 -0
- package/web-ui/build/static/rest-BOvObf4b.js +1 -0
- package/web-ui/build/static/rib-CfbyRlOV.js +1 -0
- package/web-ui/build/static/rip-BmGgp-ky.js +1 -0
- package/web-ui/build/static/roboconf-BjlIhdyT.js +1 -0
- package/web-ui/build/static/roboconf-gCvzQFG_.js +1 -0
- package/web-ui/build/static/robotframework-DMIYiZ9n.js +1 -0
- package/web-ui/build/static/routeros-dIA3JsYo.js +1 -0
- package/web-ui/build/static/rsl-C-IHLDiI.js +1 -0
- package/web-ui/build/static/ruby-2UsEEPvi.js +1 -0
- package/web-ui/build/static/ruby-DQuqRBbF.js +1 -0
- package/web-ui/build/static/ruleslanguage-DIX-ZNdD.js +1 -0
- package/web-ui/build/static/rust-C3AZB4MD.js +1 -0
- package/web-ui/build/static/rust-s-uSy2xK.js +1 -0
- package/web-ui/build/static/sas-2ySpLG9-.js +1 -0
- package/web-ui/build/static/sas-BZjFIK6U.js +1 -0
- package/web-ui/build/static/sass-DmfN0RXk.js +1 -0
- package/web-ui/build/static/scala-BWG4D45T.js +1 -0
- package/web-ui/build/static/scala-DORCOJGF.js +1 -0
- package/web-ui/build/static/scheme-Dhf3OcIw.js +1 -0
- package/web-ui/build/static/scheme-RkPOVGvt.js +1 -0
- package/web-ui/build/static/scilab-BPjU1E5p.js +1 -0
- package/web-ui/build/static/scss-Cl5xn34j.js +1 -0
- package/web-ui/build/static/scss-K2UK4NzM.js +1 -0
- package/web-ui/build/static/shell-CnNrPIpO.js +1 -0
- package/web-ui/build/static/shell-session-CWzCvkCd.js +1 -0
- package/web-ui/build/static/smali-BqUloCDk.js +1 -0
- package/web-ui/build/static/smali-D9l7tmuy.js +1 -0
- package/web-ui/build/static/smalltalk-Ch8WtZ3x.js +1 -0
- package/web-ui/build/static/smalltalk-D33bV6Ux.js +1 -0
- package/web-ui/build/static/smarty-DhuA-30v.js +1 -0
- package/web-ui/build/static/sml-CcRV_05i.js +1 -0
- package/web-ui/build/static/sml-Dxy9VWS5.js +1 -0
- package/web-ui/build/static/solidity-B6Q9ss0Q.js +1 -0
- package/web-ui/build/static/solution-file-CdD4U58t.js +1 -0
- package/web-ui/build/static/soy-DwAwdpNx.js +1 -0
- package/web-ui/build/static/sparql-BD7Xi4u4.js +1 -0
- package/web-ui/build/static/splunk-spl-DNR8Nqkh.js +1 -0
- package/web-ui/build/static/sqf-D_eO1j0l.js +1 -0
- package/web-ui/build/static/sqf-RmFM3NP_.js +1 -0
- package/web-ui/build/static/sql-BqcZzHxC.js +1 -0
- package/web-ui/build/static/sql-C1Og8w4D.js +1 -0
- package/web-ui/build/static/sql_more-B8l439k3.js +1 -0
- package/web-ui/build/static/squirrel-k8wRFBEU.js +1 -0
- package/web-ui/build/static/stan-Cyd1Qc2Z.js +1 -0
- package/web-ui/build/static/stan-vaOTiGIw.js +1 -0
- package/web-ui/build/static/stata-BvtPM-UC.js +1 -0
- package/web-ui/build/static/step21-CcJzkfyX.js +1 -0
- package/web-ui/build/static/stylus-BUdFaHOi.js +1 -0
- package/web-ui/build/static/stylus-DZUxYm7B.js +1 -0
- package/web-ui/build/static/subunit-BLFu1vy1.js +1 -0
- package/web-ui/build/static/swift-4C37Wfzo.js +1 -0
- package/web-ui/build/static/swift-tpG5dEoC.js +1 -0
- package/web-ui/build/static/systemd-CZAHgFou.js +1 -0
- package/web-ui/build/static/t4-cs-BzDTdhsq.js +1 -0
- package/web-ui/build/static/t4-templating-BnNIhX-m.js +1 -0
- package/web-ui/build/static/t4-vb-WH6kXP4O.js +1 -0
- package/web-ui/build/static/taggerscript-DPuoT3fc.js +1 -0
- package/web-ui/build/static/tap-CRdOSYnA.js +1 -0
- package/web-ui/build/static/tap-Cfv7r5Y1.js +1 -0
- package/web-ui/build/static/tcl-C57QpMKe.js +1 -0
- package/web-ui/build/static/tcl-D_HhrQb7.js +1 -0
- package/web-ui/build/static/textile-HiZT-42r.js +1 -0
- package/web-ui/build/static/thrift-BIevTRAV.js +1 -0
- package/web-ui/build/static/toml-Dzu0VuJT.js +1 -0
- package/web-ui/build/static/tp-BcFKGcDv.js +1 -0
- package/web-ui/build/static/tremor-ChPj0YkW.js +1 -0
- package/web-ui/build/static/tsx-DEgPhspu.js +1 -0
- package/web-ui/build/static/tt2-zECU_j-n.js +1 -0
- package/web-ui/build/static/turtle-DSxo1JVc.js +1 -0
- package/web-ui/build/static/twig-BzzbcVU0.js +1 -0
- package/web-ui/build/static/twig-DD8ck-xB.js +1 -0
- package/web-ui/build/static/typescript-mfGLA69h.js +1 -0
- package/web-ui/build/static/typescript-obXwfhtv.js +1 -0
- package/web-ui/build/static/typoscript-DGRFkQ44.js +1 -0
- package/web-ui/build/static/unrealscript-C71Cshhh.js +1 -0
- package/web-ui/build/static/uorazor--YPn6YI1.js +1 -0
- package/web-ui/build/static/uri-DiBB6LAn.js +1 -0
- package/web-ui/build/static/v-DD6j4G3R.js +1 -0
- package/web-ui/build/static/vala-90B6tBz6.js +1 -0
- package/web-ui/build/static/vala-CPgj-_9p.js +1 -0
- package/web-ui/build/static/vbnet-Ct4CtLUY.js +1 -0
- package/web-ui/build/static/vbnet-Dt71G1FN.js +1 -0
- package/web-ui/build/static/vbscript-2A1bKLI8.js +1 -0
- package/web-ui/build/static/vbscript-html-BNSfZskj.js +1 -0
- package/web-ui/build/static/velocity-Cw07cCrw.js +1 -0
- package/web-ui/build/static/verilog-Appxv8wV.js +1 -0
- package/web-ui/build/static/verilog-gFSdUnSn.js +1 -0
- package/web-ui/build/static/vhdl-326_OrM2.js +1 -0
- package/web-ui/build/static/vhdl-BGaNDNIa.js +1 -0
- package/web-ui/build/static/vim-D1mEwoEz.js +1 -0
- package/web-ui/build/static/vim-lvX3nIwq.js +1 -0
- package/web-ui/build/static/visual-basic-C5WWtiVx.js +1 -0
- package/web-ui/build/static/warpscript-CF7kIXUC.js +1 -0
- package/web-ui/build/static/wasm-BHfGEvXM.js +1 -0
- package/web-ui/build/static/web-idl-U4Bu4xZZ.js +1 -0
- package/web-ui/build/static/wiki-Cypfsr_n.js +1 -0
- package/web-ui/build/static/wolfram-B4afYjEC.js +1 -0
- package/web-ui/build/static/wren-CIleRBn0.js +1 -0
- package/web-ui/build/static/x86asm-C-79USsG.js +1 -0
- package/web-ui/build/static/xeora-CSaM51pY.js +1 -0
- package/web-ui/build/static/xl-CuiQZS3B.js +1 -0
- package/web-ui/build/static/xml-C6jbRHrj.js +1 -0
- package/web-ui/build/static/xml-doc-CV7qp07_.js +1 -0
- package/web-ui/build/static/xojo-D4t2uWPH.js +1 -0
- package/web-ui/build/static/xquery-DT_Ao6QG.js +1 -0
- package/web-ui/build/static/xquery-DnKodhmy.js +1 -0
- package/web-ui/build/static/yaml-CLiRAuyI.js +1 -0
- package/web-ui/build/static/yaml-aulSfOTJ.js +1 -0
- package/web-ui/build/static/yang-C1R60r9w.js +1 -0
- package/web-ui/build/static/zephir-D_18ShED.js +1 -0
- package/web-ui/build/static/zig-C-01pua6.js +1 -0
- package/web-ui/build/static/1c-DhZopHm8.js +0 -1
- package/web-ui/build/static/abap-D7DS-qX3.js +0 -1
- package/web-ui/build/static/abnf-QaPF3_oL.js +0 -1
- package/web-ui/build/static/abnf-libRwec1.js +0 -1
- package/web-ui/build/static/accesslog-CVacfqn_.js +0 -1
- package/web-ui/build/static/actionscript-CiYHROIF.js +0 -1
- package/web-ui/build/static/actionscript-DIF6Mkss.js +0 -1
- package/web-ui/build/static/ada-CkSrDZCW.js +0 -1
- package/web-ui/build/static/ada-LJoxDvSx.js +0 -1
- package/web-ui/build/static/agda-BZiLVPpq.js +0 -1
- package/web-ui/build/static/al-CAWk7Fog.js +0 -1
- package/web-ui/build/static/angelscript-kvGVBHnx.js +0 -1
- package/web-ui/build/static/antlr4-CPe6Q8x2.js +0 -1
- package/web-ui/build/static/apache-DmCrobiB.js +0 -1
- package/web-ui/build/static/apacheconf-daTVIoPW.js +0 -1
- package/web-ui/build/static/apex-CHxTMgnv.js +0 -1
- package/web-ui/build/static/apl-_RYxt80q.js +0 -1
- package/web-ui/build/static/applescript-BRswVu4N.js +0 -1
- package/web-ui/build/static/applescript-Dy9Dvj5E.js +0 -1
- package/web-ui/build/static/aql-CMy1i9qc.js +0 -1
- package/web-ui/build/static/arcade-DR1GYUBg.js +0 -1
- package/web-ui/build/static/arduino-DpNdv2uX.js +0 -1
- package/web-ui/build/static/arduino-_c-bSghX.js +0 -1
- package/web-ui/build/static/arff-BJ30Nrv6.js +0 -1
- package/web-ui/build/static/armasm-MHSjZR0N.js +0 -1
- package/web-ui/build/static/asciidoc-C0OZWNFc.js +0 -1
- package/web-ui/build/static/asciidoc-DWnapsEO.js +0 -1
- package/web-ui/build/static/asm6502-FHuRz3G7.js +0 -1
- package/web-ui/build/static/asmatmel-DogW2vku.js +0 -1
- package/web-ui/build/static/aspectj--fndt9bT.js +0 -1
- package/web-ui/build/static/aspnet-CeGuzT6_.js +0 -1
- package/web-ui/build/static/autohotkey-Av445boA.js +0 -1
- package/web-ui/build/static/autohotkey-Ct3i6zo0.js +0 -1
- package/web-ui/build/static/autoit-ffveEi-7.js +0 -1
- package/web-ui/build/static/autoit-qZYwJYMl.js +0 -1
- package/web-ui/build/static/avisynth-Bk0gOiBl.js +0 -1
- package/web-ui/build/static/avrasm-D4jn2VlP.js +0 -1
- package/web-ui/build/static/avro-idl-D2vUNy2Y.js +0 -1
- package/web-ui/build/static/awk-T1JeggK3.js +0 -1
- package/web-ui/build/static/axapta-Cjmxf8FQ.js +0 -1
- package/web-ui/build/static/bash-CbEihw26.js +0 -1
- package/web-ui/build/static/bash-W4BCgQuG.js +0 -1
- package/web-ui/build/static/basic-C7azsKgx.js +0 -1
- package/web-ui/build/static/basic-jPZjdNDz.js +0 -1
- package/web-ui/build/static/batch-DaYkMRxY.js +0 -1
- package/web-ui/build/static/bbcode-BOPF_x83.js +0 -1
- package/web-ui/build/static/bicep-CwxQ8Onn.js +0 -1
- package/web-ui/build/static/birb-3JfQ8W8v.js +0 -1
- package/web-ui/build/static/bison-Xes5Wo8_.js +0 -1
- package/web-ui/build/static/bnf-BTnHnHCS.js +0 -1
- package/web-ui/build/static/bnf-DGvL7W4k.js +0 -1
- package/web-ui/build/static/brainfuck-DRPydU_6.js +0 -1
- package/web-ui/build/static/brainfuck-VeMg-eUL.js +0 -1
- package/web-ui/build/static/brightscript-BA0kdBbR.js +0 -1
- package/web-ui/build/static/bro-PLDsFD37.js +0 -1
- package/web-ui/build/static/bsl-CW16cVHy.js +0 -1
- package/web-ui/build/static/c-Dt9N-81z.js +0 -1
- package/web-ui/build/static/c-like-zQRvr3Ru.js +0 -1
- package/web-ui/build/static/c-wuozU5-U.js +0 -1
- package/web-ui/build/static/cal-BX3-i2BF.js +0 -1
- package/web-ui/build/static/capnproto-D_zMHjyB.js +0 -1
- package/web-ui/build/static/ceylon-BWy0mHxd.js +0 -1
- package/web-ui/build/static/cfscript-DRioSA9I.js +0 -1
- package/web-ui/build/static/chaiscript-CyZk8pVd.js +0 -1
- package/web-ui/build/static/cil-suzOKDIG.js +0 -1
- package/web-ui/build/static/clean-DuVwmj8A.js +0 -1
- package/web-ui/build/static/clojure-CuMTB6BC.js +0 -1
- package/web-ui/build/static/clojure-D9H12lbJ.js +0 -1
- package/web-ui/build/static/clojure-repl-BsFHP29t.js +0 -1
- package/web-ui/build/static/cmake-BIkT90XB.js +0 -1
- package/web-ui/build/static/cmake-Bp2eDA3B.js +0 -1
- package/web-ui/build/static/cobol-bUEVqQ5u.js +0 -1
- package/web-ui/build/static/coffeescript-CyvfZBTb.js +0 -1
- package/web-ui/build/static/coffeescript-Pjf6wb_P.js +0 -1
- package/web-ui/build/static/concurnas-CGqkXLBV.js +0 -1
- package/web-ui/build/static/coq-Bd5QcMus.js +0 -1
- package/web-ui/build/static/coq-dW_drAF1.js +0 -1
- package/web-ui/build/static/cos-6jracdln.js +0 -1
- package/web-ui/build/static/cpp-BFhj3FEH.js +0 -1
- package/web-ui/build/static/cpp-BJFxkdGM.js +0 -1
- package/web-ui/build/static/crmsh-BBM8wq5G.js +0 -1
- package/web-ui/build/static/crystal-D-r6sDeS.js +0 -1
- package/web-ui/build/static/crystal-DudUySZ0.js +0 -1
- package/web-ui/build/static/csharp-CmfaOsew.js +0 -1
- package/web-ui/build/static/csharp-Cvd_KtTe.js +0 -1
- package/web-ui/build/static/cshtml-BAaLiOnn.js +0 -1
- package/web-ui/build/static/csp-C_U4SPVR.js +0 -1
- package/web-ui/build/static/csp-DhZbgD3e.js +0 -1
- package/web-ui/build/static/css-DojmZrZT.js +0 -1
- package/web-ui/build/static/css-extras-DnlHSc08.js +0 -1
- package/web-ui/build/static/csv-DAXs1z4E.js +0 -1
- package/web-ui/build/static/cypher-DnbUMZhL.js +0 -1
- package/web-ui/build/static/d-CCTwl_U6.js +0 -1
- package/web-ui/build/static/d-DYT7Qmqg.js +0 -1
- package/web-ui/build/static/dart-CIeZgzhL.js +0 -1
- package/web-ui/build/static/dart-GN7YHl59.js +0 -1
- package/web-ui/build/static/dataweave-B194FTj1.js +0 -1
- package/web-ui/build/static/dax-CHOR-o_Y.js +0 -1
- package/web-ui/build/static/delphi-C8GTB00z.js +0 -1
- package/web-ui/build/static/dhall-C2c4U57a.js +0 -1
- package/web-ui/build/static/diff-CK-3YN9c.js +0 -1
- package/web-ui/build/static/diff-z1RFA0vd.js +0 -1
- package/web-ui/build/static/django-BHgCSFvA.js +0 -1
- package/web-ui/build/static/django-ITXq1MOE.js +0 -1
- package/web-ui/build/static/dns-BcxbVfp1.js +0 -1
- package/web-ui/build/static/dns-zone-file-DD1DDky2.js +0 -1
- package/web-ui/build/static/docker-CV_PCgdU.js +0 -1
- package/web-ui/build/static/dockerfile-DQtXRrus.js +0 -1
- package/web-ui/build/static/dos-oRii7pLE.js +0 -1
- package/web-ui/build/static/dot-8h-K-pMw.js +0 -1
- package/web-ui/build/static/dsconfig-BOy7bTZ3.js +0 -1
- package/web-ui/build/static/dts-BEJtC2Cw.js +0 -1
- package/web-ui/build/static/dust-CREi6ehK.js +0 -1
- package/web-ui/build/static/ebnf-B8QVc_Ge.js +0 -1
- package/web-ui/build/static/ebnf-DMqdHhjs.js +0 -1
- package/web-ui/build/static/editorconfig-CFaVd1_m.js +0 -1
- package/web-ui/build/static/eiffel-C4CQBCJA.js +0 -1
- package/web-ui/build/static/ejs-BIH3u27T.js +0 -1
- package/web-ui/build/static/elixir-BK_dbrpG.js +0 -1
- package/web-ui/build/static/elixir-Dw2S4lkj.js +0 -1
- package/web-ui/build/static/elm-BSDSGCAk.js +0 -1
- package/web-ui/build/static/elm-DZIaubbG.js +0 -1
- package/web-ui/build/static/erb-BDa1hk_Z.js +0 -1
- package/web-ui/build/static/erb-BeXC_eRL.js +0 -1
- package/web-ui/build/static/erlang-BhAYLi99.js +0 -1
- package/web-ui/build/static/erlang-CDatmTIy.js +0 -1
- package/web-ui/build/static/erlang-repl-Hd8Yskhv.js +0 -1
- package/web-ui/build/static/etlua-BpDSCP6r.js +0 -1
- package/web-ui/build/static/excel-CC90dRFC.js +0 -1
- package/web-ui/build/static/excel-formula-DVZWu4Ni.js +0 -1
- package/web-ui/build/static/factor-BvtGdI43.js +0 -1
- package/web-ui/build/static/false-Il9E8J6I.js +0 -1
- package/web-ui/build/static/firestore-security-rules-CeQf2w1_.js +0 -1
- package/web-ui/build/static/fix-Bbx4ekMx.js +0 -1
- package/web-ui/build/static/flix-BHdTuBIp.js +0 -1
- package/web-ui/build/static/flow-LpFN_201.js +0 -1
- package/web-ui/build/static/fortran-Bslm27JM.js +0 -1
- package/web-ui/build/static/fortran-DTkCbKT-.js +0 -1
- package/web-ui/build/static/fsharp-C2tkVd8B.js +0 -1
- package/web-ui/build/static/fsharp-DuvKNHQ8.js +0 -1
- package/web-ui/build/static/ftl-CaCckAZK.js +0 -1
- package/web-ui/build/static/gams-BvllUMDj.js +0 -1
- package/web-ui/build/static/gap-D48qrg0j.js +0 -1
- package/web-ui/build/static/gauss-BJMExm7C.js +0 -1
- package/web-ui/build/static/gcode-I_TX8gIy.js +0 -1
- package/web-ui/build/static/gcode-T4WcpuSv.js +0 -1
- package/web-ui/build/static/gdscript-DH93Cnvk.js +0 -1
- package/web-ui/build/static/gedcom-Ddk7namt.js +0 -1
- package/web-ui/build/static/gherkin-CrD2RmuY.js +0 -1
- package/web-ui/build/static/gherkin-DNsg3x3F.js +0 -1
- package/web-ui/build/static/git-BKff5OSq.js +0 -1
- package/web-ui/build/static/glsl-BpX4LB7O.js +0 -1
- package/web-ui/build/static/glsl-Cpg31Flp.js +0 -1
- package/web-ui/build/static/gml-BTtgdnq4.js +0 -1
- package/web-ui/build/static/gml-n5yPVf4R.js +0 -1
- package/web-ui/build/static/gn-Co-Vyyza.js +0 -1
- package/web-ui/build/static/go-BAGV4qPX.js +0 -1
- package/web-ui/build/static/go-module-CdZTrdJ9.js +0 -1
- package/web-ui/build/static/go-qV2P5XAm.js +0 -1
- package/web-ui/build/static/golo-BlqZVf2O.js +0 -1
- package/web-ui/build/static/gradle-BImW0AeW.js +0 -1
- package/web-ui/build/static/graphql-CO4qYsWk.js +0 -1
- package/web-ui/build/static/groovy-B9-dUD0W.js +0 -1
- package/web-ui/build/static/groovy-BSeTFv14.js +0 -1
- package/web-ui/build/static/haml-DJSmWtxi.js +0 -1
- package/web-ui/build/static/haml-DWgVVGpf.js +0 -1
- package/web-ui/build/static/handlebars-CIeD3fP2.js +0 -1
- package/web-ui/build/static/handlebars-D2JyVoM7.js +0 -1
- package/web-ui/build/static/haskell-B7l5_BsM.js +0 -1
- package/web-ui/build/static/haskell-_rpfHOqd.js +0 -1
- package/web-ui/build/static/haxe-BWjs3jYf.js +0 -1
- package/web-ui/build/static/haxe-D-RXCkhi.js +0 -1
- package/web-ui/build/static/hcl-BLH7uCM_.js +0 -1
- package/web-ui/build/static/hlsl-BpYwFIpo.js +0 -1
- package/web-ui/build/static/hoon-Cu1UMd01.js +0 -1
- package/web-ui/build/static/hpkp-8ppknlNP.js +0 -1
- package/web-ui/build/static/hsp-Dnw4TRaE.js +0 -1
- package/web-ui/build/static/hsts-CYYuO1bD.js +0 -1
- package/web-ui/build/static/htmlbars-kn-iTJZv.js +0 -1
- package/web-ui/build/static/http-BW5tInW4.js +0 -1
- package/web-ui/build/static/http-DiE3Ou79.js +0 -1
- package/web-ui/build/static/hy-D-vj1RjW.js +0 -1
- package/web-ui/build/static/ichigojam-CGq1g7WS.js +0 -1
- package/web-ui/build/static/icon-B-fe2urP.js +0 -1
- package/web-ui/build/static/icu-message-format-Clwi4Xw9.js +0 -1
- package/web-ui/build/static/idris-ptkxQGgr.js +0 -1
- package/web-ui/build/static/iecst-Do8u1Q6s.js +0 -1
- package/web-ui/build/static/ignore-BuoqTIUS.js +0 -1
- package/web-ui/build/static/index-Cl5sEOz6.js +0 -1
- package/web-ui/build/static/index-CopgLJaD.css +0 -1
- package/web-ui/build/static/index-DVV0_x9b.js +0 -13
- package/web-ui/build/static/index-Dogpo2uk.js +0 -831
- package/web-ui/build/static/inform7-DcgzcbNE.js +0 -1
- package/web-ui/build/static/inform7-KNvvAu5f.js +0 -1
- package/web-ui/build/static/ini-B0n0GNMT.js +0 -1
- package/web-ui/build/static/ini-MOF6ynds.js +0 -1
- package/web-ui/build/static/io-B5xS0QRl.js +0 -1
- package/web-ui/build/static/irpf90-UhbVtlyV.js +0 -1
- package/web-ui/build/static/isbl-tMpD3oGc.js +0 -1
- package/web-ui/build/static/j-BFPoIDTu.js +0 -1
- package/web-ui/build/static/java-ByZBqfiz.js +0 -1
- package/web-ui/build/static/java-ClgmZrul.js +0 -1
- package/web-ui/build/static/javadoc-DhiOyetn.js +0 -1
- package/web-ui/build/static/javadoclike-ChoNhAKm.js +0 -1
- package/web-ui/build/static/javascript-7n6oDEFZ.js +0 -1
- package/web-ui/build/static/javastacktrace-BoDuY08Z.js +0 -1
- package/web-ui/build/static/jboss-cli-Br2Z4hPO.js +0 -1
- package/web-ui/build/static/jexl-Bjlzxuyv.js +0 -1
- package/web-ui/build/static/jolie-BSwKLOeM.js +0 -1
- package/web-ui/build/static/jq-Mgv3gpwG.js +0 -1
- package/web-ui/build/static/js-extras-wDOfC38q.js +0 -1
- package/web-ui/build/static/js-templates-BTvhw3Bs.js +0 -1
- package/web-ui/build/static/jsdoc-BYmfxTtR.js +0 -1
- package/web-ui/build/static/json-B7wTq_VO.js +0 -1
- package/web-ui/build/static/json-BNchf4vg.js +0 -1
- package/web-ui/build/static/json5-DTkI7xUc.js +0 -1
- package/web-ui/build/static/jsonp-C2qbvJ7h.js +0 -1
- package/web-ui/build/static/jsstacktrace-Jrgcvv7t.js +0 -1
- package/web-ui/build/static/jsx-BBlZiRP7.js +0 -1
- package/web-ui/build/static/julia-DgM2UwMW.js +0 -1
- package/web-ui/build/static/julia-n4l8Bvlh.js +0 -1
- package/web-ui/build/static/julia-repl-MmLxt1m7.js +0 -1
- package/web-ui/build/static/keepalived-DL_ziq3Z.js +0 -1
- package/web-ui/build/static/keyman-DpQYdroZ.js +0 -1
- package/web-ui/build/static/kotlin-B5BLhq0w.js +0 -1
- package/web-ui/build/static/kotlin-lwR9RflG.js +0 -1
- package/web-ui/build/static/kumir-CfdqRPmm.js +0 -1
- package/web-ui/build/static/kusto-CD8P_Iuy.js +0 -1
- package/web-ui/build/static/lasso-DXukfPaT.js +0 -1
- package/web-ui/build/static/latex-B0OeyHzn.js +0 -1
- package/web-ui/build/static/latex-Cjd4B7op.js +0 -1
- package/web-ui/build/static/latte-Sm0EMlTD.js +0 -1
- package/web-ui/build/static/ldif-Du6OYgm-.js +0 -1
- package/web-ui/build/static/leaf-B07dUPY3.js +0 -1
- package/web-ui/build/static/less-4haJBRPb.js +0 -1
- package/web-ui/build/static/less-_aRo80Gf.js +0 -1
- package/web-ui/build/static/lilypond-D-N3peZ9.js +0 -1
- package/web-ui/build/static/liquid-D9yM6W2K.js +0 -1
- package/web-ui/build/static/lisp-Dtd5ab3m.js +0 -1
- package/web-ui/build/static/lisp-up9TDZvu.js +0 -1
- package/web-ui/build/static/livecodeserver-C6ZVFkmf.js +0 -1
- package/web-ui/build/static/livescript-B0RxJ5Ua.js +0 -1
- package/web-ui/build/static/livescript-MCdQfikd.js +0 -1
- package/web-ui/build/static/llvm-B8_12pp-.js +0 -1
- package/web-ui/build/static/llvm-x13a08hj.js +0 -1
- package/web-ui/build/static/log-BWHqsNt4.js +0 -1
- package/web-ui/build/static/lolcode-C6g13wEU.js +0 -1
- package/web-ui/build/static/lsl-PtxTzxa4.js +0 -1
- package/web-ui/build/static/lua-Bx8zXZHL.js +0 -1
- package/web-ui/build/static/lua-DADIkxR1.js +0 -1
- package/web-ui/build/static/magma-BylPhdHY.js +0 -1
- package/web-ui/build/static/makefile-D3YKxGYh.js +0 -1
- package/web-ui/build/static/makefile-MVluFqba.js +0 -1
- package/web-ui/build/static/markdown-BfiLbYNk.js +0 -1
- package/web-ui/build/static/markdown-DhWuEchv.js +0 -1
- package/web-ui/build/static/markup-templating-DrKS7rTN.js +0 -1
- package/web-ui/build/static/mathematica-DLP6Z4D4.js +0 -1
- package/web-ui/build/static/matlab-BSl0q8c4.js +0 -1
- package/web-ui/build/static/matlab-DYR81t5M.js +0 -1
- package/web-ui/build/static/maxima-BpdMLqwv.js +0 -1
- package/web-ui/build/static/maxscript-FJUeFSxC.js +0 -1
- package/web-ui/build/static/mel-BPIRuwjE.js +0 -1
- package/web-ui/build/static/mel-CiCuj0DJ.js +0 -1
- package/web-ui/build/static/mercury-DpL68_w1.js +0 -1
- package/web-ui/build/static/mermaid-ByD91lY7.js +0 -1
- package/web-ui/build/static/mipsasm-BnmJZM8S.js +0 -1
- package/web-ui/build/static/mizar-B-g7Sx8l.js +0 -1
- package/web-ui/build/static/mizar-Bak5UL11.js +0 -1
- package/web-ui/build/static/mojolicious-VXjq_VzY.js +0 -1
- package/web-ui/build/static/mongodb-Z6PMYKUL.js +0 -1
- package/web-ui/build/static/monkey-Bwx49Ezh.js +0 -1
- package/web-ui/build/static/monkey-CVf2DUC4.js +0 -1
- package/web-ui/build/static/moonscript-DZJLhJRz.js +0 -1
- package/web-ui/build/static/moonscript-MrE9tamx.js +0 -1
- package/web-ui/build/static/n1ql-D94WdXEQ.js +0 -1
- package/web-ui/build/static/n1ql-Kj58CbMM.js +0 -1
- package/web-ui/build/static/n4js-Bnye3Trw.js +0 -1
- package/web-ui/build/static/nand2tetris-hdl-tCDY4q7_.js +0 -1
- package/web-ui/build/static/naniscript-D5jU_5hU.js +0 -1
- package/web-ui/build/static/nasm-pvoxxmCi.js +0 -1
- package/web-ui/build/static/neon-BaM7XP33.js +0 -1
- package/web-ui/build/static/nevod-D_zkqHep.js +0 -1
- package/web-ui/build/static/nginx-CrWNCVav.js +0 -1
- package/web-ui/build/static/nginx-DlNpHmoX.js +0 -1
- package/web-ui/build/static/nim-DTWBASZs.js +0 -1
- package/web-ui/build/static/nim-rYyzIvaP.js +0 -1
- package/web-ui/build/static/nix-CNDb0EJy.js +0 -1
- package/web-ui/build/static/nix-CWvUbUPB.js +0 -1
- package/web-ui/build/static/node-repl-CcT8_svU.js +0 -1
- package/web-ui/build/static/nsis-CECIBdCf.js +0 -1
- package/web-ui/build/static/nsis-oNkAwOfa.js +0 -1
- package/web-ui/build/static/objectivec-DD8_3BB3.js +0 -1
- package/web-ui/build/static/objectivec-S025sFJ1.js +0 -1
- package/web-ui/build/static/ocaml-BCZswKof.js +0 -1
- package/web-ui/build/static/ocaml-Ckeb51s-.js +0 -1
- package/web-ui/build/static/opencl-CXpZbc8M.js +0 -1
- package/web-ui/build/static/openqasm-B8Mz46WR.js +0 -1
- package/web-ui/build/static/openscad-CbCxom8s.js +0 -1
- package/web-ui/build/static/oxygene-BXz_JmTV.js +0 -1
- package/web-ui/build/static/oz-BiOltkMB.js +0 -1
- package/web-ui/build/static/parigp-DqBiu3vH.js +0 -1
- package/web-ui/build/static/parser-CZ9nZGf3.js +0 -1
- package/web-ui/build/static/parser3-fXr5psxJ.js +0 -1
- package/web-ui/build/static/pascal-CH96J0iM.js +0 -1
- package/web-ui/build/static/pascaligo-BjGKW0D0.js +0 -1
- package/web-ui/build/static/pcaxis-CYouO7Aj.js +0 -1
- package/web-ui/build/static/peoplecode-gLUqW23r.js +0 -1
- package/web-ui/build/static/perl-DmePJLJH.js +0 -1
- package/web-ui/build/static/perl-Tas409uI.js +0 -1
- package/web-ui/build/static/pf-8YdDf1VX.js +0 -1
- package/web-ui/build/static/pgsql-nSZLOPEu.js +0 -1
- package/web-ui/build/static/php-Bw9rJO-W.js +0 -1
- package/web-ui/build/static/php-dlC7m4Mw.js +0 -1
- package/web-ui/build/static/php-extras-S30D5mcZ.js +0 -1
- package/web-ui/build/static/php-template-BRYN1eal.js +0 -1
- package/web-ui/build/static/phpdoc-BwoQ8Lr8.js +0 -1
- package/web-ui/build/static/plaintext-CKE9df1d.js +0 -1
- package/web-ui/build/static/plsql-D4RxSXvo.js +0 -1
- package/web-ui/build/static/pony-BGBCbfLU.js +0 -1
- package/web-ui/build/static/powerquery-DptaVB4-.js +0 -1
- package/web-ui/build/static/powershell-DU8jPMG7.js +0 -1
- package/web-ui/build/static/powershell-J5BHElQO.js +0 -1
- package/web-ui/build/static/processing-BEPnVHf2.js +0 -1
- package/web-ui/build/static/processing-JezK6PvU.js +0 -1
- package/web-ui/build/static/profile-Cz5-8kE9.js +0 -1
- package/web-ui/build/static/prolog-BE2A3iea.js +0 -1
- package/web-ui/build/static/prolog-CNV8ifQ7.js +0 -1
- package/web-ui/build/static/promql-BshGvkLk.js +0 -1
- package/web-ui/build/static/properties-CN-tcMo3.js +0 -1
- package/web-ui/build/static/properties-qOYCvHGu.js +0 -1
- package/web-ui/build/static/protobuf-BWT4wglm.js +0 -1
- package/web-ui/build/static/protobuf-BZiRG4kT.js +0 -1
- package/web-ui/build/static/psl-CndPxDrj.js +0 -1
- package/web-ui/build/static/pug-B-TvkfFx.js +0 -1
- package/web-ui/build/static/puppet-Bd8swYQr.js +0 -1
- package/web-ui/build/static/puppet-CF7uk-5J.js +0 -1
- package/web-ui/build/static/pure-CyS1KBKg.js +0 -1
- package/web-ui/build/static/purebasic-2OUm3SLr.js +0 -1
- package/web-ui/build/static/purebasic-BZdwwNI5.js +0 -1
- package/web-ui/build/static/purescript-P-UZH0Br.js +0 -1
- package/web-ui/build/static/python-BRG43j5u.js +0 -1
- package/web-ui/build/static/python-BwWo2ijA.js +0 -1
- package/web-ui/build/static/python-repl-BWMsZf_6.js +0 -1
- package/web-ui/build/static/q-BFfhoKcu.js +0 -1
- package/web-ui/build/static/q-bkwlyyua.js +0 -1
- package/web-ui/build/static/qml-B7FTWOHv.js +0 -1
- package/web-ui/build/static/qml-DRzPlsJ2.js +0 -1
- package/web-ui/build/static/qore-cWz9v4el.js +0 -1
- package/web-ui/build/static/qsharp-hY4nYVYO.js +0 -1
- package/web-ui/build/static/r-BTrjWuch.js +0 -1
- package/web-ui/build/static/r-BnNZ6o16.js +0 -1
- package/web-ui/build/static/racket-wXEjonlM.js +0 -1
- package/web-ui/build/static/reason-CTsxHbiG.js +0 -1
- package/web-ui/build/static/reasonml-DVRtEI5y.js +0 -1
- package/web-ui/build/static/regex-Bb3Tle7W.js +0 -1
- package/web-ui/build/static/rego-CjM8rGzJ.js +0 -1
- package/web-ui/build/static/renpy-CC53LPyW.js +0 -1
- package/web-ui/build/static/rest-ClWBAb0U.js +0 -1
- package/web-ui/build/static/rib-DgYbY5eR.js +0 -1
- package/web-ui/build/static/rip-CI-QYsYf.js +0 -1
- package/web-ui/build/static/roboconf-Dqscml0w.js +0 -1
- package/web-ui/build/static/roboconf-naUkcwP5.js +0 -1
- package/web-ui/build/static/robotframework-DcnT34wd.js +0 -1
- package/web-ui/build/static/routeros-UdE7Ivsi.js +0 -1
- package/web-ui/build/static/rsl-BtviPV_6.js +0 -1
- package/web-ui/build/static/ruby-BS9sZ4DE.js +0 -1
- package/web-ui/build/static/ruby-CTvYWyT_.js +0 -1
- package/web-ui/build/static/ruleslanguage-BslHLmf_.js +0 -1
- package/web-ui/build/static/rust-Ob8s5cPr.js +0 -1
- package/web-ui/build/static/rust-PVvxxEaI.js +0 -1
- package/web-ui/build/static/sas-BFyyIa7h.js +0 -1
- package/web-ui/build/static/sas-BIO4IbDi.js +0 -1
- package/web-ui/build/static/sass-axXzRuT6.js +0 -1
- package/web-ui/build/static/scala-DGgaq2xW.js +0 -1
- package/web-ui/build/static/scala-PqRzGoGx.js +0 -1
- package/web-ui/build/static/scheme-9TDGVBAg.js +0 -1
- package/web-ui/build/static/scheme-v_g9FoeP.js +0 -1
- package/web-ui/build/static/scilab-BjGcmAuS.js +0 -1
- package/web-ui/build/static/scss-0cTCAWco.js +0 -1
- package/web-ui/build/static/scss-Rzfj2QI7.js +0 -1
- package/web-ui/build/static/shell-Bue8QuoX.js +0 -1
- package/web-ui/build/static/shell-session-BvhEPAyL.js +0 -1
- package/web-ui/build/static/smali-BSRUl7n1.js +0 -1
- package/web-ui/build/static/smali-tZU1v-A3.js +0 -1
- package/web-ui/build/static/smalltalk-BegYoKgz.js +0 -1
- package/web-ui/build/static/smalltalk-CFIgpL96.js +0 -1
- package/web-ui/build/static/smarty-ClE2g_Bs.js +0 -1
- package/web-ui/build/static/sml-CcJxuldM.js +0 -1
- package/web-ui/build/static/sml-DLtNnjoU.js +0 -1
- package/web-ui/build/static/solidity-DgawlQiE.js +0 -1
- package/web-ui/build/static/solution-file-DhyNmxs3.js +0 -1
- package/web-ui/build/static/soy-BrhBKeT-.js +0 -1
- package/web-ui/build/static/sparql-tbxFNGgO.js +0 -1
- package/web-ui/build/static/splunk-spl-YiTg96CF.js +0 -1
- package/web-ui/build/static/sqf-C19fAQ3U.js +0 -1
- package/web-ui/build/static/sqf-CxyVuZN5.js +0 -1
- package/web-ui/build/static/sql-DNPJi0qS.js +0 -1
- package/web-ui/build/static/sql-_B1skvHB.js +0 -1
- package/web-ui/build/static/sql_more-uaqRAoNM.js +0 -1
- package/web-ui/build/static/squirrel-fdGt_pSI.js +0 -1
- package/web-ui/build/static/stan-C-bRgVEZ.js +0 -1
- package/web-ui/build/static/stan-D2qV8CZI.js +0 -1
- package/web-ui/build/static/stata-BfGKQ-Ma.js +0 -1
- package/web-ui/build/static/step21-D-keb8Z6.js +0 -1
- package/web-ui/build/static/stylus-DaAI-vhv.js +0 -1
- package/web-ui/build/static/stylus-vTKRR12q.js +0 -1
- package/web-ui/build/static/subunit-wmivJIrz.js +0 -1
- package/web-ui/build/static/swift-B8gMGjYk.js +0 -1
- package/web-ui/build/static/swift-DjJOKQ2k.js +0 -1
- package/web-ui/build/static/systemd-7Qm63BQt.js +0 -1
- package/web-ui/build/static/t4-cs-BsIcgs7W.js +0 -1
- package/web-ui/build/static/t4-templating-CN0O4y7e.js +0 -1
- package/web-ui/build/static/t4-vb-Cb1pQYHK.js +0 -1
- package/web-ui/build/static/taggerscript-BNinosaW.js +0 -1
- package/web-ui/build/static/tap-BHFw8v7c.js +0 -1
- package/web-ui/build/static/tap-Cr1hMt0C.js +0 -1
- package/web-ui/build/static/tcl-BUILe22A.js +0 -1
- package/web-ui/build/static/tcl-D3-w2kxt.js +0 -1
- package/web-ui/build/static/textile-dORKLFgQ.js +0 -1
- package/web-ui/build/static/thrift-D7MX6ve6.js +0 -1
- package/web-ui/build/static/toml-C-UDGAcz.js +0 -1
- package/web-ui/build/static/tp-BQinM07S.js +0 -1
- package/web-ui/build/static/tremor-CLJzLcPq.js +0 -1
- package/web-ui/build/static/tsx-p7tkLq_g.js +0 -1
- package/web-ui/build/static/tt2-Be4bhaK_.js +0 -1
- package/web-ui/build/static/turtle-C2DlE5aO.js +0 -1
- package/web-ui/build/static/twig-Bo2xg-rg.js +0 -1
- package/web-ui/build/static/twig-CiYZwH0q.js +0 -1
- package/web-ui/build/static/typescript-BNDIJkJT.js +0 -1
- package/web-ui/build/static/typescript-URD1-q5c.js +0 -1
- package/web-ui/build/static/typoscript-Bg084574.js +0 -1
- package/web-ui/build/static/unrealscript-Byqhgqvd.js +0 -1
- package/web-ui/build/static/uorazor-B73ZSiSr.js +0 -1
- package/web-ui/build/static/uri-BK6SbkOD.js +0 -1
- package/web-ui/build/static/v-CqkuKw11.js +0 -1
- package/web-ui/build/static/vala-B15-N06e.js +0 -1
- package/web-ui/build/static/vala-CQ4tSY33.js +0 -1
- package/web-ui/build/static/vbnet-BziHw3Ip.js +0 -1
- package/web-ui/build/static/vbnet-Ct657QTC.js +0 -1
- package/web-ui/build/static/vbscript-DK5ynABY.js +0 -1
- package/web-ui/build/static/vbscript-html-kL7HWQqg.js +0 -1
- package/web-ui/build/static/velocity-oNp6VHqp.js +0 -1
- package/web-ui/build/static/verilog-BfX9-Vwz.js +0 -1
- package/web-ui/build/static/verilog-DtCPaI4i.js +0 -1
- package/web-ui/build/static/vhdl-DPsoU-bJ.js +0 -1
- package/web-ui/build/static/vhdl-D_N74Kkk.js +0 -1
- package/web-ui/build/static/vim-BiP91Atm.js +0 -1
- package/web-ui/build/static/vim-CDpC9bmv.js +0 -1
- package/web-ui/build/static/visual-basic-CMvuEZAH.js +0 -1
- package/web-ui/build/static/warpscript-2zN7p27C.js +0 -1
- package/web-ui/build/static/wasm-BvZ_HQvm.js +0 -1
- package/web-ui/build/static/web-idl-B3UL0ZzW.js +0 -1
- package/web-ui/build/static/wiki-DQruvCoJ.js +0 -1
- package/web-ui/build/static/wolfram-DixP3NHX.js +0 -1
- package/web-ui/build/static/wren-BwLruJKC.js +0 -1
- package/web-ui/build/static/x86asm-miTe-8CH.js +0 -1
- package/web-ui/build/static/xeora-BDFpe7_z.js +0 -1
- package/web-ui/build/static/xl-Cl8gAuDP.js +0 -1
- package/web-ui/build/static/xml-C0BFvP-W.js +0 -1
- package/web-ui/build/static/xml-doc-BrgqNRno.js +0 -1
- package/web-ui/build/static/xojo-DUtwtHqw.js +0 -1
- package/web-ui/build/static/xquery-DHbZjVHF.js +0 -1
- package/web-ui/build/static/xquery-DIpdmVq-.js +0 -1
- package/web-ui/build/static/yaml-CvHBBrAg.js +0 -1
- package/web-ui/build/static/yaml-DiKmBkcD.js +0 -1
- package/web-ui/build/static/yang-B0UugJNh.js +0 -1
- package/web-ui/build/static/zephir-CmAMWd7F.js +0 -1
- package/web-ui/build/static/zig-CxGT1com.js +0 -1
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Tests for in-app OAuth auth routes from webServer.js:
|
|
3
3
|
* - GET /auth/callback — portal redirect lands here with token+user
|
|
4
|
-
* - GET /api/auth/status — current auth state
|
|
5
|
-
* -
|
|
4
|
+
* - GET /api/auth/status — current auth state (enhanced: returns user, supports ?since=)
|
|
5
|
+
* - GET /api/auth/resolve — resolve user from API key via remote backend /auth/me
|
|
6
|
+
* - POST /api/auth/signout — clear stored credentials + cached auth
|
|
6
7
|
* - GET /api/health/cloud — Azure backend health check
|
|
7
8
|
*
|
|
8
9
|
* Uses a real HTTP server + fetch (same harness pattern as imageServing.test.js)
|
|
@@ -13,8 +14,11 @@ import { describe, it, expect, beforeEach, afterEach, jest } from '@jest/globals
|
|
|
13
14
|
import express from 'express';
|
|
14
15
|
import { createServer } from 'http';
|
|
15
16
|
|
|
16
|
-
|
|
17
|
-
|
|
17
|
+
/**
|
|
18
|
+
* Build a minimal Express app replicating the auth route handlers from webServer.js.
|
|
19
|
+
* `ctx` is a mutable object that holds the lastAuthResult state (simulating `this`).
|
|
20
|
+
*/
|
|
21
|
+
function buildAuthApp({ apiKeyManager, broadcastToSession, config, logger, fetchImpl, ctx }) {
|
|
18
22
|
const app = express();
|
|
19
23
|
app.use(express.json());
|
|
20
24
|
|
|
@@ -52,6 +56,12 @@ function buildAuthApp({ apiKeyManager, broadcastToSession, config, logger, fetch
|
|
|
52
56
|
await apiKeyManager.setKeys(null, { loxiaApiKey: apiKey });
|
|
53
57
|
}
|
|
54
58
|
|
|
59
|
+
ctx.lastAuthResult = {
|
|
60
|
+
user: userInfo,
|
|
61
|
+
hasApiKey: !!apiKey,
|
|
62
|
+
timestamp: new Date().toISOString()
|
|
63
|
+
};
|
|
64
|
+
|
|
55
65
|
broadcastToSession(null, {
|
|
56
66
|
type: 'auth_success',
|
|
57
67
|
data: {
|
|
@@ -72,18 +82,64 @@ function buildAuthApp({ apiKeyManager, broadcastToSession, config, logger, fetch
|
|
|
72
82
|
// ── /api/auth/status ───────────────────────────────────────────
|
|
73
83
|
app.get('/api/auth/status', (req, res) => {
|
|
74
84
|
const hasApiKey = !!(apiKeyManager?.getKeysForRequest?.(null, { platformProvided: true })?.loxiaApiKey);
|
|
85
|
+
|
|
86
|
+
let user = ctx.lastAuthResult?.user || null;
|
|
87
|
+
|
|
88
|
+
const since = req.query.since;
|
|
89
|
+
if (since && ctx.lastAuthResult?.timestamp) {
|
|
90
|
+
if (new Date(ctx.lastAuthResult.timestamp) <= new Date(since)) {
|
|
91
|
+
user = null;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
75
95
|
res.json({
|
|
76
96
|
success: true,
|
|
77
|
-
authenticated: hasApiKey
|
|
97
|
+
authenticated: hasApiKey,
|
|
98
|
+
user,
|
|
99
|
+
timestamp: ctx.lastAuthResult?.timestamp || null
|
|
78
100
|
});
|
|
79
101
|
});
|
|
80
102
|
|
|
103
|
+
// ── /api/auth/resolve ──────────────────────────────────────────
|
|
104
|
+
app.get('/api/auth/resolve', async (req, res) => {
|
|
105
|
+
try {
|
|
106
|
+
const loxiaApiKey = apiKeyManager?.getKeysForRequest?.(null, { platformProvided: true })?.loxiaApiKey;
|
|
107
|
+
if (!loxiaApiKey) {
|
|
108
|
+
return res.json({ success: true, user: null, reason: 'no_api_key' });
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
const backendBaseUrl = config?.backend?.baseUrl || 'https://autopilot-api.azurewebsites.net';
|
|
112
|
+
const response = await fetchImpl(`${backendBaseUrl}/auth/me`, {
|
|
113
|
+
headers: { 'Authorization': `Bearer ${loxiaApiKey}` }
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
if (!response.ok) {
|
|
117
|
+
return res.json({ success: true, user: null, reason: 'backend_error', status: response.status });
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
const data = await response.json();
|
|
121
|
+
const user = data.user || data;
|
|
122
|
+
|
|
123
|
+
ctx.lastAuthResult = {
|
|
124
|
+
user,
|
|
125
|
+
hasApiKey: true,
|
|
126
|
+
timestamp: new Date().toISOString()
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
res.json({ success: true, user });
|
|
130
|
+
} catch (error) {
|
|
131
|
+
logger?.warn?.('Failed to resolve user from API key', { error: error.message });
|
|
132
|
+
res.json({ success: true, user: null, reason: 'fetch_error', error: error.message });
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
|
|
81
136
|
// ── /api/auth/signout ──────────────────────────────────────────
|
|
82
137
|
app.post('/api/auth/signout', async (req, res) => {
|
|
83
138
|
try {
|
|
84
139
|
if (apiKeyManager) {
|
|
85
140
|
await apiKeyManager.removeKeys(null);
|
|
86
141
|
}
|
|
142
|
+
ctx.lastAuthResult = null;
|
|
87
143
|
broadcastToSession(null, {
|
|
88
144
|
type: 'auth_signout',
|
|
89
145
|
data: { timestamp: new Date().toISOString() }
|
|
@@ -145,27 +201,26 @@ describe('Auth Routes (webServer.js)', () => {
|
|
|
145
201
|
let broadcastToSession;
|
|
146
202
|
let logger;
|
|
147
203
|
let server;
|
|
204
|
+
let ctx;
|
|
148
205
|
|
|
149
206
|
beforeEach(() => {
|
|
150
207
|
mockFetch = jest.fn();
|
|
151
208
|
broadcasts = [];
|
|
152
209
|
broadcastToSession = jest.fn((sessionId, msg) => broadcasts.push({ sessionId, msg }));
|
|
153
|
-
logger = {
|
|
154
|
-
warn: jest.fn(),
|
|
155
|
-
error: jest.fn(),
|
|
156
|
-
info: jest.fn()
|
|
157
|
-
};
|
|
210
|
+
logger = { warn: jest.fn(), error: jest.fn(), info: jest.fn() };
|
|
158
211
|
server = null;
|
|
212
|
+
ctx = { lastAuthResult: null };
|
|
159
213
|
});
|
|
160
214
|
|
|
161
215
|
afterEach(() => {
|
|
162
216
|
if (server) server.close();
|
|
163
217
|
});
|
|
164
218
|
|
|
219
|
+
// ── /auth/callback ───────────────────────────────────────────────
|
|
165
220
|
describe('GET /auth/callback', () => {
|
|
166
221
|
it('returns 400 HTML when token is missing', async () => {
|
|
167
222
|
const apiKeyManager = makeApiKeyManager();
|
|
168
|
-
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch });
|
|
223
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
169
224
|
const { server: s, baseUrl } = await startServer(app);
|
|
170
225
|
server = s;
|
|
171
226
|
|
|
@@ -177,7 +232,7 @@ describe('Auth Routes (webServer.js)', () => {
|
|
|
177
232
|
expect(broadcastToSession).not.toHaveBeenCalled();
|
|
178
233
|
});
|
|
179
234
|
|
|
180
|
-
it('decodes user info, generates API key,
|
|
235
|
+
it('decodes user info, generates API key, caches auth result, and broadcasts', async () => {
|
|
181
236
|
const apiKeyManager = makeApiKeyManager();
|
|
182
237
|
mockFetch.mockResolvedValueOnce({
|
|
183
238
|
ok: true,
|
|
@@ -185,11 +240,9 @@ describe('Auth Routes (webServer.js)', () => {
|
|
|
185
240
|
});
|
|
186
241
|
|
|
187
242
|
const app = buildAuthApp({
|
|
188
|
-
apiKeyManager,
|
|
189
|
-
broadcastToSession,
|
|
243
|
+
apiKeyManager, broadcastToSession,
|
|
190
244
|
config: { backend: { baseUrl: 'https://test-backend.example.com' } },
|
|
191
|
-
logger,
|
|
192
|
-
fetchImpl: mockFetch
|
|
245
|
+
logger, fetchImpl: mockFetch, ctx
|
|
193
246
|
});
|
|
194
247
|
const { server: s, baseUrl } = await startServer(app);
|
|
195
248
|
server = s;
|
|
@@ -198,236 +251,255 @@ describe('Auth Routes (webServer.js)', () => {
|
|
|
198
251
|
const res = await fetch(`${baseUrl}/auth/callback?token=jwt-abc&user=${encodeUser(userInfo)}`);
|
|
199
252
|
|
|
200
253
|
expect(res.status).toBe(200);
|
|
201
|
-
|
|
202
|
-
expect(text).toContain('Authenticated!');
|
|
203
|
-
|
|
204
|
-
// Verify backend was called with the JWT
|
|
205
|
-
expect(mockFetch).toHaveBeenCalledTimes(1);
|
|
206
|
-
const fetchCall = mockFetch.mock.calls[0];
|
|
207
|
-
expect(fetchCall[0]).toBe('https://test-backend.example.com/auth/apikey');
|
|
208
|
-
expect(fetchCall[1].method).toBe('POST');
|
|
209
|
-
expect(fetchCall[1].headers.Authorization).toBe('Bearer jwt-abc');
|
|
254
|
+
expect(await res.text()).toContain('Authenticated!');
|
|
210
255
|
|
|
211
256
|
// Verify API key was stored
|
|
212
257
|
expect(apiKeyManager.setKeys).toHaveBeenCalledWith(null, { loxiaApiKey: 'lx_generated_key_123' });
|
|
213
258
|
|
|
214
259
|
// Verify broadcast
|
|
215
|
-
expect(broadcastToSession).toHaveBeenCalledTimes(1);
|
|
216
260
|
const broadcast = broadcasts[0];
|
|
217
|
-
expect(broadcast.sessionId).toBeNull();
|
|
218
261
|
expect(broadcast.msg.type).toBe('auth_success');
|
|
219
262
|
expect(broadcast.msg.data.user).toEqual(userInfo);
|
|
220
263
|
expect(broadcast.msg.data.jwt).toBe('jwt-abc');
|
|
221
264
|
expect(broadcast.msg.data.hasApiKey).toBe(true);
|
|
222
|
-
|
|
265
|
+
|
|
266
|
+
// Verify lastAuthResult was cached
|
|
267
|
+
expect(ctx.lastAuthResult).toBeDefined();
|
|
268
|
+
expect(ctx.lastAuthResult.user).toEqual(userInfo);
|
|
269
|
+
expect(ctx.lastAuthResult.hasApiKey).toBe(true);
|
|
270
|
+
expect(ctx.lastAuthResult.timestamp).toMatch(/^\d{4}-\d{2}-\d{2}T/);
|
|
223
271
|
});
|
|
224
272
|
|
|
225
|
-
it('still broadcasts
|
|
273
|
+
it('still caches and broadcasts when API key generation fails', async () => {
|
|
226
274
|
const apiKeyManager = makeApiKeyManager();
|
|
227
275
|
mockFetch.mockRejectedValueOnce(new Error('Backend down'));
|
|
228
276
|
|
|
229
|
-
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch });
|
|
277
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
230
278
|
const { server: s, baseUrl } = await startServer(app);
|
|
231
279
|
server = s;
|
|
232
280
|
|
|
233
|
-
|
|
234
|
-
expect(
|
|
235
|
-
expect(
|
|
236
|
-
expect(broadcastToSession).toHaveBeenCalled();
|
|
237
|
-
const data = broadcasts[0].msg.data;
|
|
238
|
-
expect(data.hasApiKey).toBe(false);
|
|
239
|
-
expect(data.jwt).toBe('jwt-x');
|
|
240
|
-
expect(logger.warn).toHaveBeenCalled();
|
|
281
|
+
await fetch(`${baseUrl}/auth/callback?token=jwt-x&user=${encodeUser({ id: 'u1' })}`);
|
|
282
|
+
expect(ctx.lastAuthResult.hasApiKey).toBe(false);
|
|
283
|
+
expect(ctx.lastAuthResult.user).toEqual({ id: 'u1' });
|
|
241
284
|
});
|
|
285
|
+
});
|
|
242
286
|
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
});
|
|
287
|
+
// ── /api/auth/status (enhanced) ──────────────────────────────────
|
|
288
|
+
describe('GET /api/auth/status', () => {
|
|
289
|
+
it('returns authenticated=false and user=null when no key and no cached auth', async () => {
|
|
290
|
+
const apiKeyManager = makeApiKeyManager(null);
|
|
291
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
292
|
+
const { server: s, baseUrl } = await startServer(app);
|
|
293
|
+
server = s;
|
|
294
|
+
|
|
295
|
+
const body = await (await fetch(`${baseUrl}/api/auth/status`)).json();
|
|
296
|
+
expect(body.success).toBe(true);
|
|
297
|
+
expect(body.authenticated).toBe(false);
|
|
298
|
+
expect(body.user).toBeNull();
|
|
299
|
+
expect(body.timestamp).toBeNull();
|
|
300
|
+
});
|
|
301
|
+
|
|
302
|
+
it('returns cached user after a successful auth callback', async () => {
|
|
303
|
+
const apiKeyManager = makeApiKeyManager('lx_k');
|
|
304
|
+
ctx.lastAuthResult = { user: { email: 'cached@test.com' }, hasApiKey: true, timestamp: '2026-01-01T00:00:00.000Z' };
|
|
249
305
|
|
|
250
|
-
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch });
|
|
306
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
251
307
|
const { server: s, baseUrl } = await startServer(app);
|
|
252
308
|
server = s;
|
|
253
309
|
|
|
254
|
-
const
|
|
255
|
-
expect(
|
|
256
|
-
expect(
|
|
257
|
-
expect(
|
|
310
|
+
const body = await (await fetch(`${baseUrl}/api/auth/status`)).json();
|
|
311
|
+
expect(body.authenticated).toBe(true);
|
|
312
|
+
expect(body.user.email).toBe('cached@test.com');
|
|
313
|
+
expect(body.timestamp).toBe('2026-01-01T00:00:00.000Z');
|
|
258
314
|
});
|
|
259
315
|
|
|
260
|
-
it('
|
|
261
|
-
const apiKeyManager = makeApiKeyManager();
|
|
262
|
-
|
|
263
|
-
ok: true,
|
|
264
|
-
json: () => Promise.resolve({ apiKey: { key: 'lx_k' } })
|
|
265
|
-
});
|
|
316
|
+
it('?since= returns user when auth happened AFTER the given timestamp', async () => {
|
|
317
|
+
const apiKeyManager = makeApiKeyManager('lx_k');
|
|
318
|
+
ctx.lastAuthResult = { user: { email: 'new@test.com' }, hasApiKey: true, timestamp: '2026-04-12T12:00:00.000Z' };
|
|
266
319
|
|
|
267
|
-
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch });
|
|
320
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
268
321
|
const { server: s, baseUrl } = await startServer(app);
|
|
269
322
|
server = s;
|
|
270
323
|
|
|
271
|
-
|
|
272
|
-
|
|
324
|
+
// Auth happened AFTER since → user should be returned
|
|
325
|
+
const body = await (await fetch(`${baseUrl}/api/auth/status?since=2026-04-12T11:59:00.000Z`)).json();
|
|
326
|
+
expect(body.user.email).toBe('new@test.com');
|
|
273
327
|
});
|
|
274
328
|
|
|
275
|
-
it('
|
|
276
|
-
const apiKeyManager = makeApiKeyManager();
|
|
277
|
-
|
|
278
|
-
ok: true,
|
|
279
|
-
json: () => Promise.resolve({ message: 'no key' })
|
|
280
|
-
});
|
|
329
|
+
it('?since= returns user=null when auth happened BEFORE the given timestamp', async () => {
|
|
330
|
+
const apiKeyManager = makeApiKeyManager('lx_k');
|
|
331
|
+
ctx.lastAuthResult = { user: { email: 'old@test.com' }, hasApiKey: true, timestamp: '2026-04-12T10:00:00.000Z' };
|
|
281
332
|
|
|
282
|
-
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch });
|
|
333
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
283
334
|
const { server: s, baseUrl } = await startServer(app);
|
|
284
335
|
server = s;
|
|
285
336
|
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
expect(
|
|
337
|
+
// Auth happened BEFORE since → user should NOT be returned
|
|
338
|
+
const body = await (await fetch(`${baseUrl}/api/auth/status?since=2026-04-12T11:00:00.000Z`)).json();
|
|
339
|
+
expect(body.user).toBeNull();
|
|
340
|
+
expect(body.authenticated).toBe(true); // Still has key
|
|
289
341
|
});
|
|
290
342
|
});
|
|
291
343
|
|
|
292
|
-
|
|
293
|
-
|
|
344
|
+
// ── /api/auth/resolve ────────────────────────────────────────────
|
|
345
|
+
describe('GET /api/auth/resolve', () => {
|
|
346
|
+
it('returns user=null with reason when no API key stored', async () => {
|
|
294
347
|
const apiKeyManager = makeApiKeyManager(null);
|
|
295
|
-
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch });
|
|
348
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
296
349
|
const { server: s, baseUrl } = await startServer(app);
|
|
297
350
|
server = s;
|
|
298
351
|
|
|
299
|
-
const
|
|
300
|
-
expect(res.status).toBe(200);
|
|
301
|
-
const body = await res.json();
|
|
352
|
+
const body = await (await fetch(`${baseUrl}/api/auth/resolve`)).json();
|
|
302
353
|
expect(body.success).toBe(true);
|
|
303
|
-
expect(body.
|
|
354
|
+
expect(body.user).toBeNull();
|
|
355
|
+
expect(body.reason).toBe('no_api_key');
|
|
356
|
+
expect(mockFetch).not.toHaveBeenCalled();
|
|
304
357
|
});
|
|
305
358
|
|
|
306
|
-
it('
|
|
307
|
-
const apiKeyManager = makeApiKeyManager('
|
|
308
|
-
|
|
359
|
+
it('calls backend /auth/me and returns + caches user when successful', async () => {
|
|
360
|
+
const apiKeyManager = makeApiKeyManager('lx_my_key');
|
|
361
|
+
mockFetch.mockResolvedValueOnce({
|
|
362
|
+
ok: true,
|
|
363
|
+
json: () => Promise.resolve({ user: { id: 'u1', email: 'resolved@test.com', firstName: 'Resolved' } })
|
|
364
|
+
});
|
|
365
|
+
|
|
366
|
+
const app = buildAuthApp({
|
|
367
|
+
apiKeyManager, broadcastToSession,
|
|
368
|
+
config: { backend: { baseUrl: 'https://api.example.com' } },
|
|
369
|
+
logger, fetchImpl: mockFetch, ctx
|
|
370
|
+
});
|
|
309
371
|
const { server: s, baseUrl } = await startServer(app);
|
|
310
372
|
server = s;
|
|
311
373
|
|
|
312
|
-
const
|
|
313
|
-
|
|
314
|
-
expect(body.
|
|
374
|
+
const body = await (await fetch(`${baseUrl}/api/auth/resolve`)).json();
|
|
375
|
+
expect(body.success).toBe(true);
|
|
376
|
+
expect(body.user.email).toBe('resolved@test.com');
|
|
377
|
+
|
|
378
|
+
// Verify backend was called with the API key
|
|
379
|
+
expect(mockFetch).toHaveBeenCalledTimes(1);
|
|
380
|
+
expect(mockFetch.mock.calls[0][0]).toBe('https://api.example.com/auth/me');
|
|
381
|
+
expect(mockFetch.mock.calls[0][1].headers.Authorization).toBe('Bearer lx_my_key');
|
|
382
|
+
|
|
383
|
+
// Verify cached
|
|
384
|
+
expect(ctx.lastAuthResult.user.email).toBe('resolved@test.com');
|
|
385
|
+
expect(ctx.lastAuthResult.hasApiKey).toBe(true);
|
|
386
|
+
});
|
|
387
|
+
|
|
388
|
+
it('returns user=null when backend returns non-OK (e.g. 401 invalid key)', async () => {
|
|
389
|
+
const apiKeyManager = makeApiKeyManager('lx_bad_key');
|
|
390
|
+
mockFetch.mockResolvedValueOnce({ ok: false, status: 401 });
|
|
391
|
+
|
|
392
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
393
|
+
const { server: s, baseUrl } = await startServer(app);
|
|
394
|
+
server = s;
|
|
395
|
+
|
|
396
|
+
const body = await (await fetch(`${baseUrl}/api/auth/resolve`)).json();
|
|
397
|
+
expect(body.user).toBeNull();
|
|
398
|
+
expect(body.reason).toBe('backend_error');
|
|
399
|
+
expect(body.status).toBe(401);
|
|
400
|
+
});
|
|
401
|
+
|
|
402
|
+
it('returns user=null when fetch throws (network error)', async () => {
|
|
403
|
+
const apiKeyManager = makeApiKeyManager('lx_key');
|
|
404
|
+
mockFetch.mockRejectedValueOnce(new Error('ECONNREFUSED'));
|
|
405
|
+
|
|
406
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
407
|
+
const { server: s, baseUrl } = await startServer(app);
|
|
408
|
+
server = s;
|
|
409
|
+
|
|
410
|
+
const body = await (await fetch(`${baseUrl}/api/auth/resolve`)).json();
|
|
411
|
+
expect(body.user).toBeNull();
|
|
412
|
+
expect(body.reason).toBe('fetch_error');
|
|
413
|
+
expect(body.error).toBe('ECONNREFUSED');
|
|
414
|
+
});
|
|
415
|
+
|
|
416
|
+
it('uses default backend URL when config missing', async () => {
|
|
417
|
+
const apiKeyManager = makeApiKeyManager('lx_key');
|
|
418
|
+
mockFetch.mockResolvedValueOnce({ ok: true, json: () => Promise.resolve({ user: { id: '1' } }) });
|
|
419
|
+
|
|
420
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
421
|
+
const { server: s, baseUrl } = await startServer(app);
|
|
422
|
+
server = s;
|
|
423
|
+
|
|
424
|
+
await fetch(`${baseUrl}/api/auth/resolve`);
|
|
425
|
+
expect(mockFetch.mock.calls[0][0]).toBe('https://autopilot-api.azurewebsites.net/auth/me');
|
|
315
426
|
});
|
|
316
427
|
});
|
|
317
428
|
|
|
429
|
+
// ── /api/auth/signout ────────────────────────────────────────────
|
|
318
430
|
describe('POST /api/auth/signout', () => {
|
|
319
|
-
it('clears API key and broadcasts auth_signout', async () => {
|
|
431
|
+
it('clears API key, cached auth, and broadcasts auth_signout', async () => {
|
|
320
432
|
const apiKeyManager = makeApiKeyManager('lx_signed_in');
|
|
321
|
-
|
|
433
|
+
ctx.lastAuthResult = { user: { email: 'a@b.com' }, hasApiKey: true, timestamp: '2026-01-01T00:00:00Z' };
|
|
434
|
+
|
|
435
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
322
436
|
const { server: s, baseUrl } = await startServer(app);
|
|
323
437
|
server = s;
|
|
324
438
|
|
|
325
|
-
const
|
|
326
|
-
expect(res.status).toBe(200);
|
|
327
|
-
const body = await res.json();
|
|
439
|
+
const body = await (await fetch(`${baseUrl}/api/auth/signout`, { method: 'POST' })).json();
|
|
328
440
|
expect(body.success).toBe(true);
|
|
329
441
|
expect(apiKeyManager.removeKeys).toHaveBeenCalledWith(null);
|
|
330
442
|
expect(apiKeyManager._peek()).toBeNull();
|
|
331
|
-
expect(
|
|
443
|
+
expect(ctx.lastAuthResult).toBeNull();
|
|
332
444
|
expect(broadcasts[0].msg.type).toBe('auth_signout');
|
|
333
445
|
});
|
|
334
446
|
|
|
335
447
|
it('returns 500 when removeKeys throws', async () => {
|
|
336
|
-
const apiKeyManager = {
|
|
337
|
-
|
|
338
|
-
};
|
|
339
|
-
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch });
|
|
448
|
+
const apiKeyManager = { removeKeys: jest.fn().mockRejectedValue(new Error('vault locked')) };
|
|
449
|
+
const app = buildAuthApp({ apiKeyManager, broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
340
450
|
const { server: s, baseUrl } = await startServer(app);
|
|
341
451
|
server = s;
|
|
342
452
|
|
|
343
453
|
const res = await fetch(`${baseUrl}/api/auth/signout`, { method: 'POST' });
|
|
344
454
|
expect(res.status).toBe(500);
|
|
345
455
|
const body = await res.json();
|
|
346
|
-
expect(body.success).toBe(false);
|
|
347
456
|
expect(body.error).toBe('vault locked');
|
|
348
457
|
});
|
|
349
458
|
});
|
|
350
459
|
|
|
460
|
+
// ── /api/health/cloud ────────────────────────────────────────────
|
|
351
461
|
describe('GET /api/health/cloud', () => {
|
|
352
462
|
it('returns online=true with backend payload when health 200', async () => {
|
|
353
463
|
mockFetch.mockResolvedValueOnce({
|
|
354
|
-
ok: true,
|
|
355
|
-
json: () => Promise.resolve({ status: 'OK', uptime: 123 })
|
|
464
|
+
ok: true, json: () => Promise.resolve({ status: 'OK', uptime: 123 })
|
|
356
465
|
});
|
|
357
466
|
|
|
358
467
|
const app = buildAuthApp({
|
|
359
|
-
apiKeyManager: makeApiKeyManager(),
|
|
360
|
-
broadcastToSession,
|
|
468
|
+
apiKeyManager: makeApiKeyManager(), broadcastToSession,
|
|
361
469
|
config: { backend: { healthUrl: 'https://api.example.com/health' } },
|
|
362
|
-
logger,
|
|
363
|
-
fetchImpl: mockFetch
|
|
470
|
+
logger, fetchImpl: mockFetch, ctx
|
|
364
471
|
});
|
|
365
472
|
const { server: s, baseUrl } = await startServer(app);
|
|
366
473
|
server = s;
|
|
367
474
|
|
|
368
|
-
const
|
|
369
|
-
expect(res.status).toBe(200);
|
|
370
|
-
const body = await res.json();
|
|
475
|
+
const body = await (await fetch(`${baseUrl}/api/health/cloud`)).json();
|
|
371
476
|
expect(body.success).toBe(true);
|
|
372
477
|
expect(body.online).toBe(true);
|
|
373
478
|
expect(body.backend.status).toBe('OK');
|
|
374
|
-
expect(mockFetch.mock.calls[0][0]).toBe('https://api.example.com/health');
|
|
375
479
|
});
|
|
376
480
|
|
|
377
481
|
it('returns online=false when backend returns non-OK', async () => {
|
|
378
482
|
mockFetch.mockResolvedValueOnce({ ok: false, status: 503 });
|
|
379
483
|
|
|
380
|
-
const app = buildAuthApp({
|
|
381
|
-
apiKeyManager: makeApiKeyManager(),
|
|
382
|
-
broadcastToSession,
|
|
383
|
-
config: {},
|
|
384
|
-
logger,
|
|
385
|
-
fetchImpl: mockFetch
|
|
386
|
-
});
|
|
484
|
+
const app = buildAuthApp({ apiKeyManager: makeApiKeyManager(), broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
387
485
|
const { server: s, baseUrl } = await startServer(app);
|
|
388
486
|
server = s;
|
|
389
487
|
|
|
390
|
-
const
|
|
391
|
-
const body = await res.json();
|
|
392
|
-
expect(body.success).toBe(false);
|
|
488
|
+
const body = await (await fetch(`${baseUrl}/api/health/cloud`)).json();
|
|
393
489
|
expect(body.online).toBe(false);
|
|
394
490
|
expect(body.error).toContain('503');
|
|
395
491
|
});
|
|
396
492
|
|
|
397
|
-
it('returns online=false when fetch throws
|
|
493
|
+
it('returns online=false when fetch throws', async () => {
|
|
398
494
|
mockFetch.mockRejectedValueOnce(new Error('ECONNREFUSED'));
|
|
399
495
|
|
|
400
|
-
const app = buildAuthApp({
|
|
401
|
-
apiKeyManager: makeApiKeyManager(),
|
|
402
|
-
broadcastToSession,
|
|
403
|
-
config: {},
|
|
404
|
-
logger,
|
|
405
|
-
fetchImpl: mockFetch
|
|
406
|
-
});
|
|
496
|
+
const app = buildAuthApp({ apiKeyManager: makeApiKeyManager(), broadcastToSession, config: {}, logger, fetchImpl: mockFetch, ctx });
|
|
407
497
|
const { server: s, baseUrl } = await startServer(app);
|
|
408
498
|
server = s;
|
|
409
499
|
|
|
410
|
-
const
|
|
411
|
-
const body = await res.json();
|
|
500
|
+
const body = await (await fetch(`${baseUrl}/api/health/cloud`)).json();
|
|
412
501
|
expect(body.online).toBe(false);
|
|
413
502
|
expect(body.error).toBe('ECONNREFUSED');
|
|
414
503
|
});
|
|
415
|
-
|
|
416
|
-
it('uses default health URL when config missing', async () => {
|
|
417
|
-
mockFetch.mockResolvedValueOnce({ ok: true, json: () => Promise.resolve({}) });
|
|
418
|
-
|
|
419
|
-
const app = buildAuthApp({
|
|
420
|
-
apiKeyManager: makeApiKeyManager(),
|
|
421
|
-
broadcastToSession,
|
|
422
|
-
config: {},
|
|
423
|
-
logger,
|
|
424
|
-
fetchImpl: mockFetch
|
|
425
|
-
});
|
|
426
|
-
const { server: s, baseUrl } = await startServer(app);
|
|
427
|
-
server = s;
|
|
428
|
-
|
|
429
|
-
await fetch(`${baseUrl}/api/health/cloud`);
|
|
430
|
-
expect(mockFetch.mock.calls[0][0]).toBe('https://autopilot-api.azurewebsites.net/health');
|
|
431
|
-
});
|
|
432
504
|
});
|
|
433
505
|
});
|