@selvajs/selva 2.0.1 → 2.0.3
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/{BSyJ0ZuA.js → BV1oWdGD.js} +1 -1
- package/build/client/_app/immutable/chunks/BV1oWdGD.js.br +0 -0
- package/build/client/_app/immutable/chunks/BV1oWdGD.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/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/{CS49LPny.js → CCx3W8-n.js} +1 -1
- package/build/client/_app/immutable/chunks/CCx3W8-n.js.br +0 -0
- package/build/client/_app/immutable/chunks/CCx3W8-n.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CEnIp_6Y.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{4PBDTLFF.js → CISf22d1.js} +1 -1
- package/build/client/_app/immutable/chunks/CISf22d1.js.br +0 -0
- package/build/client/_app/immutable/chunks/CISf22d1.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/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/{VmqnFAi3.js → DDJVj3K_.js} +1 -1
- package/build/client/_app/immutable/chunks/DDJVj3K_.js.br +0 -0
- package/build/client/_app/immutable/chunks/DDJVj3K_.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/{BMwGnr2J.js → DPB6Jpno.js} +1 -1
- package/build/client/_app/immutable/chunks/DPB6Jpno.js.br +0 -0
- package/build/client/_app/immutable/chunks/DPB6Jpno.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/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/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/{smW5maEe.js → mn4wqSK3.js} +1 -1
- package/build/client/_app/immutable/chunks/mn4wqSK3.js.br +0 -0
- package/build/client/_app/immutable/chunks/mn4wqSK3.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/entry/{app.GElcRZPp.js → app.BRKh5QNI.js} +2 -2
- package/build/client/_app/immutable/entry/app.BRKh5QNI.js.br +0 -0
- package/build/client/_app/immutable/entry/app.BRKh5QNI.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.DzTy4Sar.js +1 -0
- package/build/client/_app/immutable/entry/start.DzTy4Sar.js.br +2 -0
- package/build/client/_app/immutable/entry/start.DzTy4Sar.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{0.r0PA_Sxw.js → 0.KJ-PiM1c.js} +1 -1
- 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.CTfA0FAT.js → 1.CTs6oCZo.js} +1 -1
- package/build/client/_app/immutable/nodes/1.CTs6oCZo.js.br +0 -0
- package/build/client/_app/immutable/nodes/1.CTs6oCZo.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.Dk81DreT.js → 11.DemYOq3i.js} +1 -1
- package/build/client/_app/immutable/nodes/11.DemYOq3i.js.br +0 -0
- package/build/client/_app/immutable/nodes/11.DemYOq3i.js.gz +0 -0
- package/build/client/_app/immutable/nodes/12.BoPfAFdi.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{13.B3m9NRrd.js → 13.DpdyenfK.js} +1 -1
- package/build/client/_app/immutable/nodes/13.DpdyenfK.js.br +0 -0
- package/build/client/_app/immutable/nodes/13.DpdyenfK.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{14.9MmuwEpn.js → 14.CwVi2ClP.js} +1 -1
- package/build/client/_app/immutable/nodes/14.CwVi2ClP.js.br +0 -0
- package/build/client/_app/immutable/nodes/14.CwVi2ClP.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.BMWgVDGJ.js → 16.DzXblhpf.js} +2 -2
- package/build/client/_app/immutable/nodes/16.DzXblhpf.js.br +0 -0
- package/build/client/_app/immutable/nodes/16.DzXblhpf.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{17.Bch7V784.js → 17.cWP9UUvo.js} +1 -1
- package/build/client/_app/immutable/nodes/17.cWP9UUvo.js.br +0 -0
- package/build/client/_app/immutable/nodes/17.cWP9UUvo.js.gz +0 -0
- package/build/client/_app/immutable/nodes/18.BpVlwZ30.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{19.DQtOUgti.js → 19.C2JJyvh1.js} +1 -1
- package/build/client/_app/immutable/nodes/19.C2JJyvh1.js.br +0 -0
- package/build/client/_app/immutable/nodes/19.C2JJyvh1.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{2.CyCY9Gpy.js → 2.CEtR_jy5.js} +1 -1
- package/build/client/_app/immutable/nodes/2.CEtR_jy5.js.br +0 -0
- package/build/client/_app/immutable/nodes/2.CEtR_jy5.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{20.CT0e7phi.js → 20.CpAqrbNF.js} +6 -6
- package/build/client/_app/immutable/nodes/20.CpAqrbNF.js.br +0 -0
- package/build/client/_app/immutable/nodes/20.CpAqrbNF.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{21.C43xF0qL.js → 21.BW8K2thc.js} +1 -1
- package/build/client/_app/immutable/nodes/21.BW8K2thc.js.br +0 -0
- package/build/client/_app/immutable/nodes/21.BW8K2thc.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{23.CFT1SOUF.js → 23.BnfqaaSO.js} +1 -1
- package/build/client/_app/immutable/nodes/23.BnfqaaSO.js.br +0 -0
- package/build/client/_app/immutable/nodes/23.BnfqaaSO.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{24.BjGP5G3P.js → 24.XyeC_rUv.js} +1 -1
- package/build/client/_app/immutable/nodes/24.XyeC_rUv.js.br +0 -0
- package/build/client/_app/immutable/nodes/24.XyeC_rUv.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.BS48zWld.js → 27.CEXct3Wc.js} +1 -1
- package/build/client/_app/immutable/nodes/27.CEXct3Wc.js.br +0 -0
- package/build/client/_app/immutable/nodes/27.CEXct3Wc.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{28.eQk5ZqHl.js → 28.B9Yr7s3f.js} +1 -1
- package/build/client/_app/immutable/nodes/28.B9Yr7s3f.js.br +0 -0
- package/build/client/_app/immutable/nodes/28.B9Yr7s3f.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{29.-im11HaY.js → 29.9THa6mgW.js} +1 -1
- package/build/client/_app/immutable/nodes/29.9THa6mgW.js.br +0 -0
- package/build/client/_app/immutable/nodes/29.9THa6mgW.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{3.CfPrUs70.js → 3.B8tp0KuP.js} +1 -1
- package/build/client/_app/immutable/nodes/3.B8tp0KuP.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.B8tp0KuP.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{30.DUz5JI16.js → 30.B0_ohaRg.js} +1 -1
- package/build/client/_app/immutable/nodes/30.B0_ohaRg.js.br +0 -0
- package/build/client/_app/immutable/nodes/30.B0_ohaRg.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.D4jMtb1M.js → 5.CEvQHcz8.js} +1 -1
- package/build/client/_app/immutable/nodes/5.CEvQHcz8.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.CEvQHcz8.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{6.BhoBomwz.js → 6.MiARQsow.js} +1 -1
- package/build/client/_app/immutable/nodes/6.MiARQsow.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.MiARQsow.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{7.CaJkp9fo.js → 7.4E9V6GcT.js} +1 -1
- package/build/client/_app/immutable/nodes/7.4E9V6GcT.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.4E9V6GcT.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{8.Bt2DWfca.js → 8.D8g6Vds-.js} +1 -1
- package/build/client/_app/immutable/nodes/8.D8g6Vds-.js.br +0 -0
- package/build/client/_app/immutable/nodes/8.D8g6Vds-.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{9.C5-qch-V.js → 9.CaxIeYLY.js} +1 -1
- package/build/client/_app/immutable/nodes/9.CaxIeYLY.js.br +0 -0
- package/build/client/_app/immutable/nodes/9.CaxIeYLY.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-BXYXs3Xm.js → 0-wC8vebb2.js} +4 -4
- package/build/server/chunks/{0-BXYXs3Xm.js.map → 0-wC8vebb2.js.map} +1 -1
- package/build/server/chunks/{1-V8dFtmbb.js → 1-tkiRaJm3.js} +2 -2
- package/build/server/chunks/{1-V8dFtmbb.js.map → 1-tkiRaJm3.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-C54ZyrYp.js → 11-CwBAHKO1.js} +6 -6
- package/build/server/chunks/{11-C54ZyrYp.js.map → 11-CwBAHKO1.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-DVoUfflf.js → 13-CEgpkJsl.js} +3 -3
- package/build/server/chunks/{13-DVoUfflf.js.map → 13-CEgpkJsl.js.map} +1 -1
- package/build/server/chunks/{14-DkBYx89e.js → 14-CuLH3sOJ.js} +3 -3
- package/build/server/chunks/{14-DkBYx89e.js.map → 14-CuLH3sOJ.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-cz9yc7Nq.js → 16-BqSmZ0au.js} +6 -6
- package/build/server/chunks/{16-cz9yc7Nq.js.map → 16-BqSmZ0au.js.map} +1 -1
- package/build/server/chunks/{17-BLqAW2P3.js → 17-BwPRBUof.js} +2 -2
- package/build/server/chunks/{17-BLqAW2P3.js.map → 17-BwPRBUof.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-BZm3F7yF.js → 19-3FI-gBIF.js} +3 -3
- package/build/server/chunks/{19-BZm3F7yF.js.map → 19-3FI-gBIF.js.map} +1 -1
- package/build/server/chunks/{2-CNp1ZQp0.js → 2-BktREpTN.js} +5 -5
- package/build/server/chunks/{2-CNp1ZQp0.js.map → 2-BktREpTN.js.map} +1 -1
- package/build/server/chunks/{20-BXy_jr30.js → 20-D8O4C_84.js} +12 -12
- package/build/server/chunks/{20-BXy_jr30.js.map → 20-D8O4C_84.js.map} +1 -1
- package/build/server/chunks/{21-DSjRU6S2.js → 21-COO7ITK8.js} +3 -3
- package/build/server/chunks/{21-DSjRU6S2.js.map → 21-COO7ITK8.js.map} +1 -1
- package/build/server/chunks/{23-CjL9FJFA.js → 23-ckQZBIac.js} +6 -6
- package/build/server/chunks/{23-CjL9FJFA.js.map → 23-ckQZBIac.js.map} +1 -1
- package/build/server/chunks/{24-D9rqHSTE.js → 24-Byj6-QiB.js} +4 -4
- package/build/server/chunks/{24-D9rqHSTE.js.map → 24-Byj6-QiB.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-nNwc75ro.js → 27-C6KaTD0c.js} +4 -4
- package/build/server/chunks/{27-nNwc75ro.js.map → 27-C6KaTD0c.js.map} +1 -1
- package/build/server/chunks/{28-CvOKckIC.js → 28-BM0TT8tW.js} +3 -3
- package/build/server/chunks/{28-CvOKckIC.js.map → 28-BM0TT8tW.js.map} +1 -1
- package/build/server/chunks/{29-omUxa3rd.js → 29-8EsvqAjE.js} +3 -3
- package/build/server/chunks/{29-omUxa3rd.js.map → 29-8EsvqAjE.js.map} +1 -1
- package/build/server/chunks/{3-D43IIYqW.js → 3-CGZK9ryR.js} +2 -2
- package/build/server/chunks/{3-D43IIYqW.js.map → 3-CGZK9ryR.js.map} +1 -1
- package/build/server/chunks/{30-BMQ7Cr8A.js → 30-CtB6i9os.js} +3 -3
- package/build/server/chunks/{30-BMQ7Cr8A.js.map → 30-CtB6i9os.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-lJnHNLmp.js → 5-BGu6jqGh.js} +2 -2
- package/build/server/chunks/{5-lJnHNLmp.js.map → 5-BGu6jqGh.js.map} +1 -1
- package/build/server/chunks/{6-BydCaB4v.js → 6-CrVzle0G.js} +3 -3
- package/build/server/chunks/{6-BydCaB4v.js.map → 6-CrVzle0G.js.map} +1 -1
- package/build/server/chunks/{7-D4q4IBnf.js → 7-CyQgvlZo.js} +2 -2
- package/build/server/chunks/{7-D4q4IBnf.js.map → 7-CyQgvlZo.js.map} +1 -1
- package/build/server/chunks/{8-1AErDsjI.js → 8-DQerDMPb.js} +3 -3
- package/build/server/chunks/{8-1AErDsjI.js.map → 8-DQerDMPb.js.map} +1 -1
- package/build/server/chunks/{9-Cr4VDcCh.js → 9-g58PTujZ.js} +4 -4
- package/build/server/chunks/{9-Cr4VDcCh.js.map → 9-g58PTujZ.js.map} +1 -1
- package/build/server/chunks/{_layout.svelte-Px4pdCxU.js → _layout.svelte-xYAKGoE5.js} +4 -4
- package/build/server/chunks/{_layout.svelte-Px4pdCxU.js.map → _layout.svelte-xYAKGoE5.js.map} +1 -1
- package/build/server/chunks/{_page.svelte-D6lEOLLp.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-BcFniUOO.js → _page.svelte-DG_7CM7u.js} +5 -5
- package/build/server/chunks/{_page.svelte-BcFniUOO.js.map → _page.svelte-DG_7CM7u.js.map} +1 -1
- 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 +6 -7
- package/templates/.env.example +3 -2
- package/templates/ecosystem.config.cjs +7 -5
- package/build/client/_app/immutable/assets/20.DvtWUFNX.css +0 -1
- package/build/client/_app/immutable/assets/20.DvtWUFNX.css.br +0 -0
- package/build/client/_app/immutable/assets/20.DvtWUFNX.css.gz +0 -0
- package/build/client/_app/immutable/chunks/4PBDTLFF.js.br +0 -0
- package/build/client/_app/immutable/chunks/4PBDTLFF.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BMwGnr2J.js.br +0 -0
- package/build/client/_app/immutable/chunks/BMwGnr2J.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BSyJ0ZuA.js.br +0 -0
- package/build/client/_app/immutable/chunks/BSyJ0ZuA.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CS49LPny.js.br +0 -0
- package/build/client/_app/immutable/chunks/CS49LPny.js.gz +0 -0
- package/build/client/_app/immutable/chunks/VmqnFAi3.js.br +0 -0
- package/build/client/_app/immutable/chunks/VmqnFAi3.js.gz +0 -0
- package/build/client/_app/immutable/chunks/smW5maEe.js.br +0 -0
- package/build/client/_app/immutable/chunks/smW5maEe.js.gz +0 -0
- package/build/client/_app/immutable/entry/app.GElcRZPp.js.br +0 -0
- package/build/client/_app/immutable/entry/app.GElcRZPp.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.D-b3nSOP.js +0 -1
- package/build/client/_app/immutable/entry/start.D-b3nSOP.js.br +0 -0
- package/build/client/_app/immutable/entry/start.D-b3nSOP.js.gz +0 -0
- package/build/client/_app/immutable/nodes/0.r0PA_Sxw.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.r0PA_Sxw.js.gz +0 -0
- package/build/client/_app/immutable/nodes/1.CTfA0FAT.js.br +0 -0
- package/build/client/_app/immutable/nodes/1.CTfA0FAT.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.Dk81DreT.js.br +0 -0
- package/build/client/_app/immutable/nodes/11.Dk81DreT.js.gz +0 -0
- package/build/client/_app/immutable/nodes/13.B3m9NRrd.js.br +0 -0
- package/build/client/_app/immutable/nodes/13.B3m9NRrd.js.gz +0 -0
- package/build/client/_app/immutable/nodes/14.9MmuwEpn.js.br +0 -0
- package/build/client/_app/immutable/nodes/14.9MmuwEpn.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.BMWgVDGJ.js.br +0 -0
- package/build/client/_app/immutable/nodes/16.BMWgVDGJ.js.gz +0 -0
- package/build/client/_app/immutable/nodes/17.Bch7V784.js.br +0 -0
- package/build/client/_app/immutable/nodes/17.Bch7V784.js.gz +0 -0
- package/build/client/_app/immutable/nodes/19.DQtOUgti.js.br +0 -0
- package/build/client/_app/immutable/nodes/19.DQtOUgti.js.gz +0 -0
- package/build/client/_app/immutable/nodes/2.CyCY9Gpy.js.br +0 -0
- package/build/client/_app/immutable/nodes/2.CyCY9Gpy.js.gz +0 -0
- package/build/client/_app/immutable/nodes/20.CT0e7phi.js.br +0 -0
- package/build/client/_app/immutable/nodes/20.CT0e7phi.js.gz +0 -0
- package/build/client/_app/immutable/nodes/21.C43xF0qL.js.br +0 -0
- package/build/client/_app/immutable/nodes/21.C43xF0qL.js.gz +0 -0
- package/build/client/_app/immutable/nodes/23.CFT1SOUF.js.br +0 -0
- package/build/client/_app/immutable/nodes/23.CFT1SOUF.js.gz +0 -0
- package/build/client/_app/immutable/nodes/24.BjGP5G3P.js.br +0 -0
- package/build/client/_app/immutable/nodes/24.BjGP5G3P.js.gz +0 -0
- package/build/client/_app/immutable/nodes/27.BS48zWld.js.br +0 -0
- package/build/client/_app/immutable/nodes/27.BS48zWld.js.gz +0 -0
- package/build/client/_app/immutable/nodes/28.eQk5ZqHl.js.br +0 -0
- package/build/client/_app/immutable/nodes/28.eQk5ZqHl.js.gz +0 -0
- package/build/client/_app/immutable/nodes/29.-im11HaY.js.br +0 -0
- package/build/client/_app/immutable/nodes/29.-im11HaY.js.gz +0 -0
- package/build/client/_app/immutable/nodes/3.CfPrUs70.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.CfPrUs70.js.gz +0 -0
- package/build/client/_app/immutable/nodes/30.DUz5JI16.js.br +0 -0
- package/build/client/_app/immutable/nodes/30.DUz5JI16.js.gz +0 -0
- package/build/client/_app/immutable/nodes/5.D4jMtb1M.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.D4jMtb1M.js.gz +0 -0
- package/build/client/_app/immutable/nodes/6.BhoBomwz.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.BhoBomwz.js.gz +0 -0
- package/build/client/_app/immutable/nodes/7.CaJkp9fo.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.CaJkp9fo.js.gz +0 -0
- package/build/client/_app/immutable/nodes/8.Bt2DWfca.js.br +0 -0
- package/build/client/_app/immutable/nodes/8.Bt2DWfca.js.gz +0 -0
- package/build/client/_app/immutable/nodes/9.C5-qch-V.js.br +0 -0
- package/build/client/_app/immutable/nodes/9.C5-qch-V.js.gz +0 -0
- package/build/server/chunks/_page.svelte-5X2iRv32.js.map +0 -1
- package/build/server/chunks/_page.svelte-CX9DKxIH.js.map +0 -1
- package/build/server/chunks/_page.svelte-D6lEOLLp.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
|
-
};
|