hammoc 1.0.0
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/LICENSE +661 -0
- package/README.md +272 -0
- package/bin/hammoc.js +59 -0
- package/package.json +86 -0
- package/packages/client/dist/assets/abap-DsBKuouk.js +1 -0
- package/packages/client/dist/assets/actionscript-3-D_z4Izcz.js +1 -0
- package/packages/client/dist/assets/ada-727ZlQH0.js +1 -0
- package/packages/client/dist/assets/andromeeda-C3khCPGq.js +1 -0
- package/packages/client/dist/assets/angular-html-LfdN0zeE.js +1 -0
- package/packages/client/dist/assets/angular-ts-CKsD7JZE.js +1 -0
- package/packages/client/dist/assets/apache-Dn00JSTd.js +1 -0
- package/packages/client/dist/assets/apex-COJ4H7py.js +1 -0
- package/packages/client/dist/assets/apl-BBq3IX1j.js +1 -0
- package/packages/client/dist/assets/applescript-Bu5BbsvL.js +1 -0
- package/packages/client/dist/assets/ara-7O62HKoU.js +1 -0
- package/packages/client/dist/assets/asciidoc-BPT9niGB.js +1 -0
- package/packages/client/dist/assets/asm-Dhn9LcZ4.js +1 -0
- package/packages/client/dist/assets/astro-CqkE3fuf.js +1 -0
- package/packages/client/dist/assets/aurora-x-D-2ljcwZ.js +1 -0
- package/packages/client/dist/assets/awk-eg146-Ew.js +1 -0
- package/packages/client/dist/assets/ayu-dark-Cv9koXgw.js +1 -0
- package/packages/client/dist/assets/ballerina-Du268qiB.js +1 -0
- package/packages/client/dist/assets/bat-fje9CFhw.js +1 -0
- package/packages/client/dist/assets/beancount-BwXTMy5W.js +1 -0
- package/packages/client/dist/assets/berry-3xVqZejG.js +1 -0
- package/packages/client/dist/assets/bibtex-xW4inM5L.js +1 -0
- package/packages/client/dist/assets/bicep-DHo0CJ0O.js +1 -0
- package/packages/client/dist/assets/blade-a8OxSdnT.js +1 -0
- package/packages/client/dist/assets/bsl-Dgyn0ogV.js +1 -0
- package/packages/client/dist/assets/c-C3t2pwGQ.js +1 -0
- package/packages/client/dist/assets/cadence-DNquZEk8.js +1 -0
- package/packages/client/dist/assets/cairo--RitsXJZ.js +1 -0
- package/packages/client/dist/assets/catppuccin-frappe-CD_QflpE.js +1 -0
- package/packages/client/dist/assets/catppuccin-latte-DRW-0cLl.js +1 -0
- package/packages/client/dist/assets/catppuccin-macchiato-C-_shW-Y.js +1 -0
- package/packages/client/dist/assets/catppuccin-mocha-LGGdnPYs.js +1 -0
- package/packages/client/dist/assets/clarity-BHOwM8T6.js +1 -0
- package/packages/client/dist/assets/clojure-DxSadP1t.js +1 -0
- package/packages/client/dist/assets/cmake-DbXoA79R.js +1 -0
- package/packages/client/dist/assets/cobol-PTqiYgYu.js +1 -0
- package/packages/client/dist/assets/codeowners-Bp6g37R7.js +1 -0
- package/packages/client/dist/assets/codeql-sacFqUAJ.js +1 -0
- package/packages/client/dist/assets/coffee-dyiR41kL.js +1 -0
- package/packages/client/dist/assets/common-lisp-C7gG9l05.js +1 -0
- package/packages/client/dist/assets/coq-Dsg_Bt_b.js +1 -0
- package/packages/client/dist/assets/cpp-BksuvNSY.js +1 -0
- package/packages/client/dist/assets/crystal-DtDmRg-F.js +1 -0
- package/packages/client/dist/assets/csharp-D9R-vmeu.js +1 -0
- package/packages/client/dist/assets/css-BPhBrDlE.js +1 -0
- package/packages/client/dist/assets/csv-B0qRVHPH.js +1 -0
- package/packages/client/dist/assets/cue-DtFQj3wx.js +1 -0
- package/packages/client/dist/assets/cypher-m2LEI-9-.js +1 -0
- package/packages/client/dist/assets/d-BoXegm-a.js +1 -0
- package/packages/client/dist/assets/dark-plus-C3mMm8J8.js +1 -0
- package/packages/client/dist/assets/dart-B9wLZaAG.js +1 -0
- package/packages/client/dist/assets/dax-ClGRhx96.js +1 -0
- package/packages/client/dist/assets/desktop-DEIpsLCJ.js +1 -0
- package/packages/client/dist/assets/diff-BgYniUM_.js +1 -0
- package/packages/client/dist/assets/docker-COcR7UxN.js +1 -0
- package/packages/client/dist/assets/dotenv-BjQB5zDj.js +1 -0
- package/packages/client/dist/assets/dracula-BzJJZx-M.js +1 -0
- package/packages/client/dist/assets/dracula-soft-BXkSAIEj.js +1 -0
- package/packages/client/dist/assets/dream-maker-C-nORZOA.js +1 -0
- package/packages/client/dist/assets/edge-D5gP-w-T.js +1 -0
- package/packages/client/dist/assets/elixir-CLiX3zqd.js +1 -0
- package/packages/client/dist/assets/elm-CmHSxxaM.js +1 -0
- package/packages/client/dist/assets/emacs-lisp-BX77sIaO.js +1 -0
- package/packages/client/dist/assets/erb-BYTLMnw6.js +1 -0
- package/packages/client/dist/assets/erlang-B-DoSBHF.js +1 -0
- package/packages/client/dist/assets/everforest-dark-BgDCqdQA.js +1 -0
- package/packages/client/dist/assets/everforest-light-C8M2exoo.js +1 -0
- package/packages/client/dist/assets/fennel-bCA53EVm.js +1 -0
- package/packages/client/dist/assets/fish-w-ucz2PV.js +1 -0
- package/packages/client/dist/assets/fluent-Dayu4EKP.js +1 -0
- package/packages/client/dist/assets/fortran-fixed-form-TqA4NnZg.js +1 -0
- package/packages/client/dist/assets/fortran-free-form-DKXYxT9g.js +1 -0
- package/packages/client/dist/assets/fsharp-XplgxFYe.js +1 -0
- package/packages/client/dist/assets/gdresource-BHYsBjWJ.js +1 -0
- package/packages/client/dist/assets/gdscript-DfxzS6Rs.js +1 -0
- package/packages/client/dist/assets/gdshader-SKMF96pI.js +1 -0
- package/packages/client/dist/assets/genie-ajMbGru0.js +1 -0
- package/packages/client/dist/assets/gherkin--30QC5Em.js +1 -0
- package/packages/client/dist/assets/git-commit-i4q6IMui.js +1 -0
- package/packages/client/dist/assets/git-rebase-B-v9cOL2.js +1 -0
- package/packages/client/dist/assets/github-dark-DHJKELXO.js +1 -0
- package/packages/client/dist/assets/github-dark-default-Cuk6v7N8.js +1 -0
- package/packages/client/dist/assets/github-dark-dimmed-DH5Ifo-i.js +1 -0
- package/packages/client/dist/assets/github-dark-high-contrast-E3gJ1_iC.js +1 -0
- package/packages/client/dist/assets/github-light-DAi9KRSo.js +1 -0
- package/packages/client/dist/assets/github-light-default-D7oLnXFd.js +1 -0
- package/packages/client/dist/assets/github-light-high-contrast-BfjtVDDH.js +1 -0
- package/packages/client/dist/assets/gleam-B430Bg39.js +1 -0
- package/packages/client/dist/assets/glimmer-js-D-cwc0-E.js +1 -0
- package/packages/client/dist/assets/glimmer-ts-pgjy16dm.js +1 -0
- package/packages/client/dist/assets/glsl-DBO2IWDn.js +1 -0
- package/packages/client/dist/assets/gnuplot-CM8KxXT1.js +1 -0
- package/packages/client/dist/assets/go-B1SYOhNW.js +1 -0
- package/packages/client/dist/assets/graphql-cDcHW_If.js +1 -0
- package/packages/client/dist/assets/groovy-DkBy-JyN.js +1 -0
- package/packages/client/dist/assets/hack-D1yCygmZ.js +1 -0
- package/packages/client/dist/assets/haml-B2EZWmdv.js +1 -0
- package/packages/client/dist/assets/handlebars-BQGss363.js +1 -0
- package/packages/client/dist/assets/haskell-BILxekzW.js +1 -0
- package/packages/client/dist/assets/haxe-C5wWYbrZ.js +1 -0
- package/packages/client/dist/assets/hcl-HzYwdGDm.js +1 -0
- package/packages/client/dist/assets/hjson-T-Tgc4AT.js +1 -0
- package/packages/client/dist/assets/hlsl-ifBTmRxC.js +1 -0
- package/packages/client/dist/assets/houston-DnULxvSX.js +1 -0
- package/packages/client/dist/assets/html-C2L_23MC.js +1 -0
- package/packages/client/dist/assets/html-derivative-CSfWNPLT.js +1 -0
- package/packages/client/dist/assets/http-FRrOvY1W.js +1 -0
- package/packages/client/dist/assets/hxml-TIA70rKU.js +1 -0
- package/packages/client/dist/assets/hy-BMj5Y0dO.js +1 -0
- package/packages/client/dist/assets/imba-bv_oIlVt.js +1 -0
- package/packages/client/dist/assets/index-Bzql1gnR.js +2 -0
- package/packages/client/dist/assets/index-DjQDxRju.css +32 -0
- package/packages/client/dist/assets/index-q3VZc6RP.js +1297 -0
- package/packages/client/dist/assets/ini-BjABl1g7.js +1 -0
- package/packages/client/dist/assets/java-xI-RfyKK.js +1 -0
- package/packages/client/dist/assets/javascript-ySlJ1b_l.js +1 -0
- package/packages/client/dist/assets/jinja-DGy0s7-h.js +1 -0
- package/packages/client/dist/assets/jison-BqZprYcd.js +1 -0
- package/packages/client/dist/assets/json-BQoSv7ci.js +1 -0
- package/packages/client/dist/assets/json5-w8dY5SsB.js +1 -0
- package/packages/client/dist/assets/jsonc-TU54ms6u.js +1 -0
- package/packages/client/dist/assets/jsonl-DREVFZK8.js +1 -0
- package/packages/client/dist/assets/jsonnet-BfivnA6A.js +1 -0
- package/packages/client/dist/assets/jssm-P4WzXJd0.js +1 -0
- package/packages/client/dist/assets/jsx-BAng5TT0.js +1 -0
- package/packages/client/dist/assets/julia-BBuGR-5E.js +1 -0
- package/packages/client/dist/assets/kanagawa-dragon-CkXjmgJE.js +1 -0
- package/packages/client/dist/assets/kanagawa-lotus-CfQXZHmo.js +1 -0
- package/packages/client/dist/assets/kanagawa-wave-DWedfzmr.js +1 -0
- package/packages/client/dist/assets/kotlin-B5lbUyaz.js +1 -0
- package/packages/client/dist/assets/kusto-mebxcVVE.js +1 -0
- package/packages/client/dist/assets/laserwave-DUszq2jm.js +1 -0
- package/packages/client/dist/assets/latex-C-cWTeAZ.js +1 -0
- package/packages/client/dist/assets/lean-XBlWyCtg.js +1 -0
- package/packages/client/dist/assets/less-BfCpw3nA.js +1 -0
- package/packages/client/dist/assets/light-plus-B7mTdjB0.js +1 -0
- package/packages/client/dist/assets/liquid-D3W5UaiH.js +1 -0
- package/packages/client/dist/assets/log-Cc5clBb7.js +1 -0
- package/packages/client/dist/assets/logo-IuBKFhSY.js +1 -0
- package/packages/client/dist/assets/lua-CvWAzNxB.js +1 -0
- package/packages/client/dist/assets/luau-Du5NY7AG.js +1 -0
- package/packages/client/dist/assets/make-Bvotw-X0.js +1 -0
- package/packages/client/dist/assets/markdown-UIAJJxZW.js +1 -0
- package/packages/client/dist/assets/marko-z0MBrx5-.js +1 -0
- package/packages/client/dist/assets/material-theme-D5KoaKCx.js +1 -0
- package/packages/client/dist/assets/material-theme-darker-BfHTSMKl.js +1 -0
- package/packages/client/dist/assets/material-theme-lighter-B0m2ddpp.js +1 -0
- package/packages/client/dist/assets/material-theme-ocean-CyktbL80.js +1 -0
- package/packages/client/dist/assets/material-theme-palenight-Csfq5Kiy.js +1 -0
- package/packages/client/dist/assets/matlab-D9-PGadD.js +1 -0
- package/packages/client/dist/assets/mdc-DB_EDNY_.js +1 -0
- package/packages/client/dist/assets/mdx-sdHcTMYB.js +1 -0
- package/packages/client/dist/assets/mermaid-Ci6OQyBP.js +1 -0
- package/packages/client/dist/assets/min-dark-CafNBF8u.js +1 -0
- package/packages/client/dist/assets/min-light-CTRr51gU.js +1 -0
- package/packages/client/dist/assets/mipsasm-BC5c_5Pe.js +1 -0
- package/packages/client/dist/assets/mojo-Tz6hzZYG.js +1 -0
- package/packages/client/dist/assets/monokai-D4h5O-jR.js +1 -0
- package/packages/client/dist/assets/move-DB_GagMm.js +1 -0
- package/packages/client/dist/assets/narrat-DLbgOhZU.js +1 -0
- package/packages/client/dist/assets/nextflow-B0XVJmRM.js +1 -0
- package/packages/client/dist/assets/nginx-D_VnBJ67.js +1 -0
- package/packages/client/dist/assets/night-owl-C39BiMTA.js +1 -0
- package/packages/client/dist/assets/nim-ZlGxZxc3.js +1 -0
- package/packages/client/dist/assets/nix-shcSOmrb.js +1 -0
- package/packages/client/dist/assets/nord-Ddv68eIx.js +1 -0
- package/packages/client/dist/assets/nushell-D4Tzg5kh.js +1 -0
- package/packages/client/dist/assets/objective-c-Deuh7S70.js +1 -0
- package/packages/client/dist/assets/objective-cpp-BUEGK8hf.js +1 -0
- package/packages/client/dist/assets/ocaml-BNioltXt.js +1 -0
- package/packages/client/dist/assets/one-dark-pro-GBQ2dnAY.js +1 -0
- package/packages/client/dist/assets/one-light-PoHY5YXO.js +1 -0
- package/packages/client/dist/assets/pascal-JqZropPD.js +1 -0
- package/packages/client/dist/assets/perl-CHQXSrWU.js +1 -0
- package/packages/client/dist/assets/php-B5ebYQev.js +1 -0
- package/packages/client/dist/assets/plastic-3e1v2bzS.js +1 -0
- package/packages/client/dist/assets/plsql-LKU2TuZ1.js +1 -0
- package/packages/client/dist/assets/po-BFLt1xDp.js +1 -0
- package/packages/client/dist/assets/poimandres-CS3Unz2-.js +1 -0
- package/packages/client/dist/assets/polar-DKykz6zU.js +1 -0
- package/packages/client/dist/assets/postcss-B3ZDOciz.js +1 -0
- package/packages/client/dist/assets/powerquery-CSHBycmS.js +1 -0
- package/packages/client/dist/assets/powershell-BIEUsx6d.js +1 -0
- package/packages/client/dist/assets/prisma-B48N-Iqd.js +1 -0
- package/packages/client/dist/assets/prolog-BY-TUvya.js +1 -0
- package/packages/client/dist/assets/proto-zocC4JxJ.js +1 -0
- package/packages/client/dist/assets/pug-CM9l7STV.js +1 -0
- package/packages/client/dist/assets/puppet-Cza_XSSt.js +1 -0
- package/packages/client/dist/assets/purescript-Bg-kzb6g.js +1 -0
- package/packages/client/dist/assets/python-DhUJRlN_.js +1 -0
- package/packages/client/dist/assets/qml-D8XfuvdV.js +1 -0
- package/packages/client/dist/assets/qmldir-C8lEn-DE.js +1 -0
- package/packages/client/dist/assets/qss-DhMKtDLN.js +1 -0
- package/packages/client/dist/assets/r-CwjWoCRV.js +1 -0
- package/packages/client/dist/assets/racket-CzouJOBO.js +1 -0
- package/packages/client/dist/assets/raku-B1bQXN8T.js +1 -0
- package/packages/client/dist/assets/razor-CNLDkMZG.js +1 -0
- package/packages/client/dist/assets/red-bN70gL4F.js +1 -0
- package/packages/client/dist/assets/reg-5LuOXUq_.js +1 -0
- package/packages/client/dist/assets/regexp-DWJ3fJO_.js +1 -0
- package/packages/client/dist/assets/rel-DJlmqQ1C.js +1 -0
- package/packages/client/dist/assets/riscv-QhoSD0DR.js +1 -0
- package/packages/client/dist/assets/rose-pine-CmCqftbK.js +1 -0
- package/packages/client/dist/assets/rose-pine-dawn-Ds-gbosJ.js +1 -0
- package/packages/client/dist/assets/rose-pine-moon-CjDtw9vr.js +1 -0
- package/packages/client/dist/assets/rst-4NLicBqY.js +1 -0
- package/packages/client/dist/assets/ruby-DeZ3UC14.js +1 -0
- package/packages/client/dist/assets/rust-Be6lgOlo.js +1 -0
- package/packages/client/dist/assets/sas-BmTFh92c.js +1 -0
- package/packages/client/dist/assets/sass-BJ4Li9vH.js +1 -0
- package/packages/client/dist/assets/scala-DQVVAn-B.js +1 -0
- package/packages/client/dist/assets/scheme-BJGe-b2p.js +1 -0
- package/packages/client/dist/assets/scss-C31hgJw-.js +1 -0
- package/packages/client/dist/assets/sdbl-BLhTXw86.js +1 -0
- package/packages/client/dist/assets/shaderlab-B7qAK45m.js +1 -0
- package/packages/client/dist/assets/shellscript-atvbtKCR.js +1 -0
- package/packages/client/dist/assets/shellsession-C_rIy8kc.js +1 -0
- package/packages/client/dist/assets/slack-dark-BthQWCQV.js +1 -0
- package/packages/client/dist/assets/slack-ochin-DqwNpetd.js +1 -0
- package/packages/client/dist/assets/smalltalk-DkLiglaE.js +1 -0
- package/packages/client/dist/assets/snazzy-light-Bw305WKR.js +1 -0
- package/packages/client/dist/assets/solarized-dark-DXbdFlpD.js +1 -0
- package/packages/client/dist/assets/solarized-light-L9t79GZl.js +1 -0
- package/packages/client/dist/assets/solidity-C1w2a3ep.js +1 -0
- package/packages/client/dist/assets/soy-C-lX7w71.js +1 -0
- package/packages/client/dist/assets/sparql-bYkjHRlG.js +1 -0
- package/packages/client/dist/assets/splunk-Cf8iN4DR.js +1 -0
- package/packages/client/dist/assets/sql-COK4E0Yg.js +1 -0
- package/packages/client/dist/assets/ssh-config-BknIz3MU.js +1 -0
- package/packages/client/dist/assets/stata-DorPZHa4.js +1 -0
- package/packages/client/dist/assets/stylus-BeQkCIfX.js +1 -0
- package/packages/client/dist/assets/svelte-MSaWC3Je.js +1 -0
- package/packages/client/dist/assets/swift-BSxZ-RaX.js +1 -0
- package/packages/client/dist/assets/synthwave-84-CbfX1IO0.js +1 -0
- package/packages/client/dist/assets/system-verilog-C7L56vO4.js +1 -0
- package/packages/client/dist/assets/systemd-CUnW07Te.js +1 -0
- package/packages/client/dist/assets/talonscript-C1XDQQGZ.js +1 -0
- package/packages/client/dist/assets/tasl-CQjiPCtT.js +1 -0
- package/packages/client/dist/assets/tcl-DQ1-QYvQ.js +1 -0
- package/packages/client/dist/assets/templ-dwX3ZSMB.js +1 -0
- package/packages/client/dist/assets/terraform-BbSNqyBO.js +1 -0
- package/packages/client/dist/assets/tex-rYs2v40G.js +1 -0
- package/packages/client/dist/assets/tokyo-night-DBQeEorK.js +1 -0
- package/packages/client/dist/assets/toml-CB2ApiWb.js +1 -0
- package/packages/client/dist/assets/ts-tags-CipyTH0X.js +1 -0
- package/packages/client/dist/assets/tsv-B_m7g4N7.js +1 -0
- package/packages/client/dist/assets/tsx-B6W0miNI.js +1 -0
- package/packages/client/dist/assets/turtle-BMR_PYu6.js +1 -0
- package/packages/client/dist/assets/twig-NC5TFiHP.js +1 -0
- package/packages/client/dist/assets/typescript-Dj6nwHGl.js +1 -0
- package/packages/client/dist/assets/typespec-BpWG_bgh.js +1 -0
- package/packages/client/dist/assets/typst-BVUVsWT6.js +1 -0
- package/packages/client/dist/assets/v-CAQ2eGtk.js +1 -0
- package/packages/client/dist/assets/vala-BFOHcciG.js +1 -0
- package/packages/client/dist/assets/vb-CdO5JTpU.js +1 -0
- package/packages/client/dist/assets/verilog-CJaU5se_.js +1 -0
- package/packages/client/dist/assets/vesper-BEBZ7ncR.js +1 -0
- package/packages/client/dist/assets/vhdl-DYoNaHQp.js +1 -0
- package/packages/client/dist/assets/viml-m4uW47V2.js +1 -0
- package/packages/client/dist/assets/vitesse-black-Bkuqu6BP.js +1 -0
- package/packages/client/dist/assets/vitesse-dark-D0r3Knsf.js +1 -0
- package/packages/client/dist/assets/vitesse-light-CVO1_9PV.js +1 -0
- package/packages/client/dist/assets/vue-BuYVFjOK.js +1 -0
- package/packages/client/dist/assets/vue-html-xdeiXROB.js +1 -0
- package/packages/client/dist/assets/vyper-nyqBNV6O.js +1 -0
- package/packages/client/dist/assets/wasm-C6j12Q_x.js +1 -0
- package/packages/client/dist/assets/wasm-CG6Dc4jp.js +1 -0
- package/packages/client/dist/assets/wenyan-7A4Fjokl.js +1 -0
- package/packages/client/dist/assets/wgsl-CB0Krxn9.js +1 -0
- package/packages/client/dist/assets/wikitext-DCE3LsBG.js +1 -0
- package/packages/client/dist/assets/wolfram-C3FkfJm5.js +1 -0
- package/packages/client/dist/assets/xml-e3z08dGr.js +1 -0
- package/packages/client/dist/assets/xsl-Dd0NUgwM.js +1 -0
- package/packages/client/dist/assets/yaml-CVw76BM1.js +1 -0
- package/packages/client/dist/assets/zenscript-HnGAYVZD.js +1 -0
- package/packages/client/dist/assets/zig-BVz_zdnA.js +1 -0
- package/packages/client/dist/index.html +13 -0
- package/packages/server/dist/__tests__/i18n.test.d.ts +5 -0
- package/packages/server/dist/__tests__/i18n.test.d.ts.map +1 -0
- package/packages/server/dist/__tests__/i18n.test.js +31 -0
- package/packages/server/dist/__tests__/i18n.test.js.map +1 -0
- package/packages/server/dist/app.d.ts +15 -0
- package/packages/server/dist/app.d.ts.map +1 -0
- package/packages/server/dist/app.js +120 -0
- package/packages/server/dist/app.js.map +1 -0
- package/packages/server/dist/cli/passwordSetup.d.ts +5 -0
- package/packages/server/dist/cli/passwordSetup.d.ts.map +1 -0
- package/packages/server/dist/cli/passwordSetup.js +74 -0
- package/packages/server/dist/cli/passwordSetup.js.map +1 -0
- package/packages/server/dist/config/index.d.ts +81 -0
- package/packages/server/dist/config/index.d.ts.map +1 -0
- package/packages/server/dist/config/index.js +107 -0
- package/packages/server/dist/config/index.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/authController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/authController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/authController.test.js +198 -0
- package/packages/server/dist/controllers/__tests__/authController.test.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/bmadStatusController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/bmadStatusController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/bmadStatusController.test.js +121 -0
- package/packages/server/dist/controllers/__tests__/bmadStatusController.test.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/commandController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/commandController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/commandController.test.js +73 -0
- package/packages/server/dist/controllers/__tests__/commandController.test.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/dashboardController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/dashboardController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/dashboardController.test.js +63 -0
- package/packages/server/dist/controllers/__tests__/dashboardController.test.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/gitController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/gitController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/gitController.test.js +585 -0
- package/packages/server/dist/controllers/__tests__/gitController.test.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/projectController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/projectController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/projectController.test.js +175 -0
- package/packages/server/dist/controllers/__tests__/projectController.test.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/queueController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/queueController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/queueController.test.js +115 -0
- package/packages/server/dist/controllers/__tests__/queueController.test.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/queueTemplateController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/queueTemplateController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/queueTemplateController.test.js +167 -0
- package/packages/server/dist/controllers/__tests__/queueTemplateController.test.js.map +1 -0
- package/packages/server/dist/controllers/__tests__/sessionController.test.d.ts +6 -0
- package/packages/server/dist/controllers/__tests__/sessionController.test.d.ts.map +1 -0
- package/packages/server/dist/controllers/__tests__/sessionController.test.js +113 -0
- package/packages/server/dist/controllers/__tests__/sessionController.test.js.map +1 -0
- package/packages/server/dist/controllers/authController.d.ts +30 -0
- package/packages/server/dist/controllers/authController.d.ts.map +1 -0
- package/packages/server/dist/controllers/authController.js +209 -0
- package/packages/server/dist/controllers/authController.js.map +1 -0
- package/packages/server/dist/controllers/bmadStatusController.d.ts +5 -0
- package/packages/server/dist/controllers/bmadStatusController.d.ts.map +1 -0
- package/packages/server/dist/controllers/bmadStatusController.js +53 -0
- package/packages/server/dist/controllers/bmadStatusController.js.map +1 -0
- package/packages/server/dist/controllers/boardController.d.ts +16 -0
- package/packages/server/dist/controllers/boardController.d.ts.map +1 -0
- package/packages/server/dist/controllers/boardController.js +295 -0
- package/packages/server/dist/controllers/boardController.js.map +1 -0
- package/packages/server/dist/controllers/cliController.d.ts +7 -0
- package/packages/server/dist/controllers/cliController.d.ts.map +1 -0
- package/packages/server/dist/controllers/cliController.js +27 -0
- package/packages/server/dist/controllers/cliController.js.map +1 -0
- package/packages/server/dist/controllers/commandController.d.ts +14 -0
- package/packages/server/dist/controllers/commandController.d.ts.map +1 -0
- package/packages/server/dist/controllers/commandController.js +31 -0
- package/packages/server/dist/controllers/commandController.js.map +1 -0
- package/packages/server/dist/controllers/dashboardController.d.ts +10 -0
- package/packages/server/dist/controllers/dashboardController.d.ts.map +1 -0
- package/packages/server/dist/controllers/dashboardController.js +23 -0
- package/packages/server/dist/controllers/dashboardController.js.map +1 -0
- package/packages/server/dist/controllers/fileSystemController.d.ts +54 -0
- package/packages/server/dist/controllers/fileSystemController.d.ts.map +1 -0
- package/packages/server/dist/controllers/fileSystemController.js +435 -0
- package/packages/server/dist/controllers/fileSystemController.js.map +1 -0
- package/packages/server/dist/controllers/gitController.d.ts +57 -0
- package/packages/server/dist/controllers/gitController.d.ts.map +1 -0
- package/packages/server/dist/controllers/gitController.js +494 -0
- package/packages/server/dist/controllers/gitController.js.map +1 -0
- package/packages/server/dist/controllers/projectController.d.ts +57 -0
- package/packages/server/dist/controllers/projectController.d.ts.map +1 -0
- package/packages/server/dist/controllers/projectController.js +358 -0
- package/packages/server/dist/controllers/projectController.js.map +1 -0
- package/packages/server/dist/controllers/queueController.d.ts +15 -0
- package/packages/server/dist/controllers/queueController.d.ts.map +1 -0
- package/packages/server/dist/controllers/queueController.js +131 -0
- package/packages/server/dist/controllers/queueController.js.map +1 -0
- package/packages/server/dist/controllers/queueTemplateController.d.ts +15 -0
- package/packages/server/dist/controllers/queueTemplateController.d.ts.map +1 -0
- package/packages/server/dist/controllers/queueTemplateController.js +187 -0
- package/packages/server/dist/controllers/queueTemplateController.js.map +1 -0
- package/packages/server/dist/controllers/serverController.d.ts +14 -0
- package/packages/server/dist/controllers/serverController.d.ts.map +1 -0
- package/packages/server/dist/controllers/serverController.js +164 -0
- package/packages/server/dist/controllers/serverController.js.map +1 -0
- package/packages/server/dist/controllers/sessionController.d.ts +39 -0
- package/packages/server/dist/controllers/sessionController.d.ts.map +1 -0
- package/packages/server/dist/controllers/sessionController.js +230 -0
- package/packages/server/dist/controllers/sessionController.js.map +1 -0
- package/packages/server/dist/dev.d.ts +2 -0
- package/packages/server/dist/dev.d.ts.map +1 -0
- package/packages/server/dist/dev.js +8 -0
- package/packages/server/dist/dev.js.map +1 -0
- package/packages/server/dist/handlers/__tests__/websocket.auth.test.d.ts +7 -0
- package/packages/server/dist/handlers/__tests__/websocket.auth.test.d.ts.map +1 -0
- package/packages/server/dist/handlers/__tests__/websocket.auth.test.js +125 -0
- package/packages/server/dist/handlers/__tests__/websocket.auth.test.js.map +1 -0
- package/packages/server/dist/handlers/__tests__/websocket.test.d.ts +2 -0
- package/packages/server/dist/handlers/__tests__/websocket.test.d.ts.map +1 -0
- package/packages/server/dist/handlers/__tests__/websocket.test.js +1316 -0
- package/packages/server/dist/handlers/__tests__/websocket.test.js.map +1 -0
- package/packages/server/dist/handlers/streamCallbacks.d.ts +52 -0
- package/packages/server/dist/handlers/streamCallbacks.d.ts.map +1 -0
- package/packages/server/dist/handlers/streamCallbacks.js +107 -0
- package/packages/server/dist/handlers/streamCallbacks.js.map +1 -0
- package/packages/server/dist/handlers/websocket.d.ts +82 -0
- package/packages/server/dist/handlers/websocket.d.ts.map +1 -0
- package/packages/server/dist/handlers/websocket.js +1041 -0
- package/packages/server/dist/handlers/websocket.js.map +1 -0
- package/packages/server/dist/i18n.d.ts +7 -0
- package/packages/server/dist/i18n.d.ts.map +1 -0
- package/packages/server/dist/i18n.js +32 -0
- package/packages/server/dist/i18n.js.map +1 -0
- package/packages/server/dist/index.d.ts +2 -0
- package/packages/server/dist/index.d.ts.map +1 -0
- package/packages/server/dist/index.js +114 -0
- package/packages/server/dist/index.js.map +1 -0
- package/packages/server/dist/locales/en/server.json +303 -0
- package/packages/server/dist/locales/es/server.json +303 -0
- package/packages/server/dist/locales/ja/server.json +303 -0
- package/packages/server/dist/locales/ko/server.json +303 -0
- package/packages/server/dist/locales/pt/server.json +303 -0
- package/packages/server/dist/locales/zh-CN/server.json +303 -0
- package/packages/server/dist/middleware/__tests__/auth.test.d.ts +6 -0
- package/packages/server/dist/middleware/__tests__/auth.test.d.ts.map +1 -0
- package/packages/server/dist/middleware/__tests__/auth.test.js +146 -0
- package/packages/server/dist/middleware/__tests__/auth.test.js.map +1 -0
- package/packages/server/dist/middleware/__tests__/i18n.test.d.ts +5 -0
- package/packages/server/dist/middleware/__tests__/i18n.test.d.ts.map +1 -0
- package/packages/server/dist/middleware/__tests__/i18n.test.js +96 -0
- package/packages/server/dist/middleware/__tests__/i18n.test.js.map +1 -0
- package/packages/server/dist/middleware/__tests__/pathGuard.test.d.ts +6 -0
- package/packages/server/dist/middleware/__tests__/pathGuard.test.d.ts.map +1 -0
- package/packages/server/dist/middleware/__tests__/pathGuard.test.js +73 -0
- package/packages/server/dist/middleware/__tests__/pathGuard.test.js.map +1 -0
- package/packages/server/dist/middleware/__tests__/session.test.d.ts +6 -0
- package/packages/server/dist/middleware/__tests__/session.test.d.ts.map +1 -0
- package/packages/server/dist/middleware/__tests__/session.test.js +33 -0
- package/packages/server/dist/middleware/__tests__/session.test.js.map +1 -0
- package/packages/server/dist/middleware/auth.d.ts +18 -0
- package/packages/server/dist/middleware/auth.d.ts.map +1 -0
- package/packages/server/dist/middleware/auth.js +52 -0
- package/packages/server/dist/middleware/auth.js.map +1 -0
- package/packages/server/dist/middleware/i18n.d.ts +17 -0
- package/packages/server/dist/middleware/i18n.d.ts.map +1 -0
- package/packages/server/dist/middleware/i18n.js +42 -0
- package/packages/server/dist/middleware/i18n.js.map +1 -0
- package/packages/server/dist/middleware/pathGuard.d.ts +15 -0
- package/packages/server/dist/middleware/pathGuard.d.ts.map +1 -0
- package/packages/server/dist/middleware/pathGuard.js +41 -0
- package/packages/server/dist/middleware/pathGuard.js.map +1 -0
- package/packages/server/dist/middleware/session.d.ts +18 -0
- package/packages/server/dist/middleware/session.d.ts.map +1 -0
- package/packages/server/dist/middleware/session.js +35 -0
- package/packages/server/dist/middleware/session.js.map +1 -0
- package/packages/server/dist/routes/__tests__/auth.integration.test.d.ts +6 -0
- package/packages/server/dist/routes/__tests__/auth.integration.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/auth.integration.test.js +111 -0
- package/packages/server/dist/routes/__tests__/auth.integration.test.js.map +1 -0
- package/packages/server/dist/routes/__tests__/auth.test.d.ts +6 -0
- package/packages/server/dist/routes/__tests__/auth.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/auth.test.js +155 -0
- package/packages/server/dist/routes/__tests__/auth.test.js.map +1 -0
- package/packages/server/dist/routes/__tests__/board.test.d.ts +2 -0
- package/packages/server/dist/routes/__tests__/board.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/board.test.js +201 -0
- package/packages/server/dist/routes/__tests__/board.test.js.map +1 -0
- package/packages/server/dist/routes/__tests__/cli.test.d.ts +2 -0
- package/packages/server/dist/routes/__tests__/cli.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/cli.test.js +121 -0
- package/packages/server/dist/routes/__tests__/cli.test.js.map +1 -0
- package/packages/server/dist/routes/__tests__/commands.test.d.ts +6 -0
- package/packages/server/dist/routes/__tests__/commands.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/commands.test.js +74 -0
- package/packages/server/dist/routes/__tests__/commands.test.js.map +1 -0
- package/packages/server/dist/routes/__tests__/projects.integration.test.d.ts +9 -0
- package/packages/server/dist/routes/__tests__/projects.integration.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/projects.integration.test.js +517 -0
- package/packages/server/dist/routes/__tests__/projects.integration.test.js.map +1 -0
- package/packages/server/dist/routes/__tests__/projects.test.d.ts +7 -0
- package/packages/server/dist/routes/__tests__/projects.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/projects.test.js +361 -0
- package/packages/server/dist/routes/__tests__/projects.test.js.map +1 -0
- package/packages/server/dist/routes/__tests__/sessions.integration.test.d.ts +8 -0
- package/packages/server/dist/routes/__tests__/sessions.integration.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/sessions.integration.test.js +287 -0
- package/packages/server/dist/routes/__tests__/sessions.integration.test.js.map +1 -0
- package/packages/server/dist/routes/__tests__/sessions.test.d.ts +6 -0
- package/packages/server/dist/routes/__tests__/sessions.test.d.ts.map +1 -0
- package/packages/server/dist/routes/__tests__/sessions.test.js +261 -0
- package/packages/server/dist/routes/__tests__/sessions.test.js.map +1 -0
- package/packages/server/dist/routes/auth.d.ts +8 -0
- package/packages/server/dist/routes/auth.d.ts.map +1 -0
- package/packages/server/dist/routes/auth.js +18 -0
- package/packages/server/dist/routes/auth.js.map +1 -0
- package/packages/server/dist/routes/bmadStatus.d.ts +3 -0
- package/packages/server/dist/routes/bmadStatus.d.ts.map +1 -0
- package/packages/server/dist/routes/bmadStatus.js +7 -0
- package/packages/server/dist/routes/bmadStatus.js.map +1 -0
- package/packages/server/dist/routes/board.d.ts +3 -0
- package/packages/server/dist/routes/board.d.ts.map +1 -0
- package/packages/server/dist/routes/board.js +16 -0
- package/packages/server/dist/routes/board.js.map +1 -0
- package/packages/server/dist/routes/cli.d.ts +3 -0
- package/packages/server/dist/routes/cli.d.ts.map +1 -0
- package/packages/server/dist/routes/cli.js +10 -0
- package/packages/server/dist/routes/cli.js.map +1 -0
- package/packages/server/dist/routes/commands.d.ts +8 -0
- package/packages/server/dist/routes/commands.d.ts.map +1 -0
- package/packages/server/dist/routes/commands.js +12 -0
- package/packages/server/dist/routes/commands.js.map +1 -0
- package/packages/server/dist/routes/dashboard.d.ts +3 -0
- package/packages/server/dist/routes/dashboard.d.ts.map +1 -0
- package/packages/server/dist/routes/dashboard.js +7 -0
- package/packages/server/dist/routes/dashboard.js.map +1 -0
- package/packages/server/dist/routes/debug.d.ts +6 -0
- package/packages/server/dist/routes/debug.d.ts.map +1 -0
- package/packages/server/dist/routes/debug.js +59 -0
- package/packages/server/dist/routes/debug.js.map +1 -0
- package/packages/server/dist/routes/fileSystem.d.ts +8 -0
- package/packages/server/dist/routes/fileSystem.d.ts.map +1 -0
- package/packages/server/dist/routes/fileSystem.js +24 -0
- package/packages/server/dist/routes/fileSystem.js.map +1 -0
- package/packages/server/dist/routes/git.d.ts +8 -0
- package/packages/server/dist/routes/git.d.ts.map +1 -0
- package/packages/server/dist/routes/git.js +24 -0
- package/packages/server/dist/routes/git.js.map +1 -0
- package/packages/server/dist/routes/preferences.d.ts +7 -0
- package/packages/server/dist/routes/preferences.d.ts.map +1 -0
- package/packages/server/dist/routes/preferences.js +112 -0
- package/packages/server/dist/routes/preferences.js.map +1 -0
- package/packages/server/dist/routes/projects.d.ts +9 -0
- package/packages/server/dist/routes/projects.d.ts.map +1 -0
- package/packages/server/dist/routes/projects.js +84 -0
- package/packages/server/dist/routes/projects.js.map +1 -0
- package/packages/server/dist/routes/queue.d.ts +7 -0
- package/packages/server/dist/routes/queue.d.ts.map +1 -0
- package/packages/server/dist/routes/queue.js +22 -0
- package/packages/server/dist/routes/queue.js.map +1 -0
- package/packages/server/dist/routes/server.d.ts +3 -0
- package/packages/server/dist/routes/server.d.ts.map +1 -0
- package/packages/server/dist/routes/server.js +10 -0
- package/packages/server/dist/routes/server.js.map +1 -0
- package/packages/server/dist/routes/sessions.d.ts +8 -0
- package/packages/server/dist/routes/sessions.d.ts.map +1 -0
- package/packages/server/dist/routes/sessions.js +47 -0
- package/packages/server/dist/routes/sessions.js.map +1 -0
- package/packages/server/dist/services/__tests__/authConfigService.test.d.ts +2 -0
- package/packages/server/dist/services/__tests__/authConfigService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/authConfigService.test.js +274 -0
- package/packages/server/dist/services/__tests__/authConfigService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/bmadStatusService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/bmadStatusService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/bmadStatusService.test.js +456 -0
- package/packages/server/dist/services/__tests__/bmadStatusService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/chatService.integration.test.d.ts +32 -0
- package/packages/server/dist/services/__tests__/chatService.integration.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/chatService.integration.test.js +97 -0
- package/packages/server/dist/services/__tests__/chatService.integration.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/chatService.test.d.ts +2 -0
- package/packages/server/dist/services/__tests__/chatService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/chatService.test.js +517 -0
- package/packages/server/dist/services/__tests__/chatService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/cliService.test.d.ts +2 -0
- package/packages/server/dist/services/__tests__/cliService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/cliService.test.js +172 -0
- package/packages/server/dist/services/__tests__/cliService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/commandService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/commandService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/commandService.test.js +525 -0
- package/packages/server/dist/services/__tests__/commandService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/dashboardService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/dashboardService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/dashboardService.test.js +248 -0
- package/packages/server/dist/services/__tests__/dashboardService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/fileSystemService.test.d.ts +7 -0
- package/packages/server/dist/services/__tests__/fileSystemService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/fileSystemService.test.js +348 -0
- package/packages/server/dist/services/__tests__/fileSystemService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/gitService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/gitService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/gitService.test.js +340 -0
- package/packages/server/dist/services/__tests__/gitService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/historyParser.test.d.ts +2 -0
- package/packages/server/dist/services/__tests__/historyParser.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/historyParser.test.js +471 -0
- package/packages/server/dist/services/__tests__/historyParser.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/issueService.test.d.ts +2 -0
- package/packages/server/dist/services/__tests__/issueService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/issueService.test.js +382 -0
- package/packages/server/dist/services/__tests__/issueService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/notificationService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/notificationService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/notificationService.test.js +131 -0
- package/packages/server/dist/services/__tests__/notificationService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/preferencesService.telegram.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/preferencesService.telegram.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/preferencesService.telegram.test.js +101 -0
- package/packages/server/dist/services/__tests__/preferencesService.telegram.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/preferencesService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/preferencesService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/preferencesService.test.js +68 -0
- package/packages/server/dist/services/__tests__/preferencesService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/projectService.settings.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/projectService.settings.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/projectService.settings.test.js +101 -0
- package/packages/server/dist/services/__tests__/projectService.settings.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/projectService.test.d.ts +7 -0
- package/packages/server/dist/services/__tests__/projectService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/projectService.test.js +618 -0
- package/packages/server/dist/services/__tests__/projectService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/ptyService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/ptyService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/ptyService.test.js +289 -0
- package/packages/server/dist/services/__tests__/ptyService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/queueService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/queueService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/queueService.test.js +477 -0
- package/packages/server/dist/services/__tests__/queueService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/queueTemplateService.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/queueTemplateService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/queueTemplateService.test.js +129 -0
- package/packages/server/dist/services/__tests__/queueTemplateService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/rateLimiter.test.d.ts +6 -0
- package/packages/server/dist/services/__tests__/rateLimiter.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/rateLimiter.test.js +123 -0
- package/packages/server/dist/services/__tests__/rateLimiter.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/sessionService.test.d.ts +2 -0
- package/packages/server/dist/services/__tests__/sessionService.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/sessionService.test.js +349 -0
- package/packages/server/dist/services/__tests__/sessionService.test.js.map +1 -0
- package/packages/server/dist/services/__tests__/streamHandler.test.d.ts +2 -0
- package/packages/server/dist/services/__tests__/streamHandler.test.d.ts.map +1 -0
- package/packages/server/dist/services/__tests__/streamHandler.test.js +654 -0
- package/packages/server/dist/services/__tests__/streamHandler.test.js.map +1 -0
- package/packages/server/dist/services/authConfigService.d.ts +56 -0
- package/packages/server/dist/services/authConfigService.d.ts.map +1 -0
- package/packages/server/dist/services/authConfigService.js +186 -0
- package/packages/server/dist/services/authConfigService.js.map +1 -0
- package/packages/server/dist/services/bmadStatusService.d.ts +56 -0
- package/packages/server/dist/services/bmadStatusService.d.ts.map +1 -0
- package/packages/server/dist/services/bmadStatusService.js +438 -0
- package/packages/server/dist/services/bmadStatusService.js.map +1 -0
- package/packages/server/dist/services/chatService.d.ts +78 -0
- package/packages/server/dist/services/chatService.d.ts.map +1 -0
- package/packages/server/dist/services/chatService.js +335 -0
- package/packages/server/dist/services/chatService.js.map +1 -0
- package/packages/server/dist/services/cliService.d.ts +29 -0
- package/packages/server/dist/services/cliService.d.ts.map +1 -0
- package/packages/server/dist/services/cliService.js +101 -0
- package/packages/server/dist/services/cliService.js.map +1 -0
- package/packages/server/dist/services/commandService.d.ts +84 -0
- package/packages/server/dist/services/commandService.d.ts.map +1 -0
- package/packages/server/dist/services/commandService.js +322 -0
- package/packages/server/dist/services/commandService.js.map +1 -0
- package/packages/server/dist/services/dashboardService.d.ts +23 -0
- package/packages/server/dist/services/dashboardService.d.ts.map +1 -0
- package/packages/server/dist/services/dashboardService.js +81 -0
- package/packages/server/dist/services/dashboardService.js.map +1 -0
- package/packages/server/dist/services/fileSystemService.d.ts +105 -0
- package/packages/server/dist/services/fileSystemService.d.ts.map +1 -0
- package/packages/server/dist/services/fileSystemService.js +498 -0
- package/packages/server/dist/services/fileSystemService.js.map +1 -0
- package/packages/server/dist/services/gitService.d.ts +25 -0
- package/packages/server/dist/services/gitService.d.ts.map +1 -0
- package/packages/server/dist/services/gitService.js +230 -0
- package/packages/server/dist/services/gitService.js.map +1 -0
- package/packages/server/dist/services/historyParser.d.ts +45 -0
- package/packages/server/dist/services/historyParser.d.ts.map +1 -0
- package/packages/server/dist/services/historyParser.js +315 -0
- package/packages/server/dist/services/historyParser.js.map +1 -0
- package/packages/server/dist/services/issueService.d.ts +79 -0
- package/packages/server/dist/services/issueService.d.ts.map +1 -0
- package/packages/server/dist/services/issueService.js +708 -0
- package/packages/server/dist/services/issueService.js.map +1 -0
- package/packages/server/dist/services/notificationService.d.ts +78 -0
- package/packages/server/dist/services/notificationService.d.ts.map +1 -0
- package/packages/server/dist/services/notificationService.js +246 -0
- package/packages/server/dist/services/notificationService.js.map +1 -0
- package/packages/server/dist/services/preferencesService.d.ts +35 -0
- package/packages/server/dist/services/preferencesService.d.ts.map +1 -0
- package/packages/server/dist/services/preferencesService.js +121 -0
- package/packages/server/dist/services/preferencesService.js.map +1 -0
- package/packages/server/dist/services/projectService.d.ts +210 -0
- package/packages/server/dist/services/projectService.d.ts.map +1 -0
- package/packages/server/dist/services/projectService.js +892 -0
- package/packages/server/dist/services/projectService.js.map +1 -0
- package/packages/server/dist/services/ptyService.d.ts +83 -0
- package/packages/server/dist/services/ptyService.d.ts.map +1 -0
- package/packages/server/dist/services/ptyService.js +214 -0
- package/packages/server/dist/services/ptyService.js.map +1 -0
- package/packages/server/dist/services/queueService.d.ts +93 -0
- package/packages/server/dist/services/queueService.d.ts.map +1 -0
- package/packages/server/dist/services/queueService.js +598 -0
- package/packages/server/dist/services/queueService.js.map +1 -0
- package/packages/server/dist/services/queueTemplateService.d.ts +12 -0
- package/packages/server/dist/services/queueTemplateService.d.ts.map +1 -0
- package/packages/server/dist/services/queueTemplateService.js +73 -0
- package/packages/server/dist/services/queueTemplateService.js.map +1 -0
- package/packages/server/dist/services/rateLimitProbeService.d.ts +56 -0
- package/packages/server/dist/services/rateLimitProbeService.d.ts.map +1 -0
- package/packages/server/dist/services/rateLimitProbeService.js +227 -0
- package/packages/server/dist/services/rateLimitProbeService.js.map +1 -0
- package/packages/server/dist/services/rateLimiter.d.ts +32 -0
- package/packages/server/dist/services/rateLimiter.d.ts.map +1 -0
- package/packages/server/dist/services/rateLimiter.js +60 -0
- package/packages/server/dist/services/rateLimiter.js.map +1 -0
- package/packages/server/dist/services/sessionService.d.ts +152 -0
- package/packages/server/dist/services/sessionService.d.ts.map +1 -0
- package/packages/server/dist/services/sessionService.js +672 -0
- package/packages/server/dist/services/sessionService.js.map +1 -0
- package/packages/server/dist/services/streamHandler.d.ts +145 -0
- package/packages/server/dist/services/streamHandler.d.ts.map +1 -0
- package/packages/server/dist/services/streamHandler.js +753 -0
- package/packages/server/dist/services/streamHandler.js.map +1 -0
- package/packages/server/dist/utils/__tests__/networkUtils.test.d.ts +6 -0
- package/packages/server/dist/utils/__tests__/networkUtils.test.d.ts.map +1 -0
- package/packages/server/dist/utils/__tests__/networkUtils.test.js +106 -0
- package/packages/server/dist/utils/__tests__/networkUtils.test.js.map +1 -0
- package/packages/server/dist/utils/__tests__/pathUtils.test.d.ts +6 -0
- package/packages/server/dist/utils/__tests__/pathUtils.test.d.ts.map +1 -0
- package/packages/server/dist/utils/__tests__/pathUtils.test.js +111 -0
- package/packages/server/dist/utils/__tests__/pathUtils.test.js.map +1 -0
- package/packages/server/dist/utils/errors.d.ts +79 -0
- package/packages/server/dist/utils/errors.d.ts.map +1 -0
- package/packages/server/dist/utils/errors.js +167 -0
- package/packages/server/dist/utils/errors.js.map +1 -0
- package/packages/server/dist/utils/logger.d.ts +28 -0
- package/packages/server/dist/utils/logger.d.ts.map +1 -0
- package/packages/server/dist/utils/logger.js +87 -0
- package/packages/server/dist/utils/logger.js.map +1 -0
- package/packages/server/dist/utils/networkUtils.d.ts +26 -0
- package/packages/server/dist/utils/networkUtils.d.ts.map +1 -0
- package/packages/server/dist/utils/networkUtils.js +70 -0
- package/packages/server/dist/utils/networkUtils.js.map +1 -0
- package/packages/server/dist/utils/pathUtils.d.ts +30 -0
- package/packages/server/dist/utils/pathUtils.d.ts.map +1 -0
- package/packages/server/dist/utils/pathUtils.js +81 -0
- package/packages/server/dist/utils/pathUtils.js.map +1 -0
- package/packages/server/package.json +48 -0
- package/packages/shared/dist/constants/errorCodes.d.ts +31 -0
- package/packages/shared/dist/constants/errorCodes.d.ts.map +1 -0
- package/packages/shared/dist/constants/errorCodes.js +33 -0
- package/packages/shared/dist/constants/errorCodes.js.map +1 -0
- package/packages/shared/dist/index.d.ts +26 -0
- package/packages/shared/dist/index.d.ts.map +1 -0
- package/packages/shared/dist/index.js +48 -0
- package/packages/shared/dist/index.js.map +1 -0
- package/packages/shared/dist/types/auth.d.ts +159 -0
- package/packages/shared/dist/types/auth.d.ts.map +1 -0
- package/packages/shared/dist/types/auth.js +74 -0
- package/packages/shared/dist/types/auth.js.map +1 -0
- package/packages/shared/dist/types/bmadStatus.d.ts +97 -0
- package/packages/shared/dist/types/bmadStatus.d.ts.map +1 -0
- package/packages/shared/dist/types/bmadStatus.js +18 -0
- package/packages/shared/dist/types/bmadStatus.js.map +1 -0
- package/packages/shared/dist/types/board.d.ts +68 -0
- package/packages/shared/dist/types/board.d.ts.map +1 -0
- package/packages/shared/dist/types/board.js +108 -0
- package/packages/shared/dist/types/board.js.map +1 -0
- package/packages/shared/dist/types/cli.d.ts +34 -0
- package/packages/shared/dist/types/cli.d.ts.map +1 -0
- package/packages/shared/dist/types/cli.js +10 -0
- package/packages/shared/dist/types/cli.js.map +1 -0
- package/packages/shared/dist/types/command.d.ts +39 -0
- package/packages/shared/dist/types/command.d.ts.map +1 -0
- package/packages/shared/dist/types/command.js +6 -0
- package/packages/shared/dist/types/command.js.map +1 -0
- package/packages/shared/dist/types/dashboard.d.ts +15 -0
- package/packages/shared/dist/types/dashboard.d.ts.map +1 -0
- package/packages/shared/dist/types/dashboard.js +3 -0
- package/packages/shared/dist/types/dashboard.js.map +1 -0
- package/packages/shared/dist/types/fileSystem.d.ts +175 -0
- package/packages/shared/dist/types/fileSystem.d.ts.map +1 -0
- package/packages/shared/dist/types/fileSystem.js +62 -0
- package/packages/shared/dist/types/fileSystem.js.map +1 -0
- package/packages/shared/dist/types/git.d.ts +81 -0
- package/packages/shared/dist/types/git.d.ts.map +1 -0
- package/packages/shared/dist/types/git.js +34 -0
- package/packages/shared/dist/types/git.js.map +1 -0
- package/packages/shared/dist/types/history.d.ts +103 -0
- package/packages/shared/dist/types/history.d.ts.map +1 -0
- package/packages/shared/dist/types/history.js +6 -0
- package/packages/shared/dist/types/history.js.map +1 -0
- package/packages/shared/dist/types/logger.d.ts +18 -0
- package/packages/shared/dist/types/logger.d.ts.map +1 -0
- package/packages/shared/dist/types/logger.js +29 -0
- package/packages/shared/dist/types/logger.js.map +1 -0
- package/packages/shared/dist/types/message.d.ts +34 -0
- package/packages/shared/dist/types/message.d.ts.map +1 -0
- package/packages/shared/dist/types/message.js +14 -0
- package/packages/shared/dist/types/message.js.map +1 -0
- package/packages/shared/dist/types/preferences.d.ts +95 -0
- package/packages/shared/dist/types/preferences.d.ts.map +1 -0
- package/packages/shared/dist/types/preferences.js +15 -0
- package/packages/shared/dist/types/preferences.js.map +1 -0
- package/packages/shared/dist/types/project.d.ts +205 -0
- package/packages/shared/dist/types/project.d.ts.map +1 -0
- package/packages/shared/dist/types/project.js +64 -0
- package/packages/shared/dist/types/project.js.map +1 -0
- package/packages/shared/dist/types/queue.d.ts +94 -0
- package/packages/shared/dist/types/queue.d.ts.map +1 -0
- package/packages/shared/dist/types/queue.js +2 -0
- package/packages/shared/dist/types/queue.js.map +1 -0
- package/packages/shared/dist/types/sdk.d.ts +156 -0
- package/packages/shared/dist/types/sdk.d.ts.map +1 -0
- package/packages/shared/dist/types/sdk.js +13 -0
- package/packages/shared/dist/types/sdk.js.map +1 -0
- package/packages/shared/dist/types/session.d.ts +149 -0
- package/packages/shared/dist/types/session.d.ts.map +1 -0
- package/packages/shared/dist/types/session.js +51 -0
- package/packages/shared/dist/types/session.js.map +1 -0
- package/packages/shared/dist/types/streaming.d.ts +269 -0
- package/packages/shared/dist/types/streaming.d.ts.map +1 -0
- package/packages/shared/dist/types/streaming.js +43 -0
- package/packages/shared/dist/types/streaming.js.map +1 -0
- package/packages/shared/dist/types/terminal.d.ts +93 -0
- package/packages/shared/dist/types/terminal.d.ts.map +1 -0
- package/packages/shared/dist/types/terminal.js +38 -0
- package/packages/shared/dist/types/terminal.js.map +1 -0
- package/packages/shared/dist/types/websocket.d.ts +196 -0
- package/packages/shared/dist/types/websocket.d.ts.map +1 -0
- package/packages/shared/dist/types/websocket.js +7 -0
- package/packages/shared/dist/types/websocket.js.map +1 -0
- package/packages/shared/dist/utils/__tests__/queueParser.test.d.ts +2 -0
- package/packages/shared/dist/utils/__tests__/queueParser.test.d.ts.map +1 -0
- package/packages/shared/dist/utils/__tests__/queueParser.test.js +246 -0
- package/packages/shared/dist/utils/__tests__/queueParser.test.js.map +1 -0
- package/packages/shared/dist/utils/__tests__/queueTemplateUtils.test.d.ts +6 -0
- package/packages/shared/dist/utils/__tests__/queueTemplateUtils.test.d.ts.map +1 -0
- package/packages/shared/dist/utils/__tests__/queueTemplateUtils.test.js +138 -0
- package/packages/shared/dist/utils/__tests__/queueTemplateUtils.test.js.map +1 -0
- package/packages/shared/dist/utils/queueParser.d.ts +3 -0
- package/packages/shared/dist/utils/queueParser.d.ts.map +1 -0
- package/packages/shared/dist/utils/queueParser.js +165 -0
- package/packages/shared/dist/utils/queueParser.js.map +1 -0
- package/packages/shared/dist/utils/queueTemplateUtils.d.ts +17 -0
- package/packages/shared/dist/utils/queueTemplateUtils.d.ts.map +1 -0
- package/packages/shared/dist/utils/queueTemplateUtils.js +65 -0
- package/packages/shared/dist/utils/queueTemplateUtils.js.map +1 -0
- package/packages/shared/package.json +23 -0
- package/scripts/postinstall.cjs +23 -0
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Path Guard Middleware Tests
|
|
3
|
+
* [Source: Story 11.1 - Task 7.1]
|
|
4
|
+
*/
|
|
5
|
+
import { describe, it, expect } from 'vitest';
|
|
6
|
+
import path from 'path';
|
|
7
|
+
import { validateProjectPath } from '../pathGuard.js';
|
|
8
|
+
const PROJECT_ROOT = path.resolve('/tmp/test-project');
|
|
9
|
+
describe('validateProjectPath', () => {
|
|
10
|
+
// TC-PG1: Normal relative path returns resolved absolute path
|
|
11
|
+
it('returns resolved absolute path for valid relative path', () => {
|
|
12
|
+
const result = validateProjectPath(PROJECT_ROOT, 'src/index.ts');
|
|
13
|
+
expect(result).toBe(path.resolve(PROJECT_ROOT, 'src/index.ts'));
|
|
14
|
+
});
|
|
15
|
+
it('allows current directory path', () => {
|
|
16
|
+
const result = validateProjectPath(PROJECT_ROOT, '.');
|
|
17
|
+
expect(result).toBe(path.resolve(PROJECT_ROOT));
|
|
18
|
+
});
|
|
19
|
+
it('allows nested paths within project root', () => {
|
|
20
|
+
const result = validateProjectPath(PROJECT_ROOT, 'src/components/App.tsx');
|
|
21
|
+
expect(result).toBe(path.resolve(PROJECT_ROOT, 'src/components/App.tsx'));
|
|
22
|
+
});
|
|
23
|
+
// TC-PG2: ../ path traversal throws error
|
|
24
|
+
it('throws PATH_TRAVERSAL for ../ traversal', () => {
|
|
25
|
+
try {
|
|
26
|
+
validateProjectPath(PROJECT_ROOT, '../etc/passwd');
|
|
27
|
+
expect.fail('Should have thrown');
|
|
28
|
+
}
|
|
29
|
+
catch (error) {
|
|
30
|
+
expect(error.code).toBe('PATH_TRAVERSAL');
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
// TC-PG3: Absolute paths throw error
|
|
34
|
+
it('throws PATH_TRAVERSAL for Unix absolute path', () => {
|
|
35
|
+
try {
|
|
36
|
+
validateProjectPath(PROJECT_ROOT, '/etc/passwd');
|
|
37
|
+
expect.fail('Should have thrown');
|
|
38
|
+
}
|
|
39
|
+
catch (error) {
|
|
40
|
+
expect(error.code).toBe('PATH_TRAVERSAL');
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
it('throws PATH_TRAVERSAL for Windows absolute path', () => {
|
|
44
|
+
try {
|
|
45
|
+
validateProjectPath(PROJECT_ROOT, 'C:\\Windows\\System32');
|
|
46
|
+
expect.fail('Should have thrown');
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
expect(error.code).toBe('PATH_TRAVERSAL');
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
// TC-PG4: Null byte throws error
|
|
53
|
+
it('throws PATH_TRAVERSAL for path with null byte', () => {
|
|
54
|
+
try {
|
|
55
|
+
validateProjectPath(PROJECT_ROOT, 'src/index.ts\0.html');
|
|
56
|
+
expect.fail('Should have thrown');
|
|
57
|
+
}
|
|
58
|
+
catch (error) {
|
|
59
|
+
expect(error.code).toBe('PATH_TRAVERSAL');
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
// TC-PG5: Nested traversal throws error
|
|
63
|
+
it('throws PATH_TRAVERSAL for nested traversal (foo/../../etc/passwd)', () => {
|
|
64
|
+
try {
|
|
65
|
+
validateProjectPath(PROJECT_ROOT, 'foo/../../etc/passwd');
|
|
66
|
+
expect.fail('Should have thrown');
|
|
67
|
+
}
|
|
68
|
+
catch (error) {
|
|
69
|
+
expect(error.code).toBe('PATH_TRAVERSAL');
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
//# sourceMappingURL=pathGuard.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathGuard.test.js","sourceRoot":"","sources":["../../../src/middleware/__tests__/pathGuard.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.test.d.ts","sourceRoot":"","sources":["../../../src/middleware/__tests__/session.test.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Session Middleware Tests
|
|
3
|
+
* [Source: Story 2.3 - Task 9, Story 2.4 - Task 2]
|
|
4
|
+
*/
|
|
5
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
6
|
+
import { createSessionMiddleware, THIRTY_DAYS_MS } from '../session';
|
|
7
|
+
// Mock AuthConfigService
|
|
8
|
+
vi.mock('../../services/authConfigService', () => ({
|
|
9
|
+
AuthConfigService: vi.fn().mockImplementation(() => ({
|
|
10
|
+
getSessionSecret: vi.fn().mockResolvedValue('mock-session-secret'),
|
|
11
|
+
})),
|
|
12
|
+
}));
|
|
13
|
+
describe('session middleware', () => {
|
|
14
|
+
beforeEach(() => {
|
|
15
|
+
vi.clearAllMocks();
|
|
16
|
+
});
|
|
17
|
+
describe('configuration', () => {
|
|
18
|
+
it('[HIGH] should have default maxAge of 30 days', () => {
|
|
19
|
+
expect(THIRTY_DAYS_MS).toBe(30 * 24 * 60 * 60 * 1000);
|
|
20
|
+
});
|
|
21
|
+
it('[HIGH] should create async session middleware', async () => {
|
|
22
|
+
const middleware = await createSessionMiddleware();
|
|
23
|
+
expect(typeof middleware).toBe('function');
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
describe('THIRTY_DAYS_MS constant', () => {
|
|
27
|
+
it('should be exported and equal to 30 days in milliseconds', () => {
|
|
28
|
+
const expectedMs = 30 * 24 * 60 * 60 * 1000;
|
|
29
|
+
expect(THIRTY_DAYS_MS).toBe(expectedMs);
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
//# sourceMappingURL=session.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.test.js","sourceRoot":"","sources":["../../../src/middleware/__tests__/session.test.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAC9D,OAAO,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAErE,yBAAyB;AACzB,EAAE,CAAC,IAAI,CAAC,kCAAkC,EAAE,GAAG,EAAE,CAAC,CAAC;IACjD,iBAAiB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAG,EAAE,CAAC,CAAC;QACnD,gBAAgB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,qBAAqB,CAAC;KACnE,CAAC,CAAC;CACJ,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,UAAU,CAAC,GAAG,EAAE;QACd,EAAE,CAAC,aAAa,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;QAC7B,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;YACtD,MAAM,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;YAC7D,MAAM,UAAU,GAAG,MAAM,uBAAuB,EAAE,CAAC;YACnD,MAAM,CAAC,OAAO,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACvC,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;YACjE,MAAM,UAAU,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;YAC5C,MAAM,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Authentication Middleware
|
|
3
|
+
* Validates session authentication for protected routes
|
|
4
|
+
* [Source: Story 2.5 - Task 1, 2]
|
|
5
|
+
*/
|
|
6
|
+
import { Request, Response, NextFunction } from 'express';
|
|
7
|
+
/**
|
|
8
|
+
* API request authentication middleware
|
|
9
|
+
* Checks session cookie authenticated state
|
|
10
|
+
*/
|
|
11
|
+
export declare function authMiddleware(req: Request, res: Response, next: NextFunction): void;
|
|
12
|
+
/**
|
|
13
|
+
* Authentication middleware with route exclusions
|
|
14
|
+
* Skips authentication for public routes and static files
|
|
15
|
+
* [Source: Story 2.5 - Task 2]
|
|
16
|
+
*/
|
|
17
|
+
export declare function authMiddlewareWithExclusions(req: Request, res: Response, next: NextFunction): void;
|
|
18
|
+
//# sourceMappingURL=auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/middleware/auth.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAa1D;;;GAGG;AACH,wBAAgB,cAAc,CAC5B,GAAG,EAAE,OAAO,EACZ,GAAG,EAAE,QAAQ,EACb,IAAI,EAAE,YAAY,GACjB,IAAI,CAWN;AAED;;;;GAIG;AACH,wBAAgB,4BAA4B,CAC1C,GAAG,EAAE,OAAO,EACZ,GAAG,EAAE,QAAQ,EACb,IAAI,EAAE,YAAY,GACjB,IAAI,CAkBN"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Authentication Middleware
|
|
3
|
+
* Validates session authentication for protected routes
|
|
4
|
+
* [Source: Story 2.5 - Task 1, 2]
|
|
5
|
+
*/
|
|
6
|
+
import { AUTH_ERROR_CODES, AUTH_ERROR_MESSAGES } from '@hammoc/shared';
|
|
7
|
+
/**
|
|
8
|
+
* Public routes that don't require authentication (AC4)
|
|
9
|
+
*/
|
|
10
|
+
const PUBLIC_ROUTES = [
|
|
11
|
+
'/api/auth/login',
|
|
12
|
+
'/api/auth/status',
|
|
13
|
+
'/api/auth/setup',
|
|
14
|
+
'/api/health',
|
|
15
|
+
];
|
|
16
|
+
/**
|
|
17
|
+
* API request authentication middleware
|
|
18
|
+
* Checks session cookie authenticated state
|
|
19
|
+
*/
|
|
20
|
+
export function authMiddleware(req, res, next) {
|
|
21
|
+
if (req.session?.authenticated) {
|
|
22
|
+
return next();
|
|
23
|
+
}
|
|
24
|
+
res.status(401).json({
|
|
25
|
+
error: {
|
|
26
|
+
code: AUTH_ERROR_CODES.UNAUTHORIZED,
|
|
27
|
+
message: AUTH_ERROR_MESSAGES.UNAUTHORIZED,
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Authentication middleware with route exclusions
|
|
33
|
+
* Skips authentication for public routes and static files
|
|
34
|
+
* [Source: Story 2.5 - Task 2]
|
|
35
|
+
*/
|
|
36
|
+
export function authMiddlewareWithExclusions(req, res, next) {
|
|
37
|
+
// CORS preflight (OPTIONS) requests are handled by cors middleware before auth
|
|
38
|
+
// Note: cors middleware is applied before auth middleware in the middleware chain
|
|
39
|
+
if (req.method === 'OPTIONS') {
|
|
40
|
+
return next();
|
|
41
|
+
}
|
|
42
|
+
// Public routes skip authentication
|
|
43
|
+
if (PUBLIC_ROUTES.some((route) => req.path === route)) {
|
|
44
|
+
return next();
|
|
45
|
+
}
|
|
46
|
+
// Static files skip authentication (non-api paths) (AC5)
|
|
47
|
+
if (!req.path.startsWith('/api/')) {
|
|
48
|
+
return next();
|
|
49
|
+
}
|
|
50
|
+
return authMiddleware(req, res, next);
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/middleware/auth.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAEvE;;GAEG;AACH,MAAM,aAAa,GAAG;IACpB,iBAAiB;IACjB,kBAAkB;IAClB,iBAAiB;IACjB,aAAa;CACd,CAAC;AAEF;;;GAGG;AACH,MAAM,UAAU,cAAc,CAC5B,GAAY,EACZ,GAAa,EACb,IAAkB;IAElB,IAAI,GAAG,CAAC,OAAO,EAAE,aAAa,EAAE,CAAC;QAC/B,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;QACnB,KAAK,EAAE;YACL,IAAI,EAAE,gBAAgB,CAAC,YAAY;YACnC,OAAO,EAAE,mBAAmB,CAAC,YAAY;SAC1C;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,4BAA4B,CAC1C,GAAY,EACZ,GAAa,EACb,IAAkB;IAElB,+EAA+E;IAC/E,kFAAkF;IAClF,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,oCAAoC;IACpC,IAAI,aAAa,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;QACtD,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,yDAAyD;IACzD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAClC,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,OAAO,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Server i18n Middleware (Epic 22 - Story 22.1, 22.3)
|
|
3
|
+
* Determines request language using priority:
|
|
4
|
+
* (1) user preference from preferencesService → (2) Accept-Language header → (3) 'en' fallback
|
|
5
|
+
* Attaches req.t (translation function) and req.language to the request.
|
|
6
|
+
*/
|
|
7
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
8
|
+
declare module 'express' {
|
|
9
|
+
interface Request {
|
|
10
|
+
t?: (key: string, options?: Record<string, unknown>) => string;
|
|
11
|
+
language?: string;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export declare function i18nMiddleware(req: Request, _res: Response, next: NextFunction): Promise<void>;
|
|
15
|
+
/** Reset the preference cache (e.g., after language preference changes) */
|
|
16
|
+
export declare function invalidateI18nCache(): void;
|
|
17
|
+
//# sourceMappingURL=i18n.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"i18n.d.ts","sourceRoot":"","sources":["../../src/middleware/i18n.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAK/D,OAAO,QAAQ,SAAS,CAAC;IACvB,UAAU,OAAO;QACf,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,MAAM,CAAC;QAC/D,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB;CACF;AAOD,wBAAsB,cAAc,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAuBpG;AAED,2EAA2E;AAC3E,wBAAgB,mBAAmB,IAAI,IAAI,CAE1C"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Server i18n Middleware (Epic 22 - Story 22.1, 22.3)
|
|
3
|
+
* Determines request language using priority:
|
|
4
|
+
* (1) user preference from preferencesService → (2) Accept-Language header → (3) 'en' fallback
|
|
5
|
+
* Attaches req.t (translation function) and req.language to the request.
|
|
6
|
+
*/
|
|
7
|
+
import i18next from '../i18n.js';
|
|
8
|
+
import { SUPPORTED_LANGUAGES } from '@hammoc/shared';
|
|
9
|
+
import { preferencesService } from '../services/preferencesService.js';
|
|
10
|
+
// In-memory cache for language preference (avoids disk I/O on every request)
|
|
11
|
+
let cachedPrefLang = null;
|
|
12
|
+
let cacheTimestamp = 0;
|
|
13
|
+
const CACHE_TTL_MS = 30_000; // 30 seconds
|
|
14
|
+
export async function i18nMiddleware(req, _res, next) {
|
|
15
|
+
try {
|
|
16
|
+
const now = Date.now();
|
|
17
|
+
if (now - cacheTimestamp > CACHE_TTL_MS) {
|
|
18
|
+
const prefs = await preferencesService.readPreferences();
|
|
19
|
+
cachedPrefLang = prefs.language && SUPPORTED_LANGUAGES.includes(prefs.language)
|
|
20
|
+
? prefs.language
|
|
21
|
+
: null;
|
|
22
|
+
cacheTimestamp = now;
|
|
23
|
+
}
|
|
24
|
+
const headerLang = req.acceptsLanguages([...SUPPORTED_LANGUAGES]);
|
|
25
|
+
const lang = cachedPrefLang || headerLang || 'en';
|
|
26
|
+
req.t = i18next.getFixedT(lang);
|
|
27
|
+
req.language = lang;
|
|
28
|
+
}
|
|
29
|
+
catch {
|
|
30
|
+
// Fallback: try Accept-Language before hard-coding 'en'
|
|
31
|
+
const headerLang = req.acceptsLanguages([...SUPPORTED_LANGUAGES]);
|
|
32
|
+
const lang = headerLang || 'en';
|
|
33
|
+
req.t = i18next.getFixedT(lang);
|
|
34
|
+
req.language = lang;
|
|
35
|
+
}
|
|
36
|
+
next();
|
|
37
|
+
}
|
|
38
|
+
/** Reset the preference cache (e.g., after language preference changes) */
|
|
39
|
+
export function invalidateI18nCache() {
|
|
40
|
+
cacheTimestamp = 0;
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=i18n.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"i18n.js","sourceRoot":"","sources":["../../src/middleware/i18n.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,OAAO,MAAM,YAAY,CAAC;AACjC,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AASvE,6EAA6E;AAC7E,IAAI,cAAc,GAAkB,IAAI,CAAC;AACzC,IAAI,cAAc,GAAG,CAAC,CAAC;AACvB,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,aAAa;AAE1C,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,GAAY,EAAE,IAAc,EAAE,IAAkB;IACnF,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,GAAG,GAAG,cAAc,GAAG,YAAY,EAAE,CAAC;YACxC,MAAM,KAAK,GAAG,MAAM,kBAAkB,CAAC,eAAe,EAAE,CAAC;YACzD,cAAc,GAAG,KAAK,CAAC,QAAQ,IAAI,mBAAmB,CAAC,QAAQ,CAAC,KAAK,CAAC,QAA8C,CAAC;gBACnH,CAAC,CAAC,KAAK,CAAC,QAAQ;gBAChB,CAAC,CAAC,IAAI,CAAC;YACT,cAAc,GAAG,GAAG,CAAC;QACvB,CAAC;QACD,MAAM,UAAU,GAAG,GAAG,CAAC,gBAAgB,CAAC,CAAC,GAAG,mBAAmB,CAAC,CAAC,CAAC;QAClE,MAAM,IAAI,GAAG,cAAc,IAAK,UAAqB,IAAI,IAAI,CAAC;QAE9D,GAAG,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAChC,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC;IACtB,CAAC;IAAC,MAAM,CAAC;QACP,wDAAwD;QACxD,MAAM,UAAU,GAAG,GAAG,CAAC,gBAAgB,CAAC,CAAC,GAAG,mBAAmB,CAAC,CAAC,CAAC;QAClE,MAAM,IAAI,GAAI,UAAqB,IAAI,IAAI,CAAC;QAC5C,GAAG,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAChC,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC;IACtB,CAAC;IACD,IAAI,EAAE,CAAC;AACT,CAAC;AAED,2EAA2E;AAC3E,MAAM,UAAU,mBAAmB;IACjC,cAAc,GAAG,CAAC,CAAC;AACrB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Path Guard Middleware
|
|
3
|
+
* Validates that requested paths stay within the project root.
|
|
4
|
+
* Prevents path traversal attacks for file system API endpoints.
|
|
5
|
+
* [Source: Story 11.1 - Task 2]
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Validates that the requested path stays within the project root.
|
|
9
|
+
* Throws error with code 'PATH_TRAVERSAL' if validation fails.
|
|
10
|
+
* @param projectRoot Absolute path to the project root directory
|
|
11
|
+
* @param requestedPath Relative path requested by the client
|
|
12
|
+
* @returns Resolved absolute path
|
|
13
|
+
*/
|
|
14
|
+
export declare function validateProjectPath(projectRoot: string, requestedPath: string): string;
|
|
15
|
+
//# sourceMappingURL=pathGuard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathGuard.d.ts","sourceRoot":"","sources":["../../src/middleware/pathGuard.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH;;;;;;GAMG;AACH,wBAAgB,mBAAmB,CAAC,WAAW,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,MAAM,CA8BtF"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Path Guard Middleware
|
|
3
|
+
* Validates that requested paths stay within the project root.
|
|
4
|
+
* Prevents path traversal attacks for file system API endpoints.
|
|
5
|
+
* [Source: Story 11.1 - Task 2]
|
|
6
|
+
*/
|
|
7
|
+
import path from 'path';
|
|
8
|
+
/**
|
|
9
|
+
* Validates that the requested path stays within the project root.
|
|
10
|
+
* Throws error with code 'PATH_TRAVERSAL' if validation fails.
|
|
11
|
+
* @param projectRoot Absolute path to the project root directory
|
|
12
|
+
* @param requestedPath Relative path requested by the client
|
|
13
|
+
* @returns Resolved absolute path
|
|
14
|
+
*/
|
|
15
|
+
export function validateProjectPath(projectRoot, requestedPath) {
|
|
16
|
+
// 1. Null byte check
|
|
17
|
+
if (requestedPath.includes('\0')) {
|
|
18
|
+
const err = new Error('Invalid path: null byte detected');
|
|
19
|
+
err.code = 'PATH_TRAVERSAL';
|
|
20
|
+
throw err;
|
|
21
|
+
}
|
|
22
|
+
// 2. Block absolute paths (Unix: /, Windows: C:\, \\UNC)
|
|
23
|
+
if (path.isAbsolute(requestedPath)) {
|
|
24
|
+
const err = new Error('Invalid path: absolute paths are not allowed');
|
|
25
|
+
err.code = 'PATH_TRAVERSAL';
|
|
26
|
+
throw err;
|
|
27
|
+
}
|
|
28
|
+
// 3. Resolve the full path
|
|
29
|
+
const resolvedPath = path.resolve(projectRoot, requestedPath);
|
|
30
|
+
// 4. Ensure resolved path is within projectRoot
|
|
31
|
+
const normalizedRoot = path.resolve(projectRoot) + path.sep;
|
|
32
|
+
const normalizedResolved = path.resolve(resolvedPath);
|
|
33
|
+
// Allow exact match (root itself) or child paths
|
|
34
|
+
if (normalizedResolved !== path.resolve(projectRoot) && !normalizedResolved.startsWith(normalizedRoot)) {
|
|
35
|
+
const err = new Error('Invalid path: path traversal detected');
|
|
36
|
+
err.code = 'PATH_TRAVERSAL';
|
|
37
|
+
throw err;
|
|
38
|
+
}
|
|
39
|
+
return resolvedPath;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=pathGuard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathGuard.js","sourceRoot":"","sources":["../../src/middleware/pathGuard.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB;;;;;;GAMG;AACH,MAAM,UAAU,mBAAmB,CAAC,WAAmB,EAAE,aAAqB;IAC5E,qBAAqB;IACrB,IAAI,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACjC,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;QACzD,GAA6B,CAAC,IAAI,GAAG,gBAAgB,CAAC;QACvD,MAAM,GAAG,CAAC;IACZ,CAAC;IAED,yDAAyD;IACzD,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;QACnC,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;QACrE,GAA6B,CAAC,IAAI,GAAG,gBAAgB,CAAC;QACvD,MAAM,GAAG,CAAC;IACZ,CAAC;IAED,2BAA2B;IAC3B,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;IAE9D,gDAAgD;IAChD,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC;IAC5D,MAAM,kBAAkB,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;IAEtD,iDAAiD;IACjD,IAAI,kBAAkB,KAAK,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,CAAC;QACvG,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;QAC9D,GAA6B,CAAC,IAAI,GAAG,gBAAgB,CAAC;QACvD,MAAM,GAAG,CAAC;IACZ,CAAC;IAED,OAAO,YAAY,CAAC;AACtB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Session Middleware
|
|
3
|
+
* cookie-session configuration for authentication
|
|
4
|
+
* [Source: Story 2.2 - Task 4, Story 2.3 - Task 2, Story 2.4 - Task 2]
|
|
5
|
+
*/
|
|
6
|
+
import { RequestHandler } from 'express';
|
|
7
|
+
export declare const THIRTY_DAYS_MS: number;
|
|
8
|
+
/**
|
|
9
|
+
* Create session middleware with persisted secret
|
|
10
|
+
* [Source: Story 2.4 - Task 2]
|
|
11
|
+
*
|
|
12
|
+
* @note cookie-session maxAge behavior:
|
|
13
|
+
* - maxAge: number → expires after that many milliseconds
|
|
14
|
+
* - maxAge: undefined → session cookie (expires on browser close)
|
|
15
|
+
* - maxAge: 0 → immediate expiration (deletes cookie) - DO NOT USE!
|
|
16
|
+
*/
|
|
17
|
+
export declare function createSessionMiddleware(): Promise<RequestHandler>;
|
|
18
|
+
//# sourceMappingURL=session.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../src/middleware/session.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAGzC,eAAO,MAAM,cAAc,QAA2B,CAAC;AAEvD;;;;;;;;GAQG;AACH,wBAAsB,uBAAuB,IAAI,OAAO,CAAC,cAAc,CAAC,CAkBvE"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Session Middleware
|
|
3
|
+
* cookie-session configuration for authentication
|
|
4
|
+
* [Source: Story 2.2 - Task 4, Story 2.3 - Task 2, Story 2.4 - Task 2]
|
|
5
|
+
*/
|
|
6
|
+
import cookieSession from 'cookie-session';
|
|
7
|
+
import { AuthConfigService } from '../services/authConfigService.js';
|
|
8
|
+
export const THIRTY_DAYS_MS = 30 * 24 * 60 * 60 * 1000;
|
|
9
|
+
/**
|
|
10
|
+
* Create session middleware with persisted secret
|
|
11
|
+
* [Source: Story 2.4 - Task 2]
|
|
12
|
+
*
|
|
13
|
+
* @note cookie-session maxAge behavior:
|
|
14
|
+
* - maxAge: number → expires after that many milliseconds
|
|
15
|
+
* - maxAge: undefined → session cookie (expires on browser close)
|
|
16
|
+
* - maxAge: 0 → immediate expiration (deletes cookie) - DO NOT USE!
|
|
17
|
+
*/
|
|
18
|
+
export async function createSessionMiddleware() {
|
|
19
|
+
const authConfig = new AuthConfigService();
|
|
20
|
+
const secret = await authConfig.getSessionSecret();
|
|
21
|
+
// Use environment-specific cookie name to prevent session conflicts
|
|
22
|
+
// when running multiple instances on same hostname (different ports)
|
|
23
|
+
const cookieName = process.env.NODE_ENV === 'production'
|
|
24
|
+
? 'bmad-session'
|
|
25
|
+
: `bmad-session-${process.env.PORT || '3000'}`;
|
|
26
|
+
return cookieSession({
|
|
27
|
+
name: cookieName,
|
|
28
|
+
keys: [secret],
|
|
29
|
+
maxAge: THIRTY_DAYS_MS,
|
|
30
|
+
httpOnly: true,
|
|
31
|
+
sameSite: 'lax',
|
|
32
|
+
secure: false, // localhost only
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=session.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.js","sourceRoot":"","sources":["../../src/middleware/session.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,aAAa,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,MAAM,CAAC,MAAM,cAAc,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;AAEvD;;;;;;;;GAQG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB;IAC3C,MAAM,UAAU,GAAG,IAAI,iBAAiB,EAAE,CAAC;IAC3C,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,gBAAgB,EAAE,CAAC;IAEnD,oEAAoE;IACpE,qEAAqE;IACrE,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY;QACtD,CAAC,CAAC,cAAc;QAChB,CAAC,CAAC,gBAAgB,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,MAAM,EAAE,CAAC;IAEjD,OAAO,aAAa,CAAC;QACnB,IAAI,EAAE,UAAU;QAChB,IAAI,EAAE,CAAC,MAAM,CAAC;QACd,MAAM,EAAE,cAAc;QACtB,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,KAAK;QACf,MAAM,EAAE,KAAK,EAAE,iBAAiB;KACjC,CAA8B,CAAC;AAClC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.integration.test.d.ts","sourceRoot":"","sources":["../../../src/routes/__tests__/auth.integration.test.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Auth Integration Tests
|
|
3
|
+
* [Source: Story 2.5 - Task 7]
|
|
4
|
+
*/
|
|
5
|
+
import { describe, it, expect, vi, beforeAll, afterAll } from 'vitest';
|
|
6
|
+
import request from 'supertest';
|
|
7
|
+
// Mock AuthConfigService before importing app
|
|
8
|
+
vi.mock('../../services/authConfigService.js', () => ({
|
|
9
|
+
AuthConfigService: vi.fn().mockImplementation(() => ({
|
|
10
|
+
getSessionSecret: vi.fn().mockResolvedValue('test-secret-key-for-integration-tests'),
|
|
11
|
+
verifyPassword: vi.fn().mockResolvedValue(true),
|
|
12
|
+
})),
|
|
13
|
+
}));
|
|
14
|
+
// Mock rateLimiter
|
|
15
|
+
vi.mock('../../services/rateLimiter.js', () => ({
|
|
16
|
+
rateLimiter: {
|
|
17
|
+
canAttempt: vi.fn().mockReturnValue({ allowed: true }),
|
|
18
|
+
recordFailure: vi.fn(),
|
|
19
|
+
reset: vi.fn(),
|
|
20
|
+
},
|
|
21
|
+
}));
|
|
22
|
+
import { createApp } from '../../app.js';
|
|
23
|
+
describe('Auth Integration Tests', () => {
|
|
24
|
+
let app;
|
|
25
|
+
beforeAll(async () => {
|
|
26
|
+
app = await createApp();
|
|
27
|
+
});
|
|
28
|
+
afterAll(() => {
|
|
29
|
+
vi.clearAllMocks();
|
|
30
|
+
});
|
|
31
|
+
describe('Public Routes (AC4)', () => {
|
|
32
|
+
it('[HIGH] GET /api/auth/status - accessible without auth, returns authenticated: false', async () => {
|
|
33
|
+
const response = await request(app)
|
|
34
|
+
.get('/api/auth/status')
|
|
35
|
+
.expect(200);
|
|
36
|
+
expect(response.body).toEqual({ authenticated: false });
|
|
37
|
+
});
|
|
38
|
+
it('[HIGH] GET /api/health - accessible without auth', async () => {
|
|
39
|
+
const response = await request(app)
|
|
40
|
+
.get('/api/health')
|
|
41
|
+
.expect(200);
|
|
42
|
+
expect(response.body.status).toBe('healthy');
|
|
43
|
+
});
|
|
44
|
+
it('[MEDIUM] POST /api/auth/login - accessible without auth', async () => {
|
|
45
|
+
const response = await request(app)
|
|
46
|
+
.post('/api/auth/login')
|
|
47
|
+
.send({ password: 'test-password' })
|
|
48
|
+
.expect(200);
|
|
49
|
+
expect(response.body.success).toBe(true);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
describe('Protected Routes (AC1)', () => {
|
|
53
|
+
it('[HIGH] GET /api/cli-status - returns 401 without auth', async () => {
|
|
54
|
+
const response = await request(app)
|
|
55
|
+
.get('/api/cli-status')
|
|
56
|
+
.expect(401);
|
|
57
|
+
expect(response.body.error.code).toBe('UNAUTHORIZED');
|
|
58
|
+
expect(response.body.error.message).toBe('Authentication required');
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
describe('CORS Preflight (OPTIONS)', () => {
|
|
62
|
+
it('[MEDIUM] OPTIONS /api/cli-status - passes without auth', async () => {
|
|
63
|
+
const response = await request(app)
|
|
64
|
+
.options('/api/cli-status')
|
|
65
|
+
.set('Origin', 'http://localhost:5173')
|
|
66
|
+
.set('Access-Control-Request-Method', 'GET')
|
|
67
|
+
.expect(204);
|
|
68
|
+
expect(response.headers['access-control-allow-origin']).toBeDefined();
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
describe('Authenticated Access', () => {
|
|
72
|
+
it('[HIGH] GET /api/auth/status after login - returns authenticated: true', async () => {
|
|
73
|
+
const agent = request.agent(app);
|
|
74
|
+
// Login first
|
|
75
|
+
await agent
|
|
76
|
+
.post('/api/auth/login')
|
|
77
|
+
.send({ password: 'test-password' })
|
|
78
|
+
.expect(200);
|
|
79
|
+
// Check status with session cookie
|
|
80
|
+
const response = await agent
|
|
81
|
+
.get('/api/auth/status')
|
|
82
|
+
.expect(200);
|
|
83
|
+
expect(response.body).toEqual({ authenticated: true });
|
|
84
|
+
});
|
|
85
|
+
it('[HIGH] GET /api/cli-status after login - returns 200', async () => {
|
|
86
|
+
const agent = request.agent(app);
|
|
87
|
+
// Login first
|
|
88
|
+
await agent
|
|
89
|
+
.post('/api/auth/login')
|
|
90
|
+
.send({ password: 'test-password' })
|
|
91
|
+
.expect(200);
|
|
92
|
+
// Access protected route with session cookie
|
|
93
|
+
const response = await agent
|
|
94
|
+
.get('/api/cli-status')
|
|
95
|
+
.expect(200);
|
|
96
|
+
expect(response.body).toBeDefined();
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
describe('Static Files (AC5)', () => {
|
|
100
|
+
it('[HIGH] non-API paths skip authentication', async () => {
|
|
101
|
+
// Static file paths that don't start with /api/ should not return 401
|
|
102
|
+
// Note: actual static files may not exist in test environment
|
|
103
|
+
// We're testing that the middleware doesn't block, not that files are served
|
|
104
|
+
const response = await request(app)
|
|
105
|
+
.get('/some-static-path.js');
|
|
106
|
+
// Should not be 401 (may be 404 if file doesn't exist, which is fine)
|
|
107
|
+
expect(response.status).not.toBe(401);
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
//# sourceMappingURL=auth.integration.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.integration.test.js","sourceRoot":"","sources":["../../../src/routes/__tests__/auth.integration.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.test.d.ts","sourceRoot":"","sources":["../../../src/routes/__tests__/auth.test.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|