@openpalm/ui 0.12.18 → 0.12.23

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.
Files changed (382) hide show
  1. package/build/.openpalm-ui-version +1 -1
  2. package/build/client/_app/immutable/assets/4.DQdAwaDZ.css +1 -0
  3. package/build/client/_app/immutable/assets/4.DQdAwaDZ.css.br +0 -0
  4. package/build/client/_app/immutable/assets/4.DQdAwaDZ.css.gz +0 -0
  5. package/build/client/_app/immutable/chunks/B88bDQ93.js +1 -0
  6. package/build/client/_app/immutable/chunks/B88bDQ93.js.br +2 -0
  7. package/build/client/_app/immutable/chunks/B88bDQ93.js.gz +0 -0
  8. package/build/client/_app/immutable/chunks/{B8C5qi9U.js → BjCyXDZy.js} +1 -1
  9. package/build/client/_app/immutable/chunks/BjCyXDZy.js.br +0 -0
  10. package/build/client/_app/immutable/chunks/BjCyXDZy.js.gz +0 -0
  11. package/build/client/_app/immutable/chunks/CAAiIhwC.js +3 -0
  12. package/build/client/_app/immutable/chunks/CAAiIhwC.js.br +0 -0
  13. package/build/client/_app/immutable/chunks/CAAiIhwC.js.gz +0 -0
  14. package/build/client/_app/immutable/chunks/{DYXGFYr6.js → CP1N4Jy5.js} +1 -1
  15. package/build/client/_app/immutable/chunks/CP1N4Jy5.js.br +0 -0
  16. package/build/client/_app/immutable/chunks/CP1N4Jy5.js.gz +0 -0
  17. package/build/client/_app/immutable/chunks/{Dcw6L0GF.js → CgDyA2Qw.js} +2 -2
  18. package/build/client/_app/immutable/chunks/CgDyA2Qw.js.br +0 -0
  19. package/build/client/_app/immutable/chunks/CgDyA2Qw.js.gz +0 -0
  20. package/build/client/_app/immutable/chunks/{CLgRRUN_.js → DpHEXvQk.js} +1 -1
  21. package/build/client/_app/immutable/chunks/DpHEXvQk.js.br +0 -0
  22. package/build/client/_app/immutable/chunks/DpHEXvQk.js.gz +0 -0
  23. package/build/client/_app/immutable/chunks/Dr8nRIOR.js +1 -0
  24. package/build/client/_app/immutable/chunks/Dr8nRIOR.js.br +0 -0
  25. package/build/client/_app/immutable/chunks/Dr8nRIOR.js.gz +0 -0
  26. package/build/client/_app/immutable/entry/{app.CVxCoIFs.js → app.BcL08IcT.js} +2 -2
  27. package/build/client/_app/immutable/entry/app.BcL08IcT.js.br +0 -0
  28. package/build/client/_app/immutable/entry/app.BcL08IcT.js.gz +0 -0
  29. package/build/client/_app/immutable/entry/start.CAuRWqZB.js +1 -0
  30. package/build/client/_app/immutable/entry/start.CAuRWqZB.js.br +0 -0
  31. package/build/client/_app/immutable/entry/start.CAuRWqZB.js.gz +0 -0
  32. package/build/client/_app/immutable/nodes/{0.Bb8qAGW8.js → 0.AZnG4POF.js} +1 -1
  33. package/build/client/_app/immutable/nodes/0.AZnG4POF.js.br +0 -0
  34. package/build/client/_app/immutable/nodes/0.AZnG4POF.js.gz +0 -0
  35. package/build/client/_app/immutable/nodes/{1.Co_TaqLI.js → 1.uNWROKRa.js} +1 -1
  36. package/build/client/_app/immutable/nodes/1.uNWROKRa.js.br +2 -0
  37. package/build/client/_app/immutable/nodes/1.uNWROKRa.js.gz +0 -0
  38. package/build/client/_app/immutable/nodes/4.CNN_a8JB.js +126 -0
  39. package/build/client/_app/immutable/nodes/4.CNN_a8JB.js.br +0 -0
  40. package/build/client/_app/immutable/nodes/4.CNN_a8JB.js.gz +0 -0
  41. package/build/client/_app/immutable/nodes/{5.Fw13EXte.js → 5.rZSa9V3W.js} +2 -2
  42. package/build/client/_app/immutable/nodes/5.rZSa9V3W.js.br +0 -0
  43. package/build/client/_app/immutable/nodes/5.rZSa9V3W.js.gz +0 -0
  44. package/build/client/_app/immutable/nodes/{6.CWy0yXnu.js → 6.DUAMcwSm.js} +1 -1
  45. package/build/client/_app/immutable/nodes/6.DUAMcwSm.js.br +0 -0
  46. package/build/client/_app/immutable/nodes/6.DUAMcwSm.js.gz +0 -0
  47. package/build/client/_app/immutable/nodes/{7.CsM4M8Ul.js → 7.B1u5a8yO.js} +1 -1
  48. package/build/client/_app/immutable/nodes/7.B1u5a8yO.js.br +0 -0
  49. package/build/client/_app/immutable/nodes/7.B1u5a8yO.js.gz +0 -0
  50. package/build/client/_app/immutable/nodes/{8.V6hY0p8a.js → 8.DW8zKXS4.js} +1 -1
  51. package/build/client/_app/immutable/nodes/8.DW8zKXS4.js.br +0 -0
  52. package/build/client/_app/immutable/nodes/8.DW8zKXS4.js.gz +0 -0
  53. package/build/client/_app/version.json +1 -1
  54. package/build/client/_app/version.json.br +1 -1
  55. package/build/client/_app/version.json.gz +0 -0
  56. package/build/server/chunks/{0-DrD9dfbN.js → 0-DL6Jfu7F.js} +3 -3
  57. package/build/server/chunks/{0-DrD9dfbN.js.map → 0-DL6Jfu7F.js.map} +1 -1
  58. package/build/server/chunks/1-B2LhxwPN.js +9 -0
  59. package/build/server/chunks/{1-DvZDBGww.js.map → 1-B2LhxwPN.js.map} +1 -1
  60. package/build/server/chunks/{10-C96Thueb.js → 10-DQCiYDxy.js} +5 -5
  61. package/build/server/chunks/10-DQCiYDxy.js.map +1 -0
  62. package/build/server/chunks/4-2GARyIXu.js +9 -0
  63. package/build/server/chunks/{4-BYdi8hv_.js.map → 4-2GARyIXu.js.map} +1 -1
  64. package/build/server/chunks/{5-DIQyHPcz.js → 5-BPq_SUbr.js} +3 -3
  65. package/build/server/chunks/{5-DIQyHPcz.js.map → 5-BPq_SUbr.js.map} +1 -1
  66. package/build/server/chunks/6-Bnw_JRXO.js +9 -0
  67. package/build/server/chunks/{6-BsZngRIA.js.map → 6-Bnw_JRXO.js.map} +1 -1
  68. package/build/server/chunks/{7-CXWUMHvV.js → 7-ZktGMDHm.js} +3 -3
  69. package/build/server/chunks/{7-CXWUMHvV.js.map → 7-ZktGMDHm.js.map} +1 -1
  70. package/build/server/chunks/{8-l173yBhm.js → 8-V3DHLq7L.js} +3 -3
  71. package/build/server/chunks/{8-l173yBhm.js.map → 8-V3DHLq7L.js.map} +1 -1
  72. package/build/server/chunks/{IconMic-BM_3hm2T.js → IconMic-DK0ZRKNm.js} +2 -2
  73. package/build/server/chunks/{IconMic-BM_3hm2T.js.map → IconMic-DK0ZRKNm.js.map} +1 -1
  74. package/build/server/chunks/{Navbar-BZ_eb99a.js → Navbar-CRs8Q1Ed.js} +5 -5
  75. package/build/server/chunks/{Navbar-BZ_eb99a.js.map → Navbar-CRs8Q1Ed.js.map} +1 -1
  76. package/build/server/chunks/{_layout.svelte-Dd-1jqRZ.js → _layout.svelte-CtPb7AoM.js} +2 -2
  77. package/build/server/chunks/{_layout.svelte-Dd-1jqRZ.js.map → _layout.svelte-CtPb7AoM.js.map} +1 -1
  78. package/build/server/chunks/{_page.svelte-Bbooaanj.js → _page.svelte-BtDkjht-.js} +7 -7
  79. package/build/server/chunks/{_page.svelte-Bbooaanj.js.map → _page.svelte-BtDkjht-.js.map} +1 -1
  80. package/build/server/chunks/{_page.svelte-D0wEoV5A.js → _page.svelte-CXr3izpr.js} +5 -5
  81. package/build/server/chunks/{_page.svelte-D0wEoV5A.js.map → _page.svelte-CXr3izpr.js.map} +1 -1
  82. package/build/server/chunks/{_page.svelte-WYgjKj38.js → _page.svelte-D6dWiRVl.js} +31 -715
  83. package/build/server/chunks/_page.svelte-D6dWiRVl.js.map +1 -0
  84. package/build/server/chunks/{_page.svelte-C4jw4RUN.js → _page.svelte-Lhm6ya_b.js} +3 -3
  85. package/build/server/chunks/{_page.svelte-C4jw4RUN.js.map → _page.svelte-Lhm6ya_b.js.map} +1 -1
  86. package/build/server/chunks/{_page.svelte-E9h2ASFv.js → _page.svelte-m5t0OVcz.js} +7 -7
  87. package/build/server/chunks/{_page.svelte-E9h2ASFv.js.map → _page.svelte-m5t0OVcz.js.map} +1 -1
  88. package/build/server/chunks/{_server.ts-_qXm__Gf.js → _server.ts-7h410aJe.js} +5 -5
  89. package/build/server/chunks/{_server.ts-_qXm__Gf.js.map → _server.ts-7h410aJe.js.map} +1 -1
  90. package/build/server/chunks/{_server.ts-Baeek88H.js → _server.ts-B-io71lH.js} +5 -5
  91. package/build/server/chunks/_server.ts-B-io71lH.js.map +1 -0
  92. package/build/server/chunks/{_server.ts-BnNG0uRK.js → _server.ts-B7oFBy_Y.js} +6 -6
  93. package/build/server/chunks/{_server.ts-BnNG0uRK.js.map → _server.ts-B7oFBy_Y.js.map} +1 -1
  94. package/build/server/chunks/{_server.ts-B8D1t67g.js → _server.ts-BEsxh5-r.js} +7 -7
  95. package/build/server/chunks/_server.ts-BEsxh5-r.js.map +1 -0
  96. package/build/server/chunks/{_server.ts-DM6Jm6KP.js → _server.ts-BFQCNuCf.js} +5 -5
  97. package/build/server/chunks/_server.ts-BFQCNuCf.js.map +1 -0
  98. package/build/server/chunks/{_server.ts-DXoq1VzO.js → _server.ts-BIJomr8k.js} +5 -5
  99. package/build/server/chunks/_server.ts-BIJomr8k.js.map +1 -0
  100. package/build/server/chunks/{_server.ts-CU5_9yaM.js → _server.ts-BJd_BeRX.js} +5 -5
  101. package/build/server/chunks/{_server.ts-CU5_9yaM.js.map → _server.ts-BJd_BeRX.js.map} +1 -1
  102. package/build/server/chunks/{_server.ts-BlVBulWB.js → _server.ts-BLnGiLfS.js} +4 -4
  103. package/build/server/chunks/_server.ts-BLnGiLfS.js.map +1 -0
  104. package/build/server/chunks/{_server.ts-Decw7JxO.js → _server.ts-BMTnompE.js} +5 -5
  105. package/build/server/chunks/_server.ts-BMTnompE.js.map +1 -0
  106. package/build/server/chunks/_server.ts-BTeSTLAx.js +89 -0
  107. package/build/server/chunks/_server.ts-BTeSTLAx.js.map +1 -0
  108. package/build/server/chunks/{_server.ts-DFV-gf9Q.js → _server.ts-BaqsSmFS.js} +5 -5
  109. package/build/server/chunks/{_server.ts-DFV-gf9Q.js.map → _server.ts-BaqsSmFS.js.map} +1 -1
  110. package/build/server/chunks/{_server.ts-C5jyYbFm.js → _server.ts-BcIPGO7x.js} +17 -8
  111. package/build/server/chunks/_server.ts-BcIPGO7x.js.map +1 -0
  112. package/build/server/chunks/{_server.ts-Bxk1V3Ev.js → _server.ts-BdPGrcpF.js} +5 -5
  113. package/build/server/chunks/{_server.ts-Bxk1V3Ev.js.map → _server.ts-BdPGrcpF.js.map} +1 -1
  114. package/build/server/chunks/{_server.ts-Bx3uIrpl.js → _server.ts-BeXMVrJG.js} +5 -5
  115. package/build/server/chunks/{_server.ts-Bx3uIrpl.js.map → _server.ts-BeXMVrJG.js.map} +1 -1
  116. package/build/server/chunks/{_server.ts-DBQ7TD4o.js → _server.ts-BghreOti.js} +5 -5
  117. package/build/server/chunks/_server.ts-BghreOti.js.map +1 -0
  118. package/build/server/chunks/{_server.ts-D4tyRvFi.js → _server.ts-Bi33i7c7.js} +2 -2
  119. package/build/server/chunks/{_server.ts-D4tyRvFi.js.map → _server.ts-Bi33i7c7.js.map} +1 -1
  120. package/build/server/chunks/{_server.ts-C_dk6ZLP.js → _server.ts-BjSX-JsT.js} +6 -6
  121. package/build/server/chunks/{_server.ts-C_dk6ZLP.js.map → _server.ts-BjSX-JsT.js.map} +1 -1
  122. package/build/server/chunks/{_server.ts-CuBCKbP8.js → _server.ts-BokcuCWE.js} +6 -6
  123. package/build/server/chunks/{_server.ts-CuBCKbP8.js.map → _server.ts-BokcuCWE.js.map} +1 -1
  124. package/build/server/chunks/{_server.ts-2fxcxBzC.js → _server.ts-BwQSiREZ.js} +5 -5
  125. package/build/server/chunks/_server.ts-BwQSiREZ.js.map +1 -0
  126. package/build/server/chunks/{_server.ts-CzgA6LXe.js → _server.ts-Bw_r9OtK.js} +5 -5
  127. package/build/server/chunks/{_server.ts-CzgA6LXe.js.map → _server.ts-Bw_r9OtK.js.map} +1 -1
  128. package/build/server/chunks/{_server.ts-DYsP_lpr.js → _server.ts-Byn8EbtL.js} +7 -7
  129. package/build/server/chunks/_server.ts-Byn8EbtL.js.map +1 -0
  130. package/build/server/chunks/{_server.ts-BRTk2wfW.js → _server.ts-C0b2kLwv.js} +5 -5
  131. package/build/server/chunks/{_server.ts-BRTk2wfW.js.map → _server.ts-C0b2kLwv.js.map} +1 -1
  132. package/build/server/chunks/{_server.ts-CFNWzRBr.js → _server.ts-C2dpWx7K.js} +4 -4
  133. package/build/server/chunks/{_server.ts-CFNWzRBr.js.map → _server.ts-C2dpWx7K.js.map} +1 -1
  134. package/build/server/chunks/{_server.ts-F0nw0UvB.js → _server.ts-C3asto5q.js} +5 -5
  135. package/build/server/chunks/{_server.ts-F0nw0UvB.js.map → _server.ts-C3asto5q.js.map} +1 -1
  136. package/build/server/chunks/{_server.ts-YRWN3sJm.js → _server.ts-C4WOD37G.js} +5 -5
  137. package/build/server/chunks/{_server.ts-YRWN3sJm.js.map → _server.ts-C4WOD37G.js.map} +1 -1
  138. package/build/server/chunks/{_server.ts-DilgsSMu.js → _server.ts-C8LFsdDG.js} +5 -5
  139. package/build/server/chunks/{_server.ts-DilgsSMu.js.map → _server.ts-C8LFsdDG.js.map} +1 -1
  140. package/build/server/chunks/{_server.ts-wvbMWir6.js → _server.ts-C8xyXBY5.js} +6 -6
  141. package/build/server/chunks/{_server.ts-wvbMWir6.js.map → _server.ts-C8xyXBY5.js.map} +1 -1
  142. package/build/server/chunks/{_server.ts-Dq8RxTkW.js → _server.ts-CAlt9gW0.js} +5 -5
  143. package/build/server/chunks/{_server.ts-Dq8RxTkW.js.map → _server.ts-CAlt9gW0.js.map} +1 -1
  144. package/build/server/chunks/{_server.ts-DPDQh75Z.js → _server.ts-CBEVK-Yt.js} +2 -2
  145. package/build/server/chunks/{_server.ts-DPDQh75Z.js.map → _server.ts-CBEVK-Yt.js.map} +1 -1
  146. package/build/server/chunks/_server.ts-CGzgULKV.js +84 -0
  147. package/build/server/chunks/_server.ts-CGzgULKV.js.map +1 -0
  148. package/build/server/chunks/{_server.ts-B9iU6foL.js → _server.ts-CJWPhww2.js} +5 -5
  149. package/build/server/chunks/{_server.ts-B9iU6foL.js.map → _server.ts-CJWPhww2.js.map} +1 -1
  150. package/build/server/chunks/{_server.ts-ChH8nHr7.js → _server.ts-CLt4mqCt.js} +7 -7
  151. package/build/server/chunks/{_server.ts-ChH8nHr7.js.map → _server.ts-CLt4mqCt.js.map} +1 -1
  152. package/build/server/chunks/{_server.ts-CM1BFa2O.js → _server.ts-CQH5FEPp.js} +6 -6
  153. package/build/server/chunks/_server.ts-CQH5FEPp.js.map +1 -0
  154. package/build/server/chunks/{_server.ts-IW-zQmmb.js → _server.ts-CRY9d7-F.js} +5 -5
  155. package/build/server/chunks/_server.ts-CRY9d7-F.js.map +1 -0
  156. package/build/server/chunks/{_server.ts-DR7y5OQ3.js → _server.ts-CWNf8Ve1.js} +5 -5
  157. package/build/server/chunks/{_server.ts-DR7y5OQ3.js.map → _server.ts-CWNf8Ve1.js.map} +1 -1
  158. package/build/server/chunks/{_server.ts-CmyqMhn9.js → _server.ts-C_qyw2yL.js} +5 -5
  159. package/build/server/chunks/{_server.ts-CmyqMhn9.js.map → _server.ts-C_qyw2yL.js.map} +1 -1
  160. package/build/server/chunks/{_server.ts-CRVqyjYH.js → _server.ts-CaZ1wy9x.js} +7 -7
  161. package/build/server/chunks/{_server.ts-CRVqyjYH.js.map → _server.ts-CaZ1wy9x.js.map} +1 -1
  162. package/build/server/chunks/{_server.ts-kfc0Us0E.js → _server.ts-Cdq3e7xA.js} +5 -5
  163. package/build/server/chunks/{_server.ts-kfc0Us0E.js.map → _server.ts-Cdq3e7xA.js.map} +1 -1
  164. package/build/server/chunks/{_server.ts-WePF2DAq.js → _server.ts-ChI4fTd4.js} +5 -5
  165. package/build/server/chunks/_server.ts-ChI4fTd4.js.map +1 -0
  166. package/build/server/chunks/{_server.ts-DzCUdAPH.js → _server.ts-CiWKQbiz.js} +5 -5
  167. package/build/server/chunks/{_server.ts-DzCUdAPH.js.map → _server.ts-CiWKQbiz.js.map} +1 -1
  168. package/build/server/chunks/{_server.ts-Dcawi9b4.js → _server.ts-CtVWuskm.js} +2 -2
  169. package/build/server/chunks/_server.ts-CtVWuskm.js.map +1 -0
  170. package/build/server/chunks/{_server.ts-FPubTa2q.js → _server.ts-CwPqNJOY.js} +5 -5
  171. package/build/server/chunks/{_server.ts-FPubTa2q.js.map → _server.ts-CwPqNJOY.js.map} +1 -1
  172. package/build/server/chunks/{_server.ts-DdzFOqZm.js → _server.ts-D-pLD7Xu.js} +5 -5
  173. package/build/server/chunks/{_server.ts-DdzFOqZm.js.map → _server.ts-D-pLD7Xu.js.map} +1 -1
  174. package/build/server/chunks/{_server.ts-CQM2RG5K.js → _server.ts-D0RXp78c.js} +5 -5
  175. package/build/server/chunks/{_server.ts-CQM2RG5K.js.map → _server.ts-D0RXp78c.js.map} +1 -1
  176. package/build/server/chunks/{_server.ts-DRvqTDLx.js → _server.ts-D9jCVXyy.js} +5 -5
  177. package/build/server/chunks/_server.ts-D9jCVXyy.js.map +1 -0
  178. package/build/server/chunks/{_server.ts-BMCfB7xN.js → _server.ts-DBFkIfX3.js} +5 -5
  179. package/build/server/chunks/{_server.ts-BMCfB7xN.js.map → _server.ts-DBFkIfX3.js.map} +1 -1
  180. package/build/server/chunks/{_server.ts-D-jGSj8O.js → _server.ts-DBRLxv1J.js} +6 -6
  181. package/build/server/chunks/{_server.ts-D-jGSj8O.js.map → _server.ts-DBRLxv1J.js.map} +1 -1
  182. package/build/server/chunks/{_server.ts-Cap2Myq0.js → _server.ts-DH2KwFMm.js} +9 -6
  183. package/build/server/chunks/_server.ts-DH2KwFMm.js.map +1 -0
  184. package/build/server/chunks/{_server.ts-0UwoVmus.js → _server.ts-DN9DIE7V.js} +6 -6
  185. package/build/server/chunks/{_server.ts-0UwoVmus.js.map → _server.ts-DN9DIE7V.js.map} +1 -1
  186. package/build/server/chunks/{_server.ts-Brb7lRFE.js → _server.ts-DNQDl4In.js} +5 -5
  187. package/build/server/chunks/_server.ts-DNQDl4In.js.map +1 -0
  188. package/build/server/chunks/{_server.ts-D07mQlNk.js → _server.ts-DQCc-bcg.js} +5 -5
  189. package/build/server/chunks/{_server.ts-D07mQlNk.js.map → _server.ts-DQCc-bcg.js.map} +1 -1
  190. package/build/server/chunks/{_server.ts-VvJjpVtp.js → _server.ts-DVJYo8_h.js} +6 -6
  191. package/build/server/chunks/{_server.ts-VvJjpVtp.js.map → _server.ts-DVJYo8_h.js.map} +1 -1
  192. package/build/server/chunks/{_server.ts-5M6DY-PN.js → _server.ts-DXMBj9CH.js} +8 -8
  193. package/build/server/chunks/{_server.ts-5M6DY-PN.js.map → _server.ts-DXMBj9CH.js.map} +1 -1
  194. package/build/server/chunks/{_server.ts-DX3B53H8.js → _server.ts-DY8vqCzu.js} +5 -5
  195. package/build/server/chunks/{_server.ts-DX3B53H8.js.map → _server.ts-DY8vqCzu.js.map} +1 -1
  196. package/build/server/chunks/{_server.ts-C9-ewPaY.js → _server.ts-D_iVYIT5.js} +5 -5
  197. package/build/server/chunks/_server.ts-D_iVYIT5.js.map +1 -0
  198. package/build/server/chunks/{_server.ts-Dg4ouUjZ.js → _server.ts-Dc-DuHRl.js} +5 -5
  199. package/build/server/chunks/_server.ts-Dc-DuHRl.js.map +1 -0
  200. package/build/server/chunks/{_server.ts-CQt3NLuS.js → _server.ts-DeDvsRmd.js} +5 -5
  201. package/build/server/chunks/{_server.ts-CQt3NLuS.js.map → _server.ts-DeDvsRmd.js.map} +1 -1
  202. package/build/server/chunks/{_server.ts-Bi5ToBtl.js → _server.ts-DgU1uBsl.js} +5 -5
  203. package/build/server/chunks/{_server.ts-Bi5ToBtl.js.map → _server.ts-DgU1uBsl.js.map} +1 -1
  204. package/build/server/chunks/{_server.ts-DSfVK8xc.js → _server.ts-DiUBKtYa.js} +5 -5
  205. package/build/server/chunks/{_server.ts-DSfVK8xc.js.map → _server.ts-DiUBKtYa.js.map} +1 -1
  206. package/build/server/chunks/{_server.ts-CwPiZPmZ.js → _server.ts-DlONqa0N.js} +6 -6
  207. package/build/server/chunks/{_server.ts-CwPiZPmZ.js.map → _server.ts-DlONqa0N.js.map} +1 -1
  208. package/build/server/chunks/{_server.ts-Cb-e8WyG.js → _server.ts-Do8_4nUh.js} +5 -5
  209. package/build/server/chunks/{_server.ts-Cb-e8WyG.js.map → _server.ts-Do8_4nUh.js.map} +1 -1
  210. package/build/server/chunks/{_server.ts-lK-oXISB.js → _server.ts-DtVcRD5A.js} +5 -5
  211. package/build/server/chunks/{_server.ts-lK-oXISB.js.map → _server.ts-DtVcRD5A.js.map} +1 -1
  212. package/build/server/chunks/{_server.ts-hAoIbHpc.js → _server.ts-DueQnU1L.js} +6 -6
  213. package/build/server/chunks/{_server.ts-hAoIbHpc.js.map → _server.ts-DueQnU1L.js.map} +1 -1
  214. package/build/server/chunks/{_server.ts-aw8KYE5U.js → _server.ts-DvsmHJew.js} +5 -5
  215. package/build/server/chunks/{_server.ts-aw8KYE5U.js.map → _server.ts-DvsmHJew.js.map} +1 -1
  216. package/build/server/chunks/{_server.ts-DUy4kkr_.js → _server.ts-DxYoYjKM.js} +5 -5
  217. package/build/server/chunks/{_server.ts-DUy4kkr_.js.map → _server.ts-DxYoYjKM.js.map} +1 -1
  218. package/build/server/chunks/{_server.ts-BDe-TnAi.js → _server.ts-Eq4SzuV_.js} +5 -5
  219. package/build/server/chunks/{_server.ts-BDe-TnAi.js.map → _server.ts-Eq4SzuV_.js.map} +1 -1
  220. package/build/server/chunks/{_server.ts-DDCEmU_P.js → _server.ts-KuD8Wpms.js} +6 -10
  221. package/build/server/chunks/_server.ts-KuD8Wpms.js.map +1 -0
  222. package/build/server/chunks/{_server.ts-BnL3TLuz.js → _server.ts-Q60q44Je.js} +5 -5
  223. package/build/server/chunks/{_server.ts-BnL3TLuz.js.map → _server.ts-Q60q44Je.js.map} +1 -1
  224. package/build/server/chunks/{_server.ts-DMj9WYdv.js → _server.ts-RfzeE7tM.js} +2 -2
  225. package/build/server/chunks/{_server.ts-DMj9WYdv.js.map → _server.ts-RfzeE7tM.js.map} +1 -1
  226. package/build/server/chunks/{_server.ts-B6AN-mYa.js → _server.ts-Rigt7lcd.js} +7 -7
  227. package/build/server/chunks/{_server.ts-B6AN-mYa.js.map → _server.ts-Rigt7lcd.js.map} +1 -1
  228. package/build/server/chunks/{_server.ts-C7Scn_Ur.js → _server.ts-XhNvTVYt.js} +5 -5
  229. package/build/server/chunks/_server.ts-XhNvTVYt.js.map +1 -0
  230. package/build/server/chunks/{_server.ts-BETcFeB8.js → _server.ts-Zui06dcA.js} +5 -5
  231. package/build/server/chunks/_server.ts-Zui06dcA.js.map +1 -0
  232. package/build/server/chunks/{_server.ts-BwnoppTC.js → _server.ts-a1r-EHX0.js} +6 -6
  233. package/build/server/chunks/{_server.ts-BwnoppTC.js.map → _server.ts-a1r-EHX0.js.map} +1 -1
  234. package/build/server/chunks/{_server.ts-CosKSZGO.js → _server.ts-cHc1drrp.js} +2 -2
  235. package/build/server/chunks/{_server.ts-CosKSZGO.js.map → _server.ts-cHc1drrp.js.map} +1 -1
  236. package/build/server/chunks/{_server.ts-B5PHfuR5.js → _server.ts-eYpUsioT.js} +6 -6
  237. package/build/server/chunks/{_server.ts-B5PHfuR5.js.map → _server.ts-eYpUsioT.js.map} +1 -1
  238. package/build/server/chunks/{_server.ts-CGMuaSY3.js → _server.ts-iKClbuyO.js} +5 -5
  239. package/build/server/chunks/{_server.ts-CGMuaSY3.js.map → _server.ts-iKClbuyO.js.map} +1 -1
  240. package/build/server/chunks/{_server.ts-C37SDJxC.js → _server.ts-j1haXquD.js} +5 -5
  241. package/build/server/chunks/{_server.ts-C37SDJxC.js.map → _server.ts-j1haXquD.js.map} +1 -1
  242. package/build/server/chunks/{_server.ts-BW46dP9B.js → _server.ts-k5rG5cUI.js} +7 -7
  243. package/build/server/chunks/{_server.ts-BW46dP9B.js.map → _server.ts-k5rG5cUI.js.map} +1 -1
  244. package/build/server/chunks/{_server.ts-5aqdy9Zn.js → _server.ts-k9P3ZBDK.js} +25 -17
  245. package/build/server/chunks/_server.ts-k9P3ZBDK.js.map +1 -0
  246. package/build/server/chunks/{_server.ts-CcyVh5fg.js → _server.ts-ll-0r5dM.js} +5 -5
  247. package/build/server/chunks/{_server.ts-CcyVh5fg.js.map → _server.ts-ll-0r5dM.js.map} +1 -1
  248. package/build/server/chunks/{_server.ts-r07PDC8q.js → _server.ts-m1RQkdUW.js} +5 -5
  249. package/build/server/chunks/{_server.ts-r07PDC8q.js.map → _server.ts-m1RQkdUW.js.map} +1 -1
  250. package/build/server/chunks/{_server.ts-avgx1pPX.js → _server.ts-nVEAwKYe.js} +5 -5
  251. package/build/server/chunks/{_server.ts-avgx1pPX.js.map → _server.ts-nVEAwKYe.js.map} +1 -1
  252. package/build/server/chunks/{_server.ts-DP28Ocqs.js → _server.ts-vZTWdH4v.js} +5 -5
  253. package/build/server/chunks/{_server.ts-DP28Ocqs.js.map → _server.ts-vZTWdH4v.js.map} +1 -1
  254. package/build/server/chunks/{_server.ts-DiDI1Ie6.js → _server.ts-vpAn0Uxn.js} +6 -6
  255. package/build/server/chunks/{_server.ts-DiDI1Ie6.js.map → _server.ts-vpAn0Uxn.js.map} +1 -1
  256. package/build/server/chunks/{addon-helpers-ChYTbRSK.js → addon-helpers-kNrSUlMe.js} +3 -3
  257. package/build/server/chunks/addon-helpers-kNrSUlMe.js.map +1 -0
  258. package/build/server/chunks/{akm-BLz9zl09.js → akm-IP8X7RlR.js} +2 -2
  259. package/build/server/chunks/{akm-BLz9zl09.js.map → akm-IP8X7RlR.js.map} +1 -1
  260. package/build/server/chunks/{catalog-CY6FvvAs.js → catalog-DcLI63rn.js} +5 -5
  261. package/build/server/chunks/{catalog-CY6FvvAs.js.map → catalog-DcLI63rn.js.map} +1 -1
  262. package/build/server/chunks/{client-FcHtkEV-.js → client-CIUwkogU.js} +2 -2
  263. package/build/server/chunks/{client-FcHtkEV-.js.map → client-CIUwkogU.js.map} +1 -1
  264. package/build/server/chunks/{config-WS3yDsjb.js → config-EKy5PAZU.js} +2 -2
  265. package/build/server/chunks/{config-WS3yDsjb.js.map → config-EKy5PAZU.js.map} +1 -1
  266. package/build/server/chunks/{docker-CDcBV4aX.js → docker-BhJS_Y28.js} +2 -2
  267. package/build/server/chunks/{docker-CDcBV4aX.js.map → docker-BhJS_Y28.js.map} +1 -1
  268. package/build/server/chunks/{endpoints-BnI8UQUm.js → endpoints-Dq-IqF1t.js} +2 -2
  269. package/build/server/chunks/{endpoints-BnI8UQUm.js.map → endpoints-Dq-IqF1t.js.map} +1 -1
  270. package/build/server/chunks/{error.svelte-DeB-Po5T.js → error.svelte-Dbj-WAaz.js} +4 -4
  271. package/build/server/chunks/{error.svelte-DeB-Po5T.js.map → error.svelte-Dbj-WAaz.js.map} +1 -1
  272. package/build/server/chunks/{helpers-uzTc9A0Q.js → helpers-s8d3gE38.js} +3 -3
  273. package/build/server/chunks/{helpers-uzTc9A0Q.js.map → helpers-s8d3gE38.js.map} +1 -1
  274. package/build/server/chunks/{hooks.server-DaC85A-N.js → hooks.server-Cy1D3efR.js} +7 -7
  275. package/build/server/chunks/hooks.server-Cy1D3efR.js.map +1 -0
  276. package/build/server/chunks/{http-DWCniA5n.js → http-BCF8LO-V.js} +2 -2
  277. package/build/server/chunks/{http-DWCniA5n.js.map → http-BCF8LO-V.js.map} +1 -1
  278. package/build/server/chunks/{internal-DRthfYRK.js → internal-CcLms467.js} +3 -3
  279. package/build/server/chunks/{internal-DRthfYRK.js.map → internal-CcLms467.js.map} +1 -1
  280. package/build/server/chunks/{migration-status-Blvg_RFt.js → migration-status-BgiG_Rm6.js} +2 -2
  281. package/build/server/chunks/{migration-status-Blvg_RFt.js.map → migration-status-BgiG_Rm6.js.map} +1 -1
  282. package/build/server/chunks/{session-cookie-DOONPnJ5.js → session-cookie-F6DkHp5H.js} +2 -2
  283. package/build/server/chunks/{session-cookie-DOONPnJ5.js.map → session-cookie-F6DkHp5H.js.map} +1 -1
  284. package/build/server/chunks/{setup-deploy-CeeF_6ze.js → setup-deploy-BtgW_nbb.js} +2 -2
  285. package/build/server/chunks/{setup-deploy-CeeF_6ze.js.map → setup-deploy-BtgW_nbb.js.map} +1 -1
  286. package/build/server/chunks/{src-B3g4Ry1X.js → src-BN-m14sE.js} +198 -639
  287. package/build/server/chunks/src-BN-m14sE.js.map +1 -0
  288. package/build/server/chunks/{state-CL9Kv-vm.js → state-BjAIjYtQ.js} +2 -2
  289. package/build/server/chunks/{state-CL9Kv-vm.js.map → state-BjAIjYtQ.js.map} +1 -1
  290. package/build/server/chunks/{state2-Cim9_nHe.js → state2-CeseXnTO.js} +2 -2
  291. package/build/server/chunks/{state2-Cim9_nHe.js.map → state2-CeseXnTO.js.map} +1 -1
  292. package/build/server/chunks/{theme-state.svelte-BgBXJ060.js → theme-state.svelte-DshW_ZYI.js} +2 -81
  293. package/build/server/chunks/theme-state.svelte-DshW_ZYI.js.map +1 -0
  294. package/build/server/index.js +32 -2
  295. package/build/server/index.js.map +1 -1
  296. package/build/server/manifest.js +93 -107
  297. package/build/server/manifest.js.map +1 -1
  298. package/package.json +2 -2
  299. package/build/client/_app/immutable/assets/4.BLk6Mqyj.css +0 -1
  300. package/build/client/_app/immutable/assets/4.BLk6Mqyj.css.br +0 -0
  301. package/build/client/_app/immutable/assets/4.BLk6Mqyj.css.gz +0 -0
  302. package/build/client/_app/immutable/chunks/B8C5qi9U.js.br +0 -0
  303. package/build/client/_app/immutable/chunks/B8C5qi9U.js.gz +0 -0
  304. package/build/client/_app/immutable/chunks/Br6Mrpf0.js +0 -3
  305. package/build/client/_app/immutable/chunks/Br6Mrpf0.js.br +0 -0
  306. package/build/client/_app/immutable/chunks/Br6Mrpf0.js.gz +0 -0
  307. package/build/client/_app/immutable/chunks/CLgRRUN_.js.br +0 -0
  308. package/build/client/_app/immutable/chunks/CLgRRUN_.js.gz +0 -0
  309. package/build/client/_app/immutable/chunks/Ch85wCT5.js +0 -1
  310. package/build/client/_app/immutable/chunks/Ch85wCT5.js.br +0 -2
  311. package/build/client/_app/immutable/chunks/Ch85wCT5.js.gz +0 -0
  312. package/build/client/_app/immutable/chunks/DRHnoVLf.js +0 -1
  313. package/build/client/_app/immutable/chunks/DRHnoVLf.js.br +0 -0
  314. package/build/client/_app/immutable/chunks/DRHnoVLf.js.gz +0 -0
  315. package/build/client/_app/immutable/chunks/DYXGFYr6.js.br +0 -0
  316. package/build/client/_app/immutable/chunks/DYXGFYr6.js.gz +0 -0
  317. package/build/client/_app/immutable/chunks/Dcw6L0GF.js.br +0 -0
  318. package/build/client/_app/immutable/chunks/Dcw6L0GF.js.gz +0 -0
  319. package/build/client/_app/immutable/entry/app.CVxCoIFs.js.br +0 -0
  320. package/build/client/_app/immutable/entry/app.CVxCoIFs.js.gz +0 -0
  321. package/build/client/_app/immutable/entry/start.CQqNtgHJ.js +0 -1
  322. package/build/client/_app/immutable/entry/start.CQqNtgHJ.js.br +0 -0
  323. package/build/client/_app/immutable/entry/start.CQqNtgHJ.js.gz +0 -0
  324. package/build/client/_app/immutable/nodes/0.Bb8qAGW8.js.br +0 -0
  325. package/build/client/_app/immutable/nodes/0.Bb8qAGW8.js.gz +0 -0
  326. package/build/client/_app/immutable/nodes/1.Co_TaqLI.js.br +0 -2
  327. package/build/client/_app/immutable/nodes/1.Co_TaqLI.js.gz +0 -0
  328. package/build/client/_app/immutable/nodes/4.agNu3Ryl.js +0 -130
  329. package/build/client/_app/immutable/nodes/4.agNu3Ryl.js.br +0 -0
  330. package/build/client/_app/immutable/nodes/4.agNu3Ryl.js.gz +0 -0
  331. package/build/client/_app/immutable/nodes/5.Fw13EXte.js.br +0 -0
  332. package/build/client/_app/immutable/nodes/5.Fw13EXte.js.gz +0 -0
  333. package/build/client/_app/immutable/nodes/6.CWy0yXnu.js.br +0 -0
  334. package/build/client/_app/immutable/nodes/6.CWy0yXnu.js.gz +0 -0
  335. package/build/client/_app/immutable/nodes/7.CsM4M8Ul.js.br +0 -0
  336. package/build/client/_app/immutable/nodes/7.CsM4M8Ul.js.gz +0 -0
  337. package/build/client/_app/immutable/nodes/8.V6hY0p8a.js.br +0 -0
  338. package/build/client/_app/immutable/nodes/8.V6hY0p8a.js.gz +0 -0
  339. package/build/server/chunks/1-DvZDBGww.js +0 -9
  340. package/build/server/chunks/10-C96Thueb.js.map +0 -1
  341. package/build/server/chunks/4-BYdi8hv_.js +0 -9
  342. package/build/server/chunks/6-BsZngRIA.js +0 -9
  343. package/build/server/chunks/_page.svelte-WYgjKj38.js.map +0 -1
  344. package/build/server/chunks/_server.ts-2fxcxBzC.js.map +0 -1
  345. package/build/server/chunks/_server.ts-5aqdy9Zn.js.map +0 -1
  346. package/build/server/chunks/_server.ts-B8D1t67g.js.map +0 -1
  347. package/build/server/chunks/_server.ts-BETcFeB8.js.map +0 -1
  348. package/build/server/chunks/_server.ts-BM0AExGa.js +0 -121
  349. package/build/server/chunks/_server.ts-BM0AExGa.js.map +0 -1
  350. package/build/server/chunks/_server.ts-Baeek88H.js.map +0 -1
  351. package/build/server/chunks/_server.ts-BlVBulWB.js.map +0 -1
  352. package/build/server/chunks/_server.ts-Brb7lRFE.js.map +0 -1
  353. package/build/server/chunks/_server.ts-C5jyYbFm.js.map +0 -1
  354. package/build/server/chunks/_server.ts-C7Scn_Ur.js.map +0 -1
  355. package/build/server/chunks/_server.ts-C9-ewPaY.js.map +0 -1
  356. package/build/server/chunks/_server.ts-CM1BFa2O.js.map +0 -1
  357. package/build/server/chunks/_server.ts-Cap2Myq0.js.map +0 -1
  358. package/build/server/chunks/_server.ts-DBQ7TD4o.js.map +0 -1
  359. package/build/server/chunks/_server.ts-DDCEmU_P.js.map +0 -1
  360. package/build/server/chunks/_server.ts-DLLNA3jY.js +0 -47
  361. package/build/server/chunks/_server.ts-DLLNA3jY.js.map +0 -1
  362. package/build/server/chunks/_server.ts-DM6Jm6KP.js.map +0 -1
  363. package/build/server/chunks/_server.ts-DRvqTDLx.js.map +0 -1
  364. package/build/server/chunks/_server.ts-DXoq1VzO.js.map +0 -1
  365. package/build/server/chunks/_server.ts-DYsP_lpr.js.map +0 -1
  366. package/build/server/chunks/_server.ts-DZ-yNYeI.js +0 -64
  367. package/build/server/chunks/_server.ts-DZ-yNYeI.js.map +0 -1
  368. package/build/server/chunks/_server.ts-Dcawi9b4.js.map +0 -1
  369. package/build/server/chunks/_server.ts-Decw7JxO.js.map +0 -1
  370. package/build/server/chunks/_server.ts-Dg4ouUjZ.js.map +0 -1
  371. package/build/server/chunks/_server.ts-IW-zQmmb.js.map +0 -1
  372. package/build/server/chunks/_server.ts-WePF2DAq.js.map +0 -1
  373. package/build/server/chunks/_server.ts-k339Bhm3.js +0 -88
  374. package/build/server/chunks/_server.ts-k339Bhm3.js.map +0 -1
  375. package/build/server/chunks/addon-helpers-ChYTbRSK.js.map +0 -1
  376. package/build/server/chunks/environment-D-dkDBwd.js +0 -36
  377. package/build/server/chunks/environment-D-dkDBwd.js.map +0 -1
  378. package/build/server/chunks/hooks.server-DaC85A-N.js.map +0 -1
  379. package/build/server/chunks/src-B3g4Ry1X.js.map +0 -1
  380. package/build/server/chunks/theme-state.svelte-BgBXJ060.js.map +0 -1
  381. package/build/server/chunks/version-cache-CSnmLqxQ.js +0 -54
  382. package/build/server/chunks/version-cache-CSnmLqxQ.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-DFV-gf9Q.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/migrate-apply/_server.ts.js"],"sourcesContent":["import { Tn as createLogger, cn as MigrationError, ln as ensureMigrated, sn as BackupSpaceError } from \"../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../chunks/state.js\";\nimport { d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId } from \"../../../../chunks/helpers.js\";\n//#region src/routes/admin/migrate-apply/+server.ts\nvar logger = createLogger(\"migrate-apply\");\n/**\n* Apply the pending on-disk migration and report the result. This is the\n* lightweight counterpart to /admin/migrate-preview: it runs the REAL\n* `ensureMigrated()` (layout migrations + release migrations up to the home's\n* recorded version), which takes a full-home backup first and is idempotent.\n*\n* Unlike /admin/upgrade this does NOT pull images or recreate containers — it\n* only reconciles the home directory so the splash \"invalid state\" landing can\n* unblock a user whose home needs migrating, then route them onward.\n*\n* BackupSpaceError (the pre-backup free-space guard) is surfaced as 409 with the\n* estimate so the UI can ask the user to confirm before retrying with\n* `confirmLowSpace: true`. Nothing is modified when that fires.\n*/\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tlet body;\n\ttry {\n\t\tbody = await event.request.json();\n\t} catch {\n\t\tbody = {};\n\t}\n\tconst confirmLowSpace = body.confirmLowSpace === true;\n\tconst state = getState();\n\tconst lines = [];\n\ttry {\n\t\tconst report = ensureMigrated({\n\t\t\thomeDir: state.homeDir,\n\t\t\tconfirmLowSpace,\n\t\t\tlog: (m) => lines.push(m)\n\t\t});\n\t\tlogger.info(\"migration applied\", {\n\t\t\trequestId,\n\t\t\tmigrated: report.migrated,\n\t\t\tfrom: report.from,\n\t\t\tto: report.to,\n\t\t\treleaseApplied: report.releaseApplied,\n\t\t\tbackupDir: report.backupDir\n\t\t});\n\t\treturn jsonResponse(200, {\n\t\t\tok: true,\n\t\t\tmigrated: report.migrated,\n\t\t\tfrom: report.from,\n\t\t\tto: report.to,\n\t\t\tapplied: report.applied,\n\t\t\treleaseFrom: report.releaseFrom,\n\t\t\treleaseTo: report.releaseTo,\n\t\t\treleaseApplied: report.releaseApplied,\n\t\t\tbackupDir: report.backupDir,\n\t\t\tnotes: report.notes,\n\t\t\tlines\n\t\t}, requestId);\n\t} catch (e) {\n\t\tif (e instanceof BackupSpaceError) {\n\t\t\tlogger.warn(\"migration blocked: low free space\", {\n\t\t\t\trequestId,\n\t\t\t\testimatedBytes: e.estimatedBytes,\n\t\t\t\tfreeBytes: e.freeBytes\n\t\t\t});\n\t\t\treturn errorResponse(409, \"low_space\", e.message, {\n\t\t\t\tguidance: e.guidance,\n\t\t\t\testimatedBytes: e.estimatedBytes,\n\t\t\t\tfreeBytes: e.freeBytes,\n\t\t\t\tconfirmable: true\n\t\t\t}, requestId);\n\t\t}\n\t\tif (e instanceof MigrationError) {\n\t\t\tlogger.error(\"migration failed\", {\n\t\t\t\trequestId,\n\t\t\t\terror: e.message,\n\t\t\t\tbackupDir: e.backupDir\n\t\t\t});\n\t\t\treturn errorResponse(500, \"migration_failed\", e.message, {\n\t\t\t\tguidance: e.guidance,\n\t\t\t\tbackupDir: e.backupDir,\n\t\t\t\tlines\n\t\t\t}, requestId);\n\t\t}\n\t\tconst msg = e instanceof Error ? e.message : String(e);\n\t\tlogger.error(\"migration failed (unexpected)\", {\n\t\t\trequestId,\n\t\t\terror: msg\n\t\t});\n\t\treturn errorResponse(500, \"migration_failed\", msg, { lines }, requestId);\n\t}\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"_server.ts-BaqsSmFS.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/migrate-apply/_server.ts.js"],"sourcesContent":["import { hn as createLogger, nn as MigrationError, rn as ensureMigrated, tn as BackupSpaceError } from \"../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../chunks/state.js\";\nimport { d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId } from \"../../../../chunks/helpers.js\";\n//#region src/routes/admin/migrate-apply/+server.ts\nvar logger = createLogger(\"migrate-apply\");\n/**\n* Apply the pending on-disk migration and report the result. This is the\n* lightweight counterpart to /admin/migrate-preview: it runs the REAL\n* `ensureMigrated()` (layout migrations + release migrations up to the home's\n* recorded version), which takes a full-home backup first and is idempotent.\n*\n* Unlike /admin/upgrade this does NOT pull images or recreate containers — it\n* only reconciles the home directory so the splash \"invalid state\" landing can\n* unblock a user whose home needs migrating, then route them onward.\n*\n* BackupSpaceError (the pre-backup free-space guard) is surfaced as 409 with the\n* estimate so the UI can ask the user to confirm before retrying with\n* `confirmLowSpace: true`. Nothing is modified when that fires.\n*/\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tlet body;\n\ttry {\n\t\tbody = await event.request.json();\n\t} catch {\n\t\tbody = {};\n\t}\n\tconst confirmLowSpace = body.confirmLowSpace === true;\n\tconst state = getState();\n\tconst lines = [];\n\ttry {\n\t\tconst report = ensureMigrated({\n\t\t\thomeDir: state.homeDir,\n\t\t\tconfirmLowSpace,\n\t\t\tlog: (m) => lines.push(m)\n\t\t});\n\t\tlogger.info(\"migration applied\", {\n\t\t\trequestId,\n\t\t\tmigrated: report.migrated,\n\t\t\tfrom: report.from,\n\t\t\tto: report.to,\n\t\t\treleaseApplied: report.releaseApplied,\n\t\t\tbackupDir: report.backupDir\n\t\t});\n\t\treturn jsonResponse(200, {\n\t\t\tok: true,\n\t\t\tmigrated: report.migrated,\n\t\t\tfrom: report.from,\n\t\t\tto: report.to,\n\t\t\tapplied: report.applied,\n\t\t\treleaseFrom: report.releaseFrom,\n\t\t\treleaseTo: report.releaseTo,\n\t\t\treleaseApplied: report.releaseApplied,\n\t\t\tbackupDir: report.backupDir,\n\t\t\tnotes: report.notes,\n\t\t\tlines\n\t\t}, requestId);\n\t} catch (e) {\n\t\tif (e instanceof BackupSpaceError) {\n\t\t\tlogger.warn(\"migration blocked: low free space\", {\n\t\t\t\trequestId,\n\t\t\t\testimatedBytes: e.estimatedBytes,\n\t\t\t\tfreeBytes: e.freeBytes\n\t\t\t});\n\t\t\treturn errorResponse(409, \"low_space\", e.message, {\n\t\t\t\tguidance: e.guidance,\n\t\t\t\testimatedBytes: e.estimatedBytes,\n\t\t\t\tfreeBytes: e.freeBytes,\n\t\t\t\tconfirmable: true\n\t\t\t}, requestId);\n\t\t}\n\t\tif (e instanceof MigrationError) {\n\t\t\tlogger.error(\"migration failed\", {\n\t\t\t\trequestId,\n\t\t\t\terror: e.message,\n\t\t\t\tbackupDir: e.backupDir\n\t\t\t});\n\t\t\treturn errorResponse(500, \"migration_failed\", e.message, {\n\t\t\t\tguidance: e.guidance,\n\t\t\t\tbackupDir: e.backupDir,\n\t\t\t\tlines\n\t\t\t}, requestId);\n\t\t}\n\t\tconst msg = e instanceof Error ? e.message : String(e);\n\t\tlogger.error(\"migration failed (unexpected)\", {\n\t\t\trequestId,\n\t\t\terror: msg\n\t\t});\n\t\treturn errorResponse(500, \"migration_failed\", msg, { lines }, requestId);\n\t}\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACA,IAAI,MAAM,GAAG,YAAY,CAAC,eAAe,CAAC;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,IAAI,IAAI;AACT,CAAC,IAAI;AACL,EAAE,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE;AACnC,CAAC,CAAC,CAAC,MAAM;AACT,EAAE,IAAI,GAAG,EAAE;AACX,CAAC;AACD,CAAC,MAAM,eAAe,GAAG,IAAI,CAAC,eAAe,KAAK,IAAI;AACtD,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,MAAM,KAAK,GAAG,EAAE;AACjB,CAAC,IAAI;AACL,EAAE,MAAM,MAAM,GAAG,cAAc,CAAC;AAChC,GAAG,OAAO,EAAE,KAAK,CAAC,OAAO;AACzB,GAAG,eAAe;AAClB,GAAG,GAAG,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC;AAC3B,GAAG,CAAC;AACJ,EAAE,MAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE;AACnC,GAAG,SAAS;AACZ,GAAG,QAAQ,EAAE,MAAM,CAAC,QAAQ;AAC5B,GAAG,IAAI,EAAE,MAAM,CAAC,IAAI;AACpB,GAAG,EAAE,EAAE,MAAM,CAAC,EAAE;AAChB,GAAG,cAAc,EAAE,MAAM,CAAC,cAAc;AACxC,GAAG,SAAS,EAAE,MAAM,CAAC;AACrB,GAAG,CAAC;AACJ,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AAC3B,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,QAAQ,EAAE,MAAM,CAAC,QAAQ;AAC5B,GAAG,IAAI,EAAE,MAAM,CAAC,IAAI;AACpB,GAAG,EAAE,EAAE,MAAM,CAAC,EAAE;AAChB,GAAG,OAAO,EAAE,MAAM,CAAC,OAAO;AAC1B,GAAG,WAAW,EAAE,MAAM,CAAC,WAAW;AAClC,GAAG,SAAS,EAAE,MAAM,CAAC,SAAS;AAC9B,GAAG,cAAc,EAAE,MAAM,CAAC,cAAc;AACxC,GAAG,SAAS,EAAE,MAAM,CAAC,SAAS;AAC9B,GAAG,KAAK,EAAE,MAAM,CAAC,KAAK;AACtB,GAAG;AACH,GAAG,EAAE,SAAS,CAAC;AACf,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE;AACb,EAAE,IAAI,CAAC,YAAY,gBAAgB,EAAE;AACrC,GAAG,MAAM,CAAC,IAAI,CAAC,mCAAmC,EAAE;AACpD,IAAI,SAAS;AACb,IAAI,cAAc,EAAE,CAAC,CAAC,cAAc;AACpC,IAAI,SAAS,EAAE,CAAC,CAAC;AACjB,IAAI,CAAC;AACL,GAAG,OAAO,aAAa,CAAC,GAAG,EAAE,WAAW,EAAE,CAAC,CAAC,OAAO,EAAE;AACrD,IAAI,QAAQ,EAAE,CAAC,CAAC,QAAQ;AACxB,IAAI,cAAc,EAAE,CAAC,CAAC,cAAc;AACpC,IAAI,SAAS,EAAE,CAAC,CAAC,SAAS;AAC1B,IAAI,WAAW,EAAE;AACjB,IAAI,EAAE,SAAS,CAAC;AAChB,EAAE;AACF,EAAE,IAAI,CAAC,YAAY,cAAc,EAAE;AACnC,GAAG,MAAM,CAAC,KAAK,CAAC,kBAAkB,EAAE;AACpC,IAAI,SAAS;AACb,IAAI,KAAK,EAAE,CAAC,CAAC,OAAO;AACpB,IAAI,SAAS,EAAE,CAAC,CAAC;AACjB,IAAI,CAAC;AACL,GAAG,OAAO,aAAa,CAAC,GAAG,EAAE,kBAAkB,EAAE,CAAC,CAAC,OAAO,EAAE;AAC5D,IAAI,QAAQ,EAAE,CAAC,CAAC,QAAQ;AACxB,IAAI,SAAS,EAAE,CAAC,CAAC,SAAS;AAC1B,IAAI;AACJ,IAAI,EAAE,SAAS,CAAC;AAChB,EAAE;AACF,EAAE,MAAM,GAAG,GAAG,CAAC,YAAY,KAAK,GAAG,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC;AACxD,EAAE,MAAM,CAAC,KAAK,CAAC,+BAA+B,EAAE;AAChD,GAAG,SAAS;AACZ,GAAG,KAAK,EAAE;AACV,GAAG,CAAC;AACJ,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,kBAAkB,EAAE,GAAG,EAAE,EAAE,KAAK,EAAE,EAAE,SAAS,CAAC;AAC1E,CAAC;AACD;;;;"}
