squidcloudctl 1.1.0 → 1.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (231) hide show
  1. package/dist/auth-revoke-I5FM6N2S.js +2 -0
  2. package/dist/{auth-revoke-OC67YCEQ.js.map → auth-revoke-I5FM6N2S.js.map} +1 -1
  3. package/dist/{auth-sessions-XIBWY6BL.js → auth-sessions-ALQEGBDS.js} +2 -2
  4. package/dist/{auth-sessions-XIBWY6BL.js.map → auth-sessions-ALQEGBDS.js.map} +1 -1
  5. package/dist/{auth-status-B5VLDH27.js → auth-status-4VVTCDII.js} +2 -2
  6. package/dist/{auth-status-B5VLDH27.js.map → auth-status-4VVTCDII.js.map} +1 -1
  7. package/dist/bin/squidcloud.js +2 -2
  8. package/dist/bin/squidcloud.js.map +1 -1
  9. package/dist/chunk-4NTVRCZM.js +2 -0
  10. package/dist/chunk-4NTVRCZM.js.map +1 -0
  11. package/dist/{chunk-RWWBBPEJ.js → chunk-BC2OVPRV.js} +2 -2
  12. package/dist/{chunk-RWWBBPEJ.js.map → chunk-BC2OVPRV.js.map} +1 -1
  13. package/dist/chunk-FYFPDKJM.js +3 -0
  14. package/dist/chunk-FYFPDKJM.js.map +1 -0
  15. package/dist/client-RFYERFWZ.js +2 -0
  16. package/dist/{client-FRNT7PEB.js.map → client-RFYERFWZ.js.map} +1 -1
  17. package/dist/{collab-activity-GQOGCECR.js → collab-activity-5RK36CJW.js} +2 -2
  18. package/dist/{collab-activity-GQOGCECR.js.map → collab-activity-5RK36CJW.js.map} +1 -1
  19. package/dist/collab-invite-HAMMPEAQ.js +2 -0
  20. package/dist/{collab-invite-HUSQYV23.js.map → collab-invite-HAMMPEAQ.js.map} +1 -1
  21. package/dist/collab-leave-MTCXHQ4T.js +2 -0
  22. package/dist/{collab-leave-W2ESTT5L.js.map → collab-leave-MTCXHQ4T.js.map} +1 -1
  23. package/dist/{collab-list-722OEBJQ.js → collab-list-JV4ZCWLB.js} +2 -2
  24. package/dist/{collab-list-722OEBJQ.js.map → collab-list-JV4ZCWLB.js.map} +1 -1
  25. package/dist/collab-remove-DO4BIA5R.js +2 -0
  26. package/dist/{collab-remove-ZMB22U2T.js.map → collab-remove-DO4BIA5R.js.map} +1 -1
  27. package/dist/collab-transfer-6CG5PHVC.js +2 -0
  28. package/dist/{collab-transfer-56MH4IT6.js.map → collab-transfer-6CG5PHVC.js.map} +1 -1
  29. package/dist/deploy-X5HX7V4J.js +3 -0
  30. package/dist/{deploy-WK3VAA7D.js.map → deploy-X5HX7V4J.js.map} +1 -1
  31. package/dist/{doctor-C7TZGTCO.js → doctor-RSKBJYUX.js} +2 -2
  32. package/dist/{doctor-C7TZGTCO.js.map → doctor-RSKBJYUX.js.map} +1 -1
  33. package/dist/forms-clear-UJ23UHUN.js +2 -0
  34. package/dist/{forms-clear-2ERBEAEY.js.map → forms-clear-UJ23UHUN.js.map} +1 -1
  35. package/dist/forms-create-CWC7MGOJ.js +2 -0
  36. package/dist/{forms-create-3ONGTRQZ.js.map → forms-create-CWC7MGOJ.js.map} +1 -1
  37. package/dist/forms-delete-TKHTM6L5.js +2 -0
  38. package/dist/{forms-delete-CKLGD52U.js.map → forms-delete-TKHTM6L5.js.map} +1 -1
  39. package/dist/{forms-embed-4S46VDP4.js → forms-embed-FF3VMR4M.js} +3 -3
  40. package/dist/{forms-embed-4S46VDP4.js.map → forms-embed-FF3VMR4M.js.map} +1 -1
  41. package/dist/forms-export-5ZNEL3V2.js +2 -0
  42. package/dist/{forms-export-WGHH5TBF.js.map → forms-export-5ZNEL3V2.js.map} +1 -1
  43. package/dist/{forms-info-OMXUOOBT.js → forms-info-SUST47TN.js} +2 -2
  44. package/dist/{forms-info-OMXUOOBT.js.map → forms-info-SUST47TN.js.map} +1 -1
  45. package/dist/{forms-list-ZRKQXGLM.js → forms-list-W2UUPFFD.js} +2 -2
  46. package/dist/{forms-list-ZRKQXGLM.js.map → forms-list-W2UUPFFD.js.map} +1 -1
  47. package/dist/{forms-submissions-K7W7XYPR.js → forms-submissions-UTLSYPWS.js} +2 -2
  48. package/dist/{forms-submissions-K7W7XYPR.js.map → forms-submissions-UTLSYPWS.js.map} +1 -1
  49. package/dist/login-SO6BZ4HE.js +2 -0
  50. package/dist/{login-JJ7YHQB5.js.map → login-SO6BZ4HE.js.map} +1 -1
  51. package/dist/logout-QERO6G6B.js +2 -0
  52. package/dist/{logout-PS2XK3GB.js.map → logout-QERO6G6B.js.map} +1 -1
  53. package/dist/logs-export-DYOPV2LT.js +2 -0
  54. package/dist/{logs-export-55G3COYK.js.map → logs-export-DYOPV2LT.js.map} +1 -1
  55. package/dist/{logs-search-5QCEBZ6W.js → logs-search-323KRPG4.js} +2 -2
  56. package/dist/{logs-search-5QCEBZ6W.js.map → logs-search-323KRPG4.js.map} +1 -1
  57. package/dist/{logs-tail-OYLJ5EOM.js → logs-tail-J64TCZG5.js} +3 -3
  58. package/dist/{logs-tail-OYLJ5EOM.js.map → logs-tail-J64TCZG5.js.map} +1 -1
  59. package/dist/{monitor-XUW4BMBQ.js → monitor-DKLGO5H7.js} +2 -2
  60. package/dist/{monitor-XUW4BMBQ.js.map → monitor-DKLGO5H7.js.map} +1 -1
  61. package/dist/{monitor-automations-TSO65I6U.js → monitor-automations-4XOOCRFY.js} +2 -2
  62. package/dist/{monitor-automations-TSO65I6U.js.map → monitor-automations-4XOOCRFY.js.map} +1 -1
  63. package/dist/{monitor-pipelines-OPCTGGRR.js → monitor-pipelines-EPL24J3S.js} +2 -2
  64. package/dist/{monitor-pipelines-OPCTGGRR.js.map → monitor-pipelines-EPL24J3S.js.map} +1 -1
  65. package/dist/{monitor-sites-OLSGE4V2.js → monitor-sites-QIVG5TPF.js} +2 -2
  66. package/dist/{monitor-sites-OLSGE4V2.js.map → monitor-sites-QIVG5TPF.js.map} +1 -1
  67. package/dist/{monitor-storage-CVFXC3ZS.js → monitor-storage-HBCC34K7.js} +2 -2
  68. package/dist/{monitor-storage-CVFXC3ZS.js.map → monitor-storage-HBCC34K7.js.map} +1 -1
  69. package/dist/scripts-cancel-JS3LL2AT.js +2 -0
  70. package/dist/{scripts-cancel-OR2UFFC3.js.map → scripts-cancel-JS3LL2AT.js.map} +1 -1
  71. package/dist/scripts-delete-274TW63X.js +2 -0
  72. package/dist/{scripts-delete-HMHBIL4G.js.map → scripts-delete-274TW63X.js.map} +1 -1
  73. package/dist/scripts-disable-JPATOVO4.js +2 -0
  74. package/dist/{scripts-disable-ABFUD34Y.js.map → scripts-disable-JPATOVO4.js.map} +1 -1
  75. package/dist/scripts-enable-JVAA6AMP.js +2 -0
  76. package/dist/{scripts-enable-VMRAPULS.js.map → scripts-enable-JVAA6AMP.js.map} +1 -1
  77. package/dist/{scripts-list-DV2QVLPX.js → scripts-list-YPFNLI3P.js} +2 -2
  78. package/dist/{scripts-list-DV2QVLPX.js.map → scripts-list-YPFNLI3P.js.map} +1 -1
  79. package/dist/scripts-logs-VISO5ONQ.js +2 -0
  80. package/dist/{scripts-logs-AHTMTQ6G.js.map → scripts-logs-VISO5ONQ.js.map} +1 -1
  81. package/dist/scripts-run-3NBYKEMQ.js +2 -0
  82. package/dist/{scripts-run-K2LFPFTH.js.map → scripts-run-3NBYKEMQ.js.map} +1 -1
  83. package/dist/scripts-status-45K3IL5L.js +2 -0
  84. package/dist/{scripts-status-XGI5SMWL.js.map → scripts-status-45K3IL5L.js.map} +1 -1
  85. package/dist/scripts-validate-JZPIIMIX.js +2 -0
  86. package/dist/{scripts-validate-7EZXPO3Q.js.map → scripts-validate-JZPIIMIX.js.map} +1 -1
  87. package/dist/{scripts-watch-HN23AZLJ.js → scripts-watch-XZ7MZIMK.js} +2 -2
  88. package/dist/{scripts-watch-HN23AZLJ.js.map → scripts-watch-XZ7MZIMK.js.map} +1 -1
  89. package/dist/{session-T3DZUXHP.js → session-AZGWAAQQ.js} +2 -2
  90. package/dist/{session-T3DZUXHP.js.map → session-AZGWAAQQ.js.map} +1 -1
  91. package/dist/sign-cancel-OUJM5UZT.js +2 -0
  92. package/dist/{sign-cancel-R7KQFEM3.js.map → sign-cancel-OUJM5UZT.js.map} +1 -1
  93. package/dist/sign-download-FS5G6J27.js +2 -0
  94. package/dist/{sign-download-EHPZ5FMF.js.map → sign-download-FS5G6J27.js.map} +1 -1
  95. package/dist/{sign-list-6N7G36EO.js → sign-list-FV7SQSWT.js} +2 -2
  96. package/dist/{sign-list-6N7G36EO.js.map → sign-list-FV7SQSWT.js.map} +1 -1
  97. package/dist/sign-request-VVFYWT3Y.js +2 -0
  98. package/dist/{sign-request-DW6BS67P.js.map → sign-request-VVFYWT3Y.js.map} +1 -1
  99. package/dist/sign-status-LKG5UFBX.js +2 -0
  100. package/dist/{sign-status-L4PNMSBI.js.map → sign-status-LKG5UFBX.js.map} +1 -1
  101. package/dist/sign-verify-CVTTJSDL.js +2 -0
  102. package/dist/{sign-verify-I6YPHFUW.js.map → sign-verify-CVTTJSDL.js.map} +1 -1
  103. package/dist/{sites-analytics-JMW6DAC3.js → sites-analytics-JK4UFMWX.js} +2 -2
  104. package/dist/{sites-analytics-JMW6DAC3.js.map → sites-analytics-JK4UFMWX.js.map} +1 -1
  105. package/dist/sites-delete-SUHEQDZQ.js +2 -0
  106. package/dist/{sites-delete-M4DJ3GXV.js.map → sites-delete-SUHEQDZQ.js.map} +1 -1
  107. package/dist/{sites-deploys-2HBSXQA4.js → sites-deploys-C4TVID2W.js} +2 -2
  108. package/dist/{sites-deploys-2HBSXQA4.js.map → sites-deploys-C4TVID2W.js.map} +1 -1
  109. package/dist/{sites-info-CIDGRZRJ.js → sites-info-BZUK57TH.js} +2 -2
  110. package/dist/{sites-info-CIDGRZRJ.js.map → sites-info-BZUK57TH.js.map} +1 -1
  111. package/dist/{sites-list-L56B32PU.js → sites-list-LLULSE5J.js} +2 -2
  112. package/dist/{sites-list-L56B32PU.js.map → sites-list-LLULSE5J.js.map} +1 -1
  113. package/dist/{sites-logs-NMNQXOKI.js → sites-logs-NILNXF4L.js} +3 -3
  114. package/dist/{sites-logs-NMNQXOKI.js.map → sites-logs-NILNXF4L.js.map} +1 -1
  115. package/dist/sites-open-R7A5EQWM.js +3 -0
  116. package/dist/{sites-open-JOJQ5PW2.js.map → sites-open-R7A5EQWM.js.map} +1 -1
  117. package/dist/sites-purge-VHERQRUB.js +2 -0
  118. package/dist/{sites-purge-IA2673H4.js.map → sites-purge-VHERQRUB.js.map} +1 -1
  119. package/dist/sites-rename-MOO6HVW3.js +2 -0
  120. package/dist/{sites-rename-WFSBG4ME.js.map → sites-rename-MOO6HVW3.js.map} +1 -1
  121. package/dist/sites-rollback-SPW2Z73L.js +2 -0
  122. package/dist/{sites-rollback-REUDH4TZ.js.map → sites-rollback-SPW2Z73L.js.map} +1 -1
  123. package/dist/sites-unpublish-6P7SQGIU.js +2 -0
  124. package/dist/{sites-unpublish-AS4D6N3M.js.map → sites-unpublish-6P7SQGIU.js.map} +1 -1
  125. package/dist/sites-visibility-R3AQJ76F.js +2 -0
  126. package/dist/{sites-visibility-S3TKH6XD.js.map → sites-visibility-R3AQJ76F.js.map} +1 -1
  127. package/dist/storage-cat-HXFOJJG5.js +2 -0
  128. package/dist/{storage-cat-LZ7LYZAY.js.map → storage-cat-HXFOJJG5.js.map} +1 -1
  129. package/dist/storage-clean-LEQEYWL6.js +2 -0
  130. package/dist/{storage-clean-S57ZHSGL.js.map → storage-clean-LEQEYWL6.js.map} +1 -1
  131. package/dist/storage-cp-JTPTXZRQ.js +2 -0
  132. package/dist/{storage-cp-M2BVRCIL.js.map → storage-cp-JTPTXZRQ.js.map} +1 -1
  133. package/dist/storage-diff-XURHVTPC.js +2 -0
  134. package/dist/{storage-diff-ZATBMPAM.js.map → storage-diff-XURHVTPC.js.map} +1 -1
  135. package/dist/storage-download-5OYCNXKL.js +3 -0
  136. package/dist/{storage-download-PZEEX2Z3.js.map → storage-download-5OYCNXKL.js.map} +1 -1
  137. package/dist/{storage-info-T62YZOPK.js → storage-info-WA74POPR.js} +2 -2
  138. package/dist/{storage-info-T62YZOPK.js.map → storage-info-WA74POPR.js.map} +1 -1
  139. package/dist/{storage-ls-DGOI7ZXX.js → storage-ls-7RZQ3AXR.js} +2 -2
  140. package/dist/{storage-ls-DGOI7ZXX.js.map → storage-ls-7RZQ3AXR.js.map} +1 -1
  141. package/dist/storage-mkdir-NWOHGAQI.js +2 -0
  142. package/dist/{storage-mkdir-J4BYV3QL.js.map → storage-mkdir-NWOHGAQI.js.map} +1 -1
  143. package/dist/storage-mv-XQ7EPX3M.js +2 -0
  144. package/dist/{storage-mv-R73IGYOM.js.map → storage-mv-XQ7EPX3M.js.map} +1 -1
  145. package/dist/storage-rm-LYO6UR3G.js +2 -0
  146. package/dist/{storage-rm-M3UODY5G.js.map → storage-rm-LYO6UR3G.js.map} +1 -1
  147. package/dist/{storage-search-H44Y6OKS.js → storage-search-RIT5ISCA.js} +2 -2
  148. package/dist/{storage-search-H44Y6OKS.js.map → storage-search-RIT5ISCA.js.map} +1 -1
  149. package/dist/storage-share-OURRQWZK.js +2 -0
  150. package/dist/{storage-share-VIJJIHBX.js.map → storage-share-OURRQWZK.js.map} +1 -1
  151. package/dist/storage-tag-NGJGUJSZ.js +2 -0
  152. package/dist/{storage-tag-PAVT6GBZ.js.map → storage-tag-NGJGUJSZ.js.map} +1 -1
  153. package/dist/storage-unshare-3DXEKHEH.js +2 -0
  154. package/dist/{storage-unshare-O3AAJZMT.js.map → storage-unshare-3DXEKHEH.js.map} +1 -1
  155. package/dist/storage-upload-5M6PBHOC.js +2 -0
  156. package/dist/{storage-upload-DRYGLH2O.js.map → storage-upload-5M6PBHOC.js.map} +1 -1
  157. package/dist/{time-list-CW2OOCPT.js → time-list-GMZYZAOU.js} +2 -2
  158. package/dist/{time-list-CW2OOCPT.js.map → time-list-GMZYZAOU.js.map} +1 -1
  159. package/dist/time-lock-2OLEVQPJ.js +2 -0
  160. package/dist/{time-lock-A2MZ3MP2.js.map → time-lock-2OLEVQPJ.js.map} +1 -1
  161. package/dist/time-proof-RUTDAEKP.js +2 -0
  162. package/dist/{time-proof-ZLRY6ZVZ.js.map → time-proof-RUTDAEKP.js.map} +1 -1
  163. package/dist/{time-status-XQLRCYF6.js → time-status-TVNJBFKC.js} +2 -2
  164. package/dist/{time-status-XQLRCYF6.js.map → time-status-TVNJBFKC.js.map} +1 -1
  165. package/dist/time-unlock-OO6QH5R6.js +2 -0
  166. package/dist/{time-unlock-KNMGQ3TK.js.map → time-unlock-OO6QH5R6.js.map} +1 -1
  167. package/dist/update-XJQSXSFU.js +2 -0
  168. package/dist/{update-IYMIV34T.js.map → update-XJQSXSFU.js.map} +1 -1
  169. package/dist/version-LHSDYI7Q.js +2 -0
  170. package/dist/version-LHSDYI7Q.js.map +1 -0
  171. package/dist/{whoami-WIHSRTUN.js → whoami-SAURQARO.js} +2 -2
  172. package/dist/{whoami-WIHSRTUN.js.map → whoami-SAURQARO.js.map} +1 -1
  173. package/package.json +1 -1
  174. package/dist/auth-revoke-OC67YCEQ.js +0 -2
  175. package/dist/chunk-6TS5Y27A.js +0 -6
  176. package/dist/chunk-6TS5Y27A.js.map +0 -1
  177. package/dist/chunk-C5KZCYJ4.js +0 -2
  178. package/dist/chunk-C5KZCYJ4.js.map +0 -1
  179. package/dist/chunk-ON3YIMVG.js +0 -2
  180. package/dist/chunk-ON3YIMVG.js.map +0 -1
  181. package/dist/client-FRNT7PEB.js +0 -2
  182. package/dist/collab-invite-HUSQYV23.js +0 -2
  183. package/dist/collab-leave-W2ESTT5L.js +0 -2
  184. package/dist/collab-remove-ZMB22U2T.js +0 -2
  185. package/dist/collab-transfer-56MH4IT6.js +0 -2
  186. package/dist/deploy-WK3VAA7D.js +0 -3
  187. package/dist/forms-clear-2ERBEAEY.js +0 -2
  188. package/dist/forms-create-3ONGTRQZ.js +0 -2
  189. package/dist/forms-delete-CKLGD52U.js +0 -2
  190. package/dist/forms-export-WGHH5TBF.js +0 -2
  191. package/dist/login-JJ7YHQB5.js +0 -2
  192. package/dist/logout-PS2XK3GB.js +0 -2
  193. package/dist/logs-export-55G3COYK.js +0 -2
  194. package/dist/scripts-cancel-OR2UFFC3.js +0 -2
  195. package/dist/scripts-delete-HMHBIL4G.js +0 -2
  196. package/dist/scripts-disable-ABFUD34Y.js +0 -2
  197. package/dist/scripts-enable-VMRAPULS.js +0 -2
  198. package/dist/scripts-logs-AHTMTQ6G.js +0 -2
  199. package/dist/scripts-run-K2LFPFTH.js +0 -2
  200. package/dist/scripts-status-XGI5SMWL.js +0 -2
  201. package/dist/scripts-validate-7EZXPO3Q.js +0 -2
  202. package/dist/sign-cancel-R7KQFEM3.js +0 -2
  203. package/dist/sign-download-EHPZ5FMF.js +0 -2
  204. package/dist/sign-request-DW6BS67P.js +0 -2
  205. package/dist/sign-status-L4PNMSBI.js +0 -2
  206. package/dist/sign-verify-I6YPHFUW.js +0 -2
  207. package/dist/sites-delete-M4DJ3GXV.js +0 -2
  208. package/dist/sites-open-JOJQ5PW2.js +0 -3
  209. package/dist/sites-purge-IA2673H4.js +0 -2
  210. package/dist/sites-rename-WFSBG4ME.js +0 -2
  211. package/dist/sites-rollback-REUDH4TZ.js +0 -2
  212. package/dist/sites-unpublish-AS4D6N3M.js +0 -2
  213. package/dist/sites-visibility-S3TKH6XD.js +0 -2
  214. package/dist/storage-cat-LZ7LYZAY.js +0 -2
  215. package/dist/storage-clean-S57ZHSGL.js +0 -2
  216. package/dist/storage-cp-M2BVRCIL.js +0 -2
  217. package/dist/storage-diff-ZATBMPAM.js +0 -2
  218. package/dist/storage-download-PZEEX2Z3.js +0 -3
  219. package/dist/storage-mkdir-J4BYV3QL.js +0 -2
  220. package/dist/storage-mv-R73IGYOM.js +0 -2
  221. package/dist/storage-rm-M3UODY5G.js +0 -2
  222. package/dist/storage-share-VIJJIHBX.js +0 -2
  223. package/dist/storage-tag-PAVT6GBZ.js +0 -2
  224. package/dist/storage-unshare-O3AAJZMT.js +0 -2
  225. package/dist/storage-upload-DRYGLH2O.js +0 -2
  226. package/dist/time-lock-A2MZ3MP2.js +0 -2
  227. package/dist/time-proof-ZLRY6ZVZ.js +0 -2
  228. package/dist/time-unlock-KNMGQ3TK.js +0 -2
  229. package/dist/update-IYMIV34T.js +0 -2
  230. package/dist/version-7IHVNLWY.js +0 -2
  231. package/dist/version-7IHVNLWY.js.map +0 -1
