@selvajs/selva 2.0.0 → 2.0.2
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/build/client/.!34937!selva_example_0_1_0.gh +0 -0
- package/build/client/_app/immutable/assets/0.B0phAlf7.css.gz +0 -0
- package/build/client/_app/immutable/assets/20.5bKkcx-V.css +1 -0
- package/build/client/_app/immutable/assets/20.5bKkcx-V.css.br +0 -0
- package/build/client/_app/immutable/assets/20.5bKkcx-V.css.gz +0 -0
- package/build/client/_app/immutable/assets/index.CV-KWLNP.css.gz +0 -0
- package/build/client/_app/immutable/chunks/1s2jTHrf.js.gz +0 -0
- package/build/client/_app/immutable/chunks/2XlIPTRw.js.gz +0 -0
- package/build/client/_app/immutable/chunks/2_FEXmq1.js.gz +0 -0
- package/build/client/_app/immutable/chunks/2dX6Wjni.js.gz +0 -0
- package/build/client/_app/immutable/chunks/4tskcAVN.js.gz +0 -0
- package/build/client/_app/immutable/chunks/AEyooZaf.js.gz +0 -0
- package/build/client/_app/immutable/chunks/B1aRL9Hz.js.gz +0 -0
- package/build/client/_app/immutable/chunks/B8uG8z2c.js.gz +0 -0
- package/build/client/_app/immutable/chunks/B8zY50Bc.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BCse3N0b.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BGxzXVpM.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BM4_iXSA.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BMGykAfL.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BNScKugQ.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BNzEBMy8.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BU9URCkw.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BW4xleRz.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BZmrLQwT.js.gz +0 -0
- package/build/client/_app/immutable/chunks/B_Lmgh7q.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BapAUJpM.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bb9xebuT.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BjkQG7dw.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bmz9gLBz.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bnpwcepm.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BoR6OKl6.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Br5bpmJC.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BxCHY0iG.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{ChSMnQMB.js → C-pNJcZ1.js} +1 -1
- package/build/client/_app/immutable/chunks/C-pNJcZ1.js.br +0 -0
- package/build/client/_app/immutable/chunks/C-pNJcZ1.js.gz +0 -0
- package/build/client/_app/immutable/chunks/C1Sz0rtw.js.gz +0 -0
- package/build/client/_app/immutable/chunks/C1aQuqo_.js.gz +0 -0
- package/build/client/_app/immutable/chunks/C26nmevH.js.gz +0 -0
- package/build/client/_app/immutable/chunks/C8ko2SLk.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CAMhfNhW.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CEnIp_6Y.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CMjc_m7Z.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CRRzXoPz.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CXh1ITwj.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CZ1oTCKP.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Cbu9Tg11.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CcYNc8-G.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Cdcajer6.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Ce2MupFq.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CfP1DoGT.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CfhPDo21.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CkW8YtSm.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CoR7xVWs.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CpGv0MSX.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{D7PHp8xb.js → CqdlMl9v.js} +1 -1
- package/build/client/_app/immutable/chunks/CqdlMl9v.js.br +0 -0
- package/build/client/_app/immutable/chunks/CqdlMl9v.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{4y4xLOS_.js → Cvkx15k5.js} +1 -1
- package/build/client/_app/immutable/chunks/Cvkx15k5.js.br +0 -0
- package/build/client/_app/immutable/chunks/Cvkx15k5.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Cvr8AlQE.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D0QMYypb.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D40b34QZ.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D6MI_dhi.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D7l1JayF.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D99uXqZb.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DEBBEmC0.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DNsLImlA.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DRDjLZb3.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DTJeGfAL.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DZFqETAQ.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D_wr-JLf.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Dl4WTuMB.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Doks8ISn.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DsnmJJEf.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{DdaJZmuM.js → Dw1n4e1Z.js} +1 -1
- package/build/client/_app/immutable/chunks/Dw1n4e1Z.js.br +0 -0
- package/build/client/_app/immutable/chunks/Dw1n4e1Z.js.gz +0 -0
- package/build/client/_app/immutable/chunks/E3yOQTT0.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Gxlzmh6y.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Ib-7xmHT.js.gz +0 -0
- package/build/client/_app/immutable/chunks/P4Np3c9O.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Zf7VV5ZB.js.gz +0 -0
- package/build/client/_app/immutable/chunks/_OLpdTiI.js.gz +0 -0
- package/build/client/_app/immutable/chunks/azBeeLR0.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{DHWrMZkd.js → ej-X2XiW.js} +1 -1
- package/build/client/_app/immutable/chunks/ej-X2XiW.js.br +0 -0
- package/build/client/_app/immutable/chunks/ej-X2XiW.js.gz +0 -0
- package/build/client/_app/immutable/chunks/gMllmzma.js.gz +0 -0
- package/build/client/_app/immutable/chunks/hRoV10UM.js.gz +0 -0
- package/build/client/_app/immutable/chunks/iEBlyxZv.js.gz +0 -0
- package/build/client/_app/immutable/chunks/jFKgkeON.js.gz +0 -0
- package/build/client/_app/immutable/chunks/ooPBmYPj.js.gz +0 -0
- package/build/client/_app/immutable/chunks/pRg-f8xU.js.gz +0 -0
- package/build/client/_app/immutable/chunks/uINs3xv3.js.gz +0 -0
- package/build/client/_app/immutable/chunks/wamM80bu.js.gz +0 -0
- package/build/client/_app/immutable/chunks/xe-rGDG8.js +3 -0
- package/build/client/_app/immutable/chunks/xe-rGDG8.js.br +0 -0
- package/build/client/_app/immutable/chunks/xe-rGDG8.js.gz +0 -0
- package/build/client/_app/immutable/entry/{app.CY1cyDxx.js → app.CFLPIelF.js} +2 -2
- package/build/client/_app/immutable/entry/app.CFLPIelF.js.br +0 -0
- package/build/client/_app/immutable/entry/app.CFLPIelF.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.CrhtzCz1.js +1 -0
- package/build/client/_app/immutable/entry/start.CrhtzCz1.js.br +0 -0
- package/build/client/_app/immutable/entry/start.CrhtzCz1.js.gz +0 -0
- package/build/client/_app/immutable/nodes/0.KJ-PiM1c.js +1 -0
- package/build/client/_app/immutable/nodes/0.KJ-PiM1c.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.KJ-PiM1c.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{1.WcE6FOcF.js → 1.B4cNXFZe.js} +1 -1
- package/build/client/_app/immutable/nodes/1.B4cNXFZe.js.br +0 -0
- package/build/client/_app/immutable/nodes/1.B4cNXFZe.js.gz +0 -0
- package/build/client/_app/immutable/nodes/10.C5pTC9MT.js +3 -0
- package/build/client/_app/immutable/nodes/10.C5pTC9MT.js.br +0 -0
- package/build/client/_app/immutable/nodes/10.C5pTC9MT.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{11.kVvSmSNV.js → 11.DO9irQLl.js} +1 -1
- package/build/client/_app/immutable/nodes/11.DO9irQLl.js.br +0 -0
- package/build/client/_app/immutable/nodes/11.DO9irQLl.js.gz +0 -0
- package/build/client/_app/immutable/nodes/12.BoPfAFdi.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{13.JyGUEsdb.js → 13.Cmx49Kub.js} +1 -1
- package/build/client/_app/immutable/nodes/13.Cmx49Kub.js.br +0 -0
- package/build/client/_app/immutable/nodes/13.Cmx49Kub.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{14.BbJglRXt.js → 14.DtWKU29l.js} +1 -1
- package/build/client/_app/immutable/nodes/14.DtWKU29l.js.br +0 -0
- package/build/client/_app/immutable/nodes/14.DtWKU29l.js.gz +0 -0
- package/build/client/_app/immutable/nodes/15.CgB8Kdm8.js +13 -0
- package/build/client/_app/immutable/nodes/15.CgB8Kdm8.js.br +0 -0
- package/build/client/_app/immutable/nodes/15.CgB8Kdm8.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{16.DRADdurD.js → 16.CdiaMjqd.js} +2 -2
- package/build/client/_app/immutable/nodes/16.CdiaMjqd.js.br +0 -0
- package/build/client/_app/immutable/nodes/16.CdiaMjqd.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{17.DOsqdwdd.js → 17.fdmJDdhR.js} +1 -1
- package/build/client/_app/immutable/nodes/17.fdmJDdhR.js.br +0 -0
- package/build/client/_app/immutable/nodes/17.fdmJDdhR.js.gz +0 -0
- package/build/client/_app/immutable/nodes/18.BpVlwZ30.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{19.S2J54AdY.js → 19.CSLP9qPo.js} +1 -1
- package/build/client/_app/immutable/nodes/19.CSLP9qPo.js.br +0 -0
- package/build/client/_app/immutable/nodes/19.CSLP9qPo.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{2.CKVtP2Ky.js → 2.BDo-orPp.js} +1 -1
- package/build/client/_app/immutable/nodes/2.BDo-orPp.js.br +0 -0
- package/build/client/_app/immutable/nodes/2.BDo-orPp.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{20.BCasu2g4.js → 20.vMa5OYGG.js} +6 -6
- package/build/client/_app/immutable/nodes/20.vMa5OYGG.js.br +0 -0
- package/build/client/_app/immutable/nodes/20.vMa5OYGG.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{21.C1aTaoAB.js → 21.BXpF6SCn.js} +1 -1
- package/build/client/_app/immutable/nodes/21.BXpF6SCn.js.br +0 -0
- package/build/client/_app/immutable/nodes/21.BXpF6SCn.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{23.DP5Be3HR.js → 23.sYDue3fB.js} +1 -1
- package/build/client/_app/immutable/nodes/23.sYDue3fB.js.br +0 -0
- package/build/client/_app/immutable/nodes/23.sYDue3fB.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{24.BB6fXxnh.js → 24.CMNCTbEg.js} +1 -1
- package/build/client/_app/immutable/nodes/24.CMNCTbEg.js.br +0 -0
- package/build/client/_app/immutable/nodes/24.CMNCTbEg.js.gz +0 -0
- package/build/client/_app/immutable/nodes/25.oeBaWIUn.js.gz +0 -0
- package/build/client/_app/immutable/nodes/26.lPx5SjN1.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{27.DB7PVQXo.js → 27.Cx5OgRDj.js} +1 -1
- package/build/client/_app/immutable/nodes/27.Cx5OgRDj.js.br +0 -0
- package/build/client/_app/immutable/nodes/27.Cx5OgRDj.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{28.Cf2R7A3f.js → 28.CGYOjnep.js} +1 -1
- package/build/client/_app/immutable/nodes/28.CGYOjnep.js.br +0 -0
- package/build/client/_app/immutable/nodes/28.CGYOjnep.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{29.CyJS5sye.js → 29.CLf8RvpY.js} +1 -1
- package/build/client/_app/immutable/nodes/29.CLf8RvpY.js.br +0 -0
- package/build/client/_app/immutable/nodes/29.CLf8RvpY.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{3.DWyky0UV.js → 3.BlV_x8MJ.js} +1 -1
- package/build/client/_app/immutable/nodes/3.BlV_x8MJ.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.BlV_x8MJ.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{30.BFpYKBJh.js → 30.R_e5369k.js} +1 -1
- package/build/client/_app/immutable/nodes/30.R_e5369k.js.br +0 -0
- package/build/client/_app/immutable/nodes/30.R_e5369k.js.gz +0 -0
- package/build/client/_app/immutable/nodes/31.DKnO7o1W.js.gz +0 -0
- package/build/client/_app/immutable/nodes/32.D4xYDWvG.js.gz +0 -0
- package/build/client/_app/immutable/nodes/4.0a-qdY5B.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{5.BzQBSRbS.js → 5.BkfXGrZY.js} +1 -1
- package/build/client/_app/immutable/nodes/5.BkfXGrZY.js.br +1 -0
- package/build/client/_app/immutable/nodes/5.BkfXGrZY.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{6.gJ2nhxWc.js → 6.CrYuHI6-.js} +1 -1
- package/build/client/_app/immutable/nodes/6.CrYuHI6-.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.CrYuHI6-.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{7.tBTDolnc.js → 7.CMw8RqJb.js} +1 -1
- package/build/client/_app/immutable/nodes/7.CMw8RqJb.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.CMw8RqJb.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{8.BJK9n85D.js → 8.BFOXhEsE.js} +1 -1
- package/build/client/_app/immutable/nodes/8.BFOXhEsE.js.br +0 -0
- package/build/client/_app/immutable/nodes/8.BFOXhEsE.js.gz +0 -0
- package/build/client/_app/immutable/nodes/9.CDfx0uL-.js +1 -0
- package/build/client/_app/immutable/nodes/9.CDfx0uL-.js.br +0 -0
- package/build/client/_app/immutable/nodes/9.CDfx0uL-.js.gz +0 -0
- package/build/client/_app/version.json +1 -1
- package/build/client/_app/version.json.br +0 -0
- package/build/client/_app/version.json.gz +0 -0
- package/build/client/favicon/favicon.svg.gz +0 -0
- package/build/client/robots.txt.gz +0 -0
- package/build/server/chunks/{0-BRU03dEw.js → 0-wC8vebb2.js} +4 -4
- package/build/server/chunks/{0-BRU03dEw.js.map → 0-wC8vebb2.js.map} +1 -1
- package/build/server/chunks/{1-m_oCIIXD.js → 1-BuhU5ws5.js} +2 -2
- package/build/server/chunks/{1-m_oCIIXD.js.map → 1-BuhU5ws5.js.map} +1 -1
- package/build/server/chunks/{10-J_ZMrbXX.js → 10-8FzClb5u.js} +6 -6
- package/build/server/chunks/{10-J_ZMrbXX.js.map → 10-8FzClb5u.js.map} +1 -1
- package/build/server/chunks/{11-Dz77N9MO.js → 11-DDY_rtxo.js} +6 -6
- package/build/server/chunks/{11-Dz77N9MO.js.map → 11-DDY_rtxo.js.map} +1 -1
- package/build/server/chunks/{12-CrOqT0Q5.js → 12-C_P4jkDv.js} +2 -2
- package/build/server/chunks/{12-CrOqT0Q5.js.map → 12-C_P4jkDv.js.map} +1 -1
- package/build/server/chunks/{13-DQGOyx8W.js → 13-B5aiYDRf.js} +3 -3
- package/build/server/chunks/{13-DQGOyx8W.js.map → 13-B5aiYDRf.js.map} +1 -1
- package/build/server/chunks/{14-Dl5jyPyO.js → 14-BaOmOh6D.js} +3 -3
- package/build/server/chunks/{14-Dl5jyPyO.js.map → 14-BaOmOh6D.js.map} +1 -1
- package/build/server/chunks/{15-CNzxJkd-.js → 15-DHGAmNDS.js} +4 -4
- package/build/server/chunks/{15-CNzxJkd-.js.map → 15-DHGAmNDS.js.map} +1 -1
- package/build/server/chunks/{16-5ZcnQNjK.js → 16-CzffXXom.js} +6 -6
- package/build/server/chunks/{16-5ZcnQNjK.js.map → 16-CzffXXom.js.map} +1 -1
- package/build/server/chunks/{17-C4Zpziyd.js → 17-DZkJ_eHV.js} +2 -2
- package/build/server/chunks/{17-C4Zpziyd.js.map → 17-DZkJ_eHV.js.map} +1 -1
- package/build/server/chunks/{18-DFxW4YE_.js → 18-DeVS-pOT.js} +2 -2
- package/build/server/chunks/{18-DFxW4YE_.js.map → 18-DeVS-pOT.js.map} +1 -1
- package/build/server/chunks/{19-C8RtlFzY.js → 19-Dp3tqQ1t.js} +3 -3
- package/build/server/chunks/{19-C8RtlFzY.js.map → 19-Dp3tqQ1t.js.map} +1 -1
- package/build/server/chunks/{2-tPIqsVg3.js → 2-ByzJzwtP.js} +5 -5
- package/build/server/chunks/{2-tPIqsVg3.js.map → 2-ByzJzwtP.js.map} +1 -1
- package/build/server/chunks/{20-DLtIYsB6.js → 20-B0yVR9Gt.js} +12 -12
- package/build/server/chunks/{20-DLtIYsB6.js.map → 20-B0yVR9Gt.js.map} +1 -1
- package/build/server/chunks/{21-Bs7WlXoO.js → 21-C1DQ27EI.js} +3 -3
- package/build/server/chunks/{21-Bs7WlXoO.js.map → 21-C1DQ27EI.js.map} +1 -1
- package/build/server/chunks/{23-dTtOINB8.js → 23-Cu3Wc2EB.js} +6 -6
- package/build/server/chunks/{23-dTtOINB8.js.map → 23-Cu3Wc2EB.js.map} +1 -1
- package/build/server/chunks/{24-DFoVUKXD.js → 24-BT4UP2RT.js} +4 -4
- package/build/server/chunks/{24-DFoVUKXD.js.map → 24-BT4UP2RT.js.map} +1 -1
- package/build/server/chunks/{25-DstWRI72.js → 25-ef6c33Ul.js} +2 -2
- package/build/server/chunks/{25-DstWRI72.js.map → 25-ef6c33Ul.js.map} +1 -1
- package/build/server/chunks/{27-CpQEotb7.js → 27-2TZYrjFq.js} +4 -4
- package/build/server/chunks/{27-CpQEotb7.js.map → 27-2TZYrjFq.js.map} +1 -1
- package/build/server/chunks/{28-B-G5uvxa.js → 28-CgAgC0Z2.js} +3 -3
- package/build/server/chunks/{28-B-G5uvxa.js.map → 28-CgAgC0Z2.js.map} +1 -1
- package/build/server/chunks/{29-BFo4HkLa.js → 29-B5T9cb-n.js} +3 -3
- package/build/server/chunks/{29-BFo4HkLa.js.map → 29-B5T9cb-n.js.map} +1 -1
- package/build/server/chunks/{3-BU-Ucrf8.js → 3-DADb713A.js} +2 -2
- package/build/server/chunks/{3-BU-Ucrf8.js.map → 3-DADb713A.js.map} +1 -1
- package/build/server/chunks/{30-zdVVQ-al.js → 30-DltbcIRy.js} +3 -3
- package/build/server/chunks/{30-zdVVQ-al.js.map → 30-DltbcIRy.js.map} +1 -1
- package/build/server/chunks/{31-Cba3pMW9.js → 31-CirH19D6.js} +2 -2
- package/build/server/chunks/{31-Cba3pMW9.js.map → 31-CirH19D6.js.map} +1 -1
- package/build/server/chunks/{32-BmfoNY4G.js → 32-CZojKYOy.js} +2 -2
- package/build/server/chunks/{32-BmfoNY4G.js.map → 32-CZojKYOy.js.map} +1 -1
- package/build/server/chunks/{5-CsoWfpGS.js → 5-BPpDRjc1.js} +2 -2
- package/build/server/chunks/{5-CsoWfpGS.js.map → 5-BPpDRjc1.js.map} +1 -1
- package/build/server/chunks/{6-D7wR-syA.js → 6-BNfcWbqm.js} +3 -3
- package/build/server/chunks/{6-D7wR-syA.js.map → 6-BNfcWbqm.js.map} +1 -1
- package/build/server/chunks/{7-uEz6AFkY.js → 7-C5iTPe4g.js} +2 -2
- package/build/server/chunks/{7-uEz6AFkY.js.map → 7-C5iTPe4g.js.map} +1 -1
- package/build/server/chunks/{8-BF-aCqND.js → 8-Cw1nSIV4.js} +3 -3
- package/build/server/chunks/{8-BF-aCqND.js.map → 8-Cw1nSIV4.js.map} +1 -1
- package/build/server/chunks/{9-BSxBuZbd.js → 9-6pRErmUa.js} +4 -4
- package/build/server/chunks/{9-BSxBuZbd.js.map → 9-6pRErmUa.js.map} +1 -1
- package/build/server/chunks/{_layout.svelte-Czx3WsTK.js → _layout.svelte-xYAKGoE5.js} +4 -4
- package/build/server/chunks/_layout.svelte-xYAKGoE5.js.map +1 -0
- package/build/server/chunks/{_page.svelte-BO2coOCw.js → _page.svelte-BR8dze-7.js} +14 -14
- package/build/server/chunks/_page.svelte-BR8dze-7.js.map +1 -0
- package/build/server/chunks/{_page.svelte-KapMJV5_.js → _page.svelte-BsU27A26.js} +3 -3
- package/build/server/chunks/_page.svelte-BsU27A26.js.map +1 -0
- package/build/server/chunks/{_page.svelte-5X2iRv32.js → _page.svelte-CaOLJFdL.js} +2 -2
- package/build/server/chunks/_page.svelte-CaOLJFdL.js.map +1 -0
- package/build/server/chunks/{_page.svelte-CGuEBnqj.js → _page.svelte-DG_7CM7u.js} +5 -5
- package/build/server/chunks/_page.svelte-DG_7CM7u.js.map +1 -0
- package/build/server/chunks/{_page.svelte-CX9DKxIH.js → _page.svelte-DS9orYLw.js} +2 -2
- package/build/server/chunks/_page.svelte-DS9orYLw.js.map +1 -0
- package/build/server/chunks/{_server.ts-CmUr8pln.js → _server.ts-1HIleN3S.js} +4 -4
- package/build/server/chunks/{_server.ts-CmUr8pln.js.map → _server.ts-1HIleN3S.js.map} +1 -1
- package/build/server/chunks/{_server.ts-C-XniPo8.js → _server.ts-1nksAmT8.js} +4 -4
- package/build/server/chunks/{_server.ts-C-XniPo8.js.map → _server.ts-1nksAmT8.js.map} +1 -1
- package/build/server/chunks/{_server.ts-7hKc3tb_.js → _server.ts-AE1drj36.js} +4 -4
- package/build/server/chunks/{_server.ts-7hKc3tb_.js.map → _server.ts-AE1drj36.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DBh0rJrm.js → _server.ts-B0gZCMdj.js} +4 -4
- package/build/server/chunks/{_server.ts-DBh0rJrm.js.map → _server.ts-B0gZCMdj.js.map} +1 -1
- package/build/server/chunks/{_server.ts-_NTv7i9z.js → _server.ts-BSoy1Ljl.js} +4 -4
- package/build/server/chunks/{_server.ts-_NTv7i9z.js.map → _server.ts-BSoy1Ljl.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CAcgx11J.js → _server.ts-BTi2idVf.js} +4 -4
- package/build/server/chunks/{_server.ts-CAcgx11J.js.map → _server.ts-BTi2idVf.js.map} +1 -1
- package/build/server/chunks/{_server.ts-D-QkfF2o.js → _server.ts-BYlDwqEg.js} +5 -5
- package/build/server/chunks/{_server.ts-D-QkfF2o.js.map → _server.ts-BYlDwqEg.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CcQbKaET.js → _server.ts-BbzbsVfr.js} +4 -4
- package/build/server/chunks/{_server.ts-CcQbKaET.js.map → _server.ts-BbzbsVfr.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BLHjzdRp.js → _server.ts-BdKZ7aOG.js} +4 -4
- package/build/server/chunks/{_server.ts-BLHjzdRp.js.map → _server.ts-BdKZ7aOG.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BpkR7TzP.js → _server.ts-BgsmlYb6.js} +3 -3
- package/build/server/chunks/{_server.ts-BpkR7TzP.js.map → _server.ts-BgsmlYb6.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BUc1sqlR.js → _server.ts-BnN8EQwQ.js} +4 -4
- package/build/server/chunks/{_server.ts-BUc1sqlR.js.map → _server.ts-BnN8EQwQ.js.map} +1 -1
- package/build/server/chunks/{_server.ts-pDmNGXOa.js → _server.ts-ByhZiyPJ.js} +4 -4
- package/build/server/chunks/{_server.ts-pDmNGXOa.js.map → _server.ts-ByhZiyPJ.js.map} +1 -1
- package/build/server/chunks/{_server.ts-D1AD48e8.js → _server.ts-C2YLv0RS.js} +4 -4
- package/build/server/chunks/{_server.ts-D1AD48e8.js.map → _server.ts-C2YLv0RS.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Ch_RLYHQ.js → _server.ts-C3Cn_AWJ.js} +4 -4
- package/build/server/chunks/{_server.ts-Ch_RLYHQ.js.map → _server.ts-C3Cn_AWJ.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Z87uowZI.js → _server.ts-C9ggXEGb.js} +4 -4
- package/build/server/chunks/{_server.ts-Z87uowZI.js.map → _server.ts-C9ggXEGb.js.map} +1 -1
- package/build/server/chunks/{_server.ts-B0wiCYbB.js → _server.ts-CKHs57oZ.js} +2 -2
- package/build/server/chunks/{_server.ts-B0wiCYbB.js.map → _server.ts-CKHs57oZ.js.map} +1 -1
- package/build/server/chunks/{_server.ts-C4WRZSco.js → _server.ts-CM4aZGc-.js} +3 -3
- package/build/server/chunks/{_server.ts-C4WRZSco.js.map → _server.ts-CM4aZGc-.js.map} +1 -1
- package/build/server/chunks/{_server.ts-la-ySldK.js → _server.ts-CN851WSH.js} +4 -4
- package/build/server/chunks/{_server.ts-la-ySldK.js.map → _server.ts-CN851WSH.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Dmo73WWA.js → _server.ts-CNPmzTy6.js} +4 -4
- package/build/server/chunks/{_server.ts-Dmo73WWA.js.map → _server.ts-CNPmzTy6.js.map} +1 -1
- package/build/server/chunks/{_server.ts-C0F30GT4.js → _server.ts-CZW4ge6f.js} +4 -4
- package/build/server/chunks/{_server.ts-C0F30GT4.js.map → _server.ts-CZW4ge6f.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DxKERFAd.js → _server.ts-CaERLUlr.js} +3 -3
- package/build/server/chunks/{_server.ts-DxKERFAd.js.map → _server.ts-CaERLUlr.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CmGWhrdf.js → _server.ts-Cb4DODkC.js} +5 -5
- package/build/server/chunks/{_server.ts-CmGWhrdf.js.map → _server.ts-Cb4DODkC.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DNPb5zS6.js → _server.ts-CbQpXSqd.js} +4 -4
- package/build/server/chunks/{_server.ts-DNPb5zS6.js.map → _server.ts-CbQpXSqd.js.map} +1 -1
- package/build/server/chunks/{_server.ts-Bb3Kpo0Y.js → _server.ts-Ch4yLIuo.js} +3 -3
- package/build/server/chunks/{_server.ts-Bb3Kpo0Y.js.map → _server.ts-Ch4yLIuo.js.map} +1 -1
- package/build/server/chunks/{_server.ts-B_MVq_5r.js → _server.ts-Cjz2LZbt.js} +4 -4
- package/build/server/chunks/{_server.ts-B_MVq_5r.js.map → _server.ts-Cjz2LZbt.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BJWFkEuu.js → _server.ts-CyhcRpfW.js} +5 -5
- package/build/server/chunks/{_server.ts-BJWFkEuu.js.map → _server.ts-CyhcRpfW.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BemU6FO1.js → _server.ts-CzJ60KtY.js} +5 -5
- package/build/server/chunks/{_server.ts-BemU6FO1.js.map → _server.ts-CzJ60KtY.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BpAINcOs.js → _server.ts-D71yVIcY.js} +5 -15
- package/build/server/chunks/_server.ts-D71yVIcY.js.map +1 -0
- package/build/server/chunks/{_server.ts-CkXnisqg.js → _server.ts-DWL7YPsQ.js} +5 -5
- package/build/server/chunks/{_server.ts-CkXnisqg.js.map → _server.ts-DWL7YPsQ.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BkKg2yyC.js → _server.ts-DnpbPKKN.js} +4 -4
- package/build/server/chunks/{_server.ts-BkKg2yyC.js.map → _server.ts-DnpbPKKN.js.map} +1 -1
- package/build/server/chunks/{_server.ts-gic0t4mu.js → _server.ts-Dnqx5-qU.js} +6 -6
- package/build/server/chunks/{_server.ts-gic0t4mu.js.map → _server.ts-Dnqx5-qU.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CaHe7mo6.js → _server.ts-DrYz0SSH.js} +4 -4
- package/build/server/chunks/{_server.ts-CaHe7mo6.js.map → _server.ts-DrYz0SSH.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DJUYnHrj.js → _server.ts-DraBBcmz.js} +4 -4
- package/build/server/chunks/{_server.ts-DJUYnHrj.js.map → _server.ts-DraBBcmz.js.map} +1 -1
- package/build/server/chunks/{_server.ts-MOiQ4br_.js → _server.ts-I3zLnhsz.js} +4 -4
- package/build/server/chunks/{_server.ts-MOiQ4br_.js.map → _server.ts-I3zLnhsz.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DXPhlUCi.js → _server.ts-gCCprE5T.js} +4 -4
- package/build/server/chunks/{_server.ts-DXPhlUCi.js.map → _server.ts-gCCprE5T.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BrZXNFlK.js → _server.ts-k0TOB-E9.js} +5 -5
- package/build/server/chunks/{_server.ts-BrZXNFlK.js.map → _server.ts-k0TOB-E9.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CFIgn6q6.js → _server.ts-qFzkA4h-.js} +8 -8
- package/build/server/chunks/{_server.ts-CFIgn6q6.js.map → _server.ts-qFzkA4h-.js.map} +1 -1
- package/build/server/chunks/{_server.ts-0ncRaWJ_.js → _server.ts-v9eUA-cx.js} +4 -4
- package/build/server/chunks/{_server.ts-0ncRaWJ_.js.map → _server.ts-v9eUA-cx.js.map} +1 -1
- package/build/server/chunks/{access.server-GvriCjXN.js → access.server-DVG3xnR_.js} +3 -3
- package/build/server/chunks/{access.server-GvriCjXN.js.map → access.server-DVG3xnR_.js.map} +1 -1
- package/build/server/chunks/{api-errors-Dk5z97zb.js → api-errors-DGHmIOGJ.js} +2 -2
- package/build/server/chunks/{api-errors-Dk5z97zb.js.map → api-errors-DGHmIOGJ.js.map} +1 -1
- package/build/server/chunks/{auth-bootstrap.server-CfD5CPTj.js → auth-bootstrap.server-oox9p1sN.js} +10 -3
- package/build/server/chunks/auth-bootstrap.server-oox9p1sN.js.map +1 -0
- package/build/server/chunks/{bootHealth.server-Bn7taneH.js → bootHealth.server-DQx_qsNh.js} +2 -2
- package/build/server/chunks/{bootHealth.server-Bn7taneH.js.map → bootHealth.server-DQx_qsNh.js.map} +1 -1
- package/build/server/chunks/{hooks.server-CMWyl1Gd.js → hooks.server-aaRldGQ_.js} +4 -4
- package/build/server/chunks/{hooks.server-CMWyl1Gd.js.map → hooks.server-aaRldGQ_.js.map} +1 -1
- package/build/server/chunks/{permissions.server-Co6VKW9f.js → permissions.server-qrbshNHz.js} +2 -2
- package/build/server/chunks/{permissions.server-Co6VKW9f.js.map → permissions.server-qrbshNHz.js.map} +1 -1
- package/build/server/chunks/{providers.server-C32WKtDL.js → providers.server-Duyx-08B.js} +68 -68
- package/build/server/chunks/providers.server-Duyx-08B.js.map +1 -0
- package/build/server/chunks/{resolve.server-DYsU4jL3.js → resolve.server-BwfjDyaT.js} +3 -3
- package/build/server/chunks/{resolve.server-DYsU4jL3.js.map → resolve.server-BwfjDyaT.js.map} +1 -1
- package/build/server/chunks/{resolve.server2-Co65XNMI.js → resolve.server2-DjZg4oZg.js} +3 -3
- package/build/server/chunks/{resolve.server2-Co65XNMI.js.map → resolve.server2-DjZg4oZg.js.map} +1 -1
- package/build/server/chunks/{token.server-B8XVPI0F.js → token.server-CBtuQZt0.js} +2 -2
- package/build/server/chunks/token.server-CBtuQZt0.js.map +1 -0
- package/build/server/chunks/{utils2-Sy-_rI-0.js → utils2-QuTTpZq0.js} +2 -2
- package/build/server/chunks/{utils2-Sy-_rI-0.js.map → utils2-QuTTpZq0.js.map} +1 -1
- package/build/server/index.js +2 -2
- package/build/server/index.js.map +1 -1
- package/build/server/manifest.js +70 -70
- package/build/server/manifest.js.map +1 -1
- package/package.json +7 -8
- package/templates/.env.example +3 -2
- package/templates/ecosystem.config.cjs +7 -5
- package/build/client/_app/immutable/assets/20.DzF5JyuX.css +0 -1
- package/build/client/_app/immutable/assets/20.DzF5JyuX.css.br +0 -0
- package/build/client/_app/immutable/assets/20.DzF5JyuX.css.gz +0 -0
- package/build/client/_app/immutable/chunks/4y4xLOS_.js.br +0 -0
- package/build/client/_app/immutable/chunks/4y4xLOS_.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BFXFuY-o.js +0 -3
- package/build/client/_app/immutable/chunks/BFXFuY-o.js.br +0 -0
- package/build/client/_app/immutable/chunks/BFXFuY-o.js.gz +0 -0
- package/build/client/_app/immutable/chunks/ChSMnQMB.js.br +0 -0
- package/build/client/_app/immutable/chunks/ChSMnQMB.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D7PHp8xb.js.br +0 -0
- package/build/client/_app/immutable/chunks/D7PHp8xb.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DHWrMZkd.js.br +0 -0
- package/build/client/_app/immutable/chunks/DHWrMZkd.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DdaJZmuM.js.br +0 -0
- package/build/client/_app/immutable/chunks/DdaJZmuM.js.gz +0 -0
- package/build/client/_app/immutable/entry/app.CY1cyDxx.js.br +0 -0
- package/build/client/_app/immutable/entry/app.CY1cyDxx.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.ByTVZFMZ.js +0 -1
- package/build/client/_app/immutable/entry/start.ByTVZFMZ.js.br +0 -2
- package/build/client/_app/immutable/entry/start.ByTVZFMZ.js.gz +0 -0
- package/build/client/_app/immutable/nodes/0.CQbbSrko.js +0 -1
- package/build/client/_app/immutable/nodes/0.CQbbSrko.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.CQbbSrko.js.gz +0 -0
- package/build/client/_app/immutable/nodes/1.WcE6FOcF.js.br +0 -0
- package/build/client/_app/immutable/nodes/1.WcE6FOcF.js.gz +0 -0
- package/build/client/_app/immutable/nodes/10.Bl4yPogx.js +0 -3
- package/build/client/_app/immutable/nodes/10.Bl4yPogx.js.br +0 -0
- package/build/client/_app/immutable/nodes/10.Bl4yPogx.js.gz +0 -0
- package/build/client/_app/immutable/nodes/11.kVvSmSNV.js.br +0 -0
- package/build/client/_app/immutable/nodes/11.kVvSmSNV.js.gz +0 -0
- package/build/client/_app/immutable/nodes/13.JyGUEsdb.js.br +0 -0
- package/build/client/_app/immutable/nodes/13.JyGUEsdb.js.gz +0 -0
- package/build/client/_app/immutable/nodes/14.BbJglRXt.js.br +0 -0
- package/build/client/_app/immutable/nodes/14.BbJglRXt.js.gz +0 -0
- package/build/client/_app/immutable/nodes/15.94-Zje0s.js +0 -13
- package/build/client/_app/immutable/nodes/15.94-Zje0s.js.br +0 -0
- package/build/client/_app/immutable/nodes/15.94-Zje0s.js.gz +0 -0
- package/build/client/_app/immutable/nodes/16.DRADdurD.js.br +0 -0
- package/build/client/_app/immutable/nodes/16.DRADdurD.js.gz +0 -0
- package/build/client/_app/immutable/nodes/17.DOsqdwdd.js.br +0 -0
- package/build/client/_app/immutable/nodes/17.DOsqdwdd.js.gz +0 -0
- package/build/client/_app/immutable/nodes/19.S2J54AdY.js.br +0 -0
- package/build/client/_app/immutable/nodes/19.S2J54AdY.js.gz +0 -0
- package/build/client/_app/immutable/nodes/2.CKVtP2Ky.js.br +0 -0
- package/build/client/_app/immutable/nodes/2.CKVtP2Ky.js.gz +0 -0
- package/build/client/_app/immutable/nodes/20.BCasu2g4.js.br +0 -0
- package/build/client/_app/immutable/nodes/20.BCasu2g4.js.gz +0 -0
- package/build/client/_app/immutable/nodes/21.C1aTaoAB.js.br +0 -0
- package/build/client/_app/immutable/nodes/21.C1aTaoAB.js.gz +0 -0
- package/build/client/_app/immutable/nodes/23.DP5Be3HR.js.br +0 -0
- package/build/client/_app/immutable/nodes/23.DP5Be3HR.js.gz +0 -0
- package/build/client/_app/immutable/nodes/24.BB6fXxnh.js.br +0 -0
- package/build/client/_app/immutable/nodes/24.BB6fXxnh.js.gz +0 -0
- package/build/client/_app/immutable/nodes/27.DB7PVQXo.js.br +0 -0
- package/build/client/_app/immutable/nodes/27.DB7PVQXo.js.gz +0 -0
- package/build/client/_app/immutable/nodes/28.Cf2R7A3f.js.br +0 -0
- package/build/client/_app/immutable/nodes/28.Cf2R7A3f.js.gz +0 -0
- package/build/client/_app/immutable/nodes/29.CyJS5sye.js.br +0 -0
- package/build/client/_app/immutable/nodes/29.CyJS5sye.js.gz +0 -0
- package/build/client/_app/immutable/nodes/3.DWyky0UV.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.DWyky0UV.js.gz +0 -0
- package/build/client/_app/immutable/nodes/30.BFpYKBJh.js.br +0 -0
- package/build/client/_app/immutable/nodes/30.BFpYKBJh.js.gz +0 -0
- package/build/client/_app/immutable/nodes/5.BzQBSRbS.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.BzQBSRbS.js.gz +0 -0
- package/build/client/_app/immutable/nodes/6.gJ2nhxWc.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.gJ2nhxWc.js.gz +0 -0
- package/build/client/_app/immutable/nodes/7.tBTDolnc.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.tBTDolnc.js.gz +0 -0
- package/build/client/_app/immutable/nodes/8.BJK9n85D.js.br +0 -0
- package/build/client/_app/immutable/nodes/8.BJK9n85D.js.gz +0 -0
- package/build/client/_app/immutable/nodes/9.un0j6nRP.js +0 -1
- package/build/client/_app/immutable/nodes/9.un0j6nRP.js.br +0 -0
- package/build/client/_app/immutable/nodes/9.un0j6nRP.js.gz +0 -0
- package/build/server/chunks/_layout.svelte-Czx3WsTK.js.map +0 -1
- package/build/server/chunks/_page.svelte-5X2iRv32.js.map +0 -1
- package/build/server/chunks/_page.svelte-BO2coOCw.js.map +0 -1
- package/build/server/chunks/_page.svelte-CGuEBnqj.js.map +0 -1
- package/build/server/chunks/_page.svelte-CX9DKxIH.js.map +0 -1
- package/build/server/chunks/_page.svelte-KapMJV5_.js.map +0 -1
- package/build/server/chunks/_server.ts-BpAINcOs.js.map +0 -1
- package/build/server/chunks/auth-bootstrap.server-CfD5CPTj.js.map +0 -1
- package/build/server/chunks/providers.server-C32WKtDL.js.map +0 -1
- package/build/server/chunks/token.server-B8XVPI0F.js.map +0 -1
- package/templates/selva.config.example.js +0 -338
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"token.server-B8XVPI0F.js","sources":["../../../.svelte-kit/adapter-node/chunks/token.server.js"],"sourcesContent":["import { randomBytes, createHmac } from \"node:crypto\";\nimport { b as private_env } from \"./shared-server.js\";\nconst TOKEN_PREFIX = \"share_\";\nfunction getSecret() {\n const secret = private_env.SHARE_LINK_SECRET || private_env.SELVA_HMAC_KEY;\n if (!secret) {\n throw new Error(\n \"Missing required env var: SHARE_LINK_SECRET (or SELVA_HMAC_KEY as fallback). See selva.config.ts for setup instructions.\"\n );\n }\n return secret;\n}\nfunction mintRawToken() {\n return TOKEN_PREFIX + randomBytes(32).toString(\"base64url\");\n}\nfunction hashToken(raw) {\n return createHmac(\"sha256\", getSecret()).update(raw).digest(\"base64url\");\n}\nfunction looksLikeShareToken(value) {\n return value.startsWith(TOKEN_PREFIX);\n}\nexport {\n hashToken as h,\n looksLikeShareToken as l,\n mintRawToken as m\n};\n"],"names":[],"mappings":";;;AAEA,MAAM,YAAY,GAAG,QAAQ;AAC7B,SAAS,SAAS,GAAG;AACrB,EAAE,MAAM,MAAM,GAAG,WAAW,CAAC,iBAAiB,IAAI,WAAW,CAAC,cAAc;AAC5E,EAAE,IAAI,CAAC,MAAM,EAAE;AACf,IAAI,MAAM,IAAI,KAAK;AACnB,MAAM;AACN,KAAK;AACL,EAAE;AACF,EAAE,OAAO,MAAM;AACf;AACA,SAAS,YAAY,GAAG;AACxB,EAAE,OAAO,YAAY,GAAG,WAAW,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC;AAC7D;AACA,SAAS,SAAS,CAAC,GAAG,EAAE;AACxB,EAAE,OAAO,UAAU,CAAC,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC;AAC1E;AACA,SAAS,mBAAmB,CAAC,KAAK,EAAE;AACpC,EAAE,OAAO,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC;AACvC;;;;"}
|
|
@@ -1,338 +0,0 @@
|
|
|
1
|
-
// ../../selva.config.ts
|
|
2
|
-
import { defineConfig } from "@selvajs/platform";
|
|
3
|
-
import * as local from "@selvajs/local-provider";
|
|
4
|
-
import * as supa from "@selvajs/supabase-provider";
|
|
5
|
-
|
|
6
|
-
// ../providers/header-auth/dist/HeaderAuthProvider.js
|
|
7
|
-
import * as path2 from "node:path";
|
|
8
|
-
import { ProviderError as ProviderError2 } from "@selvajs/platform";
|
|
9
|
-
|
|
10
|
-
// ../providers/header-auth/dist/users.js
|
|
11
|
-
import { randomUUID } from "node:crypto";
|
|
12
|
-
import * as fs from "node:fs/promises";
|
|
13
|
-
import * as path from "node:path";
|
|
14
|
-
import { ProviderError } from "@selvajs/platform";
|
|
15
|
-
var empty = () => ({ users: [] });
|
|
16
|
-
var LAST_LOGIN_DEBOUNCE_MS = 6e4;
|
|
17
|
-
async function readFile2(filePath) {
|
|
18
|
-
try {
|
|
19
|
-
const raw = await fs.readFile(filePath, "utf-8");
|
|
20
|
-
return JSON.parse(raw);
|
|
21
|
-
} catch (err) {
|
|
22
|
-
if (err.code === "ENOENT")
|
|
23
|
-
return empty();
|
|
24
|
-
throw err;
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
async function writeFile2(filePath, data) {
|
|
28
|
-
await fs.mkdir(path.dirname(filePath), { recursive: true });
|
|
29
|
-
const tmp = `${filePath}.tmp`;
|
|
30
|
-
await fs.writeFile(tmp, JSON.stringify(data, null, " "), "utf-8");
|
|
31
|
-
await fs.rename(tmp, filePath);
|
|
32
|
-
}
|
|
33
|
-
function createAllowlistStore(filePath) {
|
|
34
|
-
const norm = (upn) => upn.trim().toLowerCase();
|
|
35
|
-
return {
|
|
36
|
-
async findByUpn(upn) {
|
|
37
|
-
const { users } = await readFile2(filePath);
|
|
38
|
-
const key = norm(upn);
|
|
39
|
-
return users.find((u) => u.upn === key) ?? null;
|
|
40
|
-
},
|
|
41
|
-
async findById(id) {
|
|
42
|
-
const { users } = await readFile2(filePath);
|
|
43
|
-
return users.find((u) => u.id === id) ?? null;
|
|
44
|
-
},
|
|
45
|
-
async listUsers() {
|
|
46
|
-
const { users } = await readFile2(filePath);
|
|
47
|
-
return users;
|
|
48
|
-
},
|
|
49
|
-
async createUser(upn) {
|
|
50
|
-
const file = await readFile2(filePath);
|
|
51
|
-
const key = norm(upn);
|
|
52
|
-
if (file.users.some((u) => u.upn === key)) {
|
|
53
|
-
throw new ProviderError(`User with UPN "${upn}" already exists`, 409);
|
|
54
|
-
}
|
|
55
|
-
const entry = {
|
|
56
|
-
id: randomUUID(),
|
|
57
|
-
upn: key,
|
|
58
|
-
createdAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
59
|
-
};
|
|
60
|
-
file.users.push(entry);
|
|
61
|
-
await writeFile2(filePath, file);
|
|
62
|
-
return entry;
|
|
63
|
-
},
|
|
64
|
-
async materializeFromHeaders(id, fields) {
|
|
65
|
-
const file = await readFile2(filePath);
|
|
66
|
-
const user = file.users.find((u) => u.id === id);
|
|
67
|
-
if (!user)
|
|
68
|
-
return;
|
|
69
|
-
let dirty = false;
|
|
70
|
-
if (!user.email && fields.email) {
|
|
71
|
-
user.email = fields.email;
|
|
72
|
-
dirty = true;
|
|
73
|
-
}
|
|
74
|
-
if (!user.displayName && fields.displayName) {
|
|
75
|
-
user.displayName = fields.displayName;
|
|
76
|
-
dirty = true;
|
|
77
|
-
}
|
|
78
|
-
if (dirty)
|
|
79
|
-
await writeFile2(filePath, file);
|
|
80
|
-
},
|
|
81
|
-
async setDisabled(id, disabled) {
|
|
82
|
-
const file = await readFile2(filePath);
|
|
83
|
-
const user = file.users.find((u) => u.id === id);
|
|
84
|
-
if (!user)
|
|
85
|
-
throw new ProviderError(`User "${id}" not found`, 404);
|
|
86
|
-
user.disabled = disabled;
|
|
87
|
-
await writeFile2(filePath, file);
|
|
88
|
-
},
|
|
89
|
-
async touchLastLogin(id) {
|
|
90
|
-
const file = await readFile2(filePath);
|
|
91
|
-
const user = file.users.find((u) => u.id === id);
|
|
92
|
-
if (!user)
|
|
93
|
-
return;
|
|
94
|
-
const now = Date.now();
|
|
95
|
-
if (user.lastLoginAt) {
|
|
96
|
-
const prev = Date.parse(user.lastLoginAt);
|
|
97
|
-
if (Number.isFinite(prev) && now - prev < LAST_LOGIN_DEBOUNCE_MS)
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
user.lastLoginAt = new Date(now).toISOString();
|
|
101
|
-
await writeFile2(filePath, file);
|
|
102
|
-
},
|
|
103
|
-
async deleteUser(id) {
|
|
104
|
-
const file = await readFile2(filePath);
|
|
105
|
-
const before = file.users.length;
|
|
106
|
-
file.users = file.users.filter((u) => u.id !== id);
|
|
107
|
-
if (file.users.length === before)
|
|
108
|
-
throw new ProviderError(`User "${id}" not found`, 404);
|
|
109
|
-
await writeFile2(filePath, file);
|
|
110
|
-
}
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
// ../providers/header-auth/dist/HeaderAuthProvider.js
|
|
115
|
-
var DEFAULT_HEADERS = {
|
|
116
|
-
upn: "SELVA-UserPrincipalName",
|
|
117
|
-
email: "SELVA-Email",
|
|
118
|
-
displayName: "SELVA-DisplayName"
|
|
119
|
-
};
|
|
120
|
-
function toAuthUser(u) {
|
|
121
|
-
return {
|
|
122
|
-
id: u.id,
|
|
123
|
-
email: u.email,
|
|
124
|
-
metadata: { upn: u.upn, displayName: u.displayName },
|
|
125
|
-
createdAt: u.createdAt,
|
|
126
|
-
lastLoginAt: u.lastLoginAt,
|
|
127
|
-
disabled: u.disabled
|
|
128
|
-
};
|
|
129
|
-
}
|
|
130
|
-
var HeaderProxyAuth = class {
|
|
131
|
-
users;
|
|
132
|
-
headers;
|
|
133
|
-
bootstrapPolicy;
|
|
134
|
-
constructor(users, headers, bootstrapPolicy) {
|
|
135
|
-
this.users = users;
|
|
136
|
-
this.headers = headers;
|
|
137
|
-
this.bootstrapPolicy = bootstrapPolicy;
|
|
138
|
-
}
|
|
139
|
-
setBootstrapPolicy(policy) {
|
|
140
|
-
this.bootstrapPolicy = policy ?? void 0;
|
|
141
|
-
}
|
|
142
|
-
async identifyFromHeaders(headers) {
|
|
143
|
-
const upn = headers.get(this.headers.upn);
|
|
144
|
-
if (!upn || !upn.trim())
|
|
145
|
-
return null;
|
|
146
|
-
const email = headers.get(this.headers.email)?.trim() || void 0;
|
|
147
|
-
const displayName = headers.get(this.headers.displayName)?.trim() || void 0;
|
|
148
|
-
let entry = await this.users.findByUpn(upn);
|
|
149
|
-
if (!entry && this.bootstrapPolicy) {
|
|
150
|
-
const allowed = await this.bootstrapPolicy({ upn, email });
|
|
151
|
-
if (allowed) {
|
|
152
|
-
try {
|
|
153
|
-
entry = await this.users.createUser(upn);
|
|
154
|
-
} catch {
|
|
155
|
-
entry = await this.users.findByUpn(upn);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
if (!entry || entry.disabled)
|
|
160
|
-
return null;
|
|
161
|
-
if (!entry.email && email || !entry.displayName && displayName) {
|
|
162
|
-
await this.users.materializeFromHeaders(entry.id, { email, displayName }).catch(() => {
|
|
163
|
-
});
|
|
164
|
-
if (email && !entry.email)
|
|
165
|
-
entry.email = email;
|
|
166
|
-
if (displayName && !entry.displayName)
|
|
167
|
-
entry.displayName = displayName;
|
|
168
|
-
}
|
|
169
|
-
await this.users.touchLastLogin(entry.id).catch(() => {
|
|
170
|
-
});
|
|
171
|
-
return toAuthUser(entry);
|
|
172
|
-
}
|
|
173
|
-
};
|
|
174
|
-
var HeaderAuthProvider = class _HeaderAuthProvider {
|
|
175
|
-
users;
|
|
176
|
-
headers;
|
|
177
|
-
name = "Header (Forward Auth)";
|
|
178
|
-
proxyAuth;
|
|
179
|
-
constructor(config) {
|
|
180
|
-
this.users = createAllowlistStore(config.allowlistFilePath);
|
|
181
|
-
this.headers = { ...DEFAULT_HEADERS, ...config.headers };
|
|
182
|
-
this.proxyAuth = new HeaderProxyAuth(this.users, this.headers, config.bootstrapAllowlistPolicy);
|
|
183
|
-
}
|
|
184
|
-
/**
|
|
185
|
-
* Late-bind a bootstrap-allowlist policy. Useful when the policy needs
|
|
186
|
-
* runtime state the platform layer owns (e.g. `hasInstanceAdmin`) and
|
|
187
|
-
* therefore can't be wired up at provider construction time. Pass `null`
|
|
188
|
-
* to clear.
|
|
189
|
-
*/
|
|
190
|
-
setBootstrapAllowlistPolicy(policy) {
|
|
191
|
-
this.proxyAuth.setBootstrapPolicy(policy);
|
|
192
|
-
}
|
|
193
|
-
static fromEnv(env) {
|
|
194
|
-
const dir = env.HEADER_AUTH_DATA_DIR ?? env.DATA_PATH;
|
|
195
|
-
if (!dir) {
|
|
196
|
-
throw new Error("Missing required env var: HEADER_AUTH_DATA_DIR (or DATA_PATH as fallback). This directory holds header-allowlist.json \u2014 the pre-provisioned UPN list.");
|
|
197
|
-
}
|
|
198
|
-
return new _HeaderAuthProvider({
|
|
199
|
-
allowlistFilePath: path2.join(dir, "header-allowlist.json"),
|
|
200
|
-
headers: {
|
|
201
|
-
upn: env.HEADER_AUTH_UPN_HEADER ?? DEFAULT_HEADERS.upn,
|
|
202
|
-
email: env.HEADER_AUTH_EMAIL_HEADER ?? DEFAULT_HEADERS.email,
|
|
203
|
-
displayName: env.HEADER_AUTH_DISPLAY_NAME_HEADER ?? DEFAULT_HEADERS.displayName
|
|
204
|
-
}
|
|
205
|
-
});
|
|
206
|
-
}
|
|
207
|
-
/**
|
|
208
|
-
* No tokens are issued by this provider — identity rides on every request
|
|
209
|
-
* via the trusted-proxy headers. Always returns null; the hook layer
|
|
210
|
-
* falls through to `proxyAuth.identifyFromHeaders`.
|
|
211
|
-
*/
|
|
212
|
-
async verifyToken(_token) {
|
|
213
|
-
return null;
|
|
214
|
-
}
|
|
215
|
-
async getUser(id) {
|
|
216
|
-
const u = await this.users.findById(id);
|
|
217
|
-
return u ? toAuthUser(u) : null;
|
|
218
|
-
}
|
|
219
|
-
async listUsers(opts) {
|
|
220
|
-
const all = await this.users.listUsers();
|
|
221
|
-
const limit = Math.min(Math.max(1, opts?.limit ?? 25), 200);
|
|
222
|
-
const offset = opts?.cursor ? parseInt(opts.cursor, 10) || 0 : 0;
|
|
223
|
-
const slice = all.slice(offset, offset + limit).map(toAuthUser);
|
|
224
|
-
const nextOffset = offset + slice.length;
|
|
225
|
-
return {
|
|
226
|
-
items: slice,
|
|
227
|
-
nextCursor: nextOffset < all.length ? String(nextOffset) : void 0
|
|
228
|
-
};
|
|
229
|
-
}
|
|
230
|
-
/**
|
|
231
|
-
* Allowlist a UPN. Admin POST `/admin/api/users` with `{ email }`; the
|
|
232
|
-
* email IS the UPN for M365 / Entra deployments where they match. For
|
|
233
|
-
* other IdPs, document the UPN format in your README/onboarding.
|
|
234
|
-
*/
|
|
235
|
-
async createUser(upn) {
|
|
236
|
-
return toAuthUser(await this.users.createUser(upn));
|
|
237
|
-
}
|
|
238
|
-
async deleteUser(id) {
|
|
239
|
-
const target = await this.users.findById(id);
|
|
240
|
-
if (!target)
|
|
241
|
-
return "not_found";
|
|
242
|
-
try {
|
|
243
|
-
await this.users.deleteUser(id);
|
|
244
|
-
return "ok";
|
|
245
|
-
} catch (err) {
|
|
246
|
-
if (err instanceof ProviderError2 && err.statusCode === 404)
|
|
247
|
-
return "not_found";
|
|
248
|
-
throw err;
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
async disableUser(id) {
|
|
252
|
-
const target = await this.users.findById(id);
|
|
253
|
-
if (!target)
|
|
254
|
-
return "not_found";
|
|
255
|
-
try {
|
|
256
|
-
await this.users.setDisabled(id, true);
|
|
257
|
-
return "ok";
|
|
258
|
-
} catch (err) {
|
|
259
|
-
if (err instanceof ProviderError2 && err.statusCode === 404)
|
|
260
|
-
return "not_found";
|
|
261
|
-
throw err;
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
async touchLastLogin(id) {
|
|
265
|
-
await this.users.touchLastLogin(id);
|
|
266
|
-
}
|
|
267
|
-
};
|
|
268
|
-
|
|
269
|
-
// ../../selva.config.ts
|
|
270
|
-
function envBool(env, key) {
|
|
271
|
-
const v = env[key]?.toLowerCase();
|
|
272
|
-
return v === "true" || v === "1" || v === "yes";
|
|
273
|
-
}
|
|
274
|
-
function pickAuth(env) {
|
|
275
|
-
const choice = (env.SELVA_AUTH_PROVIDER ?? "local").toLowerCase();
|
|
276
|
-
switch (choice) {
|
|
277
|
-
case "local":
|
|
278
|
-
return local.LocalAuthProvider.fromEnv(env);
|
|
279
|
-
case "supabase":
|
|
280
|
-
return supa.SupabaseAuthProvider.fromEnv(env);
|
|
281
|
-
case "header":
|
|
282
|
-
return HeaderAuthProvider.fromEnv(env);
|
|
283
|
-
default:
|
|
284
|
-
throw new Error(
|
|
285
|
-
`Unknown SELVA_AUTH_PROVIDER="${choice}". Expected: local | supabase | header.`
|
|
286
|
-
);
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
function pickData(env) {
|
|
290
|
-
const choice = (env.SELVA_DATA_PROVIDER ?? "local").toLowerCase();
|
|
291
|
-
switch (choice) {
|
|
292
|
-
case "local":
|
|
293
|
-
return local.LocalDataProvider.fromEnv(env);
|
|
294
|
-
case "supabase":
|
|
295
|
-
return supa.SupabaseDataProvider.fromEnv(env);
|
|
296
|
-
default:
|
|
297
|
-
throw new Error(`Unknown SELVA_DATA_PROVIDER="${choice}". Expected: local | supabase.`);
|
|
298
|
-
}
|
|
299
|
-
}
|
|
300
|
-
function pickStorage(env) {
|
|
301
|
-
const choice = (env.SELVA_STORAGE_PROVIDER ?? "local").toLowerCase();
|
|
302
|
-
switch (choice) {
|
|
303
|
-
case "local":
|
|
304
|
-
return local.LocalStorageProvider.fromEnv(env);
|
|
305
|
-
case "supabase":
|
|
306
|
-
return supa.SupabaseStorageProvider.fromEnv(env);
|
|
307
|
-
default:
|
|
308
|
-
throw new Error(`Unknown SELVA_STORAGE_PROVIDER="${choice}". Expected: local | supabase.`);
|
|
309
|
-
}
|
|
310
|
-
}
|
|
311
|
-
function pickTenancy(env) {
|
|
312
|
-
const choice = (env.SELVA_TENANCY ?? "single").toLowerCase();
|
|
313
|
-
if (choice !== "single" && choice !== "multi") {
|
|
314
|
-
throw new Error(`Unknown SELVA_TENANCY="${choice}". Expected: single | multi.`);
|
|
315
|
-
}
|
|
316
|
-
return choice;
|
|
317
|
-
}
|
|
318
|
-
var selva_config_default = defineConfig((env) => ({
|
|
319
|
-
tenancy: pickTenancy(env),
|
|
320
|
-
flags: {
|
|
321
|
-
ALLOW_CROSS_ORG_PUBLIC: envBool(env, "SELVA_FLAG_ALLOW_CROSS_ORG_PUBLIC"),
|
|
322
|
-
ALLOW_ORG_COMPUTE_OVERRIDE: envBool(env, "SELVA_FLAG_ALLOW_ORG_COMPUTE_OVERRIDE"),
|
|
323
|
-
ALLOW_ORG_CREATION: envBool(env, "SELVA_FLAG_ALLOW_ORG_CREATION"),
|
|
324
|
-
ENABLE_SHARING: envBool(env, "SELVA_FLAG_ENABLE_SHARING")
|
|
325
|
-
},
|
|
326
|
-
branding: {
|
|
327
|
-
name: env.SELVA_BRAND_NAME,
|
|
328
|
-
copyrightName: env.SELVA_BRAND_COPYRIGHT_NAME,
|
|
329
|
-
tagline: env.SELVA_BRAND_TAGLINE,
|
|
330
|
-
description: env.SELVA_BRAND_DESCRIPTION
|
|
331
|
-
},
|
|
332
|
-
auth: pickAuth(env),
|
|
333
|
-
data: pickData(env),
|
|
334
|
-
storage: pickStorage(env)
|
|
335
|
-
}));
|
|
336
|
-
export {
|
|
337
|
-
selva_config_default as default
|
|
338
|
-
};
|