@@ -1,5 +1,5 @@
1
- import { aR as resolveDataDir, b0 as seedUiBuild, H as createLogger } from './src-B3g4Ry1X.js';
2
- import { d as getRequestId, r as requireAdmin, e as errorResponse, k as jsonResponse } from './helpers-uzTc9A0Q.js';
1
+ import { aL as resolveDataDir, aR as seedUiBuild, F as createLogger } from './src-BN-m14sE.js';
2
+ import { d as getRequestId, r as requireAdmin, e as errorResponse, k as jsonResponse } from './helpers-s8d3gE38.js';
3
3
  import './chunk-CLZ62Ad-.js';
4
4
  import 'node:module';
5
5
  import './provider-constants-DPrj3yBX.js';
@@ -21,8 +21,8 @@ import 'zlib';
21
21
  import 'node:assert';
22
22
  import 'node:fs/promises';
23
23
  import 'node:os';
24
- import './endpoints-BnI8UQUm.js';
25
- import './state-CL9Kv-vm.js';
24
+ import './endpoints-Dq-IqF1t.js';
25
+ import './state-BjAIjYtQ.js';
26
26
 
27
27
  //#region src/routes/admin/ui-version/+server.ts
28
28
  var logger = createLogger("ui-version");
@@ -53,7 +53,14 @@ var POST = async (event) => {
53
53
  }