@@ -1,2 +1,2 @@
1
- import {d}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import {a as a$1}from'./chunk-THMWE2I6.js';import {c,a}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import t from'chalk';async function m(s,a$2){let o=((await d(`/api/v1/storage/ls?path=${encodeURIComponent(s||"")}&long=${a$2?.long||false}&recursive=${a$2?.recursive||false}`,{authenticated:true})).entries||[]).map(e=>({name:e.type==="folder"?t.hex("#4FC3F7")(e.name+"/"):e.name,type:e.type==="folder"?t.dim("dir"):e.type,size:e.type==="file"?a(e.size):t.dim("-"),mime:e.type==="file"?t.dim(e.mime_type):"",modified:e.updated_at?c(e.updated_at):"",tags:e.tags?.length?t.dim(e.tags.join(",")):""}));if(a$2?.long)console.log(a$1(o,[{key:"name",label:"Name"},{key:"type",label:"Type"},{key:"size",label:"Size"},{key:"mime",label:"MIME"},{key:"modified",label:"Modified"},{key:"tags",label:"Tags"}]));else for(let e of o)console.log(e.name);}export{m as default};//# sourceMappingURL=storage-ls-DGOI7ZXX.js.map
2
- //# sourceMappingURL=storage-ls-DGOI7ZXX.js.map
1
+ import {d}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import {a as a$1}from'./chunk-THMWE2I6.js';import {c,a}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';import t from'chalk';async function m(s,a$2){let o=((await d(`/api/v1/storage/ls?path=${encodeURIComponent(s||"")}&long=${a$2?.long||false}&recursive=${a$2?.recursive||false}`,{authenticated:true})).entries||[]).map(e=>({name:e.type==="folder"?t.hex("#4FC3F7")(e.name+"/"):e.name,type:e.type==="folder"?t.dim("dir"):e.type,size:e.type==="file"?a(e.size):t.dim("-"),mime:e.type==="file"?t.dim(e.mime_type):"",modified:e.updated_at?c(e.updated_at):"",tags:e.tags?.length?t.dim(e.tags.join(",")):""}));if(a$2?.long)console.log(a$1(o,[{key:"name",label:"Name"},{key:"type",label:"Type"},{key:"size",label:"Size"},{key:"mime",label:"MIME"},{key:"modified",label:"Modified"},{key:"tags",label:"Tags"}]));else for(let e of o)console.log(e.name);}export{m as default};//# sourceMappingURL=storage-ls-7RZQ3AXR.js.map
2
+ //# sourceMappingURL=storage-ls-7RZQ3AXR.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-ls.ts"],"names":["storageLs","path","options","rows","apiGet","chalk","formatBytes","formatRelative","renderTable","row"],"mappings":"8NAeA,eAAOA,CAAAA,CAAiCC,CAAAA,CAAeC,IAAkE,CAIvH,IAAMC,CAAAA,CAAAA,CAAAA,CAFO,MAAMC,EAAoC,CAAA,wBAAA,EAA2B,kBAAA,CADhEH,CAAAA,EAAQ,EACoF,CAAC,CAAA,MAAA,EAASC,GAAAA,EAAS,IAAA,EAAQ,KAAK,cAAcA,GAAAA,EAAS,SAAA,EAAa,KAAK,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EAE/L,SAAW,EAAC,EAAG,GAAA,CAAI,CAAA,GAAM,CAC1C,IAAA,CAAM,CAAA,CAAE,IAAA,GAAS,QAAA,CAAWG,EAAM,GAAA,CAAI,SAAS,CAAA,CAAE,CAAA,CAAE,KAAO,GAAG,CAAA,CAAI,CAAA,CAAE,IAAA,CACnE,KAAM,CAAA,CAAE,IAAA,GAAS,QAAA,CAAWA,CAAAA,CAAM,IAAI,KAAK,CAAA,CAAI,CAAA,CAAE,IAAA,CACjD,KAAM,CAAA,CAAE,IAAA,GAAS,MAAA,CAASC,CAAAA,CAAY,EAAE,IAAI,CAAA,CAAID,CAAAA,CAAM,GAAA,CAAI,GAAG,CAAA,CAC7D,IAAA,CAAM,EAAE,IAAA,GAAS,MAAA,CAASA,EAAM,GAAA,CAAI,CAAA,CAAE,SAAS,CAAA,CAAI,GACnD,QAAA,CAAU,CAAA,CAAE,UAAA,CAAaE,CAAAA,CAAe,EAAE,UAAU,CAAA,CAAI,EAAA,CACxD,IAAA,CAAM,EAAE,IAAA,EAAM,MAAA,CAASF,CAAAA,CAAM,GAAA,CAAI,EAAE,IAAA,CAAK,IAAA,CAAK,GAAG,CAAC,EAAI,EACvD,CAAA,CAAE,CAAA,CAEF,GAAIH,KAAS,IAAA,CACX,OAAA,CAAQ,GAAA,CAAIM,GAAAA,CAAYL,EAAM,CAC5B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,MAAA,CAAQ,MAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,OAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,UAAA,CAAY,KAAA,CAAO,UAAW,EACrC,CAAE,GAAA,CAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAC/B,CAAC,CAAC,CAAA,CAAA,aAESM,CAAAA,IAAON,CAAAA,CAChB,QAAQ,GAAA,CAAIM,CAAAA,CAAI,IAAI,EAG1B","file":"storage-ls-DGOI7ZXX.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatBytes, formatRelative } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface StorageEntry {\n name: string\n type: 'file' | 'folder'\n size: number\n mime_type: string\n updated_at: string\n tags?: string[]\n shared?: boolean\n}\n\nexport default async function storageLs(path?: string, options?: { long?: boolean; recursive?: boolean }): Promise<void> {\n const queryPath = path || ''\n const data = await apiGet<{ entries: StorageEntry[] }>(`/api/v1/storage/ls?path=${encodeURIComponent(queryPath)}&long=${options?.long || false}&recursive=${options?.recursive || false}`, { authenticated: true })\n\n const rows = (data.entries || []).map(e => ({\n name: e.type === 'folder' ? chalk.hex('#4FC3F7')(e.name + '/') : e.name,\n type: e.type === 'folder' ? chalk.dim('dir') : e.type,\n size: e.type === 'file' ? formatBytes(e.size) : chalk.dim('-'),\n mime: e.type === 'file' ? chalk.dim(e.mime_type) : '',\n modified: e.updated_at ? formatRelative(e.updated_at) : '',\n tags: e.tags?.length ? chalk.dim(e.tags.join(',')) : '',\n }))\n\n if (options?.long) {\n console.log(renderTable(rows, [\n { key: 'name', label: 'Name' },\n { key: 'type', label: 'Type' },\n { key: 'size', label: 'Size' },\n { key: 'mime', label: 'MIME' },\n { key: 'modified', label: 'Modified' },\n { key: 'tags', label: 'Tags' },\n ]))\n } else {\n for (const row of rows) {\n console.log(row.name)\n }\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-ls.ts"],"names":["storageLs","path","options","rows","apiGet","chalk","formatBytes","formatRelative","renderTable","row"],"mappings":"8NAeA,eAAOA,CAAAA,CAAiCC,CAAAA,CAAeC,IAAkE,CAIvH,IAAMC,CAAAA,CAAAA,CAAAA,CAFO,MAAMC,EAAoC,CAAA,wBAAA,EAA2B,kBAAA,CADhEH,CAAAA,EAAQ,EACoF,CAAC,CAAA,MAAA,EAASC,GAAAA,EAAS,IAAA,EAAQ,KAAK,cAAcA,GAAAA,EAAS,SAAA,EAAa,KAAK,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EAE/L,SAAW,EAAC,EAAG,GAAA,CAAI,CAAA,GAAM,CAC1C,IAAA,CAAM,CAAA,CAAE,IAAA,GAAS,QAAA,CAAWG,EAAM,GAAA,CAAI,SAAS,CAAA,CAAE,CAAA,CAAE,KAAO,GAAG,CAAA,CAAI,CAAA,CAAE,IAAA,CACnE,KAAM,CAAA,CAAE,IAAA,GAAS,QAAA,CAAWA,CAAAA,CAAM,IAAI,KAAK,CAAA,CAAI,CAAA,CAAE,IAAA,CACjD,KAAM,CAAA,CAAE,IAAA,GAAS,MAAA,CAASC,CAAAA,CAAY,EAAE,IAAI,CAAA,CAAID,CAAAA,CAAM,GAAA,CAAI,GAAG,CAAA,CAC7D,IAAA,CAAM,EAAE,IAAA,GAAS,MAAA,CAASA,EAAM,GAAA,CAAI,CAAA,CAAE,SAAS,CAAA,CAAI,GACnD,QAAA,CAAU,CAAA,CAAE,UAAA,CAAaE,CAAAA,CAAe,EAAE,UAAU,CAAA,CAAI,EAAA,CACxD,IAAA,CAAM,EAAE,IAAA,EAAM,MAAA,CAASF,CAAAA,CAAM,GAAA,CAAI,EAAE,IAAA,CAAK,IAAA,CAAK,GAAG,CAAC,EAAI,EACvD,CAAA,CAAE,CAAA,CAEF,GAAIH,KAAS,IAAA,CACX,OAAA,CAAQ,GAAA,CAAIM,GAAAA,CAAYL,EAAM,CAC5B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,MAAA,CAAQ,MAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,OAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,UAAA,CAAY,KAAA,CAAO,UAAW,EACrC,CAAE,GAAA,CAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAC/B,CAAC,CAAC,CAAA,CAAA,aAESM,CAAAA,IAAON,CAAAA,CAChB,QAAQ,GAAA,CAAIM,CAAAA,CAAI,IAAI,EAG1B","file":"storage-ls-7RZQ3AXR.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatBytes, formatRelative } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface StorageEntry {\n name: string\n type: 'file' | 'folder'\n size: number\n mime_type: string\n updated_at: string\n tags?: string[]\n shared?: boolean\n}\n\nexport default async function storageLs(path?: string, options?: { long?: boolean; recursive?: boolean }): Promise<void> {\n const queryPath = path || ''\n const data = await apiGet<{ entries: StorageEntry[] }>(`/api/v1/storage/ls?path=${encodeURIComponent(queryPath)}&long=${options?.long || false}&recursive=${options?.recursive || false}`, { authenticated: true })\n\n const rows = (data.entries || []).map(e => ({\n name: e.type === 'folder' ? chalk.hex('#4FC3F7')(e.name + '/') : e.name,\n type: e.type === 'folder' ? chalk.dim('dir') : e.type,\n size: e.type === 'file' ? formatBytes(e.size) : chalk.dim('-'),\n mime: e.type === 'file' ? chalk.dim(e.mime_type) : '',\n modified: e.updated_at ? formatRelative(e.updated_at) : '',\n tags: e.tags?.length ? chalk.dim(e.tags.join(',')) : '',\n }))\n\n if (options?.long) {\n console.log(renderTable(rows, [\n { key: 'name', label: 'Name' },\n { key: 'type', label: 'Type' },\n { key: 'size', label: 'Size' },\n { key: 'mime', label: 'MIME' },\n { key: 'modified', label: 'Modified' },\n { key: 'tags', label: 'Tags' },\n ]))\n } else {\n for (const row of rows) {\n console.log(row.name)\n }\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {e}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';async function a(r){let e$1=b(`Creating folder ${r}...`);e$1.start(),await e("/api/v1/storage/mkdir",{path:r},{authenticated:true}),e$1.succeed(),g(`Created folder ${r}`);}export{a as default};//# sourceMappingURL=storage-mkdir-NWOHGAQI.js.map
2
+ //# sourceMappingURL=storage-mkdir-NWOHGAQI.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-mkdir.ts"],"names":["storageMkdir","path","spinner","createSpinner","apiPost","logSuccess"],"mappings":"mOAIA,eAAOA,CAAAA,CAAoCC,CAAAA,CAA6B,CACtE,IAAMC,IAAUC,GAAAA,CAAc,CAAA,gBAAA,EAAmBF,CAAI,CAAA,GAAA,CAAK,CAAA,CAC1DC,GAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAQ,uBAAA,CAAyB,CAAE,IAAA,CAAAH,CAAK,CAAA,CAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACxEC,GAAAA,CAAQ,OAAA,EAAQ,CAChBG,CAAAA,CAAW,CAAA,eAAA,EAAkBJ,CAAI,EAAE,EACrC","file":"storage-mkdir-J4BYV3QL.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageMkdir(path: string): Promise<void> {\n const spinner = createSpinner(`Creating folder ${path}...`)\n spinner.start()\n await apiPost('/api/v1/storage/mkdir', { path }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Created folder ${path}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-mkdir.ts"],"names":["storageMkdir","path","spinner","createSpinner","apiPost","logSuccess"],"mappings":"gMAIA,eAAOA,CAAAA,CAAoCC,CAAAA,CAA6B,CACtE,IAAMC,IAAUC,CAAAA,CAAc,CAAA,gBAAA,EAAmBF,CAAI,CAAA,GAAA,CAAK,CAAA,CAC1DC,GAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAQ,uBAAA,CAAyB,CAAE,IAAA,CAAAH,CAAK,CAAA,CAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACxEC,GAAAA,CAAQ,OAAA,EAAQ,CAChBG,CAAAA,CAAW,CAAA,eAAA,EAAkBJ,CAAI,EAAE,EACrC","file":"storage-mkdir-NWOHGAQI.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageMkdir(path: string): Promise<void> {\n const spinner = createSpinner(`Creating folder ${path}...`)\n spinner.start()\n await apiPost('/api/v1/storage/mkdir', { path }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Created folder ${path}`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {e}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';async function a(t,i){let o=b(`Moving ${t} \u2192 ${i}...`);o.start(),await e("/api/v1/storage/move",{source:t,destination:i},{authenticated:true}),o.succeed(),g(`Moved ${t} \u2192 ${i}`);}export{a as default};//# sourceMappingURL=storage-mv-XQ7EPX3M.js.map
2
+ //# sourceMappingURL=storage-mv-XQ7EPX3M.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-mv.ts"],"names":["storageMv","source","dest","spinner","createSpinner","apiPost","logSuccess"],"mappings":"mOAIA,eAAOA,EAAiCC,CAAAA,CAAgBC,CAAAA,CAA6B,CACnF,IAAMC,EAAUC,GAAAA,CAAc,CAAA,OAAA,EAAUH,CAAM,CAAA,QAAA,EAAMC,CAAI,CAAA,GAAA,CAAK,CAAA,CAC7DC,EAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAQ,sBAAA,CAAwB,CAAE,MAAA,CAAAJ,EAAQ,WAAA,CAAaC,CAAK,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC5FC,CAAAA,CAAQ,OAAA,GACRG,CAAAA,CAAW,CAAA,MAAA,EAASL,CAAM,CAAA,QAAA,EAAMC,CAAI,EAAE,EACxC","file":"storage-mv-R73IGYOM.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageMv(source: string, dest: string): Promise<void> {\n const spinner = createSpinner(`Moving ${source} → ${dest}...`)\n spinner.start()\n await apiPost('/api/v1/storage/move', { source, destination: dest }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Moved ${source} → ${dest}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-mv.ts"],"names":["storageMv","source","dest","spinner","createSpinner","apiPost","logSuccess"],"mappings":"gMAIA,eAAOA,EAAiCC,CAAAA,CAAgBC,CAAAA,CAA6B,CACnF,IAAMC,EAAUC,CAAAA,CAAc,CAAA,OAAA,EAAUH,CAAM,CAAA,QAAA,EAAMC,CAAI,CAAA,GAAA,CAAK,CAAA,CAC7DC,EAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAQ,sBAAA,CAAwB,CAAE,MAAA,CAAAJ,EAAQ,WAAA,CAAaC,CAAK,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC5FC,CAAAA,CAAQ,OAAA,GACRG,CAAAA,CAAW,CAAA,MAAA,EAASL,CAAM,CAAA,QAAA,EAAMC,CAAI,EAAE,EACxC","file":"storage-mv-XQ7EPX3M.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageMv(source: string, dest: string): Promise<void> {\n const spinner = createSpinner(`Moving ${source} → ${dest}...`)\n spinner.start()\n await apiPost('/api/v1/storage/move', { source, destination: dest }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Moved ${source} → ${dest}`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {g}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g as g$1}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';import s from'inquirer';async function c(e,r){if(r?.recursive){let{confirm:a}=await s.prompt([{type:"confirm",name:"confirm",message:`Delete entire folder "${e}" and all contents?`,default:false}]);if(!a)return}let t=b(`Deleting ${e}...`);t.start(),await g(`/api/v1/storage/rm?path=${encodeURIComponent(e)}&recursive=${r?.recursive||false}`,{authenticated:true}),t.succeed(),g$1(`Deleted ${e}`);}export{c as default};//# sourceMappingURL=storage-rm-LYO6UR3G.js.map
2
+ //# sourceMappingURL=storage-rm-LYO6UR3G.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-rm.ts"],"names":["storageRm","path","options","confirm","inquirer","spinner","createSpinner","apiDelete","logSuccess"],"mappings":"2PAKA,eAAOA,CAAAA,CAAiCC,EAAcC,CAAAA,CAAkD,CACtG,GAAIA,CAAAA,EAAS,UAAW,CACtB,GAAM,CAAE,OAAA,CAAAC,CAAQ,CAAA,CAAI,MAAMC,CAAAA,CAAS,MAAA,CAAO,CAAC,CACzC,IAAA,CAAM,SAAA,CACN,KAAM,SAAA,CACN,OAAA,CAAS,CAAA,sBAAA,EAAyBH,CAAI,sBACtC,OAAA,CAAS,KACX,CAAC,CAAC,EACF,GAAI,CAACE,CAAAA,CAAS,MAChB,CACA,IAAME,CAAAA,CAAUC,CAAAA,CAAc,YAAYL,CAAI,CAAA,GAAA,CAAK,CAAA,CACnDI,CAAAA,CAAQ,OAAM,CACd,MAAME,CAAAA,CAAU,CAAA,wBAAA,EAA2B,mBAAmBN,CAAI,CAAC,CAAA,WAAA,EAAcC,CAAAA,EAAS,SAAA,EAAa,KAAK,CAAA,CAAA,CAAI,CAAE,cAAe,IAAK,CAAC,CAAA,CACvIG,CAAAA,CAAQ,SAAQ,CAChBG,GAAAA,CAAW,CAAA,QAAA,EAAWP,CAAI,EAAE,EAC9B","file":"storage-rm-M3UODY5G.js","sourcesContent":["import inquirer from 'inquirer'\nimport { apiDelete } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageRm(path: string, options?: { recursive?: boolean }): Promise<void> {\n if (options?.recursive) {\n const { confirm } = await inquirer.prompt([{\n type: 'confirm',\n name: 'confirm',\n message: `Delete entire folder \"${path}\" and all contents?`,\n default: false,\n }])\n if (!confirm) return\n }\n const spinner = createSpinner(`Deleting ${path}...`)\n spinner.start()\n await apiDelete(`/api/v1/storage/rm?path=${encodeURIComponent(path)}&recursive=${options?.recursive || false}`, { authenticated: true })\n spinner.succeed()\n logSuccess(`Deleted ${path}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-rm.ts"],"names":["storageRm","path","options","confirm","inquirer","spinner","createSpinner","apiDelete","logSuccess"],"mappings":"+NAKA,eAAOA,CAAAA,CAAiCC,EAAcC,CAAAA,CAAkD,CACtG,GAAIA,CAAAA,EAAS,UAAW,CACtB,GAAM,CAAE,OAAA,CAAAC,CAAQ,CAAA,CAAI,MAAMC,CAAAA,CAAS,MAAA,CAAO,CAAC,CACzC,IAAA,CAAM,SAAA,CACN,KAAM,SAAA,CACN,OAAA,CAAS,CAAA,sBAAA,EAAyBH,CAAI,sBACtC,OAAA,CAAS,KACX,CAAC,CAAC,EACF,GAAI,CAACE,CAAAA,CAAS,MAChB,CACA,IAAME,CAAAA,CAAUC,CAAAA,CAAc,YAAYL,CAAI,CAAA,GAAA,CAAK,CAAA,CACnDI,CAAAA,CAAQ,OAAM,CACd,MAAME,CAAAA,CAAU,CAAA,wBAAA,EAA2B,mBAAmBN,CAAI,CAAC,CAAA,WAAA,EAAcC,CAAAA,EAAS,SAAA,EAAa,KAAK,CAAA,CAAA,CAAI,CAAE,cAAe,IAAK,CAAC,CAAA,CACvIG,CAAAA,CAAQ,SAAQ,CAChBG,GAAAA,CAAW,CAAA,QAAA,EAAWP,CAAI,EAAE,EAC9B","file":"storage-rm-LYO6UR3G.js","sourcesContent":["import inquirer from 'inquirer'\nimport { apiDelete } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageRm(path: string, options?: { recursive?: boolean }): Promise<void> {\n if (options?.recursive) {\n const { confirm } = await inquirer.prompt([{\n type: 'confirm',\n name: 'confirm',\n message: `Delete entire folder \"${path}\" and all contents?`,\n default: false,\n }])\n if (!confirm) return\n }\n const spinner = createSpinner(`Deleting ${path}...`)\n spinner.start()\n await apiDelete(`/api/v1/storage/rm?path=${encodeURIComponent(path)}&recursive=${options?.recursive || false}`, { authenticated: true })\n spinner.succeed()\n logSuccess(`Deleted ${path}`)\n}\n"]}
@@ -1,2 +1,2 @@
1
- import {d}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import {a as a$1}from'./chunk-THMWE2I6.js';import {c,a}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import m from'chalk';async function n(r){let s=((await d(`/api/v1/storage/search?q=${encodeURIComponent(r)}`,{authenticated:true})).results||[]).map(e=>({name:e.name,path:m.dim(e.path),type:e.type,size:a(e.size),modified:e.updated_at?c(e.updated_at):""}));console.log(a$1(s,[{key:"name",label:"Name"},{key:"path",label:"Path"},{key:"type",label:"Type"},{key:"size",label:"Size"},{key:"modified",label:"Modified"}]));}export{n as default};//# sourceMappingURL=storage-search-H44Y6OKS.js.map
2
- //# sourceMappingURL=storage-search-H44Y6OKS.js.map
1
+ import {d}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import {a as a$1}from'./chunk-THMWE2I6.js';import {c,a}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';import m from'chalk';async function n(r){let s=((await d(`/api/v1/storage/search?q=${encodeURIComponent(r)}`,{authenticated:true})).results||[]).map(e=>({name:e.name,path:m.dim(e.path),type:e.type,size:a(e.size),modified:e.updated_at?c(e.updated_at):""}));console.log(a$1(s,[{key:"name",label:"Name"},{key:"path",label:"Path"},{key:"type",label:"Type"},{key:"size",label:"Size"},{key:"modified",label:"Modified"}]));}export{n as default};//# sourceMappingURL=storage-search-RIT5ISCA.js.map
2
+ //# sourceMappingURL=storage-search-RIT5ISCA.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-search.ts"],"names":["storageSearch","query","rows","apiGet","r","chalk","formatBytes","formatRelative","renderTable"],"mappings":"8NAaA,eAAOA,EAAqCC,CAAAA,CAA8B,CAExE,IAAMC,CAAAA,CAAAA,CAAAA,CADO,MAAMC,EAAoC,CAAA,yBAAA,EAA4B,kBAAA,CAAmBF,CAAK,CAAC,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACpH,OAAA,EAAW,EAAC,EAAG,GAAA,CAAIG,IAAM,CAC1C,IAAA,CAAMA,EAAE,IAAA,CACR,IAAA,CAAMC,EAAM,GAAA,CAAID,CAAAA,CAAE,IAAI,CAAA,CACtB,IAAA,CAAMA,EAAE,IAAA,CACR,IAAA,CAAME,EAAYF,CAAAA,CAAE,IAAI,EACxB,QAAA,CAAUA,CAAAA,CAAE,UAAA,CAAaG,CAAAA,CAAeH,EAAE,UAAU,CAAA,CAAI,EAC1D,CAAA,CAAE,CAAA,CACF,QAAQ,GAAA,CAAII,GAAAA,CAAYN,EAAM,CAC5B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,UAAA,CAAY,KAAA,CAAO,UAAW,CACvC,CAAC,CAAC,EACJ","file":"storage-search-H44Y6OKS.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatBytes, formatRelative } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface SearchResult {\n name: string\n path: string\n type: string\n size: number\n updated_at: string\n}\n\nexport default async function storageSearch(query: string): Promise<void> {\n const data = await apiGet<{ results: SearchResult[] }>(`/api/v1/storage/search?q=${encodeURIComponent(query)}`, { authenticated: true })\n const rows = (data.results || []).map(r => ({\n name: r.name,\n path: chalk.dim(r.path),\n type: r.type,\n size: formatBytes(r.size),\n modified: r.updated_at ? formatRelative(r.updated_at) : '',\n }))\n console.log(renderTable(rows, [\n { key: 'name', label: 'Name' },\n { key: 'path', label: 'Path' },\n { key: 'type', label: 'Type' },\n { key: 'size', label: 'Size' },\n { key: 'modified', label: 'Modified' },\n ]))\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-search.ts"],"names":["storageSearch","query","rows","apiGet","r","chalk","formatBytes","formatRelative","renderTable"],"mappings":"8NAaA,eAAOA,EAAqCC,CAAAA,CAA8B,CAExE,IAAMC,CAAAA,CAAAA,CAAAA,CADO,MAAMC,EAAoC,CAAA,yBAAA,EAA4B,kBAAA,CAAmBF,CAAK,CAAC,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACpH,OAAA,EAAW,EAAC,EAAG,GAAA,CAAIG,IAAM,CAC1C,IAAA,CAAMA,EAAE,IAAA,CACR,IAAA,CAAMC,EAAM,GAAA,CAAID,CAAAA,CAAE,IAAI,CAAA,CACtB,IAAA,CAAMA,EAAE,IAAA,CACR,IAAA,CAAME,EAAYF,CAAAA,CAAE,IAAI,EACxB,QAAA,CAAUA,CAAAA,CAAE,UAAA,CAAaG,CAAAA,CAAeH,EAAE,UAAU,CAAA,CAAI,EAC1D,CAAA,CAAE,CAAA,CACF,QAAQ,GAAA,CAAII,GAAAA,CAAYN,EAAM,CAC5B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,IAAK,UAAA,CAAY,KAAA,CAAO,UAAW,CACvC,CAAC,CAAC,EACJ","file":"storage-search-RIT5ISCA.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatBytes, formatRelative } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface SearchResult {\n name: string\n path: string\n type: string\n size: number\n updated_at: string\n}\n\nexport default async function storageSearch(query: string): Promise<void> {\n const data = await apiGet<{ results: SearchResult[] }>(`/api/v1/storage/search?q=${encodeURIComponent(query)}`, { authenticated: true })\n const rows = (data.results || []).map(r => ({\n name: r.name,\n path: chalk.dim(r.path),\n type: r.type,\n size: formatBytes(r.size),\n modified: r.updated_at ? formatRelative(r.updated_at) : '',\n }))\n console.log(renderTable(rows, [\n { key: 'name', label: 'Name' },\n { key: 'path', label: 'Path' },\n { key: 'type', label: 'Type' },\n { key: 'size', label: 'Size' },\n { key: 'modified', label: 'Modified' },\n ]))\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {e}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {f,m,g,c as c$1}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';import c from'clipboardy';import l from'chalk';async function u(i,r){let t=b(`Creating share link for ${i}...`);t.start();let e$1=await e("/api/v1/storage/share",{path:i,expires_in:r?.expires,password:r?.password,max_views:r?.views,burn_after_reading:r?.burn},{authenticated:true});t.stop();try{await c.write(e$1.url);}catch{}if(f()){m(e$1);return}g("Share link created!"),console.log(` ${l.hex("#4FC3F7")(e$1.url)} ${c$1("")}`);}export{u as default};//# sourceMappingURL=storage-share-OURRQWZK.js.map
2
+ //# sourceMappingURL=storage-share-OURRQWZK.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-share.ts"],"names":["storageShare","path","options","spinner","createSpinner","result","apiPost","clipboard","isJsonMode","logJSON","logSuccess","chalk","copied"],"mappings":"wRAQA,eAAOA,EAAoCC,CAAAA,CAAcC,CAAAA,CAAkG,CACzJ,IAAMC,EAAUC,CAAAA,CAAc,CAAA,wBAAA,EAA2BH,CAAI,CAAA,GAAA,CAAK,CAAA,CAClEE,EAAQ,KAAA,EAAM,CACd,IAAME,GAAAA,CAAS,MAAMC,CAAAA,CAA2C,uBAAA,CAAyB,CACvF,IAAA,CAAAL,CAAAA,CACA,WAAYC,CAAAA,EAAS,OAAA,CACrB,SAAUA,CAAAA,EAAS,QAAA,CACnB,UAAWA,CAAAA,EAAS,KAAA,CACpB,mBAAoBA,CAAAA,EAAS,IAC/B,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,EAC1BC,CAAAA,CAAQ,IAAA,GAER,GAAI,CACF,MAAMI,CAAAA,CAAU,KAAA,CAAMF,IAAO,GAAG,EAClC,MAAQ,CAER,CAEA,GAAIG,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQJ,GAAM,CAAA,CACd,MACF,CAEAK,CAAAA,CAAW,qBAAqB,EAChC,OAAA,CAAQ,GAAA,CAAI,KAAKC,CAAAA,CAAM,GAAA,CAAI,SAAS,CAAA,CAAEN,GAAAA,CAAO,GAAG,CAAC,CAAA,CAAA,EAAIO,IAAO,EAAE,CAAC,EAAE,EACnE","file":"storage-share-VIJJIHBX.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logJSON } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport clipboard from 'clipboardy'\nimport chalk from 'chalk'\nimport { copied } from '../../lib/output/brand.js'\n\nexport default async function storageShare(path: string, options?: { expires?: string; password?: string; views?: number; burn?: boolean }): Promise<void> {\n const spinner = createSpinner(`Creating share link for ${path}...`)\n spinner.start()\n const result = await apiPost<{ url: string; share_id: string }>('/api/v1/storage/share', {\n path,\n expires_in: options?.expires,\n password: options?.password,\n max_views: options?.views,\n burn_after_reading: options?.burn,\n }, { authenticated: true })\n spinner.stop()\n\n try {\n await clipboard.write(result.url)\n } catch {\n // ignore\n }\n\n if (isJsonMode()) {\n logJSON(result)\n return\n }\n\n logSuccess(`Share link created!`)\n console.log(` ${chalk.hex('#4FC3F7')(result.url)} ${copied('')}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-share.ts"],"names":["storageShare","path","options","spinner","createSpinner","result","apiPost","clipboard","isJsonMode","logJSON","logSuccess","chalk","copied"],"mappings":"4PAQA,eAAOA,EAAoCC,CAAAA,CAAcC,CAAAA,CAAkG,CACzJ,IAAMC,EAAUC,CAAAA,CAAc,CAAA,wBAAA,EAA2BH,CAAI,CAAA,GAAA,CAAK,CAAA,CAClEE,EAAQ,KAAA,EAAM,CACd,IAAME,GAAAA,CAAS,MAAMC,CAAAA,CAA2C,uBAAA,CAAyB,CACvF,IAAA,CAAAL,CAAAA,CACA,WAAYC,CAAAA,EAAS,OAAA,CACrB,SAAUA,CAAAA,EAAS,QAAA,CACnB,UAAWA,CAAAA,EAAS,KAAA,CACpB,mBAAoBA,CAAAA,EAAS,IAC/B,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,EAC1BC,CAAAA,CAAQ,IAAA,GAER,GAAI,CACF,MAAMI,CAAAA,CAAU,KAAA,CAAMF,IAAO,GAAG,EAClC,MAAQ,CAER,CAEA,GAAIG,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQJ,GAAM,CAAA,CACd,MACF,CAEAK,CAAAA,CAAW,qBAAqB,EAChC,OAAA,CAAQ,GAAA,CAAI,KAAKC,CAAAA,CAAM,GAAA,CAAI,SAAS,CAAA,CAAEN,GAAAA,CAAO,GAAG,CAAC,CAAA,CAAA,EAAIO,IAAO,EAAE,CAAC,EAAE,EACnE","file":"storage-share-OURRQWZK.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logJSON } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport clipboard from 'clipboardy'\nimport chalk from 'chalk'\nimport { copied } from '../../lib/output/brand.js'\n\nexport default async function storageShare(path: string, options?: { expires?: string; password?: string; views?: number; burn?: boolean }): Promise<void> {\n const spinner = createSpinner(`Creating share link for ${path}...`)\n spinner.start()\n const result = await apiPost<{ url: string; share_id: string }>('/api/v1/storage/share', {\n path,\n expires_in: options?.expires,\n password: options?.password,\n max_views: options?.views,\n burn_after_reading: options?.burn,\n }, { authenticated: true })\n spinner.stop()\n\n try {\n await clipboard.write(result.url)\n } catch {\n // ignore\n }\n\n if (isJsonMode()) {\n logJSON(result)\n return\n }\n\n logSuccess(`Share link created!`)\n console.log(` ${chalk.hex('#4FC3F7')(result.url)} ${copied('')}`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {e}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g as g$1}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';async function g(a,e$1){if(e$1.add){let r=b(`Adding tag "${e$1.add}" to ${a}...`);r.start(),await e("/api/v1/storage/tags",{path:a,tag:e$1.add,action:"add"},{authenticated:true}),r.succeed(),g$1(`Tag "${e$1.add}" added to ${a}`);}if(e$1.remove){let r=b(`Removing tag "${e$1.remove}" from ${a}...`);r.start(),await e("/api/v1/storage/tags",{path:a,tag:e$1.remove,action:"remove"},{authenticated:true}),r.succeed(),g$1(`Tag "${e$1.remove}" removed from ${a}`);}}export{g as default};//# sourceMappingURL=storage-tag-NGJGUJSZ.js.map
2
+ //# sourceMappingURL=storage-tag-NGJGUJSZ.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-tag.ts"],"names":["storageTag","path","options","spinner","createSpinner","apiPost","logSuccess"],"mappings":"mOAIA,eAAOA,CAAAA,CAAkCC,IAAcC,GAAAA,CAA2D,CAChH,GAAIA,GAAAA,CAAQ,GAAA,CAAK,CACf,IAAMC,CAAAA,CAAUC,EAAc,CAAA,YAAA,EAAeF,GAAAA,CAAQ,GAAG,CAAA,KAAA,EAAQD,GAAI,KAAK,CAAA,CACzEE,CAAAA,CAAQ,OAAM,CACd,MAAME,EAAQ,sBAAA,CAAwB,CAAE,KAAAJ,GAAAA,CAAM,GAAA,CAAKC,IAAQ,GAAA,CAAK,MAAA,CAAQ,KAAM,CAAA,CAAG,CAAE,cAAe,IAAK,CAAC,EACxGC,CAAAA,CAAQ,OAAA,GACRG,GAAAA,CAAW,CAAA,KAAA,EAAQJ,GAAAA,CAAQ,GAAG,CAAA,WAAA,EAAcD,GAAI,EAAE,EACpD,CACA,GAAIC,GAAAA,CAAQ,MAAA,CAAQ,CAClB,IAAMC,CAAAA,CAAUC,EAAc,CAAA,cAAA,EAAiBF,GAAAA,CAAQ,MAAM,CAAA,OAAA,EAAUD,GAAI,KAAK,CAAA,CAChFE,CAAAA,CAAQ,OAAM,CACd,MAAME,CAAAA,CAAQ,sBAAA,CAAwB,CAAE,IAAA,CAAAJ,IAAM,GAAA,CAAKC,GAAAA,CAAQ,OAAQ,MAAA,CAAQ,QAAS,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC9GC,EAAQ,OAAA,EAAQ,CAChBG,IAAW,CAAA,KAAA,EAAQJ,GAAAA,CAAQ,MAAM,CAAA,eAAA,EAAkBD,GAAI,CAAA,CAAE,EAC3D,CACF","file":"storage-tag-PAVT6GBZ.js","sourcesContent":["import { apiPost, apiDelete } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageTag(path: string, options: { add?: string; remove?: string }): Promise<void> {\n if (options.add) {\n const spinner = createSpinner(`Adding tag \"${options.add}\" to ${path}...`)\n spinner.start()\n await apiPost('/api/v1/storage/tags', { path, tag: options.add, action: 'add' }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Tag \"${options.add}\" added to ${path}`)\n }\n if (options.remove) {\n const spinner = createSpinner(`Removing tag \"${options.remove}\" from ${path}...`)\n spinner.start()\n await apiPost('/api/v1/storage/tags', { path, tag: options.remove, action: 'remove' }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Tag \"${options.remove}\" removed from ${path}`)\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-tag.ts"],"names":["storageTag","path","options","spinner","createSpinner","apiPost","logSuccess"],"mappings":"uMAIA,eAAOA,CAAAA,CAAkCC,EAAcC,GAAAA,CAA2D,CAChH,GAAIA,GAAAA,CAAQ,GAAA,CAAK,CACf,IAAMC,CAAAA,CAAUC,EAAc,CAAA,YAAA,EAAeF,GAAAA,CAAQ,GAAG,CAAA,KAAA,EAAQD,CAAI,KAAK,CAAA,CACzEE,CAAAA,CAAQ,OAAM,CACd,MAAME,EAAQ,sBAAA,CAAwB,CAAE,KAAAJ,CAAAA,CAAM,GAAA,CAAKC,IAAQ,GAAA,CAAK,MAAA,CAAQ,KAAM,CAAA,CAAG,CAAE,cAAe,IAAK,CAAC,EACxGC,CAAAA,CAAQ,OAAA,GACRG,GAAAA,CAAW,CAAA,KAAA,EAAQJ,GAAAA,CAAQ,GAAG,CAAA,WAAA,EAAcD,CAAI,EAAE,EACpD,CACA,GAAIC,GAAAA,CAAQ,MAAA,CAAQ,CAClB,IAAMC,CAAAA,CAAUC,EAAc,CAAA,cAAA,EAAiBF,GAAAA,CAAQ,MAAM,CAAA,OAAA,EAAUD,CAAI,KAAK,CAAA,CAChFE,CAAAA,CAAQ,OAAM,CACd,MAAME,CAAAA,CAAQ,sBAAA,CAAwB,CAAE,IAAA,CAAAJ,EAAM,GAAA,CAAKC,GAAAA,CAAQ,OAAQ,MAAA,CAAQ,QAAS,EAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC9GC,EAAQ,OAAA,EAAQ,CAChBG,IAAW,CAAA,KAAA,EAAQJ,GAAAA,CAAQ,MAAM,CAAA,eAAA,EAAkBD,CAAI,CAAA,CAAE,EAC3D,CACF","file":"storage-tag-NGJGUJSZ.js","sourcesContent":["import { apiPost, apiDelete } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageTag(path: string, options: { add?: string; remove?: string }): Promise<void> {\n if (options.add) {\n const spinner = createSpinner(`Adding tag \"${options.add}\" to ${path}...`)\n spinner.start()\n await apiPost('/api/v1/storage/tags', { path, tag: options.add, action: 'add' }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Tag \"${options.add}\" added to ${path}`)\n }\n if (options.remove) {\n const spinner = createSpinner(`Removing tag \"${options.remove}\" from ${path}...`)\n spinner.start()\n await apiPost('/api/v1/storage/tags', { path, tag: options.remove, action: 'remove' }, { authenticated: true })\n spinner.succeed()\n logSuccess(`Tag \"${options.remove}\" removed from ${path}`)\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {g}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g as g$1}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';async function s(e){let r=b(`Revoking share links for ${e}...`);r.start(),await g(`/api/v1/storage/share?path=${encodeURIComponent(e)}`,{authenticated:true}),r.succeed(),g$1(`All share links revoked for ${e}`);}export{s as default};//# sourceMappingURL=storage-unshare-3DXEKHEH.js.map
2
+ //# sourceMappingURL=storage-unshare-3DXEKHEH.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-unshare.ts"],"names":["storageUnshare","path","spinner","createSpinner","apiDelete","logSuccess"],"mappings":"mOAIA,eAAOA,CAAAA,CAAsCC,CAAAA,CAA6B,CACxE,IAAMC,EAAUC,CAAAA,CAAc,CAAA,yBAAA,EAA4BF,CAAI,CAAA,GAAA,CAAK,CAAA,CACnEC,CAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAU,CAAA,2BAAA,EAA8B,kBAAA,CAAmBH,CAAI,CAAC,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACjGC,CAAAA,CAAQ,OAAA,EAAQ,CAChBG,GAAAA,CAAW,CAAA,4BAAA,EAA+BJ,CAAI,EAAE,EAClD","file":"storage-unshare-O3AAJZMT.js","sourcesContent":["import { apiDelete } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageUnshare(path: string): Promise<void> {\n const spinner = createSpinner(`Revoking share links for ${path}...`)\n spinner.start()\n await apiDelete(`/api/v1/storage/share?path=${encodeURIComponent(path)}`, { authenticated: true })\n spinner.succeed()\n logSuccess(`All share links revoked for ${path}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-unshare.ts"],"names":["storageUnshare","path","spinner","createSpinner","apiDelete","logSuccess"],"mappings":"uMAIA,eAAOA,CAAAA,CAAsCC,CAAAA,CAA6B,CACxE,IAAMC,EAAUC,CAAAA,CAAc,CAAA,yBAAA,EAA4BF,CAAI,CAAA,GAAA,CAAK,CAAA,CACnEC,CAAAA,CAAQ,KAAA,EAAM,CACd,MAAME,CAAAA,CAAU,CAAA,2BAAA,EAA8B,kBAAA,CAAmBH,CAAI,CAAC,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CACjGC,CAAAA,CAAQ,OAAA,EAAQ,CAChBG,GAAAA,CAAW,CAAA,4BAAA,EAA+BJ,CAAI,EAAE,EAClD","file":"storage-unshare-3DXEKHEH.js","sourcesContent":["import { apiDelete } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function storageUnshare(path: string): Promise<void> {\n const spinner = createSpinner(`Revoking share links for ${path}...`)\n spinner.start()\n await apiDelete(`/api/v1/storage/share?path=${encodeURIComponent(path)}`, { authenticated: true })\n spinner.succeed()\n logSuccess(`All share links revoked for ${path}`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {a as a$1}from'./chunk-MKRWNV2T.js';import {b}from'./chunk-FYFPDKJM.js';import {h}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {a}from'./chunk-G4JU7IUC.js';import {j,f,m,g,i}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';import s from'fs';import n from'path';import F from'chalk';import B from'cli-progress';import I from'ignore';async function N(C,P,l){let e=n.resolve(C),c=P||n.basename(e);s.existsSync(e)||(console.error(`File not found: ${e}`),process.exit(1));let v=s.statSync(e);if(v.isFile()){if(l?.dryRun){j(`[DRY-RUN] Would upload: ${e} \u2192 ${c}`);return}let t=b(`Uploading ${n.basename(e)}...`);t.start();let o=s.readFileSync(e),a$1=new FormData,i=new Blob([o]);a$1.append("file",i,n.basename(e));let f$1=await h(`/api/v1/storage/upload?path=${encodeURIComponent(c)}`,a$1,{authenticated:true});t.succeed(),f()?m(f$1):g(`Uploaded ${n.basename(e)} (${a(o.length)})`);return}if(v.isDirectory()){let a=function(r,d){let m=s.readdirSync(r,{withFileTypes:true});for(let p of m){let u=n.join(r,p.name),S=n.relative(d,u);t.ignores(S)||(p.isDirectory()?a(u,d):p.isFile()&&a$1(p.name)&&o.push({relative:S,absolute:u}));}};let t=I();l?.ignore&&t.add(l.ignore),t.add(".DS_Store"),t.add("node_modules"),t.add(".git");let o=[];if(a(e,e),o.length===0){i("No allowed files found to upload");return}if(l?.dryRun){j(`[DRY-RUN] Would upload ${o.length} files:`);for(let r of o)console.log(F.dim(` ${r.relative}`));return}let i$1=new B.SingleBar({format:`${F.hex("#7C4DFF")("\u25B8")} Uploading |${F.hex("#7C4DFF")("{bar}")}| {percentage}% | {value}/{total} files`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:true});i$1.start(o.length,0);let f$1=new FormData;for(let r of o){let d=s.readFileSync(r.absolute),m=new Blob([d]);f$1.append("files",m,r.relative);}let x=await h(`/api/v1/storage/upload?path=${encodeURIComponent(c)}`,f$1,{authenticated:true});i$1.update(o.length),i$1.stop(),f()?m(x):g(`Uploaded ${o.length} files to ${c}`);}}export{N as default};//# sourceMappingURL=storage-upload-5M6PBHOC.js.map
2
+ //# sourceMappingURL=storage-upload-5M6PBHOC.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/storage/storage-upload.ts"],"names":["storageUpload","local","remote","options","localPath","path","remotePath","fs","stat","logInfo","spinner","createSpinner","content","formData","blob","result","apiUpload","isJsonMode","logJSON","logSuccess","formatBytes","walk","dir","baseDir","entries","entry","fullPath","relative","ig","isAllowedFile","files","ignore","logWarn","f","chalk","progressBar","cliProgress"],"mappings":"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","file":"storage-upload-DRYGLH2O.js","sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\nimport { apiPost, apiUpload } from '../../lib/api/client.js'\nimport { isAllowedFile } from '../../lib/deploy/allowlist.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logWarn, logJSON, logInfo } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport { formatBytes } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\nimport cliProgress from 'cli-progress'\nimport ignore from 'ignore'\n\nexport default async function storageUpload(local: string, remote?: string, options?: { ignore?: string; dryRun?: boolean }): Promise<void> {\n const localPath = path.resolve(local)\n const remotePath = remote || path.basename(localPath)\n\n if (!fs.existsSync(localPath)) {\n console.error(`File not found: ${localPath}`)\n process.exit(1)\n }\n\n const stat = fs.statSync(localPath)\n\n if (stat.isFile()) {\n if (options?.dryRun) {\n logInfo(`[DRY-RUN] Would upload: ${localPath} → ${remotePath}`)\n return\n }\n const spinner = createSpinner(`Uploading ${path.basename(localPath)}...`)\n spinner.start()\n const content = fs.readFileSync(localPath)\n const formData = new FormData()\n const blob = new Blob([content])\n formData.append('file', blob, path.basename(localPath))\n const result = await apiUpload(`/api/v1/storage/upload?path=${encodeURIComponent(remotePath)}`, formData, { authenticated: true })\n spinner.succeed()\n if (isJsonMode()) logJSON(result)\n else logSuccess(`Uploaded ${path.basename(localPath)} (${formatBytes(content.length)})`)\n return\n }\n\n if (stat.isDirectory()) {\n const ig = ignore()\n if (options?.ignore) {\n ig.add(options.ignore)\n }\n ig.add('.DS_Store')\n ig.add('node_modules')\n ig.add('.git')\n\n const files: { relative: string; absolute: string }[] = []\n function walk(dir: string, baseDir: string): void {\n const entries = fs.readdirSync(dir, { withFileTypes: true })\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name)\n const relative = path.relative(baseDir, fullPath)\n if (ig.ignores(relative)) continue\n if (entry.isDirectory()) {\n walk(fullPath, baseDir)\n } else if (entry.isFile() && isAllowedFile(entry.name)) {\n files.push({ relative, absolute: fullPath })\n }\n }\n }\n walk(localPath, localPath)\n\n if (files.length === 0) {\n logWarn('No allowed files found to upload')\n return\n }\n\n if (options?.dryRun) {\n logInfo(`[DRY-RUN] Would upload ${files.length} files:`)\n for (const f of files) {\n console.log(chalk.dim(` ${f.relative}`))\n }\n return\n }\n\n const progressBar = new cliProgress.SingleBar({\n format: `${chalk.hex('#7C4DFF')('▸')} Uploading |${chalk.hex('#7C4DFF')('{bar}')}| {percentage}% | {value}/{total} files`,\n barCompleteChar: '█',\n barIncompleteChar: '░',\n hideCursor: true,\n })\n progressBar.start(files.length, 0)\n\n const formData = new FormData()\n for (const f of files) {\n const content = fs.readFileSync(f.absolute)\n const blob = new Blob([content])\n formData.append('files', blob, f.relative)\n }\n\n const result = await apiUpload(`/api/v1/storage/upload?path=${encodeURIComponent(remotePath)}`, formData, { authenticated: true })\n progressBar.update(files.length)\n progressBar.stop()\n\n if (isJsonMode()) logJSON(result)\n else logSuccess(`Uploaded ${files.length} files to ${remotePath}`)\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/storage/storage-upload.ts"],"names":["storageUpload","local","remote","options","localPath","path","remotePath","fs","stat","logInfo","spinner","createSpinner","content","formData","blob","result","apiUpload","isJsonMode","logJSON","logSuccess","formatBytes","walk","dir","baseDir","entries","entry","fullPath","relative","ig","isAllowedFile","files","ignore","logWarn","f","chalk","progressBar","cliProgress"],"mappings":"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","file":"storage-upload-5M6PBHOC.js","sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\nimport { apiPost, apiUpload } from '../../lib/api/client.js'\nimport { isAllowedFile } from '../../lib/deploy/allowlist.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logWarn, logJSON, logInfo } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport { formatBytes } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\nimport cliProgress from 'cli-progress'\nimport ignore from 'ignore'\n\nexport default async function storageUpload(local: string, remote?: string, options?: { ignore?: string; dryRun?: boolean }): Promise<void> {\n const localPath = path.resolve(local)\n const remotePath = remote || path.basename(localPath)\n\n if (!fs.existsSync(localPath)) {\n console.error(`File not found: ${localPath}`)\n process.exit(1)\n }\n\n const stat = fs.statSync(localPath)\n\n if (stat.isFile()) {\n if (options?.dryRun) {\n logInfo(`[DRY-RUN] Would upload: ${localPath} → ${remotePath}`)\n return\n }\n const spinner = createSpinner(`Uploading ${path.basename(localPath)}...`)\n spinner.start()\n const content = fs.readFileSync(localPath)\n const formData = new FormData()\n const blob = new Blob([content])\n formData.append('file', blob, path.basename(localPath))\n const result = await apiUpload(`/api/v1/storage/upload?path=${encodeURIComponent(remotePath)}`, formData, { authenticated: true })\n spinner.succeed()\n if (isJsonMode()) logJSON(result)\n else logSuccess(`Uploaded ${path.basename(localPath)} (${formatBytes(content.length)})`)\n return\n }\n\n if (stat.isDirectory()) {\n const ig = ignore()\n if (options?.ignore) {\n ig.add(options.ignore)\n }\n ig.add('.DS_Store')\n ig.add('node_modules')\n ig.add('.git')\n\n const files: { relative: string; absolute: string }[] = []\n function walk(dir: string, baseDir: string): void {\n const entries = fs.readdirSync(dir, { withFileTypes: true })\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name)\n const relative = path.relative(baseDir, fullPath)\n if (ig.ignores(relative)) continue\n if (entry.isDirectory()) {\n walk(fullPath, baseDir)\n } else if (entry.isFile() && isAllowedFile(entry.name)) {\n files.push({ relative, absolute: fullPath })\n }\n }\n }\n walk(localPath, localPath)\n\n if (files.length === 0) {\n logWarn('No allowed files found to upload')\n return\n }\n\n if (options?.dryRun) {\n logInfo(`[DRY-RUN] Would upload ${files.length} files:`)\n for (const f of files) {\n console.log(chalk.dim(` ${f.relative}`))\n }\n return\n }\n\n const progressBar = new cliProgress.SingleBar({\n format: `${chalk.hex('#7C4DFF')('▸')} Uploading |${chalk.hex('#7C4DFF')('{bar}')}| {percentage}% | {value}/{total} files`,\n barCompleteChar: '█',\n barIncompleteChar: '░',\n hideCursor: true,\n })\n progressBar.start(files.length, 0)\n\n const formData = new FormData()\n for (const f of files) {\n const content = fs.readFileSync(f.absolute)\n const blob = new Blob([content])\n formData.append('files', blob, f.relative)\n }\n\n const result = await apiUpload(`/api/v1/storage/upload?path=${encodeURIComponent(remotePath)}`, formData, { authenticated: true })\n progressBar.update(files.length)\n progressBar.stop()\n\n if (isJsonMode()) logJSON(result)\n else logSuccess(`Uploaded ${files.length} files to ${remotePath}`)\n }\n}\n"]}
@@ -1,2 +1,2 @@
1
- import {d}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import {a}from'./chunk-THMWE2I6.js';import {d as d$1,b}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import m from'chalk';async function r(){let o=((await d("/api/v1/time/list",{authenticated:true})).locked||[]).map(e=>({path:e.path,unlocks:b(e.unlock_at),remaining:e.time_remaining_ms>0?d$1(e.time_remaining_ms):m.green("unlocked")}));console.log(a(o,[{key:"path",label:"File"},{key:"unlocks",label:"Unlocks"},{key:"remaining",label:"Time Remaining"}]));}export{r as default};//# sourceMappingURL=time-list-CW2OOCPT.js.map
2
- //# sourceMappingURL=time-list-CW2OOCPT.js.map
1
+ import {d}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import {a}from'./chunk-THMWE2I6.js';import {d as d$1,b}from'./chunk-G4JU7IUC.js';import'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';import m from'chalk';async function r(){let o=((await d("/api/v1/time/list",{authenticated:true})).locked||[]).map(e=>({path:e.path,unlocks:b(e.unlock_at),remaining:e.time_remaining_ms>0?d$1(e.time_remaining_ms):m.green("unlocked")}));console.log(a(o,[{key:"path",label:"File"},{key:"unlocks",label:"Unlocks"},{key:"remaining",label:"Time Remaining"}]));}export{r as default};//# sourceMappingURL=time-list-GMZYZAOU.js.map
2
+ //# sourceMappingURL=time-list-GMZYZAOU.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/time/time-list.ts"],"names":["timeList","rows","apiGet","l","formatDate","formatCountdown","chalk","renderTable"],"mappings":"8NAWA,eAAOA,CAAAA,EAAiD,CAEtD,IAAMC,CAAAA,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAAiC,mBAAA,CAAqB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EAC7E,MAAA,EAAU,EAAC,EAAG,GAAA,CAAIC,CAAAA,GAAM,CACzC,IAAA,CAAMA,EAAE,IAAA,CACR,OAAA,CAASC,CAAAA,CAAWD,CAAAA,CAAE,SAAS,CAAA,CAC/B,SAAA,CAAWA,CAAAA,CAAE,kBAAoB,CAAA,CAAIE,GAAAA,CAAgBF,CAAAA,CAAE,iBAAiB,CAAA,CAAIG,CAAAA,CAAM,KAAA,CAAM,UAAU,CACpG,CAAA,CAAE,CAAA,CACF,OAAA,CAAQ,GAAA,CAAIC,CAAAA,CAAYN,CAAAA,CAAM,CAC5B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,SAAA,CAAW,KAAA,CAAO,SAAU,CAAA,CACnC,CAAE,GAAA,CAAK,WAAA,CAAa,KAAA,CAAO,gBAAiB,CAC9C,CAAC,CAAC,EACJ","file":"time-list-CW2OOCPT.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatDate, formatCountdown } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface LockedFile {\n path: string\n unlock_at: string\n time_remaining_ms: number\n}\n\nexport default async function timeList(): Promise<void> {\n const data = await apiGet<{ locked: LockedFile[] }>('/api/v1/time/list', { authenticated: true })\n const rows = (data.locked || []).map(l => ({\n path: l.path,\n unlocks: formatDate(l.unlock_at),\n remaining: l.time_remaining_ms > 0 ? formatCountdown(l.time_remaining_ms) : chalk.green('unlocked'),\n }))\n console.log(renderTable(rows, [\n { key: 'path', label: 'File' },\n { key: 'unlocks', label: 'Unlocks' },\n { key: 'remaining', label: 'Time Remaining' },\n ]))\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/time/time-list.ts"],"names":["timeList","rows","apiGet","l","formatDate","formatCountdown","chalk","renderTable"],"mappings":"8NAWA,eAAOA,CAAAA,EAAiD,CAEtD,IAAMC,CAAAA,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAAiC,mBAAA,CAAqB,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EAC7E,MAAA,EAAU,EAAC,EAAG,GAAA,CAAIC,CAAAA,GAAM,CACzC,IAAA,CAAMA,EAAE,IAAA,CACR,OAAA,CAASC,CAAAA,CAAWD,CAAAA,CAAE,SAAS,CAAA,CAC/B,SAAA,CAAWA,CAAAA,CAAE,kBAAoB,CAAA,CAAIE,GAAAA,CAAgBF,CAAAA,CAAE,iBAAiB,CAAA,CAAIG,CAAAA,CAAM,KAAA,CAAM,UAAU,CACpG,CAAA,CAAE,CAAA,CACF,OAAA,CAAQ,GAAA,CAAIC,CAAAA,CAAYN,CAAAA,CAAM,CAC5B,CAAE,IAAK,MAAA,CAAQ,KAAA,CAAO,MAAO,CAAA,CAC7B,CAAE,GAAA,CAAK,SAAA,CAAW,KAAA,CAAO,SAAU,CAAA,CACnC,CAAE,GAAA,CAAK,WAAA,CAAa,KAAA,CAAO,gBAAiB,CAC9C,CAAC,CAAC,EACJ","file":"time-list-GMZYZAOU.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { renderTable } from '../../lib/output/table.js'\nimport { formatDate, formatCountdown } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface LockedFile {\n path: string\n unlock_at: string\n time_remaining_ms: number\n}\n\nexport default async function timeList(): Promise<void> {\n const data = await apiGet<{ locked: LockedFile[] }>('/api/v1/time/list', { authenticated: true })\n const rows = (data.locked || []).map(l => ({\n path: l.path,\n unlocks: formatDate(l.unlock_at),\n remaining: l.time_remaining_ms > 0 ? formatCountdown(l.time_remaining_ms) : chalk.green('unlocked'),\n }))\n console.log(renderTable(rows, [\n { key: 'path', label: 'File' },\n { key: 'unlocks', label: 'Unlocks' },\n { key: 'remaining', label: 'Time Remaining' },\n ]))\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {e}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {f,m,g}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';async function s(i,t){let n=b(`Time-locking ${i} until ${t.until}...`);n.start();let u=await e("/api/v1/time/lock",{path:i,unlock_at:t.until},{authenticated:true});if(n.succeed(),f()){m(u);return}g(`Time-locked until ${t.until}`);}export{s as default};//# sourceMappingURL=time-lock-2OLEVQPJ.js.map
2
+ //# sourceMappingURL=time-lock-2OLEVQPJ.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/time/time-lock.ts"],"names":["timeLock","path","options","spinner","createSpinner","result","apiPost","isJsonMode","logJSON","logSuccess"],"mappings":"gOAKA,eAAOA,CAAAA,CAAgCC,EAAcC,CAAAA,CAA2C,CAC9F,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,CAAA,aAAA,EAAgBH,CAAI,CAAA,OAAA,EAAUC,CAAAA,CAAQ,KAAK,CAAA,GAAA,CAAK,CAAA,CAC9EC,CAAAA,CAAQ,KAAA,EAAM,CACd,IAAME,EAAS,MAAMC,CAAAA,CAAgD,mBAAA,CAAqB,CACxF,IAAA,CAAAL,CAAAA,CACA,UAAWC,CAAAA,CAAQ,KACrB,CAAA,CAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAE1B,GADAC,CAAAA,CAAQ,OAAA,EAAQ,CACZI,CAAAA,GAAc,CAChBC,CAAAA,CAAQH,CAAM,CAAA,CACd,MACF,CACAI,EAAW,CAAA,kBAAA,EAAqBP,CAAAA,CAAQ,KAAK,CAAA,CAAE,EACjD","file":"time-lock-A2MZ3MP2.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logJSON } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\n\nexport default async function timeLock(path: string, options: { until: string }): Promise<void> {\n const spinner = createSpinner(`Time-locking ${path} until ${options.until}...`)\n spinner.start()\n const result = await apiPost<{ lock_id: string; unlock_at: string }>('/api/v1/time/lock', {\n path,\n unlock_at: options.until,\n }, { authenticated: true })\n spinner.succeed()\n if (isJsonMode()) {\n logJSON(result)\n return\n }\n logSuccess(`Time-locked until ${options.until}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/time/time-lock.ts"],"names":["timeLock","path","options","spinner","createSpinner","result","apiPost","isJsonMode","logJSON","logSuccess"],"mappings":"oMAKA,eAAOA,CAAAA,CAAgCC,EAAcC,CAAAA,CAA2C,CAC9F,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,CAAA,aAAA,EAAgBH,CAAI,CAAA,OAAA,EAAUC,CAAAA,CAAQ,KAAK,CAAA,GAAA,CAAK,CAAA,CAC9EC,CAAAA,CAAQ,KAAA,EAAM,CACd,IAAME,EAAS,MAAMC,CAAAA,CAAgD,mBAAA,CAAqB,CACxF,IAAA,CAAAL,CAAAA,CACA,UAAWC,CAAAA,CAAQ,KACrB,CAAA,CAAG,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAE1B,GADAC,CAAAA,CAAQ,OAAA,EAAQ,CACZI,CAAAA,GAAc,CAChBC,CAAAA,CAAQH,CAAM,CAAA,CACd,MACF,CACAI,EAAW,CAAA,kBAAA,EAAqBP,CAAAA,CAAQ,KAAK,CAAA,CAAE,EACjD","file":"time-lock-2OLEVQPJ.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logJSON } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\n\nexport default async function timeLock(path: string, options: { until: string }): Promise<void> {\n const spinner = createSpinner(`Time-locking ${path} until ${options.until}...`)\n spinner.start()\n const result = await apiPost<{ lock_id: string; unlock_at: string }>('/api/v1/time/lock', {\n path,\n unlock_at: options.until,\n }, { authenticated: true })\n spinner.succeed()\n if (isJsonMode()) {\n logJSON(result)\n return\n }\n logSuccess(`Time-locked until ${options.until}`)\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {d}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';import s from'fs';import p from'path';async function f(o){let t=b("Generating proof...");t.start();let a=await d(`/api/v1/time/proof?path=${encodeURIComponent(o)}`,{authenticated:true});t.succeed();let e=p.join(process.cwd(),`${p.basename(o)}.timeproof.json`);s.writeFileSync(e,JSON.stringify({proof:a.proof,generated_at:new Date().toISOString()},null,2)),g(`Existence proof saved to ${e}`);}export{f as default};//# sourceMappingURL=time-proof-RUTDAEKP.js.map
2
+ //# sourceMappingURL=time-proof-RUTDAEKP.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/time/time-proof.ts"],"names":["timeProof","filePath","spinner","createSpinner","data","apiGet","proofPath","path","fs","logSuccess"],"mappings":"kQAMA,eAAOA,CAAAA,CAAiCC,CAAAA,CAAiC,CACvE,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,qBAAqB,CAAA,CACnDD,EAAQ,KAAA,EAAM,CACd,IAAME,GAAAA,CAAO,MAAMC,CAAAA,CAA0B,CAAA,wBAAA,EAA2B,kBAAA,CAAmBJ,CAAQ,CAAC,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC/HC,CAAAA,CAAQ,OAAA,GACR,IAAMI,CAAAA,CAAYC,CAAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,GAAA,EAAI,CAAG,CAAA,EAAGA,EAAK,QAAA,CAASN,CAAQ,CAAC,CAAA,eAAA,CAAiB,EACtFO,CAAAA,CAAG,aAAA,CAAcF,CAAAA,CAAW,IAAA,CAAK,UAAU,CAAE,KAAA,CAAOF,GAAAA,CAAK,KAAA,CAAO,YAAA,CAAc,IAAI,IAAA,EAAK,CAAE,aAAc,CAAA,CAAG,IAAA,CAAM,CAAC,CAAC,CAAA,CAClHK,CAAAA,CAAW,CAAA,yBAAA,EAA4BH,CAAS,EAAE,EACpD","file":"time-proof-ZLRY6ZVZ.js","sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\nimport { apiGet } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function timeProof(filePath: string): Promise<void> {\n const spinner = createSpinner('Generating proof...')\n spinner.start()\n const data = await apiGet<{ proof: string }>(`/api/v1/time/proof?path=${encodeURIComponent(filePath)}`, { authenticated: true })\n spinner.succeed()\n const proofPath = path.join(process.cwd(), `${path.basename(filePath)}.timeproof.json`)\n fs.writeFileSync(proofPath, JSON.stringify({ proof: data.proof, generated_at: new Date().toISOString() }, null, 2))\n logSuccess(`Existence proof saved to ${proofPath}`)\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/time/time-proof.ts"],"names":["timeProof","filePath","spinner","createSpinner","data","apiGet","proofPath","path","fs","logSuccess"],"mappings":"sOAMA,eAAOA,CAAAA,CAAiCC,CAAAA,CAAiC,CACvE,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,qBAAqB,CAAA,CACnDD,EAAQ,KAAA,EAAM,CACd,IAAME,CAAAA,CAAO,MAAMC,CAAAA,CAA0B,CAAA,wBAAA,EAA2B,kBAAA,CAAmBJ,CAAQ,CAAC,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,CAC/HC,CAAAA,CAAQ,OAAA,GACR,IAAMI,CAAAA,CAAYC,CAAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,GAAA,EAAI,CAAG,CAAA,EAAGA,EAAK,QAAA,CAASN,CAAQ,CAAC,CAAA,eAAA,CAAiB,EACtFO,CAAAA,CAAG,aAAA,CAAcF,CAAAA,CAAW,IAAA,CAAK,UAAU,CAAE,KAAA,CAAOF,CAAAA,CAAK,KAAA,CAAO,YAAA,CAAc,IAAI,IAAA,EAAK,CAAE,aAAc,CAAA,CAAG,IAAA,CAAM,CAAC,CAAC,CAAA,CAClHK,CAAAA,CAAW,CAAA,yBAAA,EAA4BH,CAAS,EAAE,EACpD","file":"time-proof-RUTDAEKP.js","sourcesContent":["import fs from 'node:fs'\nimport path from 'node:path'\nimport { apiGet } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess } from '../../lib/output/logger.js'\n\nexport default async function timeProof(filePath: string): Promise<void> {\n const spinner = createSpinner('Generating proof...')\n spinner.start()\n const data = await apiGet<{ proof: string }>(`/api/v1/time/proof?path=${encodeURIComponent(filePath)}`, { authenticated: true })\n spinner.succeed()\n const proofPath = path.join(process.cwd(), `${path.basename(filePath)}.timeproof.json`)\n fs.writeFileSync(proofPath, JSON.stringify({ proof: data.proof, generated_at: new Date().toISOString() }, null, 2))\n logSuccess(`Existence proof saved to ${proofPath}`)\n}\n"]}
@@ -1,2 +1,2 @@
1
- import {d}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import {d as d$1}from'./chunk-G4JU7IUC.js';import {f,m,l}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import t from'chalk';async function s(e){let i=(await d(`/api/v1/time/status?path=${encodeURIComponent(e)}`,{authenticated:true})).status;if(f()){m(i);return}l(""),l(` ${t.bold(e)}`),l(t.dim(" \u2500\u2500\u2500".repeat(8))),l(` ${t.bold("Locked:")} ${i.locked?t.yellow("yes"):t.green("no")}`),i.unlock_at&&l(` ${t.bold("Unlocks:")} ${i.unlock_at}`),i.time_remaining_ms!==null&&i.time_remaining_ms>0&&l(` ${t.bold("Remaining:")} ${d$1(i.time_remaining_ms)}`),l(` ${t.bold("Proof:")} ${t.dim(i.proof_hash?.slice(0,16)||"-")}`),l("");}export{s as default};//# sourceMappingURL=time-status-XQLRCYF6.js.map
2
- //# sourceMappingURL=time-status-XQLRCYF6.js.map
1
+ import {d}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import {d as d$1}from'./chunk-G4JU7IUC.js';import {f,m,l}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';import t from'chalk';async function s(e){let i=(await d(`/api/v1/time/status?path=${encodeURIComponent(e)}`,{authenticated:true})).status;if(f()){m(i);return}l(""),l(` ${t.bold(e)}`),l(t.dim(" \u2500\u2500\u2500".repeat(8))),l(` ${t.bold("Locked:")} ${i.locked?t.yellow("yes"):t.green("no")}`),i.unlock_at&&l(` ${t.bold("Unlocks:")} ${i.unlock_at}`),i.time_remaining_ms!==null&&i.time_remaining_ms>0&&l(` ${t.bold("Remaining:")} ${d$1(i.time_remaining_ms)}`),l(` ${t.bold("Proof:")} ${t.dim(i.proof_hash?.slice(0,16)||"-")}`),l("");}export{s as default};//# sourceMappingURL=time-status-TVNJBFKC.js.map
2
+ //# sourceMappingURL=time-status-TVNJBFKC.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/time/time-status.ts"],"names":["timeStatus","path","s","apiGet","isJsonMode","logJSON","logRaw","chalk","formatCountdown"],"mappings":"oMAaA,eAAOA,CAAAA,CAAkCC,CAAAA,CAA6B,CAEpE,IAAMC,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAAmC,CAAA,yBAAA,EAA4B,kBAAA,CAAmBF,CAAI,CAAC,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACtH,MAAA,CAEf,GAAIG,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQH,CAAC,CAAA,CACT,MACF,CAEAI,CAAAA,CAAO,EAAE,CAAA,CACTA,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAKN,CAAI,CAAC,CAAA,CAAE,CAAA,CAC9BK,CAAAA,CAAOC,CAAAA,CAAM,GAAA,CAAI,sBAAA,CAAQ,MAAA,CAAO,CAAC,CAAC,CAAC,CAAA,CACnCD,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,SAAS,CAAC,CAAA,EAAA,EAAKL,CAAAA,CAAE,MAAA,CAASK,CAAAA,CAAM,MAAA,CAAO,KAAK,CAAA,CAAIA,CAAAA,CAAM,KAAA,CAAM,IAAI,CAAC,CAAA,CAAE,CAAA,CACtFL,CAAAA,CAAE,SAAA,EACJI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,UAAU,CAAC,CAAA,CAAA,EAAIL,CAAAA,CAAE,SAAS,CAAA,CAAE,CAAA,CAEjDA,CAAAA,CAAE,iBAAA,GAAsB,IAAA,EAAQA,CAAAA,CAAE,iBAAA,CAAoB,CAAA,EACxDI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,YAAY,CAAC,CAAA,CAAA,EAAIC,GAAAA,CAAgBN,CAAAA,CAAE,iBAAiB,CAAC,CAAA,CAAE,CAAA,CAEhFI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,QAAQ,CAAC,CAAA,GAAA,EAAMA,CAAAA,CAAM,GAAA,CAAIL,CAAAA,CAAE,UAAA,EAAY,KAAA,CAAM,CAAA,CAAG,EAAE,CAAA,EAAK,GAAG,CAAC,CAAA,CAAE,CAAA,CACpFI,CAAAA,CAAO,EAAE,EACX","file":"time-status-XQLRCYF6.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { logJSON, logRaw } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport { formatCountdown } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface TimeLockStatus {\n locked: boolean\n unlock_at: string | null\n time_remaining_ms: number | null\n proof_hash: string\n}\n\nexport default async function timeStatus(path: string): Promise<void> {\n const data = await apiGet<{ status: TimeLockStatus }>(`/api/v1/time/status?path=${encodeURIComponent(path)}`, { authenticated: true })\n const s = data.status\n\n if (isJsonMode()) {\n logJSON(s)\n return\n }\n\n logRaw('')\n logRaw(` ${chalk.bold(path)}`)\n logRaw(chalk.dim(' ───'.repeat(8)))\n logRaw(` ${chalk.bold('Locked:')} ${s.locked ? chalk.yellow('yes') : chalk.green('no')}`)\n if (s.unlock_at) {\n logRaw(` ${chalk.bold('Unlocks:')} ${s.unlock_at}`)\n }\n if (s.time_remaining_ms !== null && s.time_remaining_ms > 0) {\n logRaw(` ${chalk.bold('Remaining:')} ${formatCountdown(s.time_remaining_ms)}`)\n }\n logRaw(` ${chalk.bold('Proof:')} ${chalk.dim(s.proof_hash?.slice(0, 16) || '-')}`)\n logRaw('')\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/time/time-status.ts"],"names":["timeStatus","path","s","apiGet","isJsonMode","logJSON","logRaw","chalk","formatCountdown"],"mappings":"oMAaA,eAAOA,CAAAA,CAAkCC,CAAAA,CAA6B,CAEpE,IAAMC,CAAAA,CAAAA,CADO,MAAMC,CAAAA,CAAmC,CAAA,yBAAA,EAA4B,kBAAA,CAAmBF,CAAI,CAAC,CAAA,CAAA,CAAI,CAAE,aAAA,CAAe,IAAK,CAAC,CAAA,EACtH,MAAA,CAEf,GAAIG,CAAAA,EAAW,CAAG,CAChBC,CAAAA,CAAQH,CAAC,CAAA,CACT,MACF,CAEAI,CAAAA,CAAO,EAAE,CAAA,CACTA,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAKN,CAAI,CAAC,CAAA,CAAE,CAAA,CAC9BK,CAAAA,CAAOC,CAAAA,CAAM,GAAA,CAAI,sBAAA,CAAQ,MAAA,CAAO,CAAC,CAAC,CAAC,CAAA,CACnCD,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,SAAS,CAAC,CAAA,EAAA,EAAKL,CAAAA,CAAE,MAAA,CAASK,CAAAA,CAAM,MAAA,CAAO,KAAK,CAAA,CAAIA,CAAAA,CAAM,KAAA,CAAM,IAAI,CAAC,CAAA,CAAE,CAAA,CACtFL,CAAAA,CAAE,SAAA,EACJI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,UAAU,CAAC,CAAA,CAAA,EAAIL,CAAAA,CAAE,SAAS,CAAA,CAAE,CAAA,CAEjDA,CAAAA,CAAE,iBAAA,GAAsB,IAAA,EAAQA,CAAAA,CAAE,iBAAA,CAAoB,CAAA,EACxDI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,YAAY,CAAC,CAAA,CAAA,EAAIC,GAAAA,CAAgBN,CAAAA,CAAE,iBAAiB,CAAC,CAAA,CAAE,CAAA,CAEhFI,CAAAA,CAAO,CAAA,EAAA,EAAKC,CAAAA,CAAM,IAAA,CAAK,QAAQ,CAAC,CAAA,GAAA,EAAMA,CAAAA,CAAM,GAAA,CAAIL,CAAAA,CAAE,UAAA,EAAY,KAAA,CAAM,CAAA,CAAG,EAAE,CAAA,EAAK,GAAG,CAAC,CAAA,CAAE,CAAA,CACpFI,CAAAA,CAAO,EAAE,EACX","file":"time-status-TVNJBFKC.js","sourcesContent":["import { apiGet } from '../../lib/api/client.js'\nimport { logJSON, logRaw } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport { formatCountdown } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\n\ninterface TimeLockStatus {\n locked: boolean\n unlock_at: string | null\n time_remaining_ms: number | null\n proof_hash: string\n}\n\nexport default async function timeStatus(path: string): Promise<void> {\n const data = await apiGet<{ status: TimeLockStatus }>(`/api/v1/time/status?path=${encodeURIComponent(path)}`, { authenticated: true })\n const s = data.status\n\n if (isJsonMode()) {\n logJSON(s)\n return\n }\n\n logRaw('')\n logRaw(` ${chalk.bold(path)}`)\n logRaw(chalk.dim(' ───'.repeat(8)))\n logRaw(` ${chalk.bold('Locked:')} ${s.locked ? chalk.yellow('yes') : chalk.green('no')}`)\n if (s.unlock_at) {\n logRaw(` ${chalk.bold('Unlocks:')} ${s.unlock_at}`)\n }\n if (s.time_remaining_ms !== null && s.time_remaining_ms > 0) {\n logRaw(` ${chalk.bold('Remaining:')} ${formatCountdown(s.time_remaining_ms)}`)\n }\n logRaw(` ${chalk.bold('Proof:')} ${chalk.dim(s.proof_hash?.slice(0, 16) || '-')}`)\n logRaw('')\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import {e}from'./chunk-BC2OVPRV.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g,h}from'./chunk-QT7R3AXE.js';import'./chunk-4NTVRCZM.js';async function i(t){let o=b(`Attempting to unlock ${t}...`);o.start();try{(await e("/api/v1/time/unlock",{path:t},{authenticated:!0})).unlocked?(o.succeed(),g(`Unlocked ${t}`)):(o.fail(),h("Cannot unlock yet \u2014 lock time has not passed"),process.exit(1));}catch{throw o.fail(),new Error("Cannot unlock yet \u2014 lock time has not passed")}}export{i as default};//# sourceMappingURL=time-unlock-OO6QH5R6.js.map
2
+ //# sourceMappingURL=time-unlock-OO6QH5R6.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/time/time-unlock.ts"],"names":["timeUnlock","path","spinner","createSpinner","apiPost","logSuccess","logError"],"mappings":"8NAIA,eAAOA,CAAAA,CAAkCC,CAAAA,CAA6B,CACpE,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,CAAA,qBAAA,EAAwBF,CAAI,CAAA,GAAA,CAAK,CAAA,CAC/DC,CAAAA,CAAQ,KAAA,EAAM,CACd,GAAI,CAAA,CACa,MAAME,CAAAA,CAA+B,qBAAA,CAAuB,CAAE,IAAA,CAAAH,CAAK,CAAA,CAAG,CAAE,aAAA,CAAe,CAAA,CAAK,CAAC,CAAA,EACjG,QAAA,EACTC,EAAQ,OAAA,EAAQ,CAChBG,CAAAA,CAAW,CAAA,SAAA,EAAYJ,CAAI,CAAA,CAAE,CAAA,GAE7BC,CAAAA,CAAQ,IAAA,EAAK,CACbI,CAAAA,CAAS,mDAA8C,CAAA,CACvD,OAAA,CAAQ,KAAK,CAAC,CAAA,EAElB,CAAA,KAAQ,CACN,MAAAJ,CAAAA,CAAQ,IAAA,EAAK,CACP,IAAI,KAAA,CAAM,mDAA8C,CAChE,CACF","file":"time-unlock-KNMGQ3TK.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logError } from '../../lib/output/logger.js'\n\nexport default async function timeUnlock(path: string): Promise<void> {\n const spinner = createSpinner(`Attempting to unlock ${path}...`)\n spinner.start()\n try {\n const result = await apiPost<{ unlocked: boolean }>('/api/v1/time/unlock', { path }, { authenticated: true })\n if (result.unlocked) {\n spinner.succeed()\n logSuccess(`Unlocked ${path}`)\n } else {\n spinner.fail()\n logError('Cannot unlock yet — lock time has not passed')\n process.exit(1)\n }\n } catch {\n spinner.fail()\n throw new Error('Cannot unlock yet — lock time has not passed')\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/time/time-unlock.ts"],"names":["timeUnlock","path","spinner","createSpinner","apiPost","logSuccess","logError"],"mappings":"kMAIA,eAAOA,CAAAA,CAAkCC,CAAAA,CAA6B,CACpE,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,CAAA,qBAAA,EAAwBF,CAAI,CAAA,GAAA,CAAK,CAAA,CAC/DC,CAAAA,CAAQ,KAAA,EAAM,CACd,GAAI,CAAA,CACa,MAAME,CAAAA,CAA+B,qBAAA,CAAuB,CAAE,IAAA,CAAAH,CAAK,CAAA,CAAG,CAAE,aAAA,CAAe,CAAA,CAAK,CAAC,CAAA,EACjG,QAAA,EACTC,EAAQ,OAAA,EAAQ,CAChBG,CAAAA,CAAW,CAAA,SAAA,EAAYJ,CAAI,CAAA,CAAE,CAAA,GAE7BC,CAAAA,CAAQ,IAAA,EAAK,CACbI,CAAAA,CAAS,mDAA8C,CAAA,CACvD,OAAA,CAAQ,KAAK,CAAC,CAAA,EAElB,CAAA,KAAQ,CACN,MAAAJ,CAAAA,CAAQ,IAAA,EAAK,CACP,IAAI,KAAA,CAAM,mDAA8C,CAChE,CACF","file":"time-unlock-OO6QH5R6.js","sourcesContent":["import { apiPost } from '../../lib/api/client.js'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logError } from '../../lib/output/logger.js'\n\nexport default async function timeUnlock(path: string): Promise<void> {\n const spinner = createSpinner(`Attempting to unlock ${path}...`)\n spinner.start()\n try {\n const result = await apiPost<{ unlocked: boolean }>('/api/v1/time/unlock', { path }, { authenticated: true })\n if (result.unlocked) {\n spinner.succeed()\n logSuccess(`Unlocked ${path}`)\n } else {\n spinner.fail()\n logError('Cannot unlock yet — lock time has not passed')\n process.exit(1)\n }\n } catch {\n spinner.fail()\n throw new Error('Cannot unlock yet — lock time has not passed')\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-FYFPDKJM.js';import'./chunk-THMWE2I6.js';import {j,g,h}from'./chunk-QT7R3AXE.js';import {execSync}from'child_process';async function d(){let o=b("Checking for updates...");o.start();try{let e=execSync("npm view @squidcloud/cli version",{encoding:"utf-8"}).trim(),r={version:"1.0.0"};if(o.succeed(),e>r.version){j(`New version available: ${e} (current: ${r.version})`);let n=b("Updating...");n.start(),execSync("npm install -g @squidcloud/cli",{stdio:"pipe"}),n.succeed(),g(`Updated to v${e}`);}else g(`Already up to date (v${r.version})`);}catch{o.fail(),h("Failed to check for updates");}}export{d as default};//# sourceMappingURL=update-XJQSXSFU.js.map
2
+ //# sourceMappingURL=update-XJQSXSFU.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/util/update.ts"],"names":["update","spinner","createSpinner","result","execSync","pkg","logInfo","installSpinner","logSuccess","logError"],"mappings":"yKAIA,eAAOA,CAAAA,EAA+C,CACpD,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,yBAAyB,CAAA,CACvDD,EAAQ,KAAA,EAAM,CACd,GAAI,CACF,IAAME,EAASC,QAAAA,CAAS,kCAAA,CAAoC,CAAE,QAAA,CAAU,OAAQ,CAAC,CAAA,CAAE,MAAK,CAClFC,CAAAA,CAAM,CAAE,OAAA,CAAS,OAAQ,EAE/B,GADAJ,CAAAA,CAAQ,SAAQ,CACZE,CAAAA,CAASE,EAAI,OAAA,CAAS,CACxBC,EAAQ,CAAA,uBAAA,EAA0BH,CAAM,CAAA,WAAA,EAAcE,CAAAA,CAAI,OAAO,CAAA,CAAA,CAAG,CAAA,CACpE,IAAME,CAAAA,CAAiBL,CAAAA,CAAc,aAAa,CAAA,CAClDK,CAAAA,CAAe,KAAA,EAAM,CACrBH,SAAS,gCAAA,CAAkC,CAAE,MAAO,MAAO,CAAC,EAC5DG,CAAAA,CAAe,OAAA,EAAQ,CACvBC,CAAAA,CAAW,eAAeL,CAAM,CAAA,CAAE,EACpC,CAAA,KACEK,CAAAA,CAAW,wBAAwBH,CAAAA,CAAI,OAAO,GAAG,EAErD,CAAA,KAAc,CACZJ,CAAAA,CAAQ,IAAA,GACRQ,CAAAA,CAAS,6BAA6B,EACxC,CACF","file":"update-IYMIV34T.js","sourcesContent":["import { execSync } from 'node:child_process'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logError, logInfo } from '../../lib/output/logger.js'\n\nexport default async function update(): Promise<void> {\n const spinner = createSpinner('Checking for updates...')\n spinner.start()\n try {\n const result = execSync('npm view @squidcloud/cli version', { encoding: 'utf-8' }).trim()\n const pkg = { version: '1.0.0' }\n spinner.succeed()\n if (result > pkg.version) {\n logInfo(`New version available: ${result} (current: ${pkg.version})`)\n const installSpinner = createSpinner('Updating...')\n installSpinner.start()\n execSync('npm install -g @squidcloud/cli', { stdio: 'pipe' })\n installSpinner.succeed()\n logSuccess(`Updated to v${result}`)\n } else {\n logSuccess(`Already up to date (v${pkg.version})`)\n }\n } catch (err) {\n spinner.fail()\n logError('Failed to check for updates')\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/util/update.ts"],"names":["update","spinner","createSpinner","result","execSync","pkg","logInfo","installSpinner","logSuccess","logError"],"mappings":"6IAIA,eAAOA,CAAAA,EAA+C,CACpD,IAAMC,CAAAA,CAAUC,CAAAA,CAAc,yBAAyB,CAAA,CACvDD,EAAQ,KAAA,EAAM,CACd,GAAI,CACF,IAAME,EAASC,QAAAA,CAAS,kCAAA,CAAoC,CAAE,QAAA,CAAU,OAAQ,CAAC,CAAA,CAAE,MAAK,CAClFC,CAAAA,CAAM,CAAE,OAAA,CAAS,OAAQ,EAE/B,GADAJ,CAAAA,CAAQ,SAAQ,CACZE,CAAAA,CAASE,EAAI,OAAA,CAAS,CACxBC,EAAQ,CAAA,uBAAA,EAA0BH,CAAM,CAAA,WAAA,EAAcE,CAAAA,CAAI,OAAO,CAAA,CAAA,CAAG,CAAA,CACpE,IAAME,CAAAA,CAAiBL,CAAAA,CAAc,aAAa,CAAA,CAClDK,CAAAA,CAAe,KAAA,EAAM,CACrBH,SAAS,gCAAA,CAAkC,CAAE,MAAO,MAAO,CAAC,EAC5DG,CAAAA,CAAe,OAAA,EAAQ,CACvBC,CAAAA,CAAW,eAAeL,CAAM,CAAA,CAAE,EACpC,CAAA,KACEK,CAAAA,CAAW,wBAAwBH,CAAAA,CAAI,OAAO,GAAG,EAErD,CAAA,KAAc,CACZJ,CAAAA,CAAQ,IAAA,GACRQ,CAAAA,CAAS,6BAA6B,EACxC,CACF","file":"update-XJQSXSFU.js","sourcesContent":["import { execSync } from 'node:child_process'\nimport { createSpinner } from '../../lib/output/spinner.js'\nimport { logSuccess, logError, logInfo } from '../../lib/output/logger.js'\n\nexport default async function update(): Promise<void> {\n const spinner = createSpinner('Checking for updates...')\n spinner.start()\n try {\n const result = execSync('npm view @squidcloud/cli version', { encoding: 'utf-8' }).trim()\n const pkg = { version: '1.0.0' }\n spinner.succeed()\n if (result > pkg.version) {\n logInfo(`New version available: ${result} (current: ${pkg.version})`)\n const installSpinner = createSpinner('Updating...')\n installSpinner.start()\n execSync('npm install -g @squidcloud/cli', { stdio: 'pipe' })\n installSpinner.succeed()\n logSuccess(`Updated to v${result}`)\n } else {\n logSuccess(`Already up to date (v${pkg.version})`)\n }\n } catch (err) {\n spinner.fail()\n logError('Failed to check for updates')\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {f,m}from'./chunk-QT7R3AXE.js';import o from'chalk';var r={version:"1.0.0"};async function s(){if(f()){m({version:r.version,name:"@squidcloud/cli"});return}console.log(o.hex("#4FC3F7")("squidcloud.vercel.app")+o.dim(" CLI ")+o.dim("v"+r.version));}var d=s;export{d as default,s as showVersion};//# sourceMappingURL=version-LHSDYI7Q.js.map
2
+ //# sourceMappingURL=version-LHSDYI7Q.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/commands/util/version.ts"],"names":["pkg","showVersion","isJsonMode","logJSON","chalk","version_default"],"mappings":"2DAGA,IAAMA,CAAAA,CAAM,CAAE,OAAA,CAAS,OAAQ,EAE/B,eAAsBC,CAAAA,EAA6B,CACjD,GAAIC,CAAAA,GAAc,CAChBC,CAAAA,CAAQ,CAAE,OAAA,CAASH,CAAAA,CAAI,OAAA,CAAS,IAAA,CAAM,iBAAkB,CAAC,EACzD,MACF,CACA,QAAQ,GAAA,CAAII,CAAAA,CAAM,IAAI,SAAS,CAAA,CAAE,uBAAuB,CAAA,CAAIA,CAAAA,CAAM,GAAA,CAAI,OAAO,CAAA,CAAIA,CAAAA,CAAM,IAAI,GAAA,CAAMJ,CAAAA,CAAI,OAAO,CAAC,EAC/G,CAEA,IAAOK,CAAAA,CAAQJ","file":"version-LHSDYI7Q.js","sourcesContent":["import chalk from 'chalk'\nimport { isJsonMode, logJSON } from '../../lib/output/logger.js'\n\nconst pkg = { version: '1.0.0' }\n\nexport async function showVersion(): Promise<void> {\n if (isJsonMode()) {\n logJSON({ version: pkg.version, name: '@squidcloud/cli' })\n return\n }\n console.log(chalk.hex('#4FC3F7')('squidcloud.vercel.app') + chalk.dim(' CLI ') + chalk.dim('v' + pkg.version))\n}\n\nexport default showVersion\n"]}
@@ -1,2 +1,2 @@
1
- import {b}from'./chunk-THMWE2I6.js';import {d as d$1}from'./chunk-G4JU7IUC.js';import {h,f,m as m$1}from'./chunk-QT7R3AXE.js';import {m,r}from'./chunk-C5KZCYJ4.js';import o from'chalk';async function d(){let e=await m();if(e||(h("Not authenticated"),process.exit(1)),f()){m$1({authenticated:true,user:e.user,session_id:e.session_id,expires_at:e.expires_at});return}let m$2=r(e),u=[{key:o.bold("Email"),value:e.user.email},{key:o.bold("Username"),value:e.user.username},{key:o.bold("Plan"),value:o.hex("#7C4DFF")(e.user.plan)},{key:o.bold("Session Expires"),value:d$1(m$2)}];console.log(b(u,[{key:"key",label:"Attribute"},{key:"value",label:"Value"}]));}export{d as default};//# sourceMappingURL=whoami-WIHSRTUN.js.map
2
- //# sourceMappingURL=whoami-WIHSRTUN.js.map
1
+ import {b}from'./chunk-THMWE2I6.js';import {d as d$1}from'./chunk-G4JU7IUC.js';import {h,f,m as m$1}from'./chunk-QT7R3AXE.js';import {m,r}from'./chunk-4NTVRCZM.js';import o from'chalk';async function d(){let e=await m();if(e||(h("Not authenticated"),process.exit(1)),f()){m$1({authenticated:true,user:e.user,session_id:e.session_id,expires_at:e.expires_at});return}let m$2=r(e),u=[{key:o.bold("Email"),value:e.user.email},{key:o.bold("Username"),value:e.user.username},{key:o.bold("Plan"),value:o.hex("#7C4DFF")(e.user.plan)},{key:o.bold("Session Expires"),value:d$1(m$2)}];console.log(b(u,[{key:"key",label:"Attribute"},{key:"value",label:"Value"}]));}export{d as default};//# sourceMappingURL=whoami-SAURQARO.js.map
2
+ //# sourceMappingURL=whoami-SAURQARO.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/commands/auth/whoami.ts"],"names":["whoami","session","loadSession","logError","isJsonMode","logJSON","timeLeft","getTimeUntilExpiry","rows","chalk","formatCountdown","renderCompactTable"],"mappings":"yLAOA,eAAOA,CAAAA,EAA+C,CACpD,IAAMC,CAAAA,CAAU,MAAMC,CAAAA,EAAY,CAMlC,GALKD,CAAAA,GACHE,EAAS,mBAAmB,CAAA,CAC5B,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA,CAAA,CAGZC,CAAAA,EAAW,CAAG,CAChBC,GAAAA,CAAQ,CACN,aAAA,CAAe,IAAA,CACf,IAAA,CAAMJ,EAAQ,IAAA,CACd,UAAA,CAAYA,CAAAA,CAAQ,UAAA,CACpB,UAAA,CAAYA,CAAAA,CAAQ,UACtB,CAAC,CAAA,CACD,MACF,CAEA,IAAMK,GAAAA,CAAWC,CAAAA,CAAmBN,CAAO,CAAA,CACrCO,CAAAA,CAAO,CACX,CAAE,GAAA,CAAKC,CAAAA,CAAM,IAAA,CAAK,OAAO,CAAA,CAAG,KAAA,CAAOR,CAAAA,CAAQ,IAAA,CAAK,KAAM,CAAA,CACtD,CAAE,GAAA,CAAKQ,CAAAA,CAAM,IAAA,CAAK,UAAU,CAAA,CAAG,KAAA,CAAOR,CAAAA,CAAQ,IAAA,CAAK,QAAS,CAAA,CAC5D,CAAE,GAAA,CAAKQ,CAAAA,CAAM,IAAA,CAAK,MAAM,CAAA,CAAG,KAAA,CAAOA,CAAAA,CAAM,GAAA,CAAI,SAAS,CAAA,CAAER,CAAAA,CAAQ,IAAA,CAAK,IAAI,CAAE,CAAA,CAC1E,CAAE,GAAA,CAAKQ,CAAAA,CAAM,KAAK,iBAAiB,CAAA,CAAG,KAAA,CAAOC,GAAAA,CAAgBJ,GAAQ,CAAE,CACzE,CAAA,CAEA,OAAA,CAAQ,GAAA,CAAIK,CAAAA,CAAmBH,CAAAA,CAAM,CACnC,CAAE,IAAK,KAAA,CAAO,KAAA,CAAO,WAAY,CAAA,CACjC,CAAE,GAAA,CAAK,OAAA,CAAS,KAAA,CAAO,OAAQ,CACjC,CAAC,CAAC,EACJ","file":"whoami-WIHSRTUN.js","sourcesContent":["import { loadSession, getTimeUntilExpiry } from '../../lib/auth/session.js'\nimport { logError, logJSON } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport { formatCountdown } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\nimport { renderCompactTable } from '../../lib/output/table.js'\n\nexport default async function whoami(): Promise<void> {\n const session = await loadSession()\n if (!session) {\n logError('Not authenticated')\n process.exit(1)\n }\n\n if (isJsonMode()) {\n logJSON({\n authenticated: true,\n user: session.user,\n session_id: session.session_id,\n expires_at: session.expires_at,\n })\n return\n }\n\n const timeLeft = getTimeUntilExpiry(session)\n const rows = [\n { key: chalk.bold('Email'), value: session.user.email },\n { key: chalk.bold('Username'), value: session.user.username },\n { key: chalk.bold('Plan'), value: chalk.hex('#7C4DFF')(session.user.plan) },\n { key: chalk.bold('Session Expires'), value: formatCountdown(timeLeft) },\n ]\n\n console.log(renderCompactTable(rows, [\n { key: 'key', label: 'Attribute' },\n { key: 'value', label: 'Value' },\n ]))\n}\n"]}
1
+ {"version":3,"sources":["../src/commands/auth/whoami.ts"],"names":["whoami","session","loadSession","logError","isJsonMode","logJSON","timeLeft","getTimeUntilExpiry","rows","chalk","formatCountdown","renderCompactTable"],"mappings":"yLAOA,eAAOA,CAAAA,EAA+C,CACpD,IAAMC,CAAAA,CAAU,MAAMC,CAAAA,EAAY,CAMlC,GALKD,CAAAA,GACHE,EAAS,mBAAmB,CAAA,CAC5B,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA,CAAA,CAGZC,CAAAA,EAAW,CAAG,CAChBC,GAAAA,CAAQ,CACN,aAAA,CAAe,IAAA,CACf,IAAA,CAAMJ,EAAQ,IAAA,CACd,UAAA,CAAYA,CAAAA,CAAQ,UAAA,CACpB,UAAA,CAAYA,CAAAA,CAAQ,UACtB,CAAC,CAAA,CACD,MACF,CAEA,IAAMK,GAAAA,CAAWC,CAAAA,CAAmBN,CAAO,CAAA,CACrCO,CAAAA,CAAO,CACX,CAAE,GAAA,CAAKC,CAAAA,CAAM,IAAA,CAAK,OAAO,CAAA,CAAG,KAAA,CAAOR,CAAAA,CAAQ,IAAA,CAAK,KAAM,CAAA,CACtD,CAAE,GAAA,CAAKQ,CAAAA,CAAM,IAAA,CAAK,UAAU,CAAA,CAAG,KAAA,CAAOR,CAAAA,CAAQ,IAAA,CAAK,QAAS,CAAA,CAC5D,CAAE,GAAA,CAAKQ,CAAAA,CAAM,IAAA,CAAK,MAAM,CAAA,CAAG,KAAA,CAAOA,CAAAA,CAAM,GAAA,CAAI,SAAS,CAAA,CAAER,CAAAA,CAAQ,IAAA,CAAK,IAAI,CAAE,CAAA,CAC1E,CAAE,GAAA,CAAKQ,CAAAA,CAAM,KAAK,iBAAiB,CAAA,CAAG,KAAA,CAAOC,GAAAA,CAAgBJ,GAAQ,CAAE,CACzE,CAAA,CAEA,OAAA,CAAQ,GAAA,CAAIK,CAAAA,CAAmBH,CAAAA,CAAM,CACnC,CAAE,IAAK,KAAA,CAAO,KAAA,CAAO,WAAY,CAAA,CACjC,CAAE,GAAA,CAAK,OAAA,CAAS,KAAA,CAAO,OAAQ,CACjC,CAAC,CAAC,EACJ","file":"whoami-SAURQARO.js","sourcesContent":["import { loadSession, getTimeUntilExpiry } from '../../lib/auth/session.js'\nimport { logError, logJSON } from '../../lib/output/logger.js'\nimport { isJsonMode } from '../../lib/output/logger.js'\nimport { formatCountdown } from '../../lib/utils/format.js'\nimport chalk from 'chalk'\nimport { renderCompactTable } from '../../lib/output/table.js'\n\nexport default async function whoami(): Promise<void> {\n const session = await loadSession()\n if (!session) {\n logError('Not authenticated')\n process.exit(1)\n }\n\n if (isJsonMode()) {\n logJSON({\n authenticated: true,\n user: session.user,\n session_id: session.session_id,\n expires_at: session.expires_at,\n })\n return\n }\n\n const timeLeft = getTimeUntilExpiry(session)\n const rows = [\n { key: chalk.bold('Email'), value: session.user.email },\n { key: chalk.bold('Username'), value: session.user.username },\n { key: chalk.bold('Plan'), value: chalk.hex('#7C4DFF')(session.user.plan) },\n { key: chalk.bold('Session Expires'), value: formatCountdown(timeLeft) },\n ]\n\n console.log(renderCompactTable(rows, [\n { key: 'key', label: 'Attribute' },\n { key: 'value', label: 'Value' },\n ]))\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "squidcloudctl",
3
- "version": "1.1.0",
3
+ "version": "1.1.2",
4
4
  "description": "SquidCloud CLI — deploy, storage, sites, pipelines, and more",
5
5
  "type": "module",
6
6
  "bin": {
@@ -1,2 +0,0 @@
1
- import {a as a$1}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import {o}from'./chunk-C5KZCYJ4.js';import a from'inquirer';async function c(e$1){if(e$1.all){let{confirm:s}=await a.prompt([{type:"confirm",name:"confirm",message:"Revoke ALL active sessions? This will log out every device.",default:false}]);if(!s)return;let t=a$1("Revoking all sessions...");t.start(),await e("/api/auth/ssp/revoke-all",{},{authenticated:true}),await o(),t.succeed(),g("All sessions revoked");return}if(e$1.session){let s=a$1(`Revoking session ${e$1.session}...`);s.start(),await e("/api/auth/ssp/revoke",{session_id:e$1.session},{authenticated:true}),s.succeed(),g(`Session ${e$1.session} revoked`);return}console.error("Specify --session <id> or --all"),process.exit(1);}export{c as default};//# sourceMappingURL=auth-revoke-OC67YCEQ.js.map
2
- //# sourceMappingURL=auth-revoke-OC67YCEQ.js.map
@@ -1,6 +0,0 @@
1
- import n from'chalk';var F="#0A0E1A",r="#4FC3F7",s="#7C4DFF",c="#FFFFFF",l=[" \u2554\u2550\u2550\u2550\u2557 "," \u2554\u255D\u2588 \u2588\u255A\u2557 "," \u2551 \u25C9 \u2551 "," \u255A\u2557 \u2554\u255D "," \u2551 \u2566 \u2551 "," \u2554\u255D \u2551 \u255A\u2557 "," \u2551 \u2551 \u2551 "," \u255A\u2557 \u2551 \u2554\u255D "," \u255A\u2550\u2550\u2550\u255D "];function p(){return l.map((e,o)=>{let i=e.replace(/█/g,n.hex(s)("\u2588")).replace(/◉/g,n.hex(r)("\u25C9")).replace(/[╔╗╚╝═║╦]/g,a=>n.hex(c)(a));return n.bgHex(F)(i)}).join(`
2
- `)}function g(){let t=p(),e=n.hex(r)("SQUID")+n.hex(s)("CLOUD"),o=n.hex(c).dim("static sites \xB7 storage \xB7 pipelines");return `${t}
3
-
4
- ${e} ${o}
5
- `}export{p as a,g as b};//# sourceMappingURL=chunk-6TS5Y27A.js.map
6
- //# sourceMappingURL=chunk-6TS5Y27A.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/output/mascot.ts"],"names":["NAVY","BLUE","VIOLET","WHITE","SQUID_ART","renderMascot","line","i","colored","chalk","m","renderBrandedMascot","mascot","brand","tagline"],"mappings":"qBAEA,IAAMA,CAAAA,CAAO,UACPC,CAAAA,CAAO,SAAA,CACPC,CAAAA,CAAS,SAAA,CACTC,EAAQ,SAAA,CAERC,CAAAA,CAAY,CAChB,oCAAA,CACA,0CACA,0BAAA,CACA,+BAAA,CACA,0BAAA,CACA,oCAAA,CACA,0BAAA,CACA,oCAAA,CACA,oCACF,CAAA,CAEO,SAASC,CAAAA,EAAuB,CAOrC,OANcD,CAAAA,CAAU,IAAI,CAACE,CAAAA,CAAMC,CAAAA,GAAM,CACvC,IAAMC,CAAAA,CAAUF,CAAAA,CAAK,OAAA,CAAQ,IAAA,CAAMG,CAAAA,CAAM,GAAA,CAAIP,CAAM,CAAA,CAAE,QAAG,CAAC,CAAA,CACtD,OAAA,CAAQ,IAAA,CAAMO,EAAM,GAAA,CAAIR,CAAI,CAAA,CAAE,QAAG,CAAC,CAAA,CAClC,OAAA,CAAQ,YAAA,CAAeS,CAAAA,EAAMD,EAAM,GAAA,CAAIN,CAAK,CAAA,CAAEO,CAAC,CAAC,CAAA,CACnD,OAAOD,CAAAA,CAAM,KAAA,CAAMT,CAAI,CAAA,CAAEQ,CAAO,CAClC,CAAC,EACY,IAAA,CAAK;AAAA,CAAI,CACxB,CAEO,SAASG,CAAAA,EAA8B,CAC5C,IAAMC,CAAAA,CAASP,CAAAA,EAAa,CACtBQ,CAAAA,CAAQJ,CAAAA,CAAM,GAAA,CAAIR,CAAI,EAAE,OAAO,CAAA,CAAIQ,CAAAA,CAAM,GAAA,CAAIP,CAAM,CAAA,CAAE,OAAO,CAAA,CAC5DY,EAAUL,CAAAA,CAAM,GAAA,CAAIN,CAAK,CAAA,CAAE,GAAA,CAAI,0CAAoC,CAAA,CACzE,OAAO,GAAGS,CAAM;;AAAA,EAAA,EAASC,CAAK,KAAKC,CAAO;AAAA,CAC5C","file":"chunk-6TS5Y27A.js","sourcesContent":["import chalk from 'chalk'\n\nconst NAVY = '#0A0E1A'\nconst BLUE = '#4FC3F7'\nconst VIOLET = '#7C4DFF'\nconst WHITE = '#FFFFFF'\n\nconst SQUID_ART = [\n ' ╔═══╗ ',\n ' ╔╝█ █╚╗ ',\n ' ║ ◉ ║ ',\n ' ╚╗ ╔╝ ',\n ' ║ ╦ ║ ',\n ' ╔╝ ║ ╚╗ ',\n ' ║ ║ ║ ',\n ' ╚╗ ║ ╔╝ ',\n ' ╚═══╝ ',\n]\n\nexport function renderMascot(): string {\n const lines = SQUID_ART.map((line, i) => {\n const colored = line.replace(/█/g, chalk.hex(VIOLET)('█'))\n .replace(/◉/g, chalk.hex(BLUE)('◉'))\n .replace(/[╔╗╚╝═║╦]/g, (m) => chalk.hex(WHITE)(m))\n return chalk.bgHex(NAVY)(colored)\n })\n return lines.join('\\n')\n}\n\nexport function renderBrandedMascot(): string {\n const mascot = renderMascot()\n const brand = chalk.hex(BLUE)('SQUID') + chalk.hex(VIOLET)('CLOUD')\n const tagline = chalk.hex(WHITE).dim('static sites · storage · pipelines')\n return `${mascot}\\n\\n ${brand} ${tagline}\\n`\n}\n"]}
@@ -1,2 +0,0 @@
1
- import s from'os';import l from'path';import a,{existsSync,readFileSync}from'fs';import {randomBytes}from'@noble/hashes/utils';import {sha256}from'@noble/hashes/sha256';import {hkdf}from'@noble/hashes/hkdf';import {gcm}from'@noble/ciphers/aes';import {utils,getPublicKey,verify}from'@noble/ed25519';import {x25519}from'@noble/curves/ed25519.js';import {hmac}from'@noble/hashes/hmac';import {blake3}from'@noble/hashes/blake3';import {pbkdf2Sync,createHash}from'crypto';var T="squidcloud-session-v1";function et(){let t=utils.randomPrivateKey();return {pub:getPublicKey(t),priv:t}}function nt(){return randomBytes(32)}function it(t,r){let e=Buffer.from(r.slice(0,32).padEnd(32,"\0"));return pbkdf2Sync(t,e,1e5,32,"sha512")}function ot(t,r,e,n){let i=new Uint8Array(t.length+r.length+e.length+8);i.set(t,0),i.set(r,t.length),i.set(e,t.length+r.length);let o=new Uint8Array(8);return new DataView(o.buffer).setBigUint64(0,BigInt(n),false),i.set(o,t.length+r.length+e.length),blake3(i)}function st(t,r){return x25519.getSharedSecret(r,t)}function at(t,r,e){let n=new Uint8Array(r.length+e.length);return n.set(r,0),n.set(e,r.length),hkdf(sha256,t,n,T,32)}function ct(t,r,e,n){let i=new Uint8Array(t.length+e.length);i.set(t,0),i.set(e,t.length);let m=gcm(n,r).decrypt(i);return JSON.parse(new TextDecoder().decode(m))}function ut(t,r,e){return verify(t,r,e)}function pt(t,r){return Buffer.from(hmac(sha256,t,r)).toString("hex")}function c(t){return Buffer.from(t).toString("hex")}function f(t){return new Uint8Array(Buffer.from(t,"hex"))}var K=["/etc/machine-id","/var/lib/dbus/machine-id","/etc/hostid"];function O(){for(let r of K)try{if(existsSync(r))return readFileSync(r,"utf-8").trim()}catch{continue}return createHash("sha256").update(s.hostname()+s.arch()+s.platform()).digest("hex")}function g(){let e=[O(),s.hostname(),s.platform(),s.arch(),s.release()].join(":");return c(blake3(e))}var d=l.join(s.homedir(),".squidcloud"),u=l.join(d,".session");function h(){let t=g(),r=new TextEncoder().encode(t);return hkdf(sha256,r,new Uint8Array(32),"squidcloud-fallback-v1",32)}async function x(t){let r=h(),e=randomBytes(12),n=new TextEncoder().encode(t),o=gcm(r,e).encrypt(n);a.existsSync(d)||a.mkdirSync(d,{recursive:true,mode:448});let m={iv:c(e),data:c(o)};a.writeFileSync(u,JSON.stringify(m),{mode:384,encoding:"utf-8"});}async function A(){try{if(!a.existsSync(u))return null;let t=a.readFileSync(u,"utf-8"),{iv:r,data:e}=JSON.parse(t),n=h(),o=gcm(n,f(r)).decrypt(f(e));return new TextDecoder().decode(o)}catch{return null}}async function p(){try{a.existsSync(u)&&a.unlinkSync(u);}catch{}}async function Dt(){try{let t=await A();if(!t)return null;let r=JSON.parse(t);return !r.session_id||!r.access_token?(await p(),null):r}catch{return await p(),null}}async function Tt(t){await x(JSON.stringify(t));}async function Ft(){await p();}function It(t){return Date.now()>=t.expires_at}function Et(t){return t.expires_at-Date.now()<=12e4}function Ht(t){return t.expires_at-Date.now()}export{et as a,nt as b,it as c,ot as d,st as e,at as f,ct as g,ut as h,pt as i,c as j,f as k,g as l,Dt as m,Tt as n,Ft as o,It as p,Et as q,Ht as r};//# sourceMappingURL=chunk-C5KZCYJ4.js.map
2
- //# sourceMappingURL=chunk-C5KZCYJ4.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/crypto/ssp.ts","../src/lib/auth/fingerprint.ts","../src/lib/auth/keychain.ts","../src/lib/auth/session.ts"],"names":["HKDF_INFO","generateKeypair","priv","edUtils","getPublicKey","generateNonce","randomBytes","hashPassword","password","email","salt","pbkdf2Sync","computeSignPayload","clientNonce","serverNonce","clientPub","timestamp","payload","tsBuf","blake3","deriveSharedSecret","pub","x25519","deriveEncryptionKey","ecdhSecret","hkdf","sha256","decryptSession","encrypted","iv","tag","key","combined","plaintext","gcm","verifyServerSignature","signature","serverPub","verify","computeHMAC","data","hmac","bytesToHex","buf","hexToBytes","hex","MACHINE_ID_PATHS","getMachineId","p","existsSync","readFileSync","createHash","os","computeDeviceFingerprint","FALLBACK_DIR","path","FALLBACK_FILE","getFallbackKey","fingerprint","ikm","storeSession","sessionJson","fs","getSession","raw","decrypted","deleteSession","loadSession","session","saveSession","clearSession","isSessionExpired","shouldRefreshToken","getTimeUntilExpiry"],"mappings":"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","file":"chunk-C5KZCYJ4.js","sourcesContent":["import { getPublicKey, sign, verify, utils as edUtils } from '@noble/ed25519'\nimport { x25519 } from '@noble/curves/ed25519.js'\nimport { sha256 } from '@noble/hashes/sha256'\nimport { hmac } from '@noble/hashes/hmac'\nimport { hkdf } from '@noble/hashes/hkdf'\nimport { blake3 } from '@noble/hashes/blake3'\nimport { randomBytes } from '@noble/hashes/utils'\nimport { gcm } from '@noble/ciphers/aes'\nimport { pbkdf2Sync } from 'node:crypto'\nimport { hostname, platform, arch } from 'node:os'\n\nconst HKDF_INFO = 'squidcloud-session-v1'\n\nexport interface SSPHello {\n email: string\n password_proof: string\n client_ephemeral_pub: string\n client_nonce: string\n device_fingerprint: string\n timestamp: number\n}\n\nexport interface SSPResponse {\n server_nonce: string\n server_ephemeral_pub: string\n server_signature: string\n encrypted_session: string\n session_iv: string\n session_tag: string\n}\n\nexport interface SquidSession {\n session_id: string\n access_token: string\n refresh_token: string\n refresh_token_id: string\n device_fingerprint: string\n issued_at: number\n expires_at: number\n user: {\n id: string\n email: string\n username: string\n plan: 'free' | 'pro' | 'team'\n }\n}\n\nexport function generateKeypair(): { pub: Uint8Array; priv: Uint8Array } {\n const priv = edUtils.randomPrivateKey()\n const pub = getPublicKey(priv)\n return { pub, priv }\n}\n\nexport function generateNonce(): Uint8Array {\n return randomBytes(32)\n}\n\nexport function hashPassword(password: string, email: string): Buffer {\n const salt = Buffer.from(email.slice(0, 32).padEnd(32, '\\x00'))\n return pbkdf2Sync(password, salt, 100000, 32, 'sha512')\n}\n\nexport function computeDeviceFingerprint(machineId: string): string {\n const data = `${machineId}:${hostname()}:${platform()}:${arch()}`\n return Buffer.from(blake3(data)).toString('hex')\n}\n\nexport function computeSignPayload(clientNonce: Uint8Array, serverNonce: Uint8Array, clientPub: Uint8Array, timestamp: number): Uint8Array {\n const payload = new Uint8Array(clientNonce.length + serverNonce.length + clientPub.length + 8)\n payload.set(clientNonce, 0)\n payload.set(serverNonce, clientNonce.length)\n payload.set(clientPub, clientNonce.length + serverNonce.length)\n const tsBuf = new Uint8Array(8)\n new DataView(tsBuf.buffer).setBigUint64(0, BigInt(timestamp), false)\n payload.set(tsBuf, clientNonce.length + serverNonce.length + clientPub.length)\n return blake3(payload)\n}\n\nexport function deriveSharedSecret(pub: Uint8Array, priv: Uint8Array): Uint8Array {\n return x25519.getSharedSecret(priv, pub)\n}\n\nexport function deriveEncryptionKey(ecdhSecret: Uint8Array, clientNonce: Uint8Array, serverNonce: Uint8Array): Uint8Array {\n const salt = new Uint8Array(clientNonce.length + serverNonce.length)\n salt.set(clientNonce, 0)\n salt.set(serverNonce, clientNonce.length)\n return hkdf(sha256, ecdhSecret, salt, HKDF_INFO, 32)\n}\n\nexport function encryptSession(session: SquidSession, key: Uint8Array): { ciphertext: Uint8Array; iv: Uint8Array; tag: Uint8Array } {\n const iv = randomBytes(12)\n const plaintext = new TextEncoder().encode(JSON.stringify(session))\n const aes = gcm(key, iv)\n const encrypted = aes.encrypt(plaintext)\n const ciphertext = encrypted.slice(0, -16)\n const tag = encrypted.slice(-16)\n return { ciphertext, iv, tag }\n}\n\nexport function decryptSession(encrypted: Uint8Array, iv: Uint8Array, tag: Uint8Array, key: Uint8Array): SquidSession {\n const combined = new Uint8Array(encrypted.length + tag.length)\n combined.set(encrypted, 0)\n combined.set(tag, encrypted.length)\n const aes = gcm(key, iv)\n const plaintext = aes.decrypt(combined)\n return JSON.parse(new TextDecoder().decode(plaintext)) as SquidSession\n}\n\nexport function verifyServerSignature(signature: Uint8Array, payload: Uint8Array, serverPub: Uint8Array): Promise<boolean> {\n return verify(signature, payload, serverPub)\n}\n\nexport function signPayload(priv: Uint8Array, payload: Uint8Array): Promise<Uint8Array> {\n return sign(payload, priv)\n}\n\nexport function computeHMAC(key: Uint8Array, data: string): string {\n return Buffer.from(hmac(sha256, key, data)).toString('hex')\n}\n\nexport function bytesToHex(buf: Uint8Array): string {\n return Buffer.from(buf).toString('hex')\n}\n\nexport function hexToBytes(hex: string): Uint8Array {\n return new Uint8Array(Buffer.from(hex, 'hex'))\n}\n","import { createHash, randomBytes } from 'node:crypto'\nimport os from 'node:os'\nimport { readFileSync, existsSync } from 'node:fs'\nimport { blake3 } from '@noble/hashes/blake3'\nimport { bytesToHex } from '../crypto/ssp.js'\n\nconst MACHINE_ID_PATHS = [\n '/etc/machine-id',\n '/var/lib/dbus/machine-id',\n '/etc/hostid',\n]\n\nfunction getMachineId(): string {\n for (const p of MACHINE_ID_PATHS) {\n try {\n if (existsSync(p)) {\n return readFileSync(p, 'utf-8').trim()\n }\n } catch {\n continue\n }\n }\n const h = createHash('sha256').update(os.hostname() + os.arch() + os.platform()).digest('hex')\n return h\n}\n\nexport function computeDeviceFingerprint(): string {\n const machineId = getMachineId()\n const components = [\n machineId,\n os.hostname(),\n os.platform(),\n os.arch(),\n os.release(),\n ]\n const data = components.join(':')\n return bytesToHex(blake3(data))\n}\n\nexport function generateDeviceId(): string {\n return randomBytes(32).toString('hex')\n}\n","import os from 'node:os'\nimport path from 'node:path'\nimport fs from 'node:fs'\nimport { randomBytes } from '@noble/hashes/utils'\nimport { sha256 } from '@noble/hashes/sha256'\nimport { hkdf } from '@noble/hashes/hkdf'\nimport { blake3 } from '@noble/hashes/blake3'\nimport { gcm } from '@noble/ciphers/aes'\nimport { bytesToHex, hexToBytes } from '../crypto/ssp.js'\nimport { computeDeviceFingerprint } from './fingerprint.js'\n\nconst FALLBACK_DIR = path.join(os.homedir(), '.squidcloud')\nconst FALLBACK_FILE = path.join(FALLBACK_DIR, '.session')\n\nfunction getFallbackKey(): Uint8Array {\n const fingerprint = computeDeviceFingerprint()\n const ikm = new TextEncoder().encode(fingerprint)\n return hkdf(sha256, ikm, new Uint8Array(32), 'squidcloud-fallback-v1', 32)\n}\n\nexport async function storeSession(sessionJson: string): Promise<void> {\n const key = getFallbackKey()\n const iv = randomBytes(12)\n const plaintext = new TextEncoder().encode(sessionJson)\n const aes = gcm(key, iv)\n const encrypted = aes.encrypt(plaintext)\n if (!fs.existsSync(FALLBACK_DIR)) {\n fs.mkdirSync(FALLBACK_DIR, { recursive: true, mode: 0o700 })\n }\n const payload = {\n iv: bytesToHex(iv),\n data: bytesToHex(encrypted),\n }\n fs.writeFileSync(FALLBACK_FILE, JSON.stringify(payload), { mode: 0o600, encoding: 'utf-8' })\n}\n\nexport async function getSession(): Promise<string | null> {\n try {\n if (!fs.existsSync(FALLBACK_FILE)) return null\n const raw = fs.readFileSync(FALLBACK_FILE, 'utf-8')\n const { iv, data } = JSON.parse(raw) as { iv: string; data: string }\n const key = getFallbackKey()\n const aes = gcm(key, hexToBytes(iv))\n const decrypted = aes.decrypt(hexToBytes(data))\n return new TextDecoder().decode(decrypted)\n } catch {\n return null\n }\n}\n\nexport async function deleteSession(): Promise<void> {\n try {\n if (fs.existsSync(FALLBACK_FILE)) {\n fs.unlinkSync(FALLBACK_FILE)\n }\n } catch {\n // ignore\n }\n}\n","import { SquidSession } from '../crypto/ssp.js'\nimport { storeSession, getSession, deleteSession } from './keychain.js'\n\nexport async function loadSession(): Promise<SquidSession | null> {\n try {\n const raw = await getSession()\n if (!raw) return null\n const session = JSON.parse(raw) as SquidSession\n if (!session.session_id || !session.access_token) {\n await deleteSession()\n return null\n }\n return session\n } catch {\n await deleteSession()\n return null\n }\n}\n\nexport async function saveSession(session: SquidSession): Promise<void> {\n await storeSession(JSON.stringify(session))\n}\n\nexport async function clearSession(): Promise<void> {\n await deleteSession()\n}\n\nexport function isSessionExpired(session: SquidSession): boolean {\n return Date.now() >= session.expires_at\n}\n\nexport function shouldRefreshToken(session: SquidSession): boolean {\n const twoMinutes = 2 * 60 * 1000\n return (session.expires_at - Date.now()) <= twoMinutes\n}\n\nexport function getTimeUntilExpiry(session: SquidSession): number {\n return session.expires_at - Date.now()\n}\n"]}
@@ -1,2 +0,0 @@
1
- import {f}from'./chunk-QT7R3AXE.js';import i from'ora';import n from'chalk';function e(){return !!(process.env.CI||process.env.GITHUB_ACTIONS||process.env.GITLAB_CI||process.env.CIRCLECI)}var c={dots:{spinner:"dots"},moon:{spinner:"moon"},arc:{spinner:"arc"},bounce:{spinner:"bounce"},shark:{spinner:{interval:120,frames:["\u25B8 ","\u25B8\u25B8 ","\u25B8\u25B8\u25B8 ","\u25B8\u25B8\u25B8\u25B8"," \u25B8\u25B8\u25B8\u25B8"," \u25B8\u25B8\u25B8"," \u25B8\u25B8"," \u25B8"]}}};function t(o,a="shark"){if(e()||f()){let r={...i({text:o,spinner:"dots"}),start:()=>(e()||console.log(o),r),stop:()=>(e()||console.log(),r),succeed:()=>(e()||console.log(`${n.green("\u2713")} ${o}`),r),fail:()=>(e()||console.log(`${n.red("\u2717")} ${o}`),r),warn:()=>(e()||console.log(`${n.hex("#FF9800")("\u26A0")} ${o}`),r),info:()=>(e()||console.log(`${n.hex("#4FC3F7")("\u2139")} ${o}`),r),stopAndPersist:()=>(e()||console.log(`${o}`),r),clear:()=>r,render:()=>r,frame:()=>" ",text:o,isSpinning:false,indent:0,color:"cyan",prefixText:"",spinner:{interval:100,frames:[""]}};return r}return i({text:o,...c[a]}).start()}export{t as a};//# sourceMappingURL=chunk-ON3YIMVG.js.map
2
- //# sourceMappingURL=chunk-ON3YIMVG.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/output/index.ts","../src/lib/output/spinner.ts"],"names":["isCI","SPINNER_FRAMES","createSpinner","text","style","isJsonMode","silent","ora","chalk"],"mappings":"4EAMO,SAASA,CAAAA,EAAgB,CAC9B,OAAO,CAAC,EACN,OAAA,CAAQ,IAAI,EAAA,EACZ,OAAA,CAAQ,GAAA,CAAI,cAAA,EACZ,OAAA,CAAQ,GAAA,CAAI,SAAA,EACZ,OAAA,CAAQ,GAAA,CAAI,QAAA,CAEhB,CCTA,IAAMC,CAAAA,CAA8C,CAClD,KAAM,CAAE,OAAA,CAAS,MAAO,CAAA,CACxB,IAAA,CAAM,CAAE,QAAS,MAAO,CAAA,CACxB,GAAA,CAAK,CAAE,OAAA,CAAS,KAAM,EACtB,MAAA,CAAQ,CAAE,OAAA,CAAS,QAAS,CAAA,CAC5B,KAAA,CAAO,CAAE,OAAA,CAAS,CAAE,QAAA,CAAU,GAAA,CAAK,MAAA,CAAQ,CAAC,WAAA,CAAQ,iBAAQ,qBAAA,CAAQ,0BAAA,CAAQ,2BAAA,CAAS,sBAAA,CAAS,iBAAA,CAAS,YAAO,CAAE,CAAE,CACpH,CAAA,CAEO,SAASC,CAAAA,CAAcC,CAAAA,CAAcC,EAAqC,OAAA,CAAc,CAC7F,GAAIJ,CAAAA,EAAK,EAAKK,CAAAA,EAAW,CAAG,CAC1B,IAAMC,CAAAA,CAAc,CAClB,GAAGC,CAAAA,CAAI,CAAE,KAAAJ,CAAAA,CAAM,OAAA,CAAS,MAAO,CAAC,CAAA,CAChC,KAAA,CAAO,KAAaH,CAAAA,EAAK,EAAG,OAAA,CAAQ,GAAA,CAAIG,CAAI,CAAA,CAAUG,CAAAA,CAAAA,CACtD,KAAM,KAAaN,CAAAA,EAAK,EAAG,OAAA,CAAQ,GAAA,EAAI,CAAUM,CAAAA,CAAAA,CACjD,OAAA,CAAS,KAAaN,CAAAA,EAAK,EAAG,OAAA,CAAQ,GAAA,CAAI,CAAA,EAAGQ,EAAM,KAAA,CAAM,QAAG,CAAC,CAAA,CAAA,EAAIL,CAAI,CAAA,CAAE,EAAUG,CAAAA,CAAAA,CACjF,IAAA,CAAM,KAAaN,CAAAA,EAAK,EAAG,OAAA,CAAQ,IAAI,CAAA,EAAGQ,CAAAA,CAAM,GAAA,CAAI,QAAG,CAAC,CAAA,CAAA,EAAIL,CAAI,CAAA,CAAE,CAAA,CAAUG,CAAAA,CAAAA,CAC5E,IAAA,CAAM,KAAaN,CAAAA,EAAK,EAAG,QAAQ,GAAA,CAAI,CAAA,EAAGQ,CAAAA,CAAM,GAAA,CAAI,SAAS,CAAA,CAAE,QAAG,CAAC,CAAA,CAAA,EAAIL,CAAI,CAAA,CAAE,CAAA,CAAUG,CAAAA,CAAAA,CACvF,IAAA,CAAM,KAAaN,CAAAA,EAAK,EAAG,OAAA,CAAQ,GAAA,CAAI,CAAA,EAAGQ,CAAAA,CAAM,GAAA,CAAI,SAAS,CAAA,CAAE,QAAG,CAAC,CAAA,CAAA,EAAIL,CAAI,CAAA,CAAE,EAAUG,CAAAA,CAAAA,CACvF,cAAA,CAAgB,KAAaN,CAAAA,EAAK,EAAG,OAAA,CAAQ,IAAI,CAAA,EAAGG,CAAI,CAAA,CAAE,CAAA,CAAUG,CAAAA,CAAAA,CACpE,KAAA,CAAO,IAAeA,CAAAA,CACtB,MAAA,CAAQ,IAAeA,CAAAA,CACvB,KAAA,CAAO,IAAM,GAAA,CACb,IAAA,CAAAH,CAAAA,CACA,UAAA,CAAY,KAAA,CACZ,MAAA,CAAQ,CAAA,CACR,KAAA,CAAO,OACP,UAAA,CAAY,EAAA,CACZ,OAAA,CAAS,CAAE,QAAA,CAAU,GAAA,CAAK,MAAA,CAAQ,CAAC,EAAE,CAAE,CACzC,CAAA,CACA,OAAOG,CACT,CACA,OAAOC,CAAAA,CAAI,CAAE,IAAA,CAAAJ,CAAAA,CAAM,GAAGF,CAAAA,CAAeG,CAAK,CAAE,CAAC,CAAA,CAAE,KAAA,EACjD","file":"chunk-ON3YIMVG.js","sourcesContent":["export { renderMascot, renderBrandedMascot } from './mascot.js'\nexport { brand, brandDim, brandLine, success, error, warn, info, muted, copied, BRAND_MARKER, SUCCESS_MARK, ERROR_MARK, WARN_MARK, INFO_MARK, PROGRESS_MARK } from './brand.js'\nexport { setJsonMode, isJsonMode, log, logSuccess, logError, logWarn, logInfo, logBrand, logRaw, logJSON, logErrorJSON, writeAudit } from './logger.js'\nexport { createSpinner } from './spinner.js'\nexport { createTable, renderTable, renderCompactTable } from './table.js'\n\nexport function isCI(): boolean {\n return !!(\n process.env.CI ||\n process.env.GITHUB_ACTIONS ||\n process.env.GITLAB_CI ||\n process.env.CIRCLECI\n )\n}\n","import ora, { Ora } from 'ora'\nimport chalk from 'chalk'\nimport { isCI, isJsonMode } from './index.js'\n\nconst SPINNER_FRAMES: Record<string, ora.Options> = {\n dots: { spinner: 'dots' },\n moon: { spinner: 'moon' },\n arc: { spinner: 'arc' },\n bounce: { spinner: 'bounce' },\n shark: { spinner: { interval: 120, frames: ['▸ ', '▸▸ ', '▸▸▸ ', '▸▸▸▸', ' ▸▸▸▸', ' ▸▸▸', ' ▸▸', ' ▸'] } },\n}\n\nexport function createSpinner(text: string, style: keyof typeof SPINNER_FRAMES = 'shark'): Ora {\n if (isCI() || isJsonMode()) {\n const silent: Ora = {\n ...ora({ text, spinner: 'dots' }),\n start: () => { if (!isCI()) console.log(text); return silent },\n stop: () => { if (!isCI()) console.log(); return silent },\n succeed: () => { if (!isCI()) console.log(`${chalk.green('✓')} ${text}`); return silent },\n fail: () => { if (!isCI()) console.log(`${chalk.red('✗')} ${text}`); return silent },\n warn: () => { if (!isCI()) console.log(`${chalk.hex('#FF9800')('⚠')} ${text}`); return silent },\n info: () => { if (!isCI()) console.log(`${chalk.hex('#4FC3F7')('ℹ')} ${text}`); return silent },\n stopAndPersist: () => { if (!isCI()) console.log(`${text}`); return silent },\n clear: () => { return silent },\n render: () => { return silent },\n frame: () => ' ',\n text,\n isSpinning: false,\n indent: 0,\n color: 'cyan',\n prefixText: '',\n spinner: { interval: 100, frames: [''] },\n } as unknown as Ora\n return silent\n }\n return ora({ text, ...SPINNER_FRAMES[style] }).start()\n}\n"]}
@@ -1,2 +0,0 @@
1
- export{c as ApiError,g as apiDelete,d as apiGet,e as apiPost,f as apiPut,b as apiRequest,h as apiUpload}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-C5KZCYJ4.js';//# sourceMappingURL=client-FRNT7PEB.js.map
2
- //# sourceMappingURL=client-FRNT7PEB.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';async function m(i,e$1){let t=a(`Inviting ${e$1.email} to "${i}" as ${e$1.role}...`);t.start(),await e("/api/v1/collab/invite",{folder:i,email:e$1.email,role:e$1.role},{authenticated:true}),t.succeed(),g(`Invited ${e$1.email} to "${i}" as ${e$1.role}`);}export{m as default};//# sourceMappingURL=collab-invite-HUSQYV23.js.map
2
- //# sourceMappingURL=collab-invite-HUSQYV23.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import n from'inquirer';async function m(e$1){let{confirm:a$1}=await n.prompt([{type:"confirm",name:"confirm",message:`Remove yourself from "${e$1}"?`,default:false}]);if(!a$1)return;let t=a(`Leaving "${e$1}"...`);t.start(),await e("/api/v1/collab/leave",{folder:e$1},{authenticated:true}),t.succeed(),g(`You left "${e$1}"`);}export{m as default};//# sourceMappingURL=collab-leave-W2ESTT5L.js.map
2
- //# sourceMappingURL=collab-leave-W2ESTT5L.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';async function o(e$1,i){let m=a(`Removing ${i.email} from "${e$1}"...`);m.start(),await e("/api/v1/collab/remove",{folder:e$1,email:i.email},{authenticated:true}),m.succeed(),g(`Removed ${i.email} from "${e$1}"`);}export{o as default};//# sourceMappingURL=collab-remove-ZMB22U2T.js.map
2
- //# sourceMappingURL=collab-remove-ZMB22U2T.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import c from'inquirer';async function m(r,t){let{confirm:a$1}=await c.prompt([{type:"input",name:"confirm",message:`Type "${r}" to confirm ownership transfer to ${t.to}:`,validate:s=>s===r?true:"Type the exact folder name to confirm"}]);if(a$1!==r)return;let e$1=a(`Transferring ownership of "${r}" to ${t.to}...`);e$1.start(),await e("/api/v1/collab/transfer",{folder:r,new_owner:t.to},{authenticated:true}),e$1.succeed(),g(`Ownership of "${r}" transferred to ${t.to}`);}export{m as default};//# sourceMappingURL=collab-transfer-56MH4IT6.js.map
2
- //# sourceMappingURL=collab-transfer-56MH4IT6.js.map
@@ -1,3 +0,0 @@
1
- import {a as a$1}from'./chunk-MKRWNV2T.js';import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {h as h$1,i,f,m,g,c,b}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import h from'path';import P from'fs';import A from'clipboardy';import v from'chalk';import B from'cli-progress';async function F(d){let e=h.resolve(d),a=P.statSync(e);if(a.isFile())return h.extname(e).toLowerCase()===".html"?{type:"single-file",rootPath:e,hasIndexHtml:true,htmlFiles:[e],totalFiles:1}:{type:"invalid",rootPath:e,hasIndexHtml:false,htmlFiles:[],totalFiles:0};if(a.isDirectory()){let m=function(i){let u=P.readdirSync(i,{withFileTypes:true});for(let n of u){let c=h.join(i,n.name);n.isDirectory()?!n.name.startsWith(".")&&n.name!=="node_modules"&&m(c):n.isFile()&&(l++,n.name.endsWith(".html")&&t.push(c));}};let t=[],l=0;if(m(e),t.length===0)return {type:"invalid",rootPath:e,hasIndexHtml:false,htmlFiles:[],totalFiles:l};let o=t.some(i=>h.basename(i).toLowerCase()==="index.html");return {type:"codebase",rootPath:e,hasIndexHtml:o,htmlFiles:t,totalFiles:l}}return {type:"invalid",rootPath:e,hasIndexHtml:false,htmlFiles:[],totalFiles:0}}async function L(d,e$1){let a$2=d?h.resolve(d):process.cwd(),r=a("Analyzing project...");r.start();let t=await F(a$2);t.type==="invalid"&&(r.fail(),h$1(`No deployable content found at ${a$2}. Provide an HTML file or folder containing HTML files.`),process.exit(1)),t.type==="codebase"&&!t.hasIndexHtml&&(r.warn(),i("No index.html found at root. Scanning one level deep for entry point...")),r.text="Uploading files...";let l={source:a$2,type:t.type,slug:e$1?.name,environment:e$1?.env||(e$1?.preview?"preview":"production"),force:e$1?.force||false};if(t.type==="codebase"){let n=function(p){let y=P.readdirSync(p,{withFileTypes:true});for(let s of y){let f=h.join(p,s.name);s.isDirectory()?!s.name.startsWith(".")&&s.name!=="node_modules"&&n(f):s.isFile()&&(a$1(s.name)?i.push(f):u.push(f));}};let i=[],u=[];n(t.rootPath),!e$1?.force&&t.type==="codebase"&&(r.text="Computing diff...");let c=new B.SingleBar({format:`${v.hex("#7C4DFF")("\u25B8")} Uploading |${v.hex("#7C4DFF")("{bar}")}| {percentage}% | {value}/{total} files | {speed}`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:true});c.start(i.length,0);let w=new FormData,b=0;for(let p of i){let y=h.relative(t.rootPath,p),s=P.readFileSync(p),f=new Blob([s]);w.append("files",f,y),b++,c.update(b);}c.stop(),r.stop(),l.files=w;}if(t.type==="single-file"){let o=P.readFileSync(t.rootPath,"utf-8");l.htmlContent=o;}r.text="Deploying to SquidCloud...",r.start();try{let o=await e("/api/v1/deploy",l,{authenticated:!0});r.succeed();let i=o.url||`https://squidcloud.vercel.app/sites/${e$1?.name||o.deploy_id}`;try{await A.write(i);}catch{}if(f()){m(o);return}g("Deployed successfully!"),console.log(` ${v.hex("#4FC3F7")(i)} ${c("")}`),o.file_count&&console.log(` ${b(`${o.file_count} files \xB7 ${o.deploy_time_ms}ms`)}`);}catch(o){throw r.fail(),o}}
2
- export{L as default};//# sourceMappingURL=deploy-WK3VAA7D.js.map
3
- //# sourceMappingURL=deploy-WK3VAA7D.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {g}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g as g$1}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import n from'inquirer';async function m(o){let{confirm:t}=await n.prompt([{type:"confirm",name:"confirm",message:"Delete ALL submissions for this file request? This cannot be undone.",default:false}]);if(!t)return;let e=a("Clearing submissions...");e.start(),await g(`/api/v1/forms/${o}/submissions`,{authenticated:true}),e.succeed(),g$1("All submissions cleared");}export{m as default};//# sourceMappingURL=forms-clear-2ERBEAEY.js.map
2
- //# sourceMappingURL=forms-clear-2ERBEAEY.js.map
@@ -1,2 +0,0 @@
1
- import {a as a$1}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {f,m,g}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';async function a(r,c){let e$1=a$1(`Creating file request "${r}"...`);e$1.start();let t=await e("/api/v1/forms",{name:r,folder:c?.folder},{authenticated:true});if(e$1.succeed(),f()){m(t);return}g(`File request "${r}" created (${t.id.slice(0,8)})`);}export{a as default};//# sourceMappingURL=forms-create-3ONGTRQZ.js.map
2
- //# sourceMappingURL=forms-create-3ONGTRQZ.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {g}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g as g$1}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import s from'inquirer';async function p(t){let e=(await(await import('./client-FRNT7PEB.js')).apiGet(`/api/v1/forms/${t}`,{authenticated:true})).form.name,{confirm:o}=await s.prompt([{type:"input",name:"confirm",message:`Type "${e}" to permanently delete this file request and all submissions:`,validate:m=>m===e?true:"Type the exact name to confirm"}]);if(o!==e)return;let r=a("Deleting file request...");r.start(),await g(`/api/v1/forms/${t}`,{authenticated:true}),r.succeed(),g$1(`File request "${e}" deleted`);}export{p as default};//# sourceMappingURL=forms-delete-CKLGD52U.js.map
2
- //# sourceMappingURL=forms-delete-CKLGD52U.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {d}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import n from'fs';import p from'path';async function m(t){let o=a("Exporting submissions...");o.start();let c=await d(`/api/v1/forms/${t}/export`,{authenticated:true});o.succeed();let s=p.join(process.cwd(),`filereq-${t.slice(0,8)}-submissions.csv`);n.writeFileSync(s,c.csv,"utf-8"),g(`Exported to ${s}`);}export{m as default};//# sourceMappingURL=forms-export-WGHH5TBF.js.map
2
- //# sourceMappingURL=forms-export-WGHH5TBF.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import {a as a$1}from'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {j,k,a as a$2,g}from'./chunk-QT7R3AXE.js';import {m,a as a$3,b,c as c$1,j as j$1,k as k$1,d,h,e as e$1,f as f$1,g as g$1,n}from'./chunk-C5KZCYJ4.js';import C from'inquirer';import f from'os';import {blake3}from'@noble/hashes/blake3';function c(r){r.fill(0);}var M=process.env.SQUIDCLOUD_SERVER_PUB_KEY||"",l=null,i=null,t=null,p=null;async function N(r,u){let{pub:s,priv:e$2}=a$3();l=e$2,i=s,t=b(),p=c$1(u,r);let d$1=j$1(blake3(f.hostname()+f.platform()+f.arch())),g=Date.now(),o=await e("/api/auth/ssp/hello",{email:r,password_proof:j$1(p),client_ephemeral_pub:j$1(i),client_nonce:j$1(t),device_fingerprint:d$1,timestamp:g}),S=k$1(o.server_nonce),F=k$1(o.server_ephemeral_pub),H=k$1(o.server_signature),v=k$1(M);if(v.length>0){let j=d(t,S,i,g);if(!await h(H,j,v))throw I(),new Error("Connection rejected \u2014 server identity could not be verified")}let V=e$1(F,l),$=f$1(V,t,S),D=k$1(o.encrypted_session),O=k$1(o.session_iv),Y=k$1(o.session_tag),m=g$1(D,O,Y,$);return m.device_fingerprint=d$1,await n(m),I(),m}function I(){l&&c(l),i&&c(i),t&&c(t),p&&c(p),l=null,i=null,t=null,p=null;}async function Q(){let r=await m();if(r){j(`Already authenticated as ${r.user.email}`);let{force:e}=await C.prompt([{type:"confirm",name:"force",message:"Re-authenticate?",default:false}]);if(!e)return}let u=await C.prompt([{type:"input",name:"email",message:"Email:",validate:e=>e.includes("@")?true:"Please enter a valid email"},{type:"password",name:"password",message:"Password:",mask:"*"}]),s=a("Authenticating with SquidCloud...");s.start();try{let e=await N(u.email,u.password);s.succeed(),console.log(a$1()),k(`Welcome to SquidCloud, ${a$2(e.user.username)}!`),g(`Authenticated as ${e.user.email} (${e.user.plan})`);}catch(e){throw s.fail(),e}}export{Q as default};//# sourceMappingURL=login-JJ7YHQB5.js.map
2
- //# sourceMappingURL=login-JJ7YHQB5.js.map
@@ -1,2 +0,0 @@
1
- import {a}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {e}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import {o}from'./chunk-C5KZCYJ4.js';async function i(){let o$1=a("Revoking session...");o$1.start();try{await e("/api/auth/ssp/revoke",{},{authenticated:!0});}catch{}await o(),o$1.succeed(),g("Logged out successfully");}export{i as default};//# sourceMappingURL=logout-PS2XK3GB.js.map
2
- //# sourceMappingURL=logout-PS2XK3GB.js.map
@@ -1,2 +0,0 @@
1
- import {a as a$1}from'./chunk-ON3YIMVG.js';import'./chunk-6TS5Y27A.js';import {d}from'./chunk-RWWBBPEJ.js';import'./chunk-NDB6KXYI.js';import'./chunk-THMWE2I6.js';import {g}from'./chunk-QT7R3AXE.js';import'./chunk-C5KZCYJ4.js';import n from'fs';import p from'path';async function a(){let o=a$1("Exporting logs...");o.start();let i=await d("/api/v1/logs/export",{authenticated:true});o.succeed();let t=p.join(process.cwd(),`squidcloud-logs-${Date.now()}.jsonl`);n.writeFileSync(t,i.jsonl,"utf-8"),g(`Exported to ${t}`);}export{a as default};//# sourceMappingURL=logs-export-55G3COYK.js.map
2
- //# sourceMappingURL=logs-export-55G3COYK.js.map