onbuzz 3.9.2 → 3.9.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/scripts/push-image.sh +43 -0
- package/scripts/setup-acr.sh +65 -0
- package/src/__tests__/resolvePreferredModel.test.js +153 -0
- package/src/interfaces/__tests__/authRoutes.test.js +211 -139
- package/src/interfaces/__tests__/remoteSessionAuth.test.js +262 -0
- package/src/interfaces/webServer.js +130 -3
- package/web-ui/build/index.html +2 -2
- package/web-ui/build/static/1c-BbzHQBlF.js +1 -0
- package/web-ui/build/static/abap-EA2x-VX2.js +1 -0
- package/web-ui/build/static/abnf-Bs33FQDv.js +1 -0
- package/web-ui/build/static/abnf-DizpbWFd.js +1 -0
- package/web-ui/build/static/accesslog-CBy3t2c3.js +1 -0
- package/web-ui/build/static/actionscript-CxzDwAGi.js +1 -0
- package/web-ui/build/static/actionscript-D1fdjYRJ.js +1 -0
- package/web-ui/build/static/ada-DQFOd0Dy.js +1 -0
- package/web-ui/build/static/ada-DpW-m5RL.js +1 -0
- package/web-ui/build/static/agda-DLmtdQyM.js +1 -0
- package/web-ui/build/static/al-BDGiUEcS.js +1 -0
- package/web-ui/build/static/angelscript-D9vH4cb9.js +1 -0
- package/web-ui/build/static/antlr4-Bs_h1sQb.js +1 -0
- package/web-ui/build/static/apache-Cz2vCIKe.js +1 -0
- package/web-ui/build/static/apacheconf-CJiPQCKG.js +1 -0
- package/web-ui/build/static/apex-DOH948qy.js +1 -0
- package/web-ui/build/static/apl-Dvb-UHyh.js +1 -0
- package/web-ui/build/static/applescript-BWK3Z9rm.js +1 -0
- package/web-ui/build/static/applescript-DzappaBK.js +1 -0
- package/web-ui/build/static/aql-BhvJ5Qo5.js +1 -0
- package/web-ui/build/static/arcade-CYPHnQ8i.js +1 -0
- package/web-ui/build/static/arduino-Bftbcfp4.js +1 -0
- package/web-ui/build/static/arduino-BkZtGqiZ.js +1 -0
- package/web-ui/build/static/arff-eZYQ-iYN.js +1 -0
- package/web-ui/build/static/armasm-N6WxdzPk.js +1 -0
- package/web-ui/build/static/asciidoc-C6RnbVcU.js +1 -0
- package/web-ui/build/static/asciidoc-CM7TG3h9.js +1 -0
- package/web-ui/build/static/asm6502-BaucYNeM.js +1 -0
- package/web-ui/build/static/asmatmel-B5xsIMMq.js +1 -0
- package/web-ui/build/static/aspectj-BO7nETNc.js +1 -0
- package/web-ui/build/static/aspnet-BF_Sop3N.js +1 -0
- package/web-ui/build/static/autohotkey-C_Wfc9vD.js +1 -0
- package/web-ui/build/static/autohotkey-CzGXYim7.js +1 -0
- package/web-ui/build/static/autoit-CCQlxYj9.js +1 -0
- package/web-ui/build/static/autoit-DZl3SjZP.js +1 -0
- package/web-ui/build/static/avisynth-Ds5zGLpA.js +1 -0
- package/web-ui/build/static/avrasm-pRbkB6Hb.js +1 -0
- package/web-ui/build/static/avro-idl--Eft_3HG.js +1 -0
- package/web-ui/build/static/awk-B9M1CJL4.js +1 -0
- package/web-ui/build/static/axapta-DfDRZzdk.js +1 -0
- package/web-ui/build/static/bash-CCOC3ZUp.js +1 -0
- package/web-ui/build/static/bash-Cyid2zg_.js +1 -0
- package/web-ui/build/static/basic-DBQRgguG.js +1 -0
- package/web-ui/build/static/basic-DFedGxql.js +1 -0
- package/web-ui/build/static/batch-1uqDgb9B.js +1 -0
- package/web-ui/build/static/bbcode-BFW_vFZR.js +1 -0
- package/web-ui/build/static/bicep-DYvO2lR0.js +1 -0
- package/web-ui/build/static/birb-CSWpZzeR.js +1 -0
- package/web-ui/build/static/bison-CYSO7kwg.js +1 -0
- package/web-ui/build/static/bnf-B5ExG1GG.js +1 -0
- package/web-ui/build/static/bnf-DM0LjczC.js +1 -0
- package/web-ui/build/static/brainfuck-DUaT7by9.js +1 -0
- package/web-ui/build/static/brainfuck-Ed457baR.js +1 -0
- package/web-ui/build/static/brightscript-CcHedHah.js +1 -0
- package/web-ui/build/static/bro-B68WOXLr.js +1 -0
- package/web-ui/build/static/bsl-BrpN9yfA.js +1 -0
- package/web-ui/build/static/c-BHTqSD0-.js +1 -0
- package/web-ui/build/static/c-DB09WGhv.js +1 -0
- package/web-ui/build/static/c-like-DiGy0pYy.js +1 -0
- package/web-ui/build/static/cal-BORJ0RH-.js +1 -0
- package/web-ui/build/static/capnproto-DdvswRZG.js +1 -0
- package/web-ui/build/static/ceylon-D69BGqS3.js +1 -0
- package/web-ui/build/static/cfscript-DFH5Fvel.js +1 -0
- package/web-ui/build/static/chaiscript-DOeHoV5f.js +1 -0
- package/web-ui/build/static/cil-54x7U9sd.js +1 -0
- package/web-ui/build/static/clean-DSPrfUyl.js +1 -0
- package/web-ui/build/static/clojure-BGCFHA-o.js +1 -0
- package/web-ui/build/static/clojure-DW1uVs4J.js +1 -0
- package/web-ui/build/static/clojure-repl-CmgJJcjR.js +1 -0
- package/web-ui/build/static/cmake-B4uknxnM.js +1 -0
- package/web-ui/build/static/cmake-BmILsWe8.js +1 -0
- package/web-ui/build/static/cobol-CH-KQLSz.js +1 -0
- package/web-ui/build/static/coffeescript-DUntywPl.js +1 -0
- package/web-ui/build/static/coffeescript-aHBXArzH.js +1 -0
- package/web-ui/build/static/concurnas-CYu4U4Jk.js +1 -0
- package/web-ui/build/static/coq-AqoMF526.js +1 -0
- package/web-ui/build/static/coq-Clpb7_-H.js +1 -0
- package/web-ui/build/static/cos-mbGKdDdY.js +1 -0
- package/web-ui/build/static/cpp-BPRNyBn2.js +1 -0
- package/web-ui/build/static/cpp-Cx0w_hrJ.js +1 -0
- package/web-ui/build/static/crmsh-4hdMy5Sa.js +1 -0
- package/web-ui/build/static/crystal-2TdOl8wd.js +1 -0
- package/web-ui/build/static/crystal-BGarf6Mn.js +1 -0
- package/web-ui/build/static/csharp-Bv5Wwffq.js +1 -0
- package/web-ui/build/static/csharp-c-9enFZV.js +1 -0
- package/web-ui/build/static/cshtml-DUgYLu1f.js +1 -0
- package/web-ui/build/static/csp-Cizi56fk.js +1 -0
- package/web-ui/build/static/csp-CoHKC7Xe.js +1 -0
- package/web-ui/build/static/css-Db3sdYBT.js +1 -0
- package/web-ui/build/static/css-extras-BANcPn_K.js +1 -0
- package/web-ui/build/static/csv-BBAAXFMe.js +1 -0
- package/web-ui/build/static/cypher-CYHYSO7V.js +1 -0
- package/web-ui/build/static/d-Bhy24L5D.js +1 -0
- package/web-ui/build/static/d-C2G5---Q.js +1 -0
- package/web-ui/build/static/dart-9HLJVGCA.js +1 -0
- package/web-ui/build/static/dart-BilxnOFE.js +1 -0
- package/web-ui/build/static/dataweave-jaCC94N4.js +1 -0
- package/web-ui/build/static/dax-9szgKKLB.js +1 -0
- package/web-ui/build/static/delphi-D2TdvbT0.js +1 -0
- package/web-ui/build/static/dhall-4237a36Q.js +1 -0
- package/web-ui/build/static/diff--oashhYJ.js +1 -0
- package/web-ui/build/static/diff-ldnmCxg0.js +1 -0
- package/web-ui/build/static/django-BXD5QihR.js +1 -0
- package/web-ui/build/static/django-DZO2Fhz_.js +1 -0
- package/web-ui/build/static/dns-CwKCZYEb.js +1 -0
- package/web-ui/build/static/dns-zone-file-C0aUT_8f.js +1 -0
- package/web-ui/build/static/docker-BqM2IW2J.js +1 -0
- package/web-ui/build/static/dockerfile-DAXL-kMe.js +1 -0
- package/web-ui/build/static/dos-Cn3tSieE.js +1 -0
- package/web-ui/build/static/dot-CdyzkR9r.js +1 -0
- package/web-ui/build/static/dsconfig-p0lhPPAy.js +1 -0
- package/web-ui/build/static/dts-CyO9xrc2.js +1 -0
- package/web-ui/build/static/dust-CUlrn-am.js +1 -0
- package/web-ui/build/static/ebnf-BIzwiUmz.js +1 -0
- package/web-ui/build/static/ebnf-CbDk5JM3.js +1 -0
- package/web-ui/build/static/editorconfig-D_2TImiQ.js +1 -0
- package/web-ui/build/static/eiffel-CQRNBDqA.js +1 -0
- package/web-ui/build/static/ejs-DGj_S29C.js +1 -0
- package/web-ui/build/static/elixir-DuJFHUgt.js +1 -0
- package/web-ui/build/static/elixir-_xp5UZ-D.js +1 -0
- package/web-ui/build/static/elm-BmzVcdEI.js +1 -0
- package/web-ui/build/static/elm-drEAPXpE.js +1 -0
- package/web-ui/build/static/erb-BMlMda3o.js +1 -0
- package/web-ui/build/static/erb-bYW4nuO9.js +1 -0
- package/web-ui/build/static/erlang-BZq0zyAD.js +1 -0
- package/web-ui/build/static/erlang-Bstv4jMY.js +1 -0
- package/web-ui/build/static/erlang-repl-BZWEeElK.js +1 -0
- package/web-ui/build/static/etlua-29-21aBp.js +1 -0
- package/web-ui/build/static/excel-CnjxS7a2.js +1 -0
- package/web-ui/build/static/excel-formula-CrXFdqdA.js +1 -0
- package/web-ui/build/static/factor-D2DeivXh.js +1 -0
- package/web-ui/build/static/false-BahFR1MJ.js +1 -0
- package/web-ui/build/static/firestore-security-rules-DZlilbzn.js +1 -0
- package/web-ui/build/static/fix-CAnP-4S4.js +1 -0
- package/web-ui/build/static/flix-jFNnIw1B.js +1 -0
- package/web-ui/build/static/flow-ClNZBlSh.js +1 -0
- package/web-ui/build/static/fortran-1B_cygRB.js +1 -0
- package/web-ui/build/static/fortran-CXrQ6mXv.js +1 -0
- package/web-ui/build/static/fsharp-CTU4cKo0.js +1 -0
- package/web-ui/build/static/fsharp-DBY8aRoY.js +1 -0
- package/web-ui/build/static/ftl-j5niv9Bm.js +1 -0
- package/web-ui/build/static/gams-QW1Jlwpt.js +1 -0
- package/web-ui/build/static/gap-BmXz5h7S.js +1 -0
- package/web-ui/build/static/gauss-ClAcTzQi.js +1 -0
- package/web-ui/build/static/gcode-CNJBI8Fu.js +1 -0
- package/web-ui/build/static/gcode-DWDWbdyH.js +1 -0
- package/web-ui/build/static/gdscript-vubl1-Pf.js +1 -0
- package/web-ui/build/static/gedcom-BJURnAI4.js +1 -0
- package/web-ui/build/static/gherkin-BSIxfHt2.js +1 -0
- package/web-ui/build/static/gherkin-DWOrAqH4.js +1 -0
- package/web-ui/build/static/git-CGx_ZJhD.js +1 -0
- package/web-ui/build/static/glsl-BRAppl9h.js +1 -0
- package/web-ui/build/static/glsl-CrX_aagT.js +1 -0
- package/web-ui/build/static/gml-95-4ZLie.js +1 -0
- package/web-ui/build/static/gml-BE7scTLP.js +1 -0
- package/web-ui/build/static/gn-BinX4KNg.js +1 -0
- package/web-ui/build/static/go-BRzZXEkM.js +1 -0
- package/web-ui/build/static/go-CYc4vXfo.js +1 -0
- package/web-ui/build/static/go-module-gdV-44vm.js +1 -0
- package/web-ui/build/static/golo-J8PhOV5H.js +1 -0
- package/web-ui/build/static/gradle-CanWQ-BA.js +1 -0
- package/web-ui/build/static/graphql-BWUqUqdn.js +1 -0
- package/web-ui/build/static/groovy-Cnx4hJNe.js +1 -0
- package/web-ui/build/static/groovy-mBo8_Hp2.js +1 -0
- package/web-ui/build/static/haml-fMr-NvzF.js +1 -0
- package/web-ui/build/static/haml-tgd-P-dV.js +1 -0
- package/web-ui/build/static/handlebars-CWombTcq.js +1 -0
- package/web-ui/build/static/handlebars-CkSpr85Y.js +1 -0
- package/web-ui/build/static/haskell-CDIj8KS2.js +1 -0
- package/web-ui/build/static/haskell-Cd_so3vh.js +1 -0
- package/web-ui/build/static/haxe-64YyM8U6.js +1 -0
- package/web-ui/build/static/haxe-DJ1HZc8M.js +1 -0
- package/web-ui/build/static/hcl-D7TRGtBj.js +1 -0
- package/web-ui/build/static/hlsl-Dc2Pqiw4.js +1 -0
- package/web-ui/build/static/hoon-D4gfaEb8.js +1 -0
- package/web-ui/build/static/hpkp--dxVGtRo.js +1 -0
- package/web-ui/build/static/hsp-B4Xcj3Ft.js +1 -0
- package/web-ui/build/static/hsts-3PyMVRvm.js +1 -0
- package/web-ui/build/static/htmlbars-X9lc4ALx.js +1 -0
- package/web-ui/build/static/http-B78RMt19.js +1 -0
- package/web-ui/build/static/http-DbMEsD4Z.js +1 -0
- package/web-ui/build/static/hy-Bv8NFYlp.js +1 -0
- package/web-ui/build/static/ichigojam-BqqlFcFV.js +1 -0
- package/web-ui/build/static/icon-BbdvtZW1.js +1 -0
- package/web-ui/build/static/icu-message-format-BINm1I4C.js +1 -0
- package/web-ui/build/static/idris-C2o0VXkt.js +1 -0
- package/web-ui/build/static/iecst-B1eN-RZb.js +1 -0
- package/web-ui/build/static/ignore-Df2jg15c.js +1 -0
- package/web-ui/build/static/index-BwNJoEC1.css +1 -0
- package/web-ui/build/static/index-D0OeSKu9.js +13 -0
- package/web-ui/build/static/index-D39j_ic7.js +831 -0
- package/web-ui/build/static/index-mq2zaryu.js +1 -0
- package/web-ui/build/static/inform7-CNDLIRe-.js +1 -0
- package/web-ui/build/static/inform7-_JjuWWn2.js +1 -0
- package/web-ui/build/static/ini-CzB_AEnk.js +1 -0
- package/web-ui/build/static/ini-DLOiBWLg.js +1 -0
- package/web-ui/build/static/io-jDD56dli.js +1 -0
- package/web-ui/build/static/irpf90-DdSjFX9A.js +1 -0
- package/web-ui/build/static/isbl-mdW1cDoq.js +1 -0
- package/web-ui/build/static/j-BfBHEd4c.js +1 -0
- package/web-ui/build/static/java-3e5YwgG0.js +1 -0
- package/web-ui/build/static/java-vVrxTKNL.js +1 -0
- package/web-ui/build/static/javadoc-CEYRep16.js +1 -0
- package/web-ui/build/static/javadoclike-BrteIHXn.js +1 -0
- package/web-ui/build/static/javascript-C3GBYZ_Z.js +1 -0
- package/web-ui/build/static/javastacktrace-BS81jpsd.js +1 -0
- package/web-ui/build/static/jboss-cli-hcgm5WFV.js +1 -0
- package/web-ui/build/static/jexl-C2doOSVL.js +1 -0
- package/web-ui/build/static/jolie-bSS9rY0t.js +1 -0
- package/web-ui/build/static/jq-CohWytfY.js +1 -0
- package/web-ui/build/static/js-extras-D2hRBHEY.js +1 -0
- package/web-ui/build/static/js-templates-AhE3Imt0.js +1 -0
- package/web-ui/build/static/jsdoc-2lqA3eFn.js +1 -0
- package/web-ui/build/static/json-DSsCSXkX.js +1 -0
- package/web-ui/build/static/json-DrN6g2k3.js +1 -0
- package/web-ui/build/static/json5-DJsPkKyO.js +1 -0
- package/web-ui/build/static/jsonp-wgapXnyd.js +1 -0
- package/web-ui/build/static/jsstacktrace-B9wLFAM-.js +1 -0
- package/web-ui/build/static/jsx-Bmx-z5CX.js +1 -0
- package/web-ui/build/static/julia-B_4DriV0.js +1 -0
- package/web-ui/build/static/julia-CwqSqPuP.js +1 -0
- package/web-ui/build/static/julia-repl-ClbXnud4.js +1 -0
- package/web-ui/build/static/keepalived-CS7e1Km1.js +1 -0
- package/web-ui/build/static/keyman-Ysn5e8JW.js +1 -0
- package/web-ui/build/static/kotlin-BTAeuubS.js +1 -0
- package/web-ui/build/static/kotlin-DNTZurjT.js +1 -0
- package/web-ui/build/static/kumir-CzKcaM11.js +1 -0
- package/web-ui/build/static/kusto-CVsdPfxw.js +1 -0
- package/web-ui/build/static/lasso-B66uAJ9F.js +1 -0
- package/web-ui/build/static/latex-BHSQYicD.js +1 -0
- package/web-ui/build/static/latex-Co9p2DnB.js +1 -0
- package/web-ui/build/static/latte-Bm4Z7erF.js +1 -0
- package/web-ui/build/static/ldif-ajvWC6nG.js +1 -0
- package/web-ui/build/static/leaf-COSDkvxe.js +1 -0
- package/web-ui/build/static/less-ChvtFf5e.js +1 -0
- package/web-ui/build/static/less-D0XumieY.js +1 -0
- package/web-ui/build/static/lilypond-D2uHbQ8D.js +1 -0
- package/web-ui/build/static/liquid-B_46TpTe.js +1 -0
- package/web-ui/build/static/lisp-BRIrxEy1.js +1 -0
- package/web-ui/build/static/lisp-blAy3soM.js +1 -0
- package/web-ui/build/static/livecodeserver-DzNeJl8M.js +1 -0
- package/web-ui/build/static/livescript-DVG0CRdS.js +1 -0
- package/web-ui/build/static/livescript-UmOgSXVX.js +1 -0
- package/web-ui/build/static/llvm-C-crqI3C.js +1 -0
- package/web-ui/build/static/llvm-dBaZm_Nl.js +1 -0
- package/web-ui/build/static/log-CYZbqBSN.js +1 -0
- package/web-ui/build/static/lolcode-DfuG1iEj.js +1 -0
- package/web-ui/build/static/lsl-CMkgjXGi.js +1 -0
- package/web-ui/build/static/lua-Bja14m3Q.js +1 -0
- package/web-ui/build/static/lua-iUBPGzy4.js +1 -0
- package/web-ui/build/static/magma-Bzn8vmNi.js +1 -0
- package/web-ui/build/static/makefile-CVGxJXuc.js +1 -0
- package/web-ui/build/static/makefile-UpO4Masr.js +1 -0
- package/web-ui/build/static/markdown-BmlFckIe.js +1 -0
- package/web-ui/build/static/markdown-De819SyN.js +1 -0
- package/web-ui/build/static/markup-templating-CRlbq9R0.js +1 -0
- package/web-ui/build/static/mathematica-Dfd9T4d-.js +1 -0
- package/web-ui/build/static/matlab-B3DHbBVE.js +1 -0
- package/web-ui/build/static/matlab-DfBfq5io.js +1 -0
- package/web-ui/build/static/maxima-Cjf8-TQE.js +1 -0
- package/web-ui/build/static/maxscript-gCI7YRpF.js +1 -0
- package/web-ui/build/static/mel-BuhoUC-Q.js +1 -0
- package/web-ui/build/static/mel-DLlt-NSt.js +1 -0
- package/web-ui/build/static/mercury-D_BuP9uO.js +1 -0
- package/web-ui/build/static/mermaid-1PGxbi8F.js +1 -0
- package/web-ui/build/static/mipsasm-BqlLxpGh.js +1 -0
- package/web-ui/build/static/mizar-D2k8XFk7.js +1 -0
- package/web-ui/build/static/mizar-blnX8vHH.js +1 -0
- package/web-ui/build/static/mojolicious-anWOI1Ez.js +1 -0
- package/web-ui/build/static/mongodb-BehHhDzv.js +1 -0
- package/web-ui/build/static/monkey-BLrAKiSf.js +1 -0
- package/web-ui/build/static/monkey-DxxNjJJS.js +1 -0
- package/web-ui/build/static/moonscript-BbmkK7oI.js +1 -0
- package/web-ui/build/static/moonscript-f0wjh7GX.js +1 -0
- package/web-ui/build/static/n1ql-DWtYpgC4.js +1 -0
- package/web-ui/build/static/n1ql-DYIhp_Re.js +1 -0
- package/web-ui/build/static/n4js-tNcm5teb.js +1 -0
- package/web-ui/build/static/nand2tetris-hdl-DBYCBBL-.js +1 -0
- package/web-ui/build/static/naniscript-D3_KsPkD.js +1 -0
- package/web-ui/build/static/nasm-CNaNirqn.js +1 -0
- package/web-ui/build/static/neon-DFJ64GTl.js +1 -0
- package/web-ui/build/static/nevod-BML44bC7.js +1 -0
- package/web-ui/build/static/nginx-C5wpgsVe.js +1 -0
- package/web-ui/build/static/nginx-CGz4sJwK.js +1 -0
- package/web-ui/build/static/nim-CLLdNXzZ.js +1 -0
- package/web-ui/build/static/nim-DgBWXEst.js +1 -0
- package/web-ui/build/static/nix-BMWnMs2t.js +1 -0
- package/web-ui/build/static/nix-DUIca49y.js +1 -0
- package/web-ui/build/static/node-repl-nYzY3x-M.js +1 -0
- package/web-ui/build/static/nsis-BdX9cwP8.js +1 -0
- package/web-ui/build/static/nsis-KIiyaabz.js +1 -0
- package/web-ui/build/static/objectivec-Cm2jJu9D.js +1 -0
- package/web-ui/build/static/objectivec-Cygq2h1h.js +1 -0
- package/web-ui/build/static/ocaml-DRhKkHYJ.js +1 -0
- package/web-ui/build/static/ocaml-Dih7DWzk.js +1 -0
- package/web-ui/build/static/opencl-Y9qSQd4q.js +1 -0
- package/web-ui/build/static/openqasm-Bfxf2wOY.js +1 -0
- package/web-ui/build/static/openscad-BcEFvXd5.js +1 -0
- package/web-ui/build/static/oxygene-B3tvJv_K.js +1 -0
- package/web-ui/build/static/oz-BDJWCElB.js +1 -0
- package/web-ui/build/static/parigp-44xJ-aUu.js +1 -0
- package/web-ui/build/static/parser-HeYPjhtt.js +1 -0
- package/web-ui/build/static/parser3-DY0wOiPu.js +1 -0
- package/web-ui/build/static/pascal-kTCnN1RR.js +1 -0
- package/web-ui/build/static/pascaligo-C7o5NZQZ.js +1 -0
- package/web-ui/build/static/pcaxis-B8_5iL8t.js +1 -0
- package/web-ui/build/static/peoplecode-CCU-4u8P.js +1 -0
- package/web-ui/build/static/perl-B3eM1vNk.js +1 -0
- package/web-ui/build/static/perl-BWPIG--8.js +1 -0
- package/web-ui/build/static/pf-CScWLlue.js +1 -0
- package/web-ui/build/static/pgsql-BDO62gua.js +1 -0
- package/web-ui/build/static/php-CE0bJTUa.js +1 -0
- package/web-ui/build/static/php-CU_Zfkw1.js +1 -0
- package/web-ui/build/static/php-extras-C7uS50Ut.js +1 -0
- package/web-ui/build/static/php-template-BIJOlGw0.js +1 -0
- package/web-ui/build/static/phpdoc-Bd_c9KhT.js +1 -0
- package/web-ui/build/static/plaintext-C4fe7prc.js +1 -0
- package/web-ui/build/static/plsql-DsgiWfi1.js +1 -0
- package/web-ui/build/static/pony-Cs2_xi4S.js +1 -0
- package/web-ui/build/static/powerquery-CPbb4uAH.js +1 -0
- package/web-ui/build/static/powershell-CU0Buqdo.js +1 -0
- package/web-ui/build/static/powershell-XmaDRoF5.js +1 -0
- package/web-ui/build/static/processing-C_gqVcwu.js +1 -0
- package/web-ui/build/static/processing-CyD64x7R.js +1 -0
- package/web-ui/build/static/profile-CmJ8zYJW.js +1 -0
- package/web-ui/build/static/prolog-CyEYjtJW.js +1 -0
- package/web-ui/build/static/prolog-D5fenkjJ.js +1 -0
- package/web-ui/build/static/promql-dnnLRoq0.js +1 -0
- package/web-ui/build/static/properties-Bl_duXdu.js +1 -0
- package/web-ui/build/static/properties-rkUHxQd8.js +1 -0
- package/web-ui/build/static/protobuf-e1dDYqdS.js +1 -0
- package/web-ui/build/static/protobuf-wfA6JVc7.js +1 -0
- package/web-ui/build/static/psl-Dqm7URp7.js +1 -0
- package/web-ui/build/static/pug-cyyrMI26.js +1 -0
- package/web-ui/build/static/puppet--p69xBTl.js +1 -0
- package/web-ui/build/static/puppet-B_23kddL.js +1 -0
- package/web-ui/build/static/pure-DasPpgO9.js +1 -0
- package/web-ui/build/static/purebasic-BrszJv_V.js +1 -0
- package/web-ui/build/static/purebasic-DDcXxwLq.js +1 -0
- package/web-ui/build/static/purescript-BwPH_Z-w.js +1 -0
- package/web-ui/build/static/python-CXiJCxt-.js +1 -0
- package/web-ui/build/static/python-D3148l6Q.js +1 -0
- package/web-ui/build/static/python-repl-Bexf4Pvp.js +1 -0
- package/web-ui/build/static/q-DFvFaZE1.js +1 -0
- package/web-ui/build/static/q-fcStq_Ib.js +1 -0
- package/web-ui/build/static/qml-CKJVb8yy.js +1 -0
- package/web-ui/build/static/qml-CaCJQpgR.js +1 -0
- package/web-ui/build/static/qore-B1_Q5H9z.js +1 -0
- package/web-ui/build/static/qsharp-D630MCsl.js +1 -0
- package/web-ui/build/static/r-CYlZBmW3.js +1 -0
- package/web-ui/build/static/r-D7Teq6Ak.js +1 -0
- package/web-ui/build/static/racket-CZ5FXYzU.js +1 -0
- package/web-ui/build/static/reason-Ds7QYUS1.js +1 -0
- package/web-ui/build/static/reasonml-Rj6uXoZt.js +1 -0
- package/web-ui/build/static/regex-Dim55dWl.js +1 -0
- package/web-ui/build/static/rego-DKUev9Hj.js +1 -0
- package/web-ui/build/static/renpy-DIjQNbNL.js +1 -0
- package/web-ui/build/static/rest-Cjn9gTuB.js +1 -0
- package/web-ui/build/static/rib-D6Mm1WnR.js +1 -0
- package/web-ui/build/static/rip-D9b6EJU2.js +1 -0
- package/web-ui/build/static/roboconf-C0sCw1D_.js +1 -0
- package/web-ui/build/static/roboconf-cKAJgV8a.js +1 -0
- package/web-ui/build/static/robotframework-BidwutDW.js +1 -0
- package/web-ui/build/static/routeros-DiEExebj.js +1 -0
- package/web-ui/build/static/rsl-B9VsodpN.js +1 -0
- package/web-ui/build/static/ruby-DGR8c-bv.js +1 -0
- package/web-ui/build/static/ruby-r-f2LYUG.js +1 -0
- package/web-ui/build/static/ruleslanguage-Dzyu25FF.js +1 -0
- package/web-ui/build/static/rust-BAjh4p6h.js +1 -0
- package/web-ui/build/static/rust-DaYM9smB.js +1 -0
- package/web-ui/build/static/sas-Br35zR-5.js +1 -0
- package/web-ui/build/static/sas-CfPULy9T.js +1 -0
- package/web-ui/build/static/sass-BsrkTaSx.js +1 -0
- package/web-ui/build/static/scala-CqGuDF-N.js +1 -0
- package/web-ui/build/static/scala-DW4q5V4s.js +1 -0
- package/web-ui/build/static/scheme-9Fv3BBZC.js +1 -0
- package/web-ui/build/static/scheme-sJxa4PtW.js +1 -0
- package/web-ui/build/static/scilab-BEj8oAV5.js +1 -0
- package/web-ui/build/static/scss-ClTlgyaM.js +1 -0
- package/web-ui/build/static/scss-_W99p9-3.js +1 -0
- package/web-ui/build/static/shell-Bj6XEjgZ.js +1 -0
- package/web-ui/build/static/shell-session-03eoNSIa.js +1 -0
- package/web-ui/build/static/smali-CP7-kfk-.js +1 -0
- package/web-ui/build/static/smali-CkydYRDK.js +1 -0
- package/web-ui/build/static/smalltalk-154iSFUX.js +1 -0
- package/web-ui/build/static/smalltalk-BnBosw9z.js +1 -0
- package/web-ui/build/static/smarty-DrP596Sz.js +1 -0
- package/web-ui/build/static/sml-C7-GcATf.js +1 -0
- package/web-ui/build/static/sml-D5r_mKj1.js +1 -0
- package/web-ui/build/static/solidity-Cy-37A6U.js +1 -0
- package/web-ui/build/static/solution-file-BTP-_CNt.js +1 -0
- package/web-ui/build/static/soy-D_3oOyi2.js +1 -0
- package/web-ui/build/static/sparql-BUxH-oEi.js +1 -0
- package/web-ui/build/static/splunk-spl-ydooemHh.js +1 -0
- package/web-ui/build/static/sqf-BKkdMfdt.js +1 -0
- package/web-ui/build/static/sqf-nDIkCEZ7.js +1 -0
- package/web-ui/build/static/sql-DgHDIUow.js +1 -0
- package/web-ui/build/static/sql-rW5jQ3ML.js +1 -0
- package/web-ui/build/static/sql_more-ClI9ZBSM.js +1 -0
- package/web-ui/build/static/squirrel-Bc3i-fmL.js +1 -0
- package/web-ui/build/static/stan-ClI-YGO7.js +1 -0
- package/web-ui/build/static/stan-DakKGhOw.js +1 -0
- package/web-ui/build/static/stata-DPtmV_Qb.js +1 -0
- package/web-ui/build/static/step21-D24tbJJ_.js +1 -0
- package/web-ui/build/static/stylus-rbzveyBR.js +1 -0
- package/web-ui/build/static/stylus-za-3v2pT.js +1 -0
- package/web-ui/build/static/subunit-K5O6lhfW.js +1 -0
- package/web-ui/build/static/swift-CZFEmc58.js +1 -0
- package/web-ui/build/static/swift-DNBtxDcy.js +1 -0
- package/web-ui/build/static/systemd-BEkgAVnL.js +1 -0
- package/web-ui/build/static/t4-cs-IBLpYuR9.js +1 -0
- package/web-ui/build/static/t4-templating-CXw52J3y.js +1 -0
- package/web-ui/build/static/t4-vb-kFfrJm3I.js +1 -0
- package/web-ui/build/static/taggerscript-CmF9JGEA.js +1 -0
- package/web-ui/build/static/tap-CD5eF0sN.js +1 -0
- package/web-ui/build/static/tap-CVDhVdmP.js +1 -0
- package/web-ui/build/static/tcl-DraJ3Sfb.js +1 -0
- package/web-ui/build/static/tcl-V2mkrFh4.js +1 -0
- package/web-ui/build/static/textile-B62gEM2Y.js +1 -0
- package/web-ui/build/static/thrift-BsrJLwe5.js +1 -0
- package/web-ui/build/static/toml-kNJM8JE6.js +1 -0
- package/web-ui/build/static/tp-D-gkr5bo.js +1 -0
- package/web-ui/build/static/tremor-Bzg_cr42.js +1 -0
- package/web-ui/build/static/tsx-5IjJjwPe.js +1 -0
- package/web-ui/build/static/tt2-CosBg4xh.js +1 -0
- package/web-ui/build/static/turtle-C6zmCCSG.js +1 -0
- package/web-ui/build/static/twig-C9Z3W3Pu.js +1 -0
- package/web-ui/build/static/twig-Ci0nSBuu.js +1 -0
- package/web-ui/build/static/typescript-CO_DRYiH.js +1 -0
- package/web-ui/build/static/typescript-KUsr27HX.js +1 -0
- package/web-ui/build/static/typoscript-CtsgjdXC.js +1 -0
- package/web-ui/build/static/unrealscript-Curvfm56.js +1 -0
- package/web-ui/build/static/uorazor-BCEq8Fdd.js +1 -0
- package/web-ui/build/static/uri-a2FjFj6K.js +1 -0
- package/web-ui/build/static/v-CUxPPRYc.js +1 -0
- package/web-ui/build/static/vala-C0DDohpX.js +1 -0
- package/web-ui/build/static/vala-C5u1qEan.js +1 -0
- package/web-ui/build/static/vbnet-CEkrisUz.js +1 -0
- package/web-ui/build/static/vbnet-jSMlhHn4.js +1 -0
- package/web-ui/build/static/vbscript-CxS3uFuX.js +1 -0
- package/web-ui/build/static/vbscript-html-DrYMqZwh.js +1 -0
- package/web-ui/build/static/velocity--xldXatp.js +1 -0
- package/web-ui/build/static/verilog-BR52XKZI.js +1 -0
- package/web-ui/build/static/verilog-CxBsZmns.js +1 -0
- package/web-ui/build/static/vhdl-CZLZJEDz.js +1 -0
- package/web-ui/build/static/vhdl-DxeSf_uW.js +1 -0
- package/web-ui/build/static/vim-CCjjLKFP.js +1 -0
- package/web-ui/build/static/vim-CDYgRHU6.js +1 -0
- package/web-ui/build/static/visual-basic-DqHFz9dY.js +1 -0
- package/web-ui/build/static/warpscript-DzMyteIo.js +1 -0
- package/web-ui/build/static/wasm-BnSUdK7_.js +1 -0
- package/web-ui/build/static/web-idl-Bpgv-Gtd.js +1 -0
- package/web-ui/build/static/wiki-aAwxEhFS.js +1 -0
- package/web-ui/build/static/wolfram-K0ssNZYc.js +1 -0
- package/web-ui/build/static/wren-A7VtXKxy.js +1 -0
- package/web-ui/build/static/x86asm-D3OC2rGU.js +1 -0
- package/web-ui/build/static/xeora-Fd-hCdpL.js +1 -0
- package/web-ui/build/static/xl-BWLDspwg.js +1 -0
- package/web-ui/build/static/xml-CLi-y5lE.js +1 -0
- package/web-ui/build/static/xml-doc-CLlGgI7V.js +1 -0
- package/web-ui/build/static/xojo-DO_a9sGm.js +1 -0
- package/web-ui/build/static/xquery-B8tWoM9v.js +1 -0
- package/web-ui/build/static/xquery-CPXrtNkK.js +1 -0
- package/web-ui/build/static/yaml-BZ3EjQX3.js +1 -0
- package/web-ui/build/static/yaml-K-TYwTQz.js +1 -0
- package/web-ui/build/static/yang-C6PwnpSl.js +1 -0
- package/web-ui/build/static/zephir-DJcaUQ9K.js +1 -0
- package/web-ui/build/static/zig-D9pbvi2x.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
|
});
|