54
54
  const supervisor = process.env.OP_UI_SUPERVISOR ?? "";
55
55
  let restarting = false;
56
- if (supervisor && process.ppid && process.ppid > 1) try {
56
+ let pendingRestart = false;
57
+ if (supervisor === "electron") {
58
+ pendingRestart = true;
59
+ logger.info("ui-version downloaded (electron — client will restart via IPC)", {
60
+ requestId,
61
+ tag
62
+ });
63
+ } else if (supervisor && process.ppid && process.ppid > 1) try {
57
64
  process.kill(process.ppid, "SIGUSR2");
58
65
  restarting = true;
59
66
  logger.info("ui-version restart signalled", {
@@ -70,14 +77,16 @@ var POST = async (event) => {
70
77
  logger.info("ui-version downloaded", {
71
78
  requestId,
72
79
  tag,
73
- restarting
80
+ restarting,
81
+ pendingRestart
74
82
  });
75
83
  return jsonResponse(200, {
76
84
  ok: true,
77
85
  tag,
78
- restarting
86
+ restarting,
87
+ pendingRestart
79
88
  }, requestId);
80
89
  };
81
90
 
82
91
  export { POST };
83
- //# sourceMappingURL=_server.ts-C5jyYbFm.js.map
92
+ //# sourceMappingURL=_server.ts-BcIPGO7x.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_server.ts-BcIPGO7x.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/ui-version/_server.ts.js"],"sourcesContent":["import { $t as resolveDataDir, Xt as seedUiBuild, hn as createLogger } from \"../../../../chunks/src.js\";\nimport { d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId } from \"../../../../chunks/helpers.js\";\n//#region src/routes/admin/ui-version/+server.ts\nvar logger = createLogger(\"ui-version\");\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tlet body;\n\ttry {\n\t\tbody = await event.request.json();\n\t} catch {\n\t\treturn errorResponse(400, \"invalid_json\", \"Request body must be valid JSON\", {}, requestId);\n\t}\n\tconst tag = typeof body.tag === \"string\" ? body.tag.trim() : \"\";\n\tif (!tag) return errorResponse(400, \"tag_required\", \"tag is required\", {}, requestId);\n\tif (!/^[a-zA-Z0-9._\\-]+$/.test(tag)) return errorResponse(400, \"invalid_tag\", \"Tag must be alphanumeric with . _ or - only\", {}, requestId);\n\tconst dataDir = resolveDataDir();\n\tconst repoRef = tag.startsWith(\"v\") ? tag : `v${tag}`;\n\ttry {\n\t\tawait seedUiBuild(repoRef, dataDir, { forceRemote: true });\n\t} catch (e) {\n\t\tconst msg = e instanceof Error ? e.message : String(e);\n\t\tlogger.error(\"ui-version download failed\", {\n\t\t\trequestId,\n\t\t\terror: msg\n\t\t});\n\t\treturn errorResponse(502, \"download_failed\", msg, { message: msg }, requestId);\n\t}\n\tconst supervisor = process.env.OP_UI_SUPERVISOR ?? \"\";\n\tlet restarting = false;\n\tlet pendingRestart = false;\n\tif (supervisor === \"electron\") {\n\t\tpendingRestart = true;\n\t\tlogger.info(\"ui-version downloaded (electron — client will restart via IPC)\", {\n\t\t\trequestId,\n\t\t\ttag\n\t\t});\n\t} else if (supervisor && process.ppid && process.ppid > 1) try {\n\t\tprocess.kill(process.ppid, \"SIGUSR2\");\n\t\trestarting = true;\n\t\tlogger.info(\"ui-version restart signalled\", {\n\t\t\trequestId,\n\t\t\tsupervisor,\n\t\t\tppid: process.ppid\n\t\t});\n\t} catch (e) {\n\t\tlogger.warn(\"ui-version restart signal failed\", {\n\t\t\trequestId,\n\t\t\terror: e instanceof Error ? e.message : String(e)\n\t\t});\n\t}\n\tlogger.info(\"ui-version downloaded\", {\n\t\trequestId,\n\t\ttag,\n\t\trestarting,\n\t\tpendingRestart\n\t});\n\treturn jsonResponse(200, {\n\t\tok: true,\n\t\ttag,\n\t\trestarting,\n\t\tpendingRestart\n\t}, requestId);\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { j as json } from './exports-D1quPX8S.js';
2
- import { am as isSetupComplete, aZ as resolveStackDir, a6 as getAddonProfileSelection, b as annotateAddonProfileAvailability, a7 as getAddonProfiles } from './src-B3g4Ry1X.js';
3
- import { g as getState } from './state-CL9Kv-vm.js';
4
- import { r as requireAdmin, d as getRequestId } from './helpers-uzTc9A0Q.js';
2
+ import { ai as isSetupComplete, aO as resolveStackDir, a4 as getAddonProfileSelection, c as annotateAddonProfileAvailability, a5 as getAddonProfiles } from './src-BN-m14sE.js';
3
+ import { g as getState } from './state-BjAIjYtQ.js';
4
+ import { r as requireAdmin, d as getRequestId } from './helpers-s8d3gE38.js';
5
5
  import './utils-BSRjJDrZ.js';
6
6
  import './chunk-CLZ62Ad-.js';
7
7
  import 'node:module';
@@ -24,7 +24,7 @@ import 'zlib';
24
24
  import 'node:assert';
25
25
  import 'node:fs/promises';
26
26
  import 'node:os';
27
- import './endpoints-BnI8UQUm.js';
27
+ import './endpoints-Dq-IqF1t.js';
28
28
 
29
29
  //#region src/routes/api/setup/ollama-profiles/+server.ts
30
30
  var GET = async (event) => {
@@ -41,4 +41,4 @@ var GET = async (event) => {
41
41
  };
42
42
 
43
43
  export { GET };
44
- //# sourceMappingURL=_server.ts-Bxk1V3Ev.js.map
44
+ //# sourceMappingURL=_server.ts-BdPGrcpF.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-Bxk1V3Ev.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/ollama-profiles/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { At as getAddonProfiles, Dt as annotateAddonProfileAvailability, kt as getAddonProfileSelection, on as resolveStackDir, yt as isSetupComplete } from \"../../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../../chunks/state.js\";\nimport { d as requireAdmin, o as getRequestId } from \"../../../../../chunks/helpers.js\";\n//#region src/routes/api/setup/ollama-profiles/+server.ts\nvar GET = async (event) => {\n\tif (isSetupComplete(resolveStackDir())) {\n\t\tconst authError = requireAdmin(event, getRequestId(event));\n\t\tif (authError) return authError;\n\t}\n\tconst state = getState();\n\treturn json({\n\t\tok: true,\n\t\tprofiles: await annotateAddonProfileAvailability(getAddonProfiles(state.homeDir, \"ollama\")),\n\t\tselectedProfile: getAddonProfileSelection(state.stackDir, \"ollama\")\n\t});\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,IAAI,eAAe,CAAC,eAAe,EAAE,CAAC,EAAE;AACzC,EAAE,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC;AAC5D,EAAE,IAAI,SAAS,EAAE,OAAO,SAAS;AACjC,CAAC;AACD,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,OAAO,IAAI,CAAC;AACb,EAAE,EAAE,EAAE,IAAI;AACV,EAAE,QAAQ,EAAE,MAAM,gCAAgC,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;AAC7F,EAAE,eAAe,EAAE,wBAAwB,CAAC,KAAK,CAAC,QAAQ,EAAE,QAAQ;AACpE,EAAE,CAAC;AACH;;;;"}
1
+ {"version":3,"file":"_server.ts-BdPGrcpF.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/ollama-profiles/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { bt as getAddonProfileSelection, en as resolveStackDir, ut as isSetupComplete, vt as annotateAddonProfileAvailability, xt as getAddonProfiles } from \"../../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../../chunks/state.js\";\nimport { d as requireAdmin, o as getRequestId } from \"../../../../../chunks/helpers.js\";\n//#region src/routes/api/setup/ollama-profiles/+server.ts\nvar GET = async (event) => {\n\tif (isSetupComplete(resolveStackDir())) {\n\t\tconst authError = requireAdmin(event, getRequestId(event));\n\t\tif (authError) return authError;\n\t}\n\tconst state = getState();\n\treturn json({\n\t\tok: true,\n\t\tprofiles: await annotateAddonProfileAvailability(getAddonProfiles(state.homeDir, \"ollama\")),\n\t\tselectedProfile: getAddonProfileSelection(state.stackDir, \"ollama\")\n\t});\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,IAAI,eAAe,CAAC,eAAe,EAAE,CAAC,EAAE;AACzC,EAAE,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC;AAC5D,EAAE,IAAI,SAAS,EAAE,OAAO,SAAS;AACjC,CAAC;AACD,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,OAAO,IAAI,CAAC;AACb,EAAE,EAAE,EAAE,IAAI;AACV,EAAE,QAAQ,EAAE,MAAM,gCAAgC,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;AAC7F,EAAE,eAAe,EAAE,wBAAwB,CAAC,KAAK,CAAC,QAAQ,EAAE,QAAQ;AACpE,EAAE,CAAC;AACH;;;;"}
@@ -1,6 +1,6 @@
1
- import { aI as readStackEnv } from './src-B3g4Ry1X.js';
2
- import { g as getState } from './state-CL9Kv-vm.js';
3
- import { d as getRequestId, r as requireAdmin, e as errorResponse, k as jsonResponse } from './helpers-uzTc9A0Q.js';
1
+ import { aB as readStackEnv } from './src-BN-m14sE.js';
2
+ import { g as getState } from './state-BjAIjYtQ.js';
3
+ import { d as getRequestId, r as requireAdmin, e as errorResponse, k as jsonResponse } from './helpers-s8d3gE38.js';
4
4
  import './chunk-CLZ62Ad-.js';
5
5
  import 'node:module';
6
6
  import './provider-constants-DPrj3yBX.js';
@@ -22,7 +22,7 @@ import 'zlib';
22
22
  import 'node:assert';
23
23
  import 'node:fs/promises';
24
24
  import 'node:os';
25
- import './endpoints-BnI8UQUm.js';
25
+ import './endpoints-Dq-IqF1t.js';
26
26
 
27
27
  //#region src/routes/api/transcribe/+server.ts
28
28
  var DEFAULT_MODEL = "whisper-1";
@@ -89,4 +89,4 @@ var POST = async (event) => {
89
89
  };
90
90
 
91
91
  export { POST };
92
- //# sourceMappingURL=_server.ts-Bx3uIrpl.js.map
92
+ //# sourceMappingURL=_server.ts-BeXMVrJG.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-Bx3uIrpl.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/transcribe/_server.ts.js"],"sourcesContent":["import { Gt as readStackEnv } from \"../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../chunks/state.js\";\nimport { d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId } from \"../../../../chunks/helpers.js\";\n//#region src/routes/api/transcribe/+server.ts\nvar DEFAULT_MODEL = \"whisper-1\";\nvar UPSTREAM_TIMEOUT_MS = 6e4;\nfunction redactKey(s) {\n\treturn s.replace(/(sk-[A-Za-z0-9_-]{4,})/g, \"sk-***\").replace(/(hf_[A-Za-z0-9_-]{4,})/gi, \"hf_***\").replace(/(Bearer\\s+)[A-Za-z0-9._-]+/gi, \"$1***\");\n}\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst stackEnv = readStackEnv(getState().stackDir);\n\tconst sttBaseURL = (stackEnv.OP_STT_BASE_URL || process.env.OP_STT_BASE_URL || \"\").trim();\n\tconst sttModel = (stackEnv.OP_STT_MODEL || process.env.OP_STT_MODEL || \"\").trim() || DEFAULT_MODEL;\n\tconst sttLanguageEnv = (stackEnv.OP_STT_LANGUAGE || process.env.OP_STT_LANGUAGE || \"\").trim();\n\tconst sttApiKey = (process.env.OP_STT_API_KEY ?? \"\").trim();\n\tif (!sttBaseURL) return errorResponse(503, \"stt_not_configured\", \"Configure an STT engine in Admin → Voice settings.\", {}, requestId);\n\tlet inboundForm;\n\ttry {\n\t\tinboundForm = await event.request.formData();\n\t} catch {\n\t\treturn errorResponse(400, \"bad_request\", \"Body must be multipart/form-data\", {}, requestId);\n\t}\n\tconst audio = inboundForm.get(\"audio\");\n\tif (!(audio instanceof Blob)) return errorResponse(400, \"bad_request\", \"Missing \\\"audio\\\" field (Blob)\", {}, requestId);\n\tconst languageReq = inboundForm.get(\"language\");\n\tconst promptReq = inboundForm.get(\"prompt\");\n\tconst language = typeof languageReq === \"string\" && languageReq.trim() ? languageReq.trim() : sttLanguageEnv;\n\tconst outForm = new FormData();\n\tconst filename = audio.name || \"recording.webm\";\n\toutForm.append(\"file\", audio, filename);\n\toutForm.append(\"model\", sttModel);\n\toutForm.append(\"response_format\", \"json\");\n\tif (language) outForm.append(\"language\", language);\n\tif (typeof promptReq === \"string\" && promptReq.trim()) outForm.append(\"prompt\", promptReq.trim());\n\tconst upstreamUrl = sttBaseURL.replace(/\\/+$/, \"\") + \"/v1/audio/transcriptions\";\n\tconst headers = {};\n\tif (sttApiKey) headers[\"authorization\"] = `Bearer ${sttApiKey}`;\n\tlet upstream;\n\ttry {\n\t\tupstream = await fetch(upstreamUrl, {\n\t\t\tmethod: \"POST\",\n\t\t\theaders,\n\t\t\tbody: outForm,\n\t\t\tsignal: AbortSignal.timeout(UPSTREAM_TIMEOUT_MS)\n\t\t});\n\t} catch (err) {\n\t\treturn errorResponse(502, \"upstream_error\", `Could not reach STT endpoint: ${redactKey(err instanceof Error ? err.message : String(err))}`, { upstream: upstreamUrl }, requestId);\n\t}\n\tif (!upstream.ok) {\n\t\tconst snippet = redactKey(await upstream.text().catch(() => \"\")).slice(0, 500);\n\t\treturn errorResponse(502, \"upstream_error\", `STT endpoint returned ${upstream.status}`, {\n\t\t\tupstreamStatus: upstream.status,\n\t\t\tbody: snippet\n\t\t}, requestId);\n\t}\n\tlet payload;\n\ttry {\n\t\tpayload = await upstream.json();\n\t} catch {\n\t\treturn errorResponse(502, \"upstream_error\", \"STT endpoint returned a non-JSON response\", { upstreamStatus: upstream.status }, requestId);\n\t}\n\treturn jsonResponse(200, { text: typeof payload?.text === \"string\" ? payload.text : \"\" }, requestId);\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"_server.ts-BeXMVrJG.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/transcribe/_server.ts.js"],"sourcesContent":["import { zt as readStackEnv } from \"../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../chunks/state.js\";\nimport { d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId } from \"../../../../chunks/helpers.js\";\n//#region src/routes/api/transcribe/+server.ts\nvar DEFAULT_MODEL = \"whisper-1\";\nvar UPSTREAM_TIMEOUT_MS = 6e4;\nfunction redactKey(s) {\n\treturn s.replace(/(sk-[A-Za-z0-9_-]{4,})/g, \"sk-***\").replace(/(hf_[A-Za-z0-9_-]{4,})/gi, \"hf_***\").replace(/(Bearer\\s+)[A-Za-z0-9._-]+/gi, \"$1***\");\n}\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst stackEnv = readStackEnv(getState().stackDir);\n\tconst sttBaseURL = (stackEnv.OP_STT_BASE_URL || process.env.OP_STT_BASE_URL || \"\").trim();\n\tconst sttModel = (stackEnv.OP_STT_MODEL || process.env.OP_STT_MODEL || \"\").trim() || DEFAULT_MODEL;\n\tconst sttLanguageEnv = (stackEnv.OP_STT_LANGUAGE || process.env.OP_STT_LANGUAGE || \"\").trim();\n\tconst sttApiKey = (process.env.OP_STT_API_KEY ?? \"\").trim();\n\tif (!sttBaseURL) return errorResponse(503, \"stt_not_configured\", \"Configure an STT engine in Admin → Voice settings.\", {}, requestId);\n\tlet inboundForm;\n\ttry {\n\t\tinboundForm = await event.request.formData();\n\t} catch {\n\t\treturn errorResponse(400, \"bad_request\", \"Body must be multipart/form-data\", {}, requestId);\n\t}\n\tconst audio = inboundForm.get(\"audio\");\n\tif (!(audio instanceof Blob)) return errorResponse(400, \"bad_request\", \"Missing \\\"audio\\\" field (Blob)\", {}, requestId);\n\tconst languageReq = inboundForm.get(\"language\");\n\tconst promptReq = inboundForm.get(\"prompt\");\n\tconst language = typeof languageReq === \"string\" && languageReq.trim() ? languageReq.trim() : sttLanguageEnv;\n\tconst outForm = new FormData();\n\tconst filename = audio.name || \"recording.webm\";\n\toutForm.append(\"file\", audio, filename);\n\toutForm.append(\"model\", sttModel);\n\toutForm.append(\"response_format\", \"json\");\n\tif (language) outForm.append(\"language\", language);\n\tif (typeof promptReq === \"string\" && promptReq.trim()) outForm.append(\"prompt\", promptReq.trim());\n\tconst upstreamUrl = sttBaseURL.replace(/\\/+$/, \"\") + \"/v1/audio/transcriptions\";\n\tconst headers = {};\n\tif (sttApiKey) headers[\"authorization\"] = `Bearer ${sttApiKey}`;\n\tlet upstream;\n\ttry {\n\t\tupstream = await fetch(upstreamUrl, {\n\t\t\tmethod: \"POST\",\n\t\t\theaders,\n\t\t\tbody: outForm,\n\t\t\tsignal: AbortSignal.timeout(UPSTREAM_TIMEOUT_MS)\n\t\t});\n\t} catch (err) {\n\t\treturn errorResponse(502, \"upstream_error\", `Could not reach STT endpoint: ${redactKey(err instanceof Error ? err.message : String(err))}`, { upstream: upstreamUrl }, requestId);\n\t}\n\tif (!upstream.ok) {\n\t\tconst snippet = redactKey(await upstream.text().catch(() => \"\")).slice(0, 500);\n\t\treturn errorResponse(502, \"upstream_error\", `STT endpoint returned ${upstream.status}`, {\n\t\t\tupstreamStatus: upstream.status,\n\t\t\tbody: snippet\n\t\t}, requestId);\n\t}\n\tlet payload;\n\ttry {\n\t\tpayload = await upstream.json();\n\t} catch {\n\t\treturn errorResponse(502, \"upstream_error\", \"STT endpoint returned a non-JSON response\", { upstreamStatus: upstream.status }, requestId);\n\t}\n\treturn jsonResponse(200, { text: typeof payload?.text === \"string\" ? payload.text : \"\" }, requestId);\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACA,IAAI,aAAa,GAAG,WAAW;AAC/B,IAAI,mBAAmB,GAAG,GAAG;AAC7B,SAAS,SAAS,CAAC,CAAC,EAAE;AACtB,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,yBAAyB,EAAE,QAAQ,CAAC,CAAC,OAAO,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC,OAAO,CAAC,8BAA8B,EAAE,OAAO,CAAC;AACrJ;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,MAAM,QAAQ,GAAG,YAAY,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC;AACnD,CAAC,MAAM,UAAU,GAAG,CAAC,QAAQ,CAAC,eAAe,IAAI,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,EAAE,EAAE,IAAI,EAAE;AAC1F,CAAC,MAAM,QAAQ,GAAG,CAAC,QAAQ,CAAC,YAAY,IAAI,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,aAAa;AACnG,CAAC,MAAM,cAAc,GAAG,CAAC,QAAQ,CAAC,eAAe,IAAI,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,EAAE,EAAE,IAAI,EAAE;AAC9F,CAAC,MAAM,SAAS,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,EAAE,EAAE,IAAI,EAAE;AAC5D,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,oBAAoB,EAAE,oDAAoD,EAAE,EAAE,EAAE,SAAS,CAAC;AACtI,CAAC,IAAI,WAAW;AAChB,CAAC,IAAI;AACL,EAAE,WAAW,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,QAAQ,EAAE;AAC9C,CAAC,CAAC,CAAC,MAAM;AACT,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,aAAa,EAAE,kCAAkC,EAAE,EAAE,EAAE,SAAS,CAAC;AAC7F,CAAC;AACD,CAAC,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,CAAC,OAAO,CAAC;AACvC,CAAC,IAAI,EAAE,KAAK,YAAY,IAAI,CAAC,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,aAAa,EAAE,gCAAgC,EAAE,EAAE,EAAE,SAAS,CAAC;AACxH,CAAC,MAAM,WAAW,GAAG,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC;AAChD,CAAC,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC;AAC5C,CAAC,MAAM,QAAQ,GAAG,OAAO,WAAW,KAAK,QAAQ,IAAI,WAAW,CAAC,IAAI,EAAE,GAAG,WAAW,CAAC,IAAI,EAAE,GAAG,cAAc;AAC7G,CAAC,MAAM,OAAO,GAAG,IAAI,QAAQ,EAAE;AAC/B,CAAC,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,IAAI,gBAAgB;AAChD,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,EAAE,QAAQ,CAAC;AACxC,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,QAAQ,CAAC;AAClC,CAAC,OAAO,CAAC,MAAM,CAAC,iBAAiB,EAAE,MAAM,CAAC;AAC1C,CAAC,IAAI,QAAQ,EAAE,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE,QAAQ,CAAC;AACnD,CAAC,IAAI,OAAO,SAAS,KAAK,QAAQ,IAAI,SAAS,CAAC,IAAI,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,SAAS,CAAC,IAAI,EAAE,CAAC;AAClG,CAAC,MAAM,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,0BAA0B;AAChF,CAAC,MAAM,OAAO,GAAG,EAAE;AACnB,CAAC,IAAI,SAAS,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;AAChE,CAAC,IAAI,QAAQ;AACb,CAAC,IAAI;AACL,EAAE,QAAQ,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE;AACtC,GAAG,MAAM,EAAE,MAAM;AACjB,GAAG,OAAO;AACV,GAAG,IAAI,EAAE,OAAO;AAChB,GAAG,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,mBAAmB;AAClD,GAAG,CAAC;AACJ,CAAC,CAAC,CAAC,OAAO,GAAG,EAAE;AACf,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,gBAAgB,EAAE,CAAC,8BAA8B,EAAE,SAAS,CAAC,GAAG,YAAY,KAAK,GAAG,GAAG,CAAC,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,QAAQ,EAAE,WAAW,EAAE,EAAE,SAAS,CAAC;AACnL,CAAC;AACD,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;AACnB,EAAE,MAAM,OAAO,GAAG,SAAS,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC;AAChF,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,gBAAgB,EAAE,CAAC,sBAAsB,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE;AAC1F,GAAG,cAAc,EAAE,QAAQ,CAAC,MAAM;AAClC,GAAG,IAAI,EAAE;AACT,GAAG,EAAE,SAAS,CAAC;AACf,CAAC;AACD,CAAC,IAAI,OAAO;AACZ,CAAC,IAAI;AACL,EAAE,OAAO,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE;AACjC,CAAC,CAAC,CAAC,MAAM;AACT,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,gBAAgB,EAAE,2CAA2C,EAAE,EAAE,cAAc,EAAE,QAAQ,CAAC,MAAM,EAAE,EAAE,SAAS,CAAC;AAC1I,CAAC;AACD,CAAC,OAAO,YAAY,CAAC,GAAG,EAAE,EAAE,IAAI,EAAE,OAAO,OAAO,EAAE,IAAI,KAAK,QAAQ,GAAG,OAAO,CAAC,IAAI,GAAG,EAAE,EAAE,EAAE,SAAS,CAAC;AACrG;;;;"}
@@ -1,6 +1,6 @@
1
- import { ah as isAllowedService, p as checkDocker, z as composeStart, n as buildComposeOptions, H as createLogger } from './src-B3g4Ry1X.js';
2
- import { g as getState } from './state-CL9Kv-vm.js';
3
- import { d as getRequestId, r as requireAdmin, p as parseJsonBody, j as jsonBodyError, e as errorResponse, k as jsonResponse } from './helpers-uzTc9A0Q.js';
1
+ import { af as isAllowedService, o as checkDocker, y as composeStart, m as buildComposeOptions, F as createLogger } from './src-BN-m14sE.js';
2
+ import { g as getState } from './state-BjAIjYtQ.js';
3
+ import { d as getRequestId, r as requireAdmin, p as parseJsonBody, j as jsonBodyError, e as errorResponse, k as jsonResponse } from './helpers-s8d3gE38.js';
4
4
  import './chunk-CLZ62Ad-.js';
5
5
  import 'node:module';
6
6
  import './provider-constants-DPrj3yBX.js';
@@ -22,7 +22,7 @@ import 'zlib';
22
22
  import 'node:assert';
23
23
  import 'node:fs/promises';
24
24
  import 'node:os';
25
- import './endpoints-BnI8UQUm.js';
25
+ import './endpoints-Dq-IqF1t.js';
26
26
 
27
27
  //#region src/routes/admin/containers/up/+server.ts
28
28
  var logger = createLogger("containers-up");
@@ -54,4 +54,4 @@ var POST = async (event) => {
54
54
  };
55
55
 
56
56
  export { POST };
57
- //# sourceMappingURL=_server.ts-DBQ7TD4o.js.map
57
+ //# sourceMappingURL=_server.ts-BghreOti.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_server.ts-BghreOti.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/containers/up/_server.ts.js"],"sourcesContent":["import { L as buildComposeOptions, O as isAllowedService, X as checkDocker, hn as createLogger, it as composeStart } from \"../../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../../chunks/state.js\";\nimport { c as jsonBodyError, d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId, u as parseJsonBody } from \"../../../../../chunks/helpers.js\";\n//#region src/routes/admin/containers/up/+server.ts\nvar logger = createLogger(\"containers-up\");\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tlogger.info(\"container start request received\", { requestId });\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst state = getState();\n\tconst result = await parseJsonBody(event.request);\n\tif (\"error\" in result) return jsonBodyError(result, requestId);\n\tconst body = result.data;\n\tconst service = typeof body.service === \"string\" ? body.service : \"\";\n\tlogger.info(\"starting service\", {\n\t\trequestId,\n\t\tservice\n\t});\n\tif (!isAllowedService(service, state.configDir)) return errorResponse(400, \"invalid_service\", \"Service is not in allowlist\", { service }, requestId);\n\tif ((await checkDocker()).ok) {\n\t\tconst result = await composeStart([service], buildComposeOptions(state));\n\t\tif (result.ok) state.services[service] = \"running\";\n\t\telse return errorResponse(500, \"docker_error\", `Failed to start service: ${result.stderr}`, { service }, requestId);\n\t} else state.services[service] = \"running\";\n\treturn jsonResponse(200, {\n\t\tok: true,\n\t\tservice,\n\t\tstatus: state.services[service]\n\t}, requestId);\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACA,IAAI,MAAM,GAAG,YAAY,CAAC,eAAe,CAAC;AACvC,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,CAAC,IAAI,CAAC,kCAAkC,EAAE,EAAE,SAAS,EAAE,CAAC;AAC/D,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC;AAClD,CAAC,IAAI,OAAO,IAAI,MAAM,EAAE,OAAO,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC;AAC/D,CAAC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI;AACzB,CAAC,MAAM,OAAO,GAAG,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,GAAG,IAAI,CAAC,OAAO,GAAG,EAAE;AACrE,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE;AACjC,EAAE,SAAS;AACX,EAAE;AACF,EAAE,CAAC;AACH,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,iBAAiB,EAAE,6BAA6B,EAAE,EAAE,OAAO,EAAE,EAAE,SAAS,CAAC;AACrJ,CAAC,IAAI,CAAC,MAAM,WAAW,EAAE,EAAE,EAAE,EAAE;AAC/B,EAAE,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,CAAC,OAAO,CAAC,EAAE,mBAAmB,CAAC,KAAK,CAAC,CAAC;AAC1E,EAAE,IAAI,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,SAAS;AACpD,OAAO,OAAO,aAAa,CAAC,GAAG,EAAE,cAAc,EAAE,CAAC,yBAAyB,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,SAAS,CAAC;AACrH,CAAC,CAAC,MAAM,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,SAAS;AAC3C,CAAC,OAAO,YAAY,CAAC,GAAG,EAAE;AAC1B,EAAE,EAAE,EAAE,IAAI;AACV,EAAE,OAAO;AACT,EAAE,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,OAAO;AAChC,EAAE,EAAE,SAAS,CAAC;AACd;;;;"}
@@ -1,5 +1,5 @@
1
1
  import { j as json } from './exports-D1quPX8S.js';
2
- import { S as detectLocalProviders } from './src-B3g4Ry1X.js';
2
+ import { Q as detectLocalProviders } from './src-BN-m14sE.js';
3
3
  import './utils-BSRjJDrZ.js';
4
4
  import './chunk-CLZ62Ad-.js';
5
5
  import 'node:module';
@@ -40,4 +40,4 @@ var GET = async () => {
40
40
  };
41
41
 
42
42
  export { GET };
43
- //# sourceMappingURL=_server.ts-D4tyRvFi.js.map
43
+ //# sourceMappingURL=_server.ts-Bi33i7c7.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-D4tyRvFi.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/detect-providers/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { u as detectLocalProviders } from \"../../../../../chunks/src.js\";\n//#region src/routes/api/setup/detect-providers/+server.ts\nvar GET = async () => {\n\ttry {\n\t\treturn json({\n\t\t\tok: true,\n\t\t\tproviders: await detectLocalProviders()\n\t\t});\n\t} catch (err) {\n\t\treturn json({\n\t\t\tok: false,\n\t\t\terror: \"detection_failed\",\n\t\t\tmessage: String(err)\n\t\t}, { status: 500 });\n\t}\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAEA;AACG,IAAC,GAAG,GAAG,YAAY;AACtB,CAAC,IAAI;AACL,EAAE,OAAO,IAAI,CAAC;AACd,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,SAAS,EAAE,MAAM,oBAAoB;AACxC,GAAG,CAAC;AACJ,CAAC,CAAC,CAAC,OAAO,GAAG,EAAE;AACf,EAAE,OAAO,IAAI,CAAC;AACd,GAAG,EAAE,EAAE,KAAK;AACZ,GAAG,KAAK,EAAE,kBAAkB;AAC5B,GAAG,OAAO,EAAE,MAAM,CAAC,GAAG;AACtB,GAAG,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;AACrB,CAAC;AACD;;;;"}
1
+ {"version":3,"file":"_server.ts-Bi33i7c7.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/detect-providers/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { u as detectLocalProviders } from \"../../../../../chunks/src.js\";\n//#region src/routes/api/setup/detect-providers/+server.ts\nvar GET = async () => {\n\ttry {\n\t\treturn json({\n\t\t\tok: true,\n\t\t\tproviders: await detectLocalProviders()\n\t\t});\n\t} catch (err) {\n\t\treturn json({\n\t\t\tok: false,\n\t\t\terror: \"detection_failed\",\n\t\t\tmessage: String(err)\n\t\t}, { status: 500 });\n\t}\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAEA;AACG,IAAC,GAAG,GAAG,YAAY;AACtB,CAAC,IAAI;AACL,EAAE,OAAO,IAAI,CAAC;AACd,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,SAAS,EAAE,MAAM,oBAAoB;AACxC,GAAG,CAAC;AACJ,CAAC,CAAC,CAAC,OAAO,GAAG,EAAE;AACf,EAAE,OAAO,IAAI,CAAC;AACd,GAAG,EAAE,EAAE,KAAK;AACZ,GAAG,KAAK,EAAE,kBAAkB;AAC5B,GAAG,OAAO,EAAE,MAAM,CAAC,GAAG;AACtB,GAAG,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;AACrB,CAAC;AACD;;;;"}
@@ -1,6 +1,6 @@
1
- import { d as getRequestId, h as invalidateSession } from './helpers-uzTc9A0Q.js';
2
- import { S as SESSION_COOKIE_NAME, c as clearSessionCookieHeader } from './session-cookie-DOONPnJ5.js';
3
- import './src-B3g4Ry1X.js';
1
+ import { d as getRequestId, h as invalidateSession } from './helpers-s8d3gE38.js';
2
+ import { S as SESSION_COOKIE_NAME, c as clearSessionCookieHeader } from './session-cookie-F6DkHp5H.js';
3
+ import './src-BN-m14sE.js';
4
4
  import './chunk-CLZ62Ad-.js';
5
5
  import 'node:module';
6
6
  import './provider-constants-DPrj3yBX.js';
@@ -22,8 +22,8 @@ import 'zlib';
22
22
  import 'node:assert';
23
23
  import 'node:fs/promises';
24
24
  import 'node:os';
25
- import './endpoints-BnI8UQUm.js';
26
- import './state-CL9Kv-vm.js';
25
+ import './endpoints-Dq-IqF1t.js';
26
+ import './state-BjAIjYtQ.js';
27
27
 
28
28
  //#region src/routes/admin/auth/logout/+server.ts
29
29
  var POST = async (event) => {
@@ -41,4 +41,4 @@ var POST = async (event) => {
41
41
  };
42
42
 
43
43
  export { POST };
44
- //# sourceMappingURL=_server.ts-C_dk6ZLP.js.map
44
+ //# sourceMappingURL=_server.ts-BjSX-JsT.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-C_dk6ZLP.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/auth/logout/_server.ts.js"],"sourcesContent":["import { _ as invalidateSession, o as getRequestId } from \"../../../../../chunks/helpers.js\";\nimport { n as clearSessionCookieHeader, t as SESSION_COOKIE_NAME } from \"../../../../../chunks/session-cookie.js\";\n//#region src/routes/admin/auth/logout/+server.ts\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst match = (event.request.headers.get(\"cookie\") ?? \"\").match(new RegExp(`(?:^|;\\\\s*)${SESSION_COOKIE_NAME}=([^;]+)`));\n\tif (match) invalidateSession(match[1]);\n\treturn new Response(JSON.stringify({ ok: true }), {\n\t\tstatus: 200,\n\t\theaders: {\n\t\t\t\"content-type\": \"application/json\",\n\t\t\t\"set-cookie\": clearSessionCookieHeader(event.request),\n\t\t\t\"x-request-id\": requestId\n\t\t}\n\t});\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,KAAK,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,CAAC,WAAW,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC;AACzH,CAAC,IAAI,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACvC,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE;AACnD,EAAE,MAAM,EAAE,GAAG;AACb,EAAE,OAAO,EAAE;AACX,GAAG,cAAc,EAAE,kBAAkB;AACrC,GAAG,YAAY,EAAE,wBAAwB,CAAC,KAAK,CAAC,OAAO,CAAC;AACxD,GAAG,cAAc,EAAE;AACnB;AACA,EAAE,CAAC;AACH;;;;"}
1
+ {"version":3,"file":"_server.ts-BjSX-JsT.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/auth/logout/_server.ts.js"],"sourcesContent":["import { _ as invalidateSession, o as getRequestId } from \"../../../../../chunks/helpers.js\";\nimport { n as clearSessionCookieHeader, t as SESSION_COOKIE_NAME } from \"../../../../../chunks/session-cookie.js\";\n//#region src/routes/admin/auth/logout/+server.ts\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst match = (event.request.headers.get(\"cookie\") ?? \"\").match(new RegExp(`(?:^|;\\\\s*)${SESSION_COOKIE_NAME}=([^;]+)`));\n\tif (match) invalidateSession(match[1]);\n\treturn new Response(JSON.stringify({ ok: true }), {\n\t\tstatus: 200,\n\t\theaders: {\n\t\t\t\"content-type\": \"application/json\",\n\t\t\t\"set-cookie\": clearSessionCookieHeader(event.request),\n\t\t\t\"x-request-id\": requestId\n\t\t}\n\t});\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,KAAK,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,CAAC,WAAW,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC;AACzH,CAAC,IAAI,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACvC,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE;AACnD,EAAE,MAAM,EAAE,GAAG;AACb,EAAE,OAAO,EAAE;AACX,GAAG,cAAc,EAAE,kBAAkB;AACrC,GAAG,YAAY,EAAE,wBAAwB,CAAC,KAAK,CAAC,OAAO,CAAC;AACxD,GAAG,cAAc,EAAE;AACnB;AACA,EAAE,CAAC;AACH;;;;"}
@@ -1,6 +1,6 @@
1
- import { d as getRequestId, e as errorResponse, f as getUiLoginPassword, s as safeTokenCompare, b as createSession } from './helpers-uzTc9A0Q.js';
2
- import { s as sessionCookieHeader } from './session-cookie-DOONPnJ5.js';
3
- import './src-B3g4Ry1X.js';
1
+ import { d as getRequestId, e as errorResponse, f as getUiLoginPassword, s as safeTokenCompare, b as createSession } from './helpers-s8d3gE38.js';
2
+ import { s as sessionCookieHeader } from './session-cookie-F6DkHp5H.js';
3
+ import './src-BN-m14sE.js';
4
4
  import './chunk-CLZ62Ad-.js';
5
5
  import 'node:module';
6
6
  import './provider-constants-DPrj3yBX.js';
@@ -22,8 +22,8 @@ import 'zlib';
22
22
  import 'node:assert';
23
23
  import 'node:fs/promises';
24
24
  import 'node:os';
25
- import './endpoints-BnI8UQUm.js';
26
- import './state-CL9Kv-vm.js';
25
+ import './endpoints-Dq-IqF1t.js';
26
+ import './state-BjAIjYtQ.js';
27
27
 
28
28
  //#region src/routes/admin/auth/session/+server.ts
29
29
  /**
@@ -61,4 +61,4 @@ var POST = async (event) => {
61
61
  };
62
62
 
63
63
  export { POST };
64
- //# sourceMappingURL=_server.ts-CuBCKbP8.js.map
64
+ //# sourceMappingURL=_server.ts-BokcuCWE.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-CuBCKbP8.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/auth/session/_server.ts.js"],"sourcesContent":["import { f as safeTokenCompare, g as getUiLoginPassword, h as createSession, i as errorResponse, o as getRequestId } from \"../../../../../chunks/helpers.js\";\nimport { r as sessionCookieHeader } from \"../../../../../chunks/session-cookie.js\";\n//#region src/routes/admin/auth/session/+server.ts\n/**\n* POST /admin/auth/session\n*\n* Issues an `op_session` cookie after verifying the operator-supplied password\n* against `process.env.OP_UI_LOGIN_PASSWORD`.\n*\n* The cookie value is a random UUID session token — NOT the plaintext password.\n* Kept alongside `/admin/auth/login` as an alias; both verify the same\n* `password` body field and issue the `op_session` cookie.\n*/\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tlet body;\n\ttry {\n\t\tbody = await event.request.json();\n\t} catch {\n\t\treturn errorResponse(400, \"bad_request\", \"Invalid JSON body\", {}, requestId);\n\t}\n\tconst password = typeof body.password === \"string\" ? body.password : \"\";\n\tif (!password) return errorResponse(400, \"bad_request\", \"password is required\", {}, requestId);\n\tconst configured = getUiLoginPassword();\n\tif (!configured) return errorResponse(503, \"admin_not_configured\", \"OP_UI_LOGIN_PASSWORD has not been set. Complete setup first.\", {}, requestId);\n\tif (!safeTokenCompare(password, configured)) return errorResponse(401, \"unauthorized\", \"Invalid password\", {}, requestId);\n\tconst sessionToken = createSession();\n\treturn new Response(JSON.stringify({ ok: true }), {\n\t\tstatus: 200,\n\t\theaders: {\n\t\t\t\"content-type\": \"application/json\",\n\t\t\t\"set-cookie\": sessionCookieHeader(sessionToken, event.request),\n\t\t\t\"x-request-id\": requestId\n\t\t}\n\t});\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,IAAI,IAAI;AACT,CAAC,IAAI;AACL,EAAE,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE;AACnC,CAAC,CAAC,CAAC,MAAM;AACT,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,aAAa,EAAE,mBAAmB,EAAE,EAAE,EAAE,SAAS,CAAC;AAC9E,CAAC;AACD,CAAC,MAAM,QAAQ,GAAG,OAAO,IAAI,CAAC,QAAQ,KAAK,QAAQ,GAAG,IAAI,CAAC,QAAQ,GAAG,EAAE;AACxE,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,aAAa,EAAE,sBAAsB,EAAE,EAAE,EAAE,SAAS,CAAC;AAC/F,CAAC,MAAM,UAAU,GAAG,kBAAkB,EAAE;AACxC,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,sBAAsB,EAAE,8DAA8D,EAAE,EAAE,EAAE,SAAS,CAAC;AAClJ,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,UAAU,CAAC,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,cAAc,EAAE,kBAAkB,EAAE,EAAE,EAAE,SAAS,CAAC;AAC1H,CAAC,MAAM,YAAY,GAAG,aAAa,EAAE;AACrC,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE;AACnD,EAAE,MAAM,EAAE,GAAG;AACb,EAAE,OAAO,EAAE;AACX,GAAG,cAAc,EAAE,kBAAkB;AACrC,GAAG,YAAY,EAAE,mBAAmB,CAAC,YAAY,EAAE,KAAK,CAAC,OAAO,CAAC;AACjE,GAAG,cAAc,EAAE;AACnB;AACA,EAAE,CAAC;AACH;;;;"}
1
+ {"version":3,"file":"_server.ts-BokcuCWE.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/auth/session/_server.ts.js"],"sourcesContent":["import { f as safeTokenCompare, g as getUiLoginPassword, h as createSession, i as errorResponse, o as getRequestId } from \"../../../../../chunks/helpers.js\";\nimport { r as sessionCookieHeader } from \"../../../../../chunks/session-cookie.js\";\n//#region src/routes/admin/auth/session/+server.ts\n/**\n* POST /admin/auth/session\n*\n* Issues an `op_session` cookie after verifying the operator-supplied password\n* against `process.env.OP_UI_LOGIN_PASSWORD`.\n*\n* The cookie value is a random UUID session token — NOT the plaintext password.\n* Kept alongside `/admin/auth/login` as an alias; both verify the same\n* `password` body field and issue the `op_session` cookie.\n*/\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tlet body;\n\ttry {\n\t\tbody = await event.request.json();\n\t} catch {\n\t\treturn errorResponse(400, \"bad_request\", \"Invalid JSON body\", {}, requestId);\n\t}\n\tconst password = typeof body.password === \"string\" ? body.password : \"\";\n\tif (!password) return errorResponse(400, \"bad_request\", \"password is required\", {}, requestId);\n\tconst configured = getUiLoginPassword();\n\tif (!configured) return errorResponse(503, \"admin_not_configured\", \"OP_UI_LOGIN_PASSWORD has not been set. Complete setup first.\", {}, requestId);\n\tif (!safeTokenCompare(password, configured)) return errorResponse(401, \"unauthorized\", \"Invalid password\", {}, requestId);\n\tconst sessionToken = createSession();\n\treturn new Response(JSON.stringify({ ok: true }), {\n\t\tstatus: 200,\n\t\theaders: {\n\t\t\t\"content-type\": \"application/json\",\n\t\t\t\"set-cookie\": sessionCookieHeader(sessionToken, event.request),\n\t\t\t\"x-request-id\": requestId\n\t\t}\n\t});\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,IAAI,IAAI;AACT,CAAC,IAAI;AACL,EAAE,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE;AACnC,CAAC,CAAC,CAAC,MAAM;AACT,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,aAAa,EAAE,mBAAmB,EAAE,EAAE,EAAE,SAAS,CAAC;AAC9E,CAAC;AACD,CAAC,MAAM,QAAQ,GAAG,OAAO,IAAI,CAAC,QAAQ,KAAK,QAAQ,GAAG,IAAI,CAAC,QAAQ,GAAG,EAAE;AACxE,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,aAAa,EAAE,sBAAsB,EAAE,EAAE,EAAE,SAAS,CAAC;AAC/F,CAAC,MAAM,UAAU,GAAG,kBAAkB,EAAE;AACxC,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,sBAAsB,EAAE,8DAA8D,EAAE,EAAE,EAAE,SAAS,CAAC;AAClJ,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,UAAU,CAAC,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,cAAc,EAAE,kBAAkB,EAAE,EAAE,EAAE,SAAS,CAAC;AAC1H,CAAC,MAAM,YAAY,GAAG,aAAa,EAAE;AACrC,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE;AACnD,EAAE,MAAM,EAAE,GAAG;AACb,EAAE,OAAO,EAAE;AACX,GAAG,cAAc,EAAE,kBAAkB;AACrC,GAAG,YAAY,EAAE,mBAAmB,CAAC,YAAY,EAAE,KAAK,CAAC,OAAO,CAAC;AACjE,GAAG,cAAc,EAAE;AACnB;AACA,EAAE,CAAC;AACH;;;;"}
@@ -1,6 +1,6 @@
1
- import { H as createLogger, p as checkDocker, n as buildComposeOptions, x as composePull, o as buildManagedServices, G as composeUp } from './src-B3g4Ry1X.js';
2
- import { g as getState } from './state-CL9Kv-vm.js';
3
- import { d as getRequestId, r as requireAdmin, e as errorResponse, k as jsonResponse } from './helpers-uzTc9A0Q.js';
1
+ import { F as createLogger, o as checkDocker, m as buildComposeOptions, w as composePull, n as buildManagedServices, E as composeUp } from './src-BN-m14sE.js';
2
+ import { g as getState } from './state-BjAIjYtQ.js';
3
+ import { d as getRequestId, r as requireAdmin, e as errorResponse, k as jsonResponse } from './helpers-s8d3gE38.js';
4
4
  import { w as withSerialQueue } from './serial-queue-D9FEpYVv.js';
5
5
  import './chunk-CLZ62Ad-.js';
6
6
  import 'node:module';
@@ -23,7 +23,7 @@ import 'zlib';
23
23
  import 'node:assert';
24
24
  import 'node:fs/promises';
25
25
  import 'node:os';
26
- import './endpoints-BnI8UQUm.js';
26
+ import './endpoints-Dq-IqF1t.js';
27
27
 
28
28
  //#region src/routes/admin/containers/pull/+server.ts
29
29
  var logger = createLogger("containers-pull");
@@ -73,4 +73,4 @@ var POST = async (event) => {
73
73
  };
74
74
 
75
75
  export { POST };
76
- //# sourceMappingURL=_server.ts-2fxcxBzC.js.map
76
+ //# sourceMappingURL=_server.ts-BwQSiREZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_server.ts-BwQSiREZ.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/containers/pull/_server.ts.js"],"sourcesContent":["import { L as buildComposeOptions, V as buildManagedServices, X as checkDocker, hn as createLogger, nt as composePull, st as composeUp } from \"../../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../../chunks/state.js\";\nimport { d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId } from \"../../../../../chunks/helpers.js\";\nimport { t as withSerialQueue } from \"../../../../../chunks/serial-queue.js\";\n//#region src/routes/admin/containers/pull/+server.ts\nvar logger = createLogger(\"containers-pull\");\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tlogger.info(\"pull request received\", { requestId });\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\treturn withSerialQueue(\"admin:containers:pull\", async () => {\n\t\tconst state = getState();\n\t\tconst dockerCheck = await checkDocker();\n\t\tif (!dockerCheck.ok) return errorResponse(503, \"docker_unavailable\", \"Docker is not available\", { stderr: dockerCheck.stderr }, requestId);\n\t\tconst composeOpts = buildComposeOptions(state);\n\t\tlogger.info(\"pulling images\", { requestId });\n\t\tconst pullResult = await composePull(composeOpts);\n\t\tif (!pullResult.ok) {\n\t\t\tlogger.error(\"image pull failed\", {\n\t\t\t\trequestId,\n\t\t\t\tstderr: pullResult.stderr\n\t\t\t});\n\t\t\treturn errorResponse(502, \"pull_failed\", \"Failed to pull images\", { stderr: pullResult.stderr }, requestId);\n\t\t}\n\t\tlogger.info(\"recreating containers\", { requestId });\n\t\tconst managedServices = await buildManagedServices(state);\n\t\tconst upResult = await composeUp({\n\t\t\t...composeOpts,\n\t\t\tservices: managedServices,\n\t\t\tforceRecreate: true\n\t\t});\n\t\tif (!upResult.ok) {\n\t\t\tlogger.error(\"compose up failed after pull\", {\n\t\t\t\trequestId,\n\t\t\t\tstderr: upResult.stderr\n\t\t\t});\n\t\t\treturn errorResponse(502, \"up_failed\", \"Images pulled but failed to recreate containers\", { stderr: upResult.stderr }, requestId);\n\t\t}\n\t\tlogger.info(\"pull completed\", {\n\t\t\trequestId,\n\t\t\tstarted: managedServices\n\t\t});\n\t\treturn jsonResponse(200, {\n\t\t\tok: true,\n\t\t\tpulled: pullResult.stdout,\n\t\t\tstarted: managedServices\n\t\t}, requestId);\n\t});\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;AACA,IAAI,MAAM,GAAG,YAAY,CAAC,iBAAiB,CAAC;AACzC,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,EAAE,EAAE,SAAS,EAAE,CAAC;AACpD,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,OAAO,eAAe,CAAC,uBAAuB,EAAE,YAAY;AAC7D,EAAE,MAAM,KAAK,GAAG,QAAQ,EAAE;AAC1B,EAAE,MAAM,WAAW,GAAG,MAAM,WAAW,EAAE;AACzC,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,oBAAoB,EAAE,yBAAyB,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,MAAM,EAAE,EAAE,SAAS,CAAC;AAC5I,EAAE,MAAM,WAAW,GAAG,mBAAmB,CAAC,KAAK,CAAC;AAChD,EAAE,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,SAAS,EAAE,CAAC;AAC9C,EAAE,MAAM,UAAU,GAAG,MAAM,WAAW,CAAC,WAAW,CAAC;AACnD,EAAE,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE;AACtB,GAAG,MAAM,CAAC,KAAK,CAAC,mBAAmB,EAAE;AACrC,IAAI,SAAS;AACb,IAAI,MAAM,EAAE,UAAU,CAAC;AACvB,IAAI,CAAC;AACL,GAAG,OAAO,aAAa,CAAC,GAAG,EAAE,aAAa,EAAE,uBAAuB,EAAE,EAAE,MAAM,EAAE,UAAU,CAAC,MAAM,EAAE,EAAE,SAAS,CAAC;AAC9G,EAAE;AACF,EAAE,MAAM,CAAC,IAAI,CAAC,uBAAuB,EAAE,EAAE,SAAS,EAAE,CAAC;AACrD,EAAE,MAAM,eAAe,GAAG,MAAM,oBAAoB,CAAC,KAAK,CAAC;AAC3D,EAAE,MAAM,QAAQ,GAAG,MAAM,SAAS,CAAC;AACnC,GAAG,GAAG,WAAW;AACjB,GAAG,QAAQ,EAAE,eAAe;AAC5B,GAAG,aAAa,EAAE;AAClB,GAAG,CAAC;AACJ,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;AACpB,GAAG,MAAM,CAAC,KAAK,CAAC,8BAA8B,EAAE;AAChD,IAAI,SAAS;AACb,IAAI,MAAM,EAAE,QAAQ,CAAC;AACrB,IAAI,CAAC;AACL,GAAG,OAAO,aAAa,CAAC,GAAG,EAAE,WAAW,EAAE,iDAAiD,EAAE,EAAE,MAAM,EAAE,QAAQ,CAAC,MAAM,EAAE,EAAE,SAAS,CAAC;AACpI,EAAE;AACF,EAAE,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE;AAChC,GAAG,SAAS;AACZ,GAAG,OAAO,EAAE;AACZ,GAAG,CAAC;AACJ,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AAC3B,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,MAAM,EAAE,UAAU,CAAC,MAAM;AAC5B,GAAG,OAAO,EAAE;AACZ,GAAG,EAAE,SAAS,CAAC;AACf,CAAC,CAAC,CAAC;AACH;;;;"}
@@ -1,5 +1,5 @@
1
- import { k as jsonResponse, d as getRequestId } from './helpers-uzTc9A0Q.js';
2
- import './src-B3g4Ry1X.js';
1
+ import { k as jsonResponse, d as getRequestId } from './helpers-s8d3gE38.js';
2
+ import './src-BN-m14sE.js';
3
3
  import './chunk-CLZ62Ad-.js';
4
4
  import 'node:module';
5
5
  import './provider-constants-DPrj3yBX.js';
@@ -21,8 +21,8 @@ import 'zlib';
21
21
  import 'node:assert';
22
22
  import 'node:fs/promises';
23
23
  import 'node:os';
24
- import './endpoints-BnI8UQUm.js';
25
- import './state-CL9Kv-vm.js';
24
+ import './endpoints-Dq-IqF1t.js';
25
+ import './state-BjAIjYtQ.js';
26
26
 
27
27
  //#region src/routes/health/+server.ts
28
28
  var GET = async (event) => {
@@ -33,4 +33,4 @@ var GET = async (event) => {
33
33
  };
34
34
 
35
35
  export { GET };
36
- //# sourceMappingURL=_server.ts-CzgA6LXe.js.map
36
+ //# sourceMappingURL=_server.ts-Bw_r9OtK.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-CzgA6LXe.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/health/_server.ts.js"],"sourcesContent":["import { l as jsonResponse, o as getRequestId } from \"../../../chunks/helpers.js\";\n//#region src/routes/health/+server.ts\nvar GET = async (event) => {\n\treturn jsonResponse(200, {\n\t\tstatus: \"ok\",\n\t\tservice: \"admin\"\n\t}, getRequestId(event));\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AACA;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,OAAO,YAAY,CAAC,GAAG,EAAE;AAC1B,EAAE,MAAM,EAAE,IAAI;AACd,EAAE,OAAO,EAAE;AACX,EAAE,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC;AACxB;;;;"}
1
+ {"version":3,"file":"_server.ts-Bw_r9OtK.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/health/_server.ts.js"],"sourcesContent":["import { l as jsonResponse, o as getRequestId } from \"../../../chunks/helpers.js\";\n//#region src/routes/health/+server.ts\nvar GET = async (event) => {\n\treturn jsonResponse(200, {\n\t\tstatus: \"ok\",\n\t\tservice: \"admin\"\n\t}, getRequestId(event));\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AACA;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,OAAO,YAAY,CAAC,GAAG,EAAE;AAC1B,EAAE,MAAM,EAAE,IAAI;AACd,EAAE,OAAO,EAAE;AACX,EAAE,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC;AACxB;;;;"}
@@ -1,9 +1,9 @@
1
1
  import { j as json } from './exports-D1quPX8S.js';
2
- import { am as isSetupComplete, aZ as resolveStackDir, aA as performSetup, av as mapDockerError, p as checkDocker } from './src-B3g4Ry1X.js';
3
- import { g as getState, r as resetState } from './state-CL9Kv-vm.js';
4
- import { r as requireAdmin, d as getRequestId, f as getUiLoginPassword, b as createSession } from './helpers-uzTc9A0Q.js';
5
- import { s as sessionCookieHeader } from './session-cookie-DOONPnJ5.js';
6
- import { p as prepareSetupRestorePoint, s as startDeploy, r as resetDeployState } from './setup-deploy-CeeF_6ze.js';
2
+ import { ai as isSetupComplete, aO as resolveStackDir, at as performSetup, ap as mapDockerError, o as checkDocker } from './src-BN-m14sE.js';
3
+ import { g as getState, r as resetState } from './state-BjAIjYtQ.js';
4
+ import { r as requireAdmin, d as getRequestId, f as getUiLoginPassword, b as createSession } from './helpers-s8d3gE38.js';
5
+ import { s as sessionCookieHeader } from './session-cookie-F6DkHp5H.js';
6
+ import { p as prepareSetupRestorePoint, s as startDeploy, r as resetDeployState } from './setup-deploy-BtgW_nbb.js';
7
7
  import './utils-BSRjJDrZ.js';
8
8
  import './chunk-CLZ62Ad-.js';
9
9
  import 'node:module';
@@ -26,7 +26,7 @@ import 'zlib';
26
26
  import 'node:assert';
27
27
  import 'node:fs/promises';
28
28
  import 'node:os';
29
- import './endpoints-BnI8UQUm.js';
29
+ import './endpoints-Dq-IqF1t.js';
30
30
 
31
31
  //#region src/routes/api/setup/complete/+server.ts
32
32
  var POST = async (event) => {
@@ -91,4 +91,4 @@ var POST = async (event) => {
91
91
  };
92
92
 
93
93
  export { POST };
94
- //# sourceMappingURL=_server.ts-DYsP_lpr.js.map
94
+ //# sourceMappingURL=_server.ts-Byn8EbtL.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_server.ts-Byn8EbtL.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/complete/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { P as mapDockerError, X as checkDocker, en as resolveStackDir, o as performSetup, ut as isSetupComplete } from \"../../../../../chunks/src.js\";\nimport { n as resetState, t as getState } from \"../../../../../chunks/state.js\";\nimport { d as requireAdmin, g as getUiLoginPassword, h as createSession, o as getRequestId } from \"../../../../../chunks/helpers.js\";\nimport { r as sessionCookieHeader } from \"../../../../../chunks/session-cookie.js\";\nimport { i as startDeploy, n as prepareSetupRestorePoint, r as resetDeployState } from \"../../../../../chunks/setup-deploy.js\";\n//#region src/routes/api/setup/complete/+server.ts\nvar POST = async (event) => {\n\tif (isSetupComplete(resolveStackDir())) {\n\t\tconst authError = requireAdmin(event, getRequestId(event));\n\t\tif (authError) return authError;\n\t}\n\tconst { request } = event;\n\tlet body;\n\ttry {\n\t\tbody = await request.json();\n\t} catch {\n\t\treturn json({\n\t\t\tok: false,\n\t\t\terror: \"invalid_json\",\n\t\t\tmessage: \"Request body must be valid JSON\"\n\t\t}, { status: 400 });\n\t}\n\tconst dryRun = body.dryRun === true;\n\tlet result;\n\ttry {\n\t\tprepareSetupRestorePoint(getState());\n\t\tresult = await performSetup(body);\n\t} catch (err) {\n\t\tconst mapped = mapDockerError(String(err));\n\t\treturn json({\n\t\t\tok: false,\n\t\t\terror: mapped.code,\n\t\t\tmessage: mapped.message\n\t\t}, { status: 500 });\n\t}\n\tif (!result.ok) return json(result, { status: 400 });\n\tresetState();\n\tconst state = getState();\n\tresetDeployState();\n\tlet dockerCheck = null;\n\tif (!dryRun) {\n\t\tdockerCheck = await checkDocker();\n\t\tif (dockerCheck.ok) startDeploy(state);\n\t\telse return json({\n\t\t\tok: false,\n\t\t\terror: \"docker_unavailable\",\n\t\t\tmessage: \"Docker isn't running. Start Docker Desktop or OrbStack, then try again.\"\n\t\t}, {\n\t\t\tstatus: 503,\n\t\t\theaders: { \"content-type\": \"application/json\" }\n\t\t});\n\t}\n\tconst headers = new Headers({ \"content-type\": \"application/json\" });\n\tif (typeof body.security?.uiLoginPassword === \"string\" && body.security.uiLoginPassword || getUiLoginPassword()) {\n\t\tconst sessionToken = createSession();\n\t\theaders.set(\"set-cookie\", sessionCookieHeader(sessionToken, event.request));\n\t}\n\treturn new Response(JSON.stringify({\n\t\tok: true,\n\t\tdockerAvailable: dockerCheck?.ok ?? false,\n\t\tdryRun\n\t}), {\n\t\tstatus: 200,\n\t\theaders\n\t});\n};\n//#endregion\nexport { POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,IAAI,eAAe,CAAC,eAAe,EAAE,CAAC,EAAE;AACzC,EAAE,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC;AAC5D,EAAE,IAAI,SAAS,EAAE,OAAO,SAAS;AACjC,CAAC;AACD,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK;AAC1B,CAAC,IAAI,IAAI;AACT,CAAC,IAAI;AACL,EAAE,IAAI,GAAG,MAAM,OAAO,CAAC,IAAI,EAAE;AAC7B,CAAC,CAAC,CAAC,MAAM;AACT,EAAE,OAAO,IAAI,CAAC;AACd,GAAG,EAAE,EAAE,KAAK;AACZ,GAAG,KAAK,EAAE,cAAc;AACxB,GAAG,OAAO,EAAE;AACZ,GAAG,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;AACrB,CAAC;AACD,CAAC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,KAAK,IAAI;AACpC,CAAC,IAAI,MAAM;AACX,CAAC,IAAI;AACL,EAAE,wBAAwB,CAAC,QAAQ,EAAE,CAAC;AACtC,EAAE,MAAM,GAAG,MAAM,YAAY,CAAC,IAAI,CAAC;AACnC,CAAC,CAAC,CAAC,OAAO,GAAG,EAAE;AACf,EAAE,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;AAC5C,EAAE,OAAO,IAAI,CAAC;AACd,GAAG,EAAE,EAAE,KAAK;AACZ,GAAG,KAAK,EAAE,MAAM,CAAC,IAAI;AACrB,GAAG,OAAO,EAAE,MAAM,CAAC;AACnB,GAAG,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;AACrB,CAAC;AACD,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,IAAI,CAAC,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;AACrD,CAAC,UAAU,EAAE;AACb,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,gBAAgB,EAAE;AACnB,CAAC,IAAI,WAAW,GAAG,IAAI;AACvB,CAAC,IAAI,CAAC,MAAM,EAAE;AACd,EAAE,WAAW,GAAG,MAAM,WAAW,EAAE;AACnC,EAAE,IAAI,WAAW,CAAC,EAAE,EAAE,WAAW,CAAC,KAAK,CAAC;AACxC,OAAO,OAAO,IAAI,CAAC;AACnB,GAAG,EAAE,EAAE,KAAK;AACZ,GAAG,KAAK,EAAE,oBAAoB;AAC9B,GAAG,OAAO,EAAE;AACZ,GAAG,EAAE;AACL,GAAG,MAAM,EAAE,GAAG;AACd,GAAG,OAAO,EAAE,EAAE,cAAc,EAAE,kBAAkB;AAChD,GAAG,CAAC;AACJ,CAAC;AACD,CAAC,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,EAAE,cAAc,EAAE,kBAAkB,EAAE,CAAC;AACpE,CAAC,IAAI,OAAO,IAAI,CAAC,QAAQ,EAAE,eAAe,KAAK,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,eAAe,IAAI,kBAAkB,EAAE,EAAE;AAClH,EAAE,MAAM,YAAY,GAAG,aAAa,EAAE;AACtC,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,mBAAmB,CAAC,YAAY,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;AAC7E,CAAC;AACD,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC;AACpC,EAAE,EAAE,EAAE,IAAI;AACV,EAAE,eAAe,EAAE,WAAW,EAAE,EAAE,IAAI,KAAK;AAC3C,EAAE;AACF,EAAE,CAAC,EAAE;AACL,EAAE,MAAM,EAAE,GAAG;AACb,EAAE;AACF,EAAE,CAAC;AACH;;;;"}
@@ -1,6 +1,6 @@
1
- import { b3 as summarizeBackups, ap as listBackupDirs, aC as pruneBackupDirs, H as createLogger } from './src-B3g4Ry1X.js';
2
- import { g as getState } from './state-CL9Kv-vm.js';
3
- import { d as getRequestId, r as requireAdmin, k as jsonResponse, e as errorResponse } from './helpers-uzTc9A0Q.js';
1
+ import { aU as summarizeBackups, al as listBackupDirs, av as pruneBackupDirs, F as createLogger } from './src-BN-m14sE.js';
2
+ import { g as getState } from './state-BjAIjYtQ.js';
3
+ import { d as getRequestId, r as requireAdmin, k as jsonResponse, e as errorResponse } from './helpers-s8d3gE38.js';
4
4
  import './chunk-CLZ62Ad-.js';
5
5
  import 'node:module';
6
6
  import './provider-constants-DPrj3yBX.js';
@@ -22,7 +22,7 @@ import 'zlib';
22
22
  import 'node:assert';
23
23
  import 'node:fs/promises';
24
24
  import 'node:os';
25
- import './endpoints-BnI8UQUm.js';
25
+ import './endpoints-Dq-IqF1t.js';
26
26
 
27
27
  //#region src/routes/admin/backups/+server.ts
28
28
  var logger = createLogger("backups-admin");
@@ -86,4 +86,4 @@ var POST = async (event) => {
86
86
  };
87
87
 
88
88
  export { GET, POST };
89
- //# sourceMappingURL=_server.ts-BRTk2wfW.js.map
89
+ //# sourceMappingURL=_server.ts-C0b2kLwv.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-BRTk2wfW.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/backups/_server.ts.js"],"sourcesContent":["import { Cn as summarizeBackups, Sn as pruneBackupDirs, Tn as createLogger, xn as listBackupDirs } from \"../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../chunks/state.js\";\nimport { d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId } from \"../../../../chunks/helpers.js\";\n//#region src/routes/admin/backups/+server.ts\nvar logger = createLogger(\"backups-admin\");\n/**\n* #499 — backup visibility. Returns count, total size, last-backup time and a\n* per-backup list (newest first) so the UI can surface the recovery net.\n* Read-only.\n*/\nvar GET = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst state = getState();\n\ttry {\n\t\treturn jsonResponse(200, {\n\t\t\tok: true,\n\t\t\t...summarizeBackups(state.homeDir)\n\t\t}, requestId);\n\t} catch (e) {\n\t\treturn errorResponse(500, \"backups_list_failed\", e instanceof Error ? e.message : String(e), {}, requestId);\n\t}\n};\n/**\n* #499 — drives the EXISTING confirm-gated prune. The UI must pass an explicit\n* `keep` count (the confirmation is the UI's modal); this NEVER auto-prunes and\n* keeps the newest `keep` snapshots, deleting only the older ones.\n*/\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tlet body;\n\ttry {\n\t\tbody = await event.request.json();\n\t} catch {\n\t\tbody = {};\n\t}\n\tconst keep = Number(body.keep);\n\tif (!Number.isInteger(keep) || keep < 0) return errorResponse(400, \"invalid_keep\", \"`keep` must be a non-negative integer\", {}, requestId);\n\tconst state = getState();\n\ttry {\n\t\tif (listBackupDirs(state.homeDir).slice(keep).length === 0) return jsonResponse(200, {\n\t\t\tok: true,\n\t\t\tdeleted: [],\n\t\t\tkept: keep\n\t\t}, requestId);\n\t\tconst deleted = pruneBackupDirs(state.homeDir, keep);\n\t\tlogger.info(\"pruned backups via admin\", {\n\t\t\trequestId,\n\t\t\tdeleted: deleted.length,\n\t\t\tkept: keep\n\t\t});\n\t\treturn jsonResponse(200, {\n\t\t\tok: true,\n\t\t\tdeleted,\n\t\t\tkept: keep\n\t\t}, requestId);\n\t} catch (e) {\n\t\treturn errorResponse(500, \"backups_prune_failed\", e instanceof Error ? e.message : String(e), {}, requestId);\n\t}\n};\n//#endregion\nexport { GET, POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACA,IAAI,MAAM,GAAG,YAAY,CAAC,eAAe,CAAC;AAC1C;AACA;AACA;AACA;AACA;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,IAAI;AACL,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AAC3B,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,GAAG,gBAAgB,CAAC,KAAK,CAAC,OAAO;AACpC,GAAG,EAAE,SAAS,CAAC;AACf,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE;AACb,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,qBAAqB,EAAE,CAAC,YAAY,KAAK,GAAG,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC;AAC7G,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,IAAI,IAAI;AACT,CAAC,IAAI;AACL,EAAE,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE;AACnC,CAAC,CAAC,CAAC,MAAM;AACT,EAAE,IAAI,GAAG,EAAE;AACX,CAAC;AACD,CAAC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;AAC/B,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,cAAc,EAAE,uCAAuC,EAAE,EAAE,EAAE,SAAS,CAAC;AAC3I,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,IAAI;AACL,EAAE,IAAI,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AACvF,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,OAAO,EAAE,EAAE;AACd,GAAG,IAAI,EAAE;AACT,GAAG,EAAE,SAAS,CAAC;AACf,EAAE,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC;AACtD,EAAE,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE;AAC1C,GAAG,SAAS;AACZ,GAAG,OAAO,EAAE,OAAO,CAAC,MAAM;AAC1B,GAAG,IAAI,EAAE;AACT,GAAG,CAAC;AACJ,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AAC3B,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,OAAO;AACV,GAAG,IAAI,EAAE;AACT,GAAG,EAAE,SAAS,CAAC;AACf,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE;AACb,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,sBAAsB,EAAE,CAAC,YAAY,KAAK,GAAG,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC;AAC9G,CAAC;AACD;;;;"}
1
+ {"version":3,"file":"_server.ts-C0b2kLwv.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/backups/_server.ts.js"],"sourcesContent":["import { dn as listBackupDirs, fn as pruneBackupDirs, hn as createLogger, pn as summarizeBackups } from \"../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../chunks/state.js\";\nimport { d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId } from \"../../../../chunks/helpers.js\";\n//#region src/routes/admin/backups/+server.ts\nvar logger = createLogger(\"backups-admin\");\n/**\n* #499 — backup visibility. Returns count, total size, last-backup time and a\n* per-backup list (newest first) so the UI can surface the recovery net.\n* Read-only.\n*/\nvar GET = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst state = getState();\n\ttry {\n\t\treturn jsonResponse(200, {\n\t\t\tok: true,\n\t\t\t...summarizeBackups(state.homeDir)\n\t\t}, requestId);\n\t} catch (e) {\n\t\treturn errorResponse(500, \"backups_list_failed\", e instanceof Error ? e.message : String(e), {}, requestId);\n\t}\n};\n/**\n* #499 — drives the EXISTING confirm-gated prune. The UI must pass an explicit\n* `keep` count (the confirmation is the UI's modal); this NEVER auto-prunes and\n* keeps the newest `keep` snapshots, deleting only the older ones.\n*/\nvar POST = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tlet body;\n\ttry {\n\t\tbody = await event.request.json();\n\t} catch {\n\t\tbody = {};\n\t}\n\tconst keep = Number(body.keep);\n\tif (!Number.isInteger(keep) || keep < 0) return errorResponse(400, \"invalid_keep\", \"`keep` must be a non-negative integer\", {}, requestId);\n\tconst state = getState();\n\ttry {\n\t\tif (listBackupDirs(state.homeDir).slice(keep).length === 0) return jsonResponse(200, {\n\t\t\tok: true,\n\t\t\tdeleted: [],\n\t\t\tkept: keep\n\t\t}, requestId);\n\t\tconst deleted = pruneBackupDirs(state.homeDir, keep);\n\t\tlogger.info(\"pruned backups via admin\", {\n\t\t\trequestId,\n\t\t\tdeleted: deleted.length,\n\t\t\tkept: keep\n\t\t});\n\t\treturn jsonResponse(200, {\n\t\t\tok: true,\n\t\t\tdeleted,\n\t\t\tkept: keep\n\t\t}, requestId);\n\t} catch (e) {\n\t\treturn errorResponse(500, \"backups_prune_failed\", e instanceof Error ? e.message : String(e), {}, requestId);\n\t}\n};\n//#endregion\nexport { GET, POST };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACA,IAAI,MAAM,GAAG,YAAY,CAAC,eAAe,CAAC;AAC1C;AACA;AACA;AACA;AACA;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,IAAI;AACL,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AAC3B,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,GAAG,gBAAgB,CAAC,KAAK,CAAC,OAAO;AACpC,GAAG,EAAE,SAAS,CAAC;AACf,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE;AACb,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,qBAAqB,EAAE,CAAC,YAAY,KAAK,GAAG,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC;AAC7G,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACG,IAAC,IAAI,GAAG,OAAO,KAAK,KAAK;AAC5B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,IAAI,IAAI;AACT,CAAC,IAAI;AACL,EAAE,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE;AACnC,CAAC,CAAC,CAAC,MAAM;AACT,EAAE,IAAI,GAAG,EAAE;AACX,CAAC;AACD,CAAC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;AAC/B,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,cAAc,EAAE,uCAAuC,EAAE,EAAE,EAAE,SAAS,CAAC;AAC3I,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,IAAI;AACL,EAAE,IAAI,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AACvF,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,OAAO,EAAE,EAAE;AACd,GAAG,IAAI,EAAE;AACT,GAAG,EAAE,SAAS,CAAC;AACf,EAAE,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC;AACtD,EAAE,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE;AAC1C,GAAG,SAAS;AACZ,GAAG,OAAO,EAAE,OAAO,CAAC,MAAM;AAC1B,GAAG,IAAI,EAAE;AACT,GAAG,CAAC;AACJ,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AAC3B,GAAG,EAAE,EAAE,IAAI;AACX,GAAG,OAAO;AACV,GAAG,IAAI,EAAE;AACT,GAAG,EAAE,SAAS,CAAC;AACf,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE;AACb,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,sBAAsB,EAAE,CAAC,YAAY,KAAK,GAAG,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC;AAC9G,CAAC;AACD;;;;"}
@@ -1,8 +1,8 @@
1
1
  import { j as json } from './exports-D1quPX8S.js';
2
- import { g as getState } from './state-CL9Kv-vm.js';
3
- import { g as getDeployState } from './setup-deploy-CeeF_6ze.js';
2
+ import { g as getState } from './state-BjAIjYtQ.js';
3
+ import { g as getDeployState } from './setup-deploy-BtgW_nbb.js';
4
4
  import './utils-BSRjJDrZ.js';
5
- import './src-B3g4Ry1X.js';
5
+ import './src-BN-m14sE.js';
6
6
  import './chunk-CLZ62Ad-.js';
7
7
  import 'node:module';
8
8
  import './provider-constants-DPrj3yBX.js';
@@ -47,4 +47,4 @@ var GET = () => {
47
47
  };
48
48
 
49
49
  export { GET };
50
- //# sourceMappingURL=_server.ts-CFNWzRBr.js.map
50
+ //# sourceMappingURL=_server.ts-C2dpWx7K.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-CFNWzRBr.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/deploy-status/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { t as getState } from \"../../../../../chunks/state.js\";\nimport { t as getDeployState } from \"../../../../../chunks/setup-deploy.js\";\n//#region src/routes/api/setup/deploy-status/+server.ts\nfunction resolvePorts() {\n\treturn {\n\t\tadmin: Number(process.env.OP_HOST_UI_PORT) || 3880,\n\t\tassistant: Number(process.env.OP_HOST_ASSISTANT_PORT) || 3800\n\t};\n}\nvar GET = () => {\n\tconst state = getDeployState(getState());\n\treturn json({\n\t\tok: true,\n\t\tsetupComplete: state.setupComplete,\n\t\tdeploying: state.deploying,\n\t\tdeployStatus: state.deployStatus,\n\t\tdeployError: state.deployError,\n\t\timageWarning: state.imageWarning,\n\t\tphase: state.phase,\n\t\tports: resolvePorts()\n\t});\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACA,SAAS,YAAY,GAAG;AACxB,CAAC,OAAO;AACR,EAAE,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,IAAI;AACpD,EAAE,SAAS,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,IAAI;AAC3D,EAAE;AACF;AACG,IAAC,GAAG,GAAG,MAAM;AAChB,CAAC,MAAM,KAAK,GAAG,cAAc,CAAC,QAAQ,EAAE,CAAC;AACzC,CAAC,OAAO,IAAI,CAAC;AACb,EAAE,EAAE,EAAE,IAAI;AACV,EAAE,aAAa,EAAE,KAAK,CAAC,aAAa;AACpC,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS;AAC5B,EAAE,YAAY,EAAE,KAAK,CAAC,YAAY;AAClC,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW;AAChC,EAAE,YAAY,EAAE,KAAK,CAAC,YAAY;AAClC,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK;AACpB,EAAE,KAAK,EAAE,YAAY;AACrB,EAAE,CAAC;AACH;;;;"}
1
+ {"version":3,"file":"_server.ts-C2dpWx7K.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/api/setup/deploy-status/_server.ts.js"],"sourcesContent":["import { r as json } from \"../../../../../chunks/exports.js\";\nimport { t as getState } from \"../../../../../chunks/state.js\";\nimport { t as getDeployState } from \"../../../../../chunks/setup-deploy.js\";\n//#region src/routes/api/setup/deploy-status/+server.ts\nfunction resolvePorts() {\n\treturn {\n\t\tadmin: Number(process.env.OP_HOST_UI_PORT) || 3880,\n\t\tassistant: Number(process.env.OP_HOST_ASSISTANT_PORT) || 3800\n\t};\n}\nvar GET = () => {\n\tconst state = getDeployState(getState());\n\treturn json({\n\t\tok: true,\n\t\tsetupComplete: state.setupComplete,\n\t\tdeploying: state.deploying,\n\t\tdeployStatus: state.deployStatus,\n\t\tdeployError: state.deployError,\n\t\timageWarning: state.imageWarning,\n\t\tphase: state.phase,\n\t\tports: resolvePorts()\n\t});\n};\n//#endregion\nexport { GET };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACA,SAAS,YAAY,GAAG;AACxB,CAAC,OAAO;AACR,EAAE,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,IAAI;AACpD,EAAE,SAAS,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,IAAI;AAC3D,EAAE;AACF;AACG,IAAC,GAAG,GAAG,MAAM;AAChB,CAAC,MAAM,KAAK,GAAG,cAAc,CAAC,QAAQ,EAAE,CAAC;AACzC,CAAC,OAAO,IAAI,CAAC;AACb,EAAE,EAAE,EAAE,IAAI;AACV,EAAE,aAAa,EAAE,KAAK,CAAC,aAAa;AACpC,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS;AAC5B,EAAE,YAAY,EAAE,KAAK,CAAC,YAAY;AAClC,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW;AAChC,EAAE,YAAY,EAAE,KAAK,CAAC,YAAY;AAClC,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK;AACpB,EAAE,KAAK,EAAE,YAAY;AACrB,EAAE,CAAC;AACH;;;;"}
@@ -1,6 +1,6 @@
1
- import { U as disableHostAkmSharing, ab as getHostAkmSharingStatus, W as enableHostAkmSharing } from './src-B3g4Ry1X.js';
2
- import { g as getState } from './state-CL9Kv-vm.js';
3
- import { d as getRequestId, r as requireAdmin, k as jsonResponse, p as parseJsonBody, j as jsonBodyError, e as errorResponse } from './helpers-uzTc9A0Q.js';
1
+ import { S as disableHostAkmSharing, a9 as getHostAkmSharingStatus, U as enableHostAkmSharing } from './src-BN-m14sE.js';
2
+ import { g as getState } from './state-BjAIjYtQ.js';
3
+ import { d as getRequestId, r as requireAdmin, k as jsonResponse, p as parseJsonBody, j as jsonBodyError, e as errorResponse } from './helpers-s8d3gE38.js';
4
4
  import './chunk-CLZ62Ad-.js';
5
5
  import 'node:module';
6
6
  import './provider-constants-DPrj3yBX.js';
@@ -22,7 +22,7 @@ import 'zlib';
22
22
  import 'node:assert';
23
23
  import 'node:fs/promises';
24
24
  import 'node:os';
25
- import './endpoints-BnI8UQUm.js';
25
+ import './endpoints-Dq-IqF1t.js';
26
26
 
27
27
  //#region src/routes/admin/akm/host-sharing/+server.ts
28
28
  var GET = async (event) => {
@@ -64,4 +64,4 @@ var DELETE = async (event) => {
64
64
  };
65
65
 
66
66
  export { DELETE, GET, PUT };
67
- //# sourceMappingURL=_server.ts-F0nw0UvB.js.map
67
+ //# sourceMappingURL=_server.ts-C3asto5q.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_server.ts-F0nw0UvB.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/akm/host-sharing/_server.ts.js"],"sourcesContent":["import { C as disableHostAkmSharing, T as getHostAkmSharingStatus, w as enableHostAkmSharing } from \"../../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../../chunks/state.js\";\nimport { c as jsonBodyError, d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId, u as parseJsonBody } from \"../../../../../chunks/helpers.js\";\n//#region src/routes/admin/akm/host-sharing/+server.ts\nvar GET = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\treturn jsonResponse(200, { sharing: getHostAkmSharingStatus(getState()) }, requestId);\n};\nvar PUT = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst result = await parseJsonBody(event.request);\n\tif (\"error\" in result) return jsonBodyError(result, requestId);\n\tconst opts = result.data;\n\tconst writable = opts.writable === void 0 ? true : opts.writable === true;\n\tconst importProfiles = opts.importProfiles === true;\n\tconst state = getState();\n\ttry {\n\t\tconst { profilesImported } = enableHostAkmSharing(state, {\n\t\t\twritable,\n\t\t\timportProfiles\n\t\t});\n\t\treturn jsonResponse(200, {\n\t\t\tsharing: getHostAkmSharingStatus(state),\n\t\t\tprofilesImported\n\t\t}, requestId);\n\t} catch (err) {\n\t\treturn errorResponse(409, \"conflict\", err.message, {}, requestId);\n\t}\n};\nvar DELETE = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst state = getState();\n\tdisableHostAkmSharing(state);\n\treturn jsonResponse(200, { sharing: getHostAkmSharingStatus(state) }, requestId);\n};\n//#endregion\nexport { DELETE, GET, PUT };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,OAAO,YAAY,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,uBAAuB,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE,SAAS,CAAC;AACtF;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC;AAClD,CAAC,IAAI,OAAO,IAAI,MAAM,EAAE,OAAO,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC;AAC/D,CAAC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI;AACzB,CAAC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,KAAK,MAAM,GAAG,IAAI,GAAG,IAAI,CAAC,QAAQ,KAAK,IAAI;AAC1E,CAAC,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,KAAK,IAAI;AACpD,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,IAAI;AACL,EAAE,MAAM,EAAE,gBAAgB,EAAE,GAAG,oBAAoB,CAAC,KAAK,EAAE;AAC3D,GAAG,QAAQ;AACX,GAAG;AACH,GAAG,CAAC;AACJ,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AAC3B,GAAG,OAAO,EAAE,uBAAuB,CAAC,KAAK,CAAC;AAC1C,GAAG;AACH,GAAG,EAAE,SAAS,CAAC;AACf,CAAC,CAAC,CAAC,OAAO,GAAG,EAAE;AACf,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,CAAC,OAAO,EAAE,EAAE,EAAE,SAAS,CAAC;AACnE,CAAC;AACD;AACG,IAAC,MAAM,GAAG,OAAO,KAAK,KAAK;AAC9B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,qBAAqB,CAAC,KAAK,CAAC;AAC7B,CAAC,OAAO,YAAY,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,uBAAuB,CAAC,KAAK,CAAC,EAAE,EAAE,SAAS,CAAC;AACjF;;;;"}
1
+ {"version":3,"file":"_server.ts-C3asto5q.js","sources":["../../../.svelte-kit/adapter-node/entries/endpoints/admin/akm/host-sharing/_server.ts.js"],"sourcesContent":["import { C as getHostAkmSharingStatus, S as enableHostAkmSharing, x as disableHostAkmSharing } from \"../../../../../chunks/src.js\";\nimport { t as getState } from \"../../../../../chunks/state.js\";\nimport { c as jsonBodyError, d as requireAdmin, i as errorResponse, l as jsonResponse, o as getRequestId, u as parseJsonBody } from \"../../../../../chunks/helpers.js\";\n//#region src/routes/admin/akm/host-sharing/+server.ts\nvar GET = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\treturn jsonResponse(200, { sharing: getHostAkmSharingStatus(getState()) }, requestId);\n};\nvar PUT = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst result = await parseJsonBody(event.request);\n\tif (\"error\" in result) return jsonBodyError(result, requestId);\n\tconst opts = result.data;\n\tconst writable = opts.writable === void 0 ? true : opts.writable === true;\n\tconst importProfiles = opts.importProfiles === true;\n\tconst state = getState();\n\ttry {\n\t\tconst { profilesImported } = enableHostAkmSharing(state, {\n\t\t\twritable,\n\t\t\timportProfiles\n\t\t});\n\t\treturn jsonResponse(200, {\n\t\t\tsharing: getHostAkmSharingStatus(state),\n\t\t\tprofilesImported\n\t\t}, requestId);\n\t} catch (err) {\n\t\treturn errorResponse(409, \"conflict\", err.message, {}, requestId);\n\t}\n};\nvar DELETE = async (event) => {\n\tconst requestId = getRequestId(event);\n\tconst authError = requireAdmin(event, requestId);\n\tif (authError) return authError;\n\tconst state = getState();\n\tdisableHostAkmSharing(state);\n\treturn jsonResponse(200, { sharing: getHostAkmSharingStatus(state) }, requestId);\n};\n//#endregion\nexport { DELETE, GET, PUT };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,OAAO,YAAY,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,uBAAuB,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE,SAAS,CAAC;AACtF;AACG,IAAC,GAAG,GAAG,OAAO,KAAK,KAAK;AAC3B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC;AAClD,CAAC,IAAI,OAAO,IAAI,MAAM,EAAE,OAAO,aAAa,CAAC,MAAM,EAAE,SAAS,CAAC;AAC/D,CAAC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI;AACzB,CAAC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,KAAK,MAAM,GAAG,IAAI,GAAG,IAAI,CAAC,QAAQ,KAAK,IAAI;AAC1E,CAAC,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,KAAK,IAAI;AACpD,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,IAAI;AACL,EAAE,MAAM,EAAE,gBAAgB,EAAE,GAAG,oBAAoB,CAAC,KAAK,EAAE;AAC3D,GAAG,QAAQ;AACX,GAAG;AACH,GAAG,CAAC;AACJ,EAAE,OAAO,YAAY,CAAC,GAAG,EAAE;AAC3B,GAAG,OAAO,EAAE,uBAAuB,CAAC,KAAK,CAAC;AAC1C,GAAG;AACH,GAAG,EAAE,SAAS,CAAC;AACf,CAAC,CAAC,CAAC,OAAO,GAAG,EAAE;AACf,EAAE,OAAO,aAAa,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,CAAC,OAAO,EAAE,EAAE,EAAE,SAAS,CAAC;AACnE,CAAC;AACD;AACG,IAAC,MAAM,GAAG,OAAO,KAAK,KAAK;AAC9B,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC;AACtC,CAAC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,EAAE,SAAS,CAAC;AACjD,CAAC,IAAI,SAAS,EAAE,OAAO,SAAS;AAChC,CAAC,MAAM,KAAK,GAAG,QAAQ,EAAE;AACzB,CAAC,qBAAqB,CAAC,KAAK,CAAC;AAC7B,CAAC,OAAO,YAAY,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,uBAAuB,CAAC,KAAK,CAAC,EAAE,EAAE,SAAS,CAAC;AACjF;;;;"}